Resource managing is almost finished, the editable description must be made working
git-svn-id: http://svn.d4science-ii.research-infrastructures.eu/gcube/trunk/portlets/widgets/ckan-metadata-publisher-widget@130042 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
38fae1ceb5
commit
b80ffda613
|
@ -20,6 +20,7 @@
|
||||||
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
|
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
|
||||||
<attributes>
|
<attributes>
|
||||||
<attribute name="maven.pomderived" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
<attribute name="org.eclipse.jst.component.dependency" value="/WEB-INF/lib"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
<classpathentry excluding="**" kind="src" output="${webappDirectory}/WEB-INF/classes" path="src/main/resources">
|
<classpathentry excluding="**" kind="src" output="${webappDirectory}/WEB-INF/classes" path="src/main/resources">
|
||||||
|
|
|
@ -16,7 +16,7 @@ public class CKanMetadataPublisher implements EntryPoint {
|
||||||
public void onModuleLoad() {
|
public void onModuleLoad() {
|
||||||
|
|
||||||
// remove comment to the below line for testing the widget
|
// remove comment to the below line for testing the widget
|
||||||
//startExample();
|
startExample();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -25,7 +25,7 @@ public class CKanMetadataPublisher implements EntryPoint {
|
||||||
|
|
||||||
String idFolderWorkspace = "d3a37eb9-1589-4c95-a9d0-c473a02d4f0f";
|
String idFolderWorkspace = "d3a37eb9-1589-4c95-a9d0-c473a02d4f0f";
|
||||||
String owner = "costantino.perciante";
|
String owner = "costantino.perciante";
|
||||||
RootPanel.get("ckan-metadata-publisher-div").add(new CreateDatasetForm(owner));
|
RootPanel.get("ckan-metadata-publisher-div").add(new CreateDatasetForm(idFolderWorkspace ,owner));
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -34,5 +34,4 @@ public class AddResourceContainer extends Composite{
|
||||||
public void add(TabPanel w){
|
public void add(TabPanel w){
|
||||||
resourcesPanel.add(w);
|
resourcesPanel.add(w);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,13 +71,6 @@ public class AddResourceToDataset extends Composite{
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(ClickEvent event) {
|
public void onClick(ClickEvent event) {
|
||||||
// String currentPath = Window.Location.getHref();
|
|
||||||
// int datasetIndex = datasetUrl.indexOf("/dataset");
|
|
||||||
// if(datasetIndex == -1)
|
|
||||||
// return;
|
|
||||||
//
|
|
||||||
// String finalPart = datasetUrl.substring(datasetIndex);
|
|
||||||
// String finalPath = currentPath + "?" + "path" + "=" + finalPart;
|
|
||||||
Window.Location.assign(datasetUrl);
|
Window.Location.assign(datasetUrl);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -97,7 +90,15 @@ public class AddResourceToDataset extends Composite{
|
||||||
}
|
}
|
||||||
|
|
||||||
// collect data and build up the bean
|
// collect data and build up the bean
|
||||||
final ResourceBeanWrapper resource = new ResourceBeanWrapper(resourceUrlTextBox.getText(), resourceNameTextBox.getText(), resourceDescriptionTextArea.getText());
|
final ResourceBeanWrapper resource =
|
||||||
|
new ResourceBeanWrapper(
|
||||||
|
resourceUrlTextBox.getText(),
|
||||||
|
resourceNameTextBox.getText(),
|
||||||
|
resourceDescriptionTextArea.getText(),
|
||||||
|
null,
|
||||||
|
true,
|
||||||
|
null,
|
||||||
|
owner);
|
||||||
|
|
||||||
// disable add button
|
// disable add button
|
||||||
addResourceButton.setEnabled(false);
|
addResourceButton.setEnabled(false);
|
||||||
|
|
|
@ -34,6 +34,7 @@ import com.github.gwtbootstrap.client.ui.constants.AlertType;
|
||||||
import com.github.gwtbootstrap.client.ui.constants.ButtonType;
|
import com.github.gwtbootstrap.client.ui.constants.ButtonType;
|
||||||
import com.github.gwtbootstrap.client.ui.resources.Bootstrap.Tabs;
|
import com.github.gwtbootstrap.client.ui.resources.Bootstrap.Tabs;
|
||||||
import com.google.gwt.core.client.GWT;
|
import com.google.gwt.core.client.GWT;
|
||||||
|
import com.google.gwt.dom.client.Style.Display;
|
||||||
import com.google.gwt.event.dom.client.ChangeEvent;
|
import com.google.gwt.event.dom.client.ChangeEvent;
|
||||||
import com.google.gwt.event.dom.client.ChangeHandler;
|
import com.google.gwt.event.dom.client.ChangeHandler;
|
||||||
import com.google.gwt.event.dom.client.ClickEvent;
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
@ -50,6 +51,7 @@ import com.google.gwt.user.client.rpc.AsyncCallback;
|
||||||
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.FlowPanel;
|
||||||
import com.google.gwt.user.client.ui.HTMLPanel;
|
import com.google.gwt.user.client.ui.HTMLPanel;
|
||||||
|
import com.google.gwt.user.client.ui.SimplePanel;
|
||||||
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;
|
||||||
|
|
||||||
|
@ -86,8 +88,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
@UiField TextBox maintainerEmailTextbox;
|
@UiField TextBox maintainerEmailTextbox;
|
||||||
@UiField ControlGroup customFields;
|
@UiField ControlGroup customFields;
|
||||||
@UiField Button addCustomFieldButton;
|
@UiField Button addCustomFieldButton;
|
||||||
@UiField CheckBox addResourcesCheckBox;
|
|
||||||
@UiField ControlGroup resourcesControlGroup;
|
|
||||||
@UiField Button createButton;
|
@UiField Button createButton;
|
||||||
@UiField Button resetButton;
|
@UiField Button resetButton;
|
||||||
@UiField AlertBlock infoBlock;
|
@UiField AlertBlock infoBlock;
|
||||||
|
@ -97,11 +97,17 @@ public class CreateDatasetForm extends Composite{
|
||||||
@UiField ListBox metadataProfilesFormatListbox;
|
@UiField ListBox metadataProfilesFormatListbox;
|
||||||
@UiField Form formFirstStep;
|
@UiField Form formFirstStep;
|
||||||
@UiField Form formSecondStep;
|
@UiField Form formSecondStep;
|
||||||
|
@UiField Form formThirdStep;
|
||||||
@UiField Button continueButton;
|
@UiField Button continueButton;
|
||||||
@UiField Button goBackButton;
|
@UiField Button goBackButtonFirstOrSecondStep;
|
||||||
@UiField Paragraph selectedProfile;
|
@UiField Paragraph selectedProfile;
|
||||||
@UiField Button goToDatasetButton;
|
@UiField Button goToDatasetButton;
|
||||||
@UiField Button addResourcesButton;
|
@UiField Button addResourcesButton;
|
||||||
|
@UiField CheckBox addResourcesCheckBox;
|
||||||
|
@UiField ControlGroup resourcesControlGroup;
|
||||||
|
@UiField SimplePanel workspaceResourcesContainer;
|
||||||
|
@UiField Button continueThirdStep;
|
||||||
|
@UiField Button goBackButtonFirstStep;
|
||||||
|
|
||||||
// tab panel
|
// tab panel
|
||||||
private TabPanel tabPanel;
|
private TabPanel tabPanel;
|
||||||
|
@ -133,6 +139,9 @@ public class CreateDatasetForm extends Composite{
|
||||||
// the list of MetaDataFieldSkeleton added
|
// the list of MetaDataFieldSkeleton added
|
||||||
List<MetaDataFieldSkeleton> listOfMetadataFields = new ArrayList<MetaDataFieldSkeleton>();
|
List<MetaDataFieldSkeleton> listOfMetadataFields = new ArrayList<MetaDataFieldSkeleton>();
|
||||||
|
|
||||||
|
// resource table
|
||||||
|
private ResourcesTable resourcesTable;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Invoked in the most general case
|
* Invoked in the most general case
|
||||||
* @param owner
|
* @param owner
|
||||||
|
@ -235,9 +244,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// hide the Add resources checkbox
|
|
||||||
resourcesControlGroup.removeFromParent();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -263,14 +269,11 @@ public class CreateDatasetForm extends Composite{
|
||||||
continueButton.setEnabled(false);
|
continueButton.setEnabled(false);
|
||||||
resetButton.setEnabled(false);
|
resetButton.setEnabled(false);
|
||||||
|
|
||||||
// set to visible the checkbox to add resources of the workspace
|
|
||||||
resourcesControlGroup.setVisible(true);
|
|
||||||
|
|
||||||
// get back the licenses and the metadata information from the workspace
|
// get back the licenses and the metadata information from the workspace
|
||||||
ckanServices.getDatasetBean(idFolderWorkspace, owner, new AsyncCallback<DatasetMetadataBean>() {
|
ckanServices.getDatasetBean(idFolderWorkspace, owner, new AsyncCallback<DatasetMetadataBean>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onSuccess(DatasetMetadataBean bean) {
|
public void onSuccess(final DatasetMetadataBean bean) {
|
||||||
|
|
||||||
if(bean != null){
|
if(bean != null){
|
||||||
|
|
||||||
|
@ -319,6 +322,11 @@ public class CreateDatasetForm extends Composite{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// enable manage resources checkbox
|
||||||
|
resourcesControlGroup.setVisible(true);
|
||||||
|
addResourcesCheckBox.getElement().getStyle().setDisplay(Display.INLINE_BLOCK);
|
||||||
|
resourcesTable = new ResourcesTable(bean.getResources());
|
||||||
|
|
||||||
// try to retrieve the licenses
|
// try to retrieve the licenses
|
||||||
setAlertBlock("Retrieving licenses, please wait...", AlertType.INFO, true);
|
setAlertBlock("Retrieving licenses, please wait...", AlertType.INFO, true);
|
||||||
ckanServices.getLicenses(new AsyncCallback<LicensesBean>() {
|
ckanServices.getLicenses(new AsyncCallback<LicensesBean>() {
|
||||||
|
@ -343,7 +351,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// everything went ok
|
// everything went ok
|
||||||
setAlertBlock("", AlertType.ERROR, false);
|
setAlertBlock("", AlertType.ERROR, false);
|
||||||
continueButton.setEnabled(true);
|
continueButton.setEnabled(true);
|
||||||
|
@ -471,24 +478,77 @@ public class CreateDatasetForm extends Composite{
|
||||||
String errorMsg = validateDataOnContinue();
|
String errorMsg = validateDataOnContinue();
|
||||||
|
|
||||||
if(errorMsg == null){
|
if(errorMsg == null){
|
||||||
formFirstStep.setVisible(false);
|
|
||||||
formSecondStep.setVisible(true);
|
// check what to do
|
||||||
selectedProfile.setText("Selected Profile is " + metadataProfilesFormatListbox.getSelectedItemText());
|
if(isWorkspaceRequest){
|
||||||
|
if(!addResourcesCheckBox.getValue()){
|
||||||
|
|
||||||
|
// we need to show the page to handle resources one by one from the workspace
|
||||||
|
formFirstStep.setVisible(false);
|
||||||
|
formSecondStep.setVisible(true);
|
||||||
|
formThirdStep.setVisible(false);
|
||||||
|
|
||||||
|
// add the resources to the container panel
|
||||||
|
if(workspaceResourcesContainer.getWidget() == null)
|
||||||
|
workspaceResourcesContainer.add(resourcesTable);
|
||||||
|
|
||||||
|
}else{
|
||||||
|
|
||||||
|
// resources will be added automatically and we can show the page of the profiles
|
||||||
|
formFirstStep.setVisible(false);
|
||||||
|
formThirdStep.setVisible(true);
|
||||||
|
selectedProfile.setText("Selected Profile is " + metadataProfilesFormatListbox.getSelectedItemText());
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
|
||||||
|
// this is not a workspace request
|
||||||
|
formFirstStep.setVisible(false);
|
||||||
|
formThirdStep.setVisible(true);
|
||||||
|
selectedProfile.setText("Selected Profile is " + metadataProfilesFormatListbox.getSelectedItemText());
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
alertOnContinue("Please check inserted data [" + errorMsg + "]", AlertType.ERROR);
|
alertOnContinue("Please check inserted data [" + errorMsg + "]", AlertType.ERROR);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@UiHandler("goBackButton")
|
|
||||||
void onGoBackButton(ClickEvent e){
|
@UiHandler("goBackButtonFirstStep")
|
||||||
|
void onGoBackButtonFirstStep(ClickEvent e){
|
||||||
|
|
||||||
// swap forms
|
// swap forms
|
||||||
formFirstStep.setVisible(true);
|
formFirstStep.setVisible(true);
|
||||||
formSecondStep.setVisible(false);
|
formSecondStep.setVisible(false);
|
||||||
|
formThirdStep.setVisible(false);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@UiHandler("goBackButtonFirstOrSecondStep")
|
||||||
|
void onGoBackButton(ClickEvent e){
|
||||||
|
|
||||||
|
// swap forms
|
||||||
|
if(isWorkspaceRequest && !addResourcesCheckBox.getValue()){
|
||||||
|
formFirstStep.setVisible(false);
|
||||||
|
formSecondStep.setVisible(true);
|
||||||
|
}else{
|
||||||
|
formFirstStep.setVisible(true);
|
||||||
|
formSecondStep.setVisible(false);
|
||||||
|
}
|
||||||
|
formThirdStep.setVisible(false);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@UiHandler("continueThirdStep")
|
||||||
|
void onContinueThirdStep(ClickEvent e){
|
||||||
|
|
||||||
|
// swap forms
|
||||||
|
formSecondStep.setVisible(false);
|
||||||
|
formThirdStep.setVisible(true);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@UiHandler("createButton")
|
@UiHandler("createButton")
|
||||||
void createDatasetEvent(ClickEvent e){
|
void createDatasetEvent(ClickEvent e){
|
||||||
|
|
||||||
|
@ -506,7 +566,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
String maintainer = maintainerTextbox.getValue();
|
String maintainer = maintainerTextbox.getValue();
|
||||||
String maintainerEmail = maintainerEmailTextbox.getValue();
|
String maintainerEmail = maintainerEmailTextbox.getValue();
|
||||||
String chosenOrganization = organizationsListbox.getSelectedItemText();
|
String chosenOrganization = organizationsListbox.getSelectedItemText();
|
||||||
boolean addResources = addResourcesCheckBox.getValue();
|
|
||||||
|
|
||||||
// fill the bean
|
// fill the bean
|
||||||
receivedBean.setAuthor(author);
|
receivedBean.setAuthor(author);
|
||||||
|
@ -520,7 +579,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
receivedBean.setTitle(title);
|
receivedBean.setTitle(title);
|
||||||
receivedBean.setTags(tagsList);
|
receivedBean.setTags(tagsList);
|
||||||
receivedBean.setSelectedOrganization(chosenOrganization);
|
receivedBean.setSelectedOrganization(chosenOrganization);
|
||||||
receivedBean.setAddResources(addResources);
|
|
||||||
|
|
||||||
Map<String, String> customFieldsMap = new HashMap<String, String>();
|
Map<String, String> customFieldsMap = new HashMap<String, String>();
|
||||||
|
|
||||||
|
@ -546,7 +604,7 @@ public class CreateDatasetForm extends Composite{
|
||||||
|
|
||||||
// invoke the create method
|
// invoke the create method
|
||||||
createButton.setEnabled(false);
|
createButton.setEnabled(false);
|
||||||
goBackButton.setEnabled(false);
|
goBackButtonFirstOrSecondStep.setEnabled(false);
|
||||||
|
|
||||||
ckanServices.createCKanDataset(receivedBean, isWorkspaceRequest, new AsyncCallback<DatasetMetadataBean>() {
|
ckanServices.createCKanDataset(receivedBean, isWorkspaceRequest, new AsyncCallback<DatasetMetadataBean>() {
|
||||||
|
|
||||||
|
@ -570,14 +628,6 @@ public class CreateDatasetForm extends Composite{
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onClick(ClickEvent event) {
|
public void onClick(ClickEvent event) {
|
||||||
|
|
||||||
// String currentPath = Window.Location.getHref();
|
|
||||||
// int datasetIndex = datasetUrl.indexOf("/dataset");
|
|
||||||
// if(datasetIndex == -1)
|
|
||||||
// return;
|
|
||||||
//
|
|
||||||
// String finalPart = datasetUrl.substring(datasetIndex);
|
|
||||||
// String finalPath = currentPath + "?" + "path" + "=" + finalPart;
|
|
||||||
Window.Location.assign(datasetUrl);
|
Window.Location.assign(datasetUrl);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -715,7 +765,7 @@ public class CreateDatasetForm extends Composite{
|
||||||
onCreateAlertBlock.setType(type);
|
onCreateAlertBlock.setType(type);
|
||||||
onCreateAlertBlock.setVisible(true);
|
onCreateAlertBlock.setVisible(true);
|
||||||
createButton.setEnabled(true);
|
createButton.setEnabled(true);
|
||||||
goBackButton.setEnabled(true);
|
goBackButtonFirstOrSecondStep.setEnabled(true);
|
||||||
|
|
||||||
// hide after some seconds
|
// hide after some seconds
|
||||||
Timer t = new Timer() {
|
Timer t = new Timer() {
|
||||||
|
@ -834,6 +884,7 @@ public class CreateDatasetForm extends Composite{
|
||||||
licenseListbox.setEnabled(false);
|
licenseListbox.setEnabled(false);
|
||||||
organizationsListbox.setEnabled(false);
|
organizationsListbox.setEnabled(false);
|
||||||
addCustomFieldButton.setEnabled(false);
|
addCustomFieldButton.setEnabled(false);
|
||||||
|
addResourcesCheckBox.setEnabled(false);
|
||||||
|
|
||||||
// freeze tags
|
// freeze tags
|
||||||
for(int i = 0; i < tagsList.size(); i++){
|
for(int i = 0; i < tagsList.size(); i++){
|
||||||
|
@ -853,6 +904,9 @@ public class CreateDatasetForm extends Composite{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// freeze table of resources
|
||||||
|
if(resourcesTable != null)
|
||||||
|
resourcesTable.freezeTable();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -881,6 +935,19 @@ public class CreateDatasetForm extends Composite{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@UiHandler("addResourcesCheckBox")
|
||||||
|
void onAddResourcesCheckboxPress(ClickEvent e){
|
||||||
|
|
||||||
|
// we need to set all resources to be added if checkbox value is true
|
||||||
|
if(addResourcesCheckBox.getValue()){
|
||||||
|
|
||||||
|
GWT.log("Set all resources to be add");
|
||||||
|
resourcesTable.checkAllResources(true);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add the tag as an element
|
* Add the tag as an element
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -84,9 +84,8 @@
|
||||||
Tags:
|
Tags:
|
||||||
</b:ControlLabel>
|
</b:ControlLabel>
|
||||||
<b:Controls>
|
<b:Controls>
|
||||||
<b:TextBox width="70%"
|
<b:TextBox width="70%" placeholder="Enter one or more tag for the product"
|
||||||
placeholder="Enter one or more tag for the product" b:id="tags"
|
b:id="tags" ui:field="tagsEnterTextBox" />
|
||||||
ui:field="tagsEnterTextBox" />
|
|
||||||
<span style="float:right; width:256px; color: #aaaaaa;">
|
<span style="float:right; width:256px; color: #aaaaaa;">
|
||||||
<b:Icon type="INFO_SIGN" size="TWO_TIMES" />
|
<b:Icon type="INFO_SIGN" size="TWO_TIMES" />
|
||||||
Tags are meaningful information that can be associated to the
|
Tags are meaningful information that can be associated to the
|
||||||
|
@ -207,6 +206,26 @@
|
||||||
</b:Controls>
|
</b:Controls>
|
||||||
</b:ControlGroup>
|
</b:ControlGroup>
|
||||||
|
|
||||||
|
<!-- If the user checks this box, the resources will be automatically
|
||||||
|
added, otherwise he has to manage them -->
|
||||||
|
<b:ControlGroup ui:field="resourcesControlGroup"
|
||||||
|
visible="false">
|
||||||
|
<b:ControlLabel for="resourcesAddCheckBox"
|
||||||
|
title="Automatically add all resources to product">Product
|
||||||
|
Resources:</b:ControlLabel>
|
||||||
|
<b:Controls>
|
||||||
|
<b:CheckBox b:id="resourcesAddCheckBox" width="60%"
|
||||||
|
title="Automatically add the folder content to the product as resource"
|
||||||
|
checked="true" ui:field="addResourcesCheckBox">
|
||||||
|
<b>Add folder content as resources</b>
|
||||||
|
</b:CheckBox>
|
||||||
|
<span style="float:right; width:256px; color: #aaaaaa;">
|
||||||
|
<b:Icon type="INFO_SIGN" size="TWO_TIMES" />
|
||||||
|
Automatically add folder content as resources of the product
|
||||||
|
</span>
|
||||||
|
</b:Controls>
|
||||||
|
</b:ControlGroup>
|
||||||
|
|
||||||
<!-- Alert block on continue -->
|
<!-- Alert block on continue -->
|
||||||
<b:AlertBlock type="INFO" close="false" animation="true"
|
<b:AlertBlock type="INFO" close="false" animation="true"
|
||||||
visible="false" ui:field="onContinueAlertBlock" styleName="{style.block-alert-style}">
|
visible="false" ui:field="onContinueAlertBlock" styleName="{style.block-alert-style}">
|
||||||
|
@ -219,8 +238,28 @@
|
||||||
</b:Fieldset>
|
</b:Fieldset>
|
||||||
</b:Form>
|
</b:Form>
|
||||||
|
|
||||||
|
|
||||||
<b:Form type="HORIZONTAL" styleName="{style.form-main-style}"
|
<b:Form type="HORIZONTAL" styleName="{style.form-main-style}"
|
||||||
ui:field="formSecondStep" visible="false">
|
ui:field="formSecondStep" visible="false">
|
||||||
|
<b:Fieldset styleName="{style.fieldset-border-style}">
|
||||||
|
<b:Legend styleName="{style.legend-style}">
|
||||||
|
Manage Resources
|
||||||
|
</b:Legend>
|
||||||
|
<g:SimplePanel ui:field="workspaceResourcesContainer"
|
||||||
|
visible="true"></g:SimplePanel>
|
||||||
|
|
||||||
|
<b:Button title="Continue" ui:field="continueThirdStep"
|
||||||
|
type="PRIMARY" block="true">Continue</b:Button>
|
||||||
|
|
||||||
|
<b:Button title="Go Back" ui:field="goBackButtonFirstStep"
|
||||||
|
block="true">Go
|
||||||
|
Back</b:Button>
|
||||||
|
</b:Fieldset>
|
||||||
|
</b:Form>
|
||||||
|
|
||||||
|
|
||||||
|
<b:Form type="HORIZONTAL" styleName="{style.form-main-style}"
|
||||||
|
ui:field="formThirdStep" visible="false">
|
||||||
<b:Fieldset styleName="{style.fieldset-border-style}">
|
<b:Fieldset styleName="{style.fieldset-border-style}">
|
||||||
|
|
||||||
<b:Legend styleName="{style.legend-style}">
|
<b:Legend styleName="{style.legend-style}">
|
||||||
|
@ -258,21 +297,6 @@
|
||||||
</b:Controls>
|
</b:Controls>
|
||||||
</b:ControlGroup>
|
</b:ControlGroup>
|
||||||
|
|
||||||
<b:ControlGroup ui:field="resourcesControlGroup"
|
|
||||||
visible="false">
|
|
||||||
<b:Controls>
|
|
||||||
<b:CheckBox
|
|
||||||
title="Automatically add the folder content to the product as resource"
|
|
||||||
checked="true" ui:field="addResourcesCheckBox">
|
|
||||||
<b>Add folder content as resources</b>
|
|
||||||
</b:CheckBox>
|
|
||||||
<span style="float:right; width:256px; color: #aaaaaa;">
|
|
||||||
<b:Icon type="INFO_SIGN" size="TWO_TIMES" />
|
|
||||||
Automatically add folder content as resources of the product
|
|
||||||
</span>
|
|
||||||
</b:Controls>
|
|
||||||
</b:ControlGroup>
|
|
||||||
|
|
||||||
<!-- Alert block on create -->
|
<!-- Alert block on create -->
|
||||||
<b:AlertBlock type="INFO" close="false" animation="true"
|
<b:AlertBlock type="INFO" close="false" animation="true"
|
||||||
visible="false" ui:field="onCreateAlertBlock" styleName="{style.block-alert-style}">
|
visible="false" ui:field="onCreateAlertBlock" styleName="{style.block-alert-style}">
|
||||||
|
@ -283,7 +307,8 @@
|
||||||
|
|
||||||
<b:Button title="Create product" ui:field="createButton"
|
<b:Button title="Create product" ui:field="createButton"
|
||||||
type="PRIMARY" block="true">Create</b:Button>
|
type="PRIMARY" block="true">Create</b:Button>
|
||||||
<b:Button title="Go Back" ui:field="goBackButton" block="true">Go
|
|
||||||
|
<b:Button title="Go Back" ui:field="goBackButtonFirstOrSecondStep" block="true">Go
|
||||||
Back</b:Button>
|
Back</b:Button>
|
||||||
|
|
||||||
<b:Button title="Go to product" ui:field="goToDatasetButton"
|
<b:Button title="Go to product" ui:field="goToDatasetButton"
|
||||||
|
|
|
@ -0,0 +1,248 @@
|
||||||
|
package org.gcube.portlets.widgets.ckandatapublisherwidget.client.ui;
|
||||||
|
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.gcube.portlets.widgets.ckandatapublisherwidget.shared.ResourceBeanWrapper;
|
||||||
|
|
||||||
|
import com.github.gwtbootstrap.client.ui.Button;
|
||||||
|
import com.github.gwtbootstrap.client.ui.CellTable;
|
||||||
|
import com.google.gwt.cell.client.Cell.Context;
|
||||||
|
import com.google.gwt.cell.client.CheckboxCell;
|
||||||
|
import com.google.gwt.cell.client.EditTextCell;
|
||||||
|
import com.google.gwt.core.client.GWT;
|
||||||
|
import com.google.gwt.dom.client.Element;
|
||||||
|
import com.google.gwt.dom.client.NativeEvent;
|
||||||
|
import com.google.gwt.dom.client.Style.Unit;
|
||||||
|
import com.google.gwt.event.dom.client.ClickEvent;
|
||||||
|
import com.google.gwt.event.dom.client.ClickHandler;
|
||||||
|
import com.google.gwt.safehtml.shared.SafeHtmlBuilder;
|
||||||
|
import com.google.gwt.user.cellview.client.Column;
|
||||||
|
import com.google.gwt.user.cellview.client.ColumnSortEvent.ListHandler;
|
||||||
|
import com.google.gwt.user.cellview.client.TextColumn;
|
||||||
|
import com.google.gwt.user.client.ui.Composite;
|
||||||
|
import com.google.gwt.user.client.ui.VerticalPanel;
|
||||||
|
import com.google.gwt.view.client.ListDataProvider;
|
||||||
|
import com.google.gwt.view.client.Range;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The resources table class.
|
||||||
|
* @author Costantino Perciante at ISTI-CNR (costantino.perciante@isti.cnr.it)
|
||||||
|
*/
|
||||||
|
public class ResourcesTable extends Composite{
|
||||||
|
|
||||||
|
// the data provider
|
||||||
|
protected ListDataProvider<ResourceBeanWrapper> dataProvider = new ListDataProvider<ResourceBeanWrapper>();
|
||||||
|
|
||||||
|
// the table that will be displayed
|
||||||
|
private CellTable<ResourceBeanWrapper> table = new CellTable<ResourceBeanWrapper>();
|
||||||
|
|
||||||
|
// save original list
|
||||||
|
private List<ResourceBeanWrapper> originalResources;
|
||||||
|
|
||||||
|
// main panel
|
||||||
|
private VerticalPanel mainPanel = new VerticalPanel();
|
||||||
|
|
||||||
|
// button labels
|
||||||
|
private static final String SELECT_ALL_LABEL = "Select All";
|
||||||
|
private static final String DESELECT_ALL_LABEL = "Deselect All";
|
||||||
|
|
||||||
|
// maintain the selection status
|
||||||
|
private boolean selectedAll = true;
|
||||||
|
final Button selectAllButton = new Button(DESELECT_ALL_LABEL);
|
||||||
|
|
||||||
|
// is read only?
|
||||||
|
private boolean readOnly = false;
|
||||||
|
|
||||||
|
public ResourcesTable(List<ResourceBeanWrapper> resources){
|
||||||
|
|
||||||
|
super();
|
||||||
|
initWidget(mainPanel);
|
||||||
|
|
||||||
|
// set panel width
|
||||||
|
mainPanel.setWidth("100%");
|
||||||
|
|
||||||
|
// save original resources
|
||||||
|
this.originalResources = resources;
|
||||||
|
|
||||||
|
// add data to the provider
|
||||||
|
dataProvider.setList(resources);
|
||||||
|
dataProvider.addDataDisplay(table);
|
||||||
|
|
||||||
|
// style of the table
|
||||||
|
table.setStriped(true);
|
||||||
|
table.setWidth("100%", false);
|
||||||
|
table.addStyleName("table-style");
|
||||||
|
table.setBordered(true);
|
||||||
|
|
||||||
|
// visible rows
|
||||||
|
table.setVisibleRange(new Range(0, originalResources.size()));
|
||||||
|
table.setRowCount(originalResources.size(), true);
|
||||||
|
|
||||||
|
// Add a checked column to add the resource.
|
||||||
|
Column<ResourceBeanWrapper, Boolean> chosenColumn = new Column<ResourceBeanWrapper, Boolean>(new CheckboxCell(true,false)) {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Boolean getValue(ResourceBeanWrapper object) {
|
||||||
|
return object.isToBeAdded();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBrowserEvent(Context context, final Element parent, final ResourceBeanWrapper res, NativeEvent event) {
|
||||||
|
event.preventDefault();
|
||||||
|
res.setToBeAdded(!res.isToBeAdded());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void render(Context context, ResourceBeanWrapper object,
|
||||||
|
SafeHtmlBuilder sb) {
|
||||||
|
|
||||||
|
if(readOnly){
|
||||||
|
|
||||||
|
String checked = object.isToBeAdded() ? "checked" : "unchecked";
|
||||||
|
sb.appendHtmlConstant("<input type='checkbox'" ).
|
||||||
|
appendHtmlConstant("tabindex='-1' ").
|
||||||
|
appendEscaped(checked).appendEscaped(" disabled ").appendHtmlConstant("/>");
|
||||||
|
|
||||||
|
}else{
|
||||||
|
|
||||||
|
super.render(context, object, sb);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
};
|
||||||
|
table.addColumn(chosenColumn, "Select");
|
||||||
|
|
||||||
|
// Add a text column to show the name (and make it sortable) TODO : make it editable
|
||||||
|
Column<ResourceBeanWrapper, String> nameColumn = new Column<ResourceBeanWrapper, String>(new EditTextCell()) {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getValue(ResourceBeanWrapper object) {
|
||||||
|
return object.getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBrowserEvent(Context context, Element elem,
|
||||||
|
ResourceBeanWrapper object, NativeEvent event) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
//super.onBrowserEvent(context, elem, object, event);
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ListHandler<ResourceBeanWrapper> nameColHandler = new ListHandler<ResourceBeanWrapper>(dataProvider.getList());
|
||||||
|
|
||||||
|
nameColHandler.setComparator(nameColumn, new Comparator<ResourceBeanWrapper>() {
|
||||||
|
|
||||||
|
public int compare(ResourceBeanWrapper o1, ResourceBeanWrapper o2) {
|
||||||
|
|
||||||
|
return o1.getName().compareTo(o2.getName());
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
nameColumn.setSortable(true);
|
||||||
|
nameColumn.setDefaultSortAscending(false);
|
||||||
|
table.addColumnSortHandler(nameColHandler);
|
||||||
|
table.addColumn(nameColumn, "Name");
|
||||||
|
|
||||||
|
// Add a date column to show the url
|
||||||
|
TextColumn<ResourceBeanWrapper> urlColumn = new TextColumn<ResourceBeanWrapper>() {
|
||||||
|
@Override
|
||||||
|
public String getValue(ResourceBeanWrapper object) {
|
||||||
|
return object.getUrl();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
table.addColumn(urlColumn, "Url");
|
||||||
|
|
||||||
|
// Add a date column to show the description (and make it sortable)
|
||||||
|
Column<ResourceBeanWrapper, String> descColumn = new Column<ResourceBeanWrapper, String>(new EditTextCell()) {
|
||||||
|
@Override
|
||||||
|
public String getValue(ResourceBeanWrapper object) {
|
||||||
|
return object.getDescription();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onBrowserEvent(Context context, Element elem,
|
||||||
|
ResourceBeanWrapper object, NativeEvent event) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
if(!readOnly){
|
||||||
|
super.onBrowserEvent(context, elem, object, event);
|
||||||
|
|
||||||
|
GWT.log("Element is " + elem);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void render(Context context, ResourceBeanWrapper object,
|
||||||
|
SafeHtmlBuilder sb) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
super.render(context, object, sb);
|
||||||
|
GWT.log("Element is " + sb);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
table.addColumn(descColumn, "Description (Editable)");
|
||||||
|
|
||||||
|
// sort by columnName
|
||||||
|
table.getColumnSortList().push(nameColumn);
|
||||||
|
|
||||||
|
// set width column chosen
|
||||||
|
table.setColumnWidth(chosenColumn, 5, Unit.PCT);
|
||||||
|
table.setColumnWidth(nameColumn, 20, Unit.PCT);
|
||||||
|
table.setColumnWidth(urlColumn, 45, Unit.PCT);
|
||||||
|
table.setColumnWidth(descColumn, 30, Unit.PCT);
|
||||||
|
|
||||||
|
// add a select all button
|
||||||
|
|
||||||
|
selectAllButton.getElement().getStyle().setMarginTop(15, Unit.PX);
|
||||||
|
selectAllButton.getElement().getStyle().setMarginBottom(15, Unit.PX);
|
||||||
|
|
||||||
|
// add handler
|
||||||
|
selectAllButton.addClickHandler(new ClickHandler() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onClick(ClickEvent event) {
|
||||||
|
selectedAll = !selectedAll;
|
||||||
|
checkAllResources(selectedAll);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// add the button
|
||||||
|
mainPanel.add(selectAllButton);
|
||||||
|
|
||||||
|
// add the table
|
||||||
|
mainPanel.add(table);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check all resources
|
||||||
|
*/
|
||||||
|
public void checkAllResources(boolean value){
|
||||||
|
|
||||||
|
if(value)
|
||||||
|
selectAllButton.setText(DESELECT_ALL_LABEL);
|
||||||
|
else
|
||||||
|
selectAllButton.setText(SELECT_ALL_LABEL);
|
||||||
|
|
||||||
|
for(ResourceBeanWrapper resource: originalResources)
|
||||||
|
resource.setToBeAdded(value);
|
||||||
|
|
||||||
|
// refresh data
|
||||||
|
dataProvider.refresh();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Freeze table content and select/deselect all button
|
||||||
|
*/
|
||||||
|
public void freezeTable() {
|
||||||
|
|
||||||
|
selectAllButton.setEnabled(false);
|
||||||
|
readOnly = true;
|
||||||
|
|
||||||
|
// redraw the table
|
||||||
|
table.redraw();
|
||||||
|
}
|
||||||
|
}
|
|
@ -56,7 +56,7 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
|
|
||||||
public static final String TEST_SCOPE = "/gcube/devsec/devVRE";
|
public static final String TEST_SCOPE = "/gcube/devsec/devVRE";
|
||||||
public static final String TEST_USER = "test.user";
|
public static final String TEST_USER = "test.user";
|
||||||
private final static String TEST_SEC_TOKEN = "4620e6d0-2313-4f48-9d54-eb3efd01a810";
|
private final static String TEST_SEC_TOKEN = "a1e19695-467f-42b8-966d-bf83dd2382ef";
|
||||||
|
|
||||||
// ckan keys for ASL
|
// ckan keys for ASL
|
||||||
private static final String CKAN_TOKEN_KEY = "ckanToken";
|
private static final String CKAN_TOKEN_KEY = "ckanToken";
|
||||||
|
@ -103,7 +103,7 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
*/
|
*/
|
||||||
public String getDevelopmentUser() {
|
public String getDevelopmentUser() {
|
||||||
String user = TEST_USER;
|
String user = TEST_USER;
|
||||||
//user = "costantino.perciante";
|
user = "costantino.perciante";
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -348,12 +348,12 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
|
|
||||||
logger.info("DatasetBean request for " + folderId + " and " + owner);
|
logger.info("DatasetBean request for " + folderId + " and " + owner);
|
||||||
|
|
||||||
|
ASLSession aslSession = getASLSession();
|
||||||
|
String user = aslSession.getUsername();
|
||||||
|
|
||||||
if(isWithinPortal()){
|
if(isWithinPortal()){
|
||||||
try{
|
try{
|
||||||
|
|
||||||
ASLSession aslSession = getASLSession();
|
|
||||||
String user = aslSession.getUsername();
|
|
||||||
|
|
||||||
// check if session expired
|
// check if session expired
|
||||||
if(user.equals(TEST_USER)){
|
if(user.equals(TEST_USER)){
|
||||||
logger.debug("SESSION EXPIRED");
|
logger.debug("SESSION EXPIRED");
|
||||||
|
@ -390,7 +390,8 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
WorkspaceItem retrievedItem = ws.getItem(folderId);
|
WorkspaceItem retrievedItem = ws.getItem(folderId);
|
||||||
|
|
||||||
// set some info
|
// set some info
|
||||||
bean.setTitle(retrievedItem.getName());
|
String onlyAlphanumeric = retrievedItem.getName().replaceAll("[^A-Za-z0-9]", "");
|
||||||
|
bean.setTitle(onlyAlphanumeric);
|
||||||
bean.setDescription(retrievedItem.getDescription());
|
bean.setDescription(retrievedItem.getDescription());
|
||||||
|
|
||||||
// retrieve gcube items of the folder
|
// retrieve gcube items of the folder
|
||||||
|
@ -405,8 +406,8 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
childrenIds.add(file.getId());
|
childrenIds.add(file.getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
bean.setResourcesIds(childrenIds);
|
List<ResourceBeanWrapper> listOfResources = getWorkspaceResourcesInformation(childrenIds, ws, user);
|
||||||
|
bean.setResources(listOfResources);
|
||||||
}
|
}
|
||||||
|
|
||||||
// retrieve the metadata
|
// retrieve the metadata
|
||||||
|
@ -424,7 +425,8 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
bean.setId(folderId);
|
bean.setId(folderId);
|
||||||
bean.setDescription("This is a fantastic description");
|
bean.setDescription("This is a fantastic description");
|
||||||
bean.setVersion(1);
|
bean.setVersion(1);
|
||||||
bean.setTitle("dataset-" + Calendar.getInstance().getTimeInMillis());
|
String onlyAlphanumeric = "test-creation-blablabla".replaceAll("[^A-Za-z0-9]", "");
|
||||||
|
bean.setTitle(onlyAlphanumeric + Calendar.getInstance().getTimeInMillis());
|
||||||
bean.setAuthor("Costantino Perciante");
|
bean.setAuthor("Costantino Perciante");
|
||||||
bean.setAuthorEmail("costantino.perciante@isti.cnr.it");
|
bean.setAuthorEmail("costantino.perciante@isti.cnr.it");
|
||||||
bean.setMaintainer("Costantino Perciante");
|
bean.setMaintainer("Costantino Perciante");
|
||||||
|
@ -452,8 +454,8 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
if(!file.isFolder()) // ok, it's a file
|
if(!file.isFolder()) // ok, it's a file
|
||||||
childrenIds.add(file.getId());
|
childrenIds.add(file.getId());
|
||||||
}
|
}
|
||||||
|
List<ResourceBeanWrapper> listOfResources = getWorkspaceResourcesInformation(childrenIds, ws, user);
|
||||||
bean.setResourcesIds(childrenIds);
|
bean.setResources(listOfResources);
|
||||||
}
|
}
|
||||||
|
|
||||||
// retrieve the metadata
|
// retrieve the metadata
|
||||||
|
@ -511,14 +513,6 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// get the owner
|
|
||||||
String username = toCreate.getOwnerIdentifier();
|
|
||||||
|
|
||||||
// set dataset info (same id as the folder, if the request comes from the workspace)
|
|
||||||
String withId = null;
|
|
||||||
if(isWorkspaceRequest)
|
|
||||||
withId = toCreate.getId();
|
|
||||||
|
|
||||||
String title = toCreate.getTitle();
|
String title = toCreate.getTitle();
|
||||||
String organizationNameOrId = toCreate.getSelectedOrganization();
|
String organizationNameOrId = toCreate.getSelectedOrganization();
|
||||||
String author = toCreate.getAuthor();
|
String author = toCreate.getAuthor();
|
||||||
|
@ -532,41 +526,29 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
List<String> listOfTags = toCreate.getTags();
|
List<String> listOfTags = toCreate.getTags();
|
||||||
Map<String, String> customFields = toCreate.getCustomFields();
|
Map<String, String> customFields = toCreate.getCustomFields();
|
||||||
boolean setPublic = toCreate.getVisibility();
|
boolean setPublic = toCreate.getVisibility();
|
||||||
|
|
||||||
|
// get the list of resources and convert to ResourceBean
|
||||||
List<ResourceBean> resources = new ArrayList<ResourceBean>();
|
List<ResourceBean> resources = new ArrayList<ResourceBean>();
|
||||||
|
List<ResourceBeanWrapper> resourcesToAdd = toCreate.getResources();
|
||||||
|
|
||||||
// build the resource (if it is a workspaceRequest type)
|
if(resourcesToAdd != null && !resourcesToAdd.isEmpty())
|
||||||
if(toCreate.isAddResources() && isWorkspaceRequest){
|
for (ResourceBeanWrapper resourceBeanWrapper : resourcesToAdd) {
|
||||||
|
|
||||||
logger.debug("We need to add resources to the dataset");
|
if(resourceBeanWrapper.isToBeAdded()){
|
||||||
|
resources.add(new ResourceBean(
|
||||||
try{
|
resourceBeanWrapper.getUrl(),
|
||||||
|
resourceBeanWrapper.getName(),
|
||||||
Workspace ws = HomeLibrary
|
resourceBeanWrapper.getDescription(),
|
||||||
.getHomeManagerFactory()
|
resourceBeanWrapper.getId(),
|
||||||
.getHomeManager()
|
resourceBeanWrapper.getOwner(),
|
||||||
.getHome(toCreate.getOwnerIdentifier()).getWorkspace();
|
null,
|
||||||
|
resourceBeanWrapper.getMimeType()));
|
||||||
for(String resourceId: toCreate.getResourcesIds()){
|
|
||||||
|
|
||||||
FolderItem item = (FolderItem)ws.getItem(resourceId);
|
|
||||||
ResourceBean newResource = new ResourceBean();
|
|
||||||
newResource.setDescription(item.getDescription());
|
|
||||||
newResource.setId(item.getId());
|
|
||||||
newResource.setUrl(item.getPublicLink(false));
|
|
||||||
newResource.setName(item.getName());
|
|
||||||
newResource.setMimeType(item.getMimeType());
|
|
||||||
newResource.setOwner(username);
|
|
||||||
resources.add(newResource);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}catch(Exception e){
|
|
||||||
logger.error("Unable to add those resources to the dataset", e);
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
|
String datasetId = utils.createCKanDataset(getUserCKanTokenFromSession(), null, title, organizationNameOrId, author,
|
||||||
String datasetId = utils.createCKanDataset(getUserCKanTokenFromSession(), withId, title, organizationNameOrId, author,
|
|
||||||
authorMail, maintainer, maintainerMail, version, description, licenseId,
|
authorMail, maintainer, maintainerMail, version, description, licenseId,
|
||||||
listOfTags, customFields, resources, setPublic);
|
listOfTags, customFields, resources, setPublic);
|
||||||
|
|
||||||
|
@ -688,4 +670,41 @@ public class CKANPublisherServicesImpl extends RemoteServiceServlet implements C
|
||||||
private String concatenateSessionKeyScope(String key, String scope){
|
private String concatenateSessionKeyScope(String key, String scope){
|
||||||
return key.concat(scope);
|
return key.concat(scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build up the resource beans.
|
||||||
|
* @param resourceIds
|
||||||
|
* @param ws
|
||||||
|
* @param username
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
public List<ResourceBeanWrapper> getWorkspaceResourcesInformation(
|
||||||
|
List<String> resourceIds, Workspace ws, String username) {
|
||||||
|
|
||||||
|
List<ResourceBeanWrapper> toReturn = null;
|
||||||
|
|
||||||
|
try{
|
||||||
|
|
||||||
|
toReturn = new ArrayList<>();
|
||||||
|
|
||||||
|
for (String resourceId : resourceIds) {
|
||||||
|
|
||||||
|
ResourceBeanWrapper newResource = new ResourceBeanWrapper();
|
||||||
|
FolderItem item = (FolderItem)ws.getItem(resourceId);
|
||||||
|
newResource.setDescription(item.getDescription());
|
||||||
|
newResource.setId(item.getId());
|
||||||
|
newResource.setUrl(item.getPublicLink(true));
|
||||||
|
newResource.setName(item.getName());
|
||||||
|
newResource.setToBeAdded(true); // default is true
|
||||||
|
newResource.setMimeType(item.getMimeType());
|
||||||
|
newResource.setOwner(username);
|
||||||
|
toReturn.add(newResource);
|
||||||
|
|
||||||
|
}
|
||||||
|
}catch(Exception e){
|
||||||
|
logger.error("Unable to retrieve resources' info", e);
|
||||||
|
}
|
||||||
|
|
||||||
|
return toReturn;
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -43,8 +43,7 @@ public class DatasetMetadataBean implements Serializable {
|
||||||
private String ownerIdentifier; // owner of the folder into the workspace (e.g., andrea.rossi)
|
private String ownerIdentifier; // owner of the folder into the workspace (e.g., andrea.rossi)
|
||||||
private List<String> organizationList; // list of organization in which the user is present and could create the dataset
|
private List<String> organizationList; // list of organization in which the user is present and could create the dataset
|
||||||
private String selectedOrganization;
|
private String selectedOrganization;
|
||||||
private List<String> resourcesIds; // in case of workspace, this is the list of children's ids
|
private List<ResourceBeanWrapper> resources; // in case of workspace, this is the list of children
|
||||||
private boolean addResources; // if true, add these files as resources to the dataset
|
|
||||||
private List<MetaDataProfileBean> metadataList;
|
private List<MetaDataProfileBean> metadataList;
|
||||||
|
|
||||||
public DatasetMetadataBean(){
|
public DatasetMetadataBean(){
|
||||||
|
@ -78,7 +77,7 @@ public class DatasetMetadataBean implements Serializable {
|
||||||
String author, String authorEmail, String maintainer,
|
String author, String authorEmail, String maintainer,
|
||||||
String maintainerEmail, String ownerIdentifier,
|
String maintainerEmail, String ownerIdentifier,
|
||||||
List<String> organizationList, String selectedOrganization,
|
List<String> organizationList, String selectedOrganization,
|
||||||
List<String> resourcesIds, boolean addResources,
|
List<ResourceBeanWrapper> resources,
|
||||||
List<MetaDataProfileBean> metadataList) {
|
List<MetaDataProfileBean> metadataList) {
|
||||||
super();
|
super();
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
@ -97,8 +96,7 @@ public class DatasetMetadataBean implements Serializable {
|
||||||
this.ownerIdentifier = ownerIdentifier;
|
this.ownerIdentifier = ownerIdentifier;
|
||||||
this.organizationList = organizationList;
|
this.organizationList = organizationList;
|
||||||
this.selectedOrganization = selectedOrganization;
|
this.selectedOrganization = selectedOrganization;
|
||||||
this.resourcesIds = resourcesIds;
|
this.resources = resources;
|
||||||
this.addResources = addResources;
|
|
||||||
this.metadataList = metadataList;
|
this.metadataList = metadataList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,20 +236,12 @@ public class DatasetMetadataBean implements Serializable {
|
||||||
this.selectedOrganization = selectedOrganization;
|
this.selectedOrganization = selectedOrganization;
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<String> getResourcesIds() {
|
public List<ResourceBeanWrapper> getResources() {
|
||||||
return resourcesIds;
|
return resources;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setResourcesIds(List<String> resourcesIds) {
|
public void setResources(List<ResourceBeanWrapper> resources) {
|
||||||
this.resourcesIds = resourcesIds;
|
this.resources = resources;
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isAddResources() {
|
|
||||||
return addResources;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setAddResources(boolean addResources) {
|
|
||||||
this.addResources = addResources;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -265,8 +255,7 @@ public class DatasetMetadataBean implements Serializable {
|
||||||
+ ", maintainerEmail=" + maintainerEmail + ", ownerIdentifier="
|
+ ", maintainerEmail=" + maintainerEmail + ", ownerIdentifier="
|
||||||
+ ownerIdentifier + ", organizationList=" + organizationList
|
+ ownerIdentifier + ", organizationList=" + organizationList
|
||||||
+ ", selectedOrganization=" + selectedOrganization
|
+ ", selectedOrganization=" + selectedOrganization
|
||||||
+ ", resourcesIds=" + resourcesIds + ", addResources="
|
+ ", resources=" + resources + ", metadataList=" + metadataList + "]";
|
||||||
+ addResources + ", metadataList=" + metadataList + "]";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,35 +13,33 @@ public class ResourceBeanWrapper implements Serializable{
|
||||||
private String name;
|
private String name;
|
||||||
private String description;
|
private String description;
|
||||||
private String id;
|
private String id;
|
||||||
|
private boolean toBeAdded;
|
||||||
|
private String mimeType;
|
||||||
|
private String owner;
|
||||||
|
|
||||||
public ResourceBeanWrapper(){
|
public ResourceBeanWrapper(){
|
||||||
super();
|
super();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param url
|
|
||||||
* @param name
|
|
||||||
* @param description
|
|
||||||
*/
|
|
||||||
public ResourceBeanWrapper(String url, String name, String description) {
|
|
||||||
super();
|
|
||||||
this.url = url;
|
|
||||||
this.name = name;
|
|
||||||
this.description = description;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param url
|
* @param url
|
||||||
* @param name
|
* @param name
|
||||||
* @param description
|
* @param description
|
||||||
* @param id
|
* @param id
|
||||||
|
* @param toBeAdded
|
||||||
|
* @param mimeType
|
||||||
|
* @param owner
|
||||||
*/
|
*/
|
||||||
public ResourceBeanWrapper(String url, String name, String description, String id) {
|
public ResourceBeanWrapper(String url, String name, String description,
|
||||||
|
String id, boolean toBeAdded, String mimeType, String owner) {
|
||||||
super();
|
super();
|
||||||
this.url = url;
|
this.url = url;
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.description = description;
|
this.description = description;
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
this.toBeAdded = toBeAdded;
|
||||||
|
this.mimeType = mimeType;
|
||||||
|
this.owner = owner;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -100,9 +98,56 @@ public class ResourceBeanWrapper implements Serializable{
|
||||||
this.id = id;
|
this.id = id;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the toBeAdded
|
||||||
|
*/
|
||||||
|
public boolean isToBeAdded() {
|
||||||
|
return toBeAdded;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param toBeAdded the toBeAdded to set
|
||||||
|
*/
|
||||||
|
public void setToBeAdded(boolean toBeAdded) {
|
||||||
|
this.toBeAdded = toBeAdded;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the mimeType
|
||||||
|
*/
|
||||||
|
public String getMimeType() {
|
||||||
|
return mimeType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param mimeType the mimeType to set
|
||||||
|
*/
|
||||||
|
public void setMimeType(String mimeType) {
|
||||||
|
this.mimeType = mimeType;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the owner
|
||||||
|
*/
|
||||||
|
public String getOwner() {
|
||||||
|
return owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param owner the owner to set
|
||||||
|
*/
|
||||||
|
public void setOwner(String owner) {
|
||||||
|
this.owner = owner;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* (non-Javadoc)
|
||||||
|
* @see java.lang.Object#toString()
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "ResourceBean [url=" + url + ", name=" + name + ", description="
|
return "ResourceBeanWrapper [url=" + url + ", name=" + name
|
||||||
+ description + ", id=" + id + "]";
|
+ ", description=" + description + ", id=" + id
|
||||||
|
+ ", toBeAdded=" + toBeAdded + ", mimeType=" + mimeType
|
||||||
|
+ ", owner=" + owner + "]";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue