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

com.aoindustries.website.Skin Maven / Gradle / Ivy

/*
 * aoweb-struts-core - Core API for legacy Struts-based site framework with AOServ Platform control panels.
 * Copyright (C) 2007-2013, 2015, 2016  AO Industries, Inc.
 *     [email protected]
 *     7262 Bull Pen Cir
 *     Mobile, AL 36695
 *
 * This file is part of aoweb-struts-core.
 *
 * aoweb-struts-core 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.
 *
 * aoweb-struts-core 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 aoweb-struts-core.  If not, see .
 */
package com.aoindustries.website;

import static com.aoindustries.encoding.TextInXhtmlAttributeEncoder.encodeTextInXhtmlAttribute;
import com.aoindustries.net.UrlUtils;
import com.aoindustries.website.skintags.PageAttributes;
import java.io.IOException;
import java.util.List;
import java.util.Locale;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.JspWriter;
import org.apache.struts.util.MessageResources;

/**
 * One look-and-feel for the website.
 *
 * @author  AO Industries, Inc.
 */
abstract public class Skin {

	/**
	 * Directional references.
	 */
	public static final int
		NONE=0,
		UP=1,
		DOWN=2,
		UP_AND_DOWN=3
	;

	/**
	 * Provides the correct character set for the given locale.
	 */
	static public String getCharacterSet(Locale locale) {
		/*if(locale!=null && locale.getLanguage().equals(Locale.JAPANESE.getLanguage())) {
			//return "euc-jp";
			return "Shift_JIS";
		} else {*/
			// return "iso-8859-1";
			return "UTF-8";
		//}
	}

	/**
	 * Prints the links to the alternate translations of this page.
	 *
	 * {@link https://support.google.com/webmasters/answer/189077?hl=en}
	 */
	public static void printAlternativeLinks(HttpServletResponse resp, Appendable out, String fullPath, List languages) throws IOException {
		if(languages.size()>1) {
			// Default language
			{
				Language language = languages.get(0);
				out.append("    \n");
			}
			// All languages
			for(Language language : languages) {
				out.append("    \n");
			}
		}
	}

	/**
	 * Gets the name of this skin.
	 */
	abstract public String getName();

	/**
	 * Gets the display value for this skin in the provided locale.
	 */
	abstract public String getDisplay(HttpServletRequest req) throws JspException;

	/**
	 * Gets the prefix for URLs for the non-SSL server.  This should always end with a /.
	 */
	public static String getDefaultUrlBase(HttpServletRequest req) throws JspException {
		int port = req.getServerPort();
		String contextPath = req.getContextPath();
		if(port!=80 && port!=443) {
			if(req.isSecure()) {
				// SSL development area
				return "https://"+req.getServerName()+":11156"+contextPath+"/";
			} else {
				// Non-SSL development area
				return "http://"+req.getServerName()+":8086"+contextPath+"/";
			}
		} else {
			if(req.isSecure()) {
				return "https://"+req.getServerName()+contextPath+"/";
			} else {
				return "http://"+req.getServerName()+contextPath+"/";
			}
		}
	}

	/**
	 * Gets the prefix for URLs for the server.  This should always end with a /.
	 */
	public String getUrlBase(HttpServletRequest req) throws JspException {
		return getDefaultUrlBase(req);
	}

	/**
	 * Writes the contents between the HTML tag and the page content (not including the HTML tag itself).
	 */
	abstract public void startSkin(HttpServletRequest req, HttpServletResponse resp, JspWriter out, PageAttributes pageAttributes) throws JspException;

	/**
	 * Starts the content area of a page.  The content area provides additional features such as a nice border, and vertical and horizontal dividers.
	 */
	abstract public void startContent(HttpServletRequest req, HttpServletResponse resp, JspWriter out, PageAttributes pageAttributes, int[] colspans, String width) throws JspException;

	/**
	 * Prints an entire content line including the provided title.  The colspan should match the total colspan in startContent for proper appearance
	 */
	abstract public void printContentTitle(HttpServletRequest req, HttpServletResponse resp, JspWriter out, String title, int colspan) throws JspException;

	/**
	 * Starts one line of content with the initial colspan set to the provided colspan.
	 */
	abstract public void startContentLine(HttpServletRequest req, HttpServletResponse resp, JspWriter out, int colspan, String align, String width) throws JspException;

	/**
	 * Starts one line of content with the initial colspan set to the provided colspan.
	 */
	abstract public void printContentVerticalDivider(HttpServletRequest req, HttpServletResponse resp, JspWriter out, boolean visible, int colspan, int rowspan, String align, String width) throws JspException;

	/**
	 * Ends one line of content.
	 */
	abstract public void endContentLine(HttpServletRequest req, HttpServletResponse resp, JspWriter out, int rowspan, boolean endsInternal) throws JspException;

	/**
	 * Prints a horizontal divider of the provided colspans.
	 */
	abstract public void printContentHorizontalDivider(HttpServletRequest req, HttpServletResponse resp, JspWriter out, int[] colspansAndDirections, boolean endsInternal) throws JspException;

	/**
	 * Ends the content area of a page.
	 */
	abstract public void endContent(HttpServletRequest req, HttpServletResponse resp, JspWriter out, PageAttributes pageAttributes, int[] colspans) throws JspException;

	/**
	 * Writes the contents between the page content and the HTML tag (not including the HTML tag itself).
	 */
	abstract public void endSkin(HttpServletRequest req, HttpServletResponse resp, JspWriter out, PageAttributes pageAttributes) throws JspException;

