Android menu: Unified serverlist

This commit is contained in:
kilbith 2016-04-25 11:18:17 +02:00
parent 31c1fca6fd
commit 813cca7e5d
1 changed files with 110 additions and 100 deletions

View File

@ -17,27 +17,32 @@
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
local function get_formspec(tabview, name, tabdata) local function get_formspec(tabview, name, tabdata)
local retval = "" -- Update the cached supported proto info,
-- it may have changed after a change by the settings menu.
common_update_cached_supp_proto()
local fav_selected = menudata.favorites[tabdata.fav_selected]
local render_details = dump(core.setting_getbool("public_serverlist")) local retval =
"label[9.5,0;".. fgettext("Name / Password") .. "]" ..
retval = retval .. "field[0.25,3.35;5.5,0.5;te_address;;" ..
"label[8,0.5;".. fgettext("Name/Password") .. "]" ..
"field[0.25,3.25;5.5,0.5;te_address;;" ..
core.formspec_escape(core.setting_get("address")) .."]" .. core.formspec_escape(core.setting_get("address")) .."]" ..
"field[5.75,3.25;2.25,0.5;te_port;;" .. "field[5.75,3.35;2.25,0.5;te_port;;" ..
core.formspec_escape(core.setting_get("remote_port")) .."]" .. core.formspec_escape(core.setting_get("remote_port")) .."]" ..
"checkbox[8,-0.25;cb_public_serverlist;".. fgettext("Public Serverlist") .. ";" .. "button[10,2.6;2,1.5;btn_mp_connect;".. fgettext("Connect") .. "]" ..
render_details .. "]" "field[9.8,1;2.6,0.5;te_name;;" ..
retval = retval ..
"button[8,2.5;4,1.5;btn_mp_connect;".. fgettext("Connect") .. "]" ..
"field[8.75,1.5;3.5,0.5;te_name;;" ..
core.formspec_escape(core.setting_get("name")) .."]" .. core.formspec_escape(core.setting_get("name")) .."]" ..
"pwdfield[8.75,2.3;3.5,0.5;te_pwd;]" "pwdfield[9.8,2;2.6,0.5;te_pwd;]"
if tabdata.fav_selected and fav_selected then
if gamedata.fav then
retval = retval .. "button[7.7,2.6;2.3,1.5;btn_delete_favorite;" ..
fgettext("Del. Favorite") .. "]"
end
end
if render_details then
retval = retval .. "tablecolumns[" .. retval = retval .. "tablecolumns[" ..
image_column(fgettext("Favorite"), "favorite") .. ";" ..
"color,span=3;" .. "color,span=3;" ..
"text,align=right;" .. -- clients "text,align=right;" .. -- clients
"text,align=center,padding=0.25;" .. -- "/" "text,align=center,padding=0.25;" .. -- "/"
@ -46,30 +51,39 @@ local function get_formspec(tabview, name, tabdata)
image_column(fgettext("Damage enabled"), "damage") .. ",padding=0.25;" .. image_column(fgettext("Damage enabled"), "damage") .. ",padding=0.25;" ..
image_column(fgettext("PvP enabled"), "pvp") .. ",padding=0.25;" .. image_column(fgettext("PvP enabled"), "pvp") .. ",padding=0.25;" ..
"color,span=1;" .. "color,span=1;" ..
"text,padding=1]" -- name "text,padding=1]" .. -- name
else "table[-0.05,0;9.2,2.75;favourites;"
retval = retval .. "tablecolumns[text]"
end
retval = retval ..
"table[-0.05,0;7.55,2.75;favourites;"
if #menudata.favorites > 0 then if #menudata.favorites > 0 then
retval = retval .. render_favorite(menudata.favorites[1],render_details) local favs = core.get_favorites("local")
if #favs > 0 then
for i=2,#menudata.favorites,1 do for i = 1, #favs do
retval = retval .. "," .. render_favorite(menudata.favorites[i],render_details) for j = 1, #menudata.favorites do
if menudata.favorites[j].address == favs[i].address and
menudata.favorites[j].port == favs[i].port then
table.insert(menudata.favorites, i,
table.remove(menudata.favorites, j))
end
end
if favs[i].address ~= menudata.favorites[i].address then
table.insert(menudata.favorites, i, favs[i])
end
end
end
retval = retval .. render_favorite(menudata.favorites[1], (#favs > 0))
for i = 2, #menudata.favorites do
retval = retval .. "," .. render_favorite(menudata.favorites[i], (i <= #favs))
end end
end end
if tabdata.fav_selected ~= nil then if tabdata.fav_selected then
retval = retval .. ";" .. tabdata.fav_selected .. "]" retval = retval .. ";" .. tabdata.fav_selected .. "]"
else else
retval = retval .. ";0]" retval = retval .. ";0]"
end end
-- separator -- separator
retval = retval .. retval = retval .. "box[-0.28,3.75;12.4,0.1;#FFFFFF]"
"box[-0.28,3.75;12.4,0.1;#FFFFFF]"
-- checkboxes -- checkboxes
retval = retval .. retval = retval ..
@ -87,71 +101,75 @@ end
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
local function main_button_handler(tabview, fields, name, tabdata) local function main_button_handler(tabview, fields, name, tabdata)
if fields.btn_start_singleplayer then
if fields["btn_start_singleplayer"] then
gamedata.selected_world = gamedata.worldindex gamedata.selected_world = gamedata.worldindex
gamedata.singleplayer = true gamedata.singleplayer = true
core.start() core.start()
return true return true
end end
if fields["favourites"] ~= nil then if fields.favourites then
local event = core.explode_table_event(fields["favourites"]) local event = core.explode_table_event(fields.favourites)
if event.type == "CHG" then if event.type == "CHG" then
if event.row <= #menudata.favorites then if event.row <= #menudata.favorites then
local address = menudata.favorites[event.row].address gamedata.fav = false
local port = menudata.favorites[event.row].port local favs = core.get_favorites("local")
local fav = menudata.favorites[event.row]
local address = fav.address
local port = fav.port
gamedata.serverdescription = fav.description
if address ~= nil and for i = 1, #favs do
port ~= nil then if fav.address == favs[i].address and
fav.port == favs[i].port then
gamedata.fav = true
end
end
if address and port then
core.setting_set("address", address) core.setting_set("address", address)
core.setting_set("remote_port", port) core.setting_set("remote_port", port)
end end
tabdata.fav_selected = event.row tabdata.fav_selected = event.row
end end
end
return true return true
end end
end
if fields["cb_public_serverlist"] ~= nil then if fields.btn_delete_favorite then
core.setting_set("public_serverlist", fields["cb_public_serverlist"]) local current_favourite = core.get_table_index("favourites")
if not current_favourite then return end
if core.setting_getbool("public_serverlist") then core.delete_favorite(current_favourite)
asyncOnlineFavourites() asyncOnlineFavourites()
else tabdata.fav_selected = nil
menudata.favorites = core.get_favorites("local")
menudata.favorites_is_public = false core.setting_set("address", "")
end core.setting_set("remote_port", "30000")
return true return true
end end
if fields["cb_creative"] then if fields.cb_creative then
core.setting_set("creative_mode", fields["cb_creative"]) core.setting_set("creative_mode", fields.cb_creative)
return true return true
end end
if fields["cb_damage"] then if fields.cb_damage then
core.setting_set("enable_damage", fields["cb_damage"]) core.setting_set("enable_damage", fields.cb_damage)
return true return true
end end
if fields["btn_mp_connect"] ~= nil or if fields.btn_mp_connect or fields.key_enter then
fields["key_enter"] ~= nil then gamedata.playername = fields.te_name
gamedata.password = fields.te_pwd
gamedata.playername = fields["te_name"] gamedata.address = fields.te_address
gamedata.password = fields["te_pwd"] gamedata.port = fields.te_port
gamedata.address = fields["te_address"]
gamedata.port = fields["te_port"]
local fav_idx = core.get_textlist_index("favourites") local fav_idx = core.get_textlist_index("favourites")
if fav_idx ~= nil and fav_idx <= #menudata.favorites and if fav_idx and fav_idx <= #menudata.favorites and
menudata.favorites[fav_idx].address == fields["te_address"] and menudata.favorites[fav_idx].address == fields.te_address and
menudata.favorites[fav_idx].port == fields["te_port"] then menudata.favorites[fav_idx].port == fields.te_port then
local fav = menudata.favorites[fav_idx] local fav = menudata.favorites[fav_idx]
gamedata.servername = fav.name gamedata.servername = fav.name
gamedata.serverdescription = fav.description gamedata.serverdescription = fav.description
@ -167,17 +185,16 @@ local function main_button_handler(tabview, fields, name, tabdata)
gamedata.selected_world = 0 gamedata.selected_world = 0
core.setting_set("address",fields["te_address"]) core.setting_set("address", fields.te_address)
core.setting_set("remote_port",fields["te_port"]) core.setting_set("remote_port", fields.te_port)
core.start() core.start()
return true return true
end end
if fields["btn_config_sp_world"] ~= nil then if fields.btn_config_sp_world then
local configdialog = create_configure_world_dlg(1) local configdialog = create_configure_world_dlg(1)
if configdialog then
if (configdialog ~= nil) then
configdialog:set_parent(tabview) configdialog:set_parent(tabview)
tabview:hide() tabview:hide()
configdialog:show() configdialog:show()
@ -188,15 +205,8 @@ end
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
local function on_activate(type,old_tab,new_tab) local function on_activate(type,old_tab,new_tab)
if type == "LEAVE" then if type == "LEAVE" then return end
return
end
if core.setting_getbool("public_serverlist") then
asyncOnlineFavourites() asyncOnlineFavourites()
else
menudata.favorites = core.get_favorites("local")
menudata.favorites_is_public = false
end
end end
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------