256: Workspace explorer

Task-Url: https://support.d4science.org/issues/256

Added events
Refactor

git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/widgets/workspace-explorer@115616 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
Francesco Mangiacrapa 2015-06-29 13:58:35 +00:00
parent a7f22fde61
commit 140cf9ce2c
9 changed files with 219 additions and 30 deletions

View File

@ -17,6 +17,7 @@ import org.gcube.portlets.widgets.wsexplorer.client.view.Breadcrumbs;
import org.gcube.portlets.widgets.wsexplorer.client.view.Navigation; import org.gcube.portlets.widgets.wsexplorer.client.view.Navigation;
import org.gcube.portlets.widgets.wsexplorer.client.view.WorkspaceExplorer; import org.gcube.portlets.widgets.wsexplorer.client.view.WorkspaceExplorer;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;
import org.gcube.portlets.widgets.wsexplorer.shared.ItemType;
import com.google.gwt.core.client.GWT; import com.google.gwt.core.client.GWT;
import com.google.gwt.event.shared.EventHandler; import com.google.gwt.event.shared.EventHandler;
@ -30,13 +31,14 @@ import com.google.gwt.user.client.rpc.AsyncCallback;
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it * @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
* Jun 25, 2015 * Jun 25, 2015
*/ */
public class WorkspaceExplorerController implements EventHandler{ public class WorkspaceExplorerController implements EventHandler {
public final static HandlerManager eventBus = new HandlerManager(null); public final static HandlerManager eventBus = new HandlerManager(null);
private WorkspaceExplorerPanel workspaceExplorerPanel; private WorkspaceExplorerPanel workspaceExplorerPanel;
private WorkspaceExplorer wsExplorer = new WorkspaceExplorer(); private WorkspaceExplorer wsExplorer;
private Breadcrumbs breadcrumbs = new Breadcrumbs(); private Breadcrumbs breadcrumbs = new Breadcrumbs();
private Navigation navigation = new Navigation(); private Navigation navigation = new Navigation();
public static final WorkspaceExplorerServiceAsync workspaceNavigatorService = GWT.create(WorkspaceExplorerService.class); public static final WorkspaceExplorerServiceAsync workspaceNavigatorService = GWT.create(WorkspaceExplorerService.class);
/** /**
@ -44,6 +46,7 @@ public class WorkspaceExplorerController implements EventHandler{
*/ */
public WorkspaceExplorerController(){ public WorkspaceExplorerController(){
bindEvents(); bindEvents();
wsExplorer = new WorkspaceExplorer();
workspaceExplorerPanel = new WorkspaceExplorerPanel(5, wsExplorer.getPanel(), breadcrumbs, navigation); workspaceExplorerPanel = new WorkspaceExplorerPanel(5, wsExplorer.getPanel(), breadcrumbs, navigation);
} }
@ -68,7 +71,7 @@ public class WorkspaceExplorerController implements EventHandler{
@Override @Override
public void onLoadRoot(LoadRootEvent loadRootEvent) { public void onLoadRoot(LoadRootEvent loadRootEvent) {
wsExplorer.loadTree(); wsExplorer.loadRoot();
breadcrumbs.init(); breadcrumbs.init();
} }
}); });
@ -125,4 +128,32 @@ public class WorkspaceExplorerController implements EventHandler{
public WorkspaceExplorer getWsExplorer() { public WorkspaceExplorer getWsExplorer() {
return wsExplorer; return wsExplorer;
} }
/**
* @param selectableTypes
*/
public void setSelectableTypes(ItemType[] selectableTypes) {
wsExplorer.setSelectableTypes(selectableTypes);
}
/**
* @return the selectableTypes
*/
public List<ItemType> getSelectableTypes() {
return wsExplorer.getSelectableTypes();
}
/**
* @return
*/
public List<ItemType> getShowableTypes() {
return wsExplorer.getShowableTypes();
}
/**
* @param showableTypes
*/
public void setShowableTypes(ItemType[] showableTypes) {
wsExplorer.setShowableTypes(showableTypes);
}
} }

View File

