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

com.github.bordertech.wcomponents.examples.theme.WHeadingExample Maven / Gradle / Ivy

There is a newer version: 1.5.36
Show newest version
package com.github.bordertech.wcomponents.examples.theme;

import com.github.bordertech.wcomponents.HeadingLevel;
import com.github.bordertech.wcomponents.Margin;
import com.github.bordertech.wcomponents.Size;
import com.github.bordertech.wcomponents.WContainer;
import com.github.bordertech.wcomponents.WDecoratedLabel;
import com.github.bordertech.wcomponents.WHeading;
import com.github.bordertech.wcomponents.WHorizontalRule;
import com.github.bordertech.wcomponents.WImage;
import com.github.bordertech.wcomponents.WStyledText;
import com.github.bordertech.wcomponents.WText;
import com.github.bordertech.wcomponents.examples.common.ExplanatoryText;
import com.github.bordertech.wcomponents.util.HtmlClassProperties;

/**
 * This component demonstrates the {@link WHeading} component.
 *
 * @author Mark Reeves
 * @since 1.0.0
 */
public class WHeadingExample extends WContainer {

	/**
	 * Creates a WHeadingExample.
	 */
	public WHeadingExample() {

		add(new WHeading(HeadingLevel.H2, "Important information regarding this example"));
		add(new ExplanatoryText("This page shows an example of each WHeading HeadingLevel."
				+ " It serves as an example of the way a WHeading is created using the WComponent Java API and"
				+ " does not show how headings should be used within a user interface"
				+ " or the correct nesting order for headings.\n"
				+ "The order of headings in a user interface is extremely important and must comply"
				+ " with an unfortunately complex specification which does not lend itself to machine interpretation."
				+ " For detailed information on WHeading order consult the HTML5 specification and WCAG 2.0 guidelines.\n"
				+ "In an attempt to make this complex issue slightly simpler for application specifiers and"
				+ " developers WComponents provides components which create explicit pieces of sectioning content which"
				+ " include the requisite h1 element and reset the heading order back to WHeading Type.MAJOR. These"
				+ " components are WSection, WDialog and WPanel of Types CHROME and ACTION. In all cases WApplication defines a section"
				+ " with the heading level reset to Type.TITLE."));
		add(new WHeading(HeadingLevel.H1, "HeadingLevel.H1 is a HTML h1 element"));
		add(new ExplanatoryText("This heading level is rarely used. In almost all circumstances"
				+ " h1 will be output as part of a WSection, WDialog or WPanel of Types CHROME or ACTION."));
		add(new WHeading(HeadingLevel.H2, "HeadingLevel.H2 is a HTML h2 element"));
		add(new ExplanatoryText("This heading level should be the first heading level used within any 'headed' WPanel type or in the content of a "
				+ "WSection or WDialog."
				+ " It must always be preceded at some level by a component which can output a HTML h1 element either a WHeading HeadingLevel.H1 or the"
				+ " title of WSection, WDialog or WPanel Types CHROME or SECTION."));
		add(new WHeading(HeadingLevel.H3, "HeadingLevel.H3 is a HTML h3 element"));
		add(new ExplanatoryText(
				"This WHeading Type must be preceded, within a piece of sectioning content, by a WHeading of HeadingLevel.H2."));
		add(new WHeading(HeadingLevel.H4, "HeadingLevel.H4 is a HTML h4 element"));
		add(new ExplanatoryText(
				"This WHeading Type must be preceded, within a piece of sectioning content, by a WHeading of HeadingLevel.H3."));
		add(new WHeading(HeadingLevel.H5, "HeadingLevel.H5 is a HTML h5 element"));
		add(new ExplanatoryText(
				"This WHeading Type must be preceded, within a piece of sectioning content, by a WHeading ofHeadingLevel.H4."));
		add(new WHeading(HeadingLevel.H6,
				"HeadingLevel.H6 is a HTML h6 element"));
		add(new ExplanatoryText(
				"This WHeading Type must be preceded, within a piece of sectioning content, by a WHeading of HeadingLevel.H5."));

		add(new WHorizontalRule());

		add(new WHeading(HeadingLevel.H2, "Examples with additional content"));
		add(new ExplanatoryText("These examples are only used to show the use of a WDecoratedLabel in the WHeading. As with the examples above they "
				+ "should not be used as a sample of good label construction"));

		add(new WHeading(HeadingLevel.H1, makeHeadingLabel("Heading h1", "draft")));
		add(new WHeading(HeadingLevel.H2, makeHeadingLabel("Heading h2", "draft")));
		add(new WHeading(HeadingLevel.H3, makeHeadingLabel("Heading h3", "deleted")));
		add(new WHeading(HeadingLevel.H4, makeHeadingLabel("Heading h4", "waiting approval")));
		add(new WHeading(HeadingLevel.H5, makeHeadingLabel("Heading h5", "approved")));
		add(new WHeading(HeadingLevel.H6, makeHeadingLabel("Heading h6", "published")));

		add(new WHeading(HeadingLevel.H2, "Examples with unescaped content"));
		WHeading unescapedHeading = new WHeading(HeadingLevel.H3, "Red H3 (unescaped text)");
		unescapedHeading.setEncodeText(false);
		add(unescapedHeading);
		unescapedHeading = new WHeading(HeadingLevel.H3, "• Bulleted (unescaped text)•");
		unescapedHeading.setEncodeText(false);
		add(unescapedHeading);
		add(new WHeading(HeadingLevel.H2, "Examples with Icons"));
		WHeading iconHeading = new WHeading(HeadingLevel.H3, "Headline with icon before");
		iconHeading.setHtmlClass(HtmlClassProperties.ICON_INFO_BEFORE);
		add(iconHeading);

		iconHeading = new WHeading(HeadingLevel.H3, "Headline with icon after");
		iconHeading.setHtmlClass(HtmlClassProperties.ICON_INFO_AFTER);
		add(iconHeading);

		WHeading marginHeading = new WHeading(HeadingLevel.H1, "H1 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H2, "H2 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H3, "H3 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H4, "H4 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H5, "H5 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H6, "H6 with extra large margin");
		marginHeading.setMargin(new Margin(Size.XL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H1, "H1 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H2, "H2 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H3, "H3 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H4, "H4 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H5, "H5 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		marginHeading = new WHeading(HeadingLevel.H6, "H6 with mixed margin");
		marginHeading.setMargin(new Margin(null, Size.XL, Size.ZERO, Size.SMALL));
		add(marginHeading);

		// you should NEVER set an icon as the ONLY visible text content of a WHeading
		add(new WHorizontalRule());

		add(new WHeading(HeadingLevel.H2, "Heading anti patterns"));
		add(new ExplanatoryText("Bad heading examples - do NOT use these!"));
		add(new WHeading(HeadingLevel.H3, "Empty headings"));

		add(new WHeading(HeadingLevel.H1, ""));
		add(new WHeading(HeadingLevel.H2, ""));
		add(new WHeading(HeadingLevel.H3, ""));
		add(new WHeading(HeadingLevel.H4, ""));
		add(new WHeading(HeadingLevel.H5, ""));
		add(new WHeading(HeadingLevel.H6, ""));

		add(new WHeading(HeadingLevel.H3, "Almost empty headings"));
		add(new WHeading(HeadingLevel.H1, "\u00a0"));
		add(new WHeading(HeadingLevel.H2, "\u00a0"));
		add(new WHeading(HeadingLevel.H3, "\u00a0"));
		add(new WHeading(HeadingLevel.H4, "\u00a0"));
		add(new WHeading(HeadingLevel.H5, "\u00a0"));
		add(new WHeading(HeadingLevel.H6, "\u00a0"));

		add(new WHeading(HeadingLevel.H3, "Bad image headings"));
		add(new ExplanatoryText("The image in these headings has no description."));
		add(new WHeading(HeadingLevel.H1, makeAntiPatternLabel()));
		add(new WHeading(HeadingLevel.H2, makeAntiPatternLabel()));
		add(new WHeading(HeadingLevel.H3, makeAntiPatternLabel()));
		add(new WHeading(HeadingLevel.H4, makeAntiPatternLabel()));
		add(new WHeading(HeadingLevel.H5, makeAntiPatternLabel()));
		add(new WHeading(HeadingLevel.H6, makeAntiPatternLabel()));
	}

	/**
	 * @param text the label text
	 * @param statusText the status text
	 * @return the decorated label
	 */
	private WDecoratedLabel makeHeadingLabel(final String text, final String statusText) {
		return new WDecoratedLabel(new WImage("/image/information.png", "Informative heading"),
				new WText(text), new WStyledText(statusText, WStyledText.Type.EMPHASISED));
	}

	/**
	 *
	 * @return a decorated label containing an undescribed image.
	 */
	private WDecoratedLabel makeAntiPatternLabel() {
		return new WDecoratedLabel(new WImage("/image/information.png", ""));
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy