improve focus higlighting and positional memory

pull/4/head
Blake DeMarcy 2017-04-17 08:03:02 -05:00
parent 87cedfda9d
commit 65b250b782
1 changed files with 45 additions and 23 deletions

View File

@ -233,19 +233,21 @@ class App(object):
self.thread = None self.thread = None
self.usermap = {} self.usermap = {}
self.window_split = False self.window_split = False
self.last_pos = 0 self.last_pos = None
# these can be changed and manipulated by other methods # these can be changed and manipulated by other methods
self.walker = urwid.SimpleFocusListWalker([]) self.walker = urwid.SimpleFocusListWalker([])
self.box = ActionBox(self.walker) self.box = ActionBox(self.walker)
self.body = urwid.AttrMap(
self.loop = urwid.MainLoop(
urwid.Frame(
urwid.LineBox( urwid.LineBox(
self.box, self.box,
title=self.prefs["frame_title"], title=self.prefs["frame_title"],
**frame_theme() **frame_theme()),
)), "default"
)
self.loop = urwid.MainLoop(
urwid.Frame(self.body),
palette=colormap, palette=colormap,
handle_mouse=False) handle_mouse=False)
@ -286,7 +288,7 @@ class App(object):
""" """
Sets the footer to the default for the current screen. Sets the footer to the default for the current screen.
""" """
if not clobber_composer and self.window_split: if self.window_split and not clobber_composer:
return return
elif self.mode == "thread": elif self.mode == "thread":
@ -344,18 +346,20 @@ class App(object):
""" """
Switch focus between the thread viewer and the open editor Switch focus between the thread viewer and the open editor
""" """
pos = self.loop.widget.focus_position
attr = ["bar" if pos == "body" else "30", "dim"]
if not self.window_split: if not self.window_split:
return return
elif self.loop.widget.focus_position == "body": elif pos == "body":
self.loop.widget.focus_position = "footer" self.loop.widget.focus_position = "footer"
focus = "[focused on editor]" focus = "[focused on editor]"
attr = ("bar", "dim")
else: else:
self.loop.widget.focus_position = "body" self.loop.widget.focus_position = "body"
focus = "[focused on thread]" focus = "[focused on thread]"
attr = ("dim", "bar") attr.reverse()
self.loop.widget.footer[0].set_text( self.loop.widget.footer[0].set_text(
"[F1]Abort [F2]Swap [F3]Formatting Help [save/quit to send] " + focus) "[F1]Abort [F2]Swap [F3]Formatting Help [save/quit to send] " + focus)
@ -365,6 +369,7 @@ class App(object):
self.loop.widget.footer.contents[1][0].original_widget.attr_map = \ self.loop.widget.footer.contents[1][0].original_widget.attr_map = \
self.loop.widget.footer.contents[0][0].attr_map = {None: attr[0]} self.loop.widget.footer.contents[0][0].attr_map = {None: attr[0]}
self.loop.widget.header.attr_map = {None: attr[1]} self.loop.widget.header.attr_map = {None: attr[1]}
self.body.attr_map = {None: attr[1]}
def readable_delta(self, modified): def readable_delta(self, modified):
@ -638,19 +643,34 @@ class App(object):
def index(self, *_): def index(self, *_):
""" """
Browse the index. Browse or return to the index.
""" """
if self.mode == "thread":
# mark the current position in this thread before going back to the index
mark()
self.body.attr_map = {None: "default"}
self.mode = "index" self.mode = "index"
self.thread = None self.thread = None
self.window_split = False self.window_split = False
threads, usermap = network.thread_index() threads, usermap = network.thread_index()
self.usermap.update(usermap) self.usermap.update(usermap)
self.walker.clear() self.walker.clear()
for thread in threads:
try:
target_id, pos = self.last_pos
except:
target_id = pos = 0
for index, thread in enumerate(threads):
self.walker.append(self.make_thread_body(thread)) self.walker.append(self.make_thread_body(thread))
self.set_bars() if thread["thread_id"] == target_id:
try: self.box.set_focus(self.last_pos) pos = index
except IndexError: self.set_bars(True)
try:
self.box.change_focus(self.loop.screen_size, pos)
self.box.set_focus_valign("middle")
except:
pass pass
@ -658,8 +678,13 @@ class App(object):
""" """
Open a thread. Open a thread.
""" """
if self.mode == "index": if app.mode == "index":
self.last_pos = self.box.get_focus()[1] pos = app.get_focus_post()
self.last_pos = (self.walker[pos].thread["thread_id"], pos)
if not self.window_split:
self.body.attr_map = {None: "default"}
self.mode = "thread" self.mode = "thread"
thread, usermap = network.thread_load(thread_id, format="sequential") thread, usermap = network.thread_load(thread_id, format="sequential")
self.usermap.update(usermap) self.usermap.update(usermap)
@ -676,8 +701,8 @@ class App(object):
self.remove_overlays() self.remove_overlays()
if self.mode == "index": if self.mode == "index":
return self.index() return self.index()
thread = self.thread["thread_id"]
mark() mark()
thread = self.thread["thread_id"]
self.thread_load(None, thread) self.thread_load(None, thread)
self.goto_post(mark(thread)) self.goto_post(mark(thread))
@ -1157,7 +1182,7 @@ class App(object):
if from_temp and self.window_split: if from_temp and self.window_split:
return return
try: try:
self.set_default_footer() self.set_default_footer(True)
self.loop.widget.focus_position = "body" self.loop.widget.focus_position = "body"
except: except:
# just keep trying until the focus widget can handle it # just keep trying until the focus widget can handle it
@ -1563,9 +1588,6 @@ class ActionBox(urwid.ListBox):
overlay = app.overlay_p() overlay = app.overlay_p()
keyl = key.lower() keyl = key.lower()
if not overlay:
mark()
if key in ["j", "n", "ctrl n"]: if key in ["j", "n", "ctrl n"]:
self._keypress_down(size) self._keypress_down(size)