@ -11,6 +11,7 @@ import org.gcube.portlets.widgets.wsexplorer.client.WorkspaceExplorerController;
import org.gcube.portlets.widgets.wsexplorer.client.notification.WorskpaceExplorerNotification.HasWorskpaceExplorerNotificationListener; import org.gcube.portlets.widgets.wsexplorer.client.notification.WorskpaceExplorerNotification.HasWorskpaceExplorerNotificationListener;
import org.gcube.portlets.widgets.wsexplorer.client.notification.WorskpaceExplorerNotification.WorskpaceExplorerNotificationListener; import org.gcube.portlets.widgets.wsexplorer.client.notification.WorskpaceExplorerNotification.WorskpaceExplorerNotificationListener;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;
import org.gcube.portlets.widgets.wsexplorer.shared.ItemType;
import com.github.gwtbootstrap.client.ui.Modal; import com.github.gwtbootstrap.client.ui.Modal;
import com.github.gwtbootstrap.client.ui.ModalFooter; import com.github.gwtbootstrap.client.ui.ModalFooter;
@ -48,6 +49,7 @@ public class WorkspaceExplorerLoadDialog extends Modal implements HasWorskpaceEx
* Add {@link WorskpaceExplorerNotificationListener} to receive events * Add {@link WorskpaceExplorerNotificationListener} to receive events
*/ */
public WorkspaceExplorerLoadDialog(String captionTxt) { public WorkspaceExplorerLoadDialog(String captionTxt) {
this.captionTxt = (captionTxt==null || captionTxt.isEmpty())?WorkspaceExplorerConstants.WORKSPACE_EXPLORER_CAPTION:captionTxt; this.captionTxt = (captionTxt==null || captionTxt.isEmpty())?WorkspaceExplorerConstants.WORKSPACE_EXPLORER_CAPTION:captionTxt;
// setText(this.captionTxt); // setText(this.captionTxt);
setAnimation(false); setAnimation(false);
@ -68,6 +70,7 @@ public class WorkspaceExplorerLoadDialog extends Modal implements HasWorskpaceEx
} }
}); });
// DockPanel dock = new DockPanel(); // DockPanel dock = new DockPanel();
// dock.setSpacing(5); // dock.setSpacing(5);
@ -133,8 +136,6 @@ public class WorkspaceExplorerLoadDialog extends Modal implements HasWorskpaceEx
/** /**
* Notify aborted. * Notify aborted.
*
* @param selected the selected
*/ */
private void notifyAborted(){ private void notifyAborted(){
@ -202,4 +203,38 @@ public class WorkspaceExplorerLoadDialog extends Modal implements HasWorskpaceEx
listeners.remove(handler); listeners.remove(handler);
} }
} }
/**
* Set which items are selectable.
* @param selectableTypes the selectableTypes to set
*/
public void setSelectableTypes(ItemType ... selectableTypes) {
controller.setSelectableTypes(selectableTypes);
}
/**
* Gets the selectable types.
*
* @return the selectable types
*/
public List<ItemType> getSelectableTypes() {
return controller.getSelectableTypes();
}
/**
* Return the showable items.
* @return the showableTypes
*/
public List<ItemType> getShowableTypes() {
return controller.getShowableTypes();
}
/**
* Set the showable items. The folders items are show as default.
* @param showableTypes the showableTypes to set
*/
public void setShowableTypes(ItemType ... showableTypes) {
controller.setShowableTypes(showableTypes);
}
} }

View File

@ -3,9 +3,6 @@
*/ */
package org.gcube.portlets.widgets.wsexplorer.client.notification; package org.gcube.portlets.widgets.wsexplorer.client.notification;
import java.util.ArrayList;
import java.util.List;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;

View File

@ -0,0 +1,34 @@
/**
*
*/
package org.gcube.portlets.widgets.wsexplorer.client.view;
import java.util.List;
import org.gcube.portlets.widgets.wsexplorer.shared.ItemType;
/**
* The Interface SelectableTypes.
*
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
* Jun 29, 2015
*/
public interface SelectableTypes {
/**
* Sets the selectable types.
*
* @param selectableTypes the new selectable types
*/
public void setSelectableTypes(ItemType ... selectableTypes);
/**
* Gets the selectable types.
*
* @return the selectable types
*/
public List<ItemType> getSelectableTypes();
}

View File

