Added back, forward and reload actions to browser.

This commit is contained in:
Mark Qvist 2021-09-17 11:47:41 +02:00
parent 150076be6b
commit 0d93e7e8d2
2 changed files with 71 additions and 4 deletions

View File

@ -11,6 +11,12 @@ class BrowserFrame(urwid.Frame):
def keypress(self, size, key): def keypress(self, size, key):
if key == "ctrl w": if key == "ctrl w":
self.delegate.disconnect() self.delegate.disconnect()
elif key == "ctrl d":
self.delegate.back()
elif key == "ctrl f":
self.delegate.forward()
elif key == "ctrl r":
self.delegate.reload()
elif self.get_focus() == "body": elif self.get_focus() == "body":
return super(BrowserFrame, self).keypress(size, key) return super(BrowserFrame, self).keypress(size, key)
# if key == "up" and self.delegate.messagelist.top_is_visible: # if key == "up" and self.delegate.messagelist.top_is_visible:
@ -67,6 +73,12 @@ class Browser:
self.attr_maps = [] self.attr_maps = []
self.build_display() self.build_display()
self.history = []
self.history_ptr = 0
self.history_inc = False
self.history_dec = False
self.reloading = False
if self.path == None: if self.path == None:
self.path = Browser.DEFAULT_PATH self.path = Browser.DEFAULT_PATH
@ -232,6 +244,11 @@ class Browser:
self.response_size = None self.response_size = None
self.response_transfer_size = None self.response_transfer_size = None
self.history = []
self.history_ptr = 0
self.history_inc = False
self.history_dec = False
self.update_display() self.update_display()
@ -361,6 +378,38 @@ class Browser:
else: else:
self.link.teardown() self.link.teardown()
def write_history(self):
entry = [self.destination_hash, self.path]
self.history.insert(self.history_ptr, entry)
self.history_ptr += 1
if len(self.history) > self.history_ptr:
self.history = self.history[:self.history_ptr]
def back(self):
target_ptr = self.history_ptr-1
if not self.history_inc and not self.history_dec:
if target_ptr > 0:
self.history_dec = True
entry = self.history[target_ptr-1]
url = RNS.hexrep(entry[0], delimit=False)+":"+entry[1]
self.history_ptr = target_ptr
self.retrieve_url(url)
def forward(self):
target_ptr = self.history_ptr+1
if not self.history_inc and not self.history_dec:
if target_ptr <= len(self.history):
self.history_dec = True
entry = self.history[target_ptr-1]
url = RNS.hexrep(entry[0], delimit=False)+":"+entry[1]
self.history_ptr = target_ptr
self.retrieve_url(url)
def reload(self):
if not self.reloading and self.status == Browser.DONE:
self.reloading = True
self.load_page()
def load_page(self): def load_page(self):
if self.destination_hash != self.loopback: if self.destination_hash != self.loopback:
@ -368,9 +417,8 @@ class Browser:
load_thread.setDaemon(True) load_thread.setDaemon(True)
load_thread.start() load_thread.start()
else: else:
RNS.log("Browser handling local page: "+str(self.path), RNS.LOG_VERBOSE) RNS.log("Browser handling local page: "+str(self.path), RNS.LOG_DEBUG)
page_path = self.app.pagespath+self.path.replace("/page", "", 1) page_path = self.app.pagespath+self.path.replace("/page", "", 1)
RNS.log(page_path)
page_data = b"The requested local page did not exist in the file system" page_data = b"The requested local page did not exist in the file system"
if os.path.isfile(page_path): if os.path.isfile(page_path):
@ -382,10 +430,21 @@ class Browser:
self.page_data = page_data self.page_data = page_data
self.markup = self.page_data.decode("utf-8") self.markup = self.page_data.decode("utf-8")
self.attr_maps = markup_to_attrmaps(self.markup, url_delegate=self) self.attr_maps = markup_to_attrmaps(self.markup, url_delegate=self)
self.response_progress = 0 self.response_progress = 0
self.response_size = None
self.response_transfer_size = None
self.saved_file_name = None
self.update_display() self.update_display()
if not self.history_inc and not self.history_dec and not self.reloading:
self.write_history()
else:
self.history_dec = False
self.history_inc = False
self.reloading = False
def __load(self): def __load(self):
# If an established link exists, but it doesn't match the target # If an established link exists, but it doesn't match the target
@ -495,6 +554,14 @@ class Browser:
self.response_progress = 0 self.response_progress = 0
self.update_display() self.update_display()
if not self.history_inc and not self.history_dec and not self.reloading:
self.write_history()
else:
self.history_dec = False
self.history_inc = False
self.reloading = False
except Exception as e: except Exception as e:
RNS.log("An error occurred while handling response. The contained exception was: "+str(e)) RNS.log("An error occurred while handling response. The contained exception was: "+str(e))

View File

@ -13,7 +13,7 @@ class NetworkDisplayShortcuts():
self.app = app self.app = app
g = app.ui.glyphs g = app.ui.glyphs
self.widget = urwid.AttrMap(urwid.Text("[C-l] Toggle Nodes/Announces view [C-x] Remove entry [C-w] Disconnect remote"), "shortcutbar") self.widget = urwid.AttrMap(urwid.Text("[C-l] Toggle Nodes/Announces view [C-x] Remove entry [C-w] Disconnect [C-d] Back [C-f] Forward [C-r] Reload"), "shortcutbar")
# "[C-"+g["arrow_u"]+g["arrow_d"]+"] Navigate Lists" # "[C-"+g["arrow_u"]+g["arrow_d"]+"] Navigate Lists"