UNPKG

706 kBJavaScriptView Raw
1'use strict';
2
3Object.defineProperty(exports, '__esModule', { value: true });
4
5function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
6
7var React = require('react');
8var React__default = _interopDefault(React);
9var tokens = require('@shopify/polaris-tokens');
10var tokens__default = _interopDefault(tokens);
11var hsluv = require('hsluv');
12var isEqual = _interopDefault(require('lodash/isEqual'));
13var math = require('@shopify/javascript-utilities/math');
14var tslib_1 = require('tslib');
15var polarisIcons = require('@shopify/polaris-icons');
16var focus = require('@shopify/javascript-utilities/focus');
17var debounce = _interopDefault(require('lodash/debounce'));
18var events = require('@shopify/javascript-utilities/events');
19var dom = require('@shopify/javascript-utilities/dom');
20var geometry = require('@shopify/javascript-utilities/geometry');
21var reactDom = require('react-dom');
22var other = require('@shopify/javascript-utilities/other');
23var fastdom = require('@shopify/javascript-utilities/fastdom');
24var createApp = require('@shopify/app-bridge');
25var createApp__default = _interopDefault(createApp);
26var hoistStatics = _interopDefault(require('hoist-non-react-statics'));
27var dates = require('@shopify/javascript-utilities/dates');
28var reactTransitionGroup = require('@material-ui/react-transition-group');
29var actions = require('@shopify/app-bridge/actions');
30
31if (typeof window !== 'undefined') {
32 window.Polaris = window.Polaris || {};
33 window.Polaris.VERSION = '4.9.1';
34}
35
36var polarisVersion = '4.9.1';
37
38var ThemeContext = React__default.createContext(undefined);
39
40function _classCallCheck(instance, Constructor) {
41 if (!(instance instanceof Constructor)) {
42 throw new TypeError("Cannot call a class as a function");
43 }
44}
45
46function _defineProperties(target, props) {
47 for (var i = 0; i < props.length; i++) {
48 var descriptor = props[i];
49 descriptor.enumerable = descriptor.enumerable || false;
50 descriptor.configurable = true;
51 if ("value" in descriptor) descriptor.writable = true;
52 Object.defineProperty(target, descriptor.key, descriptor);
53 }
54}
55
56function _createClass(Constructor, protoProps, staticProps) {
57 if (protoProps) _defineProperties(Constructor.prototype, protoProps);
58 if (staticProps) _defineProperties(Constructor, staticProps);
59 return Constructor;
60}
61
62function _inherits(subClass, superClass) {
63 if (typeof superClass !== "function" && superClass !== null) {
64 throw new TypeError("Super expression must either be null or a function");
65 }
66
67 subClass.prototype = Object.create(superClass && superClass.prototype, {
68 constructor: {
69 value: subClass,
70 writable: true,
71 configurable: true
72 }
73 });
74 if (superClass) _setPrototypeOf(subClass, superClass);
75}
76
77function _getPrototypeOf(o) {
78 _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
79 return o.__proto__ || Object.getPrototypeOf(o);
80 };
81 return _getPrototypeOf(o);
82}
83
84function _setPrototypeOf(o, p) {
85 _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
86 o.__proto__ = p;
87 return o;
88 };
89
90 return _setPrototypeOf(o, p);
91}
92
93function isNativeReflectConstruct() {
94 if (typeof Reflect === "undefined" || !Reflect.construct) return false;
95 if (Reflect.construct.sham) return false;
96 if (typeof Proxy === "function") return true;
97
98 try {
99 Date.prototype.toString.call(Reflect.construct(Date, [], function () {}));
100 return true;
101 } catch (e) {
102 return false;
103 }
104}
105
106function _construct(Parent, args, Class) {
107 if (isNativeReflectConstruct()) {
108 _construct = Reflect.construct;
109 } else {
110 _construct = function _construct(Parent, args, Class) {
111 var a = [null];
112 a.push.apply(a, args);
113 var Constructor = Function.bind.apply(Parent, a);
114 var instance = new Constructor();
115 if (Class) _setPrototypeOf(instance, Class.prototype);
116 return instance;
117 };
118 }
119
120 return _construct.apply(null, arguments);
121}
122
123function _isNativeFunction(fn) {
124 return Function.toString.call(fn).indexOf("[native code]") !== -1;
125}
126
127function _wrapNativeSuper(Class) {
128 var _cache = typeof Map === "function" ? new Map() : undefined;
129
130 _wrapNativeSuper = function _wrapNativeSuper(Class) {
131 if (Class === null || !_isNativeFunction(Class)) return Class;
132
133 if (typeof Class !== "function") {
134 throw new TypeError("Super expression must either be null or a function");
135 }
136
137 if (typeof _cache !== "undefined") {
138 if (_cache.has(Class)) return _cache.get(Class);
139
140 _cache.set(Class, Wrapper);
141 }
142
143 function Wrapper() {
144 return _construct(Class, arguments, _getPrototypeOf(this).constructor);
145 }
146
147 Wrapper.prototype = Object.create(Class.prototype, {
148 constructor: {
149 value: Wrapper,
150 enumerable: false,
151 writable: true,
152 configurable: true
153 }
154 });
155 return _setPrototypeOf(Wrapper, Class);
156 };
157
158 return _wrapNativeSuper(Class);
159}
160
161function _assertThisInitialized(self) {
162 if (self === void 0) {
163 throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
164 }
165
166 return self;
167}
168
169function _possibleConstructorReturn(self, call) {
170 if (call && (typeof call === "object" || typeof call === "function")) {
171 return call;
172 }
173
174 return _assertThisInitialized(self);
175}
176
177function _slicedToArray(arr, i) {
178 return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _nonIterableRest();
179}
180
181function _toConsumableArray(arr) {
182 return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _nonIterableSpread();
183}
184
185function _arrayWithoutHoles(arr) {
186 if (Array.isArray(arr)) {
187 for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];
188
189 return arr2;
190 }
191}
192
193function _arrayWithHoles(arr) {
194 if (Array.isArray(arr)) return arr;
195}
196
197function _iterableToArray(iter) {
198 if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter);
199}
200
201function _iterableToArrayLimit(arr, i) {
202 if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) {
203 return;
204 }
205
206 var _arr = [];
207 var _n = true;
208 var _d = false;
209 var _e = undefined;
210
211 try {
212 for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
213 _arr.push(_s.value);
214
215 if (i && _arr.length === i) break;
216 }
217 } catch (err) {
218 _d = true;
219 _e = err;
220 } finally {
221 try {
222 if (!_n && _i["return"] != null) _i["return"]();
223 } finally {
224 if (_d) throw _e;
225 }
226 }
227
228 return _arr;
229}
230
231function _nonIterableSpread() {
232 throw new TypeError("Invalid attempt to spread non-iterable instance");
233}
234
235function _nonIterableRest() {
236 throw new TypeError("Invalid attempt to destructure non-iterable instance");
237}
238
239var MissingAppProviderError =
240/*#__PURE__*/
241function (_Error) {
242 _inherits(MissingAppProviderError, _Error);
243
244 function MissingAppProviderError() {
245 var _this;
246
247 var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
248
249 _classCallCheck(this, MissingAppProviderError);
250
251 _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.")));
252 _this.name = 'MissingAppProviderError';
253 return _this;
254 }
255
256 return MissingAppProviderError;
257}(_wrapNativeSuper(Error));
258
259function useTheme() {
260 var theme = React.useContext(ThemeContext);
261
262 if (!theme) {
263 throw new MissingAppProviderError('No Theme was provided.');
264 }
265
266 return theme;
267}
268
269// eslint-disable-next-line shopify/typescript/prefer-pascal-case-enums
270
271(function (UNSTABLE_Color) {
272 UNSTABLE_Color["Surface"] = "#FAFAFA";
273 UNSTABLE_Color["DarkSurface"] = "#111213";
274 UNSTABLE_Color["OnSurface"] = "#111213";
275 UNSTABLE_Color["Interactive"] = "#2E72D2";
276 UNSTABLE_Color["Neutral"] = "#111213";
277 UNSTABLE_Color["Primary"] = "#008060";
278 UNSTABLE_Color["Critical"] = "#D82C0D";
279 UNSTABLE_Color["Warning"] = "#FFC453";
280 UNSTABLE_Color["Highlight"] = "#5BCDDA";
281 UNSTABLE_Color["Success"] = "#008060";
282 UNSTABLE_Color["Decorative"] = "#FDC7CE";
283})(exports.UNSTABLE_Color || (exports.UNSTABLE_Color = {}));
284
285var roleVariants = {
286 surface: [{
287 name: 'surface',
288 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
289 light: {},
290 dark: {}
291 }, {
292 name: 'surfaceBackground',
293 description: 'For use in the background of our UIs as a background color, in components such as Page and Frame backgrounds.',
294 light: {
295 lightness: 98.3
296 },
297 dark: {
298 lightness: 3.3
299 }
300 }, {
301 name: 'surfaceForeground',
302 description: 'For use in the foreground of our UIs as a background color, in components such as Card, Modal, and Popover.',
303 light: {
304 lightness: 100
305 },
306 dark: {
307 lightness: 12.7
308 }
309 }, {
310 name: 'surfaceForegroundSubdued',
311 description: 'For use in the foreground of our UIs as a subdued background color, in components such as Card, Modal, and Popover.',
312 light: {
313 lightness: 98.3
314 },
315 dark: {
316 lightness: 10
317 }
318 }, {
319 name: 'surfaceHovered',
320 description: 'For use as a surface color on interactive elements such as resource list items and action list items when in a hovered state.',
321 light: {
322 lightness: 96
323 },
324 dark: {
325 lightness: 20
326 }
327 }, {
328 name: 'surfacePressed',
329 description: 'For use as a surface color on interactive elements such as resource list items and action list items when in a pressed state.',
330 light: {
331 lightness: 90
332 },
333 dark: {
334 lightness: 27
335 }
336 }, {
337 name: 'backdrop',
338 description: 'For use as the background color of the backdrop component for navigation and modal. This color has an alpha of `0.5`.',
339 light: {
340 hue: 0,
341 saturation: 0,
342 lightness: 0,
343 alpha: 0.5
344 },
345 dark: {
346 hue: 0,
347 saturation: 0,
348 lightness: 0,
349 alpha: 0.5
350 }
351 }, {
352 name: 'shadowFromAmbientLight',
353 description: 'For use in building shadows for popovers, cards, and modals. This color has an alpha of `0.05`.',
354 light: {
355 hue: 180,
356 saturation: 5,
357 lightness: 8,
358 alpha: 0.05
359 },
360 dark: {
361 hue: 180,
362 saturation: 5,
363 lightness: 8,
364 alpha: 0.05
365 }
366 }, {
367 name: 'shadowFromDirectLight',
368 description: 'For use in building shadows for popovers, cards, and modals. This color has an alpha of `0.15`.',
369 light: {
370 hue: 0,
371 saturation: 0,
372 lightness: 0,
373 alpha: 0.15
374 },
375 dark: {
376 hue: 0,
377 saturation: 0,
378 lightness: 0,
379 alpha: 0.15
380 }
381 }],
382 onSurface: [{
383 name: 'onSurface',
384 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
385 light: {},
386 dark: {}
387 }, {
388 name: 'borderOnSurface',
389 description: 'For use as a border (border or interactive outline).',
390 light: {
391 lightness: 75
392 },
393 dark: {
394 lightness: 35
395 }
396 }, {
397 name: 'borderDisabledOnSurface',
398 description: 'For use as a an interactive outline on disabled elements.',
399 light: {
400 lightness: 95
401 },
402 dark: {
403 lightness: 70
404 }
405 }, {
406 name: 'borderSubduedOnSurface',
407 description: 'For use as a subdued border (border or interactive outline).',
408 light: {
409 lightness: 85
410 },
411 dark: {
412 lightness: 32
413 }
414 }, {
415 name: 'iconOnSurface',
416 description: 'For use as the fill color of neutral icons.',
417 light: {
418 lightness: 40.1
419 },
420 dark: {
421 lightness: 70.1
422 }
423 }, {
424 name: 'iconDisabledOnSurface',
425 description: 'For use as the fill color of disabled neutral icons.',
426 light: {
427 lightness: 76.9
428 },
429 dark: {
430 lightness: 36.8
431 }
432 }, {
433 name: 'iconSubduedOnSurface',
434 description: 'For use as the fill color of subdued neutral icons.',
435 light: {
436 lightness: 59.8
437 },
438 dark: {
439 lightness: 52.1
440 }
441 }, {
442 name: 'textOnSurface',
443 description: 'For use as a neutral text color.',
444 light: {
445 lightness: 13.1
446 },
447 dark: {
448 lightness: 90.8
449 }
450 }, {
451 name: 'textDisabledOnSurface',
452 description: 'For use as a disabled neutral text color.',
453 light: {
454 lightness: 61.3
455 },
456 dark: {
457 lightness: 48.2
458 }
459 }, {
460 name: 'textSubduedOnSurface',
461 description: 'For use as a subdued neutral text color.',
462 light: {
463 lightness: 47.4
464 },
465 dark: {
466 lightness: 65.1
467 }
468 }],
469 interactive: [{
470 name: 'interactive',
471 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
472 light: {},
473 dark: {}
474 }, {
475 name: 'interactiveAction',
476 description: 'Used for links and plain buttons.',
477 light: {
478 lightness: 48.6
479 },
480 dark: {
481 lightness: 65,
482 saturation: 100,
483 hue: 247.6
484 }
485 }, {
486 name: 'interactiveActionDisabled',
487 description: 'Used for disabled links and plain buttons.',
488 light: {
489 lightness: 58
490 },
491 dark: {
492 lightness: 42
493 }
494 }, {
495 name: 'interactiveActionHovered',
496 description: 'Used for hovered links and plain buttons.',
497 light: {
498 lightness: 37
499 },
500 dark: {
501 lightness: 70,
502 saturation: 100,
503 hue: 247.6
504 }
505 }, {
506 name: 'interactiveActionSubdued',
507 description: 'Used for subdued links and plain buttons.',
508 light: {
509 lightness: 51
510 },
511 dark: {
512 lightness: 49
513 }
514 }, {
515 name: 'interactiveActionPressed',
516 description: 'Used for pressed links and plain buttons.',
517 light: {
518 lightness: 31
519 },
520 dark: {
521 lightness: 75,
522 saturation: 100,
523 hue: 247.6
524 }
525 }, {
526 name: 'interactiveFocus',
527 description: 'For use in the focus ring on interactive elements.',
528 light: {
529 lightness: 58
530 },
531 dark: {
532 lightness: 42
533 }
534 }, {
535 name: 'interactiveSelected',
536 description: 'For use as a surface color in selected interactive elements, in components such as option list and resource list.',
537 light: {
538 lightness: 96
539 },
540 dark: {
541 lightness: 4
542 }
543 }, {
544 name: 'interactiveSelectedHovered',
545 description: 'For use as a surface color in selected interactive elements that are hovered, in components such as option list and resource list.',
546 light: {
547 lightness: 89
548 },
549 dark: {
550 lightness: 11
551 }
552 }, {
553 name: 'interactiveSelectedPressed',
554 description: 'For use as a surface color in selected interactive elements that are pressed, in components such as option list and resource list.',
555 light: {
556 lightness: 82
557 },
558 dark: {
559 lightness: 18
560 }
561 }],
562 neutral: [{
563 name: 'neutral',
564 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
565 light: {},
566 dark: {}
567 }, {
568 name: 'neutralAction',
569 description: 'Used for secondary buttons and tertiary buttons, as well as in form elements as a background color and pontentially other neutral surfaces.',
570 light: {
571 lightness: 93
572 },
573 dark: {
574 lightness: 22
575 }
576 }, {
577 name: 'neutralActionDisabled',
578 description: 'Used as a disabled state for secondary buttons',
579 light: {
580 lightness: 94
581 },
582 dark: {
583 lightness: 13
584 }
585 }, {
586 name: 'neutralActionHovered',
587 description: 'Used as a hovered state for secondary buttons',
588 light: {
589 lightness: 90
590 },
591 dark: {
592 lightness: 37
593 }
594 }, {
595 name: 'neutralActionPressed',
596 description: 'Used as a pressed state for secondary buttons',
597 light: {
598 lightness: 87
599 },
600 dark: {
601 lightness: 42
602 }
603 }],
604 primary: [{
605 name: 'primary',
606 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
607 light: {},
608 dark: {}
609 }, {
610 name: 'primaryAction',
611 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.',
612 light: {
613 lightness: 47.3
614 },
615 dark: {
616 lightness: 47.3
617 }
618 }, {
619 name: 'primaryActionDisabled',
620 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.',
621 light: {
622 lightness: 32
623 },
624 dark: {
625 lightness: 32
626 }
627 }, {
628 name: 'primaryActionHovered',
629 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.',
630 light: {
631 lightness: 42.3
632 },
633 dark: {
634 lightness: 55
635 }
636 }, {
637 name: 'primaryActionPressed',
638 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.',
639 light: {
640 lightness: 37.3
641 },
642 dark: {
643 lightness: 60
644 }
645 }, {
646 name: 'iconOnPrimary',
647 description: 'For use as a fill color for icons on primary actions. Not for use in icons on navigation and tabs.',
648 light: {
649 lightness: 98
650 },
651 dark: {
652 lightness: 98
653 }
654 }, {
655 name: 'textOnPrimary',
656 description: 'For use as a text color on primary actions. Not for use in text on navigation and tabs.',
657 light: {
658 lightness: 100
659 },
660 dark: {
661 lightness: 100
662 }
663 }, {
664 name: 'primarySelected',
665 description: 'Used as a surface color to indicate selected interactive states in navigation and tabs.',
666 light: {
667 lightness: 95,
668 saturation: 30
669 },
670 dark: {
671 lightness: 5,
672 saturation: 30
673 }
674 }, {
675 name: 'primarySelectedHovered',
676 description: 'Used as a surface color to indicate selected interactive states that are hovered in navigation and tabs.',
677 light: {
678 lightness: 81,
679 saturation: 22
680 },
681 dark: {
682 lightness: 19,
683 saturation: 22
684 }
685 }, {
686 name: 'primarySelectedPressed',
687 description: 'Used as a surface color to indicate selected interactive states that are pressed in navigation and tabs.',
688 light: {
689 lightness: 74,
690 saturation: 22
691 },
692 dark: {
693 lightness: 26,
694 saturation: 22
695 }
696 }],
697 critical: [{
698 name: 'critical',
699 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
700 light: {},
701 dark: {}
702 }, {
703 name: 'criticalBorder',
704 description: 'For use as a border on critical components such as banners, and as an outline on interactive elements in an error state.',
705 light: {
706 lightness: 50
707 },
708 dark: {
709 lightness: 50
710 }
711 }, {
712 name: 'criticalBorderDisabled',
713 description: 'For use as a disabled border on critical components such as banners, and as an outline on interactive elements in an error state.',
714 light: {
715 lightness: 82
716 },
717 dark: {
718 lightness: 28
719 }
720 }, {
721 name: 'criticalIcon',
722 description: 'For use as an icon fill color on top of critical elements.',
723 light: {
724 lightness: 52
725 },
726 dark: {
727 lightness: 48
728 }
729 }, {
730 name: 'criticalSurface',
731 description: 'For use as a surface color on critical elements including badges.',
732 light: {
733 lightness: 98.6
734 },
735 dark: {
736 lightness: 12
737 }
738 }, {
739 name: 'criticalSurfaceSubdued',
740 description: 'For use as a subdued surface color on critical elements including banners.',
741 light: {
742 lightness: 98
743 },
744 dark: {
745 lightness: 12
746 }
747 }, {
748 name: 'criticalSurfaceSubduedHovered',
749 description: 'For use as a surface color on critical interactive elements including action list items in a hovered state.',
750 light: {
751 lightness: 96
752 },
753 dark: {
754 lightness: 15,
755 saturation: 60
756 }
757 }, {
758 name: 'criticalSurfaceSubduedPressed',
759 description: 'For use as a surface color on critical interactive elements including action list items in a pressed state.',
760 light: {
761 lightness: 88
762 },
763 dark: {
764 lightness: 22
765 }
766 }, {
767 name: 'criticalText',
768 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.',
769 light: {
770 lightness: 47.3
771 },
772 dark: {
773 lightness: 65,
774 saturation: 70
775 }
776 }, {
777 name: 'criticalAction',
778 description: 'For use as the background color for destructive buttons, and as the background color for error toast messages.',
779 light: {
780 lightness: 47.5
781 },
782 dark: {
783 lightness: 45
784 }
785 }, {
786 name: 'criticalActionDisabled',
787 description: 'For use as the background color for disabled destructive buttons, and as the background color for error toast messages.',
788 light: {
789 lightness: 59
790 },
791 dark: {
792 lightness: 41
793 }
794 }, {
795 name: 'criticalActionHovered',
796 description: 'For use as the background color for hovered destructive buttons, and as the background color for error toast messages.',
797 light: {
798 lightness: 42.5
799 },
800 dark: {
801 lightness: 50
802 }
803 }, {
804 name: 'criticalActionPressed',
805 description: 'For use as the background color for pressed destructive buttons, and as the background color for error toast messages.',
806 light: {
807 lightness: 37.5
808 },
809 dark: {
810 lightness: 55
811 }
812 }, {
813 name: 'iconOnCritical',
814 description: 'For use as a fill color for icons on critical actions.',
815 light: {
816 lightness: 98
817 },
818 dark: {
819 lightness: 98
820 }
821 }, {
822 name: 'textOnCritical',
823 description: 'For use as a text color on critical actions.',
824 light: {
825 lightness: 100
826 },
827 dark: {
828 lightness: 100
829 }
830 }, {
831 name: 'criticalLink',
832 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.',
833 light: {
834 lightness: 48.5
835 },
836 dark: {
837 lightness: 65
838 }
839 }, {
840 name: 'criticalLinkDisabled',
841 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.',
842 light: {
843 lightness: 72
844 },
845 dark: {
846 lightness: 78
847 }
848 }, {
849 name: 'criticalLinkHovered',
850 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.',
851 light: {
852 lightness: 45
853 },
854 dark: {
855 lightness: 70
856 }
857 }, {
858 name: 'criticalLinkPressed',
859 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.',
860 light: {
861 lightness: 21
862 },
863 dark: {
864 lightness: 75
865 }
866 }],
867 warning: [{
868 name: 'warning',
869 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
870 light: {},
871 dark: {}
872 }, {
873 name: 'warningBorder',
874 description: 'For use as a border on warning components such as banners.',
875 light: {
876 lightness: 76.6
877 },
878 dark: {
879 lightness: 50
880 }
881 }, {
882 name: 'warningIcon',
883 description: 'For use as an icon fill color on top of warning elements.',
884 light: {
885 lightness: 66
886 },
887 dark: {
888 lightness: 34
889 }
890 }, {
891 name: 'warningSurface',
892 description: 'For use as a surface color on warning elements including badges.',
893 light: {
894 lightness: 84.5
895 },
896 dark: {
897 lightness: 50
898 }
899 }, {
900 name: 'warningSurfaceSubdued',
901 description: 'For use as a subdued surface color on warning elements including banners.',
902 light: {
903 lightness: 96
904 },
905 dark: {
906 lightness: 26,
907 saturation: 71
908 }
909 }, {
910 name: 'warningText',
911 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.',
912 light: {
913 lightness: 47.4
914 },
915 dark: {
916 lightness: 64.9
917 }
918 }],
919 highlight: [{
920 name: 'highlight',
921 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
922 light: {},
923 dark: {}
924 }, {
925 name: 'highlightBorder',
926 description: 'For use as a border on informational components such as banners.',
927 light: {
928 lightness: 60
929 },
930 dark: {
931 lightness: 60
932 }
933 }, {
934 name: 'highlightIcon',
935 description: 'For use as an icon fill color on top of informational elements.',
936 light: {
937 lightness: 58
938 },
939 dark: {
940 lightness: 42
941 }
942 }, {
943 name: 'highlightSurface',
944 description: 'For use as a surface color on information elements including badges.',
945 light: {
946 lightness: 84.5,
947 saturation: 60
948 },
949 dark: {
950 lightness: 40,
951 saturation: 100
952 }
953 }, {
954 name: 'highlightSurfaceSubdued',
955 description: 'For use as a surface color on information elements including banners.',
956 light: {
957 lightness: 98.6
958 },
959 dark: {
960 lightness: 20
961 }
962 }, {
963 name: 'highlightext',
964 description: 'For use as a text color in inert informational elements. Not for use as a text color on banners and badges.',
965 light: {
966 lightness: 10
967 },
968 dark: {
969 lightness: 90
970 }
971 }],
972 success: [{
973 name: 'success',
974 description: 'While use directly in our components is discouraged, the base variant is unmodified from the original role input color.',
975 light: {},
976 dark: {}
977 }, {
978 name: 'successBorder',
979 description: 'For use as a border on success components such as banners.',
980 light: {
981 lightness: 50
982 },
983 dark: {
984 lightness: 50
985 }
986 }, {
987 name: 'successIcon',
988 description: 'For use as an icon fill color on top of success elements.',
989 light: {
990 lightness: 25
991 },
992 dark: {
993 lightness: 35
994 }
995 }, {
996 name: 'successSurface',
997 description: 'For use as a surface color on success elements including badges.',
998 light: {
999 lightness: 84.5,
1000 saturation: 60
1001 },
1002 dark: {
1003 lightness: 35
1004 }
1005 }, {
1006 name: 'successSurfaceSubdued',
1007 description: 'For use as a surface color on information elements including banners.',
1008 light: {
1009 lightness: 99,
1010 saturation: 60
1011 },
1012 dark: {
1013 lightness: 20,
1014 saturation: 60
1015 }
1016 }, {
1017 name: 'successText',
1018 description: 'For use as a text color in inert success elements. Not for use as a text color on banners and badges.',
1019 light: {
1020 lightness: 47.3
1021 },
1022 dark: {
1023 lightness: 65,
1024 saturation: 70
1025 }
1026 }],
1027 decorative: [{
1028 name: 'decorativeOneSurface',
1029 description: 'For use as a decorative surface color.',
1030 light: {
1031 hue: 56,
1032 saturation: 100,
1033 lightness: 84
1034 },
1035 dark: {
1036 hue: 54,
1037 saturation: 98,
1038 lightness: 46
1039 }
1040 }, {
1041 name: 'decorativeOneText',
1042 description: 'For use as a decorative text color that is applied on a decorative surface.',
1043 light: {
1044 hue: 52,
1045 saturation: 100,
1046 lightness: 18
1047 },
1048 dark: {
1049 lightness: 100
1050 }
1051 }, {
1052 name: 'decorativeTwoSurface',
1053 description: 'For use as a decorative surface color.',
1054 light: {
1055 hue: 30,
1056 saturation: 100,
1057 lightness: 84
1058 },
1059 dark: {
1060 hue: 24,
1061 saturation: 96,
1062 lightness: 52
1063 }
1064 }, {
1065 name: 'decorativeTwoText',
1066 description: 'For use as a decorative text color that is applied on a decorative surface.',
1067 light: {
1068 hue: 362,
1069 saturation: 80,
1070 lightness: 14
1071 },
1072 dark: {
1073 lightness: 100
1074 }
1075 }, {
1076 name: 'decorativeThreeSurface',
1077 description: 'For use as a decorative surface color.',
1078 light: {
1079 hue: 144,
1080 saturation: 54,
1081 lightness: 84
1082 },
1083 dark: {
1084 hue: 154,
1085 saturation: 100,
1086 lightness: 46
1087 }
1088 }, {
1089 name: 'decorativeThreeText',
1090 description: 'For use as a decorative text color that is applied on a decorative surface.',
1091 light: {
1092 hue: 144,
1093 saturation: 100,
1094 lightness: 16
1095 },
1096 dark: {
1097 lightness: 100
1098 }
1099 }, {
1100 name: 'decorativeFourSurface',
1101 description: 'For use as a decorative surface color.',
1102 light: {
1103 hue: 180,
1104 saturation: 56,
1105 lightness: 84
1106 },
1107 dark: {
1108 hue: 188,
1109 saturation: 95,
1110 lightness: 47
1111 }
1112 }, {
1113 name: 'decorativeFourText',
1114 description: 'For use as a decorative text color that is applied on a decorative surface.',
1115 light: {
1116 hue: 190,
1117 saturation: 100,
1118 lightness: 16
1119 },
1120 dark: {
1121 lightness: 100
1122 }
1123 }, {
1124 name: 'decorativeFiveSurface',
1125 description: 'For use as a decorative surface color.',
1126 light: {},
1127 dark: {
1128 hue: 363,
1129 saturation: 77,
1130 lightness: 45
1131 }
1132 }, {
1133 name: 'decorativeFiveText',
1134 description: 'For use as a decorative text color that is applied on a decorative surface.',
1135 light: {
1136 hue: 363,
1137 saturation: 78,
1138 lightness: 16
1139 },
1140 dark: {
1141 lightness: 100
1142 }
1143 }]
1144};
1145
1146function compose() {
1147 for (var _len = arguments.length, fns = new Array(_len), _key = 0; _key < _len; _key++) {
1148 fns[_key] = arguments[_key];
1149 }
1150
1151 return fns.reduce(function (func, group) {
1152 return function () {
1153 return func(group.apply(void 0, arguments));
1154 };
1155 });
1156}
1157
1158function rgbString(color) {
1159 var red = color.red,
1160 green = color.green,
1161 blue = color.blue;
1162
1163 if (Object.prototype.hasOwnProperty.call(color, 'alpha')) {
1164 return "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(color.alpha, ")");
1165 } else {
1166 return "rgb(".concat(red, ", ").concat(green, ", ").concat(blue, ")");
1167 }
1168}
1169var rgbaString = rgbString;
1170function rgbToHex(_ref) {
1171 var red = _ref.red,
1172 green = _ref.green,
1173 blue = _ref.blue;
1174 return "#".concat(componentToHex(red)).concat(componentToHex(green)).concat(componentToHex(blue));
1175}
1176
1177function componentToHex(component) {
1178 var hex = component.toString(16);
1179 return hex.length === 1 ? "0".concat(hex) : hex;
1180}
1181
1182function hsbToHex(color) {
1183 return rgbToHex(hsbToRgb(color));
1184}
1185
1186function rgbFromHueAndChroma(hue, chroma) {
1187 var huePrime = hue / 60;
1188 var hueDelta = 1 - Math.abs(huePrime % 2 - 1);
1189 var intermediateValue = chroma * hueDelta;
1190 var red = 0;
1191 var green = 0;
1192 var blue = 0;
1193
1194 if (huePrime >= 0 && huePrime <= 1) {
1195 red = chroma;
1196 green = intermediateValue;
1197 blue = 0;
1198 }
1199
1200 if (huePrime >= 1 && huePrime <= 2) {
1201 red = intermediateValue;
1202 green = chroma;
1203 blue = 0;
1204 }
1205
1206 if (huePrime >= 2 && huePrime <= 3) {
1207 red = 0;
1208 green = chroma;
1209 blue = intermediateValue;
1210 }
1211
1212 if (huePrime >= 3 && huePrime <= 4) {
1213 red = 0;
1214 green = intermediateValue;
1215 blue = chroma;
1216 }
1217
1218 if (huePrime >= 4 && huePrime <= 5) {
1219 red = intermediateValue;
1220 green = 0;
1221 blue = chroma;
1222 }
1223
1224 if (huePrime >= 5 && huePrime <= 6) {
1225 red = chroma;
1226 green = 0;
1227 blue = intermediateValue;
1228 }
1229
1230 return {
1231 red,
1232 green,
1233 blue
1234 };
1235}
1236
1237function hsbToRgb(color) {
1238 var hue = color.hue,
1239 saturation = color.saturation,
1240 brightness = color.brightness,
1241 _color$alpha = color.alpha,
1242 alpha = _color$alpha === void 0 ? 1 : _color$alpha;
1243 var chroma = brightness * saturation;
1244
1245 var _rgbFromHueAndChroma = rgbFromHueAndChroma(hue, chroma),
1246 red = _rgbFromHueAndChroma.red,
1247 green = _rgbFromHueAndChroma.green,
1248 blue = _rgbFromHueAndChroma.blue;
1249
1250 var chromaBrightnessDelta = brightness - chroma;
1251 red += chromaBrightnessDelta;
1252 green += chromaBrightnessDelta;
1253 blue += chromaBrightnessDelta;
1254 return {
1255 red: Math.round(red * 255),
1256 green: Math.round(green * 255),
1257 blue: Math.round(blue * 255),
1258 alpha
1259 };
1260}
1261function hslToRgb(color) {
1262 var hue = color.hue,
1263 saturation = color.saturation,
1264 lightness = color.lightness,
1265 _color$alpha2 = color.alpha,
1266 alpha = _color$alpha2 === void 0 ? 1 : _color$alpha2;
1267 var chroma = (1 - Math.abs(2 * (lightness / 100) - 1)) * (saturation / 100);
1268
1269 var _rgbFromHueAndChroma2 = rgbFromHueAndChroma(hue, chroma),
1270 red = _rgbFromHueAndChroma2.red,
1271 green = _rgbFromHueAndChroma2.green,
1272 blue = _rgbFromHueAndChroma2.blue;
1273
1274 var lightnessVal = lightness / 100 - chroma / 2;
1275 red += lightnessVal;
1276 green += lightnessVal;
1277 blue += lightnessVal;
1278 return {
1279 red: Math.round(red * 255),
1280 green: Math.round(green * 255),
1281 blue: Math.round(blue * 255),
1282 alpha
1283 };
1284} // ref https://en.wikipedia.org/wiki/HSL_and_HSV
1285
1286function rgbToHsbl(color) {
1287 var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'b';
1288 var r = color.red,
1289 g = color.green,
1290 b = color.blue,
1291 _color$alpha3 = color.alpha,
1292 alpha = _color$alpha3 === void 0 ? 1 : _color$alpha3;
1293 var red = r / 255;
1294 var green = g / 255;
1295 var blue = b / 255;
1296 var largestComponent = Math.max(red, green, blue);
1297 var smallestComponent = Math.min(red, green, blue);
1298 var delta = largestComponent - smallestComponent;
1299 var lightness = (largestComponent + smallestComponent) / 2;
1300 var saturation = 0;
1301
1302 if (largestComponent === 0) {
1303 saturation = 0;
1304 } else if (type === 'b') {
1305 saturation = delta / largestComponent;
1306 } else if (type === 'l') {
1307 var baseSaturation = lightness > 0.5 ? delta / (2 - largestComponent - smallestComponent) : delta / (largestComponent + smallestComponent);
1308 saturation = isNaN(baseSaturation) ? 0 : baseSaturation;
1309 }
1310
1311 var huePercentage = 0;
1312
1313 switch (largestComponent) {
1314 case red:
1315 huePercentage = (green - blue) / delta + (green < blue ? 6 : 0);
1316 break;
1317
1318 case green:
1319 huePercentage = (blue - red) / delta + 2;
1320 break;
1321
1322 case blue:
1323 huePercentage = (red - green) / delta + 4;
1324 }
1325
1326 var hue = Math.round(huePercentage / 6 * 360);
1327 return {
1328 hue: math.clamp(hue, 0, 360) || 0,
1329 saturation: parseFloat(math.clamp(saturation, 0, 1).toFixed(2)),
1330 brightness: parseFloat(math.clamp(largestComponent, 0, 1).toFixed(2)),
1331 lightness: parseFloat(lightness.toFixed(2)),
1332 alpha: parseFloat(alpha.toFixed(2))
1333 };
1334}
1335
1336function rgbToHsb(color) {
1337 var _rgbToHsbl = rgbToHsbl(color, 'b'),
1338 hue = _rgbToHsbl.hue,
1339 saturation = _rgbToHsbl.saturation,
1340 brightness = _rgbToHsbl.brightness,
1341 _rgbToHsbl$alpha = _rgbToHsbl.alpha,
1342 alpha = _rgbToHsbl$alpha === void 0 ? 1 : _rgbToHsbl$alpha;
1343
1344 return {
1345 hue,
1346 saturation,
1347 brightness,
1348 alpha
1349 };
1350}
1351function rgbToHsl(color) {
1352 var _rgbToHsbl2 = rgbToHsbl(color, 'l'),
1353 hue = _rgbToHsbl2.hue,
1354 rawSaturation = _rgbToHsbl2.saturation,
1355 rawLightness = _rgbToHsbl2.lightness,
1356 _rgbToHsbl2$alpha = _rgbToHsbl2.alpha,
1357 alpha = _rgbToHsbl2$alpha === void 0 ? 1 : _rgbToHsbl2$alpha;
1358
1359 var saturation = rawSaturation * 100;
1360 var lightness = rawLightness * 100;
1361 return {
1362 hue,
1363 saturation,
1364 lightness,
1365 alpha
1366 };
1367}
1368function hexToRgb(color) {
1369 if (color.length === 4) {
1370 var repeatHex = function repeatHex(hex1, hex2) {
1371 return color.slice(hex1, hex2).repeat(2);
1372 };
1373
1374 var _red = parseInt(repeatHex(1, 2), 16);
1375
1376 var _green = parseInt(repeatHex(2, 3), 16);
1377
1378 var _blue = parseInt(repeatHex(3, 4), 16);
1379
1380 return {
1381 red: _red,
1382 green: _green,
1383 blue: _blue
1384 };
1385 }
1386
1387 var red = parseInt(color.slice(1, 3), 16);
1388 var green = parseInt(color.slice(3, 5), 16);
1389 var blue = parseInt(color.slice(5, 7), 16);
1390 return {
1391 red,
1392 green,
1393 blue
1394 };
1395}
1396var ColorType;
1397
1398(function (ColorType) {
1399 ColorType["Hex"] = "hex";
1400 ColorType["Rgb"] = "rgb";
1401 ColorType["Rgba"] = "rgba";
1402 ColorType["Hsl"] = "hsl";
1403 ColorType["Hsla"] = "hsla";
1404 ColorType["Default"] = "default";
1405})(ColorType || (ColorType = {}));
1406
1407function getColorType(color) {
1408 if (color.includes('#')) {
1409 return ColorType.Hex;
1410 } else if (color.includes('rgb')) {
1411 return ColorType.Rgb;
1412 } else if (color.includes('rgba')) {
1413 return ColorType.Rgba;
1414 } else if (color.includes('hsl')) {
1415 return ColorType.Hsl;
1416 } else if (color.includes('hsla')) {
1417 return ColorType.Hsla;
1418 } else {
1419 if (process.env.NODE_ENV === 'development') {
1420 /* eslint-disable-next-line no-console */
1421 console.warn('Accepted colors formats are: hex, rgb, rgba, hsl and hsla');
1422 }
1423
1424 return ColorType.Default;
1425 }
1426}
1427
1428function hslToString(hslColor) {
1429 if (typeof hslColor === 'string') {
1430 return hslColor;
1431 }
1432
1433 var _hslColor$alpha = hslColor.alpha,
1434 alpha = _hslColor$alpha === void 0 ? 1 : _hslColor$alpha,
1435 hue = hslColor.hue,
1436 lightness = hslColor.lightness,
1437 saturation = hslColor.saturation;
1438 return "hsla(".concat(hue, ", ").concat(saturation, "%, ").concat(lightness, "%, ").concat(alpha, ")");
1439}
1440
1441function rgbToObject(color) {
1442 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1443 var colorMatch = color.match(/\(([^)]+)\)/);
1444
1445 if (!colorMatch) {
1446 return {
1447 red: 0,
1448 green: 0,
1449 blue: 0,
1450 alpha: 0
1451 };
1452 }
1453
1454 var _colorMatch$1$split = colorMatch[1].split(','),
1455 _colorMatch$1$split2 = _slicedToArray(_colorMatch$1$split, 4),
1456 red = _colorMatch$1$split2[0],
1457 green = _colorMatch$1$split2[1],
1458 blue = _colorMatch$1$split2[2],
1459 alpha = _colorMatch$1$split2[3];
1460
1461 var objColor = {
1462 red: parseInt(red, 10),
1463 green: parseInt(green, 10),
1464 blue: parseInt(blue, 10),
1465 alpha: parseInt(alpha, 10) || 1
1466 };
1467 return objColor;
1468}
1469
1470var hexToHsla = compose(rgbToHsl, hexToRgb);
1471var rbgStringToHsla = compose(rgbToHsl, rgbToObject);
1472
1473function hslToObject(color) {
1474 // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec
1475 var colorMatch = color.match(/\(([^)]+)\)/);
1476
1477 if (!colorMatch) {
1478 return {
1479 hue: 0,
1480 saturation: 0,
1481 lightness: 0,
1482 alpha: 0
1483 };
1484 }
1485
1486 var _colorMatch$1$split3 = colorMatch[1].split(','),
1487 _colorMatch$1$split4 = _slicedToArray(_colorMatch$1$split3, 4),
1488 hue = _colorMatch$1$split4[0],
1489 saturation = _colorMatch$1$split4[1],
1490 lightness = _colorMatch$1$split4[2],
1491 alpha = _colorMatch$1$split4[3];
1492
1493 var objColor = {
1494 hue: parseInt(hue, 10),
1495 saturation: parseInt(saturation, 10),
1496 lightness: parseInt(lightness, 10),
1497 alpha: parseFloat(alpha) || 1
1498 };
1499 return objColor;
1500}
1501
1502function colorToHsla(color) {
1503 var type = getColorType(color);
1504
1505 switch (type) {
1506 case ColorType.Hex:
1507 return hexToHsla(color);
1508
1509 case ColorType.Rgb:
1510 case ColorType.Rgba:
1511 return rbgStringToHsla(color);
1512
1513 case ColorType.Hsla:
1514 case ColorType.Hsl:
1515 return hslToObject(color);
1516
1517 case ColorType.Default:
1518 default:
1519 throw new Error('Accepted color formats are: hex, rgb, rgba, hsl and hsla');
1520 }
1521}
1522
1523// implements: https://www.w3.org/WAI/ER/WD-AERT/#color-contrast
1524function isLight(_ref) {
1525 var red = _ref.red,
1526 green = _ref.green,
1527 blue = _ref.blue;
1528 var contrast = (red * 299 + green * 587 + blue * 114) / 1000;
1529 return contrast > 125;
1530}
1531
1532function normalizeName(name) {
1533 return name.split(/(?=[A-Z])/).join('-').toLowerCase();
1534}
1535function constructColorName(baseName, property, suffix) {
1536 var name = normalizeName(baseName);
1537 var propertyName = property ? "-".concat(normalizeName(property)) : '';
1538 var constructedSuffix = suffix ? "-".concat(suffix) : '';
1539 return "--".concat(name).concat(propertyName).concat(constructedSuffix);
1540}
1541
1542function lightenColor(color) {
1543 var lighten = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1544
1545 if (typeof color === 'string') {
1546 return color;
1547 }
1548
1549 var lightness = color.lightness;
1550 var nextLightness = lightness + lighten;
1551 return Object.assign({}, color, {
1552 lightness: math.clamp(nextLightness, 0, 100)
1553 });
1554}
1555function saturateColor(color) {
1556 var saturate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
1557
1558 if (typeof color === 'string') {
1559 return color;
1560 }
1561
1562 var saturation = color.saturation;
1563 var nextSaturation = saturation + saturate;
1564 return Object.assign({}, color, {
1565 saturation: nextSaturation
1566 });
1567}
1568function createLightColor(color, lightness, saturation) {
1569 var lightenedColor = lightenColor(color, lightness);
1570 var saturatedColor = saturateColor(lightenedColor, -saturation);
1571 return saturatedColor;
1572}
1573
1574var needsVariantList = ['topBar'];
1575
1576var BorderRadius = {
1577 borderRadiusBase: rem('4px'),
1578 borderRadiusWide: rem('8px')
1579};
1580var Shadow = {
1581 cardShadow: '0px 0px 5px var(--p-shadow-from-ambient-light), 0px 1px 2px var(--p-shadow-from-direct-light)',
1582 popoverShadow: '-1px 0px 20px var(--p-shadow-from-ambient-light), 0px 1px 5px var(--p-shadow-from-direct-light)',
1583 modalShadow: '0px 6px 32px var(--p-shadow-from-ambient-light), 0px 1px 6px var(--p-shadow-from-direct-light)'
1584};
1585var Overrides = {
1586 overrideNone: 'none',
1587 overrideTransparent: 'transparent',
1588 overrideOne: '1',
1589 overrideVisible: 'visible',
1590 overrideZero: '0',
1591 overrideLoadingZIndex: '514',
1592 buttonFontWeight: '500',
1593 nonNullContent: "''",
1594 bannerDefaultBorder: buildBannerBorder('--p-border-on-surface'),
1595 bannerSuccessBorder: buildBannerBorder('--p-success-border'),
1596 bannerHighlightBorder: buildBannerBorder('--p-highlight-border'),
1597 bannerWarningBorder: buildBannerBorder('--p-warning-border'),
1598 bannerCriticalBorder: buildBannerBorder('--p-critical-border'),
1599 badgeMixBlendMode: 'luminosity',
1600 borderSubdued: "".concat(rem('1px'), " solid var(--p-border-subdued-on-surface)"),
1601 textFieldSpinnerOffset: rem('2px'),
1602 textFieldFocusRingOffset: rem('-4px'),
1603 textFieldFocusRingBorderRadius: rem('7px'),
1604 buttonGroupItemSpacing: rem('2px')
1605};
1606var Tokens = Object.assign({}, BorderRadius, Shadow, Overrides);
1607
1608function rem(px) {
1609 var baseFontSize = 10;
1610 return "".concat(parseInt(px, 10) / baseFontSize, "rem");
1611}
1612
1613function buildBannerBorder(cssVar) {
1614 return "inset 0 ".concat(rem('2px'), " 0 0 var(").concat(cssVar, "), inset 0 0 0 ").concat(rem('2px'), " var(").concat(cssVar, ")");
1615}
1616
1617function buildCustomProperties(themeConfig, globalTheming) {
1618 return globalTheming ? customPropertyTransformer(Object.assign({}, buildColors(themeConfig, roleVariants), Tokens)) : buildLegacyColors(themeConfig);
1619}
1620function buildThemeContext(themeConfig, cssCustomProperties) {
1621 var logo = themeConfig.logo;
1622 return {
1623 logo,
1624 UNSTABLE_cssCustomProperties: toString(cssCustomProperties)
1625 };
1626}
1627
1628function toString(obj) {
1629 if (obj) {
1630 return Object.entries(obj).map(function (pair) {
1631 return pair.join(':');
1632 }).join(';');
1633 } else {
1634 return undefined;
1635 }
1636}
1637
1638function hexToHsluvObj(hex) {
1639 var _hexToHsluv = hsluv.hexToHsluv(hex),
1640 _hexToHsluv2 = _slicedToArray(_hexToHsluv, 3),
1641 hue = _hexToHsluv2[0],
1642 saturation = _hexToHsluv2[1],
1643 lightness = _hexToHsluv2[2];
1644
1645 return {
1646 hue,
1647 saturation,
1648 lightness
1649 };
1650}
1651
1652function buildColors(theme, roleVariants) {
1653 var colors = Object.assign({
1654 surface: exports.UNSTABLE_Color.Surface,
1655 onSurface: exports.UNSTABLE_Color.OnSurface,
1656 interactive: exports.UNSTABLE_Color.Interactive,
1657 neutral: exports.UNSTABLE_Color.Neutral,
1658 primary: exports.UNSTABLE_Color.Primary,
1659 critical: exports.UNSTABLE_Color.Critical,
1660 warning: exports.UNSTABLE_Color.Warning,
1661 highlight: exports.UNSTABLE_Color.Highlight,
1662 success: exports.UNSTABLE_Color.Success,
1663 decorative: exports.UNSTABLE_Color.Decorative
1664 }, theme.UNSTABLE_colors);
1665 var lightSurface = isLight(hexToRgb(colors.surface));
1666 return Object.entries(roleVariants).reduce(function (acc1, _ref) {
1667 var _ref2 = _slicedToArray(_ref, 2),
1668 role = _ref2[0],
1669 variants = _ref2[1];
1670
1671 var base = hexToHsluvObj(colors[role]);
1672 return Object.assign({}, acc1, variants.reduce(function (acc2, _ref3) {
1673 var name = _ref3.name,
1674 light = _ref3.light,
1675 dark = _ref3.dark;
1676 var configs = {
1677 default: lightSurface ? light : dark
1678 };
1679
1680 if (!isEqual(light, dark)) {
1681 configs.Inverse = lightSurface ? dark : light;
1682 configs.Light = light;
1683 configs.Dark = dark;
1684 }
1685
1686 return Object.assign({}, acc2, Object.entries(configs).reduce(function (acc3, _ref4) {
1687 var _ref5 = _slicedToArray(_ref4, 2),
1688 variant = _ref5[0],
1689 config = _ref5[1];
1690
1691 var _config$hue = config.hue,
1692 hue = _config$hue === void 0 ? base.hue : _config$hue,
1693 _config$saturation = config.saturation,
1694 saturation = _config$saturation === void 0 ? base.saturation : _config$saturation,
1695 _config$lightness = config.lightness,
1696 lightness = _config$lightness === void 0 ? base.lightness : _config$lightness,
1697 _config$alpha = config.alpha,
1698 alpha = _config$alpha === void 0 ? 1 : _config$alpha;
1699 var displayName = variant === 'default' ? name : "".concat(name).concat(variant);
1700 return Object.assign({}, acc3, {
1701 [displayName]: hslToString(Object.assign({}, colorToHsla(hsluv.hsluvToHex([hue, saturation, lightness])), {
1702 alpha
1703 }))
1704 });
1705 }, {}));
1706 }, {}));
1707 }, {});
1708}
1709
1710function customPropertyTransformer(properties) {
1711 return Object.entries(properties).reduce(function (transformed, _ref6) {
1712 var _ref7 = _slicedToArray(_ref6, 2),
1713 key = _ref7[0],
1714 value = _ref7[1];
1715
1716 return Object.assign({}, transformed, {
1717 [toCssCustomPropertySyntax(key)]: value
1718 });
1719 }, {});
1720}
1721
1722function toCssCustomPropertySyntax(camelCase) {
1723 return "--p-".concat(camelCase.replace(/([A-Z0-9])/g, '-$1').toLowerCase());
1724}
1725
1726function buildLegacyColors(theme) {
1727 var colorPairs;
1728 var colors = theme && theme.colors && theme.colors.topBar ? theme.colors.topBar : {
1729 background: '#00848e',
1730 backgroundLighter: '#1d9ba4',
1731 color: '#f9fafb'
1732 };
1733 var colorKey = 'topBar';
1734 var colorKeys = Object.keys(colors);
1735
1736 if (colorKeys.length > 1) {
1737 colorPairs = colorKeys.map(function (key) {
1738 return [constructColorName(colorKey, key), colors[key]];
1739 });
1740 } else {
1741 colorPairs = parseColors([colorKey, colors]);
1742 }
1743
1744 return colorPairs.reduce(function (state, _ref8) {
1745 var _ref9 = _slicedToArray(_ref8, 2),
1746 key = _ref9[0],
1747 value = _ref9[1];
1748
1749 return Object.assign({}, state, {
1750 [key]: value
1751 });
1752 }, {});
1753}
1754
1755function needsVariant(name) {
1756 return needsVariantList.includes(name);
1757}
1758var lightenToString = compose(hslToString, createLightColor);
1759function setTextColor(name) {
1760 var variant = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'dark';
1761
1762 if (variant === 'light') {
1763 return [name, tokens__default.colorInk];
1764 }
1765
1766 return [name, tokens__default.colorWhite];
1767}
1768function setTheme(color, baseName, key, variant) {
1769 var colorPairs = [];
1770
1771 switch (variant) {
1772 case 'light':
1773 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'light'));
1774 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 7, -10)]);
1775 break;
1776
1777 case 'dark':
1778 colorPairs.push(setTextColor(constructColorName(baseName, null, 'color'), 'dark'));
1779 colorPairs.push([constructColorName(baseName, key, 'lighter'), lightenToString(color, 15, 15)]);
1780 break;
1781
1782 default:
1783 }
1784
1785 return colorPairs;
1786}
1787
1788function parseColors(_ref10) {
1789 var _ref11 = _slicedToArray(_ref10, 2),
1790 baseName = _ref11[0],
1791 colors = _ref11[1];
1792
1793 var keys = Object.keys(colors);
1794 var colorPairs = [];
1795
1796 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
1797 var key = _keys[_i];
1798 colorPairs.push([constructColorName(baseName, key), colors[key]]);
1799
1800 if (needsVariant(baseName)) {
1801 var hslColor = colorToHsla(colors[key]);
1802
1803 if (typeof hslColor === 'string') {
1804 return colorPairs;
1805 }
1806
1807 var rgbColor = hslToRgb(hslColor);
1808
1809 if (isLight(rgbColor)) {
1810 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'light')));
1811 } else {
1812 colorPairs.push.apply(colorPairs, _toConsumableArray(setTheme(hslColor, baseName, key, 'dark')));
1813 }
1814 }
1815 }
1816
1817 return colorPairs;
1818}
1819
1820(function (Key) {
1821 Key[Key["Backspace"] = 8] = "Backspace";
1822 Key[Key["Tab"] = 9] = "Tab";
1823 Key[Key["Enter"] = 13] = "Enter";
1824 Key[Key["Shift"] = 16] = "Shift";
1825 Key[Key["Ctrl"] = 17] = "Ctrl";
1826 Key[Key["Alt"] = 18] = "Alt";
1827 Key[Key["Pause"] = 19] = "Pause";
1828 Key[Key["CapsLock"] = 20] = "CapsLock";
1829 Key[Key["Escape"] = 27] = "Escape";
1830 Key[Key["Space"] = 32] = "Space";
1831 Key[Key["PageUp"] = 33] = "PageUp";
1832 Key[Key["PageDown"] = 34] = "PageDown";
1833 Key[Key["End"] = 35] = "End";
1834 Key[Key["Home"] = 36] = "Home";
1835 Key[Key["LeftArrow"] = 37] = "LeftArrow";
1836 Key[Key["UpArrow"] = 38] = "UpArrow";
1837 Key[Key["RightArrow"] = 39] = "RightArrow";
1838 Key[Key["DownArrow"] = 40] = "DownArrow";
1839 Key[Key["Insert"] = 45] = "Insert";
1840 Key[Key["Delete"] = 46] = "Delete";
1841 Key[Key["Key0"] = 48] = "Key0";
1842 Key[Key["Key1"] = 49] = "Key1";
1843 Key[Key["Key2"] = 50] = "Key2";
1844 Key[Key["Key3"] = 51] = "Key3";
1845 Key[Key["Key4"] = 52] = "Key4";
1846 Key[Key["Key5"] = 53] = "Key5";
1847 Key[Key["Key6"] = 54] = "Key6";
1848 Key[Key["Key7"] = 55] = "Key7";
1849 Key[Key["Key8"] = 56] = "Key8";
1850 Key[Key["Key9"] = 57] = "Key9";
1851 Key[Key["KeyA"] = 65] = "KeyA";
1852 Key[Key["KeyB"] = 66] = "KeyB";
1853 Key[Key["KeyC"] = 67] = "KeyC";
1854 Key[Key["KeyD"] = 68] = "KeyD";
1855 Key[Key["KeyE"] = 69] = "KeyE";
1856 Key[Key["KeyF"] = 70] = "KeyF";
1857 Key[Key["KeyG"] = 71] = "KeyG";
1858 Key[Key["KeyH"] = 72] = "KeyH";
1859 Key[Key["KeyI"] = 73] = "KeyI";
1860 Key[Key["KeyJ"] = 74] = "KeyJ";
1861 Key[Key["KeyK"] = 75] = "KeyK";
1862 Key[Key["KeyL"] = 76] = "KeyL";
1863 Key[Key["KeyM"] = 77] = "KeyM";
1864 Key[Key["KeyN"] = 78] = "KeyN";
1865 Key[Key["KeyO"] = 79] = "KeyO";
1866 Key[Key["KeyP"] = 80] = "KeyP";
1867 Key[Key["KeyQ"] = 81] = "KeyQ";
1868 Key[Key["KeyR"] = 82] = "KeyR";
1869 Key[Key["KeyS"] = 83] = "KeyS";
1870 Key[Key["KeyT"] = 84] = "KeyT";
1871 Key[Key["KeyU"] = 85] = "KeyU";
1872 Key[Key["KeyV"] = 86] = "KeyV";
1873 Key[Key["KeyW"] = 87] = "KeyW";
1874 Key[Key["KeyX"] = 88] = "KeyX";
1875 Key[Key["KeyY"] = 89] = "KeyY";
1876 Key[Key["KeyZ"] = 90] = "KeyZ";
1877 Key[Key["LeftMeta"] = 91] = "LeftMeta";
1878 Key[Key["RightMeta"] = 92] = "RightMeta";
1879 Key[Key["Select"] = 93] = "Select";
1880 Key[Key["Numpad0"] = 96] = "Numpad0";
1881 Key[Key["Numpad1"] = 97] = "Numpad1";
1882 Key[Key["Numpad2"] = 98] = "Numpad2";
1883 Key[Key["Numpad3"] = 99] = "Numpad3";
1884 Key[Key["Numpad4"] = 100] = "Numpad4";
1885 Key[Key["Numpad5"] = 101] = "Numpad5";
1886 Key[Key["Numpad6"] = 102] = "Numpad6";
1887 Key[Key["Numpad7"] = 103] = "Numpad7";
1888 Key[Key["Numpad8"] = 104] = "Numpad8";
1889 Key[Key["Numpad9"] = 105] = "Numpad9";
1890 Key[Key["Multiply"] = 106] = "Multiply";
1891 Key[Key["Add"] = 107] = "Add";
1892 Key[Key["Subtract"] = 109] = "Subtract";
1893 Key[Key["Decimal"] = 110] = "Decimal";
1894 Key[Key["Divide"] = 111] = "Divide";
1895 Key[Key["F1"] = 112] = "F1";
1896 Key[Key["F2"] = 113] = "F2";
1897 Key[Key["F3"] = 114] = "F3";
1898 Key[Key["F4"] = 115] = "F4";
1899 Key[Key["F5"] = 116] = "F5";
1900 Key[Key["F6"] = 117] = "F6";
1901 Key[Key["F7"] = 118] = "F7";
1902 Key[Key["F8"] = 119] = "F8";
1903 Key[Key["F9"] = 120] = "F9";
1904 Key[Key["F10"] = 121] = "F10";
1905 Key[Key["F11"] = 122] = "F11";
1906 Key[Key["F12"] = 123] = "F12";
1907 Key[Key["NumLock"] = 144] = "NumLock";
1908 Key[Key["ScrollLock"] = 145] = "ScrollLock";
1909 Key[Key["Semicolon"] = 186] = "Semicolon";
1910 Key[Key["Equals"] = 187] = "Equals";
1911 Key[Key["Comma"] = 188] = "Comma";
1912 Key[Key["Dash"] = 189] = "Dash";
1913 Key[Key["Period"] = 190] = "Period";
1914 Key[Key["ForwardSlash"] = 191] = "ForwardSlash";
1915 Key[Key["GraveAccent"] = 192] = "GraveAccent";
1916 Key[Key["OpenBracket"] = 219] = "OpenBracket";
1917 Key[Key["BackSlash"] = 220] = "BackSlash";
1918 Key[Key["CloseBracket"] = 221] = "CloseBracket";
1919 Key[Key["SingleQuote"] = 222] = "SingleQuote";
1920})(exports.Key || (exports.Key = {}));
1921
1922(function (TypeOf) {
1923 TypeOf["Undefined"] = "undefined";
1924 TypeOf["Object"] = "object";
1925 TypeOf["Boolean"] = "boolean";
1926 TypeOf["Number"] = "number";
1927 TypeOf["String"] = "string";
1928 TypeOf["Symbol"] = "symbol";
1929 TypeOf["Function"] = "function";
1930})(exports.TypeOf || (exports.TypeOf = {}));
1931
1932function classNames() {
1933 for (var _len = arguments.length, classes = new Array(_len), _key = 0; _key < _len; _key++) {
1934 classes[_key] = arguments[_key];
1935 }
1936
1937 return classes.filter(Boolean).join(' ');
1938}
1939function variationName(name, value) {
1940 return "".concat(name).concat(value.charAt(0).toUpperCase()).concat(value.slice(1));
1941}
1942
1943var FeaturesContext = React__default.createContext(undefined);
1944
1945function useFeatures() {
1946 var features = React.useContext(FeaturesContext);
1947
1948 if (!features) {
1949 throw new Error('No Features were provided.');
1950 }
1951
1952 return features;
1953}
1954
1955var I18nContext = React__default.createContext(undefined);
1956
1957function useI18n() {
1958 var i18n = React.useContext(I18nContext);
1959
1960 if (!i18n) {
1961 throw new MissingAppProviderError('No i18n was provided.');
1962 }
1963
1964 return i18n;
1965}
1966
1967var OBJECT_NOTATION_MATCHER = /\[(.*?)\]|(\w+)/g;
1968function get(obj, keypath, defaultValue) {
1969 if (obj == null) return undefined;
1970 var keys = Array.isArray(keypath) ? keypath : getKeypath(keypath);
1971 var acc = obj; // eslint-disable-next-line @typescript-eslint/prefer-for-of
1972
1973 for (var i = 0; i < keys.length; i++) {
1974 var val = acc[keys[i]];
1975 if (val === undefined) return defaultValue;
1976 acc = val;
1977 }
1978
1979 return acc;
1980}
1981
1982function getKeypath(str) {
1983 var path = [];
1984 var result;
1985
1986 while (result = OBJECT_NOTATION_MATCHER.exec(str)) {
1987 var _result = result,
1988 _result2 = _slicedToArray(_result, 3),
1989 first = _result2[1],
1990 second = _result2[2];
1991
1992 path.push(first || second);
1993 }
1994
1995 return path;
1996}
1997
1998function merge() {
1999 var final = {};
2000
2001 for (var _len = arguments.length, objs = new Array(_len), _key = 0; _key < _len; _key++) {
2002 objs[_key] = arguments[_key];
2003 }
2004
2005 for (var _i = 0, _objs = objs; _i < _objs.length; _i++) {
2006 var obj = _objs[_i];
2007 final = mergeRecursively(final, obj);
2008 }
2009
2010 return final;
2011}
2012
2013function mergeRecursively(inputObjA, objB) {
2014 var objA = Array.isArray(inputObjA) ? _toConsumableArray(inputObjA) : Object.assign({}, inputObjA);
2015
2016 for (var key in objB) {
2017 if (!Object.prototype.hasOwnProperty.call(objB, key)) {
2018 continue;
2019 } else if (isMergeableValue(objB[key]) && isMergeableValue(objA[key])) {
2020 objA[key] = mergeRecursively(objA[key], objB[key]);
2021 } else {
2022 objA[key] = objB[key];
2023 }
2024 }
2025
2026 return objA;
2027}
2028
2029function isMergeableValue(value) {
2030 return value !== null && typeof value === 'object';
2031}
2032
2033var REPLACE_REGEX = /{([^}]*)}/g;
2034var I18n =
2035/*#__PURE__*/
2036function () {
2037 function I18n(translation) {
2038 var _this = this;
2039
2040 _classCallCheck(this, I18n);
2041
2042 this.translation = translation;
2043
2044 this.translate = function (id, replacements) {
2045 return translate(id, _this.translation, replacements);
2046 };
2047
2048 this.setTranslation(translation);
2049 }
2050
2051 _createClass(I18n, [{
2052 key: "setTranslation",
2053 value: function setTranslation(translation) {
2054 this.translation = Array.isArray(translation) ? merge.apply(void 0, _toConsumableArray(translation)) : translation;
2055 }
2056 }, {
2057 key: "translationKeyExists",
2058 value: function translationKeyExists(path) {
2059 return Boolean(get(this.translation, path));
2060 }
2061 }]);
2062
2063 return I18n;
2064}();
2065function translate(id, translations, replacements) {
2066 var text = get(translations, id);
2067
2068 if (!text) {
2069 return '';
2070 }
2071
2072 if (replacements) {
2073 return text.replace(REPLACE_REGEX, function (match) {
2074 var replacement = match.substring(1, match.length - 1);
2075
2076 if (!Object.prototype.hasOwnProperty.call(replacements, replacement)) {
2077 throw new Error("No replacement found for key '".concat(replacement, "'. The following replacements were passed: ").concat(Object.keys(replacements).map(function (key) {
2078 return "'".concat(key, "'");
2079 }).join(', ')));
2080 }
2081
2082 return replacements[replacement];
2083 });
2084 }
2085
2086 return text;
2087}
2088
2089var isServer = typeof window === 'undefined' || typeof document === 'undefined';
2090
2091function Image(_a) {
2092 var sourceSet = _a.sourceSet,
2093 source = _a.source,
2094 crossOrigin = _a.crossOrigin,
2095 rest = tslib_1.__rest(_a, ["sourceSet", "source", "crossOrigin"]);
2096
2097 var finalSourceSet = sourceSet ? sourceSet.map(function (_ref) {
2098 var subSource = _ref.source,
2099 descriptor = _ref.descriptor;
2100 return "".concat(subSource, " ").concat(descriptor);
2101 }).join(',') : null;
2102 return finalSourceSet ? // eslint-disable-next-line jsx-a11y/alt-text
2103 React__default.createElement("img", Object.assign({
2104 src: source,
2105 srcSet: finalSourceSet,
2106 crossOrigin: crossOrigin
2107 }, rest)) : // eslint-disable-next-line jsx-a11y/alt-text
2108 React__default.createElement("img", Object.assign({
2109 src: source
2110 }, rest, {
2111 crossOrigin: crossOrigin
2112 }));
2113}
2114
2115var styles = {
2116 "Avatar": "Polaris-Avatar",
2117 "hidden": "Polaris-Avatar--hidden",
2118 "sizeSmall": "Polaris-Avatar--sizeSmall",
2119 "sizeMedium": "Polaris-Avatar--sizeMedium",
2120 "sizeLarge": "Polaris-Avatar--sizeLarge",
2121 "styleOne": "Polaris-Avatar--styleOne",
2122 "styleTwo": "Polaris-Avatar--styleTwo",
2123 "styleThree": "Polaris-Avatar--styleThree",
2124 "styleFour": "Polaris-Avatar--styleFour",
2125 "styleFive": "Polaris-Avatar--styleFive",
2126 "styleSix": "Polaris-Avatar--styleSix",
2127 "hasImage": "Polaris-Avatar--hasImage",
2128 "Image": "Polaris-Avatar__Image",
2129 "Initials": "Polaris-Avatar__Initials",
2130 "Svg": "Polaris-Avatar__Svg"
2131};
2132
2133var avatar1 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjMjQ1YjQ4IiBkPSJNMCAwaDEwMHYxMDBIMHoiLz48cGF0aCBmaWxsPSIjMmRiMTY3IiBkPSJNNjkgMHY2NS42NWwtMi0uMDF2MTkuODVsMiAuMDJWMTAwSDBWMGg2OXoiLz48cGF0aCBmaWxsPSIjZmZmIiBkPSJNNjcgNjUuNjR2MTkuODVsLTI1LjU3LS4xOUMzMiA4NS4yMiAyNS42IDgxLjQ2IDI1LjY4IDcyLjA2cy4yNS02Ljc0LjI1LTYuNzR6Ii8+PHBhdGggZmlsbD0iIzhkYzk1OCIgZD0iTTg2Ljk5IDU4SDY5VjBoMTAuOTNsNy4wNiA1OHoiLz48cGF0aCBmaWxsPSIjZWJlZGYxIiBkPSJNMjQuNTMgNDAuMjlhMTIuMjMgMTIuMjMgMCAwMTI0LjQ2IDAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZmlsbD0iIzhkYzk1OCIgZD0iTTU5LjYyIDU4QTEwLjY5IDEwLjY5IDAgMDE4MSA1OHoiLz48L3N2Zz4K';
2134
2135var avatar2 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjMWUyNjVjIiBkPSJNLS4wMSAwaDEwMHYxMDBoLTEwMHoiLz48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNLS4wMSAwaDY5LjAydjEwMEgtLjAxeiIvPjxwYXRoIGZpbGw9IiNmZmYiIGQ9Ik02OC45MyA2NS44OGwtMjQuNDQtLjE5LS4wNSA2LjA5YzAgNS4yMiAzLjQ4IDkuNDcgOC42OSA5LjUybDE1LjguMTJ6Ii8+PHBhdGggZmlsbD0iI2ZmYzA0ZCIgZD0iTTY4LjkxIDExLjNsMTkuMTcgNDYuMjktMTkuMTctLjE2VjExLjN6Ii8+PHBhdGggZmlsbD0iI2ZmZiIgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIGQ9Ik0yMy4yNSAzNi40M2EzLjIyIDMuMjIgMCAxMDAgNi40NG0yMS4wMS02LjQ0YTMuMjIgMy4yMiAwIDAwMCA2LjQ0bS0xMy41NSAzLjc0YTMuMjIgMy4yMiAwIDEwMCA2LjQ0bTMuMjItMjUuNTFhMy4yMiAzLjIyIDAgMDAwIDYuNDQiLz48L3N2Zz4K';
2136
2137var avatar3 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNLS4wMiAwaDEwMHYxMDBoLTEwMHoiLz48cGF0aCBmaWxsPSIjNmRjYWNlIiBkPSJNLjM5IDBoNjkuMDJ2MTAwSC4zOXoiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik0yNC4xOCAzMS4yMXYzLjQ3QTEwLjQzIDEwLjQzIDAgMDAzNC40IDQ1LjIxYTEwLjQzIDEwLjQzIDAgMDAxMC4yMi0xMC41M3YtMy40NyIvPjxwYXRoIGZpbGw9IiNlYmVkZjEiIGQ9Ik0yMC4xMSA0OS4wN2ExNi4yMiAxNi4yMiAwIDExMCAzMi40NCIgb3BhY2l0eT0iLjIiLz48cGF0aCBkPSJNNjkuNDQgMTguODNMOTAgNzFINjkuNDRWMTguODN6IiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTU3LjU5IDcxYTYgNiAwIDAxMTIgMHoiIGZpbGw9IiNmZmYiLz48L3N2Zz4K';
2138
2139var avatar4 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjZmZlMGMzIiBkPSJNMC0uMDFoMTAwdjEwMEgweiIvPjxwYXRoIGZpbGw9IiM1ZDZjYzEiIGQ9Ik0wIDBoNjkuMDJ2MTAwSDB6Ii8+PHBhdGggZD0iTTY5LjAyIDBsMjQuMDMgNjEuNjlINjkuMDJWMHoiIGZpbGw9IiNmZjk2N2QiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik0zMC42OSAzMS45MXYtM2MwLTQuNzggMy40Ni04LjY1IDgtOC42NXM4IDMuODcgOCA4LjY1djMiLz48cGF0aCBmaWxsPSIjZWJlZGYxIiBkPSJNMTIuNzYgNTYuMDZhMTMuMzYgMTMuMzYgMCAxMTI2LjcyIDAiIG9wYWNpdHk9Ii4yIi8+PHBhdGggZD0iTTgwIDYxLjQ2bC0yOS4zNC4yM3YtNy4zM2MwLTYuMjggNC4wNy0xMS4zNiAxMC4zNC0xMS40NGwxOS0uMTR6IiBmaWxsPSIjZmY5NjdkIi8+PC9zdmc+Cg==';
2140
2141var avatar5 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjOGRjOTU4IiBkPSJNMCAwaDcwLjAydjEwMEgweiIvPjxwYXRoIGQ9Ik02OS45MiAwdjU2LjMyTDQ5IDY3bC0uMyAyNS4wN1YxMDBIMTAwVjB6IiBmaWxsPSIjMmRiMTY3Ii8+PHBhdGggZmlsbD0iIzI0NWI0OCIgZD0iTTU5LjI3IDU4LjI5YTUuMjIgNS4yMiAwIDAwLTkuNDMgNC40OCIvPjxwYXRoIGQ9Ik0yNy4xMiA5LjMzaDQ0LjUzdjIuMTlIMjcuMTJ6bS0xMi40MSA5LjQ5aDU2Ljk0djIuMTlIMTQuNzF6IiBmaWxsPSIjMmRiMTY3Ii8+PGNpcmNsZSBjeD0iMTkuNjYiIGN5PSI0NC44IiByPSIxMS4yMiIgZmlsbD0iI2ViZWRmMSIgb3BhY2l0eT0iLjIiLz48L3N2Zz4K';
2142
2143var avatar6 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNLS4wMi0uMDFoMTAwdjEwMGgtMTAweiIgZmlsbD0iI2ZmZTBjMyIvPjxwYXRoIGZpbGw9IiNmZjk2N2QiIGQ9Ik0wIDBoNjkuNDF2MTAwSDB6Ii8+PHBhdGggZD0iTTY5LjkyIDB2NDQuMzJMNTEuMzQgNTV2NDVIMTAwVjB6IiBmaWxsPSIjZmZlMGMzIi8+PHBhdGggZmlsbD0iIzMyY2FjNiIgZD0iTTM5LjMyIDc2YTExLjg1IDExLjg1IDAgMDAxMiAxMS42MlY3NiIvPjxwYXRoIGZpbGw9IiMwMDk3OTYiIGQ9Ik0zOS4zMiA3NmExMiAxMiAwIDAxMTItMTEuODJWNzYiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiIGQ9Ik00My43NCAxOS44M2ExMi44MiAxMi44MiAwIDExLTI1LjY0IDAiLz48cGF0aCBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjQiIGQ9Ik0yNy4zOSAzMS42bC0xLjU4IDUuOTZtOS4zNy01LjcybDIuNTUgNS40N200LjI2LTkuODVsMy41MyA0LjVtLTI1LjQzLTQuNWwtMy41MyA0LjUiLz48L3N2Zz4K';
2144
2145var avatar7 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNMCAwaDEwMHYxMDAuNDhIMHoiIGZpbGw9IiM4ZGM5NTgiLz48cGF0aCBmaWxsPSIjMmRiMTY3IiBkPSJNODMgNjh2MzJsLTE0LS4xNnYuMTZIMFYwaDY5djY4aDE0eiIvPjxwYXRoIGQ9Ik02OS4yOSA0MS42OUgyMC42NnMtLjA5LTMtLjE3IDcuMTUgNyAxOC41MSAxNy4zNSAxOC41OWwzMS40NS41N3oiIGZpbGw9IiM4ZGM5NTgiLz48cGF0aCBkPSJNNjguNyAxMi40bDExLjU0IDI5LjI5SDY4LjdWMTIuNHoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNNjIuMjIgNDEuNjlhMy4zNCAzLjM0IDAgMTE2LjY5IDB6IiBmaWxsPSIjZmZmIi8+PHBhdGggZmlsbD0iIzI0NWI0OCIgZD0iTTQxLjQ1IDE4LjA2YTIuNTcgMi41NyAwIDAwLTUuMTQgME0zMy4zMyAyNGEyLjU3IDIuNTcgMCAxMC01LjE0IDBtMjAuMzYgMi41OGEyLjU3IDIuNTcgMCAxMC01LjE0IDAiLz48L3N2Zz4K';
2146
2147var avatar8 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBmaWxsPSIjZmZlZGI5IiBkPSJNMCAwaDEwMHYxMDBIMHoiLz48cGF0aCBkPSJNNjQuNjMgMTcuMzNhMTcgMTcgMCAwMTUgMjkuNzIgMTYuNzUgMTYuNzUgMCAwMS01IDIuNjIiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBzdHJva2Utd2lkdGg9IjUiLz48cGF0aCBmaWxsPSIjZmZjMDRkIiBkPSJNMCAwaDY5LjAydjEwMEgweiIvPjxjaXJjbGUgY3g9IjQ1LjExIiBjeT0iMzMuNDkiIHI9IjE2Ljk4IiBmaWxsPSJub25lIiBzdHJva2U9IiNmZmYiIHN0cm9rZS1taXRlcmxpbWl0PSIxMCIgc3Ryb2tlLXdpZHRoPSI1IiB0cmFuc2Zvcm09InJvdGF0ZSgtMzcuMDIgNDUuMTI0IDMzLjQ5MykiLz48cGF0aCBmaWxsPSIjNWQ2Y2MxIiBkPSJNNjkuMDIgMzQuNDhsMTkuNDcgMzguNzQtMTkuNDcgMS41M1YzNC40OHoiLz48cGF0aCBkPSJNNjEuNiAzMy42N2ExMC4xNyAxMC4xNyAwIDAxMTUuNC4wOCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHN0cm9rZS13aWR0aD0iNSIvPjwvc3ZnPgo=';
2148
2149var avatar9 = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAxMDAgMTAwIj48cGF0aCBkPSJNMCAwaDEwMHYxMDBIMHoiIGZpbGw9IiNmZmMwNGQiLz48cGF0aCBkPSJNMCAwaDY5LjQxdjEwMEgweiIgZmlsbD0iIzVkNmNjMSIvPjxwYXRoIGQ9Ik03MC4yMSA4MC44OGgtMTUuMWMtNC44MSAwLTUuNjgtNS44NC01LjY4LTUuODRoMjAuNzgiIGZpbGw9IiNmZmMwNGQiLz48cGF0aCBkPSJNODIgNjAuNDhsLTE0IC4yNVYwaDEwLjE3QzgwLjU5IDIwLjE0IDgyIDYwLjQ4IDgyIDYwLjQ4eiIgZmlsbD0iIzVkNmNjMSIvPjxwYXRoIGZpbGw9IiM0MTIzNmUiIGQ9Ik01Ny43MSA2MC40OGE1LjQ0IDUuNDQgMCAxMTEwLjg3IDAiLz48Y2lyY2xlIGN4PSIyNC43NyIgY3k9IjQwLjE5IiByPSIxMS4yMiIgZmlsbD0iI2ViZWRmMSIgb3BhY2l0eT0iLjIiLz48L3N2Zz4K';
2150
2151
2152
2153var avatars = /*#__PURE__*/Object.freeze({
2154 avatarOne: avatar1,
2155 avatarTwo: avatar2,
2156 avatarThree: avatar3,
2157 avatarFour: avatar4,
2158 avatarFive: avatar5,
2159 avatarSix: avatar6,
2160 avatarSeven: avatar7,
2161 avatarEight: avatar8,
2162 avatarNine: avatar9
2163});
2164
2165var Status;
2166
2167(function (Status) {
2168 Status["Pending"] = "PENDING";
2169 Status["Loaded"] = "LOADED";
2170 Status["Errored"] = "ERRORED";
2171})(Status || (Status = {}));
2172
2173var STYLE_CLASSES = ['one', 'two', 'three', 'four', 'five'];
2174var AVATAR_IMAGES = Object.keys(avatars).map( // import/namespace does not allow computed values by default
2175// eslint-disable-next-line import/namespace
2176function (key) {
2177 return avatars[key];
2178});
2179function Avatar(_ref) {
2180 var name = _ref.name,
2181 source = _ref.source,
2182 initials = _ref.initials,
2183 customer = _ref.customer,
2184 _ref$size = _ref.size,
2185 size = _ref$size === void 0 ? 'medium' : _ref$size,
2186 accessibilityLabel = _ref.accessibilityLabel;
2187 var i18n = useI18n();
2188
2189 var _useFeatures = useFeatures(),
2190 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
2191 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
2192
2193 function styleClass(name) {
2194 var finalStyleClasses = unstableGlobalTheming ? STYLE_CLASSES : [].concat(STYLE_CLASSES, ['six']);
2195 return name ? finalStyleClasses[name.charCodeAt(0) % finalStyleClasses.length] : finalStyleClasses[0];
2196 }
2197
2198 var _useState = React.useState(Status.Pending),
2199 _useState2 = _slicedToArray(_useState, 2),
2200 status = _useState2[0],
2201 setStatus = _useState2[1]; // If the source changes, set the status back to pending
2202
2203
2204 React.useEffect(function () {
2205 setStatus(Status.Pending);
2206 }, [source]);
2207 var handleError = React.useCallback(function () {
2208 setStatus(Status.Errored);
2209 }, []);
2210 var handleLoad = React.useCallback(function () {
2211 setStatus(Status.Loaded);
2212 }, []);
2213 var hasImage = (source || customer) && status !== Status.Errored;
2214 var nameString = name || initials;
2215 var finalSource;
2216 var label;
2217
2218 if (accessibilityLabel) {
2219 label = accessibilityLabel;
2220 } else if (name) {
2221 label = name;
2222 } else if (initials) {
2223 var splitInitials = initials.split('').join(' ');
2224 label = i18n.translate('Polaris.Avatar.labelWithInitials', {
2225 initials: splitInitials
2226 });
2227 } else {
2228 label = i18n.translate('Polaris.Avatar.label');
2229 }
2230
2231 if (source) {
2232 finalSource = source;
2233 } else if (customer) {
2234 finalSource = customerPlaceholder(nameString);
2235 }
2236
2237 var className = classNames(styles.Avatar, styles[variationName('style', styleClass(nameString))], size && styles[variationName('size', size)], hasImage && status !== Status.Loaded && styles.hidden, hasImage && styles.hasImage);
2238 var imageMarkUp = finalSource && !isServer && status !== Status.Errored ? React__default.createElement(Image, {
2239 className: styles.Image,
2240 source: finalSource,
2241 alt: "",
2242 role: "presentation",
2243 onLoad: handleLoad,
2244 onError: handleError
2245 }) : null; // Use `dominant-baseline: central` instead of `dy` when Edge supports it.
2246
2247 var verticalOffset = '0.35em';
2248 var initialsMarkup = initials && !hasImage ? React__default.createElement("span", {
2249 className: styles.Initials
2250 }, React__default.createElement("svg", {
2251 className: styles.Svg,
2252 viewBox: "0 0 48 48"
2253 }, React__default.createElement("text", {
2254 x: "50%",
2255 y: "50%",
2256 dy: verticalOffset,
2257 fill: "currentColor",
2258 fontSize: "26",
2259 textAnchor: "middle"
2260 }, initials))) : null;
2261 return React__default.createElement("span", {
2262 "aria-label": label,
2263 role: "img",
2264 className: className
2265 }, initialsMarkup, imageMarkUp);
2266}
2267
2268function customerPlaceholder(name) {
2269 return name ? AVATAR_IMAGES[name.charCodeAt(0) % AVATAR_IMAGES.length] : AVATAR_IMAGES[0];
2270}
2271
2272function isElementInViewport(element) {
2273 var _element$getBoundingC = element.getBoundingClientRect(),
2274 top = _element$getBoundingC.top,
2275 left = _element$getBoundingC.left,
2276 bottom = _element$getBoundingC.bottom,
2277 right = _element$getBoundingC.right;
2278
2279 return top >= 0 && right <= window.innerWidth && bottom <= window.innerHeight && left >= 0;
2280}
2281
2282function handleMouseUpByBlurring(_ref) {
2283 var currentTarget = _ref.currentTarget;
2284 currentTarget.blur();
2285}
2286function nextFocusableNode(node, filter) {
2287 var allFocusableElements = _toConsumableArray(document.querySelectorAll(focus.FOCUSABLE_SELECTOR));
2288
2289 var sliceLocation = allFocusableElements.indexOf(node) + 1;
2290 var focusableElementsAfterNode = allFocusableElements.slice(sliceLocation);
2291 var _iteratorNormalCompletion = true;
2292 var _didIteratorError = false;
2293 var _iteratorError = undefined;
2294
2295 try {
2296 for (var _iterator = focusableElementsAfterNode[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
2297 var focusableElement = _step.value;
2298
2299 if (isElementInViewport(focusableElement) && (!filter || filter && filter(focusableElement))) {
2300 return focusableElement;
2301 }
2302 }
2303 } catch (err) {
2304 _didIteratorError = true;
2305 _iteratorError = err;
2306 } finally {
2307 try {
2308 if (!_iteratorNormalCompletion && _iterator.return != null) {
2309 _iterator.return();
2310 }
2311 } finally {
2312 if (_didIteratorError) {
2313 throw _iteratorError;
2314 }
2315 }
2316 }
2317
2318 return null;
2319}
2320function focusNextFocusableNode(node, filter) {
2321 var nextFocusable = nextFocusableNode(node, filter);
2322
2323 if (nextFocusable && nextFocusable instanceof HTMLElement) {
2324 nextFocusable.focus();
2325 return true;
2326 }
2327
2328 return false;
2329}
2330
2331var scrollable = {
2332 props: {
2333 'data-polaris-scrollable': true
2334 },
2335 selector: '[data-polaris-scrollable]'
2336};
2337var overlay = {
2338 props: {
2339 'data-polaris-overlay': true
2340 },
2341 selector: '[data-polaris-overlay]'
2342};
2343var layer = {
2344 props: {
2345 'data-polaris-layer': true
2346 },
2347 selector: '[data-polaris-layer]'
2348};
2349var unstyled = {
2350 props: {
2351 'data-polaris-unstyled': true
2352 },
2353 selector: '[data-polaris-unstyled]'
2354};
2355var dataPolarisTopBar = {
2356 props: {
2357 'data-polaris-top-bar': true
2358 },
2359 selector: '[data-polaris-top-bar]'
2360};
2361var headerCell = {
2362 props: {
2363 'data-polaris-header-cell': true
2364 },
2365 selector: '[data-polaris-header-cell]'
2366};
2367var portal = {
2368 props: ['data-portal-id'],
2369 selector: '[data-portal-id]'
2370};
2371var DATA_ATTRIBUTE = {
2372 overlay,
2373 layer
2374}; // these match our values in duration.scss
2375
2376var Duration;
2377
2378(function (Duration) {
2379 Duration[Duration["Instant"] = 0] = "Instant";
2380 Duration[Duration["Fast"] = 100] = "Fast";
2381 Duration[Duration["Base"] = 200] = "Base";
2382 Duration[Duration["Slow"] = 300] = "Slow";
2383 Duration[Duration["Slower"] = 400] = "Slower";
2384 Duration[Duration["Slowest"] = 500] = "Slowest";
2385})(Duration || (Duration = {}));
2386
2387var LinkContext = React__default.createContext(undefined);
2388
2389function useLink() {
2390 return React__default.useContext(LinkContext);
2391}
2392
2393// https://github.com/facebook/react/issues/16722
2394// but eslint-plugin-react doesn't know that just yet
2395// eslint-disable-next-line react/display-name
2396
2397var UnstyledLink = React__default.memo(React__default.forwardRef(function UnstyledLink(props, _ref) {
2398 var LinkComponent = useLink();
2399
2400 if (LinkComponent) {
2401 return React__default.createElement(LinkComponent, Object.assign({}, unstyled.props, props));
2402 }
2403
2404 var external = props.external,
2405 url = props.url,
2406 rest = tslib_1.__rest(props, ["external", "url"]);
2407
2408 var target = external ? '_blank' : undefined;
2409 var rel = external ? 'noopener noreferrer' : undefined;
2410 return React__default.createElement("a", Object.assign({
2411 target: target
2412 }, rest, {
2413 href: url,
2414 rel: rel
2415 }, unstyled.props));
2416}));
2417
2418var TelemetryContext = React__default.createContext(undefined);
2419
2420function noop() {}
2421
2422var defaultTelemetry = {
2423 produce: noop
2424};
2425function useTelemetry() {
2426 return React__default.useContext(TelemetryContext) || defaultTelemetry;
2427}
2428
2429var styles$1 = {
2430 "Icon": "Polaris-Icon",
2431 "hasBackdrop": "Polaris-Icon--hasBackdrop",
2432 "isColored": "Polaris-Icon--isColored",
2433 "colorWhite": "Polaris-Icon--colorWhite",
2434 "colorBlack": "Polaris-Icon--colorBlack",
2435 "colorSkyLighter": "Polaris-Icon--colorSkyLighter",
2436 "colorSkyLight": "Polaris-Icon--colorSkyLight",
2437 "colorSky": "Polaris-Icon--colorSky",
2438 "colorSkyDark": "Polaris-Icon--colorSkyDark",
2439 "colorInkLightest": "Polaris-Icon--colorInkLightest",
2440 "colorInkLighter": "Polaris-Icon--colorInkLighter",
2441 "colorInkLight": "Polaris-Icon--colorInkLight",
2442 "colorInk": "Polaris-Icon--colorInk",
2443 "colorBlueLighter": "Polaris-Icon--colorBlueLighter",
2444 "colorBlueLight": "Polaris-Icon--colorBlueLight",
2445 "colorBlue": "Polaris-Icon--colorBlue",
2446 "colorBlueDark": "Polaris-Icon--colorBlueDark",
2447 "colorBlueDarker": "Polaris-Icon--colorBlueDarker",
2448 "colorIndigoLighter": "Polaris-Icon--colorIndigoLighter",
2449 "colorIndigoLight": "Polaris-Icon--colorIndigoLight",
2450 "colorIndigo": "Polaris-Icon--colorIndigo",
2451 "colorIndigoDark": "Polaris-Icon--colorIndigoDark",
2452 "colorIndigoDarker": "Polaris-Icon--colorIndigoDarker",
2453 "colorTealLighter": "Polaris-Icon--colorTealLighter",
2454 "colorTealLight": "Polaris-Icon--colorTealLight",
2455 "colorTeal": "Polaris-Icon--colorTeal",
2456 "colorTealDark": "Polaris-Icon--colorTealDark",
2457 "colorTealDarker": "Polaris-Icon--colorTealDarker",
2458 "colorGreenLighter": "Polaris-Icon--colorGreenLighter",
2459 "colorGreen": "Polaris-Icon--colorGreen",
2460 "colorGreenDark": "Polaris-Icon--colorGreenDark",
2461 "colorYellowLighter": "Polaris-Icon--colorYellowLighter",
2462 "colorYellow": "Polaris-Icon--colorYellow",
2463 "colorYellowDark": "Polaris-Icon--colorYellowDark",
2464 "colorOrange": "Polaris-Icon--colorOrange",
2465 "colorOrangeDark": "Polaris-Icon--colorOrangeDark",
2466 "colorRedLighter": "Polaris-Icon--colorRedLighter",
2467 "colorRed": "Polaris-Icon--colorRed",
2468 "colorRedDark": "Polaris-Icon--colorRedDark",
2469 "colorPurple": "Polaris-Icon--colorPurple",
2470 "Svg": "Polaris-Icon__Svg",
2471 "Img": "Polaris-Icon__Img",
2472 "Placeholder": "Polaris-Icon__Placeholder"
2473};
2474
2475var COLORS_WITH_BACKDROPS = ['teal', 'tealDark', 'greenDark', 'redDark', 'yellowDark', 'ink', 'inkLighter'];
2476function Icon(_ref) {
2477 var source = _ref.source,
2478 color = _ref.color,
2479 backdrop = _ref.backdrop,
2480 accessibilityLabel = _ref.accessibilityLabel;
2481 var i18n = useI18n();
2482 var telemetry = useTelemetry();
2483 React.useEffect(function () {
2484 telemetry.produce('polaris_icons_usage/1.0', {
2485 // eslint-disable-next-line @typescript-eslint/camelcase
2486 icon_source: parseSource(source)
2487 });
2488 }, [source, telemetry]);
2489
2490 if (color && backdrop && !COLORS_WITH_BACKDROPS.includes(color)) {
2491 // eslint-disable-next-line no-console
2492 console.warn(i18n.translate('Polaris.Icon.backdropWarning', {
2493 color,
2494 colorsWithBackDrops: COLORS_WITH_BACKDROPS.join(', ')
2495 }));
2496 }
2497
2498 var className = classNames(styles$1.Icon, color && styles$1[variationName('color', color)], color && color !== 'white' && styles$1.isColored, backdrop && styles$1.hasBackdrop);
2499 var contentMarkup;
2500
2501 if (typeof source === 'function') {
2502 var SourceComponent = source;
2503 contentMarkup = React__default.createElement(SourceComponent, {
2504 className: styles$1.Svg,
2505 focusable: "false",
2506 "aria-hidden": "true"
2507 });
2508 } else if (source === 'placeholder') {
2509 contentMarkup = React__default.createElement("div", {
2510 className: styles$1.Placeholder
2511 });
2512 } else {
2513 contentMarkup = React__default.createElement("img", {
2514 className: styles$1.Img,
2515 src: "data:image/svg+xml;utf8,".concat(source),
2516 alt: "",
2517 "aria-hidden": "true"
2518 });
2519 }
2520
2521 return React__default.createElement("span", {
2522 className: className,
2523 "aria-label": accessibilityLabel
2524 }, contentMarkup);
2525}
2526
2527function parseSource(source) {
2528 if (typeof source === 'function') {
2529 return source.name;
2530 } else if (source === 'placeholder') {
2531 return source;
2532 }
2533
2534 return 'custom icon string';
2535}
2536
2537var styles$2 = {
2538 "VisuallyHidden": "Polaris-VisuallyHidden"
2539};
2540
2541function VisuallyHidden(_ref) {
2542 var children = _ref.children;
2543 return React__default.createElement("span", {
2544 className: styles$2.VisuallyHidden
2545 }, children);
2546}
2547
2548/**
2549 * useIsAfterInitialMount will trigger a re-render to provide
2550 * you with an updated value. Using this you enhance server-side
2551 * code that can only run on the client.
2552 * @returns MutableRefObject<T> - Returns a ref object with the
2553 * results from invoking initial value
2554 * @example
2555 * function ComponentExample({children}) {
2556 * const isMounted = useIsAfterInitialMount();
2557 * const content = isMounted ? children : null;
2558 *
2559 * return <React.Fragment>{content}</React.Fragment>;
2560 * }
2561 */
2562
2563function useIsAfterInitialMount() {
2564 var _useState = React.useState(false),
2565 _useState2 = _slicedToArray(_useState, 2),
2566 isAfterInitialMount = _useState2[0],
2567 setIsAfterInitialMount = _useState2[1];
2568
2569 React.useEffect(function () {
2570 setIsAfterInitialMount(true);
2571 }, []);
2572 return isAfterInitialMount;
2573}
2574
2575var styles$3 = {
2576 "Spinner": "Polaris-Spinner",
2577 "loading": "Polaris-Spinner--loading",
2578 "sizeSmall": "Polaris-Spinner--sizeSmall",
2579 "sizeLarge": "Polaris-Spinner--sizeLarge",
2580 "colorWhite": "Polaris-Spinner--colorWhite",
2581 "colorTeal": "Polaris-Spinner--colorTeal",
2582 "colorInkLightest": "Polaris-Spinner--colorInkLightest"
2583};
2584
2585var spinnerLarge = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgNDQgNDQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTE1LjU0MiAxLjQ4N0EyMS41MDcgMjEuNTA3IDAgMDAuNSAyMmMwIDExLjg3NCA5LjYyNiAyMS41IDIxLjUgMjEuNSA5Ljg0NyAwIDE4LjM2NC02LjY3NSAyMC44MDktMTYuMDcyYTEuNSAxLjUgMCAwMC0yLjkwNC0uNzU2QzM3LjgwMyAzNC43NTUgMzAuNDczIDQwLjUgMjIgNDAuNSAxMS43ODMgNDAuNSAzLjUgMzIuMjE3IDMuNSAyMmMwLTguMTM3IDUuMy0xNS4yNDcgMTIuOTQyLTE3LjY1YTEuNSAxLjUgMCAxMC0uOS0yLjg2M3oiIGZpbGw9IiM5MTlFQUIiLz48L3N2Zz4K';
2586
2587var spinnerSmall = 'data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjAgMjAiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PHBhdGggZD0iTTcuMjI5IDEuMTczYTkuMjUgOS4yNSAwIDEwMTEuNjU1IDExLjQxMiAxLjI1IDEuMjUgMCAxMC0yLjQtLjY5OCA2Ljc1IDYuNzUgMCAxMS04LjUwNi04LjMyOSAxLjI1IDEuMjUgMCAxMC0uNzUtMi4zODV6IiBmaWxsPSIjOTE5RUFCIi8+PC9zdmc+Cg==';
2588
2589var COLORS_FOR_LARGE_SPINNER = ['teal', 'inkLightest'];
2590function Spinner(_ref) {
2591 var _ref$size = _ref.size,
2592 size = _ref$size === void 0 ? 'large' : _ref$size,
2593 _ref$color = _ref.color,
2594 color = _ref$color === void 0 ? 'teal' : _ref$color,
2595 accessibilityLabel = _ref.accessibilityLabel,
2596 hasFocusableParent = _ref.hasFocusableParent;
2597 var i18n = useI18n();
2598 var isAfterInitialMount = useIsAfterInitialMount();
2599
2600 if (size === 'large' && !COLORS_FOR_LARGE_SPINNER.includes(color)) {
2601 if (process.env.NODE_ENV === 'development') {
2602 // eslint-disable-next-line no-console
2603 console.warn(i18n.translate('Polaris.Spinner.warningMessage', {
2604 color,
2605 size,
2606 colors: COLORS_FOR_LARGE_SPINNER.join(', ')
2607 }));
2608 } // eslint-disable-next-line no-param-reassign
2609
2610
2611 size = 'small';
2612 }
2613
2614 var className = classNames(styles$3.Spinner, color && styles$3[variationName('color', color)], size && styles$3[variationName('size', size)]);
2615 var spinnerSVG = size === 'large' ? spinnerLarge : spinnerSmall;
2616 var spanAttributes = Object.assign({}, !hasFocusableParent && {
2617 role: 'status'
2618 });
2619 var accessibilityLabelMarkup = (isAfterInitialMount || !hasFocusableParent) && React__default.createElement(VisuallyHidden, null, accessibilityLabel);
2620 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Image, {
2621 alt: "",
2622 source: spinnerSVG,
2623 className: className,
2624 draggable: false
2625 }), React__default.createElement("span", spanAttributes, accessibilityLabelMarkup));
2626}
2627
2628var styles$4 = {
2629 "Button": "Polaris-Button",
2630 "globalTheming": "Polaris-Button--globalTheming",
2631 "disabled": "Polaris-Button--disabled",
2632 "Content": "Polaris-Button__Content",
2633 "textAlignLeft": "Polaris-Button--textAlignLeft",
2634 "textAlignCenter": "Polaris-Button--textAlignCenter",
2635 "textAlignRight": "Polaris-Button--textAlignRight",
2636 "Icon": "Polaris-Button__Icon",
2637 "Spinner": "Polaris-Button__Spinner",
2638 "primary": "Polaris-Button--primary",
2639 "pressed": "Polaris-Button--pressed",
2640 "destructive": "Polaris-Button--destructive",
2641 "outline": "Polaris-Button--outline",
2642 "loading": "Polaris-Button--loading",
2643 "plain": "Polaris-Button--plain",
2644 "iconOnly": "Polaris-Button--iconOnly",
2645 "fullWidth": "Polaris-Button--fullWidth",
2646 "sizeSlim": "Polaris-Button--sizeSlim",
2647 "sizeLarge": "Polaris-Button--sizeLarge",
2648 "monochrome": "Polaris-Button--monochrome",
2649 "Text": "Polaris-Button__Text",
2650 "DisclosureIcon": "Polaris-Button__DisclosureIcon",
2651 "DisclosureIconFacingUp": "Polaris-Button__DisclosureIconFacingUp"
2652};
2653
2654var DEFAULT_SIZE = 'medium';
2655function Button(_ref) {
2656 var id = _ref.id,
2657 url = _ref.url,
2658 disabled = _ref.disabled,
2659 loading = _ref.loading,
2660 children = _ref.children,
2661 accessibilityLabel = _ref.accessibilityLabel,
2662 ariaControls = _ref.ariaControls,
2663 ariaExpanded = _ref.ariaExpanded,
2664 ariaPressed = _ref.ariaPressed,
2665 onClick = _ref.onClick,
2666 onFocus = _ref.onFocus,
2667 onBlur = _ref.onBlur,
2668 onKeyDown = _ref.onKeyDown,
2669 onKeyPress = _ref.onKeyPress,
2670 onKeyUp = _ref.onKeyUp,
2671 onMouseEnter = _ref.onMouseEnter,
2672 onTouchStart = _ref.onTouchStart,
2673 external = _ref.external,
2674 download = _ref.download,
2675 icon = _ref.icon,
2676 primary = _ref.primary,
2677 outline = _ref.outline,
2678 destructive = _ref.destructive,
2679 disclosure = _ref.disclosure,
2680 plain = _ref.plain,
2681 monochrome = _ref.monochrome,
2682 submit = _ref.submit,
2683 _ref$size = _ref.size,
2684 size = _ref$size === void 0 ? DEFAULT_SIZE : _ref$size,
2685 textAlign = _ref.textAlign,
2686 fullWidth = _ref.fullWidth,
2687 pressed = _ref.pressed;
2688
2689 var _useFeatures = useFeatures(),
2690 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
2691 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
2692
2693 var hasGivenDeprecationWarning = React.useRef(false);
2694
2695 if (ariaPressed && !hasGivenDeprecationWarning.current) {
2696 // eslint-disable-next-line no-console
2697 console.warn('Deprecation: The ariaPressed prop has been replaced with pressed');
2698 hasGivenDeprecationWarning.current = true;
2699 }
2700
2701 var i18n = useI18n();
2702 var isDisabled = disabled || loading;
2703 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);
2704 var disclosureIcon = React__default.createElement(Icon, {
2705 source: loading ? 'placeholder' : polarisIcons.CaretDownMinor
2706 });
2707 var disclosureIconMarkup = disclosure ? React__default.createElement(IconWrapper, null, React__default.createElement("div", {
2708 className: classNames(styles$4.DisclosureIcon, disclosure === 'up' && styles$4.DisclosureIconFacingUp)
2709 }, disclosureIcon)) : null;
2710 var iconMarkup;
2711
2712 if (icon) {
2713 var iconInner = isIconSource(icon) ? React__default.createElement(Icon, {
2714 source: loading ? 'placeholder' : icon
2715 }) : icon;
2716 iconMarkup = React__default.createElement(IconWrapper, null, iconInner);
2717 }
2718
2719 var childMarkup = children ? React__default.createElement("span", {
2720 className: styles$4.Text
2721 }, children) : null;
2722 var spinnerColor = primary || destructive ? 'white' : 'inkLightest';
2723 var spinnerSVGMarkup = loading ? React__default.createElement("span", {
2724 className: styles$4.Spinner
2725 }, React__default.createElement(Spinner, {
2726 size: "small",
2727 color: spinnerColor,
2728 accessibilityLabel: i18n.translate('Polaris.Button.spinnerAccessibilityLabel')
2729 })) : null;
2730 var content = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
2731 className: styles$4.Content
2732 }, spinnerSVGMarkup, iconMarkup, childMarkup, disclosureIconMarkup) : React__default.createElement("span", {
2733 className: styles$4.Content
2734 }, spinnerSVGMarkup, childMarkup);
2735 var type = submit ? 'submit' : 'button';
2736
2737 if (url) {
2738 return isDisabled ? // Render an `<a>` so toggling disabled/enabled state changes only the
2739 // `href` attribute instead of replacing the whole element.
2740 // eslint-disable-next-line jsx-a11y/anchor-is-valid
2741 React__default.createElement("a", {
2742 id: id,
2743 className: className,
2744 "aria-label": accessibilityLabel
2745 }, content) : React__default.createElement(UnstyledLink, {
2746 id: id,
2747 url: url,
2748 external: external,
2749 download: download,
2750 onClick: onClick,
2751 onFocus: onFocus,
2752 onBlur: onBlur,
2753 onMouseUp: handleMouseUpByBlurring,
2754 onMouseEnter: onMouseEnter,
2755 onTouchStart: onTouchStart,
2756 className: className,
2757 "aria-label": accessibilityLabel
2758 }, content);
2759 }
2760
2761 var ariaPressedStatus = pressed !== undefined ? pressed : ariaPressed;
2762 return React__default.createElement("button", {
2763 id: id,
2764 type: type,
2765 onClick: onClick,
2766 onFocus: onFocus,
2767 onBlur: onBlur,
2768 onKeyDown: onKeyDown,
2769 onKeyUp: onKeyUp,
2770 onKeyPress: onKeyPress,
2771 onMouseUp: handleMouseUpByBlurring,
2772 onMouseEnter: onMouseEnter,
2773 onTouchStart: onTouchStart,
2774 className: className,
2775 disabled: isDisabled,
2776 "aria-label": accessibilityLabel,
2777 "aria-controls": ariaControls,
2778 "aria-expanded": ariaExpanded,
2779 "aria-pressed": ariaPressedStatus,
2780 role: loading ? 'alert' : undefined,
2781 "aria-busy": loading ? true : undefined
2782 }, content);
2783}
2784function IconWrapper(_ref2) {
2785 var children = _ref2.children;
2786 return React__default.createElement("span", {
2787 className: styles$4.Icon
2788 }, children);
2789}
2790
2791function isIconSource(x) {
2792 return typeof x === 'string' || typeof x === 'object' && x.body || typeof x === 'function';
2793}
2794
2795function buttonsFrom(actions) {
2796 var overrides = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2797
2798 if (Array.isArray(actions)) {
2799 return actions.map(function (action, index) {
2800 return buttonFrom(action, overrides, index);
2801 });
2802 } else {
2803 var action = actions;
2804 return buttonFrom(action, overrides);
2805 }
2806}
2807function buttonFrom(_a, overrides, key) {
2808 var content = _a.content,
2809 onAction = _a.onAction,
2810 action = tslib_1.__rest(_a, ["content", "onAction"]);
2811
2812 return React__default.createElement(Button, Object.assign({
2813 key: key,
2814 onClick: onAction
2815 }, action, overrides), content);
2816}
2817
2818function useToggle(initialState) {
2819 var _useState = React.useState(initialState),
2820 _useState2 = _slicedToArray(_useState, 2),
2821 state = _useState2[0],
2822 setState = _useState2[1];
2823
2824 var toggle = React.useCallback(function () {
2825 return setState(function (state) {
2826 return !state;
2827 });
2828 }, []); // cast needed to say this returns a two item array with the items in
2829 // their specific positions instead of `(typeof state | typeof toggle)[]`
2830
2831 return [state, toggle];
2832}
2833function useForcibleToggle(initialState) {
2834 var _useState3 = React.useState(initialState),
2835 _useState4 = _slicedToArray(_useState3, 2),
2836 state = _useState4[0],
2837 setState = _useState4[1];
2838
2839 var toggles = {
2840 toggle: React.useCallback(function () {
2841 return setState(function (state) {
2842 return !state;
2843 });
2844 }, []),
2845 forceTrue: React.useCallback(function () {
2846 return setState(true);
2847 }, []),
2848 forceFalse: React.useCallback(function () {
2849 return setState(false);
2850 }, [])
2851 }; // cast needed to say this returns a two item array with the items in
2852 // their specific positions instead of `(typeof state | typeof toggles)[]`
2853
2854 return [state, toggles];
2855}
2856
2857var WithinContentContext = React__default.createContext(false);
2858
2859// `Component`. If `props` is passed, those will be added as props on the
2860// wrapped component. If `element` is null, the component is not wrapped.
2861
2862function wrapWithComponent(element, Component, props) {
2863 if (element == null) {
2864 return null;
2865 }
2866
2867 return isElementOfType(element, Component) ? element : React__default.createElement(Component, props, element);
2868} // In development, we compare based on the name of the function because
2869// React Hot Loader proxies React components in order to make updates. In
2870// production we can simply compare the components for equality.
2871
2872var isComponent = process.env.NODE_ENV === 'development' ? hotReloadComponentCheck : function (AComponent, AnotherComponent) {
2873 return AComponent === AnotherComponent;
2874}; // Checks whether `element` is a React element of type `Component` (or one of
2875// the passed components, if `Component` is an array of React components).
2876
2877function isElementOfType(element, Component) {
2878 if (element == null || !React__default.isValidElement(element) || typeof element.type === 'string') {
2879 return false;
2880 }
2881
2882 var type = element.type;
2883 var Components = Array.isArray(Component) ? Component : [Component];
2884 return Components.some(function (AComponent) {
2885 return typeof type !== 'string' && isComponent(AComponent, type);
2886 });
2887} // Returns all children that are valid elements as an array. Can optionally be
2888// filtered by passing `predicate`.
2889
2890function elementChildren(children) {
2891 var predicate = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : function () {
2892 return true;
2893 };
2894 return React__default.Children.toArray(children).filter(function (child) {
2895 return React__default.isValidElement(child) && predicate(child);
2896 });
2897}
2898
2899function hotReloadComponentCheck(AComponent, AnotherComponent) {
2900 var componentName = AComponent.name;
2901 var anotherComponentName = AnotherComponent.displayName;
2902 return AComponent === AnotherComponent || Boolean(componentName) && componentName === anotherComponentName;
2903}
2904
2905var styles$5 = {
2906 "ButtonGroup": "Polaris-ButtonGroup",
2907 "Item": "Polaris-ButtonGroup__Item",
2908 "Item-plain": "Polaris-ButtonGroup__Item--plain",
2909 "segmented": "Polaris-ButtonGroup--segmented",
2910 "Item-focused": "Polaris-ButtonGroup__Item--focused",
2911 "fullWidth": "Polaris-ButtonGroup--fullWidth"
2912};
2913
2914function Item(_ref) {
2915 var button = _ref.button;
2916
2917 var _useForcibleToggle = useForcibleToggle(false),
2918 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
2919 focused = _useForcibleToggle2[0],
2920 _useForcibleToggle2$ = _useForcibleToggle2[1],
2921 forceTrueFocused = _useForcibleToggle2$.forceTrue,
2922 forceFalseFocused = _useForcibleToggle2$.forceFalse;
2923
2924 var className = classNames(styles$5.Item, focused && styles$5['Item-focused'], button.props.plain && styles$5['Item-plain']);
2925 return React__default.createElement("div", {
2926 className: className,
2927 onFocus: forceTrueFocused,
2928 onBlur: forceFalseFocused
2929 }, button);
2930}
2931
2932function ButtonGroup(_ref) {
2933 var children = _ref.children,
2934 segmented = _ref.segmented,
2935 fullWidth = _ref.fullWidth,
2936 connectedTop = _ref.connectedTop;
2937 var className = classNames(styles$5.ButtonGroup, segmented && styles$5.segmented, fullWidth && styles$5.fullWidth);
2938 var contents = elementChildren(children).map(function (child, index) {
2939 return React__default.createElement(Item, {
2940 button: child,
2941 key: index
2942 });
2943 });
2944 return React__default.createElement("div", {
2945 className: className,
2946 "data-buttongroup-segmented": segmented,
2947 "data-buttongroup-connected-top": connectedTop,
2948 "data-buttongroup-full-width": fullWidth
2949 }, contents);
2950}
2951
2952var StickyManagerContext = React__default.createContext(undefined);
2953
2954function useStickyManager() {
2955 var stickyManager = React.useContext(StickyManagerContext);
2956
2957 if (!stickyManager) {
2958 throw new MissingAppProviderError('No StickyManager was provided.');
2959 }
2960
2961 return stickyManager;
2962}
2963
2964var Breakpoints = {
2965 navigationBarCollapsed: '768px',
2966 stackedContent: '1043px'
2967};
2968var noWindowMatches = {
2969 media: '',
2970 addListener: noop$1,
2971 removeListener: noop$1,
2972 matches: false,
2973 onchange: noop$1,
2974 addEventListener: noop$1,
2975 removeEventListener: noop$1,
2976 dispatchEvent: function dispatchEvent(_) {
2977 return true;
2978 }
2979};
2980
2981function noop$1() {}
2982
2983function navigationBarCollapsed() {
2984 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.navigationBarCollapsed, ")"));
2985}
2986function stackedContent() {
2987 return typeof window === 'undefined' ? noWindowMatches : window.matchMedia("(max-width: ".concat(Breakpoints.stackedContent, ")"));
2988}
2989
2990var StickyManager =
2991/*#__PURE__*/
2992function () {
2993 function StickyManager(container) {
2994 var _this = this;
2995
2996 _classCallCheck(this, StickyManager);
2997
2998 this.stickyItems = [];
2999 this.stuckItems = [];
3000 this.topBarOffset = 0;
3001 this.handleResize = debounce(function () {
3002 _this.manageStickyItems();
3003 }, 40, {
3004 leading: true,
3005 trailing: true,
3006 maxWait: 40
3007 });
3008 this.handleScroll = debounce(function () {
3009 _this.manageStickyItems();
3010 }, 40, {
3011 leading: true,
3012 trailing: true,
3013 maxWait: 40
3014 });
3015
3016 if (container) {
3017 this.setContainer(container);
3018 }
3019 }
3020
3021 _createClass(StickyManager, [{
3022 key: "registerStickyItem",
3023 value: function registerStickyItem(stickyItem) {
3024 this.stickyItems.push(stickyItem);
3025 }
3026 }, {
3027 key: "unregisterStickyItem",
3028 value: function unregisterStickyItem(nodeToRemove) {
3029 var nodeIndex = this.stickyItems.findIndex(function (_ref) {
3030 var stickyNode = _ref.stickyNode;
3031 return nodeToRemove === stickyNode;
3032 });
3033 this.stickyItems.splice(nodeIndex, 1);
3034 }
3035 }, {
3036 key: "setContainer",
3037 value: function setContainer(el) {
3038 this.container = el;
3039
3040 if (isDocument(el)) {
3041 this.setTopBarOffset();
3042 }
3043
3044 events.addEventListener(this.container, 'scroll', this.handleScroll);
3045 events.addEventListener(window, 'resize', this.handleResize);
3046 this.manageStickyItems();
3047 }
3048 }, {
3049 key: "removeScrollListener",
3050 value: function removeScrollListener() {
3051 if (this.container) {
3052 events.removeEventListener(this.container, 'scroll', this.handleScroll);
3053 events.removeEventListener(window, 'resize', this.handleResize);
3054 }
3055 }
3056 }, {
3057 key: "manageStickyItems",
3058 value: function manageStickyItems() {
3059 var _this2 = this;
3060
3061 if (this.stickyItems.length <= 0) {
3062 return;
3063 }
3064
3065 var scrollTop = scrollTopFor(this.container);
3066 var containerTop = geometry.getRectForNode(this.container).top + this.topBarOffset;
3067 this.stickyItems.forEach(function (stickyItem) {
3068 var handlePositioning = stickyItem.handlePositioning;
3069
3070 var _this2$evaluateSticky = _this2.evaluateStickyItem(stickyItem, scrollTop, containerTop),
3071 sticky = _this2$evaluateSticky.sticky,
3072 top = _this2$evaluateSticky.top,
3073 left = _this2$evaluateSticky.left,
3074 width = _this2$evaluateSticky.width;
3075
3076 _this2.updateStuckItems(stickyItem, sticky);
3077
3078 handlePositioning(sticky, top, left, width);
3079 });
3080 }
3081 }, {
3082 key: "evaluateStickyItem",
3083 value: function evaluateStickyItem(stickyItem, scrollTop, containerTop) {
3084 var stickyNode = stickyItem.stickyNode,
3085 placeHolderNode = stickyItem.placeHolderNode,
3086 boundingElement = stickyItem.boundingElement,
3087 offset = stickyItem.offset,
3088 disableWhenStacked = stickyItem.disableWhenStacked;
3089
3090 if (disableWhenStacked && stackedContent().matches) {
3091 return {
3092 sticky: false,
3093 top: 0,
3094 left: 0,
3095 width: 'auto'
3096 };
3097 }
3098
3099 var stickyOffset = offset ? this.getOffset(stickyNode) + parseInt(tokens__default.spacingLoose, 10) : this.getOffset(stickyNode);
3100 var scrollPosition = scrollTop + stickyOffset;
3101 var placeHolderNodeCurrentTop = placeHolderNode.getBoundingClientRect().top - containerTop + scrollTop;
3102 var top = containerTop + stickyOffset;
3103 var width = placeHolderNode.getBoundingClientRect().width;
3104 var left = placeHolderNode.getBoundingClientRect().left;
3105 var sticky;
3106
3107 if (boundingElement == null) {
3108 sticky = scrollPosition >= placeHolderNodeCurrentTop;
3109 } else {
3110 var stickyItemHeight = stickyNode.getBoundingClientRect().height;
3111 var stickyItemBottomPosition = boundingElement.getBoundingClientRect().bottom - stickyItemHeight + scrollTop - containerTop;
3112 sticky = scrollPosition >= placeHolderNodeCurrentTop && scrollPosition < stickyItemBottomPosition;
3113 }
3114
3115 return {
3116 sticky,
3117 top,
3118 left,
3119 width
3120 };
3121 }
3122 }, {
3123 key: "updateStuckItems",
3124 value: function updateStuckItems(item, sticky) {
3125 var stickyNode = item.stickyNode;
3126
3127 if (sticky && !this.isNodeStuck(stickyNode)) {
3128 this.addStuckItem(item);
3129 } else if (!sticky && this.isNodeStuck(stickyNode)) {
3130 this.removeStuckItem(item);
3131 }
3132 }
3133 }, {
3134 key: "addStuckItem",
3135 value: function addStuckItem(stickyItem) {
3136 this.stuckItems.push(stickyItem);
3137 }
3138 }, {
3139 key: "removeStuckItem",
3140 value: function removeStuckItem(stickyItem) {
3141 var nodeToRemove = stickyItem.stickyNode;
3142 var nodeIndex = this.stuckItems.findIndex(function (_ref2) {
3143 var stickyNode = _ref2.stickyNode;
3144 return nodeToRemove === stickyNode;
3145 });
3146 this.stuckItems.splice(nodeIndex, 1);
3147 }
3148 }, {
3149 key: "getOffset",
3150 value: function getOffset(node) {
3151 if (this.stuckItems.length === 0) {
3152 return 0;
3153 }
3154
3155 var offset = 0;
3156 var count = 0;
3157 var stuckNodesLength = this.stuckItems.length;
3158 var nodeRect = geometry.getRectForNode(node);
3159
3160 while (count < stuckNodesLength) {
3161 var stuckNode = this.stuckItems[count].stickyNode;
3162
3163 if (stuckNode !== node) {
3164 var stuckNodeRect = geometry.getRectForNode(stuckNode);
3165
3166 if (!horizontallyOverlaps(nodeRect, stuckNodeRect)) {
3167 offset += geometry.getRectForNode(stuckNode).height;
3168 }
3169 } else {
3170 break;
3171 }
3172
3173 count++;
3174 }
3175
3176 return offset;
3177 }
3178 }, {
3179 key: "isNodeStuck",
3180 value: function isNodeStuck(node) {
3181 var nodeFound = this.stuckItems.findIndex(function (_ref3) {
3182 var stickyNode = _ref3.stickyNode;
3183 return node === stickyNode;
3184 });
3185 return nodeFound >= 0;
3186 }
3187 }, {
3188 key: "setTopBarOffset",
3189 value: function setTopBarOffset() {
3190 var topbarElement = this.container.querySelector(":not(".concat(scrollable.selector, ") ").concat(dataPolarisTopBar.selector));
3191 this.topBarOffset = topbarElement ? topbarElement.clientHeight : 0;
3192 }
3193 }]);
3194
3195 return StickyManager;
3196}();
3197
3198function isDocument(node) {
3199 return node === document;
3200}
3201
3202function scrollTopFor(container) {
3203 return isDocument(container) ? document.body.scrollTop || document.documentElement.scrollTop : container.scrollTop;
3204}
3205
3206function horizontallyOverlaps(rect1, rect2) {
3207 var rect1Left = rect1.left;
3208 var rect1Right = rect1.left + rect1.width;
3209 var rect2Left = rect2.left;
3210 var rect2Right = rect2.left + rect2.width;
3211 return rect2Right < rect1Left || rect1Right < rect2Left;
3212}
3213
3214var UniqueIdFactoryContext = React__default.createContext(undefined);
3215
3216/**
3217 * Returns a unique id that remains consistent across multiple re-renders of the
3218 * same hook
3219 * @param prefix Defines a prefix for the ID. You probably want to set this to
3220 * the name of the component you're calling `useUniqueId` in.
3221 * @param overrideId Defines a fixed value to use instead of generating a unique
3222 * ID. Useful for components that allow consumers to specify their own ID.
3223 */
3224
3225function useUniqueId() {
3226 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
3227 var overrideId = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
3228 var idFactory = React.useContext(UniqueIdFactoryContext); // By using a ref to store the uniqueId for each invocation of the hook and
3229 // checking that it is not already populated we ensure that we don’t generate
3230 // a new ID on every re-render of a component.
3231
3232 var uniqueIdRef = React.useRef(null);
3233
3234 if (!idFactory) {
3235 throw new MissingAppProviderError('No UniqueIdFactory was provided.');
3236 } // If an override was specified, then use that instead of using a unique ID
3237 // Hooks can’t be called conditionally so this has to go after all use* calls
3238
3239
3240 if (overrideId) {
3241 return overrideId;
3242 } // If a unique id has not yet been generated, then get a new one
3243
3244
3245 if (!uniqueIdRef.current) {
3246 uniqueIdRef.current = idFactory.nextId(prefix);
3247 }
3248
3249 return uniqueIdRef.current;
3250}
3251
3252var UniqueIdFactory =
3253/*#__PURE__*/
3254function () {
3255 function UniqueIdFactory(idGeneratorFactory) {
3256 _classCallCheck(this, UniqueIdFactory);
3257
3258 this.idGenerators = {};
3259 this.idGeneratorFactory = idGeneratorFactory;
3260 }
3261
3262 _createClass(UniqueIdFactory, [{
3263 key: "nextId",
3264 value: function nextId(prefix) {
3265 if (!this.idGenerators[prefix]) {
3266 this.idGenerators[prefix] = this.idGeneratorFactory(prefix);
3267 }
3268
3269 return this.idGenerators[prefix]();
3270 }
3271 }]);
3272
3273 return UniqueIdFactory;
3274}();
3275function globalIdGeneratorFactory() {
3276 var prefix = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
3277 var index = 1;
3278 return function () {
3279 return "Polaris".concat(prefix).concat(index++);
3280 };
3281}
3282
3283var ScrollableContext = React__default.createContext(undefined);
3284
3285function ScrollTo() {
3286 var anchorNode = React.useRef(null);
3287 var scrollToPosition = React.useContext(ScrollableContext);
3288 React.useEffect(function () {
3289 if (!scrollToPosition || !anchorNode.current) {
3290 return;
3291 }
3292
3293 scrollToPosition(anchorNode.current.offsetTop);
3294 }, [scrollToPosition]);
3295 var id = useUniqueId("ScrollTo"); // eslint-disable-next-line jsx-a11y/anchor-is-valid
3296
3297 return React__default.createElement("a", {
3298 id: id,
3299 ref: anchorNode
3300 });
3301}
3302
3303var styles$6 = {
3304 "Scrollable": "Polaris-Scrollable",
3305 "horizontal": "Polaris-Scrollable--horizontal",
3306 "vertical": "Polaris-Scrollable--vertical",
3307 "hasTopShadow": "Polaris-Scrollable--hasTopShadow",
3308 "hasBottomShadow": "Polaris-Scrollable--hasBottomShadow"
3309};
3310
3311var MAX_SCROLL_DISTANCE = 100;
3312var DELTA_THRESHOLD = 0.2;
3313var DELTA_PERCENTAGE = 0.2;
3314var EVENTS_TO_LOCK = ['scroll', 'touchmove', 'wheel'];
3315var PREFERS_REDUCED_MOTION = prefersReducedMotion();
3316var Scrollable =
3317/*#__PURE__*/
3318function (_React$Component) {
3319 _inherits(Scrollable, _React$Component);
3320
3321 function Scrollable() {
3322 var _this;
3323
3324 _classCallCheck(this, Scrollable);
3325
3326 _this = _possibleConstructorReturn(this, _getPrototypeOf(Scrollable).apply(this, arguments));
3327 _this.state = {
3328 topShadow: false,
3329 bottomShadow: false,
3330 scrollPosition: 0
3331 };
3332 _this.stickyManager = new StickyManager();
3333 _this.handleResize = debounce(function () {
3334 _this.handleScroll();
3335 }, 50, {
3336 trailing: true
3337 });
3338
3339 _this.setScrollArea = function (scrollArea) {
3340 _this.scrollArea = scrollArea;
3341 };
3342
3343 _this.handleScroll = function () {
3344 var _assertThisInitialize = _assertThisInitialized(_this),
3345 scrollArea = _assertThisInitialize.scrollArea;
3346
3347 var _this$props = _this.props,
3348 shadow = _this$props.shadow,
3349 onScrolledToBottom = _this$props.onScrolledToBottom;
3350
3351 if (scrollArea == null) {
3352 return;
3353 }
3354
3355 var scrollTop = scrollArea.scrollTop,
3356 clientHeight = scrollArea.clientHeight,
3357 scrollHeight = scrollArea.scrollHeight;
3358 var shouldBottomShadow = Boolean(shadow && !(scrollTop + clientHeight >= scrollHeight));
3359 var shouldTopShadow = Boolean(shadow && scrollTop > 0);
3360 var canScroll = scrollHeight > clientHeight;
3361 var hasScrolledToBottom = scrollHeight - scrollTop === clientHeight;
3362
3363 if (canScroll && hasScrolledToBottom && onScrolledToBottom) {
3364 onScrolledToBottom();
3365 }
3366
3367 _this.setState({
3368 topShadow: shouldTopShadow,
3369 bottomShadow: shouldBottomShadow,
3370 scrollPosition: scrollTop
3371 });
3372 };
3373
3374 _this.scrollHint = function () {
3375 var _assertThisInitialize2 = _assertThisInitialized(_this),
3376 scrollArea = _assertThisInitialize2.scrollArea;
3377
3378 if (scrollArea == null) {
3379 return;
3380 }
3381
3382 var clientHeight = scrollArea.clientHeight,
3383 scrollHeight = scrollArea.scrollHeight;
3384
3385 if (PREFERS_REDUCED_MOTION || _this.state.scrollPosition > 0 || scrollHeight <= clientHeight) {
3386 return;
3387 }
3388
3389 var scrollDistance = scrollHeight - clientHeight;
3390
3391 _this.toggleLock();
3392
3393 _this.setState({
3394 scrollPosition: scrollDistance > MAX_SCROLL_DISTANCE ? MAX_SCROLL_DISTANCE : scrollDistance
3395 }, function () {
3396 window.requestAnimationFrame(_this.scrollStep);
3397 });
3398 };
3399
3400 _this.scrollStep = function () {
3401 _this.setState(function (_ref) {
3402 var scrollPosition = _ref.scrollPosition;
3403 var delta = scrollPosition * DELTA_PERCENTAGE;
3404 return {
3405 scrollPosition: delta < DELTA_THRESHOLD ? 0 : scrollPosition - delta
3406 };
3407 }, function () {
3408 if (_this.state.scrollPosition > 0) {
3409 window.requestAnimationFrame(_this.scrollStep);
3410 } else {
3411 _this.toggleLock(false);
3412 }
3413 });
3414 };
3415
3416 _this.scrollToPosition = function (scrollY) {
3417 _this.setState({
3418 scrollPosition: scrollY
3419 });
3420 };
3421
3422 return _this;
3423 }
3424
3425 _createClass(Scrollable, [{
3426 key: "componentDidMount",
3427 value: function componentDidMount() {
3428 var _this2 = this;
3429
3430 if (this.scrollArea == null) {
3431 return;
3432 }
3433
3434 this.stickyManager.setContainer(this.scrollArea);
3435 events.addEventListener(this.scrollArea, 'scroll', function () {
3436 window.requestAnimationFrame(_this2.handleScroll);
3437 });
3438 events.addEventListener(window, 'resize', this.handleResize);
3439 window.requestAnimationFrame(function () {
3440 _this2.handleScroll();
3441
3442 if (_this2.props.hint) {
3443 _this2.scrollHint();
3444 }
3445 });
3446 }
3447 }, {
3448 key: "componentWillUnmount",
3449 value: function componentWillUnmount() {
3450 if (this.scrollArea == null) {
3451 return;
3452 }
3453
3454 events.removeEventListener(this.scrollArea, 'scroll', this.handleScroll);
3455 events.removeEventListener(window, 'resize', this.handleResize);
3456 this.stickyManager.removeScrollListener();
3457 }
3458 }, {
3459 key: "componentDidUpdate",
3460 value: function componentDidUpdate() {
3461 var scrollPosition = this.state.scrollPosition;
3462
3463 if (scrollPosition && this.scrollArea && scrollPosition > 0) {
3464 this.scrollArea.scrollTop = scrollPosition;
3465 }
3466 }
3467 }, {
3468 key: "render",
3469 value: function render() {
3470 var _this$state = this.state,
3471 topShadow = _this$state.topShadow,
3472 bottomShadow = _this$state.bottomShadow;
3473
3474 var _a = this.props,
3475 children = _a.children,
3476 className = _a.className,
3477 horizontal = _a.horizontal,
3478 _a$vertical = _a.vertical,
3479 vertical = _a$vertical === void 0 ? true : _a$vertical,
3480 shadow = _a.shadow,
3481 hint = _a.hint,
3482 onScrolledToBottom = _a.onScrolledToBottom,
3483 rest = tslib_1.__rest(_a, ["children", "className", "horizontal", "vertical", "shadow", "hint", "onScrolledToBottom"]);
3484
3485 var finalClassName = classNames(className, styles$6.Scrollable, vertical && styles$6.vertical, horizontal && styles$6.horizontal, topShadow && styles$6.hasTopShadow, bottomShadow && styles$6.hasBottomShadow);
3486 return React__default.createElement(ScrollableContext.Provider, {
3487 value: this.scrollToPosition
3488 }, React__default.createElement(StickyManagerContext.Provider, {
3489 value: this.stickyManager
3490 }, React__default.createElement("div", Object.assign({
3491 className: finalClassName
3492 }, scrollable.props, rest, {
3493 ref: this.setScrollArea
3494 }), children)));
3495 }
3496 }, {
3497 key: "toggleLock",
3498 value: function toggleLock() {
3499 var shouldLock = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
3500 var scrollArea = this.scrollArea;
3501
3502 if (scrollArea == null) {
3503 return;
3504 }
3505
3506 EVENTS_TO_LOCK.forEach(function (eventName) {
3507 if (shouldLock) {
3508 events.addEventListener(scrollArea, eventName, prevent);
3509 } else {
3510 events.removeEventListener(scrollArea, eventName, prevent);
3511 }
3512 });
3513 }
3514 }], [{
3515 key: "forNode",
3516 value: function forNode(node) {
3517 return dom.closest(node, scrollable.selector) || document;
3518 }
3519 }]);
3520
3521 return Scrollable;
3522}(React__default.Component);
3523Scrollable.ScrollTo = ScrollTo;
3524
3525function prevent(evt) {
3526 evt.preventDefault();
3527}
3528
3529function prefersReducedMotion() {
3530 try {
3531 return window.matchMedia('(prefers-reduced-motion: reduce)').matches;
3532 } catch (err) {
3533 return false;
3534 }
3535}
3536
3537var styles$7 = {
3538 "Badge": "Polaris-Badge",
3539 "Pip": "Polaris-Badge__Pip",
3540 "sizeSmall": "Polaris-Badge--sizeSmall",
3541 "statusSuccess": "Polaris-Badge--statusSuccess",
3542 "Content": "Polaris-Badge__Content",
3543 "statusInfo": "Polaris-Badge--statusInfo",
3544 "statusAttention": "Polaris-Badge--statusAttention",
3545 "statusWarning": "Polaris-Badge--statusWarning",
3546 "statusNew": "Polaris-Badge--statusNew",
3547 "progressIncomplete": "Polaris-Badge--progressIncomplete",
3548 "progressPartiallyComplete": "Polaris-Badge--progressPartiallyComplete",
3549 "progressComplete": "Polaris-Badge--progressComplete"
3550};
3551
3552var PROGRESS_LABELS = {
3553 incomplete: 'incomplete',
3554 partiallyComplete: 'partiallyComplete',
3555 complete: 'complete'
3556};
3557var STATUS_LABELS = {
3558 info: 'info',
3559 success: 'success',
3560 warning: 'warning',
3561 attention: 'attention',
3562 new: 'new'
3563};
3564var DEFAULT_SIZE$1 = 'medium';
3565function Badge(_ref) {
3566 var children = _ref.children,
3567 status = _ref.status,
3568 progress = _ref.progress,
3569 _ref$size = _ref.size,
3570 size = _ref$size === void 0 ? DEFAULT_SIZE$1 : _ref$size;
3571 var i18n = useI18n();
3572 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)]);
3573 var progressMarkup;
3574
3575 switch (progress) {
3576 case PROGRESS_LABELS.incomplete:
3577 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.incomplete');
3578 break;
3579
3580 case PROGRESS_LABELS.partiallyComplete:
3581 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.partiallyComplete');
3582 break;
3583
3584 case PROGRESS_LABELS.complete:
3585 progressMarkup = i18n.translate('Polaris.Badge.PROGRESS_LABELS.complete');
3586 break;
3587 }
3588
3589 var pipMarkup = progress ? React__default.createElement("span", {
3590 className: styles$7.Pip
3591 }, React__default.createElement(VisuallyHidden, null, progressMarkup)) : null;
3592 var statusMarkup;
3593
3594 switch (status) {
3595 case STATUS_LABELS.info:
3596 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.info');
3597 break;
3598
3599 case STATUS_LABELS.success:
3600 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.success');
3601 break;
3602
3603 case STATUS_LABELS.warning:
3604 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.warning');
3605 break;
3606
3607 case STATUS_LABELS.attention:
3608 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.attention');
3609 break;
3610
3611 case STATUS_LABELS.new:
3612 statusMarkup = i18n.translate('Polaris.Badge.STATUS_LABELS.new');
3613 break;
3614 }
3615
3616 var statusLabelMarkup = status ? React__default.createElement(VisuallyHidden, null, statusMarkup) : null;
3617 return React__default.createElement("span", {
3618 className: className
3619 }, statusLabelMarkup, pipMarkup, React__default.createElement("span", {
3620 className: styles$7.Content
3621 }, children));
3622}
3623
3624var styles$8 = {
3625 "variationPositive": "Polaris-TextStyle--variationPositive",
3626 "variationNegative": "Polaris-TextStyle--variationNegative",
3627 "variationCode": "Polaris-TextStyle--variationCode",
3628 "variationStrong": "Polaris-TextStyle--variationStrong",
3629 "variationSubdued": "Polaris-TextStyle--variationSubdued"
3630};
3631
3632var VariationValue;
3633
3634(function (VariationValue) {
3635 VariationValue["Positive"] = "positive";
3636 VariationValue["Negative"] = "negative";
3637 VariationValue["Strong"] = "strong";
3638 VariationValue["Subdued"] = "subdued";
3639 VariationValue["Code"] = "code";
3640})(VariationValue || (VariationValue = {}));
3641
3642function TextStyle(_ref) {
3643 var variation = _ref.variation,
3644 children = _ref.children;
3645 var className = classNames(variation && styles$8[variationName('variation', variation)], variation === VariationValue.Code && styles$8.code);
3646 var Element = variationElement(variation);
3647 return React__default.createElement(Element, {
3648 className: className
3649 }, children);
3650}
3651
3652function variationElement(variation) {
3653 return variation === VariationValue.Code ? 'code' : 'span';
3654}
3655
3656var styles$9 = {
3657 "ActionList": "Polaris-ActionList",
3658 "globalTheming": "Polaris-ActionList--globalTheming",
3659 "Section-withoutTitle": "Polaris-ActionList__Section--withoutTitle",
3660 "Actions": "Polaris-ActionList__Actions",
3661 "Section": "Polaris-ActionList__Section",
3662 "Title": "Polaris-ActionList__Title",
3663 "Item": "Polaris-ActionList__Item",
3664 "active": "Polaris-ActionList--active",
3665 "destructive": "Polaris-ActionList--destructive",
3666 "disabled": "Polaris-ActionList--disabled",
3667 "Image": "Polaris-ActionList__Image",
3668 "Content": "Polaris-ActionList__Content",
3669 "Text": "Polaris-ActionList__Text",
3670 "BadgeWrapper": "Polaris-ActionList__BadgeWrapper"
3671};
3672
3673function Item$1(_ref) {
3674 var id = _ref.id,
3675 badge = _ref.badge,
3676 content = _ref.content,
3677 accessibilityLabel = _ref.accessibilityLabel,
3678 helpText = _ref.helpText,
3679 url = _ref.url,
3680 onAction = _ref.onAction,
3681 icon = _ref.icon,
3682 image = _ref.image,
3683 disabled = _ref.disabled,
3684 external = _ref.external,
3685 destructive = _ref.destructive,
3686 ellipsis = _ref.ellipsis,
3687 active = _ref.active,
3688 role = _ref.role;
3689
3690 var _useFeatures = useFeatures(),
3691 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
3692 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
3693
3694 var className = classNames(styles$9.Item, disabled && styles$9.disabled, destructive && styles$9.destructive, active && styles$9.active, unstableGlobalTheming && styles$9.globalTheming);
3695 var imageElement = null;
3696
3697 if (icon) {
3698 imageElement = React__default.createElement("div", {
3699 className: styles$9.Image
3700 }, React__default.createElement(Icon, {
3701 source: icon
3702 }));
3703 } else if (image) {
3704 imageElement = React__default.createElement("div", {
3705 role: "presentation",
3706 className: styles$9.Image,
3707 style: {
3708 backgroundImage: "url(".concat(image)
3709 }
3710 });
3711 }
3712
3713 var contentText = ellipsis && content ? "".concat(content, "\u2026") : content;
3714 var contentMarkup = helpText ? React__default.createElement("div", null, React__default.createElement("div", null, contentText), React__default.createElement(TextStyle, {
3715 variation: "subdued"
3716 }, helpText)) : contentText;
3717 var badgeMarkup = badge && React__default.createElement("span", {
3718 className: styles$9.BadgeWrapper
3719 }, React__default.createElement(Badge, {
3720 status: badge.status
3721 }, badge.content));
3722 var textMarkup = imageElement ? React__default.createElement("div", {
3723 className: styles$9.Text
3724 }, contentMarkup) : contentMarkup;
3725 var contentElement = React__default.createElement("div", {
3726 className: styles$9.Content
3727 }, imageElement, textMarkup, badgeMarkup);
3728 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
3729 var control = url ? React__default.createElement(UnstyledLink, {
3730 id: id,
3731 url: url,
3732 className: className,
3733 external: external,
3734 "aria-label": accessibilityLabel,
3735 onClick: onAction
3736 }, contentElement) : React__default.createElement("button", {
3737 id: id,
3738 type: "button",
3739 className: className,
3740 disabled: disabled,
3741 "aria-label": accessibilityLabel,
3742 onClick: onAction
3743 }, contentElement);
3744 return React__default.createElement("li", {
3745 role: role,
3746 "aria-selected": active
3747 }, scrollMarkup, control);
3748}
3749
3750function Section(_ref) {
3751 var section = _ref.section,
3752 hasMultipleSections = _ref.hasMultipleSections,
3753 actionRole = _ref.actionRole,
3754 onActionAnyItem = _ref.onActionAnyItem;
3755
3756 var handleAction = function handleAction(itemOnAction) {
3757 return function () {
3758 if (itemOnAction) {
3759 itemOnAction();
3760 }
3761
3762 if (onActionAnyItem) {
3763 onActionAnyItem();
3764 }
3765 };
3766 };
3767
3768 var actionMarkup = section.items.map(function (_a, index) {
3769 var content = _a.content,
3770 helpText = _a.helpText,
3771 onAction = _a.onAction,
3772 item = tslib_1.__rest(_a, ["content", "helpText", "onAction"]);
3773
3774 return React__default.createElement(Item$1, Object.assign({
3775 key: "".concat(content, "-").concat(index),
3776 content: content,
3777 helpText: helpText,
3778 role: actionRole,
3779 onAction: handleAction(onAction)
3780 }, item));
3781 });
3782 var className = section.title ? undefined : styles$9['Section-withoutTitle'];
3783 var titleMarkup = section.title ? React__default.createElement("p", {
3784 className: styles$9.Title
3785 }, section.title) : null;
3786 var sectionRole = actionRole === 'option' ? 'presentation' : undefined;
3787 var sectionMarkup = React__default.createElement("div", {
3788 className: className
3789 }, titleMarkup, React__default.createElement("ul", {
3790 className: styles$9.Actions,
3791 role: sectionRole
3792 }, actionMarkup));
3793 return hasMultipleSections ? React__default.createElement("li", {
3794 className: styles$9.Section
3795 }, sectionMarkup) : sectionMarkup;
3796}
3797
3798function ActionList(_ref) {
3799 var items = _ref.items,
3800 _ref$sections = _ref.sections,
3801 sections = _ref$sections === void 0 ? [] : _ref$sections,
3802 actionRole = _ref.actionRole,
3803 onActionAnyItem = _ref.onActionAnyItem;
3804 var finalSections = [];
3805
3806 if (items) {
3807 finalSections = [{
3808 items
3809 }].concat(_toConsumableArray(sections));
3810 } else if (sections) {
3811 finalSections = sections;
3812 }
3813
3814 var _useFeatures = useFeatures(),
3815 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
3816 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
3817
3818 var className = classNames(styles$9.ActionList, unstableGlobalTheming && styles$9.globalTheming);
3819 var hasMultipleSections = finalSections.length > 1; // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
3820 // see https://github.com/Microsoft/TypeScript/issues/28768
3821
3822 var Element = hasMultipleSections ? 'ul' : 'div';
3823 var sectionMarkup = finalSections.map(function (section, index) {
3824 return section.items.length > 0 ? React__default.createElement(Section, {
3825 key: section.title || index,
3826 section: section,
3827 hasMultipleSections: hasMultipleSections,
3828 actionRole: actionRole,
3829 onActionAnyItem: onActionAnyItem
3830 }) : null;
3831 });
3832 return React__default.createElement(Element, {
3833 className: className
3834 }, sectionMarkup);
3835}
3836
3837var getUniqueID = other.createUniqueIDFactory('portal-');
3838var Portal =
3839/*#__PURE__*/
3840function (_React$PureComponent) {
3841 _inherits(Portal, _React$PureComponent);
3842
3843 function Portal() {
3844 var _this;
3845
3846 _classCallCheck(this, Portal);
3847
3848 _this = _possibleConstructorReturn(this, _getPrototypeOf(Portal).apply(this, arguments));
3849 _this.state = {
3850 isMounted: false
3851 };
3852 _this.portalId = _this.props.idPrefix !== '' ? "".concat(_this.props.idPrefix, "-").concat(getUniqueID()) : getUniqueID();
3853 return _this;
3854 }
3855
3856 _createClass(Portal, [{
3857 key: "componentDidMount",
3858 value: function componentDidMount() {
3859 this.portalNode = document.createElement('div');
3860 this.portalNode.setAttribute(portal.props[0], this.portalId);
3861
3862 if (this.context != null) {
3863 var UNSTABLE_cssCustomProperties = this.context.UNSTABLE_cssCustomProperties;
3864
3865 if (UNSTABLE_cssCustomProperties != null) {
3866 this.portalNode.setAttribute('style', UNSTABLE_cssCustomProperties);
3867 } else {
3868 this.portalNode.removeAttribute('style');
3869 }
3870 }
3871
3872 document.body.appendChild(this.portalNode);
3873 this.setState({
3874 isMounted: true
3875 });
3876 }
3877 }, {
3878 key: "componentDidUpdate",
3879 value: function componentDidUpdate(_, prevState) {
3880 var _this$props$onPortalC = this.props.onPortalCreated,
3881 onPortalCreated = _this$props$onPortalC === void 0 ? noop$2 : _this$props$onPortalC;
3882
3883 if (this.context != null) {
3884 var UNSTABLE_cssCustomProperties = this.context.UNSTABLE_cssCustomProperties;
3885
3886 if (UNSTABLE_cssCustomProperties != null) {
3887 this.portalNode.setAttribute('style', UNSTABLE_cssCustomProperties);
3888 } else {
3889 this.portalNode.removeAttribute('style');
3890 }
3891 }
3892
3893 if (!prevState.isMounted && this.state.isMounted) {
3894 onPortalCreated();
3895 }
3896 }
3897 }, {
3898 key: "componentWillUnmount",
3899 value: function componentWillUnmount() {
3900 document.body.removeChild(this.portalNode);
3901 }
3902 }, {
3903 key: "render",
3904 value: function render() {
3905 return this.state.isMounted ? reactDom.createPortal(this.props.children, this.portalNode) : null;
3906 }
3907 }]);
3908
3909 return Portal;
3910}(React__default.PureComponent);
3911Portal.defaultProps = {
3912 idPrefix: ''
3913};
3914Portal.contextType = ThemeContext;
3915
3916function noop$2() {}
3917
3918var styles$a = {
3919 "Popover": "Polaris-Popover",
3920 "PopoverOverlay": "Polaris-Popover__PopoverOverlay",
3921 "PopoverOverlay-entering": "Polaris-Popover__PopoverOverlay--entering",
3922 "PopoverOverlay-open": "Polaris-Popover__PopoverOverlay--open",
3923 "PopoverOverlay-exiting": "Polaris-Popover__PopoverOverlay--exiting",
3924 "measuring": "Polaris-Popover--measuring",
3925 "fullWidth": "Polaris-Popover--fullWidth",
3926 "Content": "Polaris-Popover__Content",
3927 "positionedAbove": "Polaris-Popover--positionedAbove",
3928 "Wrapper": "Polaris-Popover__Wrapper",
3929 "Content-fullHeight": "Polaris-Popover__Content--fullHeight",
3930 "Content-fluidContent": "Polaris-Popover__Content--fluidContent",
3931 "Pane": "Polaris-Popover__Pane",
3932 "Pane-fixed": "Polaris-Popover__Pane--fixed",
3933 "Section": "Polaris-Popover__Section",
3934 "FocusTracker": "Polaris-Popover__FocusTracker"
3935};
3936
3937function Section$1(_ref) {
3938 var children = _ref.children;
3939 return React__default.createElement("div", {
3940 className: styles$a.Section
3941 }, children);
3942}
3943
3944function Pane(_ref) {
3945 var fixed = _ref.fixed,
3946 sectioned = _ref.sectioned,
3947 children = _ref.children,
3948 onScrolledToBottom = _ref.onScrolledToBottom;
3949 var className = classNames(styles$a.Pane, fixed && styles$a['Pane-fixed']);
3950 var content = sectioned ? wrapWithComponent(children, Section$1, {}) : children;
3951 return fixed ? React__default.createElement("div", {
3952 className: className
3953 }, content) : React__default.createElement(Scrollable, {
3954 hint: true,
3955 shadow: true,
3956 className: className,
3957 onScrolledToBottom: onScrolledToBottom
3958 }, content);
3959}
3960
3961var EventListener =
3962/*#__PURE__*/
3963function (_React$PureComponent) {
3964 _inherits(EventListener, _React$PureComponent);
3965
3966 function EventListener() {
3967 _classCallCheck(this, EventListener);
3968
3969 return _possibleConstructorReturn(this, _getPrototypeOf(EventListener).apply(this, arguments));
3970 }
3971
3972 _createClass(EventListener, [{
3973 key: "componentDidMount",
3974 value: function componentDidMount() {
3975 this.attachListener();
3976 }
3977 }, {
3978 key: "componentDidUpdate",
3979 value: function componentDidUpdate(_a) {
3980 var passive = _a.passive,
3981 detachProps = tslib_1.__rest(_a, ["passive"]);
3982
3983 this.detachListener(detachProps);
3984 this.attachListener();
3985 }
3986 }, {
3987 key: "componentWillUnmount",
3988 value: function componentWillUnmount() {
3989 this.detachListener();
3990 }
3991 }, {
3992 key: "render",
3993 value: function render() {
3994 return null;
3995 }
3996 }, {
3997 key: "attachListener",
3998 value: function attachListener() {
3999 var _this$props = this.props,
4000 event = _this$props.event,
4001 handler = _this$props.handler,
4002 capture = _this$props.capture,
4003 passive = _this$props.passive;
4004 events.addEventListener(window, event, handler, {
4005 capture,
4006 passive
4007 });
4008 }
4009 }, {
4010 key: "detachListener",
4011 value: function detachListener(prevProps) {
4012 var _ref = prevProps || this.props,
4013 event = _ref.event,
4014 handler = _ref.handler,
4015 capture = _ref.capture;
4016
4017 events.removeEventListener(window, event, handler, capture);
4018 }
4019 }]);
4020
4021 return EventListener;
4022}(React__default.PureComponent);
4023
4024var KeypressListener =
4025/*#__PURE__*/
4026function (_React$Component) {
4027 _inherits(KeypressListener, _React$Component);
4028
4029 function KeypressListener() {
4030 var _this;
4031
4032 _classCallCheck(this, KeypressListener);
4033
4034 _this = _possibleConstructorReturn(this, _getPrototypeOf(KeypressListener).apply(this, arguments));
4035
4036 _this.handleKeyEvent = function (event) {
4037 var _this$props = _this.props,
4038 keyCode = _this$props.keyCode,
4039 handler = _this$props.handler;
4040
4041 if (event.keyCode === keyCode) {
4042 handler(event);
4043 }
4044 };
4045
4046 return _this;
4047 }
4048
4049 _createClass(KeypressListener, [{
4050 key: "componentDidMount",
4051 value: function componentDidMount() {
4052 events.addEventListener(document, 'keyup', this.handleKeyEvent);
4053 }
4054 }, {
4055 key: "componentWillUnmount",
4056 value: function componentWillUnmount() {
4057 events.removeEventListener(document, 'keyup', this.handleKeyEvent);
4058 }
4059 }, {
4060 key: "render",
4061 value: function render() {
4062 return null;
4063 }
4064 }]);
4065
4066 return KeypressListener;
4067}(React__default.Component);
4068
4069function calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed) {
4070 var activatorTop = activatorRect.top;
4071 var activatorBottom = activatorTop + activatorRect.height;
4072 var spaceAbove = activatorRect.top;
4073 var spaceBelow = containerRect.height - activatorRect.top - activatorRect.height;
4074 var desiredHeight = overlayRect.height;
4075 var verticalMargins = overlayMargins.activator + overlayMargins.container;
4076 var minimumSpaceToScroll = overlayMargins.container;
4077 var distanceToTopScroll = activatorRect.top - Math.max(scrollableContainerRect.top, 0);
4078 var distanceToBottomScroll = containerRect.top + Math.min(containerRect.height, scrollableContainerRect.top + scrollableContainerRect.height) - (activatorRect.top + activatorRect.height);
4079 var enoughSpaceFromTopScroll = distanceToTopScroll >= minimumSpaceToScroll;
4080 var enoughSpaceFromBottomScroll = distanceToBottomScroll >= minimumSpaceToScroll;
4081 var heightIfBelow = Math.min(spaceBelow, desiredHeight);
4082 var heightIfAbove = Math.min(spaceAbove, desiredHeight);
4083 var containerRectTop = fixed ? 0 : containerRect.top;
4084 var positionIfAbove = {
4085 height: heightIfAbove - verticalMargins,
4086 top: activatorTop + containerRectTop - heightIfAbove,
4087 positioning: 'above'
4088 };
4089 var positionIfBelow = {
4090 height: heightIfBelow - verticalMargins,
4091 top: activatorBottom + containerRectTop,
4092 positioning: 'below'
4093 };
4094
4095 if (preferredPosition === 'above') {
4096 return (enoughSpaceFromTopScroll || distanceToTopScroll >= distanceToBottomScroll && !enoughSpaceFromBottomScroll) && (spaceAbove > desiredHeight || spaceAbove > spaceBelow) ? positionIfAbove : positionIfBelow;
4097 }
4098
4099 if (preferredPosition === 'below') {
4100 return (enoughSpaceFromBottomScroll || distanceToBottomScroll >= distanceToTopScroll && !enoughSpaceFromTopScroll) && (spaceBelow > desiredHeight || spaceBelow > spaceAbove) ? positionIfBelow : positionIfAbove;
4101 }
4102
4103 if (enoughSpaceFromTopScroll && enoughSpaceFromBottomScroll) {
4104 return spaceAbove > spaceBelow ? positionIfAbove : positionIfBelow;
4105 }
4106
4107 return distanceToTopScroll > minimumSpaceToScroll ? positionIfAbove : positionIfBelow;
4108}
4109function calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment) {
4110 var maximum = containerRect.width - overlayRect.width;
4111
4112 if (preferredAlignment === 'left') {
4113 return Math.min(maximum, Math.max(0, activatorRect.left - overlayMargins.horizontal));
4114 } else if (preferredAlignment === 'right') {
4115 var activatorRight = activatorRect.left + activatorRect.width;
4116 return Math.min(maximum, Math.max(0, activatorRight - overlayRect.width + overlayMargins.horizontal));
4117 }
4118
4119 return Math.min(maximum, Math.max(0, activatorRect.center.x - overlayRect.width / 2));
4120}
4121function rectIsOutsideOfRect(inner, outer) {
4122 var center = inner.center;
4123 return center.y < outer.top || center.y > outer.top + outer.height;
4124}
4125
4126var styles$b = {
4127 "PositionedOverlay": "Polaris-PositionedOverlay",
4128 "fixed": "Polaris-PositionedOverlay--fixed",
4129 "calculating": "Polaris-PositionedOverlay--calculating"
4130};
4131
4132var OBSERVER_CONFIG = {
4133 childList: true,
4134 subtree: true
4135};
4136var PositionedOverlay =
4137/*#__PURE__*/
4138function (_React$PureComponent) {
4139 _inherits(PositionedOverlay, _React$PureComponent);
4140
4141 function PositionedOverlay(props) {
4142 var _this;
4143
4144 _classCallCheck(this, PositionedOverlay);
4145
4146 _this = _possibleConstructorReturn(this, _getPrototypeOf(PositionedOverlay).call(this, props));
4147 _this.state = {
4148 measuring: true,
4149 activatorRect: geometry.getRectForNode(_this.props.activator),
4150 left: 0,
4151 top: 0,
4152 height: 0,
4153 width: null,
4154 positioning: 'below',
4155 zIndex: null,
4156 outsideScrollableContainer: false,
4157 lockPosition: false
4158 };
4159 _this.overlay = null;
4160 _this.scrollableContainer = null;
4161
4162 _this.overlayDetails = function () {
4163 var _this$state = _this.state,
4164 measuring = _this$state.measuring,
4165 left = _this$state.left,
4166 positioning = _this$state.positioning,
4167 height = _this$state.height,
4168 activatorRect = _this$state.activatorRect;
4169 return {
4170 measuring,
4171 left,
4172 desiredHeight: height,
4173 positioning,
4174 activatorRect
4175 };
4176 };
4177
4178 _this.setOverlay = function (node) {
4179 _this.overlay = node;
4180 };
4181
4182 _this.handleMeasurement = function () {
4183 var _this$state2 = _this.state,
4184 lockPosition = _this$state2.lockPosition,
4185 top = _this$state2.top;
4186
4187 _this.observer.disconnect();
4188
4189 _this.setState(function (_ref) {
4190 var left = _ref.left,
4191 top = _ref.top;
4192 return {
4193 left,
4194 top,
4195 height: 0,
4196 positioning: 'below',
4197 measuring: true
4198 };
4199 }, function () {
4200 if (_this.overlay == null || _this.scrollableContainer == null) {
4201 return;
4202 }
4203
4204 var _this$props = _this.props,
4205 activator = _this$props.activator,
4206 _this$props$preferred = _this$props.preferredPosition,
4207 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred,
4208 _this$props$preferred2 = _this$props.preferredAlignment,
4209 preferredAlignment = _this$props$preferred2 === void 0 ? 'center' : _this$props$preferred2,
4210 onScrollOut = _this$props.onScrollOut,
4211 fullWidth = _this$props.fullWidth,
4212 fixed = _this$props.fixed;
4213 var textFieldActivator = activator.querySelector('input');
4214 var activatorRect = textFieldActivator != null ? geometry.getRectForNode(textFieldActivator) : geometry.getRectForNode(activator);
4215 var currentOverlayRect = geometry.getRectForNode(_this.overlay);
4216 var scrollableElement = isDocument$1(_this.scrollableContainer) ? document.body : _this.scrollableContainer;
4217 var scrollableContainerRect = geometry.getRectForNode(scrollableElement);
4218 var overlayRect = fullWidth ? Object.assign({}, currentOverlayRect, {
4219 width: activatorRect.width
4220 }) : currentOverlayRect; // If `body` is 100% height, it still acts as though it were not constrained to that size. This adjusts for that.
4221
4222 if (scrollableElement === document.body) {
4223 scrollableContainerRect.height = document.body.scrollHeight;
4224 }
4225
4226 var overlayMargins = _this.overlay.firstElementChild ? getMarginsForNode(_this.overlay.firstElementChild) : {
4227 activator: 0,
4228 container: 0,
4229 horizontal: 0
4230 };
4231 var containerRect = windowRect();
4232 var zIndexForLayer = getZIndexForLayerFromNode(activator);
4233 var zIndex = zIndexForLayer == null ? zIndexForLayer : zIndexForLayer + 1;
4234 var verticalPosition = calculateVerticalPosition(activatorRect, overlayRect, overlayMargins, scrollableContainerRect, containerRect, preferredPosition, fixed);
4235 var horizontalPosition = calculateHorizontalPosition(activatorRect, overlayRect, containerRect, overlayMargins, preferredAlignment);
4236
4237 _this.setState({
4238 measuring: false,
4239 activatorRect: geometry.getRectForNode(activator),
4240 left: horizontalPosition,
4241 top: lockPosition ? top : verticalPosition.top,
4242 lockPosition: Boolean(fixed),
4243 height: verticalPosition.height || 0,
4244 width: fullWidth ? overlayRect.width : null,
4245 positioning: verticalPosition.positioning,
4246 outsideScrollableContainer: onScrollOut != null && rectIsOutsideOfRect(activatorRect, intersectionWithViewport(scrollableContainerRect)),
4247 zIndex
4248 }, function () {
4249 if (!_this.overlay) return;
4250
4251 _this.observer.observe(_this.overlay, OBSERVER_CONFIG);
4252 });
4253 });
4254 };
4255
4256 _this.observer = new MutationObserver(_this.handleMeasurement);
4257 return _this;
4258 }
4259
4260 _createClass(PositionedOverlay, [{
4261 key: "componentDidMount",
4262 value: function componentDidMount() {
4263 this.scrollableContainer = Scrollable.forNode(this.props.activator);
4264
4265 if (this.scrollableContainer && !this.props.fixed) {
4266 this.scrollableContainer.addEventListener('scroll', this.handleMeasurement);
4267 }
4268
4269 this.handleMeasurement();
4270 }
4271 }, {
4272 key: "componentWillUnmount",
4273 value: function componentWillUnmount() {
4274 if (this.scrollableContainer && !this.props.fixed) {
4275 this.scrollableContainer.removeEventListener('scroll', this.handleMeasurement);
4276 }
4277 }
4278 }, {
4279 key: "componentDidUpdate",
4280 value: function componentDidUpdate() {
4281 var _this$state3 = this.state,
4282 outsideScrollableContainer = _this$state3.outsideScrollableContainer,
4283 top = _this$state3.top;
4284 var _this$props2 = this.props,
4285 onScrollOut = _this$props2.onScrollOut,
4286 active = _this$props2.active;
4287
4288 if (active && onScrollOut != null && top !== 0 && outsideScrollableContainer) {
4289 onScrollOut();
4290 }
4291 }
4292 }, {
4293 key: "render",
4294 value: function render() {
4295 var _this$state4 = this.state,
4296 left = _this$state4.left,
4297 top = _this$state4.top,
4298 zIndex = _this$state4.zIndex,
4299 width = _this$state4.width;
4300 var _this$props3 = this.props,
4301 render = _this$props3.render,
4302 fixed = _this$props3.fixed,
4303 propClassNames = _this$props3.classNames;
4304 var style = {
4305 top: top == null || isNaN(top) ? undefined : top,
4306 left: left == null || isNaN(left) ? undefined : left,
4307 width: width == null || isNaN(width) ? undefined : width,
4308 zIndex: zIndex == null || isNaN(zIndex) ? undefined : zIndex
4309 };
4310 var className = classNames(styles$b.PositionedOverlay, fixed && styles$b.fixed, propClassNames);
4311 return React__default.createElement("div", {
4312 className: className,
4313 style: style,
4314 ref: this.setOverlay
4315 }, React__default.createElement(EventListener, {
4316 event: "resize",
4317 handler: this.handleMeasurement
4318 }), render(this.overlayDetails()));
4319 }
4320 }]);
4321
4322 return PositionedOverlay;
4323}(React__default.PureComponent);
4324function intersectionWithViewport(rect) {
4325 var viewport = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : windowRect();
4326 var top = Math.max(rect.top, 0);
4327 var left = Math.max(rect.left, 0);
4328 var bottom = Math.min(rect.top + rect.height, viewport.height);
4329 var right = Math.min(rect.left + rect.width, viewport.width);
4330 return new geometry.Rect({
4331 top,
4332 left,
4333 height: bottom - top,
4334 width: right - left
4335 });
4336}
4337
4338function getMarginsForNode(node) {
4339 var nodeStyles = window.getComputedStyle(node);
4340 return {
4341 activator: parseFloat(nodeStyles.marginTop || ''),
4342 container: parseFloat(nodeStyles.marginBottom || ''),
4343 horizontal: parseFloat(nodeStyles.marginLeft || '')
4344 };
4345}
4346
4347function getZIndexForLayerFromNode(node) {
4348 var layerNode = dom.closest(node, layer.selector) || document.body;
4349 var zIndex = layerNode === document.body ? 'auto' : parseInt(window.getComputedStyle(layerNode).zIndex || '0', 10);
4350 return zIndex === 'auto' || isNaN(zIndex) ? null : zIndex;
4351}
4352
4353function windowRect() {
4354 return new geometry.Rect({
4355 top: window.scrollY,
4356 left: window.scrollX,
4357 height: window.innerHeight,
4358 width: window.innerWidth
4359 });
4360}
4361
4362function isDocument$1(node) {
4363 return node === document;
4364}
4365
4366(function (CloseSource) {
4367 CloseSource[CloseSource["Click"] = 0] = "Click";
4368 CloseSource[CloseSource["EscapeKeypress"] = 1] = "EscapeKeypress";
4369 CloseSource[CloseSource["FocusOut"] = 2] = "FocusOut";
4370 CloseSource[CloseSource["ScrollOut"] = 3] = "ScrollOut";
4371})(exports.PopoverCloseSource || (exports.PopoverCloseSource = {}));
4372
4373var TransitionStatus;
4374
4375(function (TransitionStatus) {
4376 TransitionStatus["Entering"] = "entering";
4377 TransitionStatus["Entered"] = "entered";
4378 TransitionStatus["Exiting"] = "exiting";
4379 TransitionStatus["Exited"] = "exited";
4380})(TransitionStatus || (TransitionStatus = {}));
4381
4382var PopoverOverlay =
4383/*#__PURE__*/
4384function (_React$PureComponent) {
4385 _inherits(PopoverOverlay, _React$PureComponent);
4386
4387 function PopoverOverlay() {
4388 var _this;
4389
4390 _classCallCheck(this, PopoverOverlay);
4391
4392 _this = _possibleConstructorReturn(this, _getPrototypeOf(PopoverOverlay).apply(this, arguments));
4393 _this.state = {
4394 transitionStatus: _this.props.active ? TransitionStatus.Entering : TransitionStatus.Exited
4395 };
4396 _this.contentNode = React.createRef();
4397
4398 _this.renderPopover = function (overlayDetails) {
4399 var measuring = overlayDetails.measuring,
4400 desiredHeight = overlayDetails.desiredHeight,
4401 positioning = overlayDetails.positioning;
4402 var _this$props = _this.props,
4403 id = _this$props.id,
4404 children = _this$props.children,
4405 sectioned = _this$props.sectioned,
4406 fullWidth = _this$props.fullWidth,
4407 fullHeight = _this$props.fullHeight,
4408 fluidContent = _this$props.fluidContent;
4409 var className = classNames(styles$a.Popover, positioning === 'above' && styles$a.positionedAbove, fullWidth && styles$a.fullWidth, measuring && styles$a.measuring);
4410 var contentStyles = measuring ? undefined : {
4411 height: desiredHeight
4412 };
4413 var contentClassNames = classNames(styles$a.Content, fullHeight && styles$a['Content-fullHeight'], fluidContent && styles$a['Content-fluidContent']);
4414 var content = React__default.createElement("div", {
4415 id: id,
4416 tabIndex: -1,
4417 className: contentClassNames,
4418 style: contentStyles,
4419 ref: _this.contentNode
4420 }, renderPopoverContent(children, {
4421 sectioned
4422 }));
4423 return React__default.createElement("div", Object.assign({
4424 className: className
4425 }, overlay.props), React__default.createElement(EventListener, {
4426 event: "click",
4427 handler: _this.handleClick
4428 }), React__default.createElement(EventListener, {
4429 event: "touchstart",
4430 handler: _this.handleClick
4431 }), React__default.createElement(KeypressListener, {
4432 keyCode: exports.Key.Escape,
4433 handler: _this.handleEscape
4434 }), React__default.createElement("div", {
4435 className: styles$a.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
4436 ,
4437 tabIndex: 0,
4438 onFocus: _this.handleFocusFirstItem
4439 }), React__default.createElement("div", {
4440 className: styles$a.Wrapper
4441 }, content), React__default.createElement("div", {
4442 className: styles$a.FocusTracker // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
4443 ,
4444 tabIndex: 0,
4445 onFocus: _this.handleFocusLastItem
4446 }));
4447 };
4448
4449 _this.handleClick = function (event) {
4450 var target = event.target;
4451
4452 var _assertThisInitialize = _assertThisInitialized(_this),
4453 contentNode = _assertThisInitialize.contentNode,
4454 _assertThisInitialize2 = _assertThisInitialize.props,
4455 activator = _assertThisInitialize2.activator,
4456 onClose = _assertThisInitialize2.onClose;
4457
4458 var isDescendant = contentNode.current != null && dom.nodeContainsDescendant(contentNode.current, target);
4459 var isActivatorDescendant = dom.nodeContainsDescendant(activator, target);
4460
4461 if (isDescendant || isActivatorDescendant || _this.state.transitionStatus !== TransitionStatus.Entered) {
4462 return;
4463 }
4464
4465 onClose(exports.PopoverCloseSource.Click);
4466 };
4467
4468 _this.handleScrollOut = function () {
4469 _this.props.onClose(exports.PopoverCloseSource.ScrollOut);
4470 };
4471
4472 _this.handleEscape = function () {
4473 _this.props.onClose(exports.PopoverCloseSource.EscapeKeypress);
4474 };
4475
4476 _this.handleFocusFirstItem = function () {
4477 _this.props.onClose(exports.PopoverCloseSource.FocusOut);
4478 };
4479
4480 _this.handleFocusLastItem = function () {
4481 _this.props.onClose(exports.PopoverCloseSource.FocusOut);
4482 };
4483
4484 return _this;
4485 }
4486
4487 _createClass(PopoverOverlay, [{
4488 key: "changeTransitionStatus",
4489 value: function changeTransitionStatus(transitionStatus, cb) {
4490 this.setState({
4491 transitionStatus
4492 }, cb); // Forcing a reflow to enable the animation
4493
4494 this.contentNode.current && this.contentNode.current.getBoundingClientRect();
4495 }
4496 }, {
4497 key: "componentDidMount",
4498 value: function componentDidMount() {
4499 if (this.props.active) {
4500 this.focusContent();
4501 this.changeTransitionStatus(TransitionStatus.Entered);
4502 }
4503 }
4504 }, {
4505 key: "componentDidUpdate",
4506 value: function componentDidUpdate(oldProps) {
4507 var _this2 = this;
4508
4509 if (this.props.active && !oldProps.active) {
4510 this.focusContent();
4511 this.changeTransitionStatus(TransitionStatus.Entering, function () {
4512 _this2.clearTransitionTimeout();
4513
4514 _this2.enteringTimer = window.setTimeout(function () {
4515 _this2.setState({
4516 transitionStatus: TransitionStatus.Entered
4517 });
4518 }, tokens.durationBase);
4519 });
4520 }
4521
4522 if (!this.props.active && oldProps.active) {
4523 this.changeTransitionStatus(TransitionStatus.Exiting, function () {
4524 _this2.clearTransitionTimeout();
4525
4526 _this2.exitingTimer = window.setTimeout(function () {
4527 _this2.setState({
4528 transitionStatus: TransitionStatus.Exited
4529 });
4530 }, tokens.durationBase);
4531 });
4532 }
4533 }
4534 }, {
4535 key: "componentWillUnmount",
4536 value: function componentWillUnmount() {
4537 this.clearTransitionTimeout();
4538 }
4539 }, {
4540 key: "render",
4541 value: function render() {
4542 var _this$props2 = this.props,
4543 active = _this$props2.active,
4544 activator = _this$props2.activator,
4545 fullWidth = _this$props2.fullWidth,
4546 _this$props2$preferre = _this$props2.preferredPosition,
4547 preferredPosition = _this$props2$preferre === void 0 ? 'below' : _this$props2$preferre,
4548 _this$props2$preferre2 = _this$props2.preferredAlignment,
4549 preferredAlignment = _this$props2$preferre2 === void 0 ? 'center' : _this$props2$preferre2,
4550 fixed = _this$props2.fixed;
4551 var transitionStatus = this.state.transitionStatus;
4552 if (transitionStatus === TransitionStatus.Exited && !active) return null;
4553 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']);
4554 return React__default.createElement(PositionedOverlay, {
4555 fullWidth: fullWidth,
4556 active: active,
4557 activator: activator,
4558 preferredPosition: preferredPosition,
4559 preferredAlignment: preferredAlignment,
4560 render: this.renderPopover.bind(this),
4561 fixed: fixed,
4562 onScrollOut: this.handleScrollOut,
4563 classNames: className
4564 });
4565 }
4566 }, {
4567 key: "clearTransitionTimeout",
4568 value: function clearTransitionTimeout() {
4569 if (this.enteringTimer) {
4570 window.clearTimeout(this.enteringTimer);
4571 }
4572
4573 if (this.exitingTimer) {
4574 window.clearTimeout(this.exitingTimer);
4575 }
4576 }
4577 }, {
4578 key: "focusContent",
4579 value: function focusContent() {
4580 var _this3 = this;
4581
4582 if (this.props.preventAutofocus) {
4583 return;
4584 }
4585
4586 if (this.contentNode == null) {
4587 return;
4588 }
4589
4590 fastdom.write(function () {
4591 if (_this3.contentNode.current == null) {
4592 return;
4593 }
4594
4595 _this3.contentNode.current.focus({
4596 preventScroll: process.env.NODE_ENV === 'development'
4597 });
4598 });
4599 }
4600 }]);
4601
4602 return PopoverOverlay;
4603}(React__default.PureComponent);
4604
4605function renderPopoverContent(children, props) {
4606 var childrenArray = React__default.Children.toArray(children);
4607
4608 if (isElementOfType(childrenArray[0], Pane)) {
4609 return childrenArray;
4610 }
4611
4612 return wrapWithComponent(childrenArray, Pane, props);
4613}
4614
4615function setActivatorAttributes(activator, _ref) {
4616 var id = _ref.id,
4617 active = _ref.active,
4618 ariaHaspopup = _ref.ariaHaspopup;
4619 activator.tabIndex = activator.tabIndex || 0;
4620 activator.setAttribute('aria-controls', id);
4621 activator.setAttribute('aria-owns', id);
4622 activator.setAttribute('aria-expanded', String(active));
4623
4624 if (ariaHaspopup != null) {
4625 activator.setAttribute('aria-haspopup', String(ariaHaspopup));
4626 }
4627}
4628
4629// subcomponents so explicitly state the subcomponents in the type definition.
4630// Letting this be implicit works in this project but fails in projects that use
4631// generated *.d.ts files.
4632
4633var Popover = function Popover(_a) {
4634 var _a$activatorWrapper = _a.activatorWrapper,
4635 activatorWrapper = _a$activatorWrapper === void 0 ? 'div' : _a$activatorWrapper,
4636 children = _a.children,
4637 onClose = _a.onClose,
4638 activator = _a.activator,
4639 active = _a.active,
4640 fixed = _a.fixed,
4641 ariaHaspopup = _a.ariaHaspopup,
4642 rest = tslib_1.__rest(_a, ["activatorWrapper", "children", "onClose", "activator", "active", "fixed", "ariaHaspopup"]);
4643
4644 var _useState = React.useState(),
4645 _useState2 = _slicedToArray(_useState, 2),
4646 activatorNode = _useState2[0],
4647 setActivatorNode = _useState2[1];
4648
4649 var activatorContainer = React.useRef(null);
4650 var WrapperComponent = activatorWrapper;
4651 var id = useUniqueId('popover');
4652 var setAccessibilityAttributes = React.useCallback(function () {
4653 if (activatorContainer.current == null) {
4654 return;
4655 }
4656
4657 var firstFocusable = focus.findFirstFocusableNode(activatorContainer.current);
4658 var focusableActivator = firstFocusable || activatorContainer.current;
4659 setActivatorAttributes(focusableActivator, {
4660 id,
4661 active,
4662 ariaHaspopup
4663 });
4664 }, [active, ariaHaspopup, id]);
4665
4666 var handleClose = function handleClose(source) {
4667 onClose(source);
4668
4669 if (activatorContainer.current == null) {
4670 return;
4671 }
4672
4673 if ((source === exports.PopoverCloseSource.FocusOut || source === exports.PopoverCloseSource.EscapeKeypress) && activatorNode) {
4674 var focusableActivator = focus.findFirstFocusableNode(activatorNode) || focus.findFirstFocusableNode(activatorContainer.current) || activatorContainer.current;
4675
4676 if (!focusNextFocusableNode(focusableActivator, isInPortal)) {
4677 focusableActivator.focus();
4678 }
4679 }
4680 };
4681
4682 React.useEffect(function () {
4683 if (!activatorNode && activatorContainer.current) {
4684 setActivatorNode(activatorContainer.current.firstElementChild);
4685 } else if (activatorNode && activatorContainer.current && !activatorContainer.current.contains(activatorNode)) {
4686 setActivatorNode(activatorContainer.current.firstElementChild);
4687 }
4688
4689 setAccessibilityAttributes();
4690 }, [activatorNode, setAccessibilityAttributes]);
4691 React.useEffect(function () {
4692 if (activatorNode && activatorContainer.current) {
4693 setActivatorNode(activatorContainer.current.firstElementChild);
4694 }
4695
4696 setAccessibilityAttributes();
4697 }, [activatorNode, setAccessibilityAttributes]);
4698 var portal = activatorNode ? React__default.createElement(Portal, {
4699 idPrefix: "popover"
4700 }, React__default.createElement(PopoverOverlay, Object.assign({
4701 id: id,
4702 activator: activatorNode,
4703 onClose: handleClose,
4704 active: active,
4705 fixed: fixed
4706 }, rest), children)) : null;
4707 return React__default.createElement(WrapperComponent, {
4708 ref: activatorContainer
4709 }, React__default.Children.only(activator), portal);
4710};
4711
4712function isInPortal(element) {
4713 var parentElement = element.parentElement;
4714
4715 while (parentElement) {
4716 if (parentElement.matches(portal.selector)) return false;
4717 parentElement = parentElement.parentElement;
4718 }
4719
4720 return true;
4721}
4722
4723Popover.Pane = Pane;
4724Popover.Section = Section$1;
4725
4726var styles$c = {
4727 "Stack": "Polaris-Stack",
4728 "Item": "Polaris-Stack__Item",
4729 "noWrap": "Polaris-Stack--noWrap",
4730 "spacingNone": "Polaris-Stack--spacingNone",
4731 "spacingExtraTight": "Polaris-Stack--spacingExtraTight",
4732 "spacingTight": "Polaris-Stack--spacingTight",
4733 "spacingLoose": "Polaris-Stack--spacingLoose",
4734 "spacingExtraLoose": "Polaris-Stack--spacingExtraLoose",
4735 "distributionLeading": "Polaris-Stack--distributionLeading",
4736 "distributionTrailing": "Polaris-Stack--distributionTrailing",
4737 "distributionCenter": "Polaris-Stack--distributionCenter",
4738 "distributionEqualSpacing": "Polaris-Stack--distributionEqualSpacing",
4739 "distributionFill": "Polaris-Stack--distributionFill",
4740 "distributionFillEvenly": "Polaris-Stack--distributionFillEvenly",
4741 "alignmentLeading": "Polaris-Stack--alignmentLeading",
4742 "alignmentTrailing": "Polaris-Stack--alignmentTrailing",
4743 "alignmentCenter": "Polaris-Stack--alignmentCenter",
4744 "alignmentFill": "Polaris-Stack--alignmentFill",
4745 "alignmentBaseline": "Polaris-Stack--alignmentBaseline",
4746 "vertical": "Polaris-Stack--vertical",
4747 "Item-fill": "Polaris-Stack__Item--fill"
4748};
4749
4750function Item$2(_ref) {
4751 var children = _ref.children,
4752 fill = _ref.fill;
4753 var className = classNames(styles$c.Item, fill && styles$c['Item-fill']);
4754 return React__default.createElement("div", {
4755 className: className
4756 }, children);
4757}
4758
4759var Stack =
4760/*#__PURE__*/
4761function (_React$PureComponent) {
4762 _inherits(Stack, _React$PureComponent);
4763
4764 function Stack() {
4765 _classCallCheck(this, Stack);
4766
4767 return _possibleConstructorReturn(this, _getPrototypeOf(Stack).apply(this, arguments));
4768 }
4769
4770 _createClass(Stack, [{
4771 key: "render",
4772 value: function render() {
4773 var _this$props = this.props,
4774 children = _this$props.children,
4775 vertical = _this$props.vertical,
4776 spacing = _this$props.spacing,
4777 distribution = _this$props.distribution,
4778 alignment = _this$props.alignment,
4779 wrap = _this$props.wrap;
4780 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);
4781 var itemMarkup = elementChildren(children).map(function (child, index) {
4782 var props = {
4783 key: index
4784 };
4785 return wrapWithComponent(child, Item$2, props);
4786 });
4787 return React__default.createElement("div", {
4788 className: className
4789 }, itemMarkup);
4790 }
4791 }]);
4792
4793 return Stack;
4794}(React__default.PureComponent);
4795Stack.Item = Item$2;
4796
4797var styles$d = {
4798 "Heading": "Polaris-Heading"
4799};
4800
4801function Heading(_ref) {
4802 var _ref$element = _ref.element,
4803 Element = _ref$element === void 0 ? 'h2' : _ref$element,
4804 children = _ref.children;
4805 return React__default.createElement(Element, {
4806 className: styles$d.Heading
4807 }, children);
4808}
4809
4810var styles$e = {
4811 "Card": "Polaris-Card",
4812 "subdued": "Polaris-Card--subdued",
4813 "Header": "Polaris-Card__Header",
4814 "Section": "Polaris-Card__Section",
4815 "Section-fullWidth": "Polaris-Card__Section--fullWidth",
4816 "Section-subdued": "Polaris-Card__Section--subdued",
4817 "SectionHeader": "Polaris-Card__SectionHeader",
4818 "Subsection": "Polaris-Card__Subsection",
4819 "Footer": "Polaris-Card__Footer",
4820 "LeftJustified": "Polaris-Card__LeftJustified"
4821};
4822
4823function Header(_ref) {
4824 var children = _ref.children,
4825 title = _ref.title,
4826 actions = _ref.actions;
4827 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
4828 plain: true
4829 })) : null;
4830 var titleMarkup = React__default.isValidElement(title) ? title : React__default.createElement(Heading, null, title);
4831 var headingMarkup = actionMarkup || children ? React__default.createElement(Stack, {
4832 alignment: "baseline"
4833 }, React__default.createElement(Stack.Item, {
4834 fill: true
4835 }, titleMarkup), actionMarkup, children) : titleMarkup;
4836 return React__default.createElement("div", {
4837 className: styles$e.Header
4838 }, headingMarkup);
4839}
4840
4841var styles$f = {
4842 "Subheading": "Polaris-Subheading"
4843};
4844
4845function Subheading(_ref) {
4846 var _ref$element = _ref.element,
4847 Element = _ref$element === void 0 ? 'h3' : _ref$element,
4848 children = _ref.children;
4849 var ariaLabel = typeof children === 'string' ? children : undefined;
4850 return React__default.createElement(Element, {
4851 "aria-label": ariaLabel,
4852 className: styles$f.Subheading
4853 }, children);
4854}
4855
4856function Section$2(_ref) {
4857 var children = _ref.children,
4858 title = _ref.title,
4859 subdued = _ref.subdued,
4860 fullWidth = _ref.fullWidth,
4861 actions = _ref.actions;
4862 var className = classNames(styles$e.Section, subdued && styles$e['Section-subdued'], fullWidth && styles$e['Section-fullWidth']);
4863 var actionMarkup = actions ? React__default.createElement(ButtonGroup, null, buttonsFrom(actions, {
4864 plain: true
4865 })) : null;
4866 var titleMarkup = typeof title === 'string' ? React__default.createElement(Subheading, null, title) : title;
4867 var titleAreaMarkup = titleMarkup || actionMarkup ? React__default.createElement("div", {
4868 className: styles$e.SectionHeader
4869 }, actionMarkup ? React__default.createElement(Stack, {
4870 alignment: "baseline"
4871 }, React__default.createElement(Stack.Item, {
4872 fill: true
4873 }, titleMarkup), actionMarkup) : titleMarkup) : null;
4874 return React__default.createElement("div", {
4875 className: className
4876 }, titleAreaMarkup, children);
4877}
4878
4879function Subsection(_ref) {
4880 var children = _ref.children;
4881 return React__default.createElement("div", {
4882 className: styles$e.Subsection
4883 }, children);
4884}
4885
4886// subcomponents so explicitly state the subcomponents in the type definition.
4887// Letting this be implicit works in this project but fails in projects that use
4888// generated *.d.ts files.
4889
4890var Card = function Card(_ref) {
4891 var children = _ref.children,
4892 title = _ref.title,
4893 subdued = _ref.subdued,
4894 sectioned = _ref.sectioned,
4895 actions = _ref.actions,
4896 primaryFooterAction = _ref.primaryFooterAction,
4897 secondaryFooterActions = _ref.secondaryFooterActions,
4898 secondaryFooterActionsDisclosureText = _ref.secondaryFooterActionsDisclosureText,
4899 _ref$footerActionAlig = _ref.footerActionAlignment,
4900 footerActionAlignment = _ref$footerActionAlig === void 0 ? 'right' : _ref$footerActionAlig;
4901 var i18n = useI18n();
4902
4903 var _useToggle = useToggle(false),
4904 _useToggle2 = _slicedToArray(_useToggle, 2),
4905 secondaryActionsPopoverOpen = _useToggle2[0],
4906 toggleSecondaryActionsPopoverOpen = _useToggle2[1];
4907
4908 var className = classNames(styles$e.Card, subdued && styles$e.subdued);
4909 var headerMarkup = title || actions ? React__default.createElement(Header, {
4910 actions: actions,
4911 title: title
4912 }) : null;
4913 var content = sectioned ? React__default.createElement(Section$2, null, children) : children;
4914 var primaryFooterActionMarkup = primaryFooterAction ? buttonFrom(primaryFooterAction, {
4915 primary: true
4916 }) : null;
4917 var secondaryFooterActionsMarkup = null;
4918
4919 if (secondaryFooterActions && secondaryFooterActions.length) {
4920 if (secondaryFooterActions.length === 1) {
4921 secondaryFooterActionsMarkup = buttonFrom(secondaryFooterActions[0]);
4922 } else {
4923 secondaryFooterActionsMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(Popover, {
4924 active: secondaryActionsPopoverOpen,
4925 activator: React__default.createElement(Button, {
4926 disclosure: true,
4927 onClick: toggleSecondaryActionsPopoverOpen
4928 }, secondaryFooterActionsDisclosureText || i18n.translate('Polaris.Common.more')),
4929 onClose: toggleSecondaryActionsPopoverOpen
4930 }, React__default.createElement(ActionList, {
4931 items: secondaryFooterActions
4932 })));
4933 }
4934 }
4935
4936 var footerMarkup = primaryFooterActionMarkup || secondaryFooterActionsMarkup ? React__default.createElement("div", {
4937 className: classNames(styles$e.Footer, footerActionAlignment === 'left' && styles$e.LeftJustified)
4938 }, footerActionAlignment === 'right' ? React__default.createElement(ButtonGroup, null, secondaryFooterActionsMarkup, primaryFooterActionMarkup) : React__default.createElement(ButtonGroup, null, primaryFooterActionMarkup, secondaryFooterActionsMarkup)) : null;
4939 return React__default.createElement(WithinContentContext.Provider, {
4940 value: true
4941 }, React__default.createElement("div", {
4942 className: className
4943 }, headerMarkup, content, footerMarkup));
4944};
4945Card.Header = Header;
4946Card.Section = Section$2;
4947Card.Subsection = Subsection;
4948
4949var styles$g = {
4950 "SettingAction": "Polaris-SettingAction",
4951 "Setting": "Polaris-SettingAction__Setting",
4952 "Action": "Polaris-SettingAction__Action"
4953};
4954
4955function SettingAction(_ref) {
4956 var action = _ref.action,
4957 children = _ref.children;
4958 return React__default.createElement("div", {
4959 className: styles$g.SettingAction
4960 }, React__default.createElement("div", {
4961 className: styles$g.Setting
4962 }, children), React__default.createElement("div", {
4963 className: styles$g.Action
4964 }, action));
4965}
4966
4967var styles$h = {
4968 "TermsOfService": "Polaris-AccountConnection__TermsOfService",
4969 "Content": "Polaris-AccountConnection__Content"
4970};
4971
4972function AccountConnection(_ref) {
4973 var _ref$connected = _ref.connected,
4974 connected = _ref$connected === void 0 ? false : _ref$connected,
4975 action = _ref.action,
4976 avatarUrl = _ref.avatarUrl,
4977 _ref$accountName = _ref.accountName,
4978 accountName = _ref$accountName === void 0 ? '' : _ref$accountName,
4979 title = _ref.title,
4980 details = _ref.details,
4981 termsOfService = _ref.termsOfService;
4982 var initials = accountName ? accountName.split(/\s+/).map(function (name) {
4983 return name[0];
4984 }).join('') : undefined;
4985 var avatarMarkup = connected ? React__default.createElement(Avatar, {
4986 accessibilityLabel: "",
4987 name: accountName,
4988 initials: initials,
4989 source: avatarUrl
4990 }) : null;
4991 var titleMarkup = null;
4992
4993 if (title) {
4994 titleMarkup = React__default.createElement("div", null, title);
4995 } else if (accountName) {
4996 titleMarkup = React__default.createElement("div", null, accountName);
4997 }
4998
4999 var detailsMarkup = details ? React__default.createElement("div", null, React__default.createElement(TextStyle, {
5000 variation: "subdued"
5001 }, details)) : null;
5002 var termsOfServiceMarkup = termsOfService ? React__default.createElement("div", {
5003 className: styles$h.TermsOfService
5004 }, termsOfService) : null;
5005 var actionElement = action ? buttonFrom(action, {
5006 primary: !connected
5007 }) : null;
5008 return React__default.createElement(Card, {
5009 sectioned: true
5010 }, React__default.createElement(SettingAction, {
5011 action: actionElement
5012 }, React__default.createElement(Stack, null, avatarMarkup, React__default.createElement(Stack.Item, {
5013 fill: true
5014 }, React__default.createElement("div", {
5015 className: styles$h.Content
5016 }, titleMarkup, detailsMarkup)))), termsOfServiceMarkup);
5017}
5018
5019var styles$i = {
5020 "MenuAction": "Polaris-ActionMenu-MenuAction",
5021 "IconWrapper": "Polaris-ActionMenu-MenuAction__IconWrapper",
5022 "disabled": "Polaris-ActionMenu-MenuAction--disabled",
5023 "ContentWrapper": "Polaris-ActionMenu-MenuAction__ContentWrapper"
5024};
5025
5026function MenuAction(_ref) {
5027 var content = _ref.content,
5028 accessibilityLabel = _ref.accessibilityLabel,
5029 url = _ref.url,
5030 external = _ref.external,
5031 icon = _ref.icon,
5032 disclosure = _ref.disclosure,
5033 disabled = _ref.disabled,
5034 onAction = _ref.onAction;
5035 var iconMarkup = icon && React__default.createElement("span", {
5036 className: styles$i.IconWrapper
5037 }, React__default.createElement(Icon, {
5038 source: icon
5039 }));
5040 var disclosureIconMarkup = disclosure && React__default.createElement("span", {
5041 className: styles$i.IconWrapper
5042 }, React__default.createElement(Icon, {
5043 source: polarisIcons.CaretDownMinor
5044 }));
5045 var contentMarkup = iconMarkup || disclosureIconMarkup ? React__default.createElement("span", {
5046 className: styles$i.ContentWrapper
5047 }, iconMarkup, React__default.createElement("span", {
5048 className: styles$i.Content
5049 }, content), disclosureIconMarkup) : content;
5050 var menuActionClassNames = classNames(styles$i.MenuAction, disabled && styles$i.disabled);
5051
5052 if (url) {
5053 return React__default.createElement(UnstyledLink, {
5054 className: menuActionClassNames,
5055 url: url,
5056 external: external,
5057 "aria-label": accessibilityLabel,
5058 onMouseUp: handleMouseUpByBlurring
5059 }, contentMarkup);
5060 }
5061
5062 return React__default.createElement("button", {
5063 type: "button",
5064 className: menuActionClassNames,
5065 disabled: disabled,
5066 "aria-label": accessibilityLabel,
5067 onClick: onAction,
5068 onMouseUp: handleMouseUpByBlurring
5069 }, contentMarkup);
5070}
5071
5072var styles$j = {
5073 "Details": "Polaris-ActionMenu-MenuGroup__Details"
5074};
5075
5076var MenuGroup =
5077/*#__PURE__*/
5078function (_React$Component) {
5079 _inherits(MenuGroup, _React$Component);
5080
5081 function MenuGroup() {
5082 var _this;
5083
5084 _classCallCheck(this, MenuGroup);
5085
5086 _this = _possibleConstructorReturn(this, _getPrototypeOf(MenuGroup).apply(this, arguments));
5087
5088 _this.handleClose = function () {
5089 var _this$props = _this.props,
5090 title = _this$props.title,
5091 onClose = _this$props.onClose;
5092 onClose(title);
5093 };
5094
5095 _this.handleOpen = function () {
5096 var _this$props2 = _this.props,
5097 title = _this$props2.title,
5098 onOpen = _this$props2.onOpen;
5099 onOpen(title);
5100 };
5101
5102 return _this;
5103 }
5104
5105 _createClass(MenuGroup, [{
5106 key: "render",
5107 value: function render() {
5108 var _this$props3 = this.props,
5109 accessibilityLabel = _this$props3.accessibilityLabel,
5110 active = _this$props3.active,
5111 actions = _this$props3.actions,
5112 details = _this$props3.details,
5113 title = _this$props3.title,
5114 icon = _this$props3.icon;
5115
5116 if (!actions.length) {
5117 return null;
5118 }
5119
5120 var popoverActivator = React__default.createElement(MenuAction, {
5121 disclosure: true,
5122 content: title,
5123 icon: icon,
5124 accessibilityLabel: accessibilityLabel,
5125 onAction: this.handleOpen
5126 });
5127 return React__default.createElement(Popover, {
5128 active: Boolean(active),
5129 activator: popoverActivator,
5130 preferredAlignment: "left",
5131 onClose: this.handleClose
5132 }, React__default.createElement(ActionList, {
5133 items: actions,
5134 onActionAnyItem: this.handleClose
5135 }), details && React__default.createElement("div", {
5136 className: styles$j.Details
5137 }, details));
5138 }
5139 }]);
5140
5141 return MenuGroup;
5142}(React__default.Component);
5143
5144var styles$k = {
5145 "RollupActivator": "Polaris-ActionMenu-RollupActions__RollupActivator"
5146};
5147
5148function RollupActions(_ref) {
5149 var _ref$items = _ref.items,
5150 items = _ref$items === void 0 ? [] : _ref$items,
5151 _ref$sections = _ref.sections,
5152 sections = _ref$sections === void 0 ? [] : _ref$sections;
5153 var i18n = useI18n();
5154
5155 var _useToggle = useToggle(false),
5156 _useToggle2 = _slicedToArray(_useToggle, 2),
5157 rollupOpen = _useToggle2[0],
5158 toggleRollupOpen = _useToggle2[1];
5159
5160 if (items.length === 0 && sections.length === 0) {
5161 return null;
5162 }
5163
5164 var activatorMarkup = React__default.createElement("div", {
5165 className: styles$k.RollupActivator
5166 }, React__default.createElement(Button, {
5167 plain: true,
5168 icon: polarisIcons.HorizontalDotsMinor,
5169 accessibilityLabel: i18n.translate('Polaris.ActionMenu.RollupActions.rollupButton'),
5170 onClick: toggleRollupOpen
5171 }));
5172 return React__default.createElement(Popover, {
5173 active: rollupOpen,
5174 activator: activatorMarkup,
5175 preferredAlignment: "right",
5176 onClose: toggleRollupOpen
5177 }, React__default.createElement(ActionList, {
5178 items: items,
5179 sections: sections,
5180 onActionAnyItem: toggleRollupOpen
5181 }));
5182}
5183
5184var styles$l = {
5185 "ActionMenu": "Polaris-ActionMenu",
5186 "rollup": "Polaris-ActionMenu--rollup",
5187 "ActionsLayout": "Polaris-ActionMenu__ActionsLayout"
5188};
5189
5190var ActionMenu =
5191/*#__PURE__*/
5192function (_React$PureComponent) {
5193 _inherits(ActionMenu, _React$PureComponent);
5194
5195 function ActionMenu() {
5196 var _this;
5197
5198 _classCallCheck(this, ActionMenu);
5199
5200 _this = _possibleConstructorReturn(this, _getPrototypeOf(ActionMenu).apply(this, arguments));
5201 _this.state = {
5202 activeMenuGroup: undefined
5203 };
5204
5205 _this.renderActions = function () {
5206 var _this$props = _this.props,
5207 _this$props$actions = _this$props.actions,
5208 actions = _this$props$actions === void 0 ? [] : _this$props$actions,
5209 _this$props$groups = _this$props.groups,
5210 groups = _this$props$groups === void 0 ? [] : _this$props$groups;
5211 var activeMenuGroup = _this.state.activeMenuGroup;
5212 var actionsMarkup = actions.length > 0 ? actions.map(function (_a, index) {
5213 var content = _a.content,
5214 action = tslib_1.__rest(_a, ["content"]);
5215
5216 return React__default.createElement(MenuAction, Object.assign({
5217 key: "MenuAction-".concat(content || index),
5218 content: content
5219 }, action));
5220 }) : null;
5221 var groupsMarkup = hasGroupsWithActions(groups) ? groups.map(function (_a, index) {
5222 var title = _a.title,
5223 rest = tslib_1.__rest(_a, ["title"]);
5224
5225 return React__default.createElement(MenuGroup, Object.assign({
5226 key: "MenuGroup-".concat(title || index),
5227 title: title,
5228 active: title === activeMenuGroup
5229 }, rest, {
5230 onOpen: _this.handleMenuGroupToggle,
5231 onClose: _this.handleMenuGroupClose
5232 }));
5233 }) : null;
5234 return actionsMarkup || groupsMarkup ? React__default.createElement("div", {
5235 className: styles$l.ActionsLayout
5236 }, actionsMarkup, groupsMarkup) : null;
5237 };
5238
5239 _this.handleMenuGroupToggle = function (group) {
5240 _this.setState(function (_ref) {
5241 var activeMenuGroup = _ref.activeMenuGroup;
5242 return {
5243 activeMenuGroup: activeMenuGroup ? undefined : group
5244 };
5245 });
5246 };
5247
5248 _this.handleMenuGroupClose = function () {
5249 _this.setState({
5250 activeMenuGroup: undefined
5251 });
5252 };
5253
5254 return _this;
5255 }
5256
5257 _createClass(ActionMenu, [{
5258 key: "render",
5259 value: function render() {
5260 var _this$props2 = this.props,
5261 _this$props2$actions = _this$props2.actions,
5262 actions = _this$props2$actions === void 0 ? [] : _this$props2$actions,
5263 _this$props2$groups = _this$props2.groups,
5264 groups = _this$props2$groups === void 0 ? [] : _this$props2$groups,
5265 rollup = _this$props2.rollup;
5266
5267 if (actions.length === 0 && groups.length === 0) {
5268 return null;
5269 }
5270
5271 var actionMenuClassNames = classNames(styles$l.ActionMenu, rollup && styles$l.rollup);
5272 var rollupSections = groups.map(function (group) {
5273 return convertGroupToSection(group);
5274 });
5275 return React__default.createElement("div", {
5276 className: actionMenuClassNames
5277 }, rollup ? React__default.createElement(RollupActions, {
5278 items: actions,
5279 sections: rollupSections
5280 }) : this.renderActions());
5281 }
5282 }]);
5283
5284 return ActionMenu;
5285}(React__default.PureComponent);
5286function hasGroupsWithActions() {
5287 var groups = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
5288 return groups.length === 0 ? false : groups.some(function (group) {
5289 return group.actions.length > 0;
5290 });
5291}
5292function convertGroupToSection(_ref2) {
5293 var title = _ref2.title,
5294 actions = _ref2.actions;
5295 return {
5296 title,
5297 items: actions
5298 };
5299}
5300
5301function ThemeProvider(_ref) {
5302 var themeConfig = _ref.theme,
5303 children = _ref.children;
5304
5305 var _useFeatures = useFeatures(),
5306 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
5307 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
5308
5309 var customProperties = React.useMemo(function () {
5310 return buildCustomProperties(themeConfig, unstableGlobalTheming);
5311 }, [unstableGlobalTheming, themeConfig]);
5312 var theme = React.useMemo(function () {
5313 return buildThemeContext(themeConfig, unstableGlobalTheming ? customProperties : undefined);
5314 }, [customProperties, themeConfig, unstableGlobalTheming]); // We want these values to be `null` instead of `undefined` when not set.
5315 // Otherwise, setting a style property to `undefined` does not remove it from the DOM.
5316
5317 var backgroundColor = customProperties['--p-surface-background'] || null;
5318 var color = customProperties['--p-text-on-surface'] || null;
5319 React.useEffect(function () {
5320 document.body.style.backgroundColor = backgroundColor;
5321 document.body.style.color = color;
5322 }, [backgroundColor, color]);
5323 return React__default.createElement(ThemeContext.Provider, {
5324 value: theme
5325 }, React__default.createElement("div", {
5326 style: customProperties
5327 }, children));
5328}
5329
5330var MediaQueryContext = React__default.createContext(undefined);
5331
5332function useMediaQuery() {
5333 var mediaQuery = React.useContext(MediaQueryContext);
5334
5335 if (!mediaQuery) {
5336 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.');
5337 }
5338
5339 return mediaQuery;
5340}
5341
5342var MediaQueryProvider = function MediaQueryProvider(_ref) {
5343 var children = _ref.children;
5344
5345 var _useState = React.useState(navigationBarCollapsed().matches),
5346 _useState2 = _slicedToArray(_useState, 2),
5347 isNavigationCollapsed = _useState2[0],
5348 setIsNavigationCollapsed = _useState2[1];
5349
5350 var handleResize = React.useCallback(debounce(function () {
5351 if (isNavigationCollapsed !== navigationBarCollapsed().matches) {
5352 setIsNavigationCollapsed(!isNavigationCollapsed);
5353 }
5354 }, 40, {
5355 trailing: true,
5356 leading: true,
5357 maxWait: 40
5358 }), [isNavigationCollapsed]);
5359 React.useEffect(function () {
5360 setIsNavigationCollapsed(navigationBarCollapsed().matches);
5361 }, []);
5362 return React__default.createElement(MediaQueryContext.Provider, {
5363 value: {
5364 isNavigationCollapsed
5365 }
5366 }, React__default.createElement(EventListener, {
5367 event: "resize",
5368 handler: handleResize
5369 }), children);
5370};
5371
5372var ScrollLockManagerContext = React__default.createContext(undefined);
5373
5374function useScrollLockManager() {
5375 var scrollLockManager = React.useContext(ScrollLockManagerContext);
5376
5377 if (!scrollLockManager) {
5378 throw new MissingAppProviderError('No ScrollLockManager was provided.');
5379 }
5380
5381 return scrollLockManager;
5382}
5383
5384var SCROLL_LOCKING_ATTRIBUTE = 'data-lock-scrolling';
5385var SCROLL_LOCKING_WRAPPER_ATTRIBUTE = 'data-lock-scrolling-wrapper';
5386var scrollPosition = 0;
5387var ScrollLockManager =
5388/*#__PURE__*/
5389function () {
5390 function ScrollLockManager() {
5391 _classCallCheck(this, ScrollLockManager);
5392
5393 this.scrollLocks = 0;
5394 this.locked = false;
5395 }
5396
5397 _createClass(ScrollLockManager, [{
5398 key: "registerScrollLock",
5399 value: function registerScrollLock() {
5400 this.scrollLocks += 1;
5401 this.handleScrollLocking();
5402 }
5403 }, {
5404 key: "unregisterScrollLock",
5405 value: function unregisterScrollLock() {
5406 this.scrollLocks -= 1;
5407 this.handleScrollLocking();
5408 }
5409 }, {
5410 key: "handleScrollLocking",
5411 value: function handleScrollLocking() {
5412 if (isServer) return;
5413 var scrollLocks = this.scrollLocks;
5414 var _document = document,
5415 body = _document.body;
5416 var wrapper = body.firstElementChild;
5417
5418 if (scrollLocks === 0) {
5419 body.removeAttribute(SCROLL_LOCKING_ATTRIBUTE);
5420
5421 if (wrapper) {
5422 wrapper.removeAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE);
5423 }
5424
5425 window.scroll(0, scrollPosition);
5426 this.locked = false;
5427 } else if (scrollLocks > 0 && !this.locked) {
5428 scrollPosition = window.pageYOffset;
5429 body.setAttribute(SCROLL_LOCKING_ATTRIBUTE, '');
5430
5431 if (wrapper) {
5432 wrapper.setAttribute(SCROLL_LOCKING_WRAPPER_ATTRIBUTE, '');
5433 wrapper.scrollTop = scrollPosition;
5434 }
5435
5436 this.locked = true;
5437 }
5438 }
5439 }, {
5440 key: "resetScrollPosition",
5441 value: function resetScrollPosition() {
5442 scrollPosition = 0;
5443 }
5444 }]);
5445
5446 return ScrollLockManager;
5447}();
5448
5449var AppBridgeContext = React__default.createContext(undefined);
5450
5451function useAppBridge() {
5452 return React.useContext(AppBridgeContext);
5453}
5454
5455function createAppBridge(_ref) {
5456 var apiKey = _ref.apiKey,
5457 shopOrigin = _ref.shopOrigin,
5458 forceRedirect = _ref.forceRedirect;
5459 var appBridge = apiKey ? createApp__default({
5460 apiKey,
5461 shopOrigin: shopOrigin || createApp.getShopOrigin(),
5462 forceRedirect
5463 }) : undefined;
5464
5465 if (appBridge !== undefined) {
5466 // eslint-disable-next-line no-console
5467 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');
5468 }
5469
5470 if (appBridge && appBridge.hooks) {
5471 appBridge.hooks.set(createApp.LifecycleHook.DispatchAction, setClientInterfaceHook);
5472 }
5473
5474 return appBridge;
5475}
5476var setClientInterfaceHook = function setClientInterfaceHook(next) {
5477 return function (action) {
5478 action.clientInterface = {
5479 name: '@shopify/polaris',
5480 version: polarisVersion
5481 };
5482 return next(action);
5483 };
5484};
5485
5486var AppProvider =
5487/*#__PURE__*/
5488function (_React$Component) {
5489 _inherits(AppProvider, _React$Component);
5490
5491 function AppProvider(props) {
5492 var _this;
5493
5494 _classCallCheck(this, AppProvider);
5495
5496 _this = _possibleConstructorReturn(this, _getPrototypeOf(AppProvider).call(this, props));
5497 _this.stickyManager = new StickyManager();
5498 _this.scrollLockManager = new ScrollLockManager();
5499 _this.uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory);
5500 var _this$props = _this.props,
5501 i18n = _this$props.i18n,
5502 apiKey = _this$props.apiKey,
5503 shopOrigin = _this$props.shopOrigin,
5504 forceRedirect = _this$props.forceRedirect,
5505 linkComponent = _this$props.linkComponent; // eslint-disable-next-line react/state-in-constructor
5506
5507 _this.state = {
5508 link: linkComponent,
5509 intl: new I18n(i18n),
5510 appBridge: createAppBridge({
5511 shopOrigin,
5512 apiKey,
5513 forceRedirect
5514 })
5515 };
5516 return _this;
5517 }
5518
5519 _createClass(AppProvider, [{
5520 key: "componentDidMount",
5521 value: function componentDidMount() {
5522 if (document != null) {
5523 this.stickyManager.setContainer(document);
5524 }
5525 }
5526 }, {
5527 key: "componentDidUpdate",
5528 value: function componentDidUpdate(_ref) {
5529 var prevI18n = _ref.i18n,
5530 prevLinkComponent = _ref.linkComponent,
5531 prevApiKey = _ref.apiKey,
5532 prevShopOrigin = _ref.shopOrigin,
5533 prevForceRedirect = _ref.forceRedirect;
5534 var _this$props2 = this.props,
5535 i18n = _this$props2.i18n,
5536 linkComponent = _this$props2.linkComponent,
5537 apiKey = _this$props2.apiKey,
5538 shopOrigin = _this$props2.shopOrigin,
5539 forceRedirect = _this$props2.forceRedirect;
5540
5541 if (i18n === prevI18n && linkComponent === prevLinkComponent && apiKey === prevApiKey && shopOrigin === prevShopOrigin && forceRedirect === prevForceRedirect) {
5542 return;
5543 } // eslint-disable-next-line react/no-did-update-set-state
5544
5545
5546 this.setState({
5547 link: linkComponent,
5548 intl: new I18n(i18n),
5549 appBridge: createAppBridge({
5550 shopOrigin,
5551 apiKey,
5552 forceRedirect
5553 })
5554 });
5555 }
5556 }, {
5557 key: "render",
5558 value: function render() {
5559 var _this$props3 = this.props,
5560 _this$props3$theme = _this$props3.theme,
5561 theme = _this$props3$theme === void 0 ? {} : _this$props3$theme,
5562 _this$props3$features = _this$props3.features,
5563 features = _this$props3$features === void 0 ? {} : _this$props3$features,
5564 UNSTABLE_telemetry = _this$props3.UNSTABLE_telemetry,
5565 children = _this$props3.children;
5566 var _this$state = this.state,
5567 intl = _this$state.intl,
5568 appBridge = _this$state.appBridge,
5569 link = _this$state.link;
5570 return React__default.createElement(FeaturesContext.Provider, {
5571 value: features
5572 }, React__default.createElement(I18nContext.Provider, {
5573 value: intl
5574 }, React__default.createElement(ScrollLockManagerContext.Provider, {
5575 value: this.scrollLockManager
5576 }, React__default.createElement(StickyManagerContext.Provider, {
5577 value: this.stickyManager
5578 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
5579 value: this.uniqueIdFactory
5580 }, React__default.createElement(AppBridgeContext.Provider, {
5581 value: appBridge
5582 }, React__default.createElement(LinkContext.Provider, {
5583 value: link
5584 }, React__default.createElement(ThemeProvider, {
5585 theme: theme
5586 }, React__default.createElement(TelemetryContext.Provider, {
5587 value: UNSTABLE_telemetry
5588 }, React__default.createElement(MediaQueryProvider, null, children))))))))));
5589 }
5590 }]);
5591
5592 return AppProvider;
5593}(React__default.Component);
5594
5595function arraysAreEqual(firstArray, secondArray, comparator) {
5596 if (firstArray.length !== secondArray.length) {
5597 return false;
5598 }
5599
5600 return firstArray.every(function (firstItem, index) {
5601 var secondItem = secondArray[index];
5602
5603 if (comparator != null) {
5604 return comparator(firstItem, secondItem);
5605 }
5606
5607 return firstItem === secondItem;
5608 });
5609}
5610
5611/**
5612 * Allows for custom or deep comparison of a dependency list. Useful to keep a consistent dependency
5613 * list across reference changes.
5614 * @param dependencies A dependency array similar to React.useEffect/React.useCallback/React.useMemo
5615 * @param comparator An optional function to compare dependencies that'll default to a deep comparison
5616 * @returns A dependency list
5617 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-effect.tsx}
5618 * @see {@link https://github.com/Shopify/polaris-react/blob/master/src/utilities/use-deep-callback.tsx}
5619 * @example
5620 * function useDeepEffectExample(callback, dependencies, customCompare) {
5621 * useEffect(callback, useDeepCompareRef(dependencies, customCompare));
5622 * }
5623 */
5624
5625function useDeepCompareRef(dependencies) {
5626 var comparator = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : isEqual;
5627 var dependencyList = React.useRef(dependencies);
5628
5629 if (!comparator(dependencyList.current, dependencies)) {
5630 dependencyList.current = dependencies;
5631 }
5632
5633 return dependencyList.current;
5634}
5635
5636/**
5637 * A replacement for React.useEffect that'll allow for custom and deep
5638 * compares of the dependency list.
5639 * @see {@link https://reactjs.org/docs/hooks-reference.html#useeffect}
5640 * @param callback Accepts a callback that's forwarded to React.useEffect
5641 * @param dependencies A dependency array similar to React.useEffect however it utilizes a deep compare
5642 * @param customCompare Opportunity to provide a custom compare function
5643 * @example
5644 * function ComponentExample() {
5645 * const [, forceUpdate] = useState();
5646 * const obj = {a: 1};
5647 *
5648 * useDeepEffect(() => {
5649 * console.log('useDeepEffect invocation');
5650 * forceUpdate(obj);
5651 * }, [obj]);
5652 *
5653 * return null;
5654 * }
5655 */
5656
5657function useDeepEffect(callback, dependencies, customCompare) {
5658 React.useEffect(callback, useDeepCompareRef(dependencies, customCompare));
5659}
5660
5661var styles$m = {
5662 "Checkbox": "Polaris-OptionList-Checkbox",
5663 "Input": "Polaris-OptionList-Checkbox__Input",
5664 "Backdrop": "Polaris-OptionList-Checkbox__Backdrop",
5665 "Icon": "Polaris-OptionList-Checkbox__Icon",
5666 "active": "Polaris-OptionList-Checkbox--active"
5667};
5668
5669function Checkbox(_ref) {
5670 var idProp = _ref.id,
5671 _ref$checked = _ref.checked,
5672 checked = _ref$checked === void 0 ? false : _ref$checked,
5673 disabled = _ref.disabled,
5674 active = _ref.active,
5675 onChange = _ref.onChange,
5676 name = _ref.name,
5677 value = _ref.value,
5678 role = _ref.role;
5679 var id = useUniqueId('Checkbox', idProp);
5680 var className = classNames(styles$m.Checkbox, active && styles$m.active);
5681 return React__default.createElement("div", {
5682 className: className
5683 }, React__default.createElement("input", {
5684 id: id,
5685 name: name,
5686 value: value,
5687 type: "checkbox",
5688 checked: checked,
5689 disabled: disabled,
5690 className: styles$m.Input,
5691 "aria-checked": checked,
5692 onChange: onChange,
5693 role: role
5694 }), React__default.createElement("div", {
5695 className: styles$m.Backdrop
5696 }), React__default.createElement("div", {
5697 className: styles$m.Icon
5698 }, React__default.createElement(Icon, {
5699 source: polarisIcons.TickSmallMinor
5700 })));
5701}
5702
5703var styles$n = {
5704 "Option": "Polaris-OptionList-Option",
5705 "SingleSelectOption": "Polaris-OptionList-Option__SingleSelectOption",
5706 "disabled": "Polaris-OptionList-Option--disabled",
5707 "Media": "Polaris-OptionList-Option__Media",
5708 "Label": "Polaris-OptionList-Option__Label",
5709 "Checkbox": "Polaris-OptionList-Option__Checkbox",
5710 "focused": "Polaris-OptionList-Option--focused",
5711 "select": "Polaris-OptionList-Option--select",
5712 "active": "Polaris-OptionList-Option--active"
5713};
5714
5715var Option =
5716/*#__PURE__*/
5717function (_React$Component) {
5718 _inherits(Option, _React$Component);
5719
5720 function Option() {
5721 var _this;
5722
5723 _classCallCheck(this, Option);
5724
5725 _this = _possibleConstructorReturn(this, _getPrototypeOf(Option).apply(this, arguments));
5726 _this.state = {
5727 focused: false
5728 };
5729
5730 _this.handleClick = function () {
5731 var _this$props = _this.props,
5732 onClick = _this$props.onClick,
5733 section = _this$props.section,
5734 index = _this$props.index,
5735 disabled = _this$props.disabled;
5736
5737 if (disabled) {
5738 return;
5739 }
5740
5741 onClick(section, index);
5742 };
5743
5744 _this.toggleFocus = function () {
5745 _this.setState(function (prevState) {
5746 return {
5747 focused: !prevState.focused
5748 };
5749 });
5750 };
5751
5752 return _this;
5753 }
5754
5755 _createClass(Option, [{
5756 key: "render",
5757 value: function render() {
5758 var _this$props2 = this.props,
5759 label = _this$props2.label,
5760 value = _this$props2.value,
5761 id = _this$props2.id,
5762 select = _this$props2.select,
5763 active = _this$props2.active,
5764 allowMultiple = _this$props2.allowMultiple,
5765 disabled = _this$props2.disabled,
5766 role = _this$props2.role,
5767 media = _this$props2.media;
5768 var focused = this.state.focused;
5769 var mediaMarkup = media ? React__default.createElement("div", {
5770 className: styles$n.Media
5771 }, media) : null;
5772 var singleSelectClassName = classNames(styles$n.SingleSelectOption, focused && styles$n.focused, disabled && styles$n.disabled, select && styles$n.select, active && styles$n.active);
5773 var multiSelectClassName = classNames(styles$n.Label, active && styles$n.active);
5774 var checkBoxRole = role === 'option' ? 'presentation' : undefined;
5775 var optionMarkup = allowMultiple ? React__default.createElement("label", {
5776 htmlFor: id,
5777 className: multiSelectClassName
5778 }, React__default.createElement("div", {
5779 className: styles$n.Checkbox
5780 }, React__default.createElement(Checkbox, {
5781 id: id,
5782 value: value,
5783 checked: select,
5784 active: active,
5785 disabled: disabled,
5786 onChange: this.handleClick,
5787 role: checkBoxRole
5788 })), mediaMarkup, label) : React__default.createElement("button", {
5789 id: id,
5790 type: "button",
5791 className: singleSelectClassName,
5792 onClick: this.handleClick,
5793 disabled: disabled,
5794 onFocus: this.toggleFocus,
5795 onBlur: this.toggleFocus
5796 }, mediaMarkup, label);
5797 var scrollMarkup = active ? React__default.createElement(Scrollable.ScrollTo, null) : null;
5798 return React__default.createElement("li", {
5799 key: id,
5800 className: styles$n.Option,
5801 tabIndex: -1,
5802 "aria-selected": active,
5803 role: role
5804 }, scrollMarkup, optionMarkup);
5805 }
5806 }]);
5807
5808 return Option;
5809}(React__default.Component);
5810
5811var styles$o = {
5812 "OptionList": "Polaris-OptionList",
5813 "Options": "Polaris-OptionList__Options",
5814 "Title": "Polaris-OptionList__Title"
5815};
5816
5817function OptionList(_ref) {
5818 var options = _ref.options,
5819 sections = _ref.sections,
5820 title = _ref.title,
5821 selected = _ref.selected,
5822 allowMultiple = _ref.allowMultiple,
5823 role = _ref.role,
5824 optionRole = _ref.optionRole,
5825 onChange = _ref.onChange,
5826 idProp = _ref.id;
5827
5828 var _useState = React.useState(createNormalizedOptions(options, sections, title)),
5829 _useState2 = _slicedToArray(_useState, 2),
5830 normalizedOptions = _useState2[0],
5831 setNormalizedOptions = _useState2[1];
5832
5833 var id = useUniqueId('OptionList', idProp);
5834 useDeepEffect(function () {
5835 setNormalizedOptions(createNormalizedOptions(options || [], sections || [], title));
5836 }, [options, sections, title], optionArraysAreEqual);
5837 var handleClick = React.useCallback(function (sectionIndex, optionIndex) {
5838 var selectedValue = normalizedOptions[sectionIndex].options[optionIndex].value;
5839 var foundIndex = selected.indexOf(selectedValue);
5840
5841 if (allowMultiple) {
5842 var newSelection = foundIndex === -1 ? [selectedValue].concat(_toConsumableArray(selected)) : [].concat(_toConsumableArray(selected.slice(0, foundIndex)), _toConsumableArray(selected.slice(foundIndex + 1, selected.length)));
5843 onChange(newSelection);
5844 return;
5845 }
5846
5847 onChange([selectedValue]);
5848 }, [normalizedOptions, selected, allowMultiple, onChange]);
5849 var optionsExist = normalizedOptions.length > 0;
5850 var optionsMarkup = optionsExist ? normalizedOptions.map(function (_ref2, sectionIndex) {
5851 var title = _ref2.title,
5852 options = _ref2.options;
5853 var titleMarkup = title ? React__default.createElement("p", {
5854 className: styles$o.Title,
5855 role: role
5856 }, title) : null;
5857 var optionsMarkup = options && options.map(function (option, optionIndex) {
5858 var isSelected = selected.includes(option.value);
5859 var optionId = option.id || "".concat(id, "-").concat(sectionIndex, "-").concat(optionIndex);
5860 return React__default.createElement(Option, Object.assign({}, option, {
5861 key: optionId,
5862 id: optionId,
5863 section: sectionIndex,
5864 index: optionIndex,
5865 onClick: handleClick,
5866 select: isSelected,
5867 allowMultiple: allowMultiple,
5868 role: optionRole
5869 }));
5870 });
5871 return React__default.createElement("li", {
5872 key: title || "noTitle-".concat(sectionIndex)
5873 }, titleMarkup, React__default.createElement("ul", {
5874 className: styles$o.Options,
5875 id: "".concat(id, "-").concat(sectionIndex),
5876 role: role,
5877 "aria-multiselectable": allowMultiple
5878 }, optionsMarkup));
5879 }) : null;
5880 return React__default.createElement("ul", {
5881 className: styles$o.OptionList,
5882 role: role
5883 }, optionsMarkup);
5884}
5885
5886function createNormalizedOptions(options, sections, title) {
5887 if (options == null) {
5888 var section = {
5889 options: [],
5890 title
5891 };
5892 return sections == null ? [] : [section].concat(_toConsumableArray(sections));
5893 }
5894
5895 if (sections == null) {
5896 return [{
5897 title,
5898 options
5899 }];
5900 }
5901
5902 return [{
5903 title,
5904 options
5905 }].concat(_toConsumableArray(sections));
5906}
5907
5908function isSection(arr) {
5909 return typeof arr[0] === 'object' && Object.prototype.hasOwnProperty.call(arr[0], 'options');
5910}
5911
5912function optionArraysAreEqual(firstArray, secondArray) {
5913 if (isSection(firstArray) && isSection(secondArray)) {
5914 return arraysAreEqual(firstArray, secondArray, testSectionsPropEquality);
5915 }
5916
5917 return arraysAreEqual(firstArray, secondArray);
5918}
5919
5920function testSectionsPropEquality(previousSection, currentSection) {
5921 var previousOptions = previousSection.options;
5922 var currentOptions = currentSection.options;
5923 var optionsAreEqual = arraysAreEqual(previousOptions, currentOptions);
5924 var titlesAreEqual = previousSection.title === currentSection.title;
5925 return optionsAreEqual && titlesAreEqual;
5926}
5927
5928var ComboBoxContext = React__default.createContext({});
5929
5930var styles$p = {
5931 "EmptyState": "Polaris-Autocomplete-ComboBox__EmptyState"
5932};
5933
5934var getUniqueId = other.createUniqueIDFactory('ComboBox');
5935var ComboBox =
5936/*#__PURE__*/
5937function (_React$PureComponent) {
5938 _inherits(ComboBox, _React$PureComponent);
5939
5940 function ComboBox() {
5941 var _this;
5942
5943 _classCallCheck(this, ComboBox);
5944
5945 _this = _possibleConstructorReturn(this, _getPrototypeOf(ComboBox).apply(this, arguments));
5946 _this.state = {
5947 comboBoxId: _this.getComboBoxId(),
5948 selectedOption: undefined,
5949 selectedIndex: -1,
5950 selectedOptions: _this.props.selected,
5951 navigableOptions: [],
5952 popoverActive: false,
5953 popoverWasActive: false
5954 };
5955
5956 _this.handleDownArrow = function () {
5957 _this.selectNextOption();
5958
5959 _this.handlePopoverOpen;
5960 };
5961
5962 _this.handleUpArrow = function () {
5963 _this.selectPreviousOption();
5964
5965 _this.handlePopoverOpen;
5966 };
5967
5968 _this.handleEnter = function (event) {
5969 if (event.keyCode !== exports.Key.Enter) {
5970 return;
5971 }
5972
5973 var selectedOption = _this.state.selectedOption;
5974
5975 if (_this.state.popoverActive && selectedOption) {
5976 if (isOption(selectedOption)) {
5977 event.preventDefault();
5978
5979 _this.handleSelection(selectedOption.value);
5980 } else {
5981 selectedOption.onAction && selectedOption.onAction();
5982 }
5983 }
5984
5985 _this.handlePopoverOpen;
5986 };
5987
5988 _this.handleFocus = function () {
5989 _this.setState({
5990 popoverActive: true,
5991 popoverWasActive: true
5992 });
5993 };
5994
5995 _this.handleBlur = function () {
5996 _this.setState({
5997 popoverActive: false,
5998 popoverWasActive: false
5999 }, function () {
6000 _this.resetVisuallySelectedOptions();
6001 });
6002 };
6003
6004 _this.handleClick = function () {
6005 !_this.state.popoverActive && _this.setState({
6006 popoverActive: true
6007 });
6008 };
6009
6010 _this.handleSelection = function (newSelected) {
6011 var _this$props = _this.props,
6012 selected = _this$props.selected,
6013 allowMultiple = _this$props.allowMultiple;
6014 var newlySelectedOptions = selected;
6015
6016 if (selected.includes(newSelected)) {
6017 newlySelectedOptions.splice(newlySelectedOptions.indexOf(newSelected), 1);
6018 } else if (allowMultiple) {
6019 newlySelectedOptions.push(newSelected);
6020 } else {
6021 newlySelectedOptions = [newSelected];
6022 }
6023
6024 _this.selectOptions(newlySelectedOptions);
6025 };
6026
6027 _this.selectOptions = function (selected) {
6028 var _this$props2 = _this.props,
6029 onSelect = _this$props2.onSelect,
6030 allowMultiple = _this$props2.allowMultiple;
6031 selected && onSelect(selected);
6032
6033 if (!allowMultiple) {
6034 _this.resetVisuallySelectedOptions();
6035
6036 _this.setState({
6037 popoverActive: false,
6038 popoverWasActive: false
6039 });
6040 }
6041 };
6042
6043 _this.updateIndexOfSelectedOption = function (newOptions) {
6044 var _this$state = _this.state,
6045 selectedIndex = _this$state.selectedIndex,
6046 selectedOption = _this$state.selectedOption;
6047
6048 if (selectedOption && newOptions.includes(selectedOption)) {
6049 _this.selectOptionAtIndex(newOptions.indexOf(selectedOption));
6050 } else if (selectedIndex > newOptions.length - 1) {
6051 _this.resetVisuallySelectedOptions();
6052 } else {
6053 _this.selectOptionAtIndex(selectedIndex);
6054 }
6055 };
6056
6057 _this.resetVisuallySelectedOptions = function () {
6058 var navigableOptions = _this.state.navigableOptions;
6059
6060 _this.setState({
6061 selectedOption: undefined,
6062 selectedIndex: -1
6063 });
6064
6065 navigableOptions && navigableOptions.forEach(function (option) {
6066 option.active = false;
6067 });
6068 };
6069
6070 _this.handlePopoverClose = function () {
6071 _this.setState({
6072 popoverActive: false,
6073 popoverWasActive: false
6074 });
6075 };
6076
6077 _this.handlePopoverOpen = function () {
6078 var _this$state2 = _this.state,
6079 popoverActive = _this$state2.popoverActive,
6080 navigableOptions = _this$state2.navigableOptions;
6081 !popoverActive && navigableOptions && navigableOptions.length > 0 && _this.setState({
6082 popoverActive: true,
6083 popoverWasActive: true
6084 });
6085 };
6086
6087 _this.selectNextOption = function () {
6088 var _this$state3 = _this.state,
6089 selectedIndex = _this$state3.selectedIndex,
6090 navigableOptions = _this$state3.navigableOptions;
6091
6092 if (!navigableOptions || navigableOptions.length === 0) {
6093 return;
6094 }
6095
6096 var newIndex = selectedIndex;
6097
6098 if (selectedIndex + 1 >= navigableOptions.length) {
6099 newIndex = 0;
6100 } else {
6101 newIndex++;
6102 }
6103
6104 _this.selectOptionAtIndex(newIndex);
6105 };
6106
6107 _this.selectPreviousOption = function () {
6108 var _this$state4 = _this.state,
6109 selectedIndex = _this$state4.selectedIndex,
6110 navigableOptions = _this$state4.navigableOptions;
6111
6112 if (!navigableOptions || navigableOptions.length === 0) {
6113 return;
6114 }
6115
6116 var newIndex = selectedIndex;
6117
6118 if (selectedIndex <= 0) {
6119 newIndex = navigableOptions.length - 1;
6120 } else {
6121 newIndex--;
6122 }
6123
6124 _this.selectOptionAtIndex(newIndex);
6125 };
6126
6127 _this.selectOptionAtIndex = function (newOptionIndex) {
6128 _this.setState(function (prevState) {
6129 if (!prevState.navigableOptions || prevState.navigableOptions.length === 0) {
6130 return prevState;
6131 }
6132
6133 var newSelectedOption = prevState.navigableOptions[newOptionIndex];
6134
6135 _this.visuallyUpdateSelectedOption(newSelectedOption, prevState.selectedOption);
6136
6137 return Object.assign({}, prevState, {
6138 selectedOption: newSelectedOption,
6139 selectedIndex: newOptionIndex
6140 });
6141 });
6142 };
6143
6144 _this.visuallyUpdateSelectedOption = function (newOption, oldOption) {
6145 if (oldOption) {
6146 oldOption.active = false;
6147 }
6148
6149 if (newOption) {
6150 newOption.active = true;
6151 }
6152 };
6153
6154 return _this;
6155 }
6156
6157 _createClass(ComboBox, [{
6158 key: "componentDidMount",
6159 value: function componentDidMount() {
6160 var _this$props3 = this.props,
6161 options = _this$props3.options,
6162 actionsBefore = _this$props3.actionsBefore,
6163 actionsAfter = _this$props3.actionsAfter;
6164 var comboBoxId = this.getComboBoxId();
6165 var navigableOptions = [];
6166
6167 if (actionsBefore) {
6168 navigableOptions = navigableOptions.concat(actionsBefore);
6169 }
6170
6171 if (options) {
6172 navigableOptions = navigableOptions.concat(options);
6173 }
6174
6175 if (actionsAfter) {
6176 navigableOptions = navigableOptions.concat(actionsAfter);
6177 }
6178
6179 navigableOptions = assignOptionIds(navigableOptions, comboBoxId);
6180 this.setState({
6181 navigableOptions
6182 });
6183 }
6184 }, {
6185 key: "componentDidUpdate",
6186 value: function componentDidUpdate(_, prevState) {
6187 var _this$props4 = this.props,
6188 contentBefore = _this$props4.contentBefore,
6189 contentAfter = _this$props4.contentAfter,
6190 emptyState = _this$props4.emptyState;
6191 var _this$state5 = this.state,
6192 navigableOptions = _this$state5.navigableOptions,
6193 popoverWasActive = _this$state5.popoverWasActive;
6194 var optionsChanged = navigableOptions && prevState.navigableOptions && !optionsAreEqual(navigableOptions, prevState.navigableOptions);
6195
6196 if (optionsChanged) {
6197 this.updateIndexOfSelectedOption(navigableOptions);
6198 }
6199
6200 if (navigableOptions && navigableOptions.length === 0 && !contentBefore && !contentAfter && !emptyState) {
6201 // eslint-disable-next-line react/no-did-update-set-state
6202 this.setState({
6203 popoverActive: false
6204 });
6205 } else if (popoverWasActive && navigableOptions && navigableOptions.length !== 0) {
6206 // eslint-disable-next-line react/no-did-update-set-state
6207 this.setState({
6208 popoverActive: true
6209 });
6210 }
6211 }
6212 }, {
6213 key: "getComboBoxId",
6214 value: function getComboBoxId() {
6215 if (this.state && this.state.comboBoxId) {
6216 return this.state.comboBoxId;
6217 }
6218
6219 return this.props.id || getUniqueId();
6220 }
6221 }, {
6222 key: "render",
6223 value: function render() {
6224 var _this$props5 = this.props,
6225 options = _this$props5.options,
6226 textField = _this$props5.textField,
6227 listTitle = _this$props5.listTitle,
6228 allowMultiple = _this$props5.allowMultiple,
6229 preferredPosition = _this$props5.preferredPosition,
6230 actionsBefore = _this$props5.actionsBefore,
6231 actionsAfter = _this$props5.actionsAfter,
6232 contentBefore = _this$props5.contentBefore,
6233 contentAfter = _this$props5.contentAfter,
6234 onEndReached = _this$props5.onEndReached,
6235 emptyState = _this$props5.emptyState;
6236 var _this$state6 = this.state,
6237 comboBoxId = _this$state6.comboBoxId,
6238 navigableOptions = _this$state6.navigableOptions,
6239 selectedOptions = _this$state6.selectedOptions;
6240 var actionsBeforeMarkup = actionsBefore && actionsBefore.length > 0 && React__default.createElement(ActionList, {
6241 actionRole: "option",
6242 items: actionsBefore
6243 });
6244 var actionsAfterMarkup = actionsAfter && actionsAfter.length > 0 && React__default.createElement(ActionList, {
6245 actionRole: "option",
6246 items: actionsAfter
6247 });
6248 var optionsMarkup = options.length > 0 && React__default.createElement(OptionList, {
6249 role: "presentation",
6250 optionRole: "option",
6251 options: filterForOptions(navigableOptions),
6252 onChange: this.selectOptions,
6253 selected: selectedOptions,
6254 title: listTitle,
6255 allowMultiple: allowMultiple
6256 });
6257 var emptyStateMarkup = !actionsAfter && !actionsBefore && !contentAfter && !contentBefore && options.length === 0 && emptyState && React__default.createElement("div", {
6258 className: styles$p.EmptyState
6259 }, emptyState);
6260 var context = {
6261 comboBoxId,
6262 selectedOptionId: this.selectedOptionId
6263 };
6264 return React__default.createElement(ComboBoxContext.Provider, {
6265 value: context
6266 }, React__default.createElement("div", {
6267 onClick: this.handleClick,
6268 role: "combobox",
6269 "aria-expanded": this.state.popoverActive,
6270 "aria-owns": this.state.comboBoxId,
6271 "aria-controls": this.state.comboBoxId,
6272 "aria-haspopup": true,
6273 onFocus: this.handleFocus,
6274 onBlur: this.handleBlur,
6275 tabIndex: 0
6276 }, React__default.createElement(KeypressListener, {
6277 keyCode: exports.Key.DownArrow,
6278 handler: this.handleDownArrow
6279 }), React__default.createElement(KeypressListener, {
6280 keyCode: exports.Key.UpArrow,
6281 handler: this.handleUpArrow
6282 }), React__default.createElement(EventListener, {
6283 event: "keydown",
6284 handler: this.handleEnter
6285 }), React__default.createElement(KeypressListener, {
6286 keyCode: exports.Key.Escape,
6287 handler: this.handlePopoverClose
6288 }), React__default.createElement(Popover, {
6289 activator: textField,
6290 active: this.state.popoverActive,
6291 onClose: this.handlePopoverClose,
6292 preferredPosition: preferredPosition,
6293 fullWidth: true,
6294 preventAutofocus: true
6295 }, React__default.createElement(Popover.Pane, {
6296 onScrolledToBottom: onEndReached
6297 }, React__default.createElement("div", {
6298 id: this.state.comboBoxId,
6299 role: "listbox",
6300 "aria-multiselectable": allowMultiple
6301 }, contentBefore, actionsBeforeMarkup, optionsMarkup, actionsAfterMarkup, contentAfter, emptyStateMarkup)))));
6302 }
6303 }, {
6304 key: "selectedOptionId",
6305 get: function get() {
6306 var _this$state7 = this.state,
6307 selectedOption = _this$state7.selectedOption,
6308 selectedIndex = _this$state7.selectedIndex,
6309 comboBoxId = _this$state7.comboBoxId;
6310 return selectedOption ? "".concat(comboBoxId, "-").concat(selectedIndex) : undefined;
6311 }
6312 }], [{
6313 key: "getDerivedStateFromProps",
6314 value: function getDerivedStateFromProps(_ref, _ref2) {
6315 var nextOptions = _ref.options,
6316 nextSelected = _ref.selected,
6317 nextActionsBefore = _ref.actionsBefore,
6318 nextActionsAfter = _ref.actionsAfter;
6319 var navigableOptions = _ref2.navigableOptions,
6320 selectedOptions = _ref2.selectedOptions,
6321 comboBoxId = _ref2.comboBoxId;
6322 var optionsChanged = filterForOptions(navigableOptions) && nextOptions && !optionsAreEqual(navigableOptions, nextOptions);
6323 var newNavigableOptions = [];
6324
6325 if (nextActionsBefore) {
6326 newNavigableOptions = newNavigableOptions.concat(nextActionsBefore);
6327 }
6328
6329 if (optionsChanged || nextActionsBefore) {
6330 newNavigableOptions = newNavigableOptions.concat(nextOptions);
6331 }
6332
6333 if (nextActionsAfter) {
6334 newNavigableOptions = newNavigableOptions.concat(nextActionsAfter);
6335 }
6336
6337 newNavigableOptions = assignOptionIds(newNavigableOptions, comboBoxId);
6338
6339 if (optionsChanged && selectedOptions !== nextSelected) {
6340 return {
6341 navigableOptions: newNavigableOptions,
6342 selectedOptions: nextSelected
6343 };
6344 } else if (optionsChanged) {
6345 return {
6346 navigableOptions: newNavigableOptions
6347 };
6348 } else if (selectedOptions !== nextSelected) {
6349 return {
6350 selectedOptions: nextSelected
6351 };
6352 }
6353
6354 return null;
6355 }
6356 }]);
6357
6358 return ComboBox;
6359}(React__default.PureComponent);
6360
6361function assignOptionIds(options, comboBoxId) {
6362 options.map(function (option, optionIndex) {
6363 option.id = "".concat(comboBoxId, "-").concat(optionIndex);
6364 });
6365 return options;
6366}
6367
6368function optionsAreEqual(firstOptions, secondOptions) {
6369 if (firstOptions.length !== secondOptions.length) {
6370 return false;
6371 }
6372
6373 return firstOptions.every(function (firstItem, index) {
6374 var secondItem = secondOptions[index];
6375
6376 if (isOption(firstItem)) {
6377 if (isOption(secondItem)) {
6378 return firstItem.value === secondItem.value;
6379 }
6380
6381 return false;
6382 } else {
6383 if (!isOption(secondItem)) {
6384 return firstItem.content === secondItem.content;
6385 }
6386
6387 return false;
6388 }
6389 });
6390}
6391
6392function isOption(navigableOption) {
6393 return navigableOption.value !== undefined;
6394}
6395
6396function filterForOptions(mixedArray) {
6397 return mixedArray.filter(function (item) {
6398 return isOption(item);
6399 });
6400}
6401
6402var styles$q = {
6403 "Label": "Polaris-Label",
6404 "hidden": "Polaris-Label--hidden",
6405 "Text": "Polaris-Label__Text"
6406};
6407
6408function labelID(id) {
6409 return "".concat(id, "Label");
6410}
6411function Label(_ref) {
6412 var children = _ref.children,
6413 id = _ref.id,
6414 hidden = _ref.hidden;
6415 var className = classNames(styles$q.Label, hidden && styles$q.hidden);
6416 return React__default.createElement("div", {
6417 className: className
6418 }, React__default.createElement("label", {
6419 id: labelID(id),
6420 htmlFor: id,
6421 className: styles$q.Text
6422 }, children));
6423}
6424
6425var styles$r = {
6426 "InlineError": "Polaris-InlineError",
6427 "Icon": "Polaris-InlineError__Icon"
6428};
6429
6430function InlineError(_ref) {
6431 var message = _ref.message,
6432 fieldID = _ref.fieldID;
6433
6434 if (!message) {
6435 return null;
6436 }
6437
6438 return React__default.createElement("div", {
6439 id: errorTextID(fieldID),
6440 className: styles$r.InlineError
6441 }, React__default.createElement("div", {
6442 className: styles$r.Icon
6443 }, React__default.createElement(Icon, {
6444 source: polarisIcons.AlertMinor
6445 })), message);
6446}
6447function errorTextID(id) {
6448 return "".concat(id, "Error");
6449}
6450
6451var styles$s = {
6452 "hidden": "Polaris-Labelled--hidden",
6453 "LabelWrapper": "Polaris-Labelled__LabelWrapper",
6454 "HelpText": "Polaris-Labelled__HelpText",
6455 "Error": "Polaris-Labelled__Error",
6456 "Action": "Polaris-Labelled__Action"
6457};
6458
6459function Labelled(_a) {
6460 var id = _a.id,
6461 label = _a.label,
6462 error = _a.error,
6463 action = _a.action,
6464 helpText = _a.helpText,
6465 children = _a.children,
6466 labelHidden = _a.labelHidden,
6467 rest = tslib_1.__rest(_a, ["id", "label", "error", "action", "helpText", "children", "labelHidden"]);
6468
6469 var className = classNames(labelHidden && styles$s.hidden);
6470 var actionMarkup = action ? React__default.createElement("div", {
6471 className: styles$s.Action
6472 }, buttonFrom(action, {
6473 plain: true
6474 })) : null;
6475 var helpTextMarkup = helpText ? React__default.createElement("div", {
6476 className: styles$s.HelpText,
6477 id: helpTextID(id)
6478 }, helpText) : null;
6479 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
6480 className: styles$s.Error
6481 }, React__default.createElement(InlineError, {
6482 message: error,
6483 fieldID: id
6484 }));
6485 var labelMarkup = label ? React__default.createElement("div", {
6486 className: styles$s.LabelWrapper
6487 }, React__default.createElement(Label, Object.assign({
6488 id: id
6489 }, rest, {
6490 hidden: false
6491 }), label), actionMarkup) : null;
6492 return React__default.createElement("div", {
6493 className: className
6494 }, labelMarkup, children, errorMarkup, helpTextMarkup);
6495}
6496function helpTextID(id) {
6497 return "".concat(id, "HelpText");
6498}
6499
6500var styles$t = {
6501 "Connected": "Polaris-Connected",
6502 "Item": "Polaris-Connected__Item",
6503 "Item-primary": "Polaris-Connected__Item--primary",
6504 "Item-connection": "Polaris-Connected__Item--connection",
6505 "Item-focused": "Polaris-Connected__Item--focused"
6506};
6507
6508var ItemPosition;
6509
6510(function (ItemPosition) {
6511 ItemPosition[ItemPosition["Left"] = 0] = "Left";
6512 ItemPosition[ItemPosition["Primary"] = 1] = "Primary";
6513 ItemPosition[ItemPosition["Right"] = 2] = "Right";
6514})(ItemPosition || (ItemPosition = {}));
6515
6516var Item$3 =
6517/*#__PURE__*/
6518function (_React$PureComponent) {
6519 _inherits(Item, _React$PureComponent);
6520
6521 function Item() {
6522 var _this;
6523
6524 _classCallCheck(this, Item);
6525
6526 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
6527 _this.state = {
6528 focused: false
6529 };
6530
6531 _this.handleBlur = function () {
6532 _this.setState({
6533 focused: false
6534 });
6535 };
6536
6537 _this.handleFocus = function () {
6538 _this.setState({
6539 focused: true
6540 });
6541 };
6542
6543 return _this;
6544 }
6545
6546 _createClass(Item, [{
6547 key: "render",
6548 value: function render() {
6549 var focused = this.state.focused;
6550 var _this$props = this.props,
6551 children = _this$props.children,
6552 position = _this$props.position;
6553 var className = classNames(styles$t.Item, focused && styles$t['Item-focused'], position === ItemPosition.Primary ? styles$t['Item-primary'] : styles$t['Item-connection']);
6554 return React__default.createElement("div", {
6555 onBlur: this.handleBlur,
6556 onFocus: this.handleFocus,
6557 className: className
6558 }, children);
6559 }
6560 }]);
6561
6562 return Item;
6563}(React__default.PureComponent);
6564
6565function Connected(_ref) {
6566 var children = _ref.children,
6567 left = _ref.left,
6568 right = _ref.right;
6569 var leftConnectionMarkup = left ? React__default.createElement(Item$3, {
6570 position: ItemPosition.Left
6571 }, left) : null;
6572 var rightConnectionMarkup = right ? React__default.createElement(Item$3, {
6573 position: ItemPosition.Right
6574 }, right) : null;
6575 return React__default.createElement("div", {
6576 className: styles$t.Connected
6577 }, leftConnectionMarkup, React__default.createElement(Item$3, {
6578 position: ItemPosition.Primary
6579 }, children), rightConnectionMarkup);
6580}
6581
6582var styles$u = {
6583 "TextField": "Polaris-TextField",
6584 "multiline": "Polaris-TextField--multiline",
6585 "Input": "Polaris-TextField__Input",
6586 "hasValue": "Polaris-TextField--hasValue",
6587 "focus": "Polaris-TextField--focus",
6588 "Backdrop": "Polaris-TextField__Backdrop",
6589 "error": "Polaris-TextField--error",
6590 "readOnly": "Polaris-TextField--readOnly",
6591 "disabled": "Polaris-TextField--disabled",
6592 "Prefix": "Polaris-TextField__Prefix",
6593 "Input-hasClearButton": "Polaris-TextField__Input--hasClearButton",
6594 "Input-suffixed": "Polaris-TextField__Input--suffixed",
6595 "Input-alignRight": "Polaris-TextField__Input--alignRight",
6596 "Input-alignLeft": "Polaris-TextField__Input--alignLeft",
6597 "Input-alignCenter": "Polaris-TextField__Input--alignCenter",
6598 "Suffix": "Polaris-TextField__Suffix",
6599 "CharacterCount": "Polaris-TextField__CharacterCount",
6600 "AlignFieldBottom": "Polaris-TextField__AlignFieldBottom",
6601 "ClearButton": "Polaris-TextField__ClearButton",
6602 "Spinner": "Polaris-TextField__Spinner",
6603 "SpinnerIcon": "Polaris-TextField__SpinnerIcon",
6604 "Resizer": "Polaris-TextField__Resizer",
6605 "DummyInput": "Polaris-TextField__DummyInput",
6606 "Segment": "Polaris-TextField__Segment",
6607 "globalTheming": "Polaris-TextField--globalTheming"
6608};
6609
6610function Resizer(_ref) {
6611 var contents = _ref.contents,
6612 _ref$currentHeight = _ref.currentHeight,
6613 currentHeightProp = _ref$currentHeight === void 0 ? null : _ref$currentHeight,
6614 minimumLines = _ref.minimumLines,
6615 onHeightChange = _ref.onHeightChange;
6616 var contentNode = React.useRef(null);
6617 var minimumLinesNode = React.useRef(null);
6618 var animationFrame = React.useRef();
6619 var currentHeight = React.useRef(currentHeightProp);
6620
6621 if (currentHeightProp !== currentHeight.current) {
6622 currentHeight.current = currentHeightProp;
6623 }
6624
6625 React.useEffect(function () {
6626 return function () {
6627 if (animationFrame.current) {
6628 cancelAnimationFrame(animationFrame.current);
6629 }
6630 };
6631 }, []);
6632 var minimumLinesMarkup = minimumLines ? React__default.createElement("div", {
6633 ref: minimumLinesNode,
6634 className: styles$u.DummyInput,
6635 dangerouslySetInnerHTML: {
6636 __html: getContentsForMinimumLines(minimumLines)
6637 }
6638 }) : null;
6639 var handleHeightCheck = React.useCallback(function () {
6640 if (animationFrame.current) {
6641 cancelAnimationFrame(animationFrame.current);
6642 }
6643
6644 animationFrame.current = requestAnimationFrame(function () {
6645 if (!contentNode.current || !minimumLinesNode.current) {
6646 return;
6647 }
6648
6649 var newHeight = Math.max(contentNode.current.offsetHeight, minimumLinesNode.current.offsetHeight);
6650
6651 if (newHeight !== currentHeight.current) {
6652 onHeightChange(newHeight);
6653 }
6654 });
6655 }, [onHeightChange]);
6656 React.useLayoutEffect(function () {
6657 handleHeightCheck();
6658 });
6659 return React__default.createElement("div", {
6660 "aria-hidden": true,
6661 className: styles$u.Resizer
6662 }, React__default.createElement(EventListener, {
6663 event: "resize",
6664 handler: handleHeightCheck
6665 }), React__default.createElement("div", {
6666 ref: contentNode,
6667 className: styles$u.DummyInput,
6668 dangerouslySetInnerHTML: {
6669 __html: getFinalContents(contents)
6670 }
6671 }), minimumLinesMarkup);
6672}
6673var ENTITIES_TO_REPLACE = {
6674 '&': '&amp;',
6675 '<': '&lt;',
6676 '>': '&gt;',
6677 '\n': '<br>',
6678 '\r': ''
6679};
6680var REPLACE_REGEX$1 = new RegExp("[".concat(Object.keys(ENTITIES_TO_REPLACE).join(), "]"), 'g');
6681
6682function replaceEntity(entity) {
6683 return ENTITIES_TO_REPLACE[entity];
6684}
6685
6686function getContentsForMinimumLines(minimumLines) {
6687 var content = '';
6688
6689 for (var line = 0; line < minimumLines; line++) {
6690 content += '<br>';
6691 }
6692
6693 return content;
6694}
6695
6696function getFinalContents(contents) {
6697 return contents ? "".concat(contents.replace(REPLACE_REGEX$1, replaceEntity), "<br>") : '<br>';
6698}
6699
6700function Spinner$1(_ref) {
6701 var onChange = _ref.onChange,
6702 onClick = _ref.onClick,
6703 onMouseDown = _ref.onMouseDown,
6704 onMouseUp = _ref.onMouseUp;
6705
6706 function handleStep(step) {
6707 return function () {
6708 return onChange(step);
6709 };
6710 }
6711
6712 function handleMouseDown(onChange) {
6713 return function (event) {
6714 if (event.button !== 0) return;
6715 onMouseDown(onChange);
6716 };
6717 }
6718
6719 return React__default.createElement("div", {
6720 className: styles$u.Spinner,
6721 onClick: onClick,
6722 "aria-hidden": true
6723 }, React__default.createElement("div", {
6724 role: "button",
6725 className: styles$u.Segment,
6726 tabIndex: -1,
6727 onClick: handleStep(1),
6728 onMouseDown: handleMouseDown(handleStep(1)),
6729 onMouseUp: onMouseUp
6730 }, React__default.createElement("div", {
6731 className: styles$u.SpinnerIcon
6732 }, React__default.createElement(Icon, {
6733 source: polarisIcons.CaretUpMinor
6734 }))), React__default.createElement("div", {
6735 role: "button",
6736 className: styles$u.Segment,
6737 tabIndex: -1,
6738 onClick: handleStep(-1),
6739 onMouseDown: handleMouseDown(handleStep(-1)),
6740 onMouseUp: onMouseUp
6741 }, React__default.createElement("div", {
6742 className: styles$u.SpinnerIcon
6743 }, React__default.createElement(Icon, {
6744 source: polarisIcons.CaretDownMinor
6745 }))));
6746}
6747
6748function TextField(_ref) {
6749 var prefix = _ref.prefix,
6750 suffix = _ref.suffix,
6751 placeholder = _ref.placeholder,
6752 value = _ref.value,
6753 helpText = _ref.helpText,
6754 label = _ref.label,
6755 labelAction = _ref.labelAction,
6756 labelHidden = _ref.labelHidden,
6757 disabled = _ref.disabled,
6758 clearButton = _ref.clearButton,
6759 readOnly = _ref.readOnly,
6760 autoFocus = _ref.autoFocus,
6761 focused = _ref.focused,
6762 multiline = _ref.multiline,
6763 error = _ref.error,
6764 connectedRight = _ref.connectedRight,
6765 connectedLeft = _ref.connectedLeft,
6766 type = _ref.type,
6767 name = _ref.name,
6768 idProp = _ref.id,
6769 role = _ref.role,
6770 _ref$step = _ref.step,
6771 step = _ref$step === void 0 ? 1 : _ref$step,
6772 autoComplete = _ref.autoComplete,
6773 _ref$max = _ref.max,
6774 max = _ref$max === void 0 ? Infinity : _ref$max,
6775 maxLength = _ref.maxLength,
6776 _ref$min = _ref.min,
6777 min = _ref$min === void 0 ? -Infinity : _ref$min,
6778 minLength = _ref.minLength,
6779 pattern = _ref.pattern,
6780 spellCheck = _ref.spellCheck,
6781 ariaOwns = _ref.ariaOwns,
6782 ariaControls = _ref.ariaControls,
6783 ariaActiveDescendant = _ref.ariaActiveDescendant,
6784 ariaAutocomplete = _ref.ariaAutocomplete,
6785 showCharacterCount = _ref.showCharacterCount,
6786 align = _ref.align,
6787 onClearButtonClick = _ref.onClearButtonClick,
6788 onChange = _ref.onChange,
6789 onFocus = _ref.onFocus,
6790 onBlur = _ref.onBlur;
6791 var i18n = useI18n();
6792
6793 var _useState = React.useState(null),
6794 _useState2 = _slicedToArray(_useState, 2),
6795 height = _useState2[0],
6796 setHeight = _useState2[1];
6797
6798 var _useState3 = React.useState(Boolean(focused)),
6799 _useState4 = _slicedToArray(_useState3, 2),
6800 focus = _useState4[0],
6801 setFocus = _useState4[1];
6802
6803 var isAfterInitial = useIsAfterInitialMount();
6804 var id = useUniqueId('TextField', idProp);
6805 var inputRef = React.useRef(null);
6806 var prefixRef = React.useRef(null);
6807 var suffixRef = React.useRef(null);
6808 var buttonPressTimer = React.useRef();
6809 React.useEffect(function () {
6810 var input = inputRef.current;
6811 if (!input || focused === undefined) return;
6812 focused ? input.focus() : input.blur();
6813 }, [focused]);
6814 var normalizedValue = value != null ? value : '';
6815
6816 var _useFeatures = useFeatures(),
6817 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
6818 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
6819
6820 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);
6821 var inputType = type === 'currency' ? 'text' : type;
6822 var prefixMarkup = prefix ? React__default.createElement("div", {
6823 className: styles$u.Prefix,
6824 id: "".concat(id, "Prefix"),
6825 ref: prefixRef
6826 }, prefix) : null;
6827 var suffixMarkup = suffix ? React__default.createElement("div", {
6828 className: styles$u.Suffix,
6829 id: "".concat(id, "Suffix"),
6830 ref: suffixRef
6831 }, suffix) : null;
6832 var characterCount = normalizedValue.length;
6833 var characterCountLabel = i18n.translate(maxLength ? 'Polaris.TextField.characterCountWithMaxLength' : 'Polaris.TextField.characterCount', {
6834 count: characterCount,
6835 limit: maxLength
6836 });
6837 var characterCountClassName = classNames(styles$u.CharacterCount, multiline && styles$u.AlignFieldBottom);
6838 var characterCountText = !maxLength ? characterCount : "".concat(characterCount, "/").concat(maxLength);
6839 var characterCountMarkup = showCharacterCount ? React__default.createElement("div", {
6840 id: "".concat(id, "CharacterCounter"),
6841 className: characterCountClassName,
6842 "aria-label": characterCountLabel,
6843 "aria-live": focus ? 'polite' : 'off',
6844 "aria-atomic": "true"
6845 }, characterCountText) : null;
6846 var clearButtonMarkup = clearButton && normalizedValue !== '' ? React__default.createElement("button", {
6847 type: "button",
6848 className: styles$u.ClearButton,
6849 onClick: handleClearButtonPress,
6850 disabled: disabled
6851 }, React__default.createElement(VisuallyHidden, null, i18n.translate('Polaris.Common.clear')), React__default.createElement(Icon, {
6852 source: polarisIcons.CircleCancelMinor,
6853 color: "inkLightest"
6854 })) : null;
6855 var handleNumberChange = React.useCallback(function (steps) {
6856 if (onChange == null) {
6857 return;
6858 } // Returns the length of decimal places in a number
6859
6860
6861 var dpl = function dpl(num) {
6862 return (num.toString().split('.')[1] || []).length;
6863 };
6864
6865 var numericValue = value ? parseFloat(value) : 0;
6866
6867 if (isNaN(numericValue)) {
6868 return;
6869 } // Making sure the new value has the same length of decimal places as the
6870 // step / value has.
6871
6872
6873 var decimalPlaces = Math.max(dpl(numericValue), dpl(step));
6874 var newValue = Math.min(Number(max), Math.max(numericValue + steps * step, Number(min)));
6875 onChange(String(newValue.toFixed(decimalPlaces)), id);
6876 }, [id, max, min, onChange, step, value]);
6877 var handleButtonRelease = React.useCallback(function () {
6878 clearTimeout(buttonPressTimer.current);
6879 }, []);
6880 var handleButtonPress = React.useCallback(function (onChange) {
6881 var minInterval = 50;
6882 var decrementBy = 10;
6883 var interval = 200;
6884
6885 var onChangeInterval = function onChangeInterval() {
6886 if (interval > minInterval) interval -= decrementBy;
6887 onChange();
6888 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6889 };
6890
6891 buttonPressTimer.current = window.setTimeout(onChangeInterval, interval);
6892 events.addEventListener(document, 'mouseup', handleButtonRelease, {
6893 once: true
6894 });
6895 }, [handleButtonRelease]);
6896 var spinnerMarkup = type === 'number' && !disabled && !readOnly ? React__default.createElement(Spinner$1, {
6897 onChange: handleNumberChange,
6898 onMouseDown: handleButtonPress,
6899 onMouseUp: handleButtonRelease
6900 }) : null;
6901 var style = multiline && height ? {
6902 height
6903 } : null;
6904 var handleExpandingResize = React.useCallback(function (height) {
6905 setHeight(height);
6906 }, []);
6907 var resizer = multiline && isAfterInitial ? React__default.createElement(Resizer, {
6908 contents: normalizedValue || placeholder,
6909 currentHeight: height,
6910 minimumLines: typeof multiline === 'number' ? multiline : 1,
6911 onHeightChange: handleExpandingResize
6912 }) : null;
6913 var describedBy = [];
6914
6915 if (error) {
6916 describedBy.push("".concat(id, "Error"));
6917 }
6918
6919 if (helpText) {
6920 describedBy.push(helpTextID(id));
6921 }
6922
6923 if (showCharacterCount) {
6924 describedBy.push("".concat(id, "CharacterCounter"));
6925 }
6926
6927 var labelledBy = [];
6928
6929 if (prefix) {
6930 labelledBy.push("".concat(id, "Prefix"));
6931 }
6932
6933 if (suffix) {
6934 labelledBy.push("".concat(id, "Suffix"));
6935 }
6936
6937 labelledBy.unshift(labelID(id));
6938 var inputClassName = classNames(styles$u.Input, align && styles$u[variationName('Input-align', align)], suffix && styles$u['Input-suffixed'], clearButton && styles$u['Input-hasClearButton']);
6939 var input = React__default.createElement(multiline ? 'textarea' : 'input', {
6940 name,
6941 id,
6942 disabled,
6943 readOnly,
6944 role,
6945 autoFocus,
6946 value: normalizedValue,
6947 placeholder,
6948 onFocus,
6949 onBlur,
6950 onKeyPress: handleKeyPress,
6951 style,
6952 autoComplete: normalizeAutoComplete(autoComplete),
6953 className: inputClassName,
6954 onChange: handleChange,
6955 ref: inputRef,
6956 min,
6957 max,
6958 step,
6959 minLength,
6960 maxLength,
6961 spellCheck,
6962 pattern,
6963 type: inputType,
6964 'aria-describedby': describedBy.length ? describedBy.join(' ') : undefined,
6965 'aria-labelledby': labelledBy.join(' '),
6966 'aria-invalid': Boolean(error),
6967 'aria-owns': ariaOwns,
6968 'aria-activedescendant': ariaActiveDescendant,
6969 'aria-autocomplete': ariaAutocomplete,
6970 'aria-controls': ariaControls,
6971 'aria-multiline': normalizeAriaMultiline(multiline)
6972 });
6973 return React__default.createElement(Labelled, {
6974 label: label,
6975 id: id,
6976 error: error,
6977 action: labelAction,
6978 labelHidden: labelHidden,
6979 helpText: helpText
6980 }, React__default.createElement(Connected, {
6981 left: connectedLeft,
6982 right: connectedRight
6983 }, React__default.createElement("div", {
6984 className: className,
6985 onFocus: handleFocus,
6986 onBlur: handleBlur,
6987 onClick: handleClick
6988 }, prefixMarkup, input, suffixMarkup, characterCountMarkup, clearButtonMarkup, spinnerMarkup, React__default.createElement("div", {
6989 className: styles$u.Backdrop
6990 }), resizer)));
6991
6992 function handleClearButtonPress() {
6993 onClearButtonClick && onClearButtonClick(id);
6994 }
6995
6996 function handleKeyPress(event) {
6997 var key = event.key,
6998 which = event.which;
6999 var numbersSpec = /[\d.eE+-]$/;
7000
7001 if (type !== 'number' || which === exports.Key.Enter || numbersSpec.test(key)) {
7002 return;
7003 }
7004
7005 event.preventDefault();
7006 }
7007
7008 function containsAffix(target) {
7009 return target instanceof HTMLElement && (prefixRef.current && prefixRef.current.contains(target) || suffixRef.current && suffixRef.current.contains(target));
7010 }
7011
7012 function handleChange(event) {
7013 onChange && onChange(event.currentTarget.value, id);
7014 }
7015
7016 function handleFocus(_ref2) {
7017 var target = _ref2.target;
7018
7019 if (containsAffix(target)) {
7020 return;
7021 }
7022
7023 setFocus(true);
7024 }
7025
7026 function handleBlur() {
7027 setFocus(false);
7028 }
7029
7030 function handleClick(_ref3) {
7031 var target = _ref3.target;
7032
7033 if (containsAffix(target)) {
7034 return;
7035 }
7036
7037 inputRef.current && inputRef.current.focus();
7038 }
7039}
7040
7041function normalizeAutoComplete(autoComplete) {
7042 if (autoComplete == null) {
7043 return autoComplete;
7044 } else if (autoComplete === true) {
7045 return 'on';
7046 } else if (autoComplete === false) {
7047 return 'off';
7048 } else {
7049 return autoComplete;
7050 }
7051}
7052
7053function normalizeAriaMultiline(multiline) {
7054 switch (typeof multiline) {
7055 case 'undefined':
7056 return false;
7057
7058 case 'boolean':
7059 return multiline;
7060
7061 case 'number':
7062 return Boolean(multiline > 0);
7063 }
7064}
7065
7066function TextField$1(props) {
7067 return React__default.createElement(ComboBoxContext.Consumer, null, function (_ref) {
7068 var selectedOptionId = _ref.selectedOptionId,
7069 comboBoxId = _ref.comboBoxId;
7070 return React__default.createElement(TextField, Object.assign({}, props, {
7071 autoComplete: false,
7072 ariaAutocomplete: "list",
7073 ariaActiveDescendant: selectedOptionId,
7074 ariaControls: comboBoxId
7075 }));
7076 });
7077}
7078
7079var styles$v = {
7080 "Loading": "Polaris-Autocomplete__Loading"
7081};
7082
7083// subcomponents so explicitly state the subcomponents in the type definition.
7084// Letting this be implicit works in this project but fails in projects that use
7085// generated *.d.ts files.
7086
7087var Autocomplete = function Autocomplete(_ref) {
7088 var id = _ref.id,
7089 options = _ref.options,
7090 selected = _ref.selected,
7091 textField = _ref.textField,
7092 preferredPosition = _ref.preferredPosition,
7093 listTitle = _ref.listTitle,
7094 allowMultiple = _ref.allowMultiple,
7095 loading = _ref.loading,
7096 actionBefore = _ref.actionBefore,
7097 willLoadMoreResults = _ref.willLoadMoreResults,
7098 emptyState = _ref.emptyState,
7099 onSelect = _ref.onSelect,
7100 onLoadMoreResults = _ref.onLoadMoreResults;
7101 var i18n = useI18n();
7102 var spinnerMarkup = loading ? React__default.createElement("div", {
7103 className: styles$v.Loading
7104 }, React__default.createElement(Spinner, {
7105 size: "small",
7106 accessibilityLabel: i18n.translate('Polaris.Autocomplete.spinnerAccessibilityLabel')
7107 })) : null;
7108 var conditionalOptions = loading && !willLoadMoreResults ? [] : options;
7109 var conditionalAction = actionBefore && actionBefore !== [] ? [actionBefore] : undefined;
7110 return React__default.createElement(ComboBox, {
7111 id: id,
7112 options: conditionalOptions,
7113 selected: selected,
7114 textField: textField,
7115 preferredPosition: preferredPosition,
7116 listTitle: listTitle,
7117 allowMultiple: allowMultiple,
7118 contentAfter: spinnerMarkup,
7119 actionsBefore: conditionalAction,
7120 onSelect: onSelect,
7121 onEndReached: onLoadMoreResults,
7122 emptyState: emptyState
7123 });
7124};
7125Autocomplete.ComboBox = ComboBox;
7126Autocomplete.TextField = TextField$1;
7127
7128// in the styleguide works without warnings about unfound props
7129
7130function ScrollLock(_) {
7131 var scrollLockManager = useScrollLockManager();
7132 React.useEffect(function () {
7133 scrollLockManager.registerScrollLock();
7134 return function () {
7135 scrollLockManager.unregisterScrollLock();
7136 };
7137 }, [scrollLockManager]);
7138 return null;
7139}
7140
7141var styles$w = {
7142 "Backdrop": "Polaris-Backdrop",
7143 "fade-in": "Polaris-Backdrop__fade--in",
7144 "transparent": "Polaris-Backdrop--transparent",
7145 "belowNavigation": "Polaris-Backdrop--belowNavigation"
7146};
7147
7148function Backdrop(props) {
7149 var onClick = props.onClick,
7150 onTouchStart = props.onTouchStart,
7151 belowNavigation = props.belowNavigation,
7152 transparent = props.transparent;
7153 var className = classNames(styles$w.Backdrop, belowNavigation && styles$w.belowNavigation, transparent && styles$w.transparent);
7154 return React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
7155 className: className,
7156 onClick: onClick,
7157 onTouchStart: onTouchStart
7158 }));
7159}
7160
7161var BannerContext = React__default.createContext(false);
7162
7163var styles$x = {
7164 "Banner": "Polaris-Banner",
7165 "withinContentContainer": "Polaris-Banner--withinContentContainer",
7166 "statusSuccess": "Polaris-Banner--statusSuccess",
7167 "statusInfo": "Polaris-Banner--statusInfo",
7168 "statusWarning": "Polaris-Banner--statusWarning",
7169 "statusCritical": "Polaris-Banner--statusCritical",
7170 "Ribbon": "Polaris-Banner__Ribbon",
7171 "Actions": "Polaris-Banner__Actions",
7172 "Dismiss": "Polaris-Banner__Dismiss",
7173 "withinPage": "Polaris-Banner--withinPage",
7174 "hasDismiss": "Polaris-Banner--hasDismiss",
7175 "Heading": "Polaris-Banner__Heading",
7176 "Content": "Polaris-Banner__Content",
7177 "PrimaryAction": "Polaris-Banner__PrimaryAction",
7178 "SecondaryAction": "Polaris-Banner__SecondaryAction",
7179 "Text": "Polaris-Banner__Text"
7180};
7181
7182var Banner =
7183/*#__PURE__*/
7184function (_React$PureComponent) {
7185 _inherits(Banner, _React$PureComponent);
7186
7187 function Banner() {
7188 var _this;
7189
7190 _classCallCheck(this, Banner);
7191
7192 _this = _possibleConstructorReturn(this, _getPrototypeOf(Banner).apply(this, arguments));
7193 _this.wrapper = React__default.createRef();
7194 return _this;
7195 }
7196
7197 _createClass(Banner, [{
7198 key: "focus",
7199 value: function focus() {
7200 this.wrapper.current && this.wrapper.current.focus();
7201 }
7202 }, {
7203 key: "render",
7204 value: function render() {
7205 var _this2 = this;
7206
7207 return React__default.createElement(BannerContext.Provider, {
7208 value: true
7209 }, React__default.createElement(WithinContentContext.Consumer, null, function (withinContentContainer) {
7210 var _this2$props = _this2.props,
7211 icon = _this2$props.icon,
7212 action = _this2$props.action,
7213 secondaryAction = _this2$props.secondaryAction,
7214 title = _this2$props.title,
7215 children = _this2$props.children,
7216 status = _this2$props.status,
7217 onDismiss = _this2$props.onDismiss,
7218 stopAnnouncements = _this2$props.stopAnnouncements;
7219 var color;
7220 var defaultIcon;
7221 var ariaRoleType = 'status';
7222
7223 switch (status) {
7224 case 'success':
7225 color = 'greenDark';
7226 defaultIcon = polarisIcons.CircleTickMajorTwotone;
7227 break;
7228
7229 case 'info':
7230 color = 'tealDark';
7231 defaultIcon = polarisIcons.CircleInformationMajorTwotone;
7232 break;
7233
7234 case 'warning':
7235 color = 'yellowDark';
7236 defaultIcon = polarisIcons.CircleAlertMajorTwotone;
7237 ariaRoleType = 'alert';
7238 break;
7239
7240 case 'critical':
7241 color = 'redDark';
7242 defaultIcon = polarisIcons.CircleDisabledMajorTwotone;
7243 ariaRoleType = 'alert';
7244 break;
7245
7246 default:
7247 color = 'inkLighter';
7248 defaultIcon = polarisIcons.FlagMajorTwotone;
7249 }
7250
7251 var className = classNames(styles$x.Banner, status && styles$x[variationName('status', status)], onDismiss && styles$x.hasDismiss, withinContentContainer ? styles$x.withinContentContainer : styles$x.withinPage);
7252 var id = uniqueID();
7253 var iconName = icon || defaultIcon;
7254 var headingMarkup = null;
7255 var headingID;
7256
7257 if (title) {
7258 headingID = "".concat(id, "Heading");
7259 headingMarkup = React__default.createElement("div", {
7260 className: styles$x.Heading,
7261 id: headingID
7262 }, React__default.createElement(Heading, {
7263 element: "p"
7264 }, title));
7265 }
7266
7267 var buttonSizeValue = withinContentContainer ? 'slim' : undefined;
7268 var secondaryActionMarkup = secondaryAction ? secondaryActionFrom(secondaryAction) : null;
7269 var actionMarkup = action ? React__default.createElement("div", {
7270 className: styles$x.Actions
7271 }, React__default.createElement(ButtonGroup, null, React__default.createElement("div", {
7272 className: styles$x.PrimaryAction
7273 }, buttonFrom(action, {
7274 outline: true,
7275 size: buttonSizeValue
7276 })), secondaryActionMarkup)) : null;
7277 var contentMarkup = null;
7278 var contentID;
7279
7280 if (children || actionMarkup) {
7281 contentID = "".concat(id, "Content");
7282 contentMarkup = React__default.createElement("div", {
7283 className: styles$x.Content,
7284 id: contentID
7285 }, children, actionMarkup);
7286 }
7287
7288 var dismissButton = onDismiss ? React__default.createElement("div", {
7289 className: styles$x.Dismiss
7290 }, React__default.createElement(Button, {
7291 plain: true,
7292 icon: polarisIcons.CancelSmallMinor,
7293 onClick: onDismiss,
7294 accessibilityLabel: "Dismiss notification"
7295 })) : null;
7296 return React__default.createElement("div", {
7297 className: className // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex
7298 ,
7299 tabIndex: 0,
7300 ref: _this2.wrapper,
7301 role: ariaRoleType,
7302 "aria-live": stopAnnouncements ? 'off' : 'polite',
7303 onMouseUp: handleMouseUp,
7304 "aria-labelledby": headingID,
7305 "aria-describedby": contentID
7306 }, dismissButton, React__default.createElement("div", {
7307 className: styles$x.Ribbon
7308 }, React__default.createElement(Icon, {
7309 source: iconName,
7310 color: color,
7311 backdrop: true
7312 })), React__default.createElement("div", null, headingMarkup, contentMarkup));
7313 }));
7314 }
7315 }]);
7316
7317 return Banner;
7318}(React__default.PureComponent);
7319var index = 1;
7320
7321function uniqueID() {
7322 return "Banner".concat(index++);
7323}
7324
7325function handleMouseUp(_ref) {
7326 var currentTarget = _ref.currentTarget;
7327 currentTarget.blur();
7328}
7329
7330function secondaryActionFrom(action) {
7331 if (action.url) {
7332 return React__default.createElement(UnstyledLink, {
7333 className: styles$x.SecondaryAction,
7334 url: action.url,
7335 external: action.external
7336 }, React__default.createElement("span", {
7337 className: styles$x.Text
7338 }, action.content));
7339 }
7340
7341 return React__default.createElement("button", {
7342 className: styles$x.SecondaryAction,
7343 onClick: action.onAction
7344 }, React__default.createElement("span", {
7345 className: styles$x.Text
7346 }, action.content));
7347}
7348
7349var styles$y = {
7350 "Breadcrumb": "Polaris-Breadcrumbs__Breadcrumb",
7351 "Icon": "Polaris-Breadcrumbs__Icon",
7352 "ContentWrapper": "Polaris-Breadcrumbs__ContentWrapper",
7353 "Content": "Polaris-Breadcrumbs__Content"
7354};
7355
7356var Breadcrumbs =
7357/*#__PURE__*/
7358function (_React$PureComponent) {
7359 _inherits(Breadcrumbs, _React$PureComponent);
7360
7361 function Breadcrumbs() {
7362 _classCallCheck(this, Breadcrumbs);
7363
7364 return _possibleConstructorReturn(this, _getPrototypeOf(Breadcrumbs).apply(this, arguments));
7365 }
7366
7367 _createClass(Breadcrumbs, [{
7368 key: "render",
7369 value: function render() {
7370 var breadcrumbs = this.props.breadcrumbs;
7371 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
7372
7373 if (breadcrumb == null) {
7374 return null;
7375 }
7376
7377 var content = breadcrumb.content;
7378 var contentMarkup = React__default.createElement("span", {
7379 className: styles$y.ContentWrapper
7380 }, React__default.createElement("span", {
7381 className: styles$y.Icon
7382 }, React__default.createElement(Icon, {
7383 source: polarisIcons.ChevronLeftMinor
7384 })), React__default.createElement("span", {
7385 className: styles$y.Content
7386 }, content));
7387 var breadcrumbMarkup = 'url' in breadcrumb ? React__default.createElement(UnstyledLink, {
7388 key: content,
7389 url: breadcrumb.url,
7390 className: styles$y.Breadcrumb,
7391 onMouseUp: handleMouseUpByBlurring,
7392 "aria-label": breadcrumb.accessibilityLabel
7393 }, contentMarkup) : React__default.createElement("button", {
7394 key: content,
7395 className: styles$y.Breadcrumb,
7396 onClick: breadcrumb.onAction,
7397 onMouseUp: handleMouseUpByBlurring,
7398 type: "button",
7399 "aria-label": breadcrumb.accessibilityLabel
7400 }, contentMarkup);
7401 return React__default.createElement("nav", {
7402 role: "navigation"
7403 }, breadcrumbMarkup);
7404 }
7405 }]);
7406
7407 return Breadcrumbs;
7408}(React__default.PureComponent);
7409
7410var styles$z = {
7411 "TextContainer": "Polaris-TextContainer",
7412 "spacingTight": "Polaris-TextContainer--spacingTight",
7413 "spacingLoose": "Polaris-TextContainer--spacingLoose"
7414};
7415
7416function TextContainer(_ref) {
7417 var spacing = _ref.spacing,
7418 children = _ref.children;
7419 var className = classNames(styles$z.TextContainer, spacing && styles$z[variationName('spacing', spacing)]);
7420 return React__default.createElement("div", {
7421 className: className
7422 }, children);
7423}
7424
7425var styles$A = {
7426 "CalloutCard": "Polaris-CalloutCard",
7427 "Image": "Polaris-CalloutCard__Image",
7428 "DismissImage": "Polaris-CalloutCard__DismissImage",
7429 "Content": "Polaris-CalloutCard__Content",
7430 "Title": "Polaris-CalloutCard__Title",
7431 "Buttons": "Polaris-CalloutCard__Buttons",
7432 "Container": "Polaris-CalloutCard__Container",
7433 "Dismiss": "Polaris-CalloutCard__Dismiss"
7434};
7435
7436function CalloutCard(_ref) {
7437 var title = _ref.title,
7438 children = _ref.children,
7439 illustration = _ref.illustration,
7440 primaryAction = _ref.primaryAction,
7441 secondaryAction = _ref.secondaryAction,
7442 onDismiss = _ref.onDismiss;
7443 var primaryActionMarkup = buttonFrom(primaryAction);
7444 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
7445 plain: true
7446 }) : null;
7447 var buttonMarkup = secondaryActionMarkup ? React__default.createElement(ButtonGroup, null, primaryActionMarkup, secondaryActionMarkup) : primaryActionMarkup;
7448 var dismissButton = onDismiss ? React__default.createElement("div", {
7449 className: styles$A.Dismiss
7450 }, React__default.createElement(Button, {
7451 plain: true,
7452 icon: polarisIcons.CancelSmallMinor,
7453 onClick: onDismiss,
7454 accessibilityLabel: "Dismiss card"
7455 })) : null;
7456 var imageClassName = classNames(styles$A.Image, onDismiss && styles$A.DismissImage);
7457 return React__default.createElement(Card, null, React__default.createElement("div", {
7458 className: styles$A.Container
7459 }, dismissButton, React__default.createElement(Card.Section, null, React__default.createElement("div", {
7460 className: styles$A.CalloutCard
7461 }, React__default.createElement("div", {
7462 className: styles$A.Content
7463 }, React__default.createElement("div", {
7464 className: styles$A.Title
7465 }, React__default.createElement(Heading, null, title)), React__default.createElement(TextContainer, null, children), React__default.createElement("div", {
7466 className: styles$A.Buttons
7467 }, buttonMarkup)), React__default.createElement(Image, {
7468 alt: "",
7469 className: imageClassName,
7470 source: illustration
7471 })))));
7472}
7473
7474var styles$B = {
7475 "Caption": "Polaris-Caption"
7476};
7477
7478function Caption(_ref) {
7479 var children = _ref.children;
7480 return React__default.createElement("p", {
7481 className: styles$B.Caption
7482 }, children);
7483}
7484
7485var styles$C = {
7486 "Choice": "Polaris-Choice",
7487 "labelHidden": "Polaris-Choice--labelHidden",
7488 "Label": "Polaris-Choice__Label",
7489 "Control": "Polaris-Choice__Control",
7490 "disabled": "Polaris-Choice--disabled",
7491 "Descriptions": "Polaris-Choice__Descriptions",
7492 "HelpText": "Polaris-Choice__HelpText"
7493};
7494
7495function Choice(_ref) {
7496 var id = _ref.id,
7497 label = _ref.label,
7498 disabled = _ref.disabled,
7499 error = _ref.error,
7500 children = _ref.children,
7501 labelHidden = _ref.labelHidden,
7502 helpText = _ref.helpText,
7503 onClick = _ref.onClick;
7504 var className = classNames(styles$C.Choice, labelHidden && styles$C.labelHidden, disabled && styles$C.disabled);
7505 var labelMarkup = React__default.createElement("label", {
7506 className: className,
7507 htmlFor: id,
7508 onClick: onClick
7509 }, React__default.createElement("span", {
7510 className: styles$C.Control
7511 }, children), React__default.createElement("span", {
7512 className: styles$C.Label
7513 }, label));
7514 var helpTextMarkup = helpText ? React__default.createElement("div", {
7515 className: styles$C.HelpText,
7516 id: helpTextID$1(id)
7517 }, helpText) : null;
7518 var errorMarkup = error && typeof error !== 'boolean' && React__default.createElement("div", {
7519 className: styles$C.Error
7520 }, React__default.createElement(InlineError, {
7521 message: error,
7522 fieldID: id
7523 }));
7524 var descriptionMarkup = helpTextMarkup || errorMarkup ? React__default.createElement("div", {
7525 className: styles$C.Descriptions
7526 }, errorMarkup, helpTextMarkup) : null;
7527 return descriptionMarkup ? React__default.createElement("div", null, labelMarkup, descriptionMarkup) : labelMarkup;
7528}
7529function helpTextID$1(id) {
7530 return "".concat(id, "HelpText");
7531}
7532
7533var styles$D = {
7534 "Checkbox": "Polaris-Checkbox",
7535 "error": "Polaris-Checkbox--error",
7536 "Input": "Polaris-Checkbox__Input",
7537 "Backdrop": "Polaris-Checkbox__Backdrop",
7538 "Input-indeterminate": "Polaris-Checkbox__Input--indeterminate",
7539 "Icon": "Polaris-Checkbox__Icon"
7540};
7541
7542var Checkbox$1 = React__default.forwardRef(function Checkbox(_ref, ref) {
7543 var ariaDescribedByProp = _ref.ariaDescribedBy,
7544 label = _ref.label,
7545 labelHidden = _ref.labelHidden,
7546 _ref$checked = _ref.checked,
7547 checked = _ref$checked === void 0 ? false : _ref$checked,
7548 helpText = _ref.helpText,
7549 disabled = _ref.disabled,
7550 idProp = _ref.id,
7551 name = _ref.name,
7552 value = _ref.value,
7553 error = _ref.error,
7554 onChange = _ref.onChange,
7555 onFocus = _ref.onFocus,
7556 onBlur = _ref.onBlur;
7557 var inputNode = React.useRef(null);
7558 var id = useUniqueId('Checkbox', idProp);
7559 React.useImperativeHandle(ref, function () {
7560 return {
7561 focus: function focus() {
7562 if (inputNode.current) {
7563 inputNode.current.focus();
7564 }
7565 }
7566 };
7567 });
7568
7569 var handleInput = function handleInput() {
7570 if (onChange == null || inputNode.current == null || disabled) {
7571 return;
7572 }
7573
7574 onChange(!inputNode.current.checked, id);
7575 inputNode.current.focus();
7576 };
7577
7578 var handleKeyUp = function handleKeyUp(event) {
7579 var keyCode = event.keyCode;
7580 if (keyCode !== exports.Key.Space) return;
7581 handleInput();
7582 };
7583
7584 var describedBy = [];
7585
7586 if (error && typeof error !== 'boolean') {
7587 describedBy.push(errorTextID(id));
7588 }
7589
7590 if (helpText) {
7591 describedBy.push(helpTextID$1(id));
7592 }
7593
7594 if (ariaDescribedByProp) {
7595 describedBy.push(ariaDescribedByProp);
7596 }
7597
7598 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
7599 var wrapperClassName = classNames(styles$D.Checkbox, error && styles$D.error);
7600 var isIndeterminate = checked === 'indeterminate';
7601 var isChecked = !isIndeterminate && Boolean(checked);
7602 var indeterminateAttributes = isIndeterminate ? {
7603 indeterminate: 'true',
7604 'aria-checked': 'mixed'
7605 } : {
7606 'aria-checked': isChecked
7607 };
7608 var iconSource = isIndeterminate ? polarisIcons.MinusMinor : polarisIcons.TickSmallMinor;
7609 var inputClassName = classNames(styles$D.Input, isIndeterminate && styles$D['Input-indeterminate']);
7610 return (
7611 /* eslint-disable jsx-a11y/no-redundant-roles */
7612 React__default.createElement(Choice, {
7613 id: id,
7614 label: label,
7615 labelHidden: labelHidden,
7616 helpText: helpText,
7617 error: error,
7618 disabled: disabled,
7619 onClick: handleInput
7620 }, React__default.createElement("span", {
7621 className: wrapperClassName
7622 }, React__default.createElement("input", Object.assign({
7623 onKeyUp: handleKeyUp,
7624 ref: inputNode,
7625 id: id,
7626 name: name,
7627 value: value,
7628 type: "checkbox",
7629 checked: isChecked,
7630 disabled: disabled,
7631 className: inputClassName,
7632 onFocus: onFocus,
7633 onBlur: onBlur,
7634 onClick: stopPropagation,
7635 onChange: noop$3,
7636 "aria-invalid": error != null,
7637 "aria-describedby": ariaDescribedBy,
7638 role: "checkbox"
7639 }, indeterminateAttributes)), React__default.createElement("span", {
7640 className: styles$D.Backdrop
7641 }), React__default.createElement("span", {
7642 className: styles$D.Icon
7643 }, React__default.createElement(Icon, {
7644 source: iconSource
7645 }))))
7646 /* eslint-enable jsx-a11y/no-redundant-roles */
7647
7648 );
7649});
7650
7651function noop$3() {}
7652
7653function stopPropagation(event) {
7654 event.stopPropagation();
7655}
7656
7657var styles$E = {
7658 "RadioButton": "Polaris-RadioButton",
7659 "Input": "Polaris-RadioButton__Input",
7660 "Backdrop": "Polaris-RadioButton__Backdrop",
7661 "Icon": "Polaris-RadioButton__Icon"
7662};
7663
7664function RadioButton(_ref) {
7665 var ariaDescribedByProp = _ref.ariaDescribedBy,
7666 label = _ref.label,
7667 labelHidden = _ref.labelHidden,
7668 helpText = _ref.helpText,
7669 checked = _ref.checked,
7670 disabled = _ref.disabled,
7671 onChange = _ref.onChange,
7672 onFocus = _ref.onFocus,
7673 onBlur = _ref.onBlur,
7674 idProp = _ref.id,
7675 nameProp = _ref.name,
7676 value = _ref.value;
7677 var id = useUniqueId('RadioButton', idProp);
7678 var name = nameProp || id;
7679
7680 function handleChange(_ref2) {
7681 var currentTarget = _ref2.currentTarget;
7682 onChange && onChange(currentTarget.checked, id);
7683 }
7684
7685 var describedBy = [];
7686
7687 if (helpText) {
7688 describedBy.push(helpTextID$1(id));
7689 }
7690
7691 if (ariaDescribedByProp) {
7692 describedBy.push(ariaDescribedByProp);
7693 }
7694
7695 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
7696 return React__default.createElement(Choice, {
7697 label: label,
7698 labelHidden: labelHidden,
7699 disabled: disabled,
7700 id: id,
7701 helpText: helpText
7702 }, React__default.createElement("span", {
7703 className: styles$E.RadioButton
7704 }, React__default.createElement("input", {
7705 id: id,
7706 name: name,
7707 value: value,
7708 type: "radio",
7709 checked: checked,
7710 disabled: disabled,
7711 className: styles$E.Input,
7712 onChange: handleChange,
7713 onFocus: onFocus,
7714 onBlur: onBlur,
7715 "aria-describedby": ariaDescribedBy
7716 }), React__default.createElement("span", {
7717 className: styles$E.Backdrop
7718 }), React__default.createElement("span", {
7719 className: styles$E.Icon
7720 })));
7721}
7722
7723var styles$F = {
7724 "ChoiceList": "Polaris-ChoiceList",
7725 "titleHidden": "Polaris-ChoiceList--titleHidden",
7726 "Title": "Polaris-ChoiceList__Title",
7727 "Choices": "Polaris-ChoiceList__Choices",
7728 "ChoiceChildren": "Polaris-ChoiceList__ChoiceChildren",
7729 "ChoiceError": "Polaris-ChoiceList__ChoiceError"
7730};
7731
7732function ChoiceList(_ref) {
7733 var title = _ref.title,
7734 titleHidden = _ref.titleHidden,
7735 allowMultiple = _ref.allowMultiple,
7736 choices = _ref.choices,
7737 selected = _ref.selected,
7738 _ref$onChange = _ref.onChange,
7739 onChange = _ref$onChange === void 0 ? noop$4 : _ref$onChange,
7740 error = _ref.error,
7741 _ref$disabled = _ref.disabled,
7742 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
7743 nameProp = _ref.name;
7744 // Type asserting to any is required for TS3.2 but can be removed when we update to 3.3
7745 // see https://github.com/Microsoft/TypeScript/issues/28768
7746 var ControlComponent = allowMultiple ? Checkbox$1 : RadioButton;
7747 var name = useUniqueId('ChoiceList', nameProp);
7748 var finalName = allowMultiple ? "".concat(name, "[]") : name;
7749 var className = classNames(styles$F.ChoiceList, titleHidden && styles$F.titleHidden);
7750 var titleMarkup = title ? React__default.createElement("legend", {
7751 className: styles$F.Title
7752 }, title) : null;
7753 var choicesMarkup = choices.map(function (choice) {
7754 var value = choice.value,
7755 label = choice.label,
7756 helpText = choice.helpText,
7757 choiceDisabled = choice.disabled,
7758 describedByError = choice.describedByError;
7759
7760 function handleChange(checked) {
7761 onChange(updateSelectedChoices(choice, checked, selected, allowMultiple), name);
7762 }
7763
7764 var isSelected = choiceIsSelected(choice, selected);
7765 var renderedChildren = choice.renderChildren ? choice.renderChildren(isSelected) : null;
7766 var children = renderedChildren ? React__default.createElement("div", {
7767 className: styles$F.ChoiceChildren
7768 }, renderedChildren) : null;
7769 return React__default.createElement("li", {
7770 key: value
7771 }, React__default.createElement(ControlComponent, {
7772 name: finalName,
7773 value: value,
7774 label: label,
7775 disabled: choiceDisabled || disabled,
7776 checked: choiceIsSelected(choice, selected),
7777 helpText: helpText,
7778 onChange: handleChange,
7779 ariaDescribedBy: error && describedByError ? errorTextID(finalName) : null
7780 }), children);
7781 });
7782 var errorMarkup = error && React__default.createElement("div", {
7783 className: styles$F.ChoiceError
7784 }, React__default.createElement(InlineError, {
7785 message: error,
7786 fieldID: finalName
7787 }));
7788 return React__default.createElement("fieldset", {
7789 className: className,
7790 id: finalName,
7791 "aria-invalid": error != null
7792 }, titleMarkup, React__default.createElement("ul", {
7793 className: styles$F.Choices
7794 }, choicesMarkup), errorMarkup);
7795}
7796
7797function noop$4() {}
7798
7799function choiceIsSelected(_ref2, selected) {
7800 var value = _ref2.value;
7801 return selected.includes(value);
7802}
7803
7804function updateSelectedChoices(_ref3, checked, selected) {
7805 var value = _ref3.value;
7806 var allowMultiple = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
7807
7808 if (checked) {
7809 return allowMultiple ? [].concat(_toConsumableArray(selected), [value]) : [value];
7810 }
7811
7812 return selected.filter(function (selectedChoice) {
7813 return selectedChoice !== value;
7814 });
7815}
7816
7817var styles$G = {
7818 "Collapsible": "Polaris-Collapsible",
7819 "animating": "Polaris-Collapsible--animating",
7820 "open": "Polaris-Collapsible--open",
7821 "fullyOpen": "Polaris-Collapsible--fullyOpen"
7822};
7823
7824var ParentCollapsibleExpandingContext = React.createContext(false);
7825
7826var Collapsible =
7827/*#__PURE__*/
7828function (_React$Component) {
7829 _inherits(Collapsible, _React$Component);
7830
7831 function Collapsible() {
7832 var _this;
7833
7834 _classCallCheck(this, Collapsible);
7835
7836 _this = _possibleConstructorReturn(this, _getPrototypeOf(Collapsible).apply(this, arguments));
7837 _this.state = {
7838 height: null,
7839 animationState: 'idle',
7840 // eslint-disable-next-line react/no-unused-state
7841 open: _this.props.open
7842 };
7843 _this.node = React.createRef();
7844 _this.heightNode = React.createRef();
7845
7846 _this.handleTransitionEnd = function (event) {
7847 var target = event.target;
7848
7849 if (target === _this.node.current) {
7850 _this.setState({
7851 animationState: 'idle',
7852 height: null
7853 });
7854 }
7855 };
7856
7857 return _this;
7858 }
7859
7860 _createClass(Collapsible, [{
7861 key: "componentDidUpdate",
7862 value: function componentDidUpdate(_ref) {
7863 var _this2 = this;
7864
7865 var wasOpen = _ref.open;
7866 var animationState = this.state.animationState;
7867 var parentCollapsibleExpanding = this.context;
7868
7869 if (parentCollapsibleExpanding && animationState !== 'idle') {
7870 // eslint-disable-next-line react/no-did-update-set-state
7871 this.setState({
7872 animationState: 'idle'
7873 });
7874 return;
7875 }
7876
7877 fastdom.read(function () {
7878 var heightNode = _this2.heightNode.current;
7879
7880 switch (animationState) {
7881 case 'idle':
7882 break;
7883
7884 case 'measuring':
7885 _this2.setState({
7886 animationState: wasOpen ? 'closingStart' : 'openingStart',
7887 height: wasOpen && heightNode ? heightNode.scrollHeight : 0
7888 });
7889
7890 break;
7891
7892 case 'closingStart':
7893 _this2.setState({
7894 animationState: 'closing',
7895 height: 0
7896 });
7897
7898 break;
7899
7900 case 'openingStart':
7901 _this2.setState({
7902 animationState: 'opening',
7903 height: heightNode ? heightNode.scrollHeight : 0
7904 });
7905
7906 }
7907 });
7908 }
7909 }, {
7910 key: "render",
7911 value: function render() {
7912 var _this$props = this.props,
7913 id = _this$props.id,
7914 open = _this$props.open,
7915 children = _this$props.children;
7916 var _this$state = this.state,
7917 animationState = _this$state.animationState,
7918 height = _this$state.height;
7919 var parentCollapsibleExpanding = this.context;
7920 var animating = animationState !== 'idle';
7921 var wrapperClassName = classNames(styles$G.Collapsible, open && styles$G.open, animating && styles$G.animating, !animating && open && styles$G.fullyOpen);
7922 var displayHeight = collapsibleHeight(open, animationState, height);
7923 var content = animating || open ? children : null;
7924 return React__default.createElement(ParentCollapsibleExpandingContext.Provider, {
7925 value: parentCollapsibleExpanding || open && animationState !== 'idle'
7926 }, React__default.createElement("div", {
7927 id: id,
7928 "aria-hidden": !open,
7929 style: {
7930 maxHeight: displayHeight
7931 },
7932 className: wrapperClassName,
7933 ref: this.node,
7934 onTransitionEnd: this.handleTransitionEnd
7935 }, React__default.createElement("div", {
7936 ref: this.heightNode
7937 }, content)));
7938 }
7939 }], [{
7940 key: "getDerivedStateFromProps",
7941 value: function getDerivedStateFromProps(_ref2, _ref3) {
7942 var willOpen = _ref2.open;
7943 var open = _ref3.open,
7944 prevAnimationState = _ref3.animationState;
7945 var nextAnimationState = prevAnimationState;
7946
7947 if (open !== willOpen) {
7948 nextAnimationState = 'measuring';
7949 }
7950
7951 return {
7952 animationState: nextAnimationState,
7953 open: willOpen
7954 };
7955 }
7956 }]);
7957
7958 return Collapsible;
7959}(React__default.Component);
7960
7961Collapsible.contextType = ParentCollapsibleExpandingContext;
7962
7963function collapsibleHeight(open, animationState, height) {
7964 if (animationState === 'idle' && open) {
7965 return open ? 'none' : undefined;
7966 }
7967
7968 if (animationState === 'measuring') {
7969 return open ? undefined : 'none';
7970 }
7971
7972 return "".concat(height || 0, "px");
7973} // Use named export once we work out why not casting this breaks web
7974
7975var styles$H = {
7976 "ColorPicker": "Polaris-ColorPicker",
7977 "MainColor": "Polaris-ColorPicker__MainColor",
7978 "Dragger": "Polaris-ColorPicker__Dragger",
7979 "ColorLayer": "Polaris-ColorPicker__ColorLayer",
7980 "HuePicker": "Polaris-ColorPicker__HuePicker",
7981 "AlphaPicker": "Polaris-ColorPicker__AlphaPicker",
7982 "Slidable": "Polaris-ColorPicker__Slidable"
7983};
7984
7985var isDragging = false; // Required to solve a bug causing the underlying page/container to scroll
7986// while trying to drag the ColorPicker controls.
7987// This must be called as soon as possible to properly prevent the event.
7988// `passive: false` must also be set, as it seems webkit has changed the "default" behaviour
7989// https://bugs.webkit.org/show_bug.cgi?id=182521
7990
7991if (!isServer) {
7992 window.addEventListener('touchmove', function (event) {
7993 if (!isDragging) {
7994 return;
7995 }
7996
7997 event.preventDefault();
7998 }, {
7999 passive: false
8000 });
8001}
8002
8003var Slidable =
8004/*#__PURE__*/
8005function (_React$PureComponent) {
8006 _inherits(Slidable, _React$PureComponent);
8007
8008 function Slidable() {
8009 var _this;
8010
8011 _classCallCheck(this, Slidable);
8012
8013 _this = _possibleConstructorReturn(this, _getPrototypeOf(Slidable).apply(this, arguments));
8014 _this.state = {
8015 dragging: false
8016 };
8017 _this.node = null;
8018 _this.draggerNode = null;
8019
8020 _this.setDraggerNode = function (node) {
8021 _this.draggerNode = node;
8022 };
8023
8024 _this.setNode = function (node) {
8025 _this.node = node;
8026 };
8027
8028 _this.startDrag = function (event) {
8029 if (event.type === 'mousedown') {
8030 var mouseEvent = event;
8031
8032 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
8033 }
8034
8035 isDragging = true;
8036
8037 _this.setState({
8038 dragging: true
8039 });
8040 };
8041
8042 _this.handleDragEnd = function () {
8043 isDragging = false;
8044
8045 _this.setState({
8046 dragging: false
8047 });
8048 };
8049
8050 _this.handleMove = function (event) {
8051 event.stopImmediatePropagation();
8052 event.stopPropagation();
8053
8054 if (event.cancelable) {
8055 event.preventDefault();
8056 }
8057
8058 if (event.type === 'mousemove') {
8059 var mouseEvent = event;
8060
8061 _this.handleDraggerMove(mouseEvent.clientX, mouseEvent.clientY);
8062
8063 return;
8064 }
8065
8066 var touchEvent = event;
8067
8068 _this.handleDraggerMove(touchEvent.touches[0].clientX, touchEvent.touches[0].clientY);
8069 };
8070
8071 _this.handleDraggerMove = function (x, y) {
8072 if (_this.node == null) {
8073 return;
8074 }
8075
8076 var onChange = _this.props.onChange;
8077
8078 var rect = _this.node.getBoundingClientRect();
8079
8080 var offsetX = x - rect.left;
8081 var offsetY = y - rect.top;
8082 onChange({
8083 x: offsetX,
8084 y: offsetY
8085 });
8086 };
8087
8088 return _this;
8089 }
8090
8091 _createClass(Slidable, [{
8092 key: "componentDidMount",
8093 value: function componentDidMount() {
8094 var onDraggerHeight = this.props.onDraggerHeight;
8095
8096 if (onDraggerHeight == null) {
8097 return;
8098 }
8099
8100 var draggerNode = this.draggerNode;
8101
8102 if (draggerNode == null) {
8103 return;
8104 }
8105
8106 onDraggerHeight(draggerNode.clientWidth);
8107
8108 if (process.env.NODE_ENV === 'development') {
8109 setTimeout(function () {
8110 onDraggerHeight(draggerNode.clientWidth);
8111 }, 0);
8112 }
8113 }
8114 }, {
8115 key: "render",
8116 value: function render() {
8117 var dragging = this.state.dragging;
8118 var _this$props = this.props,
8119 _this$props$draggerX = _this$props.draggerX,
8120 draggerX = _this$props$draggerX === void 0 ? 0 : _this$props$draggerX,
8121 _this$props$draggerY = _this$props.draggerY,
8122 draggerY = _this$props$draggerY === void 0 ? 0 : _this$props$draggerY;
8123 var draggerPositioning = {
8124 transform: "translate3d(".concat(draggerX, "px, ").concat(draggerY, "px, 0)")
8125 };
8126 var moveListener = dragging ? React__default.createElement(EventListener, {
8127 event: "mousemove",
8128 handler: this.handleMove,
8129 passive: false
8130 }) : null;
8131 var touchMoveListener = dragging ? React__default.createElement(EventListener, {
8132 event: "touchmove",
8133 handler: this.handleMove,
8134 passive: false
8135 }) : null;
8136 var endDragListener = dragging ? React__default.createElement(EventListener, {
8137 event: "mouseup",
8138 handler: this.handleDragEnd
8139 }) : null;
8140 var touchEndListener = dragging ? React__default.createElement(EventListener, {
8141 event: "touchend",
8142 handler: this.handleDragEnd
8143 }) : null;
8144 var touchCancelListener = dragging ? React__default.createElement(EventListener, {
8145 event: "touchcancel",
8146 handler: this.handleDragEnd
8147 }) : null;
8148 return React__default.createElement("div", {
8149 ref: this.setNode,
8150 className: styles$H.Slidable,
8151 onMouseDown: this.startDrag,
8152 onTouchStart: this.startDrag
8153 }, endDragListener, moveListener, touchMoveListener, touchEndListener, touchCancelListener, React__default.createElement("div", {
8154 style: draggerPositioning,
8155 className: styles$H.Dragger,
8156 ref: this.setDraggerNode
8157 }));
8158 }
8159 }]);
8160
8161 return Slidable;
8162}(React__default.PureComponent);
8163
8164var VERTICAL_PADDING = 13;
8165function calculateDraggerY(alpha, sliderHeight, draggerHeight) {
8166 var offset = offsetForAlpha(alpha, sliderHeight, draggerHeight);
8167 return math.clamp(offset, 0, sliderHeight);
8168}
8169function alphaForDraggerY(y, sliderHeight) {
8170 var offsetY = math.clamp(y, 0, sliderHeight);
8171 return alphaForOffset(offsetY, sliderHeight);
8172}
8173function alphaForOffset(offset, sliderHeight) {
8174 var selectionHeight = offset - VERTICAL_PADDING;
8175 var slidableArea = sliderHeight - VERTICAL_PADDING * 2;
8176 return math.clamp(1 - selectionHeight / slidableArea, 0, 1);
8177}
8178
8179function offsetForAlpha(alpha, sliderHeight, draggerHeight) {
8180 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING);
8181 return math.clamp((1 - alpha) * slidableArea + VERTICAL_PADDING, 0, sliderHeight - draggerHeight);
8182}
8183
8184var AlphaPicker =
8185/*#__PURE__*/
8186function (_React$PureComponent) {
8187 _inherits(AlphaPicker, _React$PureComponent);
8188
8189 function AlphaPicker() {
8190 var _this;
8191
8192 _classCallCheck(this, AlphaPicker);
8193
8194 _this = _possibleConstructorReturn(this, _getPrototypeOf(AlphaPicker).apply(this, arguments));
8195 _this.state = {
8196 sliderHeight: 0,
8197 draggerHeight: 0
8198 };
8199
8200 _this.setSliderHeight = function (node) {
8201 if (node == null) {
8202 return;
8203 }
8204
8205 _this.setState({
8206 sliderHeight: node.clientHeight
8207 });
8208
8209 if (process.env.NODE_ENV === 'development') {
8210 setTimeout(function () {
8211 _this.setState({
8212 sliderHeight: node.clientHeight
8213 });
8214 }, 0);
8215 }
8216 };
8217
8218 _this.setDraggerHeight = function (height) {
8219 _this.setState({
8220 draggerHeight: height
8221 });
8222 };
8223
8224 _this.handleChange = function (_ref) {
8225 var y = _ref.y;
8226 var onChange = _this.props.onChange;
8227 var sliderHeight = _this.state.sliderHeight;
8228 var alpha = alphaForDraggerY(y, sliderHeight);
8229 onChange(alpha);
8230 };
8231
8232 return _this;
8233 }
8234
8235 _createClass(AlphaPicker, [{
8236 key: "render",
8237 value: function render() {
8238 var _this$props = this.props,
8239 color = _this$props.color,
8240 alpha = _this$props.alpha;
8241 var _this$state = this.state,
8242 sliderHeight = _this$state.sliderHeight,
8243 draggerHeight = _this$state.draggerHeight;
8244 var draggerY = calculateDraggerY(alpha, sliderHeight, draggerHeight);
8245 var background = alphaGradientForColor(color);
8246 return React__default.createElement("div", {
8247 className: styles$H.AlphaPicker,
8248 ref: this.setSliderHeight
8249 }, React__default.createElement("div", {
8250 className: styles$H.ColorLayer,
8251 style: {
8252 background
8253 }
8254 }), React__default.createElement(Slidable, {
8255 draggerY: draggerY,
8256 draggerX: 0,
8257 onChange: this.handleChange,
8258 onDraggerHeight: this.setDraggerHeight
8259 }));
8260 }
8261 }]);
8262
8263 return AlphaPicker;
8264}(React__default.PureComponent);
8265
8266function alphaGradientForColor(color) {
8267 var _hsbToRgb = hsbToRgb(color),
8268 red = _hsbToRgb.red,
8269 green = _hsbToRgb.green,
8270 blue = _hsbToRgb.blue;
8271
8272 var rgb = "".concat(red, ", ").concat(green, ", ").concat(blue);
8273 return "linear-gradient(to top, rgba(".concat(rgb, ", 0) 18px, rgba(").concat(rgb, ", 1) calc(100% - 18px))");
8274}
8275
8276var VERTICAL_PADDING$1 = 13;
8277function calculateDraggerY$1(hue, sliderHeight, draggerHeight) {
8278 var offset = offsetForHue(hue, sliderHeight, draggerHeight);
8279 return math.clamp(offset, 0, sliderHeight);
8280}
8281function hueForDraggerY(y, sliderHeight) {
8282 var offsetY = math.clamp(y, 0, sliderHeight);
8283 return hueForOffset(offsetY, sliderHeight);
8284}
8285
8286function hueForOffset(offset, sliderHeight) {
8287 var selectionHeight = offset - VERTICAL_PADDING$1;
8288 var slidableArea = sliderHeight - VERTICAL_PADDING$1 * 2;
8289 return math.clamp(selectionHeight / slidableArea * 360, 0, 360);
8290}
8291
8292function offsetForHue(hue, sliderHeight, draggerHeight) {
8293 var slidableArea = sliderHeight - (draggerHeight + VERTICAL_PADDING$1);
8294 return math.clamp(hue / 360 * slidableArea + VERTICAL_PADDING$1, 0, sliderHeight - draggerHeight);
8295}
8296
8297var HuePicker =
8298/*#__PURE__*/
8299function (_React$PureComponent) {
8300 _inherits(HuePicker, _React$PureComponent);
8301
8302 function HuePicker() {
8303 var _this;
8304
8305 _classCallCheck(this, HuePicker);
8306
8307 _this = _possibleConstructorReturn(this, _getPrototypeOf(HuePicker).apply(this, arguments));
8308 _this.state = {
8309 sliderHeight: 0,
8310 draggerHeight: 0
8311 };
8312
8313 _this.setSliderHeight = function (node) {
8314 if (node == null) {
8315 return;
8316 }
8317
8318 _this.setState({
8319 sliderHeight: node.clientHeight
8320 });
8321
8322 if (process.env.NODE_ENV === 'development') {
8323 setTimeout(function () {
8324 _this.setState({
8325 sliderHeight: node.clientHeight
8326 });
8327 }, 0);
8328 }
8329 };
8330
8331 _this.setDraggerHeight = function (height) {
8332 _this.setState({
8333 draggerHeight: height
8334 });
8335 };
8336
8337 _this.handleChange = function (_ref) {
8338 var y = _ref.y;
8339 var onChange = _this.props.onChange;
8340 var sliderHeight = _this.state.sliderHeight;
8341 var hue = hueForDraggerY(y, sliderHeight);
8342 onChange(hue);
8343 };
8344
8345 return _this;
8346 }
8347
8348 _createClass(HuePicker, [{
8349 key: "render",
8350 value: function render() {
8351 var hue = this.props.hue;
8352 var _this$state = this.state,
8353 sliderHeight = _this$state.sliderHeight,
8354 draggerHeight = _this$state.draggerHeight;
8355 var draggerY = calculateDraggerY$1(hue, sliderHeight, draggerHeight);
8356 return React__default.createElement("div", {
8357 className: styles$H.HuePicker,
8358 ref: this.setSliderHeight
8359 }, React__default.createElement(Slidable, {
8360 draggerY: draggerY,
8361 draggerX: 0,
8362 onChange: this.handleChange,
8363 onDraggerHeight: this.setDraggerHeight
8364 }));
8365 }
8366 }]);
8367
8368 return HuePicker;
8369}(React__default.PureComponent);
8370
8371var ColorPicker =
8372/*#__PURE__*/
8373function (_React$PureComponent) {
8374 _inherits(ColorPicker, _React$PureComponent);
8375
8376 function ColorPicker() {
8377 var _this;
8378
8379 _classCallCheck(this, ColorPicker);
8380
8381 _this = _possibleConstructorReturn(this, _getPrototypeOf(ColorPicker).apply(this, arguments));
8382 _this.state = {
8383 pickerSize: 0
8384 };
8385 _this.colorNode = null;
8386
8387 _this.setColorNode = function (node) {
8388 _this.colorNode = node;
8389 };
8390
8391 _this.handleHueChange = function (hue) {
8392 var _this$props = _this.props,
8393 _this$props$color = _this$props.color,
8394 brightness = _this$props$color.brightness,
8395 saturation = _this$props$color.saturation,
8396 _this$props$color$alp = _this$props$color.alpha,
8397 alpha = _this$props$color$alp === void 0 ? 1 : _this$props$color$alp,
8398 onChange = _this$props.onChange;
8399 onChange({
8400 hue,
8401 brightness,
8402 saturation,
8403 alpha
8404 });
8405 };
8406
8407 _this.handleAlphaChange = function (alpha) {
8408 var _this$props2 = _this.props,
8409 _this$props2$color = _this$props2.color,
8410 hue = _this$props2$color.hue,
8411 brightness = _this$props2$color.brightness,
8412 saturation = _this$props2$color.saturation,
8413 onChange = _this$props2.onChange;
8414 onChange({
8415 hue,
8416 brightness,
8417 saturation,
8418 alpha
8419 });
8420 };
8421
8422 _this.handleDraggerMove = function (_ref) {
8423 var x = _ref.x,
8424 y = _ref.y;
8425 var pickerSize = _this.state.pickerSize;
8426 var _this$props3 = _this.props,
8427 _this$props3$color = _this$props3.color,
8428 hue = _this$props3$color.hue,
8429 _this$props3$color$al = _this$props3$color.alpha,
8430 alpha = _this$props3$color$al === void 0 ? 1 : _this$props3$color$al,
8431 onChange = _this$props3.onChange;
8432 var saturation = math.clamp(x / pickerSize, 0, 1);
8433 var brightness = math.clamp(1 - y / pickerSize, 0, 1);
8434 onChange({
8435 hue,
8436 saturation,
8437 brightness,
8438 alpha
8439 });
8440 };
8441
8442 _this.handlePickerDrag = function (event) {
8443 // prevents external elements from being selected
8444 event.preventDefault();
8445 };
8446
8447 return _this;
8448 }
8449
8450 _createClass(ColorPicker, [{
8451 key: "componentDidMount",
8452 value: function componentDidMount() {
8453 var _this2 = this;
8454
8455 var colorNode = this.colorNode;
8456
8457 if (colorNode == null) {
8458 return;
8459 }
8460
8461 this.setState({
8462 pickerSize: colorNode.clientWidth
8463 });
8464
8465 if (process.env.NODE_ENV === 'development') {
8466 setTimeout(function () {
8467 _this2.setState({
8468 pickerSize: colorNode.clientWidth
8469 });
8470 }, 0);
8471 }
8472 }
8473 }, {
8474 key: "render",
8475 value: function render() {
8476 var _this$props4 = this.props,
8477 id = _this$props4.id,
8478 color = _this$props4.color,
8479 allowAlpha = _this$props4.allowAlpha;
8480 var hue = color.hue,
8481 saturation = color.saturation,
8482 brightness = color.brightness,
8483 providedAlpha = color.alpha;
8484 var pickerSize = this.state.pickerSize;
8485 var alpha = providedAlpha != null && allowAlpha ? providedAlpha : 1;
8486
8487 var _hsbToRgb = hsbToRgb({
8488 hue,
8489 saturation: 1,
8490 brightness: 1
8491 }),
8492 red = _hsbToRgb.red,
8493 green = _hsbToRgb.green,
8494 blue = _hsbToRgb.blue;
8495
8496 var colorString = "rgba(".concat(red, ", ").concat(green, ", ").concat(blue, ", ").concat(alpha, ")");
8497 var draggerX = math.clamp(saturation * pickerSize, 0, pickerSize);
8498 var draggerY = math.clamp(pickerSize - brightness * pickerSize, 0, pickerSize);
8499 var alphaSliderMarkup = allowAlpha ? React__default.createElement(AlphaPicker, {
8500 alpha: alpha,
8501 color: color,
8502 onChange: this.handleAlphaChange
8503 }) : null;
8504 return React__default.createElement("div", {
8505 className: styles$H.ColorPicker,
8506 id: id,
8507 onMouseDown: this.handlePickerDrag
8508 }, React__default.createElement("div", {
8509 ref: this.setColorNode,
8510 className: styles$H.MainColor
8511 }, React__default.createElement("div", {
8512 className: styles$H.ColorLayer,
8513 style: {
8514 backgroundColor: colorString
8515 }
8516 }), React__default.createElement(Slidable, {
8517 onChange: this.handleDraggerMove,
8518 draggerX: draggerX,
8519 draggerY: draggerY
8520 })), React__default.createElement(HuePicker, {
8521 hue: hue,
8522 onChange: this.handleHueChange
8523 }), alphaSliderMarkup);
8524 }
8525 }]);
8526
8527 return ColorPicker;
8528}(React__default.PureComponent);
8529
8530var FrameContext = React__default.createContext(undefined);
8531
8532var defaultFrame = {
8533 showToast: noop$5,
8534 hideToast: noop$5,
8535 setContextualSaveBar: noop$5,
8536 removeContextualSaveBar: noop$5,
8537 startLoading: noop$5,
8538 stopLoading: noop$5
8539};
8540function useFrame() {
8541 var frame = React.useContext(FrameContext);
8542 var appBridge = useAppBridge();
8543
8544 if (!frame && !appBridge) {
8545 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.');
8546 } // This makes sure the useFrame hook always returns a FrameContext object, never undefined
8547
8548
8549 if (appBridge || !frame) {
8550 return defaultFrame;
8551 }
8552
8553 return frame;
8554}
8555
8556function noop$5() {}
8557
8558var ContextualSaveBar = React__default.memo(function ContextualSaveBar(_ref) {
8559 var message = _ref.message,
8560 saveAction = _ref.saveAction,
8561 discardAction = _ref.discardAction,
8562 alignContentFlush = _ref.alignContentFlush;
8563
8564 var _useFrame = useFrame(),
8565 setContextualSaveBar = _useFrame.setContextualSaveBar,
8566 removeContextualSaveBar = _useFrame.removeContextualSaveBar;
8567
8568 React__default.useEffect(function () {
8569 setContextualSaveBar({
8570 message,
8571 saveAction,
8572 discardAction,
8573 alignContentFlush
8574 });
8575 }, [message, saveAction, discardAction, alignContentFlush, setContextualSaveBar]);
8576 React__default.useEffect(function () {
8577 return removeContextualSaveBar;
8578 }, [removeContextualSaveBar]);
8579 return null;
8580});
8581
8582function withAppProvider() {
8583 return function addProvider(WrappedComponent) {
8584 var WithAppProvider = function WithAppProvider(props) {
8585 var polaris = {
8586 intl: useI18n(),
8587 stickyManager: useStickyManager(),
8588 appBridge: useAppBridge(),
8589 mediaQuery: useMediaQuery()
8590 };
8591 return React__default.createElement(WrappedComponent, Object.assign({}, props, {
8592 polaris: polaris
8593 }));
8594 };
8595
8596 WithAppProvider.displayName = "WithAppProvider(".concat(getDisplayName(WrappedComponent), ")");
8597 var FinalComponent = hoistStatics(WithAppProvider, WrappedComponent);
8598 return FinalComponent;
8599 };
8600}
8601
8602function getDisplayName(WrappedComponent) {
8603 return WrappedComponent.displayName || WrappedComponent.name || 'Component';
8604}
8605
8606var styles$I = {
8607 "DataTable": "Polaris-DataTable",
8608 "condensed": "Polaris-DataTable--condensed",
8609 "Navigation": "Polaris-DataTable__Navigation",
8610 "Pip": "Polaris-DataTable__Pip",
8611 "Pip-visible": "Polaris-DataTable__Pip--visible",
8612 "ScrollContainer": "Polaris-DataTable__ScrollContainer",
8613 "Table": "Polaris-DataTable__Table",
8614 "TableRow": "Polaris-DataTable__TableRow",
8615 "Cell": "Polaris-DataTable__Cell",
8616 "Cell-firstColumn": "Polaris-DataTable__Cell--firstColumn",
8617 "Cell-numeric": "Polaris-DataTable__Cell--numeric",
8618 "Cell-truncated": "Polaris-DataTable__Cell--truncated",
8619 "Cell-header": "Polaris-DataTable__Cell--header",
8620 "Cell-sortable": "Polaris-DataTable__Cell--sortable",
8621 "Cell-verticalAlignTop": "Polaris-DataTable__Cell--verticalAlignTop",
8622 "Cell-verticalAlignBottom": "Polaris-DataTable__Cell--verticalAlignBottom",
8623 "Cell-verticalAlignMiddle": "Polaris-DataTable__Cell--verticalAlignMiddle",
8624 "Cell-verticalAlignBaseline": "Polaris-DataTable__Cell--verticalAlignBaseline",
8625 "Icon": "Polaris-DataTable__Icon",
8626 "Heading": "Polaris-DataTable__Heading",
8627 "Heading-left": "Polaris-DataTable__Heading--left",
8628 "Cell-sorted": "Polaris-DataTable__Cell--sorted",
8629 "Cell-total": "Polaris-DataTable__Cell--total",
8630 "Cell-total-footer": "Polaris-DataTable--cellTotalFooter",
8631 "Footer": "Polaris-DataTable__Footer"
8632};
8633
8634function Cell(_ref) {
8635 var content = _ref.content,
8636 contentType = _ref.contentType,
8637 firstColumn = _ref.firstColumn,
8638 truncate = _ref.truncate,
8639 header = _ref.header,
8640 total = _ref.total,
8641 totalInFooter = _ref.totalInFooter,
8642 sorted = _ref.sorted,
8643 sortable = _ref.sortable,
8644 sortDirection = _ref.sortDirection,
8645 _ref$verticalAlign = _ref.verticalAlign,
8646 verticalAlign = _ref$verticalAlign === void 0 ? 'top' : _ref$verticalAlign,
8647 _ref$defaultSortDirec = _ref.defaultSortDirection,
8648 defaultSortDirection = _ref$defaultSortDirec === void 0 ? 'ascending' : _ref$defaultSortDirec,
8649 onSort = _ref.onSort;
8650 var i18n = useI18n();
8651 var numeric = contentType === 'numeric';
8652 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']);
8653 var headerClassName = classNames(header && styles$I.Heading, header && contentType === 'text' && styles$I['Heading-left']);
8654 var iconClassName = classNames(sortable && styles$I.Icon);
8655 var direction = sorted ? sortDirection : defaultSortDirection;
8656 var source = direction === 'descending' ? polarisIcons.CaretDownMinor : polarisIcons.CaretUpMinor;
8657 var oppositeDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
8658 var sortAccessibilityLabel = i18n.translate('Polaris.DataTable.sortAccessibilityLabel', {
8659 direction: sorted ? oppositeDirection : direction
8660 });
8661 var iconMarkup = React__default.createElement("span", {
8662 className: iconClassName
8663 }, React__default.createElement(Icon, {
8664 source: source,
8665 accessibilityLabel: sortAccessibilityLabel
8666 }));
8667 var sortableHeadingContent = React__default.createElement("button", {
8668 className: headerClassName,
8669 onClick: onSort
8670 }, iconMarkup, content);
8671 var columnHeadingContent = sortable ? sortableHeadingContent : content;
8672 var headingMarkup = header ? React__default.createElement("th", Object.assign({}, headerCell.props, {
8673 className: className,
8674 scope: "col",
8675 "aria-sort": sortDirection
8676 }), columnHeadingContent) : React__default.createElement("th", {
8677 className: className,
8678 scope: "row"
8679 }, content);
8680 var cellMarkup = header || firstColumn ? headingMarkup : React__default.createElement("td", {
8681 className: className
8682 }, content);
8683 return cellMarkup;
8684}
8685
8686function Navigation(_ref) {
8687 var columnVisibilityData = _ref.columnVisibilityData,
8688 isScrolledFarthestLeft = _ref.isScrolledFarthestLeft,
8689 isScrolledFarthestRight = _ref.isScrolledFarthestRight,
8690 navigateTableLeft = _ref.navigateTableLeft,
8691 navigateTableRight = _ref.navigateTableRight;
8692 var i18n = useI18n();
8693 var pipMarkup = columnVisibilityData.map(function (column, index) {
8694 var className = classNames(styles$I.Pip, column.isVisible && styles$I['Pip-visible']);
8695 return React__default.createElement("div", {
8696 className: className,
8697 key: "pip-".concat(index)
8698 });
8699 });
8700 var leftA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
8701 direction: 'left'
8702 });
8703 var rightA11yLabel = i18n.translate('Polaris.DataTable.navAccessibilityLabel', {
8704 direction: 'right'
8705 });
8706 return React__default.createElement("div", {
8707 className: styles$I.Navigation
8708 }, React__default.createElement(Button, {
8709 plain: true,
8710 icon: polarisIcons.ChevronLeftMinor,
8711 disabled: isScrolledFarthestLeft,
8712 accessibilityLabel: leftA11yLabel,
8713 onClick: navigateTableLeft
8714 }), pipMarkup, React__default.createElement(Button, {
8715 plain: true,
8716 icon: polarisIcons.ChevronRightMinor,
8717 disabled: isScrolledFarthestRight,
8718 accessibilityLabel: rightA11yLabel,
8719 onClick: navigateTableRight
8720 }));
8721}
8722
8723function measureColumn(tableData) {
8724 return function (column, index) {
8725 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex,
8726 tableStart = tableData.tableLeftVisibleEdge,
8727 tableEnd = tableData.tableRightVisibleEdge;
8728 var leftEdge = column.offsetLeft;
8729 var rightEdge = leftEdge + column.offsetWidth;
8730 var isVisibleLeft = isEdgeVisible(leftEdge, tableStart, tableEnd);
8731 var isVisibleRight = isEdgeVisible(rightEdge, tableStart, tableEnd);
8732 var isVisible = isVisibleLeft || isVisibleRight;
8733
8734 if (isVisible) {
8735 tableData.firstVisibleColumnIndex = Math.min(firstVisibleColumnIndex, index);
8736 }
8737
8738 return {
8739 leftEdge,
8740 rightEdge,
8741 isVisible
8742 };
8743 };
8744}
8745function isEdgeVisible(position, start, end) {
8746 var minVisiblePixels = 30;
8747 return position >= start + minVisiblePixels && position <= end - minVisiblePixels;
8748}
8749function getPrevAndCurrentColumns(tableData, columnData) {
8750 var firstVisibleColumnIndex = tableData.firstVisibleColumnIndex;
8751 var previousColumnIndex = Math.max(firstVisibleColumnIndex - 1, 0);
8752 var previousColumn = columnData[previousColumnIndex];
8753 var currentColumn = columnData[firstVisibleColumnIndex];
8754 return {
8755 previousColumn,
8756 currentColumn
8757 };
8758}
8759
8760var DataTable =
8761/*#__PURE__*/
8762function (_React$PureComponent) {
8763 _inherits(DataTable, _React$PureComponent);
8764
8765 function DataTable(props) {
8766 var _this;
8767
8768 _classCallCheck(this, DataTable);
8769
8770 _this = _possibleConstructorReturn(this, _getPrototypeOf(DataTable).call(this, props));
8771 _this.state = {
8772 condensed: false,
8773 columnVisibilityData: [],
8774 isScrolledFarthestLeft: true,
8775 isScrolledFarthestRight: false
8776 };
8777 _this.dataTable = React__default.createRef();
8778 _this.scrollContainer = React__default.createRef();
8779 _this.table = React__default.createRef();
8780 _this.handleResize = debounce(function () {
8781 var _assertThisInitialize = _assertThisInitialized(_this),
8782 table = _assertThisInitialize.table.current,
8783 scrollContainer = _assertThisInitialize.scrollContainer.current;
8784
8785 var condensed = false;
8786
8787 if (table && scrollContainer) {
8788 condensed = table.scrollWidth > scrollContainer.clientWidth;
8789 }
8790
8791 _this.setState(Object.assign({
8792 condensed
8793 }, _this.calculateColumnVisibilityData(condensed)));
8794 });
8795
8796 _this.calculateColumnVisibilityData = function (condensed) {
8797 var _assertThisInitialize2 = _assertThisInitialized(_this),
8798 table = _assertThisInitialize2.table.current,
8799 scrollContainer = _assertThisInitialize2.scrollContainer.current,
8800 dataTable = _assertThisInitialize2.dataTable.current;
8801
8802 if (condensed && table && scrollContainer && dataTable) {
8803 var headerCells = table.querySelectorAll(headerCell.selector);
8804 var firstVisibleColumnIndex = headerCells.length - 1;
8805 var tableLeftVisibleEdge = scrollContainer.scrollLeft;
8806 var tableRightVisibleEdge = scrollContainer.scrollLeft + dataTable.offsetWidth;
8807 var tableData = {
8808 firstVisibleColumnIndex,
8809 tableLeftVisibleEdge,
8810 tableRightVisibleEdge
8811 };
8812
8813 var columnVisibilityData = _toConsumableArray(headerCells).map(measureColumn(tableData));
8814
8815 var lastColumn = columnVisibilityData[columnVisibilityData.length - 1];
8816 return Object.assign({
8817 columnVisibilityData
8818 }, getPrevAndCurrentColumns(tableData, columnVisibilityData), {
8819 isScrolledFarthestLeft: tableLeftVisibleEdge === 0,
8820 isScrolledFarthestRight: lastColumn.rightEdge <= tableRightVisibleEdge
8821 });
8822 }
8823
8824 return {
8825 columnVisibilityData: [],
8826 previousColumn: undefined,
8827 currentColumn: undefined
8828 };
8829 };
8830
8831 _this.scrollListener = function () {
8832 _this.setState(function (prevState) {
8833 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8834 });
8835 };
8836
8837 _this.navigateTable = function (direction) {
8838 var _this$state = _this.state,
8839 currentColumn = _this$state.currentColumn,
8840 previousColumn = _this$state.previousColumn;
8841 var scrollContainer = _this.scrollContainer.current;
8842
8843 var handleScroll = function handleScroll() {
8844 if (!currentColumn || !previousColumn) {
8845 return;
8846 }
8847
8848 if (scrollContainer) {
8849 scrollContainer.scrollLeft = direction === 'right' ? currentColumn.rightEdge : previousColumn.leftEdge;
8850 requestAnimationFrame(function () {
8851 _this.setState(function (prevState) {
8852 return Object.assign({}, _this.calculateColumnVisibilityData(prevState.condensed));
8853 });
8854 });
8855 }
8856 };
8857
8858 return handleScroll;
8859 };
8860
8861 _this.renderHeadings = function (heading, headingIndex) {
8862 var _this$props = _this.props,
8863 sortable = _this$props.sortable,
8864 _this$props$truncate = _this$props.truncate,
8865 truncate = _this$props$truncate === void 0 ? false : _this$props$truncate,
8866 columnContentTypes = _this$props.columnContentTypes,
8867 defaultSortDirection = _this$props.defaultSortDirection,
8868 _this$props$initialSo = _this$props.initialSortColumnIndex,
8869 initialSortColumnIndex = _this$props$initialSo === void 0 ? 0 : _this$props$initialSo,
8870 verticalAlign = _this$props.verticalAlign;
8871 var _this$state2 = _this.state,
8872 _this$state2$sortDire = _this$state2.sortDirection,
8873 sortDirection = _this$state2$sortDire === void 0 ? defaultSortDirection : _this$state2$sortDire,
8874 _this$state2$sortedCo = _this$state2.sortedColumnIndex,
8875 sortedColumnIndex = _this$state2$sortedCo === void 0 ? initialSortColumnIndex : _this$state2$sortedCo;
8876 var sortableHeadingProps;
8877 var id = "heading-cell-".concat(headingIndex);
8878
8879 if (sortable) {
8880 var isSortable = sortable[headingIndex];
8881 var isSorted = isSortable && sortedColumnIndex === headingIndex;
8882 var direction = isSorted ? sortDirection : 'none';
8883 sortableHeadingProps = {
8884 defaultSortDirection,
8885 sorted: isSorted,
8886 sortable: isSortable,
8887 sortDirection: direction,
8888 onSort: _this.defaultOnSort(headingIndex)
8889 };
8890 }
8891
8892 return React__default.createElement(Cell, Object.assign({
8893 header: true,
8894 key: id,
8895 content: heading,
8896 contentType: columnContentTypes[headingIndex],
8897 firstColumn: headingIndex === 0,
8898 truncate: truncate
8899 }, sortableHeadingProps, {
8900 verticalAlign: verticalAlign
8901 }));
8902 };
8903
8904 _this.renderTotals = function (total, index) {
8905 var id = "totals-cell-".concat(index);
8906 var _this$props2 = _this.props,
8907 _this$props2$truncate = _this$props2.truncate,
8908 truncate = _this$props2$truncate === void 0 ? false : _this$props2$truncate,
8909 verticalAlign = _this$props2.verticalAlign;
8910 var content;
8911 var contentType;
8912
8913 if (index === 0) {
8914 content = _this.totalsRowHeading;
8915 }
8916
8917 if (total !== '' && index > 0) {
8918 contentType = 'numeric';
8919 content = total;
8920 }
8921
8922 var totalInFooter = _this.props.showTotalsInFooter;
8923 return React__default.createElement(Cell, {
8924 total: true,
8925 totalInFooter: totalInFooter,
8926 firstColumn: index === 0,
8927 key: id,
8928 content: content,
8929 contentType: contentType,
8930 truncate: truncate,
8931 verticalAlign: verticalAlign
8932 });
8933 };
8934
8935 _this.defaultRenderRow = function (row, index) {
8936 var className = classNames(styles$I.TableRow);
8937 var _this$props3 = _this.props,
8938 columnContentTypes = _this$props3.columnContentTypes,
8939 _this$props3$truncate = _this$props3.truncate,
8940 truncate = _this$props3$truncate === void 0 ? false : _this$props3$truncate,
8941 verticalAlign = _this$props3.verticalAlign;
8942 return React__default.createElement("tr", {
8943 key: "row-".concat(index),
8944 className: className
8945 }, row.map(function (content, cellIndex) {
8946 var id = "cell-".concat(cellIndex, "-row-").concat(index);
8947 return React__default.createElement(Cell, {
8948 key: id,
8949 content: content,
8950 contentType: columnContentTypes[cellIndex],
8951 firstColumn: cellIndex === 0,
8952 truncate: truncate,
8953 verticalAlign: verticalAlign
8954 });
8955 }));
8956 };
8957
8958 _this.defaultOnSort = function (headingIndex) {
8959 var _this$props4 = _this.props,
8960 onSort = _this$props4.onSort,
8961 _this$props4$defaultS = _this$props4.defaultSortDirection,
8962 defaultSortDirection = _this$props4$defaultS === void 0 ? 'ascending' : _this$props4$defaultS,
8963 initialSortColumnIndex = _this$props4.initialSortColumnIndex;
8964 var _this$state3 = _this.state,
8965 _this$state3$sortDire = _this$state3.sortDirection,
8966 sortDirection = _this$state3$sortDire === void 0 ? defaultSortDirection : _this$state3$sortDire,
8967 _this$state3$sortedCo = _this$state3.sortedColumnIndex,
8968 sortedColumnIndex = _this$state3$sortedCo === void 0 ? initialSortColumnIndex : _this$state3$sortedCo;
8969 var newSortDirection = defaultSortDirection;
8970
8971 if (sortedColumnIndex === headingIndex) {
8972 newSortDirection = sortDirection === 'ascending' ? 'descending' : 'ascending';
8973 }
8974
8975 var handleSort = function handleSort() {
8976 _this.setState({
8977 sortDirection: newSortDirection,
8978 sortedColumnIndex: headingIndex
8979 }, function () {
8980 if (onSort) {
8981 onSort(headingIndex, newSortDirection);
8982 }
8983 });
8984 };
8985
8986 return handleSort;
8987 };
8988
8989 var intl = props.polaris.intl;
8990 _this.totalsRowHeading = intl.translate('Polaris.DataTable.totalsRowHeading');
8991 return _this;
8992 }
8993
8994 _createClass(DataTable, [{
8995 key: "componentDidMount",
8996 value: function componentDidMount() {
8997 var _this2 = this;
8998
8999 // We need to defer the calculation in development so the styles have time to be injected.
9000 if (process.env.NODE_ENV === 'development') {
9001 setTimeout(function () {
9002 _this2.handleResize();
9003 }, 10);
9004 } else {
9005 this.handleResize();
9006 }
9007 }
9008 }, {
9009 key: "componentDidUpdate",
9010 value: function componentDidUpdate(prevProps) {
9011 if (isEqual(prevProps, this.props)) {
9012 return;
9013 }
9014
9015 this.handleResize();
9016 }
9017 }, {
9018 key: "render",
9019 value: function render() {
9020 var _this$props5 = this.props,
9021 headings = _this$props5.headings,
9022 totals = _this$props5.totals,
9023 showTotalsInFooter = _this$props5.showTotalsInFooter,
9024 rows = _this$props5.rows,
9025 footerContent = _this$props5.footerContent;
9026 var _this$state4 = this.state,
9027 condensed = _this$state4.condensed,
9028 columnVisibilityData = _this$state4.columnVisibilityData,
9029 isScrolledFarthestLeft = _this$state4.isScrolledFarthestLeft,
9030 isScrolledFarthestRight = _this$state4.isScrolledFarthestRight;
9031 var className = classNames(styles$I.DataTable, condensed && styles$I.condensed);
9032 var wrapperClassName = classNames(styles$I.TableWrapper, condensed && styles$I.condensed);
9033 var headingMarkup = React__default.createElement("tr", null, headings.map(this.renderHeadings));
9034 var totalsMarkup = totals ? React__default.createElement("tr", null, totals.map(this.renderTotals)) : null;
9035 var bodyMarkup = rows.map(this.defaultRenderRow);
9036 var footerMarkup = footerContent ? React__default.createElement("div", {
9037 className: styles$I.Footer
9038 }, footerContent) : null;
9039 var headerTotalsMarkup = !showTotalsInFooter ? totalsMarkup : null;
9040 var footerTotalsMarkup = showTotalsInFooter ? React__default.createElement("tfoot", null, totalsMarkup) : null;
9041 return React__default.createElement("div", {
9042 className: wrapperClassName
9043 }, React__default.createElement(Navigation, {
9044 columnVisibilityData: columnVisibilityData,
9045 isScrolledFarthestLeft: isScrolledFarthestLeft,
9046 isScrolledFarthestRight: isScrolledFarthestRight,
9047 navigateTableLeft: this.navigateTable('left'),
9048 navigateTableRight: this.navigateTable('right')
9049 }), React__default.createElement("div", {
9050 className: className,
9051 ref: this.dataTable
9052 }, React__default.createElement("div", {
9053 className: styles$I.ScrollContainer,
9054 ref: this.scrollContainer
9055 }, React__default.createElement(EventListener, {
9056 event: "resize",
9057 handler: this.handleResize
9058 }), React__default.createElement(EventListener, {
9059 capture: true,
9060 event: "scroll",
9061 handler: this.scrollListener
9062 }), React__default.createElement("table", {
9063 className: styles$I.Table,
9064 ref: this.table
9065 }, React__default.createElement("thead", null, headingMarkup, headerTotalsMarkup), React__default.createElement("tbody", null, bodyMarkup), footerTotalsMarkup)), footerMarkup));
9066 }
9067 }]);
9068
9069 return DataTable;
9070}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
9071// eslint-disable-next-line import/no-default-export
9072
9073
9074var DataTable$1 = withAppProvider()(DataTable);
9075
9076function monthName(month) {
9077 switch (month) {
9078 case 0:
9079 return 'january';
9080
9081 case 1:
9082 return 'february';
9083
9084 case 2:
9085 return 'march';
9086
9087 case 3:
9088 return 'april';
9089
9090 case 4:
9091 return 'may';
9092
9093 case 5:
9094 return 'june';
9095
9096 case 6:
9097 return 'july';
9098
9099 case 7:
9100 return 'august';
9101
9102 case 8:
9103 return 'september';
9104
9105 case 9:
9106 return 'october';
9107
9108 case 10:
9109 return 'november';
9110
9111 case 11:
9112 return 'december';
9113 }
9114}
9115function weekdayName(weekday) {
9116 switch (weekday) {
9117 case 0:
9118 return 'sunday';
9119
9120 case 1:
9121 return 'monday';
9122
9123 case 2:
9124 return 'tuesday';
9125
9126 case 3:
9127 return 'wednesday';
9128
9129 case 4:
9130 return 'thursday';
9131
9132 case 5:
9133 return 'friday';
9134
9135 case 6:
9136 return 'saturday';
9137 }
9138}
9139
9140var styles$J = {
9141 "DatePicker": "Polaris-DatePicker",
9142 "MonthContainer": "Polaris-DatePicker__MonthContainer",
9143 "Month": "Polaris-DatePicker__Month",
9144 "Month-current": "Polaris-DatePicker__Month--current",
9145 "Week": "Polaris-DatePicker__Week",
9146 "WeekHeadings": "Polaris-DatePicker__WeekHeadings",
9147 "Day": "Polaris-DatePicker__Day",
9148 "EmptyDay": "Polaris-DatePicker__EmptyDay",
9149 "Day-today": "Polaris-DatePicker__Day--today",
9150 "Day-inRange": "Polaris-DatePicker__Day--inRange",
9151 "Day-selected": "Polaris-DatePicker__Day--selected",
9152 "Day-disabled": "Polaris-DatePicker__Day--disabled",
9153 "Weekday": "Polaris-DatePicker__Weekday",
9154 "Weekday-current": "Polaris-DatePicker__Weekday--current",
9155 "Header": "Polaris-DatePicker__Header",
9156 "Title": "Polaris-DatePicker__Title"
9157};
9158
9159function Day(_ref) {
9160 var day = _ref.day,
9161 focused = _ref.focused,
9162 onClick = _ref.onClick,
9163 _ref$onHover = _ref.onHover,
9164 onHover = _ref$onHover === void 0 ? noop$6 : _ref$onHover,
9165 _ref$onFocus = _ref.onFocus,
9166 _onFocus = _ref$onFocus === void 0 ? noop$6 : _ref$onFocus,
9167 selected = _ref.selected,
9168 inRange = _ref.inRange,
9169 inHoveringRange = _ref.inHoveringRange,
9170 disabled = _ref.disabled;
9171
9172 var i18n = useI18n();
9173 var dayNode = React.useRef(null);
9174 React.useEffect(function () {
9175 if (focused && dayNode.current) {
9176 dayNode.current.focus();
9177 }
9178 }, [focused]);
9179
9180 if (!day) {
9181 return React__default.createElement("div", {
9182 className: styles$J.EmptyDay,
9183 onMouseOver: function onMouseOver() {
9184 return onHover(day);
9185 }
9186 });
9187 }
9188
9189 var handleClick = onClick && !disabled ? onClick.bind(null, day) : noop$6;
9190 var today = dates.isSameDay(new Date(), day);
9191 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']);
9192 var date = day.getDate();
9193 var tabIndex = (focused || selected || today || date === 1) && !disabled ? 0 : -1;
9194 var ariaLabel = ["".concat(today ? i18n.translate('Polaris.DatePicker.today') : ''), "".concat(dates.Months[day.getMonth()], " "), "".concat(date, " "), "".concat(day.getFullYear())].join('');
9195 return React__default.createElement("button", {
9196 onFocus: function onFocus() {
9197 return _onFocus(day);
9198 },
9199 type: "button",
9200 ref: dayNode,
9201 tabIndex: tabIndex,
9202 className: className,
9203 onMouseOver: function onMouseOver() {
9204 return onHover(day);
9205 },
9206 onClick: handleClick,
9207 "aria-label": ariaLabel,
9208 "aria-selected": selected,
9209 "aria-disabled": disabled,
9210 role: "gridcell"
9211 }, date);
9212}
9213
9214function noop$6() {}
9215
9216function Weekday(_ref) {
9217 var label = _ref.label,
9218 title = _ref.title,
9219 current = _ref.current;
9220 var className = classNames(styles$J.Weekday, current && styles$J['Weekday-current']);
9221 return React__default.createElement("div", {
9222 "aria-label": dates.Weekdays[label],
9223 className: className
9224 }, title);
9225}
9226
9227var WEEKDAYS = [dates.Weekdays.Sunday, dates.Weekdays.Monday, dates.Weekdays.Tuesday, dates.Weekdays.Wednesday, dates.Weekdays.Thursday, dates.Weekdays.Friday, dates.Weekdays.Saturday];
9228function Month(_ref) {
9229 var focusedDate = _ref.focusedDate,
9230 selected = _ref.selected,
9231 hoverDate = _ref.hoverDate,
9232 disableDatesBefore = _ref.disableDatesBefore,
9233 disableDatesAfter = _ref.disableDatesAfter,
9234 allowRange = _ref.allowRange,
9235 _ref$onChange = _ref.onChange,
9236 onChange = _ref$onChange === void 0 ? noop$7 : _ref$onChange,
9237 _ref$onHover = _ref.onHover,
9238 onHover = _ref$onHover === void 0 ? noop$7 : _ref$onHover,
9239 _ref$onFocus = _ref.onFocus,
9240 onFocus = _ref$onFocus === void 0 ? noop$7 : _ref$onFocus,
9241 month = _ref.month,
9242 year = _ref.year,
9243 weekStartsOn = _ref.weekStartsOn;
9244 var i18n = useI18n();
9245 var isInHoveringRange = allowRange ? hoveringDateIsInRange : function () {
9246 return false;
9247 };
9248 var now = new Date();
9249 var current = now.getMonth() === month && now.getFullYear() === year;
9250 var className = classNames(styles$J.Title, current && styles$J['Month-current']);
9251 var weeks = dates.getWeeksForMonth(month, year, weekStartsOn);
9252 var weekdays = getWeekdaysOrdered(weekStartsOn).map(function (weekday) {
9253 return React__default.createElement(Weekday, {
9254 key: weekday,
9255 title: i18n.translate("Polaris.DatePicker.daysAbbreviated.".concat(weekdayName(weekday))),
9256 current: current && new Date().getDay() === weekday,
9257 label: weekday
9258 });
9259 });
9260
9261 function handleDateClick(selectedDate) {
9262 onChange(dates.getNewRange(allowRange ? selected : undefined, selectedDate));
9263 }
9264
9265 function renderWeek(day, dayIndex) {
9266 if (day == null) {
9267 var lastDayOfMonth = new Date(year, month + 1, 0);
9268 return React__default.createElement(Day, {
9269 key: dayIndex,
9270 onHover: onHover.bind(null, lastDayOfMonth)
9271 });
9272 }
9273
9274 var disabled = disableDatesBefore && dates.isDateBefore(day, disableDatesBefore) || disableDatesAfter && dates.isDateAfter(day, disableDatesAfter);
9275 return React__default.createElement(Day, {
9276 focused: focusedDate != null && dates.isSameDay(day, focusedDate),
9277 day: day,
9278 key: dayIndex,
9279 onFocus: onFocus,
9280 onClick: handleDateClick,
9281 onHover: onHover,
9282 selected: selected != null && dates.dateIsSelected(day, selected),
9283 inRange: selected != null && dates.dateIsInRange(day, selected),
9284 disabled: disabled,
9285 inHoveringRange: selected != null && hoverDate != null && isInHoveringRange(day, selected, hoverDate)
9286 });
9287 }
9288
9289 var weeksMarkup = weeks.map(function (week, index) {
9290 return React__default.createElement("div", {
9291 role: "row",
9292 className: styles$J.Week,
9293 key: index
9294 }, week.map(renderWeek));
9295 });
9296 return React__default.createElement("div", {
9297 role: "grid",
9298 className: styles$J.Month
9299 }, React__default.createElement("div", {
9300 className: className
9301 }, i18n.translate("Polaris.DatePicker.months.".concat(monthName(month))), " ", year), React__default.createElement("div", {
9302 role: "rowheader",
9303 className: styles$J.WeekHeadings
9304 }, weekdays), weeksMarkup);
9305}
9306
9307function noop$7() {}
9308
9309function hoveringDateIsInRange(day, range, hoverEndDate) {
9310 if (day == null) {
9311 return false;
9312 }
9313
9314 var start = range.start,
9315 end = range.end;
9316 return Boolean(dates.isSameDay(start, end) && day > start && day <= hoverEndDate);
9317}
9318
9319function getWeekdaysOrdered(weekStartsOn) {
9320 var weekDays = [].concat(WEEKDAYS);
9321 var restOfDays = weekDays.splice(weekStartsOn);
9322 return [].concat(_toConsumableArray(restOfDays), _toConsumableArray(weekDays));
9323}
9324
9325function DatePicker(_ref) {
9326 var id = _ref.id,
9327 selected = _ref.selected,
9328 month = _ref.month,
9329 year = _ref.year,
9330 allowRange = _ref.allowRange,
9331 multiMonth = _ref.multiMonth,
9332 disableDatesBefore = _ref.disableDatesBefore,
9333 disableDatesAfter = _ref.disableDatesAfter,
9334 _ref$weekStartsOn = _ref.weekStartsOn,
9335 weekStartsOn = _ref$weekStartsOn === void 0 ? dates.Weekdays.Sunday : _ref$weekStartsOn,
9336 onMonthChange = _ref.onMonthChange,
9337 _ref$onChange = _ref.onChange,
9338 onChange = _ref$onChange === void 0 ? noop$8 : _ref$onChange;
9339 var i18n = useI18n();
9340
9341 var _useState = React.useState(undefined),
9342 _useState2 = _slicedToArray(_useState, 2),
9343 hoverDate = _useState2[0],
9344 setHoverDate = _useState2[1];
9345
9346 var _useState3 = React.useState(undefined),
9347 _useState4 = _slicedToArray(_useState3, 2),
9348 focusDate = _useState4[0],
9349 setFocusDate = _useState4[1];
9350
9351 React.useEffect(function () {
9352 setFocusDate(undefined);
9353 }, [selected]);
9354 var handleFocus = React.useCallback(function (date) {
9355 setFocusDate(date);
9356 }, []);
9357 var setFocusDateAndHandleMonthChange = React.useCallback(function (date) {
9358 if (onMonthChange) {
9359 onMonthChange(date.getMonth(), date.getFullYear());
9360 }
9361
9362 setHoverDate(date);
9363 setFocusDate(date);
9364 }, [onMonthChange]);
9365 var handleDateSelection = React.useCallback(function (range) {
9366 var end = range.end;
9367 setHoverDate(end);
9368 setFocusDate(new Date(end));
9369 onChange(range);
9370 }, [onChange]);
9371 var handleMonthChangeClick = React.useCallback(function (month, year) {
9372 if (!onMonthChange) {
9373 return;
9374 }
9375
9376 setFocusDate(undefined);
9377 onMonthChange(month, year);
9378 }, [onMonthChange]);
9379 var handleHover = React.useCallback(function (date) {
9380 setHoverDate(date);
9381 }, []);
9382 var handleKeyUp = React.useCallback(function (event) {
9383 var key = event.key;
9384 var range = deriveRange(selected);
9385 var focusedDate = focusDate || range && range.start;
9386
9387 if (focusedDate == null) {
9388 return;
9389 }
9390
9391 if (key === 'ArrowUp') {
9392 var previousWeek = new Date(focusedDate);
9393 previousWeek.setDate(focusedDate.getDate() - 7);
9394
9395 if (!(disableDatesBefore && dates.isDateBefore(previousWeek, disableDatesBefore))) {
9396 setFocusDateAndHandleMonthChange(previousWeek);
9397 }
9398 }
9399
9400 if (key === 'ArrowDown') {
9401 var nextWeek = new Date(focusedDate);
9402 nextWeek.setDate(focusedDate.getDate() + 7);
9403
9404 if (!(disableDatesAfter && dates.isDateAfter(nextWeek, disableDatesAfter))) {
9405 setFocusDateAndHandleMonthChange(nextWeek);
9406 }
9407 }
9408
9409 if (key === 'ArrowRight') {
9410 var tomorrow = new Date(focusedDate);
9411 tomorrow.setDate(focusedDate.getDate() + 1);
9412
9413 if (!(disableDatesAfter && dates.isDateAfter(tomorrow, disableDatesAfter))) {
9414 setFocusDateAndHandleMonthChange(tomorrow);
9415 }
9416 }
9417
9418 if (key === 'ArrowLeft') {
9419 var yesterday = new Date(focusedDate);
9420 yesterday.setDate(focusedDate.getDate() - 1);
9421
9422 if (!(disableDatesBefore && dates.isDateBefore(yesterday, disableDatesBefore))) {
9423 setFocusDateAndHandleMonthChange(yesterday);
9424 }
9425 }
9426 }, [disableDatesAfter, disableDatesBefore, focusDate, selected, setFocusDateAndHandleMonthChange]);
9427 var showNextYear = dates.getNextDisplayYear(month, year);
9428 var showNextMonth = dates.getNextDisplayMonth(month);
9429 var showNextToNextYear = dates.getNextDisplayYear(showNextMonth, showNextYear);
9430 var showNextToNextMonth = dates.getNextDisplayMonth(showNextMonth);
9431 var showPreviousYear = dates.getPreviousDisplayYear(month, year);
9432 var showPreviousMonth = dates.getPreviousDisplayMonth(month);
9433 var previousMonthName = i18n.translate("Polaris.DatePicker.months.".concat(monthName(showPreviousMonth)));
9434 var nextMonth = multiMonth ? i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextToNextMonth))) : i18n.translate("Polaris.DatePicker.months.".concat(monthName(showNextMonth)));
9435 var nextYear = multiMonth ? showNextToNextYear : showNextYear;
9436 var secondDatePicker = multiMonth ? React__default.createElement(Month, {
9437 onFocus: handleFocus,
9438 focusedDate: focusDate,
9439 month: showNextMonth,
9440 year: showNextYear,
9441 selected: deriveRange(selected),
9442 hoverDate: hoverDate,
9443 onChange: handleDateSelection,
9444 onHover: handleHover,
9445 disableDatesBefore: disableDatesBefore,
9446 disableDatesAfter: disableDatesAfter,
9447 allowRange: allowRange,
9448 weekStartsOn: weekStartsOn
9449 }) : null;
9450 return React__default.createElement("div", {
9451 id: id,
9452 className: styles$J.DatePicker,
9453 onKeyDown: handleKeyDown,
9454 onKeyUp: handleKeyUp
9455 }, React__default.createElement("div", {
9456 className: styles$J.Header
9457 }, React__default.createElement(Button, {
9458 plain: true,
9459 icon: polarisIcons.ArrowLeftMinor,
9460 accessibilityLabel: i18n.translate('Polaris.DatePicker.previousMonth', {
9461 previousMonthName,
9462 showPreviousYear
9463 }),
9464 onClick: function onClick() {
9465 return handleMonthChangeClick(showPreviousMonth, showPreviousYear);
9466 }
9467 }), React__default.createElement(Button, {
9468 plain: true,
9469 icon: polarisIcons.ArrowRightMinor,
9470 accessibilityLabel: i18n.translate('Polaris.DatePicker.nextMonth', {
9471 nextMonth,
9472 nextYear
9473 }),
9474 onClick: function onClick() {
9475 return handleMonthChangeClick(showNextMonth, showNextYear);
9476 }
9477 })), React__default.createElement("div", {
9478 className: styles$J.MonthContainer
9479 }, React__default.createElement(Month, {
9480 onFocus: handleFocus,
9481 focusedDate: focusDate,
9482 month: month,
9483 year: year,
9484 selected: deriveRange(selected),
9485 hoverDate: hoverDate,
9486 onChange: handleDateSelection,
9487 onHover: handleHover,
9488 disableDatesBefore: disableDatesBefore,
9489 disableDatesAfter: disableDatesAfter,
9490 allowRange: allowRange,
9491 weekStartsOn: weekStartsOn
9492 }), secondDatePicker));
9493}
9494
9495function noop$8() {}
9496
9497function handleKeyDown(event) {
9498 var key = event.key;
9499
9500 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
9501 event.preventDefault();
9502 event.stopPropagation();
9503 }
9504}
9505
9506function deriveRange(selected) {
9507 return selected instanceof Date ? {
9508 start: selected,
9509 end: selected
9510 } : selected;
9511}
9512
9513var styles$K = {
9514 "DescriptionList": "Polaris-DescriptionList",
9515 "Term": "Polaris-DescriptionList__Term",
9516 "Description": "Polaris-DescriptionList__Description"
9517};
9518
9519var getUniqueTermKey = other.createUniqueIDFactory("Term");
9520var getUniqueDescriptionKey = other.createUniqueIDFactory("Description");
9521function DescriptionList(_ref) {
9522 var items = _ref.items;
9523 var terms = items.reduce(function (allTerms, _ref2) {
9524 var term = _ref2.term,
9525 description = _ref2.description;
9526 return [].concat(_toConsumableArray(allTerms), [React__default.createElement("dt", {
9527 key: getUniqueTermKey(),
9528 className: styles$K.Term
9529 }, term), React__default.createElement("dd", {
9530 key: getUniqueDescriptionKey(),
9531 className: styles$K.Description
9532 }, description)]);
9533 }, []);
9534 return React__default.createElement("dl", {
9535 className: styles$K.DescriptionList
9536 }, terms);
9537}
9538
9539var styles$L = {
9540 "DisplayText": "Polaris-DisplayText",
9541 "sizeSmall": "Polaris-DisplayText--sizeSmall",
9542 "sizeMedium": "Polaris-DisplayText--sizeMedium",
9543 "sizeLarge": "Polaris-DisplayText--sizeLarge",
9544 "sizeExtraLarge": "Polaris-DisplayText--sizeExtraLarge"
9545};
9546
9547function DisplayText(_ref) {
9548 var _ref$element = _ref.element,
9549 Element = _ref$element === void 0 ? 'p' : _ref$element,
9550 children = _ref.children,
9551 _ref$size = _ref.size,
9552 size = _ref$size === void 0 ? 'medium' : _ref$size;
9553 var className = classNames(styles$L.DisplayText, size && styles$L[variationName('size', size)]);
9554 return React__default.createElement(Element, {
9555 className: className
9556 }, children);
9557}
9558
9559function capitalize() {
9560 var word = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
9561 var wordLower = word.toLowerCase();
9562 return wordLower.charAt(0).toUpperCase() + wordLower.slice(1);
9563}
9564
9565/**
9566 * Attaches and removes event listeners from the target
9567 * @param target Defines a target for the listener to be placed on. Defaults to window.
9568 * @param type Defines the type of event, i.e blur or focus
9569 * @param handler Defines a callback to be invoked when the event type occurs
9570 * @param listenerOptions Object that specifies event properties
9571 * @param options Object that defines properties used in the hook
9572 * interface Options {
9573 * // Uses window as a back up event target when the current
9574 * // target is falsy
9575 * defaultToWindow: boolean;
9576 * }
9577 * @example
9578 * function Playground() {
9579 * useEventListener(window, 'resize', () => console.log('resize'));
9580 *
9581 * return null;
9582 * }
9583 */
9584
9585function useEventListener(target, type, handler, listenerOptions, options) {
9586 React.useEffect(function () {
9587 var eventTarget = target && 'current' in target ? target.current : target;
9588
9589 if (!eventTarget && options && options.defaultToWindow) {
9590 eventTarget = window;
9591 }
9592
9593 if (!eventTarget) return;
9594 eventTarget.addEventListener(type, handler, listenerOptions);
9595 return function () {
9596 eventTarget && eventTarget.removeEventListener(type, handler, listenerOptions);
9597 };
9598 }, [handler, listenerOptions, options, target, type]);
9599}
9600
9601/**
9602 * Similarly to the life-cycle method componentDidMount, useComponentDidMount
9603 * will be invoked after the component has mounted, and only the initial mount.
9604 * @param callback Defines a callback to invoke once the component has
9605 * initially mounted.
9606 * @example
9607 * function Playground({active}) {
9608 * useComponentDidMount(() => {
9609 * if (active) {
9610 * console.warning(`Component has mounted.`);
9611 * }
9612 * });
9613 *
9614 * return null;
9615 * }
9616 */
9617
9618function useComponentDidMount(callback) {
9619 var isAfterInitialMount = useIsAfterInitialMount();
9620 var hasInvokedLifeCycle = React.useRef(false);
9621
9622 if (isAfterInitialMount && !hasInvokedLifeCycle.current) {
9623 hasInvokedLifeCycle.current = true;
9624 return callback();
9625 }
9626}
9627
9628var 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>
';
9629
9630var 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>
';
9631
9632var DropZoneContext = React__default.createContext({
9633 disabled: false,
9634 focused: false,
9635 size: 'extraLarge',
9636 type: 'file',
9637 measuring: false
9638});
9639
9640var styles$M = {
9641 "FileUpload": "Polaris-DropZone-FileUpload",
9642 "measuring": "Polaris-DropZone-FileUpload--measuring",
9643 "Button": "Polaris-DropZone-FileUpload__Button",
9644 "globalTheming": "Polaris-DropZone-FileUpload--globalTheming",
9645 "disabled": "Polaris-DropZone-FileUpload--disabled",
9646 "focused": "Polaris-DropZone-FileUpload--focused",
9647 "sizeSlim": "Polaris-DropZone-FileUpload--sizeSlim",
9648 "ActionTitle": "Polaris-DropZone-FileUpload__ActionTitle",
9649 "ActionTitle-disabled": "Polaris-DropZone-FileUpload__ActionTitle--disabled",
9650 "ActionTitle-focused": "Polaris-DropZone-FileUpload__ActionTitle--focused",
9651 "Image": "Polaris-DropZone-FileUpload__Image",
9652 "sizeExtraLarge": "Polaris-DropZone-FileUpload--sizeExtraLarge",
9653 "sizeLarge": "Polaris-DropZone-FileUpload--sizeLarge"
9654};
9655
9656function FileUpload(props) {
9657 var i18n = useI18n();
9658
9659 var _useContext = React.useContext(DropZoneContext),
9660 size = _useContext.size,
9661 measuring = _useContext.measuring,
9662 type = _useContext.type,
9663 focused = _useContext.focused,
9664 disabled = _useContext.disabled;
9665
9666 var suffix = capitalize(type);
9667 var _props$actionTitle = props.actionTitle,
9668 actionTitle = _props$actionTitle === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionTitle".concat(suffix)) : _props$actionTitle,
9669 _props$actionHint = props.actionHint,
9670 actionHint = _props$actionHint === void 0 ? i18n.translate("Polaris.DropZone.FileUpload.actionHint".concat(suffix)) : _props$actionHint;
9671 var imageClasses = classNames(styles$M.Image, size && size === 'extraLarge' && styles$M.sizeExtraLarge, size && size === 'large' && styles$M.sizeLarge);
9672 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;
9673 var buttonMarkup = (size === 'extraLarge' || size === 'large') && buttonStyles ? React__default.createElement("div", {
9674 className: buttonStyles
9675 }, actionTitle) : null;
9676 var extraLargeView = size === 'extraLarge' ? React__default.createElement(Stack, {
9677 vertical: true
9678 }, type === 'file' && React__default.createElement("img", {
9679 className: imageClasses,
9680 src: fileUpload,
9681 alt: ""
9682 }), type === 'image' && React__default.createElement("img", {
9683 className: imageClasses,
9684 src: imageUpload,
9685 alt: ""
9686 }), buttonMarkup, React__default.createElement(TextStyle, {
9687 variation: "subdued"
9688 }, actionHint)) : null;
9689 var largeView = size === 'large' ? React__default.createElement(Stack, {
9690 vertical: true,
9691 spacing: "tight"
9692 }, type === 'file' && React__default.createElement("img", {
9693 className: imageClasses,
9694 src: fileUpload,
9695 alt: ""
9696 }), type === 'image' && React__default.createElement("img", {
9697 className: imageClasses,
9698 src: imageUpload,
9699 alt: ""
9700 }), buttonMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
9701 variation: "subdued"
9702 }, actionHint))) : null;
9703 var actionTitleClassName = classNames(styles$M.ActionTitle, focused && !disabled && styles$M['ActionTitle-focused'], disabled && styles$M['ActionTitle-disabled']);
9704 var actionTitleMarkup = React__default.createElement("div", {
9705 className: actionTitleClassName
9706 }, actionTitle);
9707 var mediumView = size === 'medium' ? React__default.createElement(Stack, {
9708 vertical: true,
9709 spacing: "tight"
9710 }, actionTitleMarkup, React__default.createElement(Caption, null, React__default.createElement(TextStyle, {
9711 variation: "subdued"
9712 }, actionHint))) : null;
9713 var smallView = size === 'small' ? React__default.createElement(Stack, {
9714 vertical: true,
9715 spacing: "tight"
9716 }, React__default.createElement(Icon, {
9717 source: polarisIcons.DragDropMajorMonotone,
9718 color: "inkLightest"
9719 })) : null;
9720 var fileUploadClassName = classNames(styles$M.FileUpload, measuring && styles$M.measuring);
9721 return React__default.createElement("div", {
9722 className: fileUploadClassName
9723 }, smallView, mediumView, largeView, extraLargeView);
9724}
9725
9726var dragEvents = ['dragover', 'dragenter', 'drop'];
9727function fileAccepted(file, accept) {
9728 return file.type === 'application/x-moz-file' || accepts(file, accept);
9729}
9730function getDataTransferFiles(event) {
9731 if (isDragEvent(event) && event.dataTransfer) {
9732 var dt = event.dataTransfer;
9733
9734 if (dt.files && dt.files.length) {
9735 return Array.from(dt.files);
9736 } else if (dt.items && dt.items.length) {
9737 // Chrome is the only browser that allows to read the file list on drag
9738 // events and uses `items` instead of `files` in this case.
9739 return Array.from(dt.items);
9740 }
9741 } else if (isChangeEvent(event) && event.target.files) {
9742 // Return files from even when a file was selected from an upload dialog
9743 return Array.from(event.target.files);
9744 }
9745
9746 return [];
9747}
9748
9749function accepts(file, acceptedFiles) {
9750 if (file && acceptedFiles) {
9751 var fileName = file.name || '';
9752 var mimeType = file.type || '';
9753 var baseMimeType = mimeType.replace(/\/.*$/, '');
9754 var acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(',');
9755 return acceptedFilesArray.some(function (type) {
9756 var validType = type.trim();
9757
9758 if (validType.startsWith('.')) {
9759 return fileName.toLowerCase().endsWith(validType.toLowerCase());
9760 } else if (validType.endsWith('/*')) {
9761 // This is something like a image/* mime type
9762 return baseMimeType === validType.replace(/\/.*$/, '');
9763 }
9764
9765 return mimeType === validType;
9766 });
9767 }
9768
9769 return true;
9770}
9771
9772function isDragEvent(event) {
9773 return dragEvents.indexOf(event.type) > 0;
9774}
9775
9776function isChangeEvent(event) {
9777 return Object.prototype.hasOwnProperty.call(event, 'target');
9778}
9779
9780var styles$N = {
9781 "DropZone": "Polaris-DropZone",
9782 "hasOutline": "Polaris-DropZone--hasOutline",
9783 "isDisabled": "Polaris-DropZone--isDisabled",
9784 "focused": "Polaris-DropZone--focused",
9785 "isDragging": "Polaris-DropZone--isDragging",
9786 "sizeExtraLarge": "Polaris-DropZone--sizeExtraLarge",
9787 "sizeLarge": "Polaris-DropZone--sizeLarge",
9788 "sizeMedium": "Polaris-DropZone--sizeMedium",
9789 "sizeSmall": "Polaris-DropZone--sizeSmall",
9790 "measuring": "Polaris-DropZone--measuring",
9791 "Container": "Polaris-DropZone__Container",
9792 "Overlay": "Polaris-DropZone__Overlay",
9793 "hasError": "Polaris-DropZone--hasError"
9794};
9795
9796// subcomponents so explicitly state the subcomponents in the type definition.
9797// Letting this be implicit works in this project but fails in projects that use
9798// generated *.d.ts files.
9799
9800var DropZone = function DropZone(_ref) {
9801 var dropOnPage = _ref.dropOnPage,
9802 label = _ref.label,
9803 labelAction = _ref.labelAction,
9804 labelHidden = _ref.labelHidden,
9805 children = _ref.children,
9806 _ref$disabled = _ref.disabled,
9807 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
9808 _ref$outline = _ref.outline,
9809 outline = _ref$outline === void 0 ? true : _ref$outline,
9810 accept = _ref.accept,
9811 active = _ref.active,
9812 _ref$overlay = _ref.overlay,
9813 overlay = _ref$overlay === void 0 ? true : _ref$overlay,
9814 _ref$allowMultiple = _ref.allowMultiple,
9815 allowMultiple = _ref$allowMultiple === void 0 ? true : _ref$allowMultiple,
9816 overlayText = _ref.overlayText,
9817 errorOverlayText = _ref.errorOverlayText,
9818 idProp = _ref.id,
9819 _ref$type = _ref.type,
9820 type = _ref$type === void 0 ? 'file' : _ref$type,
9821 onClick = _ref.onClick,
9822 error = _ref.error,
9823 openFileDialog = _ref.openFileDialog,
9824 onFileDialogClose = _ref.onFileDialogClose,
9825 customValidator = _ref.customValidator,
9826 onDrop = _ref.onDrop,
9827 onDropAccepted = _ref.onDropAccepted,
9828 onDropRejected = _ref.onDropRejected,
9829 onDragEnter = _ref.onDragEnter,
9830 onDragOver = _ref.onDragOver,
9831 onDragLeave = _ref.onDragLeave;
9832 var node = React.useRef(null);
9833 var fileInputNode = React.useRef(null);
9834 var dragTargets = React.useRef([]);
9835 var adjustSize = React.useCallback(debounce(function () {
9836 if (!node.current) {
9837 return;
9838 }
9839
9840 var size = 'extraLarge';
9841 var width = node.current.getBoundingClientRect().width;
9842
9843 if (width < 100) {
9844 size = 'small';
9845 } else if (width < 160) {
9846 size = 'medium';
9847 } else if (width < 300) {
9848 size = 'large';
9849 }
9850
9851 setSize(size);
9852 measuring && setMeasuring(false);
9853 }, 50, {
9854 trailing: true
9855 }), []);
9856
9857 var _useState = React.useState(false),
9858 _useState2 = _slicedToArray(_useState, 2),
9859 dragging = _useState2[0],
9860 setDragging = _useState2[1];
9861
9862 var _useState3 = React.useState(false),
9863 _useState4 = _slicedToArray(_useState3, 2),
9864 internalError = _useState4[0],
9865 setInternalError = _useState4[1];
9866
9867 var _useForcibleToggle = useForcibleToggle(false),
9868 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
9869 focused = _useForcibleToggle2[0],
9870 _useForcibleToggle2$ = _useForcibleToggle2[1],
9871 handleFocus = _useForcibleToggle2$.forceTrue,
9872 handleBlur = _useForcibleToggle2$.forceFalse;
9873
9874 var _useState5 = React.useState(0),
9875 _useState6 = _slicedToArray(_useState5, 2),
9876 numFiles = _useState6[0],
9877 setNumFiles = _useState6[1];
9878
9879 var _useState7 = React.useState('extraLarge'),
9880 _useState8 = _slicedToArray(_useState7, 2),
9881 size = _useState8[0],
9882 setSize = _useState8[1];
9883
9884 var _useState9 = React.useState(true),
9885 _useState10 = _slicedToArray(_useState9, 2),
9886 measuring = _useState10[0],
9887 setMeasuring = _useState10[1];
9888
9889 var i18n = useI18n();
9890 var dropNode = dropOnPage ? document : node;
9891 var getValidatedFiles = React.useCallback(function (files) {
9892 var acceptedFiles = [];
9893 var rejectedFiles = [];
9894 Array.from(files).forEach(function (file) {
9895 !fileAccepted(file, accept) || customValidator && !customValidator(file) ? rejectedFiles.push(file) : acceptedFiles.push(file);
9896 });
9897
9898 if (!allowMultiple) {
9899 acceptedFiles.splice(1, acceptedFiles.length);
9900 rejectedFiles.push.apply(rejectedFiles, _toConsumableArray(acceptedFiles.slice(1)));
9901 }
9902
9903 return {
9904 files,
9905 acceptedFiles,
9906 rejectedFiles
9907 };
9908 }, [accept, allowMultiple, customValidator]);
9909 var handleDrop = React.useCallback(function (event) {
9910 stopEvent(event);
9911 if (disabled || !allowMultiple && numFiles > 0) return;
9912 var fileList = getDataTransferFiles(event);
9913
9914 var _getValidatedFiles = getValidatedFiles(fileList),
9915 files = _getValidatedFiles.files,
9916 acceptedFiles = _getValidatedFiles.acceptedFiles,
9917 rejectedFiles = _getValidatedFiles.rejectedFiles;
9918
9919 dragTargets.current = [];
9920 setDragging(false);
9921 setInternalError(rejectedFiles.length > 0);
9922 setNumFiles(function (numFiles) {
9923 return numFiles + acceptedFiles.length;
9924 });
9925 onDrop && onDrop(files, acceptedFiles, rejectedFiles);
9926 onDropAccepted && acceptedFiles.length && onDropAccepted(acceptedFiles);
9927 onDropRejected && rejectedFiles.length && onDropRejected(rejectedFiles);
9928 event.target.value = '';
9929 }, [allowMultiple, disabled, getValidatedFiles, numFiles, onDrop, onDropAccepted, onDropRejected]);
9930 var handleDragEnter = React.useCallback(function (event) {
9931 stopEvent(event);
9932 if (disabled || !allowMultiple && numFiles > 0) return;
9933 var fileList = getDataTransferFiles(event);
9934
9935 if (event.target && !dragTargets.current.includes(event.target)) {
9936 dragTargets.current.push(event.target);
9937 }
9938
9939 if (dragging) return;
9940
9941 var _getValidatedFiles2 = getValidatedFiles(fileList),
9942 rejectedFiles = _getValidatedFiles2.rejectedFiles;
9943
9944 setDragging(true);
9945 setInternalError(rejectedFiles.length > 0);
9946 onDragEnter && onDragEnter();
9947 }, [allowMultiple, disabled, dragging, getValidatedFiles, numFiles, onDragEnter]);
9948 var handleDragOver = React.useCallback(function (event) {
9949 stopEvent(event);
9950 if (disabled || !allowMultiple && numFiles > 0) return;
9951 onDragOver && onDragOver();
9952 }, [allowMultiple, disabled, numFiles, onDragOver]);
9953 var handleDragLeave = React.useCallback(function (event) {
9954 event.preventDefault();
9955 if (disabled || !allowMultiple && numFiles > 0) return;
9956 dragTargets.current = dragTargets.current.filter(function (el) {
9957 var compareNode = dropNode && 'current' in dropNode ? dropNode.current : document;
9958 return el !== event.target && compareNode && compareNode.contains(el);
9959 });
9960 if (dragTargets.current.length > 0) return;
9961 setDragging(false);
9962 setInternalError(false);
9963 onDragLeave && onDragLeave();
9964 }, [allowMultiple, disabled, dropNode, numFiles, onDragLeave]);
9965 useEventListener(dropNode, 'drop', handleDrop);
9966 useEventListener(dropNode, 'dragover', handleDragOver);
9967 useEventListener(dropNode, 'dragenter', handleDragEnter);
9968 useEventListener(dropNode, 'dragleave', handleDragLeave);
9969 useEventListener(null, 'resize', adjustSize, {}, {
9970 defaultToWindow: true
9971 });
9972 useComponentDidMount(function () {
9973 adjustSize();
9974 });
9975 React.useEffect(function () {
9976 if (!openFileDialog) return;
9977 open();
9978 onFileDialogClose && onFileDialogClose();
9979 }, [onFileDialogClose, openFileDialog]);
9980 var id = useUniqueId('DropZone', idProp);
9981 var suffix = capitalize(type);
9982 var overlayTextWithDefault = overlayText === undefined ? i18n.translate("Polaris.DropZone.overlayText".concat(suffix)) : overlayText;
9983 var errorOverlayTextWithDefault = errorOverlayText === undefined ? i18n.translate("Polaris.DropZone.errorOverlayText".concat(suffix)) : errorOverlayText;
9984 var inputAttributes = {
9985 id,
9986 accept,
9987 disabled,
9988 type: 'file',
9989 multiple: allowMultiple,
9990 ref: fileInputNode,
9991 onChange: handleDrop,
9992 autoComplete: 'off',
9993 onFocus: handleFocus,
9994 onBlur: handleBlur
9995 };
9996 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);
9997 var dragOverlay = (active || dragging) && (!internalError || !error) && overlay && overlayMarkup(polarisIcons.DragDropMajorMonotone, 'indigo', overlayTextWithDefault);
9998 var dragErrorOverlay = dragging && (internalError || error) && overlayMarkup(polarisIcons.CircleAlertMajorMonotone, 'red', errorOverlayTextWithDefault);
9999 var labelValue = label || i18n.translate('Polaris.DropZone.FileUpload.label');
10000 var labelHiddenValue = label ? labelHidden : true;
10001 var context = React.useMemo(function () {
10002 return {
10003 disabled,
10004 focused,
10005 size,
10006 type: type || 'file',
10007 measuring
10008 };
10009 }, [disabled, focused, measuring, size, type]);
10010 return React__default.createElement(DropZoneContext.Provider, {
10011 value: context
10012 }, React__default.createElement(Labelled, {
10013 id: id,
10014 label: labelValue,
10015 action: labelAction,
10016 labelHidden: labelHiddenValue
10017 }, React__default.createElement("div", {
10018 ref: node,
10019 className: classes,
10020 "aria-disabled": disabled,
10021 onClick: handleClick,
10022 onDragStart: stopEvent
10023 }, dragOverlay, dragErrorOverlay, React__default.createElement("div", {
10024 className: styles$N.Container
10025 }, children), React__default.createElement(VisuallyHidden, null, React__default.createElement("input", inputAttributes)))));
10026
10027 function overlayMarkup(icon, color, text) {
10028 return React__default.createElement("div", {
10029 className: styles$N.Overlay
10030 }, React__default.createElement(Stack, {
10031 vertical: true,
10032 spacing: "tight"
10033 }, React__default.createElement(Icon, {
10034 source: icon,
10035 color: color
10036 }), size === 'extraLarge' && React__default.createElement(DisplayText, {
10037 size: "small",
10038 element: "p"
10039 }, text), (size === 'medium' || size === 'large') && React__default.createElement(Caption, null, text)));
10040 }
10041
10042 function open() {
10043 fileInputNode.current && fileInputNode.current.click();
10044 }
10045
10046 function handleClick(event) {
10047 if (disabled || !allowMultiple && numFiles > 0) return;
10048 return onClick ? onClick(event) : open();
10049 }
10050};
10051
10052function stopEvent(event) {
10053 event.preventDefault();
10054 event.stopPropagation();
10055}
10056
10057DropZone.FileUpload = FileUpload;
10058
10059var 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>
';
10060
10061var styles$O = {
10062 "Image": "Polaris-EmptySearchResult__Image"
10063};
10064
10065function EmptySearchResult(_ref) {
10066 var title = _ref.title,
10067 description = _ref.description,
10068 withIllustration = _ref.withIllustration;
10069 var i18n = useI18n();
10070 var altText = i18n.translate('Polaris.EmptySearchResult.altText');
10071 var descriptionMarkup = description ? React__default.createElement("p", null, description) : null;
10072 var illustrationMarkup = withIllustration ? React__default.createElement(Image, {
10073 alt: altText,
10074 source: emptySearch,
10075 className: styles$O.Image,
10076 draggable: false
10077 }) : null;
10078 return React__default.createElement(Stack, {
10079 alignment: "center",
10080 vertical: true
10081 }, illustrationMarkup, React__default.createElement(DisplayText, {
10082 size: "small"
10083 }, title), React__default.createElement(TextStyle, {
10084 variation: "subdued"
10085 }, descriptionMarkup));
10086}
10087
10088var styles$P = {
10089 "EmptyState": "Polaris-EmptyState",
10090 "Section": "Polaris-EmptyState__Section",
10091 "ImageContainer": "Polaris-EmptyState__ImageContainer",
10092 "DetailsContainer": "Polaris-EmptyState__DetailsContainer",
10093 "withinContentContainer": "Polaris-EmptyState--withinContentContainer",
10094 "Details": "Polaris-EmptyState__Details",
10095 "Image": "Polaris-EmptyState__Image",
10096 "Content": "Polaris-EmptyState__Content",
10097 "withinPage": "Polaris-EmptyState--withinPage",
10098 "imageContained": "Polaris-EmptyState--imageContained",
10099 "Actions": "Polaris-EmptyState__Actions",
10100 "FooterContent": "Polaris-EmptyState__FooterContent"
10101};
10102
10103function EmptyState(_ref) {
10104 var children = _ref.children,
10105 heading = _ref.heading,
10106 image = _ref.image,
10107 largeImage = _ref.largeImage,
10108 imageContained = _ref.imageContained,
10109 action = _ref.action,
10110 secondaryAction = _ref.secondaryAction,
10111 footerContent = _ref.footerContent;
10112 var withinContentContainer = React.useContext(WithinContentContext);
10113 var className = classNames(styles$P.EmptyState, imageContained && styles$P.imageContained, withinContentContainer ? styles$P.withinContentContainer : styles$P.withinPage);
10114 var imageMarkup = largeImage ? React__default.createElement(Image, {
10115 alt: "",
10116 role: "presentation",
10117 className: styles$P.Image,
10118 source: largeImage,
10119 sourceSet: [{
10120 source: image,
10121 descriptor: '568w'
10122 }, {
10123 source: largeImage,
10124 descriptor: '1136w'
10125 }],
10126 sizes: "(max-width: 568px) 60vw"
10127 }) : React__default.createElement(Image, {
10128 role: "presentation",
10129 alt: "",
10130 className: styles$P.Image,
10131 source: image
10132 });
10133 var secondaryActionMarkup = secondaryAction ? buttonFrom(secondaryAction, {
10134 plain: true
10135 }) : null;
10136 var footerContentMarkup = footerContent ? React__default.createElement("div", {
10137 className: styles$P.FooterContent
10138 }, React__default.createElement(TextContainer, null, footerContent)) : null;
10139 var headingSize = withinContentContainer ? 'small' : 'medium';
10140 var primaryActionSize = withinContentContainer ? 'medium' : 'large';
10141 var primaryActionMarkup = action ? buttonFrom(action, {
10142 primary: true,
10143 size: primaryActionSize
10144 }) : null;
10145 var headingMarkup = heading ? React__default.createElement(DisplayText, {
10146 size: headingSize
10147 }, heading) : null;
10148 var childrenMarkup = children ? React__default.createElement("div", {
10149 className: styles$P.Content
10150 }, children) : null;
10151 var textContentMarkup = headingMarkup || children ? React__default.createElement(TextContainer, null, headingMarkup, childrenMarkup) : null;
10152 var actionsMarkup = primaryActionMarkup || secondaryActionMarkup ? React__default.createElement("div", {
10153 className: styles$P.Actions
10154 }, React__default.createElement(Stack, {
10155 alignment: "center"
10156 }, primaryActionMarkup, secondaryActionMarkup)) : null;
10157 var detailsMarkup = textContentMarkup || actionsMarkup || footerContentMarkup ? React__default.createElement("div", {
10158 className: styles$P.DetailsContainer
10159 }, React__default.createElement("div", {
10160 className: styles$P.Details
10161 }, textContentMarkup, actionsMarkup, footerContentMarkup)) : React__default.createElement("div", {
10162 className: styles$P.DetailsContainer
10163 });
10164 return React__default.createElement("div", {
10165 className: className
10166 }, React__default.createElement("div", {
10167 className: styles$P.Section
10168 }, detailsMarkup, React__default.createElement("div", {
10169 className: styles$P.ImageContainer
10170 }, imageMarkup)));
10171}
10172
10173var styles$Q = {
10174 "Truncate": "Polaris-Truncate"
10175};
10176
10177function Truncate(_ref) {
10178 var children = _ref.children;
10179 return React__default.createElement("span", {
10180 className: styles$Q.Truncate
10181 }, children);
10182}
10183
10184var styles$R = {
10185 "ExceptionList": "Polaris-ExceptionList",
10186 "Item": "Polaris-ExceptionList__Item",
10187 "Icon": "Polaris-ExceptionList__Icon",
10188 "statusWarning": "Polaris-ExceptionList--statusWarning",
10189 "statusCritical": "Polaris-ExceptionList--statusCritical",
10190 "Bullet": "Polaris-ExceptionList__Bullet",
10191 "Title": "Polaris-ExceptionList__Title",
10192 "Description": "Polaris-ExceptionList__Description"
10193};
10194
10195function ExceptionList(_ref) {
10196 var itemsList = _ref.items;
10197 var items = itemsList.map(function (item, index) {
10198 var status = item.status,
10199 icon = item.icon,
10200 title = item.title,
10201 description = item.description,
10202 _item$truncate = item.truncate,
10203 truncate = _item$truncate === void 0 ? false : _item$truncate;
10204 var itemClasses = classNames(styles$R.Item, status && styles$R[variationName('status', status)]);
10205 var iconMarkup = icon ? React__default.createElement(Icon, {
10206 source: icon
10207 }) : React__default.createElement("span", {
10208 className: styles$R.Bullet
10209 });
10210 var titleMarkup = title && React__default.createElement("span", {
10211 className: styles$R.Title
10212 }, title);
10213 var descriptionMarkup = description && React__default.createElement("span", {
10214 className: styles$R.Description
10215 }, description);
10216 var Element = truncate ? Truncate : React__default.Fragment;
10217 return React__default.createElement("li", {
10218 className: itemClasses,
10219 key: index
10220 }, React__default.createElement("span", {
10221 className: styles$R.Icon
10222 }, iconMarkup), React__default.createElement(Element, null, titleMarkup, descriptionMarkup));
10223 });
10224 return React__default.createElement("ul", {
10225 className: styles$R.ExceptionList
10226 }, items);
10227}
10228
10229var ResourceListContext = React__default.createContext({});
10230
10231var SELECT_ALL_ITEMS = 'All';
10232
10233var styles$S = {
10234 "Tag": "Polaris-Tag",
10235 "disabled": "Polaris-Tag--disabled",
10236 "TagText": "Polaris-Tag__TagText",
10237 "Button": "Polaris-Tag__Button"
10238};
10239
10240function Tag(_ref) {
10241 var children = _ref.children,
10242 _ref$disabled = _ref.disabled,
10243 disabled = _ref$disabled === void 0 ? false : _ref$disabled,
10244 onRemove = _ref.onRemove;
10245 var i18n = useI18n();
10246 var className = classNames(disabled && styles$S.disabled, styles$S.Tag);
10247 var ariaLabel = i18n.translate('Polaris.Tag.ariaLabel', {
10248 children
10249 });
10250 return React__default.createElement("span", {
10251 className: className
10252 }, React__default.createElement("span", {
10253 title: children,
10254 className: styles$S.TagText
10255 }, children), React__default.createElement("button", {
10256 type: "button",
10257 "aria-label": ariaLabel,
10258 className: styles$S.Button,
10259 onClick: onRemove,
10260 onMouseUp: handleMouseUpByBlurring,
10261 disabled: disabled
10262 }, React__default.createElement(Icon, {
10263 source: polarisIcons.CancelSmallMinor
10264 })));
10265}
10266
10267var Focus =
10268/*#__PURE__*/
10269function (_React$PureComponent) {
10270 _inherits(Focus, _React$PureComponent);
10271
10272 function Focus() {
10273 _classCallCheck(this, Focus);
10274
10275 return _possibleConstructorReturn(this, _getPrototypeOf(Focus).apply(this, arguments));
10276 }
10277
10278 _createClass(Focus, [{
10279 key: "componentDidMount",
10280 value: function componentDidMount() {
10281 this.handleSelfFocus();
10282 }
10283 }, {
10284 key: "componentDidUpdate",
10285 value: function componentDidUpdate(_a) {
10286 var prevChildren = _a.children,
10287 restPrevProps = tslib_1.__rest(_a, ["children"]);
10288
10289 var _b = this.props,
10290 children = _b.children,
10291 restProps = tslib_1.__rest(_b, ["children"]);
10292
10293 if (isEqual(restProps, restPrevProps)) {
10294 return;
10295 }
10296
10297 this.handleSelfFocus();
10298 }
10299 }, {
10300 key: "handleSelfFocus",
10301 value: function handleSelfFocus() {
10302 var _this$props = this.props,
10303 disabled = _this$props.disabled,
10304 root = _this$props.root;
10305
10306 if (disabled) {
10307 return;
10308 }
10309
10310 if (root) {
10311 if (!root.querySelector('[autofocus]')) {
10312 focus.focusFirstFocusableNode(root, false);
10313 }
10314 }
10315 }
10316 }, {
10317 key: "render",
10318 value: function render() {
10319 var children = this.props.children;
10320 return React__default.createElement(React__default.Fragment, null, children);
10321 }
10322 }]);
10323
10324 return Focus;
10325}(React__default.PureComponent);
10326
10327var TrapFocus =
10328/*#__PURE__*/
10329function (_React$PureComponent) {
10330 _inherits(TrapFocus, _React$PureComponent);
10331
10332 function TrapFocus() {
10333 var _this;
10334
10335 _classCallCheck(this, TrapFocus);
10336
10337 _this = _possibleConstructorReturn(this, _getPrototypeOf(TrapFocus).apply(this, arguments));
10338 _this.state = {
10339 shouldFocusSelf: undefined
10340 };
10341
10342 _this.setFocusTrapWrapper = function (node) {
10343 _this.focusTrapWrapper = node;
10344 };
10345
10346 _this.handleBlur = function (event) {
10347 var relatedTarget = event.relatedTarget;
10348
10349 var _assertThisInitialize = _assertThisInitialized(_this),
10350 focusTrapWrapper = _assertThisInitialize.focusTrapWrapper;
10351
10352 var _this$props$trapping = _this.props.trapping,
10353 trapping = _this$props$trapping === void 0 ? true : _this$props$trapping;
10354
10355 if (relatedTarget == null || trapping === false) {
10356 return;
10357 }
10358
10359 if (focusTrapWrapper && !focusTrapWrapper.contains(relatedTarget) && (!relatedTarget || !dom.closest(relatedTarget, '[data-polaris-overlay]'))) {
10360 event.preventDefault();
10361
10362 if (event.srcElement === focus.findFirstFocusableNode(focusTrapWrapper)) {
10363 return fastdom.write(function () {
10364 return focus.focusLastFocusableNode(focusTrapWrapper);
10365 });
10366 }
10367
10368 var firstNode = focus.findFirstFocusableNode(focusTrapWrapper);
10369 fastdom.write(function () {
10370 return focus.focusFirstFocusableNode(firstNode);
10371 });
10372 }
10373 };
10374
10375 return _this;
10376 }
10377
10378 _createClass(TrapFocus, [{
10379 key: "componentDidMount",
10380 value: function componentDidMount() {
10381 this.setState(this.handleTrappingChange());
10382 }
10383 }, {
10384 key: "handleTrappingChange",
10385 value: function handleTrappingChange() {
10386 var _this$props$trapping2 = this.props.trapping,
10387 trapping = _this$props$trapping2 === void 0 ? true : _this$props$trapping2;
10388
10389 if (this.focusTrapWrapper.contains(document.activeElement)) {
10390 return {
10391 shouldFocusSelf: false
10392 };
10393 }
10394
10395 return {
10396 shouldFocusSelf: trapping
10397 };
10398 }
10399 }, {
10400 key: "render",
10401 value: function render() {
10402 var children = this.props.children;
10403 return React__default.createElement(Focus, {
10404 disabled: this.shouldDisable,
10405 root: this.focusTrapWrapper
10406 }, React__default.createElement("div", {
10407 ref: this.setFocusTrapWrapper
10408 }, React__default.createElement(EventListener, {
10409 event: "focusout",
10410 handler: this.handleBlur
10411 }), children));
10412 }
10413 }, {
10414 key: "shouldDisable",
10415 get: function get() {
10416 var _this$props$trapping3 = this.props.trapping,
10417 trapping = _this$props$trapping3 === void 0 ? true : _this$props$trapping3;
10418 var shouldFocusSelf = this.state.shouldFocusSelf;
10419
10420 if (shouldFocusSelf === undefined) {
10421 return true;
10422 }
10423
10424 return shouldFocusSelf ? !trapping : !shouldFocusSelf;
10425 }
10426 }]);
10427
10428 return TrapFocus;
10429}(React__default.PureComponent);
10430
10431var styles$T = {
10432 "Sheet": "Polaris-Sheet",
10433 "Container": "Polaris-Sheet__Container",
10434 "Bottom": "Polaris-Sheet__Bottom",
10435 "enterBottom": "Polaris-Sheet--enterBottom",
10436 "enterBottomActive": "Polaris-Sheet--enterBottomActive",
10437 "exitBottom": "Polaris-Sheet--exitBottom",
10438 "exitBottomActive": "Polaris-Sheet--exitBottomActive",
10439 "Right": "Polaris-Sheet__Right",
10440 "enterRight": "Polaris-Sheet--enterRight",
10441 "enterRightActive": "Polaris-Sheet--enterRightActive",
10442 "exitRight": "Polaris-Sheet--exitRight",
10443 "exitRightActive": "Polaris-Sheet--exitRightActive"
10444};
10445
10446var BOTTOM_CLASS_NAMES = {
10447 enter: classNames(styles$T.Bottom, styles$T.enterBottom),
10448 enterActive: classNames(styles$T.Bottom, styles$T.enterBottomActive),
10449 exit: classNames(styles$T.Bottom, styles$T.exitBottom),
10450 exitActive: classNames(styles$T.Bottom, styles$T.exitBottomActive)
10451};
10452var RIGHT_CLASS_NAMES = {
10453 enter: classNames(styles$T.Right, styles$T.enterRight),
10454 enterActive: classNames(styles$T.Right, styles$T.enterRightActive),
10455 exit: classNames(styles$T.Right, styles$T.exitRight),
10456 exitActive: classNames(styles$T.Right, styles$T.exitRightActive)
10457};
10458function Sheet(_ref) {
10459 var children = _ref.children,
10460 open = _ref.open,
10461 onClose = _ref.onClose,
10462 onEntered = _ref.onEntered,
10463 onExit = _ref.onExit;
10464
10465 var _useMediaQuery = useMediaQuery(),
10466 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
10467
10468 var container = React.useRef(null);
10469 var findDOMNode = React.useCallback(function () {
10470 return container.current;
10471 }, []);
10472 return React__default.createElement(Portal, {
10473 idPrefix: "sheet"
10474 }, React__default.createElement(reactTransitionGroup.CSSTransition, {
10475 findDOMNode: findDOMNode,
10476 classNames: isNavigationCollapsed ? BOTTOM_CLASS_NAMES : RIGHT_CLASS_NAMES,
10477 timeout: Duration.Slow,
10478 in: open,
10479 mountOnEnter: true,
10480 unmountOnExit: true,
10481 onEntered: onEntered,
10482 onExit: onExit
10483 }, React__default.createElement("div", Object.assign({
10484 className: styles$T.Container
10485 }, layer.props, overlay.props, {
10486 ref: container
10487 }), React__default.createElement(TrapFocus, {
10488 trapping: open
10489 }, React__default.createElement("div", {
10490 role: "dialog",
10491 tabIndex: -1,
10492 className: styles$T.Sheet
10493 }, children)))), React__default.createElement(KeypressListener, {
10494 keyCode: exports.Key.Escape,
10495 handler: onClose
10496 }), open && React__default.createElement(Backdrop, {
10497 transparent: true,
10498 onClick: onClose
10499 }));
10500}
10501
10502var styles$U = {
10503 "Item": "Polaris-Filters-ConnectedFilterControl__Item",
10504 "Item-focused": "Polaris-Filters-ConnectedFilterControl__Item--focused",
10505 "ProxyButtonContainer": "Polaris-Filters-ConnectedFilterControl__ProxyButtonContainer",
10506 "ConnectedFilterControl": "Polaris-Filters-ConnectedFilterControl",
10507 "CenterContainer": "Polaris-Filters-ConnectedFilterControl__CenterContainer",
10508 "right": "Polaris-Filters-ConnectedFilterControl--right",
10509 "RightContainer": "Polaris-Filters-ConnectedFilterControl__RightContainer",
10510 "MoreFiltersButtonContainer": "Polaris-Filters-ConnectedFilterControl__MoreFiltersButtonContainer",
10511 "Wrapper": "Polaris-Filters-ConnectedFilterControl__Wrapper",
10512 "AuxiliaryContainer": "Polaris-Filters-ConnectedFilterControl__AuxiliaryContainer"
10513};
10514
10515var Item$4 =
10516/*#__PURE__*/
10517function (_React$PureComponent) {
10518 _inherits(Item, _React$PureComponent);
10519
10520 function Item() {
10521 var _this;
10522
10523 _classCallCheck(this, Item);
10524
10525 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
10526 _this.state = {
10527 focused: false
10528 };
10529
10530 _this.handleBlur = function () {
10531 _this.setState({
10532 focused: false
10533 });
10534 };
10535
10536 _this.handleFocus = function () {
10537 _this.setState({
10538 focused: true
10539 });
10540 };
10541
10542 return _this;
10543 }
10544
10545 _createClass(Item, [{
10546 key: "render",
10547 value: function render() {
10548 var focused = this.state.focused;
10549 var children = this.props.children;
10550 var className = classNames(styles$U.Item, focused && styles$U['Item-focused']);
10551 return React__default.createElement("div", {
10552 onBlur: this.handleBlur,
10553 onFocus: this.handleFocus,
10554 className: className
10555 }, children);
10556 }
10557 }]);
10558
10559 return Item;
10560}(React__default.PureComponent);
10561
10562var FILTER_FIELD_MIN_WIDTH = 150;
10563var ConnectedFilterControl =
10564/*#__PURE__*/
10565function (_React$Component) {
10566 _inherits(ConnectedFilterControl, _React$Component);
10567
10568 function ConnectedFilterControl() {
10569 var _this;
10570
10571 _classCallCheck(this, ConnectedFilterControl);
10572
10573 _this = _possibleConstructorReturn(this, _getPrototypeOf(ConnectedFilterControl).apply(this, arguments));
10574 _this.state = {
10575 availableWidth: 0,
10576 proxyButtonsWidth: {}
10577 };
10578 _this.container = React__default.createRef();
10579 _this.proxyButtonContainer = React__default.createRef();
10580 _this.moreFiltersButtonContainer = React__default.createRef();
10581 _this.handleResize = debounce(function () {
10582 _this.measureProxyButtons();
10583
10584 _this.measureAvailableWidth();
10585 }, 40, {
10586 leading: true,
10587 trailing: true,
10588 maxWait: 40
10589 });
10590 return _this;
10591 }
10592
10593 _createClass(ConnectedFilterControl, [{
10594 key: "componentDidMount",
10595 value: function componentDidMount() {
10596 this.handleResize();
10597 }
10598 }, {
10599 key: "render",
10600 value: function render() {
10601 var _this2 = this;
10602
10603 var _this$props = this.props,
10604 children = _this$props.children,
10605 rightPopoverableActions = _this$props.rightPopoverableActions,
10606 rightAction = _this$props.rightAction,
10607 auxiliary = _this$props.auxiliary;
10608 var className = classNames(styles$U.ConnectedFilterControl, rightPopoverableActions && styles$U.right);
10609 var rightMarkup = rightPopoverableActions ? React__default.createElement("div", {
10610 className: styles$U.RightContainer
10611 }, this.popoverFrom(this.getActionsToRender(rightPopoverableActions))) : null;
10612 var rightActionMarkup = rightAction ? React__default.createElement("div", {
10613 ref: this.moreFiltersButtonContainer,
10614 className: styles$U.MoreFiltersButtonContainer
10615 }, React__default.createElement(Item$4, null, rightAction)) : null;
10616 var proxyButtonMarkup = rightPopoverableActions ? React__default.createElement("div", {
10617 className: styles$U.ProxyButtonContainer,
10618 ref: this.proxyButtonContainer,
10619 "aria-hidden": true
10620 }, rightPopoverableActions.map(function (action) {
10621 return React__default.createElement("div", {
10622 key: action.key,
10623 "data-key": action.key
10624 }, _this2.activatorButtonFrom(action));
10625 })) : null;
10626 var auxMarkup = auxiliary ? React__default.createElement("div", {
10627 className: styles$U.AuxiliaryContainer
10628 }, auxiliary) : null;
10629 return React__default.createElement(React__default.Fragment, null, proxyButtonMarkup, React__default.createElement("div", {
10630 className: styles$U.Wrapper
10631 }, React__default.createElement("div", {
10632 className: className,
10633 ref: this.container
10634 }, React__default.createElement("div", {
10635 className: styles$U.CenterContainer
10636 }, React__default.createElement(Item$4, null, children)), rightMarkup, rightActionMarkup, React__default.createElement(EventListener, {
10637 event: "resize",
10638 handler: this.handleResize
10639 })), auxMarkup));
10640 }
10641 }, {
10642 key: "measureProxyButtons",
10643 value: function measureProxyButtons() {
10644 if (this.proxyButtonContainer.current) {
10645 var proxyButtonsWidth = {}; // this number is magical, but tweaking it solved the problem of items overlapping
10646
10647 var tolerance = 52;
10648
10649 if (this.proxyButtonContainer.current) {
10650 Array.from(this.proxyButtonContainer.current.children).forEach(function (element) {
10651 var buttonWidth = element.getBoundingClientRect().width + tolerance;
10652 var buttonKey = element.dataset.key;
10653
10654 if (buttonKey) {
10655 proxyButtonsWidth[buttonKey] = buttonWidth;
10656 }
10657 });
10658 }
10659
10660 this.setState({
10661 proxyButtonsWidth
10662 });
10663 }
10664 }
10665 }, {
10666 key: "measureAvailableWidth",
10667 value: function measureAvailableWidth() {
10668 if (this.container.current && this.moreFiltersButtonContainer.current) {
10669 var containerWidth = this.container.current.getBoundingClientRect().width;
10670 var moreFiltersButtonWidth = this.moreFiltersButtonContainer.current.getBoundingClientRect().width;
10671 var filtersActionWidth = 0;
10672 var availableWidth = containerWidth - FILTER_FIELD_MIN_WIDTH - moreFiltersButtonWidth - filtersActionWidth;
10673 this.setState({
10674 availableWidth
10675 });
10676 }
10677 }
10678 }, {
10679 key: "getActionsToRender",
10680 value: function getActionsToRender(actions) {
10681 var remainingWidth = this.state.availableWidth;
10682 var actionsToReturn = [];
10683
10684 for (var i = 0; remainingWidth > 0 && i < actions.length; i++) {
10685 var action = actions[i];
10686 var actionWidth = this.state.proxyButtonsWidth[action.key];
10687
10688 if (actionWidth <= remainingWidth) {
10689 actionsToReturn.push(action);
10690 remainingWidth -= actionWidth;
10691 }
10692 }
10693
10694 return actionsToReturn;
10695 }
10696 }, {
10697 key: "activatorButtonFrom",
10698 value: function activatorButtonFrom(action) {
10699 return React__default.createElement(Button, {
10700 onClick: action.onAction,
10701 disclosure: true,
10702 disabled: this.props.disabled || action.disabled,
10703 id: "Activator-".concat(action.key)
10704 }, action.content);
10705 }
10706 }, {
10707 key: "popoverFrom",
10708 value: function popoverFrom(actions) {
10709 var _this3 = this;
10710
10711 return actions.map(function (action) {
10712 return React__default.createElement(Item$4, {
10713 key: action.key
10714 }, React__default.createElement(Popover, {
10715 active: action.popoverOpen,
10716 activator: _this3.activatorButtonFrom(action),
10717 onClose: action.onAction,
10718 preferredAlignment: "left",
10719 sectioned: true
10720 }, action.popoverContent));
10721 });
10722 }
10723 }]);
10724
10725 return ConnectedFilterControl;
10726}(React__default.Component);
10727
10728var styles$V = {
10729 "Filters": "Polaris-Filters",
10730 "FiltersContainer": "Polaris-Filters__FiltersContainer",
10731 "FiltersContainerHeader": "Polaris-Filters__FiltersContainerHeader",
10732 "FiltersDesktopContainerContent": "Polaris-Filters__FiltersDesktopContainerContent",
10733 "FiltersMobileContainerContent": "Polaris-Filters__FiltersMobileContainerContent",
10734 "FiltersContainerFooter": "Polaris-Filters__FiltersContainerFooter",
10735 "FiltersMobileContainerFooter": "Polaris-Filters__FiltersMobileContainerFooter",
10736 "EmptyFooterState": "Polaris-Filters__EmptyFooterState",
10737 "FilterTriggerContainer": "Polaris-Filters__FilterTriggerContainer",
10738 "FilterTrigger": "Polaris-Filters__FilterTrigger",
10739 "FilterTriggerTitle": "Polaris-Filters__FilterTriggerTitle",
10740 "AppliedFilterBadgeContainer": "Polaris-Filters__AppliedFilterBadgeContainer",
10741 "open": "Polaris-Filters--open",
10742 "FilterTriggerLabelContainer": "Polaris-Filters__FilterTriggerLabelContainer",
10743 "first": "Polaris-Filters--first",
10744 "last": "Polaris-Filters--last",
10745 "FilterNodeContainer": "Polaris-Filters__FilterNodeContainer",
10746 "SearchIcon": "Polaris-Filters__SearchIcon",
10747 "Backdrop": "Polaris-Filters__Backdrop",
10748 "HelpText": "Polaris-Filters__HelpText",
10749 "TagsContainer": "Polaris-Filters__TagsContainer"
10750};
10751
10752var Suffix;
10753
10754(function (Suffix) {
10755 Suffix["Filter"] = "Filter";
10756 Suffix["Shortcut"] = "Shortcut";
10757})(Suffix || (Suffix = {}));
10758
10759var Filters =
10760/*#__PURE__*/
10761function (_React$Component) {
10762 _inherits(Filters, _React$Component);
10763
10764 function Filters() {
10765 var _this;
10766
10767 _classCallCheck(this, Filters);
10768
10769 _this = _possibleConstructorReturn(this, _getPrototypeOf(Filters).apply(this, arguments));
10770 _this.state = {
10771 open: false,
10772 readyForFocus: false
10773 };
10774 _this.moreFiltersButtonContainer = React.createRef();
10775 _this.focusNode = React.createRef();
10776
10777 _this.closeFilters = function () {
10778 _this.setState({
10779 open: false
10780 }, function () {
10781 if (_this.moreFiltersButtonContainer.current) {
10782 focus.focusFirstFocusableNode(_this.moreFiltersButtonContainer.current, false);
10783 }
10784 });
10785 };
10786
10787 _this.toggleFilters = function () {
10788 if (_this.state.open === true) {
10789 _this.closeFilters();
10790 } else {
10791 _this.openFilters();
10792 }
10793 };
10794
10795 _this.setReadyForFocus = function (newState) {
10796 return function () {
10797 _this.setState({
10798 readyForFocus: newState
10799 });
10800 };
10801 };
10802
10803 return _this;
10804 }
10805
10806 _createClass(Filters, [{
10807 key: "render",
10808 value: function render() {
10809 var _this2 = this;
10810
10811 var _this$props = this.props,
10812 filters = _this$props.filters,
10813 queryValue = _this$props.queryValue,
10814 onQueryBlur = _this$props.onQueryBlur,
10815 onQueryChange = _this$props.onQueryChange,
10816 onQueryFocus = _this$props.onQueryFocus,
10817 focused = _this$props.focused,
10818 onClearAll = _this$props.onClearAll,
10819 appliedFilters = _this$props.appliedFilters,
10820 _this$props$polaris = _this$props.polaris,
10821 intl = _this$props$polaris.intl,
10822 isNavigationCollapsed = _this$props$polaris.mediaQuery.isNavigationCollapsed,
10823 onQueryClear = _this$props.onQueryClear,
10824 queryPlaceholder = _this$props.queryPlaceholder,
10825 children = _this$props.children,
10826 _this$props$disabled = _this$props.disabled,
10827 disabled = _this$props$disabled === void 0 ? false : _this$props$disabled,
10828 helpText = _this$props.helpText;
10829 var resourceName = this.context.resourceName;
10830 var _this$state = this.state,
10831 open = _this$state.open,
10832 readyForFocus = _this$state.readyForFocus;
10833 var backdropMarkup = open ? React__default.createElement(React__default.Fragment, null, React__default.createElement(ScrollLock, null), React__default.createElement("div", {
10834 className: styles$V.Backdrop,
10835 onClick: this.closeFilters
10836 })) : null;
10837 var filtersContentMarkup = filters.map(function (filter, index) {
10838 var filterIsOpen = _this2.state["".concat(filter.key).concat(Suffix.Filter)] === true;
10839 var icon = filterIsOpen ? polarisIcons.ChevronUpMinor : polarisIcons.ChevronDownMinor;
10840 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);
10841
10842 var appliedFilterContent = _this2.getAppliedFilterContent(filter.key);
10843
10844 var appliedFilterBadgeMarkup = appliedFilterContent ? React__default.createElement("div", {
10845 className: styles$V.AppliedFilterBadgeContainer
10846 }, React__default.createElement(Badge, {
10847 size: "small",
10848 status: "new"
10849 }, appliedFilterContent)) : null;
10850 var collapsibleID = "".concat(filter.key, "Collapsible");
10851 return React__default.createElement("div", {
10852 key: filter.key,
10853 className: className
10854 }, React__default.createElement("button", {
10855 onClick: function onClick() {
10856 return _this2.toggleFilter(filter.key);
10857 },
10858 className: styles$V.FilterTrigger,
10859 id: "".concat(filter.key, "ToggleButton"),
10860 type: "button",
10861 "aria-controls": collapsibleID,
10862 "aria-expanded": filterIsOpen
10863 }, React__default.createElement("div", {
10864 className: styles$V.FilterTriggerLabelContainer
10865 }, React__default.createElement("h2", {
10866 className: styles$V.FilterTriggerTitle
10867 }, React__default.createElement(TextStyle, {
10868 variation: _this2.props.disabled || filter.disabled ? VariationValue.Subdued : undefined
10869 }, filter.label)), React__default.createElement("span", {
10870 className: styles$V.FilterTriggerIcon
10871 }, React__default.createElement(Icon, {
10872 source: icon,
10873 color: "inkLightest"
10874 }))), appliedFilterBadgeMarkup), React__default.createElement(Collapsible, {
10875 id: collapsibleID,
10876 open: filterIsOpen
10877 }, React__default.createElement("div", {
10878 className: styles$V.FilterNodeContainer
10879 }, React__default.createElement(Focus, {
10880 disabled: !filterIsOpen || !readyForFocus || !open,
10881 root: _this2.focusNode.current
10882 }, _this2.generateFilterMarkup(filter)))));
10883 });
10884 var rightActionMarkup = React__default.createElement("div", {
10885 ref: this.moreFiltersButtonContainer
10886 }, React__default.createElement(Button, {
10887 onClick: this.toggleFilters,
10888 disabled: disabled
10889 }, intl.translate('Polaris.Filters.moreFilters')));
10890 var filterResourceName = resourceName || {
10891 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
10892 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
10893 };
10894 var filtersControlMarkup = React__default.createElement(ConnectedFilterControl, {
10895 rightPopoverableActions: this.transformFilters(filters),
10896 rightAction: rightActionMarkup,
10897 auxiliary: children,
10898 disabled: disabled
10899 }, React__default.createElement(TextField, {
10900 placeholder: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10901 resourceName: filterResourceName.plural
10902 }),
10903 onChange: onQueryChange,
10904 onBlur: onQueryBlur,
10905 onFocus: onQueryFocus,
10906 value: queryValue,
10907 focused: focused,
10908 label: queryPlaceholder || intl.translate('Polaris.Filters.filter', {
10909 resourceName: filterResourceName.plural
10910 }),
10911 labelHidden: true,
10912 prefix: React__default.createElement("span", {
10913 className: styles$V.SearchIcon
10914 }, React__default.createElement(Icon, {
10915 source: polarisIcons.SearchMinor
10916 })),
10917 clearButton: true,
10918 onClearButtonClick: onQueryClear,
10919 disabled: disabled
10920 }));
10921 var filtersDesktopHeaderMarkup = React__default.createElement("div", {
10922 className: styles$V.FiltersContainerHeader
10923 }, React__default.createElement(DisplayText, {
10924 size: "small"
10925 }, intl.translate('Polaris.Filters.moreFilters')), React__default.createElement(Button, {
10926 icon: polarisIcons.CancelSmallMinor,
10927 plain: true,
10928 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10929 onClick: this.closeFilters
10930 }));
10931 var filtersMobileHeaderMarkup = React__default.createElement("div", {
10932 className: styles$V.FiltersContainerHeader
10933 }, React__default.createElement(Button, {
10934 icon: polarisIcons.CancelSmallMinor,
10935 plain: true,
10936 accessibilityLabel: intl.translate('Polaris.Filters.cancel'),
10937 onClick: this.closeFilters
10938 }), React__default.createElement(DisplayText, {
10939 size: "small"
10940 }, intl.translate('Polaris.Filters.moreFilters')), React__default.createElement(Button, {
10941 onClick: this.closeFilters,
10942 primary: true
10943 }, intl.translate('Polaris.Filters.done')));
10944 var filtersDesktopFooterMarkup = React__default.createElement("div", {
10945 className: styles$V.FiltersContainerFooter
10946 }, React__default.createElement(Button, {
10947 onClick: onClearAll,
10948 disabled: !this.hasAppliedFilters
10949 }, intl.translate('Polaris.Filters.clearAllFilters')), React__default.createElement(Button, {
10950 onClick: this.closeFilters,
10951 primary: true
10952 }, intl.translate('Polaris.Filters.done')));
10953 var filtersMobileFooterMarkup = React__default.createElement("div", {
10954 className: styles$V.FiltersMobileContainerFooter
10955 }, this.hasAppliedFilters ? React__default.createElement(Button, {
10956 onClick: onClearAll,
10957 fullWidth: true
10958 }, intl.translate('Polaris.Filters.clearAllFilters')) : React__default.createElement("div", {
10959 className: styles$V.EmptyFooterState
10960 }, React__default.createElement(TextStyle, {
10961 variation: "subdued"
10962 }, React__default.createElement("p", null, intl.translate('Polaris.Filters.noFiltersApplied')))));
10963 var tagsMarkup = appliedFilters && appliedFilters.length ? React__default.createElement("div", {
10964 className: styles$V.TagsContainer
10965 }, appliedFilters.map(function (filter) {
10966 return React__default.createElement(Tag, {
10967 key: filter.key,
10968 onRemove: function onRemove() {
10969 filter.onRemove(filter.key);
10970 },
10971 disabled: disabled
10972 }, filter.label);
10973 })) : null;
10974 var filtersContainerMarkup = isNavigationCollapsed ? React__default.createElement(Sheet, {
10975 open: open,
10976 onClose: this.closeFilters,
10977 onEntered: this.setReadyForFocus(true),
10978 onExit: this.setReadyForFocus(false)
10979 }, filtersMobileHeaderMarkup, React__default.createElement(Scrollable, {
10980 className: styles$V.FiltersMobileContainerContent,
10981 shadow: true
10982 }, filtersContentMarkup, filtersMobileFooterMarkup)) : React__default.createElement(Sheet, {
10983 open: open,
10984 onClose: this.closeFilters,
10985 onEntered: this.setReadyForFocus(true),
10986 onExit: this.setReadyForFocus(false)
10987 }, React__default.createElement("div", {
10988 className: styles$V.FiltersContainer
10989 }, filtersDesktopHeaderMarkup, React__default.createElement(Scrollable, {
10990 className: styles$V.FiltersDesktopContainerContent,
10991 shadow: true
10992 }, filtersContentMarkup), filtersDesktopFooterMarkup));
10993 var helpTextMarkup = helpText ? React__default.createElement("div", {
10994 id: "FiltersHelpText",
10995 className: styles$V.HelpText
10996 }, React__default.createElement(TextStyle, {
10997 variation: "subdued"
10998 }, helpText)) : null;
10999 return React__default.createElement("div", {
11000 className: styles$V.Filters
11001 }, filtersControlMarkup, filtersContainerMarkup, tagsMarkup, helpTextMarkup, backdropMarkup, React__default.createElement(KeypressListener, {
11002 keyCode: exports.Key.Escape,
11003 handler: this.closeFilters
11004 }));
11005 }
11006 }, {
11007 key: "getAppliedFilterContent",
11008 value: function getAppliedFilterContent(key) {
11009 var appliedFilters = this.props.appliedFilters;
11010
11011 if (!appliedFilters) {
11012 return undefined;
11013 }
11014
11015 var filter = appliedFilters.find(function (filter) {
11016 return filter.key === key;
11017 });
11018 return filter == null ? undefined : filter.label;
11019 }
11020 }, {
11021 key: "getAppliedFilterRemoveHandler",
11022 value: function getAppliedFilterRemoveHandler(key) {
11023 var appliedFilters = this.props.appliedFilters;
11024
11025 if (!appliedFilters) {
11026 return undefined;
11027 }
11028
11029 var filter = appliedFilters.find(function (filter) {
11030 return filter.key === key;
11031 });
11032 return filter == null ? undefined : filter.onRemove;
11033 }
11034 }, {
11035 key: "openFilters",
11036 value: function openFilters() {
11037 this.setState({
11038 open: true
11039 });
11040 }
11041 }, {
11042 key: "openFilter",
11043 value: function openFilter(key) {
11044 this.setState({
11045 ["".concat(key).concat(Suffix.Filter)]: true
11046 });
11047 }
11048 }, {
11049 key: "closeFilter",
11050 value: function closeFilter(key) {
11051 this.setState({
11052 ["".concat(key).concat(Suffix.Filter)]: false
11053 });
11054 }
11055 }, {
11056 key: "toggleFilter",
11057 value: function toggleFilter(key) {
11058 if (this.state["".concat(key).concat(Suffix.Filter)] === true) {
11059 this.closeFilter(key);
11060 } else {
11061 this.openFilter(key);
11062 }
11063 }
11064 }, {
11065 key: "openFilterShortcut",
11066 value: function openFilterShortcut(key) {
11067 this.setState({
11068 ["".concat(key).concat(Suffix.Shortcut)]: true
11069 });
11070 }
11071 }, {
11072 key: "closeFilterShortcut",
11073 value: function closeFilterShortcut(key) {
11074 this.setState({
11075 ["".concat(key).concat(Suffix.Shortcut)]: false
11076 });
11077 }
11078 }, {
11079 key: "toggleFilterShortcut",
11080 value: function toggleFilterShortcut(key) {
11081 if (this.state["".concat(key).concat(Suffix.Shortcut)] === true) {
11082 this.closeFilterShortcut(key);
11083 } else {
11084 this.openFilterShortcut(key);
11085 }
11086 }
11087 }, {
11088 key: "transformFilters",
11089 value: function transformFilters(filters) {
11090 var _this3 = this;
11091
11092 var transformedActions = [];
11093 getShortcutFilters(filters).forEach(function (filter) {
11094 var key = filter.key,
11095 label = filter.label,
11096 disabled = filter.disabled;
11097 transformedActions.push({
11098 popoverContent: _this3.generateFilterMarkup(filter),
11099 popoverOpen: _this3.state["".concat(key).concat(Suffix.Shortcut)],
11100 key,
11101 content: label,
11102 disabled,
11103 onAction: function onAction() {
11104 return _this3.toggleFilterShortcut(key);
11105 }
11106 });
11107 });
11108 return transformedActions;
11109 }
11110 }, {
11111 key: "generateFilterMarkup",
11112 value: function generateFilterMarkup(filter) {
11113 var intl = this.props.polaris.intl;
11114 var removeCallback = this.getAppliedFilterRemoveHandler(filter.key);
11115 var removeHandler = removeCallback == null ? undefined : function () {
11116 removeCallback(filter.key);
11117 };
11118 return React__default.createElement("div", {
11119 ref: this.focusNode
11120 }, React__default.createElement(Stack, {
11121 vertical: true,
11122 spacing: "tight"
11123 }, filter.filter, React__default.createElement(Button, {
11124 plain: true,
11125 disabled: removeHandler == null,
11126 onClick: removeHandler,
11127 accessibilityLabel: intl.translate('Polaris.Filters.clearLabel', {
11128 filterName: filter.label
11129 })
11130 }, intl.translate('Polaris.Filters.clear'))));
11131 }
11132 }, {
11133 key: "hasAppliedFilters",
11134 get: function get() {
11135 var _this$props2 = this.props,
11136 appliedFilters = _this$props2.appliedFilters,
11137 queryValue = _this$props2.queryValue;
11138 var filtersApplied = Boolean(appliedFilters && appliedFilters.length > 0);
11139 var queryApplied = Boolean(queryValue && queryValue !== '');
11140 return filtersApplied || queryApplied;
11141 }
11142 }]);
11143
11144 return Filters;
11145}(React__default.Component);
11146
11147Filters.contextType = ResourceListContext;
11148
11149function getShortcutFilters(filters) {
11150 return filters.filter(function (filter) {
11151 return filter.shortcut === true;
11152 });
11153} // Use named export once withAppProvider is refactored away
11154// eslint-disable-next-line import/no-default-export
11155
11156
11157var Filters$1 = withAppProvider()(Filters);
11158
11159var styles$W = {
11160 "FooterHelp": "Polaris-FooterHelp",
11161 "Content": "Polaris-FooterHelp__Content",
11162 "Icon": "Polaris-FooterHelp__Icon",
11163 "Text": "Polaris-FooterHelp__Text"
11164};
11165
11166function FooterHelp(_ref) {
11167 var children = _ref.children;
11168 return React__default.createElement("div", {
11169 className: styles$W.FooterHelp
11170 }, React__default.createElement("div", {
11171 className: styles$W.Content
11172 }, React__default.createElement("div", {
11173 className: styles$W.Icon
11174 }, React__default.createElement(Icon, {
11175 source: polarisIcons.QuestionMarkMajorTwotone,
11176 color: "teal",
11177 backdrop: true
11178 })), React__default.createElement("div", {
11179 className: styles$W.Text
11180 }, children)));
11181}
11182
11183function Form(_ref) {
11184 var acceptCharset = _ref.acceptCharset,
11185 action = _ref.action,
11186 autoComplete = _ref.autoComplete,
11187 children = _ref.children,
11188 encType = _ref.encType,
11189 _ref$implicitSubmit = _ref.implicitSubmit,
11190 implicitSubmit = _ref$implicitSubmit === void 0 ? true : _ref$implicitSubmit,
11191 _ref$method = _ref.method,
11192 method = _ref$method === void 0 ? 'post' : _ref$method,
11193 name = _ref.name,
11194 noValidate = _ref.noValidate,
11195 _ref$preventDefault = _ref.preventDefault,
11196 preventDefault = _ref$preventDefault === void 0 ? true : _ref$preventDefault,
11197 target = _ref.target,
11198 onSubmit = _ref.onSubmit;
11199 var i18n = useI18n();
11200 var handleSubmit = React.useCallback(function (event) {
11201 if (!preventDefault) {
11202 return;
11203 }
11204
11205 event.preventDefault();
11206 onSubmit(event);
11207 }, [onSubmit, preventDefault]);
11208 var autoCompleteInputs = normalizeAutoComplete$1(autoComplete);
11209 var submitMarkup = implicitSubmit ? React__default.createElement(VisuallyHidden, null, React__default.createElement("button", {
11210 type: "submit",
11211 "aria-hidden": "true",
11212 tabIndex: -1
11213 }, i18n.translate('Polaris.Common.submit'))) : null;
11214 return React__default.createElement("form", {
11215 acceptCharset: acceptCharset,
11216 action: action,
11217 autoComplete: autoCompleteInputs,
11218 encType: encType,
11219 method: method,
11220 name: name,
11221 noValidate: noValidate,
11222 target: target,
11223 onSubmit: handleSubmit
11224 }, children, submitMarkup);
11225}
11226
11227function normalizeAutoComplete$1(autoComplete) {
11228 if (autoComplete == null) {
11229 return autoComplete;
11230 }
11231
11232 return autoComplete ? 'on' : 'off';
11233}
11234
11235var styles$X = {
11236 "FormLayout": "Polaris-FormLayout",
11237 "Title": "Polaris-FormLayout__Title",
11238 "Items": "Polaris-FormLayout__Items",
11239 "HelpText": "Polaris-FormLayout__HelpText",
11240 "Item": "Polaris-FormLayout__Item",
11241 "grouped": "Polaris-FormLayout--grouped",
11242 "condensed": "Polaris-FormLayout--condensed"
11243};
11244
11245function Item$5(props) {
11246 return React__default.createElement("div", {
11247 className: styles$X.Item
11248 }, props.children);
11249}
11250
11251function Group(_ref) {
11252 var children = _ref.children,
11253 condensed = _ref.condensed,
11254 title = _ref.title,
11255 helpText = _ref.helpText;
11256 var className = classNames(condensed ? styles$X.condensed : styles$X.grouped);
11257 var id = useUniqueId('FormLayoutGroup');
11258 var helpTextElement = null;
11259 var helpTextID;
11260 var titleElement = null;
11261 var titleID;
11262
11263 if (helpText) {
11264 helpTextID = "".concat(id, "HelpText");
11265 helpTextElement = React__default.createElement("div", {
11266 id: helpTextID,
11267 className: styles$X.HelpText
11268 }, helpText);
11269 }
11270
11271 if (title) {
11272 titleID = "".concat(id, "Title");
11273 titleElement = React__default.createElement("div", {
11274 id: titleID,
11275 className: styles$X.Title
11276 }, title);
11277 }
11278
11279 var itemsMarkup = React__default.Children.map(children, function (child) {
11280 return wrapWithComponent(child, Item$5, {});
11281 });
11282 return React__default.createElement("div", {
11283 role: "group",
11284 className: className,
11285 "aria-labelledby": titleID,
11286 "aria-describedby": helpTextID
11287 }, titleElement, React__default.createElement("div", {
11288 className: styles$X.Items
11289 }, itemsMarkup), helpTextElement);
11290}
11291
11292var FormLayout =
11293/*#__PURE__*/
11294function (_React$PureComponent) {
11295 _inherits(FormLayout, _React$PureComponent);
11296
11297 function FormLayout() {
11298 _classCallCheck(this, FormLayout);
11299
11300 return _possibleConstructorReturn(this, _getPrototypeOf(FormLayout).apply(this, arguments));
11301 }
11302
11303 _createClass(FormLayout, [{
11304 key: "render",
11305 value: function render() {
11306 var children = this.props.children;
11307 return React__default.createElement("div", {
11308 className: styles$X.FormLayout
11309 }, React__default.Children.map(children, wrapChildren));
11310 }
11311 }]);
11312
11313 return FormLayout;
11314}(React__default.PureComponent);
11315FormLayout.Group = Group;
11316
11317function wrapChildren(child, index) {
11318 if (isElementOfType(child, Group)) {
11319 return child;
11320 }
11321
11322 var props = {
11323 key: index
11324 };
11325 return wrapWithComponent(child, Item$5, props);
11326}
11327
11328function setRootProperty(name, value, node) {
11329 if (document == null) {
11330 return;
11331 }
11332
11333 var styleNode = node && node instanceof HTMLElement ? node : document.documentElement;
11334 styleNode && styleNode.style.setProperty(name, value);
11335}
11336
11337var styles$Y = {
11338 "Toast": "Polaris-Frame-Toast",
11339 "Action": "Polaris-Frame-Toast__Action",
11340 "error": "Polaris-Frame-Toast--error",
11341 "CloseButton": "Polaris-Frame-Toast__CloseButton"
11342};
11343
11344var DEFAULT_TOAST_DURATION = 5000;
11345var DEFAULT_TOAST_DURATION_WITH_ACTION = 10000;
11346function Toast(_ref) {
11347 var content = _ref.content,
11348 onDismiss = _ref.onDismiss,
11349 duration = _ref.duration,
11350 error = _ref.error,
11351 action = _ref.action;
11352 React.useEffect(function () {
11353 var timeoutDuration = duration || DEFAULT_TOAST_DURATION;
11354
11355 if (action && !duration) {
11356 timeoutDuration = DEFAULT_TOAST_DURATION_WITH_ACTION;
11357 } else if (action && duration && duration < DEFAULT_TOAST_DURATION_WITH_ACTION) {
11358 // eslint-disable-next-line no-console
11359 console.log('Toast with action should persist for at least 10,000 milliseconds to give the merchant enough time to act on it.');
11360 }
11361
11362 var timer = setTimeout(onDismiss, timeoutDuration);
11363 return function () {
11364 clearTimeout(timer);
11365 };
11366 }, [action, duration, onDismiss]);
11367 var dismissMarkup = React__default.createElement("button", {
11368 type: "button",
11369 className: styles$Y.CloseButton,
11370 onClick: onDismiss
11371 }, React__default.createElement(Icon, {
11372 source: polarisIcons.MobileCancelMajorMonotone
11373 }));
11374 var actionMarkup = action ? React__default.createElement("div", {
11375 className: styles$Y.Action
11376 }, React__default.createElement(Button, {
11377 plain: true,
11378 monochrome: true,
11379 onClick: action.onAction
11380 }, action.content)) : null;
11381 var className = classNames(styles$Y.Toast, error && styles$Y.error);
11382 return React__default.createElement("div", {
11383 className: className
11384 }, React__default.createElement(KeypressListener, {
11385 keyCode: exports.Key.Escape,
11386 handler: onDismiss
11387 }), content, actionMarkup, dismissMarkup);
11388}
11389
11390/**
11391 * A replacement for React.useCallback that'll allow for custom and deep compares.
11392 * @see {@link https://reactjs.org/docs/hooks-reference.html#usecallback}
11393 * @param callback Accepts a callback that's forwarded to React.useCallback
11394 * @param dependencies A dependency array similar to React.useCallback however it utilizes a deep compare
11395 * @param customCompare Opportunity to provide a custom compare function
11396 * @returns A memoized callback
11397 * @example
11398 * const Child = memo(function Child({onClick}) {
11399 * console.log('Child has rendered.');
11400 * return <button onClick={onClick}>Click me</button>;
11401 * });
11402 *
11403 * function ComponentExample() {
11404 * const [timesClicked, setTimesClicked] = useState(0);
11405 *
11406 * const handleClick = useDeepCallback(() => {
11407 * setTimesClicked((timesClicked) => timesClicked + 1);
11408 * // New reference every render
11409 * }, [{}]);
11410 *
11411 * return (
11412 * <Fragment>
11413 * <div>Times clicked: {timesClicked}</div>
11414 * <Child onClick={handleClick} />
11415 * </Fragment>
11416 * );
11417 * }
11418 */
11419
11420function useDeepCallback(callback, dependencies, customCompare) {
11421 return React.useCallback(callback, useDeepCompareRef(dependencies, customCompare));
11422}
11423
11424var styles$Z = {
11425 "ToastManager": "Polaris-Frame-ToastManager",
11426 "ToastWrapper": "Polaris-Frame-ToastManager__ToastWrapper",
11427 "ToastWrapper-enter": "Polaris-Frame-ToastManager__ToastWrapper--enter",
11428 "ToastWrapper-exit": "Polaris-Frame-ToastManager__ToastWrapper--exit",
11429 "ToastWrapper-enter-done": "Polaris-Frame-ToastManager--toastWrapperEnterDone"
11430};
11431
11432var ToastManager = React.memo(function ToastManager(_ref) {
11433 var toastMessages = _ref.toastMessages;
11434 var toastNodes = [];
11435 var updateToasts = useDeepCallback(function () {
11436 var targetInPos = 0;
11437 toastMessages.forEach(function (_, index) {
11438 var currentToast = toastNodes[index];
11439 if (!currentToast.current) return;
11440 targetInPos += currentToast.current.clientHeight;
11441 currentToast.current.style.setProperty('--toast-translate-y-in', "-".concat(targetInPos, "px"));
11442 currentToast.current.style.setProperty('--toast-translate-y-out', "".concat(-targetInPos + 150, "px"));
11443 });
11444 }, [toastMessages, toastNodes]);
11445 useDeepEffect(function () {
11446 updateToasts();
11447 }, [toastMessages]);
11448 var toastsMarkup = toastMessages.map(function (toast, index) {
11449 var toastNode = React.createRef();
11450 toastNodes[index] = toastNode;
11451 return React__default.createElement(reactTransitionGroup.CSSTransition, {
11452 findDOMNode: findDOMNode(index),
11453 key: toast.id,
11454 timeout: {
11455 enter: 0,
11456 exit: 400
11457 },
11458 classNames: toastClasses
11459 }, React__default.createElement("div", {
11460 ref: toastNode
11461 }, React__default.createElement(Toast, toast)));
11462 });
11463 return React__default.createElement(Portal, {
11464 idPrefix: "toast-manager"
11465 }, React__default.createElement(EventListener, {
11466 event: "resize",
11467 handler: updateToasts
11468 }), React__default.createElement("div", {
11469 className: styles$Z.ToastManager,
11470 "aria-live": "polite"
11471 }, React__default.createElement(reactTransitionGroup.TransitionGroup, {
11472 component: null
11473 }, toastsMarkup)));
11474
11475 function findDOMNode(index) {
11476 return function () {
11477 return toastNodes[index].current;
11478 };
11479 }
11480});
11481var toastClasses = {
11482 enter: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter']),
11483 enterDone: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-enter-done']),
11484 exit: classNames(styles$Z.ToastWrapper, styles$Z['ToastWrapper-exit'])
11485};
11486
11487var styles$_ = {
11488 "Loading": "Polaris-Frame-Loading",
11489 "Level": "Polaris-Frame-Loading__Level"
11490};
11491
11492var INITIAL_STEP = 10;
11493var STUCK_THRESHOLD = 99;
11494var Loading =
11495/*#__PURE__*/
11496function (_React$Component) {
11497 _inherits(Loading, _React$Component);
11498
11499 function Loading() {
11500 var _this;
11501
11502 _classCallCheck(this, Loading);
11503
11504 _this = _possibleConstructorReturn(this, _getPrototypeOf(Loading).apply(this, arguments));
11505 _this.state = {
11506 progress: 0,
11507 step: INITIAL_STEP,
11508 animation: null
11509 };
11510 _this.ariaValuenow = debounce(function () {
11511 var progress = _this.state.progress;
11512 return Math.floor(progress / 10) * 10;
11513 }, 15);
11514 return _this;
11515 }
11516
11517 _createClass(Loading, [{
11518 key: "componentDidMount",
11519 value: function componentDidMount() {
11520 this.increment();
11521 }
11522 }, {
11523 key: "componentWillUnmount",
11524 value: function componentWillUnmount() {
11525 var animation = this.state.animation;
11526
11527 if (animation != null) {
11528 cancelAnimationFrame(animation);
11529 }
11530 }
11531 }, {
11532 key: "render",
11533 value: function render() {
11534 var progress = this.state.progress;
11535 var customStyles = {
11536 transform: "scaleX(".concat(Math.floor(progress) / 100, ")")
11537 };
11538 var ariaValuenow = this.ariaValuenow();
11539 return React__default.createElement("div", {
11540 className: styles$_.Loading
11541 }, React__default.createElement("div", {
11542 className: styles$_.Level,
11543 style: customStyles,
11544 "aria-valuenow": ariaValuenow,
11545 "aria-valuemin": 0,
11546 "aria-valuemax": 100,
11547 role: "progressbar"
11548 }));
11549 }
11550 }, {
11551 key: "increment",
11552 value: function increment() {
11553 var _this2 = this;
11554
11555 var _this$state = this.state,
11556 progress = _this$state.progress,
11557 step = _this$state.step;
11558
11559 if (progress >= STUCK_THRESHOLD) {
11560 return;
11561 }
11562
11563 var animation = requestAnimationFrame(function () {
11564 return _this2.increment();
11565 });
11566 this.setState({
11567 progress: Math.min(progress + step, 100),
11568 step: Math.pow(INITIAL_STEP, -(progress / 25)),
11569 animation
11570 });
11571 }
11572 }]);
11573
11574 return Loading;
11575}(React__default.Component);
11576
11577function isObject(value) {
11578 var type = typeof value;
11579 return value != null && (type === exports.TypeOf.Object || type === exports.TypeOf.Function);
11580}
11581
11582function pluckDeep(obj, key) {
11583 if (!obj) {
11584 return null;
11585 }
11586
11587 var keys = Object.keys(obj);
11588
11589 for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {
11590 var currKey = _keys[_i];
11591
11592 if (currKey === key) {
11593 return obj[key];
11594 }
11595
11596 if (isObject(obj[currKey])) {
11597 var plucked = pluckDeep(obj[currKey], key);
11598
11599 if (plucked) {
11600 return plucked;
11601 }
11602 }
11603 }
11604
11605 return null;
11606}
11607
11608function getWidth() {
11609 var value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
11610 var defaultWidth = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
11611 var key = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'width';
11612 var width = typeof value === 'number' ? value : pluckDeep(value, key);
11613 return width ? "".concat(width, "px") : "".concat(defaultWidth, "px");
11614}
11615
11616function generateRedirect(appBridge, url) {
11617 var target = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'APP';
11618 var external = arguments.length > 3 ? arguments[3] : undefined;
11619
11620 if (url == null) {
11621 return undefined;
11622 }
11623
11624 var redirect = actions.Redirect.create(appBridge);
11625 var payload = external === true ? {
11626 url,
11627 newContext: true
11628 } : url;
11629 return function () {
11630 redirect.dispatch(redirectAction(target, external), payload);
11631 };
11632}
11633
11634function redirectAction(target, external) {
11635 if (external === true) {
11636 return actions.Redirect.Action.REMOTE;
11637 }
11638
11639 return actions.Redirect.Action[target];
11640}
11641
11642function transformActions(appBridge, _ref) {
11643 var primaryAction = _ref.primaryAction,
11644 secondaryActions = _ref.secondaryActions,
11645 actionGroups = _ref.actionGroups;
11646 var primary = transformPrimaryAction(appBridge, primaryAction);
11647 var secondary = [].concat(_toConsumableArray(transformSecondaryActions(appBridge, secondaryActions)), _toConsumableArray(transformActionGroups(appBridge, actionGroups)));
11648 return {
11649 primary,
11650 secondary
11651 };
11652}
11653
11654function transformAction(appBridge, action) {
11655 var style = action.destructive === true ? actions.Button.Style.Danger : undefined;
11656 var button = actions.Button.create(appBridge, {
11657 label: action.content || '',
11658 disabled: action.disabled,
11659 style
11660 });
11661
11662 if (action.onAction) {
11663 button.subscribe(actions.Button.Action.CLICK, action.onAction);
11664 }
11665
11666 var redirect = generateRedirect(appBridge, action.url, action.target, action.external);
11667
11668 if (redirect != null) {
11669 button.subscribe(actions.Button.Action.CLICK, redirect);
11670 }
11671
11672 return button;
11673}
11674
11675function transformPrimaryAction(appBridge, primaryAction) {
11676 if (primaryAction == null) {
11677 return undefined;
11678 }
11679
11680 var primary = transformAction(appBridge, primaryAction);
11681 return primary;
11682}
11683
11684function transformSecondaryActions(appBridge) {
11685 var secondaryActions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
11686
11687 var secondary = _toConsumableArray(secondaryActions.map(function (secondaryAction) {
11688 return transformAction(appBridge, secondaryAction);
11689 }));
11690
11691 return secondary;
11692}
11693
11694function transformActionGroups(appBridge) {
11695 var actionGroups = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
11696
11697 var buttonGroups = _toConsumableArray(actionGroups.map(function (group) {
11698 var buttons = group.actions.map(function (groupAction) {
11699 return transformAction(appBridge, groupAction);
11700 });
11701 return actions.ButtonGroup.create(appBridge, {
11702 label: group.title,
11703 buttons
11704 });
11705 }));
11706
11707 return buttonGroups;
11708}
11709
11710function pickValueAndLength(obj, key) {
11711 var keyPaths = key.split('.');
11712 var value = obj;
11713 var _iteratorNormalCompletion = true;
11714 var _didIteratorError = false;
11715 var _iteratorError = undefined;
11716
11717 try {
11718 for (var _iterator = keyPaths[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
11719 var _key = _step.value;
11720
11721 if (!Object.prototype.hasOwnProperty.call(value, _key)) {
11722 return null;
11723 }
11724
11725 value = value[_key];
11726 }
11727 } catch (err) {
11728 _didIteratorError = true;
11729 _iteratorError = err;
11730 } finally {
11731 try {
11732 if (!_iteratorNormalCompletion && _iterator.return != null) {
11733 _iterator.return();
11734 }
11735 } finally {
11736 if (_didIteratorError) {
11737 throw _iteratorError;
11738 }
11739 }
11740 }
11741
11742 return {
11743 keyPaths,
11744 value
11745 };
11746}
11747
11748function pick(obj) {
11749 var _ref;
11750
11751 for (var _len = arguments.length, keyPaths = new Array(_len > 1 ? _len - 1 : 0), _key2 = 1; _key2 < _len; _key2++) {
11752 keyPaths[_key2 - 1] = arguments[_key2];
11753 }
11754
11755 var flattenedKeypaths = (_ref = []).concat.apply(_ref, keyPaths);
11756
11757 if (obj == null || flattenedKeypaths.length === 0) return {};
11758 return flattenedKeypaths.reduce(function (acc, key) {
11759 if (typeof key !== exports.TypeOf.String || Object.prototype.hasOwnProperty.call(obj, key)) {
11760 return Object.assign({}, acc, {
11761 [key]: obj[key]
11762 });
11763 }
11764
11765 var pickedValues = pickValueAndLength(obj, key);
11766
11767 if (pickedValues === null) {
11768 return acc;
11769 }
11770
11771 var keyPaths = pickedValues.keyPaths,
11772 value = pickedValues.value;
11773 var len = keyPaths.length;
11774 var innerObject = {
11775 [keyPaths[--len]]: value
11776 };
11777
11778 while (len--) {
11779 innerObject = {
11780 [keyPaths[len]]: innerObject
11781 };
11782 }
11783
11784 return Object.assign({}, acc, innerObject);
11785 }, {});
11786}
11787
11788var styles$$ = {
11789 "Container": "Polaris-Modal-Dialog__Container",
11790 "Modal": "Polaris-Modal-Dialog__Modal",
11791 "limitHeight": "Polaris-Modal-Dialog--limitHeight",
11792 "sizeLarge": "Polaris-Modal-Dialog--sizeLarge",
11793 "animateFadeUp": "Polaris-Modal-Dialog--animateFadeUp",
11794 "entering": "Polaris-Modal-Dialog--entering",
11795 "exiting": "Polaris-Modal-Dialog--exiting",
11796 "exited": "Polaris-Modal-Dialog--exited",
11797 "entered": "Polaris-Modal-Dialog--entered"
11798};
11799
11800function Dialog(_a) {
11801 var instant = _a.instant,
11802 labelledBy = _a.labelledBy,
11803 children = _a.children,
11804 onClose = _a.onClose,
11805 onExited = _a.onExited,
11806 onEntered = _a.onEntered,
11807 large = _a.large,
11808 limitHeight = _a.limitHeight,
11809 props = tslib_1.__rest(_a, ["instant", "labelledBy", "children", "onClose", "onExited", "onEntered", "large", "limitHeight"]);
11810
11811 var containerNode = React.useRef(null);
11812 var findDOMNode = React.useCallback(function () {
11813 return containerNode.current;
11814 }, []);
11815 var classes = classNames(styles$$.Modal, large && styles$$.sizeLarge, limitHeight && styles$$.limitHeight);
11816 var TransitionChild = instant ? reactTransitionGroup.Transition : FadeUp;
11817 return React__default.createElement(TransitionChild, Object.assign({}, props, {
11818 findDOMNode: findDOMNode,
11819 mountOnEnter: true,
11820 unmountOnExit: true,
11821 timeout: tokens.durationBase,
11822 onEntered: onEntered,
11823 onExited: onExited
11824 }), React__default.createElement("div", {
11825 className: styles$$.Container,
11826 "data-polaris-layer": true,
11827 "data-polaris-overlay": true,
11828 ref: containerNode
11829 }, React__default.createElement(TrapFocus, null, React__default.createElement("div", {
11830 className: classes,
11831 role: "dialog",
11832 "aria-labelledby": labelledBy,
11833 tabIndex: -1
11834 }, React__default.createElement(KeypressListener, {
11835 keyCode: exports.Key.Escape,
11836 handler: onClose
11837 }), children))));
11838}
11839var fadeUpClasses = {
11840 appear: classNames(styles$$.animateFadeUp, styles$$.entering),
11841 appearActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11842 enter: classNames(styles$$.animateFadeUp, styles$$.entering),
11843 enterActive: classNames(styles$$.animateFadeUp, styles$$.entered),
11844 exit: classNames(styles$$.animateFadeUp, styles$$.exiting),
11845 exitActive: classNames(styles$$.animateFadeUp, styles$$.exited)
11846};
11847
11848function FadeUp(_a) {
11849 var children = _a.children,
11850 props = tslib_1.__rest(_a, ["children"]);
11851
11852 return React__default.createElement(reactTransitionGroup.CSSTransition, Object.assign({}, props, {
11853 classNames: fadeUpClasses
11854 }), children);
11855}
11856
11857var styles$10 = {
11858 "Footer": "Polaris-Modal-Footer",
11859 "FooterContent": "Polaris-Modal-Footer__FooterContent"
11860};
11861
11862function Footer(_ref) {
11863 var primaryAction = _ref.primaryAction,
11864 secondaryActions = _ref.secondaryActions,
11865 children = _ref.children;
11866 var primaryActionButton = primaryAction && buttonsFrom(primaryAction, {
11867 primary: true
11868 }) || null;
11869 var secondaryActionButtons = secondaryActions && buttonsFrom(secondaryActions) || null;
11870 var actions = primaryActionButton || secondaryActionButtons ? React__default.createElement(ButtonGroup, null, secondaryActionButtons, primaryActionButton) : null;
11871 return React__default.createElement("div", {
11872 className: styles$10.Footer
11873 }, React__default.createElement("div", {
11874 className: styles$10.FooterContent
11875 }, React__default.createElement(Stack, {
11876 alignment: "center"
11877 }, React__default.createElement(Stack.Item, {
11878 fill: true
11879 }, children), actions)));
11880}
11881
11882var styles$11 = {
11883 "CloseButton": "Polaris-Modal-CloseButton",
11884 "withoutTitle": "Polaris-Modal-CloseButton--withoutTitle"
11885};
11886
11887function CloseButton(_ref) {
11888 var _ref$title = _ref.title,
11889 title = _ref$title === void 0 ? true : _ref$title,
11890 onClick = _ref.onClick;
11891 var i18n = useI18n();
11892 var className = classNames(styles$11.CloseButton, !title && styles$11.withoutTitle);
11893 return React__default.createElement("button", {
11894 onClick: onClick,
11895 className: className,
11896 "aria-label": i18n.translate('Polaris.Common.close')
11897 }, React__default.createElement(Icon, {
11898 source: polarisIcons.MobileCancelMajorMonotone,
11899 color: "inkLighter"
11900 }));
11901}
11902
11903var styles$12 = {
11904 "Header": "Polaris-Modal-Header",
11905 "Title": "Polaris-Modal-Header__Title"
11906};
11907
11908function Header$1(_ref) {
11909 var id = _ref.id,
11910 children = _ref.children,
11911 onClose = _ref.onClose;
11912 return React__default.createElement("div", {
11913 className: styles$12.Header
11914 }, React__default.createElement("div", {
11915 id: id,
11916 className: styles$12.Title
11917 }, React__default.createElement(DisplayText, {
11918 element: "h2",
11919 size: "small"
11920 }, children)), React__default.createElement(CloseButton, {
11921 onClick: onClose
11922 }));
11923}
11924
11925var styles$13 = {
11926 "Section": "Polaris-Modal-Section",
11927 "subdued": "Polaris-Modal-Section--subdued",
11928 "flush": "Polaris-Modal-Section--flush"
11929};
11930
11931function Section$3(_ref) {
11932 var children = _ref.children,
11933 _ref$flush = _ref.flush,
11934 flush = _ref$flush === void 0 ? false : _ref$flush,
11935 _ref$subdued = _ref.subdued,
11936 subdued = _ref$subdued === void 0 ? false : _ref$subdued;
11937 var className = classNames(styles$13.Section, flush && styles$13.flush, subdued && styles$13.subdued);
11938 return React__default.createElement("section", {
11939 className: className
11940 }, children);
11941}
11942
11943var styles$14 = {
11944 "BodyWrapper": "Polaris-Modal__BodyWrapper",
11945 "Body": "Polaris-Modal__Body",
11946 "IFrame": "Polaris-Modal__IFrame",
11947 "Spinner": "Polaris-Modal__Spinner"
11948};
11949
11950var IFRAME_LOADING_HEIGHT = 200;
11951var DEFAULT_IFRAME_CONTENT_HEIGHT = 400;
11952var getUniqueID$1 = other.createUniqueIDFactory('modal-header');
11953var APP_BRIDGE_PROPS = ['title', 'size', 'message', 'src', 'primaryAction', 'secondaryActions'];
11954
11955var Modal =
11956/*#__PURE__*/
11957function (_React$Component) {
11958 _inherits(Modal, _React$Component);
11959
11960 function Modal() {
11961 var _this;
11962
11963 _classCallCheck(this, Modal);
11964
11965 _this = _possibleConstructorReturn(this, _getPrototypeOf(Modal).apply(this, arguments));
11966 _this.state = {
11967 iframeHeight: IFRAME_LOADING_HEIGHT
11968 };
11969 _this.headerId = getUniqueID$1();
11970
11971 _this.handleEntered = function () {
11972 var onTransitionEnd = _this.props.onTransitionEnd;
11973
11974 if (onTransitionEnd) {
11975 onTransitionEnd();
11976 }
11977 };
11978
11979 _this.handleExited = function () {
11980 _this.setState({
11981 iframeHeight: IFRAME_LOADING_HEIGHT
11982 });
11983
11984 if (_this.focusReturnPointNode) {
11985 fastdom.write(function () {
11986 return focus.focusFirstFocusableNode(_this.focusReturnPointNode, false);
11987 });
11988 }
11989 };
11990
11991 _this.handleIFrameLoad = function (evt) {
11992 var iframe = evt.target;
11993
11994 if (iframe && iframe.contentWindow) {
11995 try {
11996 _this.setState({
11997 iframeHeight: iframe.contentWindow.document.body.scrollHeight
11998 });
11999 } catch (_a) {
12000 _this.setState({
12001 iframeHeight: DEFAULT_IFRAME_CONTENT_HEIGHT
12002 });
12003 }
12004 }
12005
12006 var onIFrameLoad = _this.props.onIFrameLoad;
12007
12008 if (onIFrameLoad != null) {
12009 onIFrameLoad(evt);
12010 }
12011 };
12012
12013 return _this;
12014 }
12015
12016 _createClass(Modal, [{
12017 key: "componentDidMount",
12018 value: function componentDidMount() {
12019 if (this.props.polaris.appBridge == null) {
12020 return;
12021 } // eslint-disable-next-line no-console
12022
12023
12024 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');
12025 var transformProps = this.transformProps();
12026
12027 if (transformProps) {
12028 this.appBridgeModal = actions.Modal.create(this.props.polaris.appBridge, transformProps);
12029 }
12030
12031 if (this.appBridgeModal) {
12032 this.appBridgeModal.subscribe(actions.Modal.Action.CLOSE, this.props.onClose);
12033 }
12034
12035 var open = this.props.open;
12036
12037 if (open) {
12038 this.focusReturnPointNode = document.activeElement;
12039 this.appBridgeModal && this.appBridgeModal.dispatch(actions.Modal.Action.OPEN);
12040 }
12041 }
12042 }, {
12043 key: "componentDidUpdate",
12044 value: function componentDidUpdate(prevProps) {
12045 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
12046 return;
12047 }
12048
12049 var open = this.props.open;
12050 var wasOpen = prevProps.open;
12051 var transformedProps = this.transformProps();
12052 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS);
12053 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS);
12054
12055 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps) && transformedProps) {
12056 if (isIframeModal(transformedProps)) {
12057 this.appBridgeModal.set(transformedProps);
12058 } else {
12059 this.appBridgeModal.set(transformedProps);
12060 }
12061 }
12062
12063 if (wasOpen !== open) {
12064 if (open) {
12065 this.appBridgeModal.dispatch(actions.Modal.Action.OPEN);
12066 } else {
12067 this.appBridgeModal.dispatch(actions.Modal.Action.CLOSE);
12068 }
12069 }
12070
12071 if (!wasOpen && open) {
12072 this.focusReturnPointNode = document.activeElement;
12073 } else if (wasOpen && !open && this.focusReturnPointNode != null && document.contains(this.focusReturnPointNode)) {
12074 this.focusReturnPointNode.focus();
12075 this.focusReturnPointNode = null;
12076 }
12077 }
12078 }, {
12079 key: "componentWillUnmount",
12080 value: function componentWillUnmount() {
12081 if (this.props.polaris.appBridge == null || this.appBridgeModal == null) {
12082 return;
12083 }
12084
12085 this.appBridgeModal.unsubscribe();
12086 }
12087 }, {
12088 key: "render",
12089 value: function render() {
12090 if (this.props.polaris.appBridge != null) {
12091 return null;
12092 }
12093
12094 var _this$props = this.props,
12095 children = _this$props.children,
12096 title = _this$props.title,
12097 src = _this$props.src,
12098 iFrameName = _this$props.iFrameName,
12099 open = _this$props.open,
12100 instant = _this$props.instant,
12101 sectioned = _this$props.sectioned,
12102 loading = _this$props.loading,
12103 large = _this$props.large,
12104 limitHeight = _this$props.limitHeight,
12105 onClose = _this$props.onClose,
12106 footer = _this$props.footer,
12107 primaryAction = _this$props.primaryAction,
12108 secondaryActions = _this$props.secondaryActions,
12109 intl = _this$props.polaris.intl,
12110 onScrolledToBottom = _this$props.onScrolledToBottom;
12111 var iframeHeight = this.state.iframeHeight;
12112 var iframeTitle = intl.translate('Polaris.Modal.iFrameTitle');
12113 var dialog;
12114 var backdrop;
12115
12116 if (open) {
12117 var footerMarkup = !footer && !primaryAction && !secondaryActions ? null : React__default.createElement(Footer, {
12118 primaryAction: primaryAction,
12119 secondaryActions: secondaryActions
12120 }, footer);
12121 var content = sectioned ? wrapWithComponent(children, Section$3, {}) : children;
12122 var body = loading ? React__default.createElement("div", {
12123 className: styles$14.Spinner
12124 }, React__default.createElement(Spinner, null)) : content;
12125 var bodyMarkup = src ? React__default.createElement("iframe", {
12126 name: iFrameName,
12127 title: iframeTitle,
12128 src: src,
12129 className: styles$14.IFrame,
12130 onLoad: this.handleIFrameLoad,
12131 style: {
12132 height: "".concat(iframeHeight, "px")
12133 }
12134 }) : React__default.createElement(Scrollable, {
12135 shadow: true,
12136 className: styles$14.Body,
12137 onScrolledToBottom: onScrolledToBottom
12138 }, body);
12139 var headerMarkup = title ? React__default.createElement(Header$1, {
12140 id: this.headerId,
12141 onClose: onClose
12142 }, title) : React__default.createElement(CloseButton, {
12143 onClick: onClose,
12144 title: false
12145 });
12146 var labelledBy = title ? this.headerId : undefined;
12147 dialog = React__default.createElement(Dialog, {
12148 instant: instant,
12149 labelledBy: labelledBy,
12150 onClose: onClose,
12151 onEntered: this.handleEntered,
12152 onExited: this.handleExited,
12153 large: large,
12154 limitHeight: limitHeight
12155 }, headerMarkup, React__default.createElement("div", {
12156 className: styles$14.BodyWrapper
12157 }, bodyMarkup), footerMarkup);
12158 backdrop = React__default.createElement(Backdrop, null);
12159 }
12160
12161 var animated = !instant;
12162 return React__default.createElement(WithinContentContext.Provider, {
12163 value: true
12164 }, React__default.createElement(Portal, {
12165 idPrefix: "modal"
12166 }, React__default.createElement(reactTransitionGroup.TransitionGroup, {
12167 appear: animated,
12168 enter: animated,
12169 exit: animated
12170 }, dialog), backdrop));
12171 }
12172 }, {
12173 key: "transformProps",
12174 value: function transformProps() {
12175 var _this$props2 = this.props,
12176 title = _this$props2.title,
12177 size = _this$props2.size,
12178 message = _this$props2.message,
12179 src = _this$props2.src,
12180 primaryAction = _this$props2.primaryAction,
12181 secondaryActions = _this$props2.secondaryActions,
12182 polaris = _this$props2.polaris;
12183 var appBridge = polaris.appBridge;
12184 if (!appBridge) return;
12185 var safeTitle = typeof title === 'string' ? title : undefined;
12186 var safeSize = size != null ? actions.Modal.Size[size] : undefined;
12187 var srcPayload = {};
12188
12189 if (src != null) {
12190 if (/^https?:\/\//.test(src)) {
12191 srcPayload.url = src;
12192 } else {
12193 srcPayload.path = src;
12194 }
12195 }
12196
12197 return Object.assign({
12198 title: safeTitle,
12199 message,
12200 size: safeSize
12201 }, srcPayload, {
12202 footer: {
12203 buttons: transformActions(appBridge, {
12204 primaryAction,
12205 secondaryActions
12206 })
12207 }
12208 });
12209 }
12210 }]);
12211
12212 return Modal;
12213}(React__default.Component);
12214
12215Modal.Section = Section$3;
12216
12217function isIframeModal(options) {
12218 return typeof options.url === 'string' || typeof options.path === 'string';
12219} // Use named export once withAppProvider is refactored away
12220// eslint-disable-next-line import/no-default-export
12221
12222
12223var Modal$1 = withAppProvider()(Modal);
12224
12225function DiscardConfirmationModal(_ref) {
12226 var open = _ref.open,
12227 onDiscard = _ref.onDiscard,
12228 onCancel = _ref.onCancel;
12229 var i18n = useI18n();
12230 return React__default.createElement(Modal$1, {
12231 title: i18n.translate('Polaris.DiscardConfirmationModal.title'),
12232 open: open,
12233 onClose: onCancel,
12234 primaryAction: {
12235 content: i18n.translate('Polaris.DiscardConfirmationModal.primaryAction'),
12236 destructive: true,
12237 onAction: onDiscard
12238 },
12239 secondaryActions: [{
12240 content: i18n.translate('Polaris.DiscardConfirmationModal.secondaryAction'),
12241 onAction: onCancel
12242 }],
12243 sectioned: true
12244 }, i18n.translate('Polaris.DiscardConfirmationModal.message'));
12245}
12246
12247var styles$15 = {
12248 "ContextualSaveBar": "Polaris-Frame-ContextualSaveBar",
12249 "LogoContainer": "Polaris-Frame-ContextualSaveBar__LogoContainer",
12250 "Contents": "Polaris-Frame-ContextualSaveBar__Contents",
12251 "Message": "Polaris-Frame-ContextualSaveBar__Message",
12252 "ActionContainer": "Polaris-Frame-ContextualSaveBar__ActionContainer",
12253 "Action": "Polaris-Frame-ContextualSaveBar__Action"
12254};
12255
12256function ContextualSaveBar$1(_ref) {
12257 var alignContentFlush = _ref.alignContentFlush,
12258 message = _ref.message,
12259 saveAction = _ref.saveAction,
12260 discardAction = _ref.discardAction;
12261 var i18n = useI18n();
12262
12263 var _useTheme = useTheme(),
12264 logo = _useTheme.logo;
12265
12266 var _useForcibleToggle = useForcibleToggle(false),
12267 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
12268 discardConfirmationModalVisible = _useForcibleToggle2[0],
12269 _useForcibleToggle2$ = _useForcibleToggle2[1],
12270 toggleDiscardConfirmationModal = _useForcibleToggle2$.toggle,
12271 closeDiscardConfirmationModal = _useForcibleToggle2$.forceFalse;
12272
12273 var handleDiscardAction = React.useCallback(function () {
12274 if (discardAction && discardAction.onAction) {
12275 discardAction.onAction();
12276 }
12277
12278 closeDiscardConfirmationModal();
12279 }, [closeDiscardConfirmationModal, discardAction]);
12280 var discardActionContent = discardAction && discardAction.content ? discardAction.content : i18n.translate('Polaris.ContextualSaveBar.discard');
12281 var discardActionHandler;
12282
12283 if (discardAction && discardAction.discardConfirmationModal) {
12284 discardActionHandler = toggleDiscardConfirmationModal;
12285 } else if (discardAction) {
12286 discardActionHandler = discardAction.onAction;
12287 }
12288
12289 var discardConfirmationModalMarkup = discardAction && discardAction.onAction && discardAction.discardConfirmationModal && React__default.createElement(DiscardConfirmationModal, {
12290 open: discardConfirmationModalVisible,
12291 onCancel: toggleDiscardConfirmationModal,
12292 onDiscard: handleDiscardAction
12293 });
12294 var discardActionMarkup = discardAction && React__default.createElement(Button, {
12295 url: discardAction.url,
12296 onClick: discardActionHandler,
12297 loading: discardAction.loading,
12298 disabled: discardAction.disabled,
12299 accessibilityLabel: discardAction.content
12300 }, discardActionContent);
12301 var saveActionContent = saveAction && saveAction.content ? saveAction.content : i18n.translate('Polaris.ContextualSaveBar.save');
12302 var saveActionMarkup = saveAction && React__default.createElement(Button, {
12303 primary: true,
12304 url: saveAction.url,
12305 onClick: saveAction.onAction,
12306 loading: saveAction.loading,
12307 disabled: saveAction.disabled,
12308 accessibilityLabel: saveAction.content
12309 }, saveActionContent);
12310 var width = getWidth(logo, 104);
12311 var imageMarkup = logo && React__default.createElement(Image, {
12312 style: {
12313 width
12314 },
12315 source: logo.contextualSaveBarSource || '',
12316 alt: ""
12317 });
12318 var logoMarkup = alignContentFlush ? null : React__default.createElement("div", {
12319 className: styles$15.LogoContainer,
12320 style: {
12321 width
12322 }
12323 }, imageMarkup);
12324 return React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
12325 className: styles$15.ContextualSaveBar
12326 }, logoMarkup, React__default.createElement("div", {
12327 className: styles$15.Contents
12328 }, React__default.createElement("h2", {
12329 className: styles$15.Message
12330 }, message), React__default.createElement("div", {
12331 className: styles$15.ActionContainer
12332 }, React__default.createElement(Stack, {
12333 spacing: "tight",
12334 wrap: false
12335 }, discardActionMarkup, saveActionMarkup)))), discardConfirmationModalMarkup);
12336}
12337
12338var styles$16 = {
12339 "startFade": "Polaris-Frame-CSSAnimation--startFade",
12340 "endFade": "Polaris-Frame-CSSAnimation--endFade"
12341};
12342
12343var AnimationType;
12344
12345(function (AnimationType) {
12346 AnimationType["Fade"] = "fade";
12347})(AnimationType || (AnimationType = {}));
12348
12349var TransitionStatus$1;
12350
12351(function (TransitionStatus) {
12352 TransitionStatus["Entering"] = "entering";
12353 TransitionStatus["Entered"] = "entered";
12354 TransitionStatus["Exiting"] = "exiting";
12355 TransitionStatus["Exited"] = "exited";
12356})(TransitionStatus$1 || (TransitionStatus$1 = {}));
12357
12358function CSSAnimation(_ref) {
12359 var inProp = _ref.in,
12360 className = _ref.className,
12361 type = _ref.type,
12362 children = _ref.children;
12363
12364 var _useState = React.useState(inProp ? TransitionStatus$1.Entering : TransitionStatus$1.Exited),
12365 _useState2 = _slicedToArray(_useState, 2),
12366 transitionStatus = _useState2[0],
12367 setTransitionStatus = _useState2[1];
12368
12369 var isMounted = React.useRef(false);
12370 var node = React.useRef(null);
12371 React.useEffect(function () {
12372 if (!isMounted.current) return;
12373 transitionStatus === TransitionStatus$1.Entering && changeTransitionStatus(TransitionStatus$1.Entered);
12374 }, [transitionStatus]);
12375 React.useEffect(function () {
12376 if (!isMounted.current) return;
12377 inProp && changeTransitionStatus(TransitionStatus$1.Entering);
12378 !inProp && changeTransitionStatus(TransitionStatus$1.Exiting);
12379 }, [inProp]);
12380 React.useEffect(function () {
12381 isMounted.current = true;
12382 }, []);
12383 var wrapperClassName = classNames(className, styles$16[variationName('start', type)], inProp && styles$16[variationName('end', type)]);
12384 var content = transitionStatus === TransitionStatus$1.Exited && !inProp ? null : children;
12385 return React__default.createElement("div", {
12386 className: wrapperClassName,
12387 ref: node,
12388 onTransitionEnd: handleTransitionEnd
12389 }, content);
12390
12391 function handleTransitionEnd() {
12392 transitionStatus === TransitionStatus$1.Exiting && changeTransitionStatus(TransitionStatus$1.Exited);
12393 }
12394
12395 function changeTransitionStatus(transitionStatus) {
12396 setTransitionStatus(transitionStatus); // Forcing a reflow to enable the animation
12397
12398 if (transitionStatus === TransitionStatus$1.Entering) node.current && node.current.getBoundingClientRect();
12399 }
12400}
12401
12402var styles$17 = {
12403 "Frame": "Polaris-Frame",
12404 "Navigation": "Polaris-Frame__Navigation",
12405 "Navigation-enter": "Polaris-Frame__Navigation--enter",
12406 "Navigation-enterActive": "Polaris-Frame__Navigation--enterActive",
12407 "Navigation-exit": "Polaris-Frame__Navigation--exit",
12408 "Navigation-exitActive": "Polaris-Frame__Navigation--exitActive",
12409 "NavigationDismiss": "Polaris-Frame__NavigationDismiss",
12410 "Navigation-visible": "Polaris-Frame__Navigation--visible",
12411 "TopBar": "Polaris-Frame__TopBar",
12412 "ContextualSaveBar": "Polaris-Frame__ContextualSaveBar",
12413 "Main": "Polaris-Frame__Main",
12414 "hasNav": "Polaris-Frame--hasNav",
12415 "hasTopBar": "Polaris-Frame--hasTopBar",
12416 "Content": "Polaris-Frame__Content",
12417 "GlobalRibbonContainer": "Polaris-Frame__GlobalRibbonContainer",
12418 "LoadingBar": "Polaris-Frame__LoadingBar",
12419 "Skip": "Polaris-Frame__Skip",
12420 "focused": "Polaris-Frame--focused",
12421 "SkipAnchor": "Polaris-Frame__SkipAnchor",
12422 "globalTheming": "Polaris-Frame--globalTheming"
12423};
12424
12425var GLOBAL_RIBBON_CUSTOM_PROPERTY = '--global-ribbon-height';
12426var APP_FRAME_MAIN = 'AppFrameMain';
12427var APP_FRAME_MAIN_ANCHOR_TARGET = 'AppFrameMainContent';
12428var APP_FRAME_NAV = 'AppFrameNav';
12429var APP_FRAME_TOP_BAR = 'AppFrameTopBar';
12430var APP_FRAME_LOADING_BAR = 'AppFrameLoadingBar';
12431
12432var Frame =
12433/*#__PURE__*/
12434function (_React$PureComponent) {
12435 _inherits(Frame, _React$PureComponent);
12436
12437 function Frame() {
12438 var _this;
12439
12440 _classCallCheck(this, Frame);
12441
12442 _this = _possibleConstructorReturn(this, _getPrototypeOf(Frame).apply(this, arguments));
12443 _this.state = {
12444 skipFocused: false,
12445 globalRibbonHeight: 0,
12446 loadingStack: 0,
12447 toastMessages: [],
12448 showContextualSaveBar: false
12449 };
12450 _this.globalRibbonContainer = null;
12451 _this.navigationNode = React.createRef();
12452 _this.skipToMainContentTargetNode = _this.props.skipToContentTarget || React__default.createRef();
12453
12454 _this.setGlobalRibbonHeight = function () {
12455 var _assertThisInitialize = _assertThisInitialized(_this),
12456 globalRibbonContainer = _assertThisInitialize.globalRibbonContainer;
12457
12458 if (globalRibbonContainer) {
12459 _this.setState({
12460 globalRibbonHeight: globalRibbonContainer.offsetHeight
12461 }, _this.setGlobalRibbonRootProperty);
12462 }
12463 };
12464
12465 _this.setGlobalRibbonRootProperty = function () {
12466 var globalRibbonHeight = _this.state.globalRibbonHeight;
12467 setRootProperty(GLOBAL_RIBBON_CUSTOM_PROPERTY, "".concat(globalRibbonHeight, "px"), null);
12468 };
12469
12470 _this.showToast = function (toast) {
12471 _this.setState(function (_ref) {
12472 var toastMessages = _ref.toastMessages;
12473 var hasToastById = toastMessages.find(function (_ref2) {
12474 var id = _ref2.id;
12475 return id === toast.id;
12476 }) != null;
12477 return {
12478 toastMessages: hasToastById ? toastMessages : [].concat(_toConsumableArray(toastMessages), [toast])
12479 };
12480 });
12481 };
12482
12483 _this.hideToast = function (_ref3) {
12484 var id = _ref3.id;
12485
12486 _this.setState(function (_ref4) {
12487 var toastMessages = _ref4.toastMessages;
12488 return {
12489 toastMessages: toastMessages.filter(function (_ref5) {
12490 var toastId = _ref5.id;
12491 return id !== toastId;
12492 })
12493 };
12494 });
12495 };
12496
12497 _this.setContextualSaveBar = function (props) {
12498 var showContextualSaveBar = _this.state.showContextualSaveBar;
12499 _this.contextualSaveBar = Object.assign({}, props);
12500
12501 if (showContextualSaveBar === true) {
12502 _this.forceUpdate();
12503 } else {
12504 _this.setState({
12505 showContextualSaveBar: true
12506 });
12507 }
12508 };
12509
12510 _this.removeContextualSaveBar = function () {
12511 _this.contextualSaveBar = null;
12512
12513 _this.setState({
12514 showContextualSaveBar: false
12515 });
12516 };
12517
12518 _this.startLoading = function () {
12519 _this.setState(function (_ref6) {
12520 var loadingStack = _ref6.loadingStack;
12521 return {
12522 loadingStack: loadingStack + 1
12523 };
12524 });
12525 };
12526
12527 _this.stopLoading = function () {
12528 _this.setState(function (_ref7) {
12529 var loadingStack = _ref7.loadingStack;
12530 return {
12531 loadingStack: Math.max(0, loadingStack - 1)
12532 };
12533 });
12534 };
12535
12536 _this.handleResize = function () {
12537 if (_this.props.globalRibbon) {
12538 _this.setGlobalRibbonHeight();
12539 }
12540 };
12541
12542 _this.handleFocus = function () {
12543 _this.setState({
12544 skipFocused: true
12545 });
12546 };
12547
12548 _this.handleBlur = function () {
12549 _this.setState({
12550 skipFocused: false
12551 });
12552 };
12553
12554 _this.handleClick = function () {
12555 _this.skipToMainContentTargetNode.current && _this.skipToMainContentTargetNode.current.focus();
12556 };
12557
12558 _this.handleNavigationDismiss = function () {
12559 var onNavigationDismiss = _this.props.onNavigationDismiss;
12560
12561 if (onNavigationDismiss != null) {
12562 onNavigationDismiss();
12563 }
12564 };
12565
12566 _this.setGlobalRibbonContainer = function (node) {
12567 _this.globalRibbonContainer = node;
12568 };
12569
12570 _this.handleNavKeydown = function (event) {
12571 var key = event.key;
12572
12573 if (key === 'Escape') {
12574 _this.handleNavigationDismiss();
12575 }
12576 };
12577
12578 _this.findNavigationNode = function () {
12579 return _this.navigationNode.current;
12580 };
12581
12582 return _this;
12583 }
12584
12585 _createClass(Frame, [{
12586 key: "componentDidMount",
12587 value: function componentDidMount() {
12588 this.handleResize();
12589
12590 if (this.props.globalRibbon) {
12591 return;
12592 }
12593
12594 this.setGlobalRibbonRootProperty();
12595 }
12596 }, {
12597 key: "componentDidUpdate",
12598 value: function componentDidUpdate(prevProps) {
12599 if (this.props.globalRibbon !== prevProps.globalRibbon) {
12600 this.setGlobalRibbonHeight();
12601 }
12602 }
12603 }, {
12604 key: "render",
12605 value: function render() {
12606 var _this$state = this.state,
12607 skipFocused = _this$state.skipFocused,
12608 loadingStack = _this$state.loadingStack,
12609 toastMessages = _this$state.toastMessages,
12610 showContextualSaveBar = _this$state.showContextualSaveBar;
12611 var _this$props = this.props,
12612 children = _this$props.children,
12613 navigation = _this$props.navigation,
12614 topBar = _this$props.topBar,
12615 globalRibbon = _this$props.globalRibbon,
12616 _this$props$showMobil = _this$props.showMobileNavigation,
12617 showMobileNavigation = _this$props$showMobil === void 0 ? false : _this$props$showMobil,
12618 skipToContentTarget = _this$props.skipToContentTarget,
12619 _this$props$polaris = _this$props.polaris,
12620 intl = _this$props$polaris.intl,
12621 isNavigationCollapsed = _this$props$polaris.mediaQuery.isNavigationCollapsed;
12622 var navClassName = classNames(styles$17.Navigation, showMobileNavigation && styles$17['Navigation-visible']);
12623 var mobileNavHidden = isNavigationCollapsed && !showMobileNavigation;
12624 var mobileNavShowing = isNavigationCollapsed && showMobileNavigation;
12625 var tabIndex = mobileNavShowing ? 0 : -1;
12626 var navigationMarkup = navigation ? React__default.createElement(TrapFocus, {
12627 trapping: mobileNavShowing
12628 }, React__default.createElement(reactTransitionGroup.CSSTransition, {
12629 findDOMNode: this.findNavigationNode,
12630 appear: isNavigationCollapsed,
12631 exit: isNavigationCollapsed,
12632 in: showMobileNavigation,
12633 timeout: tokens.durationSlow,
12634 classNames: navTransitionClasses
12635 }, React__default.createElement("div", {
12636 ref: this.navigationNode,
12637 className: navClassName,
12638 onKeyDown: this.handleNavKeydown,
12639 id: APP_FRAME_NAV,
12640 key: "NavContent",
12641 hidden: mobileNavHidden
12642 }, navigation, React__default.createElement("button", {
12643 type: "button",
12644 className: styles$17.NavigationDismiss,
12645 onClick: this.handleNavigationDismiss,
12646 "aria-hidden": mobileNavHidden || !isNavigationCollapsed && !showMobileNavigation,
12647 "aria-label": intl.translate('Polaris.Frame.Navigation.closeMobileNavigationLabel'),
12648 tabIndex: tabIndex
12649 }, React__default.createElement(Icon, {
12650 source: polarisIcons.MobileCancelMajorMonotone,
12651 color: "white"
12652 }))))) : null;
12653 var loadingMarkup = loadingStack > 0 ? React__default.createElement("div", {
12654 className: styles$17.LoadingBar,
12655 id: APP_FRAME_LOADING_BAR
12656 }, React__default.createElement(Loading, null)) : null;
12657 var contextualSaveBarMarkup = React__default.createElement(CSSAnimation, {
12658 in: showContextualSaveBar,
12659 className: styles$17.ContextualSaveBar,
12660 type: AnimationType.Fade
12661 }, React__default.createElement(ContextualSaveBar$1, this.contextualSaveBar));
12662 var topBarMarkup = topBar ? React__default.createElement("div", Object.assign({
12663 className: styles$17.TopBar
12664 }, layer.props, dataPolarisTopBar.props, {
12665 id: APP_FRAME_TOP_BAR
12666 }), topBar) : null;
12667 var globalRibbonMarkup = globalRibbon ? React__default.createElement("div", {
12668 className: styles$17.GlobalRibbonContainer,
12669 ref: this.setGlobalRibbonContainer
12670 }, globalRibbon) : null;
12671 var skipClassName = classNames(styles$17.Skip, skipFocused && styles$17.focused);
12672 var skipTarget = skipToContentTarget ? skipToContentTarget.current && skipToContentTarget.current.id || '' : APP_FRAME_MAIN_ANCHOR_TARGET;
12673 var skipMarkup = React__default.createElement("div", {
12674 className: skipClassName
12675 }, React__default.createElement("a", {
12676 href: "#".concat(skipTarget),
12677 onFocus: this.handleFocus,
12678 onBlur: this.handleBlur,
12679 onClick: this.handleClick,
12680 className: styles$17.SkipAnchor
12681 }, intl.translate('Polaris.Frame.skipToContent')));
12682 var navigationAttributes = navigation ? {
12683 'data-has-navigation': true
12684 } : {};
12685 var frameClassName = classNames(styles$17.Frame, navigation && styles$17.hasNav, topBar && styles$17.hasTopBar);
12686 var navigationOverlayMarkup = showMobileNavigation && isNavigationCollapsed ? React__default.createElement(Backdrop, {
12687 belowNavigation: true,
12688 onClick: this.handleNavigationDismiss,
12689 onTouchStart: this.handleNavigationDismiss
12690 }) : null;
12691 var skipToMainContentTarget = skipToContentTarget ? null : // eslint-disable-next-line jsx-a11y/anchor-is-valid
12692 React__default.createElement("a", {
12693 id: APP_FRAME_MAIN_ANCHOR_TARGET,
12694 ref: this.skipToMainContentTargetNode,
12695 tabIndex: -1
12696 });
12697 var context = {
12698 showToast: this.showToast,
12699 hideToast: this.hideToast,
12700 startLoading: this.startLoading,
12701 stopLoading: this.stopLoading,
12702 setContextualSaveBar: this.setContextualSaveBar,
12703 removeContextualSaveBar: this.removeContextualSaveBar
12704 };
12705 return React__default.createElement(FrameContext.Provider, {
12706 value: context
12707 }, React__default.createElement("div", Object.assign({
12708 className: frameClassName
12709 }, layer.props, navigationAttributes), skipMarkup, topBarMarkup, navigationMarkup, contextualSaveBarMarkup, loadingMarkup, navigationOverlayMarkup, React__default.createElement("main", {
12710 className: styles$17.Main,
12711 id: APP_FRAME_MAIN,
12712 "data-has-global-ribbon": Boolean(globalRibbon)
12713 }, skipToMainContentTarget, React__default.createElement("div", {
12714 className: styles$17.Content
12715 }, children)), React__default.createElement(ToastManager, {
12716 toastMessages: toastMessages
12717 }), globalRibbonMarkup, React__default.createElement(EventListener, {
12718 event: "resize",
12719 handler: this.handleResize
12720 })));
12721 }
12722 }]);
12723
12724 return Frame;
12725}(React__default.PureComponent);
12726
12727var navTransitionClasses = {
12728 enter: classNames(styles$17['Navigation-enter']),
12729 enterActive: classNames(styles$17['Navigation-enterActive']),
12730 enterDone: classNames(styles$17['Navigation-enterActive']),
12731 exit: classNames(styles$17['Navigation-exit']),
12732 exitActive: classNames(styles$17['Navigation-exitActive'])
12733}; // Use named export once withAppProvider is refactored away
12734// eslint-disable-next-line import/no-default-export
12735
12736var Frame$1 = withAppProvider()(Frame);
12737
12738var styles$18 = {
12739 "Indicator": "Polaris-Indicator",
12740 "pulseIndicator": "Polaris-Indicator--pulseIndicator",
12741 "bounce": "Polaris-Indicator--bounce",
12742 "pulse": "Polaris-Indicator--pulse"
12743};
12744
12745function Indicator(_ref) {
12746 var _ref$pulse = _ref.pulse,
12747 pulse = _ref$pulse === void 0 ? true : _ref$pulse;
12748 var className = classNames(styles$18.Indicator, pulse && styles$18.pulseIndicator);
12749 return React__default.createElement("span", {
12750 className: className
12751 });
12752}
12753
12754var styles$19 = {
12755 "KeyboardKey": "Polaris-KeyboardKey"
12756};
12757
12758function KeyboardKey(_ref) {
12759 var children = _ref.children;
12760 var key = children || '';
12761 key = key.length > 1 ? key.toLowerCase() : key.toUpperCase();
12762 return React__default.createElement("kbd", {
12763 className: styles$19.KeyboardKey
12764 }, key);
12765}
12766
12767var styles$1a = {
12768 "Layout": "Polaris-Layout",
12769 "Section": "Polaris-Layout__Section",
12770 "Section-secondary": "Polaris-Layout__Section--secondary",
12771 "Section-fullWidth": "Polaris-Layout__Section--fullWidth",
12772 "Section-oneHalf": "Polaris-Layout__Section--oneHalf",
12773 "Section-oneThird": "Polaris-Layout__Section--oneThird",
12774 "AnnotatedSection": "Polaris-Layout__AnnotatedSection",
12775 "AnnotationWrapper": "Polaris-Layout__AnnotationWrapper",
12776 "AnnotationContent": "Polaris-Layout__AnnotationContent",
12777 "Annotation": "Polaris-Layout__Annotation",
12778 "AnnotationDescription": "Polaris-Layout__AnnotationDescription"
12779};
12780
12781function AnnotatedSection(props) {
12782 var children = props.children,
12783 title = props.title,
12784 description = props.description;
12785 var descriptionMarkup = typeof description === 'string' ? React__default.createElement("p", null, description) : description;
12786 return React__default.createElement("div", {
12787 className: styles$1a.AnnotatedSection
12788 }, React__default.createElement("div", {
12789 className: styles$1a.AnnotationWrapper
12790 }, React__default.createElement("div", {
12791 className: styles$1a.Annotation
12792 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title), descriptionMarkup && React__default.createElement("div", {
12793 className: styles$1a.AnnotationDescription
12794 }, descriptionMarkup))), React__default.createElement("div", {
12795 className: styles$1a.AnnotationContent
12796 }, children)));
12797}
12798
12799function Section$4(_ref) {
12800 var children = _ref.children,
12801 secondary = _ref.secondary,
12802 fullWidth = _ref.fullWidth,
12803 oneHalf = _ref.oneHalf,
12804 oneThird = _ref.oneThird;
12805 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']);
12806 return React__default.createElement("div", {
12807 className: className
12808 }, children);
12809}
12810
12811var Layout =
12812/*#__PURE__*/
12813function (_React$Component) {
12814 _inherits(Layout, _React$Component);
12815
12816 function Layout() {
12817 _classCallCheck(this, Layout);
12818
12819 return _possibleConstructorReturn(this, _getPrototypeOf(Layout).apply(this, arguments));
12820 }
12821
12822 _createClass(Layout, [{
12823 key: "render",
12824 value: function render() {
12825 var _this$props = this.props,
12826 children = _this$props.children,
12827 sectioned = _this$props.sectioned;
12828 var content = sectioned ? React__default.createElement(Section$4, null, children) : children;
12829 return React__default.createElement("div", {
12830 className: styles$1a.Layout
12831 }, content);
12832 }
12833 }]);
12834
12835 return Layout;
12836}(React__default.Component);
12837Layout.AnnotatedSection = AnnotatedSection;
12838Layout.Section = Section$4;
12839
12840var styles$1b = {
12841 "Link": "Polaris-Link",
12842 "IconLockup": "Polaris-Link__IconLockup",
12843 "IconLayout": "Polaris-Link__IconLayout",
12844 "monochrome": "Polaris-Link--monochrome"
12845};
12846
12847function Link(_ref) {
12848 var url = _ref.url,
12849 children = _ref.children,
12850 onClick = _ref.onClick,
12851 external = _ref.external,
12852 id = _ref.id,
12853 monochrome = _ref.monochrome;
12854 var i18n = useI18n();
12855 var childrenMarkup = children;
12856
12857 if (external && typeof children === 'string') {
12858 var iconLabel = i18n.translate('Polaris.Common.newWindowAccessibilityHint');
12859 childrenMarkup = React__default.createElement(React__default.Fragment, null, children, React__default.createElement("span", {
12860 className: styles$1b.IconLockup
12861 }, React__default.createElement("span", {
12862 className: styles$1b.IconLayout
12863 }, React__default.createElement(Icon, {
12864 accessibilityLabel: iconLabel,
12865 source: polarisIcons.ExternalSmallMinor
12866 }))));
12867 }
12868
12869 return React__default.createElement(BannerContext.Consumer, null, function (BannerContext) {
12870 var shouldBeMonochrome = monochrome || BannerContext;
12871 var className = classNames(styles$1b.Link, shouldBeMonochrome && styles$1b.monochrome);
12872 return url ? React__default.createElement(UnstyledLink, {
12873 onClick: onClick,
12874 className: className,
12875 url: url,
12876 external: external,
12877 id: id
12878 }, childrenMarkup) : React__default.createElement("button", {
12879 type: "button",
12880 onClick: onClick,
12881 className: className,
12882 id: id
12883 }, childrenMarkup);
12884 });
12885}
12886
12887var styles$1c = {
12888 "List": "Polaris-List",
12889 "typeNumber": "Polaris-List--typeNumber",
12890 "Item": "Polaris-List__Item"
12891};
12892
12893function Item$6(_ref) {
12894 var children = _ref.children;
12895 return React__default.createElement("li", {
12896 className: styles$1c.Item
12897 }, children);
12898}
12899
12900var List =
12901/*#__PURE__*/
12902function (_React$PureComponent) {
12903 _inherits(List, _React$PureComponent);
12904
12905 function List() {
12906 _classCallCheck(this, List);
12907
12908 return _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
12909 }
12910
12911 _createClass(List, [{
12912 key: "render",
12913 value: function render() {
12914 var _this$props = this.props,
12915 children = _this$props.children,
12916 _this$props$type = _this$props.type,
12917 type = _this$props$type === void 0 ? 'bullet' : _this$props$type;
12918 var className = classNames(styles$1c.List, type && styles$1c[variationName('type', type)]);
12919 var ListElement = type === 'bullet' ? 'ul' : 'ol';
12920 return React__default.createElement(ListElement, {
12921 className: className
12922 }, children);
12923 }
12924 }]);
12925
12926 return List;
12927}(React__default.PureComponent);
12928List.Item = Item$6;
12929
12930var Loading$1 = React__default.memo(function Loading() {
12931 var appBridgeLoading = React.useRef();
12932 var appBridge = useAppBridge();
12933
12934 var _useFrame = useFrame(),
12935 startLoading = _useFrame.startLoading,
12936 stopLoading = _useFrame.stopLoading;
12937
12938 React.useEffect(function () {
12939 if (appBridge == null) {
12940 startLoading();
12941 } else {
12942 // eslint-disable-next-line no-console
12943 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');
12944 appBridgeLoading.current = actions.Loading.create(appBridge);
12945 appBridgeLoading.current.dispatch(actions.Loading.Action.START);
12946 }
12947
12948 return function () {
12949 if (appBridge == null) {
12950 stopLoading();
12951 } else {
12952 appBridgeLoading.current && appBridgeLoading.current.dispatch(actions.Loading.Action.STOP);
12953 }
12954 };
12955 }, [appBridge, startLoading, stopLoading]);
12956 return null;
12957});
12958
12959var NavigationContext = React__default.createContext({
12960 location: ''
12961});
12962
12963var styles$1d = {
12964 "Navigation": "Polaris-Navigation",
12965 "UserMenu": "Polaris-Navigation__UserMenu",
12966 "ContextControl": "Polaris-Navigation__ContextControl",
12967 "PrimaryNavigation": "Polaris-Navigation__PrimaryNavigation",
12968 "Item": "Polaris-Navigation__Item",
12969 "Icon": "Polaris-Navigation__Icon",
12970 "Item-selected": "Polaris-Navigation__Item--selected",
12971 "Item-disabled": "Polaris-Navigation__Item--disabled",
12972 "Badge": "Polaris-Navigation__Badge",
12973 "subNavigationActive": "Polaris-Navigation--subNavigationActive",
12974 "ListItem": "Polaris-Navigation__ListItem",
12975 "RollupSection": "Polaris-Navigation__RollupSection",
12976 "SecondaryNavigation": "Polaris-Navigation__SecondaryNavigation",
12977 "fade-in": "Polaris-Navigation__fade--in",
12978 "ListItem-hasAction": "Polaris-Navigation__ListItem--hasAction",
12979 "ItemWrapper": "Polaris-Navigation__ItemWrapper",
12980 "Text": "Polaris-Navigation__Text",
12981 "SecondaryAction": "Polaris-Navigation__SecondaryAction",
12982 "List": "Polaris-Navigation__List",
12983 "Section": "Polaris-Navigation__Section",
12984 "Section-fill": "Polaris-Navigation__Section--fill",
12985 "Section-withSeparator": "Polaris-Navigation__Section--withSeparator",
12986 "SectionHeading": "Polaris-Navigation__SectionHeading",
12987 "Action": "Polaris-Navigation__Action",
12988 "RollupToggle": "Polaris-Navigation__RollupToggle",
12989 "Indicator": "Polaris-Navigation__Indicator"
12990};
12991
12992function Secondary(_ref) {
12993 var children = _ref.children,
12994 expanded = _ref.expanded;
12995 var id = useUniqueId('SecondaryNavigation');
12996 return React__default.createElement(Collapsible, {
12997 id: id,
12998 open: expanded
12999 }, React__default.createElement("ul", {
13000 className: styles$1d.List
13001 }, children));
13002}
13003
13004var MatchState;
13005
13006(function (MatchState) {
13007 MatchState[MatchState["MatchForced"] = 0] = "MatchForced";
13008 MatchState[MatchState["MatchUrl"] = 1] = "MatchUrl";
13009 MatchState[MatchState["MatchPaths"] = 2] = "MatchPaths";
13010 MatchState[MatchState["Excluded"] = 3] = "Excluded";
13011 MatchState[MatchState["NoMatch"] = 4] = "NoMatch";
13012})(MatchState || (MatchState = {}));
13013
13014function Item$7(_ref) {
13015 var url = _ref.url,
13016 icon = _ref.icon,
13017 label = _ref.label,
13018 _ref$subNavigationIte = _ref.subNavigationItems,
13019 subNavigationItems = _ref$subNavigationIte === void 0 ? [] : _ref$subNavigationIte,
13020 secondaryAction = _ref.secondaryAction,
13021 disabled = _ref.disabled,
13022 onClick = _ref.onClick,
13023 accessibilityLabel = _ref.accessibilityLabel,
13024 selectedOverride = _ref.selected,
13025 badge = _ref.badge,
13026 isNew = _ref.new,
13027 matches = _ref.matches,
13028 exactMatch = _ref.exactMatch,
13029 matchPaths = _ref.matchPaths,
13030 excludePaths = _ref.excludePaths;
13031 var i18n = useI18n();
13032
13033 var _useMediaQuery = useMediaQuery(),
13034 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
13035
13036 var _useContext = React.useContext(NavigationContext),
13037 location = _useContext.location,
13038 onNavigationDismiss = _useContext.onNavigationDismiss;
13039
13040 var _useState = React.useState(false),
13041 _useState2 = _slicedToArray(_useState, 2),
13042 expanded = _useState2[0],
13043 setExpanded = _useState2[1];
13044
13045 React.useEffect(function () {
13046 if (!isNavigationCollapsed && expanded) {
13047 setExpanded(false);
13048 }
13049 }, [expanded, isNavigationCollapsed]);
13050 var tabIndex = disabled ? -1 : 0;
13051 var hasNewChild = subNavigationItems.filter(function (subNavigationItem) {
13052 return subNavigationItem.new;
13053 }).length > 0;
13054 var indicatorMarkup = hasNewChild ? React__default.createElement("span", {
13055 className: styles$1d.Indicator
13056 }, React__default.createElement(Indicator, {
13057 pulse: true
13058 })) : null;
13059 var iconMarkup = icon ? React__default.createElement("div", {
13060 className: styles$1d.Icon
13061 }, React__default.createElement(Icon, {
13062 source: icon
13063 })) : null;
13064 var badgeMarkup = null;
13065
13066 if (isNew) {
13067 badgeMarkup = React__default.createElement(Badge, {
13068 status: "new",
13069 size: "small"
13070 }, i18n.translate('Polaris.Badge.STATUS_LABELS.new'));
13071 } else if (typeof badge === 'string') {
13072 badgeMarkup = React__default.createElement(Badge, {
13073 status: "new",
13074 size: "small"
13075 }, badge);
13076 } else {
13077 badgeMarkup = badge;
13078 }
13079
13080 var wrappedBadgeMarkup = badgeMarkup == null ? null : React__default.createElement("div", {
13081 className: styles$1d.Badge
13082 }, badgeMarkup);
13083 var itemContentMarkup = React__default.createElement(React.Fragment, null, iconMarkup, React__default.createElement("span", {
13084 className: styles$1d.Text
13085 }, label, indicatorMarkup), wrappedBadgeMarkup);
13086
13087 if (url == null) {
13088 var _className = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled']);
13089
13090 return React__default.createElement("li", {
13091 className: styles$1d.ListItem
13092 }, React__default.createElement("button", {
13093 type: "button",
13094 className: _className,
13095 disabled: disabled,
13096 "aria-disabled": disabled,
13097 "aria-label": accessibilityLabel,
13098 onClick: getClickHandler(onClick)
13099 }, itemContentMarkup));
13100 }
13101
13102 var secondaryActionMarkup = secondaryAction && React__default.createElement(UnstyledLink, {
13103 external: true,
13104 url: secondaryAction.url,
13105 className: styles$1d.SecondaryAction,
13106 tabIndex: tabIndex,
13107 "aria-disabled": disabled,
13108 "aria-label": secondaryAction.accessibilityLabel
13109 }, React__default.createElement(Icon, {
13110 source: secondaryAction.icon
13111 }));
13112 var matchState = matchStateForItem({
13113 url,
13114 matches,
13115 exactMatch,
13116 matchPaths,
13117 excludePaths
13118 }, location);
13119 var matchingSubNavigationItems = subNavigationItems.filter(function (item) {
13120 var subMatchState = matchStateForItem(item, location);
13121 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
13122 });
13123 var childIsActive = matchingSubNavigationItems.length > 0;
13124 var selected = selectedOverride == null ? matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths : selectedOverride;
13125 var showExpanded = selected || expanded || childIsActive;
13126 var itemClassName = classNames(styles$1d.Item, disabled && styles$1d['Item-disabled'], selected && subNavigationItems.length === 0 && styles$1d['Item-selected'], showExpanded && styles$1d.subNavigationActive);
13127 var secondaryNavigationMarkup = null;
13128
13129 if (subNavigationItems.length > 0 && showExpanded) {
13130 var longestMatch = matchingSubNavigationItems.sort(function (_ref2, _ref3) {
13131 var firstUrl = _ref2.url;
13132 var secondUrl = _ref3.url;
13133 return secondUrl.length - firstUrl.length;
13134 })[0];
13135 secondaryNavigationMarkup = React__default.createElement("div", {
13136 className: styles$1d.SecondaryNavigation
13137 }, React__default.createElement(Secondary, {
13138 expanded: showExpanded
13139 }, subNavigationItems.map(function (item) {
13140 var label = item.label,
13141 rest = tslib_1.__rest(item, ["label"]);
13142
13143 return React__default.createElement(Item$7, Object.assign({}, rest, {
13144 key: label,
13145 label: label,
13146 matches: item === longestMatch,
13147 onClick: onNavigationDismiss
13148 }));
13149 })));
13150 }
13151
13152 var className = classNames(styles$1d.ListItem, secondaryAction && styles$1d['ListItem-hasAction']);
13153 return React__default.createElement("li", {
13154 className: className
13155 }, React__default.createElement("div", {
13156 className: styles$1d.ItemWrapper
13157 }, React__default.createElement(UnstyledLink, {
13158 url: url,
13159 className: itemClassName,
13160 tabIndex: tabIndex,
13161 "aria-disabled": disabled,
13162 "aria-label": accessibilityLabel,
13163 onClick: getClickHandler(onClick)
13164 }, itemContentMarkup), secondaryActionMarkup), secondaryNavigationMarkup);
13165
13166 function getClickHandler(onClick) {
13167 return function (event) {
13168 var currentTarget = event.currentTarget;
13169
13170 if (currentTarget.getAttribute('href') === location) {
13171 event.preventDefault();
13172 }
13173
13174 if (subNavigationItems && subNavigationItems.length > 0 && isNavigationCollapsed) {
13175 event.preventDefault();
13176 setExpanded(!expanded);
13177 } else if (onNavigationDismiss) {
13178 onNavigationDismiss();
13179
13180 if (onClick && onClick !== onNavigationDismiss) {
13181 onClick();
13182 }
13183
13184 return;
13185 }
13186
13187 if (onClick) {
13188 onClick();
13189 }
13190 };
13191 }
13192}
13193function isNavigationItemActive(navigationItem, currentPath) {
13194 var matchState = matchStateForItem(navigationItem, currentPath);
13195 var matchingSubNavigationItems = navigationItem.subNavigationItems && navigationItem.subNavigationItems.filter(function (item) {
13196 var subMatchState = matchStateForItem(item, currentPath);
13197 return subMatchState === MatchState.MatchForced || subMatchState === MatchState.MatchUrl || subMatchState === MatchState.MatchPaths;
13198 });
13199 var childIsActive = matchingSubNavigationItems && matchingSubNavigationItems.length > 0;
13200 var selected = matchState === MatchState.MatchForced || matchState === MatchState.MatchUrl || matchState === MatchState.MatchPaths;
13201 return selected || childIsActive;
13202}
13203
13204function normalizePathname(pathname) {
13205 var barePathname = pathname.split('?')[0].split('#')[0];
13206 return barePathname.endsWith('/') ? barePathname : "".concat(barePathname, "/");
13207}
13208
13209function safeEqual(location, path) {
13210 return normalizePathname(location) === normalizePathname(path);
13211}
13212
13213function safeStartsWith(location, path) {
13214 return normalizePathname(location).startsWith(normalizePathname(path));
13215}
13216
13217function matchStateForItem(_ref4, location) {
13218 var url = _ref4.url,
13219 matches = _ref4.matches,
13220 exactMatch = _ref4.exactMatch,
13221 matchPaths = _ref4.matchPaths,
13222 excludePaths = _ref4.excludePaths;
13223
13224 if (url == null) {
13225 return MatchState.NoMatch;
13226 }
13227
13228 if (matches) {
13229 return MatchState.MatchForced;
13230 }
13231
13232 if (matches === false || excludePaths && excludePaths.some(function (path) {
13233 return safeStartsWith(location, path);
13234 })) {
13235 return MatchState.Excluded;
13236 }
13237
13238 if (matchPaths && matchPaths.some(function (path) {
13239 return safeStartsWith(location, path);
13240 })) {
13241 return MatchState.MatchPaths;
13242 }
13243
13244 var matchesUrl = exactMatch ? safeEqual(location, url) : safeStartsWith(location, url);
13245 return matchesUrl ? MatchState.MatchUrl : MatchState.NoMatch;
13246}
13247
13248var createAdditionalItemsId = other.createUniqueIDFactory('AdditionalItems');
13249var Section$5 =
13250/*#__PURE__*/
13251function (_React$Component) {
13252 _inherits(Section, _React$Component);
13253
13254 function Section() {
13255 var _this;
13256
13257 _classCallCheck(this, Section);
13258
13259 _this = _possibleConstructorReturn(this, _getPrototypeOf(Section).apply(this, arguments));
13260 _this.state = {
13261 expanded: false
13262 };
13263 _this.animationFrame = null;
13264
13265 _this.toggleViewAll = function () {
13266 _this.setState(function (_ref) {
13267 var expanded = _ref.expanded;
13268 return {
13269 expanded: !expanded
13270 };
13271 });
13272 };
13273
13274 return _this;
13275 }
13276
13277 _createClass(Section, [{
13278 key: "componentWillUnmount",
13279 value: function componentWillUnmount() {
13280 if (this.animationFrame) {
13281 cancelAnimationFrame(this.animationFrame);
13282 }
13283 }
13284 }, {
13285 key: "render",
13286 value: function render() {
13287 var _this2 = this;
13288
13289 var _this$props = this.props,
13290 title = _this$props.title,
13291 fill = _this$props.fill,
13292 action = _this$props.action,
13293 items = _this$props.items,
13294 rollup = _this$props.rollup,
13295 separator = _this$props.separator;
13296 var expanded = this.state.expanded;
13297 var className = classNames(styles$1d.Section, separator && styles$1d['Section-withSeparator'], fill && styles$1d['Section-fill']);
13298 var actionMarkup = action && React__default.createElement("button", {
13299 type: "button",
13300 className: styles$1d.Action,
13301 "aria-label": action.accessibilityLabel,
13302 onClick: action.onClick
13303 }, React__default.createElement(Icon, {
13304 source: action.icon
13305 }));
13306 var sectionHeadingMarkup = title && React__default.createElement("li", {
13307 className: styles$1d.SectionHeading
13308 }, React__default.createElement("span", {
13309 className: styles$1d.Text
13310 }, title), actionMarkup);
13311 var itemsMarkup = items.map(function (item) {
13312 var onClick = item.onClick,
13313 label = item.label,
13314 subNavigationItems = item.subNavigationItems,
13315 rest = tslib_1.__rest(item, ["onClick", "label", "subNavigationItems"]);
13316
13317 var hasSubNavItems = subNavigationItems != null && subNavigationItems.length > 0;
13318 return React__default.createElement(Item$7, Object.assign({}, rest, {
13319 key: label,
13320 label: label,
13321 subNavigationItems: subNavigationItems,
13322 onClick: _this2.handleClick(onClick, hasSubNavItems)
13323 }));
13324 });
13325 var toggleClassName = classNames(styles$1d.Item, styles$1d.RollupToggle);
13326 var ariaLabel = rollup && (expanded ? rollup.hide : rollup.view);
13327 var toggleRollup = rollup && items.length > rollup.after && React__default.createElement("div", {
13328 className: styles$1d.ListItem,
13329 key: "List Item"
13330 }, React__default.createElement("button", {
13331 type: "button",
13332 className: toggleClassName,
13333 onClick: this.toggleViewAll,
13334 "aria-label": ariaLabel
13335 }, React__default.createElement("span", {
13336 className: styles$1d.Icon
13337 }, React__default.createElement(Icon, {
13338 source: polarisIcons.HorizontalDotsMinor
13339 }))));
13340 var activeItemIndex = items.findIndex(function (item) {
13341 if (!rollup) {
13342 return false;
13343 }
13344
13345 return rollup.activePath === item.url || item.url && rollup.activePath.startsWith(item.url) || (item.subNavigationItems ? item.subNavigationItems.some(function (_ref2) {
13346 var itemUrl = _ref2.url;
13347 return rollup.activePath.startsWith(itemUrl);
13348 }) : false);
13349 });
13350 var sectionItems = rollup ? itemsMarkup.slice(0, rollup.after) : itemsMarkup;
13351 var additionalItems = rollup ? itemsMarkup.slice(rollup.after) : [];
13352
13353 if (rollup && activeItemIndex !== -1 && activeItemIndex > rollup.after - 1) {
13354 sectionItems.push.apply(sectionItems, _toConsumableArray(additionalItems.splice(activeItemIndex - rollup.after, 1)));
13355 }
13356
13357 var additionalItemsId = createAdditionalItemsId();
13358 var activeItemsMarkup = rollup && additionalItems.length > 0 && React__default.createElement("li", {
13359 className: styles$1d.RollupSection
13360 }, React__default.createElement(Collapsible, {
13361 id: additionalItemsId,
13362 open: expanded
13363 }, React__default.createElement("ul", {
13364 className: styles$1d.List
13365 }, additionalItems)), toggleRollup);
13366 return React__default.createElement("ul", {
13367 className: className
13368 }, sectionHeadingMarkup, sectionItems, activeItemsMarkup);
13369 }
13370 }, {
13371 key: "handleClick",
13372 value: function handleClick(onClick, hasSubNavItems) {
13373 var _this3 = this;
13374
13375 return function () {
13376 if (onClick) {
13377 onClick();
13378 }
13379
13380 if (_this3.animationFrame) {
13381 cancelAnimationFrame(_this3.animationFrame);
13382 }
13383
13384 if (!hasSubNavItems || !navigationBarCollapsed().matches) {
13385 _this3.animationFrame = requestAnimationFrame(function () {
13386 return _this3.setState({
13387 expanded: false
13388 });
13389 });
13390 }
13391 };
13392 }
13393 }]);
13394
13395 return Section;
13396}(React__default.Component);
13397
13398var Navigation$1 =
13399/*#__PURE__*/
13400function (_React$Component) {
13401 _inherits(Navigation, _React$Component);
13402
13403 function Navigation() {
13404 _classCallCheck(this, Navigation);
13405
13406 return _possibleConstructorReturn(this, _getPrototypeOf(Navigation).apply(this, arguments));
13407 }
13408
13409 _createClass(Navigation, [{
13410 key: "render",
13411 value: function render() {
13412 var _this$props = this.props,
13413 children = _this$props.children,
13414 contextControl = _this$props.contextControl,
13415 location = _this$props.location,
13416 onDismiss = _this$props.onDismiss;
13417 var contextControlMarkup = contextControl && React__default.createElement("div", {
13418 className: styles$1d.ContextControl
13419 }, contextControl);
13420 var context = {
13421 location,
13422 onNavigationDismiss: onDismiss
13423 };
13424 return React__default.createElement(NavigationContext.Provider, {
13425 value: context
13426 }, React__default.createElement(WithinContentContext.Provider, {
13427 value: true
13428 }, React__default.createElement("nav", {
13429 className: styles$1d.Navigation
13430 }, contextControlMarkup, React__default.createElement(Scrollable, {
13431 className: styles$1d.PrimaryNavigation
13432 }, children))));
13433 }
13434 }]);
13435
13436 return Navigation;
13437}(React__default.Component);
13438Navigation$1.Item = Item$7;
13439Navigation$1.Section = Section$5;
13440
13441var EditableTarget;
13442
13443(function (EditableTarget) {
13444 EditableTarget["Input"] = "INPUT";
13445 EditableTarget["Textarea"] = "TEXTAREA";
13446 EditableTarget["Select"] = "SELECT";
13447 EditableTarget["ContentEditable"] = "contenteditable";
13448})(EditableTarget || (EditableTarget = {}));
13449
13450function isInputFocused() {
13451 if (document == null || document.activeElement == null) {
13452 return false;
13453 }
13454
13455 var tagName = document.activeElement.tagName;
13456 return tagName === EditableTarget.Input || tagName === EditableTarget.Textarea || tagName === EditableTarget.Select || document.activeElement.hasAttribute(EditableTarget.ContentEditable);
13457}
13458
13459var styles$1e = {
13460 "Tooltip": "Polaris-Tooltip",
13461 "measuring": "Polaris-Tooltip--measuring",
13462 "positionedAbove": "Polaris-Tooltip--positionedAbove",
13463 "light": "Polaris-Tooltip--light",
13464 "Wrapper": "Polaris-Tooltip__Wrapper",
13465 "Content": "Polaris-Tooltip__Content",
13466 "Label": "Polaris-Tooltip__Label"
13467};
13468
13469var TooltipOverlay =
13470/*#__PURE__*/
13471function (_React$PureComponent) {
13472 _inherits(TooltipOverlay, _React$PureComponent);
13473
13474 function TooltipOverlay() {
13475 var _this;
13476
13477 _classCallCheck(this, TooltipOverlay);
13478
13479 _this = _possibleConstructorReturn(this, _getPrototypeOf(TooltipOverlay).apply(this, arguments));
13480
13481 _this.renderOverlay = function () {
13482 var _this$props = _this.props,
13483 active = _this$props.active,
13484 activator = _this$props.activator,
13485 _this$props$preferred = _this$props.preferredPosition,
13486 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred;
13487 return React__default.createElement(PositionedOverlay, {
13488 active: active,
13489 activator: activator,
13490 preferredPosition: preferredPosition,
13491 render: _this.renderTooltip
13492 });
13493 };
13494
13495 _this.renderTooltip = function (overlayDetails) {
13496 var measuring = overlayDetails.measuring,
13497 desiredHeight = overlayDetails.desiredHeight,
13498 positioning = overlayDetails.positioning;
13499 var _this$props2 = _this.props,
13500 id = _this$props2.id,
13501 children = _this$props2.children,
13502 light = _this$props2.light;
13503 var containerClassName = classNames(styles$1e.Tooltip, light && styles$1e.light, measuring && styles$1e.measuring, positioning === 'above' && styles$1e.positionedAbove);
13504 var contentStyles = measuring ? undefined : {
13505 minHeight: desiredHeight
13506 };
13507 return React__default.createElement("div", Object.assign({
13508 className: containerClassName
13509 }, layer.props), React__default.createElement("div", {
13510 className: styles$1e.Wrapper
13511 }, React__default.createElement("div", {
13512 id: id,
13513 role: "tooltip",
13514 className: styles$1e.Content,
13515 style: contentStyles
13516 }, children)));
13517 };
13518
13519 return _this;
13520 }
13521
13522 _createClass(TooltipOverlay, [{
13523 key: "render",
13524 value: function render() {
13525 var markup = this.props.active ? this.renderOverlay() : null;
13526 return markup;
13527 }
13528 }]);
13529
13530 return TooltipOverlay;
13531}(React__default.PureComponent);
13532
13533var getUniqueID$2 = other.createUniqueIDFactory('TooltipContent');
13534var Tooltip =
13535/*#__PURE__*/
13536function (_React$PureComponent) {
13537 _inherits(Tooltip, _React$PureComponent);
13538
13539 function Tooltip() {
13540 var _this;
13541
13542 _classCallCheck(this, Tooltip);
13543
13544 _this = _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
13545 _this.state = {
13546 active: Boolean(_this.props.active),
13547 activatorNode: null
13548 };
13549 _this.id = getUniqueID$2();
13550 _this.mouseEntered = false;
13551
13552 _this.setActivator = function (node) {
13553 if (node == null) {
13554 _this.activatorContainer = null;
13555
13556 _this.setState({
13557 activatorNode: null
13558 });
13559
13560 return;
13561 }
13562
13563 _this.setState({
13564 activatorNode: node.firstElementChild
13565 });
13566
13567 _this.activatorContainer = node;
13568 };
13569
13570 _this.handleFocus = function () {
13571 _this.setState({
13572 active: true
13573 });
13574 };
13575
13576 _this.handleBlur = function () {
13577 _this.setState({
13578 active: false
13579 });
13580 };
13581
13582 _this.handleMouseEnter = function () {
13583 _this.mouseEntered = true;
13584
13585 _this.setState({
13586 active: true
13587 });
13588 };
13589
13590 _this.handleMouseLeave = function () {
13591 _this.mouseEntered = false;
13592
13593 _this.setState({
13594 active: false
13595 });
13596 }; // https://github.com/facebook/react/issues/10109
13597 // Mouseenter event not triggered when cursor moves from disabled button
13598
13599
13600 _this.handleMouseEnterFix = function () {
13601 !_this.mouseEntered && _this.handleMouseEnter();
13602 };
13603
13604 return _this;
13605 }
13606
13607 _createClass(Tooltip, [{
13608 key: "componentDidMount",
13609 value: function componentDidMount() {
13610 this.setAccessibilityAttributes();
13611 }
13612 }, {
13613 key: "componentDidUpdate",
13614 value: function componentDidUpdate() {
13615 this.setAccessibilityAttributes();
13616 }
13617 }, {
13618 key: "render",
13619 value: function render() {
13620 var id = this.id;
13621 var _this$props = this.props,
13622 children = _this$props.children,
13623 content = _this$props.content,
13624 light = _this$props.light,
13625 _this$props$preferred = _this$props.preferredPosition,
13626 preferredPosition = _this$props$preferred === void 0 ? 'below' : _this$props$preferred,
13627 _this$props$activator = _this$props.activatorWrapper,
13628 WrapperComponent = _this$props$activator === void 0 ? 'span' : _this$props$activator;
13629 var _this$state = this.state,
13630 active = _this$state.active,
13631 activatorNode = _this$state.activatorNode;
13632 var portal = activatorNode ? React__default.createElement(Portal, {
13633 idPrefix: "tooltip"
13634 }, React__default.createElement(TooltipOverlay, {
13635 id: id,
13636 preferredPosition: preferredPosition,
13637 activator: activatorNode,
13638 active: active,
13639 onClose: noop$9,
13640 light: light
13641 }, React__default.createElement("div", {
13642 className: styles$1e.Label
13643 }, content))) : null;
13644 return React__default.createElement(WrapperComponent, {
13645 onFocus: this.handleFocus,
13646 onBlur: this.handleBlur,
13647 onMouseLeave: this.handleMouseLeave,
13648 onMouseOver: this.handleMouseEnterFix,
13649 ref: this.setActivator
13650 }, children, portal);
13651 }
13652 }, {
13653 key: "setAccessibilityAttributes",
13654 value: function setAccessibilityAttributes() {
13655 var activatorContainer = this.activatorContainer,
13656 id = this.id;
13657
13658 if (activatorContainer == null) {
13659 return;
13660 }
13661
13662 var firstFocusable = focus.findFirstFocusableNode(activatorContainer);
13663 var accessibilityNode = firstFocusable || activatorContainer;
13664 accessibilityNode.tabIndex = 0;
13665 accessibilityNode.setAttribute('aria-describedby', id);
13666 }
13667 }]);
13668
13669 return Tooltip;
13670}(React__default.PureComponent);
13671
13672function noop$9() {}
13673
13674var styles$1f = {
13675 "Pagination": "Polaris-Pagination",
13676 "plain": "Polaris-Pagination--plain",
13677 "Button": "Polaris-Pagination__Button",
13678 "PreviousButton": "Polaris-Pagination__PreviousButton",
13679 "NextButton": "Polaris-Pagination__NextButton",
13680 "Label": "Polaris-Pagination__Label"
13681};
13682
13683function Pagination(_ref) {
13684 var hasNext = _ref.hasNext,
13685 hasPrevious = _ref.hasPrevious,
13686 nextURL = _ref.nextURL,
13687 previousURL = _ref.previousURL,
13688 onNext = _ref.onNext,
13689 onPrevious = _ref.onPrevious,
13690 nextTooltip = _ref.nextTooltip,
13691 previousTooltip = _ref.previousTooltip,
13692 nextKeys = _ref.nextKeys,
13693 previousKeys = _ref.previousKeys,
13694 plain = _ref.plain,
13695 accessibilityLabel = _ref.accessibilityLabel,
13696 label = _ref.label;
13697 var i18n = useI18n();
13698 var node = React__default.createRef();
13699 var navLabel = accessibilityLabel || i18n.translate('Polaris.Pagination.pagination');
13700 var className = classNames(styles$1f.Pagination, plain && styles$1f.plain);
13701 var previousClassName = classNames(styles$1f.Button, !label && styles$1f.PreviousButton);
13702 var nextClassName = classNames(styles$1f.Button, !label && styles$1f.NextButton);
13703 var previousButton = previousURL ? React__default.createElement(UnstyledLink, {
13704 className: previousClassName,
13705 url: previousURL,
13706 onMouseUp: handleMouseUpByBlurring,
13707 "aria-label": i18n.translate('Polaris.Pagination.previous'),
13708 id: "previousURL"
13709 }, React__default.createElement(Icon, {
13710 source: polarisIcons.ArrowLeftMinor
13711 })) : React__default.createElement("button", {
13712 onClick: onPrevious,
13713 type: "button",
13714 onMouseUp: handleMouseUpByBlurring,
13715 className: previousClassName,
13716 "aria-label": i18n.translate('Polaris.Pagination.previous'),
13717 disabled: !hasPrevious
13718 }, React__default.createElement(Icon, {
13719 source: polarisIcons.ArrowLeftMinor
13720 }));
13721 var nextButton = nextURL ? React__default.createElement(UnstyledLink, {
13722 className: nextClassName,
13723 url: nextURL,
13724 onMouseUp: handleMouseUpByBlurring,
13725 "aria-label": i18n.translate('Polaris.Pagination.next'),
13726 id: "nextURL"
13727 }, React__default.createElement(Icon, {
13728 source: polarisIcons.ArrowRightMinor
13729 })) : React__default.createElement("button", {
13730 onClick: onNext,
13731 type: "button",
13732 onMouseUp: handleMouseUpByBlurring,
13733 className: nextClassName,
13734 "aria-label": i18n.translate('Polaris.Pagination.next'),
13735 disabled: !hasNext
13736 }, React__default.createElement(Icon, {
13737 source: polarisIcons.ArrowRightMinor
13738 }));
13739 var constructedPrevious = previousTooltip && hasPrevious ? React__default.createElement(Tooltip, {
13740 content: previousTooltip
13741 }, previousButton) : previousButton;
13742 var constructedNext = nextTooltip && hasNext ? React__default.createElement(Tooltip, {
13743 content: nextTooltip
13744 }, nextButton) : nextButton;
13745 var previousButtonEvents = previousKeys && (previousURL || onPrevious) && hasPrevious && previousKeys.map(function (key) {
13746 return React__default.createElement(KeypressListener, {
13747 key: key,
13748 keyCode: key,
13749 handler: previousURL ? handleCallback(clickPaginationLink('previousURL', node)) : handleCallback(onPrevious)
13750 });
13751 });
13752 var nextButtonEvents = nextKeys && (nextURL || onNext) && hasNext && nextKeys.map(function (key) {
13753 return React__default.createElement(KeypressListener, {
13754 key: key,
13755 keyCode: key,
13756 handler: nextURL ? handleCallback(clickPaginationLink('nextURL', node)) : handleCallback(onNext)
13757 });
13758 });
13759 var labelTextMarkup = hasNext && hasPrevious ? React__default.createElement(TextStyle, null, label) : React__default.createElement(TextStyle, {
13760 variation: "subdued"
13761 }, label);
13762 var labelMarkup = label ? React__default.createElement("div", {
13763 className: styles$1f.Label,
13764 "aria-live": "polite"
13765 }, labelTextMarkup) : null;
13766 return React__default.createElement("nav", {
13767 className: className,
13768 "aria-label": navLabel,
13769 ref: node
13770 }, previousButtonEvents, constructedPrevious, labelMarkup, nextButtonEvents, constructedNext);
13771}
13772
13773function clickPaginationLink(id, node) {
13774 return function () {
13775 if (node.current == null) {
13776 return;
13777 }
13778
13779 var link = node.current.querySelector("#".concat(id));
13780
13781 if (link) {
13782 link.click();
13783 }
13784 };
13785}
13786
13787function handleCallback(fn) {
13788 return function () {
13789 if (isInputFocused()) {
13790 return;
13791 }
13792
13793 fn();
13794 };
13795}
13796
13797var styles$1g = {
13798 "Title": "Polaris-Header-Title",
13799 "SubTitle": "Polaris-Header-Title__SubTitle",
13800 "hasThumbnail": "Polaris-Header-Title--hasThumbnail",
13801 "TitleAndSubtitleWrapper": "Polaris-Header-Title__TitleAndSubtitleWrapper",
13802 "TitleWithMetadataWrapper": "Polaris-Header-Title__TitleWithMetadataWrapper",
13803 "TitleMetadata": "Polaris-Header-Title__TitleMetadata"
13804};
13805
13806function Title(_ref) {
13807 var title = _ref.title,
13808 subtitle = _ref.subtitle,
13809 titleMetadata = _ref.titleMetadata,
13810 thumbnail = _ref.thumbnail;
13811 var titleMarkup = title ? React.createElement("div", {
13812 className: styles$1g.Title
13813 }, React.createElement(DisplayText, {
13814 size: "large",
13815 element: "h1"
13816 }, title)) : null;
13817 var titleMetadataMarkup = titleMetadata ? React.createElement("div", {
13818 className: styles$1g.TitleMetadata
13819 }, titleMetadata) : null;
13820 var wrappedTitleMarkup = titleMetadata ? React.createElement("div", {
13821 className: styles$1g.TitleWithMetadataWrapper
13822 }, titleMarkup, titleMetadataMarkup) : titleMarkup;
13823 var subtitleMarkup = subtitle ? React.createElement("div", {
13824 className: styles$1g.SubTitle
13825 }, React.createElement("p", null, subtitle)) : null;
13826 var thumbnailMarkup = thumbnail ? React.createElement("div", null, thumbnail) : null;
13827 var pageTitleClassName = thumbnail ? classNames(styles$1g.hasThumbnail) : undefined;
13828 return React.createElement("div", {
13829 className: pageTitleClassName
13830 }, thumbnailMarkup, React.createElement("div", {
13831 className: styles$1g.TitleAndSubtitleWrapper
13832 }, wrappedTitleMarkup, subtitleMarkup));
13833}
13834
13835var styles$1h = {
13836 "Header": "Polaris-Page-Header",
13837 "separator": "Polaris-Page-Header--separator",
13838 "titleHidden": "Polaris-Page-Header--titleHidden",
13839 "Navigation": "Polaris-Page-Header__Navigation",
13840 "hasActionMenu": "Polaris-Page-Header--hasActionMenu",
13841 "mobileView": "Polaris-Page-Header--mobileView",
13842 "BreadcrumbWrapper": "Polaris-Page-Header__BreadcrumbWrapper",
13843 "PaginationWrapper": "Polaris-Page-Header__PaginationWrapper",
13844 "MainContent": "Polaris-Page-Header__MainContent",
13845 "TitleActionMenuWrapper": "Polaris-Page-Header__TitleActionMenuWrapper",
13846 "hasNavigation": "Polaris-Page-Header--hasNavigation",
13847 "PrimaryActionWrapper": "Polaris-Page-Header__PrimaryActionWrapper",
13848 "ActionMenuWrapper": "Polaris-Page-Header__ActionMenuWrapper"
13849};
13850
13851function Header$2(_ref) {
13852 var title = _ref.title,
13853 subtitle = _ref.subtitle,
13854 titleMetadata = _ref.titleMetadata,
13855 thumbnail = _ref.thumbnail,
13856 _ref$titleHidden = _ref.titleHidden,
13857 titleHidden = _ref$titleHidden === void 0 ? false : _ref$titleHidden,
13858 separator = _ref.separator,
13859 primaryAction = _ref.primaryAction,
13860 pagination = _ref.pagination,
13861 _ref$breadcrumbs = _ref.breadcrumbs,
13862 breadcrumbs = _ref$breadcrumbs === void 0 ? [] : _ref$breadcrumbs,
13863 _ref$secondaryActions = _ref.secondaryActions,
13864 secondaryActions = _ref$secondaryActions === void 0 ? [] : _ref$secondaryActions,
13865 _ref$actionGroups = _ref.actionGroups,
13866 actionGroups = _ref$actionGroups === void 0 ? [] : _ref$actionGroups;
13867
13868 var _useMediaQuery = useMediaQuery(),
13869 isNavigationCollapsed = _useMediaQuery.isNavigationCollapsed;
13870
13871 var breadcrumbMarkup = breadcrumbs.length > 0 ? React__default.createElement("div", {
13872 className: styles$1h.BreadcrumbWrapper
13873 }, React__default.createElement(Breadcrumbs, {
13874 breadcrumbs: breadcrumbs
13875 })) : null;
13876 var paginationMarkup = pagination && !isNavigationCollapsed ? React__default.createElement("div", {
13877 className: styles$1h.PaginationWrapper
13878 }, React__default.createElement(Pagination, Object.assign({}, pagination, {
13879 plain: true
13880 }))) : null;
13881 var navigationMarkup = breadcrumbMarkup || paginationMarkup ? React__default.createElement("div", {
13882 className: styles$1h.Navigation
13883 }, breadcrumbMarkup, paginationMarkup) : null;
13884 var pageTitleMarkup = React__default.createElement(Title, {
13885 title: title,
13886 subtitle: subtitle,
13887 titleMetadata: titleMetadata,
13888 thumbnail: thumbnail
13889 });
13890 var primary = primaryAction && (primaryAction.primary === undefined ? true : primaryAction.primary);
13891 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
13892 className: styles$1h.PrimaryActionWrapper
13893 }, buttonsFrom(primaryAction, {
13894 primary
13895 })) : null;
13896 var actionMenuMarkup = secondaryActions.length > 0 || hasGroupsWithActions(actionGroups) ? React__default.createElement("div", {
13897 className: styles$1h.ActionMenuWrapper
13898 }, React__default.createElement(ActionMenu, {
13899 actions: secondaryActions,
13900 groups: actionGroups,
13901 rollup: isNavigationCollapsed
13902 })) : null;
13903 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);
13904 return React__default.createElement("div", {
13905 className: headerClassNames
13906 }, navigationMarkup, React__default.createElement("div", {
13907 className: styles$1h.MainContent
13908 }, React__default.createElement("div", {
13909 className: styles$1h.TitleActionMenuWrapper
13910 }, pageTitleMarkup, actionMenuMarkup), primaryActionMarkup));
13911}
13912
13913var styles$1i = {
13914 "Page": "Polaris-Page",
13915 "fullWidth": "Polaris-Page--fullWidth",
13916 "narrowWidth": "Polaris-Page--narrowWidth",
13917 "Content": "Polaris-Page__Content"
13918};
13919
13920var APP_BRIDGE_PROPS$1 = ['title', 'breadcrumbs', 'secondaryActions', 'actionGroups', 'primaryAction'];
13921
13922var Page =
13923/*#__PURE__*/
13924function (_React$PureComponent) {
13925 _inherits(Page, _React$PureComponent);
13926
13927 function Page() {
13928 _classCallCheck(this, Page);
13929
13930 return _possibleConstructorReturn(this, _getPrototypeOf(Page).apply(this, arguments));
13931 }
13932
13933 _createClass(Page, [{
13934 key: "componentDidMount",
13935 value: function componentDidMount() {
13936 if (this.delegateToAppbridge === false || !this.props.polaris.appBridge) {
13937 return;
13938 }
13939
13940 var transformedProps = this.transformProps();
13941 if (!transformedProps) return; // eslint-disable-next-line no-console
13942
13943 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');
13944 this.titlebar = actions.TitleBar.create(this.props.polaris.appBridge, transformedProps);
13945 }
13946 }, {
13947 key: "componentDidUpdate",
13948 value: function componentDidUpdate(prevProps) {
13949 if (this.titlebar == null || this.delegateToAppbridge === false) {
13950 return;
13951 }
13952
13953 var prevAppBridgeProps = pick(prevProps, APP_BRIDGE_PROPS$1);
13954 var currentAppBridgeProps = pick(this.props, APP_BRIDGE_PROPS$1);
13955
13956 if (!isEqual(prevAppBridgeProps, currentAppBridgeProps)) {
13957 var transformedProps = this.transformProps();
13958 if (!transformedProps) return;
13959 this.titlebar.unsubscribe();
13960 this.titlebar.set(transformedProps);
13961 }
13962 }
13963 }, {
13964 key: "componentWillUnmount",
13965 value: function componentWillUnmount() {
13966 if (this.titlebar == null || this.delegateToAppbridge === false) {
13967 return;
13968 }
13969
13970 this.titlebar.unsubscribe();
13971 }
13972 }, {
13973 key: "render",
13974 value: function render() {
13975 var _a = this.props,
13976 children = _a.children,
13977 fullWidth = _a.fullWidth,
13978 narrowWidth = _a.narrowWidth,
13979 singleColumn = _a.singleColumn,
13980 rest = tslib_1.__rest(_a, ["children", "fullWidth", "narrowWidth", "singleColumn"]);
13981
13982 if (singleColumn) {
13983 // eslint-disable-next-line no-console
13984 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
13985 }
13986
13987 var className = classNames(styles$1i.Page, fullWidth && styles$1i.fullWidth, (narrowWidth || singleColumn) && styles$1i.narrowWidth);
13988 var headerMarkup = this.delegateToAppbridge || this.hasHeaderContent() === false ? null : React__default.createElement(Header$2, rest);
13989 return React__default.createElement("div", {
13990 className: className
13991 }, headerMarkup, React__default.createElement("div", {
13992 className: styles$1i.Content
13993 }, children));
13994 }
13995 }, {
13996 key: "hasHeaderContent",
13997 value: function hasHeaderContent() {
13998 var _this$props = this.props,
13999 title = _this$props.title,
14000 primaryAction = _this$props.primaryAction,
14001 secondaryActions = _this$props.secondaryActions,
14002 actionGroups = _this$props.actionGroups,
14003 breadcrumbs = _this$props.breadcrumbs;
14004 return title != null && title !== '' || primaryAction != null || secondaryActions != null && secondaryActions.length > 0 || actionGroups != null && actionGroups.length > 0 || breadcrumbs != null && breadcrumbs.length > 0;
14005 }
14006 }, {
14007 key: "transformProps",
14008 value: function transformProps() {
14009 var appBridge = this.props.polaris.appBridge;
14010 if (!appBridge) return;
14011 var _this$props2 = this.props,
14012 title = _this$props2.title,
14013 primaryAction = _this$props2.primaryAction,
14014 secondaryActions = _this$props2.secondaryActions,
14015 actionGroups = _this$props2.actionGroups;
14016 return {
14017 title,
14018 buttons: transformActions(appBridge, {
14019 primaryAction,
14020 secondaryActions,
14021 actionGroups
14022 }),
14023 breadcrumbs: this.transformBreadcrumbs()
14024 };
14025 }
14026 }, {
14027 key: "transformBreadcrumbs",
14028 value: function transformBreadcrumbs() {
14029 var appBridge = this.props.polaris.appBridge;
14030 if (!appBridge) return;
14031 var breadcrumbs = this.props.breadcrumbs;
14032
14033 if (breadcrumbs != null && breadcrumbs.length > 0) {
14034 var breadcrumb = breadcrumbs[breadcrumbs.length - 1];
14035 var button = actions.Button.create(appBridge, {
14036 label: breadcrumb.content || ''
14037 });
14038 var callback = !('url' in breadcrumb) ? breadcrumb.onAction : generateRedirect(appBridge, breadcrumb.url, breadcrumb.target);
14039
14040 if (callback != null) {
14041 button.subscribe(actions.Button.Action.CLICK, callback);
14042 }
14043
14044 return button;
14045 } else {
14046 return undefined;
14047 }
14048 }
14049 }, {
14050 key: "delegateToAppbridge",
14051 get: function get() {
14052 var _this$props3 = this.props,
14053 appBridge = _this$props3.polaris.appBridge,
14054 _this$props3$forceRen = _this$props3.forceRender,
14055 forceRender = _this$props3$forceRen === void 0 ? false : _this$props3$forceRen;
14056 return appBridge != null && forceRender === false;
14057 }
14058 }]);
14059
14060 return Page;
14061}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
14062// eslint-disable-next-line import/no-default-export
14063
14064
14065var Page$1 = withAppProvider()(Page);
14066
14067var styles$1j = {
14068 "PageActions": "Polaris-PageActions"
14069};
14070
14071function PageActions(_ref) {
14072 var primaryAction = _ref.primaryAction,
14073 secondaryActions = _ref.secondaryActions;
14074 var primaryActionMarkup = primaryAction ? buttonsFrom(primaryAction, {
14075 primary: true
14076 }) : null;
14077 var secondaryActionsMarkup = secondaryActions ? React__default.createElement(ButtonGroup, null, buttonsFrom(secondaryActions)) : null;
14078 var distribution = secondaryActionsMarkup ? 'equalSpacing' : 'trailing';
14079 return React__default.createElement("div", {
14080 className: styles$1j.PageActions
14081 }, React__default.createElement(Stack, {
14082 distribution: distribution,
14083 spacing: "tight"
14084 }, secondaryActionsMarkup, primaryActionMarkup));
14085}
14086
14087var defaultMediaQuery = {
14088 isNavigationCollapsed: false
14089};
14090function PolarisTestProvider(_ref) {
14091 var strict = _ref.strict,
14092 children = _ref.children,
14093 i18n = _ref.i18n,
14094 appBridge = _ref.appBridge,
14095 link = _ref.link,
14096 _ref$theme = _ref.theme,
14097 theme = _ref$theme === void 0 ? {} : _ref$theme,
14098 mediaQuery = _ref.mediaQuery,
14099 _ref$features = _ref.features,
14100 features = _ref$features === void 0 ? {} : _ref$features,
14101 frame = _ref.frame;
14102 var Wrapper = strict ? React__default.StrictMode : React__default.Fragment;
14103 var intl = new I18n(i18n || {});
14104 var scrollLockManager = new ScrollLockManager();
14105 var stickyManager = new StickyManager();
14106 var uniqueIdFactory = new UniqueIdFactory(globalIdGeneratorFactory); // This typing is odd, but as appBridge is deprecated and going away in v5
14107 // I'm not that worried about it
14108
14109 var appBridgeApp = appBridge;
14110 var _features$unstableGlo = features.unstableGlobalTheming,
14111 unstableGlobalTheming = _features$unstableGlo === void 0 ? false : _features$unstableGlo;
14112 var customProperties = unstableGlobalTheming ? buildCustomProperties(theme, unstableGlobalTheming) : undefined;
14113 var mergedTheme = buildThemeContext(theme, customProperties);
14114 var mergedFrame = createFrameContext(frame);
14115 var mergedMediaQuery = merge(defaultMediaQuery, mediaQuery);
14116 return React__default.createElement(Wrapper, null, React__default.createElement(FeaturesContext.Provider, {
14117 value: features
14118 }, React__default.createElement(I18nContext.Provider, {
14119 value: intl
14120 }, React__default.createElement(ScrollLockManagerContext.Provider, {
14121 value: scrollLockManager
14122 }, React__default.createElement(StickyManagerContext.Provider, {
14123 value: stickyManager
14124 }, React__default.createElement(UniqueIdFactoryContext.Provider, {
14125 value: uniqueIdFactory
14126 }, React__default.createElement(AppBridgeContext.Provider, {
14127 value: appBridgeApp
14128 }, React__default.createElement(LinkContext.Provider, {
14129 value: link
14130 }, React__default.createElement(ThemeContext.Provider, {
14131 value: mergedTheme
14132 }, React__default.createElement(MediaQueryContext.Provider, {
14133 value: mergedMediaQuery
14134 }, React__default.createElement(FrameContext.Provider, {
14135 value: mergedFrame
14136 }, children)))))))))));
14137}
14138
14139function noop$a() {}
14140
14141function createFrameContext() {
14142 var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
14143 _ref2$showToast = _ref2.showToast,
14144 showToast = _ref2$showToast === void 0 ? noop$a : _ref2$showToast,
14145 _ref2$hideToast = _ref2.hideToast,
14146 hideToast = _ref2$hideToast === void 0 ? noop$a : _ref2$hideToast,
14147 _ref2$setContextualSa = _ref2.setContextualSaveBar,
14148 setContextualSaveBar = _ref2$setContextualSa === void 0 ? noop$a : _ref2$setContextualSa,
14149 _ref2$removeContextua = _ref2.removeContextualSaveBar,
14150 removeContextualSaveBar = _ref2$removeContextua === void 0 ? noop$a : _ref2$removeContextua,
14151 _ref2$startLoading = _ref2.startLoading,
14152 startLoading = _ref2$startLoading === void 0 ? noop$a : _ref2$startLoading,
14153 _ref2$stopLoading = _ref2.stopLoading,
14154 stopLoading = _ref2$stopLoading === void 0 ? noop$a : _ref2$stopLoading;
14155
14156 return {
14157 showToast,
14158 hideToast,
14159 setContextualSaveBar,
14160 removeContextualSaveBar,
14161 startLoading,
14162 stopLoading
14163 };
14164}
14165
14166var styles$1k = {
14167 "ProgressBar": "Polaris-ProgressBar",
14168 "sizeSmall": "Polaris-ProgressBar--sizeSmall",
14169 "sizeMedium": "Polaris-ProgressBar--sizeMedium",
14170 "sizeLarge": "Polaris-ProgressBar--sizeLarge",
14171 "Indicator": "Polaris-ProgressBar__Indicator",
14172 "fillup": "Polaris-ProgressBar--fillup",
14173 "Progress": "Polaris-ProgressBar__Progress",
14174 "Label": "Polaris-ProgressBar__Label"
14175};
14176
14177function ProgressBar(_ref) {
14178 var _ref$progress = _ref.progress,
14179 progress = _ref$progress === void 0 ? 0 : _ref$progress,
14180 _ref$size = _ref.size,
14181 size = _ref$size === void 0 ? 'medium' : _ref$size;
14182 var i18n = useI18n();
14183 var className = classNames(styles$1k.ProgressBar, size && styles$1k[variationName('size', size)]);
14184 var warningMessage = i18n.translate(progress < 0 ? 'Polaris.ProgressBar.negativeWarningMessage' : 'Polaris.ProgressBar.exceedWarningMessage', {
14185 progress
14186 });
14187 var parsedProgress = parseProgress(progress, warningMessage);
14188 return React__default.createElement("div", {
14189 className: className
14190 }, React__default.createElement("progress", {
14191 className: styles$1k.Progress,
14192 value: parsedProgress,
14193 max: "100"
14194 }), React__default.createElement("div", {
14195 className: styles$1k.Indicator,
14196 style: {
14197 width: "".concat(parsedProgress, "%")
14198 }
14199 }, React__default.createElement("span", {
14200 className: styles$1k.Label
14201 }, parsedProgress, "%")));
14202}
14203
14204function parseProgress(progress, warningMessage) {
14205 var progressWidth;
14206
14207 if (progress < 0) {
14208 if (process.env.NODE_ENV === 'development') {
14209 // eslint-disable-next-line no-console
14210 console.warn(warningMessage);
14211 }
14212
14213 progressWidth = 0;
14214 } else if (progress > 100) {
14215 if (process.env.NODE_ENV === 'development') {
14216 // eslint-disable-next-line no-console
14217 console.warn(warningMessage);
14218 }
14219
14220 progressWidth = 100;
14221 } else {
14222 progressWidth = progress;
14223 }
14224
14225 return progressWidth;
14226}
14227
14228function invertNumber(number) {
14229 if (Math.sign(number) === 1) {
14230 return -Math.abs(number);
14231 } else if (Math.sign(number) === -1) {
14232 return Math.abs(number);
14233 } else {
14234 return 0;
14235 }
14236}
14237
14238var CSS_VAR_PREFIX = '--Polaris-RangeSlider-';
14239var RangeSliderDefault;
14240
14241(function (RangeSliderDefault) {
14242 RangeSliderDefault[RangeSliderDefault["Min"] = 0] = "Min";
14243 RangeSliderDefault[RangeSliderDefault["Max"] = 100] = "Max";
14244 RangeSliderDefault[RangeSliderDefault["Step"] = 1] = "Step";
14245})(RangeSliderDefault || (RangeSliderDefault = {}));
14246
14247var styles$1l = {
14248 "Wrapper": "Polaris-RangeSlider-DualThumb__Wrapper",
14249 "TrackWrapper": "Polaris-RangeSlider-DualThumb__TrackWrapper",
14250 "disabled": "Polaris-RangeSlider-DualThumb--disabled",
14251 "Track": "Polaris-RangeSlider-DualThumb__Track",
14252 "error": "Polaris-RangeSlider-DualThumb--error",
14253 "Thumbs": "Polaris-RangeSlider-DualThumb__Thumbs",
14254 "Prefix": "Polaris-RangeSlider-DualThumb__Prefix",
14255 "Suffix": "Polaris-RangeSlider-DualThumb__Suffix",
14256 "Output": "Polaris-RangeSlider-DualThumb__Output",
14257 "OutputBubble": "Polaris-RangeSlider-DualThumb__OutputBubble",
14258 "OutputText": "Polaris-RangeSlider-DualThumb__OutputText"
14259};
14260
14261var Control;
14262
14263(function (Control) {
14264 Control[Control["Lower"] = 0] = "Lower";
14265 Control[Control["Upper"] = 1] = "Upper";
14266})(Control || (Control = {}));
14267
14268var THUMB_SIZE = 24;
14269var DualThumb =
14270/*#__PURE__*/
14271function (_React$Component) {
14272 _inherits(DualThumb, _React$Component);
14273
14274 function DualThumb() {
14275 var _this;
14276
14277 _classCallCheck(this, DualThumb);
14278
14279 _this = _possibleConstructorReturn(this, _getPrototypeOf(DualThumb).apply(this, arguments));
14280 _this.state = {
14281 value: sanitizeValue(_this.props.value, _this.props.min, _this.props.max, _this.props.step),
14282 trackWidth: 0,
14283 trackLeft: 0
14284 };
14285 _this.track = React__default.createRef();
14286 _this.trackWrapper = React__default.createRef();
14287 _this.thumbLower = React__default.createRef();
14288 _this.thumbUpper = React__default.createRef();
14289 _this.setTrackPosition = debounce(function () {
14290 if (_this.track.current) {
14291 var _this$track$current$g = _this.track.current.getBoundingClientRect(),
14292 width = _this$track$current$g.width,
14293 left = _this$track$current$g.left;
14294
14295 var adjustedTrackWidth = width - THUMB_SIZE;
14296 var adjustedTrackLeft = left + THUMB_SIZE / 2;
14297
14298 _this.setState({
14299 trackWidth: adjustedTrackWidth,
14300 trackLeft: adjustedTrackLeft
14301 });
14302 }
14303 }, 40, {
14304 leading: true,
14305 trailing: true,
14306 maxWait: 40
14307 });
14308
14309 _this.handleMouseDownThumbLower = function (event) {
14310 if (event.button !== 0 || _this.props.disabled) return;
14311 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
14312 event.stopPropagation();
14313 };
14314
14315 _this.handleMouseMoveThumbLower = function (event) {
14316 var valueUpper = _this.state.value[1];
14317
14318 _this.setValue([_this.actualXPosition(event.clientX), valueUpper], Control.Upper);
14319 };
14320
14321 _this.handleTouchStartThumbLower = function (event) {
14322 if (_this.props.disabled) return;
14323 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
14324 event.stopPropagation();
14325 };
14326
14327 _this.handleTouchMoveThumbLower = function (event) {
14328 event.preventDefault();
14329 var valueUpper = _this.state.value[1];
14330
14331 _this.setValue([_this.actualXPosition(event.touches[0].clientX), valueUpper], Control.Upper);
14332 };
14333
14334 _this.handleMouseDownThumbUpper = function (event) {
14335 if (event.button !== 0 || _this.props.disabled) return;
14336 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
14337 event.stopPropagation();
14338 };
14339
14340 _this.handleMouseMoveThumbUpper = function (event) {
14341 var valueLower = _this.state.value[0];
14342
14343 _this.setValue([valueLower, _this.actualXPosition(event.clientX)], Control.Lower);
14344 };
14345
14346 _this.handleTouchStartThumbUpper = function (event) {
14347 if (_this.props.disabled) return;
14348 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
14349 event.stopPropagation();
14350 };
14351
14352 _this.handleTouchMoveThumbUpper = function (event) {
14353 event.preventDefault();
14354 var valueLower = _this.state.value[0];
14355
14356 _this.setValue([valueLower, _this.actualXPosition(event.touches[0].clientX)], Control.Lower);
14357 };
14358
14359 _this.handleKeypressLower = function (event) {
14360 if (_this.props.disabled) return;
14361
14362 var _assertThisInitialize = _assertThisInitialized(_this),
14363 incrementValueLower = _assertThisInitialize.incrementValueLower,
14364 decrementValueLower = _assertThisInitialize.decrementValueLower;
14365
14366 var handlerMap = {
14367 [exports.Key.UpArrow]: incrementValueLower,
14368 [exports.Key.RightArrow]: incrementValueLower,
14369 [exports.Key.DownArrow]: decrementValueLower,
14370 [exports.Key.LeftArrow]: decrementValueLower
14371 };
14372 var handler = handlerMap[event.keyCode];
14373
14374 if (handler != null) {
14375 event.preventDefault();
14376 event.stopPropagation();
14377 handler();
14378 }
14379 };
14380
14381 _this.handleKeypressUpper = function (event) {
14382 if (_this.props.disabled) return;
14383
14384 var _assertThisInitialize2 = _assertThisInitialized(_this),
14385 incrementValueUpper = _assertThisInitialize2.incrementValueUpper,
14386 decrementValueUpper = _assertThisInitialize2.decrementValueUpper;
14387
14388 var handlerMap = {
14389 [exports.Key.UpArrow]: incrementValueUpper,
14390 [exports.Key.RightArrow]: incrementValueUpper,
14391 [exports.Key.DownArrow]: decrementValueUpper,
14392 [exports.Key.LeftArrow]: decrementValueUpper
14393 };
14394 var handler = handlerMap[event.keyCode];
14395
14396 if (handler != null) {
14397 event.preventDefault();
14398 event.stopPropagation();
14399 handler();
14400 }
14401 };
14402
14403 _this.incrementValueLower = function () {
14404 _this.setValue([_this.state.value[0] + _this.props.step, _this.state.value[1]], Control.Upper);
14405 };
14406
14407 _this.decrementValueLower = function () {
14408 _this.setValue([_this.state.value[0] - _this.props.step, _this.state.value[1]], Control.Upper);
14409 };
14410
14411 _this.incrementValueUpper = function () {
14412 _this.setValue([_this.state.value[0], _this.state.value[1] + _this.props.step], Control.Lower);
14413 };
14414
14415 _this.decrementValueUpper = function () {
14416 _this.setValue([_this.state.value[0], _this.state.value[1] - _this.props.step], Control.Lower);
14417 };
14418
14419 _this.dispatchValue = function () {
14420 var _this$props = _this.props,
14421 onChange = _this$props.onChange,
14422 id = _this$props.id;
14423 var value = _this.state.value;
14424 onChange(value, id);
14425 };
14426
14427 _this.setValue = function (dirtyValue, control) {
14428 var _assertThisInitialize3 = _assertThisInitialized(_this),
14429 _assertThisInitialize4 = _assertThisInitialize3.props,
14430 min = _assertThisInitialize4.min,
14431 max = _assertThisInitialize4.max,
14432 step = _assertThisInitialize4.step,
14433 value = _assertThisInitialize3.state.value;
14434
14435 var sanitizedValue = sanitizeValue(dirtyValue, min, max, step, control);
14436
14437 if (isEqual(sanitizedValue, value) === false) {
14438 _this.setState({
14439 value: sanitizedValue
14440 }, _this.dispatchValue);
14441 }
14442 };
14443
14444 _this.handleMouseDownTrack = function (event) {
14445 if (event.button !== 0 || _this.props.disabled) return;
14446 event.preventDefault();
14447
14448 var clickXPosition = _this.actualXPosition(event.clientX);
14449
14450 var value = _this.state.value;
14451 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
14452 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
14453
14454 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
14455 _this.setValue([clickXPosition, value[1]], Control.Upper);
14456
14457 registerMouseMoveHandler(_this.handleMouseMoveThumbLower);
14458
14459 if (_this.thumbLower.current != null) {
14460 _this.thumbLower.current.focus();
14461 }
14462 } else {
14463 _this.setValue([value[0], clickXPosition], Control.Lower);
14464
14465 registerMouseMoveHandler(_this.handleMouseMoveThumbUpper);
14466
14467 if (_this.thumbUpper.current != null) {
14468 _this.thumbUpper.current.focus();
14469 }
14470 }
14471 };
14472
14473 _this.handleTouchStartTrack = function (event) {
14474 if (_this.props.disabled) return;
14475 event.preventDefault();
14476
14477 var clickXPosition = _this.actualXPosition(event.touches[0].clientX);
14478
14479 var value = _this.state.value;
14480 var distanceFromLowerThumb = Math.abs(value[0] - clickXPosition);
14481 var distanceFromUpperThumb = Math.abs(value[1] - clickXPosition);
14482
14483 if (distanceFromLowerThumb <= distanceFromUpperThumb) {
14484 _this.setValue([clickXPosition, value[1]], Control.Upper);
14485
14486 registerTouchMoveHandler(_this.handleTouchMoveThumbLower);
14487
14488 if (_this.thumbLower.current != null) {
14489 _this.thumbLower.current.focus();
14490 }
14491 } else {
14492 _this.setValue([value[0], clickXPosition], Control.Lower);
14493
14494 registerTouchMoveHandler(_this.handleTouchMoveThumbUpper);
14495
14496 if (_this.thumbUpper.current != null) {
14497 _this.thumbUpper.current.focus();
14498 }
14499 }
14500 };
14501
14502 _this.actualXPosition = function (dirtyXPosition) {
14503 if (_this.track.current) {
14504 var _this$props2 = _this.props,
14505 min = _this$props2.min,
14506 max = _this$props2.max;
14507 var _this$state = _this.state,
14508 trackLeft = _this$state.trackLeft,
14509 trackWidth = _this$state.trackWidth;
14510 var relativeX = dirtyXPosition - trackLeft;
14511 var percentageOfTrack = relativeX / trackWidth;
14512 return percentageOfTrack * (max - min);
14513 } else {
14514 return 0;
14515 }
14516 };
14517
14518 return _this;
14519 }
14520
14521 _createClass(DualThumb, [{
14522 key: "componentDidMount",
14523 value: function componentDidMount() {
14524 this.setTrackPosition();
14525
14526 if (this.trackWrapper.current != null) {
14527 events.addEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack, {
14528 passive: false
14529 });
14530 }
14531 }
14532 }, {
14533 key: "componentWillUnmount",
14534 value: function componentWillUnmount() {
14535 if (this.trackWrapper.current != null) {
14536 events.removeEventListener(this.trackWrapper.current, 'touchstart', this.handleTouchStartTrack);
14537 }
14538 }
14539 }, {
14540 key: "render",
14541 value: function render() {
14542 var _this$props3 = this.props,
14543 id = _this$props3.id,
14544 min = _this$props3.min,
14545 max = _this$props3.max,
14546 prefix = _this$props3.prefix,
14547 suffix = _this$props3.suffix,
14548 disabled = _this$props3.disabled,
14549 output = _this$props3.output,
14550 error = _this$props3.error,
14551 onFocus = _this$props3.onFocus,
14552 onBlur = _this$props3.onBlur,
14553 label = _this$props3.label,
14554 labelAction = _this$props3.labelAction,
14555 labelHidden = _this$props3.labelHidden,
14556 helpText = _this$props3.helpText;
14557 var value = this.state.value;
14558 var idLower = id;
14559 var idUpper = "".concat(id, "Upper");
14560 var describedBy = [];
14561
14562 if (error) {
14563 describedBy.push("".concat(id, "Error"));
14564 }
14565
14566 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
14567 var trackWrapperClassName = classNames(styles$1l.TrackWrapper, error && styles$1l.error, disabled && styles$1l.disabled);
14568 var thumbLowerClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbLower, disabled && styles$1l.disabled);
14569 var thumbUpperClassName = classNames(styles$1l.Thumbs, styles$1l.ThumbUpper, disabled && styles$1l.disabled);
14570 var trackWidth = this.state.trackWidth;
14571 var range = max - min;
14572 var leftPositionThumbLower = value[0] / range * trackWidth;
14573 var leftPositionThumbUpper = value[1] / range * trackWidth;
14574 var outputLowerClassName = classNames(styles$1l.Output, styles$1l.OutputLower);
14575 var outputMarkupLower = !disabled && output ? React__default.createElement("output", {
14576 htmlFor: idLower,
14577 className: outputLowerClassName,
14578 style: {
14579 left: "".concat(leftPositionThumbLower, "px")
14580 }
14581 }, React__default.createElement("div", {
14582 className: styles$1l.OutputBubble
14583 }, React__default.createElement("span", {
14584 className: styles$1l.OutputText
14585 }, value[0]))) : null;
14586 var outputUpperClassName = classNames(styles$1l.Output, styles$1l.OutputUpper);
14587 var outputMarkupUpper = !disabled && output ? React__default.createElement("output", {
14588 htmlFor: idUpper,
14589 className: outputUpperClassName,
14590 style: {
14591 left: "".concat(leftPositionThumbUpper, "px")
14592 }
14593 }, React__default.createElement("div", {
14594 className: styles$1l.OutputBubble
14595 }, React__default.createElement("span", {
14596 className: styles$1l.OutputText
14597 }, value[1]))) : null;
14598 var cssVars = {
14599 ["".concat(CSS_VAR_PREFIX, "progress-lower")]: "".concat(leftPositionThumbLower, "px"),
14600 ["".concat(CSS_VAR_PREFIX, "progress-upper")]: "".concat(leftPositionThumbUpper, "px")
14601 };
14602 var prefixMarkup = prefix && React__default.createElement("div", {
14603 className: styles$1l.Prefix
14604 }, prefix);
14605 var suffixMarkup = suffix && React__default.createElement("div", {
14606 className: styles$1l.Suffix
14607 }, suffix);
14608 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Labelled, {
14609 id: id,
14610 label: label,
14611 error: error,
14612 action: labelAction,
14613 labelHidden: labelHidden,
14614 helpText: helpText
14615 }, React__default.createElement("div", {
14616 className: styles$1l.Wrapper
14617 }, prefixMarkup, React__default.createElement("div", {
14618 className: trackWrapperClassName,
14619 onMouseDown: this.handleMouseDownTrack,
14620 ref: this.trackWrapper
14621 }, React__default.createElement("div", {
14622 className: styles$1l.Track,
14623 style: cssVars,
14624 ref: this.track
14625 }), React__default.createElement("button", {
14626 id: idLower,
14627 className: thumbLowerClassName,
14628 style: {
14629 left: "".concat(leftPositionThumbLower, "px")
14630 },
14631 role: "slider",
14632 "aria-disabled": disabled,
14633 "aria-valuemin": min,
14634 "aria-valuemax": max,
14635 "aria-valuenow": value[0],
14636 "aria-invalid": Boolean(error),
14637 "aria-describedby": ariaDescribedBy,
14638 "aria-labelledby": labelID(id),
14639 onFocus: onFocus,
14640 onBlur: onBlur,
14641 onKeyDown: this.handleKeypressLower,
14642 onMouseDown: this.handleMouseDownThumbLower,
14643 onTouchStart: this.handleTouchStartThumbLower,
14644 ref: this.thumbLower
14645 }), outputMarkupLower, React__default.createElement("button", {
14646 id: idUpper,
14647 className: thumbUpperClassName,
14648 style: {
14649 left: "".concat(leftPositionThumbUpper, "px")
14650 },
14651 role: "slider",
14652 "aria-disabled": disabled,
14653 "aria-valuemin": min,
14654 "aria-valuemax": max,
14655 "aria-valuenow": value[1],
14656 "aria-invalid": Boolean(error),
14657 "aria-describedby": ariaDescribedBy,
14658 "aria-labelledby": labelID(id),
14659 onFocus: onFocus,
14660 onBlur: onBlur,
14661 onKeyDown: this.handleKeypressUpper,
14662 onMouseDown: this.handleMouseDownThumbUpper,
14663 onTouchStart: this.handleTouchStartThumbUpper,
14664 ref: this.thumbUpper
14665 }), outputMarkupUpper), suffixMarkup)), React__default.createElement(EventListener, {
14666 event: "resize",
14667 handler: this.setTrackPosition
14668 }));
14669 }
14670 }], [{
14671 key: "getDerivedStateFromProps",
14672 value: function getDerivedStateFromProps(props, state) {
14673 var min = props.min,
14674 step = props.step,
14675 max = props.max,
14676 value = props.value,
14677 onChange = props.onChange,
14678 id = props.id;
14679 var prevValue = state.prevValue;
14680
14681 if (isEqual(prevValue, value)) {
14682 return null;
14683 }
14684
14685 var sanitizedValue = sanitizeValue(value, min, max, step);
14686
14687 if (!isEqual(value, sanitizedValue)) {
14688 onChange(sanitizedValue, id);
14689 }
14690
14691 return {
14692 prevValue: value,
14693 value: sanitizedValue
14694 };
14695 }
14696 }]);
14697
14698 return DualThumb;
14699}(React__default.Component);
14700
14701function registerMouseMoveHandler(handler) {
14702 events.addEventListener(document, 'mousemove', handler);
14703 events.addEventListener(document, 'mouseup', function () {
14704 events.removeEventListener(document, 'mousemove', handler);
14705 }, {
14706 once: true
14707 });
14708}
14709
14710function registerTouchMoveHandler(handler) {
14711 var removeHandler = function removeHandler() {
14712 events.removeEventListener(document, 'touchmove', handler);
14713 events.removeEventListener(document, 'touchend', removeHandler);
14714 events.removeEventListener(document, 'touchcancel', removeHandler);
14715 };
14716
14717 events.addEventListener(document, 'touchmove', handler, {
14718 passive: false
14719 });
14720 events.addEventListener(document, 'touchend', removeHandler, {
14721 once: true
14722 });
14723 events.addEventListener(document, 'touchcancel', removeHandler, {
14724 once: true
14725 });
14726}
14727
14728function sanitizeValue(value, min, max, step) {
14729 var control = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : Control.Upper;
14730 var upperValue = inBoundsUpper(roundedToStep(value[1]));
14731 var lowerValue = inBoundsLower(roundedToStep(value[0]));
14732 var maxLowerValue = upperValue - step;
14733 var minUpperValue = lowerValue + step;
14734
14735 if (control === Control.Upper && lowerValue > maxLowerValue) {
14736 lowerValue = maxLowerValue;
14737 } else if (control === Control.Lower && upperValue < minUpperValue) {
14738 upperValue = minUpperValue;
14739 }
14740
14741 return [lowerValue, upperValue];
14742
14743 function inBoundsUpper(value) {
14744 var lowerMin = min + step;
14745
14746 if (value < lowerMin) {
14747 return lowerMin;
14748 } else if (value > max) {
14749 return max;
14750 } else {
14751 return value;
14752 }
14753 }
14754
14755 function inBoundsLower(value) {
14756 var upperMax = max - step;
14757
14758 if (value < min) {
14759 return min;
14760 } else if (value > upperMax) {
14761 return upperMax;
14762 } else {
14763 return value;
14764 }
14765 }
14766
14767 function roundedToStep(value) {
14768 return Math.round(value / step) * step;
14769 }
14770}
14771
14772function clamp(number, min, max) {
14773 if (number < min) return min;
14774 if (number > max) return max;
14775 return number;
14776}
14777
14778var styles$1m = {
14779 "SingleThumb": "Polaris-RangeSlider-SingleThumb",
14780 "disabled": "Polaris-RangeSlider-SingleThumb--disabled",
14781 "InputWrapper": "Polaris-RangeSlider-SingleThumb__InputWrapper",
14782 "Prefix": "Polaris-RangeSlider-SingleThumb__Prefix",
14783 "Suffix": "Polaris-RangeSlider-SingleThumb__Suffix",
14784 "Input": "Polaris-RangeSlider-SingleThumb__Input",
14785 "error": "Polaris-RangeSlider-SingleThumb--error",
14786 "RangeSlider": "Polaris-RangeSlider-SingleThumb__RangeSlider",
14787 "Output": "Polaris-RangeSlider-SingleThumb__Output",
14788 "OutputBubble": "Polaris-RangeSlider-SingleThumb__OutputBubble",
14789 "OutputText": "Polaris-RangeSlider-SingleThumb__OutputText"
14790};
14791
14792function SingleThumb(props) {
14793 var id = props.id,
14794 error = props.error,
14795 helpText = props.helpText,
14796 value = props.value,
14797 min = props.min,
14798 max = props.max,
14799 disabled = props.disabled,
14800 output = props.output,
14801 prefix = props.prefix,
14802 suffix = props.suffix,
14803 label = props.label,
14804 labelAction = props.labelAction,
14805 labelHidden = props.labelHidden,
14806 step = props.step,
14807 onBlur = props.onBlur,
14808 onFocus = props.onFocus;
14809 var clampedValue = clamp(value, min, max);
14810 var describedBy = [];
14811
14812 if (error) {
14813 describedBy.push("".concat(id, "Error"));
14814 }
14815
14816 if (helpText) {
14817 describedBy.push(helpTextID(id));
14818 }
14819
14820 var ariaDescribedBy = describedBy.length ? describedBy.join(' ') : undefined;
14821 var sliderProgress = (clampedValue - min) * 100 / (max - min);
14822 var outputFactor = invertNumber((sliderProgress - 50) / 100);
14823 var cssVars = {
14824 ["".concat(CSS_VAR_PREFIX, "min")]: min,
14825 ["".concat(CSS_VAR_PREFIX, "max")]: max,
14826 ["".concat(CSS_VAR_PREFIX, "current")]: clampedValue,
14827 ["".concat(CSS_VAR_PREFIX, "progress")]: "".concat(sliderProgress, "%"),
14828 ["".concat(CSS_VAR_PREFIX, "output-factor")]: "".concat(outputFactor)
14829 };
14830 var outputMarkup = !disabled && output && React__default.createElement("output", {
14831 htmlFor: id,
14832 className: styles$1m.Output
14833 }, React__default.createElement("div", {
14834 className: styles$1m.OutputBubble
14835 }, React__default.createElement("span", {
14836 className: styles$1m.OutputText
14837 }, clampedValue)));
14838 var prefixMarkup = prefix && React__default.createElement("div", {
14839 className: styles$1m.Prefix
14840 }, prefix);
14841 var suffixMarkup = suffix && React__default.createElement("div", {
14842 className: styles$1m.Suffix
14843 }, suffix);
14844 var className = classNames(styles$1m.SingleThumb, error && styles$1m.error, disabled && styles$1m.disabled);
14845 return React__default.createElement(Labelled, {
14846 id: id,
14847 label: label,
14848 error: error,
14849 action: labelAction,
14850 labelHidden: labelHidden,
14851 helpText: helpText
14852 }, React__default.createElement("div", {
14853 className: className,
14854 style: cssVars
14855 }, prefixMarkup, React__default.createElement("div", {
14856 className: styles$1m.InputWrapper
14857 }, React__default.createElement("input", {
14858 type: "range",
14859 className: styles$1m.Input,
14860 id: id,
14861 name: id,
14862 min: min,
14863 max: max,
14864 step: step,
14865 value: clampedValue,
14866 disabled: disabled,
14867 onChange: handleChange,
14868 onFocus: onFocus,
14869 onBlur: onBlur,
14870 "aria-valuemin": min,
14871 "aria-valuemax": max,
14872 "aria-valuenow": clampedValue,
14873 "aria-invalid": Boolean(error),
14874 "aria-describedby": ariaDescribedBy
14875 }), outputMarkup), suffixMarkup));
14876
14877 function handleChange(event) {
14878 var onChange = props.onChange;
14879 onChange && onChange(parseFloat(event.currentTarget.value), id);
14880 }
14881}
14882
14883function RangeSlider(_a) {
14884 var _a$min = _a.min,
14885 min = _a$min === void 0 ? RangeSliderDefault.Min : _a$min,
14886 _a$max = _a.max,
14887 max = _a$max === void 0 ? RangeSliderDefault.Max : _a$max,
14888 _a$step = _a.step,
14889 step = _a$step === void 0 ? RangeSliderDefault.Step : _a$step,
14890 value = _a.value,
14891 rest = tslib_1.__rest(_a, ["min", "max", "step", "value"]);
14892
14893 var id = useUniqueId('RangeSlider');
14894 var sharedProps = Object.assign({
14895 id,
14896 min,
14897 max,
14898 step
14899 }, rest);
14900 return isDualThumb(value) ? React__default.createElement(DualThumb, Object.assign({
14901 value: value
14902 }, sharedProps)) : React__default.createElement(SingleThumb, Object.assign({
14903 value: value
14904 }, sharedProps));
14905}
14906
14907function isDualThumb(value) {
14908 return Array.isArray(value);
14909}
14910
14911var styles$1n = {
14912 "CheckboxWrapper": "Polaris-ResourceItem__CheckboxWrapper",
14913 "ResourceItem": "Polaris-ResourceItem",
14914 "persistActions": "Polaris-ResourceItem--persistActions",
14915 "Actions": "Polaris-ResourceItem__Actions",
14916 "selected": "Polaris-ResourceItem--selected",
14917 "focused": "Polaris-ResourceItem--focused",
14918 "focusedInner": "Polaris-ResourceItem--focusedInner",
14919 "Link": "Polaris-ResourceItem__Link",
14920 "Button": "Polaris-ResourceItem__Button",
14921 "Container": "Polaris-ResourceItem__Container",
14922 "Owned": "Polaris-ResourceItem__Owned",
14923 "Handle": "Polaris-ResourceItem__Handle",
14924 "selectMode": "Polaris-ResourceItem--selectMode",
14925 "selectable": "Polaris-ResourceItem--selectable",
14926 "Media": "Polaris-ResourceItem__Media",
14927 "Content": "Polaris-ResourceItem__Content",
14928 "Disclosure": "Polaris-ResourceItem__Disclosure"
14929};
14930
14931var getUniqueCheckboxID = other.createUniqueIDFactory('ResourceListItemCheckbox');
14932var getUniqueOverlayID = other.createUniqueIDFactory('ResourceListItemOverlay');
14933
14934var BaseResourceItem =
14935/*#__PURE__*/
14936function (_React$Component) {
14937 _inherits(BaseResourceItem, _React$Component);
14938
14939 function BaseResourceItem() {
14940 var _this;
14941
14942 _classCallCheck(this, BaseResourceItem);
14943
14944 _this = _possibleConstructorReturn(this, _getPrototypeOf(BaseResourceItem).apply(this, arguments));
14945 _this.state = {
14946 actionsMenuVisible: false,
14947 focused: false,
14948 focusedInner: false,
14949 selected: isSelected(_this.props.id, _this.props.context.selectedItems)
14950 };
14951 _this.node = null;
14952 _this.checkboxId = getUniqueCheckboxID();
14953 _this.overlayId = getUniqueOverlayID();
14954 _this.buttonOverlay = React__default.createRef();
14955
14956 _this.setNode = function (node) {
14957 _this.node = node;
14958 };
14959
14960 _this.handleFocus = function (event) {
14961 if (event.target === _this.buttonOverlay.current || _this.node && event.target === _this.node.querySelector("#".concat(_this.overlayId))) {
14962 _this.setState({
14963 focused: true,
14964 focusedInner: false
14965 });
14966 } else if (_this.node && _this.node.contains(event.target)) {
14967 _this.setState({
14968 focused: true,
14969 focusedInner: true
14970 });
14971 }
14972 };
14973
14974 _this.handleBlur = function (_ref) {
14975 var relatedTarget = _ref.relatedTarget;
14976
14977 if (_this.node && relatedTarget instanceof Element && _this.node.contains(relatedTarget)) {
14978 return;
14979 }
14980
14981 _this.setState({
14982 focused: false,
14983 focusedInner: false
14984 });
14985 };
14986
14987 _this.handleLargerSelectionArea = function (event) {
14988 stopPropagation$1(event);
14989
14990 _this.handleSelection(!_this.state.selected, event.nativeEvent.shiftKey);
14991 };
14992
14993 _this.handleSelection = function (value, shiftKey) {
14994 var _this$props = _this.props,
14995 id = _this$props.id,
14996 sortOrder = _this$props.sortOrder,
14997 onSelectionChange = _this$props.context.onSelectionChange;
14998
14999 if (id == null || onSelectionChange == null) {
15000 return;
15001 }
15002
15003 _this.setState({
15004 focused: value,
15005 focusedInner: value
15006 });
15007
15008 onSelectionChange(value, id, sortOrder, shiftKey);
15009 };
15010
15011 _this.handleClick = function (event) {
15012 stopPropagation$1(event);
15013 var _this$props2 = _this.props,
15014 id = _this$props2.id,
15015 onClick = _this$props2.onClick,
15016 url = _this$props2.url,
15017 selectMode = _this$props2.context.selectMode;
15018 var _event$nativeEvent = event.nativeEvent,
15019 ctrlKey = _event$nativeEvent.ctrlKey,
15020 metaKey = _event$nativeEvent.metaKey;
15021
15022 var anchor = _this.node && _this.node.querySelector('a');
15023
15024 if (selectMode) {
15025 _this.handleLargerSelectionArea(event);
15026
15027 return;
15028 }
15029
15030 if (anchor === event.target) {
15031 return;
15032 }
15033
15034 if (onClick) {
15035 onClick(id);
15036 }
15037
15038 if (url && (ctrlKey || metaKey)) {
15039 window.open(url, '_blank');
15040 return;
15041 }
15042
15043 if (url && anchor) {
15044 anchor.click();
15045 }
15046 }; // This fires onClick when there is a URL on the item
15047
15048
15049 _this.handleKeyUp = function (event) {
15050 var _this$props3 = _this.props,
15051 _this$props3$onClick = _this$props3.onClick,
15052 onClick = _this$props3$onClick === void 0 ? noop$b : _this$props3$onClick,
15053 selectMode = _this$props3.context.selectMode;
15054 var key = event.key;
15055
15056 if (key === 'Enter' && _this.props.url && !selectMode) {
15057 onClick();
15058 }
15059 };
15060
15061 _this.handleActionsClick = function () {
15062 _this.setState(function (_ref2) {
15063 var actionsMenuVisible = _ref2.actionsMenuVisible;
15064 return {
15065 actionsMenuVisible: !actionsMenuVisible
15066 };
15067 });
15068 };
15069
15070 _this.handleCloseRequest = function () {
15071 _this.setState({
15072 actionsMenuVisible: false
15073 });
15074 };
15075
15076 return _this;
15077 }
15078
15079 _createClass(BaseResourceItem, [{
15080 key: "shouldComponentUpdate",
15081 value: function shouldComponentUpdate(nextProps, nextState) {
15082 var _a = nextProps.context,
15083 nextSelectedItems = _a.selectedItems,
15084 restNextContext = tslib_1.__rest(_a, ["selectedItems"]),
15085 restNextProps = tslib_1.__rest(nextProps, ["context"]);
15086
15087 var _b = this.props,
15088 _c = _b.context,
15089 selectedItems = _c.selectedItems,
15090 restContext = tslib_1.__rest(_c, ["selectedItems"]),
15091 restProps = tslib_1.__rest(_b, ["context"]);
15092
15093 var nextSelectMode = nextProps.context.selectMode;
15094 return !isEqual(this.state, nextState) || this.props.context.selectMode !== nextSelectMode || !nextProps.context.selectMode && (!isEqual(restProps, restNextProps) || !isEqual(restContext, restNextContext));
15095 }
15096 }, {
15097 key: "render",
15098 value: function render() {
15099 var _this$props4 = this.props,
15100 children = _this$props4.children,
15101 url = _this$props4.url,
15102 external = _this$props4.external,
15103 media = _this$props4.media,
15104 shortcutActions = _this$props4.shortcutActions,
15105 ariaControls = _this$props4.ariaControls,
15106 ariaExpanded = _this$props4.ariaExpanded,
15107 _this$props4$persistA = _this$props4.persistActions,
15108 persistActions = _this$props4$persistA === void 0 ? false : _this$props4$persistA,
15109 accessibilityLabel = _this$props4.accessibilityLabel,
15110 name = _this$props4.name,
15111 _this$props4$context = _this$props4.context,
15112 selectable = _this$props4$context.selectable,
15113 selectMode = _this$props4$context.selectMode,
15114 loading = _this$props4$context.loading,
15115 resourceName = _this$props4$context.resourceName,
15116 i18n = _this$props4.i18n;
15117 var _this$state = this.state,
15118 actionsMenuVisible = _this$state.actionsMenuVisible,
15119 focused = _this$state.focused,
15120 focusedInner = _this$state.focusedInner,
15121 selected = _this$state.selected;
15122 var ownedMarkup = null;
15123 var handleMarkup = null;
15124 var mediaMarkup = media ? React__default.createElement("div", {
15125 className: styles$1n.Media
15126 }, media) : null;
15127
15128 if (selectable) {
15129 var checkboxAccessibilityLabel = name || accessibilityLabel || i18n.translate('Polaris.Common.checkbox');
15130 handleMarkup = React__default.createElement("div", {
15131 className: styles$1n.Handle,
15132 onClick: this.handleLargerSelectionArea
15133 }, React__default.createElement("div", {
15134 onClick: stopPropagation$1,
15135 className: styles$1n.CheckboxWrapper
15136 }, React__default.createElement("div", {
15137 onChange: this.handleLargerSelectionArea
15138 }, React__default.createElement(Checkbox$1, {
15139 id: this.checkboxId,
15140 label: checkboxAccessibilityLabel,
15141 labelHidden: true,
15142 checked: selected,
15143 disabled: loading
15144 }))));
15145 }
15146
15147 if (media || selectable) {
15148 ownedMarkup = React__default.createElement("div", {
15149 className: styles$1n.Owned
15150 }, handleMarkup, mediaMarkup);
15151 }
15152
15153 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);
15154 var actionsMarkup = null;
15155 var disclosureMarkup = null;
15156
15157 if (shortcutActions && !loading) {
15158 if (persistActions) {
15159 actionsMarkup = React__default.createElement("div", {
15160 className: styles$1n.Actions,
15161 onClick: stopPropagation$1
15162 }, React__default.createElement(ButtonGroup, null, buttonsFrom(shortcutActions, {
15163 plain: true
15164 })));
15165 var disclosureAccessibilityLabel = name ? i18n.translate('Polaris.ResourceList.Item.actionsDropdownLabel', {
15166 accessibilityLabel: name
15167 }) : i18n.translate('Polaris.ResourceList.Item.actionsDropdown');
15168 disclosureMarkup = React__default.createElement("div", {
15169 className: styles$1n.Disclosure,
15170 onClick: stopPropagation$1
15171 }, React__default.createElement(Popover, {
15172 activator: React__default.createElement(Button, {
15173 accessibilityLabel: disclosureAccessibilityLabel,
15174 onClick: this.handleActionsClick,
15175 plain: true,
15176 icon: polarisIcons.HorizontalDotsMinor
15177 }),
15178 onClose: this.handleCloseRequest,
15179 active: actionsMenuVisible
15180 }, React__default.createElement(ActionList, {
15181 items: shortcutActions
15182 })));
15183 } else {
15184 actionsMarkup = React__default.createElement("div", {
15185 className: styles$1n.Actions,
15186 onClick: stopPropagation$1
15187 }, React__default.createElement(ButtonGroup, {
15188 segmented: true
15189 }, buttonsFrom(shortcutActions, {
15190 size: 'slim'
15191 })));
15192 }
15193 }
15194
15195 var content = children ? React__default.createElement("div", {
15196 className: styles$1n.Content
15197 }, children) : null;
15198 var containerMarkup = React__default.createElement("div", {
15199 className: styles$1n.Container,
15200 id: this.props.id
15201 }, ownedMarkup, content, actionsMarkup, disclosureMarkup);
15202 var tabIndex = loading ? -1 : 0;
15203 var ariaLabel = accessibilityLabel || i18n.translate('Polaris.ResourceList.Item.viewItem', {
15204 itemName: name || resourceName && resourceName.singular || ''
15205 });
15206 var accessibleMarkup = url ? React__default.createElement(UnstyledLink, {
15207 "aria-describedby": this.props.id,
15208 "aria-label": ariaLabel,
15209 className: styles$1n.Link,
15210 url: url,
15211 external: external,
15212 tabIndex: tabIndex,
15213 id: this.overlayId
15214 }) : React__default.createElement("button", {
15215 className: styles$1n.Button,
15216 "aria-label": ariaLabel,
15217 "aria-controls": ariaControls,
15218 "aria-expanded": ariaExpanded,
15219 onClick: this.handleClick,
15220 tabIndex: tabIndex,
15221 ref: this.buttonOverlay
15222 });
15223 return React__default.createElement("div", {
15224 ref: this.setNode,
15225 className: className,
15226 onClick: this.handleClick,
15227 onFocus: this.handleFocus,
15228 onBlur: this.handleBlur,
15229 onKeyUp: this.handleKeyUp,
15230 "data-href": url
15231 }, accessibleMarkup, containerMarkup);
15232 }
15233 }], [{
15234 key: "getDerivedStateFromProps",
15235 value: function getDerivedStateFromProps(nextProps, prevState) {
15236 var selected = isSelected(nextProps.id, nextProps.context.selectedItems);
15237
15238 if (prevState.selected === selected) {
15239 return null;
15240 }
15241
15242 return {
15243 selected
15244 };
15245 }
15246 }]);
15247
15248 return BaseResourceItem;
15249}(React__default.Component);
15250
15251function noop$b() {}
15252
15253function stopPropagation$1(event) {
15254 event.stopPropagation();
15255}
15256
15257function isSelected(id, selectedItems) {
15258 return Boolean(selectedItems && (Array.isArray(selectedItems) && selectedItems.includes(id) || selectedItems === SELECT_ALL_ITEMS));
15259}
15260
15261function ResourceItem(props) {
15262 return React__default.createElement(BaseResourceItem, Object.assign({}, props, {
15263 context: React.useContext(ResourceListContext),
15264 i18n: useI18n()
15265 }));
15266}
15267
15268var Sticky =
15269/*#__PURE__*/
15270function (_React$Component) {
15271 _inherits(Sticky, _React$Component);
15272
15273 function Sticky() {
15274 var _this;
15275
15276 _classCallCheck(this, Sticky);
15277
15278 _this = _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
15279 _this.state = {
15280 isSticky: false,
15281 style: {}
15282 };
15283 _this.placeHolderNode = null;
15284 _this.stickyNode = null;
15285
15286 _this.setPlaceHolderNode = function (node) {
15287 _this.placeHolderNode = node;
15288 };
15289
15290 _this.setStickyNode = function (node) {
15291 _this.stickyNode = node;
15292 };
15293
15294 _this.handlePositioning = function (stick) {
15295 var top = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
15296 var left = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
15297 var width = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
15298 var isSticky = _this.state.isSticky;
15299
15300 if (stick && !isSticky || !stick && isSticky) {
15301 _this.adjustPlaceHolderNode(stick);
15302
15303 _this.setState({
15304 isSticky: !isSticky
15305 });
15306 }
15307
15308 var style = stick ? {
15309 position: 'fixed',
15310 top,
15311 left,
15312 width
15313 } : {};
15314
15315 _this.setState({
15316 style
15317 });
15318 };
15319
15320 _this.adjustPlaceHolderNode = function (add) {
15321 if (_this.placeHolderNode && _this.stickyNode) {
15322 _this.placeHolderNode.style.paddingBottom = add ? "".concat(geometry.getRectForNode(_this.stickyNode).height, "px") : '0px';
15323 }
15324 };
15325
15326 return _this;
15327 }
15328
15329 _createClass(Sticky, [{
15330 key: "componentDidMount",
15331 value: function componentDidMount() {
15332 var _this$props = this.props,
15333 boundingElement = _this$props.boundingElement,
15334 _this$props$offset = _this$props.offset,
15335 offset = _this$props$offset === void 0 ? false : _this$props$offset,
15336 _this$props$disableWh = _this$props.disableWhenStacked,
15337 disableWhenStacked = _this$props$disableWh === void 0 ? false : _this$props$disableWh,
15338 stickyManager = _this$props.polaris.stickyManager;
15339 if (!this.stickyNode || !this.placeHolderNode) return;
15340 stickyManager.registerStickyItem({
15341 stickyNode: this.stickyNode,
15342 placeHolderNode: this.placeHolderNode,
15343 handlePositioning: this.handlePositioning,
15344 offset,
15345 boundingElement,
15346 disableWhenStacked
15347 });
15348 }
15349 }, {
15350 key: "componentWillUnmount",
15351 value: function componentWillUnmount() {
15352 var stickyManager = this.props.polaris.stickyManager;
15353 if (!this.stickyNode) return;
15354 stickyManager.unregisterStickyItem(this.stickyNode);
15355 }
15356 }, {
15357 key: "render",
15358 value: function render() {
15359 var _this$state = this.state,
15360 style = _this$state.style,
15361 isSticky = _this$state.isSticky;
15362 var children = this.props.children;
15363 var childrenContent = isFunction(children) ? children(isSticky) : children;
15364 return React__default.createElement("div", null, React__default.createElement("div", {
15365 ref: this.setPlaceHolderNode
15366 }), React__default.createElement("div", {
15367 ref: this.setStickyNode,
15368 style: style
15369 }, childrenContent));
15370 }
15371 }]);
15372
15373 return Sticky;
15374}(React__default.Component);
15375
15376function isFunction(arg) {
15377 return typeof arg === 'function';
15378} // Use named export once withAppProvider is refactored away
15379// eslint-disable-next-line import/no-default-export
15380
15381
15382var Sticky$1 = withAppProvider()(Sticky);
15383
15384var styles$1o = {
15385 "Select": "Polaris-Select",
15386 "disabled": "Polaris-Select--disabled",
15387 "Content": "Polaris-Select__Content",
15388 "InlineLabel": "Polaris-Select__InlineLabel",
15389 "Icon": "Polaris-Select__Icon",
15390 "Backdrop": "Polaris-Select__Backdrop",
15391 "error": "Polaris-Select--error",
15392 "Input": "Polaris-Select__Input",
15393 "placeholder": "Polaris-Select--placeholder",
15394 "SelectedOption": "Polaris-Select__SelectedOption"
15395};
15396
15397var PLACEHOLDER_VALUE = '';
15398function Select(_ref) {
15399 var optionsProp = _ref.options,
15400 label = _ref.label,
15401 labelAction = _ref.labelAction,
15402 labelHiddenProp = _ref.labelHidden,
15403 labelInline = _ref.labelInline,
15404 disabled = _ref.disabled,
15405 helpText = _ref.helpText,
15406 placeholder = _ref.placeholder,
15407 idProp = _ref.id,
15408 name = _ref.name,
15409 _ref$value = _ref.value,
15410 value = _ref$value === void 0 ? PLACEHOLDER_VALUE : _ref$value,
15411 error = _ref.error,
15412 onChange = _ref.onChange,
15413 onFocus = _ref.onFocus,
15414 onBlur = _ref.onBlur;
15415 var id = useUniqueId('Select', idProp);
15416 var labelHidden = labelInline ? true : labelHiddenProp;
15417 var className = classNames(styles$1o.Select, error && styles$1o.error, disabled && styles$1o.disabled);
15418 var handleChange = onChange ? function (event) {
15419 return onChange(event.currentTarget.value, id);
15420 } : undefined;
15421 var describedBy = [];
15422
15423 if (helpText) {
15424 describedBy.push(helpTextID(id));
15425 }
15426
15427 if (error) {
15428 describedBy.push("".concat(id, "Error"));
15429 }
15430
15431 var options = optionsProp || [];
15432 var normalizedOptions = options.map(normalizeOption);
15433
15434 if (placeholder) {
15435 normalizedOptions = [{
15436 label: placeholder,
15437 value: PLACEHOLDER_VALUE,
15438 disabled: true
15439 }].concat(_toConsumableArray(normalizedOptions));
15440 }
15441
15442 var inlineLabelMarkup = labelInline && React__default.createElement("span", {
15443 className: styles$1o.InlineLabel
15444 }, label);
15445 var selectedOption = getSelectedOption(normalizedOptions, value);
15446 var contentMarkup = React__default.createElement("div", {
15447 className: styles$1o.Content,
15448 "aria-hidden": true,
15449 "aria-disabled": disabled
15450 }, inlineLabelMarkup, React__default.createElement("span", {
15451 className: styles$1o.SelectedOption
15452 }, selectedOption), React__default.createElement("span", {
15453 className: styles$1o.Icon
15454 }, React__default.createElement(Icon, {
15455 source: polarisIcons.ArrowUpDownMinor
15456 })));
15457 var optionsMarkup = normalizedOptions.map(renderOption);
15458 return React__default.createElement(Labelled, {
15459 id: id,
15460 label: label,
15461 error: error,
15462 action: labelAction,
15463 labelHidden: labelHidden,
15464 helpText: helpText
15465 }, React__default.createElement("div", {
15466 className: className
15467 }, React__default.createElement("select", {
15468 id: id,
15469 name: name,
15470 value: value,
15471 className: styles$1o.Input,
15472 disabled: disabled,
15473 onFocus: onFocus,
15474 onBlur: onBlur,
15475 onChange: handleChange,
15476 "aria-invalid": Boolean(error),
15477 "aria-describedby": describedBy.length ? describedBy.join(' ') : undefined
15478 }, optionsMarkup), contentMarkup, React__default.createElement("div", {
15479 className: styles$1o.Backdrop
15480 })));
15481}
15482
15483function isString(option) {
15484 return typeof option === 'string';
15485}
15486
15487function isGroup(option) {
15488 return option.options != null;
15489}
15490
15491function normalizeStringOption(option) {
15492 return {
15493 label: option,
15494 value: option
15495 };
15496}
15497/**
15498 * Converts a string option (and each string option in a Group) into
15499 * an Option object.
15500 */
15501
15502
15503function normalizeOption(option) {
15504 if (isString(option)) {
15505 return normalizeStringOption(option);
15506 } else if (isGroup(option)) {
15507 var title = option.title,
15508 options = option.options;
15509 return {
15510 title,
15511 options: options.map(function (option) {
15512 return isString(option) ? normalizeStringOption(option) : option;
15513 })
15514 };
15515 }
15516
15517 return option;
15518}
15519/**
15520 * Gets the text to display in the UI, for the currently selected option
15521 */
15522
15523
15524function getSelectedOption(options, value) {
15525 var flatOptions = flattenOptions(options);
15526 var selectedOption = flatOptions.find(function (option) {
15527 return value === option.value;
15528 });
15529
15530 if (selectedOption === undefined) {
15531 // Get the first visible option (not the hidden placeholder)
15532 selectedOption = flatOptions.find(function (option) {
15533 return !option.hidden;
15534 });
15535 }
15536
15537 return selectedOption ? selectedOption.label : '';
15538}
15539/**
15540 * Ungroups an options array
15541 */
15542
15543
15544function flattenOptions(options) {
15545 var flatOptions = [];
15546 options.forEach(function (optionOrGroup) {
15547 if (isGroup(optionOrGroup)) {
15548 flatOptions = flatOptions.concat(optionOrGroup.options);
15549 } else {
15550 flatOptions.push(optionOrGroup);
15551 }
15552 });
15553 return flatOptions;
15554}
15555
15556function renderSingleOption(option) {
15557 var value = option.value,
15558 label = option.label,
15559 rest = tslib_1.__rest(option, ["value", "label"]);
15560
15561 return React__default.createElement("option", Object.assign({
15562 key: value,
15563 value: value
15564 }, rest), label);
15565}
15566
15567function renderOption(optionOrGroup) {
15568 if (isGroup(optionOrGroup)) {
15569 var title = optionOrGroup.title,
15570 options = optionOrGroup.options;
15571 return React__default.createElement("optgroup", {
15572 label: title,
15573 key: title
15574 }, options.map(renderSingleOption));
15575 }
15576
15577 return renderSingleOption(optionOrGroup);
15578}
15579
15580var styles$1p = {
15581 "CheckableButton": "Polaris-ResourceList-CheckableButton",
15582 "globalTheming": "Polaris-ResourceList-CheckableButton--globalTheming",
15583 "CheckableButton-selectMode": "Polaris-ResourceList-CheckableButton__CheckableButton--selectMode",
15584 "CheckableButton-measuring": "Polaris-ResourceList-CheckableButton__CheckableButton--measuring",
15585 "CheckableButton-plain": "Polaris-ResourceList-CheckableButton__CheckableButton--plain",
15586 "CheckableButton-selected": "Polaris-ResourceList-CheckableButton__CheckableButton--selected",
15587 "Checkbox": "Polaris-ResourceList-CheckableButton__Checkbox",
15588 "Label": "Polaris-ResourceList-CheckableButton__Label"
15589};
15590
15591function CheckableButton(_ref) {
15592 var accessibilityLabel = _ref.accessibilityLabel,
15593 _ref$label = _ref.label,
15594 label = _ref$label === void 0 ? '' : _ref$label,
15595 onToggleAll = _ref.onToggleAll,
15596 selected = _ref.selected,
15597 selectMode = _ref.selectMode,
15598 plain = _ref.plain,
15599 measuring = _ref.measuring,
15600 disabled = _ref.disabled,
15601 smallScreen = _ref.smallScreen;
15602 var checkBoxRef = React.useRef(null);
15603
15604 var _useFeatures = useFeatures(),
15605 _useFeatures$unstable = _useFeatures.unstableGlobalTheming,
15606 unstableGlobalTheming = _useFeatures$unstable === void 0 ? false : _useFeatures$unstable;
15607
15608 var _React$useContext = React__default.useContext(ResourceListContext),
15609 registerCheckableButtons = _React$useContext.registerCheckableButtons;
15610
15611 var currentKey = 'bulkLg';
15612
15613 if (plain) {
15614 currentKey = 'plain';
15615 } else if (smallScreen) {
15616 currentKey = 'bulkSm';
15617 }
15618
15619 React.useEffect(function () {
15620 if (checkBoxRef.current && registerCheckableButtons) {
15621 registerCheckableButtons(currentKey, checkBoxRef.current);
15622 }
15623 }, [currentKey, registerCheckableButtons]);
15624 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']);
15625 return React__default.createElement("div", {
15626 className: className,
15627 onClick: onToggleAll
15628 }, React__default.createElement("div", {
15629 className: styles$1p.Checkbox
15630 }, React__default.createElement(Checkbox$1, {
15631 label: accessibilityLabel,
15632 labelHidden: true,
15633 checked: selected,
15634 disabled: disabled,
15635 onChange: onToggleAll,
15636 ref: checkBoxRef
15637 })), React__default.createElement("span", {
15638 className: styles$1p.Label
15639 }, label));
15640}
15641
15642var styles$1q = {
15643 "Group": "Polaris-ResourceList-BulkActions__Group",
15644 "Group-measuring": "Polaris-ResourceList-BulkActions__Group--measuring",
15645 "Group-entering": "Polaris-ResourceList-BulkActions__Group--entering",
15646 "Group-exiting": "Polaris-ResourceList-BulkActions__Group--exiting",
15647 "Group-entered": "Polaris-ResourceList-BulkActions__Group--entered",
15648 "Group-exited": "Polaris-ResourceList-BulkActions__Group--exited",
15649 "Group-smallScreen": "Polaris-ResourceList-BulkActions__Group--smallScreen",
15650 "Group-largeScreen": "Polaris-ResourceList-BulkActions__Group--largeScreen",
15651 "ButtonGroupWrapper": "Polaris-ResourceList-BulkActions__ButtonGroupWrapper",
15652 "BulkActionButton": "Polaris-ResourceList-BulkActions__BulkActionButton",
15653 "CheckableContainer": "Polaris-ResourceList-BulkActions__CheckableContainer",
15654 "disabled": "Polaris-ResourceList-BulkActions--disabled",
15655 "globalTheming": "Polaris-ResourceList-BulkActions--globalTheming",
15656 "PaginatedSelectAll": "Polaris-ResourceList-BulkActions__PaginatedSelectAll",
15657 "Slide": "Polaris-ResourceList-BulkActions__Slide",
15658 "Slide-appear": "Polaris-ResourceList-BulkActions__Slide--appear",
15659 "Slide-enter": "Polaris-ResourceList-BulkActions__Slide--enter",
15660 "Slide-exit": "Polaris-ResourceList-BulkActions__Slide--exit",
15661 "Slide-appearing": "Polaris-ResourceList-BulkActions__Slide--appearing",
15662 "Slide-entering": "Polaris-ResourceList-BulkActions__Slide--entering"
15663};
15664
15665var BulkActionButton =
15666/*#__PURE__*/
15667function (_React$PureComponent) {
15668 _inherits(BulkActionButton, _React$PureComponent);
15669
15670 function BulkActionButton() {
15671 var _this;
15672
15673 _classCallCheck(this, BulkActionButton);
15674
15675 _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkActionButton).apply(this, arguments));
15676 _this.bulkActionButton = React.createRef();
15677 return _this;
15678 }
15679
15680 _createClass(BulkActionButton, [{
15681 key: "componentDidMount",
15682 value: function componentDidMount() {
15683 var handleMeasurement = this.props.handleMeasurement;
15684
15685 if (handleMeasurement && this.bulkActionButton.current) {
15686 var width = this.bulkActionButton.current.getBoundingClientRect().width;
15687 handleMeasurement(width);
15688 }
15689 }
15690 }, {
15691 key: "render",
15692 value: function render() {
15693 var _this$props = this.props,
15694 url = _this$props.url,
15695 external = _this$props.external,
15696 onAction = _this$props.onAction,
15697 content = _this$props.content,
15698 disclosure = _this$props.disclosure,
15699 accessibilityLabel = _this$props.accessibilityLabel,
15700 disabled = _this$props.disabled;
15701 return React__default.createElement("div", {
15702 className: styles$1q.BulkActionButton,
15703 ref: this.bulkActionButton
15704 }, React__default.createElement(Button, {
15705 external: external,
15706 url: url,
15707 "aria-label": accessibilityLabel,
15708 onClick: onAction,
15709 disabled: disabled,
15710 disclosure: disclosure
15711 }, content));
15712 }
15713 }]);
15714
15715 return BulkActionButton;
15716}(React__default.PureComponent);
15717
15718var MAX_PROMOTED_ACTIONS = 2;
15719var slideClasses = {
15720 appear: classNames(styles$1q.Slide, styles$1q['Slide-appear']),
15721 appearActive: classNames(styles$1q.Slide, styles$1q['Slide-appearing']),
15722 enter: classNames(styles$1q.Slide, styles$1q['Slide-enter']),
15723 enterActive: classNames(styles$1q.Slide, styles$1q['Slide-entering']),
15724 exit: classNames(styles$1q.Slide, styles$1q['Slide-exit'])
15725};
15726
15727var BulkActions =
15728/*#__PURE__*/
15729function (_React$PureComponent) {
15730 _inherits(BulkActions, _React$PureComponent);
15731
15732 function BulkActions() {
15733 var _this;
15734
15735 _classCallCheck(this, BulkActions);
15736
15737 _this = _possibleConstructorReturn(this, _getPrototypeOf(BulkActions).apply(this, arguments));
15738 _this.state = {
15739 smallScreenPopoverVisible: false,
15740 largeScreenPopoverVisible: false,
15741 containerWidth: 0,
15742 measuring: true
15743 };
15744 _this.checkableWrapperNode = React.createRef();
15745 _this.largeScreenGroupNode = React.createRef();
15746 _this.smallScreenGroupNode = React.createRef();
15747 _this.promotedActionsWidths = [];
15748 _this.bulkActionsWidth = 0;
15749 _this.addedMoreActionsWidthForMeasuring = 0;
15750 _this.handleResize = debounce(function () {
15751 var _this$state = _this.state,
15752 smallScreenPopoverVisible = _this$state.smallScreenPopoverVisible,
15753 largeScreenPopoverVisible = _this$state.largeScreenPopoverVisible;
15754
15755 if (_this.containerNode) {
15756 var containerWidth = _this.containerNode.getBoundingClientRect().width;
15757
15758 if (containerWidth > 0) {
15759 _this.setState({
15760 containerWidth
15761 });
15762 }
15763 }
15764
15765 if (smallScreenPopoverVisible || largeScreenPopoverVisible) {
15766 _this.setState({
15767 smallScreenPopoverVisible: false,
15768 largeScreenPopoverVisible: false
15769 });
15770 }
15771 }, 50, {
15772 trailing: true
15773 });
15774
15775 _this.setLargeScreenButtonsNode = function (node) {
15776 _this.largeScreenButtonsNode = node;
15777 };
15778
15779 _this.setContainerNode = function (node) {
15780 _this.containerNode = node;
15781 };
15782
15783 _this.setMoreActionsNode = function (node) {
15784 _this.moreActionsNode = node;
15785 };
15786
15787 _this.setSelectMode = function (val) {
15788 var onSelectModeToggle = _this.props.onSelectModeToggle;
15789
15790 if (onSelectModeToggle) {
15791 onSelectModeToggle(val);
15792 }
15793 };
15794
15795 _this.toggleSmallScreenPopover = function () {
15796 _this.setState(function (_ref) {
15797 var smallScreenPopoverVisible = _ref.smallScreenPopoverVisible;
15798 return {
15799 smallScreenPopoverVisible: !smallScreenPopoverVisible
15800 };
15801 });
15802 };
15803
15804 _this.toggleLargeScreenPopover = function () {
15805 _this.setState(function (_ref2) {
15806 var largeScreenPopoverVisible = _ref2.largeScreenPopoverVisible;
15807 return {
15808 largeScreenPopoverVisible: !largeScreenPopoverVisible
15809 };
15810 });
15811 };
15812
15813 _this.handleMeasurement = function (width) {
15814 var measuring = _this.state.measuring;
15815
15816 if (measuring) {
15817 _this.promotedActionsWidths.push(width);
15818 }
15819 };
15820
15821 _this.findLargeScreenGroupNode = function () {
15822 return _this.largeScreenGroupNode.current;
15823 };
15824
15825 _this.findCheckableWrapperNode = function () {
15826 return _this.checkableWrapperNode.current;
15827 };
15828
15829 _this.findSmallScreenGroupNode = function () {
15830 return _this.smallScreenGroupNode.current;
15831 };
15832
15833 return _this;
15834 }
15835
15836 _createClass(BulkActions, [{
15837 key: "componentDidMount",
15838 value: function componentDidMount() {
15839 var _this$props = this.props,
15840 actions = _this$props.actions,
15841 promotedActions = _this$props.promotedActions;
15842
15843 if (promotedActions && !actions && this.moreActionsNode) {
15844 this.addedMoreActionsWidthForMeasuring = this.moreActionsNode.getBoundingClientRect().width;
15845 }
15846
15847 this.bulkActionsWidth = this.largeScreenButtonsNode ? this.largeScreenButtonsNode.getBoundingClientRect().width - this.addedMoreActionsWidthForMeasuring : 0;
15848
15849 if (this.containerNode) {
15850 this.setState({
15851 containerWidth: this.containerNode.getBoundingClientRect().width,
15852 measuring: false
15853 });
15854 }
15855 }
15856 }, {
15857 key: "render",
15858 value: function render() {
15859 var _this2 = this;
15860
15861 var _this$props2 = this.props,
15862 selectMode = _this$props2.selectMode,
15863 accessibilityLabel = _this$props2.accessibilityLabel,
15864 _this$props2$label = _this$props2.label,
15865 label = _this$props2$label === void 0 ? '' : _this$props2$label,
15866 onToggleAll = _this$props2.onToggleAll,
15867 selected = _this$props2.selected,
15868 smallScreen = _this$props2.smallScreen,
15869 disabled = _this$props2.disabled,
15870 promotedActions = _this$props2.promotedActions,
15871 _this$props2$paginate = _this$props2.paginatedSelectAllText,
15872 paginatedSelectAllText = _this$props2$paginate === void 0 ? null : _this$props2$paginate,
15873 paginatedSelectAllAction = _this$props2.paginatedSelectAllAction,
15874 intl = _this$props2.polaris.intl;
15875
15876 if (promotedActions && promotedActions.length > MAX_PROMOTED_ACTIONS) {
15877 // eslint-disable-next-line no-console
15878 console.warn(intl.translate('Polaris.ResourceList.BulkActions.warningMessage', {
15879 maxPromotedActions: MAX_PROMOTED_ACTIONS
15880 }));
15881 }
15882
15883 var _this$state2 = this.state,
15884 smallScreenPopoverVisible = _this$state2.smallScreenPopoverVisible,
15885 largeScreenPopoverVisible = _this$state2.largeScreenPopoverVisible,
15886 measuring = _this$state2.measuring;
15887 var paginatedSelectAllActionMarkup = paginatedSelectAllAction ? React__default.createElement(Button, {
15888 onClick: paginatedSelectAllAction.onAction,
15889 plain: true,
15890 disabled: disabled
15891 }, paginatedSelectAllAction.content) : null;
15892 var paginatedSelectAllTextMarkup = paginatedSelectAllText && paginatedSelectAllAction ? React__default.createElement("span", {
15893 "aria-live": "polite"
15894 }, paginatedSelectAllText) : paginatedSelectAllText;
15895 var paginatedSelectAllMarkup = paginatedSelectAllActionMarkup || paginatedSelectAllTextMarkup ? React__default.createElement("div", {
15896 className: styles$1q.PaginatedSelectAll
15897 }, paginatedSelectAllTextMarkup, " ", paginatedSelectAllActionMarkup) : null;
15898 var cancelButton = React__default.createElement(Button, {
15899 onClick: this.setSelectMode.bind(this, false),
15900 disabled: disabled
15901 }, intl.translate('Polaris.Common.cancel'));
15902 var numberOfPromotedActionsToRender = this.numberOfPromotedActionsToRender;
15903 var allActionsPopover = this.hasActions ? React__default.createElement("div", {
15904 className: styles$1q.Popover,
15905 ref: this.setMoreActionsNode
15906 }, React__default.createElement(Popover, {
15907 active: smallScreenPopoverVisible,
15908 activator: React__default.createElement(BulkActionButton, {
15909 disclosure: true,
15910 onAction: this.toggleSmallScreenPopover,
15911 content: intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel'),
15912 disabled: disabled
15913 }),
15914 onClose: this.toggleSmallScreenPopover
15915 }, React__default.createElement(ActionList, {
15916 items: promotedActions,
15917 sections: this.actionSections,
15918 onActionAnyItem: this.toggleSmallScreenPopover
15919 }))) : null;
15920 var promotedActionsMarkup = promotedActions && numberOfPromotedActionsToRender > 0 ? _toConsumableArray(promotedActions).slice(0, numberOfPromotedActionsToRender).map(function (action, index) {
15921 return React__default.createElement(BulkActionButton, Object.assign({
15922 disabled: disabled
15923 }, action, {
15924 key: index,
15925 handleMeasurement: _this2.handleMeasurement
15926 }));
15927 }) : null;
15928 var rolledInPromotedActions = promotedActions && numberOfPromotedActionsToRender < promotedActions.length ? _toConsumableArray(promotedActions).slice(numberOfPromotedActionsToRender) : [];
15929 var activatorLabel = !promotedActions || promotedActions && numberOfPromotedActionsToRender === 0 && !measuring ? intl.translate('Polaris.ResourceList.BulkActions.actionsActivatorLabel') : intl.translate('Polaris.ResourceList.BulkActions.moreActionsActivatorLabel');
15930 var combinedActions = [];
15931
15932 if (this.actionSections && rolledInPromotedActions.length > 0) {
15933 combinedActions = [{
15934 items: rolledInPromotedActions
15935 }].concat(_toConsumableArray(this.actionSections));
15936 } else if (this.actionSections) {
15937 combinedActions = this.actionSections;
15938 } else if (rolledInPromotedActions.length > 0) {
15939 combinedActions = [{
15940 items: rolledInPromotedActions
15941 }];
15942 }
15943
15944 var actionsPopover = this.actionSections || rolledInPromotedActions.length > 0 || measuring ? React__default.createElement("div", {
15945 className: styles$1q.Popover,
15946 ref: this.setMoreActionsNode
15947 }, React__default.createElement(Popover, {
15948 active: largeScreenPopoverVisible,
15949 activator: React__default.createElement(BulkActionButton, {
15950 disclosure: true,
15951 onAction: this.toggleLargeScreenPopover,
15952 content: activatorLabel,
15953 disabled: disabled
15954 }),
15955 onClose: this.toggleLargeScreenPopover
15956 }, React__default.createElement(ActionList, {
15957 sections: combinedActions,
15958 onActionAnyItem: this.toggleLargeScreenPopover
15959 }))) : null;
15960 var checkableButtonProps = {
15961 accessibilityLabel,
15962 label,
15963 selected,
15964 selectMode,
15965 onToggleAll,
15966 measuring,
15967 disabled
15968 };
15969 var smallScreenGroup = smallScreen ? React__default.createElement(reactTransitionGroup.Transition, {
15970 timeout: 0,
15971 in: selectMode,
15972 key: "smallGroup",
15973 findDOMNode: this.findSmallScreenGroupNode
15974 }, function (status) {
15975 var smallScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-smallScreen'], styles$1q["Group-".concat(status)]);
15976 return React__default.createElement("div", {
15977 className: smallScreenGroupClassName,
15978 ref: _this2.smallScreenGroupNode
15979 }, React__default.createElement("div", {
15980 className: styles$1q.ButtonGroupWrapper
15981 }, React__default.createElement(ButtonGroup, {
15982 segmented: true
15983 }, React__default.createElement(reactTransitionGroup.CSSTransition, {
15984 findDOMNode: _this2.findCheckableWrapperNode,
15985 in: selectMode,
15986 timeout: tokens.durationBase,
15987 classNames: slideClasses,
15988 appear: !selectMode
15989 }, React__default.createElement("div", {
15990 className: styles$1q.CheckableContainer,
15991 ref: _this2.checkableWrapperNode
15992 }, React__default.createElement(CheckableButton, Object.assign({}, checkableButtonProps, {
15993 smallScreen: true
15994 })))), allActionsPopover, cancelButton)), paginatedSelectAllMarkup);
15995 }) : null;
15996 var largeGroupContent = promotedActionsMarkup || actionsPopover ? React__default.createElement(ButtonGroup, {
15997 segmented: true
15998 }, React__default.createElement(CheckableButton, checkableButtonProps), promotedActionsMarkup, actionsPopover) : React__default.createElement(CheckableButton, checkableButtonProps);
15999 var largeScreenGroup = smallScreen ? null : React__default.createElement(reactTransitionGroup.Transition, {
16000 timeout: 0,
16001 in: selectMode,
16002 key: "largeGroup",
16003 findDOMNode: this.findLargeScreenGroupNode
16004 }, function (status) {
16005 var largeScreenGroupClassName = classNames(styles$1q.Group, styles$1q['Group-largeScreen'], !measuring && styles$1q["Group-".concat(status)], measuring && styles$1q['Group-measuring']);
16006 return React__default.createElement("div", {
16007 className: largeScreenGroupClassName,
16008 ref: _this2.largeScreenGroupNode
16009 }, React__default.createElement(EventListener, {
16010 event: "resize",
16011 handler: _this2.handleResize
16012 }), React__default.createElement("div", {
16013 className: styles$1q.ButtonGroupWrapper,
16014 ref: _this2.setLargeScreenButtonsNode
16015 }, largeGroupContent), paginatedSelectAllMarkup);
16016 });
16017 return React__default.createElement("div", {
16018 ref: this.setContainerNode
16019 }, smallScreenGroup, largeScreenGroup);
16020 }
16021 }, {
16022 key: "numberOfPromotedActionsToRender",
16023 get: function get() {
16024 var promotedActions = this.props.promotedActions;
16025 var _this$state3 = this.state,
16026 containerWidth = _this$state3.containerWidth,
16027 measuring = _this$state3.measuring;
16028
16029 if (!promotedActions) {
16030 return 0;
16031 }
16032
16033 if (containerWidth >= this.bulkActionsWidth || measuring) {
16034 return promotedActions.length;
16035 }
16036
16037 var sufficientSpace = false;
16038 var counter = promotedActions.length - 1;
16039 var totalWidth = 0;
16040
16041 while (!sufficientSpace && counter >= 0) {
16042 totalWidth += this.promotedActionsWidths[counter];
16043 var widthWithRemovedAction = this.bulkActionsWidth - totalWidth + this.addedMoreActionsWidthForMeasuring;
16044
16045 if (containerWidth >= widthWithRemovedAction) {
16046 sufficientSpace = true;
16047 } else {
16048 counter--;
16049 }
16050 }
16051
16052 return counter;
16053 }
16054 }, {
16055 key: "hasActions",
16056 get: function get() {
16057 var _this$props3 = this.props,
16058 promotedActions = _this$props3.promotedActions,
16059 actions = _this$props3.actions;
16060 return Boolean(promotedActions && promotedActions.length > 0 || actions && actions.length > 0);
16061 }
16062 }, {
16063 key: "actionSections",
16064 get: function get() {
16065 var actions = this.props.actions;
16066
16067 if (!actions || actions.length === 0) {
16068 return;
16069 }
16070
16071 if (instanceOfBulkActionListSectionArray(actions)) {
16072 return actions;
16073 }
16074
16075 if (instanceOfBulkActionArray(actions)) {
16076 return [{
16077 items: actions
16078 }];
16079 }
16080 }
16081 }]);
16082
16083 return BulkActions;
16084}(React__default.PureComponent);
16085
16086function instanceOfBulkActionListSectionArray(actions) {
16087 var validList = actions.filter(function (action) {
16088 return action.items;
16089 });
16090 return actions.length === validList.length;
16091}
16092
16093function instanceOfBulkActionArray(actions) {
16094 var validList = actions.filter(function (action) {
16095 return !action.items;
16096 });
16097 return actions.length === validList.length;
16098} // Use named export once withAppProvider is refactored away
16099// eslint-disable-next-line import/no-default-export
16100
16101
16102var BulkActions$1 = withAppProvider()(BulkActions);
16103
16104var styles$1r = {
16105 "DateTextField": "Polaris-FilterControl-DateSelector__DateTextField",
16106 "DatePicker": "Polaris-FilterControl-DateSelector__DatePicker"
16107};
16108
16109var VALID_DATE_REGEX = /^\d{4}-\d{1,2}-\d{1,2}$/;
16110var DateFilterOption;
16111
16112(function (DateFilterOption) {
16113 DateFilterOption["PastWeek"] = "past_week";
16114 DateFilterOption["PastMonth"] = "past_month";
16115 DateFilterOption["PastQuarter"] = "past_quarter";
16116 DateFilterOption["PastYear"] = "past_year";
16117 DateFilterOption["ComingWeek"] = "coming_week";
16118 DateFilterOption["ComingMonth"] = "coming_month";
16119 DateFilterOption["ComingQuarter"] = "coming_quarter";
16120 DateFilterOption["ComingYear"] = "coming_year";
16121 DateFilterOption["OnOrBefore"] = "on_or_before";
16122 DateFilterOption["OnOrAfter"] = "on_or_after";
16123})(DateFilterOption || (DateFilterOption = {}));
16124
16125var DateSelector = React.memo(function DateSelector(_ref) {
16126 var filterValue = _ref.filterValue,
16127 filterKey = _ref.filterKey,
16128 filterMinKey = _ref.filterMinKey,
16129 filterMaxKey = _ref.filterMaxKey,
16130 dateOptionType = _ref.dateOptionType,
16131 onFilterValueChange = _ref.onFilterValueChange,
16132 onFilterKeyChange = _ref.onFilterKeyChange;
16133 var now = new Date();
16134 var i18n = useI18n();
16135 var initialConsumerFilterKey = React.useRef(filterKey);
16136
16137 var _useState = React.useState(now.getMonth()),
16138 _useState2 = _slicedToArray(_useState, 2),
16139 datePickerMonth = _useState2[0],
16140 setDatePickerMonth = _useState2[1];
16141
16142 var _useState3 = React.useState(now.getFullYear()),
16143 _useState4 = _slicedToArray(_useState3, 2),
16144 datePickerYear = _useState4[0],
16145 setDatePickerYear = _useState4[1];
16146
16147 var _useState5 = React.useState(),
16148 _useState6 = _slicedToArray(_useState5, 2),
16149 selectedDate = _useState6[0],
16150 setSelectedDate = _useState6[1];
16151
16152 var _useState7 = React.useState(),
16153 _useState8 = _slicedToArray(_useState7, 2),
16154 userInputDate = _useState8[0],
16155 setUserInputDate = _useState8[1];
16156
16157 var _useState9 = React.useState(),
16158 _useState10 = _slicedToArray(_useState9, 2),
16159 userInputDateError = _useState10[0],
16160 setUserInputDateError = _useState10[1];
16161
16162 var dateTextFieldValue = getDateTextFieldValue();
16163 var handleDateFieldChange = React.useCallback(function (value) {
16164 if (value.length === 0) {
16165 setSelectedDate(undefined);
16166 onFilterValueChange(undefined);
16167 }
16168
16169 if (userInputDateError && isValidDate(value)) {
16170 setUserInputDateError(undefined);
16171 }
16172
16173 setUserInputDate(value);
16174 }, [onFilterValueChange, userInputDateError]);
16175 var handleDateChanged = React.useCallback(function (date) {
16176 if (!date) {
16177 return;
16178 }
16179
16180 onFilterValueChange(stripTimeFromISOString(formatDateForLocalTimezone(date)));
16181 }, [onFilterValueChange]);
16182 var handleDateBlur = React.useCallback(function () {
16183 if (!dateTextFieldValue || !isValidDate(dateTextFieldValue)) {
16184 setSelectedDate(undefined);
16185 setUserInputDateError(i18n.translate('Polaris.ResourceList.DateSelector.dateValueError'));
16186 onFilterValueChange(undefined);
16187 return;
16188 }
16189
16190 if (!userInputDate) {
16191 return;
16192 }
16193
16194 var formattedDateForTimezone = new Date(formatDateForLocalTimezone(new Date(userInputDate)));
16195 setSelectedDate(formattedDateForTimezone);
16196 setDatePickerMonth(formattedDateForTimezone.getMonth());
16197 setDatePickerYear(formattedDateForTimezone.getFullYear());
16198 setUserInputDate(undefined);
16199 setUserInputDateError(undefined);
16200 handleDateChanged(formattedDateForTimezone);
16201 }, [dateTextFieldValue, handleDateChanged, i18n, onFilterValueChange, userInputDate]);
16202 var handleDateFilterOptionsChange = React.useCallback(function (newOption) {
16203 if (!initialConsumerFilterKey.current) {
16204 return;
16205 }
16206
16207 if (newOption === DateFilterOption.OnOrBefore) {
16208 onFilterKeyChange(filterMaxKey);
16209 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
16210 return;
16211 }
16212
16213 if (newOption === DateFilterOption.OnOrAfter) {
16214 onFilterKeyChange(filterMinKey);
16215 onFilterValueChange(selectedDate ? stripTimeFromISOString(formatDateForLocalTimezone(selectedDate)) : undefined);
16216 return;
16217 }
16218
16219 onFilterKeyChange(initialConsumerFilterKey.current);
16220 onFilterValueChange(newOption);
16221 }, [filterMaxKey, filterMinKey, initialConsumerFilterKey, onFilterKeyChange, onFilterValueChange, selectedDate]);
16222 var handleDatePickerChange = React.useCallback(function (_ref2) {
16223 var nextDate = _ref2.end;
16224 var date = new Date(nextDate);
16225 setSelectedDate(date);
16226 setUserInputDate(undefined);
16227 setUserInputDateError(undefined);
16228 handleDateChanged(date);
16229 }, [handleDateChanged]);
16230 var handleDatePickerMonthChange = React.useCallback(function (month, year) {
16231 setDatePickerMonth(month);
16232 setDatePickerYear(year);
16233 }, []);
16234 var dateFilterOption = getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey);
16235 var showDatePredicate = dateFilterOption === DateFilterOption.OnOrBefore || dateFilterOption === DateFilterOption.OnOrAfter;
16236 var datePredicateMarkup = showDatePredicate && React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
16237 className: styles$1r.DateTextField
16238 }, React__default.createElement(TextField, {
16239 label: i18n.translate('Polaris.ResourceList.DateSelector.dateValueLabel'),
16240 placeholder: i18n.translate('Polaris.ResourceList.DateSelector.dateValuePlaceholder'),
16241 value: dateTextFieldValue,
16242 error: userInputDateError,
16243 prefix: React__default.createElement(Icon, {
16244 source: polarisIcons.CalendarMinor,
16245 color: "skyDark"
16246 }),
16247 autoComplete: false,
16248 onChange: handleDateFieldChange,
16249 onBlur: handleDateBlur
16250 })), React__default.createElement("div", {
16251 className: styles$1r.DatePicker
16252 }, React__default.createElement(DatePicker, {
16253 selected: selectedDate,
16254 month: datePickerMonth,
16255 year: datePickerYear,
16256 onChange: handleDatePickerChange,
16257 onMonthChange: handleDatePickerMonthChange
16258 })));
16259 var dateOptionTypes = {
16260 past: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateComparatorOptions())),
16261 future: [].concat(_toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions())),
16262 full: [].concat(_toConsumableArray(getDatePastOptions()), _toConsumableArray(getDateFutureOptions()), _toConsumableArray(getDateComparatorOptions()))
16263 };
16264 return React__default.createElement(React__default.Fragment, null, React__default.createElement(Select, {
16265 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.dateFilterLabel'),
16266 labelHidden: true,
16267 options: dateOptionType ? dateOptionTypes[dateOptionType] : dateOptionTypes.full,
16268 placeholder: i18n.translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
16269 value: dateFilterOption,
16270 onChange: handleDateFilterOptionsChange
16271 }), datePredicateMarkup);
16272
16273 function getDateComparatorOptions() {
16274 return [{
16275 value: DateFilterOption.OnOrBefore,
16276 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrBefore')
16277 }, {
16278 value: DateFilterOption.OnOrAfter,
16279 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.OnOrAfter')
16280 }];
16281 }
16282
16283 function getDatePastOptions() {
16284 return [{
16285 value: DateFilterOption.PastWeek,
16286 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastWeek')
16287 }, {
16288 value: DateFilterOption.PastMonth,
16289 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastMonth')
16290 }, {
16291 value: DateFilterOption.PastQuarter,
16292 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastQuarter')
16293 }, {
16294 value: DateFilterOption.PastYear,
16295 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.PastYear')
16296 }];
16297 }
16298
16299 function getDateFutureOptions() {
16300 return [{
16301 value: DateFilterOption.ComingWeek,
16302 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingWeek')
16303 }, {
16304 value: DateFilterOption.ComingMonth,
16305 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingMonth')
16306 }, {
16307 value: DateFilterOption.ComingQuarter,
16308 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingQuarter')
16309 }, {
16310 value: DateFilterOption.ComingYear,
16311 label: i18n.translate('Polaris.ResourceList.DateSelector.SelectOptions.ComingYear')
16312 }];
16313 }
16314
16315 function getDateTextFieldValue() {
16316 if (!userInputDate && !selectedDate) {
16317 return undefined;
16318 }
16319
16320 if (userInputDate !== undefined) {
16321 return userInputDate;
16322 }
16323
16324 if (selectedDate) {
16325 return stripTimeFromISOString(formatDateForLocalTimezone(selectedDate));
16326 }
16327 }
16328});
16329
16330function isValidDate(date) {
16331 if (!date) {
16332 return false;
16333 }
16334
16335 return VALID_DATE_REGEX.test(date) && !isNaN(new Date(date).getTime());
16336}
16337
16338function getDateFilterOption(filterValue, filterKey, filterMinKey, filterMaxKey) {
16339 if (filterKey === filterMaxKey) {
16340 return DateFilterOption.OnOrBefore;
16341 }
16342
16343 if (filterKey === filterMinKey) {
16344 return DateFilterOption.OnOrAfter;
16345 }
16346
16347 return filterValue;
16348}
16349
16350function stripTimeFromISOString(ISOString) {
16351 return ISOString.slice(0, 10);
16352}
16353
16354function formatDateForLocalTimezone(date) {
16355 var timezoneOffset = date.getTimezoneOffset();
16356 var timezoneOffsetMs = timezoneOffset * 60 * 1000;
16357 var isFringeTimezone = timezoneOffset === -720 || timezoneOffset === 720;
16358 var formattedDate = new Date();
16359
16360 if (isFringeTimezone && date.getHours() !== 0) {
16361 return date.toISOString();
16362 }
16363
16364 var newTime = timezoneOffset > -1 ? date.getTime() + timezoneOffsetMs : date.getTime() - timezoneOffsetMs;
16365 formattedDate.setTime(newTime);
16366 return formattedDate.toISOString();
16367}
16368
16369(function (FilterType) {
16370 FilterType[FilterType["Select"] = 0] = "Select";
16371 FilterType[FilterType["TextField"] = 1] = "TextField";
16372 FilterType[FilterType["DateSelector"] = 2] = "DateSelector";
16373})(exports.FilterType || (exports.FilterType = {}));
16374
16375/**
16376 * Returns a MutatableRefObject containing a boolean value that
16377 * represents a components mounted status.
16378 * @returns MutableRefObject<boolean> The mounted status
16379 */
16380
16381function useIsMountedRef() {
16382 var isMounted = React.useRef(false);
16383 React.useEffect(function () {
16384 isMounted.current = true;
16385 return function () {
16386 isMounted.current = false;
16387 };
16388 }, []);
16389 return isMounted;
16390}
16391
16392function FilterValueSelector(_ref) {
16393 var filter = _ref.filter,
16394 filterKey = _ref.filterKey,
16395 value = _ref.value,
16396 onChange = _ref.onChange,
16397 onFilterKeyChange = _ref.onFilterKeyChange;
16398
16399 var _useI18n = useI18n(),
16400 translate = _useI18n.translate;
16401
16402 var isMounted = useIsMountedRef();
16403 var operatorText = filter.operatorText,
16404 type = filter.type,
16405 label = filter.label;
16406 var showOperatorOptions = type !== exports.FilterType.DateSelector && operatorText && typeof operatorText !== 'string';
16407 var handleOperatorOptionChange = React.useCallback(function (operatorKey) {
16408 onFilterKeyChange(operatorKey);
16409
16410 if (!value) {
16411 return;
16412 }
16413
16414 onChange(value);
16415 }, [onChange, onFilterKeyChange, value]);
16416
16417 if (showOperatorOptions && operatorText.length !== 0 && !isMounted.current) {
16418 handleOperatorOptionChange(operatorText[0].key);
16419 }
16420
16421 var operatorOptionsMarkup = showOperatorOptions ? React__default.createElement(Select, {
16422 label: label,
16423 labelHidden: true,
16424 options: buildOperatorOptions(operatorText),
16425 value: filterKey,
16426 onChange: handleOperatorOptionChange
16427 }) : null;
16428 var selectedFilterLabel = typeof operatorText === 'string' ? operatorText : '';
16429
16430 switch (filter.type) {
16431 case exports.FilterType.Select:
16432 return React__default.createElement(Stack, {
16433 vertical: true
16434 }, operatorOptionsMarkup, React__default.createElement(Select, {
16435 label: selectedFilterLabel,
16436 options: filter.options,
16437 placeholder: translate('Polaris.ResourceList.FilterValueSelector.selectFilterValuePlaceholder'),
16438 value: value,
16439 onChange: onChange
16440 }));
16441
16442 case exports.FilterType.TextField:
16443 return React__default.createElement(Stack, {
16444 vertical: true
16445 }, operatorOptionsMarkup, React__default.createElement(TextField, {
16446 label: selectedFilterLabel,
16447 value: value,
16448 type: filter.textFieldType,
16449 onChange: onChange
16450 }));
16451
16452 case exports.FilterType.DateSelector:
16453 return React__default.createElement(DateSelector, {
16454 dateOptionType: filter.dateOptionType,
16455 filterValue: value,
16456 filterKey: filterKey,
16457 filterMinKey: filter.minKey,
16458 filterMaxKey: filter.maxKey,
16459 onFilterValueChange: onChange,
16460 onFilterKeyChange: onFilterKeyChange
16461 });
16462
16463 default:
16464 return null;
16465 }
16466}
16467
16468function buildOperatorOptions(operatorText) {
16469 if (!operatorText || typeof operatorText === 'string') {
16470 return [];
16471 }
16472
16473 return operatorText.map(function (_ref2) {
16474 var key = _ref2.key,
16475 optionLabel = _ref2.optionLabel;
16476 return {
16477 value: key,
16478 label: optionLabel
16479 };
16480 });
16481}
16482
16483function FilterCreator(_ref) {
16484 var filters = _ref.filters,
16485 resourceName = _ref.resourceName,
16486 disabled = _ref.disabled,
16487 onAddFilter = _ref.onAddFilter;
16488
16489 var _useForcibleToggle = useForcibleToggle(false),
16490 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
16491 popoverActive = _useForcibleToggle2[0],
16492 _useForcibleToggle2$ = _useForcibleToggle2[1],
16493 togglePopoverActive = _useForcibleToggle2$.toggle,
16494 setPopoverActiveFalse = _useForcibleToggle2$.forceFalse;
16495
16496 var _useState = React.useState(),
16497 _useState2 = _slicedToArray(_useState, 2),
16498 selectedFilter = _useState2[0],
16499 setSelectedFilter = _useState2[1];
16500
16501 var _useState3 = React.useState(),
16502 _useState4 = _slicedToArray(_useState3, 2),
16503 selectedFilterKey = _useState4[0],
16504 setSelectedFilterKey = _useState4[1];
16505
16506 var _useState5 = React.useState(),
16507 _useState6 = _slicedToArray(_useState5, 2),
16508 selectedFilterValue = _useState6[0],
16509 setSelectedFilterValue = _useState6[1];
16510
16511 var i18n = useI18n();
16512 var node = React.useRef(null);
16513 var canAddFilter = Boolean(selectedFilter && selectedFilterKey && selectedFilterValue);
16514 var handleButtonFocus = React.useCallback(function () {
16515 var event = arguments.length <= 0 ? undefined : arguments[0];
16516
16517 if (!node.current && event) {
16518 // https://github.com/DefinitelyTyped/DefinitelyTyped/issues/31065
16519 node.current = event.target;
16520 }
16521 }, []);
16522 var handleFilterKeyChange = React.useCallback(function (filterKey) {
16523 var foundFilter = filters.find(function (filter) {
16524 var minKey = filter.minKey,
16525 maxKey = filter.maxKey,
16526 operatorText = filter.operatorText;
16527
16528 if (minKey || maxKey) {
16529 return filter.key === filterKey || minKey === filterKey || maxKey === filterKey;
16530 }
16531
16532 if (operatorText && typeof operatorText !== 'string') {
16533 return filter.key === filterKey || operatorText.filter(function (_ref2) {
16534 var key = _ref2.key;
16535 return key === filterKey;
16536 }).length === 1;
16537 }
16538
16539 return filter.key === filterKey;
16540 });
16541
16542 if (!foundFilter) {
16543 return;
16544 }
16545
16546 setSelectedFilter(foundFilter);
16547 setSelectedFilterKey(filterKey);
16548 setSelectedFilterValue(undefined);
16549 }, [filters]);
16550 var handleFilterValueChange = React.useCallback(function (value) {
16551 setSelectedFilterValue(value);
16552 }, []);
16553 var handleAddFilter = React.useCallback(function () {
16554 if (!onAddFilter || !canAddFilter || !selectedFilterKey) {
16555 return;
16556 }
16557
16558 onAddFilter({
16559 key: selectedFilterKey,
16560 value: selectedFilterValue || ''
16561 });
16562 setPopoverActiveFalse();
16563 setSelectedFilter(undefined);
16564 setSelectedFilterValue(undefined);
16565
16566 if (node.current != null) {
16567 node.current.focus();
16568 }
16569 }, [canAddFilter, onAddFilter, selectedFilterKey, selectedFilterValue, setPopoverActiveFalse]);
16570 var activator = React__default.createElement(Button, {
16571 onClick: togglePopoverActive,
16572 disclosure: true,
16573 disabled: disabled,
16574 onFocus: handleButtonFocus
16575 }, i18n.translate('Polaris.ResourceList.FilterCreator.filterButtonLabel'));
16576 var filterOptions = filters.map(function (_ref3) {
16577 var key = _ref3.key,
16578 label = _ref3.label;
16579 return {
16580 value: key,
16581 label
16582 };
16583 });
16584 var filterValueSelectionMarkup = selectedFilter ? React__default.createElement(FilterValueSelector, {
16585 filter: selectedFilter,
16586 filterKey: selectedFilterKey,
16587 value: selectedFilterValue,
16588 onFilterKeyChange: handleFilterKeyChange,
16589 onChange: handleFilterValueChange
16590 }) : null;
16591 var addFilterButtonMarkup = selectedFilter ? React__default.createElement(Button, {
16592 onClick: handleAddFilter,
16593 disabled: !canAddFilter
16594 }, i18n.translate('Polaris.ResourceList.FilterCreator.addFilterButtonLabel')) : null;
16595 return React__default.createElement(Popover, {
16596 active: popoverActive,
16597 activator: activator,
16598 onClose: togglePopoverActive,
16599 sectioned: true,
16600 fullHeight: true
16601 }, React__default.createElement(Form, {
16602 onSubmit: handleAddFilter
16603 }, React__default.createElement(FormLayout, null, React__default.createElement(Select, {
16604 label: i18n.translate('Polaris.ResourceList.FilterCreator.showAllWhere', {
16605 resourceNamePlural: resourceName.plural.toLocaleLowerCase()
16606 }),
16607 placeholder: i18n.translate('Polaris.ResourceList.FilterCreator.selectFilterKeyPlaceholder'),
16608 options: filterOptions,
16609 onChange: handleFilterKeyChange,
16610 value: selectedFilter && selectedFilter.key
16611 }), filterValueSelectionMarkup, addFilterButtonMarkup)));
16612}
16613
16614var styles$1s = {
16615 "AppliedFilters": "Polaris-ResourceList-FilterControl__AppliedFilters",
16616 "AppliedFilter": "Polaris-ResourceList-FilterControl__AppliedFilter"
16617};
16618
16619/** @deprecated Use <Filters /> instead. */
16620
16621function FilterControl(_ref) {
16622 var searchValue = _ref.searchValue,
16623 _ref$appliedFilters = _ref.appliedFilters,
16624 appliedFilters = _ref$appliedFilters === void 0 ? [] : _ref$appliedFilters,
16625 additionalAction = _ref.additionalAction,
16626 _ref$focused = _ref.focused,
16627 focused = _ref$focused === void 0 ? false : _ref$focused,
16628 _ref$filters = _ref.filters,
16629 filters = _ref$filters === void 0 ? [] : _ref$filters,
16630 placeholder = _ref.placeholder,
16631 onSearchBlur = _ref.onSearchBlur,
16632 onSearchChange = _ref.onSearchChange,
16633 onFiltersChange = _ref.onFiltersChange;
16634 // eslint-disable-next-line no-console
16635 console.warn('Deprecation: <FilterControl /> is deprecated. Use <Filters /> instead.');
16636 var i18n = useI18n();
16637
16638 var _React$useContext = React__default.useContext(ResourceListContext),
16639 selectMode = _React$useContext.selectMode,
16640 resourceName = _React$useContext.resourceName;
16641
16642 var filterResourceName = resourceName || {
16643 singular: i18n.translate('Polaris.ResourceList.defaultItemSingular'),
16644 plural: i18n.translate('Polaris.ResourceList.defaultItemPlural')
16645 };
16646 var handleAddFilter = React__default.useCallback(function (newFilter) {
16647 if (!onFiltersChange) {
16648 return;
16649 }
16650
16651 var foundFilter = appliedFilters.find(function (appliedFilter) {
16652 return idFromFilter(appliedFilter) === idFromFilter(newFilter);
16653 });
16654
16655 if (foundFilter) {
16656 return;
16657 }
16658
16659 var newAppliedFilters = [].concat(_toConsumableArray(appliedFilters), [newFilter]);
16660 onFiltersChange(newAppliedFilters);
16661 }, [onFiltersChange, appliedFilters]);
16662 var handleRemoveFilter = React__default.useCallback(function (filterId) {
16663 if (!onFiltersChange) {
16664 return;
16665 }
16666
16667 var foundIndex = appliedFilters.findIndex(function (appliedFilter) {
16668 return idFromFilter(appliedFilter) === filterId;
16669 });
16670 var newAppliedFilters = foundIndex >= 0 ? [].concat(_toConsumableArray(appliedFilters.slice(0, foundIndex)), _toConsumableArray(appliedFilters.slice(foundIndex + 1, appliedFilters.length))) : _toConsumableArray(appliedFilters);
16671 onFiltersChange(newAppliedFilters);
16672 }, [appliedFilters, onFiltersChange]);
16673 var getRemoveFilterCallback = React__default.useCallback(function (filterId) {
16674 return function () {
16675 handleRemoveFilter(filterId);
16676 };
16677 }, [handleRemoveFilter]);
16678 var textFieldLabel = placeholder ? placeholder : i18n.translate('Polaris.ResourceList.FilterControl.textFieldLabel', {
16679 resourceNamePlural: filterResourceName.plural.toLocaleLowerCase()
16680 });
16681
16682 if (additionalAction) {
16683 additionalAction.disabled = selectMode;
16684 }
16685
16686 var additionalActionButton = additionalAction && buttonsFrom(additionalAction) || null;
16687 var filterCreatorMarkup = filters.length > 0 ? React__default.createElement(FilterCreator, {
16688 resourceName: filterResourceName,
16689 filters: filters,
16690 onAddFilter: handleAddFilter,
16691 disabled: selectMode
16692 }) : null;
16693 var appliedFiltersMarkup = appliedFilters.map(function (appliedFilter) {
16694 var activeFilterLabel = getFilterLabel(appliedFilter);
16695 var filterId = idFromFilter(appliedFilter);
16696 return React__default.createElement("li", {
16697 className: styles$1s.AppliedFilter,
16698 key: filterId
16699 }, React__default.createElement(Tag, {
16700 onRemove: getRemoveFilterCallback(filterId),
16701 disabled: selectMode
16702 }, activeFilterLabel));
16703 });
16704 var appliedFiltersWrapper = appliedFilters.length > 0 ? React__default.createElement("ul", {
16705 className: styles$1s.AppliedFilters
16706 }, appliedFiltersMarkup) : null;
16707 return React__default.createElement(FormLayout, null, React__default.createElement(TextField, {
16708 connectedLeft: filterCreatorMarkup,
16709 connectedRight: additionalActionButton,
16710 label: textFieldLabel,
16711 labelHidden: true,
16712 placeholder: textFieldLabel,
16713 prefix: React__default.createElement(Icon, {
16714 source: polarisIcons.SearchMinor,
16715 color: "skyDark"
16716 }),
16717 value: searchValue,
16718 onChange: onSearchChange,
16719 onBlur: onSearchBlur,
16720 focused: focused,
16721 disabled: selectMode
16722 }), appliedFiltersWrapper);
16723
16724 function getFilterLabel(appliedFilter) {
16725 var key = appliedFilter.key,
16726 value = appliedFilter.value,
16727 label = appliedFilter.label;
16728
16729 if (label) {
16730 return label;
16731 }
16732
16733 var filter = filters.find(function (filter) {
16734 var minKey = filter.minKey,
16735 maxKey = filter.maxKey,
16736 operatorText = filter.operatorText;
16737
16738 if (minKey || maxKey) {
16739 return filter.key === key || minKey === key || maxKey === key;
16740 }
16741
16742 if (operatorText && typeof operatorText !== 'string') {
16743 return filter.key === key || operatorText.filter(function (_ref2) {
16744 var operatorKey = _ref2.key;
16745 return operatorKey === key;
16746 }).length === 1;
16747 }
16748
16749 return filter.key === key;
16750 });
16751
16752 if (!filter) {
16753 return value;
16754 }
16755
16756 var filterOperatorLabel = findOperatorLabel(filter, appliedFilter);
16757 var filterLabelByType = findFilterLabelByType(filter, appliedFilter);
16758
16759 if (!filterOperatorLabel) {
16760 return "".concat(filter.label, " ").concat(filterLabelByType);
16761 }
16762
16763 return "".concat(filter.label, " ").concat(filterOperatorLabel, " ").concat(filterLabelByType);
16764 }
16765
16766 function findFilterLabelByType(filter, appliedFilter) {
16767 var appliedFilterValue = appliedFilter.value;
16768
16769 if (filter.type === exports.FilterType.Select) {
16770 var foundFilterOption = filter.options.find(function (option) {
16771 return typeof option === 'string' ? option === appliedFilterValue : option.value === appliedFilterValue;
16772 });
16773
16774 if (foundFilterOption) {
16775 return typeof foundFilterOption === 'string' ? foundFilterOption : foundFilterOption.label;
16776 }
16777 }
16778
16779 if (filter.type === exports.FilterType.DateSelector) {
16780 if (filter.key === appliedFilter.key) {
16781 var filterLabelKey = "Polaris.ResourceList.DateSelector.FilterLabelForValue.".concat(appliedFilter.value);
16782 return i18n.translationKeyExists(filterLabelKey) ? i18n.translate(filterLabelKey) : appliedFilter.value;
16783 }
16784
16785 if (appliedFilter.key === filter.maxKey) {
16786 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_before', {
16787 date: formatDateForLabelDisplay(appliedFilter.value)
16788 });
16789 }
16790
16791 if (appliedFilter.key === filter.minKey) {
16792 return i18n.translate('Polaris.ResourceList.DateSelector.FilterLabelForValue.on_or_after', {
16793 date: formatDateForLabelDisplay(appliedFilter.value)
16794 });
16795 }
16796 }
16797
16798 return appliedFilterValue;
16799 }
16800}
16801
16802function idFromFilter(appliedFilter) {
16803 return "".concat(appliedFilter.key, "-").concat(appliedFilter.value);
16804}
16805
16806function formatDateForLabelDisplay(date) {
16807 if (isNaN(new Date(date).getTime())) {
16808 return date;
16809 }
16810
16811 return new Date(date.replace(/-/g, '/')).toLocaleDateString();
16812}
16813
16814function findOperatorLabel(filter, appliedFilter) {
16815 var operatorText = filter.operatorText;
16816
16817 if (filter.type === exports.FilterType.DateSelector && (appliedFilter.key === filter.minKey || appliedFilter.key === filter.maxKey)) {
16818 return '';
16819 }
16820
16821 if (!operatorText || typeof operatorText === 'string') {
16822 return operatorText;
16823 }
16824
16825 var appliedOperator = operatorText.find(function (operator) {
16826 return operator.key === appliedFilter.key;
16827 });
16828
16829 if (appliedOperator) {
16830 return appliedOperator.filterLabel || appliedOperator.optionLabel;
16831 }
16832}
16833
16834var styles$1t = {
16835 "FiltersWrapper": "Polaris-ResourceList__FiltersWrapper",
16836 "ResourceList": "Polaris-ResourceList",
16837 "HeaderOuterWrapper": "Polaris-ResourceList__HeaderOuterWrapper",
16838 "HeaderWrapper-disabled": "Polaris-ResourceList__HeaderWrapper--disabled",
16839 "HeaderWrapper-overlay": "Polaris-ResourceList__HeaderWrapper--overlay",
16840 "HeaderWrapper": "Polaris-ResourceList__HeaderWrapper",
16841 "HeaderWrapper-isSticky": "Polaris-ResourceList__HeaderWrapper--isSticky",
16842 "HeaderContentWrapper": "Polaris-ResourceList__HeaderContentWrapper",
16843 "HeaderWrapper-inSelectMode": "Polaris-ResourceList__HeaderWrapper--inSelectMode",
16844 "SortWrapper": "Polaris-ResourceList__SortWrapper",
16845 "AlternateToolWrapper": "Polaris-ResourceList__AlternateToolWrapper",
16846 "HeaderWrapper-hasSelect": "Polaris-ResourceList__HeaderWrapper--hasSelect",
16847 "HeaderWrapper-hasAlternateTool": "Polaris-ResourceList__HeaderWrapper--hasAlternateTool",
16848 "HeaderWrapper-hasSort": "Polaris-ResourceList__HeaderWrapper--hasSort",
16849 "HeaderTitleWrapper": "Polaris-ResourceList__HeaderTitleWrapper",
16850 "BulkActionsWrapper": "Polaris-ResourceList__BulkActionsWrapper",
16851 "CheckableButtonWrapper": "Polaris-ResourceList__CheckableButtonWrapper",
16852 "SelectButtonWrapper": "Polaris-ResourceList__SelectButtonWrapper",
16853 "EmptySearchResultWrapper": "Polaris-ResourceList__EmptySearchResultWrapper",
16854 "ResourceListWrapper": "Polaris-ResourceList__ResourceListWrapper",
16855 "ItemWrapper": "Polaris-ResourceList__ItemWrapper",
16856 "ItemWrapper-isLoading": "Polaris-ResourceList__ItemWrapper--isLoading",
16857 "SpinnerContainer": "Polaris-ResourceList__SpinnerContainer",
16858 "LoadingOverlay": "Polaris-ResourceList__LoadingOverlay",
16859 "DisabledPointerEvents": "Polaris-ResourceList__DisabledPointerEvents",
16860 "disableTextSelection": "Polaris-ResourceList--disableTextSelection"
16861};
16862
16863var SMALL_SCREEN_WIDTH = 458;
16864var SMALL_SPINNER_HEIGHT = 28;
16865var LARGE_SPINNER_HEIGHT = 45;
16866
16867var ResourceList =
16868/*#__PURE__*/
16869function (_React$Component) {
16870 _inherits(ResourceList, _React$Component);
16871
16872 function ResourceList(props) {
16873 var _this;
16874
16875 _classCallCheck(this, ResourceList);
16876
16877 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourceList).call(this, props));
16878 _this.listRef = React__default.createRef();
16879 _this.handleResize = debounce(function () {
16880 var selectedItems = _this.props.selectedItems;
16881 var _this$state = _this.state,
16882 selectMode = _this$state.selectMode,
16883 smallScreen = _this$state.smallScreen;
16884 var newSmallScreen = isSmallScreen();
16885
16886 if (selectedItems && selectedItems.length === 0 && selectMode && !newSmallScreen) {
16887 _this.handleSelectMode(false);
16888 }
16889
16890 if (smallScreen !== newSmallScreen) {
16891 _this.setState({
16892 smallScreen: newSmallScreen
16893 });
16894 }
16895 }, 50, {
16896 leading: true,
16897 trailing: true,
16898 maxWait: 50
16899 });
16900
16901 _this.setLoadingPosition = function () {
16902 if (_this.listRef.current != null) {
16903 if (typeof window === 'undefined') {
16904 return;
16905 }
16906
16907 var overlay = _this.listRef.current.getBoundingClientRect();
16908
16909 var viewportHeight = Math.max(document.documentElement ? document.documentElement.clientHeight : 0, window.innerHeight || 0);
16910 var overflow = viewportHeight - overlay.height;
16911 var spinnerHeight = _this.props.items.length === 1 ? SMALL_SPINNER_HEIGHT : LARGE_SPINNER_HEIGHT;
16912 var spinnerPosition = overflow > 0 ? (overlay.height - spinnerHeight) / 2 : (viewportHeight - overlay.top - spinnerHeight) / 2;
16913
16914 _this.setState({
16915 loadingPosition: spinnerPosition
16916 });
16917 }
16918 };
16919
16920 _this.handleSelectAllItemsInStore = function () {
16921 var _this$props = _this.props,
16922 onSelectionChange = _this$props.onSelectionChange,
16923 selectedItems = _this$props.selectedItems,
16924 items = _this$props.items,
16925 _this$props$idForItem = _this$props.idForItem,
16926 idForItem = _this$props$idForItem === void 0 ? defaultIdForItem : _this$props$idForItem;
16927 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : SELECT_ALL_ITEMS;
16928
16929 if (onSelectionChange) {
16930 onSelectionChange(newlySelectedItems);
16931 }
16932 };
16933
16934 _this.renderItem = function (item, index) {
16935 var _this$props2 = _this.props,
16936 renderItem = _this$props2.renderItem,
16937 _this$props2$idForIte = _this$props2.idForItem,
16938 idForItem = _this$props2$idForIte === void 0 ? defaultIdForItem : _this$props2$idForIte;
16939 var id = idForItem(item, index);
16940 return React__default.createElement("li", {
16941 key: id,
16942 className: styles$1t.ItemWrapper
16943 }, renderItem(item, id, index));
16944 };
16945
16946 _this.handleMultiSelectionChange = function (lastSelected, currentSelected, resolveItemId) {
16947 var min = Math.min(lastSelected, currentSelected);
16948 var max = Math.max(lastSelected, currentSelected);
16949 return _this.props.items.slice(min, max + 1).map(resolveItemId);
16950 };
16951
16952 _this.handleCheckableButtonRegistration = function (key, button) {
16953 _this.setState(function (_ref) {
16954 var checkableButtons = _ref.checkableButtons;
16955 return {
16956 checkableButtons: new Map(checkableButtons).set(key, button)
16957 };
16958 });
16959 };
16960
16961 _this.handleSelectionChange = function (selected, id, sortOrder, shiftKey) {
16962 var _this$props3 = _this.props,
16963 onSelectionChange = _this$props3.onSelectionChange,
16964 selectedItems = _this$props3.selectedItems,
16965 items = _this$props3.items,
16966 _this$props3$idForIte = _this$props3.idForItem,
16967 idForItem = _this$props3$idForIte === void 0 ? defaultIdForItem : _this$props3$idForIte,
16968 resolveItemId = _this$props3.resolveItemId;
16969 var lastSelected = _this.state.lastSelected;
16970
16971 if (selectedItems == null || onSelectionChange == null) {
16972 return;
16973 }
16974
16975 var newlySelectedItems = selectedItems === SELECT_ALL_ITEMS ? getAllItemsOnPage(items, idForItem) : _toConsumableArray(selectedItems);
16976
16977 if (sortOrder !== undefined) {
16978 _this.setState({
16979 lastSelected: sortOrder
16980 });
16981 }
16982
16983 var selectedIds = [id];
16984
16985 if (shiftKey && lastSelected != null && sortOrder !== undefined && resolveItemId) {
16986 selectedIds = _this.handleMultiSelectionChange(lastSelected, sortOrder, resolveItemId);
16987 }
16988
16989 newlySelectedItems = _toConsumableArray(new Set([].concat(_toConsumableArray(newlySelectedItems), _toConsumableArray(selectedIds))));
16990
16991 if (!selected) {
16992 var _iteratorNormalCompletion = true;
16993 var _didIteratorError = false;
16994 var _iteratorError = undefined;
16995
16996 try {
16997 for (var _iterator = selectedIds[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
16998 var selectedId = _step.value;
16999 newlySelectedItems.splice(newlySelectedItems.indexOf(selectedId), 1);
17000 }
17001 } catch (err) {
17002 _didIteratorError = true;
17003 _iteratorError = err;
17004 } finally {
17005 try {
17006 if (!_iteratorNormalCompletion && _iterator.return != null) {
17007 _iterator.return();
17008 }
17009 } finally {
17010 if (_didIteratorError) {
17011 throw _iteratorError;
17012 }
17013 }
17014 }
17015 }
17016
17017 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
17018 _this.handleSelectMode(false);
17019 } else if (newlySelectedItems.length > 0) {
17020 _this.handleSelectMode(true);
17021 }
17022
17023 if (onSelectionChange) {
17024 onSelectionChange(newlySelectedItems);
17025 }
17026 };
17027
17028 _this.handleSelectMode = function (selectMode) {
17029 var onSelectionChange = _this.props.onSelectionChange;
17030
17031 _this.setState({
17032 selectMode
17033 });
17034
17035 if (!selectMode && onSelectionChange) {
17036 onSelectionChange([]);
17037 }
17038 };
17039
17040 _this.handleToggleAll = function () {
17041 var _this$props4 = _this.props,
17042 onSelectionChange = _this$props4.onSelectionChange,
17043 selectedItems = _this$props4.selectedItems,
17044 items = _this$props4.items,
17045 _this$props4$idForIte = _this$props4.idForItem,
17046 idForItem = _this$props4$idForIte === void 0 ? defaultIdForItem : _this$props4$idForIte;
17047 var checkableButtons = _this.state.checkableButtons;
17048 var newlySelectedItems = [];
17049
17050 if (Array.isArray(selectedItems) && selectedItems.length === items.length || selectedItems === SELECT_ALL_ITEMS) {
17051 newlySelectedItems = [];
17052 } else {
17053 newlySelectedItems = items.map(function (item, index) {
17054 var id = idForItem(item, index);
17055 return id;
17056 });
17057 }
17058
17059 if (newlySelectedItems.length === 0 && !isSmallScreen()) {
17060 _this.handleSelectMode(false);
17061 } else if (newlySelectedItems.length > 0) {
17062 _this.handleSelectMode(true);
17063 }
17064
17065 var checkbox;
17066
17067 if (isSmallScreen()) {
17068 checkbox = checkableButtons.get('bulkSm');
17069 } else if (newlySelectedItems.length === 0) {
17070 checkbox = checkableButtons.get('plain');
17071 } else {
17072 checkbox = checkableButtons.get('bulkLg');
17073 }
17074
17075 if (onSelectionChange) {
17076 onSelectionChange(newlySelectedItems);
17077 } // setTimeout ensures execution after the Transition on BulkActions
17078
17079
17080 setTimeout(function () {
17081 checkbox && checkbox.focus();
17082 }, 0);
17083 };
17084
17085 var selectedItems = props.selectedItems,
17086 intl = props.polaris.intl;
17087 _this.defaultResourceName = {
17088 singular: intl.translate('Polaris.ResourceList.defaultItemSingular'),
17089 plural: intl.translate('Polaris.ResourceList.defaultItemPlural')
17090 }; // eslint-disable-next-line react/state-in-constructor
17091
17092 _this.state = {
17093 selectMode: Boolean(selectedItems && selectedItems.length > 0),
17094 loadingPosition: 0,
17095 lastSelected: null,
17096 smallScreen: isSmallScreen(),
17097 checkableButtons: new Map()
17098 };
17099 return _this;
17100 }
17101
17102 _createClass(ResourceList, [{
17103 key: "componentDidMount",
17104 value: function componentDidMount() {
17105 this.forceUpdate();
17106
17107 if (this.props.loading) {
17108 this.setLoadingPosition();
17109 }
17110 }
17111 }, {
17112 key: "componentDidUpdate",
17113 value: function componentDidUpdate(_ref2) {
17114 var prevLoading = _ref2.loading,
17115 prevItems = _ref2.items,
17116 prevSelectedItems = _ref2.selectedItems;
17117 var _this$props5 = this.props,
17118 selectedItems = _this$props5.selectedItems,
17119 loading = _this$props5.loading;
17120
17121 if (this.listRef.current && this.itemsExist() && !this.itemsExist(prevItems)) {
17122 this.forceUpdate();
17123 }
17124
17125 if (loading && !prevLoading) {
17126 this.setLoadingPosition();
17127 }
17128
17129 if (selectedItems && selectedItems.length > 0 && !this.state.selectMode) {
17130 // eslint-disable-next-line react/no-did-update-set-state
17131 this.setState({
17132 selectMode: true
17133 });
17134 return;
17135 }
17136
17137 if (prevSelectedItems && prevSelectedItems.length > 0 && (!selectedItems || selectedItems.length === 0) && !isSmallScreen()) {
17138 // eslint-disable-next-line react/no-did-update-set-state
17139 this.setState({
17140 selectMode: false
17141 });
17142 }
17143 }
17144 }, {
17145 key: "render",
17146 value: function render() {
17147 var _this2 = this;
17148
17149 var _this$props6 = this.props,
17150 items = _this$props6.items,
17151 promotedBulkActions = _this$props6.promotedBulkActions,
17152 bulkActions = _this$props6.bulkActions,
17153 filterControl = _this$props6.filterControl,
17154 loading = _this$props6.loading,
17155 _this$props6$showHead = _this$props6.showHeader,
17156 showHeader = _this$props6$showHead === void 0 ? false : _this$props6$showHead,
17157 sortOptions = _this$props6.sortOptions,
17158 sortValue = _this$props6.sortValue,
17159 alternateTool = _this$props6.alternateTool,
17160 selectedItems = _this$props6.selectedItems,
17161 _this$props6$resource = _this$props6.resourceName,
17162 resourceName = _this$props6$resource === void 0 ? this.defaultResourceName : _this$props6$resource,
17163 onSortChange = _this$props6.onSortChange,
17164 intl = _this$props6.polaris.intl;
17165 var _this$state2 = this.state,
17166 selectMode = _this$state2.selectMode,
17167 loadingPosition = _this$state2.loadingPosition,
17168 smallScreen = _this$state2.smallScreen;
17169 var filterControlMarkup = filterControl ? React__default.createElement("div", {
17170 className: styles$1t.FiltersWrapper
17171 }, filterControl) : null;
17172 var bulkActionsMarkup = this.selectable ? React__default.createElement("div", {
17173 className: styles$1t.BulkActionsWrapper
17174 }, React__default.createElement(BulkActions$1, {
17175 label: this.bulkActionsLabel,
17176 accessibilityLabel: this.bulkActionsAccessibilityLabel,
17177 selected: this.bulkSelectState,
17178 onToggleAll: this.handleToggleAll,
17179 selectMode: selectMode,
17180 onSelectModeToggle: this.handleSelectMode,
17181 promotedActions: promotedBulkActions,
17182 paginatedSelectAllAction: this.paginatedSelectAllAction,
17183 paginatedSelectAllText: this.paginatedSelectAllText,
17184 actions: bulkActions,
17185 disabled: loading,
17186 smallScreen: smallScreen
17187 })) : null;
17188 var sortingSelectMarkup = sortOptions && sortOptions.length > 0 && !alternateTool ? React__default.createElement("div", {
17189 className: styles$1t.SortWrapper
17190 }, React__default.createElement(Select, {
17191 label: intl.translate('Polaris.ResourceList.sortingLabel'),
17192 labelInline: !smallScreen,
17193 labelHidden: smallScreen,
17194 options: sortOptions,
17195 onChange: onSortChange,
17196 value: sortValue,
17197 disabled: selectMode
17198 })) : null;
17199 var alternateToolMarkup = alternateTool && !sortingSelectMarkup ? React__default.createElement("div", {
17200 className: styles$1t.AlternateToolWrapper
17201 }, alternateTool) : null;
17202 var headerTitleMarkup = React__default.createElement("div", {
17203 className: styles$1t.HeaderTitleWrapper
17204 }, this.headerTitle);
17205 var selectButtonMarkup = this.selectable ? React__default.createElement("div", {
17206 className: styles$1t.SelectButtonWrapper
17207 }, React__default.createElement(Button, {
17208 disabled: selectMode,
17209 icon: polarisIcons.EnableSelectionMinor,
17210 onClick: this.handleSelectMode.bind(this, true)
17211 }, intl.translate('Polaris.ResourceList.selectButtonText'))) : null;
17212 var checkableButtonMarkup = this.selectable ? React__default.createElement("div", {
17213 className: styles$1t.CheckableButtonWrapper
17214 }, React__default.createElement(CheckableButton, {
17215 accessibilityLabel: this.bulkActionsAccessibilityLabel,
17216 label: this.headerTitle,
17217 onToggleAll: this.handleToggleAll,
17218 plain: true,
17219 disabled: loading
17220 })) : null;
17221 var needsHeader = this.selectable || sortOptions && sortOptions.length > 0 || alternateTool;
17222 var headerWrapperOverlay = loading ? React__default.createElement("div", {
17223 className: styles$1t['HeaderWrapper-overlay']
17224 }) : null;
17225 var showEmptyState = filterControl && !this.itemsExist() && !loading;
17226 var headerMarkup = !showEmptyState && (showHeader || needsHeader) && this.listRef.current && React__default.createElement("div", {
17227 className: styles$1t.HeaderOuterWrapper
17228 }, React__default.createElement(Sticky$1, {
17229 boundingElement: this.listRef.current
17230 }, function (isSticky) {
17231 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']);
17232 return React__default.createElement("div", {
17233 className: headerClassName
17234 }, React__default.createElement(EventListener, {
17235 event: "resize",
17236 handler: _this2.handleResize
17237 }), headerWrapperOverlay, React__default.createElement("div", {
17238 className: styles$1t.HeaderContentWrapper
17239 }, headerTitleMarkup, checkableButtonMarkup, alternateToolMarkup, sortingSelectMarkup, selectButtonMarkup), bulkActionsMarkup);
17240 }));
17241 var emptyStateMarkup = showEmptyState ? React__default.createElement("div", {
17242 className: styles$1t.EmptySearchResultWrapper
17243 }, React__default.createElement(EmptySearchResult, Object.assign({}, this.emptySearchResultText, {
17244 withIllustration: true
17245 }))) : null;
17246 var defaultTopPadding = 8;
17247 var topPadding = loadingPosition > 0 ? loadingPosition : defaultTopPadding;
17248 var spinnerStyle = {
17249 paddingTop: "".concat(topPadding, "px")
17250 };
17251 var spinnerSize = items.length < 2 ? 'small' : 'large';
17252 var loadingOverlay = loading ? React__default.createElement(React__default.Fragment, null, React__default.createElement("div", {
17253 className: styles$1t.SpinnerContainer,
17254 style: spinnerStyle
17255 }, React__default.createElement(Spinner, {
17256 size: spinnerSize,
17257 accessibilityLabel: "Items are loading"
17258 })), React__default.createElement("div", {
17259 className: styles$1t.LoadingOverlay
17260 })) : null;
17261 var className = classNames(styles$1t.ItemWrapper, loading && styles$1t['ItemWrapper-isLoading']);
17262 var loadingWithoutItemsMarkup = loading && !this.itemsExist() ? React__default.createElement("div", {
17263 className: className,
17264 tabIndex: -1
17265 }, loadingOverlay) : null;
17266 var resourceListClassName = classNames(styles$1t.ResourceList, loading && styles$1t.disabledPointerEvents, selectMode && styles$1t.disableTextSelection);
17267 var listMarkup = this.itemsExist() ? React__default.createElement("ul", {
17268 className: resourceListClassName,
17269 ref: this.listRef,
17270 "aria-live": "polite",
17271 "aria-busy": loading
17272 }, loadingOverlay, items.map(this.renderItem)) : emptyStateMarkup;
17273 var context = {
17274 selectable: this.selectable,
17275 selectedItems,
17276 selectMode,
17277 resourceName,
17278 loading,
17279 onSelectionChange: this.handleSelectionChange,
17280 registerCheckableButtons: this.handleCheckableButtonRegistration
17281 };
17282 return React__default.createElement(ResourceListContext.Provider, {
17283 value: context
17284 }, React__default.createElement("div", {
17285 className: styles$1t.ResourceListWrapper
17286 }, filterControlMarkup, headerMarkup, listMarkup, loadingWithoutItemsMarkup));
17287 }
17288 }, {
17289 key: "itemsExist",
17290 value: function itemsExist(items) {
17291 return (items || this.props.items).length > 0;
17292 }
17293 }, {
17294 key: "selectable",
17295 get: function get() {
17296 var _this$props7 = this.props,
17297 promotedBulkActions = _this$props7.promotedBulkActions,
17298 bulkActions = _this$props7.bulkActions,
17299 selectable = _this$props7.selectable;
17300 return Boolean(promotedBulkActions && promotedBulkActions.length > 0 || bulkActions && bulkActions.length > 0 || selectable);
17301 }
17302 }, {
17303 key: "bulkSelectState",
17304 get: function get() {
17305 var _this$props8 = this.props,
17306 selectedItems = _this$props8.selectedItems,
17307 items = _this$props8.items;
17308 var selectState = 'indeterminate';
17309
17310 if (!selectedItems || Array.isArray(selectedItems) && selectedItems.length === 0) {
17311 selectState = false;
17312 } else if (selectedItems === SELECT_ALL_ITEMS || Array.isArray(selectedItems) && selectedItems.length === items.length) {
17313 selectState = true;
17314 }
17315
17316 return selectState;
17317 }
17318 }, {
17319 key: "headerTitle",
17320 get: function get() {
17321 var _this$props9 = this.props,
17322 _this$props9$resource = _this$props9.resourceName,
17323 resourceName = _this$props9$resource === void 0 ? this.defaultResourceName : _this$props9$resource,
17324 items = _this$props9.items,
17325 intl = _this$props9.polaris.intl,
17326 loading = _this$props9.loading,
17327 totalItemsCount = _this$props9.totalItemsCount;
17328 var itemsCount = items.length;
17329 var resource = !loading && (!totalItemsCount && itemsCount === 1 || totalItemsCount === 1) ? resourceName.singular : resourceName.plural;
17330
17331 if (loading) {
17332 return intl.translate('Polaris.ResourceList.loading', {
17333 resource
17334 });
17335 } else if (totalItemsCount) {
17336 return intl.translate('Polaris.ResourceList.showingTotalCount', {
17337 itemsCount,
17338 totalItemsCount,
17339 resource
17340 });
17341 } else {
17342 return intl.translate('Polaris.ResourceList.showing', {
17343 itemsCount,
17344 resource
17345 });
17346 }
17347 }
17348 }, {
17349 key: "bulkActionsLabel",
17350 get: function get() {
17351 var _this$props10 = this.props,
17352 _this$props10$selecte = _this$props10.selectedItems,
17353 selectedItems = _this$props10$selecte === void 0 ? [] : _this$props10$selecte,
17354 items = _this$props10.items,
17355 intl = _this$props10.polaris.intl;
17356 var selectedItemsCount = selectedItems === SELECT_ALL_ITEMS ? "".concat(items.length, "+") : selectedItems.length;
17357 return intl.translate('Polaris.ResourceList.selected', {
17358 selectedItemsCount
17359 });
17360 }
17361 }, {
17362 key: "bulkActionsAccessibilityLabel",
17363 get: function get() {
17364 var _this$props11 = this.props,
17365 _this$props11$resourc = _this$props11.resourceName,
17366 resourceName = _this$props11$resourc === void 0 ? this.defaultResourceName : _this$props11$resourc,
17367 _this$props11$selecte = _this$props11.selectedItems,
17368 selectedItems = _this$props11$selecte === void 0 ? [] : _this$props11$selecte,
17369 items = _this$props11.items,
17370 intl = _this$props11.polaris.intl;
17371 var selectedItemsCount = selectedItems.length;
17372 var totalItemsCount = items.length;
17373 var allSelected = selectedItemsCount === totalItemsCount;
17374
17375 if (totalItemsCount === 1 && allSelected) {
17376 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllSingle', {
17377 resourceNameSingular: resourceName.singular
17378 });
17379 } else if (totalItemsCount === 1) {
17380 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllSingle', {
17381 resourceNameSingular: resourceName.singular
17382 });
17383 } else if (allSelected) {
17384 return intl.translate('Polaris.ResourceList.a11yCheckboxDeselectAllMultiple', {
17385 itemsLength: items.length,
17386 resourceNamePlural: resourceName.plural
17387 });
17388 } else {
17389 return intl.translate('Polaris.ResourceList.a11yCheckboxSelectAllMultiple', {
17390 itemsLength: items.length,
17391 resourceNamePlural: resourceName.plural
17392 });
17393 }
17394 }
17395 }, {
17396 key: "paginatedSelectAllText",
17397 get: function get() {
17398 var _this$props12 = this.props,
17399 hasMoreItems = _this$props12.hasMoreItems,
17400 selectedItems = _this$props12.selectedItems,
17401 items = _this$props12.items,
17402 _this$props12$resourc = _this$props12.resourceName,
17403 resourceName = _this$props12$resourc === void 0 ? this.defaultResourceName : _this$props12$resourc,
17404 intl = _this$props12.polaris.intl;
17405
17406 if (!this.selectable || !hasMoreItems) {
17407 return;
17408 }
17409
17410 if (selectedItems === SELECT_ALL_ITEMS) {
17411 return intl.translate('Polaris.ResourceList.allItemsSelected', {
17412 itemsLength: items.length,
17413 resourceNamePlural: resourceName.plural
17414 });
17415 }
17416 }
17417 }, {
17418 key: "paginatedSelectAllAction",
17419 get: function get() {
17420 var _this$props13 = this.props,
17421 hasMoreItems = _this$props13.hasMoreItems,
17422 selectedItems = _this$props13.selectedItems,
17423 items = _this$props13.items,
17424 _this$props13$resourc = _this$props13.resourceName,
17425 resourceName = _this$props13$resourc === void 0 ? this.defaultResourceName : _this$props13$resourc,
17426 intl = _this$props13.polaris.intl;
17427
17428 if (!this.selectable || !hasMoreItems) {
17429 return;
17430 }
17431
17432 var actionText = selectedItems === SELECT_ALL_ITEMS ? intl.translate('Polaris.Common.undo') : intl.translate('Polaris.ResourceList.selectAllItems', {
17433 itemsLength: items.length,
17434 resourceNamePlural: resourceName.plural
17435 });
17436 return {
17437 content: actionText,
17438 onAction: this.handleSelectAllItemsInStore
17439 };
17440 }
17441 }, {
17442 key: "emptySearchResultText",
17443 get: function get() {
17444 var _this$props14 = this.props,
17445 intl = _this$props14.polaris.intl,
17446 _this$props14$resourc = _this$props14.resourceName,
17447 resourceName = _this$props14$resourc === void 0 ? this.defaultResourceName : _this$props14$resourc;
17448 return {
17449 title: intl.translate('Polaris.ResourceList.emptySearchResultTitle', {
17450 resourceNamePlural: resourceName.plural
17451 }),
17452 description: intl.translate('Polaris.ResourceList.emptySearchResultDescription')
17453 };
17454 }
17455 }]);
17456
17457 return ResourceList;
17458}(React__default.Component);
17459
17460ResourceList.Item = ResourceItem; // eslint-disable-next-line import/no-deprecated
17461
17462ResourceList.FilterControl = FilterControl;
17463
17464function getAllItemsOnPage(items, idForItem) {
17465 return items.map(function (item, index) {
17466 return idForItem(item, index);
17467 });
17468}
17469
17470function defaultIdForItem(item, index) {
17471 return Object.prototype.hasOwnProperty.call(item, 'id') ? item.id : index.toString();
17472}
17473
17474function isSmallScreen() {
17475 return typeof window === 'undefined' ? false : window.innerWidth < SMALL_SCREEN_WIDTH;
17476} // Use named export once withAppProvider is refactored away
17477// eslint-disable-next-line import/no-default-export
17478
17479
17480var ResourceList$1 = withAppProvider()(ResourceList);
17481
17482/** @deprecated Use `ResourcePicker` from `@shopify/app-bridge-react` instead. */
17483
17484var ResourcePicker =
17485/*#__PURE__*/
17486function (_React$PureComponent) {
17487 _inherits(ResourcePicker, _React$PureComponent);
17488
17489 function ResourcePicker() {
17490 var _this;
17491
17492 _classCallCheck(this, ResourcePicker);
17493
17494 _this = _possibleConstructorReturn(this, _getPrototypeOf(ResourcePicker).apply(this, arguments));
17495 _this.focusReturnPoint = null;
17496 return _this;
17497 }
17498
17499 _createClass(ResourcePicker, [{
17500 key: "componentDidMount",
17501 value: function componentDidMount() {
17502 // eslint-disable-next-line no-console
17503 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');
17504
17505 if (this.props.polaris.appBridge == null) {
17506 return;
17507 }
17508
17509 var _this$props = this.props,
17510 open = _this$props.open,
17511 resourceType = _this$props.resourceType,
17512 initialQuery = _this$props.initialQuery,
17513 _this$props$showHidde = _this$props.showHidden,
17514 showHidden = _this$props$showHidde === void 0 ? true : _this$props$showHidde,
17515 _this$props$allowMult = _this$props.allowMultiple,
17516 allowMultiple = _this$props$allowMult === void 0 ? true : _this$props$allowMult,
17517 _this$props$showVaria = _this$props.showVariants,
17518 showVariants = _this$props$showVaria === void 0 ? true : _this$props$showVaria,
17519 onSelection = _this$props.onSelection,
17520 onCancel = _this$props.onCancel;
17521 var appBridge = this.props.polaris.appBridge;
17522 this.appBridgeResourcePicker = actions.ResourcePicker.create(appBridge, {
17523 resourceType: actions.ResourcePicker.ResourceType[resourceType],
17524 options: {
17525 initialQuery,
17526 showHidden,
17527 selectMultiple: allowMultiple,
17528 showVariants
17529 }
17530 });
17531
17532 if (onSelection != null) {
17533 this.appBridgeResourcePicker.subscribe(actions.ResourcePicker.Action.SELECT, function (_ref) {
17534 var selection = _ref.selection;
17535 onSelection({
17536 selection
17537 });
17538 });
17539 }
17540
17541 if (onCancel != null) {
17542 this.appBridgeResourcePicker.subscribe(actions.ResourcePicker.Action.CANCEL, onCancel);
17543 }
17544
17545 if (open) {
17546 this.focusReturnPoint = document.activeElement;
17547 this.appBridgeResourcePicker.dispatch(actions.ResourcePicker.Action.OPEN);
17548 }
17549 }
17550 }, {
17551 key: "componentDidUpdate",
17552 value: function componentDidUpdate(prevProps) {
17553 if (this.appBridgeResourcePicker == null) {
17554 return;
17555 }
17556
17557 var _this$props2 = this.props,
17558 open = _this$props2.open,
17559 initialQuery = _this$props2.initialQuery,
17560 _this$props2$showHidd = _this$props2.showHidden,
17561 showHidden = _this$props2$showHidd === void 0 ? false : _this$props2$showHidd,
17562 _this$props2$allowMul = _this$props2.allowMultiple,
17563 allowMultiple = _this$props2$allowMul === void 0 ? true : _this$props2$allowMul,
17564 _this$props2$showVari = _this$props2.showVariants,
17565 showVariants = _this$props2$showVari === void 0 ? true : _this$props2$showVari,
17566 onSelection = _this$props2.onSelection,
17567 onCancel = _this$props2.onCancel;
17568 var wasOpen = prevProps.open;
17569
17570 var prevAppBridge = prevProps.polaris.appBridge,
17571 prevResourcePickerProps = tslib_1.__rest(prevProps, ["polaris"]);
17572
17573 var _a = this.props,
17574 appBridge = _a.polaris.appBridge,
17575 resourcePickerProps = tslib_1.__rest(_a, ["polaris"]);
17576
17577 if (!isEqual(prevResourcePickerProps, resourcePickerProps) || !isEqual(prevAppBridge, appBridge)) {
17578 this.appBridgeResourcePicker.set({
17579 initialQuery,
17580 showHidden,
17581 selectMultiple: allowMultiple,
17582 showVariants
17583 });
17584 }
17585
17586 this.appBridgeResourcePicker.unsubscribe();
17587
17588 if (onSelection != null) {
17589 this.appBridgeResourcePicker.subscribe(actions.ResourcePicker.Action.SELECT, function (_ref2) {
17590 var selection = _ref2.selection;
17591 onSelection({
17592 selection
17593 });
17594 });
17595 }
17596
17597 if (onCancel != null) {
17598 this.appBridgeResourcePicker.subscribe(actions.ResourcePicker.Action.CANCEL, onCancel);
17599 }
17600
17601 if (wasOpen !== open) {
17602 if (open) {
17603 this.appBridgeResourcePicker.dispatch(actions.ResourcePicker.Action.OPEN);
17604 } else {
17605 this.appBridgeResourcePicker.dispatch(actions.ResourcePicker.Action.CLOSE);
17606 }
17607 }
17608
17609 if (!wasOpen && open) {
17610 this.focusReturnPoint = document.activeElement;
17611 } else if (wasOpen && !open && this.focusReturnPoint != null && document.contains(this.focusReturnPoint)) {
17612 this.focusReturnPoint.focus();
17613 this.focusReturnPoint = null;
17614 }
17615 }
17616 }, {
17617 key: "componentWillUnmount",
17618 value: function componentWillUnmount() {
17619 if (this.appBridgeResourcePicker == null) {
17620 return;
17621 }
17622
17623 this.appBridgeResourcePicker.unsubscribe();
17624 }
17625 }, {
17626 key: "render",
17627 value: function render() {
17628 return null;
17629 }
17630 }]);
17631
17632 return ResourcePicker;
17633}(React__default.PureComponent); // Use named export once withAppProvider is refactored away
17634// eslint-disable-next-line import/no-default-export
17635
17636
17637var ResourcePicker$1 = withAppProvider()(ResourcePicker);
17638
17639function SettingToggle(_ref) {
17640 var enabled = _ref.enabled,
17641 action = _ref.action,
17642 children = _ref.children;
17643 var actionMarkup = action ? buttonFrom(action, {
17644 primary: !enabled
17645 }) : null;
17646 return React__default.createElement(Card, {
17647 sectioned: true
17648 }, React__default.createElement(SettingAction, {
17649 action: actionMarkup
17650 }, children));
17651}
17652
17653var styles$1u = {
17654 "SkeletonBodyTextContainer": "Polaris-SkeletonBodyText__SkeletonBodyTextContainer",
17655 "SkeletonBodyText": "Polaris-SkeletonBodyText"
17656};
17657
17658function SkeletonBodyText(_ref) {
17659 var _ref$lines = _ref.lines,
17660 lines = _ref$lines === void 0 ? 3 : _ref$lines;
17661 var bodyTextLines = [];
17662
17663 for (var i = 0; i < lines; i++) {
17664 bodyTextLines.push(React__default.createElement("div", {
17665 className: styles$1u.SkeletonBodyText,
17666 key: i
17667 }));
17668 }
17669
17670 return React__default.createElement("div", {
17671 className: styles$1u.SkeletonBodyTextContainer
17672 }, bodyTextLines);
17673}
17674
17675var styles$1v = {
17676 "DisplayText": "Polaris-SkeletonDisplayText__DisplayText",
17677 "sizeSmall": "Polaris-SkeletonDisplayText--sizeSmall",
17678 "sizeMedium": "Polaris-SkeletonDisplayText--sizeMedium",
17679 "sizeLarge": "Polaris-SkeletonDisplayText--sizeLarge",
17680 "sizeExtraLarge": "Polaris-SkeletonDisplayText--sizeExtraLarge"
17681};
17682
17683function SkeletonDisplayText(_ref) {
17684 var _ref$size = _ref.size,
17685 size = _ref$size === void 0 ? 'medium' : _ref$size;
17686 var className = classNames(styles$1v.DisplayText, size && styles$1v[variationName('size', size)]);
17687 return React__default.createElement("div", {
17688 className: className
17689 });
17690}
17691
17692var styles$1w = {
17693 "Page": "Polaris-SkeletonPage__Page",
17694 "fullWidth": "Polaris-SkeletonPage--fullWidth",
17695 "narrowWidth": "Polaris-SkeletonPage--narrowWidth",
17696 "Content": "Polaris-SkeletonPage__Content",
17697 "Header": "Polaris-SkeletonPage__Header",
17698 "Header-hasSecondaryActions": "Polaris-SkeletonPage__Header--hasSecondaryActions",
17699 "BreadcrumbAction": "Polaris-SkeletonPage__BreadcrumbAction",
17700 "TitleAndPrimaryAction": "Polaris-SkeletonPage__TitleAndPrimaryAction",
17701 "Title": "Polaris-SkeletonPage__Title",
17702 "PrimaryAction": "Polaris-SkeletonPage__PrimaryAction",
17703 "Actions": "Polaris-SkeletonPage__Actions",
17704 "Action": "Polaris-SkeletonPage__Action"
17705};
17706
17707function SkeletonPage(_ref) {
17708 var children = _ref.children,
17709 fullWidth = _ref.fullWidth,
17710 narrowWidth = _ref.narrowWidth,
17711 singleColumn = _ref.singleColumn,
17712 primaryAction = _ref.primaryAction,
17713 secondaryActions = _ref.secondaryActions,
17714 _ref$title = _ref.title,
17715 title = _ref$title === void 0 ? '' : _ref$title,
17716 breadcrumbs = _ref.breadcrumbs;
17717
17718 if (singleColumn) {
17719 // eslint-disable-next-line no-console
17720 console.warn('Deprecation: The singleColumn prop has been renamed to narrowWidth to better represents its use and will be removed in v5.0.');
17721 }
17722
17723 var i18n = useI18n();
17724 var appBridge = useAppBridge();
17725 var className = classNames(styles$1w.Page, fullWidth && styles$1w.fullWidth, (narrowWidth || singleColumn) && styles$1w.narrowWidth);
17726 var headerClassName = classNames(styles$1w.Header, breadcrumbs && styles$1w['Header-hasBreadcrumbs'], secondaryActions && styles$1w['Header-hasSecondaryActions']);
17727 var titleMarkup = title !== null ? renderTitle(title) : null;
17728 var primaryActionMarkup = primaryAction ? React__default.createElement("div", {
17729 className: styles$1w.PrimaryAction
17730 }, React__default.createElement(SkeletonDisplayText, {
17731 size: "large"
17732 })) : null;
17733 var secondaryActionsMarkup = secondaryActions ? renderSecondaryActions(secondaryActions) : null;
17734 var breadcrumbMarkup = breadcrumbs ? React__default.createElement("div", {
17735 className: styles$1w.BreadcrumbAction,
17736 style: {
17737 width: 60
17738 }
17739 }, React__default.createElement(SkeletonBodyText, {
17740 lines: 1
17741 })) : null;
17742 var headerMarkup = !appBridge ? React__default.createElement("div", {
17743 className: headerClassName
17744 }, breadcrumbMarkup, React__default.createElement("div", {
17745 className: styles$1w.TitleAndPrimaryAction
17746 }, titleMarkup, primaryActionMarkup), secondaryActionsMarkup) : null;
17747 return React__default.createElement("div", {
17748 className: className,
17749 role: "status",
17750 "aria-label": i18n.translate('Polaris.SkeletonPage.loadingLabel')
17751 }, headerMarkup, React__default.createElement("div", {
17752 className: styles$1w.Content
17753 }, children));
17754}
17755
17756function renderSecondaryActions(actionCount) {
17757 var actions = [];
17758
17759 for (var i = 0; i < actionCount; i++) {
17760 var width = Math.round(Math.random() * 40 + 60);
17761 actions.push(React__default.createElement("div", {
17762 className: styles$1w.Action,
17763 style: {
17764 width
17765 },
17766 key: i
17767 }, React__default.createElement(SkeletonBodyText, {
17768 lines: 1
17769 })));
17770 }
17771
17772 return React__default.createElement("div", {
17773 className: styles$1w.Actions
17774 }, actions);
17775}
17776
17777function renderTitle(title) {
17778 var titleContent = title === '' ? React__default.createElement(SkeletonDisplayText, {
17779 size: "large"
17780 }) : React__default.createElement(DisplayText, {
17781 size: "large",
17782 element: "h1"
17783 }, title);
17784 return React__default.createElement("div", {
17785 className: styles$1w.Title
17786 }, titleContent);
17787}
17788
17789var styles$1x = {
17790 "SkeletonThumbnail": "Polaris-SkeletonThumbnail",
17791 "sizeSmall": "Polaris-SkeletonThumbnail--sizeSmall",
17792 "sizeMedium": "Polaris-SkeletonThumbnail--sizeMedium",
17793 "sizeLarge": "Polaris-SkeletonThumbnail--sizeLarge"
17794};
17795
17796function SkeletonThumbnail(_ref) {
17797 var _ref$size = _ref.size,
17798 size = _ref$size === void 0 ? 'medium' : _ref$size;
17799 var className = classNames(styles$1x.SkeletonThumbnail, size && styles$1x[variationName('size', size)]);
17800 return React__default.createElement("div", {
17801 className: className
17802 });
17803}
17804
17805function getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth) {
17806 var sumTabWidths = tabWidths.reduce(function (sum, width) {
17807 return sum + width;
17808 }, 0);
17809 var arrayOfTabIndices = tabs.map(function (_, index) {
17810 return index;
17811 });
17812 var visibleTabs = [];
17813 var hiddenTabs = [];
17814
17815 if (containerWidth > sumTabWidths) {
17816 visibleTabs.push.apply(visibleTabs, _toConsumableArray(arrayOfTabIndices));
17817 } else {
17818 visibleTabs.push(selected);
17819 var tabListWidth = tabWidths[selected];
17820 arrayOfTabIndices.forEach(function (currentTabIndex) {
17821 if (currentTabIndex !== selected) {
17822 var currentTabWidth = tabWidths[currentTabIndex];
17823
17824 if (tabListWidth + currentTabWidth > containerWidth - disclosureWidth) {
17825 hiddenTabs.push(currentTabIndex);
17826 return;
17827 }
17828
17829 visibleTabs.push(currentTabIndex);
17830 tabListWidth += currentTabWidth;
17831 }
17832 });
17833 }
17834
17835 return {
17836 visibleTabs,
17837 hiddenTabs
17838 };
17839}
17840
17841var styles$1y = {
17842 "Tabs": "Polaris-Tabs",
17843 "fitted": "Polaris-Tabs--fitted",
17844 "TabContainer": "Polaris-Tabs__TabContainer",
17845 "Tab": "Polaris-Tabs__Tab",
17846 "Title": "Polaris-Tabs__Title",
17847 "fillSpace": "Polaris-Tabs--fillSpace",
17848 "Tab-selected": "Polaris-Tabs__Tab--selected",
17849 "Panel": "Polaris-Tabs__Panel",
17850 "Panel-hidden": "Polaris-Tabs__Panel--hidden",
17851 "List": "Polaris-Tabs__List",
17852 "Item": "Polaris-Tabs__Item",
17853 "DisclosureTab": "Polaris-Tabs__DisclosureTab",
17854 "DisclosureTab-visible": "Polaris-Tabs__DisclosureTab--visible",
17855 "DisclosureActivator": "Polaris-Tabs__DisclosureActivator",
17856 "TabMeasurer": "Polaris-Tabs__TabMeasurer"
17857};
17858
17859var Item$8 =
17860/*#__PURE__*/
17861function (_React$PureComponent) {
17862 _inherits(Item, _React$PureComponent);
17863
17864 function Item() {
17865 var _this;
17866
17867 _classCallCheck(this, Item);
17868
17869 _this = _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments));
17870 _this.focusedNode = null;
17871
17872 _this.setFocusedNode = function (node) {
17873 _this.focusedNode = node;
17874 };
17875
17876 return _this;
17877 }
17878
17879 _createClass(Item, [{
17880 key: "componentDidMount",
17881 value: function componentDidMount() {
17882 var focusedNode = this.focusedNode;
17883 var focused = this.props.focused;
17884
17885 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17886 focusedNode.focus();
17887 }
17888 }
17889 }, {
17890 key: "componentDidUpdate",
17891 value: function componentDidUpdate() {
17892 var focusedNode = this.focusedNode;
17893 var focused = this.props.focused;
17894
17895 if (focusedNode && focusedNode instanceof HTMLElement && focused) {
17896 focusedNode.focus();
17897 }
17898 }
17899 }, {
17900 key: "render",
17901 value: function render() {
17902 var _this$props = this.props,
17903 id = _this$props.id,
17904 panelID = _this$props.panelID,
17905 children = _this$props.children,
17906 url = _this$props.url,
17907 accessibilityLabel = _this$props.accessibilityLabel,
17908 _this$props$onClick = _this$props.onClick,
17909 onClick = _this$props$onClick === void 0 ? noop$c : _this$props$onClick;
17910 var sharedProps = {
17911 id,
17912 ref: this.setFocusedNode,
17913 onClick,
17914 className: styles$1y.Item,
17915 'aria-controls': panelID,
17916 'aria-selected': false,
17917 'aria-label': accessibilityLabel
17918 };
17919 var markup = url ? React__default.createElement(UnstyledLink, Object.assign({}, sharedProps, {
17920 url: url
17921 }), children) : React__default.createElement("button", Object.assign({}, sharedProps, {
17922 type: "button"
17923 }), children);
17924 return React__default.createElement("li", null, markup);
17925 }
17926 }]);
17927
17928 return Item;
17929}(React__default.PureComponent);
17930
17931function noop$c() {}
17932
17933var List$1 =
17934/*#__PURE__*/
17935function (_React$PureComponent) {
17936 _inherits(List, _React$PureComponent);
17937
17938 function List() {
17939 var _this;
17940
17941 _classCallCheck(this, List);
17942
17943 _this = _possibleConstructorReturn(this, _getPrototypeOf(List).apply(this, arguments));
17944
17945 _this.handleKeypress = function (event) {
17946 var _this$props$onKeyPres = _this.props.onKeyPress,
17947 onKeyPress = _this$props$onKeyPres === void 0 ? noop$d : _this$props$onKeyPres;
17948 onKeyPress(event);
17949 };
17950
17951 return _this;
17952 }
17953
17954 _createClass(List, [{
17955 key: "render",
17956 value: function render() {
17957 var _this$props = this.props,
17958 focusIndex = _this$props.focusIndex,
17959 disclosureTabs = _this$props.disclosureTabs,
17960 _this$props$onClick = _this$props.onClick,
17961 onClick = _this$props$onClick === void 0 ? noop$d : _this$props$onClick;
17962 var tabs = disclosureTabs.map(function (_a, index) {
17963 var id = _a.id,
17964 content = _a.content,
17965 tabProps = tslib_1.__rest(_a, ["id", "content"]);
17966
17967 return React__default.createElement(Item$8, Object.assign({}, tabProps, {
17968 key: id,
17969 id: id,
17970 focused: index === focusIndex,
17971 onClick: onClick.bind(null, id)
17972 }), content);
17973 });
17974 return React__default.createElement("ul", {
17975 className: styles$1y.List,
17976 onKeyDown: handleKeyDown$1,
17977 onKeyUp: this.handleKeypress
17978 }, tabs);
17979 }
17980 }]);
17981
17982 return List;
17983}(React__default.PureComponent);
17984
17985function noop$d() {}
17986
17987function handleKeyDown$1(event) {
17988 var key = event.key;
17989
17990 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
17991 event.preventDefault();
17992 event.stopPropagation();
17993 }
17994}
17995
17996function Panel(_ref) {
17997 var hidden = _ref.hidden,
17998 id = _ref.id,
17999 tabID = _ref.tabID,
18000 children = _ref.children;
18001 var className = classNames(styles$1y.Panel, hidden && styles$1y['Panel-hidden']);
18002 return React__default.createElement("div", {
18003 className: className,
18004 id: id,
18005 role: "tabpanel",
18006 "aria-labelledby": tabID,
18007 tabIndex: -1
18008 }, children);
18009}
18010
18011function Tab(_ref) {
18012 var id = _ref.id,
18013 focused = _ref.focused,
18014 siblingTabHasFocus = _ref.siblingTabHasFocus,
18015 children = _ref.children,
18016 onClick = _ref.onClick,
18017 selected = _ref.selected,
18018 url = _ref.url,
18019 panelID = _ref.panelID,
18020 measuring = _ref.measuring,
18021 accessibilityLabel = _ref.accessibilityLabel;
18022 var wasSelected = React.useRef(selected);
18023 var panelFocused = React.useRef(false);
18024 var node = React.useRef(null); // A tab can start selected when it is moved from the disclosure dropdown
18025 // into the main list, so we need to send focus from the tab to the panel
18026 // on mount and update
18027
18028 React.useEffect(function () {
18029 if (measuring) {
18030 return;
18031 } // Because of timing issues with the render, we may still have the old,
18032 // in-disclosure version of the tab that has focus. Check for this
18033 // as a second indicator of focus
18034
18035
18036 var itemHadFocus = focused || document.activeElement && document.activeElement.id === id; // If we just check for selected, the panel for the active tab will
18037 // be focused on page load, which we don’t want
18038
18039 if (itemHadFocus && selected && panelID != null && !panelFocused.current) {
18040 focusPanelID(panelID);
18041 panelFocused.current = true;
18042 }
18043
18044 if (selected && !wasSelected.current && panelID != null) {
18045 focusPanelID(panelID);
18046 } else if (focused && node.current != null) {
18047 focus.focusFirstFocusableNode(node.current);
18048 }
18049
18050 wasSelected.current = selected;
18051 }, [focused, id, measuring, panelID, selected]);
18052 var handleClick = onClick && onClick.bind(null, id);
18053 var className = classNames(styles$1y.Tab, selected && styles$1y['Tab-selected']);
18054 var tabIndex;
18055
18056 if (selected && !siblingTabHasFocus && !measuring) {
18057 tabIndex = 0;
18058 } else if (focused && !measuring) {
18059 tabIndex = 0;
18060 } else {
18061 tabIndex = -1;
18062 }
18063
18064 var markup = url ? React__default.createElement(UnstyledLink, {
18065 id: id,
18066 url: url,
18067 role: "tab",
18068 tabIndex: tabIndex,
18069 onClick: handleClick,
18070 className: className,
18071 "aria-selected": selected,
18072 "aria-controls": panelID,
18073 "aria-label": accessibilityLabel,
18074 onMouseUp: handleMouseUpByBlurring
18075 }, React__default.createElement("span", {
18076 className: styles$1y.Title
18077 }, children)) : React__default.createElement("button", {
18078 id: id,
18079 role: "tab",
18080 type: "button",
18081 tabIndex: tabIndex,
18082 className: className,
18083 onClick: handleClick,
18084 "aria-selected": selected,
18085 "aria-controls": panelID,
18086 "aria-label": accessibilityLabel,
18087 onMouseUp: handleMouseUpByBlurring
18088 }, React__default.createElement("span", {
18089 className: styles$1y.Title
18090 }, children));
18091 return React__default.createElement("li", {
18092 className: styles$1y.TabContainer,
18093 ref: node
18094 }, markup);
18095}
18096
18097function focusPanelID(panelID) {
18098 var panel = document.getElementById(panelID);
18099
18100 if (panel) {
18101 panel.focus({
18102 preventScroll: true
18103 });
18104 }
18105}
18106
18107var TabMeasurer =
18108/*#__PURE__*/
18109function (_React$PureComponent) {
18110 _inherits(TabMeasurer, _React$PureComponent);
18111
18112 function TabMeasurer() {
18113 var _this;
18114
18115 _classCallCheck(this, TabMeasurer);
18116
18117 _this = _possibleConstructorReturn(this, _getPrototypeOf(TabMeasurer).apply(this, arguments));
18118 _this.containerNode = React__default.createRef();
18119 _this.animationFrame = null;
18120
18121 _this.handleMeasurement = function () {
18122 if (_this.animationFrame) {
18123 cancelAnimationFrame(_this.animationFrame);
18124 }
18125
18126 _this.animationFrame = requestAnimationFrame(function () {
18127 if (!_this.containerNode.current) {
18128 return;
18129 }
18130
18131 var handleMeasurement = _this.props.handleMeasurement;
18132 var containerWidth = _this.containerNode.current.offsetWidth;
18133 var hiddenTabNodes = _this.containerNode.current.children;
18134 var hiddenTabNodesArray = Array.from(hiddenTabNodes);
18135 var hiddenTabWidths = hiddenTabNodesArray.map(function (node) {
18136 return node.getBoundingClientRect().width;
18137 });
18138 var disclosureWidth = hiddenTabWidths.pop();
18139 handleMeasurement({
18140 containerWidth,
18141 disclosureWidth,
18142 hiddenTabWidths
18143 });
18144 });
18145 };
18146
18147 return _this;
18148 }
18149
18150 _createClass(TabMeasurer, [{
18151 key: "componentDidMount",
18152 value: function componentDidMount() {
18153 this.handleMeasurement();
18154
18155 if (process.env.NODE_ENV === 'development') {
18156 // We need to defer the calculation in development so the
18157 // styles have time to be injected.
18158 setTimeout(this.handleMeasurement, 0);
18159 }
18160 }
18161 }, {
18162 key: "componentDidUpdate",
18163 value: function componentDidUpdate(prevProps) {
18164 if (prevProps.tabs !== this.props.tabs) {
18165 this.handleMeasurement();
18166 }
18167 }
18168 }, {
18169 key: "render",
18170 value: function render() {
18171 var _this$props = this.props,
18172 selected = _this$props.selected,
18173 tabs = _this$props.tabs,
18174 activator = _this$props.activator,
18175 tabToFocus = _this$props.tabToFocus,
18176 siblingTabHasFocus = _this$props.siblingTabHasFocus;
18177 var tabsMarkup = tabs.map(function (tab, index) {
18178 return React__default.createElement(Tab, {
18179 measuring: true,
18180 key: "".concat(index).concat(tab.id, "Hidden"),
18181 id: "".concat(tab.id, "Measurer"),
18182 siblingTabHasFocus: siblingTabHasFocus,
18183 focused: index === tabToFocus,
18184 selected: index === selected,
18185 onClick: noop$e,
18186 url: tab.url
18187 }, tab.content);
18188 });
18189 var classname = classNames(styles$1y.Tabs, styles$1y.TabMeasurer);
18190 return React__default.createElement("div", {
18191 className: classname,
18192 ref: this.containerNode
18193 }, React__default.createElement(EventListener, {
18194 event: "resize",
18195 handler: this.handleMeasurement
18196 }), tabsMarkup, activator);
18197 }
18198 }]);
18199
18200 return TabMeasurer;
18201}(React__default.PureComponent);
18202
18203function noop$e() {}
18204
18205var Tabs =
18206/*#__PURE__*/
18207function (_React$PureComponent) {
18208 _inherits(Tabs, _React$PureComponent);
18209
18210 function Tabs() {
18211 var _this;
18212
18213 _classCallCheck(this, Tabs);
18214
18215 _this = _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
18216 _this.state = {
18217 disclosureWidth: 0,
18218 containerWidth: Infinity,
18219 tabWidths: [],
18220 visibleTabs: [],
18221 hiddenTabs: [],
18222 showDisclosure: false,
18223 tabToFocus: -1
18224 };
18225
18226 _this.handleKeyPress = function (event) {
18227 var _this$state = _this.state,
18228 tabToFocus = _this$state.tabToFocus,
18229 visibleTabs = _this$state.visibleTabs,
18230 hiddenTabs = _this$state.hiddenTabs,
18231 showDisclosure = _this$state.showDisclosure;
18232 var key = event.key;
18233 var tabsArrayInOrder = showDisclosure ? visibleTabs.concat(hiddenTabs) : _toConsumableArray(visibleTabs);
18234 var newFocus = tabsArrayInOrder.indexOf(tabToFocus);
18235
18236 if (key === 'ArrowRight' || key === 'ArrowDown') {
18237 newFocus += 1;
18238
18239 if (newFocus === tabsArrayInOrder.length) {
18240 newFocus = 0;
18241 }
18242 }
18243
18244 if (key === 'ArrowLeft' || key === 'ArrowUp') {
18245 if (newFocus === -1 || newFocus === 0) {
18246 newFocus = tabsArrayInOrder.length - 1;
18247 } else {
18248 newFocus -= 1;
18249 }
18250 }
18251
18252 _this.setState({
18253 tabToFocus: tabsArrayInOrder[newFocus]
18254 });
18255 };
18256
18257 _this.renderTabMarkup = function (tab, index) {
18258 var selected = _this.props.selected;
18259 var tabToFocus = _this.state.tabToFocus;
18260 return React__default.createElement(Tab, {
18261 key: "".concat(index, "-").concat(tab.id),
18262 id: tab.id,
18263 siblingTabHasFocus: tabToFocus > -1,
18264 focused: index === tabToFocus,
18265 selected: index === selected,
18266 onClick: _this.handleTabClick,
18267 panelID: tab.panelID || "".concat(tab.id, "-panel"),
18268 accessibilityLabel: tab.accessibilityLabel,
18269 url: tab.url
18270 }, tab.content);
18271 };
18272
18273 _this.handleFocus = function (event) {
18274 var _this$props = _this.props,
18275 selected = _this$props.selected,
18276 tabs = _this$props.tabs; // If we are explicitly focusing a non-selected tab, this focuses it
18277
18278 var target = event.target;
18279
18280 if (target.classList.contains(styles$1y.Tab) || target.classList.contains(styles$1y.Item)) {
18281 var tabToFocus = -1;
18282 tabs.every(function (tab, index) {
18283 if (tab.id === target.id) {
18284 tabToFocus = index;
18285 return false;
18286 }
18287
18288 return true;
18289 });
18290
18291 _this.setState({
18292 tabToFocus
18293 });
18294
18295 return;
18296 }
18297
18298 if (target.classList.contains(styles$1y.DisclosureActivator)) {
18299 return;
18300 } // If we are coming in from somewhere other than another tab, focus the
18301 // selected tab, and the focus (click) is not on the disclosure activator,
18302 // focus the selected tab
18303
18304
18305 if (!event.relatedTarget) {
18306 _this.setState({
18307 tabToFocus: selected
18308 });
18309
18310 return;
18311 }
18312
18313 var relatedTarget = event.relatedTarget;
18314
18315 if (!relatedTarget.classList.contains(styles$1y.Tab) && !relatedTarget.classList.contains(styles$1y.Item) && !relatedTarget.classList.contains(styles$1y.DisclosureActivator)) {
18316 _this.setState({
18317 tabToFocus: selected
18318 });
18319 }
18320 };
18321
18322 _this.handleBlur = function (event) {
18323 // If we blur and the target is not another tab, forget the focus position
18324 if (event.relatedTarget == null) {
18325 _this.setState({
18326 tabToFocus: -1
18327 });
18328
18329 return;
18330 }
18331
18332 var target = event.relatedTarget; // If we are going to anywhere other than another tab, lose the last focused tab
18333
18334 if (!target.classList.contains(styles$1y.Tab) && !target.classList.contains(styles$1y.Item)) {
18335 _this.setState({
18336 tabToFocus: -1
18337 });
18338 }
18339 };
18340
18341 _this.handleDisclosureActivatorClick = function () {
18342 _this.setState(function (_ref) {
18343 var showDisclosure = _ref.showDisclosure;
18344 return {
18345 showDisclosure: !showDisclosure
18346 };
18347 });
18348 };
18349
18350 _this.handleClose = function () {
18351 _this.setState({
18352 showDisclosure: false
18353 });
18354 };
18355
18356 _this.handleMeasurement = function (measurements) {
18357 var _this$props2 = _this.props,
18358 tabs = _this$props2.tabs,
18359 selected = _this$props2.selected;
18360 var tabToFocus = _this.state.tabToFocus;
18361 var tabWidths = measurements.hiddenTabWidths,
18362 containerWidth = measurements.containerWidth,
18363 disclosureWidth = measurements.disclosureWidth;
18364
18365 var _getVisibleAndHiddenT = getVisibleAndHiddenTabIndices(tabs, selected, disclosureWidth, tabWidths, containerWidth),
18366 visibleTabs = _getVisibleAndHiddenT.visibleTabs,
18367 hiddenTabs = _getVisibleAndHiddenT.hiddenTabs;
18368
18369 _this.setState({
18370 tabToFocus: tabToFocus === -1 ? -1 : selected,
18371 visibleTabs,
18372 hiddenTabs,
18373 disclosureWidth,
18374 containerWidth,
18375 tabWidths
18376 });
18377 };
18378
18379 _this.handleTabClick = function (id) {
18380 var _this$props3 = _this.props,
18381 tabs = _this$props3.tabs,
18382 _this$props3$onSelect = _this$props3.onSelect,
18383 onSelect = _this$props3$onSelect === void 0 ? noop$f : _this$props3$onSelect;
18384 var tab = tabs.find(function (aTab) {
18385 return aTab.id === id;
18386 });
18387
18388 if (tab == null) {
18389 return;
18390 }
18391
18392 var selectedIndex = tabs.indexOf(tab);
18393 onSelect(selectedIndex);
18394 };
18395
18396 return _this;
18397 }
18398
18399 _createClass(Tabs, [{
18400 key: "render",
18401 value: function render() {
18402 var _this2 = this;
18403
18404 var _this$props4 = this.props,
18405 tabs = _this$props4.tabs,
18406 selected = _this$props4.selected,
18407 fitted = _this$props4.fitted,
18408 children = _this$props4.children,
18409 intl = _this$props4.polaris.intl;
18410 var _this$state2 = this.state,
18411 tabToFocus = _this$state2.tabToFocus,
18412 visibleTabs = _this$state2.visibleTabs,
18413 hiddenTabs = _this$state2.hiddenTabs,
18414 showDisclosure = _this$state2.showDisclosure;
18415 var disclosureTabs = hiddenTabs.map(function (tabIndex) {
18416 return tabs[tabIndex];
18417 });
18418 var panelMarkup = children ? tabs.map(function (_tab, index) {
18419 return selected === index ? React__default.createElement(Panel, {
18420 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
18421 tabID: tabs[index].id,
18422 key: tabs[index].id
18423 }, children) : React__default.createElement(Panel, {
18424 id: tabs[index].panelID || "".concat(tabs[index].id, "-panel"),
18425 tabID: tabs[index].id,
18426 key: tabs[index].id,
18427 hidden: true
18428 });
18429 }) : null;
18430 var tabsMarkup = visibleTabs.sort(function (tabA, tabB) {
18431 return tabA - tabB;
18432 }).map(function (tabIndex) {
18433 return _this2.renderTabMarkup(tabs[tabIndex], tabIndex);
18434 });
18435 var disclosureActivatorVisible = visibleTabs.length < tabs.length;
18436 var classname = classNames(styles$1y.Tabs, fitted && styles$1y.fitted, disclosureActivatorVisible && styles$1y.fillSpace);
18437 var disclosureTabClassName = classNames(styles$1y.DisclosureTab, disclosureActivatorVisible && styles$1y['DisclosureTab-visible']);
18438 var activator = React__default.createElement("button", {
18439 type: "button",
18440 className: styles$1y.DisclosureActivator,
18441 onClick: this.handleDisclosureActivatorClick,
18442 "aria-label": intl.translate('Polaris.Tabs.toggleTabsLabel')
18443 }, React__default.createElement("span", {
18444 className: styles$1y.Title
18445 }, React__default.createElement(Icon, {
18446 source: polarisIcons.HorizontalDotsMinor
18447 })));
18448 return React__default.createElement("div", null, React__default.createElement("ul", {
18449 role: "tablist",
18450 className: classname,
18451 onFocus: this.handleFocus,
18452 onBlur: this.handleBlur,
18453 onKeyDown: handleKeyDown$2,
18454 onKeyUp: this.handleKeyPress
18455 }, tabsMarkup, React__default.createElement("li", {
18456 className: disclosureTabClassName
18457 }, React__default.createElement(Popover, {
18458 preferredPosition: "below",
18459 activator: activator,
18460 active: disclosureActivatorVisible && showDisclosure,
18461 onClose: this.handleClose
18462 }, React__default.createElement(List$1, {
18463 focusIndex: hiddenTabs.indexOf(tabToFocus),
18464 disclosureTabs: disclosureTabs,
18465 onClick: this.handleTabClick,
18466 onKeyPress: this.handleKeyPress
18467 })))), React__default.createElement(TabMeasurer, {
18468 tabToFocus: tabToFocus,
18469 activator: activator,
18470 selected: selected,
18471 tabs: tabs,
18472 siblingTabHasFocus: tabToFocus > -1,
18473 handleMeasurement: this.handleMeasurement
18474 }), panelMarkup);
18475 }
18476 }], [{
18477 key: "getDerivedStateFromProps",
18478 value: function getDerivedStateFromProps(nextProps, prevState) {
18479 var disclosureWidth = prevState.disclosureWidth,
18480 tabWidths = prevState.tabWidths,
18481 containerWidth = prevState.containerWidth;
18482
18483 var _getVisibleAndHiddenT2 = getVisibleAndHiddenTabIndices(nextProps.tabs, nextProps.selected, disclosureWidth, tabWidths, containerWidth),
18484 visibleTabs = _getVisibleAndHiddenT2.visibleTabs,
18485 hiddenTabs = _getVisibleAndHiddenT2.hiddenTabs;
18486
18487 return {
18488 visibleTabs,
18489 hiddenTabs,
18490 selected: nextProps.selected
18491 };
18492 }
18493 }]);
18494
18495 return Tabs;
18496}(React__default.PureComponent);
18497
18498function noop$f() {}
18499
18500function handleKeyDown$2(event) {
18501 var key = event.key;
18502
18503 if (key === 'ArrowUp' || key === 'ArrowDown' || key === 'ArrowLeft' || key === 'ArrowRight') {
18504 event.preventDefault();
18505 event.stopPropagation();
18506 }
18507} // Use named export once withAppProvider is refactored away
18508// eslint-disable-next-line import/no-default-export
18509
18510
18511var Tabs$1 = withAppProvider()(Tabs);
18512
18513var styles$1z = {
18514 "Thumbnail": "Polaris-Thumbnail",
18515 "sizeSmall": "Polaris-Thumbnail--sizeSmall",
18516 "sizeMedium": "Polaris-Thumbnail--sizeMedium",
18517 "sizeLarge": "Polaris-Thumbnail--sizeLarge",
18518 "Image": "Polaris-Thumbnail__Image"
18519};
18520
18521function Thumbnail(_ref) {
18522 var source = _ref.source,
18523 alt = _ref.alt,
18524 _ref$size = _ref.size,
18525 size = _ref$size === void 0 ? 'medium' : _ref$size;
18526 var className = classNames(styles$1z.Thumbnail, size && styles$1z[variationName('size', size)]);
18527 return React__default.createElement("span", {
18528 className: className
18529 }, React__default.createElement(Image, {
18530 alt: alt,
18531 source: source,
18532 className: styles$1z.Image
18533 }));
18534}
18535
18536var Toast$1 = React__default.memo(function Toast(props) {
18537 var id = useUniqueId('Toast');
18538 var appBridgeToast = React.useRef();
18539
18540 var _useFrame = useFrame(),
18541 showToast = _useFrame.showToast,
18542 hideToast = _useFrame.hideToast;
18543
18544 var appBridge = useAppBridge();
18545 useDeepEffect(function () {
18546 var error = props.error,
18547 content = props.content,
18548 _props$duration = props.duration,
18549 duration = _props$duration === void 0 ? DEFAULT_TOAST_DURATION : _props$duration,
18550 onDismiss = props.onDismiss;
18551
18552 if (appBridge == null) {
18553 showToast(Object.assign({
18554 id
18555 }, props));
18556 } else {
18557 // eslint-disable-next-line no-console
18558 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');
18559 appBridgeToast.current = actions.Toast.create(appBridge, {
18560 message: content,
18561 duration,
18562 isError: error
18563 });
18564 appBridgeToast.current.subscribe(actions.Toast.Action.CLEAR, onDismiss);
18565 appBridgeToast.current.dispatch(actions.Toast.Action.SHOW);
18566 }
18567
18568 return function () {
18569 if (appBridge == null) {
18570 hideToast({
18571 id
18572 });
18573 } else if (appBridgeToast.current != null) {
18574 appBridgeToast.current.unsubscribe();
18575 }
18576 };
18577 }, [appBridge, props]);
18578 return null;
18579});
18580
18581var styles$1A = {
18582 "Search": "Polaris-TopBar-Search",
18583 "visible": "Polaris-TopBar-Search--visible",
18584 "Overlay": "Polaris-TopBar-Search__Overlay"
18585};
18586
18587var Search =
18588/*#__PURE__*/
18589function (_React$PureComponent) {
18590 _inherits(Search, _React$PureComponent);
18591
18592 function Search() {
18593 var _this;
18594
18595 _classCallCheck(this, Search);
18596
18597 _this = _possibleConstructorReturn(this, _getPrototypeOf(Search).apply(this, arguments));
18598 _this.node = React__default.createRef();
18599
18600 _this.handleDismiss = function (_ref) {
18601 var target = _ref.target;
18602 var onDismiss = _this.props.onDismiss;
18603
18604 if (onDismiss != null && target === _this.node.current) {
18605 onDismiss();
18606 }
18607 };
18608
18609 return _this;
18610 }
18611
18612 _createClass(Search, [{
18613 key: "render",
18614 value: function render() {
18615 var _this$props = this.props,
18616 visible = _this$props.visible,
18617 children = _this$props.children;
18618 var searchClassName = classNames(styles$1A.Search, visible && styles$1A.visible);
18619 return React__default.createElement("div", {
18620 ref: this.node,
18621 className: searchClassName,
18622 onClick: this.handleDismiss
18623 }, React__default.createElement("div", {
18624 className: styles$1A.Overlay
18625 }, children));
18626 }
18627 }]);
18628
18629 return Search;
18630}(React__default.PureComponent);
18631
18632var styles$1B = {
18633 "SearchField": "Polaris-TopBar-SearchField",
18634 "focused": "Polaris-TopBar-SearchField--focused",
18635 "Input": "Polaris-TopBar-SearchField__Input",
18636 "Backdrop": "Polaris-TopBar-SearchField__Backdrop",
18637 "Icon": "Polaris-TopBar-SearchField__Icon",
18638 "Clear": "Polaris-TopBar-SearchField__Clear",
18639 "toLightBackground": "Polaris-TopBar-SearchField--toLightBackground"
18640};
18641
18642function SearchField(_ref) {
18643 var value = _ref.value,
18644 focused = _ref.focused,
18645 active = _ref.active,
18646 placeholder = _ref.placeholder,
18647 onChange = _ref.onChange,
18648 onFocus = _ref.onFocus,
18649 onBlur = _ref.onBlur,
18650 onCancel = _ref.onCancel;
18651 var i18n = useI18n();
18652 var input = React.useRef(null);
18653 var searchId = useUniqueId('SearchField');
18654 var handleChange = React.useCallback(function (_ref2) {
18655 var currentTarget = _ref2.currentTarget;
18656 onChange(currentTarget.value);
18657 }, [onChange]);
18658 var handleFocus = React.useCallback(function () {
18659 return onFocus && onFocus();
18660 }, [onFocus]);
18661 var handleBlur = React.useCallback(function () {
18662 return onBlur && onBlur();
18663 }, [onBlur]);
18664 var handleClear = React.useCallback(function () {
18665 onCancel && onCancel();
18666
18667 if (!input.current) {
18668 return;
18669 }
18670
18671 input.current.value = '';
18672 onChange('');
18673 input.current.focus();
18674 }, [onCancel, onChange]);
18675 React.useEffect(function () {
18676 if (!input.current) {
18677 return;
18678 }
18679
18680 if (focused) {
18681 input.current.focus();
18682 } else {
18683 input.current.blur();
18684 }
18685 }, [focused]);
18686 var clearMarkup = value !== '' && React__default.createElement("button", {
18687 type: "button",
18688 "aria-label": i18n.translate('Polaris.TopBar.SearchField.clearButtonLabel'),
18689 className: styles$1B.Clear,
18690 onClick: handleClear
18691 }, React__default.createElement(Icon, {
18692 source: polarisIcons.CircleCancelMinor
18693 }));
18694 var className = classNames(styles$1B.SearchField, (focused || active) && styles$1B.focused);
18695 return React__default.createElement("div", {
18696 className: className,
18697 onFocus: handleFocus,
18698 onBlur: handleBlur
18699 }, React__default.createElement(VisuallyHidden, null, React__default.createElement("label", {
18700 htmlFor: searchId
18701 }, i18n.translate('Polaris.TopBar.SearchField.search'))), React__default.createElement("input", {
18702 id: searchId,
18703 className: styles$1B.Input,
18704 placeholder: placeholder,
18705 type: "search",
18706 autoCapitalize: "off",
18707 autoComplete: "off",
18708 autoCorrect: "off",
18709 ref: input,
18710 value: value,
18711 onChange: handleChange,
18712 onKeyDown: preventDefault
18713 }), React__default.createElement("span", {
18714 className: styles$1B.Icon
18715 }, React__default.createElement(Icon, {
18716 source: polarisIcons.SearchMinor
18717 })), clearMarkup, React__default.createElement("div", {
18718 className: styles$1B.Backdrop
18719 }));
18720}
18721
18722function preventDefault(event) {
18723 if (event.key === 'Enter') {
18724 event.preventDefault();
18725 }
18726}
18727
18728var styles$1C = {
18729 "MessageIndicatorWrapper": "Polaris-MessageIndicator__MessageIndicatorWrapper",
18730 "MessageIndicator": "Polaris-MessageIndicator"
18731};
18732
18733function MessageIndicator(_ref) {
18734 var children = _ref.children,
18735 active = _ref.active;
18736 var indicatorMarkup = active && React__default.createElement("div", {
18737 className: styles$1C.MessageIndicator
18738 });
18739 return React__default.createElement("div", {
18740 className: styles$1C.MessageIndicatorWrapper
18741 }, indicatorMarkup, children);
18742}
18743
18744var styles$1D = {
18745 "Section": "Polaris-Menu-Message__Section"
18746};
18747
18748function Message(_ref) {
18749 var title = _ref.title,
18750 description = _ref.description,
18751 action = _ref.action,
18752 link = _ref.link,
18753 badge = _ref.badge;
18754 var badgeMarkup = badge && React__default.createElement(Badge, {
18755 status: badge.status
18756 }, badge.content);
18757 var to = link.to,
18758 linkContent = link.content;
18759 var onClick = action.onClick,
18760 actionContent = action.content;
18761 return React__default.createElement("div", {
18762 className: styles$1D.Section
18763 }, React__default.createElement(Popover.Section, null, React__default.createElement(Stack, {
18764 vertical: true,
18765 spacing: "tight"
18766 }, React__default.createElement(TextContainer, null, React__default.createElement(Heading, null, title, badgeMarkup), React__default.createElement("p", null, description)), React__default.createElement(Link, {
18767 url: to
18768 }, linkContent), React__default.createElement(Button, {
18769 plain: true,
18770 onClick: onClick
18771 }, actionContent))));
18772}
18773
18774var styles$1E = {
18775 "ActivatorWrapper": "Polaris-TopBar-Menu__ActivatorWrapper",
18776 "Activator": "Polaris-TopBar-Menu__Activator",
18777 "Section": "Polaris-TopBar-Menu__Section"
18778};
18779
18780function Menu(props) {
18781 var actions = props.actions,
18782 onOpen = props.onOpen,
18783 onClose = props.onClose,
18784 open = props.open,
18785 activatorContent = props.activatorContent,
18786 message = props.message;
18787 var badgeProps = message && message.badge && {
18788 content: message.badge.content,
18789 status: message.badge.status
18790 };
18791 var messageMarkup = message && React__default.createElement(Message, {
18792 title: message.title,
18793 description: message.description,
18794 action: {
18795 onClick: message.action.onClick,
18796 content: message.action.content
18797 },
18798 link: {
18799 to: message.link.to,
18800 content: message.link.content
18801 },
18802 badge: badgeProps
18803 });
18804 var isFullHeight = Boolean(message);
18805 return React__default.createElement(Popover, {
18806 activator: React__default.createElement("div", {
18807 className: styles$1E.ActivatorWrapper
18808 }, React__default.createElement("button", {
18809 type: "button",
18810 className: styles$1E.Activator,
18811 onClick: onOpen
18812 }, activatorContent)),
18813 active: open,
18814 onClose: onClose,
18815 fixed: true,
18816 fullHeight: isFullHeight
18817 }, React__default.createElement(ActionList, {
18818 onActionAnyItem: onClose,
18819 sections: actions
18820 }), messageMarkup);
18821}
18822
18823var styles$1F = {
18824 "Details": "Polaris-TopBar-UserMenu__Details",
18825 "Name": "Polaris-TopBar-UserMenu__Name",
18826 "Detail": "Polaris-TopBar-UserMenu__Detail"
18827};
18828
18829function UserMenu(_ref) {
18830 var name = _ref.name,
18831 detail = _ref.detail,
18832 avatar = _ref.avatar,
18833 initials = _ref.initials,
18834 actions = _ref.actions,
18835 message = _ref.message,
18836 onToggle = _ref.onToggle,
18837 open = _ref.open;
18838 var showIndicator = Boolean(message);
18839 var activatorContentMarkup = React__default.createElement(React__default.Fragment, null, React__default.createElement(MessageIndicator, {
18840 active: showIndicator
18841 }, React__default.createElement(Avatar, {
18842 size: "small",
18843 source: avatar,
18844 initials: initials && initials.replace(' ', '')
18845 })), React__default.createElement("span", {
18846 className: styles$1F.Details
18847 }, React__default.createElement("p", {
18848 className: styles$1F.Name
18849 }, name), React__default.createElement("p", {
18850 className: styles$1F.Detail
18851 }, detail)));
18852 return React__default.createElement(Menu, {
18853 activatorContent: activatorContentMarkup,
18854 open: open,
18855 onOpen: onToggle,
18856 onClose: onToggle,
18857 actions: actions,
18858 message: message
18859 });
18860}
18861
18862var styles$1G = {
18863 "TopBar": "Polaris-TopBar",
18864 "LogoContainer": "Polaris-TopBar__LogoContainer",
18865 "ContextControl": "Polaris-TopBar__ContextControl",
18866 "Logo": "Polaris-TopBar__Logo",
18867 "LogoLink": "Polaris-TopBar__LogoLink",
18868 "NavigationIcon": "Polaris-TopBar__NavigationIcon",
18869 "focused": "Polaris-TopBar--focused",
18870 "Contents": "Polaris-TopBar__Contents",
18871 "SearchField": "Polaris-TopBar__SearchField",
18872 "SecondaryMenu": "Polaris-TopBar__SecondaryMenu"
18873};
18874
18875// subcomponents so explicitly state the subcomponents in the type definition.
18876// Letting this be implicit works in this project but fails in projects that use
18877// generated *.d.ts files.
18878
18879var TopBar = function TopBar(_ref) {
18880 var showNavigationToggle = _ref.showNavigationToggle,
18881 userMenu = _ref.userMenu,
18882 searchResults = _ref.searchResults,
18883 searchField = _ref.searchField,
18884 secondaryMenu = _ref.secondaryMenu,
18885 searchResultsVisible = _ref.searchResultsVisible,
18886 onNavigationToggle = _ref.onNavigationToggle,
18887 onSearchResultsDismiss = _ref.onSearchResultsDismiss,
18888 contextControl = _ref.contextControl;
18889 var i18n = useI18n();
18890
18891 var _useTheme = useTheme(),
18892 logo = _useTheme.logo;
18893
18894 var _useForcibleToggle = useForcibleToggle(false),
18895 _useForcibleToggle2 = _slicedToArray(_useForcibleToggle, 2),
18896 focused = _useForcibleToggle2[0],
18897 _useForcibleToggle2$ = _useForcibleToggle2[1],
18898 forceTrueFocused = _useForcibleToggle2$.forceTrue,
18899 forceFalseFocused = _useForcibleToggle2$.forceFalse;
18900
18901 var className = classNames(styles$1G.NavigationIcon, focused && styles$1G.focused);
18902 var navigationButtonMarkup = showNavigationToggle ? React__default.createElement("button", {
18903 type: "button",
18904 className: className,
18905 onClick: onNavigationToggle,
18906 onFocus: forceTrueFocused,
18907 onBlur: forceFalseFocused,
18908 "aria-label": i18n.translate('Polaris.TopBar.toggleMenuLabel')
18909 }, React__default.createElement(Icon, {
18910 source: polarisIcons.MobileHamburgerMajorMonotone,
18911 color: "white"
18912 })) : null;
18913 var width = getWidth(logo, 104);
18914 var contextMarkup;
18915
18916 if (contextControl) {
18917 contextMarkup = React__default.createElement("div", {
18918 className: styles$1G.ContextControl
18919 }, contextControl);
18920 } else if (logo) {
18921 contextMarkup = React__default.createElement("div", {
18922 className: styles$1G.LogoContainer
18923 }, React__default.createElement(UnstyledLink, {
18924 url: logo.url || '',
18925 className: styles$1G.LogoLink,
18926 style: {
18927 width
18928 }
18929 }, React__default.createElement(Image, {
18930 source: logo.topBarSource || '',
18931 alt: logo.accessibilityLabel || '',
18932 className: styles$1G.Logo,
18933 style: {
18934 width
18935 }
18936 })));
18937 }
18938
18939 var searchResultsMarkup = searchResults && searchResultsVisible ? React__default.createElement(Search, {
18940 visible: searchResultsVisible,
18941 onDismiss: onSearchResultsDismiss
18942 }, searchResults) : null;
18943 var searchMarkup = searchField ? React__default.createElement(React__default.Fragment, null, searchField, searchResultsMarkup) : null;
18944 return React__default.createElement("div", {
18945 className: styles$1G.TopBar
18946 }, navigationButtonMarkup, contextMarkup, React__default.createElement("div", {
18947 className: styles$1G.Contents
18948 }, React__default.createElement("div", {
18949 className: styles$1G.SearchField
18950 }, searchMarkup), React__default.createElement("div", {
18951 className: styles$1G.SecondaryMenu
18952 }, secondaryMenu), userMenu));
18953};
18954TopBar.Menu = Menu;
18955TopBar.SearchField = SearchField;
18956TopBar.UserMenu = UserMenu;
18957
18958/* eslint-enable @typescript-eslint/camelcase */
18959
18960Object.defineProperty(exports, 'Months', {
18961 enumerable: true,
18962 get: function () {
18963 return dates.Months;
18964 }
18965});
18966exports.AccountConnection = AccountConnection;
18967exports.ActionList = ActionList;
18968exports.ActionMenu = ActionMenu;
18969exports.AppBridgeContext = AppBridgeContext;
18970exports.AppProvider = AppProvider;
18971exports.Autocomplete = Autocomplete;
18972exports.Avatar = Avatar;
18973exports.Backdrop = Backdrop;
18974exports.Badge = Badge;
18975exports.Banner = Banner;
18976exports.Breadcrumbs = Breadcrumbs;
18977exports.Button = Button;
18978exports.ButtonGroup = ButtonGroup;
18979exports.CalloutCard = CalloutCard;
18980exports.Caption = Caption;
18981exports.Card = Card;
18982exports.Checkbox = Checkbox$1;
18983exports.ChoiceList = ChoiceList;
18984exports.Collapsible = Collapsible;
18985exports.ColorPicker = ColorPicker;
18986exports.Connected = Connected;
18987exports.ContextualSaveBar = ContextualSaveBar;
18988exports.DATA_ATTRIBUTE = DATA_ATTRIBUTE;
18989exports.DEFAULT_TOAST_DURATION = DEFAULT_TOAST_DURATION;
18990exports.DEFAULT_TOAST_DURATION_WITH_ACTION = DEFAULT_TOAST_DURATION_WITH_ACTION;
18991exports.DataTable = DataTable$1;
18992exports.DatePicker = DatePicker;
18993exports.DescriptionList = DescriptionList;
18994exports.DisplayText = DisplayText;
18995exports.DropZone = DropZone;
18996exports.EmptySearchResult = EmptySearchResult;
18997exports.EmptyState = EmptyState;
18998exports.EventListener = EventListener;
18999exports.ExceptionList = ExceptionList;
19000exports.Filters = Filters$1;
19001exports.Focus = Focus;
19002exports.FooterHelp = FooterHelp;
19003exports.Form = Form;
19004exports.FormLayout = FormLayout;
19005exports.Frame = Frame$1;
19006exports.Heading = Heading;
19007exports.Icon = Icon;
19008exports.Image = Image;
19009exports.Indicator = Indicator;
19010exports.InlineError = InlineError;
19011exports.KeyboardKey = KeyboardKey;
19012exports.KeypressListener = KeypressListener;
19013exports.Label = Label;
19014exports.Labelled = Labelled;
19015exports.Layout = Layout;
19016exports.Link = Link;
19017exports.List = List;
19018exports.Loading = Loading$1;
19019exports.Modal = Modal$1;
19020exports.Navigation = Navigation$1;
19021exports.OptionList = OptionList;
19022exports.Page = Page$1;
19023exports.PageActions = PageActions;
19024exports.Pagination = Pagination;
19025exports.PolarisTestProvider = PolarisTestProvider;
19026exports.Popover = Popover;
19027exports.Portal = Portal;
19028exports.ProgressBar = ProgressBar;
19029exports.RadioButton = RadioButton;
19030exports.RangeSlider = RangeSlider;
19031exports.ResourceItem = ResourceItem;
19032exports.ResourceList = ResourceList$1;
19033exports.ResourcePicker = ResourcePicker$1;
19034exports.ScrollLock = ScrollLock;
19035exports.Scrollable = Scrollable;
19036exports.Select = Select;
19037exports.SettingToggle = SettingToggle;
19038exports.Sheet = Sheet;
19039exports.SkeletonBodyText = SkeletonBodyText;
19040exports.SkeletonDisplayText = SkeletonDisplayText;
19041exports.SkeletonPage = SkeletonPage;
19042exports.SkeletonThumbnail = SkeletonThumbnail;
19043exports.Spinner = Spinner;
19044exports.Stack = Stack;
19045exports.Sticky = Sticky$1;
19046exports.Subheading = Subheading;
19047exports.Tabs = Tabs$1;
19048exports.Tag = Tag;
19049exports.TextContainer = TextContainer;
19050exports.TextField = TextField;
19051exports.TextStyle = TextStyle;
19052exports.ThemeProvider = ThemeProvider;
19053exports.Thumbnail = Thumbnail;
19054exports.Toast = Toast$1;
19055exports.Tooltip = Tooltip;
19056exports.TopBar = TopBar;
19057exports.TrapFocus = TrapFocus;
19058exports.Truncate = Truncate;
19059exports.UNSTABLE_Tokens = Tokens;
19060exports.UNSTABLE_buildColors = buildColors;
19061exports.UNSTABLE_roleVariants = roleVariants;
19062exports.UNSTABLE_toCssCustomPropertySyntax = toCssCustomPropertySyntax;
19063exports.UnstyledLink = UnstyledLink;
19064exports.VisuallyHidden = VisuallyHidden;
19065exports._SECRET_INTERNAL_SCROLL_LOCK_MANAGER_CONTEXT = ScrollLockManagerContext;
19066exports._SECRET_INTERNAL_WITHIN_CONTENT_CONTEXT = WithinContentContext;
19067exports.buttonFrom = buttonFrom;
19068exports.buttonsFrom = buttonsFrom;
19069exports.errorTextID = errorTextID;
19070exports.hsbToHex = hsbToHex;
19071exports.hsbToRgb = hsbToRgb;
19072exports.hslToRgb = hslToRgb;
19073exports.isNavigationItemActive = isNavigationItemActive;
19074exports.rgbString = rgbString;
19075exports.rgbToHex = rgbToHex;
19076exports.rgbToHsb = rgbToHsb;
19077exports.rgbToHsl = rgbToHsl;
19078exports.rgbaString = rgbaString;