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

com.webfirmframework.wffweb.css.FontFamily Maven / Gradle / Ivy

/*
 * Copyright 2014-2019 Web Firm Framework
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * @author WFF
 */
package com.webfirmframework.wffweb.css;

import java.util.Collection;
import java.util.HashSet;
import java.util.Set;
import java.util.logging.Logger;

import com.webfirmframework.wffweb.InvalidValueException;
import com.webfirmframework.wffweb.NullValueException;
import com.webfirmframework.wffweb.css.core.AbstractCssProperty;
import com.webfirmframework.wffweb.util.StringBuilderUtil;
import com.webfirmframework.wffweb.util.StringUtil;
import com.webfirmframework.wffweb.util.TagStringUtil;

/**
 * 
 * font-family: font|initial|inherit;
 *
 * Value:       {@code [[  |  ] [, | ]* ] | inherit}
 * Initial:        depends on user agent
 * Applies to:     all elements
 * Inherited:      yes
 * Percentages:    N/A
 * Media:          visual
 * Computed value:         as specified
 *
 * Support Classes :-
 * 1. GenericFontFamilyNameContants
 * 
* * * @author WFF * @version 1.0.0 * @since 1.0.0 */ public class FontFamily extends AbstractCssProperty { private static final long serialVersionUID = 1_0_0L; public static final Logger LOGGER = Logger .getLogger(FontFamily.class.getName()); private static final Set FONT_FAMILY_NAMES = new HashSet() { private static final long serialVersionUID = 1_0_0L; @Override public boolean add(final String value) { return super.add(TagStringUtil.toLowerCase(value)); } @Override public boolean addAll(final Collection values) { boolean modified = false; for (final String each : values) { if (add(each)) { modified = true; } } return modified; } @Override public boolean remove(final Object o) { return super.remove(TagStringUtil.toLowerCase(o.toString())); }; }; static { FONT_FAMILY_NAMES.add(GenericFontFamilyNameContants.CURSIVE); FONT_FAMILY_NAMES.add(GenericFontFamilyNameContants.FANTASY); FONT_FAMILY_NAMES.add(GenericFontFamilyNameContants.MONOSPACE); FONT_FAMILY_NAMES.add(GenericFontFamilyNameContants.SANS_SERIF); FONT_FAMILY_NAMES.add(GenericFontFamilyNameContants.SERIF); } private boolean validateFontFamilyName; private static boolean validateFontFamilyNameGlobally; public static final String INITIAL = "initial"; public static final String INHERIT = "inherit"; public static final String[] EMPTY_ARRAY = new String[0]; private String cssValue; private String[] fontFamilyNames; /** * The {@code initial} will be set as the value */ public FontFamily() { setCssValue(INITIAL); } /** * @param cssValue * the css value to set. */ public FontFamily(final String cssValue) { setCssValue(cssValue); } /** *
     * Eg:-
     * String[] fontFamilyNames = {"Times New Roman", "Georgia", GenericFontFamilyNameContants.SERIF};
     *
     * 
* * @param fontFamilyNames * the font family names. */ public FontFamily(final String... fontFamilyNames) { this.fontFamilyNames = StringUtil.cloneArray(fontFamilyNames); cssValue = getBuiltCssValue(this.fontFamilyNames); } /** * @param fontFamilyNames * @return the built cssValue string from the given fontFamilyNames. * @author WFF * @since 1.0.0 */ protected static String getBuiltCssValue(final String... fontFamilyNames) { final StringBuilder cssValueSB = new StringBuilder(); int count = 1; for (final String fontFamilyName : fontFamilyNames) { if (StringUtil.containsSpace(fontFamilyName)) { cssValueSB.append('\"').append(fontFamilyName).append('\"'); } else { cssValueSB.append(fontFamilyName); } if (count != fontFamilyNames.length) { cssValueSB.append(", "); } else { break; } count++; } return StringBuilderUtil.getTrimmedString(cssValueSB); } /** * @param fontFamily * the {@code FontFamily} object from which the * cssValue to set.And, {@code null} will throw * {@code NullValueException} */ public FontFamily(final FontFamily fontFamily) { if (fontFamily == null) { throw new NullValueException("fontFamily can not be null"); } setCssValue(fontFamily.getCssValue()); } /* * (non-Javadoc) * * @see com.webfirmframework.wffweb.css.CssProperty#getCssName() * * @since 1.0.0 * * @author WFF */ @Override public String getCssName() { return CssNameConstants.FONT_FAMILY; } /* * (non-Javadoc) * * @see com.webfirmframework.wffweb.css.CssProperty#getCssValue() * * @since 1.0.0 * * @author WFF */ @Override public String getCssValue() { return cssValue; } @Override public String toString() { return getCssName() + ": " + getCssValue(); } /** * @param cssValue * The value should be a fontFamilies sequence for * example \ "Times New Roman\", Georgia, Serif Or * initial/inherit. * @since 1.0.0 * @author WFF */ @Override public FontFamily setCssValue(final String cssValue) { if (cssValue == null) { throw new NullValueException( "null is an invalid value. The value should be a fontFamilies sequence for example \"Times New Roman\", Georgia, Serif Or initial/inherit."); } else { final String trimmedCssValue = StringUtil.strip(cssValue); if (INITIAL.equals(cssValue) || INHERIT.equals(cssValue)) { fontFamilyNames = null; } else { fontFamilyNames = getExtractedFamilyNames(trimmedCssValue, validateFontFamilyName || validateFontFamilyNameGlobally); } this.cssValue = trimmedCssValue; if (getStateChangeInformer() != null) { getStateChangeInformer().stateChanged(this); } } return this; } /** * @param familyNames * @param validate * TODO * @return an array containing extracted family names from the given input. * @author WFF * @since 1.0.0 */ protected static String[] getExtractedFamilyNames(final String familyNames, final boolean validate) { final String[] parts = StringUtil.splitByComma(familyNames); int count = 0; for (final String each : parts) { final String trimmed = StringUtil.strip(each); final char firstChar; final char lastChar; if (trimmed.length() > 0) { firstChar = trimmed.charAt(0); lastChar = trimmed.charAt(trimmed.length() - 1); } else { firstChar = 0; lastChar = 0; } final boolean startsWith = firstChar == '"' || firstChar == '\''; int begin = 0; if (startsWith) { begin = 1; } final boolean endsWith = lastChar == '"' || lastChar == '\''; int end = trimmed.length(); if (endsWith) { end = end - 1; } final String familyName = trimmed.substring(begin, end); if (validate && !FONT_FAMILY_NAMES .contains(TagStringUtil.toLowerCase(familyName))) { throw new InvalidValueException("font-family name " + familyName + " is not valid against the family names added by addFontFamilyName and addFontFamilyNames methods"); } parts[count] = familyName; count++; } return parts; } /** *
     * Eg:-
     * String[] fontFamilyNames = {"Times New Roman", "Georgia", GenericFontFamilyNameContants.SERIF};
     *
     * 
* * @param fontFamilyNames * the fontFamilyNames to set * @author WFF * @since 1.0.0 */ public void setFontFamilyNames(final String[] fontFamilyNames) { if (fontFamilyNames != null) { this.fontFamilyNames = StringUtil.cloneArray(fontFamilyNames); cssValue = getBuiltCssValue(this.fontFamilyNames); } else { this.fontFamilyNames = null; cssValue = INITIAL; } if (getStateChangeInformer() != null) { getStateChangeInformer().stateChanged(this); } } /** * gets the font family names as an array and if here is no names set then * returns an empty array. * *
     * Note: it will never return null.
     * 
* * @return the fontFamilyNames. If there is no family name set then returns * an empty array instead of null. * @author WFF * @since 1.0.0 */ public String[] getFontFamilyNames() { if (fontFamilyNames == null) { return EMPTY_ARRAY; } return StringUtil.cloneArray(fontFamilyNames); } /** * sets as {@code initial} * * @since 1.0.0 * @author WFF */ public void setAsInitial() { setCssValue(INITIAL); } /** * sets as {@code inherit} * * @since 1.0.0 * @author WFF */ public void setAsInherit() { setCssValue(INHERIT); } /** * * @param fontFamilyName * the supported font-family. * @author WFF * @since 1.0.0 */ public static void addFontFamilyName(final String fontFamilyName) { FONT_FAMILY_NAMES.add(fontFamilyName); } /** * @param fontFamilyNames * the supported font-family names. * @author WFF * @since 1.0.0 */ public static void addFontFamilyNames( final Collection fontFamilyNames) { FONT_FAMILY_NAMES.addAll(fontFamilyNames); } /** * * @author WFF * @return the set of font-family names added by * {@code FontFamily#addFontFamilyName(String)} and * {@code FontFamily#addFontFamilyNames(Collection)} methods. * @since 1.0.0 */ public Set getAddedFontFamilyNames() { return FONT_FAMILY_NAMES; } /** * @return the validateFontFamilyName * @author WFF * @since 1.0.0 */ public boolean isValidateFontFamilyName() { return validateFontFamilyName; } /** * @param validateFontFamilyName * the validateFontFamilyName to set * @author WFF * @since 1.0.0 */ public void setValidateFontFamilyName( final boolean validateFontFamilyName) { this.validateFontFamilyName = validateFontFamilyName; } /** * @return the validateFontFamilyNameGlobally * @author WFF * @since 1.0.0 */ public static boolean isValidateFontFamilyNameGlobally() { return validateFontFamilyNameGlobally; } /** * @param validateFontFamilyNameGlobally * the * validateFontFamilyNameGlobally * to set * @author WFF * @since 1.0.0 */ public static void setValidateFontFamilyNameGlobally( final boolean validateFontFamilyNameGlobally) { FontFamily.validateFontFamilyNameGlobally = validateFontFamilyNameGlobally; } /** * @return true if the given cssValue is validate. It also checks whether * the font-family names added by * {@code FontFamily#addFontFamilyName(String)} and * {@code FontFamily#addFontFamilyNames(Collection)} methods contain * the given cssValue. * @author WFF * @since 1.0.0 */ public static boolean isValid(final String cssValue) { final String cssValueLC = TagStringUtil .toLowerCase(StringUtil.strip(cssValue)); return INITIAL.equals(cssValueLC) || INHERIT.equals(cssValueLC) || FONT_FAMILY_NAMES.contains(cssValueLC); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy