@atlaskit/media-ui 28.2.3 → 28.3.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 (145) hide show
  1. package/CHANGELOG.md +18 -0
  2. package/dist/cjs/MediaInlineCard/ErroredView/index.compiled.css +1 -0
  3. package/dist/cjs/MediaInlineCard/ErroredView/index.js +16 -17
  4. package/dist/cjs/MediaInlineCard/Frame/index.js +3 -1
  5. package/dist/cjs/MediaInlineCard/Frame/styled-compiled.compiled.css +3 -0
  6. package/dist/cjs/MediaInlineCard/Frame/styled-compiled.js +6 -3
  7. package/dist/cjs/MediaInlineCard/Frame/styled-emotion.js +10 -0
  8. package/dist/cjs/abuseModal/abuseModal.js +4 -28
  9. package/dist/cjs/customMediaPlayer/analytics/events/operational/captionDeleteFailed.js +24 -0
  10. package/dist/cjs/customMediaPlayer/analytics/events/operational/captionDeleteSucceeded.js +16 -0
  11. package/dist/cjs/customMediaPlayer/analytics/events/operational/captionUploadFailed.js +24 -0
  12. package/dist/cjs/customMediaPlayer/analytics/events/operational/captionUploadSucceeded.js +16 -0
  13. package/dist/cjs/customMediaPlayer/analytics/index.js +28 -0
  14. package/dist/cjs/customMediaPlayer/analytics/utils/captionAttributes.js +24 -0
  15. package/dist/cjs/customMediaPlayer/index.js +1 -1
  16. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/apiFeedback.js +46 -0
  17. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/uploader.js +32 -52
  18. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/util.js +12 -0
  19. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/artifactUploader/captionsUploaderBrowser.js +29 -5
  20. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/artifactUploader/index.js +3 -2
  21. package/dist/cjs/customMediaPlayer/mediaPlayer/captions/captionDeleteConfirmationModal.js +103 -0
  22. package/dist/cjs/customMediaPlayer/mediaPlayer/captionsAdminControls.js +6 -3
  23. package/dist/cjs/customMediaPlayer/mediaPlayer/captionsSelectControls.js +6 -2
  24. package/dist/cjs/customMediaPlayer/mediaPlayer/mediaPlayer.js +1 -1
  25. package/dist/cjs/customMediaPlayer/mediaPlayer/mediaPlayerBase.js +82 -9
  26. package/dist/cjs/customMediaPlayer/mediaPlayer/useTextTracks.js +2 -1
  27. package/dist/cjs/customMediaPlayer/timeRange.js +14 -13
  28. package/dist/cjs/messages.js +45 -0
  29. package/dist/es2019/MediaInlineCard/ErroredView/index.compiled.css +1 -0
  30. package/dist/es2019/MediaInlineCard/ErroredView/index.js +13 -17
  31. package/dist/es2019/MediaInlineCard/Frame/index.js +3 -1
  32. package/dist/es2019/MediaInlineCard/Frame/styled-compiled.compiled.css +4 -1
  33. package/dist/es2019/MediaInlineCard/Frame/styled-compiled.js +4 -2
  34. package/dist/es2019/MediaInlineCard/Frame/styled-emotion.js +9 -1
  35. package/dist/es2019/abuseModal/abuseModal.js +4 -28
  36. package/dist/es2019/customMediaPlayer/analytics/events/operational/captionDeleteFailed.js +15 -0
  37. package/dist/es2019/customMediaPlayer/analytics/events/operational/captionDeleteSucceeded.js +10 -0
  38. package/dist/es2019/customMediaPlayer/analytics/events/operational/captionUploadFailed.js +15 -0
  39. package/dist/es2019/customMediaPlayer/analytics/events/operational/captionUploadSucceeded.js +10 -0
  40. package/dist/es2019/customMediaPlayer/analytics/index.js +4 -0
  41. package/dist/es2019/customMediaPlayer/analytics/utils/captionAttributes.js +16 -0
  42. package/dist/es2019/customMediaPlayer/index.js +1 -1
  43. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/apiFeedback.js +40 -0
  44. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/uploader.js +14 -17
  45. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/util.js +6 -0
  46. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/artifactUploader/captionsUploaderBrowser.js +23 -4
  47. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/artifactUploader/index.js +2 -1
  48. package/dist/es2019/customMediaPlayer/mediaPlayer/captions/captionDeleteConfirmationModal.js +68 -0
  49. package/dist/es2019/customMediaPlayer/mediaPlayer/captionsAdminControls.js +4 -3
  50. package/dist/es2019/customMediaPlayer/mediaPlayer/captionsSelectControls.js +4 -2
  51. package/dist/es2019/customMediaPlayer/mediaPlayer/mediaPlayer.js +1 -1
  52. package/dist/es2019/customMediaPlayer/mediaPlayer/mediaPlayerBase.js +75 -10
  53. package/dist/es2019/customMediaPlayer/mediaPlayer/useTextTracks.js +2 -1
  54. package/dist/es2019/customMediaPlayer/timeRange.js +14 -13
  55. package/dist/es2019/messages.js +45 -0
  56. package/dist/esm/MediaInlineCard/ErroredView/index.compiled.css +1 -0
  57. package/dist/esm/MediaInlineCard/ErroredView/index.js +17 -18
  58. package/dist/esm/MediaInlineCard/Frame/index.js +3 -1
  59. package/dist/esm/MediaInlineCard/Frame/styled-compiled.compiled.css +3 -0
  60. package/dist/esm/MediaInlineCard/Frame/styled-compiled.js +7 -4
  61. package/dist/esm/MediaInlineCard/Frame/styled-emotion.js +11 -1
  62. package/dist/esm/abuseModal/abuseModal.js +4 -28
  63. package/dist/esm/customMediaPlayer/analytics/events/operational/captionDeleteFailed.js +17 -0
  64. package/dist/esm/customMediaPlayer/analytics/events/operational/captionDeleteSucceeded.js +10 -0
  65. package/dist/esm/customMediaPlayer/analytics/events/operational/captionUploadFailed.js +17 -0
  66. package/dist/esm/customMediaPlayer/analytics/events/operational/captionUploadSucceeded.js +10 -0
  67. package/dist/esm/customMediaPlayer/analytics/index.js +4 -0
  68. package/dist/esm/customMediaPlayer/analytics/utils/captionAttributes.js +17 -0
  69. package/dist/esm/customMediaPlayer/index.js +1 -1
  70. package/dist/esm/customMediaPlayer/mediaPlayer/captions/apiFeedback.js +39 -0
  71. package/dist/esm/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/uploader.js +32 -52
  72. package/dist/esm/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/util.js +6 -0
  73. package/dist/esm/customMediaPlayer/mediaPlayer/captions/artifactUploader/captionsUploaderBrowser.js +28 -4
  74. package/dist/esm/customMediaPlayer/mediaPlayer/captions/artifactUploader/index.js +2 -1
  75. package/dist/esm/customMediaPlayer/mediaPlayer/captions/captionDeleteConfirmationModal.js +94 -0
  76. package/dist/esm/customMediaPlayer/mediaPlayer/captionsAdminControls.js +6 -3
  77. package/dist/esm/customMediaPlayer/mediaPlayer/captionsSelectControls.js +6 -2
  78. package/dist/esm/customMediaPlayer/mediaPlayer/mediaPlayer.js +1 -1
  79. package/dist/esm/customMediaPlayer/mediaPlayer/mediaPlayerBase.js +83 -10
  80. package/dist/esm/customMediaPlayer/mediaPlayer/useTextTracks.js +2 -1
  81. package/dist/esm/customMediaPlayer/timeRange.js +14 -13
  82. package/dist/esm/messages.js +45 -0
  83. package/dist/types/MediaInlineCard/ErroredView/index.d.ts +1 -2
  84. package/dist/types/MediaInlineCard/Frame/index.d.ts +1 -0
  85. package/dist/types/MediaInlineCard/Frame/styled-compiled.d.ts +2 -1
  86. package/dist/types/customMediaPlayer/analytics/events/operational/captionDeleteFailed.d.ts +5 -0
  87. package/dist/types/customMediaPlayer/analytics/events/operational/captionDeleteSucceeded.d.ts +5 -0
  88. package/dist/types/customMediaPlayer/analytics/events/operational/captionUploadFailed.d.ts +5 -0
  89. package/dist/types/customMediaPlayer/analytics/events/operational/captionUploadSucceeded.d.ts +5 -0
  90. package/dist/types/customMediaPlayer/analytics/index.d.ts +4 -0
  91. package/dist/types/customMediaPlayer/analytics/utils/analytics.d.ts +5 -1
  92. package/dist/types/customMediaPlayer/analytics/utils/captionAttributes.d.ts +25 -0
  93. package/dist/types/customMediaPlayer/mediaPlayer/captions/apiFeedback.d.ts +13 -0
  94. package/dist/types/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/uploader.d.ts +2 -1
  95. package/dist/types/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/util.d.ts +1 -0
  96. package/dist/types/customMediaPlayer/mediaPlayer/captions/artifactUploader/captionsUploaderBrowser.d.ts +12 -2
  97. package/dist/types/customMediaPlayer/mediaPlayer/captions/artifactUploader/index.d.ts +2 -1
  98. package/dist/types/customMediaPlayer/mediaPlayer/captions/artifactUploader/types.d.ts +6 -3
  99. package/dist/types/customMediaPlayer/mediaPlayer/captions/captionDeleteConfirmationModal.d.ts +19 -0
  100. package/dist/types/customMediaPlayer/mediaPlayer/captionsAdminControls.d.ts +2 -1
  101. package/dist/types/customMediaPlayer/mediaPlayer/mediaPlayerBase.d.ts +1 -0
  102. package/dist/types/customMediaPlayer/react-video-renderer/text.d.ts +1 -0
  103. package/dist/types/customMediaPlayer/timeRange.d.ts +3 -3
  104. package/dist/types/messages.d.ts +1 -1
  105. package/dist/types-ts4.5/MediaInlineCard/ErroredView/index.d.ts +1 -2
  106. package/dist/types-ts4.5/MediaInlineCard/Frame/index.d.ts +1 -0
  107. package/dist/types-ts4.5/MediaInlineCard/Frame/styled-compiled.d.ts +2 -1
  108. package/dist/types-ts4.5/customMediaPlayer/analytics/events/operational/captionDeleteFailed.d.ts +5 -0
  109. package/dist/types-ts4.5/customMediaPlayer/analytics/events/operational/captionDeleteSucceeded.d.ts +5 -0
  110. package/dist/types-ts4.5/customMediaPlayer/analytics/events/operational/captionUploadFailed.d.ts +5 -0
  111. package/dist/types-ts4.5/customMediaPlayer/analytics/events/operational/captionUploadSucceeded.d.ts +5 -0
  112. package/dist/types-ts4.5/customMediaPlayer/analytics/index.d.ts +4 -0
  113. package/dist/types-ts4.5/customMediaPlayer/analytics/utils/analytics.d.ts +5 -1
  114. package/dist/types-ts4.5/customMediaPlayer/analytics/utils/captionAttributes.d.ts +25 -0
  115. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/apiFeedback.d.ts +13 -0
  116. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/uploader.d.ts +2 -1
  117. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/artifactUploader/captions/util.d.ts +1 -0
  118. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/artifactUploader/captionsUploaderBrowser.d.ts +12 -2
  119. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/artifactUploader/index.d.ts +2 -1
  120. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/artifactUploader/types.d.ts +6 -3
  121. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captions/captionDeleteConfirmationModal.d.ts +19 -0
  122. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/captionsAdminControls.d.ts +2 -1
  123. package/dist/types-ts4.5/customMediaPlayer/mediaPlayer/mediaPlayerBase.d.ts +1 -0
  124. package/dist/types-ts4.5/customMediaPlayer/react-video-renderer/text.d.ts +1 -0
  125. package/dist/types-ts4.5/customMediaPlayer/timeRange.d.ts +3 -3
  126. package/dist/types-ts4.5/messages.d.ts +1 -1
  127. package/package.json +13 -9
  128. package/dist/cjs/MediaInlineCard/styled-compiled.compiled.css +0 -1
  129. package/dist/cjs/MediaInlineCard/styled-compiled.js +0 -28
  130. package/dist/cjs/MediaInlineCard/styled-emotion.js +0 -15
  131. package/dist/cjs/MediaInlineCard/styled.js +0 -14
  132. package/dist/es2019/MediaInlineCard/styled-compiled.compiled.css +0 -1
  133. package/dist/es2019/MediaInlineCard/styled-compiled.js +0 -13
  134. package/dist/es2019/MediaInlineCard/styled-emotion.js +0 -8
  135. package/dist/es2019/MediaInlineCard/styled.js +0 -5
  136. package/dist/esm/MediaInlineCard/styled-compiled.compiled.css +0 -1
  137. package/dist/esm/MediaInlineCard/styled-compiled.js +0 -19
  138. package/dist/esm/MediaInlineCard/styled-emotion.js +0 -8
  139. package/dist/esm/MediaInlineCard/styled.js +0 -7
  140. package/dist/types/MediaInlineCard/styled-compiled.d.ts +0 -2
  141. package/dist/types/MediaInlineCard/styled-emotion.d.ts +0 -5
  142. package/dist/types/MediaInlineCard/styled.d.ts +0 -2
  143. package/dist/types-ts4.5/MediaInlineCard/styled-compiled.d.ts +0 -2
  144. package/dist/types-ts4.5/MediaInlineCard/styled-emotion.d.ts +0 -5
  145. package/dist/types-ts4.5/MediaInlineCard/styled.d.ts +0 -2
