Merge pull request #320 from danschwarz/notif
Basic support for viewing Status and Mention notifs as a timeline
This commit is contained in:
commit
c3c640edc3
3 changed files with 33 additions and 2 deletions
19
toot/api.py
19
toot/api.py
|
@ -287,6 +287,18 @@ def _timeline_generator(app, user, path, params=None):
|
||||||
path = _get_next_path(response.headers)
|
path = _get_next_path(response.headers)
|
||||||
|
|
||||||
|
|
||||||
|
def _notif_timeline_generator(app, user, path, params=None):
|
||||||
|
while path:
|
||||||
|
response = http.get(app, user, path, params)
|
||||||
|
notification = response.json()
|
||||||
|
statuses = []
|
||||||
|
for n in notification:
|
||||||
|
if n['status']:
|
||||||
|
statuses.append(n['status'])
|
||||||
|
yield statuses
|
||||||
|
path = _get_next_path(response.headers)
|
||||||
|
|
||||||
|
|
||||||
def home_timeline_generator(app, user, limit=20):
|
def home_timeline_generator(app, user, limit=20):
|
||||||
path = "/api/v1/timelines/home"
|
path = "/api/v1/timelines/home"
|
||||||
params = {"limit": limit}
|
params = {"limit": limit}
|
||||||
|
@ -311,6 +323,13 @@ def bookmark_timeline_generator(app, user, limit=20):
|
||||||
return _timeline_generator(app, user, path, params)
|
return _timeline_generator(app, user, path, params)
|
||||||
|
|
||||||
|
|
||||||
|
def notification_timeline_generator(app, user, limit=20):
|
||||||
|
# exclude all but mentions and statuses
|
||||||
|
exclude_types = ["follow", "favourite", "reblog", "poll", "follow_request"]
|
||||||
|
params = {"exclude_types[]": exclude_types, "limit": limit}
|
||||||
|
return _notif_timeline_generator(app, user, '/api/v1/notifications', params)
|
||||||
|
|
||||||
|
|
||||||
def timeline_list_generator(app, user, list_id, limit=20):
|
def timeline_list_generator(app, user, list_id, limit=20):
|
||||||
path = f"/api/v1/timelines/list/{list_id}"
|
path = f"/api/v1/timelines/list/{list_id}"
|
||||||
return _timeline_generator(app, user, path, {'limit': limit})
|
return _timeline_generator(app, user, path, {'limit': limit})
|
||||||
|
|
|
@ -438,13 +438,14 @@ class TUI(urwid.Frame):
|
||||||
lambda x, local: self.goto_public_timeline(local))
|
lambda x, local: self.goto_public_timeline(local))
|
||||||
urwid.connect_signal(menu, "bookmark_timeline",
|
urwid.connect_signal(menu, "bookmark_timeline",
|
||||||
lambda x, local: self.goto_bookmarks())
|
lambda x, local: self.goto_bookmarks())
|
||||||
|
urwid.connect_signal(menu, "notification_timeline",
|
||||||
|
lambda x, local: self.goto_notifications())
|
||||||
urwid.connect_signal(menu, "hashtag_timeline",
|
urwid.connect_signal(menu, "hashtag_timeline",
|
||||||
lambda x, tag, local: self.goto_tag_timeline(tag, local=local))
|
lambda x, tag, local: self.goto_tag_timeline(tag, local=local))
|
||||||
|
|
||||||
self.open_overlay(menu, title="Go to", options=dict(
|
self.open_overlay(menu, title="Go to", options=dict(
|
||||||
align="center", width=("relative", 60),
|
align="center", width=("relative", 60),
|
||||||
valign="middle", height=10 + len(user_timelines),
|
valign="middle", height=11 + len(user_timelines),
|
||||||
))
|
))
|
||||||
|
|
||||||
def show_help(self):
|
def show_help(self):
|
||||||
|
@ -474,6 +475,12 @@ class TUI(urwid.Frame):
|
||||||
promise = self.async_load_timeline(is_initial=True, timeline_name="bookmarks")
|
promise = self.async_load_timeline(is_initial=True, timeline_name="bookmarks")
|
||||||
promise.add_done_callback(lambda *args: self.close_overlay())
|
promise.add_done_callback(lambda *args: self.close_overlay())
|
||||||
|
|
||||||
|
def goto_notifications(self):
|
||||||
|
self.timeline_generator = api.notification_timeline_generator(
|
||||||
|
self.app, self.user, limit=40)
|
||||||
|
promise = self.async_load_timeline(is_initial=True, timeline_name="notifications")
|
||||||
|
promise.add_done_callback(lambda *args: self.close_overlay())
|
||||||
|
|
||||||
def goto_tag_timeline(self, tag, local):
|
def goto_tag_timeline(self, tag, local):
|
||||||
self.timeline_generator = api.tag_timeline_generator(
|
self.timeline_generator = api.tag_timeline_generator(
|
||||||
self.app, self.user, tag, local=local, limit=40)
|
self.app, self.user, tag, local=local, limit=40)
|
||||||
|
|
|
@ -100,6 +100,7 @@ class GotoMenu(urwid.ListBox):
|
||||||
"public_timeline",
|
"public_timeline",
|
||||||
"hashtag_timeline",
|
"hashtag_timeline",
|
||||||
"bookmark_timeline",
|
"bookmark_timeline",
|
||||||
|
"notification_timeline",
|
||||||
]
|
]
|
||||||
|
|
||||||
def __init__(self, user_timelines):
|
def __init__(self, user_timelines):
|
||||||
|
@ -125,6 +126,9 @@ class GotoMenu(urwid.ListBox):
|
||||||
def _bookmarks(button):
|
def _bookmarks(button):
|
||||||
self._emit("bookmark_timeline", False)
|
self._emit("bookmark_timeline", False)
|
||||||
|
|
||||||
|
def _notifications(button):
|
||||||
|
self._emit("notification_timeline", False)
|
||||||
|
|
||||||
def _hashtag(local):
|
def _hashtag(local):
|
||||||
hashtag = self.get_hashtag()
|
hashtag = self.get_hashtag()
|
||||||
if hashtag:
|
if hashtag:
|
||||||
|
@ -147,6 +151,7 @@ class GotoMenu(urwid.ListBox):
|
||||||
yield Button("Local public timeline", on_press=_local_public)
|
yield Button("Local public timeline", on_press=_local_public)
|
||||||
yield Button("Global public timeline", on_press=_global_public)
|
yield Button("Global public timeline", on_press=_global_public)
|
||||||
yield Button("Bookmarks", on_press=_bookmarks)
|
yield Button("Bookmarks", on_press=_bookmarks)
|
||||||
|
yield Button("Notifications", on_press=_notifications)
|
||||||
yield urwid.Divider()
|
yield urwid.Divider()
|
||||||
yield self.hash_edit
|
yield self.hash_edit
|
||||||
yield Button("Local hashtag timeline", on_press=lambda x: _hashtag(True))
|
yield Button("Local hashtag timeline", on_press=lambda x: _hashtag(True))
|
||||||
|
|
Loading…
Reference in a new issue