288 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			288 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace FML\Controls;
 | |
| 
 | |
| use FML\Types\Renderable;
 | |
| 
 | |
| /**
 | |
|  * Class representing CMlControl
 | |
|  *
 | |
|  * @author steeffeen
 | |
|  */
 | |
| abstract class Control implements Renderable {
 | |
| 	/**
 | |
| 	 * Constants
 | |
| 	 */
 | |
| 	const CENTER = 'center';
 | |
| 	const CENTER2 = 'center2';
 | |
| 	const TOP = 'top';
 | |
| 	const RIGHT = 'right';
 | |
| 	const BOTTOM = 'bottom';
 | |
| 	const LEFT = 'left';
 | |
| 	
 | |
| 	/**
 | |
| 	 * Protected Properties
 | |
| 	 */
 | |
| 	protected $tagName = 'control';
 | |
| 	protected $id = '';
 | |
| 	protected $x = 0.;
 | |
| 	protected $y = 0.;
 | |
| 	protected $z = 0.;
 | |
| 	protected $width = -1.;
 | |
| 	protected $height = -1.;
 | |
| 	protected $hAlign = self::CENTER;
 | |
| 	protected $vAlign = self::CENTER2;
 | |
| 	protected $scale = 1.;
 | |
| 	protected $hidden = 0;
 | |
| 	protected $classes = array();
 | |
| 
 | |
| 	/**
 | |
| 	 * Construct a new Control
 | |
| 	 *
 | |
| 	 * @param string $id Control Id
 | |
| 	 */
 | |
| 	public function __construct($id = null) {
 | |
| 		if ($id !== null) {
 | |
| 			$this->setId($id);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get Control Id
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getId() {
 | |
| 		return $this->id;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Id
 | |
| 	 *
 | |
| 	 * @param string $id Control Id
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setId($id) {
 | |
| 		$this->id = $id;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Check Id for dangerous Characters and assign an unique Id if necessary
 | |
| 	 *
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function checkId() {
 | |
| 		if (!$this->getId()) {
 | |
| 			$this->setId(uniqid());
 | |
| 			return $this;
 | |
| 		}
 | |
| 		$dangerousCharacters = array(' ', '	', '.', '|', '-', PHP_EOL);
 | |
| 		$idCharacters = str_split($this->getId());
 | |
| 		$danger = false;
 | |
| 		foreach ($idCharacters as $character) {
 | |
| 			if (!in_array($character, $dangerousCharacters)) continue;
 | |
| 			$danger = true;
 | |
| 			break;
 | |
| 		}
 | |
| 		if ($danger) {
 | |
| 			trigger_error("Please don't use special Characters in Ids, they might cause Problems! (I stripped them for You.)");
 | |
| 			$id = str_ireplace($dangerousCharacters, '', $this->getId());
 | |
| 			$this->setId($id);
 | |
| 		}
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set X Position
 | |
| 	 *
 | |
| 	 * @param float $x Horizontal Position
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setX($x) {
 | |
| 		$this->x = $x;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Y Position
 | |
| 	 *
 | |
| 	 * @param float $y Vertical Position
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setY($y) {
 | |
| 		$this->y = $y;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Z Position
 | |
| 	 *
 | |
| 	 * @param float $z Depth
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setZ($z) {
 | |
| 		$this->z = $z;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Position
 | |
| 	 *
 | |
| 	 * @param float $x Horizontal Position
 | |
| 	 * @param float $y Vertical Position
 | |
| 	 * @param float $z Depth
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setPosition($x, $y, $z = null) {
 | |
| 		$this->setX($x);
 | |
| 		$this->setY($y);
 | |
| 		if ($z !== null) {
 | |
| 			$this->setZ($z);
 | |
| 		}
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Width
 | |
| 	 *
 | |
| 	 * @param float $width Control Width
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setWidth($width) {
 | |
| 		$this->width = $width;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Height
 | |
| 	 *
 | |
| 	 * @param float $height Control Height
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setHeight($height) {
 | |
| 		$this->height = $height;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Size
 | |
| 	 *
 | |
| 	 * @param float $width Control Width
 | |
| 	 * @param float $height Control Height
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setSize($width, $height) {
 | |
| 		$this->setWidth($width);
 | |
| 		$this->setHeight($height);
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Horizontal Alignment
 | |
| 	 *
 | |
| 	 * @param string $hAlign Horizontal Alignment
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setHAlign($hAlign) {
 | |
| 		$this->hAlign = $hAlign;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Vertical Alignment
 | |
| 	 *
 | |
| 	 * @param string $vAlign Vertical Alignment
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setVAlign($vAlign) {
 | |
| 		$this->vAlign = $vAlign;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Horizontal and Vertical Alignment
 | |
| 	 *
 | |
| 	 * @param string $hAlign Horizontal Alignment
 | |
| 	 * @param string $vAlign Vertical Alignment
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setAlign($hAlign, $vAlign) {
 | |
| 		$this->setHAlign($hAlign);
 | |
| 		$this->setVAlign($vAlign);
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Control Scale
 | |
| 	 *
 | |
| 	 * @param float $scale Control Scale
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setScale($scale) {
 | |
| 		$this->scale = $scale;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Visibility
 | |
| 	 *
 | |
| 	 * @param bool $visible If Control should be visible
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function setVisible($visible) {
 | |
| 		$this->hidden = ($visible ? 0 : 1);
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Add new Class Name
 | |
| 	 *
 | |
| 	 * @param string $class Class Name
 | |
| 	 * @return \FML\Controls\Control
 | |
| 	 */
 | |
| 	public function addClass($class) {
 | |
| 		if (!in_array($class, $this->classes)) {
 | |
| 			array_push($this->classes, $class);
 | |
| 		}
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 *
 | |
| 	 * @see \FML\Types\Renderable::render()
 | |
| 	 */
 | |
| 	public function render(\DOMDocument $domDocument) {
 | |
| 		$xml = $domDocument->createElement($this->tagName);
 | |
| 		if ($this->id) {
 | |
| 			$xml->setAttribute('id', $this->id);
 | |
| 		}
 | |
| 		if ($this->x !== 0. || $this->y !== 0. || $this->z !== 0.) {
 | |
| 			$xml->setAttribute('posn', "{$this->x} {$this->y} {$this->z}");
 | |
| 		}
 | |
| 		if ($this->width >= 0. || $this->height >= 0.) {
 | |
| 			$xml->setAttribute('sizen', "{$this->width} {$this->height}");
 | |
| 		}
 | |
| 		if ($this->hAlign) {
 | |
| 			$xml->setAttribute('halign', $this->hAlign);
 | |
| 		}
 | |
| 		if ($this->vAlign) {
 | |
| 			$xml->setAttribute('valign', $this->vAlign);
 | |
| 		}
 | |
| 		if ($this->scale !== 1.) {
 | |
| 			$xml->setAttribute('scale', $this->scale);
 | |
| 		}
 | |
| 		if ($this->hidden) {
 | |
| 			$xml->setAttribute('hidden', $this->hidden);
 | |
| 		}
 | |
| 		$classes = '';
 | |
| 		foreach ($this->classes as $class) {
 | |
| 			$classes .= $class . ' ';
 | |
| 		}
 | |
| 		if ($classes) {
 | |
| 			$xml->setAttribute('class', $classes);
 | |
| 		}
 | |
| 		return $xml;
 | |
| 	}
 | |
| }
 |