Merge pull request #4053 from myk002/myk_sort_elevate_barony
search and sort for elevate to barony pagedevelop
commit
cc7bd058ce
@ -0,0 +1,165 @@
|
|||||||
|
local _ENV = mkmodule('plugins.sort.diplomacy')
|
||||||
|
|
||||||
|
local overlay = require('plugins.overlay')
|
||||||
|
local sortoverlay = require('plugins.sort.sortoverlay')
|
||||||
|
local widgets = require('gui.widgets')
|
||||||
|
|
||||||
|
local diplomacy = df.global.game.main_interface.diplomacy
|
||||||
|
|
||||||
|
-- ----------------------
|
||||||
|
-- DiplomacyOverlay
|
||||||
|
--
|
||||||
|
|
||||||
|
DiplomacyOverlay = defclass(DiplomacyOverlay, sortoverlay.SortOverlay)
|
||||||
|
DiplomacyOverlay.ATTRS{
|
||||||
|
default_pos={x=25, y=7},
|
||||||
|
viewscreens='dwarfmode/Diplomacy',
|
||||||
|
frame={w=57, h=1},
|
||||||
|
}
|
||||||
|
|
||||||
|
function DiplomacyOverlay:init()
|
||||||
|
self:addviews{
|
||||||
|
widgets.BannerPanel{
|
||||||
|
view_id='panel',
|
||||||
|
frame={l=0, t=0, r=0, h=1},
|
||||||
|
visible=self:callback('get_key'),
|
||||||
|
subviews={
|
||||||
|
widgets.EditField{
|
||||||
|
view_id='search',
|
||||||
|
frame={l=1, t=0, r=1},
|
||||||
|
label_text="Search: ",
|
||||||
|
key='CUSTOM_ALT_S',
|
||||||
|
text='',
|
||||||
|
on_change=function(text) self:do_search(text) end,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
self:register_handler('ELEVATE', diplomacy.land_holder_avail_hfid,
|
||||||
|
curry(sortoverlay.single_vector_search,
|
||||||
|
{
|
||||||
|
get_search_key_fn=self:callback('get_search_key'),
|
||||||
|
get_sort_fn=self:callback('get_sort'),
|
||||||
|
}))
|
||||||
|
end
|
||||||
|
|
||||||
|
function DiplomacyOverlay:get_key()
|
||||||
|
if diplomacy.selecting_land_holder_position then
|
||||||
|
return 'ELEVATE'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function to_item_type_str(item_type)
|
||||||
|
return string.lower(df.item_type[item_type]):gsub('_', ' ')
|
||||||
|
end
|
||||||
|
|
||||||
|
local function make_item_description(item_type, subtype)
|
||||||
|
local itemdef = dfhack.items.getSubtypeDef(item_type, subtype)
|
||||||
|
return itemdef and string.lower(itemdef.name) or to_item_type_str(item_type)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_preferences(unit)
|
||||||
|
if not unit then return {} end
|
||||||
|
local preferences = {}
|
||||||
|
for _, pref in ipairs(unit.status.current_soul.preferences) do
|
||||||
|
if pref.type == df.unit_preference.T_type.LikeItem and pref.active then
|
||||||
|
table.insert(preferences, make_item_description(pref.item_type, pref.item_subtype))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return preferences
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_unit(hfid)
|
||||||
|
local hf = df.historical_figure.find(hfid)
|
||||||
|
if not hf then return end
|
||||||
|
return df.unit.find(hf.unit_id)
|
||||||
|
end
|
||||||
|
|
||||||
|
function DiplomacyOverlay:get_search_key(hfid)
|
||||||
|
local unit = get_unit(hfid)
|
||||||
|
if not unit then return end
|
||||||
|
return ('%s %s'):format(sortoverlay.get_unit_search_key(unit),
|
||||||
|
table.concat(get_preferences(unit), ' '))
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
function DiplomacyOverlay:get_sort()
|
||||||
|
local _, sh = dfhack.screen.getWindowSize()
|
||||||
|
local list_height = sh - 17
|
||||||
|
local num_elems = list_height // 3
|
||||||
|
diplomacy.scroll_position_land_holder_hf = math.max(0,
|
||||||
|
math.min(diplomacy.scroll_position_land_holder_hf,
|
||||||
|
#diplomacy.land_holder_avail_hfid - num_elems))
|
||||||
|
return function(a, b)
|
||||||
|
local unita = get_unit(a)
|
||||||
|
local unitb = get_unit(b)
|
||||||
|
return #get_preferences(unita) < #get_preferences(unitb)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function DiplomacyOverlay:onRenderFrame(dc, rect)
|
||||||
|
local sw = dfhack.screen.getWindowSize()
|
||||||
|
local margin = (sw - 114) // 3
|
||||||
|
self.frame.w = 57 + margin
|
||||||
|
self.subviews.panel.frame.l = margin
|
||||||
|
|
||||||
|
DiplomacyOverlay.super.onRenderFrame(self, dc, rect)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- ----------------------
|
||||||
|
-- PreferenceOverlay
|
||||||
|
--
|
||||||
|
|
||||||
|
PreferenceOverlay = defclass(PreferenceOverlay, overlay.OverlayWidget)
|
||||||
|
PreferenceOverlay.ATTRS{
|
||||||
|
default_pos={x=-34, y=9},
|
||||||
|
viewscreens='dwarfmode/Diplomacy/ElevateLandHolder',
|
||||||
|
default_enabled=true,
|
||||||
|
frame={w=29, h=1},
|
||||||
|
}
|
||||||
|
|
||||||
|
function PreferenceOverlay:init()
|
||||||
|
self:addviews{
|
||||||
|
widgets.Label{
|
||||||
|
view_id='annotations',
|
||||||
|
frame={t=0, l=0},
|
||||||
|
text='',
|
||||||
|
text_pen=COLOR_GRAY,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
function PreferenceOverlay:onRenderFrame(dc, rect)
|
||||||
|
local sw, sh = dfhack.screen.getWindowSize()
|
||||||
|
local margin = (sw - 114) // 3
|
||||||
|
local list_height = sh - 17
|
||||||
|
local num_elems = list_height // 3
|
||||||
|
local max_elem = math.min(#diplomacy.land_holder_avail_hfid-1,
|
||||||
|
diplomacy.scroll_position_land_holder_hf+num_elems-1)
|
||||||
|
self.frame.w = sw - 85
|
||||||
|
self.frame.h = list_height
|
||||||
|
|
||||||
|
local annotations = {}
|
||||||
|
for idx=diplomacy.scroll_position_land_holder_hf,max_elem do
|
||||||
|
table.insert(annotations, NEWLINE)
|
||||||
|
table.insert(annotations, NEWLINE)
|
||||||
|
local prefs = get_preferences(get_unit(diplomacy.land_holder_avail_hfid[idx]))
|
||||||
|
table.insert(annotations, {text='[', pen=COLOR_RED})
|
||||||
|
if #prefs == 0 then
|
||||||
|
table.insert(annotations, 'no item preferences')
|
||||||
|
else
|
||||||
|
local pref_str = ('%d preference%s: %s'):format(#prefs,
|
||||||
|
#prefs > 1 and 's' or '', table.concat(prefs, ', '))
|
||||||
|
table.insert(annotations, pref_str:sub(1, self.frame.w-(margin+2)))
|
||||||
|
end
|
||||||
|
table.insert(annotations, {text=']', pen=COLOR_RED})
|
||||||
|
table.insert(annotations, NEWLINE)
|
||||||
|
end
|
||||||
|
self.subviews.annotations.frame.l = margin
|
||||||
|
self.subviews.annotations:setText(annotations)
|
||||||
|
|
||||||
|
PreferenceOverlay.super.onRenderFrame(self, dc, rect)
|
||||||
|
end
|
||||||
|
|
||||||
|
return _ENV
|
Loading…
Reference in New Issue