front-end-monorepo
front-end-monorepo copied to clipboard
Markdown images (ThumbnailImage) have inconsistent sizing behaviour
UI Bug
Package: lib-react-components Components: Media > ThumbnailImage, possibly Markdownz itself Noted as of: fef769f
Images in Markdown (e.g. as used in a Project's About page) can have inconsistent sizing behaviour. To be specific:
-
Sub-Issue 1: Images in Tables will always shrink to the smallest size possible. (Screenshot: the animal image in the left column should have been 800px wide, but is instead as tiny as it can get)
-
Sub-Issue 1a: the inconsistent sizing behaviour is, itself, inconsistent between PFE and FEM. (Screenshots: left is FEM, right if PFE. The animal image are both smaller than the intended 800px, but the FEM image is practically microscopic)
- Sub-Issue 2: Markdown Images in FEM can't be sized larger than the original image (e.g. if your image is 400x400, you can't render it in Markdown as 800x800.)
- Sub-Issue 2a: ...but in PFE, you CAN size an image larger than its original, resulting in inconsistent inconsistent behaviour between the two codebases.
-
Sub-Issue 3: the thumbnail service used by ThumbnailImage can't resize to 1000px wide or more.
- But you won't notice it because ThumbnailImage has a fallback that displays the original image instead.
Analysis
Analysis of Sub-Issue 1: the chicken-and-egg hypothesis
- From what I can tell, the Markdown image (ThumbnailImage component) is...
- rendered in a way that uses a lot of CSS flex, and
- has its intended size determined by the thumbnailer service instead of via HTML/CSS attributes (e.g. instead of using
<img src="example.jpg" width="800"
, it goes<img src="thumbnails.zooniverse.org/800x/example.jpg"
) (Note: the image does have a max-width FWIW)
- 🐔: the image will render itself in a way that will never exceed its container (in this case, a table's
<td>
) - 🥚: However, a
<table>
's columns will size itself depending on the size of its content - As a result, the image renders itself in the smallest way possible.
Screenshot: we see the same animal image in two different kinds of tables. In both cases, the table layout logic seems to determine the width of left & right columns by looking for "fixed content" first - in this case, the text in the right column. It then leaves the remaining space for the "flexible content", meaning the image just fills up whatever space is left.
Analysis of Sub-Issue 2 & 2a:
- The Markdown image in FEM can't be resized larger than the original simply because the thumbnail service won't allow it.
- For example, this image of a meerkat(? prairie dog? gopher??) is 206x183
- If I ask the thumbnail service to resize it to 100px wide, it becomes 100x88
- If I ask the thumbnail service to resize it to 800px wide, it remains 206x183
- In PFE, the problem is resolved simply by setting the width/height attribute in the img element: e.g.
<img src="meerkat-206x183.jpg" width="800" />
Analysis of Sub-Issue 3:
- If I ask the thumbnail service to resize the meerkat(? prairie dog???) image to 999px wide, it renders, although remains 206x183 (see above)
- If I ask the thumbnail service to resize the meerkat(? prairie dog???) image to 1000px wide, it returns a 415 error
- So if I ever ask a Markdown image to have a width (or height, presumably) of 1000px or more, the thumbnail service will fail.
- ...but the ThumbnailImage fallback will kick in and just render the original image
- ...which seems fine, until you consider what happens when say a 2000x2000 image is intended to be rendered as 1000x1000 but instead the user downloads the original image with a much larger file size.
Testing
To test this, simply try adding Markdown images with various explicit sizes (smaller than the original, larger than the original, etc) and in various situations (inside a table with a lot of other content, etc) to a test project's About page.
For example, heres my test project: https://www.zooniverse.org/lab/19242/about/results
And here's the Markdown code I used
## Markdown Test
This page is used to test how images are rendered in Markdown code on the Zooniverse. Specifically, how are _images with specified widths, inside tables,_ handled on both PFE and FEM?
--------
**Test 1: Image in Table**
|||
|:------------------:|-----|
|data:image/s3,"s3://crabby-images/69b96/69b96dc408a6c5e1486c16537ca5cb427c027508" alt="animal.jpeg"|This is a cell in a table. To your left, you should see a picture of a prairie dog(? or a gopher? I'm not a biologist dangit). The [source image](https://panoptes-uploads.zooniverse.org/project_attached_image/1a4198cb-635a-4c0f-806e-796f3ac3877f.jpeg) is 206x183 pixels in size, but the markdown specifies that the image should be presented as 800px wide. Question: how does the image appear to you on the About Page? On PFE? On FEM?|
--------
**Test 2: Image in less verbose Table**
|||
|:------------------:|-----|
|data:image/s3,"s3://crabby-images/69b96/69b96dc408a6c5e1486c16537ca5cb427c027508" alt="animal.jpeg"|Similar to table above, but text is shorter|
--------
**Test 3: Image, no Table**
Below, we see the same markdown code for the prairie dog(? or meerkat??) image, with the requested 800px width, but outside of the bounds of a table. How does it look like? On PFE? On FEM?
data:image/s3,"s3://crabby-images/69b96/69b96dc408a6c5e1486c16537ca5cb427c027508" alt="animal.jpeg"
(On FEM, we expect the image to be displayed 206px wide, because the thumbnailer service won't increase the size of an image.)
--------
**Test 4: Image, no Table, bigger**
For fun, here's what it looks like when we say the image should be 1000px wide:
data:image/s3,"s3://crabby-images/48313/48313d8228409bfaf30480894dd783fa8107fa0b" alt="animal.jpeg"
(On FEM, this should fallback to a non-thumbnailed image, because [the thumbnailer service returns a 415 error at 1000px width and above.](https://thumbnails.zooniverse.org/1000x/panoptes-uploads.zooniverse.org/project_attached_image/1a4198cb-635a-4c0f-806e-796f3ac3877f.jpeg))
--------
The end (of the tests)
Now, compare the rendered Markdown on both PFE and FEM codebases:
- https://frontend.preview.zooniverse.org/projects/darkeshard/test-project-2022/about/results
- https://master.pfe-preview.zooniverse.org/projects/darkeshard/test-project-2022/about/results?env=production
Status
Priority analysis and dev work assignment pending.
We know that, as of 3 Oct, this is affecting at least one project.
- Incident noted on Freshdesk: https://zooniverse.freshdesk.com/a/tickets/21105
- Initial investigation on Slack: https://zooniverse.slack.com/archives/CANKLB50E/p1727970366871179