NIHVIVO 3783 added urltype select element to the template

This commit is contained in:
tworrall 2012-06-19 17:55:39 +00:00
parent d1b2cabd52
commit 4d680092d5
2 changed files with 37 additions and 9 deletions

View file

@ -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" />

View file

@ -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.