integrate post editor a'la thread reply
parent
eba2128e98
commit
2cc3fdc1e7
|
@ -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()
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue