improved jukebox
This commit is contained in:
parent
4bcd642f0c
commit
bf8ede240d
@ -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
|
||||||
|
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user