TrackManiaControl/libs/FML/Script/Features/Toggle.php
2017-03-25 18:40:15 +01:00

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};
}";
}
}