163 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.4 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 © 2014 Steffen Schröder
 | 
						|
 * @license   http://www.gnu.org/licenses/ GNU General Public License, Version 3
 | 
						|
 */
 | 
						|
class Tooltip extends ScriptFeature {
 | 
						|
	/*
 | 
						|
	 * Protected properties
 | 
						|
	 */
 | 
						|
	/** @var Control $hoverControl */
 | 
						|
	protected $hoverControl = null;
 | 
						|
	/** @var Control $tooltipControl */
 | 
						|
	protected $tooltipControl = null;
 | 
						|
	protected $stayOnClick = null;
 | 
						|
	protected $invert = null;
 | 
						|
	protected $text = null;
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Construct a new Tooltip Feature
 | 
						|
	 *
 | 
						|
	 * @param Control $hoverControl   (optional) Hover Control
 | 
						|
	 * @param Control $tooltipControl (optional) Tooltip Control
 | 
						|
	 * @param bool    $stayOnClick    (optional) Whether the Tooltip should stay on click
 | 
						|
	 * @param bool    $invert         (optional) Whether 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 = false, $invert = false, $text = null) {
 | 
						|
		if (!is_null($hoverControl)) {
 | 
						|
			$this->setHoverControl($hoverControl);
 | 
						|
		}
 | 
						|
		if (!is_null($tooltipControl)) {
 | 
						|
			$this->setTooltipControl($tooltipControl);
 | 
						|
		}
 | 
						|
		$this->setStayOnClick($stayOnClick);
 | 
						|
		$this->setInvert($invert);
 | 
						|
		if (!is_null($text)) {
 | 
						|
			$this->setText($text);
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set the Hover Control
 | 
						|
	 *
 | 
						|
	 * @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;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set the Tooltip Control
 | 
						|
	 *
 | 
						|
	 * @param Control $tooltipControl Tooltip Control
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setTooltipControl(Control $tooltipControl) {
 | 
						|
		$this->tooltipControl = $tooltipControl->checkId()->setVisible(false);
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set to only show
 | 
						|
	 *
 | 
						|
	 * @param bool $stayOnClick (optional) Whether the Tooltip should stay on click
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setStayOnClick($stayOnClick) {
 | 
						|
		$this->stayOnClick = (bool)$stayOnClick;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set to only hide
 | 
						|
	 *
 | 
						|
	 * @param bool $invert (optional) Whether the visibility toggling should be inverted
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setInvert($invert) {
 | 
						|
		$this->invert = (bool)$invert;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set text
 | 
						|
	 *
 | 
						|
	 * @param string $text (optional) Text to display if the TooltipControl is a Label
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setText($text) {
 | 
						|
		$this->text = (string)$text;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * @see \FML\Script\Features\ScriptFeature::prepare()
 | 
						|
	 */
 | 
						|
	public function prepare(Script $script) {
 | 
						|
		$hoverControlId   = $this->hoverControl->getId(true, true);
 | 
						|
		$tooltipControlId = $this->tooltipControl->getId(true, true);
 | 
						|
 | 
						|
		// MouseOver
 | 
						|
		$visibility = ($this->invert ? 'False' : 'True');
 | 
						|
		$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, true);
 | 
						|
			$scriptText .= "
 | 
						|
	declare TooltipLabel = (TooltipControl as CMlLabel);
 | 
						|
	TooltipLabel.Value = {$tooltipText};";
 | 
						|
		}
 | 
						|
		$scriptText .= "
 | 
						|
}";
 | 
						|
		$script->appendGenericScriptLabel(ScriptLabel::MOUSEOVER, $scriptText);
 | 
						|
 | 
						|
		// MouseOut
 | 
						|
		$visibility = ($this->invert ? 'True' : 'False');
 | 
						|
		$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;
 | 
						|
	}
 | 
						|
}
 |