mirror of
https://github.com/EpochModTeam/Epoch.git
synced 2024-08-30 18:22:13 +00:00
128 lines
3.4 KiB
Plaintext
128 lines
3.4 KiB
Plaintext
|
/*
|
||
|
Epoch Change wall state
|
||
|
By Aaron Clark
|
||
|
*/
|
||
|
_object = param [0,objNull];
|
||
|
_anim = param [1,""];
|
||
|
_state = param [2,0];
|
||
|
if !(isNull _object) then {
|
||
|
|
||
|
_msg = "Missing Items";
|
||
|
// Get config
|
||
|
_config = 'CfgBaseBuilding' call EPOCH_returnConfig;
|
||
|
|
||
|
// upgradeBuildingPart
|
||
|
_objClass = typeOf _object;
|
||
|
|
||
|
// Add part
|
||
|
if (_state == 1) then {
|
||
|
_recipe = getArray(_config >> _objClass >> "upgradeBuildingPart");
|
||
|
|
||
|
_mags = magazines player;
|
||
|
|
||
|
_recipeCount = 0;
|
||
|
_numRemoved = 0;
|
||
|
_hasRecipeItems = true;
|
||
|
|
||
|
// Dry Run
|
||
|
{
|
||
|
_recipeItem = _x;
|
||
|
_recipeQty = 1;
|
||
|
if (typeName _x == "ARRAY") then {
|
||
|
_recipeItem = _x select 0;
|
||
|
_recipeQty = _x select 1;
|
||
|
};
|
||
|
_recipeCount = _recipeCount + _recipeQty;
|
||
|
_currentCount = { _x == _recipeItem } count _mags;
|
||
|
if (_currentCount < _recipeQty) exitWith {
|
||
|
_hasRecipeItems = false;
|
||
|
_msg = format["Need %2 %1 Have %3", _recipeItem call EPOCH_itemDisplayName,_recipeCount ,_currentCount];
|
||
|
};
|
||
|
}forEach _recipe;
|
||
|
|
||
|
// remove item
|
||
|
if (_hasRecipeItems) then {
|
||
|
{
|
||
|
_recipeItem = _x;
|
||
|
_recipeQty = 1;
|
||
|
if (typeName _x == "ARRAY") then {
|
||
|
_recipeItem = _x select 0;
|
||
|
_recipeQty = _x select 1;
|
||
|
};
|
||
|
if ([_recipeItem, "CfgWeapons"] call EPOCH_fnc_isAny) then {
|
||
|
_items = items player;
|
||
|
_currentCount = { _x == _recipeItem } count _items;
|
||
|
if (_currentCount >= _recipeQty) then {
|
||
|
for "_i" from 1 to _recipeQty do {
|
||
|
if (_recipeItem in _items) then {
|
||
|
player removeItem _recipeItem;
|
||
|
_numRemoved = _numRemoved + 1;
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
} else {
|
||
|
|
||
|
_mags = magazines player;
|
||
|
_currentCount = { _x == _recipeItem } count _mags;
|
||
|
if (_currentCount >= _recipeQty) then {
|
||
|
for "_i" from 1 to _recipeQty do {
|
||
|
if (_recipeItem in _mags) then {
|
||
|
player removeMagazine _recipeItem;
|
||
|
_numRemoved = _numRemoved + 1;
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
}forEach _recipe;
|
||
|
};
|
||
|
|
||
|
if (_numRemoved == _recipeCount) then {
|
||
|
_object animate [_anim, _state, true];
|
||
|
|
||
|
// tell server we should persist this object now
|
||
|
// [_object] remoteExec ["EPOCH_server_save_vehicles",2];
|
||
|
|
||
|
// push interacted object to save queue to save later
|
||
|
if !(_object in EPOCH_arr_interactedObjs) then{
|
||
|
EPOCH_arr_interactedObjs pushBack _object;
|
||
|
};
|
||
|
|
||
|
_dt = [format["<t size='0.8' shadow='0' color='#99ffffff'>%1 part on %2</t>","Added",_objClass call EPOCH_itemDisplayName], 0, 1, 5, 2, 0, 1] spawn bis_fnc_dynamictext;
|
||
|
|
||
|
} else {
|
||
|
_dt = [format["<t size='0.8' shadow='0' color='#99ffffff'>%1</t>", _msg], 0, 1, 5, 2, 0, 1] spawn bis_fnc_dynamictext;
|
||
|
};
|
||
|
|
||
|
|
||
|
|
||
|
} else {
|
||
|
|
||
|
// Remove part
|
||
|
_recipe = getArray(_config >> _objClass >> "removeBuildingPart");
|
||
|
|
||
|
_object animate [_anim, _state, true];
|
||
|
|
||
|
// push interacted object to save queue to save later
|
||
|
if !(_object in EPOCH_arr_interactedObjs) then{
|
||
|
EPOCH_arr_interactedObjs pushBack _object;
|
||
|
};
|
||
|
|
||
|
{
|
||
|
_craftItem = _x;
|
||
|
_craftQty = 1;
|
||
|
if (typeName _x == "ARRAY") then {
|
||
|
_craftItem = _x select 0;
|
||
|
_craftQty = _x select 1;
|
||
|
};
|
||
|
for "_i" from 1 to _craftQty do {
|
||
|
player addMagazine _craftItem;
|
||
|
};
|
||
|
}forEach _recipe;
|
||
|
|
||
|
_dt = [format["<t size='0.8' shadow='0' color='#99ffffff'>%1 part on %2</t>","Removed",_objClass call EPOCH_itemDisplayName], 0, 1, 5, 2, 0, 1] spawn bis_fnc_dynamictext;
|
||
|
};
|
||
|
|
||
|
};
|