forked from mtcontrib/homedecor_modpack
add locked wall sign, drop-in replacement for the old locked_sign mod
except because they used the old legacy wallmount draw type, you will have to use the screwdriver to rotate these signs after updating.
This commit is contained in:
parent
da3689dbe5
commit
76b0435163
@ -456,7 +456,7 @@ local function set_obj_text(obj, text, new)
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
signs_lib.construct_sign = function(pos)
|
signs_lib.construct_sign = function(pos, locked)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
meta:set_string(
|
meta:set_string(
|
||||||
"formspec",
|
"formspec",
|
||||||
@ -487,14 +487,18 @@ local function make_infotext(text)
|
|||||||
return table.concat(lines2, "\n")
|
return table.concat(lines2, "\n")
|
||||||
end
|
end
|
||||||
|
|
||||||
signs_lib.update_sign = function(pos, fields)
|
signs_lib.update_sign = function(pos, fields, owner)
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
|
|
||||||
local new
|
local new
|
||||||
if fields then
|
if fields then
|
||||||
|
|
||||||
fields.text = trim_input(fields.text)
|
fields.text = trim_input(fields.text)
|
||||||
|
|
||||||
meta:set_string("infotext", make_infotext(fields.text).." ")
|
local ownstr = ""
|
||||||
|
if owner then ownstr = "Locked sign, owned by "..owner.."\n" end
|
||||||
|
|
||||||
|
meta:set_string("infotext", ownstr..make_infotext(fields.text).." ")
|
||||||
meta:set_string("text", fields.text)
|
meta:set_string("text", fields.text)
|
||||||
meta:set_int("__signslib_new_format", 1)
|
meta:set_int("__signslib_new_format", 1)
|
||||||
new = true
|
new = true
|
||||||
@ -615,19 +619,25 @@ function signs_lib.determine_sign_type(itemstack, placer, pointed_thing)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function signs_lib.receive_fields(pos, formname, fields, sender)
|
function signs_lib.receive_fields(pos, formname, fields, sender, lock)
|
||||||
if minetest.is_protected(pos, sender:get_player_name()) then
|
if minetest.is_protected(pos, sender:get_player_name()) then
|
||||||
minetest.record_protection_violation(pos,
|
minetest.record_protection_violation(pos,
|
||||||
sender:get_player_name())
|
sender:get_player_name())
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
lockstr = ""
|
||||||
|
if lock then lockstr = "locked " end
|
||||||
if fields and fields.text and fields.ok then
|
if fields and fields.text and fields.ok then
|
||||||
minetest.log("action", S("%s wrote \"%s\" to sign at %s"):format(
|
minetest.log("action", S("%s wrote \"%s\" to "..lockstr.."sign at %s"):format(
|
||||||
(sender:get_player_name() or ""),
|
(sender:get_player_name() or ""),
|
||||||
fields.text,
|
fields.text,
|
||||||
minetest.pos_to_string(pos)
|
minetest.pos_to_string(pos)
|
||||||
))
|
))
|
||||||
signs_lib.update_sign(pos, fields)
|
if lock then
|
||||||
|
signs_lib.update_sign(pos, fields, sender:get_player_name())
|
||||||
|
else
|
||||||
|
signs_lib.update_sign(pos, fields)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -748,6 +758,60 @@ minetest.register_node(":signs:sign_post", {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- Locked wall sign
|
||||||
|
|
||||||
|
minetest.register_privilege("sign_editor", "Can edit all locked signs")
|
||||||
|
|
||||||
|
minetest.register_node(":locked_sign:sign_wall_locked", {
|
||||||
|
description = S("Sign"),
|
||||||
|
inventory_image = "signs_locked_inv.png",
|
||||||
|
wield_image = "signs_locked_inv.png",
|
||||||
|
node_placement_prediction = "",
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = signs_lib.wall_sign_model.nodebox,
|
||||||
|
tiles = {
|
||||||
|
"signs_top_locked.png",
|
||||||
|
"signs_bottom_locked.png",
|
||||||
|
"signs_side_locked.png",
|
||||||
|
"signs_side.png",
|
||||||
|
"signs_back.png",
|
||||||
|
"signs_front_locked.png"
|
||||||
|
},
|
||||||
|
groups = sign_groups,
|
||||||
|
on_place = function(itemstack, placer, pointed_thing)
|
||||||
|
return signs_lib.determine_sign_type(itemstack, placer, pointed_thing)
|
||||||
|
end,
|
||||||
|
on_construct = function(pos)
|
||||||
|
signs_lib.construct_sign(pos, true)
|
||||||
|
end,
|
||||||
|
on_destruct = function(pos)
|
||||||
|
signs_lib.destruct_sign(pos)
|
||||||
|
end,
|
||||||
|
on_receive_fields = function(pos, formname, fields, sender)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local owner = meta:get_string("owner")
|
||||||
|
local pname = sender:get_player_name() or ""
|
||||||
|
if pname ~= owner and pname ~= minetest.setting_get("name")
|
||||||
|
and not minetest.check_player_privs(pname, {sign_editor=true}) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
signs_lib.receive_fields(pos, formname, fields, sender, true)
|
||||||
|
end,
|
||||||
|
on_punch = function(pos, node, puncher)
|
||||||
|
signs_lib.update_sign(pos)
|
||||||
|
end,
|
||||||
|
can_dig = function(pos, player)
|
||||||
|
local meta = minetest.get_meta(pos)
|
||||||
|
local owner = meta:get_string("owner")
|
||||||
|
local pname = player:get_player_name()
|
||||||
|
return pname == owner or pname == minetest.setting_get("name")
|
||||||
|
or minetest.check_player_privs(pname, {sign_editor=true})
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
-- metal, colored signs
|
-- metal, colored signs
|
||||||
|
|
||||||
local sign_colors = { "green", "yellow", "red", "white_red", "white_black" }
|
local sign_colors = { "green", "yellow", "red", "white_red", "white_black" }
|
||||||
@ -886,6 +950,7 @@ end
|
|||||||
build_char_db()
|
build_char_db()
|
||||||
|
|
||||||
minetest.register_alias("homedecor:fence_wood_with_sign", "signs:sign_post")
|
minetest.register_alias("homedecor:fence_wood_with_sign", "signs:sign_post")
|
||||||
|
minetest.register_alias("sign_wall_locked", "locked_sign:sign_wall_locked")
|
||||||
|
|
||||||
signs_lib.register_fence_with_sign("default:fence_wood", "signs:sign_post")
|
signs_lib.register_fence_with_sign("default:fence_wood", "signs:sign_post")
|
||||||
|
|
||||||
@ -900,6 +965,27 @@ minetest.register_abm({
|
|||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- locked sign
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "locked_sign:sign_wall_locked",
|
||||||
|
recipe = {
|
||||||
|
{"group:wood", "group:wood", "group:wood"},
|
||||||
|
{"group:wood", "group:wood", "default:steel_ingot"},
|
||||||
|
{"", "group:stick", ""},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
--Alternate recipe.
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "locked_sign:sign_wall_locked",
|
||||||
|
recipe = {
|
||||||
|
{"default:sign_wall"},
|
||||||
|
{"default:steel_ingot"},
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
-- craft recipes for the metal signs
|
-- craft recipes for the metal signs
|
||||||
|
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
|
BIN
signs_lib/textures/signs_bottom_locked.png
Normal file
BIN
signs_lib/textures/signs_bottom_locked.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 111 B |
BIN
signs_lib/textures/signs_front_locked.png
Normal file
BIN
signs_lib/textures/signs_front_locked.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 438 B |
BIN
signs_lib/textures/signs_locked_inv.png
Normal file
BIN
signs_lib/textures/signs_locked_inv.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 453 B |
BIN
signs_lib/textures/signs_side_locked.png
Normal file
BIN
signs_lib/textures/signs_side_locked.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 149 B |
BIN
signs_lib/textures/signs_top_locked.png
Normal file
BIN
signs_lib/textures/signs_top_locked.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 119 B |
Loading…
Reference in New Issue
Block a user