X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=mailbox.lua;h=47bb26c7afe3ab9bb1f54c2abbe4267961b78d1e;hb=d742c54548ae42bc3123bfbfb8fde837abb02b5c;hp=76273bf9bfd3d88dcc479afa05a872927624d3d7;hpb=b3f9a68c1677186730d1c8264bffa70f7ae730a3;p=xdecor.git diff --git a/mailbox.lua b/mailbox.lua index 76273bf..47bb26c 100644 --- a/mailbox.lua +++ b/mailbox.lua @@ -1,3 +1,6 @@ +local mailbox = {} +screwdriver = screwdriver or {} + xdecor.register("mailbox", { description = "Mailbox", tiles = { @@ -5,85 +8,122 @@ xdecor.register("mailbox", { "xdecor_mailbox_side.png", "xdecor_mailbox_side.png", "xdecor_mailbox.png", "xdecor_mailbox.png", }, - groups = {snappy=2, cracky=2}, - after_place_node = function(pos, placer, itemstack) + groups = {cracky=3, oddly_breakable_by_hand=1}, + on_rotate = screwdriver.rotate_simple, + after_place_node = function(pos, placer, _) local meta = minetest.get_meta(pos) - local owner = placer:get_player_name() + local player_name = placer:get_player_name() - meta:set_string("owner", owner) - meta:set_string("infotext", owner.."'s Mailbox") + meta:set_string("owner", player_name) + meta:set_string("infotext", player_name.."'s Mailbox") local inv = meta:get_inventory() - inv:set_size("main", 8*4) + inv:set_size("mailbox", 6*4) inv:set_size("drop", 1) end, - on_rightclick = function(pos, node, clicker, itemstack) + on_rightclick = function(pos, _, clicker, _) local meta = minetest.get_meta(pos) local player = clicker:get_player_name() - local owner = meta:get_string("owner") - local meta = minetest.get_meta(pos) + local owner = meta:get_string("owner") - if owner == player then - minetest.show_formspec( - clicker:get_player_name(), - "default:chest_locked", - xdecor.get_mailbox_formspec(pos)) + if player == owner then + minetest.show_formspec(player, "", mailbox.formspec(pos, owner, 1)) else - minetest.show_formspec( - clicker:get_player_name(), - "default:chest_locked", - xdecor.get_mailbox_insert_formspec(pos)) + minetest.show_formspec(player, "", mailbox.formspec(pos, owner, 0)) end end, - can_dig = function(pos,player) + can_dig = function(pos, player) local meta = minetest.get_meta(pos) local owner = meta:get_string("owner") + local player_name = player:get_player_name() local inv = meta:get_inventory() - return player:get_player_name() == owner and inv:is_empty("main") + return inv:is_empty("mailbox") and player and player_name == owner end, - on_metadata_inventory_put = function(pos, listname, index, stack, player) + on_metadata_inventory_put = function(pos, listname, _, stack, player) + local inv = minetest.get_meta(pos):get_inventory() + local player_name = player:get_player_name() local meta = minetest.get_meta(pos) - local inv = meta:get_inventory() + local stack_name = stack:get_name().." "..stack:get_count() - if listname == "drop" and inv:room_for_item("main", stack) then + if listname == "drop" and inv:room_for_item("mailbox", stack) then inv:remove_item("drop", stack) - inv:add_item("main", stack) + inv:add_item("mailbox", stack) + + for i = 7, 2, -1 do + meta:set_string("giver"..i, meta:get_string("giver"..(i-1))) + meta:set_string("stack"..i, meta:get_string("stack"..(i-1))) + end + meta:set_string("giver1", player_name) + meta:set_string("stack1", stack_name) end end, - allow_metadata_inventory_put = function(pos, listname, index, stack, player) - if listname == "main" then - return 0 - end + allow_metadata_inventory_put = function(pos, listname, _, stack, _) if listname == "drop" then local meta = minetest.get_meta(pos) local inv = meta:get_inventory() - - if inv:room_for_item("main", stack) then - return -1 - else - return 0 - end + if inv:room_for_item("mailbox", stack) then return -1 end end - end, + return 0 + end }) -function xdecor.get_mailbox_formspec(pos) - local spos = pos.x..","..pos.y..","..pos.z - local formspec = - "size[8,9]"..xdecor.fancy_gui.. - "label[0,0;You received...]".. - "list[nodemeta:"..spos..";main;0,0.75;8,4;]".. - "list[current_player;main;0,5.25;8,4;]" - return formspec +local function img_col(stack) + if not stack then return "" end + if stack.type == "node" then + if stack.inventory_image ~= "" then + return string.match(stack.inventory_image, "([%w_]+)")..".png" + else + return string.match(stack.tiles[1], "([%w_]+)")..".png" + end + elseif stack.type == "tool" or stack.type == "craft" then + return string.match(stack.inventory_image, "([%w_]+)")..".png" + else return "" end end -function xdecor.get_mailbox_insert_formspec(pos) +function mailbox.formspec(pos, owner, num) + local xbg = default.gui_bg..default.gui_bg_img..default.gui_slots local spos = pos.x..","..pos.y..","..pos.z - local formspec = - "size[8,5]"..xdecor.fancy_gui.. - "label[0,0;Send your goods...]".. - "list[nodemeta:"..spos..";drop;3.5,0;1,1;]".. - "list[current_player;main;0,1.25;8,4;]" - return formspec + local meta = minetest.get_meta(pos) + local giver = "" + local def_stack1 = minetest.registered_items[meta:get_string("stack1"):match("([%w_]+:[%w_]+)")] + local def_stack2 = minetest.registered_items[meta:get_string("stack2"):match("([%w_]+:[%w_]+)")] + local def_stack3 = minetest.registered_items[meta:get_string("stack3"):match("([%w_]+:[%w_]+)")] + local def_stack4 = minetest.registered_items[meta:get_string("stack4"):match("([%w_]+:[%w_]+)")] + local def_stack5 = minetest.registered_items[meta:get_string("stack5"):match("([%w_]+:[%w_]+)")] + local def_stack6 = minetest.registered_items[meta:get_string("stack6"):match("([%w_]+:[%w_]+)")] + local def_stack7 = minetest.registered_items[meta:get_string("stack7"):match("([%w_]+:[%w_]+)")] + + if num == 1 then + for i = 1, 7 do + if meta:get_string("giver"..i) ~= "" then + giver = giver.."#FFFF00,"..meta:get_string("giver"..i):sub(1, 12).. + ","..i..",#FFFFFF,x "..meta:get_string("stack"..i):sub(-3):match("%d+").."," + end + end + + return "size[9.5,9]"..xbg.. + default.get_hotbar_bg(0.75,5.25).. + "label[0,0;Mailbox :]".. + "label[6,0;Last donators :]".. + "tablecolumns[color;text;image,".. + "1="..img_col(def_stack1)..",".. + "2="..img_col(def_stack2)..",".. + "3="..img_col(def_stack3)..",".. + "4="..img_col(def_stack4)..",".. + "5="..img_col(def_stack5)..",".. + "6="..img_col(def_stack6)..",".. + "7="..img_col(def_stack7)..";color;text]".. + "tableoptions[background=#434343;highlight=#00000000;border=true]".. + "table[6,0.75;3.3,4;givers;"..giver.."]".. + "list[nodemeta:"..spos..";mailbox;0,0.75;6,4;]".. + "list[current_player;main;0.75,5.25;8,4;]" + else + return "size[8,5]"..xbg.. + default.get_hotbar_bg(0,1.25).. + "label[0.5,0;Send your goods\nto "..owner.." :]".. + "list[nodemeta:"..spos..";drop;3.5,0;1,1;]".. + "list[current_player;main;0,1.25;8,4;]" + end end +