- Improved Chatlog Plugin

- First Step for ManialinkManager
- Added FML Update + MC-Fixes for the changes
This commit is contained in:
Steffen Schröder
2013-11-28 02:04:06 +01:00
parent 3984dd3d9b
commit 4e02b4b8ea
14 changed files with 210 additions and 120 deletions

View File

@ -0,0 +1,98 @@
<?php
namespace ManiaControl\Manialinks;
use ManiaControl\ManiaControl;
use ManiaControl\Callbacks\CallbackListener;
use ManiaControl\Callbacks\CallbackManager;
require_once __DIR__ . '/ManialinkPageAnswerListener.php';
require_once __DIR__ . '/../FML/autoload.php';
/**
* Manialink manager class
*
* @author steeffeen & kremsy
*/
class ManialinkManager implements CallbackListener {
/**
* Private properties
*/
private $maniaControl = null;
private $pageAnswerListeners = array();
/**
* Create a new manialink manager
*
* @param ManiaControl $maniaControl
*/
public function __construct(ManiaControl $maniaControl) {
$this->maniaControl = $maniaControl;
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,
'handleManialinkPageAnswer');
}
/**
* Register a new manialink page answer listener
*
* @param string $manialinkId
* @param ManialinkPageAnswerListener $listener
* @param string $method
* @return bool
*/
public function registerManialinkPageAnswerListener($manialinkId, ManialinkPageAnswerListener $listener, $method) {
if (!method_exists($listener, $method)) {
trigger_error("Given listener for manialinkId '{$manialinkId}' doesn't have callback method '{$method}'.");
return false;
}
if (!array_key_exists($manialinkId, $this->pageAnswerListeners) || !is_array($this->pageAnswerListeners[$manialinkId])) {
// Init listeners array
$this->pageAnswerListeners[$manialinkId] = array();
}
// Register page answer listener
array_push($this->pageAnswerListeners[$manialinkId], array($listener, $method));
return true;
}
/**
* Handle ManialinkPageAnswer callback
*
* @param array $callback
*/
public function handleManialinkPageAnswer(array $callback) {
var_dump($callback);
}
/**
* Send the given manialink to players
*
* @param string $manialinkText
* @param mixed $logins
* @param int $timeout
* @param bool $hideOnClick
* @return bool
*/
public function sendManialink($manialinkText, $logins = null, $timeout = 0, $hideOnClick = false) {
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_array($logins)) {
$success = true;
foreach ($logins as $login) {
$subSuccess = $this->maniaControl->client->query('SendDisplayManialinkPageToLogin', $login, $manialinkText, $timeout,
$hideOnClick);
if (!$subSuccess) {
$success = false;
}
}
return $success;
}
return false;
}
}
?>

View File

@ -0,0 +1,13 @@
<?php
namespace ManiaControl\Manialinks;
/**
* Interface for manialink page answer listeners
*
* @author steeffeen & kremsy
*/
interface ManialinkPageAnswerListener {
}
?>

View File

@ -1,93 +0,0 @@
<?php
namespace ManiaControl\Manialinks;
require_once __DIR__ . '/../FML/autoload.php';
/**
* Manialink utility class
*
* @author steeffeen & kremsy
*/
abstract class ManialinkUtil {
/**
* Send the given manialink to players
*
* @param \IXR_ClientMulticall_Gbx $client
* @param string $manialink
* @param mixed $logins
* @param int $timeout
* @param bool $hideOnClick
* @return bool
*/
public static function sendManialinkPage(\IXR_ClientMulticall_Gbx $client, $manialinkText, $logins = null, $timeout = 0,
$hideOnClick = false) {
if (!$client || !$manialinkText) {
return false;
}
if (!$logins) {
return $client->query('SendDisplayManialinkPage', $manialinkText, $timeout, $hideOnClick);
}
if (is_string($logins)) {
return $client->query('SendDisplayManialinkPageToLogin', $logins, $manialinkText, $timeout, $hideOnClick);
}
if (is_array($logins)) {
$success = true;
foreach ($logins as $login) {
$subSuccess = $client->query('SendDisplayManialinkPageToLogin', $login, $manialinkText, $timeout, $hideOnClick);
if (!$subSuccess) {
$success = false;
}
}
return $success;
}
return false;
}
/**
* Build new simple xml element
*
* @param string $name
* @param string $id
* @return \SimpleXMLElement
*/
public static function newManialinkXml($id = null) {
$xml = new \SimpleXMLElement('<?xml version="1.0" encoding="UTF-8" standalone="yes"?><manialink/>');
$xml->addAttribute('version', '1');
if ($id) {
$xml->addAttribute('id', $id);
}
return $xml;
}
/**
* Add alignment attributes to an xml element
*
* @param \SimpleXMLElement $xml
* @param string $halign
* @param string $valign
*/
public static function addAlignment(\SimpleXMLElement $xml, $halign = 'center', $valign = 'center2') {
if (!property_exists($xml, 'halign')) {
$xml->addAttribute('halign', $halign);
}
if (!property_exists($xml, 'valign')) {
$xml->addAttribute('valign', $valign);
}
}
/**
* Add translate attribute to an xml element
*
* @param \SimpleXMLElement $xml
* @param bool $translate
*/
public static function addTranslate(\SimpleXMLElement $xml, $translate = true) {
if (!property_exists($xml, 'translate')) {
$xml->addAttribute('translate', ($translate ? 1 : 0));
}
}
}
?>