sm-zombiereloaded-3/src/zr/menu.inc

197 lines
5.6 KiB
PHP
Raw Normal View History

2009-04-29 01:58:41 +02:00
/*
* ============================================================================
*
2008-10-04 22:59:11 +02:00
* Zombie:Reloaded
2009-04-29 01:58:41 +02:00
*
* File: menu.inc
* Type: Core
* Description: Base menu functions for the plugin.
*
* Copyright (C) 2009 Greyscale, Richard Helgeby
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
2009-04-29 01:58:41 +02:00
*
* ============================================================================
2008-10-04 22:59:11 +02:00
*/
/**
* Create commands specific to ZMenu.
*/
MenuOnCommandsCreate()
{
// Register ZMenu command.
RegConsoleCmd(SAYHOOKS_KEYWORD_ZMENU, ZMenuCommand, "Opens ZR's main menu.");
}
/**
* Command callback (zmenu)
* Opens ZR's main menu.
*
* @param client The client index.
* @param argc Argument count.
*/
public Action:ZMenuCommand(client, argc)
{
// If client is console, then stop and tell them this feature is for players only.
if (ZRIsConsole(client))
{
TranslationPrintToServer("Must be player");
return Plugin_Handled;
}
// Send main menu.
MenuMain(client);
// This stops the "Unknown command" message in client's console.
return Plugin_Handled;
}
2009-04-29 01:58:41 +02:00
/**
* Show main menu to client.
*
* @param client The client index.
*/
MenuMain(client)
2008-10-04 22:59:11 +02:00
{
2009-04-29 01:58:41 +02:00
// Create menu handle.
new Handle:menu_main = CreateMenu(MenuMainHandle);
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Make client global translations target.
2008-10-04 22:59:11 +02:00
SetGlobalTransTarget(client);
decl String:publictrigger[4];
decl String:silenttrigger[4];
// Get public/silent chat triggers.
SayHooksGetPublicChatTrigger(publictrigger, sizeof(publictrigger));
SayHooksGetSilentChatTrigger(silenttrigger, sizeof(silenttrigger));
2009-04-29 01:58:41 +02:00
// Set menu title.
SetMenuTitle(menu_main, "%t\n ", "Menu main title", publictrigger, silenttrigger);
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Initialize menu lines.
decl String:zadmin[256];
decl String:zclass[256];
decl String:zspawn[256];
decl String:ztele[256];
decl String:zhp[256];
decl String:zmarket[256];
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Translate each line into client's language.
Format(zadmin, sizeof(zadmin), "%t", "Menu main zadmin", SAYHOOKS_KEYWORD_ZMENU);
Format(zclass, sizeof(zclass), "%t", "Menu main zclass", SAYHOOKS_KEYWORD_ZADMIN);
Format(zspawn, sizeof(zspawn), "%t", "Menu main zspawn", SAYHOOKS_KEYWORD_ZCLASS);
Format(ztele, sizeof(ztele), "%t", "Menu main ztele", SAYHOOKS_KEYWORD_ZTELE);
Format(zhp, sizeof(zhp), "%t", "Menu main zhp", SAYHOOKS_KEYWORD_ZHP);
Format(zmarket, sizeof(zmarket), "%t", "Menu main zmarket", SAYHOOKS_KEYWORD_ZMARKET);
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Add items to menu.
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Disable option if client isn't an admin.
new bool:admin = ZRIsClientAdmin(client);
AddMenuItem(menu_main, "zadmin", zadmin, MenuGetItemDraw(admin));
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
AddMenuItem(menu_main, "zclass", zclass);
2008-10-04 22:59:11 +02:00
AddMenuItem(menu_main, "zspawn", zspawn);
AddMenuItem(menu_main, "ztele", ztele);
AddMenuItem(menu_main, "zhp", zhp);
AddMenuItem(menu_main, "zmarket", zmarket);
2008-10-04 22:59:11 +02:00
2009-04-29 01:58:41 +02:00
// Display menu to client.
2008-10-04 22:59:11 +02:00
DisplayMenu(menu_main, client, MENU_TIME_FOREVER);
}
2009-04-29 01:58:41 +02:00
/**
* Menu callback (main)
* Redirects client to selected option's handle code.
*
* @param menu The menu handle.
* @param action Action client is doing in menu.
* @param client The client index.
* @param slot The menu slot selected. (starting from 0)
*/
public MenuMainHandle(Handle:menu, MenuAction:action, client, slot)
2008-10-04 22:59:11 +02:00
{
2009-04-29 01:58:41 +02:00
// Client selected an option.
2008-10-04 22:59:11 +02:00
if (action == MenuAction_Select)
{
2009-04-29 01:58:41 +02:00
// Create variable to possible resend menu later.
new bool:resend = true;
2008-10-04 22:59:11 +02:00
switch(slot)
{
2009-04-29 01:58:41 +02:00
// Selected zadmin.
case 0:
2008-10-04 22:59:11 +02:00
{
2009-04-29 01:58:41 +02:00
// Copy return to resend variable.
resend = !ZRAdminMenu(client);
2008-10-04 22:59:11 +02:00
}
// Select zclass.
case 1:
2008-10-04 22:59:11 +02:00
{
2009-04-29 01:58:41 +02:00
// Send class menu
ClassMenuMain(client);
2009-04-29 01:58:41 +02:00
// Don't resend this menu.
resend = false;
2008-10-04 22:59:11 +02:00
}
// Select zspawn.
case 2:
2008-10-04 22:59:11 +02:00
{
2009-04-29 01:58:41 +02:00
// Send zspawn command from client.
ZSpawnClient(client);
2008-10-04 22:59:11 +02:00
}
// Select ztele.
case 3:
{
2009-04-29 01:58:41 +02:00
// Copy return to resend variable.
resend = !ZTeleClient(client);
}
// Select zhp.
case 4:
2008-10-04 22:59:11 +02:00
{
// Toggle ZHP.
ZHPToggle(client);
2008-10-04 22:59:11 +02:00
}
// Select zmarket.
case 5:
{
// Send ZMarket menu.
resend = !ZMarketMenuMain(client);
}
2008-10-04 22:59:11 +02:00
}
2009-04-29 01:58:41 +02:00
// Resend is still true, then resend menu.
if (resend)
{
MenuMain(client);
}
2008-10-04 22:59:11 +02:00
}
2009-04-29 01:58:41 +02:00
// Client exited menu.
2008-10-04 22:59:11 +02:00
if (action == MenuAction_End)
{
2009-04-29 01:58:41 +02:00
CloseHandle(menu);
2008-10-04 22:59:11 +02:00
}
2009-04-29 01:58:41 +02:00
}
/**
* Return itemdraw flag for SM menus.
*
* @param condition If this is true, item will be drawn normally.
*/
MenuGetItemDraw(bool:condition)
{
return condition ? ITEMDRAW_DEFAULT : ITEMDRAW_DISABLED;
}