@pingux/astro 2.32.0-alpha.10 → 2.32.0-alpha.11

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 (32) hide show
  1. package/lib/cjs/components/ImageUploadField/ImageUploadField.test.js +47 -14
  2. package/lib/cjs/components/TreeView/TreeView.js +99 -11
  3. package/lib/cjs/components/TreeView/TreeView.stories.js +23 -10
  4. package/lib/cjs/components/TreeView/TreeView.styles.js +22 -2
  5. package/lib/cjs/components/TreeView/TreeView.test.js +91 -11
  6. package/lib/cjs/components/TreeView/TreeViewItem.js +112 -14
  7. package/lib/cjs/components/TreeView/TreeViewKeyboardDelegate.js +200 -0
  8. package/lib/cjs/components/TreeView/TreeViewKeyboardDelegate.test.js +511 -0
  9. package/lib/cjs/components/TreeView/TreeViewRow.js +20 -5
  10. package/lib/cjs/components/TreeView/TreeViewSection.js +164 -16
  11. package/lib/cjs/components/TreeView/TreeViewWrapper.js +40 -0
  12. package/lib/cjs/hooks/useImageUploadState/index.d.ts +1 -0
  13. package/lib/cjs/hooks/useImageUploadState/useImageUploadState.d.ts +28 -0
  14. package/lib/cjs/hooks/useImageUploadState/useImageUploadState.js +9 -6
  15. package/lib/cjs/hooks/useModalState/index.d.ts +1 -0
  16. package/lib/cjs/hooks/useModalState/useModalState.d.ts +21 -0
  17. package/lib/cjs/hooks/useModalState/useModalState.js +0 -9
  18. package/lib/cjs/hooks/useModalState/useModalState.test.d.ts +1 -0
  19. package/lib/components/ImageUploadField/ImageUploadField.test.js +47 -14
  20. package/lib/components/TreeView/TreeView.js +100 -12
  21. package/lib/components/TreeView/TreeView.stories.js +23 -10
  22. package/lib/components/TreeView/TreeView.styles.js +22 -2
  23. package/lib/components/TreeView/TreeView.test.js +92 -12
  24. package/lib/components/TreeView/TreeViewItem.js +111 -14
  25. package/lib/components/TreeView/TreeViewKeyboardDelegate.js +176 -0
  26. package/lib/components/TreeView/TreeViewKeyboardDelegate.test.js +496 -0
  27. package/lib/components/TreeView/TreeViewRow.js +20 -5
  28. package/lib/components/TreeView/TreeViewSection.js +161 -16
  29. package/lib/components/TreeView/TreeViewWrapper.js +31 -0
  30. package/lib/hooks/useImageUploadState/useImageUploadState.js +9 -6
  31. package/lib/hooks/useModalState/useModalState.js +0 -10
  32. package/package.json +1 -1
@@ -8,25 +8,114 @@ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequ
8
8
  _Object$defineProperty(exports, "__esModule", {
9
9
  value: true
10
10
  });
11
- exports["default"] = void 0;
11
+ exports.removeRefFromArrayHelper = exports.onKeyDownSection = exports["default"] = exports.addRefToArrayHelper = void 0;
12
12
  var _extends2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/extends"));
13
+ var _some = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/some"));
14
+ var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
15
+ var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/filter"));
13
16
  var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
14
17
  var _from = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/array/from"));
15
18
  var _react = _interopRequireWildcard(require("react"));
19
+ var _focus = require("@react-aria/focus");
16
20
  var _listbox = require("@react-aria/listbox");
21
+ var _utils = require("@react-aria/utils");
17
22
  var _propTypes = _interopRequireDefault(require("prop-types"));
18
23
  var _TreeViewContext = require("../../context/TreeViewContext");
24
+ var _hooks = require("../../hooks");
19
25
  var _index2 = require("../../index");
20
26
  var _TreeView = require("./TreeView");
27
+ var _TreeViewKeyboardDelegate = require("./TreeViewKeyboardDelegate");
21
28
  var _TreeViewRow = _interopRequireDefault(require("./TreeViewRow"));
22
29
  var _react2 = require("@emotion/react");
23
30
  function _getRequireWildcardCache(nodeInterop) { if (typeof _WeakMap !== "function") return null; var cacheBabelInterop = new _WeakMap(); var cacheNodeInterop = new _WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
24
31
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = _Object$defineProperty && _Object$getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? _Object$getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { _Object$defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
32
+ var onKeyDownSection = function onKeyDownSection(e, state, key, tree, isSelected, isExpanded, focusManager, flatKeyArray, refArray, pageLength, isFocused) {
33
+ switch (e.which) {
34
+ case 9:
35
+ if (isFocused) {
36
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onTabPress(e, refArray, focusManager, true, key);
37
+ }
38
+ break;
39
+ case 13:
40
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onEnterPress(e, state, key);
41
+ break;
42
+ case 32:
43
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onSpacePress(e, tree, key, isSelected);
44
+ break;
45
+ case 33:
46
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onPageUpPress(e, key, flatKeyArray, refArray, pageLength);
47
+ break;
48
+ case 34:
49
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onPageDownPress(e, key, flatKeyArray, refArray, pageLength);
50
+ break;
51
+ case 36:
52
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onHomePress(key, flatKeyArray, refArray);
53
+ e.preventDefault();
54
+ e.stopPropagation();
55
+ break;
56
+ case 35:
57
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onEndPress(key, flatKeyArray, refArray);
58
+ e.preventDefault();
59
+ e.stopPropagation();
60
+ break;
61
+ case 37:
62
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onLeftPress(e, focusManager, state, key, isExpanded, refArray);
63
+ break;
64
+ case 38:
65
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onUpPress(e, key, refArray, flatKeyArray);
66
+ e.preventDefault();
67
+ e.stopPropagation();
68
+ break;
69
+ case 39:
70
+ if (isFocused) {
71
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onRightPress(e, focusManager, state, key, isExpanded, refArray);
72
+ }
73
+ break;
74
+ case 40:
75
+ _TreeViewKeyboardDelegate.sectionPressHandlers.onDownPress(e, key, refArray, flatKeyArray);
76
+ e.preventDefault();
77
+ e.stopPropagation();
78
+ break;
79
+ default:
80
+ /* istanbul ignore next */
81
+ break;
82
+ }
83
+ };
84
+ exports.onKeyDownSection = onKeyDownSection;
85
+ var removeRefFromArrayHelper = function removeRefFromArrayHelper(prevState, keyToRemove) {
86
+ if ((0, _some["default"])(prevState).call(prevState, function (item) {
87
+ return item.key === keyToRemove;
88
+ })) {
89
+ var _context;
90
+ var newArray = (0, _concat["default"])(_context = []).call(_context, (0, _filter["default"])(prevState).call(prevState, function (_item) {
91
+ return _item.key !== keyToRemove;
92
+ }));
93
+ return newArray;
94
+ }
95
+ return prevState;
96
+ };
97
+ exports.removeRefFromArrayHelper = removeRefFromArrayHelper;
98
+ var addRefToArrayHelper = function addRefToArrayHelper(prevState, keyToAdd, refToAdd) {
99
+ if (!(0, _some["default"])(prevState).call(prevState, function (i) {
100
+ return i.key === keyToAdd;
101
+ })) {
102
+ var _context2;
103
+ var thisObj = {
104
+ key: keyToAdd,
105
+ thisRef: refToAdd
106
+ };
107
+ return (0, _concat["default"])(_context2 = []).call(_context2, prevState, [thisObj]);
108
+ }
109
+ return prevState;
110
+ };
111
+ exports.addRefToArrayHelper = addRefToArrayHelper;
25
112
  var TreeViewSection = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
26
- var _context;
113
+ var _context3;
27
114
  var item = props.item,
28
115
  items = props.items,
29
116
  title = props.title,
117
+ focusManager = props.focusManager,
118
+ onKeyDown = props.onKeyDown,
30
119
  level = props.level,
31
120
  position = props.position,
32
121
  setSize = props.setSize;
@@ -37,51 +126,107 @@ var TreeViewSection = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
37
126
  return treeSectionRef.current;
38
127
  });
39
128
  var _useTreeViewContext = (0, _TreeViewContext.useTreeViewContext)(),
