254 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			254 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace FML\Script\Features;
 | |
| 
 | |
| use FML\Controls\Control;
 | |
| use FML\Controls\Label;
 | |
| use FML\Script\Builder;
 | |
| use FML\Script\Script;
 | |
| use FML\Script\ScriptLabel;
 | |
| use FML\Types\Scriptable;
 | |
| 
 | |
| /**
 | |
|  * Script Feature for showing Tooltips
 | |
|  *
 | |
|  * @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 Tooltip extends ScriptFeature
 | |
| {
 | |
| 
 | |
|     /**
 | |
|      * @var Control $hoverControl Hover Control
 | |
|      */
 | |
|     protected $hoverControl = null;
 | |
| 
 | |
|     /**
 | |
|      * @var Control $tooltipControl Tooltip Control
 | |
|      */
 | |
|     protected $tooltipControl = null;
 | |
| 
 | |
|     /**
 | |
|      * @var bool $stayOnClick Stay on click
 | |
|      */
 | |
|     protected $stayOnClick = null;
 | |
| 
 | |
|     /**
 | |
|      * @var bool $invert Inverted visibility toggling
 | |
|      */
 | |
|     protected $invert = null;
 | |
| 
 | |
|     /**
 | |
|      * @var string $text Tooltip Text
 | |
|      */
 | |
|     protected $text = null;
 | |
| 
 | |
|     /**
 | |
|      * Construct a new Tooltip
 | |
|      *
 | |
|      * @api
 | |
|      * @param Control $hoverControl   (optional) Hover Control
 | |
|      * @param Control $tooltipControl (optional) Tooltip Control
 | |
|      * @param bool    $stayOnClick    (optional) If the Tooltip should stay on click
 | |
|      * @param bool    $invert         (optional) If the visibility toggling should be inverted
 | |
|      * @param string  $text           (optional) Text to display if the TooltipControl is a Label
 | |
|      */
 | |
|     public function __construct(Control $hoverControl = null, Control $tooltipControl = null, $stayOnClick = null, $invert = null, $text = null)
 | |
