Export properly the data for each field type on dataset templates
This commit is contained in:
parent
af432cf329
commit
15c3a6fcb5
|
@ -2,6 +2,7 @@ package eu.eudat.logic.utilities.documents.xml.datasetProfileXml;
|
|||
|
||||
|
||||
import eu.eudat.models.data.admin.components.datasetprofile.Page;
|
||||
import eu.eudat.models.data.components.commons.ViewStyle;
|
||||
import eu.eudat.models.data.components.commons.datafield.*;
|
||||
import eu.eudat.models.data.user.components.datasetprofile.Field;
|
||||
import eu.eudat.models.data.user.components.datasetprofile.FieldSet;
|
||||
|
@ -202,7 +203,9 @@ public class ExportXmlBuilderDatasetProfile {
|
|||
|
||||
if (field.getData() != null) {
|
||||
Element dataOut = element.createElement("data");
|
||||
if (field.getViewStyle().getRenderStyle().equals("combobox")) {
|
||||
ViewStyle.Type viewStyleType = ViewStyle.Type.fromName(field.getViewStyle().getRenderStyle());
|
||||
switch (viewStyleType) {
|
||||
case COMBO_BOX:
|
||||
ComboBoxData comboBoxDataObject = (ComboBoxData) field.getData();
|
||||
if (comboBoxDataObject.getType().equals("wordlist")) {
|
||||
WordListData wordListDataObject = (WordListData) field.getData();
|
||||
|
@ -236,10 +239,12 @@ public class ExportXmlBuilderDatasetProfile {
|
|||
dataOut.appendChild(singleItem);
|
||||
}
|
||||
}
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("booleanDecision")) {
|
||||
break;
|
||||
case BOOLEAN_DECISION:
|
||||
BooleanDecisionData booleanDecisionDataObject = (BooleanDecisionData) field.getData();
|
||||
dataOut.setAttribute("label", booleanDecisionDataObject.getLabel());
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("radiobox")) {
|
||||
break;
|
||||
case RADIO_BOX:
|
||||
RadioBoxData radioBoxDataObject = (RadioBoxData) field.getData();
|
||||
dataOut.setAttribute("label", radioBoxDataObject.getLabel());
|
||||
|
||||
|
@ -251,18 +256,67 @@ public class ExportXmlBuilderDatasetProfile {
|
|||
options.appendChild(optionChild);
|
||||
});
|
||||
dataOut.appendChild(options);
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("checkBox")) {
|
||||
CheckBoxData checkBoxDataObject = (CheckBoxData) field.getData();
|
||||
dataOut.setAttribute("label", checkBoxDataObject.getLabel());
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("freetext")) {
|
||||
FreeTextData freeTextDataObject = (FreeTextData) field.getData();
|
||||
dataOut.setAttribute("label", freeTextDataObject.getLabel());
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("textarea")) {
|
||||
TextAreaData textAreaDataObject = (TextAreaData) field.getData();
|
||||
dataOut.setAttribute("label", textAreaDataObject.getLabel());
|
||||
} else if (field.getViewStyle().getRenderStyle().equals("datePicker")) {
|
||||
DatePickerData datePickerDataObject = (DatePickerData) field.getData();
|
||||
dataOut.setAttribute("label", datePickerDataObject.getLabel());
|
||||
break;
|
||||
case CHECK_BOX:
|
||||
case FREE_TEXT:
|
||||
case TEXT_AREA:
|
||||
case DATE_PICKER:
|
||||
case DATASET_IDENTIFIER:
|
||||
case CURRENCY:
|
||||
case TAGS:
|
||||
FieldData fieldDataObject = (FieldData) field.getData();
|
||||
dataOut.setAttribute("label", fieldDataObject.getLabel());
|
||||
break;
|
||||
case INTERNAL_DMP_ENTRIES:
|
||||
InternalDmpEntitiesData internalDmpEntitiesData = (InternalDmpEntitiesData) field.getData();
|
||||
dataOut.setAttribute("label", internalDmpEntitiesData.getLabel());
|
||||
dataOut.setAttribute("type", internalDmpEntitiesData.getType());
|
||||
switch (internalDmpEntitiesData.getType()) {
|
||||
case "researchers":
|
||||
ResearchersAutoCompleteData researchersAutoCompleteData = (ResearchersAutoCompleteData) internalDmpEntitiesData;
|
||||
dataOut.setAttribute("multiAutocomplete", researchersAutoCompleteData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case "datasets":
|
||||
DatasetsAutoCompleteData datasetsAutoCompleteData = (DatasetsAutoCompleteData) internalDmpEntitiesData;
|
||||
dataOut.setAttribute("multiAutocomplete", datasetsAutoCompleteData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case "dmps":
|
||||
DMPsAutoCompleteData dmPsAutoCompleteData = (DMPsAutoCompleteData) internalDmpEntitiesData;
|
||||
dataOut.setAttribute("multiAutocomplete", dmPsAutoCompleteData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
}
|
||||
break;
|
||||
case EXTERNAL_DATASETS:
|
||||
ExternalDatasetsData externalDatasetsData = (ExternalDatasetsData) field.getData();
|
||||
dataOut.setAttribute("label", externalDatasetsData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", externalDatasetsData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case DATA_REPOSITORIES:
|
||||
DataRepositoriesData dataRepositoriesData = (DataRepositoriesData) field.getData();
|
||||
dataOut.setAttribute("label", dataRepositoriesData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", dataRepositoriesData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case ORGANIZATIONS:
|
||||
OrganizationsData organizationsData = (OrganizationsData) field.getData();
|
||||
dataOut.setAttribute("label", organizationsData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", organizationsData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case RESEARCHERS:
|
||||
ResearcherData researcherData = (ResearcherData) field.getData();
|
||||
dataOut.setAttribute("label", researcherData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", researcherData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case REGISTRIES:
|
||||
RegistriesData registriesData = (RegistriesData) field.getData();
|
||||
dataOut.setAttribute("label", registriesData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", registriesData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
case SERVICES:
|
||||
ServicesData servicesData = (ServicesData) field.getData();
|
||||
dataOut.setAttribute("label", servicesData.getLabel());
|
||||
dataOut.setAttribute("multiAutocomplete", servicesData.getMultiAutoComplete().toString());
|
||||
break;
|
||||
|
||||
}
|
||||
elementField.appendChild(dataOut);
|
||||
}
|
||||
|
|
|
@ -117,7 +117,9 @@ public class Field {
|
|||
fieldEntity.setViewStyle(this.viewStyle.toAdminCompositeModelSection());
|
||||
FieldData data = new ModelBuilder().toFieldData(null, this.viewStyle.getRenderStyle(), (Element) this.data);
|
||||
// fieldEntity.setData( data.fromXml((Element) this.data));
|
||||
if (data != null) {
|
||||
fieldEntity.setData(data.toMap((Element) this.data));
|
||||
}
|
||||
return fieldEntity;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -20,4 +20,44 @@ public class ViewStyle {
|
|||
this.cssClass = cssClass;
|
||||
}
|
||||
|
||||
public enum Type {
|
||||
COMBO_BOX("combobox"),
|
||||
BOOLEAN_DECISION("booleanDecision"),
|
||||
RADIO_BOX("radiobox"),
|
||||
INTERNAL_DMP_ENTRIES("internalDmpEntities"),
|
||||
CHECK_BOX("checkBox"),
|
||||
FREE_TEXT("freetext"),
|
||||
TEXT_AREA("textarea"),
|
||||
DATE_PICKER("datePicker"),
|
||||
EXTERNAL_DATASETS("externalDatasets"),
|
||||
DATA_REPOSITORIES("dataRepositories"),
|
||||
REGISTRIES("registries"),
|
||||
SERVICES("services"),
|
||||
TAGS("tags"),
|
||||
RESEARCHERS("researchers"),
|
||||
ORGANIZATIONS("organizations"),
|
||||
DATASET_IDENTIFIER("datasetIdentifier"),
|
||||
CURRENCY("currency"),
|
||||
VALIDATION("validation");
|
||||
|
||||
private final String name;
|
||||
|
||||
Type(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
|
||||
public static Type fromName(String name) {
|
||||
for (Type type: Type.values()) {
|
||||
if (name.equals(type.getName())) {
|
||||
return type;
|
||||
}
|
||||
}
|
||||
throw new IllegalArgumentException("View Style Type [" + name + "] is not valid");
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue