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
134 lines
3.3 KiB
Plaintext
134 lines
3.3 KiB
Plaintext
/*
|
|
Author: Raimonds Virtoss - EpochMod.com
|
|
|
|
Contributors:
|
|
|
|
Description:
|
|
DESC-TBA
|
|
|
|
Licence:
|
|
Arma Public License Share Alike (APL-SA) - https://www.bistudio.com/community/licenses/arma-public-license-share-alike
|
|
|
|
Github:
|
|
https://github.com/EpochModTeam/Epoch/tree/master/Sources/epoch_code/gui/scripts/dynamenu/Epoch_dynamicMenu.sqf
|
|
*/
|
|
disableSerialization;
|
|
private ["_in","_selfOrTarget","_display","_cfg","_arr","_buttonSettings","_hasTarget","_checkConfigs","_entries"];
|
|
_in = [_this, 0, "",[""]] call BIS_fnc_param;
|
|
|
|
_display = findDisplay 66600;
|
|
_cfg = "CfgActionMenu" call EPOCH_returnConfig;
|
|
_arr = [];
|
|
_buttonSettings = [];
|
|
|
|
/** Variable Defines **/
|
|
{
|
|
call compile (format ["%1 = %2;",configName _x,getText _x]);
|
|
} count (configProperties [(_cfg >> "variableDefines"),"true",false]);
|
|
|
|
_hasTarget = !(dyna_cursorTarget isEqualTo objNull);
|
|
|
|
if (isNull _display && dialog) exitWith {false call Epoch_dynamicMenuCleanup; false};
|
|
|
|
if (isNull _display) then {
|
|
if (_hasTarget) then {
|
|
createDialog "rmx_dynamenu";
|
|
} else {
|
|
findDisplay 46 createDisplay "rmx_dynamenu";
|
|
};
|
|
};
|
|
|
|
_selfOrTarget = if !(_hasTarget) then {"self"} else {"target"};
|
|
_checkConfigs = {
|
|
|
|
_config = switch (_in) do {
|
|
case "build_upgrade":
|
|
{
|
|
_cfg = "CfgBaseBuilding" call EPOCH_returnConfig;
|
|
(_cfg >> dyna_cursorTargetType)
|
|
};
|
|
case "":
|
|
{
|
|
(_cfg >> _selfOrTarget)
|
|
};
|
|
default
|
|
{
|
|
_c = format ["_cfg >> '%1'",_selfOrTarget];
|
|
_arr = _this;
|
|
{
|
|
_c = _c + (format [" >> '%1'",_x]);
|
|
} forEach _arr;
|
|
|
|
(call compile _c)
|
|
};
|
|
};
|
|
|
|
switch (_in) do {
|
|
case "build_upgrade":
|
|
{
|
|
if !(isClass _config) exitWith {_in = "";};
|
|
|
|
{
|
|
_dName = getText(configfile >> "CfgVehicles" >> (_x select 0) >> "DisplayName");
|
|
_tTip = "";
|
|
_icon = "";
|
|
{
|
|
if !(_x isEqualType []) then {_x = [_x, 1]};
|
|
_c = configfile >> "CfgMagazines" >> (_x select 0);
|
|
_tTip = _tTip + format ["[%1 x %2] ", _x select 1, getText(_c >> "DisplayName")];
|
|
if (_icon isEqualTo "") then {_icon = getText (_c >> "picture")};
|
|
} forEach (_x select 1);
|
|
|
|
_tooltip = format ["%1 >> %2 ",_dName,_tTip];
|
|
_action = format ["[dyna_cursorTarget,%1] call EPOCH_upgradeBUILD; true call Epoch_dynamicMenuCleanup;",_forEachIndex];
|
|
|
|
_buttonSettings pushBack [
|
|
_icon,
|
|
_tooltip,
|
|
_action
|
|
];
|
|
|
|
} forEach (getArray (_config >> "upgradeBuilding"));
|
|
|
|
|
|
};
|
|
default
|
|
{
|
|
_configs = "true" configClasses _config;
|
|
{
|
|
if (call compile (getText(_x >> "condition"))) then {
|
|
|
|
if (_selfOrTarget isEqualTo "self" || dyna_distance) then {
|
|
|
|
_subclasses = configProperties [_x, "isClass _x",true];
|
|
|
|
_action = if (_subclasses isEqualTo []) then {
|
|
format ["%1; true call Epoch_dynamicMenuCleanup;",getText(_x >> "action")]
|
|
} else {
|
|
format ["%2 %1 call Epoch_dynamicMenu;",_arr + [(configName _x)],getText(_x >> "action")]
|
|
};
|
|
|
|
_buttonSettings pushBack [
|
|
getText(_x >> "icon"),
|
|
getText(_x >> "tooltip"),
|
|
_action
|
|
];
|
|
};
|
|
};
|
|
} forEach _configs;
|
|
};
|
|
};
|
|
};
|
|
|
|
call _checkConfigs;
|
|
if (_buttonSettings isEqualTo []) then {_selfOrTarget = "self"; call _checkConfigs;};
|
|
|
|
_entries = count _buttonSettings;
|
|
if !(_entries <= 0) then {
|
|
[_entries, _buttonSettings] call epoch_dynamicMenuPopulate;
|
|
} else {
|
|
true call Epoch_dynamicMenuCleanup;
|
|
};
|
|
|
|
true
|