aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormousebot <mousebot@riseup.net>2021-05-19 23:15:11 +0200
committermousebot <mousebot@riseup.net>2021-05-21 11:32:30 +0200
commit837d50d68c523c9f197436b86b9d681ed7f59831 (patch)
treeaf913b741dd1c902736963bba45ec2b9171b8779
parent61110d230b6e9aa692d75c1bec436fe947fad3a8 (diff)
pinned toots implemented properly, make-buffer-for revert to synchro
better pinned toots formatting
-rw-r--r--lisp/mastodon-profile.el38
-rw-r--r--lisp/mastodon-tl.el19
2 files changed, 26 insertions, 31 deletions
diff --git a/lisp/mastodon-profile.el b/lisp/mastodon-profile.el
index 8c1432b..16ef981 100644
--- a/lisp/mastodon-profile.el
+++ b/lisp/mastodon-profile.el
@@ -48,7 +48,6 @@
(autoload 'mastodon-tl--set-face "mastodon-tl.el")
(autoload 'mastodon-tl--timeline "mastodon-tl.el")
(autoload 'mastodon-tl--as-string "mastodon-tl.el")
-(autoload 'mastodon-tl--timeline-pinned "mastodon-tl.el")
(autoload 'mastodon-tl--toot-id "mastodon-tl")
(defvar mastodon-instance-url)
@@ -80,7 +79,7 @@ extra keybindings."
(defun mastodon-profile--make-author-buffer (account)
"Take a ACCOUNT and inserts a user account into a new buffer."
(mastodon-profile--make-profile-buffer-for
- account "statuses" #'mastodon-tl--timeline-pinned))
+ account "statuses" #'mastodon-tl--timeline))
(defun mastodon-profile--open-following ()
"Open a profile buffer for the current profile showing the accounts
@@ -147,19 +146,27 @@ Returns a list of lists."
nil))
fields "")))
+(defun mastodon-profile--get-statuses-pinned (account)
+ "Fetch the pinned toots for ACCOUNT."
+ (let* ((id (mastodon-profile--account-field account 'id))
+ (url (mastodon-http--api (format "accounts/%s/statuses?pinned=true" id))))
+ (mastodon-http--get-json url)))
+
+(defun mastodon-profile--insert-statuses-pinned (pinned-statuses)
+ "Insert each of the PINNED_STATUSES for a given account."
+ (mapc (lambda (pinned-status)
+ (insert (mastodon-tl--set-face
+ " :pinned: " 'success))
+ (mastodon-tl--toot pinned-status))
+ pinned-statuses))
+
(defun mastodon-profile--make-profile-buffer-for (account endpoint-type update-function)
(let* ((id (mastodon-profile--account-field account 'id))
- (url (mastodon-http--api (format "accounts/%s/%s"
- id endpoint-type))))
- (mastodon-http--get-json-async url
- 'mastodon-profile--make-profile-buffer-for*
- account endpoint-type update-function)))
-
-(defun mastodon-profile--make-profile-buffer-for* (json account endpoint-type update-function)
- (let* ((acct (mastodon-profile--account-field account 'acct))
+ (url (mastodon-http--api (format "accounts/%s/%s" id endpoint-type)))
+ (acct (mastodon-profile--account-field account 'acct))
(buffer (concat "*mastodon-" acct "-" endpoint-type "*"))
(note (mastodon-profile--account-field account 'note))
- (id (mastodon-profile--account-field account 'id))
+ (json (mastodon-http--get-json url))
(followers-count (mastodon-tl--as-string
(mastodon-profile--account-field
account 'followers_count)))
@@ -174,7 +181,8 @@ Returns a list of lists."
(follows-you (cdr (assoc 'followed_by
(aref (mastodon-profile--relationships-get id) 0))))
(followsp (or (equal follows-you 't) (equal followed-by-you 't)))
- (fields (mastodon-profile--fields-get account)))
+ (fields (mastodon-profile--fields-get account))
+ (pinned (mastodon-profile--get-statuses-pinned account)))
(with-output-to-temp-buffer buffer
(switch-to-buffer buffer)
(mastodon-mode)
@@ -212,6 +220,7 @@ Returns a list of lists."
'success)
"\n"))
"")
+ ;; insert counts
(mastodon-tl--set-face
(concat " ------------\n"
" TOOTS: " toots-count " | "
@@ -219,6 +228,7 @@ Returns a list of lists."
"FOLLOWING: " following-count "\n"
" ------------\n\n")
'success)
+ ;; insert relationship (follows)
(if followsp
(mastodon-tl--set-face
(concat (if (equal follows-you 't)
@@ -228,6 +238,7 @@ Returns a list of lists."
"\n\n")
'success)
"") ; if no followsp we still need str-or-char-p for insert
+ ;; insert endpoint
(mastodon-tl--set-face
(concat " ------------\n"
endpoint-name "\n"
@@ -235,6 +246,9 @@ Returns a list of lists."
'success))
(setq mastodon-tl--update-point (point))
(mastodon-media--inline-images (point-min) (point))
+ ;; insert pinned toots first
+ (if pinned
+ (mastodon-profile--insert-statuses-pinned pinned))
(funcall update-function json)))
(mastodon-tl--goto-next-toot)))
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el
index 4e0c031..4931913 100644
--- a/lisp/mastodon-tl.el
+++ b/lisp/mastodon-tl.el
@@ -678,25 +678,6 @@ it is `mastodon-tl--byline-boosted'"
(mapc 'mastodon-tl--toot toots)
(goto-char (point-min)))
-(defun mastodon-tl--timeline-pinned (toots)
- "Display each toot in TOOTS.
-
-If any toots are pinned, display them first."
- (let ((pinned-list))
- (mapc (lambda (toot)
- (when (equal (cdr (assoc 'pinned toot)) 't)
- (push toot pinned-list)))
- toots)
- (when pinned-list
- (progn
- (insert (mastodon-tl--set-face
- " :pinned: " 'success))
- (mapc 'mastodon-tl--toot pinned-list)
- (insert (mastodon-tl--set-face
- " :end-pinned: \n" 'success))))
- (mapc 'mastodon-tl--toot toots)
- (goto-char (point-min))))
-
(defun mastodon-tl--get-update-function (&optional buffer)
"Get the UPDATE-FUNCTION stored in `mastodon-tl--buffer-spec'"
(mastodon-tl--get-buffer-property 'update-function buffer))