mirror of
https://github.com/minetest-mods/i3.git
synced 2025-01-11 18:50:29 +01:00
API: Add field to toggle slots in custom tabs
This commit is contained in:
parent
7a4f352ce4
commit
b31e7a48ab
3
API.md
3
API.md
@ -26,6 +26,7 @@ Custom tabs can be added to the `i3` inventory as follow (example):
|
|||||||
i3.new_tab("stuff", {
|
i3.new_tab("stuff", {
|
||||||
description = "Stuff",
|
description = "Stuff",
|
||||||
image = "image.png", -- Optional, add an image next to the tab description
|
image = "image.png", -- Optional, add an image next to the tab description
|
||||||
|
slots = true -- Optional, whether the inventory slots are shown or not. Disabled by default.
|
||||||
|
|
||||||
--
|
--
|
||||||
-- The functions below are all optional
|
-- The functions below are all optional
|
||||||
@ -49,7 +50,7 @@ i3.new_tab("stuff", {
|
|||||||
-- Do things
|
-- Do things
|
||||||
end
|
end
|
||||||
|
|
||||||
i3.set_fs(player) -- Update the formspec
|
-- No need to update the formspec, it's automatic
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
```
|
```
|
||||||
|
2
init.lua
2
init.lua
@ -24,7 +24,7 @@ i3 = {
|
|||||||
data = core.deserialize(storage:get_string"data") or {},
|
data = core.deserialize(storage:get_string"data") or {},
|
||||||
|
|
||||||
settings = {
|
settings = {
|
||||||
debug_mode = false,
|
debug_mode = true,
|
||||||
max_favs = 6,
|
max_favs = 6,
|
||||||
max_waypoints = 30,
|
max_waypoints = 30,
|
||||||
min_fs_version = 6,
|
min_fs_version = 6,
|
||||||
|
@ -197,6 +197,7 @@ i3.new_tab("inventory", {
|
|||||||
description = S"Inventory",
|
description = S"Inventory",
|
||||||
formspec = get_inventory_fs,
|
formspec = get_inventory_fs,
|
||||||
fields = i3.files.fields(),
|
fields = i3.files.fields(),
|
||||||
|
slots = true,
|
||||||
})
|
})
|
||||||
|
|
||||||
function i3.remove_tab(name)
|
function i3.remove_tab(name)
|
||||||
|
@ -211,8 +211,6 @@ local function inv_fields(player, data, fields)
|
|||||||
elseif fields.hide_debug_grid then
|
elseif fields.hide_debug_grid then
|
||||||
data.hide_debug_grid = not data.hide_debug_grid
|
data.hide_debug_grid = not data.hide_debug_grid
|
||||||
end
|
end
|
||||||
|
|
||||||
return set_fs(player)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function select_item(player, data, fields)
|
local function select_item(player, data, fields)
|
||||||
@ -465,8 +463,14 @@ core.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
|
|
||||||
local tab = i3.tabs[data.tab]
|
local tab = i3.tabs[data.tab]
|
||||||
|
|
||||||
if tab and tab.fields then
|
if tab then
|
||||||
return true, tab.fields(player, data, fields)
|
if tab.slots and data.tab > 1 then
|
||||||
|
inv_fields(player, data, fields)
|
||||||
|
end
|
||||||
|
|
||||||
|
if tab.fields then
|
||||||
|
tab.fields(player, data, fields)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return true, set_fs(player)
|
return true, set_fs(player)
|
||||||
|
128
src/gui.lua
128
src/gui.lua
@ -127,32 +127,6 @@ local function get_stack_max(inv, data, is_recipe, rcp)
|
|||||||
return max_stacks
|
return max_stacks
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_inv_slots(data, fs)
|
|
||||||
local legacy_inventory = data.legacy_inventory
|
|
||||||
local hotbar_len = data.hotbar_len
|
|
||||||
local inv_x = legacy_inventory and 0.23 or 0.22
|
|
||||||
local inv_y = legacy_inventory and 6.7 or 6.9
|
|
||||||
local spacing = legacy_inventory and 0.25 or 0.1
|
|
||||||
local size = 1
|
|
||||||
|
|
||||||
fs"style_type[box;colors=#77777710,#77777710,#777,#777]"
|
|
||||||
|
|
||||||
for i = 0, hotbar_len - 1 do
|
|
||||||
box(i * size + inv_x + (i * spacing), inv_y, size, size, "")
|
|
||||||
end
|
|
||||||
|
|
||||||
fs("style_type[list;size=%f;spacing=%f]", size, spacing)
|
|
||||||
fs("list[current_player;main;%f,%f;%u,1;]", inv_x, inv_y, hotbar_len)
|
|
||||||
|
|
||||||
fs("style_type[list;size=%f;spacing=%f,%f]", size, spacing, legacy_inventory and 0.15 or spacing)
|
|
||||||
|
|
||||||
fs("list[current_player;main;%f,%f;%u,%u;%u]", inv_x, inv_y + (legacy_inventory and 1.25 or 1.15),
|
|
||||||
hotbar_len, data.inv_size / hotbar_len, hotbar_len)
|
|
||||||
|
|
||||||
fs"style_type[list;size=1;spacing=0.15]"
|
|
||||||
fs"listring[current_player;craft]listring[current_player;main]"
|
|
||||||
end
|
|
||||||
|
|
||||||
local function add_subtitle(fs, name, y, ctn_len, font_size, sep, label)
|
local function add_subtitle(fs, name, y, ctn_len, font_size, sep, label)
|
||||||
fs("style[%s;font=bold;font_size=%u]", name, font_size)
|
fs("style[%s;font=bold;font_size=%u]", name, font_size)
|
||||||
button(0, y, ctn_len, 0.5, name, ESC(label))
|
button(0, y, ctn_len, 0.5, name, ESC(label))
|
||||||
@ -688,11 +662,53 @@ local function show_settings(fs, data)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function get_footer(fs, data)
|
||||||
|
local btn = {
|
||||||
|
{"trash", ES"Clear inventory"},
|
||||||
|
{"sort", ES"Sort inventory"},
|
||||||
|
{"settings", ES"Settings"},
|
||||||
|
{"home", ES"Go home"},
|
||||||
|
}
|
||||||
|
|
||||||
|
for i, v in ipairs(btn) do
|
||||||
|
local btn_name, tooltip = unpack(v)
|
||||||
|
fs("style[%s;fgimg=%s;fgimg_hovered=%s;content_offset=0]",
|
||||||
|
btn_name, PNG[btn_name], PNG[fmt("%s_hover", btn_name)])
|
||||||
|
image_button(i + 3.43 - (i * 0.4), 11.43, 0.35, 0.35, "", btn_name, "")
|
||||||
|
fs("tooltip[%s;%s]", btn_name, tooltip)
|
||||||
|
end
|
||||||
|
|
||||||
|
show_settings(fs, data)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function get_slots(fs, data)
|
||||||
|
local legacy_inventory = data.legacy_inventory
|
||||||
|
local hotbar_len = data.hotbar_len
|
||||||
|
local inv_x = legacy_inventory and 0.23 or 0.22
|
||||||
|
local inv_y = legacy_inventory and 6.7 or 6.9
|
||||||
|
local spacing = legacy_inventory and 0.25 or 0.1
|
||||||
|
local size = 1
|
||||||
|
|
||||||
|
fs"style_type[box;colors=#77777710,#77777710,#777,#777]"
|
||||||
|
|
||||||
|
for i = 0, hotbar_len - 1 do
|
||||||
|
box(i * size + inv_x + (i * spacing), inv_y, size, size, "")
|
||||||
|
end
|
||||||
|
|
||||||
|
fs("style_type[list;size=%f;spacing=%f]", size, spacing)
|
||||||
|
fs("list[current_player;main;%f,%f;%u,1;]", inv_x, inv_y, hotbar_len)
|
||||||
|
|
||||||
|
fs("style_type[list;size=%f;spacing=%f,%f]", size, spacing, legacy_inventory and 0.15 or spacing)
|
||||||
|
|
||||||
|
fs("list[current_player;main;%f,%f;%u,%u;%u]", inv_x, inv_y + (legacy_inventory and 1.25 or 1.15),
|
||||||
|
hotbar_len, data.inv_size / hotbar_len, hotbar_len)
|
||||||
|
|
||||||
|
fs"listring[current_player;craft]listring[current_player;main]"
|
||||||
|
|
||||||
|
get_footer(fs, data)
|
||||||
|
end
|
||||||
|
|
||||||
local function get_inventory_fs(player, data, fs)
|
local function get_inventory_fs(player, data, fs)
|
||||||
fs"listcolors[#bababa50;#bababa99]"
|
|
||||||
|
|
||||||
get_inv_slots(data, fs)
|
|
||||||
|
|
||||||
local props = player:get_properties()
|
local props = player:get_properties()
|
||||||
local ctn_len = 5.7
|
local ctn_len = 5.7
|
||||||
local ctn_hgt = data.legacy_inventory and 6.1 or 6.3
|
local ctn_hgt = data.legacy_inventory and 6.1 or 6.3
|
||||||
@ -772,23 +788,6 @@ local function get_inventory_fs(player, data, fs)
|
|||||||
fs("scroll_container[3.9,0.2;%f,%f;scrbar_inv;vertical]", ctn_len, ctn_hgt)
|
fs("scroll_container[3.9,0.2;%f,%f;scrbar_inv;vertical]", ctn_len, ctn_hgt)
|
||||||
get_container(fs, data, player, yoffset, ctn_len, award_list, awards_unlocked, award_list_nb, bag_size)
|
get_container(fs, data, player, yoffset, ctn_len, award_list, awards_unlocked, award_list_nb, bag_size)
|
||||||
fs"scroll_container_end[]"
|
fs"scroll_container_end[]"
|
||||||
|
|
||||||
local btn = {
|
|
||||||
{"trash", ES"Clear inventory"},
|
|
||||||
{"sort", ES"Sort inventory"},
|
|
||||||
{"settings", ES"Settings"},
|
|
||||||
{"home", ES"Go home"},
|
|
||||||
}
|
|
||||||
|
|
||||||
for i, v in ipairs(btn) do
|
|
||||||
local btn_name, tooltip = unpack(v)
|
|
||||||
fs("style[%s;fgimg=%s;fgimg_hovered=%s;content_offset=0]",
|
|
||||||
btn_name, PNG[btn_name], PNG[fmt("%s_hover", btn_name)])
|
|
||||||
image_button(i + 3.43 - (i * 0.4), 11.43, 0.35, 0.35, "", btn_name, "")
|
|
||||||
fs("tooltip[%s;%s]", btn_name, tooltip)
|
|
||||||
end
|
|
||||||
|
|
||||||
show_settings(fs, data)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_tooltip(item, info, lang_code)
|
local function get_tooltip(item, info, lang_code)
|
||||||
@ -1313,6 +1312,7 @@ local function get_crafting_fs(fs, data, is_recipe, is_usage, max_stacks_rcp, ma
|
|||||||
button(x + 0.2, data.yoffset + 1.85, 2.5, 0.7, fmt("craft_%s", name), ES("Craft (×@1)", stack_fs))
|
button(x + 0.2, data.yoffset + 1.85, 2.5, 0.7, fmt("craft_%s", name), ES("Craft (×@1)", stack_fs))
|
||||||
|
|
||||||
fs"style_type[label;font_size=16;textcolor=#fff]"
|
fs"style_type[label;font_size=16;textcolor=#fff]"
|
||||||
|
fs"style_type[image,button,image_button;noclip=false]"
|
||||||
end
|
end
|
||||||
|
|
||||||
local function get_rcp_extra(fs, data, player, panel, is_recipe, is_usage)
|
local function get_rcp_extra(fs, data, player, panel, is_recipe, is_usage)
|
||||||
@ -1497,17 +1497,16 @@ local function get_minitabs(fs, data, player, full_height)
|
|||||||
local selected = id == data.itab
|
local selected = id == data.itab
|
||||||
local hover_texture = selected and PNG.tab_small_hover or PNG.tab_small
|
local hover_texture = selected and PNG.tab_small_hover or PNG.tab_small
|
||||||
local flip = top and "^[transformFY" or ""
|
local flip = top and "^[transformFY" or ""
|
||||||
|
local tabname = fmt("itab_%u", id)
|
||||||
|
|
||||||
fs([[ style_type[image_button;bgimg=%s%s;bgimg_hovered=%s%s;
|
fs([[ style[%s;bgimg=%s%s;bgimg_hovered=%s%s;noclip=true;font=bold;font_size=16;
|
||||||
bgimg_middle=14,0,-14,-14;padding=-14,0,14,14] ]],
|
textcolor=%s;content_offset=0;sound=i3_tab;bgimg_middle=14,0,-14,-14;padding=-14,0,14,14] ]],
|
||||||
hover_texture, flip, PNG.tab_small_hover, flip)
|
tabname, hover_texture, flip, PNG.tab_small_hover, flip, selected and "#fff" or "#bbb")
|
||||||
|
|
||||||
fs([[ style_type[image_button;noclip=true;font=bold;font_size=16;
|
fs("style[%s:hovered;textcolor=#fff]", tabname)
|
||||||
textcolor=%s;content_offset=0;sound=i3_tab] ]], selected and "#fff" or "#bbb")
|
|
||||||
fs"style_type[image_button:hovered;textcolor=#fff]"
|
|
||||||
|
|
||||||
image_button((data.inv_width - 0.65) + (X * (tab_len + 0.1)),
|
image_button((data.inv_width - 0.65) + (X * (tab_len + 0.1)),
|
||||||
top and -tab_hgh or full_height, tab_len, tab_hgh, "", fmt("itab_%u", id), title)
|
top and -tab_hgh or full_height, tab_len, tab_hgh, "", tabname, title)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -1656,17 +1655,17 @@ local function get_tabs_fs(fs, player, data, full_height)
|
|||||||
local middle = btm and "16,0,-16,-16" or "16,16,-16,-16"
|
local middle = btm and "16,0,-16,-16" or "16,16,-16,-16"
|
||||||
local padding = btm and "-16,0,16,16" or "-16,-16,16,16"
|
local padding = btm and "-16,0,16,16" or "-16,-16,16,16"
|
||||||
|
|
||||||
fs([[ style_type[image_button;bgimg=%s;bgimg_hovered=%s;bgimg_middle=%s;padding=%s] ]],
|
local tabname = fmt("tab_%s", def.name)
|
||||||
bgimg, bgimg_hover, middle, padding)
|
|
||||||
|
|
||||||
fs("style_type[image_button;noclip=true;font_size=16;textcolor=%s;content_offset=0;sound=i3_tab]",
|
fs([[ style[%s;bgimg=%s;bgimg_hovered=%s;bgimg_middle=%s;padding=%s;noclip=true;
|
||||||
selected and "#fff" or "#ddd")
|
font=bold;font_size=16;textcolor=%s;content_offset=0;sound=i3_tab] ]],
|
||||||
|
tabname, bgimg, bgimg_hover, middle, padding, selected and "#fff" or "#bbb")
|
||||||
|
|
||||||
local X = (data.inv_width / 2) + (c * (tab_len + 0.1)) - ((tab_len + 0.05) * (shift / 2))
|
local X = (data.inv_width / 2) + (c * (tab_len + 0.1)) - ((tab_len + 0.05) * (shift / 2))
|
||||||
local Y = btm and full_height or -tab_hgh
|
local Y = btm and full_height or -tab_hgh
|
||||||
|
|
||||||
fs"style_type[image_button:hovered;textcolor=#fff]"
|
fs("style[%s:hovered;textcolor=#fff]", tabname)
|
||||||
image_button(X, Y, tab_len, tab_hgh, "", fmt("tab_%s", def.name), ESC(def.description))
|
image_button(X, Y, tab_len, tab_hgh, "", tabname, ESC(def.description))
|
||||||
|
|
||||||
if true_str(def.image) then
|
if true_str(def.image) then
|
||||||
local desc = translate(data.lang_code, def.description)
|
local desc = translate(data.lang_code, def.description)
|
||||||
@ -1674,6 +1673,7 @@ local function get_tabs_fs(fs, player, data, full_height)
|
|||||||
|
|
||||||
fs"style_type[image;noclip=true]"
|
fs"style_type[image;noclip=true]"
|
||||||
image(X + (tab_len / 2) - ((desc_len * 0.1) / 2) - 0.55, Y + 0.05, 0.35, 0.35, def.image)
|
image(X + (tab_len / 2) - ((desc_len * 0.1) / 2) - 0.55, Y + 0.05, 0.35, 0.35, def.image)
|
||||||
|
fs"style_type[image;noclip=false]"
|
||||||
end
|
end
|
||||||
|
|
||||||
c++
|
c++
|
||||||
@ -1736,10 +1736,16 @@ local function make_fs(player, data)
|
|||||||
|
|
||||||
local tab = i3.tabs[data.tab]
|
local tab = i3.tabs[data.tab]
|
||||||
|
|
||||||
if tab and tab.formspec then
|
if tab then
|
||||||
|
if tab.formspec then
|
||||||
tab.formspec(player, data, fs)
|
tab.formspec(player, data, fs)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if tab.slots then
|
||||||
|
get_slots(fs, data)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if data.query_item then
|
if data.query_item then
|
||||||
get_panels(fs, data, player)
|
get_panels(fs, data, player)
|
||||||
else
|
else
|
||||||
|
@ -83,6 +83,9 @@ local PNG = {
|
|||||||
}
|
}
|
||||||
|
|
||||||
local styles = string.format([[
|
local styles = string.format([[
|
||||||
|
listcolors[#bababa50;#bababa99]
|
||||||
|
|
||||||
|
style_type[list;size=1;spacing=0.15]
|
||||||
style_type[field;border=false;bgcolor=transparent]
|
style_type[field;border=false;bgcolor=transparent]
|
||||||
style_type[label,field;font_size=16]
|
style_type[label,field;font_size=16]
|
||||||
style_type[button;border=false;content_offset=0]
|
style_type[button;border=false;content_offset=0]
|
||||||
|
@ -1,16 +1,32 @@
|
|||||||
|
local SWITCH
|
||||||
|
|
||||||
i3.new_tab("test1", {
|
i3.new_tab("test1", {
|
||||||
description = "Test 1 Test 1",
|
description = "Test 1 Test 1",
|
||||||
image = "i3_heart.png",
|
image = "i3_heart.png",
|
||||||
|
|
||||||
formspec = function(player, data, fs)
|
formspec = function(player, data, fs)
|
||||||
|
fs("button", 3, 4, 3, 0.8, "test", "Click here")
|
||||||
fs("label", 3, 1, "Just a test")
|
fs("label", 3, 1, "Just a test")
|
||||||
|
|
||||||
|
|
||||||
|
if SWITCH then
|
||||||
|
fs"label[3,2;Button clicked]"
|
||||||
|
else
|
||||||
fs"label[3,2;Lorem Ipsum]"
|
fs"label[3,2;Lorem Ipsum]"
|
||||||
|
end
|
||||||
end,
|
end,
|
||||||
|
|
||||||
|
fields = function(player, data, fields)
|
||||||
|
if fields.test then
|
||||||
|
SWITCH = true
|
||||||
|
end
|
||||||
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
i3.new_tab("test2", {
|
i3.new_tab("test2", {
|
||||||
description = "Test 2",
|
description = "Test 2",
|
||||||
image = "i3_mesepick.png",
|
image = "i3_mesepick.png",
|
||||||
|
slots = true,
|
||||||
|
|
||||||
formspec = function(player, data, fs)
|
formspec = function(player, data, fs)
|
||||||
fs("label[3,1;Test 2]")
|
fs("label[3,1;Test 2]")
|
||||||
|
Loading…
Reference in New Issue
Block a user