in progress on revisiting "Manage Resources"

This commit is contained in:
Francesco Mangiacrapa 2021-03-15 10:15:28 +01:00
parent 9e5f98f1ba
commit 5656ab218b
9 changed files with 114 additions and 57 deletions

View File

@ -13,6 +13,7 @@ This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.htm
[#20680] Ported to SHUB [#20680] Ported to SHUB
[#19568] Unify and extend the tags allowed values [#19568] Unify and extend the tags allowed values
[#20828] Revisited title size and format [#20828] Revisited title size and format
[#20868] Redesigned the "Manage Resources" user experience
## [v1.6.2] - 2021-02-08 ## [v1.6.2] - 2021-02-08

View File

@ -70,8 +70,8 @@ public class InfoIconsLabels {
// RESOURCES // RESOURCES
public static final String RESOURCES_INFO_ID_POPUP = "resouces-popup-panel-info"; public static final String RESOURCES_INFO_ID_POPUP = "resouces-popup-panel-info";
public static final String RESOURCES_INFO_CAPTION = "Manage resource items"; public static final String RESOURCES_INFO_CAPTION = "Manage resource items";
public static final String RESOURCES_INFO_TEXT = "Select the files you want to attach to the publishing item. Click on 'Trash' to remote it. Click on 'Edit' for changing resource's name or description." public static final String RESOURCES_INFO_TEXT = "Select the files you want to attach to the publishing item. Click on 'Pencil' for changing resource's name or description. Click on 'Trash' to remove the resource."
+ " You can add others files by using the 'Add files from...' facility. To navigate a folder perform a 'double click' on it. Please consider that any complex hierarchy structure you may have will be flatten."; + " You can add others files by using the 'Add files from...' facility: (i) to navigate a folder perform a 'double click' on it; (ii) to choose a file select it and press 'Select'. Please consider that any complex hierarchy structure you may have will be flatten.";
// CUSTOM FIELDS // CUSTOM FIELDS
public static final String CUSTOM_FIELDS_INFO_ID_POPUP = "custom-fields-popup-panel-info"; public static final String CUSTOM_FIELDS_INFO_ID_POPUP = "custom-fields-popup-panel-info";

View File

@ -75,6 +75,7 @@ public class ResourceInfoForm extends Composite{
if(newName == null || newName.isEmpty()){ if(newName == null || newName.isEmpty()){
showError(controlName); showError(controlName);
}else{ }else{
resourceBean.setName(newName);
resourceBean.setEditableName(newName); resourceBean.setEditableName(newName);
clearPanel(); clearPanel();
} }

View File

@ -16,7 +16,6 @@
border-radius: 5px; border-radius: 5px;
height: 320px; height: 320px;
width: 700px; width: 700px;
margin-left: 70px;
margin-bottom: 20px; margin-bottom: 20px;
} }
@ -32,9 +31,13 @@
margin-bottom: 0px !important; margin-bottom: 0px !important;
} }
.custom-input input, textarea { .custom-input input {
width: 350px; width: 350px;
} }
.custom-input textarea {
width: 355px;
}
</ui:style> </ui:style>
<g:HTMLPanel addStyleNames="{style.panel-style}"> <g:HTMLPanel addStyleNames="{style.panel-style}">
<b:Form type="HORIZONTAL" width="100%"> <b:Form type="HORIZONTAL" width="100%">
@ -71,7 +74,7 @@
<b>Description:</b> <b>Description:</b>
</b:ControlLabel> </b:ControlLabel>
<b:Controls> <b:Controls>
<b:TextArea placeholder="Resource description" <b:TextArea placeholder="Type here the resource description"
b:id="description" b:id="description"
title="The description the resource will have on the catalogue" title="The description the resource will have on the catalogue"
ui:field="resourceDescription"></b:TextArea> ui:field="resourceDescription"></b:TextArea>

View File

@ -1,6 +1,8 @@
package org.gcube.portlets.widgets.ckandatapublisherwidget.client.ui.workspace; package org.gcube.portlets.widgets.ckandatapublisherwidget.client.ui.workspace;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List;
import java.util.Map; import java.util.Map;
import org.gcube.portlets.widgets.ckandatapublisherwidget.shared.ResourceElementBean; import org.gcube.portlets.widgets.ckandatapublisherwidget.shared.ResourceElementBean;
@ -22,8 +24,8 @@ import com.google.gwt.event.shared.HandlerManager;
import com.google.gwt.uibinder.client.UiBinder; import com.google.gwt.uibinder.client.UiBinder;
import com.google.gwt.uibinder.client.UiField; import com.google.gwt.uibinder.client.UiField;
import com.google.gwt.user.client.Timer; import com.google.gwt.user.client.Timer;
import com.google.gwt.user.client.Window;
import com.google.gwt.user.client.ui.Composite; import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.HTMLPanel; import com.google.gwt.user.client.ui.HTMLPanel;
import com.google.gwt.user.client.ui.VerticalPanel; import com.google.gwt.user.client.ui.VerticalPanel;
import com.google.gwt.user.client.ui.Widget; import com.google.gwt.user.client.ui.Widget;
@ -41,12 +43,14 @@ public class SelectResourceByWEMainPanel extends Composite {
private static SelectResourceByWEMainPanelUiBinder uiBinder = GWT.create(SelectResourceByWEMainPanelUiBinder.class); private static SelectResourceByWEMainPanelUiBinder uiBinder = GWT.create(SelectResourceByWEMainPanelUiBinder.class);
private static boolean frozen = false; private static boolean frozen = false;
private final ResourceElementBean initialBean; private final ResourceElementBean initialBean;
@UiField @UiField
VerticalPanel wsContainer; VerticalPanel wsContainer;
@UiField @UiField
VerticalPanel selectResourcesContainer; FlowPanel selectResourcesContainer;
@UiField @UiField
Alert showAlert; Alert showAlert;
@ -63,14 +67,11 @@ public class SelectResourceByWEMainPanel extends Composite {
@UiField @UiField
Label labelNothing; Label labelNothing;
@UiField
HTMLPanel editPanel;
private Item selectedWEItem; private Item selectedWEItem;
public final static HandlerManager eventBus = new HandlerManager(null); public final static HandlerManager eventBus = new HandlerManager(null);
Map<String, SelectedResourceWidget> mapSelectedResources = new HashMap<String, SelectedResourceWidget>(); private Map<String, SelectedResourceWidget> mapSelectedResources = new HashMap<String, SelectedResourceWidget>();
/** /**
* The Interface SelectResourceByWEMainPanelUiBinder. * The Interface SelectResourceByWEMainPanelUiBinder.
@ -147,9 +148,9 @@ public class SelectResourceByWEMainPanel extends Composite {
containerPickResources.setVisible(false); containerPickResources.setVisible(false);
} }
if(rootName!=null) { // if(rootName!=null) {
buttPickResources.setHeading("Add files from "+rootName); // buttPickResources.setHeading("Add files from "+rootName);
} // }
} catch (Exception e) { } catch (Exception e) {
@ -157,7 +158,7 @@ public class SelectResourceByWEMainPanel extends Composite {
} }
if(!initialBean.isFolder()) { if(!initialBean.isFolder()) {
addSelectResource(initialBean.getOriginalIdInWorkspace(), initialBean.getName(),initialBean.getFullPath()); addSelectResource(initialBean.getOriginalIdInWorkspace(), initialBean.getName(),initialBean.getFullPath(), initialBean.isFolder());
} }
addHandlers(); addHandlers();
@ -171,7 +172,7 @@ public class SelectResourceByWEMainPanel extends Composite {
@Override @Override
public void onClick(ClickEvent event) { public void onClick(ClickEvent event) {
if(selectedWEItem!=null && !selectedWEItem.isFolder()) { if(selectedWEItem!=null && !selectedWEItem.isFolder()) {
addSelectResource(selectedWEItem.getId(), selectedWEItem.getName(), selectedWEItem.getPath()); addSelectResource(selectedWEItem.getId(), selectedWEItem.getName(), selectedWEItem.getPath(), selectedWEItem.isFolder());
} }
} }
@ -203,7 +204,7 @@ public class SelectResourceByWEMainPanel extends Composite {
showNothingResourceSelected(); showNothingResourceSelected();
} }
public void addSelectResource(String wsItemId, String name, String path) { public void addSelectResource(String wsItemId, String name, String path, boolean isFolder) {
SelectedResourceWidget selWidg = mapSelectedResources.get(wsItemId); SelectedResourceWidget selWidg = mapSelectedResources.get(wsItemId);
if (selWidg != null) { if (selWidg != null) {
@ -216,6 +217,7 @@ public class SelectResourceByWEMainPanel extends Composite {
rb.setName(name); rb.setName(name);
rb.setFullPath(path); rb.setFullPath(path);
rb.setEditableName(name); rb.setEditableName(name);
rb.setFolder(isFolder);
selWidg = new SelectedResourceWidget(rb); selWidg = new SelectedResourceWidget(rb);
mapSelectedResources.put(wsItemId, selWidg); mapSelectedResources.put(wsItemId, selWidg);
@ -251,32 +253,49 @@ public class SelectResourceByWEMainPanel extends Composite {
} }
} }
public ResourceElementBean getResourcesToPublish() {
// TODO Auto-generated method stub
Window.alert("getResourcesToPublish() must be implemented");
/*List<ResourceElementBean> current = dataProviderRight.getList();
public void freeze() {
GWT.log("called freeze into selected resources");
frozen = true;
selectResourcesContainer.getElement().setAttribute("disabled", "disabled");
containerPickResources.getElement().setAttribute("disabled", "disabled");
//buttPickResources.getElement().getStyle().setProperty("pointer-events","none");
buttSelectResource.setEnabled(false);
}
/**
* Returns the root parent with the children as files to save
* @return the resources to save
*/
public ResourceElementBean getResourcesToPublish(){
ResourceElementBean toReturn = new ResourceElementBean(); ResourceElementBean toReturn = new ResourceElementBean();
List<ResourceElementBean> children = new ArrayList<ResourceElementBean>(); List<ResourceElementBean> children = new ArrayList<ResourceElementBean>();
for (ResourceElementBean resource : current) { for (String wsItemId : mapSelectedResources.keySet()) {
if(resource.isToBeAdded() && !resource.isFolder()){ // be sure ... SelectedResourceWidget selecWC = mapSelectedResources.get(wsItemId);
ResourceElementBean beanWithoutChildren = new ResourceElementBean(resource); ResourceElementBean theResource = selecWC.getResourceBean();
beanWithoutChildren.setName(resource.getEditableName());
children.add(beanWithoutChildren); if(!theResource.isFolder()){ // be sure ...
children.add(theResource);
} }
} }
return toReturn;
toReturn.setToPublish(children);
return toReturn;*/
return null;
} }
public void freeze() {
// TODO Auto-generated method stub /**
Window.alert("freeze() must be implemented"); * @return the freezed
*/
public static boolean isFroozen() {
return frozen;
} }
} }

View File

@ -20,10 +20,6 @@
overflow-y: auto; overflow-y: auto;
} }
.no-border {
border: 0px !important;
}
.margin-top-10 { .margin-top-10 {
margin-top: 10px; margin-top: 10px;
} }
@ -37,18 +33,17 @@
<g:HTMLPanel> <g:HTMLPanel>
<b:PageHeader addStyleNames="{style.custom-header}">Publishing Resources</b:PageHeader> <b:PageHeader addStyleNames="{style.custom-header}">Publishing Resources</b:PageHeader>
<b:Alert ui:field="showAlert" visible="false"></b:Alert> <b:Alert ui:field="showAlert" visible="false"></b:Alert>
<g:VerticalPanel ui:field="selectResourcesContainer" width="100%"> <g:FlowPanel ui:field="selectResourcesContainer"
width="100%">
<b:Label ui:field="labelNothing">Nothing</b:Label> <b:Label ui:field="labelNothing">Nothing</b:Label>
</g:VerticalPanel> </g:FlowPanel>
<g:HTMLPanel ui:field="editPanel">
</g:HTMLPanel>
</g:HTMLPanel> </g:HTMLPanel>
<g:HTMLPanel ui:field="containerPickResources" <g:HTMLPanel ui:field="containerPickResources"
addStyleNames="{style.margin-top-20}"> addStyleNames="{style.margin-top-20}">
<b:AccordionGroup ui:field="buttPickResources" <b:AccordionGroup ui:field="buttPickResources"
heading="Add files from..." defaultOpen="false" heading="Add files from..." defaultOpen="false"
addStyleNames="{style.no-border}"> addStyleNames="accordion-no-border-inner">
<b:FluidRow addStyleNames="{style.max-height-250}"> <b:FluidRow addStyleNames="{style.max-height-250}">
<g:VerticalPanel ui:field="wsContainer"> <g:VerticalPanel ui:field="wsContainer">
</g:VerticalPanel> </g:VerticalPanel>