@ -1,15 +1,14 @@
/** /**
* *
*/ */
package org.gcube.portlets.widgets.wsexplorer.client.notification; package org.gcube.portlets.widgets.wsexplorer.client.view;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;
/** /**
* The Class SelectionItemNotification. * The Interface SelectionItem.
* *
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it * @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
* Jun 29, 2015 * Jun 29, 2015

View File

@ -0,0 +1,33 @@
/**
*
*/
package org.gcube.portlets.widgets.wsexplorer.client.view;
import java.util.List;
import org.gcube.portlets.widgets.wsexplorer.shared.ItemType;
/**
* The Interface ShowableTypes.
*
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
* Jun 29, 2015
*/
public interface ShowableTypes {
/**
* Gets the showable types.
*
* @return the showable types
*/
public List<ItemType> getShowableTypes();
/**
* Sets the showable types.
*
* @param showableTypes the new showable types
*/
public void setShowableTypes(ItemType ... showableTypes);
}

View File

@ -7,8 +7,8 @@ import java.util.Map;
import org.gcube.portlets.widgets.wsexplorer.client.Util; import org.gcube.portlets.widgets.wsexplorer.client.Util;
import org.gcube.portlets.widgets.wsexplorer.client.WorkspaceExplorerController; import org.gcube.portlets.widgets.wsexplorer.client.WorkspaceExplorerController;
import org.gcube.portlets.widgets.wsexplorer.client.grid.ItemsTable;
import org.gcube.portlets.widgets.wsexplorer.client.resources.WorkspaceExplorerResources; import org.gcube.portlets.widgets.wsexplorer.client.resources.WorkspaceExplorerResources;
import org.gcube.portlets.widgets.wsexplorer.client.view.grid.ItemsTable;
import org.gcube.portlets.widgets.wsexplorer.shared.FilterCriteria; import org.gcube.portlets.widgets.wsexplorer.shared.FilterCriteria;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;
import org.gcube.portlets.widgets.wsexplorer.shared.ItemType; import org.gcube.portlets.widgets.wsexplorer.shared.ItemType;
@ -23,8 +23,11 @@ import com.google.gwt.user.client.ui.ScrollPanel;
/** /**
* Entry point classes define <code>onModuleLoad()</code>. * Entry point classes define <code>onModuleLoad()</code>.
*
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
* Jun 29, 2015
*/ */
public class WorkspaceExplorer { public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
protected static final HorizontalPanel LOADING_PANEL = new HorizontalPanel(); protected static final HorizontalPanel LOADING_PANEL = new HorizontalPanel();
@ -51,18 +54,24 @@ public class WorkspaceExplorer {
protected ScrollPanel explorerPanel; protected ScrollPanel explorerPanel;
private ItemsTable itTables; private ItemsTable itTables;
/**
* Instantiates a new workspace explorer.
*
* As default all items are showable and selectable
*/
public WorkspaceExplorer() { public WorkspaceExplorer() {
// as default all items are showable and selectable
for (ItemType type : ItemType.values()) { for (ItemType type : ItemType.values()) {
showableTypes.add(type); showableTypes.add(type);
selectableTypes.add(type); selectableTypes.add(type);
} }
explorerPanel = new ScrollPanel(); explorerPanel = new ScrollPanel();
// sp.setWidth(width+"px"); }
// sp.setHeight(height+"px");
public void loadItems(){
loadTree(); loadRoot();
} }
/** /**
@ -76,13 +85,12 @@ public class WorkspaceExplorer {
/** /**
* Load the Workspace Tree. * Load the Workspace Tree.
*/ */
public void loadTree() { public void loadRoot() {
GWT.log("loading tree data"); GWT.log("loading tree data");
setLoading(); setLoading();
// we make a copy of showable types // we make a copy of showable types
List<ItemType> showableTypesParam = new ArrayList<ItemType>( List<ItemType> showableTypesParam = new ArrayList<ItemType>(showableTypes);
showableTypes);
// we get sure that folders are displayed // we get sure that folders are displayed
for (ItemType folder : Util.FOLDERS) { for (ItemType folder : Util.FOLDERS) {
@ -92,16 +100,14 @@ public class WorkspaceExplorer {
boolean purgeEmpyFolders = !showEmptyFolders; boolean purgeEmpyFolders = !showEmptyFolders;
FilterCriteria filterCriteria = new FilterCriteria(allowedMimeTypes, FilterCriteria filterCriteria = new FilterCriteria(allowedMimeTypes,requiredProperties);
requiredProperties);
GWT.log("loading workspace tree from server"); GWT.log("loading workspace tree from server");
WorkspaceExplorerController.workspaceNavigatorService.getRoot(showableTypesParam, purgeEmpyFolders, filterCriteria, new AsyncCallback<Item>() { WorkspaceExplorerController.workspaceNavigatorService.getRoot(showableTypesParam, purgeEmpyFolders, filterCriteria, new AsyncCallback<Item>() {
public void onFailure(Throwable caught) { public void onFailure(Throwable caught) {
GWT.log("Error loading workspace tree from server", GWT.log("Error loading workspace tree from server",caught);
caught);
} }
public void onSuccess(Item item) { public void onSuccess(Item item) {
@ -113,6 +119,8 @@ public class WorkspaceExplorer {
/** /**
* Load the Workspace Tree. * Load the Workspace Tree.
*
* @param item the item
*/ */
public void loadFolder(Item item) { public void loadFolder(Item item) {
GWT.log("loading folder data"); GWT.log("loading folder data");
@ -184,6 +192,11 @@ public class WorkspaceExplorer {
}); });
} }
/**
* Update explorer.
*
* @param items the items
*/
private void updateExplorer(ArrayList<Item> items){ private void updateExplorer(ArrayList<Item> items){
GWT.log("workspace explorer updating.."); GWT.log("workspace explorer updating..");
explorerPanel.clear(); explorerPanel.clear();
@ -194,13 +207,60 @@ public class WorkspaceExplorer {
} }
/** /**
* Gets the panel.
*
* @return the explorerPanel * @return the explorerPanel
*/ */
public ScrollPanel getPanel() { public ScrollPanel getPanel() {
return explorerPanel; return explorerPanel;
} }
/**
* Gets the item selected.
*
* @return the item selected
*/
public Item getItemSelected(){ public Item getItemSelected(){
return itTables.getSelectedItem();
Item item = itTables.getSelectedItem();
if (item!=null){
boolean selectable = selectableTypes.contains(item.getType());
return (selectable)?item:null;
}
return null;
}
/**
* @return the selectableTypes
*/
@Override
public List<ItemType> getSelectableTypes() {
return selectableTypes;
}
/**
* @param selectableTypes the selectableTypes to set
*/
@Override
public void setSelectableTypes(ItemType ... selectableTypes) {
this.selectableTypes.clear();
if (selectableTypes!=null) for (ItemType type:selectableTypes) this.selectableTypes.add(type);
}
/**
* @return the showableTypes
*/
@Override
public List<ItemType> getShowableTypes() {
return showableTypes;
}
/**
* @param showableTypes the showableTypes to set
*/
@Override
public void setShowableTypes(ItemType ... showableTypes) {
this.showableTypes.clear();
if (showableTypes!=null) for (ItemType type:showableTypes) this.showableTypes.add(type);
} }
} }

View File

@ -1,10 +1,10 @@
package org.gcube.portlets.widgets.wsexplorer.client.grid; package org.gcube.portlets.widgets.wsexplorer.client.view.grid;
import java.util.List; import java.util.List;
import org.gcube.portlets.widgets.wsexplorer.client.WorkspaceExplorerController; import org.gcube.portlets.widgets.wsexplorer.client.WorkspaceExplorerController;
import org.gcube.portlets.widgets.wsexplorer.client.notification.SelectionItem;
import org.gcube.portlets.widgets.wsexplorer.client.resources.CellTableResources; import org.gcube.portlets.widgets.wsexplorer.client.resources.CellTableResources;
import org.gcube.portlets.widgets.wsexplorer.client.view.SelectionItem;
import org.gcube.portlets.widgets.wsexplorer.shared.Item; import org.gcube.portlets.widgets.wsexplorer.shared.Item;
import com.github.gwtbootstrap.client.ui.CellTable; import com.github.gwtbootstrap.client.ui.CellTable;

View File

@ -1,7 +1,7 @@
/** /**
* *
*/ */
package org.gcube.portlets.widgets.wsexplorer.client.grid; package org.gcube.portlets.widgets.wsexplorer.client.view.grid;
import java.util.Comparator; import java.util.Comparator;
import java.util.HashSet; import java.util.HashSet;