+ }
+
+ public void list(HttpServletRequest req, HttpServletResponse res)
+ throws ServletModuleException {
+ try {
+
+ SimpleHash modelRoot = new SimpleHash();
+ EntityList theParentList;
+ EntityList theImcsList;
+ EntityList theLanguageList;
+ String offsetParam = req.getParameter("offset");
+ String where = "";
+ String offset = "";
+ PrintWriter out = res.getWriter();
+
+ // Parameter auswerten
+ String query_text = req.getParameter("query_text");
+ modelRoot.put("query_text",query_text);
+ if (query_text!=null) modelRoot.put("query_text_encoded",URLEncoder.encode(query_text));
+ String query_field = req.getParameter("query_field");
+ modelRoot.put("query_field",query_field);
+ String parent = req.getParameter("to_parent_id");
+ modelRoot.put("to_parent_id",parent);
+ String language = req.getParameter("to_language");
+ modelRoot.put("to_language",language);
+ modelRoot.put("language", getLanguage(req));
+
+ String whereClause=""; boolean isFirst=true;
+ if (query_text!=null && !query_text.equalsIgnoreCase("")) {
+ whereClause += "lower("+query_field+") like lower('%"+query_text+"%')"; isFirst=false;}
+ if (parent != null && !parent.equals("")) {
+ if (isFirst==false) whereClause+=" and ";
+ whereClause += "to_parent_id='"+parent+"'";
+ isFirst=false;
+ }
+ if (language != null && !language.equals("")) {
+ if (isFirst==false) whereClause+=" and ";
+ whereClause += "to_language='"+language+"'";
+ isFirst=false;
+ }
+
+ // hier offsetcode bearbeiten
+ if (offsetParam != null && !offsetParam.equals("")){
+ offset = offsetParam;
+ }
+ if (req.getParameter("next") != null){
+ offset= req.getParameter("nextoffset");
+ } else {
+ if (req.getParameter("prev") != null){
+ offset = req.getParameter("prevoffset");
+ }
+ }
+
+ if (offset==null || offset.equals("")) offset="0";
+ modelRoot.put("offset",(new Integer(offset)).toString());
+
+ theParentList = mainModule.getByWhereClause("to_parent_id=NULL", "title", 0, 1000);
+ theImcsList = mainModule.getByWhereClause(whereClause, "title", (new Integer(offset)).intValue());
+ theLanguageList = languageModule.getByWhereClause(null, "name", 0);
+
+ modelRoot.put("parentlist",HTMLTemplateProcessor.makeSimpleList(theParentList));
+ modelRoot.put("imcslist",HTMLTemplateProcessor.makeSimpleList(theImcsList));
+ modelRoot.put("languagelist",HTMLTemplateProcessor.makeSimpleList(theLanguageList));
+ modelRoot.put("count", (new Integer(theImcsList.getCount())).toString());
+ modelRoot.put("from", (new Integer(theImcsList.getFrom())).toString());
+ modelRoot.put("to", (new Integer(theImcsList.getTo())).toString());
+ if (theImcsList.hasNextBatch())
+ modelRoot.put("next", (new Integer(theImcsList.getNextBatch())).toString());
+ if (theImcsList.hasPrevBatch())
+ modelRoot.put("prev", (new Integer(theImcsList.getPrevBatch())).toString());
+
+ HTMLTemplateProcessor.process(res,getLanguage(req)+"/"+templateListString, modelRoot, res.getWriter());
+
+ } catch (Exception e) {
+ throw new ServletModuleException(e.toString());
+ }
+ }
+
+ public void edit(HttpServletRequest req, HttpServletResponse res)
+ throws ServletModuleException {
+ try {
+
+ SimpleHash modelRoot = new SimpleHash();
+ EntityList parentList;
+ EntityList theLanguageList;
+ int offset = 0;
+ String idParam = req.getParameter("id");
+ String where = "";
+
+ parentList = mainModule.getByWhereClause("to_parent_id=NULL", "title", offset, 1000);
+ theLanguageList = languageModule.getByWhereClause(null, "name", 0);