forked from minetest-mods/unified_inventory
Cleaner display of lack of recipes (redux)
When the current craft guide item has no recipes, show a "no" symbol instead of an ingredient grid, alongside the "No recipes" message. When no item is selected in the craft guide, leave the recipe space empty.
This commit is contained in:
parent
4c982dd667
commit
c33efe8631
26
register.lua
26
register.lua
@ -174,17 +174,18 @@ unified_inventory.register_page("craftguide", {
|
|||||||
local player_name = player:get_player_name()
|
local player_name = player:get_player_name()
|
||||||
local formspec = ""
|
local formspec = ""
|
||||||
formspec = formspec.."background[0,4.5;8,4;ui_main_inventory.png]"
|
formspec = formspec.."background[0,4.5;8,4;ui_main_inventory.png]"
|
||||||
formspec = formspec.."background[0,1;8,3;ui_craftguide_form.png]"
|
|
||||||
formspec = formspec.."label[0,0;Crafting Guide]"
|
formspec = formspec.."label[0,0;Crafting Guide]"
|
||||||
formspec = formspec.."listcolors[#00000000;#00000000]"
|
formspec = formspec.."listcolors[#00000000;#00000000]"
|
||||||
|
local item_name = unified_inventory.current_item[player_name]
|
||||||
|
if not item_name then return {formspec=formspec} end
|
||||||
|
|
||||||
|
formspec = formspec.."background[0,1;8,3;ui_craftguide_form.png]"
|
||||||
|
formspec = formspec.."textarea[0.3,0.6;10,1;;Result: "..minetest.formspec_escape(item_name)..";]"
|
||||||
|
formspec = formspec.."list[detached:"..minetest.formspec_escape(player_name).."craftrecipe;output;6,1;1,1;]"
|
||||||
local craftinv = minetest.get_inventory({
|
local craftinv = minetest.get_inventory({
|
||||||
type = "detached",
|
type = "detached",
|
||||||
name = player_name.."craftrecipe"
|
name = player_name.."craftrecipe"
|
||||||
})
|
})
|
||||||
local item_name = unified_inventory.current_item[player_name] or ""
|
|
||||||
|
|
||||||
formspec = formspec.."textarea[0.3,0.6;10,1;;Result: "..minetest.formspec_escape(item_name)..";]"
|
|
||||||
formspec = formspec.."list[detached:"..minetest.formspec_escape(player_name).."craftrecipe;output;6,1;1,1;]"
|
|
||||||
|
|
||||||
local alternate, alternates, craft, craft_type
|
local alternate, alternates, craft, craft_type
|
||||||
alternate = unified_inventory.alternate[player_name]
|
alternate = unified_inventory.alternate[player_name]
|
||||||
@ -194,19 +195,20 @@ unified_inventory.register_page("craftguide", {
|
|||||||
craft = crafts[alternate]
|
craft = crafts[alternate]
|
||||||
end
|
end
|
||||||
|
|
||||||
if craft then
|
if not craft then
|
||||||
|
craftinv:set_stack("output", 1, item_name)
|
||||||
|
craft_type = unified_inventory.craft_type_defaults("", {})
|
||||||
|
formspec = formspec.."label[6,3.35;No recipes]"
|
||||||
|
formspec = formspec.."image[4,1;1.1,1.1;ui_no.png]"
|
||||||
|
return {formspec = formspec}
|
||||||
|
end
|
||||||
|
|
||||||
craftinv:set_stack("output", 1, craft.output)
|
craftinv:set_stack("output", 1, craft.output)
|
||||||
craft_type = unified_inventory.registered_craft_types[craft.type] or
|
craft_type = unified_inventory.registered_craft_types[craft.type] or
|
||||||
unified_inventory.craft_type_defaults(craft.type, {})
|
unified_inventory.craft_type_defaults(craft.type, {})
|
||||||
formspec = formspec.."label[6,3.35;Method:]"
|
formspec = formspec.."label[6,3.35;Method:]"
|
||||||
formspec = formspec.."label[6,3.75;"
|
formspec = formspec.."label[6,3.75;"
|
||||||
..minetest.formspec_escape(craft_type.description).."]"
|
..minetest.formspec_escape(craft_type.description).."]"
|
||||||
else
|
|
||||||
craftinv:set_stack("output", 1, item_name)
|
|
||||||
craft_type = unified_inventory.craft_type_defaults("", {})
|
|
||||||
formspec = formspec.."label[6,3.35;No recipes]"
|
|
||||||
end
|
|
||||||
|
|
||||||
local display_size = craft_type.dynamic_display_size and craft_type.dynamic_display_size(craft) or { width = craft_type.width, height = craft_type.height }
|
local display_size = craft_type.dynamic_display_size and craft_type.dynamic_display_size(craft) or { width = craft_type.width, height = craft_type.height }
|
||||||
local craft_width = craft_type.get_shaped_craft_width and craft_type.get_shaped_craft_width(craft) or display_size.width
|
local craft_width = craft_type.get_shaped_craft_width and craft_type.get_shaped_craft_width(craft) or display_size.width
|
||||||
|
|
||||||
|
BIN
textures/ui_no.png
Normal file
BIN
textures/ui_no.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 7.3 KiB |
Loading…
Reference in New Issue
Block a user