mirror of
				https://github.com/minetest-mods/craftguide.git
				synced 2025-10-27 03:15:34 +01:00 
			
		
		
		
	Compare commits
	
		
			2 Commits
		
	
	
		
			7e70ccab27
			...
			redesign
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 9433ae2adc | ||
|  | 103624bc28 | 
							
								
								
									
										61
									
								
								init.lua
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								init.lua
									
									
									
									
									
								
							| @@ -65,7 +65,6 @@ local FORMSPEC_MINIMAL_VERSION = 3 | |||||||
|  |  | ||||||
| local ROWS = 9 | local ROWS = 9 | ||||||
| local LINES = sfinv_only and 5 or 9 | local LINES = sfinv_only and 5 or 9 | ||||||
| local IPP = ROWS * LINES |  | ||||||
| local WH_LIMIT = 8 | local WH_LIMIT = 8 | ||||||
|  |  | ||||||
| local XOFFSET = sfinv_only and 3.83 or 11.2 | local XOFFSET = sfinv_only and 3.83 or 11.2 | ||||||
| @@ -887,9 +886,9 @@ local function get_grid_fs(data, fs, rcp, spacing) | |||||||
| 			_btn_size = btn_size | 			_btn_size = btn_size | ||||||
|  |  | ||||||
| 			X = (btn_size * ((i - 1) % width) + XOFFSET - | 			X = (btn_size * ((i - 1) % width) + XOFFSET - | ||||||
| 				(sfinv_only and 2.83 or 0.5)) * (0.83 - (x_y / 5)) | 				(sfinv_only and 2.83 or 0)) * (0.83 - (x_y / 5)) | ||||||
| 			Y = (btn_size * floor((i - 1) / width) + | 			Y = (btn_size * floor((i - 1) / width) + | ||||||
| 				(sfinv_only and 5.81 or 5.5) + x_y) * (0.86 - (x_y / 5)) | 				(sfinv_only and 5.81 or 3.92) + x_y) * (0.86 - (x_y / 5)) | ||||||
| 		end | 		end | ||||||
|  |  | ||||||
| 		if X > rightest then | 		if X > rightest then | ||||||
| @@ -1085,37 +1084,26 @@ local function make_fs(data) | |||||||
|  |  | ||||||
| 	fs[#fs + 1] = fmt([[ | 	fs[#fs + 1] = fmt([[ | ||||||
| 		style[filter;border=false] | 		style[filter;border=false] | ||||||
| 		field[0.4,0.2;2.5,1;filter;;%s] | 		field[0.4,0.2;6.45,1;filter;;%s] | ||||||
| 		field_close_on_enter[filter;false] | 		field_close_on_enter[filter;false] | ||||||
| 		box[0,0;2.4,0.6;#bababa25] | 		box[0,0;6.35,0.6;#bababa25] | ||||||
| 	]], | 	]], | ||||||
| 	ESC(data.filter)) | 	ESC(data.filter)) | ||||||
|  |  | ||||||
| 	fs[#fs + 1] = fmt([[ | 	fs[#fs + 1] = fmt([[ | ||||||
|  | 		style_type[image;noclip=false] | ||||||
| 		style_type[image_button;border=false] | 		style_type[image_button;border=false] | ||||||
| 		style_type[item_image_button;border=false;bgimg_hovered=%s;bgimg_pressed=%s] | 		style_type[item_image_button;border=false;bgimg_hovered=%s;bgimg_pressed=%s] | ||||||
| 		style[search;fgimg=%s;fgimg_hovered=%s] | 		style[search;fgimg=%s;fgimg_hovered=%s] | ||||||
| 		style[clear;fgimg=%s;fgimg_hovered=%s] | 		style[clear;fgimg=%s;fgimg_hovered=%s] | ||||||
| 		style[prev_page;fgimg=%s;fgimg_hovered=%s;fgimg_pressed=%s] |  | ||||||
| 		style[next_page;fgimg=%s;fgimg_hovered=%s;fgimg_pressed=%s] |  | ||||||
| 	]], | 	]], | ||||||
| 	PNG.selected, PNG.selected, | 	PNG.selected, PNG.selected, | ||||||
| 	PNG.search, PNG.search_hover, | 	PNG.search, PNG.search_hover, | ||||||
| 	PNG.clear, PNG.clear_hover, | 	PNG.clear, PNG.clear_hover) | ||||||
| 	PNG.prev, PNG.prev_hover, PNG.prev_hover, |  | ||||||
| 	PNG.next, PNG.next_hover, PNG.next_hover) |  | ||||||
|  |  | ||||||
| 	fs[#fs + 1] = fmt(mul_elem(FMT.image_button, 4), | 	fs[#fs + 1] = fmt(mul_elem(FMT.image_button, 2), | ||||||
| 		sfinv_only and 2.6 or 2.54, -0.06, 0.85, 0.85, "", "search", "", | 		sfinv_only and 2.6 or 6.45, -0.06, 0.85, 0.85, "", "search", "", | ||||||
| 		sfinv_only and 3.3 or 3.25, -0.06, 0.85, 0.85, "", "clear", "", | 		sfinv_only and 3.3 or 7.15, -0.06, 0.85, 0.85, "", "clear", "") | ||||||
| 		sfinv_only and 5.45 or (9 * 6.83) / 11, -0.06, 0.85, 0.85, "", "prev_page", "", |  | ||||||
| 		sfinv_only and 7.2  or (9 * 8.75) / 11, -0.06, 0.85, 0.85, "", "next_page", "") |  | ||||||
|  |  | ||||||
| 	data.pagemax = max(1, ceil(#data.items / IPP)) |  | ||||||
|  |  | ||||||
| 	fs[#fs + 1] = fmt("label[%f,%f;%s / %u]", |  | ||||||
| 		sfinv_only and 6.35 or (9 * 7.85) / 11, |  | ||||||
| 			0.06, clr("#ff0", data.pagenum), data.pagemax) |  | ||||||
|  |  | ||||||
| 	if #data.items == 0 then | 	if #data.items == 0 then | ||||||
| 		local no_item = ES"No item to show" | 		local no_item = ES"No item to show" | ||||||
| @@ -1129,16 +1117,16 @@ local function make_fs(data) | |||||||
| 		fs[#fs + 1] = fmt(FMT.label, pos, 2, no_item) | 		fs[#fs + 1] = fmt(FMT.label, pos, 2, no_item) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	local first_item = (data.pagenum - 1) * IPP | 	fs[#fs + 1] = "scroll_container[0,1.3;9,9.3;scrbar;vertical]" | ||||||
|  |  | ||||||
| 	for i = first_item, first_item + IPP - 1 do | 	for i = 0, #data.items do | ||||||
| 		local item = data.items[i + 1] | 		local item = data.items[i + 1] | ||||||
| 		if not item then break end | 		if not item then break end | ||||||
|  |  | ||||||
| 		local X = i % ROWS | 		local X = i % ROWS | ||||||
| 		local Y = (i % IPP - X) / ROWS + 1 | 		local Y = (i - X) / ROWS | ||||||
| 		X = X - (X * (sfinv_only and 0.12 or 0.14)) - 0.05 | 		X = X - (X * 0.12) | ||||||
| 		Y = Y - (Y * 0.1) - 0.1 | 		Y = Y - (Y * 0.02) | ||||||
|  |  | ||||||
| 		if data.query_item == item then | 		if data.query_item == item then | ||||||
| 			fs[#fs + 1] = fmt(FMT.image, X, Y, 1, 1, PNG.selected) | 			fs[#fs + 1] = fmt(FMT.image, X, Y, 1, 1, PNG.selected) | ||||||
| @@ -1148,6 +1136,10 @@ local function make_fs(data) | |||||||
| 			X, Y, 1, 1, item, item) | 			X, Y, 1, 1, item, item) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
|  | 	fs[#fs + 1] = "scroll_container_end[]" | ||||||
|  | 	fs[#fs + 1] = fmt("scrollbaroptions[arrows=hide;max=%u]", (#data.items / 8) * 10 - 80) | ||||||
|  | 	fs[#fs + 1] = fmt("scrollbar[7.2,0.8;0.45,8.1;vertical;scrbar;%u]", data.scrbar) | ||||||
|  |  | ||||||
| 	if (data.recipes and #data.recipes > 0) or (data.usages and #data.usages > 0) then | 	if (data.recipes and #data.recipes > 0) or (data.usages and #data.usages > 0) then | ||||||
| 		get_panels(data, fs) | 		get_panels(data, fs) | ||||||
| 	end | 	end | ||||||
| @@ -1524,7 +1516,7 @@ end | |||||||
| local function init_data(name) | local function init_data(name) | ||||||
| 	pdata[name] = { | 	pdata[name] = { | ||||||
| 		filter     = "", | 		filter     = "", | ||||||
| 		pagenum    = 1, | 		scrbar     = 0, | ||||||
| 		items      = init_items, | 		items      = init_items, | ||||||
| 		items_raw  = init_items, | 		items_raw  = init_items, | ||||||
| 		favs       = {}, | 		favs       = {}, | ||||||
| @@ -1534,7 +1526,7 @@ end | |||||||
|  |  | ||||||
| local function reset_data(data) | local function reset_data(data) | ||||||
| 	data.filter      = "" | 	data.filter      = "" | ||||||
| 	data.pagenum     = 1 | 	data.scrbar      = 0 | ||||||
| 	data.rnum        = 1 | 	data.rnum        = 1 | ||||||
| 	data.unum        = 1 | 	data.unum        = 1 | ||||||
| 	data.query_item  = nil | 	data.query_item  = nil | ||||||
| @@ -1576,19 +1568,9 @@ local function fields(player, _f) | |||||||
| 		if data.filter == str then return end | 		if data.filter == str then return end | ||||||
|  |  | ||||||
| 		data.filter = str | 		data.filter = str | ||||||
| 		data.pagenum = 1 | 		data.scrbar = 0 | ||||||
| 		search(data) | 		search(data) | ||||||
|  |  | ||||||
| 	elseif _f.prev_page or _f.next_page then |  | ||||||
| 		if data.pagemax == 1 then return end |  | ||||||
| 		data.pagenum = data.pagenum - (_f.prev_page and 1 or -1) |  | ||||||
|  |  | ||||||
| 		if data.pagenum > data.pagemax then |  | ||||||
| 			data.pagenum = 1 |  | ||||||
| 		elseif data.pagenum == 0 then |  | ||||||
| 			data.pagenum = data.pagemax |  | ||||||
| 		end |  | ||||||
|  |  | ||||||
| 	elseif _f.fav then | 	elseif _f.fav then | ||||||
| 		local fav, i = is_fav(data) | 		local fav, i = is_fav(data) | ||||||
| 		local total = #data.favs | 		local total = #data.favs | ||||||
| @@ -1636,6 +1618,7 @@ local function fields(player, _f) | |||||||
| 		data.usages     = usages | 		data.usages     = usages | ||||||
| 		data.rnum       = 1 | 		data.rnum       = 1 | ||||||
| 		data.unum       = 1 | 		data.unum       = 1 | ||||||
|  | 		data.scrbar     = tonumber(match(_f.scrbar, "%d+")) | ||||||
| 	end | 	end | ||||||
|  |  | ||||||
| 	return true, show_fs(player, name) | 	return true, show_fs(player, name) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user