Update connectivity dialog while open

This commit is contained in:
Mark Qvist 2022-11-03 22:55:35 +01:00
parent ecb5c6ea40
commit 00ae5e9e81
2 changed files with 28 additions and 12 deletions

View File

@ -1,5 +1,4 @@
# TODO: Reset __debug_build__ = False
__debug_build__ = True
__disable_shaders__ = True __disable_shaders__ = True
__version__ = "0.3.0" __version__ = "0.3.0"
__variant__ = "beta" __variant__ = "beta"
@ -114,6 +113,8 @@ class SidebandApp(MDApp):
self.icon = self.sideband.asset_dir+"/icon.png" self.icon = self.sideband.asset_dir+"/icon.png"
self.notification_icon = self.sideband.asset_dir+"/notification_icon.png" self.notification_icon = self.sideband.asset_dir+"/notification_icon.png"
self.connectivity_updater = None
################################################# #################################################
# Application Startup # # Application Startup #
@ -748,9 +749,7 @@ class SidebandApp(MDApp):
self.sideband.setstate("wants.clear_notifications", True) self.sideband.setstate("wants.clear_notifications", True)
Clock.schedule_once(cb, 0.10) Clock.schedule_once(cb, 0.10)
def connectivity_status(self, sender): def get_connectivity_text(self):
hs = dp(22)
connectivity_status = "" connectivity_status = ""
if RNS.vendor.platformutils.get_platform() == "android": if RNS.vendor.platformutils.get_platform() == "android":
connectivity_status = self.sideband.getstate("service.connectivity_status") connectivity_status = self.sideband.getstate("service.connectivity_status")
@ -761,17 +760,31 @@ class SidebandApp(MDApp):
else: else:
connectivity_status = "[size=22dp][b]Connectivity Status[/b][/size]\n\nSideband is currently running a standalone or master Reticulum instance on this system. Use the rnstatus utility to obtain full connectivity info." connectivity_status = "[size=22dp][b]Connectivity Status[/b][/size]\n\nSideband is currently running a standalone or master Reticulum instance on this system. Use the rnstatus utility to obtain full connectivity info."
return connectivity_status
def connectivity_status(self, sender):
hs = dp(22)
yes_button = MDRectangleFlatButton(text="OK",font_size=dp(18)) yes_button = MDRectangleFlatButton(text="OK",font_size=dp(18))
dialog = MDDialog( dialog = MDDialog(
text=connectivity_status, text=self.get_connectivity_text(),
buttons=[ yes_button ], buttons=[ yes_button ],
# elevation=0, # elevation=0,
) )
def cs_updater(dt):
dialog.text = self.get_connectivity_text()
def dl_yes(s): def dl_yes(s):
self.connectivity_updater.cancel()
dialog.dismiss() dialog.dismiss()
yes_button.bind(on_release=dl_yes) yes_button.bind(on_release=dl_yes)
dialog.open() dialog.open()
if self.connectivity_updater != None:
self.connectivity_updater.cancel()
self.connectivity_updater = Clock.schedule_interval(cs_updater, 1.0)
def lxmf_sync_action(self, sender): def lxmf_sync_action(self, sender):
def cb(dt): def cb(dt):
@ -1103,6 +1116,11 @@ class SidebandApp(MDApp):
self.widget_hide(self.root.ids.connectivity_serial_label) self.widget_hide(self.root.ids.connectivity_serial_label)
self.widget_hide(self.root.ids.connectivity_use_serial) self.widget_hide(self.root.ids.connectivity_use_serial)
self.widget_hide(self.root.ids.connectivity_serial_fields) self.widget_hide(self.root.ids.connectivity_serial_fields)
self.widget_hide(self.root.ids.connectivity_transport_label)
self.widget_hide(self.root.ids.connectivity_enable_transport)
self.widget_hide(self.root.ids.connectivity_transport_info)
self.widget_hide(self.root.ids.connectivity_transport_fields)
def con_collapse_local(collapse=True): def con_collapse_local(collapse=True):
# self.widget_hide(self.root.ids.connectivity_local_fields, collapse) # self.widget_hide(self.root.ids.connectivity_local_fields, collapse)
@ -1396,9 +1414,8 @@ class SidebandApp(MDApp):
con_collapse_local(collapse=not self.root.ids.connectivity_use_local.active) con_collapse_local(collapse=not self.root.ids.connectivity_use_local.active)
self.sideband.save_configuration() self.sideband.save_configuration()
# TODO: Remove if RNS.vendor.platformutils.get_platform() == "android":
if True or RNS.vendor.platformutils.get_platform() == "android": if not self.sideband.getpersistent("service.is_controlling_connectivity"):
if False and not self.sideband.getpersistent("service.is_controlling_connectivity"):
info = "Sideband is connected via a shared Reticulum instance running on this system.\n\n" info = "Sideband is connected via a shared Reticulum instance running on this system.\n\n"
info += "To configure hardware parameters, edit the relevant configuration file for the instance." info += "To configure hardware parameters, edit the relevant configuration file for the instance."
self.root.ids.hardware_info.text = info self.root.ids.hardware_info.text = info

View File

@ -1,5 +1,4 @@
# TODO: Reset __debug_build__ = False
__debug_build__ = True
import time import time
import RNS import RNS