2099: Workspace Explorer enhancements: create a new folder
Task-Url: https://support.d4science.org/issues/2099 Added form to create New Folder git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/widgets/workspace-explorer@122701 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
7edd7191ff
commit
5b2c2d1a88
|
@ -21,6 +21,7 @@ import org.gcube.portlets.widgets.wsexplorer.client.event.RootLoadedEvent;
|
||||||
import org.gcube.portlets.widgets.wsexplorer.client.event.RootLoadedEventHandler;
|
import org.gcube.portlets.widgets.wsexplorer.client.event.RootLoadedEventHandler;
|
||||||
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.Breadcrumbs;
|
import org.gcube.portlets.widgets.wsexplorer.client.view.Breadcrumbs;
|
||||||
|
import org.gcube.portlets.widgets.wsexplorer.client.view.CreateFolderForm;
|
||||||
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.FilterCriteria;
|
import org.gcube.portlets.widgets.wsexplorer.shared.FilterCriteria;
|
||||||
|
@ -35,6 +36,7 @@ import com.google.gwt.dom.client.Style.Unit;
|
||||||
import com.google.gwt.dom.client.Style.VerticalAlign;
|
import com.google.gwt.dom.client.Style.VerticalAlign;
|
||||||
import com.google.gwt.event.shared.EventHandler;
|
import com.google.gwt.event.shared.EventHandler;
|
||||||
import com.google.gwt.event.shared.HandlerManager;
|
import com.google.gwt.event.shared.HandlerManager;
|
||||||
|
import com.google.gwt.user.client.Window;
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
import com.google.gwt.user.client.ui.HorizontalPanel;
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
import com.google.gwt.user.client.ui.Image;
|
import com.google.gwt.user.client.ui.Image;
|
||||||
|
@ -187,7 +189,40 @@ public class WorkspaceExplorerController implements EventHandler {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(CreateFolderClickEvent createFolderClickEvent) {
|
public void onClick(CreateFolderClickEvent createFolderClickEvent) {
|
||||||
|
|
||||||
// TODO Auto-generated method stub
|
CreateFolderForm createFolder = new CreateFolderForm() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void subtmitHandler(String folderName) {
|
||||||
|
|
||||||
|
WorkspaceExplorerConstants.workspaceNavigatorService.createFolder(folderName, "", breadcrumbs.getLastParent().getId(), new AsyncCallback<Item>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onFailure(Throwable caught) {
|
||||||
|
Window.alert(caught.getMessage());
|
||||||
|
GWT.log(caught.getMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onSuccess(Item result) {
|
||||||
|
|
||||||
|
if(result!=null){
|
||||||
|
wsExplorer.addItemToExplorer(result);
|
||||||
|
clearMoreInfo();
|
||||||
|
}else
|
||||||
|
Window.alert("Create folder error, Try again");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void closeHandler() {
|
||||||
|
workspaceExplorerPanel.getSouthPanel().remove(this);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
workspaceExplorerPanel.getSouthPanel().add(createFolder);
|
||||||
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -147,7 +147,6 @@ public interface WorkspaceExplorerService extends RemoteService {
|
||||||
* @throws Exception
|
* @throws Exception
|
||||||
*/
|
*/
|
||||||
Item createFolder(
|
Item createFolder(
|
||||||
String nameFolder, String description, String parentId,
|
String nameFolder, String description, String parentId)
|
||||||
List<ItemType> showableTypes, FilterCriteria filterCriteria)
|
|
||||||
throws Exception;
|
throws Exception;
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,7 +142,6 @@ public interface WorkspaceExplorerServiceAsync {
|
||||||
|
|
||||||
void createFolder(
|
void createFolder(
|
||||||
String nameFolder, String description, String parentId,
|
String nameFolder, String description, String parentId,
|
||||||
List<ItemType> showableTypes, FilterCriteria filterCriteria,
|
|
||||||
AsyncCallback<Item> callback);
|
AsyncCallback<Item> callback);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,212 @@
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
package org.gcube.portlets.widgets.wsexplorer.client.view;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Alert;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.ControlGroup;
|
||||||
|
import com.github.gwtbootstrap.client.ui.FluidRow;
|
||||||
|
import com.github.gwtbootstrap.client.ui.Form;
|
||||||
|
import com.github.gwtbootstrap.client.ui.TextBox;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
|
import com.github.gwtbootstrap.client.ui.constants.ControlGroupType;
|
||||||
|
import com.google.gwt.core.client.GWT;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.uibinder.client.UiBinder;
|
||||||
|
import com.google.gwt.uibinder.client.UiField;
|
||||||
|
import com.google.gwt.user.client.ui.Composite;
|
||||||
|
import com.google.gwt.user.client.ui.HasHorizontalAlignment;
|
||||||
|
import com.google.gwt.user.client.ui.HorizontalPanel;
|
||||||
|
import com.google.gwt.user.client.ui.Widget;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class CreateFolderForm.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
||||||
|
* Feb 1, 2016
|
||||||
|
*/
|
||||||
|
public abstract class CreateFolderForm extends Composite {
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
TextBox input_folder_name;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
Button close_dialog;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
Button submit_create_folder;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
FluidRow validator_field;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
Form form_create_folder;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
ControlGroup input_folder_name_group;
|
||||||
|
|
||||||
|
@UiField
|
||||||
|
HorizontalPanel hp_form_actions;
|
||||||
|
|
||||||
|
private Alert alertError = new Alert("Required Field");
|
||||||
|
|
||||||
|
private Alert alertSubmitResult = new Alert("");
|
||||||
|
|
||||||
|
private static AbstractFormReleaseUiBinder uiBinder = GWT.create(AbstractFormReleaseUiBinder.class);
|
||||||
|
|
||||||
|
private int width = 300;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Subtmit handler.
|
||||||
|
*
|
||||||
|
* @param folderName the folder name
|
||||||
|
*/
|
||||||
|
public abstract void subtmitHandler(String folderName);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Close handler.
|
||||||
|
*/
|
||||||
|
public abstract void closeHandler();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Interface AbstractFormReleaseUiBinder.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
||||||
|
* Feb 19, 2015
|
||||||
|
*/
|
||||||
|
interface AbstractFormReleaseUiBinder extends UiBinder<Widget, CreateFolderForm> {
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instantiates a new abstract form release.
|
||||||
|
*/
|
||||||
|
public CreateFolderForm() {
|
||||||
|
initWidget(uiBinder.createAndBindUi(this));
|
||||||
|
// setSize(width+"px", "200px");
|
||||||
|
// input_folder_name.setWidth(width-10+"px");
|
||||||
|
|
||||||
|
// input_layer_name.addStyleName("textbox-geo");
|
||||||
|
// input_layer_title.addStyleName("textbox-geo");
|
||||||
|
// input_WMS_URI.addStyleName("textbox-geo");
|
||||||
|
|
||||||
|
close_dialog.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
closeHandler();
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
submit_create_folder.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
|
||||||
|
if(validateForm()){
|
||||||
|
subtmitHandler(input_folder_name.getValue());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
alertError.addStyleName("marginTop10");
|
||||||
|
alertError.setType(AlertType.ERROR);
|
||||||
|
alertError.setVisible(false);
|
||||||
|
alertError.setClose(false);
|
||||||
|
validator_field.add(alertError);
|
||||||
|
|
||||||
|
// alertSubmitResult.addStyleName("marginTop10");
|
||||||
|
alertSubmitResult.setType(AlertType.INFO);
|
||||||
|
alertSubmitResult.setVisible(false);
|
||||||
|
alertSubmitResult.setClose(false);
|
||||||
|
|
||||||
|
hp_form_actions.setCellHorizontalAlignment(close_dialog, HasHorizontalAlignment.ALIGN_RIGHT);
|
||||||
|
|
||||||
|
showAlertSubmitResult(false, "");
|
||||||
|
form_create_folder.add(alertSubmitResult);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Validate form.
|
||||||
|
*
|
||||||
|
* @return true, if successful
|
||||||
|
*/
|
||||||
|
public boolean validateForm(){
|
||||||
|
|
||||||
|
boolean valid = true;
|
||||||
|
// input_layer_name.setType(ControlGroupType.NONE);
|
||||||
|
input_folder_name_group.setType(ControlGroupType.NONE);
|
||||||
|
|
||||||
|
if(input_folder_name.getValue()==null || input_folder_name.getValue().isEmpty()){
|
||||||
|
input_folder_name.setControlGroup(input_folder_name_group);
|
||||||
|
input_folder_name_group.setType(ControlGroupType.ERROR);
|
||||||
|
|
||||||
|
valid = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// alertError.setVisible(!valid);
|
||||||
|
setAlertErrorVisible(!valid);
|
||||||
|
return valid;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Show alert submit result.
|
||||||
|
*
|
||||||
|
* @param visible the visible
|
||||||
|
* @param text the text
|
||||||
|
*/
|
||||||
|
public void showAlertSubmitResult(boolean visible, String text){
|
||||||
|
alertSubmitResult.setText(text);
|
||||||
|
alertSubmitResult.setVisible(visible);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the submit_button.
|
||||||
|
*
|
||||||
|
* @return the submit_button
|
||||||
|
*/
|
||||||
|
public Button getSubmit_button() {
|
||||||
|
return submit_create_folder;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the validator_field.
|
||||||
|
*
|
||||||
|
* @return the validator_field
|
||||||
|
*/
|
||||||
|
public FluidRow getValidator_field() {
|
||||||
|
return validator_field;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the alert error.
|
||||||
|
*
|
||||||
|
* @return the alert error
|
||||||
|
*/
|
||||||
|
public Alert getAlertError() {
|
||||||
|
return alertError;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the alert submit result.
|
||||||
|
*
|
||||||
|
* @return the alert submit result
|
||||||
|
*/
|
||||||
|
public Alert getAlertSubmitResult() {
|
||||||
|
return alertSubmitResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the alert error visible.
|
||||||
|
*
|
||||||
|
* @param bool the new alert error visible
|
||||||
|
*/
|
||||||
|
public void setAlertErrorVisible(boolean bool){
|
||||||
|
alertError.setVisible(bool);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,23 @@
|
||||||
|
<!DOCTYPE ui:UiBinder SYSTEM "http://dl.google.com/gwt/DTD/xhtml.ent">
|
||||||
|
<ui:UiBinder xmlns:ui="urn:ui:com.google.gwt.uibinder"
|
||||||
|
xmlns:g="urn:import:com.google.gwt.user.client.ui" xmlns:b="urn:import:com.github.gwtbootstrap.client.ui">
|
||||||
|
|
||||||
|
<b:WellForm type="INLINE" ui:field="form_create_folder">
|
||||||
|
<b:Fieldset styleName="noBorder">
|
||||||
|
<b:ControlGroup ui:field="input_folder_name_group">
|
||||||
|
<b:ControlLabel for="input_folder_name">New Folder</b:ControlLabel>
|
||||||
|
<b:Controls>
|
||||||
|
<b:TextBox placeholder="Type Folder name..." b:id="input_folder_name"
|
||||||
|
ui:field="input_folder_name"></b:TextBox>
|
||||||
|
</b:Controls>
|
||||||
|
</b:ControlGroup>
|
||||||
|
<b:FluidRow ui:field="validator_field"></b:FluidRow>
|
||||||
|
<g:HorizontalPanel ui:field="hp_form_actions">
|
||||||
|
<b:FormActions>
|
||||||
|
<b:Button ui:field="submit_create_folder">Create</b:Button>
|
||||||
|
</b:FormActions>
|
||||||
|
<b:Button ui:field="close_dialog">Close</b:Button>
|
||||||
|
</g:HorizontalPanel>
|
||||||
|
</b:Fieldset>
|
||||||
|
</b:WellForm>
|
||||||
|
</ui:UiBinder>
|
|
@ -118,7 +118,6 @@ public class Navigation extends Composite{
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
new_folder.setActive(true);
|
new_folder.setActive(true);
|
||||||
new_folder.setBaseIcon(WorkspaceExplorerResources.CustomIconType.new_folder);
|
new_folder.setBaseIcon(WorkspaceExplorerResources.CustomIconType.new_folder);
|
||||||
new_folder.addClickHandler(new ClickHandler() {
|
new_folder.addClickHandler(new ClickHandler() {
|
||||||
|
|
|
@ -8,5 +8,8 @@
|
||||||
</b:NavWidget>
|
</b:NavWidget>
|
||||||
<b:NavWidget ui:field="new_folder" text="New Folder">
|
<b:NavWidget ui:field="new_folder" text="New Folder">
|
||||||
</b:NavWidget>
|
</b:NavWidget>
|
||||||
|
<!-- <g:VerticalPanel> -->
|
||||||
|
<!-- <b:TextBox placeholder="type folder name" styleName="size"></b:TextBox> -->
|
||||||
|
<!-- </g:VerticalPanel> -->
|
||||||
</g:FlowPanel>
|
</g:FlowPanel>
|
||||||
</ui:UiBinder>
|
</ui:UiBinder>
|
|
@ -1,6 +1,7 @@
|
||||||
package org.gcube.portlets.widgets.wsexplorer.client.view;
|
package org.gcube.portlets.widgets.wsexplorer.client.view;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.widgets.wsexplorer.client.Util;
|
import org.gcube.portlets.widgets.wsexplorer.client.Util;
|
||||||
|
@ -33,11 +34,11 @@ import com.google.gwt.user.client.ui.ScrollPanel;
|
||||||
* Aug 4, 2015
|
* Aug 4, 2015
|
||||||
*/
|
*/
|
||||||
public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
|
|
||||||
|
|
||||||
protected static final HorizontalPanel LOADING_PANEL = new HorizontalPanel();
|
protected static final HorizontalPanel LOADING_PANEL = new HorizontalPanel();
|
||||||
protected static final Image LOADING_IMAGE = WorkspaceExplorerResources.getIconLoading().createImage();
|
protected static final Image LOADING_IMAGE = WorkspaceExplorerResources.getIconLoading().createImage();
|
||||||
|
|
||||||
static {
|
static {
|
||||||
LOADING_PANEL.getElement().getStyle().setMargin(5.0, Unit.PX);
|
LOADING_PANEL.getElement().getStyle().setMargin(5.0, Unit.PX);
|
||||||
// LOADING_PANEL.setSpacing(3);
|
// LOADING_PANEL.setSpacing(3);
|
||||||
|
@ -46,7 +47,7 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
loading.getElement().getStyle().setPaddingLeft(5.0, Unit.PX);
|
loading.getElement().getStyle().setPaddingLeft(5.0, Unit.PX);
|
||||||
LOADING_PANEL.add(loading);
|
LOADING_PANEL.add(loading);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Alert alert = new Alert();
|
protected Alert alert = new Alert();
|
||||||
protected List<ItemType> selectableTypes = new ArrayList<ItemType>();
|
protected List<ItemType> selectableTypes = new ArrayList<ItemType>();
|
||||||
protected List<ItemType> showableTypes = new ArrayList<ItemType>();
|
protected List<ItemType> showableTypes = new ArrayList<ItemType>();
|
||||||
|
@ -128,9 +129,9 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean purgeEmpyFolders = !showEmptyFolders;
|
boolean purgeEmpyFolders = !showEmptyFolders;
|
||||||
|
|
||||||
GWT.log("loading workspace tree from server");
|
GWT.log("loading workspace tree from server");
|
||||||
|
|
||||||
WorkspaceExplorerConstants.workspaceNavigatorService.getRoot(showableTypesParam, purgeEmpyFolders, filterCriteria, new AsyncCallback<Item>() {
|
WorkspaceExplorerConstants.workspaceNavigatorService.getRoot(showableTypesParam, purgeEmpyFolders, filterCriteria, new AsyncCallback<Item>() {
|
||||||
|
|
||||||
public void onFailure(Throwable caught) {
|
public void onFailure(Throwable caught) {
|
||||||
|
@ -146,7 +147,7 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load folder.
|
* Load folder.
|
||||||
*
|
*
|
||||||
|
@ -156,13 +157,13 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
public void loadFolder(final Item item) throws Exception {
|
public void loadFolder(final Item item) throws Exception {
|
||||||
GWT.log("loading folder data");
|
GWT.log("loading folder data");
|
||||||
setLoading();
|
setLoading();
|
||||||
|
|
||||||
if(!item.isFolder())
|
if(!item.isFolder())
|
||||||
throw new Exception("Item is not a folder");
|
throw new Exception("Item is not a folder");
|
||||||
|
|
||||||
if(item.getId()==null || item.getId().isEmpty())
|
if(item.getId()==null || item.getId().isEmpty())
|
||||||
throw new Exception("Item id is null or empty");
|
throw new Exception("Item id is null or empty");
|
||||||
|
|
||||||
// we make a copy of showable types
|
// we make a copy of showable types
|
||||||
List<ItemType> showableTypesParam = new ArrayList<ItemType>(showableTypes);
|
List<ItemType> showableTypesParam = new ArrayList<ItemType>(showableTypes);
|
||||||
|
|
||||||
|
@ -189,19 +190,19 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
public void onSuccess(Item result) {
|
public void onSuccess(Item result) {
|
||||||
if(item.getName()==null || item.getName().isEmpty())
|
if(item.getName()==null || item.getName().isEmpty())
|
||||||
item.setName(result.getName());
|
item.setName(result.getName());
|
||||||
|
|
||||||
updateExplorer(result.getChildren());
|
updateExplorer(result.getChildren());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Load the Workspace Tree.
|
* Load the Workspace Tree.
|
||||||
*/
|
*/
|
||||||
public void loadMySpecialFolder() {
|
public void loadMySpecialFolder() {
|
||||||
GWT.log("loading folder data");
|
GWT.log("loading folder data");
|
||||||
setLoading();
|
setLoading();
|
||||||
|
|
||||||
|
|
||||||
// we make a copy of showable types
|
// we make a copy of showable types
|
||||||
List<ItemType> showableTypesParam = new ArrayList<ItemType>(showableTypes);
|
List<ItemType> showableTypesParam = new ArrayList<ItemType>(showableTypes);
|
||||||
|
@ -231,7 +232,7 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Update explorer.
|
* Update explorer.
|
||||||
*
|
*
|
||||||
|
@ -245,7 +246,21 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
explorerPanel.add(itTables.getCellTable());
|
explorerPanel.add(itTables.getCellTable());
|
||||||
GWT.log("workspace explorer updated");
|
GWT.log("workspace explorer updated");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the item to explorer.
|
||||||
|
*
|
||||||
|
* @param items the items
|
||||||
|
*/
|
||||||
|
public void addItemToExplorer(Item item){
|
||||||
|
GWT.log("workspace explorer add item.."+item);
|
||||||
|
// itTables = new ItemsTable(true, displayFields);
|
||||||
|
itTables.addItems(Arrays.asList(item));
|
||||||
|
explorerPanel.add(itTables.getCellTable());
|
||||||
|
GWT.log("workspace explorer updated");
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the panel.
|
* Gets the panel.
|
||||||
*
|
*
|
||||||
|
@ -254,8 +269,8 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
public ScrollPanel getPanel() {
|
public ScrollPanel getPanel() {
|
||||||
return explorerPanel;
|
return explorerPanel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the display fields.
|
* Gets the display fields.
|
||||||
*
|
*
|
||||||
|
@ -285,8 +300,8 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
public ItemsTable getItTables() {
|
public ItemsTable getItTables() {
|
||||||
return itTables;
|
return itTables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the item selected.
|
* Gets the item selected.
|
||||||
*
|
*
|
||||||
|
@ -295,9 +310,9 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
public Item getItemSelected(){
|
public Item getItemSelected(){
|
||||||
return itTables.getSelectedItem();
|
return itTables.getSelectedItem();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*public boolean itemIsSelectable(){
|
/*public boolean itemIsSelectable(){
|
||||||
|
|
||||||
Item item = itTables.getSelectedItem();
|
Item item = itTables.getSelectedItem();
|
||||||
if (item!=null){
|
if (item!=null){
|
||||||
boolean selectable = selectableTypes.contains(item.getType());
|
boolean selectable = selectableTypes.contains(item.getType());
|
||||||
|
@ -305,7 +320,7 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}*/
|
}*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the selectable types.
|
* Gets the selectable types.
|
||||||
*
|
*
|
||||||
|
@ -326,7 +341,7 @@ public class WorkspaceExplorer implements ShowableTypes, SelectableTypes{
|
||||||
this.selectableTypes.clear();
|
this.selectableTypes.clear();
|
||||||
if (selectableTypes!=null) for (ItemType type:selectableTypes) this.selectableTypes.add(type);
|
if (selectableTypes!=null) for (ItemType type:selectableTypes) this.selectableTypes.add(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the showable types.
|
* Gets the showable types.
|
||||||
*
|
*
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
package org.gcube.portlets.widgets.wsexplorer.client.view.grid;
|
package org.gcube.portlets.widgets.wsexplorer.client.view.grid;
|
||||||
|
|
||||||
|
@ -37,17 +37,27 @@ import com.google.gwt.user.client.ui.Label;
|
||||||
* Feb 19, 2015
|
* Feb 19, 2015
|
||||||
*/
|
*/
|
||||||
public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
|
|
||||||
private Column<Item, ImageResource> icon;
|
private Column<Item, ImageResource> icon;
|
||||||
private TextColumn<Item> name;
|
private TextColumn<Item> name;
|
||||||
private TextColumn<Item> owner;
|
private TextColumn<Item> owner;
|
||||||
private Item selectedItem = null;
|
private Item selectedItem = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Enum DISPLAY_FIELD.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
||||||
|
* Feb 1, 2016
|
||||||
|
*/
|
||||||
public static enum DISPLAY_FIELD{ICON, NAME, OWNER};
|
public static enum DISPLAY_FIELD{ICON, NAME, OWNER};
|
||||||
private List<DISPLAY_FIELD> displayFields;
|
private List<DISPLAY_FIELD> displayFields;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instantiates a new items table.
|
* Instantiates a new items table.
|
||||||
* @param eventBus
|
*
|
||||||
|
* @param eventBus the event bus
|
||||||
|
* @param showMoreInfo the show more info
|
||||||
|
* @param fields the fields
|
||||||
*/
|
*/
|
||||||
public ItemsTable(HandlerManager eventBus, boolean showMoreInfo, DISPLAY_FIELD[] fields) {
|
public ItemsTable(HandlerManager eventBus, boolean showMoreInfo, DISPLAY_FIELD[] fields) {
|
||||||
super(eventBus, showMoreInfo);
|
super(eventBus, showMoreInfo);
|
||||||
|
@ -55,8 +65,9 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
initTable(cellTable, null, null);
|
initTable(cellTable, null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* (non-Javadoc)
|
/* (non-Javadoc)
|
||||||
* @see org.gcube.portlets.admin.gcubereleases.client.view.AbstractPackageTable#addPackages(java.util.List)
|
* @see org.gcube.portlets.widgets.wsexplorer.client.view.grid.AbstractItemsCellTable#addItems(java.util.List)
|
||||||
*/
|
*/
|
||||||
public void addItems(List<Item> packages) {
|
public void addItems(List<Item> packages) {
|
||||||
dataProvider.getList().clear();
|
dataProvider.getList().clear();
|
||||||
|
@ -68,8 +79,9 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
cellTable.redraw();
|
cellTable.redraw();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds the package.
|
* Adds the item.
|
||||||
*
|
*
|
||||||
* @param pckg the pckg
|
* @param pckg the pckg
|
||||||
*/
|
*/
|
||||||
|
@ -107,14 +119,14 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
@Override
|
@Override
|
||||||
public void render(Context context, Item object, SafeHtmlBuilder sb) {
|
public void render(Context context, Item object, SafeHtmlBuilder sb) {
|
||||||
super.render(context, object, sb);
|
super.render(context, object, sb);
|
||||||
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
icon.setSortable(false);
|
icon.setSortable(false);
|
||||||
packageTable.addColumn(icon, "");
|
packageTable.addColumn(icon, "");
|
||||||
packageTable.setColumnWidth(icon, 10.0, Unit.PCT);
|
packageTable.setColumnWidth(icon, 10.0, Unit.PCT);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.displayFields.contains(DISPLAY_FIELD.NAME)){
|
if(this.displayFields.contains(DISPLAY_FIELD.NAME)){
|
||||||
//ARTIFACT ID
|
//ARTIFACT ID
|
||||||
name = new TextColumn<Item>() {
|
name = new TextColumn<Item>() {
|
||||||
|
@ -126,10 +138,10 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
name.setSortable(true);
|
name.setSortable(true);
|
||||||
|
|
||||||
packageTable.addColumn(name, "Name");
|
packageTable.addColumn(name, "Name");
|
||||||
|
|
||||||
double width = displayFields.size()>1?50:90;
|
double width = displayFields.size()>1?50:90;
|
||||||
packageTable.setColumnWidth(name, width, Unit.PCT);
|
packageTable.setColumnWidth(name, width, Unit.PCT);
|
||||||
|
|
||||||
ListHandler<Item> nameColumnHandler = new ListHandler<Item>(dataProvider.getList());
|
ListHandler<Item> nameColumnHandler = new ListHandler<Item>(dataProvider.getList());
|
||||||
nameColumnHandler.setComparator(name, new Comparator<Item>() {
|
nameColumnHandler.setComparator(name, new Comparator<Item>() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -137,25 +149,25 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
return o1.getName().compareTo(o2.getName());
|
return o1.getName().compareTo(o2.getName());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
packageTable.addColumnSortHandler(nameColumnHandler);
|
packageTable.addColumnSortHandler(nameColumnHandler);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(this.displayFields.contains(DISPLAY_FIELD.OWNER)){
|
if(this.displayFields.contains(DISPLAY_FIELD.OWNER)){
|
||||||
|
|
||||||
owner = new TextColumn<Item>() {
|
owner = new TextColumn<Item>() {
|
||||||
@Override
|
@Override
|
||||||
public String getValue(Item object) {
|
public String getValue(Item object) {
|
||||||
return object.getOwner() != null ? object.getOwner() : "";
|
return object.getOwner() != null ? object.getOwner() : "";
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
owner.setSortable(true);
|
owner.setSortable(true);
|
||||||
packageTable.addColumn(owner, "Owner");
|
packageTable.addColumn(owner, "Owner");
|
||||||
double width = (displayFields.size()==2) ?90:40;
|
double width = displayFields.size()==2 ?90:40;
|
||||||
packageTable.setColumnWidth(owner, width, Unit.PCT);
|
packageTable.setColumnWidth(owner, width, Unit.PCT);
|
||||||
|
|
||||||
ListHandler<Item> ownerColumnHandler = new ListHandler<Item>(dataProvider.getList());
|
ListHandler<Item> ownerColumnHandler = new ListHandler<Item>(dataProvider.getList());
|
||||||
ownerColumnHandler.setComparator(owner, new Comparator<Item>() {
|
ownerColumnHandler.setComparator(owner, new Comparator<Item>() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -164,9 +176,9 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
packageTable.addColumnSortHandler(ownerColumnHandler);
|
packageTable.addColumnSortHandler(ownerColumnHandler);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*final SingleSelectionModel<Item> selectionModel = new SingleSelectionModel<Item>();
|
/*final SingleSelectionModel<Item> selectionModel = new SingleSelectionModel<Item>();
|
||||||
selectionModel.addSelectionChangeHandler(new Handler() {
|
selectionModel.addSelectionChangeHandler(new Handler() {
|
||||||
@Override
|
@Override
|
||||||
|
@ -174,25 +186,38 @@ public class ItemsTable extends AbstractItemsCellTable implements SelectionItem{
|
||||||
}
|
}
|
||||||
});*/
|
});*/
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param displayFields the dispalyFields to set
|
* Sets the display fields.
|
||||||
|
*
|
||||||
|
* @param fields the new display fields
|
||||||
*/
|
*/
|
||||||
public void setDisplayFields(DISPLAY_FIELD[] fields) {
|
public void setDisplayFields(DISPLAY_FIELD[] fields) {
|
||||||
this.displayFields = (fields!=null && fields.length>0)?Arrays.asList(fields):Arrays.asList(DISPLAY_FIELD.values());
|
this.displayFields = fields!=null && fields.length>0?Arrays.asList(fields):Arrays.asList(DISPLAY_FIELD.values());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Gets the display fields.
|
||||||
|
*
|
||||||
* @return the displayFields
|
* @return the displayFields
|
||||||
*/
|
*/
|
||||||
public List<DISPLAY_FIELD> getDisplayFields() {
|
public List<DISPLAY_FIELD> getDisplayFields() {
|
||||||
return displayFields;
|
return displayFields;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The Class ButtonImageCell.
|
||||||
|
*
|
||||||
|
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
|
||||||
|
* Feb 1, 2016
|
||||||
|
*/
|
||||||
public class ButtonImageCell extends ButtonCell{
|
public class ButtonImageCell extends ButtonCell{
|
||||||
|
|
||||||
@Override
|
/* (non-Javadoc)
|
||||||
public void render(com.google.gwt.cell.client.Cell.Context context,
|
* @see com.google.gwt.cell.client.AbstractSafeHtmlCell#render(com.google.gwt.cell.client.Cell.Context, java.lang.Object, com.google.gwt.safehtml.shared.SafeHtmlBuilder)
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void render(com.google.gwt.cell.client.Cell.Context context,
|
||||||
String value, SafeHtmlBuilder sb) {
|
String value, SafeHtmlBuilder sb) {
|
||||||
SafeHtml html = SafeHtmlUtils.fromTrustedString(new Image(value).toString());
|
SafeHtml html = SafeHtmlUtils.fromTrustedString(new Image(value).toString());
|
||||||
sb.append(html);
|
sb.append(html);
|
||||||
|
|
|
@ -600,7 +600,7 @@ public class WorkspaceExplorerServiceImpl extends RemoteServiceServlet implement
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Item createFolder(String nameFolder, String description, String parentId, List<ItemType> showableTypes,FilterCriteria filterCriteria) throws Exception {
|
public Item createFolder(String nameFolder, String description, String parentId) throws Exception {
|
||||||
|
|
||||||
_log.trace("creating folder: "+nameFolder +" parent is null?"+parentId);
|
_log.trace("creating folder: "+nameFolder +" parent is null?"+parentId);
|
||||||
|
|
||||||
|
@ -615,10 +615,11 @@ public class WorkspaceExplorerServiceImpl extends RemoteServiceServlet implement
|
||||||
Workspace workspace = getWorkspace();
|
Workspace workspace = getWorkspace();
|
||||||
WorkspaceFolder wsFolder = workspace.createFolder(nameFolder, description, parentId);
|
WorkspaceFolder wsFolder = workspace.createFolder(nameFolder, description, parentId);
|
||||||
Item itemFolder = null;
|
Item itemFolder = null;
|
||||||
if(wsFolder!=null){
|
List<ItemType> allTypes = Arrays.asList(ItemType.values());
|
||||||
itemFolder = ItemBuilder.getItem(null, wsFolder, showableTypes, filterCriteria, false);
|
Item parent = ItemBuilder.getItem(null, wsFolder.getParent(), allTypes, null, false);
|
||||||
|
if(parent!=null){
|
||||||
|
itemFolder = ItemBuilder.getItem(parent, wsFolder, allTypes, null, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
return itemFolder;
|
return itemFolder;
|
||||||
|
|
||||||
} catch(InsufficientPrivilegesException e){
|
} catch(InsufficientPrivilegesException e){
|
||||||
|
|
Loading…
Reference in New Issue