<%-- $This file is distributed under the terms of the license in /doc/license.txt$ --%> <%@ page import="java.util.List" %> <%@ page import="java.util.ArrayList" %> <%@ page import="java.util.Arrays" %> <%@ page import="com.hp.hpl.jena.rdf.model.Literal"%> <%@ page import="com.hp.hpl.jena.rdf.model.Model"%> <%@ page import="com.hp.hpl.jena.vocabulary.XSD" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.beans.Individual"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.dao.VitroVocabulary"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.EditConfiguration"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.dao.WebappDaoFactory"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.controller.VitroRequest"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.web.MiscWebUtils"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.StartYearBeforeEndYear"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.controller.freemarker.UrlBuilder.JavaScript" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.controller.freemarker.UrlBuilder.Css" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.elements.DateTimeWithPrecision"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.Field"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.utils.FrontEndEditingUtils"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.utils.FrontEndEditingUtils.EditMode"%> <%@ page import="org.apache.commons.logging.Log" %> <%@ page import="org.apache.commons.logging.LogFactory" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.DateTimeIntervalValidation"%> <%@ taglib prefix="c" uri="http://java.sun.com/jstl/core"%> <%@ 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.personHasPositionHistory.jsp"); %> <% VitroRequest vreq = new VitroRequest(request); WebappDaoFactory wdf = vreq.getWebappDaoFactory(); vreq.setAttribute("defaultNamespace", ""); //empty string triggers default new URI behavior request.setAttribute("stringDatatypeUriJson", MiscWebUtils.escape(XSD.xstring.toString())); request.setAttribute("gYearDatatypeUriJson", MiscWebUtils.escape(XSD.gYear.toString())); /* There are 4 modes that this form can be in: 1. Add, there is a subject and a predicate but no position and nothing else. 2. normal edit where everything should already be filled out. There is a subject, a object and an individual on the other end of the object's core:personInOrganization stmt. 3. Repair a bad role node. There is a subject, prediate and object but there is no individual on the other end of the object's core:personInOrganization stmt. This should be similar to an add but the form should be expanded. 4. Really bad node. multiple core:personInOrganization statements. */ EditMode mode = FrontEndEditingUtils.getEditMode(request, "http://vivoweb.org/ontology/core#positionInOrganization"); if( mode == EditMode.ADD ) { %> <% } else if(mode == EditMode.EDIT){ %> <% } else if(mode == EditMode.REPAIR){ %> <% } %> <%-- Define predicates used in n3 assertions and sparql queries --%> <%-- Assertions for adding a new role --%> ?org a ?orgType . ?org <${label}> ?orgLabel . ?position <${label}> ?positionTitle . ?position a ?positionType . @prefix core: <${vivoCore}> . ?person core:personInPosition ?position . ?position a ?positionType ; core:positionForPerson ?person ; <${positionInOrgPred}> ?org . ?org <${orgForPositionPred}> ?position . ?position <${positionInOrgPred}> ?org . ?org <${orgForPositionPred}> ?position . ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToStart}> ?startNode . ?startNode <${type}> <${dateTimeValueType}> . ?startNode <${dateTimeValue}> ?startField.value . ?startNode <${dateTimePrecision}> ?startField.precision . ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToEnd}> ?endNode . ?endNode <${type}> <${dateTimeValueType}> . ?endNode <${dateTimeValue}> ?endField.value . ?endNode <${dateTimePrecision}> ?endField.precision . <%-- Queries for editing an existing role --%> SELECT ?existingOrg WHERE { ?position <${positionInOrgPred}> ?existingOrg . } SELECT ?existingOrgLabel WHERE { ?position <${positionInOrgPred}> ?existingOrg . ?existingOrg <${label}> ?existingOrgLabel . } <%-- Limit type to subclasses of foaf:Organization. Otherwise, sometimes owl:Thing or another type is returned and we don't get a match to the select element options. --%> PREFIX rdfs: <${rdfs}> SELECT ?existingOrgType WHERE { ?position <${positionInOrgPred}> ?existingOrg . ?existingOrg a ?existingOrgType . ?existingOrgType rdfs:subClassOf <${orgClass}> . } SELECT ?existingPositionTitle WHERE { ?position <${label}> ?existingPositionTitle . } SELECT ?existingPositionType WHERE { ?position a ?existingPositionType . } SELECT ?existingIntervalNode WHERE { ?position <${positionToInterval}> ?existingIntervalNode . ?existingIntervalNode <${type}> <${intervalType}> . } SELECT ?existingStartNode WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToStart}> ?existingStartNode . ?existingStartNode <${type}> <${dateTimeValueType}> .} SELECT ?existingDateStart WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToStart}> ?startNode . ?startNode <${type}> <${dateTimeValueType}> . ?startNode <${dateTimeValue}> ?existingDateStart . } SELECT ?existingStartPrecision WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToStart}> ?startNode . ?startNode <${type}> <${dateTimeValueType}> . ?startNode <${dateTimePrecision}> ?existingStartPrecision . } SELECT ?existingEndNode WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToEnd}> ?existingEndNode . ?existingEndNode <${type}> <${dateTimeValueType}> .} SELECT ?existingEndDate WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToEnd}> ?endNode . ?endNode <${type}> <${dateTimeValueType}> . ?endNode <${dateTimeValue}> ?existingEndDate . } SELECT ?existingEndPrecision WHERE { ?position <${positionToInterval}> ?intervalNode . ?intervalNode <${type}> <${intervalType}> . ?intervalNode <${intervalToEnd}> ?endNode . ?endNode <${type}> <${dateTimeValueType}> . ?endNode <${dateTimePrecision}> ?existingEndPrecision . } ${positionClass} ${orgClass} <%-- Configure add vs. edit --%> ${editMode == "repair" ? "" : "disabled" } { "formUrl" : "${formUrl}", "editKey" : "${editKey}", "urlPatternToReturnTo" : "/entity", "subject" : ["person", "${subjectUriJson}" ], "predicate" : ["predicate", "${predicateUriJson}" ], "object" : ["position", "${objectUriJson}", "URI" ], "n3required" : [ "${n3ForNewPosition}", "${positionTitleAssertion}", "${positionTypeAssertion}", "${orgLabelAssertion}", "${orgTypeAssertion}" ], "n3optional" : [ "${n3ForStart}", "${n3ForEnd}" ], "newResources" : { "position" : "${defaultNamespace}", "org" : "${defaultNamespace}", "intervalNode" : "${defaultNamespace}", "startNode" : "${defaultNamespace}", "endNode" : "${defaultNamespace}" }, "urisInScope" : { }, "literalsInScope": { }, "urisOnForm" : [ "org", "orgType", "positionType" ], "literalsOnForm" : [ "positionTitle", "orgLabel" ], "filesOnForm" : [ ], "sparqlForLiterals" : { }, "sparqlForUris" : { }, "sparqlForExistingLiterals" : { "orgLabel" : "${orgLabelQuery}", "positionTitle" : "${positionTitleQuery}", "startField.value" : "${existingStartDateQuery}", "endField.value" : "${existingEndDateQuery}" }, "sparqlForExistingUris" : { "org" : "${orgQuery}", "orgType" : "${orgTypeQuery}", "positionType" : "${positionTypeQuery}" , "intervalNode" : "${existingIntervalNodeQuery}", "startNode" : "${existingStartNodeQuery}", "endNode" : "${existingEndNodeQuery}", "startField.precision": "${existingStartPrecisionQuery}", "endField.precision" : "${existingEndPrecisionQuery}" }, "fields" : { "positionTitle" : { "newResource" : "false", "validators" : [ "nonempty" ], "optionsType" : "UNDEFINED", "literalOptions" : [ ], "predicateUri" : "", "objectClassUri" : "", "rangeDatatypeUri" : "${stringDatatypeUriJson}", "rangeLang" : "", "assertions" : [ "${positionTitleAssertion}" ] }, "positionType" : { "newResource" : "false", "validators" : [ "nonempty" ], "optionsType" : "CHILD_VCLASSES_WITH_PARENT", "literalOptions" : [ "Select one" ], "predicateUri" : "", "objectClassUri" : "${positionClassUriJson}", "rangeDatatypeUri" : "", "rangeLang" : "", "assertions" : [ "${positionTypeAssertion}" ] }, "org" : { "newResource" : "false", "validators" : [ ], "optionsType" : "INDIVIDUALS_VIA_VCLASS", "literalOptions" : [ "Select one" ], "predicateUri" : "", "objectClassUri" : "${orgClassUriJson}", "rangeDatatypeUri" : "", "rangeLang" : "", "assertions" : [ "${n3ForPositionToOrg}" ] }, "orgLabel" : { "newResource" : "false", "validators" : [ "nonempty" ], "optionsType" : "UNDEFINED", "literalOptions" : [ ], "predicateUri" : "", "objectClassUri" : "", "rangeDatatypeUri" : "${stringDatatypeUriJson}", "rangeLang" : "", "assertions" : [ "${orgLabelAssertion}" ] }, "orgType" : { "newResource" : "false", "validators" : [ "nonempty" ], "optionsType" : "CHILD_VCLASSES", "literalOptions" : [ "Select one" ], "predicateUri" : "", "objectClassUri" : "${orgClassUriJson}", "rangeDatatypeUri" : "", "rangeLang" : "", "assertions" : [ "${orgTypeAssertion}" ] }, "startField" : { "newResource" : "false", "validators" : [ ], "optionsType" : "UNDEFINED", "literalOptions" : [ ], "predicateUri" : "", "objectClassUri" : "", "rangeDatatypeUri" : "", "rangeLang" : "", "assertions" : ["${n3ForStart}"] }, "endField" : { "newResource" : "false", "validators" : [ ], "optionsType" : "UNDEFINED", "literalOptions" : [ ], "predicateUri" : "", "objectClassUri" : "", "rangeDatatypeUri" : "", "rangeLang" : "", "assertions" : ["${n3ForEnd}"] } } } <% //log.debug(request.getAttribute("editjson")); EditConfiguration editConfig = EditConfiguration.getConfigFromSession(session,request); if (editConfig == null) { editConfig = new EditConfiguration((String) request.getAttribute("editjson")); EditConfiguration.putConfigInSession(editConfig,session); //setup date time edit elements Field startField = editConfig.getField("startField"); // arguments for DateTimeWithPrecision are (fieldName, minimumPrecision, [requiredLevel]) startField.setEditElement(new DateTimeWithPrecision(startField, VitroVocabulary.Precision.YEAR.uri(), VitroVocabulary.Precision.NONE.uri())); Field endField = editConfig.getField("endField"); endField.setEditElement(new DateTimeWithPrecision(endField, VitroVocabulary.Precision.YEAR.uri(), VitroVocabulary.Precision.NONE.uri())); editConfig.addValidator(new DateTimeIntervalValidation("startField","endField") ); } Model model = (Model) application.getAttribute("jenaOntModel"); String objectUri = (String) request.getAttribute("objectUri"); if (objectUri != null) { // editing existing editConfig.prepareForObjPropUpdate(model); } else { // adding new editConfig.prepareForNonUpdate(model); } List customJs = new ArrayList(Arrays.asList(JavaScript.JQUERY_UI.path(), JavaScript.CUSTOM_FORM_UTILS.path(), "/edit/forms/js/customFormWithAutocomplete.js" )); request.setAttribute("customJs", customJs); List customCss = new ArrayList(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(); %> <% if( mode == EditMode.ERROR ){ %>
This form is unable to handle the editing of this position because it is associated with multiple Position individuals.
<% }else{ %>

${titleVerb} position entry for <%= subjectName %>

" >

<%--

needed to create wrapper for show/hide --%>

<%-- Store these values in hidden fields, because the displayed fields are disabled and don't submit. This ensures that when returning from a validation error, we retain the values. --%>
<%-- RY maybe make this a label and input field. See what looks best. --%>

(Verify this match)

* required fields

<% } %>