- worked on ingame configurator (not possible like that!)
- fml fix
This commit is contained in:
parent
284fc5f6e7
commit
1871617ac9
@ -18,6 +18,8 @@ use FML\Script\Menus;
|
|||||||
use FML\Script\Pages;
|
use FML\Script\Pages;
|
||||||
use FML\Script\Script;
|
use FML\Script\Script;
|
||||||
use FML\Script\Tooltips;
|
use FML\Script\Tooltips;
|
||||||
|
use FML\Controls\Quads\Quad_Icons64x64_1;
|
||||||
|
use FML\ManiaLinks;
|
||||||
|
|
||||||
require_once __DIR__ . '/ConfiguratorMenu.php';
|
require_once __DIR__ . '/ConfiguratorMenu.php';
|
||||||
require_once __DIR__ . '/ScriptSettings.php';
|
require_once __DIR__ . '/ScriptSettings.php';
|
||||||
@ -172,7 +174,10 @@ class Configurator implements CallbackListener, ManialinkPageAnswerListener {
|
|||||||
$subMenuWidth = $menuWidth - $menuListWidth;
|
$subMenuWidth = $menuWidth - $menuListWidth;
|
||||||
$subMenuHeight = $menuHeight;
|
$subMenuHeight = $menuHeight;
|
||||||
|
|
||||||
|
$manialinks = new ManiaLinks();
|
||||||
|
|
||||||
$manialink = new ManiaLink(self::MLID_MENU);
|
$manialink = new ManiaLink(self::MLID_MENU);
|
||||||
|
$manialinks->add($manialink);
|
||||||
|
|
||||||
$frame = new Frame();
|
$frame = new Frame();
|
||||||
$manialink->add($frame);
|
$manialink->add($frame);
|
||||||
@ -231,6 +236,14 @@ class Configurator implements CallbackListener, ManialinkPageAnswerListener {
|
|||||||
}
|
}
|
||||||
$menus->add($menuRelationships);
|
$menus->add($menuRelationships);
|
||||||
|
|
||||||
|
// Add Close Quad (X)
|
||||||
|
$closeQuad = new Quad_Icons64x64_1();
|
||||||
|
$frame->add($closeQuad);
|
||||||
|
$closeQuad->setPosition($menuWidth * 0.484, $menuHeight * 0.47, 3);
|
||||||
|
$closeQuad->setSize(6, 6);
|
||||||
|
$closeQuad->setSubStyle(Quad_Icons64x64_1::SUBSTYLE_QuitRace);
|
||||||
|
$closeQuad->setAction(self::ACTION_TOGGLEMENU);
|
||||||
|
|
||||||
// Add close button
|
// Add close button
|
||||||
$closeButton = new Label();
|
$closeButton = new Label();
|
||||||
$frame->add($closeButton);
|
$frame->add($closeButton);
|
||||||
@ -253,7 +266,7 @@ class Configurator implements CallbackListener, ManialinkPageAnswerListener {
|
|||||||
$saveButton->setText('Save');
|
$saveButton->setText('Save');
|
||||||
$saveButton->setAction(self::ACTION_SAVECONFIG);
|
$saveButton->setAction(self::ACTION_SAVECONFIG);
|
||||||
|
|
||||||
$this->manialink = $manialink;
|
$this->manialink = $manialinks;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -80,20 +80,20 @@ class ScriptSettings implements ConfiguratorMenu {
|
|||||||
// Pagers
|
// Pagers
|
||||||
$pagerPrev = new Quad_Icons64x64_1();
|
$pagerPrev = new Quad_Icons64x64_1();
|
||||||
$frame->add($pagerPrev);
|
$frame->add($pagerPrev);
|
||||||
$pagerPrev->setPosition($width * 0.39, $height * -0.44);
|
$pagerPrev->setPosition($width * 0.39, $height * -0.44, 2);
|
||||||
$pagerPrev->setSize($pagerSize, $pagerSize);
|
$pagerPrev->setSize($pagerSize, $pagerSize);
|
||||||
$pagerPrev->setSubStyle(Quad_Icons64x64_1::SUBSTYLE_ArrowPrev);
|
$pagerPrev->setSubStyle(Quad_Icons64x64_1::SUBSTYLE_ArrowPrev);
|
||||||
|
|
||||||
$pagerNext = new Quad_Icons64x64_1();
|
$pagerNext = new Quad_Icons64x64_1();
|
||||||
$frame->add($pagerNext);
|
$frame->add($pagerNext);
|
||||||
$pagerNext->setPosition($width * 0.45, $height * -0.44);
|
$pagerNext->setPosition($width * 0.45, $height * -0.44, 2);
|
||||||
$pagerNext->setSize($pagerSize, $pagerSize);
|
$pagerNext->setSize($pagerSize, $pagerSize);
|
||||||
$pagerNext->setSubStyle(Quad_Icons64x64_1::SUBSTYLE_ArrowNext);
|
$pagerNext->setSubStyle(Quad_Icons64x64_1::SUBSTYLE_ArrowNext);
|
||||||
|
|
||||||
$pageCountLabel = new Label();
|
$pageCountLabel = new Label();
|
||||||
$frame->add($pageCountLabel);
|
$frame->add($pageCountLabel);
|
||||||
$pageCountLabel->setHAlign(Control::RIGHT);
|
$pageCountLabel->setHAlign(Control::RIGHT);
|
||||||
$pageCountLabel->setPosition($width * 0.35, $height * -0.44);
|
$pageCountLabel->setPosition($width * 0.35, $height * -0.44, 1);
|
||||||
$pageCountLabel->setStyle('TextTitle1');
|
$pageCountLabel->setStyle('TextTitle1');
|
||||||
$pageCountLabel->setTextSize(2);
|
$pageCountLabel->setTextSize(2);
|
||||||
|
|
||||||
|
@ -128,11 +128,17 @@ class ManiaLink implements Container {
|
|||||||
* @return \DOMDocument
|
* @return \DOMDocument
|
||||||
*/
|
*/
|
||||||
public function render($echo = false, $domDocument = null) {
|
public function render($echo = false, $domDocument = null) {
|
||||||
if (!$domDocument) {
|
$isChild = false;
|
||||||
|
if ($domDocument) {
|
||||||
|
$isChild = true;
|
||||||
|
}
|
||||||
|
if (!$isChild) {
|
||||||
$domDocument = new \DOMDocument('1.0', $this->encoding);
|
$domDocument = new \DOMDocument('1.0', $this->encoding);
|
||||||
}
|
}
|
||||||
$manialink = $domDocument->createElement($this->tagName);
|
$manialink = $domDocument->createElement($this->tagName);
|
||||||
$domDocument->appendChild($manialink);
|
if (!$isChild) {
|
||||||
|
$domDocument->appendChild($manialink);
|
||||||
|
}
|
||||||
if ($this->id) {
|
if ($this->id) {
|
||||||
$manialink->setAttribute('id', $this->id);
|
$manialink->setAttribute('id', $this->id);
|
||||||
}
|
}
|
||||||
@ -157,6 +163,9 @@ class ManiaLink implements Container {
|
|||||||
$scriptXml = $this->script->render($domDocument);
|
$scriptXml = $this->script->render($domDocument);
|
||||||
$manialink->appendChild($scriptXml);
|
$manialink->appendChild($scriptXml);
|
||||||
}
|
}
|
||||||
|
if ($isChild) {
|
||||||
|
return $manialink;
|
||||||
|
}
|
||||||
if ($echo) {
|
if ($echo) {
|
||||||
header('Content-Type: application/xml');
|
header('Content-Type: application/xml');
|
||||||
echo $domDocument->saveXML();
|
echo $domDocument->saveXML();
|
||||||
|
@ -56,10 +56,11 @@ class ManiaLinks {
|
|||||||
*/
|
*/
|
||||||
public function render($echo = false) {
|
public function render($echo = false) {
|
||||||
$domDocument = new \DOMDocument('1.0', $this->encoding);
|
$domDocument = new \DOMDocument('1.0', $this->encoding);
|
||||||
$manialink = $domDocument->createElement($this->tagName);
|
$manialinks = $domDocument->createElement($this->tagName);
|
||||||
$domDocument->appendChild($manialink);
|
$domDocument->appendChild($manialinks);
|
||||||
foreach ($this->children as $child) {
|
foreach ($this->children as $child) {
|
||||||
$child->render(false, $domDocument);
|
$childXml = $child->render(false, $domDocument);
|
||||||
|
$manialinks->appendChild($childXml);
|
||||||
}
|
}
|
||||||
if ($echo) {
|
if ($echo) {
|
||||||
header('Content-Type: application/xml');
|
header('Content-Type: application/xml');
|
||||||
|
@ -97,8 +97,8 @@ class ManiaControl implements CommandListener {
|
|||||||
$this->playerManager = new PlayerManager($this);
|
$this->playerManager = new PlayerManager($this);
|
||||||
$this->authenticationManager = new AuthenticationManager($this);
|
$this->authenticationManager = new AuthenticationManager($this);
|
||||||
$this->mapManager = new MapManager($this);
|
$this->mapManager = new MapManager($this);
|
||||||
$this->pluginManager = new PluginManager($this);
|
|
||||||
$this->configurator = new Configurator($this);
|
$this->configurator = new Configurator($this);
|
||||||
|
$this->pluginManager = new PluginManager($this);
|
||||||
|
|
||||||
$this->commandManager->registerCommandListener('version', $this, 'command_Version');
|
$this->commandManager->registerCommandListener('version', $this, 'command_Version');
|
||||||
}
|
}
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
namespace ManiaControl\Plugins;
|
namespace ManiaControl\Plugins;
|
||||||
|
|
||||||
require_once __DIR__ . '/Plugin.php';
|
require_once __DIR__ . '/Plugin.php';
|
||||||
|
require_once __DIR__ . '/PluginMenu.php';
|
||||||
|
|
||||||
use ManiaControl\ManiaControl;
|
use ManiaControl\ManiaControl;
|
||||||
|
|
||||||
@ -21,6 +22,7 @@ class PluginManager {
|
|||||||
* Private properties
|
* Private properties
|
||||||
*/
|
*/
|
||||||
private $maniaControl = null;
|
private $maniaControl = null;
|
||||||
|
private $pluginMenu = null;
|
||||||
private $activePlugins = array();
|
private $activePlugins = array();
|
||||||
private $pluginClasses = array();
|
private $pluginClasses = array();
|
||||||
|
|
||||||
@ -32,6 +34,9 @@ class PluginManager {
|
|||||||
public function __construct(ManiaControl $maniaControl) {
|
public function __construct(ManiaControl $maniaControl) {
|
||||||
$this->maniaControl = $maniaControl;
|
$this->maniaControl = $maniaControl;
|
||||||
$this->initTables();
|
$this->initTables();
|
||||||
|
|
||||||
|
$this->pluginMenu = new PluginMenu($maniaControl);
|
||||||
|
$this->maniaControl->configurator->addMenu($this->pluginMenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
57
application/core/Plugins/PluginMenu.php
Normal file
57
application/core/Plugins/PluginMenu.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace ManiaControl\Plugins;
|
||||||
|
|
||||||
|
use ManiaControl\ManiaControl;
|
||||||
|
use ManiaControl\Players\Player;
|
||||||
|
use ManiaControl\Configurators\ConfiguratorMenu;
|
||||||
|
use FML\Script\Pages;
|
||||||
|
use FML\Script\Tooltips;
|
||||||
|
use FML\Controls\Frame;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configurator for enabling and disabling plugins
|
||||||
|
*
|
||||||
|
* @author steeffeen
|
||||||
|
*/
|
||||||
|
class PluginMenu implements ConfiguratorMenu {
|
||||||
|
/**
|
||||||
|
* Private properties
|
||||||
|
*/
|
||||||
|
private $maniaControl = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a new plugin menu instance
|
||||||
|
*
|
||||||
|
* @param ManiaControl $maniaControl
|
||||||
|
*/
|
||||||
|
public function __construct(ManiaControl $maniaControl) {
|
||||||
|
$this->maniaControl = $maniaControl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @see \ManiaControl\Configurators\ConfiguratorMenu::getTitle()
|
||||||
|
*/
|
||||||
|
public function getTitle() {
|
||||||
|
return "Plugins";
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @see \ManiaControl\Configurators\ConfiguratorMenu::getMenu()
|
||||||
|
*/
|
||||||
|
public function getMenu($width, $height, Pages $pages, Tooltips $tooltips) {
|
||||||
|
$frame = new Frame();
|
||||||
|
return $frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @see \ManiaControl\Configurators\ConfiguratorMenu::saveConfigData()
|
||||||
|
*/
|
||||||
|
public function saveConfigData(array $configData, Player $player) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
Loading…
Reference in New Issue
Block a user