488 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			488 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace FML\Stylesheet;
 | |
| 
 | |
| use FML\Controls\Control;
 | |
| use FML\Types\BackgroundColorable;
 | |
| use FML\Types\BgColorable;
 | |
| use FML\Types\Colorable;
 | |
| use FML\Types\Renderable;
 | |
| use FML\Types\Styleable;
 | |
| use FML\Types\SubStyleable;
 | |
| use FML\Types\TextFormatable;
 | |
| 
 | |
| /**
 | |
|  * Class representing a Style
 | |
|  * (Note: This class doesn't support all style attributes yet. This will be improved in FML v2.)
 | |
|  *
 | |
|  * @author    steeffeen <mail@steeffeen.com>
 | |
|  * @copyright FancyManiaLinks Copyright © 2017 Steffen Schröder
 | |
|  * @license   http://www.gnu.org/licenses/ GNU General Public License, Version 3
 | |
|  */
 | |
| class Style implements BackgroundColorable, BgColorable, Colorable, Renderable, Styleable, SubStyleable, TextFormatable
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * @var string[] $styleIds Style Ids
 | |
|      */
 | |
|     protected $styleIds = array();
 | |
| 
 | |
|     /**
 | |
|      * @var string[] $styleClasses Style classes
 | |
|      */
 | |
|     protected $styleClasses = array();
 | |
| 
 | |
|     /**
 | |
|      * @var string $backgroundColor Background color
 | |
|      */
 | |
|     protected $backgroundColor = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $focusBackgroundColor Focus background color
 | |
|      */
 | |
|     protected $focusBackgroundColor = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $color Color
 | |
|      */
 | |
|     protected $color = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $style Style
 | |
|      */
 | |
|     protected $style = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $subStyle SubStyle
 | |
|      */
 | |
|     protected $subStyle = null;
 | |
| 
 | |
|     /**
 | |
|      * @var int $textSize Text size
 | |
|      */
 | |
|     protected $textSize = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $textFont Text font
 | |
|      */
 | |
|     protected $textFont = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $textColor Text color
 | |
|      */
 | |
|     protected $textColor = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $areaColor Area color
 | |
|      */
 | |
|     protected $areaColor = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $focusAreaColor Focus area color
 | |
|      */
 | |
|     protected $focusAreaColor = null;
 | |
| 
 | |
|     /**
 | |
|      * Create a new Style
 | |
|      *
 | |
|      * @api
 | |
|      * @return static
 | |
|      */
 | |
|     public static function create()
 | |
|     {
 | |
|         return new static();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get style Ids
 | |
|      *
 | |
|      * @api
 | |
|      * @return string[]
 | |
|      */
 | |
|     public function getStyleIds()
 | |
|     {
 | |
|         return $this->styleIds;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add style Id
 | |
|      *
 | |
|      * @api
 | |
|      * @param string $styleId Style Id
 | |
|      * @return static
 | |
|      */
 | |
|     public function addStyleId($styleId)
 | |
|     {
 | |
|         $styleId = (string)$styleId;
 | |
|         if (!in_array($styleId, $this->styleIds)) {
 | |
|             array_push($this->styleIds, $styleId);
 | |
|         }
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add style Ids
 | |
|      *
 | |
|      * @api
 | |
|      * @param string[] $styleIds Style Ids
 | |
|      * @return static
 | |
|      */
 | |
|     public function addStyleIds(array $styleIds)
 | |
|     {
 | |
|         foreach ($styleIds as $styleId) {
 | |
|             $this->addStyleId($styleId);
 | |
|         }
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set style Ids
 | |
|      *
 | |
|      * @api
 | |
|      * @param string[] $styleIds Style Ids
 | |
|      * @return static
 | |
|      */
 | |
|     public function setStyleIds(array $styleIds)
 | |
|     {
 | |
|         return $this->removeAllStyleIds()
 | |
|                     ->addStyleIds($styleIds);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Remove all style Ids
 | |
|      *
 | |
|      * @api
 | |
|      * @return static
 | |
|      */
 | |
|     public function removeAllStyleIds()
 | |
|     {
 | |
|         $this->styleIds = array();
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Apply style to the given control using its Id
 | |
|      *
 | |
|      * @api
 | |
|      * @param Control $control Control that should be styled
 | |
|      * @return static
 | |
|      */
 | |
|     public function applyToControl(Control $control)
 | |
|     {
 | |
|         return $this->addStyleId($control->checkId());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get style classes
 | |
|      *
 | |
|      * @api
 | |
|      * @return string[]
 | |
|      */
 | |
|     public function getStyleClasses()
 | |
|     {
 | |
|         return $this->styleClasses;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add style class
 | |
|      *
 | |
|      * @api
 | |
|      * @param string $styleClass Style class
 | |
|      * @return static
 | |
|      */
 | |
|     public function addStyleClass($styleClass)
 | |
|     {
 | |
|         $styleClass = (string)$styleClass;
 | |
|         if (!in_array($styleClass, $this->styleClasses)) {
 | |
|             array_push($this->styleClasses, $styleClass);
 | |
|         }
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add style classes
 | |
|      *
 | |
|      * @api
 | |
|      * @param string[] $styleClasses Style classes
 | |
|      * @return static
 | |
|      */
 | |
|     public function addStyleClasses(array $styleClasses)
 | |
|     {
 | |
|         foreach ($styleClasses as $styleClass) {
 | |
|             $this->addStyleClass($styleClass);
 | |
|         }
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set style classes
 | |
|      *
 | |
|      * @api
 | |
|      * @param string[] $styleIds Style classes
 | |
|      * @return static
 | |
|      */
 | |
|     public function setStyleClasses(array $styleClasses)
 | |
|     {
 | |
|         return $this->removeAllStyleClasses()
 | |
|                     ->addStyleClasses($styleClasses);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Remove all style classes
 | |
|      *
 | |
|      * @api
 | |
|      * @return static
 | |
|      */
 | |
|     public function removeAllStyleClasses()
 | |
|     {
 | |
|         $this->styleClasses = array();
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Apply style to the given control using its classes
 | |
|      *
 | |
|      * @api
 | |
|      * @param Control $control Control that should be styled
 | |
|      * @return static
 | |
|      */
 | |
|     public function applyToControlViaClasses(Control $control)
 | |
|     {
 | |
|         return $this->addStyleClasses($control->getClasses());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see BackgroundColorable::getBackgroundColor()
 | |
|      */
 | |
|     public function getBackgroundColor()
 | |
|     {
 | |
|         return $this->backgroundColor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see BackgroundColorable::setBackgroundColor()
 | |
|      */
 | |
|     public function setBackgroundColor($backgroundColor)
 | |
|     {
 | |
|         $this->backgroundColor = (string)$backgroundColor;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @deprecated Use setBackgroundColor()
 | |
|      * @see        Style::setBackgroundColor()
 | |
|      */
 | |
|     public function setBgColor($bgdColor)
 | |
|     {
 | |
|         return $this->setBackgroundColor($bgdColor);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see BackgroundColorable::getFocusBackgroundColor()
 | |
|      */
 | |
|     public function getFocusBackgroundColor()
 | |
|     {
 | |
|         return $this->focusBackgroundColor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see BackgroundColorable::setFocusBackgroundColor()
 | |
|      */
 | |
|     public function setFocusBackgroundColor($focusBackgroundColor)
 | |
|     {
 | |
|         $this->focusBackgroundColor = (string)$focusBackgroundColor;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Colorable::getColor
 | |
|      */
 | |
|     public function getColor()
 | |
|     {
 | |
|         return $this->color;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Colorable::setColor
 | |
|      */
 | |
|     public function setColor($color)
 | |
|     {
 | |
|         $this->color = (string)$color;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Styleable::getStyle()
 | |
|      */
 | |
|     public function getStyle()
 | |
|     {
 | |
|         return $this->style;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Styleable::setStyle()
 | |
|      */
 | |
|     public function setStyle($style)
 | |
|     {
 | |
|         $this->style = (string)$style;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Styleable::getSubStyle()
 | |
|      */
 | |
|     public function getSubStyle()
 | |
|     {
 | |
|         return $this->subStyle;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see SubStyleable::setSubStyle()
 | |
|      */
 | |
|     public function setSubStyle($subStyle)
 | |
|     {
 | |
|         $this->subStyle = (string)$subStyle;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see SubStyleable::setStyles()
 | |
|      */
 | |
|     public function setStyles($style, $subStyle)
 | |
|     {
 | |
|         return $this->setStyle($style)
 | |
|                     ->setSubStyle($subStyle);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::getTextSize()
 | |
|      */
 | |
|     public function getTextSize()
 | |
|     {
 | |
|         return $this->textSize;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::setTextSize()
 | |
|      */
 | |
|     public function setTextSize($textSize)
 | |
|     {
 | |
|         $this->textSize = (int)$textSize;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::getTextFont()
 | |
|      */
 | |
|     public function getTextFont()
 | |
|     {
 | |
|         return $this->textFont;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::setTextFont()
 | |
|      */
 | |
|     public function setTextFont($textFont)
 | |
|     {
 | |
|         $this->textFont = (string)$textFont;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::getTextColor()
 | |
|      */
 | |
|     public function getTextColor()
 | |
|     {
 | |
|         return $this->textColor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::setTextColor()
 | |
|      */
 | |
|     public function setTextColor($textColor)
 | |
|     {
 | |
|         $this->textColor = (string)$textColor;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::getAreaColor()
 | |
|      */
 | |
|     public function getAreaColor()
 | |
|     {
 | |
|         return $this->areaColor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::setAreaColor()
 | |
|      */
 | |
|     public function setAreaColor($areaColor)
 | |
|     {
 | |
|         $this->areaColor = (string)$areaColor;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::getAreaFocusColor()
 | |
|      */
 | |
|     public function getAreaFocusColor()
 | |
|     {
 | |
|         return $this->focusAreaColor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see TextFormatable::setAreaFocusColor()
 | |
|      */
 | |
|     public function setAreaFocusColor($areaFocusColor)
 | |
|     {
 | |
|         $this->focusAreaColor = (string)$areaFocusColor;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see Renderable::render()
 | |
|      */
 | |
|     public function render(\DOMDocument $domDocument)
 | |
|     {
 | |
|         $domElement = $domDocument->createElement("style");
 | |
|         if (!empty($this->styleIds)) {
 | |
|             $domElement->setAttribute("id", implode(" ", $this->styleIds));
 | |
|         }
 | |
|         if (!empty($this->styleClasses)) {
 | |
|             $domElement->setAttribute("class", implode(" ", $this->styleClasses));
 | |
|         }
 | |
|         if ($this->backgroundColor) {
 | |
|             $domElement->setAttribute("bgcolor", $this->backgroundColor);
 | |
|         }
 | |
|         if ($this->focusBackgroundColor) {
 | |
|             $domElement->setAttribute("bgcolorfocus", $this->focusBackgroundColor);
 | |
|         }
 | |
|         if ($this->color) {
 | |
|             $domElement->setAttribute("color", $this->color);
 | |
|         }
 | |
|         if ($this->style) {
 | |
|             $domElement->setAttribute("style", $this->style);
 | |
|         }
 | |
|         if ($this->subStyle) {
 | |
|             $domElement->setAttribute("substyle", $this->subStyle);
 | |
|         }
 | |
|         if ($this->textSize) {
 | |
|             $domElement->setAttribute("textsize", $this->textSize);
 | |
|         }
 | |
|         if ($this->textFont) {
 | |
|             $domElement->setAttribute("textfont", $this->textFont);
 | |
|         }
 | |
|         if ($this->textColor) {
 | |
|             $domElement->setAttribute("textcolor", $this->textColor);
 | |
|         }
 | |
|         if ($this->areaColor) {
 | |
|             $domElement->setAttribute("focusareacolor1", $this->areaColor);
 | |
|         }
 | |
|         if ($this->focusAreaColor) {
 | |
|             $domElement->setAttribute("focusareacolor2", $this->focusAreaColor);
 | |
|         }
 | |
|         return $domElement;
 | |
|     }
 | |
| 
 | |
| }
 |