UNPKG

701 kBJavaScriptView Raw
1import React__default, { useContext, useState, useEffect, useCallback, useRef, createRef, useMemo, useLayoutEffect, useImperativeHandle, createContext, memo, Fragment, createElement } from 'react';
2import tokens, { durationBase, durationSlow } from '@shopify/polaris-tokens';
3import { hsluvToHex, hexToHsluv } from 'hsluv';
4import isEqual from 'lodash/isEqual';
5import { clamp as clamp$1 } from '@shopify/javascript-utilities/math';
6import { __rest } from 'tslib';
7import { CaretDownMinor, HorizontalDotsMinor, TickSmallMinor, AlertMinor, CaretUpMinor, CircleCancelMinor, CancelSmallMinor, CircleTickMajorTwotone, CircleInformationMajorTwotone, CircleAlertMajorTwotone, CircleDisabledMajorTwotone, FlagMajorTwotone, ChevronLeftMinor, MinusMinor, ChevronRightMinor, ArrowLeftMinor, ArrowRightMinor, DragDropMajorMonotone, CircleAlertMajorMonotone, SearchMinor, ChevronUpMinor, ChevronDownMinor, QuestionMarkMajorTwotone, MobileCancelMajorMonotone, ExternalSmallMinor, ArrowUpDownMinor, CalendarMinor, EnableSelectionMinor, MobileHamburgerMajorMonotone } from '@shopify/polaris-icons';
8import { FOCUSABLE_SELECTOR, findFirstFocusableNode, focusFirstFocusableNode, focusLastFocusableNode } from '@shopify/javascript-utilities/focus';
9import debounce from 'lodash/debounce';
10import { addEventListener, removeEventListener } from '@shopify/javascript-utilities/events';
11import { closest, nodeContainsDescendant } from '@shopify/javascript-utilities/dom';
12import { getRectForNode, Rect } from '@shopify/javascript-utilities/geometry';
13import { createPortal } from 'react-dom';
14import { createUniqueIDFactory } from '@shopify/javascript-utilities/other';
15import { write, read } from '@shopify/javascript-utilities/fastdom';
16import createApp, { getShopOrigin, LifecycleHook } from '@shopify/app-bridge';
17import hoistStatics from 'hoist-non-react-statics';
18import { isSameDay, Months, Weekdays, getWeeksForMonth, isDateBefore, isDateAfter, dateIsSelected, dateIsInRange, getNewRange, getNextDisplayYear, getNextDisplayMonth, getPreviousDisplayYear, getPreviousDisplayMonth } from '@shopify/javascript-utilities/dates';
19export { Months } from '@shopify/javascript-utilities/dates';
20import { CSSTransition, TransitionGroup, Transition } from '@material-ui/react-transition-group';
21import { Redirect, ButtonGroup as ButtonGroup$1, Button as Button$1, Modal as Modal$2, Loading as Loading$2, TitleBar, ResourcePicker as ResourcePicker$2, Toast as Toast$2 } from '@shopify/app-bridge/actions';
22
23if (typeof window !== 'undefined') {
24 window.Polaris = window.Polaris || {};
25 window.Polaris.VERSION = '4.9.1';
26}
27
28var polarisVersion = '4.9.1';
29
30var ThemeContext = React__default.createContext(undefined);
31
32function _classCallCheck(instance, Constructor) {
33 if (!(instance instanceof Constructor)) {
34 throw new TypeError("Cannot call a class as a function");
35 }
36}
37
38function _defineProperties(target, props) {
39 for (var i = 0; i < props.length; i++) {
40 var descriptor = props[i];
41 descriptor.enumerable = descriptor.enumerable || false;
42 descriptor.configurable = true;
43 if ("value" in descriptor) descriptor.writable = true;
44 Object.defineProperty(target, descriptor.key, descriptor);
45 }
46}
47
48function _createClass(Constructor, protoProps, staticProps) {
49 if (protoProps) _defineProperties(Constructor.prototype, protoProps);
50 if (staticProps) _defineProperties(Constructor, staticProps);
51 return Constructor;
52}
53
54function _inherits(subClass, superClass) {
55 if (typeof superClass !== "function" && superClass !== null) {
56 throw new TypeError("Super expression must either be null or a function");
57 }
58
59 subClass.prototype = Object.create(superClass && superClass.prototype, {
60 constructor: {
61 value: subClass,
62 writable: true,
63 configurable: true
64 }
65 });
66 if (superClass) _setPrototypeOf(subClass, superClass);
67}
68
69function _getPrototypeOf(o) {
70 _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
71 return o.__proto__ || Object.getPrototypeOf(o);
72 };
73 return _getPrototypeOf(o);
74}
75
76function _setPrototypeOf(o, p) {
77 _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
78 o.__proto__ = p;
79 return o;
80 };
81
82 return _setPrototypeOf(o, p);
83}
84
85function isNativeReflectConstruct() {
86 if (typeof Reflect === "undefined" || !Reflect.construct) return false;
87 if (Reflect.construct.sham) return false;
88 if (typeof Proxy === "function") return true;
89
90 try {
91 Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
92 return true;
93 } catch (e) {
94 return false;
95 }
96}
97
98function _construct(Parent, args, Class) {
99 if (isNativeReflectConstruct()) {
100 _construct = Reflect.construct;
101 } else {
102 _construct = function _construct(Parent, args, Class) {
103 var a = [null];
104 a.push.apply(a, args);
105 var Constructor = Function.bind.apply(Parent, a);
106 var instance = new Constructor();
107 if (Class) _setPrototypeOf(instance, Class.prototype);
108 return instance;
109 };
110 }
111
112 return _construct.apply(null, arguments);
113}
114
115function _isNativeFunction(fn) {
116 return Function.toString.call(fn).indexOf("[native code]") !== -1;
117}
118
119function _wrapNativeSuper(Class) {
120 var _cache = typeof Map === "function" ? new Map() : undefined;
121
122 _wrapNativeSuper = function _wrapNativeSuper(Class) {
123 if (Class === null || !_isNativeFunction(Class)) return Class;
124
125 if (typeof Class !== "function") {
126 throw new TypeError("Super expression must either be null or a function");
127 }
128
129 if (typeof _cache !== "undefined") {
130 if (_cache.has(Class)) return _cache.get(Class);
131
132 _cache.set(Class, Wrapper);
133 }
134
135 function Wrapper() {
136 return _construct(Class, arguments, _getPrototypeOf(this).constructor);
137 }
138
139 Wrapper.prototype = Object.create(Class.prototype, {
140 constructor: {
141 value: Wrapper,
142 enumerable: false,
143 writable: true,
144 configurable: true
145 }
146 });
147 return _setPrototypeOf(Wrapper, Class);
148 };
149
150 return _wrapNativeSuper(Class);
151}
152
153function _assertThisInitialized(self) {
154 if (self === void 0) {
155 throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
156 }
157
158 return self;
159}
160
161function _possibleConstructorReturn(self, call) {
162 if (call && (typeof call === "object" || typeof call === "function")) {
163 return call;
164 }
165
166 return _assertThisInitialized(self);
167}
168
169function _slicedToArray(arr, i) {
170 return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest();
171}
172
173function _toConsumableArray(arr) {
174 return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();
175}
176
177function _arrayWithoutHoles(arr) {
178 if (Array.isArray(arr)) {
179 for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];
180
181 return arr2;
182 }
183}
184
185function _arrayWithHoles(arr) {
186 if (Array.isArray(arr)) return arr;
187}
188
189function _iterableToArray(iter) {
190 if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
191}
192
193function _iterableToArrayLimit(arr, i) {
194 if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) {
195 return;
196 }
197
198 var _arr = [];
199 var _n = true;
200 var _d = false;
201 var _e = undefined;
202
203 try {
204 for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
205 _arr.push(_s.value);
206
207 if (i && _arr.length === i) break;
208 }
209 } catch (err) {
210 _d = true;
211 _e = err;
212 } finally {
213 try {
214 if (!_n && _i["return"] != null) _i["return"]();
215 } finally {
216 if (_d) throw _e;
217 }
218 }
219
220 return _arr;
221}
222
223function _nonIterableSpread() {
224 throw new TypeError("Invalid attempt to spread non-iterable instance");
225}
226
227function _nonIterableRest() {
228 throw new TypeError("Invalid attempt to destructure non-iterable instance");
229}
230
231var MissingAppProviderError =
232/*#__PURE__*/
233function (_Error) {
234 _inherits(MissingAppProviderError, _Error);
235
236 function MissingAppProviderError() {
237 var _this;
238
239 var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
240
241 _classCallCheck(this, MissingAppProviderError);
242
243 _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.")));
244 _this.name = 'MissingAppProviderError';
245 return _this;
246 }
247
248 return MissingAppProviderError;
249}(_wrapNativeSuper(Error));
250
251function useTheme() {
252 var theme = useContext(ThemeContext);
253
254 if (!theme) {
255 throw new MissingAppProviderError('No Theme was provided.');
256 }
257
258 return theme;
259}
260
261// eslint-disable-next-line shopify/typescript/prefer-pascal-case-enums
262var UNSTABLE_Color;
263
264(function (UNSTABLE_Color) {
265 UNSTABLE_Color["Surface"] = "#FAFAFA";
266 UNSTABLE_Color["DarkSurface"] = "#111213";
267 UNSTABLE_Color["OnSurface"] = "#111213";
268 UNSTABLE_Color["Interactive"] = "#2E72D2";
269 UNSTABLE_Color["Neutral"] = "#111213";
270 UNSTABLE_Color["Primary"] = "#008060";
271 UNSTABLE_Color["Critical"] = "#D82C0D";
272 UNSTABLE_Color["Warning"] = "#FFC453";
273 UNSTABLE_Color["Highlight"] = "#5BCDDA";
274 UNSTABLE_Color["Success"] = "#008060";
275 UNSTABLE_Color["Decorative"] = "#FDC7CE";
276})(UNSTABLE_Color || (UNSTABLE_Color = {}));
277
278var roleVariants = {
279 surface: [{
280 name: 'surface',
281 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
282 light: {},
283 dark: {}
284 }, {
285 name: 'surfaceBackground',
286 description: 'For use in the background of our UIs as a background color, in components such as Page and Frame backgrounds.',
287 light: {
288 lightness: 98.3
289 },
290 dark: {
291 lightness: 3.3
292 }
293 }, {
294 name: 'surfaceForeground',
295 description: 'For use in the foreground of our UIs as a background color, in components such as Card, Modal, and Popover.',
296 light: {
297 lightness: 100
298 },
299 dark: {
300 lightness: 12.7
301 }
302 }, {
303 name: 'surfaceForegroundSubdued',
304 description: 'For use in the foreground of our UIs as a subdued background color, in components such as Card, Modal, and Popover.',
305 light: {
306 lightness: 98.3
307 },
308 dark: {
309 lightness: 10
310 }
311 }, {
312 name: 'surfaceHovered',
313 description: 'For use as a surface color on interactive elements such as resource list items and action list items when in a hovered state.',
314 light: {
315 lightness: 96
316 },
317 dark: {
318 lightness: 20
319 }
320 }, {
321 name: 'surfacePressed',
322 description: 'For use as a surface color on interactive elements such as resource list items and action list items when in a pressed state.',
323 light: {
324 lightness: 90
325 },
326 dark: {
327 lightness: 27
328 }
329 }, {
330 name: 'backdrop',
331 description: 'For use as the background color of the backdrop component for navigation and modal. This color has an alpha of `0.5`.',
332 light: {
333 hue: 0,
334 saturation: 0,
335 lightness: 0,
336 alpha: 0.5
337 },
338 dark: {
339 hue: 0,
340 saturation: 0,
341 lightness: 0,
342 alpha: 0.5
343 }
344 }, {
345 name: 'shadowFromAmbientLight',
346 description: 'For use in building shadows for popovers, cards, and modals. This color has an alpha of `0.05`.',
347 light: {
348 hue: 180,
349 saturation: 5,
350 lightness: 8,
351 alpha: 0.05
352 },
353 dark: {
354 hue: 180,
355 saturation: 5,
356 lightness: 8,
357 alpha: 0.05
358 }
359 }, {
360 name: 'shadowFromDirectLight',
361 description: 'For use in building shadows for popovers, cards, and modals. This color has an alpha of `0.15`.',
362 light: {
363 hue: 0,
364 saturation: 0,
365 lightness: 0,
366 alpha: 0.15
367 },
368 dark: {
369 hue: 0,
370 saturation: 0,
371 lightness: 0,
372 alpha: 0.15
373 }
374 }],
375 onSurface: [{
376 name: 'onSurface',
377 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
378 light: {},
379 dark: {}
380 }, {
381 name: 'borderOnSurface',
382 description: 'For use as a border (border or interactive outline).',
383 light: {
384 lightness: 75
385 },
386 dark: {
387 lightness: 35
388 }
389 }, {
390 name: 'borderDisabledOnSurface',
391 description: 'For use as a an interactive outline on disabled elements.',
392 light: {
393 lightness: 95
394 },
395 dark: {
396 lightness: 70
397 }
398 }, {
399 name: 'borderSubduedOnSurface',
400 description: 'For use as a subdued border (border or interactive outline).',
401 light: {
402 lightness: 85
403 },
404 dark: {
405 lightness: 32
406 }
407 }, {
408 name: 'iconOnSurface',
409 description: 'For use as the fill color of neutral icons.',
410 light: {
411 lightness: 40.1
412 },
413 dark: {
414 lightness: 70.1
415 }
416 }, {
417 name: 'iconDisabledOnSurface',
418 description: 'For use as the fill color of disabled neutral icons.',
419 light: {
420 lightness: 76.9
421 },
422 dark: {
423 lightness: 36.8
424 }
425 }, {
426 name: 'iconSubduedOnSurface',
427 description: 'For use as the fill color of subdued neutral icons.',
428 light: {
429 lightness: 59.8
430 },
431 dark: {
432 lightness: 52.1
433 }
434 }, {
435 name: 'textOnSurface',
436 description: 'For use as a neutral text color.',
437 light: {
438 lightness: 13.1
439 },
440 dark: {
441 lightness: 90.8
442 }
443 }, {
444 name: 'textDisabledOnSurface',
445 description: 'For use as a disabled neutral text color.',
446 light: {
447 lightness: 61.3
448 },
449 dark: {
450 lightness: 48.2
451 }
452 }, {
453 name: 'textSubduedOnSurface',
454 description: 'For use as a subdued neutral text color.',
455 light: {
456 lightness: 47.4
457 },
458 dark: {
459 lightness: 65.1
460 }
461 }],
462 interactive: [{
463 name: 'interactive',
464 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
465 light: {},
466 dark: {}
467 }, {
468 name: 'interactiveAction',
469 description: 'Used for links and plain buttons.',
470 light: {
471 lightness: 48.6
472 },
473 dark: {
474 lightness: 65,
475 saturation: 100,
476 hue: 247.6
477 }
478 }, {
479 name: 'interactiveActionDisabled',
480 description: 'Used for disabled links and plain buttons.',
481 light: {
482 lightness: 58
483 },
484 dark: {
485 lightness: 42
486 }
487 }, {
488 name: 'interactiveActionHovered',
489 description: 'Used for hovered links and plain buttons.',
490 light: {
491 lightness: 37
492 },
493 dark: {
494 lightness: 70,
495 saturation: 100,
496 hue: 247.6
497 }
498 }, {
499 name: 'interactiveActionSubdued',
500 description: 'Used for subdued links and plain buttons.',
501 light: {
502 lightness: 51
503 },
504 dark: {
505 lightness: 49
506 }
507 }, {
508 name: 'interactiveActionPressed',
509 description: 'Used for pressed links and plain buttons.',
510 light: {
511 lightness: 31
512 },
513 dark: {
514 lightness: 75,
515 saturation: 100,
516 hue: 247.6
517 }
518 }, {
519 name: 'interactiveFocus',
520 description: 'For use in the focus ring on interactive elements.',
521 light: {
522 lightness: 58
523 },
524 dark: {
525 lightness: 42
526 }
527 }, {
528 name: 'interactiveSelected',
529 description: 'For use as a surface color in selected interactive elements, in components such as option list and resource list.',
530 light: {
531 lightness: 96
532 },
533 dark: {
534 lightness: 4
535 }
536 }, {
537 name: 'interactiveSelectedHovered',
538 description: 'For use as a surface color in selected interactive elements that are hovered, in components such as option list and resource list.',
539 light: {
540 lightness: 89
541 },
542 dark: {
543 lightness: 11
544 }
545 }, {
546 name: 'interactiveSelectedPressed',
547 description: 'For use as a surface color in selected interactive elements that are pressed, in components such as option list and resource list.',
548 light: {
549 lightness: 82
550 },
551 dark: {
552 lightness: 18
553 }
554 }],
555 neutral: [{
556 name: 'neutral',
557 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
558 light: {},
559 dark: {}
560 }, {
561 name: 'neutralAction',
562 description: 'Used for secondary buttons and tertiary buttons, as well as in form elements as a background color and pontentially other neutral surfaces.',
563 light: {
564 lightness: 93
565 },
566 dark: {
567 lightness: 22
568 }
569 }, {
570 name: 'neutralActionDisabled',
571 description: 'Used as a disabled state for secondary buttons',
572 light: {
573 lightness: 94
574 },
575 dark: {
576 lightness: 13
577 }
578 }, {
579 name: 'neutralActionHovered',
580 description: 'Used as a hovered state for secondary buttons',
581 light: {
582 lightness: 90
583 },
584 dark: {
585 lightness: 37
586 }
587 }, {
588 name: 'neutralActionPressed',
589 description: 'Used as a pressed state for secondary buttons',
590 light: {
591 lightness: 87
592 },
593 dark: {
594 lightness: 42
595 }
596 }],
597 primary: [{
598 name: 'primary',
599 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
600 light: {},
601 dark: {}
602 }, {
603 name: 'primaryAction',
604 description: 'Used as the background color for primary actions, and as the fill color for icons and the text color in navigation and tabs to communicate interaction states.',
605 light: {
606 lightness: 47.3
607 },
608 dark: {
609 lightness: 47.3
610 }
611 }, {
612 name: 'primaryActionDisabled',
613 description: 'Used as the background color for disabled primary actions, and as the fill color for icons and the text color in navigation and tabs to communicate interaction states.',
614 light: {
615 lightness: 32
616 },
617 dark: {
618 lightness: 32
619 }
620 }, {
621 name: 'primaryActionHovered',
622 description: 'Used as the background color for hovered primary actions, and as the fill color for icons and the text color in navigation and tabs to communicate interaction states.',
623 light: {
624 lightness: 42.3
625 },
626 dark: {
627 lightness: 55
628 }
629 }, {
630 name: 'primaryActionPressed',
631 description: 'Used as the background color for pressed primary actions, and as the fill color for icons and the text color in navigation and tabs to communicate interaction states.',
632 light: {
633 lightness: 37.3
634 },
635 dark: {
636 lightness: 60
637 }
638 }, {
639 name: 'iconOnPrimary',
640 description: 'For use as a fill color for icons on primary actions. Not for use in icons on navigation and tabs.',
641 light: {
642 lightness: 98
643 },
644 dark: {
645 lightness: 98
646 }
647 }, {
648 name: 'textOnPrimary',
649 description: 'For use as a text color on primary actions. Not for use in text on navigation and tabs.',
650 light: {
651 lightness: 100
652 },
653 dark: {
654 lightness: 100
655 }
656 }, {
657 name: 'primarySelected',
658 description: 'Used as a surface color to indicate selected interactive states in navigation and tabs.',
659 light: {
660 lightness: 95,
661 saturation: 30
662 },
663 dark: {
664 lightness: 5,
665 saturation: 30
666 }
667 }, {
668 name: 'primarySelectedHovered',
669 description: 'Used as a surface color to indicate selected interactive states that are hovered in navigation and tabs.',
670 light: {
671 lightness: 81,
672 saturation: 22
673 },
674 dark: {
675 lightness: 19,
676 saturation: 22
677 }
678 }, {
679 name: 'primarySelectedPressed',
680 description: 'Used as a surface color to indicate selected interactive states that are pressed in navigation and tabs.',
681 light: {
682 lightness: 74,
683 saturation: 22
684 },
685 dark: {
686 lightness: 26,
687 saturation: 22
688 }
689 }],
690 critical: [{
691 name: 'critical',
692 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
693 light: {},
694 dark: {}
695 }, {
696 name: 'criticalBorder',
697 description: 'For use as a border on critical components such as banners, and as an outline on interactive elements in an error state.',
698 light: {
699 lightness: 50
700 },
701 dark: {
702 lightness: 50
703 }
704 }, {
705 name: 'criticalBorderDisabled',
706 description: 'For use as a disabled border on critical components such as banners, and as an outline on interactive elements in an error state.',
707 light: {
708 lightness: 82
709 },
710 dark: {
711 lightness: 28
712 }
713 }, {
714 name: 'criticalIcon',
715 description: 'For use as an icon fill color on top of critical elements.',
716 light: {
717 lightness: 52
718 },
719 dark: {
720 lightness: 48
721 }
722 }, {
723 name: 'criticalSurface',
724 description: 'For use as a surface color on critical elements including badges.',
725 light: {
726 lightness: 98.6
727 },
728 dark: {
729 lightness: 12
730 }
731 }, {
732 name: 'criticalSurfaceSubdued',
733 description: 'For use as a subdued surface color on critical elements including banners.',
734 light: {
735 lightness: 98
736 },
737 dark: {
738 lightness: 12
739 }
740 }, {
741 name: 'criticalSurfaceSubduedHovered',
742 description: 'For use as a surface color on critical interactive elements including action list items in a hovered state.',
743 light: {
744 lightness: 96
745 },
746 dark: {
747 lightness: 15,
748 saturation: 60
749 }
750 }, {
751 name: 'criticalSurfaceSubduedPressed',
752 description: 'For use as a surface color on critical interactive elements including action list items in a pressed state.',
753 light: {
754 lightness: 88
755 },
756 dark: {
757 lightness: 22
758 }
759 }, {
760 name: 'criticalText',
761 description: 'For use as a text color in inert critical elements such as exception list. Not for use as a text color on banners and badges.',
762 light: {
763 lightness: 47.3
764 },
765 dark: {
766 lightness: 65,
767 saturation: 70
768 }
769 }, {
770 name: 'criticalAction',
771 description: 'For use as the background color for destructive buttons, and as the background color for error toast messages.',
772 light: {
773 lightness: 47.5
774 },
775 dark: {
776 lightness: 45
777 }
778 }, {
779 name: 'criticalActionDisabled',
780 description: 'For use as the background color for disabled destructive buttons, and as the background color for error toast messages.',
781 light: {
782 lightness: 59
783 },
784 dark: {
785 lightness: 41
786 }
787 }, {
788 name: 'criticalActionHovered',
789 description: 'For use as the background color for hovered destructive buttons, and as the background color for error toast messages.',
790 light: {
791 lightness: 42.5
792 },
793 dark: {
794 lightness: 50
795 }
796 }, {
797 name: 'criticalActionPressed',
798 description: 'For use as the background color for pressed destructive buttons, and as the background color for error toast messages.',
799 light: {
800 lightness: 37.5
801 },
802 dark: {
803 lightness: 55
804 }
805 }, {
806 name: 'iconOnCritical',
807 description: 'For use as a fill color for icons on critical actions.',
808 light: {
809 lightness: 98
810 },
811 dark: {
812 lightness: 98
813 }
814 }, {
815 name: 'textOnCritical',
816 description: 'For use as a text color on critical actions.',
817 light: {
818 lightness: 100
819 },
820 dark: {
821 lightness: 100
822 }
823 }, {
824 name: 'criticalLink',
825 description: 'For use as a text color in destructive plain buttons, as well as a text color on destructive action list items. Not for use on critical banners and badges.',
826 light: {
827 lightness: 48.5
828 },
829 dark: {
830 lightness: 65
831 }
832 }, {
833 name: 'criticalLinkDisabled',
834 description: 'For use as a text color in disabled destructive plain buttons, as well as a text color on destructive action list items. Not for use on critical banners and badges.',
835 light: {
836 lightness: 72
837 },
838 dark: {
839 lightness: 78
840 }
841 }, {
842 name: 'criticalLinkHovered',
843 description: 'For use as a text color in hovered destructive plain buttons, as well as a text color on destructive action list items. Not for use on critical banners and badges.',
844 light: {
845 lightness: 45
846 },
847 dark: {
848 lightness: 70
849 }
850 }, {
851 name: 'criticalLinkPressed',
852 description: 'For use as a text color in pressed destructive plain buttons, as well as a text color on destructive action list items. Not for use on critical banners and badges.',
853 light: {
854 lightness: 21
855 },
856 dark: {
857 lightness: 75
858 }
859 }],
860 warning: [{
861 name: 'warning',
862 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
863 light: {},
864 dark: {}
865 }, {
866 name: 'warningBorder',
867 description: 'For use as a border on warning components such as banners.',
868 light: {
869 lightness: 76.6
870 },
871 dark: {
872 lightness: 50
873 }
874 }, {
875 name: 'warningIcon',
876 description: 'For use as an icon fill color on top of warning elements.',
877 light: {
878 lightness: 66
879 },
880 dark: {
881 lightness: 34
882 }
883 }, {
884 name: 'warningSurface',
885 description: 'For use as a surface color on warning elements including badges.',
886 light: {
887 lightness: 84.5
888 },
889 dark: {
890 lightness: 50
891 }
892 }, {
893 name: 'warningSurfaceSubdued',
894 description: 'For use as a subdued surface color on warning elements including banners.',
895 light: {
896 lightness: 96
897 },
898 dark: {
899 lightness: 26,
900 saturation: 71
901 }
902 }, {
903 name: 'warningText',
904 description: 'For use as a text color in inert critical elements such as exception list. Not for use as a text color on banners and badges.',
905 light: {
906 lightness: 47.4
907 },
908 dark: {
909 lightness: 64.9
910 }
911 }],
912 highlight: [{
913 name: 'highlight',
914 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
915 light: {},
916 dark: {}
917 }, {
918 name: 'highlightBorder',
919 description: 'For use as a border on informational components such as banners.',
920 light: {
921 lightness: 60
922 },
923 dark: {
924 lightness: 60
925 }
926 }, {
927 name: 'highlightIcon',
928 description: 'For use as an icon fill color on top of informational elements.',
929 light: {
930 lightness: 58
931 },
932 dark: {
933 lightness: 42
934 }
935 }, {
936 name: 'highlightSurface',
937 description: 'For use as a surface color on information elements including badges.',
938 light: {
939 lightness: 84.5,
940 saturation: 60
941 },
942 dark: {
943 lightness: 40,
944 saturation: 100
945 }
946 }, {
947 name: 'highlightSurfaceSubdued',
948 description: 'For use as a surface color on information elements including banners.',
949 light: {
950 lightness: 98.6
951 },
952 dark: {
953 lightness: 20
954 }
955 }, {
956 name: 'highlightext',
957 description: 'For use as a text color in inert informational elements. Not for use as a text color on banners and badges.',
958 light: {
959 lightness: 10
960 },
961 dark: {
962 lightness: 90
963 }
964 }],
965 success: [{
966 name: 'success',
967 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
968 light: {},
969 dark: {}
970 }, {
971 name: 'successBorder',
972 description: 'For use as a border on success components such as banners.',
973 light: {
974 lightness: 50
975 },
976 dark: {
977 lightness: 50
978 }
979 }, {
980 name: 'successIcon',
981 description: 'For use as an icon fill color on top of success elements.',
982 light: {
983 lightness: 25
984 },
985 dark: {
986 lightness: 35
987 }
988 }, {
989 name: 'successSurface',
990 description: 'For use as a surface color on success elements including badges.',
991 light: {
992 lightness: 84.5,
993 saturation: 60
994 },
995 dark: {
996 lightness: 35
997 }
998 }, {
999 name: 'successSurfaceSubdued',
1000 description: 'For use as a surface color on information elements including banners.',
1001 light: {
1002 lightness: 99,
1003 saturation: 60
1004 },
1005 dark: {
1006 lightness: 20,
1007 saturation: 60
1008 }
1009 }, {
1010 name: 'successText',
1011 description: 'For use as a text color in inert success elements. Not for use as a text color on banners and badges.',
1012 light: {
1013 lightness: 47.3
1014 },
1015 dark: {
1016 lightness: 65,
1017 saturation: 70
1018 }
1019 }],
1020 decorative: [{
1021 name: 'decorativeOneSurface',
1022 description: 'For use as a decorative surface color.',
1023 light: {
1024 hue: 56,
1025 saturation: 100,
1026 lightness: 84
1027 },
1028 dark: {
1029 hue: 54,
1030 saturation: 98,
1031 lightness: 46
1032 }
1033 }, {
1034 name: 'decorativeOneText',
1035 description: 'For use as a decorative text color that is applied on a decorative surface.',
1036 light: {
1037 hue: 52,
1038 saturation: 100,
1039 lightness: 18
1040 },
1041 dark: {
1042 lightness: 100
1043 }
1044 }, {
1045 name: 'decorativeTwoSurface',
1046 description: 'For use as a decorative surface color.',
1047 light: {
1048 hue: 30,
1049 saturation: 100,
1050 lightness: 84
1051 },
1052 dark: {
1053 hue: 24,
1054 saturation: 96,
1055 lightness: 52
1056 }
1057 }, {
1058 name: 'decorativeTwoText',
1059 description: 'For use as a decorative text color that is applied on a decorative surface.',
1060 light: {
1061 hue: 362,
1062 saturation: 80,
1063 lightness: 14
1064 },
1065 dark: {
1066 lightness: 100
1067 }
1068 }, {
1069 name: 'decorativeThreeSurface',
1070 description: 'For use as a decorative surface color.',
1071 light: {
1072 hue: 144,
1073 saturation: 54,
1074 lightness: 84
1075 },
1076 dark: {
1077 hue: 154,
1078 saturation: 100,
1079 lightness: 46
1080 }
1081 }, {
1082 name: 'decorativeThreeText',
1083 description: 'For use as a decorative text color that is applied on a decorative surface.',
1084 light: {
1085 hue: 144,
1086 saturation: 100,
1087 lightness: 16
1088 },
1089 dark: {
1090 lightness: 100
1091 }
1092 }, {
1093 name: 'decorativeFourSurface',
1094 description: 'For use as a decorative surface color.',
1095 light: {
1096 hue: 180,
1097 saturation: 56,
1098 lightness: 84
1099 },
1100 dark: {
1101 hue: 188,
1102 saturation: 95,
1103 lightness: 47
1104 }
1105 }, {
1106 name: 'decorativeFourText',
1107 description: 'For use as a decorative text color that is applied on a decorative surface.',
1108 light: {
1109 hue: 190,
1110 saturation: 100,
1111 lightness: 16
1112 },
1113 dark: {
1114 lightness: 100
1115 }
1116 }, {
1117 name: 'decorativeFiveSurface',
1118 description: 'For use as a decorative surface color.',
1119 light: {},
1120 dark: {
1121 hue: 363,
1122 saturation: 77,
1123 lightness: 45
1124 }
1125 }, {
1126 name: 'decorativeFiveText',
1127 description: 'For use as a decorative text color that is applied on a decorative surface.',
1128 light: {
1129 hue: 363,
1130 saturation: 78,
1131 lightness: 16
1132 },
1133 dark: {
1134 lightness: 100
1135 }
1136 }]
1137};
1138
1139function compose() {
1140 for (var _len = arguments.length, fns = new Array(_len), _key = 0; _key < _len; _key++) {
1141 fns[_key] = arguments[_key];
1142 }
1143
1144 return fns.reduce(function (func, group) {
1145 return function () {
1146 return func(group.apply(void 0, arguments));
1147 };
1148 });
1149}
1150
1151function rgbString(color) {
1152 var red = color.red,
1153 green = color.green,
1154 blue = color.blue;
1155
1156 if (Object.prototype.hasOwnProperty.call(color, 'alpha')) {
1157 return "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(color.alpha, ")");
1158 } else {
1159 return "rgb(".concat(red, ", ").concat(green, ", ").concat(blue, ")");
1160 }
1161}
1162var rgbaString = rgbString;
1163function rgbToHex(_ref) {
1164 var red = _ref.red,
1165 green = _ref.green,
1166 blue = _ref.blue;
1167 return "#".concat(componentToHex(red)).concat(componentToHex(green)).concat(componentToHex(blue));
1168}
1169
1170function componentToHex(component) {
1171 var hex = component.toString(16);
1172 return hex.length === 1 ? "0".concat(hex) : hex;
1173}
1174
1175function hsbToHex(color) {
1176 return rgbToHex(hsbToRgb(color));
1177}
1178
1179function rgbFromHueAndChroma(hue, chroma) {
1180 var huePrime = hue / 60;
1181 var hueDelta = 1 - Math.abs(huePrime % 2 - 1);
1182 var intermediateValue = chroma * hueDelta;
1183 var red = 0;
1184 var green = 0;
1185 var blue = 0;
1186
1187 if (huePrime >= 0 && huePrime <= 1) {
1188 red = chroma;
1189 green = intermediateValue;
1190 blue = 0;
1191 }
1192
1193 if (huePrime >= 1 && huePrime <= 2) {
1194 red = intermediateValue;
1195 green = chroma;
1196 blue = 0;
1197 }
1198
1199 if (huePrime >= 2 && huePrime <= 3) {
1200 red = 0;
1201 green = chroma;
1202 blue = intermediateValue;
1203 }
1204
1205 if (huePrime >= 3 && huePrime <= 4) {
1206 red = 0;
1207 green = intermediateValue;
1208 blue = chroma;
1209 }
1210
1211 if (huePrime >= 4 && huePrime <= 5) {
1212 red = intermediateValue;
1213 green = 0;
1214 blue = chroma;
1215 }
1216
1217 if (huePrime >= 5 && huePrime <= 6) {
1218 red = chroma;
1219 green = 0;
1220 blue = intermediateValue;
1221 }
1222
1223 return {
1224 red,
1225 green,
1226 blue
1227 };
1228}
1229
1230function hsbToRgb(color) {
1231 var hue = color.hue,
1232 saturation = color.saturation,
1233 brightness = color.brightness,
1234 _color$alpha = color.alpha,
1235 alpha = _color$alpha === void 0 ? 1 : _color$alpha;
1236 var chroma = brightness * saturation;
1237
1238 var _rgbFromHueAndChroma = rgbFromHueAndChroma(hue, chroma),
1239 red = _rgbFromHueAndChroma.red,
1240 green = _rgbFromHueAndChroma.green,
1241 blue = _rgbFromHueAndChroma.blue;
1242
1243 var chromaBrightnessDelta = brightness - chroma;
1244 red += chromaBrightnessDelta;
1245 green += chromaBrightnessDelta;
1246 blue += chromaBrightnessDelta;
1247 return {
1248 red: Math.round(red * 255),
1249 green: Math.round(green * 255),
1250 blue: Math.round(blue * 255),
1251 alpha
1252 };
1253}
1254function hslToRgb(color) {
1255 var hue = color.hue,
1256 saturation = color.saturation,
1257 lightness = color.lightness,
1258 _color$alpha2 = color.alpha,
1259 alpha = _color$alpha2 === void 0 ? 1 : _color$alpha2;
1260 var chroma = (1 - Math.abs(2 * (lightness / 100) - 1)) * (saturation / 100);
1261
1262 var _rgbFromHueAndChroma2 = rgbFromHueAndChroma(hue, chroma),
1263 red = _rgbFromHueAndChroma2.red,
1264 green = _rgbFromHueAndChroma2.green,
1265 blue = _rgbFromHueAndChroma2.blue;
1266
1267 var lightnessVal = lightness / 100 - chroma / 2;
1268 red += lightnessVal;
1269 green += lightnessVal;
1270 blue += lightnessVal;
1271 return {
1272 red: Math.round(red * 255),
1273 green: Math.round(green * 255),
1274 blue: Math.round(blue * 255),
1275 alpha
1276 };
1277} // ref https://en.wikipedia.org/wiki/HSL_and_HSV
1278
1279function rgbToHsbl(color) {
1280 var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'b';
1281 var r = color.red,
1282 g = color.green,
1283 b = color.blue,
1284 _color$alpha3 = color.alpha,
1285 alpha = _color$alpha3 === void 0 ? 1 : _color$alpha3;
1286 var red = r / 255;
1287 var green = g / 255;
1288 var blue = b / 255;
1289 var largestComponent = Math.max(red, green, blue);
1290 var smallestComponent = Math.min(red, green, blue);
1291 var delta = largestComponent - smallestComponent;
1292 var lightness = (largestComponent + smallestComponent) / 2;
1293 var saturation = 0;
1294
1295 if (largestComponent === 0) {
1296 saturation = 0;
1297 } else if (type === 'b') {
1298 saturation = delta / largestComponent;
1299 } else if (type === 'l') {
1300 var baseSaturation = lightness > 0.5 ? delta / (2 - largestComponent - smallestComponent) : delta / (largestComponent + smallestComponent);
1301 saturation = isNaN(baseSaturation) ? 0 : baseSaturation;
1302 }
1303
1304 var huePercentage = 0;
1305
1306 switch (largestComponent) {
1307 case red:
1308 huePercentage = (green - blue) / delta + (green < blue ? 6 : 0);
1309 break;
1310
1311 case green:
1312 huePercentage = (blue - red) / delta + 2;
1313 break;
1314
1315 case blue:
1316 huePercentage = (red - green) / delta + 4;
1317 }
1318
1319 var hue = Math.round(huePercentage / 6 * 360);
1320 return {
1321 hue: clamp$1(hue, 0, 360) || 0,
1322 saturation: parseFloat(clamp$1(saturation, 0, 1).toFixed(2)),
1323 brightness: parseFloat(clamp$1(largestComponent, 0, 1).toFixed(2)),
1324 lightness: parseFloat(lightness.toFixed(2)),
1325 alpha: parseFloat(alpha.toFixed(2))
1326 };
1327}
1328
1329function rgbToHsb(color) {
1330 var _rgbToHsbl = rgbToHsbl(color, 'b'),
1331 hue = _rgbToHsbl.hue,
1332 saturation = _rgbToHsbl.saturation,
1333 brightness = _rgbToHsbl.brightness,
1334 _rgbToHsbl$alpha = _rgbToHsbl.alpha,
1335 alpha = _rgbToHsbl$alpha === void 0 ? 1 : _rgbToHsbl$alpha;
1336
1337 return {
1338 hue,
1339 saturation,
1340 brightness,
1341 alpha
1342 };
1343}
1344function rgbToHsl(color) {
1345 var _rgbToHsbl2 = rgbToHsbl(color, 'l'),
1346 hue = _rgbToHsbl2.hue,
1347 rawSaturation = _rgbToHsbl2.saturation,
1348 rawLightness = _rgbToHsbl2.lightness,
1349 _rgbToHsbl2$alpha = _rgbToHsbl2.alpha,
1350 alpha = _rgbToHsbl2$alpha === void 0 ? 1 : _rgbToHsbl2$alpha;
1351
1352 var saturation = rawSaturation * 100;
1353 var lightness = rawLightness * 100;
1354 return {
1355 hue,
1356 saturation,
1357 lightness,
1358 alpha
1359 };
1360}
1361function hexToRgb(color) {
1362 if (color.length === 4) {
1363 var repeatHex = function repeatHex(hex1, hex2) {
1364 return color.slice(hex1, hex2).repeat(2);
1365 };
1366
1367 var _red = parseInt(repeatHex(1, 2), 16);
1368
1369 var _green = parseInt(repeatHex(2, 3), 16);
1370
1371 var _blue = parseInt(repeatHex(3, 4), 16);
1372
1373 return {
1374 red: _red,
1375 green: _green,
1376 blue: _blue
1377 };
1378 }
1379
1380 var red = parseInt(color.slice(1, 3), 16);
1381 var green = parseInt(color.slice(3, 5), 16);
1382 var blue = parseInt(color.slice(5, 7), 16);
1383 return {
1384 red,
1385 green,
1386 blue
1387 };
1388}
1389var ColorType;
1390
1391(function (ColorType) {
1392 ColorType["Hex"] = "hex";
1393 ColorType["Rgb"] = "rgb";
1394 ColorType["Rgba"] = "rgba";
1395 ColorType["Hsl"] = "hsl";
1396 ColorType["Hsla"] = "hsla";
1397 ColorType["Default"] = "default";
1398})(ColorType || (ColorType = {}));
1399
1400function getColorType(color) {
1401 if (color.includes('#')) {
1402 return ColorType.Hex;
1403 } else if (color.includes('rgb')) {
1404 return ColorType.Rgb;
1405 } else if (color.includes('rgba')) {
1406 return ColorType.Rgba;
1407 } else if (color.includes('hsl')) {
1408 return ColorType.Hsl;
1409 } else if (color.includes('hsla')) {
1410 return ColorType.Hsla;
1411 } else {
1412 if (process.env.NODE_ENV === 'development') {
1413 /* eslint-disable-next-line no-console */
1414 console.warn('Accepted colors formats are: hex, rgb, rgba, hsl and hsla');
1415 }
1416
1417 return ColorType.Default;
1418 }
1419}
1420
1421function hslToString(hslColor) {
1422 if (typeof hslColor === 'string') {
1423 return hslColor;
1424 }
1425
1426 var _hslColor$alpha = hslColor.alpha,
1427 alpha = _hslColor$alpha === void 0 ? 1 : _hslColor$alpha,
1428 hue = hslColor.hue,
1429 lightness = hslColor.lightness,
1430 saturation = hslColor.saturation;
1431 return "hsla(".concat(hue, ", ").concat(saturation, "%, ").concat(lightness, "%, ").concat(alpha, ")");
1432}
1433
1434function rgbToObject(color) {
1435 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1436 var colorMatch = color.match(/\(([^)]+)\)/);
1437
1438 if (!colorMatch) {
1439 return {
1440 red: 0,
1441 green: 0,
1442 blue: 0,
1443 alpha: 0
1444 };
1445 }
1446
1447 var _colorMatch$1$split = colorMatch[1].split(','),
1448 _colorMatch$1$split2 = _slicedToArray(_colorMatch$1$split, 4),
1449 red = _colorMatch$1$split2[0],
1450 green = _colorMatch$1$split2[1],
1451 blue = _colorMatch$1$split2[2],
1452 alpha = _colorMatch$1$split2[3];
1453
1454 var objColor = {
1455 red: parseInt(red, 10),
1456 green: parseInt(green, 10),
1457 blue: parseInt(blue, 10),
1458 alpha: parseInt(alpha, 10) || 1
1459 };
1460 return objColor;
1461}
1462
1463var hexToHsla = compose(rgbToHsl, hexToRgb);
1464var rbgStringToHsla = compose(rgbToHsl, rgbToObject);
1465
1466function hslToObject(color) {
1467 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1468 var colorMatch = color.match(/\(([^)]+)\)/);
1469
1470 if (!colorMatch) {
1471 return {
1472 hue: 0,
1473 saturation: 0,
1474 lightness: 0,
1475 alpha: 0
1476 };
1477 }
1478
1479 var _colorMatch$1$split3 = colorMatch[1].split(','),
1480 _colorMatch$1$split4 = _slicedToArray(_colorMatch$1$split3, 4),
1481 hue = _colorMatch$1$split4[0],
1482 saturation = _colorMatch$1$split4[1],
1483 lightness = _colorMatch$1$split4[2],
1484 alpha = _colorMatch$1$split4[3];
1485
1486 var objColor = {
1487 hue: parseInt(hue, 10),
1488 saturation: parseInt(saturation, 10),
1489 lightness: parseInt(lightness, 10),
1490 alpha: parseFloat(alpha) || 1
1491 };
1492 return objColor;
1493}
1494
1495function colorToHsla(color) {
1496 var type = getColorType(color);
1497
1498 switch (type) {
1499 case ColorType.Hex:
1500 return hexToHsla(color);
1501
1502 case ColorType.Rgb:
1503 case ColorType.Rgba:
1504 return rbgStringToHsla(color);
1505
1506 case ColorType.Hsla:
1507 case ColorType.Hsl:
1508 return hslToObject(color);
1509
1510 case ColorType.Default:
1511 default:
1512 throw new Error('Accepted color formats are: hex, rgb, rgba, hsl and hsla');
1513 }
1514}
1515
1516// implements: https://www.w3.org/WAI/ER/WD-AERT/#color-contrast
1517function isLight(_ref) {
1518 var red = _ref.red,
1519 green = _ref.green,
1520 blue = _ref.blue;
1521 var contrast = (red * 299 + green * 587 + blue * 114) / 1000;
1522 return contrast > 125;
1523}
1524
1525function normalizeName(name) {
1526 return name.split(/(?=[A-Z])/).join('-').toLowerCase();
1527}
1528function constructColorName(baseName, property, suffix) {
1529 var name = normalizeName(baseName);
1530 var propertyName = property ? "-".concat(normalizeName(property)) : '';
1531 var constructedSuffix = suffix ? "-".concat(suffix) : '';
1532 return "--".concat(name).concat(propertyName).concat(constructedSuffix);
1533}
1534
1535function lightenColor(color) {
1536 var lighten = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1537
1538 if (typeof color === 'string') {
1539 return color;
1540 }
1541
1542 var lightness = color.lightness;
1543 var nextLightness = lightness + lighten;
1544 return Object.assign({}, color, {
1545 lightness: clamp$1(nextLightness, 0, 100)
1546 });
1547}
1548function saturateColor(color) {
1549 var saturate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1550
1551 if (typeof color === 'string') {
1552 return color;
1553 }
1554
1555 var saturation = color.saturation;
1556 var nextSaturation = saturation + saturate;
1557 return Object.assign({}, color, {
1558 saturation: nextSaturation
1559 });
1560}
1561function createLightColor(color, lightness, saturation) {
1562 var lightenedColor = lightenColor(color, lightness);
1563 var saturatedColor = saturateColor(lightenedColor, -saturation);
1564 return saturatedColor;
1565}
1566
1567var needsVariantList = ['topBar'];
1568
1569var BorderRadius = {
1570 borderRadiusBase: rem('4px'),
1571 borderRadiusWide: rem('8px')
1572};
1573var Shadow = {
1574 cardShadow: '0px 0px 5px var(--p-shadow-from-ambient-light), 0px 1px 2px var(--p-shadow-from-direct-light)',
1575 popoverShadow: '-1px 0px 20px var(--p-shadow-from-ambient-light), 0px 1px 5px var(--p-shadow-from-direct-light)',
1576 modalShadow: '0px 6px 32px var(--p-shadow-from-ambient-light), 0px 1px 6px var(--p-shadow-from-direct-light)'
1577};
1578var Overrides = {
1579 overrideNone: 'none',
1580 overrideTransparent: 'transparent',
1581 overrideOne: '1',
1582 overrideVisible: 'visible',
1583 overrideZero: '0',
1584 overrideLoadingZIndex: '514',
1585 buttonFontWeight: '500',
1586 nonNullContent: "''",
1587 bannerDefaultBorder: buildBannerBorder('--p-border-on-surface'),
1588 bannerSuccessBorder: buildBannerBorder('--p-success-border'),
1589 bannerHighlightBorder: buildBannerBorder('--p-highlight-border'),
1590 bannerWarningBorder: buildBannerBorder('--p-warning-border'),
1591 bannerCriticalBorder: buildBannerBorder('--p-critical-border'),
1592 badgeMixBlendMode: 'luminosity',
1593 borderSubdued: "".concat(rem('1px'), " solid var(--p-border-subdued-on-surface)"),
1594 textFieldSpinnerOffset: rem('2px'),
1595 textFieldFocusRingOffset: rem('-4px'),
1596 textFieldFocusRingBorderRadius: rem('7px'),
1597 buttonGroupItemSpacing: rem('2px')
1598};
1599var Tokens = Object.assign({}, BorderRadius, Shadow, Overrides);
1600
1601function rem(px) {
1602 var baseFontSize = 10;
1603 return "".concat(parseInt(px, 10) / baseFontSize, "rem");
1604}
1605
1606function buildBannerBorder(cssVar) {
1607 return "inset 0 ".concat(rem('2px'), " 0 0 var(").concat(cssVar, "), inset 0 0 0 ").concat(rem('2px'), " var(").concat(cssVar, ")");
1608}
1609
1610function buildCustomProperties(themeConfig, globalTheming) {
1611 return globalTheming ? customPropertyTransformer(Object.assign({}, buildColors(themeConfig, roleVariants), Tokens)) : buildLegacyColors(themeConfig);
1612}
1613function buildThemeContext(themeConfig, cssCustomProperties) {
1614 var logo = themeConfig.logo;
1615 return {
1616 logo,
1617 UNSTABLE_cssCustomProperties: toString(cssCustomProperties)
1618 };
1619}
1620
1621function toString(obj) {
1622 if (obj) {
1623 return Object.entries(obj).map(function (pair) {
1624 return pair.join(':');
1625 }).join(';');
1626 } else {
1627 return undefined;
1628 }
1629}
1630
1631function hexToHsluvObj(hex) {
1632 var _hexToHsluv = hexToHsluv(hex),
1633 _hexToHsluv2 = _slicedToArray(_hexToHsluv, 3),
1634 hue = _hexToHsluv2[0],
1635 saturation = _hexToHsluv2[1],
1636 lightness = _hexToHsluv2[2];
1637
1638 return {
1639 hue,
1640 saturation,
1641 lightness
1642 };
1643}
1644
1645function buildColors(theme, roleVariants) {
1646 var colors = Object.assign({
1647 surface: UNSTABLE_Color.Surface,
1648 onSurface: UNSTABLE_Color.OnSurface,
1649 interactive: UNSTABLE_Color.Interactive,
1650 neutral: UNSTABLE_Color.Neutral,
1651 primary: UNSTABLE_Color.Primary,
1652 critical: UNSTABLE_Color.Critical,
1653 warning: UNSTABLE_Color.Warning,
1654 highlight: UNSTABLE_Color.Highlight,
1655 success: UNSTABLE_Color.Success,
1656 decorative: UNSTABLE_Color.Decorative
1657 }, theme.UNSTABLE_colors);
1658 var lightSurface = isLight(hexToRgb(colors.surface));
1659 return Object.entries(roleVariants).reduce(function (acc1, _ref) {
1660 var _ref2 = _slicedToArray(_ref, 2),
1661 role = _ref2[0],
1662 variants = _ref2[1];
1663
1664 var base = hexToHsluvObj(colors[role]);
1665 return Object.assign({}, acc1, variants.reduce(function (acc2, _ref3) {
1666 var name = _ref3.name,
1667 light = _ref3.light,
1668 dark = _ref3.dark;
1669 var configs = {
1670 default: lightSurface ? light : dark
1671 };
1672
1673 if (!isEqual(light, dark)) {
1674 configs.Inverse = lightSurface ? dark : light;
1675 configs.Light = light;
1676 configs.Dark = dark;
1677 }
1678
1679 return Object.assign({}, acc2, Object.entries(configs).reduce(function (acc3, _ref4) {
1680 var _ref5 = _slicedToArray(_ref4, 2),
1681 variant = _ref5[0],
1682 config = _ref5[1];
1683
1684 var _config$hue = config.hue,
1685 hue = _config$hue === void 0 ? base.hue : _config$hue,
1686 _config$saturation = config.saturation,
1687 saturation = _config$saturation === void 0 ? base.saturation : _config$saturation,
1688 _config$lightness = config.lightness,
1689 lightness = _config$lightness === void 0 ? base.lightness : _config$lightness,
1690 _config$alpha = config.alpha,
1691 alpha = _config$alpha === void 0 ? 1 : _config$alpha;
1692 var displayName = variant === 'default' ? name : "".concat(name).concat(variant);
1693 return Object.assign({}, acc3, {
1694 [displayName]: hslToString(Object.assign({}, colorToHsla(hsluvToHex([hue, saturation, lightness])), {
1695 alpha
1696 }))
1697 });
1698 }, {}));
1699 }, {}));
1700 }, {});
1701}
1702
1703function customPropertyTransformer(properties) {
1704 return Object.entries(properties).reduce(function (transformed, _ref6) {
1705 var _ref7 = _slicedToArray(_ref6, 2),
1706 key = _ref7[0],
1707 value = _ref7[1];
1708
1709 return Object.assign({}, transformed, {
1710 [toCssCustomPropertySyntax(key)]: value
1711 });
1712 }, {});
1713}
1714
1715function toCssCustomPropertySyntax(camelCase) {
1716 return "--p-".concat(camelCase.replace(/([A-Z0-9])/g, '-$1').toLowerCase());
1717}
1718
1719function buildLegacyColors(theme) {
1720 var colorPairs;
1721 var colors = theme && theme.colors && theme.colors.topBar ? theme.colors.topBar : {
1722 background: '#00848e',
1723 backgroundLighter: '#1d9ba4',
1724 color: '#f9fafb'
1725 };
1726 var colorKey = 'topBar';
1727 var colorKeys = Object.keys(colors);
1728
1729 if (colorKeys.length > 1) {
1730 colorPairs = colorKeys.map(function (key) {
1731 return [constructColorName(colorKey, key), colors[key]];
1732 });
1733 } else {
1734 colorPairs = parseColors([colorKey, colors]);
1735 }
1736
1737 return colorPairs.reduce(function (state, _ref8) {
1738 var _ref9 = _slicedToArray(_ref8, 2),
1739 key = _ref9[0],
1740 value = _ref9[1];
1741
1742 return Object.assign({}, state, {
1743 [key]: value
1744 });
1745 }, {});
1746}
1747
1748function needsVariant(name) {
1749 return needsVariantList.includes(name);
1750}
1751var lightenToString = compose(hslToString, createLightColor);
1752function setTextColor(name) {
1753 var variant = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'dark';
1754
1755 if (variant === 'light') {
1756 return [name, tokens.colorInk];
1757 }
1758
1759 return [name, tokens.colorWhite];
1760}
1761function setTheme(color, baseName, key, variant) {
1762 var colorPairs = [];
1763
1764 switch (variant) {
1765 case 'light':
1766 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'light'));
1767 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 7, -10)]);
1768 break;
1769
1770 case 'dark':
1771 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'dark'));
1772 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 15, 15)]);
1773 break;
1774
1775 default:
1776 }
1777
1778 return colorPairs;
1779}
1780
1781function parseColors(_ref10) {
1782 var _ref11 = _slicedToArray(_ref10, 2),
1783 baseName = _ref11[0],
1784 colors = _ref11[1];
1785
1786 var keys = Object.keys(colors);
1787 var colorPairs = [];
1788
1789 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
1790 var key = _keys[_i];
1791 colorPairs.push([constructColorName(baseName, key), colors[key]]);
1792
1793 if (needsVariant(baseName)) {
1794 var hslColor = colorToHsla(colors[key]);
1795
1796 if (typeof hslColor === 'string') {
1797 return colorPairs;
1798 }
1799
1800 var rgbColor = hslToRgb(hslColor);
1801
1802 if (isLight(rgbColor)) {
1803 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'light')));
1804 } else {
1805 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'dark')));
1806 }
1807 }
1808 }
1809
1810 return colorPairs;
1811}
1812
1813var Key;
1814
1815(function (Key) {
1816 Key[Key["Backspace"] = 8] = "Backspace";
1817 Key[Key["Tab"] = 9] = "Tab";
1818 Key[Key["Enter"] = 13] = "Enter";
1819 Key[Key["Shift"] = 16] = "Shift";
1820 Key[Key["Ctrl"] = 17] = "Ctrl";
1821 Key[Key["Alt"] = 18] = "Alt";
1822 Key[Key["Pause"] = 19] = "Pause";
1823 Key[Key["CapsLock"] = 20] = "CapsLock";
1824 Key[Key["Escape"] = 27] = "Escape";
1825 Key[Key["Space"] = 32] = "Space";
1826 Key[Key["PageUp"] = 33] = "PageUp";
1827 Key[Key["PageDown"] = 34] = "PageDown";
1828 Key[Key["End"] = 35] = "End";
1829 Key[Key["Home"] = 36] = "Home";
1830 Key[Key["LeftArrow"] = 37] = "LeftArrow";
1831 Key[Key["UpArrow"] = 38] = "UpArrow";
1832 Key[Key["RightArrow"] = 39] = "RightArrow";
1833 Key[Key["DownArrow"] = 40] = "DownArrow";
1834 Key[Key["Insert"] = 45] = "Insert";
1835 Key[Key["Delete"] = 46] = "Delete";
1836 Key[Key["Key0"] = 48] = "Key0";
1837 Key[Key["Key1"] = 49] = "Key1";
1838 Key[Key["Key2"] = 50] = "Key2";
1839 Key[Key["Key3"] = 51] = "Key3";
1840 Key[Key["Key4"] = 52] = "Key4";
1841 Key[Key["Key5"] = 53] = "Key5";
1842 Key[Key["Key6"] = 54] = "Key6";
1843 Key[Key["Key7"] = 55] = "Key7";
1844 Key[Key["Key8"] = 56] = "Key8";
1845 Key[Key["Key9"] = 57] = "Key9";
1846 Key[Key["KeyA"] = 65] = "KeyA";
1847 Key[Key["KeyB"] = 66] = "KeyB";
1848 Key[Key["KeyC"] = 67] = "KeyC";
1849 Key[Key["KeyD"] = 68] = "KeyD";
1850 Key[Key["KeyE"] = 69] = "KeyE";
1851 Key[Key["KeyF"] = 70] = "KeyF";
1852 Key[Key["KeyG"] = 71] = "KeyG";
1853 Key[Key["KeyH"] = 72] = "KeyH";
1854 Key[Key["KeyI"] = 73] = "KeyI";
1855 Key[Key["KeyJ"] = 74] = "KeyJ";
1856 Key[Key["KeyK"] = 75] = "KeyK";
1857 Key[Key["KeyL"] = 76] = "KeyL";
1858 Key[Key["KeyM"] = 77] = "KeyM";
1859 Key[Key["KeyN"] = 78] = "KeyN";
1860 Key[Key["KeyO"] = 79] = "KeyO";
1861 Key[Key["KeyP"] = 80] = "KeyP";
1862 Key[Key["KeyQ"] = 81] = "KeyQ";
1863 Key[Key["KeyR"] = 82] = "KeyR";
1864 Key[Key["KeyS"] = 83] = "KeyS";
1865 Key[Key["KeyT"] = 84] = "KeyT";
1866 Key[Key["KeyU"] = 85] = "KeyU";
1867 Key[Key["KeyV"] = 86] = "KeyV";
1868 Key[Key["KeyW"] = 87] = "KeyW";
1869 Key[Key["KeyX"] = 88] = "KeyX";
1870 Key[Key["KeyY"] = 89] = "KeyY";
1871 Key[Key["KeyZ"] = 90] = "KeyZ";
1872 Key[Key["LeftMeta"] = 91] = "LeftMeta";
1873 Key[Key["RightMeta"] = 92] = "RightMeta";
1874 Key[Key["Select"] = 93] = "Select";
1875 Key[Key["Numpad0"] = 96] = "Numpad0";
1876 Key[Key["Numpad1"] = 97] = "Numpad1";
1877 Key[Key["Numpad2"] = 98] = "Numpad2";
1878 Key[Key["Numpad3"] = 99] = "Numpad3";
1879 Key[Key["Numpad4"] = 100] = "Numpad4";
1880 Key[Key["Numpad5"] = 101] = "Numpad5";
1881 Key[Key["Numpad6"] = 102] = "Numpad6";
1882 Key[Key["Numpad7"] = 103] = "Numpad7";
1883 Key[Key["Numpad8"] = 104] = "Numpad8";
1884 Key[Key["Numpad9"] = 105] = "Numpad9";
1885 Key[Key["Multiply"] = 106] = "Multiply";
1886 Key[Key["Add"] = 107] = "Add";
1887 Key[Key["Subtract"] = 109] = "Subtract";
1888 Key[Key["Decimal"] = 110] = "Decimal";
1889 Key[Key["Divide"] = 111] = "Divide";
1890 Key[Key["F1"] = 112] = "F1";
1891 Key[Key["F2"] = 113] = "F2";
1892 Key[Key["F3"] = 114] = "F3";
1893 Key[Key["F4"] = 115] = "F4";
1894 Key[Key["F5"] = 116] = "F5";
1895 Key[Key["F6"] = 117] = "F6";
1896 Key[Key["F7"] = 118] = "F7";
1897 Key[Key["F8"] = 119] = "F8";
1898 Key[Key["F9"] = 120] = "F9";
1899 Key[Key["F10"] = 121] = "F10";
1900 Key[Key["F11"] = 122] = "F11";
1901 Key[Key["F12"] = 123] = "F12";
1902 Key[Key["NumLock"] = 144] = "NumLock";
1903 Key[Key["ScrollLock"] = 145] = "ScrollLock";
1904 Key[Key["Semicolon"] = 186] = "Semicolon";
1905 Key[Key["Equals"] = 187] = "Equals";
1906 Key[Key["Comma"] = 188] = "Comma";
1907 Key[Key["Dash"] = 189] = "Dash";
1908 Key[Key["Period"] = 190] = "Period";
1909 Key[Key["ForwardSlash"] = 191] = "ForwardSlash";
1910 Key[Key["GraveAccent"] = 192] = "GraveAccent";
1911 Key[Key["OpenBracket"] = 219] = "OpenBracket";
1912 Key[Key["BackSlash"] = 220] = "BackSlash";
1913 Key[Key["CloseBracket"] = 221] = "CloseBracket";
1914 Key[Key["SingleQuote"] = 222] = "SingleQuote";
1915})(Key || (Key = {}));
1916
1917var TypeOf;
1918
1919(function (TypeOf) {
1920 TypeOf["Undefined"] = "undefined";
1921 TypeOf["Object"] = "object";
1922 TypeOf["Boolean"] = "boolean";
1923 TypeOf["Number"] = "number";
1924 TypeOf["String"] = "string";
1925 TypeOf["Symbol"] = "symbol";
1926 TypeOf["Function"] = "function";
1927})(TypeOf || (TypeOf = {}));
1928
1929function classNames() {
1930 for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) {
1931 classes[_key] = arguments[_key];
1932 }
1933
1934 return classes.filter(Boolean).join(' ');
1935}
1936function variationName(name, value) {
1937 return "".concat(name).concat(value.charAt(0).toUpperCase()).concat(value.slice(1));
1938}
1939
1940var FeaturesContext = React__default.createContext(undefined);
1941
1942function useFeatures() {
1943 var features = useContext(FeaturesContext);
1944
1945 if (!features) {
1946 throw new Error('No Features were provided.');
1947 }
1948
1949 return features;
1950}
1951
1952var I18nContext = React__default.createContext(undefined);
1953
1954function useI18n() {
1955 var i18n = useContext(I18nContext);
1956
1957 if (!i18n) {
1958 throw new MissingAppProviderError('No i18n was provided.');
1959 }
1960
1961 return i18n;
1962}
1963
1964var OBJECT_NOTATION_MATCHER = /\[(.*?)\]|(\w+)/g;
1965function get(obj, keypath, defaultValue) {
1966 if (obj == null) return undefined;
1967 var keys = Array.isArray(keypath) ? keypath : getKeypath(keypath);
1968 var acc = obj; // eslint-disable-next-line @typescript-eslint/prefer-for-of
1969
1970 for (var i = 0; i < keys.length; i++) {
1971 var val = acc[keys[i]];
1972 if (val === undefined) return defaultValue;
1973 acc = val;
1974 }
1975
1976 return acc;
1977}
1978
1979function getKeypath(str) {
1980 var path = [];
1981 var result;
1982
1983 while (result = OBJECT_NOTATION_MATCHER.exec(str)) {
1984 var _result = result,
1985 _result2 = _slicedToArray(_result, 3),
1986 first = _result2[1],
1987 second = _result2[2];
1988
1989 path.push(first || second);
1990 }
1991
1992 return path;
1993}
1994
1995function merge() {
1996 var final = {};
1997
1998 for (var _len = arguments.length, objs = new Array(_len), _key = 0; _key < _len; _key++) {
1999 objs[_key] = arguments[_key];
2000 }
2001
2002 for (var _i = 0, _objs = objs; _i < _objs.length; _i++) {
2003 var obj = _objs[_i];
2004 final = mergeRecursively(final, obj);
2005 }
2006
2007 return final;
2008}
2009
2010function mergeRecursively(inputObjA, objB) {
2011 var objA = Array.isArray(inputObjA) ? _toConsumableArray(inputObjA) : Object.assign({}, inputObjA);
2012
2013 for (var key in objB) {
2014 if (!Object.prototype.hasOwnProperty.call(objB, key)) {
2015 continue;
2016 } else if (isMergeableValue(objB[key]) && isMergeableValue(objA[key])) {
2017 objA[key] = mergeRecursively(objA[key], objB[key]);
2018 } else {
2019 objA[key] = objB[key];
2020 }
2021 }
2022
2023 return objA;
2024}
2025
2026function isMergeableValue(value) {
2027 return value !== null && typeof value === 'object';
2028}
2029
2030var REPLACE_REGEX = /{([^}]*)}/g;
2031var I18n =
2032/*#__PURE__*/
2033function () {
2034 function I18n(translation) {
2035 var _this = this;
2036
2037 _classCallCheck(this, I18n);
2038
2039 this.translation = translation;
2040
2041 this.translate = function (id, replacements) {
2042 return translate(id, _this.translation, replacements);
2043 };
2044
2045 this.setTranslation(translation);
2046 }
2047
2048 _createClass(I18n, [{
2049 key: "setTranslation",
2050 value: function setTranslation(translation) {
2051 this.translation = Array.isArray(translation) ? merge.apply(void 0, _toConsumableArray(translation)) : translation;
2052 }
2053 }, {
2054 key: "translationKeyExists",
2055 value: function translationKeyExists(path) {
2056 return Boolean(get(this.translation, path));
2057 }
2058 }]);
2059
2060 return I18n;
2061}();
2062function translate(id, translations, replacements) {
2063 var text = get(translations, id);
2064
2065 if (!text) {
2066 return '';
2067 }
2068
2069 if (replacements) {
2070 return text.replace(REPLACE_REGEX, function (match) {
2071 var replacement = match.substring(1, match.length - 1);
2072
2073 if (!Object.prototype.hasOwnProperty.call(replacements, replacement)) {
2074 throw new Error("No replacement found for key '".concat(replacement, "'. The following replacements were passed: ").concat(Object.keys(replacements).map(function (key) {
2075 return "'".concat(key, "'");
2076 }).join(', ')));
2077 }
2078
2079 return replacements[replacement];
2080 });
2081 }
2082
2083 return text;
2084}
2085
2086var isServer = typeof window === 'undefined' || typeof document === 'undefined';
2087
2088function Image(_a) {
2089 var sourceSet = _a.sourceSet,
2090 source = _a.source,
2091 crossOrigin = _a.crossOrigin,
2092 rest = __rest(_a, ["sourceSet", "source", "crossOrigin"]);
2093
2094 var finalSourceSet = sourceSet ? sourceSet.map(function (_ref) {
2095 var subSource = _ref.source,
2096 descriptor = _ref.descriptor;
2097 return "".concat(subSource, " ").concat(descriptor);
2098 }).join(',') : null;
2099 return finalSourceSet ? // eslint-disable-next-line jsx-a11y/alt-text
2100 React__default.createElement("img", Object.assign({
2101 src: source,
2102 srcSet: finalSourceSet,
2103 crossOrigin: crossOrigin
2104 }, rest)) : // eslint-disable-next-line jsx-a11y/alt-text
2105 React__default.createElement("img", Object.assign({
2106 src: source
2107 }, rest, {
2108 crossOrigin: crossOrigin
2109 }));
2110}
2111
2112var styles = {
2113 "Avatar": "Polaris-Avatar",
2114 "hidden": "Polaris-Avatar--hidden",
2115 "sizeSmall": "Polaris-Avatar--sizeSmall",
2116 "sizeMedium": "Polaris-Avatar--sizeMedium",
2117 "sizeLarge": "Polaris-Avatar--sizeLarge",
2118 "styleOne": "Polaris-Avatar--styleOne",
2119 "styleTwo": "Polaris-Avatar--styleTwo",
2120 "styleThree": "Polaris-Avatar--styleThree",
2121 "styleFour": "Polaris-Avatar--styleFour",
2122 "styleFive": "Polaris-Avatar--styleFive",
2123 "styleSix": "Polaris-Avatar--styleSix",
2124 "hasImage": "Polaris-Avatar--hasImage",
2125 "Image": "Polaris-Avatar__Image",
2126 "Initials": "Polaris-Avatar__Initials",
2127 "Svg": "Polaris-Avatar__Svg"
2128};
2129
2130var avatar1 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjMjQ1YjQ4IiBkPSJNMCAwaDEwMHYxMDBIMHoiLz48cGF0aCBmaWxsPSIjMmRiMTY3IiBkPSJNNjkgMHY2NS42NWwtMi0uMDF2MTkuODVsMiAuMDJWMTAwSDBWMGg2OXoiLz48cGF0aCBmaWxsPSIjZmZmIiBkPSJNNjcgNjUuNjR2MTkuODVsLTI1LjU3LS4xOUMzMiA4NS4yMiAyNS42IDgxLjQ2IDI1LjY4IDcyLjA2cy4yNS02Ljc0LjI1LTYuNzR6Ii8+PHBhdGggZmlsbD0iIzhkYzk1OCIgZD0iTTg2Ljk5IDU4SDY5VjBoMTAuOTNsNy4wNiA1OHoiLz48cGF0aCBmaWxsPSIjZWJlZGYxIiBkPSJNMjQuNTMgNDAuMjlhMTIuMjMgMTIuMjMgMCAwMTI0LjQ2IDAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZmlsbD0iIzhkYzk1OCIgZD0iTTU5LjYyIDU4QTEwLjY5IDEwLjY5IDAgMDE4MSA1OHoiLz48L3N2Zz4K';
2131
2132var avatar2 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjMWUyNjVjIiBkPSJNLS4wMSAwaDEwMHYxMDBoLTEwMHoiLz48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNLS4wMSAwaDY5LjAydjEwMEgtLjAxeiIvPjxwYXRoIGZpbGw9IiNmZmYiIGQ9Ik02OC45MyA2NS44OGwtMjQuNDQtLjE5LS4wNSA2LjA5YzAgNS4yMiAzLjQ4IDkuNDcgOC42OSA5LjUybDE1LjguMTJ6Ii8+PHBhdGggZmlsbD0iI2ZmYzA0ZCIgZD0iTTY4LjkxIDExLjNsMTkuMTcgNDYuMjktMTkuMTctLjE2VjExLjN6Ii8+PHBhdGggZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIGQ9Ik0yMy4yNSAzNi40M2EzLjIyIDMuMjIgMCAxMDAgNi40NG0yMS4wMS02LjQ0YTMuMjIgMy4yMiAwIDAwMCA2LjQ0bS0xMy41NSAzLjc0YTMuMjIgMy4yMiAwIDEwMCA2LjQ0bTMuMjItMjUuNTFhMy4yMiAzLjIyIDAgMDAwIDYuNDQiLz48L3N2Zz4K';
2133
2134var avatar3 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNLS4wMiAwaDEwMHYxMDBoLTEwMHoiLz48cGF0aCBmaWxsPSIjNmRjYWNlIiBkPSJNLjM5IDBoNjkuMDJ2MTAwSC4zOXoiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik0yNC4xOCAzMS4yMXYzLjQ3QTEwLjQzIDEwLjQzIDAgMDAzNC40IDQ1LjIxYTEwLjQzIDEwLjQzIDAgMDAxMC4yMi0xMC41M3YtMy40NyIvPjxwYXRoIGZpbGw9IiNlYmVkZjEiIGQ9Ik0yMC4xMSA0OS4wN2ExNi4yMiAxNi4yMiAwIDExMCAzMi40NCIgb3BhY2l0eT0iLjIiLz48cGF0aCBkPSJNNjkuNDQgMTguODNMOTAgNzFINjkuNDRWMTguODN6IiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTU3LjU5IDcxYTYgNiAwIDAxMTIgMHoiIGZpbGw9IiNmZmYiLz48L3N2Zz4K';
2135
2136var avatar4 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjZmZlMGMzIiBkPSJNMC0uMDFoMTAwdjEwMEgweiIvPjxwYXRoIGZpbGw9IiM1ZDZjYzEiIGQ9Ik0wIDBoNjkuMDJ2MTAwSDB6Ii8+PHBhdGggZD0iTTY5LjAyIDBsMjQuMDMgNjEuNjlINjkuMDJWMHoiIGZpbGw9IiNmZjk2N2QiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik0zMC42OSAzMS45MXYtM2MwLTQuNzggMy40Ni04LjY1IDgtOC42NXM4IDMuODcgOCA4LjY1djMiLz48cGF0aCBmaWxsPSIjZWJlZGYxIiBkPSJNMTIuNzYgNTYuMDZhMTMuMzYgMTMuMzYgMCAxMTI2LjcyIDAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZD0iTTgwIDYxLjQ2bC0yOS4zNC4yM3YtNy4zM2MwLTYuMjggNC4wNy0xMS4zNiAxMC4zNC0xMS40NGwxOS0uMTR6IiBmaWxsPSIjZmY5NjdkIi8+PC9zdmc+Cg==';
2137
2138var avatar5 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjOGRjOTU4IiBkPSJNMCAwaDcwLjAydjEwMEgweiIvPjxwYXRoIGQ9Ik02OS45MiAwdjU2LjMyTDQ5IDY3bC0uMyAyNS4wN1YxMDBIMTAwVjB6IiBmaWxsPSIjMmRiMTY3Ii8+PHBhdGggZmlsbD0iIzI0NWI0OCIgZD0iTTU5LjI3IDU4LjI5YTUuMjIgNS4yMiAwIDAwLTkuNDMgNC40OCIvPjxwYXRoIGQ9Ik0yNy4xMiA5LjMzaDQ0LjUzdjIuMTlIMjcuMTJ6bS0xMi40MSA5LjQ5aDU2Ljk0djIuMTlIMTQuNzF6IiBmaWxsPSIjMmRiMTY3Ii8+PGNpcmNsZSBjeD0iMTkuNjYiIGN5PSI0NC44IiByPSIxMS4yMiIgZmlsbD0iI2ViZWRmMSIgb3BhY2l0eT0iLjIiLz48L3N2Zz4K';
2139
2140var avatar6 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNLS4wMi0uMDFoMTAwdjEwMGgtMTAweiIgZmlsbD0iI2ZmZTBjMyIvPjxwYXRoIGZpbGw9IiNmZjk2N2QiIGQ9Ik0wIDBoNjkuNDF2MTAwSDB6Ii8+PHBhdGggZD0iTTY5LjkyIDB2NDQuMzJMNTEuMzQgNTV2NDVIMTAwVjB6IiBmaWxsPSIjZmZlMGMzIi8+PHBhdGggZmlsbD0iIzMyY2FjNiIgZD0iTTM5LjMyIDc2YTExLjg1IDExLjg1IDAgMDAxMiAxMS42MlY3NiIvPjxwYXRoIGZpbGw9IiMwMDk3OTYiIGQ9Ik0zOS4zMiA3NmExMiAxMiAwIDAxMTItMTEuODJWNzYiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik00My43NCAxOS44M2ExMi44MiAxMi44MiAwIDExLTI1LjY0IDAiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjQiIGQ9Ik0yNy4zOSAzMS42bC0xLjU4IDUuOTZtOS4zNy01LjcybDIuNTUgNS40N200LjI2LTkuODVsMy41MyA0LjVtLTI1LjQzLTQuNWwtMy41MyA0LjUiLz48L3N2Zz4K';
2141
2142var avatar7 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNMCAwaDEwMHYxMDAuNDhIMHoiIGZpbGw9IiM4ZGM5NTgiLz48cGF0aCBmaWxsPSIjMmRiMTY3IiBkPSJNODMgNjh2MzJsLTE0LS4xNnYuMTZIMFYwaDY5djY4aDE0eiIvPjxwYXRoIGQ9Ik02OS4yOSA0MS42OUgyMC42NnMtLjA5LTMtLjE3IDcuMTUgNyAxOC41MSAxNy4zNSAxOC41OWwzMS40NS41N3oiIGZpbGw9IiM4ZGM5NTgiLz48cGF0aCBkPSJNNjguNyAxMi40bDExLjU0IDI5LjI5SDY4LjdWMTIuNHoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNNjIuMjIgNDEuNjlhMy4zNCAzLjM0IDAgMTE2LjY5IDB6IiBmaWxsPSIjZmZmIi8+PHBhdGggZmlsbD0iIzI0NWI0OCIgZD0iTTQxLjQ1IDE4LjA2YTIuNTcgMi41NyAwIDAwLTUuMTQgME0zMy4zMyAyNGEyLjU3IDIuNTcgMCAxMC01LjE0IDBtMjAuMzYgMi41OGEyLjU3IDIuNTcgMCAxMC01LjE0IDAiLz48L3N2Zz4K';
2143
2144var avatar8 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjZmZlZGI5IiBkPSJNMCAwaDEwMHYxMDBIMHoiLz48cGF0aCBkPSJNNjQuNjMgMTcuMzNhMTcgMTcgMCAwMTUgMjkuNzIgMTYuNzUgMTYuNzUgMCAwMS01IDIuNjIiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiLz48cGF0aCBmaWxsPSIjZmZjMDRkIiBkPSJNMCAwaDY5LjAydjEwMEgweiIvPjxjaXJjbGUgY3g9IjQ1LjExIiBjeT0iMzMuNDkiIHI9IjE2Ljk4IiBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1taXRlcmxpbWl0PSIxMCIgc3Ryb2tlLXdpZHRoPSI1IiB0cmFuc2Zvcm09InJvdGF0ZSgtMzcuMDIgNDUuMTI0IDMzLjQ5MykiLz48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNNjkuMDIgMzQuNDhsMTkuNDcgMzguNzQtMTkuNDcgMS41M1YzNC40OHoiLz48cGF0aCBkPSJNNjEuNiAzMy42N2ExMC4xNyAxMC4xNyAwIDAxMTUuNC4wOCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHN0cm9rZS13aWR0aD0iNSIvPjwvc3ZnPgo=';
2145
2146var avatar9 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNMCAwaDEwMHYxMDBIMHoiIGZpbGw9IiNmZmMwNGQiLz48cGF0aCBkPSJNMCAwaDY5LjQxdjEwMEgweiIgZmlsbD0iIzVkNmNjMSIvPjxwYXRoIGQ9Ik03MC4yMSA4MC44OGgtMTUuMWMtNC44MSAwLTUuNjgtNS44NC01LjY4LTUuODRoMjAuNzgiIGZpbGw9IiNmZmMwNGQiLz48cGF0aCBkPSJNODIgNjAuNDhsLTE0IC4yNVYwaDEwLjE3QzgwLjU5IDIwLjE0IDgyIDYwLjQ4IDgyIDYwLjQ4eiIgZmlsbD0iIzVkNmNjMSIvPjxwYXRoIGZpbGw9IiM0MTIzNmUiIGQ9Ik01Ny43MSA2MC40OGE1LjQ0IDUuNDQgMCAxMTEwLjg3IDAiLz48Y2lyY2xlIGN4PSIyNC43NyIgY3k9IjQwLjE5IiByPSIxMS4yMiIgZmlsbD0iI2ViZWRmMSIgb3BhY2l0eT0iLjIiLz48L3N2Zz4K';
2147
2148
2149
2150var avatars = /*#__PURE__*/Object.freeze({
2151 avatarOne: avatar1,
2152 avatarTwo: avatar2,
2153 avatarThree: avatar3,
2154 avatarFour: avatar4,
2155 avatarFive: avatar5,
2156 avatarSix: avatar6,
2157 avatarSeven: avatar7,
2158 avatarEight: avatar8,
2159 avatarNine: avatar9
2160});
2161
2162var Status;
2163
2164(function (Status) {
2165 Status["Pending"] = "PENDING";
2166 Status["Loaded"] = "LOADED";
2167 Status["Errored"] = "ERRORED";
2168})(Status || (Status = {}));
2169
2170var STYLE_CLASSES = ['one', 'two', 'three', 'four', 'five'];
2171var AVATAR_IMAGES = Object.keys(avatars).map( // import/namespace does not allow computed values by default
2172// eslint-disable-next-line import/namespace
2173function (key) {
2174 return avatars[key];
2175});
2176function Avatar(_ref) {
2177 var name = _ref.name,
2178 source = _ref.source,
2179 initials = _ref.initials,
2180 customer = _ref.customer,
2181 _ref$size = _ref.size,
2182 size = _ref$size === void 0 ? 'medium' : _ref$size,
2183 accessibilityLabel = _ref.accessibilityLabel;
2184 var i18n = useI18n();
2185
2186 var _useFeatures = useFeatures(),
2187 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
2188 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
2189
2190 function styleClass(name) {
2191 var finalStyleClasses = unstableGlobalTheming ? STYLE_CLASSES : [].concat(STYLE_CLASSES, ['six']);
2192 return name ? finalStyleClasses[name.charCodeAt(0) % finalStyleClasses.length] : finalStyleClasses[0];
2193 }
2194
2195 var _useState = useState(Status.Pending),
2196 _useState2 = _slicedToArray(_useState, 2),
2197 status = _useState2[0],
2198 setStatus = _useState2[1]; // If the source changes, set the status back to pending
2199
2200
2201 useEffect(function () {
2202 setStatus(Status.Pending);
2203 }, [source]);
2204 var handleError = useCallback(function () {
2205 setStatus(Status.Errored);
2206 }, []);
2207 var handleLoad = useCallback(function () {
2208 setStatus(Status.Loaded);
2209 }, []);
2210 var hasImage = (source || customer) && status !== Status.Errored;
2211 var nameString = name || initials;
2212 var finalSource;
2213 var label;
2214
2215 if (accessibilityLabel) {
2216 label = accessibilityLabel;
2217 } else if (name) {
2218 label = name;
2219 } else if (initials) {
2220 var splitInitials = initials.split('').join(' ');
2221 label = i18n.translate('Polaris.Avatar.labelWithInitials', {
2222 initials: splitInitials
2223 });
2224 } else {
2225 label = i18n.translate('Polaris.Avatar.label');
2226 }
2227
2228 if (source) {
2229 finalSource = source;
2230 } else if (customer) {
2231 finalSource = customerPlaceholder(nameString);
2232 }
2233
2234 var className = classNames(styles.Avatar, styles[variationName('style', styleClass(nameString))], size && styles[variationName('size', size)], hasImage && status !== Status.Loaded && styles.hidden, hasImage && styles.hasImage);
2235 var imageMarkUp = finalSource && !isServer && status !== Status.Errored ? React__default.createElement(Image, {
2236 className: styles.Image,
2237 source: finalSource,
2238 alt: "",
2239 role: "presentation",
2240 onLoad: handleLoad,
2241 onError: handleError
2242 }) : null; // Use `dominant-baseline: central` instead of `dy` when Edge supports it.
2243
2244 var verticalOffset = '0.35em';
2245 var initialsMarkup = initials && !hasImage ? React__default.createElement("span", {
2246 className: styles.Initials
2247 }, React__default.createElement("svg", {
2248 className: styles.Svg,
2249 viewBox: "0 0 48 48"
2250 }, React__default.createElement("text", {
2251 x: "50%",
2252 y: "50%",
2253 dy: verticalOffset,
2254 fill: "currentColor",
2255 fontSize: "26",
2256 textAnchor: "middle"
2257 }, initials))) : null;
2258 return React__default.createElement("span", {
2259 "aria-label": label,
2260 role: "img",
2261 className: className
2262 }, initialsMarkup, imageMarkUp);
2263}
2264
2265function customerPlaceholder(name) {
2266 return name ? AVATAR_IMAGES[name.charCodeAt(0) % AVATAR_IMAGES.length] : AVATAR_IMAGES[0];
2267}
2268
2269function isElementInViewport(element) {
2270 var _element$getBoundingC = element.getBoundingClientRect(),
2271 top = _element$getBoundingC.top,
2272 left = _element$getBoundingC.left,
2273 bottom = _element$getBoundingC.bottom,
2274 right = _element$getBoundingC.right;
2275
2276 return top >= 0 && right <= window.innerWidth && bottom <= window.innerHeight && left >= 0;
2277}
2278
2279function handleMouseUpByBlurring(_ref) {
2280 var currentTarget = _ref.currentTarget;
2281 currentTarget.blur();
2282}
2283function nextFocusableNode(node, filter) {
2284 var allFocusableElements = _toConsumableArray(document.querySelectorAll(FOCUSABLE_SELECTOR));
2285
2286 var sliceLocation = allFocusableElements.indexOf(node) + 1;
2287 var focusableElementsAfterNode = allFocusableElements.slice(sliceLocation);
2288 var _iteratorNormalCompletion = true;
2289 var _didIteratorError = false;
2290 var _iteratorError = undefined;
2291
2292 try {
2293 for (var _iterator = focusableElementsAfterNode[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
2294 var focusableElement = _step.value;
2295
2296 if (isElementInViewport(focusableElement) && (!filter || filter && filter(focusableElement))) {
2297 return focusableElement;
2298 }
2299 }
2300 } catch (err) {
2301 _didIteratorError = true;
2302 _iteratorError = err;
2303 } finally {
2304 try {
2305 if (!_iteratorNormalCompletion && _iterator.return != null) {
2306 _iterator.return();
2307 }
2308 } finally {
2309 if (_didIteratorError) {
2310 throw _iteratorError;
2311 }
2312 }
2313 }
2314
2315 return null;
2316}
2317function focusNextFocusableNode(node, filter) {
2318 var nextFocusable = nextFocusableNode(node, filter);
2319
2320 if (nextFocusable && nextFocusable instanceof HTMLElement) {
2321 nextFocusable.focus();
2322 return true;
2323 }
2324
2325 return false;
2326}
2327
2328var scrollable = {
2329 props: {
2330 'data-polaris-scrollable': true
2331 },
2332 selector: '[data-polaris-scrollable]'
2333};
2334var overlay = {
2335 props: {
2336 'data-polaris-overlay': true
2337 },
2338 selector: '[data-polaris-overlay]'
2339};
2340var layer = {
2341 props: {
2342 'data-polaris-layer': true
2343 },
2344 selector: '[data-polaris-layer]'
2345};
2346var unstyled = {
2347 props: {
2348 'data-polaris-unstyled': true
2349 },
2350 selector: '[data-polaris-unstyled]'
2351};
2352var dataPolarisTopBar = {
2353 props: {
2354 'data-polaris-top-bar': true
2355 },
2356 selector: '[data-polaris-top-bar]'
2357};
2358var headerCell = {
2359 props: {
2360 'data-polaris-header-cell': true
2361 },
2362 selector: '[data-polaris-header-cell]'
2363};
2364var portal = {
2365 props: ['data-portal-id'],
2366 selector: '[data-portal-id]'
2367};
2368var DATA_ATTRIBUTE = {
2369 overlay,
2370 layer
2371}; // these match our values in duration.scss
2372
2373var Duration;
2374
2375(function (Duration) {
2376 Duration[Duration["Instant"] = 0] = "Instant";
2377 Duration[Duration["Fast"] = 100] = "Fast";
2378 Duration[Duration["Base"] = 200] = "Base";
2379 Duration[Duration["Slow"] = 300] = "Slow";
2380 Duration[Duration["Slower"] = 400] = "Slower";
2381 Duration[Duration["Slowest"] = 500] = "Slowest";
2382})(Duration || (Duration = {}));
2383
2384var LinkContext = React__default.createContext(undefined);
2385
2386function useLink() {
2387 return React__default.useContext(LinkContext);
2388}
2389
2390// https://github.com/facebook/react/issues/16722
2391// but eslint-plugin-react doesn't know that just yet
2392// eslint-disable-next-line react/display-name
2393
2394var UnstyledLink = React__default.memo(React__default.forwardRef(function UnstyledLink(props, _ref) {
2395 var LinkComponent = useLink();
2396
2397 if (LinkComponent) {
2398 return React__default.createElement(LinkComponent, Object.assign({}, unstyled.props, props));
2399 }
2400
2401 var external = props.external,
2402 url = props.url,
2403 rest = __rest(props, ["external", "url"]);
2404
2405 var target = external ? '_blank' : undefined;
2406 var rel = external ? 'noopener noreferrer' : undefined;
2407 return React__default.createElement("a", Object.assign({
2408 target: target
2409 }, rest, {
2410 href: url,
2411 rel: rel
2412 }, unstyled.props));
2413}));
2414
2415var TelemetryContext = React__default.createContext(undefined);
2416
2417function noop() {}
2418
2419var defaultTelemetry = {
2420 produce: noop
2421};
2422function useTelemetry() {
2423 return React__default.useContext(TelemetryContext) || defaultTelemetry;
2424}
2425
2426var styles$1 = {
2427 "Icon": "Polaris-Icon",
2428 "hasBackdrop": "Polaris-Icon--hasBackdrop",
2429 "isColored": "Polaris-Icon--isColored",
2430 "colorWhite": "Polaris-Icon--colorWhite",
2431 "colorBlack": "Polaris-Icon--colorBlack",
2432 "colorSkyLighter": "Polaris-Icon--colorSkyLighter",
2433 "colorSkyLight": "Polaris-Icon--colorSkyLight",
2434 "colorSky": "Polaris-Icon--colorSky",
2435 "colorSkyDark": "Polaris-Icon--colorSkyDark",
2436 "colorInkLightest": "Polaris-Icon--colorInkLightest",
2437 "colorInkLighter": "Polaris-Icon--colorInkLighter",
2438 "colorInkLight": "Polaris-Icon--colorInkLight",
2439 "colorInk": "Polaris-Icon--colorInk",
2440 "colorBlueLighter": "Polaris-Icon--colorBlueLighter",
2441 "colorBlueLight": "Polaris-Icon--colorBlueLight",
2442 "colorBlue": "Polaris-Icon--colorBlue",
2443 "colorBlueDark": "Polaris-Icon--colorBlueDark",
2444 "colorBlueDarker": "Polaris-Icon--colorBlueDarker",
2445 "colorIndigoLighter": "Polaris-Icon--colorIndigoLighter",
2446 "colorIndigoLight": "Polaris-Icon--colorIndigoLight",
2447 "colorIndigo": "Polaris-Icon--colorIndigo",
2448 "colorIndigoDark": "Polaris-Icon--colorIndigoDark",
2449 "colorIndigoDarker": "Polaris-Icon--colorIndigoDarker",
2450 "colorTealLighter": "Polaris-Icon--colorTealLighter",
2451 "colorTealLight": "Polaris-Icon--colorTealLight",
2452 "colorTeal": "Polaris-Icon--colorTeal",
2453 "colorTealDark": "Polaris-Icon--colorTealDark",
2454 "colorTealDarker": "Polaris-Icon--colorTealDarker",
2455 "colorGreenLighter": "Polaris-Icon--colorGreenLighter",
2456 "colorGreen": "Polaris-Icon--colorGreen",
2457 "colorGreenDark": "Polaris-Icon--colorGreenDark",
2458 "colorYellowLighter": "Polaris-Icon--colorYellowLighter",
2459 "colorYellow": "Polaris-Icon--colorYellow",
2460 "colorYellowDark": "Polaris-Icon--colorYellowDark",
2461 "colorOrange": "Polaris-Icon--colorOrange",
2462 "colorOrangeDark": "Polaris-Icon--colorOrangeDark",
2463 "colorRedLighter": "Polaris-Icon--colorRedLighter",
2464 "colorRed": "Polaris-Icon--colorRed",
2465 "colorRedDark": "Polaris-Icon--colorRedDark",
2466 "colorPurple": "Polaris-Icon--colorPurple",
2467 "Svg": "Polaris-Icon__Svg",
2468 "Img": "Polaris-Icon__Img",
2469 "Placeholder": "Polaris-Icon__Placeholder"
2470};
2471
2472var COLORS_WITH_BACKDROPS = ['teal', 'tealDark', 'greenDark', 'redDark', 'yellowDark', 'ink', 'inkLighter'];
2473function Icon(_ref) {
2474 var source = _ref.source,
2475 color = _ref.color,
2476 backdrop = _ref.backdrop,
2477 accessibilityLabel = _ref.accessibilityLabel;
2478 var i18n = useI18n();
2479 var telemetry = useTelemetry();
2480 useEffect(function () {
2481 telemetry.produce('polaris_icons_usage/1.0', {
2482 // eslint-disable-next-line @typescript-eslint/camelcase
2483 icon_source: parseSource(source)
2484 });
2485 }, [source, telemetry]);
2486
2487 if (color && backdrop && !COLORS_WITH_BACKDROPS.includes(color)) {
2488 // eslint-disable-next-line no-console
2489 console.warn(i18n.translate('Polaris.Icon.backdropWarning', {
2490 color,
2491 colorsWithBackDrops: COLORS_WITH_BACKDROPS.join(', ')
2492 }));
2493 }
2494
2495 var className = classNames(styles$1.Icon, color && styles$1[variationName('color', color)], color && color !== 'white' && styles$1.isColored, backdrop && styles$1.hasBackdrop);
2496 var contentMarkup;
2497
2498 if (typeof source === 'function') {
2499 var SourceComponent = source;
2500 contentMarkup = React__default.createElement(SourceComponent, {
2501 className: styles$1.Svg,
2502 focusable: "false",
2503 "aria-hidden": "true"
2504 });
2505 } else if (source === 'placeholder') {
2506 contentMarkup = React__default.createElement("div", {
2507 className: styles$1.Placeholder
2508 });
2509 } else {
2510 contentMarkup = React__default.createElement("img", {
2511 className: styles$1.Img,
2512 src: "data:image/svg+xml;utf8,".concat(source),
2513 alt: "",
2514 "aria-hidden": "true"
2515 });
2516 }
2517
2518 return React__default.createElement("span", {
2519 className: className,
2520 "aria-label": accessibilityLabel
2521 }, contentMarkup);
2522}
2523
2524function parseSource(source) {
2525 if (typeof source === 'function') {
2526 return source.name;
2527 } else if (source === 'placeholder') {
2528 return source;
2529 }
2530
2531 return 'custom icon string';
2532}
2533
2534var styles$2 = {
2535 "VisuallyHidden": "Polaris-VisuallyHidden"
2536};
2537
2538function VisuallyHidden(_ref) {
2539 var children = _ref.children;
2540 return React__default.createElement("span", {
2541 className: styles$2.VisuallyHidden
2542 }, children);
2543}
2544
2545/**
2546 * useIsAfterInitialMount will trigger a re-render to provide
2547 * you with an updated value. Using this you enhance server-side
2548 * code that can only run on the client.
2549 * @returns MutableRefObject<T> - Returns a ref object with the
2550 * results from invoking initial value
2551 * @example
2552 * function ComponentExample({children}) {
2553 * const isMounted = useIsAfterInitialMount();
2554 * const content = isMounted ? children : null;
2555 *
2556 * return <React.Fragment>{content}</React.Fragment>;
2557 * }
2558 */
2559
2560function useIsAfterInitialMount() {
2561 var _useState = useState(false),
2562 _useState2 = _slicedToArray(_useState, 2),
2563 isAfterInitialMount = _useState2[0],
2564 setIsAfterInitialMount = _useState2[1];
2565
2566 useEffect(function () {
2567 setIsAfterInitialMount(true);
2568 }, []);
2569 return isAfterInitialMount;
2570}
2571
2572var styles$3 = {
2573 "Spinner": "Polaris-Spinner",
2574 "loading": "Polaris-Spinner--loading",
2575 "sizeSmall": "Polaris-Spinner--sizeSmall",
2576 "sizeLarge": "Polaris-Spinner--sizeLarge",
2577 "colorWhite": "Polaris-Spinner--colorWhite",
2578 "colorTeal": "Polaris-Spinner--colorTeal",
2579 "colorInkLightest": "Polaris-Spinner--colorInkLightest"
2580};
2581
2582var spinnerLarge = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgNDQgNDQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTE1LjU0MiAxLjQ4N0EyMS41MDcgMjEuNTA3IDAgMDAuNSAyMmMwIDExLjg3NCA5LjYyNiAyMS41IDIxLjUgMjEuNSA5Ljg0NyAwIDE4LjM2NC02LjY3NSAyMC44MDktMTYuMDcyYTEuNSAxLjUgMCAwMC0yLjkwNC0uNzU2QzM3LjgwMyAzNC43NTUgMzAuNDczIDQwLjUgMjIgNDAuNSAxMS43ODMgNDAuNSAzLjUgMzIuMjE3IDMuNSAyMmMwLTguMTM3IDUuMy0xNS4yNDcgMTIuOTQyLTE3LjY1YTEuNSAxLjUgMCAxMC0uOS0yLjg2M3oiIGZpbGw9IiM5MTlFQUIiLz48L3N2Zz4K';
2583
2584var spinnerSmall = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjAgMjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTcuMjI5IDEuMTczYTkuMjUgOS4yNSAwIDEwMTEuNjU1IDExLjQxMiAxLjI1IDEuMjUgMCAxMC0yLjQtLjY5OCA2Ljc1IDYuNzUgMCAxMS04LjUwNi04LjMyOSAxLjI1IDEuMjUgMCAxMC0uNzUtMi4zODV6IiBmaWxsPSIjOTE5RUFCIi8+PC9zdmc+Cg==';
2585
2586var COLORS_FOR_LARGE_SPINNER = ['teal', 'inkLightest'];
2587function Spinner(_ref) {
2588 var _ref$size = _ref.size,
2589 size = _ref$size === void 0 ? 'large' : _ref$size,
2590 _ref$color = _ref.color,
2591 color = _ref$color === void 0 ? 'teal' : _ref$color,
2592 accessibilityLabel = _ref.accessibilityLabel,
2593 hasFocusableParent = _ref.hasFocusableParent;
2594 var i18n = useI18n();
2595 var isAfterInitialMount = useIsAfterInitialMount();
2596
2597 if (size === 'large' && !COLORS_FOR_LARGE_SPINNER.includes(color)) {
2598 if (process.env.NODE_ENV === 'development') {
2599 // eslint-disable-next-line no-console
2600 console.warn(i18n.translate('Polaris.Spinner.warningMessage', {
2601 color,
2602 size,
2603 colors: COLORS_FOR_LARGE_SPINNER.join(', ')
2604 }));
2605 } // eslint-disable-next-line no-param-reassign
2606
2607
2608 size = 'small';
2609 }
2610
2611 var className = classNames(styles$3.Spinner, color && styles$3[variationName('color', color)], size && styles$3[variationName('size', size)]);
2612 var spinnerSVG = size === 'large' ? spinnerLarge : spinnerSmall;
2613 var spanAttributes = Object.assign({}, !hasFocusableParent && {
2614 role: 'status'
2615 });
2616 var accessibilityLabelMarkup = (isAfterInitialMount || !hasFocusableParent) && React__default.createElement(VisuallyHidden, null, accessibilityLabel);
2617 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Image, {
2618 alt: "",
2619 source: spinnerSVG,
2620 className: className,
2621 draggable: false
2622 }), React__default.createElement("span", spanAttributes, accessibilityLabelMarkup));
2623}
2624
2625var styles$4 = {
2626 "Button": "Polaris-Button",
2627 "globalTheming": "Polaris-Button--globalTheming",
2628 "disabled": "Polaris-Button--disabled",
2629 "Content": "Polaris-Button__Content",
2630 "textAlignLeft": "Polaris-Button--textAlignLeft",
2631 "textAlignCenter": "Polaris-Button--textAlignCenter",
2632 "textAlignRight": "Polaris-Button--textAlignRight",
2633 "Icon": "Polaris-Button__Icon",
2634 "Spinner": "Polaris-Button__Spinner",
2635 "primary": "Polaris-Button--primary",
2636 "pressed": "Polaris-Button--pressed",
2637 "destructive": "Polaris-Button--destructive",
2638 "outline": "Polaris-Button--outline",
2639 "loading": "Polaris-Button--loading",
2640 "plain": "Polaris-Button--plain",
2641 "iconOnly": "Polaris-Button--iconOnly",
2642 "fullWidth": "Polaris-Button--fullWidth",
2643 "sizeSlim": "Polaris-Button--sizeSlim",
2644 "sizeLarge": "Polaris-Button--sizeLarge",
2645 "monochrome": "Polaris-Button--monochrome",
2646 "Text": "Polaris-Button__Text",
2647 "DisclosureIcon": "Polaris-Button__DisclosureIcon",
2648 "DisclosureIconFacingUp": "Polaris-Button__DisclosureIconFacingUp"
2649};
2650
2651var DEFAULT_SIZE = 'medium';
2652function Button(_ref) {
2653 var id = _ref.id,
2654 url = _ref.url,
2655 disabled = _ref.disabled,
2656 loading = _ref.loading,
2657 children = _ref.children,
2658 accessibilityLabel = _ref.accessibilityLabel,
2659 ariaControls = _ref.ariaControls,
2660 ariaExpanded = _ref.ariaExpanded,
2661 ariaPressed = _ref.ariaPressed,
2662 onClick = _ref.onClick,
2663 onFocus = _ref.onFocus,
2664 onBlur = _ref.onBlur,
2665 onKeyDown = _ref.onKeyDown,
2666 onKeyPress = _ref.onKeyPress,
2667 onKeyUp = _ref.onKeyUp,
2668 onMouseEnter = _ref.onMouseEnter,
2669 onTouchStart = _ref.onTouchStart,
2670 external = _ref.external,
2671 download = _ref.download,
2672 icon = _ref.icon,
2673 primary = _ref.primary,
2674 outline = _ref.outline,
2675 destructive = _ref.destructive,
2676 disclosure = _ref.disclosure,
2677 plain = _ref.plain,
2678 monochrome = _ref.monochrome,
2679 submit = _ref.submit,
2680 _ref$size = _ref.size,
2681 size = _ref$size === void 0 ? DEFAULT_SIZE : _ref$size,
2682 textAlign = _ref.textAlign,
2683 fullWidth = _ref.fullWidth,
2684 pressed = _ref.pressed;
2685
2686 var _useFeatures = useFeatures(),
2687 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
2688 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
2689
2690 var hasGivenDeprecationWarning = useRef(false);
2691
2692 if (ariaPressed && !hasGivenDeprecationWarning.current) {
2693 // eslint-disable-next-line no-console
2694 console.warn('Deprecation: The ariaPressed prop has been replaced with pressed');
2695 hasGivenDeprecationWarning.current = true;
2696 }
2697
2698 var i18n = useI18n();
2699 var isDisabled = disabled || loading;
2700 var className = classNames(styles$4.Button, unstableGlobalTheming && styles$4.globalTheming, primary && styles$4.primary, outline && styles$4.outline, destructive && styles$4.destructive, isDisabled && styles$4.disabled, loading && styles$4.loading, plain && styles$4.plain, pressed && !disabled && !url && styles$4.pressed, monochrome && styles$4.monochrome, size && size !== DEFAULT_SIZE && styles$4[variationName('size', size)], textAlign && styles$4[variationName('textAlign', textAlign)], fullWidth && styles$4.fullWidth, icon && children == null && styles$4.iconOnly);
2701 var disclosureIcon = React__default.createElement(Icon, {
2702 source: loading ? 'placeholder' : CaretDownMinor
2703 });
2704 var disclosureIconMarkup = disclosure ? React__default.createElement(IconWrapper, null, React__default.createElement("div", {
2705 className: classNames(styles$4.DisclosureIcon, disclosure === 'up' && styles$4.DisclosureIconFacingUp)
2706 }, disclosureIcon)) : null;
2707 var iconMarkup;
2708
2709 if (icon) {
2710 var iconInner = isIconSource(icon) ? React__default.createElement(Icon, {
2711 source: loading ? 'placeholder' : icon
2712 }) : icon;
2713 iconMarkup = React__default.createElement(IconWrapper, null, iconInner);
2714 }
2715
2716 var childMarkup = children ? React__default.createElement("span", {
2717 className: styles$4.Text
2718 }, children) : null;
2719 var spinnerColor = primary || destructive ? 'white' : 'inkLightest';
2720 var spinnerSVGMarkup = loading ? React__default.createElement("span", {
2721 className: styles$4.Spinner
2722 }, React__default.createElement(Spinner, {
2723 size: "small",
2724 color: spinnerColor,
2725 accessibilityLabel: i18n.translate('Polaris.Button.spinnerAccessibilityLabel')
2726 })) : null;
2727 var content = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
2728 className: styles$4.Content
2729 }, spinnerSVGMarkup, iconMarkup, childMarkup, disclosureIconMarkup) : React__default.createElement("span", {
2730 className: styles$4.Content
2731 }, spinnerSVGMarkup, childMarkup);
2732 var type = submit ? 'submit' : 'button';
2733
2734 if (url) {
2735 return isDisabled ? // Render an `<a>` so toggling disabled/enabled state changes only the
2736 // `href` attribute instead of replacing the whole element.
2737 // eslint-disable-next-line jsx-a11y/anchor-is-valid
2738 React__default.createElement("a", {
2739 id: id,
2740 className: className,
2741 "aria-label": accessibilityLabel
2742 }, content) : React__default.createElement(UnstyledLink, {
2743 id: id,
2744 url: url,
2745 external: external,
2746 download: download,
2747 onClick: onClick,
2748 onFocus: onFocus,
2749 onBlur: onBlur,
2750 onMouseUp: handleMouseUpByBlurring,
2751 onMouseEnter: onMouseEnter,
2752 onTouchStart: onTouchStart,
2753 className: className,
2754 "aria-label": accessibilityLabel
2755 }, content);
2756 }
2757
2758 var ariaPressedStatus = pressed !== undefined ? pressed : ariaPressed;
2759 return React__default.createElement("button", {
2760 id: id,
2761 type: type,
2762 onClick: onClick,
2763 onFocus: onFocus,
2764 onBlur: onBlur,
2765 onKeyDown: onKeyDown,
2766 onKeyUp: onKeyUp,
2767 onKeyPress: onKeyPress,
2768 onMouseUp: handleMouseUpByBlurring,
2769 onMouseEnter: onMouseEnter,
2770 onTouchStart: onTouchStart,
2771 className: className,
2772 disabled: isDisabled,
2773 "aria-label": accessibilityLabel,
2774 "aria-controls": ariaControls,
2775 "aria-expanded": ariaExpanded,
2776 "aria-pressed": ariaPressedStatus,
2777 role: loading ? 'alert' : undefined,
2778 "aria-busy": loading ? true : undefined
2779 }, content);
2780}
2781function IconWrapper(_ref2) {
2782 var children = _ref2.children;
2783 return React__default.createElement("span", {
2784 className: styles$4.Icon
2785 }, children);
2786}
2787
2788function isIconSource(x) {
2789 return typeof x === 'string' || typeof x === 'object' && x.body || typeof x === 'function';
2790}
2791
2792function buttonsFrom(actions) {
2793 var overrides = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2794
2795 if (Array.isArray(actions)) {
2796 return actions.map(function (action, index) {
2797 return buttonFrom(action, overrides, index);
2798 });
2799 } else {
2800 var action = actions;
2801 return buttonFrom(action, overrides);
2802 }
2803}
2804function buttonFrom(_a, overrides, key) {
2805 var content = _a.content,
2806 onAction = _a.onAction,
2807 action = __rest(_a, ["content", "onAction"]);
2808
2809 return React__default.createElement(Button, Object.assign({
2810 key: key,
2811 onClick: onAction
2812 }, action, overrides), content);
2813}
2814
2815function useToggle(initialState) {
2816 var _useState = useState(initialState),
2817 _useState2 = _slicedToArray(_useState, 2),
2818 state = _useState2[0],
2819 setState = _useState2[1];
2820
2821 var toggle = useCallback(function () {
2822 return setState(function (state) {
2823 return !state;
2824 });
2825 }, []); // cast needed to say this returns a two item array with the items in
2826 // their specific positions instead of `(typeof state | typeof toggle)[]`
2827
2828 return [state, toggle];
2829}
2830function useForcibleToggle(initialState) {
2831 var _useState3 = useState(initialState),
2832 _useState4 = _slicedToArray(_useState3, 2),
2833 state = _useState4[0],
2834 setState = _useState4[1];
2835
2836 var toggles = {
2837 toggle: useCallback(function () {
2838 return setState(function (state) {
2839 return !state;
2840 });
2841 }, []),
2842 forceTrue: useCallback(function () {
2843 return setState(true);
2844 }, []),
2845 forceFalse: useCallback(function () {
2846 return setState(false);
2847 }, [])
2848 }; // cast needed to say this returns a two item array with the items in
2849 // their specific positions instead of `(typeof state | typeof toggles)[]`
2850
2851 return [state, toggles];
2852}
2853
2854var WithinContentContext = React__default.createContext(false);
2855
2856// `Component`. If `props` is passed, those will be added as props on the
2857// wrapped component. If `element` is null, the component is not wrapped.
2858
2859function wrapWithComponent(element, Component, props) {
2860 if (element == null) {
2861 return null;
2862 }
2863
2864 return isElementOfType(element, Component) ? element : React__default.createElement(Component, props, element);
2865} // In development, we compare based on the name of the function because
2866// React Hot Loader proxies React components in order to make updates. In
2867// production we can simply compare the components for equality.
2868
2869var isComponent = process.env.NODE_ENV === 'development' ? hotReloadComponentCheck : function (AComponent, AnotherComponent) {
2870 return AComponent === AnotherComponent;
2871}; // Checks whether `element` is a React element of type `Component` (or one of
2872// the passed components, if `Component` is an array of React components).
2873
2874function isElementOfType(element, Component) {
2875 if (element == null || !React__default.isValidElement(element) || typeof element.type === 'string') {
2876 return false;
2877 }
2878
2879 var type = element.type;
2880 var Components = Array.isArray(Component) ? Component : [Component];
2881 return Components.some(function (AComponent) {
2882 return typeof type !== 'string' && isComponent(AComponent, type);
2883 });
2884} // Returns all children that are valid elements as an array. Can optionally be
2885// filtered by passing `predicate`.
2886
2887function elementChildren(children) {
2888 var predicate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {
2889 return true;
2890 };
2891 return React__default.Children.toArray(children).filter(function (child) {
2892 return React__default.isValidElement(child) && predicate(child);
2893 });
2894}
2895
2896function hotReloadComponentCheck(AComponent, AnotherComponent) {
2897 var componentName = AComponent.name;
2898 var anotherComponentName = AnotherComponent.displayName;
2899 return AComponent === AnotherComponent || Boolean(componentName) && componentName === anotherComponentName;
2900}
2901
2902var styles$5 = {
2903 "ButtonGroup": "Polaris-ButtonGroup",
2904 "Item": "Polaris-ButtonGroup__Item",
2905 "Item-plain": "Polaris-ButtonGroup__Item--plain",
2906 "segmented": "Polaris-ButtonGroup--segmented",
2907 "Item-focused": "Polaris-ButtonGroup__Item--focused",
2908 "fullWidth": "Polaris-ButtonGroup--fullWidth"
2909};
2910
2911function Item(_ref) {
2912 var button = _ref.button;
2913
2914 var _useForcibleToggle = useForcibleToggle(false),
2915 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
2916 focused = _useForcibleToggle2[0],
2917 _useForcibleToggle2$ = _useForcibleToggle2[1],
2918 forceTrueFocused = _useForcibleToggle2$.forceTrue,
2919 forceFalseFocused = _useForcibleToggle2$.forceFalse;
2920
2921 var className = classNames(styles$5.Item, focused && styles$5['Item-focused'], button.props.plain && styles$5['Item-plain']);
2922 return React__default.createElement("div", {
2923 className: className,
2924 onFocus: forceTrueFocused,
2925 onBlur: forceFalseFocused
2926 }, button);
2927}
2928
2929function ButtonGroup(_ref) {
2930 var children = _ref.children,
2931 segmented = _ref.segmented,
2932 fullWidth = _ref.fullWidth,
2933 connectedTop = _ref.connectedTop;
2934 var className = classNames(styles$5.ButtonGroup, segmented && styles$5.segmented, fullWidth && styles$5.fullWidth);
2935 var contents = elementChildren(children).map(function (child, index) {
2936 return React__default.createElement(Item, {
2937 button: child,
2938 key: index
2939 });
2940 });
2941 return React__default.createElement("div", {
2942 className: className,
2943 "data-buttongroup-segmented": segmented,
2944 "data-buttongroup-connected-top": connectedTop,
2945 "data-buttongroup-full-width": fullWidth
2946 }, contents);
2947}
2948
2949var StickyManagerContext = React__default.createContext(undefined);
2950
2951function useStickyManager() {
2952 var stickyManager = useContext(StickyManagerContext);
2953
2954 if (!stickyManager) {
2955 throw new MissingAppProviderError('No StickyManager was provided.');
2956 }
2957
2958 return stickyManager;
2959}
2960
2961var Breakpoints = {
2962 navigationBarCollapsed: '768px',
2963 stackedContent: '1043px'
2964};
2965var noWindowMatches = {
2966 media: '',
2967 addListener: noop$1,
2968 removeListener: noop$1,
2969 matches: false,
2970 onchange: noop$1,
2971 addEventListener: noop$1,
2972 removeEventListener: noop$1,
2973 dispatchEvent: function dispatchEvent(_) {
2974 return true;
2975 }
2976};
2977
2978function noop$1() {}
2979
2980function navigationBarCollapsed() {
2981 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.navigationBarCollapsed, ")"));
2982}
2983function stackedContent() {
2984 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.stackedContent, ")"));
2985}
2986
2987var StickyManager =
2988/*#__PURE__*/
2989function () {
2990 function StickyManager(container) {
2991 var _this = this;
2992
2993 _classCallCheck(this, StickyManager);
2994
2995 this.stickyItems = [];
2996 this.stuckItems = [];
2997 this.topBarOffset = 0;
2998 this.handleResize = debounce(function () {
2999 _this.manageStickyItems();
3000 }, 40, {
3001 leading: true,
3002 trailing: true,
3003 maxWait: 40
3004 });
3005 this.handleScroll = debounce(function () {
3006 _this.manageStickyItems();
3007 }, 40, {
3008 leading: true,
3009 trailing: true,
3010 maxWait: 40
3011 });
3012
3013 if (container) {
3014 this.setContainer(container);
3015 }
3016 }
3017
3018 _createClass(StickyManager, [{
3019 key: "registerStickyItem",
3020 value: function registerStickyItem(stickyItem) {
3021 this.stickyItems.push(stickyItem);
3022 }
3023 }, {
3024 key: "unregisterStickyItem",
3025 value: function unregisterStickyItem(nodeToRemove) {
3026 var nodeIndex = this.stickyItems.findIndex(function (_ref) {
3027 var stickyNode = _ref.stickyNode;
3028 return nodeToRemove === stickyNode;
3029 });
3030 this.stickyItems.splice(nodeIndex, 1);
3031 }
3032 }, {
3033 key: "setContainer",
3034 value: function setContainer(el) {
3035 this.container = el;
3036
3037 if (isDocument(el)) {
3038 this.setTopBarOffset();
3039 }
3040
3041 addEventListener(this.container, 'scroll', this.handleScroll);
3042 addEventListener(window, 'resize', this.handleResize);
3043 this.manageStickyItems();
3044 }
3045 }, {
3046 key: "removeScrollListener",
3047 value: function removeScrollListener() {
3048 if (this.container) {
3049 removeEventListener(this.container, 'scroll', this.handleScroll);
3050 removeEventListener(window, 'resize', this.handleResize);
3051 }
3052 }
3053 }, {
3054 key: "manageStickyItems",
3055 value: function manageStickyItems() {
3056 var _this2 = this;
3057
3058 if (this.stickyItems.length <= 0) {
3059 return;
3060 }
3061
3062 var scrollTop = scrollTopFor(this.container);
3063 var containerTop = getRectForNode(this.container).top + this.topBarOffset;
3064 this.stickyItems.forEach(function (stickyItem) {
3065 var handlePositioning = stickyItem.handlePositioning;
3066
3067 var _this2$evaluateSticky = _this2.evaluateStickyItem(stickyItem, scrollTop, containerTop),
3068 sticky = _this2$evaluateSticky.sticky,
3069 top = _this2$evaluateSticky.top,
3070 left = _this2$evaluateSticky.left,
3071 width = _this2$evaluateSticky.width;
3072
3073 _this2.updateStuckItems(stickyItem, sticky);
3074
3075 handlePositioning(sticky, top, left, width);
3076 });
3077 }
3078 }, {
3079 key: "evaluateStickyItem",
3080 value: function evaluateStickyItem(stickyItem, scrollTop, containerTop) {
3081 var stickyNode = stickyItem.stickyNode,
3082 placeHolderNode = stickyItem.placeHolderNode,
3083 boundingElement = stickyItem.boundingElement,
3084 offset = stickyItem.offset,
3085 disableWhenStacked = stickyItem.disableWhenStacked;
3086
3087 if (disableWhenStacked && stackedContent().matches) {
3088 return {
3089 sticky: false,
3090 top: 0,
3091 left: 0,
3092 width: 'auto'
3093 };
3094 }
3095
3096 var stickyOffset = offset ? this.getOffset(stickyNode) + parseInt(tokens.spacingLoose, 10) : this.getOffset(stickyNode);
3097 var scrollPosition = scrollTop + stickyOffset;
3098 var placeHolderNodeCurrentTop = placeHolderNode.getBoundingClientRect().top - containerTop + scrollTop;
3099 var top = containerTop + stickyOffset;
3100 var width = placeHolderNode.getBoundingClientRect().width;
3101 var left = placeHolderNode.getBoundingClientRect().left;
3102 var sticky;
3103
3104 if (boundingElement == null) {
3105 sticky = scrollPosition >= placeHolderNodeCurrentTop;
3106 } else {
3107 var stickyItemHeight = stickyNode.getBoundingClientRect().height;
3108 var stickyItemBottomPosition = boundingElement.getBoundingClientRect().bottom - stickyItemHeight + scrollTop - containerTop;
3109 sticky = scrollPosition >= placeHolderNodeCurrentTop && scrollPosition < stickyItemBottomPosition;
3110 }
3111
3112 return {
3113 sticky,
3114 top,
3115 left,
3116 width
3117 };
3118 }
3119 }, {
3120 key: "updateStuckItems",
3121 value: function updateStuckItems(item, sticky) {
3122 var stickyNode = item.stickyNode;
3123
3124 if (sticky && !this.isNodeStuck(stickyNode)) {
3125 this.addStuckItem(item);
3126 } else if (!sticky && this.isNodeStuck(stickyNode)) {
3127 this.removeStuckItem(item);
3128 }
3129 }
3130 }, {
3131 key: "addStuckItem",
3132 value: function addStuckItem(stickyItem) {
3133 this.stuckItems.push(stickyItem);
3134 }
3135 }, {
3136 key: "removeStuckItem",
3137 value: function removeStuckItem(stickyItem) {
3138 var nodeToRemove = stickyItem.stickyNode;
3139 var nodeIndex = this.stuckItems.findIndex(function (_ref2) {
3140 var stickyNode = _ref2.stickyNode;
3141 return nodeToRemove === stickyNode;
3142 });
3143 this.stuckItems.splice(nodeIndex, 1);
3144 }
3145 }, {
3146 key: "getOffset",
3147 value: function getOffset(node) {
3148 if (this.stuckItems.length === 0) {
3149 return 0;
3150 }
3151
3152 var offset = 0;
3153 var count = 0;
3154 var stuckNodesLength = this.stuckItems.length;
3155 var nodeRect = getRectForNode(node);
3156
3157 while (count < stuckNodesLength) {
3158 var stuckNode = this.stuckItems[count].stickyNode;
3159
3160 if (stuckNode !== node) {
3161 var stuckNodeRect = getRectForNode(stuckNode);
3162
3163 if (!horizontallyOverlaps(nodeRect, stuckNodeRect)) {
3164 offset += getRectForNode(stuckNode).height;
3165 }
3166 } else {
3167 break;
3168 }
3169
3170 count++;
3171 }
3172
3173 return offset;
3174 }
3175 }, {
3176 key: "isNodeStuck",
3177 value: function isNodeStuck(node) {
3178 var nodeFound = this.stuckItems.findIndex(function (_ref3) {
3179 var stickyNode = _ref3.stickyNode;
3180 return node === stickyNode;
3181 });
3182 return nodeFound >= 0;
3183 }
3184 }, {
3185 key: "setTopBarOffset",
3186 value: function setTopBarOffset() {
3187 var topbarElement = this.container.querySelector(":not(".concat(scrollable.selector, ") ").concat(dataPolarisTopBar.selector));
3188 this.topBarOffset = topbarElement ? topbarElement.clientHeight : 0;
3189 }
3190 }]);
3191
3192 return StickyManager;
3193}();
3194
3195function isDocument(node) {
3196 return node === document;
3197}
3198
3199function scrollTopFor(container) {
3200 return isDocument(container) ? document.body.scrollTop || document.documentElement.scrollTop : container.scrollTop;
3201}
3202
3203function horizontallyOverlaps(rect1, rect2) {
3204 var rect1Left = rect1.left;
3205 var rect1Right = rect1.left + rect1.width;
3206 var rect2Left = rect2.left;
3207 var rect2Right = rect2.left + rect2.width;
3208 return rect2Right < rect1Left || rect1Right < rect2Left;
3209}
3210
3211var UniqueIdFactoryContext = React__default.createContext(undefined);
3212
3213/**
3214 * Returns a unique id that remains consistent across multiple re-renders of the
3215 * same hook
3216 * @param prefix Defines a prefix for the ID. You probably want to set this to
3217 * the name of the component you're calling `useUniqueId` in.
3218 * @param overrideId Defines a fixed value to use instead of generating a unique
3219 * ID. Useful for components that allow consumers to specify their own ID.
3220 */
3221
3222function useUniqueId() {
3223 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
3224 var overrideId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
3225 var idFactory = useContext(UniqueIdFactoryContext); // By using a ref to store the uniqueId for each invocation of the hook and
3226 // checking that it is not already populated we ensure that we don’t generate
3227 // a new ID on every re-render of a component.
3228
3229 var uniqueIdRef = useRef(null);
3230
3231 if (!idFactory) {
3232 throw new MissingAppProviderError('No UniqueIdFactory was provided.');
3233 } // If an override was specified, then use that instead of using a unique ID
3234 // Hooks can’t be called conditionally so this has to go after all use* calls
3235
3236
3237 if (overrideId) {
3238 return overrideId;
3239 } // If a unique id has not yet been generated, then get a new one
3240
3241
3242 if (!uniqueIdRef.current) {
3243 uniqueIdRef.current = idFactory.nextId(prefix);
3244 }
3245
3246 return uniqueIdRef.current;
3247}
3248
3249var UniqueIdFactory =
3250/*#__PURE__*/
3251function () {
3252 function UniqueIdFactory(idGeneratorFactory) {
3253 _classCallCheck(this, UniqueIdFactory);
3254
3255 this.idGenerators = {};
3256 this.idGeneratorFactory = idGeneratorFactory;
3257 }
3258
3259 _createClass(UniqueIdFactory, [{
3260 key: "nextId",
3261 value: function nextId(prefix) {
3262 if (!this.idGenerators[prefix]) {
3263 this.idGenerators[prefix] = this.idGeneratorFactory(prefix);
3264 }
3265
3266 return this.idGenerators[prefix]();
3267 }
3268 }]);
3269
3270 return UniqueIdFactory;
3271}();
3272function globalIdGeneratorFactory() {
3273 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
3274 var index = 1;
3275 return function () {
3276 return "Polaris".concat(prefix).concat(index++);
3277 };
3278}
3279
3280var ScrollableContext = React__default.createContext(undefined);
3281
3282function ScrollTo() {
3283 var anchorNode = useRef(null);
3284 var scrollToPosition = useContext(ScrollableContext);
3285 useEffect(function () {
3286 if (!scrollToPosition || !anchorNode.current) {
3287 return;
3288 }
3289
3290 scrollToPosition(anchorNode.current.offsetTop);
3291 }, [scrollToPosition]);
3292 var id = useUniqueId("ScrollTo"); // eslint-disable-next-line jsx-a11y/anchor-is-valid
3293
3294 return React__default.createElement("a", {
3295 id: id,
3296 ref: anchorNode
3297 });
3298}
3299
3300var styles$6 = {
3301 "Scrollable": "Polaris-Scrollable",
3302 "horizontal": "Polaris-Scrollable--horizontal",
3303 "vertical": "Polaris-Scrollable--vertical",
3304 "hasTopShadow": "Polaris-Scrollable--hasTopShadow",
3305 "hasBottomShadow": "Polaris-Scrollable--hasBottomShadow"
3306};
3307
3308var MAX_SCROLL_DISTANCE = 100;
3309var DELTA_THRESHOLD = 0.2;
3310var DELTA_PERCENTAGE = 0.2;
3311var EVENTS_TO_LOCK = ['scroll', 'touchmove', 'wheel'];
3312var PREFERS_REDUCED_MOTION = prefersReducedMotion();
3313var Scrollable =
3314/*#__PURE__*/
3315function (_React$Component) {
3316 _inherits(Scrollable, _React$Component);
3317
3318 function Scrollable() {
3319 var _this;
3320
3321 _classCallCheck(this, Scrollable);
3322
3323 _this = _possibleConstructorReturn(this, _getPrototypeOf(Scrollable).apply(this, arguments));
3324 _this.state = {
3325 topShadow: false,
3326 bottomShadow: false,
3327 scrollPosition: 0
3328 };
3329 _this.stickyManager = new StickyManager();
3330 _this.handleResize = debounce(function () {
3331 _this.handleScroll();
3332 }, 50, {
3333 trailing: true
3334 });
3335
3336 _this.setScrollArea = function (scrollArea) {
3337 _this.scrollArea = scrollArea;
3338 };
3339
3340 _this.handleScroll = function () {
3341 var _assertThisInitialize = _assertThisInitialized(_this),
3342 scrollArea = _assertThisInitialize.scrollArea;
3343
3344 var _this$props = _this.props,
3345 shadow = _this$props.shadow,
3346 onScrolledToBottom = _this$props.onScrolledToBottom;
3347
3348 if (scrollArea == null) {
3349 return;
3350 }
3351
3352 var scrollTop = scrollArea.scrollTop,
3353 clientHeight = scrollArea.clientHeight,
3354 scrollHeight = scrollArea.scrollHeight;
3355 var shouldBottomShadow = Boolean(shadow && !(scrollTop + clientHeight >= scrollHeight));
3356 var shouldTopShadow = Boolean(shadow && scrollTop > 0);
3357 var canScroll = scrollHeight > clientHeight;
3358 var hasScrolledToBottom = scrollHeight - scrollTop === clientHeight;
3359
3360 if (canScroll && hasScrolledToBottom && onScrolledToBottom) {
3361 onScrolledToBottom();
3362 }
3363
3364 _this.setState({
3365 topShadow: shouldTopShadow,
3366 bottomShadow: shouldBottomShadow,
3367 scrollPosition: scrollTop
3368 });
3369 };
3370
3371 _this.scrollHint = function () {
3372 var _assertThisInitialize2 = _assertThisInitialized(_this),
3373 scrollArea = _assertThisInitialize2.scrollArea;
3374
3375 if (scrollArea == null) {
3376 return;
3377 }
3378
3379 var clientHeight = scrollArea.clientHeight,
3380 scrollHeight = scrollArea.scrollHeight;
3381
3382 if (PREFERS_REDUCED_MOTION || _this.state.scrollPosition > 0 || scrollHeight <= clientHeight) {
3383 return;
3384 }
3385
3386 var scrollDistance = scrollHeight - clientHeight;
3387
3388 _this.toggleLock();
3389
3390 _this.setState({
3391 scrollPosition: scrollDistance > MAX_SCROLL_DISTANCE ? MAX_SCROLL_DISTANCE : scrollDistance
3392 }, function () {
3393 window.requestAnimationFrame(_this.scrollStep);
3394 });
3395 };
3396
3397 _this.scrollStep = function () {
3398 _this.setState(function (_ref) {
3399 var scrollPosition = _ref.scrollPosition;
3400 var delta = scrollPosition * DELTA_PERCENTAGE;
3401 return {
3402 scrollPosition: delta < DELTA_THRESHOLD ? 0 : scrollPosition - delta
3403 };
3404 }, function () {
3405 if (_this.state.scrollPosition > 0) {
3406 window.requestAnimationFrame(_this.scrollStep);
3407 } else {
3408 _this.toggleLock(false);
3409 }
3410 });
3411 };
3412
3413 _this.scrollToPosition = function (scrollY) {
3414 _this.setState({
3415 scrollPosition: scrollY
3416 });
3417 };
3418
3419 return _this;
3420 }
3421
3422 _createClass(Scrollable, [{
3423 key: "componentDidMount",
3424 value: function componentDidMount() {
3425 var _this2 = this;
3426
3427 if (this.scrollArea == null) {
3428 return;
3429 }
3430
3431 this.stickyManager.setContainer(this.scrollArea);
3432 addEventListener(this.scrollArea, 'scroll', function () {
3433 window.requestAnimationFrame(_this2.handleScroll);
3434 });
3435 addEventListener(window, 'resize', this.handleResize);
3436 window.requestAnimationFrame(function () {
3437 _this2.handleScroll();
3438
3439 if (_this2.props.hint) {
3440 _this2.scrollHint();
3441 }
3442 });
3443 }
3444 }, {
3445 key: "componentWillUnmount",
3446 value: function componentWillUnmount() {
3447 if (this.scrollArea == null) {
3448 return;
3449 }
3450
3451 removeEventListener(this.scrollArea, 'scroll', this.handleScroll);
3452 removeEventListener(window, 'resize', this.handleResize);
3453 this.stickyManager.removeScrollListener();
3454 }
3455 }, {
3456 key: "componentDidUpdate",
3457 value: function componentDidUpdate() {
3458 var scrollPosition = this.state.scrollPosition;
3459
3460 if (scrollPosition && this.scrollArea && scrollPosition > 0) {
3461 this.scrollArea.scrollTop = scrollPosition;
3462 }
3463 }
3464 }, {
3465 key: "render",
3466 value: function render() {
3467 var _this$state = this.state,
3468 topShadow = _this$state.topShadow,
3469 bottomShadow = _this$state.bottomShadow;
3470
3471 var _a = this.props,
3472 children = _a.children,
3473 className = _a.className,
3474 horizontal = _a.horizontal,
3475 _a$vertical = _a.vertical,
3476 vertical = _a$vertical === void 0 ? true : _a$vertical,
3477 shadow = _a.shadow,
3478 hint = _a.hint,
3479 onScrolledToBottom = _a.onScrolledToBottom,
3480 rest = __rest(_a, ["children", "className", "horizontal", "vertical", "shadow", "hint", "onScrolledToBottom"]);
3481
3482 var finalClassName = classNames(className, styles$6.Scrollable, vertical && styles$6.vertical, horizontal && styles$6.horizontal, topShadow && styles$6.hasTopShadow, bottomShadow && styles$6.hasBottomShadow);
3483 return React__default.createElement(ScrollableContext.Provider, {
3484 value: this.scrollToPosition
3485 }, React__default.createElement(StickyManagerContext.Provider, {
3486 value: this.stickyManager
3487 }, React__default.createElement("div", Object.assign({
3488 className: finalClassName
3489 }, scrollable.props, rest, {
3490 ref: this.setScrollArea
3491 }), children)));
3492 }
3493 }, {
3494 key: "toggleLock",
3495 value: function toggleLock() {
3496 var shouldLock = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
3497 var scrollArea = this.scrollArea;
3498
3499 if (scrollArea == null) {
3500 return;
3501 }
3502
3503 EVENTS_TO_LOCK.forEach(function (eventName) {
3504 if (shouldLock) {
3505 addEventListener(scrollArea, eventName, prevent);
3506 } else {
3507 removeEventListener(scrollArea, eventName, prevent);
3508 }
3509 });
3510 }
3511 }], [{
3512 key: "forNode",
3513 value: function forNode(node) {
3514 return closest(node, scrollable.selector) || document;
3515 }
3516 }]);
3517
3518 return Scrollable;
3519}(React__default.Component);
3520Scrollable.ScrollTo = ScrollTo;
3521
3522function prevent(evt) {
3523 evt.preventDefault();
3524}
3525
3526function prefersReducedMotion() {
3527 try {
3528 return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
3529 } catch (err) {
3530 return false;
3531 }
3532}
3533
3534var styles$7 = {
3535 "Badge": "Polaris-Badge",
3536 "Pip": "Polaris-Badge__Pip",
3537 "sizeSmall": "Polaris-Badge--sizeSmall",
3538 "statusSuccess": "Polaris-Badge--statusSuccess",
3539 "Content": "Polaris-Badge__Content",
3540 "statusInfo": "Polaris-Badge--statusInfo",
3541 "statusAttention": "Polaris-Badge--statusAttention",
3542 "statusWarning": "Polaris-Badge--statusWarning",
3543 "statusNew": "Polaris-Badge--statusNew",
3544 "progressIncomplete": "Polaris-Badge--progressIncomplete",
3545 "progressPartiallyComplete": "Polaris-Badge--progressPartiallyComplete",
3546 "progressComplete": "Polaris-Badge--progressComplete"
3547};
3548
3549var PROGRESS_LABELS = {
3550 incomplete: 'incomplete',
3551 partiallyComplete: 'partiallyComplete',
3552 complete: 'complete'
3553};
3554var STATUS_LABELS = {
3555 info: 'info',
3556 success: 'success',
3557 warning: 'warning',
3558 attention: 'attention',
3559 new: 'new'
3560};
3561var DEFAULT_SIZE$1 = 'medium';
3562function Badge(_ref) {
3563 var children = _ref.children,
3564 status = _ref.status,
3565 progress = _ref.progress,
3566 _ref$size = _ref.size,
3567 size = _ref$size === void 0 ? DEFAULT_SIZE$1 : _ref$size;
3568 var i18n = useI18n();
3569 var className = classNames(styles$7.Badge, status && styles$7[variationName('status', status)], progress && styles$7[variationName('progress', progress)], size && size !== DEFAULT_SIZE$1 && styles$7[variationName('size', size)]);
3570 var progressMarkup;
3571
3572 switch (progress) {
3573 case PROGRESS_LABELS.incomplete:
3574 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.incomplete');
3575 break;
3576
3577 case PROGRESS_LABELS.partiallyComplete:
3578 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.partiallyComplete');
3579 break;
3580
3581 case PROGRESS_LABELS.complete:
3582 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.complete');
3583 break;
3584 }
3585
3586 var pipMarkup = progress ? React__default.createElement("span", {
3587 className: styles$7.Pip
3588 }, React__default.createElement(VisuallyHidden, null, progressMarkup)) : null;
3589 var statusMarkup;
3590
3591 switch (status) {
3592 case STATUS_LABELS.info:
3593 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.info');
3594 break;
3595
3596 case STATUS_LABELS.success:
3597 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.success');
3598 break;
3599
3600 case STATUS_LABELS.warning:
3601 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.warning');
3602 break;
3603
3604 case STATUS_LABELS.attention:
3605 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.attention');
3606 break;
3607
3608 case STATUS_LABELS.new:
3609 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.new');
3610 break;
3611 }
3612
3613 var statusLabelMarkup = status ? React__default.createElement(VisuallyHidden, null, statusMarkup) : null;
3614 return React__default.createElement("span", {
3615 className: className
3616 }, statusLabelMarkup, pipMarkup, React__default.createElement("span", {
3617 className: styles$7.Content
3618 }, children));
3619}
3620
3621var styles$8 = {
3622 "variationPositive": "Polaris-TextStyle--variationPositive",
3623 "variationNegative": "Polaris-TextStyle--variationNegative",
3624 "variationCode": "Polaris-TextStyle--variationCode",
3625 "variationStrong": "Polaris-TextStyle--variationStrong",
3626 "variationSubdued": "Polaris-TextStyle--variationSubdued"
3627};
3628
3629var VariationValue;
3630
3631(function (VariationValue) {
3632 VariationValue["Positive"] = "positive";
3633 VariationValue["Negative"] = "negative";
3634 VariationValue["Strong"] = "strong";
3635 VariationValue["Subdued"] = "subdued";
3636 VariationValue["Code"] = "code";
3637})(VariationValue || (VariationValue = {}));
3638
3639function TextStyle(_ref) {
3640 var variation = _ref.variation,
3641 children = _ref.children;
3642 var className = classNames(variation && styles$8[variationName('variation', variation)], variation === VariationValue.Code && styles$8.code);
3643 var Element = variationElement(variation);
3644 return React__default.createElement(Element, {
3645 className: className
3646 }, children);
3647}
3648
3649function variationElement(variation) {
3650 return variation === VariationValue.Code ? 'code' : 'span';
3651}
3652
3653var styles$9 = {
3654 "ActionList": "Polaris-ActionList",
3655 "globalTheming": "Polaris-ActionList--globalTheming",
3656 "Section-withoutTitle": "Polaris-ActionList__Section--withoutTitle",
3657 "Actions": "Polaris-ActionList__Actions",
3658 "Section": "Polaris-ActionList__Section",
3659 "Title": "Polaris-ActionList__Title",
3660 "Item": "Polaris-ActionList__Item",
3661 "active": "Polaris-ActionList--active",
3662 "destructive": "Polaris-ActionList--destructive",
3663 "disabled": "Polaris-ActionList--disabled",
3664 "Image": "Polaris-ActionList__Image",
3665 "Content": "Polaris-ActionList__Content",
3666 "Text": "Polaris-ActionList__Text",
3667 "BadgeWrapper": "Polaris-ActionList__BadgeWrapper"
3668};
3669
3670function Item$1(_ref) {
3671 var id = _ref.id,
3672 badge = _ref.badge,
3673 content = _ref.content,
3674 accessibilityLabel = _ref.accessibilityLabel,
3675 helpText = _ref.helpText,
3676 url = _ref.url,
3677 onAction = _ref.onAction,
3678 icon = _ref.icon,
3679 image = _ref.image,
3680 disabled = _ref.disabled,
3681 external = _ref.external,
3682 destructive = _ref.destructive,
3683 ellipsis = _ref.ellipsis,
3684 active = _ref.active,
3685 role = _ref.role;
3686
3687 var _useFeatures = useFeatures(),
3688 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
3689 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
3690
3691 var className = classNames(styles$9.Item, disabled && styles$9.disabled, destructive && styles$9.destructive, active && styles$9.active, unstableGlobalTheming && styles$9.globalTheming);
3692 var imageElement = null;
3693
3694 if (icon) {
3695 imageElement = React__default.createElement("div", {
3696 className: styles$9.Image
3697 }, React__default.createElement(Icon, {
3698 source: icon
3699 }));
3700 } else if (image) {
3701 imageElement = React__default.createElement("div", {
3702 role: "presentation",
3703 className: styles$9.Image,
3704 style: {
3705 backgroundImage: "url(".concat(image)
3706 }
3707 });
3708 }
3709
3710 var contentText = ellipsis && content ? "".concat(content, "\u2026") : content;
3711 var contentMarkup = helpText ? React__default.createElement("div", null, React__default.createElement("div", null, contentText), React__default.createElement(TextStyle, {
3712 variation: "subdued"
3713 }, helpText)) : contentText;
3714 var badgeMarkup = badge && React__default.createElement("span", {
3715 className: styles$9.BadgeWrapper
3716 }, React__default.createElement(Badge, {
3717 status: badge.status
3718 }, badge.content));
3719 var textMarkup = imageElement ? React__default.createElement("div", {
3720 className: styles$9.Text
3721 }, contentMarkup) : contentMarkup;
3722 var contentElement = React__default.createElement("div", {
3723 className: styles$9.Content
3724 }, imageElement, textMarkup, badgeMarkup);
3725 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
3726 var control = url ? React__default.createElement(UnstyledLink, {
3727 id: id,
3728 url: url,
3729 className: className,
3730 external: external,
3731 "aria-label": accessibilityLabel,
3732 onClick: onAction
3733 }, contentElement) : React__default.createElement("button", {
3734 id: id,
3735 type: "button",
3736 className: className,
3737 disabled: disabled,
3738 "aria-label": accessibilityLabel,
3739 onClick: onAction
3740 }, contentElement);
3741 return React__default.createElement("li", {
3742 role: role,
3743 "aria-selected": active
3744 }, scrollMarkup, control);
3745}
3746
3747function Section(_ref) {
3748 var section = _ref.section,
3749 hasMultipleSections = _ref.hasMultipleSections,
3750 actionRole = _ref.actionRole,
3751 onActionAnyItem = _ref.onActionAnyItem;
3752
3753 var handleAction = function handleAction(itemOnAction) {
3754 return function () {
3755 if (itemOnAction) {
3756 itemOnAction();
3757 }
3758
3759 if (onActionAnyItem) {
3760 onActionAnyItem();
3761 }
3762 };
3763 };
3764
3765 var actionMarkup = section.items.map(function (_a, index) {
3766 var content = _a.content,
3767 helpText = _a.helpText,
3768 onAction = _a.onAction,
3769 item = __rest(_a, ["content", "helpText", "onAction"]);
3770
3771 return React__default.createElement(Item$1, Object.assign({
3772 key: "".concat(content, "-").concat(index),
3773 content: content,
3774 helpText: helpText,
3775 role: actionRole,
3776 onAction: handleAction(onAction)
3777 }, item));
3778 });
3779 var className = section.title ? undefined : styles$9['Section-withoutTitle'];
3780 var titleMarkup = section.title ? React__default.createElement("p", {
3781 className: styles$9.Title
3782 }, section.title) : null;
3783 var sectionRole = actionRole === 'option' ? 'presentation' : undefined;
3784 var sectionMarkup = React__default.createElement("div", {
3785 className: className
3786 }, titleMarkup, React__default.createElement("ul", {
3787 className: styles$9.Actions,
3788 role: sectionRole
3789 }, actionMarkup));
3790 return hasMultipleSections ? React__default.createElement("li", {
3791 className: styles$9.Section
3792 }, sectionMarkup) : sectionMarkup;
3793}
3794
3795function ActionList(_ref) {
3796 var items = _ref.items,
3797 _ref$sections = _ref.sections,
3798 sections = _ref$sections === void 0 ? [] : _ref$sections,
3799 actionRole = _ref.actionRole,
3800 onActionAnyItem = _ref.onActionAnyItem;
3801 var finalSections = [];
3802
3803 if (items) {
3804 finalSections = [{
3805 items
3806 }].concat(_toConsumableArray(sections));
3807 } else if (sections) {
3808 finalSections = sections;
3809 }
3810
3811 var _useFeatures = useFeatures(),
3812 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
3813 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
3814
3815 var className = classNames(styles$9.ActionList, unstableGlobalTheming && styles$9.globalTheming);
3816 var hasMultipleSections = finalSections.length > 1; // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
3817 // see https://github.com/Microsoft/TypeScript/issues/28768
3818
3819 var Element = hasMultipleSections ? 'ul' : 'div';
3820 var sectionMarkup = finalSections.map(function (section, index) {
3821 return section.items.length > 0 ? React__default.createElement(Section, {
3822 key: section.title || index,
3823 section: section,
3824 hasMultipleSections: hasMultipleSections,
3825 actionRole: actionRole,
3826 onActionAnyItem: onActionAnyItem
3827 }) : null;
3828 });
3829 return React__default.createElement(Element, {
3830 className: className
3831 }, sectionMarkup);
3832}
3833
3834var getUniqueID = createUniqueIDFactory('portal-');
3835var Portal =
3836/*#__PURE__*/
3837function (_React$PureComponent) {
3838 _inherits(Portal, _React$PureComponent);
3839
3840 function Portal() {
3841 var _this;
3842
3843 _classCallCheck(this, Portal);
3844
3845 _this = _possibleConstructorReturn(this, _getPrototypeOf(Portal).apply(this, arguments));
3846 _this.state = {
3847 isMounted: false
3848 };
3849 _this.portalId = _this.props.idPrefix !== '' ? "".concat(_this.props.idPrefix, "-").concat(getUniqueID()) : getUniqueID();
3850 return _this;
3851 }
3852
3853 _createClass(Portal, [{
3854 key: "componentDidMount",
3855 value: function componentDidMount() {
3856 this.portalNode = document.createElement('div');
3857 this.portalNode.setAttribute(portal.props[0], this.portalId);
3858
3859 if (this.context != null) {
3860 var UNSTABLE_cssCustomProperties = this.context.UNSTABLE_cssCustomProperties;
3861
3862 if (UNSTABLE_cssCustomProperties != null) {
3863 this.portalNode.setAttribute('style', UNSTABLE_cssCustomProperties);
3864 } else {
3865 this.portalNode.removeAttribute('style');
3866 }
3867 }
3868
3869 document.body.appendChild(this.portalNode);
3870 this.setState({
3871 isMounted: true
3872 });
3873 }
3874 }, {
3875 key: "componentDidUpdate",
3876 value: function componentDidUpdate(_, prevState) {
3877 var _this$props$onPortalC = this.props.onPortalCreated,
3878 onPortalCreated = _this$props$onPortalC === void 0 ? noop$2 : _this$props$onPortalC;
3879
3880 if (this.context != null) {
3881 var UNSTABLE_cssCustomProperties = this.context.UNSTABLE_cssCustomProperties;
3882
3883 if (UNSTABLE_cssCustomProperties != null) {
3884 this.portalNode.setAttribute('style', UNSTABLE_cssCustomProperties);
3885 } else {
3886 this.portalNode.removeAttribute('style');
3887 }
3888 }
3889
3890 if (!prevState.isMounted && this.state.isMounted) {
3891 onPortalCreated();
3892 }
3893 }
3894 }, {
3895 key: "componentWillUnmount",
3896 value: function componentWillUnmount() {
3897 document.body.removeChild(this.portalNode);
3898 }
3899 }, {
3900 key: "render",
3901 value: function render() {
3902 return this.state.isMounted ? createPortal(this.props.children, this.portalNode) : null;
3903 }
3904 }]);
3905
3906 return Portal;
3907}(React__default.PureComponent);
3908Portal.defaultProps = {
3909 idPrefix: ''
3910};
3911Portal.contextType = ThemeContext;
3912
3913function noop$2() {}
3914
3915var styles$a = {
3916 "Popover": "Polaris-Popover",
3917 "PopoverOverlay": "Polaris-Popover__PopoverOverlay",
3918 "PopoverOverlay-entering": "Polaris-Popover__PopoverOverlay--entering",
3919 "PopoverOverlay-open": "Polaris-Popover__PopoverOverlay--open",
3920 "PopoverOverlay-exiting": "Polaris-Popover__PopoverOverlay--exiting",
3921 "measuring": "Polaris-Popover--measuring",
3922 "fullWidth": "Polaris-Popover--fullWidth",
3923 "Content": "Polaris-Popover__Content",
3924 "positionedAbove": "Polaris-Popover--positionedAbove",
3925 "Wrapper": "Polaris-Popover__Wrapper",
3926 "Content-fullHeight": "Polaris-Popover__Content--fullHeight",
3927 "Content-fluidContent": "Polaris-Popover__Content--fluidContent",
3928 "Pane": "Polaris-Popover__Pane",
3929 "Pane-fixed": "Polaris-Popover__Pane--fixed",
3930 "Section": "Polaris-Popover__Section",
3931 "FocusTracker": "Polaris-Popover__FocusTracker"
3932};
3933
3934function Section$1(_ref) {
3935 var children = _ref.children;
3936 return React__default.createElement("div", {
3937 className: styles$a.Section
3938 }, children);
3939}
3940
3941function Pane(_ref) {
3942 var fixed = _ref.fixed,
3943 sectioned = _ref.sectioned,
3944 children = _ref.children,
3945 onScrolledToBottom = _ref.onScrolledToBottom;
3946 var className = classNames(styles$a.Pane, fixed && styles$a['Pane-fixed']);
3947 var content = sectioned ? wrapWithComponent(children, Section$1, {}) : children;
3948 return fixed ? React__default.createElement("div", {
3949 className: className
3950 }, content) : React__default.createElement(Scrollable, {
3951 hint: true,
3952 shadow: true,
3953 className: className,
3954 onScrolledToBottom: onScrolledToBottom
3955 }, content);
3956}
3957
3958var EventListener =
3959/*#__PURE__*/
3960function (_React$PureComponent) {
3961 _inherits(EventListener, _React$PureComponent);
3962
3963 function EventListener() {
3964 _classCallCheck(this, EventListener);
3965
3966 return _possibleConstructorReturn(this, _getPrototypeOf(EventListener).apply(this, arguments));
3967 }
3968
3969 _createClass(EventListener, [{
3970 key: "componentDidMount",
3971 value: function componentDidMount() {
3972 this.attachListener();
3973 }
3974 }, {
3975 key: "componentDidUpdate",
3976 value: function componentDidUpdate(_a) {
3977 var passive = _a.passive,
3978 detachProps = __rest(_a, ["passive"]);
3979
3980 this.detachListener(detachProps);
3981 this.attachListener();
3982 }
3983 }, {
3984 key: "componentWillUnmount",
3985 value: function componentWillUnmount() {
3986 this.detachListener();
3987 }
3988 }, {
3989 key: "render",
3990 value: function render() {
3991 return null;
3992 }
3993 }, {
3994 key: "attachListener",
3995 value: function attachListener() {
3996 var _this$props = this.props,
3997 event = _this$props.event,
3998 handler = _this$props.handler,
3999 capture = _this$props.capture,
4000 passive = _this$props.passive;
4001 addEventListener(window, event, handler, {
4002 capture,
4003 passive
4004 });
4005 }
4006 }, {
4007 key: "detachListener",
4008 value: function detachListener(prevProps) {
4009 var _ref = prevProps || this.props,
4010 event = _ref.event,
4011 handler = _ref.handler,
4012 capture = _ref.capture;
4013
4014 removeEventListener(window, event, handler, capture);
4015 }
4016 }]);
4017
4018 return EventListener;
4019}(React__default.PureComponent);
4020
4021var KeypressListener =
4022/*#__PURE__*/
4023function (_React$Component) {
4024 _inherits(KeypressListener, _React$Component);
4025
4026 function KeypressListener() {
4027 var _this;
4028
4029 _classCallCheck(this, KeypressListener);
4030
4031 _this = _possibleConstructorReturn(this, _getPrototypeOf(KeypressListener).apply(this, arguments));
4032
4033 _this.handleKeyEvent = function (event) {
4034 var _this$props = _this.props,
4035 keyCode = _this$props.keyCode,
4036 handler = _this$props.handler;
4037
4038 if (event.keyCode === keyCode) {
4039 handler(event);
4040 }
4041 };
4042
4043 return _this;
4044 }
4045
4046 _createClass(KeypressListener, [{
4047 key: "componentDidMount",
4048 value: function componentDidMount() {
4049 addEventListener(document, 'keyup', this.handleKeyEvent);
4050 }
4051 }, {
4052 key: "componentWillUnmount",
4053 value: function componentWillUnmount() {
4054 removeEventListener(document, 'keyup', this.handleKeyEvent);
4055 }
4056 }, {
4057 key: "render",
4058 value: function render() {
4059 return null;
4060 }
4061 }]);
4062
4063 return KeypressListener;
4064}(React__default.Component);
4065
4066function calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed) {
4067 var activatorTop = activatorRect.top;
4068 var activatorBottom = activatorTop + activatorRect.height;
4069 var spaceAbove = activatorRect.top;
4070 var spaceBelow = containerRect.height - activatorRect.top - activatorRect.height;
4071 var desiredHeight = overlayRect.height;
4072 var verticalMargins = overlayMargins.activator + overlayMargins.container;
4073 var minimumSpaceToScroll = overlayMargins.container;
4074 var distanceToTopScroll = activatorRect.top - Math.max(scrollableContainerRect.top, 0);
4075 var distanceToBottomScroll = containerRect.top + Math.min(containerRect.height, scrollableContainerRect.top + scrollableContainerRect.height) - (activatorRect.top + activatorRect.height);
4076 var enoughSpaceFromTopScroll = distanceToTopScroll >= minimumSpaceToScroll;
4077 var enoughSpaceFromBottomScroll = distanceToBottomScroll >= minimumSpaceToScroll;
4078 var heightIfBelow = Math.min(spaceBelow, desiredHeight);
4079 var heightIfAbove = Math.min(spaceAbove, desiredHeight);
4080 var containerRectTop = fixed ? 0 : containerRect.top;
4081 var positionIfAbove = {
4082 height: heightIfAbove - verticalMargins,
4083 top: activatorTop + containerRectTop - heightIfAbove,
4084 positioning: 'above'
4085 };
4086 var positionIfBelow = {
4087 height: heightIfBelow - verticalMargins,
4088 top: activatorBottom + containerRectTop,
4089 positioning: 'below'
4090 };
4091
4092 if (preferredPosition === 'above') {
4093 return (enoughSpaceFromTopScroll || distanceToTopScroll >= distanceToBottomScroll && !enoughSpaceFromBottomScroll) && (spaceAbove > desiredHeight || spaceAbove > spaceBelow) ? positionIfAbove : positionIfBelow;
4094 }
4095
4096 if (preferredPosition === 'below') {
4097 return (enoughSpaceFromBottomScroll || distanceToBottomScroll >= distanceToTopScroll && !enoughSpaceFromTopScroll) && (spaceBelow > desiredHeight || spaceBelow > spaceAbove) ? positionIfBelow : positionIfAbove;
4098 }
4099
4100 if (enoughSpaceFromTopScroll && enoughSpaceFromBottomScroll) {
4101 return spaceAbove > spaceBelow ? positionIfAbove : positionIfBelow;
4102 }
4103
4104 return distanceToTopScroll > minimumSpaceToScroll ? positionIfAbove : positionIfBelow;
4105}
4106function calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment) {
4107 var maximum = containerRect.width - overlayRect.width;
4108
4109 if (preferredAlignment === 'left') {
4110 return Math.min(maximum, Math.max(0, activatorRect.left - overlayMargins.horizontal));
4111 } else if (preferredAlignment === 'right') {
4112 var activatorRight = activatorRect.left + activatorRect.width;
4113 return Math.min(maximum, Math.max(0, activatorRight - overlayRect.width + overlayMargins.horizontal));
4114 }
4115
4116 return Math.min(maximum, Math.max(0, activatorRect.center.x - overlayRect.width / 2));
4117}
4118function rectIsOutsideOfRect(inner, outer) {
4119 var center = inner.center;
4120 return center.y < outer.top || center.y > outer.top + outer.height;
4121}
4122
4123var styles$b = {
4124 "PositionedOverlay": "Polaris-PositionedOverlay",
4125 "fixed": "Polaris-PositionedOverlay--fixed",
4126 "calculating": "Polaris-PositionedOverlay--calculating"
4127};
4128
4129var OBSERVER_CONFIG = {
4130 childList: true,
4131 subtree: true
4132};
4133var PositionedOverlay =
4134/*#__PURE__*/
4135function (_React$PureComponent) {
4136 _inherits(PositionedOverlay, _React$PureComponent);
4137
4138 function PositionedOverlay(props) {
4139 var _this;
4140
4141 _classCallCheck(this, PositionedOverlay);
4142
4143 _this = _possibleConstructorReturn(this, _getPrototypeOf(PositionedOverlay).call(this, props));
4144 _this.state = {
4145 measuring: true,
4146 activatorRect: getRectForNode(_this.props.activator),
4147 left: 0,
4148 top: 0,
4149 height: 0,
4150 width: null,
4151 positioning: 'below',
4152 zIndex: null,
4153 outsideScrollableContainer: false,
4154 lockPosition: false
4155 };
4156 _this.overlay = null;
4157 _this.scrollableContainer = null;
4158
4159 _this.overlayDetails = function () {
4160 var _this$state = _this.state,
4161 measuring = _this$state.measuring,
4162 left = _this$state.left,
4163 positioning = _this$state.positioning,
4164 height = _this$state.height,
4165 activatorRect = _this$state.activatorRect;
4166 return {
4167 measuring,
4168 left,
4169 desiredHeight: height,
4170 positioning,
4171 activatorRect
4172 };
4173 };
4174
4175 _this.setOverlay = function (node) {
4176 _this.overlay = node;
4177 };
4178
4179 _this.handleMeasurement = function () {
4180 var _this$state2 = _this.state,
4181 lockPosition = _this$state2.lockPosition,
4182 top = _this$state2.top;
4183
4184 _this.observer.disconnect();
4185
4186 _this.setState(function (_ref) {
4187 var left = _ref.left,
4188 top = _ref.top;
4189 return {
4190 left,
4191 top,
4192 height: 0,
4193 positioning: 'below',
4194 measuring: true
4195 };
4196 }, function () {
4197 if (_this.overlay == null || _this.scrollableContainer == null) {
4198 return;
4199 }
4200
4201 var _this$props = _this.props,
4202 activator = _this$props.activator,
4203 _this$props$preferred = _this$props.preferredPosition,
4204 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred,
4205 _this$props$preferred2 = _this$props.preferredAlignment,
4206 preferredAlignment = _this$props$preferred2 === void 0 ? 'center' : _this$props$preferred2,
4207 onScrollOut = _this$props.onScrollOut,
4208 fullWidth = _this$props.fullWidth,
4209 fixed = _this$props.fixed;
4210 var textFieldActivator = activator.querySelector('input');
4211 var activatorRect = textFieldActivator != null ? getRectForNode(textFieldActivator) : getRectForNode(activator);
4212 var currentOverlayRect = getRectForNode(_this.overlay);
4213 var scrollableElement = isDocument$1(_this.scrollableContainer) ? document.body : _this.scrollableContainer;
4214 var scrollableContainerRect = getRectForNode(scrollableElement);
4215 var overlayRect = fullWidth ? Object.assign({}, currentOverlayRect, {
4216 width: activatorRect.width
4217 }) : currentOverlayRect; // If `body` is 100% height, it still acts as though it were not constrained to that size. This adjusts for that.
4218
4219 if (scrollableElement === document.body) {
4220 scrollableContainerRect.height = document.body.scrollHeight;
4221 }
4222
4223 var overlayMargins = _this.overlay.firstElementChild ? getMarginsForNode(_this.overlay.firstElementChild) : {
4224 activator: 0,
4225 container: 0,
4226 horizontal: 0
4227 };
4228 var containerRect = windowRect();
4229 var zIndexForLayer = getZIndexForLayerFromNode(activator);
4230 var zIndex = zIndexForLayer == null ? zIndexForLayer : zIndexForLayer + 1;
4231 var verticalPosition = calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed);
4232 var horizontalPosition = calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment);
4233
4234 _this.setState({
4235 measuring: false,
4236 activatorRect: getRectForNode(activator),
4237 left: horizontalPosition,
4238 top: lockPosition ? top : verticalPosition.top,
4239 lockPosition: Boolean(fixed),
4240 height: verticalPosition.height || 0,
4241 width: fullWidth ? overlayRect.width : null,
4242 positioning: verticalPosition.positioning,
4243 outsideScrollableContainer: onScrollOut != null && rectIsOutsideOfRect(activatorRect, intersectionWithViewport(scrollableContainerRect)),
4244 zIndex
4245 }, function () {
4246 if (!_this.overlay) return;
4247
4248 _this.observer.observe(_this.overlay, OBSERVER_CONFIG);
4249 });
4250 });
4251 };
4252
4253 _this.observer = new MutationObserver(_this.handleMeasurement);
4254 return _this;
4255 }
4256
4257 _createClass(PositionedOverlay, [{
4258 key: "componentDidMount",
4259 value: function componentDidMount() {
4260 this.scrollableContainer = Scrollable.forNode(this.props.activator);
4261
4262 if (this.scrollableContainer && !this.props.fixed) {
4263 this.scrollableContainer.addEventListener('scroll', this.handleMeasurement);
4264 }
4265
4266 this.handleMeasurement();
4267 }
4268 }, {
4269 key: "componentWillUnmount",
4270 value: function componentWillUnmount() {
4271 if (this.scrollableContainer && !this.props.fixed) {
4272 this.scrollableContainer.removeEventListener('scroll', this.handleMeasurement);
4273 }
4274 }
4275 }, {
4276 key: "componentDidUpdate",
4277 value: function componentDidUpdate() {
4278 var _this$state3 = this.state,
4279 outsideScrollableContainer = _this$state3.outsideScrollableContainer,
4280 top = _this$state3.top;
4281 var _this$props2 = this.props,
4282 onScrollOut = _this$props2.onScrollOut,
4283 active = _this$props2.active;
4284
4285 if (active && onScrollOut != null && top !== 0 && outsideScrollableContainer) {
4286 onScrollOut();
4287 }
4288 }
4289 }, {
4290 key: "render",
4291 value: function render() {
4292 var _this$state4 = this.state,
4293 left = _this$state4.left,
4294 top = _this$state4.top,
4295 zIndex = _this$state4.zIndex,
4296 width = _this$state4.width;
4297 var _this$props3 = this.props,
4298 render = _this$props3.render,
4299 fixed = _this$props3.fixed,
4300 propClassNames = _this$props3.classNames;
4301 var style = {
4302 top: top == null || isNaN(top) ? undefined : top,
4303 left: left == null || isNaN(left) ? undefined : left,
4304 width: width == null || isNaN(width) ? undefined : width,
4305 zIndex: zIndex == null || isNaN(zIndex) ? undefined : zIndex
4306 };
4307 var className = classNames(styles$b.PositionedOverlay, fixed && styles$b.fixed, propClassNames);
4308 return React__default.createElement("div", {
4309 className: className,
4310 style: style,
4311 ref: this.setOverlay
4312 }, React__default.createElement(EventListener, {
4313 event: "resize",
4314 handler: this.handleMeasurement
4315 }), render(this.overlayDetails()));
4316 }
4317 }]);
4318
4319 return PositionedOverlay;
4320}(React__default.PureComponent);
4321function intersectionWithViewport(rect) {
4322 var viewport = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : windowRect();
4323 var top = Math.max(rect.top, 0);
4324 var left = Math.max(rect.left, 0);
4325 var bottom = Math.min(rect.top + rect.height, viewport.height);
4326 var right = Math.min(rect.left + rect.width, viewport.width);
4327 return new Rect({
4328 top,
4329 left,
4330 height: bottom - top,
4331 width: right - left
4332 });
4333}
4334
4335function getMarginsForNode(node) {
4336 var nodeStyles = window.getComputedStyle(node);
4337 return {
4338 activator: parseFloat(nodeStyles.marginTop || ''),
4339 container: parseFloat(nodeStyles.marginBottom || ''),
4340 horizontal: parseFloat(nodeStyles.marginLeft || '')
4341 };
4342}
4343
4344function getZIndexForLayerFromNode(node) {
4345 var layerNode = closest(node, layer.selector) || document.body;
4346 var zIndex = layerNode === document.body ? 'auto' : parseInt(window.getComputedStyle(layerNode).zIndex || '0', 10);
4347 return zIndex === 'auto' || isNaN(zIndex) ? null : zIndex;
4348}
4349
4350function windowRect() {
4351 return new Rect({
4352 top: window.scrollY,
4353 left: window.scrollX,
4354 height: window.innerHeight,
4355 width: window.innerWidth
4356 });
4357}
4358
4359function isDocument$1(node) {
4360 return node === document;
4361}
4362
4363var CloseSource;
4364
4365(function (CloseSource) {
4366 CloseSource[CloseSource["Click"] = 0] = "Click";
4367 CloseSource[CloseSource["EscapeKeypress"] = 1] = "EscapeKeypress";
4368 CloseSource[CloseSource["FocusOut"] = 2] = "FocusOut";
4369 CloseSource[CloseSource["ScrollOut"] = 3] = "ScrollOut";
4370})(CloseSource || (CloseSource = {}));
4371
4372var TransitionStatus;
4373
4374(function (TransitionStatus) {
4375 TransitionStatus["Entering"] = "entering";
4376 TransitionStatus["Entered"] = "entered";
4377 TransitionStatus["Exiting"] = "exiting";
4378 TransitionStatus["Exited"] = "exited";
4379})(TransitionStatus || (TransitionStatus = {}));
4380
4381var PopoverOverlay =
4382/*#__PURE__*/
4383function (_React$PureComponent) {
4384 _inherits(PopoverOverlay, _React$PureComponent);
4385
4386 function PopoverOverlay() {
4387 var _this;
4388
4389 _classCallCheck(this, PopoverOverlay);
4390
4391 _this = _possibleConstructorReturn(this, _getPrototypeOf(PopoverOverlay).apply(this, arguments));
4392 _this.state = {
4393 transitionStatus: _this.props.active ? TransitionStatus.Entering : TransitionStatus.Exited
4394 };
4395 _this.contentNode = createRef();
4396
4397 _this.renderPopover = function (overlayDetails) {
4398 var measuring = overlayDetails.measuring,
4399 desiredHeight = overlayDetails.desiredHeight,
4400 positioning = overlayDetails.positioning;
4401 var _this$props = _this.props,
4402 id = _this$props.id,
4403 children = _this$props.children,
4404 sectioned = _this$props.sectioned,
4405 fullWidth = _this$props.fullWidth,
4406 fullHeight = _this$props.fullHeight,
4407 fluidContent = _this$props.fluidContent;
4408 var className = classNames(styles$a.Popover, positioning === 'above' && styles$a.positionedAbove, fullWidth && styles$a.fullWidth, measuring && styles$a.measuring);
4409 var contentStyles = measuring ? undefined : {
4410 height: desiredHeight
4411 };
4412 var contentClassNames = classNames(styles$a.Content, fullHeight && styles$a['Content-fullHeight'], fluidContent && styles$a['Content-fluidContent']);
4413 var content = React__default.createElement("div", {
4414 id: id,
4415 tabIndex: -1,
4416 className: contentClassNames,
4417 style: contentStyles,
4418 ref: _this.contentNode
4419 }, renderPopoverContent(children, {
4420 sectioned
4421 }));
4422 return React__default.createElement("div", Object.assign({
4423 className: className
4424 }, overlay.props), React__default.createElement(EventListener, {
4425 event: "click",
4426 handler: _this.handleClick
4427 }), React__default.createElement(EventListener, {
4428 event: "touchstart",
4429 handler: _this.handleClick
4430 }), React__default.createElement(KeypressListener, {
4431 keyCode: Key.Escape,
4432 handler: _this.handleEscape
4433 }), React__default.createElement("div", {
4434 className: styles$a.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
4435 ,
4436 tabIndex: 0,
4437 onFocus: _this.handleFocusFirstItem
4438 }), React__default.createElement("div", {
4439 className: styles$a.Wrapper
4440 }, content), React__default.createElement("div", {
4441 className: styles$a.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
4442 ,
4443 tabIndex: 0,
4444 onFocus: _this.handleFocusLastItem
4445 }));
4446 };
4447
4448 _this.handleClick = function (event) {
4449 var target = event.target;
4450
4451 var _assertThisInitialize = _assertThisInitialized(_this),
4452 contentNode = _assertThisInitialize.contentNode,
4453 _assertThisInitialize2 = _assertThisInitialize.props,
4454 activator = _assertThisInitialize2.activator,
4455 onClose = _assertThisInitialize2.onClose;
4456
4457 var isDescendant = contentNode.current != null && nodeContainsDescendant(contentNode.current, target);
4458 var isActivatorDescendant = nodeContainsDescendant(activator, target);
4459
4460 if (isDescendant || isActivatorDescendant || _this.state.transitionStatus !== TransitionStatus.Entered) {
4461 return;
4462 }
4463
4464 onClose(CloseSource.Click);
4465 };
4466
4467 _this.handleScrollOut = function () {
4468 _this.props.onClose(CloseSource.ScrollOut);
4469 };
4470
4471 _this.handleEscape = function () {
4472 _this.props.onClose(CloseSource.EscapeKeypress);
4473 };
4474
4475 _this.handleFocusFirstItem = function () {
4476 _this.props.onClose(CloseSource.FocusOut);
4477 };
4478
4479 _this.handleFocusLastItem = function () {
4480 _this.props.onClose(CloseSource.FocusOut);
4481 };
4482
4483 return _this;
4484 }
4485
4486 _createClass(PopoverOverlay, [{
4487 key: "changeTransitionStatus",
4488 value: function changeTransitionStatus(transitionStatus, cb) {
4489 this.setState({
4490 transitionStatus
4491 }, cb); // Forcing a reflow to enable the animation
4492
4493 this.contentNode.current && this.contentNode.current.getBoundingClientRect();
4494 }
4495 }, {
4496 key: "componentDidMount",
4497 value: function componentDidMount() {
4498 if (this.props.active) {
4499 this.focusContent();
4500 this.changeTransitionStatus(TransitionStatus.Entered);
4501 }
4502 }
4503 }, {
4504 key: "componentDidUpdate",
4505 value: function componentDidUpdate(oldProps) {
4506 var _this2 = this;
4507
4508 if (this.props.active && !oldProps.active) {
4509 this.focusContent();
4510 this.changeTransitionStatus(TransitionStatus.Entering, function () {
4511 _this2.clearTransitionTimeout();
4512
4513 _this2.enteringTimer = window.setTimeout(function () {
4514 _this2.setState({
4515 transitionStatus: TransitionStatus.Entered
4516 });
4517 }, durationBase);
4518 });
4519 }
4520
4521 if (!this.props.active && oldProps.active) {
4522 this.changeTransitionStatus(TransitionStatus.Exiting, function () {
4523 _this2.clearTransitionTimeout();
4524
4525 _this2.exitingTimer = window.setTimeout(function () {
4526 _this2.setState({
4527 transitionStatus: TransitionStatus.Exited
4528 });
4529 }, durationBase);
4530 });
4531 }
4532 }
4533 }, {
4534 key: "componentWillUnmount",
4535 value: function componentWillUnmount() {
4536 this.clearTransitionTimeout();
4537 }
4538 }, {
4539 key: "render",
4540 value: function render() {
4541 var _this$props2 = this.props,
4542 active = _this$props2.active,
4543 activator = _this$props2.activator,
4544 fullWidth = _this$props2.fullWidth,
4545 _this$props2$preferre = _this$props2.preferredPosition,
4546 preferredPosition = _this$props2$preferre === void 0 ? 'below' : _this$props2$preferre,
4547 _this$props2$preferre2 = _this$props2.preferredAlignment,
4548 preferredAlignment = _this$props2$preferre2 === void 0 ? 'center' : _this$props2$preferre2,
4549 fixed = _this$props2.fixed;
4550 var transitionStatus = this.state.transitionStatus;
4551 if (transitionStatus === TransitionStatus.Exited && !active) return null;
4552 var className = classNames(styles$a.PopoverOverlay, transitionStatus === TransitionStatus.Entering && styles$a['PopoverOverlay-entering'], transitionStatus === TransitionStatus.Entered && styles$a['PopoverOverlay-open'], transitionStatus === TransitionStatus.Exiting && styles$a['PopoverOverlay-exiting']);
4553 return React__default.createElement(PositionedOverlay, {
4554 fullWidth: fullWidth,
4555 active: active,
4556 activator: activator,
4557 preferredPosition: preferredPosition,
4558 preferredAlignment: preferredAlignment,
4559 render: this.renderPopover.bind(this),
4560 fixed: fixed,
4561 onScrollOut: this.handleScrollOut,
4562 classNames: className
4563 });
4564 }
4565 }, {
4566 key: "clearTransitionTimeout",
4567 value: function clearTransitionTimeout() {
4568 if (this.enteringTimer) {
4569 window.clearTimeout(this.enteringTimer);
4570 }
4571
4572 if (this.exitingTimer) {
4573 window.clearTimeout(this.exitingTimer);
4574 }
4575 }
4576 }, {
4577 key: "focusContent",
4578 value: function focusContent() {
4579 var _this3 = this;
4580
4581 if (this.props.preventAutofocus) {
4582 return;
4583 }
4584
4585 if (this.contentNode == null) {
4586 return;
4587 }
4588
4589 write(function () {
4590 if (_this3.contentNode.current == null) {
4591 return;
4592 }
4593
4594 _this3.contentNode.current.focus({
4595 preventScroll: process.env.NODE_ENV === 'development'
4596 });
4597 });
4598 }
4599 }]);
4600
4601 return PopoverOverlay;
4602}(React__default.PureComponent);
4603
4604function renderPopoverContent(children, props) {
4605 var childrenArray = React__default.Children.toArray(children);
4606
4607 if (isElementOfType(childrenArray[0], Pane)) {
4608 return childrenArray;
4609 }
4610
4611 return wrapWithComponent(childrenArray, Pane, props);
4612}
4613
4614function setActivatorAttributes(activator, _ref) {
4615 var id = _ref.id,
4616 active = _ref.active,
4617 ariaHaspopup = _ref.ariaHaspopup;
4618 activator.tabIndex = activator.tabIndex || 0;
4619 activator.setAttribute('aria-controls', id);
4620 activator.setAttribute('aria-owns', id);
4621 activator.setAttribute('aria-expanded', String(active));
4622
4623 if (ariaHaspopup != null) {
4624 activator.setAttribute('aria-haspopup', String(ariaHaspopup));
4625 }
4626}
4627
4628// subcomponents so explicitly state the subcomponents in the type definition.
4629// Letting this be implicit works in this project but fails in projects that use
4630// generated *.d.ts files.
4631
4632var Popover = function Popover(_a) {
4633 var _a$activatorWrapper = _a.activatorWrapper,
4634 activatorWrapper = _a$activatorWrapper === void 0 ? 'div' : _a$activatorWrapper,
4635 children = _a.children,
4636 onClose = _a.onClose,
4637 activator = _a.activator,
4638 active = _a.active,
4639 fixed = _a.fixed,
4640 ariaHaspopup = _a.ariaHaspopup,
4641 rest = __rest(_a, ["activatorWrapper", "children", "onClose", "activator", "active", "fixed", "ariaHaspopup"]);
4642
4643 var _useState = useState(),
4644 _useState2 = _slicedToArray(_useState, 2),
4645 activatorNode = _useState2[0],
4646 setActivatorNode = _useState2[1];
4647
4648 var activatorContainer = useRef(null);
4649 var WrapperComponent = activatorWrapper;
4650 var id = useUniqueId('popover');
4651 var setAccessibilityAttributes = useCallback(function () {
4652 if (activatorContainer.current == null) {
4653 return;
4654 }
4655
4656 var firstFocusable = findFirstFocusableNode(activatorContainer.current);
4657 var focusableActivator = firstFocusable || activatorContainer.current;
4658 setActivatorAttributes(focusableActivator, {
4659 id,
4660 active,
4661 ariaHaspopup
4662 });
4663 }, [active, ariaHaspopup, id]);
4664
4665 var handleClose = function handleClose(source) {
4666 onClose(source);
4667
4668 if (activatorContainer.current == null) {
4669 return;
4670 }
4671
4672 if ((source === CloseSource.FocusOut || source === CloseSource.EscapeKeypress) && activatorNode) {
4673 var focusableActivator = findFirstFocusableNode(activatorNode) || findFirstFocusableNode(activatorContainer.current) || activatorContainer.current;
4674
4675 if (!focusNextFocusableNode(focusableActivator, isInPortal)) {
4676 focusableActivator.focus();
4677 }
4678 }
4679 };
4680
4681 useEffect(function () {
4682 if (!activatorNode && activatorContainer.current) {
4683 setActivatorNode(activatorContainer.current.firstElementChild);
4684 } else if (activatorNode && activatorContainer.current && !activatorContainer.current.contains(activatorNode)) {
4685 setActivatorNode(activatorContainer.current.firstElementChild);
4686 }
4687
4688 setAccessibilityAttributes();
4689 }, [activatorNode, setAccessibilityAttributes]);
4690 useEffect(function () {
4691 if (activatorNode && activatorContainer.current) {
4692 setActivatorNode(activatorContainer.current.firstElementChild);
4693 }
4694
4695 setAccessibilityAttributes();
4696 }, [activatorNode, setAccessibilityAttributes]);
4697 var portal = activatorNode ? React__default.createElement(Portal, {
4698 idPrefix: "popover"
4699 }, React__default.createElement(PopoverOverlay, Object.assign({
4700 id: id,
4701 activator: activatorNode,
4702 onClose: handleClose,
4703 active: active,
4704 fixed: fixed
4705 }, rest), children)) : null;
4706 return React__default.createElement(WrapperComponent, {
4707 ref: activatorContainer
4708 }, React__default.Children.only(activator), portal);
4709};
4710
4711function isInPortal(element) {
4712 var parentElement = element.parentElement;
4713
4714 while (parentElement) {
4715 if (parentElement.matches(portal.selector)) return false;
4716 parentElement = parentElement.parentElement;
4717 }
4718
4719 return true;
4720}
4721
4722Popover.Pane = Pane;
4723Popover.Section = Section$1;
4724
4725var styles$c = {
4726 "Stack": "Polaris-Stack",
4727 "Item": "Polaris-Stack__Item",
4728 "noWrap": "Polaris-Stack--noWrap",
4729 "spacingNone": "Polaris-Stack--spacingNone",
4730 "spacingExtraTight": "Polaris-Stack--spacingExtraTight",
4731 "spacingTight": "Polaris-Stack--spacingTight",
4732 "spacingLoose": "Polaris-Stack--spacingLoose",
4733 "spacingExtraLoose": "Polaris-Stack--spacingExtraLoose",
4734 "distributionLeading": "Polaris-Stack--distributionLeading",
4735 "distributionTrailing": "Polaris-Stack--distributionTrailing",
4736 "distributionCenter": "Polaris-Stack--distributionCenter",
4737 "distributionEqualSpacing": "Polaris-Stack--distributionEqualSpacing",
4738 "distributionFill": "Polaris-Stack--distributionFill",
4739 "distributionFillEvenly": "Polaris-Stack--distributionFillEvenly",
4740 "alignmentLeading": "Polaris-Stack--alignmentLeading",
4741 "alignmentTrailing": "Polaris-Stack--alignmentTrailing",
4742 "alignmentCenter": "Polaris-Stack--alignmentCenter",
4743 "alignmentFill": "Polaris-Stack--alignmentFill",
4744 "alignmentBaseline": "Polaris-Stack--alignmentBaseline",
4745 "vertical": "Polaris-Stack--vertical",
4746 "Item-fill": "Polaris-Stack__Item--fill"
4747};
4748
4749function Item$2(_ref) {
4750 var children = _ref.children,
4751 fill = _ref.fill;
4752 var className = classNames(styles$c.Item, fill && styles$c['Item-fill']);
4753 return React__default.createElement("div", {
4754 className: className
4755 }, children);
4756}
4757
4758var Stack =
4759/*#__PURE__*/
4760function (_React$PureComponent) {
4761 _inherits(Stack, _React$PureComponent);
4762
4763 function Stack() {
4764 _classCallCheck(this, Stack);
4765
4766 return _possibleConstructorReturn(this, _getPrototypeOf(Stack).apply(this, arguments));
4767 }
4768
4769 _createClass(Stack, [{
4770 key: "render",
4771 value: function render() {
4772 var _this$props = this.props,
4773 children = _this$props.children,
4774 vertical = _this$props.vertical,
4775 spacing = _this$props.spacing,
4776 distribution = _this$props.distribution,
4777 alignment = _this$props.alignment,
4778 wrap = _this$props.wrap;
4779 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);
4780 var itemMarkup = elementChildren(children).map(function (child, index) {
4781 var props = {
4782 key: index
4783 };
4784 return wrapWithComponent(child, Item$2, props);
4785 });
4786 return React__default.createElement("div", {
4787 className: className
4788 }, itemMarkup);
4789 }
4790 }]);
4791
4792 return Stack;
4793}(React__default.PureComponent);
4794Stack.Item = Item$2;
4795
4796var styles$d = {
4797 "Heading": "Polaris-Heading"
4798};
4799
4800function Heading(_ref) {
4801 var _ref$element = _ref.element,
4802 Element = _ref$element === void 0 ? 'h2' : _ref$element,
4803 children = _ref.children;
4804 return React__default.createElement(Element, {
4805 className: styles$d.Heading
4806 }, children);
4807}
4808
4809var styles$e = {
4810 "Card": "Polaris-Card",
4811 "subdued": "Polaris-Card--subdued",
4812 "Header": "Polaris-Card__Header",
4813 "Section": "Polaris-Card__Section",
4814 "Section-fullWidth": "Polaris-Card__Section--fullWidth",
4815 "Section-subdued": "Polaris-Card__Section--subdued",
4816 "SectionHeader": "Polaris-Card__SectionHeader",
4817 "Subsection": "Polaris-Card__Subsection",
4818 "Footer": "Polaris-Card__Footer",
4819 "LeftJustified": "Polaris-Card__LeftJustified"
4820};
4821
4822function Header(_ref) {
4823 var children = _ref.children,
4824 title = _ref.title,
4825 actions = _ref.actions;
4826 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
4827 plain: true
4828 })) : null;
4829 var titleMarkup = React__default.isValidElement(title) ? title : React__default.createElement(Heading, null, title);
4830 var headingMarkup = actionMarkup || children ? React__default.createElement(Stack, {
4831 alignment: "baseline"
4832 }, React__default.createElement(Stack.Item, {
4833 fill: true
4834 }, titleMarkup), actionMarkup, children) : titleMarkup;
4835 return React__default.createElement("div", {
4836 className: styles$e.Header
4837 }, headingMarkup);
4838}
4839
4840var styles$f = {
4841 "Subheading": "Polaris-Subheading"
4842};
4843
4844function Subheading(_ref) {
4845 var _ref$element = _ref.element,
4846 Element = _ref$element === void 0 ? 'h3' : _ref$element,
4847 children = _ref.children;
4848 var ariaLabel = typeof children === 'string' ? children : undefined;
4849 return React__default.createElement(Element, {
4850 "aria-label": ariaLabel,
4851 className: styles$f.Subheading
4852 }, children);
4853}
4854
4855function Section$2(_ref) {
4856 var children = _ref.children,
4857 title = _ref.title,
4858 subdued = _ref.subdued,
4859 fullWidth = _ref.fullWidth,
4860 actions = _ref.actions;
4861 var className = classNames(styles$e.Section, subdued && styles$e['Section-subdued'], fullWidth && styles$e['Section-fullWidth']);
4862 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
4863 plain: true
4864 })) : null;
4865 var titleMarkup = typeof title === 'string' ? React__default.createElement(Subheading, null, title) : title;
4866 var titleAreaMarkup = titleMarkup || actionMarkup ? React__default.createElement("div", {
4867 className: styles$e.SectionHeader
4868 }, actionMarkup ? React__default.createElement(Stack, {
4869 alignment: "baseline"
4870 }, React__default.createElement(Stack.Item, {
4871 fill: true
4872 }, titleMarkup), actionMarkup) : titleMarkup) : null;
4873 return React__default.createElement("div", {
4874 className: className
4875 }, titleAreaMarkup, children);
4876}
4877
4878function Subsection(_ref) {
4879 var children = _ref.children;
4880 return React__default.createElement("div", {
4881 className: styles$e.Subsection
4882 }, children);
4883}
4884
4885// subcomponents so explicitly state the subcomponents in the type definition.
4886// Letting this be implicit works in this project but fails in projects that use
4887// generated *.d.ts files.
4888
4889var Card = function Card(_ref) {
4890 var children = _ref.children,
4891 title = _ref.title,
4892 subdued = _ref.subdued,
4893 sectioned = _ref.sectioned,
4894 actions = _ref.actions,
4895 primaryFooterAction = _ref.primaryFooterAction,
4896 secondaryFooterActions = _ref.secondaryFooterActions,
4897 secondaryFooterActionsDisclosureText = _ref.secondaryFooterActionsDisclosureText,
4898 _ref$footerActionAlig = _ref.footerActionAlignment,
4899 footerActionAlignment = _ref$footerActionAlig === void 0 ? 'right' : _ref$footerActionAlig;
4900 var i18n = useI18n();
4901
4902 var _useToggle = useToggle(false),
4903 _useToggle2 = _slicedToArray(_useToggle, 2),
4904 secondaryActionsPopoverOpen = _useToggle2[0],
4905 toggleSecondaryActionsPopoverOpen = _useToggle2[1];
4906
4907 var className = classNames(styles$e.Card, subdued && styles$e.subdued);
4908 var headerMarkup = title || actions ? React__default.createElement(Header, {
4909 actions: actions,
4910 title: title
4911 }) : null;
4912 var content = sectioned ? React__default.createElement(Section$2, null, children) : children;
4913 var primaryFooterActionMarkup = primaryFooterAction ? buttonFrom(primaryFooterAction, {
4914 primary: true
4915 }) : null;
4916 var secondaryFooterActionsMarkup = null;
4917
4918 if (secondaryFooterActions && secondaryFooterActions.length) {
4919 if (secondaryFooterActions.length === 1) {
4920 secondaryFooterActionsMarkup = buttonFrom(secondaryFooterActions[0]);
4921 } else {
4922 secondaryFooterActionsMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(Popover, {
4923 active: secondaryActionsPopoverOpen,
4924 activator: React__default.createElement(Button, {
4925 disclosure: true,
4926 onClick: toggleSecondaryActionsPopoverOpen
4927 }, secondaryFooterActionsDisclosureText || i18n.translate('Polaris.Common.more')),
4928 onClose: toggleSecondaryActionsPopoverOpen
4929 }, React__default.createElement(ActionList, {
4930 items: secondaryFooterActions
4931 })));
4932 }
4933 }
4934
4935 var footerMarkup = primaryFooterActionMarkup || secondaryFooterActionsMarkup ? React__default.createElement("div", {
4936 className: classNames(styles$e.Footer, footerActionAlignment === 'left' && styles$e.LeftJustified)
4937 }, footerActionAlignment === 'right' ? React__default.createElement(ButtonGroup, null, secondaryFooterActionsMarkup, primaryFooterActionMarkup) : React__default.createElement(ButtonGroup, null, primaryFooterActionMarkup, secondaryFooterActionsMarkup)) : null;
4938 return React__default.createElement(WithinContentContext.Provider, {
4939 value: true
4940 }, React__default.createElement("div", {
4941 className: className
4942 }, headerMarkup, content, footerMarkup));
4943};
4944Card.Header = Header;
4945Card.Section = Section$2;
4946Card.Subsection = Subsection;
4947
4948var styles$g = {
4949 "SettingAction": "Polaris-SettingAction",
4950 "Setting": "Polaris-SettingAction__Setting",
4951 "Action": "Polaris-SettingAction__Action"
4952};
4953
4954function SettingAction(_ref) {
4955 var action = _ref.action,
4956 children = _ref.children;
4957 return React__default.createElement("div", {
4958 className: styles$g.SettingAction
4959 }, React__default.createElement("div", {
4960 className: styles$g.Setting
4961 }, children), React__default.createElement("div", {
4962 className: styles$g.Action
4963 }, action));
4964}
4965
4966var styles$h = {
4967 "TermsOfService": "Polaris-AccountConnection__TermsOfService",
4968 "Content": "Polaris-AccountConnection__Content"
4969};
4970
4971function AccountConnection(_ref) {
4972 var _ref$connected = _ref.connected,
4973 connected = _ref$connected === void 0 ? false : _ref$connected,
4974 action = _ref.action,
4975 avatarUrl = _ref.avatarUrl,
4976 _ref$accountName = _ref.accountName,
4977 accountName = _ref$accountName === void 0 ? '' : _ref$accountName,
4978 title = _ref.title,
4979 details = _ref.details,
4980 termsOfService = _ref.termsOfService;
4981 var initials = accountName ? accountName.split(/\s+/).map(function (name) {
4982 return name[0];
4983 }).join('') : undefined;
4984 var avatarMarkup = connected ? React__default.createElement(Avatar, {
4985 accessibilityLabel: "",
4986 name: accountName,
4987 initials: initials,
4988 source: avatarUrl
4989 }) : null;
4990 var titleMarkup = null;
4991
4992 if (title) {
4993 titleMarkup = React__default.createElement("div", null, title);
4994 } else if (accountName) {
4995 titleMarkup = React__default.createElement("div", null, accountName);
4996 }
4997
4998 var detailsMarkup = details ? React__default.createElement("div", null, React__default.createElement(TextStyle, {
4999 variation: "subdued"
5000 }, details)) : null;
5001 var termsOfServiceMarkup = termsOfService ? React__default.createElement("div", {
5002 className: styles$h.TermsOfService
5003 }, termsOfService) : null;
5004 var actionElement = action ? buttonFrom(action, {
5005 primary: !connected
5006 }) : null;
5007 return React__default.createElement(Card, {
5008 sectioned: true
5009 }, React__default.createElement(SettingAction, {
5010 action: actionElement
5011 }, React__default.createElement(Stack, null, avatarMarkup, React__default.createElement(Stack.Item, {
5012 fill: true
5013 }, React__default.createElement("div", {
5014 className: styles$h.Content
5015 }, titleMarkup, detailsMarkup)))), termsOfServiceMarkup);
5016}
5017
5018var styles$i = {
5019 "MenuAction": "Polaris-ActionMenu-MenuAction",
5020 "IconWrapper": "Polaris-ActionMenu-MenuAction__IconWrapper",
5021 "disabled": "Polaris-ActionMenu-MenuAction--disabled",
5022 "ContentWrapper": "Polaris-ActionMenu-MenuAction__ContentWrapper"
5023};
5024
5025function MenuAction(_ref) {
5026 var content = _ref.content,
5027 accessibilityLabel = _ref.accessibilityLabel,
5028 url = _ref.url,
5029 external = _ref.external,
5030 icon = _ref.icon,
5031 disclosure = _ref.disclosure,
5032 disabled = _ref.disabled,
5033 onAction = _ref.onAction;
5034 var iconMarkup = icon && React__default.createElement("span", {
5035 className: styles$i.IconWrapper
5036 }, React__default.createElement(Icon, {
5037 source: icon
5038 }));
5039 var disclosureIconMarkup = disclosure && React__default.createElement("span", {
5040 className: styles$i.IconWrapper
5041 }, React__default.createElement(Icon, {
5042 source: CaretDownMinor
5043 }));
5044 var contentMarkup = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
5045 className: styles$i.ContentWrapper
5046 }, iconMarkup, React__default.createElement("span", {
5047 className: styles$i.Content
5048 }, content), disclosureIconMarkup) : content;
5049 var menuActionClassNames = classNames(styles$i.MenuAction, disabled && styles$i.disabled);
5050
5051 if (url) {
5052 return React__default.createElement(UnstyledLink, {
5053 className: menuActionClassNames,
5054 url: url,
5055 external: external,
5056 "aria-label": accessibilityLabel,
5057 onMouseUp: handleMouseUpByBlurring
5058 }, contentMarkup);
5059 }
5060
5061 return React__default.createElement("button", {
5062 type: "button",
5063 className: menuActionClassNames,
5064 disabled: disabled,
5065 "aria-label": accessibilityLabel,
5066 onClick: onAction,
5067 onMouseUp: handleMouseUpByBlurring
5068 }, contentMarkup);
5069}
5070
5071var styles$j = {
5072 "Details": "Polaris-ActionMenu-MenuGroup__Details"
5073};
5074
5075var MenuGroup =
5076/*#__PURE__*/
5077function (_React$Component) {
5078 _inherits(MenuGroup, _React$Component);
5079
5080 function MenuGroup() {
5081 var _this;
5082
5083 _classCallCheck(this, MenuGroup);
5084
5085 _this = _possibleConstructorReturn(this, _getPrototypeOf(MenuGroup).apply(this, arguments));
5086
5087 _this.handleClose = function () {
5088 var _this$props = _this.props,
5089 title = _this$props.title,
5090 onClose = _this$props.onClose;
5091 onClose(title);
5092 };
5093
5094 _this.handleOpen = function () {
5095 var _this$props2 = _this.props,
5096 title = _this$props2.title,
5097 onOpen = _this$props2.onOpen;
5098 onOpen(title);
5099 };
5100
5101 return _this;
5102 }
5103
5104 _createClass(MenuGroup, [{
5105 key: "render",
5106 value: function render() {
5107 var _this$props3 = this.props,
5108 accessibilityLabel = _this$props3.accessibilityLabel,
5109 active = _this$props3.active,
5110 actions = _this$props3.actions,
5111 details = _this$props3.details,
5112 title = _this$props3.title,
5113 icon = _this$props3.icon;
5114
5115 if (!actions.length) {
5116 return null;
5117 }
5118
5119 var popoverActivator = React__default.createElement(MenuAction, {
5120 disclosure: true,
5121 content: title,
5122 icon: icon,
5123 accessibilityLabel: accessibilityLabel,
5124 onAction: this.handleOpen
5125 });
5126 return React__default.createElement(Popover, {
5127 active: Boolean(active),
5128 activator: popoverActivator,
5129 preferredAlignment: "left",
5130 onClose: this.handleClose
5131 }, React__default.createElement(ActionList, {
5132 items: actions,
5133 onActionAnyItem: this.handleClose
5134 }), details && React__default.createElement("div", {
5135 className: styles$j.Details
5136 }, details));
5137 }
5138 }]);
5139
5140 return MenuGroup;
5141}(React__default.Component);
5142
5143var styles$k = {
5144 "RollupActivator": "Polaris-ActionMenu-RollupActions__RollupActivator"
5145};
5146
5147function RollupActions(_ref) {
5148 var _ref$items = _ref.items,
5149 items = _ref$items === void 0 ? [] : _ref$items,
5150 _ref$sections = _ref.sections,
5151 sections = _ref$sections === void 0 ? [] : _ref$sections;
5152 var i18n = useI18n();
5153
5154 var _useToggle = useToggle(false),
5155 _useToggle2 = _slicedToArray(_useToggle, 2),
5156 rollupOpen = _useToggle2[0],
5157 toggleRollupOpen = _useToggle2[1];
5158
5159 if (items.length === 0 && sections.length === 0) {
5160 return null;
5161 }
5162
5163 var activatorMarkup = React__default.createElement("div", {
5164 className: styles$k.RollupActivator
5165 }, React__default.createElement(Button, {
5166 plain: true,
5167 icon: HorizontalDotsMinor,
5168 accessibilityLabel: i18n.translate('Polaris.ActionMenu.RollupActions.rollupButton'),
5169 onClick: toggleRollupOpen
5170 }));
5171 return React__default.createElement(Popover, {
5172 active: rollupOpen,
5173 activator: activatorMarkup,
5174 preferredAlignment: "right",
5175 onClose: toggleRollupOpen
5176 }, React__default.createElement(ActionList, {
5177 items: items,
5178 sections: sections,
5179 onActionAnyItem: toggleRollupOpen
5180 }));
5181}
5182
5183var styles$l = {
5184 "ActionMenu": "Polaris-ActionMenu",
5185 "rollup": "Polaris-ActionMenu--rollup",
5186 "ActionsLayout": "Polaris-ActionMenu__ActionsLayout"
5187};
5188
5189var ActionMenu =
5190/*#__PURE__*/
5191function (_React$PureComponent) {
5192 _inherits(ActionMenu, _React$PureComponent);
5193
5194 function ActionMenu() {
5195 var _this;
5196
5197 _classCallCheck(this, ActionMenu);
5198
5199 _this = _possibleConstructorReturn(this, _getPrototypeOf(ActionMenu).apply(this, arguments));
5200 _this.state = {
5201 activeMenuGroup: undefined
5202 };
5203
5204 _this.renderActions = function () {
5205 var _this$props = _this.props,
5206 _this$props$actions = _this$props.actions,
5207 actions = _this$props$actions === void 0 ? [] : _this$props$actions,
5208 _this$props$groups = _this$props.groups,
5209 groups = _this$props$groups === void 0 ? [] : _this$props$groups;
5210 var activeMenuGroup = _this.state.activeMenuGroup;
5211 var actionsMarkup = actions.length > 0 ? actions.map(function (_a, index) {
5212 var content = _a.content,
5213 action = __rest(_a, ["content"]);
5214
5215 return React__default.createElement(MenuAction, Object.assign({
5216 key: "MenuAction-".concat(content || index),
5217 content: content
5218 }, action));
5219 }) : null;
5220 var groupsMarkup = hasGroupsWithActions(groups) ? groups.map(function (_a, index) {
5221 var title = _a.title,
5222 rest = __rest(_a, ["title"]);
5223
5224 return React__default.createElement(MenuGroup, Object.assign({
5225 key: "MenuGroup-".concat(title || index),
5226 title: title,
5227 active: title === activeMenuGroup
5228 }, rest, {
5229 onOpen: _this.handleMenuGroupToggle,
5230 onClose: _this.handleMenuGroupClose
5231 }));
5232 }) : null;
5233 return actionsMarkup || groupsMarkup ? React__default.createElement("div", {
5234 className: styles$l.ActionsLayout
5235 }, actionsMarkup, groupsMarkup) : null;
5236 };
5237
5238 _this.handleMenuGroupToggle = function (group) {
5239 _this.setState(function (_ref) {
5240 var activeMenuGroup = _ref.activeMenuGroup;
5241 return {
5242 activeMenuGroup: activeMenuGroup ? undefined : group
5243 };
5244 });
5245 };
5246
5247 _this.handleMenuGroupClose = function () {
5248 _this.setState({
5249 activeMenuGroup: undefined
5250 });
5251 };
5252
5253 return _this;
5254 }
5255
5256 _createClass(ActionMenu, [{
5257 key: "render",
5258 value: function render() {
5259 var _this$props2 = this.props,
5260 _this$props2$actions = _this$props2.actions,
5261 actions = _this$props2$actions === void 0 ? [] : _this$props2$actions,
5262 _this$props2$groups = _this$props2.groups,
5263 groups = _this$props2$groups === void 0 ? [] : _this$props2$groups,
5264 rollup = _this$props2.rollup;
5265
5266 if (actions.length === 0 && groups.length === 0) {
5267 return null;
5268 }
5269
5270 var actionMenuClassNames = classNames(styles$l.ActionMenu, rollup && styles$l.rollup);
5271 var rollupSections = groups.map(function (group) {
5272 return convertGroupToSection(group);
5273 });
5274 return React__default.createElement("div", {
5275 className: actionMenuClassNames
5276 }, rollup ? React__default.createElement(RollupActions, {
5277 items: actions,
5278 sections: rollupSections
5279 }) : this.renderActions());
5280 }
5281 }]);
5282
5283 return ActionMenu;
5284}(React__default.PureComponent);
5285function hasGroupsWithActions() {
5286 var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
5287 return groups.length === 0 ? false : groups.some(function (group) {
5288 return group.actions.length > 0;
5289 });
5290}
5291function convertGroupToSection(_ref2) {
5292 var title = _ref2.title,
5293 actions = _ref2.actions;
5294 return {
5295 title,
5296 items: actions
5297 };
5298}
5299
5300function ThemeProvider(_ref) {
5301 var themeConfig = _ref.theme,
5302 children = _ref.children;
5303
5304 var _useFeatures = useFeatures(),
5305 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
5306 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
5307
5308 var customProperties = useMemo(function () {
5309 return buildCustomProperties(themeConfig, unstableGlobalTheming);
5310 }, [unstableGlobalTheming, themeConfig]);
5311 var theme = useMemo(function () {
5312 return buildThemeContext(themeConfig, unstableGlobalTheming ? customProperties : undefined);
5313 }, [customProperties, themeConfig, unstableGlobalTheming]); // We want these values to be `null` instead of `undefined` when not set.
5314 // Otherwise, setting a style property to `undefined` does not remove it from the DOM.
5315
5316 var backgroundColor = customProperties['--p-surface-background'] || null;
5317 var color = customProperties['--p-text-on-surface'] || null;
5318 useEffect(function () {
5319 document.body.style.backgroundColor = backgroundColor;
5320 document.body.style.color = color;
5321 }, [backgroundColor, color]);
5322 return React__default.createElement(ThemeContext.Provider, {
5323 value: theme
5324 }, React__default.createElement("div", {
5325 style: customProperties
5326 }, children));
5327}
5328
5329var MediaQueryContext = React__default.createContext(undefined);
5330
5331function useMediaQuery() {
5332 var mediaQuery = useContext(MediaQueryContext);
5333
5334 if (!mediaQuery) {
5335 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.');
5336 }
5337
5338 return mediaQuery;
5339}
5340
5341var MediaQueryProvider = function MediaQueryProvider(_ref) {
5342 var children = _ref.children;
5343
5344 var _useState = useState(navigationBarCollapsed().matches),
5345 _useState2 = _slicedToArray(_useState, 2),
5346 isNavigationCollapsed = _useState2[0],
5347 setIsNavigationCollapsed = _useState2[1];
5348
5349 var handleResize = useCallback(debounce(function () {
5350 if (isNavigationCollapsed !== navigationBarCollapsed().matches) {
5351 setIsNavigationCollapsed(!isNavigationCollapsed);
5352 }
5353 }, 40, {
5354 trailing: true,
5355 leading: true,
5356 maxWait: 40
5357 }), [isNavigationCollapsed]);
5358 useEffect(function () {
5359 setIsNavigationCollapsed(navigationBarCollapsed().matches);
5360 }, []);
5361 return React__default.createElement(MediaQueryContext.Provider, {
5362 value: {
5363 isNavigationCollapsed
5364 }
5365 }, React__default.createElement(EventListener, {
5366 event: "resize",
5367 handler: handleResize
5368 }), children);
5369};
5370
5371var ScrollLockManagerContext = React__default.createContext(undefined);
5372
5373function useScrollLockManager() {
5374 var scrollLockManager = useContext(ScrollLockManagerContext);
5375
5376 if (!scrollLockManager) {
5377 throw new MissingAppProviderError('No ScrollLockManager was provided.');
5378 }
5379
5380 return scrollLockManager;
5381}
5382
5383var SCROLL_LOCKING_ATTRIBUTE = 'data-lock-scrolling';
5384var SCROLL_LOCKING_WRAPPER_ATTRIBUTE = 'data-lock-scrolling-wrapper';
5385var scrollPosition = 0;
5386var ScrollLockManager =
5387/*#__PURE__*/
5388function () {
5389 function ScrollLockManager() {
5390 _classCallCheck(this, ScrollLockManager);
5391
5392 this.scrollLocks = 0;
5393 this.locked = false;
5394 }
5395
5396 _createClass(ScrollLockManager, [{
5397 key: "registerScrollLock",
5398 value: function registerScrollLock() {
5399 this.scrollLocks += 1;
5400 this.handleScrollLocking();
5401 }
5402 }, {
5403 key: "unregisterScrollLock",
5404 value: function unregisterScrollLock() {
5405 this.scrollLocks -= 1;
5406 this.handleScrollLocking();
5407 }
5408 }, {
5409 key: "handleScrollLocking",
5410 value: function handleScrollLocking() {
5411 if (isServer) return;
5412 var scrollLocks = this.scrollLocks;
5413 var _document = document,
5414 body = _document.body;
5415 var wrapper = body.firstElementChild;
5416
5417 if (scrollLocks === 0) {
5418 body.removeAttribute(SCROLL_LOCKING_ATTRIBUTE);
5419
5420 if (wrapper) {
5421 wrapper.removeAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE);
5422 }
5423
5424 window.scroll(0, scrollPosition);
5425 this.locked = false;
5426 } else if (scrollLocks > 0 && !this.locked) {
5427 scrollPosition = window.pageYOffset;
5428 body.setAttribute(SCROLL_LOCKING_ATTRIBUTE, '');
5429
5430 if (wrapper) {
5431 wrapper.setAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE, '');
5432 wrapper.scrollTop = scrollPosition;
5433 }
5434
5435 this.locked = true;
5436 }
5437 }
5438 }, {
5439 key: "resetScrollPosition",
5440 value: function resetScrollPosition() {
5441 scrollPosition = 0;
5442 }
5443 }]);
5444
5445 return ScrollLockManager;
5446}();
5447
5448var AppBridgeContext = React__default.createContext(undefined);
5449
5450function useAppBridge() {
5451 return useContext(AppBridgeContext);
5452}
5453
5454function createAppBridge(_ref) {
5455 var apiKey = _ref.apiKey,
5456 shopOrigin = _ref.shopOrigin,
5457 forceRedirect = _ref.forceRedirect;
5458 var appBridge = apiKey ? createApp({
5459 apiKey,
5460 shopOrigin: shopOrigin || getShopOrigin(),
5461 forceRedirect
5462 }) : undefined;
5463
5464 if (appBridge !== undefined) {
5465 // eslint-disable-next-line no-console
5466 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');
5467 }
5468
5469 if (appBridge && appBridge.hooks) {
5470 appBridge.hooks.set(LifecycleHook.DispatchAction, setClientInterfaceHook);
5471 }
5472
5473 return appBridge;
5474}
5475var setClientInterfaceHook = function setClientInterfaceHook(next) {
5476 return function (action) {
5477 action.clientInterface = {
5478 name: '@shopify/polaris',
5479 version: polarisVersion
5480 };
5481 return next(action);
5482 };
5483};
5484
5485var AppProvider =
5486/*#__PURE__*/
5487function (_React$Component) {
5488 _inherits(AppProvider, _React$Component);
5489
5490 function AppProvider(props) {
5491 var _this;
5492
5493 _classCallCheck(this, AppProvider);
5494
5495 _this = _possibleConstructorReturn(this, _getPrototypeOf(AppProvider).call(this, props));
5496 _this.stickyManager = new StickyManager();
5497 _this.scrollLockManager = new ScrollLockManager();
5498 _this.uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory);
5499 var _this$props = _this.props,
5500 i18n = _this$props.i18n,
5501 apiKey = _this$props.apiKey,
5502 shopOrigin = _this$props.shopOrigin,
5503 forceRedirect = _this$props.forceRedirect,
5504 linkComponent = _this$props.linkComponent; // eslint-disable-next-line react/state-in-constructor
5505
5506 _this.state = {
5507 link: linkComponent,
5508 intl: new I18n(i18n),
5509 appBridge: createAppBridge({
5510 shopOrigin,
5511 apiKey,
5512 forceRedirect
5513 })
5514 };
5515 return _this;
5516 }
5517
5518 _createClass(AppProvider, [{
5519 key: "componentDidMount",
5520 value: function componentDidMount() {
5521 if (document != null) {
5522 this.stickyManager.setContainer(document);
5523 }
5524 }
5525 }, {
5526 key: "componentDidUpdate",
5527 value: function componentDidUpdate(_ref) {
5528 var prevI18n = _ref.i18n,
5529 prevLinkComponent = _ref.linkComponent,
5530 prevApiKey = _ref.apiKey,
5531 prevShopOrigin = _ref.shopOrigin,
5532 prevForceRedirect = _ref.forceRedirect;
5533 var _this$props2 = this.props,
5534 i18n = _this$props2.i18n,
5535 linkComponent = _this$props2.linkComponent,
5536 apiKey = _this$props2.apiKey,
5537 shopOrigin = _this$props2.shopOrigin,
5538 forceRedirect = _this$props2.forceRedirect;
5539
5540 if (i18n === prevI18n && linkComponent === prevLinkComponent && apiKey === prevApiKey && shopOrigin === prevShopOrigin && forceRedirect === prevForceRedirect) {
5541 return;
5542 } // eslint-disable-next-line react/no-did-update-set-state
5543
5544
5545 this.setState({
5546 link: linkComponent,
5547 intl: new I18n(i18n),
5548 appBridge: createAppBridge({
5549 shopOrigin,
5550 apiKey,
5551 forceRedirect
5552 })
5553 });
5554 }
5555 }, {
5556 key: "render",
5557 value: function render() {
5558 var _this$props3 = this.props,
5559 _this$props3$theme = _this$props3.theme,
5560 theme = _this$props3$theme === void 0 ? {} : _this$props3$theme,
5561 _this$props3$features = _this$props3.features,
5562 features = _this$props3$features === void 0 ? {} : _this$props3$features,
5563 UNSTABLE_telemetry = _this$props3.UNSTABLE_telemetry,
5564 children = _this$props3.children;
5565 var _this$state = this.state,
5566 intl = _this$state.intl,
5567 appBridge = _this$state.appBridge,
5568 link = _this$state.link;
5569 return React__default.createElement(FeaturesContext.Provider, {
5570 value: features
5571 }, React__default.createElement(I18nContext.Provider, {
5572 value: intl
5573 }, React__default.createElement(ScrollLockManagerContext.Provider, {
5574 value: this.scrollLockManager
5575 }, React__default.createElement(StickyManagerContext.Provider, {
5576 value: this.stickyManager
5577 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
5578 value: this.uniqueIdFactory
5579 }, React__default.createElement(AppBridgeContext.Provider, {
5580 value: appBridge
5581 }, React__default.createElement(LinkContext.Provider, {
5582 value: link
5583 }, React__default.createElement(ThemeProvider, {
5584 theme: theme
5585 }, React__default.createElement(TelemetryContext.Provider, {
5586 value: UNSTABLE_telemetry
5587 }, React__default.createElement(MediaQueryProvider, null, children))))))))));
5588 }
5589 }]);
5590
5591 return AppProvider;
5592}(React__default.Component);
5593
5594function arraysAreEqual(firstArray, secondArray, comparator) {
5595 if (firstArray.length !== secondArray.length) {
5596 return false;
5597 }
5598
5599 return firstArray.every(function (firstItem, index) {
5600 var secondItem = secondArray[index];
5601
5602 if (comparator != null) {
5603 return comparator(firstItem, secondItem);
5604 }
5605
5606 return firstItem === secondItem;
5607 });
5608}
5609
5610/**
5611 * Allows for custom or deep comparison of a dependency list. Useful to keep a consistent dependency
5612 * list across reference changes.
5613 * @param dependencies A dependency array similar to React.useEffect/React.useCallback/React.useMemo
5614 * @param comparator An optional function to compare dependencies that'll default to a deep comparison
5615 * @returns A dependency list
5616 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-effect.tsx}
5617 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-callback.tsx}
5618 * @example
5619 * function useDeepEffectExample(callback, dependencies, customCompare) {
5620 * useEffect(callback, useDeepCompareRef(dependencies, customCompare));
5621 * }
5622 */
5623
5624function useDeepCompareRef(dependencies) {
5625 var comparator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : isEqual;
5626 var dependencyList = useRef(dependencies);
5627
5628 if (!comparator(dependencyList.current, dependencies)) {
5629 dependencyList.current = dependencies;
5630 }
5631
5632 return dependencyList.current;
5633}
5634
5635/**
5636 * A replacement for React.useEffect that'll allow for custom and deep
5637 * compares of the dependency list.
5638 * @see {@link https://reactjs.org/docs/hooks-reference.html#useeffect}
5639 * @param callback Accepts a callback that's forwarded to React.useEffect
5640 * @param dependencies A dependency array similar to React.useEffect however it utilizes a deep compare
5641 * @param customCompare Opportunity to provide a custom compare function
5642 * @example
5643 * function ComponentExample() {
5644 * const [, forceUpdate] = useState();
5645 * const obj = {a: 1};
5646 *
5647 * useDeepEffect(() => {
5648 * console.log('useDeepEffect invocation');
5649 * forceUpdate(obj);
5650 * }, [obj]);
5651 *
5652 * return null;
5653 * }
5654 */
5655
5656function useDeepEffect(callback, dependencies, customCompare) {
5657 useEffect(callback, useDeepCompareRef(dependencies, customCompare));
5658}
5659
5660var styles$m = {
5661 "Checkbox": "Polaris-OptionList-Checkbox",
5662 "Input": "Polaris-OptionList-Checkbox__Input",
5663 "Backdrop": "Polaris-OptionList-Checkbox__Backdrop",
5664 "Icon": "Polaris-OptionList-Checkbox__Icon",
5665 "active": "Polaris-OptionList-Checkbox--active"
5666};
5667
5668function Checkbox(_ref) {
5669 var idProp = _ref.id,
5670 _ref$checked = _ref.checked,
5671 checked = _ref$checked === void 0 ? false : _ref$checked,
5672 disabled = _ref.disabled,
5673 active = _ref.active,
5674 onChange = _ref.onChange,
5675 name = _ref.name,
5676 value = _ref.value,
5677 role = _ref.role;
5678 var id = useUniqueId('Checkbox', idProp);
5679 var className = classNames(styles$m.Checkbox, active && styles$m.active);
5680 return React__default.createElement("div", {
5681 className: className
5682 }, React__default.createElement("input", {
5683 id: id,
5684 name: name,
5685 value: value,
5686 type: "checkbox",
5687 checked: checked,
5688 disabled: disabled,
5689 className: styles$m.Input,
5690 "aria-checked": checked,
5691 onChange: onChange,
5692 role: role
5693 }), React__default.createElement("div", {
5694 className: styles$m.Backdrop
5695 }), React__default.createElement("div", {
5696 className: styles$m.Icon
5697 }, React__default.createElement(Icon, {
5698 source: TickSmallMinor
5699 })));
5700}
5701
5702var styles$n = {
5703 "Option": "Polaris-OptionList-Option",
5704 "SingleSelectOption": "Polaris-OptionList-Option__SingleSelectOption",
5705 "disabled": "Polaris-OptionList-Option--disabled",
5706 "Media": "Polaris-OptionList-Option__Media",
5707 "Label": "Polaris-OptionList-Option__Label",
5708 "Checkbox": "Polaris-OptionList-Option__Checkbox",
5709 "focused": "Polaris-OptionList-Option--focused",
5710 "select": "Polaris-OptionList-Option--select",
5711 "active": "Polaris-OptionList-Option--active"
5712};
5713
5714var Option =
5715/*#__PURE__*/
5716function (_React$Component) {
5717 _inherits(Option, _React$Component);
5718
5719 function Option() {
5720 var _this;
5721
5722 _classCallCheck(this, Option);
5723
5724 _this = _possibleConstructorReturn(this, _getPrototypeOf(Option).apply(this, arguments));
5725 _this.state = {
5726 focused: false
5727 };
5728
5729 _this.handleClick = function () {
5730 var _this$props = _this.props,
5731 onClick = _this$props.onClick,
5732 section = _this$props.section,
5733 index = _this$props.index,
5734 disabled = _this$props.disabled;
5735
5736 if (disabled) {
5737 return;
5738 }
5739
5740 onClick(section, index);
5741 };
5742
5743 _this.toggleFocus = function () {
5744 _this.setState(function (prevState) {
5745 return {
5746 focused: !prevState.focused
5747 };
5748 });
5749 };
5750
5751 return _this;
5752 }
5753
5754 _createClass(Option, [{
5755 key: "render",
5756 value: function render() {
5757 var _this$props2 = this.props,
5758 label = _this$props2.label,
5759 value = _this$props2.value,
5760 id = _this$props2.id,
5761 select = _this$props2.select,
5762 active = _this$props2.active,
5763 allowMultiple = _this$props2.allowMultiple,
5764 disabled = _this$props2.disabled,
5765 role = _this$props2.role,
5766 media = _this$props2.media;
5767 var focused = this.state.focused;
5768 var mediaMarkup = media ? React__default.createElement("div", {
5769 className: styles$n.Media
5770 }, media) : null;
5771 var singleSelectClassName = classNames(styles$n.SingleSelectOption, focused && styles$n.focused, disabled && styles$n.disabled, select && styles$n.select, active && styles$n.active);
5772 var multiSelectClassName = classNames(styles$n.Label, active && styles$n.active);
5773 var checkBoxRole = role === 'option' ? 'presentation' : undefined;
5774 var optionMarkup = allowMultiple ? React__default.createElement("label", {
5775 htmlFor: id,
5776 className: multiSelectClassName
5777 }, React__default.createElement("div", {
5778 className: styles$n.Checkbox
5779 }, React__default.createElement(Checkbox, {
5780 id: id,
5781 value: value,
5782 checked: select,
5783 active: active,
5784 disabled: disabled,
5785 onChange: this.handleClick,
5786 role: checkBoxRole
5787 })), mediaMarkup, label) : React__default.createElement("button", {
5788 id: id,
5789 type: "button",
5790 className: singleSelectClassName,
5791 onClick: this.handleClick,
5792 disabled: disabled,
5793 onFocus: this.toggleFocus,
5794 onBlur: this.toggleFocus
5795 }, mediaMarkup, label);
5796 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
5797 return React__default.createElement("li", {
5798 key: id,
5799 className: styles$n.Option,
5800 tabIndex: -1,
5801 "aria-selected": active,
5802 role: role
5803 }, scrollMarkup, optionMarkup);
5804 }
5805 }]);
5806
5807 return Option;
5808}(React__default.Component);
5809
5810var styles$o = {
5811 "OptionList": "Polaris-OptionList",
5812 "Options": "Polaris-OptionList__Options",
5813 "Title": "Polaris-OptionList__Title"
5814};
5815
5816function OptionList(_ref) {
5817 var options = _ref.options,
5818 sections = _ref.sections,
5819 title = _ref.title,
5820 selected = _ref.selected,
5821 allowMultiple = _ref.allowMultiple,
5822 role = _ref.role,
5823 optionRole = _ref.optionRole,
5824 onChange = _ref.onChange,
5825 idProp = _ref.id;
5826
5827 var _useState = useState(createNormalizedOptions(options, sections, title)),
5828 _useState2 = _slicedToArray(_useState, 2),
5829 normalizedOptions = _useState2[0],
5830 setNormalizedOptions = _useState2[1];
5831
5832 var id = useUniqueId('OptionList', idProp);
5833 useDeepEffect(function () {
5834 setNormalizedOptions(createNormalizedOptions(options || [], sections || [], title));
5835 }, [options, sections, title], optionArraysAreEqual);
5836 var handleClick = useCallback(function (sectionIndex, optionIndex) {
5837 var selectedValue = normalizedOptions[sectionIndex].options[optionIndex].value;
5838 var foundIndex = selected.indexOf(selectedValue);
5839
5840 if (allowMultiple) {
5841 var newSelection = foundIndex === -1 ? [selectedValue].concat(_toConsumableArray(selected)) : [].concat(_toConsumableArray(selected.slice(0, foundIndex)), _toConsumableArray(selected.slice(foundIndex + 1, selected.length)));
5842 onChange(newSelection);
5843 return;
5844 }
5845
5846 onChange([selectedValue]);
5847 }, [normalizedOptions, selected, allowMultiple, onChange]);
5848 var optionsExist = normalizedOptions.length > 0;
5849 var optionsMarkup = optionsExist ? normalizedOptions.map(function (_ref2, sectionIndex) {
5850 var title = _ref2.title,
5851 options = _ref2.options;
5852 var titleMarkup = title ? React__default.createElement("p", {
5853 className: styles$o.Title,
5854 role: role
5855 }, title) : null;
5856 var optionsMarkup = options && options.map(function (option, optionIndex) {
5857 var isSelected = selected.includes(option.value);
5858 var optionId = option.id || "".concat(id, "-").concat(sectionIndex, "-").concat(optionIndex);
5859 return React__default.createElement(Option, Object.assign({}, option, {
5860 key: optionId,
5861 id: optionId,
5862 section: sectionIndex,
5863 index: optionIndex,
5864 onClick: handleClick,
5865 select: isSelected,
5866 allowMultiple: allowMultiple,
5867 role: optionRole
5868 }));
5869 });
5870 return React__default.createElement("li", {
5871 key: title || "noTitle-".concat(sectionIndex)
5872 }, titleMarkup, React__default.createElement("ul", {
5873 className: styles$o.Options,
5874 id: "".concat(id, "-").concat(sectionIndex),
5875 role: role,
5876 "aria-multiselectable": allowMultiple
5877 }, optionsMarkup));
5878 }) : null;
5879 return React__default.createElement("ul", {
5880 className: styles$o.OptionList,
5881 role: role
5882 }, optionsMarkup);
5883}
5884
5885function createNormalizedOptions(options, sections, title) {
5886 if (options == null) {
5887 var section = {
5888 options: [],
5889 title
5890 };
5891 return sections == null ? [] : [section].concat(_toConsumableArray(sections));
5892 }
5893
5894 if (sections == null) {
5895 return [{
5896 title,
5897 options
5898 }];
5899 }
5900
5901 return [{
5902 title,
5903 options
5904 }].concat(_toConsumableArray(sections));
5905}
5906
5907function isSection(arr) {
5908 return typeof arr[0] === 'object' && Object.prototype.hasOwnProperty.call(arr[0], 'options');
5909}
5910
5911function optionArraysAreEqual(firstArray, secondArray) {
5912 if (isSection(firstArray) && isSection(secondArray)) {
5913 return arraysAreEqual(firstArray, secondArray, testSectionsPropEquality);
5914 }
5915
5916 return arraysAreEqual(firstArray, secondArray);
5917}
5918
5919function testSectionsPropEquality(previousSection, currentSection) {
5920 var previousOptions = previousSection.options;
5921 var currentOptions = currentSection.options;
5922 var optionsAreEqual = arraysAreEqual(previousOptions, currentOptions);
5923 var titlesAreEqual = previousSection.title === currentSection.title;
5924 return optionsAreEqual && titlesAreEqual;
5925}
5926
5927var ComboBoxContext = React__default.createContext({});
5928
5929var styles$p = {
5930 "EmptyState": "Polaris-Autocomplete-ComboBox__EmptyState"
5931};
5932
5933var getUniqueId = createUniqueIDFactory('ComboBox');
5934var ComboBox =
5935/*#__PURE__*/
5936function (_React$PureComponent) {
5937 _inherits(ComboBox, _React$PureComponent);
5938
5939 function ComboBox() {
5940 var _this;
5941
5942 _classCallCheck(this, ComboBox);
5943
5944 _this = _possibleConstructorReturn(this, _getPrototypeOf(ComboBox).apply(this, arguments));
5945 _this.state = {
5946 comboBoxId: _this.getComboBoxId(),
5947 selectedOption: undefined,
5948 selectedIndex: -1,
5949 selectedOptions: _this.props.selected,
5950 navigableOptions: [],
5951 popoverActive: false,
5952 popoverWasActive: false
5953 };
5954
5955 _this.handleDownArrow = function () {
5956 _this.selectNextOption();
5957
5958 _this.handlePopoverOpen;
5959 };
5960
5961 _this.handleUpArrow = function () {
5962 _this.selectPreviousOption();
5963
5964 _this.handlePopoverOpen;
5965 };
5966
5967 _this.handleEnter = function (event) {
5968 if (event.keyCode !== Key.Enter) {
5969 return;
5970 }
5971
5972 var selectedOption = _this.state.selectedOption;
5973
5974 if (_this.state.popoverActive && selectedOption) {
5975 if (isOption(selectedOption)) {
5976 event.preventDefault();
5977
5978 _this.handleSelection(selectedOption.value);
5979 } else {
5980 selectedOption.onAction && selectedOption.onAction();
5981 }
5982 }
5983
5984 _this.handlePopoverOpen;
5985 };
5986
5987 _this.handleFocus = function () {
5988 _this.setState({
5989 popoverActive: true,
5990 popoverWasActive: true
5991 });
5992 };
5993
5994 _this.handleBlur = function () {
5995 _this.setState({
5996 popoverActive: false,
5997 popoverWasActive: false
5998 }, function () {
5999 _this.resetVisuallySelectedOptions();
6000 });
6001 };
6002
6003 _this.handleClick = function () {
6004 !_this.state.popoverActive && _this.setState({
6005 popoverActive: true
6006 });
6007 };
6008
6009 _this.handleSelection = function (newSelected) {
6010 var _this$props = _this.props,
6011 selected = _this$props.selected,
6012 allowMultiple = _this$props.allowMultiple;
6013 var newlySelectedOptions = selected;
6014
6015 if (selected.includes(newSelected)) {
6016 newlySelectedOptions.splice(newlySelectedOptions.indexOf(newSelected), 1);
6017 } else if (allowMultiple) {
6018 newlySelectedOptions.push(newSelected);
6019 } else {
6020 newlySelectedOptions = [newSelected];
6021 }
6022
6023 _this.selectOptions(newlySelectedOptions);
6024 };
6025
6026 _this.selectOptions = function (selected) {
6027 var _this$props2 = _this.props,
6028 onSelect = _this$props2.onSelect,
6029 allowMultiple = _this$props2.allowMultiple;
6030 selected && onSelect(selected);
6031
6032 if (!allowMultiple) {
6033 _this.resetVisuallySelectedOptions();
6034
6035 _this.setState({
6036 popoverActive: false,
6037 popoverWasActive: false
6038 });
6039 }
6040 };
6041
6042 _this.updateIndexOfSelectedOption = function (newOptions) {
6043 var _this$state = _this.state,
6044 selectedIndex = _this$state.selectedIndex,
6045 selectedOption = _this$state.selectedOption;
6046
6047 if (selectedOption && newOptions.includes(selectedOption)) {
6048 _this.selectOptionAtIndex(newOptions.indexOf(selectedOption));
6049 } else if (selectedIndex > newOptions.length - 1) {
6050 _this.resetVisuallySelectedOptions();
6051 } else {
6052 _this.selectOptionAtIndex(selectedIndex);
6053 }
6054 };
6055
6056 _this.resetVisuallySelectedOptions = function () {
6057 var navigableOptions = _this.state.navigableOptions;
6058
6059 _this.setState({
6060 selectedOption: undefined,
6061 selectedIndex: -1
6062 });
6063
6064 navigableOptions && navigableOptions.forEach(function (option) {
6065 option.active = false;
6066 });
6067 };
6068
6069 _this.handlePopoverClose = function () {
6070 _this.setState({
6071 popoverActive: false,
6072 popoverWasActive: false
6073 });
6074 };
6075
6076 _this.handlePopoverOpen = function () {
6077 var _this$state2 = _this.state,
6078 popoverActive = _this$state2.popoverActive,
6079 navigableOptions = _this$state2.navigableOptions;
6080 !popoverActive && navigableOptions && navigableOptions.length > 0 && _this.setState({
6081 popoverActive: true,
6082 popoverWasActive: true
6083 });
6084 };
6085
6086 _this.selectNextOption = function () {
6087 var _this$state3 = _this.state,
6088 selectedIndex = _this$state3.selectedIndex,
6089 navigableOptions = _this$state3.navigableOptions;
6090
6091 if (!navigableOptions || navigableOptions.length === 0) {
6092 return;
6093 }
6094
6095 var newIndex = selectedIndex;
6096
6097 if (selectedIndex + 1 >= navigableOptions.length) {
6098 newIndex = 0;
6099 } else {
6100 newIndex++;
6101 }
6102
6103 _this.selectOptionAtIndex(newIndex);
6104 };
6105
6106 _this.selectPreviousOption = function () {
6107 var _this$state4 = _this.state,
6108 selectedIndex = _this$state4.selectedIndex,
6109 navigableOptions = _this$state4.navigableOptions;
6110
6111 if (!navigableOptions || navigableOptions.length === 0) {
6112 return;
6113 }
6114
6115 var newIndex = selectedIndex;
6116
6117 if (selectedIndex <= 0) {
6118 newIndex = navigableOptions.length - 1;
6119 } else {
6120 newIndex--;
6121 }
6122
6123 _this.selectOptionAtIndex(newIndex);
6124 };
6125
6126 _this.selectOptionAtIndex = function (newOptionIndex) {
6127 _this.setState(function (prevState) {
6128 if (!prevState.navigableOptions || prevState.navigableOptions.length === 0) {
6129 return prevState;
6130 }
6131
6132 var newSelectedOption = prevState.navigableOptions[newOptionIndex];
6133
6134 _this.visuallyUpdateSelectedOption(newSelectedOption, prevState.selectedOption);
6135
6136 return Object.assign({}, prevState, {
6137 selectedOption: newSelectedOption,
6138 selectedIndex: newOptionIndex
6139 });
6140 });
6141 };
6142
6143 _this.visuallyUpdateSelectedOption = function (newOption, oldOption) {
6144 if (oldOption) {
6145 oldOption.active = false;
6146 }
6147
6148 if (newOption) {
6149 newOption.active = true;
6150 }
6151 };
6152
6153 return _this;
6154 }
6155
6156 _createClass(ComboBox, [{
6157 key: "componentDidMount",
6158 value: function componentDidMount() {
6159 var _this$props3 = this.props,
6160 options = _this$props3.options,
6161 actionsBefore = _this$props3.actionsBefore,
6162 actionsAfter = _this$props3.actionsAfter;
6163 var comboBoxId = this.getComboBoxId();
6164 var navigableOptions = [];
6165
6166 if (actionsBefore) {
6167 navigableOptions = navigableOptions.concat(actionsBefore);
6168 }
6169
6170 if (options) {
6171 navigableOptions = navigableOptions.concat(options);
6172 }
6173
6174 if (actionsAfter) {
6175 navigableOptions = navigableOptions.concat(actionsAfter);
6176 }
6177
6178 navigableOptions = assignOptionIds(navigableOptions, comboBoxId);
6179 this.setState({
6180 navigableOptions
6181 });
6182 }
6183 }, {
6184 key: "componentDidUpdate",
6185 value: function componentDidUpdate(_, prevState) {
6186 var _this$props4 = this.props,
6187 contentBefore = _this$props4.contentBefore,
6188 contentAfter = _this$props4.contentAfter,
6189 emptyState = _this$props4.emptyState;
6190 var _this$state5 = this.state,
6191 navigableOptions = _this$state5.navigableOptions,
6192 popoverWasActive = _this$state5.popoverWasActive;
6193 var optionsChanged = navigableOptions && prevState.navigableOptions && !optionsAreEqual(navigableOptions, prevState.navigableOptions);
6194
6195 if (optionsChanged) {
6196 this.updateIndexOfSelectedOption(navigableOptions);
6197 }
6198
6199 if (navigableOptions && navigableOptions.length === 0 && !contentBefore && !contentAfter && !emptyState) {
6200 // eslint-disable-next-line react/no-did-update-set-state
6201 this.setState({
6202 popoverActive: false
6203 });
6204 } else if (popoverWasActive && navigableOptions && navigableOptions.length !== 0) {
6205 // eslint-disable-next-line react/no-did-update-set-state
6206 this.setState({
6207 popoverActive: true
6208 });
6209 }
6210 }
6211 }, {
6212 key: "getComboBoxId",
6213 value: function getComboBoxId() {
6214 if (this.state && this.state.comboBoxId) {
6215 return this.state.comboBoxId;
6216 }
6217
6218 return this.props.id || getUniqueId();
6219 }
6220 }, {
6221 key: "render",
6222 value: function render() {
6223 var _this$props5 = this.props,
6224 options = _this$props5.options,
6225 textField = _this$props5.textField,
6226 listTitle = _this$props5.listTitle,
6227 allowMultiple = _this$props5.allowMultiple,
6228 preferredPosition = _this$props5.preferredPosition,
6229 actionsBefore = _this$props5.actionsBefore,
6230 actionsAfter = _this$props5.actionsAfter,
6231 contentBefore = _this$props5.contentBefore,
6232 contentAfter = _this$props5.contentAfter,
6233 onEndReached = _this$props5.onEndReached,
6234 emptyState = _this$props5.emptyState;
6235 var _this$state6 = this.state,
6236 comboBoxId = _this$state6.comboBoxId,
6237 navigableOptions = _this$state6.navigableOptions,
6238 selectedOptions = _this$state6.selectedOptions;
6239 var actionsBeforeMarkup = actionsBefore && actionsBefore.length > 0 && React__default.createElement(ActionList, {
6240 actionRole: "option",
6241 items: actionsBefore
6242 });
6243 var actionsAfterMarkup = actionsAfter && actionsAfter.length > 0 && React__default.createElement(ActionList, {
6244 actionRole: "option",
6245 items: actionsAfter
6246 });
6247 var optionsMarkup = options.length > 0 && React__default.createElement(OptionList, {
6248 role: "presentation",
6249 optionRole: "option",
6250 options: filterForOptions(navigableOptions),
6251 onChange: this.selectOptions,
6252 selected: selectedOptions,
6253 title: listTitle,
6254 allowMultiple: allowMultiple
6255 });
6256 var emptyStateMarkup = !actionsAfter && !actionsBefore && !contentAfter && !contentBefore && options.length === 0 && emptyState && React__default.createElement("div", {
6257 className: styles$p.EmptyState
6258 }, emptyState);
6259 var context = {
6260 comboBoxId,
6261 selectedOptionId: this.selectedOptionId
6262 };
6263 return React__default.createElement(ComboBoxContext.Provider, {
6264 value: context
6265 }, React__default.createElement("div", {
6266 onClick: this.handleClick,
6267 role: "combobox",
6268 "aria-expanded": this.state.popoverActive,
6269 "aria-owns": this.state.comboBoxId,
6270 "aria-controls": this.state.comboBoxId,
6271 "aria-haspopup": true,
6272 onFocus: this.handleFocus,
6273 onBlur: this.handleBlur,
6274 tabIndex: 0
6275 }, React__default.createElement(KeypressListener, {
6276 keyCode: Key.DownArrow,
6277 handler: this.handleDownArrow
6278 }), React__default.createElement(KeypressListener, {
6279 keyCode: Key.UpArrow,
6280 handler: this.handleUpArrow
6281 }), React__default.createElement(EventListener, {
6282 event: "keydown",
6283 handler: this.handleEnter
6284 }), React__default.createElement(KeypressListener, {
6285 keyCode: Key.Escape,
6286 handler: this.handlePopoverClose
6287 }), React__default.createElement(Popover, {
6288 activator: textField,
6289 active: this.state.popoverActive,
6290 onClose: this.handlePopoverClose,
6291 preferredPosition: preferredPosition,
6292 fullWidth: true,
6293 preventAutofocus: true
6294 }, React__default.createElement(Popover.Pane, {
6295 onScrolledToBottom: onEndReached
6296 }, React__default.createElement("div", {
6297 id: this.state.comboBoxId,
6298 role: "listbox",
6299 "aria-multiselectable": allowMultiple
6300 }, contentBefore, actionsBeforeMarkup, optionsMarkup, actionsAfterMarkup, contentAfter, emptyStateMarkup)))));
6301 }
6302 }, {
6303 key: "selectedOptionId",
6304 get: function get() {
6305 var _this$state7 = this.state,
6306 selectedOption = _this$state7.selectedOption,
6307 selectedIndex = _this$state7.selectedIndex,
6308 comboBoxId = _this$state7.comboBoxId;
6309 return selectedOption ? "".concat(comboBoxId, "-").concat(selectedIndex) : undefined;
6310 }
6311 }], [{
6312 key: "getDerivedStateFromProps",
6313 value: function getDerivedStateFromProps(_ref, _ref2) {
6314 var nextOptions = _ref.options,
6315 nextSelected = _ref.selected,
6316 nextActionsBefore = _ref.actionsBefore,
6317 nextActionsAfter = _ref.actionsAfter;
6318 var navigableOptions = _ref2.navigableOptions,
6319 selectedOptions = _ref2.selectedOptions,
6320 comboBoxId = _ref2.comboBoxId;
6321 var optionsChanged = filterForOptions(navigableOptions) && nextOptions && !optionsAreEqual(navigableOptions, nextOptions);
6322 var newNavigableOptions = [];
6323
6324 if (nextActionsBefore) {
6325 newNavigableOptions = newNavigableOptions.concat(nextActionsBefore);
6326 }
6327
6328 if (optionsChanged || nextActionsBefore) {
6329 newNavigableOptions = newNavigableOptions.concat(nextOptions);
6330 }
6331
6332 if (nextActionsAfter) {
6333 newNavigableOptions = newNavigableOptions.concat(nextActionsAfter);
6334 }
6335
6336 newNavigableOptions = assignOptionIds(newNavigableOptions, comboBoxId);
6337
6338 if (optionsChanged && selectedOptions !== nextSelected) {
6339 return {
6340 navigableOptions: newNavigableOptions,
6341 selectedOptions: nextSelected
6342 };
6343 } else if (optionsChanged) {
6344 return {
6345 navigableOptions: newNavigableOptions
6346 };
6347 } else if (selectedOptions !== nextSelected) {
6348 return {
6349 selectedOptions: nextSelected
6350 };
6351 }
6352
6353 return null;
6354 }
6355 }]);
6356
6357 return ComboBox;
6358}(React__default.PureComponent);
6359
6360function assignOptionIds(options, comboBoxId) {
6361 options.map(function (option, optionIndex) {
6362 option.id = "".concat(comboBoxId, "-").concat(optionIndex);
6363 });
6364 return options;
6365}
6366
6367function optionsAreEqual(firstOptions, secondOptions) {
6368 if (firstOptions.length !== secondOptions.length) {
6369 return false;
6370 }
6371
6372 return firstOptions.every(function (firstItem, index) {
6373 var secondItem = secondOptions[index];
6374
6375 if (isOption(firstItem)) {
6376 if (isOption(secondItem)) {
6377 return firstItem.value === secondItem.value;
6378 }
6379
6380 return false;
6381 } else {
6382 if (!isOption(secondItem)) {
6383 return firstItem.content === secondItem.content;
6384 }
6385
6386 return false;
6387 }
6388 });
6389}
6390
6391function isOption(navigableOption) {
6392 return navigableOption.value !== undefined;
6393}
6394
6395function filterForOptions(mixedArray) {
6396 return mixedArray.filter(function (item) {
6397 return isOption(item);
6398 });
6399}
6400
6401var styles$q = {
6402 "Label": "Polaris-Label",
6403 "hidden": "Polaris-Label--hidden",
6404 "Text": "Polaris-Label__Text"
6405};
6406
6407function labelID(id) {
6408 return "".concat(id, "Label");
6409}
6410function Label(_ref) {
6411 var children = _ref.children,
6412 id = _ref.id,
6413 hidden = _ref.hidden;
6414 var className = classNames(styles$q.Label, hidden && styles$q.hidden);
6415 return React__default.createElement("div", {
6416 className: className
6417 }, React__default.createElement("label", {
6418 id: labelID(id),
6419 htmlFor: id,
6420 className: styles$q.Text
6421 }, children));
6422}
6423
6424var styles$r = {
6425 "InlineError": "Polaris-InlineError",
6426 "Icon": "Polaris-InlineError__Icon"
6427};
6428
6429function InlineError(_ref) {
6430 var message = _ref.message,
6431 fieldID = _ref.fieldID;
6432
6433 if (!message) {
6434 return null;
6435 }
6436
6437 return React__default.createElement("div", {
6438 id: errorTextID(fieldID),
6439 className: styles$r.InlineError
6440 }, React__default.createElement("div", {
6441 className: styles$r.Icon
6442 }, React__default.createElement(Icon, {
6443 source: AlertMinor
6444 })), message);
6445}
6446function errorTextID(id) {
6447 return "".concat(id, "Error");
6448}
6449
6450var styles$s = {
6451 "hidden": "Polaris-Labelled--hidden",
6452 "LabelWrapper": "Polaris-Labelled__LabelWrapper",
6453 "HelpText": "Polaris-Labelled__HelpText",
6454 "Error": "Polaris-Labelled__Error",
6455 "Action": "Polaris-Labelled__Action"
6456};
6457
6458function Labelled(_a) {
6459 var id = _a.id,
6460 label = _a.label,
6461 error = _a.error,
6462 action = _a.action,
6463 helpText = _a.helpText,
6464 children = _a.children,
6465 labelHidden = _a.labelHidden,
6466 rest = __rest(_a, ["id", "label", "error", "action", "helpText", "children", "labelHidden"]);
6467
6468 var className = classNames(labelHidden && styles$s.hidden);
6469 var actionMarkup = action ? React__default.createElement("div", {
6470 className: styles$s.Action
6471 }, buttonFrom(action, {
6472 plain: true
6473 })) : null;
6474 var helpTextMarkup = helpText ? React__default.createElement("div", {
6475 className: styles$s.HelpText,
6476 id: helpTextID(id)
6477 }, helpText) : null;
6478 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
6479 className: styles$s.Error
6480 }, React__default.createElement(InlineError, {
6481 message: error,
6482 fieldID: id
6483 }));
6484 var labelMarkup = label ? React__default.createElement("div", {
6485 className: styles$s.LabelWrapper
6486 }, React__default.createElement(Label, Object.assign({
6487 id: id
6488 }, rest, {
6489 hidden: false
6490 }), label), actionMarkup) : null;
6491 return React__default.createElement("div", {
6492 className: className
6493 }, labelMarkup, children, errorMarkup, helpTextMarkup);
6494}
6495function helpTextID(id) {
6496 return "".concat(id, "HelpText");
6497}
6498
6499var styles$t = {
6500 "Connected": "Polaris-Connected",
6501 "Item": "Polaris-Connected__Item",
6502 "Item-primary": "Polaris-Connected__Item--primary",
6503 "Item-connection": "Polaris-Connected__Item--connection",
6504 "Item-focused": "Polaris-Connected__Item--focused"
6505};
6506
6507var ItemPosition;
6508
6509(function (ItemPosition) {
6510 ItemPosition[ItemPosition["Left"] = 0] = "Left";
6511 ItemPosition[ItemPosition["Primary"] = 1] = "Primary";
6512 ItemPosition[ItemPosition["Right"] = 2] = "Right";
6513})(ItemPosition || (ItemPosition = {}));
6514
6515var Item$3 =
6516/*#__PURE__*/
6517function (_React$PureComponent) {
6518 _inherits(Item, _React$PureComponent);
6519
6520 function Item() {
6521 var _this;
6522
6523 _classCallCheck(this, Item);
6524
6525 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
6526 _this.state = {
6527 focused: false
6528 };
6529
6530 _this.handleBlur = function () {
6531 _this.setState({
6532 focused: false
6533 });
6534 };
6535
6536 _this.handleFocus = function () {
6537 _this.setState({
6538 focused: true
6539 });
6540 };
6541
6542 return _this;
6543 }
6544
6545 _createClass(Item, [{
6546 key: "render",
6547 value: function render() {
6548 var focused = this.state.focused;
6549 var _this$props = this.props,
6550 children = _this$props.children,
6551 position = _this$props.position;
6552 var className = classNames(styles$t.Item, focused && styles$t['Item-focused'], position === ItemPosition.Primary ? styles$t['Item-primary'] : styles$t['Item-connection']);
6553 return React__default.createElement("div", {
6554 onBlur: this.handleBlur,
6555 onFocus: this.handleFocus,
6556 className: className
6557 }, children);
6558 }
6559 }]);
6560
6561 return Item;
6562}(React__default.PureComponent);
6563
6564function Connected(_ref) {
6565 var children = _ref.children,
6566 left = _ref.left,
6567 right = _ref.right;
6568 var leftConnectionMarkup = left ? React__default.createElement(Item$3, {
6569 position: ItemPosition.Left
6570 }, left) : null;
6571 var rightConnectionMarkup = right ? React__default.createElement(Item$3, {
6572 position: ItemPosition.Right
6573 }, right) : null;
6574 return React__default.createElement("div", {
6575 className: styles$t.Connected
6576 }, leftConnectionMarkup, React__default.createElement(Item$3, {
6577 position: ItemPosition.Primary
6578 }, children), rightConnectionMarkup);
6579}
6580
6581var styles$u = {
6582 "TextField": "Polaris-TextField",
6583 "multiline": "Polaris-TextField--multiline",
6584 "Input": "Polaris-TextField__Input",
6585 "hasValue": "Polaris-TextField--hasValue",
6586 "focus": "Polaris-TextField--focus",
6587 "Backdrop": "Polaris-TextField__Backdrop",
6588 "error": "Polaris-TextField--error",
6589 "readOnly": "Polaris-TextField--readOnly",
6590 "disabled": "Polaris-TextField--disabled",
6591 "Prefix": "Polaris-TextField__Prefix",
6592 "Input-hasClearButton": "Polaris-TextField__Input--hasClearButton",
6593 "Input-suffixed": "Polaris-TextField__Input--suffixed",
6594 "Input-alignRight": "Polaris-TextField__Input--alignRight",
6595 "Input-alignLeft": "Polaris-TextField__Input--alignLeft",
6596 "Input-alignCenter": "Polaris-TextField__Input--alignCenter",
6597 "Suffix": "Polaris-TextField__Suffix",
6598 "CharacterCount": "Polaris-TextField__CharacterCount",
6599 "AlignFieldBottom": "Polaris-TextField__AlignFieldBottom",
6600 "ClearButton": "Polaris-TextField__ClearButton",
6601 "Spinner": "Polaris-TextField__Spinner",
6602 "SpinnerIcon": "Polaris-TextField__SpinnerIcon",
6603 "Resizer": "Polaris-TextField__Resizer",
6604 "DummyInput": "Polaris-TextField__DummyInput",
6605 "Segment": "Polaris-TextField__Segment",
6606 "globalTheming": "Polaris-TextField--globalTheming"
6607};
6608
6609function Resizer(_ref) {
6610 var contents = _ref.contents,
6611 _ref$currentHeight = _ref.currentHeight,
6612 currentHeightProp = _ref$currentHeight === void 0 ? null : _ref$currentHeight,
6613 minimumLines = _ref.minimumLines,
6614 onHeightChange = _ref.onHeightChange;
6615 var contentNode = useRef(null);
6616 var minimumLinesNode = useRef(null);
6617 var animationFrame = useRef();
6618 var currentHeight = useRef(currentHeightProp);
6619
6620 if (currentHeightProp !== currentHeight.current) {
6621 currentHeight.current = currentHeightProp;
6622 }
6623
6624 useEffect(function () {
6625 return function () {
6626 if (animationFrame.current) {
6627 cancelAnimationFrame(animationFrame.current);
6628 }
6629 };
6630 }, []);
6631 var minimumLinesMarkup = minimumLines ? React__default.createElement("div", {
6632 ref: minimumLinesNode,
6633 className: styles$u.DummyInput,
6634 dangerouslySetInnerHTML: {
6635 __html: getContentsForMinimumLines(minimumLines)
6636 }
6637 }) : null;
6638 var handleHeightCheck = useCallback(function () {
6639 if (animationFrame.current) {
6640 cancelAnimationFrame(animationFrame.current);
6641 }
6642
6643 animationFrame.current = requestAnimationFrame(function () {
6644 if (!contentNode.current || !minimumLinesNode.current) {
6645 return;
6646 }
6647
6648 var newHeight = Math.max(contentNode.current.offsetHeight, minimumLinesNode.current.offsetHeight);
6649
6650 if (newHeight !== currentHeight.current) {
6651 onHeightChange(newHeight);
6652 }
6653 });
6654 }, [onHeightChange]);
6655 useLayoutEffect(function () {
6656 handleHeightCheck();
6657 });
6658 return React__default.createElement("div", {
6659 "aria-hidden": true,
6660 className: styles$u.Resizer
6661 }, React__default.createElement(EventListener, {
6662 event: "resize",
6663 handler: handleHeightCheck
6664 }), React__default.createElement("div", {
6665 ref: contentNode,
6666 className: styles$u.DummyInput,
6667 dangerouslySetInnerHTML: {
6668 __html: getFinalContents(contents)
6669 }
6670 }), minimumLinesMarkup);
6671}
6672var ENTITIES_TO_REPLACE = {
6673 '&': '&amp;',
6674 '<': '&lt;',
6675 '>': '&gt;',
6676 '\n': '<br>',
6677 '\r': ''
6678};
6679var REPLACE_REGEX$1 = new RegExp("[".concat(Object.keys(ENTITIES_TO_REPLACE).join(), "]"), 'g');
6680
6681function replaceEntity(entity) {
6682 return ENTITIES_TO_REPLACE[entity];
6683}
6684
6685function getContentsForMinimumLines(minimumLines) {
6686 var content = '';
6687
6688 for (var line = 0; line < minimumLines; line++) {
6689 content += '<br>';
6690 }
6691
6692 return content;
6693}
6694
6695function getFinalContents(contents) {
6696 return contents ? "".concat(contents.replace(REPLACE_REGEX$1, replaceEntity), "<br>") : '<br>';
6697}
6698
6699function Spinner$1(_ref) {
6700 var onChange = _ref.onChange,
6701 onClick = _ref.onClick,
6702 onMouseDown = _ref.onMouseDown,
6703 onMouseUp = _ref.onMouseUp;
6704
6705 function handleStep(step) {
6706 return function () {
6707 return onChange(step);
6708 };
6709 }
6710
6711 function handleMouseDown(onChange) {
6712 return function (event) {
6713 if (event.button !== 0) return;
6714 onMouseDown(onChange);
6715 };
6716 }
6717
6718 return React__default.createElement("div", {
6719 className: styles$u.Spinner,
6720 onClick: onClick,
6721 "aria-hidden": true
6722 }, React__default.createElement("div", {
6723 role: "button",
6724 className: styles$u.Segment,
6725 tabIndex: -1,
6726 onClick: handleStep(1),
6727 onMouseDown: handleMouseDown(handleStep(1)),
6728 onMouseUp: onMouseUp
6729 }, React__default.createElement("div", {
6730 className: styles$u.SpinnerIcon
6731 }, React__default.createElement(Icon, {
6732 source: CaretUpMinor
6733 }))), React__default.createElement("div", {
6734 role: "button",
6735 className: styles$u.Segment,
6736 tabIndex: -1,
6737 onClick: handleStep(-1),
6738 onMouseDown: handleMouseDown(handleStep(-1)),
6739 onMouseUp: onMouseUp
6740 }, React__default.createElement("div", {
6741 className: styles$u.SpinnerIcon
6742 }, React__default.createElement(Icon, {
6743 source: CaretDownMinor
6744 }))));
6745}
6746
6747function TextField(_ref) {
6748 var prefix = _ref.prefix,
6749 suffix = _ref.suffix,
6750 placeholder = _ref.placeholder,
6751 value = _ref.value,
6752 helpText = _ref.helpText,
6753 label = _ref.label,
6754 labelAction = _ref.labelAction,
6755 labelHidden = _ref.labelHidden,
6756 disabled = _ref.disabled,
6757 clearButton = _ref.clearButton,
6758 readOnly = _ref.readOnly,
6759 autoFocus = _ref.autoFocus,
6760 focused = _ref.focused,
6761 multiline = _ref.multiline,
6762 error = _ref.error,
6763 connectedRight = _ref.connectedRight,
6764 connectedLeft = _ref.connectedLeft,
6765 type = _ref.type,
6766 name = _ref.name,
6767 idProp = _ref.id,
6768 role = _ref.role,
6769 _ref$step = _ref.step,
6770 step = _ref$step === void 0 ? 1 : _ref$step,
6771 autoComplete = _ref.autoComplete,
6772 _ref$max = _ref.max,
6773 max = _ref$max === void 0 ? Infinity : _ref$max,
6774 maxLength = _ref.maxLength,
6775 _ref$min = _ref.min,
6776 min = _ref$min === void 0 ? -Infinity : _ref$min,
6777 minLength = _ref.minLength,
6778 pattern = _ref.pattern,
6779 spellCheck = _ref.spellCheck,
6780 ariaOwns = _ref.ariaOwns,
6781 ariaControls = _ref.ariaControls,
6782 ariaActiveDescendant = _ref.ariaActiveDescendant,
6783 ariaAutocomplete = _ref.ariaAutocomplete,
6784 showCharacterCount = _ref.showCharacterCount,
6785 align = _ref.align,
6786 onClearButtonClick = _ref.onClearButtonClick,
6787 onChange = _ref.onChange,
6788 onFocus = _ref.onFocus,
6789 onBlur = _ref.onBlur;
6790 var i18n = useI18n();
6791
6792 var _useState = useState(null),
6793 _useState2 = _slicedToArray(_useState, 2),
6794 height = _useState2[0],
6795 setHeight = _useState2[1];
6796
6797 var _useState3 = useState(Boolean(focused)),
6798 _useState4 = _slicedToArray(_useState3, 2),
6799 focus = _useState4[0],
6800 setFocus = _useState4[1];
6801
6802 var isAfterInitial = useIsAfterInitialMount();
6803 var id = useUniqueId('TextField', idProp);
6804 var inputRef = useRef(null);
6805 var prefixRef = useRef(null);
6806 var suffixRef = useRef(null);
6807 var buttonPressTimer = useRef();
6808 useEffect(function () {
6809 var input = inputRef.current;
6810 if (!input || focused === undefined) return;
6811 focused ? input.focus() : input.blur();
6812 }, [focused]);
6813 var normalizedValue = value != null ? value : '';
6814
6815 var _useFeatures = useFeatures(),
6816 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
6817 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
6818
6819 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, unstableGlobalTheming && styles$u.globalTheming);
6820 var inputType = type === 'currency' ? 'text' : type;
6821 var prefixMarkup = prefix ? React__default.createElement("div", {
6822 className: styles$u.Prefix,
6823 id: "".concat(id, "Prefix"),
6824 ref: prefixRef
6825 }, prefix) : null;
6826 var suffixMarkup = suffix ? React__default.createElement("div", {
6827 className: styles$u.Suffix,
6828 id: "".concat(id, "Suffix"),
6829 ref: suffixRef
6830 }, suffix) : null;
6831 var characterCount = normalizedValue.length;
6832 var characterCountLabel = i18n.translate(maxLength ? 'Polaris.TextField.characterCountWithMaxLength' : 'Polaris.TextField.characterCount', {
6833 count: characterCount,
6834 limit: maxLength
6835 });
6836 var characterCountClassName = classNames(styles$u.CharacterCount, multiline && styles$u.AlignFieldBottom);
6837 var characterCountText = !maxLength ? characterCount : "".concat(characterCount, "/").concat(maxLength);
6838 var characterCountMarkup = showCharacterCount ? React__default.createElement("div", {
6839 id: "".concat(id, "CharacterCounter"),
6840 className: characterCountClassName,
6841 "aria-label": characterCountLabel,
6842 "aria-live": focus ? 'polite' : 'off',
6843 "aria-atomic": "true"
6844 }, characterCountText) : null;
6845 var clearButtonMarkup = clearButton && normalizedValue !== '' ? React__default.createElement("button", {
6846 type: "button",
6847 className: styles$u.ClearButton,
6848 onClick: handleClearButtonPress,
6849 disabled: disabled
6850 }, React__default.createElement(VisuallyHidden, null, i18n.translate('Polaris.Common.clear')), React__default.createElement(Icon, {
6851 source: CircleCancelMinor,
6852 color: "inkLightest"
6853 })) : null;
6854 var handleNumberChange = useCallback(function (steps) {
6855 if (onChange == null) {
6856 return;
6857 } // Returns the length of decimal places in a number
6858
6859
6860 var dpl = function dpl(num) {
6861 return (num.toString().split('.')[1] || []).length;
6862 };
6863
6864 var numericValue = value ? parseFloat(value) : 0;
6865
6866 if (isNaN(numericValue)) {
6867 return;
6868 } // Making sure the new value has the same length of decimal places as the
6869 // step / value has.
6870
6871
6872 var decimalPlaces = Math.max(dpl(numericValue), dpl(step));
6873 var newValue = Math.min(Number(max), Math.max(numericValue + steps * step, Number(min)));
6874 onChange(String(newValue.toFixed(decimalPlaces)), id);
6875 }, [id, max, min, onChange, step, value]);
6876 var handleButtonRelease = useCallback(function () {
6877 clearTimeout(buttonPressTimer.current);
6878 }, []);
6879 var handleButtonPress = useCallback(function (onChange) {
6880 var minInterval = 50;
6881 var decrementBy = 10;
6882 var interval = 200;
6883
6884 var onChangeInterval = function onChangeInterval() {
6885 if (interval > minInterval) interval -= decrementBy;
6886 onChange();
6887 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6888 };
6889
6890 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6891 addEventListener(document, 'mouseup', handleButtonRelease, {
6892 once: true
6893 });
6894 }, [handleButtonRelease]);
6895 var spinnerMarkup = type === 'number' && !disabled && !readOnly ? React__default.createElement(Spinner$1, {
6896 onChange: handleNumberChange,
6897 onMouseDown: handleButtonPress,
6898 onMouseUp: handleButtonRelease
6899 }) : null;
6900 var style = multiline && height ? {
6901 height
6902 } : null;
6903 var handleExpandingResize = useCallback(function (height) {
6904 setHeight(height);
6905 }, []);
6906 var resizer = multiline && isAfterInitial ? React__default.createElement(Resizer, {
6907 contents: normalizedValue || placeholder,
6908 currentHeight: height,
6909 minimumLines: typeof multiline === 'number' ? multiline : 1,
6910 onHeightChange: handleExpandingResize
6911 }) : null;
6912 var describedBy = [];
6913
6914 if (error) {
6915 describedBy.push("".concat(id, "Error"));
6916 }
6917
6918 if (helpText) {
6919 describedBy.push(helpTextID(id));
6920 }
6921
6922 if (showCharacterCount) {
6923 describedBy.push("".concat(id, "CharacterCounter"));
6924 }
6925
6926 var labelledBy = [];
6927
6928 if (prefix) {
6929 labelledBy.push("".concat(id, "Prefix"));
6930 }
6931
6932 if (suffix) {
6933 labelledBy.push("".concat(id, "Suffix"));
6934 }
6935
6936 labelledBy.unshift(labelID(id));
6937 var inputClassName = classNames(styles$u.Input, align && styles$u[variationName('Input-align', align)], suffix && styles$u['Input-suffixed'], clearButton && styles$u['Input-hasClearButton']);
6938 var input = React__default.createElement(multiline ? 'textarea' : 'input', {
6939 name,
6940 id,
6941 disabled,
6942 readOnly,
6943 role,
6944 autoFocus,
6945 value: normalizedValue,
6946 placeholder,
6947 onFocus,
6948 onBlur,
6949 onKeyPress: handleKeyPress,
6950 style,
6951 autoComplete: normalizeAutoComplete(autoComplete),
6952 className: inputClassName,
6953 onChange: handleChange,
6954 ref: inputRef,
6955 min,
6956 max,
6957 step,
6958 minLength,
6959 maxLength,
6960 spellCheck,
6961 pattern,
6962 type: inputType,
6963 'aria-describedby': describedBy.length ? describedBy.join(' ') : undefined,
6964 'aria-labelledby': labelledBy.join(' '),
6965 'aria-invalid': Boolean(error),
6966 'aria-owns': ariaOwns,
6967 'aria-activedescendant': ariaActiveDescendant,
6968 'aria-autocomplete': ariaAutocomplete,
6969 'aria-controls': ariaControls,
6970 'aria-multiline': normalizeAriaMultiline(multiline)
6971 });
6972 return React__default.createElement(Labelled, {
6973 label: label,
6974 id: id,
6975 error: error,
6976 action: labelAction,
6977 labelHidden: labelHidden,
6978 helpText: helpText
6979 }, React__default.createElement(Connected, {
6980 left: connectedLeft,
6981 right: connectedRight
6982 }, React__default.createElement("div", {
6983 className: className,
6984 onFocus: handleFocus,
6985 onBlur: handleBlur,
6986 onClick: handleClick
6987 }, prefixMarkup, input, suffixMarkup, characterCountMarkup, clearButtonMarkup, spinnerMarkup, React__default.createElement("div", {
6988 className: styles$u.Backdrop
6989 }), resizer)));
6990
6991 function handleClearButtonPress() {
6992 onClearButtonClick && onClearButtonClick(id);
6993 }
6994
6995 function handleKeyPress(event) {
6996 var key = event.key,
6997 which = event.which;
6998 var numbersSpec = /[\d.eE+-]$/;
6999
7000 if (type !== 'number' || which === Key.Enter || numbersSpec.test(key)) {
7001 return;
7002 }
7003
7004 event.preventDefault();
7005 }
7006
7007 function containsAffix(target) {
7008 return target instanceof HTMLElement && (prefixRef.current && prefixRef.current.contains(target) || suffixRef.current && suffixRef.current.contains(target));
7009 }
7010
7011 function handleChange(event) {
7012 onChange && onChange(event.currentTarget.value, id);
7013 }
7014
7015 function handleFocus(_ref2) {
7016 var target = _ref2.target;
7017
7018 if (containsAffix(target)) {
7019 return;
7020 }
7021
7022 setFocus(true);
7023 }
7024
7025 function handleBlur() {
7026 setFocus(false);
7027 }
7028
7029 function handleClick(_ref3) {
7030 var target = _ref3.target;
7031
7032 if (containsAffix(target)) {
7033 return;
7034 }
7035
7036 inputRef.current && inputRef.current.focus();
7037 }
7038}
7039
7040function normalizeAutoComplete(autoComplete) {
7041 if (autoComplete == null) {
7042 return autoComplete;
7043 } else if (autoComplete === true) {
7044 return 'on';
7045 } else if (autoComplete === false) {
7046 return 'off';
7047 } else {
7048 return autoComplete;
7049 }
7050}
7051
7052function normalizeAriaMultiline(multiline) {
7053 switch (typeof multiline) {
7054 case 'undefined':
7055 return false;
7056
7057 case 'boolean':
7058 return multiline;
7059
7060 case 'number':
7061 return Boolean(multiline > 0);
7062 }
7063}
7064
7065function TextField$1(props) {
7066 return React__default.createElement(ComboBoxContext.Consumer, null, function (_ref) {
7067 var selectedOptionId = _ref.selectedOptionId,
7068 comboBoxId = _ref.comboBoxId;
7069 return React__default.createElement(TextField, Object.assign({}, props, {
7070 autoComplete: false,
7071 ariaAutocomplete: "list",
7072 ariaActiveDescendant: selectedOptionId,
7073 ariaControls: comboBoxId
7074 }));
7075 });
7076}
7077
7078var styles$v = {
7079 "Loading": "Polaris-Autocomplete__Loading"
7080};
7081
7082// subcomponents so explicitly state the subcomponents in the type definition.
7083// Letting this be implicit works in this project but fails in projects that use
7084// generated *.d.ts files.
7085
7086var Autocomplete = function Autocomplete(_ref) {
7087 var id = _ref.id,
7088 options = _ref.options,
7089 selected = _ref.selected,
7090 textField = _ref.textField,
7091 preferredPosition = _ref.preferredPosition,
7092 listTitle = _ref.listTitle,
7093 allowMultiple = _ref.allowMultiple,
7094 loading = _ref.loading,
7095 actionBefore = _ref.actionBefore,
7096 willLoadMoreResults = _ref.willLoadMoreResults,
7097 emptyState = _ref.emptyState,
7098 onSelect = _ref.onSelect,
7099 onLoadMoreResults = _ref.onLoadMoreResults;
7100 var i18n = useI18n();
7101 var spinnerMarkup = loading ? React__default.createElement("div", {
7102 className: styles$v.Loading
7103 }, React__default.createElement(Spinner, {
7104 size: "small",
7105 accessibilityLabel: i18n.translate('Polaris.Autocomplete.spinnerAccessibilityLabel')
7106 })) : null;
7107 var conditionalOptions = loading && !willLoadMoreResults ? [] : options;
7108 var conditionalAction = actionBefore && actionBefore !== [] ? [actionBefore] : undefined;
7109 return React__default.createElement(ComboBox, {
7110 id: id,
7111 options: conditionalOptions,
7112 selected: selected,
7113 textField: textField,
7114 preferredPosition: preferredPosition,
7115 listTitle: listTitle,
7116 allowMultiple: allowMultiple,
7117 contentAfter: spinnerMarkup,
7118 actionsBefore: conditionalAction,
7119 onSelect: onSelect,
7120 onEndReached: onLoadMoreResults,
7121 emptyState: emptyState
7122 });
7123};
7124Autocomplete.ComboBox = ComboBox;
7125Autocomplete.TextField = TextField$1;
7126
7127// in the styleguide works without warnings about unfound props
7128
7129function ScrollLock(_) {
7130 var scrollLockManager = useScrollLockManager();
7131 useEffect(function () {
7132 scrollLockManager.registerScrollLock();
7133 return function () {
7134 scrollLockManager.unregisterScrollLock();
7135 };
7136 }, [scrollLockManager]);
7137 return null;
7138}
7139
7140var styles$w = {
7141 "Backdrop": "Polaris-Backdrop",
7142 "fade-in": "Polaris-Backdrop__fade--in",
7143 "transparent": "Polaris-Backdrop--transparent",
7144 "belowNavigation": "Polaris-Backdrop--belowNavigation"
7145};
7146
7147function Backdrop(props) {
7148 var onClick = props.onClick,
7149 onTouchStart = props.onTouchStart,
7150 belowNavigation = props.belowNavigation,
7151 transparent = props.transparent;
7152 var className = classNames(styles$w.Backdrop, belowNavigation && styles$w.belowNavigation, transparent && styles$w.transparent);
7153 return React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
7154 className: className,
7155 onClick: onClick,
7156 onTouchStart: onTouchStart
7157 }));
7158}
7159
7160var BannerContext = React__default.createContext(false);
7161
7162var styles$x = {
7163 "Banner": "Polaris-Banner",
7164 "withinContentContainer": "Polaris-Banner--withinContentContainer",
7165 "statusSuccess": "Polaris-Banner--statusSuccess",
7166 "statusInfo": "Polaris-Banner--statusInfo",
7167 "statusWarning": "Polaris-Banner--statusWarning",
7168 "statusCritical": "Polaris-Banner--statusCritical",
7169 "Ribbon": "Polaris-Banner__Ribbon",
7170 "Actions": "Polaris-Banner__Actions",
7171 "Dismiss": "Polaris-Banner__Dismiss",
7172 "withinPage": "Polaris-Banner--withinPage",
7173 "hasDismiss": "Polaris-Banner--hasDismiss",
7174 "Heading": "Polaris-Banner__Heading",
7175 "Content": "Polaris-Banner__Content",
7176 "PrimaryAction": "Polaris-Banner__PrimaryAction",
7177 "SecondaryAction": "Polaris-Banner__SecondaryAction",
7178 "Text": "Polaris-Banner__Text"
7179};
7180
7181var Banner =
7182/*#__PURE__*/
7183function (_React$PureComponent) {
7184 _inherits(Banner, _React$PureComponent);
7185
7186 function Banner() {
7187 var _this;
7188
7189 _classCallCheck(this, Banner);
7190
7191 _this = _possibleConstructorReturn(this, _getPrototypeOf(Banner).apply(this, arguments));
7192 _this.wrapper = React__default.createRef();
7193 return _this;
7194 }
7195
7196 _createClass(Banner, [{
7197 key: "focus",
7198 value: function focus() {
7199 this.wrapper.current && this.wrapper.current.focus();
7200 }
7201 }, {
7202 key: "render",
7203 value: function render() {
7204 var _this2 = this;
7205
7206 return React__default.createElement(BannerContext.Provider, {
7207 value: true
7208 }, React__default.createElement(WithinContentContext.Consumer, null, function (withinContentContainer) {
7209 var _this2$props = _this2.props,
7210 icon = _this2$props.icon,
7211 action = _this2$props.action,
7212 secondaryAction = _this2$props.secondaryAction,
7213 title = _this2$props.title,
7214 children = _this2$props.children,
7215 status = _this2$props.status,
7216 onDismiss = _this2$props.onDismiss,
7217 stopAnnouncements = _this2$props.stopAnnouncements;
7218 var color;
7219 var defaultIcon;
7220 var ariaRoleType = 'status';
7221
7222 switch (status) {
7223 case 'success':
7224 color = 'greenDark';
7225 defaultIcon = CircleTickMajorTwotone;
7226 break;
7227
7228 case 'info':
7229 color = 'tealDark';
7230 defaultIcon = CircleInformationMajorTwotone;
7231 break;
7232
7233 case 'warning':
7234 color = 'yellowDark';
7235 defaultIcon = CircleAlertMajorTwotone;
7236 ariaRoleType = 'alert';
7237 break;
7238
7239 case 'critical':
7240 color = 'redDark';
7241 defaultIcon = CircleDisabledMajorTwotone;
7242 ariaRoleType = 'alert';
7243 break;
7244
7245 default:
7246 color = 'inkLighter';
7247 defaultIcon = FlagMajorTwotone;
7248 }
7249
7250 var className = classNames(styles$x.Banner, status && styles$x[variationName('status', status)], onDismiss && styles$x.hasDismiss, withinContentContainer ? styles$x.withinContentContainer : styles$x.withinPage);
7251 var id = uniqueID();
7252 var iconName = icon || defaultIcon;
7253 var headingMarkup = null;
7254 var headingID;
7255
7256 if (title) {
7257 headingID = "".concat(id, "Heading");
7258 headingMarkup = React__default.createElement("div", {
7259 className: styles$x.Heading,
7260 id: headingID
7261 }, React__default.createElement(Heading, {
7262 element: "p"
7263 }, title));
7264 }
7265
7266 var buttonSizeValue = withinContentContainer ? 'slim' : undefined;
7267 var secondaryActionMarkup = secondaryAction ? secondaryActionFrom(secondaryAction) : null;
7268 var actionMarkup = action ? React__default.createElement("div", {
7269 className: styles$x.Actions
7270 }, React__default.createElement(ButtonGroup, null, React__default.createElement("div", {
7271 className: styles$x.PrimaryAction
7272 }, buttonFrom(action, {
7273 outline: true,
7274 size: buttonSizeValue
7275 })), secondaryActionMarkup)) : null;
7276 var contentMarkup = null;
7277 var contentID;
7278
7279 if (children || actionMarkup) {
7280 contentID = "".concat(id, "Content");
7281 contentMarkup = React__default.createElement("div", {
7282 className: styles$x.Content,
7283 id: contentID
7284 }, children, actionMarkup);
7285 }
7286
7287 var dismissButton = onDismiss ? React__default.createElement("div", {
7288 className: styles$x.Dismiss
7289 }, React__default.createElement(Button, {
7290 plain: true,
7291 icon: CancelSmallMinor,
7292 onClick: onDismiss,
7293 accessibilityLabel: "Dismiss notification"
7294 })) : null;
7295 return React__default.createElement("div", {
7296 className: className // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
7297 ,
7298 tabIndex: 0,
7299 ref: _this2.wrapper,
7300 role: ariaRoleType,
7301 "aria-live": stopAnnouncements ? 'off' : 'polite',
7302 onMouseUp: handleMouseUp,
7303 "aria-labelledby": headingID,
7304 "aria-describedby": contentID
7305 }, dismissButton, React__default.createElement("div", {
7306 className: styles$x.Ribbon
7307 }, React__default.createElement(Icon, {
7308 source: iconName,
7309 color: color,
7310 backdrop: true
7311 })), React__default.createElement("div", null, headingMarkup, contentMarkup));
7312 }));
7313 }
7314 }]);
7315
7316 return Banner;
7317}(React__default.PureComponent);
7318var index = 1;
7319
7320function uniqueID() {
7321 return "Banner".concat(index++);
7322}
7323
7324function handleMouseUp(_ref) {
7325 var currentTarget = _ref.currentTarget;
7326 currentTarget.blur();
7327}
7328
7329function secondaryActionFrom(action) {
7330 if (action.url) {
7331 return React__default.createElement(UnstyledLink, {
7332 className: styles$x.SecondaryAction,
7333 url: action.url,
7334 external: action.external
7335 }, React__default.createElement("span", {
7336 className: styles$x.Text
7337 }, action.content));
7338 }
7339
7340 return React__default.createElement("button", {
7341 className: styles$x.SecondaryAction,
7342 onClick: action.onAction
7343 }, React__default.createElement("span", {
7344 className: styles$x.Text
7345 }, action.content));
7346}
7347
7348var styles$y = {
7349 "Breadcrumb": "Polaris-Breadcrumbs__Breadcrumb",
7350 "Icon": "Polaris-Breadcrumbs__Icon",
7351 "ContentWrapper": "Polaris-Breadcrumbs__ContentWrapper",
7352 "Content": "Polaris-Breadcrumbs__Content"
7353};
7354
7355var Breadcrumbs =
7356/*#__PURE__*/
7357function (_React$PureComponent) {
7358 _inherits(Breadcrumbs, _React$PureComponent);
7359
7360 function Breadcrumbs() {
7361 _classCallCheck(this, Breadcrumbs);
7362
7363 return _possibleConstructorReturn(this, _getPrototypeOf(Breadcrumbs).apply(this, arguments));
7364 }
7365
7366 _createClass(Breadcrumbs, [{
7367 key: "render",
7368 value: function render() {
7369 var breadcrumbs = this.props.breadcrumbs;
7370 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
7371
7372 if (breadcrumb == null) {
7373 return null;
7374 }
7375
7376 var content = breadcrumb.content;
7377 var contentMarkup = React__default.createElement("span", {
7378 className: styles$y.ContentWrapper
7379 }, React__default.createElement("span", {
7380 className: styles$y.Icon
7381 }, React__default.createElement(Icon, {
7382 source: ChevronLeftMinor
7383 })), React__default.createElement("span", {
7384 className: styles$y.Content
7385 }, content));
7386 var breadcrumbMarkup = 'url' in breadcrumb ? React__default.createElement(UnstyledLink, {
7387 key: content,
7388 url: breadcrumb.url,
7389 className: styles$y.Breadcrumb,
7390 onMouseUp: handleMouseUpByBlurring,
7391 "aria-label": breadcrumb.accessibilityLabel
7392 }, contentMarkup) : React__default.createElement("button", {
7393 key: content,
7394 className: styles$y.Breadcrumb,
7395 onClick: breadcrumb.onAction,
7396 onMouseUp: handleMouseUpByBlurring,
7397 type: "button",
7398 "aria-label": breadcrumb.accessibilityLabel
7399 }, contentMarkup);
7400 return React__default.createElement("nav", {
7401 role: "navigation"
7402 }, breadcrumbMarkup);
7403 }
7404 }]);
7405
7406 return Breadcrumbs;
7407}(React__default.PureComponent);
7408
7409var styles$z = {
7410 "TextContainer": "Polaris-TextContainer",
7411 "spacingTight": "Polaris-TextContainer--spacingTight",
7412 "spacingLoose": "Polaris-TextContainer--spacingLoose"
7413};
7414
7415function TextContainer(_ref) {
7416 var spacing = _ref.spacing,
7417 children = _ref.children;
7418 var className = classNames(styles$z.TextContainer, spacing && styles$z[variationName('spacing', spacing)]);
7419 return React__default.createElement("div", {
7420 className: className
7421 }, children);
7422}
7423
7424var styles$A = {
7425 "CalloutCard": "Polaris-CalloutCard",
7426 "Image": "Polaris-CalloutCard__Image",
7427 "DismissImage": "Polaris-CalloutCard__DismissImage",
7428 "Content": "Polaris-CalloutCard__Content",
7429 "Title": "Polaris-CalloutCard__Title",
7430 "Buttons": "Polaris-CalloutCard__Buttons",
7431 "Container": "Polaris-CalloutCard__Container",
7432 "Dismiss": "Polaris-CalloutCard__Dismiss"
7433};
7434
7435function CalloutCard(_ref) {
7436 var title = _ref.title,
7437 children = _ref.children,
7438 illustration = _ref.illustration,
7439 primaryAction = _ref.primaryAction,
7440 secondaryAction = _ref.secondaryAction,
7441 onDismiss = _ref.onDismiss;
7442 var primaryActionMarkup = buttonFrom(primaryAction);
7443 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
7444 plain: true
7445 }) : null;
7446 var buttonMarkup = secondaryActionMarkup ? React__default.createElement(ButtonGroup, null, primaryActionMarkup, secondaryActionMarkup) : primaryActionMarkup;
7447 var dismissButton = onDismiss ? React__default.createElement("div", {
7448 className: styles$A.Dismiss
7449 }, React__default.createElement(Button, {
7450 plain: true,
7451 icon: CancelSmallMinor,
7452 onClick: onDismiss,
7453 accessibilityLabel: "Dismiss card"
7454 })) : null;
7455 var imageClassName = classNames(styles$A.Image, onDismiss && styles$A.DismissImage);
7456 return React__default.createElement(Card, null, React__default.createElement("div", {
7457 className: styles$A.Container
7458 }, dismissButton, React__default.createElement(Card.Section, null, React__default.createElement("div", {
7459 className: styles$A.CalloutCard
7460 }, React__default.createElement("div", {
7461 className: styles$A.Content
7462 }, React__default.createElement("div", {
7463 className: styles$A.Title
7464 }, React__default.createElement(Heading, null, title)), React__default.createElement(TextContainer, null, children), React__default.createElement("div", {
7465 className: styles$A.Buttons
7466 }, buttonMarkup)), React__default.createElement(Image, {
7467 alt: "",
7468 className: imageClassName,
7469 source: illustration
7470 })))));
7471}
7472
7473var styles$B = {
7474 "Caption": "Polaris-Caption"
7475};
7476
7477function Caption(_ref) {
7478 var children = _ref.children;
7479 return React__default.createElement("p", {
7480 className: styles$B.Caption
7481 }, children);
7482}
7483
7484var styles$C = {
7485 "Choice": "Polaris-Choice",
7486 "labelHidden": "Polaris-Choice--labelHidden",
7487 "Label": "Polaris-Choice__Label",
7488 "Control": "Polaris-Choice__Control",
7489 "disabled": "Polaris-Choice--disabled",
7490 "Descriptions": "Polaris-Choice__Descriptions",
7491 "HelpText": "Polaris-Choice__HelpText"
7492};
7493
7494function Choice(_ref) {
7495 var id = _ref.id,
7496 label = _ref.label,
7497 disabled = _ref.disabled,
7498 error = _ref.error,
7499 children = _ref.children,
7500 labelHidden = _ref.labelHidden,
7501 helpText = _ref.helpText,
7502 onClick = _ref.onClick;
7503 var className = classNames(styles$C.Choice, labelHidden && styles$C.labelHidden, disabled && styles$C.disabled);
7504 var labelMarkup = React__default.createElement("label", {
7505 className: className,
7506 htmlFor: id,
7507 onClick: onClick
7508 }, React__default.createElement("span", {
7509 className: styles$C.Control
7510 }, children), React__default.createElement("span", {
7511 className: styles$C.Label
7512 }, label));
7513 var helpTextMarkup = helpText ? React__default.createElement("div", {
7514 className: styles$C.HelpText,
7515 id: helpTextID$1(id)
7516 }, helpText) : null;
7517 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
7518 className: styles$C.Error
7519 }, React__default.createElement(InlineError, {
7520 message: error,
7521 fieldID: id
7522 }));
7523 var descriptionMarkup = helpTextMarkup || errorMarkup ? React__default.createElement("div", {
7524 className: styles$C.Descriptions
7525 }, errorMarkup, helpTextMarkup) : null;
7526 return descriptionMarkup ? React__default.createElement("div", null, labelMarkup, descriptionMarkup) : labelMarkup;
7527}
7528function helpTextID$1(id) {
7529 return "".concat(id, "HelpText");
7530}
7531
7532var styles$D = {
7533 "Checkbox": "Polaris-Checkbox",
7534 "error": "Polaris-Checkbox--error",
7535 "Input": "Polaris-Checkbox__Input",
7536 "Backdrop": "Polaris-Checkbox__Backdrop",
7537 "Input-indeterminate": "Polaris-Checkbox__Input--indeterminate",
7538 "Icon": "Polaris-Checkbox__Icon"
7539};
7540
7541var Checkbox$1 = React__default.forwardRef(function Checkbox(_ref, ref) {
7542 var ariaDescribedByProp = _ref.ariaDescribedBy,
7543 label = _ref.label,
7544 labelHidden = _ref.labelHidden,
7545 _ref$checked = _ref.checked,
7546 checked = _ref$checked === void 0 ? false : _ref$checked,
7547 helpText = _ref.helpText,
7548 disabled = _ref.disabled,
7549 idProp = _ref.id,
7550 name = _ref.name,
7551 value = _ref.value,
7552 error = _ref.error,
7553 onChange = _ref.onChange,
7554 onFocus = _ref.onFocus,
7555 onBlur = _ref.onBlur;
7556 var inputNode = useRef(null);
7557 var id = useUniqueId('Checkbox', idProp);
7558 useImperativeHandle(ref, function () {
7559 return {
7560 focus: function focus() {
7561 if (inputNode.current) {
7562 inputNode.current.focus();
7563 }
7564 }
7565 };
7566 });
7567
7568 var handleInput = function handleInput() {
7569 if (onChange == null || inputNode.current == null || disabled) {
7570 return;
7571 }
7572
7573 onChange(!inputNode.current.checked, id);
7574 inputNode.current.focus();
7575 };
7576
7577 var handleKeyUp = function handleKeyUp(event) {
7578 var keyCode = event.keyCode;
7579 if (keyCode !== Key.Space) return;
7580 handleInput();
7581 };
7582
7583 var describedBy = [];
7584
7585 if (error && typeof error !== 'boolean') {
7586 describedBy.push(errorTextID(id));
7587 }
7588
7589 if (helpText) {
7590 describedBy.push(helpTextID$1(id));
7591 }
7592
7593 if (ariaDescribedByProp) {
7594 describedBy.push(ariaDescribedByProp);
7595 }
7596
7597 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
7598 var wrapperClassName = classNames(styles$D.Checkbox, error && styles$D.error);
7599 var isIndeterminate = checked === 'indeterminate';
7600 var isChecked = !isIndeterminate && Boolean(checked);
7601 var indeterminateAttributes = isIndeterminate ? {
7602 indeterminate: 'true',
7603 'aria-checked': 'mixed'
7604 } : {
7605 'aria-checked': isChecked
7606 };
7607 var iconSource = isIndeterminate ? MinusMinor : TickSmallMinor;
7608 var inputClassName = classNames(styles$D.Input, isIndeterminate && styles$D['Input-indeterminate']);
7609 return (
7610 /* eslint-disable jsx-a11y/no-redundant-roles */
7611 React__default.createElement(Choice, {
7612 id: id,
7613 label: label,
7614 labelHidden: labelHidden,
7615 helpText: helpText,
7616 error: error,
7617 disabled: disabled,
7618 onClick: handleInput
7619 }, React__default.createElement("span", {
7620 className: wrapperClassName
7621 }, React__default.createElement("input", Object.assign({
7622 onKeyUp: handleKeyUp,
7623 ref: inputNode,
7624 id: id,
7625 name: name,
7626 value: value,
7627 type: "checkbox",
7628 checked: isChecked,
7629 disabled: disabled,
7630 className: inputClassName,
7631 onFocus: onFocus,
7632 onBlur: onBlur,
7633 onClick: stopPropagation,
7634 onChange: noop$3,
7635 "aria-invalid": error != null,
7636 "aria-describedby": ariaDescribedBy,
7637 role: "checkbox"
7638 }, indeterminateAttributes)), React__default.createElement("span", {
7639 className: styles$D.Backdrop
7640 }), React__default.createElement("span", {
7641 className: styles$D.Icon
7642 }, React__default.createElement(Icon, {
7643 source: iconSource
7644 }))))
7645 /* eslint-enable jsx-a11y/no-redundant-roles */
7646
7647 );
7648});
7649
7650function noop$3() {}
7651
7652function stopPropagation(event) {
7653 event.stopPropagation();
7654}
7655
7656var styles$E = {
7657 "RadioButton": "Polaris-RadioButton",
7658 "Input": "Polaris-RadioButton__Input",
7659 "Backdrop": "Polaris-RadioButton__Backdrop",
7660 "Icon": "Polaris-RadioButton__Icon"
7661};
7662
7663function RadioButton(_ref) {
7664 var ariaDescribedByProp = _ref.ariaDescribedBy,
7665 label = _ref.label,
7666 labelHidden = _ref.labelHidden,
7667 helpText = _ref.helpText,
7668 checked = _ref.checked,
7669 disabled = _ref.disabled,
7670 onChange = _ref.onChange,
7671 onFocus = _ref.onFocus,
7672 onBlur = _ref.onBlur,
7673 idProp = _ref.id,
7674 nameProp = _ref.name,
7675 value = _ref.value;
7676 var id = useUniqueId('RadioButton', idProp);
7677 var name = nameProp || id;
7678
7679 function handleChange(_ref2) {
7680 var currentTarget = _ref2.currentTarget;
7681 onChange && onChange(currentTarget.checked, id);
7682 }
7683
7684 var describedBy = [];
7685
7686 if (helpText) {
7687 describedBy.push(helpTextID$1(id));
7688 }
7689
7690 if (ariaDescribedByProp) {
7691 describedBy.push(ariaDescribedByProp);
7692 }
7693
7694 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
7695 return React__default.createElement(Choice, {
7696 label: label,
7697 labelHidden: labelHidden,
7698 disabled: disabled,
7699 id: id,
7700 helpText: helpText
7701 }, React__default.createElement("span", {
7702 className: styles$E.RadioButton
7703 }, React__default.createElement("input", {
7704 id: id,
7705 name: name,
7706 value: value,
7707 type: "radio",
7708 checked: checked,
7709 disabled: disabled,
7710 className: styles$E.Input,
7711 onChange: handleChange,
7712 onFocus: onFocus,
7713 onBlur: onBlur,
7714 "aria-describedby": ariaDescribedBy
7715 }), React__default.createElement("span", {
7716 className: styles$E.Backdrop
7717 }), React__default.createElement("span", {
7718 className: styles$E.Icon
7719 })));
7720}
7721
7722var styles$F = {
7723 "ChoiceList": "Polaris-ChoiceList",
7724 "titleHidden": "Polaris-ChoiceList--titleHidden",
7725 "Title": "Polaris-ChoiceList__Title",
7726 "Choices": "Polaris-ChoiceList__Choices",
7727 "ChoiceChildren": "Polaris-ChoiceList__ChoiceChildren",
7728 "ChoiceError": "Polaris-ChoiceList__ChoiceError"
7729};
7730
7731function ChoiceList(_ref) {
7732 var title = _ref.title,
7733 titleHidden = _ref.titleHidden,
7734 allowMultiple = _ref.allowMultiple,
7735 choices = _ref.choices,
7736 selected = _ref.selected,
7737 _ref$onChange = _ref.onChange,
7738 onChange = _ref$onChange === void 0 ? noop$4 : _ref$onChange,
7739 error = _ref.error,
7740 _ref$disabled = _ref.disabled,
7741 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
7742 nameProp = _ref.name;
7743 // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
7744 // see https://github.com/Microsoft/TypeScript/issues/28768
7745 var ControlComponent = allowMultiple ? Checkbox$1 : RadioButton;
7746 var name = useUniqueId('ChoiceList', nameProp);
7747 var finalName = allowMultiple ? "".concat(name, "[]") : name;
7748 var className = classNames(styles$F.ChoiceList, titleHidden && styles$F.titleHidden);
7749 var titleMarkup = title ? React__default.createElement("legend", {
7750 className: styles$F.Title
7751 }, title) : null;
7752 var choicesMarkup = choices.map(function (choice) {
7753 var value = choice.value,
7754 label = choice.label,
7755 helpText = choice.helpText,
7756 choiceDisabled = choice.disabled,
7757 describedByError = choice.describedByError;
7758
7759 function handleChange(checked) {
7760 onChange(updateSelectedChoices(choice, checked, selected, allowMultiple), name);
7761 }
7762
7763 var isSelected = choiceIsSelected(choice, selected);
7764 var renderedChildren = choice.renderChildren ? choice.renderChildren(isSelected) : null;
7765 var children = renderedChildren ? React__default.createElement("div", {
7766 className: styles$F.ChoiceChildren
7767 }, renderedChildren) : null;
7768 return React__default.createElement("li", {
7769 key: value
7770 }, React__default.createElement(ControlComponent, {
7771 name: finalName,
7772 value: value,
7773 label: label,
7774 disabled: choiceDisabled || disabled,
7775 checked: choiceIsSelected(choice, selected),
7776 helpText: helpText,
7777 onChange: handleChange,
7778 ariaDescribedBy: error && describedByError ? errorTextID(finalName) : null
7779 }), children);
7780 });
7781 var errorMarkup = error && React__default.createElement("div", {
7782 className: styles$F.ChoiceError
7783 }, React__default.createElement(InlineError, {
7784 message: error,
7785 fieldID: finalName
7786 }));
7787 return React__default.createElement("fieldset", {
7788 className: className,
7789 id: finalName,
7790 "aria-invalid": error != null
7791 }, titleMarkup, React__default.createElement("ul", {
7792 className: styles$F.Choices
7793 }, choicesMarkup), errorMarkup);
7794}
7795
7796function noop$4() {}
7797
7798function choiceIsSelected(_ref2, selected) {
7799 var value = _ref2.value;
7800 return selected.includes(value);
7801}
7802
7803function updateSelectedChoices(_ref3, checked, selected) {
7804 var value = _ref3.value;
7805 var allowMultiple = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
7806
7807 if (checked) {
7808 return allowMultiple ? [].concat(_toConsumableArray(selected), [value]) : [value];
7809 }
7810
7811 return selected.filter(function (selectedChoice) {
7812 return selectedChoice !== value;
7813 });
7814}
7815
7816var styles$G = {
7817 "Collapsible": "Polaris-Collapsible",
7818 "animating": "Polaris-Collapsible--animating",
7819 "open": "Polaris-Collapsible--open",
7820 "fullyOpen": "Polaris-Collapsible--fullyOpen"
7821};
7822
7823var ParentCollapsibleExpandingContext = createContext(false);
7824
7825var Collapsible =
7826/*#__PURE__*/
7827function (_React$Component) {
7828 _inherits(Collapsible, _React$Component);
7829
7830 function Collapsible() {
7831 var _this;
7832
7833 _classCallCheck(this, Collapsible);
7834
7835 _this = _possibleConstructorReturn(this, _getPrototypeOf(Collapsible).apply(this, arguments));
7836 _this.state = {
7837 height: null,
7838 animationState: 'idle',
7839 // eslint-disable-next-line react/no-unused-state
7840 open: _this.props.open
7841 };
7842 _this.node = createRef();
7843 _this.heightNode = createRef();
7844
7845 _this.handleTransitionEnd = function (event) {
7846 var target = event.target;
7847
7848 if (target === _this.node.current) {
7849 _this.setState({
7850 animationState: 'idle',
7851 height: null
7852 });
7853 }
7854 };
7855
7856 return _this;
7857 }
7858
7859 _createClass(Collapsible, [{
7860 key: "componentDidUpdate",
7861 value: function componentDidUpdate(_ref) {
7862 var _this2 = this;
7863
7864 var wasOpen = _ref.open;
7865 var animationState = this.state.animationState;
7866 var parentCollapsibleExpanding = this.context;
7867
7868 if (parentCollapsibleExpanding && animationState !== 'idle') {
7869 // eslint-disable-next-line react/no-did-update-set-state
7870 this.setState({
7871 animationState: 'idle'
7872 });
7873 return;
7874 }
7875
7876 read(function () {
7877 var heightNode = _this2.heightNode.current;
7878
7879 switch (animationState) {
7880 case 'idle':
7881 break;
7882
7883 case 'measuring':
7884 _this2.setState({
7885 animationState: wasOpen ? 'closingStart' : 'openingStart',
7886 height: wasOpen && heightNode ? heightNode.scrollHeight : 0
7887 });
7888
7889 break;
7890
7891 case 'closingStart':
7892 _this2.setState({
7893 animationState: 'closing',
7894 height: 0
7895 });
7896
7897 break;
7898
7899 case 'openingStart':
7900 _this2.setState({
7901 animationState: 'opening',
7902 height: heightNode ? heightNode.scrollHeight : 0
7903 });
7904
7905 }
7906 });
7907 }
7908 }, {
7909 key: "render",
7910 value: function render() {
7911 var _this$props = this.props,
7912 id = _this$props.id,
7913 open = _this$props.open,
7914 children = _this$props.children;
7915 var _this$state = this.state,
7916 animationState = _this$state.animationState,
7917 height = _this$state.height;
7918 var parentCollapsibleExpanding = this.context;
7919 var animating = animationState !== 'idle';
7920 var wrapperClassName = classNames(styles$G.Collapsible, open && styles$G.open, animating && styles$G.animating, !animating && open && styles$G.fullyOpen);
7921 var displayHeight = collapsibleHeight(open, animationState, height);
7922 var content = animating || open ? children : null;
7923 return React__default.createElement(ParentCollapsibleExpandingContext.Provider, {
7924 value: parentCollapsibleExpanding || open && animationState !== 'idle'
7925 }, React__default.createElement("div", {
7926 id: id,
7927 "aria-hidden": !open,
7928 style: {
7929 maxHeight: displayHeight
7930 },
7931 className: wrapperClassName,
7932 ref: this.node,
7933 onTransitionEnd: this.handleTransitionEnd
7934 }, React__default.createElement("div", {
7935 ref: this.heightNode
7936 }, content)));
7937 }
7938 }], [{
7939 key: "getDerivedStateFromProps",
7940 value: function getDerivedStateFromProps(_ref2, _ref3) {
7941 var willOpen = _ref2.open;
7942 var open = _ref3.open,
7943 prevAnimationState = _ref3.animationState;
7944 var nextAnimationState = prevAnimationState;
7945
7946 if (open !== willOpen) {
7947 nextAnimationState = 'measuring';
7948 }
7949
7950 return {
7951 animationState: nextAnimationState,
7952 open: willOpen
7953 };
7954 }
7955 }]);
7956
7957 return Collapsible;
7958}(React__default.Component);
7959
7960Collapsible.contextType = ParentCollapsibleExpandingContext;
7961
7962function collapsibleHeight(open, animationState, height) {
7963 if (animationState === 'idle' && open) {
7964 return open ? 'none' : undefined;
7965 }
7966
7967 if (animationState === 'measuring') {
7968 return open ? undefined : 'none';
7969 }
7970
7971 return "".concat(height || 0, "px");
7972} // Use named export once we work out why not casting this breaks web
7973
7974var styles$H = {
7975 "ColorPicker": "Polaris-ColorPicker",
7976 "MainColor": "Polaris-ColorPicker__MainColor",
7977 "Dragger": "Polaris-ColorPicker__Dragger",
7978 "ColorLayer": "Polaris-ColorPicker__ColorLayer",
7979 "HuePicker": "Polaris-ColorPicker__HuePicker",
7980 "AlphaPicker": "Polaris-ColorPicker__AlphaPicker",
7981 "Slidable": "Polaris-ColorPicker__Slidable"
7982};
7983
7984var isDragging = false; // Required to solve a bug causing the underlying page/container to scroll
7985// while trying to drag the ColorPicker controls.
7986// This must be called as soon as possible to properly prevent the event.
7987// `passive: false` must also be set, as it seems webkit has changed the "default" behaviour
7988// https://bugs.webkit.org/show_bug.cgi?id=182521
7989
7990if (!isServer) {
7991 window.addEventListener('touchmove', function (event) {
7992 if (!isDragging) {
7993 return;
7994 }
7995
7996 event.preventDefault();
7997 }, {
7998 passive: false
7999 });
8000}
8001
8002var Slidable =
8003/*#__PURE__*/
8004function (_React$PureComponent) {
8005 _inherits(Slidable, _React$PureComponent);
8006
8007 function Slidable() {
8008 var _this;
8009
8010 _classCallCheck(this, Slidable);
8011
8012 _this = _possibleConstructorReturn(this, _getPrototypeOf(Slidable).apply(this, arguments));
8013 _this.state = {
8014 dragging: false
8015 };
8016 _this.node = null;
8017 _this.draggerNode = null;
8018
8019 _this.setDraggerNode = function (node) {
8020 _this.draggerNode = node;
8021 };
8022
8023 _this.setNode = function (node) {
8024 _this.node = node;
8025 };
8026
8027 _this.startDrag = function (event) {
8028 if (event.type === 'mousedown') {
8029 var mouseEvent = event;
8030
8031 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
8032 }
8033
8034 isDragging = true;
8035
8036 _this.setState({
8037 dragging: true
8038 });
8039 };
8040
8041 _this.handleDragEnd = function () {
8042 isDragging = false;
8043
8044 _this.setState({
8045 dragging: false
8046 });
8047 };
8048
8049 _this.handleMove = function (event) {
8050 event.stopImmediatePropagation();
8051 event.stopPropagation();
8052
8053 if (event.cancelable) {
8054 event.preventDefault();
8055 }
8056
8057 if (event.type === 'mousemove') {
8058 var mouseEvent = event;
8059
8060 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
8061
8062 return;
8063 }
8064
8065 var touchEvent = event;
8066
8067 _this.handleDraggerMove(touchEvent.touches[0].clientX, touchEvent.touches[0].clientY);
8068 };
8069
8070 _this.handleDraggerMove = function (x, y) {
8071 if (_this.node == null) {
8072 return;
8073 }
8074
8075 var onChange = _this.props.onChange;
8076
8077 var rect = _this.node.getBoundingClientRect();
8078
8079 var offsetX = x - rect.left;
8080 var offsetY = y - rect.top;
8081 onChange({
8082 x: offsetX,
8083 y: offsetY
8084 });
8085 };
8086
8087 return _this;
8088 }
8089
8090 _createClass(Slidable, [{
8091 key: "componentDidMount",
8092 value: function componentDidMount() {
8093 var onDraggerHeight = this.props.onDraggerHeight;
8094
8095 if (onDraggerHeight == null) {
8096 return;
8097 }
8098
8099 var draggerNode = this.draggerNode;
8100
8101 if (draggerNode == null) {
8102 return;
8103 }
8104
8105 onDraggerHeight(draggerNode.clientWidth);
8106
8107 if (process.env.NODE_ENV === 'development') {
8108 setTimeout(function () {
8109 onDraggerHeight(draggerNode.clientWidth);
8110 }, 0);
8111 }
8112 }
8113 }, {
8114 key: "render",
8115 value: function render() {
8116 var dragging = this.state.dragging;
8117 var _this$props = this.props,
8118 _this$props$draggerX = _this$props.draggerX,
8119 draggerX = _this$props$draggerX === void 0 ? 0 : _this$props$draggerX,
8120 _this$props$draggerY = _this$props.draggerY,
8121 draggerY = _this$props$draggerY === void 0 ? 0 : _this$props$draggerY;
8122 var draggerPositioning = {
8123 transform: "translate3d(".concat(draggerX, "px, ").concat(draggerY, "px, 0)")
8124 };
8125 var moveListener = dragging ? React__default.createElement(EventListener, {
8126 event: "mousemove",
8127 handler: this.handleMove,
8128 passive: false
8129 }) : null;
8130 var touchMoveListener = dragging ? React__default.createElement(EventListener, {
8131 event: "touchmove",
8132 handler: this.handleMove,
8133 passive: false
8134 }) : null;
8135 var endDragListener = dragging ? React__default.createElement(EventListener, {
8136 event: "mouseup",
8137 handler: this.handleDragEnd
8138 }) : null;
8139 var touchEndListener = dragging ? React__default.createElement(EventListener, {
8140 event: "touchend",
8141 handler: this.handleDragEnd
8142 }) : null;
8143 var touchCancelListener = dragging ? React__default.createElement(EventListener, {
8144 event: "touchcancel",
8145 handler: this.handleDragEnd
8146 }) : null;
8147 return React__default.createElement("div", {
8148 ref: this.setNode,
8149 className: styles$H.Slidable,
8150 onMouseDown: this.startDrag,
8151 onTouchStart: this.startDrag
8152 }, endDragListener, moveListener, touchMoveListener, touchEndListener, touchCancelListener, React__default.createElement("div", {
8153 style: draggerPositioning,
8154 className: styles$H.Dragger,
8155 ref: this.setDraggerNode
8156 }));
8157 }
8158 }]);
8159
8160 return Slidable;
8161}(React__default.PureComponent);
8162
8163var VERTICAL_PADDING = 13;
8164function calculateDraggerY(alpha, sliderHeight, draggerHeight) {
8165 var offset = offsetForAlpha(alpha, sliderHeight, draggerHeight);
8166 return clamp$1(offset, 0, sliderHeight);
8167}
8168function alphaForDraggerY(y, sliderHeight) {
8169 var offsetY = clamp$1(y, 0, sliderHeight);
8170 return alphaForOffset(offsetY, sliderHeight);
8171}
8172function alphaForOffset(offset, sliderHeight) {
8173 var selectionHeight = offset - VERTICAL_PADDING;
8174 var slidableArea = sliderHeight - VERTICAL_PADDING * 2;
8175 return clamp$1(1 - selectionHeight / slidableArea, 0, 1);
8176}
8177
8178function offsetForAlpha(alpha, sliderHeight, draggerHeight) {
8179 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING);
8180 return clamp$1((1 - alpha) * slidableArea + VERTICAL_PADDING, 0, sliderHeight - draggerHeight);
8181}
8182
8183var AlphaPicker =
8184/*#__PURE__*/
8185function (_React$PureComponent) {
8186 _inherits(AlphaPicker, _React$PureComponent);
8187
8188 function AlphaPicker() {
8189 var _this;
8190
8191 _classCallCheck(this, AlphaPicker);
8192
8193 _this = _possibleConstructorReturn(this, _getPrototypeOf(AlphaPicker).apply(this, arguments));
8194 _this.state = {
8195 sliderHeight: 0,
8196 draggerHeight: 0
8197 };
8198
8199 _this.setSliderHeight = function (node) {
8200 if (node == null) {
8201 return;
8202 }
8203
8204 _this.setState({
8205 sliderHeight: node.clientHeight
8206 });
8207
8208 if (process.env.NODE_ENV === 'development') {
8209 setTimeout(function () {
8210 _this.setState({
8211 sliderHeight: node.clientHeight
8212 });
8213 }, 0);
8214 }
8215 };
8216
8217 _this.setDraggerHeight = function (height) {
8218 _this.setState({
8219 draggerHeight: height
8220 });
8221 };
8222
8223 _this.handleChange = function (_ref) {
8224 var y = _ref.y;
8225 var onChange = _this.props.onChange;
8226 var sliderHeight = _this.state.sliderHeight;
8227 var alpha = alphaForDraggerY(y, sliderHeight);
8228 onChange(alpha);
8229 };
8230
8231 return _this;
8232 }
8233
8234 _createClass(AlphaPicker, [{
8235 key: "render",
8236 value: function render() {
8237 var _this$props = this.props,
8238 color = _this$props.color,
8239 alpha = _this$props.alpha;
8240 var _this$state = this.state,
8241 sliderHeight = _this$state.sliderHeight,
8242 draggerHeight = _this$state.draggerHeight;
8243 var draggerY = calculateDraggerY(alpha, sliderHeight, draggerHeight);
8244 var background = alphaGradientForColor(color);
8245 return React__default.createElement("div", {
8246 className: styles$H.AlphaPicker,
8247 ref: this.setSliderHeight
8248 }, React__default.createElement("div", {
8249 className: styles$H.ColorLayer,
8250 style: {
8251 background
8252 }
8253 }), React__default.createElement(Slidable, {
8254 draggerY: draggerY,
8255 draggerX: 0,
8256 onChange: this.handleChange,
8257 onDraggerHeight: this.setDraggerHeight
8258 }));
8259 }
8260 }]);
8261
8262 return AlphaPicker;
8263}(React__default.PureComponent);
8264
8265function alphaGradientForColor(color) {
8266 var _hsbToRgb = hsbToRgb(color),
8267 red = _hsbToRgb.red,
8268 green = _hsbToRgb.green,
8269 blue = _hsbToRgb.blue;
8270
8271 var rgb = "".concat(red, ", ").concat(green, ", ").concat(blue);
8272 return "linear-gradient(to top, rgba(".concat(rgb, ", 0) 18px, rgba(").concat(rgb, ", 1) calc(100% - 18px))");
8273}
8274
8275var VERTICAL_PADDING$1 = 13;
8276function calculateDraggerY$1(hue, sliderHeight, draggerHeight) {
8277 var offset = offsetForHue(hue, sliderHeight, draggerHeight);
8278 return clamp$1(offset, 0, sliderHeight);
8279}
8280function hueForDraggerY(y, sliderHeight) {
8281 var offsetY = clamp$1(y, 0, sliderHeight);
8282 return hueForOffset(offsetY, sliderHeight);
8283}
8284
8285function hueForOffset(offset, sliderHeight) {
8286 var selectionHeight = offset - VERTICAL_PADDING$1;
8287 var slidableArea = sliderHeight - VERTICAL_PADDING$1 * 2;
8288 return clamp$1(selectionHeight / slidableArea * 360, 0, 360);
8289}
8290
8291function offsetForHue(hue, sliderHeight, draggerHeight) {
8292 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING$1);
8293 return clamp$1(hue / 360 * slidableArea + VERTICAL_PADDING$1, 0, sliderHeight - draggerHeight);
8294}
8295
8296var HuePicker =
8297/*#__PURE__*/
8298function (_React$PureComponent) {
8299 _inherits(HuePicker, _React$PureComponent);
8300
8301 function HuePicker() {
8302 var _this;
8303
8304 _classCallCheck(this, HuePicker);
8305
8306 _this = _possibleConstructorReturn(this, _getPrototypeOf(HuePicker).apply(this, arguments));
8307 _this.state = {
8308 sliderHeight: 0,
8309 draggerHeight: 0
8310 };
8311
8312 _this.setSliderHeight = function (node) {
8313 if (node == null) {
8314 return;
8315 }
8316
8317 _this.setState({
8318 sliderHeight: node.clientHeight
8319 });
8320
8321 if (process.env.NODE_ENV === 'development') {
8322 setTimeout(function () {
8323 _this.setState({
8324 sliderHeight: node.clientHeight
8325 });
8326 }, 0);
8327 }
8328 };
8329
8330 _this.setDraggerHeight = function (height) {
8331 _this.setState({
8332 draggerHeight: height
8333 });
8334 };
8335
8336 _this.handleChange = function (_ref) {
8337 var y = _ref.y;
8338 var onChange = _this.props.onChange;
8339 var sliderHeight = _this.state.sliderHeight;
8340 var hue = hueForDraggerY(y, sliderHeight);
8341 onChange(hue);
8342 };
8343
8344 return _this;
8345 }
8346
8347 _createClass(HuePicker, [{
8348 key: "render",
8349 value: function render() {
8350 var hue = this.props.hue;
8351 var _this$state = this.state,
8352 sliderHeight = _this$state.sliderHeight,
8353 draggerHeight = _this$state.draggerHeight;
8354 var draggerY = calculateDraggerY$1(hue, sliderHeight, draggerHeight);
8355 return React__default.createElement("div", {
8356 className: styles$H.HuePicker,
8357 ref: this.setSliderHeight
8358 }, React__default.createElement(Slidable, {
8359 draggerY: draggerY,
8360 draggerX: 0,
8361 onChange: this.handleChange,
8362 onDraggerHeight: this.setDraggerHeight
8363 }));
8364 }
8365 }]);
8366
8367 return HuePicker;
8368}(React__default.PureComponent);
8369
8370var ColorPicker =
8371/*#__PURE__*/
8372function (_React$PureComponent) {
8373 _inherits(ColorPicker, _React$PureComponent);
8374
8375 function ColorPicker() {
8376 var _this;
8377
8378 _classCallCheck(this, ColorPicker);
8379
8380 _this = _possibleConstructorReturn(this, _getPrototypeOf(ColorPicker).apply(this, arguments));
8381 _this.state = {
8382 pickerSize: 0
8383 };
8384 _this.colorNode = null;
8385
8386 _this.setColorNode = function (node) {
8387 _this.colorNode = node;
8388 };
8389
8390 _this.handleHueChange = function (hue) {
8391 var _this$props = _this.props,
8392 _this$props$color = _this$props.color,
8393 brightness = _this$props$color.brightness,
8394 saturation = _this$props$color.saturation,
8395 _this$props$color$alp = _this$props$color.alpha,
8396 alpha = _this$props$color$alp === void 0 ? 1 : _this$props$color$alp,
8397 onChange = _this$props.onChange;
8398 onChange({
8399 hue,
8400 brightness,
8401 saturation,
8402 alpha
8403 });
8404 };
8405
8406 _this.handleAlphaChange = function (alpha) {
8407 var _this$props2 = _this.props,
8408 _this$props2$color = _this$props2.color,
8409 hue = _this$props2$color.hue,
8410 brightness = _this$props2$color.brightness,
8411 saturation = _this$props2$color.saturation,
8412 onChange = _this$props2.onChange;
8413 onChange({
8414 hue,
8415 brightness,
8416 saturation,
8417 alpha
8418 });
8419 };
8420
8421 _this.handleDraggerMove = function (_ref) {
8422 var x = _ref.x,
8423 y = _ref.y;
8424 var pickerSize = _this.state.pickerSize;
8425 var _this$props3 = _this.props,
8426 _this$props3$color = _this$props3.color,
8427 hue = _this$props3$color.hue,
8428 _this$props3$color$al = _this$props3$color.alpha,
8429 alpha = _this$props3$color$al === void 0 ? 1 : _this$props3$color$al,
8430 onChange = _this$props3.onChange;
8431 var saturation = clamp$1(x / pickerSize, 0, 1);
8432 var brightness = clamp$1(1 - y / pickerSize, 0, 1);
8433 onChange({
8434 hue,
8435 saturation,
8436 brightness,
8437 alpha
8438 });
8439 };
8440
8441 _this.handlePickerDrag = function (event) {
8442 // prevents external elements from being selected
8443 event.preventDefault();
8444 };
8445
8446 return _this;
8447 }
8448
8449 _createClass(ColorPicker, [{
8450 key: "componentDidMount",
8451 value: function componentDidMount() {
8452 var _this2 = this;
8453
8454 var colorNode = this.colorNode;
8455
8456 if (colorNode == null) {
8457 return;
8458 }
8459
8460 this.setState({
8461 pickerSize: colorNode.clientWidth
8462 });
8463
8464 if (process.env.NODE_ENV === 'development') {
8465 setTimeout(function () {
8466 _this2.setState({
8467 pickerSize: colorNode.clientWidth
8468 });
8469 }, 0);
8470 }
8471 }
8472 }, {
8473 key: "render",
8474 value: function render() {
8475 var _this$props4 = this.props,
8476 id = _this$props4.id,
8477 color = _this$props4.color,
8478 allowAlpha = _this$props4.allowAlpha;
8479 var hue = color.hue,
8480 saturation = color.saturation,
8481 brightness = color.brightness,
8482 providedAlpha = color.alpha;
8483 var pickerSize = this.state.pickerSize;
8484 var alpha = providedAlpha != null && allowAlpha ? providedAlpha : 1;
8485
8486 var _hsbToRgb = hsbToRgb({
8487 hue,
8488 saturation: 1,
8489 brightness: 1
8490 }),
8491 red = _hsbToRgb.red,
8492 green = _hsbToRgb.green,
8493 blue = _hsbToRgb.blue;
8494
8495 var colorString = "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(alpha, ")");
8496 var draggerX = clamp$1(saturation * pickerSize, 0, pickerSize);
8497 var draggerY = clamp$1(pickerSize - brightness * pickerSize, 0, pickerSize);
8498 var alphaSliderMarkup = allowAlpha ? React__default.createElement(AlphaPicker, {
8499 alpha: alpha,
8500 color: color,
8501 onChange: this.handleAlphaChange
8502 }) : null;
8503 return React__default.createElement("div", {
8504 className: styles$H.ColorPicker,
8505 id: id,
8506 onMouseDown: this.handlePickerDrag
8507 }, React__default.createElement("div", {
8508 ref: this.setColorNode,
8509 className: styles$H.MainColor
8510 }, React__default.createElement("div", {
8511 className: styles$H.ColorLayer,
8512 style: {
8513 backgroundColor: colorString
8514 }
8515 }), React__default.createElement(Slidable, {
8516 onChange: this.handleDraggerMove,
8517 draggerX: draggerX,
8518 draggerY: draggerY
8519 })), React__default.createElement(HuePicker, {
8520 hue: hue,
8521 onChange: this.handleHueChange
8522 }), alphaSliderMarkup);
8523 }
8524 }]);
8525
8526 return ColorPicker;
8527}(React__default.PureComponent);
8528
8529var FrameContext = React__default.createContext(undefined);
8530
8531var defaultFrame = {
8532 showToast: noop$5,
8533 hideToast: noop$5,
8534 setContextualSaveBar: noop$5,
8535 removeContextualSaveBar: noop$5,
8536 startLoading: noop$5,
8537 stopLoading: noop$5
8538};
8539function useFrame() {
8540 var frame = useContext(FrameContext);
8541 var appBridge = useAppBridge();
8542
8543 if (!frame && !appBridge) {
8544 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.');
8545 } // This makes sure the useFrame hook always returns a FrameContext object, never undefined
8546
8547
8548 if (appBridge || !frame) {
8549 return defaultFrame;
8550 }
8551
8552 return frame;
8553}
8554
8555function noop$5() {}
8556
8557var ContextualSaveBar = React__default.memo(function ContextualSaveBar(_ref) {
8558 var message = _ref.message,
8559 saveAction = _ref.saveAction,
8560 discardAction = _ref.discardAction,
8561 alignContentFlush = _ref.alignContentFlush;
8562
8563 var _useFrame = useFrame(),
8564 setContextualSaveBar = _useFrame.setContextualSaveBar,
8565 removeContextualSaveBar = _useFrame.removeContextualSaveBar;
8566
8567 React__default.useEffect(function () {
8568 setContextualSaveBar({
8569 message,
8570 saveAction,
8571 discardAction,
8572 alignContentFlush
8573 });
8574 }, [message, saveAction, discardAction, alignContentFlush, setContextualSaveBar]);
8575 React__default.useEffect(function () {
8576 return removeContextualSaveBar;
8577 }, [removeContextualSaveBar]);
8578 return null;
8579});
8580
8581function withAppProvider() {
8582 return function addProvider(WrappedComponent) {
8583 var WithAppProvider = function WithAppProvider(props) {
8584 var polaris = {
8585 intl: useI18n(),
8586 stickyManager: useStickyManager(),
8587 appBridge: useAppBridge(),
8588 mediaQuery: useMediaQuery()
8589 };
8590 return React__default.createElement(WrappedComponent, Object.assign({}, props, {
8591 polaris: polaris
8592 }));
8593 };
8594
8595 WithAppProvider.displayName = "WithAppProvider(".concat(getDisplayName(WrappedComponent), ")");
8596 var FinalComponent = hoistStatics(WithAppProvider, WrappedComponent);
8597 return FinalComponent;
8598 };
8599}
8600
8601function getDisplayName(WrappedComponent) {
8602 return WrappedComponent.displayName || WrappedComponent.name || 'Component';
8603}
8604
8605var styles$I = {
8606 "DataTable": "Polaris-DataTable",
8607 "condensed": "Polaris-DataTable--condensed",
8608 "Navigation": "Polaris-DataTable__Navigation",
8609 "Pip": "Polaris-DataTable__Pip",
8610 "Pip-visible": "Polaris-DataTable__Pip--visible",
8611 "ScrollContainer": "Polaris-DataTable__ScrollContainer",
8612 "Table": "Polaris-DataTable__Table",
8613 "TableRow": "Polaris-DataTable__TableRow",
8614 "Cell": "Polaris-DataTable__Cell",
8615 "Cell-firstColumn": "Polaris-DataTable__Cell--firstColumn",
8616 "Cell-numeric": "Polaris-DataTable__Cell--numeric",
8617 "Cell-truncated": "Polaris-DataTable__Cell--truncated",
8618 "Cell-header": "Polaris-DataTable__Cell--header",
8619 "Cell-sortable": "Polaris-DataTable__Cell--sortable",
8620 "Cell-verticalAlignTop": "Polaris-DataTable__Cell--verticalAlignTop",
8621 "Cell-verticalAlignBottom": "Polaris-DataTable__Cell--verticalAlignBottom",
8622 "Cell-verticalAlignMiddle": "Polaris-DataTable__Cell--verticalAlignMiddle",
8623 "Cell-verticalAlignBaseline": "Polaris-DataTable__Cell--verticalAlignBaseline",
8624 "Icon": "Polaris-DataTable__Icon",
8625 "Heading": "Polaris-DataTable__Heading",
8626 "Heading-left": "Polaris-DataTable__Heading--left",
8627 "Cell-sorted": "Polaris-DataTable__Cell--sorted",
8628 "Cell-total": "Polaris-DataTable__Cell--total",
8629 "Cell-total-footer": "Polaris-DataTable--cellTotalFooter",
8630 "Footer": "Polaris-DataTable__Footer"
8631};
8632
8633function Cell(_ref) {
8634 var content = _ref.content,
8635 contentType = _ref.contentType,
8636 firstColumn = _ref.firstColumn,
8637 truncate = _ref.truncate,
8638 header = _ref.header,
8639 total = _ref.total,
8640 totalInFooter = _ref.totalInFooter,
8641 sorted = _ref.sorted,
8642 sortable = _ref.sortable,
8643 sortDirection = _ref.sortDirection,
8644 _ref$verticalAlign = _ref.verticalAlign,
8645 verticalAlign = _ref$verticalAlign === void 0 ? 'top' : _ref$verticalAlign,
8646 _ref$defaultSortDirec = _ref.defaultSortDirection,
8647 defaultSortDirection = _ref$defaultSortDirec === void 0 ? 'ascending' : _ref$defaultSortDirec,
8648 onSort = _ref.onSort;
8649 var i18n = useI18n();
8650 var numeric = contentType === 'numeric';
8651 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']);
8652 var headerClassName = classNames(header && styles$I.Heading, header && contentType === 'text' && styles$I['Heading-left']);
8653 var iconClassName = classNames(sortable && styles$I.Icon);
8654 var direction = sorted ? sortDirection : defaultSortDirection;
8655 var source = direction === 'descending' ? CaretDownMinor : CaretUpMinor;
8656 var oppositeDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
8657 var sortAccessibilityLabel = i18n.translate('Polaris.DataTable.sortAccessibilityLabel', {
8658 direction: sorted ? oppositeDirection : direction
8659 });
8660 var iconMarkup = React__default.createElement("span", {
8661 className: iconClassName
8662 }, React__default.createElement(Icon, {
8663 source: source,
8664 accessibilityLabel: sortAccessibilityLabel
8665 }));
8666 var sortableHeadingContent = React__default.createElement("button", {
8667 className: headerClassName,
8668 onClick: onSort
8669 }, iconMarkup, content);
8670 var columnHeadingContent = sortable ? sortableHeadingContent : content;
8671 var headingMarkup = header ? React__default.createElement("th", Object.assign({}, headerCell.props, {
8672 className: className,
8673 scope: "col",
8674 "aria-sort": sortDirection
8675 }), columnHeadingContent) : React__default.createElement("th", {
8676 className: className,
8677 scope: "row"
8678 }, content);
8679 var cellMarkup = header || firstColumn ? headingMarkup : React__default.createElement("td", {
8680 className: className
8681 }, content);
8682 return cellMarkup;
8683}
8684
8685function Navigation(_ref) {
8686 var columnVisibilityData = _ref.columnVisibilityData,
8687 isScrolledFarthestLeft = _ref.isScrolledFarthestLeft,
8688 isScrolledFarthestRight = _ref.isScrolledFarthestRight,
8689 navigateTableLeft = _ref.navigateTableLeft,
8690 navigateTableRight = _ref.navigateTableRight;
8691 var i18n = useI18n();
8692 var pipMarkup = columnVisibilityData.map(function (column, index) {
8693 var className = classNames(styles$I.Pip, column.isVisible && styles$I['Pip-visible']);
8694 return React__default.createElement("div", {
8695 className: className,
8696 key: "pip-".concat(index)
8697 });
8698 });
8699 var leftA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
8700 direction: 'left'
8701 });
8702 var rightA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
8703 direction: 'right'
8704 });
8705 return React__default.createElement("div", {
8706 className: styles$I.Navigation
8707 }, React__default.createElement(Button, {
8708 plain: true,
8709 icon: ChevronLeftMinor,
8710 disabled: isScrolledFarthestLeft,
8711 accessibilityLabel: leftA11yLabel,
8712 onClick: navigateTableLeft
8713 }), pipMarkup, React__default.createElement(Button, {
8714 plain: true,
8715 icon: ChevronRightMinor,
8716 disabled: isScrolledFarthestRight,
8717 accessibilityLabel: rightA11yLabel,
8718 onClick: navigateTableRight
8719 }));
8720}
8721
8722function measureColumn(tableData) {
8723 return function (column, index) {
8724 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex,
8725 tableStart = tableData.tableLeftVisibleEdge,
8726 tableEnd = tableData.tableRightVisibleEdge;
8727 var leftEdge = column.offsetLeft;
8728 var rightEdge = leftEdge + column.offsetWidth;
8729 var isVisibleLeft = isEdgeVisible(leftEdge, tableStart, tableEnd);
8730 var isVisibleRight = isEdgeVisible(rightEdge, tableStart, tableEnd);
8731 var isVisible = isVisibleLeft || isVisibleRight;
8732
8733 if (isVisible) {
8734 tableData.firstVisibleColumnIndex = Math.min(firstVisibleColumnIndex, index);
8735 }
8736
8737 return {
8738 leftEdge,
8739 rightEdge,
8740 isVisible
8741 };
8742 };
8743}
8744function isEdgeVisible(position, start, end) {
8745 var minVisiblePixels = 30;
8746 return position >= start + minVisiblePixels && position <= end - minVisiblePixels;
8747}
8748function getPrevAndCurrentColumns(tableData, columnData) {
8749 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex;
8750 var previousColumnIndex = Math.max(firstVisibleColumnIndex - 1, 0);
8751 var previousColumn = columnData[previousColumnIndex];
8752 var currentColumn = columnData[firstVisibleColumnIndex];
8753 return {
8754 previousColumn,
8755 currentColumn
8756 };
8757}
8758
8759var DataTable =
8760/*#__PURE__*/
8761function (_React$PureComponent) {
8762 _inherits(DataTable, _React$PureComponent);
8763
8764 function DataTable(props) {
8765 var _this;
8766
8767 _classCallCheck(this, DataTable);
8768
8769 _this = _possibleConstructorReturn(this, _getPrototypeOf(DataTable).call(this, props));
8770 _this.state = {
8771 condensed: false,
8772 columnVisibilityData: [],
8773 isScrolledFarthestLeft: true,
8774 isScrolledFarthestRight: false
8775 };
8776 _this.dataTable = React__default.createRef();
8777 _this.scrollContainer = React__default.createRef();
8778 _this.table = React__default.createRef();
8779 _this.handleResize = debounce(function () {
8780 var _assertThisInitialize = _assertThisInitialized(_this),
8781 table = _assertThisInitialize.table.current,
8782 scrollContainer = _assertThisInitialize.scrollContainer.current;
8783
8784 var condensed = false;
8785
8786 if (table && scrollContainer) {
8787 condensed = table.scrollWidth > scrollContainer.clientWidth;
8788 }
8789
8790 _this.setState(Object.assign({
8791 condensed
8792 }, _this.calculateColumnVisibilityData(condensed)));
8793 });
8794
8795 _this.calculateColumnVisibilityData = function (condensed) {
8796 var _assertThisInitialize2 = _assertThisInitialized(_this),
8797 table = _assertThisInitialize2.table.current,
8798 scrollContainer = _assertThisInitialize2.scrollContainer.current,
8799 dataTable = _assertThisInitialize2.dataTable.current;
8800
8801 if (condensed && table && scrollContainer && dataTable) {
8802 var headerCells = table.querySelectorAll(headerCell.selector);
8803 var firstVisibleColumnIndex = headerCells.length - 1;
8804 var tableLeftVisibleEdge = scrollContainer.scrollLeft;
8805 var tableRightVisibleEdge = scrollContainer.scrollLeft + dataTable.offsetWidth;
8806 var tableData = {
8807 firstVisibleColumnIndex,
8808 tableLeftVisibleEdge,
8809 tableRightVisibleEdge
8810 };
8811
8812 var columnVisibilityData = _toConsumableArray(headerCells).map(measureColumn(tableData));
8813
8814 var lastColumn = columnVisibilityData[columnVisibilityData.length - 1];
8815 return Object.assign({
8816 columnVisibilityData
8817 }, getPrevAndCurrentColumns(tableData, columnVisibilityData), {
8818 isScrolledFarthestLeft: tableLeftVisibleEdge === 0,
8819 isScrolledFarthestRight: lastColumn.rightEdge <= tableRightVisibleEdge
8820 });
8821 }
8822
8823 return {
8824 columnVisibilityData: [],
8825 previousColumn: undefined,
8826 currentColumn: undefined
8827 };
8828 };
8829
8830 _this.scrollListener = function () {
8831 _this.setState(function (prevState) {
8832 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8833 });
8834 };
8835
8836 _this.navigateTable = function (direction) {
8837 var _this$state = _this.state,
8838 currentColumn = _this$state.currentColumn,
8839 previousColumn = _this$state.previousColumn;
8840 var scrollContainer = _this.scrollContainer.current;
8841
8842 var handleScroll = function handleScroll() {
8843 if (!currentColumn || !previousColumn) {
8844 return;
8845 }
8846
8847 if (scrollContainer) {
8848 scrollContainer.scrollLeft = direction === 'right' ? currentColumn.rightEdge : previousColumn.leftEdge;
8849 requestAnimationFrame(function () {
8850 _this.setState(function (prevState) {
8851 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8852 });
8853 });
8854 }
8855 };
8856
8857 return handleScroll;
8858 };
8859
8860 _this.renderHeadings = function (heading, headingIndex) {
8861 var _this$props = _this.props,
8862 sortable = _this$props.sortable,
8863 _this$props$truncate = _this$props.truncate,
8864 truncate = _this$props$truncate === void 0 ? false : _this$props$truncate,
8865 columnContentTypes = _this$props.columnContentTypes,
8866 defaultSortDirection = _this$props.defaultSortDirection,
8867 _this$props$initialSo = _this$props.initialSortColumnIndex,
8868 initialSortColumnIndex = _this$props$initialSo === void 0 ? 0 : _this$props$initialSo,
8869 verticalAlign = _this$props.verticalAlign;
8870 var _this$state2 = _this.state,
8871 _this$state2$sortDire = _this$state2.sortDirection,
8872 sortDirection = _this$state2$sortDire === void 0 ? defaultSortDirection : _this$state2$sortDire,
8873 _this$state2$sortedCo = _this$state2.sortedColumnIndex,
8874 sortedColumnIndex = _this$state2$sortedCo === void 0 ? initialSortColumnIndex : _this$state2$sortedCo;
8875 var sortableHeadingProps;
8876 var id = "heading-cell-".concat(headingIndex);
8877
8878 if (sortable) {
8879 var isSortable = sortable[headingIndex];
8880 var isSorted = isSortable && sortedColumnIndex === headingIndex;
8881 var direction = isSorted ? sortDirection : 'none';
8882 sortableHeadingProps = {
8883 defaultSortDirection,
8884 sorted: isSorted,
8885 sortable: isSortable,
8886 sortDirection: direction,
8887 onSort: _this.defaultOnSort(headingIndex)
8888 };
8889 }
8890
8891 return React__default.createElement(Cell, Object.assign({
8892 header: true,
8893 key: id,
8894 content: heading,
8895 contentType: columnContentTypes[headingIndex],
8896 firstColumn: headingIndex === 0,
8897 truncate: truncate
8898 }, sortableHeadingProps, {
8899 verticalAlign: verticalAlign
8900 }));
8901 };
8902
8903 _this.renderTotals = function (total, index) {
8904 var id = "totals-cell-".concat(index);
8905 var _this$props2 = _this.props,
8906 _this$props2$truncate = _this$props2.truncate,
8907 truncate = _this$props2$truncate === void 0 ? false : _this$props2$truncate,
8908 verticalAlign = _this$props2.verticalAlign;
8909 var content;
8910 var contentType;
8911
8912 if (index === 0) {
8913 content = _this.totalsRowHeading;
8914 }
8915
8916 if (total !== '' && index > 0) {
8917 contentType = 'numeric';
8918 content = total;
8919 }
8920
8921 var totalInFooter = _this.props.showTotalsInFooter;
8922 return React__default.createElement(Cell, {
8923 total: true,
8924 totalInFooter: totalInFooter,
8925 firstColumn: index === 0,
8926 key: id,
8927 content: content,
8928 contentType: contentType,
8929 truncate: truncate,
8930 verticalAlign: verticalAlign
8931 });
8932 };
8933
8934 _this.defaultRenderRow = function (row, index) {
8935 var className = classNames(styles$I.TableRow);
8936 var _this$props3 = _this.props,
8937 columnContentTypes = _this$props3.columnContentTypes,
8938 _this$props3$truncate = _this$props3.truncate,
8939 truncate = _this$props3$truncate === void 0 ? false : _this$props3$truncate,
8940 verticalAlign = _this$props3.verticalAlign;
8941 return React__default.createElement("tr", {
8942 key: "row-".concat(index),
8943 className: className
8944 }, row.map(function (content, cellIndex) {
8945 var id = "cell-".concat(cellIndex, "-row-").concat(index);
8946 return React__default.createElement(Cell, {
8947 key: id,
8948 content: content,
8949 contentType: columnContentTypes[cellIndex],
8950 firstColumn: cellIndex === 0,
8951 truncate: truncate,
8952 verticalAlign: verticalAlign
8953 });
8954 }));
8955 };
8956
8957 _this.defaultOnSort = function (headingIndex) {
8958 var _this$props4 = _this.props,
8959 onSort = _this$props4.onSort,
8960 _this$props4$defaultS = _this$props4.defaultSortDirection,
8961 defaultSortDirection = _this$props4$defaultS === void 0 ? 'ascending' : _this$props4$defaultS,
8962 initialSortColumnIndex = _this$props4.initialSortColumnIndex;
8963 var _this$state3 = _this.state,
8964 _this$state3$sortDire = _this$state3.sortDirection,
8965 sortDirection = _this$state3$sortDire === void 0 ? defaultSortDirection : _this$state3$sortDire,
8966 _this$state3$sortedCo = _this$state3.sortedColumnIndex,
8967 sortedColumnIndex = _this$state3$sortedCo === void 0 ? initialSortColumnIndex : _this$state3$sortedCo;
8968 var newSortDirection = defaultSortDirection;
8969
8970 if (sortedColumnIndex === headingIndex) {
8971 newSortDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
8972 }
8973
8974 var handleSort = function handleSort() {
8975 _this.setState({
8976 sortDirection: newSortDirection,
8977 sortedColumnIndex: headingIndex
8978 }, function () {
8979 if (onSort) {
8980 onSort(headingIndex, newSortDirection);
8981 }
8982 });
8983 };
8984
8985 return handleSort;
8986 };
8987
8988 var intl = props.polaris.intl;
8989 _this.totalsRowHeading = intl.translate('Polaris.DataTable.totalsRowHeading');
8990 return _this;
8991 }
8992
8993 _createClass(DataTable, [{
8994 key: "componentDidMount",
8995 value: function componentDidMount() {
8996 var _this2 = this;
8997
8998 // We need to defer the calculation in development so the styles have time to be injected.
8999 if (process.env.NODE_ENV === 'development') {
9000 setTimeout(function () {
9001 _this2.handleResize();
9002 }, 10);
9003 } else {
9004 this.handleResize();
9005 }
9006 }
9007 }, {
9008 key: "componentDidUpdate",
9009 value: function componentDidUpdate(prevProps) {
9010 if (isEqual(prevProps, this.props)) {
9011 return;
9012 }
9013
9014 this.handleResize();
9015 }
9016 }, {
9017 key: "render",
9018 value: function render() {
9019 var _this$props5 = this.props,
9020 headings = _this$props5.headings,
9021 totals = _this$props5.totals,
9022 showTotalsInFooter = _this$props5.showTotalsInFooter,
9023 rows = _this$props5.rows,
9024 footerContent = _this$props5.footerContent;
9025 var _this$state4 = this.state,
9026 condensed = _this$state4.condensed,
9027 columnVisibilityData = _this$state4.columnVisibilityData,
9028 isScrolledFarthestLeft = _this$state4.isScrolledFarthestLeft,
9029 isScrolledFarthestRight = _this$state4.isScrolledFarthestRight;
9030 var className = classNames(styles$I.DataTable, condensed && styles$I.condensed);
9031 var wrapperClassName = classNames(styles$I.TableWrapper, condensed && styles$I.condensed);
9032 var headingMarkup = React__default.createElement("tr", null, headings.map(this.renderHeadings));
9033 var totalsMarkup = totals ? React__default.createElement("tr", null, totals.map(this.renderTotals)) : null;
9034 var bodyMarkup = rows.map(this.defaultRenderRow);
9035 var footerMarkup = footerContent ? React__default.createElement("div", {
9036 className: styles$I.Footer
9037 }, footerContent) : null;
9038 var headerTotalsMarkup = !showTotalsInFooter ? totalsMarkup : null;
9039 var footerTotalsMarkup = showTotalsInFooter ? React__default.createElement("tfoot", null, totalsMarkup) : null;
9040 return React__default.createElement("div", {
9041 className: wrapperClassName
9042 }, React__default.createElement(Navigation, {
9043 columnVisibilityData: columnVisibilityData,
9044 isScrolledFarthestLeft: isScrolledFarthestLeft,
9045 isScrolledFarthestRight: isScrolledFarthestRight,
9046 navigateTableLeft: this.navigateTable('left'),
9047 navigateTableRight: this.navigateTable('right')
9048 }), React__default.createElement("div", {
9049 className: className,
9050 ref: this.dataTable
9051 }, React__default.createElement("div", {
9052 className: styles$I.ScrollContainer,
9053 ref: this.scrollContainer
9054 }, React__default.createElement(EventListener, {
9055 event: "resize",
9056 handler: this.handleResize
9057 }), React__default.createElement(EventListener, {
9058 capture: true,
9059 event: "scroll",
9060 handler: this.scrollListener
9061 }), React__default.createElement("table", {
9062 className: styles$I.Table,
9063 ref: this.table
9064 }, React__default.createElement("thead", null, headingMarkup, headerTotalsMarkup), React__default.createElement("tbody", null, bodyMarkup), footerTotalsMarkup)), footerMarkup));
9065 }
9066 }]);
9067
9068 return DataTable;
9069}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
9070// eslint-disable-next-line import/no-default-export
9071
9072
9073var DataTable$1 = withAppProvider()(DataTable);
9074
9075function monthName(month) {
9076 switch (month) {
9077 case 0:
9078 return 'january';
9079
9080 case 1:
9081 return 'february';
9082
9083 case 2:
9084 return 'march';
9085
9086 case 3:
9087 return 'april';
9088
9089 case 4:
9090 return 'may';
9091
9092 case 5:
9093 return 'june';
9094
9095 case 6:
9096 return 'july';
9097
9098 case 7:
9099 return 'august';
9100
9101 case 8:
9102 return 'september';
9103
9104 case 9:
9105 return 'october';
9106
9107 case 10:
9108 return 'november';
9109
9110 case 11:
9111 return 'december';
9112 }
9113}
9114function weekdayName(weekday) {
9115 switch (weekday) {
9116 case 0:
9117 return 'sunday';
9118
9119 case 1:
9120 return 'monday';
9121
9122 case 2:
9123 return 'tuesday';
9124
9125 case 3:
9126 return 'wednesday';
9127
9128 case 4:
9129 return 'thursday';
9130
9131 case 5:
9132 return 'friday';
9133
9134 case 6:
9135 return 'saturday';
9136 }
9137}
9138
9139var styles$J = {
9140 "DatePicker": "Polaris-DatePicker",
9141 "MonthContainer": "Polaris-DatePicker__MonthContainer",
9142 "Month": "Polaris-DatePicker__Month",
9143 "Month-current": "Polaris-DatePicker__Month--current",
9144 "Week": "Polaris-DatePicker__Week",
9145 "WeekHeadings": "Polaris-DatePicker__WeekHeadings",
9146 "Day": "Polaris-DatePicker__Day",
9147 "EmptyDay": "Polaris-DatePicker__EmptyDay",
9148 "Day-today": "Polaris-DatePicker__Day--today",
9149 "Day-inRange": "Polaris-DatePicker__Day--inRange",
9150 "Day-selected": "Polaris-DatePicker__Day--selected",
9151 "Day-disabled": "Polaris-DatePicker__Day--disabled",
9152 "Weekday": "Polaris-DatePicker__Weekday",
9153 "Weekday-current": "Polaris-DatePicker__Weekday--current",
9154 "Header": "Polaris-DatePicker__Header",
9155 "Title": "Polaris-DatePicker__Title"
9156};
9157
9158function Day(_ref) {
9159 var day = _ref.day,
9160 focused = _ref.focused,
9161 onClick = _ref.onClick,
9162 _ref$onHover = _ref.onHover,
9163 onHover = _ref$onHover === void 0 ? noop$6 : _ref$onHover,
9164 _ref$onFocus = _ref.onFocus,
9165 _onFocus = _ref$onFocus === void 0 ? noop$6 : _ref$onFocus,
9166 selected = _ref.selected,
9167 inRange = _ref.inRange,
9168 inHoveringRange = _ref.inHoveringRange,
9169 disabled = _ref.disabled;
9170
9171 var i18n = useI18n();
9172 var dayNode = useRef(null);
9173 useEffect(function () {
9174 if (focused && dayNode.current) {
9175 dayNode.current.focus();
9176 }
9177 }, [focused]);
9178
9179 if (!day) {
9180 return React__default.createElement("div", {
9181 className: styles$J.EmptyDay,
9182 onMouseOver: function onMouseOver() {
9183 return onHover(day);
9184 }
9185 });
9186 }
9187
9188 var handleClick = onClick && !disabled ? onClick.bind(null, day) : noop$6;
9189 var today = isSameDay(new Date(), day);
9190 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']);
9191 var date = day.getDate();
9192 var tabIndex = (focused || selected || today || date === 1) && !disabled ? 0 : -1;
9193 var ariaLabel = ["".concat(today ? i18n.translate('Polaris.DatePicker.today') : ''), "".concat(Months[day.getMonth()], " "), "".concat(date, " "), "".concat(day.getFullYear())].join('');
9194 return React__default.createElement("button", {
9195 onFocus: function onFocus() {
9196 return _onFocus(day);
9197 },
9198 type: "button",
9199 ref: dayNode,
9200 tabIndex: tabIndex,
9201 className: className,
9202 onMouseOver: function onMouseOver() {
9203 return onHover(day);
9204 },
9205 onClick: handleClick,
9206 "aria-label": ariaLabel,
9207 "aria-selected": selected,
9208 "aria-disabled": disabled,
9209 role: "gridcell"
9210 }, date);
9211}
9212
9213function noop$6() {}
9214
9215function Weekday(_ref) {
9216 var label = _ref.label,
9217 title = _ref.title,
9218 current = _ref.current;
9219 var className = classNames(styles$J.Weekday, current && styles$J['Weekday-current']);
9220 return React__default.createElement("div", {
9221 "aria-label": Weekdays[label],
9222 className: className
9223 }, title);
9224}
9225
9226var WEEKDAYS = [Weekdays.Sunday, Weekdays.Monday, Weekdays.Tuesday, Weekdays.Wednesday, Weekdays.Thursday, Weekdays.Friday, Weekdays.Saturday];
9227function Month(_ref) {
9228 var focusedDate = _ref.focusedDate,
9229 selected = _ref.selected,
9230 hoverDate = _ref.hoverDate,
9231 disableDatesBefore = _ref.disableDatesBefore,
9232 disableDatesAfter = _ref.disableDatesAfter,
9233 allowRange = _ref.allowRange,
9234 _ref$onChange = _ref.onChange,
9235 onChange = _ref$onChange === void 0 ? noop$7 : _ref$onChange,
9236 _ref$onHover = _ref.onHover,
9237 onHover = _ref$onHover === void 0 ? noop$7 : _ref$onHover,
9238 _ref$onFocus = _ref.onFocus,
9239 onFocus = _ref$onFocus === void 0 ? noop$7 : _ref$onFocus,
9240 month = _ref.month,
9241 year = _ref.year,
9242 weekStartsOn = _ref.weekStartsOn;
9243 var i18n = useI18n();
9244 var isInHoveringRange = allowRange ? hoveringDateIsInRange : function () {
9245 return false;
9246 };
9247 var now = new Date();
9248 var current = now.getMonth() === month && now.getFullYear() === year;
9249 var className = classNames(styles$J.Title, current && styles$J['Month-current']);
9250 var weeks = getWeeksForMonth(month, year, weekStartsOn);
9251 var weekdays = getWeekdaysOrdered(weekStartsOn).map(function (weekday) {
9252 return React__default.createElement(Weekday, {
9253 key: weekday,
9254 title: i18n.translate("Polaris.DatePicker.daysAbbreviated.".concat(weekdayName(weekday))),
9255 current: current && new Date().getDay() === weekday,
9256 label: weekday
9257 });
9258 });
9259
9260 function handleDateClick(selectedDate) {
9261 onChange(getNewRange(allowRange ? selected : undefined, selectedDate));
9262 }
9263
9264 function renderWeek(day, dayIndex) {
9265 if (day == null) {
9266 var lastDayOfMonth = new Date(year, month + 1, 0);
9267 return React__default.createElement(Day, {
9268 key: dayIndex,
9269 onHover: onHover.bind(null, lastDayOfMonth)
9270 });
9271 }
9272
9273 var disabled = disableDatesBefore && isDateBefore(day, disableDatesBefore) || disableDatesAfter && isDateAfter(day, disableDatesAfter);
9274 return React__default.createElement(Day, {
9275 focused: focusedDate != null && isSameDay(day, focusedDate),
9276 day: day,
9277 key: dayIndex,
9278 onFocus: onFocus,
9279 onClick: handleDateClick,
9280 onHover: onHover,
9281 selected: selected != null && dateIsSelected(day, selected),
9282 inRange: selected != null && dateIsInRange(day, selected),
9283 disabled: disabled,
9284 inHoveringRange: selected != null && hoverDate != null && isInHoveringRange(day, selected, hoverDate)
9285 });
9286 }
9287
9288 var weeksMarkup = weeks.map(function (week, index) {
9289 return React__default.createElement("div", {
9290 role: "row",
9291 className: styles$J.Week,
9292 key: index
9293 }, week.map(renderWeek));
9294 });
9295 return React__default.createElement("div", {
9296 role: "grid",
9297 className: styles$J.Month
9298 }, React__default.createElement("div", {
9299 className: className
9300 }, i18n.translate("Polaris.DatePicker.months.".concat(monthName(month))), " ", year), React__default.createElement("div", {
9301 role: "rowheader",
9302 className: styles$J.WeekHeadings
9303 }, weekdays), weeksMarkup);
9304}
9305
9306function noop$7() {}
9307
9308function hoveringDateIsInRange(day, range, hoverEndDate) {
9309 if (day == null) {
9310 return false;
9311 }
9312
9313 var start = range.start,
9314 end = range.end;
9315 return Boolean(isSameDay(start, end) && day > start && day <= hoverEndDate);
9316}
9317
9318function getWeekdaysOrdered(weekStartsOn) {
9319 var weekDays = [].concat(WEEKDAYS);
9320 var restOfDays = weekDays.splice(weekStartsOn);
9321 return [].concat(_toConsumableArray(restOfDays), _toConsumableArray(weekDays));
9322}
9323
9324function DatePicker(_ref) {
9325 var id = _ref.id,
9326 selected = _ref.selected,
9327 month = _ref.month,
9328 year = _ref.year,
9329 allowRange = _ref.allowRange,
9330 multiMonth = _ref.multiMonth,
9331 disableDatesBefore = _ref.disableDatesBefore,
9332 disableDatesAfter = _ref.disableDatesAfter,
9333 _ref$weekStartsOn = _ref.weekStartsOn,
9334 weekStartsOn = _ref$weekStartsOn === void 0 ? Weekdays.Sunday : _ref$weekStartsOn,
9335 onMonthChange = _ref.onMonthChange,
9336 _ref$onChange = _ref.onChange,
9337 onChange = _ref$onChange === void 0 ? noop$8 : _ref$onChange;
9338 var i18n = useI18n();
9339
9340 var _useState = useState(undefined),
9341 _useState2 = _slicedToArray(_useState, 2),
9342 hoverDate = _useState2[0],
9343 setHoverDate = _useState2[1];
9344
9345 var _useState3 = useState(undefined),
9346 _useState4 = _slicedToArray(_useState3, 2),
9347 focusDate = _useState4[0],
9348 setFocusDate = _useState4[1];
9349
9350 useEffect(function () {
9351 setFocusDate(undefined);
9352 }, [selected]);
9353 var handleFocus = useCallback(function (date) {
9354 setFocusDate(date);
9355 }, []);
9356 var setFocusDateAndHandleMonthChange = useCallback(function (date) {
9357 if (onMonthChange) {
9358 onMonthChange(date.getMonth(), date.getFullYear());
9359 }
9360
9361 setHoverDate(date);
9362 setFocusDate(date);
9363 }, [onMonthChange]);
9364 var handleDateSelection = useCallback(function (range) {
9365 var end = range.end;
9366 setHoverDate(end);
9367 setFocusDate(new Date(end));
9368 onChange(range);
9369 }, [onChange]);
9370 var handleMonthChangeClick = useCallback(function (month, year) {
9371 if (!onMonthChange) {
9372 return;
9373 }
9374
9375 setFocusDate(undefined);
9376 onMonthChange(month, year);
9377 }, [onMonthChange]);
9378 var handleHover = useCallback(function (date) {
9379 setHoverDate(date);
9380 }, []);
9381 var handleKeyUp = useCallback(function (event) {
9382 var key = event.key;
9383 var range = deriveRange(selected);
9384 var focusedDate = focusDate || range && range.start;
9385
9386 if (focusedDate == null) {
9387 return;
9388 }
9389
9390 if (key === 'ArrowUp') {
9391 var previousWeek = new Date(focusedDate);
9392 previousWeek.setDate(focusedDate.getDate() - 7);
9393
9394 if (!(disableDatesBefore && isDateBefore(previousWeek, disableDatesBefore))) {
9395 setFocusDateAndHandleMonthChange(previousWeek);
9396 }
9397 }
9398
9399 if (key === 'ArrowDown') {
9400 var nextWeek = new Date(focusedDate);
9401 nextWeek.setDate(focusedDate.getDate() + 7);
9402
9403 if (!(disableDatesAfter && isDateAfter(nextWeek, disableDatesAfter))) {
9404 setFocusDateAndHandleMonthChange(nextWeek);
9405 }
9406 }
9407
9408 if (key === 'ArrowRight') {
9409 var tomorrow = new Date(focusedDate);
9410 tomorrow.setDate(focusedDate.getDate() + 1);
9411
9412 if (!(disableDatesAfter && isDateAfter(tomorrow, disableDatesAfter))) {
9413 setFocusDateAndHandleMonthChange(tomorrow);
9414 }
9415 }
9416
9417 if (key === 'ArrowLeft') {
9418 var yesterday = new Date(focusedDate);
9419 yesterday.setDate(focusedDate.getDate() - 1);
9420
9421 if (!(disableDatesBefore && isDateBefore(yesterday, disableDatesBefore))) {
9422 setFocusDateAndHandleMonthChange(yesterday);
9423 }
9424 }
9425 }, [disableDatesAfter, disableDatesBefore, focusDate, selected, setFocusDateAndHandleMonthChange]);
9426 var showNextYear = getNextDisplayYear(month, year);
9427 var showNextMonth = getNextDisplayMonth(month);
9428 var showNextToNextYear = getNextDisplayYear(showNextMonth, showNextYear);
9429 var showNextToNextMonth = getNextDisplayMonth(showNextMonth);
9430 var showPreviousYear = getPreviousDisplayYear(month, year);
9431 var showPreviousMonth = getPreviousDisplayMonth(month);
9432 var previousMonthName = i18n.translate("Polaris.DatePicker.months.".concat(monthName(showPreviousMonth)));
9433 var nextMonth = multiMonth ? i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextToNextMonth))) : i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextMonth)));
9434 var nextYear = multiMonth ? showNextToNextYear : showNextYear;
9435 var secondDatePicker = multiMonth ? React__default.createElement(Month, {
9436 onFocus: handleFocus,
9437 focusedDate: focusDate,
9438 month: showNextMonth,
9439 year: showNextYear,
9440 selected: deriveRange(selected),
9441 hoverDate: hoverDate,
9442 onChange: handleDateSelection,
9443 onHover: handleHover,
9444 disableDatesBefore: disableDatesBefore,
9445 disableDatesAfter: disableDatesAfter,
9446 allowRange: allowRange,
9447 weekStartsOn: weekStartsOn
9448 }) : null;
9449 return React__default.createElement("div", {
9450 id: id,
9451 className: styles$J.DatePicker,
9452 onKeyDown: handleKeyDown,
9453 onKeyUp: handleKeyUp
9454 }, React__default.createElement("div", {
9455 className: styles$J.Header
9456 }, React__default.createElement(Button, {
9457 plain: true,
9458 icon: ArrowLeftMinor,
9459 accessibilityLabel: i18n.translate('Polaris.DatePicker.previousMonth', {
9460 previousMonthName,
9461 showPreviousYear
9462 }),
9463 onClick: function onClick() {
9464 return handleMonthChangeClick(showPreviousMonth, showPreviousYear);
9465 }
9466 }), React__default.createElement(Button, {
9467 plain: true,
9468 icon: ArrowRightMinor,
9469 accessibilityLabel: i18n.translate('Polaris.DatePicker.nextMonth', {
9470 nextMonth,
9471 nextYear
9472 }),
9473 onClick: function onClick() {
9474 return handleMonthChangeClick(showNextMonth, showNextYear);
9475 }
9476 })), React__default.createElement("div", {
9477 className: styles$J.MonthContainer
9478 }, React__default.createElement(Month, {
9479 onFocus: handleFocus,
9480 focusedDate: focusDate,
9481 month: month,
9482 year: year,
9483 selected: deriveRange(selected),
9484 hoverDate: hoverDate,
9485 onChange: handleDateSelection,
9486 onHover: handleHover,
9487 disableDatesBefore: disableDatesBefore,
9488 disableDatesAfter: disableDatesAfter,
9489 allowRange: allowRange,
9490 weekStartsOn: weekStartsOn
9491 }), secondDatePicker));
9492}
9493
9494function noop$8() {}
9495
9496function handleKeyDown(event) {
9497 var key = event.key;
9498
9499 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
9500 event.preventDefault();
9501 event.stopPropagation();
9502 }
9503}
9504
9505function deriveRange(selected) {
9506 return selected instanceof Date ? {
9507 start: selected,
9508 end: selected
9509 } : selected;
9510}
9511
9512var styles$K = {
9513 "DescriptionList": "Polaris-DescriptionList",
9514 "Term": "Polaris-DescriptionList__Term",
9515 "Description": "Polaris-DescriptionList__Description"
9516};
9517
9518var getUniqueTermKey = createUniqueIDFactory("Term");
9519var getUniqueDescriptionKey = createUniqueIDFactory("Description");
9520function DescriptionList(_ref) {
9521 var items = _ref.items;
9522 var terms = items.reduce(function (allTerms, _ref2) {
9523 var term = _ref2.term,
9524 description = _ref2.description;
9525 return [].concat(_toConsumableArray(allTerms), [React__default.createElement("dt", {
9526 key: getUniqueTermKey(),
9527 className: styles$K.Term
9528 }, term), React__default.createElement("dd", {
9529 key: getUniqueDescriptionKey(),
9530 className: styles$K.Description
9531 }, description)]);
9532 }, []);
9533 return React__default.createElement("dl", {
9534 className: styles$K.DescriptionList
9535 }, terms);
9536}
9537
9538var styles$L = {
9539 "DisplayText": "Polaris-DisplayText",
9540 "sizeSmall": "Polaris-DisplayText--sizeSmall",
9541 "sizeMedium": "Polaris-DisplayText--sizeMedium",
9542 "sizeLarge": "Polaris-DisplayText--sizeLarge",
9543 "sizeExtraLarge": "Polaris-DisplayText--sizeExtraLarge"
9544};
9545
9546function DisplayText(_ref) {
9547 var _ref$element = _ref.element,
9548 Element = _ref$element === void 0 ? 'p' : _ref$element,
9549 children = _ref.children,
9550 _ref$size = _ref.size,
9551 size = _ref$size === void 0 ? 'medium' : _ref$size;
9552 var className = classNames(styles$L.DisplayText, size && styles$L[variationName('size', size)]);
9553 return React__default.createElement(Element, {
9554 className: className
9555 }, children);
9556}
9557
9558function capitalize() {
9559 var word = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
9560 var wordLower = word.toLowerCase();
9561 return wordLower.charAt(0).toUpperCase() + wordLower.slice(1);
9562}
9563
9564/**
9565 * Attaches and removes event listeners from the target
9566 * @param target Defines a target for the listener to be placed on. Defaults to window.
9567 * @param type Defines the type of event, i.e blur or focus
9568 * @param handler Defines a callback to be invoked when the event type occurs
9569 * @param listenerOptions Object that specifies event properties
9570 * @param options Object that defines properties used in the hook
9571 * interface Options {
9572 * // Uses window as a back up event target when the current
9573 * // target is falsy
9574 * defaultToWindow: boolean;
9575 * }
9576 * @example
9577 * function Playground() {
9578 * useEventListener(window, 'resize', () => console.log('resize'));
9579 *
9580 * return null;
9581 * }
9582 */
9583
9584function useEventListener(target, type, handler, listenerOptions, options) {
9585 useEffect(function () {
9586 var eventTarget = target && 'current' in target ? target.current : target;
9587
9588 if (!eventTarget && options && options.defaultToWindow) {
9589 eventTarget = window;
9590 }
9591
9592 if (!eventTarget) return;
9593 eventTarget.addEventListener(type, handler, listenerOptions);
9594 return function () {
9595 eventTarget && eventTarget.removeEventListener(type, handler, listenerOptions);
9596 };
9597 }, [handler, listenerOptions, options, target, type]);
9598}
9599
9600/**
9601 * Similarly to the life-cycle method componentDidMount, useComponentDidMount
9602 * will be invoked after the component has mounted, and only the initial mount.
9603 * @param callback Defines a callback to invoke once the component has
9604 * initially mounted.
9605 * @example
9606 * function Playground({active}) {
9607 * useComponentDidMount(() => {
9608 * if (active) {
9609 * console.warning(`Component has mounted.`);
9610 * }
9611 * });
9612 *
9613 * return null;
9614 * }
9615 */
9616
9617function useComponentDidMount(callback) {
9618 var isAfterInitialMount = useIsAfterInitialMount();
9619 var hasInvokedLifeCycle = useRef(false);
9620
9621 if (isAfterInitialMount && !hasInvokedLifeCycle.current) {
9622 hasInvokedLifeCycle.current = true;
9623 return callback();
9624 }
9625}
9626
9627var 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>
';
9628
9629var 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>
';
9630
9631var DropZoneContext = React__default.createContext({
9632 disabled: false,
9633 focused: false,
9634 size: 'extraLarge',
9635 type: 'file',
9636 measuring: false
9637});
9638
9639var styles$M = {
9640 "FileUpload": "Polaris-DropZone-FileUpload",
9641 "measuring": "Polaris-DropZone-FileUpload--measuring",
9642 "Button": "Polaris-DropZone-FileUpload__Button",
9643 "globalTheming": "Polaris-DropZone-FileUpload--globalTheming",
9644 "disabled": "Polaris-DropZone-FileUpload--disabled",
9645 "focused": "Polaris-DropZone-FileUpload--focused",
9646 "sizeSlim": "Polaris-DropZone-FileUpload--sizeSlim",
9647 "ActionTitle": "Polaris-DropZone-FileUpload__ActionTitle",
9648 "ActionTitle-disabled": "Polaris-DropZone-FileUpload__ActionTitle--disabled",
9649 "ActionTitle-focused": "Polaris-DropZone-FileUpload__ActionTitle--focused",
9650 "Image": "Polaris-DropZone-FileUpload__Image",
9651 "sizeExtraLarge": "Polaris-DropZone-FileUpload--sizeExtraLarge",
9652 "sizeLarge": "Polaris-DropZone-FileUpload--sizeLarge"
9653};
9654
9655function FileUpload(props) {
9656 var i18n = useI18n();
9657
9658 var _useContext = useContext(DropZoneContext),
9659 size = _useContext.size,
9660 measuring = _useContext.measuring,
9661 type = _useContext.type,
9662 focused = _useContext.focused,
9663 disabled = _useContext.disabled;
9664
9665 var suffix = capitalize(type);
9666 var _props$actionTitle = props.actionTitle,
9667 actionTitle = _props$actionTitle === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionTitle".concat(suffix)) : _props$actionTitle,
9668 _props$actionHint = props.actionHint,
9669 actionHint = _props$actionHint === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionHint".concat(suffix)) : _props$actionHint;
9670 var imageClasses = classNames(styles$M.Image, size && size === 'extraLarge' && styles$M.sizeExtraLarge, size && size === 'large' && styles$M.sizeLarge);
9671 var buttonStyles = size === 'extraLarge' || size === 'large' ? classNames(styles$M.Button, size && size !== 'extraLarge' && styles$M.slim, focused && styles$M.focused, disabled && styles$M.disabled) : null;
9672 var buttonMarkup = (size === 'extraLarge' || size === 'large') && buttonStyles ? React__default.createElement("div", {
9673 className: buttonStyles
9674 }, actionTitle) : null;
9675 var extraLargeView = size === 'extraLarge' ? React__default.createElement(Stack, {
9676 vertical: true
9677 }, type === 'file' && React__default.createElement("img", {
9678 className: imageClasses,
9679 src: fileUpload,
9680 alt: ""
9681 }), type === 'image' && React__default.createElement("img", {
9682 className: imageClasses,
9683 src: imageUpload,
9684 alt: ""
9685 }), buttonMarkup, React__default.createElement(TextStyle, {
9686 variation: "subdued"
9687 }, actionHint)) : null;
9688 var largeView = size === 'large' ? React__default.createElement(Stack, {
9689 vertical: true,
9690 spacing: "tight"
9691 }, type === 'file' && React__default.createElement("img", {
9692 className: imageClasses,
9693 src: fileUpload,
9694 alt: ""
9695 }), type === 'image' && React__default.createElement("img", {
9696 className: imageClasses,
9697 src: imageUpload,
9698 alt: ""
9699 }), buttonMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
9700 variation: "subdued"
9701 }, actionHint))) : null;
9702 var actionTitleClassName = classNames(styles$M.ActionTitle, focused && !disabled && styles$M['ActionTitle-focused'], disabled && styles$M['ActionTitle-disabled']);
9703 var actionTitleMarkup = React__default.createElement("div", {
9704 className: actionTitleClassName
9705 }, actionTitle);
9706 var mediumView = size === 'medium' ? React__default.createElement(Stack, {
9707 vertical: true,
9708 spacing: "tight"
9709 }, actionTitleMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
9710 variation: "subdued"
9711 }, actionHint))) : null;
9712 var smallView = size === 'small' ? React__default.createElement(Stack, {
9713 vertical: true,
9714 spacing: "tight"
9715 }, React__default.createElement(Icon, {
9716 source: DragDropMajorMonotone,
9717 color: "inkLightest"
9718 })) : null;
9719 var fileUploadClassName = classNames(styles$M.FileUpload, measuring && styles$M.measuring);
9720 return React__default.createElement("div", {
9721 className: fileUploadClassName
9722 }, smallView, mediumView, largeView, extraLargeView);
9723}
9724
9725var dragEvents = ['dragover', 'dragenter', 'drop'];
9726function fileAccepted(file, accept) {
9727 return file.type === 'application/x-moz-file' || accepts(file, accept);
9728}
9729function getDataTransferFiles(event) {
9730 if (isDragEvent(event) && event.dataTransfer) {
9731 var dt = event.dataTransfer;
9732
9733 if (dt.files && dt.files.length) {
9734 return Array.from(dt.files);
9735 } else if (dt.items && dt.items.length) {
9736 // Chrome is the only browser that allows to read the file list on drag
9737 // events and uses `items` instead of `files` in this case.
9738 return Array.from(dt.items);
9739 }
9740 } else if (isChangeEvent(event) && event.target.files) {
9741 // Return files from even when a file was selected from an upload dialog
9742 return Array.from(event.target.files);
9743 }
9744
9745 return [];
9746}
9747
9748function accepts(file, acceptedFiles) {
9749 if (file && acceptedFiles) {
9750 var fileName = file.name || '';
9751 var mimeType = file.type || '';
9752 var baseMimeType = mimeType.replace(/\/.*$/, '');
9753 var acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(',');
9754 return acceptedFilesArray.some(function (type) {
9755 var validType = type.trim();
9756
9757 if (validType.startsWith('.')) {
9758 return fileName.toLowerCase().endsWith(validType.toLowerCase());
9759 } else if (validType.endsWith('/*')) {
9760 // This is something like a image/* mime type
9761 return baseMimeType === validType.replace(/\/.*$/, '');
9762 }
9763
9764 return mimeType === validType;
9765 });
9766 }
9767
9768 return true;
9769}
9770
9771function isDragEvent(event) {
9772 return dragEvents.indexOf(event.type) > 0;
9773}
9774
9775function isChangeEvent(event) {
9776 return Object.prototype.hasOwnProperty.call(event, 'target');
9777}
9778
9779var styles$N = {
9780 "DropZone": "Polaris-DropZone",
9781 "hasOutline": "Polaris-DropZone--hasOutline",
9782 "isDisabled": "Polaris-DropZone--isDisabled",
9783 "focused": "Polaris-DropZone--focused",
9784 "isDragging": "Polaris-DropZone--isDragging",
9785 "sizeExtraLarge": "Polaris-DropZone--sizeExtraLarge",
9786 "sizeLarge": "Polaris-DropZone--sizeLarge",
9787 "sizeMedium": "Polaris-DropZone--sizeMedium",
9788 "sizeSmall": "Polaris-DropZone--sizeSmall",
9789 "measuring": "Polaris-DropZone--measuring",
9790 "Container": "Polaris-DropZone__Container",
9791 "Overlay": "Polaris-DropZone__Overlay",
9792 "hasError": "Polaris-DropZone--hasError"
9793};
9794
9795// subcomponents so explicitly state the subcomponents in the type definition.
9796// Letting this be implicit works in this project but fails in projects that use
9797// generated *.d.ts files.
9798
9799var DropZone = function DropZone(_ref) {
9800 var dropOnPage = _ref.dropOnPage,
9801 label = _ref.label,
9802 labelAction = _ref.labelAction,
9803 labelHidden = _ref.labelHidden,
9804 children = _ref.children,
9805 _ref$disabled = _ref.disabled,
9806 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
9807 _ref$outline = _ref.outline,
9808 outline = _ref$outline === void 0 ? true : _ref$outline,
9809 accept = _ref.accept,
9810 active = _ref.active,
9811 _ref$overlay = _ref.overlay,
9812 overlay = _ref$overlay === void 0 ? true : _ref$overlay,
9813 _ref$allowMultiple = _ref.allowMultiple,
9814 allowMultiple = _ref$allowMultiple === void 0 ? true : _ref$allowMultiple,
9815 overlayText = _ref.overlayText,
9816 errorOverlayText = _ref.errorOverlayText,
9817 idProp = _ref.id,
9818 _ref$type = _ref.type,
9819 type = _ref$type === void 0 ? 'file' : _ref$type,
9820 onClick = _ref.onClick,
9821 error = _ref.error,
9822 openFileDialog = _ref.openFileDialog,
9823 onFileDialogClose = _ref.onFileDialogClose,
9824 customValidator = _ref.customValidator,
9825 onDrop = _ref.onDrop,
9826 onDropAccepted = _ref.onDropAccepted,
9827 onDropRejected = _ref.onDropRejected,
9828 onDragEnter = _ref.onDragEnter,
9829 onDragOver = _ref.onDragOver,
9830 onDragLeave = _ref.onDragLeave;
9831 var node = useRef(null);
9832 var fileInputNode = useRef(null);
9833 var dragTargets = useRef([]);
9834 var adjustSize = useCallback(debounce(function () {
9835 if (!node.current) {
9836 return;
9837 }
9838
9839 var size = 'extraLarge';
9840 var width = node.current.getBoundingClientRect().width;
9841
9842 if (width < 100) {
9843 size = 'small';
9844 } else if (width < 160) {
9845 size = 'medium';
9846 } else if (width < 300) {
9847 size = 'large';
9848 }
9849
9850 setSize(size);
9851 measuring && setMeasuring(false);
9852 }, 50, {
9853 trailing: true
9854 }), []);
9855
9856 var _useState = useState(false),
9857 _useState2 = _slicedToArray(_useState, 2),
9858 dragging = _useState2[0],
9859 setDragging = _useState2[1];
9860
9861 var _useState3 = useState(false),
9862 _useState4 = _slicedToArray(_useState3, 2),
9863 internalError = _useState4[0],
9864 setInternalError = _useState4[1];
9865
9866 var _useForcibleToggle = useForcibleToggle(false),
9867 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
9868 focused = _useForcibleToggle2[0],
9869 _useForcibleToggle2$ = _useForcibleToggle2[1],
9870 handleFocus = _useForcibleToggle2$.forceTrue,
9871 handleBlur = _useForcibleToggle2$.forceFalse;
9872
9873 var _useState5 = useState(0),
9874 _useState6 = _slicedToArray(_useState5, 2),
9875 numFiles = _useState6[0],
9876 setNumFiles = _useState6[1];
9877
9878 var _useState7 = useState('extraLarge'),
9879 _useState8 = _slicedToArray(_useState7, 2),
9880 size = _useState8[0],
9881 setSize = _useState8[1];
9882
9883 var _useState9 = useState(true),
9884 _useState10 = _slicedToArray(_useState9, 2),
9885 measuring = _useState10[0],
9886 setMeasuring = _useState10[1];
9887
9888 var i18n = useI18n();
9889 var dropNode = dropOnPage ? document : node;
9890 var getValidatedFiles = useCallback(function (files) {
9891 var acceptedFiles = [];
9892 var rejectedFiles = [];
9893 Array.from(files).forEach(function (file) {
9894 !fileAccepted(file, accept) || customValidator && !customValidator(file) ? rejectedFiles.push(file) : acceptedFiles.push(file);
9895 });
9896
9897 if (!allowMultiple) {
9898 acceptedFiles.splice(1, acceptedFiles.length);
9899 rejectedFiles.push.apply(rejectedFiles, _toConsumableArray(acceptedFiles.slice(1)));
9900 }
9901
9902 return {
9903 files,
9904 acceptedFiles,
9905 rejectedFiles
9906 };
9907 }, [accept, allowMultiple, customValidator]);
9908 var handleDrop = useCallback(function (event) {
9909 stopEvent(event);
9910 if (disabled || !allowMultiple && numFiles > 0) return;
9911 var fileList = getDataTransferFiles(event);
9912
9913 var _getValidatedFiles = getValidatedFiles(fileList),
9914 files = _getValidatedFiles.files,
9915 acceptedFiles = _getValidatedFiles.acceptedFiles,
9916 rejectedFiles = _getValidatedFiles.rejectedFiles;
9917
9918 dragTargets.current = [];
9919 setDragging(false);
9920 setInternalError(rejectedFiles.length > 0);
9921 setNumFiles(function (numFiles) {
9922 return numFiles + acceptedFiles.length;
9923 });
9924 onDrop && onDrop(files, acceptedFiles, rejectedFiles);
9925 onDropAccepted && acceptedFiles.length && onDropAccepted(acceptedFiles);
9926 onDropRejected && rejectedFiles.length && onDropRejected(rejectedFiles);
9927 event.target.value = '';
9928 }, [allowMultiple, disabled, getValidatedFiles, numFiles, onDrop, onDropAccepted, onDropRejected]);
9929 var handleDragEnter = useCallback(function (event) {
9930 stopEvent(event);
9931 if (disabled || !allowMultiple && numFiles > 0) return;
9932 var fileList = getDataTransferFiles(event);
9933
9934 if (event.target && !dragTargets.current.includes(event.target)) {
9935 dragTargets.current.push(event.target);
9936 }
9937
9938 if (dragging) return;
9939
9940 var _getValidatedFiles2 = getValidatedFiles(fileList),
9941 rejectedFiles = _getValidatedFiles2.rejectedFiles;
9942
9943 setDragging(true);
9944 setInternalError(rejectedFiles.length > 0);
9945 onDragEnter && onDragEnter();
9946 }, [allowMultiple, disabled, dragging, getValidatedFiles, numFiles, onDragEnter]);
9947 var handleDragOver = useCallback(function (event) {
9948 stopEvent(event);
9949 if (disabled || !allowMultiple && numFiles > 0) return;
9950 onDragOver && onDragOver();
9951 }, [allowMultiple, disabled, numFiles, onDragOver]);
9952 var handleDragLeave = useCallback(function (event) {
9953 event.preventDefault();
9954 if (disabled || !allowMultiple && numFiles > 0) return;
9955 dragTargets.current = dragTargets.current.filter(function (el) {
9956 var compareNode = dropNode && 'current' in dropNode ? dropNode.current : document;
9957 return el !== event.target && compareNode && compareNode.contains(el);
9958 });
9959 if (dragTargets.current.length > 0) return;
9960 setDragging(false);
9961 setInternalError(false);
9962 onDragLeave && onDragLeave();
9963 }, [allowMultiple, disabled, dropNode, numFiles, onDragLeave]);
9964 useEventListener(dropNode, 'drop', handleDrop);
9965 useEventListener(dropNode, 'dragover', handleDragOver);
9966 useEventListener(dropNode, 'dragenter', handleDragEnter);
9967 useEventListener(dropNode, 'dragleave', handleDragLeave);
9968 useEventListener(null, 'resize', adjustSize, {}, {
9969 defaultToWindow: true
9970 });
9971 useComponentDidMount(function () {
9972 adjustSize();
9973 });
9974 useEffect(function () {
9975 if (!openFileDialog) return;
9976 open();
9977 onFileDialogClose && onFileDialogClose();
9978 }, [onFileDialogClose, openFileDialog]);
9979 var id = useUniqueId('DropZone', idProp);
9980 var suffix = capitalize(type);
9981 var overlayTextWithDefault = overlayText === undefined ? i18n.translate("Polaris.DropZone.overlayText".concat(suffix)) : overlayText;
9982 var errorOverlayTextWithDefault = errorOverlayText === undefined ? i18n.translate("Polaris.DropZone.errorOverlayText".concat(suffix)) : errorOverlayText;
9983 var inputAttributes = {
9984 id,
9985 accept,
9986 disabled,
9987 type: 'file',
9988 multiple: allowMultiple,
9989 ref: fileInputNode,
9990 onChange: handleDrop,
9991 autoComplete: 'off',
9992 onFocus: handleFocus,
9993 onBlur: handleBlur
9994 };
9995 var classes = classNames(styles$N.DropZone, outline && styles$N.hasOutline, focused && styles$N.focused, (active || dragging) && styles$N.isDragging, disabled && styles$N.isDisabled, (internalError || error) && styles$N.hasError, styles$N[variationName('size', size)], measuring && styles$N.measuring);
9996 var dragOverlay = (active || dragging) && (!internalError || !error) && overlay && overlayMarkup(DragDropMajorMonotone, 'indigo', overlayTextWithDefault);
9997 var dragErrorOverlay = dragging && (internalError || error) && overlayMarkup(CircleAlertMajorMonotone, 'red', errorOverlayTextWithDefault);
9998 var labelValue = label || i18n.translate('Polaris.DropZone.FileUpload.label');
9999 var labelHiddenValue = label ? labelHidden : true;
10000 var context = useMemo(function () {
10001 return {
10002 disabled,
10003 focused,
10004 size,
10005 type: type || 'file',
10006 measuring
10007 };
10008 }, [disabled, focused, measuring, size, type]);
10009 return React__default.createElement(DropZoneContext.Provider, {
10010 value: context
10011 }, React__default.createElement(Labelled, {
10012 id: id,
10013 label: labelValue,
10014 action: labelAction,
10015 labelHidden: labelHiddenValue
10016 }, React__default.createElement("div", {
10017 ref: node,
10018 className: classes,
10019 "aria-disabled": disabled,
10020 onClick: handleClick,
10021 onDragStart: stopEvent
10022 }, dragOverlay, dragErrorOverlay, React__default.createElement("div", {
10023 className: styles$N.Container
10024 }, children), React__default.createElement(VisuallyHidden, null, React__default.createElement("input", inputAttributes)))));
10025
10026 function overlayMarkup(icon, color, text) {
10027 return React__default.createElement("div", {
10028 className: styles$N.Overlay
10029 }, React__default.createElement(Stack, {
10030 vertical: true,
10031 spacing: "tight"
10032 }, React__default.createElement(Icon, {
10033 source: icon,
10034 color: color
10035 }), size === 'extraLarge' && React__default.createElement(DisplayText, {
10036 size: "small",
10037 element: "p"
10038 }, text), (size === 'medium' || size === 'large') && React__default.createElement(Caption, null, text)));
10039 }
10040
10041 function open() {
10042 fileInputNode.current && fileInputNode.current.click();
10043 }
10044
10045 function handleClick(event) {
10046 if (disabled || !allowMultiple && numFiles > 0) return;
10047 return onClick ? onClick(event) : open();
10048 }
10049};
10050
10051function stopEvent(event) {
10052 event.preventDefault();
10053 event.stopPropagation();
10054}
10055
10056DropZone.FileUpload = FileUpload;
10057
10058var 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>
';
10059
10060var styles$O = {
10061 "Image": "Polaris-EmptySearchResult__Image"
10062};
10063
10064function EmptySearchResult(_ref) {
10065 var title = _ref.title,
10066 description = _ref.description,
10067 withIllustration = _ref.withIllustration;
10068 var i18n = useI18n();
10069 var altText = i18n.translate('Polaris.EmptySearchResult.altText');
10070 var descriptionMarkup = description ? React__default.createElement("p", null, description) : null;
10071 var illustrationMarkup = withIllustration ? React__default.createElement(Image, {
10072 alt: altText,
10073 source: emptySearch,
10074 className: styles$O.Image,
10075 draggable: false
10076 }) : null;
10077 return React__default.createElement(Stack, {
10078 alignment: "center",
10079 vertical: true
10080 }, illustrationMarkup, React__default.createElement(DisplayText, {
10081 size: "small"
10082 }, title), React__default.createElement(TextStyle, {
10083 variation: "subdued"
10084 }, descriptionMarkup));
10085}
10086
10087var styles$P = {
10088 "EmptyState": "Polaris-EmptyState",
10089 "Section": "Polaris-EmptyState__Section",
10090 "ImageContainer": "Polaris-EmptyState__ImageContainer",
10091 "DetailsContainer": "Polaris-EmptyState__DetailsContainer",
10092 "withinContentContainer": "Polaris-EmptyState--withinContentContainer",
10093 "Details": "Polaris-EmptyState__Details",
10094 "Image": "Polaris-EmptyState__Image",
10095 "Content": "Polaris-EmptyState__Content",
10096 "withinPage": "Polaris-EmptyState--withinPage",
10097 "imageContained": "Polaris-EmptyState--imageContained",
10098 "Actions": "Polaris-EmptyState__Actions",
10099 "FooterContent": "Polaris-EmptyState__FooterContent"
10100};
10101
10102function EmptyState(_ref) {
10103 var children = _ref.children,
10104 heading = _ref.heading,
10105 image = _ref.image,
10106 largeImage = _ref.largeImage,
10107 imageContained = _ref.imageContained,
10108 action = _ref.action,
10109 secondaryAction = _ref.secondaryAction,
10110 footerContent = _ref.footerContent;
10111 var withinContentContainer = useContext(WithinContentContext);
10112 var className = classNames(styles$P.EmptyState, imageContained && styles$P.imageContained, withinContentContainer ? styles$P.withinContentContainer : styles$P.withinPage);
10113 var imageMarkup = largeImage ? React__default.createElement(Image, {
10114 alt: "",
10115 role: "presentation",
10116 className: styles$P.Image,
10117 source: largeImage,
10118 sourceSet: [{
10119 source: image,
10120 descriptor: '568w'
10121 }, {
10122 source: largeImage,
10123 descriptor: '1136w'
10124 }],
10125 sizes: "(max-width: 568px) 60vw"
10126 }) : React__default.createElement(Image, {
10127 role: "presentation",
10128 alt: "",
10129 className: styles$P.Image,
10130 source: image
10131 });
10132 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
10133 plain: true
10134 }) : null;
10135 var footerContentMarkup = footerContent ? React__default.createElement("div", {
10136 className: styles$P.FooterContent
10137 }, React__default.createElement(TextContainer, null, footerContent)) : null;
10138 var headingSize = withinContentContainer ? 'small' : 'medium';
10139 var primaryActionSize = withinContentContainer ? 'medium' : 'large';
10140 var primaryActionMarkup = action ? buttonFrom(action, {
10141 primary: true,
10142 size: primaryActionSize
10143 }) : null;
10144 var headingMarkup = heading ? React__default.createElement(DisplayText, {
10145 size: headingSize
10146 }, heading) : null;
10147 var childrenMarkup = children ? React__default.createElement("div", {
10148 className: styles$P.Content
10149 }, children) : null;
10150 var textContentMarkup = headingMarkup || children ? React__default.createElement(TextContainer, null, headingMarkup, childrenMarkup) : null;
10151 var actionsMarkup = primaryActionMarkup || secondaryActionMarkup ? React__default.createElement("div", {
10152 className: styles$P.Actions
10153 }, React__default.createElement(Stack, {
10154 alignment: "center"
10155 }, primaryActionMarkup, secondaryActionMarkup)) : null;
10156 var detailsMarkup = textContentMarkup || actionsMarkup || footerContentMarkup ? React__default.createElement("div", {
10157 className: styles$P.DetailsContainer
10158 }, React__default.createElement("div", {
10159 className: styles$P.Details
10160 }, textContentMarkup, actionsMarkup, footerContentMarkup)) : React__default.createElement("div", {
10161 className: styles$P.DetailsContainer
10162 });
10163 return React__default.createElement("div", {
10164 className: className
10165 }, React__default.createElement("div", {
10166 className: styles$P.Section
10167 }, detailsMarkup, React__default.createElement("div", {
10168 className: styles$P.ImageContainer
10169 }, imageMarkup)));
10170}
10171
10172var styles$Q = {
10173 "Truncate": "Polaris-Truncate"
10174};
10175
10176function Truncate(_ref) {
10177 var children = _ref.children;
10178 return React__default.createElement("span", {
10179 className: styles$Q.Truncate
10180 }, children);
10181}
10182
10183var styles$R = {
10184 "ExceptionList": "Polaris-ExceptionList",
10185 "Item": "Polaris-ExceptionList__Item",
10186 "Icon": "Polaris-ExceptionList__Icon",
10187 "statusWarning": "Polaris-ExceptionList--statusWarning",
10188 "statusCritical": "Polaris-ExceptionList--statusCritical",
10189 "Bullet": "Polaris-ExceptionList__Bullet",
10190 "Title": "Polaris-ExceptionList__Title",
10191 "Description": "Polaris-ExceptionList__Description"
10192};
10193
10194function ExceptionList(_ref) {
10195 var itemsList = _ref.items;
10196 var items = itemsList.map(function (item, index) {
10197 var status = item.status,
10198 icon = item.icon,
10199 title = item.title,
10200 description = item.description,
10201 _item$truncate = item.truncate,
10202 truncate = _item$truncate === void 0 ? false : _item$truncate;
10203 var itemClasses = classNames(styles$R.Item, status && styles$R[variationName('status', status)]);
10204 var iconMarkup = icon ? React__default.createElement(Icon, {
10205 source: icon
10206 }) : React__default.createElement("span", {
10207 className: styles$R.Bullet
10208 });
10209 var titleMarkup = title && React__default.createElement("span", {
10210 className: styles$R.Title
10211 }, title);
10212 var descriptionMarkup = description && React__default.createElement("span", {
10213 className: styles$R.Description
10214 }, description);
10215 var Element = truncate ? Truncate : React__default.Fragment;
10216 return React__default.createElement("li", {
10217 className: itemClasses,
10218 key: index
10219 }, React__default.createElement("span", {
10220 className: styles$R.Icon
10221 }, iconMarkup), React__default.createElement(Element, null, titleMarkup, descriptionMarkup));
10222 });
10223 return React__default.createElement("ul", {
10224 className: styles$R.ExceptionList
10225 }, items);
10226}
10227
10228var ResourceListContext = React__default.createContext({});
10229
10230var SELECT_ALL_ITEMS = 'All';
10231
10232var styles$S = {
10233 "Tag": "Polaris-Tag",
10234 "disabled": "Polaris-Tag--disabled",
10235 "TagText": "Polaris-Tag__TagText",
10236 "Button": "Polaris-Tag__Button"
10237};
10238
10239function Tag(_ref) {
10240 var children = _ref.children,
10241 _ref$disabled = _ref.disabled,
10242 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
10243 onRemove = _ref.onRemove;
10244 var i18n = useI18n();
10245 var className = classNames(disabled && styles$S.disabled, styles$S.Tag);
10246 var ariaLabel = i18n.translate('Polaris.Tag.ariaLabel', {
10247 children
10248 });
10249 return React__default.createElement("span", {
10250 className: className
10251 }, React__default.createElement("span", {
10252 title: children,
10253 className: styles$S.TagText
10254 }, children), React__default.createElement("button", {
10255 type: "button",
10256 "aria-label": ariaLabel,
10257 className: styles$S.Button,
10258 onClick: onRemove,
10259 onMouseUp: handleMouseUpByBlurring,
10260 disabled: disabled
10261 }, React__default.createElement(Icon, {
10262 source: CancelSmallMinor
10263 })));
10264}
10265
10266var Focus =
10267/*#__PURE__*/
10268function (_React$PureComponent) {
10269 _inherits(Focus, _React$PureComponent);
10270
10271 function Focus() {
10272 _classCallCheck(this, Focus);
10273
10274 return _possibleConstructorReturn(this, _getPrototypeOf(Focus).apply(this, arguments));
10275 }
10276
10277 _createClass(Focus, [{
10278 key: "componentDidMount",
10279 value: function componentDidMount() {
10280 this.handleSelfFocus();
10281 }
10282 }, {
10283 key: "componentDidUpdate",
10284 value: function componentDidUpdate(_a) {
10285 var prevChildren = _a.children,
10286 restPrevProps = __rest(_a, ["children"]);
10287
10288 var _b = this.props,
10289 children = _b.children,
10290 restProps = __rest(_b, ["children"]);
10291
10292 if (isEqual(restProps, restPrevProps)) {
10293 return;
10294 }
10295
10296 this.handleSelfFocus();
10297 }
10298 }, {
10299 key: "handleSelfFocus",
10300 value: function handleSelfFocus() {
10301 var _this$props = this.props,
10302 disabled = _this$props.disabled,
10303 root = _this$props.root;
10304
10305 if (disabled) {
10306 return;
10307 }
10308
10309 if (root) {
10310 if (!root.querySelector('[autofocus]')) {
10311 focusFirstFocusableNode(root, false);
10312 }
10313 }
10314 }
10315 }, {
10316 key: "render",
10317 value: function render() {
10318 var children = this.props.children;
10319 return React__default.createElement(React__default.Fragment, null, children);
10320 }
10321 }]);
10322
10323 return Focus;
10324}(React__default.PureComponent);
10325
10326var TrapFocus =
10327/*#__PURE__*/
10328function (_React$PureComponent) {
10329 _inherits(TrapFocus, _React$PureComponent);
10330
10331 function TrapFocus() {
10332 var _this;
10333
10334 _classCallCheck(this, TrapFocus);
10335
10336 _this = _possibleConstructorReturn(this, _getPrototypeOf(TrapFocus).apply(this, arguments));
10337 _this.state = {
10338 shouldFocusSelf: undefined
10339 };
10340
10341 _this.setFocusTrapWrapper = function (node) {
10342 _this.focusTrapWrapper = node;
10343 };
10344
10345 _this.handleBlur = function (event) {
10346 var relatedTarget = event.relatedTarget;
10347
10348 var _assertThisInitialize = _assertThisInitialized(_this),
10349 focusTrapWrapper = _assertThisInitialize.focusTrapWrapper;
10350
10351 var _this$props$trapping = _this.props.trapping,
10352 trapping = _this$props$trapping === void 0 ? true : _this$props$trapping;
10353
10354 if (relatedTarget == null || trapping === false) {
10355 return;
10356 }
10357
10358 if (focusTrapWrapper && !focusTrapWrapper.contains(relatedTarget) && (!relatedTarget || !closest(relatedTarget, '[data-polaris-overlay]'))) {
10359 event.preventDefault();
10360
10361 if (event.srcElement === findFirstFocusableNode(focusTrapWrapper)) {
10362 return write(function () {
10363 return focusLastFocusableNode(focusTrapWrapper);
10364 });
10365 }
10366
10367 var firstNode = findFirstFocusableNode(focusTrapWrapper);
10368 write(function () {
10369 return focusFirstFocusableNode(firstNode);
10370 });
10371 }
10372 };
10373
10374 return _this;
10375 }
10376
10377 _createClass(TrapFocus, [{
10378 key: "componentDidMount",
10379 value: function componentDidMount() {
10380 this.setState(this.handleTrappingChange());
10381 }
10382 }, {
10383 key: "handleTrappingChange",
10384 value: function handleTrappingChange() {
10385 var _this$props$trapping2 = this.props.trapping,
10386 trapping = _this$props$trapping2 === void 0 ? true : _this$props$trapping2;
10387
10388 if (this.focusTrapWrapper.contains(document.activeElement)) {
10389 return {
10390 shouldFocusSelf: false
10391 };
10392 }
10393
10394 return {
10395 shouldFocusSelf: trapping
10396 };
10397 }
10398 }, {
10399 key: "render",
10400 value: function render() {
10401 var children = this.props.children;
10402 return React__default.createElement(Focus, {
10403 disabled: this.shouldDisable,
10404 root: this.focusTrapWrapper
10405 }, React__default.createElement("div", {
10406 ref: this.setFocusTrapWrapper
10407 }, React__default.createElement(EventListener, {
10408 event: "focusout",
10409 handler: this.handleBlur
10410 }), children));
10411 }
10412 }, {
10413 key: "shouldDisable",
10414 get: function get() {
10415 var _this$props$trapping3 = this.props.trapping,
10416 trapping = _this$props$trapping3 === void 0 ? true : _this$props$trapping3;
10417 var shouldFocusSelf = this.state.shouldFocusSelf;
10418
10419 if (shouldFocusSelf === undefined) {
10420 return true;
10421 }
10422
10423 return shouldFocusSelf ? !trapping : !shouldFocusSelf;
10424 }
10425 }]);
10426
10427 return TrapFocus;
10428}(React__default.PureComponent);
10429
10430var styles$T = {
10431 "Sheet": "Polaris-Sheet",
10432 "Container": "Polaris-Sheet__Container",
10433 "Bottom": "Polaris-Sheet__Bottom",
10434 "enterBottom": "Polaris-Sheet--enterBottom",
10435 "enterBottomActive": "Polaris-Sheet--enterBottomActive",
10436 "exitBottom": "Polaris-Sheet--exitBottom",
10437 "exitBottomActive": "Polaris-Sheet--exitBottomActive",
10438 "Right": "Polaris-Sheet__Right",
10439 "enterRight": "Polaris-Sheet--enterRight",
10440 "enterRightActive": "Polaris-Sheet--enterRightActive",
10441 "exitRight": "Polaris-Sheet--exitRight",
10442 "exitRightActive": "Polaris-Sheet--exitRightActive"
10443};
10444
10445var BOTTOM_CLASS_NAMES = {
10446 enter: classNames(styles$T.Bottom, styles$T.enterBottom),
10447 enterActive: classNames(styles$T.Bottom, styles$T.enterBottomActive),
10448 exit: classNames(styles$T.Bottom, styles$T.exitBottom),
10449 exitActive: classNames(styles$T.Bottom, styles$T.exitBottomActive)
10450};
10451var RIGHT_CLASS_NAMES = {
10452 enter: classNames(styles$T.Right, styles$T.enterRight),
10453 enterActive: classNames(styles$T.Right, styles$T.enterRightActive),
10454 exit: classNames(styles$T.Right, styles$T.exitRight),
10455 exitActive: classNames(styles$T.Right, styles$T.exitRightActive)
10456};
10457function Sheet(_ref) {
10458 var children = _ref.children,
10459 open = _ref.open,
10460 onClose = _ref.onClose,
10461 onEntered = _ref.onEntered,
10462 onExit = _ref.onExit;
10463
10464 var _useMediaQuery = useMediaQuery(),
10465 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
10466
10467 var container = useRef(null);
10468 var findDOMNode = useCallback(function () {
10469 return container.current;
10470 }, []);
10471 return React__default.createElement(Portal, {
10472 idPrefix: "sheet"
10473 }, React__default.createElement(CSSTransition, {
10474 findDOMNode: findDOMNode,
10475 classNames: isNavigationCollapsed ? BOTTOM_CLASS_NAMES : RIGHT_CLASS_NAMES,
10476 timeout: Duration.Slow,
10477 in: open,
10478 mountOnEnter: true,
10479 unmountOnExit: true,
10480 onEntered: onEntered,
10481 onExit: onExit
10482 }, React__default.createElement("div", Object.assign({
10483 className: styles$T.Container
10484 }, layer.props, overlay.props, {
10485 ref: container
10486 }), React__default.createElement(TrapFocus, {
10487 trapping: open
10488 }, React__default.createElement("div", {
10489 role: "dialog",
10490 tabIndex: -1,
10491 className: styles$T.Sheet
10492 }, children)))), React__default.createElement(KeypressListener, {
10493 keyCode: Key.Escape,
10494 handler: onClose
10495 }), open && React__default.createElement(Backdrop, {
10496 transparent: true,
10497 onClick: onClose
10498 }));
10499}
10500
10501var styles$U = {
10502 "Item": "Polaris-Filters-ConnectedFilterControl__Item",
10503 "Item-focused": "Polaris-Filters-ConnectedFilterControl__Item--focused",
10504 "ProxyButtonContainer": "Polaris-Filters-ConnectedFilterControl__ProxyButtonContainer",
10505 "ConnectedFilterControl": "Polaris-Filters-ConnectedFilterControl",
10506 "CenterContainer": "Polaris-Filters-ConnectedFilterControl__CenterContainer",
10507 "right": "Polaris-Filters-ConnectedFilterControl--right",
10508 "RightContainer": "Polaris-Filters-ConnectedFilterControl__RightContainer",
10509 "MoreFiltersButtonContainer": "Polaris-Filters-ConnectedFilterControl__MoreFiltersButtonContainer",
10510 "Wrapper": "Polaris-Filters-ConnectedFilterControl__Wrapper",
10511 "AuxiliaryContainer": "Polaris-Filters-ConnectedFilterControl__AuxiliaryContainer"
10512};
10513
10514var Item$4 =
10515/*#__PURE__*/
10516function (_React$PureComponent) {
10517 _inherits(Item, _React$PureComponent);
10518
10519 function Item() {
10520 var _this;
10521
10522 _classCallCheck(this, Item);
10523
10524 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
10525 _this.state = {
10526 focused: false
10527 };
10528
10529 _this.handleBlur = function () {
10530 _this.setState({
10531 focused: false
10532 });
10533 };
10534
10535 _this.handleFocus = function () {
10536 _this.setState({
10537 focused: true
10538 });
10539 };
10540
10541 return _this;
10542 }
10543
10544 _createClass(Item, [{
10545 key: "render",
10546 value: function render() {
10547 var focused = this.state.focused;
10548 var children = this.props.children;
10549 var className = classNames(styles$U.Item, focused && styles$U['Item-focused']);
10550 return React__default.createElement("div", {
10551 onBlur: this.handleBlur,
10552 onFocus: this.handleFocus,
10553 className: className
10554 }, children);
10555 }
10556 }]);
10557
10558 return Item;
10559}(React__default.PureComponent);
10560
10561var FILTER_FIELD_MIN_WIDTH = 150;
10562var ConnectedFilterControl =
10563/*#__PURE__*/
10564function (_React$Component) {
10565 _inherits(ConnectedFilterControl, _React$Component);
10566
10567 function ConnectedFilterControl() {
10568 var _this;
10569
10570 _classCallCheck(this, ConnectedFilterControl);
10571
10572 _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectedFilterControl).apply(this, arguments));
10573 _this.state = {
10574 availableWidth: 0,
10575 proxyButtonsWidth: {}
10576 };
10577 _this.container = React__default.createRef();
10578 _this.proxyButtonContainer = React__default.createRef();
10579 _this.moreFiltersButtonContainer = React__default.createRef();
10580 _this.handleResize = debounce(function () {
10581 _this.measureProxyButtons();
10582
10583 _this.measureAvailableWidth();
10584 }, 40, {
10585 leading: true,
10586 trailing: true,
10587 maxWait: 40
10588 });
10589 return _this;
10590 }
10591
10592 _createClass(ConnectedFilterControl, [{
10593 key: "componentDidMount",
10594 value: function componentDidMount() {
10595 this.handleResize();
10596 }
10597 }, {
10598 key: "render",
10599 value: function render() {
10600 var _this2 = this;
10601
10602 var _this$props = this.props,
10603 children = _this$props.children,
10604 rightPopoverableActions = _this$props.rightPopoverableActions,
10605 rightAction = _this$props.rightAction,
10606 auxiliary = _this$props.auxiliary;
10607 var className = classNames(styles$U.ConnectedFilterControl, rightPopoverableActions && styles$U.right);
10608 var rightMarkup = rightPopoverableActions ? React__default.createElement("div", {
10609 className: styles$U.RightContainer
10610 }, this.popoverFrom(this.getActionsToRender(rightPopoverableActions))) : null;
10611 var rightActionMarkup = rightAction ? React__default.createElement("div", {
10612 ref: this.moreFiltersButtonContainer,
10613 className: styles$U.MoreFiltersButtonContainer
10614 }, React__default.createElement(Item$4, null, rightAction)) : null;
10615 var proxyButtonMarkup = rightPopoverableActions ? React__default.createElement("div", {
10616 className: styles$U.ProxyButtonContainer,
10617 ref: this.proxyButtonContainer,
10618 "aria-hidden": true
10619 }, rightPopoverableActions.map(function (action) {
10620 return React__default.createElement("div", {
10621 key: action.key,
10622 "data-key": action.key
10623 }, _this2.activatorButtonFrom(action));
10624 })) : null;
10625 var auxMarkup = auxiliary ? React__default.createElement("div", {
10626 className: styles$U.AuxiliaryContainer
10627 }, auxiliary) : null;
10628 return React__default.createElement(React__default.Fragment, null, proxyButtonMarkup, React__default.createElement("div", {
10629 className: styles$U.Wrapper
10630 }, React__default.createElement("div", {
10631 className: className,
10632 ref: this.container
10633 }, React__default.createElement("div", {
10634 className: styles$U.CenterContainer
10635 }, React__default.createElement(Item$4, null, children)), rightMarkup, rightActionMarkup, React__default.createElement(EventListener, {
10636 event: "resize",
10637 handler: this.handleResize
10638 })), auxMarkup));
10639 }
10640 }, {
10641 key: "measureProxyButtons",
10642 value: function measureProxyButtons() {
10643 if (this.proxyButtonContainer.current) {
10644 var proxyButtonsWidth = {}; // this number is magical, but tweaking it solved the problem of items overlapping
10645
10646 var tolerance = 52;
10647
10648 if (this.proxyButtonContainer.current) {
10649 Array.from(this.proxyButtonContainer.current.children).forEach(function (element) {
10650 var buttonWidth = element.getBoundingClientRect().width + tolerance;
10651 var buttonKey = element.dataset.key;
10652
10653 if (buttonKey) {
10654 proxyButtonsWidth[buttonKey] = buttonWidth;
10655 }
10656 });
10657 }
10658
10659 this.setState({
10660 proxyButtonsWidth
10661 });
10662 }
10663 }
10664 }, {
10665 key: "measureAvailableWidth",
10666 value: function measureAvailableWidth() {
10667 if (this.container.current && this.moreFiltersButtonContainer.current) {
10668 var containerWidth = this.container.current.getBoundingClientRect().width;
10669 var moreFiltersButtonWidth = this.moreFiltersButtonContainer.current.getBoundingClientRect().width;
10670 var filtersActionWidth = 0;
10671 var availableWidth = containerWidth - FILTER_FIELD_MIN_WIDTH - moreFiltersButtonWidth - filtersActionWidth;
10672 this.setState({
10673 availableWidth
10674 });
10675 }
10676 }
10677 }, {
10678 key: "getActionsToRender",
10679 value: function getActionsToRender(actions) {
10680 var remainingWidth = this.state.availableWidth;
10681 var actionsToReturn = [];
10682
10683 for (var i = 0; remainingWidth > 0 && i < actions.length; i++) {
10684 var action = actions[i];
10685 var actionWidth = this.state.proxyButtonsWidth[action.key];
10686
10687 if (actionWidth <= remainingWidth) {
10688 actionsToReturn.push(action);
10689 remainingWidth -= actionWidth;
10690 }
10691 }
10692
10693 return actionsToReturn;
10694 }
10695 }, {
10696 key: "activatorButtonFrom",
10697 value: function activatorButtonFrom(action) {
10698 return React__default.createElement(Button, {
10699 onClick: action.onAction,
10700 disclosure: true,
10701 disabled: this.props.disabled || action.disabled,
10702 id: "Activator-".concat(action.key)
10703 }, action.content);
10704 }
10705 }, {
10706 key: "popoverFrom",
10707 value: function popoverFrom(actions) {
10708 var _this3 = this;
10709
10710 return actions.map(function (action) {
10711 return React__default.createElement(Item$4, {
10712 key: action.key
10713 }, React__default.createElement(Popover, {
10714 active: action.popoverOpen,
10715 activator: _this3.activatorButtonFrom(action),
10716 onClose: action.onAction,
10717 preferredAlignment: "left",
10718 sectioned: true
10719 }, action.popoverContent));
10720 });
10721 }
10722 }]);
10723
10724 return ConnectedFilterControl;
10725}(React__default.Component);
10726
10727var styles$V = {
10728 "Filters": "Polaris-Filters",
10729 "FiltersContainer": "Polaris-Filters__FiltersContainer",
10730 "FiltersContainerHeader": "Polaris-Filters__FiltersContainerHeader",
10731 "FiltersDesktopContainerContent": "Polaris-Filters__FiltersDesktopContainerContent",
10732 "FiltersMobileContainerContent": "Polaris-Filters__FiltersMobileContainerContent",
10733 "FiltersContainerFooter": "Polaris-Filters__FiltersContainerFooter",
10734 "FiltersMobileContainerFooter": "Polaris-Filters__FiltersMobileContainerFooter",
10735 "EmptyFooterState": "Polaris-Filters__EmptyFooterState",
10736 "FilterTriggerContainer": "Polaris-Filters__FilterTriggerContainer",
10737 "FilterTrigger": "Polaris-Filters__FilterTrigger",
10738 "FilterTriggerTitle": "Polaris-Filters__FilterTriggerTitle",
10739 "AppliedFilterBadgeContainer": "Polaris-Filters__AppliedFilterBadgeContainer",
10740 "open": "Polaris-Filters--open",
10741 "FilterTriggerLabelContainer": "Polaris-Filters__FilterTriggerLabelContainer",
10742 "first": "Polaris-Filters--first",
10743 "last": "Polaris-Filters--last",
10744 "FilterNodeContainer": "Polaris-Filters__FilterNodeContainer",
10745 "SearchIcon": "Polaris-Filters__SearchIcon",
10746 "Backdrop": "Polaris-Filters__Backdrop",
10747 "HelpText": "Polaris-Filters__HelpText",
10748 "TagsContainer": "Polaris-Filters__TagsContainer"
10749};
10750
10751var Suffix;
10752
10753(function (Suffix) {
10754 Suffix["Filter"] = "Filter";
10755 Suffix["Shortcut"] = "Shortcut";
10756})(Suffix || (Suffix = {}));
10757
10758var Filters =
10759/*#__PURE__*/
10760function (_React$Component) {
10761 _inherits(Filters, _React$Component);
10762
10763 function Filters() {
10764 var _this;
10765
10766 _classCallCheck(this, Filters);
10767
10768 _this = _possibleConstructorReturn(this, _getPrototypeOf(Filters).apply(this, arguments));
10769 _this.state = {
10770 open: false,
10771 readyForFocus: false
10772 };
10773 _this.moreFiltersButtonContainer = createRef();
10774 _this.focusNode = createRef();
10775
10776 _this.closeFilters = function () {
10777 _this.setState({
10778 open: false
10779 }, function () {
10780 if (_this.moreFiltersButtonContainer.current) {
10781 focusFirstFocusableNode(_this.moreFiltersButtonContainer.current, false);
10782 }
10783 });
10784 };
10785
10786 _this.toggleFilters = function () {
10787 if (_this.state.open === true) {
10788 _this.closeFilters();
10789 } else {
10790 _this.openFilters();
10791 }
10792 };
10793
10794 _this.setReadyForFocus = function (newState) {
10795 return function () {
10796 _this.setState({
10797 readyForFocus: newState
10798 });
10799 };
10800 };
10801
10802 return _this;
10803 }
10804
10805 _createClass(Filters, [{
10806 key: "render",
10807 value: function render() {
10808 var _this2 = this;
10809
10810 var _this$props = this.props,
10811 filters = _this$props.filters,
10812 queryValue = _this$props.queryValue,
10813 onQueryBlur = _this$props.onQueryBlur,
10814 onQueryChange = _this$props.onQueryChange,
10815 onQueryFocus = _this$props.onQueryFocus,
10816 focused = _this$props.focused,
10817 onClearAll = _this$props.onClearAll,
10818 appliedFilters = _this$props.appliedFilters,
10819 _this$props$polaris = _this$props.polaris,
10820 intl = _this$props$polaris.intl,
10821 isNavigationCollapsed = _this$props$polaris.mediaQuery.isNavigationCollapsed,
10822 onQueryClear = _this$props.onQueryClear,
10823 queryPlaceholder = _this$props.queryPlaceholder,
10824 children = _this$props.children,
10825 _this$props$disabled = _this$props.disabled,
10826 disabled = _this$props$disabled === void 0 ? false : _this$props$disabled,
10827 helpText = _this$props.helpText;
10828 var resourceName = this.context.resourceName;
10829 var _this$state = this.state,
10830 open = _this$state.open,
10831 readyForFocus = _this$state.readyForFocus;
10832 var backdropMarkup = open ? React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
10833 className: styles$V.Backdrop,
10834 onClick: this.closeFilters
10835 })) : null;
10836 var filtersContentMarkup = filters.map(function (filter, index) {
10837 var filterIsOpen = _this2.state["".concat(filter.key).concat(Suffix.Filter)] === true;
10838 var icon = filterIsOpen ? ChevronUpMinor : ChevronDownMinor;
10839 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);
10840
10841 var appliedFilterContent = _this2.getAppliedFilterContent(filter.key);
10842
10843 var appliedFilterBadgeMarkup = appliedFilterContent ? React__default.createElement("div", {
10844 className: styles$V.AppliedFilterBadgeContainer
10845 }, React__default.createElement(Badge, {
10846 size: "small",
10847 status: "new"
10848 }, appliedFilterContent)) : null;
10849 var collapsibleID = "".concat(filter.key, "Collapsible");
10850 return React__default.createElement("div", {
10851 key: filter.key,
10852 className: className
10853 }, React__default.createElement("button", {
10854 onClick: function onClick() {
10855 return _this2.toggleFilter(filter.key);
10856 },
10857 className: styles$V.FilterTrigger,
10858 id: "".concat(filter.key, "ToggleButton"),
10859 type: "button",
10860 "aria-controls": collapsibleID,
10861 "aria-expanded": filterIsOpen
10862 }, React__default.createElement("div", {
10863 className: styles$V.FilterTriggerLabelContainer
10864 }, React__default.createElement("h2", {
10865 className: styles$V.FilterTriggerTitle
10866 }, React__default.createElement(TextStyle, {
10867 variation: _this2.props.disabled || filter.disabled ? VariationValue.Subdued : undefined
10868 }, filter.label)), React__default.createElement("span", {
10869 className: styles$V.FilterTriggerIcon
10870 }, React__default.createElement(Icon, {
10871 source: icon,
10872 color: "inkLightest"
10873 }))), appliedFilterBadgeMarkup), React__default.createElement(Collapsible, {
10874 id: collapsibleID,
10875 open: filterIsOpen
10876 }, React__default.createElement("div", {
10877 className: styles$V.FilterNodeContainer
10878 }, React__default.createElement(Focus, {
10879 disabled: !filterIsOpen || !readyForFocus || !open,
10880 root: _this2.focusNode.current
10881 }, _this2.generateFilterMarkup(filter)))));
10882 });
10883 var rightActionMarkup = React__default.createElement("div", {
10884 ref: this.moreFiltersButtonContainer
10885 }, React__default.createElement(Button, {
10886 onClick: this.toggleFilters,
10887 disabled: disabled
10888 }, intl.translate('Polaris.Filters.moreFilters')));
10889 var filterResourceName = resourceName || {
10890 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
10891 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
10892 };
10893 var filtersControlMarkup = React__default.createElement(ConnectedFilterControl, {
10894 rightPopoverableActions: this.transformFilters(filters),
10895 rightAction: rightActionMarkup,
10896 auxiliary: children,
10897 disabled: disabled
10898 }, React__default.createElement(TextField, {
10899 placeholder: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10900 resourceName: filterResourceName.plural
10901 }),
10902 onChange: onQueryChange,
10903 onBlur: onQueryBlur,
10904 onFocus: onQueryFocus,
10905 value: queryValue,
10906 focused: focused,
10907 label: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10908 resourceName: filterResourceName.plural
10909 }),
10910 labelHidden: true,
10911 prefix: React__default.createElement("span", {
10912 className: styles$V.SearchIcon
10913 }, React__default.createElement(Icon, {
10914 source: SearchMinor
10915 })),
10916 clearButton: true,
10917 onClearButtonClick: onQueryClear,
10918 disabled: disabled
10919 }));
10920 var filtersDesktopHeaderMarkup = React__default.createElement("div", {
10921 className: styles$V.FiltersContainerHeader
10922 }, React__default.createElement(DisplayText, {
10923 size: "small"
10924 }, intl.translate('Polaris.Filters.moreFilters')), React__default.createElement(Button, {
10925 icon: CancelSmallMinor,
10926 plain: true,
10927 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10928 onClick: this.closeFilters
10929 }));
10930 var filtersMobileHeaderMarkup = React__default.createElement("div", {
10931 className: styles$V.FiltersContainerHeader
10932 }, React__default.createElement(Button, {
10933 icon: CancelSmallMinor,
10934 plain: true,
10935 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10936 onClick: this.closeFilters
10937 }), React__default.createElement(DisplayText, {
10938 size: "small"
10939 }, intl.translate('Polaris.Filters.moreFilters')), React__default.createElement(Button, {
10940 onClick: this.closeFilters,
10941 primary: true
10942 }, intl.translate('Polaris.Filters.done')));
10943 var filtersDesktopFooterMarkup = React__default.createElement("div", {
10944 className: styles$V.FiltersContainerFooter
10945 }, React__default.createElement(Button, {
10946 onClick: onClearAll,
10947 disabled: !this.hasAppliedFilters
10948 }, intl.translate('Polaris.Filters.clearAllFilters')), React__default.createElement(Button, {
10949 onClick: this.closeFilters,
10950 primary: true
10951 }, intl.translate('Polaris.Filters.done')));
10952 var filtersMobileFooterMarkup = React__default.createElement("div", {
10953 className: styles$V.FiltersMobileContainerFooter
10954 }, this.hasAppliedFilters ? React__default.createElement(Button, {
10955 onClick: onClearAll,
10956 fullWidth: true
10957 }, intl.translate('Polaris.Filters.clearAllFilters')) : React__default.createElement("div", {
10958 className: styles$V.EmptyFooterState
10959 }, React__default.createElement(TextStyle, {
10960 variation: "subdued"
10961 }, React__default.createElement("p", null, intl.translate('Polaris.Filters.noFiltersApplied')))));
10962 var tagsMarkup = appliedFilters && appliedFilters.length ? React__default.createElement("div", {
10963 className: styles$V.TagsContainer
10964 }, appliedFilters.map(function (filter) {
10965 return React__default.createElement(Tag, {
10966 key: filter.key,
10967 onRemove: function onRemove() {
10968 filter.onRemove(filter.key);
10969 },
10970 disabled: disabled
10971 }, filter.label);
10972 })) : null;
10973 var filtersContainerMarkup = isNavigationCollapsed ? React__default.createElement(Sheet, {
10974 open: open,
10975 onClose: this.closeFilters,
10976 onEntered: this.setReadyForFocus(true),
10977 onExit: this.setReadyForFocus(false)
10978 }, filtersMobileHeaderMarkup, React__default.createElement(Scrollable, {
10979 className: styles$V.FiltersMobileContainerContent,
10980 shadow: true
10981 }, filtersContentMarkup, filtersMobileFooterMarkup)) : React__default.createElement(Sheet, {
10982 open: open,
10983 onClose: this.closeFilters,
10984 onEntered: this.setReadyForFocus(true),
10985 onExit: this.setReadyForFocus(false)
10986 }, React__default.createElement("div", {
10987 className: styles$V.FiltersContainer
10988 }, filtersDesktopHeaderMarkup, React__default.createElement(Scrollable, {
10989 className: styles$V.FiltersDesktopContainerContent,
10990 shadow: true
10991 }, filtersContentMarkup), filtersDesktopFooterMarkup));
10992 var helpTextMarkup = helpText ? React__default.createElement("div", {
10993 id: "FiltersHelpText",
10994 className: styles$V.HelpText
10995 }, React__default.createElement(TextStyle, {
10996 variation: "subdued"
10997 }, helpText)) : null;
10998 return React__default.createElement("div", {
10999 className: styles$V.Filters
11000 }, filtersControlMarkup, filtersContainerMarkup, tagsMarkup, helpTextMarkup, backdropMarkup, React__default.createElement(KeypressListener, {
11001 keyCode: Key.Escape,
11002 handler: this.closeFilters
11003 }));
11004 }
11005 }, {
11006 key: "getAppliedFilterContent",
11007 value: function getAppliedFilterContent(key) {
11008 var appliedFilters = this.props.appliedFilters;
11009
11010 if (!appliedFilters) {
11011 return undefined;
11012 }
11013
11014 var filter = appliedFilters.find(function (filter) {
11015 return filter.key === key;
11016 });
11017 return filter == null ? undefined : filter.label;
11018 }
11019 }, {
11020 key: "getAppliedFilterRemoveHandler",
11021 value: function getAppliedFilterRemoveHandler(key) {
11022 var appliedFilters = this.props.appliedFilters;
11023
11024 if (!appliedFilters) {
11025 return undefined;
11026 }
11027
11028 var filter = appliedFilters.find(function (filter) {
11029 return filter.key === key;
11030 });
11031 return filter == null ? undefined : filter.onRemove;
11032 }
11033 }, {
11034 key: "openFilters",
11035 value: function openFilters() {
11036 this.setState({
11037 open: true
11038 });
11039 }
11040 }, {
11041 key: "openFilter",
11042 value: function openFilter(key) {
11043 this.setState({
11044 ["".concat(key).concat(Suffix.Filter)]: true
11045 });
11046 }
11047 }, {
11048 key: "closeFilter",
11049 value: function closeFilter(key) {
11050 this.setState({
11051 ["".concat(key).concat(Suffix.Filter)]: false
11052 });
11053 }
11054 }, {
11055 key: "toggleFilter",
11056 value: function toggleFilter(key) {
11057 if (this.state["".concat(key).concat(Suffix.Filter)] === true) {
11058 this.closeFilter(key);
11059 } else {
11060 this.openFilter(key);
11061 }
11062 }
11063 }, {
11064 key: "openFilterShortcut",
11065 value: function openFilterShortcut(key) {
11066 this.setState({
11067 ["".concat(key).concat(Suffix.Shortcut)]: true
11068 });
11069 }
11070 }, {
11071 key: "closeFilterShortcut",
11072 value: function closeFilterShortcut(key) {
11073 this.setState({
11074 ["".concat(key).concat(Suffix.Shortcut)]: false
11075 });
11076 }
11077 }, {
11078 key: "toggleFilterShortcut",
11079 value: function toggleFilterShortcut(key) {
11080 if (this.state["".concat(key).concat(Suffix.Shortcut)] === true) {
11081 this.closeFilterShortcut(key);
11082 } else {
11083 this.openFilterShortcut(key);
11084 }
11085 }
11086 }, {
11087 key: "transformFilters",
11088 value: function transformFilters(filters) {
11089 var _this3 = this;
11090
11091 var transformedActions = [];
11092 getShortcutFilters(filters).forEach(function (filter) {
11093 var key = filter.key,
11094 label = filter.label,
11095 disabled = filter.disabled;
11096 transformedActions.push({
11097 popoverContent: _this3.generateFilterMarkup(filter),
11098 popoverOpen: _this3.state["".concat(key).concat(Suffix.Shortcut)],
11099 key,
11100 content: label,
11101 disabled,
11102 onAction: function onAction() {
11103 return _this3.toggleFilterShortcut(key);
11104 }
11105 });
11106 });
11107 return transformedActions;
11108 }
11109 }, {
11110 key: "generateFilterMarkup",
11111 value: function generateFilterMarkup(filter) {
11112 var intl = this.props.polaris.intl;
11113 var removeCallback = this.getAppliedFilterRemoveHandler(filter.key);
11114 var removeHandler = removeCallback == null ? undefined : function () {
11115 removeCallback(filter.key);
11116 };
11117 return React__default.createElement("div", {
11118 ref: this.focusNode
11119 }, React__default.createElement(Stack, {
11120 vertical: true,
11121 spacing: "tight"
11122 }, filter.filter, React__default.createElement(Button, {
11123 plain: true,
11124 disabled: removeHandler == null,
11125 onClick: removeHandler,
11126 accessibilityLabel: intl.translate('Polaris.Filters.clearLabel', {
11127 filterName: filter.label
11128 })
11129 }, intl.translate('Polaris.Filters.clear'))));
11130 }
11131 }, {
11132 key: "hasAppliedFilters",
11133 get: function get() {
11134 var _this$props2 = this.props,
11135 appliedFilters = _this$props2.appliedFilters,
11136 queryValue = _this$props2.queryValue;
11137 var filtersApplied = Boolean(appliedFilters && appliedFilters.length > 0);
11138 var queryApplied = Boolean(queryValue && queryValue !== '');
11139 return filtersApplied || queryApplied;
11140 }
11141 }]);
11142
11143 return Filters;
11144}(React__default.Component);
11145
11146Filters.contextType = ResourceListContext;
11147
11148function getShortcutFilters(filters) {
11149 return filters.filter(function (filter) {
11150 return filter.shortcut === true;
11151 });
11152} // Use named export once withAppProvider is refactored away
11153// eslint-disable-next-line import/no-default-export
11154
11155
11156var Filters$1 = withAppProvider()(Filters);
11157
11158var styles$W = {
11159 "FooterHelp": "Polaris-FooterHelp",
11160 "Content": "Polaris-FooterHelp__Content",
11161 "Icon": "Polaris-FooterHelp__Icon",
11162 "Text": "Polaris-FooterHelp__Text"
11163};
11164
11165function FooterHelp(_ref) {
11166 var children = _ref.children;
11167 return React__default.createElement("div", {
11168 className: styles$W.FooterHelp
11169 }, React__default.createElement("div", {
11170 className: styles$W.Content
11171 }, React__default.createElement("div", {
11172 className: styles$W.Icon
11173 }, React__default.createElement(Icon, {
11174 source: QuestionMarkMajorTwotone,
11175 color: "teal",
11176 backdrop: true
11177 })), React__default.createElement("div", {
11178 className: styles$W.Text
11179 }, children)));
11180}
11181
11182function Form(_ref) {
11183 var acceptCharset = _ref.acceptCharset,
11184 action = _ref.action,
11185 autoComplete = _ref.autoComplete,
11186 children = _ref.children,
11187 encType = _ref.encType,
11188 _ref$implicitSubmit = _ref.implicitSubmit,
11189 implicitSubmit = _ref$implicitSubmit === void 0 ? true : _ref$implicitSubmit,
11190 _ref$method = _ref.method,
11191 method = _ref$method === void 0 ? 'post' : _ref$method,
11192 name = _ref.name,
11193 noValidate = _ref.noValidate,
11194 _ref$preventDefault = _ref.preventDefault,
11195 preventDefault = _ref$preventDefault === void 0 ? true : _ref$preventDefault,
11196 target = _ref.target,
11197 onSubmit = _ref.onSubmit;
11198 var i18n = useI18n();
11199 var handleSubmit = useCallback(function (event) {
11200 if (!preventDefault) {
11201 return;
11202 }
11203
11204 event.preventDefault();
11205 onSubmit(event);
11206 }, [onSubmit, preventDefault]);
11207 var autoCompleteInputs = normalizeAutoComplete$1(autoComplete);
11208 var submitMarkup = implicitSubmit ? React__default.createElement(VisuallyHidden, null, React__default.createElement("button", {
11209 type: "submit",
11210 "aria-hidden": "true",
11211 tabIndex: -1
11212 }, i18n.translate('Polaris.Common.submit'))) : null;
11213 return React__default.createElement("form", {
11214 acceptCharset: acceptCharset,
11215 action: action,
11216 autoComplete: autoCompleteInputs,
11217 encType: encType,
11218 method: method,
11219 name: name,
11220 noValidate: noValidate,
11221 target: target,
11222 onSubmit: handleSubmit
11223 }, children, submitMarkup);
11224}
11225
11226function normalizeAutoComplete$1(autoComplete) {
11227 if (autoComplete == null) {
11228 return autoComplete;
11229 }
11230
11231 return autoComplete ? 'on' : 'off';
11232}
11233
11234var styles$X = {
11235 "FormLayout": "Polaris-FormLayout",
11236 "Title": "Polaris-FormLayout__Title",
11237 "Items": "Polaris-FormLayout__Items",
11238 "HelpText": "Polaris-FormLayout__HelpText",
11239 "Item": "Polaris-FormLayout__Item",
11240 "grouped": "Polaris-FormLayout--grouped",
11241 "condensed": "Polaris-FormLayout--condensed"
11242};
11243
11244function Item$5(props) {
11245 return React__default.createElement("div", {
11246 className: styles$X.Item
11247 }, props.children);
11248}
11249
11250function Group(_ref) {
11251 var children = _ref.children,
11252 condensed = _ref.condensed,
11253 title = _ref.title,
11254 helpText = _ref.helpText;
11255 var className = classNames(condensed ? styles$X.condensed : styles$X.grouped);
11256 var id = useUniqueId('FormLayoutGroup');
11257 var helpTextElement = null;
11258 var helpTextID;
11259 var titleElement = null;
11260 var titleID;
11261
11262 if (helpText) {
11263 helpTextID = "".concat(id, "HelpText");
11264 helpTextElement = React__default.createElement("div", {
11265 id: helpTextID,
11266 className: styles$X.HelpText
11267 }, helpText);
11268 }
11269
11270 if (title) {
11271 titleID = "".concat(id, "Title");
11272 titleElement = React__default.createElement("div", {
11273 id: titleID,
11274 className: styles$X.Title
11275 }, title);
11276 }
11277
11278 var itemsMarkup = React__default.Children.map(children, function (child) {
11279 return wrapWithComponent(child, Item$5, {});
11280 });
11281 return React__default.createElement("div", {
11282 role: "group",
11283 className: className,
11284 "aria-labelledby": titleID,
11285 "aria-describedby": helpTextID
11286 }, titleElement, React__default.createElement("div", {
11287 className: styles$X.Items
11288 }, itemsMarkup), helpTextElement);
11289}
11290
11291var FormLayout =
11292/*#__PURE__*/
11293function (_React$PureComponent) {
11294 _inherits(FormLayout, _React$PureComponent);
11295
11296 function FormLayout() {
11297 _classCallCheck(this, FormLayout);
11298
11299 return _possibleConstructorReturn(this, _getPrototypeOf(FormLayout).apply(this, arguments));
11300 }
11301
11302 _createClass(FormLayout, [{
11303 key: "render",
11304 value: function render() {
11305 var children = this.props.children;
11306 return React__default.createElement("div", {
11307 className: styles$X.FormLayout
11308 }, React__default.Children.map(children, wrapChildren));
11309 }
11310 }]);
11311
11312 return FormLayout;
11313}(React__default.PureComponent);
11314FormLayout.Group = Group;
11315
11316function wrapChildren(child, index) {
11317 if (isElementOfType(child, Group)) {
11318 return child;
11319 }
11320
11321 var props = {
11322 key: index
11323 };
11324 return wrapWithComponent(child, Item$5, props);
11325}
11326
11327function setRootProperty(name, value, node) {
11328 if (document == null) {
11329 return;
11330 }
11331
11332 var styleNode = node && node instanceof HTMLElement ? node : document.documentElement;
11333 styleNode && styleNode.style.setProperty(name, value);
11334}
11335
11336var styles$Y = {
11337 "Toast": "Polaris-Frame-Toast",
11338 "Action": "Polaris-Frame-Toast__Action",
11339 "error": "Polaris-Frame-Toast--error",
11340 "CloseButton": "Polaris-Frame-Toast__CloseButton"
11341};
11342
11343var DEFAULT_TOAST_DURATION = 5000;
11344var DEFAULT_TOAST_DURATION_WITH_ACTION = 10000;
11345function Toast(_ref) {
11346 var content = _ref.content,
11347 onDismiss = _ref.onDismiss,
11348 duration = _ref.duration,
11349 error = _ref.error,
11350 action = _ref.action;
11351 useEffect(function () {
11352 var timeoutDuration = duration || DEFAULT_TOAST_DURATION;
11353
11354 if (action && !duration) {
11355 timeoutDuration = DEFAULT_TOAST_DURATION_WITH_ACTION;
11356 } else if (action && duration && duration < DEFAULT_TOAST_DURATION_WITH_ACTION) {
11357 // eslint-disable-next-line no-console
11358 console.log('Toast with action should persist for at least 10,000 milliseconds to give the merchant enough time to act on it.');
11359 }
11360
11361 var timer = setTimeout(onDismiss, timeoutDuration);
11362 return function () {
11363 clearTimeout(timer);
11364 };
11365 }, [action, duration, onDismiss]);
11366 var dismissMarkup = React__default.createElement("button", {
11367 type: "button",
11368 className: styles$Y.CloseButton,
11369 onClick: onDismiss
11370 }, React__default.createElement(Icon, {
11371 source: MobileCancelMajorMonotone
11372 }));
11373 var actionMarkup = action ? React__default.createElement("div", {
11374 className: styles$Y.Action
11375 }, React__default.createElement(Button, {
11376 plain: true,
11377 monochrome: true,
11378 onClick: action.onAction
11379 }, action.content)) : null;
11380 var className = classNames(styles$Y.Toast, error && styles$Y.error);
11381 return React__default.createElement("div", {
11382 className: className
11383 }, React__default.createElement(KeypressListener, {
11384 keyCode: Key.Escape,
11385 handler: onDismiss
11386 }), content, actionMarkup, dismissMarkup);
11387}
11388
11389/**
11390 * A replacement for React.useCallback that'll allow for custom and deep compares.
11391 * @see {@link https://reactjs.org/docs/hooks-reference.html#usecallback}
11392 * @param callback Accepts a callback that's forwarded to React.useCallback
11393 * @param dependencies A dependency array similar to React.useCallback however it utilizes a deep compare
11394 * @param customCompare Opportunity to provide a custom compare function
11395 * @returns A memoized callback
11396 * @example
11397 * const Child = memo(function Child({onClick}) {
11398 * console.log('Child has rendered.');
11399 * return <button onClick={onClick}>Click me</button>;
11400 * });
11401 *
11402 * function ComponentExample() {
11403 * const [timesClicked, setTimesClicked] = useState(0);
11404 *
11405 * const handleClick = useDeepCallback(() => {
11406 * setTimesClicked((timesClicked) => timesClicked + 1);
11407 * // New reference every render
11408 * }, [{}]);
11409 *
11410 * return (
11411 * <Fragment>
11412 * <div>Times clicked: {timesClicked}</div>
11413 * <Child onClick={handleClick} />
11414 * </Fragment>
11415 * );
11416 * }
11417 */
11418
11419function useDeepCallback(callback, dependencies, customCompare) {
11420 return useCallback(callback, useDeepCompareRef(dependencies, customCompare));
11421}
11422
11423var styles$Z = {
11424 "ToastManager": "Polaris-Frame-ToastManager",
11425 "ToastWrapper": "Polaris-Frame-ToastManager__ToastWrapper",
11426 "ToastWrapper-enter": "Polaris-Frame-ToastManager__ToastWrapper--enter",
11427 "ToastWrapper-exit": "Polaris-Frame-ToastManager__ToastWrapper--exit",
11428 "ToastWrapper-enter-done": "Polaris-Frame-ToastManager--toastWrapperEnterDone"
11429};
11430
11431var ToastManager = memo(function ToastManager(_ref) {
11432 var toastMessages = _ref.toastMessages;
11433 var toastNodes = [];
11434 var updateToasts = useDeepCallback(function () {
11435 var targetInPos = 0;
11436 toastMessages.forEach(function (_, index) {
11437 var currentToast = toastNodes[index];
11438 if (!currentToast.current) return;
11439 targetInPos += currentToast.current.clientHeight;
11440 currentToast.current.style.setProperty('--toast-translate-y-in', "-".concat(targetInPos, "px"));
11441 currentToast.current.style.setProperty('--toast-translate-y-out', "".concat(-targetInPos + 150, "px"));
11442 });
11443 }, [toastMessages, toastNodes]);
11444 useDeepEffect(function () {
11445 updateToasts();
11446 }, [toastMessages]);
11447 var toastsMarkup = toastMessages.map(function (toast, index) {
11448 var toastNode = createRef();
11449 toastNodes[index] = toastNode;
11450 return React__default.createElement(CSSTransition, {
11451 findDOMNode: findDOMNode(index),
11452 key: toast.id,
11453 timeout: {
11454 enter: 0,
11455 exit: 400
11456 },
11457 classNames: toastClasses
11458 }, React__default.createElement("div", {
11459 ref: toastNode
11460 }, React__default.createElement(Toast, toast)));
11461 });
11462 return React__default.createElement(Portal, {
11463 idPrefix: "toast-manager"
11464 }, React__default.createElement(EventListener, {
11465 event: "resize",
11466 handler: updateToasts
11467 }), React__default.createElement("div", {
11468 className: styles$Z.ToastManager,
11469 "aria-live": "polite"
11470 }, React__default.createElement(TransitionGroup, {
11471 component: null
11472 }, toastsMarkup)));
11473
11474 function findDOMNode(index) {
11475 return function () {
11476 return toastNodes[index].current;
11477 };
11478 }
11479});
11480var toastClasses = {
11481 enter: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter']),
11482 enterDone: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter-done']),
11483 exit: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-exit'])
11484};
11485
11486var styles$_ = {
11487 "Loading": "Polaris-Frame-Loading",
11488 "Level": "Polaris-Frame-Loading__Level"
11489};
11490
11491var INITIAL_STEP = 10;
11492var STUCK_THRESHOLD = 99;
11493var Loading =
11494/*#__PURE__*/
11495function (_React$Component) {
11496 _inherits(Loading, _React$Component);
11497
11498 function Loading() {
11499 var _this;
11500
11501 _classCallCheck(this, Loading);
11502
11503 _this = _possibleConstructorReturn(this, _getPrototypeOf(Loading).apply(this, arguments));
11504 _this.state = {
11505 progress: 0,
11506 step: INITIAL_STEP,
11507 animation: null
11508 };
11509 _this.ariaValuenow = debounce(function () {
11510 var progress = _this.state.progress;
11511 return Math.floor(progress / 10) * 10;
11512 }, 15);
11513 return _this;
11514 }
11515
11516 _createClass(Loading, [{
11517 key: "componentDidMount",
11518 value: function componentDidMount() {
11519 this.increment();
11520 }
11521 }, {
11522 key: "componentWillUnmount",
11523 value: function componentWillUnmount() {
11524 var animation = this.state.animation;
11525
11526 if (animation != null) {
11527 cancelAnimationFrame(animation);
11528 }
11529 }
11530 }, {
11531 key: "render",
11532 value: function render() {
11533 var progress = this.state.progress;
11534 var customStyles = {
11535 transform: "scaleX(".concat(Math.floor(progress) / 100, ")")
11536 };
11537 var ariaValuenow = this.ariaValuenow();
11538 return React__default.createElement("div", {
11539 className: styles$_.Loading
11540 }, React__default.createElement("div", {
11541 className: styles$_.Level,
11542 style: customStyles,
11543 "aria-valuenow": ariaValuenow,
11544 "aria-valuemin": 0,
11545 "aria-valuemax": 100,
11546 role: "progressbar"
11547 }));
11548 }
11549 }, {
11550 key: "increment",
11551 value: function increment() {
11552 var _this2 = this;
11553
11554 var _this$state = this.state,
11555 progress = _this$state.progress,
11556 step = _this$state.step;
11557
11558 if (progress >= STUCK_THRESHOLD) {
11559 return;
11560 }
11561
11562 var animation = requestAnimationFrame(function () {
11563 return _this2.increment();
11564 });
11565 this.setState({
11566 progress: Math.min(progress + step, 100),
11567 step: Math.pow(INITIAL_STEP, -(progress / 25)),
11568 animation
11569 });
11570 }
11571 }]);
11572
11573 return Loading;
11574}(React__default.Component);
11575
11576function isObject(value) {
11577 var type = typeof value;
11578 return value != null && (type === TypeOf.Object || type === TypeOf.Function);
11579}
11580
11581function pluckDeep(obj, key) {
11582 if (!obj) {
11583 return null;
11584 }
11585
11586 var keys = Object.keys(obj);
11587
11588 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
11589 var currKey = _keys[_i];
11590
11591 if (currKey === key) {
11592 return obj[key];
11593 }
11594
11595 if (isObject(obj[currKey])) {
11596 var plucked = pluckDeep(obj[currKey], key);
11597
11598 if (plucked) {
11599 return plucked;
11600 }
11601 }
11602 }
11603
11604 return null;
11605}
11606
11607function getWidth() {
11608 var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
11609 var defaultWidth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
11610 var key = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'width';
11611 var width = typeof value === 'number' ? value : pluckDeep(value, key);
11612 return width ? "".concat(width, "px") : "".concat(defaultWidth, "px");
11613}
11614
11615function generateRedirect(appBridge, url) {
11616 var target = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'APP';
11617 var external = arguments.length > 3 ? arguments[3] : undefined;
11618
11619 if (url == null) {
11620 return undefined;
11621 }
11622
11623 var redirect = Redirect.create(appBridge);
11624 var payload = external === true ? {
11625 url,
11626 newContext: true
11627 } : url;
11628 return function () {
11629 redirect.dispatch(redirectAction(target, external), payload);
11630 };
11631}
11632
11633function redirectAction(target, external) {
11634 if (external === true) {
11635 return Redirect.Action.REMOTE;
11636 }
11637
11638 return Redirect.Action[target];
11639}
11640
11641function transformActions(appBridge, _ref) {
11642 var primaryAction = _ref.primaryAction,
11643 secondaryActions = _ref.secondaryActions,
11644 actionGroups = _ref.actionGroups;
11645 var primary = transformPrimaryAction(appBridge, primaryAction);
11646 var secondary = [].concat(_toConsumableArray(transformSecondaryActions(appBridge, secondaryActions)), _toConsumableArray(transformActionGroups(appBridge, actionGroups)));
11647 return {
11648 primary,
11649 secondary
11650 };
11651}
11652
11653function transformAction(appBridge, action) {
11654 var style = action.destructive === true ? Button$1.Style.Danger : undefined;
11655 var button = Button$1.create(appBridge, {
11656 label: action.content || '',
11657 disabled: action.disabled,
11658 style
11659 });
11660
11661 if (action.onAction) {
11662 button.subscribe(Button$1.Action.CLICK, action.onAction);
11663 }
11664
11665 var redirect = generateRedirect(appBridge, action.url, action.target, action.external);
11666
11667 if (redirect != null) {
11668 button.subscribe(Button$1.Action.CLICK, redirect);
11669 }
11670
11671 return button;
11672}
11673
11674function transformPrimaryAction(appBridge, primaryAction) {
11675 if (primaryAction == null) {
11676 return undefined;
11677 }
11678
11679 var primary = transformAction(appBridge, primaryAction);
11680 return primary;
11681}
11682
11683function transformSecondaryActions(appBridge) {
11684 var secondaryActions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
11685
11686 var secondary = _toConsumableArray(secondaryActions.map(function (secondaryAction) {
11687 return transformAction(appBridge, secondaryAction);
11688 }));
11689
11690 return secondary;
11691}
11692
11693function transformActionGroups(appBridge) {
11694 var actionGroups = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
11695
11696 var buttonGroups = _toConsumableArray(actionGroups.map(function (group) {
11697 var buttons = group.actions.map(function (groupAction) {
11698 return transformAction(appBridge, groupAction);
11699 });
11700 return ButtonGroup$1.create(appBridge, {
11701 label: group.title,
11702 buttons
11703 });
11704 }));
11705
11706 return buttonGroups;
11707}
11708
11709function pickValueAndLength(obj, key) {
11710 var keyPaths = key.split('.');
11711 var value = obj;
11712 var _iteratorNormalCompletion = true;
11713 var _didIteratorError = false;
11714 var _iteratorError = undefined;
11715
11716 try {
11717 for (var _iterator = keyPaths[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
11718 var _key = _step.value;
11719
11720 if (!Object.prototype.hasOwnProperty.call(value, _key)) {
11721 return null;
11722 }
11723
11724 value = value[_key];
11725 }
11726 } catch (err) {
11727 _didIteratorError = true;
11728 _iteratorError = err;
11729 } finally {
11730 try {
11731 if (!_iteratorNormalCompletion && _iterator.return != null) {
11732 _iterator.return();
11733 }
11734 } finally {
11735 if (_didIteratorError) {
11736 throw _iteratorError;
11737 }
11738 }
11739 }
11740
11741 return {
11742 keyPaths,
11743 value
11744 };
11745}
11746
11747function pick(obj) {
11748 var _ref;
11749
11750 for (var _len = arguments.length, keyPaths = new Array(_len > 1 ? _len - 1 : 0), _key2 = 1; _key2 < _len; _key2++) {
11751 keyPaths[_key2 - 1] = arguments[_key2];
11752 }
11753
11754 var flattenedKeypaths = (_ref = []).concat.apply(_ref, keyPaths);
11755
11756 if (obj == null || flattenedKeypaths.length === 0) return {};
11757 return flattenedKeypaths.reduce(function (acc, key) {
11758 if (typeof key !== TypeOf.String || Object.prototype.hasOwnProperty.call(obj, key)) {
11759 return Object.assign({}, acc, {
11760 [key]: obj[key]
11761 });
11762 }
11763
11764 var pickedValues = pickValueAndLength(obj, key);
11765
11766 if (pickedValues === null) {
11767 return acc;
11768 }
11769
11770 var keyPaths = pickedValues.keyPaths,
11771 value = pickedValues.value;
11772 var len = keyPaths.length;
11773 var innerObject = {
11774 [keyPaths[--len]]: value
11775 };
11776
11777 while (len--) {
11778 innerObject = {
11779 [keyPaths[len]]: innerObject
11780 };
11781 }
11782
11783 return Object.assign({}, acc, innerObject);
11784 }, {});
11785}
11786
11787var styles$$ = {
11788 "Container": "Polaris-Modal-Dialog__Container",
11789 "Modal": "Polaris-Modal-Dialog__Modal",
11790 "limitHeight": "Polaris-Modal-Dialog--limitHeight",
11791 "sizeLarge": "Polaris-Modal-Dialog--sizeLarge",
11792 "animateFadeUp": "Polaris-Modal-Dialog--animateFadeUp",
11793 "entering": "Polaris-Modal-Dialog--entering",
11794 "exiting": "Polaris-Modal-Dialog--exiting",
11795 "exited": "Polaris-Modal-Dialog--exited",
11796 "entered": "Polaris-Modal-Dialog--entered"
11797};
11798
11799function Dialog(_a) {
11800 var instant = _a.instant,
11801 labelledBy = _a.labelledBy,
11802 children = _a.children,
11803 onClose = _a.onClose,
11804 onExited = _a.onExited,
11805 onEntered = _a.onEntered,
11806 large = _a.large,
11807 limitHeight = _a.limitHeight,
11808 props = __rest(_a, ["instant", "labelledBy", "children", "onClose", "onExited", "onEntered", "large", "limitHeight"]);
11809
11810 var containerNode = useRef(null);
11811 var findDOMNode = useCallback(function () {
11812 return containerNode.current;
11813 }, []);
11814 var classes = classNames(styles$$.Modal, large && styles$$.sizeLarge, limitHeight && styles$$.limitHeight);
11815 var TransitionChild = instant ? Transition : FadeUp;
11816 return React__default.createElement(TransitionChild, Object.assign({}, props, {
11817 findDOMNode: findDOMNode,
11818 mountOnEnter: true,
11819 unmountOnExit: true,
11820 timeout: durationBase,
11821 onEntered: onEntered,
11822 onExited: onExited
11823 }), React__default.createElement("div", {
11824 className: styles$$.Container,
11825 "data-polaris-layer": true,
11826 "data-polaris-overlay": true,
11827 ref: containerNode
11828 }, React__default.createElement(TrapFocus, null, React__default.createElement("div", {
11829 className: classes,
11830 role: "dialog",
11831 "aria-labelledby": labelledBy,
11832 tabIndex: -1
11833 }, React__default.createElement(KeypressListener, {
11834 keyCode: Key.Escape,
11835 handler: onClose
11836 }), children))));
11837}
11838var fadeUpClasses = {
11839 appear: classNames(styles$$.animateFadeUp, styles$$.entering),
11840 appearActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11841 enter: classNames(styles$$.animateFadeUp, styles$$.entering),
11842 enterActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11843 exit: classNames(styles$$.animateFadeUp, styles$$.exiting),
11844 exitActive: classNames(styles$$.animateFadeUp, styles$$.exited)
11845};
11846
11847function FadeUp(_a) {
11848 var children = _a.children,
11849 props = __rest(_a, ["children"]);
11850
11851 return React__default.createElement(CSSTransition, Object.assign({}, props, {
11852 classNames: fadeUpClasses
11853 }), children);
11854}
11855
11856var styles$10 = {
11857 "Footer": "Polaris-Modal-Footer",
11858 "FooterContent": "Polaris-Modal-Footer__FooterContent"
11859};
11860
11861function Footer(_ref) {
11862 var primaryAction = _ref.primaryAction,
11863 secondaryActions = _ref.secondaryActions,
11864 children = _ref.children;
11865 var primaryActionButton = primaryAction && buttonsFrom(primaryAction, {
11866 primary: true
11867 }) || null;
11868 var secondaryActionButtons = secondaryActions && buttonsFrom(secondaryActions) || null;
11869 var actions = primaryActionButton || secondaryActionButtons ? React__default.createElement(ButtonGroup, null, secondaryActionButtons, primaryActionButton) : null;
11870 return React__default.createElement("div", {
11871 className: styles$10.Footer
11872 }, React__default.createElement("div", {
11873 className: styles$10.FooterContent
11874 }, React__default.createElement(Stack, {
11875 alignment: "center"
11876 }, React__default.createElement(Stack.Item, {
11877 fill: true
11878 }, children), actions)));
11879}
11880
11881var styles$11 = {
11882 "CloseButton": "Polaris-Modal-CloseButton",
11883 "withoutTitle": "Polaris-Modal-CloseButton--withoutTitle"
11884};
11885
11886function CloseButton(_ref) {
11887 var _ref$title = _ref.title,
11888 title = _ref$title === void 0 ? true : _ref$title,
11889 onClick = _ref.onClick;
11890 var i18n = useI18n();
11891 var className = classNames(styles$11.CloseButton, !title && styles$11.withoutTitle);
11892 return React__default.createElement("button", {
11893 onClick: onClick,
11894 className: className,
11895 "aria-label": i18n.translate('Polaris.Common.close')
11896 }, React__default.createElement(Icon, {
11897 source: MobileCancelMajorMonotone,
11898 color: "inkLighter"
11899 }));
11900}
11901
11902var styles$12 = {
11903 "Header": "Polaris-Modal-Header",
11904 "Title": "Polaris-Modal-Header__Title"
11905};
11906
11907function Header$1(_ref) {
11908 var id = _ref.id,
11909 children = _ref.children,
11910 onClose = _ref.onClose;
11911 return React__default.createElement("div", {
11912 className: styles$12.Header
11913 }, React__default.createElement("div", {
11914 id: id,
11915 className: styles$12.Title
11916 }, React__default.createElement(DisplayText, {
11917 element: "h2",
11918 size: "small"
11919 }, children)), React__default.createElement(CloseButton, {
11920 onClick: onClose
11921 }));
11922}
11923
11924var styles$13 = {
11925 "Section": "Polaris-Modal-Section",
11926 "subdued": "Polaris-Modal-Section--subdued",
11927 "flush": "Polaris-Modal-Section--flush"
11928};
11929
11930function Section$3(_ref) {
11931 var children = _ref.children,
11932 _ref$flush = _ref.flush,
11933 flush = _ref$flush === void 0 ? false : _ref$flush,
11934 _ref$subdued = _ref.subdued,
11935 subdued = _ref$subdued === void 0 ? false : _ref$subdued;
11936 var className = classNames(styles$13.Section, flush && styles$13.flush, subdued && styles$13.subdued);
11937 return React__default.createElement("section", {
11938 className: className
11939 }, children);
11940}
11941
11942var styles$14 = {
11943 "BodyWrapper": "Polaris-Modal__BodyWrapper",
11944 "Body": "Polaris-Modal__Body",
11945 "IFrame": "Polaris-Modal__IFrame",
11946 "Spinner": "Polaris-Modal__Spinner"
11947};
11948
11949var IFRAME_LOADING_HEIGHT = 200;
11950var DEFAULT_IFRAME_CONTENT_HEIGHT = 400;
11951var getUniqueID$1 = createUniqueIDFactory('modal-header');
11952var APP_BRIDGE_PROPS = ['title', 'size', 'message', 'src', 'primaryAction', 'secondaryActions'];
11953
11954var Modal =
11955/*#__PURE__*/
11956function (_React$Component) {
11957 _inherits(Modal, _React$Component);
11958
11959 function Modal() {
11960 var _this;
11961
11962 _classCallCheck(this, Modal);
11963
11964 _this = _possibleConstructorReturn(this, _getPrototypeOf(Modal).apply(this, arguments));
11965 _this.state = {
11966 iframeHeight: IFRAME_LOADING_HEIGHT
11967 };
11968 _this.headerId = getUniqueID$1();
11969
11970 _this.handleEntered = function () {
11971 var onTransitionEnd = _this.props.onTransitionEnd;
11972
11973 if (onTransitionEnd) {
11974 onTransitionEnd();
11975 }
11976 };
11977
11978 _this.handleExited = function () {
11979 _this.setState({
11980 iframeHeight: IFRAME_LOADING_HEIGHT
11981 });
11982
11983 if (_this.focusReturnPointNode) {
11984 write(function () {
11985 return focusFirstFocusableNode(_this.focusReturnPointNode, false);
11986 });
11987 }
11988 };
11989
11990 _this.handleIFrameLoad = function (evt) {
11991 var iframe = evt.target;
11992
11993 if (iframe && iframe.contentWindow) {
11994 try {
11995 _this.setState({
11996 iframeHeight: iframe.contentWindow.document.body.scrollHeight
11997 });
11998 } catch (_a) {
11999 _this.setState({
12000 iframeHeight: DEFAULT_IFRAME_CONTENT_HEIGHT
12001 });
12002 }
12003 }
12004
12005 var onIFrameLoad = _this.props.onIFrameLoad;
12006
12007 if (onIFrameLoad != null) {
12008 onIFrameLoad(evt);
12009 }
12010 };
12011
12012 return _this;
12013 }
12014
12015 _createClass(Modal, [{
12016 key: "componentDidMount",
12017 value: function componentDidMount() {
12018 if (this.props.polaris.appBridge == null) {
12019 return;
12020 } // eslint-disable-next-line no-console
12021
12022
12023 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');
12024 var transformProps = this.transformProps();
12025
12026 if (transformProps) {
12027 this.appBridgeModal = Modal$2.create(this.props.polaris.appBridge, transformProps);
12028 }
12029
12030 if (this.appBridgeModal) {
12031 this.appBridgeModal.subscribe(Modal$2.Action.CLOSE, this.props.onClose);
12032 }
12033
12034 var open = this.props.open;
12035
12036 if (open) {
12037 this.focusReturnPointNode = document.activeElement;
12038 this.appBridgeModal && this.appBridgeModal.dispatch(Modal$2.Action.OPEN);
12039 }
12040 }
12041 }, {
12042 key: "componentDidUpdate",
12043 value: function componentDidUpdate(prevProps) {
12044 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
12045 return;
12046 }
12047
12048 var open = this.props.open;
12049 var wasOpen = prevProps.open;
12050 var transformedProps = this.transformProps();
12051 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS);
12052 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS);
12053
12054 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps) && transformedProps) {
12055 if (isIframeModal(transformedProps)) {
12056 this.appBridgeModal.set(transformedProps);
12057 } else {
12058 this.appBridgeModal.set(transformedProps);
12059 }
12060 }
12061
12062 if (wasOpen !== open) {
12063 if (open) {
12064 this.appBridgeModal.dispatch(Modal$2.Action.OPEN);
12065 } else {
12066 this.appBridgeModal.dispatch(Modal$2.Action.CLOSE);
12067 }
12068 }
12069
12070 if (!wasOpen && open) {
12071 this.focusReturnPointNode = document.activeElement;
12072 } else if (wasOpen && !open && this.focusReturnPointNode != null && document.contains(this.focusReturnPointNode)) {
12073 this.focusReturnPointNode.focus();
12074 this.focusReturnPointNode = null;
12075 }
12076 }
12077 }, {
12078 key: "componentWillUnmount",
12079 value: function componentWillUnmount() {
12080 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
12081 return;
12082 }
12083
12084 this.appBridgeModal.unsubscribe();
12085 }
12086 }, {
12087 key: "render",
12088 value: function render() {
12089 if (this.props.polaris.appBridge != null) {
12090 return null;
12091 }
12092
12093 var _this$props = this.props,
12094 children = _this$props.children,
12095 title = _this$props.title,
12096 src = _this$props.src,
12097 iFrameName = _this$props.iFrameName,
12098 open = _this$props.open,
12099 instant = _this$props.instant,
12100 sectioned = _this$props.sectioned,
12101 loading = _this$props.loading,
12102 large = _this$props.large,
12103 limitHeight = _this$props.limitHeight,
12104 onClose = _this$props.onClose,
12105 footer = _this$props.footer,
12106 primaryAction = _this$props.primaryAction,
12107 secondaryActions = _this$props.secondaryActions,
12108 intl = _this$props.polaris.intl,
12109 onScrolledToBottom = _this$props.onScrolledToBottom;
12110 var iframeHeight = this.state.iframeHeight;
12111 var iframeTitle = intl.translate('Polaris.Modal.iFrameTitle');
12112 var dialog;
12113 var backdrop;
12114
12115 if (open) {
12116 var footerMarkup = !footer && !primaryAction && !secondaryActions ? null : React__default.createElement(Footer, {
12117 primaryAction: primaryAction,
12118 secondaryActions: secondaryActions
12119 }, footer);
12120 var content = sectioned ? wrapWithComponent(children, Section$3, {}) : children;
12121 var body = loading ? React__default.createElement("div", {
12122 className: styles$14.Spinner
12123 }, React__default.createElement(Spinner, null)) : content;
12124 var bodyMarkup = src ? React__default.createElement("iframe", {
12125 name: iFrameName,
12126 title: iframeTitle,
12127 src: src,
12128 className: styles$14.IFrame,
12129 onLoad: this.handleIFrameLoad,
12130 style: {
12131 height: "".concat(iframeHeight, "px")
12132 }
12133 }) : React__default.createElement(Scrollable, {
12134 shadow: true,
12135 className: styles$14.Body,
12136 onScrolledToBottom: onScrolledToBottom
12137 }, body);
12138 var headerMarkup = title ? React__default.createElement(Header$1, {
12139 id: this.headerId,
12140 onClose: onClose
12141 }, title) : React__default.createElement(CloseButton, {
12142 onClick: onClose,
12143 title: false
12144 });
12145 var labelledBy = title ? this.headerId : undefined;
12146 dialog = React__default.createElement(Dialog, {
12147 instant: instant,
12148 labelledBy: labelledBy,
12149 onClose: onClose,
12150 onEntered: this.handleEntered,
12151 onExited: this.handleExited,
12152 large: large,
12153 limitHeight: limitHeight
12154 }, headerMarkup, React__default.createElement("div", {
12155 className: styles$14.BodyWrapper
12156 }, bodyMarkup), footerMarkup);
12157 backdrop = React__default.createElement(Backdrop, null);
12158 }
12159
12160 var animated = !instant;
12161 return React__default.createElement(WithinContentContext.Provider, {
12162 value: true
12163 }, React__default.createElement(Portal, {
12164 idPrefix: "modal"
12165 }, React__default.createElement(TransitionGroup, {
12166 appear: animated,
12167 enter: animated,
12168 exit: animated
12169 }, dialog), backdrop));
12170 }
12171 }, {
12172 key: "transformProps",
12173 value: function transformProps() {
12174 var _this$props2 = this.props,
12175 title = _this$props2.title,
12176 size = _this$props2.size,
12177 message = _this$props2.message,
12178 src = _this$props2.src,
12179 primaryAction = _this$props2.primaryAction,
12180 secondaryActions = _this$props2.secondaryActions,
12181 polaris = _this$props2.polaris;
12182 var appBridge = polaris.appBridge;
12183 if (!appBridge) return;
12184 var safeTitle = typeof title === 'string' ? title : undefined;
12185 var safeSize = size != null ? Modal$2.Size[size] : undefined;
12186 var srcPayload = {};
12187
12188 if (src != null) {
12189 if (/^https?:\/\//.test(src)) {
12190 srcPayload.url = src;
12191 } else {
12192 srcPayload.path = src;
12193 }
12194 }
12195
12196 return Object.assign({
12197 title: safeTitle,
12198 message,
12199 size: safeSize
12200 }, srcPayload, {
12201 footer: {
12202 buttons: transformActions(appBridge, {
12203 primaryAction,
12204 secondaryActions
12205 })
12206 }
12207 });
12208 }
12209 }]);
12210
12211 return Modal;
12212}(React__default.Component);
12213
12214Modal.Section = Section$3;
12215
12216function isIframeModal(options) {
12217 return typeof options.url === 'string' || typeof options.path === 'string';
12218} // Use named export once withAppProvider is refactored away
12219// eslint-disable-next-line import/no-default-export
12220
12221
12222var Modal$1 = withAppProvider()(Modal);
12223
12224function DiscardConfirmationModal(_ref) {
12225 var open = _ref.open,
12226 onDiscard = _ref.onDiscard,
12227 onCancel = _ref.onCancel;
12228 var i18n = useI18n();
12229 return React__default.createElement(Modal$1, {
12230 title: i18n.translate('Polaris.DiscardConfirmationModal.title'),
12231 open: open,
12232 onClose: onCancel,
12233 primaryAction: {
12234 content: i18n.translate('Polaris.DiscardConfirmationModal.primaryAction'),
12235 destructive: true,
12236 onAction: onDiscard
12237 },
12238 secondaryActions: [{
12239 content: i18n.translate('Polaris.DiscardConfirmationModal.secondaryAction'),
12240 onAction: onCancel
12241 }],
12242 sectioned: true
12243 }, i18n.translate('Polaris.DiscardConfirmationModal.message'));
12244}
12245
12246var styles$15 = {
12247 "ContextualSaveBar": "Polaris-Frame-ContextualSaveBar",
12248 "LogoContainer": "Polaris-Frame-ContextualSaveBar__LogoContainer",
12249 "Contents": "Polaris-Frame-ContextualSaveBar__Contents",
12250 "Message": "Polaris-Frame-ContextualSaveBar__Message",
12251 "ActionContainer": "Polaris-Frame-ContextualSaveBar__ActionContainer",
12252 "Action": "Polaris-Frame-ContextualSaveBar__Action"
12253};
12254
12255function ContextualSaveBar$1(_ref) {
12256 var alignContentFlush = _ref.alignContentFlush,
12257 message = _ref.message,
12258 saveAction = _ref.saveAction,
12259 discardAction = _ref.discardAction;
12260 var i18n = useI18n();
12261
12262 var _useTheme = useTheme(),
12263 logo = _useTheme.logo;
12264
12265 var _useForcibleToggle = useForcibleToggle(false),
12266 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
12267 discardConfirmationModalVisible = _useForcibleToggle2[0],
12268 _useForcibleToggle2$ = _useForcibleToggle2[1],
12269 toggleDiscardConfirmationModal = _useForcibleToggle2$.toggle,
12270 closeDiscardConfirmationModal = _useForcibleToggle2$.forceFalse;
12271
12272 var handleDiscardAction = useCallback(function () {
12273 if (discardAction && discardAction.onAction) {
12274 discardAction.onAction();
12275 }
12276
12277 closeDiscardConfirmationModal();
12278 }, [closeDiscardConfirmationModal, discardAction]);
12279 var discardActionContent = discardAction && discardAction.content ? discardAction.content : i18n.translate('Polaris.ContextualSaveBar.discard');
12280 var discardActionHandler;
12281
12282 if (discardAction && discardAction.discardConfirmationModal) {
12283 discardActionHandler = toggleDiscardConfirmationModal;
12284 } else if (discardAction) {
12285 discardActionHandler = discardAction.onAction;
12286 }
12287
12288 var discardConfirmationModalMarkup = discardAction && discardAction.onAction && discardAction.discardConfirmationModal && React__default.createElement(DiscardConfirmationModal, {
12289 open: discardConfirmationModalVisible,
12290 onCancel: toggleDiscardConfirmationModal,
12291 onDiscard: handleDiscardAction
12292 });
12293 var discardActionMarkup = discardAction && React__default.createElement(Button, {
12294 url: discardAction.url,
12295 onClick: discardActionHandler,
12296 loading: discardAction.loading,
12297 disabled: discardAction.disabled,
12298 accessibilityLabel: discardAction.content
12299 }, discardActionContent);
12300 var saveActionContent = saveAction && saveAction.content ? saveAction.content : i18n.translate('Polaris.ContextualSaveBar.save');
12301 var saveActionMarkup = saveAction && React__default.createElement(Button, {
12302 primary: true,
12303 url: saveAction.url,
12304 onClick: saveAction.onAction,
12305 loading: saveAction.loading,
12306 disabled: saveAction.disabled,
12307 accessibilityLabel: saveAction.content
12308 }, saveActionContent);
12309 var width = getWidth(logo, 104);
12310 var imageMarkup = logo && React__default.createElement(Image, {
12311 style: {
12312 width
12313 },
12314 source: logo.contextualSaveBarSource || '',
12315 alt: ""
12316 });
12317 var logoMarkup = alignContentFlush ? null : React__default.createElement("div", {
12318 className: styles$15.LogoContainer,
12319 style: {
12320 width
12321 }
12322 }, imageMarkup);
12323 return React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
12324 className: styles$15.ContextualSaveBar
12325 }, logoMarkup, React__default.createElement("div", {
12326 className: styles$15.Contents
12327 }, React__default.createElement("h2", {
12328 className: styles$15.Message
12329 }, message), React__default.createElement("div", {
12330 className: styles$15.ActionContainer
12331 }, React__default.createElement(Stack, {
12332 spacing: "tight",
12333 wrap: false
12334 }, discardActionMarkup, saveActionMarkup)))), discardConfirmationModalMarkup);
12335}
12336
12337var styles$16 = {
12338 "startFade": "Polaris-Frame-CSSAnimation--startFade",
12339 "endFade": "Polaris-Frame-CSSAnimation--endFade"
12340};
12341
12342var AnimationType;
12343
12344(function (AnimationType) {
12345 AnimationType["Fade"] = "fade";
12346})(AnimationType || (AnimationType = {}));
12347
12348var TransitionStatus$1;
12349
12350(function (TransitionStatus) {
12351 TransitionStatus["Entering"] = "entering";
12352 TransitionStatus["Entered"] = "entered";
12353 TransitionStatus["Exiting"] = "exiting";
12354 TransitionStatus["Exited"] = "exited";
12355})(TransitionStatus$1 || (TransitionStatus$1 = {}));
12356
12357function CSSAnimation(_ref) {
12358 var inProp = _ref.in,
12359 className = _ref.className,
12360 type = _ref.type,
12361 children = _ref.children;
12362
12363 var _useState = useState(inProp ? TransitionStatus$1.Entering : TransitionStatus$1.Exited),
12364 _useState2 = _slicedToArray(_useState, 2),
12365 transitionStatus = _useState2[0],
12366 setTransitionStatus = _useState2[1];
12367
12368 var isMounted = useRef(false);
12369 var node = useRef(null);
12370 useEffect(function () {
12371 if (!isMounted.current) return;
12372 transitionStatus === TransitionStatus$1.Entering && changeTransitionStatus(TransitionStatus$1.Entered);
12373 }, [transitionStatus]);
12374 useEffect(function () {
12375 if (!isMounted.current) return;
12376 inProp && changeTransitionStatus(TransitionStatus$1.Entering);
12377 !inProp && changeTransitionStatus(TransitionStatus$1.Exiting);
12378 }, [inProp]);
12379 useEffect(function () {
12380 isMounted.current = true;
12381 }, []);
12382 var wrapperClassName = classNames(className, styles$16[variationName('start', type)], inProp && styles$16[variationName('end', type)]);
12383 var content = transitionStatus === TransitionStatus$1.Exited && !inProp ? null : children;
12384 return React__default.createElement("div", {
12385 className: wrapperClassName,
12386 ref: node,
12387 onTransitionEnd: handleTransitionEnd
12388 }, content);
12389
12390 function handleTransitionEnd() {
12391 transitionStatus === TransitionStatus$1.Exiting && changeTransitionStatus(TransitionStatus$1.Exited);
12392 }
12393
12394 function changeTransitionStatus(transitionStatus) {
12395 setTransitionStatus(transitionStatus); // Forcing a reflow to enable the animation
12396
12397 if (transitionStatus === TransitionStatus$1.Entering) node.current && node.current.getBoundingClientRect();
12398 }
12399}
12400
12401var styles$17 = {
12402 "Frame": "Polaris-Frame",
12403 "Navigation": "Polaris-Frame__Navigation",
12404 "Navigation-enter": "Polaris-Frame__Navigation--enter",
12405 "Navigation-enterActive": "Polaris-Frame__Navigation--enterActive",
12406 "Navigation-exit": "Polaris-Frame__Navigation--exit",
12407 "Navigation-exitActive": "Polaris-Frame__Navigation--exitActive",
12408 "NavigationDismiss": "Polaris-Frame__NavigationDismiss",
12409 "Navigation-visible": "Polaris-Frame__Navigation--visible",
12410 "TopBar": "Polaris-Frame__TopBar",
12411 "ContextualSaveBar": "Polaris-Frame__ContextualSaveBar",
12412 "Main": "Polaris-Frame__Main",
12413 "hasNav": "Polaris-Frame--hasNav",
12414 "hasTopBar": "Polaris-Frame--hasTopBar",
12415 "Content": "Polaris-Frame__Content",
12416 "GlobalRibbonContainer": "Polaris-Frame__GlobalRibbonContainer",
12417 "LoadingBar": "Polaris-Frame__LoadingBar",
12418 "Skip": "Polaris-Frame__Skip",
12419 "focused": "Polaris-Frame--focused",
12420 "SkipAnchor": "Polaris-Frame__SkipAnchor",
12421 "globalTheming": "Polaris-Frame--globalTheming"
12422};
12423
12424var GLOBAL_RIBBON_CUSTOM_PROPERTY = '--global-ribbon-height';
12425var APP_FRAME_MAIN = 'AppFrameMain';
12426var APP_FRAME_MAIN_ANCHOR_TARGET = 'AppFrameMainContent';
12427var APP_FRAME_NAV = 'AppFrameNav';
12428var APP_FRAME_TOP_BAR = 'AppFrameTopBar';
12429var APP_FRAME_LOADING_BAR = 'AppFrameLoadingBar';
12430
12431var Frame =
12432/*#__PURE__*/
12433function (_React$PureComponent) {
12434 _inherits(Frame, _React$PureComponent);
12435
12436 function Frame() {
12437 var _this;
12438
12439 _classCallCheck(this, Frame);
12440
12441 _this = _possibleConstructorReturn(this, _getPrototypeOf(Frame).apply(this, arguments));
12442 _this.state = {
12443 skipFocused: false,
12444 globalRibbonHeight: 0,
12445 loadingStack: 0,
12446 toastMessages: [],
12447 showContextualSaveBar: false
12448 };
12449 _this.globalRibbonContainer = null;
12450 _this.navigationNode = createRef();
12451 _this.skipToMainContentTargetNode = _this.props.skipToContentTarget || React__default.createRef();
12452
12453 _this.setGlobalRibbonHeight = function () {
12454 var _assertThisInitialize = _assertThisInitialized(_this),
12455 globalRibbonContainer = _assertThisInitialize.globalRibbonContainer;
12456
12457 if (globalRibbonContainer) {
12458 _this.setState({
12459 globalRibbonHeight: globalRibbonContainer.offsetHeight
12460 }, _this.setGlobalRibbonRootProperty);
12461 }
12462 };
12463
12464 _this.setGlobalRibbonRootProperty = function () {
12465 var globalRibbonHeight = _this.state.globalRibbonHeight;
12466 setRootProperty(GLOBAL_RIBBON_CUSTOM_PROPERTY, "".concat(globalRibbonHeight, "px"), null);
12467 };
12468
12469 _this.showToast = function (toast) {
12470 _this.setState(function (_ref) {
12471 var toastMessages = _ref.toastMessages;
12472 var hasToastById = toastMessages.find(function (_ref2) {
12473 var id = _ref2.id;
12474 return id === toast.id;
12475 }) != null;
12476 return {
12477 toastMessages: hasToastById ? toastMessages : [].concat(_toConsumableArray(toastMessages), [toast])
12478 };
12479 });
12480 };
12481
12482 _this.hideToast = function (_ref3) {
12483 var id = _ref3.id;
12484
12485 _this.setState(function (_ref4) {
12486 var toastMessages = _ref4.toastMessages;
12487 return {
12488 toastMessages: toastMessages.filter(function (_ref5) {
12489 var toastId = _ref5.id;
12490 return id !== toastId;
12491 })
12492 };
12493 });
12494 };
12495
12496 _this.setContextualSaveBar = function (props) {
12497 var showContextualSaveBar = _this.state.showContextualSaveBar;
12498 _this.contextualSaveBar = Object.assign({}, props);
12499
12500 if (showContextualSaveBar === true) {
12501 _this.forceUpdate();
12502 } else {
12503 _this.setState({
12504 showContextualSaveBar: true
12505 });
12506 }
12507 };
12508
12509 _this.removeContextualSaveBar = function () {
12510 _this.contextualSaveBar = null;
12511
12512 _this.setState({
12513 showContextualSaveBar: false
12514 });
12515 };
12516
12517 _this.startLoading = function () {
12518 _this.setState(function (_ref6) {
12519 var loadingStack = _ref6.loadingStack;
12520 return {
12521 loadingStack: loadingStack + 1
12522 };
12523 });
12524 };
12525
12526 _this.stopLoading = function () {
12527 _this.setState(function (_ref7) {
12528 var loadingStack = _ref7.loadingStack;
12529 return {
12530 loadingStack: Math.max(0, loadingStack - 1)
12531 };
12532 });
12533 };
12534
12535 _this.handleResize = function () {
12536 if (_this.props.globalRibbon) {
12537 _this.setGlobalRibbonHeight();
12538 }
12539 };
12540
12541 _this.handleFocus = function () {
12542 _this.setState({
12543 skipFocused: true
12544 });
12545 };
12546
12547 _this.handleBlur = function () {
12548 _this.setState({
12549 skipFocused: false
12550 });
12551 };
12552
12553 _this.handleClick = function () {
12554 _this.skipToMainContentTargetNode.current && _this.skipToMainContentTargetNode.current.focus();
12555 };
12556
12557 _this.handleNavigationDismiss = function () {
12558 var onNavigationDismiss = _this.props.onNavigationDismiss;
12559
12560 if (onNavigationDismiss != null) {
12561 onNavigationDismiss();
12562 }
12563 };
12564
12565 _this.setGlobalRibbonContainer = function (node) {
12566 _this.globalRibbonContainer = node;
12567 };
12568
12569 _this.handleNavKeydown = function (event) {
12570 var key = event.key;
12571
12572 if (key === 'Escape') {
12573 _this.handleNavigationDismiss();
12574 }
12575 };
12576
12577 _this.findNavigationNode = function () {
12578 return _this.navigationNode.current;
12579 };
12580
12581 return _this;
12582 }
12583
12584 _createClass(Frame, [{
12585 key: "componentDidMount",
12586 value: function componentDidMount() {
12587 this.handleResize();
12588
12589 if (this.props.globalRibbon) {
12590 return;
12591 }
12592
12593 this.setGlobalRibbonRootProperty();
12594 }
12595 }, {
12596 key: "componentDidUpdate",
12597 value: function componentDidUpdate(prevProps) {
12598 if (this.props.globalRibbon !== prevProps.globalRibbon) {
12599 this.setGlobalRibbonHeight();
12600 }
12601 }
12602 }, {
12603 key: "render",
12604 value: function render() {
12605 var _this$state = this.state,
12606 skipFocused = _this$state.skipFocused,
12607 loadingStack = _this$state.loadingStack,
12608 toastMessages = _this$state.toastMessages,
12609 showContextualSaveBar = _this$state.showContextualSaveBar;
12610 var _this$props = this.props,
12611 children = _this$props.children,
12612 navigation = _this$props.navigation,
12613 topBar = _this$props.topBar,
12614 globalRibbon = _this$props.globalRibbon,
12615 _this$props$showMobil = _this$props.showMobileNavigation,
12616 showMobileNavigation = _this$props$showMobil === void 0 ? false : _this$props$showMobil,
12617 skipToContentTarget = _this$props.skipToContentTarget,
12618 _this$props$polaris = _this$props.polaris,
12619 intl = _this$props$polaris.intl,
12620 isNavigationCollapsed = _this$props$polaris.mediaQuery.isNavigationCollapsed;
12621 var navClassName = classNames(styles$17.Navigation, showMobileNavigation && styles$17['Navigation-visible']);
12622 var mobileNavHidden = isNavigationCollapsed && !showMobileNavigation;
12623 var mobileNavShowing = isNavigationCollapsed && showMobileNavigation;
12624 var tabIndex = mobileNavShowing ? 0 : -1;
12625 var navigationMarkup = navigation ? React__default.createElement(TrapFocus, {
12626 trapping: mobileNavShowing
12627 }, React__default.createElement(CSSTransition, {
12628 findDOMNode: this.findNavigationNode,
12629 appear: isNavigationCollapsed,
12630 exit: isNavigationCollapsed,
12631 in: showMobileNavigation,
12632 timeout: durationSlow,
12633 classNames: navTransitionClasses
12634 }, React__default.createElement("div", {
12635 ref: this.navigationNode,
12636 className: navClassName,
12637 onKeyDown: this.handleNavKeydown,
12638 id: APP_FRAME_NAV,
12639 key: "NavContent",
12640 hidden: mobileNavHidden
12641 }, navigation, React__default.createElement("button", {
12642 type: "button",
12643 className: styles$17.NavigationDismiss,
12644 onClick: this.handleNavigationDismiss,
12645 "aria-hidden": mobileNavHidden || !isNavigationCollapsed && !showMobileNavigation,
12646 "aria-label": intl.translate('Polaris.Frame.Navigation.closeMobileNavigationLabel'),
12647 tabIndex: tabIndex
12648 }, React__default.createElement(Icon, {
12649 source: MobileCancelMajorMonotone,
12650 color: "white"
12651 }))))) : null;
12652 var loadingMarkup = loadingStack > 0 ? React__default.createElement("div", {
12653 className: styles$17.LoadingBar,
12654 id: APP_FRAME_LOADING_BAR
12655 }, React__default.createElement(Loading, null)) : null;
12656 var contextualSaveBarMarkup = React__default.createElement(CSSAnimation, {
12657 in: showContextualSaveBar,
12658 className: styles$17.ContextualSaveBar,
12659 type: AnimationType.Fade
12660 }, React__default.createElement(ContextualSaveBar$1, this.contextualSaveBar));
12661 var topBarMarkup = topBar ? React__default.createElement("div", Object.assign({
12662 className: styles$17.TopBar
12663 }, layer.props, dataPolarisTopBar.props, {
12664 id: APP_FRAME_TOP_BAR
12665 }), topBar) : null;
12666 var globalRibbonMarkup = globalRibbon ? React__default.createElement("div", {
12667 className: styles$17.GlobalRibbonContainer,
12668 ref: this.setGlobalRibbonContainer
12669 }, globalRibbon) : null;
12670 var skipClassName = classNames(styles$17.Skip, skipFocused && styles$17.focused);
12671 var skipTarget = skipToContentTarget ? skipToContentTarget.current && skipToContentTarget.current.id || '' : APP_FRAME_MAIN_ANCHOR_TARGET;
12672 var skipMarkup = React__default.createElement("div", {
12673 className: skipClassName
12674 }, React__default.createElement("a", {
12675 href: "#".concat(skipTarget),
12676 onFocus: this.handleFocus,
12677 onBlur: this.handleBlur,
12678 onClick: this.handleClick,
12679 className: styles$17.SkipAnchor
12680 }, intl.translate('Polaris.Frame.skipToContent')));
12681 var navigationAttributes = navigation ? {
12682 'data-has-navigation': true
12683 } : {};
12684 var frameClassName = classNames(styles$17.Frame, navigation && styles$17.hasNav, topBar && styles$17.hasTopBar);
12685 var navigationOverlayMarkup = showMobileNavigation && isNavigationCollapsed ? React__default.createElement(Backdrop, {
12686 belowNavigation: true,
12687 onClick: this.handleNavigationDismiss,
12688 onTouchStart: this.handleNavigationDismiss
12689 }) : null;
12690 var skipToMainContentTarget = skipToContentTarget ? null : // eslint-disable-next-line jsx-a11y/anchor-is-valid
12691 React__default.createElement("a", {
12692 id: APP_FRAME_MAIN_ANCHOR_TARGET,
12693 ref: this.skipToMainContentTargetNode,
12694 tabIndex: -1
12695 });
12696 var context = {
12697 showToast: this.showToast,
12698 hideToast: this.hideToast,
12699 startLoading: this.startLoading,
12700 stopLoading: this.stopLoading,
12701 setContextualSaveBar: this.setContextualSaveBar,
12702 removeContextualSaveBar: this.removeContextualSaveBar
12703 };
12704 return React__default.createElement(FrameContext.Provider, {
12705 value: context
12706 }, React__default.createElement("div", Object.assign({
12707 className: frameClassName
12708 }, layer.props, navigationAttributes), skipMarkup, topBarMarkup, navigationMarkup, contextualSaveBarMarkup, loadingMarkup, navigationOverlayMarkup, React__default.createElement("main", {
12709 className: styles$17.Main,
12710 id: APP_FRAME_MAIN,
12711 "data-has-global-ribbon": Boolean(globalRibbon)
12712 }, skipToMainContentTarget, React__default.createElement("div", {
12713 className: styles$17.Content
12714 }, children)), React__default.createElement(ToastManager, {
12715 toastMessages: toastMessages
12716 }), globalRibbonMarkup, React__default.createElement(EventListener, {
12717 event: "resize",
12718 handler: this.handleResize
12719 })));
12720 }
12721 }]);
12722
12723 return Frame;
12724}(React__default.PureComponent);
12725
12726var navTransitionClasses = {
12727 enter: classNames(styles$17['Navigation-enter']),
12728 enterActive: classNames(styles$17['Navigation-enterActive']),
12729 enterDone: classNames(styles$17['Navigation-enterActive']),
12730 exit: classNames(styles$17['Navigation-exit']),
12731 exitActive: classNames(styles$17['Navigation-exitActive'])
12732}; // Use named export once withAppProvider is refactored away
12733// eslint-disable-next-line import/no-default-export
12734
12735var Frame$1 = withAppProvider()(Frame);
12736
12737var styles$18 = {
12738 "Indicator": "Polaris-Indicator",
12739 "pulseIndicator": "Polaris-Indicator--pulseIndicator",
12740 "bounce": "Polaris-Indicator--bounce",
12741 "pulse": "Polaris-Indicator--pulse"
12742};
12743
12744function Indicator(_ref) {
12745 var _ref$pulse = _ref.pulse,
12746 pulse = _ref$pulse === void 0 ? true : _ref$pulse;
12747 var className = classNames(styles$18.Indicator, pulse && styles$18.pulseIndicator);
12748 return React__default.createElement("span", {
12749 className: className
12750 });
12751}
12752
12753var styles$19 = {
12754 "KeyboardKey": "Polaris-KeyboardKey"
12755};
12756
12757function KeyboardKey(_ref) {
12758 var children = _ref.children;
12759 var key = children || '';
12760 key = key.length > 1 ? key.toLowerCase() : key.toUpperCase();
12761 return React__default.createElement("kbd", {
12762 className: styles$19.KeyboardKey
12763 }, key);
12764}
12765
12766var styles$1a = {
12767 "Layout": "Polaris-Layout",
12768 "Section": "Polaris-Layout__Section",
12769 "Section-secondary": "Polaris-Layout__Section--secondary",
12770 "Section-fullWidth": "Polaris-Layout__Section--fullWidth",
12771 "Section-oneHalf": "Polaris-Layout__Section--oneHalf",
12772 "Section-oneThird": "Polaris-Layout__Section--oneThird",
12773 "AnnotatedSection": "Polaris-Layout__AnnotatedSection",
12774 "AnnotationWrapper": "Polaris-Layout__AnnotationWrapper",
12775 "AnnotationContent": "Polaris-Layout__AnnotationContent",
12776 "Annotation": "Polaris-Layout__Annotation",
12777 "AnnotationDescription": "Polaris-Layout__AnnotationDescription"
12778};
12779
12780function AnnotatedSection(props) {
12781 var children = props.children,
12782 title = props.title,
12783 description = props.description;
12784 var descriptionMarkup = typeof description === 'string' ? React__default.createElement("p", null, description) : description;
12785 return React__default.createElement("div", {
12786 className: styles$1a.AnnotatedSection
12787 }, React__default.createElement("div", {
12788 className: styles$1a.AnnotationWrapper
12789 }, React__default.createElement("div", {
12790 className: styles$1a.Annotation
12791 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title), descriptionMarkup && React__default.createElement("div", {
12792 className: styles$1a.AnnotationDescription
12793 }, descriptionMarkup))), React__default.createElement("div", {
12794 className: styles$1a.AnnotationContent
12795 }, children)));
12796}
12797
12798function Section$4(_ref) {
12799 var children = _ref.children,
12800 secondary = _ref.secondary,
12801 fullWidth = _ref.fullWidth,
12802 oneHalf = _ref.oneHalf,
12803 oneThird = _ref.oneThird;
12804 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']);
12805 return React__default.createElement("div", {
12806 className: className
12807 }, children);
12808}
12809
12810var Layout =
12811/*#__PURE__*/
12812function (_React$Component) {
12813 _inherits(Layout, _React$Component);
12814
12815 function Layout() {
12816 _classCallCheck(this, Layout);
12817
12818 return _possibleConstructorReturn(this, _getPrototypeOf(Layout).apply(this, arguments));
12819 }
12820
12821 _createClass(Layout, [{
12822 key: "render",
12823 value: function render() {
12824 var _this$props = this.props,
12825 children = _this$props.children,
12826 sectioned = _this$props.sectioned;
12827 var content = sectioned ? React__default.createElement(Section$4, null, children) : children;
12828 return React__default.createElement("div", {
12829 className: styles$1a.Layout
12830 }, content);
12831 }
12832 }]);
12833
12834 return Layout;
12835}(React__default.Component);
12836Layout.AnnotatedSection = AnnotatedSection;
12837Layout.Section = Section$4;
12838
12839var styles$1b = {
12840 "Link": "Polaris-Link",
12841 "IconLockup": "Polaris-Link__IconLockup",
12842 "IconLayout": "Polaris-Link__IconLayout",
12843 "monochrome": "Polaris-Link--monochrome"
12844};
12845
12846function Link(_ref) {
12847 var url = _ref.url,
12848 children = _ref.children,
12849 onClick = _ref.onClick,
12850 external = _ref.external,
12851 id = _ref.id,
12852 monochrome = _ref.monochrome;
12853 var i18n = useI18n();
12854 var childrenMarkup = children;
12855
12856 if (external && typeof children === 'string') {
12857 var iconLabel = i18n.translate('Polaris.Common.newWindowAccessibilityHint');
12858 childrenMarkup = React__default.createElement(React__default.Fragment, null, children, React__default.createElement("span", {
12859 className: styles$1b.IconLockup
12860 }, React__default.createElement("span", {
12861 className: styles$1b.IconLayout
12862 }, React__default.createElement(Icon, {
12863 accessibilityLabel: iconLabel,
12864 source: ExternalSmallMinor
12865 }))));
12866 }
12867
12868 return React__default.createElement(BannerContext.Consumer, null, function (BannerContext) {
12869 var shouldBeMonochrome = monochrome || BannerContext;
12870 var className = classNames(styles$1b.Link, shouldBeMonochrome && styles$1b.monochrome);
12871 return url ? React__default.createElement(UnstyledLink, {
12872 onClick: onClick,
12873 className: className,
12874 url: url,
12875 external: external,
12876 id: id
12877 }, childrenMarkup) : React__default.createElement("button", {
12878 type: "button",
12879 onClick: onClick,
12880 className: className,
12881 id: id
12882 }, childrenMarkup);
12883 });
12884}
12885
12886var styles$1c = {
12887 "List": "Polaris-List",
12888 "typeNumber": "Polaris-List--typeNumber",
12889 "Item": "Polaris-List__Item"
12890};
12891
12892function Item$6(_ref) {
12893 var children = _ref.children;
12894 return React__default.createElement("li", {
12895 className: styles$1c.Item
12896 }, children);
12897}
12898
12899var List =
12900/*#__PURE__*/
12901function (_React$PureComponent) {
12902 _inherits(List, _React$PureComponent);
12903
12904 function List() {
12905 _classCallCheck(this, List);
12906
12907 return _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
12908 }
12909
12910 _createClass(List, [{
12911 key: "render",
12912 value: function render() {
12913 var _this$props = this.props,
12914 children = _this$props.children,
12915 _this$props$type = _this$props.type,
12916 type = _this$props$type === void 0 ? 'bullet' : _this$props$type;
12917 var className = classNames(styles$1c.List, type && styles$1c[variationName('type', type)]);
12918 var ListElement = type === 'bullet' ? 'ul' : 'ol';
12919 return React__default.createElement(ListElement, {
12920 className: className
12921 }, children);
12922 }
12923 }]);
12924
12925 return List;
12926}(React__default.PureComponent);
12927List.Item = Item$6;
12928
12929var Loading$1 = React__default.memo(function Loading() {
12930 var appBridgeLoading = useRef();
12931 var appBridge = useAppBridge();
12932
12933 var _useFrame = useFrame(),
12934 startLoading = _useFrame.startLoading,
12935 stopLoading = _useFrame.stopLoading;
12936
12937 useEffect(function () {
12938 if (appBridge == null) {
12939 startLoading();
12940 } else {
12941 // eslint-disable-next-line no-console
12942 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');
12943 appBridgeLoading.current = Loading$2.create(appBridge);
12944 appBridgeLoading.current.dispatch(Loading$2.Action.START);
12945 }
12946
12947 return function () {
12948 if (appBridge == null) {
12949 stopLoading();
12950 } else {
12951 appBridgeLoading.current && appBridgeLoading.current.dispatch(Loading$2.Action.STOP);
12952 }
12953 };
12954 }, [appBridge, startLoading, stopLoading]);
12955 return null;
12956});
12957
12958var NavigationContext = React__default.createContext({
12959 location: ''
12960});
12961
12962var styles$1d = {
12963 "Navigation": "Polaris-Navigation",
12964 "UserMenu": "Polaris-Navigation__UserMenu",
12965 "ContextControl": "Polaris-Navigation__ContextControl",
12966 "PrimaryNavigation": "Polaris-Navigation__PrimaryNavigation",
12967 "Item": "Polaris-Navigation__Item",
12968 "Icon": "Polaris-Navigation__Icon",
12969 "Item-selected": "Polaris-Navigation__Item--selected",
12970 "Item-disabled": "Polaris-Navigation__Item--disabled",
12971 "Badge": "Polaris-Navigation__Badge",
12972 "subNavigationActive": "Polaris-Navigation--subNavigationActive",
12973 "ListItem": "Polaris-Navigation__ListItem",
12974 "RollupSection": "Polaris-Navigation__RollupSection",
12975 "SecondaryNavigation": "Polaris-Navigation__SecondaryNavigation",
12976 "fade-in": "Polaris-Navigation__fade--in",
12977 "ListItem-hasAction": "Polaris-Navigation__ListItem--hasAction",
12978 "ItemWrapper": "Polaris-Navigation__ItemWrapper",
12979 "Text": "Polaris-Navigation__Text",
12980 "SecondaryAction": "Polaris-Navigation__SecondaryAction",
12981 "List": "Polaris-Navigation__List",
12982 "Section": "Polaris-Navigation__Section",
12983 "Section-fill": "Polaris-Navigation__Section--fill",
12984 "Section-withSeparator": "Polaris-Navigation__Section--withSeparator",
12985 "SectionHeading": "Polaris-Navigation__SectionHeading",
12986 "Action": "Polaris-Navigation__Action",
12987 "RollupToggle": "Polaris-Navigation__RollupToggle",
12988 "Indicator": "Polaris-Navigation__Indicator"
12989};
12990
12991function Secondary(_ref) {
12992 var children = _ref.children,
12993 expanded = _ref.expanded;
12994 var id = useUniqueId('SecondaryNavigation');
12995 return React__default.createElement(Collapsible, {
12996 id: id,
12997 open: expanded
12998 }, React__default.createElement("ul", {
12999 className: styles$1d.List
13000 }, children));
13001}
13002
13003var MatchState;
13004
13005(function (MatchState) {
13006 MatchState[MatchState["MatchForced"] = 0] = "MatchForced";
13007 MatchState[MatchState["MatchUrl"] = 1] = "MatchUrl";
13008 MatchState[MatchState["MatchPaths"] = 2] = "MatchPaths";
13009 MatchState[MatchState["Excluded"] = 3] = "Excluded";
13010 MatchState[MatchState["NoMatch"] = 4] = "NoMatch";
13011})(MatchState || (MatchState = {}));
13012
13013function Item$7(_ref) {
13014 var url = _ref.url,
13015 icon = _ref.icon,
13016 label = _ref.label,
13017 _ref$subNavigationIte = _ref.subNavigationItems,
13018 subNavigationItems = _ref$subNavigationIte === void 0 ? [] : _ref$subNavigationIte,
13019 secondaryAction = _ref.secondaryAction,
13020 disabled = _ref.disabled,
13021 onClick = _ref.onClick,
13022 accessibilityLabel = _ref.accessibilityLabel,
13023 selectedOverride = _ref.selected,
13024 badge = _ref.badge,
13025 isNew = _ref.new,
13026 matches = _ref.matches,
13027 exactMatch = _ref.exactMatch,
13028 matchPaths = _ref.matchPaths,
13029 excludePaths = _ref.excludePaths;
13030 var i18n = useI18n();
13031
13032 var _useMediaQuery = useMediaQuery(),
13033 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
13034
13035 var _useContext = useContext(NavigationContext),
13036 location = _useContext.location,
13037 onNavigationDismiss = _useContext.onNavigationDismiss;
13038
13039 var _useState = useState(false),
13040 _useState2 = _slicedToArray(_useState, 2),
13041 expanded = _useState2[0],
13042 setExpanded = _useState2[1];
13043
13044 useEffect(function () {
13045 if (!isNavigationCollapsed && expanded) {
13046 setExpanded(false);
13047 }
13048 }, [expanded, isNavigationCollapsed]);
13049 var tabIndex = disabled ? -1 : 0;
13050 var hasNewChild = subNavigationItems.filter(function (subNavigationItem) {
13051 return subNavigationItem.new;
13052 }).length > 0;
13053 var indicatorMarkup = hasNewChild ? React__default.createElement("span", {
13054 className: styles$1d.Indicator
13055 }, React__default.createElement(Indicator, {
13056 pulse: true
13057 })) : null;
13058 var iconMarkup = icon ? React__default.createElement("div", {
13059 className: styles$1d.Icon
13060 }, React__default.createElement(Icon, {
13061 source: icon
13062 })) : null;
13063 var badgeMarkup = null;
13064
13065 if (isNew) {
13066 badgeMarkup = React__default.createElement(Badge, {
13067 status: "new",
13068 size: "small"
13069 }, i18n.translate('Polaris.Badge.STATUS_LABELS.new'));
13070 } else if (typeof badge === 'string') {
13071 badgeMarkup = React__default.createElement(Badge, {
13072 status: "new",
13073 size: "small"
13074 }, badge);
13075 } else {
13076 badgeMarkup = badge;
13077 }
13078
13079 var wrappedBadgeMarkup = badgeMarkup == null ? null : React__default.createElement("div", {
13080 className: styles$1d.Badge
13081 }, badgeMarkup);
13082 var itemContentMarkup = React__default.createElement(Fragment, null, iconMarkup, React__default.createElement("span", {
13083 className: styles$1d.Text
13084 }, label, indicatorMarkup), wrappedBadgeMarkup);
13085
13086 if (url == null) {
13087 var _className = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled']);
13088
13089 return React__default.createElement("li", {
13090 className: styles$1d.ListItem
13091 }, React__default.createElement("button", {
13092 type: "button",
13093 className: _className,
13094 disabled: disabled,
13095 "aria-disabled": disabled,
13096 "aria-label": accessibilityLabel,
13097 onClick: getClickHandler(onClick)
13098 }, itemContentMarkup));
13099 }
13100
13101 var secondaryActionMarkup = secondaryAction && React__default.createElement(UnstyledLink, {
13102 external: true,
13103 url: secondaryAction.url,
13104 className: styles$1d.SecondaryAction,
13105 tabIndex: tabIndex,
13106 "aria-disabled": disabled,
13107 "aria-label": secondaryAction.accessibilityLabel
13108 }, React__default.createElement(Icon, {
13109 source: secondaryAction.icon
13110 }));
13111 var matchState = matchStateForItem({
13112 url,
13113 matches,
13114 exactMatch,
13115 matchPaths,
13116 excludePaths
13117 }, location);
13118 var matchingSubNavigationItems = subNavigationItems.filter(function (item) {
13119 var subMatchState = matchStateForItem(item, location);
13120 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
13121 });
13122 var childIsActive = matchingSubNavigationItems.length > 0;
13123 var selected = selectedOverride == null ? matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths : selectedOverride;
13124 var showExpanded = selected || expanded || childIsActive;
13125 var itemClassName = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled'], selected && subNavigationItems.length === 0 && styles$1d['Item-selected'], showExpanded && styles$1d.subNavigationActive);
13126 var secondaryNavigationMarkup = null;
13127
13128 if (subNavigationItems.length > 0 && showExpanded) {
13129 var longestMatch = matchingSubNavigationItems.sort(function (_ref2, _ref3) {
13130 var firstUrl = _ref2.url;
13131 var secondUrl = _ref3.url;
13132 return secondUrl.length - firstUrl.length;
13133 })[0];
13134 secondaryNavigationMarkup = React__default.createElement("div", {
13135 className: styles$1d.SecondaryNavigation
13136 }, React__default.createElement(Secondary, {
13137 expanded: showExpanded
13138 }, subNavigationItems.map(function (item) {
13139 var label = item.label,
13140 rest = __rest(item, ["label"]);
13141
13142 return React__default.createElement(Item$7, Object.assign({}, rest, {
13143 key: label,
13144 label: label,
13145 matches: item === longestMatch,
13146 onClick: onNavigationDismiss
13147 }));
13148 })));
13149 }
13150
13151 var className = classNames(styles$1d.ListItem, secondaryAction && styles$1d['ListItem-hasAction']);
13152 return React__default.createElement("li", {
13153 className: className
13154 }, React__default.createElement("div", {
13155 className: styles$1d.ItemWrapper
13156 }, React__default.createElement(UnstyledLink, {
13157 url: url,
13158 className: itemClassName,
13159 tabIndex: tabIndex,
13160 "aria-disabled": disabled,
13161 "aria-label": accessibilityLabel,
13162 onClick: getClickHandler(onClick)
13163 }, itemContentMarkup), secondaryActionMarkup), secondaryNavigationMarkup);
13164
13165 function getClickHandler(onClick) {
13166 return function (event) {
13167 var currentTarget = event.currentTarget;
13168
13169 if (currentTarget.getAttribute('href') === location) {
13170 event.preventDefault();
13171 }
13172
13173 if (subNavigationItems && subNavigationItems.length > 0 && isNavigationCollapsed) {
13174 event.preventDefault();
13175 setExpanded(!expanded);
13176 } else if (onNavigationDismiss) {
13177 onNavigationDismiss();
13178
13179 if (onClick && onClick !== onNavigationDismiss) {
13180 onClick();
13181 }
13182
13183 return;
13184 }
13185
13186 if (onClick) {
13187 onClick();
13188 }
13189 };
13190 }
13191}
13192function isNavigationItemActive(navigationItem, currentPath) {
13193 var matchState = matchStateForItem(navigationItem, currentPath);
13194 var matchingSubNavigationItems = navigationItem.subNavigationItems && navigationItem.subNavigationItems.filter(function (item) {
13195 var subMatchState = matchStateForItem(item, currentPath);
13196 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
13197 });
13198 var childIsActive = matchingSubNavigationItems && matchingSubNavigationItems.length > 0;
13199 var selected = matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths;
13200 return selected || childIsActive;
13201}
13202
13203function normalizePathname(pathname) {
13204 var barePathname = pathname.split('?')[0].split('#')[0];
13205 return barePathname.endsWith('/') ? barePathname : "".concat(barePathname, "/");
13206}
13207
13208function safeEqual(location, path) {
13209 return normalizePathname(location) === normalizePathname(path);
13210}
13211
13212function safeStartsWith(location, path) {
13213 return normalizePathname(location).startsWith(normalizePathname(path));
13214}
13215
13216function matchStateForItem(_ref4, location) {
13217 var url = _ref4.url,
13218 matches = _ref4.matches,
13219 exactMatch = _ref4.exactMatch,
13220 matchPaths = _ref4.matchPaths,
13221 excludePaths = _ref4.excludePaths;
13222
13223 if (url == null) {
13224 return MatchState.NoMatch;
13225 }
13226
13227 if (matches) {
13228 return MatchState.MatchForced;
13229 }
13230
13231 if (matches === false || excludePaths && excludePaths.some(function (path) {
13232 return safeStartsWith(location, path);
13233 })) {
13234 return MatchState.Excluded;
13235 }
13236
13237 if (matchPaths && matchPaths.some(function (path) {
13238 return safeStartsWith(location, path);
13239 })) {
13240 return MatchState.MatchPaths;
13241 }
13242
13243 var matchesUrl = exactMatch ? safeEqual(location, url) : safeStartsWith(location, url);
13244 return matchesUrl ? MatchState.MatchUrl : MatchState.NoMatch;
13245}
13246
13247var createAdditionalItemsId = createUniqueIDFactory('AdditionalItems');
13248var Section$5 =
13249/*#__PURE__*/
13250function (_React$Component) {
13251 _inherits(Section, _React$Component);
13252
13253 function Section() {
13254 var _this;
13255
13256 _classCallCheck(this, Section);
13257
13258 _this = _possibleConstructorReturn(this, _getPrototypeOf(Section).apply(this, arguments));
13259 _this.state = {
13260 expanded: false
13261 };
13262 _this.animationFrame = null;
13263
13264 _this.toggleViewAll = function () {
13265 _this.setState(function (_ref) {
13266 var expanded = _ref.expanded;
13267 return {
13268 expanded: !expanded
13269 };
13270 });
13271 };
13272
13273 return _this;
13274 }
13275
13276 _createClass(Section, [{
13277 key: "componentWillUnmount",
13278 value: function componentWillUnmount() {
13279 if (this.animationFrame) {
13280 cancelAnimationFrame(this.animationFrame);
13281 }
13282 }
13283 }, {
13284 key: "render",
13285 value: function render() {
13286 var _this2 = this;
13287
13288 var _this$props = this.props,
13289 title = _this$props.title,
13290 fill = _this$props.fill,
13291 action = _this$props.action,
13292 items = _this$props.items,
13293 rollup = _this$props.rollup,
13294 separator = _this$props.separator;
13295 var expanded = this.state.expanded;
13296 var className = classNames(styles$1d.Section, separator && styles$1d['Section-withSeparator'], fill && styles$1d['Section-fill']);
13297 var actionMarkup = action && React__default.createElement("button", {
13298 type: "button",
13299 className: styles$1d.Action,
13300 "aria-label": action.accessibilityLabel,
13301 onClick: action.onClick
13302 }, React__default.createElement(Icon, {
13303 source: action.icon
13304 }));
13305 var sectionHeadingMarkup = title && React__default.createElement("li", {
13306 className: styles$1d.SectionHeading
13307 }, React__default.createElement("span", {
13308 className: styles$1d.Text
13309 }, title), actionMarkup);
13310 var itemsMarkup = items.map(function (item) {
13311 var onClick = item.onClick,
13312 label = item.label,
13313 subNavigationItems = item.subNavigationItems,
13314 rest = __rest(item, ["onClick", "label", "subNavigationItems"]);
13315
13316 var hasSubNavItems = subNavigationItems != null && subNavigationItems.length > 0;
13317 return React__default.createElement(Item$7, Object.assign({}, rest, {
13318 key: label,
13319 label: label,
13320 subNavigationItems: subNavigationItems,
13321 onClick: _this2.handleClick(onClick, hasSubNavItems)
13322 }));
13323 });
13324 var toggleClassName = classNames(styles$1d.Item, styles$1d.RollupToggle);
13325 var ariaLabel = rollup && (expanded ? rollup.hide : rollup.view);
13326 var toggleRollup = rollup && items.length > rollup.after && React__default.createElement("div", {
13327 className: styles$1d.ListItem,
13328 key: "List Item"
13329 }, React__default.createElement("button", {
13330 type: "button",
13331 className: toggleClassName,
13332 onClick: this.toggleViewAll,
13333 "aria-label": ariaLabel
13334 }, React__default.createElement("span", {
13335 className: styles$1d.Icon
13336 }, React__default.createElement(Icon, {
13337 source: HorizontalDotsMinor
13338 }))));
13339 var activeItemIndex = items.findIndex(function (item) {
13340 if (!rollup) {
13341 return false;
13342 }
13343
13344 return rollup.activePath === item.url || item.url && rollup.activePath.startsWith(item.url) || (item.subNavigationItems ? item.subNavigationItems.some(function (_ref2) {
13345 var itemUrl = _ref2.url;
13346 return rollup.activePath.startsWith(itemUrl);
13347 }) : false);
13348 });
13349 var sectionItems = rollup ? itemsMarkup.slice(0, rollup.after) : itemsMarkup;
13350 var additionalItems = rollup ? itemsMarkup.slice(rollup.after) : [];
13351
13352 if (rollup && activeItemIndex !== -1 && activeItemIndex > rollup.after - 1) {
13353 sectionItems.push.apply(sectionItems, _toConsumableArray(additionalItems.splice(activeItemIndex - rollup.after, 1)));
13354 }
13355
13356 var additionalItemsId = createAdditionalItemsId();
13357 var activeItemsMarkup = rollup && additionalItems.length > 0 && React__default.createElement("li", {
13358 className: styles$1d.RollupSection
13359 }, React__default.createElement(Collapsible, {
13360 id: additionalItemsId,
13361 open: expanded
13362 }, React__default.createElement("ul", {
13363 className: styles$1d.List
13364 }, additionalItems)), toggleRollup);
13365 return React__default.createElement("ul", {
13366 className: className
13367 }, sectionHeadingMarkup, sectionItems, activeItemsMarkup);
13368 }
13369 }, {
13370 key: "handleClick",
13371 value: function handleClick(onClick, hasSubNavItems) {
13372 var _this3 = this;
13373
13374 return function () {
13375 if (onClick) {
13376 onClick();
13377 }
13378
13379 if (_this3.animationFrame) {
13380 cancelAnimationFrame(_this3.animationFrame);
13381 }
13382
13383 if (!hasSubNavItems || !navigationBarCollapsed().matches) {
13384 _this3.animationFrame = requestAnimationFrame(function () {
13385 return _this3.setState({
13386 expanded: false
13387 });
13388 });
13389 }
13390 };
13391 }
13392 }]);
13393
13394 return Section;
13395}(React__default.Component);
13396
13397var Navigation$1 =
13398/*#__PURE__*/
13399function (_React$Component) {
13400 _inherits(Navigation, _React$Component);
13401
13402 function Navigation() {
13403 _classCallCheck(this, Navigation);
13404
13405 return _possibleConstructorReturn(this, _getPrototypeOf(Navigation).apply(this, arguments));
13406 }
13407
13408 _createClass(Navigation, [{
13409 key: "render",
13410 value: function render() {
13411 var _this$props = this.props,
13412 children = _this$props.children,
13413 contextControl = _this$props.contextControl,
13414 location = _this$props.location,
13415 onDismiss = _this$props.onDismiss;
13416 var contextControlMarkup = contextControl && React__default.createElement("div", {
13417 className: styles$1d.ContextControl
13418 }, contextControl);
13419 var context = {
13420 location,
13421 onNavigationDismiss: onDismiss
13422 };
13423 return React__default.createElement(NavigationContext.Provider, {
13424 value: context
13425 }, React__default.createElement(WithinContentContext.Provider, {
13426 value: true
13427 }, React__default.createElement("nav", {
13428 className: styles$1d.Navigation
13429 }, contextControlMarkup, React__default.createElement(Scrollable, {
13430 className: styles$1d.PrimaryNavigation
13431 }, children))));
13432 }
13433 }]);
13434
13435 return Navigation;
13436}(React__default.Component);
13437Navigation$1.Item = Item$7;
13438Navigation$1.Section = Section$5;
13439
13440var EditableTarget;
13441
13442(function (EditableTarget) {
13443 EditableTarget["Input"] = "INPUT";
13444 EditableTarget["Textarea"] = "TEXTAREA";
13445 EditableTarget["Select"] = "SELECT";
13446 EditableTarget["ContentEditable"] = "contenteditable";
13447})(EditableTarget || (EditableTarget = {}));
13448
13449function isInputFocused() {
13450 if (document == null || document.activeElement == null) {
13451 return false;
13452 }
13453
13454 var tagName = document.activeElement.tagName;
13455 return tagName === EditableTarget.Input || tagName === EditableTarget.Textarea || tagName === EditableTarget.Select || document.activeElement.hasAttribute(EditableTarget.ContentEditable);
13456}
13457
13458var styles$1e = {
13459 "Tooltip": "Polaris-Tooltip",
13460 "measuring": "Polaris-Tooltip--measuring",
13461 "positionedAbove": "Polaris-Tooltip--positionedAbove",
13462 "light": "Polaris-Tooltip--light",
13463 "Wrapper": "Polaris-Tooltip__Wrapper",
13464 "Content": "Polaris-Tooltip__Content",
13465 "Label": "Polaris-Tooltip__Label"
13466};
13467
13468var TooltipOverlay =
13469/*#__PURE__*/
13470function (_React$PureComponent) {
13471 _inherits(TooltipOverlay, _React$PureComponent);
13472
13473 function TooltipOverlay() {
13474 var _this;
13475
13476 _classCallCheck(this, TooltipOverlay);
13477
13478 _this = _possibleConstructorReturn(this, _getPrototypeOf(TooltipOverlay).apply(this, arguments));
13479
13480 _this.renderOverlay = function () {
13481 var _this$props = _this.props,
13482 active = _this$props.active,
13483 activator = _this$props.activator,
13484 _this$props$preferred = _this$props.preferredPosition,
13485 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred;
13486 return React__default.createElement(PositionedOverlay, {
13487 active: active,
13488 activator: activator,
13489 preferredPosition: preferredPosition,
13490 render: _this.renderTooltip
13491 });
13492 };
13493
13494 _this.renderTooltip = function (overlayDetails) {
13495 var measuring = overlayDetails.measuring,
13496 desiredHeight = overlayDetails.desiredHeight,
13497 positioning = overlayDetails.positioning;
13498 var _this$props2 = _this.props,
13499 id = _this$props2.id,
13500 children = _this$props2.children,
13501 light = _this$props2.light;
13502 var containerClassName = classNames(styles$1e.Tooltip, light && styles$1e.light, measuring && styles$1e.measuring, positioning === 'above' && styles$1e.positionedAbove);
13503 var contentStyles = measuring ? undefined : {
13504 minHeight: desiredHeight
13505 };
13506 return React__default.createElement("div", Object.assign({
13507 className: containerClassName
13508 }, layer.props), React__default.createElement("div", {
13509 className: styles$1e.Wrapper
13510 }, React__default.createElement("div", {
13511 id: id,
13512 role: "tooltip",
13513 className: styles$1e.Content,
13514 style: contentStyles
13515 }, children)));
13516 };
13517
13518 return _this;
13519 }
13520
13521 _createClass(TooltipOverlay, [{
13522 key: "render",
13523 value: function render() {
13524 var markup = this.props.active ? this.renderOverlay() : null;
13525 return markup;
13526 }
13527 }]);
13528
13529 return TooltipOverlay;
13530}(React__default.PureComponent);
13531
13532var getUniqueID$2 = createUniqueIDFactory('TooltipContent');
13533var Tooltip =
13534/*#__PURE__*/
13535function (_React$PureComponent) {
13536 _inherits(Tooltip, _React$PureComponent);
13537
13538 function Tooltip() {
13539 var _this;
13540
13541 _classCallCheck(this, Tooltip);
13542
13543 _this = _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
13544 _this.state = {
13545 active: Boolean(_this.props.active),
13546 activatorNode: null
13547 };
13548 _this.id = getUniqueID$2();
13549 _this.mouseEntered = false;
13550
13551 _this.setActivator = function (node) {
13552 if (node == null) {
13553 _this.activatorContainer = null;
13554
13555 _this.setState({
13556 activatorNode: null
13557 });
13558
13559 return;
13560 }
13561
13562 _this.setState({
13563 activatorNode: node.firstElementChild
13564 });
13565
13566 _this.activatorContainer = node;
13567 };
13568
13569 _this.handleFocus = function () {
13570 _this.setState({
13571 active: true
13572 });
13573 };
13574
13575 _this.handleBlur = function () {
13576 _this.setState({
13577 active: false
13578 });
13579 };
13580
13581 _this.handleMouseEnter = function () {
13582 _this.mouseEntered = true;
13583
13584 _this.setState({
13585 active: true
13586 });
13587 };
13588
13589 _this.handleMouseLeave = function () {
13590 _this.mouseEntered = false;
13591
13592 _this.setState({
13593 active: false
13594 });
13595 }; // https://github.com/facebook/react/issues/10109
13596 // Mouseenter event not triggered when cursor moves from disabled button
13597
13598
13599 _this.handleMouseEnterFix = function () {
13600 !_this.mouseEntered && _this.handleMouseEnter();
13601 };
13602
13603 return _this;
13604 }
13605
13606 _createClass(Tooltip, [{
13607 key: "componentDidMount",
13608 value: function componentDidMount() {
13609 this.setAccessibilityAttributes();
13610 }
13611 }, {
13612 key: "componentDidUpdate",
13613 value: function componentDidUpdate() {
13614 this.setAccessibilityAttributes();
13615 }
13616 }, {
13617 key: "render",
13618 value: function render() {
13619 var id = this.id;
13620 var _this$props = this.props,
13621 children = _this$props.children,
13622 content = _this$props.content,
13623 light = _this$props.light,
13624 _this$props$preferred = _this$props.preferredPosition,
13625 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred,
13626 _this$props$activator = _this$props.activatorWrapper,
13627 WrapperComponent = _this$props$activator === void 0 ? 'span' : _this$props$activator;
13628 var _this$state = this.state,
13629 active = _this$state.active,
13630 activatorNode = _this$state.activatorNode;
13631 var portal = activatorNode ? React__default.createElement(Portal, {
13632 idPrefix: "tooltip"
13633 }, React__default.createElement(TooltipOverlay, {
13634 id: id,
13635 preferredPosition: preferredPosition,
13636 activator: activatorNode,
13637 active: active,
13638 onClose: noop$9,
13639 light: light
13640 }, React__default.createElement("div", {
13641 className: styles$1e.Label
13642 }, content))) : null;
13643 return React__default.createElement(WrapperComponent, {
13644 onFocus: this.handleFocus,
13645 onBlur: this.handleBlur,
13646 onMouseLeave: this.handleMouseLeave,
13647 onMouseOver: this.handleMouseEnterFix,
13648 ref: this.setActivator
13649 }, children, portal);
13650 }
13651 }, {
13652 key: "setAccessibilityAttributes",
13653 value: function setAccessibilityAttributes() {
13654 var activatorContainer = this.activatorContainer,
13655 id = this.id;
13656
13657 if (activatorContainer == null) {
13658 return;
13659 }
13660
13661 var firstFocusable = findFirstFocusableNode(activatorContainer);
13662 var accessibilityNode = firstFocusable || activatorContainer;
13663 accessibilityNode.tabIndex = 0;
13664 accessibilityNode.setAttribute('aria-describedby', id);
13665 }
13666 }]);
13667
13668 return Tooltip;
13669}(React__default.PureComponent);
13670
13671function noop$9() {}
13672
13673var styles$1f = {
13674 "Pagination": "Polaris-Pagination",
13675 "plain": "Polaris-Pagination--plain",
13676 "Button": "Polaris-Pagination__Button",
13677 "PreviousButton": "Polaris-Pagination__PreviousButton",
13678 "NextButton": "Polaris-Pagination__NextButton",
13679 "Label": "Polaris-Pagination__Label"
13680};
13681
13682function Pagination(_ref) {
13683 var hasNext = _ref.hasNext,
13684 hasPrevious = _ref.hasPrevious,
13685 nextURL = _ref.nextURL,
13686 previousURL = _ref.previousURL,
13687 onNext = _ref.onNext,
13688 onPrevious = _ref.onPrevious,
13689 nextTooltip = _ref.nextTooltip,
13690 previousTooltip = _ref.previousTooltip,
13691 nextKeys = _ref.nextKeys,
13692 previousKeys = _ref.previousKeys,
13693 plain = _ref.plain,
13694 accessibilityLabel = _ref.accessibilityLabel,
13695 label = _ref.label;
13696 var i18n = useI18n();
13697 var node = React__default.createRef();
13698 var navLabel = accessibilityLabel || i18n.translate('Polaris.Pagination.pagination');
13699 var className = classNames(styles$1f.Pagination, plain && styles$1f.plain);
13700 var previousClassName = classNames(styles$1f.Button, !label && styles$1f.PreviousButton);
13701 var nextClassName = classNames(styles$1f.Button, !label && styles$1f.NextButton);
13702 var previousButton = previousURL ? React__default.createElement(UnstyledLink, {
13703 className: previousClassName,
13704 url: previousURL,
13705 onMouseUp: handleMouseUpByBlurring,
13706 "aria-label": i18n.translate('Polaris.Pagination.previous'),
13707 id: "previousURL"
13708 }, React__default.createElement(Icon, {
13709 source: ArrowLeftMinor
13710 })) : React__default.createElement("button", {
13711 onClick: onPrevious,
13712 type: "button",
13713 onMouseUp: handleMouseUpByBlurring,
13714 className: previousClassName,
13715 "aria-label": i18n.translate('Polaris.Pagination.previous'),
13716 disabled: !hasPrevious
13717 }, React__default.createElement(Icon, {
13718 source: ArrowLeftMinor
13719 }));
13720 var nextButton = nextURL ? React__default.createElement(UnstyledLink, {
13721 className: nextClassName,
13722 url: nextURL,
13723 onMouseUp: handleMouseUpByBlurring,
13724 "aria-label": i18n.translate('Polaris.Pagination.next'),
13725 id: "nextURL"
13726 }, React__default.createElement(Icon, {
13727 source: ArrowRightMinor
13728 })) : React__default.createElement("button", {
13729 onClick: onNext,
13730 type: "button",
13731 onMouseUp: handleMouseUpByBlurring,
13732 className: nextClassName,
13733 "aria-label": i18n.translate('Polaris.Pagination.next'),
13734 disabled: !hasNext
13735 }, React__default.createElement(Icon, {
13736 source: ArrowRightMinor
13737 }));
13738 var constructedPrevious = previousTooltip && hasPrevious ? React__default.createElement(Tooltip, {
13739 content: previousTooltip
13740 }, previousButton) : previousButton;
13741 var constructedNext = nextTooltip && hasNext ? React__default.createElement(Tooltip, {
13742 content: nextTooltip
13743 }, nextButton) : nextButton;
13744 var previousButtonEvents = previousKeys && (previousURL || onPrevious) && hasPrevious && previousKeys.map(function (key) {
13745 return React__default.createElement(KeypressListener, {
13746 key: key,
13747 keyCode: key,
13748 handler: previousURL ? handleCallback(clickPaginationLink('previousURL', node)) : handleCallback(onPrevious)
13749 });
13750 });
13751 var nextButtonEvents = nextKeys && (nextURL || onNext) && hasNext && nextKeys.map(function (key) {
13752 return React__default.createElement(KeypressListener, {
13753 key: key,
13754 keyCode: key,
13755 handler: nextURL ? handleCallback(clickPaginationLink('nextURL', node)) : handleCallback(onNext)
13756 });
13757 });
13758 var labelTextMarkup = hasNext && hasPrevious ? React__default.createElement(TextStyle, null, label) : React__default.createElement(TextStyle, {
13759 variation: "subdued"
13760 }, label);
13761 var labelMarkup = label ? React__default.createElement("div", {
13762 className: styles$1f.Label,
13763 "aria-live": "polite"
13764 }, labelTextMarkup) : null;
13765 return React__default.createElement("nav", {
13766 className: className,
13767 "aria-label": navLabel,
13768 ref: node
13769 }, previousButtonEvents, constructedPrevious, labelMarkup, nextButtonEvents, constructedNext);
13770}
13771
13772function clickPaginationLink(id, node) {
13773 return function () {
13774 if (node.current == null) {
13775 return;
13776 }
13777
13778 var link = node.current.querySelector("#".concat(id));
13779
13780 if (link) {
13781 link.click();
13782 }
13783 };
13784}
13785
13786function handleCallback(fn) {
13787 return function () {
13788 if (isInputFocused()) {
13789 return;
13790 }
13791
13792 fn();
13793 };
13794}
13795
13796var styles$1g = {
13797 "Title": "Polaris-Header-Title",
13798 "SubTitle": "Polaris-Header-Title__SubTitle",
13799 "hasThumbnail": "Polaris-Header-Title--hasThumbnail",
13800 "TitleAndSubtitleWrapper": "Polaris-Header-Title__TitleAndSubtitleWrapper",
13801 "TitleWithMetadataWrapper": "Polaris-Header-Title__TitleWithMetadataWrapper",
13802 "TitleMetadata": "Polaris-Header-Title__TitleMetadata"
13803};
13804
13805function Title(_ref) {
13806 var title = _ref.title,
13807 subtitle = _ref.subtitle,
13808 titleMetadata = _ref.titleMetadata,
13809 thumbnail = _ref.thumbnail;
13810 var titleMarkup = title ? createElement("div", {
13811 className: styles$1g.Title
13812 }, createElement(DisplayText, {
13813 size: "large",
13814 element: "h1"
13815 }, title)) : null;
13816 var titleMetadataMarkup = titleMetadata ? createElement("div", {
13817 className: styles$1g.TitleMetadata
13818 }, titleMetadata) : null;
13819 var wrappedTitleMarkup = titleMetadata ? createElement("div", {
13820 className: styles$1g.TitleWithMetadataWrapper
13821 }, titleMarkup, titleMetadataMarkup) : titleMarkup;
13822 var subtitleMarkup = subtitle ? createElement("div", {
13823 className: styles$1g.SubTitle
13824 }, createElement("p", null, subtitle)) : null;
13825 var thumbnailMarkup = thumbnail ? createElement("div", null, thumbnail) : null;
13826 var pageTitleClassName = thumbnail ? classNames(styles$1g.hasThumbnail) : undefined;
13827 return createElement("div", {
13828 className: pageTitleClassName
13829 }, thumbnailMarkup, createElement("div", {
13830 className: styles$1g.TitleAndSubtitleWrapper
13831 }, wrappedTitleMarkup, subtitleMarkup));
13832}
13833
13834var styles$1h = {
13835 "Header": "Polaris-Page-Header",
13836 "separator": "Polaris-Page-Header--separator",
13837 "titleHidden": "Polaris-Page-Header--titleHidden",
13838 "Navigation": "Polaris-Page-Header__Navigation",
13839 "hasActionMenu": "Polaris-Page-Header--hasActionMenu",
13840 "mobileView": "Polaris-Page-Header--mobileView",
13841 "BreadcrumbWrapper": "Polaris-Page-Header__BreadcrumbWrapper",
13842 "PaginationWrapper": "Polaris-Page-Header__PaginationWrapper",
13843 "MainContent": "Polaris-Page-Header__MainContent",
13844 "TitleActionMenuWrapper": "Polaris-Page-Header__TitleActionMenuWrapper",
13845 "hasNavigation": "Polaris-Page-Header--hasNavigation",
13846 "PrimaryActionWrapper": "Polaris-Page-Header__PrimaryActionWrapper",
13847 "ActionMenuWrapper": "Polaris-Page-Header__ActionMenuWrapper"
13848};
13849
13850function Header$2(_ref) {
13851 var title = _ref.title,
13852 subtitle = _ref.subtitle,
13853 titleMetadata = _ref.titleMetadata,
13854 thumbnail = _ref.thumbnail,
13855 _ref$titleHidden = _ref.titleHidden,
13856 titleHidden = _ref$titleHidden === void 0 ? false : _ref$titleHidden,
13857 separator = _ref.separator,
13858 primaryAction = _ref.primaryAction,
13859 pagination = _ref.pagination,
13860 _ref$breadcrumbs = _ref.breadcrumbs,
13861 breadcrumbs = _ref$breadcrumbs === void 0 ? [] : _ref$breadcrumbs,
13862 _ref$secondaryActions = _ref.secondaryActions,
13863 secondaryActions = _ref$secondaryActions === void 0 ? [] : _ref$secondaryActions,
13864 _ref$actionGroups = _ref.actionGroups,
13865 actionGroups = _ref$actionGroups === void 0 ? [] : _ref$actionGroups;
13866
13867 var _useMediaQuery = useMediaQuery(),
13868 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
13869
13870 var breadcrumbMarkup = breadcrumbs.length > 0 ? React__default.createElement("div", {
13871 className: styles$1h.BreadcrumbWrapper
13872 }, React__default.createElement(Breadcrumbs, {
13873 breadcrumbs: breadcrumbs
13874 })) : null;
13875 var paginationMarkup = pagination && !isNavigationCollapsed ? React__default.createElement("div", {
13876 className: styles$1h.PaginationWrapper
13877 }, React__default.createElement(Pagination, Object.assign({}, pagination, {
13878 plain: true
13879 }))) : null;
13880 var navigationMarkup = breadcrumbMarkup || paginationMarkup ? React__default.createElement("div", {
13881 className: styles$1h.Navigation
13882 }, breadcrumbMarkup, paginationMarkup) : null;
13883 var pageTitleMarkup = React__default.createElement(Title, {
13884 title: title,
13885 subtitle: subtitle,
13886 titleMetadata: titleMetadata,
13887 thumbnail: thumbnail
13888 });
13889 var primary = primaryAction && (primaryAction.primary === undefined ? true : primaryAction.primary);
13890 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
13891 className: styles$1h.PrimaryActionWrapper
13892 }, buttonsFrom(primaryAction, {
13893 primary
13894 })) : null;
13895 var actionMenuMarkup = secondaryActions.length > 0 || hasGroupsWithActions(actionGroups) ? React__default.createElement("div", {
13896 className: styles$1h.ActionMenuWrapper
13897 }, React__default.createElement(ActionMenu, {
13898 actions: secondaryActions,
13899 groups: actionGroups,
13900 rollup: isNavigationCollapsed
13901 })) : null;
13902 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);
13903 return React__default.createElement("div", {
13904 className: headerClassNames
13905 }, navigationMarkup, React__default.createElement("div", {
13906 className: styles$1h.MainContent
13907 }, React__default.createElement("div", {
13908 className: styles$1h.TitleActionMenuWrapper
13909 }, pageTitleMarkup, actionMenuMarkup), primaryActionMarkup));
13910}
13911
13912var styles$1i = {
13913 "Page": "Polaris-Page",
13914 "fullWidth": "Polaris-Page--fullWidth",
13915 "narrowWidth": "Polaris-Page--narrowWidth",
13916 "Content": "Polaris-Page__Content"
13917};
13918
13919var APP_BRIDGE_PROPS$1 = ['title', 'breadcrumbs', 'secondaryActions', 'actionGroups', 'primaryAction'];
13920
13921var Page =
13922/*#__PURE__*/
13923function (_React$PureComponent) {
13924 _inherits(Page, _React$PureComponent);
13925
13926 function Page() {
13927 _classCallCheck(this, Page);
13928
13929 return _possibleConstructorReturn(this, _getPrototypeOf(Page).apply(this, arguments));
13930 }
13931
13932 _createClass(Page, [{
13933 key: "componentDidMount",
13934 value: function componentDidMount() {
13935 if (this.delegateToAppbridge === false || !this.props.polaris.appBridge) {
13936 return;
13937 }
13938
13939 var transformedProps = this.transformProps();
13940 if (!transformedProps) return; // eslint-disable-next-line no-console
13941
13942 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');
13943 this.titlebar = TitleBar.create(this.props.polaris.appBridge, transformedProps);
13944 }
13945 }, {
13946 key: "componentDidUpdate",
13947 value: function componentDidUpdate(prevProps) {
13948 if (this.titlebar == null || this.delegateToAppbridge === false) {
13949 return;
13950 }
13951
13952 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS$1);
13953 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS$1);
13954
13955 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps)) {
13956 var transformedProps = this.transformProps();
13957 if (!transformedProps) return;
13958 this.titlebar.unsubscribe();
13959 this.titlebar.set(transformedProps);
13960 }
13961 }
13962 }, {
13963 key: "componentWillUnmount",
13964 value: function componentWillUnmount() {
13965 if (this.titlebar == null || this.delegateToAppbridge === false) {
13966 return;
13967 }
13968
13969 this.titlebar.unsubscribe();
13970 }
13971 }, {
13972 key: "render",
13973 value: function render() {
13974 var _a = this.props,
13975 children = _a.children,
13976 fullWidth = _a.fullWidth,
13977 narrowWidth = _a.narrowWidth,
13978 singleColumn = _a.singleColumn,
13979 rest = __rest(_a, ["children", "fullWidth", "narrowWidth", "singleColumn"]);
13980
13981 if (singleColumn) {
13982 // eslint-disable-next-line no-console
13983 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
13984 }
13985
13986 var className = classNames(styles$1i.Page, fullWidth && styles$1i.fullWidth, (narrowWidth || singleColumn) && styles$1i.narrowWidth);
13987 var headerMarkup = this.delegateToAppbridge || this.hasHeaderContent() === false ? null : React__default.createElement(Header$2, rest);
13988 return React__default.createElement("div", {
13989 className: className
13990 }, headerMarkup, React__default.createElement("div", {
13991 className: styles$1i.Content
13992 }, children));
13993 }
13994 }, {
13995 key: "hasHeaderContent",
13996 value: function hasHeaderContent() {
13997 var _this$props = this.props,
13998 title = _this$props.title,
13999 primaryAction = _this$props.primaryAction,
14000 secondaryActions = _this$props.secondaryActions,
14001 actionGroups = _this$props.actionGroups,
14002 breadcrumbs = _this$props.breadcrumbs;
14003 return title != null && title !== '' || primaryAction != null || secondaryActions != null && secondaryActions.length > 0 || actionGroups != null && actionGroups.length > 0 || breadcrumbs != null && breadcrumbs.length > 0;
14004 }
14005 }, {
14006 key: "transformProps",
14007 value: function transformProps() {
14008 var appBridge = this.props.polaris.appBridge;
14009 if (!appBridge) return;
14010 var _this$props2 = this.props,
14011 title = _this$props2.title,
14012 primaryAction = _this$props2.primaryAction,
14013 secondaryActions = _this$props2.secondaryActions,
14014 actionGroups = _this$props2.actionGroups;
14015 return {
14016 title,
14017 buttons: transformActions(appBridge, {
14018 primaryAction,
14019 secondaryActions,
14020 actionGroups
14021 }),
14022 breadcrumbs: this.transformBreadcrumbs()
14023 };
14024 }
14025 }, {
14026 key: "transformBreadcrumbs",
14027 value: function transformBreadcrumbs() {
14028 var appBridge = this.props.polaris.appBridge;
14029 if (!appBridge) return;
14030 var breadcrumbs = this.props.breadcrumbs;
14031
14032 if (breadcrumbs != null && breadcrumbs.length > 0) {
14033 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
14034 var button = Button$1.create(appBridge, {
14035 label: breadcrumb.content || ''
14036 });
14037 var callback = !('url' in breadcrumb) ? breadcrumb.onAction : generateRedirect(appBridge, breadcrumb.url, breadcrumb.target);
14038
14039 if (callback != null) {
14040 button.subscribe(Button$1.Action.CLICK, callback);
14041 }
14042
14043 return button;
14044 } else {
14045 return undefined;
14046 }
14047 }
14048 }, {
14049 key: "delegateToAppbridge",
14050 get: function get() {
14051 var _this$props3 = this.props,
14052 appBridge = _this$props3.polaris.appBridge,
14053 _this$props3$forceRen = _this$props3.forceRender,
14054 forceRender = _this$props3$forceRen === void 0 ? false : _this$props3$forceRen;
14055 return appBridge != null && forceRender === false;
14056 }
14057 }]);
14058
14059 return Page;
14060}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
14061// eslint-disable-next-line import/no-default-export
14062
14063
14064var Page$1 = withAppProvider()(Page);
14065
14066var styles$1j = {
14067 "PageActions": "Polaris-PageActions"
14068};
14069
14070function PageActions(_ref) {
14071 var primaryAction = _ref.primaryAction,
14072 secondaryActions = _ref.secondaryActions;
14073 var primaryActionMarkup = primaryAction ? buttonsFrom(primaryAction, {
14074 primary: true
14075 }) : null;
14076 var secondaryActionsMarkup = secondaryActions ? React__default.createElement(ButtonGroup, null, buttonsFrom(secondaryActions)) : null;
14077 var distribution = secondaryActionsMarkup ? 'equalSpacing' : 'trailing';
14078 return React__default.createElement("div", {
14079 className: styles$1j.PageActions
14080 }, React__default.createElement(Stack, {
14081 distribution: distribution,
14082 spacing: "tight"
14083 }, secondaryActionsMarkup, primaryActionMarkup));
14084}
14085
14086var defaultMediaQuery = {
14087 isNavigationCollapsed: false
14088};
14089function PolarisTestProvider(_ref) {
14090 var strict = _ref.strict,
14091 children = _ref.children,
14092 i18n = _ref.i18n,
14093 appBridge = _ref.appBridge,
14094 link = _ref.link,
14095 _ref$theme = _ref.theme,
14096 theme = _ref$theme === void 0 ? {} : _ref$theme,
14097 mediaQuery = _ref.mediaQuery,
14098 _ref$features = _ref.features,
14099 features = _ref$features === void 0 ? {} : _ref$features,
14100 frame = _ref.frame;
14101 var Wrapper = strict ? React__default.StrictMode : React__default.Fragment;
14102 var intl = new I18n(i18n || {});
14103 var scrollLockManager = new ScrollLockManager();
14104 var stickyManager = new StickyManager();
14105 var uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory); // This typing is odd, but as appBridge is deprecated and going away in v5
14106 // I'm not that worried about it
14107
14108 var appBridgeApp = appBridge;
14109 var _features$unstableGlo = features.unstableGlobalTheming,
14110 unstableGlobalTheming = _features$unstableGlo === void 0 ? false : _features$unstableGlo;
14111 var customProperties = unstableGlobalTheming ? buildCustomProperties(theme, unstableGlobalTheming) : undefined;
14112 var mergedTheme = buildThemeContext(theme, customProperties);
14113 var mergedFrame = createFrameContext(frame);
14114 var mergedMediaQuery = merge(defaultMediaQuery, mediaQuery);
14115 return React__default.createElement(Wrapper, null, React__default.createElement(FeaturesContext.Provider, {
14116 value: features
14117 }, React__default.createElement(I18nContext.Provider, {
14118 value: intl
14119 }, React__default.createElement(ScrollLockManagerContext.Provider, {
14120 value: scrollLockManager
14121 }, React__default.createElement(StickyManagerContext.Provider, {
14122 value: stickyManager
14123 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
14124 value: uniqueIdFactory
14125 }, React__default.createElement(AppBridgeContext.Provider, {
14126 value: appBridgeApp
14127 }, React__default.createElement(LinkContext.Provider, {
14128 value: link
14129 }, React__default.createElement(ThemeContext.Provider, {
14130 value: mergedTheme
14131 }, React__default.createElement(MediaQueryContext.Provider, {
14132 value: mergedMediaQuery
14133 }, React__default.createElement(FrameContext.Provider, {
14134 value: mergedFrame
14135 }, children)))))))))));
14136}
14137
14138function noop$a() {}
14139
14140function createFrameContext() {
14141 var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
14142 _ref2$showToast = _ref2.showToast,
14143 showToast = _ref2$showToast === void 0 ? noop$a : _ref2$showToast,
14144 _ref2$hideToast = _ref2.hideToast,
14145 hideToast = _ref2$hideToast === void 0 ? noop$a : _ref2$hideToast,
14146 _ref2$setContextualSa = _ref2.setContextualSaveBar,
14147 setContextualSaveBar = _ref2$setContextualSa === void 0 ? noop$a : _ref2$setContextualSa,
14148 _ref2$removeContextua = _ref2.removeContextualSaveBar,
14149 removeContextualSaveBar = _ref2$removeContextua === void 0 ? noop$a : _ref2$removeContextua,
14150 _ref2$startLoading = _ref2.startLoading,
14151 startLoading = _ref2$startLoading === void 0 ? noop$a : _ref2$startLoading,
14152 _ref2$stopLoading = _ref2.stopLoading,
14153 stopLoading = _ref2$stopLoading === void 0 ? noop$a : _ref2$stopLoading;
14154
14155 return {
14156 showToast,
14157 hideToast,
14158 setContextualSaveBar,
14159 removeContextualSaveBar,
14160 startLoading,
14161 stopLoading
14162 };
14163}
14164
14165var styles$1k = {
14166 "ProgressBar": "Polaris-ProgressBar",
14167 "sizeSmall": "Polaris-ProgressBar--sizeSmall",
14168 "sizeMedium": "Polaris-ProgressBar--sizeMedium",
14169 "sizeLarge": "Polaris-ProgressBar--sizeLarge",
14170 "Indicator": "Polaris-ProgressBar__Indicator",
14171 "fillup": "Polaris-ProgressBar--fillup",
14172 "Progress": "Polaris-ProgressBar__Progress",
14173 "Label": "Polaris-ProgressBar__Label"
14174};
14175
14176function ProgressBar(_ref) {
14177 var _ref$progress = _ref.progress,
14178 progress = _ref$progress === void 0 ? 0 : _ref$progress,
14179 _ref$size = _ref.size,
14180 size = _ref$size === void 0 ? 'medium' : _ref$size;
14181 var i18n = useI18n();
14182 var className = classNames(styles$1k.ProgressBar, size && styles$1k[variationName('size', size)]);
14183 var warningMessage = i18n.translate(progress < 0 ? 'Polaris.ProgressBar.negativeWarningMessage' : 'Polaris.ProgressBar.exceedWarningMessage', {
14184 progress
14185 });
14186 var parsedProgress = parseProgress(progress, warningMessage);
14187 return React__default.createElement("div", {
14188 className: className
14189 }, React__default.createElement("progress", {
14190 className: styles$1k.Progress,
14191 value: parsedProgress,
14192 max: "100"
14193 }), React__default.createElement("div", {
14194 className: styles$1k.Indicator,
14195 style: {
14196 width: "".concat(parsedProgress, "%")
14197 }
14198 }, React__default.createElement("span", {
14199 className: styles$1k.Label
14200 }, parsedProgress, "%")));
14201}
14202
14203function parseProgress(progress, warningMessage) {
14204 var progressWidth;
14205
14206 if (progress < 0) {
14207 if (process.env.NODE_ENV === 'development') {
14208 // eslint-disable-next-line no-console
14209 console.warn(warningMessage);
14210 }
14211
14212 progressWidth = 0;
14213 } else if (progress > 100) {
14214 if (process.env.NODE_ENV === 'development') {
14215 // eslint-disable-next-line no-console
14216 console.warn(warningMessage);
14217 }
14218
14219 progressWidth = 100;
14220 } else {
14221 progressWidth = progress;
14222 }
14223
14224 return progressWidth;
14225}
14226
14227function invertNumber(number) {
14228 if (Math.sign(number) === 1) {
14229 return -Math.abs(number);
14230 } else if (Math.sign(number) === -1) {
14231 return Math.abs(number);
14232 } else {
14233 return 0;
14234 }
14235}
14236
14237var CSS_VAR_PREFIX = '--Polaris-RangeSlider-';
14238var RangeSliderDefault;
14239
14240(function (RangeSliderDefault) {
14241 RangeSliderDefault[RangeSliderDefault["Min"] = 0] = "Min";
14242 RangeSliderDefault[RangeSliderDefault["Max"] = 100] = "Max";
14243 RangeSliderDefault[RangeSliderDefault["Step"] = 1] = "Step";
14244})(RangeSliderDefault || (RangeSliderDefault = {}));
14245
14246var styles$1l = {
14247 "Wrapper": "Polaris-RangeSlider-DualThumb__Wrapper",
14248 "TrackWrapper": "Polaris-RangeSlider-DualThumb__TrackWrapper",
14249 "disabled": "Polaris-RangeSlider-DualThumb--disabled",
14250 "Track": "Polaris-RangeSlider-DualThumb__Track",
14251 "error": "Polaris-RangeSlider-DualThumb--error",
14252 "Thumbs": "Polaris-RangeSlider-DualThumb__Thumbs",
14253 "Prefix": "Polaris-RangeSlider-DualThumb__Prefix",
14254 "Suffix": "Polaris-RangeSlider-DualThumb__Suffix",
14255 "Output": "Polaris-RangeSlider-DualThumb__Output",
14256 "OutputBubble": "Polaris-RangeSlider-DualThumb__OutputBubble",
14257 "OutputText": "Polaris-RangeSlider-DualThumb__OutputText"
14258};
14259
14260var Control;
14261
14262(function (Control) {
14263 Control[Control["Lower"] = 0] = "Lower";
14264 Control[Control["Upper"] = 1] = "Upper";
14265})(Control || (Control = {}));
14266
14267var THUMB_SIZE = 24;
14268var DualThumb =
14269/*#__PURE__*/
14270function (_React$Component) {
14271 _inherits(DualThumb, _React$Component);
14272
14273 function DualThumb() {
14274 var _this;
14275
14276 _classCallCheck(this, DualThumb);
14277
14278 _this = _possibleConstructorReturn(this, _getPrototypeOf(DualThumb).apply(this, arguments));
14279 _this.state = {
14280 value: sanitizeValue(_this.props.value, _this.props.min, _this.props.max, _this.props.step),
14281 trackWidth: 0,
14282 trackLeft: 0
14283 };
14284 _this.track = React__default.createRef();
14285 _this.trackWrapper = React__default.createRef();
14286 _this.thumbLower = React__default.createRef();
14287 _this.thumbUpper = React__default.createRef();
14288 _this.setTrackPosition = debounce(function () {
14289 if (_this.track.current) {
14290 var _this$track$current$g = _this.track.current.getBoundingClientRect(),
14291 width = _this$track$current$g.width,
14292 left = _this$track$current$g.left;
14293
14294 var adjustedTrackWidth = width - THUMB_SIZE;
14295 var adjustedTrackLeft = left + THUMB_SIZE / 2;
14296
14297 _this.setState({
14298 trackWidth: adjustedTrackWidth,
14299 trackLeft: adjustedTrackLeft
14300 });
14301 }
14302 }, 40, {
14303 leading: true,
14304 trailing: true,
14305 maxWait: 40
14306 });
14307
14308 _this.handleMouseDownThumbLower = function (event) {
14309 if (event.button !== 0 || _this.props.disabled) return;
14310 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
14311 event.stopPropagation();
14312 };
14313
14314 _this.handleMouseMoveThumbLower = function (event) {
14315 var valueUpper = _this.state.value[1];
14316
14317 _this.setValue([_this.actualXPosition(event.clientX), valueUpper], Control.Upper);
14318 };
14319
14320 _this.handleTouchStartThumbLower = function (event) {
14321 if (_this.props.disabled) return;
14322 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
14323 event.stopPropagation();
14324 };
14325
14326 _this.handleTouchMoveThumbLower = function (event) {
14327 event.preventDefault();
14328 var valueUpper = _this.state.value[1];
14329
14330 _this.setValue([_this.actualXPosition(event.touches[0].clientX), valueUpper], Control.Upper);
14331 };
14332
14333 _this.handleMouseDownThumbUpper = function (event) {
14334 if (event.button !== 0 || _this.props.disabled) return;
14335 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
14336 event.stopPropagation();
14337 };
14338
14339 _this.handleMouseMoveThumbUpper = function (event) {
14340 var valueLower = _this.state.value[0];
14341
14342 _this.setValue([valueLower, _this.actualXPosition(event.clientX)], Control.Lower);
14343 };
14344
14345 _this.handleTouchStartThumbUpper = function (event) {
14346 if (_this.props.disabled) return;
14347 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
14348 event.stopPropagation();
14349 };
14350
14351 _this.handleTouchMoveThumbUpper = function (event) {
14352 event.preventDefault();
14353 var valueLower = _this.state.value[0];
14354
14355 _this.setValue([valueLower, _this.actualXPosition(event.touches[0].clientX)], Control.Lower);
14356 };
14357
14358 _this.handleKeypressLower = function (event) {
14359 if (_this.props.disabled) return;
14360
14361 var _assertThisInitialize = _assertThisInitialized(_this),
14362 incrementValueLower = _assertThisInitialize.incrementValueLower,
14363 decrementValueLower = _assertThisInitialize.decrementValueLower;
14364
14365 var handlerMap = {
14366 [Key.UpArrow]: incrementValueLower,
14367 [Key.RightArrow]: incrementValueLower,
14368 [Key.DownArrow]: decrementValueLower,
14369 [Key.LeftArrow]: decrementValueLower
14370 };
14371 var handler = handlerMap[event.keyCode];
14372
14373 if (handler != null) {
14374 event.preventDefault();
14375 event.stopPropagation();
14376 handler();
14377 }
14378 };
14379
14380 _this.handleKeypressUpper = function (event) {
14381 if (_this.props.disabled) return;
14382
14383 var _assertThisInitialize2 = _assertThisInitialized(_this),
14384 incrementValueUpper = _assertThisInitialize2.incrementValueUpper,
14385 decrementValueUpper = _assertThisInitialize2.decrementValueUpper;
14386
14387 var handlerMap = {
14388 [Key.UpArrow]: incrementValueUpper,
14389 [Key.RightArrow]: incrementValueUpper,
14390 [Key.DownArrow]: decrementValueUpper,
14391 [Key.LeftArrow]: decrementValueUpper
14392 };
14393 var handler = handlerMap[event.keyCode];
14394
14395 if (handler != null) {
14396 event.preventDefault();
14397 event.stopPropagation();
14398 handler();
14399 }
14400 };
14401
14402 _this.incrementValueLower = function () {
14403 _this.setValue([_this.state.value[0] + _this.props.step, _this.state.value[1]], Control.Upper);
14404 };
14405
14406 _this.decrementValueLower = function () {
14407 _this.setValue([_this.state.value[0] - _this.props.step, _this.state.value[1]], Control.Upper);
14408 };
14409
14410 _this.incrementValueUpper = function () {
14411 _this.setValue([_this.state.value[0], _this.state.value[1] + _this.props.step], Control.Lower);
14412 };
14413
14414 _this.decrementValueUpper = function () {
14415 _this.setValue([_this.state.value[0], _this.state.value[1] - _this.props.step], Control.Lower);
14416 };
14417
14418 _this.dispatchValue = function () {
14419 var _this$props = _this.props,
14420 onChange = _this$props.onChange,
14421 id = _this$props.id;
14422 var value = _this.state.value;
14423 onChange(value, id);
14424 };
14425
14426 _this.setValue = function (dirtyValue, control) {
14427 var _assertThisInitialize3 = _assertThisInitialized(_this),
14428 _assertThisInitialize4 = _assertThisInitialize3.props,
14429 min = _assertThisInitialize4.min,
14430 max = _assertThisInitialize4.max,
14431 step = _assertThisInitialize4.step,
14432 value = _assertThisInitialize3.state.value;
14433
14434 var sanitizedValue = sanitizeValue(dirtyValue, min, max, step, control);
14435
14436 if (isEqual(sanitizedValue, value) === false) {
14437 _this.setState({
14438 value: sanitizedValue
14439 }, _this.dispatchValue);
14440 }
14441 };
14442
14443 _this.handleMouseDownTrack = function (event) {
14444 if (event.button !== 0 || _this.props.disabled) return;
14445 event.preventDefault();
14446
14447 var clickXPosition = _this.actualXPosition(event.clientX);
14448
14449 var value = _this.state.value;
14450 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
14451 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
14452
14453 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
14454 _this.setValue([clickXPosition, value[1]], Control.Upper);
14455
14456 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
14457
14458 if (_this.thumbLower.current != null) {
14459 _this.thumbLower.current.focus();
14460 }
14461 } else {
14462 _this.setValue([value[0], clickXPosition], Control.Lower);
14463
14464 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
14465
14466 if (_this.thumbUpper.current != null) {
14467 _this.thumbUpper.current.focus();
14468 }
14469 }
14470 };
14471
14472 _this.handleTouchStartTrack = function (event) {
14473 if (_this.props.disabled) return;
14474 event.preventDefault();
14475
14476 var clickXPosition = _this.actualXPosition(event.touches[0].clientX);
14477
14478 var value = _this.state.value;
14479 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
14480 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
14481
14482 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
14483 _this.setValue([clickXPosition, value[1]], Control.Upper);
14484
14485 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
14486
14487 if (_this.thumbLower.current != null) {
14488 _this.thumbLower.current.focus();
14489 }
14490 } else {
14491 _this.setValue([value[0], clickXPosition], Control.Lower);
14492
14493 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
14494
14495 if (_this.thumbUpper.current != null) {
14496 _this.thumbUpper.current.focus();
14497 }
14498 }
14499 };
14500
14501 _this.actualXPosition = function (dirtyXPosition) {
14502 if (_this.track.current) {
14503 var _this$props2 = _this.props,
14504 min = _this$props2.min,
14505 max = _this$props2.max;
14506 var _this$state = _this.state,
14507 trackLeft = _this$state.trackLeft,
14508 trackWidth = _this$state.trackWidth;
14509 var relativeX = dirtyXPosition - trackLeft;
14510 var percentageOfTrack = relativeX / trackWidth;
14511 return percentageOfTrack * (max - min);
14512 } else {
14513 return 0;
14514 }
14515 };
14516
14517 return _this;
14518 }
14519
14520 _createClass(DualThumb, [{
14521 key: "componentDidMount",
14522 value: function componentDidMount() {
14523 this.setTrackPosition();
14524
14525 if (this.trackWrapper.current != null) {
14526 addEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack, {
14527 passive: false
14528 });
14529 }
14530 }
14531 }, {
14532 key: "componentWillUnmount",
14533 value: function componentWillUnmount() {
14534 if (this.trackWrapper.current != null) {
14535 removeEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack);
14536 }
14537 }
14538 }, {
14539 key: "render",
14540 value: function render() {
14541 var _this$props3 = this.props,
14542 id = _this$props3.id,
14543 min = _this$props3.min,
14544 max = _this$props3.max,
14545 prefix = _this$props3.prefix,
14546 suffix = _this$props3.suffix,
14547 disabled = _this$props3.disabled,
14548 output = _this$props3.output,
14549 error = _this$props3.error,
14550 onFocus = _this$props3.onFocus,
14551 onBlur = _this$props3.onBlur,
14552 label = _this$props3.label,
14553 labelAction = _this$props3.labelAction,
14554 labelHidden = _this$props3.labelHidden,
14555 helpText = _this$props3.helpText;
14556 var value = this.state.value;
14557 var idLower = id;
14558 var idUpper = "".concat(id, "Upper");
14559 var describedBy = [];
14560
14561 if (error) {
14562 describedBy.push("".concat(id, "Error"));
14563 }
14564
14565 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
14566 var trackWrapperClassName = classNames(styles$1l.TrackWrapper, error && styles$1l.error, disabled && styles$1l.disabled);
14567 var thumbLowerClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbLower, disabled && styles$1l.disabled);
14568 var thumbUpperClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbUpper, disabled && styles$1l.disabled);
14569 var trackWidth = this.state.trackWidth;
14570 var range = max - min;
14571 var leftPositionThumbLower = value[0] / range * trackWidth;
14572 var leftPositionThumbUpper = value[1] / range * trackWidth;
14573 var outputLowerClassName = classNames(styles$1l.Output, styles$1l.OutputLower);
14574 var outputMarkupLower = !disabled && output ? React__default.createElement("output", {
14575 htmlFor: idLower,
14576 className: outputLowerClassName,
14577 style: {
14578 left: "".concat(leftPositionThumbLower, "px")
14579 }
14580 }, React__default.createElement("div", {
14581 className: styles$1l.OutputBubble
14582 }, React__default.createElement("span", {
14583 className: styles$1l.OutputText
14584 }, value[0]))) : null;
14585 var outputUpperClassName = classNames(styles$1l.Output, styles$1l.OutputUpper);
14586 var outputMarkupUpper = !disabled && output ? React__default.createElement("output", {
14587 htmlFor: idUpper,
14588 className: outputUpperClassName,
14589 style: {
14590 left: "".concat(leftPositionThumbUpper, "px")
14591 }
14592 }, React__default.createElement("div", {
14593 className: styles$1l.OutputBubble
14594 }, React__default.createElement("span", {
14595 className: styles$1l.OutputText
14596 }, value[1]))) : null;
14597 var cssVars = {
14598 ["".concat(CSS_VAR_PREFIX, "progress-lower")]: "".concat(leftPositionThumbLower, "px"),
14599 ["".concat(CSS_VAR_PREFIX, "progress-upper")]: "".concat(leftPositionThumbUpper, "px")
14600 };
14601 var prefixMarkup = prefix && React__default.createElement("div", {
14602 className: styles$1l.Prefix
14603 }, prefix);
14604 var suffixMarkup = suffix && React__default.createElement("div", {
14605 className: styles$1l.Suffix
14606 }, suffix);
14607 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Labelled, {
14608 id: id,
14609 label: label,
14610 error: error,
14611 action: labelAction,
14612 labelHidden: labelHidden,
14613 helpText: helpText
14614 }, React__default.createElement("div", {
14615 className: styles$1l.Wrapper
14616 }, prefixMarkup, React__default.createElement("div", {
14617 className: trackWrapperClassName,
14618 onMouseDown: this.handleMouseDownTrack,
14619 ref: this.trackWrapper
14620 }, React__default.createElement("div", {
14621 className: styles$1l.Track,
14622 style: cssVars,
14623 ref: this.track
14624 }), React__default.createElement("button", {
14625 id: idLower,
14626 className: thumbLowerClassName,
14627 style: {
14628 left: "".concat(leftPositionThumbLower, "px")
14629 },
14630 role: "slider",
14631 "aria-disabled": disabled,
14632 "aria-valuemin": min,
14633 "aria-valuemax": max,
14634 "aria-valuenow": value[0],
14635 "aria-invalid": Boolean(error),
14636 "aria-describedby": ariaDescribedBy,
14637 "aria-labelledby": labelID(id),
14638 onFocus: onFocus,
14639 onBlur: onBlur,
14640 onKeyDown: this.handleKeypressLower,
14641 onMouseDown: this.handleMouseDownThumbLower,
14642 onTouchStart: this.handleTouchStartThumbLower,
14643 ref: this.thumbLower
14644 }), outputMarkupLower, React__default.createElement("button", {
14645 id: idUpper,
14646 className: thumbUpperClassName,
14647 style: {
14648 left: "".concat(leftPositionThumbUpper, "px")
14649 },
14650 role: "slider",
14651 "aria-disabled": disabled,
14652 "aria-valuemin": min,
14653 "aria-valuemax": max,
14654 "aria-valuenow": value[1],
14655 "aria-invalid": Boolean(error),
14656 "aria-describedby": ariaDescribedBy,
14657 "aria-labelledby": labelID(id),
14658 onFocus: onFocus,
14659 onBlur: onBlur,
14660 onKeyDown: this.handleKeypressUpper,
14661 onMouseDown: this.handleMouseDownThumbUpper,
14662 onTouchStart: this.handleTouchStartThumbUpper,
14663 ref: this.thumbUpper
14664 }), outputMarkupUpper), suffixMarkup)), React__default.createElement(EventListener, {
14665 event: "resize",
14666 handler: this.setTrackPosition
14667 }));
14668 }
14669 }], [{
14670 key: "getDerivedStateFromProps",
14671 value: function getDerivedStateFromProps(props, state) {
14672 var min = props.min,
14673 step = props.step,
14674 max = props.max,
14675 value = props.value,
14676 onChange = props.onChange,
14677 id = props.id;
14678 var prevValue = state.prevValue;
14679
14680 if (isEqual(prevValue, value)) {
14681 return null;
14682 }
14683
14684 var sanitizedValue = sanitizeValue(value, min, max, step);
14685
14686 if (!isEqual(value, sanitizedValue)) {
14687 onChange(sanitizedValue, id);
14688 }
14689
14690 return {
14691 prevValue: value,
14692 value: sanitizedValue
14693 };
14694 }
14695 }]);
14696
14697 return DualThumb;
14698}(React__default.Component);
14699
14700function registerMouseMoveHandler(handler) {
14701 addEventListener(document, 'mousemove', handler);
14702 addEventListener(document, 'mouseup', function () {
14703 removeEventListener(document, 'mousemove', handler);
14704 }, {
14705 once: true
14706 });
14707}
14708
14709function registerTouchMoveHandler(handler) {
14710 var removeHandler = function removeHandler() {
14711 removeEventListener(document, 'touchmove', handler);
14712 removeEventListener(document, 'touchend', removeHandler);
14713 removeEventListener(document, 'touchcancel', removeHandler);
14714 };
14715
14716 addEventListener(document, 'touchmove', handler, {
14717 passive: false
14718 });
14719 addEventListener(document, 'touchend', removeHandler, {
14720 once: true
14721 });
14722 addEventListener(document, 'touchcancel', removeHandler, {
14723 once: true
14724 });
14725}
14726
14727function sanitizeValue(value, min, max, step) {
14728 var control = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : Control.Upper;
14729 var upperValue = inBoundsUpper(roundedToStep(value[1]));
14730 var lowerValue = inBoundsLower(roundedToStep(value[0]));
14731 var maxLowerValue = upperValue - step;
14732 var minUpperValue = lowerValue + step;
14733
14734 if (control === Control.Upper && lowerValue > maxLowerValue) {
14735 lowerValue = maxLowerValue;
14736 } else if (control === Control.Lower && upperValue < minUpperValue) {
14737 upperValue = minUpperValue;
14738 }
14739
14740 return [lowerValue, upperValue];
14741
14742 function inBoundsUpper(value) {
14743 var lowerMin = min + step;
14744
14745 if (value < lowerMin) {
14746 return lowerMin;
14747 } else if (value > max) {
14748 return max;
14749 } else {
14750 return value;
14751 }
14752 }
14753
14754 function inBoundsLower(value) {
14755 var upperMax = max - step;
14756
14757 if (value < min) {
14758 return min;
14759 } else if (value > upperMax) {
14760 return upperMax;
14761 } else {
14762 return value;
14763 }
14764 }
14765
14766 function roundedToStep(value) {
14767 return Math.round(value / step) * step;
14768 }
14769}
14770
14771function clamp(number, min, max) {
14772 if (number < min) return min;
14773 if (number > max) return max;
14774 return number;
14775}
14776
14777var styles$1m = {
14778 "SingleThumb": "Polaris-RangeSlider-SingleThumb",
14779 "disabled": "Polaris-RangeSlider-SingleThumb--disabled",
14780 "InputWrapper": "Polaris-RangeSlider-SingleThumb__InputWrapper",
14781 "Prefix": "Polaris-RangeSlider-SingleThumb__Prefix",
14782 "Suffix": "Polaris-RangeSlider-SingleThumb__Suffix",
14783 "Input": "Polaris-RangeSlider-SingleThumb__Input",
14784 "error": "Polaris-RangeSlider-SingleThumb--error",
14785 "RangeSlider": "Polaris-RangeSlider-SingleThumb__RangeSlider",
14786 "Output": "Polaris-RangeSlider-SingleThumb__Output",
14787 "OutputBubble": "Polaris-RangeSlider-SingleThumb__OutputBubble",
14788 "OutputText": "Polaris-RangeSlider-SingleThumb__OutputText"
14789};
14790
14791function SingleThumb(props) {
14792 var id = props.id,
14793 error = props.error,
14794 helpText = props.helpText,
14795 value = props.value,
14796 min = props.min,
14797 max = props.max,
14798 disabled = props.disabled,
14799 output = props.output,
14800 prefix = props.prefix,
14801 suffix = props.suffix,
14802 label = props.label,
14803 labelAction = props.labelAction,
14804 labelHidden = props.labelHidden,
14805 step = props.step,
14806 onBlur = props.onBlur,
14807 onFocus = props.onFocus;
14808 var clampedValue = clamp(value, min, max);
14809 var describedBy = [];
14810
14811 if (error) {
14812 describedBy.push("".concat(id, "Error"));
14813 }
14814
14815 if (helpText) {
14816 describedBy.push(helpTextID(id));
14817 }
14818
14819 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
14820 var sliderProgress = (clampedValue - min) * 100 / (max - min);
14821 var outputFactor = invertNumber((sliderProgress - 50) / 100);
14822 var cssVars = {
14823 ["".concat(CSS_VAR_PREFIX, "min")]: min,
14824 ["".concat(CSS_VAR_PREFIX, "max")]: max,
14825 ["".concat(CSS_VAR_PREFIX, "current")]: clampedValue,
14826 ["".concat(CSS_VAR_PREFIX, "progress")]: "".concat(sliderProgress, "%"),
14827 ["".concat(CSS_VAR_PREFIX, "output-factor")]: "".concat(outputFactor)
14828 };
14829 var outputMarkup = !disabled && output && React__default.createElement("output", {
14830 htmlFor: id,
14831 className: styles$1m.Output
14832 }, React__default.createElement("div", {
14833 className: styles$1m.OutputBubble
14834 }, React__default.createElement("span", {
14835 className: styles$1m.OutputText
14836 }, clampedValue)));
14837 var prefixMarkup = prefix && React__default.createElement("div", {
14838 className: styles$1m.Prefix
14839 }, prefix);
14840 var suffixMarkup = suffix && React__default.createElement("div", {
14841 className: styles$1m.Suffix
14842 }, suffix);
14843 var className = classNames(styles$1m.SingleThumb, error && styles$1m.error, disabled && styles$1m.disabled);
14844 return React__default.createElement(Labelled, {
14845 id: id,
14846 label: label,
14847 error: error,
14848 action: labelAction,
14849 labelHidden: labelHidden,
14850 helpText: helpText
14851 }, React__default.createElement("div", {
14852 className: className,
14853 style: cssVars
14854 }, prefixMarkup, React__default.createElement("div", {
14855 className: styles$1m.InputWrapper
14856 }, React__default.createElement("input", {
14857 type: "range",
14858 className: styles$1m.Input,
14859 id: id,
14860 name: id,
14861 min: min,
14862 max: max,
14863 step: step,
14864 value: clampedValue,
14865 disabled: disabled,
14866 onChange: handleChange,
14867 onFocus: onFocus,
14868 onBlur: onBlur,
14869 "aria-valuemin": min,
14870 "aria-valuemax": max,
14871 "aria-valuenow": clampedValue,
14872 "aria-invalid": Boolean(error),
14873 "aria-describedby": ariaDescribedBy
14874 }), outputMarkup), suffixMarkup));
14875
14876 function handleChange(event) {
14877 var onChange = props.onChange;
14878 onChange && onChange(parseFloat(event.currentTarget.value), id);
14879 }
14880}
14881
14882function RangeSlider(_a) {
14883 var _a$min = _a.min,
14884 min = _a$min === void 0 ? RangeSliderDefault.Min : _a$min,
14885 _a$max = _a.max,
14886 max = _a$max === void 0 ? RangeSliderDefault.Max : _a$max,
14887 _a$step = _a.step,
14888 step = _a$step === void 0 ? RangeSliderDefault.Step : _a$step,
14889 value = _a.value,
14890 rest = __rest(_a, ["min", "max", "step", "value"]);
14891
14892 var id = useUniqueId('RangeSlider');
14893 var sharedProps = Object.assign({
14894 id,
14895 min,
14896 max,
14897 step
14898 }, rest);
14899 return isDualThumb(value) ? React__default.createElement(DualThumb, Object.assign({
14900 value: value
14901 }, sharedProps)) : React__default.createElement(SingleThumb, Object.assign({
14902 value: value
14903 }, sharedProps));
14904}
14905
14906function isDualThumb(value) {
14907 return Array.isArray(value);
14908}
14909
14910var styles$1n = {
14911 "CheckboxWrapper": "Polaris-ResourceItem__CheckboxWrapper",
14912 "ResourceItem": "Polaris-ResourceItem",
14913 "persistActions": "Polaris-ResourceItem--persistActions",
14914 "Actions": "Polaris-ResourceItem__Actions",
14915 "selected": "Polaris-ResourceItem--selected",
14916 "focused": "Polaris-ResourceItem--focused",
14917 "focusedInner": "Polaris-ResourceItem--focusedInner",
14918 "Link": "Polaris-ResourceItem__Link",
14919 "Button": "Polaris-ResourceItem__Button",
14920 "Container": "Polaris-ResourceItem__Container",
14921 "Owned": "Polaris-ResourceItem__Owned",
14922 "Handle": "Polaris-ResourceItem__Handle",
14923 "selectMode": "Polaris-ResourceItem--selectMode",
14924 "selectable": "Polaris-ResourceItem--selectable",
14925 "Media": "Polaris-ResourceItem__Media",
14926 "Content": "Polaris-ResourceItem__Content",
14927 "Disclosure": "Polaris-ResourceItem__Disclosure"
14928};
14929
14930var getUniqueCheckboxID = createUniqueIDFactory('ResourceListItemCheckbox');
14931var getUniqueOverlayID = createUniqueIDFactory('ResourceListItemOverlay');
14932
14933var BaseResourceItem =
14934/*#__PURE__*/
14935function (_React$Component) {
14936 _inherits(BaseResourceItem, _React$Component);
14937
14938 function BaseResourceItem() {
14939 var _this;
14940
14941 _classCallCheck(this, BaseResourceItem);
14942
14943 _this = _possibleConstructorReturn(this, _getPrototypeOf(BaseResourceItem).apply(this, arguments));
14944 _this.state = {
14945 actionsMenuVisible: false,
14946 focused: false,
14947 focusedInner: false,
14948 selected: isSelected(_this.props.id, _this.props.context.selectedItems)
14949 };
14950 _this.node = null;
14951 _this.checkboxId = getUniqueCheckboxID();
14952 _this.overlayId = getUniqueOverlayID();
14953 _this.buttonOverlay = React__default.createRef();
14954
14955 _this.setNode = function (node) {
14956 _this.node = node;
14957 };
14958
14959 _this.handleFocus = function (event) {
14960 if (event.target === _this.buttonOverlay.current || _this.node && event.target === _this.node.querySelector("#".concat(_this.overlayId))) {
14961 _this.setState({
14962 focused: true,
14963 focusedInner: false
14964 });
14965 } else if (_this.node && _this.node.contains(event.target)) {
14966 _this.setState({
14967 focused: true,
14968 focusedInner: true
14969 });
14970 }
14971 };
14972
14973 _this.handleBlur = function (_ref) {
14974 var relatedTarget = _ref.relatedTarget;
14975
14976 if (_this.node && relatedTarget instanceof Element && _this.node.contains(relatedTarget)) {
14977 return;
14978 }
14979
14980 _this.setState({
14981 focused: false,
14982 focusedInner: false
14983 });
14984 };
14985
14986 _this.handleLargerSelectionArea = function (event) {
14987 stopPropagation$1(event);
14988
14989 _this.handleSelection(!_this.state.selected, event.nativeEvent.shiftKey);
14990 };
14991
14992 _this.handleSelection = function (value, shiftKey) {
14993 var _this$props = _this.props,
14994 id = _this$props.id,
14995 sortOrder = _this$props.sortOrder,
14996 onSelectionChange = _this$props.context.onSelectionChange;
14997
14998 if (id == null || onSelectionChange == null) {
14999 return;
15000 }
15001
15002 _this.setState({
15003 focused: value,
15004 focusedInner: value
15005 });
15006
15007 onSelectionChange(value, id, sortOrder, shiftKey);
15008 };
15009
15010 _this.handleClick = function (event) {
15011 stopPropagation$1(event);
15012 var _this$props2 = _this.props,
15013 id = _this$props2.id,
15014 onClick = _this$props2.onClick,
15015 url = _this$props2.url,
15016 selectMode = _this$props2.context.selectMode;
15017 var _event$nativeEvent = event.nativeEvent,
15018 ctrlKey = _event$nativeEvent.ctrlKey,
15019 metaKey = _event$nativeEvent.metaKey;
15020
15021 var anchor = _this.node && _this.node.querySelector('a');
15022
15023 if (selectMode) {
15024 _this.handleLargerSelectionArea(event);
15025
15026 return;
15027 }
15028
15029 if (anchor === event.target) {
15030 return;
15031 }
15032
15033 if (onClick) {
15034 onClick(id);
15035 }
15036
15037 if (url && (ctrlKey || metaKey)) {
15038 window.open(url, '_blank');
15039 return;
15040 }
15041
15042 if (url && anchor) {
15043 anchor.click();
15044 }
15045 }; // This fires onClick when there is a URL on the item
15046
15047
15048 _this.handleKeyUp = function (event) {
15049 var _this$props3 = _this.props,
15050 _this$props3$onClick = _this$props3.onClick,
15051 onClick = _this$props3$onClick === void 0 ? noop$b : _this$props3$onClick,
15052 selectMode = _this$props3.context.selectMode;
15053 var key = event.key;
15054
15055 if (key === 'Enter' && _this.props.url && !selectMode) {
15056 onClick();
15057 }
15058 };
15059
15060 _this.handleActionsClick = function () {
15061 _this.setState(function (_ref2) {
15062 var actionsMenuVisible = _ref2.actionsMenuVisible;
15063 return {
15064 actionsMenuVisible: !actionsMenuVisible
15065 };
15066 });
15067 };
15068
15069 _this.handleCloseRequest = function () {
15070 _this.setState({
15071 actionsMenuVisible: false
15072 });
15073 };
15074
15075 return _this;
15076 }
15077
15078 _createClass(BaseResourceItem, [{
15079 key: "shouldComponentUpdate",
15080 value: function shouldComponentUpdate(nextProps, nextState) {
15081 var _a = nextProps.context,
15082 nextSelectedItems = _a.selectedItems,
15083 restNextContext = __rest(_a, ["selectedItems"]),
15084 restNextProps = __rest(nextProps, ["context"]);
15085
15086 var _b = this.props,
15087 _c = _b.context,
15088 selectedItems = _c.selectedItems,
15089 restContext = __rest(_c, ["selectedItems"]),
15090 restProps = __rest(_b, ["context"]);
15091
15092 var nextSelectMode = nextProps.context.selectMode;
15093 return !isEqual(this.state, nextState) || this.props.context.selectMode !== nextSelectMode || !nextProps.context.selectMode && (!isEqual(restProps, restNextProps) || !isEqual(restContext, restNextContext));
15094 }
15095 }, {
15096 key: "render",
15097 value: function render() {
15098 var _this$props4 = this.props,
15099 children = _this$props4.children,
15100 url = _this$props4.url,
15101 external = _this$props4.external,
15102 media = _this$props4.media,
15103 shortcutActions = _this$props4.shortcutActions,
15104 ariaControls = _this$props4.ariaControls,
15105 ariaExpanded = _this$props4.ariaExpanded,
15106 _this$props4$persistA = _this$props4.persistActions,
15107 persistActions = _this$props4$persistA === void 0 ? false : _this$props4$persistA,
15108 accessibilityLabel = _this$props4.accessibilityLabel,
15109 name = _this$props4.name,
15110 _this$props4$context = _this$props4.context,
15111 selectable = _this$props4$context.selectable,
15112 selectMode = _this$props4$context.selectMode,
15113 loading = _this$props4$context.loading,
15114 resourceName = _this$props4$context.resourceName,
15115 i18n = _this$props4.i18n;
15116 var _this$state = this.state,
15117 actionsMenuVisible = _this$state.actionsMenuVisible,
15118 focused = _this$state.focused,
15119 focusedInner = _this$state.focusedInner,
15120 selected = _this$state.selected;
15121 var ownedMarkup = null;
15122 var handleMarkup = null;
15123 var mediaMarkup = media ? React__default.createElement("div", {
15124 className: styles$1n.Media
15125 }, media) : null;
15126
15127 if (selectable) {
15128 var checkboxAccessibilityLabel = name || accessibilityLabel || i18n.translate('Polaris.Common.checkbox');
15129 handleMarkup = React__default.createElement("div", {
15130 className: styles$1n.Handle,
15131 onClick: this.handleLargerSelectionArea
15132 }, React__default.createElement("div", {
15133 onClick: stopPropagation$1,
15134 className: styles$1n.CheckboxWrapper
15135 }, React__default.createElement("div", {
15136 onChange: this.handleLargerSelectionArea
15137 }, React__default.createElement(Checkbox$1, {
15138 id: this.checkboxId,
15139 label: checkboxAccessibilityLabel,
15140 labelHidden: true,
15141 checked: selected,
15142 disabled: loading
15143 }))));
15144 }
15145
15146 if (media || selectable) {
15147 ownedMarkup = React__default.createElement("div", {
15148 className: styles$1n.Owned
15149 }, handleMarkup, mediaMarkup);
15150 }
15151
15152 var className = classNames(styles$1n.ResourceItem, focused && styles$1n.focused, selectable && styles$1n.selectable, selected && styles$1n.selected, selectMode && styles$1n.selectMode, persistActions && styles$1n.persistActions, focusedInner && styles$1n.focusedInner);
15153 var actionsMarkup = null;
15154 var disclosureMarkup = null;
15155
15156 if (shortcutActions && !loading) {
15157 if (persistActions) {
15158 actionsMarkup = React__default.createElement("div", {
15159 className: styles$1n.Actions,
15160 onClick: stopPropagation$1
15161 }, React__default.createElement(ButtonGroup, null, buttonsFrom(shortcutActions, {
15162 plain: true
15163 })));
15164 var disclosureAccessibilityLabel = name ? i18n.translate('Polaris.ResourceList.Item.actionsDropdownLabel', {
15165 accessibilityLabel: name
15166 }) : i18n.translate('Polaris.ResourceList.Item.actionsDropdown');
15167 disclosureMarkup = React__default.createElement("div", {
15168 className: styles$1n.Disclosure,
15169 onClick: stopPropagation$1
15170 }, React__default.createElement(Popover, {
15171 activator: React__default.createElement(Button, {
15172 accessibilityLabel: disclosureAccessibilityLabel,
15173 onClick: this.handleActionsClick,
15174 plain: true,
15175 icon: HorizontalDotsMinor
15176 }),
15177 onClose: this.handleCloseRequest,
15178 active: actionsMenuVisible
15179 }, React__default.createElement(ActionList, {
15180 items: shortcutActions
15181 })));
15182 } else {
15183 actionsMarkup = React__default.createElement("div", {
15184 className: styles$1n.Actions,
15185 onClick: stopPropagation$1
15186 }, React__default.createElement(ButtonGroup, {
15187 segmented: true
15188 }, buttonsFrom(shortcutActions, {
15189 size: 'slim'
15190 })));
15191 }
15192 }
15193
15194 var content = children ? React__default.createElement("div", {
15195 className: styles$1n.Content
15196 }, children) : null;
15197 var containerMarkup = React__default.createElement("div", {
15198 className: styles$1n.Container,
15199 id: this.props.id
15200 }, ownedMarkup, content, actionsMarkup, disclosureMarkup);
15201 var tabIndex = loading ? -1 : 0;
15202 var ariaLabel = accessibilityLabel || i18n.translate('Polaris.ResourceList.Item.viewItem', {
15203 itemName: name || resourceName && resourceName.singular || ''
15204 });
15205 var accessibleMarkup = url ? React__default.createElement(UnstyledLink, {
15206 "aria-describedby": this.props.id,
15207 "aria-label": ariaLabel,
15208 className: styles$1n.Link,
15209 url: url,
15210 external: external,
15211 tabIndex: tabIndex,
15212 id: this.overlayId
15213 }) : React__default.createElement("button", {
15214 className: styles$1n.Button,
15215 "aria-label": ariaLabel,
15216 "aria-controls": ariaControls,
15217 "aria-expanded": ariaExpanded,
15218 onClick: this.handleClick,
15219 tabIndex: tabIndex,
15220 ref: this.buttonOverlay
15221 });
15222 return React__default.createElement("div", {
15223 ref: this.setNode,
15224 className: className,
15225 onClick: this.handleClick,
15226 onFocus: this.handleFocus,
15227 onBlur: this.handleBlur,
15228 onKeyUp: this.handleKeyUp,
15229 "data-href": url
15230 }, accessibleMarkup, containerMarkup);
15231 }
15232 }], [{
15233 key: "getDerivedStateFromProps",
15234 value: function getDerivedStateFromProps(nextProps, prevState) {
15235 var selected = isSelected(nextProps.id, nextProps.context.selectedItems);
15236
15237 if (prevState.selected === selected) {
15238 return null;
15239 }
15240
15241 return {
15242 selected
15243 };
15244 }
15245 }]);
15246
15247 return BaseResourceItem;
15248}(React__default.Component);
15249
15250function noop$b() {}
15251
15252function stopPropagation$1(event) {
15253 event.stopPropagation();
15254}
15255
15256function isSelected(id, selectedItems) {
15257 return Boolean(selectedItems && (Array.isArray(selectedItems) && selectedItems.includes(id) || selectedItems === SELECT_ALL_ITEMS));
15258}
15259
15260function ResourceItem(props) {
15261 return React__default.createElement(BaseResourceItem, Object.assign({}, props, {
15262 context: useContext(ResourceListContext),
15263 i18n: useI18n()
15264 }));
15265}
15266
15267var Sticky =
15268/*#__PURE__*/
15269function (_React$Component) {
15270 _inherits(Sticky, _React$Component);
15271
15272 function Sticky() {
15273 var _this;
15274
15275 _classCallCheck(this, Sticky);
15276
15277 _this = _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
15278 _this.state = {
15279 isSticky: false,
15280 style: {}
15281 };
15282 _this.placeHolderNode = null;
15283 _this.stickyNode = null;
15284
15285 _this.setPlaceHolderNode = function (node) {
15286 _this.placeHolderNode = node;
15287 };
15288
15289 _this.setStickyNode = function (node) {
15290 _this.stickyNode = node;
15291 };
15292
15293 _this.handlePositioning = function (stick) {
15294 var top = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
15295 var left = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
15296 var width = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
15297 var isSticky = _this.state.isSticky;
15298
15299 if (stick && !isSticky || !stick && isSticky) {
15300 _this.adjustPlaceHolderNode(stick);
15301
15302 _this.setState({
15303 isSticky: !isSticky
15304 });
15305 }
15306
15307 var style = stick ? {
15308 position: 'fixed',
15309 top,
15310 left,
15311 width
15312 } : {};
15313
15314 _this.setState({
15315 style
15316 });
15317 };
15318
15319 _this.adjustPlaceHolderNode = function (add) {
15320 if (_this.placeHolderNode && _this.stickyNode) {
15321 _this.placeHolderNode.style.paddingBottom = add ? "".concat(getRectForNode(_this.stickyNode).height, "px") : '0px';
15322 }
15323 };
15324
15325 return _this;
15326 }
15327
15328 _createClass(Sticky, [{
15329 key: "componentDidMount",
15330 value: function componentDidMount() {
15331 var _this$props = this.props,
15332 boundingElement = _this$props.boundingElement,
15333 _this$props$offset = _this$props.offset,
15334 offset = _this$props$offset === void 0 ? false : _this$props$offset,
15335 _this$props$disableWh = _this$props.disableWhenStacked,
15336 disableWhenStacked = _this$props$disableWh === void 0 ? false : _this$props$disableWh,
15337 stickyManager = _this$props.polaris.stickyManager;
15338 if (!this.stickyNode || !this.placeHolderNode) return;
15339 stickyManager.registerStickyItem({
15340 stickyNode: this.stickyNode,
15341 placeHolderNode: this.placeHolderNode,
15342 handlePositioning: this.handlePositioning,
15343 offset,
15344 boundingElement,
15345 disableWhenStacked
15346 });
15347 }
15348 }, {
15349 key: "componentWillUnmount",
15350 value: function componentWillUnmount() {
15351 var stickyManager = this.props.polaris.stickyManager;
15352 if (!this.stickyNode) return;
15353 stickyManager.unregisterStickyItem(this.stickyNode);
15354 }
15355 }, {
15356 key: "render",
15357 value: function render() {
15358 var _this$state = this.state,
15359 style = _this$state.style,
15360 isSticky = _this$state.isSticky;
15361 var children = this.props.children;
15362 var childrenContent = isFunction(children) ? children(isSticky) : children;
15363 return React__default.createElement("div", null, React__default.createElement("div", {
15364 ref: this.setPlaceHolderNode
15365 }), React__default.createElement("div", {
15366 ref: this.setStickyNode,
15367 style: style
15368 }, childrenContent));
15369 }
15370 }]);
15371
15372 return Sticky;
15373}(React__default.Component);
15374
15375function isFunction(arg) {
15376 return typeof arg === 'function';
15377} // Use named export once withAppProvider is refactored away
15378// eslint-disable-next-line import/no-default-export
15379
15380
15381var Sticky$1 = withAppProvider()(Sticky);
15382
15383var styles$1o = {
15384 "Select": "Polaris-Select",
15385 "disabled": "Polaris-Select--disabled",
15386 "Content": "Polaris-Select__Content",
15387 "InlineLabel": "Polaris-Select__InlineLabel",
15388 "Icon": "Polaris-Select__Icon",
15389 "Backdrop": "Polaris-Select__Backdrop",
15390 "error": "Polaris-Select--error",
15391 "Input": "Polaris-Select__Input",
15392 "placeholder": "Polaris-Select--placeholder",
15393 "SelectedOption": "Polaris-Select__SelectedOption"
15394};
15395
15396var PLACEHOLDER_VALUE = '';
15397function Select(_ref) {
15398 var optionsProp = _ref.options,
15399 label = _ref.label,
15400 labelAction = _ref.labelAction,
15401 labelHiddenProp = _ref.labelHidden,
15402 labelInline = _ref.labelInline,
15403 disabled = _ref.disabled,
15404 helpText = _ref.helpText,
15405 placeholder = _ref.placeholder,
15406 idProp = _ref.id,
15407 name = _ref.name,
15408 _ref$value = _ref.value,
15409 value = _ref$value === void 0 ? PLACEHOLDER_VALUE : _ref$value,
15410 error = _ref.error,
15411 onChange = _ref.onChange,
15412 onFocus = _ref.onFocus,
15413 onBlur = _ref.onBlur;
15414 var id = useUniqueId('Select', idProp);
15415 var labelHidden = labelInline ? true : labelHiddenProp;
15416 var className = classNames(styles$1o.Select, error && styles$1o.error, disabled && styles$1o.disabled);
15417 var handleChange = onChange ? function (event) {
15418 return onChange(event.currentTarget.value, id);
15419 } : undefined;
15420 var describedBy = [];
15421
15422 if (helpText) {
15423 describedBy.push(helpTextID(id));
15424 }
15425
15426 if (error) {
15427 describedBy.push("".concat(id, "Error"));
15428 }
15429
15430 var options = optionsProp || [];
15431 var normalizedOptions = options.map(normalizeOption);
15432
15433 if (placeholder) {
15434 normalizedOptions = [{
15435 label: placeholder,
15436 value: PLACEHOLDER_VALUE,
15437 disabled: true
15438 }].concat(_toConsumableArray(normalizedOptions));
15439 }
15440
15441 var inlineLabelMarkup = labelInline && React__default.createElement("span", {
15442 className: styles$1o.InlineLabel
15443 }, label);
15444 var selectedOption = getSelectedOption(normalizedOptions, value);
15445 var contentMarkup = React__default.createElement("div", {
15446 className: styles$1o.Content,
15447 "aria-hidden": true,
15448 "aria-disabled": disabled
15449 }, inlineLabelMarkup, React__default.createElement("span", {
15450 className: styles$1o.SelectedOption
15451 }, selectedOption), React__default.createElement("span", {
15452 className: styles$1o.Icon
15453 }, React__default.createElement(Icon, {
15454 source: ArrowUpDownMinor
15455 })));
15456 var optionsMarkup = normalizedOptions.map(renderOption);
15457 return React__default.createElement(Labelled, {
15458 id: id,
15459 label: label,
15460 error: error,
15461 action: labelAction,
15462 labelHidden: labelHidden,
15463 helpText: helpText
15464 }, React__default.createElement("div", {
15465 className: className
15466 }, React__default.createElement("select", {
15467 id: id,
15468 name: name,
15469 value: value,
15470 className: styles$1o.Input,
15471 disabled: disabled,
15472 onFocus: onFocus,
15473 onBlur: onBlur,
15474 onChange: handleChange,
15475 "aria-invalid": Boolean(error),
15476 "aria-describedby": describedBy.length ? describedBy.join(' ') : undefined
15477 }, optionsMarkup), contentMarkup, React__default.createElement("div", {
15478 className: styles$1o.Backdrop
15479 })));
15480}
15481
15482function isString(option) {
15483 return typeof option === 'string';
15484}
15485
15486function isGroup(option) {
15487 return option.options != null;
15488}
15489
15490function normalizeStringOption(option) {
15491 return {
15492 label: option,
15493 value: option
15494 };
15495}
15496/**
15497 * Converts a string option (and each string option in a Group) into
15498 * an Option object.
15499 */
15500
15501
15502function normalizeOption(option) {
15503 if (isString(option)) {
15504 return normalizeStringOption(option);
15505 } else if (isGroup(option)) {
15506 var title = option.title,
15507 options = option.options;
15508 return {
15509 title,
15510 options: options.map(function (option) {
15511 return isString(option) ? normalizeStringOption(option) : option;
15512 })
15513 };
15514 }
15515
15516 return option;
15517}
15518/**
15519 * Gets the text to display in the UI, for the currently selected option
15520 */
15521
15522
15523function getSelectedOption(options, value) {
15524 var flatOptions = flattenOptions(options);
15525 var selectedOption = flatOptions.find(function (option) {
15526 return value === option.value;
15527 });
15528
15529 if (selectedOption === undefined) {
15530 // Get the first visible option (not the hidden placeholder)
15531 selectedOption = flatOptions.find(function (option) {
15532 return !option.hidden;
15533 });
15534 }
15535
15536 return selectedOption ? selectedOption.label : '';
15537}
15538/**
15539 * Ungroups an options array
15540 */
15541
15542
15543function flattenOptions(options) {
15544 var flatOptions = [];
15545 options.forEach(function (optionOrGroup) {
15546 if (isGroup(optionOrGroup)) {
15547 flatOptions = flatOptions.concat(optionOrGroup.options);
15548 } else {
15549 flatOptions.push(optionOrGroup);
15550 }
15551 });
15552 return flatOptions;
15553}
15554
15555function renderSingleOption(option) {
15556 var value = option.value,
15557 label = option.label,
15558 rest = __rest(option, ["value", "label"]);
15559
15560 return React__default.createElement("option", Object.assign({
15561 key: value,
15562 value: value
15563 }, rest), label);
15564}
15565
15566function renderOption(optionOrGroup) {
15567 if (isGroup(optionOrGroup)) {
15568 var title = optionOrGroup.title,
15569 options = optionOrGroup.options;
15570 return React__default.createElement("optgroup", {
15571 label: title,
15572 key: title
15573 }, options.map(renderSingleOption));
15574 }
15575
15576 return renderSingleOption(optionOrGroup);
15577}
15578
15579var styles$1p = {
15580 "CheckableButton": "Polaris-ResourceList-CheckableButton",
15581 "globalTheming": "Polaris-ResourceList-CheckableButton--globalTheming",
15582 "CheckableButton-selectMode": "Polaris-ResourceList-CheckableButton__CheckableButton--selectMode",
15583 "CheckableButton-measuring": "Polaris-ResourceList-CheckableButton__CheckableButton--measuring",
15584 "CheckableButton-plain": "Polaris-ResourceList-CheckableButton__CheckableButton--plain",
15585 "CheckableButton-selected": "Polaris-ResourceList-CheckableButton__CheckableButton--selected",
15586 "Checkbox": "Polaris-ResourceList-CheckableButton__Checkbox",
15587 "Label": "Polaris-ResourceList-CheckableButton__Label"
15588};
15589
15590function CheckableButton(_ref) {
15591 var accessibilityLabel = _ref.accessibilityLabel,
15592 _ref$label = _ref.label,
15593 label = _ref$label === void 0 ? '' : _ref$label,
15594 onToggleAll = _ref.onToggleAll,
15595 selected = _ref.selected,
15596 selectMode = _ref.selectMode,
15597 plain = _ref.plain,
15598 measuring = _ref.measuring,
15599 disabled = _ref.disabled,
15600 smallScreen = _ref.smallScreen;
15601 var checkBoxRef = useRef(null);
15602
15603 var _useFeatures = useFeatures(),
15604 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
15605 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
15606
15607 var _React$useContext = React__default.useContext(ResourceListContext),
15608 registerCheckableButtons = _React$useContext.registerCheckableButtons;
15609
15610 var currentKey = 'bulkLg';
15611
15612 if (plain) {
15613 currentKey = 'plain';
15614 } else if (smallScreen) {
15615 currentKey = 'bulkSm';
15616 }
15617
15618 useEffect(function () {
15619 if (checkBoxRef.current && registerCheckableButtons) {
15620 registerCheckableButtons(currentKey, checkBoxRef.current);
15621 }
15622 }, [currentKey, registerCheckableButtons]);
15623 var className = plain ? classNames(styles$1p.CheckableButton, styles$1p['CheckableButton-plain'], unstableGlobalTheming && styles$1p.globalTheming) : classNames(styles$1p.CheckableButton, unstableGlobalTheming && styles$1p.globalTheming, selectMode && styles$1p['CheckableButton-selectMode'], selected && styles$1p['CheckableButton-selected'], measuring && styles$1p['CheckableButton-measuring']);
15624 return React__default.createElement("div", {
15625 className: className,
15626 onClick: onToggleAll
15627 }, React__default.createElement("div", {
15628 className: styles$1p.Checkbox
15629 }, React__default.createElement(Checkbox$1, {
15630 label: accessibilityLabel,
15631 labelHidden: true,
15632 checked: selected,
15633 disabled: disabled,
15634 onChange: onToggleAll,
15635 ref: checkBoxRef
15636 })), React__default.createElement("span", {
15637 className: styles$1p.Label
15638 }, label));
15639}
15640
15641var styles$1q = {
15642 "Group": "Polaris-ResourceList-BulkActions__Group",
15643 "Group-measuring": "Polaris-ResourceList-BulkActions__Group--measuring",
15644 "Group-entering": "Polaris-ResourceList-BulkActions__Group--entering",
15645 "Group-exiting": "Polaris-ResourceList-BulkActions__Group--exiting",
15646 "Group-entered": "Polaris-ResourceList-BulkActions__Group--entered",
15647 "Group-exited": "Polaris-ResourceList-BulkActions__Group--exited",
15648 "Group-smallScreen": "Polaris-ResourceList-BulkActions__Group--smallScreen",
15649 "Group-largeScreen": "Polaris-ResourceList-BulkActions__Group--largeScreen",
15650 "ButtonGroupWrapper": "Polaris-ResourceList-BulkActions__ButtonGroupWrapper",
15651 "BulkActionButton": "Polaris-ResourceList-BulkActions__BulkActionButton",
15652 "CheckableContainer": "Polaris-ResourceList-BulkActions__CheckableContainer",
15653 "disabled": "Polaris-ResourceList-BulkActions--disabled",
15654 "globalTheming": "Polaris-ResourceList-BulkActions--globalTheming",
15655 "PaginatedSelectAll": "Polaris-ResourceList-BulkActions__PaginatedSelectAll",
15656 "Slide": "Polaris-ResourceList-BulkActions__Slide",
15657 "Slide-appear": "Polaris-ResourceList-BulkActions__Slide--appear",
15658 "Slide-enter": "Polaris-ResourceList-BulkActions__Slide--enter",
15659 "Slide-exit": "Polaris-ResourceList-BulkActions__Slide--exit",
15660 "Slide-appearing": "Polaris-ResourceList-BulkActions__Slide--appearing",
15661 "Slide-entering": "Polaris-ResourceList-BulkActions__Slide--entering"
15662};
15663
15664var BulkActionButton =
15665/*#__PURE__*/
15666function (_React$PureComponent) {
15667 _inherits(BulkActionButton, _React$PureComponent);
15668
15669 function BulkActionButton() {
15670 var _this;
15671
15672 _classCallCheck(this, BulkActionButton);
15673
15674 _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkActionButton).apply(this, arguments));
15675 _this.bulkActionButton = createRef();
15676 return _this;
15677 }
15678
15679 _createClass(BulkActionButton, [{
15680 key: "componentDidMount",
15681 value: function componentDidMount() {
15682 var handleMeasurement = this.props.handleMeasurement;
15683
15684 if (handleMeasurement && this.bulkActionButton.current) {
15685 var width = this.bulkActionButton.current.getBoundingClientRect().width;
15686 handleMeasurement(width);
15687 }
15688 }
15689 }, {
15690 key: "render",
15691 value: function render() {
15692 var _this$props = this.props,
15693 url = _this$props.url,
15694 external = _this$props.external,
15695 onAction = _this$props.onAction,
15696 content = _this$props.content,
15697 disclosure = _this$props.disclosure,
15698 accessibilityLabel = _this$props.accessibilityLabel,
15699 disabled = _this$props.disabled;
15700 return React__default.createElement("div", {
15701 className: styles$1q.BulkActionButton,
15702 ref: this.bulkActionButton
15703 }, React__default.createElement(Button, {
15704 external: external,
15705 url: url,
15706 "aria-label": accessibilityLabel,
15707 onClick: onAction,
15708 disabled: disabled,
15709 disclosure: disclosure
15710 }, content));
15711 }
15712 }]);
15713
15714 return BulkActionButton;
15715}(React__default.PureComponent);
15716
15717var MAX_PROMOTED_ACTIONS = 2;
15718var slideClasses = {
15719 appear: classNames(styles$1q.Slide, styles$1q['Slide-appear']),
15720 appearActive: classNames(styles$1q.Slide, styles$1q['Slide-appearing']),
15721 enter: classNames(styles$1q.Slide, styles$1q['Slide-enter']),
15722 enterActive: classNames(styles$1q.Slide, styles$1q['Slide-entering']),
15723 exit: classNames(styles$1q.Slide, styles$1q['Slide-exit'])
15724};
15725
15726var BulkActions =
15727/*#__PURE__*/
15728function (_React$PureComponent) {
15729 _inherits(BulkActions, _React$PureComponent);
15730
15731 function BulkActions() {
15732 var _this;
15733
15734 _classCallCheck(this, BulkActions);
15735
15736 _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkActions).apply(this, arguments));
15737 _this.state = {
15738 smallScreenPopoverVisible: false,
15739 largeScreenPopoverVisible: false,
15740 containerWidth: 0,
15741 measuring: true
15742 };
15743 _this.checkableWrapperNode = createRef();
15744 _this.largeScreenGroupNode = createRef();
15745 _this.smallScreenGroupNode = createRef();
15746 _this.promotedActionsWidths = [];
15747 _this.bulkActionsWidth = 0;
15748 _this.addedMoreActionsWidthForMeasuring = 0;
15749 _this.handleResize = debounce(function () {
15750 var _this$state = _this.state,
15751 smallScreenPopoverVisible = _this$state.smallScreenPopoverVisible,
15752 largeScreenPopoverVisible = _this$state.largeScreenPopoverVisible;
15753
15754 if (_this.containerNode) {
15755 var containerWidth = _this.containerNode.getBoundingClientRect().width;
15756
15757 if (containerWidth > 0) {
15758 _this.setState({
15759 containerWidth
15760 });
15761 }
15762 }
15763
15764 if (smallScreenPopoverVisible || largeScreenPopoverVisible) {
15765 _this.setState({
15766 smallScreenPopoverVisible: false,
15767 largeScreenPopoverVisible: false
15768 });
15769 }
15770 }, 50, {
15771 trailing: true
15772 });
15773
15774 _this.setLargeScreenButtonsNode = function (node) {
15775 _this.largeScreenButtonsNode = node;
15776 };
15777
15778 _this.setContainerNode = function (node) {
15779 _this.containerNode = node;
15780 };
15781
15782 _this.setMoreActionsNode = function (node) {
15783 _this.moreActionsNode = node;
15784 };
15785
15786 _this.setSelectMode = function (val) {
15787 var onSelectModeToggle = _this.props.onSelectModeToggle;
15788
15789 if (onSelectModeToggle) {
15790 onSelectModeToggle(val);
15791 }
15792 };
15793
15794 _this.toggleSmallScreenPopover = function () {
15795 _this.setState(function (_ref) {
15796 var smallScreenPopoverVisible = _ref.smallScreenPopoverVisible;
15797 return {
15798 smallScreenPopoverVisible: !smallScreenPopoverVisible
15799 };
15800 });
15801 };
15802
15803 _this.toggleLargeScreenPopover = function () {
15804 _this.setState(function (_ref2) {
15805 var largeScreenPopoverVisible = _ref2.largeScreenPopoverVisible;
15806 return {
15807 largeScreenPopoverVisible: !largeScreenPopoverVisible
15808 };
15809 });
15810 };
15811
15812 _this.handleMeasurement = function (width) {
15813 var measuring = _this.state.measuring;
15814
15815 if (measuring) {
15816 _this.promotedActionsWidths.push(width);
15817 }
15818 };
15819
15820 _this.findLargeScreenGroupNode = function () {
15821 return _this.largeScreenGroupNode.current;
15822 };
15823
15824 _this.findCheckableWrapperNode = function () {
15825 return _this.checkableWrapperNode.current;
15826 };
15827
15828 _this.findSmallScreenGroupNode = function () {
15829 return _this.smallScreenGroupNode.current;
15830 };
15831
15832 return _this;
15833 }
15834
15835 _createClass(BulkActions, [{
15836 key: "componentDidMount",
15837 value: function componentDidMount() {
15838 var _this$props = this.props,
15839 actions = _this$props.actions,
15840 promotedActions = _this$props.promotedActions;
15841
15842 if (promotedActions && !actions && this.moreActionsNode) {
15843 this.addedMoreActionsWidthForMeasuring = this.moreActionsNode.getBoundingClientRect().width;
15844 }
15845
15846 this.bulkActionsWidth = this.largeScreenButtonsNode ? this.largeScreenButtonsNode.getBoundingClientRect().width - this.addedMoreActionsWidthForMeasuring : 0;
15847
15848 if (this.containerNode) {
15849 this.setState({
15850 containerWidth: this.containerNode.getBoundingClientRect().width,
15851 measuring: false
15852 });
15853 }
15854 }
15855 }, {
15856 key: "render",
15857 value: function render() {
15858 var _this2 = this;
15859
15860 var _this$props2 = this.props,
15861 selectMode = _this$props2.selectMode,
15862 accessibilityLabel = _this$props2.accessibilityLabel,
15863 _this$props2$label = _this$props2.label,
15864 label = _this$props2$label === void 0 ? '' : _this$props2$label,
15865 onToggleAll = _this$props2.onToggleAll,
15866 selected = _this$props2.selected,
15867 smallScreen = _this$props2.smallScreen,
15868 disabled = _this$props2.disabled,
15869 promotedActions = _this$props2.promotedActions,
15870 _this$props2$paginate = _this$props2.paginatedSelectAllText,
15871 paginatedSelectAllText = _this$props2$paginate === void 0 ? null : _this$props2$paginate,
15872 paginatedSelectAllAction = _this$props2.paginatedSelectAllAction,
15873 intl = _this$props2.polaris.intl;
15874
15875 if (promotedActions && promotedActions.length > MAX_PROMOTED_ACTIONS) {
15876 // eslint-disable-next-line no-console
15877 console.warn(intl.translate('Polaris.ResourceList.BulkActions.warningMessage', {
15878 maxPromotedActions: MAX_PROMOTED_ACTIONS
15879 }));
15880 }
15881
15882 var _this$state2 = this.state,
15883 smallScreenPopoverVisible = _this$state2.smallScreenPopoverVisible,
15884 largeScreenPopoverVisible = _this$state2.largeScreenPopoverVisible,
15885 measuring = _this$state2.measuring;
15886 var paginatedSelectAllActionMarkup = paginatedSelectAllAction ? React__default.createElement(Button, {
15887 onClick: paginatedSelectAllAction.onAction,
15888 plain: true,
15889 disabled: disabled
15890 }, paginatedSelectAllAction.content) : null;
15891 var paginatedSelectAllTextMarkup = paginatedSelectAllText && paginatedSelectAllAction ? React__default.createElement("span", {
15892 "aria-live": "polite"
15893 }, paginatedSelectAllText) : paginatedSelectAllText;
15894 var paginatedSelectAllMarkup = paginatedSelectAllActionMarkup || paginatedSelectAllTextMarkup ? React__default.createElement("div", {
15895 className: styles$1q.PaginatedSelectAll
15896 }, paginatedSelectAllTextMarkup, " ", paginatedSelectAllActionMarkup) : null;
15897 var cancelButton = React__default.createElement(Button, {
15898 onClick: this.setSelectMode.bind(this, false),
15899 disabled: disabled
15900 }, intl.translate('Polaris.Common.cancel'));
15901 var numberOfPromotedActionsToRender = this.numberOfPromotedActionsToRender;
15902 var allActionsPopover = this.hasActions ? React__default.createElement("div", {
15903 className: styles$1q.Popover,
15904 ref: this.setMoreActionsNode
15905 }, React__default.createElement(Popover, {
15906 active: smallScreenPopoverVisible,
15907 activator: React__default.createElement(BulkActionButton, {
15908 disclosure: true,
15909 onAction: this.toggleSmallScreenPopover,
15910 content: intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel'),
15911 disabled: disabled
15912 }),
15913 onClose: this.toggleSmallScreenPopover
15914 }, React__default.createElement(ActionList, {
15915 items: promotedActions,
15916 sections: this.actionSections,
15917 onActionAnyItem: this.toggleSmallScreenPopover
15918 }))) : null;
15919 var promotedActionsMarkup = promotedActions && numberOfPromotedActionsToRender > 0 ? _toConsumableArray(promotedActions).slice(0, numberOfPromotedActionsToRender).map(function (action, index) {
15920 return React__default.createElement(BulkActionButton, Object.assign({
15921 disabled: disabled
15922 }, action, {
15923 key: index,
15924 handleMeasurement: _this2.handleMeasurement
15925 }));
15926 }) : null;
15927 var rolledInPromotedActions = promotedActions && numberOfPromotedActionsToRender < promotedActions.length ? _toConsumableArray(promotedActions).slice(numberOfPromotedActionsToRender) : [];
15928 var activatorLabel = !promotedActions || promotedActions && numberOfPromotedActionsToRender === 0 && !measuring ? intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel') : intl.translate('Polaris.ResourceList.BulkActions.moreActionsActivatorLabel');
15929 var combinedActions = [];
15930
15931 if (this.actionSections && rolledInPromotedActions.length > 0) {
15932 combinedActions = [{
15933 items: rolledInPromotedActions
15934 }].concat(_toConsumableArray(this.actionSections));
15935 } else if (this.actionSections) {
15936 combinedActions = this.actionSections;
15937 } else if (rolledInPromotedActions.length > 0) {
15938 combinedActions = [{
15939 items: rolledInPromotedActions
15940 }];
15941 }
15942
15943 var actionsPopover = this.actionSections || rolledInPromotedActions.length > 0 || measuring ? React__default.createElement("div", {
15944 className: styles$1q.Popover,
15945 ref: this.setMoreActionsNode
15946 }, React__default.createElement(Popover, {
15947 active: largeScreenPopoverVisible,
15948 activator: React__default.createElement(BulkActionButton, {
15949 disclosure: true,
15950 onAction: this.toggleLargeScreenPopover,
15951 content: activatorLabel,
15952 disabled: disabled
15953 }),
15954 onClose: this.toggleLargeScreenPopover
15955 }, React__default.createElement(ActionList, {
15956 sections: combinedActions,
15957 onActionAnyItem: this.toggleLargeScreenPopover
15958 }))) : null;
15959 var checkableButtonProps = {
15960 accessibilityLabel,
15961 label,
15962 selected,
15963 selectMode,
15964 onToggleAll,
15965 measuring,
15966 disabled
15967 };
15968 var smallScreenGroup = smallScreen ? React__default.createElement(Transition, {
15969 timeout: 0,
15970 in: selectMode,
15971 key: "smallGroup",
15972 findDOMNode: this.findSmallScreenGroupNode
15973 }, function (status) {
15974 var smallScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-smallScreen'], styles$1q["Group-".concat(status)]);
15975 return React__default.createElement("div", {
15976 className: smallScreenGroupClassName,
15977 ref: _this2.smallScreenGroupNode
15978 }, React__default.createElement("div", {
15979 className: styles$1q.ButtonGroupWrapper
15980 }, React__default.createElement(ButtonGroup, {
15981 segmented: true
15982 }, React__default.createElement(CSSTransition, {
15983 findDOMNode: _this2.findCheckableWrapperNode,
15984 in: selectMode,
15985 timeout: durationBase,
15986 classNames: slideClasses,
15987 appear: !selectMode
15988 }, React__default.createElement("div", {
15989 className: styles$1q.CheckableContainer,
15990 ref: _this2.checkableWrapperNode
15991 }, React__default.createElement(CheckableButton, Object.assign({}, checkableButtonProps, {
15992 smallScreen: true
15993 })))), allActionsPopover, cancelButton)), paginatedSelectAllMarkup);
15994 }) : null;
15995 var largeGroupContent = promotedActionsMarkup || actionsPopover ? React__default.createElement(ButtonGroup, {
15996 segmented: true
15997 }, React__default.createElement(CheckableButton, checkableButtonProps), promotedActionsMarkup, actionsPopover) : React__default.createElement(CheckableButton, checkableButtonProps);
15998 var largeScreenGroup = smallScreen ? null : React__default.createElement(Transition, {
15999 timeout: 0,
16000 in: selectMode,
16001 key: "largeGroup",
16002 findDOMNode: this.findLargeScreenGroupNode
16003 }, function (status) {
16004 var largeScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-largeScreen'], !measuring && styles$1q["Group-".concat(status)], measuring && styles$1q['Group-measuring']);
16005 return React__default.createElement("div", {
16006 className: largeScreenGroupClassName,
16007 ref: _this2.largeScreenGroupNode
16008 }, React__default.createElement(EventListener, {
16009 event: "resize",
16010 handler: _this2.handleResize
16011 }), React__default.createElement("div", {
16012 className: styles$1q.ButtonGroupWrapper,
16013 ref: _this2.setLargeScreenButtonsNode
16014 }, largeGroupContent), paginatedSelectAllMarkup);
16015 });
16016 return React__default.createElement("div", {
16017 ref: this.setContainerNode
16018 }, smallScreenGroup, largeScreenGroup);
16019 }
16020 }, {
16021 key: "numberOfPromotedActionsToRender",
16022 get: function get() {
16023 var promotedActions = this.props.promotedActions;
16024 var _this$state3 = this.state,
16025 containerWidth = _this$state3.containerWidth,
16026 measuring = _this$state3.measuring;
16027
16028 if (!promotedActions) {
16029 return 0;
16030 }
16031
16032 if (containerWidth >= this.bulkActionsWidth || measuring) {
16033 return promotedActions.length;
16034 }
16035
16036 var sufficientSpace = false;
16037 var counter = promotedActions.length - 1;
16038 var totalWidth = 0;
16039
16040 while (!sufficientSpace && counter >= 0) {
16041 totalWidth += this.promotedActionsWidths[counter];
16042 var widthWithRemovedAction = this.bulkActionsWidth - totalWidth + this.addedMoreActionsWidthForMeasuring;
16043
16044 if (containerWidth >= widthWithRemovedAction) {
16045 sufficientSpace = true;
16046 } else {
16047 counter--;
16048 }
16049 }
16050
16051 return counter;
16052 }
16053 }, {
16054 key: "hasActions",
16055 get: function get() {
16056 var _this$props3 = this.props,
16057 promotedActions = _this$props3.promotedActions,
16058 actions = _this$props3.actions;
16059 return Boolean(promotedActions && promotedActions.length > 0 || actions && actions.length > 0);
16060 }
16061 }, {
16062 key: "actionSections",
16063 get: function get() {
16064 var actions = this.props.actions;
16065
16066 if (!actions || actions.length === 0) {
16067 return;
16068 }
16069
16070 if (instanceOfBulkActionListSectionArray(actions)) {
16071 return actions;
16072 }
16073
16074 if (instanceOfBulkActionArray(actions)) {
16075 return [{
16076 items: actions
16077 }];
16078 }
16079 }
16080 }]);
16081
16082 return BulkActions;
16083}(React__default.PureComponent);
16084
16085function instanceOfBulkActionListSectionArray(actions) {
16086 var validList = actions.filter(function (action) {
16087 return action.items;
16088 });
16089 return actions.length === validList.length;
16090}
16091
16092function instanceOfBulkActionArray(actions) {
16093 var validList = actions.filter(function (action) {
16094 return !action.items;
16095 });
16096 return actions.length === validList.length;
16097} // Use named export once withAppProvider is refactored away
16098// eslint-disable-next-line import/no-default-export
16099
16100
16101var BulkActions$1 = withAppProvider()(BulkActions);
16102
16103var styles$1r = {
16104 "DateTextField": "Polaris-FilterControl-DateSelector__DateTextField",
16105 "DatePicker": "Polaris-FilterControl-DateSelector__DatePicker"
16106};
16107
16108var VALID_DATE_REGEX = /^\d{4}-\d{1,2}-\d{1,2}$/;
16109var DateFilterOption;
16110
16111(function (DateFilterOption) {
16112 DateFilterOption["PastWeek"] = "past_week";
16113 DateFilterOption["PastMonth"] = "past_month";
16114 DateFilterOption["PastQuarter"] = "past_quarter";
16115 DateFilterOption["PastYear"] = "past_year";
16116 DateFilterOption["ComingWeek"] = "coming_week";
16117 DateFilterOption["ComingMonth"] = "coming_month";
16118 DateFilterOption["ComingQuarter"] = "coming_quarter";
16119 DateFilterOption["ComingYear"] = "coming_year";
16120 DateFilterOption["OnOrBefore"] = "on_or_before";
16121 DateFilterOption["OnOrAfter"] = "on_or_after";
16122})(DateFilterOption || (DateFilterOption = {}));
16123
16124var DateSelector = memo(function DateSelector(_ref) {
16125 var filterValue = _ref.filterValue,
16126 filterKey = _ref.filterKey,
16127 filterMinKey = _ref.filterMinKey,
16128 filterMaxKey = _ref.filterMaxKey,
16129 dateOptionType = _ref.dateOptionType,
16130 onFilterValueChange = _ref.onFilterValueChange,
16131 onFilterKeyChange = _ref.onFilterKeyChange;
16132 var now = new Date();
16133 var i18n = useI18n();
16134 var initialConsumerFilterKey = useRef(filterKey);
16135
16136 var _useState = useState(now.getMonth()),
16137 _useState2 = _slicedToArray(_useState, 2),
16138 datePickerMonth = _useState2[0],
16139 setDatePickerMonth = _useState2[1];
16140
16141 var _useState3 = useState(now.getFullYear()),
16142 _useState4 = _slicedToArray(_useState3, 2),
16143 datePickerYear = _useState4[0],
16144 setDatePickerYear = _useState4[1];
16145
16146 var _useState5 = useState(),
16147 _useState6 = _slicedToArray(_useState5, 2),
16148 selectedDate = _useState6[0],
16149 setSelectedDate = _useState6[1];
16150
16151 var _useState7 = useState(),
16152 _useState8 = _slicedToArray(_useState7, 2),
16153 userInputDate = _useState8[0],
16154 setUserInputDate = _useState8[1];
16155
16156 var _useState9 = useState(),
16157 _useState10 = _slicedToArray(_useState9, 2),
16158 userInputDateError = _useState10[0],
16159 setUserInputDateError = _useState10[1];
16160
16161 var dateTextFieldValue = getDateTextFieldValue();
16162 var handleDateFieldChange = useCallback(function (value) {
16163 if (value.length === 0) {
16164 setSelectedDate(undefined);
16165 onFilterValueChange(undefined);
16166 }
16167
16168 if (userInputDateError && isValidDate(value)) {
16169 setUserInputDateError(undefined);
16170 }
16171
16172 setUserInputDate(value);
16173 }, [onFilterValueChange, userInputDateError]);
16174 var handleDateChanged = useCallback(function (date) {
16175 if (!date) {
16176 return;
16177 }
16178
16179 onFilterValueChange(stripTimeFromISOString(formatDateForLocalTimezone(date)));
16180 }, [onFilterValueChange]);
16181 var handleDateBlur = useCallback(function () {
16182 if (!dateTextFieldValue || !isValidDate(dateTextFieldValue)) {
16183 setSelectedDate(undefined);
16184 setUserInputDateError(i18n.translate('Polaris.ResourceList.DateSelector.dateValueError'));
16185 onFilterValueChange(undefined);
16186 return;
16187 }
16188
16189 if (!userInputDate) {
16190 return;
16191 }
16192
16193 var formattedDateForTimezone = new Date(formatDateForLocalTimezone(new Date(userInputDate)));
16194 setSelectedDate(formattedDateForTimezone);
16195 setDatePickerMonth(formattedDateForTimezone.getMonth());
16196 setDatePickerYear(formattedDateForTimezone.getFullYear());
16197 setUserInputDate(undefined);
16198 setUserInputDateError(undefined);
16199 handleDateChanged(formattedDateForTimezone);
16200 }, [dateTextFieldValue, handleDateChanged, i18n, onFilterValueChange, userInputDate]);
16201 var handleDateFilterOptionsChange = useCallback(function (newOption) {
16202 if (!initialConsumerFilterKey.current) {
16203 return;
16204 }
16205
16206 if (newOption === DateFilterOption.OnOrBefore) {
16207 onFilterKeyChange(filterMaxKey);
16208 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
16209 return;
16210 }
16211
16212 if (newOption === DateFilterOption.OnOrAfter) {
16213 onFilterKeyChange(filterMinKey);
16214 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
16215 return;
16216 }
16217
16218 onFilterKeyChange(initialConsumerFilterKey.current);
16219 onFilterValueChange(newOption);
16220 }, [filterMaxKey, filterMinKey, initialConsumerFilterKey, onFilterKeyChange, onFilterValueChange, selectedDate]);
16221 var handleDatePickerChange = useCallback(function (_ref2) {
16222 var nextDate = _ref2.end;
16223 var date = new Date(nextDate);
16224 setSelectedDate(date);
16225 setUserInputDate(undefined);
16226 setUserInputDateError(undefined);
16227 handleDateChanged(date);
16228 }, [handleDateChanged]);
16229 var handleDatePickerMonthChange = useCallback(function (month, year) {
16230 setDatePickerMonth(month);
16231 setDatePickerYear(year);
16232 }, []);
16233 var dateFilterOption = getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey);
16234 var showDatePredicate = dateFilterOption === DateFilterOption.OnOrBefore || dateFilterOption === DateFilterOption.OnOrAfter;
16235 var datePredicateMarkup = showDatePredicate && React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
16236 className: styles$1r.DateTextField
16237 }, React__default.createElement(TextField, {
16238 label: i18n.translate('Polaris.ResourceList.DateSelector.dateValueLabel'),
16239 placeholder: i18n.translate('Polaris.ResourceList.DateSelector.dateValuePlaceholder'),
16240 value: dateTextFieldValue,
16241 error: userInputDateError,
16242 prefix: React__default.createElement(Icon, {
16243 source: CalendarMinor,
16244 color: "skyDark"
16245 }),
16246 autoComplete: false,
16247 onChange: handleDateFieldChange,
16248 onBlur: handleDateBlur
16249 })), React__default.createElement("div", {
16250 className: styles$1r.DatePicker
16251 }, React__default.createElement(DatePicker, {
16252 selected: selectedDate,
16253 month: datePickerMonth,
16254 year: datePickerYear,
16255 onChange: handleDatePickerChange,
16256 onMonthChange: handleDatePickerMonthChange
16257 })));
16258 var dateOptionTypes = {
16259 past: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateComparatorOptions())),
16260 future: [].concat(_toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions())),
16261 full: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions()))
16262 };
16263 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Select, {
16264 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.dateFilterLabel'),
16265 labelHidden: true,
16266 options: dateOptionType ? dateOptionTypes[dateOptionType] : dateOptionTypes.full,
16267 placeholder: i18n.translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
16268 value: dateFilterOption,
16269 onChange: handleDateFilterOptionsChange
16270 }), datePredicateMarkup);
16271
16272 function getDateComparatorOptions() {
16273 return [{
16274 value: DateFilterOption.OnOrBefore,
16275 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrBefore')
16276 }, {
16277 value: DateFilterOption.OnOrAfter,
16278 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrAfter')
16279 }];
16280 }
16281
16282 function getDatePastOptions() {
16283 return [{
16284 value: DateFilterOption.PastWeek,
16285 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastWeek')
16286 }, {
16287 value: DateFilterOption.PastMonth,
16288 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastMonth')
16289 }, {
16290 value: DateFilterOption.PastQuarter,
16291 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastQuarter')
16292 }, {
16293 value: DateFilterOption.PastYear,
16294 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastYear')
16295 }];
16296 }
16297
16298 function getDateFutureOptions() {
16299 return [{
16300 value: DateFilterOption.ComingWeek,
16301 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingWeek')
16302 }, {
16303 value: DateFilterOption.ComingMonth,
16304 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingMonth')
16305 }, {
16306 value: DateFilterOption.ComingQuarter,
16307 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingQuarter')
16308 }, {
16309 value: DateFilterOption.ComingYear,
16310 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingYear')
16311 }];
16312 }
16313
16314 function getDateTextFieldValue() {
16315 if (!userInputDate && !selectedDate) {
16316 return undefined;
16317 }
16318
16319 if (userInputDate !== undefined) {
16320 return userInputDate;
16321 }
16322
16323 if (selectedDate) {
16324 return stripTimeFromISOString(formatDateForLocalTimezone(selectedDate));
16325 }
16326 }
16327});
16328
16329function isValidDate(date) {
16330 if (!date) {
16331 return false;
16332 }
16333
16334 return VALID_DATE_REGEX.test(date) && !isNaN(new Date(date).getTime());
16335}
16336
16337function getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey) {
16338 if (filterKey === filterMaxKey) {
16339 return DateFilterOption.OnOrBefore;
16340 }
16341
16342 if (filterKey === filterMinKey) {
16343 return DateFilterOption.OnOrAfter;
16344 }
16345
16346 return filterValue;
16347}
16348
16349function stripTimeFromISOString(ISOString) {
16350 return ISOString.slice(0, 10);
16351}
16352
16353function formatDateForLocalTimezone(date) {
16354 var timezoneOffset = date.getTimezoneOffset();
16355 var timezoneOffsetMs = timezoneOffset * 60 * 1000;
16356 var isFringeTimezone = timezoneOffset === -720 || timezoneOffset === 720;
16357 var formattedDate = new Date();
16358
16359 if (isFringeTimezone && date.getHours() !== 0) {
16360 return date.toISOString();
16361 }
16362
16363 var newTime = timezoneOffset > -1 ? date.getTime() + timezoneOffsetMs : date.getTime() - timezoneOffsetMs;
16364 formattedDate.setTime(newTime);
16365 return formattedDate.toISOString();
16366}
16367
16368var FilterType;
16369
16370(function (FilterType) {
16371 FilterType[FilterType["Select"] = 0] = "Select";
16372 FilterType[FilterType["TextField"] = 1] = "TextField";
16373 FilterType[FilterType["DateSelector"] = 2] = "DateSelector";
16374})(FilterType || (FilterType = {}));
16375
16376/**
16377 * Returns a MutatableRefObject containing a boolean value that
16378 * represents a components mounted status.
16379 * @returns MutableRefObject<boolean> The mounted status
16380 */
16381
16382function useIsMountedRef() {
16383 var isMounted = useRef(false);
16384 useEffect(function () {
16385 isMounted.current = true;
16386 return function () {
16387 isMounted.current = false;
16388 };
16389 }, []);
16390 return isMounted;
16391}
16392
16393function FilterValueSelector(_ref) {
16394 var filter = _ref.filter,
16395 filterKey = _ref.filterKey,
16396 value = _ref.value,
16397 onChange = _ref.onChange,
16398 onFilterKeyChange = _ref.onFilterKeyChange;
16399
16400 var _useI18n = useI18n(),
16401 translate = _useI18n.translate;
16402
16403 var isMounted = useIsMountedRef();
16404 var operatorText = filter.operatorText,
16405 type = filter.type,
16406 label = filter.label;
16407 var showOperatorOptions = type !== FilterType.DateSelector && operatorText && typeof operatorText !== 'string';
16408 var handleOperatorOptionChange = useCallback(function (operatorKey) {
16409 onFilterKeyChange(operatorKey);
16410
16411 if (!value) {
16412 return;
16413 }
16414
16415 onChange(value);
16416 }, [onChange, onFilterKeyChange, value]);
16417
16418 if (showOperatorOptions && operatorText.length !== 0 && !isMounted.current) {
16419 handleOperatorOptionChange(operatorText[0].key);
16420 }
16421
16422 var operatorOptionsMarkup = showOperatorOptions ? React__default.createElement(Select, {
16423 label: label,
16424 labelHidden: true,
16425 options: buildOperatorOptions(operatorText),
16426 value: filterKey,
16427 onChange: handleOperatorOptionChange
16428 }) : null;
16429 var selectedFilterLabel = typeof operatorText === 'string' ? operatorText : '';
16430
16431 switch (filter.type) {
16432 case FilterType.Select:
16433 return React__default.createElement(Stack, {
16434 vertical: true
16435 }, operatorOptionsMarkup, React__default.createElement(Select, {
16436 label: selectedFilterLabel,
16437 options: filter.options,
16438 placeholder: translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
16439 value: value,
16440 onChange: onChange
16441 }));
16442
16443 case FilterType.TextField:
16444 return React__default.createElement(Stack, {
16445 vertical: true
16446 }, operatorOptionsMarkup, React__default.createElement(TextField, {
16447 label: selectedFilterLabel,
16448 value: value,
16449 type: filter.textFieldType,
16450 onChange: onChange
16451 }));
16452
16453 case FilterType.DateSelector:
16454 return React__default.createElement(DateSelector, {
16455 dateOptionType: filter.dateOptionType,
16456 filterValue: value,
16457 filterKey: filterKey,
16458 filterMinKey: filter.minKey,
16459 filterMaxKey: filter.maxKey,
16460 onFilterValueChange: onChange,
16461 onFilterKeyChange: onFilterKeyChange
16462 });
16463
16464 default:
16465 return null;
16466 }
16467}
16468
16469function buildOperatorOptions(operatorText) {
16470 if (!operatorText || typeof operatorText === 'string') {
16471 return [];
16472 }
16473
16474 return operatorText.map(function (_ref2) {
16475 var key = _ref2.key,
16476 optionLabel = _ref2.optionLabel;
16477 return {
16478 value: key,
16479 label: optionLabel
16480 };
16481 });
16482}
16483
16484function FilterCreator(_ref) {
16485 var filters = _ref.filters,
16486 resourceName = _ref.resourceName,
16487 disabled = _ref.disabled,
16488 onAddFilter = _ref.onAddFilter;
16489
16490 var _useForcibleToggle = useForcibleToggle(false),
16491 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
16492 popoverActive = _useForcibleToggle2[0],
16493 _useForcibleToggle2$ = _useForcibleToggle2[1],
16494 togglePopoverActive = _useForcibleToggle2$.toggle,
16495 setPopoverActiveFalse = _useForcibleToggle2$.forceFalse;
16496
16497 var _useState = useState(),
16498 _useState2 = _slicedToArray(_useState, 2),
16499 selectedFilter = _useState2[0],
16500 setSelectedFilter = _useState2[1];
16501
16502 var _useState3 = useState(),
16503 _useState4 = _slicedToArray(_useState3, 2),
16504 selectedFilterKey = _useState4[0],
16505 setSelectedFilterKey = _useState4[1];
16506
16507 var _useState5 = useState(),
16508 _useState6 = _slicedToArray(_useState5, 2),
16509 selectedFilterValue = _useState6[0],
16510 setSelectedFilterValue = _useState6[1];
16511
16512 var i18n = useI18n();
16513 var node = useRef(null);
16514 var canAddFilter = Boolean(selectedFilter && selectedFilterKey && selectedFilterValue);
16515 var handleButtonFocus = useCallback(function () {
16516 var event = arguments.length <= 0 ? undefined : arguments[0];
16517
16518 if (!node.current && event) {
16519 // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065
16520 node.current = event.target;
16521 }
16522 }, []);
16523 var handleFilterKeyChange = useCallback(function (filterKey) {
16524 var foundFilter = filters.find(function (filter) {
16525 var minKey = filter.minKey,
16526 maxKey = filter.maxKey,
16527 operatorText = filter.operatorText;
16528
16529 if (minKey || maxKey) {
16530 return filter.key === filterKey || minKey === filterKey || maxKey === filterKey;
16531 }
16532
16533 if (operatorText && typeof operatorText !== 'string') {
16534 return filter.key === filterKey || operatorText.filter(function (_ref2) {
16535 var key = _ref2.key;
16536 return key === filterKey;
16537 }).length === 1;
16538 }
16539
16540 return filter.key === filterKey;
16541 });
16542
16543 if (!foundFilter) {
16544 return;
16545 }
16546
16547 setSelectedFilter(foundFilter);
16548 setSelectedFilterKey(filterKey);
16549 setSelectedFilterValue(undefined);
16550 }, [filters]);
16551 var handleFilterValueChange = useCallback(function (value) {
16552 setSelectedFilterValue(value);
16553 }, []);
16554 var handleAddFilter = useCallback(function () {
16555 if (!onAddFilter || !canAddFilter || !selectedFilterKey) {
16556 return;
16557 }
16558
16559 onAddFilter({
16560 key: selectedFilterKey,
16561 value: selectedFilterValue || ''
16562 });
16563 setPopoverActiveFalse();
16564 setSelectedFilter(undefined);
16565 setSelectedFilterValue(undefined);
16566
16567 if (node.current != null) {
16568 node.current.focus();
16569 }
16570 }, [canAddFilter, onAddFilter, selectedFilterKey, selectedFilterValue, setPopoverActiveFalse]);
16571 var activator = React__default.createElement(Button, {
16572 onClick: togglePopoverActive,
16573 disclosure: true,
16574 disabled: disabled,
16575 onFocus: handleButtonFocus
16576 }, i18n.translate('Polaris.ResourceList.FilterCreator.filterButtonLabel'));
16577 var filterOptions = filters.map(function (_ref3) {
16578 var key = _ref3.key,
16579 label = _ref3.label;
16580 return {
16581 value: key,
16582 label
16583 };
16584 });
16585 var filterValueSelectionMarkup = selectedFilter ? React__default.createElement(FilterValueSelector, {
16586 filter: selectedFilter,
16587 filterKey: selectedFilterKey,
16588 value: selectedFilterValue,
16589 onFilterKeyChange: handleFilterKeyChange,
16590 onChange: handleFilterValueChange
16591 }) : null;
16592 var addFilterButtonMarkup = selectedFilter ? React__default.createElement(Button, {
16593 onClick: handleAddFilter,
16594 disabled: !canAddFilter
16595 }, i18n.translate('Polaris.ResourceList.FilterCreator.addFilterButtonLabel')) : null;
16596 return React__default.createElement(Popover, {
16597 active: popoverActive,
16598 activator: activator,
16599 onClose: togglePopoverActive,
16600 sectioned: true,
16601 fullHeight: true
16602 }, React__default.createElement(Form, {
16603 onSubmit: handleAddFilter
16604 }, React__default.createElement(FormLayout, null, React__default.createElement(Select, {
16605 label: i18n.translate('Polaris.ResourceList.FilterCreator.showAllWhere', {
16606 resourceNamePlural: resourceName.plural.toLocaleLowerCase()
16607 }),
16608 placeholder: i18n.translate('Polaris.ResourceList.FilterCreator.selectFilterKeyPlaceholder'),
16609 options: filterOptions,
16610 onChange: handleFilterKeyChange,
16611 value: selectedFilter && selectedFilter.key
16612 }), filterValueSelectionMarkup, addFilterButtonMarkup)));
16613}
16614
16615var styles$1s = {
16616 "AppliedFilters": "Polaris-ResourceList-FilterControl__AppliedFilters",
16617 "AppliedFilter": "Polaris-ResourceList-FilterControl__AppliedFilter"
16618};
16619
16620/** @deprecated Use <Filters /> instead. */
16621
16622function FilterControl(_ref) {
16623 var searchValue = _ref.searchValue,
16624 _ref$appliedFilters = _ref.appliedFilters,
16625 appliedFilters = _ref$appliedFilters === void 0 ? [] : _ref$appliedFilters,
16626 additionalAction = _ref.additionalAction,
16627 _ref$focused = _ref.focused,
16628 focused = _ref$focused === void 0 ? false : _ref$focused,
16629 _ref$filters = _ref.filters,
16630 filters = _ref$filters === void 0 ? [] : _ref$filters,
16631 placeholder = _ref.placeholder,
16632 onSearchBlur = _ref.onSearchBlur,
16633 onSearchChange = _ref.onSearchChange,
16634 onFiltersChange = _ref.onFiltersChange;
16635 // eslint-disable-next-line no-console
16636 console.warn('Deprecation: <FilterControl /> is deprecated. Use <Filters /> instead.');
16637 var i18n = useI18n();
16638
16639 var _React$useContext = React__default.useContext(ResourceListContext),
16640 selectMode = _React$useContext.selectMode,
16641 resourceName = _React$useContext.resourceName;
16642
16643 var filterResourceName = resourceName || {
16644 singular: i18n.translate('Polaris.ResourceList.defaultItemSingular'),
16645 plural: i18n.translate('Polaris.ResourceList.defaultItemPlural')
16646 };
16647 var handleAddFilter = React__default.useCallback(function (newFilter) {
16648 if (!onFiltersChange) {
16649 return;
16650 }
16651
16652 var foundFilter = appliedFilters.find(function (appliedFilter) {
16653 return idFromFilter(appliedFilter) === idFromFilter(newFilter);
16654 });
16655
16656 if (foundFilter) {
16657 return;
16658 }
16659
16660 var newAppliedFilters = [].concat(_toConsumableArray(appliedFilters), [newFilter]);
16661 onFiltersChange(newAppliedFilters);
16662 }, [onFiltersChange, appliedFilters]);
16663 var handleRemoveFilter = React__default.useCallback(function (filterId) {
16664 if (!onFiltersChange) {
16665 return;
16666 }
16667
16668 var foundIndex = appliedFilters.findIndex(function (appliedFilter) {
16669 return idFromFilter(appliedFilter) === filterId;
16670 });
16671 var newAppliedFilters = foundIndex >= 0 ? [].concat(_toConsumableArray(appliedFilters.slice(0, foundIndex)), _toConsumableArray(appliedFilters.slice(foundIndex + 1, appliedFilters.length))) : _toConsumableArray(appliedFilters);
16672 onFiltersChange(newAppliedFilters);
16673 }, [appliedFilters, onFiltersChange]);
16674 var getRemoveFilterCallback = React__default.useCallback(function (filterId) {
16675 return function () {
16676 handleRemoveFilter(filterId);
16677 };
16678 }, [handleRemoveFilter]);
16679 var textFieldLabel = placeholder ? placeholder : i18n.translate('Polaris.ResourceList.FilterControl.textFieldLabel', {
16680 resourceNamePlural: filterResourceName.plural.toLocaleLowerCase()
16681 });
16682
16683 if (additionalAction) {
16684 additionalAction.disabled = selectMode;
16685 }
16686
16687 var additionalActionButton = additionalAction && buttonsFrom(additionalAction) || null;
16688 var filterCreatorMarkup = filters.length > 0 ? React__default.createElement(FilterCreator, {
16689 resourceName: filterResourceName,
16690 filters: filters,
16691 onAddFilter: handleAddFilter,
16692 disabled: selectMode
16693 }) : null;
16694 var appliedFiltersMarkup = appliedFilters.map(function (appliedFilter) {
16695 var activeFilterLabel = getFilterLabel(appliedFilter);
16696 var filterId = idFromFilter(appliedFilter);
16697 return React__default.createElement("li", {
16698 className: styles$1s.AppliedFilter,
16699 key: filterId
16700 }, React__default.createElement(Tag, {
16701 onRemove: getRemoveFilterCallback(filterId),
16702 disabled: selectMode
16703 }, activeFilterLabel));
16704 });
16705 var appliedFiltersWrapper = appliedFilters.length > 0 ? React__default.createElement("ul", {
16706 className: styles$1s.AppliedFilters
16707 }, appliedFiltersMarkup) : null;
16708 return React__default.createElement(FormLayout, null, React__default.createElement(TextField, {
16709 connectedLeft: filterCreatorMarkup,
16710 connectedRight: additionalActionButton,
16711 label: textFieldLabel,
16712 labelHidden: true,
16713 placeholder: textFieldLabel,
16714 prefix: React__default.createElement(Icon, {
16715 source: SearchMinor,
16716 color: "skyDark"
16717 }),
16718 value: searchValue,
16719 onChange: onSearchChange,
16720 onBlur: onSearchBlur,
16721 focused: focused,
16722 disabled: selectMode
16723 }), appliedFiltersWrapper);
16724
16725 function getFilterLabel(appliedFilter) {
16726 var key = appliedFilter.key,
16727 value = appliedFilter.value,
16728 label = appliedFilter.label;
16729
16730 if (label) {
16731 return label;
16732 }
16733
16734 var filter = filters.find(function (filter) {
16735 var minKey = filter.minKey,
16736 maxKey = filter.maxKey,
16737 operatorText = filter.operatorText;
16738
16739 if (minKey || maxKey) {
16740 return filter.key === key || minKey === key || maxKey === key;
16741 }
16742
16743 if (operatorText && typeof operatorText !== 'string') {
16744 return filter.key === key || operatorText.filter(function (_ref2) {
16745 var operatorKey = _ref2.key;
16746 return operatorKey === key;
16747 }).length === 1;
16748 }
16749
16750 return filter.key === key;
16751 });
16752
16753 if (!filter) {
16754 return value;
16755 }
16756
16757 var filterOperatorLabel = findOperatorLabel(filter, appliedFilter);
16758 var filterLabelByType = findFilterLabelByType(filter, appliedFilter);
16759
16760 if (!filterOperatorLabel) {
16761 return "".concat(filter.label, " ").concat(filterLabelByType);
16762 }
16763
16764 return "".concat(filter.label, " ").concat(filterOperatorLabel, " ").concat(filterLabelByType);
16765 }
16766
16767 function findFilterLabelByType(filter, appliedFilter) {
16768 var appliedFilterValue = appliedFilter.value;
16769
16770 if (filter.type === FilterType.Select) {
16771 var foundFilterOption = filter.options.find(function (option) {
16772 return typeof option === 'string' ? option === appliedFilterValue : option.value === appliedFilterValue;
16773 });
16774
16775 if (foundFilterOption) {
16776 return typeof foundFilterOption === 'string' ? foundFilterOption : foundFilterOption.label;
16777 }
16778 }
16779
16780 if (filter.type === FilterType.DateSelector) {
16781 if (filter.key === appliedFilter.key) {
16782 var filterLabelKey = "Polaris.ResourceList.DateSelector.FilterLabelForValue.".concat(appliedFilter.value);
16783 return i18n.translationKeyExists(filterLabelKey) ? i18n.translate(filterLabelKey) : appliedFilter.value;
16784 }
16785
16786 if (appliedFilter.key === filter.maxKey) {
16787 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_before', {
16788 date: formatDateForLabelDisplay(appliedFilter.value)
16789 });
16790 }
16791
16792 if (appliedFilter.key === filter.minKey) {
16793 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_after', {
16794 date: formatDateForLabelDisplay(appliedFilter.value)
16795 });
16796 }
16797 }
16798
16799 return appliedFilterValue;
16800 }
16801}
16802
16803function idFromFilter(appliedFilter) {
16804 return "".concat(appliedFilter.key, "-").concat(appliedFilter.value);
16805}
16806
16807function formatDateForLabelDisplay(date) {
16808 if (isNaN(new Date(date).getTime())) {
16809 return date;
16810 }
16811
16812 return new Date(date.replace(/-/g, '/')).toLocaleDateString();
16813}
16814
16815function findOperatorLabel(filter, appliedFilter) {
16816 var operatorText = filter.operatorText;
16817
16818 if (filter.type === FilterType.DateSelector && (appliedFilter.key === filter.minKey || appliedFilter.key === filter.maxKey)) {
16819 return '';
16820 }
16821
16822 if (!operatorText || typeof operatorText === 'string') {
16823 return operatorText;
16824 }
16825
16826 var appliedOperator = operatorText.find(function (operator) {
16827 return operator.key === appliedFilter.key;
16828 });
16829
16830 if (appliedOperator) {
16831 return appliedOperator.filterLabel || appliedOperator.optionLabel;
16832 }
16833}
16834
16835var styles$1t = {
16836 "FiltersWrapper": "Polaris-ResourceList__FiltersWrapper",
16837 "ResourceList": "Polaris-ResourceList",
16838 "HeaderOuterWrapper": "Polaris-ResourceList__HeaderOuterWrapper",
16839 "HeaderWrapper-disabled": "Polaris-ResourceList__HeaderWrapper--disabled",
16840 "HeaderWrapper-overlay": "Polaris-ResourceList__HeaderWrapper--overlay",
16841 "HeaderWrapper": "Polaris-ResourceList__HeaderWrapper",
16842 "HeaderWrapper-isSticky": "Polaris-ResourceList__HeaderWrapper--isSticky",
16843 "HeaderContentWrapper": "Polaris-ResourceList__HeaderContentWrapper",
16844 "HeaderWrapper-inSelectMode": "Polaris-ResourceList__HeaderWrapper--inSelectMode",
16845 "SortWrapper": "Polaris-ResourceList__SortWrapper",
16846 "AlternateToolWrapper": "Polaris-ResourceList__AlternateToolWrapper",
16847 "HeaderWrapper-hasSelect": "Polaris-ResourceList__HeaderWrapper--hasSelect",
16848 "HeaderWrapper-hasAlternateTool": "Polaris-ResourceList__HeaderWrapper--hasAlternateTool",
16849 "HeaderWrapper-hasSort": "Polaris-ResourceList__HeaderWrapper--hasSort",
16850 "HeaderTitleWrapper": "Polaris-ResourceList__HeaderTitleWrapper",
16851 "BulkActionsWrapper": "Polaris-ResourceList__BulkActionsWrapper",
16852 "CheckableButtonWrapper": "Polaris-ResourceList__CheckableButtonWrapper",
16853 "SelectButtonWrapper": "Polaris-ResourceList__SelectButtonWrapper",
16854 "EmptySearchResultWrapper": "Polaris-ResourceList__EmptySearchResultWrapper",
16855 "ResourceListWrapper": "Polaris-ResourceList__ResourceListWrapper",
16856 "ItemWrapper": "Polaris-ResourceList__ItemWrapper",
16857 "ItemWrapper-isLoading": "Polaris-ResourceList__ItemWrapper--isLoading",
16858 "SpinnerContainer": "Polaris-ResourceList__SpinnerContainer",
16859 "LoadingOverlay": "Polaris-ResourceList__LoadingOverlay",
16860 "DisabledPointerEvents": "Polaris-ResourceList__DisabledPointerEvents",
16861 "disableTextSelection": "Polaris-ResourceList--disableTextSelection"
16862};
16863
16864var SMALL_SCREEN_WIDTH = 458;
16865var SMALL_SPINNER_HEIGHT = 28;
16866var LARGE_SPINNER_HEIGHT = 45;
16867
16868var ResourceList =
16869/*#__PURE__*/
16870function (_React$Component) {
16871 _inherits(ResourceList, _React$Component);
16872
16873 function ResourceList(props) {
16874 var _this;
16875
16876 _classCallCheck(this, ResourceList);
16877
16878 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourceList).call(this, props));
16879 _this.listRef = React__default.createRef();
16880 _this.handleResize = debounce(function () {
16881 var selectedItems = _this.props.selectedItems;
16882 var _this$state = _this.state,
16883 selectMode = _this$state.selectMode,
16884 smallScreen = _this$state.smallScreen;
16885 var newSmallScreen = isSmallScreen();
16886
16887 if (selectedItems && selectedItems.length === 0 && selectMode && !newSmallScreen) {
16888 _this.handleSelectMode(false);
16889 }
16890
16891 if (smallScreen !== newSmallScreen) {
16892 _this.setState({
16893 smallScreen: newSmallScreen
16894 });
16895 }
16896 }, 50, {
16897 leading: true,
16898 trailing: true,
16899 maxWait: 50
16900 });
16901
16902 _this.setLoadingPosition = function () {
16903 if (_this.listRef.current != null) {
16904 if (typeof window === 'undefined') {
16905 return;
16906 }
16907
16908 var overlay = _this.listRef.current.getBoundingClientRect();
16909
16910 var viewportHeight = Math.max(document.documentElement ? document.documentElement.clientHeight : 0, window.innerHeight || 0);
16911 var overflow = viewportHeight - overlay.height;
16912 var spinnerHeight = _this.props.items.length === 1 ? SMALL_SPINNER_HEIGHT : LARGE_SPINNER_HEIGHT;
16913 var spinnerPosition = overflow > 0 ? (overlay.height - spinnerHeight) / 2 : (viewportHeight - overlay.top - spinnerHeight) / 2;
16914
16915 _this.setState({
16916 loadingPosition: spinnerPosition
16917 });
16918 }
16919 };
16920
16921 _this.handleSelectAllItemsInStore = function () {
16922 var _this$props = _this.props,
16923 onSelectionChange = _this$props.onSelectionChange,
16924 selectedItems = _this$props.selectedItems,
16925 items = _this$props.items,
16926 _this$props$idForItem = _this$props.idForItem,
16927 idForItem = _this$props$idForItem === void 0 ? defaultIdForItem : _this$props$idForItem;
16928 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : SELECT_ALL_ITEMS;
16929
16930 if (onSelectionChange) {
16931 onSelectionChange(newlySelectedItems);
16932 }
16933 };
16934
16935 _this.renderItem = function (item, index) {
16936 var _this$props2 = _this.props,
16937 renderItem = _this$props2.renderItem,
16938 _this$props2$idForIte = _this$props2.idForItem,
16939 idForItem = _this$props2$idForIte === void 0 ? defaultIdForItem : _this$props2$idForIte;
16940 var id = idForItem(item, index);
16941 return React__default.createElement("li", {
16942 key: id,
16943 className: styles$1t.ItemWrapper
16944 }, renderItem(item, id, index));
16945 };
16946
16947 _this.handleMultiSelectionChange = function (lastSelected, currentSelected, resolveItemId) {
16948 var min = Math.min(lastSelected, currentSelected);
16949 var max = Math.max(lastSelected, currentSelected);
16950 return _this.props.items.slice(min, max + 1).map(resolveItemId);
16951 };
16952
16953 _this.handleCheckableButtonRegistration = function (key, button) {
16954 _this.setState(function (_ref) {
16955 var checkableButtons = _ref.checkableButtons;
16956 return {
16957 checkableButtons: new Map(checkableButtons).set(key, button)
16958 };
16959 });
16960 };
16961
16962 _this.handleSelectionChange = function (selected, id, sortOrder, shiftKey) {
16963 var _this$props3 = _this.props,
16964 onSelectionChange = _this$props3.onSelectionChange,
16965 selectedItems = _this$props3.selectedItems,
16966 items = _this$props3.items,
16967 _this$props3$idForIte = _this$props3.idForItem,
16968 idForItem = _this$props3$idForIte === void 0 ? defaultIdForItem : _this$props3$idForIte,
16969 resolveItemId = _this$props3.resolveItemId;
16970 var lastSelected = _this.state.lastSelected;
16971
16972 if (selectedItems == null || onSelectionChange == null) {
16973 return;
16974 }
16975
16976 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : _toConsumableArray(selectedItems);
16977
16978 if (sortOrder !== undefined) {
16979 _this.setState({
16980 lastSelected: sortOrder
16981 });
16982 }
16983
16984 var selectedIds = [id];
16985
16986 if (shiftKey && lastSelected != null && sortOrder !== undefined && resolveItemId) {
16987 selectedIds = _this.handleMultiSelectionChange(lastSelected, sortOrder, resolveItemId);
16988 }
16989
16990 newlySelectedItems = _toConsumableArray(new Set([].concat(_toConsumableArray(newlySelectedItems), _toConsumableArray(selectedIds))));
16991
16992 if (!selected) {
16993 var _iteratorNormalCompletion = true;
16994 var _didIteratorError = false;
16995 var _iteratorError = undefined;
16996
16997 try {
16998 for (var _iterator = selectedIds[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
16999 var selectedId = _step.value;
17000 newlySelectedItems.splice(newlySelectedItems.indexOf(selectedId), 1);
17001 }
17002 } catch (err) {
17003 _didIteratorError = true;
17004 _iteratorError = err;
17005 } finally {
17006 try {
17007 if (!_iteratorNormalCompletion && _iterator.return != null) {
17008 _iterator.return();
17009 }
17010 } finally {
17011 if (_didIteratorError) {
17012 throw _iteratorError;
17013 }
17014 }
17015 }
17016 }
17017
17018 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
17019 _this.handleSelectMode(false);
17020 } else if (newlySelectedItems.length > 0) {
17021 _this.handleSelectMode(true);
17022 }
17023
17024 if (onSelectionChange) {
17025 onSelectionChange(newlySelectedItems);
17026 }
17027 };
17028
17029 _this.handleSelectMode = function (selectMode) {
17030 var onSelectionChange = _this.props.onSelectionChange;
17031
17032 _this.setState({
17033 selectMode
17034 });
17035
17036 if (!selectMode && onSelectionChange) {
17037 onSelectionChange([]);
17038 }
17039 };
17040
17041 _this.handleToggleAll = function () {
17042 var _this$props4 = _this.props,
17043 onSelectionChange = _this$props4.onSelectionChange,
17044 selectedItems = _this$props4.selectedItems,
17045 items = _this$props4.items,
17046 _this$props4$idForIte = _this$props4.idForItem,
17047 idForItem = _this$props4$idForIte === void 0 ? defaultIdForItem : _this$props4$idForIte;
17048 var checkableButtons = _this.state.checkableButtons;
17049 var newlySelectedItems = [];
17050
17051 if (Array.isArray(selectedItems) && selectedItems.length === items.length || selectedItems === SELECT_ALL_ITEMS) {
17052 newlySelectedItems = [];
17053 } else {
17054 newlySelectedItems = items.map(function (item, index) {
17055 var id = idForItem(item, index);
17056 return id;
17057 });
17058 }
17059
17060 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
17061 _this.handleSelectMode(false);
17062 } else if (newlySelectedItems.length > 0) {
17063 _this.handleSelectMode(true);
17064 }
17065
17066 var checkbox;
17067
17068 if (isSmallScreen()) {
17069 checkbox = checkableButtons.get('bulkSm');
17070 } else if (newlySelectedItems.length === 0) {
17071 checkbox = checkableButtons.get('plain');
17072 } else {
17073 checkbox = checkableButtons.get('bulkLg');
17074 }
17075
17076 if (onSelectionChange) {
17077 onSelectionChange(newlySelectedItems);
17078 } // setTimeout ensures execution after the Transition on BulkActions
17079
17080
17081 setTimeout(function () {
17082 checkbox && checkbox.focus();
17083 }, 0);
17084 };
17085
17086 var selectedItems = props.selectedItems,
17087 intl = props.polaris.intl;
17088 _this.defaultResourceName = {
17089 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
17090 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
17091 }; // eslint-disable-next-line react/state-in-constructor
17092
17093 _this.state = {
17094 selectMode: Boolean(selectedItems && selectedItems.length > 0),
17095 loadingPosition: 0,
17096 lastSelected: null,
17097 smallScreen: isSmallScreen(),
17098 checkableButtons: new Map()
17099 };
17100 return _this;
17101 }
17102
17103 _createClass(ResourceList, [{
17104 key: "componentDidMount",
17105 value: function componentDidMount() {
17106 this.forceUpdate();
17107
17108 if (this.props.loading) {
17109 this.setLoadingPosition();
17110 }
17111 }
17112 }, {
17113 key: "componentDidUpdate",
17114 value: function componentDidUpdate(_ref2) {
17115 var prevLoading = _ref2.loading,
17116 prevItems = _ref2.items,
17117 prevSelectedItems = _ref2.selectedItems;
17118 var _this$props5 = this.props,
17119 selectedItems = _this$props5.selectedItems,
17120 loading = _this$props5.loading;
17121
17122 if (this.listRef.current && this.itemsExist() && !this.itemsExist(prevItems)) {
17123 this.forceUpdate();
17124 }
17125
17126 if (loading && !prevLoading) {
17127 this.setLoadingPosition();
17128 }
17129
17130 if (selectedItems && selectedItems.length > 0 && !this.state.selectMode) {
17131 // eslint-disable-next-line react/no-did-update-set-state
17132 this.setState({
17133 selectMode: true
17134 });
17135 return;
17136 }
17137
17138 if (prevSelectedItems && prevSelectedItems.length > 0 && (!selectedItems || selectedItems.length === 0) && !isSmallScreen()) {
17139 // eslint-disable-next-line react/no-did-update-set-state
17140 this.setState({
17141 selectMode: false
17142 });
17143 }
17144 }
17145 }, {
17146 key: "render",
17147 value: function render() {
17148 var _this2 = this;
17149
17150 var _this$props6 = this.props,
17151 items = _this$props6.items,
17152 promotedBulkActions = _this$props6.promotedBulkActions,
17153 bulkActions = _this$props6.bulkActions,
17154 filterControl = _this$props6.filterControl,
17155 loading = _this$props6.loading,
17156 _this$props6$showHead = _this$props6.showHeader,
17157 showHeader = _this$props6$showHead === void 0 ? false : _this$props6$showHead,
17158 sortOptions = _this$props6.sortOptions,
17159 sortValue = _this$props6.sortValue,
17160 alternateTool = _this$props6.alternateTool,
17161 selectedItems = _this$props6.selectedItems,
17162 _this$props6$resource = _this$props6.resourceName,
17163 resourceName = _this$props6$resource === void 0 ? this.defaultResourceName : _this$props6$resource,
17164 onSortChange = _this$props6.onSortChange,
17165 intl = _this$props6.polaris.intl;
17166 var _this$state2 = this.state,
17167 selectMode = _this$state2.selectMode,
17168 loadingPosition = _this$state2.loadingPosition,
17169 smallScreen = _this$state2.smallScreen;
17170 var filterControlMarkup = filterControl ? React__default.createElement("div", {
17171 className: styles$1t.FiltersWrapper
17172 }, filterControl) : null;
17173 var bulkActionsMarkup = this.selectable ? React__default.createElement("div", {
17174 className: styles$1t.BulkActionsWrapper
17175 }, React__default.createElement(BulkActions$1, {
17176 label: this.bulkActionsLabel,
17177 accessibilityLabel: this.bulkActionsAccessibilityLabel,
17178 selected: this.bulkSelectState,
17179 onToggleAll: this.handleToggleAll,
17180 selectMode: selectMode,
17181 onSelectModeToggle: this.handleSelectMode,
17182 promotedActions: promotedBulkActions,
17183 paginatedSelectAllAction: this.paginatedSelectAllAction,
17184 paginatedSelectAllText: this.paginatedSelectAllText,
17185 actions: bulkActions,
17186 disabled: loading,
17187 smallScreen: smallScreen
17188 })) : null;
17189 var sortingSelectMarkup = sortOptions && sortOptions.length > 0 && !alternateTool ? React__default.createElement("div", {
17190 className: styles$1t.SortWrapper
17191 }, React__default.createElement(Select, {
17192 label: intl.translate('Polaris.ResourceList.sortingLabel'),
17193 labelInline: !smallScreen,
17194 labelHidden: smallScreen,
17195 options: sortOptions,
17196 onChange: onSortChange,
17197 value: sortValue,
17198 disabled: selectMode
17199 })) : null;
17200 var alternateToolMarkup = alternateTool && !sortingSelectMarkup ? React__default.createElement("div", {
17201 className: styles$1t.AlternateToolWrapper
17202 }, alternateTool) : null;
17203 var headerTitleMarkup = React__default.createElement("div", {
17204 className: styles$1t.HeaderTitleWrapper
17205 }, this.headerTitle);
17206 var selectButtonMarkup = this.selectable ? React__default.createElement("div", {
17207 className: styles$1t.SelectButtonWrapper
17208 }, React__default.createElement(Button, {
17209 disabled: selectMode,
17210 icon: EnableSelectionMinor,
17211 onClick: this.handleSelectMode.bind(this, true)
17212 }, intl.translate('Polaris.ResourceList.selectButtonText'))) : null;
17213 var checkableButtonMarkup = this.selectable ? React__default.createElement("div", {
17214 className: styles$1t.CheckableButtonWrapper
17215 }, React__default.createElement(CheckableButton, {
17216 accessibilityLabel: this.bulkActionsAccessibilityLabel,
17217 label: this.headerTitle,
17218 onToggleAll: this.handleToggleAll,
17219 plain: true,
17220 disabled: loading
17221 })) : null;
17222 var needsHeader = this.selectable || sortOptions && sortOptions.length > 0 || alternateTool;
17223 var headerWrapperOverlay = loading ? React__default.createElement("div", {
17224 className: styles$1t['HeaderWrapper-overlay']
17225 }) : null;
17226 var showEmptyState = filterControl && !this.itemsExist() && !loading;
17227 var headerMarkup = !showEmptyState && (showHeader || needsHeader) && this.listRef.current && React__default.createElement("div", {
17228 className: styles$1t.HeaderOuterWrapper
17229 }, React__default.createElement(Sticky$1, {
17230 boundingElement: this.listRef.current
17231 }, function (isSticky) {
17232 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']);
17233 return React__default.createElement("div", {
17234 className: headerClassName
17235 }, React__default.createElement(EventListener, {
17236 event: "resize",
17237 handler: _this2.handleResize
17238 }), headerWrapperOverlay, React__default.createElement("div", {
17239 className: styles$1t.HeaderContentWrapper
17240 }, headerTitleMarkup, checkableButtonMarkup, alternateToolMarkup, sortingSelectMarkup, selectButtonMarkup), bulkActionsMarkup);
17241 }));
17242 var emptyStateMarkup = showEmptyState ? React__default.createElement("div", {
17243 className: styles$1t.EmptySearchResultWrapper
17244 }, React__default.createElement(EmptySearchResult, Object.assign({}, this.emptySearchResultText, {
17245 withIllustration: true
17246 }))) : null;
17247 var defaultTopPadding = 8;
17248 var topPadding = loadingPosition > 0 ? loadingPosition : defaultTopPadding;
17249 var spinnerStyle = {
17250 paddingTop: "".concat(topPadding, "px")
17251 };
17252 var spinnerSize = items.length < 2 ? 'small' : 'large';
17253 var loadingOverlay = loading ? React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
17254 className: styles$1t.SpinnerContainer,
17255 style: spinnerStyle
17256 }, React__default.createElement(Spinner, {
17257 size: spinnerSize,
17258 accessibilityLabel: "Items are loading"
17259 })), React__default.createElement("div", {
17260 className: styles$1t.LoadingOverlay
17261 })) : null;
17262 var className = classNames(styles$1t.ItemWrapper, loading && styles$1t['ItemWrapper-isLoading']);
17263 var loadingWithoutItemsMarkup = loading && !this.itemsExist() ? React__default.createElement("div", {
17264 className: className,
17265 tabIndex: -1
17266 }, loadingOverlay) : null;
17267 var resourceListClassName = classNames(styles$1t.ResourceList, loading && styles$1t.disabledPointerEvents, selectMode && styles$1t.disableTextSelection);
17268 var listMarkup = this.itemsExist() ? React__default.createElement("ul", {
17269 className: resourceListClassName,
17270 ref: this.listRef,
17271 "aria-live": "polite",
17272 "aria-busy": loading
17273 }, loadingOverlay, items.map(this.renderItem)) : emptyStateMarkup;
17274 var context = {
17275 selectable: this.selectable,
17276 selectedItems,
17277 selectMode,
17278 resourceName,
17279 loading,
17280 onSelectionChange: this.handleSelectionChange,
17281 registerCheckableButtons: this.handleCheckableButtonRegistration
17282 };
17283 return React__default.createElement(ResourceListContext.Provider, {
17284 value: context
17285 }, React__default.createElement("div", {
17286 className: styles$1t.ResourceListWrapper
17287 }, filterControlMarkup, headerMarkup, listMarkup, loadingWithoutItemsMarkup));
17288 }
17289 }, {
17290 key: "itemsExist",
17291 value: function itemsExist(items) {
17292 return (items || this.props.items).length > 0;
17293 }
17294 }, {
17295 key: "selectable",
17296 get: function get() {
17297 var _this$props7 = this.props,
17298 promotedBulkActions = _this$props7.promotedBulkActions,
17299 bulkActions = _this$props7.bulkActions,
17300 selectable = _this$props7.selectable;
17301 return Boolean(promotedBulkActions && promotedBulkActions.length > 0 || bulkActions && bulkActions.length > 0 || selectable);
17302 }
17303 }, {
17304 key: "bulkSelectState",
17305 get: function get() {
17306 var _this$props8 = this.props,
17307 selectedItems = _this$props8.selectedItems,
17308 items = _this$props8.items;
17309 var selectState = 'indeterminate';
17310
17311 if (!selectedItems || Array.isArray(selectedItems) && selectedItems.length === 0) {
17312 selectState = false;
17313 } else if (selectedItems === SELECT_ALL_ITEMS || Array.isArray(selectedItems) && selectedItems.length === items.length) {
17314 selectState = true;
17315 }
17316
17317 return selectState;
17318 }
17319 }, {
17320 key: "headerTitle",
17321 get: function get() {
17322 var _this$props9 = this.props,
17323 _this$props9$resource = _this$props9.resourceName,
17324 resourceName = _this$props9$resource === void 0 ? this.defaultResourceName : _this$props9$resource,
17325 items = _this$props9.items,
17326 intl = _this$props9.polaris.intl,
17327 loading = _this$props9.loading,
17328 totalItemsCount = _this$props9.totalItemsCount;
17329 var itemsCount = items.length;
17330 var resource = !loading && (!totalItemsCount && itemsCount === 1 || totalItemsCount === 1) ? resourceName.singular : resourceName.plural;
17331
17332 if (loading) {
17333 return intl.translate('Polaris.ResourceList.loading', {
17334 resource
17335 });
17336 } else if (totalItemsCount) {
17337 return intl.translate('Polaris.ResourceList.showingTotalCount', {
17338 itemsCount,
17339 totalItemsCount,
17340 resource
17341 });
17342 } else {
17343 return intl.translate('Polaris.ResourceList.showing', {
17344 itemsCount,
17345 resource
17346 });
17347 }
17348 }
17349 }, {
17350 key: "bulkActionsLabel",
17351 get: function get() {
17352 var _this$props10 = this.props,
17353 _this$props10$selecte = _this$props10.selectedItems,
17354 selectedItems = _this$props10$selecte === void 0 ? [] : _this$props10$selecte,
17355 items = _this$props10.items,
17356 intl = _this$props10.polaris.intl;
17357 var selectedItemsCount = selectedItems === SELECT_ALL_ITEMS ? "".concat(items.length, "+") : selectedItems.length;
17358 return intl.translate('Polaris.ResourceList.selected', {
17359 selectedItemsCount
17360 });
17361 }
17362 }, {
17363 key: "bulkActionsAccessibilityLabel",
17364 get: function get() {
17365 var _this$props11 = this.props,
17366 _this$props11$resourc = _this$props11.resourceName,
17367 resourceName = _this$props11$resourc === void 0 ? this.defaultResourceName : _this$props11$resourc,
17368 _this$props11$selecte = _this$props11.selectedItems,
17369 selectedItems = _this$props11$selecte === void 0 ? [] : _this$props11$selecte,
17370 items = _this$props11.items,
17371 intl = _this$props11.polaris.intl;
17372 var selectedItemsCount = selectedItems.length;
17373 var totalItemsCount = items.length;
17374 var allSelected = selectedItemsCount === totalItemsCount;
17375
17376 if (totalItemsCount === 1 && allSelected) {
17377 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllSingle', {
17378 resourceNameSingular: resourceName.singular
17379 });
17380 } else if (totalItemsCount === 1) {
17381 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllSingle', {
17382 resourceNameSingular: resourceName.singular
17383 });
17384 } else if (allSelected) {
17385 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllMultiple', {
17386 itemsLength: items.length,
17387 resourceNamePlural: resourceName.plural
17388 });
17389 } else {
17390 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllMultiple', {
17391 itemsLength: items.length,
17392 resourceNamePlural: resourceName.plural
17393 });
17394 }
17395 }
17396 }, {
17397 key: "paginatedSelectAllText",
17398 get: function get() {
17399 var _this$props12 = this.props,
17400 hasMoreItems = _this$props12.hasMoreItems,
17401 selectedItems = _this$props12.selectedItems,
17402 items = _this$props12.items,
17403 _this$props12$resourc = _this$props12.resourceName,
17404 resourceName = _this$props12$resourc === void 0 ? this.defaultResourceName : _this$props12$resourc,
17405 intl = _this$props12.polaris.intl;
17406
17407 if (!this.selectable || !hasMoreItems) {
17408 return;
17409 }
17410
17411 if (selectedItems === SELECT_ALL_ITEMS) {
17412 return intl.translate('Polaris.ResourceList.allItemsSelected', {
17413 itemsLength: items.length,
17414 resourceNamePlural: resourceName.plural
17415 });
17416 }
17417 }
17418 }, {
17419 key: "paginatedSelectAllAction",
17420 get: function get() {
17421 var _this$props13 = this.props,
17422 hasMoreItems = _this$props13.hasMoreItems,
17423 selectedItems = _this$props13.selectedItems,
17424 items = _this$props13.items,
17425 _this$props13$resourc = _this$props13.resourceName,
17426 resourceName = _this$props13$resourc === void 0 ? this.defaultResourceName : _this$props13$resourc,
17427 intl = _this$props13.polaris.intl;
17428
17429 if (!this.selectable || !hasMoreItems) {
17430 return;
17431 }
17432
17433 var actionText = selectedItems === SELECT_ALL_ITEMS ? intl.translate('Polaris.Common.undo') : intl.translate('Polaris.ResourceList.selectAllItems', {
17434 itemsLength: items.length,
17435 resourceNamePlural: resourceName.plural
17436 });
17437 return {
17438 content: actionText,
17439 onAction: this.handleSelectAllItemsInStore
17440 };
17441 }
17442 }, {
17443 key: "emptySearchResultText",
17444 get: function get() {
17445 var _this$props14 = this.props,
17446 intl = _this$props14.polaris.intl,
17447 _this$props14$resourc = _this$props14.resourceName,
17448 resourceName = _this$props14$resourc === void 0 ? this.defaultResourceName : _this$props14$resourc;
17449 return {
17450 title: intl.translate('Polaris.ResourceList.emptySearchResultTitle', {
17451 resourceNamePlural: resourceName.plural
17452 }),
17453 description: intl.translate('Polaris.ResourceList.emptySearchResultDescription')
17454 };
17455 }
17456 }]);
17457
17458 return ResourceList;
17459}(React__default.Component);
17460
17461ResourceList.Item = ResourceItem; // eslint-disable-next-line import/no-deprecated
17462
17463ResourceList.FilterControl = FilterControl;
17464
17465function getAllItemsOnPage(items, idForItem) {
17466 return items.map(function (item, index) {
17467 return idForItem(item, index);
17468 });
17469}
17470
17471function defaultIdForItem(item, index) {
17472 return Object.prototype.hasOwnProperty.call(item, 'id') ? item.id : index.toString();
17473}
17474
17475function isSmallScreen() {
17476 return typeof window === 'undefined' ? false : window.innerWidth < SMALL_SCREEN_WIDTH;
17477} // Use named export once withAppProvider is refactored away
17478// eslint-disable-next-line import/no-default-export
17479
17480
17481var ResourceList$1 = withAppProvider()(ResourceList);
17482
17483/** @deprecated Use `ResourcePicker` from `@shopify/app-bridge-react` instead. */
17484
17485var ResourcePicker =
17486/*#__PURE__*/
17487function (_React$PureComponent) {
17488 _inherits(ResourcePicker, _React$PureComponent);
17489
17490 function ResourcePicker() {
17491 var _this;
17492
17493 _classCallCheck(this, ResourcePicker);
17494
17495 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourcePicker).apply(this, arguments));
17496 _this.focusReturnPoint = null;
17497 return _this;
17498 }
17499
17500 _createClass(ResourcePicker, [{
17501 key: "componentDidMount",
17502 value: function componentDidMount() {
17503 // eslint-disable-next-line no-console
17504 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');
17505
17506 if (this.props.polaris.appBridge == null) {
17507 return;
17508 }
17509
17510 var _this$props = this.props,
17511 open = _this$props.open,
17512 resourceType = _this$props.resourceType,
17513 initialQuery = _this$props.initialQuery,
17514 _this$props$showHidde = _this$props.showHidden,
17515 showHidden = _this$props$showHidde === void 0 ? true : _this$props$showHidde,
17516 _this$props$allowMult = _this$props.allowMultiple,
17517 allowMultiple = _this$props$allowMult === void 0 ? true : _this$props$allowMult,
17518 _this$props$showVaria = _this$props.showVariants,
17519 showVariants = _this$props$showVaria === void 0 ? true : _this$props$showVaria,
17520 onSelection = _this$props.onSelection,
17521 onCancel = _this$props.onCancel;
17522 var appBridge = this.props.polaris.appBridge;
17523 this.appBridgeResourcePicker = ResourcePicker$2.create(appBridge, {
17524 resourceType: ResourcePicker$2.ResourceType[resourceType],
17525 options: {
17526 initialQuery,
17527 showHidden,
17528 selectMultiple: allowMultiple,
17529 showVariants
17530 }
17531 });
17532
17533 if (onSelection != null) {
17534 this.appBridgeResourcePicker.subscribe(ResourcePicker$2.Action.SELECT, function (_ref) {
17535 var selection = _ref.selection;
17536 onSelection({
17537 selection
17538 });
17539 });
17540 }
17541
17542 if (onCancel != null) {
17543 this.appBridgeResourcePicker.subscribe(ResourcePicker$2.Action.CANCEL, onCancel);
17544 }
17545
17546 if (open) {
17547 this.focusReturnPoint = document.activeElement;
17548 this.appBridgeResourcePicker.dispatch(ResourcePicker$2.Action.OPEN);
17549 }
17550 }
17551 }, {
17552 key: "componentDidUpdate",
17553 value: function componentDidUpdate(prevProps) {
17554 if (this.appBridgeResourcePicker == null) {
17555 return;
17556 }
17557
17558 var _this$props2 = this.props,
17559 open = _this$props2.open,
17560 initialQuery = _this$props2.initialQuery,
17561 _this$props2$showHidd = _this$props2.showHidden,
17562 showHidden = _this$props2$showHidd === void 0 ? false : _this$props2$showHidd,
17563 _this$props2$allowMul = _this$props2.allowMultiple,
17564 allowMultiple = _this$props2$allowMul === void 0 ? true : _this$props2$allowMul,
17565 _this$props2$showVari = _this$props2.showVariants,
17566 showVariants = _this$props2$showVari === void 0 ? true : _this$props2$showVari,
17567 onSelection = _this$props2.onSelection,
17568 onCancel = _this$props2.onCancel;
17569 var wasOpen = prevProps.open;
17570
17571 var prevAppBridge = prevProps.polaris.appBridge,
17572 prevResourcePickerProps = __rest(prevProps, ["polaris"]);
17573
17574 var _a = this.props,
17575 appBridge = _a.polaris.appBridge,
17576 resourcePickerProps = __rest(_a, ["polaris"]);
17577
17578 if (!isEqual(prevResourcePickerProps, resourcePickerProps) || !isEqual(prevAppBridge, appBridge)) {
17579 this.appBridgeResourcePicker.set({
17580 initialQuery,
17581 showHidden,
17582 selectMultiple: allowMultiple,
17583 showVariants
17584 });
17585 }
17586
17587 this.appBridgeResourcePicker.unsubscribe();
17588
17589 if (onSelection != null) {
17590 this.appBridgeResourcePicker.subscribe(ResourcePicker$2.Action.SELECT, function (_ref2) {
17591 var selection = _ref2.selection;
17592 onSelection({
17593 selection
17594 });
17595 });
17596 }
17597
17598 if (onCancel != null) {
17599 this.appBridgeResourcePicker.subscribe(ResourcePicker$2.Action.CANCEL, onCancel);
17600 }
17601
17602 if (wasOpen !== open) {
17603 if (open) {
17604 this.appBridgeResourcePicker.dispatch(ResourcePicker$2.Action.OPEN);
17605 } else {
17606 this.appBridgeResourcePicker.dispatch(ResourcePicker$2.Action.CLOSE);
17607 }
17608 }
17609
17610 if (!wasOpen && open) {
17611 this.focusReturnPoint = document.activeElement;
17612 } else if (wasOpen && !open && this.focusReturnPoint != null && document.contains(this.focusReturnPoint)) {
17613 this.focusReturnPoint.focus();
17614 this.focusReturnPoint = null;
17615 }
17616 }
17617 }, {
17618 key: "componentWillUnmount",
17619 value: function componentWillUnmount() {
17620 if (this.appBridgeResourcePicker == null) {
17621 return;
17622 }
17623
17624 this.appBridgeResourcePicker.unsubscribe();
17625 }
17626 }, {
17627 key: "render",
17628 value: function render() {
17629 return null;
17630 }
17631 }]);
17632
17633 return ResourcePicker;
17634}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
17635// eslint-disable-next-line import/no-default-export
17636
17637
17638var ResourcePicker$1 = withAppProvider()(ResourcePicker);
17639
17640function SettingToggle(_ref) {
17641 var enabled = _ref.enabled,
17642 action = _ref.action,
17643 children = _ref.children;
17644 var actionMarkup = action ? buttonFrom(action, {
17645 primary: !enabled
17646 }) : null;
17647 return React__default.createElement(Card, {
17648 sectioned: true
17649 }, React__default.createElement(SettingAction, {
17650 action: actionMarkup
17651 }, children));
17652}
17653
17654var styles$1u = {
17655 "SkeletonBodyTextContainer": "Polaris-SkeletonBodyText__SkeletonBodyTextContainer",
17656 "SkeletonBodyText": "Polaris-SkeletonBodyText"
17657};
17658
17659function SkeletonBodyText(_ref) {
17660 var _ref$lines = _ref.lines,
17661 lines = _ref$lines === void 0 ? 3 : _ref$lines;
17662 var bodyTextLines = [];
17663
17664 for (var i = 0; i < lines; i++) {
17665 bodyTextLines.push(React__default.createElement("div", {
17666 className: styles$1u.SkeletonBodyText,
17667 key: i
17668 }));
17669 }
17670
17671 return React__default.createElement("div", {
17672 className: styles$1u.SkeletonBodyTextContainer
17673 }, bodyTextLines);
17674}
17675
17676var styles$1v = {
17677 "DisplayText": "Polaris-SkeletonDisplayText__DisplayText",
17678 "sizeSmall": "Polaris-SkeletonDisplayText--sizeSmall",
17679 "sizeMedium": "Polaris-SkeletonDisplayText--sizeMedium",
17680 "sizeLarge": "Polaris-SkeletonDisplayText--sizeLarge",
17681 "sizeExtraLarge": "Polaris-SkeletonDisplayText--sizeExtraLarge"
17682};
17683
17684function SkeletonDisplayText(_ref) {
17685 var _ref$size = _ref.size,
17686 size = _ref$size === void 0 ? 'medium' : _ref$size;
17687 var className = classNames(styles$1v.DisplayText, size && styles$1v[variationName('size', size)]);
17688 return React__default.createElement("div", {
17689 className: className
17690 });
17691}
17692
17693var styles$1w = {
17694 "Page": "Polaris-SkeletonPage__Page",
17695 "fullWidth": "Polaris-SkeletonPage--fullWidth",
17696 "narrowWidth": "Polaris-SkeletonPage--narrowWidth",
17697 "Content": "Polaris-SkeletonPage__Content",
17698 "Header": "Polaris-SkeletonPage__Header",
17699 "Header-hasSecondaryActions": "Polaris-SkeletonPage__Header--hasSecondaryActions",
17700 "BreadcrumbAction": "Polaris-SkeletonPage__BreadcrumbAction",
17701 "TitleAndPrimaryAction": "Polaris-SkeletonPage__TitleAndPrimaryAction",
17702 "Title": "Polaris-SkeletonPage__Title",
17703 "PrimaryAction": "Polaris-SkeletonPage__PrimaryAction",
17704 "Actions": "Polaris-SkeletonPage__Actions",
17705 "Action": "Polaris-SkeletonPage__Action"
17706};
17707
17708function SkeletonPage(_ref) {
17709 var children = _ref.children,
17710 fullWidth = _ref.fullWidth,
17711 narrowWidth = _ref.narrowWidth,
17712 singleColumn = _ref.singleColumn,
17713 primaryAction = _ref.primaryAction,
17714 secondaryActions = _ref.secondaryActions,
17715 _ref$title = _ref.title,
17716 title = _ref$title === void 0 ? '' : _ref$title,
17717 breadcrumbs = _ref.breadcrumbs;
17718
17719 if (singleColumn) {
17720 // eslint-disable-next-line no-console
17721 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
17722 }
17723
17724 var i18n = useI18n();
17725 var appBridge = useAppBridge();
17726 var className = classNames(styles$1w.Page, fullWidth && styles$1w.fullWidth, (narrowWidth || singleColumn) && styles$1w.narrowWidth);
17727 var headerClassName = classNames(styles$1w.Header, breadcrumbs && styles$1w['Header-hasBreadcrumbs'], secondaryActions && styles$1w['Header-hasSecondaryActions']);
17728 var titleMarkup = title !== null ? renderTitle(title) : null;
17729 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
17730 className: styles$1w.PrimaryAction
17731 }, React__default.createElement(SkeletonDisplayText, {
17732 size: "large"
17733 })) : null;
17734 var secondaryActionsMarkup = secondaryActions ? renderSecondaryActions(secondaryActions) : null;
17735 var breadcrumbMarkup = breadcrumbs ? React__default.createElement("div", {
17736 className: styles$1w.BreadcrumbAction,
17737 style: {
17738 width: 60
17739 }
17740 }, React__default.createElement(SkeletonBodyText, {
17741 lines: 1
17742 })) : null;
17743 var headerMarkup = !appBridge ? React__default.createElement("div", {
17744 className: headerClassName
17745 }, breadcrumbMarkup, React__default.createElement("div", {
17746 className: styles$1w.TitleAndPrimaryAction
17747 }, titleMarkup, primaryActionMarkup), secondaryActionsMarkup) : null;
17748 return React__default.createElement("div", {
17749 className: className,
17750 role: "status",
17751 "aria-label": i18n.translate('Polaris.SkeletonPage.loadingLabel')
17752 }, headerMarkup, React__default.createElement("div", {
17753 className: styles$1w.Content
17754 }, children));
17755}
17756
17757function renderSecondaryActions(actionCount) {
17758 var actions = [];
17759
17760 for (var i = 0; i < actionCount; i++) {
17761 var width = Math.round(Math.random() * 40 + 60);
17762 actions.push(React__default.createElement("div", {
17763 className: styles$1w.Action,
17764 style: {
17765 width
17766 },
17767 key: i
17768 }, React__default.createElement(SkeletonBodyText, {
17769 lines: 1
17770 })));
17771 }
17772
17773 return React__default.createElement("div", {
17774 className: styles$1w.Actions
17775 }, actions);
17776}
17777
17778function renderTitle(title) {
17779 var titleContent = title === '' ? React__default.createElement(SkeletonDisplayText, {
17780 size: "large"
17781 }) : React__default.createElement(DisplayText, {
17782 size: "large",
17783 element: "h1"
17784 }, title);
17785 return React__default.createElement("div", {
17786 className: styles$1w.Title
17787 }, titleContent);
17788}
17789
17790var styles$1x = {
17791 "SkeletonThumbnail": "Polaris-SkeletonThumbnail",
17792 "sizeSmall": "Polaris-SkeletonThumbnail--sizeSmall",
17793 "sizeMedium": "Polaris-SkeletonThumbnail--sizeMedium",
17794 "sizeLarge": "Polaris-SkeletonThumbnail--sizeLarge"
17795};
17796
17797function SkeletonThumbnail(_ref) {
17798 var _ref$size = _ref.size,
17799 size = _ref$size === void 0 ? 'medium' : _ref$size;
17800 var className = classNames(styles$1x.SkeletonThumbnail, size && styles$1x[variationName('size', size)]);
17801 return React__default.createElement("div", {
17802 className: className
17803 });
17804}
17805
17806function getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth) {
17807 var sumTabWidths = tabWidths.reduce(function (sum, width) {
17808 return sum + width;
17809 }, 0);
17810 var arrayOfTabIndices = tabs.map(function (_, index) {
17811 return index;
17812 });
17813 var visibleTabs = [];
17814 var hiddenTabs = [];
17815
17816 if (containerWidth > sumTabWidths) {
17817 visibleTabs.push.apply(visibleTabs, _toConsumableArray(arrayOfTabIndices));
17818 } else {
17819 visibleTabs.push(selected);
17820 var tabListWidth = tabWidths[selected];
17821 arrayOfTabIndices.forEach(function (currentTabIndex) {
17822 if (currentTabIndex !== selected) {
17823 var currentTabWidth = tabWidths[currentTabIndex];
17824
17825 if (tabListWidth + currentTabWidth > containerWidth - disclosureWidth) {
17826 hiddenTabs.push(currentTabIndex);
17827 return;
17828 }
17829
17830 visibleTabs.push(currentTabIndex);
17831 tabListWidth += currentTabWidth;
17832 }
17833 });
17834 }
17835
17836 return {
17837 visibleTabs,
17838 hiddenTabs
17839 };
17840}
17841
17842var styles$1y = {
17843 "Tabs": "Polaris-Tabs",
17844 "fitted": "Polaris-Tabs--fitted",
17845 "TabContainer": "Polaris-Tabs__TabContainer",
17846 "Tab": "Polaris-Tabs__Tab",
17847 "Title": "Polaris-Tabs__Title",
17848 "fillSpace": "Polaris-Tabs--fillSpace",
17849 "Tab-selected": "Polaris-Tabs__Tab--selected",
17850 "Panel": "Polaris-Tabs__Panel",
17851 "Panel-hidden": "Polaris-Tabs__Panel--hidden",
17852 "List": "Polaris-Tabs__List",
17853 "Item": "Polaris-Tabs__Item",
17854 "DisclosureTab": "Polaris-Tabs__DisclosureTab",
17855 "DisclosureTab-visible": "Polaris-Tabs__DisclosureTab--visible",
17856 "DisclosureActivator": "Polaris-Tabs__DisclosureActivator",
17857 "TabMeasurer": "Polaris-Tabs__TabMeasurer"
17858};
17859
17860var Item$8 =
17861/*#__PURE__*/
17862function (_React$PureComponent) {
17863 _inherits(Item, _React$PureComponent);
17864
17865 function Item() {
17866 var _this;
17867
17868 _classCallCheck(this, Item);
17869
17870 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
17871 _this.focusedNode = null;
17872
17873 _this.setFocusedNode = function (node) {
17874 _this.focusedNode = node;
17875 };
17876
17877 return _this;
17878 }
17879
17880 _createClass(Item, [{
17881 key: "componentDidMount",
17882 value: function componentDidMount() {
17883 var focusedNode = this.focusedNode;
17884 var focused = this.props.focused;
17885
17886 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17887 focusedNode.focus();
17888 }
17889 }
17890 }, {
17891 key: "componentDidUpdate",
17892 value: function componentDidUpdate() {
17893 var focusedNode = this.focusedNode;
17894 var focused = this.props.focused;
17895
17896 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17897 focusedNode.focus();
17898 }
17899 }
17900 }, {
17901 key: "render",
17902 value: function render() {
17903 var _this$props = this.props,
17904 id = _this$props.id,
17905 panelID = _this$props.panelID,
17906 children = _this$props.children,
17907 url = _this$props.url,
17908 accessibilityLabel = _this$props.accessibilityLabel,
17909 _this$props$onClick = _this$props.onClick,
17910 onClick = _this$props$onClick === void 0 ? noop$c : _this$props$onClick;
17911 var sharedProps = {
17912 id,
17913 ref: this.setFocusedNode,
17914 onClick,
17915 className: styles$1y.Item,
17916 'aria-controls': panelID,
17917 'aria-selected': false,
17918 'aria-label': accessibilityLabel
17919 };
17920 var markup = url ? React__default.createElement(UnstyledLink, Object.assign({}, sharedProps, {
17921 url: url
17922 }), children) : React__default.createElement("button", Object.assign({}, sharedProps, {
17923 type: "button"
17924 }), children);
17925 return React__default.createElement("li", null, markup);
17926 }
17927 }]);
17928
17929 return Item;
17930}(React__default.PureComponent);
17931
17932function noop$c() {}
17933
17934var List$1 =
17935/*#__PURE__*/
17936function (_React$PureComponent) {
17937 _inherits(List, _React$PureComponent);
17938
17939 function List() {
17940 var _this;
17941
17942 _classCallCheck(this, List);
17943
17944 _this = _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
17945
17946 _this.handleKeypress = function (event) {
17947 var _this$props$onKeyPres = _this.props.onKeyPress,
17948 onKeyPress = _this$props$onKeyPres === void 0 ? noop$d : _this$props$onKeyPres;
17949 onKeyPress(event);
17950 };
17951
17952 return _this;
17953 }
17954
17955 _createClass(List, [{
17956 key: "render",
17957 value: function render() {
17958 var _this$props = this.props,
17959 focusIndex = _this$props.focusIndex,
17960 disclosureTabs = _this$props.disclosureTabs,
17961 _this$props$onClick = _this$props.onClick,
17962 onClick = _this$props$onClick === void 0 ? noop$d : _this$props$onClick;
17963 var tabs = disclosureTabs.map(function (_a, index) {
17964 var id = _a.id,
17965 content = _a.content,
17966 tabProps = __rest(_a, ["id", "content"]);
17967
17968 return React__default.createElement(Item$8, Object.assign({}, tabProps, {
17969 key: id,
17970 id: id,
17971 focused: index === focusIndex,
17972 onClick: onClick.bind(null, id)
17973 }), content);
17974 });
17975 return React__default.createElement("ul", {
17976 className: styles$1y.List,
17977 onKeyDown: handleKeyDown$1,
17978 onKeyUp: this.handleKeypress
17979 }, tabs);
17980 }
17981 }]);
17982
17983 return List;
17984}(React__default.PureComponent);
17985
17986function noop$d() {}
17987
17988function handleKeyDown$1(event) {
17989 var key = event.key;
17990
17991 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
17992 event.preventDefault();
17993 event.stopPropagation();
17994 }
17995}
17996
17997function Panel(_ref) {
17998 var hidden = _ref.hidden,
17999 id = _ref.id,
18000 tabID = _ref.tabID,
18001 children = _ref.children;
18002 var className = classNames(styles$1y.Panel, hidden && styles$1y['Panel-hidden']);
18003 return React__default.createElement("div", {
18004 className: className,
18005 id: id,
18006 role: "tabpanel",
18007 "aria-labelledby": tabID,
18008 tabIndex: -1
18009 }, children);
18010}
18011
18012function Tab(_ref) {
18013 var id = _ref.id,
18014 focused = _ref.focused,
18015 siblingTabHasFocus = _ref.siblingTabHasFocus,
18016 children = _ref.children,
18017 onClick = _ref.onClick,
18018 selected = _ref.selected,
18019 url = _ref.url,
18020 panelID = _ref.panelID,
18021 measuring = _ref.measuring,
18022 accessibilityLabel = _ref.accessibilityLabel;
18023 var wasSelected = useRef(selected);
18024 var panelFocused = useRef(false);
18025 var node = useRef(null); // A tab can start selected when it is moved from the disclosure dropdown
18026 // into the main list, so we need to send focus from the tab to the panel
18027 // on mount and update
18028
18029 useEffect(function () {
18030 if (measuring) {
18031 return;
18032 } // Because of timing issues with the render, we may still have the old,
18033 // in-disclosure version of the tab that has focus. Check for this
18034 // as a second indicator of focus
18035
18036
18037 var itemHadFocus = focused || document.activeElement && document.activeElement.id === id; // If we just check for selected, the panel for the active tab will
18038 // be focused on page load, which we don’t want
18039
18040 if (itemHadFocus && selected && panelID != null && !panelFocused.current) {
18041 focusPanelID(panelID);
18042 panelFocused.current = true;
18043 }
18044
18045 if (selected && !wasSelected.current && panelID != null) {
18046 focusPanelID(panelID);
18047 } else if (focused && node.current != null) {
18048 focusFirstFocusableNode(node.current);
18049 }
18050
18051 wasSelected.current = selected;
18052 }, [focused, id, measuring, panelID, selected]);
18053 var handleClick = onClick && onClick.bind(null, id);
18054 var className = classNames(styles$1y.Tab, selected && styles$1y['Tab-selected']);
18055 var tabIndex;
18056
18057 if (selected && !siblingTabHasFocus && !measuring) {
18058 tabIndex = 0;
18059 } else if (focused && !measuring) {
18060 tabIndex = 0;
18061 } else {
18062 tabIndex = -1;
18063 }
18064
18065 var markup = url ? React__default.createElement(UnstyledLink, {
18066 id: id,
18067 url: url,
18068 role: "tab",
18069 tabIndex: tabIndex,
18070 onClick: handleClick,
18071 className: className,
18072 "aria-selected": selected,
18073 "aria-controls": panelID,
18074 "aria-label": accessibilityLabel,
18075 onMouseUp: handleMouseUpByBlurring
18076 }, React__default.createElement("span", {
18077 className: styles$1y.Title
18078 }, children)) : React__default.createElement("button", {
18079 id: id,
18080 role: "tab",
18081 type: "button",
18082 tabIndex: tabIndex,
18083 className: className,
18084 onClick: handleClick,
18085 "aria-selected": selected,
18086 "aria-controls": panelID,
18087 "aria-label": accessibilityLabel,
18088 onMouseUp: handleMouseUpByBlurring
18089 }, React__default.createElement("span", {
18090 className: styles$1y.Title
18091 }, children));
18092 return React__default.createElement("li", {
18093 className: styles$1y.TabContainer,
18094 ref: node
18095 }, markup);
18096}
18097
18098function focusPanelID(panelID) {
18099 var panel = document.getElementById(panelID);
18100
18101 if (panel) {
18102 panel.focus({
18103 preventScroll: true
18104 });
18105 }
18106}
18107
18108var TabMeasurer =
18109/*#__PURE__*/
18110function (_React$PureComponent) {
18111 _inherits(TabMeasurer, _React$PureComponent);
18112
18113 function TabMeasurer() {
18114 var _this;
18115
18116 _classCallCheck(this, TabMeasurer);
18117
18118 _this = _possibleConstructorReturn(this, _getPrototypeOf(TabMeasurer).apply(this, arguments));
18119 _this.containerNode = React__default.createRef();
18120 _this.animationFrame = null;
18121
18122 _this.handleMeasurement = function () {
18123 if (_this.animationFrame) {
18124 cancelAnimationFrame(_this.animationFrame);
18125 }
18126
18127 _this.animationFrame = requestAnimationFrame(function () {
18128 if (!_this.containerNode.current) {
18129 return;
18130 }
18131
18132 var handleMeasurement = _this.props.handleMeasurement;
18133 var containerWidth = _this.containerNode.current.offsetWidth;
18134 var hiddenTabNodes = _this.containerNode.current.children;
18135 var hiddenTabNodesArray = Array.from(hiddenTabNodes);
18136 var hiddenTabWidths = hiddenTabNodesArray.map(function (node) {
18137 return node.getBoundingClientRect().width;
18138 });
18139 var disclosureWidth = hiddenTabWidths.pop();
18140 handleMeasurement({
18141 containerWidth,
18142 disclosureWidth,
18143 hiddenTabWidths
18144 });
18145 });
18146 };
18147
18148 return _this;
18149 }
18150
18151 _createClass(TabMeasurer, [{
18152 key: "componentDidMount",
18153 value: function componentDidMount() {
18154 this.handleMeasurement();
18155
18156 if (process.env.NODE_ENV === 'development') {
18157 // We need to defer the calculation in development so the
18158 // styles have time to be injected.
18159 setTimeout(this.handleMeasurement, 0);
18160 }
18161 }
18162 }, {
18163 key: "componentDidUpdate",
18164 value: function componentDidUpdate(prevProps) {
18165 if (prevProps.tabs !== this.props.tabs) {
18166 this.handleMeasurement();
18167 }
18168 }
18169 }, {
18170 key: "render",
18171 value: function render() {
18172 var _this$props = this.props,
18173 selected = _this$props.selected,
18174 tabs = _this$props.tabs,
18175 activator = _this$props.activator,
18176 tabToFocus = _this$props.tabToFocus,
18177 siblingTabHasFocus = _this$props.siblingTabHasFocus;
18178 var tabsMarkup = tabs.map(function (tab, index) {
18179 return React__default.createElement(Tab, {
18180 measuring: true,
18181 key: "".concat(index).concat(tab.id, "Hidden"),
18182 id: "".concat(tab.id, "Measurer"),
18183 siblingTabHasFocus: siblingTabHasFocus,
18184 focused: index === tabToFocus,
18185 selected: index === selected,
18186 onClick: noop$e,
18187 url: tab.url
18188 }, tab.content);
18189 });
18190 var classname = classNames(styles$1y.Tabs, styles$1y.TabMeasurer);
18191 return React__default.createElement("div", {
18192 className: classname,
18193 ref: this.containerNode
18194 }, React__default.createElement(EventListener, {
18195 event: "resize",
18196 handler: this.handleMeasurement
18197 }), tabsMarkup, activator);
18198 }
18199 }]);
18200
18201 return TabMeasurer;
18202}(React__default.PureComponent);
18203
18204function noop$e() {}
18205
18206var Tabs =
18207/*#__PURE__*/
18208function (_React$PureComponent) {
18209 _inherits(Tabs, _React$PureComponent);
18210
18211 function Tabs() {
18212 var _this;
18213
18214 _classCallCheck(this, Tabs);
18215
18216 _this = _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
18217 _this.state = {
18218 disclosureWidth: 0,
18219 containerWidth: Infinity,
18220 tabWidths: [],
18221 visibleTabs: [],
18222 hiddenTabs: [],
18223 showDisclosure: false,
18224 tabToFocus: -1
18225 };
18226
18227 _this.handleKeyPress = function (event) {
18228 var _this$state = _this.state,
18229 tabToFocus = _this$state.tabToFocus,
18230 visibleTabs = _this$state.visibleTabs,
18231 hiddenTabs = _this$state.hiddenTabs,
18232 showDisclosure = _this$state.showDisclosure;
18233 var key = event.key;
18234 var tabsArrayInOrder = showDisclosure ? visibleTabs.concat(hiddenTabs) : _toConsumableArray(visibleTabs);
18235 var newFocus = tabsArrayInOrder.indexOf(tabToFocus);
18236
18237 if (key === 'ArrowRight' || key === 'ArrowDown') {
18238 newFocus += 1;
18239
18240 if (newFocus === tabsArrayInOrder.length) {
18241 newFocus = 0;
18242 }
18243 }
18244
18245 if (key === 'ArrowLeft' || key === 'ArrowUp') {
18246 if (newFocus === -1 || newFocus === 0) {
18247 newFocus = tabsArrayInOrder.length - 1;
18248 } else {
18249 newFocus -= 1;
18250 }
18251 }
18252
18253 _this.setState({
18254 tabToFocus: tabsArrayInOrder[newFocus]
18255 });
18256 };
18257
18258 _this.renderTabMarkup = function (tab, index) {
18259 var selected = _this.props.selected;
18260 var tabToFocus = _this.state.tabToFocus;
18261 return React__default.createElement(Tab, {
18262 key: "".concat(index, "-").concat(tab.id),
18263 id: tab.id,
18264 siblingTabHasFocus: tabToFocus > -1,
18265 focused: index === tabToFocus,
18266 selected: index === selected,
18267 onClick: _this.handleTabClick,
18268 panelID: tab.panelID || "".concat(tab.id, "-panel"),
18269 accessibilityLabel: tab.accessibilityLabel,
18270 url: tab.url
18271 }, tab.content);
18272 };
18273
18274 _this.handleFocus = function (event) {
18275 var _this$props = _this.props,
18276 selected = _this$props.selected,
18277 tabs = _this$props.tabs; // If we are explicitly focusing a non-selected tab, this focuses it
18278
18279 var target = event.target;
18280
18281 if (target.classList.contains(styles$1y.Tab) || target.classList.contains(styles$1y.Item)) {
18282 var tabToFocus = -1;
18283 tabs.every(function (tab, index) {
18284 if (tab.id === target.id) {
18285 tabToFocus = index;
18286 return false;
18287 }
18288
18289 return true;
18290 });
18291
18292 _this.setState({
18293 tabToFocus
18294 });
18295
18296 return;
18297 }
18298
18299 if (target.classList.contains(styles$1y.DisclosureActivator)) {
18300 return;
18301 } // If we are coming in from somewhere other than another tab, focus the
18302 // selected tab, and the focus (click) is not on the disclosure activator,
18303 // focus the selected tab
18304
18305
18306 if (!event.relatedTarget) {
18307 _this.setState({
18308 tabToFocus: selected
18309 });
18310
18311 return;
18312 }
18313
18314 var relatedTarget = event.relatedTarget;
18315
18316 if (!relatedTarget.classList.contains(styles$1y.Tab) && !relatedTarget.classList.contains(styles$1y.Item) && !relatedTarget.classList.contains(styles$1y.DisclosureActivator)) {
18317 _this.setState({
18318 tabToFocus: selected
18319 });
18320 }
18321 };
18322
18323 _this.handleBlur = function (event) {
18324 // If we blur and the target is not another tab, forget the focus position
18325 if (event.relatedTarget == null) {
18326 _this.setState({
18327 tabToFocus: -1
18328 });
18329
18330 return;
18331 }
18332
18333 var target = event.relatedTarget; // If we are going to anywhere other than another tab, lose the last focused tab
18334
18335 if (!target.classList.contains(styles$1y.Tab) && !target.classList.contains(styles$1y.Item)) {
18336 _this.setState({
18337 tabToFocus: -1
18338 });
18339 }
18340 };
18341
18342 _this.handleDisclosureActivatorClick = function () {
18343 _this.setState(function (_ref) {
18344 var showDisclosure = _ref.showDisclosure;
18345 return {
18346 showDisclosure: !showDisclosure
18347 };
18348 });
18349 };
18350
18351 _this.handleClose = function () {
18352 _this.setState({
18353 showDisclosure: false
18354 });
18355 };
18356
18357 _this.handleMeasurement = function (measurements) {
18358 var _this$props2 = _this.props,
18359 tabs = _this$props2.tabs,
18360 selected = _this$props2.selected;
18361 var tabToFocus = _this.state.tabToFocus;
18362 var tabWidths = measurements.hiddenTabWidths,
18363 containerWidth = measurements.containerWidth,
18364 disclosureWidth = measurements.disclosureWidth;
18365
18366 var _getVisibleAndHiddenT = getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth),
18367 visibleTabs = _getVisibleAndHiddenT.visibleTabs,
18368 hiddenTabs = _getVisibleAndHiddenT.hiddenTabs;
18369
18370 _this.setState({
18371 tabToFocus: tabToFocus === -1 ? -1 : selected,
18372 visibleTabs,
18373 hiddenTabs,
18374 disclosureWidth,
18375 containerWidth,
18376 tabWidths
18377 });
18378 };
18379
18380 _this.handleTabClick = function (id) {
18381 var _this$props3 = _this.props,
18382 tabs = _this$props3.tabs,
18383 _this$props3$onSelect = _this$props3.onSelect,
18384 onSelect = _this$props3$onSelect === void 0 ? noop$f : _this$props3$onSelect;
18385 var tab = tabs.find(function (aTab) {
18386 return aTab.id === id;
18387 });
18388
18389 if (tab == null) {
18390 return;
18391 }
18392
18393 var selectedIndex = tabs.indexOf(tab);
18394 onSelect(selectedIndex);
18395 };
18396
18397 return _this;
18398 }
18399
18400 _createClass(Tabs, [{
18401 key: "render",
18402 value: function render() {
18403 var _this2 = this;
18404
18405 var _this$props4 = this.props,
18406 tabs = _this$props4.tabs,
18407 selected = _this$props4.selected,
18408 fitted = _this$props4.fitted,
18409 children = _this$props4.children,
18410 intl = _this$props4.polaris.intl;
18411 var _this$state2 = this.state,
18412 tabToFocus = _this$state2.tabToFocus,
18413 visibleTabs = _this$state2.visibleTabs,
18414 hiddenTabs = _this$state2.hiddenTabs,
18415 showDisclosure = _this$state2.showDisclosure;
18416 var disclosureTabs = hiddenTabs.map(function (tabIndex) {
18417 return tabs[tabIndex];
18418 });
18419 var panelMarkup = children ? tabs.map(function (_tab, index) {
18420 return selected === index ? React__default.createElement(Panel, {
18421 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
18422 tabID: tabs[index].id,
18423 key: tabs[index].id
18424 }, children) : React__default.createElement(Panel, {
18425 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
18426 tabID: tabs[index].id,
18427 key: tabs[index].id,
18428 hidden: true
18429 });
18430 }) : null;
18431 var tabsMarkup = visibleTabs.sort(function (tabA, tabB) {
18432 return tabA - tabB;
18433 }).map(function (tabIndex) {
18434 return _this2.renderTabMarkup(tabs[tabIndex], tabIndex);
18435 });
18436 var disclosureActivatorVisible = visibleTabs.length < tabs.length;
18437 var classname = classNames(styles$1y.Tabs, fitted && styles$1y.fitted, disclosureActivatorVisible && styles$1y.fillSpace);
18438 var disclosureTabClassName = classNames(styles$1y.DisclosureTab, disclosureActivatorVisible && styles$1y['DisclosureTab-visible']);
18439 var activator = React__default.createElement("button", {
18440 type: "button",
18441 className: styles$1y.DisclosureActivator,
18442 onClick: this.handleDisclosureActivatorClick,
18443 "aria-label": intl.translate('Polaris.Tabs.toggleTabsLabel')
18444 }, React__default.createElement("span", {
18445 className: styles$1y.Title
18446 }, React__default.createElement(Icon, {
18447 source: HorizontalDotsMinor
18448 })));
18449 return React__default.createElement("div", null, React__default.createElement("ul", {
18450 role: "tablist",
18451 className: classname,
18452 onFocus: this.handleFocus,
18453 onBlur: this.handleBlur,
18454 onKeyDown: handleKeyDown$2,
18455 onKeyUp: this.handleKeyPress
18456 }, tabsMarkup, React__default.createElement("li", {
18457 className: disclosureTabClassName
18458 }, React__default.createElement(Popover, {
18459 preferredPosition: "below",
18460 activator: activator,
18461 active: disclosureActivatorVisible && showDisclosure,
18462 onClose: this.handleClose
18463 }, React__default.createElement(List$1, {
18464 focusIndex: hiddenTabs.indexOf(tabToFocus),
18465 disclosureTabs: disclosureTabs,
18466 onClick: this.handleTabClick,
18467 onKeyPress: this.handleKeyPress
18468 })))), React__default.createElement(TabMeasurer, {
18469 tabToFocus: tabToFocus,
18470 activator: activator,
18471 selected: selected,
18472 tabs: tabs,
18473 siblingTabHasFocus: tabToFocus > -1,
18474 handleMeasurement: this.handleMeasurement
18475 }), panelMarkup);
18476 }
18477 }], [{
18478 key: "getDerivedStateFromProps",
18479 value: function getDerivedStateFromProps(nextProps, prevState) {
18480 var disclosureWidth = prevState.disclosureWidth,
18481 tabWidths = prevState.tabWidths,
18482 containerWidth = prevState.containerWidth;
18483
18484 var _getVisibleAndHiddenT2 = getVisibleAndHiddenTabIndices(nextProps.tabs, nextProps.selected, disclosureWidth, tabWidths, containerWidth),
18485 visibleTabs = _getVisibleAndHiddenT2.visibleTabs,
18486 hiddenTabs = _getVisibleAndHiddenT2.hiddenTabs;
18487
18488 return {
18489 visibleTabs,
18490 hiddenTabs,
18491 selected: nextProps.selected
18492 };
18493 }
18494 }]);
18495
18496 return Tabs;
18497}(React__default.PureComponent);
18498
18499function noop$f() {}
18500
18501function handleKeyDown$2(event) {
18502 var key = event.key;
18503
18504 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
18505 event.preventDefault();
18506 event.stopPropagation();
18507 }
18508} // Use named export once withAppProvider is refactored away
18509// eslint-disable-next-line import/no-default-export
18510
18511
18512var Tabs$1 = withAppProvider()(Tabs);
18513
18514var styles$1z = {
18515 "Thumbnail": "Polaris-Thumbnail",
18516 "sizeSmall": "Polaris-Thumbnail--sizeSmall",
18517 "sizeMedium": "Polaris-Thumbnail--sizeMedium",
18518 "sizeLarge": "Polaris-Thumbnail--sizeLarge",
18519 "Image": "Polaris-Thumbnail__Image"
18520};
18521
18522function Thumbnail(_ref) {
18523 var source = _ref.source,
18524 alt = _ref.alt,
18525 _ref$size = _ref.size,
18526 size = _ref$size === void 0 ? 'medium' : _ref$size;
18527 var className = classNames(styles$1z.Thumbnail, size && styles$1z[variationName('size', size)]);
18528 return React__default.createElement("span", {
18529 className: className
18530 }, React__default.createElement(Image, {
18531 alt: alt,
18532 source: source,
18533 className: styles$1z.Image
18534 }));
18535}
18536
18537var Toast$1 = React__default.memo(function Toast(props) {
18538 var id = useUniqueId('Toast');
18539 var appBridgeToast = useRef();
18540
18541 var _useFrame = useFrame(),
18542 showToast = _useFrame.showToast,
18543 hideToast = _useFrame.hideToast;
18544
18545 var appBridge = useAppBridge();
18546 useDeepEffect(function () {
18547 var error = props.error,
18548 content = props.content,
18549 _props$duration = props.duration,
18550 duration = _props$duration === void 0 ? DEFAULT_TOAST_DURATION : _props$duration,
18551 onDismiss = props.onDismiss;
18552
18553 if (appBridge == null) {
18554 showToast(Object.assign({
18555 id
18556 }, props));
18557 } else {
18558 // eslint-disable-next-line no-console
18559 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');
18560 appBridgeToast.current = Toast$2.create(appBridge, {
18561 message: content,
18562 duration,
18563 isError: error
18564 });
18565 appBridgeToast.current.subscribe(Toast$2.Action.CLEAR, onDismiss);
18566 appBridgeToast.current.dispatch(Toast$2.Action.SHOW);
18567 }
18568
18569 return function () {
18570 if (appBridge == null) {
18571 hideToast({
18572 id
18573 });
18574 } else if (appBridgeToast.current != null) {
18575 appBridgeToast.current.unsubscribe();
18576 }
18577 };
18578 }, [appBridge, props]);
18579 return null;
18580});
18581
18582var styles$1A = {
18583 "Search": "Polaris-TopBar-Search",
18584 "visible": "Polaris-TopBar-Search--visible",
18585 "Overlay": "Polaris-TopBar-Search__Overlay"
18586};
18587
18588var Search =
18589/*#__PURE__*/
18590function (_React$PureComponent) {
18591 _inherits(Search, _React$PureComponent);
18592
18593 function Search() {
18594 var _this;
18595
18596 _classCallCheck(this, Search);
18597
18598 _this = _possibleConstructorReturn(this, _getPrototypeOf(Search).apply(this, arguments));
18599 _this.node = React__default.createRef();
18600
18601 _this.handleDismiss = function (_ref) {
18602 var target = _ref.target;
18603 var onDismiss = _this.props.onDismiss;
18604
18605 if (onDismiss != null && target === _this.node.current) {
18606 onDismiss();
18607 }
18608 };
18609
18610 return _this;
18611 }
18612
18613 _createClass(Search, [{
18614 key: "render",
18615 value: function render() {
18616 var _this$props = this.props,
18617 visible = _this$props.visible,
18618 children = _this$props.children;
18619 var searchClassName = classNames(styles$1A.Search, visible && styles$1A.visible);
18620 return React__default.createElement("div", {
18621 ref: this.node,
18622 className: searchClassName,
18623 onClick: this.handleDismiss
18624 }, React__default.createElement("div", {
18625 className: styles$1A.Overlay
18626 }, children));
18627 }
18628 }]);
18629
18630 return Search;
18631}(React__default.PureComponent);
18632
18633var styles$1B = {
18634 "SearchField": "Polaris-TopBar-SearchField",
18635 "focused": "Polaris-TopBar-SearchField--focused",
18636 "Input": "Polaris-TopBar-SearchField__Input",
18637 "Backdrop": "Polaris-TopBar-SearchField__Backdrop",
18638 "Icon": "Polaris-TopBar-SearchField__Icon",
18639 "Clear": "Polaris-TopBar-SearchField__Clear",
18640 "toLightBackground": "Polaris-TopBar-SearchField--toLightBackground"
18641};
18642
18643function SearchField(_ref) {
18644 var value = _ref.value,
18645 focused = _ref.focused,
18646 active = _ref.active,
18647 placeholder = _ref.placeholder,
18648 onChange = _ref.onChange,
18649 onFocus = _ref.onFocus,
18650 onBlur = _ref.onBlur,
18651 onCancel = _ref.onCancel;
18652 var i18n = useI18n();
18653 var input = useRef(null);
18654 var searchId = useUniqueId('SearchField');
18655 var handleChange = useCallback(function (_ref2) {
18656 var currentTarget = _ref2.currentTarget;
18657 onChange(currentTarget.value);
18658 }, [onChange]);
18659 var handleFocus = useCallback(function () {
18660 return onFocus && onFocus();
18661 }, [onFocus]);
18662 var handleBlur = useCallback(function () {
18663 return onBlur && onBlur();
18664 }, [onBlur]);
18665 var handleClear = useCallback(function () {
18666 onCancel && onCancel();
18667
18668 if (!input.current) {
18669 return;
18670 }
18671
18672 input.current.value = '';
18673 onChange('');
18674 input.current.focus();
18675 }, [onCancel, onChange]);
18676 useEffect(function () {
18677 if (!input.current) {
18678 return;
18679 }
18680
18681 if (focused) {
18682 input.current.focus();
18683 } else {
18684 input.current.blur();
18685 }
18686 }, [focused]);
18687 var clearMarkup = value !== '' && React__default.createElement("button", {
18688 type: "button",
18689 "aria-label": i18n.translate('Polaris.TopBar.SearchField.clearButtonLabel'),
18690 className: styles$1B.Clear,
18691 onClick: handleClear
18692 }, React__default.createElement(Icon, {
18693 source: CircleCancelMinor
18694 }));
18695 var className = classNames(styles$1B.SearchField, (focused || active) && styles$1B.focused);
18696 return React__default.createElement("div", {
18697 className: className,
18698 onFocus: handleFocus,
18699 onBlur: handleBlur
18700 }, React__default.createElement(VisuallyHidden, null, React__default.createElement("label", {
18701 htmlFor: searchId
18702 }, i18n.translate('Polaris.TopBar.SearchField.search'))), React__default.createElement("input", {
18703 id: searchId,
18704 className: styles$1B.Input,
18705 placeholder: placeholder,
18706 type: "search",
18707 autoCapitalize: "off",
18708 autoComplete: "off",
18709 autoCorrect: "off",
18710 ref: input,
18711 value: value,
18712 onChange: handleChange,
18713 onKeyDown: preventDefault
18714 }), React__default.createElement("span", {
18715 className: styles$1B.Icon
18716 }, React__default.createElement(Icon, {
18717 source: SearchMinor
18718 })), clearMarkup, React__default.createElement("div", {
18719 className: styles$1B.Backdrop
18720 }));
18721}
18722
18723function preventDefault(event) {
18724 if (event.key === 'Enter') {
18725 event.preventDefault();
18726 }
18727}
18728
18729var styles$1C = {
18730 "MessageIndicatorWrapper": "Polaris-MessageIndicator__MessageIndicatorWrapper",
18731 "MessageIndicator": "Polaris-MessageIndicator"
18732};
18733
18734function MessageIndicator(_ref) {
18735 var children = _ref.children,
18736 active = _ref.active;
18737 var indicatorMarkup = active && React__default.createElement("div", {
18738 className: styles$1C.MessageIndicator
18739 });
18740 return React__default.createElement("div", {
18741 className: styles$1C.MessageIndicatorWrapper
18742 }, indicatorMarkup, children);
18743}
18744
18745var styles$1D = {
18746 "Section": "Polaris-Menu-Message__Section"
18747};
18748
18749function Message(_ref) {
18750 var title = _ref.title,
18751 description = _ref.description,
18752 action = _ref.action,
18753 link = _ref.link,
18754 badge = _ref.badge;
18755 var badgeMarkup = badge && React__default.createElement(Badge, {
18756 status: badge.status
18757 }, badge.content);
18758 var to = link.to,
18759 linkContent = link.content;
18760 var onClick = action.onClick,
18761 actionContent = action.content;
18762 return React__default.createElement("div", {
18763 className: styles$1D.Section
18764 }, React__default.createElement(Popover.Section, null, React__default.createElement(Stack, {
18765 vertical: true,
18766 spacing: "tight"
18767 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title, badgeMarkup), React__default.createElement("p", null, description)), React__default.createElement(Link, {
18768 url: to
18769 }, linkContent), React__default.createElement(Button, {
18770 plain: true,
18771 onClick: onClick
18772 }, actionContent))));
18773}
18774
18775var styles$1E = {
18776 "ActivatorWrapper": "Polaris-TopBar-Menu__ActivatorWrapper",
18777 "Activator": "Polaris-TopBar-Menu__Activator",
18778 "Section": "Polaris-TopBar-Menu__Section"
18779};
18780
18781function Menu(props) {
18782 var actions = props.actions,
18783 onOpen = props.onOpen,
18784 onClose = props.onClose,
18785 open = props.open,
18786 activatorContent = props.activatorContent,
18787 message = props.message;
18788 var badgeProps = message && message.badge && {
18789 content: message.badge.content,
18790 status: message.badge.status
18791 };
18792 var messageMarkup = message && React__default.createElement(Message, {
18793 title: message.title,
18794 description: message.description,
18795 action: {
18796 onClick: message.action.onClick,
18797 content: message.action.content
18798 },
18799 link: {
18800 to: message.link.to,
18801 content: message.link.content
18802 },
18803 badge: badgeProps
18804 });
18805 var isFullHeight = Boolean(message);
18806 return React__default.createElement(Popover, {
18807 activator: React__default.createElement("div", {
18808 className: styles$1E.ActivatorWrapper
18809 }, React__default.createElement("button", {
18810 type: "button",
18811 className: styles$1E.Activator,
18812 onClick: onOpen
18813 }, activatorContent)),
18814 active: open,
18815 onClose: onClose,
18816 fixed: true,
18817 fullHeight: isFullHeight
18818 }, React__default.createElement(ActionList, {
18819 onActionAnyItem: onClose,
18820 sections: actions
18821 }), messageMarkup);
18822}
18823
18824var styles$1F = {
18825 "Details": "Polaris-TopBar-UserMenu__Details",
18826 "Name": "Polaris-TopBar-UserMenu__Name",
18827 "Detail": "Polaris-TopBar-UserMenu__Detail"
18828};
18829
18830function UserMenu(_ref) {
18831 var name = _ref.name,
18832 detail = _ref.detail,
18833 avatar = _ref.avatar,
18834 initials = _ref.initials,
18835 actions = _ref.actions,
18836 message = _ref.message,
18837 onToggle = _ref.onToggle,
18838 open = _ref.open;
18839 var showIndicator = Boolean(message);
18840 var activatorContentMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(MessageIndicator, {
18841 active: showIndicator
18842 }, React__default.createElement(Avatar, {
18843 size: "small",
18844 source: avatar,
18845 initials: initials && initials.replace(' ', '')
18846 })), React__default.createElement("span", {
18847 className: styles$1F.Details
18848 }, React__default.createElement("p", {
18849 className: styles$1F.Name
18850 }, name), React__default.createElement("p", {
18851 className: styles$1F.Detail
18852 }, detail)));
18853 return React__default.createElement(Menu, {
18854 activatorContent: activatorContentMarkup,
18855 open: open,
18856 onOpen: onToggle,
18857 onClose: onToggle,
18858 actions: actions,
18859 message: message
18860 });
18861}
18862
18863var styles$1G = {
18864 "TopBar": "Polaris-TopBar",
18865 "LogoContainer": "Polaris-TopBar__LogoContainer",
18866 "ContextControl": "Polaris-TopBar__ContextControl",
18867 "Logo": "Polaris-TopBar__Logo",
18868 "LogoLink": "Polaris-TopBar__LogoLink",
18869 "NavigationIcon": "Polaris-TopBar__NavigationIcon",
18870 "focused": "Polaris-TopBar--focused",
18871 "Contents": "Polaris-TopBar__Contents",
18872 "SearchField": "Polaris-TopBar__SearchField",
18873 "SecondaryMenu": "Polaris-TopBar__SecondaryMenu"
18874};
18875
18876// subcomponents so explicitly state the subcomponents in the type definition.
18877// Letting this be implicit works in this project but fails in projects that use
18878// generated *.d.ts files.
18879
18880var TopBar = function TopBar(_ref) {
18881 var showNavigationToggle = _ref.showNavigationToggle,
18882 userMenu = _ref.userMenu,
18883 searchResults = _ref.searchResults,
18884 searchField = _ref.searchField,
18885 secondaryMenu = _ref.secondaryMenu,
18886 searchResultsVisible = _ref.searchResultsVisible,
18887 onNavigationToggle = _ref.onNavigationToggle,
18888 onSearchResultsDismiss = _ref.onSearchResultsDismiss,
18889 contextControl = _ref.contextControl;
18890 var i18n = useI18n();
18891
18892 var _useTheme = useTheme(),
18893 logo = _useTheme.logo;
18894
18895 var _useForcibleToggle = useForcibleToggle(false),
18896 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
18897 focused = _useForcibleToggle2[0],
18898 _useForcibleToggle2$ = _useForcibleToggle2[1],
18899 forceTrueFocused = _useForcibleToggle2$.forceTrue,
18900 forceFalseFocused = _useForcibleToggle2$.forceFalse;
18901
18902 var className = classNames(styles$1G.NavigationIcon, focused && styles$1G.focused);
18903 var navigationButtonMarkup = showNavigationToggle ? React__default.createElement("button", {
18904 type: "button",
18905 className: className,
18906 onClick: onNavigationToggle,
18907 onFocus: forceTrueFocused,
18908 onBlur: forceFalseFocused,
18909 "aria-label": i18n.translate('Polaris.TopBar.toggleMenuLabel')
18910 }, React__default.createElement(Icon, {
18911 source: MobileHamburgerMajorMonotone,
18912 color: "white"
18913 })) : null;
18914 var width = getWidth(logo, 104);
18915 var contextMarkup;
18916
18917 if (contextControl) {
18918 contextMarkup = React__default.createElement("div", {
18919 className: styles$1G.ContextControl
18920 }, contextControl);
18921 } else if (logo) {
18922 contextMarkup = React__default.createElement("div", {
18923 className: styles$1G.LogoContainer
18924 }, React__default.createElement(UnstyledLink, {
18925 url: logo.url || '',
18926 className: styles$1G.LogoLink,
18927 style: {
18928 width
18929 }
18930 }, React__default.createElement(Image, {
18931 source: logo.topBarSource || '',
18932 alt: logo.accessibilityLabel || '',
18933 className: styles$1G.Logo,
18934 style: {
18935 width
18936 }
18937 })));
18938 }
18939
18940 var searchResultsMarkup = searchResults && searchResultsVisible ? React__default.createElement(Search, {
18941 visible: searchResultsVisible,
18942 onDismiss: onSearchResultsDismiss
18943 }, searchResults) : null;
18944 var searchMarkup = searchField ? React__default.createElement(React__default.Fragment, null, searchField, searchResultsMarkup) : null;
18945 return React__default.createElement("div", {
18946 className: styles$1G.TopBar
18947 }, navigationButtonMarkup, contextMarkup, React__default.createElement("div", {
18948 className: styles$1G.Contents
18949 }, React__default.createElement("div", {
18950 className: styles$1G.SearchField
18951 }, searchMarkup), React__default.createElement("div", {
18952 className: styles$1G.SecondaryMenu
18953 }, secondaryMenu), userMenu));
18954};
18955TopBar.Menu = Menu;
18956TopBar.SearchField = SearchField;
18957TopBar.UserMenu = UserMenu;
18958
18959/* eslint-enable @typescript-eslint/camelcase */
18960
18961export { 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$1 as DataTable, DatePicker, DescriptionList, DisplayText, DropZone, EmptySearchResult, EmptyState, EventListener, ExceptionList, FilterType, Filters$1 as Filters, Focus, FooterHelp, Form, FormLayout, Frame$1 as Frame, Heading, Icon, Image, Indicator, InlineError, Key, KeyboardKey, KeypressListener, Label, Labelled, Layout, Link, List, Loading$1 as Loading, Modal$1 as Modal, Navigation$1 as Navigation, OptionList, Page$1 as Page, PageActions, Pagination, PolarisTestProvider, Popover, CloseSource as PopoverCloseSource, Portal, ProgressBar, RadioButton, RangeSlider, ResourceItem, ResourceList$1 as ResourceList, ResourcePicker$1 as ResourcePicker, ScrollLock, Scrollable, Select, SettingToggle, Sheet, SkeletonBodyText, SkeletonDisplayText, SkeletonPage, SkeletonThumbnail, Spinner, Stack, Sticky$1 as Sticky, Subheading, Tabs$1 as Tabs, Tag, TextContainer, TextField, TextStyle, ThemeProvider, Thumbnail, Toast$1 as Toast, Tooltip, TopBar, TrapFocus, Truncate, TypeOf, UNSTABLE_Color, Tokens as UNSTABLE_Tokens, buildColors as UNSTABLE_buildColors, roleVariants as UNSTABLE_roleVariants, 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 };