Adaptive Filter Sample (Smart GWT) : Table Filter Sorter « GWT « Java

Home
Java
1.2D Graphics GUI
2.3D
3.Advanced Graphics
4.Ant
5.Apache Common
6.Chart
7.Class
8.Collections Data Structure
9.Data Type
10.Database SQL JDBC
11.Design Pattern
12.Development Class
13.EJB3
14.Email
15.Event
16.File Input Output
17.Game
18.Generics
19.GWT
20.Hibernate
21.I18N
22.J2EE
23.J2ME
24.JDK 6
25.JNDI LDAP
26.JPA
27.JSP
28.JSTL
29.Language Basics
30.Network Protocol
31.PDF RTF
32.Reflection
33.Regular Expressions
34.Scripting
35.Security
36.Servlets
37.Spring
38.Swing Components
39.Swing JFC
40.SWT JFace Eclipse
41.Threads
42.Tiny Application
43.Velocity
44.Web Services SOA
45.XML
Java Tutorial
Java Source Code / Java Documentation
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Java » GWT » Table Filter SorterScreenshots 
Adaptive Filter Sample (Smart GWT)
Adaptive Filter 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.Timer;
import com.google.gwt.user.client.ui.RootPanel;
import com.smartgwt.client.data.DSRequest;
import com.smartgwt.client.data.DSResponse;
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.DataSourceEnumField;
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.util.SC;
import com.smartgwt.client.widgets.Canvas;
import com.smartgwt.client.widgets.Label;
import com.smartgwt.client.widgets.form.validator.FloatPrecisionValidator;
import com.smartgwt.client.widgets.form.validator.FloatRangeValidator;
import com.smartgwt.client.widgets.grid.ListGrid;
import com.smartgwt.client.widgets.grid.ListGridField;

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

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

  public Canvas getViewPanel() {

    Canvas canvas = new Canvas();

    final ServerCountLabel serverCountLabel = new ServerCountLabel();

    ItemSupplyXmlDS supplyXmlDS = new ItemSupplyXmlDS(SC.generateID()) {

      // this approach logs simulated server trips for DataSources with
      // clientOnly:true
      // so that no server is required. Since this example has a clientOnly
      // datasource that loads data
      // from a static xml, use the simulated server trips getClientOnlyResponse
      // override point.
      // If working with a real server that returns data dynamically based on
      // start/end row, override
      // transformResponse instead.

      @Override
      public DSResponse getClientOnlyResponse(DSRequest request) {
        DSResponse response = super.getClientOnlyResponse(request);
        int totalRows = response.getTotalRows();
        int startRow = response.getStartRow();
        int endRow = response.getEndRow();
        serverCountLabel.incrementAndUpdate(totalRows, startRow, endRow);
        serverCountLabel.setBackgroundColor("ffff77");
        new Timer() {
          public void run() {
            serverCountLabel.setBackgroundColor("ffffff");
          }
        }.schedule(500);

        return response;
      }
    };

    // when working with a server that dynamically returns the response based on
    // start row, end row,
    // use can override transformResponse instead of getClientOnlyResponse
    /*
     * protected void transformResponse(DSResponse response, DSRequest request,
     * Object data) { int totalRows = response.getTotalRows(); int startRow =
     * response.getStartRow(); int endRow = response.getEndRow();
     * serverCountLabel.incrementAndUpdate(totalRows, startRow, endRow);
     * serverCountLabel.setBackgroundColor("ffff77"); new Timer() { public void
     * run() { serverCountLabel.setBackgroundColor("ffffff"); } }.schedule(500); }
     */

    final ListGrid supplyItemGrid = new ListGrid();
    supplyItemGrid.setWidth(500);
    supplyItemGrid.setHeight(300);
    supplyItemGrid.setAlternateRecordStyles(true);
    supplyItemGrid.setAutoFetchData(true);
    supplyItemGrid.setShowFilterEditor(true);
    supplyItemGrid.setFilterOnKeypress(true);
    supplyItemGrid.setFetchDelay(500);
    supplyItemGrid.setDataSource(supplyXmlDS);

    ListGridField skuField = new ListGridField("SKU"100);
    ListGridField nameField = new ListGridField("itemName"150);
    ListGridField descriptionField = new ListGridField("description"250);
    ListGridField categoryField = new ListGridField("category"100);

    supplyItemGrid.setFields(skuField, nameField, descriptionField, categoryField);

    canvas.addChild(supplyItemGrid);
    canvas.addChild(serverCountLabel);

    return canvas;
  }

  class ServerCountLabel extends Label {
    private int count = 0;

    ServerCountLabel() {
      setContents("<b>Number of server trips : 0</b>");
      setTop(320);
      setPadding(10);
      setWidth(500);
      setHeight(30);
      setBorder("1px solid black");
    }

    public void incrementAndUpdate(int totalRows, int startRow, int endRow) {
      count++;
      setContents("<b>Number of server trips: " + count + "<br/>Total rows in this filter set: "
          + totalRows + "<br/>Last range of records returned: " + startRow + " to " + endRow
          "</b>");
    }
  }

}

