removed reservermanialinks
This commit is contained in:
		@@ -49,47 +49,49 @@ class IconManager implements CallbackListener {
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * Adds an Icon
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param string $iconName
 | 
			
		||||
	 * @param string $iconLink
 | 
			
		||||
	 */
 | 
			
		||||
	public function addIcon($iconName, $iconLink = self::DEFAULT_IMG_URL){
 | 
			
		||||
	public function addIcon($iconName, $iconLink = self::DEFAULT_IMG_URL) {
 | 
			
		||||
		$this->icons[$iconName] = $iconLink . "/" . $iconName;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * Gets an Icon by its name
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param $iconName
 | 
			
		||||
	 * @return string
 | 
			
		||||
	 */
 | 
			
		||||
	public function getIcon($iconName){
 | 
			
		||||
	public function getIcon($iconName) {
 | 
			
		||||
		return $this->icons[$iconName];
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * @param array $callback
 | 
			
		||||
	 */
 | 
			
		||||
	public function handleOnInit(array $callback){
 | 
			
		||||
	public function handleOnInit(array $callback) {
 | 
			
		||||
		$this->preloadIcons();
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * @param array $callback
 | 
			
		||||
	 */
 | 
			
		||||
	public function handlePlayerConnect(array $callback){
 | 
			
		||||
	public function handlePlayerConnect(array $callback) {
 | 
			
		||||
		$this->preloadIcons($callback[1]);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * Preload Icons
 | 
			
		||||
	 */
 | 
			
		||||
	private function preloadIcons($login = false){
 | 
			
		||||
	private function preloadIcons($login = false) {
 | 
			
		||||
		$maniaLink = new ManiaLink(self::PRELOAD_ML_ID);
 | 
			
		||||
 | 
			
		||||
		$frame = new Frame();
 | 
			
		||||
		$maniaLink->add($frame);
 | 
			
		||||
		$frame->setPosition(500, 500);
 | 
			
		||||
 | 
			
		||||
		foreach($this->icons as $iconUrl){
 | 
			
		||||
		foreach ($this->icons as $iconUrl) {
 | 
			
		||||
			$iconQuad = new Quad();
 | 
			
		||||
			$iconQuad->setImage($iconUrl);
 | 
			
		||||
			$iconQuad->setSize(10, 10);
 | 
			
		||||
 
 | 
			
		||||
@@ -2,15 +2,14 @@
 | 
			
		||||
 | 
			
		||||
namespace ManiaControl\Manialinks;
 | 
			
		||||
 | 
			
		||||
use ManiaControl\ManiaControl;
 | 
			
		||||
use ManiaControl\Callbacks\CallbackListener;
 | 
			
		||||
use ManiaControl\Callbacks\CallbackManager;
 | 
			
		||||
use ManiaControl\Manialinks\ManialinkPageAnswerListener;
 | 
			
		||||
use ManiaControl\Players\Player;
 | 
			
		||||
use FML\ManiaLink;
 | 
			
		||||
use FML\Controls\Control;
 | 
			
		||||
use FML\Controls\Frame;
 | 
			
		||||
use FML\Controls\Labels\Label_Text;
 | 
			
		||||
use FML\ManiaLink;
 | 
			
		||||
use ManiaControl\Callbacks\CallbackListener;
 | 
			
		||||
use ManiaControl\Callbacks\CallbackManager;
 | 
			
		||||
use ManiaControl\ManiaControl;
 | 
			
		||||
use ManiaControl\Players\Player;
 | 
			
		||||
 | 
			
		||||
require_once __DIR__ . '/StyleManager.php';
 | 
			
		||||
require_once __DIR__ . '/IconManager.php';
 | 
			
		||||
@@ -43,7 +42,6 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
	 */
 | 
			
		||||
	private $maniaControl = null;
 | 
			
		||||
	private $pageAnswerListeners = array();
 | 
			
		||||
	private $maniaLinkIdCount = 0;
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * Create a new manialink manager
 | 
			
		||||
@@ -58,8 +56,7 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
 | 
			
		||||
		// Register for callbacks
 | 
			
		||||
		$this->registerManialinkPageAnswerListener(self::ACTION_CLOSEWIDGET, $this, 'closeWidgetCallback');
 | 
			
		||||
		$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_PLAYERMANIALINKPAGEANSWER, $this, 
 | 
			
		||||
				'handleManialinkPageAnswer');
 | 
			
		||||
		$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_PLAYERMANIALINKPAGEANSWER, $this, 'handleManialinkPageAnswer');
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
@@ -71,16 +68,18 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
	 * @return bool
 | 
			
		||||
	 */
 | 
			
		||||
	public function registerManialinkPageAnswerListener($actionId, ManialinkPageAnswerListener $listener, $method) {
 | 
			
		||||
		if (!method_exists($listener, $method)) {
 | 
			
		||||
		if(!method_exists($listener, $method)) {
 | 
			
		||||
			trigger_error("Given listener for actionId '{$actionId}' doesn't have callback method '{$method}'!");
 | 
			
		||||
 | 
			
		||||
			return false;
 | 
			
		||||
		}
 | 
			
		||||
		if (!array_key_exists($actionId, $this->pageAnswerListeners) || !is_array($this->pageAnswerListeners[$actionId])) {
 | 
			
		||||
		if(!array_key_exists($actionId, $this->pageAnswerListeners) || !is_array($this->pageAnswerListeners[$actionId])) {
 | 
			
		||||
			// Init listeners array
 | 
			
		||||
			$this->pageAnswerListeners[$actionId] = array();
 | 
			
		||||
		}
 | 
			
		||||
		// Register page answer listener
 | 
			
		||||
		array_push($this->pageAnswerListeners[$actionId], array($listener, $method));
 | 
			
		||||
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
@@ -95,21 +94,8 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
		foreach ($keys as $key) {
 | 
			
		||||
			unset($this->pageAnswerListeners[$key]);
 | 
			
		||||
		}
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * Reserve manialink ids
 | 
			
		||||
	 *
 | 
			
		||||
	 * @param int $count
 | 
			
		||||
	 * @return array
 | 
			
		||||
	 */
 | 
			
		||||
	public function reserveManiaLinkIds($count) {
 | 
			
		||||
		$manialinkIds = array();
 | 
			
		||||
		for ($i = 0; $i < $count; $i++) {
 | 
			
		||||
			array_push($manialinkIds, $this->maniaLinkIdCount++);
 | 
			
		||||
		}
 | 
			
		||||
		return $manialinkIds;
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
@@ -121,7 +107,7 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
		$actionId = $callback[1][2];
 | 
			
		||||
		$login    = $callback[1][1];
 | 
			
		||||
		$player   = $this->maniaControl->playerManager->getPlayer($login);
 | 
			
		||||
		if (!array_key_exists($actionId, $this->pageAnswerListeners) || !is_array($this->pageAnswerListeners[$actionId])) {
 | 
			
		||||
		if(!array_key_exists($actionId, $this->pageAnswerListeners) || !is_array($this->pageAnswerListeners[$actionId])) {
 | 
			
		||||
			// No page answer listener registered
 | 
			
		||||
			return;
 | 
			
		||||
		}
 | 
			
		||||
@@ -141,24 +127,24 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
	 * @return bool
 | 
			
		||||
	 */
 | 
			
		||||
	public function sendManialink($manialinkText, $logins = null, $timeout = 0, $hideOnClick = false) {
 | 
			
		||||
		if (!$logins) {
 | 
			
		||||
		if(!$logins) {
 | 
			
		||||
			return $this->maniaControl->client->query('SendDisplayManialinkPage', $manialinkText, $timeout, $hideOnClick);
 | 
			
		||||
		}
 | 
			
		||||
		if (is_string($logins)) {
 | 
			
		||||
			return $this->maniaControl->client->query('SendDisplayManialinkPageToLogin', $logins, $manialinkText, $timeout, 
 | 
			
		||||
					$hideOnClick);
 | 
			
		||||
		if(is_string($logins)) {
 | 
			
		||||
			return $this->maniaControl->client->query('SendDisplayManialinkPageToLogin', $logins, $manialinkText, $timeout, $hideOnClick);
 | 
			
		||||
		}
 | 
			
		||||
		if (is_array($logins)) {
 | 
			
		||||
		if(is_array($logins)) {
 | 
			
		||||
			$success = true;
 | 
			
		||||
			foreach ($logins as $login) {
 | 
			
		||||
				$subSuccess = $this->maniaControl->client->query('SendDisplayManialinkPageToLogin', $login, $manialinkText, $timeout, 
 | 
			
		||||
						$hideOnClick);
 | 
			
		||||
				if (!$subSuccess) {
 | 
			
		||||
				$subSuccess = $this->maniaControl->client->query('SendDisplayManialinkPageToLogin', $login, $manialinkText, $timeout, $hideOnClick);
 | 
			
		||||
				if(!$subSuccess) {
 | 
			
		||||
					$success = false;
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			return $success;
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		return false;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
@@ -250,12 +236,13 @@ class ManialinkManager implements ManialinkPageAnswerListener, CallbackListener
 | 
			
		||||
			$label->setText($text);
 | 
			
		||||
			$label->setTextColor($textColor);
 | 
			
		||||
 | 
			
		||||
			if ($profile) {
 | 
			
		||||
			if($profile) {
 | 
			
		||||
				$script->addProfileButton($label, $profile);
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			$frames[] = $frame; // add Frame to the frames array
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		return $frames;
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user