@atlaskit/media-viewer 53.2.4 → 54.0.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.
- package/AGENTS.md +62 -0
- package/CHANGELOG.md +32 -0
- package/classnames/package.json +1 -8
- package/dist/cjs/analytics/index.js +1 -1
- package/dist/cjs/analytics/ufoExperiences.js +1 -1
- package/dist/cjs/download.js +2 -2
- package/dist/cjs/utils/getObjectUrlFromFileState.js +15 -16
- package/dist/cjs/utils/index.js +16 -17
- package/dist/cjs/viewers/archiveSidebar/archive-sidebar-folder-entry.js +11 -11
- package/dist/cjs/viewers/archiveSidebar/archive-sidebar-renderer.js +12 -12
- package/dist/cjs/viewers/archiveSidebar/archive-sidebar.js +28 -28
- package/dist/cjs/viewers/archiveSidebar/archive.js +29 -29
- package/dist/cjs/viewers/archiveSidebar/archiveViewerLoader.js +12 -12
- package/dist/cjs/viewers/audio.js +37 -37
- package/dist/cjs/viewers/codeViewer/codeViewerRenderer-compiled.js +2 -2
- package/dist/cjs/viewers/codeViewer/index.js +35 -35
- package/dist/cjs/viewers/doc/doc-viewer.js +29 -27
- package/dist/cjs/viewers/doc/index.js +2 -2
- package/dist/cjs/viewers/image/index.js +43 -44
- package/dist/cjs/viewers/video.js +20 -20
- package/dist/es2019/analytics/index.js +1 -1
- package/dist/es2019/analytics/ufoExperiences.js +1 -1
- package/dist/esm/analytics/index.js +1 -1
- package/dist/esm/analytics/ufoExperiences.js +1 -1
- package/dist/esm/download.js +2 -2
- package/dist/esm/utils/getObjectUrlFromFileState.js +15 -16
- package/dist/esm/utils/index.js +16 -17
- package/dist/esm/viewers/archiveSidebar/archive-sidebar-folder-entry.js +11 -11
- package/dist/esm/viewers/archiveSidebar/archive-sidebar-renderer.js +11 -11
- package/dist/esm/viewers/archiveSidebar/archive-sidebar.js +28 -28
- package/dist/esm/viewers/archiveSidebar/archive.js +29 -29
- package/dist/esm/viewers/archiveSidebar/archiveViewerLoader.js +11 -11
- package/dist/esm/viewers/audio.js +37 -37
- package/dist/esm/viewers/codeViewer/codeViewerRenderer-compiled.js +2 -2
- package/dist/esm/viewers/codeViewer/index.js +34 -34
- package/dist/esm/viewers/doc/doc-viewer.js +28 -26
- package/dist/esm/viewers/doc/index.js +2 -2
- package/dist/esm/viewers/image/index.js +43 -44
- package/dist/esm/viewers/video.js +20 -20
- package/media-viewer-loader/package.json +1 -8
- package/package.json +33 -42
- package/types/package.json +1 -8
- package/viewer-options/package.json +1 -8
- package/dist/types-ts4.5/analytics/events/index.d.ts +0 -17
- package/dist/types-ts4.5/analytics/events/operational/_mediaFile.d.ts +0 -3
- package/dist/types-ts4.5/analytics/events/operational/commenced.d.ts +0 -5
- package/dist/types-ts4.5/analytics/events/operational/download.d.ts +0 -9
- package/dist/types-ts4.5/analytics/events/operational/loadFailed.d.ts +0 -7
- package/dist/types-ts4.5/analytics/events/operational/loadSucceeded.d.ts +0 -11
- package/dist/types-ts4.5/analytics/events/operational/previewUnsupported.d.ts +0 -6
- package/dist/types-ts4.5/analytics/events/operational/zipEntryLoadFailed.d.ts +0 -13
- package/dist/types-ts4.5/analytics/events/operational/zipEntryLoadSucceeded.d.ts +0 -12
- package/dist/types-ts4.5/analytics/events/screen/modal.d.ts +0 -3
- package/dist/types-ts4.5/analytics/events/screen/passwordPdf.d.ts +0 -3
- package/dist/types-ts4.5/analytics/events/screen/pdfPasswordInput.d.ts +0 -3
- package/dist/types-ts4.5/analytics/events/ui/_clickedButton.d.ts +0 -2
- package/dist/types-ts4.5/analytics/events/ui/closed.d.ts +0 -8
- package/dist/types-ts4.5/analytics/events/ui/downloadButtonClicked.d.ts +0 -8
- package/dist/types-ts4.5/analytics/events/ui/failedPreviewDownloadButtonClicked.d.ts +0 -10
- package/dist/types-ts4.5/analytics/events/ui/navigated.d.ts +0 -12
- package/dist/types-ts4.5/analytics/events/ui/zoomInButtonClicked.d.ts +0 -8
- package/dist/types-ts4.5/analytics/events/ui/zoomOutButtonClicked.d.ts +0 -6
- package/dist/types-ts4.5/analytics/index.d.ts +0 -17
- package/dist/types-ts4.5/analytics/ufoExperiences.d.ts +0 -19
- package/dist/types-ts4.5/classnames.d.ts +0 -5
- package/dist/types-ts4.5/components/media-viewer-error-boundary.d.ts +0 -3
- package/dist/types-ts4.5/components/media-viewer-loader.d.ts +0 -3
- package/dist/types-ts4.5/components/media-viewer.d.ts +0 -5
- package/dist/types-ts4.5/components/portal.d.ts +0 -4
- package/dist/types-ts4.5/components/types.d.ts +0 -45
- package/dist/types-ts4.5/content.d.ts +0 -11
- package/dist/types-ts4.5/domain/index.d.ts +0 -1
- package/dist/types-ts4.5/domain/outcome.d.ts +0 -31
- package/dist/types-ts4.5/domain/zoomLevel.d.ts +0 -15
- package/dist/types-ts4.5/download.d.ts +0 -20
- package/dist/types-ts4.5/error-images.d.ts +0 -2
- package/dist/types-ts4.5/errorMessage.d.ts +0 -33
- package/dist/types-ts4.5/errors.d.ts +0 -23
- package/dist/types-ts4.5/header.d.ts +0 -19
- package/dist/types-ts4.5/index.d.ts +0 -3
- package/dist/types-ts4.5/item-viewer.d.ts +0 -32
- package/dist/types-ts4.5/list.d.ts +0 -24
- package/dist/types-ts4.5/loading.d.ts +0 -2
- package/dist/types-ts4.5/media-viewer.d.ts +0 -16
- package/dist/types-ts4.5/navigation.d.ts +0 -25
- package/dist/types-ts4.5/styleWrappers.d.ts +0 -122
- package/dist/types-ts4.5/styles.d.ts +0 -2
- package/dist/types-ts4.5/utils/closeOnDirectClick.d.ts +0 -2
- package/dist/types-ts4.5/utils/getIdentifierCollection.d.ts +0 -2
- package/dist/types-ts4.5/utils/getObjectUrlFromFileState.d.ts +0 -2
- package/dist/types-ts4.5/utils/index.d.ts +0 -10
- package/dist/types-ts4.5/utils/isIE.d.ts +0 -1
- package/dist/types-ts4.5/viewerOptions.d.ts +0 -20
- package/dist/types-ts4.5/viewers/archiveSidebar/archive-download-button.d.ts +0 -8
- package/dist/types-ts4.5/viewers/archiveSidebar/archive-sidebar-folder-entry.d.ts +0 -24
- package/dist/types-ts4.5/viewers/archiveSidebar/archive-sidebar-header.d.ts +0 -9
- package/dist/types-ts4.5/viewers/archiveSidebar/archive-sidebar-renderer.d.ts +0 -26
- package/dist/types-ts4.5/viewers/archiveSidebar/archive-sidebar.d.ts +0 -28
- package/dist/types-ts4.5/viewers/archiveSidebar/archive.d.ts +0 -37
- package/dist/types-ts4.5/viewers/archiveSidebar/archiveViewerLoader.d.ts +0 -12
- package/dist/types-ts4.5/viewers/archiveSidebar/consts.d.ts +0 -2
- package/dist/types-ts4.5/viewers/archiveSidebar/custom-button-item.d.ts +0 -2
- package/dist/types-ts4.5/viewers/archiveSidebar/nativePdfViewer.d.ts +0 -9
- package/dist/types-ts4.5/viewers/archiveSidebar/styleWrappers.d.ts +0 -30
- package/dist/types-ts4.5/viewers/archiveSidebar/styles.d.ts +0 -1
- package/dist/types-ts4.5/viewers/archiveSidebar/types.d.ts +0 -13
- package/dist/types-ts4.5/viewers/audio.d.ts +0 -33
- package/dist/types-ts4.5/viewers/base-viewer.d.ts +0 -32
- package/dist/types-ts4.5/viewers/codeViewer/CodeRendererAdvanced/CodeRendererAdvanced.d.ts +0 -11
- package/dist/types-ts4.5/viewers/codeViewer/CodeRendererAdvanced/theme.d.ts +0 -4
- package/dist/types-ts4.5/viewers/codeViewer/codeViewerRenderer-compiled.d.ts +0 -29
- package/dist/types-ts4.5/viewers/codeViewer/codeViewerRenderer.d.ts +0 -23
- package/dist/types-ts4.5/viewers/codeViewer/index.d.ts +0 -27
- package/dist/types-ts4.5/viewers/codeViewer/msg-parser.d.ts +0 -8
- package/dist/types-ts4.5/viewers/codeViewer/styles.d.ts +0 -4
- package/dist/types-ts4.5/viewers/codeViewer/util.d.ts +0 -4
- package/dist/types-ts4.5/viewers/customViewer/customViewer.d.ts +0 -13
- package/dist/types-ts4.5/viewers/doc/doc-viewer.d.ts +0 -13
- package/dist/types-ts4.5/viewers/doc/index.d.ts +0 -36
- package/dist/types-ts4.5/viewers/doc/passwordInput.d.ts +0 -10
- package/dist/types-ts4.5/viewers/image/index.d.ts +0 -35
- package/dist/types-ts4.5/viewers/image/interactive-img.d.ts +0 -42
- package/dist/types-ts4.5/viewers/modalSpinner.d.ts +0 -8
- package/dist/types-ts4.5/viewers/svg/ImageWrapper-compiled.d.ts +0 -7
- package/dist/types-ts4.5/viewers/svg/ImageWrapper.d.ts +0 -7
- package/dist/types-ts4.5/viewers/svg/errors.d.ts +0 -3
- package/dist/types-ts4.5/viewers/svg/index.d.ts +0 -14
- package/dist/types-ts4.5/viewers/svg/utils.d.ts +0 -5
- package/dist/types-ts4.5/viewers/video.d.ts +0 -32
- package/dist/types-ts4.5/zoomControls.d.ts +0 -15
package/AGENTS.md
ADDED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
# media-viewer — Agent Guide
|
|
2
|
+
|
|
3
|
+
> **Parent guide:** Always read [`../AGENTS.md`](../AGENTS.md) before working in this package — it
|
|
4
|
+
> contains workspace-wide rules covering platform guidelines, changeset workflow, accessibility
|
|
5
|
+
> standards, and the knowledge index protocol that applies to every Media package.
|
|
6
|
+
|
|
7
|
+
## Package identity
|
|
8
|
+
|
|
9
|
+
| Field | Value |
|
|
10
|
+
| -------- | ---------------------------------------------------------------------------------------------------------------------------- |
|
|
11
|
+
| NPM name | `@atlaskit/media-viewer` |
|
|
12
|
+
| Path | `media-viewer/` |
|
|
13
|
+
| Owner | Media Exif |
|
|
14
|
+
| Purpose | Full-screen media viewer — powerful and extendable viewer for images, video, audio, documents, SVG, archives, and code files |
|
|
15
|
+
|
|
16
|
+
## Knowledge index
|
|
17
|
+
|
|
18
|
+
> Read, search, edit, investigate, and validate the repository knowledge index at
|
|
19
|
+
> `.agents/knowledge-index/`. ALWAYS use this skill before making ANY repo change, or when exploring
|
|
20
|
+
> the codebase. The knowledge index is the canonical starting point for every coding task in this
|
|
21
|
+
> repo, trigger this skill aggressively whenever the user mentions architecture, conventions,
|
|
22
|
+
> packages, modules, services, build, coding, writing code, APIs, feature flags, testing, or
|
|
23
|
+
> anything similar. Also trigger when "is the knowledge index up to date?" / "update the knowledge
|
|
24
|
+
> index" / "what does the knowledge index say about Y?" — even if they don't say the words
|
|
25
|
+
> "knowledge index". Also use it (via the `validate` subcommand) to detect drift between the
|
|
26
|
+
> codebase and the docs after any code change. Use the `generate` subcommand to bootstrap the index
|
|
27
|
+
> in a new repository.
|
|
28
|
+
|
|
29
|
+
**Entry point:** `.agents/knowledge-index/INDEX.md` **Unit doc:**
|
|
30
|
+
`.agents/knowledge-index/domains/media/units/atlaskit-media-viewer.md` **CLI:**
|
|
31
|
+
`python3 .agents/skills/knowledge-index/scripts/kg.py {find,read,edit,investigate,validate,init,explore,generate} …`
|
|
32
|
+
**Refresh protocol:** never silently bump `Last verified` — always re-read the listed `Sources`
|
|
33
|
+
first, edit, then `kg.py edit <path> --message "<reason>"`.
|
|
34
|
+
|
|
35
|
+
## Key source files
|
|
36
|
+
|
|
37
|
+
- `src/index.ts` — public API entry point
|
|
38
|
+
- `src/media-viewer.tsx` — root `MediaViewer` component
|
|
39
|
+
- `src/viewers/` — per-format viewer implementations (image, video, doc, SVG, code, archive, custom)
|
|
40
|
+
- `src/components/` — shared viewer UI components
|
|
41
|
+
- `src/analytics/` — analytics event definitions and helpers
|
|
42
|
+
- `src/domain/` — domain types and state
|
|
43
|
+
- `src/utils/` — shared utilities
|
|
44
|
+
- `src/header.tsx` — viewer header bar
|
|
45
|
+
- `src/navigation.tsx` — multi-file navigation
|
|
46
|
+
- `src/content.tsx` — content area
|
|
47
|
+
|
|
48
|
+
## Public API (key exports)
|
|
49
|
+
|
|
50
|
+
`MediaViewer` (default), `MediaViewerExtensions`, `MediaViewerExtensionsActions`,
|
|
51
|
+
`MediaViewerProps`, `MediaMessage`, `ViewerOptionsProps`, `CustomRendererConfig`,
|
|
52
|
+
`CustomRendererStateProps`, `CustomRendererProps`, `ArchiveFileItem`
|
|
53
|
+
|
|
54
|
+
## Development notes
|
|
55
|
+
|
|
56
|
+
- React Compiler is enabled for this package
|
|
57
|
+
- Peer dependencies: `@emotion/react`, `react`, `react-intl`
|
|
58
|
+
- Export subpaths: `.`, `./classnames`, `./media-viewer-loader`, `./types`, `./viewer-options`
|
|
59
|
+
- Supports custom viewer via `CustomRendererConfig`
|
|
60
|
+
- Large test suite: 50+ test files under `src/__tests__/`
|
|
61
|
+
- All new behaviour changes must be behind a feature gate (`fg()` from
|
|
62
|
+
`@atlaskit/platform-feature-flags`)
|
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,37 @@
|
|
|
1
1
|
# @atlaskit/media-viewer
|
|
2
2
|
|
|
3
|
+
## 54.0.0
|
|
4
|
+
|
|
5
|
+
### Major Changes
|
|
6
|
+
|
|
7
|
+
- [`f2dc9097319f0`](https://bitbucket.org/atlassian/atlassian-frontend-monorepo/commits/f2dc9097319f0) - ###
|
|
8
|
+
Dropped support for _legacy_ Typescript 4 types. **Typescript 5 is now the new minimum**.
|
|
9
|
+
|
|
10
|
+
Removes the `typesVersions` property and `dist/types-ts4.5` directory from the dist.
|
|
11
|
+
|
|
12
|
+
Types are now exclusively via the `"types": "dist/types/index.d.ts"` property.
|
|
13
|
+
|
|
14
|
+
```diff
|
|
15
|
+
- "typesVersions": {
|
|
16
|
+
- ">=4.5 <4.9": {
|
|
17
|
+
- "*": [
|
|
18
|
+
- "dist/types-ts4.5/*",
|
|
19
|
+
- "dist/types-ts4.5/index.d.ts"
|
|
20
|
+
- ]
|
|
21
|
+
- }
|
|
22
|
+
- },
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
### Patch Changes
|
|
26
|
+
|
|
27
|
+
- Updated dependencies
|
|
28
|
+
|
|
29
|
+
## 53.2.5
|
|
30
|
+
|
|
31
|
+
### Patch Changes
|
|
32
|
+
|
|
33
|
+
- Updated dependencies
|
|
34
|
+
|
|
3
35
|
## 53.2.4
|
|
4
36
|
|
|
5
37
|
### Patch Changes
|
package/classnames/package.json
CHANGED
|
@@ -10,7 +10,7 @@ exports.packageVersion = exports.packageName = void 0;
|
|
|
10
10
|
var _analytics = require("@atlaskit/media-common/analytics");
|
|
11
11
|
var componentName = exports.component = exports.componentName = 'mediaViewer';
|
|
12
12
|
var packageName = exports.packageName = "@atlaskit/media-viewer";
|
|
13
|
-
var packageVersion = exports.packageVersion = "53.2.
|
|
13
|
+
var packageVersion = exports.packageVersion = "53.2.5";
|
|
14
14
|
function getFileAttributes(fileState) {
|
|
15
15
|
if (!fileState) {
|
|
16
16
|
return {
|
|
@@ -13,7 +13,7 @@ var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
|
|
|
13
13
|
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; }
|
|
14
14
|
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; }
|
|
15
15
|
var packageName = "@atlaskit/media-viewer";
|
|
16
|
-
var packageVersion = "53.2.
|
|
16
|
+
var packageVersion = "53.2.5";
|
|
17
17
|
var ufoExperience;
|
|
18
18
|
var getExperience = function getExperience() {
|
|
19
19
|
if (!ufoExperience) {
|
package/dist/cjs/download.js
CHANGED
|
@@ -57,7 +57,7 @@ function DownloadButton(_ref) {
|
|
|
57
57
|
var createItemDownloader = function createItemDownloader(file, mediaClient, options) {
|
|
58
58
|
return /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
|
|
59
59
|
var collectionName, traceContext, createAnalyticsEvent, id, name;
|
|
60
|
-
return _regenerator.default.wrap(function
|
|
60
|
+
return _regenerator.default.wrap(function (_context) {
|
|
61
61
|
while (1) switch (_context.prev = _context.next) {
|
|
62
62
|
case 0:
|
|
63
63
|
collectionName = options.collectionName, traceContext = options.traceContext, createAnalyticsEvent = options.createAnalyticsEvent;
|
|
@@ -68,7 +68,7 @@ var createItemDownloader = function createItemDownloader(file, mediaClient, opti
|
|
|
68
68
|
}).catch(function (e) {
|
|
69
69
|
(0, _analytics.fireAnalytics)((0, _download2.createDownloadFailedEventPayload)(file.id, new _errors.MediaViewerError('download', e), file, traceContext), createAnalyticsEvent);
|
|
70
70
|
});
|
|
71
|
-
case
|
|
71
|
+
case 1:
|
|
72
72
|
case "end":
|
|
73
73
|
return _context.stop();
|
|
74
74
|
}
|
|
@@ -10,37 +10,36 @@ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/
|
|
|
10
10
|
var _mediaClient = require("@atlaskit/media-client");
|
|
11
11
|
var getObjectUrlFromFileState = exports.getObjectUrlFromFileState = /*#__PURE__*/function () {
|
|
12
12
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(state) {
|
|
13
|
-
var preview;
|
|
14
|
-
return _regenerator.default.wrap(function
|
|
13
|
+
var preview, _t, _t2;
|
|
14
|
+
return _regenerator.default.wrap(function (_context) {
|
|
15
15
|
while (1) switch (_context.prev = _context.next) {
|
|
16
16
|
case 0:
|
|
17
17
|
if ((0, _mediaClient.isErrorFileState)(state)) {
|
|
18
|
-
_context.next =
|
|
18
|
+
_context.next = 4;
|
|
19
19
|
break;
|
|
20
20
|
}
|
|
21
21
|
preview = state.preview;
|
|
22
22
|
if (!preview) {
|
|
23
|
-
_context.next =
|
|
23
|
+
_context.next = 4;
|
|
24
24
|
break;
|
|
25
25
|
}
|
|
26
|
-
_context.prev =
|
|
27
|
-
|
|
28
|
-
_context.next =
|
|
26
|
+
_context.prev = 1;
|
|
27
|
+
_t = URL;
|
|
28
|
+
_context.next = 2;
|
|
29
29
|
return preview;
|
|
30
|
-
case
|
|
31
|
-
_context.
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
_context.t2 = _context["catch"](3);
|
|
30
|
+
case 2:
|
|
31
|
+
return _context.abrupt("return", _t.createObjectURL.call(_t, _context.sent.value));
|
|
32
|
+
case 3:
|
|
33
|
+
_context.prev = 3;
|
|
34
|
+
_t2 = _context["catch"](1);
|
|
36
35
|
return _context.abrupt("return", undefined);
|
|
37
|
-
case
|
|
36
|
+
case 4:
|
|
38
37
|
return _context.abrupt("return", undefined);
|
|
39
|
-
case
|
|
38
|
+
case 5:
|
|
40
39
|
case "end":
|
|
41
40
|
return _context.stop();
|
|
42
41
|
}
|
|
43
|
-
}, _callee, null, [[
|
|
42
|
+
}, _callee, null, [[1, 3]]);
|
|
44
43
|
}));
|
|
45
44
|
return function getObjectUrlFromFileState(_x) {
|
|
46
45
|
return _ref.apply(this, arguments);
|
package/dist/cjs/utils/index.js
CHANGED
|
@@ -74,35 +74,34 @@ var rejectAfter = exports.rejectAfter = function rejectAfter(fn) {
|
|
|
74
74
|
var delay = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 5000;
|
|
75
75
|
return new Promise( /*#__PURE__*/function () {
|
|
76
76
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(resolve, reject) {
|
|
77
|
-
var timeoutId;
|
|
78
|
-
return _regenerator.default.wrap(function
|
|
77
|
+
var timeoutId, _t, _t2;
|
|
78
|
+
return _regenerator.default.wrap(function (_context) {
|
|
79
79
|
while (1) switch (_context.prev = _context.next) {
|
|
80
80
|
case 0:
|
|
81
81
|
timeoutId = setTimeout(function () {
|
|
82
82
|
return reject(new Error('timed out'));
|
|
83
83
|
}, delay);
|
|
84
84
|
_context.prev = 1;
|
|
85
|
-
|
|
86
|
-
_context.next =
|
|
85
|
+
_t = resolve;
|
|
86
|
+
_context.next = 2;
|
|
87
87
|
return fn();
|
|
88
|
-
case
|
|
89
|
-
_context.
|
|
90
|
-
|
|
91
|
-
_context.next = 12;
|
|
88
|
+
case 2:
|
|
89
|
+
_t(_context.sent);
|
|
90
|
+
_context.next = 4;
|
|
92
91
|
break;
|
|
93
|
-
case
|
|
94
|
-
_context.prev =
|
|
95
|
-
|
|
96
|
-
reject(
|
|
97
|
-
case
|
|
98
|
-
_context.prev =
|
|
92
|
+
case 3:
|
|
93
|
+
_context.prev = 3;
|
|
94
|
+
_t2 = _context["catch"](1);
|
|
95
|
+
reject(_t2);
|
|
96
|
+
case 4:
|
|
97
|
+
_context.prev = 4;
|
|
99
98
|
clearTimeout(timeoutId);
|
|
100
|
-
return _context.finish(
|
|
101
|
-
case
|
|
99
|
+
return _context.finish(4);
|
|
100
|
+
case 5:
|
|
102
101
|
case "end":
|
|
103
102
|
return _context.stop();
|
|
104
103
|
}
|
|
105
|
-
}, _callee, null, [[1,
|
|
104
|
+
}, _callee, null, [[1, 3, 4, 5]]);
|
|
106
105
|
}));
|
|
107
106
|
return function (_x, _x2) {
|
|
108
107
|
return _ref.apply(this, arguments);
|
|
@@ -82,16 +82,16 @@ var ArchiveSidebarFolderEntryBase = /*#__PURE__*/function (_React$Component) {
|
|
|
82
82
|
});
|
|
83
83
|
(0, _defineProperty2.default)(_this, "downloadZipEntry", /*#__PURE__*/function () {
|
|
84
84
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(entry, root) {
|
|
85
|
-
var blob, name;
|
|
86
|
-
return _regenerator.default.wrap(function
|
|
85
|
+
var blob, name, _t;
|
|
86
|
+
return _regenerator.default.wrap(function (_context) {
|
|
87
87
|
while (1) switch (_context.prev = _context.next) {
|
|
88
88
|
case 0:
|
|
89
89
|
_context.prev = 0;
|
|
90
|
-
_context.next =
|
|
90
|
+
_context.next = 1;
|
|
91
91
|
return (0, _utils.rejectAfter)(function () {
|
|
92
92
|
return entry.blob();
|
|
93
93
|
});
|
|
94
|
-
case
|
|
94
|
+
case 1:
|
|
95
95
|
blob = _context.sent;
|
|
96
96
|
name = _this.formatName(root, entry.name); // Emit media-viewed event if feature flag is enabled
|
|
97
97
|
if (_this.props.fileId && (0, _platformFeatureFlags.fg)('download_event_for_jira_attachments')) {
|
|
@@ -104,17 +104,17 @@ var ArchiveSidebarFolderEntryBase = /*#__PURE__*/function (_React$Component) {
|
|
|
104
104
|
(0, _mediaCommon.downloadUrl)(URL.createObjectURL(blob), {
|
|
105
105
|
name: name
|
|
106
106
|
});
|
|
107
|
-
_context.next =
|
|
107
|
+
_context.next = 3;
|
|
108
108
|
break;
|
|
109
|
-
case
|
|
110
|
-
_context.prev =
|
|
111
|
-
|
|
112
|
-
_this.props.onError(
|
|
113
|
-
case
|
|
109
|
+
case 2:
|
|
110
|
+
_context.prev = 2;
|
|
111
|
+
_t = _context["catch"](0);
|
|
112
|
+
_this.props.onError(_t, entry);
|
|
113
|
+
case 3:
|
|
114
114
|
case "end":
|
|
115
115
|
return _context.stop();
|
|
116
116
|
}
|
|
117
|
-
}, _callee, null, [[0,
|
|
117
|
+
}, _callee, null, [[0, 2]]);
|
|
118
118
|
}));
|
|
119
119
|
return function (_x, _x2) {
|
|
120
120
|
return _ref.apply(this, arguments);
|
|
@@ -22,7 +22,7 @@ var _archive = require("./archive");
|
|
|
22
22
|
var _loading = require("../../loading");
|
|
23
23
|
var _errors = require("../../errors");
|
|
24
24
|
var _styleWrappers2 = require("./styleWrappers");
|
|
25
|
-
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
|
|
25
|
+
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 _t2 in e) "default" !== _t2 && {}.hasOwnProperty.call(e, _t2) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t2)) && (i.get || i.set) ? o(f, _t2, i) : f[_t2] = e[_t2]); return f; })(e, t); }
|
|
26
26
|
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
|
|
27
27
|
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
|
|
28
28
|
var ArchiveSidebarRenderer = exports.default = /*#__PURE__*/function (_Component) {
|
|
@@ -44,15 +44,15 @@ var ArchiveSidebarRenderer = exports.default = /*#__PURE__*/function (_Component
|
|
|
44
44
|
key: "componentDidMount",
|
|
45
45
|
value: function () {
|
|
46
46
|
var _componentDidMount = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
|
|
47
|
-
var _this$props, selectedFileState, mediaClient, collectionName, onError, onSuccess, archive, entries;
|
|
48
|
-
return _regenerator.default.wrap(function
|
|
47
|
+
var _this$props, selectedFileState, mediaClient, collectionName, onError, onSuccess, archive, entries, _t;
|
|
48
|
+
return _regenerator.default.wrap(function (_context) {
|
|
49
49
|
while (1) switch (_context.prev = _context.next) {
|
|
50
50
|
case 0:
|
|
51
51
|
_this$props = this.props, selectedFileState = _this$props.selectedFileState, mediaClient = _this$props.mediaClient, collectionName = _this$props.collectionName, onError = _this$props.onError, onSuccess = _this$props.onSuccess;
|
|
52
52
|
_context.prev = 1;
|
|
53
|
-
_context.next =
|
|
53
|
+
_context.next = 2;
|
|
54
54
|
return (0, _archive.getArchiveEntriesFromFileState)(selectedFileState, mediaClient, collectionName);
|
|
55
|
-
case
|
|
55
|
+
case 2:
|
|
56
56
|
archive = _context.sent;
|
|
57
57
|
entries = archive.entries;
|
|
58
58
|
this.setState({
|
|
@@ -60,20 +60,20 @@ var ArchiveSidebarRenderer = exports.default = /*#__PURE__*/function (_Component
|
|
|
60
60
|
status: 'loaded'
|
|
61
61
|
});
|
|
62
62
|
onSuccess();
|
|
63
|
-
_context.next =
|
|
63
|
+
_context.next = 4;
|
|
64
64
|
break;
|
|
65
|
-
case
|
|
66
|
-
_context.prev =
|
|
67
|
-
|
|
65
|
+
case 3:
|
|
66
|
+
_context.prev = 3;
|
|
67
|
+
_t = _context["catch"](1);
|
|
68
68
|
this.setState({
|
|
69
69
|
status: 'loaded'
|
|
70
70
|
});
|
|
71
|
-
onError(new _errors.ArchiveViewerError('archiveviewer-read-binary',
|
|
72
|
-
case
|
|
71
|
+
onError(new _errors.ArchiveViewerError('archiveviewer-read-binary', _t instanceof Error ? _t : undefined));
|
|
72
|
+
case 4:
|
|
73
73
|
case "end":
|
|
74
74
|
return _context.stop();
|
|
75
75
|
}
|
|
76
|
-
}, _callee, this, [[1,
|
|
76
|
+
}, _callee, this, [[1, 3]]);
|
|
77
77
|
}));
|
|
78
78
|
function componentDidMount() {
|
|
79
79
|
return _componentDidMount.apply(this, arguments);
|
|
@@ -32,27 +32,27 @@ var ArchiveSidebar = exports.ArchiveSidebar = /*#__PURE__*/function (_React$Comp
|
|
|
32
32
|
(0, _defineProperty2.default)(_this, "getArchiveFromEntry", /*#__PURE__*/function () {
|
|
33
33
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(entry) {
|
|
34
34
|
var blob, archive;
|
|
35
|
-
return _regenerator.default.wrap(function
|
|
35
|
+
return _regenerator.default.wrap(function (_context) {
|
|
36
36
|
while (1) switch (_context.prev = _context.next) {
|
|
37
37
|
case 0:
|
|
38
|
-
_context.next =
|
|
38
|
+
_context.next = 1;
|
|
39
39
|
return (0, _utils.rejectAfter)(function () {
|
|
40
40
|
return entry.blob();
|
|
41
41
|
});
|
|
42
|
-
case
|
|
42
|
+
case 1:
|
|
43
43
|
blob = _context.sent;
|
|
44
|
-
_context.next =
|
|
44
|
+
_context.next = 2;
|
|
45
45
|
return (0, _utils.rejectAfter)(function () {
|
|
46
46
|
return (0, _unzipit.unzip)(blob);
|
|
47
47
|
});
|
|
48
|
-
case
|
|
48
|
+
case 2:
|
|
49
49
|
archive = _context.sent;
|
|
50
50
|
Object.values(archive.entries).forEach(function (zipEntry) {
|
|
51
51
|
// eslint-disable-next-line no-param-reassign
|
|
52
52
|
zipEntry.name = _this.state.currentArchiveSidebarFolder.name + zipEntry.name;
|
|
53
53
|
});
|
|
54
54
|
return _context.abrupt("return", archive);
|
|
55
|
-
case
|
|
55
|
+
case 3:
|
|
56
56
|
case "end":
|
|
57
57
|
return _context.stop();
|
|
58
58
|
}
|
|
@@ -64,8 +64,8 @@ var ArchiveSidebar = exports.ArchiveSidebar = /*#__PURE__*/function (_React$Comp
|
|
|
64
64
|
}());
|
|
65
65
|
(0, _defineProperty2.default)(_this, "onEntrySelected", /*#__PURE__*/function () {
|
|
66
66
|
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(entry) {
|
|
67
|
-
var onEntrySelected, isArchive;
|
|
68
|
-
return _regenerator.default.wrap(function
|
|
67
|
+
var onEntrySelected, isArchive, _t;
|
|
68
|
+
return _regenerator.default.wrap(function (_context2) {
|
|
69
69
|
while (1) switch (_context2.prev = _context2.next) {
|
|
70
70
|
case 0:
|
|
71
71
|
onEntrySelected = _this.props.onEntrySelected;
|
|
@@ -73,30 +73,30 @@ var ArchiveSidebar = exports.ArchiveSidebar = /*#__PURE__*/function (_React$Comp
|
|
|
73
73
|
onEntrySelected(entry);
|
|
74
74
|
}
|
|
75
75
|
isArchive = !entry.isDirectory && (0, _utils.getMediaTypeFromFilename)(entry.name) === 'archive';
|
|
76
|
-
_context2.prev =
|
|
76
|
+
_context2.prev = 1;
|
|
77
77
|
if (!(isArchive || entry.isDirectory)) {
|
|
78
|
-
_context2.next =
|
|
78
|
+
_context2.next = 3;
|
|
79
79
|
break;
|
|
80
80
|
}
|
|
81
|
-
_context2.next =
|
|
81
|
+
_context2.next = 2;
|
|
82
82
|
return _this.onFolderEntrySelected(entry, isArchive);
|
|
83
|
-
case
|
|
84
|
-
_context2.next =
|
|
83
|
+
case 2:
|
|
84
|
+
_context2.next = 4;
|
|
85
85
|
break;
|
|
86
|
-
case
|
|
86
|
+
case 3:
|
|
87
87
|
null;
|
|
88
|
-
case
|
|
89
|
-
_context2.next =
|
|
88
|
+
case 4:
|
|
89
|
+
_context2.next = 6;
|
|
90
90
|
break;
|
|
91
|
-
case
|
|
92
|
-
_context2.prev =
|
|
93
|
-
|
|
94
|
-
return _context2.abrupt("return", _this.props.onError(
|
|
95
|
-
case
|
|
91
|
+
case 5:
|
|
92
|
+
_context2.prev = 5;
|
|
93
|
+
_t = _context2["catch"](1);
|
|
94
|
+
return _context2.abrupt("return", _this.props.onError(_t, entry));
|
|
95
|
+
case 6:
|
|
96
96
|
case "end":
|
|
97
97
|
return _context2.stop();
|
|
98
98
|
}
|
|
99
|
-
}, _callee2, null, [[
|
|
99
|
+
}, _callee2, null, [[1, 5]]);
|
|
100
100
|
}));
|
|
101
101
|
return function (_x2) {
|
|
102
102
|
return _ref2.apply(this, arguments);
|
|
@@ -105,21 +105,21 @@ var ArchiveSidebar = exports.ArchiveSidebar = /*#__PURE__*/function (_React$Comp
|
|
|
105
105
|
(0, _defineProperty2.default)(_this, "onFolderEntrySelected", /*#__PURE__*/function () {
|
|
106
106
|
var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(folder, isArchive) {
|
|
107
107
|
var _this$props, entries, mediaClient, folderName, archiveEntries, _this$props2, isArchiveEntryLoading, onError, shouldRenderAbuseModal, fileId, currentFolderName;
|
|
108
|
-
return _regenerator.default.wrap(function
|
|
108
|
+
return _regenerator.default.wrap(function (_context3) {
|
|
109
109
|
while (1) switch (_context3.prev = _context3.next) {
|
|
110
110
|
case 0:
|
|
111
111
|
_this$props = _this.props, entries = _this$props.entries, mediaClient = _this$props.mediaClient;
|
|
112
112
|
if (!isArchive) {
|
|
113
|
-
_context3.next =
|
|
113
|
+
_context3.next = 2;
|
|
114
114
|
break;
|
|
115
115
|
}
|
|
116
|
-
_context3.next =
|
|
116
|
+
_context3.next = 1;
|
|
117
117
|
return _this.getArchiveFromEntry(folder);
|
|
118
|
-
case
|
|
118
|
+
case 1:
|
|
119
119
|
archiveEntries = _context3.sent.entries;
|
|
120
120
|
entries = _objectSpread(_objectSpread({}, entries), archiveEntries);
|
|
121
121
|
folderName = (0, _utils.extractArchiveFolderName)(folder.name);
|
|
122
|
-
case
|
|
122
|
+
case 2:
|
|
123
123
|
_this$props2 = _this.props, isArchiveEntryLoading = _this$props2.isArchiveEntryLoading, onError = _this$props2.onError, shouldRenderAbuseModal = _this$props2.shouldRenderAbuseModal, fileId = _this$props2.fileId;
|
|
124
124
|
currentFolderName = folderName || folder.name;
|
|
125
125
|
_this.setState({
|
|
@@ -135,7 +135,7 @@ var ArchiveSidebar = exports.ArchiveSidebar = /*#__PURE__*/function (_React$Comp
|
|
|
135
135
|
fileId: fileId
|
|
136
136
|
}
|
|
137
137
|
});
|
|
138
|
-
case
|
|
138
|
+
case 3:
|
|
139
139
|
case "end":
|
|
140
140
|
return _context3.stop();
|
|
141
141
|
}
|
|
@@ -47,22 +47,22 @@ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.
|
|
|
47
47
|
var getArchiveEntriesFromFileState = exports.getArchiveEntriesFromFileState = /*#__PURE__*/function () {
|
|
48
48
|
var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(fileState, mediaClient, collectionName) {
|
|
49
49
|
var url, reader, archive;
|
|
50
|
-
return _regenerator.default.wrap(function
|
|
50
|
+
return _regenerator.default.wrap(function (_context) {
|
|
51
51
|
while (1) switch (_context.prev = _context.next) {
|
|
52
52
|
case 0:
|
|
53
|
-
_context.next =
|
|
53
|
+
_context.next = 1;
|
|
54
54
|
return mediaClient.file.getFileBinaryURL(fileState.id, collectionName);
|
|
55
|
-
case
|
|
55
|
+
case 1:
|
|
56
56
|
url = _context.sent;
|
|
57
57
|
reader = new _unzipit.HTTPRangeReader(url);
|
|
58
|
-
_context.next =
|
|
58
|
+
_context.next = 2;
|
|
59
59
|
return (0, _utils.rejectAfter)(function () {
|
|
60
60
|
return (0, _unzipit.unzip)(reader);
|
|
61
61
|
});
|
|
62
|
-
case
|
|
62
|
+
case 2:
|
|
63
63
|
archive = _context.sent;
|
|
64
64
|
return _context.abrupt("return", archive);
|
|
65
|
-
case
|
|
65
|
+
case 3:
|
|
66
66
|
case "end":
|
|
67
67
|
return _context.stop();
|
|
68
68
|
}
|
|
@@ -91,8 +91,8 @@ var ArchiveViewerBase = exports.ArchiveViewerBase = /*#__PURE__*/function (_Base
|
|
|
91
91
|
});
|
|
92
92
|
(0, _defineProperty2.default)(_this, "onSelectedArchiveEntryChange", /*#__PURE__*/function () {
|
|
93
93
|
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(selectedArchiveEntry) {
|
|
94
|
-
var src, codeViewerSrc, mimeType, isCodeMimeType, blob, blobWithMimeType;
|
|
95
|
-
return _regenerator.default.wrap(function
|
|
94
|
+
var src, codeViewerSrc, mimeType, isCodeMimeType, blob, blobWithMimeType, _t;
|
|
95
|
+
return _regenerator.default.wrap(function (_context2) {
|
|
96
96
|
while (1) switch (_context2.prev = _context2.next) {
|
|
97
97
|
case 0:
|
|
98
98
|
_this.setState({
|
|
@@ -106,38 +106,38 @@ var ArchiveViewerBase = exports.ArchiveViewerBase = /*#__PURE__*/function (_Base
|
|
|
106
106
|
mimeType = (0, _utils.getMimeTypeFromFilename)(selectedArchiveEntry.name);
|
|
107
107
|
isCodeMimeType = (0, _codeViewer.isCodeViewerItem)(selectedArchiveEntry.name, mimeType);
|
|
108
108
|
if (selectedArchiveEntry.isDirectory) {
|
|
109
|
-
_context2.next =
|
|
109
|
+
_context2.next = 6;
|
|
110
110
|
break;
|
|
111
111
|
}
|
|
112
|
-
_context2.prev =
|
|
113
|
-
_context2.next =
|
|
112
|
+
_context2.prev = 1;
|
|
113
|
+
_context2.next = 2;
|
|
114
114
|
return (0, _utils.rejectAfter)(function () {
|
|
115
115
|
return selectedArchiveEntry.blob();
|
|
116
116
|
}, 10000);
|
|
117
|
-
case
|
|
117
|
+
case 2:
|
|
118
118
|
blob = _context2.sent;
|
|
119
119
|
blobWithMimeType = new Blob([blob], {
|
|
120
120
|
type: mimeType
|
|
121
121
|
});
|
|
122
122
|
src = URL.createObjectURL(blobWithMimeType);
|
|
123
123
|
if (!isCodeMimeType) {
|
|
124
|
-
_context2.next =
|
|
124
|
+
_context2.next = 4;
|
|
125
125
|
break;
|
|
126
126
|
}
|
|
127
|
-
_context2.next =
|
|
127
|
+
_context2.next = 3;
|
|
128
128
|
return (0, _utils.rejectAfter)(function () {
|
|
129
129
|
return blob.text();
|
|
130
130
|
});
|
|
131
|
-
case
|
|
131
|
+
case 3:
|
|
132
132
|
codeViewerSrc = _context2.sent;
|
|
133
|
-
case
|
|
134
|
-
_context2.next =
|
|
133
|
+
case 4:
|
|
134
|
+
_context2.next = 6;
|
|
135
135
|
break;
|
|
136
|
-
case
|
|
137
|
-
_context2.prev =
|
|
138
|
-
|
|
139
|
-
return _context2.abrupt("return", _this.onError(new _errors.ArchiveViewerError(
|
|
140
|
-
case
|
|
136
|
+
case 5:
|
|
137
|
+
_context2.prev = 5;
|
|
138
|
+
_t = _context2["catch"](1);
|
|
139
|
+
return _context2.abrupt("return", _this.onError(new _errors.ArchiveViewerError(_t.message === _consts.ENCRYPTED_ENTRY_ERROR_MESSAGE ? 'archiveviewer-encrypted-entry' : 'archiveviewer-create-url', _t), selectedArchiveEntry));
|
|
140
|
+
case 6:
|
|
141
141
|
_this.setState({
|
|
142
142
|
content: _domain.Outcome.successful(_objectSpread(_objectSpread({}, _this.state.content.data), {}, {
|
|
143
143
|
selectedArchiveEntry: selectedArchiveEntry,
|
|
@@ -150,11 +150,11 @@ var ArchiveViewerBase = exports.ArchiveViewerBase = /*#__PURE__*/function (_Base
|
|
|
150
150
|
hasLoadedEntries: true
|
|
151
151
|
}))
|
|
152
152
|
});
|
|
153
|
-
case
|
|
153
|
+
case 7:
|
|
154
154
|
case "end":
|
|
155
155
|
return _context2.stop();
|
|
156
156
|
}
|
|
157
|
-
}, _callee2, null, [[
|
|
157
|
+
}, _callee2, null, [[1, 5]]);
|
|
158
158
|
}));
|
|
159
159
|
return function (_x4) {
|
|
160
160
|
return _ref2.apply(this, arguments);
|
|
@@ -194,7 +194,7 @@ var ArchiveViewerBase = exports.ArchiveViewerBase = /*#__PURE__*/function (_Base
|
|
|
194
194
|
key: "init",
|
|
195
195
|
value: function () {
|
|
196
196
|
var _init = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {
|
|
197
|
-
return _regenerator.default.wrap(function
|
|
197
|
+
return _regenerator.default.wrap(function (_context3) {
|
|
198
198
|
while (1) switch (_context3.prev = _context3.next) {
|
|
199
199
|
case 0:
|
|
200
200
|
this.setState(this.initialState);
|
|
@@ -287,14 +287,14 @@ var ArchiveViewerBase = exports.ArchiveViewerBase = /*#__PURE__*/function (_Base
|
|
|
287
287
|
},
|
|
288
288
|
getBinaryContent: function () {
|
|
289
289
|
var _getBinaryContent = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4() {
|
|
290
|
-
return _regenerator.default.wrap(function
|
|
290
|
+
return _regenerator.default.wrap(function (_context4) {
|
|
291
291
|
while (1) switch (_context4.prev = _context4.next) {
|
|
292
292
|
case 0:
|
|
293
|
-
_context4.next =
|
|
293
|
+
_context4.next = 1;
|
|
294
294
|
return fetch(src);
|
|
295
|
-
case
|
|
295
|
+
case 1:
|
|
296
296
|
return _context4.abrupt("return", _context4.sent.blob());
|
|
297
|
-
case
|
|
297
|
+
case 2:
|
|
298
298
|
case "end":
|
|
299
299
|
return _context4.stop();
|
|
300
300
|
}
|