Перейти к содержанию
Авторизация  
spahlevanyan

Помогите создать /lpanel ИЛИ /lmenu

Рекомендуемые сообщения

spahlevanyan

Ребят нужно делать так, чтобы возможно было в /lpanel принять там,увольнять и управлять транспортом фракции. Помогите

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
spahlevanyan
В 9/11/2018 в 12:23 AM, SCRIPTMAN сказал:

Есть. Поиском на форуме воспользуйся. А вообще, это простые команды.

 

В 9/5/2016 в 3:00 PM, Na'Vi сказал:

Для работы команды вам потребуется:

 

MySQL R39-4

Командный процессор DC_CMD

 

  Функционал (Скрыть контент)

Функциональность меню лидера:


- Увольнение в OFFLINE
- Понижение/Повышение в OFFLINE
- Выговоры в OFFLINE
- Список всех сотрудников во фракции

 

 

 

Для начала создадим команду


CMD:leadermenu(playerid) // Команда
{
        if(gPlayerLogged[playerid] == 0) return 1; // Проверка на авторизация игрока [Измените на свою]
        if(Player[playerid][pLeader] <= 0) return SendClientMessage(playerid, 0x009999FF, "Вы не являетесь руководителем"); // Проверка на лидерку [Измените на свою]
        return ShowPlayerDialog(playerid, 5379, DIALOG_STYLE_LIST, "Меню лидера", "1. Список сотрудников в offline\n2. Выдать выговор в offline\n3. Уволить в offline\n4. Понизить/Повысить в offline", "Выбрать", "Закрыть"); // Функции
}

В OnDialogResponse добавляем


//------------------------------------------------------------------------------
if(dialogid == 5379)
{
        if(!response) return 1;
        switch(listitem)
        {
                case 0: new string[64],mysql_format(handle,string,sizeof(string),"SELECT * FROM `acc` WHERE `Team` = '%d'",Player[playerid][pTeam]),mysql_function_query(handle, string, true, "OFFmembers", "d",playerid);
                case 1: ShowPlayerDialog(playerid, 5380, DIALOG_STYLE_INPUT, "Меню лидера: Выговор", "Для того что-бы выдавать выговор,необходимо указать ник.\nУкажите Имя_Фамилия сотрудника:", "Выдать", "Закрыть");
                case 2: ShowPlayerDialog(playerid, 5381, DIALOG_STYLE_INPUT, "Меню лидера: Увольнение", "Для того что-бы уволить,необходимо указать ник.\nУкажите Имя_Фамилия сотрудника:", "Выдать", "Закрыть");
                case 3: ShowPlayerDialog(playerid, 5382, DIALOG_STYLE_INPUT, "Меню лидера: Повышение/Понижение", "Для того что-бы повысить/понизить,необходимо указать ник и ранг\nПример: Nick_Name,9\n\nУкажите Имя_Фамилия,Ранг:", "Выдать", "Закрыть");
        }
}
//------------------------------------------------------------------------------
if(dialogid == 5380)
{
        if(!response) return 1;
        if(!strlen(inputtext)) return SendClientMessage(playerid,-1,"Укажите Имя_Фамилия"),ShowPlayerDialog(playerid, 5380, DIALOG_STYLE_INPUT, "Меню лидера: Выговор", "Для того что-бы выдавать выговор,необходимо указать ник.\nУкажите Имя_Фамилия сотрудника:", "Выдать", "Закрыть");
        new qstring[64];
        format(qstring,sizeof(qstring), "SELECT * FROM "TABLE_ACCOUNT" WHERE `Name`='%s'", inputtext);
        mysql_function_query(handle, qstring, true, "VigovorOffline", "is", playerid, inputtext);
}
//------------------------------------------------------------------------------
if(dialogid == 5381)
{
        if(!response) return 1;
        if(!strlen(inputtext)) return SendClientMessage(playerid,-1,"Укажите Имя_Фамилия"),ShowPlayerDialog(playerid, 5381, DIALOG_STYLE_INPUT, "Меню лидера: Увольнение", "Для того что-бы уволить,необходимо указать ник.\nУкажите Имя_Фамилия сотрудника:", "Выдать", "Закрыть");
        new qstring[64];
        format(qstring,sizeof(qstring), "SELECT * FROM "TABLE_ACCOUNT" WHERE `Name`='%s'", inputtext);
        mysql_function_query(handle, qstring, true, "UvalOffline", "is", playerid, inputtext);
}
//------------------------------------------------------------------------------
if(dialogid == 5382)
{
        if(!response) return 1;
        if(!strlen(inputtext)) return SendClientMessage(playerid,-1,"Укажите Имя_Фамилия,Ранг"),ShowPlayerDialog(playerid, 5382, DIALOG_STYLE_INPUT, "Меню лидера: Повышение/Понижение", "Для того что-бы повысить/понизить,необходимо указать ник и ранг\nПример: Dmitriy_Grishin,9\n\nУкажите Имя_Фамилия,Ранг:", "Выдать", "Закрыть");
        new qstring[64],name, rang;
    if(sscanf(inputtext, "p<,>si", name, rang)) return SCM(playerid,-1,"Укажите Имя_Фамилия,Ранг через запятую"),ShowPlayerDialog(playerid, 5382, DIALOG_STYLE_INPUT, "Меню лидера: Повышение/Понижение", "Для того что-бы повысить/понизить,необходимо указать ник и ранг\nПример: Dmitriy_Grishin,9\n\nУкажите Имя_Фамилия,Ранг:", "Выдать", "Закрыть");
        format(qstring,sizeof(qstring), "SELECT * FROM "TABLE_ACCOUNT" WHERE `Name`='%s'", name);
        mysql_function_query(handle, qstring, true, "PonPovOffline", "isi", playerid,name,rang);
}
//------------------------------------------------------------------------------

