Mega Code Archive

 
Categories / Java / GWT
 

Column grouping with Widget (Ext GWT)

/*  * Ext GWT - Ext for GWT  * Copyright(c) 2007-2009, Ext JS, LLC.  * licensing@extjs.com  *   * http://extjs.com/license  */     package com.google.gwt.sample.hello.client; import java.util.ArrayList; import java.util.Date; import java.util.List; import com.extjs.gxt.ui.client.Style.HorizontalAlignment; import com.extjs.gxt.ui.client.data.BaseModel; import com.extjs.gxt.ui.client.event.ButtonEvent; import com.extjs.gxt.ui.client.event.Events; import com.extjs.gxt.ui.client.event.Listener; import com.extjs.gxt.ui.client.store.ListStore; import com.extjs.gxt.ui.client.widget.ContentPanel; import com.extjs.gxt.ui.client.widget.LayoutContainer; import com.extjs.gxt.ui.client.widget.Slider; import com.extjs.gxt.ui.client.widget.VerticalPanel; import com.extjs.gxt.ui.client.widget.button.Button; import com.extjs.gxt.ui.client.widget.grid.ColumnConfig; import com.extjs.gxt.ui.client.widget.grid.ColumnData; import com.extjs.gxt.ui.client.widget.grid.ColumnModel; import com.extjs.gxt.ui.client.widget.grid.Grid; import com.extjs.gxt.ui.client.widget.grid.GridCellRenderer; import com.extjs.gxt.ui.client.widget.grid.HeaderGroupConfig; import com.extjs.gxt.ui.client.widget.layout.FitLayout; import com.extjs.gxt.ui.client.widget.table.NumberCellRenderer; import com.google.gwt.core.client.EntryPoint; import com.google.gwt.i18n.client.DateTimeFormat; import com.google.gwt.i18n.client.NumberFormat; import com.google.gwt.user.client.Element; import com.google.gwt.user.client.ui.FlexTable; import com.google.gwt.user.client.ui.RootPanel; public class Hello implements EntryPoint {   public void onModuleLoad() {     RootPanel.get().add(new ColumnGroupingExample());   } } class ColumnGroupingExample extends LayoutContainer {   private NumberFormat currency = NumberFormat.getCurrencyFormat();   private NumberFormat number = NumberFormat.getFormat("0.00");   private NumberCellRenderer<Grid<Stock>> numberRenderer;   private GridCellRenderer<Stock> change;   private GridCellRenderer<Stock> gridNumber;   private VerticalPanel vp;   @Override   protected void onRender(Element parent, int index) {     super.onRender(parent, index);     numberRenderer = new NumberCellRenderer<Grid<Stock>>(currency);     change = new GridCellRenderer<Stock>() {       public String render(Stock model, String property, ColumnData config, int rowIndex, int colIndex,           ListStore<Stock> store, Grid<Stock> grid) {         double val = (Double) model.get(property);         String style = val < 0 ? "red" : "green";         return "<span style='color:" + style + "'>" + number.format(val) + "</span>";       }     };     gridNumber = new GridCellRenderer<Stock>() {       public String render(Stock model, String property, ColumnData config, int rowIndex, int colIndex,           ListStore<Stock> store, Grid<Stock> grid) {         return numberRenderer.render(null, property, model.get(property));       }     };     vp = new VerticalPanel();     vp.setSpacing(20);     createGrid(false);     createGrid(true);     add(vp);   }   private void createGrid(boolean widget) {     List<ColumnConfig> configs = new ArrayList<ColumnConfig>();     ColumnConfig column = new ColumnConfig();     column.setId("name");     column.setHeader("Company");     column.setWidth(200);     configs.add(column);     column = new ColumnConfig();     column.setId("symbol");     column.setHeader("Symbol");     column.setWidth(100);     configs.add(column);     column = new ColumnConfig();     column.setId("last");     column.setHeader("Last");     column.setAlignment(HorizontalAlignment.RIGHT);     column.setWidth(75);     column.setRenderer(gridNumber);     configs.add(column);     column = new ColumnConfig("change", "Change", 100);     column.setAlignment(HorizontalAlignment.RIGHT);     column.setRenderer(change);     configs.add(column);     column = new ColumnConfig("date", 125);     if (widget) {       Button btn = new Button("Updated");       btn.addListener(Events.OnClick, new Listener<ButtonEvent>() {         public void handleEvent(ButtonEvent be) {           // stop column from getting click and causing sort           be.cancelBubble();         }       });       btn.setStyleAttribute("float", "left");       column.setWidget(btn, "Last Updated");     } else {       column.setAlignment(HorizontalAlignment.RIGHT);       column.setHeader("Last Updated");     }     column.setDateTimeFormat(DateTimeFormat.getShortDateFormat());     configs.add(column);     ListStore<Stock> store = new ListStore<Stock>();     store.add(getStocks());     ColumnModel cm = new ColumnModel(configs);     cm.addHeaderGroup(0, 0, new HeaderGroupConfig("Header Grouping Example", 1, 5));     cm.addHeaderGroup(1, 2, new HeaderGroupConfig("Stock Performance", 1, 2));     if (widget) {       Slider s = new Slider();       s.setWidth(100);       // ugly, but centers slider       FlexTable tbl = new FlexTable();       tbl.setWidth("100%");       tbl.setHTML(0, 0, "&nbsp;");       tbl.setHTML(0, 1, "<span style='white-space: nowrap;font-size: 11px'>Slide Me: &nbsp;</span>");       tbl.setWidget(0, 2, s);       tbl.setHTML(0, 3, "&nbsp;");       tbl.getCellFormatter().setWidth(0, 0, "50%");       tbl.getCellFormatter().setWidth(0, 3, "50%");       cm.addHeaderGroup(1, 0, new HeaderGroupConfig(tbl, 1, 2));     } else {       cm.addHeaderGroup(1, 0, new HeaderGroupConfig("Stock Information", 1, 2));     }     ContentPanel cp = new ContentPanel();     cp.setBodyBorder(false);     //cp.setIcon(Resources.ICONS.table());     cp.setHeading(widget ? "Column Grouping with Widget" : "Column Grouping");     cp.setButtonAlign(HorizontalAlignment.CENTER);     cp.setLayout(new FitLayout());     cp.setSize(600, 300);     Grid<Stock> grid = new Grid<Stock>(store, cm);     grid.setStyleAttribute("borderTop", "none");     grid.getView().setForceFit(true);     grid.setBorders(true);     cp.add(grid);     vp.add(cp);   }   public static List<Stock> getStocks() {     List<Stock> stocks = new ArrayList<Stock>();     stocks.add(new Stock("Apple Inc.", "AAPL", 125.64, 123.43));     stocks.add(new Stock("Cisco Systems, Inc.", "CSCO", 25.84, 26.3));     stocks.add(new Stock("Google Inc.", "GOOG", 516.2, 512.6));     stocks.add(new Stock("Intel Corporation", "INTC", 21.36, 21.53));     stocks.add(new Stock("Level 3 Communications, Inc.", "LVLT", 5.55, 5.54));     stocks.add(new Stock("Microsoft Corporation", "MSFT", 29.56, 29.72));     stocks.add(new Stock("Nokia Corporation (ADR)", "NOK", 27.83, 27.93));     stocks.add(new Stock("Oracle Corporation", "ORCL", 18.73, 18.98));     stocks.add(new Stock("Starbucks Corporation", "SBUX", 27.33, 27.36));     stocks.add(new Stock("Yahoo! Inc.", "YHOO", 26.97, 27.29));     stocks.add(new Stock("Applied Materials, Inc.", "AMAT", 18.4, 18.66));     stocks.add(new Stock("Comcast Corporation", "CMCSA", 25.9, 26.4));     stocks.add(new Stock("Sirius Satellite", "SIRI", 2.77, 2.74));     stocks.add(new Stock("Tellabs, Inc.", "TLAB", 10.64, 10.75));     stocks.add(new Stock("eBay Inc.", "EBAY", 30.43, 31.21));     stocks.add(new Stock("Broadcom Corporation", "BRCM", 30.88, 30.48));     stocks.add(new Stock("CMGI Inc.", "CMGI", 2.14, 2.13));     stocks.add(new Stock("Amgen, Inc.", "AMGN", 56.22, 57.02));     stocks.add(new Stock("Limelight Networks", "LLNW", 23, 22.11));     stocks.add(new Stock("Amazon.com, Inc.", "AMZN", 72.47, 72.23));     stocks.add(new Stock("E TRADE Financial Corporation", "ETFC", 24.32, 24.58));     stocks.add(new Stock("AVANIR Pharmaceuticals", "AVNR", 3.7, 3.52));     stocks.add(new Stock("Gemstar-TV Guide, Inc.", "GMST", 4.41, 4.55));     stocks.add(new Stock("Akamai Technologies, Inc.", "AKAM", 43.08, 45.32));     stocks.add(new Stock("Motorola, Inc.", "MOT", 17.74, 17.69));     stocks.add(new Stock("Advanced Micro Devices, Inc.", "AMD", 13.77, 13.98));     stocks.add(new Stock("General Electric Company", "GE", 36.8, 36.91));     stocks.add(new Stock("Texas Instruments Incorporated", "TXN", 35.02, 35.7));     stocks.add(new Stock("Qwest Communications", "Q", 9.9, 10.03));     stocks.add(new Stock("Tyco International Ltd.", "TYC", 33.48, 33.26));     stocks.add(new Stock("Pfizer Inc.", "PFE", 26.21, 26.19));     stocks.add(new Stock("Time Warner Inc.", "TWX", 20.3, 20.45));     stocks.add(new Stock("Sprint Nextel Corporation", "S", 21.85, 21.76));     stocks.add(new Stock("Bank of America Corporation", "BAC", 49.92, 49.73));     stocks.add(new Stock("Taiwan Semiconductor", "TSM", 10.4, 10.52));     stocks.add(new Stock("AT&T Inc.", "T", 39.7, 39.66));     stocks.add(new Stock("United States Steel Corporation", "X", 115.81, 114.62));     stocks.add(new Stock("Exxon Mobil Corporation", "XOM", 81.77, 81.86));     stocks.add(new Stock("Valero Energy Corporation", "VLO", 72.46, 72.6));     stocks.add(new Stock("Micron Technology, Inc.", "MU", 12.02, 12.27));     stocks.add(new Stock("Verizon Communications Inc.", "VZ", 42.5, 42.61));     stocks.add(new Stock("Avaya Inc.", "AV", 16.96, 16.96));     stocks.add(new Stock("The Home Depot, Inc.", "HD", 37.66, 37.79));     stocks.add(new Stock("First Data Corporation", "FDC", 32.7, 32.65));     return stocks;   } } class Stock extends BaseModel {   public Stock() {   }   public Stock(String name, String symbol, double open, double last) {     set("name", name);     set("symbol", symbol);     set("open", open);     set("last", last);     set("date", new Date());     set("change", last - open);   }   public Stock(String name, double open, double change, double pctChange, Date date, String industry) {     set("name", name);     set("open", open);     set("change", change);     set("percentChange", pctChange);     set("date", date);     set("industry", industry);   }   public String getIndustry() {     return get("industry");   }   public void setIndustry(String industry) {     set("industry", industry);   }   public Date getLastTrans() {     return (Date) get("date");   }   public String getName() {     return (String) get("name");   }   public String getSymbol() {     return (String) get("symbol");   }   public double getOpen() {     Double open = (Double) get("open");     return open.doubleValue();   }   public double getLast() {     Double open = (Double) get("last");     return open.doubleValue();   }   public double getChange() {     return getLast() - getOpen();   }   public double getPercentChange() {     return getChange() / getOpen();   }   public String toString() {     return getName();   } }        Ext-GWT.zip( 4,297 k)