mirror of
https://github.com/markqvist/NomadNet.git
synced 2025-01-15 17:17:14 -05:00
Improved dialog navigation
This commit is contained in:
parent
27dc1b5fb5
commit
f75b4d0b57
@ -210,7 +210,8 @@ class TextUI:
|
|||||||
self.screen.reset_default_terminal_palette()
|
self.screen.reset_default_terminal_palette()
|
||||||
|
|
||||||
def unhandled_input(self, key):
|
def unhandled_input(self, key):
|
||||||
pass
|
if key == "ctrl q":
|
||||||
|
raise urwid.ExitMainLoop
|
||||||
|
|
||||||
def display_main(self, loop, user_data):
|
def display_main(self, loop, user_data):
|
||||||
self.loop.widget = self.main_display.widget
|
self.loop.widget = self.main_display.widget
|
||||||
|
@ -51,6 +51,13 @@ class ListEntry(urwid.Text):
|
|||||||
|
|
||||||
|
|
||||||
class AnnounceInfo(urwid.WidgetWrap):
|
class AnnounceInfo(urwid.WidgetWrap):
|
||||||
|
def keypress(self, size, key):
|
||||||
|
if key == "esc":
|
||||||
|
options = self.parent.left_pile.options(height_type="weight", height_amount=1)
|
||||||
|
self.parent.left_pile.contents[0] = (self.parent.announce_stream_display, options)
|
||||||
|
else:
|
||||||
|
return super(AnnounceInfo, self).keypress(size, key)
|
||||||
|
|
||||||
def __init__(self, announce, parent, app):
|
def __init__(self, announce, parent, app):
|
||||||
self.app = nomadnet.NomadNetworkApp.get_shared_instance()
|
self.app = nomadnet.NomadNetworkApp.get_shared_instance()
|
||||||
self.parent = self.app.ui.main_display.sub_displays.network_display
|
self.parent = self.app.ui.main_display.sub_displays.network_display
|
||||||
@ -387,6 +394,13 @@ class ListDialogLineBox(urwid.LineBox):
|
|||||||
return super(ListDialogLineBox, self).keypress(size, key)
|
return super(ListDialogLineBox, self).keypress(size, key)
|
||||||
|
|
||||||
class KnownNodeInfo(urwid.WidgetWrap):
|
class KnownNodeInfo(urwid.WidgetWrap):
|
||||||
|
def keypress(self, size, key):
|
||||||
|
if key == "esc":
|
||||||
|
options = self.parent.left_pile.options(height_type="weight", height_amount=1)
|
||||||
|
self.parent.left_pile.contents[0] = (self.parent.known_nodes_display, options)
|
||||||
|
else:
|
||||||
|
return super(KnownNodeInfo, self).keypress(size, key)
|
||||||
|
|
||||||
def __init__(self, node_hash):
|
def __init__(self, node_hash):
|
||||||
self.app = nomadnet.NomadNetworkApp.get_shared_instance()
|
self.app = nomadnet.NomadNetworkApp.get_shared_instance()
|
||||||
self.parent = self.app.ui.main_display.sub_displays.network_display
|
self.parent = self.app.ui.main_display.sub_displays.network_display
|
||||||
@ -568,6 +582,10 @@ class KnownNodeInfo(urwid.WidgetWrap):
|
|||||||
|
|
||||||
pile = urwid.Pile(pile_widgets)
|
pile = urwid.Pile(pile_widgets)
|
||||||
|
|
||||||
|
pile.focus_position = len(pile.contents)-1
|
||||||
|
button_columns.focus_position = 0
|
||||||
|
|
||||||
|
|
||||||
self.display_widget = urwid.Filler(pile, valign="top", height="pack")
|
self.display_widget = urwid.Filler(pile, valign="top", height="pack")
|
||||||
|
|
||||||
urwid.WidgetWrap.__init__(self, urwid.LineBox(self.display_widget, title="Node Info"))
|
urwid.WidgetWrap.__init__(self, urwid.LineBox(self.display_widget, title="Node Info"))
|
||||||
@ -1257,6 +1275,8 @@ class NetworkLeftPile(urwid.Pile):
|
|||||||
def keypress(self, size, key):
|
def keypress(self, size, key):
|
||||||
if key == "ctrl l":
|
if key == "ctrl l":
|
||||||
self.parent.toggle_list()
|
self.parent.toggle_list()
|
||||||
|
elif key == "ctrl e":
|
||||||
|
self.parent.selected_node_info()
|
||||||
elif key == "ctrl p":
|
elif key == "ctrl p":
|
||||||
self.parent.reinit_lxmf_peers()
|
self.parent.reinit_lxmf_peers()
|
||||||
self.parent.show_peers()
|
self.parent.show_peers()
|
||||||
@ -1332,6 +1352,18 @@ class NetworkDisplay():
|
|||||||
else:
|
else:
|
||||||
self.list_display = 1
|
self.list_display = 1
|
||||||
|
|
||||||
|
def selected_node_info(self):
|
||||||
|
if self.list_display == 1:
|
||||||
|
parent = self.app.ui.main_display.sub_displays.network_display
|
||||||
|
selected_node_entry = parent.known_nodes_display.ilb.get_selected_item()
|
||||||
|
if selected_node_entry != None:
|
||||||
|
selected_node_hash = selected_node_entry._get_base_widget().display_widget.source_hash
|
||||||
|
|
||||||
|
if selected_node_hash != None:
|
||||||
|
info_widget = KnownNodeInfo(selected_node_hash)
|
||||||
|
options = parent.left_pile.options(height_type="weight", height_amount=1)
|
||||||
|
parent.left_pile.contents[0] = (info_widget, options)
|
||||||
|
|
||||||
def focus_lists(self):
|
def focus_lists(self):
|
||||||
self.columns.focus_position = 0
|
self.columns.focus_position = 0
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user