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

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

/*
 * Copyright 2014-2016 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.Arrays;
import java.util.List;

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

/**
 * 
 * border-bottom-width: medium|thin|thick|length|initial|inherit;
 *
 * The border-bottom-width property sets the width of an element's bottom border.
 *
 * Note: Always declare the border-style property before the border-bottom-width property. An element must have borders before you can change the width.
 * Default value:  medium
 * Inherited:      no
 * Animatable:     yes
 * Version:        CSS1
 * JavaScript syntax:      object.style.borderBottomWidth="5px"
 * 
* * * @author WFF * @since 1.0.0 */ public class BorderBottomWidth extends AbstractCssProperty { private static final long serialVersionUID = 1_0_0L; public static final String MEDIUM = "medium"; public static final String THIN = "thin"; public static final String THICK = "thick"; public static final String INITIAL = "initial"; public static final String INHERIT = "inherit"; private static final List PREDEFINED_CONSTANTS = Arrays .asList(INITIAL, INHERIT, MEDIUM, THIN, THICK); private String cssValue; private Float value; private CssLengthUnit cssLengthUnit; /** * The {@code medium} will be set as the value */ public BorderBottomWidth() { setCssValue(MEDIUM); } /** * @param cssValue * the css value to set. */ public BorderBottomWidth(final String cssValue) { setCssValue(cssValue); } /** * @param borderBottomWidth * the {@code BorderBottomWidth} object from which the cssValue * to set.And, {@code null} will throw {@code NullValueException} */ public BorderBottomWidth(final BorderBottomWidth borderBottomWidth) { if (borderBottomWidth == null) { throw new NullValueException("borderBottomWidth can not be null"); } setCssValue(borderBottomWidth.getCssValue()); } /** * @param percent * the percentage value to set. The cssLengthUnit will * automatically set to %. * @since 1.0.0 * @author WFF */ public BorderBottomWidth(final float percent) { cssLengthUnit = CssLengthUnit.PER; value = Float.valueOf(percent); cssValue = percent + "" + cssLengthUnit; } /** * @param value * @param cssLengthUnit */ public BorderBottomWidth(final float value, final CssLengthUnit cssLengthUnit) { this.value = Float.valueOf(value); this.cssLengthUnit = cssLengthUnit; cssValue = value + "" + cssLengthUnit; } /** * @param value * @param cssLengthUnit * @return the current object * @since 1.0.0 * @author WFF */ public BorderBottomWidth setValue(final float value, final CssLengthUnit cssLengthUnit) { this.value = Float.valueOf(value); this.cssLengthUnit = cssLengthUnit; cssValue = value + "" + cssLengthUnit; if (getStateChangeInformer() != null) { getStateChangeInformer().stateChanged(this); } return this; } /** * @param percent * the percent to set * @since 1.0.0 * @author WFF */ public void setPercent(final float percent) { value = Float.valueOf(percent); cssLengthUnit = CssLengthUnit.PER; cssValue = percent + "" + cssLengthUnit; if (getStateChangeInformer() != null) { getStateChangeInformer().stateChanged(this); } } /* * (non-Javadoc) * * @see com.webfirmframework.wffweb.css.CssProperty#getCssName() * * @since 1.0.0 * * @author WFF */ @Override public String getCssName() { return CssNameConstants.BORDER_BOTTOM_WIDTH; } /* * (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(); } /** * gets the border-bottom-width in {@code Float} value. * {@code BorderBottomWidth#getUnit()} should be used to get the * cssLengthUnit for this value. * * @return the value in Float or null if the * border-bottom-width is set as initial or * inherit. * @since 1.0.0 * @author WFF */ public Float getValue() { return value; } /** * @return the cssLengthUnit {@code PX}/{@code PER}, or {@code null} if the * value is any inbuilt value like {@code inherit}. * @since 1.0.0 * @author WFF */ public CssLengthUnit getUnit() { return cssLengthUnit; } /** * @param cssValue * the value should be in the format of 55px or * 95%. {@code null} is considered as an invalid * value and it will throw {@code NullValueException}. * @since 1.0.0 * @author WFF */ @Override public BorderBottomWidth setCssValue(final String cssValue) { final String previousCssValue = this.cssValue; try { if (cssValue == null) { throw new NullValueException( "null is an invalid value. The value format should be as for example 75px or 85%. Or, initial/inherit."); } else { final String trimmedCssValue = TagStringUtil .toLowerCase(cssValue.trim()); boolean invalidValue = true; for (final CssLengthUnit cssLengthUnit : CssLengthUnit .values()) { final String unit = cssLengthUnit.getUnit(); if (trimmedCssValue.endsWith(unit)) { final String valueOnly = trimmedCssValue .replaceFirst(unit, ""); try { value = Float.parseFloat(valueOnly); } catch (final NumberFormatException e) { break; } this.cssLengthUnit = cssLengthUnit; this.cssValue = cssValue; invalidValue = false; break; } } if (PREDEFINED_CONSTANTS.contains(trimmedCssValue)) { this.cssValue = trimmedCssValue; cssLengthUnit = null; value = null; invalidValue = false; } if (invalidValue) { throw new InvalidValueException(cssValue + " is an invalid value. The value format should be as for example 75px, 85%, initial, inherit etc.."); } } if (getStateChangeInformer() != null) { getStateChangeInformer().stateChanged(this); } } catch (final NumberFormatException | InvalidValueException e) { this.cssValue = previousCssValue; throw new InvalidValueException( cssValue + " is an invalid value. The value format should be as for example 75px or 85%. Or, initial/inherit.", e); } return this; } /** * 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); } /** * sets as {@code medium}. * * @since 1.0.0 * @author WFF */ public void setAsMedium() { setCssValue(MEDIUM); } /** * sets as {@code thin}. * * @since 1.0.0 * @author WFF */ public void setAsThin() { setCssValue(THIN); } /** * sets as {@code thick}. * * @since 1.0.0 * @author WFF */ public void setAsThick() { setCssValue(THICK); } /** * validates if the given cssValue is valid for this class. * * @param cssValue * the value to check. * @return true if valid and false if invalid. * @author WFF * @since 1.0.0 */ public static boolean isValid(final String cssValue) { final String trimmedCssValue = cssValue.trim().toLowerCase(); if (trimmedCssValue.contains(" ")) { return false; } for (final CssLengthUnit cssLengthUnit : CssLengthUnit.values()) { final String unit = cssLengthUnit.getUnit(); if (trimmedCssValue.endsWith(unit)) { final String valueOnly = trimmedCssValue.replaceFirst(unit, ""); try { Float.parseFloat(valueOnly); } catch (final NumberFormatException e) { break; } return true; } } return PREDEFINED_CONSTANTS.contains(trimmedCssValue); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy