UNPKG

683 kBJavaScriptView Raw
1import React__default, { useContext, useState, useEffect, useCallback, useRef, createRef, memo, useMemo, useLayoutEffect, useImperativeHandle, createContext, Component, Fragment, createElement } from 'react';
2import { __rest } from 'tslib';
3import { CaretDownMinor, HorizontalDotsMinor, TickSmallMinor, AlertMinor, CaretUpMinor, CircleCancelMinor, CancelSmallMinor, FlagMajorTwotone, CircleDisabledMajorTwotone, CircleAlertMajorTwotone, CircleInformationMajorTwotone, CircleTickMajorTwotone, ChevronLeftMinor, MinusMinor, ChevronRightMinor, ArrowLeftMinor, ArrowRightMinor, DragDropMajorMonotone, CircleAlertMajorMonotone, SearchMinor, ChevronUpMinor, ChevronDownMinor, QuestionMarkMajorTwotone, MobileCancelMajorMonotone, ExternalSmallMinor, ArrowUpDownMinor, CalendarMinor, EnableSelectionMinor, MobileHamburgerMajorMonotone } from '@shopify/polaris-icons';
4import { FOCUSABLE_SELECTOR, findFirstFocusableNode, focusFirstFocusableNode } from '@shopify/javascript-utilities/focus';
5import { createPortal } from 'react-dom';
6import { createUniqueIDFactory } from '@shopify/javascript-utilities/other';
7import tokens, { durationBase, durationSlow } from '@shopify/polaris-tokens';
8import { colorFactory } from '@shopify/polaris-tokens/dist-modern';
9import { clamp as clamp$1 } from '@shopify/javascript-utilities/math';
10import debounce from 'lodash/debounce';
11import { addEventListener, removeEventListener } from '@shopify/javascript-utilities/events';
12import { closest, nodeContainsDescendant } from '@shopify/javascript-utilities/dom';
13import { getRectForNode, Rect } from '@shopify/javascript-utilities/geometry';
14import { write, read } from '@shopify/javascript-utilities/fastdom';
15import DefaultThemeColors from '@shopify/polaris-tokens/dist-modern/theme/base.json';
16import createApp, { getShopOrigin, LifecycleHook } from '@shopify/app-bridge';
17import isEqual from 'lodash/isEqual';
18import hoistStatics from 'hoist-non-react-statics';
19import { isSameDay, Months, Weekdays, getWeeksForMonth, getNewRange, isDateBefore, isDateAfter, dateIsSelected, dateIsInRange, getNextDisplayYear, getNextDisplayMonth, getPreviousDisplayYear, getPreviousDisplayMonth } from '@shopify/javascript-utilities/dates';
20export { Months } from '@shopify/javascript-utilities/dates';
21import { CSSTransition, TransitionGroup, Transition } from '@material-ui/react-transition-group';
22import { Redirect, ButtonGroup as ButtonGroup$1, Button as Button$1, Modal as Modal$1, Loading as Loading$2, TitleBar, ResourcePicker as ResourcePicker$1, Toast as Toast$2 } from '@shopify/app-bridge/actions';
23
24if (typeof window !== 'undefined') {
25 window.Polaris = window.Polaris || {};
26 window.Polaris.VERSION = '4.14.0';
27}
28
29var polarisVersion = '4.14.0';
30
31var Key;
32
33(function (Key) {
34 Key[Key["Backspace"] = 8] = "Backspace";
35 Key[Key["Tab"] = 9] = "Tab";
36 Key[Key["Enter"] = 13] = "Enter";
37 Key[Key["Shift"] = 16] = "Shift";
38 Key[Key["Ctrl"] = 17] = "Ctrl";
39 Key[Key["Alt"] = 18] = "Alt";
40 Key[Key["Pause"] = 19] = "Pause";
41 Key[Key["CapsLock"] = 20] = "CapsLock";
42 Key[Key["Escape"] = 27] = "Escape";
43 Key[Key["Space"] = 32] = "Space";
44 Key[Key["PageUp"] = 33] = "PageUp";
45 Key[Key["PageDown"] = 34] = "PageDown";
46 Key[Key["End"] = 35] = "End";
47 Key[Key["Home"] = 36] = "Home";
48 Key[Key["LeftArrow"] = 37] = "LeftArrow";
49 Key[Key["UpArrow"] = 38] = "UpArrow";
50 Key[Key["RightArrow"] = 39] = "RightArrow";
51 Key[Key["DownArrow"] = 40] = "DownArrow";
52 Key[Key["Insert"] = 45] = "Insert";
53 Key[Key["Delete"] = 46] = "Delete";
54 Key[Key["Key0"] = 48] = "Key0";
55 Key[Key["Key1"] = 49] = "Key1";
56 Key[Key["Key2"] = 50] = "Key2";
57 Key[Key["Key3"] = 51] = "Key3";
58 Key[Key["Key4"] = 52] = "Key4";
59 Key[Key["Key5"] = 53] = "Key5";
60 Key[Key["Key6"] = 54] = "Key6";
61 Key[Key["Key7"] = 55] = "Key7";
62 Key[Key["Key8"] = 56] = "Key8";
63 Key[Key["Key9"] = 57] = "Key9";
64 Key[Key["KeyA"] = 65] = "KeyA";
65 Key[Key["KeyB"] = 66] = "KeyB";
66 Key[Key["KeyC"] = 67] = "KeyC";
67 Key[Key["KeyD"] = 68] = "KeyD";
68 Key[Key["KeyE"] = 69] = "KeyE";
69 Key[Key["KeyF"] = 70] = "KeyF";
70 Key[Key["KeyG"] = 71] = "KeyG";
71 Key[Key["KeyH"] = 72] = "KeyH";
72 Key[Key["KeyI"] = 73] = "KeyI";
73 Key[Key["KeyJ"] = 74] = "KeyJ";
74 Key[Key["KeyK"] = 75] = "KeyK";
75 Key[Key["KeyL"] = 76] = "KeyL";
76 Key[Key["KeyM"] = 77] = "KeyM";
77 Key[Key["KeyN"] = 78] = "KeyN";
78 Key[Key["KeyO"] = 79] = "KeyO";
79 Key[Key["KeyP"] = 80] = "KeyP";
80 Key[Key["KeyQ"] = 81] = "KeyQ";
81 Key[Key["KeyR"] = 82] = "KeyR";
82 Key[Key["KeyS"] = 83] = "KeyS";
83 Key[Key["KeyT"] = 84] = "KeyT";
84 Key[Key["KeyU"] = 85] = "KeyU";
85 Key[Key["KeyV"] = 86] = "KeyV";
86 Key[Key["KeyW"] = 87] = "KeyW";
87 Key[Key["KeyX"] = 88] = "KeyX";
88 Key[Key["KeyY"] = 89] = "KeyY";
89 Key[Key["KeyZ"] = 90] = "KeyZ";
90 Key[Key["LeftMeta"] = 91] = "LeftMeta";
91 Key[Key["RightMeta"] = 92] = "RightMeta";
92 Key[Key["Select"] = 93] = "Select";
93 Key[Key["Numpad0"] = 96] = "Numpad0";
94 Key[Key["Numpad1"] = 97] = "Numpad1";
95 Key[Key["Numpad2"] = 98] = "Numpad2";
96 Key[Key["Numpad3"] = 99] = "Numpad3";
97 Key[Key["Numpad4"] = 100] = "Numpad4";
98 Key[Key["Numpad5"] = 101] = "Numpad5";
99 Key[Key["Numpad6"] = 102] = "Numpad6";
100 Key[Key["Numpad7"] = 103] = "Numpad7";
101 Key[Key["Numpad8"] = 104] = "Numpad8";
102 Key[Key["Numpad9"] = 105] = "Numpad9";
103 Key[Key["Multiply"] = 106] = "Multiply";
104 Key[Key["Add"] = 107] = "Add";
105 Key[Key["Subtract"] = 109] = "Subtract";
106 Key[Key["Decimal"] = 110] = "Decimal";
107 Key[Key["Divide"] = 111] = "Divide";
108 Key[Key["F1"] = 112] = "F1";
109 Key[Key["F2"] = 113] = "F2";
110 Key[Key["F3"] = 114] = "F3";
111 Key[Key["F4"] = 115] = "F4";
112 Key[Key["F5"] = 116] = "F5";
113 Key[Key["F6"] = 117] = "F6";
114 Key[Key["F7"] = 118] = "F7";
115 Key[Key["F8"] = 119] = "F8";
116 Key[Key["F9"] = 120] = "F9";
117 Key[Key["F10"] = 121] = "F10";
118 Key[Key["F11"] = 122] = "F11";
119 Key[Key["F12"] = 123] = "F12";
120 Key[Key["NumLock"] = 144] = "NumLock";
121 Key[Key["ScrollLock"] = 145] = "ScrollLock";
122 Key[Key["Semicolon"] = 186] = "Semicolon";
123 Key[Key["Equals"] = 187] = "Equals";
124 Key[Key["Comma"] = 188] = "Comma";
125 Key[Key["Dash"] = 189] = "Dash";
126 Key[Key["Period"] = 190] = "Period";
127 Key[Key["ForwardSlash"] = 191] = "ForwardSlash";
128 Key[Key["GraveAccent"] = 192] = "GraveAccent";
129 Key[Key["OpenBracket"] = 219] = "OpenBracket";
130 Key[Key["BackSlash"] = 220] = "BackSlash";
131 Key[Key["CloseBracket"] = 221] = "CloseBracket";
132 Key[Key["SingleQuote"] = 222] = "SingleQuote";
133})(Key || (Key = {}));
134
135var TypeOf;
136
137(function (TypeOf) {
138 TypeOf["Undefined"] = "undefined";
139 TypeOf["Object"] = "object";
140 TypeOf["Boolean"] = "boolean";
141 TypeOf["Number"] = "number";
142 TypeOf["String"] = "string";
143 TypeOf["Symbol"] = "symbol";
144 TypeOf["Function"] = "function";
145})(TypeOf || (TypeOf = {}));
146
147function _classCallCheck(instance, Constructor) {
148 if (!(instance instanceof Constructor)) {
149 throw new TypeError("Cannot call a class as a function");
150 }
151}
152
153function _defineProperties(target, props) {
154 for (var i = 0; i < props.length; i++) {
155 var descriptor = props[i];
156 descriptor.enumerable = descriptor.enumerable || false;
157 descriptor.configurable = true;
158 if ("value" in descriptor) descriptor.writable = true;
159 Object.defineProperty(target, descriptor.key, descriptor);
160 }
161}
162
163function _createClass(Constructor, protoProps, staticProps) {
164 if (protoProps) _defineProperties(Constructor.prototype, protoProps);
165 if (staticProps) _defineProperties(Constructor, staticProps);
166 return Constructor;
167}
168
169function _inherits(subClass, superClass) {
170 if (typeof superClass !== "function" && superClass !== null) {
171 throw new TypeError("Super expression must either be null or a function");
172 }
173
174 subClass.prototype = Object.create(superClass && superClass.prototype, {
175 constructor: {
176 value: subClass,
177 writable: true,
178 configurable: true
179 }
180 });
181 if (superClass) _setPrototypeOf(subClass, superClass);
182}
183
184function _getPrototypeOf(o) {
185 _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
186 return o.__proto__ || Object.getPrototypeOf(o);
187 };
188 return _getPrototypeOf(o);
189}
190
191function _setPrototypeOf(o, p) {
192 _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
193 o.__proto__ = p;
194 return o;
195 };
196
197 return _setPrototypeOf(o, p);
198}
199
200function isNativeReflectConstruct() {
201 if (typeof Reflect === "undefined" || !Reflect.construct) return false;
202 if (Reflect.construct.sham) return false;
203 if (typeof Proxy === "function") return true;
204
205 try {
206 Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
207 return true;
208 } catch (e) {
209 return false;
210 }
211}
212
213function _construct(Parent, args, Class) {
214 if (isNativeReflectConstruct()) {
215 _construct = Reflect.construct;
216 } else {
217 _construct = function _construct(Parent, args, Class) {
218 var a = [null];
219 a.push.apply(a, args);
220 var Constructor = Function.bind.apply(Parent, a);
221 var instance = new Constructor();
222 if (Class) _setPrototypeOf(instance, Class.prototype);
223 return instance;
224 };
225 }
226
227 return _construct.apply(null, arguments);
228}
229
230function _isNativeFunction(fn) {
231 return Function.toString.call(fn).indexOf("[native code]") !== -1;
232}
233
234function _wrapNativeSuper(Class) {
235 var _cache = typeof Map === "function" ? new Map() : undefined;
236
237 _wrapNativeSuper = function _wrapNativeSuper(Class) {
238 if (Class === null || !_isNativeFunction(Class)) return Class;
239
240 if (typeof Class !== "function") {
241 throw new TypeError("Super expression must either be null or a function");
242 }
243
244 if (typeof _cache !== "undefined") {
245 if (_cache.has(Class)) return _cache.get(Class);
246
247 _cache.set(Class, Wrapper);
248 }
249
250 function Wrapper() {
251 return _construct(Class, arguments, _getPrototypeOf(this).constructor);
252 }
253
254 Wrapper.prototype = Object.create(Class.prototype, {
255 constructor: {
256 value: Wrapper,
257 enumerable: false,
258 writable: true,
259 configurable: true
260 }
261 });
262 return _setPrototypeOf(Wrapper, Class);
263 };
264
265 return _wrapNativeSuper(Class);
266}
267
268function _assertThisInitialized(self) {
269 if (self === void 0) {
270 throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
271 }
272
273 return self;
274}
275
276function _possibleConstructorReturn(self, call) {
277 if (call && (typeof call === "object" || typeof call === "function")) {
278 return call;
279 }
280
281 return _assertThisInitialized(self);
282}
283
284function _slicedToArray(arr, i) {
285 return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest();
286}
287
288function _toConsumableArray(arr) {
289 return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();
290}
291
292function _arrayWithoutHoles(arr) {
293 if (Array.isArray(arr)) {
294 for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];
295
296 return arr2;
297 }
298}
299
300function _arrayWithHoles(arr) {
301 if (Array.isArray(arr)) return arr;
302}
303
304function _iterableToArray(iter) {
305 if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
306}
307
308function _iterableToArrayLimit(arr, i) {
309 if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) {
310 return;
311 }
312
313 var _arr = [];
314 var _n = true;
315 var _d = false;
316 var _e = undefined;
317
318 try {
319 for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
320 _arr.push(_s.value);
321
322 if (i && _arr.length === i) break;
323 }
324 } catch (err) {
325 _d = true;
326 _e = err;
327 } finally {
328 try {
329 if (!_n && _i["return"] != null) _i["return"]();
330 } finally {
331 if (_d) throw _e;
332 }
333 }
334
335 return _arr;
336}
337
338function _nonIterableSpread() {
339 throw new TypeError("Invalid attempt to spread non-iterable instance");
340}
341
342function _nonIterableRest() {
343 throw new TypeError("Invalid attempt to destructure non-iterable instance");
344}
345
346function classNames() {
347 for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) {
348 classes[_key] = arguments[_key];
349 }
350
351 return classes.filter(Boolean).join(' ');
352}
353function variationName(name, value) {
354 return "".concat(name).concat(value.charAt(0).toUpperCase()).concat(value.slice(1));
355}
356
357var FeaturesContext = React__default.createContext(undefined);
358
359function useFeatures() {
360 var features = useContext(FeaturesContext);
361
362 if (!features) {
363 throw new Error('No Features were provided.');
364 }
365
366 return features;
367}
368
369var I18nContext = React__default.createContext(undefined);
370
371var MissingAppProviderError =
372/*#__PURE__*/
373function (_Error) {
374 _inherits(MissingAppProviderError, _Error);
375
376 function MissingAppProviderError() {
377 var _this;
378
379 var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
380
381 _classCallCheck(this, MissingAppProviderError);
382
383 _this = _possibleConstructorReturn(this, _getPrototypeOf(MissingAppProviderError).call(this, "".concat(message ? "".concat(message, " ") : message, "Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.")));
384 _this.name = 'MissingAppProviderError';
385 return _this;
386 }
387
388 return MissingAppProviderError;
389}(_wrapNativeSuper(Error));
390
391function useI18n() {
392 var i18n = useContext(I18nContext);
393
394 if (!i18n) {
395 throw new MissingAppProviderError('No i18n was provided.');
396 }
397
398 return i18n;
399}
400
401var OBJECT_NOTATION_MATCHER = /\[(.*?)\]|(\w+)/g;
402function get(obj, keypath, defaultValue) {
403 if (obj == null) return undefined;
404 var keys = Array.isArray(keypath) ? keypath : getKeypath(keypath);
405 var acc = obj; // eslint-disable-next-line @typescript-eslint/prefer-for-of
406
407 for (var i = 0; i < keys.length; i++) {
408 var val = acc[keys[i]];
409 if (val === undefined) return defaultValue;
410 acc = val;
411 }
412
413 return acc;
414}
415
416function getKeypath(str) {
417 var path = [];
418 var result;
419
420 while (result = OBJECT_NOTATION_MATCHER.exec(str)) {
421 var _result = result,
422 _result2 = _slicedToArray(_result, 3),
423 first = _result2[1],
424 second = _result2[2];
425
426 path.push(first || second);
427 }
428
429 return path;
430}
431
432function merge() {
433 var final = {};
434
435 for (var _len = arguments.length, objs = new Array(_len), _key = 0; _key < _len; _key++) {
436 objs[_key] = arguments[_key];
437 }
438
439 for (var _i = 0, _objs = objs; _i < _objs.length; _i++) {
440 var obj = _objs[_i];
441 final = mergeRecursively(final, obj);
442 }
443
444 return final;
445}
446
447function mergeRecursively(inputObjA, objB) {
448 var objA = Array.isArray(inputObjA) ? _toConsumableArray(inputObjA) : Object.assign({}, inputObjA);
449
450 for (var key in objB) {
451 if (!Object.prototype.hasOwnProperty.call(objB, key)) {
452 continue;
453 } else if (isMergeableValue(objB[key]) && isMergeableValue(objA[key])) {
454 objA[key] = mergeRecursively(objA[key], objB[key]);
455 } else {
456 objA[key] = objB[key];
457 }
458 }
459
460 return objA;
461}
462
463function isMergeableValue(value) {
464 return value !== null && typeof value === 'object';
465}
466
467var REPLACE_REGEX = /{([^}]*)}/g;
468var I18n =
469/*#__PURE__*/
470function () {
471 /**
472 * @param translation A locale object or array of locale objects that overrides default translations. If specifying an array then your fallback language dictionaries should come first, followed by your primary language dictionary
473 */
474 function I18n(translation) {
475 _classCallCheck(this, I18n);
476
477 this.translation = {};
478 this.translation = Array.isArray(translation) ? merge.apply(void 0, _toConsumableArray(translation)) : translation;
479 }
480
481 _createClass(I18n, [{
482 key: "translate",
483 value: function translate(id, replacements) {
484 var text = get(this.translation, id, '');
485
486 if (!text) {
487 return '';
488 }
489
490 if (replacements) {
491 return text.replace(REPLACE_REGEX, function (match) {
492 var replacement = match.substring(1, match.length - 1);
493
494 if (replacements[replacement] === undefined) {
495 var replacementData = JSON.stringify(replacements);
496 throw new Error("Error in translation for key '".concat(id, "'. No replacement found for key '").concat(replacement, "'. The following replacements were passed: '").concat(replacementData, "'"));
497 } // This could be a string or a number, but JS doesn't mind which it gets
498 // and can handle that cast internally. So let it, to save us calling
499 // toString() on what's already a string in 90% of cases.
500
501
502 return replacements[replacement];
503 });
504 }
505
506 return text;
507 }
508 }, {
509 key: "translationKeyExists",
510 value: function translationKeyExists(path) {
511 return Boolean(get(this.translation, path));
512 }
513 }]);
514
515 return I18n;
516}();
517
518/**
519 * useIsAfterInitialMount will trigger a re-render to provide
520 * you with an updated value. Using this you enhance server-side
521 * code that can only run on the client.
522 * @returns MutableRefObject<T> - Returns a ref object with the
523 * results from invoking initial value
524 * @example
525 * function ComponentExample({children}) {
526 * const isMounted = useIsAfterInitialMount();
527 * const content = isMounted ? children : null;
528 *
529 * return <React.Fragment>{content}</React.Fragment>;
530 * }
531 */
532
533function useIsAfterInitialMount() {
534 var _useState = useState(false),
535 _useState2 = _slicedToArray(_useState, 2),
536 isAfterInitialMount = _useState2[0],
537 setIsAfterInitialMount = _useState2[1];
538
539 useEffect(function () {
540 setIsAfterInitialMount(true);
541 }, []);
542 return isAfterInitialMount;
543}
544
545function Image(_a) {
546 var sourceSet = _a.sourceSet,
547 source = _a.source,
548 crossOrigin = _a.crossOrigin,
549 rest = __rest(_a, ["sourceSet", "source", "crossOrigin"]);
550
551 var finalSourceSet = sourceSet ? sourceSet.map(function (_ref) {
552 var subSource = _ref.source,
553 descriptor = _ref.descriptor;
554 return "".concat(subSource, " ").concat(descriptor);
555 }).join(',') : null;
556 return finalSourceSet ? // eslint-disable-next-line jsx-a11y/alt-text
557 React__default.createElement("img", Object.assign({
558 src: source,
559 srcSet: finalSourceSet,
560 crossOrigin: crossOrigin
561 }, rest)) : // eslint-disable-next-line jsx-a11y/alt-text
562 React__default.createElement("img", Object.assign({
563 src: source
564 }, rest, {
565 crossOrigin: crossOrigin
566 }));
567}
568
569var styles = {
570 "Avatar": "Polaris-Avatar",
571 "hidden": "Polaris-Avatar--hidden",
572 "sizeSmall": "Polaris-Avatar--sizeSmall",
573 "sizeMedium": "Polaris-Avatar--sizeMedium",
574 "sizeLarge": "Polaris-Avatar--sizeLarge",
575 "styleOne": "Polaris-Avatar--styleOne",
576 "styleTwo": "Polaris-Avatar--styleTwo",
577 "styleThree": "Polaris-Avatar--styleThree",
578 "styleFour": "Polaris-Avatar--styleFour",
579 "styleFive": "Polaris-Avatar--styleFive",
580 "styleSix": "Polaris-Avatar--styleSix",
581 "hasImage": "Polaris-Avatar--hasImage",
582 "Image": "Polaris-Avatar__Image",
583 "Initials": "Polaris-Avatar__Initials",
584 "Svg": "Polaris-Avatar__Svg"
585};
586
587var Status;
588
589(function (Status) {
590 Status["Pending"] = "PENDING";
591 Status["Loaded"] = "LOADED";
592 Status["Errored"] = "ERRORED";
593})(Status || (Status = {}));
594
595var STYLE_CLASSES = ['one', 'two', 'three', 'four', 'five'];
596function Avatar(_ref) {
597 var name = _ref.name,
598 source = _ref.source,
599 initials = _ref.initials,
600 customer = _ref.customer,
601 _ref$size = _ref.size,
602 size = _ref$size === void 0 ? 'medium' : _ref$size,
603 accessibilityLabel = _ref.accessibilityLabel;
604 var i18n = useI18n();
605
606 var _useFeatures = useFeatures(),
607 newDesignLanguage = _useFeatures.newDesignLanguage;
608
609 var isAfterInitialMount = useIsAfterInitialMount();
610
611 function styleClass(name) {
612 var finalStyleClasses = newDesignLanguage ? STYLE_CLASSES : [].concat(STYLE_CLASSES, ['six']);
613 return name ? finalStyleClasses[name.charCodeAt(0) % finalStyleClasses.length] : finalStyleClasses[0];
614 }
615
616 var _useState = useState(Status.Pending),
617 _useState2 = _slicedToArray(_useState, 2),
618 status = _useState2[0],
619 setStatus = _useState2[1]; // If the source changes, set the status back to pending
620
621
622 useEffect(function () {
623 setStatus(Status.Pending);
624 }, [source]);
625 var handleError = useCallback(function () {
626 setStatus(Status.Errored);
627 }, []);
628 var handleLoad = useCallback(function () {
629 setStatus(Status.Loaded);
630 }, []);
631 var hasImage = source && status !== Status.Errored;
632 var nameString = name || initials;
633 var label;
634
635 if (accessibilityLabel) {
636 label = accessibilityLabel;
637 } else if (name) {
638 label = name;
639 } else if (initials) {
640 var splitInitials = initials.split('').join(' ');
641 label = i18n.translate('Polaris.Avatar.labelWithInitials', {
642 initials: splitInitials
643 });
644 } else {
645 label = i18n.translate('Polaris.Avatar.label');
646 }
647
648 var className = classNames(styles.Avatar, size && styles[variationName('size', size)], !customer && styles[variationName('style', styleClass(nameString))], (hasImage || initials && initials.length === 0) && status !== Status.Loaded && styles.hidden, hasImage && styles.hasImage);
649 var imageMarkUp = source && isAfterInitialMount && status !== Status.Errored ? React__default.createElement(Image, {
650 className: styles.Image,
651 source: source,
652 alt: "",
653 role: "presentation",
654 onLoad: handleLoad,
655 onError: handleError
656 }) : null; // Use `dominant-baseline: central` instead of `dy` when Edge supports it.
657
658 var verticalOffset = '0.35em';
659 var avatarBody = customer || !initials ? React__default.createElement("path", {
660 fill: "currentColor",
661 d: "M8.28 27.5A14.95 14.95 0 0120 21.8c4.76 0 8.97 2.24 11.72 5.7a14.02 14.02 0 01-8.25 5.91 14.82 14.82 0 01-6.94 0 14.02 14.02 0 01-8.25-5.9zM13.99 12.78a6.02 6.02 0 1112.03 0 6.02 6.02 0 01-12.03 0z"
662 }) : React__default.createElement("text", {
663 x: "50%",
664 y: "50%",
665 dy: verticalOffset,
666 fill: "currentColor",
667 fontSize: "20",
668 textAnchor: "middle"
669 }, initials);
670 var svgMarkup = !hasImage ? React__default.createElement("span", {
671 className: styles.Initials
672 }, React__default.createElement("svg", {
673 className: styles.Svg,
674 viewBox: "0 0 40 40"
675 }, avatarBody)) : null;
676 return React__default.createElement("span", {
677 "aria-label": label,
678 role: "img",
679 className: className
680 }, svgMarkup, imageMarkUp);
681}
682
683function isElementInViewport(element) {
684 var _element$getBoundingC = element.getBoundingClientRect(),
685 top = _element$getBoundingC.top,
686 left = _element$getBoundingC.left,
687 bottom = _element$getBoundingC.bottom,
688 right = _element$getBoundingC.right;
689
690 return top >= 0 && right <= window.innerWidth && bottom <= window.innerHeight && left >= 0;
691}
692
693var KEYBOARD_FOCUSABLE_SELECTORS = 'a,frame,iframe,input:not([type=hidden]):not(:disabled),select:not(:disabled),textarea:not(:disabled),button:not(:disabled),*[tabindex]:not([tabindex="-1"])';
694function handleMouseUpByBlurring(_ref) {
695 var currentTarget = _ref.currentTarget;
696 currentTarget.blur();
697}
698function nextFocusableNode(node, filter) {
699 var allFocusableElements = _toConsumableArray(document.querySelectorAll(FOCUSABLE_SELECTOR));
700
701 var sliceLocation = allFocusableElements.indexOf(node) + 1;
702 var focusableElementsAfterNode = allFocusableElements.slice(sliceLocation);
703 var _iteratorNormalCompletion = true;
704 var _didIteratorError = false;
705 var _iteratorError = undefined;
706
707 try {
708 for (var _iterator = focusableElementsAfterNode[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
709 var focusableElement = _step.value;
710
711 if (isElementInViewport(focusableElement) && (!filter || filter && filter(focusableElement))) {
712 return focusableElement;
713 }
714 }
715 } catch (err) {
716 _didIteratorError = true;
717 _iteratorError = err;
718 } finally {
719 try {
720 if (!_iteratorNormalCompletion && _iterator.return != null) {
721 _iterator.return();
722 }
723 } finally {
724 if (_didIteratorError) {
725 throw _iteratorError;
726 }
727 }
728 }
729
730 return null;
731}
732function focusNextFocusableNode(node, filter) {
733 var nextFocusable = nextFocusableNode(node, filter);
734
735 if (nextFocusable && nextFocusable instanceof HTMLElement) {
736 nextFocusable.focus();
737 return true;
738 }
739
740 return false;
741} // https://github.com/Shopify/javascript-utilities/blob/1e705564643d6fe7ffea5ebfbbf3e6b759a66c9b/src/focus.ts
742
743function findFirstKeyboardFocusableNode(element) {
744 var onlyDescendants = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
745
746 if (!onlyDescendants && matches(element, KEYBOARD_FOCUSABLE_SELECTORS)) {
747 return element;
748 }
749
750 return element.querySelector(KEYBOARD_FOCUSABLE_SELECTORS);
751}
752function focusFirstKeyboardFocusableNode(element) {
753 var onlyDescendants = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
754 var firstFocusable = findFirstKeyboardFocusableNode(element, onlyDescendants);
755
756 if (firstFocusable) {
757 firstFocusable.focus();
758 return true;
759 }
760
761 return false;
762}
763function findLastKeyboardFocusableNode(element) {
764 var onlyDescendants = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
765
766 if (!onlyDescendants && matches(element, KEYBOARD_FOCUSABLE_SELECTORS)) {
767 return element;
768 }
769
770 var allFocusable = element.querySelectorAll(KEYBOARD_FOCUSABLE_SELECTORS);
771 return allFocusable[allFocusable.length - 1];
772}
773function focusLastKeyboardFocusableNode(element) {
774 var onlyDescendants = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
775 var lastFocusable = findLastKeyboardFocusableNode(element, onlyDescendants);
776
777 if (lastFocusable) {
778 lastFocusable.focus();
779 return true;
780 }
781
782 return false;
783}
784
785function matches(node, selector) {
786 if (node.matches) {
787 return node.matches(selector);
788 }
789
790 var matches = (node.ownerDocument || document).querySelectorAll(selector);
791 var i = matches.length;
792
793 while (--i >= 0 && matches.item(i) !== node) {
794 return i > -1;
795 }
796}
797
798var scrollable = {
799 props: {
800 'data-polaris-scrollable': true
801 },
802 selector: '[data-polaris-scrollable]'
803};
804var overlay = {
805 props: {
806 'data-polaris-overlay': true
807 },
808 selector: '[data-polaris-overlay]'
809};
810var layer = {
811 props: {
812 'data-polaris-layer': true
813 },
814 selector: '[data-polaris-layer]'
815};
816var unstyled = {
817 props: {
818 'data-polaris-unstyled': true
819 },
820 selector: '[data-polaris-unstyled]'
821};
822var dataPolarisTopBar = {
823 props: {
824 'data-polaris-top-bar': true
825 },
826 selector: '[data-polaris-top-bar]'
827};
828var headerCell = {
829 props: {
830 'data-polaris-header-cell': true
831 },
832 selector: '[data-polaris-header-cell]'
833};
834var portal = {
835 props: ['data-portal-id'],
836 selector: '[data-portal-id]'
837};
838var DATA_ATTRIBUTE = {
839 overlay,
840 layer
841};
842
843var LinkContext = React__default.createContext(undefined);
844
845function useLink() {
846 return React__default.useContext(LinkContext);
847}
848
849// https://github.com/facebook/react/issues/16722
850// but eslint-plugin-react doesn't know that just yet
851// eslint-disable-next-line react/display-name
852
853var UnstyledLink = React__default.memo(React__default.forwardRef(function UnstyledLink(props, _ref) {
854 var LinkComponent = useLink();
855
856 if (LinkComponent) {
857 return React__default.createElement(LinkComponent, Object.assign({}, unstyled.props, props));
858 }
859
860 var external = props.external,
861 url = props.url,
862 rest = __rest(props, ["external", "url"]);
863
864 var target = external ? '_blank' : undefined;
865 var rel = external ? 'noopener noreferrer' : undefined;
866 return React__default.createElement("a", Object.assign({
867 target: target
868 }, rest, {
869 href: url,
870 rel: rel
871 }, unstyled.props));
872}));
873
874var styles$1 = {
875 "Icon": "Polaris-Icon",
876 "hasBackdrop": "Polaris-Icon--hasBackdrop",
877 "isColored": "Polaris-Icon--isColored",
878 "colorWhite": "Polaris-Icon--colorWhite",
879 "colorBlack": "Polaris-Icon--colorBlack",
880 "colorSkyLighter": "Polaris-Icon--colorSkyLighter",
881 "colorSkyLight": "Polaris-Icon--colorSkyLight",
882 "colorSky": "Polaris-Icon--colorSky",
883 "colorSkyDark": "Polaris-Icon--colorSkyDark",
884 "colorInkLightest": "Polaris-Icon--colorInkLightest",
885 "colorInkLighter": "Polaris-Icon--colorInkLighter",
886 "colorInkLight": "Polaris-Icon--colorInkLight",
887 "colorInk": "Polaris-Icon--colorInk",
888 "colorBlueLighter": "Polaris-Icon--colorBlueLighter",
889 "colorBlueLight": "Polaris-Icon--colorBlueLight",
890 "colorBlue": "Polaris-Icon--colorBlue",
891 "colorBlueDark": "Polaris-Icon--colorBlueDark",
892 "colorBlueDarker": "Polaris-Icon--colorBlueDarker",
893 "colorIndigoLighter": "Polaris-Icon--colorIndigoLighter",
894 "colorIndigoLight": "Polaris-Icon--colorIndigoLight",
895 "colorIndigo": "Polaris-Icon--colorIndigo",
896 "colorIndigoDark": "Polaris-Icon--colorIndigoDark",
897 "colorIndigoDarker": "Polaris-Icon--colorIndigoDarker",
898 "colorTealLighter": "Polaris-Icon--colorTealLighter",
899 "colorTealLight": "Polaris-Icon--colorTealLight",
900 "colorTeal": "Polaris-Icon--colorTeal",
901 "colorTealDark": "Polaris-Icon--colorTealDark",
902 "colorTealDarker": "Polaris-Icon--colorTealDarker",
903 "colorGreenLighter": "Polaris-Icon--colorGreenLighter",
904 "colorGreen": "Polaris-Icon--colorGreen",
905 "colorGreenDark": "Polaris-Icon--colorGreenDark",
906 "colorYellowLighter": "Polaris-Icon--colorYellowLighter",
907 "colorYellow": "Polaris-Icon--colorYellow",
908 "colorYellowDark": "Polaris-Icon--colorYellowDark",
909 "colorOrange": "Polaris-Icon--colorOrange",
910 "colorOrangeDark": "Polaris-Icon--colorOrangeDark",
911 "colorRedLighter": "Polaris-Icon--colorRedLighter",
912 "colorRed": "Polaris-Icon--colorRed",
913 "colorRedDark": "Polaris-Icon--colorRedDark",
914 "colorPurple": "Polaris-Icon--colorPurple",
915 "Svg": "Polaris-Icon__Svg",
916 "Img": "Polaris-Icon__Img",
917 "Placeholder": "Polaris-Icon__Placeholder"
918};
919
920var COLORS_WITH_BACKDROPS = ['teal', 'tealDark', 'greenDark', 'redDark', 'yellowDark', 'ink', 'inkLighter'];
921function Icon(_ref) {
922 var source = _ref.source,
923 color = _ref.color,
924 backdrop = _ref.backdrop,
925 accessibilityLabel = _ref.accessibilityLabel;
926 var i18n = useI18n();
927
928 if (color && backdrop && !COLORS_WITH_BACKDROPS.includes(color)) {
929 // eslint-disable-next-line no-console
930 console.warn(i18n.translate('Polaris.Icon.backdropWarning', {
931 color,
932 colorsWithBackDrops: COLORS_WITH_BACKDROPS.join(', ')
933 }));
934 }
935
936 var className = classNames(styles$1.Icon, color && styles$1[variationName('color', color)], color && color !== 'white' && styles$1.isColored, backdrop && styles$1.hasBackdrop);
937 var contentMarkup;
938
939 if (typeof source === 'function') {
940 var SourceComponent = source;
941 contentMarkup = React__default.createElement(SourceComponent, {
942 className: styles$1.Svg,
943 focusable: "false",
944 "aria-hidden": "true"
945 });
946 } else if (source === 'placeholder') {
947 contentMarkup = React__default.createElement("div", {
948 className: styles$1.Placeholder
949 });
950 } else {
951 contentMarkup = React__default.createElement("img", {
952 className: styles$1.Img,
953 src: "data:image/svg+xml;utf8,".concat(source),
954 alt: "",
955 "aria-hidden": "true"
956 });
957 }
958
959 return React__default.createElement("span", {
960 className: className,
961 "aria-label": accessibilityLabel
962 }, contentMarkup);
963}
964
965var styles$2 = {
966 "VisuallyHidden": "Polaris-VisuallyHidden"
967};
968
969function VisuallyHidden(_ref) {
970 var children = _ref.children;
971 return React__default.createElement("span", {
972 className: styles$2.VisuallyHidden
973 }, children);
974}
975
976var styles$3 = {
977 "Spinner": "Polaris-Spinner",
978 "loading": "Polaris-Spinner--loading",
979 "sizeSmall": "Polaris-Spinner--sizeSmall",
980 "sizeLarge": "Polaris-Spinner--sizeLarge",
981 "colorWhite": "Polaris-Spinner--colorWhite",
982 "colorTeal": "Polaris-Spinner--colorTeal",
983 "colorInkLightest": "Polaris-Spinner--colorInkLightest"
984};
985
986var spinnerLarge = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgNDQgNDQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTE1LjU0MiAxLjQ4N0EyMS41MDcgMjEuNTA3IDAgMDAuNSAyMmMwIDExLjg3NCA5LjYyNiAyMS41IDIxLjUgMjEuNSA5Ljg0NyAwIDE4LjM2NC02LjY3NSAyMC44MDktMTYuMDcyYTEuNSAxLjUgMCAwMC0yLjkwNC0uNzU2QzM3LjgwMyAzNC43NTUgMzAuNDczIDQwLjUgMjIgNDAuNSAxMS43ODMgNDAuNSAzLjUgMzIuMjE3IDMuNSAyMmMwLTguMTM3IDUuMy0xNS4yNDcgMTIuOTQyLTE3LjY1YTEuNSAxLjUgMCAxMC0uOS0yLjg2M3oiIGZpbGw9IiM5MTlFQUIiLz48L3N2Zz4K';
987
988var spinnerSmall = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjAgMjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTcuMjI5IDEuMTczYTkuMjUgOS4yNSAwIDEwMTEuNjU1IDExLjQxMiAxLjI1IDEuMjUgMCAxMC0yLjQtLjY5OCA2Ljc1IDYuNzUgMCAxMS04LjUwNi04LjMyOSAxLjI1IDEuMjUgMCAxMC0uNzUtMi4zODV6IiBmaWxsPSIjOTE5RUFCIi8+PC9zdmc+Cg==';
989
990var COLORS_FOR_LARGE_SPINNER = ['teal', 'inkLightest'];
991function Spinner(_ref) {
992 var _ref$size = _ref.size,
993 size = _ref$size === void 0 ? 'large' : _ref$size,
994 _ref$color = _ref.color,
995 color = _ref$color === void 0 ? 'teal' : _ref$color,
996 accessibilityLabel = _ref.accessibilityLabel,
997 hasFocusableParent = _ref.hasFocusableParent;
998 var i18n = useI18n();
999 var isAfterInitialMount = useIsAfterInitialMount();
1000
1001 if (size === 'large' && !COLORS_FOR_LARGE_SPINNER.includes(color)) {
1002 if (process.env.NODE_ENV === 'development') {
1003 // eslint-disable-next-line no-console
1004 console.warn(i18n.translate('Polaris.Spinner.warningMessage', {
1005 color,
1006 size,
1007 colors: COLORS_FOR_LARGE_SPINNER.join(', ')
1008 }));
1009 } // eslint-disable-next-line no-param-reassign
1010
1011
1012 size = 'small';
1013 }
1014
1015 var className = classNames(styles$3.Spinner, color && styles$3[variationName('color', color)], size && styles$3[variationName('size', size)]);
1016 var spinnerSVG = size === 'large' ? spinnerLarge : spinnerSmall;
1017 var spanAttributes = Object.assign({}, !hasFocusableParent && {
1018 role: 'status'
1019 });
1020 var accessibilityLabelMarkup = (isAfterInitialMount || !hasFocusableParent) && React__default.createElement(VisuallyHidden, null, accessibilityLabel);
1021 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Image, {
1022 alt: "",
1023 source: spinnerSVG,
1024 className: className,
1025 draggable: false
1026 }), React__default.createElement("span", spanAttributes, accessibilityLabelMarkup));
1027}
1028
1029var ThemeContext = React__default.createContext(undefined);
1030
1031function useTheme() {
1032 var theme = useContext(ThemeContext);
1033
1034 if (!theme) {
1035 throw new MissingAppProviderError('No Theme was provided.');
1036 }
1037
1038 return theme;
1039}
1040
1041function compose() {
1042 for (var _len = arguments.length, fns = new Array(_len), _key = 0; _key < _len; _key++) {
1043 fns[_key] = arguments[_key];
1044 }
1045
1046 return fns.reduce(function (func, group) {
1047 return function () {
1048 return func(group.apply(void 0, arguments));
1049 };
1050 });
1051}
1052
1053function rgbString(color) {
1054 var red = color.red,
1055 green = color.green,
1056 blue = color.blue;
1057
1058 if (Object.prototype.hasOwnProperty.call(color, 'alpha')) {
1059 return "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(color.alpha, ")");
1060 } else {
1061 return "rgb(".concat(red, ", ").concat(green, ", ").concat(blue, ")");
1062 }
1063}
1064var rgbaString = rgbString;
1065function rgbToHex(_ref) {
1066 var red = _ref.red,
1067 green = _ref.green,
1068 blue = _ref.blue;
1069 return "#".concat(componentToHex(red)).concat(componentToHex(green)).concat(componentToHex(blue));
1070}
1071
1072function componentToHex(component) {
1073 var hex = component.toString(16);
1074 return hex.length === 1 ? "0".concat(hex) : hex;
1075}
1076
1077function hsbToHex(color) {
1078 return rgbToHex(hsbToRgb(color));
1079}
1080
1081function rgbFromHueAndChroma(hue, chroma) {
1082 var huePrime = hue / 60;
1083 var hueDelta = 1 - Math.abs(huePrime % 2 - 1);
1084 var intermediateValue = chroma * hueDelta;
1085 var red = 0;
1086 var green = 0;
1087 var blue = 0;
1088
1089 if (huePrime >= 0 && huePrime <= 1) {
1090 red = chroma;
1091 green = intermediateValue;
1092 blue = 0;
1093 }
1094
1095 if (huePrime >= 1 && huePrime <= 2) {
1096 red = intermediateValue;
1097 green = chroma;
1098 blue = 0;
1099 }
1100
1101 if (huePrime >= 2 && huePrime <= 3) {
1102 red = 0;
1103 green = chroma;
1104 blue = intermediateValue;
1105 }
1106
1107 if (huePrime >= 3 && huePrime <= 4) {
1108 red = 0;
1109 green = intermediateValue;
1110 blue = chroma;
1111 }
1112
1113 if (huePrime >= 4 && huePrime <= 5) {
1114 red = intermediateValue;
1115 green = 0;
1116 blue = chroma;
1117 }
1118
1119 if (huePrime >= 5 && huePrime <= 6) {
1120 red = chroma;
1121 green = 0;
1122 blue = intermediateValue;
1123 }
1124
1125 return {
1126 red,
1127 green,
1128 blue
1129 };
1130}
1131
1132function hsbToRgb(color) {
1133 var hue = color.hue,
1134 saturation = color.saturation,
1135 brightness = color.brightness,
1136 _color$alpha = color.alpha,
1137 alpha = _color$alpha === void 0 ? 1 : _color$alpha;
1138 var chroma = brightness * saturation;
1139
1140 var _rgbFromHueAndChroma = rgbFromHueAndChroma(hue, chroma),
1141 red = _rgbFromHueAndChroma.red,
1142 green = _rgbFromHueAndChroma.green,
1143 blue = _rgbFromHueAndChroma.blue;
1144
1145 var chromaBrightnessDelta = brightness - chroma;
1146 red += chromaBrightnessDelta;
1147 green += chromaBrightnessDelta;
1148 blue += chromaBrightnessDelta;
1149 return {
1150 red: Math.round(red * 255),
1151 green: Math.round(green * 255),
1152 blue: Math.round(blue * 255),
1153 alpha
1154 };
1155}
1156function hslToRgb(color) {
1157 var hue = color.hue,
1158 saturation = color.saturation,
1159 lightness = color.lightness,
1160 _color$alpha2 = color.alpha,
1161 alpha = _color$alpha2 === void 0 ? 1 : _color$alpha2;
1162 var chroma = (1 - Math.abs(2 * (lightness / 100) - 1)) * (saturation / 100);
1163
1164 var _rgbFromHueAndChroma2 = rgbFromHueAndChroma(hue, chroma),
1165 red = _rgbFromHueAndChroma2.red,
1166 green = _rgbFromHueAndChroma2.green,
1167 blue = _rgbFromHueAndChroma2.blue;
1168
1169 var lightnessVal = lightness / 100 - chroma / 2;
1170 red += lightnessVal;
1171 green += lightnessVal;
1172 blue += lightnessVal;
1173 return {
1174 red: Math.round(red * 255),
1175 green: Math.round(green * 255),
1176 blue: Math.round(blue * 255),
1177 alpha
1178 };
1179} // ref https://en.wikipedia.org/wiki/HSL_and_HSV
1180
1181function rgbToHsbl(color) {
1182 var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'b';
1183 var r = color.red,
1184 g = color.green,
1185 b = color.blue,
1186 _color$alpha3 = color.alpha,
1187 alpha = _color$alpha3 === void 0 ? 1 : _color$alpha3;
1188 var red = r / 255;
1189 var green = g / 255;
1190 var blue = b / 255;
1191 var largestComponent = Math.max(red, green, blue);
1192 var smallestComponent = Math.min(red, green, blue);
1193 var delta = largestComponent - smallestComponent;
1194 var lightness = (largestComponent + smallestComponent) / 2;
1195 var saturation = 0;
1196
1197 if (largestComponent === 0) {
1198 saturation = 0;
1199 } else if (type === 'b') {
1200 saturation = delta / largestComponent;
1201 } else if (type === 'l') {
1202 var baseSaturation = lightness > 0.5 ? delta / (2 - largestComponent - smallestComponent) : delta / (largestComponent + smallestComponent);
1203 saturation = isNaN(baseSaturation) ? 0 : baseSaturation;
1204 }
1205
1206 var huePercentage = 0;
1207
1208 switch (largestComponent) {
1209 case red:
1210 huePercentage = (green - blue) / delta + (green < blue ? 6 : 0);
1211 break;
1212
1213 case green:
1214 huePercentage = (blue - red) / delta + 2;
1215 break;
1216
1217 case blue:
1218 huePercentage = (red - green) / delta + 4;
1219 }
1220
1221 var hue = Math.round(huePercentage / 6 * 360);
1222 return {
1223 hue: clamp$1(hue, 0, 360) || 0,
1224 saturation: parseFloat(clamp$1(saturation, 0, 1).toFixed(2)),
1225 brightness: parseFloat(clamp$1(largestComponent, 0, 1).toFixed(2)),
1226 lightness: parseFloat(lightness.toFixed(2)),
1227 alpha: parseFloat(alpha.toFixed(2))
1228 };
1229}
1230
1231function rgbToHsb(color) {
1232 var _rgbToHsbl = rgbToHsbl(color, 'b'),
1233 hue = _rgbToHsbl.hue,
1234 saturation = _rgbToHsbl.saturation,
1235 brightness = _rgbToHsbl.brightness,
1236 _rgbToHsbl$alpha = _rgbToHsbl.alpha,
1237 alpha = _rgbToHsbl$alpha === void 0 ? 1 : _rgbToHsbl$alpha;
1238
1239 return {
1240 hue,
1241 saturation,
1242 brightness,
1243 alpha
1244 };
1245}
1246function rgbToHsl(color) {
1247 var _rgbToHsbl2 = rgbToHsbl(color, 'l'),
1248 hue = _rgbToHsbl2.hue,
1249 rawSaturation = _rgbToHsbl2.saturation,
1250 rawLightness = _rgbToHsbl2.lightness,
1251 _rgbToHsbl2$alpha = _rgbToHsbl2.alpha,
1252 alpha = _rgbToHsbl2$alpha === void 0 ? 1 : _rgbToHsbl2$alpha;
1253
1254 var saturation = rawSaturation * 100;
1255 var lightness = rawLightness * 100;
1256 return {
1257 hue,
1258 saturation,
1259 lightness,
1260 alpha
1261 };
1262}
1263function hexToRgb(color) {
1264 if (color.length === 4) {
1265 var repeatHex = function repeatHex(hex1, hex2) {
1266 return color.slice(hex1, hex2).repeat(2);
1267 };
1268
1269 var _red = parseInt(repeatHex(1, 2), 16);
1270
1271 var _green = parseInt(repeatHex(2, 3), 16);
1272
1273 var _blue = parseInt(repeatHex(3, 4), 16);
1274
1275 return {
1276 red: _red,
1277 green: _green,
1278 blue: _blue
1279 };
1280 }
1281
1282 var red = parseInt(color.slice(1, 3), 16);
1283 var green = parseInt(color.slice(3, 5), 16);
1284 var blue = parseInt(color.slice(5, 7), 16);
1285 return {
1286 red,
1287 green,
1288 blue
1289 };
1290}
1291var ColorType;
1292
1293(function (ColorType) {
1294 ColorType["Hex"] = "hex";
1295 ColorType["Rgb"] = "rgb";
1296 ColorType["Rgba"] = "rgba";
1297 ColorType["Hsl"] = "hsl";
1298 ColorType["Hsla"] = "hsla";
1299 ColorType["Default"] = "default";
1300})(ColorType || (ColorType = {}));
1301
1302function getColorType(color) {
1303 if (color.includes('#')) {
1304 return ColorType.Hex;
1305 } else if (color.includes('rgb')) {
1306 return ColorType.Rgb;
1307 } else if (color.includes('rgba')) {
1308 return ColorType.Rgba;
1309 } else if (color.includes('hsl')) {
1310 return ColorType.Hsl;
1311 } else if (color.includes('hsla')) {
1312 return ColorType.Hsla;
1313 } else {
1314 if (process.env.NODE_ENV === 'development') {
1315 /* eslint-disable-next-line no-console */
1316 console.warn('Accepted colors formats are: hex, rgb, rgba, hsl and hsla');
1317 }
1318
1319 return ColorType.Default;
1320 }
1321}
1322
1323function hslToString(hslColor) {
1324 if (typeof hslColor === 'string') {
1325 return hslColor;
1326 }
1327
1328 var _hslColor$alpha = hslColor.alpha,
1329 alpha = _hslColor$alpha === void 0 ? 1 : _hslColor$alpha,
1330 hue = hslColor.hue,
1331 lightness = hslColor.lightness,
1332 saturation = hslColor.saturation;
1333 return "hsla(".concat(hue, ", ").concat(saturation, "%, ").concat(lightness, "%, ").concat(alpha, ")");
1334}
1335
1336function rgbToObject(color) {
1337 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1338 var colorMatch = color.match(/\(([^)]+)\)/);
1339
1340 if (!colorMatch) {
1341 return {
1342 red: 0,
1343 green: 0,
1344 blue: 0,
1345 alpha: 0
1346 };
1347 }
1348
1349 var _colorMatch$1$split = colorMatch[1].split(','),
1350 _colorMatch$1$split2 = _slicedToArray(_colorMatch$1$split, 4),
1351 red = _colorMatch$1$split2[0],
1352 green = _colorMatch$1$split2[1],
1353 blue = _colorMatch$1$split2[2],
1354 alpha = _colorMatch$1$split2[3];
1355
1356 var objColor = {
1357 red: parseInt(red, 10),
1358 green: parseInt(green, 10),
1359 blue: parseInt(blue, 10),
1360 alpha: parseInt(alpha, 10) || 1
1361 };
1362 return objColor;
1363}
1364
1365var hexToHsla = compose(rgbToHsl, hexToRgb);
1366var rbgStringToHsla = compose(rgbToHsl, rgbToObject);
1367
1368function hslToObject(color) {
1369 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1370 var colorMatch = color.match(/\(([^)]+)\)/);
1371
1372 if (!colorMatch) {
1373 return {
1374 hue: 0,
1375 saturation: 0,
1376 lightness: 0,
1377 alpha: 0
1378 };
1379 }
1380
1381 var _colorMatch$1$split3 = colorMatch[1].split(','),
1382 _colorMatch$1$split4 = _slicedToArray(_colorMatch$1$split3, 4),
1383 hue = _colorMatch$1$split4[0],
1384 saturation = _colorMatch$1$split4[1],
1385 lightness = _colorMatch$1$split4[2],
1386 alpha = _colorMatch$1$split4[3];
1387
1388 var objColor = {
1389 hue: parseInt(hue, 10),
1390 saturation: parseInt(saturation, 10),
1391 lightness: parseInt(lightness, 10),
1392 alpha: parseFloat(alpha) || 1
1393 };
1394 return objColor;
1395}
1396
1397function colorToHsla(color) {
1398 var type = getColorType(color);
1399
1400 switch (type) {
1401 case ColorType.Hex:
1402 return hexToHsla(color);
1403
1404 case ColorType.Rgb:
1405 case ColorType.Rgba:
1406 return rbgStringToHsla(color);
1407
1408 case ColorType.Hsla:
1409 case ColorType.Hsl:
1410 return hslToObject(color);
1411
1412 case ColorType.Default:
1413 default:
1414 throw new Error('Accepted color formats are: hex, rgb, rgba, hsl and hsla');
1415 }
1416}
1417
1418// implements: https://www.w3.org/WAI/ER/WD-AERT/#color-contrast
1419function isLight(_ref) {
1420 var red = _ref.red,
1421 green = _ref.green,
1422 blue = _ref.blue;
1423 var contrast = (red * 299 + green * 587 + blue * 114) / 1000;
1424 return contrast > 125;
1425}
1426
1427function normalizeName(name) {
1428 return name.split(/(?=[A-Z])/).join('-').toLowerCase();
1429}
1430function constructColorName(baseName, property, suffix) {
1431 var name = normalizeName(baseName);
1432 var propertyName = property ? "-".concat(normalizeName(property)) : '';
1433 var constructedSuffix = suffix ? "-".concat(suffix) : '';
1434 return "--".concat(name).concat(propertyName).concat(constructedSuffix);
1435}
1436
1437function lightenColor(color) {
1438 var lighten = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1439
1440 if (typeof color === 'string') {
1441 return color;
1442 }
1443
1444 var lightness = color.lightness;
1445 var nextLightness = lightness + lighten;
1446 return Object.assign(Object.assign({}, color), {
1447 lightness: clamp$1(nextLightness, 0, 100)
1448 });
1449}
1450function saturateColor(color) {
1451 var saturate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1452
1453 if (typeof color === 'string') {
1454 return color;
1455 }
1456
1457 var saturation = color.saturation;
1458 var nextSaturation = saturation + saturate;
1459 return Object.assign(Object.assign({}, color), {
1460 saturation: nextSaturation
1461 });
1462}
1463function createLightColor(color, lightness, saturation) {
1464 var lightenedColor = lightenColor(color, lightness);
1465 var saturatedColor = saturateColor(lightenedColor, -saturation);
1466 return saturatedColor;
1467}
1468
1469var needsVariantList = ['topBar'];
1470
1471function buildCustomProperties(themeConfig, newDesignLanguage, tokens) {
1472 var _themeConfig$colors = themeConfig.colors,
1473 colors = _themeConfig$colors === void 0 ? {} : _themeConfig$colors,
1474 colorScheme = themeConfig.colorScheme;
1475 return newDesignLanguage ? customPropertyTransformer(Object.assign(Object.assign({}, colorFactory(colors, colorScheme)), tokens)) : buildLegacyColors(themeConfig);
1476}
1477function buildThemeContext(themeConfig, cssCustomProperties) {
1478 var logo = themeConfig.logo,
1479 _themeConfig$colors2 = themeConfig.colors,
1480 colors = _themeConfig$colors2 === void 0 ? {} : _themeConfig$colors2,
1481 colorScheme = themeConfig.colorScheme;
1482
1483 var topBar = colors.topBar,
1484 newDesignLanguageColors = __rest(colors, ["topBar"]);
1485
1486 return {
1487 logo,
1488 cssCustomProperties: toString(cssCustomProperties),
1489 colors: newDesignLanguageColors,
1490 colorScheme
1491 };
1492}
1493
1494function toString(obj) {
1495 if (obj) {
1496 return Object.entries(obj).map(function (pair) {
1497 return pair.join(':');
1498 }).join(';');
1499 } else {
1500 return undefined;
1501 }
1502}
1503
1504function customPropertyTransformer(properties) {
1505 return Object.entries(properties).reduce(function (transformed, _ref) {
1506 var _ref2 = _slicedToArray(_ref, 2),
1507 key = _ref2[0],
1508 value = _ref2[1];
1509
1510 return Object.assign(Object.assign({}, transformed), {
1511 [toCssCustomPropertySyntax(key)]: value
1512 });
1513 }, {});
1514}
1515
1516function toCssCustomPropertySyntax(camelCase) {
1517 return "--p-".concat(camelCase.replace(/([A-Z0-9])/g, '-$1').toLowerCase());
1518}
1519
1520function buildLegacyColors(theme) {
1521 var colorPairs;
1522 var colors = theme && theme.colors && theme.colors.topBar ? theme.colors.topBar : {
1523 background: '#00848e',
1524 backgroundLighter: '#1d9ba4',
1525 color: '#f9fafb'
1526 };
1527 var colorKey = 'topBar';
1528 var colorKeys = Object.keys(colors);
1529
1530 if (colorKeys.length > 1) {
1531 colorPairs = colorKeys.map(function (key) {
1532 return [constructColorName(colorKey, key), colors[key]];
1533 });
1534 } else {
1535 colorPairs = parseColors([colorKey, colors]);
1536 }
1537
1538 return colorPairs.reduce(function (state, _ref3) {
1539 var _ref4 = _slicedToArray(_ref3, 2),
1540 key = _ref4[0],
1541 value = _ref4[1];
1542
1543 return Object.assign(Object.assign({}, state), {
1544 [key]: value
1545 });
1546 }, {});
1547}
1548
1549function needsVariant(name) {
1550 return needsVariantList.includes(name);
1551}
1552var lightenToString = compose(hslToString, createLightColor);
1553function setTextColor(name) {
1554 var variant = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'dark';
1555
1556 if (variant === 'light') {
1557 return [name, tokens.colorInk];
1558 }
1559
1560 return [name, tokens.colorWhite];
1561}
1562function setTheme(color, baseName, key, variant) {
1563 var colorPairs = [];
1564
1565 switch (variant) {
1566 case 'light':
1567 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'light'));
1568 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 7, -10)]);
1569 break;
1570
1571 case 'dark':
1572 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'dark'));
1573 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 15, 15)]);
1574 break;
1575 }
1576
1577 return colorPairs;
1578}
1579
1580function parseColors(_ref5) {
1581 var _ref6 = _slicedToArray(_ref5, 2),
1582 baseName = _ref6[0],
1583 colors = _ref6[1];
1584
1585 var keys = Object.keys(colors);
1586 var colorPairs = [];
1587
1588 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
1589 var key = _keys[_i];
1590 colorPairs.push([constructColorName(baseName, key), colors[key]]);
1591
1592 if (needsVariant(baseName)) {
1593 var hslColor = colorToHsla(colors[key]);
1594
1595 if (typeof hslColor === 'string') {
1596 return colorPairs;
1597 }
1598
1599 var rgbColor = hslToRgb(hslColor);
1600
1601 if (isLight(rgbColor)) {
1602 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'light')));
1603 } else {
1604 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'dark')));
1605 }
1606 }
1607 }
1608
1609 return colorPairs;
1610}
1611
1612var BorderRadius = {
1613 borderRadiusBase: rem('4px'),
1614 borderRadiusWide: rem('8px')
1615};
1616var Shadow = {
1617 cardShadow: '0px 0px 5px var(--p-shadow-from-ambient-light), 0px 1px 2px var(--p-shadow-from-direct-light)',
1618 popoverShadow: '-1px 0px 20px var(--p-shadow-from-ambient-light), 0px 1px 5px var(--p-shadow-from-direct-light)',
1619 modalShadow: '0px 26px 80px var(--p-shadow-from-dim-light), 0px 0px 1px var(--p-shadow-from-dim-light)',
1620 topBarShadow: '0 2px 2px -1px var(--p-shadow-from-direct-light)'
1621};
1622var Overrides = {
1623 overrideNone: 'none',
1624 overrideTransparent: 'transparent',
1625 overrideOne: '1',
1626 overrideVisible: 'visible',
1627 overrideZero: '0',
1628 overrideLoadingZIndex: '514',
1629 buttonFontWeight: '500',
1630 nonNullContent: "''",
1631 choiceSize: rem('20px'),
1632 iconSize: rem('10px'),
1633 choiceMargin: rem('1px'),
1634 controlBorderWidth: rem('2px'),
1635 bannerBorderDefault: buildBannerBorder('--p-border'),
1636 bannerBorderSuccess: buildBannerBorder('--p-border-success'),
1637 bannerBorderHighlight: buildBannerBorder('--p-border-highlight'),
1638 bannerBorderWarning: buildBannerBorder('--p-border-warning'),
1639 bannerBorderCritical: buildBannerBorder('--p-border-critical'),
1640 badgeMixBlendMode: 'luminosity',
1641 thinBorderSubdued: "".concat(rem('1px'), " solid var(--p-border-subdued)"),
1642 textFieldSpinnerOffset: rem('2px'),
1643 textFieldFocusRingOffset: rem('-4px'),
1644 textFieldFocusRingBorderRadius: rem('7px'),
1645 buttonGroupItemSpacing: rem('2px'),
1646 topBarHeight: '68px',
1647 contextualSaveBarHeight: '64px',
1648 duration100: '100ms',
1649 duration150: '150ms',
1650 easeIn: 'cubic-bezier(0.5, 0.1, 1, 1)',
1651 ease: 'cubic-bezier(0.4, 0.22, 0.28, 1)'
1652};
1653var Tokens = Object.assign(Object.assign(Object.assign({}, BorderRadius), Shadow), Overrides);
1654
1655function rem(px) {
1656 var baseFontSize = 10;
1657 return "".concat(parseInt(px, 10) / baseFontSize, "rem");
1658}
1659
1660function buildBannerBorder(cssVar) {
1661 return "inset 0 ".concat(rem('2px'), " 0 0 var(").concat(cssVar, "), inset 0 0 0 ").concat(rem('2px'), " var(").concat(cssVar, ")");
1662}
1663
1664var getUniqueID = createUniqueIDFactory('portal-');
1665var Portal =
1666/*#__PURE__*/
1667function (_React$PureComponent) {
1668 _inherits(Portal, _React$PureComponent);
1669
1670 function Portal() {
1671 var _this;
1672
1673 _classCallCheck(this, Portal);
1674
1675 _this = _possibleConstructorReturn(this, _getPrototypeOf(Portal).apply(this, arguments));
1676 _this.state = {
1677 isMounted: false
1678 };
1679 _this.portalNode = null;
1680 _this.portalId = _this.props.idPrefix !== '' ? "".concat(_this.props.idPrefix, "-").concat(getUniqueID()) : getUniqueID();
1681 return _this;
1682 }
1683
1684 _createClass(Portal, [{
1685 key: "componentDidMount",
1686 value: function componentDidMount() {
1687 this.portalNode = document.createElement('div');
1688 this.portalNode.setAttribute(portal.props[0], this.portalId);
1689
1690 if (this.context != null) {
1691 var cssCustomProperties = this.context.cssCustomProperties;
1692
1693 if (cssCustomProperties != null) {
1694 this.portalNode.setAttribute('style', cssCustomProperties);
1695 } else {
1696 this.portalNode.removeAttribute('style');
1697 }
1698 }
1699
1700 document.body.appendChild(this.portalNode);
1701 this.setState({
1702 isMounted: true
1703 });
1704 }
1705 }, {
1706 key: "componentDidUpdate",
1707 value: function componentDidUpdate(_, prevState) {
1708 var _this$props$onPortalC = this.props.onPortalCreated,
1709 onPortalCreated = _this$props$onPortalC === void 0 ? noop : _this$props$onPortalC;
1710
1711 if (this.portalNode && this.context != null) {
1712 var _this$context = this.context,
1713 cssCustomProperties = _this$context.cssCustomProperties,
1714 textColor = _this$context.textColor;
1715
1716 if (cssCustomProperties != null) {
1717 var style = "".concat(cssCustomProperties, ";color:").concat(textColor, ";");
1718 this.portalNode.setAttribute('style', style);
1719 } else {
1720 this.portalNode.removeAttribute('style');
1721 }
1722 }
1723
1724 if (!prevState.isMounted && this.state.isMounted) {
1725 onPortalCreated();
1726 }
1727 }
1728 }, {
1729 key: "componentWillUnmount",
1730 value: function componentWillUnmount() {
1731 if (this.portalNode) {
1732 document.body.removeChild(this.portalNode);
1733 }
1734 }
1735 }, {
1736 key: "render",
1737 value: function render() {
1738 return this.portalNode && this.state.isMounted ? createPortal(this.props.children, this.portalNode) : null;
1739 }
1740 }]);
1741
1742 return Portal;
1743}(React__default.PureComponent);
1744Portal.defaultProps = {
1745 idPrefix: ''
1746};
1747Portal.contextType = ThemeContext;
1748
1749function noop() {}
1750
1751var UniqueIdFactoryContext = React__default.createContext(undefined);
1752
1753/**
1754 * Returns a unique id that remains consistent across multiple re-renders of the
1755 * same hook
1756 * @param prefix Defines a prefix for the ID. You probably want to set this to
1757 * the name of the component you're calling `useUniqueId` in.
1758 * @param overrideId Defines a fixed value to use instead of generating a unique
1759 * ID. Useful for components that allow consumers to specify their own ID.
1760 */
1761
1762function useUniqueId() {
1763 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
1764 var overrideId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
1765 var idFactory = useContext(UniqueIdFactoryContext); // By using a ref to store the uniqueId for each invocation of the hook and
1766 // checking that it is not already populated we ensure that we don’t generate
1767 // a new ID on every re-render of a component.
1768
1769 var uniqueIdRef = useRef(null);
1770
1771 if (!idFactory) {
1772 throw new MissingAppProviderError('No UniqueIdFactory was provided.');
1773 } // If an override was specified, then use that instead of using a unique ID
1774 // Hooks can’t be called conditionally so this has to go after all use* calls
1775
1776
1777 if (overrideId) {
1778 return overrideId;
1779 } // If a unique id has not yet been generated, then get a new one
1780
1781
1782 if (!uniqueIdRef.current) {
1783 uniqueIdRef.current = idFactory.nextId(prefix);
1784 }
1785
1786 return uniqueIdRef.current;
1787}
1788
1789var UniqueIdFactory =
1790/*#__PURE__*/
1791function () {
1792 function UniqueIdFactory(idGeneratorFactory) {
1793 _classCallCheck(this, UniqueIdFactory);
1794
1795 this.idGenerators = {};
1796 this.idGeneratorFactory = idGeneratorFactory;
1797 }
1798
1799 _createClass(UniqueIdFactory, [{
1800 key: "nextId",
1801 value: function nextId(prefix) {
1802 if (!this.idGenerators[prefix]) {
1803 this.idGenerators[prefix] = this.idGeneratorFactory(prefix);
1804 }
1805
1806 return this.idGenerators[prefix]();
1807 }
1808 }]);
1809
1810 return UniqueIdFactory;
1811}();
1812function globalIdGeneratorFactory() {
1813 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
1814 var index = 1;
1815 return function () {
1816 return "Polaris".concat(prefix).concat(index++);
1817 };
1818}
1819
1820// `Component`. If `props` is passed, those will be added as props on the
1821// wrapped component. If `element` is null, the component is not wrapped.
1822
1823function wrapWithComponent(element, Component, props) {
1824 if (element == null) {
1825 return null;
1826 }
1827
1828 return isElementOfType(element, Component) ? element : React__default.createElement(Component, props, element);
1829} // In development, we compare based on the name of the function because
1830// React Hot Loader proxies React components in order to make updates. In
1831// production we can simply compare the components for equality.
1832
1833var isComponent = process.env.NODE_ENV === 'development' ? hotReloadComponentCheck : function (AComponent, AnotherComponent) {
1834 return AComponent === AnotherComponent;
1835}; // Checks whether `element` is a React element of type `Component` (or one of
1836// the passed components, if `Component` is an array of React components).
1837
1838function isElementOfType(element, Component) {
1839 if (element == null || !React__default.isValidElement(element) || typeof element.type === 'string') {
1840 return false;
1841 }
1842
1843 var type = element.type;
1844 var Components = Array.isArray(Component) ? Component : [Component];
1845 return Components.some(function (AComponent) {
1846 return typeof type !== 'string' && isComponent(AComponent, type);
1847 });
1848} // Returns all children that are valid elements as an array. Can optionally be
1849// filtered by passing `predicate`.
1850
1851function elementChildren(children) {
1852 var predicate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {
1853 return true;
1854 };
1855 return React__default.Children.toArray(children).filter(function (child) {
1856 return React__default.isValidElement(child) && predicate(child);
1857 });
1858}
1859
1860function hotReloadComponentCheck(AComponent, AnotherComponent) {
1861 var componentName = AComponent.name;
1862 var anotherComponentName = AnotherComponent.displayName;
1863 return AComponent === AnotherComponent || Boolean(componentName) && componentName === anotherComponentName;
1864}
1865
1866var StickyManagerContext = React__default.createContext(undefined);
1867
1868function useStickyManager() {
1869 var stickyManager = useContext(StickyManagerContext);
1870
1871 if (!stickyManager) {
1872 throw new MissingAppProviderError('No StickyManager was provided.');
1873 }
1874
1875 return stickyManager;
1876}
1877
1878var Breakpoints = {
1879 navigationBarCollapsed: '768px',
1880 stackedContent: '1043px'
1881};
1882var noWindowMatches = {
1883 media: '',
1884 addListener: noop$1,
1885 removeListener: noop$1,
1886 matches: false,
1887 onchange: noop$1,
1888 addEventListener: noop$1,
1889 removeEventListener: noop$1,
1890 dispatchEvent: function dispatchEvent(_) {
1891 return true;
1892 }
1893};
1894
1895function noop$1() {}
1896
1897function navigationBarCollapsed() {
1898 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.navigationBarCollapsed, ")"));
1899}
1900function stackedContent() {
1901 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.stackedContent, ")"));
1902}
1903
1904var StickyManager =
1905/*#__PURE__*/
1906function () {
1907 function StickyManager(container) {
1908 var _this = this;
1909
1910 _classCallCheck(this, StickyManager);
1911
1912 this.stickyItems = [];
1913 this.stuckItems = [];
1914 this.container = null;
1915 this.topBarOffset = 0;
1916 this.handleResize = debounce(function () {
1917 _this.manageStickyItems();
1918 }, 40, {
1919 leading: true,
1920 trailing: true,
1921 maxWait: 40
1922 });
1923 this.handleScroll = debounce(function () {
1924 _this.manageStickyItems();
1925 }, 40, {
1926 leading: true,
1927 trailing: true,
1928 maxWait: 40
1929 });
1930
1931 if (container) {
1932 this.setContainer(container);
1933 }
1934 }
1935
1936 _createClass(StickyManager, [{
1937 key: "registerStickyItem",
1938 value: function registerStickyItem(stickyItem) {
1939 this.stickyItems.push(stickyItem);
1940 }
1941 }, {
1942 key: "unregisterStickyItem",
1943 value: function unregisterStickyItem(nodeToRemove) {
1944 var nodeIndex = this.stickyItems.findIndex(function (_ref) {
1945 var stickyNode = _ref.stickyNode;
1946 return nodeToRemove === stickyNode;
1947 });
1948 this.stickyItems.splice(nodeIndex, 1);
1949 }
1950 }, {
1951 key: "setContainer",
1952 value: function setContainer(el) {
1953 this.container = el;
1954
1955 if (isDocument(el)) {
1956 this.setTopBarOffset(el);
1957 }
1958
1959 addEventListener(this.container, 'scroll', this.handleScroll);
1960 addEventListener(window, 'resize', this.handleResize);
1961 this.manageStickyItems();
1962 }
1963 }, {
1964 key: "removeScrollListener",
1965 value: function removeScrollListener() {
1966 if (this.container) {
1967 removeEventListener(this.container, 'scroll', this.handleScroll);
1968 removeEventListener(window, 'resize', this.handleResize);
1969 }
1970 }
1971 }, {
1972 key: "manageStickyItems",
1973 value: function manageStickyItems() {
1974 var _this2 = this;
1975
1976 if (this.stickyItems.length <= 0) {
1977 return;
1978 }
1979
1980 var scrollTop = this.container ? scrollTopFor(this.container) : 0;
1981 var containerTop = getRectForNode(this.container).top + this.topBarOffset;
1982 this.stickyItems.forEach(function (stickyItem) {
1983 var handlePositioning = stickyItem.handlePositioning;
1984
1985 var _this2$evaluateSticky = _this2.evaluateStickyItem(stickyItem, scrollTop, containerTop),
1986 sticky = _this2$evaluateSticky.sticky,
1987 top = _this2$evaluateSticky.top,
1988 left = _this2$evaluateSticky.left,
1989 width = _this2$evaluateSticky.width;
1990
1991 _this2.updateStuckItems(stickyItem, sticky);
1992
1993 handlePositioning(sticky, top, left, width);
1994 });
1995 }
1996 }, {
1997 key: "evaluateStickyItem",
1998 value: function evaluateStickyItem(stickyItem, scrollTop, containerTop) {
1999 var stickyNode = stickyItem.stickyNode,
2000 placeHolderNode = stickyItem.placeHolderNode,
2001 boundingElement = stickyItem.boundingElement,
2002 offset = stickyItem.offset,
2003 disableWhenStacked = stickyItem.disableWhenStacked;
2004
2005 if (disableWhenStacked && stackedContent().matches) {
2006 return {
2007 sticky: false,
2008 top: 0,
2009 left: 0,
2010 width: 'auto'
2011 };
2012 }
2013
2014 var stickyOffset = offset ? this.getOffset(stickyNode) + parseInt(tokens.spacingLoose, 10) : this.getOffset(stickyNode);
2015 var scrollPosition = scrollTop + stickyOffset;
2016 var placeHolderNodeCurrentTop = placeHolderNode.getBoundingClientRect().top - containerTop + scrollTop;
2017 var top = containerTop + stickyOffset;
2018 var width = placeHolderNode.getBoundingClientRect().width;
2019 var left = placeHolderNode.getBoundingClientRect().left;
2020 var sticky;
2021
2022 if (boundingElement == null) {
2023 sticky = scrollPosition >= placeHolderNodeCurrentTop;
2024 } else {
2025 var stickyItemHeight = stickyNode.getBoundingClientRect().height;
2026 var stickyItemBottomPosition = boundingElement.getBoundingClientRect().bottom - stickyItemHeight + scrollTop - containerTop;
2027 sticky = scrollPosition >= placeHolderNodeCurrentTop && scrollPosition < stickyItemBottomPosition;
2028 }
2029
2030 return {
2031 sticky,
2032 top,
2033 left,
2034 width
2035 };
2036 }
2037 }, {
2038 key: "updateStuckItems",
2039 value: function updateStuckItems(item, sticky) {
2040 var stickyNode = item.stickyNode;
2041
2042 if (sticky && !this.isNodeStuck(stickyNode)) {
2043 this.addStuckItem(item);
2044 } else if (!sticky && this.isNodeStuck(stickyNode)) {
2045 this.removeStuckItem(item);
2046 }
2047 }
2048 }, {
2049 key: "addStuckItem",
2050 value: function addStuckItem(stickyItem) {
2051 this.stuckItems.push(stickyItem);
2052 }
2053 }, {
2054 key: "removeStuckItem",
2055 value: function removeStuckItem(stickyItem) {
2056 var nodeToRemove = stickyItem.stickyNode;
2057 var nodeIndex = this.stuckItems.findIndex(function (_ref2) {
2058 var stickyNode = _ref2.stickyNode;
2059 return nodeToRemove === stickyNode;
2060 });
2061 this.stuckItems.splice(nodeIndex, 1);
2062 }
2063 }, {
2064 key: "getOffset",
2065 value: function getOffset(node) {
2066 if (this.stuckItems.length === 0) {
2067 return 0;
2068 }
2069
2070 var offset = 0;
2071 var count = 0;
2072 var stuckNodesLength = this.stuckItems.length;
2073 var nodeRect = getRectForNode(node);
2074
2075 while (count < stuckNodesLength) {
2076 var stuckNode = this.stuckItems[count].stickyNode;
2077
2078 if (stuckNode !== node) {
2079 var stuckNodeRect = getRectForNode(stuckNode);
2080
2081 if (!horizontallyOverlaps(nodeRect, stuckNodeRect)) {
2082 offset += getRectForNode(stuckNode).height;
2083 }
2084 } else {
2085 break;
2086 }
2087
2088 count++;
2089 }
2090
2091 return offset;
2092 }
2093 }, {
2094 key: "isNodeStuck",
2095 value: function isNodeStuck(node) {
2096 var nodeFound = this.stuckItems.findIndex(function (_ref3) {
2097 var stickyNode = _ref3.stickyNode;
2098 return node === stickyNode;
2099 });
2100 return nodeFound >= 0;
2101 }
2102 }, {
2103 key: "setTopBarOffset",
2104 value: function setTopBarOffset(container) {
2105 var topbarElement = container.querySelector(":not(".concat(scrollable.selector, ") ").concat(dataPolarisTopBar.selector));
2106 this.topBarOffset = topbarElement ? topbarElement.clientHeight : 0;
2107 }
2108 }]);
2109
2110 return StickyManager;
2111}();
2112
2113function isDocument(node) {
2114 return node === document;
2115}
2116
2117function scrollTopFor(container) {
2118 return isDocument(container) ? document.body.scrollTop || document.documentElement.scrollTop : container.scrollTop;
2119}
2120
2121function horizontallyOverlaps(rect1, rect2) {
2122 var rect1Left = rect1.left;
2123 var rect1Right = rect1.left + rect1.width;
2124 var rect2Left = rect2.left;
2125 var rect2Right = rect2.left + rect2.width;
2126 return rect2Right < rect1Left || rect1Right < rect2Left;
2127}
2128
2129var ScrollableContext = React__default.createContext(undefined);
2130
2131function ScrollTo() {
2132 var anchorNode = useRef(null);
2133 var scrollToPosition = useContext(ScrollableContext);
2134 useEffect(function () {
2135 if (!scrollToPosition || !anchorNode.current) {
2136 return;
2137 }
2138
2139 scrollToPosition(anchorNode.current.offsetTop);
2140 }, [scrollToPosition]);
2141 var id = useUniqueId("ScrollTo"); // eslint-disable-next-line jsx-a11y/anchor-is-valid
2142
2143 return React__default.createElement("a", {
2144 id: id,
2145 ref: anchorNode
2146 });
2147}
2148
2149var styles$4 = {
2150 "Scrollable": "Polaris-Scrollable",
2151 "horizontal": "Polaris-Scrollable--horizontal",
2152 "vertical": "Polaris-Scrollable--vertical",
2153 "verticalHasScrolling": "Polaris-Scrollable--verticalHasScrolling",
2154 "hasTopShadow": "Polaris-Scrollable--hasTopShadow",
2155 "hasBottomShadow": "Polaris-Scrollable--hasBottomShadow"
2156};
2157
2158var MAX_SCROLL_DISTANCE = 100;
2159var DELTA_THRESHOLD = 0.2;
2160var DELTA_PERCENTAGE = 0.2;
2161var EVENTS_TO_LOCK = ['scroll', 'touchmove', 'wheel'];
2162var PREFERS_REDUCED_MOTION = prefersReducedMotion();
2163var Scrollable =
2164/*#__PURE__*/
2165function (_React$Component) {
2166 _inherits(Scrollable, _React$Component);
2167
2168 function Scrollable() {
2169 var _this;
2170
2171 _classCallCheck(this, Scrollable);
2172
2173 _this = _possibleConstructorReturn(this, _getPrototypeOf(Scrollable).apply(this, arguments));
2174 _this.state = {
2175 topShadow: false,
2176 bottomShadow: false,
2177 scrollPosition: 0,
2178 canScroll: false
2179 };
2180 _this.stickyManager = new StickyManager();
2181 _this.scrollArea = null;
2182 _this.handleResize = debounce(function () {
2183 _this.handleScroll();
2184 }, 50, {
2185 trailing: true
2186 });
2187
2188 _this.setScrollArea = function (scrollArea) {
2189 _this.scrollArea = scrollArea;
2190 };
2191
2192 _this.handleScroll = function () {
2193 var _assertThisInitialize = _assertThisInitialized(_this),
2194 scrollArea = _assertThisInitialize.scrollArea;
2195
2196 var _this$props = _this.props,
2197 shadow = _this$props.shadow,
2198 onScrolledToBottom = _this$props.onScrolledToBottom;
2199
2200 if (scrollArea == null) {
2201 return;
2202 }
2203
2204 var scrollTop = scrollArea.scrollTop,
2205 clientHeight = scrollArea.clientHeight,
2206 scrollHeight = scrollArea.scrollHeight;
2207 var shouldBottomShadow = Boolean(shadow && !(scrollTop + clientHeight >= scrollHeight));
2208 var shouldTopShadow = Boolean(shadow && scrollTop > 0);
2209 var canScroll = scrollHeight > clientHeight;
2210 var hasScrolledToBottom = scrollHeight - scrollTop === clientHeight;
2211
2212 if (canScroll && hasScrolledToBottom && onScrolledToBottom) {
2213 onScrolledToBottom();
2214 }
2215
2216 _this.setState({
2217 topShadow: shouldTopShadow,
2218 bottomShadow: shouldBottomShadow,
2219 scrollPosition: scrollTop,
2220 canScroll
2221 });
2222 };
2223
2224 _this.scrollHint = function () {
2225 var _assertThisInitialize2 = _assertThisInitialized(_this),
2226 scrollArea = _assertThisInitialize2.scrollArea;
2227
2228 if (scrollArea == null) {
2229 return;
2230 }
2231
2232 var clientHeight = scrollArea.clientHeight,
2233 scrollHeight = scrollArea.scrollHeight;
2234
2235 if (PREFERS_REDUCED_MOTION || _this.state.scrollPosition > 0 || scrollHeight <= clientHeight) {
2236 return;
2237 }
2238
2239 var scrollDistance = scrollHeight - clientHeight;
2240
2241 _this.toggleLock();
2242
2243 _this.setState({
2244 scrollPosition: scrollDistance > MAX_SCROLL_DISTANCE ? MAX_SCROLL_DISTANCE : scrollDistance
2245 }, function () {
2246 window.requestAnimationFrame(_this.scrollStep);
2247 });
2248 };
2249
2250 _this.scrollStep = function () {
2251 _this.setState(function (_ref) {
2252 var scrollPosition = _ref.scrollPosition;
2253 var delta = scrollPosition * DELTA_PERCENTAGE;
2254 return {
2255 scrollPosition: delta < DELTA_THRESHOLD ? 0 : scrollPosition - delta
2256 };
2257 }, function () {
2258 if (_this.state.scrollPosition > 0) {
2259 window.requestAnimationFrame(_this.scrollStep);
2260 } else {
2261 _this.toggleLock(false);
2262 }
2263 });
2264 };
2265
2266 _this.scrollToPosition = function (scrollY) {
2267 _this.setState({
2268 scrollPosition: scrollY
2269 });
2270 };
2271
2272 return _this;
2273 }
2274
2275 _createClass(Scrollable, [{
2276 key: "componentDidMount",
2277 value: function componentDidMount() {
2278 var _this2 = this;
2279
2280 if (this.scrollArea == null) {
2281 return;
2282 }
2283
2284 this.stickyManager.setContainer(this.scrollArea);
2285 addEventListener(this.scrollArea, 'scroll', function () {
2286 window.requestAnimationFrame(_this2.handleScroll);
2287 });
2288 addEventListener(window, 'resize', this.handleResize);
2289 window.requestAnimationFrame(function () {
2290 _this2.handleScroll();
2291
2292 if (_this2.props.hint) {
2293 _this2.scrollHint();
2294 }
2295 });
2296 }
2297 }, {
2298 key: "componentWillUnmount",
2299 value: function componentWillUnmount() {
2300 if (this.scrollArea == null) {
2301 return;
2302 }
2303
2304 removeEventListener(this.scrollArea, 'scroll', this.handleScroll);
2305 removeEventListener(window, 'resize', this.handleResize);
2306 this.stickyManager.removeScrollListener();
2307 }
2308 }, {
2309 key: "componentDidUpdate",
2310 value: function componentDidUpdate() {
2311 var scrollPosition = this.state.scrollPosition;
2312
2313 if (scrollPosition && this.scrollArea && scrollPosition > 0) {
2314 this.scrollArea.scrollTop = scrollPosition;
2315 }
2316 }
2317 }, {
2318 key: "render",
2319 value: function render() {
2320 var _this$state = this.state,
2321 topShadow = _this$state.topShadow,
2322 bottomShadow = _this$state.bottomShadow,
2323 canScroll = _this$state.canScroll;
2324
2325 var _a = this.props,
2326 children = _a.children,
2327 className = _a.className,
2328 horizontal = _a.horizontal,
2329 _a$vertical = _a.vertical,
2330 vertical = _a$vertical === void 0 ? true : _a$vertical,
2331 shadow = _a.shadow,
2332 hint = _a.hint,
2333 onScrolledToBottom = _a.onScrolledToBottom,
2334 rest = __rest(_a, ["children", "className", "horizontal", "vertical", "shadow", "hint", "onScrolledToBottom"]);
2335
2336 var finalClassName = classNames(className, styles$4.Scrollable, vertical && styles$4.vertical, horizontal && styles$4.horizontal, topShadow && styles$4.hasTopShadow, bottomShadow && styles$4.hasBottomShadow, vertical && canScroll && styles$4.verticalHasScrolling);
2337 return React__default.createElement(ScrollableContext.Provider, {
2338 value: this.scrollToPosition
2339 }, React__default.createElement(StickyManagerContext.Provider, {
2340 value: this.stickyManager
2341 }, React__default.createElement("div", Object.assign({
2342 className: finalClassName
2343 }, scrollable.props, rest, {
2344 ref: this.setScrollArea
2345 }), children)));
2346 }
2347 }, {
2348 key: "toggleLock",
2349 value: function toggleLock() {
2350 var shouldLock = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
2351 var scrollArea = this.scrollArea;
2352
2353 if (scrollArea == null) {
2354 return;
2355 }
2356
2357 EVENTS_TO_LOCK.forEach(function (eventName) {
2358 if (shouldLock) {
2359 addEventListener(scrollArea, eventName, prevent);
2360 } else {
2361 removeEventListener(scrollArea, eventName, prevent);
2362 }
2363 });
2364 }
2365 }], [{
2366 key: "forNode",
2367 value: function forNode(node) {
2368 return closest(node, scrollable.selector) || document;
2369 }
2370 }]);
2371
2372 return Scrollable;
2373}(React__default.Component);
2374Scrollable.ScrollTo = ScrollTo;
2375
2376function prevent(evt) {
2377 evt.preventDefault();
2378}
2379
2380function prefersReducedMotion() {
2381 try {
2382 return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
2383 } catch (err) {
2384 return false;
2385 }
2386}
2387
2388var styles$5 = {
2389 "Popover": "Polaris-Popover",
2390 "PopoverOverlay": "Polaris-Popover__PopoverOverlay",
2391 "PopoverOverlay-entering": "Polaris-Popover__PopoverOverlay--entering",
2392 "PopoverOverlay-open": "Polaris-Popover__PopoverOverlay--open",
2393 "PopoverOverlay-exiting": "Polaris-Popover__PopoverOverlay--exiting",
2394 "measuring": "Polaris-Popover--measuring",
2395 "fullWidth": "Polaris-Popover--fullWidth",
2396 "Content": "Polaris-Popover__Content",
2397 "positionedAbove": "Polaris-Popover--positionedAbove",
2398 "Wrapper": "Polaris-Popover__Wrapper",
2399 "Content-fullHeight": "Polaris-Popover__Content--fullHeight",
2400 "Content-fluidContent": "Polaris-Popover__Content--fluidContent",
2401 "Pane": "Polaris-Popover__Pane",
2402 "Pane-fixed": "Polaris-Popover__Pane--fixed",
2403 "Section": "Polaris-Popover__Section",
2404 "FocusTracker": "Polaris-Popover__FocusTracker"
2405};
2406
2407function Section(_ref) {
2408 var children = _ref.children;
2409 return React__default.createElement("div", {
2410 className: styles$5.Section
2411 }, children);
2412}
2413
2414function Pane(_ref) {
2415 var fixed = _ref.fixed,
2416 sectioned = _ref.sectioned,
2417 children = _ref.children,
2418 onScrolledToBottom = _ref.onScrolledToBottom;
2419 var className = classNames(styles$5.Pane, fixed && styles$5['Pane-fixed']);
2420 var content = sectioned ? wrapWithComponent(children, Section, {}) : children;
2421 return fixed ? React__default.createElement("div", {
2422 className: className
2423 }, content) : React__default.createElement(Scrollable, {
2424 hint: true,
2425 shadow: true,
2426 className: className,
2427 onScrolledToBottom: onScrolledToBottom
2428 }, content);
2429}
2430
2431var EventListener =
2432/*#__PURE__*/
2433function (_React$PureComponent) {
2434 _inherits(EventListener, _React$PureComponent);
2435
2436 function EventListener() {
2437 _classCallCheck(this, EventListener);
2438
2439 return _possibleConstructorReturn(this, _getPrototypeOf(EventListener).apply(this, arguments));
2440 }
2441
2442 _createClass(EventListener, [{
2443 key: "componentDidMount",
2444 value: function componentDidMount() {
2445 this.attachListener();
2446 }
2447 }, {
2448 key: "componentDidUpdate",
2449 value: function componentDidUpdate(_a) {
2450 var passive = _a.passive,
2451 detachProps = __rest(_a, ["passive"]);
2452
2453 this.detachListener(detachProps);
2454 this.attachListener();
2455 }
2456 }, {
2457 key: "componentWillUnmount",
2458 value: function componentWillUnmount() {
2459 this.detachListener();
2460 }
2461 }, {
2462 key: "render",
2463 value: function render() {
2464 return null;
2465 }
2466 }, {
2467 key: "attachListener",
2468 value: function attachListener() {
2469 var _this$props = this.props,
2470 event = _this$props.event,
2471 handler = _this$props.handler,
2472 capture = _this$props.capture,
2473 passive = _this$props.passive;
2474 addEventListener(window, event, handler, {
2475 capture,
2476 passive
2477 });
2478 }
2479 }, {
2480 key: "detachListener",
2481 value: function detachListener(prevProps) {
2482 var _ref = prevProps || this.props,
2483 event = _ref.event,
2484 handler = _ref.handler,
2485 capture = _ref.capture;
2486
2487 removeEventListener(window, event, handler, capture);
2488 }
2489 }]);
2490
2491 return EventListener;
2492}(React__default.PureComponent);
2493
2494function KeypressListener(_ref) {
2495 var keyCode = _ref.keyCode,
2496 handler = _ref.handler,
2497 _ref$keyEvent = _ref.keyEvent,
2498 keyEvent = _ref$keyEvent === void 0 ? 'keyup' : _ref$keyEvent;
2499
2500 var handleKeyEvent = function handleKeyEvent(event) {
2501 if (event.keyCode === keyCode) {
2502 handler(event);
2503 }
2504 };
2505
2506 useEffect(function () {
2507 addEventListener(document, keyEvent, handleKeyEvent);
2508 return function () {
2509 removeEventListener(document, keyEvent, handleKeyEvent);
2510 };
2511 });
2512 return null;
2513}
2514
2515function calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed) {
2516 var activatorTop = activatorRect.top;
2517 var activatorBottom = activatorTop + activatorRect.height;
2518 var spaceAbove = activatorRect.top;
2519 var spaceBelow = containerRect.height - activatorRect.top - activatorRect.height;
2520 var desiredHeight = overlayRect.height;
2521 var verticalMargins = overlayMargins.activator + overlayMargins.container;
2522 var minimumSpaceToScroll = overlayMargins.container;
2523 var distanceToTopScroll = activatorRect.top - Math.max(scrollableContainerRect.top, 0);
2524 var distanceToBottomScroll = containerRect.top + Math.min(containerRect.height, scrollableContainerRect.top + scrollableContainerRect.height) - (activatorRect.top + activatorRect.height);
2525 var enoughSpaceFromTopScroll = distanceToTopScroll >= minimumSpaceToScroll;
2526 var enoughSpaceFromBottomScroll = distanceToBottomScroll >= minimumSpaceToScroll;
2527 var heightIfBelow = Math.min(spaceBelow, desiredHeight);
2528 var heightIfAbove = Math.min(spaceAbove, desiredHeight);
2529 var containerRectTop = fixed ? 0 : containerRect.top;
2530 var positionIfAbove = {
2531 height: heightIfAbove - verticalMargins,
2532 top: activatorTop + containerRectTop - heightIfAbove,
2533 positioning: 'above'
2534 };
2535 var positionIfBelow = {
2536 height: heightIfBelow - verticalMargins,
2537 top: activatorBottom + containerRectTop,
2538 positioning: 'below'
2539 };
2540
2541 if (preferredPosition === 'above') {
2542 return (enoughSpaceFromTopScroll || distanceToTopScroll >= distanceToBottomScroll && !enoughSpaceFromBottomScroll) && (spaceAbove > desiredHeight || spaceAbove > spaceBelow) ? positionIfAbove : positionIfBelow;
2543 }
2544
2545 if (preferredPosition === 'below') {
2546 return (enoughSpaceFromBottomScroll || distanceToBottomScroll >= distanceToTopScroll && !enoughSpaceFromTopScroll) && (spaceBelow > desiredHeight || spaceBelow > spaceAbove) ? positionIfBelow : positionIfAbove;
2547 }
2548
2549 if (enoughSpaceFromTopScroll && enoughSpaceFromBottomScroll) {
2550 return spaceAbove > spaceBelow ? positionIfAbove : positionIfBelow;
2551 }
2552
2553 return distanceToTopScroll > minimumSpaceToScroll ? positionIfAbove : positionIfBelow;
2554}
2555function calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment) {
2556 var maximum = containerRect.width - overlayRect.width;
2557
2558 if (preferredAlignment === 'left') {
2559 return Math.min(maximum, Math.max(0, activatorRect.left - overlayMargins.horizontal));
2560 } else if (preferredAlignment === 'right') {
2561 var activatorRight = containerRect.width - (activatorRect.left + activatorRect.width);
2562 return Math.min(maximum, Math.max(0, activatorRight - overlayMargins.horizontal));
2563 }
2564
2565 return Math.min(maximum, Math.max(0, activatorRect.center.x - overlayRect.width / 2));
2566}
2567function rectIsOutsideOfRect(inner, outer) {
2568 var center = inner.center;
2569 return center.y < outer.top || center.y > outer.top + outer.height;
2570}
2571function intersectionWithViewport(rect) {
2572 var viewport = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : windowRect();
2573 var top = Math.max(rect.top, 0);
2574 var left = Math.max(rect.left, 0);
2575 var bottom = Math.min(rect.top + rect.height, viewport.height);
2576 var right = Math.min(rect.left + rect.width, viewport.width);
2577 return new Rect({
2578 top,
2579 left,
2580 height: bottom - top,
2581 width: right - left
2582 });
2583}
2584function windowRect() {
2585 return new Rect({
2586 top: window.scrollY,
2587 left: window.scrollX,
2588 height: window.innerHeight,
2589 width: document.body.clientWidth
2590 });
2591}
2592
2593var styles$6 = {
2594 "PositionedOverlay": "Polaris-PositionedOverlay",
2595 "fixed": "Polaris-PositionedOverlay--fixed",
2596 "calculating": "Polaris-PositionedOverlay--calculating"
2597};
2598
2599var OBSERVER_CONFIG = {
2600 childList: true,
2601 subtree: true
2602};
2603var PositionedOverlay =
2604/*#__PURE__*/
2605function (_React$PureComponent) {
2606 _inherits(PositionedOverlay, _React$PureComponent);
2607
2608 function PositionedOverlay(props) {
2609 var _this;
2610
2611 _classCallCheck(this, PositionedOverlay);
2612
2613 _this = _possibleConstructorReturn(this, _getPrototypeOf(PositionedOverlay).call(this, props));
2614 _this.state = {
2615 measuring: true,
2616 activatorRect: getRectForNode(_this.props.activator),
2617 right: undefined,
2618 left: undefined,
2619 top: 0,
2620 height: 0,
2621 width: null,
2622 positioning: 'below',
2623 zIndex: null,
2624 outsideScrollableContainer: false,
2625 lockPosition: false
2626 };
2627 _this.overlay = null;
2628 _this.scrollableContainer = null;
2629
2630 _this.overlayDetails = function () {
2631 var _this$state = _this.state,
2632 measuring = _this$state.measuring,
2633 left = _this$state.left,
2634 right = _this$state.right,
2635 positioning = _this$state.positioning,
2636 height = _this$state.height,
2637 activatorRect = _this$state.activatorRect;
2638 return {
2639 measuring,
2640 left,
2641 right,
2642 desiredHeight: height,
2643 positioning,
2644 activatorRect
2645 };
2646 };
2647
2648 _this.setOverlay = function (node) {
2649 _this.overlay = node;
2650 };
2651
2652 _this.handleMeasurement = function () {
2653 var _this$state2 = _this.state,
2654 lockPosition = _this$state2.lockPosition,
2655 top = _this$state2.top;
2656
2657 _this.observer.disconnect();
2658
2659 _this.setState(function (_ref) {
2660 var left = _ref.left,
2661 top = _ref.top,
2662 right = _ref.right;
2663 return {
2664 left,
2665 right,
2666 top,
2667 height: 0,
2668 positioning: 'below',
2669 measuring: true
2670 };
2671 }, function () {
2672 if (_this.overlay == null || _this.scrollableContainer == null) {
2673 return;
2674 }
2675
2676 var _this$props = _this.props,
2677 activator = _this$props.activator,
2678 _this$props$preferred = _this$props.preferredPosition,
2679 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred,
2680 _this$props$preferred2 = _this$props.preferredAlignment,
2681 preferredAlignment = _this$props$preferred2 === void 0 ? 'center' : _this$props$preferred2,
2682 onScrollOut = _this$props.onScrollOut,
2683 fullWidth = _this$props.fullWidth,
2684 fixed = _this$props.fixed,
2685 _this$props$preferInp = _this$props.preferInputActivator,
2686 preferInputActivator = _this$props$preferInp === void 0 ? true : _this$props$preferInp;
2687 var preferredActivator = preferInputActivator ? activator.querySelector('input') || activator : activator;
2688 var activatorRect = getRectForNode(preferredActivator);
2689 var currentOverlayRect = getRectForNode(_this.overlay);
2690 var scrollableElement = isDocument$1(_this.scrollableContainer) ? document.body : _this.scrollableContainer;
2691 var scrollableContainerRect = getRectForNode(scrollableElement);
2692 var overlayRect = fullWidth ? Object.assign(Object.assign({}, currentOverlayRect), {
2693 width: activatorRect.width
2694 }) : currentOverlayRect; // If `body` is 100% height, it still acts as though it were not constrained to that size. This adjusts for that.
2695
2696 if (scrollableElement === document.body) {
2697 scrollableContainerRect.height = document.body.scrollHeight;
2698 }
2699
2700 var overlayMargins = _this.overlay.firstElementChild ? getMarginsForNode(_this.overlay.firstElementChild) : {
2701 activator: 0,
2702 container: 0,
2703 horizontal: 0
2704 };
2705 var containerRect = windowRect();
2706 var zIndexForLayer = getZIndexForLayerFromNode(activator);
2707 var zIndex = zIndexForLayer == null ? zIndexForLayer : zIndexForLayer + 1;
2708 var verticalPosition = calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed);
2709 var horizontalPosition = calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment);
2710
2711 _this.setState({
2712 measuring: false,
2713 activatorRect: getRectForNode(activator),
2714 left: preferredAlignment !== 'right' ? horizontalPosition : undefined,
2715 right: preferredAlignment === 'right' ? horizontalPosition : undefined,
2716 top: lockPosition ? top : verticalPosition.top,
2717 lockPosition: Boolean(fixed),
2718 height: verticalPosition.height || 0,
2719 width: fullWidth ? overlayRect.width : null,
2720 positioning: verticalPosition.positioning,
2721 outsideScrollableContainer: onScrollOut != null && rectIsOutsideOfRect(activatorRect, intersectionWithViewport(scrollableContainerRect)),
2722 zIndex
2723 }, function () {
2724 if (!_this.overlay) return;
2725
2726 _this.observer.observe(_this.overlay, OBSERVER_CONFIG);
2727 });
2728 });
2729 };
2730
2731 _this.observer = new MutationObserver(_this.handleMeasurement);
2732 return _this;
2733 }
2734
2735 _createClass(PositionedOverlay, [{
2736 key: "componentDidMount",
2737 value: function componentDidMount() {
2738 this.scrollableContainer = Scrollable.forNode(this.props.activator);
2739
2740 if (this.scrollableContainer && !this.props.fixed) {
2741 this.scrollableContainer.addEventListener('scroll', this.handleMeasurement);
2742 }
2743
2744 this.handleMeasurement();
2745 }
2746 }, {
2747 key: "componentWillUnmount",
2748 value: function componentWillUnmount() {
2749 if (this.scrollableContainer && !this.props.fixed) {
2750 this.scrollableContainer.removeEventListener('scroll', this.handleMeasurement);
2751 }
2752 }
2753 }, {
2754 key: "componentDidUpdate",
2755 value: function componentDidUpdate() {
2756 var _this$state3 = this.state,
2757 outsideScrollableContainer = _this$state3.outsideScrollableContainer,
2758 top = _this$state3.top;
2759 var _this$props2 = this.props,
2760 onScrollOut = _this$props2.onScrollOut,
2761 active = _this$props2.active;
2762
2763 if (active && onScrollOut != null && top !== 0 && outsideScrollableContainer) {
2764 onScrollOut();
2765 }
2766 }
2767 }, {
2768 key: "render",
2769 value: function render() {
2770 var _this$state4 = this.state,
2771 left = _this$state4.left,
2772 right = _this$state4.right,
2773 top = _this$state4.top,
2774 zIndex = _this$state4.zIndex,
2775 width = _this$state4.width;
2776 var _this$props3 = this.props,
2777 render = _this$props3.render,
2778 fixed = _this$props3.fixed,
2779 propClassNames = _this$props3.classNames;
2780 var style = {
2781 top: top == null || isNaN(top) ? undefined : top,
2782 left: left == null || isNaN(left) ? undefined : left,
2783 right: right == null || isNaN(right) ? undefined : right,
2784 width: width == null || isNaN(width) ? undefined : width,
2785 zIndex: zIndex == null || isNaN(zIndex) ? undefined : zIndex
2786 };
2787 var className = classNames(styles$6.PositionedOverlay, fixed && styles$6.fixed, propClassNames);
2788 return React__default.createElement("div", {
2789 className: className,
2790 style: style,
2791 ref: this.setOverlay
2792 }, React__default.createElement(EventListener, {
2793 event: "resize",
2794 handler: this.handleMeasurement
2795 }), render(this.overlayDetails()));
2796 }
2797 }]);
2798
2799 return PositionedOverlay;
2800}(React__default.PureComponent);
2801
2802function getMarginsForNode(node) {
2803 var nodeStyles = window.getComputedStyle(node);
2804 return {
2805 activator: parseFloat(nodeStyles.marginTop || '0'),
2806 container: parseFloat(nodeStyles.marginBottom || '0'),
2807 horizontal: parseFloat(nodeStyles.marginLeft || '0')
2808 };
2809}
2810
2811function getZIndexForLayerFromNode(node) {
2812 var layerNode = closest(node, layer.selector) || document.body;
2813 var zIndex = layerNode === document.body ? 'auto' : parseInt(window.getComputedStyle(layerNode).zIndex || '0', 10);
2814 return zIndex === 'auto' || isNaN(zIndex) ? null : zIndex;
2815}
2816
2817function isDocument$1(node) {
2818 return node === document;
2819}
2820
2821var PopoverCloseSource;
2822
2823(function (PopoverCloseSource) {
2824 PopoverCloseSource[PopoverCloseSource["Click"] = 0] = "Click";
2825 PopoverCloseSource[PopoverCloseSource["EscapeKeypress"] = 1] = "EscapeKeypress";
2826 PopoverCloseSource[PopoverCloseSource["FocusOut"] = 2] = "FocusOut";
2827 PopoverCloseSource[PopoverCloseSource["ScrollOut"] = 3] = "ScrollOut";
2828})(PopoverCloseSource || (PopoverCloseSource = {}));
2829
2830var TransitionStatus;
2831
2832(function (TransitionStatus) {
2833 TransitionStatus["Entering"] = "entering";
2834 TransitionStatus["Entered"] = "entered";
2835 TransitionStatus["Exiting"] = "exiting";
2836 TransitionStatus["Exited"] = "exited";
2837})(TransitionStatus || (TransitionStatus = {}));
2838
2839var PopoverOverlay =
2840/*#__PURE__*/
2841function (_React$PureComponent) {
2842 _inherits(PopoverOverlay, _React$PureComponent);
2843
2844 function PopoverOverlay() {
2845 var _this;
2846
2847 _classCallCheck(this, PopoverOverlay);
2848
2849 _this = _possibleConstructorReturn(this, _getPrototypeOf(PopoverOverlay).apply(this, arguments));
2850 _this.state = {
2851 transitionStatus: _this.props.active ? TransitionStatus.Entering : TransitionStatus.Exited
2852 };
2853 _this.contentNode = createRef();
2854
2855 _this.renderPopover = function (overlayDetails) {
2856 var measuring = overlayDetails.measuring,
2857 desiredHeight = overlayDetails.desiredHeight,
2858 positioning = overlayDetails.positioning;
2859 var _this$props = _this.props,
2860 id = _this$props.id,
2861 children = _this$props.children,
2862 sectioned = _this$props.sectioned,
2863 fullWidth = _this$props.fullWidth,
2864 fullHeight = _this$props.fullHeight,
2865 fluidContent = _this$props.fluidContent;
2866 var className = classNames(styles$5.Popover, positioning === 'above' && styles$5.positionedAbove, fullWidth && styles$5.fullWidth, measuring && styles$5.measuring);
2867 var contentStyles = measuring ? undefined : {
2868 height: desiredHeight
2869 };
2870 var contentClassNames = classNames(styles$5.Content, fullHeight && styles$5['Content-fullHeight'], fluidContent && styles$5['Content-fluidContent']);
2871 var content = React__default.createElement("div", {
2872 id: id,
2873 tabIndex: -1,
2874 className: contentClassNames,
2875 style: contentStyles,
2876 ref: _this.contentNode
2877 }, renderPopoverContent(children, {
2878 sectioned
2879 }));
2880 return React__default.createElement("div", Object.assign({
2881 className: className
2882 }, overlay.props), React__default.createElement(EventListener, {
2883 event: "click",
2884 handler: _this.handleClick
2885 }), React__default.createElement(EventListener, {
2886 event: "touchstart",
2887 handler: _this.handleClick
2888 }), React__default.createElement(KeypressListener, {
2889 keyCode: Key.Escape,
2890 handler: _this.handleEscape
2891 }), React__default.createElement("div", {
2892 className: styles$5.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
2893 ,
2894 tabIndex: 0,
2895 onFocus: _this.handleFocusFirstItem
2896 }), React__default.createElement("div", {
2897 className: styles$5.Wrapper
2898 }, content), React__default.createElement("div", {
2899 className: styles$5.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
2900 ,
2901 tabIndex: 0,
2902 onFocus: _this.handleFocusLastItem
2903 }));
2904 };
2905
2906 _this.handleClick = function (event) {
2907 var target = event.target;
2908
2909 var _assertThisInitialize = _assertThisInitialized(_this),
2910 contentNode = _assertThisInitialize.contentNode,
2911 _assertThisInitialize2 = _assertThisInitialize.props,
2912 activator = _assertThisInitialize2.activator,
2913 onClose = _assertThisInitialize2.onClose;
2914
2915 var isDescendant = contentNode.current != null && nodeContainsDescendant(contentNode.current, target);
2916 var isActivatorDescendant = nodeContainsDescendant(activator, target);
2917
2918 if (isDescendant || isActivatorDescendant || _this.state.transitionStatus !== TransitionStatus.Entered) {
2919 return;
2920 }
2921
2922 onClose(PopoverCloseSource.Click);
2923 };
2924
2925 _this.handleScrollOut = function () {
2926 _this.props.onClose(PopoverCloseSource.ScrollOut);
2927 };
2928
2929 _this.handleEscape = function () {
2930 _this.props.onClose(PopoverCloseSource.EscapeKeypress);
2931 };
2932
2933 _this.handleFocusFirstItem = function () {
2934 _this.props.onClose(PopoverCloseSource.FocusOut);
2935 };
2936
2937 _this.handleFocusLastItem = function () {
2938 _this.props.onClose(PopoverCloseSource.FocusOut);
2939 };
2940
2941 return _this;
2942 }
2943
2944 _createClass(PopoverOverlay, [{
2945 key: "changeTransitionStatus",
2946 value: function changeTransitionStatus(transitionStatus, cb) {
2947 this.setState({
2948 transitionStatus
2949 }, cb); // Forcing a reflow to enable the animation
2950
2951 this.contentNode.current && this.contentNode.current.getBoundingClientRect();
2952 }
2953 }, {
2954 key: "componentDidMount",
2955 value: function componentDidMount() {
2956 if (this.props.active) {
2957 this.focusContent();
2958 this.changeTransitionStatus(TransitionStatus.Entered);
2959 }
2960 }
2961 }, {
2962 key: "componentDidUpdate",
2963 value: function componentDidUpdate(oldProps) {
2964 var _this2 = this;
2965
2966 if (this.props.active && !oldProps.active) {
2967 this.focusContent();
2968 this.changeTransitionStatus(TransitionStatus.Entering, function () {
2969 _this2.clearTransitionTimeout();
2970
2971 _this2.enteringTimer = window.setTimeout(function () {
2972 _this2.setState({
2973 transitionStatus: TransitionStatus.Entered
2974 });
2975 }, durationBase);
2976 });
2977 }
2978
2979 if (!this.props.active && oldProps.active) {
2980 this.changeTransitionStatus(TransitionStatus.Exiting, function () {
2981 _this2.clearTransitionTimeout();
2982
2983 _this2.exitingTimer = window.setTimeout(function () {
2984 _this2.setState({
2985 transitionStatus: TransitionStatus.Exited
2986 });
2987 }, durationBase);
2988 });
2989 }
2990 }
2991 }, {
2992 key: "componentWillUnmount",
2993 value: function componentWillUnmount() {
2994 this.clearTransitionTimeout();
2995 }
2996 }, {
2997 key: "render",
2998 value: function render() {
2999 var _this$props2 = this.props,
3000 active = _this$props2.active,
3001 activator = _this$props2.activator,
3002 fullWidth = _this$props2.fullWidth,
3003 _this$props2$preferre = _this$props2.preferredPosition,
3004 preferredPosition = _this$props2$preferre === void 0 ? 'below' : _this$props2$preferre,
3005 _this$props2$preferre2 = _this$props2.preferredAlignment,
3006 preferredAlignment = _this$props2$preferre2 === void 0 ? 'center' : _this$props2$preferre2,
3007 _this$props2$preferIn = _this$props2.preferInputActivator,
3008 preferInputActivator = _this$props2$preferIn === void 0 ? true : _this$props2$preferIn,
3009 fixed = _this$props2.fixed;
3010 var transitionStatus = this.state.transitionStatus;
3011 if (transitionStatus === TransitionStatus.Exited && !active) return null;
3012 var className = classNames(styles$5.PopoverOverlay, transitionStatus === TransitionStatus.Entering && styles$5['PopoverOverlay-entering'], transitionStatus === TransitionStatus.Entered && styles$5['PopoverOverlay-open'], transitionStatus === TransitionStatus.Exiting && styles$5['PopoverOverlay-exiting']);
3013 return React__default.createElement(PositionedOverlay, {
3014 fullWidth: fullWidth,
3015 active: active,
3016 activator: activator,
3017 preferInputActivator: preferInputActivator,
3018 preferredPosition: preferredPosition,
3019 preferredAlignment: preferredAlignment,
3020 render: this.renderPopover.bind(this),
3021 fixed: fixed,
3022 onScrollOut: this.handleScrollOut,
3023 classNames: className
3024 });
3025 }
3026 }, {
3027 key: "clearTransitionTimeout",
3028 value: function clearTransitionTimeout() {
3029 if (this.enteringTimer) {
3030 window.clearTimeout(this.enteringTimer);
3031 }
3032
3033 if (this.exitingTimer) {
3034 window.clearTimeout(this.exitingTimer);
3035 }
3036 }
3037 }, {
3038 key: "focusContent",
3039 value: function focusContent() {
3040 var _this3 = this;
3041
3042 if (this.props.preventAutofocus) {
3043 return;
3044 }
3045
3046 if (this.contentNode == null) {
3047 return;
3048 }
3049
3050 write(function () {
3051 if (_this3.contentNode.current == null) {
3052 return;
3053 }
3054
3055 _this3.contentNode.current.focus({
3056 preventScroll: process.env.NODE_ENV === 'development'
3057 });
3058 });
3059 }
3060 }]);
3061
3062 return PopoverOverlay;
3063}(React__default.PureComponent);
3064
3065function renderPopoverContent(children, props) {
3066 var childrenArray = React__default.Children.toArray(children);
3067
3068 if (isElementOfType(childrenArray[0], Pane)) {
3069 return childrenArray;
3070 }
3071
3072 return wrapWithComponent(childrenArray, Pane, props);
3073}
3074
3075function setActivatorAttributes(activator, _ref) {
3076 var id = _ref.id,
3077 active = _ref.active,
3078 ariaHaspopup = _ref.ariaHaspopup;
3079 activator.tabIndex = activator.tabIndex || 0;
3080 activator.setAttribute('aria-controls', id);
3081 activator.setAttribute('aria-owns', id);
3082 activator.setAttribute('aria-expanded', String(active));
3083
3084 if (ariaHaspopup != null) {
3085 activator.setAttribute('aria-haspopup', String(ariaHaspopup));
3086 }
3087}
3088
3089// subcomponents so explicitly state the subcomponents in the type definition.
3090// Letting this be implicit works in this project but fails in projects that use
3091// generated *.d.ts files.
3092
3093var Popover = function Popover(_a) {
3094 var _a$activatorWrapper = _a.activatorWrapper,
3095 activatorWrapper = _a$activatorWrapper === void 0 ? 'div' : _a$activatorWrapper,
3096 children = _a.children,
3097 onClose = _a.onClose,
3098 activator = _a.activator,
3099 active = _a.active,
3100 fixed = _a.fixed,
3101 ariaHaspopup = _a.ariaHaspopup,
3102 _a$preferInputActivat = _a.preferInputActivator,
3103 preferInputActivator = _a$preferInputActivat === void 0 ? true : _a$preferInputActivat,
3104 rest = __rest(_a, ["activatorWrapper", "children", "onClose", "activator", "active", "fixed", "ariaHaspopup", "preferInputActivator"]);
3105
3106 var _useState = useState(),
3107 _useState2 = _slicedToArray(_useState, 2),
3108 activatorNode = _useState2[0],
3109 setActivatorNode = _useState2[1];
3110
3111 var activatorContainer = useRef(null);
3112 var WrapperComponent = activatorWrapper;
3113 var id = useUniqueId('popover');
3114 var setAccessibilityAttributes = useCallback(function () {
3115 if (activatorContainer.current == null) {
3116 return;
3117 }
3118
3119 var firstFocusable = findFirstFocusableNode(activatorContainer.current);
3120 var focusableActivator = firstFocusable || activatorContainer.current;
3121 setActivatorAttributes(focusableActivator, {
3122 id,
3123 active,
3124 ariaHaspopup
3125 });
3126 }, [active, ariaHaspopup, id]);
3127
3128 var handleClose = function handleClose(source) {
3129 onClose(source);
3130
3131 if (activatorContainer.current == null) {
3132 return;
3133 }
3134
3135 if ((source === PopoverCloseSource.FocusOut || source === PopoverCloseSource.EscapeKeypress) && activatorNode) {
3136 var focusableActivator = findFirstFocusableNode(activatorNode) || findFirstFocusableNode(activatorContainer.current) || activatorContainer.current;
3137
3138 if (!focusNextFocusableNode(focusableActivator, isInPortal)) {
3139 focusableActivator.focus();
3140 }
3141 }
3142 };
3143
3144 useEffect(function () {
3145 if (!activatorNode && activatorContainer.current) {
3146 setActivatorNode(activatorContainer.current.firstElementChild);
3147 } else if (activatorNode && activatorContainer.current && !activatorContainer.current.contains(activatorNode)) {
3148 setActivatorNode(activatorContainer.current.firstElementChild);
3149 }
3150
3151 setAccessibilityAttributes();
3152 }, [activatorNode, setAccessibilityAttributes]);
3153 useEffect(function () {
3154 if (activatorNode && activatorContainer.current) {
3155 setActivatorNode(activatorContainer.current.firstElementChild);
3156 }
3157
3158 setAccessibilityAttributes();
3159 }, [activatorNode, setAccessibilityAttributes]);
3160 var portal = activatorNode ? React__default.createElement(Portal, {
3161 idPrefix: "popover"
3162 }, React__default.createElement(PopoverOverlay, Object.assign({
3163 id: id,
3164 activator: activatorNode,
3165 preferInputActivator: preferInputActivator,
3166 onClose: handleClose,
3167 active: active,
3168 fixed: fixed
3169 }, rest), children)) : null;
3170 return React__default.createElement(WrapperComponent, {
3171 ref: activatorContainer
3172 }, React__default.Children.only(activator), portal);
3173};
3174
3175function isInPortal(element) {
3176 var parentElement = element.parentElement;
3177
3178 while (parentElement) {
3179 if (parentElement.matches(portal.selector)) return false;
3180 parentElement = parentElement.parentElement;
3181 }
3182
3183 return true;
3184}
3185
3186Popover.Pane = Pane;
3187Popover.Section = Section;
3188
3189var styles$7 = {
3190 "Badge": "Polaris-Badge",
3191 "Pip": "Polaris-Badge__Pip",
3192 "sizeSmall": "Polaris-Badge--sizeSmall",
3193 "statusSuccess": "Polaris-Badge--statusSuccess",
3194 "Content": "Polaris-Badge__Content",
3195 "statusInfo": "Polaris-Badge--statusInfo",
3196 "statusAttention": "Polaris-Badge--statusAttention",
3197 "statusWarning": "Polaris-Badge--statusWarning",
3198 "statusNew": "Polaris-Badge--statusNew",
3199 "progressIncomplete": "Polaris-Badge--progressIncomplete",
3200 "progressPartiallyComplete": "Polaris-Badge--progressPartiallyComplete",
3201 "progressComplete": "Polaris-Badge--progressComplete"
3202};
3203
3204var PROGRESS_LABELS = {
3205 incomplete: 'incomplete',
3206 partiallyComplete: 'partiallyComplete',
3207 complete: 'complete'
3208};
3209var STATUS_LABELS = {
3210 info: 'info',
3211 success: 'success',
3212 warning: 'warning',
3213 attention: 'attention',
3214 new: 'new'
3215};
3216var DEFAULT_SIZE = 'medium';
3217function Badge(_ref) {
3218 var children = _ref.children,
3219 status = _ref.status,
3220 progress = _ref.progress,
3221 _ref$size = _ref.size,
3222 size = _ref$size === void 0 ? DEFAULT_SIZE : _ref$size;
3223 var i18n = useI18n();
3224 var className = classNames(styles$7.Badge, status && styles$7[variationName('status', status)], progress && styles$7[variationName('progress', progress)], size && size !== DEFAULT_SIZE && styles$7[variationName('size', size)]);
3225 var progressMarkup;
3226
3227 switch (progress) {
3228 case PROGRESS_LABELS.incomplete:
3229 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.incomplete');
3230 break;
3231
3232 case PROGRESS_LABELS.partiallyComplete:
3233 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.partiallyComplete');
3234 break;
3235
3236 case PROGRESS_LABELS.complete:
3237 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.complete');
3238 break;
3239 }
3240
3241 var pipMarkup = progress ? React__default.createElement("span", {
3242 className: styles$7.Pip
3243 }, React__default.createElement(VisuallyHidden, null, progressMarkup)) : null;
3244 var statusMarkup;
3245
3246 switch (status) {
3247 case STATUS_LABELS.info:
3248 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.info');
3249 break;
3250
3251 case STATUS_LABELS.success:
3252 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.success');
3253 break;
3254
3255 case STATUS_LABELS.warning:
3256 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.warning');
3257 break;
3258
3259 case STATUS_LABELS.attention:
3260 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.attention');
3261 break;
3262
3263 case STATUS_LABELS.new:
3264 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.new');
3265 break;
3266 }
3267
3268 var statusLabelMarkup = status ? React__default.createElement(VisuallyHidden, null, statusMarkup) : null;
3269 return React__default.createElement("span", {
3270 className: className
3271 }, statusLabelMarkup, pipMarkup, React__default.createElement("span", {
3272 className: styles$7.Content
3273 }, children));
3274}
3275
3276var styles$8 = {
3277 "variationPositive": "Polaris-TextStyle--variationPositive",
3278 "variationNegative": "Polaris-TextStyle--variationNegative",
3279 "variationCode": "Polaris-TextStyle--variationCode",
3280 "variationStrong": "Polaris-TextStyle--variationStrong",
3281 "variationSubdued": "Polaris-TextStyle--variationSubdued"
3282};
3283
3284var VariationValue;
3285
3286(function (VariationValue) {
3287 VariationValue["Positive"] = "positive";
3288 VariationValue["Negative"] = "negative";
3289 VariationValue["Strong"] = "strong";
3290 VariationValue["Subdued"] = "subdued";
3291 VariationValue["Code"] = "code";
3292})(VariationValue || (VariationValue = {}));
3293
3294function TextStyle(_ref) {
3295 var variation = _ref.variation,
3296 children = _ref.children;
3297 var className = classNames(variation && styles$8[variationName('variation', variation)], variation === VariationValue.Code && styles$8.code);
3298 var Element = variationElement(variation);
3299 return React__default.createElement(Element, {
3300 className: className
3301 }, children);
3302}
3303
3304function variationElement(variation) {
3305 return variation === VariationValue.Code ? 'code' : 'span';
3306}
3307
3308var styles$9 = {
3309 "ActionList": "Polaris-ActionList",
3310 "newDesignLanguage": "Polaris-ActionList--newDesignLanguage",
3311 "Section-withoutTitle": "Polaris-ActionList__Section--withoutTitle",
3312 "Actions": "Polaris-ActionList__Actions",
3313 "Section": "Polaris-ActionList__Section",
3314 "Title": "Polaris-ActionList__Title",
3315 "Item": "Polaris-ActionList__Item",
3316 "active": "Polaris-ActionList--active",
3317 "destructive": "Polaris-ActionList--destructive",
3318 "disabled": "Polaris-ActionList--disabled",
3319 "Image": "Polaris-ActionList__Image",
3320 "Content": "Polaris-ActionList__Content",
3321 "Text": "Polaris-ActionList__Text",
3322 "BadgeWrapper": "Polaris-ActionList__BadgeWrapper"
3323};
3324
3325function Item(_ref) {
3326 var id = _ref.id,
3327 badge = _ref.badge,
3328 content = _ref.content,
3329 accessibilityLabel = _ref.accessibilityLabel,
3330 helpText = _ref.helpText,
3331 url = _ref.url,
3332 onAction = _ref.onAction,
3333 icon = _ref.icon,
3334 image = _ref.image,
3335 disabled = _ref.disabled,
3336 external = _ref.external,
3337 destructive = _ref.destructive,
3338 ellipsis = _ref.ellipsis,
3339 active = _ref.active,
3340 role = _ref.role;
3341
3342 var _useFeatures = useFeatures(),
3343 newDesignLanguage = _useFeatures.newDesignLanguage;
3344
3345 var className = classNames(styles$9.Item, disabled && styles$9.disabled, destructive && styles$9.destructive, active && styles$9.active, newDesignLanguage && styles$9.newDesignLanguage);
3346 var imageElement = null;
3347
3348 if (icon) {
3349 imageElement = React__default.createElement("div", {
3350 className: styles$9.Image
3351 }, React__default.createElement(Icon, {
3352 source: icon
3353 }));
3354 } else if (image) {
3355 imageElement = React__default.createElement("div", {
3356 role: "presentation",
3357 className: styles$9.Image,
3358 style: {
3359 backgroundImage: "url(".concat(image)
3360 }
3361 });
3362 }
3363
3364 var contentText = ellipsis && content ? "".concat(content, "\u2026") : content;
3365 var contentMarkup = helpText ? React__default.createElement("div", null, React__default.createElement("div", null, contentText), React__default.createElement(TextStyle, {
3366 variation: "subdued"
3367 }, helpText)) : contentText;
3368 var badgeMarkup = badge && React__default.createElement("span", {
3369 className: styles$9.BadgeWrapper
3370 }, React__default.createElement(Badge, {
3371 status: badge.status
3372 }, badge.content));
3373 var textMarkup = imageElement ? React__default.createElement("div", {
3374 className: styles$9.Text
3375 }, contentMarkup) : contentMarkup;
3376 var contentElement = React__default.createElement("div", {
3377 className: styles$9.Content
3378 }, imageElement, textMarkup, badgeMarkup);
3379 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
3380 var control = url ? React__default.createElement(UnstyledLink, {
3381 id: id,
3382 url: url,
3383 className: className,
3384 external: external,
3385 "aria-label": accessibilityLabel,
3386 onClick: onAction
3387 }, contentElement) : React__default.createElement("button", {
3388 id: id,
3389 type: "button",
3390 className: className,
3391 disabled: disabled,
3392 "aria-label": accessibilityLabel,
3393 onClick: onAction
3394 }, contentElement);
3395 return React__default.createElement("li", {
3396 role: role,
3397 "aria-selected": active
3398 }, scrollMarkup, control);
3399}
3400
3401function Section$1(_ref) {
3402 var section = _ref.section,
3403 hasMultipleSections = _ref.hasMultipleSections,
3404 actionRole = _ref.actionRole,
3405 onActionAnyItem = _ref.onActionAnyItem;
3406
3407 var handleAction = function handleAction(itemOnAction) {
3408 return function () {
3409 if (itemOnAction) {
3410 itemOnAction();
3411 }
3412
3413 if (onActionAnyItem) {
3414 onActionAnyItem();
3415 }
3416 };
3417 };
3418
3419 var actionMarkup = section.items.map(function (_a, index) {
3420 var content = _a.content,
3421 helpText = _a.helpText,
3422 onAction = _a.onAction,
3423 item = __rest(_a, ["content", "helpText", "onAction"]);
3424
3425 return React__default.createElement(Item, Object.assign({
3426 key: "".concat(content, "-").concat(index),
3427 content: content,
3428 helpText: helpText,
3429 role: actionRole,
3430 onAction: handleAction(onAction)
3431 }, item));
3432 });
3433 var className = section.title ? undefined : styles$9['Section-withoutTitle'];
3434 var titleMarkup = section.title ? React__default.createElement("p", {
3435 className: styles$9.Title
3436 }, section.title) : null;
3437 var sectionRole = actionRole === 'option' ? 'presentation' : undefined;
3438 var sectionMarkup = React__default.createElement("div", {
3439 className: className
3440 }, titleMarkup, React__default.createElement("ul", {
3441 className: styles$9.Actions,
3442 role: sectionRole
3443 }, actionMarkup));
3444 return hasMultipleSections ? React__default.createElement("li", {
3445 className: styles$9.Section
3446 }, sectionMarkup) : sectionMarkup;
3447}
3448
3449function ActionList(_ref) {
3450 var items = _ref.items,
3451 _ref$sections = _ref.sections,
3452 sections = _ref$sections === void 0 ? [] : _ref$sections,
3453 actionRole = _ref.actionRole,
3454 onActionAnyItem = _ref.onActionAnyItem;
3455 var finalSections = [];
3456
3457 if (items) {
3458 finalSections = [{
3459 items
3460 }].concat(_toConsumableArray(sections));
3461 } else if (sections) {
3462 finalSections = sections;
3463 }
3464
3465 var _useFeatures = useFeatures(),
3466 newDesignLanguage = _useFeatures.newDesignLanguage;
3467
3468 var className = classNames(styles$9.ActionList, newDesignLanguage && styles$9.newDesignLanguage);
3469 var hasMultipleSections = finalSections.length > 1; // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
3470 // see https://github.com/Microsoft/TypeScript/issues/28768
3471
3472 var Element = hasMultipleSections ? 'ul' : 'div';
3473 var sectionMarkup = finalSections.map(function (section, index) {
3474 return section.items.length > 0 ? React__default.createElement(Section$1, {
3475 key: section.title || index,
3476 section: section,
3477 hasMultipleSections: hasMultipleSections,
3478 actionRole: actionRole,
3479 onActionAnyItem: onActionAnyItem
3480 }) : null;
3481 });
3482 return React__default.createElement(Element, {
3483 className: className
3484 }, sectionMarkup);
3485}
3486
3487var styles$a = {
3488 "Button": "Polaris-Button",
3489 "newDesignLanguage": "Polaris-Button--newDesignLanguage",
3490 "disabled": "Polaris-Button--disabled",
3491 "connectedDisclosure": "Polaris-Button--connectedDisclosure",
3492 "Content": "Polaris-Button__Content",
3493 "textAlignLeft": "Polaris-Button--textAlignLeft",
3494 "textAlignCenter": "Polaris-Button--textAlignCenter",
3495 "textAlignRight": "Polaris-Button--textAlignRight",
3496 "Icon": "Polaris-Button__Icon",
3497 "Spinner": "Polaris-Button__Spinner",
3498 "primary": "Polaris-Button--primary",
3499 "pressed": "Polaris-Button--pressed",
3500 "destructive": "Polaris-Button--destructive",
3501 "outline": "Polaris-Button--outline",
3502 "loading": "Polaris-Button--loading",
3503 "plain": "Polaris-Button--plain",
3504 "iconOnly": "Polaris-Button--iconOnly",
3505 "fullWidth": "Polaris-Button--fullWidth",
3506 "sizeSlim": "Polaris-Button--sizeSlim",
3507 "sizeLarge": "Polaris-Button--sizeLarge",
3508 "monochrome": "Polaris-Button--monochrome",
3509 "Text": "Polaris-Button__Text",
3510 "DisclosureIcon": "Polaris-Button__DisclosureIcon",
3511 "DisclosureIconFacingUp": "Polaris-Button__DisclosureIconFacingUp",
3512 "ConnectedDisclosureWrapper": "Polaris-Button__ConnectedDisclosureWrapper",
3513 "ConnectedDisclosure": "Polaris-Button__ConnectedDisclosure"
3514};
3515
3516var DEFAULT_SIZE$1 = 'medium';
3517function Button(_ref) {
3518 var id = _ref.id,
3519 url = _ref.url,
3520 disabled = _ref.disabled,
3521 loading = _ref.loading,
3522 children = _ref.children,
3523 accessibilityLabel = _ref.accessibilityLabel,
3524 ariaControls = _ref.ariaControls,
3525 ariaExpanded = _ref.ariaExpanded,
3526 ariaPressed = _ref.ariaPressed,
3527 onClick = _ref.onClick,
3528 onFocus = _ref.onFocus,
3529 onBlur = _ref.onBlur,
3530 onKeyDown = _ref.onKeyDown,
3531 onKeyPress = _ref.onKeyPress,
3532 onKeyUp = _ref.onKeyUp,
3533 onMouseEnter = _ref.onMouseEnter,
3534 onTouchStart = _ref.onTouchStart,
3535 external = _ref.external,
3536 download = _ref.download,
3537 icon = _ref.icon,
3538 primary = _ref.primary,
3539 outline = _ref.outline,
3540 destructive = _ref.destructive,
3541 disclosure = _ref.disclosure,
3542 plain = _ref.plain,
3543 monochrome = _ref.monochrome,
3544 submit = _ref.submit,
3545 _ref$size = _ref.size,
3546 size = _ref$size === void 0 ? DEFAULT_SIZE$1 : _ref$size,
3547 textAlign = _ref.textAlign,
3548 fullWidth = _ref.fullWidth,
3549 pressed = _ref.pressed,
3550 connectedDisclosure = _ref.connectedDisclosure;
3551
3552 var _useFeatures = useFeatures(),
3553 newDesignLanguage = _useFeatures.newDesignLanguage;
3554
3555 var hasGivenDeprecationWarning = useRef(false);
3556
3557 if (ariaPressed && !hasGivenDeprecationWarning.current) {
3558 // eslint-disable-next-line no-console
3559 console.warn('Deprecation: The ariaPressed prop has been replaced with pressed');
3560 hasGivenDeprecationWarning.current = true;
3561 }
3562
3563 var i18n = useI18n();
3564 var isDisabled = disabled || loading;
3565 var className = classNames(styles$a.Button, newDesignLanguage && styles$a.newDesignLanguage, primary && styles$a.primary, outline && styles$a.outline, destructive && styles$a.destructive, isDisabled && styles$a.disabled, loading && styles$a.loading, plain && styles$a.plain, pressed && !disabled && !url && styles$a.pressed, monochrome && styles$a.monochrome, size && size !== DEFAULT_SIZE$1 && styles$a[variationName('size', size)], textAlign && styles$a[variationName('textAlign', textAlign)], fullWidth && styles$a.fullWidth, icon && children == null && styles$a.iconOnly, connectedDisclosure && styles$a.connectedDisclosure);
3566 var disclosureIcon = React__default.createElement(Icon, {
3567 source: loading ? 'placeholder' : CaretDownMinor
3568 });
3569 var disclosureIconMarkup = disclosure ? React__default.createElement("span", {
3570 className: styles$a.Icon
3571 }, React__default.createElement("div", {
3572 className: classNames(styles$a.DisclosureIcon, disclosure === 'up' && styles$a.DisclosureIconFacingUp)
3573 }, disclosureIcon)) : null;
3574 var iconMarkup;
3575
3576 if (icon) {
3577 var iconInner = isIconSource(icon) ? React__default.createElement(Icon, {
3578 source: loading ? 'placeholder' : icon
3579 }) : icon;
3580 iconMarkup = React__default.createElement("span", {
3581 className: styles$a.Icon
3582 }, iconInner);
3583 }
3584
3585 var childMarkup = children ? React__default.createElement("span", {
3586 className: styles$a.Text
3587 }, children) : null;
3588 var spinnerColor = primary || destructive ? 'white' : 'inkLightest';
3589 var spinnerSVGMarkup = loading ? React__default.createElement("span", {
3590 className: styles$a.Spinner
3591 }, React__default.createElement(Spinner, {
3592 size: "small",
3593 color: spinnerColor,
3594 accessibilityLabel: i18n.translate('Polaris.Button.spinnerAccessibilityLabel')
3595 })) : null;
3596 var content = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
3597 className: styles$a.Content
3598 }, spinnerSVGMarkup, iconMarkup, childMarkup, disclosureIconMarkup) : React__default.createElement("span", {
3599 className: styles$a.Content
3600 }, spinnerSVGMarkup, childMarkup);
3601 var type = submit ? 'submit' : 'button';
3602 var ariaPressedStatus = pressed !== undefined ? pressed : ariaPressed;
3603
3604 var _useState = useState(false),
3605 _useState2 = _slicedToArray(_useState, 2),
3606 disclosureActive = _useState2[0],
3607 setDisclosureActive = _useState2[1];
3608
3609 var toggleDisclosureActive = useCallback(function () {
3610 setDisclosureActive(function (disclosureActive) {
3611 return !disclosureActive;
3612 });
3613 }, []);
3614 var connectedDisclosureMarkup;
3615
3616 if (connectedDisclosure) {
3617 var connectedDisclosureClassName = classNames(styles$a.Button, primary && styles$a.primary, outline && styles$a.outline, size && size !== DEFAULT_SIZE$1 && styles$a[variationName('size', size)], textAlign && styles$a[variationName('textAlign', textAlign)], destructive && styles$a.destructive, connectedDisclosure.disabled && styles$a.disabled, styles$a.iconOnly, styles$a.ConnectedDisclosure, newDesignLanguage && styles$a.newDesignLanguage);
3618 var defaultLabel = i18n.translate('Polaris.Button.connectedDisclosureAccessibilityLabel');
3619 var _disabled = connectedDisclosure.disabled,
3620 _connectedDisclosure$ = connectedDisclosure.accessibilityLabel,
3621 disclosureLabel = _connectedDisclosure$ === void 0 ? defaultLabel : _connectedDisclosure$;
3622 var connectedDisclosureActivator = React__default.createElement("button", {
3623 type: "button",
3624 className: connectedDisclosureClassName,
3625 disabled: _disabled,
3626 "aria-label": disclosureLabel,
3627 onClick: toggleDisclosureActive,
3628 onMouseUp: handleMouseUpByBlurring
3629 }, React__default.createElement("span", {
3630 className: styles$a.Icon
3631 }, React__default.createElement(Icon, {
3632 source: CaretDownMinor
3633 })));
3634 connectedDisclosureMarkup = React__default.createElement(Popover, {
3635 active: disclosureActive,
3636 onClose: toggleDisclosureActive,
3637 activator: connectedDisclosureActivator,
3638 preferredAlignment: "right"
3639 }, React__default.createElement(ActionList, {
3640 items: connectedDisclosure.actions,
3641 onActionAnyItem: toggleDisclosureActive
3642 }));
3643 }
3644
3645 var buttonMarkup;
3646
3647 if (url) {
3648 buttonMarkup = isDisabled ? // Render an `<a>` so toggling disabled/enabled state changes only the
3649 // `href` attribute instead of replacing the whole element.
3650 // eslint-disable-next-line jsx-a11y/anchor-is-valid
3651 React__default.createElement("a", {
3652 id: id,
3653 className: className,
3654 "aria-label": accessibilityLabel
3655 }, content) : React__default.createElement(UnstyledLink, {
3656 id: id,
3657 url: url,
3658 external: external,
3659 download: download,
3660 onClick: onClick,
3661 onFocus: onFocus,
3662 onBlur: onBlur,
3663 onMouseUp: handleMouseUpByBlurring,
3664 onMouseEnter: onMouseEnter,
3665 onTouchStart: onTouchStart,
3666 className: className,
3667 "aria-label": accessibilityLabel
3668 }, content);
3669 } else {
3670 buttonMarkup = React__default.createElement("button", {
3671 id: id,
3672 type: type,
3673 onClick: onClick,
3674 onFocus: onFocus,
3675 onBlur: onBlur,
3676 onKeyDown: onKeyDown,
3677 onKeyUp: onKeyUp,
3678 onKeyPress: onKeyPress,
3679 onMouseUp: handleMouseUpByBlurring,
3680 onMouseEnter: onMouseEnter,
3681 onTouchStart: onTouchStart,
3682 className: className,
3683 disabled: isDisabled,
3684 "aria-label": accessibilityLabel,
3685 "aria-controls": ariaControls,
3686 "aria-expanded": ariaExpanded,
3687 "aria-pressed": ariaPressedStatus,
3688 role: loading ? 'alert' : undefined,
3689 "aria-busy": loading ? true : undefined
3690 }, content);
3691 }
3692
3693 return connectedDisclosureMarkup ? React__default.createElement("div", {
3694 className: styles$a.ConnectedDisclosureWrapper
3695 }, buttonMarkup, connectedDisclosureMarkup) : buttonMarkup;
3696}
3697
3698function isIconSource(x) {
3699 return typeof x === 'string' || typeof x === 'object' && x.body || typeof x === 'function';
3700}
3701
3702function buttonsFrom(actions) {
3703 var overrides = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
3704
3705 if (Array.isArray(actions)) {
3706 return actions.map(function (action, index) {
3707 return buttonFrom(action, overrides, index);
3708 });
3709 } else {
3710 var action = actions;
3711 return buttonFrom(action, overrides);
3712 }
3713}
3714function buttonFrom(_a, overrides, key) {
3715 var content = _a.content,
3716 onAction = _a.onAction,
3717 action = __rest(_a, ["content", "onAction"]);
3718
3719 return React__default.createElement(Button, Object.assign({
3720 key: key,
3721 onClick: onAction
3722 }, action, overrides), content);
3723}
3724
3725/**
3726 * Returns a stateful value, and a set of memoized functions to toggle it,
3727 * set it to true and set it to false
3728 */
3729
3730function useToggle(initialState) {
3731 var _useState = useState(initialState),
3732 _useState2 = _slicedToArray(_useState, 2),
3733 value = _useState2[0],
3734 setState = _useState2[1];
3735
3736 return {
3737 value,
3738 toggle: useCallback(function () {
3739 return setState(function (state) {
3740 return !state;
3741 });
3742 }, []),
3743 setTrue: useCallback(function () {
3744 return setState(true);
3745 }, []),
3746 setFalse: useCallback(function () {
3747 return setState(false);
3748 }, [])
3749 };
3750}
3751
3752var WithinContentContext = React__default.createContext(false);
3753
3754var styles$b = {
3755 "ButtonGroup": "Polaris-ButtonGroup",
3756 "Item": "Polaris-ButtonGroup__Item",
3757 "Item-plain": "Polaris-ButtonGroup__Item--plain",
3758 "segmented": "Polaris-ButtonGroup--segmented",
3759 "Item-focused": "Polaris-ButtonGroup__Item--focused",
3760 "fullWidth": "Polaris-ButtonGroup--fullWidth"
3761};
3762
3763function Item$1(_ref) {
3764 var button = _ref.button;
3765
3766 var _useToggle = useToggle(false),
3767 focused = _useToggle.value,
3768 forceTrueFocused = _useToggle.setTrue,
3769 forceFalseFocused = _useToggle.setFalse;
3770
3771 var className = classNames(styles$b.Item, focused && styles$b['Item-focused'], button.props.plain && styles$b['Item-plain']);
3772 return React__default.createElement("div", {
3773 className: className,
3774 onFocus: forceTrueFocused,
3775 onBlur: forceFalseFocused
3776 }, button);
3777}
3778
3779function ButtonGroup(_ref) {
3780 var children = _ref.children,
3781 segmented = _ref.segmented,
3782 fullWidth = _ref.fullWidth,
3783 connectedTop = _ref.connectedTop;
3784 var className = classNames(styles$b.ButtonGroup, segmented && styles$b.segmented, fullWidth && styles$b.fullWidth);
3785 var contents = elementChildren(children).map(function (child, index) {
3786 return React__default.createElement(Item$1, {
3787 button: child,
3788 key: index
3789 });
3790 });
3791 return React__default.createElement("div", {
3792 className: className,
3793 "data-buttongroup-segmented": segmented,
3794 "data-buttongroup-connected-top": connectedTop,
3795 "data-buttongroup-full-width": fullWidth
3796 }, contents);
3797}
3798
3799var styles$c = {
3800 "Stack": "Polaris-Stack",
3801 "Item": "Polaris-Stack__Item",
3802 "noWrap": "Polaris-Stack--noWrap",
3803 "spacingNone": "Polaris-Stack--spacingNone",
3804 "spacingExtraTight": "Polaris-Stack--spacingExtraTight",
3805 "spacingTight": "Polaris-Stack--spacingTight",
3806 "spacingLoose": "Polaris-Stack--spacingLoose",
3807 "spacingExtraLoose": "Polaris-Stack--spacingExtraLoose",
3808 "distributionLeading": "Polaris-Stack--distributionLeading",
3809 "distributionTrailing": "Polaris-Stack--distributionTrailing",
3810 "distributionCenter": "Polaris-Stack--distributionCenter",
3811 "distributionEqualSpacing": "Polaris-Stack--distributionEqualSpacing",
3812 "distributionFill": "Polaris-Stack--distributionFill",
3813 "distributionFillEvenly": "Polaris-Stack--distributionFillEvenly",
3814 "alignmentLeading": "Polaris-Stack--alignmentLeading",
3815 "alignmentTrailing": "Polaris-Stack--alignmentTrailing",
3816 "alignmentCenter": "Polaris-Stack--alignmentCenter",
3817 "alignmentFill": "Polaris-Stack--alignmentFill",
3818 "alignmentBaseline": "Polaris-Stack--alignmentBaseline",
3819 "vertical": "Polaris-Stack--vertical",
3820 "Item-fill": "Polaris-Stack__Item--fill"
3821};
3822
3823function Item$2(_ref) {
3824 var children = _ref.children,
3825 fill = _ref.fill;
3826 var className = classNames(styles$c.Item, fill && styles$c['Item-fill']);
3827 return React__default.createElement("div", {
3828 className: className
3829 }, children);
3830}
3831
3832var Stack = memo(function Stack(_ref) {
3833 var children = _ref.children,
3834 vertical = _ref.vertical,
3835 spacing = _ref.spacing,
3836 distribution = _ref.distribution,
3837 alignment = _ref.alignment,
3838 wrap = _ref.wrap;
3839 var className = classNames(styles$c.Stack, vertical && styles$c.vertical, spacing && styles$c[variationName('spacing', spacing)], distribution && styles$c[variationName('distribution', distribution)], alignment && styles$c[variationName('alignment', alignment)], wrap === false && styles$c.noWrap);
3840 var itemMarkup = elementChildren(children).map(function (child, index) {
3841 var props = {
3842 key: index
3843 };
3844 return wrapWithComponent(child, Item$2, props);
3845 });
3846 return React__default.createElement("div", {
3847 className: className
3848 }, itemMarkup);
3849});
3850Stack.Item = Item$2;
3851
3852var styles$d = {
3853 "Heading": "Polaris-Heading"
3854};
3855
3856function Heading(_ref) {
3857 var _ref$element = _ref.element,
3858 Element = _ref$element === void 0 ? 'h2' : _ref$element,
3859 children = _ref.children;
3860 return React__default.createElement(Element, {
3861 className: styles$d.Heading
3862 }, children);
3863}
3864
3865var styles$e = {
3866 "Card": "Polaris-Card",
3867 "subdued": "Polaris-Card--subdued",
3868 "Header": "Polaris-Card__Header",
3869 "Section": "Polaris-Card__Section",
3870 "Section-fullWidth": "Polaris-Card__Section--fullWidth",
3871 "Section-subdued": "Polaris-Card__Section--subdued",
3872 "SectionHeader": "Polaris-Card__SectionHeader",
3873 "Subsection": "Polaris-Card__Subsection",
3874 "Footer": "Polaris-Card__Footer",
3875 "LeftJustified": "Polaris-Card__LeftJustified"
3876};
3877
3878function Header(_ref) {
3879 var children = _ref.children,
3880 title = _ref.title,
3881 actions = _ref.actions;
3882 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
3883 plain: true
3884 })) : null;
3885 var titleMarkup = React__default.isValidElement(title) ? title : React__default.createElement(Heading, null, title);
3886 var headingMarkup = actionMarkup || children ? React__default.createElement(Stack, {
3887 alignment: "baseline"
3888 }, React__default.createElement(Stack.Item, {
3889 fill: true
3890 }, titleMarkup), actionMarkup, children) : titleMarkup;
3891 return React__default.createElement("div", {
3892 className: styles$e.Header
3893 }, headingMarkup);
3894}
3895
3896var styles$f = {
3897 "Subheading": "Polaris-Subheading"
3898};
3899
3900function Subheading(_ref) {
3901 var _ref$element = _ref.element,
3902 Element = _ref$element === void 0 ? 'h3' : _ref$element,
3903 children = _ref.children;
3904 var ariaLabel = typeof children === 'string' ? children : undefined;
3905 return React__default.createElement(Element, {
3906 "aria-label": ariaLabel,
3907 className: styles$f.Subheading
3908 }, children);
3909}
3910
3911function Section$2(_ref) {
3912 var children = _ref.children,
3913 title = _ref.title,
3914 subdued = _ref.subdued,
3915 fullWidth = _ref.fullWidth,
3916 actions = _ref.actions;
3917 var className = classNames(styles$e.Section, subdued && styles$e['Section-subdued'], fullWidth && styles$e['Section-fullWidth']);
3918 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
3919 plain: true
3920 })) : null;
3921 var titleMarkup = typeof title === 'string' ? React__default.createElement(Subheading, null, title) : title;
3922 var titleAreaMarkup = titleMarkup || actionMarkup ? React__default.createElement("div", {
3923 className: styles$e.SectionHeader
3924 }, actionMarkup ? React__default.createElement(Stack, {
3925 alignment: "baseline"
3926 }, React__default.createElement(Stack.Item, {
3927 fill: true
3928 }, titleMarkup), actionMarkup) : titleMarkup) : null;
3929 return React__default.createElement("div", {
3930 className: className
3931 }, titleAreaMarkup, children);
3932}
3933
3934function Subsection(_ref) {
3935 var children = _ref.children;
3936 return React__default.createElement("div", {
3937 className: styles$e.Subsection
3938 }, children);
3939}
3940
3941// subcomponents so explicitly state the subcomponents in the type definition.
3942// Letting this be implicit works in this project but fails in projects that use
3943// generated *.d.ts files.
3944
3945var Card = function Card(_ref) {
3946 var children = _ref.children,
3947 title = _ref.title,
3948 subdued = _ref.subdued,
3949 sectioned = _ref.sectioned,
3950 actions = _ref.actions,
3951 primaryFooterAction = _ref.primaryFooterAction,
3952 secondaryFooterActions = _ref.secondaryFooterActions,
3953 secondaryFooterActionsDisclosureText = _ref.secondaryFooterActionsDisclosureText,
3954 _ref$footerActionAlig = _ref.footerActionAlignment,
3955 footerActionAlignment = _ref$footerActionAlig === void 0 ? 'right' : _ref$footerActionAlig;
3956 var i18n = useI18n();
3957
3958 var _useToggle = useToggle(false),
3959 secondaryActionsPopoverOpen = _useToggle.value,
3960 toggleSecondaryActionsPopoverOpen = _useToggle.toggle;
3961
3962 var className = classNames(styles$e.Card, subdued && styles$e.subdued);
3963 var headerMarkup = title || actions ? React__default.createElement(Header, {
3964 actions: actions,
3965 title: title
3966 }) : null;
3967 var content = sectioned ? React__default.createElement(Section$2, null, children) : children;
3968 var primaryFooterActionMarkup = primaryFooterAction ? buttonFrom(primaryFooterAction, {
3969 primary: true
3970 }) : null;
3971 var secondaryFooterActionsMarkup = null;
3972
3973 if (secondaryFooterActions && secondaryFooterActions.length) {
3974 if (secondaryFooterActions.length === 1) {
3975 secondaryFooterActionsMarkup = buttonFrom(secondaryFooterActions[0]);
3976 } else {
3977 secondaryFooterActionsMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(Popover, {
3978 active: secondaryActionsPopoverOpen,
3979 activator: React__default.createElement(Button, {
3980 disclosure: true,
3981 onClick: toggleSecondaryActionsPopoverOpen
3982 }, secondaryFooterActionsDisclosureText || i18n.translate('Polaris.Common.more')),
3983 onClose: toggleSecondaryActionsPopoverOpen
3984 }, React__default.createElement(ActionList, {
3985 items: secondaryFooterActions
3986 })));
3987 }
3988 }
3989
3990 var footerMarkup = primaryFooterActionMarkup || secondaryFooterActionsMarkup ? React__default.createElement("div", {
3991 className: classNames(styles$e.Footer, footerActionAlignment === 'left' && styles$e.LeftJustified)
3992 }, footerActionAlignment === 'right' ? React__default.createElement(ButtonGroup, null, secondaryFooterActionsMarkup, primaryFooterActionMarkup) : React__default.createElement(ButtonGroup, null, primaryFooterActionMarkup, secondaryFooterActionsMarkup)) : null;
3993 return React__default.createElement(WithinContentContext.Provider, {
3994 value: true
3995 }, React__default.createElement("div", {
3996 className: className
3997 }, headerMarkup, content, footerMarkup));
3998};
3999Card.Header = Header;
4000Card.Section = Section$2;
4001Card.Subsection = Subsection;
4002
4003var styles$g = {
4004 "SettingAction": "Polaris-SettingAction",
4005 "Setting": "Polaris-SettingAction__Setting",
4006 "Action": "Polaris-SettingAction__Action"
4007};
4008
4009function SettingAction(_ref) {
4010 var action = _ref.action,
4011 children = _ref.children;
4012 return React__default.createElement("div", {
4013 className: styles$g.SettingAction
4014 }, React__default.createElement("div", {
4015 className: styles$g.Setting
4016 }, children), React__default.createElement("div", {
4017 className: styles$g.Action
4018 }, action));
4019}
4020
4021var styles$h = {
4022 "TermsOfService": "Polaris-AccountConnection__TermsOfService",
4023 "Content": "Polaris-AccountConnection__Content"
4024};
4025
4026function AccountConnection(_ref) {
4027 var _ref$connected = _ref.connected,
4028 connected = _ref$connected === void 0 ? false : _ref$connected,
4029 action = _ref.action,
4030 avatarUrl = _ref.avatarUrl,
4031 _ref$accountName = _ref.accountName,
4032 accountName = _ref$accountName === void 0 ? '' : _ref$accountName,
4033 title = _ref.title,
4034 details = _ref.details,
4035 termsOfService = _ref.termsOfService;
4036 var initials = accountName ? accountName.split(/\s+/).map(function (name) {
4037 return name[0];
4038 }).join('') : undefined;
4039 var avatarMarkup = connected ? React__default.createElement(Avatar, {
4040 accessibilityLabel: "",
4041 name: accountName,
4042 initials: initials,
4043 source: avatarUrl
4044 }) : null;
4045 var titleMarkup = null;
4046
4047 if (title) {
4048 titleMarkup = React__default.createElement("div", null, title);
4049 } else if (accountName) {
4050 titleMarkup = React__default.createElement("div", null, accountName);
4051 }
4052
4053 var detailsMarkup = details ? React__default.createElement("div", null, React__default.createElement(TextStyle, {
4054 variation: "subdued"
4055 }, details)) : null;
4056 var termsOfServiceMarkup = termsOfService ? React__default.createElement("div", {
4057 className: styles$h.TermsOfService
4058 }, termsOfService) : null;
4059 var actionElement = action ? buttonFrom(action, {
4060 primary: !connected
4061 }) : null;
4062 return React__default.createElement(Card, {
4063 sectioned: true
4064 }, React__default.createElement(SettingAction, {
4065 action: actionElement
4066 }, React__default.createElement(Stack, null, avatarMarkup, React__default.createElement(Stack.Item, {
4067 fill: true
4068 }, React__default.createElement("div", {
4069 className: styles$h.Content
4070 }, titleMarkup, detailsMarkup)))), termsOfServiceMarkup);
4071}
4072
4073function sortAndOverrideActionOrder(actions) {
4074 var actionsWithOverrides = actions.filter(function (action) {
4075 return action.index !== undefined;
4076 });
4077
4078 if (actionsWithOverrides.length === 0) {
4079 return actions;
4080 }
4081
4082 var sortedActionsWithOverrides = actionsWithOverrides.sort(function (_ref, _ref2) {
4083 var indexA = _ref.index;
4084 var indexB = _ref2.index;
4085 return indexA - indexB;
4086 });
4087 var actionsWithoutOverrides = actions.filter(function (action) {
4088 return action.index === undefined;
4089 });
4090
4091 var overriddenActions = _toConsumableArray(actionsWithoutOverrides);
4092
4093 sortedActionsWithOverrides.forEach(function (action) {
4094 overriddenActions.splice(action.index, 0, action);
4095 });
4096 return overriddenActions;
4097}
4098
4099var styles$i = {
4100 "MenuAction": "Polaris-ActionMenu-MenuAction",
4101 "IconWrapper": "Polaris-ActionMenu-MenuAction__IconWrapper",
4102 "disabled": "Polaris-ActionMenu-MenuAction--disabled",
4103 "newDesignLanguage": "Polaris-ActionMenu-MenuAction--newDesignLanguage",
4104 "ContentWrapper": "Polaris-ActionMenu-MenuAction__ContentWrapper"
4105};
4106
4107function MenuAction(_ref) {
4108 var content = _ref.content,
4109 accessibilityLabel = _ref.accessibilityLabel,
4110 url = _ref.url,
4111 external = _ref.external,
4112 icon = _ref.icon,
4113 disclosure = _ref.disclosure,
4114 disabled = _ref.disabled,
4115 onAction = _ref.onAction;
4116
4117 var _useFeatures = useFeatures(),
4118 newDesignLanguage = _useFeatures.newDesignLanguage;
4119
4120 var iconMarkup = icon && React__default.createElement("span", {
4121 className: styles$i.IconWrapper
4122 }, React__default.createElement(Icon, {
4123 source: icon
4124 }));
4125 var disclosureIconMarkup = disclosure && React__default.createElement("span", {
4126 className: styles$i.IconWrapper
4127 }, React__default.createElement(Icon, {
4128 source: CaretDownMinor
4129 }));
4130 var contentMarkup = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
4131 className: styles$i.ContentWrapper
4132 }, iconMarkup, React__default.createElement("span", {
4133 className: styles$i.Content
4134 }, content), disclosureIconMarkup) : content;
4135 var menuActionClassNames = classNames(styles$i.MenuAction, newDesignLanguage && styles$i.newDesignLanguage, disabled && styles$i.disabled);
4136
4137 if (url) {
4138 return React__default.createElement(UnstyledLink, {
4139 className: menuActionClassNames,
4140 url: url,
4141 external: external,
4142 "aria-label": accessibilityLabel,
4143 onMouseUp: handleMouseUpByBlurring
4144 }, contentMarkup);
4145 }
4146
4147 return React__default.createElement("button", {
4148 type: "button",
4149 className: menuActionClassNames,
4150 disabled: disabled,
4151 "aria-label": accessibilityLabel,
4152 onClick: onAction,
4153 onMouseUp: handleMouseUpByBlurring
4154 }, contentMarkup);
4155}
4156
4157var styles$j = {
4158 "Details": "Polaris-ActionMenu-MenuGroup__Details"
4159};
4160
4161function MenuGroup(_ref) {
4162 var accessibilityLabel = _ref.accessibilityLabel,
4163 active = _ref.active,
4164 actions = _ref.actions,
4165 details = _ref.details,
4166 title = _ref.title,
4167 icon = _ref.icon,
4168 onClose = _ref.onClose,
4169 onOpen = _ref.onOpen;
4170 var handleClose = useCallback(function () {
4171 onClose(title);
4172 }, [onClose, title]);
4173 var handleOpen = useCallback(function () {
4174 onOpen(title);
4175 }, [onOpen, title]);
4176
4177 if (!actions.length) {
4178 return null;
4179 }
4180
4181 var popoverActivator = React__default.createElement(MenuAction, {
4182 disclosure: true,
4183 content: title,
4184 icon: icon,
4185 accessibilityLabel: accessibilityLabel,
4186 onAction: handleOpen
4187 });
4188 return React__default.createElement(Popover, {
4189 active: Boolean(active),
4190 activator: popoverActivator,
4191 preferredAlignment: "left",
4192 onClose: handleClose
4193 }, React__default.createElement(ActionList, {
4194 items: actions,
4195 onActionAnyItem: handleClose
4196 }), details && React__default.createElement("div", {
4197 className: styles$j.Details
4198 }, details));
4199}
4200
4201var styles$k = {
4202 "RollupActivator": "Polaris-ActionMenu-RollupActions__RollupActivator"
4203};
4204
4205function RollupActions(_ref) {
4206 var _ref$items = _ref.items,
4207 items = _ref$items === void 0 ? [] : _ref$items,
4208 _ref$sections = _ref.sections,
4209 sections = _ref$sections === void 0 ? [] : _ref$sections;
4210 var i18n = useI18n();
4211
4212 var _useToggle = useToggle(false),
4213 rollupOpen = _useToggle.value,
4214 toggleRollupOpen = _useToggle.toggle;
4215
4216 if (items.length === 0 && sections.length === 0) {
4217 return null;
4218 }
4219
4220 var activatorMarkup = React__default.createElement("div", {
4221 className: styles$k.RollupActivator
4222 }, React__default.createElement(Button, {
4223 plain: true,
4224 icon: HorizontalDotsMinor,
4225 accessibilityLabel: i18n.translate('Polaris.ActionMenu.RollupActions.rollupButton'),
4226 onClick: toggleRollupOpen
4227 }));
4228 return React__default.createElement(Popover, {
4229 active: rollupOpen,
4230 activator: activatorMarkup,
4231 preferredAlignment: "right",
4232 onClose: toggleRollupOpen
4233 }, React__default.createElement(ActionList, {
4234 items: items,
4235 sections: sections,
4236 onActionAnyItem: toggleRollupOpen
4237 }));
4238}
4239
4240var styles$l = {
4241 "ActionMenu": "Polaris-ActionMenu",
4242 "rollup": "Polaris-ActionMenu--rollup",
4243 "ActionsLayout": "Polaris-ActionMenu__ActionsLayout"
4244};
4245
4246var ActionMenu =
4247/*#__PURE__*/
4248function (_React$PureComponent) {
4249 _inherits(ActionMenu, _React$PureComponent);
4250
4251 function ActionMenu() {
4252 var _this;
4253
4254 _classCallCheck(this, ActionMenu);
4255
4256 _this = _possibleConstructorReturn(this, _getPrototypeOf(ActionMenu).apply(this, arguments));
4257 _this.state = {
4258 activeMenuGroup: undefined
4259 };
4260
4261 _this.renderActions = function () {
4262 var _this$props = _this.props,
4263 _this$props$actions = _this$props.actions,
4264 actions = _this$props$actions === void 0 ? [] : _this$props$actions,
4265 _this$props$groups = _this$props.groups,
4266 groups = _this$props$groups === void 0 ? [] : _this$props$groups;
4267 var activeMenuGroup = _this.state.activeMenuGroup;
4268 var menuActions = [].concat(_toConsumableArray(actions), _toConsumableArray(groups));
4269 var overriddenActions = sortAndOverrideActionOrder(menuActions);
4270 var actionMarkup = overriddenActions.map(function (action, index) {
4271 if ('title' in action) {
4272 var title = action.title,
4273 _actions = action.actions,
4274 _rest = __rest(action, ["title", "actions"]);
4275
4276 return _actions.length > 0 ? React__default.createElement(MenuGroup, Object.assign({
4277 key: "MenuGroup-".concat(index),
4278 title: title,
4279 active: title === activeMenuGroup,
4280 actions: _actions
4281 }, _rest, {
4282 onOpen: _this.handleMenuGroupToggle,
4283 onClose: _this.handleMenuGroupClose
4284 })) : null;
4285 }
4286
4287 var content = action.content,
4288 rest = __rest(action, ["content"]);
4289
4290 return React__default.createElement(MenuAction, Object.assign({
4291 key: "MenuAction-".concat(index),
4292 content: content
4293 }, rest));
4294 });
4295 return React__default.createElement("div", {
4296 className: styles$l.ActionsLayout
4297 }, actionMarkup);
4298 };
4299
4300 _this.handleMenuGroupToggle = function (group) {
4301 _this.setState(function (_ref) {
4302 var activeMenuGroup = _ref.activeMenuGroup;
4303 return {
4304 activeMenuGroup: activeMenuGroup ? undefined : group
4305 };
4306 });
4307 };
4308
4309 _this.handleMenuGroupClose = function () {
4310 _this.setState({
4311 activeMenuGroup: undefined
4312 });
4313 };
4314
4315 return _this;
4316 }
4317
4318 _createClass(ActionMenu, [{
4319 key: "render",
4320 value: function render() {
4321 var _this$props2 = this.props,
4322 _this$props2$actions = _this$props2.actions,
4323 actions = _this$props2$actions === void 0 ? [] : _this$props2$actions,
4324 _this$props2$groups = _this$props2.groups,
4325 groups = _this$props2$groups === void 0 ? [] : _this$props2$groups,
4326 rollup = _this$props2.rollup;
4327
4328 if (actions.length === 0 && groups.length === 0) {
4329 return null;
4330 }
4331
4332 var actionMenuClassNames = classNames(styles$l.ActionMenu, rollup && styles$l.rollup);
4333 var rollupSections = groups.map(function (group) {
4334 return convertGroupToSection(group);
4335 });
4336 return React__default.createElement("div", {
4337 className: actionMenuClassNames
4338 }, rollup ? React__default.createElement(RollupActions, {
4339 items: actions,
4340 sections: rollupSections
4341 }) : this.renderActions());
4342 }
4343 }]);
4344
4345 return ActionMenu;
4346}(React__default.PureComponent);
4347function hasGroupsWithActions() {
4348 var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
4349 return groups.length === 0 ? false : groups.some(function (group) {
4350 return group.actions.length > 0;
4351 });
4352}
4353
4354function convertGroupToSection(_ref2) {
4355 var title = _ref2.title,
4356 actions = _ref2.actions;
4357 return {
4358 title,
4359 items: actions
4360 };
4361}
4362
4363function ThemeProvider(_ref) {
4364 var themeConfig = _ref.theme,
4365 children = _ref.children;
4366
4367 var _useFeatures = useFeatures(),
4368 newDesignLanguage = _useFeatures.newDesignLanguage;
4369
4370 var parentContext = useContext(ThemeContext);
4371 var isParentThemeProvider = parentContext === undefined;
4372 var parentColorScheme = parentContext && parentContext.colorScheme && parentContext.colorScheme;
4373 var parentColors = parentContext && parentContext.colors && parentContext.colors;
4374
4375 var colors = themeConfig.colors,
4376 colorScheme = themeConfig.colorScheme,
4377 rest = __rest(themeConfig, ["colors", "colorScheme"]);
4378
4379 var processedThemeConfig = Object.assign(Object.assign(Object.assign({}, rest), {
4380 colorScheme: getColorScheme(colorScheme, parentColorScheme)
4381 }), {
4382 colors: Object.assign(Object.assign(Object.assign({}, isParentThemeProvider && DefaultThemeColors), shouldInheritParentColors(isParentThemeProvider, colorScheme, parentColorScheme) && parentColors), colors)
4383 });
4384 var customProperties = useMemo(function () {
4385 return buildCustomProperties(processedThemeConfig, newDesignLanguage, Tokens);
4386 }, [processedThemeConfig, newDesignLanguage]);
4387 var theme = useMemo(function () {
4388 return buildThemeContext(processedThemeConfig, newDesignLanguage ? customProperties : undefined);
4389 }, [customProperties, processedThemeConfig, newDesignLanguage]); // We want these values to be empty string instead of `undefined` when not set.
4390 // Otherwise, setting a style property to `undefined` does not remove it from the DOM.
4391
4392 var backgroundColor = customProperties['--p-background'] || '';
4393 var color = customProperties['--p-text'] || '';
4394 useEffect(function () {
4395 if (isParentThemeProvider) {
4396 document.body.style.backgroundColor = backgroundColor;
4397 document.body.style.color = color;
4398 }
4399 }, [backgroundColor, color, isParentThemeProvider]);
4400 var style = Object.assign(Object.assign({}, customProperties), !isParentThemeProvider && {
4401 color
4402 });
4403 return React__default.createElement(ThemeContext.Provider, {
4404 value: Object.assign(Object.assign({}, theme), {
4405 textColor: color
4406 })
4407 }, React__default.createElement("div", {
4408 style: style
4409 }, children));
4410}
4411
4412function isInverseColorScheme(colorScheme) {
4413 return colorScheme === 'inverse';
4414}
4415
4416function getColorScheme(colorScheme, parentColorScheme) {
4417 if (colorScheme == null) {
4418 return parentColorScheme || 'light';
4419 } else if (isInverseColorScheme(colorScheme)) {
4420 return parentColorScheme === 'dark' || parentColorScheme === undefined ? 'light' : 'dark';
4421 } else {
4422 return colorScheme;
4423 }
4424}
4425
4426function shouldInheritParentColors(isParentThemeProvider, colorScheme, parentColorScheme) {
4427 if (isParentThemeProvider) {
4428 return false;
4429 } else if (isInverseColorScheme(colorScheme) || colorScheme === 'dark' && parentColorScheme === 'light' || colorScheme === 'light' && parentColorScheme === 'dark') {
4430 return true;
4431 } else {
4432 return false;
4433 }
4434}
4435
4436var MediaQueryContext = React__default.createContext(undefined);
4437
4438function useMediaQuery() {
4439 var mediaQuery = useContext(MediaQueryContext);
4440
4441 if (!mediaQuery) {
4442 throw new Error('No mediaQuery was provided. Your application must be wrapped in an <AppProvider> component. See https://polaris.shopify.com/components/structure/app-provider for implementation instructions.');
4443 }
4444
4445 return mediaQuery;
4446}
4447
4448var MediaQueryProvider = function MediaQueryProvider(_ref) {
4449 var children = _ref.children;
4450
4451 var _useState = useState(navigationBarCollapsed().matches),
4452 _useState2 = _slicedToArray(_useState, 2),
4453 isNavigationCollapsed = _useState2[0],
4454 setIsNavigationCollapsed = _useState2[1];
4455
4456 var handleResize = useCallback(debounce(function () {
4457 if (isNavigationCollapsed !== navigationBarCollapsed().matches) {
4458 setIsNavigationCollapsed(!isNavigationCollapsed);
4459 }
4460 }, 40, {
4461 trailing: true,
4462 leading: true,
4463 maxWait: 40
4464 }), [isNavigationCollapsed]);
4465 useEffect(function () {
4466 setIsNavigationCollapsed(navigationBarCollapsed().matches);
4467 }, []);
4468 return React__default.createElement(MediaQueryContext.Provider, {
4469 value: {
4470 isNavigationCollapsed
4471 }
4472 }, React__default.createElement(EventListener, {
4473 event: "resize",
4474 handler: handleResize
4475 }), children);
4476};
4477
4478var FocusManagerContext = React__default.createContext(undefined);
4479
4480function useFocusManager() {
4481 var focusManager = useContext(FocusManagerContext);
4482 var id = useUniqueId();
4483
4484 if (!focusManager) {
4485 throw new MissingAppProviderError('No FocusManager was provided.');
4486 }
4487
4488 var trapFocusList = focusManager.trapFocusList,
4489 addFocusItem = focusManager.add,
4490 removeFocusItem = focusManager.remove;
4491 var canSafelyFocus = trapFocusList[0] === id;
4492 var value = useMemo(function () {
4493 return {
4494 canSafelyFocus
4495 };
4496 }, [canSafelyFocus]);
4497 useEffect(function () {
4498 addFocusItem(id);
4499 return function () {
4500 removeFocusItem(id);
4501 };
4502 }, [addFocusItem, id, removeFocusItem]);
4503 return value;
4504}
4505
4506function FocusManager(_ref) {
4507 var children = _ref.children;
4508
4509 var _useState = useState([]),
4510 _useState2 = _slicedToArray(_useState, 2),
4511 trapFocusList = _useState2[0],
4512 setTrapFocusList = _useState2[1];
4513
4514 var add = useCallback(function (id) {
4515 setTrapFocusList(function (list) {
4516 return [].concat(_toConsumableArray(list), [id]);
4517 });
4518 }, []);
4519 var remove = useCallback(function (id) {
4520 var removed = true;
4521 setTrapFocusList(function (list) {
4522 var clone = _toConsumableArray(list);
4523
4524 var index = clone.indexOf(id);
4525
4526 if (index === -1) {
4527 removed = false;
4528 } else {
4529 clone.splice(index, 1);
4530 }
4531
4532 return clone;
4533 });
4534 return removed;
4535 }, []);
4536 var value = useMemo(function () {
4537 return {
4538 trapFocusList,
4539 add,
4540 remove
4541 };
4542 }, [add, trapFocusList, remove]);
4543 return React__default.createElement(FocusManagerContext.Provider, {
4544 value: value
4545 }, children);
4546}
4547
4548var ScrollLockManagerContext = React__default.createContext(undefined);
4549
4550function useScrollLockManager() {
4551 var scrollLockManager = useContext(ScrollLockManagerContext);
4552
4553 if (!scrollLockManager) {
4554 throw new MissingAppProviderError('No ScrollLockManager was provided.');
4555 }
4556
4557 return scrollLockManager;
4558}
4559
4560var isServer = typeof window === 'undefined' || typeof document === 'undefined';
4561
4562var SCROLL_LOCKING_ATTRIBUTE = 'data-lock-scrolling';
4563var SCROLL_LOCKING_WRAPPER_ATTRIBUTE = 'data-lock-scrolling-wrapper';
4564var scrollPosition = 0;
4565var ScrollLockManager =
4566/*#__PURE__*/
4567function () {
4568 function ScrollLockManager() {
4569 _classCallCheck(this, ScrollLockManager);
4570
4571 this.scrollLocks = 0;
4572 this.locked = false;
4573 }
4574
4575 _createClass(ScrollLockManager, [{
4576 key: "registerScrollLock",
4577 value: function registerScrollLock() {
4578 this.scrollLocks += 1;
4579 this.handleScrollLocking();
4580 }
4581 }, {
4582 key: "unregisterScrollLock",
4583 value: function unregisterScrollLock() {
4584 this.scrollLocks -= 1;
4585 this.handleScrollLocking();
4586 }
4587 }, {
4588 key: "handleScrollLocking",
4589 value: function handleScrollLocking() {
4590 if (isServer) return;
4591 var scrollLocks = this.scrollLocks;
4592 var _document = document,
4593 body = _document.body;
4594 var wrapper = body.firstElementChild;
4595
4596 if (scrollLocks === 0) {
4597 body.removeAttribute(SCROLL_LOCKING_ATTRIBUTE);
4598
4599 if (wrapper) {
4600 wrapper.removeAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE);
4601 }
4602
4603 window.scroll(0, scrollPosition);
4604 this.locked = false;
4605 } else if (scrollLocks > 0 && !this.locked) {
4606 scrollPosition = window.pageYOffset;
4607 body.setAttribute(SCROLL_LOCKING_ATTRIBUTE, '');
4608
4609 if (wrapper) {
4610 wrapper.setAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE, '');
4611 wrapper.scrollTop = scrollPosition;
4612 }
4613
4614 this.locked = true;
4615 }
4616 }
4617 }, {
4618 key: "resetScrollPosition",
4619 value: function resetScrollPosition() {
4620 scrollPosition = 0;
4621 }
4622 }]);
4623
4624 return ScrollLockManager;
4625}();
4626
4627var AppBridgeContext = React__default.createContext(undefined);
4628
4629function useAppBridge() {
4630 return useContext(AppBridgeContext);
4631}
4632
4633function createAppBridge(_ref) {
4634 var apiKey = _ref.apiKey,
4635 shopOrigin = _ref.shopOrigin,
4636 forceRedirect = _ref.forceRedirect;
4637 var appBridge = apiKey ? createApp({
4638 apiKey,
4639 shopOrigin: shopOrigin || getShopOrigin(),
4640 forceRedirect
4641 }) : undefined;
4642
4643 if (appBridge !== undefined) {
4644 // eslint-disable-next-line no-console
4645 console.warn('Deprecation: Using `apiKey` and `shopOrigin` on `AppProvider` to initialize the Shopify App Bridge is deprecated. Support for this will be removed in v5.0. Use `Provider` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/provider');
4646 }
4647
4648 if (appBridge && appBridge.hooks) {
4649 appBridge.hooks.set(LifecycleHook.DispatchAction, setClientInterfaceHook);
4650 }
4651
4652 return appBridge;
4653}
4654var setClientInterfaceHook = function setClientInterfaceHook(next) {
4655 return function (action) {
4656 action.clientInterface = {
4657 name: '@shopify/polaris',
4658 version: polarisVersion
4659 };
4660 return next(action);
4661 };
4662};
4663
4664var AppProvider =
4665/*#__PURE__*/
4666function (_React$Component) {
4667 _inherits(AppProvider, _React$Component);
4668
4669 function AppProvider(props) {
4670 var _this;
4671
4672 _classCallCheck(this, AppProvider);
4673
4674 _this = _possibleConstructorReturn(this, _getPrototypeOf(AppProvider).call(this, props));
4675 _this.stickyManager = new StickyManager();
4676 _this.scrollLockManager = new ScrollLockManager();
4677 _this.uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory);
4678 var _this$props = _this.props,
4679 i18n = _this$props.i18n,
4680 apiKey = _this$props.apiKey,
4681 shopOrigin = _this$props.shopOrigin,
4682 forceRedirect = _this$props.forceRedirect,
4683 linkComponent = _this$props.linkComponent; // eslint-disable-next-line react/state-in-constructor
4684
4685 _this.state = {
4686 link: linkComponent,
4687 intl: new I18n(i18n),
4688 appBridge: createAppBridge({
4689 shopOrigin,
4690 apiKey,
4691 forceRedirect
4692 })
4693 };
4694 return _this;
4695 }
4696
4697 _createClass(AppProvider, [{
4698 key: "componentDidMount",
4699 value: function componentDidMount() {
4700 if (document != null) {
4701 this.stickyManager.setContainer(document);
4702 }
4703 }
4704 }, {
4705 key: "componentDidUpdate",
4706 value: function componentDidUpdate(_ref) {
4707 var prevI18n = _ref.i18n,
4708 prevLinkComponent = _ref.linkComponent,
4709 prevApiKey = _ref.apiKey,
4710 prevShopOrigin = _ref.shopOrigin,
4711 prevForceRedirect = _ref.forceRedirect;
4712 var _this$props2 = this.props,
4713 i18n = _this$props2.i18n,
4714 linkComponent = _this$props2.linkComponent,
4715 apiKey = _this$props2.apiKey,
4716 shopOrigin = _this$props2.shopOrigin,
4717 forceRedirect = _this$props2.forceRedirect;
4718
4719 if (i18n === prevI18n && linkComponent === prevLinkComponent && apiKey === prevApiKey && shopOrigin === prevShopOrigin && forceRedirect === prevForceRedirect) {
4720 return;
4721 } // eslint-disable-next-line react/no-did-update-set-state
4722
4723
4724 this.setState({
4725 link: linkComponent,
4726 intl: new I18n(i18n),
4727 appBridge: createAppBridge({
4728 shopOrigin,
4729 apiKey,
4730 forceRedirect
4731 })
4732 });
4733 }
4734 }, {
4735 key: "render",
4736 value: function render() {
4737 var _this$props3 = this.props,
4738 _this$props3$theme = _this$props3.theme,
4739 theme = _this$props3$theme === void 0 ? {} : _this$props3$theme,
4740 children = _this$props3.children;
4741 var _this$state = this.state,
4742 intl = _this$state.intl,
4743 appBridge = _this$state.appBridge,
4744 link = _this$state.link;
4745 var features = Object.assign({
4746 newDesignLanguage: false
4747 }, this.props.features);
4748 return React__default.createElement(FeaturesContext.Provider, {
4749 value: features
4750 }, React__default.createElement(I18nContext.Provider, {
4751 value: intl
4752 }, React__default.createElement(ScrollLockManagerContext.Provider, {
4753 value: this.scrollLockManager
4754 }, React__default.createElement(StickyManagerContext.Provider, {
4755 value: this.stickyManager
4756 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
4757 value: this.uniqueIdFactory
4758 }, React__default.createElement(AppBridgeContext.Provider, {
4759 value: appBridge
4760 }, React__default.createElement(LinkContext.Provider, {
4761 value: link
4762 }, React__default.createElement(ThemeProvider, {
4763 theme: theme
4764 }, React__default.createElement(MediaQueryProvider, null, React__default.createElement(FocusManager, null, children))))))))));
4765 }
4766 }]);
4767
4768 return AppProvider;
4769}(React__default.Component);
4770
4771function arraysAreEqual(firstArray, secondArray, comparator) {
4772 if (firstArray.length !== secondArray.length) {
4773 return false;
4774 }
4775
4776 return firstArray.every(function (firstItem, index) {
4777 var secondItem = secondArray[index];
4778
4779 if (comparator != null) {
4780 return comparator(firstItem, secondItem);
4781 }
4782
4783 return firstItem === secondItem;
4784 });
4785}
4786
4787/**
4788 * Allows for custom or deep comparison of a dependency list. Useful to keep a consistent dependency
4789 * list across reference changes.
4790 * @param dependencies A dependency array similar to React.useEffect/React.useCallback/React.useMemo
4791 * @param comparator An optional function to compare dependencies that'll default to a deep comparison
4792 * @returns A dependency list
4793 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-effect.tsx}
4794 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-callback.tsx}
4795 * @example
4796 * function useDeepEffectExample(callback, dependencies, customCompare) {
4797 * useEffect(callback, useDeepCompareRef(dependencies, customCompare));
4798 * }
4799 */
4800
4801function useDeepCompareRef(dependencies) {
4802 var comparator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : isEqual;
4803 var dependencyList = useRef(dependencies);
4804
4805 if (!comparator(dependencyList.current, dependencies)) {
4806 dependencyList.current = dependencies;
4807 }
4808
4809 return dependencyList.current;
4810}
4811
4812/**
4813 * A replacement for React.useEffect that'll allow for custom and deep
4814 * compares of the dependency list.
4815 * @see {@link https://reactjs.org/docs/hooks-reference.html#useeffect}
4816 * @param callback Accepts a callback that's forwarded to React.useEffect
4817 * @param dependencies A dependency array similar to React.useEffect however it utilizes a deep compare
4818 * @param customCompare Opportunity to provide a custom compare function
4819 * @example
4820 * function ComponentExample() {
4821 * const [, forceUpdate] = useState();
4822 * const obj = {a: 1};
4823 *
4824 * useDeepEffect(() => {
4825 * console.log('useDeepEffect invocation');
4826 * forceUpdate(obj);
4827 * }, [obj]);
4828 *
4829 * return null;
4830 * }
4831 */
4832
4833function useDeepEffect(callback, dependencies, customCompare) {
4834 useEffect(callback, useDeepCompareRef(dependencies, customCompare));
4835}
4836
4837var styles$m = {
4838 "Checkbox": "Polaris-OptionList-Checkbox",
4839 "Input": "Polaris-OptionList-Checkbox__Input",
4840 "newDesignLanguage": "Polaris-OptionList-Checkbox--newDesignLanguage",
4841 "Backdrop": "Polaris-OptionList-Checkbox__Backdrop",
4842 "Icon": "Polaris-OptionList-Checkbox__Icon",
4843 "active": "Polaris-OptionList-Checkbox--active",
4844 "keyFocused": "Polaris-OptionList-Checkbox--keyFocused",
4845 "Input-indeterminate": "Polaris-OptionList-Checkbox__Input--indeterminate",
4846 "hover": "Polaris-OptionList-Checkbox--hover"
4847};
4848
4849function Checkbox(_ref) {
4850 var idProp = _ref.id,
4851 _ref$checked = _ref.checked,
4852 checked = _ref$checked === void 0 ? false : _ref$checked,
4853 disabled = _ref.disabled,
4854 active = _ref.active,
4855 onChange = _ref.onChange,
4856 name = _ref.name,
4857 value = _ref.value,
4858 role = _ref.role;
4859 var id = useUniqueId('Checkbox', idProp);
4860
4861 var _useFeatures = useFeatures(),
4862 newDesignLanguage = _useFeatures.newDesignLanguage;
4863
4864 var _useState = useState(false),
4865 _useState2 = _slicedToArray(_useState, 2),
4866 keyFocused = _useState2[0],
4867 setKeyFocused = _useState2[1];
4868
4869 var className = classNames(styles$m.Checkbox, active && styles$m.active, newDesignLanguage && styles$m.newDesignLanguage);
4870
4871 var handleBlur = function handleBlur() {
4872 setKeyFocused(false);
4873 };
4874
4875 var handleKeyUp = function handleKeyUp() {
4876 !keyFocused && setKeyFocused(true);
4877 };
4878
4879 var inputClassName = classNames(styles$m.Input, newDesignLanguage && keyFocused && styles$m.keyFocused);
4880 return React__default.createElement("div", {
4881 className: className
4882 }, React__default.createElement("input", {
4883 id: id,
4884 name: name,
4885 value: value,
4886 type: "checkbox",
4887 checked: checked,
4888 disabled: disabled,
4889 className: inputClassName,
4890 "aria-checked": checked,
4891 onChange: onChange,
4892 onBlur: handleBlur,
4893 onKeyUp: handleKeyUp,
4894 role: role
4895 }), React__default.createElement("div", {
4896 className: styles$m.Backdrop
4897 }), React__default.createElement("div", {
4898 className: styles$m.Icon
4899 }, React__default.createElement(Icon, {
4900 source: TickSmallMinor
4901 })));
4902}
4903
4904var styles$n = {
4905 "Option": "Polaris-OptionList-Option",
4906 "SingleSelectOption": "Polaris-OptionList-Option__SingleSelectOption",
4907 "disabled": "Polaris-OptionList-Option--disabled",
4908 "Media": "Polaris-OptionList-Option__Media",
4909 "Label": "Polaris-OptionList-Option__Label",
4910 "Checkbox": "Polaris-OptionList-Option__Checkbox",
4911 "newDesignLanguage": "Polaris-OptionList-Option--newDesignLanguage",
4912 "focused": "Polaris-OptionList-Option--focused",
4913 "select": "Polaris-OptionList-Option--select",
4914 "active": "Polaris-OptionList-Option--active"
4915};
4916
4917function Option(_ref) {
4918 var label = _ref.label,
4919 value = _ref.value,
4920 id = _ref.id,
4921 select = _ref.select,
4922 active = _ref.active,
4923 allowMultiple = _ref.allowMultiple,
4924 disabled = _ref.disabled,
4925 role = _ref.role,
4926 media = _ref.media,
4927 onClick = _ref.onClick,
4928 section = _ref.section,
4929 index = _ref.index;
4930
4931 var _useToggle = useToggle(false),
4932 focused = _useToggle.value,
4933 toggleFocused = _useToggle.toggle;
4934
4935 var _useFeatures = useFeatures(),
4936 newDesignLanguage = _useFeatures.newDesignLanguage;
4937
4938 var handleClick = useCallback(function () {
4939 if (disabled) {
4940 return;
4941 }
4942
4943 onClick(section, index);
4944 }, [disabled, index, onClick, section]);
4945 var mediaMarkup = media ? React__default.createElement("div", {
4946 className: styles$n.Media
4947 }, media) : null;
4948 var singleSelectClassName = classNames(styles$n.SingleSelectOption, focused && styles$n.focused, disabled && styles$n.disabled, select && styles$n.select, active && styles$n.active);
4949 var multiSelectClassName = classNames(styles$n.Label, disabled && styles$n.disabled, active && styles$n.active, newDesignLanguage && select && styles$n.select);
4950 var checkBoxRole = role === 'option' ? 'presentation' : undefined;
4951 var optionMarkup = allowMultiple ? React__default.createElement("label", {
4952 htmlFor: id,
4953 className: multiSelectClassName
4954 }, React__default.createElement("div", {
4955 className: styles$n.Checkbox
4956 }, React__default.createElement(Checkbox, {
4957 id: id,
4958 value: value,
4959 checked: select,
4960 active: active,
4961 disabled: disabled,
4962 onChange: handleClick,
4963 role: checkBoxRole
4964 })), mediaMarkup, label) : React__default.createElement("button", {
4965 id: id,
4966 type: "button",
4967 className: singleSelectClassName,
4968 onClick: handleClick,
4969 disabled: disabled,
4970 onFocus: toggleFocused,
4971 onBlur: toggleFocused
4972 }, mediaMarkup, label);
4973 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
4974 var optionClassName = classNames(styles$n.Option, newDesignLanguage && styles$n.newDesignLanguage);
4975 return React__default.createElement("li", {
4976 key: id,
4977 className: optionClassName,
4978 tabIndex: -1,
4979 "aria-selected": active,
4980 role: role
4981 }, scrollMarkup, optionMarkup);
4982}
4983
4984var styles$o = {
4985 "OptionList": "Polaris-OptionList",
4986 "newDesignLanguage": "Polaris-OptionList--newDesignLanguage",
4987 "Options": "Polaris-OptionList__Options",
4988 "Title": "Polaris-OptionList__Title"
4989};
4990
4991function OptionList(_ref) {
4992 var options = _ref.options,
4993 sections = _ref.sections,
4994 title = _ref.title,
4995 selected = _ref.selected,
4996 allowMultiple = _ref.allowMultiple,
4997 role = _ref.role,
4998 optionRole = _ref.optionRole,
4999 onChange = _ref.onChange,
5000 idProp = _ref.id;
5001
5002 var _useState = useState(createNormalizedOptions(options, sections, title)),
5003 _useState2 = _slicedToArray(_useState, 2),
5004 normalizedOptions = _useState2[0],
5005 setNormalizedOptions = _useState2[1];
5006
5007 var id = useUniqueId('OptionList', idProp);
5008
5009 var _useFeatures = useFeatures(),
5010 newDesignLanguage = _useFeatures.newDesignLanguage;
5011
5012 useDeepEffect(function () {
5013 setNormalizedOptions(createNormalizedOptions(options || [], sections || [], title));
5014 }, [options, sections, title], optionArraysAreEqual);
5015 var handleClick = useCallback(function (sectionIndex, optionIndex) {
5016 var selectedValue = normalizedOptions[sectionIndex].options[optionIndex].value;
5017 var foundIndex = selected.indexOf(selectedValue);
5018
5019 if (allowMultiple) {
5020 var newSelection = foundIndex === -1 ? [selectedValue].concat(_toConsumableArray(selected)) : [].concat(_toConsumableArray(selected.slice(0, foundIndex)), _toConsumableArray(selected.slice(foundIndex + 1, selected.length)));
5021 onChange(newSelection);
5022 return;
5023 }
5024
5025 onChange([selectedValue]);
5026 }, [normalizedOptions, selected, allowMultiple, onChange]);
5027 var optionsExist = normalizedOptions.length > 0;
5028 var optionsMarkup = optionsExist ? normalizedOptions.map(function (_ref2, sectionIndex) {
5029 var title = _ref2.title,
5030 options = _ref2.options;
5031 var titleMarkup = title ? React__default.createElement("p", {
5032 className: styles$o.Title,
5033 role: role
5034 }, title) : null;
5035 var optionsMarkup = options && options.map(function (option, optionIndex) {
5036 var isSelected = selected.includes(option.value);
5037 var optionId = option.id || "".concat(id, "-").concat(sectionIndex, "-").concat(optionIndex);
5038 return React__default.createElement(Option, Object.assign({}, option, {
5039 key: optionId,
5040 id: optionId,
5041 section: sectionIndex,
5042 index: optionIndex,
5043 onClick: handleClick,
5044 select: isSelected,
5045 allowMultiple: allowMultiple,
5046 role: optionRole
5047 }));
5048 });
5049 return React__default.createElement("li", {
5050 key: title || "noTitle-".concat(sectionIndex)
5051 }, titleMarkup, React__default.createElement("ul", {
5052 className: styles$o.Options,
5053 id: "".concat(id, "-").concat(sectionIndex),
5054 role: role,
5055 "aria-multiselectable": allowMultiple
5056 }, optionsMarkup));
5057 }) : null;
5058 var optionListClassName = classNames(styles$o.OptionList, newDesignLanguage && styles$o.newDesignLanguage);
5059 return React__default.createElement("ul", {
5060 className: optionListClassName,
5061 role: role
5062 }, optionsMarkup);
5063}
5064
5065function createNormalizedOptions(options, sections, title) {
5066 if (options == null) {
5067 var section = {
5068 options: [],
5069 title
5070 };
5071 return sections == null ? [] : [section].concat(_toConsumableArray(sections));
5072 }
5073
5074 if (sections == null) {
5075 return [{
5076 title,
5077 options
5078 }];
5079 }
5080
5081 return [{
5082 title,
5083 options
5084 }].concat(_toConsumableArray(sections));
5085}
5086
5087function isSection(arr) {
5088 return typeof arr[0] === 'object' && Object.prototype.hasOwnProperty.call(arr[0], 'options');
5089}
5090
5091function optionArraysAreEqual(firstArray, secondArray) {
5092 if (isSection(firstArray) && isSection(secondArray)) {
5093 return arraysAreEqual(firstArray, secondArray, testSectionsPropEquality);
5094 }
5095
5096 return arraysAreEqual(firstArray, secondArray);
5097}
5098
5099function testSectionsPropEquality(previousSection, currentSection) {
5100 var previousOptions = previousSection.options;
5101 var currentOptions = currentSection.options;
5102 var optionsAreEqual = arraysAreEqual(previousOptions, currentOptions);
5103 var titlesAreEqual = previousSection.title === currentSection.title;
5104 return optionsAreEqual && titlesAreEqual;
5105}
5106
5107var ComboBoxContext = React__default.createContext({});
5108
5109var styles$p = {
5110 "EmptyState": "Polaris-Autocomplete-ComboBox__EmptyState"
5111};
5112
5113var getUniqueId = createUniqueIDFactory('ComboBox');
5114var ComboBox =
5115/*#__PURE__*/
5116function (_React$PureComponent) {
5117 _inherits(ComboBox, _React$PureComponent);
5118
5119 function ComboBox() {
5120 var _this;
5121
5122 _classCallCheck(this, ComboBox);
5123
5124 _this = _possibleConstructorReturn(this, _getPrototypeOf(ComboBox).apply(this, arguments));
5125 _this.state = {
5126 comboBoxId: _this.getComboBoxId(),
5127 selectedOption: undefined,
5128 selectedIndex: -1,
5129 selectedOptions: _this.props.selected,
5130 navigableOptions: [],
5131 popoverActive: false,
5132 popoverWasActive: false
5133 };
5134
5135 _this.handleDownArrow = function () {
5136 _this.selectNextOption();
5137
5138 _this.handlePopoverOpen;
5139 };
5140
5141 _this.handleUpArrow = function () {
5142 _this.selectPreviousOption();
5143
5144 _this.handlePopoverOpen;
5145 };
5146
5147 _this.handleEnter = function (event) {
5148 if (event.keyCode !== Key.Enter) {
5149 return;
5150 }
5151
5152 var selectedOption = _this.state.selectedOption;
5153
5154 if (_this.state.popoverActive && selectedOption) {
5155 if (isOption(selectedOption)) {
5156 event.preventDefault();
5157
5158 _this.handleSelection(selectedOption.value);
5159 } else {
5160 selectedOption.onAction && selectedOption.onAction();
5161 }
5162 }
5163
5164 _this.handlePopoverOpen;
5165 };
5166
5167 _this.handleFocus = function () {
5168 _this.setState({
5169 popoverActive: true,
5170 popoverWasActive: true
5171 });
5172 };
5173
5174 _this.handleBlur = function () {
5175 _this.setState({
5176 popoverActive: false,
5177 popoverWasActive: false
5178 }, function () {
5179 _this.resetVisuallySelectedOptions();
5180 });
5181 };
5182
5183 _this.handleClick = function () {
5184 !_this.state.popoverActive && _this.setState({
5185 popoverActive: true
5186 });
5187 };
5188
5189 _this.handleSelection = function (newSelected) {
5190 var _this$props = _this.props,
5191 selected = _this$props.selected,
5192 allowMultiple = _this$props.allowMultiple;
5193 var newlySelectedOptions = selected;
5194
5195 if (selected.includes(newSelected)) {
5196 newlySelectedOptions.splice(newlySelectedOptions.indexOf(newSelected), 1);
5197 } else if (allowMultiple) {
5198 newlySelectedOptions.push(newSelected);
5199 } else {
5200 newlySelectedOptions = [newSelected];
5201 }
5202
5203 _this.selectOptions(newlySelectedOptions);
5204 };
5205
5206 _this.selectOptions = function (selected) {
5207 var _this$props2 = _this.props,
5208 onSelect = _this$props2.onSelect,
5209 allowMultiple = _this$props2.allowMultiple;
5210 selected && onSelect(selected);
5211
5212 if (!allowMultiple) {
5213 _this.resetVisuallySelectedOptions();
5214
5215 _this.setState({
5216 popoverActive: false,
5217 popoverWasActive: false
5218 });
5219 }
5220 };
5221
5222 _this.updateIndexOfSelectedOption = function (newOptions) {
5223 var _this$state = _this.state,
5224 selectedIndex = _this$state.selectedIndex,
5225 selectedOption = _this$state.selectedOption;
5226
5227 if (selectedOption && newOptions.includes(selectedOption)) {
5228 _this.selectOptionAtIndex(newOptions.indexOf(selectedOption));
5229 } else if (selectedIndex > newOptions.length - 1) {
5230 _this.resetVisuallySelectedOptions();
5231 } else {
5232 _this.selectOptionAtIndex(selectedIndex);
5233 }
5234 };
5235
5236 _this.resetVisuallySelectedOptions = function () {
5237 var navigableOptions = _this.state.navigableOptions;
5238
5239 _this.setState({
5240 selectedOption: undefined,
5241 selectedIndex: -1
5242 });
5243
5244 navigableOptions && navigableOptions.forEach(function (option) {
5245 option.active = false;
5246 });
5247 };
5248
5249 _this.handlePopoverClose = function () {
5250 _this.setState({
5251 popoverActive: false,
5252 popoverWasActive: false
5253 });
5254 };
5255
5256 _this.handlePopoverOpen = function () {
5257 var _this$state2 = _this.state,
5258 popoverActive = _this$state2.popoverActive,
5259 navigableOptions = _this$state2.navigableOptions;
5260 !popoverActive && navigableOptions && navigableOptions.length > 0 && _this.setState({
5261 popoverActive: true,
5262 popoverWasActive: true
5263 });
5264 };
5265
5266 _this.selectNextOption = function () {
5267 var _this$state3 = _this.state,
5268 selectedIndex = _this$state3.selectedIndex,
5269 navigableOptions = _this$state3.navigableOptions;
5270
5271 if (!navigableOptions || navigableOptions.length === 0) {
5272 return;
5273 }
5274
5275 var newIndex = selectedIndex;
5276
5277 if (selectedIndex + 1 >= navigableOptions.length) {
5278 newIndex = 0;
5279 } else {
5280 newIndex++;
5281 }
5282
5283 _this.selectOptionAtIndex(newIndex);
5284 };
5285
5286 _this.selectPreviousOption = function () {
5287 var _this$state4 = _this.state,
5288 selectedIndex = _this$state4.selectedIndex,
5289 navigableOptions = _this$state4.navigableOptions;
5290
5291 if (!navigableOptions || navigableOptions.length === 0) {
5292 return;
5293 }
5294
5295 var newIndex = selectedIndex;
5296
5297 if (selectedIndex <= 0) {
5298 newIndex = navigableOptions.length - 1;
5299 } else {
5300 newIndex--;
5301 }
5302
5303 _this.selectOptionAtIndex(newIndex);
5304 };
5305
5306 _this.selectOptionAtIndex = function (newOptionIndex) {
5307 _this.setState(function (prevState) {
5308 if (!prevState.navigableOptions || prevState.navigableOptions.length === 0) {
5309 return prevState;
5310 }
5311
5312 var newSelectedOption = prevState.navigableOptions[newOptionIndex];
5313
5314 _this.visuallyUpdateSelectedOption(newSelectedOption, prevState.selectedOption);
5315
5316 return Object.assign(Object.assign({}, prevState), {
5317 selectedOption: newSelectedOption,
5318 selectedIndex: newOptionIndex
5319 });
5320 });
5321 };
5322
5323 _this.visuallyUpdateSelectedOption = function (newOption, oldOption) {
5324 if (oldOption) {
5325 oldOption.active = false;
5326 }
5327
5328 if (newOption) {
5329 newOption.active = true;
5330 }
5331 };
5332
5333 return _this;
5334 }
5335
5336 _createClass(ComboBox, [{
5337 key: "componentDidMount",
5338 value: function componentDidMount() {
5339 var _this$props3 = this.props,
5340 options = _this$props3.options,
5341 actionsBefore = _this$props3.actionsBefore,
5342 actionsAfter = _this$props3.actionsAfter;
5343 var comboBoxId = this.getComboBoxId();
5344 var navigableOptions = [];
5345
5346 if (actionsBefore) {
5347 navigableOptions = navigableOptions.concat(actionsBefore);
5348 }
5349
5350 if (options) {
5351 navigableOptions = navigableOptions.concat(options);
5352 }
5353
5354 if (actionsAfter) {
5355 navigableOptions = navigableOptions.concat(actionsAfter);
5356 }
5357
5358 navigableOptions = assignOptionIds(navigableOptions, comboBoxId);
5359 this.setState({
5360 navigableOptions
5361 });
5362 }
5363 }, {
5364 key: "componentDidUpdate",
5365 value: function componentDidUpdate(_, prevState) {
5366 var _this$props4 = this.props,
5367 contentBefore = _this$props4.contentBefore,
5368 contentAfter = _this$props4.contentAfter,
5369 emptyState = _this$props4.emptyState;
5370 var _this$state5 = this.state,
5371 navigableOptions = _this$state5.navigableOptions,
5372 popoverWasActive = _this$state5.popoverWasActive;
5373 var optionsChanged = navigableOptions && prevState.navigableOptions && !optionsAreEqual(navigableOptions, prevState.navigableOptions);
5374
5375 if (optionsChanged) {
5376 this.updateIndexOfSelectedOption(navigableOptions);
5377 }
5378
5379 if (navigableOptions && navigableOptions.length === 0 && !contentBefore && !contentAfter && !emptyState) {
5380 // eslint-disable-next-line react/no-did-update-set-state
5381 this.setState({
5382 popoverActive: false
5383 });
5384 } else if (popoverWasActive && navigableOptions && navigableOptions.length !== 0) {
5385 // eslint-disable-next-line react/no-did-update-set-state
5386 this.setState({
5387 popoverActive: true
5388 });
5389 }
5390 }
5391 }, {
5392 key: "getComboBoxId",
5393 value: function getComboBoxId() {
5394 if (this.state && this.state.comboBoxId) {
5395 return this.state.comboBoxId;
5396 }
5397
5398 return this.props.id || getUniqueId();
5399 }
5400 }, {
5401 key: "render",
5402 value: function render() {
5403 var _this$props5 = this.props,
5404 options = _this$props5.options,
5405 textField = _this$props5.textField,
5406 listTitle = _this$props5.listTitle,
5407 allowMultiple = _this$props5.allowMultiple,
5408 preferredPosition = _this$props5.preferredPosition,
5409 actionsBefore = _this$props5.actionsBefore,
5410 actionsAfter = _this$props5.actionsAfter,
5411 contentBefore = _this$props5.contentBefore,
5412 contentAfter = _this$props5.contentAfter,
5413 onEndReached = _this$props5.onEndReached,
5414 emptyState = _this$props5.emptyState;
5415 var _this$state6 = this.state,
5416 comboBoxId = _this$state6.comboBoxId,
5417 navigableOptions = _this$state6.navigableOptions,
5418 selectedOptions = _this$state6.selectedOptions;
5419 var actionsBeforeMarkup = actionsBefore && actionsBefore.length > 0 && React__default.createElement(ActionList, {
5420 actionRole: "option",
5421 items: actionsBefore
5422 });
5423 var actionsAfterMarkup = actionsAfter && actionsAfter.length > 0 && React__default.createElement(ActionList, {
5424 actionRole: "option",
5425 items: actionsAfter
5426 });
5427 var optionsMarkup = options.length > 0 && React__default.createElement(OptionList, {
5428 role: "presentation",
5429 optionRole: "option",
5430 options: filterForOptions(navigableOptions),
5431 onChange: this.selectOptions,
5432 selected: selectedOptions,
5433 title: listTitle,
5434 allowMultiple: allowMultiple
5435 });
5436 var emptyStateMarkup = !actionsAfter && !actionsBefore && !contentAfter && !contentBefore && options.length === 0 && emptyState && React__default.createElement("div", {
5437 className: styles$p.EmptyState
5438 }, emptyState);
5439 var context = {
5440 comboBoxId,
5441 selectedOptionId: this.selectedOptionId()
5442 };
5443 return React__default.createElement(ComboBoxContext.Provider, {
5444 value: context
5445 }, React__default.createElement("div", {
5446 onClick: this.handleClick,
5447 role: "combobox",
5448 "aria-expanded": this.state.popoverActive,
5449 "aria-owns": this.state.comboBoxId,
5450 "aria-controls": this.state.comboBoxId,
5451 "aria-haspopup": true,
5452 onFocus: this.handleFocus,
5453 onBlur: this.handleBlur,
5454 tabIndex: 0
5455 }, React__default.createElement(KeypressListener, {
5456 keyCode: Key.DownArrow,
5457 handler: this.handleDownArrow
5458 }), React__default.createElement(KeypressListener, {
5459 keyCode: Key.UpArrow,
5460 handler: this.handleUpArrow
5461 }), React__default.createElement(EventListener, {
5462 event: "keydown",
5463 handler: this.handleEnter
5464 }), React__default.createElement(KeypressListener, {
5465 keyCode: Key.Escape,
5466 handler: this.handlePopoverClose
5467 }), React__default.createElement(Popover, {
5468 activator: textField,
5469 active: this.state.popoverActive,
5470 onClose: this.handlePopoverClose,
5471 preferredPosition: preferredPosition,
5472 fullWidth: true,
5473 preventAutofocus: true
5474 }, React__default.createElement(Popover.Pane, {
5475 onScrolledToBottom: onEndReached
5476 }, React__default.createElement("div", {
5477 id: this.state.comboBoxId,
5478 role: "listbox",
5479 "aria-multiselectable": allowMultiple
5480 }, contentBefore, actionsBeforeMarkup, optionsMarkup, actionsAfterMarkup, contentAfter, emptyStateMarkup)))));
5481 }
5482 }, {
5483 key: "selectedOptionId",
5484 value: function selectedOptionId() {
5485 var _this$state7 = this.state,
5486 selectedOption = _this$state7.selectedOption,
5487 selectedIndex = _this$state7.selectedIndex,
5488 comboBoxId = _this$state7.comboBoxId;
5489 return selectedOption ? "".concat(comboBoxId, "-").concat(selectedIndex) : undefined;
5490 }
5491 }], [{
5492 key: "getDerivedStateFromProps",
5493 value: function getDerivedStateFromProps(_ref, _ref2) {
5494 var nextOptions = _ref.options,
5495 nextSelected = _ref.selected,
5496 nextActionsBefore = _ref.actionsBefore,
5497 nextActionsAfter = _ref.actionsAfter;
5498 var navigableOptions = _ref2.navigableOptions,
5499 selectedOptions = _ref2.selectedOptions,
5500 comboBoxId = _ref2.comboBoxId;
5501 var optionsChanged = filterForOptions(navigableOptions) && nextOptions && !optionsAreEqual(navigableOptions, nextOptions);
5502 var newNavigableOptions = [];
5503
5504 if (nextActionsBefore) {
5505 newNavigableOptions = newNavigableOptions.concat(nextActionsBefore);
5506 }
5507
5508 if (optionsChanged || nextActionsBefore) {
5509 newNavigableOptions = newNavigableOptions.concat(nextOptions);
5510 }
5511
5512 if (nextActionsAfter) {
5513 newNavigableOptions = newNavigableOptions.concat(nextActionsAfter);
5514 }
5515
5516 newNavigableOptions = assignOptionIds(newNavigableOptions, comboBoxId);
5517
5518 if (optionsChanged && selectedOptions !== nextSelected) {
5519 return {
5520 navigableOptions: newNavigableOptions,
5521 selectedOptions: nextSelected
5522 };
5523 } else if (optionsChanged) {
5524 return {
5525 navigableOptions: newNavigableOptions
5526 };
5527 } else if (selectedOptions !== nextSelected) {
5528 return {
5529 selectedOptions: nextSelected
5530 };
5531 }
5532
5533 return null;
5534 }
5535 }]);
5536
5537 return ComboBox;
5538}(React__default.PureComponent);
5539
5540function assignOptionIds(options, comboBoxId) {
5541 options.map(function (option, optionIndex) {
5542 option.id = "".concat(comboBoxId, "-").concat(optionIndex);
5543 });
5544 return options;
5545}
5546
5547function optionsAreEqual(firstOptions, secondOptions) {
5548 if (firstOptions.length !== secondOptions.length) {
5549 return false;
5550 }
5551
5552 return firstOptions.every(function (firstItem, index) {
5553 var secondItem = secondOptions[index];
5554
5555 if (isOption(firstItem)) {
5556 if (isOption(secondItem)) {
5557 return firstItem.value === secondItem.value;
5558 }
5559
5560 return false;
5561 } else {
5562 if (!isOption(secondItem)) {
5563 return firstItem.content === secondItem.content;
5564 }
5565
5566 return false;
5567 }
5568 });
5569}
5570
5571function isOption(navigableOption) {
5572 return navigableOption.value !== undefined;
5573}
5574
5575function filterForOptions(mixedArray) {
5576 return mixedArray.filter(function (item) {
5577 return isOption(item);
5578 });
5579}
5580
5581var styles$q = {
5582 "Label": "Polaris-Label",
5583 "hidden": "Polaris-Label--hidden",
5584 "Text": "Polaris-Label__Text"
5585};
5586
5587function labelID(id) {
5588 return "".concat(id, "Label");
5589}
5590function Label(_ref) {
5591 var children = _ref.children,
5592 id = _ref.id,
5593 hidden = _ref.hidden;
5594 var className = classNames(styles$q.Label, hidden && styles$q.hidden);
5595 return React__default.createElement("div", {
5596 className: className
5597 }, React__default.createElement("label", {
5598 id: labelID(id),
5599 htmlFor: id,
5600 className: styles$q.Text
5601 }, children));
5602}
5603
5604var styles$r = {
5605 "InlineError": "Polaris-InlineError",
5606 "Icon": "Polaris-InlineError__Icon"
5607};
5608
5609function InlineError(_ref) {
5610 var message = _ref.message,
5611 fieldID = _ref.fieldID;
5612
5613 if (!message) {
5614 return null;
5615 }
5616
5617 return React__default.createElement("div", {
5618 id: errorTextID(fieldID),
5619 className: styles$r.InlineError
5620 }, React__default.createElement("div", {
5621 className: styles$r.Icon
5622 }, React__default.createElement(Icon, {
5623 source: AlertMinor
5624 })), message);
5625}
5626function errorTextID(id) {
5627 return "".concat(id, "Error");
5628}
5629
5630var styles$s = {
5631 "hidden": "Polaris-Labelled--hidden",
5632 "LabelWrapper": "Polaris-Labelled__LabelWrapper",
5633 "HelpText": "Polaris-Labelled__HelpText",
5634 "Error": "Polaris-Labelled__Error",
5635 "Action": "Polaris-Labelled__Action"
5636};
5637
5638function Labelled(_a) {
5639 var id = _a.id,
5640 label = _a.label,
5641 error = _a.error,
5642 action = _a.action,
5643 helpText = _a.helpText,
5644 children = _a.children,
5645 labelHidden = _a.labelHidden,
5646 rest = __rest(_a, ["id", "label", "error", "action", "helpText", "children", "labelHidden"]);
5647
5648 var className = classNames(labelHidden && styles$s.hidden);
5649 var actionMarkup = action ? React__default.createElement("div", {
5650 className: styles$s.Action
5651 }, buttonFrom(action, {
5652 plain: true
5653 })) : null;
5654 var helpTextMarkup = helpText ? React__default.createElement("div", {
5655 className: styles$s.HelpText,
5656 id: helpTextID(id)
5657 }, helpText) : null;
5658 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
5659 className: styles$s.Error
5660 }, React__default.createElement(InlineError, {
5661 message: error,
5662 fieldID: id
5663 }));
5664 var labelMarkup = label ? React__default.createElement("div", {
5665 className: styles$s.LabelWrapper
5666 }, React__default.createElement(Label, Object.assign({
5667 id: id
5668 }, rest, {
5669 hidden: false
5670 }), label), actionMarkup) : null;
5671 return React__default.createElement("div", {
5672 className: className
5673 }, labelMarkup, children, errorMarkup, helpTextMarkup);
5674}
5675function helpTextID(id) {
5676 return "".concat(id, "HelpText");
5677}
5678
5679var styles$t = {
5680 "Connected": "Polaris-Connected",
5681 "Item": "Polaris-Connected__Item",
5682 "Item-primary": "Polaris-Connected__Item--primary",
5683 "Item-connection": "Polaris-Connected__Item--connection",
5684 "Item-focused": "Polaris-Connected__Item--focused"
5685};
5686
5687var Item$3 =
5688/*#__PURE__*/
5689function (_React$PureComponent) {
5690 _inherits(Item, _React$PureComponent);
5691
5692 function Item() {
5693 var _this;
5694
5695 _classCallCheck(this, Item);
5696
5697 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
5698 _this.state = {
5699 focused: false
5700 };
5701
5702 _this.handleBlur = function () {
5703 _this.setState({
5704 focused: false
5705 });
5706 };
5707
5708 _this.handleFocus = function () {
5709 _this.setState({
5710 focused: true
5711 });
5712 };
5713
5714 return _this;
5715 }
5716
5717 _createClass(Item, [{
5718 key: "render",
5719 value: function render() {
5720 var focused = this.state.focused;
5721 var _this$props = this.props,
5722 children = _this$props.children,
5723 position = _this$props.position;
5724 var className = classNames(styles$t.Item, focused && styles$t['Item-focused'], position === 'primary' ? styles$t['Item-primary'] : styles$t['Item-connection']);
5725 return React__default.createElement("div", {
5726 onBlur: this.handleBlur,
5727 onFocus: this.handleFocus,
5728 className: className
5729 }, children);
5730 }
5731 }]);
5732
5733 return Item;
5734}(React__default.PureComponent);
5735
5736function Connected(_ref) {
5737 var children = _ref.children,
5738 left = _ref.left,
5739 right = _ref.right;
5740 var leftConnectionMarkup = left ? React__default.createElement(Item$3, {
5741 position: "left"
5742 }, left) : null;
5743 var rightConnectionMarkup = right ? React__default.createElement(Item$3, {
5744 position: "right"
5745 }, right) : null;
5746 return React__default.createElement("div", {
5747 className: styles$t.Connected
5748 }, leftConnectionMarkup, React__default.createElement(Item$3, {
5749 position: "primary"
5750 }, children), rightConnectionMarkup);
5751}
5752
5753var styles$u = {
5754 "TextField": "Polaris-TextField",
5755 "multiline": "Polaris-TextField--multiline",
5756 "Input": "Polaris-TextField__Input",
5757 "hasValue": "Polaris-TextField--hasValue",
5758 "focus": "Polaris-TextField--focus",
5759 "Backdrop": "Polaris-TextField__Backdrop",
5760 "error": "Polaris-TextField--error",
5761 "readOnly": "Polaris-TextField--readOnly",
5762 "disabled": "Polaris-TextField--disabled",
5763 "Prefix": "Polaris-TextField__Prefix",
5764 "Input-hasClearButton": "Polaris-TextField__Input--hasClearButton",
5765 "Input-suffixed": "Polaris-TextField__Input--suffixed",
5766 "Input-alignRight": "Polaris-TextField__Input--alignRight",
5767 "Input-alignLeft": "Polaris-TextField__Input--alignLeft",
5768 "Input-alignCenter": "Polaris-TextField__Input--alignCenter",
5769 "Suffix": "Polaris-TextField__Suffix",
5770 "CharacterCount": "Polaris-TextField__CharacterCount",
5771 "AlignFieldBottom": "Polaris-TextField__AlignFieldBottom",
5772 "ClearButton": "Polaris-TextField__ClearButton",
5773 "Spinner": "Polaris-TextField__Spinner",
5774 "SpinnerIcon": "Polaris-TextField__SpinnerIcon",
5775 "Resizer": "Polaris-TextField__Resizer",
5776 "DummyInput": "Polaris-TextField__DummyInput",
5777 "Segment": "Polaris-TextField__Segment",
5778 "newDesignLanguage": "Polaris-TextField--newDesignLanguage",
5779 "Backdrop-connectedLeft": "Polaris-TextField__Backdrop--connectedLeft",
5780 "Backdrop-connectedRight": "Polaris-TextField__Backdrop--connectedRight"
5781};
5782
5783function Resizer(_ref) {
5784 var contents = _ref.contents,
5785 _ref$currentHeight = _ref.currentHeight,
5786 currentHeightProp = _ref$currentHeight === void 0 ? null : _ref$currentHeight,
5787 minimumLines = _ref.minimumLines,
5788 onHeightChange = _ref.onHeightChange;
5789 var contentNode = useRef(null);
5790 var minimumLinesNode = useRef(null);
5791 var animationFrame = useRef();
5792 var currentHeight = useRef(currentHeightProp);
5793
5794 if (currentHeightProp !== currentHeight.current) {
5795 currentHeight.current = currentHeightProp;
5796 }
5797
5798 useEffect(function () {
5799 return function () {
5800 if (animationFrame.current) {
5801 cancelAnimationFrame(animationFrame.current);
5802 }
5803 };
5804 }, []);
5805 var minimumLinesMarkup = minimumLines ? React__default.createElement("div", {
5806 ref: minimumLinesNode,
5807 className: styles$u.DummyInput,
5808 dangerouslySetInnerHTML: {
5809 __html: getContentsForMinimumLines(minimumLines)
5810 }
5811 }) : null;
5812 var handleHeightCheck = useCallback(function () {
5813 if (animationFrame.current) {
5814 cancelAnimationFrame(animationFrame.current);
5815 }
5816
5817 animationFrame.current = requestAnimationFrame(function () {
5818 if (!contentNode.current || !minimumLinesNode.current) {
5819 return;
5820 }
5821
5822 var newHeight = Math.max(contentNode.current.offsetHeight, minimumLinesNode.current.offsetHeight);
5823
5824 if (newHeight !== currentHeight.current) {
5825 onHeightChange(newHeight);
5826 }
5827 });
5828 }, [onHeightChange]);
5829 useLayoutEffect(function () {
5830 handleHeightCheck();
5831 });
5832 return React__default.createElement("div", {
5833 "aria-hidden": true,
5834 className: styles$u.Resizer
5835 }, React__default.createElement(EventListener, {
5836 event: "resize",
5837 handler: handleHeightCheck
5838 }), React__default.createElement("div", {
5839 ref: contentNode,
5840 className: styles$u.DummyInput,
5841 dangerouslySetInnerHTML: {
5842 __html: getFinalContents(contents)
5843 }
5844 }), minimumLinesMarkup);
5845}
5846var ENTITIES_TO_REPLACE = {
5847 '&': '&amp;',
5848 '<': '&lt;',
5849 '>': '&gt;',
5850 '\n': '<br>',
5851 '\r': ''
5852};
5853var REPLACE_REGEX$1 = new RegExp("[".concat(Object.keys(ENTITIES_TO_REPLACE).join(), "]"), 'g');
5854
5855function replaceEntity(entity) {
5856 return ENTITIES_TO_REPLACE[entity];
5857}
5858
5859function getContentsForMinimumLines(minimumLines) {
5860 var content = '';
5861
5862 for (var line = 0; line < minimumLines; line++) {
5863 content += '<br>';
5864 }
5865
5866 return content;
5867}
5868
5869function getFinalContents(contents) {
5870 return contents ? "".concat(contents.replace(REPLACE_REGEX$1, replaceEntity), "<br>") : '<br>';
5871}
5872
5873function Spinner$1(_ref) {
5874 var onChange = _ref.onChange,
5875 onClick = _ref.onClick,
5876 onMouseDown = _ref.onMouseDown,
5877 onMouseUp = _ref.onMouseUp;
5878
5879 function handleStep(step) {
5880 return function () {
5881 return onChange(step);
5882 };
5883 }
5884
5885 function handleMouseDown(onChange) {
5886 return function (event) {
5887 if (event.button !== 0) return;
5888 onMouseDown(onChange);
5889 };
5890 }
5891
5892 return React__default.createElement("div", {
5893 className: styles$u.Spinner,
5894 onClick: onClick,
5895 "aria-hidden": true
5896 }, React__default.createElement("div", {
5897 role: "button",
5898 className: styles$u.Segment,
5899 tabIndex: -1,
5900 onClick: handleStep(1),
5901 onMouseDown: handleMouseDown(handleStep(1)),
5902 onMouseUp: onMouseUp
5903 }, React__default.createElement("div", {
5904 className: styles$u.SpinnerIcon
5905 }, React__default.createElement(Icon, {
5906 source: CaretUpMinor
5907 }))), React__default.createElement("div", {
5908 role: "button",
5909 className: styles$u.Segment,
5910 tabIndex: -1,
5911 onClick: handleStep(-1),
5912 onMouseDown: handleMouseDown(handleStep(-1)),
5913 onMouseUp: onMouseUp
5914 }, React__default.createElement("div", {
5915 className: styles$u.SpinnerIcon
5916 }, React__default.createElement(Icon, {
5917 source: CaretDownMinor
5918 }))));
5919}
5920
5921function TextField(_ref) {
5922 var prefix = _ref.prefix,
5923 suffix = _ref.suffix,
5924 placeholder = _ref.placeholder,
5925 value = _ref.value,
5926 helpText = _ref.helpText,
5927 label = _ref.label,
5928 labelAction = _ref.labelAction,
5929 labelHidden = _ref.labelHidden,
5930 disabled = _ref.disabled,
5931 clearButton = _ref.clearButton,
5932 readOnly = _ref.readOnly,
5933 autoFocus = _ref.autoFocus,
5934 focused = _ref.focused,
5935 multiline = _ref.multiline,
5936 error = _ref.error,
5937 connectedRight = _ref.connectedRight,
5938 connectedLeft = _ref.connectedLeft,
5939 type = _ref.type,
5940 name = _ref.name,
5941 idProp = _ref.id,
5942 role = _ref.role,
5943 step = _ref.step,
5944 autoComplete = _ref.autoComplete,
5945 max = _ref.max,
5946 maxLength = _ref.maxLength,
5947 min = _ref.min,
5948 minLength = _ref.minLength,
5949 pattern = _ref.pattern,
5950 spellCheck = _ref.spellCheck,
5951 ariaOwns = _ref.ariaOwns,
5952 ariaControls = _ref.ariaControls,
5953 ariaActiveDescendant = _ref.ariaActiveDescendant,
5954 ariaAutocomplete = _ref.ariaAutocomplete,
5955 showCharacterCount = _ref.showCharacterCount,
5956 align = _ref.align,
5957 onClearButtonClick = _ref.onClearButtonClick,
5958 onChange = _ref.onChange,
5959 onFocus = _ref.onFocus,
5960 onBlur = _ref.onBlur;
5961 var i18n = useI18n();
5962
5963 var _useState = useState(null),
5964 _useState2 = _slicedToArray(_useState, 2),
5965 height = _useState2[0],
5966 setHeight = _useState2[1];
5967
5968 var _useState3 = useState(Boolean(focused)),
5969 _useState4 = _slicedToArray(_useState3, 2),
5970 focus = _useState4[0],
5971 setFocus = _useState4[1];
5972
5973 var isAfterInitial = useIsAfterInitialMount();
5974 var id = useUniqueId('TextField', idProp);
5975 var inputRef = useRef(null);
5976 var prefixRef = useRef(null);
5977 var suffixRef = useRef(null);
5978 var buttonPressTimer = useRef();
5979 useEffect(function () {
5980 var input = inputRef.current;
5981 if (!input || focused === undefined) return;
5982 focused ? input.focus() : input.blur();
5983 }, [focused]);
5984
5985 var _useFeatures = useFeatures(),
5986 newDesignLanguage = _useFeatures.newDesignLanguage; // Use a typeof check here as Typescript mostly protects us from non-stringy
5987 // values but overzealous usage of `any` in consuming apps means people have
5988 // been known to pass a number in, so make it clear that doesn't work.
5989
5990
5991 var normalizedValue = typeof value === 'string' ? value : '';
5992 var normalizedStep = step != null ? step : 1;
5993 var normalizedMax = max != null ? max : Infinity;
5994 var normalizedMin = min != null ? min : -Infinity;
5995 var className = classNames(styles$u.TextField, Boolean(normalizedValue) && styles$u.hasValue, disabled && styles$u.disabled, readOnly && styles$u.readOnly, error && styles$u.error, multiline && styles$u.multiline, focus && styles$u.focus, newDesignLanguage && styles$u.newDesignLanguage);
5996 var inputType = type === 'currency' ? 'text' : type;
5997 var prefixMarkup = prefix ? React__default.createElement("div", {
5998 className: styles$u.Prefix,
5999 id: "".concat(id, "Prefix"),
6000 ref: prefixRef
6001 }, prefix) : null;
6002 var suffixMarkup = suffix ? React__default.createElement("div", {
6003 className: styles$u.Suffix,
6004 id: "".concat(id, "Suffix"),
6005 ref: suffixRef
6006 }, suffix) : null;
6007 var characterCountMarkup = null;
6008
6009 if (showCharacterCount) {
6010 var characterCount = normalizedValue.length;
6011 var characterCountLabel = maxLength ? i18n.translate('Polaris.TextField.characterCountWithMaxLength', {
6012 count: characterCount,
6013 limit: maxLength
6014 }) : i18n.translate('Polaris.TextField.characterCount', {
6015 count: characterCount
6016 });
6017 var characterCountClassName = classNames(styles$u.CharacterCount, multiline && styles$u.AlignFieldBottom);
6018 var characterCountText = !maxLength ? characterCount : "".concat(characterCount, "/").concat(maxLength);
6019 characterCountMarkup = React__default.createElement("div", {
6020 id: "".concat(id, "CharacterCounter"),
6021 className: characterCountClassName,
6022 "aria-label": characterCountLabel,
6023 "aria-live": focus ? 'polite' : 'off',
6024 "aria-atomic": "true"
6025 }, characterCountText);
6026 }
6027
6028 var clearButtonMarkup = clearButton && normalizedValue !== '' ? React__default.createElement("button", {
6029 type: "button",
6030 className: styles$u.ClearButton,
6031 onClick: handleClearButtonPress,
6032 disabled: disabled
6033 }, React__default.createElement(VisuallyHidden, null, i18n.translate('Polaris.Common.clear')), React__default.createElement(Icon, {
6034 source: CircleCancelMinor,
6035 color: "inkLightest"
6036 })) : null;
6037 var handleNumberChange = useCallback(function (steps) {
6038 if (onChange == null) {
6039 return;
6040 } // Returns the length of decimal places in a number
6041
6042
6043 var dpl = function dpl(num) {
6044 return (num.toString().split('.')[1] || []).length;
6045 };
6046
6047 var numericValue = value ? parseFloat(value) : 0;
6048
6049 if (isNaN(numericValue)) {
6050 return;
6051 } // Making sure the new value has the same length of decimal places as the
6052 // step / value has.
6053
6054
6055 var decimalPlaces = Math.max(dpl(numericValue), dpl(normalizedStep));
6056 var newValue = Math.min(Number(normalizedMax), Math.max(numericValue + steps * normalizedStep, Number(normalizedMin)));
6057 onChange(String(newValue.toFixed(decimalPlaces)), id);
6058 }, [id, normalizedMax, normalizedMin, onChange, normalizedStep, value]);
6059 var handleButtonRelease = useCallback(function () {
6060 clearTimeout(buttonPressTimer.current);
6061 }, []);
6062 var handleButtonPress = useCallback(function (onChange) {
6063 var minInterval = 50;
6064 var decrementBy = 10;
6065 var interval = 200;
6066
6067 var onChangeInterval = function onChangeInterval() {
6068 if (interval > minInterval) interval -= decrementBy;
6069 onChange();
6070 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6071 };
6072
6073 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6074 addEventListener(document, 'mouseup', handleButtonRelease, {
6075 once: true
6076 });
6077 }, [handleButtonRelease]);
6078 var spinnerMarkup = type === 'number' && !disabled && !readOnly ? React__default.createElement(Spinner$1, {
6079 onChange: handleNumberChange,
6080 onMouseDown: handleButtonPress,
6081 onMouseUp: handleButtonRelease
6082 }) : null;
6083 var style = multiline && height ? {
6084 height
6085 } : null;
6086 var handleExpandingResize = useCallback(function (height) {
6087 setHeight(height);
6088 }, []);
6089 var resizer = multiline && isAfterInitial ? React__default.createElement(Resizer, {
6090 contents: normalizedValue || placeholder,
6091 currentHeight: height,
6092 minimumLines: typeof multiline === 'number' ? multiline : 1,
6093 onHeightChange: handleExpandingResize
6094 }) : null;
6095 var describedBy = [];
6096
6097 if (error) {
6098 describedBy.push("".concat(id, "Error"));
6099 }
6100
6101 if (helpText) {
6102 describedBy.push(helpTextID(id));
6103 }
6104
6105 if (showCharacterCount) {
6106 describedBy.push("".concat(id, "CharacterCounter"));
6107 }
6108
6109 var labelledBy = [];
6110
6111 if (prefix) {
6112 labelledBy.push("".concat(id, "Prefix"));
6113 }
6114
6115 if (suffix) {
6116 labelledBy.push("".concat(id, "Suffix"));
6117 }
6118
6119 labelledBy.unshift(labelID(id));
6120 var inputClassName = classNames(styles$u.Input, align && styles$u[variationName('Input-align', align)], suffix && styles$u['Input-suffixed'], clearButton && styles$u['Input-hasClearButton']);
6121 var input = React__default.createElement(multiline ? 'textarea' : 'input', {
6122 name,
6123 id,
6124 disabled,
6125 readOnly,
6126 role,
6127 autoFocus,
6128 value: normalizedValue,
6129 placeholder,
6130 onFocus,
6131 onBlur,
6132 onKeyPress: handleKeyPress,
6133 style,
6134 autoComplete: normalizeAutoComplete(autoComplete),
6135 className: inputClassName,
6136 onChange: handleChange,
6137 ref: inputRef,
6138 min,
6139 max,
6140 step,
6141 minLength,
6142 maxLength,
6143 spellCheck,
6144 pattern,
6145 type: inputType,
6146 'aria-describedby': describedBy.length ? describedBy.join(' ') : undefined,
6147 'aria-labelledby': labelledBy.join(' '),
6148 'aria-invalid': Boolean(error),
6149 'aria-owns': ariaOwns,
6150 'aria-activedescendant': ariaActiveDescendant,
6151 'aria-autocomplete': ariaAutocomplete,
6152 'aria-controls': ariaControls,
6153 'aria-multiline': normalizeAriaMultiline(multiline)
6154 });
6155 var backdropClassName = classNames(styles$u.Backdrop, newDesignLanguage && connectedLeft && styles$u['Backdrop-connectedLeft'], newDesignLanguage && connectedRight && styles$u['Backdrop-connectedRight']);
6156 return React__default.createElement(Labelled, {
6157 label: label,
6158 id: id,
6159 error: error,
6160 action: labelAction,
6161 labelHidden: labelHidden,
6162 helpText: helpText
6163 }, React__default.createElement(Connected, {
6164 left: connectedLeft,
6165 right: connectedRight
6166 }, React__default.createElement("div", {
6167 className: className,
6168 onFocus: handleFocus,
6169 onBlur: handleBlur,
6170 onClick: handleClick
6171 }, prefixMarkup, input, suffixMarkup, characterCountMarkup, clearButtonMarkup, spinnerMarkup, React__default.createElement("div", {
6172 className: backdropClassName
6173 }), resizer)));
6174
6175 function handleClearButtonPress() {
6176 onClearButtonClick && onClearButtonClick(id);
6177 }
6178
6179 function handleKeyPress(event) {
6180 var key = event.key,
6181 which = event.which;
6182 var numbersSpec = /[\d.eE+-]$/;
6183
6184 if (type !== 'number' || which === Key.Enter || numbersSpec.test(key)) {
6185 return;
6186 }
6187
6188 event.preventDefault();
6189 }
6190
6191 function containsAffix(target) {
6192 return target instanceof HTMLElement && (prefixRef.current && prefixRef.current.contains(target) || suffixRef.current && suffixRef.current.contains(target));
6193 }
6194
6195 function handleChange(event) {
6196 onChange && onChange(event.currentTarget.value, id);
6197 }
6198
6199 function handleFocus(_ref2) {
6200 var target = _ref2.target;
6201
6202 if (containsAffix(target)) {
6203 return;
6204 }
6205
6206 setFocus(true);
6207 }
6208
6209 function handleBlur() {
6210 setFocus(false);
6211 }
6212
6213 function handleClick(_ref3) {
6214 var target = _ref3.target;
6215
6216 if (containsAffix(target)) {
6217 return;
6218 }
6219
6220 inputRef.current && inputRef.current.focus();
6221 }
6222}
6223
6224function normalizeAutoComplete(autoComplete) {
6225 if (autoComplete == null) {
6226 return autoComplete;
6227 } else if (autoComplete === true) {
6228 return 'on';
6229 } else if (autoComplete === false) {
6230 return 'off';
6231 } else {
6232 return autoComplete;
6233 }
6234}
6235
6236function normalizeAriaMultiline(multiline) {
6237 switch (typeof multiline) {
6238 case 'undefined':
6239 return false;
6240
6241 case 'boolean':
6242 return multiline;
6243
6244 case 'number':
6245 return Boolean(multiline > 0);
6246 }
6247}
6248
6249function TextField$1(props) {
6250 return React__default.createElement(ComboBoxContext.Consumer, null, function (_ref) {
6251 var selectedOptionId = _ref.selectedOptionId,
6252 comboBoxId = _ref.comboBoxId;
6253 return React__default.createElement(TextField, Object.assign({}, props, {
6254 autoComplete: false,
6255 ariaAutocomplete: "list",
6256 ariaActiveDescendant: selectedOptionId,
6257 ariaControls: comboBoxId
6258 }));
6259 });
6260}
6261
6262var styles$v = {
6263 "Loading": "Polaris-Autocomplete__Loading"
6264};
6265
6266// subcomponents so explicitly state the subcomponents in the type definition.
6267// Letting this be implicit works in this project but fails in projects that use
6268// generated *.d.ts files.
6269
6270var Autocomplete = function Autocomplete(_ref) {
6271 var id = _ref.id,
6272 options = _ref.options,
6273 selected = _ref.selected,
6274 textField = _ref.textField,
6275 preferredPosition = _ref.preferredPosition,
6276 listTitle = _ref.listTitle,
6277 allowMultiple = _ref.allowMultiple,
6278 loading = _ref.loading,
6279 actionBefore = _ref.actionBefore,
6280 willLoadMoreResults = _ref.willLoadMoreResults,
6281 emptyState = _ref.emptyState,
6282 onSelect = _ref.onSelect,
6283 onLoadMoreResults = _ref.onLoadMoreResults;
6284 var i18n = useI18n();
6285 var spinnerMarkup = loading ? React__default.createElement("div", {
6286 className: styles$v.Loading
6287 }, React__default.createElement(Spinner, {
6288 size: "small",
6289 accessibilityLabel: i18n.translate('Polaris.Autocomplete.spinnerAccessibilityLabel')
6290 })) : null;
6291 var conditionalOptions = loading && !willLoadMoreResults ? [] : options;
6292 var conditionalAction = actionBefore && actionBefore !== [] ? [actionBefore] : undefined;
6293 return React__default.createElement(ComboBox, {
6294 id: id,
6295 options: conditionalOptions,
6296 selected: selected,
6297 textField: textField,
6298 preferredPosition: preferredPosition,
6299 listTitle: listTitle,
6300 allowMultiple: allowMultiple,
6301 contentAfter: spinnerMarkup,
6302 actionsBefore: conditionalAction,
6303 onSelect: onSelect,
6304 onEndReached: onLoadMoreResults,
6305 emptyState: emptyState
6306 });
6307};
6308Autocomplete.ComboBox = ComboBox;
6309Autocomplete.TextField = TextField$1;
6310
6311// in the styleguide works without warnings about unfound props
6312
6313function ScrollLock(_) {
6314 var scrollLockManager = useScrollLockManager();
6315 useEffect(function () {
6316 scrollLockManager.registerScrollLock();
6317 return function () {
6318 scrollLockManager.unregisterScrollLock();
6319 };
6320 }, [scrollLockManager]);
6321 return null;
6322}
6323
6324var styles$w = {
6325 "Backdrop": "Polaris-Backdrop",
6326 "fade-in": "Polaris-Backdrop__fade--in",
6327 "transparent": "Polaris-Backdrop--transparent",
6328 "belowNavigation": "Polaris-Backdrop--belowNavigation"
6329};
6330
6331function Backdrop(props) {
6332 var onClick = props.onClick,
6333 onTouchStart = props.onTouchStart,
6334 belowNavigation = props.belowNavigation,
6335 transparent = props.transparent;
6336 var className = classNames(styles$w.Backdrop, belowNavigation && styles$w.belowNavigation, transparent && styles$w.transparent);
6337 return React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
6338 className: className,
6339 onClick: onClick,
6340 onTouchStart: onTouchStart
6341 }));
6342}
6343
6344var BannerContext = React__default.createContext(false);
6345
6346var styles$x = {
6347 "Banner": "Polaris-Banner",
6348 "withinContentContainer": "Polaris-Banner--withinContentContainer",
6349 "keyFocused": "Polaris-Banner--keyFocused",
6350 "statusSuccess": "Polaris-Banner--statusSuccess",
6351 "statusInfo": "Polaris-Banner--statusInfo",
6352 "statusWarning": "Polaris-Banner--statusWarning",
6353 "statusCritical": "Polaris-Banner--statusCritical",
6354 "Ribbon": "Polaris-Banner__Ribbon",
6355 "Actions": "Polaris-Banner__Actions",
6356 "Dismiss": "Polaris-Banner__Dismiss",
6357 "withinPage": "Polaris-Banner--withinPage",
6358 "hasDismiss": "Polaris-Banner--hasDismiss",
6359 "Heading": "Polaris-Banner__Heading",
6360 "Content": "Polaris-Banner__Content",
6361 "PrimaryAction": "Polaris-Banner__PrimaryAction",
6362 "SecondaryAction": "Polaris-Banner__SecondaryAction",
6363 "Text": "Polaris-Banner__Text"
6364};
6365
6366var Banner =
6367/*#__PURE__*/
6368function (_React$PureComponent) {
6369 _inherits(Banner, _React$PureComponent);
6370
6371 function Banner() {
6372 var _this;
6373
6374 _classCallCheck(this, Banner);
6375
6376 _this = _possibleConstructorReturn(this, _getPrototypeOf(Banner).apply(this, arguments));
6377 _this.state = {
6378 showFocus: false
6379 };
6380 _this.wrapper = React__default.createRef();
6381 return _this;
6382 }
6383
6384 _createClass(Banner, [{
6385 key: "focus",
6386 value: function focus() {
6387 this.wrapper.current && this.wrapper.current.focus();
6388 this.setState({
6389 showFocus: true
6390 });
6391 }
6392 }, {
6393 key: "render",
6394 value: function render() {
6395 var _this2 = this;
6396
6397 var showFocus = this.state.showFocus;
6398
6399 var handleKeyUp = function handleKeyUp(evt) {
6400 if (evt.target === _this2.wrapper.current) {
6401 _this2.setState({
6402 showFocus: true
6403 });
6404 }
6405 };
6406
6407 var handleBlur = function handleBlur() {
6408 _this2.setState({
6409 showFocus: false
6410 });
6411 };
6412
6413 var handleMouseUp = function handleMouseUp(_ref) {
6414 var currentTarget = _ref.currentTarget;
6415 var showFocus = _this2.state.showFocus;
6416 currentTarget.blur();
6417 showFocus && _this2.setState({
6418 showFocus: false
6419 });
6420 };
6421
6422 return React__default.createElement(BannerContext.Provider, {
6423 value: true
6424 }, React__default.createElement(WithinContentContext.Consumer, null, function (withinContentContainer) {
6425 var _this2$props = _this2.props,
6426 icon = _this2$props.icon,
6427 action = _this2$props.action,
6428 secondaryAction = _this2$props.secondaryAction,
6429 title = _this2$props.title,
6430 children = _this2$props.children,
6431 status = _this2$props.status,
6432 onDismiss = _this2$props.onDismiss,
6433 stopAnnouncements = _this2$props.stopAnnouncements;
6434 var color;
6435 var defaultIcon;
6436 var ariaRoleType = 'status';
6437
6438 switch (status) {
6439 case 'success':
6440 color = 'greenDark';
6441 defaultIcon = CircleTickMajorTwotone;
6442 break;
6443
6444 case 'info':
6445 color = 'tealDark';
6446 defaultIcon = CircleInformationMajorTwotone;
6447 break;
6448
6449 case 'warning':
6450 color = 'yellowDark';
6451 defaultIcon = CircleAlertMajorTwotone;
6452 ariaRoleType = 'alert';
6453 break;
6454
6455 case 'critical':
6456 color = 'redDark';
6457 defaultIcon = CircleDisabledMajorTwotone;
6458 ariaRoleType = 'alert';
6459 break;
6460
6461 default:
6462 color = 'inkLighter';
6463 defaultIcon = FlagMajorTwotone;
6464 }
6465
6466 var className = classNames(styles$x.Banner, status && styles$x[variationName('status', status)], onDismiss && styles$x.hasDismiss, showFocus && styles$x.keyFocused, withinContentContainer ? styles$x.withinContentContainer : styles$x.withinPage);
6467 var id = uniqueID();
6468 var iconName = icon || defaultIcon;
6469 var headingMarkup = null;
6470 var headingID;
6471
6472 if (title) {
6473 headingID = "".concat(id, "Heading");
6474 headingMarkup = React__default.createElement("div", {
6475 className: styles$x.Heading,
6476 id: headingID
6477 }, React__default.createElement(Heading, {
6478 element: "p"
6479 }, title));
6480 }
6481
6482 var buttonSizeValue = withinContentContainer ? 'slim' : undefined;
6483 var secondaryActionMarkup = secondaryAction ? secondaryActionFrom(secondaryAction) : null;
6484 var actionMarkup = action ? React__default.createElement("div", {
6485 className: styles$x.Actions
6486 }, React__default.createElement(ButtonGroup, null, React__default.createElement("div", {
6487 className: styles$x.PrimaryAction
6488 }, buttonFrom(action, {
6489 outline: true,
6490 size: buttonSizeValue
6491 })), secondaryActionMarkup)) : null;
6492 var contentMarkup = null;
6493 var contentID;
6494
6495 if (children || actionMarkup) {
6496 contentID = "".concat(id, "Content");
6497 contentMarkup = React__default.createElement("div", {
6498 className: styles$x.Content,
6499 id: contentID
6500 }, children, actionMarkup);
6501 }
6502
6503 var dismissButton = onDismiss ? React__default.createElement("div", {
6504 className: styles$x.Dismiss
6505 }, React__default.createElement(Button, {
6506 plain: true,
6507 icon: CancelSmallMinor,
6508 onClick: onDismiss,
6509 accessibilityLabel: "Dismiss notification"
6510 })) : null;
6511 return React__default.createElement("div", {
6512 className: className // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
6513 ,
6514 tabIndex: 0,
6515 ref: _this2.wrapper,
6516 role: ariaRoleType,
6517 "aria-live": stopAnnouncements ? 'off' : 'polite',
6518 onMouseUp: handleMouseUp,
6519 onKeyUp: handleKeyUp,
6520 onBlur: handleBlur,
6521 "aria-labelledby": headingID,
6522 "aria-describedby": contentID
6523 }, dismissButton, React__default.createElement("div", {
6524 className: styles$x.Ribbon
6525 }, React__default.createElement(Icon, {
6526 source: iconName,
6527 color: color,
6528 backdrop: true
6529 })), React__default.createElement("div", null, headingMarkup, contentMarkup));
6530 }));
6531 }
6532 }]);
6533
6534 return Banner;
6535}(React__default.PureComponent);
6536var index = 1;
6537
6538function uniqueID() {
6539 return "Banner".concat(index++);
6540}
6541
6542function secondaryActionFrom(action) {
6543 if (action.url) {
6544 return React__default.createElement(UnstyledLink, {
6545 className: styles$x.SecondaryAction,
6546 url: action.url,
6547 external: action.external
6548 }, React__default.createElement("span", {
6549 className: styles$x.Text
6550 }, action.content));
6551 }
6552
6553 return React__default.createElement("button", {
6554 className: styles$x.SecondaryAction,
6555 onClick: action.onAction
6556 }, React__default.createElement("span", {
6557 className: styles$x.Text
6558 }, action.content));
6559}
6560
6561var styles$y = {
6562 "Breadcrumb": "Polaris-Breadcrumbs__Breadcrumb",
6563 "Icon": "Polaris-Breadcrumbs__Icon",
6564 "ContentWrapper": "Polaris-Breadcrumbs__ContentWrapper",
6565 "Content": "Polaris-Breadcrumbs__Content"
6566};
6567
6568var Breadcrumbs =
6569/*#__PURE__*/
6570function (_React$PureComponent) {
6571 _inherits(Breadcrumbs, _React$PureComponent);
6572
6573 function Breadcrumbs() {
6574 _classCallCheck(this, Breadcrumbs);
6575
6576 return _possibleConstructorReturn(this, _getPrototypeOf(Breadcrumbs).apply(this, arguments));
6577 }
6578
6579 _createClass(Breadcrumbs, [{
6580 key: "render",
6581 value: function render() {
6582 var breadcrumbs = this.props.breadcrumbs;
6583 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
6584
6585 if (breadcrumb == null) {
6586 return null;
6587 }
6588
6589 var content = breadcrumb.content;
6590 var contentMarkup = React__default.createElement("span", {
6591 className: styles$y.ContentWrapper
6592 }, React__default.createElement("span", {
6593 className: styles$y.Icon
6594 }, React__default.createElement(Icon, {
6595 source: ChevronLeftMinor
6596 })), React__default.createElement("span", {
6597 className: styles$y.Content
6598 }, content));
6599 var breadcrumbMarkup = 'url' in breadcrumb ? React__default.createElement(UnstyledLink, {
6600 key: content,
6601 url: breadcrumb.url,
6602 className: styles$y.Breadcrumb,
6603 onMouseUp: handleMouseUpByBlurring,
6604 "aria-label": breadcrumb.accessibilityLabel
6605 }, contentMarkup) : React__default.createElement("button", {
6606 key: content,
6607 className: styles$y.Breadcrumb,
6608 onClick: breadcrumb.onAction,
6609 onMouseUp: handleMouseUpByBlurring,
6610 type: "button",
6611 "aria-label": breadcrumb.accessibilityLabel
6612 }, contentMarkup);
6613 return React__default.createElement("nav", {
6614 role: "navigation"
6615 }, breadcrumbMarkup);
6616 }
6617 }]);
6618
6619 return Breadcrumbs;
6620}(React__default.PureComponent);
6621
6622var styles$z = {
6623 "TextContainer": "Polaris-TextContainer",
6624 "spacingTight": "Polaris-TextContainer--spacingTight",
6625 "spacingLoose": "Polaris-TextContainer--spacingLoose"
6626};
6627
6628function TextContainer(_ref) {
6629 var spacing = _ref.spacing,
6630 children = _ref.children;
6631 var className = classNames(styles$z.TextContainer, spacing && styles$z[variationName('spacing', spacing)]);
6632 return React__default.createElement("div", {
6633 className: className
6634 }, children);
6635}
6636
6637var styles$A = {
6638 "CalloutCard": "Polaris-CalloutCard",
6639 "Image": "Polaris-CalloutCard__Image",
6640 "DismissImage": "Polaris-CalloutCard__DismissImage",
6641 "Content": "Polaris-CalloutCard__Content",
6642 "Title": "Polaris-CalloutCard__Title",
6643 "Buttons": "Polaris-CalloutCard__Buttons",
6644 "Container": "Polaris-CalloutCard__Container",
6645 "Dismiss": "Polaris-CalloutCard__Dismiss"
6646};
6647
6648function CalloutCard(_ref) {
6649 var title = _ref.title,
6650 children = _ref.children,
6651 illustration = _ref.illustration,
6652 primaryAction = _ref.primaryAction,
6653 secondaryAction = _ref.secondaryAction,
6654 onDismiss = _ref.onDismiss;
6655 var primaryActionMarkup = buttonFrom(primaryAction);
6656 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
6657 plain: true
6658 }) : null;
6659 var buttonMarkup = secondaryActionMarkup ? React__default.createElement(ButtonGroup, null, primaryActionMarkup, secondaryActionMarkup) : primaryActionMarkup;
6660 var dismissButton = onDismiss ? React__default.createElement("div", {
6661 className: styles$A.Dismiss
6662 }, React__default.createElement(Button, {
6663 plain: true,
6664 icon: CancelSmallMinor,
6665 onClick: onDismiss,
6666 accessibilityLabel: "Dismiss card"
6667 })) : null;
6668 var imageClassName = classNames(styles$A.Image, onDismiss && styles$A.DismissImage);
6669 return React__default.createElement(Card, null, React__default.createElement("div", {
6670 className: styles$A.Container
6671 }, dismissButton, React__default.createElement(Card.Section, null, React__default.createElement("div", {
6672 className: styles$A.CalloutCard
6673 }, React__default.createElement("div", {
6674 className: styles$A.Content
6675 }, React__default.createElement("div", {
6676 className: styles$A.Title
6677 }, React__default.createElement(Heading, null, title)), React__default.createElement(TextContainer, null, children), React__default.createElement("div", {
6678 className: styles$A.Buttons
6679 }, buttonMarkup)), React__default.createElement(Image, {
6680 alt: "",
6681 className: imageClassName,
6682 source: illustration
6683 })))));
6684}
6685
6686var styles$B = {
6687 "Caption": "Polaris-Caption"
6688};
6689
6690function Caption(_ref) {
6691 var children = _ref.children;
6692 return React__default.createElement("p", {
6693 className: styles$B.Caption
6694 }, children);
6695}
6696
6697var styles$C = {
6698 "Choice": "Polaris-Choice",
6699 "labelHidden": "Polaris-Choice--labelHidden",
6700 "Label": "Polaris-Choice__Label",
6701 "Control": "Polaris-Choice__Control",
6702 "disabled": "Polaris-Choice--disabled",
6703 "Descriptions": "Polaris-Choice__Descriptions",
6704 "HelpText": "Polaris-Choice__HelpText"
6705};
6706
6707function Choice(_ref) {
6708 var id = _ref.id,
6709 label = _ref.label,
6710 disabled = _ref.disabled,
6711 error = _ref.error,
6712 children = _ref.children,
6713 labelHidden = _ref.labelHidden,
6714 helpText = _ref.helpText,
6715 onClick = _ref.onClick,
6716 onMouseOut = _ref.onMouseOut,
6717 onMouseOver = _ref.onMouseOver;
6718 var className = classNames(styles$C.Choice, labelHidden && styles$C.labelHidden, disabled && styles$C.disabled);
6719 var labelMarkup = React__default.createElement("label", {
6720 className: className,
6721 htmlFor: id,
6722 onClick: onClick,
6723 onMouseOver: onMouseOver,
6724 onMouseOut: onMouseOut
6725 }, React__default.createElement("span", {
6726 className: styles$C.Control
6727 }, children), React__default.createElement("span", {
6728 className: styles$C.Label
6729 }, label));
6730 var helpTextMarkup = helpText ? React__default.createElement("div", {
6731 className: styles$C.HelpText,
6732 id: helpTextID$1(id)
6733 }, helpText) : null;
6734 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
6735 className: styles$C.Error
6736 }, React__default.createElement(InlineError, {
6737 message: error,
6738 fieldID: id
6739 }));
6740 var descriptionMarkup = helpTextMarkup || errorMarkup ? React__default.createElement("div", {
6741 className: styles$C.Descriptions
6742 }, errorMarkup, helpTextMarkup) : null;
6743 return descriptionMarkup ? React__default.createElement("div", null, labelMarkup, descriptionMarkup) : labelMarkup;
6744}
6745function helpTextID$1(id) {
6746 return "".concat(id, "HelpText");
6747}
6748
6749var styles$D = {
6750 "Checkbox": "Polaris-Checkbox",
6751 "Input": "Polaris-Checkbox__Input",
6752 "newDesignLanguage": "Polaris-Checkbox--newDesignLanguage",
6753 "Backdrop": "Polaris-Checkbox__Backdrop",
6754 "Input-indeterminate": "Polaris-Checkbox__Input--indeterminate",
6755 "Icon": "Polaris-Checkbox__Icon",
6756 "keyFocused": "Polaris-Checkbox--keyFocused",
6757 "hover": "Polaris-Checkbox--hover",
6758 "error": "Polaris-Checkbox--error"
6759};
6760
6761var Checkbox$1 = React__default.forwardRef(function Checkbox(_ref, ref) {
6762 var ariaDescribedByProp = _ref.ariaDescribedBy,
6763 label = _ref.label,
6764 labelHidden = _ref.labelHidden,
6765 _ref$checked = _ref.checked,
6766 checked = _ref$checked === void 0 ? false : _ref$checked,
6767 helpText = _ref.helpText,
6768 disabled = _ref.disabled,
6769 idProp = _ref.id,
6770 name = _ref.name,
6771 value = _ref.value,
6772 error = _ref.error,
6773 onChange = _ref.onChange,
6774 onFocus = _ref.onFocus,
6775 onBlur = _ref.onBlur;
6776 var inputNode = useRef(null);
6777
6778 var _useFeatures = useFeatures(),
6779 newDesignLanguage = _useFeatures.newDesignLanguage;
6780
6781 var id = useUniqueId('Checkbox', idProp);
6782
6783 var _useToggle = useToggle(false),
6784 mouseOver = _useToggle.value,
6785 handleMouseOver = _useToggle.setTrue,
6786 handleMouseOut = _useToggle.setFalse;
6787
6788 var _useState = useState(false),
6789 _useState2 = _slicedToArray(_useState, 2),
6790 keyFocused = _useState2[0],
6791 setKeyFocused = _useState2[1];
6792
6793 useImperativeHandle(ref, function () {
6794 return {
6795 focus: function focus() {
6796 if (inputNode.current) {
6797 inputNode.current.focus();
6798 }
6799 }
6800 };
6801 });
6802
6803 var handleBlur = function handleBlur() {
6804 onBlur && onBlur();
6805 setKeyFocused(false);
6806 };
6807
6808 var handleInput = function handleInput() {
6809 if (onChange == null || inputNode.current == null || disabled) {
6810 return;
6811 }
6812
6813 onChange(!inputNode.current.checked, id);
6814 inputNode.current.focus();
6815 };
6816
6817 var handleKeyUp = function handleKeyUp(event) {
6818 var keyCode = event.keyCode;
6819 !keyFocused && setKeyFocused(true);
6820
6821 if (keyCode === Key.Space) {
6822 handleInput();
6823 }
6824 };
6825
6826 var describedBy = [];
6827
6828 if (error && typeof error !== 'boolean') {
6829 describedBy.push(errorTextID(id));
6830 }
6831
6832 if (helpText) {
6833 describedBy.push(helpTextID$1(id));
6834 }
6835
6836 if (ariaDescribedByProp) {
6837 describedBy.push(ariaDescribedByProp);
6838 }
6839
6840 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
6841 var wrapperClassName = classNames(styles$D.Checkbox, error && styles$D.error, newDesignLanguage && styles$D.newDesignLanguage);
6842 var backdropClassName = classNames(styles$D.Backdrop, mouseOver && styles$D.hover);
6843 var isIndeterminate = checked === 'indeterminate';
6844 var isChecked = !isIndeterminate && Boolean(checked);
6845 var indeterminateAttributes = isIndeterminate ? {
6846 indeterminate: 'true',
6847 'aria-checked': 'mixed'
6848 } : {
6849 'aria-checked': isChecked
6850 };
6851 var iconSource = isIndeterminate ? MinusMinor : TickSmallMinor;
6852 var inputClassName = classNames(styles$D.Input, isIndeterminate && styles$D['Input-indeterminate'], newDesignLanguage && keyFocused && styles$D.keyFocused);
6853 return (
6854 /* eslint-disable jsx-a11y/no-redundant-roles */
6855 React__default.createElement(Choice, {
6856 id: id,
6857 label: label,
6858 labelHidden: labelHidden,
6859 helpText: helpText,
6860 error: error,
6861 disabled: disabled,
6862 onClick: handleInput,
6863 onMouseOver: handleMouseOver,
6864 onMouseOut: handleMouseOut
6865 }, React__default.createElement("span", {
6866 className: wrapperClassName
6867 }, React__default.createElement("input", Object.assign({
6868 onKeyUp: handleKeyUp,
6869 ref: inputNode,
6870 id: id,
6871 name: name,
6872 value: value,
6873 type: "checkbox",
6874 checked: isChecked,
6875 disabled: disabled,
6876 className: inputClassName,
6877 onFocus: onFocus,
6878 onBlur: handleBlur,
6879 onClick: stopPropagation,
6880 onChange: noop$2,
6881 "aria-invalid": error != null,
6882 "aria-describedby": ariaDescribedBy,
6883 role: "checkbox"
6884 }, indeterminateAttributes)), React__default.createElement("span", {
6885 className: backdropClassName
6886 }), React__default.createElement("span", {
6887 className: styles$D.Icon
6888 }, React__default.createElement(Icon, {
6889 source: iconSource
6890 }))))
6891 /* eslint-enable jsx-a11y/no-redundant-roles */
6892
6893 );
6894});
6895
6896function noop$2() {}
6897
6898function stopPropagation(event) {
6899 event.stopPropagation();
6900}
6901
6902var styles$E = {
6903 "RadioButton": "Polaris-RadioButton",
6904 "Input": "Polaris-RadioButton__Input",
6905 "newDesignLanguage": "Polaris-RadioButton--newDesignLanguage",
6906 "Backdrop": "Polaris-RadioButton__Backdrop",
6907 "Icon": "Polaris-RadioButton__Icon",
6908 "hover": "Polaris-RadioButton--hover",
6909 "keyFocused": "Polaris-RadioButton--keyFocused"
6910};
6911
6912function RadioButton(_ref) {
6913 var ariaDescribedByProp = _ref.ariaDescribedBy,
6914 label = _ref.label,
6915 labelHidden = _ref.labelHidden,
6916 helpText = _ref.helpText,
6917 checked = _ref.checked,
6918 disabled = _ref.disabled,
6919 onChange = _ref.onChange,
6920 onFocus = _ref.onFocus,
6921 onBlur = _ref.onBlur,
6922 idProp = _ref.id,
6923 nameProp = _ref.name,
6924 value = _ref.value;
6925 var id = useUniqueId('RadioButton', idProp);
6926 var name = nameProp || id;
6927 var inputNode = useRef(null);
6928
6929 var _useState = useState(false),
6930 _useState2 = _slicedToArray(_useState, 2),
6931 keyFocused = _useState2[0],
6932 setKeyFocused = _useState2[1];
6933
6934 var _useFeatures = useFeatures(),
6935 newDesignLanguage = _useFeatures.newDesignLanguage;
6936
6937 var _useToggle = useToggle(false),
6938 mouseOver = _useToggle.value,
6939 handleMouseOver = _useToggle.setTrue,
6940 handleMouseOut = _useToggle.setFalse;
6941
6942 var handleKeyUp = function handleKeyUp() {
6943 !keyFocused && setKeyFocused(true);
6944 };
6945
6946 var handleBlur = function handleBlur() {
6947 onBlur && onBlur();
6948 setKeyFocused(false);
6949 };
6950
6951 function handleChange(_ref2) {
6952 var currentTarget = _ref2.currentTarget;
6953 onChange && onChange(currentTarget.checked, id);
6954 }
6955
6956 var describedBy = [];
6957
6958 if (helpText) {
6959 describedBy.push(helpTextID$1(id));
6960 }
6961
6962 if (ariaDescribedByProp) {
6963 describedBy.push(ariaDescribedByProp);
6964 }
6965
6966 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
6967 var inputClassName = classNames(styles$E.Input, newDesignLanguage && keyFocused && styles$E.keyFocused);
6968 var wrapperClassName = classNames(styles$E.RadioButton, newDesignLanguage && styles$E.newDesignLanguage);
6969 var iconMarkup = !newDesignLanguage && React__default.createElement("span", {
6970 className: styles$E.Icon
6971 });
6972 var backdropClassName = classNames(styles$E.Backdrop, mouseOver && styles$E.hover);
6973 return React__default.createElement(Choice, {
6974 label: label,
6975 labelHidden: labelHidden,
6976 disabled: disabled,
6977 id: id,
6978 helpText: helpText,
6979 onMouseOver: handleMouseOver,
6980 onMouseOut: handleMouseOut
6981 }, React__default.createElement("span", {
6982 className: wrapperClassName
6983 }, React__default.createElement("input", {
6984 id: id,
6985 name: name,
6986 value: value,
6987 type: "radio",
6988 checked: checked,
6989 disabled: disabled,
6990 className: inputClassName,
6991 onChange: handleChange,
6992 onFocus: onFocus,
6993 onKeyUp: handleKeyUp,
6994 onBlur: handleBlur,
6995 "aria-describedby": ariaDescribedBy,
6996 ref: inputNode
6997 }), React__default.createElement("span", {
6998 className: backdropClassName
6999 }), iconMarkup));
7000}
7001
7002var styles$F = {
7003 "ChoiceList": "Polaris-ChoiceList",
7004 "titleHidden": "Polaris-ChoiceList--titleHidden",
7005 "Title": "Polaris-ChoiceList__Title",
7006 "Choices": "Polaris-ChoiceList__Choices",
7007 "ChoiceChildren": "Polaris-ChoiceList__ChoiceChildren",
7008 "ChoiceError": "Polaris-ChoiceList__ChoiceError"
7009};
7010
7011function ChoiceList(_ref) {
7012 var title = _ref.title,
7013 titleHidden = _ref.titleHidden,
7014 allowMultiple = _ref.allowMultiple,
7015 choices = _ref.choices,
7016 selected = _ref.selected,
7017 _ref$onChange = _ref.onChange,
7018 onChange = _ref$onChange === void 0 ? noop$3 : _ref$onChange,
7019 error = _ref.error,
7020 _ref$disabled = _ref.disabled,
7021 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
7022 nameProp = _ref.name;
7023 // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
7024 // see https://github.com/Microsoft/TypeScript/issues/28768
7025 var ControlComponent = allowMultiple ? Checkbox$1 : RadioButton;
7026 var name = useUniqueId('ChoiceList', nameProp);
7027 var finalName = allowMultiple ? "".concat(name, "[]") : name;
7028 var className = classNames(styles$F.ChoiceList, titleHidden && styles$F.titleHidden);
7029 var titleMarkup = title ? React__default.createElement("legend", {
7030 className: styles$F.Title
7031 }, title) : null;
7032 var choicesMarkup = choices.map(function (choice) {
7033 var value = choice.value,
7034 label = choice.label,
7035 helpText = choice.helpText,
7036 choiceDisabled = choice.disabled,
7037 describedByError = choice.describedByError;
7038
7039 function handleChange(checked) {
7040 onChange(updateSelectedChoices(choice, checked, selected, allowMultiple), name);
7041 }
7042
7043 var isSelected = choiceIsSelected(choice, selected);
7044 var renderedChildren = choice.renderChildren ? choice.renderChildren(isSelected) : null;
7045 var children = renderedChildren ? React__default.createElement("div", {
7046 className: styles$F.ChoiceChildren
7047 }, renderedChildren) : null;
7048 return React__default.createElement("li", {
7049 key: value
7050 }, React__default.createElement(ControlComponent, {
7051 name: finalName,
7052 value: value,
7053 label: label,
7054 disabled: choiceDisabled || disabled,
7055 checked: choiceIsSelected(choice, selected),
7056 helpText: helpText,
7057 onChange: handleChange,
7058 ariaDescribedBy: error && describedByError ? errorTextID(finalName) : null
7059 }), children);
7060 });
7061 var errorMarkup = error && React__default.createElement("div", {
7062 className: styles$F.ChoiceError
7063 }, React__default.createElement(InlineError, {
7064 message: error,
7065 fieldID: finalName
7066 }));
7067 return React__default.createElement("fieldset", {
7068 className: className,
7069 id: finalName,
7070 "aria-invalid": error != null
7071 }, titleMarkup, React__default.createElement("ul", {
7072 className: styles$F.Choices
7073 }, choicesMarkup), errorMarkup);
7074}
7075
7076function noop$3() {}
7077
7078function choiceIsSelected(_ref2, selected) {
7079 var value = _ref2.value;
7080 return selected.includes(value);
7081}
7082
7083function updateSelectedChoices(_ref3, checked, selected) {
7084 var value = _ref3.value;
7085 var allowMultiple = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
7086
7087 if (checked) {
7088 return allowMultiple ? [].concat(_toConsumableArray(selected), [value]) : [value];
7089 }
7090
7091 return selected.filter(function (selectedChoice) {
7092 return selectedChoice !== value;
7093 });
7094}
7095
7096var styles$G = {
7097 "Collapsible": "Polaris-Collapsible",
7098 "animating": "Polaris-Collapsible--animating",
7099 "open": "Polaris-Collapsible--open",
7100 "fullyOpen": "Polaris-Collapsible--fullyOpen"
7101};
7102
7103var ParentCollapsibleExpandingContext = createContext(false);
7104
7105var CollapsibleInner =
7106/*#__PURE__*/
7107function (_React$Component) {
7108 _inherits(CollapsibleInner, _React$Component);
7109
7110 function CollapsibleInner() {
7111 var _this;
7112
7113 _classCallCheck(this, CollapsibleInner);
7114
7115 _this = _possibleConstructorReturn(this, _getPrototypeOf(CollapsibleInner).apply(this, arguments));
7116 _this.state = {
7117 height: null,
7118 animationState: 'idle',
7119 // eslint-disable-next-line react/no-unused-state
7120 open: _this.props.open
7121 };
7122 _this.node = createRef();
7123 _this.heightNode = createRef();
7124
7125 _this.handleTransitionEnd = function (event) {
7126 var target = event.target;
7127
7128 if (target === _this.node.current) {
7129 _this.setState({
7130 animationState: 'idle',
7131 height: null
7132 });
7133 }
7134 };
7135
7136 return _this;
7137 }
7138
7139 _createClass(CollapsibleInner, [{
7140 key: "componentDidUpdate",
7141 value: function componentDidUpdate(_ref) {
7142 var _this2 = this;
7143
7144 var wasOpen = _ref.open;
7145 var animationState = this.state.animationState;
7146 var parentCollapsibleExpanding = this.context;
7147
7148 if (parentCollapsibleExpanding && animationState !== 'idle') {
7149 // eslint-disable-next-line react/no-did-update-set-state
7150 this.setState({
7151 animationState: 'idle'
7152 });
7153 return;
7154 }
7155
7156 read(function () {
7157 var heightNode = _this2.heightNode.current;
7158
7159 switch (animationState) {
7160 case 'idle':
7161 break;
7162
7163 case 'measuring':
7164 _this2.setState({
7165 animationState: wasOpen ? 'closingStart' : 'openingStart',
7166 height: wasOpen && heightNode ? heightNode.scrollHeight : 0
7167 });
7168
7169 break;
7170
7171 case 'closingStart':
7172 _this2.setState({
7173 animationState: 'closing',
7174 height: 0
7175 });
7176
7177 break;
7178
7179 case 'openingStart':
7180 _this2.setState({
7181 animationState: 'opening',
7182 height: heightNode ? heightNode.scrollHeight : 0
7183 });
7184
7185 }
7186 });
7187 }
7188 }, {
7189 key: "render",
7190 value: function render() {
7191 var _this$props = this.props,
7192 id = _this$props.id,
7193 open = _this$props.open,
7194 children = _this$props.children;
7195 var _this$state = this.state,
7196 animationState = _this$state.animationState,
7197 height = _this$state.height;
7198 var parentCollapsibleExpanding = this.context;
7199 var animating = animationState !== 'idle';
7200 var wrapperClassName = classNames(styles$G.Collapsible, open && styles$G.open, animating && styles$G.animating, !animating && open && styles$G.fullyOpen);
7201 var displayHeight = collapsibleHeight(open, animationState, height);
7202 var content = animating || open ? children : null;
7203 return React__default.createElement(ParentCollapsibleExpandingContext.Provider, {
7204 value: parentCollapsibleExpanding || open && animationState !== 'idle'
7205 }, React__default.createElement("div", {
7206 id: id,
7207 "aria-hidden": !open,
7208 style: {
7209 maxHeight: displayHeight
7210 },
7211 className: wrapperClassName,
7212 ref: this.node,
7213 onTransitionEnd: this.handleTransitionEnd
7214 }, React__default.createElement("div", {
7215 ref: this.heightNode
7216 }, content)));
7217 }
7218 }], [{
7219 key: "getDerivedStateFromProps",
7220 value: function getDerivedStateFromProps(_ref2, _ref3) {
7221 var willOpen = _ref2.open;
7222 var open = _ref3.open,
7223 prevAnimationState = _ref3.animationState;
7224 var nextAnimationState = prevAnimationState;
7225
7226 if (open !== willOpen) {
7227 nextAnimationState = 'measuring';
7228 }
7229
7230 return {
7231 animationState: nextAnimationState,
7232 open: willOpen
7233 };
7234 }
7235 }]);
7236
7237 return CollapsibleInner;
7238}(React__default.Component);
7239
7240CollapsibleInner.contextType = ParentCollapsibleExpandingContext;
7241
7242function collapsibleHeight(open, animationState, height) {
7243 if (animationState === 'idle' && open) {
7244 return open ? 'none' : undefined;
7245 }
7246
7247 if (animationState === 'measuring') {
7248 return open ? undefined : 'none';
7249 }
7250
7251 return "".concat(height || 0, "px");
7252}
7253
7254var Collapsible = CollapsibleInner;
7255
7256var styles$H = {
7257 "ColorPicker": "Polaris-ColorPicker",
7258 "MainColor": "Polaris-ColorPicker__MainColor",
7259 "Dragger": "Polaris-ColorPicker__Dragger",
7260 "ColorLayer": "Polaris-ColorPicker__ColorLayer",
7261 "HuePicker": "Polaris-ColorPicker__HuePicker",
7262 "AlphaPicker": "Polaris-ColorPicker__AlphaPicker",
7263 "Slidable": "Polaris-ColorPicker__Slidable"
7264};
7265
7266var isDragging = false; // Required to solve a bug causing the underlying page/container to scroll
7267// while trying to drag the ColorPicker controls.
7268// This must be called as soon as possible to properly prevent the event.
7269// `passive: false` must also be set, as it seems webkit has changed the "default" behaviour
7270// https://bugs.webkit.org/show_bug.cgi?id=182521
7271
7272if (!isServer) {
7273 window.addEventListener('touchmove', function (event) {
7274 if (!isDragging) {
7275 return;
7276 }
7277
7278 event.preventDefault();
7279 }, {
7280 passive: false
7281 });
7282}
7283
7284var Slidable =
7285/*#__PURE__*/
7286function (_React$PureComponent) {
7287 _inherits(Slidable, _React$PureComponent);
7288
7289 function Slidable() {
7290 var _this;
7291
7292 _classCallCheck(this, Slidable);
7293
7294 _this = _possibleConstructorReturn(this, _getPrototypeOf(Slidable).apply(this, arguments));
7295 _this.state = {
7296 dragging: false
7297 };
7298 _this.node = null;
7299 _this.draggerNode = null;
7300
7301 _this.setDraggerNode = function (node) {
7302 _this.draggerNode = node;
7303 };
7304
7305 _this.setNode = function (node) {
7306 _this.node = node;
7307 };
7308
7309 _this.startDrag = function (event) {
7310 if (event.type === 'mousedown') {
7311 var mouseEvent = event;
7312
7313 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
7314 }
7315
7316 isDragging = true;
7317
7318 _this.setState({
7319 dragging: true
7320 });
7321 };
7322
7323 _this.handleDragEnd = function () {
7324 isDragging = false;
7325
7326 _this.setState({
7327 dragging: false
7328 });
7329 };
7330
7331 _this.handleMove = function (event) {
7332 event.stopImmediatePropagation();
7333 event.stopPropagation();
7334
7335 if (event.cancelable) {
7336 event.preventDefault();
7337 }
7338
7339 if (event.type === 'mousemove') {
7340 var mouseEvent = event;
7341
7342 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
7343
7344 return;
7345 }
7346
7347 var touchEvent = event;
7348
7349 _this.handleDraggerMove(touchEvent.touches[0].clientX, touchEvent.touches[0].clientY);
7350 };
7351
7352 _this.handleDraggerMove = function (x, y) {
7353 if (_this.node == null) {
7354 return;
7355 }
7356
7357 var onChange = _this.props.onChange;
7358
7359 var rect = _this.node.getBoundingClientRect();
7360
7361 var offsetX = x - rect.left;
7362 var offsetY = y - rect.top;
7363 onChange({
7364 x: offsetX,
7365 y: offsetY
7366 });
7367 };
7368
7369 return _this;
7370 }
7371
7372 _createClass(Slidable, [{
7373 key: "componentDidMount",
7374 value: function componentDidMount() {
7375 var onDraggerHeight = this.props.onDraggerHeight;
7376
7377 if (onDraggerHeight == null) {
7378 return;
7379 }
7380
7381 var draggerNode = this.draggerNode;
7382
7383 if (draggerNode == null) {
7384 return;
7385 }
7386
7387 onDraggerHeight(draggerNode.clientWidth);
7388
7389 if (process.env.NODE_ENV === 'development') {
7390 setTimeout(function () {
7391 onDraggerHeight(draggerNode.clientWidth);
7392 }, 0);
7393 }
7394 }
7395 }, {
7396 key: "render",
7397 value: function render() {
7398 var dragging = this.state.dragging;
7399 var _this$props = this.props,
7400 _this$props$draggerX = _this$props.draggerX,
7401 draggerX = _this$props$draggerX === void 0 ? 0 : _this$props$draggerX,
7402 _this$props$draggerY = _this$props.draggerY,
7403 draggerY = _this$props$draggerY === void 0 ? 0 : _this$props$draggerY;
7404 var draggerPositioning = {
7405 transform: "translate3d(".concat(draggerX, "px, ").concat(draggerY, "px, 0)")
7406 };
7407 var moveListener = dragging ? React__default.createElement(EventListener, {
7408 event: "mousemove",
7409 handler: this.handleMove,
7410 passive: false
7411 }) : null;
7412 var touchMoveListener = dragging ? React__default.createElement(EventListener, {
7413 event: "touchmove",
7414 handler: this.handleMove,
7415 passive: false
7416 }) : null;
7417 var endDragListener = dragging ? React__default.createElement(EventListener, {
7418 event: "mouseup",
7419 handler: this.handleDragEnd
7420 }) : null;
7421 var touchEndListener = dragging ? React__default.createElement(EventListener, {
7422 event: "touchend",
7423 handler: this.handleDragEnd
7424 }) : null;
7425 var touchCancelListener = dragging ? React__default.createElement(EventListener, {
7426 event: "touchcancel",
7427 handler: this.handleDragEnd
7428 }) : null;
7429 return React__default.createElement("div", {
7430 ref: this.setNode,
7431 className: styles$H.Slidable,
7432 onMouseDown: this.startDrag,
7433 onTouchStart: this.startDrag
7434 }, endDragListener, moveListener, touchMoveListener, touchEndListener, touchCancelListener, React__default.createElement("div", {
7435 style: draggerPositioning,
7436 className: styles$H.Dragger,
7437 ref: this.setDraggerNode
7438 }));
7439 }
7440 }]);
7441
7442 return Slidable;
7443}(React__default.PureComponent);
7444
7445var VERTICAL_PADDING = 13;
7446function calculateDraggerY(alpha, sliderHeight, draggerHeight) {
7447 var offset = offsetForAlpha(alpha, sliderHeight, draggerHeight);
7448 return clamp$1(offset, 0, sliderHeight);
7449}
7450function alphaForDraggerY(y, sliderHeight) {
7451 var offsetY = clamp$1(y, 0, sliderHeight);
7452 return alphaForOffset(offsetY, sliderHeight);
7453}
7454function alphaForOffset(offset, sliderHeight) {
7455 var selectionHeight = offset - VERTICAL_PADDING;
7456 var slidableArea = sliderHeight - VERTICAL_PADDING * 2;
7457 return clamp$1(1 - selectionHeight / slidableArea, 0, 1);
7458}
7459
7460function offsetForAlpha(alpha, sliderHeight, draggerHeight) {
7461 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING);
7462 return clamp$1((1 - alpha) * slidableArea + VERTICAL_PADDING, 0, sliderHeight - draggerHeight);
7463}
7464
7465var AlphaPicker =
7466/*#__PURE__*/
7467function (_React$PureComponent) {
7468 _inherits(AlphaPicker, _React$PureComponent);
7469
7470 function AlphaPicker() {
7471 var _this;
7472
7473 _classCallCheck(this, AlphaPicker);
7474
7475 _this = _possibleConstructorReturn(this, _getPrototypeOf(AlphaPicker).apply(this, arguments));
7476 _this.state = {
7477 sliderHeight: 0,
7478 draggerHeight: 0
7479 };
7480
7481 _this.setSliderHeight = function (node) {
7482 if (node == null) {
7483 return;
7484 }
7485
7486 _this.setState({
7487 sliderHeight: node.clientHeight
7488 });
7489
7490 if (process.env.NODE_ENV === 'development') {
7491 setTimeout(function () {
7492 _this.setState({
7493 sliderHeight: node.clientHeight
7494 });
7495 }, 0);
7496 }
7497 };
7498
7499 _this.setDraggerHeight = function (height) {
7500 _this.setState({
7501 draggerHeight: height
7502 });
7503 };
7504
7505 _this.handleChange = function (_ref) {
7506 var y = _ref.y;
7507 var onChange = _this.props.onChange;
7508 var sliderHeight = _this.state.sliderHeight;
7509 var alpha = alphaForDraggerY(y, sliderHeight);
7510 onChange(alpha);
7511 };
7512
7513 return _this;
7514 }
7515
7516 _createClass(AlphaPicker, [{
7517 key: "render",
7518 value: function render() {
7519 var _this$props = this.props,
7520 color = _this$props.color,
7521 alpha = _this$props.alpha;
7522 var _this$state = this.state,
7523 sliderHeight = _this$state.sliderHeight,
7524 draggerHeight = _this$state.draggerHeight;
7525 var draggerY = calculateDraggerY(alpha, sliderHeight, draggerHeight);
7526 var background = alphaGradientForColor(color);
7527 return React__default.createElement("div", {
7528 className: styles$H.AlphaPicker,
7529 ref: this.setSliderHeight
7530 }, React__default.createElement("div", {
7531 className: styles$H.ColorLayer,
7532 style: {
7533 background
7534 }
7535 }), React__default.createElement(Slidable, {
7536 draggerY: draggerY,
7537 draggerX: 0,
7538 onChange: this.handleChange,
7539 onDraggerHeight: this.setDraggerHeight
7540 }));
7541 }
7542 }]);
7543
7544 return AlphaPicker;
7545}(React__default.PureComponent);
7546
7547function alphaGradientForColor(color) {
7548 var _hsbToRgb = hsbToRgb(color),
7549 red = _hsbToRgb.red,
7550 green = _hsbToRgb.green,
7551 blue = _hsbToRgb.blue;
7552
7553 var rgb = "".concat(red, ", ").concat(green, ", ").concat(blue);
7554 return "linear-gradient(to top, rgba(".concat(rgb, ", 0) 18px, rgba(").concat(rgb, ", 1) calc(100% - 18px))");
7555}
7556
7557var VERTICAL_PADDING$1 = 13;
7558function calculateDraggerY$1(hue, sliderHeight, draggerHeight) {
7559 var offset = offsetForHue(hue, sliderHeight, draggerHeight);
7560 return clamp$1(offset, 0, sliderHeight);
7561}
7562function hueForDraggerY(y, sliderHeight) {
7563 var offsetY = clamp$1(y, 0, sliderHeight);
7564 return hueForOffset(offsetY, sliderHeight);
7565}
7566
7567function hueForOffset(offset, sliderHeight) {
7568 var selectionHeight = offset - VERTICAL_PADDING$1;
7569 var slidableArea = sliderHeight - VERTICAL_PADDING$1 * 2;
7570 return clamp$1(selectionHeight / slidableArea * 360, 0, 360);
7571}
7572
7573function offsetForHue(hue, sliderHeight, draggerHeight) {
7574 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING$1);
7575 return clamp$1(hue / 360 * slidableArea + VERTICAL_PADDING$1, 0, sliderHeight - draggerHeight);
7576}
7577
7578var HuePicker =
7579/*#__PURE__*/
7580function (_React$PureComponent) {
7581 _inherits(HuePicker, _React$PureComponent);
7582
7583 function HuePicker() {
7584 var _this;
7585
7586 _classCallCheck(this, HuePicker);
7587
7588 _this = _possibleConstructorReturn(this, _getPrototypeOf(HuePicker).apply(this, arguments));
7589 _this.state = {
7590 sliderHeight: 0,
7591 draggerHeight: 0
7592 };
7593
7594 _this.setSliderHeight = function (node) {
7595 if (node == null) {
7596 return;
7597 }
7598
7599 _this.setState({
7600 sliderHeight: node.clientHeight
7601 });
7602
7603 if (process.env.NODE_ENV === 'development') {
7604 setTimeout(function () {
7605 _this.setState({
7606 sliderHeight: node.clientHeight
7607 });
7608 }, 0);
7609 }
7610 };
7611
7612 _this.setDraggerHeight = function (height) {
7613 _this.setState({
7614 draggerHeight: height
7615 });
7616 };
7617
7618 _this.handleChange = function (_ref) {
7619 var y = _ref.y;
7620 var onChange = _this.props.onChange;
7621 var sliderHeight = _this.state.sliderHeight;
7622 var hue = hueForDraggerY(y, sliderHeight);
7623 onChange(hue);
7624 };
7625
7626 return _this;
7627 }
7628
7629 _createClass(HuePicker, [{
7630 key: "render",
7631 value: function render() {
7632 var hue = this.props.hue;
7633 var _this$state = this.state,
7634 sliderHeight = _this$state.sliderHeight,
7635 draggerHeight = _this$state.draggerHeight;
7636 var draggerY = calculateDraggerY$1(hue, sliderHeight, draggerHeight);
7637 return React__default.createElement("div", {
7638 className: styles$H.HuePicker,
7639 ref: this.setSliderHeight
7640 }, React__default.createElement(Slidable, {
7641 draggerY: draggerY,
7642 draggerX: 0,
7643 onChange: this.handleChange,
7644 onDraggerHeight: this.setDraggerHeight
7645 }));
7646 }
7647 }]);
7648
7649 return HuePicker;
7650}(React__default.PureComponent);
7651
7652var ColorPicker =
7653/*#__PURE__*/
7654function (_React$PureComponent) {
7655 _inherits(ColorPicker, _React$PureComponent);
7656
7657 function ColorPicker() {
7658 var _this;
7659
7660 _classCallCheck(this, ColorPicker);
7661
7662 _this = _possibleConstructorReturn(this, _getPrototypeOf(ColorPicker).apply(this, arguments));
7663 _this.state = {
7664 pickerSize: 0
7665 };
7666 _this.colorNode = null;
7667
7668 _this.setColorNode = function (node) {
7669 _this.colorNode = node;
7670 };
7671
7672 _this.handleHueChange = function (hue) {
7673 var _this$props = _this.props,
7674 _this$props$color = _this$props.color,
7675 brightness = _this$props$color.brightness,
7676 saturation = _this$props$color.saturation,
7677 _this$props$color$alp = _this$props$color.alpha,
7678 alpha = _this$props$color$alp === void 0 ? 1 : _this$props$color$alp,
7679 onChange = _this$props.onChange;
7680 onChange({
7681 hue,
7682 brightness,
7683 saturation,
7684 alpha
7685 });
7686 };
7687
7688 _this.handleAlphaChange = function (alpha) {
7689 var _this$props2 = _this.props,
7690 _this$props2$color = _this$props2.color,
7691 hue = _this$props2$color.hue,
7692 brightness = _this$props2$color.brightness,
7693 saturation = _this$props2$color.saturation,
7694 onChange = _this$props2.onChange;
7695 onChange({
7696 hue,
7697 brightness,
7698 saturation,
7699 alpha
7700 });
7701 };
7702
7703 _this.handleDraggerMove = function (_ref) {
7704 var x = _ref.x,
7705 y = _ref.y;
7706 var pickerSize = _this.state.pickerSize;
7707 var _this$props3 = _this.props,
7708 _this$props3$color = _this$props3.color,
7709 hue = _this$props3$color.hue,
7710 _this$props3$color$al = _this$props3$color.alpha,
7711 alpha = _this$props3$color$al === void 0 ? 1 : _this$props3$color$al,
7712 onChange = _this$props3.onChange;
7713 var saturation = clamp$1(x / pickerSize, 0, 1);
7714 var brightness = clamp$1(1 - y / pickerSize, 0, 1);
7715 onChange({
7716 hue,
7717 saturation,
7718 brightness,
7719 alpha
7720 });
7721 };
7722
7723 _this.handlePickerDrag = function (event) {
7724 // prevents external elements from being selected
7725 event.preventDefault();
7726 };
7727
7728 return _this;
7729 }
7730
7731 _createClass(ColorPicker, [{
7732 key: "componentDidMount",
7733 value: function componentDidMount() {
7734 var _this2 = this;
7735
7736 var colorNode = this.colorNode;
7737
7738 if (colorNode == null) {
7739 return;
7740 }
7741
7742 this.setState({
7743 pickerSize: colorNode.clientWidth
7744 });
7745
7746 if (process.env.NODE_ENV === 'development') {
7747 setTimeout(function () {
7748 _this2.setState({
7749 pickerSize: colorNode.clientWidth
7750 });
7751 }, 0);
7752 }
7753 }
7754 }, {
7755 key: "render",
7756 value: function render() {
7757 var _this$props4 = this.props,
7758 id = _this$props4.id,
7759 color = _this$props4.color,
7760 allowAlpha = _this$props4.allowAlpha;
7761 var hue = color.hue,
7762 saturation = color.saturation,
7763 brightness = color.brightness,
7764 providedAlpha = color.alpha;
7765 var pickerSize = this.state.pickerSize;
7766 var alpha = providedAlpha != null && allowAlpha ? providedAlpha : 1;
7767
7768 var _hsbToRgb = hsbToRgb({
7769 hue,
7770 saturation: 1,
7771 brightness: 1
7772 }),
7773 red = _hsbToRgb.red,
7774 green = _hsbToRgb.green,
7775 blue = _hsbToRgb.blue;
7776
7777 var colorString = "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(alpha, ")");
7778 var draggerX = clamp$1(saturation * pickerSize, 0, pickerSize);
7779 var draggerY = clamp$1(pickerSize - brightness * pickerSize, 0, pickerSize);
7780 var alphaSliderMarkup = allowAlpha ? React__default.createElement(AlphaPicker, {
7781 alpha: alpha,
7782 color: color,
7783 onChange: this.handleAlphaChange
7784 }) : null;
7785 return React__default.createElement("div", {
7786 className: styles$H.ColorPicker,
7787 id: id,
7788 onMouseDown: this.handlePickerDrag
7789 }, React__default.createElement("div", {
7790 ref: this.setColorNode,
7791 className: styles$H.MainColor
7792 }, React__default.createElement("div", {
7793 className: styles$H.ColorLayer,
7794 style: {
7795 backgroundColor: colorString
7796 }
7797 }), React__default.createElement(Slidable, {
7798 onChange: this.handleDraggerMove,
7799 draggerX: draggerX,
7800 draggerY: draggerY
7801 })), React__default.createElement(HuePicker, {
7802 hue: hue,
7803 onChange: this.handleHueChange
7804 }), alphaSliderMarkup);
7805 }
7806 }]);
7807
7808 return ColorPicker;
7809}(React__default.PureComponent);
7810
7811var FrameContext = React__default.createContext(undefined);
7812
7813var defaultFrame = {
7814 showToast: noop$4,
7815 hideToast: noop$4,
7816 setContextualSaveBar: noop$4,
7817 removeContextualSaveBar: noop$4,
7818 startLoading: noop$4,
7819 stopLoading: noop$4
7820};
7821function useFrame() {
7822 var frame = useContext(FrameContext);
7823 var appBridge = useAppBridge();
7824
7825 if (!frame && !appBridge) {
7826 throw new Error('No Frame context was provided. Your component must be wrapped in a <Frame> component, or be used within an embedded application by setting the apiKey and shopOrigin properties on <AppProvider>. See https://polaris.shopify.com/components/structure/frame for implementation instructions.');
7827 } // This makes sure the useFrame hook always returns a FrameContext object, never undefined
7828
7829
7830 if (appBridge || !frame) {
7831 return defaultFrame;
7832 }
7833
7834 return frame;
7835}
7836
7837function noop$4() {}
7838
7839var ContextualSaveBar = React__default.memo(function ContextualSaveBar(_ref) {
7840 var message = _ref.message,
7841 saveAction = _ref.saveAction,
7842 discardAction = _ref.discardAction,
7843 alignContentFlush = _ref.alignContentFlush;
7844
7845 var _useFrame = useFrame(),
7846 setContextualSaveBar = _useFrame.setContextualSaveBar,
7847 removeContextualSaveBar = _useFrame.removeContextualSaveBar;
7848
7849 React__default.useEffect(function () {
7850 setContextualSaveBar({
7851 message,
7852 saveAction,
7853 discardAction,
7854 alignContentFlush
7855 });
7856 }, [message, saveAction, discardAction, alignContentFlush, setContextualSaveBar]);
7857 React__default.useEffect(function () {
7858 return removeContextualSaveBar;
7859 }, [removeContextualSaveBar]);
7860 return null;
7861});
7862
7863function withAppProvider() {
7864 return function addProvider(WrappedComponent) {
7865 var WithAppProvider = function WithAppProvider(props) {
7866 var polaris = {
7867 intl: useI18n(),
7868 stickyManager: useStickyManager(),
7869 appBridge: useAppBridge(),
7870 mediaQuery: useMediaQuery()
7871 };
7872 return React__default.createElement(WrappedComponent, Object.assign({}, props, {
7873 polaris: polaris
7874 }));
7875 };
7876
7877 WithAppProvider.displayName = "WithAppProvider(".concat(getDisplayName(WrappedComponent), ")");
7878 var FinalComponent = hoistStatics(WithAppProvider, WrappedComponent);
7879 return FinalComponent;
7880 };
7881}
7882
7883function getDisplayName(WrappedComponent) {
7884 return WrappedComponent.displayName || WrappedComponent.name || 'Component';
7885}
7886
7887var styles$I = {
7888 "DataTable": "Polaris-DataTable",
7889 "condensed": "Polaris-DataTable--condensed",
7890 "Navigation": "Polaris-DataTable__Navigation",
7891 "Pip": "Polaris-DataTable__Pip",
7892 "Pip-visible": "Polaris-DataTable__Pip--visible",
7893 "ScrollContainer": "Polaris-DataTable__ScrollContainer",
7894 "Table": "Polaris-DataTable__Table",
7895 "TableRow": "Polaris-DataTable__TableRow",
7896 "Cell": "Polaris-DataTable__Cell",
7897 "Cell-firstColumn": "Polaris-DataTable__Cell--firstColumn",
7898 "Cell-numeric": "Polaris-DataTable__Cell--numeric",
7899 "Cell-truncated": "Polaris-DataTable__Cell--truncated",
7900 "Cell-header": "Polaris-DataTable__Cell--header",
7901 "Cell-sortable": "Polaris-DataTable__Cell--sortable",
7902 "Cell-verticalAlignTop": "Polaris-DataTable__Cell--verticalAlignTop",
7903 "Cell-verticalAlignBottom": "Polaris-DataTable__Cell--verticalAlignBottom",
7904 "Cell-verticalAlignMiddle": "Polaris-DataTable__Cell--verticalAlignMiddle",
7905 "Cell-verticalAlignBaseline": "Polaris-DataTable__Cell--verticalAlignBaseline",
7906 "Icon": "Polaris-DataTable__Icon",
7907 "Heading": "Polaris-DataTable__Heading",
7908 "Heading-left": "Polaris-DataTable__Heading--left",
7909 "Cell-sorted": "Polaris-DataTable__Cell--sorted",
7910 "Cell-total": "Polaris-DataTable__Cell--total",
7911 "Cell-total-footer": "Polaris-DataTable--cellTotalFooter",
7912 "Footer": "Polaris-DataTable__Footer"
7913};
7914
7915function Cell(_ref) {
7916 var content = _ref.content,
7917 contentType = _ref.contentType,
7918 firstColumn = _ref.firstColumn,
7919 truncate = _ref.truncate,
7920 header = _ref.header,
7921 total = _ref.total,
7922 totalInFooter = _ref.totalInFooter,
7923 sorted = _ref.sorted,
7924 sortable = _ref.sortable,
7925 sortDirection = _ref.sortDirection,
7926 _ref$verticalAlign = _ref.verticalAlign,
7927 verticalAlign = _ref$verticalAlign === void 0 ? 'top' : _ref$verticalAlign,
7928 _ref$defaultSortDirec = _ref.defaultSortDirection,
7929 defaultSortDirection = _ref$defaultSortDirec === void 0 ? 'ascending' : _ref$defaultSortDirec,
7930 onSort = _ref.onSort;
7931 var i18n = useI18n();
7932 var numeric = contentType === 'numeric';
7933 var className = classNames(styles$I.Cell, styles$I["Cell-".concat(variationName('verticalAlign', verticalAlign))], firstColumn && styles$I['Cell-firstColumn'], firstColumn && truncate && styles$I['Cell-truncated'], header && styles$I['Cell-header'], total && styles$I['Cell-total'], totalInFooter && styles$I['Cell-total-footer'], numeric && styles$I['Cell-numeric'], sortable && styles$I['Cell-sortable'], sorted && styles$I['Cell-sorted']);
7934 var headerClassName = classNames(header && styles$I.Heading, header && contentType === 'text' && styles$I['Heading-left']);
7935 var iconClassName = classNames(sortable && styles$I.Icon);
7936 var direction = sorted && sortDirection ? sortDirection : defaultSortDirection;
7937 var source = direction === 'descending' ? CaretDownMinor : CaretUpMinor;
7938 var oppositeDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
7939 var sortAccessibilityLabel = i18n.translate('Polaris.DataTable.sortAccessibilityLabel', {
7940 direction: sorted ? oppositeDirection : direction
7941 });
7942 var iconMarkup = React__default.createElement("span", {
7943 className: iconClassName
7944 }, React__default.createElement(Icon, {
7945 source: source,
7946 accessibilityLabel: sortAccessibilityLabel
7947 }));
7948 var sortableHeadingContent = React__default.createElement("button", {
7949 className: headerClassName,
7950 onClick: onSort
7951 }, iconMarkup, content);
7952 var columnHeadingContent = sortable ? sortableHeadingContent : content;
7953 var headingMarkup = header ? React__default.createElement("th", Object.assign({}, headerCell.props, {
7954 className: className,
7955 scope: "col",
7956 "aria-sort": sortDirection
7957 }), columnHeadingContent) : React__default.createElement("th", {
7958 className: className,
7959 scope: "row"
7960 }, content);
7961 var cellMarkup = header || firstColumn ? headingMarkup : React__default.createElement("td", {
7962 className: className
7963 }, content);
7964 return cellMarkup;
7965}
7966
7967function Navigation(_ref) {
7968 var columnVisibilityData = _ref.columnVisibilityData,
7969 isScrolledFarthestLeft = _ref.isScrolledFarthestLeft,
7970 isScrolledFarthestRight = _ref.isScrolledFarthestRight,
7971 navigateTableLeft = _ref.navigateTableLeft,
7972 navigateTableRight = _ref.navigateTableRight;
7973 var i18n = useI18n();
7974 var pipMarkup = columnVisibilityData.map(function (column, index) {
7975 var className = classNames(styles$I.Pip, column.isVisible && styles$I['Pip-visible']);
7976 return React__default.createElement("div", {
7977 className: className,
7978 key: "pip-".concat(index)
7979 });
7980 });
7981 var leftA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
7982 direction: 'left'
7983 });
7984 var rightA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
7985 direction: 'right'
7986 });
7987 return React__default.createElement("div", {
7988 className: styles$I.Navigation
7989 }, React__default.createElement(Button, {
7990 plain: true,
7991 icon: ChevronLeftMinor,
7992 disabled: isScrolledFarthestLeft,
7993 accessibilityLabel: leftA11yLabel,
7994 onClick: navigateTableLeft
7995 }), pipMarkup, React__default.createElement(Button, {
7996 plain: true,
7997 icon: ChevronRightMinor,
7998 disabled: isScrolledFarthestRight,
7999 accessibilityLabel: rightA11yLabel,
8000 onClick: navigateTableRight
8001 }));
8002}
8003
8004function measureColumn(tableData) {
8005 return function (column, index) {
8006 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex,
8007 tableStart = tableData.tableLeftVisibleEdge,
8008 tableEnd = tableData.tableRightVisibleEdge;
8009 var leftEdge = column.offsetLeft;
8010 var rightEdge = leftEdge + column.offsetWidth;
8011 var isVisibleLeft = isEdgeVisible(leftEdge, tableStart, tableEnd);
8012 var isVisibleRight = isEdgeVisible(rightEdge, tableStart, tableEnd);
8013 var isVisible = isVisibleLeft || isVisibleRight;
8014
8015 if (isVisible) {
8016 tableData.firstVisibleColumnIndex = Math.min(firstVisibleColumnIndex, index);
8017 }
8018
8019 return {
8020 leftEdge,
8021 rightEdge,
8022 isVisible
8023 };
8024 };
8025}
8026function isEdgeVisible(position, start, end) {
8027 var minVisiblePixels = 30;
8028 return position >= start + minVisiblePixels && position <= end - minVisiblePixels;
8029}
8030function getPrevAndCurrentColumns(tableData, columnData) {
8031 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex;
8032 var previousColumnIndex = Math.max(firstVisibleColumnIndex - 1, 0);
8033 var previousColumn = columnData[previousColumnIndex];
8034 var currentColumn = columnData[firstVisibleColumnIndex];
8035 return {
8036 previousColumn,
8037 currentColumn
8038 };
8039}
8040
8041var DataTableInner =
8042/*#__PURE__*/
8043function (_React$PureComponent) {
8044 _inherits(DataTableInner, _React$PureComponent);
8045
8046 function DataTableInner() {
8047 var _this;
8048
8049 _classCallCheck(this, DataTableInner);
8050
8051 _this = _possibleConstructorReturn(this, _getPrototypeOf(DataTableInner).apply(this, arguments));
8052 _this.state = {
8053 condensed: false,
8054 columnVisibilityData: [],
8055 isScrolledFarthestLeft: true,
8056 isScrolledFarthestRight: false
8057 };
8058 _this.dataTable = React__default.createRef();
8059 _this.scrollContainer = React__default.createRef();
8060 _this.table = React__default.createRef();
8061 _this.handleResize = debounce(function () {
8062 var _assertThisInitialize = _assertThisInitialized(_this),
8063 table = _assertThisInitialize.table.current,
8064 scrollContainer = _assertThisInitialize.scrollContainer.current;
8065
8066 var condensed = false;
8067
8068 if (table && scrollContainer) {
8069 condensed = table.scrollWidth > scrollContainer.clientWidth;
8070 }
8071
8072 _this.setState(Object.assign({
8073 condensed
8074 }, _this.calculateColumnVisibilityData(condensed)));
8075 });
8076
8077 _this.calculateColumnVisibilityData = function (condensed) {
8078 var _assertThisInitialize2 = _assertThisInitialized(_this),
8079 table = _assertThisInitialize2.table.current,
8080 scrollContainer = _assertThisInitialize2.scrollContainer.current,
8081 dataTable = _assertThisInitialize2.dataTable.current;
8082
8083 if (condensed && table && scrollContainer && dataTable) {
8084 var headerCells = table.querySelectorAll(headerCell.selector);
8085
8086 if (headerCells.length > 0) {
8087 var firstVisibleColumnIndex = headerCells.length - 1;
8088 var tableLeftVisibleEdge = scrollContainer.scrollLeft;
8089 var tableRightVisibleEdge = scrollContainer.scrollLeft + dataTable.offsetWidth;
8090 var tableData = {
8091 firstVisibleColumnIndex,
8092 tableLeftVisibleEdge,
8093 tableRightVisibleEdge
8094 };
8095
8096 var columnVisibilityData = _toConsumableArray(headerCells).map(measureColumn(tableData));
8097
8098 var lastColumn = columnVisibilityData[columnVisibilityData.length - 1];
8099 return Object.assign(Object.assign({
8100 columnVisibilityData
8101 }, getPrevAndCurrentColumns(tableData, columnVisibilityData)), {
8102 isScrolledFarthestLeft: tableLeftVisibleEdge === 0,
8103 isScrolledFarthestRight: lastColumn.rightEdge <= tableRightVisibleEdge
8104 });
8105 }
8106 }
8107
8108 return {
8109 columnVisibilityData: [],
8110 previousColumn: undefined,
8111 currentColumn: undefined
8112 };
8113 };
8114
8115 _this.scrollListener = function () {
8116 _this.setState(function (prevState) {
8117 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8118 });
8119 };
8120
8121 _this.navigateTable = function (direction) {
8122 var _this$state = _this.state,
8123 currentColumn = _this$state.currentColumn,
8124 previousColumn = _this$state.previousColumn;
8125 var scrollContainer = _this.scrollContainer.current;
8126
8127 var handleScroll = function handleScroll() {
8128 if (!currentColumn || !previousColumn) {
8129 return;
8130 }
8131
8132 if (scrollContainer) {
8133 scrollContainer.scrollLeft = direction === 'right' ? currentColumn.rightEdge : previousColumn.leftEdge;
8134 requestAnimationFrame(function () {
8135 _this.setState(function (prevState) {
8136 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8137 });
8138 });
8139 }
8140 };
8141
8142 return handleScroll;
8143 };
8144
8145 _this.renderHeadings = function (heading, headingIndex) {
8146 var _this$props = _this.props,
8147 sortable = _this$props.sortable,
8148 _this$props$truncate = _this$props.truncate,
8149 truncate = _this$props$truncate === void 0 ? false : _this$props$truncate,
8150 columnContentTypes = _this$props.columnContentTypes,
8151 defaultSortDirection = _this$props.defaultSortDirection,
8152 _this$props$initialSo = _this$props.initialSortColumnIndex,
8153 initialSortColumnIndex = _this$props$initialSo === void 0 ? 0 : _this$props$initialSo,
8154 verticalAlign = _this$props.verticalAlign;
8155 var _this$state2 = _this.state,
8156 _this$state2$sortDire = _this$state2.sortDirection,
8157 sortDirection = _this$state2$sortDire === void 0 ? defaultSortDirection : _this$state2$sortDire,
8158 _this$state2$sortedCo = _this$state2.sortedColumnIndex,
8159 sortedColumnIndex = _this$state2$sortedCo === void 0 ? initialSortColumnIndex : _this$state2$sortedCo;
8160 var sortableHeadingProps;
8161 var id = "heading-cell-".concat(headingIndex);
8162
8163 if (sortable) {
8164 var isSortable = sortable[headingIndex];
8165 var isSorted = isSortable && sortedColumnIndex === headingIndex;
8166 var direction = isSorted ? sortDirection : 'none';
8167 sortableHeadingProps = {
8168 defaultSortDirection,
8169 sorted: isSorted,
8170 sortable: isSortable,
8171 sortDirection: direction,
8172 onSort: _this.defaultOnSort(headingIndex)
8173 };
8174 }
8175
8176 return React__default.createElement(Cell, Object.assign({
8177 header: true,
8178 key: id,
8179 content: heading,
8180 contentType: columnContentTypes[headingIndex],
8181 firstColumn: headingIndex === 0,
8182 truncate: truncate
8183 }, sortableHeadingProps, {
8184 verticalAlign: verticalAlign
8185 }));
8186 };
8187
8188 _this.totalsRowHeading = function () {
8189 var _this$props2 = _this.props,
8190 intl = _this$props2.polaris.intl,
8191 totals = _this$props2.totals,
8192 totalsName = _this$props2.totalsName;
8193 var totalsLabel = totalsName ? totalsName : {
8194 singular: intl.translate('Polaris.DataTable.totalRowHeading'),
8195 plural: intl.translate('Polaris.DataTable.totalsRowHeading')
8196 };
8197 return totals && totals.filter(function (total) {
8198 return total !== '';
8199 }).length > 1 ? totalsLabel.plural : totalsLabel.singular;
8200 };
8201
8202 _this.renderTotals = function (total, index) {
8203 var id = "totals-cell-".concat(index);
8204 var _this$props3 = _this.props,
8205 _this$props3$truncate = _this$props3.truncate,
8206 truncate = _this$props3$truncate === void 0 ? false : _this$props3$truncate,
8207 verticalAlign = _this$props3.verticalAlign;
8208 var content;
8209 var contentType;
8210
8211 if (index === 0) {
8212 content = _this.totalsRowHeading();
8213 }
8214
8215 if (total !== '' && index > 0) {
8216 contentType = 'numeric';
8217 content = total;
8218 }
8219
8220 var totalInFooter = _this.props.showTotalsInFooter;
8221 return React__default.createElement(Cell, {
8222 total: true,
8223 totalInFooter: totalInFooter,
8224 firstColumn: index === 0,
8225 key: id,
8226 content: content,
8227 contentType: contentType,
8228 truncate: truncate,
8229 verticalAlign: verticalAlign
8230 });
8231 };
8232
8233 _this.defaultRenderRow = function (row, index) {
8234 var className = classNames(styles$I.TableRow);
8235 var _this$props4 = _this.props,
8236 columnContentTypes = _this$props4.columnContentTypes,
8237 _this$props4$truncate = _this$props4.truncate,
8238 truncate = _this$props4$truncate === void 0 ? false : _this$props4$truncate,
8239 verticalAlign = _this$props4.verticalAlign;
8240 return React__default.createElement("tr", {
8241 key: "row-".concat(index),
8242 className: className
8243 }, row.map(function (content, cellIndex) {
8244 var id = "cell-".concat(cellIndex, "-row-").concat(index);
8245 return React__default.createElement(Cell, {
8246 key: id,
8247 content: content,
8248 contentType: columnContentTypes[cellIndex],
8249 firstColumn: cellIndex === 0,
8250 truncate: truncate,
8251 verticalAlign: verticalAlign
8252 });
8253 }));
8254 };
8255
8256 _this.defaultOnSort = function (headingIndex) {
8257 var _this$props5 = _this.props,
8258 onSort = _this$props5.onSort,
8259 _this$props5$defaultS = _this$props5.defaultSortDirection,
8260 defaultSortDirection = _this$props5$defaultS === void 0 ? 'ascending' : _this$props5$defaultS,
8261 initialSortColumnIndex = _this$props5.initialSortColumnIndex;
8262 var _this$state3 = _this.state,
8263 _this$state3$sortDire = _this$state3.sortDirection,
8264 sortDirection = _this$state3$sortDire === void 0 ? defaultSortDirection : _this$state3$sortDire,
8265 _this$state3$sortedCo = _this$state3.sortedColumnIndex,
8266 sortedColumnIndex = _this$state3$sortedCo === void 0 ? initialSortColumnIndex : _this$state3$sortedCo;
8267 var newSortDirection = defaultSortDirection;
8268
8269 if (sortedColumnIndex === headingIndex) {
8270 newSortDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
8271 }
8272
8273 var handleSort = function handleSort() {
8274 _this.setState({
8275 sortDirection: newSortDirection,
8276 sortedColumnIndex: headingIndex
8277 }, function () {
8278 if (onSort) {
8279 onSort(headingIndex, newSortDirection);
8280 }
8281 });
8282 };
8283
8284 return handleSort;
8285 };
8286
8287 return _this;
8288 }
8289
8290 _createClass(DataTableInner, [{
8291 key: "componentDidMount",
8292 value: function componentDidMount() {
8293 var _this2 = this;
8294
8295 // We need to defer the calculation in development so the styles have time to be injected.
8296 if (process.env.NODE_ENV === 'development') {
8297 setTimeout(function () {
8298 _this2.handleResize();
8299 }, 10);
8300 } else {
8301 this.handleResize();
8302 }
8303 }
8304 }, {
8305 key: "componentDidUpdate",
8306 value: function componentDidUpdate(prevProps) {
8307 if (isEqual(prevProps, this.props)) {
8308 return;
8309 }
8310
8311 this.handleResize();
8312 }
8313 }, {
8314 key: "render",
8315 value: function render() {
8316 var _this$props6 = this.props,
8317 headings = _this$props6.headings,
8318 totals = _this$props6.totals,
8319 showTotalsInFooter = _this$props6.showTotalsInFooter,
8320 rows = _this$props6.rows,
8321 footerContent = _this$props6.footerContent,
8322 _this$props6$hideScro = _this$props6.hideScrollIndicator,
8323 hideScrollIndicator = _this$props6$hideScro === void 0 ? false : _this$props6$hideScro;
8324 var _this$state4 = this.state,
8325 condensed = _this$state4.condensed,
8326 columnVisibilityData = _this$state4.columnVisibilityData,
8327 isScrolledFarthestLeft = _this$state4.isScrolledFarthestLeft,
8328 isScrolledFarthestRight = _this$state4.isScrolledFarthestRight;
8329 var className = classNames(styles$I.DataTable, condensed && styles$I.condensed);
8330 var wrapperClassName = classNames(styles$I.TableWrapper, condensed && styles$I.condensed);
8331 var headingMarkup = React__default.createElement("tr", null, headings.map(this.renderHeadings));
8332 var totalsMarkup = totals ? React__default.createElement("tr", null, totals.map(this.renderTotals)) : null;
8333 var bodyMarkup = rows.map(this.defaultRenderRow);
8334 var footerMarkup = footerContent ? React__default.createElement("div", {
8335 className: styles$I.Footer
8336 }, footerContent) : null;
8337 var headerTotalsMarkup = !showTotalsInFooter ? totalsMarkup : null;
8338 var footerTotalsMarkup = showTotalsInFooter ? React__default.createElement("tfoot", null, totalsMarkup) : null;
8339 var navigationMarkup = hideScrollIndicator ? null : React__default.createElement(Navigation, {
8340 columnVisibilityData: columnVisibilityData,
8341 isScrolledFarthestLeft: isScrolledFarthestLeft,
8342 isScrolledFarthestRight: isScrolledFarthestRight,
8343 navigateTableLeft: this.navigateTable('left'),
8344 navigateTableRight: this.navigateTable('right')
8345 });
8346 return React__default.createElement("div", {
8347 className: wrapperClassName
8348 }, navigationMarkup, React__default.createElement("div", {
8349 className: className,
8350 ref: this.dataTable
8351 }, React__default.createElement("div", {
8352 className: styles$I.ScrollContainer,
8353 ref: this.scrollContainer
8354 }, React__default.createElement(EventListener, {
8355 event: "resize",
8356 handler: this.handleResize
8357 }), React__default.createElement(EventListener, {
8358 capture: true,
8359 event: "scroll",
8360 handler: this.scrollListener
8361 }), React__default.createElement("table", {
8362 className: styles$I.Table,
8363 ref: this.table
8364 }, React__default.createElement("thead", null, headingMarkup, headerTotalsMarkup), React__default.createElement("tbody", null, bodyMarkup), footerTotalsMarkup)), footerMarkup));
8365 }
8366 }]);
8367
8368 return DataTableInner;
8369}(React__default.PureComponent);
8370
8371var DataTable = withAppProvider()(DataTableInner);
8372
8373function monthName(month) {
8374 switch (month) {
8375 case 0:
8376 return 'january';
8377
8378 case 1:
8379 return 'february';
8380
8381 case 2:
8382 return 'march';
8383
8384 case 3:
8385 return 'april';
8386
8387 case 4:
8388 return 'may';
8389
8390 case 5:
8391 return 'june';
8392
8393 case 6:
8394 return 'july';
8395
8396 case 7:
8397 return 'august';
8398
8399 case 8:
8400 return 'september';
8401
8402 case 9:
8403 return 'october';
8404
8405 case 10:
8406 return 'november';
8407
8408 case 11:
8409 return 'december';
8410 }
8411}
8412function weekdayName(weekday) {
8413 switch (weekday) {
8414 case 0:
8415 return 'sunday';
8416
8417 case 1:
8418 return 'monday';
8419
8420 case 2:
8421 return 'tuesday';
8422
8423 case 3:
8424 return 'wednesday';
8425
8426 case 4:
8427 return 'thursday';
8428
8429 case 5:
8430 return 'friday';
8431
8432 case 6:
8433 return 'saturday';
8434 }
8435}
8436
8437var styles$J = {
8438 "DatePicker": "Polaris-DatePicker",
8439 "MonthContainer": "Polaris-DatePicker__MonthContainer",
8440 "Month": "Polaris-DatePicker__Month",
8441 "Month-current": "Polaris-DatePicker__Month--current",
8442 "Week": "Polaris-DatePicker__Week",
8443 "WeekHeadings": "Polaris-DatePicker__WeekHeadings",
8444 "Day": "Polaris-DatePicker__Day",
8445 "EmptyDay": "Polaris-DatePicker__EmptyDay",
8446 "Day-today": "Polaris-DatePicker__Day--today",
8447 "Day-inRange": "Polaris-DatePicker__Day--inRange",
8448 "Day-selected": "Polaris-DatePicker__Day--selected",
8449 "Day-disabled": "Polaris-DatePicker__Day--disabled",
8450 "Weekday": "Polaris-DatePicker__Weekday",
8451 "Weekday-current": "Polaris-DatePicker__Weekday--current",
8452 "Header": "Polaris-DatePicker__Header",
8453 "Title": "Polaris-DatePicker__Title"
8454};
8455
8456var Day = memo(function Day(_ref) {
8457 var day = _ref.day,
8458 focused = _ref.focused,
8459 onClick = _ref.onClick,
8460 _ref$onHover = _ref.onHover,
8461 onHover = _ref$onHover === void 0 ? noop$5 : _ref$onHover,
8462 _ref$onFocus = _ref.onFocus,
8463 _onFocus = _ref$onFocus === void 0 ? noop$5 : _ref$onFocus,
8464 selected = _ref.selected,
8465 inRange = _ref.inRange,
8466 inHoveringRange = _ref.inHoveringRange,
8467 disabled = _ref.disabled,
8468 lastDayOfMonth = _ref.lastDayOfMonth;
8469
8470 var i18n = useI18n();
8471 var dayNode = useRef(null);
8472 var hoverValue = lastDayOfMonth || day;
8473 useEffect(function () {
8474 if (focused && dayNode.current) {
8475 dayNode.current.focus();
8476 }
8477 }, [focused]);
8478
8479 if (!day) {
8480 return React__default.createElement("div", {
8481 className: styles$J.EmptyDay,
8482 onMouseOver: function onMouseOver() {
8483 return onHover(hoverValue);
8484 }
8485 });
8486 }
8487
8488 var handleClick = onClick && !disabled ? onClick.bind(null, day) : noop$5;
8489 var today = isSameDay(new Date(), day);
8490 var className = classNames(styles$J.Day, selected && styles$J['Day-selected'], disabled && styles$J['Day-disabled'], today && styles$J['Day-today'], (inRange || inHoveringRange) && !disabled && styles$J['Day-inRange']);
8491 var date = day.getDate();
8492 var tabIndex = (focused || selected || today || date === 1) && !disabled ? 0 : -1;
8493 var ariaLabel = ["".concat(today ? i18n.translate('Polaris.DatePicker.today') : ''), "".concat(Months[day.getMonth()], " "), "".concat(date, " "), "".concat(day.getFullYear())].join('');
8494 return React__default.createElement("button", {
8495 onFocus: function onFocus() {
8496 return _onFocus(day);
8497 },
8498 type: "button",
8499 ref: dayNode,
8500 tabIndex: tabIndex,
8501 className: className,
8502 onMouseOver: function onMouseOver() {
8503 return onHover(hoverValue);
8504 },
8505 onClick: handleClick,
8506 "aria-label": ariaLabel,
8507 "aria-selected": selected,
8508 "aria-disabled": disabled,
8509 role: "gridcell"
8510 }, date);
8511});
8512
8513function noop$5() {}
8514
8515var Weekday = memo(function Weekday(_ref) {
8516 var label = _ref.label,
8517 title = _ref.title,
8518 current = _ref.current;
8519 var className = classNames(styles$J.Weekday, current && styles$J['Weekday-current']);
8520 return React__default.createElement("div", {
8521 "aria-label": Weekdays[label],
8522 className: className
8523 }, title);
8524});
8525
8526var WEEKDAYS = [Weekdays.Sunday, Weekdays.Monday, Weekdays.Tuesday, Weekdays.Wednesday, Weekdays.Thursday, Weekdays.Friday, Weekdays.Saturday];
8527function Month(_ref) {
8528 var focusedDate = _ref.focusedDate,
8529 selected = _ref.selected,
8530 hoverDate = _ref.hoverDate,
8531 disableDatesBefore = _ref.disableDatesBefore,
8532 disableDatesAfter = _ref.disableDatesAfter,
8533 allowRange = _ref.allowRange,
8534 _ref$onChange = _ref.onChange,
8535 onChange = _ref$onChange === void 0 ? noop$6 : _ref$onChange,
8536 _ref$onHover = _ref.onHover,
8537 onHover = _ref$onHover === void 0 ? noop$6 : _ref$onHover,
8538 _ref$onFocus = _ref.onFocus,
8539 onFocus = _ref$onFocus === void 0 ? noop$6 : _ref$onFocus,
8540 month = _ref.month,
8541 year = _ref.year,
8542 weekStartsOn = _ref.weekStartsOn;
8543 var i18n = useI18n();
8544 var isInHoveringRange = allowRange ? hoveringDateIsInRange : function () {
8545 return false;
8546 };
8547 var now = new Date();
8548 var current = now.getMonth() === month && now.getFullYear() === year;
8549 var className = classNames(styles$J.Title, current && styles$J['Month-current']);
8550 var weeks = useMemo(function () {
8551 return getWeeksForMonth(month, year, weekStartsOn);
8552 }, [month, weekStartsOn, year]);
8553 var weekdays = getWeekdaysOrdered(weekStartsOn).map(function (weekday) {
8554 return React__default.createElement(Weekday, {
8555 key: weekday,
8556 title: i18n.translate("Polaris.DatePicker.daysAbbreviated.".concat(weekdayName(weekday))),
8557 current: current && new Date().getDay() === weekday,
8558 label: weekday
8559 });
8560 });
8561 var handleDateClick = useCallback(function (selectedDate) {
8562 onChange(getNewRange(allowRange ? selected : undefined, selectedDate));
8563 }, [allowRange, onChange, selected]);
8564 var lastDayOfMonth = useMemo(function () {
8565 return new Date(year, month + 1, 0);
8566 }, [month, year]);
8567
8568 function renderWeek(day, dayIndex) {
8569 if (day == null) {
8570 return React__default.createElement(Day, {
8571 key: dayIndex,
8572 onHover: onHover,
8573 lastDayOfMonth: lastDayOfMonth
8574 });
8575 }
8576
8577 var disabled = disableDatesBefore && isDateBefore(day, disableDatesBefore) || disableDatesAfter && isDateAfter(day, disableDatesAfter);
8578 return React__default.createElement(Day, {
8579 focused: focusedDate != null && isSameDay(day, focusedDate),
8580 day: day,
8581 key: dayIndex,
8582 onFocus: onFocus,
8583 onClick: handleDateClick,
8584 onHover: onHover,
8585 selected: selected != null && dateIsSelected(day, selected),
8586 inRange: selected != null && dateIsInRange(day, selected),
8587 disabled: disabled,
8588 inHoveringRange: selected != null && hoverDate != null && isInHoveringRange(day, selected, hoverDate)
8589 });
8590 }
8591
8592 var weeksMarkup = weeks.map(function (week, index) {
8593 return React__default.createElement("div", {
8594 role: "row",
8595 className: styles$J.Week,
8596 key: index
8597 }, week.map(renderWeek));
8598 });
8599 return React__default.createElement("div", {
8600 role: "grid",
8601 className: styles$J.Month
8602 }, React__default.createElement("div", {
8603 className: className
8604 }, i18n.translate("Polaris.DatePicker.months.".concat(monthName(month))), " ", year), React__default.createElement("div", {
8605 role: "rowheader",
8606 className: styles$J.WeekHeadings
8607 }, weekdays), weeksMarkup);
8608}
8609
8610function noop$6() {}
8611
8612function hoveringDateIsInRange(day, range, hoverEndDate) {
8613 if (day == null) {
8614 return false;
8615 }
8616
8617 var start = range.start,
8618 end = range.end;
8619 return Boolean(isSameDay(start, end) && day > start && day <= hoverEndDate);
8620}
8621
8622function getWeekdaysOrdered(weekStartsOn) {
8623 var weekDays = [].concat(WEEKDAYS);
8624 var restOfDays = weekDays.splice(weekStartsOn);
8625 return [].concat(_toConsumableArray(restOfDays), _toConsumableArray(weekDays));
8626}
8627
8628function DatePicker(_ref) {
8629 var id = _ref.id,
8630 selected = _ref.selected,
8631 month = _ref.month,
8632 year = _ref.year,
8633 allowRange = _ref.allowRange,
8634 multiMonth = _ref.multiMonth,
8635 disableDatesBefore = _ref.disableDatesBefore,
8636 disableDatesAfter = _ref.disableDatesAfter,
8637 _ref$weekStartsOn = _ref.weekStartsOn,
8638 weekStartsOn = _ref$weekStartsOn === void 0 ? Weekdays.Sunday : _ref$weekStartsOn,
8639 onMonthChange = _ref.onMonthChange,
8640 _ref$onChange = _ref.onChange,
8641 onChange = _ref$onChange === void 0 ? noop$7 : _ref$onChange;
8642 var i18n = useI18n();
8643
8644 var _useState = useState(undefined),
8645 _useState2 = _slicedToArray(_useState, 2),
8646 hoverDate = _useState2[0],
8647 setHoverDate = _useState2[1];
8648
8649 var _useState3 = useState(undefined),
8650 _useState4 = _slicedToArray(_useState3, 2),
8651 focusDate = _useState4[0],
8652 setFocusDate = _useState4[1];
8653
8654 useEffect(function () {
8655 setFocusDate(undefined);
8656 }, [selected]);
8657 var handleFocus = useCallback(function (date) {
8658 setFocusDate(date);
8659 }, []);
8660 var setFocusDateAndHandleMonthChange = useCallback(function (date) {
8661 if (onMonthChange) {
8662 onMonthChange(date.getMonth(), date.getFullYear());
8663 }
8664
8665 setHoverDate(date);
8666 setFocusDate(date);
8667 }, [onMonthChange]);
8668 var handleDateSelection = useCallback(function (range) {
8669 var end = range.end;
8670 setHoverDate(end);
8671 setFocusDate(new Date(end));
8672 onChange(range);
8673 }, [onChange]);
8674 var handleMonthChangeClick = useCallback(function (month, year) {
8675 if (!onMonthChange) {
8676 return;
8677 }
8678
8679 setFocusDate(undefined);
8680 onMonthChange(month, year);
8681 }, [onMonthChange]);
8682 var handleHover = useCallback(function (date) {
8683 setHoverDate(date);
8684 }, []);
8685 var handleKeyUp = useCallback(function (event) {
8686 var key = event.key;
8687 var range = deriveRange(selected);
8688 var focusedDate = focusDate || range && range.start;
8689
8690 if (focusedDate == null) {
8691 return;
8692 }
8693
8694 if (key === 'ArrowUp') {
8695 var previousWeek = new Date(focusedDate);
8696 previousWeek.setDate(focusedDate.getDate() - 7);
8697
8698 if (!(disableDatesBefore && isDateBefore(previousWeek, disableDatesBefore))) {
8699 setFocusDateAndHandleMonthChange(previousWeek);
8700 }
8701 }
8702
8703 if (key === 'ArrowDown') {
8704 var nextWeek = new Date(focusedDate);
8705 nextWeek.setDate(focusedDate.getDate() + 7);
8706
8707 if (!(disableDatesAfter && isDateAfter(nextWeek, disableDatesAfter))) {
8708 setFocusDateAndHandleMonthChange(nextWeek);
8709 }
8710 }
8711
8712 if (key === 'ArrowRight') {
8713 var tomorrow = new Date(focusedDate);
8714 tomorrow.setDate(focusedDate.getDate() + 1);
8715
8716 if (!(disableDatesAfter && isDateAfter(tomorrow, disableDatesAfter))) {
8717 setFocusDateAndHandleMonthChange(tomorrow);
8718 }
8719 }
8720
8721 if (key === 'ArrowLeft') {
8722 var yesterday = new Date(focusedDate);
8723 yesterday.setDate(focusedDate.getDate() - 1);
8724
8725 if (!(disableDatesBefore && isDateBefore(yesterday, disableDatesBefore))) {
8726 setFocusDateAndHandleMonthChange(yesterday);
8727 }
8728 }
8729 }, [disableDatesAfter, disableDatesBefore, focusDate, selected, setFocusDateAndHandleMonthChange]);
8730 var showNextYear = getNextDisplayYear(month, year);
8731 var showNextMonth = getNextDisplayMonth(month);
8732 var showNextToNextYear = getNextDisplayYear(showNextMonth, showNextYear);
8733 var showNextToNextMonth = getNextDisplayMonth(showNextMonth);
8734 var showPreviousYear = getPreviousDisplayYear(month, year);
8735 var showPreviousMonth = getPreviousDisplayMonth(month);
8736 var previousMonthName = i18n.translate("Polaris.DatePicker.months.".concat(monthName(showPreviousMonth)));
8737 var nextMonth = multiMonth ? i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextToNextMonth))) : i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextMonth)));
8738 var nextYear = multiMonth ? showNextToNextYear : showNextYear;
8739 var monthIsSelected = useMemo(function () {
8740 return deriveRange(selected);
8741 }, [selected]);
8742 var secondDatePicker = multiMonth ? React__default.createElement(Month, {
8743 onFocus: handleFocus,
8744 focusedDate: focusDate,
8745 month: showNextMonth,
8746 year: showNextYear,
8747 selected: monthIsSelected,
8748 hoverDate: hoverDate,
8749 onChange: handleDateSelection,
8750 onHover: handleHover,
8751 disableDatesBefore: disableDatesBefore,
8752 disableDatesAfter: disableDatesAfter,
8753 allowRange: allowRange,
8754 weekStartsOn: weekStartsOn
8755 }) : null;
8756 return React__default.createElement("div", {
8757 id: id,
8758 className: styles$J.DatePicker,
8759 onKeyDown: handleKeyDown,
8760 onKeyUp: handleKeyUp
8761 }, React__default.createElement("div", {
8762 className: styles$J.Header
8763 }, React__default.createElement(Button, {
8764 plain: true,
8765 icon: ArrowLeftMinor,
8766 accessibilityLabel: i18n.translate('Polaris.DatePicker.previousMonth', {
8767 previousMonthName,
8768 showPreviousYear
8769 }),
8770 onClick: function onClick() {
8771 return handleMonthChangeClick(showPreviousMonth, showPreviousYear);
8772 }
8773 }), React__default.createElement(Button, {
8774 plain: true,
8775 icon: ArrowRightMinor,
8776 accessibilityLabel: i18n.translate('Polaris.DatePicker.nextMonth', {
8777 nextMonth,
8778 nextYear
8779 }),
8780 onClick: function onClick() {
8781 return handleMonthChangeClick(showNextMonth, showNextYear);
8782 }
8783 })), React__default.createElement("div", {
8784 className: styles$J.MonthContainer
8785 }, React__default.createElement(Month, {
8786 onFocus: handleFocus,
8787 focusedDate: focusDate,
8788 month: month,
8789 year: year,
8790 selected: deriveRange(selected),
8791 hoverDate: hoverDate,
8792 onChange: handleDateSelection,
8793 onHover: handleHover,
8794 disableDatesBefore: disableDatesBefore,
8795 disableDatesAfter: disableDatesAfter,
8796 allowRange: allowRange,
8797 weekStartsOn: weekStartsOn
8798 }), secondDatePicker));
8799}
8800
8801function noop$7() {}
8802
8803function handleKeyDown(event) {
8804 var key = event.key;
8805
8806 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
8807 event.preventDefault();
8808 event.stopPropagation();
8809 }
8810}
8811
8812function deriveRange(selected) {
8813 return selected instanceof Date ? {
8814 start: selected,
8815 end: selected
8816 } : selected;
8817}
8818
8819var styles$K = {
8820 "DescriptionList": "Polaris-DescriptionList",
8821 "Term": "Polaris-DescriptionList__Term",
8822 "Description": "Polaris-DescriptionList__Description"
8823};
8824
8825var getUniqueTermKey = createUniqueIDFactory("Term");
8826var getUniqueDescriptionKey = createUniqueIDFactory("Description");
8827function DescriptionList(_ref) {
8828 var items = _ref.items;
8829 var terms = items.reduce(function (allTerms, _ref2) {
8830 var term = _ref2.term,
8831 description = _ref2.description;
8832 return [].concat(_toConsumableArray(allTerms), [React__default.createElement("dt", {
8833 key: getUniqueTermKey(),
8834 className: styles$K.Term
8835 }, term), React__default.createElement("dd", {
8836 key: getUniqueDescriptionKey(),
8837 className: styles$K.Description
8838 }, description)]);
8839 }, []);
8840 return React__default.createElement("dl", {
8841 className: styles$K.DescriptionList
8842 }, terms);
8843}
8844
8845var styles$L = {
8846 "DisplayText": "Polaris-DisplayText",
8847 "sizeSmall": "Polaris-DisplayText--sizeSmall",
8848 "sizeMedium": "Polaris-DisplayText--sizeMedium",
8849 "sizeLarge": "Polaris-DisplayText--sizeLarge",
8850 "sizeExtraLarge": "Polaris-DisplayText--sizeExtraLarge"
8851};
8852
8853function DisplayText(_ref) {
8854 var _ref$element = _ref.element,
8855 Element = _ref$element === void 0 ? 'p' : _ref$element,
8856 children = _ref.children,
8857 _ref$size = _ref.size,
8858 size = _ref$size === void 0 ? 'medium' : _ref$size;
8859 var className = classNames(styles$L.DisplayText, size && styles$L[variationName('size', size)]);
8860 return React__default.createElement(Element, {
8861 className: className
8862 }, children);
8863}
8864
8865function capitalize() {
8866 var word = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
8867 var wordLower = word.toLowerCase();
8868 return wordLower.charAt(0).toUpperCase() + wordLower.slice(1);
8869}
8870
8871/**
8872 * Similarly to the life-cycle method componentDidMount, useComponentDidMount
8873 * will be invoked after the component has mounted, and only the initial mount.
8874 * @param callback Defines a callback to invoke once the component has
8875 * initially mounted.
8876 * @example
8877 * function Playground({active}) {
8878 * useComponentDidMount(() => {
8879 * if (active) {
8880 * console.warning(`Component has mounted.`);
8881 * }
8882 * });
8883 *
8884 * return null;
8885 * }
8886 */
8887
8888function useComponentDidMount(callback) {
8889 var isAfterInitialMount = useIsAfterInitialMount();
8890 var hasInvokedLifeCycle = useRef(false);
8891
8892 if (isAfterInitialMount && !hasInvokedLifeCycle.current) {
8893 hasInvokedLifeCycle.current = true;
8894 return callback();
8895 }
8896}
8897
8898var fileUpload = 'data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 128 128"><path d="M69.81 124.43a1.39 1.39 0 01-.57-.12 1.43 1.43 0 01-.49-.32 1.52 1.52 0 01-.44-1.06 1.5 1.5 0 01.44-1.06 1.53 1.53 0 011.35-.42 1.31 1.31 0 01.28.09 1.08 1.08 0 01.26.14 1.06 1.06 0 01.23.19 1.37 1.37 0 01.19.22 1.26 1.26 0 01.13.26 1.49 1.49 0 01-.32 1.64 1.34 1.34 0 01-.49.32 1.39 1.39 0 01-.57.12zm-9.71-1.5a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.51 1.51 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.51 1.51 0 011.51 1.5 1.51 1.51 0 01-1.51 1.5 1.51 1.51 0 01-1.5-1.5zm-8.21 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.51 1.51 0 011.51 1.5 1.51 1.51 0 01-1.51 1.5 1.51 1.51 0 01-1.5-1.5zm-8.21 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.52-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.51 1.51 0 011.51 1.5 1.51 1.51 0 01-1.51 1.5 1.5 1.5 0 01-1.5-1.5zm-6.71 1.5A1.5 1.5 0 013 124a1.47 1.47 0 01-.44-1.06 1.53 1.53 0 010-.3c0-.09 0-.19.08-.28a2.15 2.15 0 01.14-.26 1.37 1.37 0 01.19-.22 1.06 1.06 0 01.23-.19 1.08 1.08 0 01.26-.14 1.31 1.31 0 01.28-.09 1.88 1.88 0 01.58 0 1.31 1.31 0 01.28.09 1.3 1.3 0 01.26.14 1.37 1.37 0 01.23.19 1.37 1.37 0 01.19.22 1.26 1.26 0 01.13.26 1.41 1.41 0 01.12.58 1.56 1.56 0 01-.11.57 1.63 1.63 0 01-.33.49 1.5 1.5 0 01-1 .43zm-1.5-9.5a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.49zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.49zm0-8a1.5 1.5 0 011.5-1.5A1.5 1.5 0 015.59 83a1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5A1.5 1.5 0 015.59 75a1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5A1.5 1.5 0 015.59 67a1.51 1.51 0 01-1.5 1.51A1.51 1.51 0 012.59 67zm0-8a1.5 1.5 0 011.5-1.5A1.5 1.5 0 015.59 59a1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.51 1.51 0 011.5-1.51A1.51 1.51 0 015.59 51a1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm1.5-6.46A1.5 1.5 0 012.59 43a1.36 1.36 0 010-.29 2.29 2.29 0 01.08-.28 2.15 2.15 0 01.14-.26 1.57 1.57 0 01.42-.42 2 2 0 01.25-.14l.29-.08a1.5 1.5 0 011.35.41 1.45 1.45 0 01.19.23 1.26 1.26 0 01.13.26 1.31 1.31 0 01.09.28 1.36 1.36 0 010 .29 1.52 1.52 0 01-.38 1 2.11 2.11 0 01-.23.19 1.26 1.26 0 01-.26.13 1.31 1.31 0 01-.28.09 1.43 1.43 0 01-.29.06zM60.1 43a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.51 1.51 0 011.51 1.5 1.51 1.51 0 01-1.51 1.5 1.5 1.5 0 01-1.5-1.5zm-8.21 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm-8.22 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zM19 43a1.5 1.5 0 011.5-1.5A1.5 1.5 0 0122 43a1.5 1.5 0 01-1.5 1.5A1.5 1.5 0 0119 43zm-8.2 0a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm59.01 1.47a1.5 1.5 0 01-1.06-.47 1.52 1.52 0 01-.44-1 1.5 1.5 0 011.79-1.5l.28.08.26.14a2.11 2.11 0 01.23.19 1.5 1.5 0 01.44 1.09 1.52 1.52 0 01-.44 1 2.11 2.11 0 01-.23.19 1.26 1.26 0 01-.26.13 1.31 1.31 0 01-.28.09 1.36 1.36 0 01-.29.06zm-1.5 70.46a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.5zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.49zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.49zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.43zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.43zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.49 1.5 1.5 0 01-1.5-1.42zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.43zm0-8a1.5 1.5 0 011.5-1.5 1.5 1.5 0 011.5 1.5 1.5 1.5 0 01-1.5 1.5 1.5 1.5 0 01-1.5-1.43z" fill="#dee4f5"/><path fill="#fff" d="M26.67 3.57h79.41v96.61H26.67z"/><path d="M106.92 101H91.78c-1.64 0-3.24.15-4.9.18s-3.39-.05-5.11-.13c-.85 0-1.7-.06-2.54 0s-1.67 0-2.49 0l-9.91.29c-3.32.08-6.62.24-10 .26s-6.78-.27-10.11-.19c-6.63.42-13.4.16-20.07 0h-.08a1.1 1.1 0 01-1.07-1.13c.08-2 .06-4 .08-6s0-4 0-6-.19-4-.23-6 .15-4 .28-6a21.6 21.6 0 000-3 27.86 27.86 0 01-.14-3v-6l.13-12.08v-12l.33-6a53 53 0 00-.13-6c-.23-4 .12-8 .26-12.08l.06-3v-3l-.08-6A.55.55 0 0126.64 3c3.3-.1 6.61 0 9.92 0s6.62 0 9.93.06c1.65 0 3.31.06 5 .07H54l2.48-.08 9.93-.33C73 2.54 79.6 2.4 86.22 2.43c3.31.07 6.62.3 9.93.24l9.92-.26a1.13 1.13 0 011.16 1.1v.06l.18 6.1c0 2-.11 4.06-.16 6.08 0 4.06.22 8.16.13 12.22 0 2-.26 4-.33 6-.06 1 0 2 0 3v6.06l-.12 3a46.75 46.75 0 00.09 6.13c.21 4.16-.21 8-.2 12.08-.17 4 .13 8.2 0 12.21 0 2-.15 4-.16 6s.07 4.11.13 6.19l.08 3.12v3.06c.06 2.18.13 4.18.05 6.18zm-1.7-1.69V87.37c0-2 .08-3.93.06-5.93s-.2-4.13-.26-6.15c-.15-4.08.22-7.83 0-11.93-.06-2-.16-4.06-.27-6.1a43.89 43.89 0 010-6 31.14 31.14 0 00.16-5.9 44.75 44.75 0 01-.09-6 58.45 58.45 0 00.18-5.86c0-2-.27-4.05-.28-6s0-4 .11-5.95.15-4 .14-6-.19-4-.16-6l.14-6 1.11 1.11c-3.31-.07-6.61-.19-9.92-.18s-6.62.3-9.93.43C79.6 5.06 73 5 66.37 4.83c-1.66 0-3.31-.1-5-.17l-5-.29c-3.31-.18-6.61 0-9.92.13-6.62.22-13.24.39-19.85.27l1.2-1.2-.28 6v3l.1 3c.22 4 .83 8.06.37 12.08-.11 1-.27 2-.34 3s0 2 0 3c.11 2 .41 4 .5 6v3l-.07 3-.14 6L28 64l-.06 6a22 22 0 01-.2 3 20.18 20.18 0 00-.08 3c.09 2 .28 4 .19 6l-.27 6c-.06 4-.14 8.05-.13 12.08l-.74-.75h9.85c3.28 0 6.58.08 9.86.06s6.51-.25 9.76-.29 6.57.1 9.87.14l9.91.19h4.89c1.59 0 3.18-.14 4.82-.14s3.34.11 5 .14l4.86-.06c3.17-.05 6.47-.02 9.69-.04z" fill="#fff"/><g opacity=".5" fill="#dee4f5"><path d="M26.67 3.57h79.41v96.61H26.67z"/><path d="M106.92 101H91.78c-1.64 0-3.24.15-4.9.18s-3.39-.05-5.11-.13c-.85 0-1.7-.06-2.54 0s-1.67 0-2.49 0l-9.91.29c-3.32.08-6.62.24-10 .26s-6.78-.27-10.11-.19c-6.63.42-13.4.16-20.07 0h-.08a1.1 1.1 0 01-1.07-1.13c.08-2 .06-4 .08-6s0-4 0-6-.19-4-.23-6 .15-4 .28-6a21.6 21.6 0 000-3 27.86 27.86 0 01-.14-3v-6l.13-12.08v-12l.33-6a53 53 0 00-.13-6c-.23-4 .12-8 .26-12.08l.06-3v-3l-.08-6A.55.55 0 0126.64 3c3.3-.1 6.61 0 9.92 0s6.62 0 9.93.06c1.65 0 3.31.06 5 .07H54l2.48-.08 9.93-.33C73 2.54 79.6 2.4 86.22 2.43c3.31.07 6.62.3 9.93.24l9.92-.26a1.13 1.13 0 011.16 1.1v.06l.18 6.1c0 2-.11 4.06-.16 6.08 0 4.06.22 8.16.13 12.22 0 2-.26 4-.33 6-.06 1 0 2 0 3v6.06l-.12 3a46.75 46.75 0 00.09 6.13c.21 4.16-.21 8-.2 12.08-.17 4 .13 8.2 0 12.21 0 2-.15 4-.16 6s.07 4.11.13 6.19l.08 3.12v3.06c.06 2.18.13 4.18.05 6.18zm-1.7-1.69V87.37c0-2 .08-3.93.06-5.93s-.2-4.13-.26-6.15c-.15-4.08.22-7.83 0-11.93-.06-2-.16-4.06-.27-6.1a43.89 43.89 0 010-6 31.14 31.14 0 00.16-5.9 44.75 44.75 0 01-.09-6 58.45 58.45 0 00.18-5.86c0-2-.27-4.05-.28-6s0-4 .11-5.95.15-4 .14-6-.19-4-.16-6l.14-6 1.11 1.11c-3.31-.07-6.61-.19-9.92-.18s-6.62.3-9.93.43C79.6 5.06 73 5 66.37 4.83c-1.66 0-3.31-.1-5-.17l-5-.29c-3.31-.18-6.61 0-9.92.13-6.62.22-13.24.39-19.85.27l1.2-1.2-.28 6v3l.1 3c.22 4 .83 8.06.37 12.08-.11 1-.27 2-.34 3s0 2 0 3c.11 2 .41 4 .5 6v3l-.07 3-.14 6L28 64l-.06 6a22 22 0 01-.2 3 20.18 20.18 0 00-.08 3c.09 2 .28 4 .19 6l-.27 6c-.06 4-.14 8.05-.13 12.08l-.74-.75h9.85c3.28 0 6.58.08 9.86.06s6.51-.25 9.76-.29 6.57.1 9.87.14l9.91.19h4.89c1.59 0 3.18-.14 4.82-.14s3.34.11 5 .14l4.86-.06c3.17-.05 6.47-.02 9.69-.04z"/></g><rect x="38.8" y="16.17" width="21.96" height="23.33" rx="10.71" ry="10.71" fill="#dee4f5"/><path d="M50.05 40.29a11.78 11.78 0 01-4.7-.82c-.72-.35-1.43-.72-2.15-1.09-.35-.19-.68-.43-1-.64s-.65-.5-1-.76a11.45 11.45 0 01-3.27-8.87L38 27c0-.39 0-.8.07-1.2s.14-.8.22-1.2l.34-1.16a10.68 10.68 0 012.51-4 15.51 15.51 0 011.76-1.58 10.18 10.18 0 012.06-1.16 13.63 13.63 0 014.58-.95 11.85 11.85 0 014.58.81 12.29 12.29 0 014 2.41 11.75 11.75 0 013.46 8.65 12.61 12.61 0 01-3 8.82 7.57 7.57 0 01-.89.81 8.46 8.46 0 01-1 .72 12.42 12.42 0 01-2 1.23 11.14 11.14 0 01-4.64 1.09zm0-1.58a9.69 9.69 0 004-.92 9.32 9.32 0 001.77-1.06 5.12 5.12 0 00.76-.71 7.07 7.07 0 00.67-.78 11.15 11.15 0 002.09-3.49l.3-1 .16-1 .07-1v-1.18c0-.38.05-.76 0-1.1a6.15 6.15 0 000-1 6 6 0 00-.53-2A10.19 10.19 0 0057.05 20c-.51-.47-1.07-.86-1.57-1.36a4.44 4.44 0 00-1.82-1 6.07 6.07 0 00-1-.25 6.14 6.14 0 00-1-.12c-.71-.08-1.33 0-2.11 0h-1a8.61 8.61 0 00-1 .12 9.38 9.38 0 00-2 .68 11.32 11.32 0 00-1.79 1 5 5 0 00-.83.62l-.39.35-.32.4a25.35 25.35 0 00-2.11 3.55 6.48 6.48 0 00-.32 1c-.05.34-.11.69-.15 1L39.46 27l-.1 1.13a9.38 9.38 0 003 7.71c.24.25.5.49.75.74s.54.45.83.66a5.59 5.59 0 001.9.92 11.23 11.23 0 004.21.55z" fill="#dee4f5"/><path fill="#fff" d="M49.77 27.84h28.68v30.47H49.77z"/><path d="M79 58.87c-2.43.05-5-.13-7.31.07a41.42 41.42 0 00-7.26.18 24.87 24.87 0 01-3.67 0 16 16 0 00-3.67.05c-2.43.16-4.92-.2-7.34-.21a.67.67 0 01-.67-.68v-1.91c0-.64-.1-1.27-.15-1.9-.15-1.27.44-2.54.08-3.81 0-2.54.1-5.08.1-7.62a32.31 32.31 0 01.09-3.81 15.26 15.26 0 00.18-1.9c0-.64-.13-1.27-.16-1.91 0-1.26.15-2.53.23-3.8s0-2.54-.05-3.81a.36.36 0 01.34-.37c1.2-.06 2.39 0 3.59 0s2.39 0 3.58.06c2.39.16 4.78-.23 7.17-.29a86.1 86.1 0 013.59-.13 25.19 25.19 0 013.58.09 63.62 63.62 0 007.2-.17.87.87 0 01.89.83v.06a18 18 0 01-.1 1.94 18 18 0 000 1.94 15.61 15.61 0 01-.12 3.87 38.3 38.3 0 00-.06 3.87 13.2 13.2 0 00-.11 1.9 19.64 19.64 0 01.15 2c-.06 1.27-.22 2.49-.22 3.77s.16 2.69 0 3.91a21.08 21.08 0 000 3.89v2c0 .66.12 1.26.12 1.89zm-1.13-1.13v-3.71a18.64 18.64 0 00-.08-3.78 35.5 35.5 0 010-3.72c0-1.25-.23-2.59-.28-3.84a8.67 8.67 0 01.21-1.78 11.28 11.28 0 00-.12-1.9 8.54 8.54 0 01.1-1.83 7.82 7.82 0 000-1.87 14.21 14.21 0 010-3.74 14.39 14.39 0 00.06-1.86c0-.63-.11-1.25-.09-1.87l.83.83c-2.39 0-4.78-.4-7.17-.08a21.49 21.49 0 01-3.58.19H65.9l-1.79-.07c-2.39 0-4.78-.64-7.17-.29a68.69 68.69 0 01-7.17.22l.8-.8a22.09 22.09 0 00-.16 3.81 22.33 22.33 0 01.37 3.8 16 16 0 00-.35 1.91 8.86 8.86 0 00.26 1.9 16.19 16.19 0 010 3.81c-.11 2.54 0 5.08-.17 7.62-.42 1.27.13 2.54 0 3.81l-.18 1.9-.05 1.91-.53-.53c2.37.09 4.71 0 7.08 0a22.57 22.57 0 003.5-.1 25.48 25.48 0 013.5 0 45 45 0 007.05.06c2.47.17 4.66-.03 7 0z" fill="#fff"/><path d="M83.71 41.19L74 59.28l21.46-.67-11.15-17.45a.34.34 0 00-.6.03z" fill="#dee4f5"/><path d="M84.4 41.56c-.82 1.5-1.59 3-2.49 4.48l-1 2.37c-.35.78-.75 1.53-1.17 2.28l-2.52 4.47c-.81 1.5-1.67 3-2.54 4.45l-.65-1c1.79 0 3.58.14 5.37 0s3.58 0 5.37-.09 3.57 0 5.36-.12a53.51 53.51 0 015.36-.43l-.55 1-1.49-2.23c-.52-.74-1-1.47-1.52-2.22C91 53 90.13 51.43 89.1 50c-.48-.76-1-1.48-1.45-2.26s-.85-1.58-1.36-2.31-1-1.49-1.51-2.22L84 42.08l-.31-.46a.44.44 0 00.71-.06zm-1.4-.74a1.13 1.13 0 01.85-.6 1.15 1.15 0 011 .36 2 2 0 01.17.24l.09.14.19.28.73 1.12 1.48 2.24c.47.76 1.06 1.44 1.58 2.17s.94 1.52 1.41 2.28c.89 1.56 1.86 3.06 2.78 4.6.44.78.85 1.58 1.34 2.33l1.53 2.2a.78.78 0 01-.2 1.08.75.75 0 01-.38.13h-.06a24.72 24.72 0 01-5.37.07c-1.79.07-3.57.52-5.36.44a17.26 17.26 0 00-2.69 0c-.89.06-1.78.07-2.68.08-1.79-.15-3.57.41-5.36.14h-.25a.8.8 0 01-.67-.92.69.69 0 01.12-.32l.75-1.09.6-1.13c.45-.73.93-1.44 1.4-2.15.89-1.47 1.6-3 2.34-4.57.36-.78.72-1.55 1.14-2.3l1.3-2.21c.66-1.58 1.48-3.08 2.22-4.61zm14.76 36.69H86a1 1 0 010-2h11.76a1 1 0 010 2zm-20.16 0H35a1 1 0 010-2h42.6a1 1 0 010 2zM98 88.14H69.31a1 1 0 010-2H98a1 1 0 010 2zm-37.25 0H35a1 1 0 010-2h25.75a1 1 0 010 2z" fill="#dee4f5"/><circle cx="107.41" cy="106.43" r="18" fill="#dee4f5" stroke="#dee4f5" stroke-linecap="round" stroke-linejoin="round" stroke-width="3"/><path fill="none" stroke="#fff" stroke-linecap="round" stroke-linejoin="round" stroke-width="3" d="M107.41 96.84v19.18m7.18-9.59l-7.18-9.59-7.18 9.59"/></svg>
';
8899
8900var imageUpload = 'data:image/svg+xml;base64,<svg viewBox="0 0 129 108" xmlns="http://www.w3.org/2000/svg"><g fill="none" fill-rule="evenodd"><path d="M68.78 106.25a1.52 1.52 0 01-1.06-.44 1.54 1.54 0 01-.32-.49 1.39 1.39 0 01-.12-.57 1.41 1.41 0 01.12-.58.94.94 0 01.14-.26 1 1 0 01.18-.22 1.54 1.54 0 012.12 0 1.5 1.5 0 01-1.06 2.56zm-9.78-1.5a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm-8.31 0a1.5 1.5 0 013 0 1.51 1.51 0 01-1.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.32 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.56-1.5h.06zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.32 0a1.5 1.5 0 111.5 1.5 1.51 1.51 0 01-1.53-1.5h.03zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-6.84 1.5a1.5 1.5 0 01-1.06-.44 1.5 1.5 0 010-2.12 1.06 1.06 0 01.23-.19 1.08 1.08 0 01.26-.14 1.31 1.31 0 01.28-.09 1.88 1.88 0 01.58 0 1.31 1.31 0 01.28.09 1.3 1.3 0 01.26.14 1.37 1.37 0 01.23.19 1.5 1.5 0 01.44 1.06 1.5 1.5 0 01-1.5 1.5zm-1.5-9.43a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 .02 1.5 1.5 0 01-3 0v-.02zm0-7.93a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.93a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm1.5-6.42a1.5 1.5 0 01-1.06-2.56 1.06 1.06 0 01.23-.19 1.59 1.59 0 01.26-.11l.29-.11a1.42 1.42 0 01.58 0l.28.08.26.14a1.37 1.37 0 01.23.19 1.5 1.5 0 01-1.06 2.56h-.01zM59 41.36a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.32 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.56-1.5h.06zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.32 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm-8.31 0a1.5 1.5 0 111.5 1.5 1.5 1.5 0 01-1.53-1.5h.03zm59.66 1.5a1.49 1.49 0 01-1.38-2.08 1.1 1.1 0 01.14-.26 1.24 1.24 0 01.18-.22 1.52 1.52 0 011.36-.41l.28.08a2 2 0 01.25.14 1.06 1.06 0 01.23.19 1.3 1.3 0 01.19.22c0 .09.1.17.14.26a1.47 1.47 0 01.08.28 1.5 1.5 0 01-.41 1.36 1 1 0 01-.23.18 1.23 1.23 0 01-.25.14 1.41 1.41 0 01-.58.12zm-1.5 53.96a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92c0-.83.67-1.505 1.5-1.51a1.51 1.51 0 011.5 1.53 1.5 1.5 0 01-3 0v-.02zm0-7.93a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.93a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0zm0-7.92a1.5 1.5 0 113 0 1.5 1.5 0 01-3 0z" fill="#DEE4F5" fill-rule="nonzero"/><path fill="#FFF" fill-rule="nonzero" d="M17.64 1.98h91.26v87.55H17.64z"/><path d="M109.75 90.38H98.16c-1.92 0-3.88-.06-5.73 0-.94 0-1.85.1-2.81.1h-2.91c-2-.07-3.95-.17-5.86-.16l-5.68.15-11.38.33c-1.91 0-3.81.13-5.75.1s-3.89-.13-5.83-.17c-1.94-.04-3.85 0-5.75.06s-3.81.17-5.73.19c-3.87-.07-7.72-.14-11.58-.26l-2.88-.08h-8.63a1 1 0 01-1-1c0-3.65-.39-7.29-.17-10.94a45.5 45.5 0 00.23-5.47c-.06-.91-.17-1.83-.18-2.74-.01-.91 0-1.82 0-2.73 0-7.3.21-14.6.16-21.89V40.4c0-1.82.17-3.65.25-5.48.08-1.83.19-3.64.13-5.47-.06-1.83-.24-3.64-.23-5.47 0-3.65.3-7.29.37-10.94.07-3.65 0-7.3-.08-10.95 0-.3.24-.545.54-.55 3.8-.09 7.61 0 11.41 0s7.6 0 11.41.11c1.9 0 3.8.05 5.7 0l5.7-.18c3.81-.16 7.61-.24 11.41-.33 3.8-.09 7.6-.12 11.41-.18 3.81-.06 7.6.21 11.4.26 3.8.05 7.61-.16 11.41-.24 3.8-.08 7.61-.33 11.41-.1h.08A1.19 1.19 0 01110.13 2c0 .93-.06 1.85-.07 2.77l.06 2.76.11 5.54c0 1.85 0 3.69-.12 5.52-.12 1.83-.26 3.64-.27 5.48 0 3.68.16 7.41-.09 11a45.21 45.21 0 00.11 5.56 53.72 53.72 0 010 5.53c-.16 3.62-.25 7.25-.26 10.93-.01 3.68.17 7.47 0 11-.17 3.53 0 7.34.08 11.11.06 1.9 0 3.73.06 5.59.06 1.86.03 3.77.01 5.59zm-1.7-1.7V77.87c.06-3.55.18-7.08-.06-10.85-.1-1.87-.19-3.72-.17-5.51l.11-5.34c0-3.6-.18-7.3-.37-11a36.89 36.89 0 010-5.37 30.52 30.52 0 00.18-5.35 50 50 0 01-.16-5.45c0-1.78.23-3.55.23-5.36v-2.72l-.16-2.73c-.12-1.82-.12-3.62-.09-5.42l.17-5.4.08-2.7V1.95l1.14 1.15c-7.61.32-15.21-.39-22.82-.18-1.9 0-3.8.19-5.7.29-.95.07-1.9.1-2.85.13-.95.03-1.9.05-2.85 0-3.81 0-7.61.05-11.41-.07-3.8-.12-7.6-.09-11.41-.33a94.3 94.3 0 00-11.4-.2c-7.61.32-15.21.48-22.82.38L18.84 2c-.14 3.65-.41 7.3-.25 11 .16 3.7.58 7.29.59 10.94 0 1.83-.34 3.65-.5 5.47a20.89 20.89 0 000 2.74c0 .91.1 1.82.18 2.73a50.41 50.41 0 01.36 5.48c.05 1.82-.05 3.64-.08 5.47l-.14 5.4v5.47l-.08 11v2.73c0 .91-.16 1.83-.24 2.74a43.45 43.45 0 00.14 5.47c.17 3.65-.24 7.29-.28 10.94l-.84-.84c7.56.15 15.12.08 22.67.06l5.67.06c1.89 0 3.79 0 5.65-.07l5.59-.19h5.66l11.4.2 5.7.09c1.89 0 3.72-.1 5.55-.17 1.83-.07 3.73 0 5.67 0h5.66c3.63-.03 7.4-.02 11.13-.04z" fill="#DEE4F5" fill-rule="nonzero"/><g opacity=".5" fill="#DEE4F5" fill-rule="nonzero"><path d="M25.9 9.9h74.75v71.71H25.9z"/><path d="M101.21 82.18H87.06c-1.52 0-3.08.1-4.69 0-1.61-.1-3.21-.09-4.77-.08l-4.65.1-9.34.22c-3.09.12-6.29 0-9.45 0-1.58-.06-3.14 0-4.7 0l-4.7.11c-6.31-.07-12.6-.29-18.86-.25a.7.7 0 01-.71-.69c0-3-.24-6-.11-9a44.71 44.71 0 00.16-4.48c0-.75-.12-1.5-.12-2.24v-2.18c0-6 .14-12 .11-17.93-.03-5.93.57-11.95.1-17.93l.24-9c.06-3 0-6-.05-9 0-.2.16-.365.36-.37 3.11-.06 6.22 0 9.34 0s6.23 0 9.34.07h4.67l4.68-.12c3.11-.1 6.23-.16 9.34-.22 3.11-.06 6.23-.07 9.34-.11 3.11-.04 6.23.11 9.35.15 3.12.04 6.23-.09 9.34-.14 3.11-.05 6.23-.19 9.34-.07h.06a.81.81 0 01.77.82v4.52l.06 4.53c0 1.51 0 3-.08 4.51-.08 1.51-.14 3-.17 4.49 0 3 .1 6 0 9-.07 1.48 0 3 .06 4.53.06 1.53 0 3 0 4.53-.1 3-.16 5.94-.17 8.95-.01 3.01.11 6.09 0 9s0 6 .05 9.08 0 6.17.01 9.2zm-1.13-1.13v-8.88c0-2.88.1-5.85 0-8.9-.1-3.05-.09-6 0-8.9.09-2.9-.11-6-.24-9a40.63 40.63 0 010-4.42 32 32 0 00.12-4.4c-.25-3 0-5.91 0-8.87 0-2.96-.33-6-.18-8.91l.1-4.44V9.88l.77.77c-3.11.12-6.22 0-9.34 0s-6.23-.12-9.34-.08c-3.11.04-6.23.33-9.35.3-3.12-.03-6.23 0-9.34 0-3.11 0-6.23-.08-9.34-.23l-4.68-.17c-1.55-.05-3.11 0-4.67 0-6.23.22-12.46.32-18.68.25l.8-.8c-.1 3-.28 6-.17 9 .11 3 .39 6 .39 9 0 1.5-.22 3-.32 4.48a31.89 31.89 0 00.1 4.48 70.69 70.69 0 01.18 9c-.15 6-.07 11.95-.15 17.93v2.24c0 .74-.11 1.49-.16 2.24a41.87 41.87 0 00.09 4.48c.1 3-.15 6-.18 9l-.56-.56c6.19.1 12.39 0 18.58 0 3.1 0 6.23.11 9.29 0 3.06-.11 6.12-.2 9.24-.11l9.34.14 4.67.06 4.57-.1c1.51-.06 3.07 0 4.65 0h4.64c3.01-.15 6.09-.14 9.17-.15z"/></g><rect fill="#DEE4F5" fill-rule="nonzero" x="34.67" y="23.11" width="22.15" height="24.52" rx="11.02"/><path d="M45.79 48a12.07 12.07 0 01-8.61-3.7 11.11 11.11 0 01-2.42-4.16c-.12-.39-.2-.79-.3-1.18-.1-.39-.12-.79-.18-1.19l-.05-1.21v-1.14c0-.77 0-1.55.07-2.36 0-.4.13-.8.19-1.19l.32-1.16a11.06 11.06 0 012.43-4.08 11.39 11.39 0 013.82-2.78 12.27 12.27 0 014.62-1 11.25 11.25 0 014.61 1 12 12 0 013.88 2.69 11.41 11.41 0 012.43 4.09c.13.37.22.77.32 1.15.1.38.14.79.21 1.19l.07 1.19v1.17c0 .77 0 1.55-.09 2.35-.05.4-.13.8-.19 1.19L56.64 40a10.87 10.87 0 01-2.35 4.14 7.48 7.48 0 01-.86.83 8.26 8.26 0 01-.94.74A10.92 10.92 0 0150.44 47a11.62 11.62 0 01-4.65 1zm0-.79a10.29 10.29 0 007.86-3.64 11.23 11.23 0 002.22-3.81 13 13 0 00.53-4.46v-2.29c-.06-.37-.09-.74-.16-1.11-.07-.37-.19-.73-.31-1.08a10.69 10.69 0 00-2.3-3.82 10.48 10.48 0 00-3.57-2.65 11.27 11.27 0 00-4.37-.78h-1.11a10.6 10.6 0 00-1.11.16 11 11 0 00-2.1.71 10.28 10.28 0 00-3.58 2.61 14.12 14.12 0 00-2.23 3.83 10.22 10.22 0 00-.31 1.12c0 .37-.12.74-.16 1.11-.08.74-.12 1.51-.14 2.29a10.57 10.57 0 002.84 8.34 10.23 10.23 0 008 3.49v-.02z" fill="#DEE4F5" fill-rule="nonzero"/><path fill="#FFF" fill-rule="nonzero" d="M45.74 35.37h28.93v32.02H45.74z"/><path d="M75 67.67c-2.43 0-4.94-.06-7.3 0-2.51-.11-4.87 0-7.29.07-1.21 0-2.41.09-3.65 0-1.24-.09-2.46-.07-3.66 0-2.43.12-4.89-.07-7.32-.07a.36.36 0 01-.36-.36v-4c0-1.33.12-2.67 0-4-.08-2.66 0-5.33 0-8v-4l.09-2c0-.67 0-1.34-.06-2 0-1.33.06-2.66.09-4 .03-1.34 0-2.67 0-4a.2.2 0 01.19-.19h7.23c2.41.08 4.83-.1 7.24-.12h7.24c2.41.11 4.82 0 7.23-.08a.42.42 0 01.43.4c.07 1.35-.09 2.69 0 4s.07 2.71 0 4-.07 2.67 0 4l-.07 2-.03 2.2c0 1.34-.1 2.65-.11 4-.01 1.35.08 2.74 0 4l-.05 2 .05 2.06C75 65 75 66.31 75 67.67zm-.57-.56v-6l-.07-2c-.09-1.37 0-2.61 0-4l-.14-4c0-.66.13-1.27.12-1.94-.01-.67-.06-1.34-.08-2a37.12 37.12 0 000-4c-.09-1.34 0-2.64 0-4 0-1.36-.07-2.65 0-4l.4.4c-2.41 0-4.82-.16-7.23 0l-1.81.07H60.2c-2.41 0-4.83-.29-7.24-.13-2.41.16-4.82.16-7.23.1l.39-.39c0 1.33-.14 2.67-.06 4 .08 1.33.23 2.67.16 4a19.43 19.43 0 00-.16 2c0 .66.09 1.33.14 2 .12 1.33 0 2.66 0 4-.06 2.67 0 5.34-.12 8-.09 1.34.12 2.67 0 4s-.07 2.67-.09 4l-.26-.25h7.19c1.2 0 2.39 0 3.57-.07 1.18-.07 2.38 0 3.58 0 2.4 0 4.85.13 7.17 0 2.45.29 4.76.19 7.15.21h.04z" fill="#FFF" fill-rule="nonzero"/><path d="M80 49.4l-9.76 19 21.65-.7-11.31-18.33a.33.33 0 00-.58.03z" fill="#DEE4F5" fill-rule="nonzero"/><path d="M80.33 49.58c-.82 1.58-1.62 3.17-2.48 4.73l-1.12 2.43-1.2 2.38c-1.68 3.15-3.29 6.32-5 9.45l-.33-.52c1.8 0 3.61 0 5.42-.09s3.61 0 5.41-.13c1.8-.13 3.61-.09 5.41-.16 1.8-.07 3.61-.23 5.41-.3l-.27.51-3-4.71c-1-1.58-1.87-3.2-2.88-4.76-.49-.79-1-1.57-1.47-2.37s-.91-1.62-1.42-2.4l-1.48-2.35-.75-1.18-.35-.54.1.01zm-.7-.36a.74.74 0 01.57-.41.71.71 0 01.66.27c.19.27.27.41.4.63l.74 1.18 1.48 2.36c.48.8 1 1.55 1.52 2.34.52.79 1 1.59 1.44 2.38l2.86 4.78a65.35 65.35 0 001.41 2.4l1.5 2.35a.38.38 0 01-.12.54.33.33 0 01-.19.06l-2.71.13c-.9.08-1.81 0-2.71 0-1.8.09-3.6.29-5.41.31-1.81.02-3.61.13-5.41.14-1.8.01-3.61.26-5.42.17a.43.43 0 01-.41-.45.46.46 0 010-.2c.45-.77.9-1.54 1.29-2.34.39-.8.88-1.55 1.3-2.33.88-1.53 1.58-3.17 2.41-4.77L76 56.37 77.27 54c.73-1.6 1.57-3.19 2.36-4.78z" fill="#DEE4F5" fill-rule="nonzero"/><circle fill="#DEE4F5" fill-rule="nonzero" cx="108.64" cy="88.25" r="19.5"/><path d="M108.64 78.66v19.18m7.18-9.59l-7.18-9.59-7.18 9.59" stroke="#FFF" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"/></g></svg>
';
8901
8902var DropZoneContext = React__default.createContext({
8903 disabled: false,
8904 focused: false,
8905 size: 'extraLarge',
8906 type: 'file',
8907 measuring: false
8908});
8909
8910var styles$M = {
8911 "FileUpload": "Polaris-DropZone-FileUpload",
8912 "Button": "Polaris-DropZone-FileUpload__Button",
8913 "newDesignLanguage": "Polaris-DropZone-FileUpload--newDesignLanguage",
8914 "disabled": "Polaris-DropZone-FileUpload--disabled",
8915 "focused": "Polaris-DropZone-FileUpload--focused",
8916 "sizeSlim": "Polaris-DropZone-FileUpload--sizeSlim",
8917 "ActionTitle": "Polaris-DropZone-FileUpload__ActionTitle",
8918 "ActionTitle-disabled": "Polaris-DropZone-FileUpload__ActionTitle--disabled",
8919 "ActionTitle-focused": "Polaris-DropZone-FileUpload__ActionTitle--focused",
8920 "Image": "Polaris-DropZone-FileUpload__Image",
8921 "sizeExtraLarge": "Polaris-DropZone-FileUpload--sizeExtraLarge",
8922 "sizeLarge": "Polaris-DropZone-FileUpload--sizeLarge"
8923};
8924
8925function FileUpload(props) {
8926 var i18n = useI18n();
8927
8928 var _useFeatures = useFeatures(),
8929 newDesignLanguage = _useFeatures.newDesignLanguage;
8930
8931 var _useContext = useContext(DropZoneContext),
8932 size = _useContext.size,
8933 measuring = _useContext.measuring,
8934 type = _useContext.type,
8935 focused = _useContext.focused,
8936 disabled = _useContext.disabled;
8937
8938 var suffix = capitalize(type);
8939 var _props$actionTitle = props.actionTitle,
8940 actionTitle = _props$actionTitle === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionTitle".concat(suffix)) : _props$actionTitle,
8941 _props$actionHint = props.actionHint,
8942 actionHint = _props$actionHint === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionHint".concat(suffix)) : _props$actionHint;
8943 var imageClasses = classNames(styles$M.Image, size && size === 'extraLarge' && styles$M.sizeExtraLarge, size && size === 'large' && styles$M.sizeLarge);
8944 var buttonStyles = size === 'extraLarge' || size === 'large' ? classNames(styles$M.Button, newDesignLanguage && styles$M.newDesignLanguage, size && size !== 'extraLarge' && styles$M.slim, focused && styles$M.focused, disabled && styles$M.disabled) : null;
8945 var buttonMarkup = (size === 'extraLarge' || size === 'large') && buttonStyles ? React__default.createElement("div", {
8946 className: buttonStyles
8947 }, actionTitle) : null;
8948 var extraLargeView = size === 'extraLarge' ? React__default.createElement(Stack, {
8949 vertical: true
8950 }, type === 'file' && React__default.createElement("img", {
8951 className: imageClasses,
8952 src: fileUpload,
8953 alt: ""
8954 }), type === 'image' && React__default.createElement("img", {
8955 className: imageClasses,
8956 src: imageUpload,
8957 alt: ""
8958 }), buttonMarkup, React__default.createElement(TextStyle, {
8959 variation: "subdued"
8960 }, actionHint)) : null;
8961 var largeView = size === 'large' ? React__default.createElement(Stack, {
8962 vertical: true,
8963 spacing: "tight"
8964 }, type === 'file' && React__default.createElement("img", {
8965 className: imageClasses,
8966 src: fileUpload,
8967 alt: ""
8968 }), type === 'image' && React__default.createElement("img", {
8969 className: imageClasses,
8970 src: imageUpload,
8971 alt: ""
8972 }), buttonMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
8973 variation: "subdued"
8974 }, actionHint))) : null;
8975 var actionTitleClassName = classNames(styles$M.ActionTitle, focused && !disabled && styles$M['ActionTitle-focused'], disabled && styles$M['ActionTitle-disabled']);
8976 var actionTitleMarkup = React__default.createElement("div", {
8977 className: actionTitleClassName
8978 }, actionTitle);
8979 var mediumView = size === 'medium' ? React__default.createElement(Stack, {
8980 vertical: true,
8981 spacing: "tight"
8982 }, actionTitleMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
8983 variation: "subdued"
8984 }, actionHint))) : null;
8985 var smallView = size === 'small' ? React__default.createElement(Stack, {
8986 vertical: true,
8987 spacing: "tight"
8988 }, React__default.createElement(Icon, {
8989 source: DragDropMajorMonotone,
8990 color: "inkLightest"
8991 })) : null;
8992 var fileUploadClassName = classNames(styles$M.FileUpload, newDesignLanguage && styles$M.newDesignLanguage, measuring && styles$M.measuring);
8993 return React__default.createElement("div", {
8994 className: fileUploadClassName
8995 }, smallView, mediumView, largeView, extraLargeView);
8996}
8997
8998var dragEvents = ['dragover', 'dragenter', 'drop'];
8999function fileAccepted(file, accept) {
9000 return file.type === 'application/x-moz-file' || accepts(file, accept);
9001}
9002function getDataTransferFiles(event) {
9003 if (isDragEvent(event) && event.dataTransfer) {
9004 var dt = event.dataTransfer;
9005
9006 if (dt.files && dt.files.length) {
9007 return Array.from(dt.files);
9008 } else if (dt.items && dt.items.length) {
9009 // Chrome is the only browser that allows to read the file list on drag
9010 // events and uses `items` instead of `files` in this case.
9011 return Array.from(dt.items);
9012 }
9013 } else if (isChangeEvent(event) && event.target.files) {
9014 // Return files from even when a file was selected from an upload dialog
9015 return Array.from(event.target.files);
9016 }
9017
9018 return [];
9019}
9020
9021function accepts(file, acceptedFiles) {
9022 if (file && acceptedFiles) {
9023 var fileName = file.name || '';
9024 var mimeType = file.type || '';
9025 var baseMimeType = mimeType.replace(/\/.*$/, '');
9026 var acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(',');
9027 return acceptedFilesArray.some(function (type) {
9028 var validType = type.trim();
9029
9030 if (validType.startsWith('.')) {
9031 return fileName.toLowerCase().endsWith(validType.toLowerCase());
9032 } else if (validType.endsWith('/*')) {
9033 // This is something like a image/* mime type
9034 return baseMimeType === validType.replace(/\/.*$/, '');
9035 }
9036
9037 return mimeType === validType;
9038 });
9039 }
9040
9041 return true;
9042}
9043
9044function isDragEvent(event) {
9045 return dragEvents.indexOf(event.type) > 0;
9046}
9047
9048function isChangeEvent(event) {
9049 return Object.prototype.hasOwnProperty.call(event, 'target');
9050}
9051
9052var styles$N = {
9053 "DropZone": "Polaris-DropZone",
9054 "hasOutline": "Polaris-DropZone--hasOutline",
9055 "isDisabled": "Polaris-DropZone--isDisabled",
9056 "newDesignLanguage": "Polaris-DropZone--newDesignLanguage",
9057 "focused": "Polaris-DropZone--focused",
9058 "isDragging": "Polaris-DropZone--isDragging",
9059 "sizeExtraLarge": "Polaris-DropZone--sizeExtraLarge",
9060 "sizeLarge": "Polaris-DropZone--sizeLarge",
9061 "sizeMedium": "Polaris-DropZone--sizeMedium",
9062 "sizeSmall": "Polaris-DropZone--sizeSmall",
9063 "measuring": "Polaris-DropZone--measuring",
9064 "Container": "Polaris-DropZone__Container",
9065 "Overlay": "Polaris-DropZone__Overlay",
9066 "hasError": "Polaris-DropZone--hasError"
9067};
9068
9069// subcomponents so explicitly state the subcomponents in the type definition.
9070// Letting this be implicit works in this project but fails in projects that use
9071// generated *.d.ts files.
9072
9073var DropZone = function DropZone(_ref) {
9074 var dropOnPage = _ref.dropOnPage,
9075 label = _ref.label,
9076 labelAction = _ref.labelAction,
9077 labelHidden = _ref.labelHidden,
9078 children = _ref.children,
9079 _ref$disabled = _ref.disabled,
9080 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
9081 _ref$outline = _ref.outline,
9082 outline = _ref$outline === void 0 ? true : _ref$outline,
9083 accept = _ref.accept,
9084 active = _ref.active,
9085 _ref$overlay = _ref.overlay,
9086 overlay = _ref$overlay === void 0 ? true : _ref$overlay,
9087 _ref$allowMultiple = _ref.allowMultiple,
9088 allowMultiple = _ref$allowMultiple === void 0 ? true : _ref$allowMultiple,
9089 overlayText = _ref.overlayText,
9090 errorOverlayText = _ref.errorOverlayText,
9091 idProp = _ref.id,
9092 _ref$type = _ref.type,
9093 type = _ref$type === void 0 ? 'file' : _ref$type,
9094 onClick = _ref.onClick,
9095 error = _ref.error,
9096 openFileDialog = _ref.openFileDialog,
9097 onFileDialogClose = _ref.onFileDialogClose,
9098 customValidator = _ref.customValidator,
9099 onDrop = _ref.onDrop,
9100 onDropAccepted = _ref.onDropAccepted,
9101 onDropRejected = _ref.onDropRejected,
9102 onDragEnter = _ref.onDragEnter,
9103 onDragOver = _ref.onDragOver,
9104 onDragLeave = _ref.onDragLeave;
9105
9106 var _useFeatures = useFeatures(),
9107 newDesignLanguage = _useFeatures.newDesignLanguage;
9108
9109 var node = useRef(null);
9110 var dragTargets = useRef([]);
9111 var adjustSize = useCallback(debounce(function () {
9112 if (!node.current) {
9113 return;
9114 }
9115
9116 var size = 'extraLarge';
9117 var width = node.current.getBoundingClientRect().width;
9118
9119 if (width < 100) {
9120 size = 'small';
9121 } else if (width < 160) {
9122 size = 'medium';
9123 } else if (width < 300) {
9124 size = 'large';
9125 }
9126
9127 setSize(size);
9128 measuring && setMeasuring(false);
9129 }, 50, {
9130 trailing: true
9131 }), []);
9132
9133 var _useState = useState(false),
9134 _useState2 = _slicedToArray(_useState, 2),
9135 dragging = _useState2[0],
9136 setDragging = _useState2[1];
9137
9138 var _useState3 = useState(false),
9139 _useState4 = _slicedToArray(_useState3, 2),
9140 internalError = _useState4[0],
9141 setInternalError = _useState4[1];
9142
9143 var _useToggle = useToggle(false),
9144 focused = _useToggle.value,
9145 handleFocus = _useToggle.setTrue,
9146 handleBlur = _useToggle.setFalse;
9147
9148 var _useState5 = useState(0),
9149 _useState6 = _slicedToArray(_useState5, 2),
9150 numFiles = _useState6[0],
9151 setNumFiles = _useState6[1];
9152
9153 var _useState7 = useState('extraLarge'),
9154 _useState8 = _slicedToArray(_useState7, 2),
9155 size = _useState8[0],
9156 setSize = _useState8[1];
9157
9158 var _useState9 = useState(true),
9159 _useState10 = _slicedToArray(_useState9, 2),
9160 measuring = _useState10[0],
9161 setMeasuring = _useState10[1];
9162
9163 var i18n = useI18n();
9164 var getValidatedFiles = useCallback(function (files) {
9165 var acceptedFiles = [];
9166 var rejectedFiles = [];
9167 Array.from(files).forEach(function (file) {
9168 !fileAccepted(file, accept) || customValidator && !customValidator(file) ? rejectedFiles.push(file) : acceptedFiles.push(file);
9169 });
9170
9171 if (!allowMultiple) {
9172 acceptedFiles.splice(1, acceptedFiles.length);
9173 rejectedFiles.push.apply(rejectedFiles, _toConsumableArray(acceptedFiles.slice(1)));
9174 }
9175
9176 return {
9177 files,
9178 acceptedFiles,
9179 rejectedFiles
9180 };
9181 }, [accept, allowMultiple, customValidator]);
9182 var handleDrop = useCallback(function (event) {
9183 stopEvent(event);
9184 if (disabled || !allowMultiple && numFiles > 0) return;
9185 var fileList = getDataTransferFiles(event);
9186
9187 var _getValidatedFiles = getValidatedFiles(fileList),
9188 files = _getValidatedFiles.files,
9189 acceptedFiles = _getValidatedFiles.acceptedFiles,
9190 rejectedFiles = _getValidatedFiles.rejectedFiles;
9191
9192 dragTargets.current = [];
9193 setDragging(false);
9194 setInternalError(rejectedFiles.length > 0);
9195 setNumFiles(function (numFiles) {
9196 return numFiles + acceptedFiles.length;
9197 });
9198 onDrop && onDrop(files, acceptedFiles, rejectedFiles);
9199 onDropAccepted && acceptedFiles.length && onDropAccepted(acceptedFiles);
9200 onDropRejected && rejectedFiles.length && onDropRejected(rejectedFiles);
9201 event.target.value = '';
9202 }, [allowMultiple, disabled, getValidatedFiles, numFiles, onDrop, onDropAccepted, onDropRejected]);
9203 var handleDragEnter = useCallback(function (event) {
9204 stopEvent(event);
9205 if (disabled || !allowMultiple && numFiles > 0) return;
9206 var fileList = getDataTransferFiles(event);
9207
9208 if (event.target && !dragTargets.current.includes(event.target)) {
9209 dragTargets.current.push(event.target);
9210 }
9211
9212 if (dragging) return;
9213
9214 var _getValidatedFiles2 = getValidatedFiles(fileList),
9215 rejectedFiles = _getValidatedFiles2.rejectedFiles;
9216
9217 setDragging(true);
9218 setInternalError(rejectedFiles.length > 0);
9219 onDragEnter && onDragEnter();
9220 }, [allowMultiple, disabled, dragging, getValidatedFiles, numFiles, onDragEnter]);
9221 var handleDragOver = useCallback(function (event) {
9222 stopEvent(event);
9223 if (disabled || !allowMultiple && numFiles > 0) return;
9224 onDragOver && onDragOver();
9225 }, [allowMultiple, disabled, numFiles, onDragOver]);
9226 var handleDragLeave = useCallback(function (event) {
9227 event.preventDefault();
9228 if (disabled || !allowMultiple && numFiles > 0) return;
9229 dragTargets.current = dragTargets.current.filter(function (el) {
9230 var compareNode = dropOnPage && !isServer ? document : node.current;
9231 return el !== event.target && compareNode && compareNode.contains(el);
9232 });
9233 if (dragTargets.current.length > 0) return;
9234 setDragging(false);
9235 setInternalError(false);
9236 onDragLeave && onDragLeave();
9237 }, [allowMultiple, dropOnPage, disabled, numFiles, onDragLeave]);
9238 useEffect(function () {
9239 var dropNode = dropOnPage ? document : node.current;
9240 if (!dropNode) return;
9241 addEventListener(dropNode, 'drop', handleDrop);
9242 addEventListener(dropNode, 'dragover', handleDragOver);
9243 addEventListener(dropNode, 'dragenter', handleDragEnter);
9244 addEventListener(dropNode, 'dragleave', handleDragLeave);
9245 addEventListener(window, 'resize', adjustSize);
9246 return function () {
9247 removeEventListener(dropNode, 'drop', handleDrop);
9248 removeEventListener(dropNode, 'dragover', handleDragOver);
9249 removeEventListener(dropNode, 'dragenter', handleDragEnter);
9250 removeEventListener(dropNode, 'dragleave', handleDragLeave);
9251 removeEventListener(window, 'resize', adjustSize);
9252 };
9253 }, [dropOnPage, handleDrop, handleDragOver, handleDragEnter, handleDragLeave, adjustSize]);
9254 useComponentDidMount(function () {
9255 adjustSize();
9256 });
9257 var id = useUniqueId('DropZone', idProp);
9258 var suffix = capitalize(type);
9259 var overlayTextWithDefault = overlayText === undefined ? i18n.translate("Polaris.DropZone.overlayText".concat(suffix)) : overlayText;
9260 var errorOverlayTextWithDefault = errorOverlayText === undefined ? i18n.translate("Polaris.DropZone.errorOverlayText".concat(suffix)) : errorOverlayText;
9261 var inputAttributes = {
9262 id,
9263 accept,
9264 disabled,
9265 type: 'file',
9266 multiple: allowMultiple,
9267 onChange: handleDrop,
9268 onFocus: handleFocus,
9269 onBlur: handleBlur
9270 };
9271 var classes = classNames(styles$N.DropZone, outline && styles$N.hasOutline, focused && styles$N.focused, (active || dragging) && styles$N.isDragging, disabled && styles$N.isDisabled, newDesignLanguage && styles$N.newDesignLanguage, (internalError || error) && styles$N.hasError, styles$N[variationName('size', size)], measuring && styles$N.measuring);
9272 var dragOverlay = (active || dragging) && (!internalError || !error) && overlay && overlayMarkup(DragDropMajorMonotone, 'indigo', overlayTextWithDefault);
9273 var dragErrorOverlay = dragging && (internalError || error) && overlayMarkup(CircleAlertMajorMonotone, 'red', errorOverlayTextWithDefault);
9274 var labelValue = label || i18n.translate('Polaris.DropZone.FileUpload.label');
9275 var labelHiddenValue = label ? labelHidden : true;
9276 var context = useMemo(function () {
9277 return {
9278 disabled,
9279 focused,
9280 size,
9281 type: type || 'file',
9282 measuring
9283 };
9284 }, [disabled, focused, measuring, size, type]);
9285 return React__default.createElement(DropZoneContext.Provider, {
9286 value: context
9287 }, React__default.createElement(Labelled, {
9288 id: id,
9289 label: labelValue,
9290 action: labelAction,
9291 labelHidden: labelHiddenValue
9292 }, React__default.createElement("div", {
9293 ref: node,
9294 className: classes,
9295 "aria-disabled": disabled,
9296 onClick: handleClick,
9297 onDragStart: stopEvent
9298 }, dragOverlay, dragErrorOverlay, React__default.createElement("div", {
9299 className: styles$N.Container
9300 }, children), React__default.createElement(VisuallyHidden, null, React__default.createElement(DropZoneInput, Object.assign({}, inputAttributes, {
9301 openFileDialog: openFileDialog,
9302 onFileDialogClose: onFileDialogClose
9303 }))))));
9304
9305 function overlayMarkup(icon, color, text) {
9306 var overlayClass = classNames(styles$N.Overlay, newDesignLanguage && styles$N.newDesignLanguage);
9307 return React__default.createElement("div", {
9308 className: overlayClass
9309 }, React__default.createElement(Stack, {
9310 vertical: true,
9311 spacing: "tight"
9312 }, React__default.createElement(Icon, {
9313 source: icon,
9314 color: color
9315 }), size === 'extraLarge' && React__default.createElement(DisplayText, {
9316 size: "small",
9317 element: "p"
9318 }, text), (size === 'medium' || size === 'large') && React__default.createElement(Caption, null, text)));
9319 }
9320
9321 function open() {
9322 var fileInputNode = node.current && node.current.querySelector("#".concat(id));
9323 fileInputNode && fileInputNode instanceof HTMLElement && fileInputNode.click();
9324 }
9325
9326 function handleClick(event) {
9327 if (disabled || !allowMultiple && numFiles > 0) return;
9328 return onClick ? onClick(event) : open();
9329 }
9330};
9331
9332function stopEvent(event) {
9333 event.preventDefault();
9334 event.stopPropagation();
9335}
9336
9337DropZone.FileUpload = FileUpload; // Due to security reasons, browsers do not allow file inputs to be opened artificially.
9338// For example `useEffect(() => { ref.click() })`. Oddly enough react class-based components bi-pass this.
9339
9340var DropZoneInput =
9341/*#__PURE__*/
9342function (_Component) {
9343 _inherits(DropZoneInput, _Component);
9344
9345 function DropZoneInput() {
9346 var _this;
9347
9348 _classCallCheck(this, DropZoneInput);
9349
9350 _this = _possibleConstructorReturn(this, _getPrototypeOf(DropZoneInput).apply(this, arguments));
9351 _this.fileInputNode = React__default.createRef();
9352
9353 _this.triggerFileDialog = function () {
9354 _this.open();
9355
9356 _this.props.onFileDialogClose && _this.props.onFileDialogClose();
9357 };
9358
9359 _this.open = function () {
9360 if (!_this.fileInputNode.current) return;
9361
9362 _this.fileInputNode.current.click();
9363 };
9364
9365 return _this;
9366 }
9367
9368 _createClass(DropZoneInput, [{
9369 key: "componentDidMount",
9370 value: function componentDidMount() {
9371 this.props.openFileDialog && this.triggerFileDialog();
9372 }
9373 }, {
9374 key: "componentDidUpdate",
9375 value: function componentDidUpdate() {
9376 this.props.openFileDialog && this.triggerFileDialog();
9377 }
9378 }, {
9379 key: "render",
9380 value: function render() {
9381 var _a = this.props,
9382 openFileDialog = _a.openFileDialog,
9383 onFileDialogClose = _a.onFileDialogClose,
9384 inputProps = __rest(_a, ["openFileDialog", "onFileDialogClose"]);
9385
9386 return React__default.createElement("input", Object.assign({}, inputProps, {
9387 ref: this.fileInputNode,
9388 autoComplete: "off"
9389 }));
9390 }
9391 }]);
9392
9393 return DropZoneInput;
9394}(Component);
9395
9396var emptySearch = 'data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 178 158"><path d="M9.19 129.84a40.029 40.029 0 01-4.9-7.14C-13.91 88.59 58.08-41.88 135.85 18.43a105.946 105.946 0 018.34 7.18c.32.3.63.6.95.91 87.49 85-82.3 166.28-135.95 103.32z" fill="#f4f6f8"/><path d="M122.6 100.885c-3.367 5.4-7.834 10.765-13.646 13.605-4.287 2.1-14.453 9.75-31.709 7.033-7.56-14.523 40.431-11.323 23.149-32.87-8.072-10.081 13.327-14.12 10.747-23.607-1.756-6.452-12.59-7.41-6.093-19.216 4.174-7.589-4.97-8.194-9.839-10.914a8.439 8.439 0 01-2.96-2.714 25.54 25.54 0 012.624.472c4.609 1.1 9.317 3.624 13.325 6.119 10.881 6.787 14.836 13.414 17.221 19.48 5.775 14.749 5.705 28.951-2.819 42.612z" fill="#fff" opacity=".4"/><path d="M113.7 28.206c-.155.136-.314.272-.469.412-.442.39-.885.79-1.331 1.184a24.1 24.1 0 01-3.642 2.81 19.335 19.335 0 01-4.569.938c-2.405-1.532-7.723-1.4-7.466-4.879.17-2.288 2.3-4.856 4.138-6.343.163-.132.325-.253.48-.367 3.532-2.549 8.26-2.421 12.345-1.66 4.559.847 3.614 5.238.514 7.905z" fill="#afbadd"/><path d="M113.964 28.508c-.823.721-1.72 1.375-2.488 2.179-.955.591-1.7 1.44-2.647 2.077l-.358.248a3.1 3.1 0 01-.465.212 4.157 4.157 0 01-.839.178 9.881 9.881 0 00-1.629.4 9.238 9.238 0 01-1.725.162.813.813 0 01-.222-.036.407.407 0 01-.13-.066l-.039-.027-.156-.109a4.472 4.472 0 00-.344-.179 8.552 8.552 0 00-.733-.307 7.051 7.051 0 01-1.561-.478 1.87 1.87 0 00-.8-.221c-.271-.069-.532-.172-.8-.268a7.825 7.825 0 01-1.552-.752 3.449 3.449 0 01-1.276-1.288 3.967 3.967 0 01-.169-1.789A3.231 3.231 0 0196.5 26.8a17.9 17.9 0 011.856-2.8 12.823 12.823 0 012.494-2.221 9.891 9.891 0 012.94-1.659 10.05 10.05 0 011.644-.428c.561-.083 1.13-.06 1.686-.125s1.119-.113 1.68-.136a5.835 5.835 0 011.679.089c.556.067 1.117.078 1.671.158a15.434 15.434 0 011.643.432 5.7 5.7 0 01.837.276 3.18 3.18 0 01.739.507c.215.21.472.374.691.6a2.122 2.122 0 01.422.829 4.674 4.674 0 01.051 1.788 3.788 3.788 0 01-.53 1.649c-.3.489-.566.992-.884 1.474a7.714 7.714 0 01-1.155 1.275zm-.525-.6a11.277 11.277 0 001.116-1.121 3.609 3.609 0 00.862-1.313c.139-.508.366-.964.476-1.46a2.2 2.2 0 00-.188-1.42c-.1-.209-.222-.389-.317-.6a1.114 1.114 0 00-.422-.571c-.215-.123-.447-.2-.667-.315a5.411 5.411 0 00-.687-.332c-.484-.173-1.071-.083-1.6-.21a13.747 13.747 0 00-1.608-.271c-1.087.031-2.161-.209-3.247-.112a7.8 7.8 0 00-1.582.34c-.519.121-1.04.225-1.545.389a12.371 12.371 0 00-1.5.519 8 8 0 00-1.46.67 16.064 16.064 0 00-2.26 2.3c-.634.839-1.553 1.56-1.742 2.65a5.317 5.317 0 01-.442 1.468.878.878 0 00-.011.725c.1.227.243.4.331.593a2.73 2.73 0 00.933 1.01 8.22 8.22 0 001.411.664c.248.1.509.174.76.28a1.686 1.686 0 00.77.292 5.431 5.431 0 011.575.559c.262.1.523.214.778.344l.38.2.189.109c.119.06-.035 0 .064.019a15.848 15.848 0 001.585-.243 7.626 7.626 0 001.594-.382c.256-.1.513-.191.762-.266a2.726 2.726 0 00.323-.1l.345-.2A10.523 10.523 0 00111 30.14c.878-.666 1.612-1.496 2.439-2.24z" fill="#afbadd"/><g opacity=".4" fill="#7b8ed0"><path d="M113.233 28.618c-.442.39-.885.79-1.331 1.184a24.1 24.1 0 01-3.642 2.81 19.335 19.335 0 01-4.569.938c-2.405-1.532-7.723-1.4-7.466-4.879.17-2.288 2.3-4.856 4.138-6.343a22.668 22.668 0 0112.87 6.29z"/><path d="M113.632 28.631a13.631 13.631 0 01-1.5 1.418c-.24.177-.392.454-.637.628-.23.191-.515.316-.739.515l-1.358 1.2a8.313 8.313 0 01-.738.542 1.518 1.518 0 01-.5.214l-.466.091a4.673 4.673 0 00-.867.274 4.259 4.259 0 01-.883.175c-.6.072-1.19.123-1.8.208l-.243.018h-.143c-.042-.006-.059 0-.123-.012a.546.546 0 01-.134-.052l-.024-.01a3.878 3.878 0 00-.383-.154 3 3 0 01-.745-.408c-.566-.123-1.112-.326-1.677-.507l-1.7-.57c-.6-.144-1.033-.666-1.618-.881a2.267 2.267 0 01-1.125-1.487 3.137 3.137 0 01-.093-1.843 6.373 6.373 0 01.664-1.69c.317-.514.625-1.025.933-1.546a9.7 9.7 0 012.407-2.7l.056-.041a.242.242 0 01.21-.037c1.193.352 2.483.227 3.64.726.575.228 1.2.306 1.76.59a9.046 9.046 0 00.808.466c.278.131.574.226.846.371a3.737 3.737 0 00.8.46 2.415 2.415 0 01.827.414 11.3 11.3 0 001.529 1.038c.557.284.918.825 1.464 1.126.251.179.518.344.752.547a4.143 4.143 0 01.8.917zm-.8-.026a1.227 1.227 0 01-.526-.323c-.228-.191-.419-.425-.635-.634-.4-.457-1.037-.612-1.468-1.029a4.941 4.941 0 00-1.543-.906 1.891 1.891 0 01-.74-.508 2.408 2.408 0 00-.813-.376c-.277-.111-.505-.326-.774-.458a5.153 5.153 0 00-.859-.267c-.57-.174-1.08-.518-1.662-.666-1.166-.214-2.27-.847-3.5-.69l.312-.091c-.821.8-1.65 1.588-2.452 2.427a3.236 3.236 0 00-.952 1.434 9.407 9.407 0 00-.5 1.6 3.674 3.674 0 00-.084 1.563c.211.521.793.607 1.076 1.089a.851.851 0 00.717.4 2.288 2.288 0 01.82.232 11.34 11.34 0 001.644.6 7.444 7.444 0 011.677.67 2.085 2.085 0 01.867.327c.13.09.258.187.382.287-.1-.017-.023.007.043 0l.2-.009a11.281 11.281 0 001.729-.278 15.248 15.248 0 001.709-.408c.134-.056.269-.11.391-.174a2.537 2.537 0 00.317-.2c.249-.146.5-.289.745-.447.489-.314.973-.645 1.435-1.007.229-.185.4-.439.613-.639s.48-.346.685-.559a6.913 6.913 0 011.147-.965z"/></g><path d="M114.8 62.791c.069 21.478-12.181 18.842-31.5 35.187-12.876 10.893-22.7 6.477-24.246-.738a9.648 9.648 0 01-.2-2.524C59.114 89.41 63.6 83.444 74 80.925 84.837 78.3 80.8 59.7 99.645 51.4c.446-.2.9-.386 1.374-.571.206-.082.408-.155.605-.227 9.335-3.37 13.146 1.836 13.176 12.189z" fill="#ffbf4d"/><path d="M115 62.79a33.853 33.853 0 01-1.454 10.5 16.954 16.954 0 01-2.479 4.71l-.821 1.059c-.281.346-.621.638-.929.96s-.627.634-.952.939l-1.035.84a86.132 86.132 0 01-8.861 5.817c-3.025 1.809-5.99 3.706-8.858 5.745-2.891 2.021-5.539 4.31-8.372 6.456a24.684 24.684 0 01-9.54 4.544l-1.315.236-1.336.072a7.27 7.27 0 01-1.336-.047 6.5 6.5 0 01-1.324-.185 9.322 9.322 0 01-7.2-12.221 14.8 14.8 0 016.581-8.086 26.315 26.315 0 014.777-2.308c1.645-.651 3.441-.92 5.022-1.6a9.578 9.578 0 003.861-3.4 28.315 28.315 0 002.484-4.621 82.129 82.129 0 014.587-9.548 27.7 27.7 0 017.029-7.915A30.709 30.709 0 01103 49.993a12.042 12.042 0 015.3-.407 6.6 6.6 0 014.388 2.918 13.525 13.525 0 011.872 4.988 34.034 34.034 0 01.44 5.298zm-.4 0a33.651 33.651 0 00-.436-5.228 13.141 13.141 0 00-1.808-4.838 6.2 6.2 0 00-4.135-2.753 11.546 11.546 0 00-5.115.4 30.787 30.787 0 00-9.334 4.681 27.37 27.37 0 00-6.942 7.795 81.875 81.875 0 00-4.587 9.5 28.644 28.644 0 01-2.526 4.68 9.931 9.931 0 01-4.008 3.509c-1.682.717-3.414.959-5.051 1.6a25.987 25.987 0 00-4.717 2.268 14.406 14.406 0 00-6.451 7.9 9.242 9.242 0 002.41 9.496 9.135 9.135 0 004.567 2.238 6.17 6.17 0 001.278.171 7.443 7.443 0 001.292.047l1.3-.064 1.282-.225a24.31 24.31 0 009.409-4.434c2.789-2.114 5.443-4.493 8.356-6.485 2.88-2.044 5.864-3.938 8.888-5.751a90.007 90.007 0 008.795-5.821l1.021-.827.933-.92c.3-.315.637-.6.912-.939l.8-1.034a16.541 16.541 0 002.429-4.6 33.471 33.471 0 001.438-10.365zM59.313 87.5a3.216 3.216 0 01.768-1.082l.125-.111c.056-.025.13-.034.156-.084l.233-.234c.148-.163.391-.234.544-.388l.837-1.023a1.262 1.262 0 01.533-.388 3.932 3.932 0 00.478-.456l.48.64c-.156.142-.3.3-.46.433s-.4.176-.526.351c-.309.284-.613.573-.892.885-.128.168-.19.394-.379.5-.093.056-.217.085-.307.146-.065.013-.068.08-.09.129l-.133.093a.928.928 0 00-.249.2c-.057.089-.044.232-.117.308-.117.174-.208.365-.338.528z" fill="#ffbf4d"/><path d="M66.4 81.655a29.768 29.768 0 015.723-2.155 9.055 9.055 0 004.912-2.808 12.566 12.566 0 00.916-1.135 9.457 9.457 0 00.846-1.211 33.67 33.67 0 001.376-2.649l2.572-5.459a35.124 35.124 0 016.52-10.208 22.284 22.284 0 014.782-3.79 35.335 35.335 0 015.409-2.813l.294.744a32.514 32.514 0 00-5.275 2.742 24.732 24.732 0 00-4.664 3.657 33.359 33.359 0 00-6.49 9.934c-.815 1.828-1.49 3.723-2.408 5.536a29.577 29.577 0 01-1.5 2.665c-.3.42-.527.877-.818 1.3a11.711 11.711 0 01-.985 1.2 10.023 10.023 0 01-2.426 1.93 10.7 10.7 0 01-1.387.715 13.491 13.491 0 01-1.471.461 28.943 28.943 0 00-5.577 2.062z" fill="#ffbf4d"/><path d="M114.8 62.791c.069 21.478-12.181 18.842-31.5 35.187-12.876 10.893-22.7 6.477-24.246-.738a9.648 9.648 0 01-.2-2.524 19.513 19.513 0 018.464-3.983c4.382-.6 8.975-.258 13.378-1.142 8.387-1.682 19.087-10.365 17.314-19.937-.871-4.7-2.412-8.674-.7-13.451a23.009 23.009 0 012.335-4.8c.446-.2.9-.386 1.374-.571.206-.082.408-.155.605-.227 9.335-3.373 13.146 1.833 13.176 12.186z" fill="#ffaa10" stroke="#ffaa10" stroke-linejoin="round" stroke-width=".5"/><path d="M38.113 84.659a17.265 17.265 0 01-3.207 3.616 29.3 29.3 0 01-3.672 2.708 12.172 12.172 0 01-1.513.813c-3.589 1.645-7.738 1.785-11.093 3.99-2.651 1.744-4.573 5.178-8.181 4.89-3.555-.284-5.276-3.423-4.255-6.653 1.392-4.425 7.477-3.915 10.62-6.528a41.821 41.821 0 004.5-4.871c.318-.374.651-.745.98-1.1a13.673 13.673 0 014.527-3.48 8.036 8.036 0 011.694-.53c4.154-.814 13.564.976 9.6 7.145z" fill="#afbadd"/><path d="M38.449 84.875a21.218 21.218 0 01-3.71 4.029 42.489 42.489 0 01-4.5 3.112 9.975 9.975 0 01-2.56 1.008c-.888.21-1.736.526-2.6.777a25.391 25.391 0 00-5.05 1.587 9.316 9.316 0 00-2.129 1.477q-.53.388-1.055.808c-.347.283-.591.679-.949.962a12.542 12.542 0 01-2.228 1.642 5.768 5.768 0 01-2.73.742 4.9 4.9 0 01-2.719-.709 6.562 6.562 0 01-1.1-.877 4.579 4.579 0 01-.895-1.095 4.991 4.991 0 01-.479-2.738 6.861 6.861 0 01.725-2.65A5.053 5.053 0 018.408 91a11.7 11.7 0 012.49-1.1 22.972 22.972 0 004.9-2.067 10.4 10.4 0 001.958-1.711c.585-.659 1.239-1.265 1.828-1.939 1.2-1.321 2.185-2.859 3.542-4.107a25.649 25.649 0 012.174-1.722 6.88 6.88 0 012.593-1.043 9.208 9.208 0 012.751-.3 22.6 22.6 0 012.738.19 16.555 16.555 0 012.628.821 5.518 5.518 0 012.362 1.489 3.986 3.986 0 011.021 2.677 5.587 5.587 0 01-.944 2.687zm-.673-.433a5.585 5.585 0 00.905-2.3 2.709 2.709 0 00-.11-1.182 2.654 2.654 0 00-.69-.982 8.769 8.769 0 00-2.108-1.363 10.549 10.549 0 00-2.534-.573 12.258 12.258 0 00-5.166-.051 15.61 15.61 0 00-2.319 1.1 8.483 8.483 0 00-2.063 1.588 43.856 43.856 0 00-3.613 3.921 14.958 14.958 0 01-1.722 2.111 9.813 9.813 0 01-2.173 1.761c-1.636 1.007-3.516 1.089-5.138 1.836C9.426 91 7.811 91.8 6.97 93.238a4.409 4.409 0 00-.739 2.385 5.223 5.223 0 00.686 2.347 4.936 4.936 0 00.583 1.077 2.411 2.411 0 001.041.656 8.9 8.9 0 002.385.494c1.666.088 3.124-1.005 4.43-2.158.31-.315.733-.519 1.051-.838s.637-.645.971-.96a12.285 12.285 0 012.374-1.415c3.309-1.59 7.026-1.858 10.145-3.51l1.169-.595q.572-.345 1.131-.709a12.652 12.652 0 002.091-1.645 19 19 0 001.922-1.82 17.684 17.684 0 001.566-2.105z" fill="#afbadd"/><g opacity=".4" fill="#7b8ed0"><path d="M38.113 84.659a17.265 17.265 0 01-3.207 3.616 29.3 29.3 0 01-3.672 2.708 12.172 12.172 0 01-1.513.813c-.219-3.283.363-6.388-.915-9.766a27.018 27.018 0 00-1.982-3.99 8.036 8.036 0 011.694-.53c4.149-.81 13.559.98 9.595 7.149z"/><path d="M38.449 84.875A9.754 9.754 0 0137.575 86c-.349.324-.526.8-.915 1.088-.768.569-1.292 1.377-2.005 2.005a5.826 5.826 0 01-1.153.822c-.4.252-.7.644-1.111.873-.791.5-1.7.846-2.524 1.325a.329.329 0 01-.492-.241l-.007-.057a6.861 6.861 0 01-.117-.905 4.9 4.9 0 00.078-.906 3.01 3.01 0 01-.044-.9l.027-.894a16.832 16.832 0 00-.007-1.774c-.091-.579.146-1.194-.056-1.764a11.114 11.114 0 01-.312-1.736 9.067 9.067 0 00-.648-1.645 26.992 26.992 0 00-.754-1.608 7.528 7.528 0 00-.893-1.543.187.187 0 01.037-.262l.02-.013.04-.022a6.867 6.867 0 014.34-.808 16.341 16.341 0 012.221.065c.7.264 1.477.232 2.172.547a8.526 8.526 0 001.007.517c.174.073.345.152.516.235a4.308 4.308 0 01.453.349c.275.257.7.349.934.681a3.816 3.816 0 01.606 1.012 4.558 4.558 0 01.374 1.125 3.274 3.274 0 01-.132 1.164 6.66 6.66 0 01-.266 1.124 8.992 8.992 0 01-.515 1.021zm-.673-.433a8.223 8.223 0 00.5-.9 3.3 3.3 0 00.391-.931 5.024 5.024 0 00-.038-.971 1.812 1.812 0 00-.217-.912 2.718 2.718 0 00-.65-.7c-.247-.189-.359-.582-.683-.722a2.955 2.955 0 01-.894-.5 2.432 2.432 0 00-.991-.322 7.464 7.464 0 00-2.031-.531 13.353 13.353 0 00-2.1-.307 5.5 5.5 0 00-1.055.149c-.347.059-.693.066-1.033.119a16.474 16.474 0 00-2.017.431l.153-.47a5.717 5.717 0 00.875 1.579 12.219 12.219 0 01.87 1.6c.27.549.294 1.194.541 1.756.224.564.652 1.124.468 1.779-.126.629.386 1.192.292 1.816-.017.612-.045 1.215-.042 1.815l-.023.9A2.952 2.952 0 0130 90a3.345 3.345 0 00.07.885c0 .295-.039.59-.056.887l-.413-.247a13.247 13.247 0 002.378-1.349 11.359 11.359 0 001.129-.793 9.324 9.324 0 011.032-.914c.364-.276.725-.563 1.074-.858a3.983 3.983 0 00.945-.993c.245-.391.661-.632.886-1.037.246-.381.504-.75.731-1.139z"/></g><path d="M144.19 25.61a.249.249 0 01-.07.04 40.521 40.521 0 00-5.49 3.07c-3.1 2.32-3.98 8.05-8.36 8.36-3.21.22-5.72-2.06-5.2-5.4.53-3.39 4.12-4.4 6.32-6.46 2.02-1.9 3.12-4.42 4.46-6.79a105.946 105.946 0 018.34 7.18z" fill="#afbadd"/><path d="M117.855 37.033a50.936 50.936 0 104.265 71.908 50.671 50.671 0 00-4.265-71.908zm9.7 49.638c-2.176 6.892-5.175 13.295-10.012 18.742-4.225 4.753-9.533 9.3-15.739 11.119-3.978 1.17-8.02 2.966-12.134 3.607a45.328 45.328 0 01-8.793.212 44.516 44.516 0 01-26.967-11.164c-8.7-7.729-12.943-17.379-14.446-28.616a37.2 37.2 0 01-.175-10.564c1.225-8.49 5.146-18.036 10.847-24.453 9.9-11.152 27.817-18.735 42.686-14.639a70.674 70.674 0 018.84 2.594c4.36 1.863 8.577 5.138 12.107 8.271a47.943 47.943 0 019.187 10.636 28.155 28.155 0 012.065 3.608 38.5 38.5 0 012.451 7.853c1.472 7.077 2.294 15.799.087 22.794z" fill="#fff"/><path d="M123.3 109.986a51.554 51.554 0 01-16.366 12.306c-1.566.7-3.2 1.231-4.769 1.922l-4.865 1.678c-1.657.441-3.337.814-5.013 1.228l-5.126.741a49.553 49.553 0 01-20.414-2.843 53.8 53.8 0 01-17.667-10.546l-3.663-3.639c-1.125-1.3-2.2-2.649-3.29-3.977-.995-1.4-1.9-2.871-2.844-4.3-.855-1.488-1.6-3.038-2.406-4.552-.7-1.563-1.3-3.176-1.946-4.759-.536-1.625-.978-3.282-1.468-4.92-.368-1.67-.634-3.362-.945-5.038l-.443-5.1c.029-1.7.013-3.406 0-5.106.153-1.694.256-3.394.433-5.085.3-1.675.586-3.356.964-5.012.494-1.628.924-3.277 1.474-4.884.656-1.569 1.259-3.16 1.976-4.7.815-1.49 1.555-3.02 2.409-4.482.957-1.4 1.821-2.861 2.773-4.263l3.146-4a51.384 51.384 0 0116.173-12.133 53.04 53.04 0 014.68-1.977 81.19 81.19 0 014.8-1.689 46.608 46.608 0 014.961-1.22 52.512 52.512 0 015.082-.6 52.467 52.467 0 0137.985 12.772l3.621 3.669c1.113 1.307 2.165 2.666 3.245 4 .993 1.4 1.889 2.862 2.833 4.289.865 1.475 1.656 3 2.485 4.5.736 1.544 1.36 3.143 2.043 4.715.572 1.613 1.045 3.263 1.57 4.9.4 1.666.723 3.351 1.084 5.028.235 1.7.362 3.413.507 5.118l-.061 5.136-.549 5.1c-.311 1.677-.571 3.368-.929 5.035-.481 1.638-.88 3.3-1.393 4.931a52.326 52.326 0 01-10.087 17.757zm-2.355-2.091a49.581 49.581 0 009.634-16.655c.5-1.531.881-3.1 1.331-4.645.334-1.574.573-3.17.869-4.751.15-1.6.187-3.216.29-4.816l-.169-4.81c-.22-1.59-.416-3.176-.568-4.77-.318-1.567-.595-3.146-.939-4.71-.468-1.531-.894-3.077-1.387-4.6-.609-1.481-1.156-2.994-1.811-4.459a48.272 48.272 0 00-11.455-15.394 43.92 43.92 0 00-16.507-9.921 49.953 49.953 0 00-19.106-2.355 49.17 49.17 0 00-4.789.586c-1.59.245-3.172.523-4.768.8a30.928 30.928 0 00-9.134 3.212 53.434 53.434 0 00-14.987 12.006c-1.018 1.235-2.083 2.436-3.123 3.665a75.328 75.328 0 00-2.719 3.983c-.783 1.4-1.478 2.857-2.209 4.288-.642 1.472-1.155 3-1.756 4.488-.508 1.522-.9 3.083-1.362 4.621-.35 1.567-.584 3.159-.934 4.731-.211 1.593-.347 3.2-.5 4.8-.02.8 0 1.611 0 2.416l.083 2.414.722 4.77c.368 1.563.689 3.131 1 4.7l.659 2.313c.216.772.381 1.565.638 2.326.573 1.5 1.093 3.03 1.716 4.52.724 1.438 1.372 2.933 2.222 4.307.918 1.332 1.785 2.7 2.74 4 1.014 1.258 1.966 2.574 2.993 3.834l3.354 3.551a44.023 44.023 0 0016.748 9.875 51.158 51.158 0 0019.251 2.326l4.845-.446c1.592-.31 3.2-.581 4.786-.918 1.551-.479 3.144-.848 4.669-1.413 1.481-.679 2.987-1.3 4.429-2.039a50.929 50.929 0 0015.242-11.83zm6.889 3.705c2.9 2.347 5.764 4.74 8.44 7.343 1.346 1.292 2.6 2.684 3.975 3.947 1.35 1.288 2.795 2.469 4.251 3.637s2.9 2.345 4.267 3.619 2.7 2.577 4.049 3.864c.667.653 1.4 1.237 2.093 1.855l2.2 1.737c.742.568 1.417 1.213 2.121 1.824s1.4 1.235 2.065 1.887a1.8 1.8 0 01-2.344 2.732l-.049-.037c-.748-.562-1.47-1.152-2.187-1.749s-1.454-1.171-2.142-1.8c-.706-.609-1.38-1.254-2.062-1.89s-1.316-1.326-2.023-1.934c-2.809-2.452-5.6-4.921-8.236-7.572-1.326-1.315-2.655-2.626-4.061-3.85s-2.852-2.4-4.264-3.622c-1.451-1.173-2.7-2.572-4.085-3.824a41.242 41.242 0 00-4.4-3.47 1.8 1.8 0 012-3q.068.046.131.1z" fill="#081140"/><path d="M170 141.818a6.943 6.943 0 01-1.67 4.385c-1.1 1.46-3.268 5.083-5.06 5.622-2.693.808-6.5-2.746-8.317-4.1-4.675-3.484-4.406-3.024-8.676-6.982-4.31-4-8.529-8.089-12.778-12.15-2.3-2.193-9.253-5.883-7.318-10.134.976-2.11 4.873-5.129 6.7-6.493 5.832-4.361 17.145 10.183 20.986 13.593 4.555 4.044 4.528 3.648 9.082 7.692 2.831 2.518 6.929 4.975 7.051 8.567z" fill="#081140"/><path d="M170.194 141.811a6.639 6.639 0 01-1.176 3.735 214.25 214.25 0 01-2.237 3.16 14.212 14.212 0 01-2.631 2.89 2.92 2.92 0 01-1.948.565 5.578 5.578 0 01-1.936-.5c-2.429-1.082-4.292-2.945-6.365-4.425a64.637 64.637 0 01-6.075-4.785c-3.777-3.5-7.449-7.1-11.167-10.664a56.533 56.533 0 00-5.759-5.106 29.091 29.091 0 01-2.942-2.517 7.627 7.627 0 01-2.105-3.252 3.6 3.6 0 01.024-1.967 5.054 5.054 0 01.954-1.713 21.384 21.384 0 012.729-2.751c.973-.848 1.993-1.636 3.012-2.423a4.44 4.44 0 013.712-.968 10.841 10.841 0 013.621 1.433 26.348 26.348 0 013.173 2.234 67.611 67.611 0 015.662 5.269l2.673 2.786c.885.932 1.753 1.882 2.7 2.73 1.894 1.743 3.911 3.322 5.911 4.951 1 .817 1.958 1.676 2.915 2.537s1.966 1.645 2.96 2.467a19.364 19.364 0 012.79 2.707 6.186 6.186 0 011.505 3.607zm-.393.013a5.8 5.8 0 00-1.407-3.387 18.783 18.783 0 00-2.73-2.656c-.985-.819-2.007-1.606-2.985-2.457l-2.93-2.5c-1.98-1.625-3.99-3.261-5.9-4.987-1.918-1.76-3.588-3.709-5.383-5.551a59.668 59.668 0 00-5.618-5.253 25.985 25.985 0 00-3.131-2.2 10.484 10.484 0 00-3.494-1.381 4.14 4.14 0 00-3.476.833 44.002 44.002 0 00-2.986 2.421 21.075 21.075 0 00-2.659 2.731 3.778 3.778 0 00-.9 3.378 7.133 7.133 0 001.992 3.108 28.779 28.779 0 002.923 2.468 28.426 28.426 0 012.995 2.467l2.785 2.671c3.8 3.467 7.4 7.157 11.184 10.632.943.873 1.9 1.72 2.923 2.5s2.08 1.511 3.114 2.277c2.106 1.481 3.98 3.316 6.314 4.341 1.126.488 2.5.787 3.514.015a11.752 11.752 0 002.556-2.8l2.2-3.157a6.259 6.259 0 001.098-3.513z" fill="#081140"/><path d="M141.752 114.062a35.54 35.54 0 01-2.726 3.123 23.714 23.714 0 00-2.84 3.023 30.066 30.066 0 01-2.792 3.065 15.566 15.566 0 00-1.321 1.6 21.737 21.737 0 01-1.381 1.546.9.9 0 01-1.369-1.17l.008-.011a25.653 25.653 0 012.741-3.119c.911-1.042 1.831-2.076 2.842-3.03a33.437 33.437 0 002.792-3.074 20.231 20.231 0 002.7-3.153.9.9 0 111.559.91.913.913 0 01-.063.094zm14.987 35.114a39.212 39.212 0 012.2-3.359 26.856 26.856 0 002.37-3.3 19.142 19.142 0 012.506-3.239c.467-.5.871-1.063 1.3-1.609a13.28 13.28 0 011.469-1.476.9.9 0 011.263 1.279l-.036.041a94.868 94.868 0 01-2.642 2.884c-.825 1.022-1.611 2.082-2.475 3.1a25.643 25.643 0 00-2.285 3.3 21.073 21.073 0 00-2.191 3.407.9.9 0 11-1.611-.807z" fill="#ffc757"/><path d="M38.834 67.691c.44-2.779 1.386-5.409 1.942-8.173a43.89 43.89 0 013.424-7.672 33.5 33.5 0 012.236-3.563A30.9 30.9 0 0149.063 45c.931-1.048 1.844-2.1 2.869-3.053l3.129-2.767a44.949 44.949 0 013.362-2.467c1.181-.728 2.2-1.728 3.419-2.4l1.8-1.063 1.862-.961c1.264-.59 2.5-1.259 3.822-1.731.669-.21 1.323-.461 2-.628s1.349-.371 2.013-.593a31.924 31.924 0 014.086-.962c.691-.118 1.393-.158 2.089-.227.692-.106 1.384-.2 2.082-.262 1.392-.181 2.8-.229 4.2-.277a.787.787 0 11.053 1.572h-.1c-1.349.02-2.7.036-4.039.185a19.136 19.136 0 00-3.98.705c-.651.177-1.326.232-1.981.393l-1.978.433a40.033 40.033 0 00-3.875 1.2 28.779 28.779 0 00-7.327 3.5 10.6 10.6 0 01-1.77 1 5 5 0 00-.921.451c-.278.2-.544.409-.816.612-1.083.826-2.024 1.822-3.087 2.648-.531.415-1.109.78-1.618 1.225l-1.424 1.427c-.5.454-.926.979-1.42 1.441a10.258 10.258 0 00-1.347 1.5 25.123 25.123 0 01-2.435 3.228 11.243 11.243 0 00-1.122 1.693c-.4.552-.765 1.126-1.153 1.69a32.736 32.736 0 00-3.112 7.544 19.283 19.283 0 00-1.21 3.9 71.333 71.333 0 00-.749 4 .787.787 0 01-1.556-.239zm82.905 34.26l-1.854 2.309a21.091 21.091 0 01-1.946 2.215l-1.052 1.03c-.347.347-.661.727-1 1.083q-1 1.084-2.077 2.116a29.085 29.085 0 01-10.324 5.907l-5.541 1.714a46.5 46.5 0 01-5.678 1.516c-.971.17-1.942.377-2.928.487a28.531 28.531 0 01-2.947.149c-.98 0-1.956-.032-2.93-.083s-1.942-.045-2.923-.119a38.862 38.862 0 01-5.8-.867 51.547 51.547 0 01-5.709-1.4 47 47 0 01-10.6-5.118c-1.613-1.14-3.1-2.436-4.6-3.7a36.25 36.25 0 01-4.174-4.171 51.205 51.205 0 01-1.777-2.359c-.6-.78-1.161-1.586-1.719-2.4a43.318 43.318 0 01-2.99-5.1.787.787 0 111.407-.706v.006l.016.032a41.546 41.546 0 002.811 4.953 38.9 38.9 0 001.653 2.316c.6.738 1.252 1.427 1.889 2.126 1.287 1.385 2.561 2.787 3.957 4.078a40.427 40.427 0 004.454 3.547 33.8 33.8 0 0010.162 5.088c1.841.451 3.537 1.467 5.454 1.67 1.882.319 3.788.391 5.669.535.933.11 1.9.241 2.856.264s1.911.01 2.86-.021c.949-.011 1.89-.082 2.823-.147a12.327 12.327 0 002.761-.467c.906-.259 1.789-.6 2.712-.836.915-.263 1.856-.473 2.787-.738.944-.226 1.846-.586 2.775-.887.925-.273 1.931-.474 2.826-.722 3.706-.949 6.833-3.357 9.7-5.817.741-.6 1.473-1.213 2.18-1.858a15.976 15.976 0 001.978-2.076c1.292-1.425 2.376-2.985 3.559-4.472l.05-.063a.786.786 0 011.231.979zM40.218 87.414a4.71 4.71 0 01-.454-1.554 3.573 3.573 0 00-.251-1.6 3.928 3.928 0 01-.271-1.59 2.486 2.486 0 00-.219-.78 3.182 3.182 0 01-.13-.8.9.9 0 011.734-.384l.047.11a3.779 3.779 0 01.295 1.539 6.937 6.937 0 01.2 1.556 4.025 4.025 0 00.312 1.536 4.251 4.251 0 01.116.778 1.685 1.685 0 00.356.716.91.91 0 11-1.51.981z" fill="#081140"/><path d="M25.3 123.627c-1.723 3.553-5.114 4.233-8.592 4.616a71.637 71.637 0 00-7.521 1.6 39.931 39.931 0 01-4.893-7.143c1.855-.5 3.829-1.082 4.366-1.307 4.953-2.1 7.736-6.837 12.492-9.118 1.375-.663 4.437-1.15 5.755-.075 2.081 1.7-1.3 10.783-1.607 11.427z" fill="#afbadd"/><path d="M80.475 58.995c-.4-.838-.838-1.66-1.258-2.5a14.631 14.631 0 00-1.407-2.436c-.554-.76-1.067-1.545-1.59-2.327a11.079 11.079 0 00-.887-1.095c-.307-.355-.588-.73-.891-1.087a.45.45 0 01.667-.6l.018.019a15.862 15.862 0 011.8 2.245 22.023 22.023 0 011.6 2.388c.471.834.979 1.644 1.468 2.47.244.414.429.859.639 1.291s.43.86.676 1.282a.451.451 0 01-.779.455l-.017-.032zm-3.007 4.06a19.547 19.547 0 01-7.725-5.566 10.133 10.133 0 01-1.307-2.078 3.55 3.55 0 01-.29-2.594 2.665 2.665 0 01.811-1.117 3.416 3.416 0 011.2-.577 3.639 3.639 0 012.581.241 1.9 1.9 0 01.578.455 2.566 2.566 0 01.377.58 2 2 0 01.153 1.445 3.049 3.049 0 01-1.955 1.8 8.317 8.317 0 01-4.885.095 9.693 9.693 0 01-4.232-2.388 9.922 9.922 0 01-2.46-4.185.451.451 0 11.86-.27 8.835 8.835 0 006.052 5.989 7.443 7.443 0 004.333-.11A2.245 2.245 0 0073 53.595a1.129 1.129 0 00-.078-.833 1.74 1.74 0 00-.25-.406 1.08 1.08 0 00-.335-.27c-1.121-.618-3.042-.27-3.441 1a2.758 2.758 0 00.3 1.969 9.276 9.276 0 001.234 1.867 18.31 18.31 0 003.337 3.131 18.509 18.509 0 004.033 2.166.451.451 0 01-.324.841zm-.868 3.526c-1.212-.345-2.468-.595-3.722-.954a47.74 47.74 0 01-1.863-.613 18.516 18.516 0 00-1.846-.5 31.551 31.551 0 01-3.746-1.046c-.618-.215-1.248-.4-1.87-.638a9.847 9.847 0 01-1.785-.934.45.45 0 01.471-.767l.027.016a20.866 20.866 0 003.421 1.486c1.21.382 2.46.674 3.7 1.063 1.254.36 2.482.806 3.713 1.08.623.146 1.239.336 1.867.5s1.263.309 1.91.453a.451.451 0 01-.2.88l-.025-.006z" fill="#22266d"/><path d="M80.527 58.973c-.214-.412-.272-.9-.658-1.234-.252-.394-.388-.849-.608-1.264s-.4-.851-.578-1.293c-.1-.215-.25-.4-.349-.615a2.694 2.694 0 00-.364-.607c-.136-.193-.238-.408-.37-.6-.094-.222-.367-.321-.481-.528-.3-.366-.591-.735-.9-1.092a6.893 6.893 0 00-.819-1.15 3.892 3.892 0 00-.913-1.072.392.392 0 01.563-.546l.036.036a8.728 8.728 0 001 1.044c.3.372.52.81.805 1.194a3.988 3.988 0 00.853 1.154c.208.148.126.493.342.635a3.508 3.508 0 01.505.527 14.822 14.822 0 011.3 2.571 5.929 5.929 0 00.73 1.24 7.98 7.98 0 00.64 1.3.393.393 0 01-.713.329z" fill="#ffc657"/><path d="M80.12 59.164a23.381 23.381 0 00-1.509-2.833A25.918 25.918 0 0077 53.638c-.3-.446-.587-.9-.867-1.364-.274-.476-.6-.85-.892-1.3-.311-.427-.683-.824-1-1.258a.691.691 0 01.223-1.048.72.72 0 01.58-.027.7.7 0 01.24.164l.144.143a15.18 15.18 0 011.036 1.256c.3.461.726.809 1.006 1.274.605.89 1.3 1.756 1.844 2.667.464.965 1.086 1.834 1.528 2.844a9.254 9.254 0 00.709 1.422.861.861 0 01.135.615.8.8 0 01-.4.561.824.824 0 01-1.006-.17 1.167 1.167 0 01-.16-.253zm.711-.339c.039.081.045.082.045.082a.043.043 0 00.02.01.043.043 0 00.04-.007.037.037 0 00.017-.032.055.055 0 000-.016l-.041-.074-.393-.718c-.14-.231-.307-.465-.43-.689-.272-.452-.419-.948-.7-1.418-.246-.479-.526-.937-.787-1.406A14.829 14.829 0 0076.86 51.9c-.375-.381-.453-.991-.85-1.338-.354-.388-.752-.732-1.113-1.106-.046-.047-.081-.1-.122-.154-.022-.031.008-.013.005-.024s0-.031 0-.022.01.015.011 0c.354.4.626.856 1 1.255a4.251 4.251 0 01.98 1.326 5.083 5.083 0 00.427.677l.383.709a10.684 10.684 0 00.9 1.351 12 12 0 01.872 1.39 27.758 27.758 0 001.477 2.861zM77.489 63a34.466 34.466 0 01-4.208-2.27 17.26 17.26 0 01-3.49-3.281 9.373 9.373 0 01-1.284-2.072 3.39 3.39 0 01-.226-2.516 2.688 2.688 0 01.758-1.061 2.958 2.958 0 011.154-.541 3.827 3.827 0 012.458.26 1.911 1.911 0 01.858.964 1.774 1.774 0 01.115 1.293 2.969 2.969 0 01-1.788 1.728 8.329 8.329 0 01-4.828.227 9.785 9.785 0 01-4.172-2.44 10.216 10.216 0 01-.758-.951 9.495 9.495 0 01-.682-1 12.265 12.265 0 01-1.027-2.19.393.393 0 01.736-.278v.006l.013.036a8.543 8.543 0 002.325 3.774 11.354 11.354 0 001.725 1.375 7.729 7.729 0 002.044.867 6.394 6.394 0 004.356-.122c.331-.139.618-.325.926-.471a1.041 1.041 0 00.561-.729 1.463 1.463 0 00-.759-1.453 2.391 2.391 0 00-1.929-.207 1.83 1.83 0 00-1.411 1.155 4.029 4.029 0 00.248 1.947 4.323 4.323 0 00.53.979c.173.334.4.645.605.966a13.711 13.711 0 003.425 3.061 14.793 14.793 0 004.016 2.212.394.394 0 01-.294.73z" fill="#ffc657"/><path d="M77.321 63.421a21.987 21.987 0 01-8.021-5.733 10.135 10.135 0 01-1.342-2.172 3.944 3.944 0 01-.3-2.684 3.1 3.1 0 011.915-1.977 4.263 4.263 0 012.666-.141 2.968 2.968 0 011.242.664 2.86 2.86 0 01.421.569 2.155 2.155 0 01.317.636 2.316 2.316 0 01-.017 1.447 2.817 2.817 0 01-.789 1.149 4.982 4.982 0 01-2.37 1.054 8.183 8.183 0 01-2.517.067 10.01 10.01 0 01-4.643-1.718 10.134 10.134 0 01-3.647-4.928 2 2 0 01-.165-.685.68.68 0 011.318-.163l.2.57a10.162 10.162 0 00.493 1.082 8.52 8.52 0 003.276 3.324 7.859 7.859 0 004.488 1 5.178 5.178 0 002.158-.623 1.385 1.385 0 00.63-.67.865.865 0 00-.208-.778c-.667-.919-3.115-.665-3.233.7a3.54 3.54 0 00.654 2.051 15.354 15.354 0 001.433 1.873 14.676 14.676 0 003.62 3.071 17.019 17.019 0 002.12 1.1l.551.228.278.107a.952.952 0 01.4.247.834.834 0 01.068 1.036.844.844 0 01-.996.297zm.293-.731a.054.054 0 00.064-.084c.06.014-.22-.087-.4-.161l-.573-.243a18.965 18.965 0 01-2.2-1.158 16.568 16.568 0 01-2.025-1.453 18.164 18.164 0 01-1.847-1.678A10.786 10.786 0 0169.1 55.9a4.267 4.267 0 01-.72-2.607 2.116 2.116 0 01.761-1.309 2.886 2.886 0 011.3-.572 3.347 3.347 0 011.383.031 2.741 2.741 0 01.668.246 1.35 1.35 0 01.589.532 1.65 1.65 0 01.281 1.509 2.133 2.133 0 01-.994 1.064 6.592 6.592 0 01-2.483.7 8.547 8.547 0 01-4.919-1.076 9.605 9.605 0 01-3.421-3.684 10.767 10.767 0 01-.555-1.134l-.222-.576c-.008-.009-.027-.007-.023 0-.1-.313.337.842.615 1.461a8.531 8.531 0 001.191 1.977 8.7 8.7 0 001.727 1.526 9.1 9.1 0 004.311 1.589 9.3 9.3 0 002.281-.15 4.374 4.374 0 002.016-.824 1.817 1.817 0 00.589-.824 1.547 1.547 0 00-.007-.963 1.6 1.6 0 00-.22-.463 2.241 2.241 0 00-.289-.438 2.172 2.172 0 00-.919-.52c-1.392-.462-3.305.171-3.678 1.633a3.31 3.31 0 00.328 2.171 9.38 9.38 0 001.26 1.973 17.923 17.923 0 007.664 5.518zm-.997 3.837a6.123 6.123 0 00-1.858-.435c-.633-.107-1.239-.348-1.868-.514a12.409 12.409 0 01-1.837-.685c-.294-.124-.612-.179-.91-.3a4.716 4.716 0 00-.925-.269c-.313-.075-.617-.186-.93-.265-.3-.128-.656-.042-.962-.152-.631-.145-1.27-.275-1.9-.445-.593-.289-1.235-.437-1.836-.718-.556-.372-1.2-.548-1.788-.9a.393.393 0 01.395-.679l.041.023a6.174 6.174 0 001.688.767c.579.226 1.141.53 1.749.718a6.475 6.475 0 001.845.515c.335-.014.579.326.916.309a6.092 6.092 0 01.971.115 3.5 3.5 0 00.931.293c.32.073.613.231.936.3a1.811 1.811 0 01.9.313 1.7 1.7 0 00.452.157l.441.207a9.19 9.19 0 001.893.4 18.258 18.258 0 001.9.49.393.393 0 01-.221.755z" fill="#ffc657"/><path d="M76.492 66.96c-1.375-.339-2.709-.775-4.126-1-1.4-.44-2.647-.872-4.028-1.2a27.814 27.814 0 01-4.046-1.383c-.328-.143-.665-.227-1.005-.362a7.684 7.684 0 01-.972-.49l-.458-.289-.227-.155a.676.676 0 01-.24-.31.7.7 0 01.148-.731.683.683 0 01.739-.154 16.49 16.49 0 001.893.942 15.976 15.976 0 002.007.622l4.088 1.082c.673.224 1.322.5 2 .668s1.36.3 2.038.522c.338.1.674.229 1.014.315l1.03.222.515.111a.95.95 0 01.372.137.812.812 0 01.118 1.25.862.862 0 01-.86.203zm.216-.757c.142.043.111-.031.111-.055a.05.05 0 00-.018-.018.6.6 0 00-.1-.024l-.519-.117c-.689-.169-1.391-.3-2.077-.435-1.345-.33-2.767-.794-4.08-1.233a34.636 34.636 0 00-4.08-1.167c-.725-.1-1.289-.626-1.99-.791-.338-.12-.686-.225-1.022-.365l-.506-.214-.251-.117-.12-.068c-.048-.029-.079-.046-.059-.036.062-.01.006-.069.01-.041h.005l.21.129.444.247a8.2 8.2 0 001.879.8 9.842 9.842 0 011.972.7 6.708 6.708 0 001 .319l.995.34c1.341.425 2.8.673 4.106 1.1a39.164 39.164 0 004.09 1.043z" fill="#ffc657"/><path d="M68.1 44.906c.036-.293-.233-.576-.451-.473a.515.515 0 00-.09.727c.182.191.5.039.541-.254" fill="#ffc757"/><path d="M67.707 44.857c-.038-.032-.159.023-.022-.015a.31.31 0 00.05-.014c.021-.027.03-.076.045-.068.027-.013.038-.032.035-.038s-.144-.008-.154.065c0 .154.2.219.12.082-.05-.077-.077.018-.029.039.01-.007 0-.041-.045-.051a.656.656 0 11.809-.625l-.015.724a.772.772 0 01-.229.551c-.166.161-.429.121-.656.113a.7.7 0 01-.5-.415 1.085 1.085 0 01-.082-.5c0-.155-.054-.392.172-.547a.766.766 0 01.4-.091c.069.025.124-.023.19-.031a.45.45 0 01.159.078 2.412 2.412 0 01.193.2c.063.043.191.052.223.137a.7.7 0 01.133.506.294.294 0 01-.477.17zm4.1 1.343c.067-.553-.507-1.1-.962-.921a.9.9 0 00-.167 1.372.687.687 0 001.129-.451" fill="#ffc757"/><path d="M71.41 46.154c-.022-.188-.242-.324-.325-.455l-.038-.035c-.008-.029-.027-.078-.041-.062a.172.172 0 00-.093.025c-.055.042-.241.124-.263.29-.012.33.245.589.4.523.072-.05.153.005.273-.022a.232.232 0 00.086-.263.416.416 0 11.806-.127l-.011.224a1.1 1.1 0 01-.415.809 1.258 1.258 0 01-.9.13 1.039 1.039 0 01-.712-.552 1.48 1.48 0 01-.149-.8.912.912 0 01.338-.829.986.986 0 01.528-.111c.086.026.162-.016.245-.021a.762.762 0 01.211.094 2.886 2.886 0 01.309.257c.1.068.259.106.323.228a1.092 1.092 0 01.225.8.4.4 0 01-.785-.015z" fill="#ffc757"/></svg>
';
9397
9398var styles$O = {
9399 "Image": "Polaris-EmptySearchResult__Image"
9400};
9401
9402function EmptySearchResult(_ref) {
9403 var title = _ref.title,
9404 description = _ref.description,
9405 withIllustration = _ref.withIllustration;
9406 var i18n = useI18n();
9407 var altText = i18n.translate('Polaris.EmptySearchResult.altText');
9408 var descriptionMarkup = description ? React__default.createElement("p", null, description) : null;
9409 var illustrationMarkup = withIllustration ? React__default.createElement(Image, {
9410 alt: altText,
9411 source: emptySearch,
9412 className: styles$O.Image,
9413 draggable: false
9414 }) : null;
9415 return React__default.createElement(Stack, {
9416 alignment: "center",
9417 vertical: true
9418 }, illustrationMarkup, React__default.createElement(DisplayText, {
9419 size: "small"
9420 }, title), React__default.createElement(TextStyle, {
9421 variation: "subdued"
9422 }, descriptionMarkup));
9423}
9424
9425var styles$P = {
9426 "EmptyState": "Polaris-EmptyState",
9427 "Section": "Polaris-EmptyState__Section",
9428 "ImageContainer": "Polaris-EmptyState__ImageContainer",
9429 "DetailsContainer": "Polaris-EmptyState__DetailsContainer",
9430 "withinContentContainer": "Polaris-EmptyState--withinContentContainer",
9431 "Details": "Polaris-EmptyState__Details",
9432 "Image": "Polaris-EmptyState__Image",
9433 "Content": "Polaris-EmptyState__Content",
9434 "withinPage": "Polaris-EmptyState--withinPage",
9435 "imageContained": "Polaris-EmptyState--imageContained",
9436 "Actions": "Polaris-EmptyState__Actions",
9437 "FooterContent": "Polaris-EmptyState__FooterContent"
9438};
9439
9440function EmptyState(_ref) {
9441 var children = _ref.children,
9442 heading = _ref.heading,
9443 image = _ref.image,
9444 largeImage = _ref.largeImage,
9445 imageContained = _ref.imageContained,
9446 action = _ref.action,
9447 secondaryAction = _ref.secondaryAction,
9448 footerContent = _ref.footerContent;
9449 var withinContentContainer = useContext(WithinContentContext);
9450 var className = classNames(styles$P.EmptyState, imageContained && styles$P.imageContained, withinContentContainer ? styles$P.withinContentContainer : styles$P.withinPage);
9451 var imageMarkup = largeImage ? React__default.createElement(Image, {
9452 alt: "",
9453 role: "presentation",
9454 className: styles$P.Image,
9455 source: largeImage,
9456 sourceSet: [{
9457 source: image,
9458 descriptor: '568w'
9459 }, {
9460 source: largeImage,
9461 descriptor: '1136w'
9462 }],
9463 sizes: "(max-width: 568px) 60vw"
9464 }) : React__default.createElement(Image, {
9465 role: "presentation",
9466 alt: "",
9467 className: styles$P.Image,
9468 source: image
9469 });
9470 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
9471 plain: true
9472 }) : null;
9473 var footerContentMarkup = footerContent ? React__default.createElement("div", {
9474 className: styles$P.FooterContent
9475 }, React__default.createElement(TextContainer, null, footerContent)) : null;
9476 var headingSize = withinContentContainer ? 'small' : 'medium';
9477 var primaryActionSize = withinContentContainer ? 'medium' : 'large';
9478 var primaryActionMarkup = action ? buttonFrom(action, {
9479 primary: true,
9480 size: primaryActionSize
9481 }) : null;
9482 var headingMarkup = heading ? React__default.createElement(DisplayText, {
9483 size: headingSize
9484 }, heading) : null;
9485 var childrenMarkup = children ? React__default.createElement("div", {
9486 className: styles$P.Content
9487 }, children) : null;
9488 var textContentMarkup = headingMarkup || children ? React__default.createElement(TextContainer, null, headingMarkup, childrenMarkup) : null;
9489 var actionsMarkup = primaryActionMarkup || secondaryActionMarkup ? React__default.createElement("div", {
9490 className: styles$P.Actions
9491 }, React__default.createElement(Stack, {
9492 alignment: "center"
9493 }, primaryActionMarkup, secondaryActionMarkup)) : null;
9494 var detailsMarkup = textContentMarkup || actionsMarkup || footerContentMarkup ? React__default.createElement("div", {
9495 className: styles$P.DetailsContainer
9496 }, React__default.createElement("div", {
9497 className: styles$P.Details
9498 }, textContentMarkup, actionsMarkup, footerContentMarkup)) : React__default.createElement("div", {
9499 className: styles$P.DetailsContainer
9500 });
9501 return React__default.createElement("div", {
9502 className: className
9503 }, React__default.createElement("div", {
9504 className: styles$P.Section
9505 }, detailsMarkup, React__default.createElement("div", {
9506 className: styles$P.ImageContainer
9507 }, imageMarkup)));
9508}
9509
9510var styles$Q = {
9511 "Truncate": "Polaris-Truncate"
9512};
9513
9514function Truncate(_ref) {
9515 var children = _ref.children;
9516 return React__default.createElement("span", {
9517 className: styles$Q.Truncate
9518 }, children);
9519}
9520
9521var styles$R = {
9522 "ExceptionList": "Polaris-ExceptionList",
9523 "Item": "Polaris-ExceptionList__Item",
9524 "Icon": "Polaris-ExceptionList__Icon",
9525 "statusWarning": "Polaris-ExceptionList--statusWarning",
9526 "statusCritical": "Polaris-ExceptionList--statusCritical",
9527 "Bullet": "Polaris-ExceptionList__Bullet",
9528 "Title": "Polaris-ExceptionList__Title",
9529 "Description": "Polaris-ExceptionList__Description"
9530};
9531
9532function ExceptionList(_ref) {
9533 var itemsList = _ref.items;
9534 var items = itemsList.map(function (item, index) {
9535 var status = item.status,
9536 icon = item.icon,
9537 title = item.title,
9538 description = item.description,
9539 _item$truncate = item.truncate,
9540 truncate = _item$truncate === void 0 ? false : _item$truncate;
9541 var itemClasses = classNames(styles$R.Item, status && styles$R[variationName('status', status)]);
9542 var iconMarkup = icon ? React__default.createElement(Icon, {
9543 source: icon
9544 }) : React__default.createElement("span", {
9545 className: styles$R.Bullet
9546 });
9547 var titleMarkup = title && React__default.createElement("span", {
9548 className: styles$R.Title
9549 }, title);
9550 var descriptionMarkup = description && React__default.createElement("span", {
9551 className: styles$R.Description
9552 }, description);
9553 var Element = truncate ? Truncate : React__default.Fragment;
9554 return React__default.createElement("li", {
9555 className: itemClasses,
9556 key: index
9557 }, React__default.createElement("span", {
9558 className: styles$R.Icon
9559 }, iconMarkup), React__default.createElement(Element, null, titleMarkup, descriptionMarkup));
9560 });
9561 return React__default.createElement("ul", {
9562 className: styles$R.ExceptionList
9563 }, items);
9564}
9565
9566var ResourceListContext = React__default.createContext({});
9567
9568var SELECT_ALL_ITEMS = 'All';
9569
9570var styles$S = {
9571 "Tag": "Polaris-Tag",
9572 "disabled": "Polaris-Tag--disabled",
9573 "TagText": "Polaris-Tag__TagText",
9574 "Button": "Polaris-Tag__Button",
9575 "newDesignLanguage": "Polaris-Tag--newDesignLanguage"
9576};
9577
9578function Tag(_ref) {
9579 var children = _ref.children,
9580 _ref$disabled = _ref.disabled,
9581 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
9582 onRemove = _ref.onRemove;
9583 var i18n = useI18n();
9584
9585 var _useFeatures = useFeatures(),
9586 newDesignLanguage = _useFeatures.newDesignLanguage;
9587
9588 var className = classNames(disabled && styles$S.disabled, styles$S.Tag);
9589 var ariaLabel = i18n.translate('Polaris.Tag.ariaLabel', {
9590 children: children || ''
9591 });
9592 var buttonClassName = classNames(styles$S.Button, newDesignLanguage && styles$S.newDesignLanguage);
9593 return React__default.createElement("span", {
9594 className: className
9595 }, React__default.createElement("span", {
9596 title: children,
9597 className: styles$S.TagText
9598 }, children), React__default.createElement("button", {
9599 type: "button",
9600 "aria-label": ariaLabel,
9601 className: buttonClassName,
9602 onClick: onRemove,
9603 onMouseUp: handleMouseUpByBlurring,
9604 disabled: disabled
9605 }, React__default.createElement(Icon, {
9606 source: CancelSmallMinor
9607 })));
9608}
9609
9610var Focus = memo(function Focus(_ref) {
9611 var children = _ref.children,
9612 disabled = _ref.disabled,
9613 root = _ref.root;
9614 useEffect(function () {
9615 if (disabled || !root || root.querySelector('[autofocus]')) return;
9616 focusFirstFocusableNode(root, false);
9617 }, [disabled, root]);
9618 return React__default.createElement(React__default.Fragment, null, children);
9619});
9620
9621function TrapFocus(_ref) {
9622 var _ref$trapping = _ref.trapping,
9623 trapping = _ref$trapping === void 0 ? true : _ref$trapping,
9624 children = _ref.children;
9625
9626 var _useState = useState(undefined),
9627 _useState2 = _slicedToArray(_useState, 2),
9628 shouldFocusSelf = _useState2[0],
9629 setFocusSelf = _useState2[1];
9630
9631 var _useFocusManager = useFocusManager(),
9632 canSafelyFocus = _useFocusManager.canSafelyFocus;
9633
9634 var focusTrapWrapper = useRef(null);
9635 useEffect(function () {
9636 setFocusSelf(!(canSafelyFocus && focusTrapWrapper.current && focusTrapWrapper.current.contains(document.activeElement)));
9637 }, [canSafelyFocus]);
9638
9639 var shouldDisableFirstElementFocus = function shouldDisableFirstElementFocus() {
9640 if (shouldFocusSelf === undefined || !canSafelyFocus) {
9641 return true;
9642 }
9643
9644 return shouldFocusSelf ? !trapping : !shouldFocusSelf;
9645 };
9646
9647 var handleFocusIn = function handleFocusIn(event) {
9648 var containerContentsHaveFocus = focusTrapWrapper.current && focusTrapWrapper.current.contains(document.activeElement);
9649
9650 if (trapping === false || !focusTrapWrapper.current || containerContentsHaveFocus) {
9651 return;
9652 }
9653
9654 if (canSafelyFocus && focusTrapWrapper.current !== event.target && !focusTrapWrapper.current.contains(event.target)) {
9655 focusFirstFocusableNode(focusTrapWrapper.current);
9656 }
9657 };
9658
9659 var handleTab = function handleTab(event) {
9660 if (trapping === false || !focusTrapWrapper.current) {
9661 return;
9662 }
9663
9664 var firstFocusableNode = findFirstKeyboardFocusableNode(focusTrapWrapper.current);
9665 var lastFocusableNode = findLastKeyboardFocusableNode(focusTrapWrapper.current);
9666
9667 if (event.target === lastFocusableNode && !event.shiftKey) {
9668 event.preventDefault();
9669 focusFirstKeyboardFocusableNode(focusTrapWrapper.current);
9670 }
9671
9672 if (event.target === firstFocusableNode && event.shiftKey) {
9673 event.preventDefault();
9674 focusLastKeyboardFocusableNode(focusTrapWrapper.current);
9675 }
9676 };
9677
9678 return React__default.createElement(Focus, {
9679 disabled: shouldDisableFirstElementFocus(),
9680 root: focusTrapWrapper.current
9681 }, React__default.createElement("div", {
9682 ref: focusTrapWrapper
9683 }, React__default.createElement(EventListener, {
9684 event: "focusin",
9685 handler: handleFocusIn
9686 }), React__default.createElement(KeypressListener, {
9687 keyCode: Key.Tab,
9688 keyEvent: "keydown",
9689 handler: handleTab
9690 }), children));
9691}
9692
9693var styles$T = {
9694 "Sheet": "Polaris-Sheet",
9695 "Container": "Polaris-Sheet__Container",
9696 "Bottom": "Polaris-Sheet__Bottom",
9697 "enterBottom": "Polaris-Sheet--enterBottom",
9698 "enterBottomActive": "Polaris-Sheet--enterBottomActive",
9699 "exitBottom": "Polaris-Sheet--exitBottom",
9700 "exitBottomActive": "Polaris-Sheet--exitBottomActive",
9701 "Right": "Polaris-Sheet__Right",
9702 "enterRight": "Polaris-Sheet--enterRight",
9703 "enterRightActive": "Polaris-Sheet--enterRightActive",
9704 "exitRight": "Polaris-Sheet--exitRight",
9705 "exitRightActive": "Polaris-Sheet--exitRightActive"
9706};
9707
9708var BOTTOM_CLASS_NAMES = {
9709 enter: classNames(styles$T.Bottom, styles$T.enterBottom),
9710 enterActive: classNames(styles$T.Bottom, styles$T.enterBottomActive),
9711 exit: classNames(styles$T.Bottom, styles$T.exitBottom),
9712 exitActive: classNames(styles$T.Bottom, styles$T.exitBottomActive)
9713};
9714var RIGHT_CLASS_NAMES = {
9715 enter: classNames(styles$T.Right, styles$T.enterRight),
9716 enterActive: classNames(styles$T.Right, styles$T.enterRightActive),
9717 exit: classNames(styles$T.Right, styles$T.exitRight),
9718 exitActive: classNames(styles$T.Right, styles$T.exitRightActive)
9719};
9720function Sheet(_ref) {
9721 var children = _ref.children,
9722 open = _ref.open,
9723 onClose = _ref.onClose,
9724 onEntered = _ref.onEntered,
9725 onExit = _ref.onExit;
9726
9727 var _useMediaQuery = useMediaQuery(),
9728 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
9729
9730 var container = useRef(null);
9731 var findDOMNode = useCallback(function () {
9732 return container.current;
9733 }, []);
9734 return React__default.createElement(Portal, {
9735 idPrefix: "sheet"
9736 }, React__default.createElement(CSSTransition, {
9737 findDOMNode: findDOMNode,
9738 classNames: isNavigationCollapsed ? BOTTOM_CLASS_NAMES : RIGHT_CLASS_NAMES,
9739 timeout: durationSlow,
9740 in: open,
9741 mountOnEnter: true,
9742 unmountOnExit: true,
9743 onEntered: onEntered,
9744 onExit: onExit
9745 }, React__default.createElement("div", Object.assign({
9746 className: styles$T.Container
9747 }, layer.props, overlay.props, {
9748 ref: container
9749 }), React__default.createElement(TrapFocus, {
9750 trapping: open
9751 }, React__default.createElement("div", {
9752 role: "dialog",
9753 tabIndex: -1,
9754 className: styles$T.Sheet
9755 }, children)))), React__default.createElement(KeypressListener, {
9756 keyCode: Key.Escape,
9757 handler: onClose
9758 }), open && React__default.createElement(Backdrop, {
9759 transparent: true,
9760 onClick: onClose
9761 }));
9762}
9763
9764var styles$U = {
9765 "Item": "Polaris-Filters-ConnectedFilterControl__Item",
9766 "Item-focused": "Polaris-Filters-ConnectedFilterControl__Item--focused",
9767 "ProxyButtonContainer": "Polaris-Filters-ConnectedFilterControl__ProxyButtonContainer",
9768 "ConnectedFilterControl": "Polaris-Filters-ConnectedFilterControl",
9769 "CenterContainer": "Polaris-Filters-ConnectedFilterControl__CenterContainer",
9770 "right": "Polaris-Filters-ConnectedFilterControl--right",
9771 "RightContainer": "Polaris-Filters-ConnectedFilterControl__RightContainer",
9772 "MoreFiltersButtonContainer": "Polaris-Filters-ConnectedFilterControl__MoreFiltersButtonContainer",
9773 "Wrapper": "Polaris-Filters-ConnectedFilterControl__Wrapper",
9774 "AuxiliaryContainer": "Polaris-Filters-ConnectedFilterControl__AuxiliaryContainer"
9775};
9776
9777var Item$4 =
9778/*#__PURE__*/
9779function (_React$PureComponent) {
9780 _inherits(Item, _React$PureComponent);
9781
9782 function Item() {
9783 var _this;
9784
9785 _classCallCheck(this, Item);
9786
9787 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
9788 _this.state = {
9789 focused: false
9790 };
9791
9792 _this.handleBlur = function () {
9793 _this.setState({
9794 focused: false
9795 });
9796 };
9797
9798 _this.handleFocus = function () {
9799 _this.setState({
9800 focused: true
9801 });
9802 };
9803
9804 return _this;
9805 }
9806
9807 _createClass(Item, [{
9808 key: "render",
9809 value: function render() {
9810 var focused = this.state.focused;
9811 var children = this.props.children;
9812 var className = classNames(styles$U.Item, focused && styles$U['Item-focused']);
9813 return React__default.createElement("div", {
9814 onBlur: this.handleBlur,
9815 onFocus: this.handleFocus,
9816 className: className
9817 }, children);
9818 }
9819 }]);
9820
9821 return Item;
9822}(React__default.PureComponent);
9823
9824var FILTER_FIELD_MIN_WIDTH = 150;
9825var ConnectedFilterControl =
9826/*#__PURE__*/
9827function (_React$Component) {
9828 _inherits(ConnectedFilterControl, _React$Component);
9829
9830 function ConnectedFilterControl() {
9831 var _this;
9832
9833 _classCallCheck(this, ConnectedFilterControl);
9834
9835 _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectedFilterControl).apply(this, arguments));
9836 _this.state = {
9837 availableWidth: 0,
9838 proxyButtonsWidth: {}
9839 };
9840 _this.container = React__default.createRef();
9841 _this.proxyButtonContainer = React__default.createRef();
9842 _this.moreFiltersButtonContainer = React__default.createRef();
9843 _this.handleResize = debounce(function () {
9844 _this.measureProxyButtons();
9845
9846 _this.measureAvailableWidth();
9847 }, 40, {
9848 leading: true,
9849 trailing: true,
9850 maxWait: 40
9851 });
9852 return _this;
9853 }
9854
9855 _createClass(ConnectedFilterControl, [{
9856 key: "componentDidMount",
9857 value: function componentDidMount() {
9858 this.handleResize();
9859 }
9860 }, {
9861 key: "render",
9862 value: function render() {
9863 var _this2 = this;
9864
9865 var _this$props = this.props,
9866 children = _this$props.children,
9867 rightPopoverableActions = _this$props.rightPopoverableActions,
9868 rightAction = _this$props.rightAction,
9869 auxiliary = _this$props.auxiliary;
9870 var className = classNames(styles$U.ConnectedFilterControl, rightPopoverableActions && styles$U.right);
9871 var rightMarkup = rightPopoverableActions ? React__default.createElement("div", {
9872 className: styles$U.RightContainer
9873 }, this.popoverFrom(this.getActionsToRender(rightPopoverableActions))) : null;
9874 var rightActionMarkup = rightAction ? React__default.createElement("div", {
9875 ref: this.moreFiltersButtonContainer,
9876 className: styles$U.MoreFiltersButtonContainer
9877 }, React__default.createElement(Item$4, null, rightAction)) : null;
9878 var proxyButtonMarkup = rightPopoverableActions ? React__default.createElement("div", {
9879 className: styles$U.ProxyButtonContainer,
9880 ref: this.proxyButtonContainer,
9881 "aria-hidden": true
9882 }, rightPopoverableActions.map(function (action) {
9883 return React__default.createElement("div", {
9884 key: action.key,
9885 "data-key": action.key
9886 }, _this2.activatorButtonFrom(action));
9887 })) : null;
9888 var auxMarkup = auxiliary ? React__default.createElement("div", {
9889 className: styles$U.AuxiliaryContainer
9890 }, auxiliary) : null;
9891 return React__default.createElement(React__default.Fragment, null, proxyButtonMarkup, React__default.createElement("div", {
9892 className: styles$U.Wrapper
9893 }, React__default.createElement("div", {
9894 className: className,
9895 ref: this.container
9896 }, React__default.createElement("div", {
9897 className: styles$U.CenterContainer
9898 }, React__default.createElement(Item$4, null, children)), rightMarkup, rightActionMarkup, React__default.createElement(EventListener, {
9899 event: "resize",
9900 handler: this.handleResize
9901 })), auxMarkup));
9902 }
9903 }, {
9904 key: "measureProxyButtons",
9905 value: function measureProxyButtons() {
9906 if (this.proxyButtonContainer.current) {
9907 var proxyButtonsWidth = {}; // this number is magical, but tweaking it solved the problem of items overlapping
9908
9909 var tolerance = 52;
9910
9911 if (this.proxyButtonContainer.current) {
9912 Array.from(this.proxyButtonContainer.current.children).forEach(function (element) {
9913 var buttonWidth = element.getBoundingClientRect().width + tolerance;
9914 var buttonKey = element.dataset.key;
9915
9916 if (buttonKey) {
9917 proxyButtonsWidth[buttonKey] = buttonWidth;
9918 }
9919 });
9920 }
9921
9922 this.setState({
9923 proxyButtonsWidth
9924 });
9925 }
9926 }
9927 }, {
9928 key: "measureAvailableWidth",
9929 value: function measureAvailableWidth() {
9930 if (this.container.current && this.moreFiltersButtonContainer.current) {
9931 var containerWidth = this.container.current.getBoundingClientRect().width;
9932 var moreFiltersButtonWidth = this.moreFiltersButtonContainer.current.getBoundingClientRect().width;
9933 var filtersActionWidth = 0;
9934 var availableWidth = containerWidth - FILTER_FIELD_MIN_WIDTH - moreFiltersButtonWidth - filtersActionWidth;
9935 this.setState({
9936 availableWidth
9937 });
9938 }
9939 }
9940 }, {
9941 key: "getActionsToRender",
9942 value: function getActionsToRender(actions) {
9943 var remainingWidth = this.state.availableWidth;
9944 var actionsToReturn = [];
9945
9946 for (var i = 0; remainingWidth > 0 && i < actions.length; i++) {
9947 var action = actions[i];
9948 var actionWidth = this.state.proxyButtonsWidth[action.key];
9949
9950 if (actionWidth <= remainingWidth) {
9951 actionsToReturn.push(action);
9952 remainingWidth -= actionWidth;
9953 }
9954 }
9955
9956 return actionsToReturn;
9957 }
9958 }, {
9959 key: "activatorButtonFrom",
9960 value: function activatorButtonFrom(action) {
9961 return React__default.createElement(Button, {
9962 onClick: action.onAction,
9963 disclosure: true,
9964 disabled: this.props.disabled || action.disabled,
9965 id: "Activator-".concat(action.key)
9966 }, action.content);
9967 }
9968 }, {
9969 key: "popoverFrom",
9970 value: function popoverFrom(actions) {
9971 var _this3 = this;
9972
9973 return actions.map(function (action) {
9974 return React__default.createElement(Item$4, {
9975 key: action.key
9976 }, React__default.createElement(Popover, {
9977 active: action.popoverOpen,
9978 activator: _this3.activatorButtonFrom(action),
9979 onClose: action.onAction,
9980 preferredAlignment: "left",
9981 sectioned: true
9982 }, action.popoverContent));
9983 });
9984 }
9985 }]);
9986
9987 return ConnectedFilterControl;
9988}(React__default.Component);
9989
9990var styles$V = {
9991 "Filters": "Polaris-Filters",
9992 "FiltersContainer": "Polaris-Filters__FiltersContainer",
9993 "FiltersContainerHeader": "Polaris-Filters__FiltersContainerHeader",
9994 "FiltersDesktopContainerContent": "Polaris-Filters__FiltersDesktopContainerContent",
9995 "FiltersMobileContainerContent": "Polaris-Filters__FiltersMobileContainerContent",
9996 "FiltersContainerFooter": "Polaris-Filters__FiltersContainerFooter",
9997 "FiltersMobileContainerFooter": "Polaris-Filters__FiltersMobileContainerFooter",
9998 "EmptyFooterState": "Polaris-Filters__EmptyFooterState",
9999 "FilterTriggerContainer": "Polaris-Filters__FilterTriggerContainer",
10000 "FilterTrigger": "Polaris-Filters__FilterTrigger",
10001 "newDesignLanguage": "Polaris-Filters--newDesignLanguage",
10002 "FilterTriggerTitle": "Polaris-Filters__FilterTriggerTitle",
10003 "AppliedFilterBadgeContainer": "Polaris-Filters__AppliedFilterBadgeContainer",
10004 "open": "Polaris-Filters--open",
10005 "FilterTriggerLabelContainer": "Polaris-Filters__FilterTriggerLabelContainer",
10006 "first": "Polaris-Filters--first",
10007 "last": "Polaris-Filters--last",
10008 "FilterNodeContainer": "Polaris-Filters__FilterNodeContainer",
10009 "SearchIcon": "Polaris-Filters__SearchIcon",
10010 "Backdrop": "Polaris-Filters__Backdrop",
10011 "HelpText": "Polaris-Filters__HelpText",
10012 "TagsContainer": "Polaris-Filters__TagsContainer"
10013};
10014
10015var Suffix;
10016
10017(function (Suffix) {
10018 Suffix["Filter"] = "Filter";
10019 Suffix["Shortcut"] = "Shortcut";
10020})(Suffix || (Suffix = {}));
10021
10022var FiltersInner =
10023/*#__PURE__*/
10024function (_React$Component) {
10025 _inherits(FiltersInner, _React$Component);
10026
10027 function FiltersInner() {
10028 var _this;
10029
10030 _classCallCheck(this, FiltersInner);
10031
10032 _this = _possibleConstructorReturn(this, _getPrototypeOf(FiltersInner).apply(this, arguments));
10033 _this.state = {
10034 open: false,
10035 readyForFocus: false
10036 };
10037 _this.moreFiltersButtonContainer = createRef();
10038 _this.focusNode = createRef();
10039
10040 _this.closeFilters = function () {
10041 _this.setState({
10042 open: false
10043 }, function () {
10044 if (_this.moreFiltersButtonContainer.current) {
10045 focusFirstFocusableNode(_this.moreFiltersButtonContainer.current, false);
10046 }
10047 });
10048 };
10049
10050 _this.toggleFilters = function () {
10051 if (_this.state.open === true) {
10052 _this.closeFilters();
10053 } else {
10054 _this.openFilters();
10055 }
10056 };
10057
10058 _this.setReadyForFocus = function (newState) {
10059 return function () {
10060 _this.setState({
10061 readyForFocus: newState
10062 });
10063 };
10064 };
10065
10066 return _this;
10067 }
10068
10069 _createClass(FiltersInner, [{
10070 key: "render",
10071 value: function render() {
10072 var _this2 = this;
10073
10074 var _this$props = this.props,
10075 filters = _this$props.filters,
10076 queryValue = _this$props.queryValue,
10077 onQueryBlur = _this$props.onQueryBlur,
10078 onQueryChange = _this$props.onQueryChange,
10079 onQueryFocus = _this$props.onQueryFocus,
10080 focused = _this$props.focused,
10081 onClearAll = _this$props.onClearAll,
10082 appliedFilters = _this$props.appliedFilters,
10083 _this$props$polaris = _this$props.polaris,
10084 intl = _this$props$polaris.intl,
10085 isNavigationCollapsed = _this$props$polaris.mediaQuery.isNavigationCollapsed,
10086 onQueryClear = _this$props.onQueryClear,
10087 queryPlaceholder = _this$props.queryPlaceholder,
10088 children = _this$props.children,
10089 _this$props$disabled = _this$props.disabled,
10090 disabled = _this$props$disabled === void 0 ? false : _this$props$disabled,
10091 helpText = _this$props.helpText,
10092 hideTags = _this$props.hideTags,
10093 newDesignLanguage = _this$props.newDesignLanguage;
10094 var resourceName = this.context.resourceName;
10095 var _this$state = this.state,
10096 open = _this$state.open,
10097 readyForFocus = _this$state.readyForFocus;
10098 var backdropMarkup = open ? React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
10099 className: styles$V.Backdrop,
10100 onClick: this.closeFilters
10101 })) : null;
10102 var filtersContentMarkup = filters.map(function (filter, index) {
10103 var filterIsOpen = _this2.state["".concat(filter.key).concat(Suffix.Filter)] === true;
10104 var icon = filterIsOpen ? ChevronUpMinor : ChevronDownMinor;
10105 var className = classNames(styles$V.FilterTriggerContainer, filterIsOpen && styles$V.open, index === 0 && styles$V.first, filters.length !== 1 && index === filters.length - 1 && styles$V.last);
10106
10107 var appliedFilterContent = _this2.getAppliedFilterContent(filter.key);
10108
10109 var appliedFilterBadgeMarkup = appliedFilterContent ? React__default.createElement("div", {
10110 className: styles$V.AppliedFilterBadgeContainer
10111 }, React__default.createElement(Badge, {
10112 size: "small",
10113 status: "new"
10114 }, appliedFilterContent)) : null;
10115 var collapsibleID = "".concat(filter.key, "Collapsible");
10116 var buttonClassName = classNames(styles$V.FilterTrigger, newDesignLanguage && styles$V.newDesignLanguage);
10117 return React__default.createElement("div", {
10118 key: filter.key,
10119 className: className
10120 }, React__default.createElement("button", {
10121 onClick: function onClick() {
10122 return _this2.toggleFilter(filter.key);
10123 },
10124 className: buttonClassName,
10125 id: "".concat(filter.key, "ToggleButton"),
10126 type: "button",
10127 "aria-controls": collapsibleID,
10128 "aria-expanded": filterIsOpen
10129 }, React__default.createElement("div", {
10130 className: styles$V.FilterTriggerLabelContainer
10131 }, React__default.createElement("h2", {
10132 className: styles$V.FilterTriggerTitle
10133 }, React__default.createElement(TextStyle, {
10134 variation: _this2.props.disabled || filter.disabled ? 'subdued' : undefined
10135 }, filter.label)), React__default.createElement("span", {
10136 className: styles$V.FilterTriggerIcon
10137 }, React__default.createElement(Icon, {
10138 source: icon,
10139 color: "inkLightest"
10140 }))), appliedFilterBadgeMarkup), React__default.createElement(Collapsible, {
10141 id: collapsibleID,
10142 open: filterIsOpen
10143 }, React__default.createElement("div", {
10144 className: styles$V.FilterNodeContainer
10145 }, React__default.createElement(Focus, {
10146 disabled: !filterIsOpen || !readyForFocus || !open,
10147 root: _this2.focusNode.current
10148 }, _this2.generateFilterMarkup(filter)))));
10149 });
10150 var appliedFiltersCount = appliedFilters ? appliedFilters.length : 0;
10151 var moreFiltersLabel = hideTags && appliedFiltersCount > 0 ? intl.translate('Polaris.Filters.moreFiltersWithCount', {
10152 count: appliedFiltersCount
10153 }) : intl.translate('Polaris.Filters.moreFilters');
10154 var rightActionMarkup = React__default.createElement("div", {
10155 ref: this.moreFiltersButtonContainer
10156 }, React__default.createElement(Button, {
10157 onClick: this.toggleFilters,
10158 disabled: disabled
10159 }, moreFiltersLabel));
10160 var filterResourceName = resourceName || {
10161 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
10162 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
10163 };
10164 var filtersControlMarkup = React__default.createElement(ConnectedFilterControl, {
10165 rightPopoverableActions: this.transformFilters(filters),
10166 rightAction: rightActionMarkup,
10167 auxiliary: children,
10168 disabled: disabled
10169 }, React__default.createElement(TextField, {
10170 placeholder: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10171 resourceName: filterResourceName.plural
10172 }),
10173 onChange: onQueryChange,
10174 onBlur: onQueryBlur,
10175 onFocus: onQueryFocus,
10176 value: queryValue,
10177 focused: focused,
10178 label: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10179 resourceName: filterResourceName.plural
10180 }),
10181 labelHidden: true,
10182 prefix: React__default.createElement("span", {
10183 className: styles$V.SearchIcon
10184 }, React__default.createElement(Icon, {
10185 source: SearchMinor
10186 })),
10187 clearButton: true,
10188 onClearButtonClick: onQueryClear,
10189 disabled: disabled
10190 }));
10191 var filtersDesktopHeaderMarkup = React__default.createElement("div", {
10192 className: styles$V.FiltersContainerHeader
10193 }, React__default.createElement(DisplayText, {
10194 size: "small"
10195 }, moreFiltersLabel), React__default.createElement(Button, {
10196 icon: CancelSmallMinor,
10197 plain: true,
10198 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10199 onClick: this.closeFilters
10200 }));
10201 var filtersMobileHeaderMarkup = React__default.createElement("div", {
10202 className: styles$V.FiltersContainerHeader
10203 }, React__default.createElement(Button, {
10204 icon: CancelSmallMinor,
10205 plain: true,
10206 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10207 onClick: this.closeFilters
10208 }), React__default.createElement(DisplayText, {
10209 size: "small"
10210 }, moreFiltersLabel), React__default.createElement(Button, {
10211 onClick: this.closeFilters,
10212 primary: true
10213 }, intl.translate('Polaris.Filters.done')));
10214 var filtersDesktopFooterMarkup = React__default.createElement("div", {
10215 className: styles$V.FiltersContainerFooter
10216 }, React__default.createElement(Button, {
10217 onClick: onClearAll,
10218 disabled: !this.hasAppliedFilters()
10219 }, intl.translate('Polaris.Filters.clearAllFilters')), React__default.createElement(Button, {
10220 onClick: this.closeFilters,
10221 primary: true
10222 }, intl.translate('Polaris.Filters.done')));
10223 var filtersMobileFooterMarkup = React__default.createElement("div", {
10224 className: styles$V.FiltersMobileContainerFooter
10225 }, this.hasAppliedFilters() ? React__default.createElement(Button, {
10226 onClick: onClearAll,
10227 fullWidth: true
10228 }, intl.translate('Polaris.Filters.clearAllFilters')) : React__default.createElement("div", {
10229 className: styles$V.EmptyFooterState
10230 }, React__default.createElement(TextStyle, {
10231 variation: "subdued"
10232 }, React__default.createElement("p", null, intl.translate('Polaris.Filters.noFiltersApplied')))));
10233 var tagsMarkup = !hideTags && appliedFilters && appliedFilters.length ? React__default.createElement("div", {
10234 className: styles$V.TagsContainer
10235 }, appliedFilters.map(function (filter) {
10236 return React__default.createElement(Tag, {
10237 key: filter.key,
10238 onRemove: function onRemove() {
10239 filter.onRemove(filter.key);
10240 },
10241 disabled: disabled
10242 }, filter.label);
10243 })) : null;
10244 var filtersContainerMarkup = isNavigationCollapsed ? React__default.createElement(Sheet, {
10245 open: open,
10246 onClose: this.closeFilters,
10247 onEntered: this.setReadyForFocus(true),
10248 onExit: this.setReadyForFocus(false)
10249 }, filtersMobileHeaderMarkup, React__default.createElement(Scrollable, {
10250 className: styles$V.FiltersMobileContainerContent,
10251 shadow: true
10252 }, filtersContentMarkup, filtersMobileFooterMarkup)) : React__default.createElement(Sheet, {
10253 open: open,
10254 onClose: this.closeFilters,
10255 onEntered: this.setReadyForFocus(true),
10256 onExit: this.setReadyForFocus(false)
10257 }, React__default.createElement("div", {
10258 className: styles$V.FiltersContainer
10259 }, filtersDesktopHeaderMarkup, React__default.createElement(Scrollable, {
10260 className: styles$V.FiltersDesktopContainerContent,
10261 shadow: true
10262 }, filtersContentMarkup), filtersDesktopFooterMarkup));
10263 var helpTextMarkup = helpText ? React__default.createElement("div", {
10264 id: "FiltersHelpText",
10265 className: styles$V.HelpText
10266 }, React__default.createElement(TextStyle, {
10267 variation: "subdued"
10268 }, helpText)) : null;
10269 return React__default.createElement("div", {
10270 className: styles$V.Filters
10271 }, filtersControlMarkup, filtersContainerMarkup, tagsMarkup, helpTextMarkup, backdropMarkup, React__default.createElement(KeypressListener, {
10272 keyCode: Key.Escape,
10273 handler: this.closeFilters
10274 }));
10275 }
10276 }, {
10277 key: "hasAppliedFilters",
10278 value: function hasAppliedFilters() {
10279 var _this$props2 = this.props,
10280 appliedFilters = _this$props2.appliedFilters,
10281 queryValue = _this$props2.queryValue;
10282 var filtersApplied = Boolean(appliedFilters && appliedFilters.length > 0);
10283 var queryApplied = Boolean(queryValue && queryValue !== '');
10284 return filtersApplied || queryApplied;
10285 }
10286 }, {
10287 key: "getAppliedFilterContent",
10288 value: function getAppliedFilterContent(key) {
10289 var appliedFilters = this.props.appliedFilters;
10290
10291 if (!appliedFilters) {
10292 return undefined;
10293 }
10294
10295 var filter = appliedFilters.find(function (filter) {
10296 return filter.key === key;
10297 });
10298 return filter == null ? undefined : filter.label;
10299 }
10300 }, {
10301 key: "getAppliedFilterRemoveHandler",
10302 value: function getAppliedFilterRemoveHandler(key) {
10303 var appliedFilters = this.props.appliedFilters;
10304
10305 if (!appliedFilters) {
10306 return undefined;
10307 }
10308
10309 var filter = appliedFilters.find(function (filter) {
10310 return filter.key === key;
10311 });
10312 return filter == null ? undefined : filter.onRemove;
10313 }
10314 }, {
10315 key: "openFilters",
10316 value: function openFilters() {
10317 this.setState({
10318 open: true
10319 });
10320 }
10321 }, {
10322 key: "openFilter",
10323 value: function openFilter(key) {
10324 this.setState({
10325 ["".concat(key).concat(Suffix.Filter)]: true
10326 });
10327 }
10328 }, {
10329 key: "closeFilter",
10330 value: function closeFilter(key) {
10331 this.setState({
10332 ["".concat(key).concat(Suffix.Filter)]: false
10333 });
10334 }
10335 }, {
10336 key: "toggleFilter",
10337 value: function toggleFilter(key) {
10338 if (this.state["".concat(key).concat(Suffix.Filter)] === true) {
10339 this.closeFilter(key);
10340 } else {
10341 this.openFilter(key);
10342 }
10343 }
10344 }, {
10345 key: "openFilterShortcut",
10346 value: function openFilterShortcut(key) {
10347 this.setState({
10348 ["".concat(key).concat(Suffix.Shortcut)]: true
10349 });
10350 }
10351 }, {
10352 key: "closeFilterShortcut",
10353 value: function closeFilterShortcut(key) {
10354 this.setState({
10355 ["".concat(key).concat(Suffix.Shortcut)]: false
10356 });
10357 }
10358 }, {
10359 key: "toggleFilterShortcut",
10360 value: function toggleFilterShortcut(key) {
10361 if (this.state["".concat(key).concat(Suffix.Shortcut)] === true) {
10362 this.closeFilterShortcut(key);
10363 } else {
10364 this.openFilterShortcut(key);
10365 }
10366 }
10367 }, {
10368 key: "transformFilters",
10369 value: function transformFilters(filters) {
10370 var _this3 = this;
10371
10372 var transformedActions = [];
10373 getShortcutFilters(filters).forEach(function (filter) {
10374 var key = filter.key,
10375 label = filter.label,
10376 disabled = filter.disabled;
10377 transformedActions.push({
10378 popoverContent: _this3.generateFilterMarkup(filter),
10379 popoverOpen: Boolean(_this3.state["".concat(key).concat(Suffix.Shortcut)]),
10380 key,
10381 content: label,
10382 disabled,
10383 onAction: function onAction() {
10384 return _this3.toggleFilterShortcut(key);
10385 }
10386 });
10387 });
10388 return transformedActions;
10389 }
10390 }, {
10391 key: "generateFilterMarkup",
10392 value: function generateFilterMarkup(filter) {
10393 var intl = this.props.polaris.intl;
10394 var removeCallback = this.getAppliedFilterRemoveHandler(filter.key);
10395 var removeHandler = removeCallback == null ? undefined : function () {
10396 removeCallback(filter.key);
10397 };
10398 return React__default.createElement("div", {
10399 ref: this.focusNode
10400 }, React__default.createElement(Stack, {
10401 vertical: true,
10402 spacing: "tight"
10403 }, filter.filter, React__default.createElement(Button, {
10404 plain: true,
10405 disabled: removeHandler == null,
10406 onClick: removeHandler,
10407 accessibilityLabel: intl.translate('Polaris.Filters.clearLabel', {
10408 filterName: filter.label
10409 })
10410 }, intl.translate('Polaris.Filters.clear'))));
10411 }
10412 }]);
10413
10414 return FiltersInner;
10415}(React__default.Component);
10416
10417FiltersInner.contextType = ResourceListContext;
10418
10419function getShortcutFilters(filters) {
10420 return filters.filter(function (filter) {
10421 return filter.shortcut === true;
10422 });
10423}
10424
10425function FiltersInnerWrapper(props) {
10426 var _useFeatures = useFeatures(),
10427 newDesignLanguage = _useFeatures.newDesignLanguage;
10428
10429 return React__default.createElement(FiltersInner, Object.assign({}, props, {
10430 newDesignLanguage: newDesignLanguage
10431 }));
10432}
10433
10434var Filters = withAppProvider()(FiltersInnerWrapper);
10435
10436var styles$W = {
10437 "FooterHelp": "Polaris-FooterHelp",
10438 "Content": "Polaris-FooterHelp__Content",
10439 "Icon": "Polaris-FooterHelp__Icon",
10440 "Text": "Polaris-FooterHelp__Text"
10441};
10442
10443function FooterHelp(_ref) {
10444 var children = _ref.children;
10445 return React__default.createElement("div", {
10446 className: styles$W.FooterHelp
10447 }, React__default.createElement("div", {
10448 className: styles$W.Content
10449 }, React__default.createElement("div", {
10450 className: styles$W.Icon
10451 }, React__default.createElement(Icon, {
10452 source: QuestionMarkMajorTwotone,
10453 color: "teal",
10454 backdrop: true
10455 })), React__default.createElement("div", {
10456 className: styles$W.Text
10457 }, children)));
10458}
10459
10460function Form(_ref) {
10461 var acceptCharset = _ref.acceptCharset,
10462 action = _ref.action,
10463 autoComplete = _ref.autoComplete,
10464 children = _ref.children,
10465 encType = _ref.encType,
10466 _ref$implicitSubmit = _ref.implicitSubmit,
10467 implicitSubmit = _ref$implicitSubmit === void 0 ? true : _ref$implicitSubmit,
10468 _ref$method = _ref.method,
10469 method = _ref$method === void 0 ? 'post' : _ref$method,
10470 name = _ref.name,
10471 noValidate = _ref.noValidate,
10472 _ref$preventDefault = _ref.preventDefault,
10473 preventDefault = _ref$preventDefault === void 0 ? true : _ref$preventDefault,
10474 target = _ref.target,
10475 onSubmit = _ref.onSubmit;
10476 var i18n = useI18n();
10477 var handleSubmit = useCallback(function (event) {
10478 if (!preventDefault) {
10479 return;
10480 }
10481
10482 event.preventDefault();
10483 onSubmit(event);
10484 }, [onSubmit, preventDefault]);
10485 var autoCompleteInputs = normalizeAutoComplete$1(autoComplete);
10486 var submitMarkup = implicitSubmit ? React__default.createElement(VisuallyHidden, null, React__default.createElement("button", {
10487 type: "submit",
10488 "aria-hidden": "true",
10489 tabIndex: -1
10490 }, i18n.translate('Polaris.Common.submit'))) : null;
10491 return React__default.createElement("form", {
10492 acceptCharset: acceptCharset,
10493 action: action,
10494 autoComplete: autoCompleteInputs,
10495 encType: encType,
10496 method: method,
10497 name: name,
10498 noValidate: noValidate,
10499 target: target,
10500 onSubmit: handleSubmit
10501 }, children, submitMarkup);
10502}
10503
10504function normalizeAutoComplete$1(autoComplete) {
10505 if (autoComplete == null) {
10506 return autoComplete;
10507 }
10508
10509 return autoComplete ? 'on' : 'off';
10510}
10511
10512var styles$X = {
10513 "FormLayout": "Polaris-FormLayout",
10514 "Title": "Polaris-FormLayout__Title",
10515 "Items": "Polaris-FormLayout__Items",
10516 "HelpText": "Polaris-FormLayout__HelpText",
10517 "Item": "Polaris-FormLayout__Item",
10518 "grouped": "Polaris-FormLayout--grouped",
10519 "condensed": "Polaris-FormLayout--condensed"
10520};
10521
10522function Item$5(props) {
10523 return React__default.createElement("div", {
10524 className: styles$X.Item
10525 }, props.children);
10526}
10527
10528function Group(_ref) {
10529 var children = _ref.children,
10530 condensed = _ref.condensed,
10531 title = _ref.title,
10532 helpText = _ref.helpText;
10533 var className = classNames(condensed ? styles$X.condensed : styles$X.grouped);
10534 var id = useUniqueId('FormLayoutGroup');
10535 var helpTextElement = null;
10536 var helpTextID;
10537 var titleElement = null;
10538 var titleID;
10539
10540 if (helpText) {
10541 helpTextID = "".concat(id, "HelpText");
10542 helpTextElement = React__default.createElement("div", {
10543 id: helpTextID,
10544 className: styles$X.HelpText
10545 }, helpText);
10546 }
10547
10548 if (title) {
10549 titleID = "".concat(id, "Title");
10550 titleElement = React__default.createElement("div", {
10551 id: titleID,
10552 className: styles$X.Title
10553 }, title);
10554 }
10555
10556 var itemsMarkup = React__default.Children.map(children, function (child) {
10557 return wrapWithComponent(child, Item$5, {});
10558 });
10559 return React__default.createElement("div", {
10560 role: "group",
10561 className: className,
10562 "aria-labelledby": titleID,
10563 "aria-describedby": helpTextID
10564 }, titleElement, React__default.createElement("div", {
10565 className: styles$X.Items
10566 }, itemsMarkup), helpTextElement);
10567}
10568
10569var FormLayout = memo(function FormLayout(_ref) {
10570 var children = _ref.children;
10571 return React__default.createElement("div", {
10572 className: styles$X.FormLayout
10573 }, React__default.Children.map(children, wrapChildren));
10574});
10575FormLayout.Group = Group;
10576
10577function wrapChildren(child, index) {
10578 if (isElementOfType(child, Group)) {
10579 return child;
10580 }
10581
10582 var props = {
10583 key: index
10584 };
10585 return wrapWithComponent(child, Item$5, props);
10586}
10587
10588function setRootProperty(name, value, node) {
10589 if (document == null) {
10590 return;
10591 }
10592
10593 var styleNode = node && node instanceof HTMLElement ? node : document.documentElement;
10594 styleNode && styleNode.style.setProperty(name, value);
10595}
10596
10597var styles$Y = {
10598 "Toast": "Polaris-Frame-Toast",
10599 "Action": "Polaris-Frame-Toast__Action",
10600 "error": "Polaris-Frame-Toast--error",
10601 "CloseButton": "Polaris-Frame-Toast__CloseButton"
10602};
10603
10604var DEFAULT_TOAST_DURATION = 5000;
10605var DEFAULT_TOAST_DURATION_WITH_ACTION = 10000;
10606function Toast(_ref) {
10607 var content = _ref.content,
10608 onDismiss = _ref.onDismiss,
10609 duration = _ref.duration,
10610 error = _ref.error,
10611 action = _ref.action;
10612 useEffect(function () {
10613 var timeoutDuration = duration || DEFAULT_TOAST_DURATION;
10614
10615 if (action && !duration) {
10616 timeoutDuration = DEFAULT_TOAST_DURATION_WITH_ACTION;
10617 } else if (action && duration && duration < DEFAULT_TOAST_DURATION_WITH_ACTION) {
10618 // eslint-disable-next-line no-console
10619 console.log('Toast with action should persist for at least 10,000 milliseconds to give the merchant enough time to act on it.');
10620 }
10621
10622 var timer = setTimeout(onDismiss, timeoutDuration);
10623 return function () {
10624 clearTimeout(timer);
10625 };
10626 }, [action, duration, onDismiss]);
10627 var dismissMarkup = React__default.createElement("button", {
10628 type: "button",
10629 className: styles$Y.CloseButton,
10630 onClick: onDismiss
10631 }, React__default.createElement(Icon, {
10632 source: MobileCancelMajorMonotone
10633 }));
10634 var actionMarkup = action ? React__default.createElement("div", {
10635 className: styles$Y.Action
10636 }, React__default.createElement(Button, {
10637 plain: true,
10638 monochrome: true,
10639 onClick: action.onAction
10640 }, action.content)) : null;
10641 var className = classNames(styles$Y.Toast, error && styles$Y.error);
10642 return React__default.createElement(ThemeProvider, {
10643 theme: {
10644 colorScheme: 'inverse'
10645 }
10646 }, React__default.createElement("div", {
10647 className: className
10648 }, React__default.createElement(KeypressListener, {
10649 keyCode: Key.Escape,
10650 handler: onDismiss
10651 }), content, actionMarkup, dismissMarkup));
10652}
10653
10654/**
10655 * A replacement for React.useCallback that'll allow for custom and deep compares.
10656 * @see {@link https://reactjs.org/docs/hooks-reference.html#usecallback}
10657 * @param callback Accepts a callback that's forwarded to React.useCallback
10658 * @param dependencies A dependency array similar to React.useCallback however it utilizes a deep compare
10659 * @param customCompare Opportunity to provide a custom compare function
10660 * @returns A memoized callback
10661 * @example
10662 * const Child = memo(function Child({onClick}) {
10663 * console.log('Child has rendered.');
10664 * return <button onClick={onClick}>Click me</button>;
10665 * });
10666 *
10667 * function ComponentExample() {
10668 * const [timesClicked, setTimesClicked] = useState(0);
10669 *
10670 * const handleClick = useDeepCallback(() => {
10671 * setTimesClicked((timesClicked) => timesClicked + 1);
10672 * // New reference every render
10673 * }, [{}]);
10674 *
10675 * return (
10676 * <Fragment>
10677 * <div>Times clicked: {timesClicked}</div>
10678 * <Child onClick={handleClick} />
10679 * </Fragment>
10680 * );
10681 * }
10682 */
10683
10684function useDeepCallback(callback, dependencies, customCompare) {
10685 return useCallback(callback, useDeepCompareRef(dependencies, customCompare));
10686}
10687
10688var styles$Z = {
10689 "ToastManager": "Polaris-Frame-ToastManager",
10690 "ToastWrapper": "Polaris-Frame-ToastManager__ToastWrapper",
10691 "ToastWrapper-enter": "Polaris-Frame-ToastManager__ToastWrapper--enter",
10692 "ToastWrapper-exit": "Polaris-Frame-ToastManager__ToastWrapper--exit",
10693 "ToastWrapper-enter-done": "Polaris-Frame-ToastManager--toastWrapperEnterDone"
10694};
10695
10696var ToastManager = memo(function ToastManager(_ref) {
10697 var toastMessages = _ref.toastMessages;
10698 var toastNodes = [];
10699 var updateToasts = useDeepCallback(function () {
10700 var targetInPos = 0;
10701 toastMessages.forEach(function (_, index) {
10702 var currentToast = toastNodes[index];
10703 if (!currentToast.current) return;
10704 targetInPos += currentToast.current.clientHeight;
10705 currentToast.current.style.setProperty('--toast-translate-y-in', "-".concat(targetInPos, "px"));
10706 currentToast.current.style.setProperty('--toast-translate-y-out', "".concat(-targetInPos + 150, "px"));
10707 });
10708 }, [toastMessages, toastNodes]);
10709 useDeepEffect(function () {
10710 updateToasts();
10711 }, [toastMessages]);
10712 var toastsMarkup = toastMessages.map(function (toast, index) {
10713 var toastNode = createRef();
10714 toastNodes[index] = toastNode;
10715 return React__default.createElement(CSSTransition, {
10716 findDOMNode: findDOMNode(index),
10717 key: toast.id,
10718 timeout: {
10719 enter: 0,
10720 exit: 400
10721 },
10722 classNames: toastClasses
10723 }, React__default.createElement("div", {
10724 ref: toastNode
10725 }, React__default.createElement(Toast, toast)));
10726 });
10727 return React__default.createElement(Portal, {
10728 idPrefix: "toast-manager"
10729 }, React__default.createElement(EventListener, {
10730 event: "resize",
10731 handler: updateToasts
10732 }), React__default.createElement("div", {
10733 className: styles$Z.ToastManager,
10734 "aria-live": "polite"
10735 }, React__default.createElement(TransitionGroup, {
10736 component: null
10737 }, toastsMarkup)));
10738
10739 function findDOMNode(index) {
10740 return function () {
10741 return toastNodes[index].current;
10742 };
10743 }
10744});
10745var toastClasses = {
10746 enter: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter']),
10747 enterDone: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter-done']),
10748 exit: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-exit'])
10749};
10750
10751var styles$_ = {
10752 "Loading": "Polaris-Frame-Loading",
10753 "Level": "Polaris-Frame-Loading__Level"
10754};
10755
10756var INITIAL_STEP = 10;
10757var STUCK_THRESHOLD = 99;
10758var Loading =
10759/*#__PURE__*/
10760function (_React$Component) {
10761 _inherits(Loading, _React$Component);
10762
10763 function Loading() {
10764 var _this;
10765
10766 _classCallCheck(this, Loading);
10767
10768 _this = _possibleConstructorReturn(this, _getPrototypeOf(Loading).apply(this, arguments));
10769 _this.state = {
10770 progress: 0,
10771 step: INITIAL_STEP,
10772 animation: null
10773 };
10774 _this.ariaValuenow = debounce(function () {
10775 var progress = _this.state.progress;
10776 return Math.floor(progress / 10) * 10;
10777 }, 15);
10778 return _this;
10779 }
10780
10781 _createClass(Loading, [{
10782 key: "componentDidMount",
10783 value: function componentDidMount() {
10784 this.increment();
10785 }
10786 }, {
10787 key: "componentWillUnmount",
10788 value: function componentWillUnmount() {
10789 var animation = this.state.animation;
10790
10791 if (animation != null) {
10792 cancelAnimationFrame(animation);
10793 }
10794 }
10795 }, {
10796 key: "render",
10797 value: function render() {
10798 var progress = this.state.progress;
10799 var customStyles = {
10800 transform: "scaleX(".concat(Math.floor(progress) / 100, ")")
10801 };
10802 var ariaValuenow = this.ariaValuenow();
10803 return React__default.createElement("div", {
10804 className: styles$_.Loading
10805 }, React__default.createElement("div", {
10806 className: styles$_.Level,
10807 style: customStyles,
10808 "aria-valuenow": ariaValuenow,
10809 "aria-valuemin": 0,
10810 "aria-valuemax": 100,
10811 role: "progressbar"
10812 }));
10813 }
10814 }, {
10815 key: "increment",
10816 value: function increment() {
10817 var _this2 = this;
10818
10819 var _this$state = this.state,
10820 progress = _this$state.progress,
10821 step = _this$state.step;
10822
10823 if (progress >= STUCK_THRESHOLD) {
10824 return;
10825 }
10826
10827 var animation = requestAnimationFrame(function () {
10828 return _this2.increment();
10829 });
10830 this.setState({
10831 progress: Math.min(progress + step, 100),
10832 step: Math.pow(INITIAL_STEP, -(progress / 25)),
10833 animation
10834 });
10835 }
10836 }]);
10837
10838 return Loading;
10839}(React__default.Component);
10840
10841function isObject(value) {
10842 var type = typeof value;
10843 return value != null && (type === TypeOf.Object || type === TypeOf.Function);
10844}
10845
10846function pluckDeep(obj, key) {
10847 if (!obj) {
10848 return null;
10849 }
10850
10851 var keys = Object.keys(obj);
10852
10853 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
10854 var currKey = _keys[_i];
10855
10856 if (currKey === key) {
10857 return obj[key];
10858 }
10859
10860 if (isObject(obj[currKey])) {
10861 var plucked = pluckDeep(obj[currKey], key);
10862
10863 if (plucked) {
10864 return plucked;
10865 }
10866 }
10867 }
10868
10869 return null;
10870}
10871
10872function getWidth() {
10873 var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
10874 var defaultWidth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
10875 var key = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'width';
10876 var width = typeof value === 'number' ? value : pluckDeep(value, key);
10877 return width ? "".concat(width, "px") : "".concat(defaultWidth, "px");
10878}
10879
10880function generateRedirect(appBridge, url) {
10881 var target = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'APP';
10882 var external = arguments.length > 3 ? arguments[3] : undefined;
10883
10884 if (url == null) {
10885 return undefined;
10886 }
10887
10888 var redirect = Redirect.create(appBridge);
10889 var payload = external === true ? {
10890 url,
10891 newContext: true
10892 } : url;
10893 return function () {
10894 redirect.dispatch(redirectAction(target, external), payload);
10895 };
10896}
10897
10898function redirectAction(target, external) {
10899 if (external === true) {
10900 return Redirect.Action.REMOTE;
10901 }
10902
10903 return Redirect.Action[target];
10904}
10905
10906function transformActions(appBridge, _ref) {
10907 var primaryAction = _ref.primaryAction,
10908 secondaryActions = _ref.secondaryActions,
10909 actionGroups = _ref.actionGroups;
10910 var primary = transformPrimaryAction(appBridge, primaryAction);
10911 var secondary = [].concat(_toConsumableArray(transformSecondaryActions(appBridge, secondaryActions)), _toConsumableArray(transformActionGroups(appBridge, actionGroups)));
10912 return {
10913 primary,
10914 secondary
10915 };
10916}
10917
10918function transformAction(appBridge, action) {
10919 var style = action.destructive === true ? Button$1.Style.Danger : undefined;
10920 var button = Button$1.create(appBridge, {
10921 label: action.content || '',
10922 disabled: action.disabled,
10923 style
10924 });
10925
10926 if (action.onAction) {
10927 button.subscribe(Button$1.Action.CLICK, action.onAction);
10928 }
10929
10930 var redirect = generateRedirect(appBridge, action.url, action.target, action.external);
10931
10932 if (redirect != null) {
10933 button.subscribe(Button$1.Action.CLICK, redirect);
10934 }
10935
10936 return button;
10937}
10938
10939function transformPrimaryAction(appBridge, primaryAction) {
10940 if (primaryAction == null) {
10941 return undefined;
10942 }
10943
10944 var primary = transformAction(appBridge, primaryAction);
10945 return primary;
10946}
10947
10948function transformSecondaryActions(appBridge) {
10949 var secondaryActions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
10950
10951 var secondary = _toConsumableArray(secondaryActions.map(function (secondaryAction) {
10952 return transformAction(appBridge, secondaryAction);
10953 }));
10954
10955 return secondary;
10956}
10957
10958function transformActionGroups(appBridge) {
10959 var actionGroups = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
10960
10961 var buttonGroups = _toConsumableArray(actionGroups.map(function (group) {
10962 var buttons = group.actions.map(function (groupAction) {
10963 return transformAction(appBridge, groupAction);
10964 });
10965 return ButtonGroup$1.create(appBridge, {
10966 label: group.title,
10967 buttons
10968 });
10969 }));
10970
10971 return buttonGroups;
10972}
10973
10974function pickValueAndLength(obj, key) {
10975 var keyPaths = key.split('.');
10976 var value = obj;
10977 var _iteratorNormalCompletion = true;
10978 var _didIteratorError = false;
10979 var _iteratorError = undefined;
10980
10981 try {
10982 for (var _iterator = keyPaths[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
10983 var _key = _step.value;
10984
10985 if (!Object.prototype.hasOwnProperty.call(value, _key)) {
10986 return null;
10987 }
10988
10989 value = value[_key];
10990 }
10991 } catch (err) {
10992 _didIteratorError = true;
10993 _iteratorError = err;
10994 } finally {
10995 try {
10996 if (!_iteratorNormalCompletion && _iterator.return != null) {
10997 _iterator.return();
10998 }
10999 } finally {
11000 if (_didIteratorError) {
11001 throw _iteratorError;
11002 }
11003 }
11004 }
11005
11006 return {
11007 keyPaths,
11008 value
11009 };
11010}
11011
11012function pick(obj) {
11013 var _ref;
11014
11015 for (var _len = arguments.length, keyPaths = new Array(_len > 1 ? _len - 1 : 0), _key2 = 1; _key2 < _len; _key2++) {
11016 keyPaths[_key2 - 1] = arguments[_key2];
11017 }
11018
11019 var flattenedKeypaths = (_ref = []).concat.apply(_ref, keyPaths);
11020
11021 if (obj == null || flattenedKeypaths.length === 0) return {};
11022 return flattenedKeypaths.reduce(function (acc, key) {
11023 if (typeof key !== TypeOf.String || Object.prototype.hasOwnProperty.call(obj, key)) {
11024 return Object.assign(Object.assign({}, acc), {
11025 [key]: obj[key]
11026 });
11027 }
11028
11029 var pickedValues = pickValueAndLength(obj, key);
11030
11031 if (pickedValues === null) {
11032 return acc;
11033 }
11034
11035 var keyPaths = pickedValues.keyPaths,
11036 value = pickedValues.value;
11037 var len = keyPaths.length;
11038 var innerObject = {
11039 [keyPaths[--len]]: value
11040 };
11041
11042 while (len--) {
11043 innerObject = {
11044 [keyPaths[len]]: innerObject
11045 };
11046 }
11047
11048 return Object.assign(Object.assign({}, acc), innerObject);
11049 }, {});
11050}
11051
11052var styles$$ = {
11053 "Container": "Polaris-Modal-Dialog__Container",
11054 "Dialog": "Polaris-Modal-Dialog",
11055 "Modal": "Polaris-Modal-Dialog__Modal",
11056 "limitHeight": "Polaris-Modal-Dialog--limitHeight",
11057 "sizeLarge": "Polaris-Modal-Dialog--sizeLarge",
11058 "animateFadeUp": "Polaris-Modal-Dialog--animateFadeUp",
11059 "entering": "Polaris-Modal-Dialog--entering",
11060 "exiting": "Polaris-Modal-Dialog--exiting",
11061 "exited": "Polaris-Modal-Dialog--exited",
11062 "entered": "Polaris-Modal-Dialog--entered"
11063};
11064
11065function Dialog(_a) {
11066 var instant = _a.instant,
11067 labelledBy = _a.labelledBy,
11068 children = _a.children,
11069 onClose = _a.onClose,
11070 onExited = _a.onExited,
11071 onEntered = _a.onEntered,
11072 large = _a.large,
11073 limitHeight = _a.limitHeight,
11074 props = __rest(_a, ["instant", "labelledBy", "children", "onClose", "onExited", "onEntered", "large", "limitHeight"]);
11075
11076 var containerNode = useRef(null);
11077 var findDOMNode = useCallback(function () {
11078 return containerNode.current;
11079 }, []);
11080 var classes = classNames(styles$$.Modal, large && styles$$.sizeLarge, limitHeight && styles$$.limitHeight);
11081 var TransitionChild = instant ? Transition : FadeUp;
11082 useEffect(function () {
11083 containerNode.current && !containerNode.current.contains(document.activeElement) && focusFirstFocusableNode(containerNode.current);
11084 }, []);
11085 return React__default.createElement(TransitionChild, Object.assign({}, props, {
11086 findDOMNode: findDOMNode,
11087 mountOnEnter: true,
11088 unmountOnExit: true,
11089 timeout: durationBase,
11090 onEntered: onEntered,
11091 onExited: onExited
11092 }), React__default.createElement("div", {
11093 className: styles$$.Container,
11094 "data-polaris-layer": true,
11095 "data-polaris-overlay": true,
11096 ref: containerNode
11097 }, React__default.createElement(TrapFocus, null, React__default.createElement("div", {
11098 role: "dialog",
11099 "aria-labelledby": labelledBy,
11100 tabIndex: -1,
11101 className: styles$$.Dialog
11102 }, React__default.createElement("div", {
11103 className: classes
11104 }, React__default.createElement(KeypressListener, {
11105 keyCode: Key.Escape,
11106 handler: onClose
11107 }), children)))));
11108}
11109var fadeUpClasses = {
11110 appear: classNames(styles$$.animateFadeUp, styles$$.entering),
11111 appearActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11112 enter: classNames(styles$$.animateFadeUp, styles$$.entering),
11113 enterActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11114 exit: classNames(styles$$.animateFadeUp, styles$$.exiting),
11115 exitActive: classNames(styles$$.animateFadeUp, styles$$.exited)
11116};
11117
11118function FadeUp(_a) {
11119 var children = _a.children,
11120 props = __rest(_a, ["children"]);
11121
11122 return React__default.createElement(CSSTransition, Object.assign({}, props, {
11123 classNames: fadeUpClasses
11124 }), children);
11125}
11126
11127var styles$10 = {
11128 "Footer": "Polaris-Modal-Footer",
11129 "FooterContent": "Polaris-Modal-Footer__FooterContent"
11130};
11131
11132function Footer(_ref) {
11133 var primaryAction = _ref.primaryAction,
11134 secondaryActions = _ref.secondaryActions,
11135 children = _ref.children;
11136 var primaryActionButton = primaryAction && buttonsFrom(primaryAction, {
11137 primary: true
11138 }) || null;
11139 var secondaryActionButtons = secondaryActions && buttonsFrom(secondaryActions) || null;
11140 var actions = primaryActionButton || secondaryActionButtons ? React__default.createElement(ButtonGroup, null, secondaryActionButtons, primaryActionButton) : null;
11141 return React__default.createElement("div", {
11142 className: styles$10.Footer
11143 }, React__default.createElement("div", {
11144 className: styles$10.FooterContent
11145 }, React__default.createElement(Stack, {
11146 alignment: "center"
11147 }, React__default.createElement(Stack.Item, {
11148 fill: true
11149 }, children), actions)));
11150}
11151
11152var styles$11 = {
11153 "CloseButton": "Polaris-Modal-CloseButton",
11154 "withoutTitle": "Polaris-Modal-CloseButton--withoutTitle"
11155};
11156
11157function CloseButton(_ref) {
11158 var _ref$title = _ref.title,
11159 title = _ref$title === void 0 ? true : _ref$title,
11160 onClick = _ref.onClick;
11161 var i18n = useI18n();
11162 var className = classNames(styles$11.CloseButton, !title && styles$11.withoutTitle);
11163 return React__default.createElement("button", {
11164 onClick: onClick,
11165 className: className,
11166 "aria-label": i18n.translate('Polaris.Common.close')
11167 }, React__default.createElement(Icon, {
11168 source: MobileCancelMajorMonotone,
11169 color: "inkLighter"
11170 }));
11171}
11172
11173var styles$12 = {
11174 "Header": "Polaris-Modal-Header",
11175 "Title": "Polaris-Modal-Header__Title"
11176};
11177
11178function Header$1(_ref) {
11179 var id = _ref.id,
11180 children = _ref.children,
11181 onClose = _ref.onClose;
11182 return React__default.createElement("div", {
11183 className: styles$12.Header
11184 }, React__default.createElement("div", {
11185 id: id,
11186 className: styles$12.Title
11187 }, React__default.createElement(DisplayText, {
11188 element: "h2",
11189 size: "small"
11190 }, children)), React__default.createElement(CloseButton, {
11191 onClick: onClose
11192 }));
11193}
11194
11195var styles$13 = {
11196 "Section": "Polaris-Modal-Section",
11197 "subdued": "Polaris-Modal-Section--subdued",
11198 "flush": "Polaris-Modal-Section--flush"
11199};
11200
11201function Section$3(_ref) {
11202 var children = _ref.children,
11203 _ref$flush = _ref.flush,
11204 flush = _ref$flush === void 0 ? false : _ref$flush,
11205 _ref$subdued = _ref.subdued,
11206 subdued = _ref$subdued === void 0 ? false : _ref$subdued;
11207 var className = classNames(styles$13.Section, flush && styles$13.flush, subdued && styles$13.subdued);
11208 return React__default.createElement("section", {
11209 className: className
11210 }, children);
11211}
11212
11213var styles$14 = {
11214 "BodyWrapper": "Polaris-Modal__BodyWrapper",
11215 "Body": "Polaris-Modal__Body",
11216 "IFrame": "Polaris-Modal__IFrame",
11217 "Spinner": "Polaris-Modal__Spinner"
11218};
11219
11220var IFRAME_LOADING_HEIGHT = 200;
11221var DEFAULT_IFRAME_CONTENT_HEIGHT = 400;
11222var getUniqueID$1 = createUniqueIDFactory('modal-header');
11223var APP_BRIDGE_PROPS = ['title', 'size', 'message', 'src', 'primaryAction', 'secondaryActions'];
11224
11225var ModalInner =
11226/*#__PURE__*/
11227function (_React$Component) {
11228 _inherits(ModalInner, _React$Component);
11229
11230 function ModalInner() {
11231 var _this;
11232
11233 _classCallCheck(this, ModalInner);
11234
11235 _this = _possibleConstructorReturn(this, _getPrototypeOf(ModalInner).apply(this, arguments));
11236 _this.focusReturnPointNode = null;
11237 _this.state = {
11238 iframeHeight: IFRAME_LOADING_HEIGHT
11239 };
11240 _this.headerId = getUniqueID$1();
11241
11242 _this.handleEntered = function () {
11243 var onTransitionEnd = _this.props.onTransitionEnd;
11244
11245 if (onTransitionEnd) {
11246 onTransitionEnd();
11247 }
11248 };
11249
11250 _this.handleExited = function () {
11251 _this.setState({
11252 iframeHeight: IFRAME_LOADING_HEIGHT
11253 });
11254
11255 if (_this.focusReturnPointNode) {
11256 write(function () {
11257 return _this.focusReturnPointNode && focusFirstFocusableNode(_this.focusReturnPointNode, false);
11258 });
11259 }
11260 };
11261
11262 _this.handleIFrameLoad = function (evt) {
11263 var iframe = evt.target;
11264
11265 if (iframe && iframe.contentWindow) {
11266 try {
11267 _this.setState({
11268 iframeHeight: iframe.contentWindow.document.body.scrollHeight
11269 });
11270 } catch (_a) {
11271 _this.setState({
11272 iframeHeight: DEFAULT_IFRAME_CONTENT_HEIGHT
11273 });
11274 }
11275 }
11276
11277 var onIFrameLoad = _this.props.onIFrameLoad;
11278
11279 if (onIFrameLoad != null) {
11280 onIFrameLoad(evt);
11281 }
11282 };
11283
11284 return _this;
11285 }
11286
11287 _createClass(ModalInner, [{
11288 key: "componentDidMount",
11289 value: function componentDidMount() {
11290 if (this.props.polaris.appBridge == null) {
11291 return;
11292 } // eslint-disable-next-line no-console
11293
11294
11295 console.warn('Deprecation: Using `Modal` in an embedded app is deprecated and will be removed in v5.0. Use `Modal` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/modal');
11296 var transformProps = this.transformProps();
11297
11298 if (transformProps) {
11299 this.appBridgeModal = Modal$1.create(this.props.polaris.appBridge, transformProps);
11300 }
11301
11302 if (this.appBridgeModal) {
11303 this.appBridgeModal.subscribe(Modal$1.Action.CLOSE, this.props.onClose);
11304 }
11305
11306 var open = this.props.open;
11307
11308 if (open) {
11309 this.focusReturnPointNode = document.activeElement;
11310 this.appBridgeModal && this.appBridgeModal.dispatch(Modal$1.Action.OPEN);
11311 }
11312 }
11313 }, {
11314 key: "componentDidUpdate",
11315 value: function componentDidUpdate(prevProps) {
11316 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
11317 return;
11318 }
11319
11320 var open = this.props.open;
11321 var wasOpen = prevProps.open;
11322 var transformedProps = this.transformProps();
11323 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS);
11324 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS);
11325
11326 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps) && transformedProps) {
11327 if (isIframeModal(transformedProps)) {
11328 this.appBridgeModal.set(transformedProps);
11329 } else {
11330 this.appBridgeModal.set(transformedProps);
11331 }
11332 }
11333
11334 if (wasOpen !== open) {
11335 if (open) {
11336 this.appBridgeModal.dispatch(Modal$1.Action.OPEN);
11337 } else {
11338 this.appBridgeModal.dispatch(Modal$1.Action.CLOSE);
11339 }
11340 }
11341
11342 if (!wasOpen && open) {
11343 this.focusReturnPointNode = document.activeElement;
11344 } else if (wasOpen && !open && this.focusReturnPointNode != null && document.contains(this.focusReturnPointNode)) {
11345 this.focusReturnPointNode.focus();
11346 this.focusReturnPointNode = null;
11347 }
11348 }
11349 }, {
11350 key: "componentWillUnmount",
11351 value: function componentWillUnmount() {
11352 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
11353 return;
11354 }
11355
11356 this.appBridgeModal.unsubscribe();
11357 }
11358 }, {
11359 key: "render",
11360 value: function render() {
11361 if (this.props.polaris.appBridge != null) {
11362 return null;
11363 }
11364
11365 var _this$props = this.props,
11366 children = _this$props.children,
11367 title = _this$props.title,
11368 src = _this$props.src,
11369 iFrameName = _this$props.iFrameName,
11370 open = _this$props.open,
11371 instant = _this$props.instant,
11372 sectioned = _this$props.sectioned,
11373 loading = _this$props.loading,
11374 large = _this$props.large,
11375 limitHeight = _this$props.limitHeight,
11376 onClose = _this$props.onClose,
11377 footer = _this$props.footer,
11378 primaryAction = _this$props.primaryAction,
11379 secondaryActions = _this$props.secondaryActions,
11380 intl = _this$props.polaris.intl,
11381 onScrolledToBottom = _this$props.onScrolledToBottom;
11382 var iframeHeight = this.state.iframeHeight;
11383 var iframeTitle = intl.translate('Polaris.Modal.iFrameTitle');
11384 var dialog;
11385 var backdrop;
11386
11387 if (open) {
11388 var footerMarkup = !footer && !primaryAction && !secondaryActions ? null : React__default.createElement(Footer, {
11389 primaryAction: primaryAction,
11390 secondaryActions: secondaryActions
11391 }, footer);
11392 var content = sectioned ? wrapWithComponent(children, Section$3, {}) : children;
11393 var body = loading ? React__default.createElement("div", {
11394 className: styles$14.Spinner
11395 }, React__default.createElement(Spinner, null)) : content;
11396 var bodyMarkup = src ? React__default.createElement("iframe", {
11397 name: iFrameName,
11398 title: iframeTitle,
11399 src: src,
11400 className: styles$14.IFrame,
11401 onLoad: this.handleIFrameLoad,
11402 style: {
11403 height: "".concat(iframeHeight, "px")
11404 }
11405 }) : React__default.createElement(Scrollable, {
11406 shadow: true,
11407 className: styles$14.Body,
11408 onScrolledToBottom: onScrolledToBottom
11409 }, body);
11410 var headerMarkup = title ? React__default.createElement(Header$1, {
11411 id: this.headerId,
11412 onClose: onClose
11413 }, title) : React__default.createElement(CloseButton, {
11414 onClick: onClose,
11415 title: false
11416 });
11417 var labelledBy = title ? this.headerId : undefined;
11418 dialog = React__default.createElement(Dialog, {
11419 instant: instant,
11420 labelledBy: labelledBy,
11421 onClose: onClose,
11422 onEntered: this.handleEntered,
11423 onExited: this.handleExited,
11424 large: large,
11425 limitHeight: limitHeight
11426 }, headerMarkup, React__default.createElement("div", {
11427 className: styles$14.BodyWrapper
11428 }, bodyMarkup), footerMarkup);
11429 backdrop = React__default.createElement(Backdrop, null);
11430 }
11431
11432 var animated = !instant;
11433 return React__default.createElement(WithinContentContext.Provider, {
11434 value: true
11435 }, React__default.createElement(Portal, {
11436 idPrefix: "modal"
11437 }, React__default.createElement(TransitionGroup, {
11438 appear: animated,
11439 enter: animated,
11440 exit: animated
11441 }, dialog), backdrop));
11442 }
11443 }, {
11444 key: "transformProps",
11445 value: function transformProps() {
11446 var _this$props2 = this.props,
11447 title = _this$props2.title,
11448 size = _this$props2.size,
11449 message = _this$props2.message,
11450 src = _this$props2.src,
11451 primaryAction = _this$props2.primaryAction,
11452 secondaryActions = _this$props2.secondaryActions,
11453 polaris = _this$props2.polaris;
11454 var appBridge = polaris.appBridge;
11455 if (!appBridge) return;
11456 var safeTitle = typeof title === 'string' ? title : undefined;
11457 var safeSize = size != null ? Modal$1.Size[size] : undefined;
11458 var srcPayload = {};
11459
11460 if (src != null) {
11461 if (/^https?:\/\//.test(src)) {
11462 srcPayload.url = src;
11463 } else {
11464 srcPayload.path = src;
11465 }
11466 }
11467
11468 return Object.assign(Object.assign({
11469 title: safeTitle,
11470 message,
11471 size: safeSize
11472 }, srcPayload), {
11473 footer: {
11474 buttons: transformActions(appBridge, {
11475 primaryAction,
11476 secondaryActions
11477 })
11478 }
11479 });
11480 }
11481 }]);
11482
11483 return ModalInner;
11484}(React__default.Component);
11485
11486ModalInner.Section = Section$3;
11487
11488function isIframeModal(options) {
11489 return typeof options.url === 'string' || typeof options.path === 'string';
11490}
11491
11492var Modal = withAppProvider()(ModalInner);
11493
11494function DiscardConfirmationModal(_ref) {
11495 var open = _ref.open,
11496 onDiscard = _ref.onDiscard,
11497 onCancel = _ref.onCancel;
11498 var i18n = useI18n();
11499 return React__default.createElement(Modal, {
11500 title: i18n.translate('Polaris.DiscardConfirmationModal.title'),
11501 open: open,
11502 onClose: onCancel,
11503 primaryAction: {
11504 content: i18n.translate('Polaris.DiscardConfirmationModal.primaryAction'),
11505 destructive: true,
11506 onAction: onDiscard
11507 },
11508 secondaryActions: [{
11509 content: i18n.translate('Polaris.DiscardConfirmationModal.secondaryAction'),
11510 onAction: onCancel
11511 }],
11512 sectioned: true
11513 }, i18n.translate('Polaris.DiscardConfirmationModal.message'));
11514}
11515
11516var styles$15 = {
11517 "ContextualSaveBar": "Polaris-Frame-ContextualSaveBar",
11518 "LogoContainer": "Polaris-Frame-ContextualSaveBar__LogoContainer",
11519 "Contents": "Polaris-Frame-ContextualSaveBar__Contents",
11520 "Message": "Polaris-Frame-ContextualSaveBar__Message",
11521 "ActionContainer": "Polaris-Frame-ContextualSaveBar__ActionContainer",
11522 "Action": "Polaris-Frame-ContextualSaveBar__Action",
11523 "newDesignLanguage": "Polaris-Frame-ContextualSaveBar--newDesignLanguage"
11524};
11525
11526function ContextualSaveBar$1(_ref) {
11527 var alignContentFlush = _ref.alignContentFlush,
11528 message = _ref.message,
11529 saveAction = _ref.saveAction,
11530 discardAction = _ref.discardAction;
11531 var i18n = useI18n();
11532
11533 var _useTheme = useTheme(),
11534 logo = _useTheme.logo;
11535
11536 var _useFeatures = useFeatures(),
11537 _useFeatures$newDesig = _useFeatures.newDesignLanguage,
11538 newDesignLanguage = _useFeatures$newDesig === void 0 ? false : _useFeatures$newDesig;
11539
11540 var _useToggle = useToggle(false),
11541 discardConfirmationModalVisible = _useToggle.value,
11542 toggleDiscardConfirmationModal = _useToggle.toggle,
11543 closeDiscardConfirmationModal = _useToggle.setFalse;
11544
11545 var handleDiscardAction = useCallback(function () {
11546 if (discardAction && discardAction.onAction) {
11547 discardAction.onAction();
11548 }
11549
11550 closeDiscardConfirmationModal();
11551 }, [closeDiscardConfirmationModal, discardAction]);
11552 var discardActionContent = discardAction && discardAction.content ? discardAction.content : i18n.translate('Polaris.ContextualSaveBar.discard');
11553 var discardActionHandler;
11554
11555 if (discardAction && discardAction.discardConfirmationModal) {
11556 discardActionHandler = toggleDiscardConfirmationModal;
11557 } else if (discardAction) {
11558 discardActionHandler = discardAction.onAction;
11559 }
11560
11561 var discardConfirmationModalMarkup = discardAction && discardAction.onAction && discardAction.discardConfirmationModal && React__default.createElement(DiscardConfirmationModal, {
11562 open: discardConfirmationModalVisible,
11563 onCancel: toggleDiscardConfirmationModal,
11564 onDiscard: handleDiscardAction
11565 });
11566 var discardActionMarkup = discardAction && React__default.createElement(Button, {
11567 url: discardAction.url,
11568 onClick: discardActionHandler,
11569 loading: discardAction.loading,
11570 disabled: discardAction.disabled,
11571 accessibilityLabel: discardAction.content
11572 }, discardActionContent);
11573 var saveActionContent = saveAction && saveAction.content ? saveAction.content : i18n.translate('Polaris.ContextualSaveBar.save');
11574 var saveActionMarkup = saveAction && React__default.createElement(Button, {
11575 primary: true,
11576 url: saveAction.url,
11577 onClick: saveAction.onAction,
11578 loading: saveAction.loading,
11579 disabled: saveAction.disabled,
11580 accessibilityLabel: saveAction.content
11581 }, saveActionContent);
11582 var width = getWidth(logo, 104);
11583 var imageMarkup = logo && React__default.createElement(Image, {
11584 style: {
11585 width
11586 },
11587 source: logo.contextualSaveBarSource || '',
11588 alt: ""
11589 });
11590 var logoMarkup = alignContentFlush ? null : React__default.createElement("div", {
11591 className: styles$15.LogoContainer,
11592 style: {
11593 width
11594 }
11595 }, imageMarkup);
11596 var contexualSaveBarClassName = classNames(styles$15.ContextualSaveBar, newDesignLanguage && styles$15.newDesignLanguage);
11597 return React__default.createElement(ThemeProvider, {
11598 theme: {
11599 colorScheme: 'inverse'
11600 }
11601 }, React__default.createElement("div", {
11602 className: contexualSaveBarClassName
11603 }, logoMarkup, React__default.createElement("div", {
11604 className: styles$15.Contents
11605 }, React__default.createElement("h2", {
11606 className: styles$15.Message
11607 }, message), React__default.createElement("div", {
11608 className: styles$15.ActionContainer
11609 }, React__default.createElement(Stack, {
11610 spacing: "tight",
11611 wrap: false
11612 }, discardActionMarkup, saveActionMarkup)))), discardConfirmationModalMarkup);
11613}
11614
11615var styles$16 = {
11616 "startFade": "Polaris-Frame-CSSAnimation--startFade",
11617 "endFade": "Polaris-Frame-CSSAnimation--endFade",
11618 "startFadeUp": "Polaris-Frame-CSSAnimation--startFadeUp",
11619 "endFadeUp": "Polaris-Frame-CSSAnimation--endFadeUp"
11620};
11621
11622var TransitionStatus$1;
11623
11624(function (TransitionStatus) {
11625 TransitionStatus["Entering"] = "entering";
11626 TransitionStatus["Entered"] = "entered";
11627 TransitionStatus["Exiting"] = "exiting";
11628 TransitionStatus["Exited"] = "exited";
11629})(TransitionStatus$1 || (TransitionStatus$1 = {}));
11630
11631function CSSAnimation(_ref) {
11632 var inProp = _ref.in,
11633 className = _ref.className,
11634 type = _ref.type,
11635 children = _ref.children;
11636
11637 var _useState = useState(inProp ? TransitionStatus$1.Entering : TransitionStatus$1.Exited),
11638 _useState2 = _slicedToArray(_useState, 2),
11639 transitionStatus = _useState2[0],
11640 setTransitionStatus = _useState2[1];
11641
11642 var isMounted = useRef(false);
11643 var node = useRef(null);
11644 useEffect(function () {
11645 if (!isMounted.current) return;
11646 transitionStatus === TransitionStatus$1.Entering && changeTransitionStatus(TransitionStatus$1.Entered);
11647 }, [transitionStatus]);
11648 useEffect(function () {
11649 if (!isMounted.current) return;
11650 inProp && changeTransitionStatus(TransitionStatus$1.Entering);
11651 !inProp && changeTransitionStatus(TransitionStatus$1.Exiting);
11652 }, [inProp]);
11653 useEffect(function () {
11654 isMounted.current = true;
11655 }, []);
11656 var wrapperClassName = classNames(className, styles$16[variationName('start', type)], inProp && styles$16[variationName('end', type)]);
11657 var content = transitionStatus === TransitionStatus$1.Exited && !inProp ? null : children;
11658 return React__default.createElement("div", {
11659 className: wrapperClassName,
11660 ref: node,
11661 onTransitionEnd: handleTransitionEnd
11662 }, content);
11663
11664 function handleTransitionEnd() {
11665 transitionStatus === TransitionStatus$1.Exiting && changeTransitionStatus(TransitionStatus$1.Exited);
11666 }
11667
11668 function changeTransitionStatus(transitionStatus) {
11669 setTransitionStatus(transitionStatus); // Forcing a reflow to enable the animation
11670
11671 if (transitionStatus === TransitionStatus$1.Entering) node.current && node.current.getBoundingClientRect();
11672 }
11673}
11674
11675var styles$17 = {
11676 "Frame": "Polaris-Frame",
11677 "Navigation": "Polaris-Frame__Navigation",
11678 "Navigation-newDesignLanguage": "Polaris-Frame__Navigation--newDesignLanguage",
11679 "Navigation-enter": "Polaris-Frame__Navigation--enter",
11680 "Navigation-enterActive": "Polaris-Frame__Navigation--enterActive",
11681 "Navigation-exit": "Polaris-Frame__Navigation--exit",
11682 "Navigation-exitActive": "Polaris-Frame__Navigation--exitActive",
11683 "NavigationDismiss": "Polaris-Frame__NavigationDismiss",
11684 "Navigation-visible": "Polaris-Frame__Navigation--visible",
11685 "TopBar": "Polaris-Frame__TopBar",
11686 "TopBar-newDesignLanguage": "Polaris-Frame__TopBar--newDesignLanguage",
11687 "ContextualSaveBar": "Polaris-Frame__ContextualSaveBar",
11688 "ContextualSaveBar-newDesignLanguage": "Polaris-Frame__ContextualSaveBar--newDesignLanguage",
11689 "Main": "Polaris-Frame__Main",
11690 "hasNav": "Polaris-Frame--hasNav",
11691 "hasTopBar": "Polaris-Frame--hasTopBar",
11692 "Main-newDesignLanguage": "Polaris-Frame__Main--newDesignLanguage",
11693 "Content": "Polaris-Frame__Content",
11694 "GlobalRibbonContainer": "Polaris-Frame__GlobalRibbonContainer",
11695 "GlobalRibbonContainer-newDesignLanguage": "Polaris-Frame__GlobalRibbonContainer--newDesignLanguage",
11696 "LoadingBar": "Polaris-Frame__LoadingBar",
11697 "Skip": "Polaris-Frame__Skip",
11698 "focused": "Polaris-Frame--focused",
11699 "SkipAnchor": "Polaris-Frame__SkipAnchor",
11700 "newDesignLanguage": "Polaris-Frame--newDesignLanguage"
11701};
11702
11703var GLOBAL_RIBBON_CUSTOM_PROPERTY = '--global-ribbon-height';
11704var APP_FRAME_MAIN = 'AppFrameMain';
11705var APP_FRAME_MAIN_ANCHOR_TARGET = 'AppFrameMainContent';
11706var APP_FRAME_NAV = 'AppFrameNav';
11707var APP_FRAME_TOP_BAR = 'AppFrameTopBar';
11708var APP_FRAME_LOADING_BAR = 'AppFrameLoadingBar';
11709
11710var FrameInner =
11711/*#__PURE__*/
11712function (_React$PureComponent) {
11713 _inherits(FrameInner, _React$PureComponent);
11714
11715 function FrameInner() {
11716 var _this;
11717
11718 _classCallCheck(this, FrameInner);
11719
11720 _this = _possibleConstructorReturn(this, _getPrototypeOf(FrameInner).apply(this, arguments));
11721 _this.state = {
11722 skipFocused: false,
11723 globalRibbonHeight: 0,
11724 loadingStack: 0,
11725 toastMessages: [],
11726 showContextualSaveBar: false
11727 };
11728 _this.contextualSaveBar = null;
11729 _this.globalRibbonContainer = null;
11730 _this.navigationNode = createRef();
11731 _this.skipToMainContentTargetNode = _this.props.skipToContentTarget || React__default.createRef();
11732
11733 _this.setGlobalRibbonHeight = function () {
11734 var _assertThisInitialize = _assertThisInitialized(_this),
11735 globalRibbonContainer = _assertThisInitialize.globalRibbonContainer;
11736
11737 if (globalRibbonContainer) {
11738 _this.setState({
11739 globalRibbonHeight: globalRibbonContainer.offsetHeight
11740 }, _this.setGlobalRibbonRootProperty);
11741 }
11742 };
11743
11744 _this.setGlobalRibbonRootProperty = function () {
11745 var globalRibbonHeight = _this.state.globalRibbonHeight;
11746 setRootProperty(GLOBAL_RIBBON_CUSTOM_PROPERTY, "".concat(globalRibbonHeight, "px"), null);
11747 };
11748
11749 _this.showToast = function (toast) {
11750 _this.setState(function (_ref) {
11751 var toastMessages = _ref.toastMessages;
11752 var hasToastById = toastMessages.find(function (_ref2) {
11753 var id = _ref2.id;
11754 return id === toast.id;
11755 }) != null;
11756 return {
11757 toastMessages: hasToastById ? toastMessages : [].concat(_toConsumableArray(toastMessages), [toast])
11758 };
11759 });
11760 };
11761
11762 _this.hideToast = function (_ref3) {
11763 var id = _ref3.id;
11764
11765 _this.setState(function (_ref4) {
11766 var toastMessages = _ref4.toastMessages;
11767 return {
11768 toastMessages: toastMessages.filter(function (_ref5) {
11769 var toastId = _ref5.id;
11770 return id !== toastId;
11771 })
11772 };
11773 });
11774 };
11775
11776 _this.setContextualSaveBar = function (props) {
11777 var showContextualSaveBar = _this.state.showContextualSaveBar;
11778 _this.contextualSaveBar = Object.assign({}, props);
11779
11780 if (showContextualSaveBar === true) {
11781 _this.forceUpdate();
11782 } else {
11783 _this.setState({
11784 showContextualSaveBar: true
11785 });
11786 }
11787 };
11788
11789 _this.removeContextualSaveBar = function () {
11790 _this.contextualSaveBar = null;
11791
11792 _this.setState({
11793 showContextualSaveBar: false
11794 });
11795 };
11796
11797 _this.startLoading = function () {
11798 _this.setState(function (_ref6) {
11799 var loadingStack = _ref6.loadingStack;
11800 return {
11801 loadingStack: loadingStack + 1
11802 };
11803 });
11804 };
11805
11806 _this.stopLoading = function () {
11807 _this.setState(function (_ref7) {
11808 var loadingStack = _ref7.loadingStack;
11809 return {
11810 loadingStack: Math.max(0, loadingStack - 1)
11811 };
11812 });
11813 };
11814
11815 _this.handleResize = function () {
11816 if (_this.props.globalRibbon) {
11817 _this.setGlobalRibbonHeight();
11818 }
11819 };
11820
11821 _this.handleFocus = function () {
11822 _this.setState({
11823 skipFocused: true
11824 });
11825 };
11826
11827 _this.handleBlur = function () {
11828 _this.setState({
11829 skipFocused: false
11830 });
11831 };
11832
11833 _this.handleClick = function () {
11834 _this.skipToMainContentTargetNode.current && _this.skipToMainContentTargetNode.current.focus();
11835 };
11836
11837 _this.handleNavigationDismiss = function () {
11838 var onNavigationDismiss = _this.props.onNavigationDismiss;
11839
11840 if (onNavigationDismiss != null) {
11841 onNavigationDismiss();
11842 }
11843 };
11844
11845 _this.setGlobalRibbonContainer = function (node) {
11846 _this.globalRibbonContainer = node;
11847 };
11848
11849 _this.handleNavKeydown = function (event) {
11850 var key = event.key;
11851 var _this$props = _this.props,
11852 isNavigationCollapsed = _this$props.polaris.mediaQuery.isNavigationCollapsed,
11853 showMobileNavigation = _this$props.showMobileNavigation;
11854 var mobileNavShowing = isNavigationCollapsed && showMobileNavigation;
11855
11856 if (mobileNavShowing && key === 'Escape') {
11857 _this.handleNavigationDismiss();
11858 }
11859 };
11860
11861 _this.findNavigationNode = function () {
11862 return _this.navigationNode.current;
11863 };
11864
11865 return _this;
11866 }
11867
11868 _createClass(FrameInner, [{
11869 key: "componentDidMount",
11870 value: function componentDidMount() {
11871 this.handleResize();
11872
11873 if (this.props.globalRibbon) {
11874 return;
11875 }
11876
11877 this.setGlobalRibbonRootProperty();
11878 }
11879 }, {
11880 key: "componentDidUpdate",
11881 value: function componentDidUpdate(prevProps) {
11882 if (this.props.globalRibbon !== prevProps.globalRibbon) {
11883 this.setGlobalRibbonHeight();
11884 }
11885 }
11886 }, {
11887 key: "render",
11888 value: function render() {
11889 var _this$state = this.state,
11890 skipFocused = _this$state.skipFocused,
11891 loadingStack = _this$state.loadingStack,
11892 toastMessages = _this$state.toastMessages,
11893 showContextualSaveBar = _this$state.showContextualSaveBar;
11894 var _this$props2 = this.props,
11895 children = _this$props2.children,
11896 navigation = _this$props2.navigation,
11897 topBar = _this$props2.topBar,
11898 globalRibbon = _this$props2.globalRibbon,
11899 _this$props2$showMobi = _this$props2.showMobileNavigation,
11900 showMobileNavigation = _this$props2$showMobi === void 0 ? false : _this$props2$showMobi,
11901 skipToContentTarget = _this$props2.skipToContentTarget,
11902 _this$props2$polaris = _this$props2.polaris,
11903 intl = _this$props2$polaris.intl,
11904 isNavigationCollapsed = _this$props2$polaris.mediaQuery.isNavigationCollapsed;
11905
11906 var _ref8 = this.context || {},
11907 newDesignLanguage = _ref8.newDesignLanguage;
11908
11909 var navClassName = classNames(styles$17.Navigation, showMobileNavigation && styles$17['Navigation-visible'], newDesignLanguage && styles$17['Navigation-newDesignLanguage']);
11910 var mobileNavHidden = isNavigationCollapsed && !showMobileNavigation;
11911 var mobileNavShowing = isNavigationCollapsed && showMobileNavigation;
11912 var tabIndex = mobileNavShowing ? 0 : -1;
11913 var navigationMarkup = navigation ? React__default.createElement(TrapFocus, {
11914 trapping: mobileNavShowing
11915 }, React__default.createElement(CSSTransition, {
11916 findDOMNode: this.findNavigationNode,
11917 appear: isNavigationCollapsed,
11918 exit: isNavigationCollapsed,
11919 in: showMobileNavigation,
11920 timeout: durationSlow,
11921 classNames: navTransitionClasses
11922 }, React__default.createElement("div", {
11923 ref: this.navigationNode,
11924 className: navClassName,
11925 onKeyDown: this.handleNavKeydown,
11926 id: APP_FRAME_NAV,
11927 key: "NavContent",
11928 hidden: mobileNavHidden
11929 }, navigation, React__default.createElement("button", {
11930 type: "button",
11931 className: styles$17.NavigationDismiss,
11932 onClick: this.handleNavigationDismiss,
11933 "aria-hidden": mobileNavHidden || !isNavigationCollapsed && !showMobileNavigation,
11934 "aria-label": intl.translate('Polaris.Frame.Navigation.closeMobileNavigationLabel'),
11935 tabIndex: tabIndex
11936 }, React__default.createElement(Icon, {
11937 source: MobileCancelMajorMonotone,
11938 color: "white"
11939 }))))) : null;
11940 var loadingMarkup = loadingStack > 0 ? React__default.createElement("div", {
11941 className: styles$17.LoadingBar,
11942 id: APP_FRAME_LOADING_BAR
11943 }, React__default.createElement(Loading, null)) : null;
11944 var contextualSaveBarClassName = classNames(styles$17.ContextualSaveBar, newDesignLanguage && styles$17['ContextualSaveBar-newDesignLanguage']);
11945 var contextualSaveBarMarkup = React__default.createElement(CSSAnimation, {
11946 in: showContextualSaveBar,
11947 className: contextualSaveBarClassName,
11948 type: newDesignLanguage ? 'fadeUp' : 'fade'
11949 }, React__default.createElement(ContextualSaveBar$1, this.contextualSaveBar));
11950 var topBarClassName = classNames(styles$17.TopBar, newDesignLanguage && styles$17['TopBar-newDesignLanguage']);
11951 var topBarMarkup = topBar ? React__default.createElement("div", Object.assign({
11952 className: topBarClassName
11953 }, layer.props, dataPolarisTopBar.props, {
11954 id: APP_FRAME_TOP_BAR
11955 }), topBar) : null;
11956 var globalRibbonClassName = classNames(styles$17.GlobalRibbonContainer, newDesignLanguage && styles$17['GlobalRibbonContainer-newDesignLanguage']);
11957 var globalRibbonMarkup = globalRibbon ? React__default.createElement("div", {
11958 className: globalRibbonClassName,
11959 ref: this.setGlobalRibbonContainer
11960 }, globalRibbon) : null;
11961 var skipClassName = classNames(styles$17.Skip, skipFocused && styles$17.focused);
11962 var skipTarget = skipToContentTarget ? skipToContentTarget.current && skipToContentTarget.current.id || '' : APP_FRAME_MAIN_ANCHOR_TARGET;
11963 var skipMarkup = React__default.createElement("div", {
11964 className: skipClassName
11965 }, React__default.createElement("a", {
11966 href: "#".concat(skipTarget),
11967 onFocus: this.handleFocus,
11968 onBlur: this.handleBlur,
11969 onClick: this.handleClick,
11970 className: styles$17.SkipAnchor
11971 }, intl.translate('Polaris.Frame.skipToContent')));
11972 var navigationAttributes = navigation ? {
11973 'data-has-navigation': true
11974 } : {};
11975 var frameClassName = classNames(styles$17.Frame, navigation && styles$17.hasNav, topBar && styles$17.hasTopBar);
11976 var mainClassName = classNames(styles$17.Main, newDesignLanguage && styles$17['Main-newDesignLanguage']);
11977 var navigationOverlayMarkup = showMobileNavigation && isNavigationCollapsed ? React__default.createElement(Backdrop, {
11978 belowNavigation: true,
11979 onClick: this.handleNavigationDismiss,
11980 onTouchStart: this.handleNavigationDismiss
11981 }) : null;
11982 var skipToMainContentTarget = skipToContentTarget ? null : // eslint-disable-next-line jsx-a11y/anchor-is-valid
11983 React__default.createElement("a", {
11984 id: APP_FRAME_MAIN_ANCHOR_TARGET,
11985 ref: this.skipToMainContentTargetNode,
11986 tabIndex: -1
11987 });
11988 var context = {
11989 showToast: this.showToast,
11990 hideToast: this.hideToast,
11991 startLoading: this.startLoading,
11992 stopLoading: this.stopLoading,
11993 setContextualSaveBar: this.setContextualSaveBar,
11994 removeContextualSaveBar: this.removeContextualSaveBar
11995 };
11996 return React__default.createElement(FrameContext.Provider, {
11997 value: context
11998 }, React__default.createElement("div", Object.assign({
11999 className: frameClassName
12000 }, layer.props, navigationAttributes), skipMarkup, topBarMarkup, navigationMarkup, contextualSaveBarMarkup, loadingMarkup, navigationOverlayMarkup, React__default.createElement("main", {
12001 className: mainClassName,
12002 id: APP_FRAME_MAIN,
12003 "data-has-global-ribbon": Boolean(globalRibbon)
12004 }, skipToMainContentTarget, React__default.createElement("div", {
12005 className: styles$17.Content
12006 }, children)), React__default.createElement(ToastManager, {
12007 toastMessages: toastMessages
12008 }), globalRibbonMarkup, React__default.createElement(EventListener, {
12009 event: "resize",
12010 handler: this.handleResize
12011 })));
12012 }
12013 }]);
12014
12015 return FrameInner;
12016}(React__default.PureComponent);
12017
12018FrameInner.contextType = FeaturesContext;
12019var navTransitionClasses = {
12020 enter: classNames(styles$17['Navigation-enter']),
12021 enterActive: classNames(styles$17['Navigation-enterActive']),
12022 enterDone: classNames(styles$17['Navigation-enterActive']),
12023 exit: classNames(styles$17['Navigation-exit']),
12024 exitActive: classNames(styles$17['Navigation-exitActive'])
12025};
12026var Frame = withAppProvider()(FrameInner);
12027
12028var styles$18 = {
12029 "Indicator": "Polaris-Indicator",
12030 "pulseIndicator": "Polaris-Indicator--pulseIndicator",
12031 "bounce": "Polaris-Indicator--bounce",
12032 "pulse": "Polaris-Indicator--pulse"
12033};
12034
12035function Indicator(_ref) {
12036 var _ref$pulse = _ref.pulse,
12037 pulse = _ref$pulse === void 0 ? true : _ref$pulse;
12038 var className = classNames(styles$18.Indicator, pulse && styles$18.pulseIndicator);
12039 return React__default.createElement("span", {
12040 className: className
12041 });
12042}
12043
12044var styles$19 = {
12045 "KeyboardKey": "Polaris-KeyboardKey"
12046};
12047
12048function KeyboardKey(_ref) {
12049 var children = _ref.children;
12050 var key = children || '';
12051 key = key.length > 1 ? key.toLowerCase() : key.toUpperCase();
12052 return React__default.createElement("kbd", {
12053 className: styles$19.KeyboardKey
12054 }, key);
12055}
12056
12057var styles$1a = {
12058 "Layout": "Polaris-Layout",
12059 "Section": "Polaris-Layout__Section",
12060 "Section-secondary": "Polaris-Layout__Section--secondary",
12061 "Section-fullWidth": "Polaris-Layout__Section--fullWidth",
12062 "Section-oneHalf": "Polaris-Layout__Section--oneHalf",
12063 "Section-oneThird": "Polaris-Layout__Section--oneThird",
12064 "AnnotatedSection": "Polaris-Layout__AnnotatedSection",
12065 "AnnotationWrapper": "Polaris-Layout__AnnotationWrapper",
12066 "AnnotationContent": "Polaris-Layout__AnnotationContent",
12067 "Annotation": "Polaris-Layout__Annotation",
12068 "AnnotationDescription": "Polaris-Layout__AnnotationDescription"
12069};
12070
12071function AnnotatedSection(props) {
12072 var children = props.children,
12073 title = props.title,
12074 description = props.description;
12075 var descriptionMarkup = typeof description === 'string' ? React__default.createElement("p", null, description) : description;
12076 return React__default.createElement("div", {
12077 className: styles$1a.AnnotatedSection
12078 }, React__default.createElement("div", {
12079 className: styles$1a.AnnotationWrapper
12080 }, React__default.createElement("div", {
12081 className: styles$1a.Annotation
12082 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title), descriptionMarkup && React__default.createElement("div", {
12083 className: styles$1a.AnnotationDescription
12084 }, descriptionMarkup))), React__default.createElement("div", {
12085 className: styles$1a.AnnotationContent
12086 }, children)));
12087}
12088
12089function Section$4(_ref) {
12090 var children = _ref.children,
12091 secondary = _ref.secondary,
12092 fullWidth = _ref.fullWidth,
12093 oneHalf = _ref.oneHalf,
12094 oneThird = _ref.oneThird;
12095 var className = classNames(styles$1a.Section, secondary && styles$1a['Section-secondary'], fullWidth && styles$1a['Section-fullWidth'], oneHalf && styles$1a['Section-oneHalf'], oneThird && styles$1a['Section-oneThird']);
12096 return React__default.createElement("div", {
12097 className: className
12098 }, children);
12099}
12100
12101var Layout = function Layout(_ref) {
12102 var sectioned = _ref.sectioned,
12103 children = _ref.children;
12104 var content = sectioned ? React__default.createElement(Section$4, null, children) : children;
12105 return React__default.createElement("div", {
12106 className: styles$1a.Layout
12107 }, content);
12108};
12109Layout.AnnotatedSection = AnnotatedSection;
12110Layout.Section = Section$4;
12111
12112var styles$1b = {
12113 "Link": "Polaris-Link",
12114 "IconLockup": "Polaris-Link__IconLockup",
12115 "IconLayout": "Polaris-Link__IconLayout",
12116 "monochrome": "Polaris-Link--monochrome"
12117};
12118
12119function Link(_ref) {
12120 var url = _ref.url,
12121 children = _ref.children,
12122 onClick = _ref.onClick,
12123 external = _ref.external,
12124 id = _ref.id,
12125 monochrome = _ref.monochrome;
12126 var i18n = useI18n();
12127 var childrenMarkup = children;
12128
12129 if (external && typeof children === 'string') {
12130 var iconLabel = i18n.translate('Polaris.Common.newWindowAccessibilityHint');
12131 childrenMarkup = React__default.createElement(React__default.Fragment, null, children, React__default.createElement("span", {
12132 className: styles$1b.IconLockup
12133 }, React__default.createElement("span", {
12134 className: styles$1b.IconLayout
12135 }, React__default.createElement(Icon, {
12136 accessibilityLabel: iconLabel,
12137 source: ExternalSmallMinor
12138 }))));
12139 }
12140
12141 return React__default.createElement(BannerContext.Consumer, null, function (BannerContext) {
12142 var shouldBeMonochrome = monochrome || BannerContext;
12143 var className = classNames(styles$1b.Link, shouldBeMonochrome && styles$1b.monochrome);
12144 return url ? React__default.createElement(UnstyledLink, {
12145 onClick: onClick,
12146 className: className,
12147 url: url,
12148 external: external,
12149 id: id
12150 }, childrenMarkup) : React__default.createElement("button", {
12151 type: "button",
12152 onClick: onClick,
12153 className: className,
12154 id: id
12155 }, childrenMarkup);
12156 });
12157}
12158
12159var styles$1c = {
12160 "List": "Polaris-List",
12161 "typeNumber": "Polaris-List--typeNumber",
12162 "Item": "Polaris-List__Item"
12163};
12164
12165function Item$6(_ref) {
12166 var children = _ref.children;
12167 return React__default.createElement("li", {
12168 className: styles$1c.Item
12169 }, children);
12170}
12171
12172var List =
12173/*#__PURE__*/
12174function (_React$PureComponent) {
12175 _inherits(List, _React$PureComponent);
12176
12177 function List() {
12178 _classCallCheck(this, List);
12179
12180 return _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
12181 }
12182
12183 _createClass(List, [{
12184 key: "render",
12185 value: function render() {
12186 var _this$props = this.props,
12187 children = _this$props.children,
12188 _this$props$type = _this$props.type,
12189 type = _this$props$type === void 0 ? 'bullet' : _this$props$type;
12190 var className = classNames(styles$1c.List, type && styles$1c[variationName('type', type)]);
12191 var ListElement = type === 'bullet' ? 'ul' : 'ol';
12192 return React__default.createElement(ListElement, {
12193 className: className
12194 }, children);
12195 }
12196 }]);
12197
12198 return List;
12199}(React__default.PureComponent);
12200List.Item = Item$6;
12201
12202var Loading$1 = React__default.memo(function Loading() {
12203 var appBridgeLoading = useRef();
12204 var appBridge = useAppBridge();
12205
12206 var _useFrame = useFrame(),
12207 startLoading = _useFrame.startLoading,
12208 stopLoading = _useFrame.stopLoading;
12209
12210 useEffect(function () {
12211 if (appBridge == null) {
12212 startLoading();
12213 } else {
12214 // eslint-disable-next-line no-console
12215 console.warn('Deprecation: Using `Loading` in an embedded app is deprecated and will be removed in v5.0. Use `Loading` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/loading');
12216 appBridgeLoading.current = Loading$2.create(appBridge);
12217 appBridgeLoading.current.dispatch(Loading$2.Action.START);
12218 }
12219
12220 return function () {
12221 if (appBridge == null) {
12222 stopLoading();
12223 } else {
12224 appBridgeLoading.current && appBridgeLoading.current.dispatch(Loading$2.Action.STOP);
12225 }
12226 };
12227 }, [appBridge, startLoading, stopLoading]);
12228 return null;
12229});
12230
12231var NavigationContext = React__default.createContext({
12232 location: ''
12233});
12234
12235var styles$1d = {
12236 "Navigation": "Polaris-Navigation",
12237 "Navigation-newDesignLanguage": "Polaris-Navigation__Navigation--newDesignLanguage",
12238 "Navigation-noMedia": "Polaris-Navigation__Navigation--noMedia",
12239 "UserMenu": "Polaris-Navigation__UserMenu",
12240 "ContextControl": "Polaris-Navigation__ContextControl",
12241 "PrimaryNavigation": "Polaris-Navigation__PrimaryNavigation",
12242 "LogoContainer": "Polaris-Navigation__LogoContainer",
12243 "Logo": "Polaris-Navigation__Logo",
12244 "LogoLink": "Polaris-Navigation__LogoLink",
12245 "Item": "Polaris-Navigation__Item",
12246 "Icon": "Polaris-Navigation__Icon",
12247 "Item-selected": "Polaris-Navigation__Item--selected",
12248 "Item-disabled": "Polaris-Navigation__Item--disabled",
12249 "Badge": "Polaris-Navigation__Badge",
12250 "subNavigationActive": "Polaris-Navigation--subNavigationActive",
12251 "ListItem": "Polaris-Navigation__ListItem",
12252 "RollupSection": "Polaris-Navigation__RollupSection",
12253 "SecondaryNavigation": "Polaris-Navigation__SecondaryNavigation",
12254 "fade-in": "Polaris-Navigation__fade--in",
12255 "ListItem-hasAction": "Polaris-Navigation__ListItem--hasAction",
12256 "ItemWrapper": "Polaris-Navigation__ItemWrapper",
12257 "Text": "Polaris-Navigation__Text",
12258 "SecondaryAction": "Polaris-Navigation__SecondaryAction",
12259 "List": "Polaris-Navigation__List",
12260 "Section": "Polaris-Navigation__Section",
12261 "Section-fill": "Polaris-Navigation__Section--fill",
12262 "Section-withSeparator": "Polaris-Navigation__Section--withSeparator",
12263 "SectionHeading": "Polaris-Navigation__SectionHeading",
12264 "Action": "Polaris-Navigation__Action",
12265 "RollupToggle": "Polaris-Navigation__RollupToggle",
12266 "Indicator": "Polaris-Navigation__Indicator"
12267};
12268
12269function Secondary(_ref) {
12270 var children = _ref.children,
12271 expanded = _ref.expanded;
12272 var id = useUniqueId('SecondaryNavigation');
12273 return React__default.createElement(Collapsible, {
12274 id: id,
12275 open: expanded
12276 }, React__default.createElement("ul", {
12277 className: styles$1d.List
12278 }, children));
12279}
12280
12281var MatchState;
12282
12283(function (MatchState) {
12284 MatchState[MatchState["MatchForced"] = 0] = "MatchForced";
12285 MatchState[MatchState["MatchUrl"] = 1] = "MatchUrl";
12286 MatchState[MatchState["MatchPaths"] = 2] = "MatchPaths";
12287 MatchState[MatchState["Excluded"] = 3] = "Excluded";
12288 MatchState[MatchState["NoMatch"] = 4] = "NoMatch";
12289})(MatchState || (MatchState = {}));
12290
12291function Item$7(_ref) {
12292 var url = _ref.url,
12293 icon = _ref.icon,
12294 label = _ref.label,
12295 _ref$subNavigationIte = _ref.subNavigationItems,
12296 subNavigationItems = _ref$subNavigationIte === void 0 ? [] : _ref$subNavigationIte,
12297 secondaryAction = _ref.secondaryAction,
12298 disabled = _ref.disabled,
12299 onClick = _ref.onClick,
12300 accessibilityLabel = _ref.accessibilityLabel,
12301 selectedOverride = _ref.selected,
12302 badge = _ref.badge,
12303 isNew = _ref.new,
12304 matches = _ref.matches,
12305 exactMatch = _ref.exactMatch,
12306 matchPaths = _ref.matchPaths,
12307 excludePaths = _ref.excludePaths;
12308 var i18n = useI18n();
12309
12310 var _useMediaQuery = useMediaQuery(),
12311 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
12312
12313 var _useContext = useContext(NavigationContext),
12314 location = _useContext.location,
12315 onNavigationDismiss = _useContext.onNavigationDismiss;
12316
12317 var _useState = useState(false),
12318 _useState2 = _slicedToArray(_useState, 2),
12319 expanded = _useState2[0],
12320 setExpanded = _useState2[1];
12321
12322 useEffect(function () {
12323 if (!isNavigationCollapsed && expanded) {
12324 setExpanded(false);
12325 }
12326 }, [expanded, isNavigationCollapsed]);
12327 var tabIndex = disabled ? -1 : 0;
12328 var hasNewChild = subNavigationItems.filter(function (subNavigationItem) {
12329 return subNavigationItem.new;
12330 }).length > 0;
12331 var indicatorMarkup = hasNewChild ? React__default.createElement("span", {
12332 className: styles$1d.Indicator
12333 }, React__default.createElement(Indicator, {
12334 pulse: true
12335 })) : null;
12336 var iconMarkup = icon ? React__default.createElement("div", {
12337 className: styles$1d.Icon
12338 }, React__default.createElement(Icon, {
12339 source: icon
12340 })) : null;
12341 var badgeMarkup = null;
12342
12343 if (isNew) {
12344 badgeMarkup = React__default.createElement(Badge, {
12345 status: "new",
12346 size: "small"
12347 }, i18n.translate('Polaris.Badge.STATUS_LABELS.new'));
12348 } else if (typeof badge === 'string') {
12349 badgeMarkup = React__default.createElement(Badge, {
12350 status: "new",
12351 size: "small"
12352 }, badge);
12353 } else {
12354 badgeMarkup = badge;
12355 }
12356
12357 var wrappedBadgeMarkup = badgeMarkup == null ? null : React__default.createElement("div", {
12358 className: styles$1d.Badge
12359 }, badgeMarkup);
12360 var itemContentMarkup = React__default.createElement(Fragment, null, iconMarkup, React__default.createElement("span", {
12361 className: styles$1d.Text
12362 }, label, indicatorMarkup), wrappedBadgeMarkup);
12363
12364 if (url == null) {
12365 var _className = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled']);
12366
12367 return React__default.createElement("li", {
12368 className: styles$1d.ListItem
12369 }, React__default.createElement("button", {
12370 type: "button",
12371 className: _className,
12372 disabled: disabled,
12373 "aria-disabled": disabled,
12374 "aria-label": accessibilityLabel,
12375 onClick: getClickHandler(onClick)
12376 }, itemContentMarkup));
12377 }
12378
12379 var secondaryActionMarkup = secondaryAction && React__default.createElement(UnstyledLink, {
12380 external: true,
12381 url: secondaryAction.url,
12382 className: styles$1d.SecondaryAction,
12383 tabIndex: tabIndex,
12384 "aria-disabled": disabled,
12385 "aria-label": secondaryAction.accessibilityLabel
12386 }, React__default.createElement(Icon, {
12387 source: secondaryAction.icon
12388 }));
12389 var matchState = matchStateForItem({
12390 url,
12391 matches,
12392 exactMatch,
12393 matchPaths,
12394 excludePaths
12395 }, location);
12396 var matchingSubNavigationItems = subNavigationItems.filter(function (item) {
12397 var subMatchState = matchStateForItem(item, location);
12398 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
12399 });
12400 var childIsActive = matchingSubNavigationItems.length > 0;
12401 var selected = selectedOverride == null ? matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths : selectedOverride;
12402 var showExpanded = selected || expanded || childIsActive;
12403 var itemClassName = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled'], selected && subNavigationItems.length === 0 && styles$1d['Item-selected'], showExpanded && styles$1d.subNavigationActive);
12404 var secondaryNavigationMarkup = null;
12405
12406 if (subNavigationItems.length > 0 && showExpanded) {
12407 var longestMatch = matchingSubNavigationItems.sort(function (_ref2, _ref3) {
12408 var firstUrl = _ref2.url;
12409 var secondUrl = _ref3.url;
12410 return secondUrl.length - firstUrl.length;
12411 })[0];
12412 secondaryNavigationMarkup = React__default.createElement("div", {
12413 className: styles$1d.SecondaryNavigation
12414 }, React__default.createElement(Secondary, {
12415 expanded: showExpanded
12416 }, subNavigationItems.map(function (item) {
12417 var label = item.label,
12418 rest = __rest(item, ["label"]);
12419
12420 return React__default.createElement(Item$7, Object.assign({}, rest, {
12421 key: label,
12422 label: label,
12423 matches: item === longestMatch,
12424 onClick: onNavigationDismiss
12425 }));
12426 })));
12427 }
12428
12429 var className = classNames(styles$1d.ListItem, secondaryAction && styles$1d['ListItem-hasAction']);
12430 return React__default.createElement("li", {
12431 className: className
12432 }, React__default.createElement("div", {
12433 className: styles$1d.ItemWrapper
12434 }, React__default.createElement(UnstyledLink, {
12435 url: url,
12436 className: itemClassName,
12437 tabIndex: tabIndex,
12438 "aria-disabled": disabled,
12439 "aria-label": accessibilityLabel,
12440 onClick: getClickHandler(onClick)
12441 }, itemContentMarkup), secondaryActionMarkup), secondaryNavigationMarkup);
12442
12443 function getClickHandler(onClick) {
12444 return function (event) {
12445 var currentTarget = event.currentTarget;
12446
12447 if (currentTarget.getAttribute('href') === location) {
12448 event.preventDefault();
12449 }
12450
12451 if (subNavigationItems && subNavigationItems.length > 0 && isNavigationCollapsed) {
12452 event.preventDefault();
12453 setExpanded(!expanded);
12454 } else if (onNavigationDismiss) {
12455 onNavigationDismiss();
12456
12457 if (onClick && onClick !== onNavigationDismiss) {
12458 onClick();
12459 }
12460
12461 return;
12462 }
12463
12464 if (onClick) {
12465 onClick();
12466 }
12467 };
12468 }
12469}
12470function isNavigationItemActive(navigationItem, currentPath) {
12471 var matchState = matchStateForItem(navigationItem, currentPath);
12472 var matchingSubNavigationItems = navigationItem.subNavigationItems && navigationItem.subNavigationItems.filter(function (item) {
12473 var subMatchState = matchStateForItem(item, currentPath);
12474 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
12475 });
12476 var childIsActive = matchingSubNavigationItems && matchingSubNavigationItems.length > 0;
12477 var selected = matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths;
12478 return selected || childIsActive;
12479}
12480
12481function normalizePathname(pathname) {
12482 var barePathname = pathname.split('?')[0].split('#')[0];
12483 return barePathname.endsWith('/') ? barePathname : "".concat(barePathname, "/");
12484}
12485
12486function safeEqual(location, path) {
12487 return normalizePathname(location) === normalizePathname(path);
12488}
12489
12490function safeStartsWith(location, path) {
12491 return normalizePathname(location).startsWith(normalizePathname(path));
12492}
12493
12494function matchStateForItem(_ref4, location) {
12495 var url = _ref4.url,
12496 matches = _ref4.matches,
12497 exactMatch = _ref4.exactMatch,
12498 matchPaths = _ref4.matchPaths,
12499 excludePaths = _ref4.excludePaths;
12500
12501 if (url == null) {
12502 return MatchState.NoMatch;
12503 }
12504
12505 if (matches) {
12506 return MatchState.MatchForced;
12507 }
12508
12509 if (matches === false || excludePaths && excludePaths.some(function (path) {
12510 return safeStartsWith(location, path);
12511 })) {
12512 return MatchState.Excluded;
12513 }
12514
12515 if (matchPaths && matchPaths.some(function (path) {
12516 return safeStartsWith(location, path);
12517 })) {
12518 return MatchState.MatchPaths;
12519 }
12520
12521 var matchesUrl = exactMatch ? safeEqual(location, url) : safeStartsWith(location, url);
12522 return matchesUrl ? MatchState.MatchUrl : MatchState.NoMatch;
12523}
12524
12525function Section$5(_ref) {
12526 var title = _ref.title,
12527 fill = _ref.fill,
12528 action = _ref.action,
12529 items = _ref.items,
12530 rollup = _ref.rollup,
12531 separator = _ref.separator;
12532
12533 var _useToggle = useToggle(false),
12534 expanded = _useToggle.value,
12535 toggleExpanded = _useToggle.toggle,
12536 setExpandedFalse = _useToggle.setFalse;
12537
12538 var animationFrame = useRef(null);
12539
12540 var handleClick = function handleClick(onClick, hasSubNavItems) {
12541 return function () {
12542 if (onClick) {
12543 onClick();
12544 }
12545
12546 if (animationFrame.current) {
12547 cancelAnimationFrame(animationFrame.current);
12548 }
12549
12550 if (!hasSubNavItems || !navigationBarCollapsed().matches) {
12551 animationFrame.current = requestAnimationFrame(setExpandedFalse);
12552 }
12553 };
12554 };
12555
12556 useEffect(function () {
12557 return function () {
12558 animationFrame.current && cancelAnimationFrame(animationFrame.current);
12559 };
12560 });
12561 var className = classNames(styles$1d.Section, separator && styles$1d['Section-withSeparator'], fill && styles$1d['Section-fill']);
12562 var actionMarkup = action && React__default.createElement("button", {
12563 type: "button",
12564 className: styles$1d.Action,
12565 "aria-label": action.accessibilityLabel,
12566 onClick: action.onClick
12567 }, React__default.createElement(Icon, {
12568 source: action.icon
12569 }));
12570 var sectionHeadingMarkup = title && React__default.createElement("li", {
12571 className: styles$1d.SectionHeading
12572 }, React__default.createElement("span", {
12573 className: styles$1d.Text
12574 }, title), actionMarkup);
12575 var itemsMarkup = items.map(function (item) {
12576 var onClick = item.onClick,
12577 label = item.label,
12578 subNavigationItems = item.subNavigationItems,
12579 rest = __rest(item, ["onClick", "label", "subNavigationItems"]);
12580
12581 var hasSubNavItems = subNavigationItems != null && subNavigationItems.length > 0;
12582 return React__default.createElement(Item$7, Object.assign({}, rest, {
12583 key: label,
12584 label: label,
12585 subNavigationItems: subNavigationItems,
12586 onClick: handleClick(onClick, hasSubNavItems)
12587 }));
12588 });
12589 var toggleClassName = classNames(styles$1d.Item, styles$1d.RollupToggle);
12590 var ariaLabel = rollup && (expanded ? rollup.hide : rollup.view);
12591 var toggleRollup = rollup && items.length > rollup.after && React__default.createElement("div", {
12592 className: styles$1d.ListItem,
12593 key: "List Item"
12594 }, React__default.createElement("button", {
12595 type: "button",
12596 className: toggleClassName,
12597 onClick: toggleExpanded,
12598 "aria-label": ariaLabel
12599 }, React__default.createElement("span", {
12600 className: styles$1d.Icon
12601 }, React__default.createElement(Icon, {
12602 source: HorizontalDotsMinor
12603 }))));
12604 var activeItemIndex = items.findIndex(function (item) {
12605 if (!rollup) {
12606 return false;
12607 }
12608
12609 return rollup.activePath === item.url || item.url && rollup.activePath.startsWith(item.url) || (item.subNavigationItems ? item.subNavigationItems.some(function (_ref2) {
12610 var itemUrl = _ref2.url;
12611 return rollup.activePath.startsWith(itemUrl);
12612 }) : false);
12613 });
12614 var sectionItems = rollup ? itemsMarkup.slice(0, rollup.after) : itemsMarkup;
12615 var additionalItems = rollup ? itemsMarkup.slice(rollup.after) : [];
12616
12617 if (rollup && activeItemIndex !== -1 && activeItemIndex > rollup.after - 1) {
12618 sectionItems.push.apply(sectionItems, _toConsumableArray(additionalItems.splice(activeItemIndex - rollup.after, 1)));
12619 }
12620
12621 var additionalItemsId = useUniqueId('AdditionalItems');
12622 var activeItemsMarkup = rollup && additionalItems.length > 0 && React__default.createElement("li", {
12623 className: styles$1d.RollupSection
12624 }, React__default.createElement(Collapsible, {
12625 id: additionalItemsId,
12626 open: expanded
12627 }, React__default.createElement("ul", {
12628 className: styles$1d.List
12629 }, additionalItems)), toggleRollup);
12630 return React__default.createElement("ul", {
12631 className: className
12632 }, sectionHeadingMarkup, sectionItems, activeItemsMarkup);
12633}
12634
12635var Navigation$1 = function Navigation(_ref) {
12636 var children = _ref.children,
12637 contextControl = _ref.contextControl,
12638 location = _ref.location,
12639 onDismiss = _ref.onDismiss;
12640
12641 var _useTheme = useTheme(),
12642 logo = _useTheme.logo;
12643
12644 var _useFeatures = useFeatures(),
12645 newDesignLanguage = _useFeatures.newDesignLanguage;
12646
12647 var width = getWidth(logo, 104);
12648 var logoMarkup = logo && newDesignLanguage ? React__default.createElement("div", {
12649 className: styles$1d.LogoContainer
12650 }, React__default.createElement(UnstyledLink, {
12651 url: logo.url || '',
12652 className: styles$1d.LogoLink,
12653 style: {
12654 width
12655 }
12656 }, React__default.createElement(Image, {
12657 source: logo.topBarSource || '',
12658 alt: logo.accessibilityLabel || '',
12659 className: styles$1d.Logo,
12660 style: {
12661 width
12662 }
12663 }))) : null;
12664 var mediaMarkup = contextControl ? React__default.createElement("div", {
12665 className: styles$1d.ContextControl
12666 }, contextControl) : logoMarkup;
12667 var className = classNames(styles$1d.Navigation, !mediaMarkup && newDesignLanguage && styles$1d['Navigation-noMedia'], newDesignLanguage && styles$1d['Navigation-newDesignLanguage']);
12668 var context = {
12669 location,
12670 onNavigationDismiss: onDismiss
12671 };
12672 return React__default.createElement(NavigationContext.Provider, {
12673 value: context
12674 }, React__default.createElement(WithinContentContext.Provider, {
12675 value: true
12676 }, React__default.createElement("nav", {
12677 className: className
12678 }, mediaMarkup, React__default.createElement(Scrollable, {
12679 className: styles$1d.PrimaryNavigation
12680 }, children))));
12681};
12682Navigation$1.Item = Item$7;
12683Navigation$1.Section = Section$5;
12684
12685var EditableTarget;
12686
12687(function (EditableTarget) {
12688 EditableTarget["Input"] = "INPUT";
12689 EditableTarget["Textarea"] = "TEXTAREA";
12690 EditableTarget["Select"] = "SELECT";
12691 EditableTarget["ContentEditable"] = "contenteditable";
12692})(EditableTarget || (EditableTarget = {}));
12693
12694function isInputFocused() {
12695 if (document == null || document.activeElement == null) {
12696 return false;
12697 }
12698
12699 var tagName = document.activeElement.tagName;
12700 return tagName === EditableTarget.Input || tagName === EditableTarget.Textarea || tagName === EditableTarget.Select || document.activeElement.hasAttribute(EditableTarget.ContentEditable);
12701}
12702
12703var styles$1e = {
12704 "Tooltip": "Polaris-Tooltip",
12705 "measuring": "Polaris-Tooltip--measuring",
12706 "positionedAbove": "Polaris-Tooltip--positionedAbove",
12707 "light": "Polaris-Tooltip--light",
12708 "Wrapper": "Polaris-Tooltip__Wrapper",
12709 "Content": "Polaris-Tooltip__Content",
12710 "Label": "Polaris-Tooltip__Label"
12711};
12712
12713var TooltipOverlay =
12714/*#__PURE__*/
12715function (_React$PureComponent) {
12716 _inherits(TooltipOverlay, _React$PureComponent);
12717
12718 function TooltipOverlay() {
12719 var _this;
12720
12721 _classCallCheck(this, TooltipOverlay);
12722
12723 _this = _possibleConstructorReturn(this, _getPrototypeOf(TooltipOverlay).apply(this, arguments));
12724
12725 _this.renderOverlay = function () {
12726 var _this$props = _this.props,
12727 active = _this$props.active,
12728 activator = _this$props.activator,
12729 _this$props$preferred = _this$props.preferredPosition,
12730 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred;
12731 return React__default.createElement(PositionedOverlay, {
12732 active: active,
12733 activator: activator,
12734 preferredPosition: preferredPosition,
12735 render: _this.renderTooltip
12736 });
12737 };
12738
12739 _this.renderTooltip = function (overlayDetails) {
12740 var measuring = overlayDetails.measuring,
12741 desiredHeight = overlayDetails.desiredHeight,
12742 positioning = overlayDetails.positioning;
12743 var _this$props2 = _this.props,
12744 id = _this$props2.id,
12745 children = _this$props2.children,
12746 light = _this$props2.light;
12747 var containerClassName = classNames(styles$1e.Tooltip, light && styles$1e.light, measuring && styles$1e.measuring, positioning === 'above' && styles$1e.positionedAbove);
12748 var contentStyles = measuring ? undefined : {
12749 minHeight: desiredHeight
12750 };
12751 return React__default.createElement("div", Object.assign({
12752 className: containerClassName
12753 }, layer.props), React__default.createElement("div", {
12754 className: styles$1e.Wrapper
12755 }, React__default.createElement("div", {
12756 id: id,
12757 role: "tooltip",
12758 className: styles$1e.Content,
12759 style: contentStyles
12760 }, children)));
12761 };
12762
12763 return _this;
12764 }
12765
12766 _createClass(TooltipOverlay, [{
12767 key: "render",
12768 value: function render() {
12769 var markup = this.props.active ? this.renderOverlay() : null;
12770 return markup;
12771 }
12772 }]);
12773
12774 return TooltipOverlay;
12775}(React__default.PureComponent);
12776
12777function Tooltip(_ref) {
12778 var children = _ref.children,
12779 content = _ref.content,
12780 light = _ref.light,
12781 originalActive = _ref.active,
12782 _ref$preferredPositio = _ref.preferredPosition,
12783 preferredPosition = _ref$preferredPositio === void 0 ? 'below' : _ref$preferredPositio,
12784 _ref$activatorWrapper = _ref.activatorWrapper,
12785 activatorWrapper = _ref$activatorWrapper === void 0 ? 'span' : _ref$activatorWrapper;
12786 var WrapperComponent = activatorWrapper;
12787
12788 var _useToggle = useToggle(Boolean(originalActive)),
12789 active = _useToggle.value,
12790 handleFocus = _useToggle.setTrue,
12791 handleBlur = _useToggle.setFalse;
12792
12793 var _useState = useState(null),
12794 _useState2 = _slicedToArray(_useState, 2),
12795 activatorNode = _useState2[0],
12796 setActivatorNode = _useState2[1];
12797
12798 var id = useUniqueId('TooltipContent');
12799 var activatorContainer = useRef(null);
12800 var mouseEntered = useRef(false);
12801 useEffect(function () {
12802 var firstFocusable = activatorContainer.current ? findFirstFocusableNode(activatorContainer.current) : null;
12803 var accessibilityNode = firstFocusable || activatorContainer.current;
12804 if (!accessibilityNode) return;
12805 accessibilityNode.tabIndex = 0;
12806 accessibilityNode.setAttribute('aria-describedby', id);
12807 }, [id, children]);
12808 var portal = activatorNode ? React__default.createElement(Portal, {
12809 idPrefix: "tooltip"
12810 }, React__default.createElement(TooltipOverlay, {
12811 id: id,
12812 preferredPosition: preferredPosition,
12813 activator: activatorNode,
12814 active: active,
12815 onClose: noop$8,
12816 light: light
12817 }, React__default.createElement("div", {
12818 className: styles$1e.Label
12819 }, content))) : null;
12820 return React__default.createElement(WrapperComponent, {
12821 onFocus: handleFocus,
12822 onBlur: handleBlur,
12823 onMouseLeave: handleMouseLeave,
12824 onMouseOver: handleMouseEnterFix,
12825 ref: setActivator
12826 }, children, portal);
12827
12828 function setActivator(node) {
12829 var activatorContainerRef = activatorContainer;
12830
12831 if (node == null) {
12832 activatorContainerRef.current = null;
12833 setActivatorNode(null);
12834 return;
12835 }
12836
12837 setActivatorNode(node.firstElementChild);
12838 activatorContainerRef.current = node;
12839 }
12840
12841 function handleMouseEnter() {
12842 mouseEntered.current = true;
12843 handleFocus();
12844 }
12845
12846 function handleMouseLeave() {
12847 mouseEntered.current = false;
12848 handleBlur();
12849 } // https://github.com/facebook/react/issues/10109
12850 // Mouseenter event not triggered when cursor moves from disabled button
12851
12852
12853 function handleMouseEnterFix() {
12854 !mouseEntered.current && handleMouseEnter();
12855 }
12856}
12857
12858function noop$8() {}
12859
12860var styles$1f = {
12861 "Pagination": "Polaris-Pagination",
12862 "plain": "Polaris-Pagination--plain",
12863 "Button": "Polaris-Pagination__Button",
12864 "newDesignLanguage": "Polaris-Pagination--newDesignLanguage",
12865 "PreviousButton": "Polaris-Pagination__PreviousButton",
12866 "NextButton": "Polaris-Pagination__NextButton",
12867 "rightButton": "Polaris-Pagination--rightButton",
12868 "Label": "Polaris-Pagination__Label"
12869};
12870
12871function Pagination(_ref) {
12872 var hasNext = _ref.hasNext,
12873 hasPrevious = _ref.hasPrevious,
12874 nextURL = _ref.nextURL,
12875 previousURL = _ref.previousURL,
12876 onNext = _ref.onNext,
12877 onPrevious = _ref.onPrevious,
12878 nextTooltip = _ref.nextTooltip,
12879 previousTooltip = _ref.previousTooltip,
12880 nextKeys = _ref.nextKeys,
12881 previousKeys = _ref.previousKeys,
12882 plain = _ref.plain,
12883 accessibilityLabel = _ref.accessibilityLabel,
12884 label = _ref.label;
12885 var i18n = useI18n();
12886
12887 var _useFeatures = useFeatures(),
12888 newDesignLanguage = _useFeatures.newDesignLanguage;
12889
12890 var node = React__default.createRef();
12891 var navLabel = accessibilityLabel || i18n.translate('Polaris.Pagination.pagination');
12892 var className = classNames(styles$1f.Pagination, plain && styles$1f.plain);
12893 var previousClassName = classNames(styles$1f.Button, newDesignLanguage && styles$1f.newDesignLanguage, !label && styles$1f.PreviousButton);
12894 var nextClassName = classNames(styles$1f.Button, newDesignLanguage && styles$1f.newDesignLanguage, newDesignLanguage && styles$1f.rightButton, !label && styles$1f.NextButton);
12895 var previousButton = previousURL ? React__default.createElement(UnstyledLink, {
12896 className: previousClassName,
12897 url: previousURL,
12898 onMouseUp: handleMouseUpByBlurring,
12899 "aria-label": i18n.translate('Polaris.Pagination.previous'),
12900 id: "previousURL"
12901 }, React__default.createElement(Icon, {
12902 source: ArrowLeftMinor
12903 })) : React__default.createElement("button", {
12904 onClick: onPrevious,
12905 type: "button",
12906 onMouseUp: handleMouseUpByBlurring,
12907 className: previousClassName,
12908 "aria-label": i18n.translate('Polaris.Pagination.previous'),
12909 disabled: !hasPrevious
12910 }, React__default.createElement(Icon, {
12911 source: ArrowLeftMinor
12912 }));
12913 var nextButton = nextURL ? React__default.createElement(UnstyledLink, {
12914 className: nextClassName,
12915 url: nextURL,
12916 onMouseUp: handleMouseUpByBlurring,
12917 "aria-label": i18n.translate('Polaris.Pagination.next'),
12918 id: "nextURL"
12919 }, React__default.createElement(Icon, {
12920 source: ArrowRightMinor
12921 })) : React__default.createElement("button", {
12922 onClick: onNext,
12923 type: "button",
12924 onMouseUp: handleMouseUpByBlurring,
12925 className: nextClassName,
12926 "aria-label": i18n.translate('Polaris.Pagination.next'),
12927 disabled: !hasNext
12928 }, React__default.createElement(Icon, {
12929 source: ArrowRightMinor
12930 }));
12931 var constructedPrevious = previousTooltip && hasPrevious ? React__default.createElement(Tooltip, {
12932 content: previousTooltip
12933 }, previousButton) : previousButton;
12934 var constructedNext = nextTooltip && hasNext ? React__default.createElement(Tooltip, {
12935 content: nextTooltip
12936 }, nextButton) : nextButton;
12937 var previousButtonEvents = previousKeys && (previousURL || onPrevious) && hasPrevious && previousKeys.map(function (key) {
12938 return React__default.createElement(KeypressListener, {
12939 key: key,
12940 keyCode: key,
12941 handler: previousURL ? handleCallback(clickPaginationLink('previousURL', node)) : handleCallback(onPrevious)
12942 });
12943 });
12944 var nextButtonEvents = nextKeys && (nextURL || onNext) && hasNext && nextKeys.map(function (key) {
12945 return React__default.createElement(KeypressListener, {
12946 key: key,
12947 keyCode: key,
12948 handler: nextURL ? handleCallback(clickPaginationLink('nextURL', node)) : handleCallback(onNext)
12949 });
12950 });
12951 var labelTextMarkup = hasNext && hasPrevious ? React__default.createElement(TextStyle, null, label) : React__default.createElement(TextStyle, {
12952 variation: "subdued"
12953 }, label);
12954 var labelMarkup = label ? React__default.createElement("div", {
12955 className: styles$1f.Label,
12956 "aria-live": "polite"
12957 }, labelTextMarkup) : null;
12958 return React__default.createElement("nav", {
12959 className: className,
12960 "aria-label": navLabel,
12961 ref: node
12962 }, previousButtonEvents, constructedPrevious, labelMarkup, nextButtonEvents, constructedNext);
12963}
12964
12965function clickPaginationLink(id, node) {
12966 return function () {
12967 if (node.current == null) {
12968 return;
12969 }
12970
12971 var link = node.current.querySelector("#".concat(id));
12972
12973 if (link) {
12974 link.click();
12975 }
12976 };
12977}
12978
12979function handleCallback(fn) {
12980 return function () {
12981 if (isInputFocused()) {
12982 return;
12983 }
12984
12985 fn();
12986 };
12987}
12988
12989var styles$1g = {
12990 "Title": "Polaris-Header-Title",
12991 "SubTitle": "Polaris-Header-Title__SubTitle",
12992 "hasThumbnail": "Polaris-Header-Title--hasThumbnail",
12993 "TitleAndSubtitleWrapper": "Polaris-Header-Title__TitleAndSubtitleWrapper",
12994 "TitleWithMetadataWrapper": "Polaris-Header-Title__TitleWithMetadataWrapper",
12995 "TitleMetadata": "Polaris-Header-Title__TitleMetadata"
12996};
12997
12998function Title(_ref) {
12999 var title = _ref.title,
13000 subtitle = _ref.subtitle,
13001 titleMetadata = _ref.titleMetadata,
13002 thumbnail = _ref.thumbnail;
13003 var titleMarkup = title ? createElement("div", {
13004 className: styles$1g.Title
13005 }, createElement(DisplayText, {
13006 size: "large",
13007 element: "h1"
13008 }, title)) : null;
13009 var titleMetadataMarkup = titleMetadata ? createElement("div", {
13010 className: styles$1g.TitleMetadata
13011 }, titleMetadata) : null;
13012 var wrappedTitleMarkup = titleMetadata ? createElement("div", {
13013 className: styles$1g.TitleWithMetadataWrapper
13014 }, titleMarkup, titleMetadataMarkup) : titleMarkup;
13015 var subtitleMarkup = subtitle ? createElement("div", {
13016 className: styles$1g.SubTitle
13017 }, createElement("p", null, subtitle)) : null;
13018 var thumbnailMarkup = thumbnail ? createElement("div", null, thumbnail) : null;
13019 var pageTitleClassName = thumbnail ? classNames(styles$1g.hasThumbnail) : undefined;
13020 return createElement("div", {
13021 className: pageTitleClassName
13022 }, thumbnailMarkup, createElement("div", {
13023 className: styles$1g.TitleAndSubtitleWrapper
13024 }, wrappedTitleMarkup, subtitleMarkup));
13025}
13026
13027var styles$1h = {
13028 "Header": "Polaris-Page-Header",
13029 "separator": "Polaris-Page-Header--separator",
13030 "titleHidden": "Polaris-Page-Header--titleHidden",
13031 "Navigation": "Polaris-Page-Header__Navigation",
13032 "hasActionMenu": "Polaris-Page-Header--hasActionMenu",
13033 "mobileView": "Polaris-Page-Header--mobileView",
13034 "BreadcrumbWrapper": "Polaris-Page-Header__BreadcrumbWrapper",
13035 "PaginationWrapper": "Polaris-Page-Header__PaginationWrapper",
13036 "MainContent": "Polaris-Page-Header__MainContent",
13037 "TitleActionMenuWrapper": "Polaris-Page-Header__TitleActionMenuWrapper",
13038 "hasNavigation": "Polaris-Page-Header--hasNavigation",
13039 "PrimaryActionWrapper": "Polaris-Page-Header__PrimaryActionWrapper",
13040 "ActionMenuWrapper": "Polaris-Page-Header__ActionMenuWrapper"
13041};
13042
13043function Header$2(_ref) {
13044 var title = _ref.title,
13045 subtitle = _ref.subtitle,
13046 titleMetadata = _ref.titleMetadata,
13047 thumbnail = _ref.thumbnail,
13048 _ref$titleHidden = _ref.titleHidden,
13049 titleHidden = _ref$titleHidden === void 0 ? false : _ref$titleHidden,
13050 separator = _ref.separator,
13051 primaryAction = _ref.primaryAction,
13052 pagination = _ref.pagination,
13053 _ref$breadcrumbs = _ref.breadcrumbs,
13054 breadcrumbs = _ref$breadcrumbs === void 0 ? [] : _ref$breadcrumbs,
13055 _ref$secondaryActions = _ref.secondaryActions,
13056 secondaryActions = _ref$secondaryActions === void 0 ? [] : _ref$secondaryActions,
13057 _ref$actionGroups = _ref.actionGroups,
13058 actionGroups = _ref$actionGroups === void 0 ? [] : _ref$actionGroups;
13059
13060 var _useMediaQuery = useMediaQuery(),
13061 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
13062
13063 var breadcrumbMarkup = breadcrumbs.length > 0 ? React__default.createElement("div", {
13064 className: styles$1h.BreadcrumbWrapper
13065 }, React__default.createElement(Breadcrumbs, {
13066 breadcrumbs: breadcrumbs
13067 })) : null;
13068 var paginationMarkup = pagination && !isNavigationCollapsed ? React__default.createElement("div", {
13069 className: styles$1h.PaginationWrapper
13070 }, React__default.createElement(Pagination, Object.assign({}, pagination, {
13071 plain: true
13072 }))) : null;
13073 var navigationMarkup = breadcrumbMarkup || paginationMarkup ? React__default.createElement("div", {
13074 className: styles$1h.Navigation
13075 }, breadcrumbMarkup, paginationMarkup) : null;
13076 var pageTitleMarkup = React__default.createElement(Title, {
13077 title: title,
13078 subtitle: subtitle,
13079 titleMetadata: titleMetadata,
13080 thumbnail: thumbnail
13081 });
13082 var primary = primaryAction && (primaryAction.primary === undefined ? true : primaryAction.primary);
13083 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
13084 className: styles$1h.PrimaryActionWrapper
13085 }, buttonsFrom(primaryAction, {
13086 primary
13087 })) : null;
13088 var actionMenuMarkup = secondaryActions.length > 0 || hasGroupsWithActions(actionGroups) ? React__default.createElement("div", {
13089 className: styles$1h.ActionMenuWrapper
13090 }, React__default.createElement(ActionMenu, {
13091 actions: secondaryActions,
13092 groups: actionGroups,
13093 rollup: isNavigationCollapsed
13094 })) : null;
13095 var headerClassNames = classNames(styles$1h.Header, titleHidden && styles$1h.titleHidden, separator && styles$1h.separator, navigationMarkup && styles$1h.hasNavigation, actionMenuMarkup && styles$1h.hasActionMenu, isNavigationCollapsed && styles$1h.mobileView);
13096 return React__default.createElement("div", {
13097 className: headerClassNames
13098 }, navigationMarkup, React__default.createElement("div", {
13099 className: styles$1h.MainContent
13100 }, React__default.createElement("div", {
13101 className: styles$1h.TitleActionMenuWrapper
13102 }, pageTitleMarkup, actionMenuMarkup), primaryActionMarkup));
13103}
13104
13105var styles$1i = {
13106 "Page": "Polaris-Page",
13107 "fullWidth": "Polaris-Page--fullWidth",
13108 "narrowWidth": "Polaris-Page--narrowWidth",
13109 "Content": "Polaris-Page__Content"
13110};
13111
13112var APP_BRIDGE_PROPS$1 = ['title', 'breadcrumbs', 'secondaryActions', 'actionGroups', 'primaryAction'];
13113
13114var PageInner =
13115/*#__PURE__*/
13116function (_React$PureComponent) {
13117 _inherits(PageInner, _React$PureComponent);
13118
13119 function PageInner() {
13120 _classCallCheck(this, PageInner);
13121
13122 return _possibleConstructorReturn(this, _getPrototypeOf(PageInner).apply(this, arguments));
13123 }
13124
13125 _createClass(PageInner, [{
13126 key: "componentDidMount",
13127 value: function componentDidMount() {
13128 if (this.delegateToAppbridge() === false || !this.props.polaris.appBridge) {
13129 return;
13130 }
13131
13132 var transformedProps = this.transformProps();
13133 if (!transformedProps) return; // eslint-disable-next-line no-console
13134
13135 console.warn('Deprecation: Using `Page` to render an embedded app title bar is deprecated and will be removed in v5.0. Use `TitleBar` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/titlebar');
13136 this.titlebar = TitleBar.create(this.props.polaris.appBridge, transformedProps);
13137 }
13138 }, {
13139 key: "componentDidUpdate",
13140 value: function componentDidUpdate(prevProps) {
13141 if (this.titlebar == null || this.delegateToAppbridge() === false) {
13142 return;
13143 }
13144
13145 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS$1);
13146 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS$1);
13147
13148 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps)) {
13149 var transformedProps = this.transformProps();
13150 if (!transformedProps) return;
13151 this.titlebar.unsubscribe();
13152 this.titlebar.set(transformedProps);
13153 }
13154 }
13155 }, {
13156 key: "componentWillUnmount",
13157 value: function componentWillUnmount() {
13158 if (this.titlebar == null || this.delegateToAppbridge() === false) {
13159 return;
13160 }
13161
13162 this.titlebar.unsubscribe();
13163 }
13164 }, {
13165 key: "render",
13166 value: function render() {
13167 var _a = this.props,
13168 children = _a.children,
13169 fullWidth = _a.fullWidth,
13170 narrowWidth = _a.narrowWidth,
13171 singleColumn = _a.singleColumn,
13172 rest = __rest(_a, ["children", "fullWidth", "narrowWidth", "singleColumn"]);
13173
13174 if (singleColumn) {
13175 // eslint-disable-next-line no-console
13176 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
13177 }
13178
13179 var className = classNames(styles$1i.Page, fullWidth && styles$1i.fullWidth, (narrowWidth || singleColumn) && styles$1i.narrowWidth);
13180 var headerMarkup = this.delegateToAppbridge() || this.hasHeaderContent() === false ? null : React__default.createElement(Header$2, rest);
13181 return React__default.createElement("div", {
13182 className: className
13183 }, headerMarkup, React__default.createElement("div", {
13184 className: styles$1i.Content
13185 }, children));
13186 }
13187 }, {
13188 key: "delegateToAppbridge",
13189 value: function delegateToAppbridge() {
13190 var _this$props = this.props,
13191 appBridge = _this$props.polaris.appBridge,
13192 _this$props$forceRend = _this$props.forceRender,
13193 forceRender = _this$props$forceRend === void 0 ? false : _this$props$forceRend;
13194 return appBridge != null && forceRender === false;
13195 }
13196 }, {
13197 key: "hasHeaderContent",
13198 value: function hasHeaderContent() {
13199 var _this$props2 = this.props,
13200 title = _this$props2.title,
13201 primaryAction = _this$props2.primaryAction,
13202 secondaryActions = _this$props2.secondaryActions,
13203 actionGroups = _this$props2.actionGroups,
13204 breadcrumbs = _this$props2.breadcrumbs;
13205 return title != null && title !== '' || primaryAction != null || secondaryActions != null && secondaryActions.length > 0 || actionGroups != null && actionGroups.length > 0 || breadcrumbs != null && breadcrumbs.length > 0;
13206 }
13207 }, {
13208 key: "transformProps",
13209 value: function transformProps() {
13210 var appBridge = this.props.polaris.appBridge;
13211 if (!appBridge) return;
13212 var _this$props3 = this.props,
13213 title = _this$props3.title,
13214 primaryAction = _this$props3.primaryAction,
13215 secondaryActions = _this$props3.secondaryActions,
13216 actionGroups = _this$props3.actionGroups;
13217 return {
13218 title,
13219 buttons: transformActions(appBridge, {
13220 primaryAction,
13221 secondaryActions,
13222 actionGroups
13223 }),
13224 breadcrumbs: this.transformBreadcrumbs()
13225 };
13226 }
13227 }, {
13228 key: "transformBreadcrumbs",
13229 value: function transformBreadcrumbs() {
13230 var appBridge = this.props.polaris.appBridge;
13231 if (!appBridge) return;
13232 var breadcrumbs = this.props.breadcrumbs;
13233
13234 if (breadcrumbs != null && breadcrumbs.length > 0) {
13235 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
13236 var button = Button$1.create(appBridge, {
13237 label: breadcrumb.content || ''
13238 });
13239 var callback = !('url' in breadcrumb) ? breadcrumb.onAction : generateRedirect(appBridge, breadcrumb.url, breadcrumb.target);
13240
13241 if (callback != null) {
13242 button.subscribe(Button$1.Action.CLICK, callback);
13243 }
13244
13245 return button;
13246 } else {
13247 return undefined;
13248 }
13249 }
13250 }]);
13251
13252 return PageInner;
13253}(React__default.PureComponent);
13254
13255var Page = withAppProvider()(PageInner);
13256
13257var styles$1j = {
13258 "PageActions": "Polaris-PageActions"
13259};
13260
13261function PageActions(_ref) {
13262 var primaryAction = _ref.primaryAction,
13263 secondaryActions = _ref.secondaryActions;
13264 var primaryActionMarkup = primaryAction ? buttonsFrom(primaryAction, {
13265 primary: true
13266 }) : null;
13267 var secondaryActionsMarkup = secondaryActions ? React__default.createElement(ButtonGroup, null, buttonsFrom(secondaryActions)) : null;
13268 var distribution = secondaryActionsMarkup ? 'equalSpacing' : 'trailing';
13269 return React__default.createElement("div", {
13270 className: styles$1j.PageActions
13271 }, React__default.createElement(Stack, {
13272 distribution: distribution,
13273 spacing: "tight"
13274 }, secondaryActionsMarkup, primaryActionMarkup));
13275}
13276
13277var defaultMediaQuery = {
13278 isNavigationCollapsed: false
13279};
13280function PolarisTestProvider(_ref) {
13281 var strict = _ref.strict,
13282 children = _ref.children,
13283 i18n = _ref.i18n,
13284 appBridge = _ref.appBridge,
13285 link = _ref.link,
13286 _ref$theme = _ref.theme,
13287 theme = _ref$theme === void 0 ? {} : _ref$theme,
13288 mediaQuery = _ref.mediaQuery,
13289 _ref$features = _ref.features,
13290 featuresProp = _ref$features === void 0 ? {} : _ref$features,
13291 frame = _ref.frame;
13292 var Wrapper = strict ? React__default.StrictMode : React__default.Fragment;
13293 var intl = new I18n(i18n || {});
13294 var scrollLockManager = new ScrollLockManager();
13295 var stickyManager = new StickyManager();
13296 var uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory); // This typing is odd, but as appBridge is deprecated and going away in v5
13297 // I'm not that worried about it
13298
13299 var appBridgeApp = appBridge;
13300 var features = Object.assign({
13301 newDesignLanguage: false
13302 }, featuresProp);
13303 var customProperties = features.newDesignLanguage ? buildCustomProperties(Object.assign(Object.assign({}, theme), {
13304 colorScheme: 'light'
13305 }), features.newDesignLanguage) : undefined;
13306 var mergedTheme = buildThemeContext(theme, customProperties);
13307 var mergedFrame = createFrameContext(frame);
13308 var mergedMediaQuery = merge(defaultMediaQuery, mediaQuery);
13309 return React__default.createElement(Wrapper, null, React__default.createElement(FeaturesContext.Provider, {
13310 value: features
13311 }, React__default.createElement(I18nContext.Provider, {
13312 value: intl
13313 }, React__default.createElement(ScrollLockManagerContext.Provider, {
13314 value: scrollLockManager
13315 }, React__default.createElement(StickyManagerContext.Provider, {
13316 value: stickyManager
13317 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
13318 value: uniqueIdFactory
13319 }, React__default.createElement(AppBridgeContext.Provider, {
13320 value: appBridgeApp
13321 }, React__default.createElement(LinkContext.Provider, {
13322 value: link
13323 }, React__default.createElement(ThemeContext.Provider, {
13324 value: mergedTheme
13325 }, React__default.createElement(MediaQueryContext.Provider, {
13326 value: mergedMediaQuery
13327 }, React__default.createElement(FocusManager, null, React__default.createElement(FrameContext.Provider, {
13328 value: mergedFrame
13329 }, children))))))))))));
13330}
13331
13332function noop$9() {}
13333
13334function createFrameContext() {
13335 var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
13336 _ref2$showToast = _ref2.showToast,
13337 showToast = _ref2$showToast === void 0 ? noop$9 : _ref2$showToast,
13338 _ref2$hideToast = _ref2.hideToast,
13339 hideToast = _ref2$hideToast === void 0 ? noop$9 : _ref2$hideToast,
13340 _ref2$setContextualSa = _ref2.setContextualSaveBar,
13341 setContextualSaveBar = _ref2$setContextualSa === void 0 ? noop$9 : _ref2$setContextualSa,
13342 _ref2$removeContextua = _ref2.removeContextualSaveBar,
13343 removeContextualSaveBar = _ref2$removeContextua === void 0 ? noop$9 : _ref2$removeContextua,
13344 _ref2$startLoading = _ref2.startLoading,
13345 startLoading = _ref2$startLoading === void 0 ? noop$9 : _ref2$startLoading,
13346 _ref2$stopLoading = _ref2.stopLoading,
13347 stopLoading = _ref2$stopLoading === void 0 ? noop$9 : _ref2$stopLoading;
13348
13349 return {
13350 showToast,
13351 hideToast,
13352 setContextualSaveBar,
13353 removeContextualSaveBar,
13354 startLoading,
13355 stopLoading
13356 };
13357}
13358
13359var styles$1k = {
13360 "ProgressBar": "Polaris-ProgressBar",
13361 "sizeSmall": "Polaris-ProgressBar--sizeSmall",
13362 "sizeMedium": "Polaris-ProgressBar--sizeMedium",
13363 "sizeLarge": "Polaris-ProgressBar--sizeLarge",
13364 "Indicator": "Polaris-ProgressBar__Indicator",
13365 "fillup": "Polaris-ProgressBar--fillup",
13366 "Progress": "Polaris-ProgressBar__Progress",
13367 "Label": "Polaris-ProgressBar__Label"
13368};
13369
13370function ProgressBar(_ref) {
13371 var _ref$progress = _ref.progress,
13372 progress = _ref$progress === void 0 ? 0 : _ref$progress,
13373 _ref$size = _ref.size,
13374 size = _ref$size === void 0 ? 'medium' : _ref$size;
13375 var i18n = useI18n();
13376 var className = classNames(styles$1k.ProgressBar, size && styles$1k[variationName('size', size)]);
13377 var warningMessage = i18n.translate(progress < 0 ? 'Polaris.ProgressBar.negativeWarningMessage' : 'Polaris.ProgressBar.exceedWarningMessage', {
13378 progress
13379 });
13380 var parsedProgress = parseProgress(progress, warningMessage);
13381 return React__default.createElement("div", {
13382 className: className
13383 }, React__default.createElement("progress", {
13384 className: styles$1k.Progress,
13385 value: parsedProgress,
13386 max: "100"
13387 }), React__default.createElement("div", {
13388 className: styles$1k.Indicator,
13389 style: {
13390 width: "".concat(parsedProgress, "%")
13391 }
13392 }, React__default.createElement("span", {
13393 className: styles$1k.Label
13394 }, parsedProgress, "%")));
13395}
13396
13397function parseProgress(progress, warningMessage) {
13398 var progressWidth;
13399
13400 if (progress < 0) {
13401 if (process.env.NODE_ENV === 'development') {
13402 // eslint-disable-next-line no-console
13403 console.warn(warningMessage);
13404 }
13405
13406 progressWidth = 0;
13407 } else if (progress > 100) {
13408 if (process.env.NODE_ENV === 'development') {
13409 // eslint-disable-next-line no-console
13410 console.warn(warningMessage);
13411 }
13412
13413 progressWidth = 100;
13414 } else {
13415 progressWidth = progress;
13416 }
13417
13418 return progressWidth;
13419}
13420
13421function invertNumber(number) {
13422 if (Math.sign(number) === 1) {
13423 return -Math.abs(number);
13424 } else if (Math.sign(number) === -1) {
13425 return Math.abs(number);
13426 } else {
13427 return 0;
13428 }
13429}
13430
13431var CSS_VAR_PREFIX = '--Polaris-RangeSlider-';
13432
13433var styles$1l = {
13434 "Wrapper": "Polaris-RangeSlider-DualThumb__Wrapper",
13435 "TrackWrapper": "Polaris-RangeSlider-DualThumb__TrackWrapper",
13436 "disabled": "Polaris-RangeSlider-DualThumb--disabled",
13437 "Track": "Polaris-RangeSlider-DualThumb__Track",
13438 "error": "Polaris-RangeSlider-DualThumb--error",
13439 "Track--dashed": "Polaris-RangeSlider-DualThumb--trackDashed",
13440 "Thumbs": "Polaris-RangeSlider-DualThumb__Thumbs",
13441 "Prefix": "Polaris-RangeSlider-DualThumb__Prefix",
13442 "Suffix": "Polaris-RangeSlider-DualThumb__Suffix",
13443 "Output": "Polaris-RangeSlider-DualThumb__Output",
13444 "OutputBubble": "Polaris-RangeSlider-DualThumb__OutputBubble",
13445 "OutputText": "Polaris-RangeSlider-DualThumb__OutputText"
13446};
13447
13448var Control;
13449
13450(function (Control) {
13451 Control[Control["Lower"] = 0] = "Lower";
13452 Control[Control["Upper"] = 1] = "Upper";
13453})(Control || (Control = {}));
13454
13455var THUMB_SIZE = 24;
13456var DualThumb =
13457/*#__PURE__*/
13458function (_React$Component) {
13459 _inherits(DualThumb, _React$Component);
13460
13461 function DualThumb() {
13462 var _this;
13463
13464 _classCallCheck(this, DualThumb);
13465
13466 _this = _possibleConstructorReturn(this, _getPrototypeOf(DualThumb).apply(this, arguments));
13467 _this.state = {
13468 value: sanitizeValue(_this.props.value, _this.props.min, _this.props.max, _this.props.step),
13469 trackWidth: 0,
13470 trackLeft: 0
13471 };
13472 _this.track = React__default.createRef();
13473 _this.trackWrapper = React__default.createRef();
13474 _this.thumbLower = React__default.createRef();
13475 _this.thumbUpper = React__default.createRef();
13476 _this.setTrackPosition = debounce(function () {
13477 if (_this.track.current) {
13478 var _this$track$current$g = _this.track.current.getBoundingClientRect(),
13479 width = _this$track$current$g.width,
13480 left = _this$track$current$g.left;
13481
13482 var adjustedTrackWidth = width - THUMB_SIZE;
13483 var adjustedTrackLeft = left + THUMB_SIZE / 2;
13484
13485 _this.setState({
13486 trackWidth: adjustedTrackWidth,
13487 trackLeft: adjustedTrackLeft
13488 });
13489 }
13490 }, 40, {
13491 leading: true,
13492 trailing: true,
13493 maxWait: 40
13494 });
13495
13496 _this.handleMouseDownThumbLower = function (event) {
13497 if (event.button !== 0 || _this.props.disabled) return;
13498 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
13499 event.stopPropagation();
13500 };
13501
13502 _this.handleMouseMoveThumbLower = function (event) {
13503 var valueUpper = _this.state.value[1];
13504
13505 _this.setValue([_this.actualXPosition(event.clientX), valueUpper], Control.Upper);
13506 };
13507
13508 _this.handleTouchStartThumbLower = function (event) {
13509 if (_this.props.disabled) return;
13510 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
13511 event.stopPropagation();
13512 };
13513
13514 _this.handleTouchMoveThumbLower = function (event) {
13515 event.preventDefault();
13516 var valueUpper = _this.state.value[1];
13517
13518 _this.setValue([_this.actualXPosition(event.touches[0].clientX), valueUpper], Control.Upper);
13519 };
13520
13521 _this.handleMouseDownThumbUpper = function (event) {
13522 if (event.button !== 0 || _this.props.disabled) return;
13523 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
13524 event.stopPropagation();
13525 };
13526
13527 _this.handleMouseMoveThumbUpper = function (event) {
13528 var valueLower = _this.state.value[0];
13529
13530 _this.setValue([valueLower, _this.actualXPosition(event.clientX)], Control.Lower);
13531 };
13532
13533 _this.handleTouchStartThumbUpper = function (event) {
13534 if (_this.props.disabled) return;
13535 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
13536 event.stopPropagation();
13537 };
13538
13539 _this.handleTouchMoveThumbUpper = function (event) {
13540 event.preventDefault();
13541 var valueLower = _this.state.value[0];
13542
13543 _this.setValue([valueLower, _this.actualXPosition(event.touches[0].clientX)], Control.Lower);
13544 };
13545
13546 _this.handleKeypressLower = function (event) {
13547 if (_this.props.disabled) return;
13548
13549 var _assertThisInitialize = _assertThisInitialized(_this),
13550 incrementValueLower = _assertThisInitialize.incrementValueLower,
13551 decrementValueLower = _assertThisInitialize.decrementValueLower;
13552
13553 var handlerMap = {
13554 [Key.UpArrow]: incrementValueLower,
13555 [Key.RightArrow]: incrementValueLower,
13556 [Key.DownArrow]: decrementValueLower,
13557 [Key.LeftArrow]: decrementValueLower
13558 };
13559 var handler = handlerMap[event.keyCode];
13560
13561 if (handler != null) {
13562 event.preventDefault();
13563 event.stopPropagation();
13564 handler();
13565 }
13566 };
13567
13568 _this.handleKeypressUpper = function (event) {
13569 if (_this.props.disabled) return;
13570
13571 var _assertThisInitialize2 = _assertThisInitialized(_this),
13572 incrementValueUpper = _assertThisInitialize2.incrementValueUpper,
13573 decrementValueUpper = _assertThisInitialize2.decrementValueUpper;
13574
13575 var handlerMap = {
13576 [Key.UpArrow]: incrementValueUpper,
13577 [Key.RightArrow]: incrementValueUpper,
13578 [Key.DownArrow]: decrementValueUpper,
13579 [Key.LeftArrow]: decrementValueUpper
13580 };
13581 var handler = handlerMap[event.keyCode];
13582
13583 if (handler != null) {
13584 event.preventDefault();
13585 event.stopPropagation();
13586 handler();
13587 }
13588 };
13589
13590 _this.incrementValueLower = function () {
13591 _this.setValue([_this.state.value[0] + _this.props.step, _this.state.value[1]], Control.Upper);
13592 };
13593
13594 _this.decrementValueLower = function () {
13595 _this.setValue([_this.state.value[0] - _this.props.step, _this.state.value[1]], Control.Upper);
13596 };
13597
13598 _this.incrementValueUpper = function () {
13599 _this.setValue([_this.state.value[0], _this.state.value[1] + _this.props.step], Control.Lower);
13600 };
13601
13602 _this.decrementValueUpper = function () {
13603 _this.setValue([_this.state.value[0], _this.state.value[1] - _this.props.step], Control.Lower);
13604 };
13605
13606 _this.dispatchValue = function () {
13607 var _this$props = _this.props,
13608 onChange = _this$props.onChange,
13609 id = _this$props.id;
13610 var value = _this.state.value;
13611 onChange(value, id);
13612 };
13613
13614 _this.setValue = function (dirtyValue, control) {
13615 var _assertThisInitialize3 = _assertThisInitialized(_this),
13616 _assertThisInitialize4 = _assertThisInitialize3.props,
13617 min = _assertThisInitialize4.min,
13618 max = _assertThisInitialize4.max,
13619 step = _assertThisInitialize4.step,
13620 value = _assertThisInitialize3.state.value;
13621
13622 var sanitizedValue = sanitizeValue(dirtyValue, min, max, step, control);
13623
13624 if (isEqual(sanitizedValue, value) === false) {
13625 _this.setState({
13626 value: sanitizedValue
13627 }, _this.dispatchValue);
13628 }
13629 };
13630
13631 _this.handleMouseDownTrack = function (event) {
13632 if (event.button !== 0 || _this.props.disabled) return;
13633 event.preventDefault();
13634
13635 var clickXPosition = _this.actualXPosition(event.clientX);
13636
13637 var value = _this.state.value;
13638 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
13639 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
13640
13641 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
13642 _this.setValue([clickXPosition, value[1]], Control.Upper);
13643
13644 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
13645
13646 if (_this.thumbLower.current != null) {
13647 _this.thumbLower.current.focus();
13648 }
13649 } else {
13650 _this.setValue([value[0], clickXPosition], Control.Lower);
13651
13652 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
13653
13654 if (_this.thumbUpper.current != null) {
13655 _this.thumbUpper.current.focus();
13656 }
13657 }
13658 };
13659
13660 _this.handleTouchStartTrack = function (event) {
13661 if (_this.props.disabled) return;
13662 event.preventDefault();
13663
13664 var clickXPosition = _this.actualXPosition(event.touches[0].clientX);
13665
13666 var value = _this.state.value;
13667 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
13668 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
13669
13670 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
13671 _this.setValue([clickXPosition, value[1]], Control.Upper);
13672
13673 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
13674
13675 if (_this.thumbLower.current != null) {
13676 _this.thumbLower.current.focus();
13677 }
13678 } else {
13679 _this.setValue([value[0], clickXPosition], Control.Lower);
13680
13681 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
13682
13683 if (_this.thumbUpper.current != null) {
13684 _this.thumbUpper.current.focus();
13685 }
13686 }
13687 };
13688
13689 _this.actualXPosition = function (dirtyXPosition) {
13690 if (_this.track.current) {
13691 var _this$props2 = _this.props,
13692 min = _this$props2.min,
13693 max = _this$props2.max;
13694 var _this$state = _this.state,
13695 trackLeft = _this$state.trackLeft,
13696 trackWidth = _this$state.trackWidth;
13697 var relativeX = dirtyXPosition - trackLeft;
13698 var percentageOfTrack = relativeX / trackWidth;
13699 return percentageOfTrack * (max - min);
13700 } else {
13701 return 0;
13702 }
13703 };
13704
13705 return _this;
13706 }
13707
13708 _createClass(DualThumb, [{
13709 key: "componentDidMount",
13710 value: function componentDidMount() {
13711 this.setTrackPosition();
13712
13713 if (this.trackWrapper.current != null) {
13714 addEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack, {
13715 passive: false
13716 });
13717 }
13718 }
13719 }, {
13720 key: "componentWillUnmount",
13721 value: function componentWillUnmount() {
13722 if (this.trackWrapper.current != null) {
13723 removeEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack);
13724 }
13725 }
13726 }, {
13727 key: "render",
13728 value: function render() {
13729 var _this$props3 = this.props,
13730 id = _this$props3.id,
13731 min = _this$props3.min,
13732 max = _this$props3.max,
13733 prefix = _this$props3.prefix,
13734 suffix = _this$props3.suffix,
13735 disabled = _this$props3.disabled,
13736 output = _this$props3.output,
13737 error = _this$props3.error,
13738 onFocus = _this$props3.onFocus,
13739 onBlur = _this$props3.onBlur,
13740 label = _this$props3.label,
13741 labelAction = _this$props3.labelAction,
13742 labelHidden = _this$props3.labelHidden,
13743 helpText = _this$props3.helpText;
13744 var value = this.state.value;
13745 var idLower = id;
13746 var idUpper = "".concat(id, "Upper");
13747 var describedBy = [];
13748
13749 if (error) {
13750 describedBy.push("".concat(id, "Error"));
13751 }
13752
13753 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
13754 var trackWrapperClassName = classNames(styles$1l.TrackWrapper, error && styles$1l.error, disabled && styles$1l.disabled);
13755 var thumbLowerClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbLower, disabled && styles$1l.disabled);
13756 var thumbUpperClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbUpper, disabled && styles$1l.disabled);
13757 var trackWidth = this.state.trackWidth;
13758 var range = max - min;
13759 var leftPositionThumbLower = value[0] / range * trackWidth;
13760 var leftPositionThumbUpper = value[1] / range * trackWidth;
13761 var outputLowerClassName = classNames(styles$1l.Output, styles$1l.OutputLower);
13762 var outputMarkupLower = !disabled && output ? React__default.createElement("output", {
13763 htmlFor: idLower,
13764 className: outputLowerClassName,
13765 style: {
13766 left: "".concat(leftPositionThumbLower, "px")
13767 }
13768 }, React__default.createElement("div", {
13769 className: styles$1l.OutputBubble
13770 }, React__default.createElement("span", {
13771 className: styles$1l.OutputText
13772 }, value[0]))) : null;
13773 var outputUpperClassName = classNames(styles$1l.Output, styles$1l.OutputUpper);
13774 var outputMarkupUpper = !disabled && output ? React__default.createElement("output", {
13775 htmlFor: idUpper,
13776 className: outputUpperClassName,
13777 style: {
13778 left: "".concat(leftPositionThumbUpper, "px")
13779 }
13780 }, React__default.createElement("div", {
13781 className: styles$1l.OutputBubble
13782 }, React__default.createElement("span", {
13783 className: styles$1l.OutputText
13784 }, value[1]))) : null;
13785 var cssVars = {
13786 ["".concat(CSS_VAR_PREFIX, "progress-lower")]: "".concat(leftPositionThumbLower, "px"),
13787 ["".concat(CSS_VAR_PREFIX, "progress-upper")]: "".concat(leftPositionThumbUpper, "px")
13788 };
13789 var prefixMarkup = prefix && React__default.createElement("div", {
13790 className: styles$1l.Prefix
13791 }, prefix);
13792 var suffixMarkup = suffix && React__default.createElement("div", {
13793 className: styles$1l.Suffix
13794 }, suffix);
13795 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Labelled, {
13796 id: id,
13797 label: label,
13798 error: error,
13799 action: labelAction,
13800 labelHidden: labelHidden,
13801 helpText: helpText
13802 }, React__default.createElement("div", {
13803 className: styles$1l.Wrapper
13804 }, prefixMarkup, React__default.createElement("div", {
13805 className: trackWrapperClassName,
13806 onMouseDown: this.handleMouseDownTrack,
13807 ref: this.trackWrapper
13808 }, React__default.createElement("div", {
13809 className: styles$1l.Track,
13810 style: cssVars,
13811 ref: this.track
13812 }), React__default.createElement("div", {
13813 className: styles$1l['Track--dashed']
13814 }), React__default.createElement("button", {
13815 id: idLower,
13816 className: thumbLowerClassName,
13817 style: {
13818 left: "".concat(leftPositionThumbLower, "px")
13819 },
13820 role: "slider",
13821 "aria-disabled": disabled,
13822 "aria-valuemin": min,
13823 "aria-valuemax": max,
13824 "aria-valuenow": value[0],
13825 "aria-invalid": Boolean(error),
13826 "aria-describedby": ariaDescribedBy,
13827 "aria-labelledby": labelID(id),
13828 onFocus: onFocus,
13829 onBlur: onBlur,
13830 onKeyDown: this.handleKeypressLower,
13831 onMouseDown: this.handleMouseDownThumbLower,
13832 onTouchStart: this.handleTouchStartThumbLower,
13833 ref: this.thumbLower,
13834 disabled: disabled
13835 }), outputMarkupLower, React__default.createElement("button", {
13836 id: idUpper,
13837 className: thumbUpperClassName,
13838 style: {
13839 left: "".concat(leftPositionThumbUpper, "px")
13840 },
13841 role: "slider",
13842 "aria-disabled": disabled,
13843 "aria-valuemin": min,
13844 "aria-valuemax": max,
13845 "aria-valuenow": value[1],
13846 "aria-invalid": Boolean(error),
13847 "aria-describedby": ariaDescribedBy,
13848 "aria-labelledby": labelID(id),
13849 onFocus: onFocus,
13850 onBlur: onBlur,
13851 onKeyDown: this.handleKeypressUpper,
13852 onMouseDown: this.handleMouseDownThumbUpper,
13853 onTouchStart: this.handleTouchStartThumbUpper,
13854 ref: this.thumbUpper,
13855 disabled: disabled
13856 }), outputMarkupUpper), suffixMarkup)), React__default.createElement(EventListener, {
13857 event: "resize",
13858 handler: this.setTrackPosition
13859 }));
13860 }
13861 }], [{
13862 key: "getDerivedStateFromProps",
13863 value: function getDerivedStateFromProps(props, state) {
13864 var min = props.min,
13865 step = props.step,
13866 max = props.max,
13867 value = props.value,
13868 onChange = props.onChange,
13869 id = props.id;
13870 var prevValue = state.prevValue;
13871
13872 if (isEqual(prevValue, value)) {
13873 return null;
13874 }
13875
13876 var sanitizedValue = sanitizeValue(value, min, max, step);
13877
13878 if (!isEqual(value, sanitizedValue)) {
13879 onChange(sanitizedValue, id);
13880 }
13881
13882 return {
13883 prevValue: value,
13884 value: sanitizedValue
13885 };
13886 }
13887 }]);
13888
13889 return DualThumb;
13890}(React__default.Component);
13891
13892function registerMouseMoveHandler(handler) {
13893 addEventListener(document, 'mousemove', handler);
13894 addEventListener(document, 'mouseup', function () {
13895 removeEventListener(document, 'mousemove', handler);
13896 }, {
13897 once: true
13898 });
13899}
13900
13901function registerTouchMoveHandler(handler) {
13902 var removeHandler = function removeHandler() {
13903 removeEventListener(document, 'touchmove', handler);
13904 removeEventListener(document, 'touchend', removeHandler);
13905 removeEventListener(document, 'touchcancel', removeHandler);
13906 };
13907
13908 addEventListener(document, 'touchmove', handler, {
13909 passive: false
13910 });
13911 addEventListener(document, 'touchend', removeHandler, {
13912 once: true
13913 });
13914 addEventListener(document, 'touchcancel', removeHandler, {
13915 once: true
13916 });
13917}
13918
13919function sanitizeValue(value, min, max, step) {
13920 var control = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : Control.Upper;
13921 var upperValue = inBoundsUpper(roundedToStep(value[1]));
13922 var lowerValue = inBoundsLower(roundedToStep(value[0]));
13923 var maxLowerValue = upperValue - step;
13924 var minUpperValue = lowerValue + step;
13925
13926 if (control === Control.Upper && lowerValue > maxLowerValue) {
13927 lowerValue = maxLowerValue;
13928 } else if (control === Control.Lower && upperValue < minUpperValue) {
13929 upperValue = minUpperValue;
13930 }
13931
13932 return [lowerValue, upperValue];
13933
13934 function inBoundsUpper(value) {
13935 var lowerMin = min + step;
13936
13937 if (value < lowerMin) {
13938 return lowerMin;
13939 } else if (value > max) {
13940 return max;
13941 } else {
13942 return value;
13943 }
13944 }
13945
13946 function inBoundsLower(value) {
13947 var upperMax = max - step;
13948
13949 if (value < min) {
13950 return min;
13951 } else if (value > upperMax) {
13952 return upperMax;
13953 } else {
13954 return value;
13955 }
13956 }
13957
13958 function roundedToStep(value) {
13959 return Math.round(value / step) * step;
13960 }
13961}
13962
13963function clamp(number, min, max) {
13964 if (number < min) return min;
13965 if (number > max) return max;
13966 return number;
13967}
13968
13969var styles$1m = {
13970 "SingleThumb": "Polaris-RangeSlider-SingleThumb",
13971 "disabled": "Polaris-RangeSlider-SingleThumb--disabled",
13972 "InputWrapper": "Polaris-RangeSlider-SingleThumb__InputWrapper",
13973 "Prefix": "Polaris-RangeSlider-SingleThumb__Prefix",
13974 "Suffix": "Polaris-RangeSlider-SingleThumb__Suffix",
13975 "Input": "Polaris-RangeSlider-SingleThumb__Input",
13976 "error": "Polaris-RangeSlider-SingleThumb--error",
13977 "Output": "Polaris-RangeSlider-SingleThumb__Output",
13978 "OutputBubble": "Polaris-RangeSlider-SingleThumb__OutputBubble",
13979 "OutputText": "Polaris-RangeSlider-SingleThumb__OutputText"
13980};
13981
13982function SingleThumb(props) {
13983 var id = props.id,
13984 error = props.error,
13985 helpText = props.helpText,
13986 value = props.value,
13987 min = props.min,
13988 max = props.max,
13989 disabled = props.disabled,
13990 output = props.output,
13991 prefix = props.prefix,
13992 suffix = props.suffix,
13993 label = props.label,
13994 labelAction = props.labelAction,
13995 labelHidden = props.labelHidden,
13996 step = props.step,
13997 onBlur = props.onBlur,
13998 onFocus = props.onFocus;
13999 var clampedValue = clamp(value, min, max);
14000 var describedBy = [];
14001
14002 if (error) {
14003 describedBy.push("".concat(id, "Error"));
14004 }
14005
14006 if (helpText) {
14007 describedBy.push(helpTextID(id));
14008 }
14009
14010 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
14011 var sliderProgress = (clampedValue - min) * 100 / (max - min);
14012 var outputFactor = invertNumber((sliderProgress - 50) / 100);
14013 var cssVars = {
14014 ["".concat(CSS_VAR_PREFIX, "min")]: min,
14015 ["".concat(CSS_VAR_PREFIX, "max")]: max,
14016 ["".concat(CSS_VAR_PREFIX, "current")]: clampedValue,
14017 ["".concat(CSS_VAR_PREFIX, "progress")]: "".concat(sliderProgress, "%"),
14018 ["".concat(CSS_VAR_PREFIX, "output-factor")]: "".concat(outputFactor)
14019 };
14020 var outputMarkup = !disabled && output && React__default.createElement("output", {
14021 htmlFor: id,
14022 className: styles$1m.Output
14023 }, React__default.createElement("div", {
14024 className: styles$1m.OutputBubble
14025 }, React__default.createElement("span", {
14026 className: styles$1m.OutputText
14027 }, clampedValue)));
14028 var prefixMarkup = prefix && React__default.createElement("div", {
14029 className: styles$1m.Prefix
14030 }, prefix);
14031 var suffixMarkup = suffix && React__default.createElement("div", {
14032 className: styles$1m.Suffix
14033 }, suffix);
14034 var className = classNames(styles$1m.SingleThumb, error && styles$1m.error, disabled && styles$1m.disabled);
14035 return React__default.createElement(Labelled, {
14036 id: id,
14037 label: label,
14038 error: error,
14039 action: labelAction,
14040 labelHidden: labelHidden,
14041 helpText: helpText
14042 }, React__default.createElement("div", {
14043 className: className,
14044 style: cssVars
14045 }, prefixMarkup, React__default.createElement("div", {
14046 className: styles$1m.InputWrapper
14047 }, React__default.createElement("input", {
14048 type: "range",
14049 className: styles$1m.Input,
14050 id: id,
14051 name: id,
14052 min: min,
14053 max: max,
14054 step: step,
14055 value: clampedValue,
14056 disabled: disabled,
14057 onChange: handleChange,
14058 onFocus: onFocus,
14059 onBlur: onBlur,
14060 "aria-valuemin": min,
14061 "aria-valuemax": max,
14062 "aria-valuenow": clampedValue,
14063 "aria-invalid": Boolean(error),
14064 "aria-describedby": ariaDescribedBy
14065 }), outputMarkup), suffixMarkup));
14066
14067 function handleChange(event) {
14068 var onChange = props.onChange;
14069 onChange && onChange(parseFloat(event.currentTarget.value), id);
14070 }
14071}
14072
14073function RangeSlider(_a) {
14074 var _a$min = _a.min,
14075 min = _a$min === void 0 ? 0 : _a$min,
14076 _a$max = _a.max,
14077 max = _a$max === void 0 ? 100 : _a$max,
14078 _a$step = _a.step,
14079 step = _a$step === void 0 ? 1 : _a$step,
14080 value = _a.value,
14081 rest = __rest(_a, ["min", "max", "step", "value"]);
14082
14083 var id = useUniqueId('RangeSlider');
14084 var sharedProps = Object.assign({
14085 id,
14086 min,
14087 max,
14088 step
14089 }, rest);
14090 return isDualThumb(value) ? React__default.createElement(DualThumb, Object.assign({
14091 value: value
14092 }, sharedProps)) : React__default.createElement(SingleThumb, Object.assign({
14093 value: value
14094 }, sharedProps));
14095}
14096
14097function isDualThumb(value) {
14098 return Array.isArray(value);
14099}
14100
14101var styles$1n = {
14102 "CheckboxWrapper": "Polaris-ResourceItem__CheckboxWrapper",
14103 "ResourceItem": "Polaris-ResourceItem",
14104 "persistActions": "Polaris-ResourceItem--persistActions",
14105 "Actions": "Polaris-ResourceItem__Actions",
14106 "newDesignLanguage": "Polaris-ResourceItem--newDesignLanguage",
14107 "selected": "Polaris-ResourceItem--selected",
14108 "focused": "Polaris-ResourceItem--focused",
14109 "focusedInner": "Polaris-ResourceItem--focusedInner",
14110 "Link": "Polaris-ResourceItem__Link",
14111 "Button": "Polaris-ResourceItem__Button",
14112 "Container": "Polaris-ResourceItem__Container",
14113 "Owned": "Polaris-ResourceItem__Owned",
14114 "Handle": "Polaris-ResourceItem__Handle",
14115 "selectMode": "Polaris-ResourceItem--selectMode",
14116 "selectable": "Polaris-ResourceItem--selectable",
14117 "Media": "Polaris-ResourceItem__Media",
14118 "Content": "Polaris-ResourceItem__Content",
14119 "Disclosure": "Polaris-ResourceItem__Disclosure"
14120};
14121
14122var getUniqueCheckboxID = createUniqueIDFactory('ResourceListItemCheckbox');
14123var getUniqueOverlayID = createUniqueIDFactory('ResourceListItemOverlay');
14124
14125var BaseResourceItem =
14126/*#__PURE__*/
14127function (_React$Component) {
14128 _inherits(BaseResourceItem, _React$Component);
14129
14130 function BaseResourceItem() {
14131 var _this;
14132
14133 _classCallCheck(this, BaseResourceItem);
14134
14135 _this = _possibleConstructorReturn(this, _getPrototypeOf(BaseResourceItem).apply(this, arguments));
14136 _this.state = {
14137 actionsMenuVisible: false,
14138 focused: false,
14139 focusedInner: false,
14140 selected: isSelected(_this.props.id, _this.props.context.selectedItems)
14141 };
14142 _this.node = null;
14143 _this.checkboxId = getUniqueCheckboxID();
14144 _this.overlayId = getUniqueOverlayID();
14145 _this.buttonOverlay = React__default.createRef();
14146
14147 _this.setNode = function (node) {
14148 _this.node = node;
14149 };
14150
14151 _this.handleFocus = function (event) {
14152 if (event.target === _this.buttonOverlay.current || _this.node && event.target === _this.node.querySelector("#".concat(_this.overlayId))) {
14153 _this.setState({
14154 focused: true,
14155 focusedInner: false
14156 });
14157 } else if (_this.node && _this.node.contains(event.target)) {
14158 _this.setState({
14159 focused: true,
14160 focusedInner: true
14161 });
14162 }
14163 };
14164
14165 _this.handleBlur = function (_ref) {
14166 var relatedTarget = _ref.relatedTarget;
14167
14168 if (_this.node && relatedTarget instanceof Element && _this.node.contains(relatedTarget)) {
14169 return;
14170 }
14171
14172 _this.setState({
14173 focused: false,
14174 focusedInner: false
14175 });
14176 };
14177
14178 _this.handleMouseOut = function () {
14179 _this.state.focused && _this.setState({
14180 focused: false,
14181 focusedInner: false
14182 });
14183 };
14184
14185 _this.handleLargerSelectionArea = function (event) {
14186 stopPropagation$1(event);
14187
14188 _this.handleSelection(!_this.state.selected, event.nativeEvent.shiftKey);
14189 };
14190
14191 _this.handleSelection = function (value, shiftKey) {
14192 var _this$props = _this.props,
14193 id = _this$props.id,
14194 sortOrder = _this$props.sortOrder,
14195 onSelectionChange = _this$props.context.onSelectionChange;
14196
14197 if (id == null || onSelectionChange == null) {
14198 return;
14199 }
14200
14201 _this.setState({
14202 focused: value,
14203 focusedInner: value
14204 });
14205
14206 onSelectionChange(value, id, sortOrder, shiftKey);
14207 };
14208
14209 _this.handleClick = function (event) {
14210 stopPropagation$1(event);
14211 var _this$props2 = _this.props,
14212 id = _this$props2.id,
14213 onClick = _this$props2.onClick,
14214 url = _this$props2.url,
14215 selectMode = _this$props2.context.selectMode;
14216 var _event$nativeEvent = event.nativeEvent,
14217 ctrlKey = _event$nativeEvent.ctrlKey,
14218 metaKey = _event$nativeEvent.metaKey;
14219
14220 var anchor = _this.node && _this.node.querySelector('a');
14221
14222 if (selectMode) {
14223 _this.handleLargerSelectionArea(event);
14224
14225 return;
14226 }
14227
14228 if (anchor === event.target) {
14229 return;
14230 }
14231
14232 if (onClick) {
14233 onClick(id);
14234 }
14235
14236 if (url && (ctrlKey || metaKey)) {
14237 window.open(url, '_blank');
14238 return;
14239 }
14240
14241 if (url && anchor) {
14242 anchor.click();
14243 }
14244 }; // This fires onClick when there is a URL on the item
14245
14246
14247 _this.handleKeyUp = function (event) {
14248 var _this$props3 = _this.props,
14249 _this$props3$onClick = _this$props3.onClick,
14250 onClick = _this$props3$onClick === void 0 ? noop$a : _this$props3$onClick,
14251 selectMode = _this$props3.context.selectMode;
14252 var key = event.key;
14253
14254 if (key === 'Enter' && _this.props.url && !selectMode) {
14255 onClick();
14256 }
14257 };
14258
14259 _this.handleActionsClick = function () {
14260 _this.setState(function (_ref2) {
14261 var actionsMenuVisible = _ref2.actionsMenuVisible;
14262 return {
14263 actionsMenuVisible: !actionsMenuVisible
14264 };
14265 });
14266 };
14267
14268 _this.handleCloseRequest = function () {
14269 _this.setState({
14270 actionsMenuVisible: false
14271 });
14272 };
14273
14274 return _this;
14275 }
14276
14277 _createClass(BaseResourceItem, [{
14278 key: "shouldComponentUpdate",
14279 value: function shouldComponentUpdate(nextProps, nextState) {
14280 var _a = nextProps.context,
14281 nextSelectedItems = _a.selectedItems,
14282 restNextContext = __rest(_a, ["selectedItems"]),
14283 restNextProps = __rest(nextProps, ["context"]);
14284
14285 var _b = this.props,
14286 _c = _b.context,
14287 selectedItems = _c.selectedItems,
14288 restContext = __rest(_c, ["selectedItems"]),
14289 restProps = __rest(_b, ["context"]);
14290
14291 var nextSelectMode = nextProps.context.selectMode;
14292 return !isEqual(this.state, nextState) || this.props.context.selectMode !== nextSelectMode || !nextProps.context.selectMode && (!isEqual(restProps, restNextProps) || !isEqual(restContext, restNextContext));
14293 }
14294 }, {
14295 key: "render",
14296 value: function render() {
14297 var _this$props4 = this.props,
14298 children = _this$props4.children,
14299 url = _this$props4.url,
14300 external = _this$props4.external,
14301 media = _this$props4.media,
14302 shortcutActions = _this$props4.shortcutActions,
14303 ariaControls = _this$props4.ariaControls,
14304 ariaExpanded = _this$props4.ariaExpanded,
14305 _this$props4$persistA = _this$props4.persistActions,
14306 persistActions = _this$props4$persistA === void 0 ? false : _this$props4$persistA,
14307 accessibilityLabel = _this$props4.accessibilityLabel,
14308 name = _this$props4.name,
14309 _this$props4$context = _this$props4.context,
14310 selectable = _this$props4$context.selectable,
14311 selectMode = _this$props4$context.selectMode,
14312 loading = _this$props4$context.loading,
14313 resourceName = _this$props4$context.resourceName,
14314 i18n = _this$props4.i18n,
14315 newDesignLanguage = _this$props4.features.newDesignLanguage;
14316 var _this$state = this.state,
14317 actionsMenuVisible = _this$state.actionsMenuVisible,
14318 focused = _this$state.focused,
14319 focusedInner = _this$state.focusedInner,
14320 selected = _this$state.selected;
14321 var ownedMarkup = null;
14322 var handleMarkup = null;
14323 var mediaMarkup = media ? React__default.createElement("div", {
14324 className: styles$1n.Media
14325 }, media) : null;
14326
14327 if (selectable) {
14328 var checkboxAccessibilityLabel = name || accessibilityLabel || i18n.translate('Polaris.Common.checkbox');
14329 handleMarkup = React__default.createElement("div", {
14330 className: styles$1n.Handle,
14331 onClick: this.handleLargerSelectionArea
14332 }, React__default.createElement("div", {
14333 onClick: stopPropagation$1,
14334 className: styles$1n.CheckboxWrapper
14335 }, React__default.createElement("div", {
14336 onChange: this.handleLargerSelectionArea
14337 }, React__default.createElement(Checkbox$1, {
14338 id: this.checkboxId,
14339 label: checkboxAccessibilityLabel,
14340 labelHidden: true,
14341 checked: selected,
14342 disabled: loading
14343 }))));
14344 }
14345
14346 if (media || selectable) {
14347 ownedMarkup = React__default.createElement("div", {
14348 className: styles$1n.Owned
14349 }, handleMarkup, mediaMarkup);
14350 }
14351
14352 var className = classNames(styles$1n.ResourceItem, newDesignLanguage && styles$1n.newDesignLanguage, focused && styles$1n.focused, selectable && styles$1n.selectable, selected && styles$1n.selected, selectMode && styles$1n.selectMode, persistActions && styles$1n.persistActions, focusedInner && styles$1n.focusedInner);
14353 var actionsMarkup = null;
14354 var disclosureMarkup = null;
14355
14356 if (shortcutActions && !loading) {
14357 if (persistActions) {
14358 actionsMarkup = React__default.createElement("div", {
14359 className: styles$1n.Actions,
14360 onClick: stopPropagation$1
14361 }, React__default.createElement(ButtonGroup, null, buttonsFrom(shortcutActions, {
14362 plain: true
14363 })));
14364 var disclosureAccessibilityLabel = name ? i18n.translate('Polaris.ResourceList.Item.actionsDropdownLabel', {
14365 accessibilityLabel: name
14366 }) : i18n.translate('Polaris.ResourceList.Item.actionsDropdown');
14367 disclosureMarkup = React__default.createElement("div", {
14368 className: styles$1n.Disclosure,
14369 onClick: stopPropagation$1
14370 }, React__default.createElement(Popover, {
14371 activator: React__default.createElement(Button, {
14372 accessibilityLabel: disclosureAccessibilityLabel,
14373 onClick: this.handleActionsClick,
14374 plain: true,
14375 icon: HorizontalDotsMinor
14376 }),
14377 onClose: this.handleCloseRequest,
14378 active: actionsMenuVisible
14379 }, React__default.createElement(ActionList, {
14380 items: shortcutActions
14381 })));
14382 } else {
14383 actionsMarkup = React__default.createElement("div", {
14384 className: styles$1n.Actions,
14385 onClick: stopPropagation$1
14386 }, React__default.createElement(ButtonGroup, {
14387 segmented: true
14388 }, buttonsFrom(shortcutActions, {
14389 size: 'slim'
14390 })));
14391 }
14392 }
14393
14394 var content = children ? React__default.createElement("div", {
14395 className: styles$1n.Content
14396 }, children) : null;
14397 var containerMarkup = React__default.createElement("div", {
14398 className: styles$1n.Container,
14399 id: this.props.id
14400 }, ownedMarkup, content, actionsMarkup, disclosureMarkup);
14401 var tabIndex = loading ? -1 : 0;
14402 var ariaLabel = accessibilityLabel || i18n.translate('Polaris.ResourceList.Item.viewItem', {
14403 itemName: name || resourceName && resourceName.singular || ''
14404 });
14405 var accessibleMarkup = url ? React__default.createElement(UnstyledLink, {
14406 "aria-describedby": this.props.id,
14407 "aria-label": ariaLabel,
14408 className: styles$1n.Link,
14409 url: url,
14410 external: external,
14411 tabIndex: tabIndex,
14412 id: this.overlayId
14413 }) : React__default.createElement("button", {
14414 className: styles$1n.Button,
14415 "aria-label": ariaLabel,
14416 "aria-controls": ariaControls,
14417 "aria-expanded": ariaExpanded,
14418 onClick: this.handleClick,
14419 tabIndex: tabIndex,
14420 ref: this.buttonOverlay
14421 });
14422 return React__default.createElement("div", {
14423 ref: this.setNode,
14424 className: className,
14425 onClick: this.handleClick,
14426 onFocus: this.handleFocus,
14427 onBlur: this.handleBlur,
14428 onKeyUp: this.handleKeyUp,
14429 onMouseOut: this.handleMouseOut,
14430 "data-href": url
14431 }, accessibleMarkup, containerMarkup);
14432 }
14433 }], [{
14434 key: "getDerivedStateFromProps",
14435 value: function getDerivedStateFromProps(nextProps, prevState) {
14436 var selected = isSelected(nextProps.id, nextProps.context.selectedItems);
14437
14438 if (prevState.selected === selected) {
14439 return null;
14440 }
14441
14442 return {
14443 selected
14444 };
14445 }
14446 }]);
14447
14448 return BaseResourceItem;
14449}(React__default.Component);
14450
14451function noop$a() {}
14452
14453function stopPropagation$1(event) {
14454 event.stopPropagation();
14455}
14456
14457function isSelected(id, selectedItems) {
14458 return Boolean(selectedItems && (Array.isArray(selectedItems) && selectedItems.includes(id) || selectedItems === SELECT_ALL_ITEMS));
14459}
14460
14461function ResourceItem(props) {
14462 return React__default.createElement(BaseResourceItem, Object.assign({}, props, {
14463 context: useContext(ResourceListContext),
14464 features: useFeatures(),
14465 i18n: useI18n()
14466 }));
14467}
14468
14469var StickyInner =
14470/*#__PURE__*/
14471function (_React$Component) {
14472 _inherits(StickyInner, _React$Component);
14473
14474 function StickyInner() {
14475 var _this;
14476
14477 _classCallCheck(this, StickyInner);
14478
14479 _this = _possibleConstructorReturn(this, _getPrototypeOf(StickyInner).apply(this, arguments));
14480 _this.state = {
14481 isSticky: false,
14482 style: {}
14483 };
14484 _this.placeHolderNode = null;
14485 _this.stickyNode = null;
14486
14487 _this.setPlaceHolderNode = function (node) {
14488 _this.placeHolderNode = node;
14489 };
14490
14491 _this.setStickyNode = function (node) {
14492 _this.stickyNode = node;
14493 };
14494
14495 _this.handlePositioning = function (stick) {
14496 var top = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
14497 var left = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
14498 var width = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
14499 var isSticky = _this.state.isSticky;
14500
14501 if (stick && !isSticky || !stick && isSticky) {
14502 _this.adjustPlaceHolderNode(stick);
14503
14504 _this.setState({
14505 isSticky: !isSticky
14506 });
14507 }
14508
14509 var style = stick ? {
14510 position: 'fixed',
14511 top,
14512 left,
14513 width
14514 } : {};
14515
14516 _this.setState({
14517 style
14518 });
14519 };
14520
14521 _this.adjustPlaceHolderNode = function (add) {
14522 if (_this.placeHolderNode && _this.stickyNode) {
14523 _this.placeHolderNode.style.paddingBottom = add ? "".concat(getRectForNode(_this.stickyNode).height, "px") : '0px';
14524 }
14525 };
14526
14527 return _this;
14528 }
14529
14530 _createClass(StickyInner, [{
14531 key: "componentDidMount",
14532 value: function componentDidMount() {
14533 var _this$props = this.props,
14534 boundingElement = _this$props.boundingElement,
14535 _this$props$offset = _this$props.offset,
14536 offset = _this$props$offset === void 0 ? false : _this$props$offset,
14537 _this$props$disableWh = _this$props.disableWhenStacked,
14538 disableWhenStacked = _this$props$disableWh === void 0 ? false : _this$props$disableWh,
14539 stickyManager = _this$props.polaris.stickyManager;
14540 if (!this.stickyNode || !this.placeHolderNode) return;
14541 stickyManager.registerStickyItem({
14542 stickyNode: this.stickyNode,
14543 placeHolderNode: this.placeHolderNode,
14544 handlePositioning: this.handlePositioning,
14545 offset,
14546 boundingElement,
14547 disableWhenStacked
14548 });
14549 }
14550 }, {
14551 key: "componentWillUnmount",
14552 value: function componentWillUnmount() {
14553 var stickyManager = this.props.polaris.stickyManager;
14554 if (!this.stickyNode) return;
14555 stickyManager.unregisterStickyItem(this.stickyNode);
14556 }
14557 }, {
14558 key: "render",
14559 value: function render() {
14560 var _this$state = this.state,
14561 style = _this$state.style,
14562 isSticky = _this$state.isSticky;
14563 var children = this.props.children;
14564 var childrenContent = isFunction(children) ? children(isSticky) : children;
14565 return React__default.createElement("div", null, React__default.createElement("div", {
14566 ref: this.setPlaceHolderNode
14567 }), React__default.createElement("div", {
14568 ref: this.setStickyNode,
14569 style: style
14570 }, childrenContent));
14571 }
14572 }]);
14573
14574 return StickyInner;
14575}(React__default.Component);
14576
14577function isFunction(arg) {
14578 return typeof arg === 'function';
14579}
14580
14581var Sticky = withAppProvider()(StickyInner);
14582
14583var styles$1o = {
14584 "Select": "Polaris-Select",
14585 "disabled": "Polaris-Select--disabled",
14586 "Content": "Polaris-Select__Content",
14587 "InlineLabel": "Polaris-Select__InlineLabel",
14588 "Icon": "Polaris-Select__Icon",
14589 "newDesignLanguage": "Polaris-Select--newDesignLanguage",
14590 "Backdrop": "Polaris-Select__Backdrop",
14591 "placeholder": "Polaris-Select--placeholder",
14592 "error": "Polaris-Select--error",
14593 "Input": "Polaris-Select__Input",
14594 "SelectedOption": "Polaris-Select__SelectedOption",
14595 "hover": "Polaris-Select--hover"
14596};
14597
14598var PLACEHOLDER_VALUE = '';
14599function Select(_ref) {
14600 var optionsProp = _ref.options,
14601 label = _ref.label,
14602 labelAction = _ref.labelAction,
14603 labelHiddenProp = _ref.labelHidden,
14604 labelInline = _ref.labelInline,
14605 disabled = _ref.disabled,
14606 helpText = _ref.helpText,
14607 placeholder = _ref.placeholder,
14608 idProp = _ref.id,
14609 name = _ref.name,
14610 _ref$value = _ref.value,
14611 value = _ref$value === void 0 ? PLACEHOLDER_VALUE : _ref$value,
14612 error = _ref.error,
14613 onChange = _ref.onChange,
14614 onFocus = _ref.onFocus,
14615 onBlur = _ref.onBlur;
14616 var id = useUniqueId('Select', idProp);
14617 var labelHidden = labelInline ? true : labelHiddenProp;
14618
14619 var _useFeatures = useFeatures(),
14620 newDesignLanguage = _useFeatures.newDesignLanguage;
14621
14622 var className = classNames(styles$1o.Select, error && styles$1o.error, disabled && styles$1o.disabled, newDesignLanguage && styles$1o.newDesignLanguage);
14623 var handleChange = onChange ? function (event) {
14624 return onChange(event.currentTarget.value, id);
14625 } : undefined;
14626 var describedBy = [];
14627
14628 if (helpText) {
14629 describedBy.push(helpTextID(id));
14630 }
14631
14632 if (error) {
14633 describedBy.push("".concat(id, "Error"));
14634 }
14635
14636 var options = optionsProp || [];
14637 var normalizedOptions = options.map(normalizeOption);
14638
14639 if (placeholder) {
14640 normalizedOptions = [{
14641 label: placeholder,
14642 value: PLACEHOLDER_VALUE,
14643 disabled: true
14644 }].concat(_toConsumableArray(normalizedOptions));
14645 }
14646
14647 var inlineLabelMarkup = labelInline && React__default.createElement("span", {
14648 className: styles$1o.InlineLabel
14649 }, label);
14650 var selectedOption = getSelectedOption(normalizedOptions, value);
14651 var contentMarkup = React__default.createElement("div", {
14652 className: styles$1o.Content,
14653 "aria-hidden": true,
14654 "aria-disabled": disabled
14655 }, inlineLabelMarkup, React__default.createElement("span", {
14656 className: styles$1o.SelectedOption
14657 }, selectedOption), React__default.createElement("span", {
14658 className: styles$1o.Icon
14659 }, React__default.createElement(Icon, {
14660 source: ArrowUpDownMinor
14661 })));
14662 var optionsMarkup = normalizedOptions.map(renderOption);
14663 return React__default.createElement(Labelled, {
14664 id: id,
14665 label: label,
14666 error: error,
14667 action: labelAction,
14668 labelHidden: labelHidden,
14669 helpText: helpText
14670 }, React__default.createElement("div", {
14671 className: className
14672 }, React__default.createElement("select", {
14673 id: id,
14674 name: name,
14675 value: value,
14676 className: styles$1o.Input,
14677 disabled: disabled,
14678 onFocus: onFocus,
14679 onBlur: onBlur,
14680 onChange: handleChange,
14681 "aria-invalid": Boolean(error),
14682 "aria-describedby": describedBy.length ? describedBy.join(' ') : undefined
14683 }, optionsMarkup), contentMarkup, React__default.createElement("div", {
14684 className: styles$1o.Backdrop
14685 })));
14686}
14687
14688function isString(option) {
14689 return typeof option === 'string';
14690}
14691
14692function isGroup(option) {
14693 return option.options != null;
14694}
14695
14696function normalizeStringOption(option) {
14697 return {
14698 label: option,
14699 value: option
14700 };
14701}
14702/**
14703 * Converts a string option (and each string option in a Group) into
14704 * an Option object.
14705 */
14706
14707
14708function normalizeOption(option) {
14709 if (isString(option)) {
14710 return normalizeStringOption(option);
14711 } else if (isGroup(option)) {
14712 var title = option.title,
14713 options = option.options;
14714 return {
14715 title,
14716 options: options.map(function (option) {
14717 return isString(option) ? normalizeStringOption(option) : option;
14718 })
14719 };
14720 }
14721
14722 return option;
14723}
14724/**
14725 * Gets the text to display in the UI, for the currently selected option
14726 */
14727
14728
14729function getSelectedOption(options, value) {
14730 var flatOptions = flattenOptions(options);
14731 var selectedOption = flatOptions.find(function (option) {
14732 return value === option.value;
14733 });
14734
14735 if (selectedOption === undefined) {
14736 // Get the first visible option (not the hidden placeholder)
14737 selectedOption = flatOptions.find(function (option) {
14738 return !option.hidden;
14739 });
14740 }
14741
14742 return selectedOption ? selectedOption.label : '';
14743}
14744/**
14745 * Ungroups an options array
14746 */
14747
14748
14749function flattenOptions(options) {
14750 var flatOptions = [];
14751 options.forEach(function (optionOrGroup) {
14752 if (isGroup(optionOrGroup)) {
14753 flatOptions = flatOptions.concat(optionOrGroup.options);
14754 } else {
14755 flatOptions.push(optionOrGroup);
14756 }
14757 });
14758 return flatOptions;
14759}
14760
14761function renderSingleOption(option) {
14762 var value = option.value,
14763 label = option.label,
14764 rest = __rest(option, ["value", "label"]);
14765
14766 return React__default.createElement("option", Object.assign({
14767 key: value,
14768 value: value
14769 }, rest), label);
14770}
14771
14772function renderOption(optionOrGroup) {
14773 if (isGroup(optionOrGroup)) {
14774 var title = optionOrGroup.title,
14775 options = optionOrGroup.options;
14776 return React__default.createElement("optgroup", {
14777 label: title,
14778 key: title
14779 }, options.map(renderSingleOption));
14780 }
14781
14782 return renderSingleOption(optionOrGroup);
14783}
14784
14785var styles$1p = {
14786 "CheckableButton": "Polaris-ResourceList-CheckableButton",
14787 "newDesignLanguage": "Polaris-ResourceList-CheckableButton--newDesignLanguage",
14788 "CheckableButton-selectMode": "Polaris-ResourceList-CheckableButton__CheckableButton--selectMode",
14789 "CheckableButton-measuring": "Polaris-ResourceList-CheckableButton__CheckableButton--measuring",
14790 "CheckableButton-plain": "Polaris-ResourceList-CheckableButton__CheckableButton--plain",
14791 "CheckableButton-selected": "Polaris-ResourceList-CheckableButton__CheckableButton--selected",
14792 "Checkbox": "Polaris-ResourceList-CheckableButton__Checkbox",
14793 "Label": "Polaris-ResourceList-CheckableButton__Label"
14794};
14795
14796function CheckableButton(_ref) {
14797 var accessibilityLabel = _ref.accessibilityLabel,
14798 _ref$label = _ref.label,
14799 label = _ref$label === void 0 ? '' : _ref$label,
14800 onToggleAll = _ref.onToggleAll,
14801 selected = _ref.selected,
14802 selectMode = _ref.selectMode,
14803 plain = _ref.plain,
14804 measuring = _ref.measuring,
14805 disabled = _ref.disabled,
14806 smallScreen = _ref.smallScreen;
14807 var checkBoxRef = useRef(null);
14808
14809 var _useFeatures = useFeatures(),
14810 newDesignLanguage = _useFeatures.newDesignLanguage;
14811
14812 var _React$useContext = React__default.useContext(ResourceListContext),
14813 registerCheckableButtons = _React$useContext.registerCheckableButtons;
14814
14815 var currentKey = 'bulkLg';
14816
14817 if (plain) {
14818 currentKey = 'plain';
14819 } else if (smallScreen) {
14820 currentKey = 'bulkSm';
14821 }
14822
14823 useEffect(function () {
14824 if (checkBoxRef.current && registerCheckableButtons) {
14825 registerCheckableButtons(currentKey, checkBoxRef.current);
14826 }
14827 }, [currentKey, registerCheckableButtons]);
14828 var className = plain ? classNames(styles$1p.CheckableButton, styles$1p['CheckableButton-plain'], newDesignLanguage && styles$1p.newDesignLanguage) : classNames(styles$1p.CheckableButton, newDesignLanguage && styles$1p.newDesignLanguage, selectMode && styles$1p['CheckableButton-selectMode'], selected && styles$1p['CheckableButton-selected'], measuring && styles$1p['CheckableButton-measuring']);
14829 return React__default.createElement("div", {
14830 className: className,
14831 onClick: onToggleAll
14832 }, React__default.createElement("div", {
14833 className: styles$1p.Checkbox
14834 }, React__default.createElement(Checkbox$1, {
14835 label: accessibilityLabel,
14836 labelHidden: true,
14837 checked: selected,
14838 disabled: disabled,
14839 onChange: onToggleAll,
14840 ref: checkBoxRef
14841 })), React__default.createElement("span", {
14842 className: styles$1p.Label
14843 }, label));
14844}
14845
14846var styles$1q = {
14847 "Group": "Polaris-ResourceList-BulkActions__Group",
14848 "Group-measuring": "Polaris-ResourceList-BulkActions__Group--measuring",
14849 "Group-entering": "Polaris-ResourceList-BulkActions__Group--entering",
14850 "Group-exiting": "Polaris-ResourceList-BulkActions__Group--exiting",
14851 "Group-entered": "Polaris-ResourceList-BulkActions__Group--entered",
14852 "Group-exited": "Polaris-ResourceList-BulkActions__Group--exited",
14853 "Group-smallScreen": "Polaris-ResourceList-BulkActions__Group--smallScreen",
14854 "Group-largeScreen": "Polaris-ResourceList-BulkActions__Group--largeScreen",
14855 "ButtonGroupWrapper": "Polaris-ResourceList-BulkActions__ButtonGroupWrapper",
14856 "BulkActionButton": "Polaris-ResourceList-BulkActions__BulkActionButton",
14857 "CheckableContainer": "Polaris-ResourceList-BulkActions__CheckableContainer",
14858 "disabled": "Polaris-ResourceList-BulkActions--disabled",
14859 "newDesignLanguage": "Polaris-ResourceList-BulkActions--newDesignLanguage",
14860 "PaginatedSelectAll": "Polaris-ResourceList-BulkActions__PaginatedSelectAll",
14861 "Slide": "Polaris-ResourceList-BulkActions__Slide",
14862 "Slide-appear": "Polaris-ResourceList-BulkActions__Slide--appear",
14863 "Slide-enter": "Polaris-ResourceList-BulkActions__Slide--enter",
14864 "Slide-exit": "Polaris-ResourceList-BulkActions__Slide--exit",
14865 "Slide-appearing": "Polaris-ResourceList-BulkActions__Slide--appearing",
14866 "Slide-entering": "Polaris-ResourceList-BulkActions__Slide--entering"
14867};
14868
14869function BulkActionButton(_ref) {
14870 var handleMeasurement = _ref.handleMeasurement,
14871 url = _ref.url,
14872 external = _ref.external,
14873 onAction = _ref.onAction,
14874 content = _ref.content,
14875 disclosure = _ref.disclosure,
14876 accessibilityLabel = _ref.accessibilityLabel,
14877 disabled = _ref.disabled;
14878 var bulkActionButton = useRef(null);
14879 useComponentDidMount(function () {
14880 if (handleMeasurement && bulkActionButton.current) {
14881 var width = bulkActionButton.current.getBoundingClientRect().width;
14882 handleMeasurement(width);
14883 }
14884 });
14885 return React__default.createElement("div", {
14886 className: styles$1q.BulkActionButton,
14887 ref: bulkActionButton
14888 }, React__default.createElement(Button, {
14889 external: external,
14890 url: url,
14891 "aria-label": accessibilityLabel,
14892 onClick: onAction,
14893 disabled: disabled,
14894 disclosure: disclosure
14895 }, content));
14896}
14897
14898var MAX_PROMOTED_ACTIONS = 2;
14899var slideClasses = {
14900 appear: classNames(styles$1q.Slide, styles$1q['Slide-appear']),
14901 appearActive: classNames(styles$1q.Slide, styles$1q['Slide-appearing']),
14902 enter: classNames(styles$1q.Slide, styles$1q['Slide-enter']),
14903 enterActive: classNames(styles$1q.Slide, styles$1q['Slide-entering']),
14904 exit: classNames(styles$1q.Slide, styles$1q['Slide-exit'])
14905};
14906
14907var BulkActionsInner =
14908/*#__PURE__*/
14909function (_React$PureComponent) {
14910 _inherits(BulkActionsInner, _React$PureComponent);
14911
14912 function BulkActionsInner() {
14913 var _this;
14914
14915 _classCallCheck(this, BulkActionsInner);
14916
14917 _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkActionsInner).apply(this, arguments));
14918 _this.state = {
14919 smallScreenPopoverVisible: false,
14920 largeScreenPopoverVisible: false,
14921 containerWidth: 0,
14922 measuring: true
14923 };
14924 _this.containerNode = null;
14925 _this.largeScreenButtonsNode = null;
14926 _this.moreActionsNode = null;
14927 _this.checkableWrapperNode = createRef();
14928 _this.largeScreenGroupNode = createRef();
14929 _this.smallScreenGroupNode = createRef();
14930 _this.promotedActionsWidths = [];
14931 _this.bulkActionsWidth = 0;
14932 _this.addedMoreActionsWidthForMeasuring = 0;
14933 _this.handleResize = debounce(function () {
14934 var _this$state = _this.state,
14935 smallScreenPopoverVisible = _this$state.smallScreenPopoverVisible,
14936 largeScreenPopoverVisible = _this$state.largeScreenPopoverVisible;
14937
14938 if (_this.containerNode) {
14939 var containerWidth = _this.containerNode.getBoundingClientRect().width;
14940
14941 if (containerWidth > 0) {
14942 _this.setState({
14943 containerWidth
14944 });
14945 }
14946 }
14947
14948 if (smallScreenPopoverVisible || largeScreenPopoverVisible) {
14949 _this.setState({
14950 smallScreenPopoverVisible: false,
14951 largeScreenPopoverVisible: false
14952 });
14953 }
14954 }, 50, {
14955 trailing: true
14956 });
14957
14958 _this.setLargeScreenButtonsNode = function (node) {
14959 _this.largeScreenButtonsNode = node;
14960 };
14961
14962 _this.setContainerNode = function (node) {
14963 _this.containerNode = node;
14964 };
14965
14966 _this.setMoreActionsNode = function (node) {
14967 _this.moreActionsNode = node;
14968 };
14969
14970 _this.setSelectMode = function (val) {
14971 var onSelectModeToggle = _this.props.onSelectModeToggle;
14972
14973 if (onSelectModeToggle) {
14974 onSelectModeToggle(val);
14975 }
14976 };
14977
14978 _this.toggleSmallScreenPopover = function () {
14979 _this.setState(function (_ref) {
14980 var smallScreenPopoverVisible = _ref.smallScreenPopoverVisible;
14981 return {
14982 smallScreenPopoverVisible: !smallScreenPopoverVisible
14983 };
14984 });
14985 };
14986
14987 _this.toggleLargeScreenPopover = function () {
14988 _this.setState(function (_ref2) {
14989 var largeScreenPopoverVisible = _ref2.largeScreenPopoverVisible;
14990 return {
14991 largeScreenPopoverVisible: !largeScreenPopoverVisible
14992 };
14993 });
14994 };
14995
14996 _this.handleMeasurement = function (width) {
14997 var measuring = _this.state.measuring;
14998
14999 if (measuring) {
15000 _this.promotedActionsWidths.push(width);
15001 }
15002 };
15003
15004 _this.findLargeScreenGroupNode = function () {
15005 return _this.largeScreenGroupNode.current;
15006 };
15007
15008 _this.findCheckableWrapperNode = function () {
15009 return _this.checkableWrapperNode.current;
15010 };
15011
15012 _this.findSmallScreenGroupNode = function () {
15013 return _this.smallScreenGroupNode.current;
15014 };
15015
15016 return _this;
15017 }
15018
15019 _createClass(BulkActionsInner, [{
15020 key: "numberOfPromotedActionsToRender",
15021 value: function numberOfPromotedActionsToRender() {
15022 var promotedActions = this.props.promotedActions;
15023 var _this$state2 = this.state,
15024 containerWidth = _this$state2.containerWidth,
15025 measuring = _this$state2.measuring;
15026
15027 if (!promotedActions) {
15028 return 0;
15029 }
15030
15031 if (containerWidth >= this.bulkActionsWidth || measuring) {
15032 return promotedActions.length;
15033 }
15034
15035 var sufficientSpace = false;
15036 var counter = promotedActions.length - 1;
15037 var totalWidth = 0;
15038
15039 while (!sufficientSpace && counter >= 0) {
15040 totalWidth += this.promotedActionsWidths[counter];
15041 var widthWithRemovedAction = this.bulkActionsWidth - totalWidth + this.addedMoreActionsWidthForMeasuring;
15042
15043 if (containerWidth >= widthWithRemovedAction) {
15044 sufficientSpace = true;
15045 } else {
15046 counter--;
15047 }
15048 }
15049
15050 return counter;
15051 }
15052 }, {
15053 key: "hasActions",
15054 value: function hasActions() {
15055 var _this$props = this.props,
15056 promotedActions = _this$props.promotedActions,
15057 actions = _this$props.actions;
15058 return Boolean(promotedActions && promotedActions.length > 0 || actions && actions.length > 0);
15059 }
15060 }, {
15061 key: "actionSections",
15062 value: function actionSections() {
15063 var actions = this.props.actions;
15064
15065 if (!actions || actions.length === 0) {
15066 return;
15067 }
15068
15069 if (instanceOfBulkActionListSectionArray(actions)) {
15070 return actions;
15071 }
15072
15073 if (instanceOfBulkActionArray(actions)) {
15074 return [{
15075 items: actions
15076 }];
15077 }
15078 } // eslint-disable-next-line @typescript-eslint/member-ordering
15079
15080 }, {
15081 key: "componentDidMount",
15082 value: function componentDidMount() {
15083 var _this$props2 = this.props,
15084 actions = _this$props2.actions,
15085 promotedActions = _this$props2.promotedActions;
15086
15087 if (promotedActions && !actions && this.moreActionsNode) {
15088 this.addedMoreActionsWidthForMeasuring = this.moreActionsNode.getBoundingClientRect().width;
15089 }
15090
15091 this.bulkActionsWidth = this.largeScreenButtonsNode ? this.largeScreenButtonsNode.getBoundingClientRect().width - this.addedMoreActionsWidthForMeasuring : 0;
15092
15093 if (this.containerNode) {
15094 this.setState({
15095 containerWidth: this.containerNode.getBoundingClientRect().width,
15096 measuring: false
15097 });
15098 }
15099 } // eslint-disable-next-line @typescript-eslint/member-ordering
15100
15101 }, {
15102 key: "render",
15103 value: function render() {
15104 var _this2 = this;
15105
15106 var _this$props3 = this.props,
15107 selectMode = _this$props3.selectMode,
15108 accessibilityLabel = _this$props3.accessibilityLabel,
15109 _this$props3$label = _this$props3.label,
15110 label = _this$props3$label === void 0 ? '' : _this$props3$label,
15111 onToggleAll = _this$props3.onToggleAll,
15112 selected = _this$props3.selected,
15113 smallScreen = _this$props3.smallScreen,
15114 disabled = _this$props3.disabled,
15115 promotedActions = _this$props3.promotedActions,
15116 _this$props3$paginate = _this$props3.paginatedSelectAllText,
15117 paginatedSelectAllText = _this$props3$paginate === void 0 ? null : _this$props3$paginate,
15118 paginatedSelectAllAction = _this$props3.paginatedSelectAllAction,
15119 intl = _this$props3.polaris.intl;
15120 var actionSections = this.actionSections();
15121
15122 if (promotedActions && promotedActions.length > MAX_PROMOTED_ACTIONS) {
15123 // eslint-disable-next-line no-console
15124 console.warn(intl.translate('Polaris.ResourceList.BulkActions.warningMessage', {
15125 maxPromotedActions: MAX_PROMOTED_ACTIONS
15126 }));
15127 }
15128
15129 var _this$state3 = this.state,
15130 smallScreenPopoverVisible = _this$state3.smallScreenPopoverVisible,
15131 largeScreenPopoverVisible = _this$state3.largeScreenPopoverVisible,
15132 measuring = _this$state3.measuring;
15133 var paginatedSelectAllActionMarkup = paginatedSelectAllAction ? React__default.createElement(Button, {
15134 onClick: paginatedSelectAllAction.onAction,
15135 plain: true,
15136 disabled: disabled
15137 }, paginatedSelectAllAction.content) : null;
15138 var paginatedSelectAllTextMarkup = paginatedSelectAllText && paginatedSelectAllAction ? React__default.createElement("span", {
15139 "aria-live": "polite"
15140 }, paginatedSelectAllText) : paginatedSelectAllText;
15141 var paginatedSelectAllMarkup = paginatedSelectAllActionMarkup || paginatedSelectAllTextMarkup ? React__default.createElement("div", {
15142 className: styles$1q.PaginatedSelectAll
15143 }, paginatedSelectAllTextMarkup, " ", paginatedSelectAllActionMarkup) : null;
15144 var cancelButton = React__default.createElement(Button, {
15145 onClick: this.setSelectMode.bind(this, false),
15146 disabled: disabled
15147 }, intl.translate('Polaris.Common.cancel'));
15148 var numberOfPromotedActionsToRender = this.numberOfPromotedActionsToRender();
15149 var allActionsPopover = this.hasActions() ? React__default.createElement("div", {
15150 className: styles$1q.Popover,
15151 ref: this.setMoreActionsNode
15152 }, React__default.createElement(Popover, {
15153 active: smallScreenPopoverVisible,
15154 activator: React__default.createElement(BulkActionButton, {
15155 disclosure: true,
15156 onAction: this.toggleSmallScreenPopover,
15157 content: intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel'),
15158 disabled: disabled
15159 }),
15160 onClose: this.toggleSmallScreenPopover
15161 }, React__default.createElement(ActionList, {
15162 items: promotedActions,
15163 sections: actionSections,
15164 onActionAnyItem: this.toggleSmallScreenPopover
15165 }))) : null;
15166 var promotedActionsMarkup = promotedActions && numberOfPromotedActionsToRender > 0 ? _toConsumableArray(promotedActions).slice(0, numberOfPromotedActionsToRender).map(function (action, index) {
15167 return React__default.createElement(BulkActionButton, Object.assign({
15168 disabled: disabled
15169 }, action, {
15170 key: index,
15171 handleMeasurement: _this2.handleMeasurement
15172 }));
15173 }) : null;
15174 var rolledInPromotedActions = promotedActions && numberOfPromotedActionsToRender < promotedActions.length ? _toConsumableArray(promotedActions).slice(numberOfPromotedActionsToRender) : [];
15175 var activatorLabel = !promotedActions || promotedActions && numberOfPromotedActionsToRender === 0 && !measuring ? intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel') : intl.translate('Polaris.ResourceList.BulkActions.moreActionsActivatorLabel');
15176 var combinedActions = [];
15177
15178 if (actionSections && rolledInPromotedActions.length > 0) {
15179 combinedActions = [{
15180 items: rolledInPromotedActions
15181 }].concat(_toConsumableArray(actionSections));
15182 } else if (actionSections) {
15183 combinedActions = actionSections;
15184 } else if (rolledInPromotedActions.length > 0) {
15185 combinedActions = [{
15186 items: rolledInPromotedActions
15187 }];
15188 }
15189
15190 var actionsPopover = actionSections || rolledInPromotedActions.length > 0 || measuring ? React__default.createElement("div", {
15191 className: styles$1q.Popover,
15192 ref: this.setMoreActionsNode
15193 }, React__default.createElement(Popover, {
15194 active: largeScreenPopoverVisible,
15195 activator: React__default.createElement(BulkActionButton, {
15196 disclosure: true,
15197 onAction: this.toggleLargeScreenPopover,
15198 content: activatorLabel,
15199 disabled: disabled
15200 }),
15201 onClose: this.toggleLargeScreenPopover
15202 }, React__default.createElement(ActionList, {
15203 sections: combinedActions,
15204 onActionAnyItem: this.toggleLargeScreenPopover
15205 }))) : null;
15206 var checkableButtonProps = {
15207 accessibilityLabel,
15208 label,
15209 selected,
15210 selectMode,
15211 onToggleAll,
15212 measuring,
15213 disabled
15214 };
15215 var smallScreenGroup = smallScreen ? React__default.createElement(Transition, {
15216 timeout: 0,
15217 in: selectMode,
15218 key: "smallGroup",
15219 findDOMNode: this.findSmallScreenGroupNode
15220 }, function (status) {
15221 var smallScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-smallScreen'], styles$1q["Group-".concat(status)]);
15222 return React__default.createElement("div", {
15223 className: smallScreenGroupClassName,
15224 ref: _this2.smallScreenGroupNode
15225 }, React__default.createElement("div", {
15226 className: styles$1q.ButtonGroupWrapper
15227 }, React__default.createElement(ButtonGroup, {
15228 segmented: true
15229 }, React__default.createElement(CSSTransition, {
15230 findDOMNode: _this2.findCheckableWrapperNode,
15231 in: selectMode,
15232 timeout: durationBase,
15233 classNames: slideClasses,
15234 appear: !selectMode
15235 }, React__default.createElement("div", {
15236 className: styles$1q.CheckableContainer,
15237 ref: _this2.checkableWrapperNode
15238 }, React__default.createElement(CheckableButton, Object.assign({}, checkableButtonProps, {
15239 smallScreen: true
15240 })))), allActionsPopover, cancelButton)), paginatedSelectAllMarkup);
15241 }) : null;
15242 var largeGroupContent = promotedActionsMarkup || actionsPopover ? React__default.createElement(ButtonGroup, {
15243 segmented: true
15244 }, React__default.createElement(CheckableButton, checkableButtonProps), promotedActionsMarkup, actionsPopover) : React__default.createElement(CheckableButton, checkableButtonProps);
15245 var largeScreenGroup = smallScreen ? null : React__default.createElement(Transition, {
15246 timeout: 0,
15247 in: selectMode,
15248 key: "largeGroup",
15249 findDOMNode: this.findLargeScreenGroupNode
15250 }, function (status) {
15251 var largeScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-largeScreen'], !measuring && styles$1q["Group-".concat(status)], measuring && styles$1q['Group-measuring']);
15252 return React__default.createElement("div", {
15253 className: largeScreenGroupClassName,
15254 ref: _this2.largeScreenGroupNode
15255 }, React__default.createElement(EventListener, {
15256 event: "resize",
15257 handler: _this2.handleResize
15258 }), React__default.createElement("div", {
15259 className: styles$1q.ButtonGroupWrapper,
15260 ref: _this2.setLargeScreenButtonsNode
15261 }, largeGroupContent), paginatedSelectAllMarkup);
15262 });
15263 return React__default.createElement("div", {
15264 ref: this.setContainerNode
15265 }, smallScreenGroup, largeScreenGroup);
15266 }
15267 }]);
15268
15269 return BulkActionsInner;
15270}(React__default.PureComponent);
15271
15272function instanceOfBulkActionListSectionArray(actions) {
15273 var validList = actions.filter(function (action) {
15274 return action.items;
15275 });
15276 return actions.length === validList.length;
15277}
15278
15279function instanceOfBulkActionArray(actions) {
15280 var validList = actions.filter(function (action) {
15281 return !action.items;
15282 });
15283 return actions.length === validList.length;
15284}
15285
15286var BulkActions = withAppProvider()(BulkActionsInner);
15287
15288var styles$1r = {
15289 "DateTextField": "Polaris-FilterControl-DateSelector__DateTextField",
15290 "DatePicker": "Polaris-FilterControl-DateSelector__DatePicker"
15291};
15292
15293var VALID_DATE_REGEX = /^\d{4}-\d{1,2}-\d{1,2}$/;
15294var DateFilterOption;
15295
15296(function (DateFilterOption) {
15297 DateFilterOption["PastWeek"] = "past_week";
15298 DateFilterOption["PastMonth"] = "past_month";
15299 DateFilterOption["PastQuarter"] = "past_quarter";
15300 DateFilterOption["PastYear"] = "past_year";
15301 DateFilterOption["ComingWeek"] = "coming_week";
15302 DateFilterOption["ComingMonth"] = "coming_month";
15303 DateFilterOption["ComingQuarter"] = "coming_quarter";
15304 DateFilterOption["ComingYear"] = "coming_year";
15305 DateFilterOption["OnOrBefore"] = "on_or_before";
15306 DateFilterOption["OnOrAfter"] = "on_or_after";
15307})(DateFilterOption || (DateFilterOption = {}));
15308
15309var DateSelector = memo(function DateSelector(_ref) {
15310 var filterValue = _ref.filterValue,
15311 filterKey = _ref.filterKey,
15312 filterMinKey = _ref.filterMinKey,
15313 filterMaxKey = _ref.filterMaxKey,
15314 dateOptionType = _ref.dateOptionType,
15315 onFilterValueChange = _ref.onFilterValueChange,
15316 onFilterKeyChange = _ref.onFilterKeyChange;
15317 var now = new Date();
15318 var i18n = useI18n();
15319 var initialConsumerFilterKey = useRef(filterKey);
15320
15321 var _useState = useState(now.getMonth()),
15322 _useState2 = _slicedToArray(_useState, 2),
15323 datePickerMonth = _useState2[0],
15324 setDatePickerMonth = _useState2[1];
15325
15326 var _useState3 = useState(now.getFullYear()),
15327 _useState4 = _slicedToArray(_useState3, 2),
15328 datePickerYear = _useState4[0],
15329 setDatePickerYear = _useState4[1];
15330
15331 var _useState5 = useState(),
15332 _useState6 = _slicedToArray(_useState5, 2),
15333 selectedDate = _useState6[0],
15334 setSelectedDate = _useState6[1];
15335
15336 var _useState7 = useState(),
15337 _useState8 = _slicedToArray(_useState7, 2),
15338 userInputDate = _useState8[0],
15339 setUserInputDate = _useState8[1];
15340
15341 var _useState9 = useState(),
15342 _useState10 = _slicedToArray(_useState9, 2),
15343 userInputDateError = _useState10[0],
15344 setUserInputDateError = _useState10[1];
15345
15346 var dateTextFieldValue = getDateTextFieldValue();
15347 var handleDateFieldChange = useCallback(function (value) {
15348 if (value.length === 0) {
15349 setSelectedDate(undefined);
15350 onFilterValueChange(undefined);
15351 }
15352
15353 if (userInputDateError && isValidDate(value)) {
15354 setUserInputDateError(undefined);
15355 }
15356
15357 setUserInputDate(value);
15358 }, [onFilterValueChange, userInputDateError]);
15359 var handleDateChanged = useCallback(function (date) {
15360 if (!date) {
15361 return;
15362 }
15363
15364 onFilterValueChange(stripTimeFromISOString(formatDateForLocalTimezone(date)));
15365 }, [onFilterValueChange]);
15366 var handleDateBlur = useCallback(function () {
15367 if (!dateTextFieldValue || !isValidDate(dateTextFieldValue)) {
15368 setSelectedDate(undefined);
15369 setUserInputDateError(i18n.translate('Polaris.ResourceList.DateSelector.dateValueError'));
15370 onFilterValueChange(undefined);
15371 return;
15372 }
15373
15374 if (!userInputDate) {
15375 return;
15376 }
15377
15378 var formattedDateForTimezone = new Date(formatDateForLocalTimezone(new Date(userInputDate)));
15379 setSelectedDate(formattedDateForTimezone);
15380 setDatePickerMonth(formattedDateForTimezone.getMonth());
15381 setDatePickerYear(formattedDateForTimezone.getFullYear());
15382 setUserInputDate(undefined);
15383 setUserInputDateError(undefined);
15384 handleDateChanged(formattedDateForTimezone);
15385 }, [dateTextFieldValue, handleDateChanged, i18n, onFilterValueChange, userInputDate]);
15386 var handleDateFilterOptionsChange = useCallback(function (newOption) {
15387 if (!initialConsumerFilterKey.current) {
15388 return;
15389 }
15390
15391 if (newOption === DateFilterOption.OnOrBefore) {
15392 onFilterKeyChange(filterMaxKey);
15393 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
15394 return;
15395 }
15396
15397 if (newOption === DateFilterOption.OnOrAfter) {
15398 onFilterKeyChange(filterMinKey);
15399 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
15400 return;
15401 }
15402
15403 onFilterKeyChange(initialConsumerFilterKey.current);
15404 onFilterValueChange(newOption);
15405 }, [filterMaxKey, filterMinKey, initialConsumerFilterKey, onFilterKeyChange, onFilterValueChange, selectedDate]);
15406 var handleDatePickerChange = useCallback(function (_ref2) {
15407 var nextDate = _ref2.end;
15408 var date = new Date(nextDate);
15409 setSelectedDate(date);
15410 setUserInputDate(undefined);
15411 setUserInputDateError(undefined);
15412 handleDateChanged(date);
15413 }, [handleDateChanged]);
15414 var handleDatePickerMonthChange = useCallback(function (month, year) {
15415 setDatePickerMonth(month);
15416 setDatePickerYear(year);
15417 }, []);
15418 var dateFilterOption = getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey);
15419 var showDatePredicate = dateFilterOption === DateFilterOption.OnOrBefore || dateFilterOption === DateFilterOption.OnOrAfter;
15420 var datePredicateMarkup = showDatePredicate && React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
15421 className: styles$1r.DateTextField
15422 }, React__default.createElement(TextField, {
15423 label: i18n.translate('Polaris.ResourceList.DateSelector.dateValueLabel'),
15424 placeholder: i18n.translate('Polaris.ResourceList.DateSelector.dateValuePlaceholder'),
15425 value: dateTextFieldValue,
15426 error: userInputDateError,
15427 prefix: React__default.createElement(Icon, {
15428 source: CalendarMinor,
15429 color: "skyDark"
15430 }),
15431 autoComplete: false,
15432 onChange: handleDateFieldChange,
15433 onBlur: handleDateBlur
15434 })), React__default.createElement("div", {
15435 className: styles$1r.DatePicker
15436 }, React__default.createElement(DatePicker, {
15437 selected: selectedDate,
15438 month: datePickerMonth,
15439 year: datePickerYear,
15440 onChange: handleDatePickerChange,
15441 onMonthChange: handleDatePickerMonthChange
15442 })));
15443 var dateOptionTypes = {
15444 past: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateComparatorOptions())),
15445 future: [].concat(_toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions())),
15446 full: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions()))
15447 };
15448 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Select, {
15449 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.dateFilterLabel'),
15450 labelHidden: true,
15451 options: dateOptionType ? dateOptionTypes[dateOptionType] : dateOptionTypes.full,
15452 placeholder: i18n.translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
15453 value: dateFilterOption,
15454 onChange: handleDateFilterOptionsChange
15455 }), datePredicateMarkup);
15456
15457 function getDateComparatorOptions() {
15458 return [{
15459 value: DateFilterOption.OnOrBefore,
15460 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrBefore')
15461 }, {
15462 value: DateFilterOption.OnOrAfter,
15463 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrAfter')
15464 }];
15465 }
15466
15467 function getDatePastOptions() {
15468 return [{
15469 value: DateFilterOption.PastWeek,
15470 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastWeek')
15471 }, {
15472 value: DateFilterOption.PastMonth,
15473 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastMonth')
15474 }, {
15475 value: DateFilterOption.PastQuarter,
15476 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastQuarter')
15477 }, {
15478 value: DateFilterOption.PastYear,
15479 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastYear')
15480 }];
15481 }
15482
15483 function getDateFutureOptions() {
15484 return [{
15485 value: DateFilterOption.ComingWeek,
15486 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingWeek')
15487 }, {
15488 value: DateFilterOption.ComingMonth,
15489 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingMonth')
15490 }, {
15491 value: DateFilterOption.ComingQuarter,
15492 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingQuarter')
15493 }, {
15494 value: DateFilterOption.ComingYear,
15495 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingYear')
15496 }];
15497 }
15498
15499 function getDateTextFieldValue() {
15500 if (!userInputDate && !selectedDate) {
15501 return undefined;
15502 }
15503
15504 if (userInputDate !== undefined) {
15505 return userInputDate;
15506 }
15507
15508 if (selectedDate) {
15509 return stripTimeFromISOString(formatDateForLocalTimezone(selectedDate));
15510 }
15511 }
15512});
15513
15514function isValidDate(date) {
15515 if (!date) {
15516 return false;
15517 }
15518
15519 return VALID_DATE_REGEX.test(date) && !isNaN(new Date(date).getTime());
15520}
15521
15522function getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey) {
15523 if (filterKey === filterMaxKey) {
15524 return DateFilterOption.OnOrBefore;
15525 }
15526
15527 if (filterKey === filterMinKey) {
15528 return DateFilterOption.OnOrAfter;
15529 }
15530
15531 return filterValue;
15532}
15533
15534function stripTimeFromISOString(ISOString) {
15535 return ISOString.slice(0, 10);
15536}
15537
15538function formatDateForLocalTimezone(date) {
15539 var timezoneOffset = date.getTimezoneOffset();
15540 var timezoneOffsetMs = timezoneOffset * 60 * 1000;
15541 var isFringeTimezone = timezoneOffset === -720 || timezoneOffset === 720;
15542 var formattedDate = new Date();
15543
15544 if (isFringeTimezone && date.getHours() !== 0) {
15545 return date.toISOString();
15546 }
15547
15548 var newTime = timezoneOffset > -1 ? date.getTime() + timezoneOffsetMs : date.getTime() - timezoneOffsetMs;
15549 formattedDate.setTime(newTime);
15550 return formattedDate.toISOString();
15551}
15552
15553var FilterType;
15554
15555(function (FilterType) {
15556 FilterType[FilterType["Select"] = 0] = "Select";
15557 FilterType[FilterType["TextField"] = 1] = "TextField";
15558 FilterType[FilterType["DateSelector"] = 2] = "DateSelector";
15559})(FilterType || (FilterType = {}));
15560
15561/**
15562 * Returns a MutatableRefObject containing a boolean value that
15563 * represents a components mounted status.
15564 * @returns MutableRefObject<boolean> The mounted status
15565 */
15566
15567function useIsMountedRef() {
15568 var isMounted = useRef(false);
15569 useEffect(function () {
15570 isMounted.current = true;
15571 return function () {
15572 isMounted.current = false;
15573 };
15574 }, []);
15575 return isMounted;
15576}
15577
15578function FilterValueSelector(_ref) {
15579 var filter = _ref.filter,
15580 filterKey = _ref.filterKey,
15581 value = _ref.value,
15582 onChange = _ref.onChange,
15583 onFilterKeyChange = _ref.onFilterKeyChange;
15584 var i18n = useI18n();
15585 var isMounted = useIsMountedRef();
15586 var operatorText = filter.operatorText,
15587 type = filter.type,
15588 label = filter.label;
15589 var showOperatorOptions = type !== FilterType.DateSelector && operatorText && typeof operatorText !== 'string';
15590 var handleOperatorOptionChange = useCallback(function (operatorKey) {
15591 onFilterKeyChange(operatorKey);
15592
15593 if (!value) {
15594 return;
15595 }
15596
15597 onChange(value);
15598 }, [onChange, onFilterKeyChange, value]);
15599
15600 if (showOperatorOptions && operatorText.length !== 0 && !isMounted.current) {
15601 handleOperatorOptionChange(operatorText[0].key);
15602 }
15603
15604 var operatorOptionsMarkup = showOperatorOptions ? React__default.createElement(Select, {
15605 label: label,
15606 labelHidden: true,
15607 options: buildOperatorOptions(operatorText),
15608 value: filterKey,
15609 onChange: handleOperatorOptionChange
15610 }) : null;
15611 var selectedFilterLabel = typeof operatorText === 'string' ? operatorText : '';
15612
15613 switch (filter.type) {
15614 case FilterType.Select:
15615 return React__default.createElement(Stack, {
15616 vertical: true
15617 }, operatorOptionsMarkup, React__default.createElement(Select, {
15618 label: selectedFilterLabel,
15619 options: filter.options,
15620 placeholder: i18n.translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
15621 value: value,
15622 onChange: onChange
15623 }));
15624
15625 case FilterType.TextField:
15626 return React__default.createElement(Stack, {
15627 vertical: true
15628 }, operatorOptionsMarkup, React__default.createElement(TextField, {
15629 label: selectedFilterLabel,
15630 value: value,
15631 type: filter.textFieldType,
15632 onChange: onChange
15633 }));
15634
15635 case FilterType.DateSelector:
15636 return React__default.createElement(DateSelector, {
15637 dateOptionType: filter.dateOptionType,
15638 filterValue: value,
15639 filterKey: filterKey,
15640 filterMinKey: filter.minKey,
15641 filterMaxKey: filter.maxKey,
15642 onFilterValueChange: onChange,
15643 onFilterKeyChange: onFilterKeyChange
15644 });
15645
15646 default:
15647 return null;
15648 }
15649}
15650
15651function buildOperatorOptions(operatorText) {
15652 if (!operatorText || typeof operatorText === 'string') {
15653 return [];
15654 }
15655
15656 return operatorText.map(function (_ref2) {
15657 var key = _ref2.key,
15658 optionLabel = _ref2.optionLabel;
15659 return {
15660 value: key,
15661 label: optionLabel
15662 };
15663 });
15664}
15665
15666function FilterCreator(_ref) {
15667 var filters = _ref.filters,
15668 resourceName = _ref.resourceName,
15669 disabled = _ref.disabled,
15670 onAddFilter = _ref.onAddFilter;
15671
15672 var _useToggle = useToggle(false),
15673 popoverActive = _useToggle.value,
15674 togglePopoverActive = _useToggle.toggle,
15675 setPopoverActiveFalse = _useToggle.setFalse;
15676
15677 var _useState = useState(),
15678 _useState2 = _slicedToArray(_useState, 2),
15679 selectedFilter = _useState2[0],
15680 setSelectedFilter = _useState2[1];
15681
15682 var _useState3 = useState(),
15683 _useState4 = _slicedToArray(_useState3, 2),
15684 selectedFilterKey = _useState4[0],
15685 setSelectedFilterKey = _useState4[1];
15686
15687 var _useState5 = useState(),
15688 _useState6 = _slicedToArray(_useState5, 2),
15689 selectedFilterValue = _useState6[0],
15690 setSelectedFilterValue = _useState6[1];
15691
15692 var i18n = useI18n();
15693 var node = useRef(null);
15694 var canAddFilter = Boolean(selectedFilter && selectedFilterKey && selectedFilterValue);
15695 var handleButtonFocus = useCallback(function () {
15696 var event = arguments.length <= 0 ? undefined : arguments[0];
15697
15698 if (!node.current && event) {
15699 // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065
15700 node.current = event.target;
15701 }
15702 }, []);
15703 var handleFilterKeyChange = useCallback(function (filterKey) {
15704 var foundFilter = filters.find(function (filter) {
15705 var minKey = filter.minKey,
15706 maxKey = filter.maxKey,
15707 operatorText = filter.operatorText;
15708
15709 if (minKey || maxKey) {
15710 return filter.key === filterKey || minKey === filterKey || maxKey === filterKey;
15711 }
15712
15713 if (operatorText && typeof operatorText !== 'string') {
15714 return filter.key === filterKey || operatorText.filter(function (_ref2) {
15715 var key = _ref2.key;
15716 return key === filterKey;
15717 }).length === 1;
15718 }
15719
15720 return filter.key === filterKey;
15721 });
15722
15723 if (!foundFilter) {
15724 return;
15725 }
15726
15727 setSelectedFilter(foundFilter);
15728 setSelectedFilterKey(filterKey);
15729 setSelectedFilterValue(undefined);
15730 }, [filters]);
15731 var handleFilterValueChange = useCallback(function (value) {
15732 setSelectedFilterValue(value);
15733 }, []);
15734 var handleAddFilter = useCallback(function () {
15735 if (!onAddFilter || !canAddFilter || !selectedFilterKey) {
15736 return;
15737 }
15738
15739 onAddFilter({
15740 key: selectedFilterKey,
15741 value: selectedFilterValue || ''
15742 });
15743 setPopoverActiveFalse();
15744 setSelectedFilter(undefined);
15745 setSelectedFilterValue(undefined);
15746
15747 if (node.current != null) {
15748 node.current.focus();
15749 }
15750 }, [canAddFilter, onAddFilter, selectedFilterKey, selectedFilterValue, setPopoverActiveFalse]);
15751 var activator = React__default.createElement(Button, {
15752 onClick: togglePopoverActive,
15753 disclosure: true,
15754 disabled: disabled,
15755 onFocus: handleButtonFocus
15756 }, i18n.translate('Polaris.ResourceList.FilterCreator.filterButtonLabel'));
15757 var filterOptions = filters.map(function (_ref3) {
15758 var key = _ref3.key,
15759 label = _ref3.label;
15760 return {
15761 value: key,
15762 label
15763 };
15764 });
15765 var filterValueSelectionMarkup = selectedFilter ? React__default.createElement(FilterValueSelector, {
15766 filter: selectedFilter,
15767 filterKey: selectedFilterKey,
15768 value: selectedFilterValue,
15769 onFilterKeyChange: handleFilterKeyChange,
15770 onChange: handleFilterValueChange
15771 }) : null;
15772 var addFilterButtonMarkup = selectedFilter ? React__default.createElement(Button, {
15773 onClick: handleAddFilter,
15774 disabled: !canAddFilter
15775 }, i18n.translate('Polaris.ResourceList.FilterCreator.addFilterButtonLabel')) : null;
15776 return React__default.createElement(Popover, {
15777 active: popoverActive,
15778 activator: activator,
15779 onClose: togglePopoverActive,
15780 sectioned: true,
15781 fullHeight: true
15782 }, React__default.createElement(Form, {
15783 onSubmit: handleAddFilter
15784 }, React__default.createElement(FormLayout, null, React__default.createElement(Select, {
15785 label: i18n.translate('Polaris.ResourceList.FilterCreator.showAllWhere', {
15786 resourceNamePlural: resourceName.plural.toLocaleLowerCase()
15787 }),
15788 placeholder: i18n.translate('Polaris.ResourceList.FilterCreator.selectFilterKeyPlaceholder'),
15789 options: filterOptions,
15790 onChange: handleFilterKeyChange,
15791 value: selectedFilter && selectedFilter.key
15792 }), filterValueSelectionMarkup, addFilterButtonMarkup)));
15793}
15794
15795var styles$1s = {
15796 "AppliedFilters": "Polaris-ResourceList-FilterControl__AppliedFilters",
15797 "AppliedFilter": "Polaris-ResourceList-FilterControl__AppliedFilter"
15798};
15799
15800/** @deprecated Use <Filters /> instead. */
15801
15802function FilterControl(_ref) {
15803 var searchValue = _ref.searchValue,
15804 _ref$appliedFilters = _ref.appliedFilters,
15805 appliedFilters = _ref$appliedFilters === void 0 ? [] : _ref$appliedFilters,
15806 additionalAction = _ref.additionalAction,
15807 _ref$focused = _ref.focused,
15808 focused = _ref$focused === void 0 ? false : _ref$focused,
15809 _ref$filters = _ref.filters,
15810 filters = _ref$filters === void 0 ? [] : _ref$filters,
15811 placeholder = _ref.placeholder,
15812 onSearchBlur = _ref.onSearchBlur,
15813 onSearchChange = _ref.onSearchChange,
15814 onFiltersChange = _ref.onFiltersChange;
15815 // eslint-disable-next-line no-console
15816 console.warn('Deprecation: <FilterControl /> is deprecated. Use <Filters /> instead.');
15817 var i18n = useI18n();
15818
15819 var _React$useContext = React__default.useContext(ResourceListContext),
15820 selectMode = _React$useContext.selectMode,
15821 resourceName = _React$useContext.resourceName;
15822
15823 var filterResourceName = resourceName || {
15824 singular: i18n.translate('Polaris.ResourceList.defaultItemSingular'),
15825 plural: i18n.translate('Polaris.ResourceList.defaultItemPlural')
15826 };
15827 var handleAddFilter = React__default.useCallback(function (newFilter) {
15828 if (!onFiltersChange) {
15829 return;
15830 }
15831
15832 var foundFilter = appliedFilters.find(function (appliedFilter) {
15833 return idFromFilter(appliedFilter) === idFromFilter(newFilter);
15834 });
15835
15836 if (foundFilter) {
15837 return;
15838 }
15839
15840 var newAppliedFilters = [].concat(_toConsumableArray(appliedFilters), [newFilter]);
15841 onFiltersChange(newAppliedFilters);
15842 }, [onFiltersChange, appliedFilters]);
15843 var handleRemoveFilter = React__default.useCallback(function (filterId) {
15844 if (!onFiltersChange) {
15845 return;
15846 }
15847
15848 var foundIndex = appliedFilters.findIndex(function (appliedFilter) {
15849 return idFromFilter(appliedFilter) === filterId;
15850 });
15851 var newAppliedFilters = foundIndex >= 0 ? [].concat(_toConsumableArray(appliedFilters.slice(0, foundIndex)), _toConsumableArray(appliedFilters.slice(foundIndex + 1, appliedFilters.length))) : _toConsumableArray(appliedFilters);
15852 onFiltersChange(newAppliedFilters);
15853 }, [appliedFilters, onFiltersChange]);
15854 var getRemoveFilterCallback = React__default.useCallback(function (filterId) {
15855 return function () {
15856 handleRemoveFilter(filterId);
15857 };
15858 }, [handleRemoveFilter]);
15859 var textFieldLabel = placeholder ? placeholder : i18n.translate('Polaris.ResourceList.FilterControl.textFieldLabel', {
15860 resourceNamePlural: filterResourceName.plural.toLocaleLowerCase()
15861 });
15862
15863 if (additionalAction) {
15864 additionalAction.disabled = selectMode;
15865 }
15866
15867 var additionalActionButton = additionalAction && buttonsFrom(additionalAction) || null;
15868 var filterCreatorMarkup = filters.length > 0 ? React__default.createElement(FilterCreator, {
15869 resourceName: filterResourceName,
15870 filters: filters,
15871 onAddFilter: handleAddFilter,
15872 disabled: selectMode
15873 }) : null;
15874 var appliedFiltersMarkup = appliedFilters.map(function (appliedFilter) {
15875 var activeFilterLabel = getFilterLabel(appliedFilter);
15876 var filterId = idFromFilter(appliedFilter);
15877 return React__default.createElement("li", {
15878 className: styles$1s.AppliedFilter,
15879 key: filterId
15880 }, React__default.createElement(Tag, {
15881 onRemove: getRemoveFilterCallback(filterId),
15882 disabled: selectMode
15883 }, activeFilterLabel));
15884 });
15885 var appliedFiltersWrapper = appliedFilters.length > 0 ? React__default.createElement("ul", {
15886 className: styles$1s.AppliedFilters
15887 }, appliedFiltersMarkup) : null;
15888 return React__default.createElement(FormLayout, null, React__default.createElement(TextField, {
15889 connectedLeft: filterCreatorMarkup,
15890 connectedRight: additionalActionButton,
15891 label: textFieldLabel,
15892 labelHidden: true,
15893 placeholder: textFieldLabel,
15894 prefix: React__default.createElement(Icon, {
15895 source: SearchMinor,
15896 color: "skyDark"
15897 }),
15898 value: searchValue,
15899 onChange: onSearchChange,
15900 onBlur: onSearchBlur,
15901 focused: focused,
15902 disabled: selectMode
15903 }), appliedFiltersWrapper);
15904
15905 function getFilterLabel(appliedFilter) {
15906 var key = appliedFilter.key,
15907 value = appliedFilter.value,
15908 label = appliedFilter.label;
15909
15910 if (label) {
15911 return label;
15912 }
15913
15914 var filter = filters.find(function (filter) {
15915 var minKey = filter.minKey,
15916 maxKey = filter.maxKey,
15917 operatorText = filter.operatorText;
15918
15919 if (minKey || maxKey) {
15920 return filter.key === key || minKey === key || maxKey === key;
15921 }
15922
15923 if (operatorText && typeof operatorText !== 'string') {
15924 return filter.key === key || operatorText.filter(function (_ref2) {
15925 var operatorKey = _ref2.key;
15926 return operatorKey === key;
15927 }).length === 1;
15928 }
15929
15930 return filter.key === key;
15931 });
15932
15933 if (!filter) {
15934 return value;
15935 }
15936
15937 var filterOperatorLabel = findOperatorLabel(filter, appliedFilter);
15938 var filterLabelByType = findFilterLabelByType(filter, appliedFilter);
15939
15940 if (!filterOperatorLabel) {
15941 return "".concat(filter.label, " ").concat(filterLabelByType);
15942 }
15943
15944 return "".concat(filter.label, " ").concat(filterOperatorLabel, " ").concat(filterLabelByType);
15945 }
15946
15947 function findFilterLabelByType(filter, appliedFilter) {
15948 var appliedFilterValue = appliedFilter.value;
15949
15950 if (filter.type === FilterType.Select) {
15951 var foundFilterOption = filter.options.find(function (option) {
15952 return typeof option === 'string' ? option === appliedFilterValue : option.value === appliedFilterValue;
15953 });
15954
15955 if (foundFilterOption) {
15956 return typeof foundFilterOption === 'string' ? foundFilterOption : foundFilterOption.label;
15957 }
15958 }
15959
15960 if (filter.type === FilterType.DateSelector) {
15961 if (filter.key === appliedFilter.key) {
15962 var filterLabelKey = "Polaris.ResourceList.DateSelector.FilterLabelForValue.".concat(appliedFilter.value);
15963 return i18n.translationKeyExists(filterLabelKey) ? i18n.translate(filterLabelKey) : appliedFilter.value;
15964 }
15965
15966 if (appliedFilter.key === filter.maxKey) {
15967 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_before', {
15968 date: formatDateForLabelDisplay(appliedFilter.value)
15969 });
15970 }
15971
15972 if (appliedFilter.key === filter.minKey) {
15973 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_after', {
15974 date: formatDateForLabelDisplay(appliedFilter.value)
15975 });
15976 }
15977 }
15978
15979 return appliedFilterValue;
15980 }
15981}
15982
15983function idFromFilter(appliedFilter) {
15984 return "".concat(appliedFilter.key, "-").concat(appliedFilter.value);
15985}
15986
15987function formatDateForLabelDisplay(date) {
15988 if (isNaN(new Date(date).getTime())) {
15989 return date;
15990 }
15991
15992 return new Date(date.replace(/-/g, '/')).toLocaleDateString();
15993}
15994
15995function findOperatorLabel(filter, appliedFilter) {
15996 var operatorText = filter.operatorText;
15997
15998 if (filter.type === FilterType.DateSelector && (appliedFilter.key === filter.minKey || appliedFilter.key === filter.maxKey)) {
15999 return '';
16000 }
16001
16002 if (!operatorText || typeof operatorText === 'string') {
16003 return operatorText;
16004 }
16005
16006 var appliedOperator = operatorText.find(function (operator) {
16007 return operator.key === appliedFilter.key;
16008 });
16009
16010 if (appliedOperator) {
16011 return appliedOperator.filterLabel || appliedOperator.optionLabel;
16012 }
16013}
16014
16015var styles$1t = {
16016 "FiltersWrapper": "Polaris-ResourceList__FiltersWrapper",
16017 "ResourceList": "Polaris-ResourceList",
16018 "HeaderOuterWrapper": "Polaris-ResourceList__HeaderOuterWrapper",
16019 "HeaderWrapper-disabled": "Polaris-ResourceList__HeaderWrapper--disabled",
16020 "HeaderWrapper-overlay": "Polaris-ResourceList__HeaderWrapper--overlay",
16021 "HeaderWrapper": "Polaris-ResourceList__HeaderWrapper",
16022 "HeaderWrapper-isSticky": "Polaris-ResourceList__HeaderWrapper--isSticky",
16023 "HeaderContentWrapper": "Polaris-ResourceList__HeaderContentWrapper",
16024 "HeaderWrapper-inSelectMode": "Polaris-ResourceList__HeaderWrapper--inSelectMode",
16025 "SortWrapper": "Polaris-ResourceList__SortWrapper",
16026 "AlternateToolWrapper": "Polaris-ResourceList__AlternateToolWrapper",
16027 "HeaderWrapper-hasSelect": "Polaris-ResourceList__HeaderWrapper--hasSelect",
16028 "HeaderWrapper-hasAlternateTool": "Polaris-ResourceList__HeaderWrapper--hasAlternateTool",
16029 "HeaderWrapper-hasSort": "Polaris-ResourceList__HeaderWrapper--hasSort",
16030 "HeaderTitleWrapper": "Polaris-ResourceList__HeaderTitleWrapper",
16031 "BulkActionsWrapper": "Polaris-ResourceList__BulkActionsWrapper",
16032 "CheckableButtonWrapper": "Polaris-ResourceList__CheckableButtonWrapper",
16033 "SelectButtonWrapper": "Polaris-ResourceList__SelectButtonWrapper",
16034 "EmptySearchResultWrapper": "Polaris-ResourceList__EmptySearchResultWrapper",
16035 "ResourceListWrapper": "Polaris-ResourceList__ResourceListWrapper",
16036 "ItemWrapper": "Polaris-ResourceList__ItemWrapper",
16037 "ItemWrapper-isLoading": "Polaris-ResourceList__ItemWrapper--isLoading",
16038 "SpinnerContainer": "Polaris-ResourceList__SpinnerContainer",
16039 "LoadingOverlay": "Polaris-ResourceList__LoadingOverlay",
16040 "DisabledPointerEvents": "Polaris-ResourceList__DisabledPointerEvents",
16041 "disableTextSelection": "Polaris-ResourceList--disableTextSelection"
16042};
16043
16044var SMALL_SCREEN_WIDTH = 458;
16045var SMALL_SPINNER_HEIGHT = 28;
16046var LARGE_SPINNER_HEIGHT = 45;
16047
16048var ResourceListInner =
16049/*#__PURE__*/
16050function (_React$Component) {
16051 _inherits(ResourceListInner, _React$Component);
16052
16053 function ResourceListInner(props) {
16054 var _this;
16055
16056 _classCallCheck(this, ResourceListInner);
16057
16058 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourceListInner).call(this, props));
16059 _this.listRef = React__default.createRef();
16060 _this.handleResize = debounce(function () {
16061 var selectedItems = _this.props.selectedItems;
16062 var _this$state = _this.state,
16063 selectMode = _this$state.selectMode,
16064 smallScreen = _this$state.smallScreen;
16065 var newSmallScreen = isSmallScreen();
16066
16067 if (selectedItems && selectedItems.length === 0 && selectMode && !newSmallScreen) {
16068 _this.handleSelectMode(false);
16069 }
16070
16071 if (smallScreen !== newSmallScreen) {
16072 _this.setState({
16073 smallScreen: newSmallScreen
16074 });
16075 }
16076 }, 50, {
16077 leading: true,
16078 trailing: true,
16079 maxWait: 50
16080 });
16081
16082 _this.setLoadingPosition = function () {
16083 if (_this.listRef.current != null) {
16084 if (typeof window === 'undefined') {
16085 return;
16086 }
16087
16088 var overlay = _this.listRef.current.getBoundingClientRect();
16089
16090 var viewportHeight = Math.max(document.documentElement ? document.documentElement.clientHeight : 0, window.innerHeight || 0);
16091 var overflow = viewportHeight - overlay.height;
16092 var spinnerHeight = _this.props.items.length === 1 ? SMALL_SPINNER_HEIGHT : LARGE_SPINNER_HEIGHT;
16093 var spinnerPosition = overflow > 0 ? (overlay.height - spinnerHeight) / 2 : (viewportHeight - overlay.top - spinnerHeight) / 2;
16094
16095 _this.setState({
16096 loadingPosition: spinnerPosition
16097 });
16098 }
16099 };
16100
16101 _this.handleSelectAllItemsInStore = function () {
16102 var _this$props = _this.props,
16103 onSelectionChange = _this$props.onSelectionChange,
16104 selectedItems = _this$props.selectedItems,
16105 items = _this$props.items,
16106 _this$props$idForItem = _this$props.idForItem,
16107 idForItem = _this$props$idForItem === void 0 ? defaultIdForItem : _this$props$idForItem;
16108 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : SELECT_ALL_ITEMS;
16109
16110 if (onSelectionChange) {
16111 onSelectionChange(newlySelectedItems);
16112 }
16113 };
16114
16115 _this.renderItem = function (item, index) {
16116 var _this$props2 = _this.props,
16117 renderItem = _this$props2.renderItem,
16118 _this$props2$idForIte = _this$props2.idForItem,
16119 idForItem = _this$props2$idForIte === void 0 ? defaultIdForItem : _this$props2$idForIte;
16120 var id = idForItem(item, index);
16121 return React__default.createElement("li", {
16122 key: id,
16123 className: styles$1t.ItemWrapper
16124 }, renderItem(item, id, index));
16125 };
16126
16127 _this.handleMultiSelectionChange = function (lastSelected, currentSelected, resolveItemId) {
16128 var min = Math.min(lastSelected, currentSelected);
16129 var max = Math.max(lastSelected, currentSelected);
16130 return _this.props.items.slice(min, max + 1).map(resolveItemId);
16131 };
16132
16133 _this.handleCheckableButtonRegistration = function (key, button) {
16134 _this.setState(function (_ref) {
16135 var checkableButtons = _ref.checkableButtons;
16136 return {
16137 checkableButtons: new Map(checkableButtons).set(key, button)
16138 };
16139 });
16140 };
16141
16142 _this.handleSelectionChange = function (selected, id, sortOrder, shiftKey) {
16143 var _this$props3 = _this.props,
16144 onSelectionChange = _this$props3.onSelectionChange,
16145 selectedItems = _this$props3.selectedItems,
16146 items = _this$props3.items,
16147 _this$props3$idForIte = _this$props3.idForItem,
16148 idForItem = _this$props3$idForIte === void 0 ? defaultIdForItem : _this$props3$idForIte,
16149 resolveItemId = _this$props3.resolveItemId;
16150 var lastSelected = _this.state.lastSelected;
16151
16152 if (selectedItems == null || onSelectionChange == null) {
16153 return;
16154 }
16155
16156 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : _toConsumableArray(selectedItems);
16157
16158 if (sortOrder !== undefined) {
16159 _this.setState({
16160 lastSelected: sortOrder
16161 });
16162 }
16163
16164 var selectedIds = [id];
16165
16166 if (shiftKey && lastSelected != null && sortOrder !== undefined && resolveItemId) {
16167 selectedIds = _this.handleMultiSelectionChange(lastSelected, sortOrder, resolveItemId);
16168 }
16169
16170 newlySelectedItems = _toConsumableArray(new Set([].concat(_toConsumableArray(newlySelectedItems), _toConsumableArray(selectedIds))));
16171
16172 if (!selected) {
16173 var _iteratorNormalCompletion = true;
16174 var _didIteratorError = false;
16175 var _iteratorError = undefined;
16176
16177 try {
16178 for (var _iterator = selectedIds[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
16179 var selectedId = _step.value;
16180 newlySelectedItems.splice(newlySelectedItems.indexOf(selectedId), 1);
16181 }
16182 } catch (err) {
16183 _didIteratorError = true;
16184 _iteratorError = err;
16185 } finally {
16186 try {
16187 if (!_iteratorNormalCompletion && _iterator.return != null) {
16188 _iterator.return();
16189 }
16190 } finally {
16191 if (_didIteratorError) {
16192 throw _iteratorError;
16193 }
16194 }
16195 }
16196 }
16197
16198 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
16199 _this.handleSelectMode(false);
16200 } else if (newlySelectedItems.length > 0) {
16201 _this.handleSelectMode(true);
16202 }
16203
16204 if (onSelectionChange) {
16205 onSelectionChange(newlySelectedItems);
16206 }
16207 };
16208
16209 _this.handleSelectMode = function (selectMode) {
16210 var onSelectionChange = _this.props.onSelectionChange;
16211
16212 _this.setState({
16213 selectMode
16214 });
16215
16216 if (!selectMode && onSelectionChange) {
16217 onSelectionChange([]);
16218 }
16219 };
16220
16221 _this.handleToggleAll = function () {
16222 var _this$props4 = _this.props,
16223 onSelectionChange = _this$props4.onSelectionChange,
16224 selectedItems = _this$props4.selectedItems,
16225 items = _this$props4.items,
16226 _this$props4$idForIte = _this$props4.idForItem,
16227 idForItem = _this$props4$idForIte === void 0 ? defaultIdForItem : _this$props4$idForIte;
16228 var checkableButtons = _this.state.checkableButtons;
16229 var newlySelectedItems = [];
16230
16231 if (Array.isArray(selectedItems) && selectedItems.length === items.length || selectedItems === SELECT_ALL_ITEMS) {
16232 newlySelectedItems = [];
16233 } else {
16234 newlySelectedItems = items.map(function (item, index) {
16235 var id = idForItem(item, index);
16236 return id;
16237 });
16238 }
16239
16240 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
16241 _this.handleSelectMode(false);
16242 } else if (newlySelectedItems.length > 0) {
16243 _this.handleSelectMode(true);
16244 }
16245
16246 var checkbox;
16247
16248 if (isSmallScreen()) {
16249 checkbox = checkableButtons.get('bulkSm');
16250 } else if (newlySelectedItems.length === 0) {
16251 checkbox = checkableButtons.get('plain');
16252 } else {
16253 checkbox = checkableButtons.get('bulkLg');
16254 }
16255
16256 if (onSelectionChange) {
16257 onSelectionChange(newlySelectedItems);
16258 } // setTimeout ensures execution after the Transition on BulkActions
16259
16260
16261 setTimeout(function () {
16262 checkbox && checkbox.focus();
16263 }, 0);
16264 };
16265
16266 var selectedItems = props.selectedItems,
16267 intl = props.polaris.intl;
16268 _this.defaultResourceName = {
16269 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
16270 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
16271 }; // eslint-disable-next-line react/state-in-constructor
16272
16273 _this.state = {
16274 selectMode: Boolean(selectedItems && selectedItems.length > 0),
16275 loadingPosition: 0,
16276 lastSelected: null,
16277 smallScreen: isSmallScreen(),
16278 checkableButtons: new Map()
16279 };
16280 return _this;
16281 }
16282
16283 _createClass(ResourceListInner, [{
16284 key: "selectable",
16285 value: function selectable() {
16286 var _this$props5 = this.props,
16287 promotedBulkActions = _this$props5.promotedBulkActions,
16288 bulkActions = _this$props5.bulkActions,
16289 selectable = _this$props5.selectable;
16290 return Boolean(promotedBulkActions && promotedBulkActions.length > 0 || bulkActions && bulkActions.length > 0 || selectable);
16291 }
16292 }, {
16293 key: "bulkSelectState",
16294 value: function bulkSelectState() {
16295 var _this$props6 = this.props,
16296 selectedItems = _this$props6.selectedItems,
16297 items = _this$props6.items;
16298 var selectState = 'indeterminate';
16299
16300 if (!selectedItems || Array.isArray(selectedItems) && selectedItems.length === 0) {
16301 selectState = false;
16302 } else if (selectedItems === SELECT_ALL_ITEMS || Array.isArray(selectedItems) && selectedItems.length === items.length) {
16303 selectState = true;
16304 }
16305
16306 return selectState;
16307 }
16308 }, {
16309 key: "headerTitle",
16310 value: function headerTitle() {
16311 var _this$props7 = this.props,
16312 _this$props7$resource = _this$props7.resourceName,
16313 resourceName = _this$props7$resource === void 0 ? this.defaultResourceName : _this$props7$resource,
16314 items = _this$props7.items,
16315 intl = _this$props7.polaris.intl,
16316 loading = _this$props7.loading,
16317 totalItemsCount = _this$props7.totalItemsCount;
16318 var itemsCount = items.length;
16319 var resource = !loading && (!totalItemsCount && itemsCount === 1 || totalItemsCount === 1) ? resourceName.singular : resourceName.plural;
16320
16321 if (loading) {
16322 return intl.translate('Polaris.ResourceList.loading', {
16323 resource
16324 });
16325 } else if (totalItemsCount) {
16326 return intl.translate('Polaris.ResourceList.showingTotalCount', {
16327 itemsCount,
16328 totalItemsCount,
16329 resource
16330 });
16331 } else {
16332 return intl.translate('Polaris.ResourceList.showing', {
16333 itemsCount,
16334 resource
16335 });
16336 }
16337 }
16338 }, {
16339 key: "bulkActionsLabel",
16340 value: function bulkActionsLabel() {
16341 var _this$props8 = this.props,
16342 _this$props8$selected = _this$props8.selectedItems,
16343 selectedItems = _this$props8$selected === void 0 ? [] : _this$props8$selected,
16344 items = _this$props8.items,
16345 intl = _this$props8.polaris.intl;
16346 var selectedItemsCount = selectedItems === SELECT_ALL_ITEMS ? "".concat(items.length, "+") : selectedItems.length;
16347 return intl.translate('Polaris.ResourceList.selected', {
16348 selectedItemsCount
16349 });
16350 }
16351 }, {
16352 key: "bulkActionsAccessibilityLabel",
16353 value: function bulkActionsAccessibilityLabel() {
16354 var _this$props9 = this.props,
16355 _this$props9$resource = _this$props9.resourceName,
16356 resourceName = _this$props9$resource === void 0 ? this.defaultResourceName : _this$props9$resource,
16357 _this$props9$selected = _this$props9.selectedItems,
16358 selectedItems = _this$props9$selected === void 0 ? [] : _this$props9$selected,
16359 items = _this$props9.items,
16360 intl = _this$props9.polaris.intl;
16361 var selectedItemsCount = selectedItems.length;
16362 var totalItemsCount = items.length;
16363 var allSelected = selectedItemsCount === totalItemsCount;
16364
16365 if (totalItemsCount === 1 && allSelected) {
16366 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllSingle', {
16367 resourceNameSingular: resourceName.singular
16368 });
16369 } else if (totalItemsCount === 1) {
16370 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllSingle', {
16371 resourceNameSingular: resourceName.singular
16372 });
16373 } else if (allSelected) {
16374 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllMultiple', {
16375 itemsLength: items.length,
16376 resourceNamePlural: resourceName.plural
16377 });
16378 } else {
16379 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllMultiple', {
16380 itemsLength: items.length,
16381 resourceNamePlural: resourceName.plural
16382 });
16383 }
16384 }
16385 }, {
16386 key: "paginatedSelectAllText",
16387 value: function paginatedSelectAllText() {
16388 var _this$props10 = this.props,
16389 hasMoreItems = _this$props10.hasMoreItems,
16390 selectedItems = _this$props10.selectedItems,
16391 items = _this$props10.items,
16392 _this$props10$resourc = _this$props10.resourceName,
16393 resourceName = _this$props10$resourc === void 0 ? this.defaultResourceName : _this$props10$resourc,
16394 intl = _this$props10.polaris.intl;
16395
16396 if (!this.selectable() || !hasMoreItems) {
16397 return;
16398 }
16399
16400 if (selectedItems === SELECT_ALL_ITEMS) {
16401 return intl.translate('Polaris.ResourceList.allItemsSelected', {
16402 itemsLength: items.length,
16403 resourceNamePlural: resourceName.plural
16404 });
16405 }
16406 }
16407 }, {
16408 key: "paginatedSelectAllAction",
16409 value: function paginatedSelectAllAction() {
16410 var _this$props11 = this.props,
16411 hasMoreItems = _this$props11.hasMoreItems,
16412 selectedItems = _this$props11.selectedItems,
16413 items = _this$props11.items,
16414 _this$props11$resourc = _this$props11.resourceName,
16415 resourceName = _this$props11$resourc === void 0 ? this.defaultResourceName : _this$props11$resourc,
16416 intl = _this$props11.polaris.intl;
16417
16418 if (!this.selectable() || !hasMoreItems) {
16419 return;
16420 }
16421
16422 var actionText = selectedItems === SELECT_ALL_ITEMS ? intl.translate('Polaris.Common.undo') : intl.translate('Polaris.ResourceList.selectAllItems', {
16423 itemsLength: items.length,
16424 resourceNamePlural: resourceName.plural
16425 });
16426 return {
16427 content: actionText,
16428 onAction: this.handleSelectAllItemsInStore
16429 };
16430 }
16431 }, {
16432 key: "emptySearchResultText",
16433 value: function emptySearchResultText() {
16434 var _this$props12 = this.props,
16435 intl = _this$props12.polaris.intl,
16436 _this$props12$resourc = _this$props12.resourceName,
16437 resourceName = _this$props12$resourc === void 0 ? this.defaultResourceName : _this$props12$resourc;
16438 return {
16439 title: intl.translate('Polaris.ResourceList.emptySearchResultTitle', {
16440 resourceNamePlural: resourceName.plural
16441 }),
16442 description: intl.translate('Polaris.ResourceList.emptySearchResultDescription')
16443 };
16444 } // eslint-disable-next-line @typescript-eslint/member-ordering
16445
16446 }, {
16447 key: "componentDidMount",
16448 value: function componentDidMount() {
16449 this.forceUpdate();
16450
16451 if (this.props.loading) {
16452 this.setLoadingPosition();
16453 }
16454 } // eslint-disable-next-line @typescript-eslint/member-ordering
16455
16456 }, {
16457 key: "componentDidUpdate",
16458 value: function componentDidUpdate(_ref2) {
16459 var prevLoading = _ref2.loading,
16460 prevItems = _ref2.items,
16461 prevSelectedItems = _ref2.selectedItems;
16462 var _this$props13 = this.props,
16463 selectedItems = _this$props13.selectedItems,
16464 loading = _this$props13.loading;
16465
16466 if (this.listRef.current && this.itemsExist() && !this.itemsExist(prevItems)) {
16467 this.forceUpdate();
16468 }
16469
16470 if (loading && !prevLoading) {
16471 this.setLoadingPosition();
16472 }
16473
16474 if (selectedItems && selectedItems.length > 0 && !this.state.selectMode) {
16475 // eslint-disable-next-line react/no-did-update-set-state
16476 this.setState({
16477 selectMode: true
16478 });
16479 return;
16480 }
16481
16482 if (prevSelectedItems && prevSelectedItems.length > 0 && (!selectedItems || selectedItems.length === 0) && !isSmallScreen()) {
16483 // eslint-disable-next-line react/no-did-update-set-state
16484 this.setState({
16485 selectMode: false
16486 });
16487 }
16488 } // eslint-disable-next-line @typescript-eslint/member-ordering
16489
16490 }, {
16491 key: "render",
16492 value: function render() {
16493 var _this2 = this;
16494
16495 var _this$props14 = this.props,
16496 items = _this$props14.items,
16497 promotedBulkActions = _this$props14.promotedBulkActions,
16498 bulkActions = _this$props14.bulkActions,
16499 filterControl = _this$props14.filterControl,
16500 loading = _this$props14.loading,
16501 _this$props14$showHea = _this$props14.showHeader,
16502 showHeader = _this$props14$showHea === void 0 ? false : _this$props14$showHea,
16503 sortOptions = _this$props14.sortOptions,
16504 sortValue = _this$props14.sortValue,
16505 alternateTool = _this$props14.alternateTool,
16506 selectedItems = _this$props14.selectedItems,
16507 _this$props14$resourc = _this$props14.resourceName,
16508 resourceName = _this$props14$resourc === void 0 ? this.defaultResourceName : _this$props14$resourc,
16509 onSortChange = _this$props14.onSortChange,
16510 intl = _this$props14.polaris.intl;
16511 var _this$state2 = this.state,
16512 selectMode = _this$state2.selectMode,
16513 loadingPosition = _this$state2.loadingPosition,
16514 smallScreen = _this$state2.smallScreen;
16515 var filterControlMarkup = filterControl ? React__default.createElement("div", {
16516 className: styles$1t.FiltersWrapper
16517 }, filterControl) : null;
16518 var bulkActionsMarkup = this.selectable() ? React__default.createElement("div", {
16519 className: styles$1t.BulkActionsWrapper
16520 }, React__default.createElement(BulkActions, {
16521 label: this.bulkActionsLabel(),
16522 accessibilityLabel: this.bulkActionsAccessibilityLabel(),
16523 selected: this.bulkSelectState(),
16524 onToggleAll: this.handleToggleAll,
16525 selectMode: selectMode,
16526 onSelectModeToggle: this.handleSelectMode,
16527 promotedActions: promotedBulkActions,
16528 paginatedSelectAllAction: this.paginatedSelectAllAction(),
16529 paginatedSelectAllText: this.paginatedSelectAllText(),
16530 actions: bulkActions,
16531 disabled: loading,
16532 smallScreen: smallScreen
16533 })) : null;
16534 var sortingSelectMarkup = sortOptions && sortOptions.length > 0 && !alternateTool ? React__default.createElement("div", {
16535 className: styles$1t.SortWrapper
16536 }, React__default.createElement(Select, {
16537 label: intl.translate('Polaris.ResourceList.sortingLabel'),
16538 labelInline: !smallScreen,
16539 labelHidden: smallScreen,
16540 options: sortOptions,
16541 onChange: onSortChange,
16542 value: sortValue,
16543 disabled: selectMode
16544 })) : null;
16545 var alternateToolMarkup = alternateTool && !sortingSelectMarkup ? React__default.createElement("div", {
16546 className: styles$1t.AlternateToolWrapper
16547 }, alternateTool) : null;
16548 var headerTitleMarkup = React__default.createElement("div", {
16549 className: styles$1t.HeaderTitleWrapper
16550 }, this.headerTitle());
16551 var selectButtonMarkup = this.selectable() ? React__default.createElement("div", {
16552 className: styles$1t.SelectButtonWrapper
16553 }, React__default.createElement(Button, {
16554 disabled: selectMode,
16555 icon: EnableSelectionMinor,
16556 onClick: this.handleSelectMode.bind(this, true)
16557 }, intl.translate('Polaris.ResourceList.selectButtonText'))) : null;
16558 var checkableButtonMarkup = this.selectable() ? React__default.createElement("div", {
16559 className: styles$1t.CheckableButtonWrapper
16560 }, React__default.createElement(CheckableButton, {
16561 accessibilityLabel: this.bulkActionsAccessibilityLabel(),
16562 label: this.headerTitle(),
16563 onToggleAll: this.handleToggleAll,
16564 plain: true,
16565 disabled: loading
16566 })) : null;
16567 var needsHeader = this.selectable() || sortOptions && sortOptions.length > 0 || alternateTool;
16568 var headerWrapperOverlay = loading ? React__default.createElement("div", {
16569 className: styles$1t['HeaderWrapper-overlay']
16570 }) : null;
16571 var showEmptyState = filterControl && !this.itemsExist() && !loading;
16572 var headerMarkup = !showEmptyState && (showHeader || needsHeader) && this.listRef.current && React__default.createElement("div", {
16573 className: styles$1t.HeaderOuterWrapper
16574 }, React__default.createElement(Sticky, {
16575 boundingElement: this.listRef.current
16576 }, function (isSticky) {
16577 var headerClassName = classNames(styles$1t.HeaderWrapper, sortOptions && sortOptions.length > 0 && !alternateTool && styles$1t['HeaderWrapper-hasSort'], alternateTool && styles$1t['HeaderWrapper-hasAlternateTool'], _this2.selectable() && styles$1t['HeaderWrapper-hasSelect'], loading && styles$1t['HeaderWrapper-disabled'], _this2.selectable() && selectMode && styles$1t['HeaderWrapper-inSelectMode'], isSticky && styles$1t['HeaderWrapper-isSticky']);
16578 return React__default.createElement("div", {
16579 className: headerClassName
16580 }, React__default.createElement(EventListener, {
16581 event: "resize",
16582 handler: _this2.handleResize
16583 }), headerWrapperOverlay, React__default.createElement("div", {
16584 className: styles$1t.HeaderContentWrapper
16585 }, headerTitleMarkup, checkableButtonMarkup, alternateToolMarkup, sortingSelectMarkup, selectButtonMarkup), bulkActionsMarkup);
16586 }));
16587 var emptyStateMarkup = showEmptyState ? React__default.createElement("div", {
16588 className: styles$1t.EmptySearchResultWrapper
16589 }, React__default.createElement(EmptySearchResult, Object.assign({}, this.emptySearchResultText(), {
16590 withIllustration: true
16591 }))) : null;
16592 var defaultTopPadding = 8;
16593 var topPadding = loadingPosition > 0 ? loadingPosition : defaultTopPadding;
16594 var spinnerStyle = {
16595 paddingTop: "".concat(topPadding, "px")
16596 };
16597 var spinnerSize = items.length < 2 ? 'small' : 'large';
16598 var loadingOverlay = loading ? React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
16599 className: styles$1t.SpinnerContainer,
16600 style: spinnerStyle
16601 }, React__default.createElement(Spinner, {
16602 size: spinnerSize,
16603 accessibilityLabel: "Items are loading"
16604 })), React__default.createElement("div", {
16605 className: styles$1t.LoadingOverlay
16606 })) : null;
16607 var className = classNames(styles$1t.ItemWrapper, loading && styles$1t['ItemWrapper-isLoading']);
16608 var loadingWithoutItemsMarkup = loading && !this.itemsExist() ? React__default.createElement("div", {
16609 className: className,
16610 tabIndex: -1
16611 }, loadingOverlay) : null;
16612 var resourceListClassName = classNames(styles$1t.ResourceList, loading && styles$1t.disabledPointerEvents, selectMode && styles$1t.disableTextSelection);
16613 var listMarkup = this.itemsExist() ? React__default.createElement("ul", {
16614 className: resourceListClassName,
16615 ref: this.listRef,
16616 "aria-live": "polite",
16617 "aria-busy": loading
16618 }, loadingOverlay, items.map(this.renderItem)) : emptyStateMarkup;
16619 var context = {
16620 selectable: this.selectable(),
16621 selectedItems,
16622 selectMode,
16623 resourceName,
16624 loading,
16625 onSelectionChange: this.handleSelectionChange,
16626 registerCheckableButtons: this.handleCheckableButtonRegistration
16627 };
16628 return React__default.createElement(ResourceListContext.Provider, {
16629 value: context
16630 }, React__default.createElement("div", {
16631 className: styles$1t.ResourceListWrapper
16632 }, filterControlMarkup, headerMarkup, listMarkup, loadingWithoutItemsMarkup));
16633 }
16634 }, {
16635 key: "itemsExist",
16636 value: function itemsExist(items) {
16637 return (items || this.props.items).length > 0;
16638 }
16639 }]);
16640
16641 return ResourceListInner;
16642}(React__default.Component);
16643
16644ResourceListInner.Item = ResourceItem; // eslint-disable-next-line import/no-deprecated
16645
16646ResourceListInner.FilterControl = FilterControl;
16647
16648function getAllItemsOnPage(items, idForItem) {
16649 return items.map(function (item, index) {
16650 return idForItem(item, index);
16651 });
16652}
16653
16654function defaultIdForItem(item, index) {
16655 return Object.prototype.hasOwnProperty.call(item, 'id') ? item.id : index.toString();
16656}
16657
16658function isSmallScreen() {
16659 return typeof window === 'undefined' ? false : window.innerWidth < SMALL_SCREEN_WIDTH;
16660}
16661
16662var ResourceList = withAppProvider()(ResourceListInner);
16663
16664/** @deprecated Use `ResourcePicker` from `@shopify/app-bridge-react` instead. */
16665
16666var ResourcePickerInner =
16667/*#__PURE__*/
16668function (_React$PureComponent) {
16669 _inherits(ResourcePickerInner, _React$PureComponent);
16670
16671 function ResourcePickerInner() {
16672 var _this;
16673
16674 _classCallCheck(this, ResourcePickerInner);
16675
16676 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourcePickerInner).apply(this, arguments));
16677 _this.focusReturnPoint = null;
16678 return _this;
16679 }
16680
16681 _createClass(ResourcePickerInner, [{
16682 key: "componentDidMount",
16683 value: function componentDidMount() {
16684 // eslint-disable-next-line no-console
16685 console.warn('Deprecation: `ResourcePicker` is deprecated and will be removed in v5.0. Use `ResourcePicker` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/resourcepicker');
16686
16687 if (this.props.polaris.appBridge == null) {
16688 return;
16689 }
16690
16691 var _this$props = this.props,
16692 open = _this$props.open,
16693 resourceType = _this$props.resourceType,
16694 initialQuery = _this$props.initialQuery,
16695 _this$props$showHidde = _this$props.showHidden,
16696 showHidden = _this$props$showHidde === void 0 ? true : _this$props$showHidde,
16697 _this$props$allowMult = _this$props.allowMultiple,
16698 allowMultiple = _this$props$allowMult === void 0 ? true : _this$props$allowMult,
16699 _this$props$showVaria = _this$props.showVariants,
16700 showVariants = _this$props$showVaria === void 0 ? true : _this$props$showVaria,
16701 onSelection = _this$props.onSelection,
16702 onCancel = _this$props.onCancel;
16703 var appBridge = this.props.polaris.appBridge;
16704 this.appBridgeResourcePicker = ResourcePicker$1.create(appBridge, {
16705 resourceType: ResourcePicker$1.ResourceType[resourceType],
16706 options: {
16707 initialQuery,
16708 showHidden,
16709 selectMultiple: allowMultiple,
16710 showVariants
16711 }
16712 });
16713
16714 if (onSelection != null) {
16715 this.appBridgeResourcePicker.subscribe(ResourcePicker$1.Action.SELECT, function (_ref) {
16716 var selection = _ref.selection;
16717 onSelection({
16718 selection
16719 });
16720 });
16721 }
16722
16723 if (onCancel != null) {
16724 this.appBridgeResourcePicker.subscribe(ResourcePicker$1.Action.CANCEL, onCancel);
16725 }
16726
16727 if (open) {
16728 this.focusReturnPoint = document.activeElement;
16729 this.appBridgeResourcePicker.dispatch(ResourcePicker$1.Action.OPEN);
16730 }
16731 }
16732 }, {
16733 key: "componentDidUpdate",
16734 value: function componentDidUpdate(prevProps) {
16735 if (this.appBridgeResourcePicker == null) {
16736 return;
16737 }
16738
16739 var _this$props2 = this.props,
16740 open = _this$props2.open,
16741 initialQuery = _this$props2.initialQuery,
16742 _this$props2$showHidd = _this$props2.showHidden,
16743 showHidden = _this$props2$showHidd === void 0 ? false : _this$props2$showHidd,
16744 _this$props2$allowMul = _this$props2.allowMultiple,
16745 allowMultiple = _this$props2$allowMul === void 0 ? true : _this$props2$allowMul,
16746 _this$props2$showVari = _this$props2.showVariants,
16747 showVariants = _this$props2$showVari === void 0 ? true : _this$props2$showVari,
16748 onSelection = _this$props2.onSelection,
16749 onCancel = _this$props2.onCancel;
16750 var wasOpen = prevProps.open;
16751
16752 var prevAppBridge = prevProps.polaris.appBridge,
16753 prevResourcePickerProps = __rest(prevProps, ["polaris"]);
16754
16755 var _a = this.props,
16756 appBridge = _a.polaris.appBridge,
16757 resourcePickerProps = __rest(_a, ["polaris"]);
16758
16759 if (!isEqual(prevResourcePickerProps, resourcePickerProps) || !isEqual(prevAppBridge, appBridge)) {
16760 this.appBridgeResourcePicker.set({
16761 initialQuery,
16762 showHidden,
16763 selectMultiple: allowMultiple,
16764 showVariants
16765 });
16766 }
16767
16768 this.appBridgeResourcePicker.unsubscribe();
16769
16770 if (onSelection != null) {
16771 this.appBridgeResourcePicker.subscribe(ResourcePicker$1.Action.SELECT, function (_ref2) {
16772 var selection = _ref2.selection;
16773 onSelection({
16774 selection
16775 });
16776 });
16777 }
16778
16779 if (onCancel != null) {
16780 this.appBridgeResourcePicker.subscribe(ResourcePicker$1.Action.CANCEL, onCancel);
16781 }
16782
16783 if (wasOpen !== open) {
16784 if (open) {
16785 this.appBridgeResourcePicker.dispatch(ResourcePicker$1.Action.OPEN);
16786 } else {
16787 this.appBridgeResourcePicker.dispatch(ResourcePicker$1.Action.CLOSE);
16788 }
16789 }
16790
16791 if (!wasOpen && open) {
16792 this.focusReturnPoint = document.activeElement;
16793 } else if (wasOpen && !open && this.focusReturnPoint != null && document.contains(this.focusReturnPoint)) {
16794 this.focusReturnPoint.focus();
16795 this.focusReturnPoint = null;
16796 }
16797 }
16798 }, {
16799 key: "componentWillUnmount",
16800 value: function componentWillUnmount() {
16801 if (this.appBridgeResourcePicker == null) {
16802 return;
16803 }
16804
16805 this.appBridgeResourcePicker.unsubscribe();
16806 }
16807 }, {
16808 key: "render",
16809 value: function render() {
16810 return null;
16811 }
16812 }]);
16813
16814 return ResourcePickerInner;
16815}(React__default.PureComponent);
16816
16817var ResourcePicker = withAppProvider()(ResourcePickerInner);
16818
16819function SettingToggle(_ref) {
16820 var enabled = _ref.enabled,
16821 action = _ref.action,
16822 children = _ref.children;
16823 var actionMarkup = action ? buttonFrom(action, {
16824 primary: !enabled
16825 }) : null;
16826 return React__default.createElement(Card, {
16827 sectioned: true
16828 }, React__default.createElement(SettingAction, {
16829 action: actionMarkup
16830 }, children));
16831}
16832
16833var styles$1u = {
16834 "SkeletonBodyTextContainer": "Polaris-SkeletonBodyText__SkeletonBodyTextContainer",
16835 "SkeletonBodyText": "Polaris-SkeletonBodyText"
16836};
16837
16838function SkeletonBodyText(_ref) {
16839 var _ref$lines = _ref.lines,
16840 lines = _ref$lines === void 0 ? 3 : _ref$lines;
16841 var bodyTextLines = [];
16842
16843 for (var i = 0; i < lines; i++) {
16844 bodyTextLines.push(React__default.createElement("div", {
16845 className: styles$1u.SkeletonBodyText,
16846 key: i
16847 }));
16848 }
16849
16850 return React__default.createElement("div", {
16851 className: styles$1u.SkeletonBodyTextContainer
16852 }, bodyTextLines);
16853}
16854
16855var styles$1v = {
16856 "DisplayText": "Polaris-SkeletonDisplayText__DisplayText",
16857 "sizeSmall": "Polaris-SkeletonDisplayText--sizeSmall",
16858 "sizeMedium": "Polaris-SkeletonDisplayText--sizeMedium",
16859 "sizeLarge": "Polaris-SkeletonDisplayText--sizeLarge",
16860 "sizeExtraLarge": "Polaris-SkeletonDisplayText--sizeExtraLarge"
16861};
16862
16863function SkeletonDisplayText(_ref) {
16864 var _ref$size = _ref.size,
16865 size = _ref$size === void 0 ? 'medium' : _ref$size;
16866 var className = classNames(styles$1v.DisplayText, size && styles$1v[variationName('size', size)]);
16867 return React__default.createElement("div", {
16868 className: className
16869 });
16870}
16871
16872var styles$1w = {
16873 "Page": "Polaris-SkeletonPage__Page",
16874 "fullWidth": "Polaris-SkeletonPage--fullWidth",
16875 "narrowWidth": "Polaris-SkeletonPage--narrowWidth",
16876 "Content": "Polaris-SkeletonPage__Content",
16877 "Header": "Polaris-SkeletonPage__Header",
16878 "Header-hasSecondaryActions": "Polaris-SkeletonPage__Header--hasSecondaryActions",
16879 "BreadcrumbAction": "Polaris-SkeletonPage__BreadcrumbAction",
16880 "TitleAndPrimaryAction": "Polaris-SkeletonPage__TitleAndPrimaryAction",
16881 "Title": "Polaris-SkeletonPage__Title",
16882 "PrimaryAction": "Polaris-SkeletonPage__PrimaryAction",
16883 "Actions": "Polaris-SkeletonPage__Actions",
16884 "Action": "Polaris-SkeletonPage__Action"
16885};
16886
16887function SkeletonPage(_ref) {
16888 var children = _ref.children,
16889 fullWidth = _ref.fullWidth,
16890 narrowWidth = _ref.narrowWidth,
16891 singleColumn = _ref.singleColumn,
16892 primaryAction = _ref.primaryAction,
16893 secondaryActions = _ref.secondaryActions,
16894 _ref$title = _ref.title,
16895 title = _ref$title === void 0 ? '' : _ref$title,
16896 breadcrumbs = _ref.breadcrumbs;
16897
16898 if (singleColumn) {
16899 // eslint-disable-next-line no-console
16900 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
16901 }
16902
16903 var i18n = useI18n();
16904 var appBridge = useAppBridge();
16905 var className = classNames(styles$1w.Page, fullWidth && styles$1w.fullWidth, (narrowWidth || singleColumn) && styles$1w.narrowWidth);
16906 var headerClassName = classNames(styles$1w.Header, breadcrumbs && styles$1w['Header-hasBreadcrumbs'], secondaryActions && styles$1w['Header-hasSecondaryActions']);
16907 var titleMarkup = title !== null ? renderTitle(title) : null;
16908 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
16909 className: styles$1w.PrimaryAction
16910 }, React__default.createElement(SkeletonDisplayText, {
16911 size: "large"
16912 })) : null;
16913 var secondaryActionsMarkup = secondaryActions ? renderSecondaryActions(secondaryActions) : null;
16914 var breadcrumbMarkup = breadcrumbs ? React__default.createElement("div", {
16915 className: styles$1w.BreadcrumbAction,
16916 style: {
16917 width: 60
16918 }
16919 }, React__default.createElement(SkeletonBodyText, {
16920 lines: 1
16921 })) : null;
16922 var headerMarkup = !appBridge ? React__default.createElement("div", {
16923 className: headerClassName
16924 }, breadcrumbMarkup, React__default.createElement("div", {
16925 className: styles$1w.TitleAndPrimaryAction
16926 }, titleMarkup, primaryActionMarkup), secondaryActionsMarkup) : null;
16927 return React__default.createElement("div", {
16928 className: className,
16929 role: "status",
16930 "aria-label": i18n.translate('Polaris.SkeletonPage.loadingLabel')
16931 }, headerMarkup, React__default.createElement("div", {
16932 className: styles$1w.Content
16933 }, children));
16934}
16935
16936function renderSecondaryActions(actionCount) {
16937 var actions = [];
16938
16939 for (var i = 0; i < actionCount; i++) {
16940 var width = Math.round(Math.random() * 40 + 60);
16941 actions.push(React__default.createElement("div", {
16942 className: styles$1w.Action,
16943 style: {
16944 width
16945 },
16946 key: i
16947 }, React__default.createElement(SkeletonBodyText, {
16948 lines: 1
16949 })));
16950 }
16951
16952 return React__default.createElement("div", {
16953 className: styles$1w.Actions
16954 }, actions);
16955}
16956
16957function renderTitle(title) {
16958 var titleContent = title === '' ? React__default.createElement(SkeletonDisplayText, {
16959 size: "large"
16960 }) : React__default.createElement(DisplayText, {
16961 size: "large",
16962 element: "h1"
16963 }, title);
16964 return React__default.createElement("div", {
16965 className: styles$1w.Title
16966 }, titleContent);
16967}
16968
16969var styles$1x = {
16970 "SkeletonThumbnail": "Polaris-SkeletonThumbnail",
16971 "sizeSmall": "Polaris-SkeletonThumbnail--sizeSmall",
16972 "sizeMedium": "Polaris-SkeletonThumbnail--sizeMedium",
16973 "sizeLarge": "Polaris-SkeletonThumbnail--sizeLarge"
16974};
16975
16976function SkeletonThumbnail(_ref) {
16977 var _ref$size = _ref.size,
16978 size = _ref$size === void 0 ? 'medium' : _ref$size;
16979 var className = classNames(styles$1x.SkeletonThumbnail, size && styles$1x[variationName('size', size)]);
16980 return React__default.createElement("div", {
16981 className: className
16982 });
16983}
16984
16985function getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth) {
16986 var sumTabWidths = tabWidths.reduce(function (sum, width) {
16987 return sum + width;
16988 }, 0);
16989 var arrayOfTabIndices = tabs.map(function (_, index) {
16990 return index;
16991 });
16992 var visibleTabs = [];
16993 var hiddenTabs = [];
16994
16995 if (containerWidth > sumTabWidths) {
16996 visibleTabs.push.apply(visibleTabs, _toConsumableArray(arrayOfTabIndices));
16997 } else {
16998 visibleTabs.push(selected);
16999 var tabListWidth = tabWidths[selected];
17000 arrayOfTabIndices.forEach(function (currentTabIndex) {
17001 if (currentTabIndex !== selected) {
17002 var currentTabWidth = tabWidths[currentTabIndex];
17003
17004 if (tabListWidth + currentTabWidth > containerWidth - disclosureWidth) {
17005 hiddenTabs.push(currentTabIndex);
17006 return;
17007 }
17008
17009 visibleTabs.push(currentTabIndex);
17010 tabListWidth += currentTabWidth;
17011 }
17012 });
17013 }
17014
17015 return {
17016 visibleTabs,
17017 hiddenTabs
17018 };
17019}
17020
17021var styles$1y = {
17022 "Tabs": "Polaris-Tabs",
17023 "fitted": "Polaris-Tabs--fitted",
17024 "TabContainer": "Polaris-Tabs__TabContainer",
17025 "Tab": "Polaris-Tabs__Tab",
17026 "Title": "Polaris-Tabs__Title",
17027 "fillSpace": "Polaris-Tabs--fillSpace",
17028 "Tab-selected": "Polaris-Tabs__Tab--selected",
17029 "Panel": "Polaris-Tabs__Panel",
17030 "Panel-hidden": "Polaris-Tabs__Panel--hidden",
17031 "List": "Polaris-Tabs__List",
17032 "Item": "Polaris-Tabs__Item",
17033 "DisclosureTab": "Polaris-Tabs__DisclosureTab",
17034 "DisclosureTab-visible": "Polaris-Tabs__DisclosureTab--visible",
17035 "DisclosureActivator": "Polaris-Tabs__DisclosureActivator",
17036 "TabMeasurer": "Polaris-Tabs__TabMeasurer"
17037};
17038
17039var Item$8 =
17040/*#__PURE__*/
17041function (_React$PureComponent) {
17042 _inherits(Item, _React$PureComponent);
17043
17044 function Item() {
17045 var _this;
17046
17047 _classCallCheck(this, Item);
17048
17049 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
17050 _this.focusedNode = null;
17051
17052 _this.setFocusedNode = function (node) {
17053 _this.focusedNode = node;
17054 };
17055
17056 return _this;
17057 }
17058
17059 _createClass(Item, [{
17060 key: "componentDidMount",
17061 value: function componentDidMount() {
17062 var focusedNode = this.focusedNode;
17063 var focused = this.props.focused;
17064
17065 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17066 focusedNode.focus();
17067 }
17068 }
17069 }, {
17070 key: "componentDidUpdate",
17071 value: function componentDidUpdate() {
17072 var focusedNode = this.focusedNode;
17073 var focused = this.props.focused;
17074
17075 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17076 focusedNode.focus();
17077 }
17078 }
17079 }, {
17080 key: "render",
17081 value: function render() {
17082 var _this$props = this.props,
17083 id = _this$props.id,
17084 panelID = _this$props.panelID,
17085 children = _this$props.children,
17086 url = _this$props.url,
17087 accessibilityLabel = _this$props.accessibilityLabel,
17088 _this$props$onClick = _this$props.onClick,
17089 onClick = _this$props$onClick === void 0 ? noop$b : _this$props$onClick;
17090 var sharedProps = {
17091 id,
17092 ref: this.setFocusedNode,
17093 onClick,
17094 className: styles$1y.Item,
17095 'aria-controls': panelID,
17096 'aria-selected': false,
17097 'aria-label': accessibilityLabel
17098 };
17099 var markup = url ? React__default.createElement(UnstyledLink, Object.assign({}, sharedProps, {
17100 url: url
17101 }), children) : React__default.createElement("button", Object.assign({}, sharedProps, {
17102 type: "button"
17103 }), children);
17104 return React__default.createElement("li", null, markup);
17105 }
17106 }]);
17107
17108 return Item;
17109}(React__default.PureComponent);
17110
17111function noop$b() {}
17112
17113var List$1 =
17114/*#__PURE__*/
17115function (_React$PureComponent) {
17116 _inherits(List, _React$PureComponent);
17117
17118 function List() {
17119 var _this;
17120
17121 _classCallCheck(this, List);
17122
17123 _this = _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
17124
17125 _this.handleKeypress = function (event) {
17126 var _this$props$onKeyPres = _this.props.onKeyPress,
17127 onKeyPress = _this$props$onKeyPres === void 0 ? noop$c : _this$props$onKeyPres;
17128 onKeyPress(event);
17129 };
17130
17131 return _this;
17132 }
17133
17134 _createClass(List, [{
17135 key: "render",
17136 value: function render() {
17137 var _this$props = this.props,
17138 focusIndex = _this$props.focusIndex,
17139 disclosureTabs = _this$props.disclosureTabs,
17140 _this$props$onClick = _this$props.onClick,
17141 onClick = _this$props$onClick === void 0 ? noop$c : _this$props$onClick;
17142 var tabs = disclosureTabs.map(function (_a, index) {
17143 var id = _a.id,
17144 content = _a.content,
17145 tabProps = __rest(_a, ["id", "content"]);
17146
17147 return React__default.createElement(Item$8, Object.assign({}, tabProps, {
17148 key: id,
17149 id: id,
17150 focused: index === focusIndex,
17151 onClick: onClick.bind(null, id)
17152 }), content);
17153 });
17154 return React__default.createElement("ul", {
17155 className: styles$1y.List,
17156 onKeyDown: handleKeyDown$1,
17157 onKeyUp: this.handleKeypress
17158 }, tabs);
17159 }
17160 }]);
17161
17162 return List;
17163}(React__default.PureComponent);
17164
17165function noop$c() {}
17166
17167function handleKeyDown$1(event) {
17168 var key = event.key;
17169
17170 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
17171 event.preventDefault();
17172 event.stopPropagation();
17173 }
17174}
17175
17176function Panel(_ref) {
17177 var hidden = _ref.hidden,
17178 id = _ref.id,
17179 tabID = _ref.tabID,
17180 children = _ref.children;
17181 var className = classNames(styles$1y.Panel, hidden && styles$1y['Panel-hidden']);
17182 return React__default.createElement("div", {
17183 className: className,
17184 id: id,
17185 role: "tabpanel",
17186 "aria-labelledby": tabID,
17187 tabIndex: -1
17188 }, children);
17189}
17190
17191function Tab(_ref) {
17192 var id = _ref.id,
17193 focused = _ref.focused,
17194 siblingTabHasFocus = _ref.siblingTabHasFocus,
17195 children = _ref.children,
17196 onClick = _ref.onClick,
17197 selected = _ref.selected,
17198 url = _ref.url,
17199 panelID = _ref.panelID,
17200 measuring = _ref.measuring,
17201 accessibilityLabel = _ref.accessibilityLabel;
17202 var wasSelected = useRef(selected);
17203 var panelFocused = useRef(false);
17204 var node = useRef(null); // A tab can start selected when it is moved from the disclosure dropdown
17205 // into the main list, so we need to send focus from the tab to the panel
17206 // on mount and update
17207
17208 useEffect(function () {
17209 if (measuring) {
17210 return;
17211 } // Because of timing issues with the render, we may still have the old,
17212 // in-disclosure version of the tab that has focus. Check for this
17213 // as a second indicator of focus
17214
17215
17216 var itemHadFocus = focused || document.activeElement && document.activeElement.id === id; // If we just check for selected, the panel for the active tab will
17217 // be focused on page load, which we don’t want
17218
17219 if (itemHadFocus && selected && panelID != null && !panelFocused.current) {
17220 focusPanelID(panelID);
17221 panelFocused.current = true;
17222 }
17223
17224 if (selected && !wasSelected.current && panelID != null) {
17225 focusPanelID(panelID);
17226 } else if (focused && node.current != null) {
17227 focusFirstFocusableNode(node.current);
17228 }
17229
17230 wasSelected.current = selected;
17231 }, [focused, id, measuring, panelID, selected]);
17232 var handleClick = onClick && onClick.bind(null, id);
17233 var className = classNames(styles$1y.Tab, selected && styles$1y['Tab-selected']);
17234 var tabIndex;
17235
17236 if (selected && !siblingTabHasFocus && !measuring) {
17237 tabIndex = 0;
17238 } else if (focused && !measuring) {
17239 tabIndex = 0;
17240 } else {
17241 tabIndex = -1;
17242 }
17243
17244 var markup = url ? React__default.createElement(UnstyledLink, {
17245 id: id,
17246 url: url,
17247 role: "tab",
17248 tabIndex: tabIndex,
17249 onClick: handleClick,
17250 className: className,
17251 "aria-selected": selected,
17252 "aria-controls": panelID,
17253 "aria-label": accessibilityLabel,
17254 onMouseUp: handleMouseUpByBlurring
17255 }, React__default.createElement("span", {
17256 className: styles$1y.Title
17257 }, children)) : React__default.createElement("button", {
17258 id: id,
17259 role: "tab",
17260 type: "button",
17261 tabIndex: tabIndex,
17262 className: className,
17263 onClick: handleClick,
17264 "aria-selected": selected,
17265 "aria-controls": panelID,
17266 "aria-label": accessibilityLabel,
17267 onMouseUp: handleMouseUpByBlurring
17268 }, React__default.createElement("span", {
17269 className: styles$1y.Title
17270 }, children));
17271 return React__default.createElement("li", {
17272 className: styles$1y.TabContainer,
17273 ref: node
17274 }, markup);
17275}
17276
17277function focusPanelID(panelID) {
17278 var panel = document.getElementById(panelID);
17279
17280 if (panel) {
17281 panel.focus({
17282 preventScroll: true
17283 });
17284 }
17285}
17286
17287var TabMeasurer = memo(function TabMeasurer(_ref) {
17288 var selected = _ref.selected,
17289 tabs = _ref.tabs,
17290 activator = _ref.activator,
17291 tabToFocus = _ref.tabToFocus,
17292 siblingTabHasFocus = _ref.siblingTabHasFocus,
17293 handleMeasurementProp = _ref.handleMeasurement;
17294 var containerNode = useRef(null);
17295 var animationFrame = useRef(null);
17296 var handleMeasurement = useCallback(function () {
17297 if (animationFrame.current) {
17298 cancelAnimationFrame(animationFrame.current);
17299 }
17300
17301 animationFrame.current = requestAnimationFrame(function () {
17302 if (!containerNode.current) {
17303 return;
17304 }
17305
17306 var containerWidth = containerNode.current.offsetWidth;
17307 var hiddenTabNodes = containerNode.current.children;
17308 var hiddenTabNodesArray = Array.from(hiddenTabNodes);
17309 var hiddenTabWidths = hiddenTabNodesArray.map(function (node) {
17310 return node.getBoundingClientRect().width;
17311 });
17312 var disclosureWidth = hiddenTabWidths.pop();
17313 handleMeasurementProp({
17314 containerWidth,
17315 disclosureWidth,
17316 hiddenTabWidths
17317 });
17318 });
17319 }, [handleMeasurementProp]);
17320 useEffect(function () {
17321 handleMeasurement();
17322 }, [handleMeasurement, tabs]);
17323 useComponentDidMount(function () {
17324 if (process.env.NODE_ENV === 'development') {
17325 setTimeout(handleMeasurement, 0);
17326 }
17327 });
17328 var tabsMarkup = tabs.map(function (tab, index) {
17329 return React__default.createElement(Tab, {
17330 measuring: true,
17331 key: "".concat(index).concat(tab.id, "Hidden"),
17332 id: "".concat(tab.id, "Measurer"),
17333 siblingTabHasFocus: siblingTabHasFocus,
17334 focused: index === tabToFocus,
17335 selected: index === selected,
17336 onClick: noop$d,
17337 url: tab.url
17338 }, tab.content);
17339 });
17340 var classname = classNames(styles$1y.Tabs, styles$1y.TabMeasurer);
17341 return React__default.createElement("div", {
17342 className: classname,
17343 ref: containerNode
17344 }, React__default.createElement(EventListener, {
17345 event: "resize",
17346 handler: handleMeasurement
17347 }), tabsMarkup, activator);
17348});
17349
17350function noop$d() {}
17351
17352var TabsInner =
17353/*#__PURE__*/
17354function (_React$PureComponent) {
17355 _inherits(TabsInner, _React$PureComponent);
17356
17357 function TabsInner() {
17358 var _this;
17359
17360 _classCallCheck(this, TabsInner);
17361
17362 _this = _possibleConstructorReturn(this, _getPrototypeOf(TabsInner).apply(this, arguments));
17363 _this.state = {
17364 disclosureWidth: 0,
17365 containerWidth: Infinity,
17366 tabWidths: [],
17367 visibleTabs: [],
17368 hiddenTabs: [],
17369 showDisclosure: false,
17370 tabToFocus: -1
17371 };
17372
17373 _this.handleKeyPress = function (event) {
17374 var _this$state = _this.state,
17375 tabToFocus = _this$state.tabToFocus,
17376 visibleTabs = _this$state.visibleTabs,
17377 hiddenTabs = _this$state.hiddenTabs,
17378 showDisclosure = _this$state.showDisclosure;
17379 var key = event.key;
17380 var tabsArrayInOrder = showDisclosure ? visibleTabs.concat(hiddenTabs) : _toConsumableArray(visibleTabs);
17381 var newFocus = tabsArrayInOrder.indexOf(tabToFocus);
17382
17383 if (key === 'ArrowRight' || key === 'ArrowDown') {
17384 newFocus += 1;
17385
17386 if (newFocus === tabsArrayInOrder.length) {
17387 newFocus = 0;
17388 }
17389 }
17390
17391 if (key === 'ArrowLeft' || key === 'ArrowUp') {
17392 if (newFocus === -1 || newFocus === 0) {
17393 newFocus = tabsArrayInOrder.length - 1;
17394 } else {
17395 newFocus -= 1;
17396 }
17397 }
17398
17399 _this.setState({
17400 tabToFocus: tabsArrayInOrder[newFocus]
17401 });
17402 };
17403
17404 _this.renderTabMarkup = function (tab, index) {
17405 var selected = _this.props.selected;
17406 var tabToFocus = _this.state.tabToFocus;
17407 return React__default.createElement(Tab, {
17408 key: "".concat(index, "-").concat(tab.id),
17409 id: tab.id,
17410 siblingTabHasFocus: tabToFocus > -1,
17411 focused: index === tabToFocus,
17412 selected: index === selected,
17413 onClick: _this.handleTabClick,
17414 panelID: tab.panelID || "".concat(tab.id, "-panel"),
17415 accessibilityLabel: tab.accessibilityLabel,
17416 url: tab.url
17417 }, tab.content);
17418 };
17419
17420 _this.handleFocus = function (event) {
17421 var _this$props = _this.props,
17422 selected = _this$props.selected,
17423 tabs = _this$props.tabs; // If we are explicitly focusing a non-selected tab, this focuses it
17424
17425 var target = event.target;
17426
17427 if (target.classList.contains(styles$1y.Tab) || target.classList.contains(styles$1y.Item)) {
17428 var tabToFocus = -1;
17429 tabs.every(function (tab, index) {
17430 if (tab.id === target.id) {
17431 tabToFocus = index;
17432 return false;
17433 }
17434
17435 return true;
17436 });
17437
17438 _this.setState({
17439 tabToFocus
17440 });
17441
17442 return;
17443 }
17444
17445 if (target.classList.contains(styles$1y.DisclosureActivator)) {
17446 return;
17447 } // If we are coming in from somewhere other than another tab, focus the
17448 // selected tab, and the focus (click) is not on the disclosure activator,
17449 // focus the selected tab
17450
17451
17452 if (!event.relatedTarget) {
17453 _this.setState({
17454 tabToFocus: selected
17455 });
17456
17457 return;
17458 }
17459
17460 var relatedTarget = event.relatedTarget;
17461
17462 if (!relatedTarget.classList.contains(styles$1y.Tab) && !relatedTarget.classList.contains(styles$1y.Item) && !relatedTarget.classList.contains(styles$1y.DisclosureActivator)) {
17463 _this.setState({
17464 tabToFocus: selected
17465 });
17466 }
17467 };
17468
17469 _this.handleBlur = function (event) {
17470 // If we blur and the target is not another tab, forget the focus position
17471 if (event.relatedTarget == null) {
17472 _this.setState({
17473 tabToFocus: -1
17474 });
17475
17476 return;
17477 }
17478
17479 var target = event.relatedTarget; // If we are going to anywhere other than another tab, lose the last focused tab
17480
17481 if (!target.classList.contains(styles$1y.Tab) && !target.classList.contains(styles$1y.Item)) {
17482 _this.setState({
17483 tabToFocus: -1
17484 });
17485 }
17486 };
17487
17488 _this.handleDisclosureActivatorClick = function () {
17489 _this.setState(function (_ref) {
17490 var showDisclosure = _ref.showDisclosure;
17491 return {
17492 showDisclosure: !showDisclosure
17493 };
17494 });
17495 };
17496
17497 _this.handleClose = function () {
17498 _this.setState({
17499 showDisclosure: false
17500 });
17501 };
17502
17503 _this.handleMeasurement = function (measurements) {
17504 var _this$props2 = _this.props,
17505 tabs = _this$props2.tabs,
17506 selected = _this$props2.selected;
17507 var tabToFocus = _this.state.tabToFocus;
17508 var tabWidths = measurements.hiddenTabWidths,
17509 containerWidth = measurements.containerWidth,
17510 disclosureWidth = measurements.disclosureWidth;
17511
17512 var _getVisibleAndHiddenT = getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth),
17513 visibleTabs = _getVisibleAndHiddenT.visibleTabs,
17514 hiddenTabs = _getVisibleAndHiddenT.hiddenTabs;
17515
17516 _this.setState({
17517 tabToFocus: tabToFocus === -1 ? -1 : selected,
17518 visibleTabs,
17519 hiddenTabs,
17520 disclosureWidth,
17521 containerWidth,
17522 tabWidths
17523 });
17524 };
17525
17526 _this.handleTabClick = function (id) {
17527 var _this$props3 = _this.props,
17528 tabs = _this$props3.tabs,
17529 _this$props3$onSelect = _this$props3.onSelect,
17530 onSelect = _this$props3$onSelect === void 0 ? noop$e : _this$props3$onSelect;
17531 var tab = tabs.find(function (aTab) {
17532 return aTab.id === id;
17533 });
17534
17535 if (tab == null) {
17536 return;
17537 }
17538
17539 var selectedIndex = tabs.indexOf(tab);
17540 onSelect(selectedIndex);
17541 };
17542
17543 return _this;
17544 }
17545
17546 _createClass(TabsInner, [{
17547 key: "render",
17548 value: function render() {
17549 var _this2 = this;
17550
17551 var _this$props4 = this.props,
17552 tabs = _this$props4.tabs,
17553 selected = _this$props4.selected,
17554 fitted = _this$props4.fitted,
17555 children = _this$props4.children,
17556 intl = _this$props4.polaris.intl;
17557 var _this$state2 = this.state,
17558 tabToFocus = _this$state2.tabToFocus,
17559 visibleTabs = _this$state2.visibleTabs,
17560 hiddenTabs = _this$state2.hiddenTabs,
17561 showDisclosure = _this$state2.showDisclosure;
17562 var disclosureTabs = hiddenTabs.map(function (tabIndex) {
17563 return tabs[tabIndex];
17564 });
17565 var panelMarkup = children ? tabs.map(function (_tab, index) {
17566 return selected === index ? React__default.createElement(Panel, {
17567 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
17568 tabID: tabs[index].id,
17569 key: tabs[index].id
17570 }, children) : React__default.createElement(Panel, {
17571 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
17572 tabID: tabs[index].id,
17573 key: tabs[index].id,
17574 hidden: true
17575 });
17576 }) : null;
17577 var tabsMarkup = visibleTabs.sort(function (tabA, tabB) {
17578 return tabA - tabB;
17579 }).map(function (tabIndex) {
17580 return _this2.renderTabMarkup(tabs[tabIndex], tabIndex);
17581 });
17582 var disclosureActivatorVisible = visibleTabs.length < tabs.length;
17583 var classname = classNames(styles$1y.Tabs, fitted && styles$1y.fitted, disclosureActivatorVisible && styles$1y.fillSpace);
17584 var disclosureTabClassName = classNames(styles$1y.DisclosureTab, disclosureActivatorVisible && styles$1y['DisclosureTab-visible']);
17585 var activator = React__default.createElement("button", {
17586 type: "button",
17587 className: styles$1y.DisclosureActivator,
17588 onClick: this.handleDisclosureActivatorClick,
17589 "aria-label": intl.translate('Polaris.Tabs.toggleTabsLabel')
17590 }, React__default.createElement("span", {
17591 className: styles$1y.Title
17592 }, React__default.createElement(Icon, {
17593 source: HorizontalDotsMinor
17594 })));
17595 return React__default.createElement("div", null, React__default.createElement("ul", {
17596 role: "tablist",
17597 className: classname,
17598 onFocus: this.handleFocus,
17599 onBlur: this.handleBlur,
17600 onKeyDown: handleKeyDown$2,
17601 onKeyUp: this.handleKeyPress
17602 }, tabsMarkup, React__default.createElement("li", {
17603 className: disclosureTabClassName
17604 }, React__default.createElement(Popover, {
17605 preferredPosition: "below",
17606 activator: activator,
17607 active: disclosureActivatorVisible && showDisclosure,
17608 onClose: this.handleClose
17609 }, React__default.createElement(List$1, {
17610 focusIndex: hiddenTabs.indexOf(tabToFocus),
17611 disclosureTabs: disclosureTabs,
17612 onClick: this.handleTabClick,
17613 onKeyPress: this.handleKeyPress
17614 })))), React__default.createElement(TabMeasurer, {
17615 tabToFocus: tabToFocus,
17616 activator: activator,
17617 selected: selected,
17618 tabs: tabs,
17619 siblingTabHasFocus: tabToFocus > -1,
17620 handleMeasurement: this.handleMeasurement
17621 }), panelMarkup);
17622 }
17623 }], [{
17624 key: "getDerivedStateFromProps",
17625 value: function getDerivedStateFromProps(nextProps, prevState) {
17626 var disclosureWidth = prevState.disclosureWidth,
17627 tabWidths = prevState.tabWidths,
17628 containerWidth = prevState.containerWidth;
17629
17630 var _getVisibleAndHiddenT2 = getVisibleAndHiddenTabIndices(nextProps.tabs, nextProps.selected, disclosureWidth, tabWidths, containerWidth),
17631 visibleTabs = _getVisibleAndHiddenT2.visibleTabs,
17632 hiddenTabs = _getVisibleAndHiddenT2.hiddenTabs;
17633
17634 return {
17635 visibleTabs,
17636 hiddenTabs,
17637 selected: nextProps.selected
17638 };
17639 }
17640 }]);
17641
17642 return TabsInner;
17643}(React__default.PureComponent);
17644
17645function noop$e() {}
17646
17647function handleKeyDown$2(event) {
17648 var key = event.key;
17649
17650 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
17651 event.preventDefault();
17652 event.stopPropagation();
17653 }
17654}
17655
17656var Tabs = withAppProvider()(TabsInner);
17657
17658var styles$1z = {
17659 "Thumbnail": "Polaris-Thumbnail",
17660 "sizeSmall": "Polaris-Thumbnail--sizeSmall",
17661 "sizeMedium": "Polaris-Thumbnail--sizeMedium",
17662 "sizeLarge": "Polaris-Thumbnail--sizeLarge",
17663 "Image": "Polaris-Thumbnail__Image"
17664};
17665
17666function Thumbnail(_ref) {
17667 var source = _ref.source,
17668 alt = _ref.alt,
17669 _ref$size = _ref.size,
17670 size = _ref$size === void 0 ? 'medium' : _ref$size;
17671 var className = classNames(styles$1z.Thumbnail, size && styles$1z[variationName('size', size)]);
17672 return React__default.createElement("span", {
17673 className: className
17674 }, React__default.createElement(Image, {
17675 alt: alt,
17676 source: source,
17677 className: styles$1z.Image
17678 }));
17679}
17680
17681var Toast$1 = React__default.memo(function Toast(props) {
17682 var id = useUniqueId('Toast');
17683 var appBridgeToast = useRef();
17684
17685 var _useFrame = useFrame(),
17686 showToast = _useFrame.showToast,
17687 hideToast = _useFrame.hideToast;
17688
17689 var appBridge = useAppBridge();
17690 useDeepEffect(function () {
17691 var error = props.error,
17692 content = props.content,
17693 _props$duration = props.duration,
17694 duration = _props$duration === void 0 ? DEFAULT_TOAST_DURATION : _props$duration,
17695 onDismiss = props.onDismiss;
17696
17697 if (appBridge == null) {
17698 showToast(Object.assign({
17699 id
17700 }, props));
17701 } else {
17702 // eslint-disable-next-line no-console
17703 console.warn('Deprecation: Using `Toast` in an embedded app is deprecated and will be removed in v5.0. Use `Toast` from `@shopify/app-bridge-react` instead: https://help.shopify.com/en/api/embedded-apps/app-bridge/react-components/toast');
17704 appBridgeToast.current = Toast$2.create(appBridge, {
17705 message: content,
17706 duration,
17707 isError: error
17708 });
17709 appBridgeToast.current.subscribe(Toast$2.Action.CLEAR, onDismiss);
17710 appBridgeToast.current.dispatch(Toast$2.Action.SHOW);
17711 }
17712
17713 return function () {
17714 if (appBridge == null) {
17715 hideToast({
17716 id
17717 });
17718 } else if (appBridgeToast.current != null) {
17719 appBridgeToast.current.unsubscribe();
17720 }
17721 };
17722 }, [appBridge, props]);
17723 return null;
17724});
17725
17726var styles$1A = {
17727 "SearchDismissOverlay": "Polaris-TopBar-SearchDismissOverlay",
17728 "visible": "Polaris-TopBar-SearchDismissOverlay--visible",
17729 "fade-in": "Polaris-TopBar-SearchDismissOverlay__fade--in"
17730};
17731
17732function SearchDismissOverlay(_ref) {
17733 var onDismiss = _ref.onDismiss,
17734 visible = _ref.visible;
17735 var node = useRef(null);
17736 var handleDismiss = useCallback(function (_ref2) {
17737 var target = _ref2.target;
17738
17739 if (target === node.current && onDismiss != null) {
17740 onDismiss();
17741 }
17742 }, [onDismiss]);
17743 return React__default.createElement(React__default.Fragment, null, visible ? React__default.createElement(ScrollLock, null) : null, React__default.createElement("div", {
17744 ref: node,
17745 className: classNames(styles$1A.SearchDismissOverlay, visible && styles$1A.visible),
17746 onClick: handleDismiss
17747 }));
17748}
17749
17750var styles$1B = {
17751 "Search": "Polaris-TopBar-Search",
17752 "visible": "Polaris-TopBar-Search--visible",
17753 "Results": "Polaris-TopBar-Search__Results"
17754};
17755
17756function Search(_ref) {
17757 var visible = _ref.visible,
17758 children = _ref.children,
17759 onDismiss = _ref.onDismiss,
17760 _ref$overlayVisible = _ref.overlayVisible,
17761 overlayVisible = _ref$overlayVisible === void 0 ? false : _ref$overlayVisible;
17762
17763 if (children == null) {
17764 return null;
17765 }
17766
17767 var overlayMarkup = visible ? React__default.createElement(SearchDismissOverlay, {
17768 onDismiss: onDismiss,
17769 visible: overlayVisible
17770 }) : null;
17771 return React__default.createElement("div", {
17772 className: classNames(styles$1B.Search, visible && styles$1B.visible)
17773 }, overlayMarkup, React__default.createElement("div", {
17774 className: styles$1B.Results
17775 }, children));
17776}
17777
17778var styles$1C = {
17779 "SearchField": "Polaris-TopBar-SearchField",
17780 "SearchField-newDesignLanguage": "Polaris-TopBar-SearchField__SearchField--newDesignLanguage",
17781 "Backdrop": "Polaris-TopBar-SearchField__Backdrop",
17782 "Input": "Polaris-TopBar-SearchField__Input",
17783 "focused": "Polaris-TopBar-SearchField--focused",
17784 "Icon": "Polaris-TopBar-SearchField__Icon",
17785 "Clear": "Polaris-TopBar-SearchField__Clear",
17786 "toLightBackground": "Polaris-TopBar-SearchField--toLightBackground"
17787};
17788
17789function SearchField(_ref) {
17790 var value = _ref.value,
17791 focused = _ref.focused,
17792 active = _ref.active,
17793 placeholder = _ref.placeholder,
17794 onChange = _ref.onChange,
17795 onFocus = _ref.onFocus,
17796 onBlur = _ref.onBlur,
17797 onCancel = _ref.onCancel;
17798 var i18n = useI18n();
17799
17800 var _useState = useState(false),
17801 _useState2 = _slicedToArray(_useState, 2),
17802 forceActive = _useState2[0],
17803 setForceActive = _useState2[1];
17804
17805 var _useFeatures = useFeatures(),
17806 newDesignLanguage = _useFeatures.newDesignLanguage;
17807
17808 var input = useRef(null);
17809 var searchId = useUniqueId('SearchField');
17810 var handleChange = useCallback(function (_ref2) {
17811 var currentTarget = _ref2.currentTarget;
17812 onChange(currentTarget.value);
17813 }, [onChange]);
17814 var handleFocus = useCallback(function () {
17815 return onFocus && onFocus();
17816 }, [onFocus]);
17817 var handleBlur = useCallback(function () {
17818 return onBlur && onBlur();
17819 }, [onBlur]);
17820 var handleClear = useCallback(function () {
17821 onCancel && onCancel();
17822
17823 if (!input.current) {
17824 return;
17825 }
17826
17827 input.current.value = '';
17828 onChange('');
17829 input.current.focus();
17830 }, [onCancel, onChange]);
17831 useEffect(function () {
17832 if (!input.current) {
17833 return;
17834 }
17835
17836 if (focused) {
17837 input.current.focus();
17838 } else {
17839 input.current.blur();
17840 }
17841 }, [focused]);
17842 var clearMarkup = value !== '' && React__default.createElement("button", {
17843 type: "button",
17844 "aria-label": i18n.translate('Polaris.TopBar.SearchField.clearButtonLabel'),
17845 className: styles$1C.Clear,
17846 onClick: handleClear,
17847 onBlur: function onBlur() {
17848 setForceActive(false);
17849 handleClear();
17850 },
17851 onFocus: function onFocus() {
17852 handleFocus();
17853 setForceActive(true);
17854 }
17855 }, React__default.createElement(Icon, {
17856 source: CircleCancelMinor
17857 }));
17858 var className = classNames(styles$1C.SearchField, (focused || active || forceActive) && styles$1C.focused, newDesignLanguage && styles$1C['SearchField-newDesignLanguage']);
17859 return React__default.createElement("div", {
17860 className: className,
17861 onFocus: handleFocus,
17862 onBlur: handleBlur
17863 }, React__default.createElement(VisuallyHidden, null, React__default.createElement("label", {
17864 htmlFor: searchId
17865 }, i18n.translate('Polaris.TopBar.SearchField.search'))), React__default.createElement("input", {
17866 id: searchId,
17867 className: styles$1C.Input,
17868 placeholder: placeholder,
17869 type: "search",
17870 autoCapitalize: "off",
17871 autoComplete: "off",
17872 autoCorrect: "off",
17873 ref: input,
17874 value: value,
17875 onChange: handleChange,
17876 onKeyDown: preventDefault
17877 }), React__default.createElement("span", {
17878 className: styles$1C.Icon
17879 }, React__default.createElement(Icon, {
17880 source: SearchMinor
17881 })), clearMarkup, React__default.createElement("div", {
17882 className: styles$1C.Backdrop
17883 }));
17884}
17885
17886function preventDefault(event) {
17887 if (event.key === 'Enter') {
17888 event.preventDefault();
17889 }
17890}
17891
17892var styles$1D = {
17893 "MessageIndicatorWrapper": "Polaris-MessageIndicator__MessageIndicatorWrapper",
17894 "MessageIndicator": "Polaris-MessageIndicator"
17895};
17896
17897function MessageIndicator(_ref) {
17898 var children = _ref.children,
17899 active = _ref.active;
17900 var indicatorMarkup = active && React__default.createElement("div", {
17901 className: styles$1D.MessageIndicator
17902 });
17903 return React__default.createElement("div", {
17904 className: styles$1D.MessageIndicatorWrapper
17905 }, indicatorMarkup, children);
17906}
17907
17908var styles$1E = {
17909 "Section": "Polaris-Menu-Message__Section"
17910};
17911
17912function Message(_ref) {
17913 var title = _ref.title,
17914 description = _ref.description,
17915 action = _ref.action,
17916 link = _ref.link,
17917 badge = _ref.badge;
17918 var badgeMarkup = badge && React__default.createElement(Badge, {
17919 status: badge.status
17920 }, badge.content);
17921 var to = link.to,
17922 linkContent = link.content;
17923 var onClick = action.onClick,
17924 actionContent = action.content;
17925 return React__default.createElement("div", {
17926 className: styles$1E.Section
17927 }, React__default.createElement(Popover.Section, null, React__default.createElement(Stack, {
17928 vertical: true,
17929 spacing: "tight"
17930 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title, badgeMarkup), React__default.createElement("p", null, description)), React__default.createElement(Link, {
17931 url: to
17932 }, linkContent), React__default.createElement(Button, {
17933 plain: true,
17934 onClick: onClick
17935 }, actionContent))));
17936}
17937
17938var styles$1F = {
17939 "ActivatorWrapper": "Polaris-TopBar-Menu__ActivatorWrapper",
17940 "Activator": "Polaris-TopBar-Menu__Activator",
17941 "Section": "Polaris-TopBar-Menu__Section"
17942};
17943
17944function Menu(props) {
17945 var actions = props.actions,
17946 onOpen = props.onOpen,
17947 onClose = props.onClose,
17948 open = props.open,
17949 activatorContent = props.activatorContent,
17950 message = props.message;
17951 var badgeProps = message && message.badge && {
17952 content: message.badge.content,
17953 status: message.badge.status
17954 };
17955 var messageMarkup = message && React__default.createElement(Message, {
17956 title: message.title,
17957 description: message.description,
17958 action: {
17959 onClick: message.action.onClick,
17960 content: message.action.content
17961 },
17962 link: {
17963 to: message.link.to,
17964 content: message.link.content
17965 },
17966 badge: badgeProps
17967 });
17968 var isFullHeight = Boolean(message);
17969 return React__default.createElement(Popover, {
17970 activator: React__default.createElement("div", {
17971 className: styles$1F.ActivatorWrapper
17972 }, React__default.createElement("button", {
17973 type: "button",
17974 className: styles$1F.Activator,
17975 onClick: onOpen
17976 }, activatorContent)),
17977 active: open,
17978 onClose: onClose,
17979 fixed: true,
17980 fullHeight: isFullHeight,
17981 preferredAlignment: "right"
17982 }, React__default.createElement(ActionList, {
17983 onActionAnyItem: onClose,
17984 sections: actions
17985 }), messageMarkup);
17986}
17987
17988var styles$1G = {
17989 "Details": "Polaris-TopBar-UserMenu__Details",
17990 "Name": "Polaris-TopBar-UserMenu__Name",
17991 "Detail": "Polaris-TopBar-UserMenu__Detail"
17992};
17993
17994function UserMenu(_ref) {
17995 var name = _ref.name,
17996 detail = _ref.detail,
17997 avatar = _ref.avatar,
17998 initials = _ref.initials,
17999 actions = _ref.actions,
18000 message = _ref.message,
18001 onToggle = _ref.onToggle,
18002 open = _ref.open;
18003 var showIndicator = Boolean(message);
18004 var activatorContentMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(MessageIndicator, {
18005 active: showIndicator
18006 }, React__default.createElement(Avatar, {
18007 size: "small",
18008 source: avatar,
18009 initials: initials && initials.replace(' ', '')
18010 })), React__default.createElement("span", {
18011 className: styles$1G.Details
18012 }, React__default.createElement("p", {
18013 className: styles$1G.Name
18014 }, name), React__default.createElement("p", {
18015 className: styles$1G.Detail
18016 }, detail)));
18017 return React__default.createElement(Menu, {
18018 activatorContent: activatorContentMarkup,
18019 open: open,
18020 onOpen: onToggle,
18021 onClose: onToggle,
18022 actions: actions,
18023 message: message
18024 });
18025}
18026
18027var styles$1H = {
18028 "TopBar": "Polaris-TopBar",
18029 "TopBar-newDesignLanguage": "Polaris-TopBar__TopBar--newDesignLanguage",
18030 "isScrolled": "Polaris-TopBar--isScrolled",
18031 "LogoContainer": "Polaris-TopBar__LogoContainer",
18032 "Logo": "Polaris-TopBar__Logo",
18033 "LogoLink": "Polaris-TopBar__LogoLink",
18034 "ContextControl": "Polaris-TopBar__ContextControl",
18035 "NavigationIcon": "Polaris-TopBar__NavigationIcon",
18036 "focused": "Polaris-TopBar--focused",
18037 "Contents": "Polaris-TopBar__Contents",
18038 "SearchField": "Polaris-TopBar__SearchField",
18039 "SecondaryMenu": "Polaris-TopBar__SecondaryMenu"
18040};
18041
18042// subcomponents so explicitly state the subcomponents in the type definition.
18043// Letting this be implicit works in this project but fails in projects that use
18044// generated *.d.ts files.
18045
18046var TopBar = function TopBar(_ref) {
18047 var showNavigationToggle = _ref.showNavigationToggle,
18048 userMenu = _ref.userMenu,
18049 searchResults = _ref.searchResults,
18050 searchField = _ref.searchField,
18051 secondaryMenu = _ref.secondaryMenu,
18052 searchResultsVisible = _ref.searchResultsVisible,
18053 _ref$searchResultsOve = _ref.searchResultsOverlayVisible,
18054 searchResultsOverlayVisible = _ref$searchResultsOve === void 0 ? false : _ref$searchResultsOve,
18055 onNavigationToggle = _ref.onNavigationToggle,
18056 onSearchResultsDismiss = _ref.onSearchResultsDismiss,
18057 contextControl = _ref.contextControl;
18058 var i18n = useI18n();
18059
18060 var _useTheme = useTheme(),
18061 logo = _useTheme.logo;
18062
18063 var _useState = useState(false),
18064 _useState2 = _slicedToArray(_useState, 2),
18065 scrolled = _useState2[0],
18066 setScrolled = _useState2[1];
18067
18068 var _useFeatures = useFeatures(),
18069 newDesignLanguage = _useFeatures.newDesignLanguage;
18070
18071 var _useToggle = useToggle(false),
18072 focused = _useToggle.value,
18073 forceTrueFocused = _useToggle.setTrue,
18074 forceFalseFocused = _useToggle.setFalse;
18075
18076 var handleScroll = useCallback(debounce(function () {
18077 var scrollDistance = window.scrollY;
18078 var isScrolled = scrollDistance >= 1;
18079
18080 if (scrolled && isScrolled) {
18081 return;
18082 }
18083
18084 window.requestAnimationFrame(function () {
18085 return setScrolled(Boolean(isScrolled));
18086 });
18087 }, 20), []);
18088 var iconClassName = classNames(styles$1H.NavigationIcon, focused && styles$1H.focused);
18089 var navigationButtonMarkup = showNavigationToggle ? React__default.createElement("button", {
18090 type: "button",
18091 className: iconClassName,
18092 onClick: onNavigationToggle,
18093 onFocus: forceTrueFocused,
18094 onBlur: forceFalseFocused,
18095 "aria-label": i18n.translate('Polaris.TopBar.toggleMenuLabel')
18096 }, React__default.createElement(Icon, {
18097 source: MobileHamburgerMajorMonotone
18098 })) : null;
18099 var width = getWidth(logo, 104);
18100 var contextMarkup;
18101
18102 if (contextControl && !newDesignLanguage) {
18103 contextMarkup = React__default.createElement("div", {
18104 className: styles$1H.ContextControl
18105 }, contextControl);
18106 } else if (logo && !newDesignLanguage) {
18107 contextMarkup = React__default.createElement("div", {
18108 className: styles$1H.LogoContainer
18109 }, React__default.createElement(UnstyledLink, {
18110 url: logo.url || '',
18111 className: styles$1H.LogoLink,
18112 style: {
18113 width
18114 }
18115 }, React__default.createElement(Image, {
18116 source: logo.topBarSource || '',
18117 alt: logo.accessibilityLabel || '',
18118 className: styles$1H.Logo,
18119 style: {
18120 width
18121 }
18122 })));
18123 }
18124
18125 var searchMarkup = searchField ? React__default.createElement(React__default.Fragment, null, searchField, React__default.createElement(Search, {
18126 visible: searchResultsVisible,
18127 onDismiss: onSearchResultsDismiss,
18128 overlayVisible: searchResultsOverlayVisible
18129 }, searchResults)) : null;
18130 var scrollListenerMarkup = newDesignLanguage ? React__default.createElement(EventListener, {
18131 event: "scroll",
18132 handler: handleScroll,
18133 passive: true
18134 }) : null;
18135 var className = classNames(styles$1H.TopBar, newDesignLanguage && styles$1H['TopBar-newDesignLanguage'], scrolled && styles$1H.isScrolled);
18136 return React__default.createElement("div", {
18137 className: className
18138 }, navigationButtonMarkup, contextMarkup, React__default.createElement("div", {
18139 className: styles$1H.Contents
18140 }, React__default.createElement("div", {
18141 className: styles$1H.SearchField
18142 }, searchMarkup), React__default.createElement("div", {
18143 className: styles$1H.SecondaryMenu
18144 }, secondaryMenu), userMenu), scrollListenerMarkup);
18145};
18146TopBar.Menu = Menu;
18147TopBar.SearchField = SearchField;
18148TopBar.UserMenu = UserMenu;
18149
18150export { AccountConnection, ActionList, ActionMenu, AppBridgeContext, AppProvider, Autocomplete, Avatar, Backdrop, Badge, Banner, Breadcrumbs, Button, ButtonGroup, CalloutCard, Caption, Card, Checkbox$1 as Checkbox, ChoiceList, Collapsible, ColorPicker, Connected, ContextualSaveBar, DATA_ATTRIBUTE, DEFAULT_TOAST_DURATION, DEFAULT_TOAST_DURATION_WITH_ACTION, DataTable, DatePicker, DescriptionList, DisplayText, DropZone, EmptySearchResult, EmptyState, EventListener, ExceptionList, FilterType, Filters, Focus, FooterHelp, Form, FormLayout, Frame, Heading, Icon, Image, Indicator, InlineError, Key, KeyboardKey, KeypressListener, Label, Labelled, Layout, Link, List, Loading$1 as Loading, Modal, Navigation$1 as Navigation, OptionList, Page, PageActions, Pagination, PolarisTestProvider, Popover, PopoverCloseSource, Portal, ProgressBar, RadioButton, RangeSlider, ResourceItem, ResourceList, ResourcePicker, ScrollLock, Scrollable, Select, SettingToggle, Sheet, SkeletonBodyText, SkeletonDisplayText, SkeletonPage, SkeletonThumbnail, Spinner, Stack, Sticky, Subheading, Tabs, Tag, TextContainer, TextField, TextStyle, ThemeProvider, Thumbnail, Toast$1 as Toast, Tooltip, TopBar, TrapFocus, Truncate, TypeOf, Tokens as UNSTABLE_Tokens, toCssCustomPropertySyntax as UNSTABLE_toCssCustomPropertySyntax, UnstyledLink, VisuallyHidden, ScrollLockManagerContext as _SECRET_INTERNAL_SCROLL_LOCK_MANAGER_CONTEXT, WithinContentContext as _SECRET_INTERNAL_WITHIN_CONTENT_CONTEXT, buttonFrom, buttonsFrom, errorTextID, hsbToHex, hsbToRgb, hslToRgb, isNavigationItemActive, rgbString, rgbToHex, rgbToHsb, rgbToHsl, rgbaString };