mirror of
https://github.com/minetest-mods/craftguide.git
synced 2024-11-23 03:13:44 +01:00
Add bookmarks
This commit is contained in:
parent
a823a200b7
commit
58b2f49c8c
130
init.lua
130
init.lua
@ -79,7 +79,7 @@ local IPP = ROWS * LINES
|
|||||||
local WH_LIMIT = 8
|
local WH_LIMIT = 8
|
||||||
|
|
||||||
local XOFFSET = sfinv_only and 3.83 or 11.2
|
local XOFFSET = sfinv_only and 3.83 or 11.2
|
||||||
local YOFFSET = sfinv_only and 4.9 or 1
|
local YOFFSET = sfinv_only and 6 or 1
|
||||||
|
|
||||||
local PNG = {
|
local PNG = {
|
||||||
bg = "craftguide_bg.png",
|
bg = "craftguide_bg.png",
|
||||||
@ -639,6 +639,19 @@ local function repairable(tool)
|
|||||||
return toolrepair and def and def.groups and def.groups.disable_repair ~= 1
|
return toolrepair and def and def.groups and def.groups.disable_repair ~= 1
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function is_fav(data)
|
||||||
|
local fav, i
|
||||||
|
for j = 1, #data.favs do
|
||||||
|
if data.favs[j] == data.query_item then
|
||||||
|
fav = true
|
||||||
|
i = j
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return fav, i
|
||||||
|
end
|
||||||
|
|
||||||
local function get_desc(name)
|
local function get_desc(name)
|
||||||
local def = reg_items[name]
|
local def = reg_items[name]
|
||||||
|
|
||||||
@ -854,8 +867,7 @@ local function get_grid_fs(fs, rcp, spacing)
|
|||||||
|
|
||||||
if CORE_VERSION >= 510 and not large_recipe then
|
if CORE_VERSION >= 510 and not large_recipe then
|
||||||
fs[#fs + 1] = fmt(FMT.image,
|
fs[#fs + 1] = fmt(FMT.image,
|
||||||
X, Y + (sfinv_only and 0.7 or 0),
|
X, Y + (sfinv_only and 0.7 or 0), btn_size, btn_size, PNG.selected)
|
||||||
btn_size, btn_size, PNG.selected)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
fs[#fs + 1] = fmt(FMT.item_image_button,
|
fs[#fs + 1] = fmt(FMT.item_image_button,
|
||||||
@ -891,33 +903,52 @@ local function get_grid_fs(fs, rcp, spacing)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function get_panels(data, fs)
|
local function get_panels(data, fs)
|
||||||
local panels = {recipes = data.recipes or {}, usages = data.usages or {}}
|
local start_y = CORE_VERSION >= 520 and 0 or 0.33
|
||||||
local x = 0.33
|
local panels = {
|
||||||
|
{dat = data.usages or {}, height = 3.5},
|
||||||
|
{dat = data.recipes or {}, height = 3.5},
|
||||||
|
}
|
||||||
|
|
||||||
if sfinv_only then
|
if CORE_VERSION >= 520 and not sfinv_only then
|
||||||
panels = data.show_usages and {usages = data.usages} or {recipes = data.recipes}
|
panels.favs = {dat = {}, height = 2.19}
|
||||||
|
elseif sfinv_only then
|
||||||
|
panels = data.show_usages and
|
||||||
|
{{dat = data.usages}} or {{dat = data.recipes}}
|
||||||
end
|
end
|
||||||
|
|
||||||
for k, v in pairs(panels) do
|
for k, v in pairs(panels) do
|
||||||
x = x + 1
|
start_y = start_y + 1
|
||||||
local spacing = (x - 1) * 3.6
|
local spacing = (start_y - 1) * 3.6
|
||||||
|
|
||||||
if not sfinv_only then
|
if not sfinv_only then
|
||||||
fs[#fs + 1] = CORE_VERSION >= 510 and
|
fs[#fs + 1] = CORE_VERSION >= 510 and
|
||||||
fmt("background9[8.1,%f;6.6,3.5;%s;false;%d]",
|
fmt("background9[8.1,%f;6.6,%f;%s;false;%d]",
|
||||||
-0.2 + spacing, PNG.bg_full, 10) or
|
-0.2 + spacing, v.height, PNG.bg_full, 10) or
|
||||||
fmt("background[8.1,%f;6.6,3.5;%s;false]",
|
fmt("background[8.1,%f;6.6,%f;%s;false]",
|
||||||
-0.2 + spacing, PNG.bg_full)
|
-0.2 + spacing, v.height, PNG.bg_full)
|
||||||
|
|
||||||
|
if k ~= "favs" then
|
||||||
|
local fav = is_fav(data)
|
||||||
|
|
||||||
|
fs[#fs + 1] = fmt(
|
||||||
|
"style[fav;fgimg=%s;fgimg_hovered=%s;fgimg_pressed=%s]",
|
||||||
|
fmt("craftguide_fav%s.png", fav and "" or "_off"),
|
||||||
|
fmt("craftguide_fav%s.png", fav and "_off" or ""),
|
||||||
|
fmt("craftguide_fav%s.png", fav and "_off" or ""))
|
||||||
|
|
||||||
|
fs[#fs + 1] = fmt(FMT.image_button,
|
||||||
|
14, spacing, 0.5, 0.45, "", "fav", "")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local rn = #v
|
local rn = #v.dat
|
||||||
local _rn = tostring(rn)
|
local _rn = tostring(rn)
|
||||||
local xu = tostring(data.unum) .. _rn
|
local xu = tostring(data.unum) .. _rn
|
||||||
local xr = tostring(data.rnum) .. _rn
|
local xr = tostring(data.rnum) .. _rn
|
||||||
xu = max(-0.3, -((#xu - 3) * 0.15))
|
xu = max(-0.3, -((#xu - 3) * 0.05))
|
||||||
xr = max(-0.3, -((#xr - 3) * 0.15))
|
xr = max(-0.3, -((#xr - 3) * 0.05))
|
||||||
|
|
||||||
local is_recipe = k == "recipes"
|
local is_recipe = k == 2
|
||||||
local lbl
|
local lbl
|
||||||
|
|
||||||
if not sfinv_only and rn == 0 then
|
if not sfinv_only and rn == 0 then
|
||||||
@ -938,14 +969,14 @@ local function get_panels(data, fs)
|
|||||||
|
|
||||||
fs[#fs + 1] = fmt(FMT.label,
|
fs[#fs + 1] = fmt(FMT.label,
|
||||||
XOFFSET + (sfinv_only and 2.3 or 1.6) + (is_recipe and xr or xu),
|
XOFFSET + (sfinv_only and 2.3 or 1.6) + (is_recipe and xr or xu),
|
||||||
YOFFSET + (sfinv_only and 3.35 or 1.5 + spacing), lbl)
|
YOFFSET + (sfinv_only and 2.3 or 1.5 + spacing), lbl)
|
||||||
|
|
||||||
if rn > 1 then
|
if rn > 1 then
|
||||||
local btn_suffix = is_recipe and "recipe" or "usage"
|
local btn_suffix = is_recipe and "recipe" or "usage"
|
||||||
local prev_name = fmt("prev_%s", btn_suffix)
|
local prev_name = fmt("prev_%s", btn_suffix)
|
||||||
local next_name = fmt("next_%s", btn_suffix)
|
local next_name = fmt("next_%s", btn_suffix)
|
||||||
local x_arrow = XOFFSET + (sfinv_only and 1.7 or 1)
|
local x_arrow = XOFFSET + (sfinv_only and 1.7 or 1)
|
||||||
local y_arrow = YOFFSET + (sfinv_only and 3.25 or 1.4 + spacing)
|
local y_arrow = YOFFSET + (sfinv_only and 2.2 or 1.4 + spacing)
|
||||||
|
|
||||||
if CORE_VERSION >= 520 then
|
if CORE_VERSION >= 520 then
|
||||||
fs[#fs + 1] = fmt(mul_elem(FMT.arrow, 2),
|
fs[#fs + 1] = fmt(mul_elem(FMT.arrow, 2),
|
||||||
@ -960,10 +991,28 @@ local function get_panels(data, fs)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local rcp = is_recipe and v[data.rnum] or v[data.unum]
|
local rcp = is_recipe and v.dat[data.rnum] or v.dat[data.unum]
|
||||||
if rcp then
|
if rcp then
|
||||||
get_grid_fs(fs, rcp, spacing)
|
get_grid_fs(fs, rcp, spacing)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if k == "favs" and CORE_VERSION >= 520 and not sfinv_only then
|
||||||
|
fs[#fs + 1] = fmt(FMT.label, 8.3, spacing - 0.1, ES"Bookmarks")
|
||||||
|
|
||||||
|
for i = 1, #data.favs do
|
||||||
|
local item = data.favs[i]
|
||||||
|
|
||||||
|
if data.query_item == item then
|
||||||
|
fs[#fs + 1] = fmt(FMT.image,
|
||||||
|
7.85 + (i - 0.5), spacing + 0.45,
|
||||||
|
1.1, 1.1, PNG.selected)
|
||||||
|
end
|
||||||
|
|
||||||
|
fs[#fs + 1] = fmt(FMT.item_image_button,
|
||||||
|
7.85 + (i - 0.5), spacing + 0.45,
|
||||||
|
1.1, 1.1, item, item, "")
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -971,16 +1020,13 @@ local function make_formspec(name)
|
|||||||
local data = pdata[name]
|
local data = pdata[name]
|
||||||
local fs = {}
|
local fs = {}
|
||||||
|
|
||||||
if not sfinv_only then
|
fs[#fs + 1] = fmt([[
|
||||||
fs[#fs + 1] = fmt([[
|
size[%f,%f]
|
||||||
size[%f,%f]
|
no_prepend[]
|
||||||
no_prepend[]
|
bgcolor[#0000]
|
||||||
bgcolor[#0000]
|
]], ROWS + (data.query_item and 6.7 or 0) - 1.2, LINES - 0.3)
|
||||||
style_type[image_button;border=false]
|
|
||||||
style_type[item_image_button;border=false;bgimg_hovered=%s]
|
|
||||||
]],
|
|
||||||
ROWS + (data.query_item and 6.7 or 0) - 1.2, LINES - 0.3, PNG.selected)
|
|
||||||
|
|
||||||
|
if not sfinv_only then
|
||||||
fs[#fs + 1] = CORE_VERSION >= 510 and
|
fs[#fs + 1] = CORE_VERSION >= 510 and
|
||||||
fmt("background9[-0.15,-0.2;%f,%f;%s;false;%d]",
|
fmt("background9[-0.15,-0.2;%f,%f;%s;false;%d]",
|
||||||
ROWS - 0.9, LINES + 0.4, PNG.bg_full, 10) or
|
ROWS - 0.9, LINES + 0.4, PNG.bg_full, 10) or
|
||||||
@ -996,15 +1042,18 @@ local function make_formspec(name)
|
|||||||
|
|
||||||
if CORE_VERSION >= 520 then
|
if CORE_VERSION >= 520 then
|
||||||
fs[#fs + 1] = fmt([[
|
fs[#fs + 1] = fmt([[
|
||||||
|
style_type[image_button;border=false]
|
||||||
|
style_type[item_image_button;border=false;bgimg_hovered=%s;bgimg_pressed=%s]
|
||||||
style[search;fgimg=%s;fgimg_hovered=%s]
|
style[search;fgimg=%s;fgimg_hovered=%s]
|
||||||
style[clear;fgimg=%s;fgimg_hovered=%s]
|
style[clear;fgimg=%s;fgimg_hovered=%s]
|
||||||
style[prev_page;fgimg=%s;fgimg_hovered=%s]
|
style[prev_page;fgimg=%s;fgimg_hovered=%s;fgimg_pressed=%s]
|
||||||
style[next_page;fgimg=%s;fgimg_hovered=%s]
|
style[next_page;fgimg=%s;fgimg_hovered=%s;fgimg_pressed=%s]
|
||||||
]],
|
]],
|
||||||
|
PNG.selected, PNG.selected,
|
||||||
PNG.search, PNG.search_hover,
|
PNG.search, PNG.search_hover,
|
||||||
PNG.clear, PNG.clear_hover,
|
PNG.clear, PNG.clear_hover,
|
||||||
PNG.prev, PNG.prev_hover,
|
PNG.prev, PNG.prev_hover, PNG.prev_hover,
|
||||||
PNG.next, PNG.next_hover)
|
PNG.next, PNG.next_hover, PNG.next_hover)
|
||||||
|
|
||||||
fs[#fs + 1] = fmt(mul_elem(FMT.image_button, 4),
|
fs[#fs + 1] = fmt(mul_elem(FMT.image_button, 4),
|
||||||
sfinv_only and 2.6 or 2.54, -0.06, 0.85, 0.85, "", "search", "",
|
sfinv_only and 2.6 or 2.54, -0.06, 0.85, 0.85, "", "search", "",
|
||||||
@ -1475,6 +1524,7 @@ local function init_data(name)
|
|||||||
pagenum = 1,
|
pagenum = 1,
|
||||||
items = items,
|
items = items,
|
||||||
items_raw = items,
|
items_raw = items,
|
||||||
|
favs = {},
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -1537,6 +1587,18 @@ local function fields(player, _f)
|
|||||||
data.pagenum = data.pagemax
|
data.pagenum = data.pagemax
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return true, show_fs(player, name)
|
||||||
|
|
||||||
|
elseif _f.fav then
|
||||||
|
local fav, i = is_fav(data)
|
||||||
|
local total = #data.favs
|
||||||
|
|
||||||
|
if total < 6 and not fav then
|
||||||
|
data.favs[total + 1] = data.query_item
|
||||||
|
elseif fav then
|
||||||
|
remove(data.favs, i)
|
||||||
|
end
|
||||||
|
|
||||||
return true, show_fs(player, name)
|
return true, show_fs(player, name)
|
||||||
else
|
else
|
||||||
local item
|
local item
|
||||||
|
Loading…
Reference in New Issue
Block a user