Remove old workshops
parent
8ce6da5c07
commit
0838bdd981
2
init.lua
2
init.lua
|
@ -31,14 +31,12 @@ dofile(streets.conf.modpath .. "/global.lua")
|
|||
-- Load mod files
|
||||
streets.load_submod("streets_roadsurface")
|
||||
streets.load_submod("streets_roadmarkings")
|
||||
streets.load_submod("streets_asphaltworkshop")
|
||||
streets.load_submod("streets_installations")
|
||||
streets.load_submod("streets_accessories")
|
||||
streets.load_submod("streets_concrete")
|
||||
streets.load_submod("streets_poles")
|
||||
streets.load_submod("streets_rrxing")
|
||||
streets.load_submod("streets_signs")
|
||||
streets.load_submod("streets_signworkshop")
|
||||
streets.load_submod("streets_steelsupport")
|
||||
streets.load_submod("streets_roadwork")
|
||||
streets.load_submod("streets_bollards")
|
||||
|
|
|
@ -1,307 +0,0 @@
|
|||
--[[
|
||||
## StreetsMod 2.0 ##
|
||||
Submod: asphaltworkshop
|
||||
Optional: true
|
||||
]]
|
||||
|
||||
streets.asphaltworkshop = {}
|
||||
|
||||
function streets.asphaltworkshop.start(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:asphalt_workshop" then
|
||||
return
|
||||
end
|
||||
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local template = inv:get_stack("template", 1):get_name()
|
||||
local steel = inv:get_stack("steel", 1):get_name()
|
||||
local yellow_needed = inv:get_stack("yellow_needed", 1):get_count()
|
||||
local white_needed = inv:get_stack("white_needed", 1):get_count()
|
||||
local yellow_ok = inv:get_stack("yellow_dye", 1):get_count() >= yellow_needed
|
||||
local white_ok = inv:get_stack("white_dye", 1):get_count() >= white_needed
|
||||
|
||||
if not (yellow_ok and white_ok and steel and steel == "default:steel_ingot" and template and template ~= "") then
|
||||
return
|
||||
end
|
||||
|
||||
if not inv:room_for_item("output", { name = template, count = 1 }) then
|
||||
return
|
||||
end
|
||||
|
||||
meta:set_string("working_on", template)
|
||||
meta:set_int("progress", 0)
|
||||
inv:remove_item("yellow_dye", { name = "dye:yellow", count = yellow_needed })
|
||||
inv:remove_item("white_dye", { name = "dye:white", count = white_needed })
|
||||
inv:remove_item("steel", { name = "default:steel_ingot", count = 1 })
|
||||
streets.asphaltworkshop.step(pos)
|
||||
end
|
||||
|
||||
function streets.asphaltworkshop.step(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:asphalt_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
if meta:get_string("working_on") == "" then
|
||||
return
|
||||
end
|
||||
local inv = meta:get_inventory()
|
||||
local progress = meta:get_int("progress")
|
||||
progress = progress + 1
|
||||
if progress < 10 then
|
||||
minetest.after(0.2, streets.asphaltworkshop.step, pos)
|
||||
else
|
||||
meta:set_int("progress", 0)
|
||||
progress = 0
|
||||
inv:add_item("output", meta:get_string("working_on"))
|
||||
meta:set_string("working_on", "")
|
||||
streets.asphaltworkshop.start(pos)
|
||||
end
|
||||
meta:set_int("progress", progress)
|
||||
streets.asphaltworkshop.update_formspec(pos)
|
||||
end
|
||||
|
||||
function streets.asphaltworkshop.update_formspec(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:asphalt_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
local fs = "size[9,10;]"
|
||||
fs = fs .. "tabheader[0,0;tabs;"
|
||||
for k, v in pairs(streets.labels.sections) do
|
||||
fs = fs .. minetest.formspec_escape(v.friendlyname) .. ","
|
||||
end
|
||||
fs = fs:sub(1, -2) --Strip trailing comma
|
||||
fs = fs .. ";" .. meta:get_int("section") .. ";false;true]"
|
||||
fs = fs .. "label[0,-0.25;Select Color]"
|
||||
fs = fs .. "image_button[0,0.25;1,1;dye_white.png;color_white;]"
|
||||
fs = fs .. "image_button[1,0.25;1,1;dye_yellow.png;color_yellow;]"
|
||||
fs = fs .. "label[0,1.25;Dye Input]"
|
||||
fs = fs .. "list[context;white_dye;0,1.75;1,1]"
|
||||
fs = fs .. "list[context;yellow_dye;1,1.75;1,1]"
|
||||
fs = fs .. "label[0,2.75;Dye Required]"
|
||||
fs = fs .. "list[context;white_needed;0,3.25;1,1]"
|
||||
fs = fs .. "list[context;yellow_needed;1,3.25;1,1]"
|
||||
fs = fs .. "label[2,-0.25;Rotation]"
|
||||
fs = fs .. "button[2,0.25;1,1;r0;R0]"
|
||||
fs = fs .. "button[2,1.25;1,1;r90;R90]"
|
||||
fs = fs .. "button[2,2.25;1,1;r180;R180]"
|
||||
fs = fs .. "button[2,3.25;1,1;r270;R270]"
|
||||
fs = fs .. "list[context;list;3,0;4,4]"
|
||||
fs = fs .. "label[7,0.5;Steel ingot]"
|
||||
fs = fs .. "label[8,0.5;Template]"
|
||||
fs = fs .. "list[context;steel;7,1;1,1]"
|
||||
fs = fs .. "list[context;template;8,1;1,1]"
|
||||
fs = fs .. "image[7.5,2;1,1;gui_furnace_arrow_bg.png^[lowpart:" .. meta:get_int("progress") * 10 .. ":gui_furnace_arrow_fg.png^[transformR180]"
|
||||
fs = fs .. "list[context;output;7.5,3;1,1]"
|
||||
fs = fs .. "label[0,5;" .. minetest.colorize("#dd0000", "THIS WORKSHOP IS DEPRECATED!\nPlease switch to the new \"Streets Workshop\" for better usability and cheaper crafting.") .. "]"
|
||||
fs = fs .. "list[current_player;main;0.5,6;8,4]"
|
||||
if minetest.setting_getbool("creative_mode") then
|
||||
fs = fs .. "label[2,4;CREATIVE MODE: Taking templates is enabled]"
|
||||
end
|
||||
meta:set_string("formspec", fs)
|
||||
end
|
||||
|
||||
local function update_inventory(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:asphalt_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
inv:set_size("white_dye", 1)
|
||||
inv:set_size("yellow_dye", 1)
|
||||
inv:set_size("white_needed", 0)
|
||||
inv:set_size("yellow_needed", 0)
|
||||
inv:set_size("list", 0)
|
||||
inv:set_size("white_needed", 1)
|
||||
inv:set_size("yellow_needed", 1)
|
||||
inv:set_size("list", 16) -- 4x4
|
||||
inv:set_size("steel", 1)
|
||||
inv:set_size("template", 1)
|
||||
inv:set_size("output", 1)
|
||||
|
||||
local color = meta:get_string("color")
|
||||
local section = meta:get_int("section")
|
||||
local rotation = meta:get_string("rotation")
|
||||
local sectionname = streets.labels.sections[section].name
|
||||
for k, v in pairs(streets.labels.labeltypes) do
|
||||
if v.section == sectionname then
|
||||
if v.rotation then
|
||||
if v.rotation.r90 and rotation == "r90" then
|
||||
inv:add_item("list", "streets:tool_" .. v.name:gsub("{color}", color:lower()) .. "_r90")
|
||||
elseif v.rotation.r180 and rotation == "r180" then
|
||||
inv:add_item("list", "streets:tool_" .. v.name:gsub("{color}", color:lower()) .. "_r180")
|
||||
elseif v.rotation.r270 and rotation == "r270" then
|
||||
inv:add_item("list", "streets:tool_" .. v.name:gsub("{color}", color:lower()) .. "_r270")
|
||||
end
|
||||
end
|
||||
if rotation == "r0" then
|
||||
inv:add_item("list", "streets:tool_" .. v.name:gsub("{color}", color:lower()))
|
||||
end
|
||||
end
|
||||
end
|
||||
local templatestack = inv:get_stack("template", 1)
|
||||
local markingcolor = ""
|
||||
if templatestack and templatestack:to_string() ~= "" then
|
||||
local selectedmarking = templatestack:to_table().name:sub(14)
|
||||
if selectedmarking:find("white") then
|
||||
markingcolor = "white"
|
||||
elseif selectedmarking:find("yellow") then
|
||||
markingcolor = "yellow"
|
||||
end
|
||||
selectedmarking = selectedmarking:gsub("white", "{color}")
|
||||
selectedmarking = selectedmarking:gsub("yellow", "{color}")
|
||||
selectedmarking = selectedmarking:gsub("_r90", "")
|
||||
selectedmarking = selectedmarking:gsub("_r180", "")
|
||||
selectedmarking = selectedmarking:gsub("_r270", "")
|
||||
local dyesneeded = streets.labels.labeltypes[selectedmarking].dye_needed
|
||||
if markingcolor == "white" then
|
||||
inv:add_item("white_needed", { name = "dye:white", count = dyesneeded })
|
||||
end
|
||||
if markingcolor == "yellow" then
|
||||
inv:add_item("yellow_needed", { name = "dye:yellow", count = dyesneeded })
|
||||
end
|
||||
end
|
||||
streets.asphaltworkshop.update_formspec(pos)
|
||||
streets.asphaltworkshop.start(pos)
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, sender)
|
||||
local meta = minetest.get_meta(pos)
|
||||
if fields.tabs then
|
||||
meta:set_int("section", fields.tabs)
|
||||
elseif fields.color_white then
|
||||
meta:set_string("color", "white")
|
||||
elseif fields.color_yellow then
|
||||
meta:set_string("color", "yellow")
|
||||
elseif fields.r0 then
|
||||
meta:set_string("rotation", "r0")
|
||||
elseif fields.r90 then
|
||||
meta:set_string("rotation", "r90")
|
||||
elseif fields.r180 then
|
||||
meta:set_string("rotation", "r180")
|
||||
elseif fields.r270 then
|
||||
meta:set_string("rotation", "r270")
|
||||
end
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_construct(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_int("section", 1)
|
||||
meta:set_string("color", "white")
|
||||
meta:set_string("rotation", "r0")
|
||||
meta:set_int("progress", 0)
|
||||
meta:set_string("working_on", "")
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_take(pos, listname, index, stack, player)
|
||||
if listname == "output" or listname == "steel" or listname == "white_dye" or listname == "yellow_dye" or (listname == "list" and minetest.setting_getbool("creative_mode")) then
|
||||
return stack:get_count()
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
||||
if from_list == "list" and to_list == "template" then
|
||||
return 1
|
||||
elseif from_list == "template" and to_list == "list" then
|
||||
local inv = minetest.get_meta(pos):get_inventory()
|
||||
return 1
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_put(pos, listname, index, stack, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_take(pos, listname, index, stack, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_put(pos, listname, index, stack, player)
|
||||
if listname == "yellow_dye" or listname == "white_dye" or (listname == "list" and minetest.setting_getbool("creative_mode")) then
|
||||
return stack:get_count()
|
||||
elseif listname == "steel" and (stack:get_name() == "default:steel_ingot") then
|
||||
return stack:get_count()
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function can_dig(pos, player)
|
||||
local inv = minetest.get_meta(pos):get_inventory()
|
||||
if inv:is_empty("yellow_dye") and inv:is_empty("white_dye") and inv:is_empty("steel") and inv:is_empty("output") then
|
||||
return true
|
||||
else
|
||||
return false
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_node(":streets:asphalt_workshop", {
|
||||
description = "Asphalt Workshop",
|
||||
tiles = {
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
"default_steel_block.png^(streets_asphalt.png^[opacity:200)",
|
||||
},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
groups = { cracky = 1 },
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
{ -0.4375, 0.375, -0.1875, 0.4375, 0.4375, -0.125 }, -- rail
|
||||
{ -0.125, 0.3125, -0.25, -0.0625, 0.375, -0.0625 }, -- sprayer
|
||||
{ -0.5, -0.5, -0.5, -0.4375, 0.5, 0.5 }, -- sideL
|
||||
{ 0.4375, -0.5, -0.5, 0.5, 0.5, 0.5 }, -- sideR
|
||||
{ -0.4375, 0.3125, -0.5, -0.375, 0.375, 0.5 }, -- railLB
|
||||
{ -0.4375, 0.4375, -0.5, -0.375, 0.5, 0.5 }, -- railLT
|
||||
{ -0.4375, 0.375, -0.5, -0.375, 0.4375, -0.4375 }, -- railLF
|
||||
{ -0.4375, -0.5, 0.4375, 0.4375, 0.5, 0.5 }, -- sideR
|
||||
{ 0.375, 0.3125, -0.5, 0.4375, 0.375, 0.5 }, -- railRB
|
||||
{ 0.375, 0.4375, -0.5, 0.4375, 0.5, 0.5 }, -- railRT
|
||||
{ 0.375, 0.375, -0.5, 0.4375, 0.4375, -0.4375 }, -- railRF
|
||||
{ -0.4375, 0.375, 0.375, -0.375, 0.4375, 0.4375 }, -- railLB
|
||||
{ 0.375, 0.3125, 0.375, 0.4375, 0.375, 0.4375 }, -- railRB
|
||||
{ -0.5, -0.5, -0.5, -0.375, 0.3125, 0.4375 }, -- sideL2
|
||||
{ 0.375, -0.5, -0.5, 0.4375, 0.3125, 0.4375 }, -- sideR2
|
||||
{ -0.4375, -0.5, -0.4375, 0.4375, -0.1875, 0.4375 }, -- body
|
||||
}
|
||||
},
|
||||
selection_box = {
|
||||
type = "regular"
|
||||
},
|
||||
on_receive_fields = on_receive_fields,
|
||||
on_construct = on_construct,
|
||||
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
||||
allow_metadata_inventory_move = allow_metadata_inventory_move,
|
||||
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
||||
on_metadata_inventory_move = on_metadata_inventory_move,
|
||||
on_metadata_inventory_put = on_metadata_inventory_put,
|
||||
on_metadata_inventory_take = on_metadata_inventory_take,
|
||||
can_dig = can_dig,
|
||||
})
|
||||
|
||||
minetest.register_lbm({
|
||||
name = "streets:update_asphalt_workshop",
|
||||
nodenames = { "streets:asphalt_workshop" },
|
||||
action = function(pos, node)
|
||||
update_inventory(pos)
|
||||
end,
|
||||
})
|
|
@ -1,300 +0,0 @@
|
|||
--[[
|
||||
## StreetsMod 2.0 ##
|
||||
Submod: signworkshop
|
||||
Optional: true
|
||||
]]
|
||||
|
||||
streets.signworkshop = {}
|
||||
|
||||
function streets.signworkshop.start(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:sign_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local template = inv:get_stack("template", 1):get_name()
|
||||
if not (template and template ~= "") then
|
||||
return
|
||||
end
|
||||
local surface = inv:get_stack("surface", 1):get_name()
|
||||
if not (surface and surface ~= "") then
|
||||
return
|
||||
end
|
||||
local dyes_needed = streets.signs.signtypes[template].dye_needed
|
||||
if not (dyes_needed) then
|
||||
return
|
||||
end
|
||||
local dye_level_ok = true
|
||||
for k, v in pairs(dyes_needed) do
|
||||
dye_level_ok = dye_level_ok and inv:contains_item("dye", { name = "dye:" .. k, count = v })
|
||||
end
|
||||
if not dye_level_ok then
|
||||
return
|
||||
end
|
||||
if not inv:room_for_item("output", { name = template, count = 1 }) then
|
||||
return
|
||||
end
|
||||
meta:set_string("working_on", template)
|
||||
meta:set_int("progress", 0)
|
||||
inv:remove_item("surface", { name = inv:get_stack("surface", 1):get_name(), count = 1 })
|
||||
for k, v in pairs(dyes_needed) do
|
||||
inv:remove_item("dye", { name = "dye:" .. k, count = v })
|
||||
end
|
||||
streets.signworkshop.step(pos)
|
||||
end
|
||||
|
||||
function streets.signworkshop.step(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:sign_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
if meta:get_string("working_on") == "" then
|
||||
return
|
||||
end
|
||||
local inv = meta:get_inventory()
|
||||
local progress = meta:get_int("progress")
|
||||
progress = progress + 1
|
||||
if progress < 10 then
|
||||
minetest.after(0.2, streets.signworkshop.step, pos)
|
||||
else
|
||||
meta:set_int("progress", 0)
|
||||
progress = 0
|
||||
inv:add_item("output", meta:get_string("working_on"))
|
||||
meta:set_string("working_on", "")
|
||||
streets.signworkshop.start(pos)
|
||||
end
|
||||
meta:set_int("progress", progress)
|
||||
streets.signworkshop.update_formspec(pos)
|
||||
end
|
||||
|
||||
function streets.signworkshop.update_formspec(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:sign_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
local page = meta:get_int("page")
|
||||
local maxpage = meta:get_int("maxpage")
|
||||
if page < 1 then
|
||||
page = maxpage
|
||||
elseif page > maxpage then
|
||||
page = 1
|
||||
end
|
||||
meta:set_int("page", page)
|
||||
local fs = "size[9,10;]"
|
||||
fs = fs .. "tabheader[0,0;tabs;"
|
||||
fs = fs .. minetest.formspec_escape("Dye Storage") .. ","
|
||||
fs = fs .. minetest.formspec_escape("Select Section") .. ","
|
||||
fs = fs .. minetest.formspec_escape("Craft Signs") .. ";"
|
||||
fs = fs .. meta:get_int("tab") .. ";false;true]"
|
||||
if meta:get_int("tab") == 1 then
|
||||
fs = fs .. "list[context;dye;0,0;8,6]"
|
||||
fs = fs .. "listring[context;dye]"
|
||||
fs = fs .. "listring[current_player;main]"
|
||||
elseif meta:get_int("tab") == 2 then
|
||||
local x_pos = 0.5
|
||||
local y_pos = 0
|
||||
for k, v in pairs(streets.signs.sections) do
|
||||
fs = fs .. "button[" .. x_pos .. "," .. y_pos .. ";2.5,1;"
|
||||
fs = fs .. minetest.formspec_escape(v.name) .. ";"
|
||||
fs = fs .. minetest.formspec_escape(v.friendlyname) .. "]"
|
||||
y_pos = y_pos + 0.8
|
||||
if y_pos > 4 then
|
||||
y_pos = 0
|
||||
x_pos = x_pos + 2.5
|
||||
end
|
||||
end
|
||||
elseif meta:get_int("tab") == 3 then
|
||||
fs = fs .. "label[0,0;Dyes Needed]"
|
||||
fs = fs .. "list[context;dye_needed;0,0.5;2,3]"
|
||||
fs = fs .. "list[context;list;2.25,0;4,4;" .. tostring((page - 1) * 16) .. "]" --Each page is a 4x4 grid (16 items)
|
||||
fs = fs .. "label[6.5,0.5;Blank Sign]"
|
||||
fs = fs .. "label[7.5,0.5;Template]"
|
||||
fs = fs .. "list[context;surface;6.5,1;1,1]"
|
||||
fs = fs .. "list[context;template;7.5,1;1,1]"
|
||||
fs = fs .. "image[7,2;1,1;gui_furnace_arrow_bg.png^[lowpart:" .. meta:get_int("progress") * 10 .. ":gui_furnace_arrow_fg.png^[transformR180]"
|
||||
fs = fs .. "list[context;output;7,3;1,1]"
|
||||
fs = fs .. "button[2.25,4;1,1;prevpage;<-]"
|
||||
fs = fs .. "button[5.25,4;1,1;nextpage;->]"
|
||||
fs = fs .. "label[3.75,4;" .. string.format("Page %s of %s", page, maxpage) .. "]"
|
||||
if minetest.setting_getbool("creative_mode") then
|
||||
fs = fs .. "label[0,3.5;CREATIVE MODE\nTaking templates\nis enabled]"
|
||||
end
|
||||
end
|
||||
fs = fs .. "label[0,5;" .. minetest.colorize("#dd0000", "THIS WORKSHOP IS DEPRECATED!\nPlease switch to the new \"Streets Workshop\" for better usability and cheaper crafting.") .. "]"
|
||||
fs = fs .. "list[current_player;main;0.5,6;8,4]"
|
||||
meta:set_string("formspec", fs)
|
||||
end
|
||||
|
||||
local function update_inventory(pos)
|
||||
local node = minetest.get_node(pos)
|
||||
if node.name ~= "streets:sign_workshop" then
|
||||
return
|
||||
end
|
||||
local meta = minetest.get_meta(pos)
|
||||
local inv = meta:get_inventory()
|
||||
local section = meta:get_string("section")
|
||||
local itemcount = 0
|
||||
for k, v in pairs(streets.signs.signtypes) do
|
||||
if v.section == section then
|
||||
itemcount = itemcount + 1
|
||||
end
|
||||
end
|
||||
inv:set_size("dye_needed", 0)
|
||||
inv:set_size("list", 0)
|
||||
inv:set_size("dye_needed", 6)
|
||||
inv:set_size("list", math.ceil(itemcount / 16) * 16)
|
||||
inv:set_size("dye", 32) -- 8x4
|
||||
inv:set_size("surface", 1)
|
||||
inv:set_size("template", 1)
|
||||
inv:set_size("output", 1)
|
||||
for k, v in pairs(streets.signs.signtypes) do
|
||||
if v.section == section then
|
||||
inv:add_item("list", "streets:" .. v.name)
|
||||
end
|
||||
end
|
||||
meta:set_int("maxpage", math.ceil(itemcount / 16))
|
||||
local templatestack = inv:get_stack("template", 1)
|
||||
if templatestack and templatestack:to_string() ~= "" then
|
||||
local selectedmarking = templatestack:to_table().name
|
||||
local dyesneeded = streets.signs.signtypes[selectedmarking].dye_needed
|
||||
for k, v in pairs(dyesneeded) do
|
||||
inv:add_item("dye_needed", { name = "dye:" .. k, count = v })
|
||||
end
|
||||
end
|
||||
streets.signworkshop.update_formspec(pos)
|
||||
if meta:get_string("working_on") == "" then
|
||||
streets.signworkshop.start(pos)
|
||||
end
|
||||
end
|
||||
|
||||
local function on_receive_fields(pos, formname, fields, sender)
|
||||
local meta = minetest.get_meta(pos)
|
||||
if fields.tabs then
|
||||
meta:set_int("tab", fields.tabs)
|
||||
meta:set_int("page", 1)
|
||||
elseif fields.prevpage then
|
||||
meta:set_int("page", meta:get_int("page") - 1)
|
||||
elseif fields.nextpage then
|
||||
meta:set_int("page", meta:get_int("page") + 1)
|
||||
else
|
||||
for k, v in pairs(streets.signs.sections) do
|
||||
if fields[v.name] then
|
||||
meta:set_string("section", v.name)
|
||||
meta:set_int("tab", 3)
|
||||
end
|
||||
end
|
||||
end
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_construct(pos)
|
||||
local meta = minetest.get_meta(pos)
|
||||
meta:set_string("section", streets.signs.sections[1].name)
|
||||
meta:set_int("tab", 1)
|
||||
meta:set_int("progress", 0)
|
||||
meta:set_int("page", 1)
|
||||
meta:set_int("maxpage", 1)
|
||||
meta:set_string("working_on", "")
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_take(pos, listname, index, stack, player)
|
||||
if listname == "output" or listname == "surface" or listname == "dye" or (listname == "list" and minetest.setting_getbool("creative_mode")) then
|
||||
return stack:get_count()
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
||||
if from_list == "list" and to_list == "template" then
|
||||
return 1
|
||||
elseif from_list == "template" and to_list == "list" then
|
||||
local inv = minetest.get_meta(pos):get_inventory()
|
||||
return 1
|
||||
elseif from_list == "dye" and to_list == "dye" then
|
||||
return count
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_move(pos, from_list, from_index, to_list, to_index, count, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_put(pos, listname, index, stack, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function on_metadata_inventory_take(pos, listname, index, stack, player)
|
||||
update_inventory(pos)
|
||||
end
|
||||
|
||||
local function allow_metadata_inventory_put(pos, listname, index, stack, player)
|
||||
if listname == "dye" and stack:get_name():sub(1, 4) == "dye:" then
|
||||
return stack:get_count()
|
||||
elseif (listname == "surface" and stack:get_name() == "streets:sign_blank") or (listname == "list" and minetest.setting_getbool("creative_mode")) then
|
||||
return stack:get_count()
|
||||
else
|
||||
return 0
|
||||
end
|
||||
end
|
||||
|
||||
local function can_dig(pos, player)
|
||||
local inv = minetest.get_meta(pos):get_inventory()
|
||||
if inv:is_empty("dye") and inv:is_empty("surface") and inv:is_empty("output") then
|
||||
return true
|
||||
else
|
||||
return false
|
||||
end
|
||||
end
|
||||
|
||||
minetest.register_node(":streets:sign_workshop", {
|
||||
description = "Sign Workshop",
|
||||
tiles = {
|
||||
"default_wood.png", "default_wood.png",
|
||||
"default_wood.png^default_sign_steel.png", "default_wood.png^default_sign_steel.png",
|
||||
"default_wood.png^default_sign_steel.png", "default_wood.png",
|
||||
},
|
||||
drawtype = "nodebox",
|
||||
paramtype = "light",
|
||||
paramtype2 = "facedir",
|
||||
groups = { cracky = 1 },
|
||||
node_box = {
|
||||
type = "fixed",
|
||||
fixed = {
|
||||
{ -0.4375, 0.375, -0.1875, 0.4375, 0.4375, -0.125 }, -- rail
|
||||
{ -0.125, 0.3125, -0.25, -0.0625, 0.375, -0.0625 }, -- sprayer
|
||||
{ -0.5, -0.5, -0.5, -0.4375, 0.5, 0.5 }, -- sideL
|
||||
{ 0.4375, -0.5, -0.5, 0.5, 0.5, 0.5 }, -- sideR
|
||||
{ -0.4375, 0.3125, -0.5, -0.375, 0.375, 0.5 }, -- railLB
|
||||
{ -0.4375, 0.4375, -0.5, -0.375, 0.5, 0.5 }, -- railLT
|
||||
{ -0.4375, 0.375, -0.5, -0.375, 0.4375, -0.4375 }, -- railLF
|
||||
{ -0.4375, -0.5, 0.4375, 0.4375, 0.5, 0.5 }, -- sideR
|
||||
{ 0.375, 0.3125, -0.5, 0.4375, 0.375, 0.5 }, -- railRB
|
||||
{ 0.375, 0.4375, -0.5, 0.4375, 0.5, 0.5 }, -- railRT
|
||||
{ 0.375, 0.375, -0.5, 0.4375, 0.4375, -0.4375 }, -- railRF
|
||||
{ -0.4375, 0.375, 0.375, -0.375, 0.4375, 0.4375 }, -- railLB
|
||||
{ 0.375, 0.3125, 0.375, 0.4375, 0.375, 0.4375 }, -- railRB
|
||||
{ -0.5, -0.5, -0.5, -0.375, 0.3125, 0.4375 }, -- sideL2
|
||||
{ 0.375, -0.5, -0.5, 0.4375, 0.3125, 0.4375 }, -- sideR2
|
||||
{ -0.4375, -0.5, -0.4375, 0.4375, -0.1875, 0.4375 }, -- body
|
||||
}
|
||||
},
|
||||
selection_box = {
|
||||
type = "regular"
|
||||
},
|
||||
on_receive_fields = on_receive_fields,
|
||||
on_construct = on_construct,
|
||||
allow_metadata_inventory_take = allow_metadata_inventory_take,
|
||||
allow_metadata_inventory_move = allow_metadata_inventory_move,
|
||||
allow_metadata_inventory_put = allow_metadata_inventory_put,
|
||||
on_metadata_inventory_move = on_metadata_inventory_move,
|
||||
on_metadata_inventory_put = on_metadata_inventory_put,
|
||||
on_metadata_inventory_take = on_metadata_inventory_take,
|
||||
can_dig = can_dig,
|
||||
})
|
|
@ -689,4 +689,7 @@ minetest.register_craft({
|
|||
{ "streets:asphalt", "default:mese_crystal_fragment", "streets:asphalt" },
|
||||
{ "streets:asphalt", "streets:asphalt", "streets:asphalt" },
|
||||
}
|
||||
})
|
||||
})
|
||||
|
||||
minetest.register_alias("streets:asphalt_workshop", "streets:workshop")
|
||||
minetest.register_alias("streets:sign_workshop", "air")
|
Loading…
Reference in New Issue