From 0211c582e9ce8745e19ff49496b026d393dad074 Mon Sep 17 00:00:00 2001 From: sfence <sfence.software@gmail.com> Date: Mon, 06 Jun 2022 18:53:50 +0200 Subject: [PATCH] Add charge set/get callbacks (#600) --- technic_chests/silver_chest.lua | 172 ++++++++++++-------------------------------------------- 1 files changed, 38 insertions(+), 134 deletions(-) diff --git a/technic_chests/silver_chest.lua b/technic_chests/silver_chest.lua index 176e36f..6e2ce56 100644 --- a/technic_chests/silver_chest.lua +++ b/technic_chests/silver_chest.lua @@ -1,145 +1,49 @@ -minetest.register_craft({ - output = 'technic:silver_chest', - recipe = { - {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, - {'moreores:silver_ingot','technic:copper_chest','moreores:silver_ingot'}, - {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, - } -}) +if minetest.get_modpath("moreores") then + minetest.register_craft({ + output = 'technic:silver_chest', + recipe = { + {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, + {'moreores:silver_ingot','technic:copper_chest','moreores:silver_ingot'}, + {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, + } + }) + + minetest.register_craft({ + output = 'technic:silver_locked_chest', + recipe = { + {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, + {'moreores:silver_ingot','technic:copper_locked_chest','moreores:silver_ingot'}, + {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, + } + }) +end minetest.register_craft({ output = 'technic:silver_locked_chest', + type = "shapeless", recipe = { - {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, - {'moreores:silver_ingot','technic:copper_locked_chest','moreores:silver_ingot'}, - {'moreores:silver_ingot','moreores:silver_ingot','moreores:silver_ingot'}, + 'basic_materials:padlock', + 'technic:silver_chest', } }) -minetest.register_craft({ - output = 'technic:silver_locked_chest', - recipe = { - {'default:steel_ingot'}, - {'technic:silver_chest'}, - } +technic.chests:register("Silver", { + width = 12, + height = 6, + sort = true, + autosort = true, + infotext = true, + color = false, + locked = false, }) -minetest.register_craftitem(":technic:silver_chest", { - description = "Silver Chest", - stack_max = 99, -}) -minetest.register_craftitem(":technic:silver_locked_chest", { - description = "Silver Locked Chest", - stack_max = 99, +technic.chests:register("Silver", { + width = 12, + height = 6, + sort = true, + autosort = true, + infotext = true, + color = false, + locked = true, }) -silver_chest_formspec = - "invsize[11,10;]".. - "list[current_name;main;0,1;11,4;]".. - "list[current_player;main;0,6;8,4;]".. - "background[-0.19,-0.25;11.4,10.75;ui_form_bg.png]".. - "background[0,1;11,4;ui_silver_chest_inventory.png]".. - "background[0,6;8,4;ui_main_inventory.png]" - -minetest.register_node(":technic:silver_chest", { - description = "Silver Chest", - tiles = {"technic_silver_chest_top.png", "technic_silver_chest_top.png", "technic_silver_chest_side.png", - "technic_silver_chest_side.png", "technic_silver_chest_side.png", "technic_silver_chest_front.png"}, - paramtype2 = "facedir", - groups = chest_groups1, - tube = tubes_properties, - legacy_facedir_simple = true, - sounds = default.node_sound_wood_defaults(), - on_construct = function(pos) - local meta = minetest.env:get_meta(pos) - meta:set_string("formspec", - silver_chest_formspec.. - "label[0,0;Silver Chest]".. - "image_button[3.5,.1;.6,.6;pencil_icon.png;edit_infotext;]") - meta:set_string("infotext", "Silver Chest") - local inv = meta:get_inventory() - inv:set_size("main", 11*4) - end, - can_dig = chest_can_dig, - - on_receive_fields = function(pos, formname, fields, sender) - local meta = minetest.env:get_meta(pos) - local page="main" - if fields.edit_infotext then - page="edit_infotext" - end - if fields.save_infotext then - meta:set_string("infotext",fields.infotext_box) - end - local formspec = silver_chest_formspec.."label[0,0;Silver Chest]" - if page=="main" then - formspec = formspec.."image_button[3.5,.1;.6,.6;pencil_icon.png;edit_infotext;]" - formspec = formspec.."label[4,0;"..meta:get_string("infotext").."]" - end - if page=="edit_infotext" then - formspec = formspec.."image_button[3.5,.1;.6,.6;ok_icon.png;save_infotext;]" - formspec = formspec.."field[4.3,.2;6,1;infotext_box;Edit chest description:;"..meta:get_string("infotext").."]" - end - meta:set_string("formspec",formspec) - end, - - on_metadata_inventory_move = def_on_metadata_inventory_move, - on_metadata_inventory_put = def_on_metadata_inventory_put, - on_metadata_inventory_take = def_on_metadata_inventory_take -}) - -minetest.register_node(":technic:silver_locked_chest", { - description = "Silver Locked Chest", - tiles = {"technic_silver_chest_top.png", "technic_silver_chest_top.png", "technic_silver_chest_side.png", - "technic_silver_chest_side.png", "technic_silver_chest_side.png", "technic_silver_chest_locked.png"}, - paramtype2 = "facedir", - groups = chest_groups1, - tube = tubes_properties, - legacy_facedir_simple = true, - sounds = default.node_sound_wood_defaults(), - after_place_node = function(pos, placer) - local meta = minetest.env:get_meta(pos) - meta:set_string("owner", placer:get_player_name() or "") - meta:set_string("infotext", "Silver Locked Chest (owned by ".. - meta:get_string("owner")..")") - end, - on_construct = function(pos) - local meta = minetest.env:get_meta(pos) - meta:set_string("formspec", - silver_chest_formspec.. - "label[0,0;Silver Locked Chest]".. - "image_button[3.5,.1;.6,.6;pencil_icon.png;edit_infotext;]") - meta:set_string("owner", "") - local inv = meta:get_inventory() - inv:set_size("main", 11*4) - end, - can_dig = chest_can_dig, - - on_receive_fields = function(pos, formname, fields, sender) - local meta = minetest.env:get_meta(pos) - local page="main" - if fields.edit_infotext then - page="edit_infotext" - end - if fields.save_infotext then - meta:set_string("infotext",fields.infotext_box) - end - local formspec = silver_chest_formspec.."label[0,0;Silver Locked Chest]" - if page=="main" then - formspec = formspec.."image_button[3.5,.1;.6,.6;pencil_icon.png;edit_infotext;]" - formspec = formspec.."label[4,0;"..meta:get_string("infotext").."]" - end - if page=="edit_infotext" then - formspec = formspec.."image_button[3.5,.1;.6,.6;ok_icon.png;save_infotext;]" - formspec = formspec.."field[4.3,.2;6,1;infotext_box;Edit chest description:;"..meta:get_string("infotext").."]" - end - meta:set_string("formspec",formspec) - end, - - allow_metadata_inventory_move = def_allow_metadata_inventory_move, - allow_metadata_inventory_put = def_allow_metadata_inventory_put, - allow_metadata_inventory_take = def_allow_metadata_inventory_take, - on_metadata_inventory_move = def_on_metadata_inventory_move, - on_metadata_inventory_put = def_on_metadata_inventory_put, - on_metadata_inventory_take = def_on_metadata_inventory_take -}) -- Gitblit v1.8.0