Далее в самый конец мода вставляем


forward OFFmembers(playerid);
public OFFmembers(playerid)
{
        new rows, fields,i,string2[64],string[1256],name[MAX_PLAYER_NAME];
        cache_get_data(rows, fields);
        for(i = 0; i < rows; i++)
        {
                cache_get_field_content(i, "Name", string2),strmid(name, string2, 0, strlen(string2), MAX_PLAYER_NAME); // Достём имя Name,у Вас может быть подругому.
                new rang = cache_get_field_content_int(i, "Rang"); // У Вас в БД Rang может означаться подругому (Ранг)
                new vigovor = cache_get_field_content_int(i, "Fwarns"); // У Вас в БД Fwarns может означаться подругому (Выговоры)
                new time = cache_get_field_content_int(i, "PlayerDTimers"); // У Вас в БД Rang может означаться подругому (Отыграно за день)
                format(string,sizeof(string),"%s | Ранг: %d | Выговоры: %d/3 | За день: %d мин\n%s",name,rang,vigovor,time,string); // Форматируем диалог
                ShowPlayerDialog(playerid, 0, DIALOG_STYLE_LIST, "Меню лидера: Сотрудники",string, "", "Закрыть"); // Выводим диалог
        }
        return true;
}
//------------------------------------------------------------------------------
forward VigovorOffline(playerid,name[]);
public VigovorOffline(playerid,name[])
{
        new query[128];
        new teams = cache_get_field_content_int(0, "Team"); // У Вас в БД Team может означаться подругому (Организация)
        new vigovor = cache_get_field_content_int(0, "Fwarns"); // У Вас в БД Fwarns может означаться подругому (Выговоры)
        if(Player[playerid][pTeam] != teams) return SCM(playerid,-1,"Данный игрок не в Вашей фракции."); // Проверяем на фракцию
        if(vigovor >= 3) return SCM(playerid,-1,"У сотрудника больше 3-ёх выговоров."); // Проверка на выговоры
        mysql_format(handle,query,sizeof(query),"UPDATE `acc` SET `Fwarns` = (`Fwarns` + '1') WHERE `Name` = '%s'",name); // Форматируем запрос
    mysql_function_query(handle, query, true, "", ""); // Отправляем
        format(strcom, 156, "[R] Руководитель %s[%d] выдал выговор[%d/3] %s[OFFLINE]",Player[playerid][pName], playerid,vigovor+1,name); // Форматируем текст для всех
        SendRadioMessage(Player[playerid][pLeader], 0x429252FF, strcom); // Отправляем в чат организации (у Вас может быть подругому)
        return true;
}
//------------------------------------------------------------------------------
forward UvalOffline(playerid,name[]);
public UvalOffline(playerid,name[])
{
        new query[128];
        new teams = cache_get_field_content_int(0, "Team"); // У Вас в бд Team может быть подругому. (Организация)
        if(Player[playerid][pTeam] != teams) return SCM(playerid,-1,"Данный игрок не в Вашей фракции."); // Проверка на фракцию
        format(query,sizeof(query),"UPDATE "TABLE_ACCOUNT" SET `Leader` = '0',`Member` = '0',`Rang` = '0',`Team` = '0',`Fskin` = '0' WHERE `Name` = '%s'",name); // Обнляем все переменные. (Заменяем на свои)
        mysql_function_query(handle, query, true, "", ""); // Отправляем запрос выше
        format(strcom, 156, "[R] Руководитель %s[%d] уволил %s[OFFLINE]",Player[playerid][pName], playerid,name); // Форматируем текст для всех
        SendRadioMessage(Player[playerid][pLeader], 0x429252FF, strcom); // Отправляем в чат организации (у Вас может быть подругому)
        return true;
}
//------------------------------------------------------------------------------
forward PonPovOffline(playerid,name[],rang);
public PonPovOffline(playerid,name[],rang)
{
        new query[128];
        new teams = cache_get_field_content_int(0, "Team"); // Достаём инфу о фракции
        if(Player[playerid][pTeam] != teams) return SCM(playerid,-1,"Данный игрок не в Вашей фракции."); // Проверка на фракцию
        if(rang >= Player[playerid][pRang]) // Проверяем на ранг
        {
                SendMes(playerid, COLOR_GRAD1, "{009999} Ранг не должен быть больше %d и меньше 0", Player[playerid][pRang]-1);
                return 1;
        }
        if(rang < 0) return SCM(playerid, 0x009999FF, "Ранг не должен быть меньше 0"); // Проверяем на ранг
        format(strcom, 156, "[R] Руководитель %s[%d] установил %d ранг для %s[OFFLINE]",Player[playerid][pName], playerid,rang,name); // Форматируем текст для всех
        SendRadioMessage(Player[playerid][pLeader], 0x429252FF, strcom); // Отправляем в чат организации (у Вас может быть подругому)
        format(query,sizeof(query),"UPDATE "TABLE_ACCOUNT" SET `Rang` = '%d' WHERE `Name` = '%s'",rang,name); // Форматируем запрос (Rang может быть подругому)
        mysql_function_query(handle, query, true, "", ""); // Отправляем запрос
        return true;
}

Готово!

 

Автор Na'Vi

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти
Авторизация  

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

Мы разместили cookie-файлы на ваше устройство, чтобы помочь сделать этот сайт лучше. Вы можете изменить свои настройки cookie-файлов, или продолжить без изменения настроек.