mirror of
https://github.com/FlightControl-Master/MOOSE.git
synced 2025-10-29 16:58:06 +00:00
#CTLD
* Added categories for Troops
This commit is contained in:
parent
abf694aa81
commit
e8ab86ab7f
@ -1390,6 +1390,7 @@ function CTLD:New(Coalition, Prefixes, Alias)
|
|||||||
-- sub categories
|
-- sub categories
|
||||||
self.usesubcats = false
|
self.usesubcats = false
|
||||||
self.subcats = {}
|
self.subcats = {}
|
||||||
|
self.subcatsTroop = {}
|
||||||
|
|
||||||
-- disallow building in loadzones
|
-- disallow building in loadzones
|
||||||
self.nobuildinloadzones = true
|
self.nobuildinloadzones = true
|
||||||
@ -3468,6 +3469,12 @@ function CTLD:_RefreshF10Menus()
|
|||||||
self.subcats[entry.Subcategory] = entry.Subcategory
|
self.subcats[entry.Subcategory] = entry.Subcategory
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
for _id,_cargo in pairs(self.Cargo_Troops) do
|
||||||
|
local entry = _cargo -- #CTLD_CARGO
|
||||||
|
if not self.subcatsTroop[entry.Subcategory] then
|
||||||
|
self.subcatsTroop[entry.Subcategory] = entry.Subcategory
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- build unit menus
|
-- build unit menus
|
||||||
@ -3506,11 +3513,24 @@ function CTLD:_RefreshF10Menus()
|
|||||||
-- sub menu troops management
|
-- sub menu troops management
|
||||||
if cantroops then
|
if cantroops then
|
||||||
local troopsmenu = MENU_GROUP:New(_group,"Load troops",toptroops)
|
local troopsmenu = MENU_GROUP:New(_group,"Load troops",toptroops)
|
||||||
|
if self.usesubcats then
|
||||||
|
local subcatmenus = {}
|
||||||
|
for _name,_entry in pairs(self.subcatsTroop) do
|
||||||
|
subcatmenus[_name] = MENU_GROUP:New(_group,_name,troopsmenu)
|
||||||
|
end
|
||||||
|
for _,_entry in pairs(self.Cargo_Troops) do
|
||||||
|
local entry = _entry -- #CTLD_CARGO
|
||||||
|
local subcat = entry.Subcategory
|
||||||
|
menucount = menucount + 1
|
||||||
|
menus[menucount] = MENU_GROUP_COMMAND:New(_group,entry.Name,subcatmenus[subcat],self._LoadTroops, self, _group, _unit, entry)
|
||||||
|
end
|
||||||
|
else
|
||||||
for _,_entry in pairs(self.Cargo_Troops) do
|
for _,_entry in pairs(self.Cargo_Troops) do
|
||||||
local entry = _entry -- #CTLD_CARGO
|
local entry = _entry -- #CTLD_CARGO
|
||||||
menucount = menucount + 1
|
menucount = menucount + 1
|
||||||
menus[menucount] = MENU_GROUP_COMMAND:New(_group,entry.Name,troopsmenu,self._LoadTroops, self, _group, _unit, entry)
|
menus[menucount] = MENU_GROUP_COMMAND:New(_group,entry.Name,troopsmenu,self._LoadTroops, self, _group, _unit, entry)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
local unloadmenu1 = MENU_GROUP_COMMAND:New(_group,"Drop troops",toptroops, self._UnloadTroops, self, _group, _unit):Refresh()
|
local unloadmenu1 = MENU_GROUP_COMMAND:New(_group,"Drop troops",toptroops, self._UnloadTroops, self, _group, _unit):Refresh()
|
||||||
local extractMenu1 = MENU_GROUP_COMMAND:New(_group, "Extract troops", toptroops, self._ExtractTroops, self, _group, _unit):Refresh()
|
local extractMenu1 = MENU_GROUP_COMMAND:New(_group, "Extract troops", toptroops, self._ExtractTroops, self, _group, _unit):Refresh()
|
||||||
end
|
end
|
||||||
@ -3603,7 +3623,8 @@ end
|
|||||||
-- @param #number NoTroops Size of the group in number of Units across combined templates (for loading).
|
-- @param #number NoTroops Size of the group in number of Units across combined templates (for loading).
|
||||||
-- @param #number PerTroopMass Mass in kg of each soldier
|
-- @param #number PerTroopMass Mass in kg of each soldier
|
||||||
-- @param #number Stock Number of groups in stock. Nil for unlimited.
|
-- @param #number Stock Number of groups in stock. Nil for unlimited.
|
||||||
function CTLD:AddTroopsCargo(Name,Templates,Type,NoTroops,PerTroopMass,Stock)
|
-- @param #string SubCategory Name of sub-category (optional).
|
||||||
|
function CTLD:AddTroopsCargo(Name,Templates,Type,NoTroops,PerTroopMass,Stock,SubCategory)
|
||||||
self:T(self.lid .. " AddTroopsCargo")
|
self:T(self.lid .. " AddTroopsCargo")
|
||||||
self:T({Name,Templates,Type,NoTroops,PerTroopMass,Stock})
|
self:T({Name,Templates,Type,NoTroops,PerTroopMass,Stock})
|
||||||
if not self:_CheckTemplates(Templates) then
|
if not self:_CheckTemplates(Templates) then
|
||||||
@ -3612,7 +3633,7 @@ function CTLD:AddTroopsCargo(Name,Templates,Type,NoTroops,PerTroopMass,Stock)
|
|||||||
end
|
end
|
||||||
self.CargoCounter = self.CargoCounter + 1
|
self.CargoCounter = self.CargoCounter + 1
|
||||||
-- Troops are directly loadable
|
-- Troops are directly loadable
|
||||||
local cargo = CTLD_CARGO:New(self.CargoCounter,Name,Templates,Type,false,true,NoTroops,nil,nil,PerTroopMass,Stock)
|
local cargo = CTLD_CARGO:New(self.CargoCounter,Name,Templates,Type,false,true,NoTroops,nil,nil,PerTroopMass,Stock, SubCategory)
|
||||||
table.insert(self.Cargo_Troops,cargo)
|
table.insert(self.Cargo_Troops,cargo)
|
||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user