activated tooltip option OnClick
This commit is contained in:
parent
7c2508a0af
commit
eb37af0579
@ -205,7 +205,7 @@ class ActionsMenu implements CallbackListener, ManialinkPageAnswerListener {
|
|||||||
$backgroundQuad->setStyles($quadStyle, $quadSubstyle);
|
$backgroundQuad->setStyles($quadStyle, $quadSubstyle);
|
||||||
$backgroundQuad->setSize(count($this->adminMenuItems) * $itemSize * 1.15 + 2, $itemSize * $itemMarginFactorY);
|
$backgroundQuad->setSize(count($this->adminMenuItems) * $itemSize * 1.15 + 2, $itemSize * $itemMarginFactorY);
|
||||||
|
|
||||||
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_STAYONCLICK);
|
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_ONCLICK);
|
||||||
|
|
||||||
// Add items
|
// Add items
|
||||||
$x = -1;
|
$x = -1;
|
||||||
@ -273,7 +273,7 @@ class ActionsMenu implements CallbackListener, ManialinkPageAnswerListener {
|
|||||||
$backgroundQuad->setStyles($quadStyle, $quadSubstyle);
|
$backgroundQuad->setStyles($quadStyle, $quadSubstyle);
|
||||||
$backgroundQuad->setSize(count($this->playerMenuItems) * $itemSize * 1.15 + 2, $itemSize * $itemMarginFactorY);
|
$backgroundQuad->setSize(count($this->playerMenuItems) * $itemSize * 1.15 + 2, $itemSize * $itemMarginFactorY);
|
||||||
|
|
||||||
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_STAYONCLICK);
|
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_ONCLICK);
|
||||||
|
|
||||||
// Add items
|
// Add items
|
||||||
$x = -1;
|
$x = -1;
|
||||||
|
@ -20,7 +20,7 @@ use ManiaControl\Plugins\Plugin;
|
|||||||
/**
|
/**
|
||||||
* Donation plugin
|
* Donation plugin
|
||||||
*
|
*
|
||||||
* @author steeffeen and Lukas
|
* @author steeffeen & kremsy
|
||||||
*/
|
*/
|
||||||
class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
||||||
/**
|
/**
|
||||||
@ -44,7 +44,10 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
/**
|
/**
|
||||||
* Private properties
|
* Private properties
|
||||||
*/
|
*/
|
||||||
/** @var maniaControl $maniaControl */
|
/**
|
||||||
|
*
|
||||||
|
* @var maniaControl $maniaControl
|
||||||
|
*/
|
||||||
private $maniaControl = null;
|
private $maniaControl = null;
|
||||||
private $openBills = array();
|
private $openBills = array();
|
||||||
|
|
||||||
@ -64,7 +67,8 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_BILLUPDATED, $this, 'handleBillUpdated');
|
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_BILLUPDATED, $this, 'handleBillUpdated');
|
||||||
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MC_ONINIT, $this, 'handleOnInit');
|
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MC_ONINIT, $this, 'handleOnInit');
|
||||||
$this->maniaControl->callbackManager->registerCallbackListener(PlayerManager::CB_PLAYERJOINED, $this, 'handlePlayerConnect');
|
$this->maniaControl->callbackManager->registerCallbackListener(PlayerManager::CB_PLAYERJOINED, $this, 'handlePlayerConnect');
|
||||||
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_PLAYERMANIALINKPAGEANSWER, $this, 'handleManialinkPageAnswer');
|
$this->maniaControl->callbackManager->registerCallbackListener(CallbackManager::CB_MP_PLAYERMANIALINKPAGEANSWER, $this,
|
||||||
|
'handleManialinkPageAnswer');
|
||||||
|
|
||||||
// Define player stats
|
// Define player stats
|
||||||
$this->maniaControl->statisticManager->defineStatMetaData(self::STAT_PLAYER_DONATIONS);
|
$this->maniaControl->statisticManager->defineStatMetaData(self::STAT_PLAYER_DONATIONS);
|
||||||
@ -135,7 +139,7 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
* @param array $callback
|
* @param array $callback
|
||||||
*/
|
*/
|
||||||
public function handleOnInit(array $callback) {
|
public function handleOnInit(array $callback) {
|
||||||
if($this->maniaControl->settingManager->getSetting($this, self::SETTING_DONATE_WIDGET_ACTIVATED)) {
|
if ($this->maniaControl->settingManager->getSetting($this, self::SETTING_DONATE_WIDGET_ACTIVATED)) {
|
||||||
$this->displayDonateWidget();
|
$this->displayDonateWidget();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -148,18 +152,11 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
public function handleManialinkPageAnswer(array $callback) {
|
public function handleManialinkPageAnswer(array $callback) {
|
||||||
$actionId = $callback[1][2];
|
$actionId = $callback[1][2];
|
||||||
$boolSetting = (strpos($actionId, self::ACTION_DONATE_VALUE) === 0);
|
$boolSetting = (strpos($actionId, self::ACTION_DONATE_VALUE) === 0);
|
||||||
if(!$boolSetting) {
|
if (!$boolSetting) return;
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
$login = $callback[1][1];
|
$login = $callback[1][1];
|
||||||
|
|
||||||
$player = $this->maniaControl->playerManager->getPlayer($login);
|
$player = $this->maniaControl->playerManager->getPlayer($login);
|
||||||
|
|
||||||
$actionArray = explode(".", $callback[1][2]);
|
$actionArray = explode(".", $callback[1][2]);
|
||||||
|
|
||||||
$this->handleDonation($player, intval($actionArray[2]));
|
$this->handleDonation($player, intval($actionArray[2]));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -170,7 +167,7 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
public function handlePlayerConnect(array $callback) {
|
public function handlePlayerConnect(array $callback) {
|
||||||
$player = $callback[1];
|
$player = $callback[1];
|
||||||
// Display Map Widget
|
// Display Map Widget
|
||||||
if($this->maniaControl->settingManager->getSetting($this, self::SETTING_DONATE_WIDGET_ACTIVATED)) {
|
if ($this->maniaControl->settingManager->getSetting($this, self::SETTING_DONATE_WIDGET_ACTIVATED)) {
|
||||||
$this->displayDonateWidget($player->login);
|
$this->displayDonateWidget($player->login);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -194,11 +191,10 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
$itemSize = $width;
|
$itemSize = $width;
|
||||||
|
|
||||||
$maniaLink = new ManiaLink(self::MLID_DONATE_WIDGET);
|
$maniaLink = new ManiaLink(self::MLID_DONATE_WIDGET);
|
||||||
|
|
||||||
$script = new Script();
|
$script = new Script();
|
||||||
$maniaLink->setScript($script);
|
$maniaLink->setScript($script);
|
||||||
|
|
||||||
//Donate Menu Icon Frame
|
// Donate Menu Icon Frame
|
||||||
$frame = new Frame();
|
$frame = new Frame();
|
||||||
$maniaLink->add($frame);
|
$maniaLink->add($frame);
|
||||||
$frame->setPosition($posX, $posY);
|
$frame->setPosition($posX, $posY);
|
||||||
@ -219,7 +215,7 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
|
|
||||||
$valueArray = explode(",", $values);
|
$valueArray = explode(",", $values);
|
||||||
|
|
||||||
//Values Menu
|
// Values Menu
|
||||||
$popoutFrame = new Frame();
|
$popoutFrame = new Frame();
|
||||||
$maniaLink->add($popoutFrame);
|
$maniaLink->add($popoutFrame);
|
||||||
$popoutFrame->setPosition($posX - $itemSize * 0.5, $posY);
|
$popoutFrame->setPosition($posX - $itemSize * 0.5, $posY);
|
||||||
@ -232,12 +228,11 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
$quad->setStyles($quadStyle, $quadSubstyle);
|
$quad->setStyles($quadStyle, $quadSubstyle);
|
||||||
$quad->setSize(strlen($values) * 2 + count($valueArray) * 1, $itemSize * $itemMarginFactorY);
|
$quad->setSize(strlen($values) * 2 + count($valueArray) * 1, $itemSize * $itemMarginFactorY);
|
||||||
|
|
||||||
|
|
||||||
$popoutFrame->add($quad);
|
$popoutFrame->add($quad);
|
||||||
|
|
||||||
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_STAYONCLICK);
|
$script->addTooltip($itemQuad, $popoutFrame, Script::OPTION_TOOLTIP_ONCLICK);
|
||||||
|
|
||||||
//Description Label
|
// Description Label
|
||||||
$descriptionFrame = new Frame();
|
$descriptionFrame = new Frame();
|
||||||
$maniaLink->add($descriptionFrame);
|
$maniaLink->add($descriptionFrame);
|
||||||
$descriptionFrame->setPosition($posX - 50, $posY - 5);
|
$descriptionFrame->setPosition($posX - 50, $posY - 5);
|
||||||
@ -253,12 +248,12 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
|
|
||||||
// Add items
|
// Add items
|
||||||
$x = -2;
|
$x = -2;
|
||||||
foreach(array_reverse($valueArray) as $value) {
|
foreach (array_reverse($valueArray) as $value) {
|
||||||
$label = new Label_Button();
|
$label = new Label_Button();
|
||||||
$popoutFrame->add($label);
|
$popoutFrame->add($label);
|
||||||
$label->setX($x);
|
$label->setX($x);
|
||||||
$label->setHAlign(Control::RIGHT);
|
$label->setHAlign(Control::RIGHT);
|
||||||
$label->setText('$s$FFF'.$value . '$09FP');
|
$label->setText('$s$FFF' . $value . '$09FP');
|
||||||
$label->setTextSize(1.2);
|
$label->setTextSize(1.2);
|
||||||
$label->setAction(self::ACTION_DONATE_VALUE . "." . $value);
|
$label->setAction(self::ACTION_DONATE_VALUE . "." . $value);
|
||||||
$label->setStyle(Label_Text::STYLE_TextCardSmall);
|
$label->setStyle(Label_Text::STYLE_TextCardSmall);
|
||||||
@ -267,7 +262,6 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
$x -= strlen($value) * 2 + 1.7;
|
$x -= strlen($value) * 2 + 1.7;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Send manialink
|
// Send manialink
|
||||||
$manialinkText = $maniaLink->render()->saveXML();
|
$manialinkText = $maniaLink->render()->saveXML();
|
||||||
$this->maniaControl->manialinkManager->sendManialink($manialinkText, $login);
|
$this->maniaControl->manialinkManager->sendManialink($manialinkText, $login);
|
||||||
@ -283,21 +277,21 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
public function command_Donate(array $chatCallback, Player $player) {
|
public function command_Donate(array $chatCallback, Player $player) {
|
||||||
$text = $chatCallback[1][2];
|
$text = $chatCallback[1][2];
|
||||||
$params = explode(' ', $text);
|
$params = explode(' ', $text);
|
||||||
if(count($params) < 2) {
|
if (count($params) < 2) {
|
||||||
$this->sendDonateUsageExample($player);
|
$this->sendDonateUsageExample($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$amount = (int)$params[1];
|
$amount = (int) $params[1];
|
||||||
if(!$amount || $amount <= 0) {
|
if (!$amount || $amount <= 0) {
|
||||||
$this->sendDonateUsageExample($player);
|
$this->sendDonateUsageExample($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(count($params) >= 3) {
|
if (count($params) >= 3) {
|
||||||
$receiver = $params[2];
|
$receiver = $params[2];
|
||||||
$receiverPlayer = $this->maniaControl->playerManager->getPlayer($receiver);
|
$receiverPlayer = $this->maniaControl->playerManager->getPlayer($receiver);
|
||||||
$receiverName = ($receiverPlayer ? $receiverPlayer['NickName'] : $receiver);
|
$receiverName = ($receiverPlayer ? $receiverPlayer['NickName'] : $receiver);
|
||||||
|
}
|
||||||
} else {
|
else {
|
||||||
$receiver = '';
|
$receiver = '';
|
||||||
$receiverName = $this->maniaControl->server->getName();
|
$receiverName = $this->maniaControl->server->getName();
|
||||||
}
|
}
|
||||||
@ -312,13 +306,15 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
* @param $value
|
* @param $value
|
||||||
*/
|
*/
|
||||||
private function handleDonation(Player $player, $amount, $receiver = '', $receiverName = false) {
|
private function handleDonation(Player $player, $amount, $receiver = '', $receiverName = false) {
|
||||||
if(!$receiverName) {
|
if (!$receiverName) {
|
||||||
$receiverName = $this->maniaControl->server->getName();
|
$receiverName = $this->maniaControl->server->getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
$message = 'Donate ' . $amount . ' Planets to $<' . $receiverName . '$>?';
|
$message = 'Donate ' . $amount . ' Planets to $<' . $receiverName . '$>?';
|
||||||
if(!$this->maniaControl->client->query('SendBill', $player->login, $amount, $message, $receiver)) {
|
if (!$this->maniaControl->client->query('SendBill', $player->login, $amount, $message, $receiver)) {
|
||||||
trigger_error("Couldn't create donation of {$amount} planets from '{$player->login}' for '{$receiver}'. " . $this->maniaControl->getClientErrorText());
|
trigger_error(
|
||||||
|
"Couldn't create donation of {$amount} planets from '{$player->login}' for '{$receiver}'. " .
|
||||||
|
$this->maniaControl->getClientErrorText());
|
||||||
$this->maniaControl->chat->sendError("Creating donation failed.", $player->login);
|
$this->maniaControl->chat->sendError("Creating donation failed.", $player->login);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -336,29 +332,31 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function command_Pay(array $chatCallback, Player $player) {
|
public function command_Pay(array $chatCallback, Player $player) {
|
||||||
if(!$this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_SUPERADMIN)) {
|
if (!$this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_SUPERADMIN)) {
|
||||||
$this->maniaControl->authenticationManager->sendNotAllowed($player);
|
$this->maniaControl->authenticationManager->sendNotAllowed($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$text = $chatCallback[1][2];
|
$text = $chatCallback[1][2];
|
||||||
$params = explode(' ', $text);
|
$params = explode(' ', $text);
|
||||||
if(count($params) < 2) {
|
if (count($params) < 2) {
|
||||||
$this->sendPayUsageExample($player);
|
$this->sendPayUsageExample($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$amount = (int)$params[1];
|
$amount = (int) $params[1];
|
||||||
if(!$amount || $amount <= 0) {
|
if (!$amount || $amount <= 0) {
|
||||||
$this->sendPayUsageExample($player);
|
$this->sendPayUsageExample($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(count($params) >= 3) {
|
if (count($params) >= 3) {
|
||||||
$receiver = $params[2];
|
$receiver = $params[2];
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
$receiver = $player->login;
|
$receiver = $player->login;
|
||||||
}
|
}
|
||||||
$message = 'Payout from $<' . $this->maniaControl->server->getName() . '$>.';
|
$message = 'Payout from $<' . $this->maniaControl->server->getName() . '$>.';
|
||||||
if(!$this->maniaControl->client->query('Pay', $receiver, $amount, $message)) {
|
if (!$this->maniaControl->client->query('Pay', $receiver, $amount, $message)) {
|
||||||
trigger_error("Couldn't create payout of {$amount} planets by '{$player->login}' for '{$receiver}'. " . $this->maniaControl->getClientErrorText());
|
trigger_error(
|
||||||
|
"Couldn't create payout of {$amount} planets by '{$player->login}' for '{$receiver}'. " . $this->maniaControl->getClientErrorText());
|
||||||
$this->maniaControl->chat->sendError("Creating payout failed.", $player->login);
|
$this->maniaControl->chat->sendError("Creating payout failed.", $player->login);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -375,11 +373,11 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
public function command_GetPlanets(array $chatCallback, Player $player) {
|
public function command_GetPlanets(array $chatCallback, Player $player) {
|
||||||
if(!$this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_ADMIN)) {
|
if (!$this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_ADMIN)) {
|
||||||
$this->maniaControl->authenticationManager->sendNotAllowed($player);
|
$this->maniaControl->authenticationManager->sendNotAllowed($player);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if(!$this->maniaControl->client->query('GetServerPlanets')) {
|
if (!$this->maniaControl->client->query('GetServerPlanets')) {
|
||||||
trigger_error("Couldn't retrieve server planets. " . $this->maniaControl->getClientErrorText());
|
trigger_error("Couldn't retrieve server planets. " . $this->maniaControl->getClientErrorText());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -396,37 +394,41 @@ class DonationPlugin implements CallbackListener, CommandListener, Plugin {
|
|||||||
*/
|
*/
|
||||||
public function handleBillUpdated(array $callback) {
|
public function handleBillUpdated(array $callback) {
|
||||||
$billId = $callback[1][0];
|
$billId = $callback[1][0];
|
||||||
if(!array_key_exists($billId, $this->openBills)) {
|
if (!array_key_exists($billId, $this->openBills)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$billData = $this->openBills[$billId];
|
$billData = $this->openBills[$billId];
|
||||||
$login = $billData[1];
|
$login = $billData[1];
|
||||||
$receiver = $billData[2];
|
$receiver = $billData[2];
|
||||||
switch($callback[1][1]) {
|
switch ($callback[1][1]) {
|
||||||
case 4:
|
case 4:
|
||||||
{
|
{
|
||||||
// Payed
|
// Payed
|
||||||
$donation = $billData[0];
|
$donation = $billData[0];
|
||||||
$amount = $billData[3];
|
$amount = $billData[3];
|
||||||
if($donation) {
|
if ($donation) {
|
||||||
$player = $this->maniaControl->playerManager->getPlayer($login);
|
$player = $this->maniaControl->playerManager->getPlayer($login);
|
||||||
|
|
||||||
// Donation
|
// Donation
|
||||||
if(strlen($receiver) > 0) {
|
if (strlen($receiver) > 0) {
|
||||||
// To player
|
// To player
|
||||||
$message = "Successfully donated {$amount} to '{$receiver}'!";
|
$message = "Successfully donated {$amount} to '{$receiver}'!";
|
||||||
$this->maniaControl->chat->sendSuccess($message, $login);
|
$this->maniaControl->chat->sendSuccess($message, $login);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
// To server
|
// To server
|
||||||
if($this->maniaControl->settingManager->getSetting($this, self::SETTING_ANNOUNCE_SERVERDONATION, true)) {
|
if ($this->maniaControl->settingManager->getSetting($this, self::SETTING_ANNOUNCE_SERVERDONATION, true)) {
|
||||||
$message = '$<' . $player->nickname . '$> donated ' . $amount . ' Planets! Thanks.';
|
$message = '$<' . $player->nickname . '$> donated ' . $amount . ' Planets! Thanks.';
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
$message = 'Donation successful! Thanks.';
|
$message = 'Donation successful! Thanks.';
|
||||||
}
|
}
|
||||||
$this->maniaControl->chat->sendSuccess($message, $login);
|
$this->maniaControl->chat->sendSuccess($message, $login);
|
||||||
$this->maniaControl->statisticManager->insertStat(self::STAT_PLAYER_DONATIONS, $player, $this->maniaControl->server->getServerId(), $amount);
|
$this->maniaControl->statisticManager->insertStat(self::STAT_PLAYER_DONATIONS, $player,
|
||||||
|
$this->maniaControl->server->getServerId(), $amount);
|
||||||
}
|
}
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
// Payout
|
// Payout
|
||||||
$message = "Successfully payed out {$amount} to '{$receiver}'!";
|
$message = "Successfully payed out {$amount} to '{$receiver}'!";
|
||||||
$this->maniaControl->chat->sendSuccess($message, $login);
|
$this->maniaControl->chat->sendSuccess($message, $login);
|
||||||
|
Loading…
Reference in New Issue
Block a user