@@ -1,12 +1,13 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
3
4
  Object.defineProperty(exports, "__esModule", {
4
5
  value: true
5
6
  });
6
7
  Object.defineProperty(exports, "CaptionsUploaderBrowser", {
7
8
  enumerable: true,
8
9
  get: function get() {
9
- return _captionsUploaderBrowser.CaptionsUploaderBrowser;
10
+ return _captionsUploaderBrowser.default;
10
11
  }
11
12
  });
12
- var _captionsUploaderBrowser = require("./captionsUploaderBrowser");
13
+ var _captionsUploaderBrowser = _interopRequireDefault(require("./captionsUploaderBrowser"));
@@ -0,0 +1,103 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _new = _interopRequireDefault(require("@atlaskit/button/new"));
14
+ var _modalDialog = _interopRequireWildcard(require("@atlaskit/modal-dialog"));
15
+ var _mediaClientReact = require("@atlaskit/media-client-react");
16
+ var _util = require("./artifactUploader/captions/util");
17
+ var _apiFeedback = _interopRequireDefault(require("./apiFeedback"));
18
+ var _reactIntlNext = require("react-intl-next");
19
+ var _messages = require("../../../messages");
20
+ var _mediaCommon = require("@atlaskit/media-common");
21
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
22
+ var CaptionDeleteConfirmationModal = function CaptionDeleteConfirmationModal(_ref) {
23
+ var identifier = _ref.identifier,
24
+ artifactName = _ref.artifactName,
25
+ onClose = _ref.onClose,
26
+ onStart = _ref.onStart,
27
+ onEnd = _ref.onEnd,
28
+ onError = _ref.onError,
29
+ intl = _ref.intl;
30
+ var mediaClient = (0, _mediaClientReact.useMediaClient)();
31
+ var _useState = (0, _react.useState)(null),
32
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
33
+ notificationType = _useState2[0],
34
+ setNotificationType = _useState2[1];
35
+ var _onError = function _onError(error, context) {
36
+ setNotificationType('error');
37
+ onError === null || onError === void 0 || onError(error, context);
38
+ };
39
+ var _onEnd = function _onEnd(context) {
40
+ setNotificationType('success');
41
+ onEnd === null || onEnd === void 0 || onEnd(context);
42
+ };
43
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_modalDialog.ModalTransition, null, artifactName && /*#__PURE__*/_react.default.createElement(_modalDialog.default, {
44
+ onClose: onClose
45
+ }, /*#__PURE__*/_react.default.createElement(_modalDialog.ModalHeader, {
46
+ hasCloseButton: true
47
+ }, /*#__PURE__*/_react.default.createElement(_modalDialog.ModalTitle, {
48
+ appearance: "danger"
49
+ }, intl.formatMessage(_messages.messages.video_captions_delete_captions_confirmation_header))), /*#__PURE__*/_react.default.createElement(_modalDialog.ModalBody, null, intl.formatMessage(_messages.messages.video_captions_delete_captions_confirmation_description)), /*#__PURE__*/_react.default.createElement(_modalDialog.ModalFooter, null, /*#__PURE__*/_react.default.createElement(_new.default, {
50
+ appearance: "subtle",
51
+ onClick: onClose
52
+ }, intl.formatMessage(_messages.messages.cancel)), /*#__PURE__*/_react.default.createElement(_new.default, {
53
+ appearance: "danger",
54
+ onClick: function onClick() {
55
+ deleteCaption(mediaClient, identifier, artifactName, onStart, _onEnd, _onError);
56
+ onClose();
57
+ }
58
+ }, intl.formatMessage(_messages.messages.delete))))), /*#__PURE__*/_react.default.createElement(_apiFeedback.default, {
59
+ notificationType: notificationType,
60
+ onDismissed: function onDismissed() {
61
+ return setNotificationType(null);
62
+ },
63
+ successDescription: intl.formatMessage(_messages.messages.video_captions_delete_success_description),
64
+ errorDescription: intl.formatMessage(_messages.messages.video_captions_delete_error_description)
65
+ }));
66
+ };
67
+ var _default = exports.default = (0, _reactIntlNext.injectIntl)(CaptionDeleteConfirmationModal);
68
+ var deleteCaption = /*#__PURE__*/function () {
69
+ var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(mediaClient, identifier, artifactName, onStart, onEnd, onError) {
70
+ var context;
71
+ return _regenerator.default.wrap(function _callee$(_context) {
72
+ while (1) switch (_context.prev = _context.next) {
73
+ case 0:
74
+ context = {
75
+ traceId: (0, _mediaCommon.getRandomTelemetryId)(),
76
+ artifactName: artifactName
77
+ };
78
+ onStart === null || onStart === void 0 || onStart(context);
79
+ _context.prev = 2;
80
+ _context.next = 5;
81
+ return mediaClient.file.deleteArtifact(identifier.id, {
82
+ artifactName: artifactName
83
+ }, identifier.collectionName, {
84
+ traceId: context.traceId
85
+ });
86
+ case 5:
87
+ onEnd === null || onEnd === void 0 || onEnd(context);
88
+ _context.next = 11;
89
+ break;
90
+ case 8:
91
+ _context.prev = 8;
92
+ _context.t0 = _context["catch"](2);
93
+ onError === null || onError === void 0 || onError((0, _util.parseError)(_context.t0), context);
94
+ case 11:
95
+ case "end":
96
+ return _context.stop();
97
+ }
98
+ }, _callee, null, [[2, 8]]);
99
+ }));
100
+ return function deleteCaption(_x, _x2, _x3, _x4, _x5, _x6) {
101
+ return _ref2.apply(this, arguments);
102
+ };
103
+ }();
@@ -25,7 +25,8 @@ var _CaptionsAdminControls = exports._CaptionsAdminControls = function _Captions
25
25
  var intl = _ref.intl,
