aboutsummaryrefslogtreecommitdiff
path: root/lisp/mastodon-tl.el
diff options
context:
space:
mode:
authormousebot <mousebot@riseup.net>2021-05-20 16:27:56 +0200
committermousebot <mousebot@riseup.net>2021-05-21 11:32:30 +0200
commit6d675413823b267c76b67dfdcffee11c3a1bf173 (patch)
tree3063682968c8ae695a4025b1cac2c46f06d5652b /lisp/mastodon-tl.el
parent841bf851ed49389a38007ca02257ba780972e48b (diff)
Implement clickable images with shr-browse-image.
images are tab stops. click or RET runs shr-browse-image. a prefix arg copies the URL. images use the mastodon-tl--shr-image-map-replacement for extra functions like zoom image, save image, rotate image, etc.
Diffstat (limited to 'lisp/mastodon-tl.el')
-rw-r--r--lisp/mastodon-tl.el14
1 files changed, 10 insertions, 4 deletions
diff --git a/lisp/mastodon-tl.el b/lisp/mastodon-tl.el
index 4931913..da2e418 100644
--- a/lisp/mastodon-tl.el
+++ b/lisp/mastodon-tl.el
@@ -130,6 +130,9 @@ types of mastodon links and not just shr.el-generated ones.")
;; version that knows about more types of links.
(define-key map [remap shr-next-link] 'mastodon-tl--next-tab-item)
(define-key map [remap shr-previous-link] 'mastodon-tl--previous-tab-item)
+ ;; browse-url loads the preview only, we want browse-image
+ ;; on RET to browse full sized image URL
+ (define-key map [remap shr-browse-url] 'shr-browse-image)
(keymap-canonicalize map))
"The keymap to be set for shr.el generated image links.
@@ -551,6 +554,7 @@ LINK-TYPE is the type of link to produce."
'help-echo help-text)))
(defun mastodon-tl--do-link-action-at-point (position)
+ ;; called by RET
(interactive "d")
(let ((link-type (get-text-property position 'mastodon-tab-stop)))
(cond ((eq link-type 'content-warning)
@@ -575,6 +579,7 @@ LINK-TYPE is the type of link to produce."
(error "unknown link type %s" link-type)))))
(defun mastodon-tl--do-link-action (event)
+ ;; called by mouse click
(interactive "e")
(mastodon-tl--do-link-action-at-point (posn-point (event-end event))))
@@ -603,7 +608,7 @@ message is a link which unhides/hides the main body."
(message (concat ;"\n"
" ---------------\n"
" " (mastodon-tl--make-link
- (concat "CW: " string) ;"Content Warning"
+ (concat "CW: " string)
'content-warning)
"\n"
" ---------------\n"))
@@ -620,10 +625,12 @@ message is a link which unhides/hides the main body."
(media-string (mapconcat
(lambda (media-attachement)
(let ((preview-url
- (cdr (assoc 'preview_url media-attachement))))
+ (cdr (assoc 'preview_url media-attachement)))
+ (remote-url
+ (cdr (assoc 'remote_url media-attachement))))
(if mastodon-tl--display-media-p
(mastodon-media--get-media-link-rendering
- preview-url)
+ preview-url remote-url) ; 2nd arg for shr-browse-url
(concat "Media::" preview-url "\n"))))
media-attachements "")))
(if (not (and mastodon-tl--display-media-p
@@ -631,7 +638,6 @@ message is a link which unhides/hides the main body."
(concat "\n" media-string)
"")))
-
(defun mastodon-tl--content (toot)
"Retrieve text content from TOOT."
(let ((content (mastodon-tl--field 'content toot)))