update available in maplist und mxicon

This commit is contained in:
kremsy 2014-01-12 00:28:06 +01:00 committed by Steffen Schröder
parent de96708156
commit 5d8470cb1c
2 changed files with 47 additions and 27 deletions

View File

@ -27,6 +27,9 @@ class IconManager implements CallbackListener {
const MX_ICON = 'ManiaExchange.png'; const MX_ICON = 'ManiaExchange.png';
const MX_ICON_MOVER = 'ManiaExchange_logo_press.png'; const MX_ICON_MOVER = 'ManiaExchange_logo_press.png';
const MX_ICON_GREEN = 'ManiaExchangeGreen.png';
const MX_ICON_GREEN_MOVER = 'ManiaExchange_logo_pressGreen.png';
/** /**
* Private Properties * Private Properties
*/ */
@ -53,6 +56,9 @@ class IconManager implements CallbackListener {
private function addDefaultIcons() { private function addDefaultIcons() {
$this->addIcon(self::MX_ICON); $this->addIcon(self::MX_ICON);
$this->addIcon(self::MX_ICON_MOVER); $this->addIcon(self::MX_ICON_MOVER);
$this->addIcon(self::MX_ICON_GREEN, "http://www.pictures.esc-clan.net/upload/"); //TODO mc website
$this->addIcon(self::MX_ICON_GREEN_MOVER , " http://www.pictures.esc-clan.net/upload/");
} }
/** /**

View File

@ -217,7 +217,6 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$mapFrame->setY($y); $mapFrame->setY($y);
$mxQuad = new Quad(); $mxQuad = new Quad();
$mapFrame->add($mxQuad); $mapFrame->add($mxQuad);
$mxQuad->setSize(3, 3); $mxQuad->setSize(3, 3);
@ -409,12 +408,13 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$this->maniaControl->manialinkManager->labelLine($headFrame, $array); $this->maniaControl->manialinkManager->labelLine($headFrame, $array);
// Predefine Description Label // Predefine Description Label
$preDefinedDescriptionLabel = new Label(); $descriptionLabel = new Label();
$preDefinedDescriptionLabel->setAlign(Control::LEFT, Control::TOP); $frame->add($descriptionLabel);
$preDefinedDescriptionLabel->setPosition($x + 10, -$height / 2 + 5); $descriptionLabel->setAlign(Control::LEFT, Control::TOP);
$preDefinedDescriptionLabel->setSize($width * 0.7, 4); $descriptionLabel->setPosition($x + 10, -$height / 2 + 5);
$preDefinedDescriptionLabel->setTextSize(2); $descriptionLabel->setSize($width * 0.7, 4);
$preDefinedDescriptionLabel->setVisible(false); $descriptionLabel->setTextSize(2);
$descriptionLabel->setVisible(false);
$queuedMaps = $this->maniaControl->mapManager->mapQueue->getQueuedMapsRanking(); $queuedMaps = $this->maniaControl->mapManager->mapQueue->getQueuedMapsRanking();
/** /**
@ -431,7 +431,6 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
* @var Map $map * @var Map $map
*/ */
foreach($mapList as $map) { foreach($mapList as $map) {
var_dump($map->updateAvailable());
if(!isset($pageFrame)) { if(!isset($pageFrame)) {
$pageFrame = new Frame(); $pageFrame = new Frame();
$frame->add($pageFrame); $frame->add($pageFrame);
@ -469,6 +468,29 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$mxId = '-'; $mxId = '-';
if(isset($map->mx->id)) { if(isset($map->mx->id)) {
$mxId = $map->mx->id; $mxId = $map->mx->id;
$mxQuad = new Quad();
$mapFrame->add($mxQuad);
$mxQuad->setSize(3, 3);
$mxQuad->setImage($this->maniaControl->manialinkManager->iconManager->getIcon(IconManager::MX_ICON));
$mxQuad->setImageFocus($this->maniaControl->manialinkManager->iconManager->getIcon(IconManager::MX_ICON_MOVER));
$mxQuad->setX($x + 65);
$mxQuad->setUrl($map->mx->pageurl);
$mxQuad->setZ(0.01);
$script->addTooltip($mxQuad, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => "View $<" . $map->name . "$> on Mania-Exchange"));
if($map->updateAvailable()) {
$mxQuad = new Quad();
$mapFrame->add($mxQuad);
$mxQuad->setSize(3, 3);
$mxQuad->setImage($this->maniaControl->manialinkManager->iconManager->getIcon(IconManager::MX_ICON_GREEN));
$mxQuad->setImageFocus($this->maniaControl->manialinkManager->iconManager->getIcon(IconManager::MX_ICON_GREEN_MOVER));
$mxQuad->setX($x + 62);
$mxQuad->setUrl($map->mx->pageurl);
$mxQuad->setZ(0.01);
$script->addTooltip($mxQuad, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => "Update of $<" . $map->name . "$> available on Mania-Exchange"));
}
} }
// Display Maps // Display Maps
@ -476,10 +498,6 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$this->maniaControl->manialinkManager->labelLine($mapFrame, $array); $this->maniaControl->manialinkManager->labelLine($mapFrame, $array);
// TODO action detailed map info including mx info // TODO action detailed map info including mx info
// MapQueue Description Label
$descriptionLabel = clone $preDefinedDescriptionLabel;
$frame->add($descriptionLabel);
// Map-Queue-Map-Label // Map-Queue-Map-Label
if(isset($queuedMaps[$map->uid])) { if(isset($queuedMaps[$map->uid])) {
$label = new Label_Text(); $label = new Label_Text();
@ -490,7 +508,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$label->setTextSize(1.5); $label->setTextSize(1.5);
$label->setText($queuedMaps[$map->uid]); $label->setText($queuedMaps[$map->uid]);
$label->setTextColor('fff'); $label->setTextColor('fff');
$descriptionLabel->setText('$<' . $map->name . '$> is on Map-Queue Position: ' . $queuedMaps[$map->uid]); $script->addTooltip($label, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => '$<' . $map->name . '$> is on Map-Queue Position: ' . $queuedMaps[$map->uid]));
} else { } else {
// Map-Queue-Map-Button // Map-Queue-Map-Button
$queueLabel = new Label_Button(); $queueLabel = new Label_Button();
@ -502,8 +520,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$queueLabel->setText('+'); $queueLabel->setText('+');
$queueLabel->setTextColor('09f'); $queueLabel->setTextColor('09f');
$descriptionLabel->setText('Add Map to the Map Queue: $<' . $map->name . '$>'); $script->addTooltip($queueLabel, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => 'Add Map to the Map Queue: $<' . $map->name . '$>'));
$script->addTooltip($queueLabel, $descriptionLabel);
} }
if($this->maniaControl->authenticationManager->checkPermission($player, MapManager::SETTING_PERMISSION_REMOVE_MAP)) { if($this->maniaControl->authenticationManager->checkPermission($player, MapManager::SETTING_PERMISSION_REMOVE_MAP)) {
@ -521,11 +538,8 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
//$script->addToggle($eraseLabel, $confirmFrame); //TODO //$script->addToggle($eraseLabel, $confirmFrame); //TODO
$script->addTooltip($eraseLabel, $confirmFrame, Script::OPTION_TOOLTIP_STAYONCLICK); $script->addTooltip($eraseLabel, $confirmFrame, Script::OPTION_TOOLTIP_STAYONCLICK);
// Description Label $script->addTooltip($eraseLabel, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => 'Remove Map: $<' . $map->name . '$>'));
$descriptionLabel = clone $preDefinedDescriptionLabel;
$frame->add($descriptionLabel);
$descriptionLabel->setText('Remove Map: $<' . $map->name . '$>');
$script->addTooltip($eraseLabel, $descriptionLabel);
} }
if($this->maniaControl->authenticationManager->checkPermission($player, MapManager::SETTING_PERMISSION_ADD_MAP)) { if($this->maniaControl->authenticationManager->checkPermission($player, MapManager::SETTING_PERMISSION_ADD_MAP)) {
@ -543,10 +557,8 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$script->addTooltip($switchLabel, $confirmFrame, Script::OPTION_TOOLTIP_STAYONCLICK); //TODO $script->addTooltip($switchLabel, $confirmFrame, Script::OPTION_TOOLTIP_STAYONCLICK); //TODO
//$script->addToggle($switchLabel, $confirmFrame); //$script->addToggle($switchLabel, $confirmFrame);
$descriptionLabel = clone $preDefinedDescriptionLabel; $script->addTooltip($switchLabel, $descriptionLabel, array(Script::OPTION_TOOLTIP_TEXT => 'Switch Directly to Map: $<' . $map->name . '$>'));
$frame->add($descriptionLabel);
$descriptionLabel->setText('Switch Directly to Map: $<' . $map->name . '$>');
$script->addTooltip($switchLabel, $descriptionLabel);
} }
// Display Karma bar // Display Karma bar
@ -644,6 +656,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
/** /**
* Unset the player if he opened another Main Widget * Unset the player if he opened another Main Widget
*
* @param array $callback * @param array $callback
*/ */
public function handleWidgetOpened(array $callback) { public function handleWidgetOpened(array $callback) {
@ -654,6 +667,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
unset($this->mapListShown[$player->login]); unset($this->mapListShown[$player->login]);
} }
} }
/** /**
* Closes the widget * Closes the widget
* *