26
26
  _ref$textTracks = _ref.textTracks,
27
27
  textTracks = _ref$textTracks === void 0 ? {} : _ref$textTracks,
28
- onUpload = _ref.onUpload;
28
+ onUpload = _ref.onUpload,
29
+ onDelete = _ref.onDelete;
29
30
  var videoSettings = intl.formatMessage(_messages.messages.video_settings);
30
31
  return /*#__PURE__*/_react.default.createElement(_dropdownMenu.default, {
31
32
  shouldRenderToParent: true,
@@ -49,8 +50,10 @@ var _CaptionsAdminControls = exports._CaptionsAdminControls = function _Captions
49
50
  }, (_textTracks$captions = textTracks.captions) === null || _textTracks$captions === void 0 ? void 0 : _textTracks$captions.tracks.map(function (track, index) {
50
51
  return /*#__PURE__*/_react.default.createElement(_dropdownMenu.DropdownItem, {
51
52
  key: "".concat(track.lang, "-").concat(index),
52
- onClick: function onClick() {},
53
- elemBefore: /*#__PURE__*/_react.default.createElement(_delete.default, {
53
+ onClick: function onClick() {
54
+ return onDelete(track.artifactName);
55
+ },
56
+ elemAfter: /*#__PURE__*/_react.default.createElement(_delete.default, {
54
57
  spacing: "spacious",
55
58
  label: "",
56
59
  color: "var(--ds-icon-danger, #C9372C)"
@@ -14,7 +14,7 @@ var _reactIntlNext = require("react-intl-next");
14
14
  var _tooltip = _interopRequireDefault(require("@atlaskit/tooltip"));
15
15
  var _new = _interopRequireWildcard(require("@atlaskit/button/new"));
16
16
  var _dropdownMenu = _interopRequireWildcard(require("@atlaskit/dropdown-menu"));
17
- var _chevronDown = _interopRequireDefault(require("@atlaskit/icon/utility/migration/chevron-down"));
17
+ var _chevronDown = _interopRequireDefault(require("@atlaskit/icon/core/migration/chevron-down"));
18
18
  var _messages = require("../../messages");
19
19
  var _captions = require("./captions");
20
20
  var _excluded = ["triggerRef"];
@@ -61,7 +61,11 @@ var _CaptionsSelectControls = exports._CaptionsSelectControls = /*#__PURE__*/(0,
61
61
  }, /*#__PURE__*/_react.default.createElement(_new.IconButton, (0, _extends2.default)({
62
62
  ref: triggerRef
63
63
  }, triggerProps, {
64
- icon: _chevronDown.default,
64
+ icon: function icon(iconProps) {
65
+ return /*#__PURE__*/_react.default.createElement(_chevronDown.default, (0, _extends2.default)({}, iconProps, {
66
+ size: "small"
67
+ }));
68
+ },
65
69
  label: selectCaptions,
66
70
  appearance: "subtle"
67
71
  })));
@@ -12,7 +12,7 @@ var _mediaClientReact = require("@atlaskit/media-client-react");
12
12
  var _mediaPlayerBase = require("./mediaPlayerBase");
13
13
  var _useTextTracks = require("./useTextTracks");
14
14
  var packageName = "@atlaskit/media-ui";
15
- var packageVersion = "28.2.3";
15
+ var packageVersion = "28.3.0";
16
16
  var MediaPlayerBaseWithContext = (0, _mediaCommon.withMediaAnalyticsContext)({
17
17
  packageVersion: packageVersion,
18
18
  packageName: packageName,
@@ -53,6 +53,7 @@ var _videoSkipForwardTen = _interopRequireDefault(require("@atlaskit/icon/core/v
53
53
  var _videoSkipBackwardTen = _interopRequireDefault(require("@atlaskit/icon/core/video-skip-backward-ten"));
54
54
  var _captions = require("./captions");
55
55
  var _artifactUploader = require("./captions/artifactUploader");
56
+ var _captionDeleteConfirmationModal = _interopRequireDefault(require("./captions/captionDeleteConfirmationModal"));
56
57
  function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
57
58
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
58
59
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
@@ -105,7 +106,8 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
105
106
  playbackSpeed: 1,
106
107
  selectedTracksIndex: -1,
107
108
  areCaptionsEnabled: false,
108
- isArtifactUploaderOpen: false
109
+ isArtifactUploaderOpen: false,
110
+ artifactToDelete: undefined
109
111
  });
110
112
  (0, _defineProperty2.default)(_this, "findPreselectedTrackIndex", function (_ref) {
111
113
  var _textTracks$captions;
@@ -504,6 +506,16 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
504
506
  areCaptionsEnabled: areCaptionsEnabled
505
507
  });
506
508
  });
509
+ (0, _defineProperty2.default)(_this, "onCaptionDelete", function (artifactName) {
510
+ // Modal is not supported in fullscreen mode (as it uses portals which are not in the same DOM tree),
511
+ // So we need to exit fullscreen first
512
+ if (_this.state.isFullScreenEnabled) {
513
+ _this.toggleFullscreen();
514
+ }
515
+ _this.setState({
516
+ artifactToDelete: artifactName
517
+ });
518
+ });
507
519
  (0, _defineProperty2.default)(_this, "resolveSelectedTracksIndex", function () {
508
520
  var _this$state3 = _this.state,
509
521
  areCaptionsEnabled = _this$state3.areCaptionsEnabled,
@@ -669,6 +681,48 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
669
681
  }
670
682
  (0, _analytics.fireAnalyticsEvent)(analyticsEvent, createAnalyticsEvent);
671
683
  }
684
+ }, {
685
+ key: "baseAnalyticCaptionAttributes",
686
+ value: function baseAnalyticCaptionAttributes() {
687
+ var _textTracks$captions3, _textTracks$captions4;
688
+ var textTracks = this.props.textTracks;
689
+ var selectedTracksIndex = this.state.selectedTracksIndex;
690
+ var captionAttributes = {
691
+ selectedTrackIndex: selectedTracksIndex,
692
+ availableCaptionTracks: (textTracks === null || textTracks === void 0 || (_textTracks$captions3 = textTracks.captions) === null || _textTracks$captions3 === void 0 || (_textTracks$captions3 = _textTracks$captions3.tracks) === null || _textTracks$captions3 === void 0 ? void 0 : _textTracks$captions3.length) || 0,
693
+ selectedTrackLanguage: (textTracks === null || textTracks === void 0 || (_textTracks$captions4 = textTracks.captions) === null || _textTracks$captions4 === void 0 || (_textTracks$captions4 = _textTracks$captions4.tracks) === null || _textTracks$captions4 === void 0 || (_textTracks$captions4 = _textTracks$captions4[selectedTracksIndex]) === null || _textTracks$captions4 === void 0 ? void 0 : _textTracks$captions4.lang) || null
694
+ };
695
+ return captionAttributes;
696
+ }
697
+ }, {
698
+ key: "fireCaptionEvent",
699
+ value: function fireCaptionEvent(event) {
700
+ (0, _analytics.fireAnalyticsEvent)(event, this.props.createAnalyticsEvent);
701
+ }
702
+ }, {
703
+ key: "fireCaptionUploadSucceededEvent",
704
+ value: function fireCaptionUploadSucceededEvent(traceId) {
705
+ this.fireCaptionEvent((0, _analytics.createCaptionUploadSucceededOperationalEvent)(this.props.type, this.baseAnalyticCaptionAttributes(), this.props.identifier.id, traceId));
706
+ }
707
+ }, {
708
+ key: "fireCaptionUploadFailedEvent",
709
+ value: function fireCaptionUploadFailedEvent(traceId, error) {
710
+ this.fireCaptionEvent((0, _analytics.createCaptionUploadFailedOperationalEvent)(this.props.type, this.baseAnalyticCaptionAttributes(), this.props.identifier.id, traceId, error));
711
+ }
712
+ }, {
713
+ key: "fireCaptionDeleteSucceededEvent",
714
+ value: function fireCaptionDeleteSucceededEvent(traceId, artifactName) {
715
+ this.fireCaptionEvent((0, _analytics.createCaptionDeleteSucceededOperationalEvent)(this.props.type, _objectSpread(_objectSpread({}, this.baseAnalyticCaptionAttributes()), {}, {
716
+ artifactName: artifactName
717
+ }), this.props.identifier.id, traceId));
718
+ }
719
+ }, {
720
+ key: "fireCaptionDeleteFailedEvent",
721
+ value: function fireCaptionDeleteFailedEvent(traceId, artifactName, error) {
722
+ this.fireCaptionEvent((0, _analytics.createCaptionDeleteFailedOperationalEvent)(this.props.type, _objectSpread(_objectSpread({}, this.baseAnalyticCaptionAttributes()), {}, {
723
+ artifactName: artifactName
724
+ }), this.props.identifier.id, traceId, error));
725
+ }
672
726
  }, {
673
727
  key: "render",
674
728
  value: function render() {
@@ -690,7 +744,8 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
690
744
  canUpdateVideoCaptions = _this$props11$mediaSe3 === void 0 ? false : _this$props11$mediaSe3;
691
745
  var _this$state6 = this.state,
692
746
  areCaptionsEnabled = _this$state6.areCaptionsEnabled,
693
- isArtifactUploaderOpen = _this$state6.isArtifactUploaderOpen;
747
+ isArtifactUploaderOpen = _this$state6.isArtifactUploaderOpen,
748
+ artifactToDelete = _this$state6.artifactToDelete;
694
749
  return /*#__PURE__*/_react.default.createElement(_compiled.Box, {
695
750
  xcss: customVideoWrapperStyles.root,
696
751
  ref: this.videoWrapperRef,
@@ -781,7 +836,8 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
781
836
  return _this2.setState({
782
837
  isArtifactUploaderOpen: true
783
838
  });
784
- }
839
+ },
840
+ onDelete: _this2.onCaptionDelete
785
841
  }), /*#__PURE__*/_react.default.createElement(_artifactUploader.CaptionsUploaderBrowser, {
786
842
  identifier: identifier,
787
843
  isOpen: isArtifactUploaderOpen,
@@ -790,14 +846,31 @@ var _MediaPlayerBase = /*#__PURE__*/function (_Component) {
790
846
  isArtifactUploaderOpen: false
791
847
  });
792
848
  },
793
- onStart: function onStart() {
794
- // console.log('xxx onStart', file);
849
+ onEnd: function onEnd(metadata, context) {
850
+ _this2.fireCaptionUploadSucceededEvent(context.traceId);
795
851
  },
796
- onEnd: function onEnd() {
797
- // console.log('xxx onEnd', result);
852
+ onError: function onError(err, context) {
853
+ _this2.fireCaptionUploadFailedEvent(context.traceId, err);
854
+ }
855
+ }), /*#__PURE__*/_react.default.createElement(_captionDeleteConfirmationModal.default, {
856
+ identifier: identifier,
857
+ artifactName: artifactToDelete,
858
+ onClose: function onClose() {
859
+ return _this2.setState({
860
+ artifactToDelete: ''
861
+ });
798
862
  },
799
- onError: function onError() {
800
- // console.log('xxx onError', error);
863
+ onEnd: function onEnd(context) {
864
+ _this2.fireCaptionDeleteSucceededEvent(context.traceId, context.artifactName);
865
+ _this2.setState({
866
+ artifactToDelete: ''
867
+ });
868
+ },
869
+ onError: function onError(err, context) {
870
+ _this2.fireCaptionDeleteFailedEvent(context.traceId, context.artifactName, err);
871
+ _this2.setState({
872
+ artifactToDelete: ''
873
+ });
801
874
  }
802
875
  }))))));
803
876
  }));
