aboutsummaryrefslogtreecommitdiff
path: root/lisp
diff options
context:
space:
mode:
authormarty hiatt <martianhiatus [a t] riseup [d o t] net>2022-11-28 14:39:59 +0100
committermarty hiatt <martianhiatus [a t] riseup [d o t] net>2022-11-28 14:39:59 +0100
commite8797f4769248ab79bab4e30548b4796eefd2520 (patch)
treea51896f397b5e2e710f9546793bc1b495ffc9252 /lisp
parentb6dd92225bfef4bfdbc229791d1c863335d2f403 (diff)
add remove-from-followers via list of 100 followers.
Diffstat (limited to 'lisp')
-rw-r--r--lisp/mastodon-profile.el33
1 files changed, 26 insertions, 7 deletions
diff --git a/lisp/mastodon-profile.el b/lisp/mastodon-profile.el
index c2c58f6..d0b7179 100644
--- a/lisp/mastodon-profile.el
+++ b/lisp/mastodon-profile.el
@@ -77,6 +77,7 @@
(autoload 'mastodon-tl--get-link-header-from-response "mastodon-tl")
(autoload 'mastodon-tl--set-buffer-spec "mastodon-tl")
(autoload 'mastodon-tl--symbol "mastodon-tl")
+(autoload 'mastodon-auth--get-account-id "mastodon-auth")
(defvar mastodon-instance-url)
(defvar mastodon-tl--buffer-spec)
@@ -575,14 +576,14 @@ NO-REBLOGS means do not display boosts in statuses.
HEADERS means also fetch link headers for pagination."
(let* ((id (mastodon-profile--account-field account 'id))
(args (when no-reblogs '(("exclude_reblogs" . "t"))))
- (url (mastodon-http--api (format "accounts/%s/%s" id endpoint-type)))
+ (endpoint (format "accounts/%s/%s" id endpoint-type))
+ (url (mastodon-http--api endpoint))
(acct (mastodon-profile--account-field account 'acct))
(buffer (concat "*mastodon-" acct "-" endpoint-type "*"))
(response (if headers
(mastodon-http--get-response url args)
(mastodon-http--get-json url args)))
(json (if headers (car response) response))
- (endpoint (format "accounts/%s/%s" id endpoint-type))
(link-header (when headers
(mastodon-tl--get-link-header-from-response
(cdr response))))
@@ -842,11 +843,9 @@ These include the author, author of reblogged entries and any user mentioned."
(defun mastodon-profile--remove-user-from-followers (&optional id)
"Remove a user from your followers.
-User may be the current profile page if not your own, or the
-account ('toot-json) at point if you are on your own profile page (followers)."
+Optionally provide the ID of the account to remove."
(interactive)
(let* ((account (unless id (get-text-property (point) 'toot-json)))
- ;; TODO: read account from list of all followers' handles
(id (or id (alist-get 'id account)))
(handle (if account
(alist-get 'acct account)
@@ -861,8 +860,8 @@ account ('toot-json) at point if you are on your own profile page (followers)."
(lambda ()
(message "Follower %s removed!" handle)))))))
-(defun mastodon-profile--remove-from-followers-toot-at-point ()
- "Prompt for a user in the toot at point and remove from followers."
+(defun mastodon-profile--remove-from-followers-at-point ()
+ "Prompt for a user in the item at point and remove from followers."
(interactive)
(let* ((handles (mastodon-profile--extract-users-handles
(mastodon-profile--toot-json)))
@@ -873,5 +872,25 @@ account ('toot-json) at point if you are on your own profile page (followers)."
(id (alist-get 'id account)))
(mastodon-profile--remove-user-from-followers id)))
+(defun mastodon-profile--remove-from-followers-list ()
+ "Select a user from your followers and remove from followers.
+Currently limited to 100 handles. If not found, try
+`mastodon-search--search-query'."
+ (interactive)
+ (let* ((endpoint (format "accounts/%s/followers"
+ (mastodon-auth--get-account-id)))
+ (url (mastodon-http--api endpoint))
+ (response (mastodon-http--get-json url
+ `(("limit" . "100"))))
+ (handles (mapcar (lambda (x)
+ (cons
+ (alist-get 'acct x)
+ (alist-get 'id x)))
+ response))
+ (choice (completing-read "Remove from followers: "
+ handles))
+ (id (alist-get choice handles nil nil 'equal)))
+ (mastodon-profile--remove-user-from-followers id)))
+
(provide 'mastodon-profile)
;;; mastodon-profile.el ends here