Wuzzy 4382174993 Merge crafting grid and armor into main inv. menu
(this changes inventory_plus)
2015-05-28 11:13:01 +02:00

157 lines
4.2 KiB
Lua

--[[
Inventory Plus for Minetest
Copyright (c) 2012 cornernote, Brett O'Donnell <cornernote@gmail.com>
Source Code: https://github.com/cornernote/minetest-particles
License: GPLv3
]]--
-- expose api
inventory_plus = {}
-- define buttons
inventory_plus.buttons = {}
-- default inventory page
inventory_plus.default = minetest.setting_get("inventory_default") or "main"
-- register_button
inventory_plus.register_button = function(player,name,label)
local player_name = player:get_player_name()
if inventory_plus.buttons[player_name] == nil then
inventory_plus.buttons[player_name] = {}
end
inventory_plus.buttons[player_name][name] = label
end
-- set_inventory_formspec
inventory_plus.set_inventory_formspec = function(player,formspec)
local privs = minetest.get_player_privs(player:get_player_name())
if privs.hg_maker then
-- if creative mode is on then wait a bit
minetest.after(0.1,function()
player:set_inventory_formspec(formspec)
end)
else
player:set_inventory_formspec(formspec)
end
end
-- get_formspec
inventory_plus.get_formspec = function(player,page)
local f = {}
local fp = #f
fp = fp + 1
f[fp] = "size[9,8.5]"
-- player inventory
fp = fp + 1
f[fp] = "list[current_player;main;0.5,4.5;8,4;]"
-- main page
if page=="main" then
local name = player:get_player_name()
-- buttons
local x,y=0,0
for k,v in pairs(inventory_plus.buttons[name]) do
fp = fp + 1
f[fp] = "button["..x..","..y..";2,0.5;"..k..";"..v.."]"
x=x+2
if x == 8 then
x=0
y=y+1
end
end
-- armor
fp = fp + 1
f[fp] = "list[detached:"..name.."_armor;armor_head;2,0;1,1;]"
fp = fp + 1
f[fp] = "list[detached:"..name.."_armor;armor_torso;2,1;1,1;]"
fp = fp + 1
f[fp] = "list[detached:"..name.."_armor;armor_legs;2,2;1,1;]"
fp = fp + 1
f[fp] = "list[detached:"..name.."_armor;armor_feet;2,3;1,1;]"
fp = fp + 1
f[fp] = "list[detached:"..name.."_armor;armor_shield;3,1;1,1;]"
-- crafting
fp = fp + 1
f[fp] = "list[current_player;craftpreview;8,1.5;1,1;]"
if minetest.setting_getbool("inventory_craft_small") then
fp = fp + 1
f[fp] = "list[current_player;craft;4.5,0.5;2,2;]"
player:get_inventory():set_width("craft", 2)
player:get_inventory():set_size("craft", 2*2)
else
fp = fp + 1
f[fp] = "list[current_player;craft;4.5,0.5;3,3;]"
player:get_inventory():set_width("craft", 3)
player:get_inventory():set_size("craft", 3*3)
end
end
return table.concat(f, "")
end
-- trash slot
inventory_plus.trash = minetest.create_detached_inventory("trash", {
allow_put = function(inv, listname, index, stack, player)
if minetest.setting_getbool("creative_mode") then
return stack:get_count()
else
return 0
end
end,
on_put = function(inv, listname, index, stack, player)
inv:set_stack(listname, index, nil)
end,
})
inventory_plus.trash:set_size("main", 1)
-- refill slot
inventory_plus.refill = minetest.create_detached_inventory("refill", {
allow_put = function(inv, listname, index, stack, player)
local privs = minetest.get_player_privs(name)
if privs.hg_maker then
return stack:get_count()
else
return 0
end
end,
on_put = function(inv, listname, index, stack, player)
inv:set_stack(listname, index, ItemStack(stack:get_name().." "..stack:get_stack_max()))
end,
})
inventory_plus.refill:set_size("main", 1)
-- register_on_joinplayer
minetest.register_on_joinplayer(function(player)
if minetest.setting_getbool("inventory_craft_small") then
player:get_inventory():set_width("craft", 2)
player:get_inventory():set_size("craft", 2*2)
else
player:get_inventory():set_width("craft", 3)
player:get_inventory():set_size("craft", 3*3)
end
local privs = minetest.get_player_privs(player:get_player_name())
minetest.after(1,function()
inventory_plus.set_inventory_formspec(player,inventory_plus.get_formspec(player, inventory_plus.default))
end)
end)
-- register_on_player_receive_fields
minetest.register_on_player_receive_fields(function(player, formname, fields)
-- main
if fields.main then
inventory_plus.set_inventory_formspec(player, inventory_plus.get_formspec(player,"main"))
return
end
end)
-- log that we started
minetest.log("action", "[MOD]"..minetest.get_current_modname().." -- loaded from "..minetest.get_modpath(minetest.get_current_modname()))