/* * GWT-Ext Widget Library * Copyright(c) 2007-2008, GWT-Ext. * licensing@gwt-ext.com * * http://www.gwt-ext.com/license */ package com.gwtext.tutorials.client; import com.google.gwt.core.client.EntryPoint; import com.google.gwt.user.client.ui.RootPanel; import com.gwtext.client.core.SortDir; import com.gwtext.client.core.TextAlign; import com.gwtext.client.data.*; import com.gwtext.client.util.DateUtil; import com.gwtext.client.util.Format; import com.gwtext.client.widgets.*; import com.gwtext.client.widgets.event.ButtonListenerAdapter; import com.gwtext.client.widgets.event.PanelListenerAdapter; import com.gwtext.client.widgets.grid.*; import java.util.Date; public class RemotePagingSample implements EntryPoint { private GridPanel grid; private boolean showPreview = true; private Renderer renderTopic = new Renderer() { public String render(Object value, CellMetadata cellMetadata, Record record, int rowIndex, int colNum, Store store) { return Format.format("
{0}
{1} Forum
", new String[]{(String) value, record.getAsString("forumtitle"), record.getId(), record.getAsString("forumid"), }); } }; private Renderer renderLast = new Renderer() { public String render(Object value, CellMetadata cellMetadata, Record record, int rowIndex, int colNum, Store store) { Date lastPost = record.getAsDate("lastpost"); String lastPostStr = DateUtil.format(lastPost, "M j, Y, g:i a"); return Format.format("{0}
by {1}", new String[]{lastPostStr, record.getAsString("lastposter")}); } }; public void onModuleLoad() { Panel panel = new Panel(); panel.setBorder(false); panel.setPaddings(15); DataProxy dataProxy = new ScriptTagProxy("http://extjs.com/forum/topics-browse-remote.php"); final RecordDef recordDef = new RecordDef(new FieldDef[]{ new StringFieldDef("title"), new StringFieldDef("forumtitle"), new StringFieldDef("forumid"), new StringFieldDef("author"), new IntegerFieldDef("replycount"), new DateFieldDef("lastpost", "lastpost", "timestamp"), new StringFieldDef("lastposter"), new StringFieldDef("excerpt") }); JsonReader reader = new JsonReader(recordDef); reader.setRoot("topics"); reader.setTotalProperty("totalCount"); reader.setId("threadid"); final Store store = new Store(dataProxy, reader, true); store.setDefaultSort("lastpost", SortDir.DESC); ColumnConfig topicColumn = new ColumnConfig("Topic", "title", 420, false, renderTopic, "topic"); topicColumn.setCss("white-space:normal;"); ColumnConfig authorColumn = new ColumnConfig("Author", "author", 100); authorColumn.setHidden(true); ColumnConfig repliesColumn = new ColumnConfig("Replies", "replycount", 70); repliesColumn.setAlign(TextAlign.RIGHT); ColumnConfig lastPostColumn = new ColumnConfig("Last Post", "lastPost", 150, true, renderLast, "last"); ColumnModel columnModel = new ColumnModel(new ColumnConfig[]{ topicColumn, authorColumn, repliesColumn, lastPostColumn }); columnModel.setDefaultSortable(true); grid = new GridPanel(); grid.setWidth(700); grid.setHeight(500); grid.setTitle("Remote Paging Grid "); grid.setStore(store); grid.setColumnModel(columnModel); grid.setTrackMouseOver(false); grid.setLoadMask(true); grid.setSelectionModel(new RowSelectionModel()); grid.setFrame(true); grid.setStripeRows(true); grid.setIconCls("grid-icon"); GridView view = new GridView() { public String getRowClass(Record record, int index, RowParams rowParams, Store store) { if (showPreview) { rowParams.setBody(Format.format("
{0}
", record.getAsString("excerpt"))); return "x-grid3-row-expanded"; } else { return "x-grid3-row-collapsed"; } } }; view.setForceFit(true); view.setEnableRowBody(true); grid.setView(view); PagingToolbar pagingToolbar = new PagingToolbar(store); pagingToolbar.setPageSize(25); pagingToolbar.setDisplayInfo(true); pagingToolbar.setDisplayMsg("Displaying topics {0} - {1} of {2}"); pagingToolbar.setEmptyMsg("No topics to display"); pagingToolbar.addSeparator(); ToolbarButton toolbarButton = new ToolbarButton("Show Preview"); toolbarButton.setPressed(showPreview); toolbarButton.setEnableToggle(true); toolbarButton.setCls("x-btn-text-icon details"); toolbarButton.addListener(new ButtonListenerAdapter() { public void onToggle(Button button, boolean pressed) { toggleDetails(pressed); } }); pagingToolbar.addButton(toolbarButton); grid.setBottomToolbar(pagingToolbar); grid.addListener(new PanelListenerAdapter() { public void onRender(Component component) { store.load(0, 25); } }); panel.add(grid); RootPanel.get().add(panel); } private void toggleDetails(boolean pressed) { showPreview = pressed; grid.getView().refresh(); } }