class SupplyCategoryXmlDS extends DataSource {

  private static SupplyCategoryXmlDS instance = null;

  public static SupplyCategoryXmlDS getInstance() {
    if (instance == null) {
      instance = new SupplyCategoryXmlDS("supplyCategoryDS");
    }
    return instance;
  }

  public SupplyCategoryXmlDS(String id) {

    setID(id);
    setRecordXPath("/List/supplyCategory");

    DataSourceTextField itemNameField = new DataSourceTextField("categoryName""Item"128true);
    itemNameField.setPrimaryKey(true);

    DataSourceTextField parentField = new DataSourceTextField("parentID"null);
    parentField.setHidden(true);
    parentField.setRequired(true);
    parentField.setRootValue("root");
    parentField.setForeignKey("supplyCategoryDS.categoryName");

    setFields(itemNameField, parentField);

    setDataURL("ds/test_data/supplyCategory.data.xml");

    setClientOnly(true);

  }
}

class ItemSupplyXmlDS extends DataSource {

  private static ItemSupplyXmlDS instance = null;

  public static ItemSupplyXmlDS getInstance() {
    if (instance == null) {
      instance = new ItemSupplyXmlDS("supplyItemDS");
    }
    return instance;
  }

  public ItemSupplyXmlDS(String id) {

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

    DataSourceTextField itemNameField = new DataSourceTextField("itemName""Item Name"128true);
    DataSourceTextField skuField = new DataSourceTextField("SKU""SKU"10true);

    DataSourceTextField descriptionField = new DataSourceTextField("description""Description",
        2000);
    DataSourceTextField categoryField = new DataSourceTextField("category""Category"128true);
    categoryField.setForeignKey("supplyCategoryDS.categoryName");

    DataSourceEnumField unitsField = new DataSourceEnumField("units""Units"5);
    unitsField.setValueMap("Roll""Ea""Pkt""Set""Tube""Pad""Ream""Tin""Bag""Ctn",
        "Box");

    DataSourceFloatField unitCostField = new DataSourceFloatField("unitCost""Unit Cost"5);
    FloatRangeValidator rangeValidator = new FloatRangeValidator();
    rangeValidator.setMin(0);
    rangeValidator.setErrorMessage("Please enter a valid (positive) cost");

    FloatPrecisionValidator precisionValidator = new FloatPrecisionValidator();
    precisionValidator.setPrecision(2);
    precisionValidator.setErrorMessage("The maximum allowed precision is 2");

    unitCostField.setValidators(rangeValidator, precisionValidator);

    DataSourceBooleanField inStockField = new DataSourceBooleanField("inStock""In Stock");

    DataSourceDateField nextShipmentField = new DataSourceDateField("nextShipment""Next Shipment");

    setFields(pkField, itemNameField, skuField, descriptionField, categoryField, unitsField,
        unitCostField, inStockField, nextShipmentField);

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

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&amp;sup2;)");
    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 Nested Filter Bulder Sample (Smart GWT)Grid Nested Filter Bulder Sample (Smart GWT)
2.Grid Disable Filter Sample (Smart GWT)Grid Disable Filter Sample (Smart GWT)
3.Grid Filter Sample (Smart GWT)Grid Filter Sample (Smart GWT)
4.Grid Live Filter Sample (Smart GWT)Grid Live Filter Sample (Smart GWT)
5.This grid shows the sort-direction arrow in the top-right corner only (Smart GWT)This grid shows the sort-direction arrow in the top-right corner only (Smart GWT)
6.To reverse the sort direction, click on the same column header, or the top-right corner of the grid. (Smart GWT)To reverse the sort direction, click on the same column header, or the top-right corner of the grid. (Smart GWT)
7.Sorting is disabled on the Flag column (Smart GWT)Sorting is disabled on the Flag column (Smart GWT)
8.Reordering TreeGrid (Ext GWT)Reordering TreeGrid (Ext GWT)
9.Reordering grid (Ext GWT)Reordering grid (Ext GWT)
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.