package com.sencha.gxt.explorer.client.grid; import java.util.ArrayList; import java.util.Date; import java.util.List; import com.google.gwt.cell.client.DateCell; import com.google.gwt.core.client.EntryPoint; import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.Scheduler; import com.google.gwt.core.client.Scheduler.ScheduledCommand; import com.google.gwt.i18n.client.DateTimeFormat; import com.google.gwt.i18n.client.DateTimeFormat.PredefinedFormat; import com.google.gwt.user.client.rpc.AsyncCallback; 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.sencha.gxt.core.client.ValueProvider; import com.sencha.gxt.core.client.resources.ThemeStyles; import com.sencha.gxt.data.client.loader.RpcProxy; 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.PagingLoadConfig; import com.sencha.gxt.data.shared.loader.PagingLoadResult; import com.sencha.gxt.data.shared.loader.PagingLoader; import com.sencha.gxt.examples.resources.client.ExampleService; import com.sencha.gxt.examples.resources.client.ExampleServiceAsync; import com.sencha.gxt.examples.resources.client.model.Post; import com.sencha.gxt.explorer.client.model.Example.Detail; import com.sencha.gxt.widget.core.client.FramedPanel; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer; import com.sencha.gxt.widget.core.client.container.VerticalLayoutContainer.VerticalLayoutData; 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; import com.sencha.gxt.widget.core.client.grid.LiveGridView; import com.sencha.gxt.widget.core.client.grid.LiveToolItem; import com.sencha.gxt.widget.core.client.toolbar.ToolBar; public class LiveGridExample implements IsWidget, EntryPoint { interface PostProperties extends PropertyAccess
{ ValueProvider
date(); ValueProvider
forum(); ModelKeyProvider
id(); ValueProvider
subject(); ValueProvider
username(); } @Override public Widget asWidget() { final ExampleServiceAsync service = GWT.create(ExampleService.class); RpcProxy
> proxy = new RpcProxy
>() { @Override public void load(PagingLoadConfig loadConfig, AsyncCallback
> callback) { service.getPosts(loadConfig, callback); } }; PostProperties props = GWT.create(PostProperties.class); ListStore
store = new ListStore
(new ModelKeyProvider
() { @Override public String getKey(Post item) { return "" + item.getId(); } }); final PagingLoader
> gridLoader = new PagingLoader
>( proxy); gridLoader.setRemoteSort(true); ColumnConfig
forumColumn = new ColumnConfig
(props.forum(), 150, "Forum"); ColumnConfig
usernameColumn = new ColumnConfig
(props.username(), 150, "Username"); ColumnConfig
subjectColumn = new ColumnConfig
(props.subject(), 150, "Subject"); ColumnConfig
dateColumn = new ColumnConfig
(props.date(), 150, "Date"); dateColumn.setCell(new DateCell(DateTimeFormat.getFormat(PredefinedFormat.DATE_SHORT))); List
> l = new ArrayList
>(); l.add(forumColumn); l.add(usernameColumn); l.add(subjectColumn); l.add(dateColumn); final LiveGridView
liveGridView = new LiveGridView
(); liveGridView.setForceFit(true); ColumnModel
cm = new ColumnModel
(l); Grid
view = new Grid
(store, cm) { @Override protected void onAfterFirstAttach() { super.onAfterFirstAttach(); Scheduler.get().scheduleDeferred(new ScheduledCommand() { @Override public void execute() { gridLoader.load(0, liveGridView.getCacheSize()); } }); } }; view.setLoadMask(true); view.setLoader(gridLoader); view.setView(liveGridView); FramedPanel cp = new FramedPanel(); cp.setCollapsible(true); cp.setHeadingText("Live Grid Example"); cp.setPixelSize(600, 390); cp.addStyleName("margin-10"); VerticalLayoutContainer con = new VerticalLayoutContainer(); con.setBorders(true); con.add(view, new VerticalLayoutData(1, 1)); ToolBar toolBar = new ToolBar(); toolBar.add(new LiveToolItem(view)); toolBar.addStyleName(ThemeStyles.getStyle().borderTop()); toolBar.getElement().getStyle().setProperty("borderBottom", "none"); con.add(toolBar, new VerticalLayoutData(1, 25)); cp.setWidget(con); return cp; } @Override public void onModuleLoad() { RootPanel.get().add(this); } }