forked from Mirrorlandia_minetest/minetest
Make content tab use real coordinates and minor cleanups (#13719)
This commit is contained in:
parent
c6a0ead72d
commit
e4bedc7ea8
@ -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"),
|
||||||
|
Loading…
Reference in New Issue
Block a user