forked from minetest-mods/craftguide
Minor style cleanup
This commit is contained in:
parent
b3679124fa
commit
455a937521
66
init.lua
66
init.lua
@ -30,7 +30,9 @@ function craftguide:group_to_item(item)
|
|||||||
elseif minetest.registered_items["default:"..item:sub(7)] then
|
elseif minetest.registered_items["default:"..item:sub(7)] then
|
||||||
item = item:gsub("group:", "default:")
|
item = item:gsub("group:", "default:")
|
||||||
else for node, def in pairs(minetest.registered_items) do
|
else for node, def in pairs(minetest.registered_items) do
|
||||||
if def.groups[item:match("[^,:]+$")] then item = node end
|
if def.groups[item:match("[^,:]+$")] then
|
||||||
|
item = node
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -43,6 +45,7 @@ local function extract_groups(str)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function colorize(str)
|
local function colorize(str)
|
||||||
|
-- If client <= 0.4.14, don't colorize for compatibility.
|
||||||
return minetest.colorize and minetest.colorize("#FFFF00", str) or str
|
return minetest.colorize and minetest.colorize("#FFFF00", str) or str
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -68,20 +71,23 @@ function craftguide:get_tooltip(item, recipe_type, cooktime, groups)
|
|||||||
tooltip = tooltip..groupstr.." group(s)"
|
tooltip = tooltip..groupstr.." group(s)"
|
||||||
end
|
end
|
||||||
if recipe_type == "cooking" then
|
if recipe_type == "cooking" then
|
||||||
tooltip = tooltip..item_desc.."\nCooking time: "..colorize(cooktime)
|
tooltip = tooltip..item_desc.."\nCooking time: "..
|
||||||
|
colorize(cooktime)
|
||||||
end
|
end
|
||||||
if fueltime > 0 then
|
if fueltime > 0 then
|
||||||
tooltip = tooltip..item_desc.."\nBurning time: "..colorize(fueltime)
|
tooltip = tooltip..item_desc.."\nBurning time: "..
|
||||||
|
colorize(fueltime)
|
||||||
end
|
end
|
||||||
|
|
||||||
return has_extras and tooltip.."]" or ""
|
return has_extras and tooltip.."]" or ""
|
||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:get_recipe(player_name, tooltip_l, item, recipe_num, recipes)
|
function craftguide:get_recipe(player_name, tooltipl, item, recipe_num, recipes)
|
||||||
local formspec, recipe_type = "", recipes[recipe_num].type
|
local formspec, recipe_type = "", recipes[recipe_num].type
|
||||||
if #recipes > 1 then formspec = formspec..
|
if #recipes > 1 then formspec = formspec..
|
||||||
"button[0,"..(iY+3)..";2,1;alternate;Alternate]"..
|
"button[0,"..(iY+3)..";2,1;alternate;Alternate]"..
|
||||||
"label[0,"..(iY+2)..".5;Recipe "..recipe_num.." of "..#recipes.."]"
|
"label[0,"..(iY+2)..".5;Recipe "..
|
||||||
|
recipe_num.." of "..#recipes.."]"
|
||||||
end
|
end
|
||||||
if recipe_type == "cooking" then
|
if recipe_type == "cooking" then
|
||||||
formspec = formspec.."image["..(xoffset-0.8)..","..(iY+1)..
|
formspec = formspec.."image["..(xoffset-0.8)..","..(iY+1)..
|
||||||
@ -106,24 +112,27 @@ function craftguide:get_recipe(player_name, tooltip_l, item, recipe_num, recipes
|
|||||||
if recipe_type == "normal" and width > 3 or rows > 3 then
|
if recipe_type == "normal" and width > 3 or rows > 3 then
|
||||||
btn_size = width > 3 and 3 / width or 3 / rows
|
btn_size = width > 3 and 3 / width or 3 / rows
|
||||||
X = btn_size * (i % width) + xoffset
|
X = btn_size * (i % width) + xoffset
|
||||||
Y = btn_size * floor((i-1) / width) + iY+3 - min(2, rows)
|
Y = btn_size * floor((i-1) / width) + iY+3 -
|
||||||
|
min(2, rows)
|
||||||
end
|
end
|
||||||
|
|
||||||
local groups = extract_groups(v)
|
local groups = extract_groups(v)
|
||||||
local label = groups and "\nG" or ""
|
local label = groups and "\nG" or ""
|
||||||
local item_r = self:group_to_item(v)
|
local item_r = self:group_to_item(v)
|
||||||
local tooltip = self:get_tooltip(item_r, recipe_type, width, groups)
|
local tooltip = self:get_tooltip(item_r, recipe_type,
|
||||||
|
width, groups)
|
||||||
|
|
||||||
formspec = formspec.."item_image_button["..X..","..Y..";"..
|
formspec = formspec.."item_image_button["..X..","..Y..";"..
|
||||||
btn_size..","..btn_size..";"..
|
btn_size..","..btn_size..";"..
|
||||||
item_r..";"..item_r..";"..label.."]"..tooltip
|
item_r..";"..item_r..";"..label.."]"..
|
||||||
|
tooltip
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local output = recipes[recipe_num].output
|
local output = recipes[recipe_num].output
|
||||||
return formspec.."image["..(xoffset-1)..","..(iY+2)..
|
return formspec.."image["..(xoffset-1)..","..(iY+2)..
|
||||||
".12;0.9,0.7;craftguide_arrow.png]"..
|
".12;0.9,0.7;craftguide_arrow.png]"..
|
||||||
"item_image_button["..(xoffset-2)..","..(iY+2)..";1,1;"..
|
"item_image_button["..(xoffset-2)..","..(iY+2)..";1,1;"..
|
||||||
output..";"..item..";]"..tooltip_l
|
output..";"..item..";]"..tooltipl
|
||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:get_formspec(player_name, is_fuel)
|
function craftguide:get_formspec(player_name, is_fuel)
|
||||||
@ -165,8 +174,8 @@ function craftguide:get_formspec(player_name, is_fuel)
|
|||||||
formspec = formspec..
|
formspec = formspec..
|
||||||
"image["..(xoffset-1)..","..(iY+2)..
|
"image["..(xoffset-1)..","..(iY+2)..
|
||||||
".12;0.9,0.7;craftguide_arrow.png]"..
|
".12;0.9,0.7;craftguide_arrow.png]"..
|
||||||
"item_image_button["..xoffset..","..(iY+2)..";1,1;"..
|
"item_image_button["..xoffset..","..(iY+2)..
|
||||||
data.item..";"..data.item..";]"..
|
";1,1;"..data.item..";"..data.item..";]"..
|
||||||
tooltip.."image["..(xoffset-2)..","..
|
tooltip.."image["..(xoffset-2)..","..
|
||||||
(iY+2)..";1,1;craftguide_none.png]"
|
(iY+2)..";1,1;craftguide_none.png]"
|
||||||
else
|
else
|
||||||
@ -195,7 +204,8 @@ local function group_to_items(group)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:recipe_in_inv(inv, item_name, recipes_f)
|
function craftguide:recipe_in_inv(inv, item_name, recipes_f)
|
||||||
local recipes = recipes_f or minetest.get_all_craft_recipes(item_name) or {}
|
local recipes = recipes_f or
|
||||||
|
minetest.get_all_craft_recipes(item_name) or {}
|
||||||
local show_item_recipes = {}
|
local show_item_recipes = {}
|
||||||
|
|
||||||
for i=1, #recipes do
|
for i=1, #recipes do
|
||||||
@ -205,12 +215,14 @@ function craftguide:recipe_in_inv(inv, item_name, recipes_f)
|
|||||||
if item:sub(1,6) == "group:" then
|
if item:sub(1,6) == "group:" then
|
||||||
local groups = group_to_items(item)
|
local groups = group_to_items(item)
|
||||||
for j=1, #groups do
|
for j=1, #groups do
|
||||||
if inv:contains_item("main", groups[j]) then
|
if inv:contains_item("main",
|
||||||
|
groups[j]) then
|
||||||
group_in_inv = true
|
group_in_inv = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not group_in_inv and not inv:contains_item("main", item) then
|
if not group_in_inv and not
|
||||||
|
inv:contains_item("main", item) then
|
||||||
show_item_recipes[i] = false
|
show_item_recipes[i] = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -238,30 +250,32 @@ function craftguide:get_init_items(player_name)
|
|||||||
|
|
||||||
sort(items_list)
|
sort(items_list)
|
||||||
data.items = items_list
|
data.items = items_list
|
||||||
data.size = #items_list
|
data.pagemax = max(1, ceil(list_size / ipp))
|
||||||
data.pagemax = max(1, ceil(data.size / ipp))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function craftguide:get_filter_items(player_name)
|
function craftguide:get_filter_items(player_name)
|
||||||
local data = datas[player_name]
|
local data = datas[player_name]
|
||||||
local items_list = data.items
|
local items_list, list_size = data.items, #data.items
|
||||||
local player = minetest.get_player_by_name(player_name)
|
local player = minetest.get_player_by_name(player_name)
|
||||||
local inv = player:get_inventory()
|
local inv = player:get_inventory()
|
||||||
|
|
||||||
for i=#items_list, 1, -1 do
|
for i=list_size, 1, -1 do
|
||||||
if not items_list[i]:find(data.filter, 1, true) then
|
if not items_list[i]:find(data.filter, 1, true) then
|
||||||
remove(items_list, i)
|
remove(items_list, i)
|
||||||
|
list_size = list_size - 1
|
||||||
end
|
end
|
||||||
if progressive_mode then
|
if progressive_mode then
|
||||||
local _, has_item =
|
local _, has_item =
|
||||||
self:recipe_in_inv(inv, items_list[i] or "")
|
self:recipe_in_inv(inv, items_list[i] or "")
|
||||||
if not has_item then remove(items_list, i) end
|
if not has_item then
|
||||||
|
remove(items_list, i)
|
||||||
|
list_size = list_size - 1
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
data.items = items_list
|
data.items = items_list
|
||||||
data.size = #items_list
|
data.pagemax = max(1, ceil(list_size / ipp))
|
||||||
data.pagemax = max(1, ceil(data.size / ipp))
|
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
minetest.register_on_player_receive_fields(function(player, formname, fields)
|
||||||
@ -270,7 +284,8 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
local data = datas[player_name]
|
local data = datas[player_name]
|
||||||
|
|
||||||
if fields.clear then
|
if fields.clear then
|
||||||
data.filter, data.item, data.pagenum, data.recipe_num = "", nil, 1, 1
|
data.filter, data.item, data.pagenum, data.recipe_num =
|
||||||
|
"", nil, 1, 1
|
||||||
craftguide:get_init_items(player_name)
|
craftguide:get_init_items(player_name)
|
||||||
if progressive_mode then
|
if progressive_mode then
|
||||||
craftguide:get_filter_items(player_name)
|
craftguide:get_filter_items(player_name)
|
||||||
@ -280,7 +295,8 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
local recipe = data.recipes_item[data.recipe_num + 1]
|
local recipe = data.recipes_item[data.recipe_num + 1]
|
||||||
data.recipe_num = recipe and data.recipe_num + 1 or 1
|
data.recipe_num = recipe and data.recipe_num + 1 or 1
|
||||||
craftguide:get_formspec(player_name)
|
craftguide:get_formspec(player_name)
|
||||||
elseif fields.search or fields.key_enter_field == "craftguide_filter" then
|
elseif fields.search or
|
||||||
|
fields.key_enter_field == "craftguide_filter" then
|
||||||
data.filter = fields.craftguide_filter:lower()
|
data.filter = fields.craftguide_filter:lower()
|
||||||
data.pagenum = 1
|
data.pagenum = 1
|
||||||
craftguide:get_init_items(player_name)
|
craftguide:get_init_items(player_name)
|
||||||
@ -304,8 +320,8 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
|
|||||||
if not recipes and not is_fuel then return end
|
if not recipes and not is_fuel then return end
|
||||||
|
|
||||||
if progressive_mode then
|
if progressive_mode then
|
||||||
local player = minetest.get_player_by_name(player_name)
|
local who = minetest.get_player_by_name(player_name)
|
||||||
local inv = player:get_inventory()
|
local inv = who:get_inventory()
|
||||||
local _, has_item = craftguide:recipe_in_inv(inv, item)
|
local _, has_item = craftguide:recipe_in_inv(inv, item)
|
||||||
|
|
||||||
if not has_item then return end
|
if not has_item then return end
|
||||||
|
Loading…
Reference in New Issue
Block a user