|     {
 | |
|         if ($hoverControl) {
 | |
|             $this->setHoverControl($hoverControl);
 | |
|         }
 | |
|         if ($tooltipControl) {
 | |
|             $this->setTooltipControl($tooltipControl);
 | |
|         }
 | |
|         if ($stayOnClick) {
 | |
|             $this->setStayOnClick($stayOnClick);
 | |
|         }
 | |
|         if ($invert) {
 | |
|             $this->setInvert($invert);
 | |
|         }
 | |
|         if ($text) {
 | |
|             $this->setText($text);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the Hover Control
 | |
|      *
 | |
|      * @api
 | |
|      * @return Control
 | |
|      */
 | |
|     public function getHoverControl()
 | |
|     {
 | |
|         return $this->hoverControl;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the Hover Control
 | |
|      *
 | |
|      * @api
 | |
|      * @param Control $hoverControl Hover Control
 | |
|      * @return static
 | |
|      */
 | |
|     public function setHoverControl(Control $hoverControl)
 | |
|     {
 | |
|         $hoverControl->checkId();
 | |
|         if ($hoverControl instanceof Scriptable) {
 | |
|             $hoverControl->setScriptEvents(true);
 | |
|         }
 | |
|         $this->hoverControl = $hoverControl;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the Tooltip Control
 | |
|      *
 | |
|      * @api
 | |
|      * @return Control
 | |
|      */
 | |
|     public function getTooltipControl()
 | |
|     {
 | |
|         return $this->tooltipControl;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the Tooltip Control
 | |
|      *
 | |
|      * @api
 | |
|      * @param Control $tooltipControl Tooltip Control
 | |
|      * @return static
 | |
|      */
 | |
|     public function setTooltipControl(Control $tooltipControl)
 | |
|     {
 | |
|         $tooltipControl->checkId();
 | |
|         $tooltipControl->setVisible(false);
 | |
|         $this->tooltipControl = $tooltipControl;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the staying on click
 | |
|      *
 | |
|      * @api
 | |
|      * @return bool
 | |
|      */
 | |
|     public function getStayOnClick()
 | |
|     {
 | |
|         return $this->stayOnClick;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the staying on click
 | |
|      *
 | |
|      * @api
 | |
|      * @param bool $stayOnClick If the Tooltip should stay on click
 | |
|      * @return static
 | |
|      */
 | |
|     public function setStayOnClick($stayOnClick)
 | |
|     {
 | |
|         $this->stayOnClick = (bool)$stayOnClick;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get inverting of the visibility
 | |
|      *
 | |
|      * @api
 | |
|      * @return bool
 | |
|      */
 | |
|     public function getInvert()
 | |
|     {
 | |
|         return $this->invert;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set inverting of the visibility
 | |
|      *
 | |
|      * @api
 | |
|      * @param bool $invert If the visibility toggling should be inverted
 | |
|      * @return static
 | |
|      */
 | |
|     public function setInvert($invert)
 | |
|     {
 | |
|         $this->invert = (bool)$invert;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the text
 | |
|      *
 | |
|      * @api
 | |
|      * @return string
 | |
|      */
 | |
|     public function getText()
 | |
|     {
 | |
|         return $this->text;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the text
 | |
|      *
 | |
|      * @api
 | |
|      * @param string $text Text to display if the TooltipControl is a Label
 | |
|      * @return static
 | |
|      */
 | |
|     public function setText($text)
 | |
|     {
 | |
|         $this->text = (string)$text;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * @see ScriptFeature::prepare()
 | |
|      */
 | |
|     public function prepare(Script $script)
 | |
|     {
 | |
|         $hoverControlId   = Builder::escapeText($this->hoverControl->getId());
 | |
|         $tooltipControlId = Builder::escapeText($this->tooltipControl->getId());
 | |
| 
 | |
|         // MouseOver
 | |
|         $visibility = Builder::getBoolean(!$this->invert);
 | |
|         $scriptText = "
 | |
| if (Event.Control.ControlId == {$hoverControlId}) {
 | |
| 	declare TooltipControl = Page.GetFirstChild({$tooltipControlId});
 | |
| 	TooltipControl.Visible = {$visibility};";
 | |
|         if (is_string($this->text) && ($this->tooltipControl instanceof Label)) {
 | |
|             $tooltipText = Builder::escapeText($this->text);
 | |
|             $scriptText .= "
 | |
| 	declare TooltipLabel = (TooltipControl as CMlLabel);
 | |
| 	TooltipLabel.Value = {$tooltipText};";
 | |
|         }
 | |
|         $scriptText .= "
 | |
| }";
 | |
|         $script->appendGenericScriptLabel(ScriptLabel::MOUSEOVER, $scriptText);
 | |
| 
 | |
|         // MouseOut
 | |
|         $visibility = Builder::getBoolean($this->invert);
 | |
|         $scriptText = "
 | |
| if (Event.Control.ControlId == {$hoverControlId}) {
 | |
| 	declare TooltipControl = Page.GetFirstChild({$tooltipControlId});";
 | |
|         if ($this->stayOnClick) {
 | |
|             $scriptText .= "
 | |
| 	declare FML_Clicked for Event.Control = False;
 | |
| 	if (!FML_Clicked) ";
 | |
|         }
 | |
|         $scriptText .= "
 | |
| 	TooltipControl.Visible = {$visibility};
 | |
| }";
 | |
|         $script->appendGenericScriptLabel(ScriptLabel::MOUSEOUT, $scriptText);
 | |
| 
 | |
|         // MouseClick
 | |
|         if ($this->stayOnClick) {
 | |
|             $scriptText = "
 | |
| if (Event.Control.ControlId == {$hoverControlId}) {
 | |
| 	declare FML_Clicked for Event.Control = False;
 | |
| 	FML_Clicked = !FML_Clicked;
 | |
| }";
 | |
|             $script->appendGenericScriptLabel(ScriptLabel::MOUSECLICK, $scriptText);
 | |
|         }
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
| }
 |