Fix: Nav buttons didn't work after doc.show_entry

This commit is contained in:
Wuzzy 2016-08-31 14:12:57 +02:00
parent 7b4883ddec
commit eb1d45e915

View File

@ -142,11 +142,16 @@ function doc.show_entry(playername, category_id, entry_id, ignore_hidden)
return return
end end
if ignore_hidden or doc.entry_revealed(playername, category_id, entry_id) then if ignore_hidden or doc.entry_revealed(playername, category_id, entry_id) then
-- FIXME: catsel must be set! local playerdata = doc.data.players[playername]
doc.data.players[playername].catsel = nil playerdata.category = category_id
doc.data.players[playername].category = category_id playerdata.entry = entry_id
doc.data.players[playername].entry = entry_id
doc.mark_entry_as_viewed(playername, category_id, entry_id) doc.mark_entry_as_viewed(playername, category_id, entry_id)
playerdata.entry_textlist_needs_updating = true
doc.generate_entry_list(category_id, playername)
playerdata.catsel = playerdata.catsel_list[entry_id]
local formspec = doc.formspec_core(3)..doc.formspec_entry(category_id, entry_id) local formspec = doc.formspec_core(3)..doc.formspec_entry(category_id, entry_id)
minetest.show_formspec(playername, "doc:entry", formspec) minetest.show_formspec(playername, "doc:entry", formspec)
else else
@ -345,16 +350,20 @@ end
function doc.generate_entry_list(cid, playername) function doc.generate_entry_list(cid, playername)
local formstring local formstring
if doc.data.players[playername].entry_textlist == nil if doc.data.players[playername].entry_textlist == nil
or doc.data.players[playername].catsel_list == nil
or doc.data.players[playername].category ~= cid or doc.data.players[playername].category ~= cid
or doc.data.players[playername].entry_textlist_needs_updating == true then or doc.data.players[playername].entry_textlist_needs_updating == true then
local entry_textlist = "textlist[0,1;11,7;doc_catlist;" local entry_textlist = "textlist[0,1;11,7;doc_catlist;"
local counter = 0 local counter = 0
doc.data.players[playername].entry_ids = {} doc.data.players[playername].entry_ids = {}
local entries = doc.get_sorted_entry_names(cid) local entries = doc.get_sorted_entry_names(cid)
doc.data.players[playername].catsel_list = {}
for i=1, #entries do for i=1, #entries do
local eid = entries[i].eid local eid = entries[i]
local edata = doc.data.categories[cid].entries[eid]
if doc.entry_revealed(playername, cid, eid) then if doc.entry_revealed(playername, cid, eid) then
table.insert(doc.data.players[playername].entry_ids, eid) table.insert(doc.data.players[playername].entry_ids, eid)
doc.data.players[playername].catsel_list[eid] = counter + 1
-- Colorize entries based on viewed status -- Colorize entries based on viewed status
-- Not viewed: Cyan -- Not viewed: Cyan
local viewedprefix = "#00FFFF" local viewedprefix = "#00FFFF"
@ -362,7 +371,7 @@ function doc.generate_entry_list(cid, playername)
-- Viewed: White -- Viewed: White
viewedprefix = "#FFFFFF" viewedprefix = "#FFFFFF"
end end
entry_textlist = entry_textlist .. viewedprefix .. minetest.formspec_escape(entries[i].name) .. "," entry_textlist = entry_textlist .. viewedprefix .. minetest.formspec_escape(edata.name) .. ","
counter = counter + 1 counter = counter + 1
end end
end end
@ -376,7 +385,7 @@ function doc.generate_entry_list(cid, playername)
entry_textlist = entry_textlist .. "]" entry_textlist = entry_textlist .. "]"
doc.data.players[playername].entry_textlist = entry_textlist doc.data.players[playername].entry_textlist = entry_textlist
formstring = entry_textlist formstring = entry_textlist
doc.data.players[playername].entry_testlist_needs_updating = false doc.data.players[playername].entry_textlist_needs_updating = false
else else
formstring = doc.data.players[playername].entry_textlist formstring = doc.data.players[playername].entry_textlist
end end
@ -388,6 +397,15 @@ function doc.get_sorted_entry_names(cid)
local entry_table = {} local entry_table = {}
local cat = doc.data.categories[cid] local cat = doc.data.categories[cid]
local used_eids = {} local used_eids = {}
-- Helper function to extract the entry ID out of the output table
local extract = function(entry_table)
local eids = {}
for k,v in pairs(entry_table) do
local eid = v.eid
table.insert(eids, eid)
end
return eids
end
-- Predefined sorting -- Predefined sorting
if cat.def.sorting == "custom" then if cat.def.sorting == "custom" then
for i=1,#cat.def.sorting_data do for i=1,#cat.def.sorting_data do
@ -406,7 +424,7 @@ function doc.get_sorted_entry_names(cid)
table.insert(sort_table, entry.name) table.insert(sort_table, entry.name)
end end
if cat.def.sorting == "custom" then if cat.def.sorting == "custom" then
return entry_table return extract(entry_table)
else else
table.sort(sort_table) table.sort(sort_table)
end end
@ -428,7 +446,7 @@ function doc.get_sorted_entry_names(cid)
table.sort(entry_table, comp) table.sort(entry_table, comp)
end end
return entry_table return extract(entry_table)
end end
function doc.formspec_category(id, playername) function doc.formspec_category(id, playername)