Grid with Dynamic Grouping Sample (Smart GWT) : Table Grouping « GWT « Java






Grid with Dynamic Grouping Sample (Smart GWT)

Grid with Dynamic Grouping Sample (Smart GWT)
   



/*
 * SmartGWT (GWT for SmartClient)
 * Copyright 2008 and beyond, Isomorphic Software, Inc.
 *
 * SmartGWT is free software; you can redistribute it and/or modify it
 * under the terms of the GNU Lesser General Public License version 3
 * as published by the Free Software Foundation.  SmartGWT is also
 * available under typical commercial license terms - see
 * http://smartclient.com/license
 * This software is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 */

package com.smartgwt.sample.showcase.client;

import com.google.gwt.core.client.EntryPoint;
import com.google.gwt.user.client.ui.RootPanel;
import com.smartgwt.client.data.DataSource;
import com.smartgwt.client.data.fields.DataSourceBooleanField;
import com.smartgwt.client.data.fields.DataSourceDateField;
import com.smartgwt.client.data.fields.DataSourceFloatField;
import com.smartgwt.client.data.fields.DataSourceIntegerField;
import com.smartgwt.client.data.fields.DataSourceLinkField;
import com.smartgwt.client.data.fields.DataSourceTextField;
import com.smartgwt.client.types.Alignment;
import com.smartgwt.client.types.ListGridFieldType;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.IButton;
import com.smartgwt.client.widgets.events.ClickEvent;
import com.smartgwt.client.widgets.events.ClickHandler;
import com.smartgwt.client.widgets.grid.ListGrid;
import com.smartgwt.client.widgets.grid.ListGridField;
import com.smartgwt.client.widgets.layout.HLayout;
import com.smartgwt.client.widgets.layout.VLayout;

public class Showcase implements EntryPoint {
  public void onModuleLoad() {

    RootPanel.get().add(getViewPanel());
  }

  public Canvas getViewPanel() {

    VLayout layout = new VLayout(15);

    CountryXmlDS dataSource = CountryXmlDS.getInstance();

    final ListGrid countryGrid = new ListGrid();
    countryGrid.setCanEdit(true);

    countryGrid.setWidth(522);
    countryGrid.setHeight(224);
    countryGrid.setAlternateRecordStyles(true);
    countryGrid.setShowAllRecords(true);
    countryGrid.setCellHeight(22);

    countryGrid.setGroupStartOpen("all");
    countryGrid.setGroupByField("continent");
    countryGrid.setDataSource(dataSource);

    ListGridField countryCodeField = new ListGridField("countryCode", "Flag", 40);
    countryCodeField.setAlign(Alignment.CENTER);
    countryCodeField.setType(ListGridFieldType.IMAGE);
    countryCodeField.setImageURLPrefix("flags/16/");
    countryCodeField.setImageURLSuffix(".png");
    countryCodeField.setCanEdit(false);

    ListGridField nameField = new ListGridField("countryName");

    ListGridField governmentField = new ListGridField("government");
    ListGridField continentField = new ListGridField("continent");
    countryGrid.setFields(countryCodeField, nameField, governmentField, continentField);

    countryGrid.setAutoFetchData(true);

    HLayout buttonLayout = new HLayout(15);

    IButton unGroupButton = new IButton("Ungroup");
    unGroupButton.addClickHandler(new ClickHandler() {
        public void onClick(ClickEvent event) {
            countryGrid.ungroup();
        }
    });


    IButton groupByButton = new IButton("Group By Continent");
    groupByButton.setWidth(140);
    groupByButton.addClickHandler(new ClickHandler() {
        public void onClick(ClickEvent event) {
            countryGrid.groupBy("continent");
        }
    });

    buttonLayout.addMember(unGroupButton);
    buttonLayout.addMember(groupByButton);
    
    layout.addMember(countryGrid);
    layout.addMember(buttonLayout);

    return layout;

  }

}
class CountryXmlDS extends DataSource {

  private static CountryXmlDS instance = null;

  public static CountryXmlDS getInstance() {
      if (instance == null) {
          instance = new CountryXmlDS("countryDS");
      }
      return instance;
  }

  public CountryXmlDS(String id) {

      setID(id);
      setRecordXPath("/List/country");
      DataSourceIntegerField pkField = new DataSourceIntegerField("pk");
      pkField.setHidden(true);
      pkField.setPrimaryKey(true);

      DataSourceTextField countryCodeField = new DataSourceTextField("countryCode", "Code");
      countryCodeField.setRequired(true);

      DataSourceTextField countryNameField = new DataSourceTextField("countryName", "Country");
      countryNameField.setRequired(true);

      DataSourceTextField capitalField = new DataSourceTextField("capital", "Capital");
      DataSourceTextField governmentField = new DataSourceTextField("government", "Government", 500);

      DataSourceBooleanField memberG8Field = new DataSourceBooleanField("member_g8", "G8");

      DataSourceTextField continentField = new DataSourceTextField("continent", "Continent");
      continentField.setValueMap("Europe", "Asia", "North America", "Australia/Oceania", "South America", "Africa");

      DataSourceDateField independenceField = new DataSourceDateField("independence", "Nationhood");
      DataSourceFloatField areaField = new DataSourceFloatField("area", "Area (km²)");
      DataSourceIntegerField populationField = new DataSourceIntegerField("population", "Population");
      DataSourceFloatField gdpField = new DataSourceFloatField("gdp", "GDP ($M)");
      DataSourceLinkField articleField = new DataSourceLinkField("article", "Info");

      setFields(pkField, countryCodeField, countryNameField, capitalField, governmentField,
              memberG8Field, continentField, independenceField, areaField, populationField,
              gdpField, articleField);

      setDataURL("ds/test_data/country.data.xml");
      setClientOnly(true);
  }
}

   
    
    
  








SmartGWT.zip( 9,880 k)

Related examples in the same category

1.Grid with Custom Grouping Sample (Smart GWT)Grid with Custom Grouping Sample (Smart GWT)
2.Grid Grouped Editing Sample (Smart GWT)Grid Grouped Editing Sample (Smart GWT)
3.Column grouping with Widget (Ext GWT)Column grouping with Widget (Ext GWT)
4.Three-level column grouping (Ext GWT)Three-level column grouping (Ext GWT)
5.Using GroupingStore to load grouped grid data (Ext GWT)Using GroupingStore to load grouped grid data (Ext GWT)
6.Using GroupingView to display grouped grid data (Ext GWT)Using GroupingView to display grouped grid data (Ext GWT)