forked from minetest-mods/craftguide
Compare commits
4 Commits
aa47a70e12
...
1.11b
Author | SHA1 | Date | |
---|---|---|---|
001176b124 | |||
2c2dbc9efc | |||
24d8faec59 | |||
58b2f49c8c |
183
init.lua
183
init.lua
@ -79,7 +79,7 @@ local IPP = ROWS * LINES
|
||||
local WH_LIMIT = 8
|
||||
|
||||
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 = {
|
||||
bg = "craftguide_bg.png",
|
||||
@ -556,7 +556,7 @@ local function get_usages(item)
|
||||
end
|
||||
|
||||
local function get_burntime(item)
|
||||
return get_craft_result({method = "fuel", items = {item}}).time
|
||||
return get_craft_result{method = "fuel", items = {item}}.time
|
||||
end
|
||||
|
||||
local function cache_fuel(item)
|
||||
@ -639,6 +639,19 @@ local function repairable(tool)
|
||||
return toolrepair and def and def.groups and def.groups.disable_repair ~= 1
|
||||
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 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
|
||||
fs[#fs + 1] = fmt(FMT.image,
|
||||
X, Y + (sfinv_only and 0.7 or 0),
|
||||
btn_size, btn_size, PNG.selected)
|
||||
X, Y + (sfinv_only and 0.7 or 0), btn_size, btn_size, PNG.selected)
|
||||
end
|
||||
|
||||
fs[#fs + 1] = fmt(FMT.item_image_button,
|
||||
@ -891,33 +903,58 @@ local function get_grid_fs(fs, rcp, spacing)
|
||||
end
|
||||
|
||||
local function get_panels(data, fs)
|
||||
local panels = {recipes = data.recipes or {}, usages = data.usages or {}}
|
||||
local x = 0.33
|
||||
local start_y = CORE_VERSION >= 520 and 0 or 0.33
|
||||
local panels = {
|
||||
{dat = data.usages or {}, height = 3.5},
|
||||
{dat = data.recipes or {}, height = 3.5},
|
||||
}
|
||||
|
||||
if sfinv_only then
|
||||
panels = data.show_usages and {usages = data.usages} or {recipes = data.recipes}
|
||||
if CORE_VERSION >= 520 and not sfinv_only then
|
||||
panels.favs = {dat = {}, height = 2.19}
|
||||
elseif sfinv_only then
|
||||
panels = data.show_usages and
|
||||
{{dat = data.usages}} or {{dat = data.recipes}}
|
||||
end
|
||||
|
||||
for k, v in pairs(panels) do
|
||||
x = x + 1
|
||||
local spacing = (x - 1) * 3.6
|
||||
start_y = start_y + 1
|
||||
local spacing = (start_y - 1) * 3.6
|
||||
|
||||
if not sfinv_only then
|
||||
fs[#fs + 1] = CORE_VERSION >= 510 and
|
||||
fmt("background9[8.1,%f;6.6,3.5;%s;false;%d]",
|
||||
-0.2 + spacing, PNG.bg_full, 10) or
|
||||
fmt("background[8.1,%f;6.6,3.5;%s;false]",
|
||||
-0.2 + spacing, PNG.bg_full)
|
||||
fmt("background9[8.1,%f;6.6,%f;%s;false;%d]",
|
||||
-0.2 + spacing, v.height, PNG.bg_full, 10) or
|
||||
fmt("background[8.1,%f;6.6,%f;%s;false]",
|
||||
-0.2 + spacing, v.height, PNG.bg_full)
|
||||
|
||||
if k ~= "favs" then
|
||||
local fav = is_fav(data)
|
||||
local nfavs = #data.favs
|
||||
|
||||
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 ""))
|
||||
|
||||
if nfavs < 6 or (nfavs >= 6 and fav) then
|
||||
fs[#fs + 1] = fmt(FMT.image_button,
|
||||
14, spacing, 0.5, 0.45, "", "fav", "")
|
||||
end
|
||||
|
||||
fs[#fs + 1] = fmt("tooltip[fav;%s]",
|
||||
fav and ES"Unmark this item" or ES"Mark this item")
|
||||
end
|
||||
end
|
||||
|
||||
local rn = #v
|
||||
local rn = #v.dat
|
||||
local _rn = tostring(rn)
|
||||
local xu = tostring(data.unum) .. _rn
|
||||
local xr = tostring(data.rnum) .. _rn
|
||||
xu = max(-0.3, -((#xu - 3) * 0.15))
|
||||
xr = max(-0.3, -((#xr - 3) * 0.15))
|
||||
xu = max(-0.3, -((#xu - 3) * 0.05))
|
||||
xr = max(-0.3, -((#xr - 3) * 0.05))
|
||||
|
||||
local is_recipe = k == "recipes"
|
||||
local is_recipe = k == 2
|
||||
local lbl
|
||||
|
||||
if not sfinv_only and rn == 0 then
|
||||
@ -938,14 +975,14 @@ local function get_panels(data, fs)
|
||||
|
||||
fs[#fs + 1] = fmt(FMT.label,
|
||||
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
|
||||
local btn_suffix = is_recipe and "recipe" or "usage"
|
||||
local prev_name = fmt("prev_%s", btn_suffix)
|
||||
local next_name = fmt("next_%s", btn_suffix)
|
||||
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
|
||||
fs[#fs + 1] = fmt(mul_elem(FMT.arrow, 2),
|
||||
@ -960,10 +997,28 @@ local function get_panels(data, fs)
|
||||
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
|
||||
get_grid_fs(fs, rcp, spacing)
|
||||
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
|
||||
|
||||
@ -971,16 +1026,14 @@ local function make_formspec(name)
|
||||
local data = pdata[name]
|
||||
local fs = {}
|
||||
|
||||
if not sfinv_only then
|
||||
fs[#fs + 1] = fmt([[
|
||||
size[%f,%f]
|
||||
no_prepend[]
|
||||
bgcolor[#0000]
|
||||
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)
|
||||
fs[#fs + 1] = fmt([[
|
||||
size[%f,%f]
|
||||
no_prepend[]
|
||||
bgcolor[#0000]
|
||||
]],
|
||||
ROWS + (data.query_item and 6.7 or 0) - 1.2, LINES - 0.3)
|
||||
|
||||
if not sfinv_only then
|
||||
fs[#fs + 1] = CORE_VERSION >= 510 and
|
||||
fmt("background9[-0.15,-0.2;%f,%f;%s;false;%d]",
|
||||
ROWS - 0.9, LINES + 0.4, PNG.bg_full, 10) or
|
||||
@ -996,15 +1049,18 @@ local function make_formspec(name)
|
||||
|
||||
if CORE_VERSION >= 520 then
|
||||
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[clear;fgimg=%s;fgimg_hovered=%s]
|
||||
style[prev_page;fgimg=%s;fgimg_hovered=%s]
|
||||
style[next_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;fgimg_pressed=%s]
|
||||
]],
|
||||
PNG.selected, PNG.selected,
|
||||
PNG.search, PNG.search_hover,
|
||||
PNG.clear, PNG.clear_hover,
|
||||
PNG.prev, PNG.prev_hover,
|
||||
PNG.next, PNG.next_hover)
|
||||
PNG.clear, PNG.clear_hover,
|
||||
PNG.prev, PNG.prev_hover, PNG.prev_hover,
|
||||
PNG.next, PNG.next_hover, PNG.next_hover)
|
||||
|
||||
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", "",
|
||||
@ -1320,20 +1376,20 @@ local function handle_drops_table(name, drop)
|
||||
end
|
||||
|
||||
for item, count in pairs(drop_sure) do
|
||||
craftguide.register_craft({
|
||||
craftguide.register_craft{
|
||||
type = "digging",
|
||||
items = {name},
|
||||
output = fmt("%s %u", item, count),
|
||||
})
|
||||
}
|
||||
end
|
||||
|
||||
for item, data in pairs(drop_maybe) do
|
||||
craftguide.register_craft({
|
||||
craftguide.register_craft{
|
||||
type = "digging_chance",
|
||||
items = {name},
|
||||
output = fmt("%s %u", item, data.output),
|
||||
rarity = data.rarity,
|
||||
})
|
||||
}
|
||||
end
|
||||
end
|
||||
|
||||
@ -1342,11 +1398,11 @@ local function register_drops(name, def)
|
||||
local dstack = ItemStack(drop)
|
||||
|
||||
if not dstack:is_empty() and dstack:get_name() ~= name then
|
||||
craftguide.register_craft({
|
||||
craftguide.register_craft{
|
||||
type = "digging",
|
||||
items = {name},
|
||||
output = drop,
|
||||
})
|
||||
}
|
||||
elseif is_table(drop) then
|
||||
handle_drops_table(name, drop)
|
||||
end
|
||||
@ -1457,10 +1513,10 @@ local function get_init_items()
|
||||
fuel = fuel_cache,
|
||||
}
|
||||
|
||||
http.fetch_async({
|
||||
http.fetch_async{
|
||||
url = craftguide.export_url,
|
||||
post_data = write_json(post_data),
|
||||
})
|
||||
}
|
||||
end
|
||||
|
||||
print()
|
||||
@ -1475,6 +1531,7 @@ local function init_data(name)
|
||||
pagenum = 1,
|
||||
items = items,
|
||||
items_raw = items,
|
||||
favs = {},
|
||||
}
|
||||
end
|
||||
|
||||
@ -1537,6 +1594,18 @@ local function fields(player, _f)
|
||||
data.pagenum = data.pagemax
|
||||
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)
|
||||
else
|
||||
local item
|
||||
@ -1658,29 +1727,29 @@ else
|
||||
end
|
||||
})
|
||||
|
||||
core.register_craft({
|
||||
core.register_craft{
|
||||
output = "craftguide:book",
|
||||
type = "shapeless",
|
||||
recipe = {"default:book"}
|
||||
})
|
||||
}
|
||||
|
||||
core.register_craft({
|
||||
core.register_craft{
|
||||
type = "fuel",
|
||||
recipe = "craftguide:book",
|
||||
burntime = 3
|
||||
})
|
||||
}
|
||||
|
||||
core.register_craft({
|
||||
core.register_craft{
|
||||
output = "craftguide:sign",
|
||||
type = "shapeless",
|
||||
recipe = {"default:sign_wall_wood"}
|
||||
})
|
||||
}
|
||||
|
||||
core.register_craft({
|
||||
core.register_craft{
|
||||
type = "fuel",
|
||||
recipe = "craftguide:sign",
|
||||
burntime = 10
|
||||
})
|
||||
}
|
||||
|
||||
if rawget(_G, "sfinv_buttons") then
|
||||
sfinv_buttons.register_button("craftguide", {
|
||||
@ -1896,29 +1965,29 @@ if progressive_mode then
|
||||
end
|
||||
|
||||
data.hud = {
|
||||
bg = player:hud_add({
|
||||
bg = player:hud_add{
|
||||
hud_elem_type = "image",
|
||||
position = {x = 0.78, y = 1},
|
||||
alignment = {x = 1, y = 1},
|
||||
scale = {x = 370, y = 112},
|
||||
text = PNG.bg,
|
||||
}),
|
||||
},
|
||||
|
||||
book = player:hud_add({
|
||||
book = player:hud_add{
|
||||
hud_elem_type = "image",
|
||||
position = {x = 0.79, y = 1.02},
|
||||
alignment = {x = 1, y = 1},
|
||||
scale = {x = 4, y = 4},
|
||||
text = PNG.book,
|
||||
}),
|
||||
},
|
||||
|
||||
text = player:hud_add({
|
||||
text = player:hud_add{
|
||||
hud_elem_type = "text",
|
||||
position = {x = 0.84, y = 1.04},
|
||||
alignment = {x = 1, y = 1},
|
||||
number = 0xfff,
|
||||
text = "",
|
||||
}),
|
||||
},
|
||||
}
|
||||
end)
|
||||
|
||||
|
@ -3,7 +3,7 @@ License of source code
|
||||
|
||||
The MIT License (MIT)
|
||||
|
||||
Copyright (c) 2015-2019 Jean-Patrick Guerrero and contributors.
|
||||
Copyright (c) 2015-2020 Jean-Patrick Guerrero and contributors.
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
|
BIN
textures/craftguide_fav.png
Normal file
BIN
textures/craftguide_fav.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 916 B |
BIN
textures/craftguide_fav_off.png
Normal file
BIN
textures/craftguide_fav_off.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.8 KiB |
Reference in New Issue
Block a user