diff --git a/res/css/views/rooms/_EventTile.scss b/res/css/views/rooms/_EventTile.scss index 51e7f16927..ddf10840c8 100644 --- a/res/css/views/rooms/_EventTile.scss +++ b/res/css/views/rooms/_EventTile.scss @@ -471,9 +471,6 @@ $left-gutter: 64px; // selector wrongly applies to pill avatars but those have explicit width/height passed at a higher specificity &.markdown-body img { - // the image will have max-width and max-height applied during sanitization - width: 100%; - height: 100%; object-fit: contain; object-position: left top; } diff --git a/src/HtmlUtils.tsx b/src/HtmlUtils.tsx index ca391fc300..2f0e4fc8c5 100644 --- a/src/HtmlUtils.tsx +++ b/src/HtmlUtils.tsx @@ -209,11 +209,19 @@ const transformTags: IExtendedSanitizeOptions["transformTags"] = { // custom to return { tagName, attribs: {} }; } - const width = Math.min(Number(attribs.width) || 800, 800); - const height = Math.min(Number(attribs.height) || 600, 600); + const requestedWidth = Number(attribs.width); + const requestedHeight = Number(attribs.height); + const width = Math.min(requestedWidth || 800, 800); + const height = Math.min(requestedHeight || 600, 600); // specify width/height as max values instead of absolute ones to allow object-fit to do its thing // we only allow our own styles for this tag so overwrite the attribute attribs.style = `max-width: ${width}px; max-height: ${height}px;`; + if (requestedWidth) { + attribs.style += "width: 100%;"; + } + if (requestedHeight) { + attribs.style += "height: 100%;"; + } attribs.src = mediaFromMxc(src).getThumbnailOfSourceHttp(width, height); return { tagName, attribs };