improved jukebox

This commit is contained in:
kremsy 2013-12-29 12:01:13 +01:00
parent 4bcd642f0c
commit bf8ede240d
2 changed files with 48 additions and 12 deletions

View File

@ -3,14 +3,17 @@
namespace ManiaControl\Maps; namespace ManiaControl\Maps;
use ManiaControl\Callbacks\CallbackListener; use ManiaControl\Callbacks\CallbackListener;
use ManiaControl\Callbacks\CallbackManager; use ManiaControl\Callbacks\CallbackManager;
use ManiaControl\Commands\CommandListener;
use ManiaControl\Formatter;
use ManiaControl\ManiaControl; use ManiaControl\ManiaControl;
use ManiaControl\Players\Player;
/** /**
* Jukebox Class * Jukebox Class
* *
* @author steeffeen & kremsy * @author steeffeen & kremsy
*/ */
class Jukebox implements CallbackListener { class Jukebox implements CallbackListener, CommandListener {
/** /**
* Constants * Constants
*/ */
@ -18,6 +21,8 @@ class Jukebox implements CallbackListener {
const SETTING_SKIP_MAP_ON_LEAVE = 'Skip Map when the requester leaves'; const SETTING_SKIP_MAP_ON_LEAVE = 'Skip Map when the requester leaves';
const SETTING_SKIP_JUKED_ADMIN = 'Skip Map when admin leaves'; const SETTING_SKIP_JUKED_ADMIN = 'Skip Map when admin leaves';
const ADMIN_COMMAND_CLEAR_JUKEBOX = 'clearjukebox';
/** /**
* Private properties * Private properties
*/ */
@ -38,6 +43,27 @@ class Jukebox implements CallbackListener {
// Init settings // Init settings
$this->maniaControl->settingManager->initSetting($this, self::SETTING_SKIP_MAP_ON_LEAVE, true); $this->maniaControl->settingManager->initSetting($this, self::SETTING_SKIP_MAP_ON_LEAVE, true);
$this->maniaControl->settingManager->initSetting($this, self::SETTING_SKIP_JUKED_ADMIN, false); $this->maniaControl->settingManager->initSetting($this, self::SETTING_SKIP_JUKED_ADMIN, false);
//Register Admin Commands
$this->maniaControl->commandManager->registerCommandListener(self::ADMIN_COMMAND_CLEAR_JUKEBOX, $this, 'command_ClearJukebox', true);
}
/**
* Clears the jukebox via admin command clearjukebox
* @param array $chat
* @param Player $player
*/
public function command_ClearJukebox(array $chat, Player $admin){
$title = $this->maniaControl->authenticationManager->getAuthLevelName($admin->authLevel);
//Destroy jukebox list
$this->jukedMaps = array();
$this->maniaControl->chat->sendInformation($title . ' $<' . $admin->nickname . '$> cleared the Jukebox!');
$this->maniaControl->log($title .' ' . Formatter::stripCodes($admin->nickname) . ' cleared the Jukebox');
// Trigger callback
$this->maniaControl->callbackManager->triggerCallback(self::CB_JUKEBOX_CHANGED, array('clear'));
} }
/** /**
@ -46,6 +72,7 @@ class Jukebox implements CallbackListener {
* @param $uid * @param $uid
*/ */
public function addMapToJukebox($login, $uid){ public function addMapToJukebox($login, $uid){
$player = $this->maniaControl->playerManager->getPlayer($login);
//Check if the map is already juked //Check if the map is already juked
if(array_key_exists($uid, $this->jukedMaps)){ if(array_key_exists($uid, $this->jukedMaps)){
@ -55,10 +82,11 @@ class Jukebox implements CallbackListener {
//TODO recently maps not able to add to jukebox setting, and management //TODO recently maps not able to add to jukebox setting, and management
$map = $this->maniaControl->mapManager->getMapByUid($uid);
$this->jukedMaps[$uid] = array($login, $this->maniaControl->mapManager->getMapByUid($uid)); $this->jukedMaps[$uid] = array($player, $map);
//TODO Message $this->maniaControl->chat->sendInformation('$<' . $player->nickname . '$> added $<' . $map->name . '$> to the Jukebox!');
// Trigger callback // Trigger callback
$this->maniaControl->callbackManager->triggerCallback(self::CB_JUKEBOX_CHANGED, array('add', $this->jukedMaps[$uid])); $this->maniaControl->callbackManager->triggerCallback(self::CB_JUKEBOX_CHANGED, array('add', $this->jukedMaps[$uid]));
@ -71,10 +99,7 @@ class Jukebox implements CallbackListener {
* @param $uid * @param $uid
*/ */
public function removeFromJukebox($login, $uid){ public function removeFromJukebox($login, $uid){
//unset($this->jukedMapsUid[$uid]);
unset($this->jukedMaps[$uid]); unset($this->jukedMaps[$uid]);
} }
public function beginMap(){ public function beginMap(){
@ -90,18 +115,21 @@ class Jukebox implements CallbackListener {
public function endMap(array $callback){ public function endMap(array $callback){
if($this->maniaControl->settingManager->getSetting($this, self::SETTING_SKIP_MAP_ON_LEAVE) == TRUE){ if($this->maniaControl->settingManager->getSetting($this, self::SETTING_SKIP_MAP_ON_LEAVE) == TRUE){
//Skip Map if requester has left //Skip Map if requester has left
for($i = 0; $i < count($this->jukedMaps); $i++){ foreach($this->jukedMaps as $jukedMap){
$jukedMap = reset($this->jukedMaps); $player = $jukedMap[0];
//found player, so play this map //found player, so play this map
if($this->maniaControl->playerManager->getPlayer($jukedMap[0]) != null){ if($this->maniaControl->playerManager->getPlayer($player->login) != null){
break; break;
} }
if($this->maniaControl->settingManager->getSetting($this, self::SETTING_SKIP_JUKED_ADMIN) == FALSE){ if($this->maniaControl->settingManager->getSetting($this, self::SETTING_SKIP_JUKED_ADMIN) == FALSE){
//TODO check in database if a the juker of the map is admin, and if he is, just break //Check if the juker is a admin
if($player->authLevel > 0){
break;
}
} }
// Trigger callback // Trigger callback
@ -110,9 +138,10 @@ class Jukebox implements CallbackListener {
//Player not found, so remove the map from the jukebox //Player not found, so remove the map from the jukebox
array_shift($this->jukedMaps); array_shift($this->jukedMaps);
//TODO Message, report skip $this->maniaControl->chat->sendInformation('Juked Map skipped because $<' . $player->nickname . '$> left!');
} }
} }
$nextMap = array_shift($this->jukedMaps); $nextMap = array_shift($this->jukedMaps);
//Check if Jukebox is empty //Check if Jukebox is empty

View File

@ -175,6 +175,7 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$descriptionLabel->setVisible(false); $descriptionLabel->setVisible(false);
$descriptionLabel->setText("Add-Map: {$map->name}"); $descriptionLabel->setText("Add-Map: {$map->name}");
$tooltips->add($addQuad, $descriptionLabel); $tooltips->add($addQuad, $descriptionLabel);
} }
$y -= 4; $y -= 4;
@ -334,6 +335,12 @@ class MapList implements ManialinkPageAnswerListener, CallbackListener {
$descriptionLabel->setText("Switch Directly to Map: {$map->name}"); $descriptionLabel->setText("Switch Directly to Map: {$map->name}");
$tooltips->add($switchToQuad, $descriptionLabel); $tooltips->add($switchToQuad, $descriptionLabel);
} }
/*$descriptionLabel2 = clone $descriptionLabel;
$descriptionLabel2->setText("test1");
$tooltips->add($eraseQuad, $descriptionLabel2); */
$y -= 4; $y -= 4;
$id++; $id++;
if($id == self::MAX_MAPS_PER_PAGE + 1) if($id == self::MAX_MAPS_PER_PAGE + 1)