net.anotheria.asg.generator.view.jsp.AbstractJSPGenerator Maven / Gradle / Ivy
package net.anotheria.asg.generator.view.jsp;
import net.anotheria.asg.generator.*;
import net.anotheria.asg.generator.meta.MetaContainerProperty;
import net.anotheria.asg.generator.meta.MetaDocument;
import net.anotheria.asg.generator.meta.MetaModule;
import net.anotheria.asg.generator.view.CMSMappingsConfiguratorGenerator;
import net.anotheria.asg.generator.view.meta.MetaDialog;
import net.anotheria.asg.generator.view.meta.MetaModuleSection;
import net.anotheria.asg.generator.view.meta.MetaSection;
import net.anotheria.asg.generator.view.meta.MetaView;
import net.anotheria.util.ArrayUtils;
import net.anotheria.util.StringUtils;
import java.util.List;
/**
* Generator for the JSP files used for generations of the view jsps.
* @author lrosenberg
*/
public abstract class AbstractJSPGenerator extends AbstractGenerator{
/**
* Captions for the Queries link in the footer.
*/
public static final String FOOTER_SELECTION_QUERIES = "Queries";
/**
* Caption for the CMS link in the footer.
*/
public static final String FOOTER_SELECTION_CMS = "CMS";
/*
* The context for the generation.
*/
// private Context context;
@Override
protected void appendCommentLine(String commentLine){
appendString("<%-- " + commentLine + " --%>");
}
/**
* Generates the header for all jsp files.
* @return
*/
protected String getBaseJSPHeader(){
String ret = "";
ret += "<%-- generated by AbstractJSPGenerator.getBaseJSPHeader --%>"+CRLF;
ret += "<%@ page"+CRLF;
ret += "\tcontentType=\"text/html;charset="+GeneratorDataRegistry.getInstance().getContext().getEncoding()+"\" session=\"true\""+CRLF;
ret += "%><%@ taglib uri=\"http://www.anotheria.net/ano-tags\" prefix=\"ano\""+CRLF;
ret += "%><%@ taglib uri=\"/WEB-INF/tlds/anosite.tld\" prefix=\"as\""+CRLF;
ret += "%><%@ page isELIgnored =\"false\" %>"+CRLF;
ret += "<%-- / generated by AbstractJSPGenerator.getBaseJSPHeader --%>"+CRLF;
return ret;
}
/**
* Generates the header for jsp files that generate xml exports.
* @return
*/
protected String getBaseXMLHeader(){
String ret = "";
ret += "<%@ page"+CRLF;
ret += "\tcontentType=\"text/xml;charset="+GeneratorDataRegistry.getInstance().getContext().getEncoding()+"\" session=\"true\""+CRLF;
ret += "%><%@ taglib uri=\"http://www.anotheria.net/ano-tags\" prefix=\"ano\""+CRLF;
ret += "%><%@ taglib uri=\"/WEB-INF/tld/ano-tags-xml.tld\" prefix=\"ano-xml\""+CRLF;
ret += "%>";
return ret;
}
/**
* Generates the header for jsp files that generate csv exports.
* @return
*/
protected String getBaseCSVHeader(){
String ret = "";
ret += "<%@ page"+CRLF;
ret += "\tcontentType=\"application/msexcel;charset="+GeneratorDataRegistry.getInstance().getContext().getEncoding()+"\" session=\"true\""+CRLF;
ret += "%><%@ taglib uri=\"http://www.anotheria.net/ano-tags\" prefix=\"ano\""+CRLF;
ret += "%>";
return ret;
}
private String getFooterLink(String selection, String link, String linkCaption){
if (selection!=null && selection.equals(linkCaption)){
return ""+linkCaption+"";
}
return " "+link+"\">"+linkCaption+"";
}
/**
* Generates a footer file which is included by other jsps.
* @param view the vie to generate the footer for.
* @param selection ?
* @param name the name of the file.
* @return
*/
protected GeneratedJSPFile generateFooter(MetaView view, String selection, String name){
GeneratedJSPFile jsp = new GeneratedJSPFile();
startNewJob(jsp);
jsp.setPackage(GeneratorDataRegistry.getInstance().getContext().getPackageName(MetaModule.SHARED)+".jsp");
jsp.setName(name);
append(getBaseJSPHeader());
appendString("");
increaseIdent();
appendString("");
increaseIdent();
appendString("");
increaseIdent();
appendString(getFooterLink(selection, defineLinkToViewCms(view), FOOTER_SELECTION_CMS));
appendString(" | ");
//appendString("Queries");
appendString(getFooterLink(selection, defineLinkToViewQueries(view), FOOTER_SELECTION_QUERIES));
decreaseIdent();
appendString(" ");
appendString("");
appendIncreasedString(" ");
appendString(" ");
appendString("");
increaseIdent();
appendString("Generated by "+Generator.getProductString()+" V "+Generator.getVersionString());
//String timestamp = NumberUtils.makeISO8601TimestampString(System.currentTimeMillis());
String timestamp = "Timestamp unset";
appendString(" on "+timestamp+" | ");
appendString("logout\">Logout ");
decreaseIdent();
appendString(" ");
decreaseIdent();
appendString(" ");
decreaseIdent();
appendString("
");
append(getBaseJSPFooter());
return jsp;
}
private String defineLinkToViewQueries(MetaView view){
String ret = "#";
List sections = view.getSections();
for (int i=0; i0){
return CMSMappingsConfiguratorGenerator.getShowQueriesPath(targetDoc);
}
}
}
return ret;
}
/**
* Returns image tag for the duplicate entry image.
* @return
*/
protected String getDuplicateImage(){
return getDuplicateImage("duplicate");
}
private String defineLinkToViewCms(MetaView view){
String ret = "#";
List sections = view.getSections();
for (int i=0; i";
return ret;
}
/**
* Returns the name of the jsp file for the show page for the document.
* @param doc
* @return
*/
public static String getShowPageName(MetaDocument doc){
return "Show"+doc.getMultiple();
}
public static String getSearchResultPageName(){
return "SearchResult";
}
/**
* Returns the page name for the version info page.
* @return
*/
public static String getVersionInfoPageName(){
return "VersionInfo";
}
/**
* Returns the page name for the version info page for the given document.
* @return
*/
public static String getVersionInfoPageName(MetaDocument doc){
return getVersionInfoPageName();
}
public static String getShowQueriesPageName(MetaDocument doc){
return "Show"+doc.getMultiple()+"Queries";
}
/**
* Returns the name of the jsp file for the csv page export for the document.
* @return
*/
public static String getExportAsCSVPageName(MetaDocument doc){
return "Show"+doc.getMultiple()+"AsCSV";
}
/**
* Returns the name of the jsp file for the xml page export for the document.
* @return
*/
public static String getExportAsXMLPageName(MetaDocument doc){
return "Show"+doc.getMultiple()+"AsXML";
}
/**
* Returns the name of the edit page for this document.
* @return
*/
public static String getEditPageName(MetaDocument doc){
return "Edit"+doc.getName();
}
public static String getDialogName(MetaDialog dialog, MetaDocument doc){
return dialog.getName()+doc.getName();
}
public static String getLinksToMePageName(MetaDocument doc){
return "LinksTo"+doc.getName();
}
public static String getContainerPageName(MetaDocument doc, MetaContainerProperty table){
return "Show"+doc.getName()+StringUtils.capitalize(table.getName());
}
protected static String generateTimestampedLinkPath(String path){
return ""+path+" ";
}
protected String getCurrentImagePath(String imageName){
return getImagePath(imageName, GeneratorDataRegistry.getInstance().getContext());
}
public static String getImagePath(String imageName, Context context){
return context.getApplicationURLPath()+"/img/"+imageName;
}
protected String getCurrentCSSPath(String stylesheetName){
return getCSSPath(stylesheetName, GeneratorDataRegistry.getInstance().getContext());
}
protected String getCurrentJSPath(String jsName){
return getJSPath(jsName, GeneratorDataRegistry.getInstance().getContext());
}
protected String getCurrentYUIPath(String yuiName){
return getYUIPath(yuiName, GeneratorDataRegistry.getInstance().getContext());
}
protected String getCurrentJavaScriptPath(String javaScript){
return getJavaScriptPath(javaScript, GeneratorDataRegistry.getInstance().getContext());
}
public static String getCSSPath(String stylesheetName, Context context){
return context.getApplicationURLPath()+"/cms_static/css/"+stylesheetName;
}
public static String getJSPath(String jsName, Context context){
return context.getApplicationURLPath()+"/cms_static/js/"+jsName;
}
public static String getJavaScriptPath(String javaScript, Context context){
return context.getApplicationURLPath()+"/cms_static/js/"+javaScript;
}
public static String getYUIPath(String yuiName, Context context){
return context.getApplicationURLPath()+"/cms_static/yui/"+yuiName;
}
public static String getPackage(MetaModule mod){
return GeneratorDataRegistry.getInstance().getContext().getJspPackageName(mod);
}
public static String getPackage(MetaDocument doc){
return GeneratorDataRegistry.getInstance().getContext().getJspPackageName(doc);
}
/**
* Returns the tag for the delete image in the overview.
* @return
*/
protected String getDeleteImage(){
return getDeleteImage("delete");
}
/**
* Returns the tag for the preview image in the overview.
* @return
*/
protected String getPreviewImage(){
return getPreviewImage("preview");
}
/**
* Returns the tag for the version info image in the overview. Note: for now it returns a 'V' text.
* @return
*/
protected String getVersionImage(){
return getVersionImage("version");//getDeleteImage("delete");
}
/**
* Returns the tag for the edit image in the overview.
* @return
*/
protected String getEditImage(){
return getEditImage("edit");
}
/**
* Returns the tag for the Version in the overview with the given alt tag.
* @return
*/
protected String getVersionImage(String alt){
return getImage("version",alt);
}
/**
* Returns the tag for the delete image in the overview with the given alt tag.
* @return
*/
protected String getDeleteImage(String alt){
return getImage("delete",alt);
}
/**
* Returns the tag for the preview image in the overview with the given alt tag.
* @return
*/
protected String getPreviewImage(String alt){
return getImage("preview",alt);
}
/**
* Returns the tag for the lock image in the overview.
* @return created image tag
*/
protected String getLockImage(){
return getLockImage("lock");
}
/**
* Returns the tag for the lock image in the overview.
* @return created image tag
*/
protected String getUnLockImage(){
return getUnLockImage("unlock");
}
/**
* Returns the tag for the lock image in the overview with the given alt tag.
* @param alt actually alt - for the image tag
* @return created image tag
*/
protected String getLockImage(String alt){
return getImage("lock",alt);
}
/**
* Returns the tag for the unLock image in the overview with the given alt tag.
* @param alt actually alt for image tag
* @return created image tag
*/
protected String getUnLockImage(String alt){
return getImage("unlock",alt);
}
/**
* Returns the tag for the move to the top image in the list view with the given alt tag.
* @return
*/
protected String getTopImage(String alt){
return getImage("top",alt);
}
/**
* Returns the tag for the move to the bottom image in the list view with the given alt tag.
* @return
*/
protected String getBottomImage(String alt){
return getImage("bottom",alt);
}
/**
* Returns the tag for the move up image in the list view with the given alt tag.
* @return
*/
protected String getUpImage(String alt){
return getImage("up",alt);
}
/**
* Returns the tag for the move down image in the list view with the given alt tag.
* @return
*/
protected String getDownImage(String alt){
return getImage("down",alt);
}
/**
* Returns the tag for the duplicate image in the overview with the given alt tag.
* @return
*/
protected String getDuplicateImage(String alt){
return getImage("clone",alt);
}
protected String getEditImage(String alt){
return getImage("edit_icon",alt);
}
/**
* Returns the img tag to embed an image into the jsp.
* @param name name of the gif file containing the image.
* @param alt alternative description (alt tag).
* @return
*/
protected String getImage(String name, String alt){
return "";
}
public Context getContext() {
return GeneratorDataRegistry.getInstance().getContext();
}
/**
* Generates pragmas for a given view.
* @param view the view to generate pragmas for.
*/
protected void generatePragmas(MetaView view){
generatePragmas();
}
/**
* Generates generic pragmas.
* Adds the generated content to the current job.
*/
protected void generatePragmas(){
appendString("");
appendString("");
appendString("");
appendString("");
}
protected void openTag(String tag, String params){
appendString("<"+tag+(params.length()>0 ? " ":"")+params+">");
}
protected void closeTag(String tag, String params){
appendString(""+tag+(params.length()>0 ? " ":"")+params+">");
}
protected void openTR(String additionalParams){
openTag("tr", additionalParams);
increaseIdent();
}
protected void closeTR(String additionalParams){
decreaseIdent();
closeTag("tr", additionalParams);
}
protected void openTR(){
openTR("");
}
protected void closeTR(){
closeTR("");
}
/**
* Opens a table cell.
*/
protected void openTD(){
openTD("");
}
protected void closeTD(){
closeTD("");
}
/**
* Opens a table cell.
* @param additionalParams additional parameters.
*/
protected void openTD(String additionalParams){
openTag("td", additionalParams);
}
protected void closeTD(String additionalParams){
closeTag("td", additionalParams);
}
/**
* Appends to generation output tag without body.
* @param tag tag name
* @param id html id attribute
* @param clazz html class attribute
* @param attrs array of tag attributes
*/
protected void tag(String tag, String id, String clazz, TagAttribute... attrs){
attrs = ArrayUtils.mergeArrays(new TagAttribute[]{new TagAttribute("id", id), new TagAttribute("class", clazz)}, attrs);
tag(tag, attrs);
}
/**
* Appends to generation output tag without body.
* @param tag tag name
* @param clazz html class attribute
* @param attrs array of tag attributes
*/
protected void tag(String tag, String clazz, TagAttribute... attrs){
attrs = ArrayUtils.mergeArrays(new TagAttribute[]{new TagAttribute("class", clazz)}, attrs);
tag(tag, attrs);
}
/**
* Appends to generation output tag without body.
* @param tag tag name
* @param attrs array of tag attributes
*/
protected void tag(String tag, TagAttribute... attrs){
StringBuilder attrsStr = new StringBuilder();
for(TagAttribute attr:attrs)
attrsStr.append(' ' + attr.toString());
appendString("<"+tag, attrsStr.toString(), "/>");
}
/**
* Appends to generation output opening for tag.
* @param tag tag name
* @param id html id attribute
* @param clazz html class attribute
* @param attrs array of tag attributes
*/
protected void tagOpen(String tag, String id, String clazz, TagAttribute... attrs){
attrs = ArrayUtils.mergeArrays(new TagAttribute[]{new TagAttribute("id", id), new TagAttribute("class", clazz)}, attrs);
tagOpen(tag, attrs);
}
/**
* Appends to generation output opening for tag.
* @param tag tag name
* @param clazz html class attribute
* @param attrs array of tag attributes
*/
protected void tagOpen(String tag, String clazz, TagAttribute... attrs){
attrs = ArrayUtils.mergeArrays(new TagAttribute[]{new TagAttribute("class", clazz)}, attrs);
tagOpen(tag, attrs);
}
/**
* Appends to generation output opening for tag.
* @param tag tag name
* @param attrs array of tag attributes
*/
protected void tagOpen(String tag, TagAttribute... attrs){
StringBuilder attrsStr = new StringBuilder();
for(TagAttribute attr:attrs)
attrsStr.append(' ' + attr.toString());
appendString("<"+tag, attrsStr.toString(), ">");
increaseIdent();
}
/**
* Appends to generation output closing for tag.
* @param tag tag name
*/
protected void tagClose(String tag){
decreaseIdent();
appendString(""+tag+">");
}
/**
* Appends to generation output script tag with type javascript.
*/
protected void openJavaScript(){
tagOpen("script", new TagAttribute("type", "text/javascript"));
}
/**
* Appends to generation output script tag closing.
*/
protected void closeJavaScript(){
tagClose("script");
}
/**
* HTML/JSP tag attribute object representation.
* @author denis
*
*/
protected static class TagAttribute{
/**
* attr name.
*/
private String name;
/**
* attr value.
*/
private String value;
public TagAttribute(String aName, String aValue) {
name = aName;
value = aValue;
}
@Override public String toString(){
return StringUtils.isEmpty(value)? name: name + "=" + '"' + value + '"';
}
}
protected String getTopMenuPage(){
return "../../shared/jsp/"+MenuJspGenerator.getMenuPageName();
}
protected String getMenuName(MetaView view){
return "../../shared/jsp/"+StringUtils.capitalize(view.getName())+"Menu";
}
protected String getFooterName(MetaView view){
return "../../shared/jsp/"+StringUtils.capitalize(view.getName())+"Footer";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy