NIHVIVO-144 Finished editing/deletion of primary and additional links on front end.

This commit is contained in:
rjy7 2010-03-25 21:30:45 +00:00
parent 7a09152f53
commit 069c64d4d2
2 changed files with 56 additions and 44 deletions

View file

@ -156,7 +156,7 @@ public class PropertyEditLinks extends TagSupport{
// This is NOT the correct object property statement - we need the link individual uri in data, instead of the link URL // This is NOT the correct object property statement - we need the link individual uri in data, instead of the link URL
// Then we can combine this with doObjPropStmt // Then we can combine this with doObjPropStmt
ObjectPropertyStatement prop = new ObjectPropertyStatementImpl(subjectUri, predicateUri, data); ObjectPropertyStatement prop = new ObjectPropertyStatementImpl(subjectUri, predicateUri, data);
links = doVitroNsObjPropStmt( subjectUri, predicateUri, data, policyToAccess(ids, policy, prop), contextPath ); links = doObjPropStmt( prop, policyToAccess(ids, policy, prop), contextPath );
} }
} }
else { else {
@ -426,24 +426,8 @@ public class PropertyEditLinks extends TagSupport{
String subjectUri = opropStmt.getSubjectURI(); String subjectUri = opropStmt.getSubjectURI();
String predicateUri = opropStmt.getPropertyURI(); String predicateUri = opropStmt.getPropertyURI();
String objectUri = opropStmt.getObjectURI(); String objectUri = opropStmt.getObjectURI();
String mouseoverLabel = "relationship";
return doObjPropStmt(subjectUri, predicateUri, objectUri, allowedAccessTypeArray, contextPath, mouseoverLabel);
}
protected LinkStruct[] doVitroNsObjPropStmt(String subjectUri, String predicateUri, String objectUri, EditLinkAccess[] allowedAccessTypeArray, String contextPath) {
if( allowedAccessTypeArray == null || subjectUri == null || allowedAccessTypeArray.length == 0 ) {
log.info("null or empty access type array in doObjPropStmt for " + predicateUri);
return empty_array;
}
Model model = (Model)pageContext.getServletContext().getAttribute("jenaOntModel");
String mouseoverLabel = getObjPropMouseoverLabel(predicateUri); String mouseoverLabel = getObjPropMouseoverLabel(predicateUri);
return doObjPropStmt(subjectUri, predicateUri, objectUri, allowedAccessTypeArray, contextPath, mouseoverLabel);
}
protected LinkStruct[] doObjPropStmt(String subjectUri, String predicateUri, String objectUri, EditLinkAccess[] allowedAccessTypeArray, String contextPath, String mouseoverLabel) {
LinkStruct[] links = new LinkStruct[2]; LinkStruct[] links = new LinkStruct[2];
int index=0; int index=0;

View file

@ -2,6 +2,8 @@
<%@ page import="com.hp.hpl.jena.rdf.model.Literal" %> <%@ page import="com.hp.hpl.jena.rdf.model.Literal" %>
<%@ page import="com.hp.hpl.jena.rdf.model.Model" %> <%@ 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.beans.Individual" %>
<%@ page import="edu.cornell.mannlib.vitro.webapp.beans.VClass" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.beans.VClass" %>
<%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.EditConfiguration" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.edit.n3editing.EditConfiguration" %>
@ -10,6 +12,7 @@
<%@ page import="edu.cornell.mannlib.vitro.webapp.beans.DataProperty" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.beans.DataProperty" %>
<%@ page import="edu.cornell.mannlib.vitro.webapp.dao.DataPropertyDao" %> <%@ page import="edu.cornell.mannlib.vitro.webapp.dao.DataPropertyDao" %>
<%@ page import="edu.cornell.mannlib.vitro.webapp.dao.VitroVocabulary"%> <%@ page import="edu.cornell.mannlib.vitro.webapp.dao.VitroVocabulary"%>
<%@ page import="edu.cornell.mannlib.vitro.webapp.web.MiscWebUtils"%>
<%@ page import="java.util.List" %> <%@ page import="java.util.List" %>
@ -29,10 +32,18 @@
String propertyUri = (String) request.getAttribute("predicateUri"); String propertyUri = (String) request.getAttribute("predicateUri");
String objectUri = (String) request.getAttribute("objectUri"); String objectUri = (String) request.getAttribute("objectUri");
String stringDatatypeUriJson = MiscWebUtils.escape(XSD.xstring.toString());
String uriDatatypeUriJson = MiscWebUtils.escape(XSD.anyURI.toString());
%> %>
<c:set var="vitroUri" value="<%= VitroVocabulary.vitroURI %>" /> <c:set var="stringDatatypeUriJson" value="<%= stringDatatypeUriJson %>" />
<c:set var="uriDatatypeUriJson" value="<%= uriDatatypeUriJson %>" />
<c:set var="rdfUri" value="<%= VitroVocabulary.RDF %>" /> <c:set var="rdfUri" value="<%= VitroVocabulary.RDF %>" />
<c:set var="vitroUri" value="<%= VitroVocabulary.vitroURI %>" />
<c:set var="linkUrl" value="<%= VitroVocabulary.LINK_URL %>" />
<c:set var="linkAnchor" value="<%= VitroVocabulary.LINK_ANCHOR %>" />
<c:set var="linkDisplayRank" value="<%= VitroVocabulary.LINK_DISPLAYRANK_URL %>" />
<%-- Enter here any class names to be used for constructing INDIVIDUALS_VIA_VCLASS pick lists <%-- Enter here any class names to be used for constructing INDIVIDUALS_VIA_VCLASS pick lists
These are then referenced in the field's ObjectClassUri but not elsewhere. These are then referenced in the field's ObjectClassUri but not elsewhere.
@ -46,23 +57,30 @@
and in the literalsOnForm --%> and in the literalsOnForm --%>
<v:jsonset var="urlExisting" > <v:jsonset var="urlExisting" >
SELECT ?urlExisting SELECT ?urlExisting
WHERE { ?subject ?predicate ?urlExisting } WHERE { ?link <${linkUrl}> ?urlExisting }
</v:jsonset> </v:jsonset>
<%-- Pair the "existing" query with the skeleton of what will be asserted for a new statement involving this field. <%-- Pair the "existing" query with the skeleton of what will be asserted for a new statement involving this field.
The actual assertion inserted in the model will be created via string substitution into the ? variables. The actual assertion inserted in the model will be created via string substitution into the ? variables.
NOTE the pattern of punctuation (a period after the prefix URI and after the ?field) --%> NOTE the pattern of punctuation (a period after the prefix URI and after the ?field) --%>
<v:jsonset var="urlAssertion" > <v:jsonset var="urlAssertion" >
?subject ?predicate ?url . ?link <${linkUrl}> ?url .
</v:jsonset> </v:jsonset>
<v:jsonset var="anchorExisting" > <v:jsonset var="anchorExisting" >
PREFIX vitro: <${vitroUri}> .
SELECT ?anchorExisting SELECT ?anchorExisting
WHERE { ?link vitro:linkAnchor ?anchorExisting } WHERE { ?link <${linkAnchor}> ?anchorExisting }
</v:jsonset> </v:jsonset>
<v:jsonset var="anchorAssertion" > <v:jsonset var="anchorAssertion" >
@prefix vitro: <${vitroUri}> . ?link <${linkAnchor}> ?anchor .
?link vitro:linkAnchor ?anchor . </v:jsonset>
<%-- RY Currently display rank is always hard-coded to -1, but later we may want to enable sorting. --%>
<v:jsonset var="displayRankExisting" >
SELECT ?displayRankExisting
WHERE { ?link <${linkDisplayRank}> ?displayRankExisting }
</v:jsonset>
<v:jsonset var="displayRankAssertion" >
?link <${linkDisplayRank}> ?displayRank .
</v:jsonset> </v:jsonset>
<%-- When not retrieving a literal via a datatype property, put the SPARQL statement into <%-- When not retrieving a literal via a datatype property, put the SPARQL statement into
@ -77,16 +95,12 @@
?link rdf:type vitro:Link . ?link rdf:type vitro:Link .
?link ?link
vitro:linkURL ?url ; <${linkUrl}> ?url ;
vitro:linkAnchor ?anchor . <${linkAnchor}> ?anchor ;
<${linkDisplayRank}> ?displayRank .
</v:jsonset> </v:jsonset>
<v:jsonset var="n3Optional">
@prefix rdf: <${rdfUri}> .
?link rdf:type ?type .
</v:jsonset>
<c:set var="editjson" scope="request"> <c:set var="editjson" scope="request">
{ {
@ -99,48 +113,61 @@
"object" : ["link", "${objectUriJson}", "URI" ], "object" : ["link", "${objectUriJson}", "URI" ],
"n3required" : [ "${n3ForEdit}" ], "n3required" : [ "${n3ForEdit}" ],
"n3optional" : [ "${n3Optional}" ], "n3optional" : [ ],
"newResources" : { "link" : "${defaultNamespace}" }, "newResources" : { "link" : "${defaultNamespace}" },
"urisInScope" : { }, "urisInScope" : { },
"literalsInScope" : { }, "literalsInScope" : { },
"urisOnForm" : [ ], "urisOnForm" : [ ],
"literalsOnForm" : [ "url", "anchor" ], "literalsOnForm" : [ "url", "anchor", "displayRank" ],
"filesOnForm" : [ ], "filesOnForm" : [ ],
"sparqlForLiterals" : { }, "sparqlForLiterals" : { },
"sparqlForUris" : { }, "sparqlForUris" : { },
"sparqlForExistingLiterals" : { "sparqlForExistingLiterals" : {
"url" : "${urlExisting}", "url" : "${urlExisting}",
"anchor" : "${anchorExisting}" "anchor" : "${anchorExisting}",
"displayRank" : "${displayRankExisting}"
}, },
"sparqlForExistingUris" : { }, "sparqlForExistingUris" : { },
"fields" : { "fields" : {
"url" : { "url" : {
"newResource" : "false", "newResource" : "false",
"validators" : [ "nonempty" ], "validators" : [ "nonempty", "datatype:${uriDatatypeUriJson}" ],
"optionsType" : "UNDEFINED", "optionsType" : "UNDEFINED",
"literalOptions" : [ ], "literalOptions" : [ ],
"predicateUri" : "", "predicateUri" : "",
"objectClassUri" : "", "objectClassUri" : "",
"rangeDatatypeUri" : "", "rangeDatatypeUri" : "${uriDatatypeUriJson}",
"rangeLang" : "", "rangeLang" : "",
"assertions" : [ "${urlAssertion}" ] "assertions" : [ "${urlAssertion}" ]
}, },
"anchor" : { "anchor" : {
"newResource" : "false", "newResource" : "false",
"validators" : [ "nonempty" ], "validators" : [ "nonempty", "datatype:${stringDatatypeUriJson}" ],
"optionsType" : "UNDEFINED", "optionsType" : "UNDEFINED",
"literalOptions" : [ ], "literalOptions" : [ ],
"predicateUri" : "", "predicateUri" : "",
"objectClassUri" : "", "objectClassUri" : "",
"rangeDatatypeUri" : "", "rangeDatatypeUri" : "${stringDatatypeUriJson}",
"rangeLang" : "", "rangeLang" : "",
"assertions" : [ "${anchorAssertion}" ] "assertions" : [ "${anchorAssertion}" ]
},
"displayRank" : {
"newResource" : "false",
"validators" : [ ],
"optionsType" : "UNDEFINED",
"literalOptions" : [ ],
"predicateUri" : "",
"objectClassUri" : "",
"rangeDatatypeUri" : "${stringDatatypeUriJson}",
"rangeLang" : "",
"assertions" : [ "${displayRankAssertion}" ]
} }
} }
} }
</c:set> </c:set>
<% <%
log.debug(request.getAttribute("editjson")); log.debug(request.getAttribute("editjson"));
System.out.println(request.getAttribute("editjson"));
EditConfiguration editConfig = EditConfiguration.getConfigFromSession(session,request); EditConfiguration editConfig = EditConfiguration.getConfigFromSession(session,request);
if( editConfig == null ){ if( editConfig == null ){
@ -156,16 +183,16 @@
} }
/* get some data to make the form more useful */ /* get some data to make the form more useful */
Individual subject = (Individual)request.getAttribute("subject"); String subjectName = ((Individual)request.getAttribute("subject")).getName();
String submitLabel=""; String submitLabel="";
String title=""; String title="";
String linkType = propertyUri.equals(VitroVocabulary.PRIMARY_LINK) ? "primary" : "additional"; String linkCategory = propertyUri.equals(VitroVocabulary.PRIMARY_LINK) ? "primary" : "additional";
if (objectUri != null) { if (objectUri != null) {
title = "Edit <em>" + linkType + " link</em> for " + subject.getName(); title = "Edit <em>" + linkCategory + " link</em> for " + subjectName;
submitLabel = "Save changes"; submitLabel = "Save changes";
} else { } else {
title = "Create a new <em>" + linkType + " link</em> for " + subject.getName(); title = "Create a new <em>" + linkCategory + " link</em> for " + subjectName;
submitLabel = "Create new link"; submitLabel = "Create new link";
} }
@ -177,6 +204,7 @@
<form action="<c:url value="/edit/processRdfForm2.jsp"/>" > <form action="<c:url value="/edit/processRdfForm2.jsp"/>" >
<v:input type="text" label="URL" id="url" size="70"/> <v:input type="text" label="URL" id="url" size="70"/>
<v:input type="text" label="Link anchor text" id="anchor" size="70"/> <v:input type="text" label="Link anchor text" id="anchor" size="70"/>
<input type="hidden" name="displayRank" value="-1" />
<p class="submit"><v:input type="submit" id="submit" value="<%=submitLabel%>" cancel="${param.subjectUri}"/></p> <p class="submit"><v:input type="submit" id="submit" value="<%=submitLabel%>" cancel="${param.subjectUri}"/></p>
</form> </form>