aboutsummaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
authormarty hiatt <martianhiatus [a t] riseup [d o t] net>2022-08-10 14:43:31 +0200
committermarty hiatt <martianhiatus [a t] riseup [d o t] net>2022-08-10 14:49:50 +0200
commit036088469a567caee7630f9538c8fa525e78b6be (patch)
tree777bb600ba466b12bcc91219b37f39e8360b6437 /lisp
parentb7800ee9cd3267e7e5b220feeac459ac8741c8dd (diff)
-tl--do-if-toot macro
Diffstat (limited to 'lisp')
-rw-r--r--lisp/mastodon-tl.el91
1 files changed, 43 insertions, 48 deletions
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el
index 7aef0a1..80a0831 100644
--- a/lisp/mastodon-tl.el
+++ b/lisp/mastodon-tl.el
@@ -1279,28 +1279,31 @@ RESPONSE is the JSON returned by the server."
(mastodon-search--insert-users-propertized response :note)
(goto-char (point-min)))
+(defmacro mastodon--do-if-toot (&rest body)
+ "Execute BODY if we have a toot or user at point."
+ `(if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
+ (not (mastodon-tl--property 'toot-json)))
+ (message "Looks like there's no toot or user at point?")
+ ,@body))
+
(defun mastodon-tl--follow-user (user-handle &optional notify)
"Query for USER-HANDLE from current status and follow that user.
If NOTIFY is \"true\", enable notifications when that user posts.
If NOTIFY is \"false\", disable notifications when that user posts.
Can be called to toggle NOTIFY on users already being followed."
- (interactive
- (list
- (mastodon-tl--interactive-user-handles-get "follow")))
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (mastodon-tl--do-user-action-and-response user-handle "follow" nil notify)))
+ (interactive
+ (list
+ (mastodon-tl--interactive-user-handles-get "follow")))
+ (mastodon--do-if-toot
+ (mastodon-tl--do-user-action-and-response user-handle "follow" nil notify)))
(defun mastodon-tl--enable-notify-user-posts (user-handle)
"Query for USER-HANDLE and enable notifications when they post."
(interactive
(list
(mastodon-tl--interactive-user-handles-get "enable")))
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (mastodon-tl--follow-user user-handle "true")))
+ (mastodon--do-if-toot
+ (mastodon-tl--follow-user user-handle "true")))
(defun mastodon-tl--disable-notify-user-posts (user-handle)
"Query for USER-HANDLE and disable notifications when they post."
@@ -1314,20 +1317,16 @@ Can be called to toggle NOTIFY on users already being followed."
(interactive
(list
(mastodon-tl--interactive-user-handles-get "unfollow")))
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (mastodon-tl--do-user-action-and-response user-handle "unfollow" t)))
+ (mastodon--do-if-toot
+ (mastodon-tl--do-user-action-and-response user-handle "unfollow" t)))
(defun mastodon-tl--block-user (user-handle)
"Query for USER-HANDLE from current status and block that user."
(interactive
(list
(mastodon-tl--interactive-user-handles-get "block")))
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (mastodon-tl--do-user-action-and-response user-handle "block")))
+ (mastodon--do-if-toot
+ (mastodon-tl--do-user-action-and-response user-handle "block")))
(defun mastodon-tl--unblock-user (user-handle)
"Query for USER-HANDLE from list of blocked users and unblock that user."
@@ -1343,10 +1342,8 @@ Can be called to toggle NOTIFY on users already being followed."
(interactive
(list
(mastodon-tl--interactive-user-handles-get "mute")))
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (mastodon-tl--do-user-action-and-response user-handle "mute")))
+ (mastodon--do-if-toot
+ (mastodon-tl--do-user-action-and-response user-handle "mute")))
(defun mastodon-tl--unmute-user (user-handle)
"Query for USER-HANDLE from list of muted users and unmute that user."
@@ -1359,31 +1356,29 @@ Can be called to toggle NOTIFY on users already being followed."
(defun mastodon-tl--interactive-user-handles-get (action)
"Get the list of user-handles for ACTION from the current toot."
- (if (and (not (string-prefix-p "accounts" (mastodon-tl--get-endpoint))) ;profile view
- (not (get-text-property (point) 'toot-json)))
- (message "Looks like there's no toot or user at point?")
- (let ((user-handles
- (cond ((or (equal (buffer-name) "*mastodon-follow-suggestions*")
- ;; follow suggests / search / foll requests compat:
- (string-prefix-p "*mastodon-search" (buffer-name))
- (equal (buffer-name) "*mastodon-follow-requests*")
- ;; profile view follows/followers compat:
- ;; but not for profile statuses:
- (and (string-prefix-p "accounts" (mastodon-tl--get-endpoint))
- (not (string-suffix-p "statuses" (mastodon-tl--get-endpoint)))))
- ;; avoid tl--property here because it calls next-toot
- ;; which breaks non-toot buffers like foll reqs etc.:
- (list (alist-get 'acct (get-text-property (point) 'toot-json))))
- (t
- (mastodon-profile--extract-users-handles
- (mastodon-profile--toot-json))))))
- (completing-read (if (or (equal action "disable")
- (equal action "enable"))
- (format "%s notifications when user posts: " action)
- (format "Handle of user to %s: " action))
- user-handles
- nil ; predicate
- 'confirm))))
+ (mastodon--do-if-toot
+ (let ((user-handles
+ (cond ((or (equal (buffer-name) "*mastodon-follow-suggestions*")
+ ;; follow suggests / search / foll requests compat:
+ (string-prefix-p "*mastodon-search" (buffer-name))
+ (equal (buffer-name) "*mastodon-follow-requests*")
+ ;; profile view follows/followers compat:
+ ;; but not for profile statuses:
+ (and (string-prefix-p "accounts" (mastodon-tl--get-endpoint))
+ (not (string-suffix-p "statuses" (mastodon-tl--get-endpoint)))))
+ ;; avoid tl--property here because it calls next-toot
+ ;; which breaks non-toot buffers like foll reqs etc.:
+ (list (alist-get 'acct (get-text-property (point) 'toot-json))))
+ (t
+ (mastodon-profile--extract-users-handles
+ (mastodon-profile--toot-json))))))
+ (completing-read (if (or (equal action "disable")
+ (equal action "enable"))
+ (format "%s notifications when user posts: " action)
+ (format "Handle of user to %s: " action))
+ user-handles
+ nil ; predicate
+ 'confirm))))
(defun mastodon-tl--interactive-blocks-or-mutes-list-get (action)
"Fetch the list of accounts for ACTION from the server.