Updated Share Template
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-portlet@113686 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
9cbe065f21
commit
76e3de370a
|
@ -12,6 +12,7 @@ import org.gcube.portlets.user.td.client.rstudio.RStudio;
|
||||||
import org.gcube.portlets.user.td.client.template.TemplateApplyDialog;
|
import org.gcube.portlets.user.td.client.template.TemplateApplyDialog;
|
||||||
import org.gcube.portlets.user.td.client.template.TemplateDeleteDialog;
|
import org.gcube.portlets.user.td.client.template.TemplateDeleteDialog;
|
||||||
import org.gcube.portlets.user.td.client.template.TemplateOpenDialog;
|
import org.gcube.portlets.user.td.client.template.TemplateOpenDialog;
|
||||||
|
import org.gcube.portlets.user.td.client.template.TemplateShareDialog;
|
||||||
import org.gcube.portlets.user.td.codelistmappingimportwidget.client.CodelistMappingImportWizardTD;
|
import org.gcube.portlets.user.td.codelistmappingimportwidget.client.CodelistMappingImportWizardTD;
|
||||||
import org.gcube.portlets.user.td.columnwidget.client.batch.ReplaceBatchDialog;
|
import org.gcube.portlets.user.td.columnwidget.client.batch.ReplaceBatchDialog;
|
||||||
import org.gcube.portlets.user.td.columnwidget.client.replace.ReplaceAllDialog;
|
import org.gcube.portlets.user.td.columnwidget.client.replace.ReplaceAllDialog;
|
||||||
|
@ -833,14 +834,14 @@ public class TabularDataController {
|
||||||
case GENERATE_SUMMARY:
|
case GENERATE_SUMMARY:
|
||||||
break;
|
break;
|
||||||
case COLUMN_MULTI_FILTER:
|
case COLUMN_MULTI_FILTER:
|
||||||
//Filter On multicolumn
|
// Filter On multicolumn
|
||||||
break;
|
break;
|
||||||
case COLUMN_REPLACE_BATCH:
|
case COLUMN_REPLACE_BATCH:
|
||||||
openColumnBatchReplace();
|
openColumnBatchReplace();
|
||||||
break;
|
break;
|
||||||
case COLUMN_REPLACE_BY_EXPRESSION:
|
case COLUMN_REPLACE_BY_EXPRESSION:
|
||||||
openColumnReplaceByExpression();
|
openColumnReplaceByExpression();
|
||||||
break;
|
break;
|
||||||
case COLUMN_REPLACE_BY_EXTERNAL_COL:
|
case COLUMN_REPLACE_BY_EXTERNAL_COL:
|
||||||
openReplaceByExternalColWizard();
|
openReplaceByExternalColWizard();
|
||||||
break;
|
break;
|
||||||
|
@ -849,10 +850,10 @@ public class TabularDataController {
|
||||||
break;
|
break;
|
||||||
case DUPLICATE_DELETE:
|
case DUPLICATE_DELETE:
|
||||||
openDuplicatesRows();
|
openDuplicatesRows();
|
||||||
break;
|
break;
|
||||||
case BYEXPRESSION_DELETE:
|
case BYEXPRESSION_DELETE:
|
||||||
openRowsDeleteByExpression();
|
openRowsDeleteByExpression();
|
||||||
break;
|
break;
|
||||||
case ROW_ADD:
|
case ROW_ADD:
|
||||||
doRowAdd();
|
doRowAdd();
|
||||||
break;
|
break;
|
||||||
|
@ -894,10 +895,13 @@ public class TabularDataController {
|
||||||
break;
|
break;
|
||||||
case TEMPLATE_DELETE:
|
case TEMPLATE_DELETE:
|
||||||
openTemplateDelete();
|
openTemplateDelete();
|
||||||
break;
|
break;
|
||||||
case TEMPLATE_APPLY:
|
case TEMPLATE_APPLY:
|
||||||
openTemplateApply();
|
openTemplateApply();
|
||||||
break;
|
break;
|
||||||
|
case TEMPLATE_SHARE:
|
||||||
|
openTemplateShare();
|
||||||
|
break;
|
||||||
case ANALYSE_TABLE_FILTER:
|
case ANALYSE_TABLE_FILTER:
|
||||||
break;
|
break;
|
||||||
case ANALYSE_TABLE_UNION:
|
case ANALYSE_TABLE_UNION:
|
||||||
|
@ -932,7 +936,7 @@ public class TabularDataController {
|
||||||
case CREATE_GIS_MAP:
|
case CREATE_GIS_MAP:
|
||||||
openCreateMapWizard();
|
openCreateMapWizard();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1646,6 +1650,22 @@ public class TabularDataController {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void openTemplateShare() {
|
||||||
|
GWT.runAsync(new RunAsyncCallback() {
|
||||||
|
public void onSuccess() {
|
||||||
|
Log.debug("Template Share call");
|
||||||
|
TemplateShareDialog tsDialog = new TemplateShareDialog(eventBus);
|
||||||
|
tsDialog.show();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void onFailure(Throwable reason) {
|
||||||
|
asyncCodeLoadingFailed(reason);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private void openShareWindow() {
|
private void openShareWindow() {
|
||||||
GWT.runAsync(new RunAsyncCallback() {
|
GWT.runAsync(new RunAsyncCallback() {
|
||||||
public void onSuccess() {
|
public void onSuccess() {
|
||||||
|
@ -1704,14 +1724,10 @@ public class TabularDataController {
|
||||||
UtilsGXT3.alert("Error", "No current tabular resource present");
|
UtilsGXT3.alert("Error", "No current tabular resource present");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void openColumnFilter() {
|
||||||
|
openColumnFilter(null, null);
|
||||||
|
|
||||||
private void openColumnFilter(){
|
|
||||||
openColumnFilter(null,null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void openColumnFilter(String columnLocalId, String columnName) {
|
private void openColumnFilter(String columnLocalId, String columnName) {
|
||||||
Log.debug("Request Open Column Filter Dialog");
|
Log.debug("Request Open Column Filter Dialog");
|
||||||
|
@ -1725,30 +1741,27 @@ public class TabularDataController {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openRowsDeleteByExpression(){
|
private void openRowsDeleteByExpression() {
|
||||||
openRowsDeleteByExpression(null,null);
|
openRowsDeleteByExpression(null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void openRowsDeleteByExpression(String columnLocalId, String columnName) {
|
private void openRowsDeleteByExpression(String columnLocalId,
|
||||||
|
String columnName) {
|
||||||
Log.debug("Request Open Row Delete By Expression Dialog");
|
Log.debug("Request Open Row Delete By Expression Dialog");
|
||||||
if (trId != null) {
|
if (trId != null) {
|
||||||
RowsDeleteByExpressionDialog cfDialog = new RowsDeleteByExpressionDialog(trId,
|
RowsDeleteByExpressionDialog cfDialog = new RowsDeleteByExpressionDialog(
|
||||||
columnLocalId, eventBus);
|
trId, columnLocalId, eventBus);
|
||||||
cfDialog.show();
|
cfDialog.show();
|
||||||
} else {
|
} else {
|
||||||
Log.error("TRId is null");
|
Log.error("TRId is null");
|
||||||
UtilsGXT3.alert("Error", "No current tabular resource present");
|
UtilsGXT3.alert("Error", "No current tabular resource present");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void openColumnReplaceByExpression() {
|
||||||
|
openColumnReplaceByExpression(null, null);
|
||||||
|
|
||||||
private void openColumnReplaceByExpression(){
|
|
||||||
openColumnReplaceByExpression(null,null);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void openColumnReplaceByExpression(String columnLocalId,
|
private void openColumnReplaceByExpression(String columnLocalId,
|
||||||
String columnName) {
|
String columnName) {
|
||||||
Log.debug("Request Open Replace Column By Expression Dialog");
|
Log.debug("Request Open Replace Column By Expression Dialog");
|
||||||
|
@ -1822,7 +1835,6 @@ public class TabularDataController {
|
||||||
cloneTR.cloneTR();
|
cloneTR.cloneTR();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void openColumnBatchReplace() {
|
private void openColumnBatchReplace() {
|
||||||
openColumnBatchReplace(null, null);
|
openColumnBatchReplace(null, null);
|
||||||
}
|
}
|
||||||
|
@ -2219,8 +2231,8 @@ public class TabularDataController {
|
||||||
if (cellData == null) {
|
if (cellData == null) {
|
||||||
UtilsGXT3.alert("No cell selected", "No cell selected");
|
UtilsGXT3.alert("No cell selected", "No cell selected");
|
||||||
} else {
|
} else {
|
||||||
ReplaceAllDialog replaceDialog = new ReplaceAllDialog(cellData, trId,
|
ReplaceAllDialog replaceDialog = new ReplaceAllDialog(cellData,
|
||||||
eventBus);
|
trId, eventBus);
|
||||||
replaceDialog.show();
|
replaceDialog.show();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -40,6 +40,7 @@ public class TemplateToolBar {
|
||||||
private TextButton templateOpenButton;
|
private TextButton templateOpenButton;
|
||||||
private TextButton templateDeleteButton;
|
private TextButton templateDeleteButton;
|
||||||
private TextButton templateApplyButton;
|
private TextButton templateApplyButton;
|
||||||
|
private TextButton templateShareButton;
|
||||||
|
|
||||||
|
|
||||||
public TemplateToolBar(EventBus eventBus) {
|
public TemplateToolBar(EventBus eventBus) {
|
||||||
|
@ -139,6 +140,24 @@ public class TemplateToolBar {
|
||||||
|
|
||||||
templateLayout.setWidget(0, 3, templateApplyButton);
|
templateLayout.setWidget(0, 3, templateApplyButton);
|
||||||
templateLayout.getFlexCellFormatter().setRowSpan(0, 3, 2);
|
templateLayout.getFlexCellFormatter().setRowSpan(0, 3, 2);
|
||||||
|
|
||||||
|
|
||||||
|
templateShareButton = new TextButton("Share",
|
||||||
|
TabularDataResources.INSTANCE.templateShare32());
|
||||||
|
templateShareButton.enable();
|
||||||
|
templateShareButton.setScale(ButtonScale.LARGE);
|
||||||
|
templateShareButton.setIconAlign(IconAlign.TOP);
|
||||||
|
templateShareButton.setToolTip("Share Template");
|
||||||
|
templateShareButton.setArrowAlign(ButtonArrowAlign.BOTTOM);
|
||||||
|
templateShareButton.addSelectHandler(new SelectHandler() {
|
||||||
|
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
eventBus.fireEvent(new RibbonEvent(RibbonType.TEMPLATE_SHARE));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
templateLayout.setWidget(0, 4, templateShareButton);
|
||||||
|
templateLayout.getFlexCellFormatter().setRowSpan(0, 4, 2);
|
||||||
|
|
||||||
cleanCells(templateLayout.getElement());
|
cleanCells(templateLayout.getElement());
|
||||||
|
|
||||||
|
@ -173,6 +192,7 @@ public class TemplateToolBar {
|
||||||
templateNewButton.enable();
|
templateNewButton.enable();
|
||||||
templateDeleteButton.enable();
|
templateDeleteButton.enable();
|
||||||
templateApplyButton.disable();
|
templateApplyButton.disable();
|
||||||
|
templateShareButton.enable();
|
||||||
break;
|
break;
|
||||||
case TR_CLOSE:
|
case TR_CLOSE:
|
||||||
case TR_READONLY:
|
case TR_READONLY:
|
||||||
|
@ -180,6 +200,7 @@ public class TemplateToolBar {
|
||||||
templateNewButton.enable();
|
templateNewButton.enable();
|
||||||
templateDeleteButton.enable();
|
templateDeleteButton.enable();
|
||||||
templateApplyButton.disable();
|
templateApplyButton.disable();
|
||||||
|
templateShareButton.enable();
|
||||||
break;
|
break;
|
||||||
case TR_OPEN:
|
case TR_OPEN:
|
||||||
case TABLEUPDATE:
|
case TABLEUPDATE:
|
||||||
|
@ -188,12 +209,14 @@ public class TemplateToolBar {
|
||||||
templateNewButton.enable();
|
templateNewButton.enable();
|
||||||
templateDeleteButton.enable();
|
templateDeleteButton.enable();
|
||||||
templateApplyButton.enable();
|
templateApplyButton.enable();
|
||||||
|
templateShareButton.enable();
|
||||||
break;
|
break;
|
||||||
case WIZARD_OPEN:
|
case WIZARD_OPEN:
|
||||||
templateOpenButton.disable();
|
templateOpenButton.disable();
|
||||||
templateNewButton.disable();
|
templateNewButton.disable();
|
||||||
templateDeleteButton.disable();
|
templateDeleteButton.disable();
|
||||||
templateApplyButton.disable();
|
templateApplyButton.disable();
|
||||||
|
templateShareButton.disable();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -32,14 +32,11 @@ import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
||||||
*/
|
*/
|
||||||
public class TemplateApplyDialog extends Window implements
|
public class TemplateApplyDialog extends Window implements
|
||||||
MonitorDialogListener {
|
MonitorDialogListener {
|
||||||
protected String WIDTH = "720px";
|
private static final String WIDTH = "720px";
|
||||||
protected String HEIGHT = "530px";
|
private static final String HEIGHT = "530px";
|
||||||
protected TemplateApplySession templateApplySession;
|
private EventBus eventBus;
|
||||||
protected TRId trId;
|
|
||||||
protected EventBus eventBus;
|
|
||||||
|
|
||||||
public TemplateApplyDialog(TRId trId, EventBus eventBus) {
|
public TemplateApplyDialog(TRId trId, EventBus eventBus) {
|
||||||
this.trId = trId;
|
|
||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
initWindow();
|
initWindow();
|
||||||
|
|
||||||
|
@ -82,7 +79,7 @@ public class TemplateApplyDialog extends Window implements
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void applyTemplate(final TemplateApplySession templateApplySession) {
|
protected void applyTemplate(final TemplateApplySession templateApplySession) {
|
||||||
this.templateApplySession = templateApplySession;
|
|
||||||
|
|
||||||
TDGWTServiceAsync.INSTANCE.startTemplateApply(templateApplySession,
|
TDGWTServiceAsync.INSTANCE.startTemplateApply(templateApplySession,
|
||||||
new AsyncCallback<String>() {
|
new AsyncCallback<String>() {
|
||||||
|
|
|
@ -5,9 +5,12 @@ import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
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.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.TemplateApplySession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
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.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 org.gcube.portlets.user.td.widgetcommonevent.shared.TRId;
|
||||||
|
|
||||||
import com.allen_sauer.gwt.log.client.Log;
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
|
@ -53,24 +56,24 @@ import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author giancarlo
|
* @author giancarlo email: <a
|
||||||
* email: <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class TemplateApplyPanel extends FramedPanel {
|
public class TemplateApplyPanel extends FramedPanel {
|
||||||
protected String WIDTH = "630px";
|
private static final String WIDTH = "630px";
|
||||||
protected String HEIGHT = "520px";
|
private static final String HEIGHT = "520px";
|
||||||
protected EventBus eventBus;
|
private EventBus eventBus;
|
||||||
protected TemplateApplyDialog parent;
|
private TemplateApplyDialog parent;
|
||||||
protected TRId trId;
|
private TRId trId;
|
||||||
protected TemplateApplySession templateApplySession;
|
private TemplateApplySession templateApplySession;
|
||||||
|
|
||||||
private TextButton btnApply;
|
private TextButton btnApply;
|
||||||
private TextButton btnClose;
|
private TextButton btnClose;
|
||||||
|
|
||||||
protected ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
private ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
||||||
protected Grid<TemplateData> grid;
|
private Grid<TemplateData> grid;
|
||||||
protected ExtendedListStore<TemplateData> store;
|
private ExtendedListStore<TemplateData> store;
|
||||||
|
|
||||||
public TemplateApplyPanel(TemplateApplyDialog parent, TRId trId,
|
public TemplateApplyPanel(TemplateApplyDialog parent, TRId trId,
|
||||||
EventBus eventBus) {
|
EventBus eventBus) {
|
||||||
|
@ -92,14 +95,13 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
toolBarHead.add(new LabelToolItem("Search: "));
|
toolBarHead.add(new LabelToolItem("Search: "));
|
||||||
final TextField searchField = new TextField();
|
final TextField searchField = new TextField();
|
||||||
toolBarHead.add(searchField);
|
toolBarHead.add(searchField);
|
||||||
|
|
||||||
TextButton btnReload = new TextButton();
|
TextButton btnReload = new TextButton();
|
||||||
//btnReload.setText("Reload");
|
// btnReload.setText("Reload");
|
||||||
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
||||||
btnReload.setToolTip("Reload");
|
btnReload.setToolTip("Reload");
|
||||||
toolBarHead.add(btnReload);
|
toolBarHead.add(btnReload);
|
||||||
|
|
||||||
|
|
||||||
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
||||||
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
||||||
identity);
|
identity);
|
||||||
|
@ -110,10 +112,10 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
props.name(), 120, "Name");
|
props.name(), 120, "Name");
|
||||||
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.category(), 60, "Category");
|
props.category(), 60, "Category");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.ownerLogin(), 70, "Owner");
|
props.ownerLogin(), 70, "Owner");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.agency(), 100, "Agency");
|
props.agency(), 100, "Agency");
|
||||||
|
|
||||||
|
@ -134,24 +136,24 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
searchField.addKeyUpHandler(new KeyUpHandler() {
|
searchField.addKeyUpHandler(new KeyUpHandler() {
|
||||||
|
|
||||||
public void onKeyUp(KeyUpEvent event) {
|
public void onKeyUp(KeyUpEvent event) {
|
||||||
Log.trace("searchTerm: "+searchField.getCurrentValue());
|
Log.trace("searchTerm: " + searchField.getCurrentValue());
|
||||||
store.applyFilters();
|
store.applyFilters();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.addFilter(new StoreFilter<TemplateData>() {
|
store.addFilter(new StoreFilter<TemplateData>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean select(Store<TemplateData> store,
|
public boolean select(Store<TemplateData> store,
|
||||||
TemplateData parent, TemplateData item) {
|
TemplateData parent, TemplateData item) {
|
||||||
String searchTerm = searchField.getCurrentValue();
|
String searchTerm = searchField.getCurrentValue();
|
||||||
if (searchTerm == null) return true;
|
if (searchTerm == null)
|
||||||
|
return true;
|
||||||
return TemplateApplyPanel.this.select(item, searchTerm);
|
return TemplateApplyPanel.this.select(item, searchTerm);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.setEnableFilters(true);
|
store.setEnableFilters(true);
|
||||||
|
|
||||||
|
|
||||||
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
||||||
|
|
||||||
|
@ -167,16 +169,15 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
||||||
store) {
|
store) {
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
SelectHandler sh = new SelectHandler() {
|
SelectHandler sh = new SelectHandler() {
|
||||||
public void onSelect(SelectEvent event) {
|
public void onSelect(SelectEvent event) {
|
||||||
loader.load();
|
loader.load();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
btnReload.addSelectHandler(sh);
|
btnReload.addSelectHandler(sh);
|
||||||
|
|
||||||
grid = new Grid<TemplateData>(store, cm) {
|
grid = new Grid<TemplateData>(store, cm) {
|
||||||
@Override
|
@Override
|
||||||
protected void onAfterFirstAttach() {
|
protected void onAfterFirstAttach() {
|
||||||
|
@ -202,10 +203,7 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
grid.setColumnReordering(true);
|
grid.setColumnReordering(true);
|
||||||
grid.setColumnResize(true);
|
grid.setColumnResize(true);
|
||||||
grid.getView().setAutoExpandColumn(descriptionCol);
|
grid.getView().setAutoExpandColumn(descriptionCol);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ToolBar toolBar = new ToolBar();
|
ToolBar toolBar = new ToolBar();
|
||||||
toolBar.add(grid);
|
toolBar.add(grid);
|
||||||
toolBar.addStyleName(ThemeStyles.get().style().borderTop());
|
toolBar.addStyleName(ThemeStyles.get().style().borderTop());
|
||||||
|
@ -247,8 +245,8 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
||||||
v.add(grid, 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(toolBar, new VerticalLayoutData(1, 25, new Margins(0)));
|
||||||
v.add(flowButton, new VerticalLayoutData(1, 36,
|
v.add(flowButton,
|
||||||
new Margins(5, 2, 5, 2)));
|
new VerticalLayoutData(1, 36, new Margins(5, 2, 5, 2)));
|
||||||
add(v);
|
add(v);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -260,10 +258,15 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
||||||
|
|
||||||
public void onFailure(Throwable caught) {
|
public void onFailure(Throwable caught) {
|
||||||
Log.error("load templates failure:"
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
+ caught.getLocalizedMessage());
|
eventBus.fireEvent(new SessionExpiredEvent(
|
||||||
UtilsGXT3.alert("Error retrieving templates",
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
"Error retrieving templates");
|
} else {
|
||||||
|
Log.error("Load templates failure:"
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
UtilsGXT3.alert("Error retrieving templates",
|
||||||
|
"Error retrieving templates");
|
||||||
|
}
|
||||||
callback.onFailure(caught);
|
callback.onFailure(caught);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -277,25 +280,7 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
});
|
});
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* protected void setMenu() { Menu contextMenu = new Menu();
|
|
||||||
*
|
|
||||||
* MenuItem deleteTemplateItem = new MenuItem("Delete");
|
|
||||||
* deleteTemplateItem.setId("DeleteTemplate");
|
|
||||||
* deleteTemplateItem.setIcon(TabularDataResources.INSTANCE.removeTemplate());
|
|
||||||
* deleteTemplateItem.addSelectionHandler(new SelectionHandler<Item>() {
|
|
||||||
*
|
|
||||||
* @Override public void onSelection(SelectionEvent<Item> event) {
|
|
||||||
* Log.debug("Delete Template"); TemplateData templateDesc =
|
|
||||||
* getSelectedItem();
|
|
||||||
*
|
|
||||||
* } });
|
|
||||||
*
|
|
||||||
* grid.setContextMenu(contextMenu); }
|
|
||||||
*/
|
|
||||||
|
|
||||||
protected TemplateData getSelectedItem() {
|
protected TemplateData getSelectedItem() {
|
||||||
return grid.getSelectionModel().getSelectedItem();
|
return grid.getSelectionModel().getSelectedItem();
|
||||||
|
@ -317,29 +302,40 @@ public class TemplateApplyPanel extends FramedPanel {
|
||||||
protected void close() {
|
protected void close() {
|
||||||
parent.close();
|
parent.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected class ExtendedListStore<M> extends ListStore<M> {
|
protected class ExtendedListStore<M> extends ListStore<M> {
|
||||||
|
|
||||||
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
||||||
super(keyProvider);
|
super(keyProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void applyFilters()
|
public void applyFilters() {
|
||||||
{
|
|
||||||
super.applyFilters();
|
super.applyFilters();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void gridReload(){
|
public void gridReload() {
|
||||||
grid.getLoader().load();
|
grid.getLoader().load();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean select(TemplateData item, String searchTerm) {
|
protected boolean select(TemplateData item, String searchTerm) {
|
||||||
if (item.getName()!=null && item.getName().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
if (item.getName() != null
|
||||||
if (item.getCategory()!=null &&item.getCategory().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
&& item.getName().toLowerCase()
|
||||||
if (item.getAgency()!=null &&item.getAgency().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
.contains(searchTerm.toLowerCase()))
|
||||||
if (item.getDescription()!=null && item.getDescription().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
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;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,10 +23,9 @@ import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class TemplateDeleteDialog extends Window {
|
public class TemplateDeleteDialog extends Window {
|
||||||
protected String WIDTH = "720px";
|
private static final String WIDTH = "720px";
|
||||||
protected String HEIGHT = "530px";
|
private static final String HEIGHT = "530px";
|
||||||
protected TemplateDeleteSession templateDeleteSession;
|
private EventBus eventBus;
|
||||||
protected EventBus eventBus;
|
|
||||||
|
|
||||||
public TemplateDeleteDialog(EventBus eventBus) {
|
public TemplateDeleteDialog(EventBus eventBus) {
|
||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
|
@ -72,7 +71,7 @@ public class TemplateDeleteDialog extends Window {
|
||||||
|
|
||||||
protected void templatesDelete(
|
protected void templatesDelete(
|
||||||
final TemplateDeleteSession templateDeleteSession) {
|
final TemplateDeleteSession templateDeleteSession) {
|
||||||
this.templateDeleteSession = templateDeleteSession;
|
|
||||||
|
|
||||||
TDGWTServiceAsync.INSTANCE.templateDelete(templateDeleteSession,
|
TDGWTServiceAsync.INSTANCE.templateDelete(templateDeleteSession,
|
||||||
new AsyncCallback<Void>() {
|
new AsyncCallback<Void>() {
|
||||||
|
|
|
@ -5,9 +5,12 @@ import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
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.client.rpc.TDGWTServiceAsync;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateDeleteSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateDeleteSession;
|
||||||
import org.gcube.portlets.user.td.tablewidget.client.util.UtilsGXT3;
|
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 com.allen_sauer.gwt.log.client.Log;
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
import com.google.gwt.core.client.GWT;
|
import com.google.gwt.core.client.GWT;
|
||||||
|
@ -51,21 +54,20 @@ import com.sencha.gxt.widget.core.client.toolbar.LabelToolItem;
|
||||||
import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
|
import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
|
||||||
|
|
||||||
public class TemplateDeletePanel extends FramedPanel {
|
public class TemplateDeletePanel extends FramedPanel {
|
||||||
protected String WIDTH = "630px";
|
private static final String WIDTH = "630px";
|
||||||
protected String HEIGHT = "520px";
|
private static final String HEIGHT = "520px";
|
||||||
protected EventBus eventBus;
|
private EventBus eventBus;
|
||||||
protected TemplateDeleteDialog parent;
|
private TemplateDeleteDialog parent;
|
||||||
protected TemplateDeleteSession templateDeleteSession;
|
private TemplateDeleteSession templateDeleteSession;
|
||||||
|
|
||||||
private TextButton btnDelete;
|
private TextButton btnDelete;
|
||||||
private TextButton btnClose;
|
private TextButton btnClose;
|
||||||
|
|
||||||
protected ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
private ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
||||||
protected Grid<TemplateData> grid;
|
private Grid<TemplateData> grid;
|
||||||
protected ExtendedListStore<TemplateData> store;
|
private ExtendedListStore<TemplateData> store;
|
||||||
|
|
||||||
public TemplateDeletePanel(TemplateDeleteDialog parent,
|
public TemplateDeletePanel(TemplateDeleteDialog parent, EventBus eventBus) {
|
||||||
EventBus eventBus) {
|
|
||||||
this.parent = parent;
|
this.parent = parent;
|
||||||
Log.debug("TemplateDeletePanel");
|
Log.debug("TemplateDeletePanel");
|
||||||
setWidth(WIDTH);
|
setWidth(WIDTH);
|
||||||
|
@ -83,15 +85,13 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
toolBarHead.add(new LabelToolItem("Search: "));
|
toolBarHead.add(new LabelToolItem("Search: "));
|
||||||
final TextField searchField = new TextField();
|
final TextField searchField = new TextField();
|
||||||
toolBarHead.add(searchField);
|
toolBarHead.add(searchField);
|
||||||
|
|
||||||
TextButton btnReload = new TextButton();
|
TextButton btnReload = new TextButton();
|
||||||
//btnReload.setText("Reload");
|
// btnReload.setText("Reload");
|
||||||
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
||||||
btnReload.setToolTip("Reload");
|
btnReload.setToolTip("Reload");
|
||||||
toolBarHead.add(btnReload);
|
toolBarHead.add(btnReload);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
||||||
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
||||||
identity);
|
identity);
|
||||||
|
@ -102,10 +102,10 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
props.name(), 120, "Name");
|
props.name(), 120, "Name");
|
||||||
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.category(), 60, "Category");
|
props.category(), 60, "Category");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.ownerLogin(), 70, "Owner");
|
props.ownerLogin(), 70, "Owner");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.agency(), 100, "Agency");
|
props.agency(), 100, "Agency");
|
||||||
|
|
||||||
|
@ -120,30 +120,30 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
l.add(descriptionCol);
|
l.add(descriptionCol);
|
||||||
|
|
||||||
ColumnModel<TemplateData> cm = new ColumnModel<TemplateData>(l);
|
ColumnModel<TemplateData> cm = new ColumnModel<TemplateData>(l);
|
||||||
|
|
||||||
store = new ExtendedListStore<TemplateData>(props.id());
|
store = new ExtendedListStore<TemplateData>(props.id());
|
||||||
|
|
||||||
searchField.addKeyUpHandler(new KeyUpHandler() {
|
searchField.addKeyUpHandler(new KeyUpHandler() {
|
||||||
|
|
||||||
public void onKeyUp(KeyUpEvent event) {
|
public void onKeyUp(KeyUpEvent event) {
|
||||||
Log.trace("searchTerm: "+searchField.getCurrentValue());
|
Log.trace("searchTerm: " + searchField.getCurrentValue());
|
||||||
store.applyFilters();
|
store.applyFilters();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.addFilter(new StoreFilter<TemplateData>() {
|
store.addFilter(new StoreFilter<TemplateData>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean select(Store<TemplateData> store,
|
public boolean select(Store<TemplateData> store,
|
||||||
TemplateData parent, TemplateData item) {
|
TemplateData parent, TemplateData item) {
|
||||||
String searchTerm = searchField.getCurrentValue();
|
String searchTerm = searchField.getCurrentValue();
|
||||||
if (searchTerm == null) return true;
|
if (searchTerm == null)
|
||||||
|
return true;
|
||||||
return TemplateDeletePanel.this.select(item, searchTerm);
|
return TemplateDeletePanel.this.select(item, searchTerm);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.setEnableFilters(true);
|
store.setEnableFilters(true);
|
||||||
|
|
||||||
|
|
||||||
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
||||||
|
|
||||||
|
@ -159,15 +159,15 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
||||||
store) {
|
store) {
|
||||||
});
|
});
|
||||||
|
|
||||||
SelectHandler sh = new SelectHandler() {
|
SelectHandler sh = new SelectHandler() {
|
||||||
public void onSelect(SelectEvent event) {
|
public void onSelect(SelectEvent event) {
|
||||||
loader.load();
|
loader.load();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
btnReload.addSelectHandler(sh);
|
btnReload.addSelectHandler(sh);
|
||||||
|
|
||||||
grid = new Grid<TemplateData>(store, cm) {
|
grid = new Grid<TemplateData>(store, cm) {
|
||||||
@Override
|
@Override
|
||||||
protected void onAfterFirstAttach() {
|
protected void onAfterFirstAttach() {
|
||||||
|
@ -227,8 +227,8 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
||||||
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
||||||
flowButton.setPack(BoxLayoutPack.CENTER);
|
flowButton.setPack(BoxLayoutPack.CENTER);
|
||||||
|
|
||||||
BoxLayoutData boxLayoutData=new BoxLayoutData(new Margins(2, 4, 2, 4));
|
BoxLayoutData boxLayoutData = new BoxLayoutData(new Margins(2, 4, 2, 4));
|
||||||
flowButton.add(btnDelete, boxLayoutData);
|
flowButton.add(btnDelete, boxLayoutData);
|
||||||
flowButton.add(btnClose, boxLayoutData);
|
flowButton.add(btnClose, boxLayoutData);
|
||||||
|
|
||||||
|
@ -236,8 +236,8 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
||||||
v.add(grid, 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(toolBar, new VerticalLayoutData(1, 25, new Margins(0)));
|
||||||
v.add(flowButton, new VerticalLayoutData(1, 36,
|
v.add(flowButton,
|
||||||
new Margins(5, 2, 5, 2)));
|
new VerticalLayoutData(1, 36, new Margins(5, 2, 5, 2)));
|
||||||
add(v);
|
add(v);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -249,10 +249,15 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
||||||
|
|
||||||
public void onFailure(Throwable caught) {
|
public void onFailure(Throwable caught) {
|
||||||
Log.error("load templates failure:"
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
+ caught.getLocalizedMessage());
|
eventBus.fireEvent(new SessionExpiredEvent(
|
||||||
UtilsGXT3.alert("Error retrieving templates",
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
"Error retrieving templates");
|
} else {
|
||||||
|
Log.error("Load templates failure:"
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
UtilsGXT3.alert("Error retrieving templates",
|
||||||
|
"Error retrieving templates");
|
||||||
|
}
|
||||||
callback.onFailure(caught);
|
callback.onFailure(caught);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,32 +272,27 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* protected void setMenu() { Menu contextMenu = new Menu();
|
||||||
|
*
|
||||||
|
* MenuItem deleteTemplateItem = new MenuItem("Delete");
|
||||||
/*protected void setMenu() {
|
* deleteTemplateItem.setId("DeleteTemplate");
|
||||||
Menu contextMenu = new Menu();
|
* deleteTemplateItem.setIcon(ResourceBundle.INSTANCE.removeTemplate());
|
||||||
|
* deleteTemplateItem.addSelectionHandler(new SelectionHandler<Item>() {
|
||||||
MenuItem deleteTemplateItem = new MenuItem("Delete");
|
*
|
||||||
deleteTemplateItem.setId("DeleteTemplate");
|
* @Override public void onSelection(SelectionEvent<Item> event) {
|
||||||
deleteTemplateItem.setIcon(ResourceBundle.INSTANCE.removeTemplate());
|
* Log.debug("Delete Template"); TemplateData templateDesc =
|
||||||
deleteTemplateItem.addSelectionHandler(new SelectionHandler<Item>() {
|
* getSelectedItem();
|
||||||
|
*
|
||||||
@Override
|
* } });
|
||||||
public void onSelection(SelectionEvent<Item> event) {
|
*
|
||||||
Log.debug("Delete Template");
|
* grid.setContextMenu(contextMenu); }
|
||||||
TemplateData templateDesc = getSelectedItem();
|
*/
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
grid.setContextMenu(contextMenu);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
protected ArrayList<TemplateData> getSelectedItem() {
|
protected ArrayList<TemplateData> getSelectedItem() {
|
||||||
ArrayList<TemplateData> templates=new ArrayList<TemplateData>();
|
ArrayList<TemplateData> templates = new ArrayList<TemplateData>();
|
||||||
for(TemplateData template:grid.getSelectionModel().getSelectedItems()){
|
for (TemplateData template : grid.getSelectionModel()
|
||||||
|
.getSelectedItems()) {
|
||||||
templates.add(template);
|
templates.add(template);
|
||||||
}
|
}
|
||||||
return templates;
|
return templates;
|
||||||
|
@ -300,45 +300,55 @@ public class TemplateDeletePanel extends FramedPanel {
|
||||||
|
|
||||||
protected void delete() {
|
protected void delete() {
|
||||||
templateDeleteSession = new TemplateDeleteSession();
|
templateDeleteSession = new TemplateDeleteSession();
|
||||||
ArrayList<TemplateData> templates=getSelectedItem();
|
ArrayList<TemplateData> templates = getSelectedItem();
|
||||||
if(templates==null|| templates.size()==0){
|
if (templates == null || templates.size() == 0) {
|
||||||
UtilsGXT3.info("Attention",
|
UtilsGXT3.info("Attention", "Select the template to be deleted");
|
||||||
"Select the template to be deleted");
|
|
||||||
} else {
|
} else {
|
||||||
templateDeleteSession.setTemplates(getSelectedItem());
|
templateDeleteSession.setTemplates(getSelectedItem());
|
||||||
Log.debug("templateDeleteSession: " + templateDeleteSession);
|
Log.debug("templateDeleteSession: " + templateDeleteSession);
|
||||||
parent.templatesDelete(templateDeleteSession);
|
parent.templatesDelete(templateDeleteSession);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void close() {
|
protected void close() {
|
||||||
parent.close();
|
parent.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected class ExtendedListStore<M> extends ListStore<M> {
|
protected class ExtendedListStore<M> extends ListStore<M> {
|
||||||
|
|
||||||
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
||||||
super(keyProvider);
|
super(keyProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void applyFilters()
|
public void applyFilters() {
|
||||||
{
|
|
||||||
super.applyFilters();
|
super.applyFilters();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void gridReload(){
|
public void gridReload() {
|
||||||
grid.getLoader().load();
|
grid.getLoader().load();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean select(TemplateData item, String searchTerm) {
|
protected boolean select(TemplateData item, String searchTerm) {
|
||||||
if (item.getName()!=null && item.getName().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
if (item.getName() != null
|
||||||
if (item.getCategory()!=null &&item.getCategory().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
&& item.getName().toLowerCase()
|
||||||
if (item.getAgency()!=null &&item.getAgency().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
.contains(searchTerm.toLowerCase()))
|
||||||
if (item.getDescription()!=null && item.getDescription().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
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;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2,12 +2,9 @@ package org.gcube.portlets.user.td.client.template;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateDeleteSession;
|
|
||||||
import org.gcube.portlets.user.td.sharewidget.client.TemplateShare;
|
|
||||||
import org.gcube.portlets.user.tdtemplate.client.TdTemplateController;
|
import org.gcube.portlets.user.tdtemplate.client.TdTemplateController;
|
||||||
import org.gcube.portlets.user.tdtemplate.client.TdTemplateControllerUpdater;
|
import org.gcube.portlets.user.tdtemplate.client.TdTemplateControllerUpdater;
|
||||||
|
|
||||||
import com.allen_sauer.gwt.log.client.Log;
|
|
||||||
import com.google.web.bindery.event.shared.EventBus;
|
import com.google.web.bindery.event.shared.EventBus;
|
||||||
import com.sencha.gxt.widget.core.client.Window;
|
import com.sencha.gxt.widget.core.client.Window;
|
||||||
import com.sencha.gxt.widget.core.client.event.SelectEvent;
|
import com.sencha.gxt.widget.core.client.event.SelectEvent;
|
||||||
|
@ -20,10 +17,9 @@ import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class TemplateOpenDialog extends Window {
|
public class TemplateOpenDialog extends Window {
|
||||||
protected String WIDTH = "720px";
|
private static final String WIDTH = "720px";
|
||||||
protected String HEIGHT = "530px";
|
private static final String HEIGHT = "530px";
|
||||||
protected TemplateDeleteSession templateDeleteSession;
|
private EventBus eventBus;
|
||||||
protected EventBus eventBus;
|
|
||||||
|
|
||||||
public TemplateOpenDialog(EventBus eventBus) {
|
public TemplateOpenDialog(EventBus eventBus) {
|
||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
|
@ -76,12 +72,6 @@ public class TemplateOpenDialog extends Window {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void templateShare(TemplateData templateData) {
|
|
||||||
Log.debug("Open Share Window");
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
TemplateShare templateShare = new TemplateShare(templateData, eventBus);
|
|
||||||
close();
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,8 +5,11 @@ import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
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.client.rpc.TDGWTServiceAsync;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.exception.TDGWTSessionExpiredException;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
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.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 com.allen_sauer.gwt.log.client.Log;
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
import com.google.gwt.core.client.GWT;
|
import com.google.gwt.core.client.GWT;
|
||||||
|
@ -51,29 +54,27 @@ import com.sencha.gxt.widget.core.client.toolbar.ToolBar;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author giancarlo
|
* @author giancarlo email: <a
|
||||||
* email: <a href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
public class TemplateOpenPanel extends FramedPanel {
|
public class TemplateOpenPanel extends FramedPanel {
|
||||||
protected String WIDTH = "630px";
|
private static final String WIDTH = "630px";
|
||||||
protected String HEIGHT = "520px";
|
private static final String HEIGHT = "520px";
|
||||||
protected EventBus eventBus;
|
private EventBus eventBus;
|
||||||
protected TemplateOpenDialog parent;
|
private TemplateOpenDialog parent;
|
||||||
|
|
||||||
|
|
||||||
private TextButton btnOpen;
|
private TextButton btnOpen;
|
||||||
private TextButton btnClose;
|
private TextButton btnClose;
|
||||||
private TextButton btnShare;
|
|
||||||
|
|
||||||
protected ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
|
||||||
protected Grid<TemplateData> grid;
|
private ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
||||||
protected ExtendedListStore<TemplateData> store;
|
private Grid<TemplateData> grid;
|
||||||
|
private ExtendedListStore<TemplateData> store;
|
||||||
public TemplateOpenPanel(TemplateOpenDialog parent,
|
|
||||||
EventBus eventBus) {
|
public TemplateOpenPanel(TemplateOpenDialog parent, EventBus eventBus) {
|
||||||
this.parent = parent;
|
this.parent = parent;
|
||||||
Log.debug("TemplateDeletePanel");
|
Log.debug("TemplateOpenPanel");
|
||||||
setWidth(WIDTH);
|
setWidth(WIDTH);
|
||||||
setHeight(HEIGHT);
|
setHeight(HEIGHT);
|
||||||
setHeaderVisible(false);
|
setHeaderVisible(false);
|
||||||
|
@ -89,15 +90,13 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
toolBarHead.add(new LabelToolItem("Search: "));
|
toolBarHead.add(new LabelToolItem("Search: "));
|
||||||
final TextField searchField = new TextField();
|
final TextField searchField = new TextField();
|
||||||
toolBarHead.add(searchField);
|
toolBarHead.add(searchField);
|
||||||
|
|
||||||
TextButton btnReload = new TextButton();
|
TextButton btnReload = new TextButton();
|
||||||
//btnReload.setText("Reload");
|
// btnReload.setText("Reload");
|
||||||
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
btnReload.setIcon(TabularDataResources.INSTANCE.refresh());
|
||||||
btnReload.setToolTip("Reload");
|
btnReload.setToolTip("Reload");
|
||||||
toolBarHead.add(btnReload);
|
toolBarHead.add(btnReload);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
IdentityValueProvider<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
||||||
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
||||||
identity);
|
identity);
|
||||||
|
@ -108,10 +107,10 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
props.name(), 120, "Name");
|
props.name(), 120, "Name");
|
||||||
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.category(), 60, "Category");
|
props.category(), 60, "Category");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.ownerLogin(), 70, "Owner");
|
props.ownerLogin(), 70, "Owner");
|
||||||
|
|
||||||
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
||||||
props.agency(), 100, "Agency");
|
props.agency(), 100, "Agency");
|
||||||
|
|
||||||
|
@ -126,30 +125,30 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
l.add(descriptionCol);
|
l.add(descriptionCol);
|
||||||
|
|
||||||
ColumnModel<TemplateData> cm = new ColumnModel<TemplateData>(l);
|
ColumnModel<TemplateData> cm = new ColumnModel<TemplateData>(l);
|
||||||
|
|
||||||
store = new ExtendedListStore<TemplateData>(props.id());
|
store = new ExtendedListStore<TemplateData>(props.id());
|
||||||
|
|
||||||
searchField.addKeyUpHandler(new KeyUpHandler() {
|
searchField.addKeyUpHandler(new KeyUpHandler() {
|
||||||
|
|
||||||
public void onKeyUp(KeyUpEvent event) {
|
public void onKeyUp(KeyUpEvent event) {
|
||||||
Log.trace("searchTerm: "+searchField.getCurrentValue());
|
Log.trace("searchTerm: " + searchField.getCurrentValue());
|
||||||
store.applyFilters();
|
store.applyFilters();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.addFilter(new StoreFilter<TemplateData>() {
|
store.addFilter(new StoreFilter<TemplateData>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean select(Store<TemplateData> store,
|
public boolean select(Store<TemplateData> store,
|
||||||
TemplateData parent, TemplateData item) {
|
TemplateData parent, TemplateData item) {
|
||||||
String searchTerm = searchField.getCurrentValue();
|
String searchTerm = searchField.getCurrentValue();
|
||||||
if (searchTerm == null) return true;
|
if (searchTerm == null)
|
||||||
|
return true;
|
||||||
return TemplateOpenPanel.this.select(item, searchTerm);
|
return TemplateOpenPanel.this.select(item, searchTerm);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
store.setEnableFilters(true);
|
store.setEnableFilters(true);
|
||||||
|
|
||||||
|
|
||||||
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
||||||
|
|
||||||
|
@ -165,15 +164,15 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
||||||
store) {
|
store) {
|
||||||
});
|
});
|
||||||
|
|
||||||
SelectHandler sh = new SelectHandler() {
|
SelectHandler sh = new SelectHandler() {
|
||||||
public void onSelect(SelectEvent event) {
|
public void onSelect(SelectEvent event) {
|
||||||
loader.load();
|
loader.load();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
btnReload.addSelectHandler(sh);
|
btnReload.addSelectHandler(sh);
|
||||||
|
|
||||||
grid = new Grid<TemplateData>(store, cm) {
|
grid = new Grid<TemplateData>(store, cm) {
|
||||||
@Override
|
@Override
|
||||||
protected void onAfterFirstAttach() {
|
protected void onAfterFirstAttach() {
|
||||||
|
@ -229,34 +228,24 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
btnShare = new TextButton("Share");
|
|
||||||
btnShare.setIcon(TabularDataResources.INSTANCE.share());
|
|
||||||
btnShare.setIconAlign(IconAlign.RIGHT);
|
|
||||||
btnShare.setTitle("Share");
|
|
||||||
btnShare.addSelectHandler(new SelectHandler() {
|
|
||||||
|
|
||||||
public void onSelect(SelectEvent event) {
|
|
||||||
Log.debug("Pressed Share");
|
|
||||||
share();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
||||||
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
||||||
flowButton.setPack(BoxLayoutPack.CENTER);
|
flowButton.setPack(BoxLayoutPack.CENTER);
|
||||||
|
|
||||||
BoxLayoutData boxLayoutData= new BoxLayoutData(new Margins(2, 4, 2, 4));
|
BoxLayoutData boxLayoutData = new BoxLayoutData(new Margins(2, 4, 2, 4));
|
||||||
flowButton.add(btnOpen, boxLayoutData);
|
flowButton.add(btnOpen, boxLayoutData);
|
||||||
flowButton.add(btnClose, boxLayoutData);
|
flowButton.add(btnClose, boxLayoutData);
|
||||||
flowButton.add(btnShare, boxLayoutData);
|
|
||||||
|
|
||||||
VerticalLayoutContainer v = new VerticalLayoutContainer();
|
VerticalLayoutContainer v = new VerticalLayoutContainer();
|
||||||
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
v.add(toolBarHead, new VerticalLayoutData(1, -1, new Margins(0)));
|
||||||
v.add(grid, 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(toolBar, new VerticalLayoutData(1, 25, new Margins(0)));
|
||||||
v.add(flowButton, new VerticalLayoutData(1, 36,
|
v.add(flowButton,
|
||||||
new Margins(5, 2, 5, 2)));
|
new VerticalLayoutData(1, 36, new Margins(5, 2, 5, 2)));
|
||||||
add(v);
|
add(v);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -268,10 +257,15 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
||||||
|
|
||||||
public void onFailure(Throwable caught) {
|
public void onFailure(Throwable caught) {
|
||||||
Log.error("load templates failure:"
|
if (caught instanceof TDGWTSessionExpiredException) {
|
||||||
+ caught.getLocalizedMessage());
|
eventBus.fireEvent(new SessionExpiredEvent(
|
||||||
UtilsGXT3.alert("Error retrieving templates",
|
SessionExpiredType.EXPIREDONSERVER));
|
||||||
"Error retrieving templates");
|
} else {
|
||||||
|
Log.error("Load templates failure:"
|
||||||
|
+ caught.getLocalizedMessage());
|
||||||
|
UtilsGXT3.alert("Error retrieving templates",
|
||||||
|
"Error retrieving templates");
|
||||||
|
}
|
||||||
callback.onFailure(caught);
|
callback.onFailure(caught);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -286,95 +280,68 @@ public class TemplateOpenPanel extends FramedPanel {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/*protected void setMenu() {
|
|
||||||
Menu contextMenu = new Menu();
|
|
||||||
|
|
||||||
MenuItem deleteTemplateItem = new MenuItem("Delete");
|
|
||||||
deleteTemplateItem.setId("DeleteTemplate");
|
|
||||||
deleteTemplateItem.setIcon(ResourceBundle.INSTANCE.removeTemplate());
|
|
||||||
deleteTemplateItem.addSelectionHandler(new SelectionHandler<Item>() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onSelection(SelectionEvent<Item> event) {
|
|
||||||
Log.debug("Delete Template");
|
|
||||||
TemplateData templateDesc = getSelectedItem();
|
|
||||||
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
grid.setContextMenu(contextMenu);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
protected ArrayList<TemplateData> getSelectedItem() {
|
protected ArrayList<TemplateData> getSelectedItem() {
|
||||||
ArrayList<TemplateData> templates=new ArrayList<TemplateData>();
|
ArrayList<TemplateData> templates = new ArrayList<TemplateData>();
|
||||||
for(TemplateData template:grid.getSelectionModel().getSelectedItems()){
|
for (TemplateData template : grid.getSelectionModel()
|
||||||
|
.getSelectedItems()) {
|
||||||
templates.add(template);
|
templates.add(template);
|
||||||
}
|
}
|
||||||
return templates;
|
return templates;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void open() {
|
protected void open() {
|
||||||
|
|
||||||
ArrayList<TemplateData> templates=getSelectedItem();
|
ArrayList<TemplateData> templates = getSelectedItem();
|
||||||
if(templates==null|| templates.size()==0){
|
if (templates == null || templates.size() == 0) {
|
||||||
UtilsGXT3.info("Attention",
|
UtilsGXT3.info("Attention", "Select the template");
|
||||||
"Select the template");
|
|
||||||
} else {
|
} else {
|
||||||
TemplateData template=templates.get(0);
|
TemplateData template = templates.get(0);
|
||||||
Log.debug("templateOpenSession: " + template);
|
Log.debug("templateOpenSession: " + template);
|
||||||
parent.templateOpen(template);
|
parent.templateOpen(template);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void share() {
|
|
||||||
|
|
||||||
ArrayList<TemplateData> templates=getSelectedItem();
|
|
||||||
if(templates==null|| templates.size()==0){
|
|
||||||
UtilsGXT3.info("Attention",
|
|
||||||
"Select the template");
|
|
||||||
} else {
|
|
||||||
TemplateData template=templates.get(0);
|
|
||||||
Log.debug("templateShare: " + template);
|
|
||||||
parent.templateShare(template);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected void close() {
|
protected void close() {
|
||||||
parent.close();
|
parent.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected class ExtendedListStore<M> extends ListStore<M> {
|
protected class ExtendedListStore<M> extends ListStore<M> {
|
||||||
|
|
||||||
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
public ExtendedListStore(ModelKeyProvider<? super M> keyProvider) {
|
||||||
super(keyProvider);
|
super(keyProvider);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void applyFilters()
|
public void applyFilters() {
|
||||||
{
|
|
||||||
super.applyFilters();
|
super.applyFilters();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void gridReload(){
|
public void gridReload() {
|
||||||
grid.getLoader().load();
|
grid.getLoader().load();
|
||||||
}
|
}
|
||||||
|
|
||||||
protected boolean select(TemplateData item, String searchTerm) {
|
protected boolean select(TemplateData item, String searchTerm) {
|
||||||
if (item.getName()!=null && item.getName().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
if (item.getName() != null
|
||||||
if (item.getCategory()!=null &&item.getCategory().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
&& item.getName().toLowerCase()
|
||||||
if (item.getAgency()!=null &&item.getAgency().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
.contains(searchTerm.toLowerCase()))
|
||||||
if (item.getDescription()!=null && item.getDescription().toLowerCase().contains(searchTerm.toLowerCase())) return true;
|
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;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,76 @@
|
||||||
|
package org.gcube.portlets.user.td.client.template;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.td.client.resource.TabularDataResources;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.template.TemplateData;
|
||||||
|
import org.gcube.portlets.user.td.sharewidget.client.TemplateShare;
|
||||||
|
|
||||||
|
import com.allen_sauer.gwt.log.client.Log;
|
||||||
|
import com.google.web.bindery.event.shared.EventBus;
|
||||||
|
import com.sencha.gxt.widget.core.client.Window;
|
||||||
|
import com.sencha.gxt.widget.core.client.event.SelectEvent;
|
||||||
|
import com.sencha.gxt.widget.core.client.event.SelectEvent.SelectHandler;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author "Giancarlo Panichi" <a
|
||||||
|
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class TemplateShareDialog extends Window {
|
||||||
|
private static final String WIDTH = "720px";
|
||||||
|
private static final String HEIGHT = "530px";
|
||||||
|
|
||||||
|
private EventBus eventBus;
|
||||||
|
|
||||||
|
public TemplateShareDialog(EventBus eventBus) {
|
||||||
|
this.eventBus = eventBus;
|
||||||
|
initWindow();
|
||||||
|
|
||||||
|
TemplateSharePanel templateDeletePanel = new TemplateSharePanel(this,
|
||||||
|
eventBus);
|
||||||
|
add(templateDeletePanel);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void initWindow() {
|
||||||
|
setWidth(WIDTH);
|
||||||
|
setHeight(HEIGHT);
|
||||||
|
setBodyBorder(false);
|
||||||
|
setResizable(false);
|
||||||
|
setHeadingText("Share Template");
|
||||||
|
setClosable(true);
|
||||||
|
setModal(true);
|
||||||
|
forceLayoutOnResize = true;
|
||||||
|
getHeader().setIcon(TabularDataResources.INSTANCE.templateShare());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void initTools() {
|
||||||
|
super.initTools();
|
||||||
|
|
||||||
|
closeBtn.addSelectHandler(new SelectHandler() {
|
||||||
|
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void close() {
|
||||||
|
hide();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void templateShare(TemplateData templateData) {
|
||||||
|
Log.debug("Share Window");
|
||||||
|
@SuppressWarnings("unused")
|
||||||
|
TemplateShare templateShare = new TemplateShare(templateData, eventBus);
|
||||||
|
close();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,346 @@
|
||||||
|
package org.gcube.portlets.user.td.client.template;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
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.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 com.allen_sauer.gwt.log.client.Log;
|
||||||
|
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.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 email: <a
|
||||||
|
* href="mailto:g.panichi@isti.cnr.it">g.panichi@isti.cnr.it</a>
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class TemplateSharePanel extends FramedPanel {
|
||||||
|
private static final String WIDTH = "630px";
|
||||||
|
private static final String HEIGHT = "520px";
|
||||||
|
private EventBus eventBus;
|
||||||
|
private TemplateShareDialog parent;
|
||||||
|
|
||||||
|
private TextButton btnClose;
|
||||||
|
private TextButton btnShare;
|
||||||
|
|
||||||
|
private ListLoader<ListLoadConfig, ListLoadResult<TemplateData>> loader;
|
||||||
|
private Grid<TemplateData> grid;
|
||||||
|
private ExtendedListStore<TemplateData> store;
|
||||||
|
|
||||||
|
public TemplateSharePanel(TemplateShareDialog parent, EventBus eventBus) {
|
||||||
|
this.parent = parent;
|
||||||
|
Log.debug("TemplateSharePanel");
|
||||||
|
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<TemplateData> identity = new IdentityValueProvider<TemplateData>();
|
||||||
|
CheckBoxSelectionModel<TemplateData> sm = new CheckBoxSelectionModel<TemplateData>(
|
||||||
|
identity);
|
||||||
|
|
||||||
|
TemplateDataProperties props = GWT.create(TemplateDataProperties.class);
|
||||||
|
|
||||||
|
ColumnConfig<TemplateData, String> nameCol = new ColumnConfig<TemplateData, String>(
|
||||||
|
props.name(), 120, "Name");
|
||||||
|
ColumnConfig<TemplateData, String> categoryCol = new ColumnConfig<TemplateData, String>(
|
||||||
|
props.category(), 60, "Category");
|
||||||
|
|
||||||
|
ColumnConfig<TemplateData, String> ownerCol = new ColumnConfig<TemplateData, String>(
|
||||||
|
props.ownerLogin(), 70, "Owner");
|
||||||
|
|
||||||
|
ColumnConfig<TemplateData, String> agencyCol = new ColumnConfig<TemplateData, String>(
|
||||||
|
props.agency(), 100, "Agency");
|
||||||
|
|
||||||
|
ColumnConfig<TemplateData, String> descriptionCol = new ColumnConfig<TemplateData, String>(
|
||||||
|
props.description(), 120, "Description");
|
||||||
|
|
||||||
|
List<ColumnConfig<TemplateData, ?>> l = new ArrayList<ColumnConfig<TemplateData, ?>>();
|
||||||
|
l.add(nameCol);
|
||||||
|
l.add(categoryCol);
|
||||||
|
l.add(ownerCol);
|
||||||
|
l.add(agencyCol);
|
||||||
|
l.add(descriptionCol);
|
||||||
|
|
||||||
|
ColumnModel<TemplateData> cm = new ColumnModel<TemplateData>(l);
|
||||||
|
|
||||||
|
store = new ExtendedListStore<TemplateData>(props.id());
|
||||||
|
|
||||||
|
searchField.addKeyUpHandler(new KeyUpHandler() {
|
||||||
|
|
||||||
|
public void onKeyUp(KeyUpEvent event) {
|
||||||
|
Log.trace("searchTerm: " + searchField.getCurrentValue());
|
||||||
|
store.applyFilters();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
store.addFilter(new StoreFilter<TemplateData>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean select(Store<TemplateData> store,
|
||||||
|
TemplateData parent, TemplateData item) {
|
||||||
|
String searchTerm = searchField.getCurrentValue();
|
||||||
|
if (searchTerm == null)
|
||||||
|
return true;
|
||||||
|
return TemplateSharePanel.this.select(item, searchTerm);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
store.setEnableFilters(true);
|
||||||
|
|
||||||
|
RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>> proxy = new RpcProxy<ListLoadConfig, ListLoadResult<TemplateData>>() {
|
||||||
|
|
||||||
|
public void load(ListLoadConfig loadConfig,
|
||||||
|
final AsyncCallback<ListLoadResult<TemplateData>> callback) {
|
||||||
|
loadData(loadConfig, callback);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
loader = new ListLoader<ListLoadConfig, ListLoadResult<TemplateData>>(
|
||||||
|
proxy);
|
||||||
|
|
||||||
|
loader.setRemoteSort(false);
|
||||||
|
loader.addLoadHandler(new LoadResultListStoreBinding<ListLoadConfig, TemplateData, ListLoadResult<TemplateData>>(
|
||||||
|
store) {
|
||||||
|
});
|
||||||
|
|
||||||
|
SelectHandler sh = new SelectHandler() {
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
loader.load();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
btnReload.addSelectHandler(sh);
|
||||||
|
|
||||||
|
grid = new Grid<TemplateData>(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");
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
btnClose = new TextButton("Close");
|
||||||
|
btnClose.setIcon(TabularDataResources.INSTANCE.close());
|
||||||
|
btnClose.setIconAlign(IconAlign.RIGHT);
|
||||||
|
btnClose.setTitle("Close");
|
||||||
|
btnClose.addSelectHandler(new SelectHandler() {
|
||||||
|
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
Log.debug("Pressed Close");
|
||||||
|
close();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
btnShare = new TextButton("Share");
|
||||||
|
btnShare.setIcon(TabularDataResources.INSTANCE.share());
|
||||||
|
btnShare.setIconAlign(IconAlign.RIGHT);
|
||||||
|
btnShare.setTitle("Share");
|
||||||
|
btnShare.addSelectHandler(new SelectHandler() {
|
||||||
|
|
||||||
|
public void onSelect(SelectEvent event) {
|
||||||
|
Log.debug("Pressed Share");
|
||||||
|
share();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
HBoxLayoutContainer flowButton = new HBoxLayoutContainer();
|
||||||
|
flowButton.setHBoxLayoutAlign(HBoxLayoutAlign.MIDDLE);
|
||||||
|
flowButton.setPack(BoxLayoutPack.CENTER);
|
||||||
|
|
||||||
|
BoxLayoutData boxLayoutData = new BoxLayoutData(new Margins(2, 4, 2, 4));
|
||||||
|
flowButton.add(btnShare, boxLayoutData);
|
||||||
|
flowButton.add(btnClose, boxLayoutData);
|
||||||
|
|
||||||
|
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<ListLoadResult<TemplateData>> callback) {
|
||||||
|
|
||||||
|
TDGWTServiceAsync.INSTANCE
|
||||||
|
.getTemplates(new AsyncCallback<ArrayList<TemplateData>>() {
|
||||||
|
|
||||||
|
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<TemplateData> result) {
|
||||||
|
Log.trace("loaded " + result.size() + " Occurences");
|
||||||
|
callback.onSuccess(new ListLoadResultBean<TemplateData>(
|
||||||
|
result));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
protected ArrayList<TemplateData> getSelectedItem() {
|
||||||
|
ArrayList<TemplateData> templates = new ArrayList<TemplateData>();
|
||||||
|
for (TemplateData template : grid.getSelectionModel()
|
||||||
|
.getSelectedItems()) {
|
||||||
|
templates.add(template);
|
||||||
|
}
|
||||||
|
return templates;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
protected void share() {
|
||||||
|
|
||||||
|
ArrayList<TemplateData> templates = getSelectedItem();
|
||||||
|
if (templates == null || templates.size() == 0) {
|
||||||
|
UtilsGXT3.info("Attention", "Select the template");
|
||||||
|
} else {
|
||||||
|
TemplateData template = templates.get(0);
|
||||||
|
Log.debug("templateShare: " + template);
|
||||||
|
parent.templateShare(template);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void close() {
|
||||||
|
parent.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected class ExtendedListStore<M> extends ListStore<M> {
|
||||||
|
|
||||||
|
public ExtendedListStore(ModelKeyProvider<? super M> 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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -76,18 +76,18 @@
|
||||||
<!-- Specify the app entry point class. -->
|
<!-- Specify the app entry point class. -->
|
||||||
<entry-point class='org.gcube.portlets.user.td.client.TabularDataPortlet' />
|
<entry-point class='org.gcube.portlets.user.td.client.TabularDataPortlet' />
|
||||||
|
|
||||||
|
<!--
|
||||||
<set-property name="log_ConsoleLogger" value="ENABLED" />
|
<set-property name="log_ConsoleLogger" value="ENABLED" />
|
||||||
<set-property name="log_DivLogger" value="ENABLED" />
|
<set-property name="log_DivLogger" value="ENABLED" />
|
||||||
<set-property name="log_GWTLogger" value="ENABLED" />
|
<set-property name="log_GWTLogger" value="ENABLED" />
|
||||||
<set-property name="log_SystemLogger" value="ENABLED" />
|
<set-property name="log_SystemLogger" value="ENABLED" /> -->
|
||||||
<!-- Not in GWT 2.6 <set-property name="log_FirebugLogger" value="ENABLED" /> -->
|
<!-- Not in GWT 2.6 <set-property name="log_FirebugLogger" value="ENABLED" /> -->
|
||||||
|
|
||||||
<!--
|
|
||||||
<set-property name="log_ConsoleLogger" value="DISABLED" />
|
<set-property name="log_ConsoleLogger" value="DISABLED" />
|
||||||
<set-property name="log_DivLogger" value="DISABLED" />
|
<set-property name="log_DivLogger" value="DISABLED" />
|
||||||
<set-property name="log_GWTLogger" value="DISABLED" />
|
<set-property name="log_GWTLogger" value="DISABLED" />
|
||||||
<set-property name="log_SystemLogger" value="DISABLED" /> -->
|
<set-property name="log_SystemLogger" value="DISABLED" />
|
||||||
<!-- Not in GWT 2.6 <set-property name="log_FirebugLogger" value="DISABLED" /> -->
|
<!-- Not in GWT 2.6 <set-property name="log_FirebugLogger" value="DISABLED" /> -->
|
||||||
|
|
||||||
<!-- Specify the paths for translatable code -->
|
<!-- Specify the paths for translatable code -->
|
||||||
|
|
Loading…
Reference in New Issue