forked from minetest-mods/more_chests
Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
cac8cddc66 | |||
f7cfee874a | |||
058b3a0d4b | |||
426a13089c | |||
1d59b74c89 | |||
74b3c5a25d | |||
939c7ea73d | |||
9666707470 | |||
1d7edabfc3 |
@ -1,3 +1,6 @@
|
||||
-- Load support for translation.
|
||||
local S = minetest.get_translator("more_chests")
|
||||
|
||||
local function has_locked_chest_privilege(meta, player)
|
||||
if player:get_player_name() ~= meta:get_string("owner") then
|
||||
return false
|
||||
@ -6,7 +9,7 @@ local function has_locked_chest_privilege(meta, player)
|
||||
end
|
||||
|
||||
minetest.register_node("more_chests:cobble", {
|
||||
description = "Cobble Chest",
|
||||
description = S("Cobble Chest"),
|
||||
tiles = {"default_cobble.png", "default_cobble.png", "default_cobble.png",
|
||||
"default_cobble.png", "default_cobble.png", "cobblechest_front.png"},
|
||||
paramtype2 = "facedir",
|
||||
@ -110,4 +113,3 @@ minetest.register_craft({
|
||||
{'default:wood','default:cobble','default:wood'}
|
||||
}
|
||||
})
|
||||
|
||||
|
@ -1 +0,0 @@
|
||||
default
|
@ -1 +0,0 @@
|
||||
Adds several chests that behave differently, and can be used to donate items, share items, hide chests, make secret chests, and more.
|
14
dropbox.lua
14
dropbox.lua
@ -1,3 +1,7 @@
|
||||
-- Load support for translation.
|
||||
local S = minetest.get_translator("more_chests")
|
||||
local DS = minetest.get_translator("default")
|
||||
|
||||
local function has_locked_chest_privilege(meta, player)
|
||||
if player:get_player_name() ~= meta:get_string("owner") then
|
||||
return false
|
||||
@ -6,7 +10,7 @@ local function has_locked_chest_privilege(meta, player)
|
||||
end
|
||||
|
||||
minetest.register_node("more_chests:dropbox", {
|
||||
description = "Dropbox",
|
||||
description = S("Dropbox"),
|
||||
tiles = {"dropbox_top.png", "dropbox_top.png", "dropbox_side.png",
|
||||
"dropbox_side.png", "dropbox_side.png", "dropbox_front.png"},
|
||||
paramtype2 = "facedir",
|
||||
@ -31,8 +35,9 @@ minetest.register_node("more_chests:dropbox", {
|
||||
after_place_node = function(pos, placer)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("owner", placer:get_player_name() or "")
|
||||
meta:set_string("infotext", "Dropbox (owned by "..
|
||||
meta:get_string("owner")..")")
|
||||
meta:set_string("infotext", S("@1 (owned by @2)",
|
||||
S("Dropbox"),
|
||||
meta:get_string("owner")))
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
@ -47,7 +52,7 @@ minetest.register_node("more_chests:dropbox", {
|
||||
"listring[current_name;main]" ..
|
||||
"listring[current_player;main]" ..
|
||||
default.get_hotbar_bg(0,4.85))
|
||||
meta:set_string("infotext", "Chest")
|
||||
meta:set_string("infotext", DS("Chest"))
|
||||
local inv = meta:get_inventory()
|
||||
inv:set_size("main", 8*4)
|
||||
end,
|
||||
@ -106,4 +111,3 @@ minetest.register_craft({
|
||||
{'default:wood','default:wood','default:wood'}
|
||||
}
|
||||
})
|
||||
|
||||
|
11
locale/more_chests.fr.tr
Normal file
11
locale/more_chests.fr.tr
Normal file
@ -0,0 +1,11 @@
|
||||
# textdomain: more_chests
|
||||
Cobble Chest=Coffre en pierre taillée
|
||||
Dropbox=Boîte de dépôt
|
||||
Secret Chest=Coffre secret
|
||||
Shared Chest=Coffre partagé
|
||||
Wifi Chest=Coffre wifi
|
||||
|
||||
|
||||
@1 (owned by @2)=@1 (appartient à @2)
|
||||
Shared with (separate names with spaces)=Partagé avec (séparez les noms avec des espaces)
|
||||
submit=valider
|
12
locale/more_chests.hu.tr
Normal file
12
locale/more_chests.hu.tr
Normal file
@ -0,0 +1,12 @@
|
||||
# textdomain: more_chests
|
||||
|
||||
# Translation by An0n3m0us
|
||||
|
||||
Secret Chest=Titkos Láda
|
||||
Wifi Chest=Wifi Láda
|
||||
Cobble Chest=Zúzottkő Láda
|
||||
Shared Chest=Közös Láda
|
||||
|
||||
@1 (owned by @2)=@1 (@2 tulajdonában van)
|
||||
Shared with (separate names with spaces)=Megosztva (válassza el a neveket szóközökkel)
|
||||
submit=előterjeszt
|
6
locale/template.txt
Normal file
6
locale/template.txt
Normal file
@ -0,0 +1,6 @@
|
||||
# textdomain: more_chests
|
||||
Secret Chest=
|
||||
Wifi Chest=
|
||||
Cobble Chest=
|
||||
Shared Chest=
|
||||
Dropbox=
|
3
mod.conf
3
mod.conf
@ -1 +1,4 @@
|
||||
name = more_chests
|
||||
description = Adds several chests that behave differently, and can be used to donate items, share items, hide chests, make secret chests, and more.
|
||||
depends = default
|
||||
optional_depends = pipeworks
|
||||
|
13
secret.lua
13
secret.lua
@ -1,3 +1,6 @@
|
||||
-- Load support for translation.
|
||||
local S = minetest.get_translator("more_chests")
|
||||
|
||||
local function has_locked_chest_privilege(meta, player)
|
||||
if player:get_player_name() ~= meta:get_string("owner") then
|
||||
return false
|
||||
@ -20,7 +23,7 @@ local closed = "size[2,1]"..
|
||||
"button[0,0;2,1;open;open]"
|
||||
|
||||
minetest.register_node("more_chests:secret", {
|
||||
description = "Secret Chest",
|
||||
description = S("Secret Chest"),
|
||||
tiles = {"secret_top.png", "secret_top.png", "secret_side.png",
|
||||
"secret_side.png", "secret_side.png", "secret_front.png"},
|
||||
paramtype2 = "facedir",
|
||||
@ -45,13 +48,14 @@ minetest.register_node("more_chests:secret", {
|
||||
after_place_node = function(pos, placer)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("owner", placer:get_player_name() or "")
|
||||
meta:set_string("infotext", "Secret Chest (owned by "..
|
||||
meta:get_string("owner")..")")
|
||||
meta:set_string("infotext", S("@1 (owned by @2)",
|
||||
S("Secret Chest"),
|
||||
meta:get_string("owner")))
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("formspec", open)
|
||||
meta:set_string("infotext", "Secret Chest")
|
||||
meta:set_string("infotext", S("Secret Chest"))
|
||||
meta:set_string("owner", "")
|
||||
local inv = meta:get_inventory()
|
||||
inv:set_size("main", 8*4)
|
||||
@ -126,4 +130,3 @@ minetest.register_craft({
|
||||
{'default:wood','default:wood','default:wood'}
|
||||
}
|
||||
})
|
||||
|
||||
|
17
shared.lua
17
shared.lua
@ -1,3 +1,6 @@
|
||||
-- Load support for translation.
|
||||
local S = minetest.get_translator("more_chests")
|
||||
|
||||
local function has_locked_chest_privilege(meta, player)
|
||||
local name = player:get_player_name()
|
||||
local shared = " "..meta:get_string("shared").." "
|
||||
@ -19,15 +22,15 @@ local function get_formspec(string)
|
||||
"list[current_name;main;0,0.3;8,4;]"..
|
||||
"list[current_player;main;0,4.85;8,1;]" ..
|
||||
"list[current_player;main;0,6;8,3;8]" ..
|
||||
"field[.25,9.5;6,1;shared;Shared with (separate names with spaces):;"..string.."]"..
|
||||
"button[6,9.2;2,1;submit;submit]" ..
|
||||
"field[.25,9.5;8,1;shared;"..S("Shared with (separate names with spaces)")..":;"..string.."]"..
|
||||
"button[6,9.2;2,1;submit;"..S("submit").."]" ..
|
||||
"listring[current_name;main]" ..
|
||||
"listring[current_player;main]" ..
|
||||
default.get_hotbar_bg(0,4.85)
|
||||
end
|
||||
|
||||
minetest.register_node("more_chests:shared", {
|
||||
description = "Shared Chest",
|
||||
description = S("Shared Chest"),
|
||||
tiles = {"shared_top.png", "shared_top.png", "shared_side.png",
|
||||
"shared_side.png", "shared_side.png", "shared_front.png"},
|
||||
paramtype2 = "facedir",
|
||||
@ -52,13 +55,14 @@ minetest.register_node("more_chests:shared", {
|
||||
after_place_node = function(pos, placer)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("owner", placer:get_player_name() or "")
|
||||
meta:set_string("infotext", "Shared Chest (owned by "..
|
||||
meta:get_string("owner")..")")
|
||||
meta:set_string("infotext", S("@1 (owned by @2)",
|
||||
S("Shared Chest"),
|
||||
meta:get_string("owner")))
|
||||
end,
|
||||
on_construct = function(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("formspec", get_formspec(""))
|
||||
meta:set_string("infotext", "Shared Chest")
|
||||
meta:set_string("infotext", S("Shared Chest"))
|
||||
meta:set_string("owner", "")
|
||||
local inv = meta:get_inventory()
|
||||
inv:set_size("main", 8*4)
|
||||
@ -132,4 +136,3 @@ minetest.register_craft({
|
||||
{'default:wood','default:wood','default:wood'}
|
||||
}
|
||||
})
|
||||
|
||||
|
Binary file not shown.
Before Width: | Height: | Size: 864 B |
BIN
textures/wifi_front_animated.png
Normal file
BIN
textures/wifi_front_animated.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 462 B |
Binary file not shown.
Before Width: | Height: | Size: 833 B After Width: | Height: | Size: 244 B |
Binary file not shown.
Before Width: | Height: | Size: 741 B After Width: | Height: | Size: 239 B |
55
wifi.lua
55
wifi.lua
@ -1,9 +1,55 @@
|
||||
-- Load support for translation.
|
||||
local S = minetest.get_translator("more_chests")
|
||||
|
||||
local pipeworks_enabled = minetest.global_exists("pipeworks")
|
||||
|
||||
minetest.register_node("more_chests:wifi", {
|
||||
description = "Wifi Chest",
|
||||
description = S("Wifi Chest"),
|
||||
tiles = {"wifi_top.png", "wifi_top.png", "wifi_side.png",
|
||||
"wifi_side.png", "wifi_side.png", "wifi_front.png"},
|
||||
"wifi_side.png", "wifi_side.png",
|
||||
{name="wifi_front_animated.png", animation={type="vertical_frames",
|
||||
aspect_w=16, aspect_h=16, length=2.0}}},
|
||||
paramtype2 = "facedir",
|
||||
groups = {snappy=2, choppy=2, oddly_breakable_by_hand=2,},
|
||||
groups = {snappy=2, choppy=2, oddly_breakable_by_hand=2, tubedevice = 1, tubedevice_receiver = 1},
|
||||
-- Pipeworks
|
||||
tube = pipeworks_enabled and {
|
||||
insert_object = function(pos, node, stack, direction, owner)
|
||||
if not owner then
|
||||
return stack
|
||||
end
|
||||
local player = minetest.get_player_by_name(owner)
|
||||
if not player then
|
||||
return stack
|
||||
end
|
||||
local inv = player:get_inventory()
|
||||
return inv:add_item("more_chests:wifi", stack)
|
||||
end,
|
||||
can_insert = function(pos, node, stack, direction, owner)
|
||||
if not owner then
|
||||
return false
|
||||
end
|
||||
local player = minetest.get_player_by_name(owner)
|
||||
if not player then
|
||||
return false
|
||||
end
|
||||
local inv = player:get_inventory()
|
||||
return inv:room_for_item("more_chests:wifi", stack)
|
||||
end,
|
||||
input_inventory = "more_chests:wifi",
|
||||
return_input_invref = function(pos, node, direction, player_name)
|
||||
if not player_name then
|
||||
return false
|
||||
end
|
||||
local player = minetest.get_player_by_name(player_name)
|
||||
if not player then
|
||||
return false
|
||||
end
|
||||
return player:get_inventory()
|
||||
end,
|
||||
connect_sides = {left = 1, right = 1, back = 1, front = 1, bottom = 1, top = 1}
|
||||
} or nil,
|
||||
after_place_node = pipeworks_enabled and pipeworks.after_place or nil,
|
||||
after_dig_node = pipeworks_enabled and pipeworks.after_dig or nil,
|
||||
legacy_facedir_simple = true,
|
||||
sounds = default.node_sound_wood_defaults(),
|
||||
on_construct = function(pos)
|
||||
@ -20,7 +66,7 @@ minetest.register_node("more_chests:wifi", {
|
||||
"listring[current_player;main]" ..
|
||||
default.get_hotbar_bg(0,4.85))
|
||||
|
||||
meta:set_string("infotext", "Wifi Chest")
|
||||
meta:set_string("infotext", S("Wifi Chest"))
|
||||
end,
|
||||
on_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player)
|
||||
minetest.log("action", player:get_player_name()..
|
||||
@ -49,4 +95,3 @@ minetest.register_on_joinplayer(function(player)
|
||||
local inv = player:get_inventory()
|
||||
inv:set_size("more_chests:wifi", 8*4)
|
||||
end)
|
||||
|
||||
|
Reference in New Issue
Block a user