aboutsummaryrefslogtreecommitdiff
path: root/lisp/mastodon-toot.el
diff options
context:
space:
mode:
authormousebot <mousebot@riseup.net>2021-11-01 10:47:23 +0100
committermousebot <mousebot@riseup.net>2021-11-01 10:51:47 +0100
commit04465567450d6fc9cdec1a1ba0ef12557b0ab54b (patch)
treeabe0eb83237327617a4985ea68a816ec6fb33ffc /lisp/mastodon-toot.el
parentcb288c6e49d46ef7584b16b1fbc7d5c42cb0e5cf (diff)
include user's profile URL in company mentions completion.
also rename company mentions completion default value to "following" not "followers", which is what the actual search is called and what it returns.
Diffstat (limited to 'lisp/mastodon-toot.el')
-rw-r--r--lisp/mastodon-toot.el28
1 files changed, 15 insertions, 13 deletions
diff --git a/lisp/mastodon-toot.el b/lisp/mastodon-toot.el
index dd13251..b0b7e13 100644
--- a/lisp/mastodon-toot.el
+++ b/lisp/mastodon-toot.el
@@ -89,12 +89,12 @@ Must be one of \"public\", \"unlisted\", \"private\" (for followers-only), or \"
:type 'integer)
(when (require 'company nil :noerror)
- (defcustom mastodon-toot--enable-completion-for-mentions "followers"
+ (defcustom mastodon-toot--enable-completion-for-mentions "following"
"Whether to enable company completion for mentions in toot compose buffer."
:group 'mastodon-toot
:type '(choice
(const :tag "off" nil)
- (const :tag "followers only" "followers")
+ (const :tag "following only" "following")
(const :tag "all users" "all"))))
(defvar mastodon-toot--content-warning nil
@@ -436,18 +436,18 @@ eg. \"feduser@fed.social\" -> \"feduser@fed.social\"."
(reverse (append mentions nil))
"")))
-;; (defun mastodon-toot--mentions-company-meta (candidate)
-;; (format "meta %s of candidate %s"
-;; (get-text-property 0 'meta candidate)
-;; (substring-no-properties candidate)))
+(defun mastodon-toot--mentions-company-meta (candidate)
+ "Format company completion CANDIDATE's meta field."
+ (format " %s"
+ (get-text-property 0 'meta candidate)))
(defun mastodon-toot--mentions-company-annotation (candidate)
- "Construct a company completion CANDIDATE's annotation for display."
- (format " %s" (get-text-property 0 'meta candidate)))
+ "Format company completion CANDIDATE's annotation."
+ (format " %s" (get-text-property 0 'annot candidate)))
(defun mastodon-toot--mentions-company-candidates (prefix)
- "Given a company PREFIX, build a list of candidates.
-The prefix string can match against both user handles and display names."
+ "Given a company PREFIX query, build a list of candidates.
+The prefix can match against both user handles and display names."
(let (res)
(dolist (item (mastodon-search--search-accounts-query prefix))
(when (or (string-prefix-p prefix (cadr item))
@@ -458,8 +458,9 @@ The prefix string can match against both user handles and display names."
(defun mastodon-toot--mentions-company-make-candidate (candidate)
"Construct a company completion CANDIDATE for display."
(let ((display-name (car candidate))
- (handle (cadr candidate)))
- (propertize handle 'meta display-name)))
+ (handle (cadr candidate))
+ (url (caddr candidate)))
+ (propertize handle 'annot display-name 'meta url)))
(defun mastodon-toot--mentions-completion (command &optional arg &rest ignored)
"A company completion backend for toot mentions."
@@ -474,7 +475,8 @@ The prefix string can match against both user handles and display names."
;; @ + thing before point
(concat "@" (company-grab-symbol))))
(candidates (mastodon-toot--mentions-company-candidates arg))
- (annotation (mastodon-toot--mentions-company-annotation arg))))
+ (annotation (mastodon-toot--mentions-company-annotation arg))
+ (meta (mastodon-toot--mentions-company-meta arg))))
(defun mastodon-toot--reply ()
"Reply to toot at `point'."