@@ -63,7 +63,8 @@ var useTextTracks = exports.useTextTracks = function useTextTracks(fileState, me
63
63
  return _context.abrupt("return", {
64
64
  src: src,
65
65
  lang: lang,
66
- label: label
66
+ label: label,
67
+ artifactName: artifactName
67
68
  });
68
69
  case 11:
69
70
  case "end":
@@ -43,13 +43,14 @@ var TimeRangeBase = exports.TimeRangeBase = /*#__PURE__*/function (_Component) {
43
43
  }
44
44
  _this.wrapperElementWidth = _this.wrapperElement.current.getBoundingClientRect().width;
45
45
  });
46
- (0, _defineProperty2.default)(_this, "onMouseMove", function (e) {
46
+ (0, _defineProperty2.default)(_this, "onPointerMove", function (e) {
47
47
  var _this$state = _this.state,
48
48
  isDragging = _this$state.isDragging,
49
49
  dragStartClientX = _this$state.dragStartClientX;
50
50
  if (!isDragging) {
51
51
  return;
52
52
  }
53
+ e.preventDefault();
53
54
  e.stopPropagation();
54
55
  var _this$props = _this.props,
55
56
  onChange = _this$props.onChange,
@@ -75,11 +76,11 @@ var TimeRangeBase = exports.TimeRangeBase = /*#__PURE__*/function (_Component) {
75
76
  onChange(newTimeWithBoundaries);
76
77
  }
77
78
  });
78
- (0, _defineProperty2.default)(_this, "onMouseUp", function () {
79
+ (0, _defineProperty2.default)(_this, "onPointerUp", function () {
79
80
  var onChanged = _this.props.onChanged;
80
81
  // As soon as user finished dragging, we should clean up events.
81
- document.removeEventListener('mouseup', _this.onMouseUp);
82
- document.removeEventListener('mousemove', _this.onMouseMove);
82
+ document.removeEventListener('pointerup', _this.onPointerUp);
83
+ document.removeEventListener('pointermove', _this.onPointerMove);
83
84
  if (onChanged) {
84
85
  onChanged();
85
86
  }
@@ -87,17 +88,17 @@ var TimeRangeBase = exports.TimeRangeBase = /*#__PURE__*/function (_Component) {
87
88
  isDragging: false
88
89
  });
89
90
  });
90
- (0, _defineProperty2.default)(_this, "onThumbMouseDown", function (e) {
91
+ (0, _defineProperty2.default)(_this, "onPointerDown", function (e) {
91
92
  e.preventDefault();
92
93
 
93
94
  // We need to recalculate every time, because width can change (thanks, editor ;-)
94
95
  _this.setWrapperWidth();
95
96
 
96
- // We are implementing drag and drop here. There is no reason to start listening for mouseUp or move
97
- // before that. Also if we start listening for mouseup before that we could pick up someone else's event
97
+ // We are implementing drag and drop here. There is no reason to start listening for pointerUp or move
98
+ // before that. Also if we start listening for pointerup before that we could pick up someone else's event
98
99
  // For example editors resizing of a inline video player.
99
- document.addEventListener('mouseup', _this.onMouseUp);
100
- document.addEventListener('mousemove', _this.onMouseMove);
100
+ document.addEventListener('pointerup', _this.onPointerUp);
101
+ document.addEventListener('pointermove', _this.onPointerMove);
101
102
  var _this$props2 = _this.props,
102
103
  duration = _this$props2.duration,
103
104
  onChange = _this$props2.onChange;
@@ -176,8 +177,8 @@ var TimeRangeBase = exports.TimeRangeBase = /*#__PURE__*/function (_Component) {
176
177
  }, {
177
178
  key: "componentWillUnmount",
178
179
  value: function componentWillUnmount() {
179
- document.removeEventListener('mousemove', this.onMouseMove);
180
- document.removeEventListener('mouseup', this.onMouseUp);
180
+ document.removeEventListener('pointermove', this.onPointerMove);
181
+ document.removeEventListener('pointerup', this.onPointerUp);
181
182
  window.removeEventListener('resize', this.setWrapperWidth);
182
183
  }
183
184
  }, {
@@ -270,11 +271,11 @@ var TimeRangeBase = exports.TimeRangeBase = /*#__PURE__*/function (_Component) {
270
271
  }
271
272
  }, disableThumbTooltip ? null : currentTimeTooltip)));
272
273
  return (0, _platformFeatureFlags.fg)('platform_media_compiled') ? /*#__PURE__*/_react.default.createElement(_styledCompiled.TimeRangeWrapper, {
273
- onMouseDown: this.onThumbMouseDown,
274
+ onPointerDown: this.onPointerDown,
274
275
  "data-testid": "time-range-wrapper"
275
276
  }, timeline) : /*#__PURE__*/_react.default.createElement(_styledEmotion.TimeRangeWrapper, {
276
277
  showAsActive: isAlwaysActive,
277
- onMouseDown: this.onThumbMouseDown,
278
+ onPointerDown: this.onPointerDown,
278
279
  "data-testid": "time-range-wrapper"
279
280
  }, timeline);
280
281
  }
@@ -96,6 +96,21 @@ var messages = exports.messages = (0, _reactIntlNext.defineMessages)({
96
96
  defaultMessage: 'Cancel',
97
97
  description: 'cancel'
98
98
  },
99
+ delete: {
100
+ id: 'fabric.media.delete',
101
+ defaultMessage: 'Delete',
102
+ description: 'delete'
103
+ },
104
+ success: {
105
+ id: 'fabric.media.success',
106
+ defaultMessage: 'Success',
107
+ description: 'success'
108
+ },
109
+ error: {
110
+ id: 'fabric.media.error',
111
+ defaultMessage: 'Error',
112
+ description: 'error'
113
+ },
99
114
  search_all_gifs: {
100
115
  id: 'fabric.media.search_all_gifs',
101
116
  defaultMessage: 'Search all the GIFs!',
@@ -641,6 +656,36 @@ var messages = exports.messages = (0, _reactIntlNext.defineMessages)({
641
656
  defaultMessage: 'Select the file language',
642
657
  description: 'In the context of a video player, it allows user to select the language of the uploading captions'
643
658
  },
659
+ video_captions_upload_success_description: {
660
+ id: 'fabric.media.video_captions_upload_success_description',
661
+ defaultMessage: 'The caption was successfully uploaded for this video.',
662
+ description: 'In the context of a video player, it provides feedback when a caption was successfully uploadd'
663
+ },
664
+ video_captions_upload_error_description: {
665
+ id: 'fabric.media.video_captions_upload_error_description',
666
+ defaultMessage: 'The caption failed to upload.',
667
+ description: 'In the context of a video player, it provides feedback when a caption failed to upload'
668
+ },
669
+ video_captions_delete_captions_confirmation_header: {
670
+ id: 'fabric.media.video_captions_delete_captions_confirmation_header',
671
+ defaultMessage: 'Delete Caption',
672
+ description: 'In the context of a video player, it provides a confirmation header before deleting captions'
673
+ },
674
+ video_captions_delete_captions_confirmation_description: {
675
+ id: 'fabric.media.video_captions_delete_captions_confirmation_description',
676
+ defaultMessage: 'Please confirm that you want to delete this caption.',
677
+ description: 'In the context of a video player, it provides a confirmation description before deleting captions'
678
+ },
679
+ video_captions_delete_success_description: {
680
+ id: 'fabric.media.video_captions_delete_success_description',
681
+ defaultMessage: 'The caption was successfully removed from this video.',
682
+ description: 'In the context of a video player, it provides feedback when a caption was successfully deleted'
683
+ },
684
+ video_captions_delete_error_description: {
685
+ id: 'fabric.media.video_captions_delete_error_description',
686
+ defaultMessage: 'The caption failed to delete.',
687
+ description: 'In the context of a video player, it provides feedback when a caption failed to delete'
688
+ },
644
689
  video_settings: {
645
690
  id: 'fabric.media.video_settings',
646
691
  defaultMessage: 'Video Settings',
@@ -0,0 +1 @@
1
+ ._syaz1gtz{color:var(--ds-text-danger,#bf2600)}
@@ -1,22 +1,14 @@
1
- import _defineProperty from "@babel/runtime/helpers/defineProperty";
1
+ /* index.tsx generated by @compiled/babel-plugin v0.36.1 */
2
+ import "./index.compiled.css";
3
+ import { ax, ix } from "@compiled/react/runtime";
2
4
  import React from 'react';
3
- import { R300 } from '@atlaskit/theme/colors';
4
- import WarningIcon from '@atlaskit/icon/utility/migration/warning';
5
+ import { R500 } from '@atlaskit/theme/colors';
6
+ import WarningIcon from '@atlaskit/icon/core/migration/warning';
5
7
  import { Frame } from '../Frame';
6
8
  import { IconAndTitleLayout } from '../IconAndTitleLayout';
7
9
  import { AKIconWrapper } from '../Icon';
8
- import { NoLinkAppearance } from '../styled';
10
+ const errorTitleStyles = null;
9
11
  export class MediaInlineCardErroredView extends React.Component {
10
- constructor(...args) {
11
- super(...args);
12
- _defineProperty(this, "renderMessage", () => {
13
- const {
14
- message
15
- } = this.props;
16
- const errorMessage = /*#__PURE__*/React.createElement(NoLinkAppearance, null, message);
17
- return /*#__PURE__*/React.createElement(React.Fragment, null, errorMessage);
18
- });
19
- }
20
12
  render() {
21
13
  const {
22
14
  onClick,
@@ -29,14 +21,18 @@ export class MediaInlineCardErroredView extends React.Component {
29
21
  testId: testId,
30
22
  innerRef: innerRef,
31
23
  onClick: onClick,
32
- isSelected: isSelected
24
+ isSelected: isSelected,
25
+ isError: true
33
26
  }, /*#__PURE__*/React.createElement(IconAndTitleLayout, {
34
27
  icon: icon || /*#__PURE__*/React.createElement(AKIconWrapper, null, /*#__PURE__*/React.createElement(WarningIcon, {
35
28
  label: "error",
36
29
  LEGACY_size: "small",
37
- color: `var(--ds-icon-danger, ${R300})`
30
+ color: `var(--ds-icon-danger, ${R500})`,
31
+ size: "small"
38
32
  })),
39
- title: this.renderMessage()
33
+ title: /*#__PURE__*/React.createElement("span", {
34
+ className: ax(["_syaz1gtz"])
35
+ }, this.props.message)
40
36
  }));
41
37
  }
42
38
  }
@@ -34,12 +34,14 @@ export class Frame extends React.Component {
34
34
  children,
35
35
  onClick,
36
36
  innerRef,
37
- testId
37
+ testId,
38
+ isError
38
39
  } = this.props;
39
40
  const isInteractive = Boolean(onClick);
40
41
  return /*#__PURE__*/React.createElement(Wrapper, {
41
42
  ref: innerRef,
42
43
  isSelected: isSelected,
44
+ isError: isError,
43
45
  tabIndex: isInteractive ? 0 : undefined,
44
46
  role: isInteractive ? 'button' : undefined,
45
47
  onClick: this.handleClick,
@@ -11,9 +11,11 @@
11
11
  ._1qu2glyw{outline-style:none}
12
12
  ._1rkwglyw{-moz-user-select:none}
13
13
  ._4bfu1r31, ._1nrm1r31:active, ._1a3b1r31:focus, ._9oik1r31:hover{text-decoration-color:currentColor}
14
+ ._80om73ad{cursor:default}
14
15
  ._80omtlke{cursor:pointer}
15
16
  ._ajmmnqa1, ._1iohnqa1:active, ._5goinqa1:focus, ._jf4cnqa1:hover{text-decoration-style:solid}
16
17
  ._bfhkq7nr{background-color:var(--ds-background-neutral,rgba(9,30,66,.08))}
18
+ ._bfhktaeo{background-color:var(--ds-background-danger,#ffebe6)}
17
19
  ._ca0qv77o{padding-top:var(--ds-space-025,2px)}
18
20
  ._n3tdv77o{padding-bottom:var(--ds-space-025,2px)}
19
21
  ._syazj3m3{color:var(--ds-text,#091e42)}
@@ -21,4 +23,5 @@
21
23
  ._uizt1kdv{-webkit-user-select:text;-ms-user-select:text;user-select:text}
22
24
  ._uiztglyw{-webkit-user-select:none;-ms-user-select:none;user-select:none}
23
25
  ._vwz47vkz{line-height:1pc}
24
- ._irr3hv1p:hover{background-color:var(--ds-background-neutral-hovered,rgba(9,30,66,.13))}
26
+ ._irr3hv1p:hover{background-color:var(--ds-background-neutral-hovered,rgba(9,30,66,.13))}
27
+ ._irr3taeo:hover{background-color:var(--ds-background-danger,#ffebe6)}
@@ -3,9 +3,10 @@ import _extends from "@babel/runtime/helpers/extends";
3
3
  import "./styled-compiled.compiled.css";
4
4
  import * as React from 'react';
5
5
  import { ax, ix } from "@compiled/react/runtime";
6
- import { B300, N30A, N40A, N900 } from '@atlaskit/theme/colors';
6
+ import { B300, N30A, N40A, N900, R50 } from '@atlaskit/theme/colors';
7
7
  const selectedStyles = null;
8
8
  const notSelectedStyles = null;
9
+ const errorStyles = null;
9
10
  const wrapperStyles = null;
10
11
 
11
12
  /*
@@ -22,10 +23,11 @@ const wrapperStyles = null;
22
23
  // NB: `box-decoration-break` required for retaining properties (border-radius) on wrap.
23
24
  export const Wrapper = ({
24
25
  isSelected,
26
+ isError,
25
27
  children,
26
28
  ...props
27
29
  }) => /*#__PURE__*/React.createElement("span", _extends({
28
30
  "data-testid": "frame-wrapper"
29
31
  }, props, {
30
- className: ax(["_2rko1sit _v56415x0 _vwz47vkz _ca0qv77o _u5f31b66 _n3tdv77o _19bv1b66 _16d9qvcn _1e0c1nu9 _syazj3m3 _bfhkq7nr _1rkwglyw _80omtlke _irr3hv1p", isSelected && "_12ji1r31 _1qu2glyw _12y31o36 _1h6d1j28 _80omtlke _16qs1s9b _uiztglyw _4bfu1r31 _1nrm1r31 _1a3b1r31 _9oik1r31 _1hmsglyw _c2waglyw _4fprglyw _1bnxglyw _ajmmnqa1 _1iohnqa1 _5goinqa1 _jf4cnqa1", !isSelected && "_uizt1kdv"])
32
+ className: ax(["_2rko1sit _v56415x0 _vwz47vkz _ca0qv77o _u5f31b66 _n3tdv77o _19bv1b66 _16d9qvcn _1e0c1nu9 _syazj3m3 _bfhkq7nr _1rkwglyw _80omtlke _irr3hv1p", isSelected && "_12ji1r31 _1qu2glyw _12y31o36 _1h6d1j28 _80omtlke _16qs1s9b _uiztglyw _4bfu1r31 _1nrm1r31 _1a3b1r31 _9oik1r31 _1hmsglyw _c2waglyw _4fprglyw _1bnxglyw _ajmmnqa1 _1iohnqa1 _5goinqa1 _jf4cnqa1", !isSelected && "_uizt1kdv", isError && "_bfhktaeo _80om73ad _irr3taeo"])
31
33
  }), children);
@@ -1,6 +1,6 @@
1
1
  // eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766
2
2
  import styled from '@emotion/styled';
3
- import { B300, N30A, N40A, N900 } from '@atlaskit/theme/colors';
3
+ import { B300, N30A, N40A, N900, R50 } from '@atlaskit/theme/colors';
4
4
  const selected = `
5
5
  cursor: pointer;
6
6
  box-shadow: 0 0 0 1px ${`var(--ds-border-selected, ${B300})`};
@@ -52,4 +52,12 @@ props => isSelected(props), {
52
52
  '&:hover': {
53
53
  backgroundColor: `var(--ds-background-neutral-hovered, ${N40A})`
54
54
  }
55
+ },
56
+ // eslint-disable-next-line @atlaskit/ui-styling-standard/no-dynamic-styles -- Ignored via go/DSP-18766
57
+ props => props.isError && {
58
+ backgroundColor: `var(--ds-background-danger, ${R50})`,
59
+ cursor: 'default',
60
+ '&:hover': {
61
+ backgroundColor: `var(--ds-background-danger, ${R50})`
62
+ }
55
63
  });