Question

Спойлер

stock ShowPlayerOrdersList(playerid, stage = 0)
{
	new rows;

	mysql_query(dbHandle, "SELECT * FROM orders");

	rows = cache_num_rows();

	if(!rows)
		return SendClientMessage(playerid, C_RED, "В данный момент заказов нет");

	new fmt_str[130];

	STRING_GLOBAL[0] = EOS;

	new count;

	for(new idx = stage+1; idx < rows; idx ++)
	{
		if(count > 9) break;

		//if(cache_get_field_content_int(idx, "business") == 0)
		//	continue;

		format(fmt_str, sizeof fmt_str, "{FFFFFF}Бизнес: %d\tСтатус: %s\t{FFFFFF}Кол-во: %d шт.\tОплата: 50000р\n", cache_get_field_content_int(idx, "business"), cache_get_field_content_int(idx, "status") == 0 ? ("{FFCC00}[Ожидается]") : ("{FF3300}[В пути]"), cache_get_field_content_int(idx, "count"));
		strcat(STRING_GLOBAL, fmt_str);

		g_player_listitem[playerid][count] = cache_get_field_content_int(idx, "id");
		g_player_listitem_use[playerid] = idx;
		count ++;
	}

	if(count > 9)
	{
		strcat(STRING_GLOBAL, "Следующая страница >>");
	}

	ShowPlayerDialog
	(
		playerid, DIALOG_ORDERS, DIALOG_STYLE_LIST,
		"{FFCC00}Заказы продуктов бизнесами",
		STRING_GLOBAL,
		"Взять", "Отмена"
	);

	return 1;
}

 

 

Share this post


Link to post

2 answers to this question

  • 0

@archiboy6, попробуйте условие цикла сделать таким: idx <= rows.

Share this post


Link to post
  • 0

@odosenok @odosenok диалог выползает, но не пишет кол-во сколько заказали продуктов, и когда хочу взять заказ пишет заказ уже в пути

Спойлер
Цитата


case DIALOG_ORDERS:
	{
		if(response)
		{
			new bool: car;

			for(new i; i < MAX_PLAYER_OWNABLE_CARS; i ++)
			{
				if(!IsValidVehicle(PI[playerid][P_OWNABLE_CAR][i]))
					continue;

				if(GetVehicleData(PI[playerid][P_OWNABLE_CAR][i], veh_slot) == 4)
				{
					car = true;
					break;
				}
			}

			if(car == false)
				return SendClientMessage(playerid, C_RED, "У Вас нет грузовика");

			if(0 <= listitem <= 9)
			{
				new index = g_player_listitem[playerid][listitem];

				new Cache: result, rows;
				STRING_GLOBAL[0] = EOS;
				format(STRING_GLOBAL, sizeof STRING_GLOBAL, "SELECT * FROM orders WHERE id=%d AND status=0", index);
				result = mysql_query(dbHandle, STRING_GLOBAL);

				rows = cache_num_rows();

				if(!rows)
					return SendClientMessage(playerid, C_RED, "Этот заказ уже в пути"), cache_delete(result);

				new product = cache_get_field_content_int(0, "amount");

				if(PI[playerid][P_LOAD_JOB] < product)
					return SendClientMessage(playerid, C_RED, "У Вас недостаточно продуктов"), cache_delete(result);

				PI[playerid][P_ORDER_ID] = index;

				new businessid = cache_get_field_content_int(0, "business");

				GPSPlayer_(playerid, BizzInfo[businessid][bEntrx],  BizzInfo[businessid][bEntry],  BizzInfo[businessid][bEntrz], "Доставка продуктов");

				SendClientMessage(playerid, C_OSNOV, "Доставьте продукты к бизнесу, отмеченному на карте");
				SendClientMessage(playerid, C_OSNOV, "Если Вы не доставите заказ в течении 10 минут то он будет передан другому игроку");

				STRING_GLOBAL[0] = EOS;
				format(STRING_GLOBAL, sizeof STRING_GLOBAL, "UPDATE orders SET status=1, contractor=%d WHERE id=%d", PI[playerid][pID], index);
				mysql_query(dbHandle, STRING_GLOBAL);

				PI[playerid][P_ORDER_BIZ_ID] = GetPVarInt(playerid, "PlayerBizz");
				PI[playerid][P_ORDER_TIME] = gettime() + 60*10;

				if(BizzInfo[PI[playerid][P_ORDER_BIZ_ID]][bProduct] > 0)
				{
					BizzInfo[PI[playerid][P_ORDER_BIZ_ID]][bProduct] -= 100;
					MysqlUpdateBizzInt(PI[playerid][P_ORDER_BIZ_ID], "money", BizzInfo[PI[playerid][P_ORDER_BIZ_ID]][bMoney]);
					MysqlUpdateBizzInt(PI[playerid][P_ORDER_BIZ_ID], "product", BizzInfo[PI[playerid][P_ORDER_BIZ_ID]][bProduct]);
				}

				cache_delete(result);
			}
			else if(listitem == 10)
			{
				ShowPlayerOrdersList(playerid, g_player_listitem_use[playerid]);
			}
		}
	}

 

 

 

