Commit 563e5bc
authored
fix: set width attribute on image and video elements in editor render (#2740)
* fix: set width attribute on image element in editor render
When the editor is rendered with editable: false, the <img> tag did not
include a width attribute even though the block's previewWidth prop was
set — the width was only applied as inline style on the wrapper. This
prevented the browser from reserving space before the image loaded
(CLS) and made the rendered DOM lossy for downstream consumers reading
innerHTML.
Apply previewWidth directly to the <img> element in the editor render
path, mirroring what imageToExternalHTML and the core Video block
already do. CSS width: 100% on .bn-visual-media still controls layout
so resize behavior is unaffected.
Fixes #2726
* fix: also apply width attribute to video block
Apply the same fix as the image block to video:
- React VideoPreview now sets width on the <video> element so read-only
rendering includes it.
- React VideoToExternalHTML now serializes previewWidth (it was
previously dropped entirely on export).
- Core video render path guards `video.width = previewWidth` against
undefined (assigning undefined to a numeric DOM property coerces to
0).
Audio and File blocks don't have a previewWidth prop, so no change is
needed there.
Refs #2726
* test: update snapshots for image/video width fix
- Image snapshots now include the new width attribute on the <img>
element when previewWidth is set.
- Video snapshots no longer include width="0" since the core video
render now guards against an undefined previewWidth.
Refs #2726
* fix: guard previewWidth to avoid emitting width="0" on video elements1 parent 792c439 commit 563e5bc
15 files changed
Lines changed: 80 additions & 15 deletions
File tree
- packages
- core/src/blocks
- Image
- Video
- react/src/blocks
- Image
- Video
- server-util/src/context/__snapshots__
- tests/src/unit
- core/formatConversion/export/__snapshots__/blocknoteHTML
- image
- video
- react/formatConversion/export/__snapshots__/blocknoteHTML/reactImage
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
122 | 122 | | |
123 | 123 | | |
124 | 124 | | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
125 | 128 | | |
126 | 129 | | |
127 | 130 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
92 | 92 | | |
93 | 93 | | |
94 | 94 | | |
95 | | - | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
96 | 98 | | |
97 | 99 | | |
98 | 100 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
32 | 32 | | |
33 | 33 | | |
34 | 34 | | |
| 35 | + | |
35 | 36 | | |
36 | 37 | | |
37 | 38 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
27 | 27 | | |
28 | 28 | | |
29 | 29 | | |
| 30 | + | |
30 | 31 | | |
31 | 32 | | |
32 | 33 | | |
| |||
44 | 45 | | |
45 | 46 | | |
46 | 47 | | |
47 | | - | |
| 48 | + | |
48 | 49 | | |
49 | 50 | | |
50 | 51 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
| 3 | + | |
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| |||
Lines changed: 7 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
15 | 15 | | |
16 | 16 | | |
17 | 17 | | |
18 | | - | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
19 | 25 | | |
20 | 26 | | |
21 | 27 | | |
| |||
Lines changed: 14 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
17 | | - | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
18 | 24 | | |
19 | 25 | | |
20 | 26 | | |
| |||
37 | 43 | | |
38 | 44 | | |
39 | 45 | | |
40 | | - | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
41 | 53 | | |
42 | 54 | | |
43 | 55 | | |
| |||
Lines changed: 7 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
17 | | - | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
18 | 24 | | |
19 | 25 | | |
20 | 26 | | |
| |||
Lines changed: 7 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
17 | | - | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
18 | 24 | | |
19 | 25 | | |
20 | 26 | | |
| |||
Lines changed: 0 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
21 | 20 | | |
22 | 21 | | |
23 | 22 | | |
| |||
0 commit comments