diff options
author | Andrei Karas <akaras@inbox.ru> | 2017-07-20 21:28:58 +0300 |
---|---|---|
committer | Andrei Karas <akaras@inbox.ru> | 2017-07-20 21:28:58 +0300 |
commit | 5b66f7a00e8f3868366cdf792ac15162267f6848 (patch) | |
tree | f60238e8817235d03a4ac46e875f55ba4f93c913 /src/gui | |
parent | 70e304a900be02a734b6ebe7517b81bbe786a79f (diff) | |
download | manaplus-5b66f7a00e8f3868366cdf792ac15162267f6848.tar.gz manaplus-5b66f7a00e8f3868366cdf792ac15162267f6848.tar.bz2 manaplus-5b66f7a00e8f3868366cdf792ac15162267f6848.tar.xz manaplus-5b66f7a00e8f3868366cdf792ac15162267f6848.zip |
Show gm commands in popup menu based or player allowed gm commands.
For legacy server aka tmwa, it allow all commands.
Diffstat (limited to 'src/gui')
-rw-r--r-- | src/gui/popups/popupmenu.cpp | 503 | ||||
-rw-r--r-- | src/gui/popups/popupmenu.h | 6 |
2 files changed, 350 insertions, 159 deletions
diff --git a/src/gui/popups/popupmenu.cpp b/src/gui/popups/popupmenu.cpp index 2fe511be1..9f99ecf37 100644 --- a/src/gui/popups/popupmenu.cpp +++ b/src/gui/popups/popupmenu.cpp @@ -75,6 +75,7 @@ #endif // TMWA_SUPPORT #include "resources/chatobject.h" +#include "resources/groupinfo.h" #include "resources/iteminfo.h" #include "resources/db/groupdb.h" @@ -152,6 +153,45 @@ void PopupMenu::initPopup() mGroup = GroupDb::getGroup(groupId); } +bool PopupMenu::isAllowCommand(const ServerCommandTypeT command) +{ + if (mGroup == nullptr) + return false; +#ifdef TMWA_SUPPORT + // allow any commands for legacy if group > 0 + if (Net::getNetworkType() == ServerType::TMWATHENA && + localPlayer != nullptr && + localPlayer->isGM()) + { + return true; + } +#endif + const ServerCommandEnable::Type enabled = + mGroup->mCommands[CAST_SIZE(command)]; + return (enabled & ServerCommandEnable::Self) != 0; +} + +bool PopupMenu::isAllowOtherCommand(const ServerCommandTypeT command) +{ + if (mGroup == nullptr || + localPlayer == nullptr) + return false; +#ifdef TMWA_SUPPORT + // allow any commands for legacy if group > 0 + if (Net::getNetworkType() == ServerType::TMWATHENA && + localPlayer->isGM()) + { + return true; + } +#endif + const ServerCommandEnable::Type enabled = + mGroup->mCommands[CAST_SIZE(command)]; + if (mName == localPlayer->getName()) + return (enabled & ServerCommandEnable::Self) != 0; + else + return (enabled & ServerCommandEnable::Other) != 0; +} + void PopupMenu::showPopup(const int x, const int y, const Being *const being) { if (being == nullptr || @@ -727,7 +767,7 @@ void PopupMenu::showPopup(const int x, const int y, MapItem *const mapItem) // TRANSLATORS: remove map item mBrowserBox->addRow("remove map", _("Remove")); - if ((localPlayer != nullptr) && localPlayer->isGM()) + if (isAllowCommand(ServerCommandType::slide)) { mBrowserBox->addRow("##3---"); // TRANSLATORS: popup menu item @@ -758,7 +798,7 @@ void PopupMenu::showMapPopup(const int x, const int y, // TRANSLATORS: popup menu header mBrowserBox->addRow(_("Map Item")); - if ((localPlayer != nullptr) && localPlayer->isGM()) + if (isAllowCommand(ServerCommandType::slide)) { // TRANSLATORS: popup menu item // TRANSLATORS: warp to map item @@ -2767,30 +2807,54 @@ void PopupMenu::showPlayerMenu() // TRANSLATORS: popup menu header mBrowserBox->addRow(strprintf(_("Show %s"), mName.c_str())); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player account info - mBrowserBox->addRow("/showaccountinfo 'NAME'", _("Account info")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player level - mBrowserBox->addRow("/showlevel 'NAME'", _("Level")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player stats - mBrowserBox->addRow("/showstats 'NAME'", _("Stats")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player inventory list - mBrowserBox->addRow("/showinventory 'NAME'", _("Inventory")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player storage list - mBrowserBox->addRow("/showstorage 'NAME'", _("Storage")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show player cart list - mBrowserBox->addRow("/showcart 'NAME'", _("Cart")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm commands - mBrowserBox->addRow("/gmcommands 'NAME'", _("Commands")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm char commands - mBrowserBox->addRow("/gmcharcommands 'NAME'", _("Char commands")); + if (isAllowCommand(ServerCommandType::accinfo)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player account info + mBrowserBox->addRow("/showaccountinfo 'NAME'", _("Account info")); + } + if (isAllowOtherCommand(ServerCommandType::exp)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player level + mBrowserBox->addRow("/showlevel 'NAME'", _("Level")); + } + if (isAllowOtherCommand(ServerCommandType::stats)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player stats + mBrowserBox->addRow("/showstats 'NAME'", _("Stats")); + } + if (isAllowOtherCommand(ServerCommandType::itemlist)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player inventory list + mBrowserBox->addRow("/showinventory 'NAME'", _("Inventory")); + } + if (isAllowOtherCommand(ServerCommandType::storagelist)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player storage list + mBrowserBox->addRow("/showstorage 'NAME'", _("Storage")); + } + if (isAllowOtherCommand(ServerCommandType::cartlist)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show player cart list + mBrowserBox->addRow("/showcart 'NAME'", _("Cart")); + } + if (isAllowOtherCommand(ServerCommandType::commands)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: gm commands + mBrowserBox->addRow("/gmcommands 'NAME'", _("Commands")); + } + if (isAllowOtherCommand(ServerCommandType::charcommands)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: gm char commands + mBrowserBox->addRow("/gmcharcommands 'NAME'", _("Char commands")); + } // TRANSLATORS: popup menu item // TRANSLATORS: back to gm menu mBrowserBox->addRow("gm", _("Back")); @@ -2802,8 +2866,10 @@ void PopupMenu::showPlayerMenu() void PopupMenu::showPlayerGMCommands(const std::string &name) { + if (localPlayer == nullptr) + return; const bool legacy = Net::getNetworkType() == ServerType::TMWATHENA; - if (!legacy) + if (!legacy && isAllowCommand(ServerCommandType::where)) { // TRANSLATORS: popup menu item // TRANSLATORS: find player position @@ -2815,29 +2881,40 @@ void PopupMenu::showPlayerGMCommands(const std::string &name) // TRANSLATORS: check player ip mBrowserBox->addRow("/ipcheck 'NAME'", _("Check ip")); } - // TRANSLATORS: popup menu item - // TRANSLATORS: go to player position - mBrowserBox->addRow("/gotopc 'NAME'", _("Goto")); - // TRANSLATORS: popup menu item - // TRANSLATORS: recall player to current position - mBrowserBox->addRow("/recallpc 'NAME'", _("Recall")); - // TRANSLATORS: popup menu item - // TRANSLATORS: revive player - mBrowserBox->addRow("/alive 'NAME'", _("Revive")); + if (isAllowCommand(ServerCommandType::jumpto)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: go to player position + mBrowserBox->addRow("/gotopc 'NAME'", _("Goto")); + } + if (isAllowCommand(ServerCommandType::recall)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: recall player to current position + mBrowserBox->addRow("/recallpc 'NAME'", _("Recall")); + } + if (isAllowOtherCommand(ServerCommandType::alive)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: revive player + mBrowserBox->addRow("/alive 'NAME'", _("Revive")); + } if (!legacy) { Being *const being = actorManager->findBeingByName(name, ActorType::Player); - if (being != nullptr) + if (being != nullptr && being == localPlayer) { - if (!being->getPartyName().empty()) + if (!being->getPartyName().empty() && + isAllowCommand(ServerCommandType::partyrecall)) { mBrowserBox->addRow("/partyrecall 'PARTY'", // TRANSLATORS: popup menu item // TRANSLATORS: recall all party members to player location _("Recall party")); } - if (!being->getGuildName().empty()) + if (!being->getGuildName().empty() && + isAllowCommand(ServerCommandType::guildrecall)) { mBrowserBox->addRow("/guildrecall 'PARTY'", // TRANSLATORS: popup menu item @@ -2845,10 +2922,12 @@ void PopupMenu::showPlayerGMCommands(const std::string &name) _("Recall guild")); } } - if ((localPlayer != nullptr) && localPlayer->isInParty()) + if (localPlayer->isInParty()) { const Party *const party = localPlayer->getParty(); - if ((party != nullptr) && party->isMember(name)) + if (party != nullptr && + party->isMember(name) && + isAllowCommand(ServerCommandType::changeleader)) { mBrowserBox->addRow("/gmpartyleader 'NAME'", // TRANSLATORS: popup menu item @@ -2857,12 +2936,18 @@ void PopupMenu::showPlayerGMCommands(const std::string &name) } } - // TRANSLATORS: popup menu item - // TRANSLATORS: nuke player - mBrowserBox->addRow("/gmnuke 'NAME'", _("Nuke")); - // TRANSLATORS: popup menu item - // TRANSLATORS: kill player - mBrowserBox->addRow("/kill 'NAME'", _("Kill")); + if (isAllowCommand(ServerCommandType::nuke)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: nuke player + mBrowserBox->addRow("/gmnuke 'NAME'", _("Nuke")); + } + if (isAllowOtherCommand(ServerCommandType::kill)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: kill player + mBrowserBox->addRow("/kill 'NAME'", _("Kill")); + } if (mBeingId != BeingId_zero) { mBrowserBox->addRow("##3---"); @@ -2886,53 +2971,97 @@ void PopupMenu::showPlayerGMCommands(const std::string &name) } else { - // TRANSLATORS: popup menu item - // TRANSLATORS: heal player - mBrowserBox->addRow("/gmheal 'NAME'", _("Heal")); - // TRANSLATORS: popup menu item - // TRANSLATORS: enable immortal mode for player - mBrowserBox->addRow("/immortal 'NAME'", _("Immortal")); - // TRANSLATORS: popup menu item - // TRANSLATORS: send player to jail - mBrowserBox->addRow("/jail 'NAME'", _("Jail")); - // TRANSLATORS: popup menu item - // TRANSLATORS: restore player from jail - mBrowserBox->addRow("/unjail 'NAME'", _("Unjail")); - // TRANSLATORS: popup menu item - // TRANSLATORS: hide player - mBrowserBox->addRow("/hide 'NAME'", _("Hide")); + if (isAllowOtherCommand(ServerCommandType::heal)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: heal player + mBrowserBox->addRow("/gmheal 'NAME'", _("Heal")); + } + if (isAllowOtherCommand(ServerCommandType::monsterignore)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: enable immortal mode for player + mBrowserBox->addRow("/immortal 'NAME'", _("Immortal")); + } + if (isAllowCommand(ServerCommandType::jail)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: send player to jail + mBrowserBox->addRow("/jail 'NAME'", _("Jail")); + } + if (isAllowCommand(ServerCommandType::unjail)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: restore player from jail + mBrowserBox->addRow("/unjail 'NAME'", _("Unjail")); + } + if (name == localPlayer->getName() && + isAllowCommand(ServerCommandType::hide)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: hide player + mBrowserBox->addRow("/hide 'NAME'", _("Hide")); + } mBrowserBox->addRow("##3---"); - // TRANSLATORS: popup menu item - // TRANSLATORS: set player as killer - mBrowserBox->addRow("/killer 'NAME'", _("Killer")); - // TRANSLATORS: popup menu item - // TRANSLATORS: set player as killable - mBrowserBox->addRow("/killable 'NAME'", _("Killable")); - // TRANSLATORS: popup menu item - // TRANSLATORS: set player save position - mBrowserBox->addRow("/savepos 'NAME'", _("Set save")); - // TRANSLATORS: popup menu item - // TRANSLATORS: warp player to save position - mBrowserBox->addRow("/loadpos 'NAME'", _("Warp to save")); - // TRANSLATORS: popup menu item - // TRANSLATORS: warp player to random position on same map - mBrowserBox->addRow("/randomwarp 'NAME'", _("Warp to random")); + if (isAllowOtherCommand(ServerCommandType::killer)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: set player as killer + mBrowserBox->addRow("/killer 'NAME'", _("Killer")); + } + if (isAllowOtherCommand(ServerCommandType::killable)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: set player as killable + mBrowserBox->addRow("/killable 'NAME'", _("Killable")); + } + if (isAllowOtherCommand(ServerCommandType::save)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: set player save position + mBrowserBox->addRow("/savepos 'NAME'", _("Set save")); + } + if (isAllowOtherCommand(ServerCommandType::load)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: warp player to save position + mBrowserBox->addRow("/loadpos 'NAME'", _("Warp to save")); + } + if (isAllowOtherCommand(ServerCommandType::jump)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: warp player to random position on same map + mBrowserBox->addRow("/randomwarp 'NAME'", _("Warp to random")); + } mBrowserBox->addRow("##3---"); - // TRANSLATORS: popup menu item - // TRANSLATORS: spawn player clone - mBrowserBox->addRow("/spawnclone 'NAME'", _("Spawn clone")); - // TRANSLATORS: popup menu item - // TRANSLATORS: spawn slave player clone - mBrowserBox->addRow("/spawnslaveclone 'NAME'", _("Spawn slave clone")); - // TRANSLATORS: popup menu item - // TRANSLATORS: spawn evil player clone - mBrowserBox->addRow("/spawnevilclone 'NAME'", _("Spawn evil clone")); + if (isAllowCommand(ServerCommandType::clone)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: spawn player clone + mBrowserBox->addRow("/spawnclone 'NAME'", _("Spawn clone")); + } + if (isAllowCommand(ServerCommandType::slaveclone)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: spawn slave player clone + mBrowserBox->addRow("/spawnslaveclone 'NAME'", _("Spawn slave clone")); + } + if (isAllowCommand(ServerCommandType::evilclone)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: spawn evil player clone + mBrowserBox->addRow("/spawnevilclone 'NAME'", _("Spawn evil clone")); + } mBrowserBox->addRow("##3---"); - // TRANSLATORS: popup menu item - // TRANSLATORS: break guild - mBrowserBox->addRow("/gmbreakguild 'NAME'", _("Break guild")); + if (isAllowOtherCommand(ServerCommandType::breakguild)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: break guild + mBrowserBox->addRow("/gmbreakguild 'NAME'", _("Break guild")); + } } - if (mBeingId != BeingId_zero) + if (mBeingId != BeingId_zero && + isAllowCommand(ServerCommandType::kick)) { mBrowserBox->addRow("##3---"); // TRANSLATORS: popup menu item @@ -2948,7 +3077,8 @@ void PopupMenu::showMuteCommands() mBrowserBox->addRow(strprintf(_("Mute %s"), mName.c_str())); if (mBeingId != BeingId_zero && - Net::getNetworkType() != ServerType::TMWATHENA) + Net::getNetworkType() != ServerType::TMWATHENA && + isAllowCommand(ServerCommandType::mute)) { mBrowserBox->addRow("mute_+1", // TRANSLATORS: popup menu item @@ -3006,26 +3136,42 @@ void PopupMenu::showNpcGMCommands() { if (mBeingId != BeingId_zero) { - // TRANSLATORS: popup menu item - // TRANSLATORS: kick player - mBrowserBox->addRow("/kick :'BEINGID'", _("Kick")); + if (isAllowCommand(ServerCommandType::kick)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: kick player + mBrowserBox->addRow("/kick :'BEINGID'", _("Kick")); + } const bool legacy = Net::getNetworkType() == ServerType::TMWATHENA; if (!legacy) { - // TRANSLATORS: popup menu item - // TRANSLATORS: hide npc - mBrowserBox->addRow("/hidenpc 'EXTNAME'", _("Hide")); + if (isAllowCommand(ServerCommandType::hidenpc)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: hide npc + mBrowserBox->addRow("/hidenpc 'EXTNAME'", _("Hide")); + } mBrowserBox->addRow("##3---"); - mBrowserBox->addRow("/npcmove 'EEXTNAME' 'PLAYERX' 'PLAYERY'", + if (isAllowCommand(ServerCommandType::npcmove)) + { + mBrowserBox->addRow("/npcmove 'EEXTNAME' 'PLAYERX' 'PLAYERY'", + // TRANSLATORS: popup menu item + // TRANSLATORS: warp npc to player location + _("Recall")); + } + if (isAllowCommand(ServerCommandType::disguise)) + { + mBrowserBox->addRow("/disguise 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: disguise to npc + _("Disguise")); + } + if (isAllowCommand(ServerCommandType::tonpc)) + { // TRANSLATORS: popup menu item - // TRANSLATORS: warp npc to player location - _("Recall")); - // TRANSLATORS: popup menu item - // TRANSLATORS: disguise to npc - mBrowserBox->addRow("/disguise 'BEINGSUBTYPEID'", _("Disguise")); - // TRANSLATORS: popup menu item - // TRANSLATORS: warp to npc - mBrowserBox->addRow("/gotonpc 'EXTNAME'", _("Goto")); + // TRANSLATORS: warp to npc + mBrowserBox->addRow("/gotonpc 'EXTNAME'", _("Goto")); + } } } } @@ -3035,32 +3181,56 @@ void PopupMenu::showMonsterGMCommands() if (mBeingId != BeingId_zero) { const bool legacy = Net::getNetworkType() == ServerType::TMWATHENA; - // TRANSLATORS: popup menu item - // TRANSLATORS: kick monster - mBrowserBox->addRow("/kick :'BEINGID'", _("Kick")); - // TRANSLATORS: popup menu item - // TRANSLATORS: spawn monster - mBrowserBox->addRow("/spawn 'BEINGSUBTYPEID'", _("Spawn same")); - if (!legacy) + if (isAllowCommand(ServerCommandType::kick)) { - mBrowserBox->addRow("/spawnslave 'BEINGSUBTYPEID'", - // TRANSLATORS: popup menu item - // TRANSLATORS: spawn slave monster - _("Spawn slave")); // TRANSLATORS: popup menu item - // TRANSLATORS: disguise to monster - mBrowserBox->addRow("/disguise 'BEINGSUBTYPEID'", _("Disguise")); - mBrowserBox->addRow("##3---"); - // TRANSLATORS: popup menu item - // TRANSLATORS: show monster information - mBrowserBox->addRow("/monsterinfo 'BEINGSUBTYPEID'", _("Info")); + // TRANSLATORS: kick monster + mBrowserBox->addRow("/kick :'BEINGID'", _("Kick")); + } + if (isAllowCommand(ServerCommandType::monster)) + { // TRANSLATORS: popup menu item - // TRANSLATORS: show selected monster in current map - mBrowserBox->addRow("/mobsearch 'BEINGSUBTYPEID'", _("Search")); - mBrowserBox->addRow("/mobspawnsearch 'BEINGSUBTYPEID'", - // TRANSLATORS: popup menu item - // TRANSLATORS: show selected monster spawns in all maps - _("Search spawns")); + // TRANSLATORS: spawn monster + mBrowserBox->addRow("/spawn 'BEINGSUBTYPEID'", _("Spawn same")); + } + if (!legacy) + { + if (isAllowCommand(ServerCommandType::summon)) + { + mBrowserBox->addRow("/spawnslave 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: spawn slave monster + _("Spawn slave")); + } + if (isAllowCommand(ServerCommandType::disguise)) + { + mBrowserBox->addRow("/disguise 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: disguise to monster + _("Disguise")); + } + mBrowserBox->addRow("##3---"); + if (isAllowCommand(ServerCommandType::mobinfo)) + { + mBrowserBox->addRow("/monsterinfo 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: show monster information + _("Info")); + } + if (isAllowCommand(ServerCommandType::mobsearch)) + { + mBrowserBox->addRow("/mobsearch 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: show selected monster in current map + _("Search")); + } + if (isAllowCommand(ServerCommandType::whereis)) + { + mBrowserBox->addRow("/mobspawnsearch 'BEINGSUBTYPEID'", + // TRANSLATORS: popup menu item + // TRANSLATORS: show selected monster spawns in all maps + _("Search spawns")); + } } } } @@ -3070,12 +3240,18 @@ void PopupMenu::showFloorItemGMCommands() const bool legacy = Net::getNetworkType() == ServerType::TMWATHENA; if (legacy) return; - // TRANSLATORS: popup menu item - // TRANSLATORS: show item information - mBrowserBox->addRow("/iteminfo 'ITEMID'", _("Info")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show who drops item - mBrowserBox->addRow("/whodrops 'ITEMID'", _("Who drops")); + if (isAllowCommand(ServerCommandType::iteminfo)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show item information + mBrowserBox->addRow("/iteminfo 'ITEMID'", _("Info")); + } + if (isAllowCommand(ServerCommandType::whodrops)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show who drops item + mBrowserBox->addRow("/whodrops 'ITEMID'", _("Who drops")); + } } void PopupMenu::showItemGMCommands() @@ -3083,31 +3259,40 @@ void PopupMenu::showItemGMCommands() const bool legacy = Net::getNetworkType() == ServerType::TMWATHENA; if (legacy) return; - // TRANSLATORS: popup menu item - // TRANSLATORS: show item information - mBrowserBox->addRow("/iteminfo 'ITEMID'", _("Info")); - // TRANSLATORS: popup menu item - // TRANSLATORS: show who drops item - mBrowserBox->addRow("/whodrops 'ITEMID'", _("Who drops")); + if (isAllowCommand(ServerCommandType::iteminfo)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show item information + mBrowserBox->addRow("/iteminfo 'ITEMID'", _("Info")); + } + if (isAllowCommand(ServerCommandType::whodrops)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: show who drops item + mBrowserBox->addRow("/whodrops 'ITEMID'", _("Who drops")); + } mBrowserBox->addRow("##3---"); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 1", _("Add 1")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 5", _("Add 5")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 10", _("Add 10")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 100", _("Add 100")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 1000", _("Add 1000")); - // TRANSLATORS: popup menu item - // TRANSLATORS: gm create item - mBrowserBox->addRow("/createitem 'ITEMID' 10000", _("Add 10000")); + if (isAllowCommand(ServerCommandType::item)) + { + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 1", _("Add 1")); + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 5", _("Add 5")); + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 10", _("Add 10")); + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 100", _("Add 100")); + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 1000", _("Add 1000")); + // TRANSLATORS: popup menu item + // TRANSLATORS: gm create item + mBrowserBox->addRow("/createitem 'ITEMID' 10000", _("Add 10000")); + } } void PopupMenu::showGMPopup(const std::string &name) diff --git a/src/gui/popups/popupmenu.h b/src/gui/popups/popupmenu.h index d97021737..6d0c141f5 100644 --- a/src/gui/popups/popupmenu.h +++ b/src/gui/popups/popupmenu.h @@ -29,6 +29,8 @@ #include "enums/inventorytype.h" +#include "enums/resources/servercommandtype.h" + #include "enums/simpletypes/beingid.h" #include "enums/simpletypes/beingtypeid.h" #include "enums/simpletypes/itemcolor.h" @@ -206,6 +208,10 @@ class PopupMenu final : public Popup, public LinkHandler private: void initPopup(); + bool isAllowCommand(const ServerCommandTypeT command); + + bool isAllowOtherCommand(const ServerCommandTypeT command); + void setMousePos(); void setMousePos2(); |