Adding alpha to browse widget data generation, adding JSONtoFmModel.java NIHVIVO-1674
This commit is contained in:
parent
7373e6ce67
commit
8f0b35209f
3 changed files with 239 additions and 5 deletions
|
@ -97,7 +97,7 @@ public class JSONServlet extends VitroHttpServlet {
|
||||||
log.debug("parameter vclassId URI parameter expected ");
|
log.debug("parameter vclassId URI parameter expected ");
|
||||||
throw new Exception("parameter vclassId URI parameter expected ");
|
throw new Exception("parameter vclassId URI parameter expected ");
|
||||||
}
|
}
|
||||||
rObj = getLuceneIndividualsByVClass(vclass.getURI(),req,resp,getServletContext());
|
rObj = getLuceneIndividualsByVClass(vclass.getURI(),req, getServletContext());
|
||||||
}catch(Exception ex){
|
}catch(Exception ex){
|
||||||
errorMessage = ex.toString();
|
errorMessage = ex.toString();
|
||||||
log.error(ex,ex);
|
log.error(ex,ex);
|
||||||
|
@ -126,7 +126,7 @@ public class JSONServlet extends VitroHttpServlet {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static JSONObject getLuceneIndividualsByVClass(String vclassURI, HttpServletRequest req, HttpServletResponse resp, ServletContext context) throws Exception {
|
public static JSONObject getLuceneIndividualsByVClass(String vclassURI, HttpServletRequest req, ServletContext context) throws Exception {
|
||||||
|
|
||||||
VitroRequest vreq = new VitroRequest(req);
|
VitroRequest vreq = new VitroRequest(req);
|
||||||
VClass vclass=null;
|
VClass vclass=null;
|
||||||
|
|
|
@ -0,0 +1,202 @@
|
||||||
|
package edu.cornell.mannlib.vitro.webapp.utils;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Copyright (C) 2005-2010 Alfresco Software Limited.
|
||||||
|
*
|
||||||
|
* This file is part of Alfresco
|
||||||
|
*
|
||||||
|
* Alfresco is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Alfresco is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Lesser General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Lesser General Public License
|
||||||
|
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.SortedMap;
|
||||||
|
import java.util.TreeMap;
|
||||||
|
//import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
import org.json.JSONTokener;
|
||||||
|
//import org.springframework.extensions.surf.util.ISO8601DateFormat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Utility to convert JSON to Freemarker-compatible data model
|
||||||
|
*
|
||||||
|
* @author janv
|
||||||
|
*/
|
||||||
|
public final class JSONtoFmModel
|
||||||
|
{
|
||||||
|
public static String ROOT_ARRAY = "root";
|
||||||
|
|
||||||
|
// note: current format is dependent on ISO8601DateFormat.parser, eg. YYYY-MM-DDThh:mm:ss.sssTZD
|
||||||
|
// private static String REGEXP_ISO8061 = "^([0-9]{4})-([0-9]{2})-([0-9]{2})T([0-9]{2}):([0-9]{2}):([0-9]{2})(.([0-9]){3})?(Z|[\\+\\-]([0-9]{2}):([0-9]{2}))$";
|
||||||
|
// private static Pattern matcherISO8601 = Pattern.compile(REGEXP_ISO8061);
|
||||||
|
//
|
||||||
|
// public static boolean autoConvertISO8601 = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert JSON Object string to Freemarker-compatible data model
|
||||||
|
*
|
||||||
|
* @param jsonString
|
||||||
|
* @return model
|
||||||
|
* @throws JSONException
|
||||||
|
*/
|
||||||
|
public static Map<String, Object> convertJSONObjectToMap(String jsonString) throws JSONException
|
||||||
|
{
|
||||||
|
JSONObject jo = new JSONObject(new JSONTokener(jsonString));
|
||||||
|
return convertJSONObjectToMap(jo);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* JSONObject is an unordered collection of name/value pairs -> convert to Map (equivalent to Freemarker "hash")
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
public static Map<String, Object> convertJSONObjectToMap(JSONObject jo) throws JSONException
|
||||||
|
{
|
||||||
|
Map<String, Object> model = new HashMap<String, Object>();
|
||||||
|
|
||||||
|
Iterator<String> itr = (Iterator<String>)jo.keys();
|
||||||
|
while (itr.hasNext())
|
||||||
|
{
|
||||||
|
String key = (String)itr.next();
|
||||||
|
|
||||||
|
Object o = jo.get(key);
|
||||||
|
if (o instanceof JSONObject)
|
||||||
|
{
|
||||||
|
model.put(key, convertJSONObjectToMap((JSONObject)o));
|
||||||
|
}
|
||||||
|
else if (o instanceof JSONArray)
|
||||||
|
{
|
||||||
|
model.put(key, convertJSONArrayToList((JSONArray)o));
|
||||||
|
}
|
||||||
|
else if (o == JSONObject.NULL)
|
||||||
|
{
|
||||||
|
model.put(key, null); // note: http://freemarker.org/docs/dgui_template_exp.html#dgui_template_exp_missing
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// if ((o instanceof String) && autoConvertISO8601 && (matcherISO8601.matcher((String)o).matches()))
|
||||||
|
// {
|
||||||
|
// o = ISO8601DateFormat.parse((String)o);
|
||||||
|
// }
|
||||||
|
|
||||||
|
model.put(key, o);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert JSON Array string to Freemarker-compatible data model
|
||||||
|
*
|
||||||
|
* @param jsonString
|
||||||
|
* @return model
|
||||||
|
* @throws JSONException
|
||||||
|
*/
|
||||||
|
public static Map<String, Object> convertJSONArrayToMap(String jsonString) throws JSONException
|
||||||
|
{
|
||||||
|
Map<String, Object> model = new HashMap<String, Object>();
|
||||||
|
JSONArray ja = new JSONArray(new JSONTokener(jsonString));
|
||||||
|
model.put(ROOT_ARRAY, convertJSONArrayToList(ja));
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* JSONArray is an ordered sequence of values -> convert to List (equivalent to Freemarker "sequence")
|
||||||
|
*/
|
||||||
|
public static List<Object> convertJSONArrayToList(JSONArray ja) throws JSONException
|
||||||
|
{
|
||||||
|
List<Object> model = new ArrayList<Object>();
|
||||||
|
|
||||||
|
for (int i = 0; i < ja.length(); i++)
|
||||||
|
{
|
||||||
|
Object o = ja.get(i);
|
||||||
|
|
||||||
|
if (o instanceof JSONArray)
|
||||||
|
{
|
||||||
|
model.add(convertJSONArrayToList((JSONArray)o));
|
||||||
|
}
|
||||||
|
else if (o instanceof JSONObject)
|
||||||
|
{
|
||||||
|
model.add(convertJSONObjectToMap((JSONObject)o));
|
||||||
|
}
|
||||||
|
else if (o == JSONObject.NULL)
|
||||||
|
{
|
||||||
|
model.add(null);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// if ((o instanceof String) && autoConvertISO8601 && (matcherISO8601.matcher((String)o).matches()))
|
||||||
|
// {
|
||||||
|
// o = ISO8601DateFormat.parse((String)o);
|
||||||
|
// }
|
||||||
|
|
||||||
|
model.add(o);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return model;
|
||||||
|
}
|
||||||
|
|
||||||
|
// for debugging only
|
||||||
|
public static String toString(Map<String, Object> map)
|
||||||
|
{
|
||||||
|
return JSONtoFmModel.toStringBuffer(map, 0).toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
private static StringBuffer toStringBuffer(Map<String, Object> unsortedMap, int indent)
|
||||||
|
{
|
||||||
|
StringBuffer tabs = new StringBuffer();
|
||||||
|
for (int i = 0; i < indent; i++)
|
||||||
|
{
|
||||||
|
tabs.append("\t");
|
||||||
|
}
|
||||||
|
|
||||||
|
StringBuffer sb = new StringBuffer();
|
||||||
|
|
||||||
|
SortedMap<String, Object> map = new TreeMap<String, Object>();
|
||||||
|
map.putAll(unsortedMap);
|
||||||
|
|
||||||
|
for (Map.Entry<String, Object> entry : map.entrySet())
|
||||||
|
{
|
||||||
|
if (entry.getValue() instanceof Map)
|
||||||
|
{
|
||||||
|
sb.append(tabs).append(entry.getKey()).append(":").append(entry.getValue().getClass()).append("\n");
|
||||||
|
sb.append(JSONtoFmModel.toStringBuffer((Map<String, Object>)entry.getValue(), indent+1));
|
||||||
|
}
|
||||||
|
else if (entry.getValue() instanceof List)
|
||||||
|
{
|
||||||
|
sb.append(tabs).append("[\n");
|
||||||
|
List l = (List)entry.getValue();
|
||||||
|
for (int i = 0; i < l.size(); i++)
|
||||||
|
{
|
||||||
|
sb.append(tabs).append(l.get(i)).append(":").append((l.get(i) != null) ? l.get(i).getClass() : "null").append("\n");
|
||||||
|
}
|
||||||
|
sb.append(tabs).append("]\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sb.append(tabs).append(entry.getKey()).append(":").append(entry.getValue()).append(":").append((entry.getValue() != null ? entry.getValue().getClass() : "null")).append("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return sb;
|
||||||
|
}
|
||||||
|
}
|
|
@ -13,13 +13,17 @@ import javax.servlet.http.HttpServletRequest;
|
||||||
|
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
|
import org.json.JSONArray;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
import edu.cornell.mannlib.vitro.webapp.beans.Individual;
|
import edu.cornell.mannlib.vitro.webapp.beans.Individual;
|
||||||
import edu.cornell.mannlib.vitro.webapp.beans.VClass;
|
import edu.cornell.mannlib.vitro.webapp.beans.VClass;
|
||||||
import edu.cornell.mannlib.vitro.webapp.beans.VClassGroup;
|
import edu.cornell.mannlib.vitro.webapp.beans.VClassGroup;
|
||||||
|
import edu.cornell.mannlib.vitro.webapp.controller.JSONServlet;
|
||||||
import edu.cornell.mannlib.vitro.webapp.controller.VitroRequest;
|
import edu.cornell.mannlib.vitro.webapp.controller.VitroRequest;
|
||||||
import edu.cornell.mannlib.vitro.webapp.controller.freemarker.FreemarkerHttpServlet;
|
import edu.cornell.mannlib.vitro.webapp.controller.freemarker.FreemarkerHttpServlet;
|
||||||
import edu.cornell.mannlib.vitro.webapp.dao.jena.VClassGroupCache;
|
import edu.cornell.mannlib.vitro.webapp.dao.jena.VClassGroupCache;
|
||||||
|
import edu.cornell.mannlib.vitro.webapp.utils.JSONtoFmModel;
|
||||||
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.VClassGroupTemplateModel;
|
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.VClassGroupTemplateModel;
|
||||||
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.VClassTemplateModel;
|
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.VClassTemplateModel;
|
||||||
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.individual.ListedIndividualTemplateModel;
|
import edu.cornell.mannlib.vitro.webapp.web.templatemodels.individual.ListedIndividualTemplateModel;
|
||||||
|
@ -40,6 +44,7 @@ public class BrowseWidget extends Widget {
|
||||||
protected WidgetTemplateValues process(Environment env, Map params,
|
protected WidgetTemplateValues process(Environment env, Map params,
|
||||||
HttpServletRequest request, ServletContext context) throws Exception
|
HttpServletRequest request, ServletContext context) throws Exception
|
||||||
{
|
{
|
||||||
|
try{
|
||||||
Mode mode = getMode( request, params );
|
Mode mode = getMode( request, params );
|
||||||
switch( mode ){
|
switch( mode ){
|
||||||
case VCLASS_ALPHA:
|
case VCLASS_ALPHA:
|
||||||
|
@ -53,13 +58,40 @@ public class BrowseWidget extends Widget {
|
||||||
default:
|
default:
|
||||||
return doAllClassGroupsDisplay(env, params, request, context);
|
return doAllClassGroupsDisplay(env, params, request, context);
|
||||||
}
|
}
|
||||||
|
}catch(Throwable th){
|
||||||
|
log.error(th,th);
|
||||||
|
//should we return an error here?
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private WidgetTemplateValues doClassAlphaDisplay(Environment env,
|
private WidgetTemplateValues doClassAlphaDisplay(Environment env,
|
||||||
Map params, HttpServletRequest request, ServletContext context) {
|
Map params, HttpServletRequest request, ServletContext context) throws Exception {
|
||||||
// TODO Auto-generated method stub
|
Map<String,Object> body = new HashMap<String,Object>();
|
||||||
|
body.putAll(getCommonValues(env,context));
|
||||||
|
body.putAll(getClassAlphaValues(env,params,request,context));
|
||||||
|
|
||||||
return null;
|
String macroName = Mode.VCLASS_ALPHA.macroName;
|
||||||
|
return new WidgetTemplateValues(macroName, body);
|
||||||
|
}
|
||||||
|
|
||||||
|
private Map<String,Object> getClassAlphaValues(Environment env, Map params, HttpServletRequest request, ServletContext context) throws Exception{
|
||||||
|
Map<String,Object> map= new HashMap<String,Object>();
|
||||||
|
|
||||||
|
String classUri = getParam(Mode.VCLASS, request, params);
|
||||||
|
VitroRequest vreq = new VitroRequest(request);
|
||||||
|
VClass vclass = vreq.getWebappDaoFactory().getVClassDao().getVClassByURI(classUri);
|
||||||
|
map.put("class", new VClassTemplateModel(vclass));
|
||||||
|
|
||||||
|
JSONObject vclassRes = JSONServlet.getLuceneIndividualsByVClass(vclass.getURI(), request, context);
|
||||||
|
map.put("vclass", JSONtoFmModel.convertJSONObjectToMap( (JSONObject) vclassRes.get("vclass") ));
|
||||||
|
map.put("totalCount", JSONtoFmModel.convertJSONObjectToMap( (String) vclassRes.get("totalCount") ));
|
||||||
|
map.put("alpha", JSONtoFmModel.convertJSONObjectToMap( (String) vclassRes.get("alpha") ));
|
||||||
|
map.put("individuals", JSONtoFmModel.convertJSONArrayToList( (JSONArray) vclassRes.get("individuals") ));
|
||||||
|
map.put("pages", JSONtoFmModel.convertJSONArrayToList( (JSONArray) vclassRes.get("pages") ));
|
||||||
|
map.put("letters", JSONtoFmModel.convertJSONArrayToList( (JSONArray) vclassRes.get("letters") ));
|
||||||
|
|
||||||
|
return map;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Map<String,Object> getCommonValues(Environment env, ServletContext context){
|
private Map<String,Object> getCommonValues(Environment env, ServletContext context){
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue