@atlaskit/media-card 72.1.0 → 73.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/CHANGELOG.md +89 -0
  2. package/dist/cjs/actions.js +2 -2
  3. package/dist/cjs/errors.js +11 -7
  4. package/dist/cjs/files/cardImageView/cardOverlay/styled.js +1 -1
  5. package/dist/cjs/files/cardImageView/index.js +52 -42
  6. package/dist/cjs/files/cardImageView/styled.js +1 -1
  7. package/dist/cjs/index.js +8 -8
  8. package/dist/cjs/root/card/cardAnalytics.js +2 -2
  9. package/dist/cjs/root/card/cardState.js +2 -2
  10. package/dist/cjs/root/card/getCardPreview/cache.js +5 -5
  11. package/dist/cjs/root/card/getCardPreview/filePreviewStatus.js +4 -1
  12. package/dist/cjs/root/card/getCardPreview/helpers.js +1 -1
  13. package/dist/cjs/root/card/getCardPreview/index.js +18 -9
  14. package/dist/cjs/root/card/getCardStatus.js +1 -1
  15. package/dist/cjs/root/card/index.js +279 -159
  16. package/dist/cjs/root/cardView.js +130 -118
  17. package/dist/cjs/root/inline/loader.js +45 -14
  18. package/dist/cjs/root/inline/mediaInlineCard.js +24 -9
  19. package/dist/cjs/root/inlinePlayer.js +80 -25
  20. package/dist/cjs/root/styled.js +7 -3
  21. package/dist/cjs/root/ui/actionsBar/styled.js +1 -1
  22. package/dist/cjs/root/ui/blanket/styled.js +1 -1
  23. package/dist/cjs/root/ui/common.js +1 -1
  24. package/dist/cjs/root/ui/iconMessage/index.js +5 -3
  25. package/dist/cjs/root/ui/iconWrapper/styled.js +1 -1
  26. package/dist/cjs/root/ui/imageRenderer/imageRenderer.js +14 -6
  27. package/dist/cjs/root/ui/loadingRateLimited/loadingRateLimited.js +4 -2
  28. package/dist/cjs/root/ui/loadingRateLimited/styled.js +2 -2
  29. package/dist/cjs/root/ui/playButton/styled.js +1 -1
  30. package/dist/cjs/root/ui/progressBar/progressBar.js +5 -2
  31. package/dist/cjs/root/ui/progressBar/styled.js +7 -6
  32. package/dist/cjs/root/ui/styled.js +6 -6
  33. package/dist/cjs/root/ui/tickBox/styled.js +1 -1
  34. package/dist/cjs/root/ui/titleBox/failedTitleBox.js +4 -2
  35. package/dist/cjs/root/ui/titleBox/styled.js +1 -1
  36. package/dist/cjs/root/ui/titleBox/titleBox.js +2 -2
  37. package/dist/cjs/styles/index.js +25 -23
  38. package/dist/cjs/styles/mixins.js +1 -1
  39. package/dist/cjs/types.js +10 -1
  40. package/dist/cjs/utils/analytics.js +24 -7
  41. package/dist/cjs/utils/breakpoint.js +1 -1
  42. package/dist/cjs/utils/cardActions/cardActionsDropdownMenu.js +3 -1
  43. package/dist/cjs/utils/cardActions/index.js +10 -10
  44. package/dist/cjs/utils/cardActions/styled.js +1 -1
  45. package/dist/cjs/utils/cardDimensions.js +1 -1
  46. package/dist/cjs/utils/dimensionComparer.js +7 -13
  47. package/dist/cjs/utils/getErrorMessage.js +2 -2
  48. package/dist/cjs/utils/getMediaCardCursor.js +29 -0
  49. package/dist/cjs/utils/globalScope/getSSRData.js +20 -0
  50. package/dist/cjs/utils/globalScope/globalScope.js +94 -0
  51. package/dist/cjs/utils/globalScope/index.js +39 -0
  52. package/dist/cjs/utils/globalScope/types.js +5 -0
  53. package/dist/cjs/utils/index.js +46 -46
  54. package/dist/cjs/utils/lightCards/styled.js +1 -1
  55. package/dist/cjs/utils/objectURLCache.js +1 -1
  56. package/dist/cjs/utils/printScript.js +44 -0
  57. package/dist/cjs/utils/viewportDetector.js +49 -22
  58. package/dist/cjs/version.json +1 -1
  59. package/dist/es2019/files/cardImageView/index.js +19 -5
  60. package/dist/es2019/root/card/cardAnalytics.js +1 -1
  61. package/dist/es2019/root/card/getCardPreview/filePreviewStatus.js +4 -1
  62. package/dist/es2019/root/card/getCardPreview/index.js +1 -0
  63. package/dist/es2019/root/card/index.js +150 -49
  64. package/dist/es2019/root/cardView.js +40 -30
  65. package/dist/es2019/root/inline/loader.js +15 -4
  66. package/dist/es2019/root/inline/mediaInlineCard.js +23 -8
  67. package/dist/es2019/root/inlinePlayer.js +59 -5
  68. package/dist/es2019/root/styled.js +2 -1
  69. package/dist/es2019/root/ui/iconMessage/index.js +3 -2
  70. package/dist/es2019/root/ui/imageRenderer/imageRenderer.js +14 -6
  71. package/dist/es2019/root/ui/loadingRateLimited/loadingRateLimited.js +3 -2
  72. package/dist/es2019/root/ui/loadingRateLimited/styled.js +1 -1
  73. package/dist/es2019/root/ui/progressBar/progressBar.js +4 -2
  74. package/dist/es2019/root/ui/progressBar/styled.js +6 -4
  75. package/dist/es2019/root/ui/styled.js +5 -5
  76. package/dist/es2019/root/ui/titleBox/failedTitleBox.js +3 -2
  77. package/dist/es2019/root/ui/titleBox/titleBox.js +1 -1
  78. package/dist/es2019/types.js +7 -1
  79. package/dist/es2019/utils/analytics.js +8 -3
  80. package/dist/es2019/utils/dimensionComparer.js +6 -13
  81. package/dist/es2019/utils/getErrorMessage.js +1 -1
  82. package/dist/es2019/utils/getMediaCardCursor.js +19 -0
  83. package/dist/es2019/utils/globalScope/getSSRData.js +10 -0
  84. package/dist/es2019/utils/globalScope/globalScope.js +62 -0
  85. package/dist/es2019/utils/globalScope/index.js +2 -0
  86. package/dist/es2019/utils/globalScope/types.js +1 -0
  87. package/dist/es2019/utils/printScript.js +19 -0
  88. package/dist/es2019/utils/viewportDetector.js +48 -18
  89. package/dist/es2019/version.json +1 -1
  90. package/dist/esm/actions.js +2 -2
  91. package/dist/esm/errors.js +6 -5
  92. package/dist/esm/files/cardImageView/index.js +53 -41
  93. package/dist/esm/root/card/cardAnalytics.js +1 -1
  94. package/dist/esm/root/card/cardState.js +2 -2
  95. package/dist/esm/root/card/getCardPreview/cache.js +3 -2
  96. package/dist/esm/root/card/getCardPreview/filePreviewStatus.js +4 -1
  97. package/dist/esm/root/card/getCardPreview/index.js +5 -2
  98. package/dist/esm/root/card/index.js +266 -145
  99. package/dist/esm/root/cardView.js +128 -117
  100. package/dist/esm/root/inline/loader.js +46 -14
  101. package/dist/esm/root/inline/mediaInlineCard.js +23 -8
  102. package/dist/esm/root/inlinePlayer.js +77 -24
  103. package/dist/esm/root/styled.js +3 -2
  104. package/dist/esm/root/ui/iconMessage/index.js +3 -2
  105. package/dist/esm/root/ui/imageRenderer/imageRenderer.js +14 -6
  106. package/dist/esm/root/ui/loadingRateLimited/loadingRateLimited.js +3 -2
  107. package/dist/esm/root/ui/loadingRateLimited/styled.js +1 -1
  108. package/dist/esm/root/ui/progressBar/progressBar.js +5 -2
  109. package/dist/esm/root/ui/progressBar/styled.js +6 -5
  110. package/dist/esm/root/ui/styled.js +5 -5
  111. package/dist/esm/root/ui/titleBox/failedTitleBox.js +3 -2
  112. package/dist/esm/root/ui/titleBox/titleBox.js +1 -1
  113. package/dist/esm/types.js +7 -1
  114. package/dist/esm/utils/analytics.js +17 -6
  115. package/dist/esm/utils/cardActions/cardActionsDropdownMenu.js +2 -1
  116. package/dist/esm/utils/dimensionComparer.js +8 -13
  117. package/dist/esm/utils/getErrorMessage.js +1 -1
  118. package/dist/esm/utils/getMediaCardCursor.js +19 -0
  119. package/dist/esm/utils/globalScope/getSSRData.js +10 -0
  120. package/dist/esm/utils/globalScope/globalScope.js +69 -0
  121. package/dist/esm/utils/globalScope/index.js +2 -0
  122. package/dist/esm/utils/globalScope/types.js +1 -0
  123. package/dist/esm/utils/printScript.js +30 -0
  124. package/dist/esm/utils/viewportDetector.js +48 -21
  125. package/dist/esm/version.json +1 -1
  126. package/dist/types/errors.d.ts +1 -1
  127. package/dist/types/files/cardImageView/index.d.ts +6 -2
  128. package/dist/types/index.d.ts +1 -0
  129. package/dist/types/root/card/cardLoader.d.ts +2 -2
  130. package/dist/types/root/card/getCardPreview/index.d.ts +1 -0
  131. package/dist/types/root/card/index.d.ts +10 -9
  132. package/dist/types/root/cardView.d.ts +10 -8
  133. package/dist/types/root/inline/loader.d.ts +2 -0
  134. package/dist/types/root/inline/mediaInlineCard.d.ts +3 -5
  135. package/dist/types/root/inlinePlayer.d.ts +10 -1
  136. package/dist/types/root/styled.d.ts +1 -0
  137. package/dist/types/root/ui/iconMessage/index.d.ts +2 -2
  138. package/dist/types/root/ui/imageRenderer/imageRenderer.d.ts +4 -4
  139. package/dist/types/root/ui/loadingRateLimited/loadingRateLimited.d.ts +1 -0
  140. package/dist/types/root/ui/playButton/playButton.d.ts +1 -0
  141. package/dist/types/root/ui/progressBar/progressBar.d.ts +3 -1
  142. package/dist/types/root/ui/progressBar/styled.d.ts +2 -1
  143. package/dist/types/root/ui/styled.d.ts +2 -1
  144. package/dist/types/root/ui/tickBox/tickBox.d.ts +1 -0
  145. package/dist/types/root/ui/titleBox/failedTitleBox.d.ts +2 -2
  146. package/dist/types/root/ui/titleBox/titleBox.d.ts +1 -9
  147. package/dist/types/types.d.ts +6 -1
  148. package/dist/types/utils/analytics.d.ts +6 -0
  149. package/dist/types/utils/getErrorMessage.d.ts +1 -0
  150. package/dist/types/utils/getMediaCardCursor.d.ts +2 -0
  151. package/dist/types/utils/globalScope/getSSRData.d.ts +3 -0
  152. package/dist/types/utils/globalScope/globalScope.d.ts +21 -0
  153. package/dist/types/utils/globalScope/index.d.ts +4 -0
  154. package/dist/types/utils/globalScope/types.d.ts +8 -0
  155. package/dist/types/utils/printScript.d.ts +2 -0
  156. package/dist/types/utils/viewportDetector.d.ts +13 -5
  157. package/package.json +14 -16
  158. package/dist/cjs/utils/lazyContent/index.js +0 -56
  159. package/dist/cjs/utils/lazyContent/styled.js +0 -23
  160. package/dist/es2019/utils/lazyContent/index.js +0 -18
  161. package/dist/es2019/utils/lazyContent/styled.js +0 -12
  162. package/dist/esm/utils/lazyContent/index.js +0 -41
  163. package/dist/esm/utils/lazyContent/styled.js +0 -14
  164. package/dist/types/utils/lazyContent/index.d.ts +0 -11
  165. package/dist/types/utils/lazyContent/styled.d.ts +0 -5
@@ -5,7 +5,7 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
- exports.CardView = exports.CardViewBase = void 0;
8
+ exports.CardViewBase = exports.CardView = void 0;
9
9
 
10
10
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
11
 
@@ -83,9 +83,11 @@ var _cardConstants = require("./card/cardConstants");
83
83
 
84
84
  var _errors = require("../errors");
85
85
 
86
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
86
+ var _types = require("../types");
87
87
 
88
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
88
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
89
+
90
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
89
91
 
90
92
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
91
93
 
@@ -114,30 +116,37 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
114
116
  didImageRender: false
115
117
  });
116
118
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "divRef", /*#__PURE__*/_react.default.createRef());
117
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onImageLoad", function () {
118
- var onImageLoad = _this.props.onImageLoad; // We render the icon & icon message always, even if there is dataURI available.
119
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onImageLoad", function (prevCardPreview) {
120
+ var _this$props = _this.props,
121
+ onImageLoad = _this$props.onImageLoad,
122
+ cardPreview = _this$props.cardPreview;
123
+
124
+ if (prevCardPreview.dataURI !== (cardPreview === null || cardPreview === void 0 ? void 0 : cardPreview.dataURI)) {
125
+ return;
126
+ } // We render the icon & icon message always, even if there is cardPreview available.
119
127
  // If the image fails to load/render, the icon will remain, i.e. the user won't see a change until
120
128
  // the root card decides to chage status to error.
121
129
  // If the image renders successfully, we switch this variable to hide the icon & icon message
122
130
  // behind the thumbnail in case the image has transparency.
123
- // It is less likely that root component replaces a suceeded dataURI for a failed one
131
+ // It is less likely that root component replaces a suceeded cardPreview for a failed one
124
132
  // than the opposite case. Therefore we prefer to hide the icon instead show when the image fails,
125
133
  // for a smoother transition
126
134
 
135
+
127
136
  _this.setState({
128
137
  didImageRender: true
129
138
  });
130
139
 
131
- onImageLoad && onImageLoad();
140
+ onImageLoad && onImageLoad(cardPreview);
132
141
  });
133
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onImageError", function () {
142
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onImageError", function (cardPreview) {
134
143
  var onImageError = _this.props.onImageError;
135
144
 
136
145
  _this.setState({
137
146
  didImageRender: false
138
147
  });
139
148
 
140
- onImageError && onImageError();
149
+ onImageError && onImageError(cardPreview);
141
150
  });
142
151
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "saveElementWidth", function () {
143
152
  var dimensions = _this.props.dimensions;
@@ -157,24 +166,24 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
157
166
  }
158
167
  });
159
168
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "renderFileNewExperience", function () {
160
- var _this$props = _this.props,
161
- dimensions = _this$props.dimensions,
162
- appearance = _this$props.appearance,
163
- onClick = _this$props.onClick,
164
- onMouseEnter = _this$props.onMouseEnter,
165
- testId = _this$props.testId,
166
- metadata = _this$props.metadata,
167
- status = _this$props.status,
168
- selected = _this$props.selected,
169
- selectable = _this$props.selectable,
170
- disableOverlay = _this$props.disableOverlay,
171
- dataURI = _this$props.dataURI;
169
+ var _this$props2 = _this.props,
170
+ dimensions = _this$props2.dimensions,
171
+ appearance = _this$props2.appearance,
172
+ onClick = _this$props2.onClick,
173
+ onMouseEnter = _this$props2.onMouseEnter,
174
+ testId = _this$props2.testId,
175
+ metadata = _this$props2.metadata,
176
+ status = _this$props2.status,
177
+ selected = _this$props2.selected,
178
+ selectable = _this$props2.selectable,
179
+ disableOverlay = _this$props2.disableOverlay,
180
+ cardPreview = _this$props2.cardPreview,
181
+ mediaCardCursor = _this$props2.mediaCardCursor;
172
182
 
173
183
  var _ref = metadata || {},
174
184
  name = _ref.name;
175
185
 
176
- var shouldUsePointerCursor = status !== 'error' && status !== 'failed-processing';
177
- var shouldDisplayBackground = !dataURI || !disableOverlay || status === 'error' || status === 'failed-processing';
186
+ var shouldDisplayBackground = !cardPreview || !disableOverlay || status === 'error' || status === 'failed-processing';
178
187
  var isPlayButtonClickable = !!(_this.shouldRenderPlayButton() && disableOverlay);
179
188
  var isTickBoxSelectable = !disableOverlay && !!selectable && !selected; // Disable tooltip for Media Single
180
189
 
@@ -188,7 +197,7 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
188
197
  onMouseEnter: onMouseEnter,
189
198
  innerRef: _this.divRef,
190
199
  breakpoint: _this.breakpoint,
191
- shouldUsePointerCursor: shouldUsePointerCursor,
200
+ mediaCardCursor: mediaCardCursor,
192
201
  disableOverlay: !!disableOverlay,
193
202
  selected: !!selected,
194
203
  displayBackground: shouldDisplayBackground,
@@ -202,27 +211,30 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
202
211
  }, _this.renderNewExperienceCard()) : _this.renderNewExperienceCard());
203
212
  });
204
213
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "renderFile", function () {
205
- var _this$props2 = _this.props,
206
- status = _this$props2.status,
207
- mediaItemType = _this$props2.mediaItemType,
208
- metadata = _this$props2.metadata,
209
- dataURI = _this$props2.dataURI,
210
- progress = _this$props2.progress,
211
- resizeMode = _this$props2.resizeMode,
212
- dimensions = _this$props2.dimensions,
213
- selectable = _this$props2.selectable,
214
- selected = _this$props2.selected,
215
- disableOverlay = _this$props2.disableOverlay,
216
- previewOrientation = _this$props2.previewOrientation,
217
- alt = _this$props2.alt,
218
- onDisplayImage = _this$props2.onDisplayImage,
219
- actions = _this$props2.actions;
214
+ var _this$props3 = _this.props,
215
+ cardPreview = _this$props3.cardPreview,
216
+ status = _this$props3.status,
217
+ mediaItemType = _this$props3.mediaItemType,
218
+ metadata = _this$props3.metadata,
219
+ progress = _this$props3.progress,
220
+ resizeMode = _this$props3.resizeMode,
221
+ dimensions = _this$props3.dimensions,
222
+ selectable = _this$props3.selectable,
223
+ selected = _this$props3.selected,
224
+ disableOverlay = _this$props3.disableOverlay,
225
+ alt = _this$props3.alt,
226
+ onDisplayImage = _this$props3.onDisplayImage,
227
+ actions = _this$props3.actions;
228
+
229
+ var _ref2 = cardPreview || {},
230
+ dataURI = _ref2.dataURI,
231
+ orientation = _ref2.orientation;
220
232
 
221
- var _ref2 = metadata || {},
222
- name = _ref2.name,
223
- mediaType = _ref2.mediaType,
224
- mimeType = _ref2.mimeType,
225
- size = _ref2.size;
233
+ var _ref3 = metadata || {},
234
+ name = _ref3.name,
235
+ mediaType = _ref3.mediaType,
236
+ mimeType = _ref3.mimeType,
237
+ size = _ref3.size;
226
238
 
227
239
  var actionsWithDetails = metadata && actions ? (0, _actions.attachDetailsToActions)(actions, metadata) : [];
228
240
  var errorMessage = (0, _getErrorMessage.getErrorMessage)(status);
@@ -244,32 +256,33 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
244
256
  onDisplayImage: onDisplayImage,
245
257
  actions: actionsWithDetails,
246
258
  disableOverlay: disableOverlay,
247
- previewOrientation: previewOrientation,
259
+ previewOrientation: orientation,
248
260
  alt: alt,
249
261
  onImageLoad: _this.onImageLoad,
250
- onImageError: _this.onImageError
262
+ onImageError: _this.onImageError,
263
+ cardPreview: cardPreview
251
264
  });
252
265
  });
