<?php namespace FML\Components; use FML\Controls\Entry; use FML\Controls\Frame; use FML\Controls\Quad; use FML\Models\CheckBoxDesign; use FML\Script\Features\CheckBoxFeature; use FML\Script\Features\ScriptFeature; use FML\Types\Renderable; use FML\Types\ScriptFeatureable; /** * CheckBox Component * * @author steeffeen <mail@steeffeen.com> * @copyright FancyManiaLinks Copyright © 2014 Steffen Schröder * @license http://www.gnu.org/licenses/ GNU General Public License, Version 3 */ class CheckBox implements Renderable, ScriptFeatureable { /* * Protected Properties */ protected $name = null; protected $feature = null; /** * Create a new CheckBox Component * * @param string $name (optional) CheckBox Name * @param bool $default (optional) Default Value * @param Quad $quad (optional) CheckBox Quad */ public function __construct($name = null, $default = null, Quad $quad = null) { $this->feature = new CheckBoxFeature(); $this->setName($name); $this->setDefault($default); $this->setQuad($quad); } /** * Set the Name * * @param string $name CheckBox Name * @return \FML\Components\CheckBox */ public function setName($name) { $this->name = (string)$name; return $this; } /** * Set the Default Value * * @param bool $default Default Value * @return \FML\Components\CheckBox */ public function setDefault($default) { $this->feature->setDefault($default); return $this; } /** * Set the Enabled Design * * @param string $style Style Name or Image Url * @param string $subStyle SubStyle Name * @return \FML\Components\CheckBox */ public function setEnabledDesign($style, $subStyle = null) { $checkBoxDesign = new CheckBoxDesign($style, $subStyle); $this->feature->setEnabledDesign($checkBoxDesign); return $this; } /** * Set the Disabled Design * * @param string $style Style Name or Image Url * @param string $subStyle SubStyle Name * @return \FML\Components\CheckBox */ public function setDisabledDesign($style, $subStyle = null) { $checkBoxDesign = new CheckBoxDesign($style, $subStyle); $this->feature->setDisabledDesign($checkBoxDesign); return $this; } /** * Set the CheckBox Quad * * @param Quad $quad CheckBox Quad * @return \FML\Components\CheckBox */ public function setQuad(Quad $quad = null) { $this->feature->setQuad($quad); return $this; } /** * @see \FML\Types\ScriptFeatureable::getScriptFeatures() */ public function getScriptFeatures() { return ScriptFeature::collect($this->feature, $this->getQuad(), $this->feature->getEntry()); } /** * Get the CheckBox Quad * * @param bool $createIfEmpty (optional) Create the Quad if it's not set * @return \FML\Controls\Quad */ public function getQuad($createIfEmpty = true) { if (!$this->feature->getQuad() && $createIfEmpty) { $quad = new Quad(); $quad->setSize(10, 10); $this->setQuad($quad); } return $this->feature->getQuad(); } /** * @see \ManiaControl\Types\Renderable::render() */ public function render(\DOMDocument $domDocument) { $frame = new Frame(); $quad = $this->getQuad(); $frame->add($quad); $entry = $this->buildEntry(); $frame->add($entry); $this->feature->setEntry($entry); return $frame->render($domDocument); } /** * Build the hidden Entry * * @return Entry */ protected function buildEntry() { $entry = new Entry(); $entry->setVisible(false); $entry->setName($this->name); return $entry; } }