mirror of
https://github.com/EpochModTeam/Epoch.git
synced 2024-08-30 18:22:13 +00:00
87c23b106f
* first build for 0.3.8 * 0.3.8.0190 * 0.3.8.0202 * 0.3.8.0213 * 0.3.7.0214 * 0.3.8.0222 * 0.3.8.0246 * 0.3.8.0247 fixed typo * 0.3.8.0249 more fixes for server compiler * 0.3.8.0256 * add build number and simple batch file for packing * match build number with internal * add build numbers to server pbo's and mission files also reworked build script for more options * 0.3.8.0261 * 0.3.8.0261 * 0.3.8.0283 * 0.3.8.0284 * changelog * 0.3.8.0307 * 0.3.8.0311 * remove old BEC plugin * update redis-server.exe to latest build and full config * 0.3.8.0314 * 0.3.8.0315 * inverse logic This should correctly prevent spawning these units nearby jammer or protection zones * use pushbackUnique here * optimized loot function by using selectRandom instead of slower sqf logic * 0.3.8.0316 * make use of new getDir functionality instead of BIS fnc * add lower disconnect value to server.cfg * use new getpos functionality * 0.3.8.0317 * 0.3.8.0319 * 0.3.8.0327 * 0.3.8.0338 changelog update tba * changelog * 0.3.8.0341 * BE update * 0.3.8.0353 * changelog * removed duplicates * 0.3.8.0355 fixed error in getIDC * 0.3.8.0356 revert to BIS_fnc_param as params threw errors * 0.3.8.0357 fixes for #496 #497 * 0.3.8.0359 fixed #497 fixed #496 * 0.3.8.0365 * 0.3.8.0371 * 0.3.8.0373 * 0.3.8.0379 * 0.3.8.0381 * 0.3.8.0386 * 0.3.8.0393 * 0.3.8.0395 * 0.3.8.0396 * 0.3.8.0397 * 0.3.8.0406 * 0.3.8.0409 * 0.3.8.0410 loot balance suppress error in spawnloot make near object check based on building size * 0.3.8.0412 * 0.3.8.0414 removed classes with scope 0 test remove loot trash on gear for #498 fixed #501 * 0.3.8.0415 * same
102 lines
3.3 KiB
Plaintext
102 lines
3.3 KiB
Plaintext
private ["_stockLimit","_allowAdd","_limit","_slot","_aiItems","_itemClasses","_itemQtys","_qtyIndex","_item","_sizeOut","_worth","_cryptoCount","_itemWorth","_itemTax","_tax","_index","_uiItem","_config"];
|
|
params ["_control","_selected"];
|
|
|
|
if !(isNull EPOCH_lastNPCtradeTarget) then {
|
|
|
|
_allowAdd = true;
|
|
_stockLimit = false;
|
|
_uiItem = (_selected select 0) lbData (_selected select 1);
|
|
|
|
_config = 'CfgPricing' call EPOCH_returnConfig;
|
|
if (isClass(_config >> _uiItem)) then{
|
|
|
|
if !(_control in[41500, 41503]) then {
|
|
|
|
// limit adding more if item is over stocked
|
|
if (_control == 41501) then {
|
|
_slot = EPOCH_lastNPCtradeTarget getVariable["AI_SLOT", -1];
|
|
_aiItems = EPOCH_lastNPCtradeTarget getVariable["AI_ITEMS", [[], []]];
|
|
_itemClasses = _aiItems select 0;
|
|
_itemQtys = _aiItems select 1;
|
|
|
|
// find item and get current qty
|
|
_qtyIndex = _itemClasses find _uiItem;
|
|
if (_qtyIndex != -1) then {
|
|
_limit = ["CfgTraderLimits", _uiItem, 100] call EPOCH_fnc_returnConfigEntryV2;
|
|
if (_itemQtys select _qtyIndex >= _limit) then{
|
|
_stockLimit = true;
|
|
_allowAdd = false;
|
|
};
|
|
};
|
|
};
|
|
|
|
if (_uiItem isKindOf "Air" || _uiItem isKindOf "Ship" || _uiItem isKindOf "LandVehicle" || _uiItem isKindOf "Tank") then {
|
|
|
|
// check if a vehicle is already on the list
|
|
_sizeOut = lbSize 41501;
|
|
if (_sizeOut > 0) then {
|
|
for "_i" from 0 to(_sizeOut - 1) do {
|
|
_item = lbData[41501, _i];
|
|
if (_item isKindOf "Air" || _item isKindOf "Ship" || _item isKindOf "LandVehicle" || _item isKindOf "Tank") exitWith{
|
|
_allowAdd = false;
|
|
};
|
|
};
|
|
};
|
|
_sizeOut = lbSize 41502;
|
|
if (_sizeOut > 0) then {
|
|
for "_i" from 0 to(_sizeOut - 1) do {
|
|
_item = lbData[41502, _i];
|
|
if (_item isKindOf "Air" || _item isKindOf "Ship" || _item isKindOf "LandVehicle" || _item isKindOf "Tank") exitWith{
|
|
_allowAdd = false;
|
|
};
|
|
};
|
|
};
|
|
// disallow adding item to list of already one
|
|
};
|
|
};
|
|
|
|
if (_allowAdd) then {
|
|
_index = lbAdd[_control, ((_selected select 0) lbText(_selected select 1))];
|
|
lbSetData[_control, _index, _uiItem];
|
|
|
|
lbSetPicture[_control, _index, ((_selected select 0) lbPicture(_selected select 1))];
|
|
(_selected select 0) lbDelete(_selected select 1);
|
|
|
|
_cryptoCount = 0;
|
|
_sizeOut = lbSize 41501;
|
|
//_array = [];
|
|
if (_sizeOut > 0) then {
|
|
for "_i" from 0 to(_sizeOut - 1) do {
|
|
_item = lbData[41501, _i];
|
|
//_array pushBack _item;
|
|
_worth = getNumber(_config >> _item >> "price");
|
|
_cryptoCount = _cryptoCount + _worth;
|
|
};
|
|
};
|
|
ctrlSetText[41004, (format["%1 Krypto", _cryptoCount])];
|
|
|
|
_cryptoCount = 0;
|
|
_sizeOut = lbSize 41502;
|
|
if (_sizeOut > 0) then {
|
|
for "_i" from 0 to(_sizeOut - 1) do {
|
|
_item = lbData[41502, _i];
|
|
_itemWorth = getNumber(_config >> _item >> "price");
|
|
_itemTax = getNumber(_config >> _item >> "tax");
|
|
_tax = _itemWorth * (EPOCH_taxRate + _itemTax);
|
|
_itemWorth = ceil(_itemWorth + _tax);
|
|
_cryptoCount = _cryptoCount + _itemWorth;
|
|
};
|
|
};
|
|
ctrlSetText[41005, (format["%1 Krypto", _cryptoCount])];
|
|
} else {
|
|
if (_stockLimit) then{
|
|
["<t size='1.6' color='#99ffffff'>Trader has the maximum amount of this item</t>", 5] call Epoch_dynamicText;
|
|
} else {
|
|
["<t size='1.6' color='#99ffffff'>Limit one per trade</t>", 5] call Epoch_dynamicText;
|
|
};
|
|
};
|
|
};
|
|
} else {
|
|
closeDialog 0;
|
|
};
|