	/**
	 * Begins a light area.
	 */
	abstract public void beginLightArea(HttpServletRequest req, HttpServletResponse resp, JspWriter out, String width, boolean nowrap) throws JspException;

	/**
	 * Ends a light area.
	 */
	abstract public void endLightArea(HttpServletRequest req, HttpServletResponse resp, JspWriter out) throws JspException;

	/**
	 * Begins a white area.
	 */
	abstract public void beginWhiteArea(HttpServletRequest req, HttpServletResponse resp, JspWriter out, String width, boolean nowrap) throws JspException;

	/**
	 * Ends a white area.
	 */
	abstract public void endWhiteArea(HttpServletRequest req, HttpServletResponse resp, JspWriter out) throws JspException;

	public static class Language {
		private final String code;
		private final String displayResourcesKey;
		private final String displayKey;
		private final String flagOnSrcResourcesKey;
		private final String flagOnSrcKey;
		private final String flagOffSrcResourcesKey;
		private final String flagOffSrcKey;
		private final String flagWidthResourcesKey;
		private final String flagWidthKey;
		private final String flagHeightResourcesKey;
		private final String flagHeightKey;
		private final String url;

		/**
		 * @param url the constant URL to use or null to have automatically set.
		 */
		public Language(
			String code,
			String displayResourcesKey,
			String displayKey,
			String flagOnSrcResourcesKey,
			String flagOnSrcKey,
			String flagOffSrcResourcesKey,
			String flagOffSrcKey,
			String flagWidthResourcesKey,
			String flagWidthKey,
			String flagHeightResourcesKey,
			String flagHeightKey,
			String url
		) {
			this.code = code;
			this.displayResourcesKey = displayResourcesKey;
			this.displayKey = displayKey;
			this.flagOnSrcResourcesKey = flagOnSrcResourcesKey;
			this.flagOnSrcKey = flagOnSrcKey;
			this.flagOffSrcResourcesKey = flagOffSrcResourcesKey;
			this.flagOffSrcKey = flagOffSrcKey;
			this.flagWidthResourcesKey = flagWidthResourcesKey;
			this.flagWidthKey = flagWidthKey;
			this.flagHeightResourcesKey = flagHeightResourcesKey;
			this.flagHeightKey = flagHeightKey;
			this.url = url;
		}

		public String getCode() {
			return code;
		}

		public String getDisplay(HttpServletRequest req, Locale locale) throws JspException {
			MessageResources applicationResources = (MessageResources)req.getAttribute(displayResourcesKey);
			if(applicationResources==null) throw new JspException("Unable to load resources: "+displayResourcesKey);
			return applicationResources.getMessage(locale, displayKey);
		}

		public String getFlagOnSrc(HttpServletRequest req, Locale locale) throws JspException {
			MessageResources applicationResources = (MessageResources)req.getAttribute(flagOnSrcResourcesKey);
			if(applicationResources==null) throw new JspException("Unable to load resources: "+flagOnSrcResourcesKey);
			return applicationResources.getMessage(locale, flagOnSrcKey);
		}

		public String getFlagOffSrc(HttpServletRequest req, Locale locale) throws JspException {
			MessageResources applicationResources = (MessageResources)req.getAttribute(flagOffSrcResourcesKey);
			if(applicationResources==null) throw new JspException("Unable to load resources: "+flagOffSrcResourcesKey);
			return applicationResources.getMessage(locale, flagOffSrcKey);
		}

		public String getFlagWidth(HttpServletRequest req, Locale locale) throws JspException {
			MessageResources applicationResources = (MessageResources)req.getAttribute(flagWidthResourcesKey);
			if(applicationResources==null) throw new JspException("Unable to load resources: "+flagWidthResourcesKey);
			return applicationResources.getMessage(locale, flagWidthKey);
		}

		public String getFlagHeight(HttpServletRequest req, Locale locale) throws JspException {
			MessageResources applicationResources = (MessageResources)req.getAttribute(flagHeightResourcesKey);
			if(applicationResources==null) throw new JspException("Unable to load resources: "+flagHeightResourcesKey);
			return applicationResources.getMessage(locale, flagHeightKey);
		}

		/**
		 * Gets the absolute URL to use for this language or null
		 * to change language on the existing page.
		 */
		public String getUrl() {
			return url;
		}
	}

	/**
	 * Prints the auto index of all the page siblings.
	 */
	abstract public void printAutoIndex(HttpServletRequest req, HttpServletResponse resp, JspWriter out, PageAttributes pageAttributes) throws JspException;

	/**
	 * Begins a popup group.
	 */
	abstract public void beginPopupGroup(HttpServletRequest req, JspWriter out, long groupId) throws JspException;

	/**
	 * Ends a popup group.
	 */
	abstract public void endPopupGroup(HttpServletRequest req, JspWriter out, long groupId) throws JspException;

	/**
	 * Begins a popup that is in a popup group.
	 */
	abstract public void beginPopup(HttpServletRequest req, HttpServletResponse resp, JspWriter out, long groupId, long popupId, String width) throws JspException;

	/**
	 * Prints a popup close link/image/button for a popup that is part of a popup group.
	 */
	abstract public void printPopupClose(HttpServletRequest req, HttpServletResponse resp, JspWriter out, long groupId, long popupId) throws JspException;

	/**
	 * Ends a popup that is in a popup group.
	 */
	abstract public void endPopup(HttpServletRequest req, HttpServletResponse resp, JspWriter out, long groupId, long popupId, String width) throws JspException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy