mirror of
https://gitlab.com/brutaldon/brutaldon.git
synced 2025-01-03 14:56:25 -05:00
Add back support for backwards paging
This commit is contained in:
parent
8dbebea29a
commit
5c11d3c871
@ -40,7 +40,7 @@
|
|||||||
{% if next %}
|
{% if next %}
|
||||||
<p class="column is-one-quarter"></p>
|
<p class="column is-one-quarter"></p>
|
||||||
<p class="column">
|
<p class="column">
|
||||||
<a class="pagination-previous is-fullwidth button"
|
<a class="pagination-previous is-one-quarter"
|
||||||
href="{% url 'home_next' next.max_id %}"
|
href="{% url 'home_next' next.max_id %}"
|
||||||
{% if preferences.click_to_load %}
|
{% if preferences.click_to_load %}
|
||||||
ic-get-from="{% url 'home_next' next.max_id %}"
|
ic-get-from="{% url 'home_next' next.max_id %}"
|
||||||
@ -53,7 +53,14 @@
|
|||||||
Older
|
Older
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
<p class="column is-one-quarter"></p>
|
{% endif %}
|
||||||
|
{% if prev %}
|
||||||
|
<p class="column is-one-quarter">
|
||||||
|
<a class="pagination-next iss-fullwidth button"
|
||||||
|
href="{% url 'home_prev' prev.min_id %}">
|
||||||
|
Newer
|
||||||
|
</a>
|
||||||
|
</p>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -117,16 +117,16 @@ def user_search_inner(request, query):
|
|||||||
{'active_users': "\n".join([ user.acct for user in results.accounts ]),
|
{'active_users': "\n".join([ user.acct for user in results.accounts ]),
|
||||||
'preferences': account.preferences })
|
'preferences': account.preferences })
|
||||||
|
|
||||||
def timeline(request, timeline='home', timeline_name='Home', max_id=None, since_id=None, filter_context='home'):
|
def timeline(request, timeline='home', timeline_name='Home', max_id=None, min_id=None, filter_context='home'):
|
||||||
account, mastodon = get_usercontext(request)
|
account, mastodon = get_usercontext(request)
|
||||||
data = mastodon.timeline(timeline, limit=40, max_id=max_id, since_id=since_id)
|
data = mastodon.timeline(timeline, limit=40, max_id=max_id, min_id=min_id)
|
||||||
form = PostForm(initial={'visibility': request.session['active_user'].source.privacy})
|
form = PostForm(initial={'visibility': request.session['active_user'].source.privacy})
|
||||||
try:
|
try:
|
||||||
prev = data[0]._pagination_prev
|
prev = data[0]._pagination_prev
|
||||||
if len(mastodon.timeline(since_id=prev['since_id'])) == 0:
|
if len(mastodon.timeline(min_id=prev['min_id'])) == 0:
|
||||||
prev = None
|
prev = None
|
||||||
else:
|
else:
|
||||||
prev['since_id'] = data[0].id
|
prev['min_id'] = data[0].id
|
||||||
except (IndexError, AttributeError, KeyError):
|
except (IndexError, AttributeError, KeyError):
|
||||||
prev = None
|
prev = None
|
||||||
try:
|
try:
|
||||||
@ -236,15 +236,15 @@ def notes_count(request):
|
|||||||
|
|
||||||
@br_login_required
|
@br_login_required
|
||||||
def home(request, next=None, prev=None):
|
def home(request, next=None, prev=None):
|
||||||
return timeline(request, 'home', 'Home', max_id=next, since_id=prev, filter_context='home')
|
return timeline(request, 'home', 'Home', max_id=next, min_id=prev, filter_context='home')
|
||||||
|
|
||||||
@br_login_required
|
@br_login_required
|
||||||
def local(request, next=None, prev=None, filter_context='public'):
|
def local(request, next=None, prev=None, filter_context='public'):
|
||||||
return timeline(request, 'local', 'Local', max_id=next, since_id=prev)
|
return timeline(request, 'local', 'Local', max_id=next, min_id=prev)
|
||||||
|
|
||||||
@br_login_required
|
@br_login_required
|
||||||
def fed(request, next=None, prev=None, filter_context='public'):
|
def fed(request, next=None, prev=None, filter_context='public'):
|
||||||
return timeline(request, 'public', 'Federated', max_id=next, since_id=prev)
|
return timeline(request, 'public', 'Federated', max_id=next, min_id=prev)
|
||||||
|
|
||||||
@br_login_required
|
@br_login_required
|
||||||
def tag(request, tag):
|
def tag(request, tag):
|
||||||
@ -457,7 +457,7 @@ def note(request, next=None, prev=None):
|
|||||||
account.note_seen = last_seen.id
|
account.note_seen = last_seen.id
|
||||||
account.save()
|
account.save()
|
||||||
|
|
||||||
notes = mastodon.notifications(limit=40, max_id=next, since_id=prev)
|
notes = mastodon.notifications(limit=40, max_id=next, min_id=prev)
|
||||||
filters = get_filters(mastodon, context='notifications')
|
filters = get_filters(mastodon, context='notifications')
|
||||||
|
|
||||||
if account.preferences.filter_notifications:
|
if account.preferences.filter_notifications:
|
||||||
@ -468,7 +468,7 @@ def note(request, next=None, prev=None):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
prev = notes[0]._pagination_prev
|
prev = notes[0]._pagination_prev
|
||||||
if len(mastodon.notifications(since_id=prev['since_id'])) == 0:
|
if len(mastodon.notifications(min_id=prev['min_id'])) == 0:
|
||||||
prev = None
|
prev = None
|
||||||
except (IndexError, AttributeError, KeyError):
|
except (IndexError, AttributeError, KeyError):
|
||||||
prev = None
|
prev = None
|
||||||
@ -520,13 +520,13 @@ def user(request, username, prev=None, next=None):
|
|||||||
username.split('@')[1] == account.username.split('@')[1]))][0]
|
username.split('@')[1] == account.username.split('@')[1]))][0]
|
||||||
except (IndexError, AttributeError):
|
except (IndexError, AttributeError):
|
||||||
raise Http404(_("The user %s could not be found.") % username)
|
raise Http404(_("The user %s could not be found.") % username)
|
||||||
data = mastodon.account_statuses(user_dict.id, max_id=next, since_id=prev)
|
data = mastodon.account_statuses(user_dict.id, max_id=next, min_id=prev)
|
||||||
relationship = mastodon.account_relationships(user_dict.id)[0]
|
relationship = mastodon.account_relationships(user_dict.id)[0]
|
||||||
notifications = _notes_count(account, mastodon)
|
notifications = _notes_count(account, mastodon)
|
||||||
try:
|
try:
|
||||||
prev = data[0]._pagination_prev
|
prev = data[0]._pagination_prev
|
||||||
if len(mastodon.account_statuses(user_dict.id,
|
if len(mastodon.account_statuses(user_dict.id,
|
||||||
since_id=prev['since_id'])) == 0:
|
min_id=prev['min_id'])) == 0:
|
||||||
prev = None
|
prev = None
|
||||||
except (IndexError, AttributeError, KeyError):
|
except (IndexError, AttributeError, KeyError):
|
||||||
prev = None
|
prev = None
|
||||||
|
Loading…
Reference in New Issue
Block a user