243 lines
5.3 KiB
PHP
243 lines
5.3 KiB
PHP
<?php
|
|
|
|
namespace FML\Script\Features;
|
|
|
|
use FML\Controls\Control;
|
|
use FML\Script\Builder;
|
|
use FML\Script\Script;
|
|
use FML\Script\ScriptLabel;
|
|
use FML\Types\Scriptable;
|
|
|
|
/**
|
|
* Script Feature for toggling Controls
|
|
*
|
|
* @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 Toggle extends ScriptFeature
|
|
{
|
|
|
|
/**
|
|
* @var Control $togglingControl Toggling Control
|
|
*/
|
|
protected $togglingControl = null;
|
|
|
|
/**
|
|
* @var Control $toggledControl Toggled Control
|
|
*/
|
|
protected $toggledControl = null;
|
|
|
|
/**
|
|
* @var $labelName Script Label name
|
|
*/
|
|
protected $labelName = null;
|
|
|
|
/**
|
|
* @var bool $onlyShow Show only
|
|
*/
|
|
protected $onlyShow = null;
|
|
|
|
/**
|
|
* @var bool $onlyHide Hide only
|
|
*/
|
|
protected $onlyHide = null;
|
|
|
|
/**
|
|
* Construct a new Toggle
|
|
*
|
|
* @api
|
|
* @param Control $togglingControl (optional) Toggling Control
|
|
* @param Control $toggledControl (optional) Toggled Control
|
|
* @param string $labelName (optional) Script Label name
|
|
* @param bool $onlyShow (optional) If it should only show the Control but not toggle
|
|
* @param bool $onlyHide (optional) If it should only hide the Control but not toggle
|
|
*/
|
|
public function __construct(
|
|
Control $togglingControl = null,
|
|
Control $toggledControl = null,
|
|
$labelName = ScriptLabel::MOUSECLICK,
|
|
$onlyShow = false,
|
|
$onlyHide = false
|
|
) {
|
|
if ($togglingControl) {
|
|
$this->setTogglingControl($togglingControl);
|
|
}
|
|
if ($toggledControl) {
|
|
$this->setToggledControl($toggledControl);
|
|
}
|
|
if ($labelName) {
|
|
$this->setLabelName($labelName);
|
|
}
|
|
if ($onlyShow) {
|
|
$this->setOnlyShow($onlyShow);
|
|
}
|
|
if ($onlyHide) {
|
|
$this->setOnlyHide($onlyHide);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get the toggling Control
|
|
*
|
|
* @api
|
|
* @return Control
|
|
*/
|
|
public function getTogglingControl()
|
|
{
|
|
return $this->togglingControl;
|
|
}
|
|
|
|
/**
|
|
* Set the toggling Control
|
|
*
|
|
* @api
|
|
* @param Control $control Toggling Control
|
|
* @return static
|
|
*/
|
|
public function setTogglingControl(Control $control)
|
|
{
|
|
$control->checkId();
|
|
if ($control instanceof Scriptable) {
|
|
$control->setScriptEvents(true);
|
|
}
|
|
$this->togglingControl = $control;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the toggled Control
|
|
*
|
|
* @api
|
|
* @return Control
|
|
*/
|
|
public function getToggledControl()
|
|
{
|
|
return $this->toggledControl;
|
|
}
|
|
|
|
/**
|
|
* Set the toggled Control
|
|
*
|
|
* @api
|
|
* @param Control $control Toggled Control
|
|
* @return static
|
|
*/
|
|
public function setToggledControl(Control $control)
|
|
{
|
|
$control->checkId();
|
|
$this->toggledControl = $control;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the Script Label name
|
|
*
|
|
* @api
|
|
* @return string
|
|
*/
|
|
public function getLabelName()
|
|
{
|
|
return $this->labelName;
|
|
}
|
|
|
|
/**
|
|
* Set the Script Label name
|
|
*
|
|
* @api
|
|
* @param string $labelName Script Label Name
|
|
* @return static
|
|
*/
|
|
public function setLabelName($labelName)
|
|
{
|
|
$this->labelName = (string)$labelName;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get Show Only
|
|
*
|
|
* @api
|
|
* @return bool
|
|
*/
|
|
public function getOnlyShow()
|
|
{
|
|
return $this->onlyShow;
|
|
}
|
|
|
|
/**
|
|
* Set Show Only
|
|
*
|
|
* @api
|
|
* @param bool $onlyShow If it should only show the Control but not toggle
|
|
* @return static
|
|
*/
|
|
public function setOnlyShow($onlyShow)
|
|
{
|
|
$this->onlyShow = (bool)$onlyShow;
|
|
if ($this->onlyShow) {
|
|
$this->onlyHide = null;
|
|
}
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get Hide Only
|
|
*
|
|
* @api
|
|
* @return bool
|
|
*/
|
|
public function getOnlyHide()
|
|
{
|
|
return $this->onlyHide;
|
|
}
|
|
|
|
/**
|
|
* Set Hide Only
|
|
*
|
|
* @api
|
|
* @param bool $onlyHide If it should only hide the Control but not toggle
|
|
* @return static
|
|
*/
|
|
public function setOnlyHide($onlyHide)
|
|
{
|
|
$this->onlyHide = (bool)$onlyHide;
|
|
if ($this->onlyHide) {
|
|
$this->onlyShow = null;
|
|
}
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* @see ScriptFeature::prepare()
|
|
*/
|
|
public function prepare(Script $script)
|
|
{
|
|
$script->appendGenericScriptLabel($this->labelName, $this->getScriptText());
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* Get the script text
|
|
*
|
|
* @return string
|
|
*/
|
|
protected function getScriptText()
|
|
{
|
|
$togglingControlId = Builder::escapeText($this->togglingControl->getId());
|
|
$toggledControlId = Builder::escapeText($this->toggledControl->getId());
|
|
$visibility = "!ToggleControl.Visible";
|
|
if ($this->onlyShow) {
|
|
$visibility = "True";
|
|
} else if ($this->onlyHide) {
|
|
$visibility = "False";
|
|
}
|
|
return "
|
|
if (Event.Control.ControlId == {$togglingControlId}) {
|
|
declare ToggleControl = Page.GetFirstChild({$toggledControlId});
|
|
ToggleControl.Visible = {$visibility};
|
|
}";
|
|
}
|
|
|
|
}
|