package org.gcube.portlets.user.td.client.template; import java.util.ArrayList; import java.util.Date; import java.util.List; import org.gcube.portlets.user.td.client.resource.TabularDataResources; import org.gcube.portlets.user.td.gwtservice.client.rpc.TDGWTServiceAsync; import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException; import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateApplySession; import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData; import org.gcube.portlets.user.td.tablewidget.client.util.UtilsGXT3; import org.gcube.portlets.user.td.widgetcommonevent.client.event.SessionExpiredEvent; import org.gcube.portlets.user.td.widgetcommonevent.client.type.SessionExpiredType; import org.gcube.portlets.user.td.widgetcommonevent.shared.TRId; import com.allen_sauer.gwt.log.client.Log; import com.google.gwt.cell.client.DateCell; 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.event.dom.client.KeyUpEvent; import com.google.gwt.event.dom.client.KeyUpHandler; import com.google.gwt.i18n.client.DateTimeFormat; import com.google.gwt.user.client.rpc.AsyncCallback; import com.google.web.bindery.event.shared.EventBus; import com.sencha.gxt.cell.core.client.ButtonCell.IconAlign; import com.sencha.gxt.core.client.IdentityValueProvider; import com.sencha.gxt.core.client.Style.SelectionMode; import com.sencha.gxt.core.client.resources.ThemeStyles; import com.sencha.gxt.core.client.util.Margins; 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.Store; import com.sencha.gxt.data.shared.Store.StoreFilter; import com.sencha.gxt.data.shared.loader.ListLoadConfig; import com.sencha.gxt.data.shared.loader.ListLoadResult; import com.sencha.gxt.data.shared.loader.ListLoadResultBean; import com.sencha.gxt.data.shared.loader.ListLoader; import com.sencha.gxt.data.shared.loader.LoadResultListStoreBinding; 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.BoxLayoutData; import com.sencha.gxt.widget.core.client.container.BoxLayoutContainer.BoxLayoutPack; import com.sencha.gxt.widget.core.client.container.HBoxLayoutContainer; import com.sencha.gxt.widget.core.client.container.HBoxLayoutContainer.HBoxLayoutAlign; 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.event.SelectEvent; import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler; import com.sencha.gxt.widget.core.client.form.TextField; import com.sencha.gxt.widget.core.client.grid.CheckBoxSelectionModel; 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.toolbar.LabelToolItem; import com.sencha.gxt.widget.core.client.toolbar.ToolBar; /** * * @author Giancarlo Panichi * * */ public class TemplateApplyPanel extends FramedPanel { private static final String WIDTH = "840px"; private static final String HEIGHT = "520px"; private static final DateTimeFormat sdf=DateTimeFormat.getFormat("yyyy-MM-dd HH:mm"); private EventBus eventBus; private TemplateApplyDialog parent; private TRId trId; private TemplateApplySession templateApplySession; private TextButton btnApply; private TextButton btnClose; private ListLoader> loader; private Grid grid; private ExtendedListStore store; public TemplateApplyPanel(TemplateApplyDialog parent, TRId trId, EventBus eventBus) { this.parent = parent; this.trId = trId; Log.debug("TemplateApplyPanel"); setWidth(WIDTH); setHeight(HEIGHT); setHeaderVisible(false); setBodyBorder(false); this.eventBus = eventBus; create(); } protected void create() { ToolBar toolBarHead = new ToolBar(); toolBarHead.add(new LabelToolItem("Search: ")); final TextField searchField = new TextField(); toolBarHead.add(searchField); TextButton btnReload = new TextButton(); // btnReload.setText("Reload"); btnReload.setIcon(TabularDataResources.INSTANCE.refresh()); btnReload.setToolTip("Reload"); toolBarHead.add(btnReload); IdentityValueProvider identity = new IdentityValueProvider(); CheckBoxSelectionModel sm = new CheckBoxSelectionModel( identity); TemplateDataProperties props = GWT.create(TemplateDataProperties.class); ColumnConfig nameCol = new ColumnConfig( props.name(), 120, "Name"); ColumnConfig categoryCol = new ColumnConfig( props.category(), 50, "Category"); ColumnConfig ownerCol = new ColumnConfig( props.ownerLogin(), 70, "Owner"); ColumnConfig agencyCol = new ColumnConfig( props.agency(), 90, "Agency"); ColumnConfig descriptionCol = new ColumnConfig( props.description(), 90, "Description"); ColumnConfig creationDateCol = new ColumnConfig( props.creationDate(), 60, "Creation Date"); //DateTimeFormat.getFormat(PredefinedFormat.DATE_SHORT)) creationDateCol.setCell(new DateCell(sdf)); List> l = new ArrayList>(); l.add(nameCol); l.add(categoryCol); l.add(ownerCol); l.add(agencyCol); l.add(descriptionCol); l.add(creationDateCol); ColumnModel cm = new ColumnModel(l); store = new ExtendedListStore(props.id()); searchField.addKeyUpHandler(new KeyUpHandler() { public void onKeyUp(KeyUpEvent event) { Log.trace("searchTerm: " + searchField.getCurrentValue()); store.applyFilters(); } }); store.addFilter(new StoreFilter() { @Override public boolean select(Store store, TemplateData parent, TemplateData item) { String searchTerm = searchField.getCurrentValue(); if (searchTerm == null) return true; return TemplateApplyPanel.this.select(item, searchTerm); } }); store.setEnableFilters(true); RpcProxy> proxy = new RpcProxy>() { public void load(ListLoadConfig loadConfig, final AsyncCallback> callback) { loadData(loadConfig, callback); } }; loader = new ListLoader>( proxy); loader.setRemoteSort(false); loader.addLoadHandler(new LoadResultListStoreBinding>( store) { }); SelectHandler sh = new SelectHandler() { public void onSelect(SelectEvent event) { loader.load(); } }; btnReload.addSelectHandler(sh); grid = new Grid(store, cm) { @Override protected void onAfterFirstAttach() { super.onAfterFirstAttach(); Scheduler.get().scheduleDeferred(new ScheduledCommand() { public void execute() { loader.load(); } }); } }; sm.setSelectionMode(SelectionMode.SINGLE); grid.setLoader(loader); grid.setSelectionModel(sm); grid.setHeight("384px"); grid.getView().setStripeRows(true); grid.getView().setColumnLines(true); grid.getView().setAutoFill(true); grid.setBorders(false); grid.setLoadMask(true); grid.setColumnReordering(true); grid.setColumnResize(true); grid.getView().setAutoExpandColumn(descriptionCol); ToolBar toolBar = new ToolBar(); toolBar.add(grid); toolBar.addStyleName(ThemeStyles.get().style().borderTop()); toolBar.getElement().getStyle().setProperty("borderBottom", "none"); btnApply = new TextButton("Apply"); btnApply.setIcon(TabularDataResources.INSTANCE.templateApply()); btnApply.setIconAlign(IconAlign.RIGHT); btnApply.setToolTip("Apply Template"); btnApply.addSelectHandler(new SelectHandler() { public void onSelect(SelectEvent event) { Log.debug("Pressed Apply"); apply(); } }); btnClose = new TextButton("Close"); btnClose.setIcon(TabularDataResources.INSTANCE.close()); btnClose.setIconAlign(IconAlign.RIGHT); btnClose.setToolTip("Close"); btnClose.addSelectHandler(new SelectHandler() { public void onSelect(SelectEvent event) { Log.debug("Pressed Close"); close(); } }); HBoxLayoutContainer flowButton = new HBoxLayoutContainer(); flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE); flowButton.setPack(BoxLayoutPack.CENTER); flowButton.add(btnApply, new BoxLayoutData(new Margins(2, 4, 2, 4))); flowButton.add(btnClose, new BoxLayoutData(new Margins(2, 4, 2, 4))); VerticalLayoutContainer v = new VerticalLayoutContainer(); v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0))); v.add(grid, new VerticalLayoutData(-1, -1, new Margins(0))); v.add(toolBar, new VerticalLayoutData(1, 25, new Margins(0))); v.add(flowButton, new VerticalLayoutData(1, 36, new Margins(5, 2, 5, 2))); add(v); } protected void loadData(ListLoadConfig loadConfig, final AsyncCallback> callback) { TDGWTServiceAsync.INSTANCE .getTemplates(new AsyncCallback>() { public void onFailure(Throwable caught) { if (caught instanceof TDGWTSessionExpiredException) { eventBus.fireEvent(new SessionExpiredEvent( SessionExpiredType.EXPIREDONSERVER)); } else { Log.error("Load templates failure:" + caught.getLocalizedMessage()); UtilsGXT3.alert("Error retrieving templates", "Error retrieving templates"); } callback.onFailure(caught); } public void onSuccess(ArrayList result) { Log.trace("loaded " + result.size() + " Occurences"); callback.onSuccess(new ListLoadResultBean( result)); } }); } protected TemplateData getSelectedItem() { return grid.getSelectionModel().getSelectedItem(); } protected void apply() { templateApplySession = new TemplateApplySession(); TemplateData template = getSelectedItem(); if (template == null) { UtilsGXT3.info("Attention", "Select the template to apply"); } else { templateApplySession.setTemplateData(getSelectedItem()); templateApplySession.setTrId(trId); Log.debug("applyTemplateSession: " + templateApplySession); parent.applyTemplate(templateApplySession); } } protected void close() { parent.close(); } protected class ExtendedListStore extends ListStore { public ExtendedListStore(ModelKeyProvider keyProvider) { super(keyProvider); } public void applyFilters() { super.applyFilters(); } } public void gridReload() { grid.getLoader().load(); } protected boolean select(TemplateData item, String searchTerm) { if (item.getName() != null && item.getName().toLowerCase() .contains(searchTerm.toLowerCase())) return true; if (item.getCategory() != null && item.getCategory().toLowerCase() .contains(searchTerm.toLowerCase())) return true; if (item.getAgency() != null && item.getAgency().toLowerCase() .contains(searchTerm.toLowerCase())) return true; if (item.getDescription() != null && item.getDescription().toLowerCase() .contains(searchTerm.toLowerCase())) return true; return false; } }