]> git.lizzy.rs Git - xdecor.git/blobdiff - mailbox.lua
Get rid of minetest.serialize in cooking code + cleaning of ench. table
[xdecor.git] / mailbox.lua
index 9dd304023789fc8a467f3ea34879cedc4b787739..b8b18bb7dc929157cac30fac887607f730c1e9c4 100644 (file)
@@ -1,3 +1,6 @@
+local mailbox = {}
+screwdriver = screwdriver or {}
+
 xdecor.register("mailbox", {
        description = "Mailbox",
        tiles = {
@@ -5,16 +8,17 @@ xdecor.register("mailbox", {
                "xdecor_mailbox_side.png", "xdecor_mailbox_side.png",
                "xdecor_mailbox.png", "xdecor_mailbox.png",
        },
-       groups = {cracky=2},
+       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, _, clicker, _)
@@ -22,57 +26,99 @@ xdecor.register("mailbox", {
                local player = clicker:get_player_name()
                local owner = meta:get_string("owner")
 
-               if owner == player then
-                       minetest.show_formspec(player, "default:chest_locked",
-                               xdecor.get_mailbox_formspec(pos))
-               else minetest.show_formspec(player, "default:chest_locked",
-                               xdecor.get_mailbox_insert_formspec(pos))
+               if player == owner then
+                       minetest.show_formspec(player, "", mailbox.formspec(pos, owner, 1))
+               else
+                       minetest.show_formspec(player, "", mailbox.formspec(pos, owner, 0))
                end
        end,
        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()
 
-               if not inv:is_empty("main") then return false end
-               return player:get_player_name() == owner
+               return inv:is_empty("mailbox") and player and player_name == owner
        end,
-       on_metadata_inventory_put = function(pos, listname, _, stack, _)
+       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, _, stack, _)
-               if listname == "main" then return 0 end
+       allow_metadata_inventory_put = function(pos, listname, _, stack, player)
+               local player_name = player:get_player_name()
                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
+                       else
+                               minetest.chat_send_player(player_name, "The mailbox is full")
+                       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.inventory_image ~= "" then
+               return stack.inventory_image:match("([%w_]+)%.png")..".png"
+       else
+               return stack.tiles[1]:match("([%w_]+)%.png")..".png"
+       end
 end
 
-function xdecor.get_mailbox_insert_formspec(pos)
+function mailbox.formspec(pos, owner, num)
        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, img = "", ""
+
+       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):match("%s(%d+)")..","
+
+                               img = img..i.."="..img_col(minetest.registered_items[
+                                       meta:get_string("stack"..i):match("([%w_:]+)")])..","
+                       end
+               end
+
+               return [[ size[9.5,9]
+                       label[0,0;Mailbox]
+                       label[6,0;Last donators]
+                       box[6,0.72;3.3,3.5;#555555]
+                       listring[current_player;main]
+                       list[current_player;main;0.75,5.25;8,4;]
+                       tableoptions[background=#00000000;highlight=#00000000;border=false] ]]
+                       .."tablecolumns[color;text;image,"..img.."0;color;text]"..
+                       "table[6,0.75;3.3,4;givers;"..giver.."]"..
+                       "list[nodemeta:"..spos..";mailbox;0,0.75;6,4;]"..
+                       "listring[nodemeta:"..spos..";mailbox]"..
+                       xbg..default.get_hotbar_bg(0.75,5.25)
+       else
+               return [[ size[8,5]
+                       list[current_player;main;0,1.25;8,4;]
+                       tablecolumns[color;text;color;text]
+                       tableoptions[background=#00000000;highlight=#00000000;border=false] ]]
+                       .."table[0,0;3,1;sendform;#FFFFFF,Send your goods to,,,#FFFF00,"..owner.."]"..
+                       "list[nodemeta:"..spos..";drop;3.5,0;1,1;]"..
+                       xbg..default.get_hotbar_bg(0,1.25)
+       end
 end
+