40
- state = _useTreeViewContext.state;
129
+ state = _useTreeViewContext.state,
130
+ tree = _useTreeViewContext.tree,
131
+ refArray = _useTreeViewContext.refArray,
132
+ setRefs = _useTreeViewContext.setRefs,
133
+ flatKeyArray = _useTreeViewContext.flatKeyArray,
134
+ pageLength = _useTreeViewContext.pageLength,
135
+ setLastFocusedItem = _useTreeViewContext.setLastFocusedItem,
136
+ lastFocusedItem = _useTreeViewContext.lastFocusedItem;
41
137
  var _useOption = (0, _listbox.useOption)({
42
138
  key: key
43
139
  }, state, treeSectionRef),
44
140
  optionProps = _useOption.optionProps,
45
141
  isDisabled = _useOption.isDisabled,
46
142
  isSelected = _useOption.isSelected;
143
+ var _useFocusRing = (0, _focus.useFocusRing)(),
144
+ focusProps = _useFocusRing.focusProps,
145
+ isFocused = _useFocusRing.isFocused;
146
+ var _useFocusRing2 = (0, _focus.useFocusRing)({
147
+ within: true
148
+ }),
149
+ focusPropsWithin = _useFocusRing2.focusProps,
150
+ isFocusedWithin = _useFocusRing2.isFocused;
47
151
  var isExpanded = state.expandedKeys.has(key);
