1
0
mirror of https://github.com/ihabunek/toot synced 2025-01-27 09:41:26 +01:00

Merge pull request #330 from rogarb/conversations

Add conversations support in TUI
This commit is contained in:
Ivan Habunek 2023-03-05 11:34:18 +01:00 committed by GitHub
commit 04beac87ed
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 30 additions and 0 deletions

View File

@ -293,6 +293,14 @@ def _notification_timeline_generator(app, user, path, params=None):
path = _get_next_path(response.headers)
def _conversation_timeline_generator(app, user, path, params=None):
while path:
response = http.get(app, user, path, params)
conversation = response.json()
yield [c["last_status"] for c in conversation if c["last_status"]]
path = _get_next_path(response.headers)
def home_timeline_generator(app, user, limit=20):
path = "/api/v1/timelines/home"
params = {"limit": limit}
@ -324,6 +332,12 @@ def notification_timeline_generator(app, user, limit=20):
return _notification_timeline_generator(app, user, "/api/v1/notifications", params)
def conversation_timeline_generator(app, user, limit=20):
path = "/api/v1/conversations"
params = {"limit": limit}
return _conversation_timeline_generator(app, user, path, params)
def timeline_list_generator(app, user, list_id, limit=20):
path = f"/api/v1/timelines/list/{list_id}"
return _timeline_generator(app, user, path, {'limit': limit})

View File

@ -440,6 +440,8 @@ class TUI(urwid.Frame):
lambda x, local: self.goto_bookmarks())
urwid.connect_signal(menu, "notification_timeline",
lambda x, local: self.goto_notifications())
urwid.connect_signal(menu, "conversation_timeline",
lambda x, local: self.goto_conversations())
urwid.connect_signal(menu, "hashtag_timeline",
lambda x, tag, local: self.goto_tag_timeline(tag, local=local))
@ -481,6 +483,15 @@ class TUI(urwid.Frame):
promise = self.async_load_timeline(is_initial=True, timeline_name="notifications")
promise.add_done_callback(lambda *args: self.close_overlay())
def goto_conversations(self):
self.timeline_generator = api.conversation_timeline_generator(
self.app, self.user, limit=40
)
promise = self.async_load_timeline(
is_initial=True, timeline_name="conversations"
)
promise.add_done_callback(lambda *args: self.close_overlay())
def goto_tag_timeline(self, tag, local):
self.timeline_generator = api.tag_timeline_generator(
self.app, self.user, tag, local=local, limit=40)

View File

@ -101,6 +101,7 @@ class GotoMenu(urwid.ListBox):
"hashtag_timeline",
"bookmark_timeline",
"notification_timeline",
"conversation_timeline",
]
def __init__(self, user_timelines):
@ -129,6 +130,9 @@ class GotoMenu(urwid.ListBox):
def _notifications(button):
self._emit("notification_timeline", False)
def _conversations(button):
self._emit("conversation_timeline", False)
def _hashtag(local):
hashtag = self.get_hashtag()
if hashtag:
@ -152,6 +156,7 @@ class GotoMenu(urwid.ListBox):
yield Button("Global public timeline", on_press=_global_public)
yield Button("Bookmarks", on_press=_bookmarks)
yield Button("Notifications", on_press=_notifications)
yield Button("Conversations", on_press=_conversations)
yield urwid.Divider()
yield self.hash_edit
yield Button("Local hashtag timeline", on_press=lambda x: _hashtag(True))