forked from minetest-mods/technic
		
	Chests sorting by Zefram_Fysh
This commit is contained in:
		| @@ -26,6 +26,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| technic.chests:register("Copper", { | technic.chests:register("Copper", { | ||||||
| 	width = 10, | 	width = 10, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = false, | 	locked = false, | ||||||
| @@ -33,6 +35,8 @@ technic.chests:register("Copper", { | |||||||
|  |  | ||||||
| technic.chests:register("Copper", { | technic.chests:register("Copper", { | ||||||
| 	width = 10, | 	width = 10, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = true, | 	locked = true, | ||||||
|   | |||||||
| @@ -27,6 +27,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| technic.chests:register("Gold", { | technic.chests:register("Gold", { | ||||||
| 	width = 12, | 	width = 12, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = true, | 	infotext = true, | ||||||
| 	color = true, | 	color = true, | ||||||
| 	locked = false, | 	locked = false, | ||||||
| @@ -34,6 +36,8 @@ technic.chests:register("Gold", { | |||||||
|  |  | ||||||
| technic.chests:register("Gold", { | technic.chests:register("Gold", { | ||||||
| 	width = 12, | 	width = 12, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = true, | 	infotext = true, | ||||||
| 	color = true, | 	color = true, | ||||||
| 	locked = true, | 	locked = true, | ||||||
|   | |||||||
| @@ -27,6 +27,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| technic.chests:register("Iron", { | technic.chests:register("Iron", { | ||||||
| 	width = 9, | 	width = 9, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = false, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = false, | 	locked = false, | ||||||
| @@ -34,6 +36,8 @@ technic.chests:register("Iron", { | |||||||
|  |  | ||||||
| technic.chests:register("Iron", { | technic.chests:register("Iron", { | ||||||
| 	width = 9, | 	width = 9, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = false, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = true, | 	locked = true, | ||||||
|   | |||||||
| @@ -33,3 +33,8 @@ Iron = Eisen | |||||||
| Mithril = Mithril | Mithril = Mithril | ||||||
| Silver = Silber | Silver = Silber | ||||||
|  |  | ||||||
|  | # Sorting | ||||||
|  | Sort = | ||||||
|  | Auto-sort is %s = | ||||||
|  | Off = | ||||||
|  | On = | ||||||
|   | |||||||
| @@ -31,3 +31,8 @@ Iron = | |||||||
| Mithril = | Mithril = | ||||||
| Silver = | Silver = | ||||||
|  |  | ||||||
|  | # Sorting | ||||||
|  | Sort = | ||||||
|  | Auto-sort is %s = | ||||||
|  | Off = | ||||||
|  | On = | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| technic.chests:register("Mithril", { | technic.chests:register("Mithril", { | ||||||
| 	width = 13, | 	width = 13, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = false, | 	locked = false, | ||||||
| @@ -33,6 +35,8 @@ technic.chests:register("Mithril", { | |||||||
|  |  | ||||||
| technic.chests:register("Mithril", { | technic.chests:register("Mithril", { | ||||||
| 	width = 13, | 	width = 13, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = false, | 	infotext = false, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = true, | 	locked = true, | ||||||
|   | |||||||
| @@ -56,50 +56,111 @@ local function check_color_buttons(pos, meta, chest_name, fields) | |||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | local function set_formspec(pos, data, page) | ||||||
| local function get_receive_fields(name, data) | 	local meta = minetest.get_meta(pos) | ||||||
| 	if not data.infotext and not data.color then | 	local node = minetest.get_node(pos) | ||||||
| 		return nil | 	local formspec = data.formspec | ||||||
|  | 	if data.autosort then | ||||||
|  | 		local status = meta:get_int("autosort") | ||||||
|  | 		formspec = formspec.."button[2,5.1;3,0.8;autosort_to_"..(1-status)..";"..S("Auto-sort is %s"):format(status == 1 and S("On") or S("Off")).."]" | ||||||
| 	end | 	end | ||||||
| 	local lname = name:lower() | 	if data.infotext then | ||||||
| 	return function(pos, formname, fields, sender) |  | ||||||
| 		local meta = minetest.get_meta(pos) |  | ||||||
| 		local node = minetest.get_node(pos) |  | ||||||
| 		local page = "main" |  | ||||||
| 		if fields.edit_infotext then |  | ||||||
| 			page = "edit_infotext" |  | ||||||
| 		end |  | ||||||
| 		if fields.infotext_box then |  | ||||||
| 			meta:set_string("infotext", fields.infotext_box) |  | ||||||
| 		end |  | ||||||
| 		local formspec = data.formspec |  | ||||||
| 		local formspec_infotext = minetest.formspec_escape(meta:get_string("infotext")) | 		local formspec_infotext = minetest.formspec_escape(meta:get_string("infotext")) | ||||||
| 		if page == "main" and data.infotext then | 		if page == "main" then | ||||||
| 			formspec = formspec.."image_button[2.1,0.1;0.8,0.8;" | 			formspec = formspec.."image_button[2.1,0.1;0.8,0.8;" | ||||||
| 					.."technic_pencil_icon.png;edit_infotext;]" | 					.."technic_pencil_icon.png;edit_infotext;]" | ||||||
| 					.."label[3,0;"..formspec_infotext.."]" | 					.."label[3,0;"..formspec_infotext.."]" | ||||||
| 		end | 		elseif page == "edit_infotext" then | ||||||
| 		if page == "edit_infotext" then |  | ||||||
| 			formspec = formspec.."image_button[2.1,0.1;0.8,0.8;" | 			formspec = formspec.."image_button[2.1,0.1;0.8,0.8;" | ||||||
| 					.."technic_checkmark_icon.png;save_infotext;]" | 					.."technic_checkmark_icon.png;save_infotext;]" | ||||||
| 					.."field[3.3,0.2;4.8,1;" | 					.."field[3.3,0.2;4.8,1;" | ||||||
| 					.."infotext_box;"..S("Edit chest description:")..";" | 					.."infotext_box;"..S("Edit chest description:")..";" | ||||||
| 					..formspec_infotext.."]" | 					..formspec_infotext.."]" | ||||||
| 		end | 		end | ||||||
|  | 	end | ||||||
|  | 	if data.color then | ||||||
|  | 		local colorID = meta:get_int("color") | ||||||
|  | 		local colorName | ||||||
|  | 		if chest_mark_colors[colorID] then | ||||||
|  | 			colorName = chest_mark_colors[colorID][2] | ||||||
|  | 		else | ||||||
|  | 			colorName = S("None") | ||||||
|  | 		end | ||||||
|  | 		formspec = formspec.."label[8.2,9;"..S("Color Filter: %s"):format(colorName).."]" | ||||||
|  | 	end | ||||||
|  | 	meta:set_string("formspec", formspec) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local function sort_inventory(inv) | ||||||
|  | 	local inlist = inv:get_list("main") | ||||||
|  | 	local typecnt = {} | ||||||
|  | 	local typekeys = {} | ||||||
|  | 	for _, st in ipairs(inlist) do | ||||||
|  | 		if not st:is_empty() then | ||||||
|  | 			local n = st:get_name() | ||||||
|  | 			local w = st:get_wear() | ||||||
|  | 			local m = st:get_metadata() | ||||||
|  | 			local k = string.format("%s %05d %s", n, w, m) | ||||||
|  | 			if not typecnt[k] then | ||||||
|  | 				typecnt[k] = { | ||||||
|  | 					name = n, | ||||||
|  | 					wear = w, | ||||||
|  | 					metadata = m, | ||||||
|  | 					stack_max = st:get_stack_max(), | ||||||
|  | 					count = 0, | ||||||
|  | 				} | ||||||
|  | 				table.insert(typekeys, k) | ||||||
|  | 			end | ||||||
|  | 			typecnt[k].count = typecnt[k].count + st:get_count() | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | 	table.sort(typekeys) | ||||||
|  | 	local outlist = {} | ||||||
|  | 	for _, k in ipairs(typekeys) do | ||||||
|  | 		local tc = typecnt[k] | ||||||
|  | 		while tc.count > 0 do | ||||||
|  | 			local c = math.min(tc.count, tc.stack_max) | ||||||
|  | 			table.insert(outlist, ItemStack({ | ||||||
|  | 				name = tc.name, | ||||||
|  | 				wear = tc.wear, | ||||||
|  | 				metadata = tc.metadata, | ||||||
|  | 				count = c, | ||||||
|  | 			})) | ||||||
|  | 			tc.count = tc.count - c | ||||||
|  | 		end | ||||||
|  | 	end | ||||||
|  | 	if #outlist > #inlist then return end | ||||||
|  | 	while #outlist < #inlist do | ||||||
|  | 		table.insert(outlist, ItemStack(nil)) | ||||||
|  | 	end | ||||||
|  | 	inv:set_list("main", outlist) | ||||||
|  | end | ||||||
|  |  | ||||||
|  | local function get_receive_fields(name, data) | ||||||
|  | 	if not data.sort and not data.autosort and not data.infotext and not data.color then | ||||||
|  | 		return nil | ||||||
|  | 	end | ||||||
|  | 	local lname = name:lower() | ||||||
|  | 	return function(pos, formname, fields, sender) | ||||||
|  | 		local meta = minetest.get_meta(pos) | ||||||
|  | 		local page = "main" | ||||||
|  | 		if fields.sort or (data.autosort and fields.quit and meta:get_int("autosort") == 1) then | ||||||
|  | 			sort_inventory(meta:get_inventory()) | ||||||
|  | 		end | ||||||
|  | 		if fields.edit_infotext then | ||||||
|  | 			page = "edit_infotext" | ||||||
|  | 		end | ||||||
|  | 		if fields.autosort_to_1 then meta:set_int("autosort", 1) end | ||||||
|  | 		if fields.autosort_to_0 then meta:set_int("autosort", 0) end | ||||||
|  | 		if fields.infotext_box then | ||||||
|  | 			meta:set_string("infotext", fields.infotext_box) | ||||||
|  | 		end | ||||||
| 		if data.color then | 		if data.color then | ||||||
| 			-- This sets the node | 			-- This sets the node | ||||||
| 			local nn = "technic:"..lname..(data.locked and "_locked" or "").."_chest" | 			local nn = "technic:"..lname..(data.locked and "_locked" or "").."_chest" | ||||||
| 			check_color_buttons(pos, meta, nn, fields) | 			check_color_buttons(pos, meta, nn, fields) | ||||||
| 			local colorID = meta:get_int("color") |  | ||||||
| 			local colorName |  | ||||||
| 			if chest_mark_colors[colorID] then |  | ||||||
| 				colorName = chest_mark_colors[colorID][2] |  | ||||||
| 			else |  | ||||||
| 				colorName = S("None") |  | ||||||
| 			end |  | ||||||
| 			formspec = formspec.."label[8.2,9;"..S("Color Filter: %s"):format(colorName).."]" |  | ||||||
| 		end | 		end | ||||||
| 		meta:set_string("formspec", formspec) | 		set_formspec(pos, data, page) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
|  |  | ||||||
| @@ -119,6 +180,9 @@ function technic.chests:register(name, data) | |||||||
| 			"background[-0.19,-0.25;"..width..".4,10.75;ui_form_bg.png]".. | 			"background[-0.19,-0.25;"..width..".4,10.75;ui_form_bg.png]".. | ||||||
| 			"background[0,1;"..width..",4;technic_"..lname.."_chest_inventory.png]".. | 			"background[0,1;"..width..",4;technic_"..lname.."_chest_inventory.png]".. | ||||||
| 			"background[0,6;8,4;ui_main_inventory.png]" | 			"background[0,6;8,4;ui_main_inventory.png]" | ||||||
|  | 	if data.sort then | ||||||
|  | 		data.formspec = data.formspec.."button[0,5.1;1,0.8;sort;"..S("Sort").."]" | ||||||
|  | 	end | ||||||
| 	if data.color then | 	if data.color then | ||||||
| 		data.formspec = data.formspec..get_color_buttons() | 		data.formspec = data.formspec..get_color_buttons() | ||||||
| 	end | 	end | ||||||
| @@ -154,11 +218,8 @@ function technic.chests:register(name, data) | |||||||
| 		after_place_node = locked_after_place, | 		after_place_node = locked_after_place, | ||||||
| 		on_construct = function(pos) | 		on_construct = function(pos) | ||||||
| 			local meta = minetest.get_meta(pos) | 			local meta = minetest.get_meta(pos) | ||||||
| 			meta:set_string("formspec", data.formspec |  | ||||||
| 				..(data.color and "label[8.2,9;Color Filter: None" or "") |  | ||||||
| 				..(data.infotext and "image_button[2.1,0.1;0.8,0.8;" |  | ||||||
| 					.."technic_pencil_icon.png;edit_infotext;]" or "")) |  | ||||||
| 			meta:set_string("infotext", S("%s Chest"):format(name)) | 			meta:set_string("infotext", S("%s Chest"):format(name)) | ||||||
|  | 			set_formspec(pos, data, "main") | ||||||
| 			local inv = meta:get_inventory() | 			local inv = meta:get_inventory() | ||||||
| 			inv:set_size("main", data.width * 4) | 			inv:set_size("main", data.width * 4) | ||||||
| 		end, | 		end, | ||||||
|   | |||||||
| @@ -26,6 +26,8 @@ minetest.register_craft({ | |||||||
|  |  | ||||||
| technic.chests:register("Silver", { | technic.chests:register("Silver", { | ||||||
| 	width = 11, | 	width = 11, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = true, | 	infotext = true, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = false, | 	locked = false, | ||||||
| @@ -33,6 +35,8 @@ technic.chests:register("Silver", { | |||||||
|  |  | ||||||
| technic.chests:register("Silver", { | technic.chests:register("Silver", { | ||||||
| 	width = 11, | 	width = 11, | ||||||
|  | 	sort = true, | ||||||
|  | 	autosort = true, | ||||||
| 	infotext = true, | 	infotext = true, | ||||||
| 	color = false, | 	color = false, | ||||||
| 	locked = true, | 	locked = true, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user