package com.sencha.gxt.explorer.client.grid; import java.util.ArrayList; import java.util.List; import com.google.gwt.core.client.EntryPoint; import com.google.gwt.core.client.GWT; import com.google.gwt.editor.client.Editor.Path; import com.google.gwt.http.client.RequestBuilder; import com.google.gwt.user.client.ui.IsWidget; import com.google.gwt.user.client.ui.RootPanel; import com.google.gwt.user.client.ui.Widget; import com.google.web.bindery.autobean.shared.AutoBean; import com.google.web.bindery.autobean.shared.AutoBeanFactory; import com.sencha.gxt.core.client.ValueProvider; import com.sencha.gxt.data.client.loader.HttpProxy; import com.sencha.gxt.data.shared.ListStore; import com.sencha.gxt.data.shared.ModelKeyProvider; import com.sencha.gxt.data.shared.PropertyAccess; import com.sencha.gxt.data.shared.loader.ListLoadResultBean; import com.sencha.gxt.data.shared.loader.JsonReader; import com.sencha.gxt.data.shared.loader.ListLoadConfig; import com.sencha.gxt.data.shared.loader.ListLoadResult; import com.sencha.gxt.data.shared.loader.ListLoader; import com.sencha.gxt.data.shared.loader.LoadResultListStoreBinding; import com.sencha.gxt.explorer.client.model.Example.Detail; import com.sencha.gxt.widget.core.client.FramedPanel; import com.sencha.gxt.widget.core.client.button.TextButton; import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutPack; import com.sencha.gxt.widget.core.client.event.SelectEvent; import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler; import com.sencha.gxt.widget.core.client.grid.ColumnConfig; import com.sencha.gxt.widget.core.client.grid.ColumnModel; import com.sencha.gxt.widget.core.client.grid.Grid; public class JsonGridExample implements IsWidget, EntryPoint { public interface EmailAutoBeanFactory extends AutoBeanFactory { AutoBean
items(); AutoBean
loadConfig(); } public interface Email { String getName(); String getEmail(); String getPhone(); String getState(); String getZip(); } /** * Defines the structure of the root JSON object being returned by the server. * This class is needed as we cannot return a list of objects. Instead, we * return a single object with a single property that contains the data * records. */ public interface RecordResult { List
getRecords(); } class DataRecordJsonReader extends JsonReader
, RecordResult> { public DataRecordJsonReader(AutoBeanFactory factory, Class
rootBeanType) { super(factory, rootBeanType); } @Override protected ListLoadResult
createReturnData(Object loadConfig, RecordResult incomingData) { return new ListLoadResultBean
(incomingData.getRecords()); } } interface EmailProperties extends PropertyAccess
{ @Path("name") ModelKeyProvider
key(); ValueProvider
name(); ValueProvider
email(); ValueProvider
phone(); ValueProvider
state(); ValueProvider
zip(); } @Override public void onModuleLoad() { RootPanel.get().add(this); } @Override public Widget asWidget() { EmailAutoBeanFactory factory = GWT.create(EmailAutoBeanFactory.class); DataRecordJsonReader reader = new DataRecordJsonReader(factory, RecordResult.class); String path = "data/data.json"; RequestBuilder builder = new RequestBuilder(RequestBuilder.GET, path); HttpProxy
proxy = new HttpProxy
(builder); final ListLoader
> loader = new ListLoader
>( proxy, reader); loader.useLoadConfig(factory.create(ListLoadConfig.class).as()); EmailProperties props = GWT.create(EmailProperties.class); ListStore
store = new ListStore
(props.key()); loader.addLoadHandler(new LoadResultListStoreBinding
>(store)); ColumnConfig
cc1 = new ColumnConfig
(props.name(), 100, "Sender"); ColumnConfig
cc2 = new ColumnConfig
(props.email(), 165, "Email"); ColumnConfig
cc3 = new ColumnConfig
(props.phone(), 100, "Phone"); ColumnConfig
cc4 = new ColumnConfig
(props.state(), 50, "State"); ColumnConfig
cc5 = new ColumnConfig
(props.zip(), 65, "Zip Code"); List
> l = new ArrayList
>(); l.add(cc1); l.add(cc2); l.add(cc3); l.add(cc4); l.add(cc5); ColumnModel
cm = new ColumnModel
(l); Grid
grid = new Grid
(store, cm); grid.getView().setForceFit(true); grid.setLoader(loader); grid.setLoadMask(true); grid.setBorders(true); grid.getView().setEmptyText("Please hit the load button."); FramedPanel cp = new FramedPanel(); cp.setHeadingText("Json Grid Example"); cp.setCollapsible(true); cp.setAnimCollapse(true); cp.setWidget(grid); cp.setPixelSize(575, 350); cp.addStyleName("margin-10"); cp.setButtonAlign(BoxLayoutPack.CENTER); cp.addButton(new TextButton("Load Json", new SelectHandler() { @Override public void onSelect(SelectEvent event) { loader.load(); } })); return cp; } }