152
+ var onKeyDownFunction = function onKeyDownFunction(e) {
153
+ onKeyDownSection(e, state, key, tree, isSelected, isExpanded, focusManager, flatKeyArray, refArray, pageLength, isFocused);
154
+ if (onKeyDown) {
155
+ onKeyDown(e, key);
156
+ }
157
+ };
158
+ var addRefToArray = function addRefToArray(thisKey, thisRef) {
159
+ setRefs(function (prev) {
160
+ return addRefToArrayHelper(prev, thisKey, thisRef);
161
+ });
162
+ };
163
+ var removeRefFromArray = function removeRefFromArray() {
164
+ setRefs(function (prev) {
165
+ return removeRefFromArrayHelper(prev, key);
166
+ });
167
+ };
168
+
169
+ // adds and removes refs on mount and dismount
170
+ (0, _react.useEffect)(function () {
171
+ // this runs on mount
172
+ addRefToArray(key, treeSectionRef);
173
+ return function () {
174
+ // this runs on cleanup
175
+ removeRefFromArray(key, refArray);
176
+ };
177
+ }, []);
178
+ var mergedProps = (0, _utils.mergeProps)(focusPropsWithin, focusProps, optionProps, {
179
+ onFocus: function onFocus() {
180
+ return setLastFocusedItem(key);
181
+ }
182
+ });
183
+ var _useStatusClasses = (0, _hooks.useStatusClasses)('', {
184
+ isFocused: isFocused
185
+ }),
186
+ classNames = _useStatusClasses.classNames;
48
187
  return (0, _react2.jsx)(_index2.Box, (0, _extends2["default"])({
49
188
  ref: treeSectionRef,
50
189
  as: "li",
51
- sx: {
52
- ':not(:last-child)': {
53
- pb: 'sm'
54
- }
55
- },
56
190
  "aria-expanded": isExpanded,
57
- "aria-disabled": isDisabled,
191
+ "aria-disabled": isDisabled
192
+ }, mergedProps, {
193
+ role: "treeitem",
194
+ variant: "treeView.wrapper",
195
+ className: classNames,
196
+ "aria-selected": isSelected,
58
197
  "aria-level": level,
59
198
  "aria-setsize": setSize,
60
- "aria-posinset": position + 1
61
- }, optionProps, {
62
- role: "treeitem",
63
- "aria-selected": isSelected
199
+ "aria-posinset": position + 1,
200
+ onKeyDown: function onKeyDown(e) {
201
+ return onKeyDownFunction(e);
202
+ },
203
+ tabIndex: lastFocusedItem === key ? 0 : -1
64
204
  }), (0, _react2.jsx)(_TreeViewRow["default"], {
65
205
  item: item,
66
206
  title: title,
67
207
  items: items,
68
208
  isExpanded: isExpanded,
69
209
  isSelected: isSelected,
70
- isDisabled: isDisabled
210
+ isDisabled: isDisabled,
211
+ isParentFocused: isFocusedWithin
71
212
  }), isExpanded && (0, _react2.jsx)(_index2.Box, {
72
213
  as: "ul",
73
214
  role: "group",
74
215
  key: "".concat(item.key, " ul"),
75
216
  sx: {
76
- pl: 'md'
217
+ pl: 'md',
218
+ '& :focus': {
219
+ border: 'none'
220
+ }
77
221
  }
78
- }, (0, _map["default"])(_context = (0, _from["default"])(items)).call(_context, function (_item, _index) {
222
+ }, (0, _map["default"])(_context3 = (0, _from["default"])(items)).call(_context3, function (_item, _index) {
79
223
  var _item$value$items;
80
224
  return (0, _TreeView.SectionOrItemRender)(((_item$value$items = _item.value.items) === null || _item$value$items === void 0 ? void 0 : _item$value$items.length) > 0, (0, _react2.jsx)(TreeViewSection, {
81
225
  item: _item,
82
226
  items: _item.children,
83
227
  title: _item.value.title,
84
228
  key: _item.value.title,
229
+ focusManager: focusManager,
85
230
  level: level + 1,
86
231
  position: _index,
87
232
  setSize: items.length
@@ -89,6 +234,7 @@ var TreeViewSection = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref)
89
234
  item: _item,
90
235
  title: _item.value.title,
91
236
  key: _item.value.title,
237
+ focusManager: focusManager,
92
238
  level: level + 1,
93
239
  position: _index,
94
240
  setSize: items.length
@@ -101,6 +247,8 @@ TreeViewSection.propTypes = {
101
247
  key: _propTypes["default"].string
102
248
  }),
103
249
  title: _propTypes["default"].string,
250
+ focusManager: _propTypes["default"].shape({}),
251
+ onKeyDown: _propTypes["default"].func,
104
252
  level: _propTypes["default"].number,
105
253
  position: _propTypes["default"].number,
106
254
  setSize: _propTypes["default"].number
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _Object$defineProperty = require("@babel/runtime-corejs3/core-js-stable/object/define-property");
4
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
5
+ _Object$defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
10
+ var _react = _interopRequireDefault(require("react"));
11
+ var _focus = require("@react-aria/focus");
12
+ var _react2 = require("@emotion/react");
13
+ var TreeViewWrapper = function TreeViewWrapper(props) {
14
+ var children = props.children;
15
+ var items = (0, _map["default"])(children).call(children, function (child) {
16
+ return {
17
+ item: child,
18
+ key: child.key
19
+ };
20
+ });
21
+ return (0, _react2.jsx)(_focus.FocusScope, {
22
+ restoreFocus: false,
23
+ contain: false
24
+ }, (0, _map["default"])(items).call(items, function (_ref) {
25
+ var item = _ref.item,
26
+ key = _ref.key;
27
+ return (0, _react2.jsx)(FocusableItem, {
28
+ key: key
29
+ }, item);
30
+ }));
31
+ };
32
+ var FocusableItem = function FocusableItem(props) {
33
+ var focusManager = (0, _focus.useFocusManager)();
34
+ var childWithFocusHandle = /*#__PURE__*/_react["default"].cloneElement(props.children, {
35
+ focusManager: focusManager
36
+ });
37
+ return childWithFocusHandle;
38
+ };
39
+ var _default = TreeViewWrapper;
40
+ exports["default"] = _default;
@@ -0,0 +1 @@
1
+ export { default as useImageUploadState } from './useImageUploadState';
@@ -0,0 +1,28 @@
1
+ import React, { RefObject } from 'react';
2
+ interface ImageUploadStateProps {
3
+ previewImage?: string;
4
+ defaultPreviewImage?: string | null;
5
+ fileTypes?: string[];
6
+ onChange?: (event: React.ChangeEvent<HTMLInputElement>) => void;
7
+ previewHeight?: string;
8
+ previewWidth?: string;
9
+ }
10
+ declare const useImageUploadState: (inputRef: RefObject<HTMLInputElement | null>, props?: ImageUploadStateProps) => {
11
+ defaultPreviewImage: string | null;
12
+ defaultPreviewNode: string | null | undefined;
13
+ fileName: string;
14
+ handleInputChange: (event: React.ChangeEvent<HTMLInputElement>) => void;
15
+ handleLabelClick: (e: React.MouseEvent<HTMLButtonElement>) => void;
16
+ handleOpenMenuChange: (isOpen: boolean) => void;
17
+ isImageType: boolean;
18
+ isMenuOpen: boolean;
19
+ pressPreviewButton: () => void;
20
+ previewImage: string | null;
21
+ removePreview: () => void;
22
+ showFileDialog: () => void | undefined;
23
+ widthHeightSx: {
24
+ height: string | undefined;
25
+ width: string | undefined;
26
+ };
27
+ };
28
+ export default useImageUploadState;
@@ -43,11 +43,15 @@ var useImageUploadState = function useImageUploadState(inputRef) {
43
43
  if (previewImage && previewImage !== defaultPreviewImage) {
44
44
  setIsMenuOpen(true);
45
45
  } else {
46
- inputRef.current.click();
46
+ var _inputRef$current;
47
+ (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.click();
47
48
  }
48
49
  }, [defaultPreviewImage, previewImage, inputRef]);
49
50
  var handleInputChange = (0, _react.useCallback)(function (event) {
50
51
  var _event$target;
52
+ if (!event.target.files) {
53
+ return;
54
+ }
51
55
  var eventFileType = (_event$target = event.target) === null || _event$target === void 0 || (_event$target = _event$target.files[0]) === null || _event$target === void 0 || (_event$target = _event$target.type) === null || _event$target === void 0 ? void 0 : _event$target.split('/')[0];
52
56
  if (fileTypes !== null && fileTypes !== void 0 && (0, _includes["default"])(fileTypes).call(fileTypes, eventFileType)) {
53
57
  if (onChange && typeof onChange === 'function') {
@@ -60,9 +64,8 @@ var useImageUploadState = function useImageUploadState(inputRef) {
60
64
  var _event$target2;
61
65
  setIsImageType(true);
62
66
  var reader = new FileReader();
63
- reader.onload = function (_ref) {
64
- var result = _ref.target.result;
65
- setPreviewImage(result);
67
+ reader.onload = function () {
68
+ setPreviewImage(reader.result);
66
69
  };
67
70
  reader.readAsDataURL((_event$target2 = event.target) === null || _event$target2 === void 0 ? void 0 : _event$target2.files[0]);
68
71
  } else {
@@ -84,8 +87,8 @@ var useImageUploadState = function useImageUploadState(inputRef) {
84
87
  return setPreviewImage(defaultPreviewImage);
85
88
  }, [defaultPreviewImage]);
86
89
  var showFileDialog = (0, _react.useCallback)(function () {
87
- var _inputRef$current;
88
- return inputRef === null || inputRef === void 0 || (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.click();
90
+ var _inputRef$current2;
91
+ return inputRef === null || inputRef === void 0 || (_inputRef$current2 = inputRef.current) === null || _inputRef$current2 === void 0 ? void 0 : _inputRef$current2.click();
89
92
  }, [inputRef]);
90
93
  var handleLabelClick = (0, _react.useCallback)(function (e) {
91
94
  e.preventDefault();
@@ -0,0 +1 @@
1
+ export { default } from './useModalState';
@@ -0,0 +1,21 @@
1
+ import { OverlayTriggerState } from 'react-stately';
2
+ interface UseModalStateProps {
3
+ isDefaultOpen?: boolean;
4
+ isOpen?: boolean;
5
+ onOpenChange?: (isOpen: boolean) => void;
6
+ }
7
+ interface UseModalState {
8
+ /**
9
+ * Returns state-related data and functions for use with a Modal component.
10
+ * @param {Object} [props] Properties provided to the state
11
+ *
12
+ * `props.isDefaultOpen`: boolean - Whether the modal is open by default (uncontrolled).
13
+ * `props.isOpen`: boolean - Whether the modal is currently open (controlled).
14
+ * `props.onOpenChange`: boolean - Handler that is called when the open state changes.
15
+ *
16
+ * @returns {Object} `{ isOpen: Boolean, open: Function, close: Function, toggle: Function }`
17
+ */
18
+ (props?: UseModalStateProps): OverlayTriggerState;
19
+ }
20
+ declare const useModalState: UseModalState;
21
+ export default useModalState;
@@ -6,15 +6,6 @@ _Object$defineProperty(exports, "__esModule", {
6
6
  });
7
7
  exports["default"] = void 0;
8
8
  var _reactStately = require("react-stately");
9
- /**
10
- * Returns state-related data and functions for use with a Modal component.
11
- * @param {Object} [props] Properties provided to the state
12
- * @param {Boolean} [props.isDefaultOpen] Whether the modal is open by default (uncontrolled).
13
- * @param {Boolean} [props.isOpen] Whether the modal is currently open (controlled).
14
- * @param {Function} [props.onOpenChange] Handler that is called when the open state changes.
15
- * `(isOpen: boolean) => void`
16
- * @returns {Object} `{ isOpen: Boolean, open: Function, close: Function, toggle: Function }`
17
- */
18
9
  var useModalState = function useModalState() {
19
10
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
20
11
  var isDefaultOpen = props.isDefaultOpen,
@@ -1,7 +1,7 @@
1
1
  import _typeof from "@babel/runtime-corejs3/helpers/esm/typeof";
2
2
  import _asyncToGenerator from "@babel/runtime-corejs3/helpers/esm/asyncToGenerator";
3
3
  import _extends from "@babel/runtime-corejs3/helpers/esm/extends";
4
- function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = _Object$defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof _Symbol ? _Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return _Object$defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = _Object$create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = _Object$getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = _Object$create(IteratorPrototype); function defineIteratorMethods(prototype) { var _context8; _forEachInstanceProperty(_context8 = ["next", "throw", "return"]).call(_context8, function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], _forEachInstanceProperty(tryLocsList).call(tryLocsList, pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return _Object$setPrototypeOf ? _Object$setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = _Object$create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = _Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) keys.push(key); return _reverseInstanceProperty(keys).call(keys), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { var _context9; if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, _forEachInstanceProperty(_context9 = this.tryEntries).call(_context9, resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+_sliceInstanceProperty(name).call(name, 1)) && (this[name] = undefined); }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
4
+ function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, defineProperty = _Object$defineProperty || function (obj, key, desc) { obj[key] = desc.value; }, $Symbol = "function" == typeof _Symbol ? _Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return _Object$defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = _Object$create(protoGenerator.prototype), context = new Context(tryLocsList || []); return defineProperty(generator, "_invoke", { value: makeInvokeMethod(innerFn, self, context) }), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = _Object$getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = _Object$create(IteratorPrototype); function defineIteratorMethods(prototype) { var _context9; _forEachInstanceProperty(_context9 = ["next", "throw", "return"]).call(_context9, function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; defineProperty(this, "_invoke", { value: function value(method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; } function maybeInvokeDelegate(delegate, context) { var methodName = context.method, method = delegate.iterator[methodName]; if (undefined === method) return context.delegate = null, "throw" === methodName && delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method) || "return" !== methodName && (context.method = "throw", context.arg = new TypeError("The iterator does not provide a '" + methodName + "' method")), ContinueSentinel; var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], _forEachInstanceProperty(tryLocsList).call(tryLocsList, pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, defineProperty(Gp, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), defineProperty(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return _Object$setPrototypeOf ? _Object$setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = _Object$create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = _Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (val) { var object = Object(val), keys = []; for (var key in object) keys.push(key); return _reverseInstanceProperty(keys).call(keys), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { var _context10; if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, _forEachInstanceProperty(_context10 = this.tryEntries).call(_context10, resetTryEntry), !skipTempReset) for (var name in this) "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+_sliceInstanceProperty(name).call(name, 1)) && (this[name] = undefined); }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
5
5
  import _URL from "@babel/runtime-corejs3/core-js-stable/url";
6
6
  import _Object$defineProperty from "@babel/runtime-corejs3/core-js-stable/object/define-property";
7
7
  import _Symbol from "@babel/runtime-corejs3/core-js-stable/symbol";
@@ -336,10 +336,43 @@ test('loader size can be changed via the prop', function () {
336
336
  'font-size': "".concat(testLoaderSize, "px")
337
337
  });
338
338
  });
339
- test('should show the menu if label clicked when preview image exists with custom uploads', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6() {
340
- var customUploadProp, customRemoveProp, imagePreview;
339
+ test('should show the menu if label clicked when preview image exists', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee6() {
340
+ var imageUploadButton, imagePreview, imageUploadLabel;
341
341
  return _regeneratorRuntime().wrap(function _callee6$(_context6) {
342
342
  while (1) switch (_context6.prev = _context6.next) {
343
+ case 0:
344
+ getComponent();
345
+ imageUploadButton = screen.getByTestId(testButtonId);
346
+ userEvent.click(imageUploadButton);
347
+ fireEvent.change(screen.getByTestId('image-upload-input'), {
348
+ target: {
349
+ files: [file]
350
+ }
351
+ });
352
+ _context6.next = 6;
353
+ return screen.findByTestId(imageUploadImagePreview);
354
+ case 6:
355
+ imagePreview = _context6.sent;
356
+ expect(imagePreview).toBeInTheDocument();
357
+ expect(imagePreview).toHaveAttribute('src');
358
+
359
+ // Click on the image preview button
360
+ imageUploadLabel = screen.getByText(testLabel);
361
+ fireEvent.click(imageUploadLabel);
362
+ expect(screen.getAllByRole('button')[0]).toHaveAttribute('aria-expanded', 'true');
363
+ expect(screen.getByRole('menu')).toBeInTheDocument();
364
+ expect(screen.getByText('Upload New Image')).toBeInTheDocument();
365
+ expect(screen.getByText('Remove Image')).toBeInTheDocument();
366
+ case 15:
367
+ case "end":
368
+ return _context6.stop();
369
+ }
370
+ }, _callee6);
371
+ })));
372
+ test('should show the menu if label clicked when preview image exists with custom uploads', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7() {
373
+ var customUploadProp, customRemoveProp, imagePreview;
374
+ return _regeneratorRuntime().wrap(function _callee7$(_context7) {
375
+ while (1) switch (_context7.prev = _context7.next) {
343
376
  case 0:
344
377
  customUploadProp = 'Custom Upload';
345
378
  customRemoveProp = 'Custom Remove';
@@ -352,10 +385,10 @@ test('should show the menu if label clicked when preview image exists with custo
352
385
  files: [file]
353
386
  }
354
387
  });
355
- _context6.next = 6;
388
+ _context7.next = 6;
356
389
  return screen.findByTestId(imageUploadImagePreview);
357
390
  case 6:
358
- imagePreview = _context6.sent;
391
+ imagePreview = _context7.sent;
359
392
  expect(imagePreview).toBeInTheDocument();
360
393
  expect(imagePreview).toHaveAttribute('src');
361
394
 
@@ -365,9 +398,9 @@ test('should show the menu if label clicked when preview image exists with custo
365
398
  expect(screen.getByText(customRemoveProp)).toBeInTheDocument();
366
399
  case 12:
367
400
  case "end":
368
- return _context6.stop();
401
+ return _context7.stop();
369
402
  }
370
- }, _callee6);
403
+ }, _callee7);
371
404
  })));
372
405
  test('should render node element if passed as default image', function () {
373
406
  getComponent({
@@ -379,10 +412,10 @@ test('should render node element if passed as default image', function () {
379
412
  expect(img).toBeInstanceOf(HTMLImageElement);
380
413
  expect(img).toBeInTheDocument();
381
414
  });
382
- test('should implement popover menu props', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee7() {
415
+ test('should implement popover menu props', /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee8() {
383
416
  var imagePreview;
384
- return _regeneratorRuntime().wrap(function _callee7$(_context7) {
385
- while (1) switch (_context7.prev = _context7.next) {
417
+ return _regeneratorRuntime().wrap(function _callee8$(_context8) {
418
+ while (1) switch (_context8.prev = _context8.next) {
386
419
  case 0:
387
420
  getComponent({
388
421
  popoverMenuProps: {
@@ -394,10 +427,10 @@ test('should implement popover menu props', /*#__PURE__*/_asyncToGenerator( /*#_
394
427
  files: [file]
395
428
  }
396
429
  });
397
- _context7.next = 4;
430
+ _context8.next = 4;
398
431
  return screen.findByTestId(imageUploadImagePreview);
399
432
  case 4:
400
- imagePreview = _context7.sent;
433
+ imagePreview = _context8.sent;
401
434
  expect(imagePreview).toBeInTheDocument();
402
435
  expect(imagePreview).toHaveAttribute('src');
403
436
 
@@ -408,7 +441,7 @@ test('should implement popover menu props', /*#__PURE__*/_asyncToGenerator( /*#_
408
441
  expect(screen.getByRole('presentation')).toHaveAttribute('data-popover-placement', 'right');
409
442
  case 11:
410
443
  case "end":
411
- return _context7.stop();
444
+ return _context8.stop();
412
445
  }
413
- }, _callee7);
446
+ }, _callee8);
414
447
  })));