mirror of
https://github.com/minetest-mods/skinsdb.git
synced 2025-04-15 08:20:22 +02:00
unify the both inventories implementation unified_inventory supports now private skins too
This commit is contained in:
parent
751f0f9538
commit
ebdcede90e
@ -1,5 +1,23 @@
|
|||||||
local S = skins.S
|
local S = skins.S
|
||||||
|
|
||||||
|
|
||||||
|
-- Prepare server-site state / context
|
||||||
|
function skins.rebuild_formspec_context(player, context)
|
||||||
|
local skin = skins.get_player_skin(player)
|
||||||
|
context.skins_list = skins.get_skinlist_for_player(player:get_player_name())
|
||||||
|
context.total_pages = 1
|
||||||
|
for i, skin in ipairs(context.skins_list ) do
|
||||||
|
local page = math.floor((i-1) / 16)+1
|
||||||
|
skin:set_meta("inv_page", page)
|
||||||
|
skin:set_meta("inv_page_index", (i-1)%16+1)
|
||||||
|
context.total_pages = page
|
||||||
|
end
|
||||||
|
context.skins_page = context.skins_page or skin:get_meta("inv_page")
|
||||||
|
context.dropdown_values = nil
|
||||||
|
return context
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
-- Show skin info
|
-- Show skin info
|
||||||
function skins.get_skin_info_formspec(skin)
|
function skins.get_skin_info_formspec(skin)
|
||||||
local texture = skin:get_texture()
|
local texture = skin:get_texture()
|
||||||
@ -23,3 +41,70 @@ function skins.get_skin_info_formspec(skin)
|
|||||||
end
|
end
|
||||||
return formspec
|
return formspec
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function skins.get_skin_selection_formspec(context, y_delta)
|
||||||
|
local page = context.skins_page or 1
|
||||||
|
local formspec = ""
|
||||||
|
for i = (page-1)*16+1, page*16 do
|
||||||
|
local skin = context.skins_list[i]
|
||||||
|
if not skin then
|
||||||
|
break
|
||||||
|
end
|
||||||
|
|
||||||
|
local index_p = skin:get_meta("inv_page_index")
|
||||||
|
local x = (index_p-1) % 8
|
||||||
|
local y
|
||||||
|
if index_p > 8 then
|
||||||
|
y = y_delta + 1.9
|
||||||
|
else
|
||||||
|
y = y_delta
|
||||||
|
end
|
||||||
|
formspec = formspec.."image_button["..x..","..y..";1,2;"..
|
||||||
|
skin:get_preview()..";skins_set$"..i..";]"..
|
||||||
|
"tooltip[skins_set$"..i..";"..minetest.formspec_escape(skin:get_meta_string("name")).."]"
|
||||||
|
end
|
||||||
|
|
||||||
|
if context.total_pages > 1 then
|
||||||
|
local page_prev = page - 1
|
||||||
|
local page_next = page + 1
|
||||||
|
if page_prev < 1 then
|
||||||
|
page_prev = context.total_pages
|
||||||
|
end
|
||||||
|
if page_next > context.total_pages then
|
||||||
|
page_next = 1
|
||||||
|
end
|
||||||
|
local page_list = ""
|
||||||
|
context.dropdown_values = {}
|
||||||
|
for pg=1, context.total_pages do
|
||||||
|
local pagename = S("Page").." "..pg.."/"..context.total_pages
|
||||||
|
context.dropdown_values[pagename] = pg
|
||||||
|
if pg > 1 then page_list = page_list.."," end
|
||||||
|
page_list = page_list..pagename
|
||||||
|
end
|
||||||
|
formspec = formspec
|
||||||
|
.."button[0,"..(y_delta+4.0)..";1,.5;skins_page$"..page_prev..";<<]"
|
||||||
|
.."dropdown[0.9,"..(y_delta+3.88)..";6.5,.5;skins_selpg;"..page_list..";"..page.."]"
|
||||||
|
.."button[7,"..(y_delta+4.0)..";1,.5;skins_page$"..page_next..";>>]"
|
||||||
|
end
|
||||||
|
return formspec
|
||||||
|
end
|
||||||
|
|
||||||
|
function skins.on_skin_selection_receive_fields(player, context, fields)
|
||||||
|
for field, _ in pairs(fields) do
|
||||||
|
local current = string.split(field, "$", 2)
|
||||||
|
if current[1] == "skins_set" then
|
||||||
|
local selected_skin = context.skins_list[tonumber(current[2])]
|
||||||
|
setmetatable(selected_skin, skins.skin_class)
|
||||||
|
|
||||||
|
skins.set_player_skin(player, selected_skin)
|
||||||
|
return 'set'
|
||||||
|
elseif current[1] == "skins_page" then
|
||||||
|
context.skins_page = tonumber(current[2])
|
||||||
|
return 'page'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if fields.skins_selpg then
|
||||||
|
context.skins_page = tonumber(context.dropdown_values[fields.skins_selpg])
|
||||||
|
return 'page'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
@ -2,58 +2,9 @@ local S = skins.S
|
|||||||
|
|
||||||
-- generate the current formspec
|
-- generate the current formspec
|
||||||
local function get_formspec(player, context)
|
local function get_formspec(player, context)
|
||||||
local name = player:get_player_name()
|
|
||||||
local skin = skins.get_player_skin(player)
|
local skin = skins.get_player_skin(player)
|
||||||
local formspec = skins.get_skin_info_formspec(skin)
|
local formspec = skins.get_skin_info_formspec(skin)
|
||||||
|
formspec = formspec..skins.get_skin_selection_formspec(context, 4)
|
||||||
local page = 1
|
|
||||||
if context.skins_page then
|
|
||||||
page = context.skins_page
|
|
||||||
else
|
|
||||||
page = skin:get_meta("inv_page") or 1
|
|
||||||
end
|
|
||||||
|
|
||||||
for i = (page-1)*16+1, page*16 do
|
|
||||||
local skin = context.skins_list[i]
|
|
||||||
if not skin then
|
|
||||||
break
|
|
||||||
end
|
|
||||||
|
|
||||||
local index_p = skin:get_meta("inv_page_index")
|
|
||||||
local x = (index_p-1) % 8
|
|
||||||
local y
|
|
||||||
if index_p > 8 then
|
|
||||||
y = 5.5
|
|
||||||
else
|
|
||||||
y = 3.2
|
|
||||||
end
|
|
||||||
formspec = formspec.."image_button["..x..","..y..";1,2;"..
|
|
||||||
skin:get_preview()..";skins_set$"..i..";]"..
|
|
||||||
"tooltip[skins_set$"..i..";"..minetest.formspec_escape(skin:get_meta_string("name")).."]"
|
|
||||||
end
|
|
||||||
|
|
||||||
if context.total_pages > 1 then
|
|
||||||
local page_prev = page - 1
|
|
||||||
local page_next = page + 1
|
|
||||||
if page_prev < 1 then
|
|
||||||
page_prev = context.total_pages
|
|
||||||
end
|
|
||||||
if page_next > context.total_pages then
|
|
||||||
page_next = 1
|
|
||||||
end
|
|
||||||
local page_list = ""
|
|
||||||
context.dropdown_values = {}
|
|
||||||
for pg=1, context.total_pages do
|
|
||||||
local pagename = S("Page").." "..pg.."/"..context.total_pages
|
|
||||||
context.dropdown_values[pagename] = pg
|
|
||||||
if pg > 1 then page_list = page_list.."," end
|
|
||||||
page_list = page_list..pagename
|
|
||||||
end
|
|
||||||
formspec = formspec
|
|
||||||
.."button[0,8.3;1,.5;skins_page$"..page_prev..";<<]"
|
|
||||||
.."dropdown[1,8.16;6.5,.5;skins_selpg;"..page_list..";"..page.."]"
|
|
||||||
.."button[7,8.3;1,.5;skins_page$"..page_next..";>>]"
|
|
||||||
end
|
|
||||||
return formspec
|
return formspec
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -61,34 +12,11 @@ sfinv.register_page("skins:overview", {
|
|||||||
title = "Skins",
|
title = "Skins",
|
||||||
get = function(self, player, context)
|
get = function(self, player, context)
|
||||||
-- collect skins data
|
-- collect skins data
|
||||||
context.skins_list = skins.get_skinlist_for_player(player:get_player_name())
|
context = skins.rebuild_formspec_context(player, context)
|
||||||
context.total_pages = 1
|
|
||||||
for i, skin in ipairs(context.skins_list ) do
|
|
||||||
local page = math.floor((i-1) / 16)+1
|
|
||||||
skin:set_meta("inv_page", page)
|
|
||||||
skin:set_meta("inv_page_index", (i-1)%16+1)
|
|
||||||
context.total_pages = page
|
|
||||||
end
|
|
||||||
-- generate first formspec
|
|
||||||
return sfinv.make_formspec(player, context, get_formspec(player, context))
|
return sfinv.make_formspec(player, context, get_formspec(player, context))
|
||||||
end,
|
end,
|
||||||
on_player_receive_fields = function(self, player, context, fields)
|
on_player_receive_fields = function(self, player, context, fields)
|
||||||
for field, _ in pairs(fields) do
|
skins.on_skin_selection_receive_fields(player, context, fields)
|
||||||
local current = string.split(field, "$", 2)
|
sfinv.set_player_inventory_formspec(player)
|
||||||
if current[1] == "skins_set" then
|
|
||||||
skins.set_player_skin(player, context.skins_list[tonumber(current[2])])
|
|
||||||
sfinv.set_player_inventory_formspec(player)
|
|
||||||
return
|
|
||||||
elseif current[1] == "skins_page" then
|
|
||||||
context.skins_page = tonumber(current[2])
|
|
||||||
sfinv.set_player_inventory_formspec(player)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if fields.skins_selpg then
|
|
||||||
context.skins_page = tonumber(context.dropdown_values[fields.skins_selpg])
|
|
||||||
sfinv.set_player_inventory_formspec(player)
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
@ -2,6 +2,7 @@ skins.meta = {}
|
|||||||
|
|
||||||
local skin_class = {}
|
local skin_class = {}
|
||||||
skin_class.__index = skin_class
|
skin_class.__index = skin_class
|
||||||
|
skins.skin_class = skin_class
|
||||||
-----------------------
|
-----------------------
|
||||||
-- Class methods
|
-- Class methods
|
||||||
-----------------------
|
-----------------------
|
||||||
|
@ -1,14 +1,10 @@
|
|||||||
local S = skins.S
|
local S = skins.S
|
||||||
|
|
||||||
local dropdown_values = {}
|
|
||||||
local skins_reftab = {}
|
|
||||||
local skins_list = skins.get_skinlist_for_player() --public only
|
|
||||||
unified_inventory.register_page("skins", {
|
unified_inventory.register_page("skins", {
|
||||||
get_formspec = function(player)
|
get_formspec = function(player)
|
||||||
local skin = skins.get_player_skin(player)
|
local skin = skins.get_player_skin(player)
|
||||||
local page = skin:get_meta("inv_page") or 1
|
|
||||||
local formspec = "background[0.06,0.99;7.92,7.52;ui_misc_form.png]"..skins.get_skin_info_formspec(skin)..
|
local formspec = "background[0.06,0.99;7.92,7.52;ui_misc_form.png]"..skins.get_skin_info_formspec(skin)..
|
||||||
"button[.75,3;6.5,.5;skins_page$"..page..";"..S("Change").."]"
|
"button[.75,3;6.5,.5;skins_page;"..S("Change").."]"
|
||||||
return {formspec=formspec}
|
return {formspec=formspec}
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
@ -18,85 +14,47 @@ unified_inventory.register_button("skins", {
|
|||||||
image = "skins_button.png",
|
image = "skins_button.png",
|
||||||
})
|
})
|
||||||
|
|
||||||
-- Create all of the skin-picker pages.
|
local function get_formspec(player)
|
||||||
local total_pages = 1
|
-- unified inventory is stateless, but skins pager needs some context usage to be more flexible
|
||||||
for i, skin in ipairs(skins_list) do
|
local context = minetest.deserialize(player:get_attribute('skinsdb_unified_inventory_context')) or {}
|
||||||
local page = math.floor((i-1) / 16)+1
|
context = skins.rebuild_formspec_context(player, context)
|
||||||
skin:set_meta("inv_page", page)
|
local formspec = "background[0.06,0.99;7.92,7.52;ui_misc_form.png]"..
|
||||||
skin:set_meta("inv_page_index", (i-1)%16+1)
|
skins.get_skin_selection_formspec(context, -0.2)
|
||||||
total_pages = page
|
player:set_attribute('skinsdb_unified_inventory_context', minetest.serialize(context))
|
||||||
|
return formspec
|
||||||
end
|
end
|
||||||
|
|
||||||
for page=1, total_pages do
|
unified_inventory.register_page("skins_page", {
|
||||||
local formspec = "background[0.06,0.99;7.92,7.52;ui_misc_form.png]"
|
get_formspec = function(player)
|
||||||
for i = (page-1)*16+1, page*16 do
|
return {formspec=get_formspec(player)}
|
||||||
local skin = skins_list[i]
|
|
||||||
if not skin then
|
|
||||||
break
|
|
||||||
end
|
|
||||||
|
|
||||||
local index_p = skin:get_meta("inv_page_index")
|
|
||||||
local x = (index_p-1) % 8
|
|
||||||
local y
|
|
||||||
if index_p > 8 then
|
|
||||||
y = 1.8
|
|
||||||
else
|
|
||||||
y = -0.1
|
|
||||||
end
|
|
||||||
formspec = (formspec.."image_button["..x..","..y..";1,2;"..
|
|
||||||
skin:get_preview()..";skins_set$"..i..";]"..
|
|
||||||
"tooltip[skins_set$"..i..";"..minetest.formspec_escape(skin:get_meta_string("name")).."]")
|
|
||||||
end
|
end
|
||||||
if total_pages > 1 then
|
})
|
||||||
local page_prev = page - 1
|
|
||||||
local page_next = page + 1
|
|
||||||
if page_prev < 1 then
|
|
||||||
page_prev = total_pages
|
|
||||||
end
|
|
||||||
if page_next > total_pages then
|
|
||||||
page_next = 1
|
|
||||||
end
|
|
||||||
local page_list = ""
|
|
||||||
dropdown_values = {}
|
|
||||||
for pg=1, total_pages do
|
|
||||||
local pagename = S("Page").." "..pg.."/"..total_pages
|
|
||||||
dropdown_values[pagename] = pg
|
|
||||||
if pg > 1 then page_list = page_list.."," end
|
|
||||||
page_list = page_list..pagename
|
|
||||||
end
|
|
||||||
formspec = (formspec
|
|
||||||
.."button[0,3.8;1,.5;skins_page$"..page_prev..";<<]"
|
|
||||||
.."dropdown[1,3.68;6.5,.5;skins_selpg;"..page_list..";"..page.."]"
|
|
||||||
.."button[7,3.8;1,.5;skins_page$"..page_next..";>>]")
|
|
||||||
end
|
|
||||||
unified_inventory.register_page("skins_page$"..(page), {
|
|
||||||
get_formspec = function(player)
|
|
||||||
return {formspec=formspec}
|
|
||||||
end
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
-- click button handlers
|
-- click button handlers
|
||||||
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
||||||
if fields.skins then
|
if fields.skins then
|
||||||
|
player:set_attribute('skinsdb_unified_inventory_context',"") --reset context
|
||||||
unified_inventory.set_inventory_formspec(player, "craft")
|
unified_inventory.set_inventory_formspec(player, "craft")
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local context -- read context only if skins related action
|
||||||
for field, _ in pairs(fields) do
|
for field, _ in pairs(fields) do
|
||||||
local current = string.split(field, "$", 2)
|
if field:sub(1,5) == "skins" then
|
||||||
if current[1] == "skins_set" then
|
context = minetest.deserialize(player:get_attribute('skinsdb_unified_inventory_context')) or {}
|
||||||
skins.set_player_skin(player, skins_list[tonumber(current[2])])
|
break
|
||||||
unified_inventory.set_inventory_formspec(player, "skins")
|
|
||||||
return
|
|
||||||
elseif current[1] == "skins_page" then
|
|
||||||
unified_inventory.set_inventory_formspec(player, "skins_page$"..current[2])
|
|
||||||
return
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if fields.skins_selpg then
|
if not context then
|
||||||
local page = dropdown_values[fields.skins_selpg]
|
|
||||||
unified_inventory.set_inventory_formspec(player, "skins_page$"..(page))
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local action = skins.on_skin_selection_receive_fields(player, context, fields)
|
||||||
|
if action == 'set' then
|
||||||
|
player:set_attribute('skinsdb_unified_inventory_context',"") --reset context
|
||||||
|
unified_inventory.set_inventory_formspec(player, "skins")
|
||||||
|
elseif action == 'page' then
|
||||||
|
player:set_attribute('skinsdb_unified_inventory_context', minetest.serialize(context))
|
||||||
|
unified_inventory.set_inventory_formspec(player, "skins_page")
|
||||||
|
end
|
||||||
end)
|
end)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user