NIHVIVO-1820 Updated precision to full (Second) and requiredLevel to none for dateTimeInterval dateTimeValue custom forms. NIHVIVO-1855, NIHVIVO-1829 Corrected submit button text for dateTimeIntervalForm.jsp

This commit is contained in:
nac26 2011-01-21 20:18:05 +00:00
parent 893ac85b38
commit 1f2edcc622
3 changed files with 66 additions and 44 deletions

View file

@ -138,14 +138,14 @@
%> %>
<c:set var="editMode" value="edit" /> <c:set var="editMode" value="edit" />
<c:set var="titleVerb" value="Edit" /> <c:set var="titleVerb" value="Edit" />
<c:set var="submitButtonText" value="Edit Position" /> <c:set var="submitButtonText" value="Edit Date/Time Interval" />
<c:set var="disabledVal" value="disabled" /> <c:set var="disabledVal" value="disabled" />
<% <%
} else { // adding new entry } else { // adding new entry
%> %>
<c:set var="editMode" value="add" /> <c:set var="editMode" value="add" />
<c:set var="titleVerb" value="Create" /> <c:set var="titleVerb" value="Create" />
<c:set var="submitButtonText" value="Position" /> <c:set var="submitButtonText" value="Create Date/Time Interval" />
<c:set var="disabledVal" value="" /> <c:set var="disabledVal" value="" />
<% } %> <% } %>
@ -223,9 +223,9 @@
//setup date time edit elements //setup date time edit elements
Field startField = editConfig.getField("startField"); Field startField = editConfig.getField("startField");
// arguments for DateTimeWithPrecision are (fieldName, minimumPrecision, [requiredLevel]) // arguments for DateTimeWithPrecision are (fieldName, minimumPrecision, [requiredLevel])
startField.setEditElement(new DateTimeWithPrecision(startField, VitroVocabulary.Precision.DAY.uri(), VitroVocabulary.Precision.DAY.uri())); startField.setEditElement(new DateTimeWithPrecision(startField, VitroVocabulary.Precision.SECOND.uri(), VitroVocabulary.Precision.NONE.uri()));
Field endField = editConfig.getField("endField"); Field endField = editConfig.getField("endField");
endField.setEditElement(new DateTimeWithPrecision(endField, VitroVocabulary.Precision.DAY.uri(), VitroVocabulary.Precision.DAY.uri())); endField.setEditElement(new DateTimeWithPrecision(endField, VitroVocabulary.Precision.SECOND.uri(), VitroVocabulary.Precision.NONE.uri()));
} }
editConfig.addValidator(new DateTimeIntervalValidation("startField","endField") ); editConfig.addValidator(new DateTimeIntervalValidation("startField","endField") );
@ -236,7 +236,19 @@
editConfig.prepareForObjPropUpdate(model); editConfig.prepareForObjPropUpdate(model);
} else { // adding new } else { // adding new
editConfig.prepareForNonUpdate(model); editConfig.prepareForNonUpdate(model);
} }
List<String> customJs = new ArrayList<String>(Arrays.asList(JavaScript.JQUERY_UI.path(),
JavaScript.CUSTOM_FORM_UTILS.path(),
"/edit/forms/js/customFormWithAutocomplete.js"
));
request.setAttribute("customJs", customJs);
List<String> customCss = new ArrayList<String>(Arrays.asList(Css.JQUERY_UI.path(),
Css.CUSTOM_FORM.path(),
"/edit/forms/css/customFormWithAutocomplete.css"
));
request.setAttribute("customCss", customCss);
String subjectName = ((Individual) request.getAttribute("subject")).getName(); String subjectName = ((Individual) request.getAttribute("subject")).getName();
%> %>

View file

@ -27,13 +27,13 @@
<%@ taglib prefix="c" uri="http://java.sun.com/jstl/core"%> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core"%>
<%@ taglib prefix="v" uri="http://vitro.mannlib.cornell.edu/vitro/tags" %> <%@ taglib prefix="v" uri="http://vitro.mannlib.cornell.edu/vitro/tags" %>
<%! <%!
public static Log log = LogFactory.getLog("edu.cornell.mannlib.vitro.webapp.jsp.edit.forms.dateTimeValueForm"); public static Log log = LogFactory.getLog("edu.cornell.mannlib.vitro.webapp.jsp.edit.forms.dateTimeValueForm");
%> %>
<% <%
VitroRequest vreq = new VitroRequest(request); VitroRequest vreq = new VitroRequest(request);
WebappDaoFactory wdf = vreq.getWebappDaoFactory(); WebappDaoFactory wdf = vreq.getWebappDaoFactory();
vreq.setAttribute("defaultNamespace", ""); //empty string triggers default new URI behavior vreq.setAttribute("defaultNamespace", ""); //empty string triggers default new URI behavior
%> %>
<c:set var="vivoCore" value="http://vivoweb.org/ontology/core#" /> <c:set var="vivoCore" value="http://vivoweb.org/ontology/core#" />
@ -48,33 +48,31 @@
<c:set var="dateTimePrecision" value="${vivoCore}dateTimePrecision"/> <c:set var="dateTimePrecision" value="${vivoCore}dateTimePrecision"/>
<%-- Assertions for adding a new date time value --%> <%-- Assertions for adding a new date time value --%>
<v:jsonset var="n3ForValue"> <v:jsonset var="n3ForValue">
?subject <${toDateTimeValue}> ?valueNode . ?subject <${toDateTimeValue}> ?valueNode .
?valueNode <${type}> <${valueType}> . ?valueNode <${type}> <${valueType}> .
?valueNode <${dateTimeValue}> ?dateTimeField.value . ?valueNode <${dateTimeValue}> ?dateTimeField.value .
?valueNode <${dateTimePrecision}> ?dateTimeField.precision . ?valueNode <${dateTimePrecision}> ?dateTimeField.precision .
</v:jsonset> </v:jsonset>
<%-- Queries for editing an existing role --%> <%-- Queries for editing an existing role --%>
<v:jsonset var="existingNodeQuery" >
<v:jsonset var="existingNodeQuery" >
SELECT ?existingNode WHERE { SELECT ?existingNode WHERE {
?subject <${toDateTimeValue}> ?existingNode . ?subject <${toDateTimeValue}> ?existingNode .
?existingNode <${type}> <${valueType}> . } ?existingNode <${type}> <${valueType}> . }
</v:jsonset> </v:jsonset>
existingDateTimeValueQuery <v:jsonset var="existingDateTimeValueQuery" >
<v:jsonset var="existingDateTimeValueQuery" > SELECT ?existingDateTimeValue WHERE {
SELECT ?existingDateTimeValue WHERE { ?subject <${toDateTimeValue}> ?existingValueNode .
?subject <${toDateTimeValue}> ?existingValueNode . ?existingValueNode <${type}> <${valueType}> .
?existingValueNode <${type}> <${valueType}> .
?existingValueNode <${dateTimeValue}> ?existingDateTimeValue . } ?existingValueNode <${dateTimeValue}> ?existingDateTimeValue . }
</v:jsonset> </v:jsonset>
<v:jsonset var="existingPrecisionQuery" > <v:jsonset var="existingPrecisionQuery" >
SELECT ?existingPrecision WHERE { SELECT ?existingPrecision WHERE {
?subject <${toDateTimeValue}> ?existingValueNode . ?subject <${toDateTimeValue}> ?existingValueNode .
?existingValueNode <${type}> <${valueType}> . ?existingValueNode <${type}> <${valueType}> .
?existingValueNode <${dateTimePrecision}> ?existingPrecision . } ?existingValueNode <${dateTimePrecision}> ?existingPrecision . }
</v:jsonset> </v:jsonset>
@ -87,14 +85,14 @@
%> %>
<c:set var="editMode" value="edit" /> <c:set var="editMode" value="edit" />
<c:set var="titleVerb" value="Edit" /> <c:set var="titleVerb" value="Edit" />
<c:set var="submitButtonText" value="Edit DateTime Value" /> <c:set var="submitButtonText" value="Edit Date/Time Value" />
<c:set var="disabledVal" value="disabled" /> <c:set var="disabledVal" value="disabled" />
<% <%
} else { // adding new entry } else { // adding new entry
%> %>
<c:set var="editMode" value="add" /> <c:set var="editMode" value="add" />
<c:set var="titleVerb" value="Create" /> <c:set var="titleVerb" value="Create" />
<c:set var="submitButtonText" value="DateTime Value" /> <c:set var="submitButtonText" value="Create Date/Time Value" />
<c:set var="disabledVal" value="" /> <c:set var="disabledVal" value="" />
<% } %> <% } %>
@ -103,21 +101,21 @@
"formUrl" : "${formUrl}", "formUrl" : "${formUrl}",
"editKey" : "${editKey}", "editKey" : "${editKey}",
"urlPatternToReturnTo" : "/individual", "urlPatternToReturnTo" : "/individual",
"subject" : ["subject", "${subjectUriJson}" ], "subject" : ["subject", "${subjectUriJson}" ],
"predicate" : ["toDateTimeValue", "${predicateUriJson}" ], "predicate" : ["toDateTimeValue", "${predicateUriJson}" ],
"object" : ["valueNode", "${objectUriJson}", "URI" ], "object" : ["valueNode", "${objectUriJson}", "URI" ],
"n3required" : [ "${n3ForValue}" ], "n3required" : [ ],
"n3optional" : [ ], "n3optional" : [ "${n3ForValue}" ],
"newResources" : { "valueNode" : "${defaultNamespace}" }, "newResources" : { "valueNode" : "${defaultNamespace}" },
"urisInScope" : { }, "urisInScope" : { },
"literalsInScope": { }, "literalsInScope": { },
"urisOnForm" : [ ], "urisOnForm" : [ ],
"literalsOnForm" : [ ], "literalsOnForm" : [ ],
"filesOnForm" : [ ], "filesOnForm" : [ ],
"sparqlForLiterals" : { }, "sparqlForLiterals" : { },
"sparqlForUris" : { }, "sparqlForUris" : { },
@ -125,8 +123,8 @@
"dateTimeField.value" : "${existingDateTimeValueQuery}", "dateTimeField.value" : "${existingDateTimeValueQuery}",
}, },
"sparqlForExistingUris" : { "sparqlForExistingUris" : {
"valueNode" : "${existingNodeQuery}", "valueNode" : "${existingNodeQuery}",
"dateTimeField.precision": "${existingPrecisionQuery}" "dateTimeField.precision": "${existingPrecisionQuery}"
}, },
"fields" : { "fields" : {
"dateTimeField" : { "dateTimeField" : {
@ -137,7 +135,7 @@
"predicateUri" : "", "predicateUri" : "",
"objectClassUri" : "", "objectClassUri" : "",
"rangeDatatypeUri" : "", "rangeDatatypeUri" : "",
"rangeLang" : "", "rangeLang" : "",
"assertions" : ["${n3ForValue}"] "assertions" : ["${n3ForValue}"]
} }
} }
@ -149,13 +147,13 @@
EditConfiguration editConfig = EditConfiguration.getConfigFromSession(session,request); EditConfiguration editConfig = EditConfiguration.getConfigFromSession(session,request);
if (editConfig == null) { if (editConfig == null) {
editConfig = new EditConfiguration((String) request.getAttribute("editjson")); editConfig = new EditConfiguration((String) request.getAttribute("editjson"));
EditConfiguration.putConfigInSession(editConfig,session); EditConfiguration.putConfigInSession(editConfig,session);
//setup date time edit elements //setup date time edit elements
Field dateTimeField = editConfig.getField("dateTimeField"); Field dateTimeField = editConfig.getField("dateTimeField");
// arguments for DateTimeWithPrecision are (fieldName, minimumPrecision, [requiredLevel]) // arguments for DateTimeWithPrecision are (fieldName, minimumPrecision, [requiredLevel])
dateTimeField.setEditElement(new DateTimeWithPrecision(dateTimeField, VitroVocabulary.Precision.DAY.uri(), VitroVocabulary.Precision.DAY.uri())); dateTimeField.setEditElement(new DateTimeWithPrecision(dateTimeField, VitroVocabulary.Precision.SECOND.uri(), VitroVocabulary.Precision.NONE.uri()));
} }
Model model = (Model) application.getAttribute("jenaOntModel"); Model model = (Model) application.getAttribute("jenaOntModel");
@ -164,20 +162,32 @@
editConfig.prepareForObjPropUpdate(model); editConfig.prepareForObjPropUpdate(model);
} else { // adding new } else { // adding new
editConfig.prepareForNonUpdate(model); editConfig.prepareForNonUpdate(model);
} }
List<String> customJs = new ArrayList<String>(Arrays.asList(JavaScript.JQUERY_UI.path(),
JavaScript.CUSTOM_FORM_UTILS.path(),
"/edit/forms/js/customFormWithAutocomplete.js"
));
request.setAttribute("customJs", customJs);
List<String> customCss = new ArrayList<String>(Arrays.asList(Css.JQUERY_UI.path(),
Css.CUSTOM_FORM.path(),
"/edit/forms/css/customFormWithAutocomplete.css"
));
request.setAttribute("customCss", customCss);
String subjectName = ((Individual) request.getAttribute("subject")).getName(); String subjectName = ((Individual) request.getAttribute("subject")).getName();
%> %>
<jsp:include page="${preForm}" /> <jsp:include page="${preForm}" />
<h2>${titleVerb}&nbsp;date time value for <%= subjectName %></h2> <h2>${titleVerb} date time value for <%= subjectName %></h2>
<form class="customForm" action="<c:url value="/edit/processRdfForm2.jsp"/>" > <form class="customForm" action="<c:url value="/edit/processRdfForm2.jsp"/>" >
<v:input id="dateTimeField" label="date time" /> <v:input id="dateTimeField" />
<p class="submit"><v:input type="submit" id="submit" value="${submitButtonText}" cancel="true"/></p> <p class="submit"><v:input type="submit" id="submit" value="${submitButtonText}" cancel="true"/></p>
</form> </form>
<jsp:include page="${postForm}"/> <jsp:include page="${postForm}"/>

View file

@ -68,7 +68,7 @@ precisionConstants.second -- URI for precision
<#assign reqLevel = 0 /> <#assign reqLevel = 0 />
</#if> </#if>
<fieldset id="dateTime"> <fieldset class="dateTime">
<#if precLevel gte 1> <#if precLevel gte 1>
<#-- Only text input field in the mix. We should have some validation to ensure it's a valid year (4 digits, integer, etc) --> <#-- Only text input field in the mix. We should have some validation to ensure it's a valid year (4 digits, integer, etc) -->