Make content tab use real coordinates and minor cleanups (#13719)

This commit is contained in:
ROllerozxa 2023-08-13 14:28:16 +02:00 committed by GitHub
parent c6a0ead72d
commit e4bedc7ea8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -16,19 +16,17 @@
--with this program; if not, write to the Free Software Foundation, Inc., --with this program; if not, write to the Free Software Foundation, Inc.,
--51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. --51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
local packages_raw local packages_raw, packages
local packages
--------------------------------------------------------------------------------
local function get_formspec(tabview, name, tabdata) local function get_formspec(tabview, name, tabdata)
if pkgmgr.global_mods == nil then if not pkgmgr.global_mods then
pkgmgr.refresh_globals() pkgmgr.refresh_globals()
end end
if pkgmgr.games == nil then if not pkgmgr.games then
pkgmgr.update_gamelist() pkgmgr.update_gamelist()
end end
if packages == nil then if not packages then
packages_raw = {} packages_raw = {}
table.insert_all(packages_raw, pkgmgr.games) table.insert_all(packages_raw, pkgmgr.games)
table.insert_all(packages_raw, pkgmgr.get_texture_packs()) table.insert_all(packages_raw, pkgmgr.get_texture_packs())
@ -47,40 +45,38 @@ local function get_formspec(tabview, name, tabdata)
is_equal, nil, {}) is_equal, nil, {})
end end
if tabdata.selected_pkg == nil then if not tabdata.selected_pkg then
tabdata.selected_pkg = 1 tabdata.selected_pkg = 1
end end
local use_technical_names = core.settings:get_bool("show_technical_names") local use_technical_names = core.settings:get_bool("show_technical_names")
local retval = {
"label[0.4,0.4;", fgettext("Installed Packages:"), "]",
"tablecolumns[color;tree;text]",
"table[0.4,0.8;6.3,4.8;pkglist;",
pkgmgr.render_packagelist(packages, use_technical_names),
";", tabdata.selected_pkg, "]",
local retval = "button[0.4,5.8;6.3,0.9;btn_contentdb;", fgettext("Browse online content"), "]"
"label[0.05,-0.25;".. fgettext("Installed Packages:") .. "]" .. }
"tablecolumns[color;tree;text]" ..
"table[0,0.25;5.1,4.3;pkglist;" ..
pkgmgr.render_packagelist(packages, use_technical_names) ..
";" .. tabdata.selected_pkg .. "]" ..
"button[0,4.85;5.25,0.5;btn_contentdb;".. fgettext("Browse online content") .. "]"
local selected_pkg local selected_pkg
if filterlist.size(packages) >= tabdata.selected_pkg then if filterlist.size(packages) >= tabdata.selected_pkg then
selected_pkg = packages:get_list()[tabdata.selected_pkg] selected_pkg = packages:get_list()[tabdata.selected_pkg]
end end
if selected_pkg ~= nil then if selected_pkg then
--check for screenshot beeing available -- Check for screenshot being available
local screenshotfilename = selected_pkg.path .. DIR_DELIM .. "screenshot.png" local screenshotfilename = selected_pkg.path .. DIR_DELIM .. "screenshot.png"
local screenshotfile, error = io.open(screenshotfilename, "r") local screenshotfile, error = io.open(screenshotfilename, "r")
local modscreenshot local modscreenshot
if error == nil then if not error then
screenshotfile:close() screenshotfile:close()
modscreenshot = screenshotfilename modscreenshot = screenshotfilename
end else
modscreenshot = defaulttexturedir .. "no_screenshot.png"
if modscreenshot == nil then
modscreenshot = defaulttexturedir .. "no_screenshot.png"
end end
local info = core.get_content_info(selected_pkg.path) local info = core.get_content_info(selected_pkg.path)
@ -97,65 +93,65 @@ local function get_formspec(tabview, name, tabdata)
core.colorize("#BFBFBF", selected_pkg.name) core.colorize("#BFBFBF", selected_pkg.name)
end end
retval = retval .. table.insert_all(retval, {
"image[5.5,0;3,2;" .. core.formspec_escape(modscreenshot) .. "]" .. "image[7.1,0.2;3,2;", core.formspec_escape(modscreenshot), "]",
"label[8.25,0.6;" .. core.formspec_escape(title_and_name) .. "]" .. "label[10.5,1;", core.formspec_escape(title_and_name), "]",
"box[5.5,2.2;6.15,2.35;#000]" "box[7.1,2.4;8,3.1;#000]"
})
if selected_pkg.type == "mod" then if selected_pkg.is_modpack then
if selected_pkg.is_modpack then table.insert_all(retval, {
retval = retval .. "button[11.1,5.8;4,0.9;btn_mod_mgr_rename_modpack;",
"button[8.65,4.65;3.25,1;btn_mod_mgr_rename_modpack;" .. fgettext("Rename"), "]"
fgettext("Rename") .. "]" })
elseif selected_pkg.type == "mod" then
-- Show dependencies for mods
desc = desc .. "\n\n"
local toadd_hard = table.concat(info.depends or {}, "\n")
local toadd_soft = table.concat(info.optional_depends or {}, "\n")
if toadd_hard == "" and toadd_soft == "" then
desc = desc .. fgettext("No dependencies.")
else else
--show dependencies if toadd_hard ~= "" then
desc = desc .. "\n\n" desc = desc ..fgettext("Dependencies:") ..
local toadd_hard = table.concat(info.depends or {}, "\n") "\n" .. toadd_hard
local toadd_soft = table.concat(info.optional_depends or {}, "\n") end
if toadd_hard == "" and toadd_soft == "" then if toadd_soft ~= "" then
desc = desc .. fgettext("No dependencies.")
else
if toadd_hard ~= "" then if toadd_hard ~= "" then
desc = desc ..fgettext("Dependencies:") .. desc = desc .. "\n\n"
"\n" .. toadd_hard
end
if toadd_soft ~= "" then
if toadd_hard ~= "" then
desc = desc .. "\n\n"
end
desc = desc .. fgettext("Optional dependencies:") ..
"\n" .. toadd_soft
end end
desc = desc .. fgettext("Optional dependencies:") ..
"\n" .. toadd_soft
end end
end end
elseif selected_pkg.type == "txp" then
else if selected_pkg.enabled then
if selected_pkg.type == "txp" then table.insert_all(retval, {
if selected_pkg.enabled then "button[11.1,5.8;4,0.9;btn_mod_mgr_disable_txp;",
retval = retval .. fgettext("Disable Texture Pack"), "]"
"button[8.65,4.65;3.25,1;btn_mod_mgr_disable_txp;" .. })
fgettext("Disable Texture Pack") .. "]" else
else table.insert_all(retval, {
retval = retval .. "button[11.1,5.8;4,0.9;btn_mod_mgr_use_txp;",
"button[8.65,4.65;3.25,1;btn_mod_mgr_use_txp;" .. fgettext("Use Texture Pack"), "]"
fgettext("Use Texture Pack") .. "]" })
end
end end
end end
retval = retval .. "textarea[5.85,2.2;6.35,2.9;;" .. table.insert_all(retval, {"textarea[7.1,2.4;8,3.1;;;", desc, "]"})
fgettext("Information:") .. ";" .. desc .. "]"
if core.may_modify_path(selected_pkg.path) then if core.may_modify_path(selected_pkg.path) then
retval = retval .. table.insert_all(retval, {
"button[5.5,4.65;3.25,1;btn_mod_mgr_delete_mod;" .. "button[7.1,5.8;4,0.9;btn_mod_mgr_delete_mod;",
fgettext("Uninstall Package") .. "]" fgettext("Uninstall Package"), "]"
})
end end
end end
return retval
return table.concat(retval),
"size[15.5,7.1,false]real_coordinates[true]"
end end
--------------------------------------------------------------------------------
local function handle_doubleclick(pkg) local function handle_doubleclick(pkg)
if pkg.type == "txp" then if pkg.type == "txp" then
if core.settings:get("texture_path") == pkg.path then if core.settings:get("texture_path") == pkg.path then
@ -170,10 +166,10 @@ local function handle_doubleclick(pkg)
end end
end end
--------------------------------------------------------------------------------
local function handle_buttons(tabview, fields, tabname, tabdata) local function handle_buttons(tabview, fields, tabname, tabdata)
if fields["pkglist"] ~= nil then
local event = core.explode_table_event(fields["pkglist"]) if fields.pkglist then
local event = core.explode_table_event(fields.pkglist)
tabdata.selected_pkg = event.row tabdata.selected_pkg = event.row
if event.type == "DCL" then if event.type == "DCL" then
handle_doubleclick(packages:get_list()[tabdata.selected_pkg]) handle_doubleclick(packages:get_list()[tabdata.selected_pkg])
@ -181,7 +177,7 @@ local function handle_buttons(tabview, fields, tabname, tabdata)
return true return true
end end
if fields["btn_contentdb"] ~= nil then if fields.btn_contentdb then
local dlg = create_store_dlg() local dlg = create_store_dlg()
dlg:set_parent(tabview) dlg:set_parent(tabview)
tabview:hide() tabview:hide()
@ -190,7 +186,7 @@ local function handle_buttons(tabview, fields, tabname, tabdata)
return true return true
end end
if fields["btn_mod_mgr_rename_modpack"] ~= nil then if fields.btn_mod_mgr_rename_modpack then
local mod = packages:get_list()[tabdata.selected_pkg] local mod = packages:get_list()[tabdata.selected_pkg]
local dlg_renamemp = create_rename_modpack_dlg(mod) local dlg_renamemp = create_rename_modpack_dlg(mod)
dlg_renamemp:set_parent(tabview) dlg_renamemp:set_parent(tabview)
@ -200,7 +196,7 @@ local function handle_buttons(tabview, fields, tabname, tabdata)
return true return true
end end
if fields["btn_mod_mgr_delete_mod"] ~= nil then if fields.btn_mod_mgr_delete_mod then
local mod = packages:get_list()[tabdata.selected_pkg] local mod = packages:get_list()[tabdata.selected_pkg]
local dlg_delmod = create_delete_content_dlg(mod) local dlg_delmod = create_delete_content_dlg(mod)
dlg_delmod:set_parent(tabview) dlg_delmod:set_parent(tabview)
@ -227,7 +223,6 @@ local function handle_buttons(tabview, fields, tabname, tabdata)
return false return false
end end
--------------------------------------------------------------------------------
return { return {
name = "content", name = "content",
caption = fgettext("Content"), caption = fgettext("Content"),