Share this post


Link to post
Guest
This topic is now closed to further replies.
Sign in to follow this  
Followers 0
  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • zerolora
      By zerolora
      Всем привет, помогите пожалуйста разобраться. Что за беда с командой. Младшие ранги могут банить основателей на раз-два. Хотя в команде вроде как есть защита FD
       
      CMD:ban(playerid, params[]) {     if(PI[playerid][pAdmin] < 3) return SCM(playerid, COLOR_RED, NO_DOSTUP_TEXT);     if(!ADuty{playerid}) return callcmd::apanel(playerid);     static id, days, reason[30];     if(sscanf(params, "uds[30]", id, days, reason)) return SCM(playerid, COLOR_RED, !"Используй: /ban [id] [days 1-30] [Причина]");     if(id == INVALID_PLAYER_ID) return 0;     if(GetString(PN(id), ""FULL_FD"") && !GetString(PN(id), ""FULL_FD2"")) return SCM(playerid, COLOR_RED, "Нельзя забанить создателя");     if(strlen(reason) > 30) return SCM(playerid, COLOR_RED, !"Не больше 30 символов!");     if(IsAIP(reason)) return 1;     if(CheckIsADomen(playerid, reason)) return 1;     if(!(1 <= days <= 30)) return SCM(playerid, COLOR_RED, !"Используй: /ban [id] [days 1-30] [Причина]");     if(id == playerid) return SCM(playerid, COLOR_GREY, !"Вы не можете выдать наказание самому себе!");     ASCMToAllf(COLOR_LIGHTRED, "Администратор %s[%i] забанил игрока %s[%i] на %i дней. Причина: %s", PN(playerid), playerid, PN(id), id, days, reason);     AntiReAction(playerid);     SPDf(id, 0, DIALOG_STYLE_MSGBOX, !"", !"Закрыть", !"", !"Вы получили бан аккаунта, если вы не согласны с решением Администратора, то напишите жалобу на форум, приложив данный скриншот.\n{2D8E35}%s", ServerCFG[server_forum]);     UpdatePlayerDataInt(id, "Warns", 0);     BanName(PN(id), PN(playerid), days, reason);     PI[playerid][pReputation] += 5;     UpdatePlayerDataInt(playerid, "Reputation", PI[playerid][pReputation]);     //  aml(8, playerid, PN(id), reason, days);     str_1[0] = EOS, f(str_1, sizeof(str_1), "%s[%i] забанил игрока %s[%i] на %i дней. Причина: %s", PN(playerid), playerid, PN(id), id, days, reason);     SavePunish(0, str_1, id);     return J_Kick(id); }