integrate post editor a'la thread reply

pull/4/head
Blake DeMarcy 2017-04-15 12:09:04 -05:00
parent eba2128e98
commit 2cc3fdc1e7
1 changed files with 40 additions and 41 deletions

View File

@ -415,9 +415,6 @@ class App(object):
) )
def edit_post(self, button, message): def edit_post(self, button, message):
post_id = message["post_id"] post_id = message["post_id"]
thread_id = message["thread_id"] thread_id = message["thread_id"]
@ -428,21 +425,8 @@ class App(object):
except UserWarning as e: except UserWarning as e:
self.remove_overlays() self.remove_overlays()
return self.temp_footer_message(e.description) return self.temp_footer_message(e.description)
self.remove_overlays()
self.loop.widget = urwid.Overlay( self.compose(init_body=message["body"], edit=message)
urwid.LineBox(
ExternalEditor(
"edit_post",
init_body=message["body"],
post_id=post_id,
thread_id=thread_id),
title="[F1]Abort [F3]Formatting Help (save/quit to commit)",
**frame_theme()),
self.loop.widget,
align="center",
valign="middle",
width=("relative", 75),
height=("relative", 75))
def reply(self, button, message): def reply(self, button, message):
@ -1044,7 +1028,7 @@ class App(object):
return body.strip() return body.strip()
def compose(self, title=None, init_body=""): def compose(self, title=None, init_body="", edit=False):
""" """
Dispatches the appropriate composure mode and widget based on application Dispatches the appropriate composure mode and widget based on application
context and user preferences. context and user preferences.
@ -1058,20 +1042,28 @@ class App(object):
return self.footer_prompt( return self.footer_prompt(
"Title", self.compose, extra_text=e.description) "Title", self.compose, extra_text=e.description)
if self.prefs["editor"] and not self.prefs["integrate_external_editor"]: if not self.prefs["integrate_external_editor"]:
body = self.overthrow_ext_edit(init_body) body = self.overthrow_ext_edit(init_body)
if not body: if not body:
return self.temp_footer_message("EMPTY POST DISCARDED") return self.temp_footer_message("EMPTY POST DISCARDED")
params = {"body": body} params = {"body": body}
if self.mode == "thread": if self.mode == "thread" and not edit:
endpoint = "reply" endpoint = "thread_reply"
params.update({"thread_id": self.thread["thread_id"]}) params.update({"thread_id": self.thread["thread_id"]})
elif edit:
endpoint = "edit_post"
params.update({
"thread_id": self.thread["thread_id"],
"post_id": edit["post_id"]
})
else: else:
endpoint = "create" endpoint = "thread_create"
params.update({"title": title}) params.update({"title": title})
network.request("thread_" + endpoint, **params) network.request(endpoint, **params)
return self.refresh(True) return self.refresh(True)
if self.mode == "index": if self.mode == "index":
@ -1088,22 +1080,29 @@ class App(object):
width=("relative", 90), width=("relative", 90),
height=("relative", 80)) height=("relative", 80))
elif self.mode == "thread": params = {"thread_id": self.thread["thread_id"]}
self.window_split=True
self.set_header('Replying to "{}"', self.thread["title"]) if edit:
_id = edit["post_id"]
params.update({"post_id": _id})
header = ["Editing your post; >>{}", _id]
endpoint = "edit_post"
else:
header = ['Replying to "{}"', self.thread["title"]]
endpoint = "thread_reply"
self.loop.widget.footer = urwid.Pile([ self.loop.widget.footer = urwid.Pile([
urwid.AttrMap(urwid.Text(""), "bar"), urwid.AttrMap(urwid.Text(""), "bar"),
urwid.BoxAdapter( urwid.BoxAdapter(
urwid.AttrMap( urwid.AttrMap(
urwid.LineBox( urwid.LineBox(
ExternalEditor( ExternalEditor(endpoint, init_body=init_body, **params),
"thread_reply",
init_body=init_body,
thread_id=self.thread["thread_id"]),
**frame_theme() **frame_theme()
), ), "bar"),
"bar"),
self.loop.screen_size[1] // 2)]) self.loop.screen_size[1] // 2)])
self.set_header(*header)
self.window_split=True
self.switch_editor() self.switch_editor()