193 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
 | 
						|
namespace FML;
 | 
						|
 | 
						|
/**
 | 
						|
 * Class representing a Custom_UI
 | 
						|
 *
 | 
						|
 * @author    steeffeen
 | 
						|
 * @copyright FancyManiaLinks Copyright © 2014 Steffen Schröder
 | 
						|
 * @license   http://www.gnu.org/licenses/ GNU General Public License, Version 3
 | 
						|
 */
 | 
						|
class CustomUI {
 | 
						|
	/*
 | 
						|
	 * Protected properties
 | 
						|
	 */
 | 
						|
	protected $encoding = 'utf-8';
 | 
						|
	protected $tagName = 'custom_ui';
 | 
						|
	protected $noticeVisible = null;
 | 
						|
	protected $challengeInfoVisible = null;
 | 
						|
	protected $netInfosVisible = null;
 | 
						|
	protected $chatVisible = null;
 | 
						|
	protected $checkpointListVisible = null;
 | 
						|
	protected $roundScoresVisible = null;
 | 
						|
	protected $scoretableVisible = null;
 | 
						|
	protected $globalVisible = null;
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Create a new CustomUI object
 | 
						|
	 *
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public static function create() {
 | 
						|
		return new static();
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set XML encoding
 | 
						|
	 *
 | 
						|
	 * @param string $encoding XML encoding
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setXMLEncoding($encoding) {
 | 
						|
		$this->encoding = (string)$encoding;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of notices
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether notices should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setNoticeVisible($visible) {
 | 
						|
		$this->noticeVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of the challenge info
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the challenge info should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setChallengeInfoVisible($visible) {
 | 
						|
		$this->challengeInfoVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of the net infos
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the net infos should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setNetInfosVisible($visible) {
 | 
						|
		$this->netInfosVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of the chat
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the chat should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setChatVisible($visible) {
 | 
						|
		$this->chatVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of the checkpoint list
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the checkpoint should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setCheckpointListVisible($visible) {
 | 
						|
		$this->checkpointListVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of round scores
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the round scores should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setRoundScoresVisible($visible) {
 | 
						|
		$this->roundScoresVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set showing of the scoretable
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the scoretable should be shown
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setScoretableVisible($visible) {
 | 
						|
		$this->scoretableVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Set global showing
 | 
						|
	 *
 | 
						|
	 * @param bool $visible Whether the UI should be disabled completely
 | 
						|
	 * @return static
 | 
						|
	 */
 | 
						|
	public function setGlobalVisible($visible) {
 | 
						|
		$this->globalVisible = $visible;
 | 
						|
		return $this;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Render the XML document
 | 
						|
	 *
 | 
						|
	 * @param \DOMDocument $domDocument (optional) DOMDocument for which the XML element should be rendered
 | 
						|
	 * @return \DOMDocument
 | 
						|
	 */
 | 
						|
	public function render($domDocument = null) {
 | 
						|
		$isChild = (bool)$domDocument;
 | 
						|
		if (!$isChild) {
 | 
						|
			$domDocument                = new \DOMDocument('1.0', $this->encoding);
 | 
						|
			$domDocument->xmlStandalone = true;
 | 
						|
		}
 | 
						|
		$xmlElement = $domDocument->createElement($this->tagName);
 | 
						|
		if (!$isChild) {
 | 
						|
			$domDocument->appendChild($xmlElement);
 | 
						|
		}
 | 
						|
		$settings = $this->getSettings();
 | 
						|
		foreach ($settings as $setting => $value) {
 | 
						|
			if (is_null($value)) {
 | 
						|
				continue;
 | 
						|
			}
 | 
						|
			$xmlSubElement = $domDocument->createElement($setting);
 | 
						|
			$xmlSubElement->setAttribute('visible', ($value ? 1 : 0));
 | 
						|
			$xmlElement->appendChild($xmlSubElement);
 | 
						|
		}
 | 
						|
		if ($isChild) {
 | 
						|
			return $xmlElement;
 | 
						|
		}
 | 
						|
		return $domDocument;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Get string representation
 | 
						|
	 *
 | 
						|
	 * @return string
 | 
						|
	 */
 | 
						|
	public function __toString() {
 | 
						|
		return $this->render()->saveXML();
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Get associative array of all CustomUI settings
 | 
						|
	 *
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	protected function getSettings() {
 | 
						|
		$settings                    = array();
 | 
						|
		$settings['challenge_info']  = $this->challengeInfoVisible;
 | 
						|
		$settings['chat']            = $this->chatVisible;
 | 
						|
		$settings['checkpoint_list'] = $this->checkpointListVisible;
 | 
						|
		$settings['global']          = $this->globalVisible;
 | 
						|
		$settings['net_infos']       = $this->netInfosVisible;
 | 
						|
		$settings['notice']          = $this->noticeVisible;
 | 
						|
		$settings['round_scores']    = $this->roundScoresVisible;
 | 
						|
		$settings['scoretable']      = $this->scoretableVisible;
 | 
						|
		return $settings;
 | 
						|
	}
 | 
						|
}
 |