aboutsummaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
authormousebot <mousebot@riseup.net>2021-05-08 21:20:33 +0200
committermousebot <mousebot@riseup.net>2021-05-09 11:24:31 +0200
commitc69bf45a170a28934d18b762960845e773922514 (patch)
tree0cabff2b0f5ea3a650270c7a6c006351104f981b /lisp
parent4b4f45e4e3f09c065e547ff5def03bde7e42de2d (diff)
async view profile, async view thread, better prompts
- view profile (using make-profile-buffer-for). - user confirm to delete toot. - better follow/mute/block/profile prompts
Diffstat (limited to 'lisp')
-rw-r--r--lisp/mastodon-profile.el13
-rw-r--r--lisp/mastodon-tl.el35
-rw-r--r--lisp/mastodon.el3
3 files changed, 31 insertions, 20 deletions
diff --git a/lisp/mastodon-profile.el b/lisp/mastodon-profile.el
index aed33a7..2c6b798 100644
--- a/lisp/mastodon-profile.el
+++ b/lisp/mastodon-profile.el
@@ -102,12 +102,17 @@ following the current profile."
(defun mastodon-profile--make-profile-buffer-for (account endpoint-type update-function)
(let* ((id (mastodon-profile--account-field account 'id))
- (acct (mastodon-profile--account-field account 'acct))
(url (mastodon-http--api (format "accounts/%s/%s"
- id endpoint-type)))
+ 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))
(buffer (concat "*mastodon-" acct "-" endpoint-type "*"))
(note (mastodon-profile--account-field account 'note))
- (json (mastodon-http--get-json url))
+ (id (mastodon-profile--account-field account 'id))
(fol_count (mastodon-tl--as-string (mastodon-profile--account-field account 'followers_count)))
(folling_count (mastodon-tl--as-string (mastodon-profile--account-field account 'following_count)))
(toots_count (mastodon-tl--as-string (mastodon-profile--account-field account 'statuses_count))))
@@ -175,7 +180,7 @@ following the current profile."
(list
(let ((user-handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))
- (completing-read "User handle: "
+ (completing-read "View profile of user: "
user-handles
nil ; predicate
'confirm))))
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el
index a1c6495..b44b160 100644
--- a/lisp/mastodon-tl.el
+++ b/lisp/mastodon-tl.el
@@ -771,14 +771,18 @@ webapp"
(if reblog (cdr (assoc 'id reblog)) id)))
(defun mastodon-tl--thread ()
- "Open thread buffer for toot under `point'."
+ "Open thread buffer for toot under `point' asynchronously."
(interactive)
(let* ((id (mastodon-tl--as-string (mastodon-tl--toot-id
(mastodon-tl--property 'toot-json))))
- (url (mastodon-http--api (format "statuses/%s/context" id)))
- (buffer (format "*mastodon-thread-%s*" id))
(toot (mastodon-tl--property 'toot-json))
- (context (mastodon-http--get-json url)))
+ (buffer (format "*mastodon-thread-%s*" id))
+ (url (mastodon-http--api (format "statuses/%s/context" id))))
+ (mastodon-http--get-json-async url
+ 'mastodon-tl--thread* id toot buffer)))
+
+(defun mastodon-tl--thread* (context id toot buffer)
+ (interactive)
(when (member (cdr (assoc 'type toot)) '("reblog" "favourite"))
(setq toot (cdr (assoc 'status toot))))
(if (> (+ (length (cdr (assoc 'ancestors context)))
@@ -797,7 +801,7 @@ webapp"
(cdr (assoc 'ancestors context))
`(,toot)
(cdr (assoc 'descendants context))))))
- (message "No Thread!"))))
+ (message "No Thread!")));)
(defun mastodon-tl--delete-toot ()
"Delete user's toot at point synchronously."
@@ -805,10 +809,11 @@ webapp"
(let* ((id (mastodon-tl--as-string (mastodon-tl--toot-id
(mastodon-tl--property 'toot-json))))
(url (mastodon-http--api (format "statuses/%s" id))))
- (let ((response (mastodon-http--delete url)))
- (mastodon-http--triage response
- (lambda ()
- (message "Toot deleted! There may be a delay before it disappears from your profile."))))))
+ (when (y-or-n-p (format "Delete this toot? "))
+ (let ((response (mastodon-http--delete url)))
+ (mastodon-http--triage response
+ (lambda ()
+ (message "Toot deleted! There may be a delay before it disappears from your profile.")))))))
(defun mastodon-tl--follow-user (user-handle)
"Query for user id from current status and follow that user."
@@ -816,7 +821,7 @@ webapp"
(list
(let ((user-handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))
- (completing-read "User handle: "
+ (completing-read "Handle of user to follow: "
user-handles
nil ; predicate
'confirm))))
@@ -838,7 +843,7 @@ webapp"
(list
(let ((user-handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))
- (completing-read "User handle: "
+ (completing-read "Handle of user to unfollow: "
user-handles
nil ; predicate
'confirm))))
@@ -861,7 +866,7 @@ webapp"
(list
(let ((user-handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))
- (completing-read "User handle: "
+ (completing-read "Handle of user to mute: "
user-handles
nil ; predicate
'confirm))))
@@ -887,7 +892,7 @@ webapp"
(muted-accts (mapcar (lambda (muted)
(cdr (assoc 'acct muted)))
mutes-json)))
- (completing-read "Unmute user: "
+ (completing-read "Handle of user to unmute: "
muted-accts
nil ; predicate
t))))
@@ -910,7 +915,7 @@ webapp"
(list
(let ((user-handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json))))
- (completing-read "User handle: "
+ (completing-read "Handle of user to block: "
user-handles
nil ; predicate
'confirm))))
@@ -936,7 +941,7 @@ webapp"
(blocked-accts (mapcar (lambda (blocked)
(cdr (assoc 'acct blocked)))
blocks-json)))
- (completing-read "Unblock user: "
+ (completing-read "Handle of user to unblock: "
blocked-accts
nil ; predicate
t))))
diff --git a/lisp/mastodon.el b/lisp/mastodon.el
index 929ae8c..7cd673b 100644
--- a/lisp/mastodon.el
+++ b/lisp/mastodon.el
@@ -106,7 +106,8 @@ Use. e.g. \"%c\" for your locale's date and time format."
(define-key map (kbd "t") #'mastodon-toot)
;; override special mode binding
(define-key map (kbd "g") #'undefined)
- (define-key map (kbd "D") #'mastodon-tl--delete-toot)
+ ;; mousebot additions
+ (define-key map (kbd "d") #'mastodon-tl--delete-toot)
(define-key map (kbd "W") #'mastodon-tl--follow-user)
(define-key map (kbd "C-S-W") #'mastodon-tl--unfollow-user)
(define-key map (kbd "B") #'mastodon-tl--block-user)