NIHVIVO 3783 added urltype select element to the template
This commit is contained in:
parent
d1b2cabd52
commit
4d680092d5
2 changed files with 37 additions and 9 deletions
|
@ -12,6 +12,7 @@
|
||||||
|
|
||||||
<#--Retrieve variables needed-->
|
<#--Retrieve variables needed-->
|
||||||
<#assign url = lvf.getFormFieldValue(editSubmission, editConfiguration, "url")/>
|
<#assign url = lvf.getFormFieldValue(editSubmission, editConfiguration, "url")/>
|
||||||
|
<#assign urlTypeValue = lvf.getFormFieldValue(editSubmission, editConfiguration, "urlType")/>
|
||||||
<#assign anchor = lvf.getFormFieldValue(editSubmission, editConfiguration, "anchor") />
|
<#assign anchor = lvf.getFormFieldValue(editSubmission, editConfiguration, "anchor") />
|
||||||
<#assign newRank = lvf.getFormFieldValue(editSubmission, editConfiguration, "newRank") />
|
<#assign newRank = lvf.getFormFieldValue(editSubmission, editConfiguration, "newRank") />
|
||||||
|
|
||||||
|
@ -48,6 +49,14 @@
|
||||||
|
|
||||||
<form class="customForm" action ="${submitUrl}" class="customForm">
|
<form class="customForm" action ="${submitUrl}" class="customForm">
|
||||||
|
|
||||||
|
<label for="urlType">URL Type${requiredHint}</label>
|
||||||
|
<#assign urlTypeOpts = editConfiguration.pageData.urlType />
|
||||||
|
<select name="urlType" style="margin-top:-2px" >
|
||||||
|
<option value="" <#if editMode == "add">selected</#if>>Select one</option>
|
||||||
|
<#list urlTypeOpts?keys as key>
|
||||||
|
<option value="${key}" <#if editMode == "edit" && urlTypeValue == key>selected</#if>>${urlTypeOpts[key]}</option>
|
||||||
|
</#list>
|
||||||
|
</select>
|
||||||
<label for="url">URL ${requiredHint}</label>
|
<label for="url">URL ${requiredHint}</label>
|
||||||
<input size="70" type="text" id="url" name="url" value="${url}" role="input" />
|
<input size="70" type="text" id="url" name="url" value="${url}" role="input" />
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
/* $This file is distributed under the terms of the license in /doc/license.txt$ */
|
/* $This file is distributed under the terms of the license in /doc/license.txt$ */
|
||||||
package edu.cornell.mannlib.vitro.webapp.edit.n3editing.configuration.generators;
|
package edu.cornell.mannlib.vitro.webapp.edit.n3editing.configuration.generators;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
import javax.servlet.http.HttpSession;
|
import javax.servlet.http.HttpSession;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
|
@ -13,9 +17,11 @@ import com.hp.hpl.jena.vocabulary.XSD;
|
||||||
|
|
||||||
import edu.cornell.mannlib.vitro.webapp.beans.Individual;
|
import edu.cornell.mannlib.vitro.webapp.beans.Individual;
|
||||||
import edu.cornell.mannlib.vitro.webapp.controller.VitroRequest;
|
import edu.cornell.mannlib.vitro.webapp.controller.VitroRequest;
|
||||||
|
import edu.cornell.mannlib.vitro.webapp.dao.VitroVocabulary;
|
||||||
import edu.cornell.mannlib.vitro.webapp.dao.jena.QueryUtils;
|
import edu.cornell.mannlib.vitro.webapp.dao.jena.QueryUtils;
|
||||||
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.EditConfigurationUtils;
|
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.EditConfigurationUtils;
|
||||||
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.EditConfigurationVTwo;
|
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.EditConfigurationVTwo;
|
||||||
|
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.fields.ChildVClassesWithParent;
|
||||||
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.fields.FieldVTwo;
|
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.VTwo.fields.FieldVTwo;
|
||||||
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.configuration.validators.AntiXssValidation;
|
import edu.cornell.mannlib.vitro.webapp.edit.n3editing.configuration.validators.AntiXssValidation;
|
||||||
/**
|
/**
|
||||||
|
@ -41,7 +47,7 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
public static Log log = LogFactory.getLog( AddEditWebpageFormGenerator.class );
|
public static Log log = LogFactory.getLog( AddEditWebpageFormGenerator.class );
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public EditConfigurationVTwo getEditConfiguration(VitroRequest vreq, HttpSession session) {
|
public EditConfigurationVTwo getEditConfiguration(VitroRequest vreq, HttpSession session) throws Exception {
|
||||||
EditConfigurationVTwo config = new EditConfigurationVTwo();
|
EditConfigurationVTwo config = new EditConfigurationVTwo();
|
||||||
|
|
||||||
config.setTemplate("addEditWebpageForm.ftl");
|
config.setTemplate("addEditWebpageForm.ftl");
|
||||||
|
@ -51,11 +57,11 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
initObjectPropForm(config, vreq);
|
initObjectPropForm(config, vreq);
|
||||||
|
|
||||||
config.setVarNameForSubject("subject");
|
config.setVarNameForSubject("subject");
|
||||||
|
|
||||||
config.setVarNameForObject("link");
|
config.setVarNameForObject("link");
|
||||||
|
|
||||||
config.addNewResource("link", DEFAULT_NS_FOR_NEW_RESOURCE);
|
config.addNewResource("link", DEFAULT_NS_FOR_NEW_RESOURCE);
|
||||||
|
|
||||||
config.setN3Required(list( N3_FOR_WEBPAGE ));
|
config.setN3Required(list( N3_FOR_WEBPAGE, N3_FOR_URLTYPE ));
|
||||||
config.setN3Optional(list( N3_FOR_ANCHOR, N3_FOR_RANK));
|
config.setN3Optional(list( N3_FOR_ANCHOR, N3_FOR_RANK));
|
||||||
|
|
||||||
config.addUrisInScope("webpageProperty", list( core + "webpage"));
|
config.addUrisInScope("webpageProperty", list( core + "webpage"));
|
||||||
|
@ -64,19 +70,26 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
config.addUrisInScope("linkURI", list( core + "linkURI" ));
|
config.addUrisInScope("linkURI", list( core + "linkURI" ));
|
||||||
config.addUrisInScope("linkAnchorPredicate", list( core + "linkAnchorText" ));
|
config.addUrisInScope("linkAnchorPredicate", list( core + "linkAnchorText" ));
|
||||||
config.addUrisInScope("rankPredicate", list( core + "rank"));
|
config.addUrisInScope("rankPredicate", list( core + "rank"));
|
||||||
config.addUrisInScope("linkClass", list( core + "URLLink"));
|
|
||||||
|
|
||||||
|
config.setUrisOnForm("urlType");
|
||||||
config.setLiteralsOnForm(list("url","anchor","rank"));
|
config.setLiteralsOnForm(list("url","anchor","rank"));
|
||||||
|
|
||||||
config.addSparqlForExistingLiteral("url", URL_QUERY);
|
config.addSparqlForExistingLiteral("url", URL_QUERY);
|
||||||
config.addSparqlForExistingLiteral("anchor", ANCHOR_QUERY);
|
config.addSparqlForExistingLiteral("anchor", ANCHOR_QUERY);
|
||||||
config.addSparqlForExistingLiteral("rank", MAX_RANK_QUERY);
|
config.addSparqlForExistingLiteral("rank", MAX_RANK_QUERY);
|
||||||
|
config.addSparqlForExistingUris("urlType", URLTYPE_QUERY);
|
||||||
|
|
||||||
config.addField(new FieldVTwo().
|
config.addField(new FieldVTwo().
|
||||||
setName("url").
|
setName("url").
|
||||||
setValidators(list("nonempty", "datatype:"+XSD.anyURI.toString(), "httpUrl")).
|
setValidators(list("nonempty", "datatype:"+XSD.anyURI.toString(), "httpUrl")).
|
||||||
setRangeDatatypeUri(XSD.anyURI.toString()));
|
setRangeDatatypeUri(XSD.anyURI.toString()));
|
||||||
|
|
||||||
|
config.addField( new FieldVTwo().
|
||||||
|
setName("urlType").
|
||||||
|
setValidators( list("nonempty") ).
|
||||||
|
setOptions(
|
||||||
|
new ChildVClassesWithParent(core + "URLLink")));
|
||||||
|
|
||||||
config.addField(new FieldVTwo().
|
config.addField(new FieldVTwo().
|
||||||
setName("anchor"));
|
setName("anchor"));
|
||||||
|
|
||||||
|
@ -110,8 +123,11 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
static String N3_FOR_WEBPAGE =
|
static String N3_FOR_WEBPAGE =
|
||||||
"?subject ?webpageProperty ?link . \n"+
|
"?subject ?webpageProperty ?link . \n"+
|
||||||
"?link ?inverseProperty ?subject . \n"+
|
"?link ?inverseProperty ?subject . \n"+
|
||||||
"?link a ?linkClass ; \n" +
|
"?link a ?linkClass . \n" +
|
||||||
" ?linkURI ?url .";
|
"?link ?linkURI ?url .";
|
||||||
|
|
||||||
|
static String N3_FOR_URLTYPE =
|
||||||
|
"?link a ?urlType .";
|
||||||
|
|
||||||
static String N3_FOR_ANCHOR =
|
static String N3_FOR_ANCHOR =
|
||||||
"?link ?linkAnchorPredicate ?anchor .";
|
"?link ?linkAnchorPredicate ?anchor .";
|
||||||
|
@ -124,6 +140,10 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
static String URL_QUERY =
|
static String URL_QUERY =
|
||||||
"SELECT ?urlExisting WHERE { ?link ?linkURI ?urlExisting }";
|
"SELECT ?urlExisting WHERE { ?link ?linkURI ?urlExisting }";
|
||||||
|
|
||||||
|
static String URLTYPE_QUERY =
|
||||||
|
"PREFIX vitro: <" + VitroVocabulary.vitroURI + "> \n" +
|
||||||
|
"SELECT ?linkClassExisting WHERE { ?link vitro:mostSpecificType ?linkClassExisting }";
|
||||||
|
|
||||||
static String ANCHOR_QUERY =
|
static String ANCHOR_QUERY =
|
||||||
"SELECT ?anchorExisting WHERE { ?link ?linkAnchorPredicate ?anchorExisting }";
|
"SELECT ?anchorExisting WHERE { ?link ?linkAnchorPredicate ?anchorExisting }";
|
||||||
|
|
||||||
|
@ -132,7 +152,6 @@ public class AddEditWebpageFormGenerator extends BaseEditConfigurationGenerator
|
||||||
|
|
||||||
static String core = "http://vivoweb.org/ontology/core#";
|
static String core = "http://vivoweb.org/ontology/core#";
|
||||||
|
|
||||||
|
|
||||||
/* Note on ordering by rank in sparql: if there is a non-integer value on a link, that will be returned,
|
/* Note on ordering by rank in sparql: if there is a non-integer value on a link, that will be returned,
|
||||||
* since it's ranked highest. Preventing that would require getting all the ranks and sorting in Java,
|
* since it's ranked highest. Preventing that would require getting all the ranks and sorting in Java,
|
||||||
* throwing out non-int values.
|
* throwing out non-int values.
|
||||||
|
|
Loading…
Add table
Reference in a new issue