View File

@ -53,7 +53,10 @@ public class SelectedResourceWidget extends Composite {
/** The field name. */ /** The field name. */
@UiField @UiField
Label fieldName; com.github.gwtbootstrap.client.ui.Label fieldName;
@UiField
Label fieldDescription;
/** The edit panel. */ /** The edit panel. */
@UiField @UiField
@ -69,19 +72,24 @@ public class SelectedResourceWidget extends Composite {
*/ */
public SelectedResourceWidget(ResourceElementBean rb) { public SelectedResourceWidget(ResourceElementBean rb) {
initWidget(uiBinder.createAndBindUi(this)); initWidget(uiBinder.createAndBindUi(this));
this.resourceBean = rb;
this.fieldName.setText(rb.getEditableName());
buttonEdit.setType(ButtonType.LINK); buttonEdit.setType(ButtonType.LINK);
buttonDelete.setType(ButtonType.LINK); buttonDelete.setType(ButtonType.LINK);
this.resourceBean = rb;
updateFields();
addHandlers(); addHandlers();
} }
private void updateFields() {
this.fieldName.setText(resourceBean.getEditableName());
if(resourceBean.getDescription()!=null && !resourceBean.getDescription().isEmpty()) {
this.fieldDescription.setVisible(true);
this.fieldDescription.setText(resourceBean.getDescription());
}else
this.fieldDescription.setVisible(false);
}
/** /**
* Adds the handlers. * Adds the handlers.
*/ */
@ -91,9 +99,15 @@ public class SelectedResourceWidget extends Composite {
@Override @Override
public void onClick(ClickEvent event) { public void onClick(ClickEvent event) {
editPanel.clear();
ResourceInfoForm resourceInformationInfo = new ResourceInfoForm(resourceBean) {
protected void onUnload() {
super.onUnload();
updateFields();
};
};
editPanel.add(resourceInformationInfo);
ResourceInfoForm rif = new ResourceInfoForm(resourceBean);
editPanel.add(rif);
} }
}); });

View File

@ -14,14 +14,34 @@
.selected-resources td { .selected-resources td {
vertical-align: middle !important; vertical-align: middle !important;
} }
.margin-bottom-8 {
margin-bottom: 8px;
}
.descr-text {
font-style: italic;
padding-left: 105px;
font-size: 12px;
}
.icon-my-style {
font-size: 1.2em;
margin-right: 10px;
margin-left: 10px;
vertical-align: middle;
}
</ui:style> </ui:style>
<g:HTMLPanel> <g:HTMLPanel addStyleNames="{style.margin-bottom-8}">
<g:FlowPanel addStyleNames="{style.selected-resources}"> <g:FlowPanel addStyleNames="{style.selected-resources}">
<b:Icon type="PUSHPIN" addStyleNames="{style.icon-my-style}"></b:Icon>
<b:Button ui:field="buttonEdit" icon="PENCIL"
title="Edit the resource information" />
<b:Button ui:field="buttonDelete" icon="TRASH" <b:Button ui:field="buttonDelete" icon="TRASH"
title="Remove this resource" /> title="Remove this resource" />
<b:Button ui:field="buttonEdit" icon="PENCIL"
title="Edit the resource title" />
<b:Label ui:field="fieldName"></b:Label> <b:Label ui:field="fieldName"></b:Label>
<g:Label ui:field="fieldDescription" visible="false"
addStyleNames="{style.descr-text}"></g:Label>
</g:FlowPanel> </g:FlowPanel>
<g:HTMLPanel ui:field="editPanel"></g:HTMLPanel> <g:HTMLPanel ui:field="editPanel"></g:HTMLPanel>
</g:HTMLPanel> </g:HTMLPanel>

View File

@ -50,3 +50,7 @@
.GeoJson-DialogBox{ .GeoJson-DialogBox{
width: 100% !important; width: 100% !important;
} }
.accordion-no-border-inner .accordion-inner {
border: 0px;
}