markdown-it-imsize
markdown-it-imsize copied to clipboard
Support specifying a single dimension
Users should be allowed to pass a single dimension, which is assumed to be the width. We let the browser maintain the aspect ratio for the height.
data:image/s3,"s3://crabby-images/d625e/d625eb85b1640cddc55a7bec6cce8495ceae5e67" alt="test1"
data:image/s3,"s3://crabby-images/763ae/763ae778eb5bc0798419316b8c205efc66557d3e" alt="test2"
<p><img src="image.png" alt="test1" width="100" ></p>
<p><img src="image2.png" alt="test2" width="50%" ></p>
Hi @sloria,
Actually, your request is already supported. You can specify the size only for width or height by:
data:image/s3,"s3://crabby-images/e9f6c/e9f6c565789e0718e0c227009f910dbfcfa5bb0d" alt="test1"
data:image/s3,"s3://crabby-images/bd01a/bd01a488341d4fb5b21c9e2f81a4418699b7e7ac" alt="test2"
They will be rendered as:
<img src="image.png" alt="test1" width="100"/>
<img src="image2.png" alt="test2" height="100"/>
@tatsy Ah, didn't realize you could leave out a dimension like that.
I still think that =100
is more intuitive than =100x
. Would you be willing to support that? My colleague @Johnetordoff has already implemented it, so if you're up for it, a PR is on its way!
Hi @sloria,
I think the specification =100
is not supported either official Markdown nor GitHub flavored Markdown. If it is supported either of them, please let me provide a link to the document.
This plugin is designed to follow the GitHub-flavored Markdown, therefore, the functions, which are not supported by it, should not be included in this plugin.
@tatsy Ah, I didn't realize this plugin's syntax was following a specification. Which specification does this project follow?
GitHub-flavored Markdown does not support this syntax. As of this writing, the only way to size images in GFM is to use an img
tag.
The image sizing syntax is listed in one of the Deployed Extensions for Commonmark, but it doesn't specify how to define a single dimension.
The syntax I'm proposing was also proposed in the Commonmark forum here: https://talk.commonmark.org/t/support-for-image-dimensions/148/7 .
Hi @sloria,
Thank you for sharing the links. But these links indicate that people proposed the new syntax but it is not officially supported. I think this is because the syntax data:image/s3,"s3://crabby-images/d625e/d625eb85b1640cddc55a7bec6cce8495ceae5e67" alt="test"
is ambiguous. It is unclear that the number 100
specifies width or height.
Accordingly, GitHub-flavored Markdown supports the syntax only data:image/s3,"s3://crabby-images/e9f6c/e9f6c565789e0718e0c227009f910dbfcfa5bb0d" alt="test"
to specify only width.
The proposed syntax is especially convenient when using percentages.
data:image/s3,"s3://crabby-images/266c5/266c52b23cd295fb40762f0b75267ec27e6ecec6" alt="test"
I understand it's more ambiguous when using pixels, but as a user, I would assume =100
means "100px for width and scale height accordingly". This is is consistent with other programs such as ImageMagick (e.g. mogrify -resize 100 image.png
).
Btw, I haven't been able to get data:image/s3,"s3://crabby-images/e9f6c/e9f6c565789e0718e0c227009f910dbfcfa5bb0d" alt="test"
(or any other variant) working anywhere on GitHub. I've tried comments, README.md, Wiki, and Gist; what am I missing?
Hi @sloria,
I am sorry for my misunderstanding. You're right. The GitHub-flavored Markdown does not support the above features.
The syntax data:image/s3,"s3://crabby-images/faf5a/faf5a04a0ead2f218e703927595315b1eb75bc1f" alt="test"
is supported by the MacOS editors Mou, Marked2 and Ruby-based Markdown parser RDiscount.
I remembered that I adopted this syntax because this one is simple and intuitive, also it was easy to support. For example, Pandoc supports the syntax like data:image/s3,"s3://crabby-images/29593/295937b655aba28e6b93f6e552ff0d1398f4bacc" alt="test"{width=640px, height=480px}
, but this one is rather hard to parse appropriately with the simple codes.
Despite the fact that the many Markdown parsers do not support the syntax that this plugin supports, I am still against to support the syntax data:image/s3,"s3://crabby-images/d625e/d625eb85b1640cddc55a7bec6cce8495ceae5e67" alt="test"
because, as I mentioned before, this is ambiguous and hard to distinguish the size "100" is for width or height. Also, the syntax data:image/s3,"s3://crabby-images/e9f6c/e9f6c565789e0718e0c227009f910dbfcfa5bb0d" alt="test"
is acceptable because just type a character "x" is not so laborious.
In conclusion, I think there is not enough justification to support the syntax that you have proposed. However, I am still open to your opinion. Please feel free to tell me your further opinion.
Thank you.