* Re: Link preview generation with new link preview property
[not found] <6755f138.0c0a0220.40388.51fbSMTPIN_ADDED_BROKEN@mx.google.com>
@ 2024-12-13 5:49 ` Karthik Chikmagalur
2024-12-14 0:03 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Karthik Chikmagalur @ 2024-12-13 5:49 UTC (permalink / raw)
To: Björn Bidar, emacs-orgmode
> The PR do port the package to this new handler property:
> https://github.com/gaoDean/org-remoteimg/pull/4
>
> However it left me with a few questions:
> - Who is supposed to take care of the scaling/width of the preview
> image, the handler or the caller of the handler?
The handler is responsible for sizing the image. The reason for this is
that the preview does not have to be an image -- it can be any kind of
overlay decoration.
If you decide to use an image file as the preview, you can call
`org-link-preview-file' inside your handler to handle the geometry for
you. This includes the size and alignment specified by #+attr_*
keywords, `org-image-max-width' and `org-image-align'.
If you are using a preview image from image data, you'll have to copy
some of the code in `org-link-preview-file' to your handler if you want
to respect these user options.
> - When calling the link preview function for a description with prefix
> argument 1 I noticed that it doesn't get the contents of the
> description.
> Why is that? In this instance the link looked like this:
> [[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]]
I don't follow. What do you mean by "it doesn't get the contents"? Did
the preview work as expected when you used a prefix arg of 1?
Karthik
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-13 5:49 ` Link preview generation with new link preview property Karthik Chikmagalur
@ 2024-12-14 0:03 ` Björn Bidar
2024-12-14 7:04 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2024-12-14 0:03 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: emacs-orgmode
Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>> The PR do port the package to this new handler property:
>> https://github.com/gaoDean/org-remoteimg/pull/4
>>
>> However it left me with a few questions:
>> - Who is supposed to take care of the scaling/width of the preview
>> image, the handler or the caller of the handler?
>
> The handler is responsible for sizing the image. The reason for this is
> that the preview does not have to be an image -- it can be any kind of
> overlay decoration.
>
> If you decide to use an image file as the preview, you can call
> `org-link-preview-file' inside your handler to handle the geometry for
> you. This includes the size and alignment specified by #+attr_*
> keywords, `org-image-max-width' and `org-image-align'.
>
> If you are using a preview image from image data, you'll have to copy
> some of the code in `org-link-preview-file' to your handler if you want
> to respect these user options.
Would it be possible to also handle image data in the function or
refactor the org-link-preview-file function in a way that the geometry
handling is done in a helper function which can be reused by other
handlers.
In the example I mentioned it should be possible to use the cached file
from the url cache but that might be not so easy in other cases.
>> - When calling the link preview function for a description with prefix
>> argument 1 I noticed that it doesn't get the contents of the
>> description.
>> Why is that? In this instance the link looked like this:
>> [[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]]
>
> I don't follow. What do you mean by "it doesn't get the contents"? Did
> the preview work as expected when you used a prefix arg of 1?
The link element passed towards the handler didn't contain the
description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg.
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-14 0:03 ` Björn Bidar
@ 2024-12-14 7:04 ` Ihor Radchenko
2024-12-17 2:46 ` Björn Bidar
2024-12-17 3:42 ` Karthik Chikmagalur
0 siblings, 2 replies; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-14 7:04 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
> Would it be possible to also handle image data in the function or
> refactor the org-link-preview-file function in a way that the geometry
> handling is done in a helper function which can be reused by other
> handlers.
There is such function: `org-display-inline-image--width'.
We may consider exposing it as public function.
> The link element passed towards the handler didn't contain the
> description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg.
This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a
You can access the contents by looking at buffer text between
:contents-begin and :contents-end. Either directly, or by invoking
sub-parser on the text.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-14 7:04 ` Ihor Radchenko
@ 2024-12-17 2:46 ` Björn Bidar
2024-12-17 17:39 ` Ihor Radchenko
2024-12-17 3:42 ` Karthik Chikmagalur
1 sibling, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2024-12-17 2:46 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Björn Bidar <bjorn.bidar@thaodan.de> writes:
>
>> Would it be possible to also handle image data in the function or
>> refactor the org-link-preview-file function in a way that the geometry
>> handling is done in a helper function which can be reused by other
>> handlers.
>
> There is such function: `org-display-inline-image--width'.
> We may consider exposing it as public function.
That would be awesome, the easier it is for other modes to add their own
handlers and them to survive org-mode updates.
Although for this http link handler it could be better a function inside org-mode.
>> The link element passed towards the handler didn't contain the
>> description e.g. in this case file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg.
>
> This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a
> You can access the contents by looking at buffer text between
> :contents-begin and :contents-end. Either directly, or by invoking
> sub-parser on the text.
Oh thanks, will look into that. Is there a offline version of the manual
like the org info manual?
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 2:46 ` Björn Bidar
@ 2024-12-17 17:39 ` Ihor Radchenko
2024-12-19 21:55 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-17 17:39 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
>> This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a
>> You can access the contents by looking at buffer text between
>> :contents-begin and :contents-end. Either directly, or by invoking
>> sub-parser on the text.
>
> Oh thanks, will look into that. Is there a offline version of the manual
> like the org info manual?
Nothing shipped with Org distribution.
But you can always clone WORG - it is mostly a collection of .org files.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 17:39 ` Ihor Radchenko
@ 2024-12-19 21:55 ` Björn Bidar
2024-12-21 12:03 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2024-12-19 21:55 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Björn Bidar <bjorn.bidar@thaodan.de> writes:
>
>>> This is expected. See https://orgmode.org/worg/dev/org-element-api.html#org22c967a
>>> You can access the contents by looking at buffer text between
>>> :contents-begin and :contents-end. Either directly, or by invoking
>>> sub-parser on the text.
>>
>> Oh thanks, will look into that. Is there a offline version of the manual
>> like the org info manual?
>
> Nothing shipped with Org distribution.
> But you can always clone WORG - it is mostly a collection of .org files.
That's a good suggestion. I never used org for reading only but it
should be better than a website. Does view-mode mode work fine with org?
Anyway it would be a good improvement to include the org-mode api manual
with org-mode similar to how Emacs includes the Elisp manual.
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-14 7:04 ` Ihor Radchenko
2024-12-17 2:46 ` Björn Bidar
@ 2024-12-17 3:42 ` Karthik Chikmagalur
2024-12-17 17:40 ` Ihor Radchenko
2024-12-18 6:21 ` stardiviner
1 sibling, 2 replies; 25+ messages in thread
From: Karthik Chikmagalur @ 2024-12-17 3:42 UTC (permalink / raw)
To: Ihor Radchenko, Björn Bidar; +Cc: emacs-orgmode
>> Would it be possible to also handle image data in the function or
>> refactor the org-link-preview-file function in a way that the geometry
>> handling is done in a helper function which can be reused by other
>> handlers.
>
> There is such function: `org-display-inline-image--width'.
> We may consider exposing it as public function.
This will not be enough, we will also have to expose `org-image--align'
and the alignment code:
(when align
(overlay-put
ov 'before-string
(propertize
" " 'face 'default
'display
(pcase align
("center" `(space :align-to (- center (0.5 . ,image))))
("right" `(space :align-to (- right ,image)))))))
I don't think we can expect third party packages to figure out and
reimplement Org's image alignment logic.
Considering this, it might be better to just split
`org-link-preview-file' into two public functions, where the "inside"
function accepts an image instead of a file.
Karthik
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 3:42 ` Karthik Chikmagalur
@ 2024-12-17 17:40 ` Ihor Radchenko
2024-12-19 23:20 ` Björn Bidar
` (2 more replies)
2024-12-18 6:21 ` stardiviner
1 sibling, 3 replies; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-17 17:40 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: Björn Bidar, emacs-orgmode
Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
> ...
> Considering this, it might be better to just split
> `org-link-preview-file' into two public functions, where the "inside"
> function accepts an image instead of a file.
Agree.
Would you be interested to create a patch?
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 17:40 ` Ihor Radchenko
@ 2024-12-19 23:20 ` Björn Bidar
2024-12-20 0:45 ` Karthik Chikmagalur
[not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>
2 siblings, 0 replies; 25+ messages in thread
From: Björn Bidar @ 2024-12-19 23:20 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
[-- Attachment #1: Type: text/plain, Size: 387 bytes --]
Ihor Radchenko <yantar92@posteo.net> writes:
> Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>
>> ...
>> Considering this, it might be better to just split
>> `org-link-preview-file' into two public functions, where the "inside"
>> function accepts an image instead of a file.
>
> Agree.
> Would you be interested to create a patch?
Did you think of something like this?
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: 0001-org-link-Split-link-preview-into-two-functions.patch --]
[-- Type: text/x-patch, Size: 2817 bytes --]
From a3c682a7d730b0ae9492407d080ba8549a19e02d Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Bj=C3=B6rn=20Bidar?= <bjorn.bidar@thaodan.de>
Date: Fri, 20 Dec 2024 01:00:46 +0200
Subject: [PATCH] org-link: Split link preview into two functions
* lisp/ol.el (org-link-preview-file,
org-link-preview-image-data): Split up the actual preview part into
a separate function. The new preview function can be called by
:preview handler to display the image according to the correct alignment
for the link to be previewed.
---
lisp/ol.el | 45 ++++++++++++++++++++++++++-------------------
1 file changed, 26 insertions(+), 19 deletions(-)
diff --git a/lisp/ol.el b/lisp/ol.el
index 032610bad..dd6b07152 100644
--- a/lisp/ol.el
+++ b/lisp/ol.el
@@ -2177,27 +2177,34 @@ (defun org-link-preview-file (ov path link)
((string-match-p (image-file-name-regexp) file))
((file-exists-p file)))
(let* ((width (org-display-inline-image--width link))
- (align (org-image--align link))
- (image (org--create-inline-image file width)))
- (when image ; Add image to overlay
- ;; See bug#59902. We cannot rely
- ;; on Emacs to update image if the file
- ;; has changed.
- (image-flush image)
- (overlay-put ov 'display image)
- (overlay-put ov 'face 'default)
- (overlay-put ov 'keymap image-map)
- (when align
- (overlay-put
- ov 'before-string
- (propertize
- " " 'face 'default
- 'display
- (pcase align
- ("center" `(space :align-to (- center (0.5 . ,image))))
- ("right" `(space :align-to (- right ,image)))))))
+ (image-data (org--create-inline-image file width)))
+ (when image-data
+ (org-link-preview-image-data ov image-data link)
t)))))
+(defun org-link-preview-image-data (ov image-data link)
+ "Display image data IMAGE-DATA in overlay OV for link.
+
+This intended to be used by functions which provide the :preview link property
+of links such as in `org-link-preview-file'"
+ (let ((align (org-image--align link)))
+ ;; See bug#59902. We cannot rely
+ ;; on Emacs to update image if the file
+ ;; has changed.
+ (image-flush image-data)
+ (overlay-put ov 'display image-data)
+ (overlay-put ov 'face 'default)
+ (overlay-put ov 'keymap image-map)
+ (when align
+ (overlay-put
+ ov 'before-string
+ (propertize
+ " " 'face 'default
+ 'display
+ (pcase align
+ ("center" `(space :align-to (- center (0.5 . ,image-data))))
+ ("right" `(space :align-to (- right ,image-data)))))))))
+
;;;; "help" link type
(defun org-link--open-help (path _)
"Open a \"help\" type link.
--
2.45.2
^ permalink raw reply related [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 17:40 ` Ihor Radchenko
2024-12-19 23:20 ` Björn Bidar
@ 2024-12-20 0:45 ` Karthik Chikmagalur
2024-12-21 12:05 ` Ihor Radchenko
[not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>
2 siblings, 1 reply; 25+ messages in thread
From: Karthik Chikmagalur @ 2024-12-20 0:45 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Björn Bidar, emacs-orgmode
>> ...
>> Considering this, it might be better to just split
>> `org-link-preview-file' into two public functions, where the "inside"
>> function accepts an image instead of a file.
>
> Agree.
> Would you be interested to create a patch?
Ihor, did you write a patch for this already? I thought I saw something
from you but can't locate it now.
If not, I can submit a patch but it will be a week or so before I can
get to it.
Karthik
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-20 0:45 ` Karthik Chikmagalur
@ 2024-12-21 12:05 ` Ihor Radchenko
2024-12-23 20:41 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-21 12:05 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: Björn Bidar, emacs-orgmode
Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>>> ...
>>> Considering this, it might be better to just split
>>> `org-link-preview-file' into two public functions, where the "inside"
>>> function accepts an image instead of a file.
>>
>> Agree.
>> Would you be interested to create a patch?
>
> Ihor, did you write a patch for this already? I thought I saw something
> from you but can't locate it now.
No, I did not. (I hope I did not forget 🤦)
> If not, I can submit a patch but it will be a week or so before I can
> get to it.
Maybe you can work with Bjorn on his patch instead?
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-21 12:05 ` Ihor Radchenko
@ 2024-12-23 20:41 ` Björn Bidar
0 siblings, 0 replies; 25+ messages in thread
From: Björn Bidar @ 2024-12-23 20:41 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>
>>>> ...
>>>> Considering this, it might be better to just split
>>>> `org-link-preview-file' into two public functions, where the "inside"
>>>> function accepts an image instead of a file.
>>>
>>> Agree.
>>> Would you be interested to create a patch?
>>
>> Ihor, did you write a patch for this already? I thought I saw something
>> from you but can't locate it now.
>
> No, I did not. (I hope I did not forget 🤦)
>
>> If not, I can submit a patch but it will be a week or so before I can
>> get to it.
>
> Maybe you can work with Bjorn on his patch instead?
Anything is fine for me. Feedback on my last patch would be great.
^ permalink raw reply [flat|nested] 25+ messages in thread
[parent not found: <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>]
* Re: Link preview generation with new link preview property
[not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>
@ 2024-12-26 18:46 ` Karthik Chikmagalur
2024-12-29 15:44 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Karthik Chikmagalur @ 2024-12-26 18:46 UTC (permalink / raw)
To: Björn Bidar, Ihor Radchenko; +Cc: emacs-orgmode
>>> ...
>>> Considering this, it might be better to just split
>>> `org-link-preview-file' into two public functions, where the "inside"
>>> function accepts an image instead of a file.
>>
>> Agree.
>> Would you be interested to create a patch?
>
> Did you think of something like this?
It looks like you are respecting the alignment specifications, set via
org-image-align or the :align property of #+attr_*, but not the :width
property. Is the idea that the preview implementation that provides the
image should independently use org-display-inline-image--width?
At minimum this requires making org-display-inline-image--width a public
function. But it would be good for org-link-preview-image-data to
respect both properties.
Karthik
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-26 18:46 ` Karthik Chikmagalur
@ 2024-12-29 15:44 ` Björn Bidar
2024-12-30 17:05 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2024-12-29 15:44 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: Ihor Radchenko, emacs-orgmode
Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>>>> ...
>>>> Considering this, it might be better to just split
>>>> `org-link-preview-file' into two public functions, where the "inside"
>>>> function accepts an image instead of a file.
>>>
>>> Agree.
>>> Would you be interested to create a patch?
>>
>> Did you think of something like this?
>
> It looks like you are respecting the alignment specifications, set via
> org-image-align or the :align property of #+attr_*, but not the :width
> property. Is the idea that the preview implementation that provides the
> image should independently use org-display-inline-image--width?
The width is set before the inline image is created. I'm not sure how
this should be handled. Is the with set when creating the inline image
Ihor?
If the width is set before the image is created how should it be handled
in
the preview image-data function?
> At minimum this requires making org-display-inline-image--width a public
> function. But it would be good for org-link-preview-image-data to
> respect both properties.
I agree with both but I'm not sure what should be done on this.
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-29 15:44 ` Björn Bidar
@ 2024-12-30 17:05 ` Ihor Radchenko
2025-01-04 2:01 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-30 17:05 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
>> It looks like you are respecting the alignment specifications, set via
>> org-image-align or the :align property of #+attr_*, but not the :width
>> property. Is the idea that the preview implementation that provides the
>> image should independently use org-display-inline-image--width?
>
> The width is set before the inline image is created. I'm not sure how
> this should be handled. Is the with set when creating the inline image
> Ihor?
> If the width is set before the image is created how should it be handled
> in
> the preview image-data function?
Both alignment and width are derived from LINK AST node.
I am not sure what is the problem.
AFAIU, Karthik is simply asking why you decided to calculate alignment
from LINK, but not width.
>> At minimum this requires making org-display-inline-image--width a public
>> function. But it would be good for org-link-preview-image-data to
>> respect both properties.
>
> I agree with both but I'm not sure what should be done on this.
If we think about the API function to be more useful, we can derive
alignment and width from LINK itself by default, but also provide
optional parameters, so that the caller can override the values
manually. If both alignment and width parameters are explicitly
specified, LINK does not have to be provided.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-30 17:05 ` Ihor Radchenko
@ 2025-01-04 2:01 ` Björn Bidar
2025-01-04 14:11 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2025-01-04 2:01 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Björn Bidar <bjorn.bidar@thaodan.de> writes:
>
>>> It looks like you are respecting the alignment specifications, set via
>>> org-image-align or the :align property of #+attr_*, but not the :width
>>> property. Is the idea that the preview implementation that provides the
>>> image should independently use org-display-inline-image--width?
>>
>> The width is set before the inline image is created. I'm not sure how
>> this should be handled. Is the with set when creating the inline image
>> Ihor?
>> If the width is set before the image is created how should it be handled
>> in
>> the preview image-data function?
>
> Both alignment and width are derived from LINK AST node.
> I am not sure what is the problem.
> AFAIU, Karthik is simply asking why you decided to calculate alignment
> from LINK, but not width.
My question was because the width is set through the width of the inline
image, i.e. the image-data passed through the preview function.
Is there no difference if function using org-link-review-image-data has
not set the width of the image and then we set the with of the overlay instead?
>>> At minimum this requires making org-display-inline-image--width a public
>>> function. But it would be good for org-link-preview-image-data to
>>> respect both properties.
>>
>> I agree with both but I'm not sure what should be done on this.
>
> If we think about the API function to be more useful, we can derive
> alignment and width from LINK itself by default, but also provide
> optional parameters, so that the caller can override the values
> manually. If both alignment and width parameters are explicitly
> specified, LINK does not have to be provided.
How would that work? Make link align and with optional and fail if
align or with are missing without link?
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2025-01-04 2:01 ` Björn Bidar
@ 2025-01-04 14:11 ` Ihor Radchenko
2025-01-18 14:44 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Ihor Radchenko @ 2025-01-04 14:11 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
>> Both alignment and width are derived from LINK AST node.
>> I am not sure what is the problem.
>> AFAIU, Karthik is simply asking why you decided to calculate alignment
>> from LINK, but not width.
>
> My question was because the width is set through the width of the inline
> image, i.e. the image-data passed through the preview function.
> Is there no difference if function using org-link-review-image-data has
> not set the width of the image and then we set the with of the overlay instead?
You are probably confused by `org--create-inline-image'?
IMHO, it would be best to pass image file name/raw image data to
`org-link-preview-image-data', not an image object and call
`org--create-inline-image' from inside `org-link-preview-image-data'.
That way, we can automatically obey Org customization wrt image
alignment, image width, and image max width.
>> If we think about the API function to be more useful, we can derive
>> alignment and width from LINK itself by default, but also provide
>> optional parameters, so that the caller can override the values
>> manually. If both alignment and width parameters are explicitly
>> specified, LINK does not have to be provided.
>
> How would that work? Make link align and with optional and fail if
> align or with are missing without link?
Yes.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2025-01-04 14:11 ` Ihor Radchenko
@ 2025-01-18 14:44 ` Björn Bidar
2025-01-18 15:03 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2025-01-18 14:44 UTC (permalink / raw)
To: Ihor Radchenko; +Cc: Karthik Chikmagalur, emacs-orgmode
Ihor Radchenko <yantar92@posteo.net> writes:
> Björn Bidar <bjorn.bidar@thaodan.de> writes:
>
>>> Both alignment and width are derived from LINK AST node.
>>> I am not sure what is the problem.
>>> AFAIU, Karthik is simply asking why you decided to calculate alignment
>>> from LINK, but not width.
>>
>> My question was because the width is set through the width of the inline
>> image, i.e. the image-data passed through the preview function.
>> Is there no difference if function using org-link-review-image-data has
>> not set the width of the image and then we set the with of the overlay instead?
>
> You are probably confused by `org--create-inline-image'?
Possibly but I simply was confused by some of the properties of the
overlay being set and some of them being taken from the image object.
> IMHO, it would be best to pass image file name/raw image data to
> `org-link-preview-image-data', not an image object and call
> `org--create-inline-image' from inside `org-link-preview-image-data'.
> That way, we can automatically obey Org customization wrt image
> alignment, image width, and image max width.
For that case using org-link-preview-file should be sufficient?
>>> If we think about the API function to be more useful, we can derive
>>> alignment and width from LINK itself by default, but also provide
>>> optional parameters, so that the caller can override the values
>>> manually. If both alignment and width parameters are explicitly
>>> specified, LINK does not have to be provided.
>>
>> How would that work? Make link align and with optional and fail if
>> align or with are missing without link?
>
> Yes.
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2025-01-18 14:44 ` Björn Bidar
@ 2025-01-18 15:03 ` Ihor Radchenko
0 siblings, 0 replies; 25+ messages in thread
From: Ihor Radchenko @ 2025-01-18 15:03 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
>> IMHO, it would be best to pass image file name/raw image data to
>> `org-link-preview-image-data', not an image object and call
>> `org--create-inline-image' from inside `org-link-preview-image-data'.
>> That way, we can automatically obey Org customization wrt image
>> alignment, image width, and image max width.
>
> For that case using org-link-preview-file should be sufficient?
Sorry, I am lost.
AFAIU, your original motivation was:
>> Would it be possible to also handle image data in the function or
>> refactor the org-link-preview-file function in a way that the geometry
>> handling is done in a helper function which can be reused by other
>> handlers.
Did it change?
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-17 3:42 ` Karthik Chikmagalur
2024-12-17 17:40 ` Ihor Radchenko
@ 2024-12-18 6:21 ` stardiviner
2024-12-18 6:33 ` Karthik Chikmagalur
1 sibling, 1 reply; 25+ messages in thread
From: stardiviner @ 2024-12-18 6:21 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: Ihor Radchenko, Björn Bidar, emacs-orgmode
[-- Attachment #1: Type: text/plain, Size: 1643 bytes --]
I don't think so, my package org-link-beautify ported to the new
:preview mechanism. The file preview not always image. Could be text, or
icon etc. So pass in image object is not a good idea. It will limit
preview functionality extensibility.
[stardiviner] <Hack this world!> GPG key ID: 47C32433
IRC(freeenode): stardiviner Twitter: @numbchild
Key fingerprint = 9BAA 92BC CDDD B9EF 3B36 CB99 B8C4 B8E5 47C3 2433
Blog: http://stardiviner.github.io/
On Tue, Dec 17, 2024 at 11:43 AM Karthik Chikmagalur <
karthikchikmagalur@gmail.com> wrote:
> >> Would it be possible to also handle image data in the function or
> >> refactor the org-link-preview-file function in a way that the geometry
> >> handling is done in a helper function which can be reused by other
> >> handlers.
> >
> > There is such function: `org-display-inline-image--width'.
> > We may consider exposing it as public function.
>
> This will not be enough, we will also have to expose `org-image--align'
> and the alignment code:
>
> (when align
> (overlay-put
> ov 'before-string
> (propertize
> " " 'face 'default
> 'display
> (pcase align
> ("center" `(space :align-to (- center (0.5 . ,image))))
> ("right" `(space :align-to (- right ,image)))))))
>
> I don't think we can expect third party packages to figure out and
> reimplement Org's image alignment logic.
>
> Considering this, it might be better to just split
> `org-link-preview-file' into two public functions, where the "inside"
> function accepts an image instead of a file.
>
> Karthik
>
>
[-- Attachment #2: Type: text/html, Size: 2425 bytes --]
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-18 6:21 ` stardiviner
@ 2024-12-18 6:33 ` Karthik Chikmagalur
2024-12-19 23:26 ` Björn Bidar
0 siblings, 1 reply; 25+ messages in thread
From: Karthik Chikmagalur @ 2024-12-18 6:33 UTC (permalink / raw)
To: stardiviner; +Cc: Ihor Radchenko, Björn Bidar, emacs-orgmode
> I don't think so, my package org-link-beautify ported to the new
> :preview mechanism. The file preview not always image. Could be text, or
> icon etc. So pass in image object is not a good idea. It will limit
> preview functionality extensibility.
The API will not be changed. Org will provide a new
`org-link-preview-image' function that you can use to preview links
using image data. You'll have to write the adapter to register this as
the :preview handler for a link type yourself.
Karthik
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-18 6:33 ` Karthik Chikmagalur
@ 2024-12-19 23:26 ` Björn Bidar
2024-12-21 12:09 ` Ihor Radchenko
0 siblings, 1 reply; 25+ messages in thread
From: Björn Bidar @ 2024-12-19 23:26 UTC (permalink / raw)
To: Karthik Chikmagalur; +Cc: stardiviner, Ihor Radchenko, emacs-orgmode
Karthik Chikmagalur <karthikchikmagalur@gmail.com> writes:
>> I don't think so, my package org-link-beautify ported to the new
>> :preview mechanism. The file preview not always image. Could be text, or
>> icon etc. So pass in image object is not a good idea. It will limit
>> preview functionality extensibility.
>
> The API will not be changed. Org will provide a new
> `org-link-preview-image' function that you can use to preview links
> using image data. You'll have to write the adapter to register this as
> the :preview handler for a link type yourself.
>
> Karthik
I'm also wondering how much could there be shared if the thing to be
displayed on the overlay isn't an image.
The org-image--align function talks about images but ultimately
doesn't do anything specific to image.
I think the alignment the only part which is generic.
^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: Link preview generation with new link preview property
2024-12-19 23:26 ` Björn Bidar
@ 2024-12-21 12:09 ` Ihor Radchenko
0 siblings, 0 replies; 25+ messages in thread
From: Ihor Radchenko @ 2024-12-21 12:09 UTC (permalink / raw)
To: Björn Bidar; +Cc: Karthik Chikmagalur, stardiviner, emacs-orgmode
Björn Bidar <bjorn.bidar@thaodan.de> writes:
> I'm also wondering how much could there be shared if the thing to be
> displayed on the overlay isn't an image.
>
> The org-image--align function talks about images but ultimately
> doesn't do anything specific to image.
> I think the alignment the only part which is generic.
If we provide a generic alignment, yes. We may or may not. Or we may
choose some other way to control non-image alignment.
I see no reason to generalize things needlessly. We can always do it is
we wish to. We cannot go back as easily if we commit prematurely.
--
Ihor Radchenko // yantar92,
Org mode maintainer,
Learn more about Org mode at <https://orgmode.org/>.
Support Org development at <https://liberapay.com/org-mode>,
or support my work at <https://liberapay.com/yantar92>
^ permalink raw reply [flat|nested] 25+ messages in thread
* Link preview generation with new link preview property
@ 2024-12-08 19:18 Björn Bidar
0 siblings, 0 replies; 25+ messages in thread
From: Björn Bidar @ 2024-12-08 19:18 UTC (permalink / raw)
To: emacs-orgmode
Hello,
I have a few question regarding the new link preview handler property
added recently. I ported the org-remoteimg package to it which was quite
easy, much cleaner with the new property.
The PR do port the package to this new handler property:
https://github.com/gaoDean/org-remoteimg/pull/4
However it left me with a few questions:
- Who is supposed to take care of the scaling/width of the preview
image, the handler or the caller of the handler?
- When calling the link preview function for a description with prefix
argument 1 I noticed that it doesn't get the contents of the
description.
Why is that? In this instance the link looked like this:
[[https://stable.melpa.org/#/rpm-spec-mode][file:https://stable.melpa.org/packages/rpm-spec-mode-badge.svg]]
Thanks have a great day,
Björn
^ permalink raw reply [flat|nested] 25+ messages in thread
end of thread, other threads:[~2025-01-18 15:02 UTC | newest]
Thread overview: 25+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <6755f138.0c0a0220.40388.51fbSMTPIN_ADDED_BROKEN@mx.google.com>
2024-12-13 5:49 ` Link preview generation with new link preview property Karthik Chikmagalur
2024-12-14 0:03 ` Björn Bidar
2024-12-14 7:04 ` Ihor Radchenko
2024-12-17 2:46 ` Björn Bidar
2024-12-17 17:39 ` Ihor Radchenko
2024-12-19 21:55 ` Björn Bidar
2024-12-21 12:03 ` Ihor Radchenko
2024-12-17 3:42 ` Karthik Chikmagalur
2024-12-17 17:40 ` Ihor Radchenko
2024-12-19 23:20 ` Björn Bidar
2024-12-20 0:45 ` Karthik Chikmagalur
2024-12-21 12:05 ` Ihor Radchenko
2024-12-23 20:41 ` Björn Bidar
[not found] ` <6764aa79.050a0220.23273b.09a5SMTPIN_ADDED_BROKEN@mx.google.com>
2024-12-26 18:46 ` Karthik Chikmagalur
2024-12-29 15:44 ` Björn Bidar
2024-12-30 17:05 ` Ihor Radchenko
2025-01-04 2:01 ` Björn Bidar
2025-01-04 14:11 ` Ihor Radchenko
2025-01-18 14:44 ` Björn Bidar
2025-01-18 15:03 ` Ihor Radchenko
2024-12-18 6:21 ` stardiviner
2024-12-18 6:33 ` Karthik Chikmagalur
2024-12-19 23:26 ` Björn Bidar
2024-12-21 12:09 ` Ihor Radchenko
2024-12-08 19:18 Björn Bidar
Code repositories for project(s) associated with this public inbox
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).