Skip to content

Commit

Permalink
Configurable emoji reaction picker (fixes alphapapa#199)
Browse files Browse the repository at this point in the history
  • Loading branch information
oantolin committed Aug 11, 2023
1 parent 60e9a50 commit d196e53
Showing 1 changed file with 52 additions and 3 deletions.
55 changes: 52 additions & 3 deletions ement-room.el
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,15 @@ Used to, e.g. call `ement-room-compose-org'.")
map)
"Keymap used in `ement-room-read-string'.")

(defvar ement-room-reaction-map
(let ((map (make-sparse-keymap)))
(define-key map "c" #'insert-char)
(define-key map "i" #'emoji-insert)
(define-key map "s" #'emoji-search)
(define-key map "m" #'ement-room-select-emoji-input-method)
map)
"Keymap used in `ement-room-send-reaction'.")

(defvar ement-room-sender-in-headers nil
"Non-nil when sender is displayed in headers.
In that case, sender names are aligned to the margin edge.")
Expand Down Expand Up @@ -387,6 +396,24 @@ unread depends on the room's fully-read marker, read-receipt
marker, whether the local user sent the latest events, etc."
:type 'boolean)

(defcustom ement-room-reaction-picker (if (commandp #'emoji-insert)
#'emoji-insert
#'insert-char)
"Command used to select a reaction by `ement-room-send-reaction'.
Should be set to a command that somehow prompts the user for an
emoji and inserts it into the current buffer. In Emacs 29
reasonable choices include `emoji-insert' which uses a transient
interface, and `emoji-search' which uses `completing-read'. If
those are not available, one can use `insert-char'."
:type '(choice
(const :tag "Complete unicode character name" insert-char)
(const :tag "Complete emoji name" emoji-search)
(const :tag "Transient emoji menu" emoji-insert)
(const :tag "Emoji input method"
ement-room-select-emoji-input-method)
(const :tag "Type an emoji without assistance" ignore)
(function :tag "Use other command")))

(defvar ement-room-sender-in-left-margin nil
"Whether sender is shown in left margin.
Set by `ement-room-message-format-spec-setter'.")
Expand Down Expand Up @@ -1712,12 +1739,34 @@ The message must be one sent by the local user."
(ement-room-read-string prompt nil nil nil 'inherit-input-method))))
(ement-room-send-message room session :body body :replying-to-event event))))

(defun ement-room-select-emoji-input-method ()
"Activate the emoji input method in the current buffer."
(interactive)
(set-input-method "emoji"))

(defun ement-room-send-reaction (key position)
"Send reaction of KEY to event at POSITION.
Interactively, send reaction to event at point. KEY should be a
reaction string, e.g. \"👍\"."
KEY should be a reaction string, e.g. \"👍\".

Interactively, send reaction to event at point. The user option
`ement-room-reaction-picker' controls how the reaction string
is selected, or rather controls the initial mechanism, since the
user can always cancel that command with \\[keyboard-quit] and
choose a different one using the key bindings in
`ement-room-reaction-map' (note that other than `insert-char',
these all require at least version 29 of Emacs):

\\{ement-room-reaction-map}"
(interactive
(list (char-to-string (read-char-by-name "Reaction (prepend \"*\" for substring search): "))
(list (minibuffer-with-setup-hook
(lambda ()
(setq-local after-change-functions
(list (lambda (&rest _) (exit-minibuffer))))
(use-local-map
(make-composed-keymap ement-room-reaction-map (current-local-map)))
(let ((enable-recursive-minibuffers t))
(funcall ement-room-reaction-picker)))
(read-string "Reaction: "))
(point)))
;; SPEC: MSC2677 <https://github.com/matrix-org/matrix-doc/pull/2677>
;; HACK: We could simplify this by storing the key in a text property...
Expand Down

0 comments on commit d196e53

Please sign in to comment.