switch directly to a map
This commit is contained in:
parent
e72c03a609
commit
11d966a6ca
@ -32,6 +32,8 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
|
|
||||||
const ACTION_CLOSEWIDGET = 'MapList.CloseWidget';
|
const ACTION_CLOSEWIDGET = 'MapList.CloseWidget';
|
||||||
const ACTION_ADD_MAP = 'MapList.AddMap';
|
const ACTION_ADD_MAP = 'MapList.AddMap';
|
||||||
|
const ACTION_ERASE_MAP = 'MapList.EraseMap';
|
||||||
|
const ACTION_SWITCH_MAP = 'MapList.SwitchMap';
|
||||||
const MAX_MAPS_PER_PAGE = 15;
|
const MAX_MAPS_PER_PAGE = 15;
|
||||||
|
|
||||||
|
|
||||||
@ -243,6 +245,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
$this->displayMap($id, $map, $mapFrame, $tooltips);
|
$this->displayMap($id, $map, $mapFrame, $tooltips);
|
||||||
$mapFrame->setY($y);
|
$mapFrame->setY($y);
|
||||||
|
|
||||||
|
if($this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_ADMIN)){ //todoSET as setting who can add maps
|
||||||
//erase map quad
|
//erase map quad
|
||||||
$eraseQuad = new Quad_UIConstruction_Buttons();
|
$eraseQuad = new Quad_UIConstruction_Buttons();
|
||||||
$mapFrame->add($eraseQuad);
|
$mapFrame->add($eraseQuad);
|
||||||
@ -250,15 +253,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
$eraseQuad->setZ(0.2);
|
$eraseQuad->setZ(0.2);
|
||||||
$eraseQuad->setSize(4,4);
|
$eraseQuad->setSize(4,4);
|
||||||
$eraseQuad->setSubStyle($eraseQuad::SUBSTYLE_Erase);
|
$eraseQuad->setSubStyle($eraseQuad::SUBSTYLE_Erase);
|
||||||
//TODO bestätigung?
|
$eraseQuad->setAction(self::ACTION_ERASE_MAP . "." .($id-1));
|
||||||
|
|
||||||
//switch to map quad
|
|
||||||
$switchToQuad = new Quad_Icons64x64_1();
|
|
||||||
$mapFrame->add($switchToQuad);
|
|
||||||
$switchToQuad->setX($this->width/2 - 10);
|
|
||||||
$switchToQuad->setZ(0.2);
|
|
||||||
$switchToQuad->setSize(4, 4);
|
|
||||||
$switchToQuad->setSubStyle($switchToQuad::SUBSTYLE_ArrowFastNext);
|
|
||||||
//TODO bestätigung?
|
//TODO bestätigung?
|
||||||
|
|
||||||
//Description Label
|
//Description Label
|
||||||
@ -271,6 +266,17 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
$descriptionLabel->setVisible(false);
|
$descriptionLabel->setVisible(false);
|
||||||
$descriptionLabel->setText("Remove Map: {$map->name}");
|
$descriptionLabel->setText("Remove Map: {$map->name}");
|
||||||
$tooltips->add($eraseQuad, $descriptionLabel);
|
$tooltips->add($eraseQuad, $descriptionLabel);
|
||||||
|
}
|
||||||
|
if($this->maniaControl->authenticationManager->checkRight($player, AuthenticationManager::AUTH_LEVEL_OPERATOR)){ //todoSET as setting who can add maps
|
||||||
|
//switch to map quad
|
||||||
|
$switchToQuad = new Quad_Icons64x64_1();
|
||||||
|
$mapFrame->add($switchToQuad);
|
||||||
|
$switchToQuad->setX($this->width/2 - 10);
|
||||||
|
$switchToQuad->setZ(0.2);
|
||||||
|
$switchToQuad->setSize(4, 4);
|
||||||
|
$switchToQuad->setSubStyle($switchToQuad::SUBSTYLE_ArrowFastNext);
|
||||||
|
$switchToQuad->setAction(self::ACTION_SWITCH_MAP . "." .($id-1));
|
||||||
|
//TODO bestätigung?
|
||||||
|
|
||||||
$descriptionLabel = new Label();
|
$descriptionLabel = new Label();
|
||||||
$frame->add($descriptionLabel);
|
$frame->add($descriptionLabel);
|
||||||
@ -281,7 +287,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
$descriptionLabel->setVisible(false);
|
$descriptionLabel->setVisible(false);
|
||||||
$descriptionLabel->setText("Switch Directly to Map: {$map->name}");
|
$descriptionLabel->setText("Switch Directly to Map: {$map->name}");
|
||||||
$tooltips->add($switchToQuad, $descriptionLabel);
|
$tooltips->add($switchToQuad, $descriptionLabel);
|
||||||
|
}
|
||||||
$y -= 4;
|
$y -= 4;
|
||||||
$id++;
|
$id++;
|
||||||
if($id == self::MAX_MAPS_PER_PAGE - 1)
|
if($id == self::MAX_MAPS_PER_PAGE - 1)
|
||||||
@ -344,11 +350,21 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
|
|||||||
public function handleManialinkPageAnswer(array $callback){
|
public function handleManialinkPageAnswer(array $callback){
|
||||||
$actionId = $callback[1][2];
|
$actionId = $callback[1][2];
|
||||||
$addMap = (strpos($actionId, self::ACTION_ADD_MAP) === 0);
|
$addMap = (strpos($actionId, self::ACTION_ADD_MAP) === 0);
|
||||||
if(!$addMap)
|
$eraseMap = (strpos($actionId, self::ACTION_ERASE_MAP) === 0);
|
||||||
|
$switchMap = (strpos($actionId, self::ACTION_SWITCH_MAP) === 0);
|
||||||
|
|
||||||
|
if(!$addMap && !$eraseMap && !$switchMap)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
$actionArray = explode(".", $actionId);
|
$actionArray = explode(".", $actionId);
|
||||||
var_dump($actionArray);
|
|
||||||
|
if($addMap){ //TODO log and chat message
|
||||||
$this->maniaControl->mapManager->addMapFromMx($actionArray[2],$callback[1][1]);
|
$this->maniaControl->mapManager->addMapFromMx($actionArray[2],$callback[1][1]);
|
||||||
|
}else if($eraseMap){
|
||||||
|
|
||||||
|
}else if($switchMap){ //TODO log and chat message
|
||||||
|
$this->maniaControl->client->query('JumpToMapIndex', intval($actionArray[2]));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user