253
266
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "getRenderConfigByStatus", function () {
254
- var _this$props3 = _this.props,
255
- dataURI = _this$props3.dataURI,
256
- status = _this$props3.status,
257
- metadata = _this$props3.metadata,
258
- disableOverlay = _this$props3.disableOverlay,
259
- error = _this$props3.error,
260
- selectable = _this$props3.selectable,
261
- disableAnimation = _this$props3.disableAnimation;
267
+ var _this$props4 = _this.props,
268
+ cardPreview = _this$props4.cardPreview,
269
+ status = _this$props4.status,
270
+ metadata = _this$props4.metadata,
271
+ disableOverlay = _this$props4.disableOverlay,
272
+ error = _this$props4.error,
273
+ selectable = _this$props4.selectable,
274
+ disableAnimation = _this$props4.disableAnimation;
262
275
 
263
- var _ref3 = metadata || {},
264
- name = _ref3.name,
265
- mediaType = _ref3.mediaType;
276
+ var _ref4 = metadata || {},
277
+ name = _ref4.name,
278
+ mediaType = _ref4.mediaType;
266
279
 
267
280
  var didImageRender = _this.state.didImageRender;
268
281
  var isZeroSize = !!(metadata && metadata.size === 0);
269
282
  var defaultConfig = {
270
283
  renderTypeIcon: !didImageRender,
271
- renderImageRenderer: !!dataURI,
272
- renderPlayButton: !!dataURI && mediaType === 'video',
284
+ renderImageRenderer: !!cardPreview,
285
+ renderPlayButton: !!cardPreview && mediaType === 'video',
273
286
  renderBlanket: !disableOverlay,
274
287
  renderTitleBox: !disableOverlay && !!name,
275
288
  renderTickBox: !disableOverlay && !!selectable
@@ -306,8 +319,8 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
306
319
  var iconMessage;
307
320
  var customTitleMessage;
308
321
 
309
- var _ref4 = error || {},
310
- secondaryError = _ref4.secondaryError;
322
+ var _ref5 = error || {},
323
+ secondaryError = _ref5.secondaryError;
311
324
 
312
325
  if ((0, _mediaClient.isRateLimitedError)(secondaryError) || (0, _mediaClient.isPollingError)(secondaryError)) {
313
326
  iconMessage = /*#__PURE__*/_react.default.createElement(_iconMessage.PreviewCurrentlyUnavailable, null);
@@ -358,14 +371,14 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
358
371
  isFixedBlanket = _this$getRenderConfig.isFixedBlanket,
359
372
  customTitleMessage = _this$getRenderConfig.customTitleMessage;
360
373
 
361
- var _this$props4 = _this.props,
362
- progress = _this$props4.progress,
363
- selected = _this$props4.selected,
364
- status = _this$props4.status,
365
- metadata = _this$props4.metadata;
374
+ var _this$props5 = _this.props,
375
+ progress = _this$props5.progress,
376
+ selected = _this$props5.selected,
377
+ status = _this$props5.status,
378
+ metadata = _this$props5.metadata;
366
379
 
367
- var _ref5 = metadata || {},
368
- name = _ref5.name;
380
+ var _ref6 = metadata || {},
381
+ name = _ref6.name;
369
382
 
370
383
  var hasTitleBox = !!renderTitleBox || !!renderFailedTitleBox;
371
384
  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_styled2.CardImageContainer, {
@@ -389,14 +402,14 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
389
402
  }
390
403
  }, {
391
404
  key: "componentDidUpdate",
392
- value: function componentDidUpdate(_ref6) {
393
- var prevDataURI = _ref6.dataURI;
394
- var dataURI = this.props.dataURI; // We should only switch didImageRender to false
395
- // when dataURI goes undefined, not when it is updated.
405
+ value: function componentDidUpdate(_ref7) {
406
+ var prevCardPreview = _ref7.cardPreview;
407
+ var cardPreview = this.props.cardPreview; // We should only switch didImageRender to false
408
+ // when cardPreview goes undefined, not when it is updated.
396
409
  // as this method could be triggered after onImageLoad callback,
397
410
  // falling on a race condition
398
411
 
399
- prevDataURI && !dataURI && this.setState({
412
+ !!prevCardPreview && !cardPreview && this.setState({
400
413
  didImageRender: false
401
414
  });
402
415
  }
@@ -411,10 +424,10 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
411
424
  return elementWidth;
412
425
  }
413
426
 
414
- var _ref7 = this.props.dimensions || {
427
+ var _ref8 = this.props.dimensions || {
415
428
  width: undefined
416
429
  },
417
- width = _ref7.width;
430
+ width = _ref8.width;
418
431
 
419
432
  if (!width) {
420
433
  return _cardDimensions.defaultImageCardDimensions.width;
@@ -439,12 +452,12 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
439
452
  return this.renderFileNewExperience();
440
453
  }
441
454
 
442
- var _this$props5 = this.props,
443
- dimensions = _this$props5.dimensions,
444
- appearance = _this$props5.appearance,
445
- onClick = _this$props5.onClick,
446
- onMouseEnter = _this$props5.onMouseEnter,
447
- testId = _this$props5.testId;
455
+ var _this$props6 = this.props,
456
+ dimensions = _this$props6.dimensions,
457
+ appearance = _this$props6.appearance,
458
+ onClick = _this$props6.onClick,
459
+ onMouseEnter = _this$props6.onMouseEnter,
460
+ testId = _this$props6.testId;
448
461
  var wrapperDimensions = dimensions ? dimensions : (0, _cardDimensions.getDefaultCardDimensions)(appearance);
449
462
  return /*#__PURE__*/_react.default.createElement(_styled.Wrapper, {
450
463
  "data-testid": testId || 'media-card-view',
@@ -467,14 +480,14 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
467
480
  }, {
468
481
  key: "shouldRenderPlayButton",
469
482
  value: function shouldRenderPlayButton() {
470
- var _this$props6 = this.props,
471
- metadata = _this$props6.metadata,
472
- dataURI = _this$props6.dataURI;
483
+ var _this$props7 = this.props,
484
+ metadata = _this$props7.metadata,
485
+ cardPreview = _this$props7.cardPreview;
473
486
 
474
- var _ref8 = metadata || {},
475
- mediaType = _ref8.mediaType;
487
+ var _ref9 = metadata || {},
488
+ mediaType = _ref9.mediaType;
476
489
 
477
- if (mediaType !== 'video' || !dataURI) {
490
+ if (mediaType !== 'video' || !cardPreview) {
478
491
  return false;
479
492
  }
480
493
 
@@ -500,14 +513,14 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
500
513
  }, {
501
514
  key: "renderTitleBox",
502
515
  value: function renderTitleBox() {
503
- var _this$props7 = this.props,
504
- metadata = _this$props7.metadata,
505
- titleBoxBgColor = _this$props7.titleBoxBgColor,
506
- titleBoxIcon = _this$props7.titleBoxIcon;
516
+ var _this$props8 = this.props,
517
+ metadata = _this$props8.metadata,
518
+ titleBoxBgColor = _this$props8.titleBoxBgColor,
519
+ titleBoxIcon = _this$props8.titleBoxIcon;
507
520
 
508
- var _ref9 = metadata || {},
509
- name = _ref9.name,
510
- createdAt = _ref9.createdAt;
521
+ var _ref10 = metadata || {},
522
+ name = _ref10.name,
523
+ createdAt = _ref10.createdAt;
511
524
 
512
525
  return !!name && /*#__PURE__*/_react.default.createElement(_titleBox.TitleBox, {
513
526
  name: name,
@@ -538,22 +551,20 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
538
551
  }, {
539
552
  key: "renderImageRenderer",
540
553
  value: function renderImageRenderer() {
541
- var _this$props8 = this.props,
542
- dataURI = _this$props8.dataURI,
543
- _this$props8$metadata = _this$props8.metadata;
544
- _this$props8$metadata = _this$props8$metadata === void 0 ? {} : _this$props8$metadata;
545
- var _this$props8$metadata2 = _this$props8$metadata.mediaType,
546
- mediaType = _this$props8$metadata2 === void 0 ? 'unknown' : _this$props8$metadata2,
547
- previewOrientation = _this$props8.previewOrientation,
548
- alt = _this$props8.alt,
549
- resizeMode = _this$props8.resizeMode,
550
- onDisplayImage = _this$props8.onDisplayImage,
551
- nativeLazyLoad = _this$props8.nativeLazyLoad,
552
- forceSyncDisplay = _this$props8.forceSyncDisplay;
553
- return !!dataURI && /*#__PURE__*/_react.default.createElement(_imageRenderer.ImageRenderer, {
554
- dataURI: dataURI,
554
+ var _this$props9 = this.props,
555
+ cardPreview = _this$props9.cardPreview,
556
+ _this$props9$metadata = _this$props9.metadata;
557
+ _this$props9$metadata = _this$props9$metadata === void 0 ? {} : _this$props9$metadata;
558
+ var _this$props9$metadata2 = _this$props9$metadata.mediaType,
559
+ mediaType = _this$props9$metadata2 === void 0 ? 'unknown' : _this$props9$metadata2,
560
+ alt = _this$props9.alt,
561
+ resizeMode = _this$props9.resizeMode,
562
+ onDisplayImage = _this$props9.onDisplayImage,
563
+ nativeLazyLoad = _this$props9.nativeLazyLoad,
564
+ forceSyncDisplay = _this$props9.forceSyncDisplay;
565
+ return !!cardPreview && /*#__PURE__*/_react.default.createElement(_imageRenderer.ImageRenderer, {
566
+ cardPreview: cardPreview,
555
567
  mediaType: mediaType,
556
- previewOrientation: previewOrientation,
557
568
  alt: alt,
558
569
  resizeMode: resizeMode,
559
570
  onDisplayImage: onDisplayImage,
@@ -576,10 +587,10 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
576
587
  value: function renderMediaTypeIcon(hasTitleBox, iconMessage) {
577
588
  var metadata = this.props.metadata;
578
589
 
579
- var _ref10 = metadata || {},
580
- mediaType = _ref10.mediaType,
581
- mimeType = _ref10.mimeType,
582
- name = _ref10.name;
590
+ var _ref11 = metadata || {},
591
+ mediaType = _ref11.mediaType,
592
+ mimeType = _ref11.mimeType,
593
+ name = _ref11.name;
583
594
 
584
595
  return /*#__PURE__*/_react.default.createElement(_styled4.IconWrapper, {
585
596
  breakpoint: this.breakpoint,
@@ -594,10 +605,10 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
594
605
  }, {
595
606
  key: "renderActionsBar",
596
607
  value: function renderActionsBar() {
597
- var _this$props9 = this.props,
598
- disableOverlay = _this$props9.disableOverlay,
599
- actions = _this$props9.actions,
600
- metadata = _this$props9.metadata;
608
+ var _this$props10 = this.props,
609
+ disableOverlay = _this$props10.disableOverlay,
610
+ actions = _this$props10.actions,
611
+ metadata = _this$props10.metadata;
601
612
  var actionsWithDetails = metadata && actions ? (0, _actions.attachDetailsToActions)(actions, metadata) : [];
602
613
 
603
614
  if (disableOverlay || !actions || actions.length === 0) {
@@ -614,7 +625,8 @@ var CardViewBase = /*#__PURE__*/function (_React$Component) {
614
625
 
615
626
  exports.CardViewBase = CardViewBase;
616
627
  (0, _defineProperty2.default)(CardViewBase, "defaultProps", {
617
- appearance: 'auto'
628
+ appearance: 'auto',
629
+ mediaCardCursor: _types.MediaCardCursor.NoAction
618
630
  });
619
631
  var CardView = (0, _analyticsNext.withAnalyticsEvents)({
620
632
  onClick: (0, _analytics.createAndFireMediaCardEvent)({
@@ -56,6 +56,7 @@ var MediaInlineCardLoader = /*#__PURE__*/function (_React$PureComponent) {
56
56
  }
57
57
 
58
58
  _this = _super.call.apply(_super, [this].concat(args));
59
+ (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "isMounted", false);
59
60
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {
60
61
  MediaInlineCard: MediaInlineCardLoader.MediaInlineCard,
61
62
  ErrorBoundary: MediaInlineCardLoader.ErrorBoundary
@@ -73,13 +74,15 @@ var MediaInlineCardLoader = /*#__PURE__*/function (_React$PureComponent) {
73
74
  while (1) {
74
75
  switch (_context.prev = _context.next) {
75
76
  case 0:
77
+ this.isMounted = true;
78
+
76
79
  if (this.state.MediaInlineCard) {
77
- _context.next = 16;
80
+ _context.next = 17;
78
81
  break;
79
82
  }
80
83
 
81
- _context.prev = 1;
82
- _context.next = 4;
84
+ _context.prev = 2;
85
+ _context.next = 5;
83
86
  return Promise.all([Promise.resolve().then(function () {
84
87
  return _interopRequireWildcard(require('@atlaskit/media-client'));
85
88
  }), Promise.resolve().then(function () {
@@ -88,7 +91,7 @@ var MediaInlineCardLoader = /*#__PURE__*/function (_React$PureComponent) {
88
91
  return _interopRequireWildcard(require('../media-card-analytics-error-boundary'));
89
92
  })]);
90
93
 
91
- case 4:
94
+ case 5:
92
95
  _yield$Promise$all = _context.sent;
93
96
  _yield$Promise$all2 = (0, _slicedToArray2.default)(_yield$Promise$all, 3);
94
97
  mediaClient = _yield$Promise$all2[0];
@@ -96,23 +99,27 @@ var MediaInlineCardLoader = /*#__PURE__*/function (_React$PureComponent) {
96
99
  mediaCardErrorBoundaryModule = _yield$Promise$all2[2];
97
100
  MediaInlineCardLoader.MediaInlineCard = mediaClient.withMediaClient(cardModule.MediaInlineCard);
98
101
  MediaInlineCardLoader.ErrorBoundary = mediaCardErrorBoundaryModule.default;
99
- this.setState({
100
- MediaInlineCard: MediaInlineCardLoader.MediaInlineCard,
101
- ErrorBoundary: MediaInlineCardLoader.ErrorBoundary
102
- });
103
- _context.next = 16;
102
+
103
+ if (this.isMounted) {
104
+ this.setState({
105
+ MediaInlineCard: MediaInlineCardLoader.MediaInlineCard,
106
+ ErrorBoundary: MediaInlineCardLoader.ErrorBoundary
107
+ });
108
+ }
109
+
110
+ _context.next = 17;
104
111
  break;
105
112
 
106
- case 14:
107
- _context.prev = 14;
108
- _context.t0 = _context["catch"](1);
113
+ case 15:
114
+ _context.prev = 15;
115
+ _context.t0 = _context["catch"](2);
109
116
 
110
- case 16:
117
+ case 17:
111
118
  case "end":
112
119
  return _context.stop();
113
120
  }
114
121
  }
115
- }, _callee, this, [[1, 14]]);
122
+ }, _callee, this, [[2, 15]]);
116
123
  }));
117
124
 
118
125
  function componentDidMount() {
@@ -121,6 +128,30 @@ var MediaInlineCardLoader = /*#__PURE__*/function (_React$PureComponent) {
121
128
 
122
129
  return componentDidMount;
123
130
  }()
131
+ }, {
132
+ key: "componentWillUnmount",
133
+ value: function () {
134
+ var _componentWillUnmount = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
135
+ return _regenerator.default.wrap(function _callee2$(_context2) {
136
+ while (1) {
137
+ switch (_context2.prev = _context2.next) {
138
+ case 0:
139
+ this.isMounted = false;
140
+
141
+ case 1:
142
+ case "end":
143
+ return _context2.stop();
144
+ }
145
+ }
146
+ }, _callee2, this);
147
+ }));
148
+
149
+ function componentWillUnmount() {
150
+ return _componentWillUnmount.apply(this, arguments);
151
+ }
152
+
153
+ return componentWillUnmount;
154
+ }()
124
155
  }, {
125
156
  key: "render",
126
157
  value: function render() {
@@ -7,7 +7,7 @@ var _typeof = require("@babel/runtime/helpers/typeof");
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
- exports.MediaInlineCard = exports.MediaInlineCardInternal = void 0;
10
+ exports.MediaInlineCardInternal = exports.MediaInlineCard = void 0;
11
11
 
12
12
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
13
 
@@ -15,7 +15,7 @@ var _react = _interopRequireWildcard(require("react"));
15
15
 
16
16
  var _reactDom = _interopRequireDefault(require("react-dom"));
17
17
 
18
- var _reactIntl = require("react-intl");
18
+ var _reactIntlNext = require("react-intl-next");
19
19
 
20
20
  var _mediaUi = require("@atlaskit/media-ui");
21
21
 
@@ -87,29 +87,42 @@ var MediaInlineCardInternal = function MediaInlineCardInternal(_ref) {
87
87
  return null;
88
88
  };
89
89
 
90
+ var renderContent = function renderContent(children) {
91
+ return intl ? children : /*#__PURE__*/_react.default.createElement(_reactIntlNext.IntlProvider, {
92
+ locale: "en"
93
+ }, children);
94
+ };
95
+
96
+ var defaultIntl = (0, _reactIntlNext.createIntl)({
97
+ locale: 'en'
98
+ });
90
99
  (0, _react.useEffect)(function () {
91
- mediaClient.file.getFileState(identifier.id, {
100
+ var subscription = mediaClient.file.getFileState(identifier.id, {
92
101
  collectionName: identifier.collectionName
93
102
  }).subscribe({
94
103
  next: function next(fileState) {
95
104
  setFileState(fileState);
105
+ setIsErrored(false);
96
106
  },
97
107
  error: function error() {
98
108
  setIsErrored(true);
99
109
  }
100
110
  });
111
+ return function () {
112
+ subscription.unsubscribe();
113
+ };
101
114
  }, [identifier.collectionName, identifier.id, mediaClient.file]);
102
115
 
103
116
  if (!fileState) {
104
117
  return /*#__PURE__*/_react.default.createElement(_mediaUi.MediaInlineCardLoadingView, {
105
- message: intl.formatMessage(_mediaUi.messages.loading_file),
118
+ message: (intl || defaultIntl).formatMessage(_mediaUi.messages.loading_file),
106
119
  isSelected: isSelected
107
120
  });
108
121
  }
109
122
 
110
123
  if (isErrored) {
111
124
  return /*#__PURE__*/_react.default.createElement(_mediaUi.MediaInlineCardErroredView, {
112
- message: intl.formatMessage(_mediaUi.messages.couldnt_load_file),
125
+ message: (intl || defaultIntl).formatMessage(_mediaUi.messages.couldnt_load_file),
113
126
  isSelected: isSelected
114
127
  });
115
128
  }
@@ -123,7 +136,7 @@ var MediaInlineCardInternal = function MediaInlineCardInternal(_ref) {
123
136
 
124
137
  if (fileState.status === 'failed-processing') {
125
138
  return /*#__PURE__*/_react.default.createElement(_mediaUi.MediaInlineCardErroredView, {
126
- message: intl.formatMessage(_mediaUi.messages.couldnt_load_file),
139
+ message: (intl || defaultIntl).formatMessage(_mediaUi.messages.couldnt_load_file),
127
140
  isSelected: isSelected
128
141
  });
129
142
  }
@@ -157,7 +170,7 @@ var MediaInlineCardInternal = function MediaInlineCardInternal(_ref) {
157
170
  formattedDate = (0, _formatDate.formatDate)(fileState.createdAt, locale);
158
171
  }
159
172
 
160
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_tooltip.default, {
173
+ return renderContent( /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_tooltip.default, {
161
174
  position: "bottom",
162
175
  content: formattedDate,
163
176
  tag: "span"
@@ -166,9 +179,11 @@ var MediaInlineCardInternal = function MediaInlineCardInternal(_ref) {
166
179
  title: name,
167
180
  onClick: onMediaInlineCardClick,
168
181
  isSelected: isSelected
169
- })), mediaViewer);
182
+ })), mediaViewer));
170
183
  };
171
184
 
172
185
  exports.MediaInlineCardInternal = MediaInlineCardInternal;
173
- var MediaInlineCard = (0, _reactIntl.injectIntl)(MediaInlineCardInternal);
186
+ var MediaInlineCard = (0, _reactIntlNext.injectIntl)(MediaInlineCardInternal, {
187
+ enforceContext: false
188
+ });
174
189
  exports.MediaInlineCard = MediaInlineCard;