All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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("");
		appendString("");
		appendString("");
		decreaseIdent();
		appendString("");
		decreaseIdent();
		appendString("
"); increaseIdent(); appendString(getFooterLink(selection, defineLinkToViewCms(view), FOOTER_SELECTION_CMS)); appendString(" | "); //appendString("Queries"); appendString(getFooterLink(selection, defineLinkToViewQueries(view), FOOTER_SELECTION_QUERIES)); decreaseIdent(); appendString(""); appendIncreasedString(""); 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("
"); 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 "+quote(alt)+"; } 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("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(""); } /** * 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