diff --git a/src/components/views/messages/MImageBody.js b/src/components/views/messages/MImageBody.js
index c42840b03a..1b6bdeb588 100644
--- a/src/components/views/messages/MImageBody.js
+++ b/src/components/views/messages/MImageBody.js
@@ -65,6 +65,7 @@ export default class extends React.Component {
error: null,
imgError: false,
imgLoaded: false,
+ loadedImageDimensions: null,
hover: false,
};
}
@@ -147,7 +148,16 @@ export default class extends React.Component {
onImageLoad() {
this.props.onWidgetLoad();
- this.setState({ imgLoaded: true });
+
+ let loadedImageDimensions;
+
+ if (this.refs.image) {
+ const { naturalWidth, naturalHeight } = this.refs.image;
+
+ loadedImageDimensions = { naturalWidth, naturalHeight };
+ }
+
+ this.setState({ imgLoaded: true, loadedImageDimensions });
}
_getContentUrl() {
@@ -185,7 +195,7 @@ export default class extends React.Component {
const content = this.props.mxEvent.getContent();
if (content.file !== undefined && this.state.decryptedUrl === null) {
let thumbnailPromise = Promise.resolve(null);
- if (content.info.thumbnail_file) {
+ if (content.info && content.info.thumbnail_file) {
thumbnailPromise = decryptFile(
content.info.thumbnail_file,
).then(function(blob) {
@@ -239,11 +249,37 @@ export default class extends React.Component {
}
_messageContent(contentUrl, thumbUrl, content) {
+ let infoWidth;
+ let infoHeight;
+
+ if (content && content.info && content.info.w && content.info.h) {
+ infoWidth = content.info.w;
+ infoHeight = content.info.h;
+ } else {
+ // Whilst the image loads, display nothing.
+ //
+ // Once loaded, use the loaded image dimensions stored in `loadedImageDimensions`.
+ //
+ // By doing this, the image "pops" into the timeline, but is still restricted
+ // by the same width and height logic below.
+ if (!this.state.loadedImageDimensions) {
+ return this.wrapImage(contentUrl,
+ ,
+ );
+ }
+ infoWidth = this.state.loadedImageDimensions.naturalWidth;
+ infoHeight = this.state.loadedImageDimensions.naturalHeight;
+ }
+
// The maximum height of the thumbnail as it is rendered as an
- const maxHeight = Math.min(this.props.maxImageHeight || 600, content.info.h);
+ const maxHeight = Math.min(this.props.maxImageHeight || 600, infoHeight);
// The maximum width of the thumbnail, as dictated by its natural
// maximum height.
- const maxWidth = content.info.w * maxHeight / content.info.h;
+ const maxWidth = infoWidth * maxHeight / infoHeight;
let img = null;
let placeholder = null;
@@ -274,12 +310,12 @@ export default class extends React.Component {
const thumbnail = (