@commercetools-uikit/filters 19.15.0 → 19.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5,16 +5,35 @@ Object.defineProperty(exports, '__esModule', { value: true });
5
5
  var react = require('@emotion/react');
6
6
  var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
7
7
  var _pt = require('prop-types');
8
+ var _mapInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/map');
9
+ var _reduceInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/reduce');
10
+ var _findInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/find');
11
+ var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
12
+ var _sortInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/sort');
13
+ var _includesInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/includes');
14
+ var _concatInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/concat');
15
+ var react$1 = require('react');
8
16
  var Popover = require('@radix-ui/react-popover');
17
+ var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
18
+ var designSystem = require('@commercetools-uikit/design-system');
9
19
  var FlatButton = require('@commercetools-uikit/flat-button');
10
- var SelectInput = require('@commercetools-uikit/select-input');
11
20
  var icons = require('@commercetools-uikit/icons');
12
- var react$1 = require('react');
21
+ var SelectInput = require('@commercetools-uikit/select-input');
13
22
  var Spacings = require('@commercetools-uikit/spacings');
14
- var designSystem = require('@commercetools-uikit/design-system');
15
23
  var reactIntl = require('react-intl');
16
24
  var jsxRuntime = require('@emotion/react/jsx-runtime');
17
- var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
25
+ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
26
+ var _objectWithoutProperties = require('@babel/runtime-corejs3/helpers/objectWithoutProperties');
27
+ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
28
+ var _Array$from = require('@babel/runtime-corejs3/core-js-stable/array/from');
29
+ var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
30
+ var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
31
+ var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
32
+ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
33
+ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
34
+ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
35
+ var SecondaryIconButton = require('@commercetools-uikit/secondary-icon-button');
36
+ var IconButton = require('@commercetools-uikit/icon-button');
18
37
 
19
38
  function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
20
39
 
@@ -37,46 +56,344 @@ function _interopNamespace(e) {
37
56
  }
38
57
 
39
58
  var _pt__default = /*#__PURE__*/_interopDefault(_pt);
59
+ var _mapInstanceProperty__default = /*#__PURE__*/_interopDefault(_mapInstanceProperty);
60
+ var _reduceInstanceProperty__default = /*#__PURE__*/_interopDefault(_reduceInstanceProperty);
61
+ var _findInstanceProperty__default = /*#__PURE__*/_interopDefault(_findInstanceProperty);
62
+ var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
63
+ var _sortInstanceProperty__default = /*#__PURE__*/_interopDefault(_sortInstanceProperty);
64
+ var _includesInstanceProperty__default = /*#__PURE__*/_interopDefault(_includesInstanceProperty);
65
+ var _concatInstanceProperty__default = /*#__PURE__*/_interopDefault(_concatInstanceProperty);
40
66
  var Popover__namespace = /*#__PURE__*/_interopNamespace(Popover);
67
+ var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
41
68
  var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
42
69
  var SelectInput__default = /*#__PURE__*/_interopDefault(SelectInput);
43
70
  var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
44
- var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
71
+ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
72
+ var _Array$from__default = /*#__PURE__*/_interopDefault(_Array$from);
73
+ var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
74
+ var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
75
+ var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
76
+ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
77
+ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
78
+ var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
79
+ var SecondaryIconButton__default = /*#__PURE__*/_interopDefault(SecondaryIconButton);
80
+ var IconButton__default = /*#__PURE__*/_interopDefault(IconButton);
45
81
 
46
- var messages = reactIntl.defineMessages({
47
- addFilterButtonLabel: {
48
- id: 'UIKit.AddFilterButton.addFilterButtonLabel',
49
- description: 'Label for the add filter button',
50
- defaultMessage: 'Add filter'
51
- },
52
- clearAllFiltersButtonLabel: {
53
- id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
54
- description: 'Label for the clear all filters button',
82
+ var messages$1 = reactIntl.defineMessages({
83
+ clearAllButtonLabel: {
84
+ id: 'UIKit.ClearAllButton.clearAllButtonLabel',
85
+ description: 'Label for the clear all button',
55
86
  defaultMessage: 'Clear all'
56
- },
57
- filtersButtonLabel: {
58
- id: 'UIKit.FiltersButton.filtersButtonLabel',
59
- description: 'Label for the filters button',
60
- defaultMessage: 'Filters'
61
87
  }
62
88
  });
63
89
 
90
+ const footerContainerStyles = /*#__PURE__*/react.css("border-top:", designSystem.designTokens.borderWidth1, " solid ", designSystem.designTokens.colorNeutral90, ";padding-top:", designSystem.designTokens.spacing20, ";display:grid;grid-template-columns:1fr 1fr;align-items:center;width:100%;div:last-of-type{display:flex;justify-content:flex-end;}" + (process.env.NODE_ENV === "production" ? "" : ";label:footerContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZvb3Rlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUJpQyIsImZpbGUiOiJmb290ZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBSZWFjdE5vZGUsIHR5cGUgTW91c2VFdmVudCwgdHlwZSBLZXlib2FyZEV2ZW50IH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgRmxhdEJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9mbGF0LWJ1dHRvbic7XG5pbXBvcnQgeyBDbG9zZUJvbGRJY29uIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbnMnO1xuaW1wb3J0IHsgdXNlSW50bCB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IG1lc3NhZ2VzIGZyb20gJy4vbWVzc2FnZXMnO1xuXG50eXBlIFRGb290ZXJQcm9wcyA9IHtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgYGFwcGx5YCBidXR0b24gaW4gTWVudSBCb2R5IEZvb3RlciBpcyBkaXNwbGF5ZWRcbiAgICovXG4gIHJlbmRlckFwcGx5QnV0dG9uPzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBhIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xufTtcblxuY29uc3QgZm9vdGVyQ29udGFpbmVyU3R5bGVzID0gY3NzYFxuICBib3JkZXItdG9wOiAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9IHNvbGlkICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDkwfTtcblxuICBwYWRkaW5nLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcblxuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDFmciAxZnI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHdpZHRoOiAxMDAlO1xuICBkaXY6bGFzdC1vZi10eXBlIHtcbiAgICBkaXNwbGF5OiBmbGV4O1xuICAgIGp1c3RpZnktY29udGVudDogZmxleC1lbmQ7XG4gIH1cbmA7XG5cbmNvbnN0IEZvb3RlciA9ICh7IHJlbmRlckFwcGx5QnV0dG9uLCBvbkNsZWFyUmVxdWVzdCB9OiBURm9vdGVyUHJvcHMpID0+IHtcbiAgY29uc3QgaW50bCA9IHVzZUludGwoKTtcbiAgaWYgKCFyZW5kZXJBcHBseUJ1dHRvbiAmJiAhb25DbGVhclJlcXVlc3QpIHJldHVybiBudWxsO1xuXG4gIHJldHVybiAoXG4gICAgPGZvb3RlciBjc3M9e2Zvb3RlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2PntyZW5kZXJBcHBseUJ1dHRvbiAmJiByZW5kZXJBcHBseUJ1dHRvbigpfTwvZGl2PlxuICAgICAgPGRpdj5cbiAgICAgICAge29uQ2xlYXJSZXF1ZXN0ICYmIChcbiAgICAgICAgICA8RmxhdEJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICB0b25lPVwic2Vjb25kYXJ5XCJcbiAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xlYXJSZXF1ZXN0fVxuICAgICAgICAgICAgbGFiZWw9e2ludGwuZm9ybWF0TWVzc2FnZShtZXNzYWdlcy5jbGVhckFsbEJ1dHRvbkxhYmVsKX1cbiAgICAgICAgICAvPlxuICAgICAgICApfVxuICAgICAgPC9kaXY+XG4gICAgPC9mb290ZXI+XG4gICk7XG59O1xuXG5Gb290ZXIuZGlzcGxheU5hbWUgPSAnRm9vdGVyJztcbmV4cG9ydCBkZWZhdWx0IEZvb3RlcjtcbiJdfQ== */");
91
+ const Footer = _ref => {
92
+ let renderApplyButton = _ref.renderApplyButton,
93
+ onClearRequest = _ref.onClearRequest;
94
+ const intl = reactIntl.useIntl();
95
+ if (!renderApplyButton && !onClearRequest) return null;
96
+ return jsxRuntime.jsxs("footer", {
97
+ css: footerContainerStyles,
98
+ children: [jsxRuntime.jsx("div", {
99
+ children: renderApplyButton && renderApplyButton()
100
+ }), jsxRuntime.jsx("div", {
101
+ children: onClearRequest && jsxRuntime.jsx(FlatButton__default["default"], {
102
+ icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
103
+ tone: "secondary",
104
+ onClick: onClearRequest,
105
+ label: intl.formatMessage(messages$1.clearAllButtonLabel)
106
+ })
107
+ })]
108
+ });
109
+ };
110
+ Footer.propTypes = process.env.NODE_ENV !== "production" ? {
111
+ renderApplyButton: _pt__default["default"].func,
112
+ onClearRequest: _pt__default["default"].func
113
+ } : {};
114
+ Footer.displayName = 'Footer';
115
+ var Footer$1 = Footer;
116
+
117
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$2() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
118
+ const headerContainerStyles = /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral40, ";font-weight:", designSystem.designTokens.fontWeight500, ";font-size:", designSystem.designTokens.fontSize20, ";line-height:", designSystem.designTokens.lineHeight20, ";display:grid;grid-template-columns:1fr min-content;align-items:center;padding-bottom:", designSystem.designTokens.spacing10, ";border-bottom:1px solid ", designSystem.designTokens.colorNeutral90, ";width:100%;" + (process.env.NODE_ENV === "production" ? "" : ";label:headerContainerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0JpQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */");
119
+ const selectInputStyles = /*#__PURE__*/react.css("flex:0 0 auto;max-width:", designSystem.designTokens.constraint3, ";margin-left:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:selectInputStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEM2QiIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */");
120
+ const sortButtonMargin = /*#__PURE__*/react.css("margin-right:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:sortButtonMargin;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0Q0QiIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */");
121
+ const operatorInputContainer = process.env.NODE_ENV === "production" ? {
122
+ name: "1ckoci3",
123
+ styles: "word-break:break-word;display:flex;align-items:center"
124
+ } : {
125
+ name: "8xu73l-operatorInputContainer",
126
+ styles: "word-break:break-word;display:flex;align-items:center;label:operatorInputContainer;",
127
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0RrQyIsImZpbGUiOiJoZWFkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdXNlU3RhdGUsXG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IEljb25CdXR0b24gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgU29ydGluZ0ljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxudHlwZSBUSGVhZGVyUHJvcHMgPSB7XG4gIC8qKlxuICAgKiB0aGUgbGFiZWwgb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHJlbmRlciB0aGUgb3BlcmF0b3IgaW5wdXRcbiAgICovXG4gIHJlbmRlck9wZXJhdG9yc0lucHV0PzogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGZ1bmN0aW9uIHRvIHNvcnQgdGhlIGRhdGFcbiAgICovXG4gIG9uU29ydFJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogdGhlIHdpZHRoIG9mIHRoZSBtZW51IGhlYWRlclxuICAgKi9cbn07XG5cbmNvbnN0IGhlYWRlckNvbnRhaW5lclN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgZGlzcGxheTogZ3JpZDtcbiAgZ3JpZC10ZW1wbGF0ZS1jb2x1bW5zOiAxZnIgbWluLWNvbnRlbnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctYm90dG9tOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9O1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuICB3aWR0aDogMTAwJTtcbmA7XG5cbmNvbnN0IHNlbGVjdElucHV0U3R5bGVzID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50M307XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuY29uc3Qgc29ydEJ1dHRvbk1hcmdpbiA9IGNzc2BcbiAgbWFyZ2luLXJpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuYDtcblxuY29uc3Qgb3BlcmF0b3JJbnB1dENvbnRhaW5lciA9IGNzc2BcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XG5cbmNvbnN0IEhlYWRlciA9IChwcm9wczogVEhlYWRlclByb3BzKSA9PiB7XG4gIGNvbnN0IFtpc0FjdGl2ZSwgc2V0SXNBY3RpdmVdID0gdXNlU3RhdGUoZmFsc2UpO1xuXG4gIHJldHVybiAoXG4gICAgPGhlYWRlciBjc3M9e2hlYWRlckNvbnRhaW5lclN0eWxlc30+XG4gICAgICA8ZGl2XG4gICAgICAgIGNzcz17W29wZXJhdG9ySW5wdXRDb250YWluZXIsIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgc29ydEJ1dHRvbk1hcmdpbl19XG4gICAgICA+XG4gICAgICAgIDxkaXY+e3Byb3BzLmxhYmVsfTwvZGl2PlxuICAgICAgICB7cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQgJiYgKFxuICAgICAgICAgIDxkaXYgY3NzPXtzZWxlY3RJbnB1dFN0eWxlc30+e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0KCl9PC9kaXY+XG4gICAgICAgICl9XG4gICAgICA8L2Rpdj5cbiAgICAgIHtwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIChcbiAgICAgICAgPEljb25CdXR0b25cbiAgICAgICAgICBzaXplPVwiMjBcIlxuICAgICAgICAgIHRoZW1lPXtpc0FjdGl2ZSA/ICdpbmZvJyA6ICdkZWZhdWx0J31cbiAgICAgICAgICBsYWJlbD1cIlNvcnRcIlxuICAgICAgICAgIGljb249ezxTb3J0aW5nSWNvbiAvPn1cbiAgICAgICAgICBpc1RvZ2dsZUJ1dHRvbj17dHJ1ZX1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgc2V0SXNBY3RpdmUoIWlzQWN0aXZlKTtcbiAgICAgICAgICAgIHJldHVybiBwcm9wcy5vblNvcnRSZXF1ZXN0ICYmIHByb3BzLm9uU29ydFJlcXVlc3QoZSk7XG4gICAgICAgICAgfX1cbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgPC9oZWFkZXI+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBIZWFkZXI7XG4iXX0= */",
128
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
129
+ };
130
+ const Header = props => {
131
+ const _useState = react$1.useState(false),
132
+ _useState2 = _slicedToArray(_useState, 2),
133
+ isActive = _useState2[0],
134
+ setIsActive = _useState2[1];
135
+ return jsxRuntime.jsxs("header", {
136
+ css: headerContainerStyles,
137
+ children: [jsxRuntime.jsxs("div", {
138
+ css: [operatorInputContainer, props.onSortRequest && sortButtonMargin, process.env.NODE_ENV === "production" ? "" : ";label:Header;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImhlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0VRIiwiZmlsZSI6ImhlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB1c2VTdGF0ZSxcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIHR5cGUgTW91c2VFdmVudCxcbiAgdHlwZSBLZXlib2FyZEV2ZW50LFxufSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgSWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29uLWJ1dHRvbic7XG5pbXBvcnQgeyBTb3J0aW5nSWNvbiB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2ljb25zJztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG50eXBlIFRIZWFkZXJQcm9wcyA9IHtcbiAgLyoqXG4gICAqIHRoZSBsYWJlbCBvZiB0aGUgbWVudSBoZWFkZXJcbiAgICovXG4gIGxhYmVsOiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiB0aGUgZnVuY3Rpb24gdG8gcmVuZGVyIHRoZSBvcGVyYXRvciBpbnB1dFxuICAgKi9cbiAgcmVuZGVyT3BlcmF0b3JzSW5wdXQ/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiB0aGUgZnVuY3Rpb24gdG8gc29ydCB0aGUgZGF0YVxuICAgKi9cbiAgb25Tb3J0UmVxdWVzdD86IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiB0aGUgd2lkdGggb2YgdGhlIG1lbnUgaGVhZGVyXG4gICAqL1xufTtcblxuY29uc3QgaGVhZGVyQ29udGFpbmVyU3R5bGVzID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBmb250LXdlaWdodDogJHtkZXNpZ25Ub2tlbnMuZm9udFdlaWdodDUwMH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGxpbmUtaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5saW5lSGVpZ2h0MjB9O1xuICBkaXNwbGF5OiBncmlkO1xuICBncmlkLXRlbXBsYXRlLWNvbHVtbnM6IDFmciBtaW4tY29udGVudDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZy1ib3R0b206ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIGJvcmRlci1ib3R0b206IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG4gIHdpZHRoOiAxMDAlO1xuYDtcblxuY29uc3Qgc2VsZWN0SW5wdXRTdHlsZXMgPSBjc3NgXG4gIGZsZXg6IDAgMCBhdXRvO1xuICBtYXgtd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQzfTtcbiAgbWFyZ2luLWxlZnQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG5gO1xuXG5jb25zdCBzb3J0QnV0dG9uTWFyZ2luID0gY3NzYFxuICBtYXJnaW4tcmlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc0MH07XG5gO1xuXG5jb25zdCBvcGVyYXRvcklucHV0Q29udGFpbmVyID0gY3NzYFxuICB3b3JkLWJyZWFrOiBicmVhay13b3JkO1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuYDtcblxuY29uc3QgSGVhZGVyID0gKHByb3BzOiBUSGVhZGVyUHJvcHMpID0+IHtcbiAgY29uc3QgW2lzQWN0aXZlLCBzZXRJc0FjdGl2ZV0gPSB1c2VTdGF0ZShmYWxzZSk7XG5cbiAgcmV0dXJuIChcbiAgICA8aGVhZGVyIGNzcz17aGVhZGVyQ29udGFpbmVyU3R5bGVzfT5cbiAgICAgIDxkaXZcbiAgICAgICAgY3NzPXtbb3BlcmF0b3JJbnB1dENvbnRhaW5lciwgcHJvcHMub25Tb3J0UmVxdWVzdCAmJiBzb3J0QnV0dG9uTWFyZ2luXX1cbiAgICAgID5cbiAgICAgICAgPGRpdj57cHJvcHMubGFiZWx9PC9kaXY+XG4gICAgICAgIHtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dCAmJiAoXG4gICAgICAgICAgPGRpdiBjc3M9e3NlbGVjdElucHV0U3R5bGVzfT57cHJvcHMucmVuZGVyT3BlcmF0b3JzSW5wdXQoKX08L2Rpdj5cbiAgICAgICAgKX1cbiAgICAgIDwvZGl2PlxuICAgICAge3Byb3BzLm9uU29ydFJlcXVlc3QgJiYgKFxuICAgICAgICA8SWNvbkJ1dHRvblxuICAgICAgICAgIHNpemU9XCIyMFwiXG4gICAgICAgICAgdGhlbWU9e2lzQWN0aXZlID8gJ2luZm8nIDogJ2RlZmF1bHQnfVxuICAgICAgICAgIGxhYmVsPVwiU29ydFwiXG4gICAgICAgICAgaWNvbj17PFNvcnRpbmdJY29uIC8+fVxuICAgICAgICAgIGlzVG9nZ2xlQnV0dG9uPXt0cnVlfVxuICAgICAgICAgIG9uQ2xpY2s9eyhlKSA9PiB7XG4gICAgICAgICAgICBzZXRJc0FjdGl2ZSghaXNBY3RpdmUpO1xuICAgICAgICAgICAgcmV0dXJuIHByb3BzLm9uU29ydFJlcXVlc3QgJiYgcHJvcHMub25Tb3J0UmVxdWVzdChlKTtcbiAgICAgICAgICB9fVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L2hlYWRlcj5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEhlYWRlcjtcbiJdfQ== */"],
139
+ children: [jsxRuntime.jsx("div", {
140
+ children: props.label
141
+ }), props.renderOperatorsInput && jsxRuntime.jsx("div", {
142
+ css: selectInputStyles,
143
+ children: props.renderOperatorsInput()
144
+ })]
145
+ }), props.onSortRequest && jsxRuntime.jsx(IconButton__default["default"], {
146
+ size: "20",
147
+ theme: isActive ? 'info' : 'default',
148
+ label: "Sort",
149
+ icon: jsxRuntime.jsx(icons.SortingIcon, {}),
150
+ isToggleButton: true,
151
+ onClick: e => {
152
+ setIsActive(!isActive);
153
+ return props.onSortRequest && props.onSortRequest(e);
154
+ }
155
+ })]
156
+ });
157
+ };
158
+ Header.propTypes = process.env.NODE_ENV !== "production" ? {
159
+ label: _pt__default["default"].node.isRequired,
160
+ renderOperatorsInput: _pt__default["default"].func,
161
+ onSortRequest: _pt__default["default"].func
162
+ } : {};
163
+ var Header$1 = Header;
164
+
165
+ const triggerWrapper = /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral40, ";background-color:", designSystem.designTokens.colorSurface, ";font-size:", designSystem.designTokens.fontSize20, ";font-weight:", designSystem.designTokens.fontWeight500, ";line-height:", designSystem.designTokens.lineHeight20, ";position:relative;display:inline-flex;align-items:center;gap:", designSystem.designTokens.spacing20, ";padding:3px ", designSystem.designTokens.spacing25, ";border-radius:", designSystem.designTokens.borderRadius20, ";box-shadow:0 0 0 ", designSystem.designTokens.borderWidth1, " ", designSystem.designTokens.colorNeutral85, ";cursor:pointer;height:", designSystem.designTokens.spacing50, ";max-width:min(100%, ", designSystem.designTokens.constraint13, ");align-self:flex-start;&:hover{background-color:", designSystem.designTokens.colorPrimary98, ";.ui-kit-filter-trigger-badge-container{background:linear-gradient(\n to right,\n transparent,\n ", designSystem.designTokens.colorPrimary98, " 25%\n );}}" + (process.env.NODE_ENV === "production" ? "" : ";label:triggerWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHaUMiLCJmaWxlIjoidHJpZ2dlci1idXR0b24uc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbmV4cG9ydCBjb25zdCB0cmlnZ2VyV3JhcHBlciA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlfTtcbiAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZTIwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuICBwYWRkaW5nOiAzcHggJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzI1fTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICBib3gtc2hhZG93OiAwIDAgMCAke2Rlc2lnblRva2Vucy5ib3JkZXJXaWR0aDF9ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDg1fTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc1MH07XG4gIG1heC13aWR0aDogbWluKDEwMCUsICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQxM30pO1xuICBhbGlnbi1zZWxmOiBmbGV4LXN0YXJ0O1xuICAmOmhvdmVyIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH07XG4gICAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgICAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgICAgICB0byByaWdodCxcbiAgICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTk4fSAyNSVcbiAgICAgICk7XG4gICAgfVxuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgZGlzYWJsZWQgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgICAgdG8gcmlnaHQsXG4gICAgICB0cmFuc3BhcmVudCxcbiAgICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fSAyNSVcbiAgICApO1xuICB9XG4gID4gKiB7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBtYWluQWN0aW9uQnV0dG9uID0gY3NzYFxuICBiYWNrZ3JvdW5kOiB0cmFuc3BhcmVudDtcbiAgYm9yZGVyOiAwO1xuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGluc2V0OiAwO1xuICB6LWluZGV4OiAxO1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXMyMH07XG4gICY6Zm9jdXMge1xuICAgIGJveC1zaGFkb3c6IDAgMCAwIDJweCAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH07XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCByZW1vdmVCdXR0b24gPSBjc3NgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgei1pbmRleDogMjtcbiAgZmxleC1ncm93OiAwO1xuICBmbGV4LXNocmluazogMDtcbiAgZGlzcGxheTogZmxleDtcbiAgc3ZnIHtcbiAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH0gIWltcG9ydGFudDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGZpbGw6ICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTQwfSAhaW1wb3J0YW50O1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGxhYmVsID0gY3NzYFxuICBmbGV4OiAwIDAgYXV0bztcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIGN1cnNvcjogaW5oZXJpdDtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgbWF4LXdpZHRoOiAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50Nn07XG5gO1xuXG5leHBvcnQgY29uc3Qgb3BlcmF0b3JDb250YWluZXIgPSBjc3NgXG4gIGZvbnQtc3R5bGU6IGl0YWxpYztcbiAgZm9udC13ZWlnaHQ6IDMwMDtcbiAgbWFyZ2luLWxlZnQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG5gO1xuXG5leHBvcnQgY29uc3QgdmFsdWVzQ29udGFpbmVyID0gY3NzYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBwYWRkaW5nLWxlZnQ6IDA7XG4gIG1hcmdpbjogMDtcbmA7XG5cbmV4cG9ydCBjb25zdCBiYWRnZUNvbnRhaW5lciA9IGNzc2BcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICByaWdodDogMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZy1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgdG8gcmlnaHQsXG4gICAgdHJhbnNwYXJlbnQsXG4gICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlfSAyNSVcbiAgKTtcbmA7XG4iXX0= */");
166
+ const disabled = /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral40, ";background-color:", designSystem.designTokens.colorNeutral95, ";cursor:not-allowed;&:hover{background-color:", designSystem.designTokens.colorNeutral95, ";.ui-kit-filter-trigger-badge-container{background:linear-gradient(\n to right,\n transparent,\n ", designSystem.designTokens.colorNeutral95, " 25%\n );}}.ui-kit-filter-trigger-badge-container{background:linear-gradient(\n to right,\n transparent,\n ", designSystem.designTokens.colorNeutral95, " 25%\n );}>*{pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:disabled;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQzJCIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
167
+ const mainActionButton = /*#__PURE__*/react.css("background:transparent;border:0;position:absolute;inset:0;z-index:1;border-radius:", designSystem.designTokens.borderRadius20, ";&:focus{box-shadow:0 0 0 2px ", designSystem.designTokens.colorPrimary40, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:mainActionButton;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUEwRG1DIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
168
+ const removeButton = /*#__PURE__*/react.css("position:relative;z-index:2;flex-grow:0;flex-shrink:0;display:flex;svg{fill:", designSystem.designTokens.colorNeutral40, "!important;&:hover{fill:", designSystem.designTokens.colorPrimary40, "!important;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:removeButton;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFzRStCIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
169
+ const label = /*#__PURE__*/react.css("flex:0 0 auto;overflow:hidden;text-overflow:ellipsis;cursor:inherit;white-space:nowrap;max-width:", designSystem.designTokens.constraint6, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:label;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRndCIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
170
+ const operatorContainer = /*#__PURE__*/react.css("font-style:italic;font-weight:300;margin-left:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:operatorContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2Rm9DIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
171
+ const valuesContainer = /*#__PURE__*/react.css("display:flex;align-items:center;justify-content:flex-start;gap:", designSystem.designTokens.spacing10, ";overflow:hidden;position:relative;padding-left:0;margin:0;" + (process.env.NODE_ENV === "production" ? "" : ";label:valuesContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtR2tDIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
172
+ const badgeContainer = /*#__PURE__*/react.css("position:absolute;right:0;display:flex;align-items:center;padding-left:", designSystem.designTokens.spacing30, ";background:linear-gradient(\n to right,\n transparent,\n ", designSystem.designTokens.colorSurface, " 25%\n );" + (process.env.NODE_ENV === "production" ? "" : ";label:badgeContainer;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE4R2lDIiwiZmlsZSI6InRyaWdnZXItYnV0dG9uLnN0eWxlcy50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgY29uc3QgdHJpZ2dlcldyYXBwZXIgPSBjc3NgXG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw0MH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NTAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfTtcbiAgcGFkZGluZzogM3B4ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyNX07XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgYm94LXNoYWRvdzogMCAwIDAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyV2lkdGgxfSAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw4NX07XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNTB9O1xuICBtYXgtd2lkdGg6IG1pbigxMDAlLCAke2Rlc2lnblRva2Vucy5jb25zdHJhaW50MTN9KTtcbiAgYWxpZ24tc2VsZjogZmxleC1zdGFydDtcbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5OTh9O1xuICAgIC51aS1raXQtZmlsdGVyLXRyaWdnZXItYmFkZ2UtY29udGFpbmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgICAgdG8gcmlnaHQsXG4gICAgICAgIHRyYW5zcGFyZW50LFxuICAgICAgICAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5OH0gMjUlXG4gICAgICApO1xuICAgIH1cbiAgfVxuYDtcblxuZXhwb3J0IGNvbnN0IGRpc2FibGVkID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX07XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDk1fTtcbiAgICAudWkta2l0LWZpbHRlci10cmlnZ2VyLWJhZGdlLWNvbnRhaW5lciB7XG4gICAgICBiYWNrZ3JvdW5kOiBsaW5lYXItZ3JhZGllbnQoXG4gICAgICAgIHRvIHJpZ2h0LFxuICAgICAgICB0cmFuc3BhcmVudCxcbiAgICAgICAgJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTV9IDI1JVxuICAgICAgKTtcbiAgICB9XG4gIH1cbiAgLnVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXIge1xuICAgIGJhY2tncm91bmQ6IGxpbmVhci1ncmFkaWVudChcbiAgICAgIHRvIHJpZ2h0LFxuICAgICAgdHJhbnNwYXJlbnQsXG4gICAgICAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5NX0gMjUlXG4gICAgKTtcbiAgfVxuICA+ICoge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgbWFpbkFjdGlvbkJ1dHRvbiA9IGNzc2BcbiAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gIGJvcmRlcjogMDtcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBpbnNldDogMDtcbiAgei1pbmRleDogMTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICAmOmZvY3VzIHtcbiAgICBib3gtc2hhZG93OiAwIDAgMCAycHggJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5NDB9O1xuICB9XG5gO1xuXG5leHBvcnQgY29uc3QgcmVtb3ZlQnV0dG9uID0gY3NzYFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIHotaW5kZXg6IDI7XG4gIGZsZXgtZ3JvdzogMDtcbiAgZmxleC1zaHJpbms6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHN2ZyB7XG4gICAgZmlsbDogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9ICFpbXBvcnRhbnQ7XG4gICAgJjpob3ZlciB7XG4gICAgICBmaWxsOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk0MH0gIWltcG9ydGFudDtcbiAgICB9XG4gIH1cbmA7XG5cbmV4cG9ydCBjb25zdCBsYWJlbCA9IGNzc2BcbiAgZmxleDogMCAwIGF1dG87XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICBjdXJzb3I6IGluaGVyaXQ7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG1heC13aWR0aDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDZ9O1xuYDtcblxuZXhwb3J0IGNvbnN0IG9wZXJhdG9yQ29udGFpbmVyID0gY3NzYFxuICBmb250LXN0eWxlOiBpdGFsaWM7XG4gIGZvbnQtd2VpZ2h0OiAzMDA7XG4gIG1hcmdpbi1sZWZ0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuYDtcblxuZXhwb3J0IGNvbnN0IHZhbHVlc0NvbnRhaW5lciA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBnYXA6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcxMH07XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW46IDA7XG5gO1xuXG5leHBvcnQgY29uc3QgYmFkZ2VDb250YWluZXIgPSBjc3NgXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgcmlnaHQ6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmctbGVmdDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgYmFja2dyb3VuZDogbGluZWFyLWdyYWRpZW50KFxuICAgIHRvIHJpZ2h0LFxuICAgIHRyYW5zcGFyZW50LFxuICAgICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX0gMjUlXG4gICk7XG5gO1xuIl19 */");
173
+
174
+ const badgeStyles = /*#__PURE__*/react.css("font-size:", designSystem.designTokens.fontSize20, ";font-weight:", designSystem.designTokens.fontWeight500, ";line-height:", designSystem.designTokens.lineHeight20, ";color:", designSystem.designTokens.colorSurface, ";background-color:", designSystem.designTokens.colorInfo, ";padding:0 calc(", designSystem.designTokens.spacing05, " + ", designSystem.designTokens.spacing10, ");border-radius:", designSystem.designTokens.borderRadius20, ";display:inline-flex;flex-direction:column;justify-content:center;align-items:center;height:", designSystem.designTokens.spacing40, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:badgeStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhZGdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QnVCIiwiZmlsZSI6ImJhZGdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgdHlwZSBUQmFkZ2VQcm9wcyA9IHtcbiAgLyoqXG4gICAqIENTUyBJRCBmb3IgYmFkZ2UsIHVzZWQgdG8gc3BlY2lmeSByZWxhdGlvbnNoaXAgd2l0aCBwYXJlbnQgaW4gcGFyZW50J3MgYGFyaWEtY29udHJvbHNgIHByb3BlcnR5XG4gICAqIHNlZSBodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEtMS4xLyNzdGF0dXNcbiAgICovXG4gIGlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJZiBgdHJ1ZWAsIGluZGljYXRlcyB0aGF0IHRoZSBlbGVtZW50IGlzIGluIGEgZGlzYWJsZWQgc3RhdGUuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN0cmluZyB0byBiZSBkaXNwbGF5ZWQgaW4gYmFkZ2UsIGdlbmVyYWxseSBhIGNvdW50IG9mIHNvbWUga2luZFxuICAgKi9cbiAgbGFiZWw6IHN0cmluZztcblxuICAvKipcbiAgICogT3B0aW9uYWwgZGVzY3JpcHRpdmUgZXhwbGFuYXRpb24gb2YgbGFiZWwgKGUuZy4gXCIrNCBhZGRpdGlvbmFsIGZpbHRlcnMgYXBwbGllZFwiKVxuICAgKi9cbiAgWydhcmlhLWxhYmVsJ10/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBiYWRnZVN0eWxlcyA9IGNzc2BcbiAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZTIwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9ySW5mb307XG4gIHBhZGRpbmc6IDAgY2FsYygke2Rlc2lnblRva2Vucy5zcGFjaW5nMDV9ICsgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfSk7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc0MH07XG5gO1xuXG5jb25zdCBkaXNhYmxlZEJhZGdlU3R5bGVzID0gY3NzYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWx9O1xuYDtcblxuZnVuY3Rpb24gQmFkZ2UocHJvcHM6IFRCYWRnZVByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPHNwYW5cbiAgICAgIGFyaWEtbGFiZWw9e3Byb3BzWydhcmlhLWxhYmVsJ119XG4gICAgICBjc3M9e1tiYWRnZVN0eWxlcywgcHJvcHMuaXNEaXNhYmxlZCAmJiBkaXNhYmxlZEJhZGdlU3R5bGVzXX1cbiAgICAgIGlkPXtwcm9wcy5pZH1cbiAgICAgIHJvbGU9XCJzdGF0dXNcIlxuICAgID5cbiAgICAgIHtwcm9wcy5sYWJlbH1cbiAgICA8L3NwYW4+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEJhZGdlO1xuIl19 */");
175
+ const disabledBadgeStyles = /*#__PURE__*/react.css("background-color:", designSystem.designTokens.colorNeutral, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:disabledBadgeStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhZGdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QytCIiwiZmlsZSI6ImJhZGdlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuXG5leHBvcnQgdHlwZSBUQmFkZ2VQcm9wcyA9IHtcbiAgLyoqXG4gICAqIENTUyBJRCBmb3IgYmFkZ2UsIHVzZWQgdG8gc3BlY2lmeSByZWxhdGlvbnNoaXAgd2l0aCBwYXJlbnQgaW4gcGFyZW50J3MgYGFyaWEtY29udHJvbHNgIHByb3BlcnR5XG4gICAqIHNlZSBodHRwczovL3d3dy53My5vcmcvVFIvd2FpLWFyaWEtMS4xLyNzdGF0dXNcbiAgICovXG4gIGlkOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJZiBgdHJ1ZWAsIGluZGljYXRlcyB0aGF0IHRoZSBlbGVtZW50IGlzIGluIGEgZGlzYWJsZWQgc3RhdGUuXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN0cmluZyB0byBiZSBkaXNwbGF5ZWQgaW4gYmFkZ2UsIGdlbmVyYWxseSBhIGNvdW50IG9mIHNvbWUga2luZFxuICAgKi9cbiAgbGFiZWw6IHN0cmluZztcblxuICAvKipcbiAgICogT3B0aW9uYWwgZGVzY3JpcHRpdmUgZXhwbGFuYXRpb24gb2YgbGFiZWwgKGUuZy4gXCIrNCBhZGRpdGlvbmFsIGZpbHRlcnMgYXBwbGllZFwiKVxuICAgKi9cbiAgWydhcmlhLWxhYmVsJ10/OiBzdHJpbmc7XG59O1xuXG5jb25zdCBiYWRnZVN0eWxlcyA9IGNzc2BcbiAgZm9udC1zaXplOiAke2Rlc2lnblRva2Vucy5mb250U2l6ZTIwfTtcbiAgZm9udC13ZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmZvbnRXZWlnaHQ1MDB9O1xuICBsaW5lLWhlaWdodDogJHtkZXNpZ25Ub2tlbnMubGluZUhlaWdodDIwfTtcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yU3VyZmFjZX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9ySW5mb307XG4gIHBhZGRpbmc6IDAgY2FsYygke2Rlc2lnblRva2Vucy5zcGFjaW5nMDV9ICsgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfSk7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBoZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLnNwYWNpbmc0MH07XG5gO1xuXG5jb25zdCBkaXNhYmxlZEJhZGdlU3R5bGVzID0gY3NzYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWx9O1xuYDtcblxuZnVuY3Rpb24gQmFkZ2UocHJvcHM6IFRCYWRnZVByb3BzKSB7XG4gIHJldHVybiAoXG4gICAgPHNwYW5cbiAgICAgIGFyaWEtbGFiZWw9e3Byb3BzWydhcmlhLWxhYmVsJ119XG4gICAgICBjc3M9e1tiYWRnZVN0eWxlcywgcHJvcHMuaXNEaXNhYmxlZCAmJiBkaXNhYmxlZEJhZGdlU3R5bGVzXX1cbiAgICAgIGlkPXtwcm9wcy5pZH1cbiAgICAgIHJvbGU9XCJzdGF0dXNcIlxuICAgID5cbiAgICAgIHtwcm9wcy5sYWJlbH1cbiAgICA8L3NwYW4+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEJhZGdlO1xuIl19 */");
176
+ function Badge(props) {
177
+ return jsxRuntime.jsx("span", {
178
+ "aria-label": props['aria-label'],
179
+ css: [badgeStyles, props.isDisabled && disabledBadgeStyles, process.env.NODE_ENV === "production" ? "" : ";label:Badge;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImJhZGdlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErQ00iLCJmaWxlIjoiYmFkZ2UudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5cbmV4cG9ydCB0eXBlIFRCYWRnZVByb3BzID0ge1xuICAvKipcbiAgICogQ1NTIElEIGZvciBiYWRnZSwgdXNlZCB0byBzcGVjaWZ5IHJlbGF0aW9uc2hpcCB3aXRoIHBhcmVudCBpbiBwYXJlbnQncyBgYXJpYS1jb250cm9sc2AgcHJvcGVydHlcbiAgICogc2VlIGh0dHBzOi8vd3d3LnczLm9yZy9UUi93YWktYXJpYS0xLjEvI3N0YXR1c1xuICAgKi9cbiAgaWQ6IHN0cmluZztcbiAgLyoqXG4gICAqIElmIGB0cnVlYCwgaW5kaWNhdGVzIHRoYXQgdGhlIGVsZW1lbnQgaXMgaW4gYSBkaXNhYmxlZCBzdGF0ZS5cbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogU3RyaW5nIHRvIGJlIGRpc3BsYXllZCBpbiBiYWRnZSwgZ2VuZXJhbGx5IGEgY291bnQgb2Ygc29tZSBraW5kXG4gICAqL1xuICBsYWJlbDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBPcHRpb25hbCBkZXNjcmlwdGl2ZSBleHBsYW5hdGlvbiBvZiBsYWJlbCAoZS5nLiBcIis0IGFkZGl0aW9uYWwgZmlsdGVycyBhcHBsaWVkXCIpXG4gICAqL1xuICBbJ2FyaWEtbGFiZWwnXT86IHN0cmluZztcbn07XG5cbmNvbnN0IGJhZGdlU3R5bGVzID0gY3NzYFxuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBmb250LXdlaWdodDogJHtkZXNpZ25Ub2tlbnMuZm9udFdlaWdodDUwMH07XG4gIGxpbmUtaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5saW5lSGVpZ2h0MjB9O1xuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JTdXJmYWNlfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JJbmZvfTtcbiAgcGFkZGluZzogMCBjYWxjKCR7ZGVzaWduVG9rZW5zLnNwYWNpbmcwNX0gKyAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9KTtcbiAgYm9yZGVyLXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9O1xuICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGhlaWdodDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfTtcbmA7XG5cbmNvbnN0IGRpc2FibGVkQmFkZ2VTdHlsZXMgPSBjc3NgXG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbH07XG5gO1xuXG5mdW5jdGlvbiBCYWRnZShwcm9wczogVEJhZGdlUHJvcHMpIHtcbiAgcmV0dXJuIChcbiAgICA8c3BhblxuICAgICAgYXJpYS1sYWJlbD17cHJvcHNbJ2FyaWEtbGFiZWwnXX1cbiAgICAgIGNzcz17W2JhZGdlU3R5bGVzLCBwcm9wcy5pc0Rpc2FibGVkICYmIGRpc2FibGVkQmFkZ2VTdHlsZXNdfVxuICAgICAgaWQ9e3Byb3BzLmlkfVxuICAgICAgcm9sZT1cInN0YXR1c1wiXG4gICAgPlxuICAgICAge3Byb3BzLmxhYmVsfVxuICAgIDwvc3Bhbj5cbiAgKTtcbn1cblxuZXhwb3J0IGRlZmF1bHQgQmFkZ2U7XG4iXX0= */"],
180
+ id: props.id,
181
+ role: "status",
182
+ children: props.label
183
+ });
184
+ }
185
+
186
+ const chipStyles = /*#__PURE__*/react.css("font-size:", designSystem.designTokens.fontSize20, ";font-weight:", designSystem.designTokens.fontWeight400, ";line-height:", designSystem.designTokens.lineHeight20, ";color:", designSystem.designTokens.colorPrimary20, ";background-color:", designSystem.designTokens.colorPrimary95, ";height:", designSystem.designTokens.spacing40, ";padding:0 ", designSystem.designTokens.spacing20, ";border-radius:calc(\n ", designSystem.designTokens.borderRadius20, " - ", designSystem.designTokens.borderRadius4, "\n );display:inline-flex;justify-content:center;align-items:center;list-style:none;white-space:nowrap;" + (process.env.NODE_ENV === "production" ? "" : ";label:chipStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNoaXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVNzQiIsImZpbGUiOiJjaGlwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51Q2hpcFByb3BzID0ge1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IGNoaXBTdHlsZXMgPSBjc3NgXG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NDAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyMH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTk1fTtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuICBwYWRkaW5nOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gIGJvcmRlci1yYWRpdXM6IGNhbGMoXG4gICAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9IC0gJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNH1cbiAgKTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuYDtcblxuY29uc3QgZGlzYWJsZWRDaGlwU3R5bGVzID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG5gO1xuXG5mdW5jdGlvbiBDaGlwKHByb3BzOiBURmlsdGVyTWVudUNoaXBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxsaSBjc3M9e1tjaGlwU3R5bGVzLCBwcm9wcy5pc0Rpc2FibGVkICYmIGRpc2FibGVkQ2hpcFN0eWxlc119PlxuICAgICAge3Byb3BzLmxhYmVsfVxuICAgIDwvbGk+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IENoaXA7XG4iXX0= */");
187
+ const disabledChipStyles = /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral40, ";background-color:", designSystem.designTokens.colorNeutral90, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:disabledChipStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNoaXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTJCOEIiLCJmaWxlIjoiY2hpcC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0eXBlIFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlc2lnblRva2VucyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2Rlc2lnbi1zeXN0ZW0nO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuXG5leHBvcnQgdHlwZSBURmlsdGVyTWVudUNoaXBQcm9wcyA9IHtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGxhYmVsOiBSZWFjdE5vZGU7XG59O1xuXG5jb25zdCBjaGlwU3R5bGVzID0gY3NzYFxuICBmb250LXNpemU6ICR7ZGVzaWduVG9rZW5zLmZvbnRTaXplMjB9O1xuICBmb250LXdlaWdodDogJHtkZXNpZ25Ub2tlbnMuZm9udFdlaWdodDQwMH07XG4gIGxpbmUtaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5saW5lSGVpZ2h0MjB9O1xuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JQcmltYXJ5MjB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnk5NX07XG4gIGhlaWdodDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzQwfTtcbiAgcGFkZGluZzogMCAke2Rlc2lnblRva2Vucy5zcGFjaW5nMjB9O1xuICBib3JkZXItcmFkaXVzOiBjYWxjKFxuICAgICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czIwfSAtICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czR9XG4gICk7XG4gIGRpc3BsYXk6IGlubGluZS1mbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbGlzdC1zdHlsZTogbm9uZTtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbmA7XG5cbmNvbnN0IGRpc2FibGVkQ2hpcFN0eWxlcyA9IGNzc2BcbiAgY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yTmV1dHJhbDQwfTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsOTB9O1xuYDtcblxuZnVuY3Rpb24gQ2hpcChwcm9wczogVEZpbHRlck1lbnVDaGlwUHJvcHMpIHtcbiAgcmV0dXJuIChcbiAgICA8bGkgY3NzPXtbY2hpcFN0eWxlcywgcHJvcHMuaXNEaXNhYmxlZCAmJiBkaXNhYmxlZENoaXBTdHlsZXNdfT5cbiAgICAgIHtwcm9wcy5sYWJlbH1cbiAgICA8L2xpPlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBDaGlwO1xuIl19 */");
188
+ function Chip(props) {
189
+ return jsxRuntime.jsx("li", {
190
+ css: [chipStyles, props.isDisabled && disabledChipStyles, process.env.NODE_ENV === "production" ? "" : ";label:Chip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImNoaXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtDUSIsImZpbGUiOiJjaGlwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHR5cGUgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51Q2hpcFByb3BzID0ge1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmNvbnN0IGNoaXBTdHlsZXMgPSBjc3NgXG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIGZvbnQtd2VpZ2h0OiAke2Rlc2lnblRva2Vucy5mb250V2VpZ2h0NDAwfTtcbiAgbGluZS1oZWlnaHQ6ICR7ZGVzaWduVG9rZW5zLmxpbmVIZWlnaHQyMH07XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclByaW1hcnkyMH07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7ZGVzaWduVG9rZW5zLmNvbG9yUHJpbWFyeTk1fTtcbiAgaGVpZ2h0OiAke2Rlc2lnblRva2Vucy5zcGFjaW5nNDB9O1xuICBwYWRkaW5nOiAwICR7ZGVzaWduVG9rZW5zLnNwYWNpbmcyMH07XG4gIGJvcmRlci1yYWRpdXM6IGNhbGMoXG4gICAgJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMjB9IC0gJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzNH1cbiAgKTtcbiAgZGlzcGxheTogaW5saW5lLWZsZXg7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBsaXN0LXN0eWxlOiBub25lO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuYDtcblxuY29uc3QgZGlzYWJsZWRDaGlwU3R5bGVzID0gY3NzYFxuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuY29sb3JOZXV0cmFsNDB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvck5ldXRyYWw5MH07XG5gO1xuXG5mdW5jdGlvbiBDaGlwKHByb3BzOiBURmlsdGVyTWVudUNoaXBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxsaSBjc3M9e1tjaGlwU3R5bGVzLCBwcm9wcy5pc0Rpc2FibGVkICYmIGRpc2FibGVkQ2hpcFN0eWxlc119PlxuICAgICAge3Byb3BzLmxhYmVsfVxuICAgIDwvbGk+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IENoaXA7XG4iXX0= */"],
191
+ children: props.label
192
+ });
193
+ }
194
+ Chip.propTypes = process.env.NODE_ENV !== "production" ? {
195
+ isDisabled: _pt__default["default"].bool,
196
+ label: _pt__default["default"].node.isRequired
197
+ } : {};
198
+
199
+ const _excluded = ["filterKey", "label", "operatorLabel", "appliedFilterValues", "isDisabled", "isPersistent", "onRemoveRequest"];
200
+ function ownKeys(e, r) { var t = _Object$keys__default["default"](e); if (_Object$getOwnPropertySymbols__default["default"]) { var o = _Object$getOwnPropertySymbols__default["default"](e); r && (o = _filterInstanceProperty__default["default"](o).call(o, function (r) { return _Object$getOwnPropertyDescriptor__default["default"](e, r).enumerable; })), t.push.apply(t, o); } return t; }
201
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var _context3, _context4; var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? _forEachInstanceProperty__default["default"](_context3 = ownKeys(Object(t), !0)).call(_context3, function (r) { _defineProperty(e, r, t[r]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](e, _Object$getOwnPropertyDescriptors__default["default"](t)) : _forEachInstanceProperty__default["default"](_context4 = ownKeys(Object(t))).call(_context4, function (r) { _Object$defineProperty__default["default"](e, r, _Object$getOwnPropertyDescriptor__default["default"](t, r)); }); } return e; }
202
+ const useScrollObserver = values => {
203
+ const _useState = react$1.useState(false),
204
+ _useState2 = _slicedToArray(_useState, 2),
205
+ isOverflowing = _useState2[0],
206
+ setIsOverflowing = _useState2[1];
207
+ const _useState3 = react$1.useState(0),
208
+ _useState4 = _slicedToArray(_useState3, 2),
209
+ overflowCount = _useState4[0],
210
+ setOverflowCount = _useState4[1];
211
+ const containerRef = react$1.useRef(null);
212
+ const setContainerRef = react$1.useCallback(node => {
213
+ if (node) {
214
+ containerRef.current = node;
215
+ const clientWidth = node.clientWidth,
216
+ scrollWidth = node.scrollWidth,
217
+ children = node.children;
218
+ const hasOverflow = scrollWidth > clientWidth;
219
+ setIsOverflowing(hasOverflow);
220
+ let visibleChipCount = 0;
221
+ if (hasOverflow) {
222
+ var _context;
223
+ _forEachInstanceProperty__default["default"](_context = _Array$from__default["default"](children)).call(_context, child => {
224
+ var _context2;
225
+ const childRect = child.getBoundingClientRect();
226
+ const containerRect = node.getBoundingClientRect();
227
+ if (
228
+ // if the right hand side of the child is past the right of the container
229
+ childRect.right <= containerRect.right &&
230
+ // and it's not the badge
231
+ !_includesInstanceProperty__default["default"](_context2 = _Array$from__default["default"](child.classList)).call(_context2, 'ui-kit-filter-trigger-badge-container')) {
232
+ ++visibleChipCount;
233
+ }
234
+ });
235
+ }
236
+ setOverflowCount(values.length - visibleChipCount);
237
+ }
238
+ }, [values]);
239
+ return {
240
+ isOverflowing,
241
+ overflowCount,
242
+ setContainerRef
243
+ };
244
+ };
245
+ const TriggerButton = /*#__PURE__*/react$1.forwardRef(function TriggerButton(props, ref) {
246
+ const filterKey = props.filterKey,
247
+ label$1 = props.label,
248
+ operatorLabel = props.operatorLabel,
249
+ appliedFilterValues = props.appliedFilterValues,
250
+ isDisabled = props.isDisabled,
251
+ isPersistent = props.isPersistent,
252
+ onRemoveRequest = props.onRemoveRequest,
253
+ rest = _objectWithoutProperties(props, _excluded);
254
+ const values = appliedFilterValues || [];
255
+ const filtersApplied = values.length > 0;
256
+ const _useScrollObserver = useScrollObserver(values),
257
+ isOverflowing = _useScrollObserver.isOverflowing,
258
+ overflowCount = _useScrollObserver.overflowCount,
259
+ setContainerRef = _useScrollObserver.setContainerRef;
260
+ return jsxRuntime.jsxs("div", {
261
+ css: [triggerWrapper, isDisabled && disabled, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFxSFMiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
262
+ children: [jsxRuntime.jsxs("label", {
263
+ css: label,
264
+ htmlFor: `${filterKey}-menu-trigger`,
265
+ id: `${filterKey}-menu-label`,
266
+ children: [label$1, ":", operatorLabel && jsxRuntime.jsx("span", {
267
+ css: operatorContainer,
268
+ children: operatorLabel
269
+ })]
270
+ }), filtersApplied && jsxRuntime.jsxs("ul", {
271
+ ref: setContainerRef,
272
+ css: valuesContainer,
273
+ "aria-label": `${filterKey} selected values`,
274
+ "aria-live": "polite",
275
+ children: [_mapInstanceProperty__default["default"](values).call(values, value => jsxRuntime.jsx(Chip, {
276
+ label: value.label,
277
+ isDisabled: isDisabled
278
+ }, value.value)), isOverflowing && overflowCount && jsxRuntime.jsx("li", {
279
+ className: "ui-kit-filter-trigger-badge-container",
280
+ css: badgeContainer,
281
+ children: jsxRuntime.jsx(Badge, {
282
+ id: "ui-kit-filter-trigger-overflow-count-badge",
283
+ label: `+${overflowCount}`,
284
+ isDisabled: isDisabled
285
+ })
286
+ })]
287
+ }), !filtersApplied && jsxRuntime.jsx(icons.CaretDownIcon, {
288
+ "aria-label": `toggle filter menu icon`,
289
+ size: "small",
290
+ color: "neutral60"
291
+ }), jsxRuntime.jsx("button", _objectSpread(_objectSpread({
292
+ css: [mainActionButton, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvS1EiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
293
+ ref: ref,
294
+ id: `${filterKey}-menu-trigger`,
295
+ "aria-disabled": isDisabled,
296
+ "aria-labelledby": `${filterKey}-menu-label`
297
+ }, rest), isDisabled && {
298
+ tabIndex: -1,
299
+ disabled: true,
300
+ readOnly: true
301
+ })), filtersApplied && onRemoveRequest && !isPersistent && jsxRuntime.jsx("div", {
302
+ css: [removeButton, process.env.NODE_ENV === "production" ? "" : ";label:TriggerButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRyaWdnZXItYnV0dG9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpTGEiLCJmaWxlIjoidHJpZ2dlci1idXR0b24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgdHlwZSBSZWFjdE5vZGUsXG4gIGZvcndhcmRSZWYsXG4gIHR5cGUgTGVnYWN5UmVmLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlQ2FsbGJhY2ssXG4gIHVzZVJlZixcbiAgdXNlU3RhdGUsXG59IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IENhcmV0RG93bkljb24sIENsb3NlQm9sZEljb24gfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9pY29ucyc7XG5pbXBvcnQgU2Vjb25kYXJ5SWNvbkJ1dHRvbiBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9zZWNvbmRhcnktaWNvbi1idXR0b24nO1xuaW1wb3J0IHsgdHlwZSBUQXBwbGllZEZpbHRlclZhbHVlIH0gZnJvbSAnLi4vZmlsdGVyLW1lbnUnO1xuaW1wb3J0ICogYXMgc3R5bGVzIGZyb20gJy4vdHJpZ2dlci1idXR0b24uc3R5bGVzJztcbmltcG9ydCB7IEJhZGdlIH0gZnJvbSAnLi4vLi4vYmFkZ2UnO1xuaW1wb3J0IHsgQ2hpcCB9IGZyb20gJy4uL2NoaXAnO1xuXG5jb25zdCB1c2VTY3JvbGxPYnNlcnZlciA9ICh2YWx1ZXM6IFRBcHBsaWVkRmlsdGVyVmFsdWVbXSkgPT4ge1xuICBjb25zdCBbaXNPdmVyZmxvd2luZywgc2V0SXNPdmVyZmxvd2luZ10gPSB1c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IFtvdmVyZmxvd0NvdW50LCBzZXRPdmVyZmxvd0NvdW50XSA9IHVzZVN0YXRlKDApO1xuICBjb25zdCBjb250YWluZXJSZWYgPSB1c2VSZWY8SFRNTFVMaXN0RWxlbWVudCB8IG51bGw+KG51bGwpO1xuXG4gIGNvbnN0IHNldENvbnRhaW5lclJlZiA9IHVzZUNhbGxiYWNrKFxuICAgIChub2RlOiBIVE1MVUxpc3RFbGVtZW50IHwgbnVsbCkgPT4ge1xuICAgICAgaWYgKG5vZGUpIHtcbiAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQgPSBub2RlO1xuXG4gICAgICAgIGNvbnN0IHsgY2xpZW50V2lkdGgsIHNjcm9sbFdpZHRoLCBjaGlsZHJlbiB9ID0gbm9kZTtcbiAgICAgICAgY29uc3QgaGFzT3ZlcmZsb3cgPSBzY3JvbGxXaWR0aCA+IGNsaWVudFdpZHRoO1xuXG4gICAgICAgIHNldElzT3ZlcmZsb3dpbmcoaGFzT3ZlcmZsb3cpO1xuXG4gICAgICAgIGxldCB2aXNpYmxlQ2hpcENvdW50ID0gMDtcblxuICAgICAgICBpZiAoaGFzT3ZlcmZsb3cpIHtcbiAgICAgICAgICBBcnJheS5mcm9tKGNoaWxkcmVuKS5mb3JFYWNoKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgY2hpbGRSZWN0ID0gY2hpbGQuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgICAgICBjb25zdCBjb250YWluZXJSZWN0ID0gbm9kZS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKTtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgLy8gaWYgdGhlIHJpZ2h0IGhhbmQgc2lkZSBvZiB0aGUgY2hpbGQgaXMgcGFzdCB0aGUgcmlnaHQgb2YgdGhlIGNvbnRhaW5lclxuICAgICAgICAgICAgICBjaGlsZFJlY3QucmlnaHQgPD0gY29udGFpbmVyUmVjdC5yaWdodCAmJlxuICAgICAgICAgICAgICAvLyBhbmQgaXQncyBub3QgdGhlIGJhZGdlXG4gICAgICAgICAgICAgICFBcnJheS5mcm9tKGNoaWxkLmNsYXNzTGlzdCkuaW5jbHVkZXMoXG4gICAgICAgICAgICAgICAgJ3VpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXInXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICArK3Zpc2libGVDaGlwQ291bnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0T3ZlcmZsb3dDb3VudCh2YWx1ZXMubGVuZ3RoIC0gdmlzaWJsZUNoaXBDb3VudCk7XG4gICAgICB9XG4gICAgfSxcbiAgICBbdmFsdWVzXVxuICApO1xuXG4gIHJldHVybiB7XG4gICAgaXNPdmVyZmxvd2luZyxcbiAgICBvdmVyZmxvd0NvdW50LFxuICAgIHNldENvbnRhaW5lclJlZixcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51VHJpZ2dlckJ1dHRvblByb3BzID0ge1xuICAvKipcbiAgICogdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSBmaWx0ZXJcbiAgICovXG4gIGZpbHRlcktleTogc3RyaW5nO1xuICAvKipcbiAgICogZm9ybWF0dGVkIG1lc3NhZ2UgdG8gZGlzcGxheSB0aGUgZmlsdGVyJ3MgbmFtZVxuICAgKi9cbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogd2hldGhlciBvciBub3QgdGhlIGZpbHRlciBpcyBkaXNhYmxlZFxuICAgKi9cbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBpbmRpY2F0ZXMgd2hldGhlciBGaWx0ZXJNZW51IGNhbiBiZSByZW1vdmVkIGZyb20gdGhlIGZpbHRlcnNMaXN0XG4gICAqL1xuICBpc1BlcnNpc3RlbnQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbn07XG5cbmNvbnN0IFRyaWdnZXJCdXR0b24gPSBmb3J3YXJkUmVmKGZ1bmN0aW9uIFRyaWdnZXJCdXR0b24oXG4gIHByb3BzOiBURmlsdGVyTWVudVRyaWdnZXJCdXR0b25Qcm9wcyxcbiAgcmVmOiBMZWdhY3lSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4pIHtcbiAgY29uc3Qge1xuICAgIGZpbHRlcktleSxcbiAgICBsYWJlbCxcbiAgICBvcGVyYXRvckxhYmVsLFxuICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXMsXG4gICAgaXNEaXNhYmxlZCxcbiAgICBpc1BlcnNpc3RlbnQsXG4gICAgb25SZW1vdmVSZXF1ZXN0LFxuICAgIC4uLnJlc3RcbiAgfSA9IHByb3BzO1xuICBjb25zdCB2YWx1ZXMgPSBhcHBsaWVkRmlsdGVyVmFsdWVzIHx8IFtdO1xuICBjb25zdCBmaWx0ZXJzQXBwbGllZDogYm9vbGVhbiA9IHZhbHVlcy5sZW5ndGggPiAwO1xuXG4gIGNvbnN0IHsgaXNPdmVyZmxvd2luZywgb3ZlcmZsb3dDb3VudCwgc2V0Q29udGFpbmVyUmVmIH0gPVxuICAgIHVzZVNjcm9sbE9ic2VydmVyKHZhbHVlcyk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNzcz17W3N0eWxlcy50cmlnZ2VyV3JhcHBlciwgaXNEaXNhYmxlZCAmJiBzdHlsZXMuZGlzYWJsZWRdfT5cbiAgICAgIDxsYWJlbFxuICAgICAgICBjc3M9e3N0eWxlcy5sYWJlbH1cbiAgICAgICAgaHRtbEZvcj17YCR7ZmlsdGVyS2V5fS1tZW51LXRyaWdnZXJgfVxuICAgICAgICBpZD17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgID5cbiAgICAgICAge2xhYmVsfTpcbiAgICAgICAge29wZXJhdG9yTGFiZWwgJiYgKFxuICAgICAgICAgIDxzcGFuIGNzcz17c3R5bGVzLm9wZXJhdG9yQ29udGFpbmVyfT57b3BlcmF0b3JMYWJlbH08L3NwYW4+XG4gICAgICAgICl9XG4gICAgICA8L2xhYmVsPlxuICAgICAge2ZpbHRlcnNBcHBsaWVkICYmIChcbiAgICAgICAgPHVsXG4gICAgICAgICAgcmVmPXtzZXRDb250YWluZXJSZWZ9XG4gICAgICAgICAgY3NzPXtzdHlsZXMudmFsdWVzQ29udGFpbmVyfVxuICAgICAgICAgIGFyaWEtbGFiZWw9e2Ake2ZpbHRlcktleX0gc2VsZWN0ZWQgdmFsdWVzYH1cbiAgICAgICAgICBhcmlhLWxpdmU9XCJwb2xpdGVcIlxuICAgICAgICA+XG4gICAgICAgICAge3ZhbHVlcy5tYXAoKHZhbHVlKSA9PiAoXG4gICAgICAgICAgICA8Q2hpcFxuICAgICAgICAgICAgICBrZXk9e3ZhbHVlLnZhbHVlfVxuICAgICAgICAgICAgICBsYWJlbD17dmFsdWUubGFiZWx9XG4gICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICkpfVxuICAgICAgICAgIHtpc092ZXJmbG93aW5nICYmIG92ZXJmbG93Q291bnQgJiYgKFxuICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgIGNsYXNzTmFtZT1cInVpLWtpdC1maWx0ZXItdHJpZ2dlci1iYWRnZS1jb250YWluZXJcIlxuICAgICAgICAgICAgICBjc3M9e3N0eWxlcy5iYWRnZUNvbnRhaW5lcn1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPEJhZGdlXG4gICAgICAgICAgICAgICAgaWQ9XCJ1aS1raXQtZmlsdGVyLXRyaWdnZXItb3ZlcmZsb3ctY291bnQtYmFkZ2VcIlxuICAgICAgICAgICAgICAgIGxhYmVsPXtgKyR7b3ZlcmZsb3dDb3VudH1gfVxuICAgICAgICAgICAgICAgIGlzRGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L2xpPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvdWw+XG4gICAgICApfVxuICAgICAgeyFmaWx0ZXJzQXBwbGllZCAmJiAoXG4gICAgICAgIDxDYXJldERvd25JY29uXG4gICAgICAgICAgYXJpYS1sYWJlbD17YHRvZ2dsZSBmaWx0ZXIgbWVudSBpY29uYH1cbiAgICAgICAgICBzaXplPVwic21hbGxcIlxuICAgICAgICAgIGNvbG9yPVwibmV1dHJhbDYwXCJcbiAgICAgICAgLz5cbiAgICAgICl9XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNzcz17W3N0eWxlcy5tYWluQWN0aW9uQnV0dG9uXX1cbiAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgIGlkPXtgJHtmaWx0ZXJLZXl9LW1lbnUtdHJpZ2dlcmB9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2lzRGlzYWJsZWR9XG4gICAgICAgIGFyaWEtbGFiZWxsZWRieT17YCR7ZmlsdGVyS2V5fS1tZW51LWxhYmVsYH1cbiAgICAgICAgey4uLnJlc3R9XG4gICAgICAgIHsuLi4oaXNEaXNhYmxlZCAmJiB7XG4gICAgICAgICAgdGFiSW5kZXg6IC0xLFxuICAgICAgICAgIGRpc2FibGVkOiB0cnVlLFxuICAgICAgICAgIHJlYWRPbmx5OiB0cnVlLFxuICAgICAgICB9KX1cbiAgICAgIC8+XG4gICAgICB7ZmlsdGVyc0FwcGxpZWQgJiYgb25SZW1vdmVSZXF1ZXN0ICYmICFpc1BlcnNpc3RlbnQgJiYgKFxuICAgICAgICA8ZGl2IGNzcz17W3N0eWxlcy5yZW1vdmVCdXR0b25dfT5cbiAgICAgICAgICA8U2Vjb25kYXJ5SWNvbkJ1dHRvblxuICAgICAgICAgICAgaWNvbj17PENsb3NlQm9sZEljb24gLz59XG4gICAgICAgICAgICBzaXplPVwiMTBcIlxuICAgICAgICAgICAgbGFiZWw9e2ByZW1vdmUgJHtsYWJlbH0gZmlsdGVyYH1cbiAgICAgICAgICAgIGlzRGlzYWJsZWQ9e3Byb3BzLmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBlLnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgICAgICAgICBvblJlbW92ZVJlcXVlc3QhKGUpO1xuICAgICAgICAgICAgfX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICl9XG4gICAgPC9kaXY+XG4gICk7XG59KTtcblxuZXhwb3J0IGRlZmF1bHQgVHJpZ2dlckJ1dHRvbjtcbiJdfQ== */"],
303
+ children: jsxRuntime.jsx(SecondaryIconButton__default["default"], {
304
+ icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
305
+ size: "10",
306
+ label: `remove ${label$1} filter`,
307
+ isDisabled: props.isDisabled,
308
+ onClick: e => {
309
+ e.stopPropagation();
310
+ onRemoveRequest(e);
311
+ }
312
+ })
313
+ })]
314
+ });
315
+ });
316
+ var TriggerButton$1 = TriggerButton;
317
+
64
318
  function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
65
- const menuStyles = /*#__PURE__*/react.css("display:flex;flex-direction:column;align-items:flex-start;gap:", designSystem.designTokens.spacing30, ";width:", designSystem.designTokens.constraint6, ";padding:", designSystem.designTokens.spacing20, " ", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius8, ";box-shadow:", designSystem.designTokens.shadow18, ";animation-duration:", designSystem.designTokens.transitionStandard, ";will-change:'transform, opacity';margin-top:", designSystem.designTokens.spacing10, ";position:relative;z-index:5;" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RjZCIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIHRoZSB2YWx1ZXMgYXBwbGllZCB0byB0aGlzIGZpbHRlciBieSB0aGUgdXNlclxuICAgKi9cbiAgYXBwbGllZEZpbHRlclZhbHVlczogVEFwcGxpZWRGaWx0ZXJWYWx1ZVtdIHwgdW5kZWZpbmVkIHwgbnVsbDtcbiAgLyoqXG4gICAqIGluZGljYXRlcyB3aGV0aGVyIEZpbHRlck1lbnUgY2FuIGJlIHJlbW92ZWQgZnJvbSB0aGUgZmlsdGVyc0xpc3RcbiAgICovXG4gIGlzUGVyc2lzdGVudD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiB3aGV0aGVyIG9yIG5vdCB0aGUgZmlsdGVyIGlzIGRpc2FibGVkXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgYHhgIGluIFRyaWdnZXIgQnV0dG9uIGlzIGRpc3BsYXllZCAtIHJlcXVpcmVkIGlmIGBpc1BlcnNpc3RlbnRgIGlzIGBmYWxzZWBcbiAgICovXG4gIG9uUmVtb3ZlUmVxdWVzdD86IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuY29uc3QgbWVudUJvZHlTdHlsZSA9IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3QgZGVmYXVsdE9wZW49e3Byb3BzLmlzRGlzYWJsZWQgPyBmYWxzZSA6IHByb3BzLmRlZmF1bHRPcGVufT5cbiAgICAgIDxQb3BvdmVyLlRyaWdnZXIgYXNDaGlsZD5cbiAgICAgICAgPFRyaWdnZXJCdXR0b25cbiAgICAgICAgICBmaWx0ZXJLZXk9e3Byb3BzLmZpbHRlcktleX1cbiAgICAgICAgICBsYWJlbD17cHJvcHMubGFiZWx9XG4gICAgICAgICAgYXBwbGllZEZpbHRlclZhbHVlcz17cHJvcHMuYXBwbGllZEZpbHRlclZhbHVlc31cbiAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgIGlzUGVyc2lzdGVudD17cHJvcHMuaXNQZXJzaXN0ZW50fVxuICAgICAgICAgIG9uUmVtb3ZlUmVxdWVzdD17cHJvcHMub25SZW1vdmVSZXF1ZXN0fVxuICAgICAgICAvPlxuICAgICAgPC9Qb3BvdmVyLlRyaWdnZXI+XG4gICAgICA8UG9wb3Zlci5Qb3J0YWw+XG4gICAgICAgIDxQb3BvdmVyLkNvbnRlbnRcbiAgICAgICAgICBzaWRlPVwiYm90dG9tXCJcbiAgICAgICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICAgICAgICBjc3M9e21lbnVTdHlsZXN9XG4gICAgICAgICAgb25PcGVuQXV0b0ZvY3VzPXtmb2N1c01lbnVCb2R5fVxuICAgICAgICA+XG4gICAgICAgICAgPEhlYWRlclxuICAgICAgICAgICAgbGFiZWw9e3Byb3BzLmxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyT3BlcmF0b3JzSW5wdXQ9e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0fVxuICAgICAgICAgICAgb25Tb3J0UmVxdWVzdD17cHJvcHMub25Tb3J0UmVxdWVzdH1cbiAgICAgICAgICAvPlxuICAgICAgICAgIDxkaXYgY3NzPXttZW51Qm9keVN0eWxlfSByZWY9e21lbnVCb2R5UmVmfT5cbiAgICAgICAgICAgIHtwcm9wcy5yZW5kZXJNZW51Qm9keSgpfVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxGb290ZXJcbiAgICAgICAgICAgIG9uQ2xlYXJSZXF1ZXN0PXtwcm9wcy5vbkNsZWFyUmVxdWVzdH1cbiAgICAgICAgICAgIHJlbmRlckFwcGx5QnV0dG9uPXtwcm9wcy5yZW5kZXJBcHBseUJ1dHRvbn1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1BvcG92ZXIuQ29udGVudD5cbiAgICAgIDwvUG9wb3Zlci5Qb3J0YWw+XG4gICAgPC9Qb3BvdmVyLlJvb3Q+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEZpbHRlck1lbnU7XG4iXX0= */");
66
- process.env.NODE_ENV === "production" ? {
67
- name: "1d3w5wq",
68
- styles: "width:100%"
319
+ const FOCUSABLE_CSS_SELECTOR = `a[href], button:not([disabled]), input:not([disabled]), select:not([disabled]), textarea:not([disabled]), *[tabindex], *[contenteditable]`;
320
+
321
+ /**
322
+ * Find the first focusable element in the given container,
323
+ * such as the first focusable list item.
324
+ * @param {HTMLElement} container
325
+ * @returns {HTMLElement | null}
326
+ */
327
+ function findFirstFocusable(container) {
328
+ return container.querySelector(FOCUSABLE_CSS_SELECTOR);
329
+ }
330
+ const menuStyles = /*#__PURE__*/react.css("display:flex;flex-direction:column;align-items:flex-start;gap:", designSystem.designTokens.spacing30, ";width:", designSystem.designTokens.constraint6, ";max-height:", designSystem.designTokens.constraint10, ";padding:", designSystem.designTokens.spacing20, " ", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius8, ";box-shadow:", designSystem.designTokens.shadow18, ";animation-duration:", designSystem.designTokens.transitionStandard, ";will-change:'transform, opacity';margin-top:", designSystem.designTokens.spacing10, ";position:relative;z-index:5;" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpRzZCIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */");
331
+ const menuBodyStyle = process.env.NODE_ENV === "production" ? {
332
+ name: "pw6q3u",
333
+ styles: "width:100%;overflow:hidden auto"
69
334
  } : {
70
- name: "11z4rpd-menuBodyStyle",
71
- styles: "width:100%;label:menuBodyStyle;",
72
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErR3lCIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIHRoZSB2YWx1ZXMgYXBwbGllZCB0byB0aGlzIGZpbHRlciBieSB0aGUgdXNlclxuICAgKi9cbiAgYXBwbGllZEZpbHRlclZhbHVlczogVEFwcGxpZWRGaWx0ZXJWYWx1ZVtdIHwgdW5kZWZpbmVkIHwgbnVsbDtcbiAgLyoqXG4gICAqIGluZGljYXRlcyB3aGV0aGVyIEZpbHRlck1lbnUgY2FuIGJlIHJlbW92ZWQgZnJvbSB0aGUgZmlsdGVyc0xpc3RcbiAgICovXG4gIGlzUGVyc2lzdGVudD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiB3aGV0aGVyIG9yIG5vdCB0aGUgZmlsdGVyIGlzIGRpc2FibGVkXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgYHhgIGluIFRyaWdnZXIgQnV0dG9uIGlzIGRpc3BsYXllZCAtIHJlcXVpcmVkIGlmIGBpc1BlcnNpc3RlbnRgIGlzIGBmYWxzZWBcbiAgICovXG4gIG9uUmVtb3ZlUmVxdWVzdD86IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuY29uc3QgbWVudUJvZHlTdHlsZSA9IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3QgZGVmYXVsdE9wZW49e3Byb3BzLmlzRGlzYWJsZWQgPyBmYWxzZSA6IHByb3BzLmRlZmF1bHRPcGVufT5cbiAgICAgIDxQb3BvdmVyLlRyaWdnZXIgYXNDaGlsZD5cbiAgICAgICAgPFRyaWdnZXJCdXR0b25cbiAgICAgICAgICBmaWx0ZXJLZXk9e3Byb3BzLmZpbHRlcktleX1cbiAgICAgICAgICBsYWJlbD17cHJvcHMubGFiZWx9XG4gICAgICAgICAgYXBwbGllZEZpbHRlclZhbHVlcz17cHJvcHMuYXBwbGllZEZpbHRlclZhbHVlc31cbiAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgIGlzUGVyc2lzdGVudD17cHJvcHMuaXNQZXJzaXN0ZW50fVxuICAgICAgICAgIG9uUmVtb3ZlUmVxdWVzdD17cHJvcHMub25SZW1vdmVSZXF1ZXN0fVxuICAgICAgICAvPlxuICAgICAgPC9Qb3BvdmVyLlRyaWdnZXI+XG4gICAgICA8UG9wb3Zlci5Qb3J0YWw+XG4gICAgICAgIDxQb3BvdmVyLkNvbnRlbnRcbiAgICAgICAgICBzaWRlPVwiYm90dG9tXCJcbiAgICAgICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICAgICAgICBjc3M9e21lbnVTdHlsZXN9XG4gICAgICAgICAgb25PcGVuQXV0b0ZvY3VzPXtmb2N1c01lbnVCb2R5fVxuICAgICAgICA+XG4gICAgICAgICAgPEhlYWRlclxuICAgICAgICAgICAgbGFiZWw9e3Byb3BzLmxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyT3BlcmF0b3JzSW5wdXQ9e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0fVxuICAgICAgICAgICAgb25Tb3J0UmVxdWVzdD17cHJvcHMub25Tb3J0UmVxdWVzdH1cbiAgICAgICAgICAvPlxuICAgICAgICAgIDxkaXYgY3NzPXttZW51Qm9keVN0eWxlfSByZWY9e21lbnVCb2R5UmVmfT5cbiAgICAgICAgICAgIHtwcm9wcy5yZW5kZXJNZW51Qm9keSgpfVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxGb290ZXJcbiAgICAgICAgICAgIG9uQ2xlYXJSZXF1ZXN0PXtwcm9wcy5vbkNsZWFyUmVxdWVzdH1cbiAgICAgICAgICAgIHJlbmRlckFwcGx5QnV0dG9uPXtwcm9wcy5yZW5kZXJBcHBseUJ1dHRvbn1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1BvcG92ZXIuQ29udGVudD5cbiAgICAgIDwvUG9wb3Zlci5Qb3J0YWw+XG4gICAgPC9Qb3BvdmVyLlJvb3Q+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEZpbHRlck1lbnU7XG4iXX0= */",
335
+ name: "a5of5h-menuBodyStyle",
336
+ styles: "width:100%;overflow:hidden auto;label:menuBodyStyle;",
337
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvSGdDIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIGZvcm1hdHRlZCBtZXNzYWdlIHRvIGRpc3BsYXkgdGhlIHNlbGVjdGVkIG9wZXJhdG9yIHZhbHVlXG4gICAqL1xuICBvcGVyYXRvckxhYmVsPzogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIHZhbHVlcyBhcHBsaWVkIHRvIHRoaXMgZmlsdGVyIGJ5IHRoZSB1c2VyXG4gICAqL1xuICBhcHBsaWVkRmlsdGVyVmFsdWVzOiBUQXBwbGllZEZpbHRlclZhbHVlW10gfCB1bmRlZmluZWQgfCBudWxsO1xuICAvKipcbiAgICogaW5kaWNhdGVzIHdoZXRoZXIgRmlsdGVyTWVudSBjYW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBmaWx0ZXJzTGlzdFxuICAgKi9cbiAgaXNQZXJzaXN0ZW50PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIHdoZXRoZXIgb3Igbm90IHRoZSBmaWx0ZXIgaXMgZGlzYWJsZWRcbiAgICovXG4gIGlzRGlzYWJsZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgeGAgaW4gVHJpZ2dlciBCdXR0b24gaXMgZGlzcGxheWVkIC0gcmVxdWlyZWQgaWYgYGlzUGVyc2lzdGVudGAgaXMgYGZhbHNlYFxuICAgKi9cbiAgb25SZW1vdmVSZXF1ZXN0PzogKFxuICAgIGV2ZW50PzogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgbWF4LWhlaWdodDogJHtkZXNpZ25Ub2tlbnMuY29uc3RyYWludDEwfTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuZXhwb3J0IGNvbnN0IG1lbnVCb2R5U3R5bGUgPSBjc3NgXG4gIHdpZHRoOiAxMDAlO1xuXG4gIC8qKiBlbnN1cmUgdGhhdCBib2R5IHNjcm9sbHMgd2l0aCBvdmVyZmxvdyBub3cgdGhhdCB0aGVyZSBpcyBhIG1lbnUgbWF4LWhlaWdodCAqL1xuICBvdmVyZmxvdzogaGlkZGVuIGF1dG87XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3RcbiAgICAgIGRlZmF1bHRPcGVuPXtwcm9wcy5pc0Rpc2FibGVkID8gZmFsc2UgOiBwcm9wcy5kZWZhdWx0T3Blbn1cbiAgICAgIG9uT3BlbkNoYW5nZT17KG9wZW4pID0+IHtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICFvcGVuICYmXG4gICAgICAgICAgIXByb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXM/Lmxlbmd0aCAmJlxuICAgICAgICAgICFwcm9wcy5pc1BlcnNpc3RlbnQgJiZcbiAgICAgICAgICBwcm9wcy5vblJlbW92ZVJlcXVlc3RcbiAgICAgICAgKSB7XG4gICAgICAgICAgcHJvcHMub25SZW1vdmVSZXF1ZXN0KCk7XG4gICAgICAgIH1cbiAgICAgIH19XG4gICAgPlxuICAgICAgPFBvcG92ZXIuVHJpZ2dlciBhc0NoaWxkPlxuICAgICAgICA8VHJpZ2dlckJ1dHRvblxuICAgICAgICAgIGZpbHRlcktleT17cHJvcHMuZmlsdGVyS2V5fVxuICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICBvcGVyYXRvckxhYmVsPXtwcm9wcy5vcGVyYXRvckxhYmVsfVxuICAgICAgICAgIGFwcGxpZWRGaWx0ZXJWYWx1ZXM9e3Byb3BzLmFwcGxpZWRGaWx0ZXJWYWx1ZXN9XG4gICAgICAgICAgaXNEaXNhYmxlZD17cHJvcHMuaXNEaXNhYmxlZH1cbiAgICAgICAgICBpc1BlcnNpc3RlbnQ9e3Byb3BzLmlzUGVyc2lzdGVudH1cbiAgICAgICAgICBvblJlbW92ZVJlcXVlc3Q9e3Byb3BzLm9uUmVtb3ZlUmVxdWVzdH1cbiAgICAgICAgLz5cbiAgICAgIDwvUG9wb3Zlci5UcmlnZ2VyPlxuICAgICAgPFBvcG92ZXIuUG9ydGFsPlxuICAgICAgICA8UG9wb3Zlci5Db250ZW50XG4gICAgICAgICAgc2lkZT1cImJvdHRvbVwiXG4gICAgICAgICAgYWxpZ249XCJzdGFydFwiXG4gICAgICAgICAgY3NzPXttZW51U3R5bGVzfVxuICAgICAgICAgIG9uT3BlbkF1dG9Gb2N1cz17Zm9jdXNNZW51Qm9keX1cbiAgICAgICAgPlxuICAgICAgICAgIDxIZWFkZXJcbiAgICAgICAgICAgIGxhYmVsPXtwcm9wcy5sYWJlbH1cbiAgICAgICAgICAgIHJlbmRlck9wZXJhdG9yc0lucHV0PXtwcm9wcy5yZW5kZXJPcGVyYXRvcnNJbnB1dH1cbiAgICAgICAgICAgIG9uU29ydFJlcXVlc3Q9e3Byb3BzLm9uU29ydFJlcXVlc3R9XG4gICAgICAgICAgLz5cbiAgICAgICAgICA8ZGl2IGNzcz17bWVudUJvZHlTdHlsZX0gcmVmPXttZW51Qm9keVJlZn0+XG4gICAgICAgICAgICB7cHJvcHMucmVuZGVyTWVudUJvZHkoKX1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8Rm9vdGVyXG4gICAgICAgICAgICBvbkNsZWFyUmVxdWVzdD17cHJvcHMub25DbGVhclJlcXVlc3R9XG4gICAgICAgICAgICByZW5kZXJBcHBseUJ1dHRvbj17cHJvcHMucmVuZGVyQXBwbHlCdXR0b259XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9Qb3BvdmVyLkNvbnRlbnQ+XG4gICAgICA8L1BvcG92ZXIuUG9ydGFsPlxuICAgIDwvUG9wb3Zlci5Sb290PlxuICApO1xufVxuXG5leHBvcnQgZGVmYXVsdCBGaWx0ZXJNZW51O1xuIl19 */",
73
338
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
74
339
  };
75
- process.env.NODE_ENV !== "production" ? {
340
+ function FilterMenu(props) {
341
+ const menuBodyRef = react$1.useRef(null);
342
+ const focusMenuBody = react$1.useCallback(e => {
343
+ if (menuBodyRef.current) {
344
+ const firstFocusableElementInMenuBody = findFirstFocusable(menuBodyRef.current);
345
+ if (firstFocusableElementInMenuBody) {
346
+ e.preventDefault();
347
+ firstFocusableElementInMenuBody.focus();
348
+ }
349
+ }
350
+ }, [menuBodyRef]);
351
+ return jsxRuntime.jsxs(Popover__namespace.Root, {
352
+ defaultOpen: props.isDisabled ? false : props.defaultOpen,
353
+ onOpenChange: open => {
354
+ if (!open && !props.appliedFilterValues?.length && !props.isPersistent && props.onRemoveRequest) {
355
+ props.onRemoveRequest();
356
+ }
357
+ },
358
+ children: [jsxRuntime.jsx(Popover__namespace.Trigger, {
359
+ asChild: true,
360
+ children: jsxRuntime.jsx(TriggerButton$1, {
361
+ filterKey: props.filterKey,
362
+ label: props.label,
363
+ operatorLabel: props.operatorLabel,
364
+ appliedFilterValues: props.appliedFilterValues,
365
+ isDisabled: props.isDisabled,
366
+ isPersistent: props.isPersistent,
367
+ onRemoveRequest: props.onRemoveRequest
368
+ })
369
+ }), jsxRuntime.jsx(Popover__namespace.Portal, {
370
+ children: jsxRuntime.jsxs(Popover__namespace.Content, {
371
+ side: "bottom",
372
+ align: "start",
373
+ css: menuStyles,
374
+ onOpenAutoFocus: focusMenuBody,
375
+ children: [jsxRuntime.jsx(Header$1, {
376
+ label: props.label,
377
+ renderOperatorsInput: props.renderOperatorsInput,
378
+ onSortRequest: props.onSortRequest
379
+ }), jsxRuntime.jsx("div", {
380
+ css: menuBodyStyle,
381
+ ref: menuBodyRef,
382
+ children: props.renderMenuBody()
383
+ }), jsxRuntime.jsx(Footer$1, {
384
+ onClearRequest: props.onClearRequest,
385
+ renderApplyButton: props.renderApplyButton
386
+ })]
387
+ })
388
+ })]
389
+ });
390
+ }
391
+ FilterMenu.propTypes = process.env.NODE_ENV !== "production" ? {
76
392
  filterKey: _pt__default["default"].string.isRequired,
77
393
  label: _pt__default["default"].node.isRequired,
78
394
  renderMenuBody: _pt__default["default"].func.isRequired,
79
395
  renderOperatorsInput: _pt__default["default"].func,
396
+ operatorLabel: _pt__default["default"].node,
80
397
  isPersistent: _pt__default["default"].bool,
81
398
  isDisabled: _pt__default["default"].bool,
82
399
  onRemoveRequest: _pt__default["default"].func,
@@ -86,28 +403,132 @@ process.env.NODE_ENV !== "production" ? {
86
403
  defaultOpen: _pt__default["default"].bool
87
404
  } : {};
88
405
 
406
+ var messages = reactIntl.defineMessages({
407
+ addFilterButtonLabel: {
408
+ id: 'UIKit.AddFilterButton.addFilterButtonLabel',
409
+ description: 'Label for the add filter button',
410
+ defaultMessage: 'Add filter'
411
+ },
412
+ clearAllFiltersButtonLabel: {
413
+ id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
414
+ description: 'Label for the clear all filters button',
415
+ defaultMessage: 'Clear all'
416
+ },
417
+ filtersButtonLabel: {
418
+ id: 'UIKit.FiltersButton.filtersButtonLabel',
419
+ description: 'Label for the filters button',
420
+ defaultMessage: 'Filters'
421
+ }
422
+ });
423
+
89
424
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
90
- const horizontalDividerStyles = /*#__PURE__*/react.css("width:100%;height:1px;border:1px solid ", designSystem.designTokens.colorNeutral90, ";margin-top:", designSystem.designTokens.spacing25, ";margin-bottom:", designSystem.designTokens.spacing30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:horizontalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAqHmC","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
91
- const verticalDividerStyles = /*#__PURE__*/react.css("width:1px;height:", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorNeutral90, ";margin:0 ", designSystem.designTokens.spacing20, " 0 ", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:verticalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA6HiC","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
92
- const menuListStyles = /*#__PURE__*/react.css("width:100%;display:flex;align-items:center;gap:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuListStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAoI0B","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
93
- var _ref2 = process.env.NODE_ENV === "production" ? {
425
+ const horizontalDividerStyles = /*#__PURE__*/react.css("color:", designSystem.designTokens.colorNeutral90, ";background-color:", designSystem.designTokens.colorNeutral90, ";width:100%;height:1px;border:0;margin-top:", designSystem.designTokens.spacing25, ";margin-bottom:", designSystem.designTokens.spacing30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:horizontalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA6JmC","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
426
+ const verticalDividerStyles = /*#__PURE__*/react.css("width:1px;height:", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorNeutral90, ";margin:0 ", designSystem.designTokens.spacing20, " 0 ", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:verticalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAuKiC","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
427
+ const menuListStyles = /*#__PURE__*/react.css("width:100%;display:flex;flex-wrap:wrap;align-items:center;gap:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuListStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA8K0B","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
428
+ function getFilterOptions(filters, filterGroups) {
429
+ let filterOptions = [];
430
+ // define option groups
431
+ if (filterGroups) {
432
+ filterOptions = _mapInstanceProperty__default["default"](filterGroups).call(filterGroups, filterGroup => ({
433
+ label: filterGroup.label,
434
+ key: filterGroup.key,
435
+ options: []
436
+ }));
437
+ }
438
+ return _reduceInstanceProperty__default["default"](filters).call(filters, (filterOptions, filter) => {
439
+ const formattedOption = {
440
+ value: filter.key,
441
+ label: filter.label,
442
+ isDisabled: filter.isDisabled
443
+ };
444
+ //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group
445
+ if (filter.groupKey && filterGroups) {
446
+ const optionGroup = _findInstanceProperty__default["default"](filterOptions).call(filterOptions, option => 'key' in option && option.key === filter.groupKey);
447
+ if (optionGroup && 'options' in optionGroup) {
448
+ optionGroup.options.push(formattedOption);
449
+ return filterOptions;
450
+ }
451
+ }
452
+ // otherwise add option directly
453
+ return [formattedOption, ...filterOptions];
454
+ }, filterOptions);
455
+ }
456
+ var _ref9 = process.env.NODE_ENV === "production" ? {
94
457
  name: "1lv1yo7",
95
458
  styles: "display:inline-flex"
96
459
  } : {
97
460
  name: "irmyae-Filters",
98
461
  styles: "display:inline-flex;label:Filters;",
99
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA2KuB","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
462
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAwWuB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
100
463
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
464
  };
102
- function Filters(props) {
465
+ function Filters(_ref) {
466
+ var _context, _context2;
467
+ let appliedFilters = _ref.appliedFilters,
468
+ filters = _ref.filters,
469
+ filterGroups = _ref.filterGroups,
470
+ onClearAllRequest = _ref.onClearAllRequest,
471
+ onAddFilterRequest = _ref.onAddFilterRequest,
472
+ renderSearchComponent = _ref.renderSearchComponent,
473
+ _ref$defaultOpen = _ref.defaultOpen,
474
+ defaultOpen = _ref$defaultOpen === void 0 ? false : _ref$defaultOpen;
103
475
  const intl = reactIntl.useIntl();
104
- const _useState = react$1.useState(false),
476
+ const _useState = react$1.useState(defaultOpen),
105
477
  _useState2 = _slicedToArray(_useState, 2),
106
- showAddFilters = _useState2[0],
107
- setShowAddFilters = _useState2[1];
478
+ showFilterControls = _useState2[0],
479
+ setShowFilterControls = _useState2[1];
108
480
  const handleFiltersClick = () => {
109
- setShowAddFilters(currState => !currState);
481
+ setShowFilterControls(currState => !currState);
110
482
  };
483
+ /**
484
+ * persisted filters: always visible
485
+ * applied filters: filters for which values have been selected
486
+ * visible filters = persisted + applied
487
+ *
488
+ * visibleFiltersFromProps = filters visible based on props
489
+ * localVisibleFilters = filters actually visible in component currently
490
+ */
491
+ const persistedFilterKeys = _mapInstanceProperty__default["default"](_context = _filterInstanceProperty__default["default"](filters).call(filters, _ref2 => {
492
+ let isPersistent = _ref2.isPersistent;
493
+ return isPersistent;
494
+ })).call(_context, filter => filter.key);
495
+ const persistedFiltersRef = react$1.useRef(persistedFilterKeys);
496
+ const appliedFilterKeys = _mapInstanceProperty__default["default"](appliedFilters).call(appliedFilters, _ref3 => {
497
+ let filterKey = _ref3.filterKey;
498
+ return filterKey;
499
+ });
500
+
501
+ // applied filters must have corresponding filter in `props.filters`,
502
+ const visibleFiltersFromProps = _sortInstanceProperty__default["default"](_context2 = _filterInstanceProperty__default["default"](filters).call(filters, _ref4 => {
503
+ let key = _ref4.key,
504
+ isPersistent = _ref4.isPersistent;
505
+ const isVisible = Boolean(isPersistent) || _includesInstanceProperty__default["default"](appliedFilterKeys).call(appliedFilterKeys, key);
506
+ return isVisible;
507
+ })
508
+ // persistent filters should be first in filter list
509
+ ).call(_context2, _ref5 => {
510
+ let isPersistent = _ref5.isPersistent;
511
+ return isPersistent ? -1 : 1;
512
+ });
513
+
514
+ // set initial state as visibleFiltersFromProps
515
+ const _useState3 = react$1.useState(_mapInstanceProperty__default["default"](visibleFiltersFromProps).call(visibleFiltersFromProps, _ref6 => {
516
+ let key = _ref6.key;
517
+ return key;
518
+ })),
519
+ _useState4 = _slicedToArray(_useState3, 2),
520
+ localVisibleFilters = _useState4[0],
521
+ setLocalVisibleFilters = _useState4[1];
522
+
523
+ //update localVisibleFilters if persisted filter count changes
524
+ if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {
525
+ setLocalVisibleFilters(_mapInstanceProperty__default["default"](visibleFiltersFromProps).call(visibleFiltersFromProps, _ref7 => {
526
+ let key = _ref7.key;
527
+ return key;
528
+ }));
529
+ persistedFiltersRef.current = persistedFilterKeys;
530
+ }
531
+ const removeFilter = filterKey => setLocalVisibleFilters(currentVisibleFilters => _filterInstanceProperty__default["default"](currentVisibleFilters).call(currentVisibleFilters, visibleFilterKey => visibleFilterKey !== filterKey));
111
532
  return jsxRuntime.jsxs(jsxRuntime.Fragment, {
112
533
  children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
113
534
  scale: "m",
@@ -115,54 +536,105 @@ function Filters(props) {
115
536
  children: [jsxRuntime.jsx("div", {
116
537
  css: /*#__PURE__*/react.css({
117
538
  maxWidth: `${designSystem.designTokens.constraint16}`
118
- }, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAsJa","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"),
119
- children: props.renderSearchComponent()
120
- }), jsxRuntime.jsx(FlatButton__default["default"], {
121
- "data-testid": "filters-button",
122
- label: intl.formatMessage(messages.filtersButtonLabel),
123
- icon: jsxRuntime.jsx(icons.FilterIcon, {}),
124
- onClick: handleFiltersClick
539
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAsRa","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"),
540
+ children: renderSearchComponent
541
+ }), jsxRuntime.jsxs(Spacings__default["default"].Inline, {
542
+ scale: "s",
543
+ alignItems: "center",
544
+ children: [jsxRuntime.jsx(FlatButton__default["default"], {
545
+ label: intl.formatMessage(messages.filtersButtonLabel),
546
+ icon: jsxRuntime.jsx(icons.FilterIcon, {}),
547
+ onClick: handleFiltersClick
548
+ }), appliedFilters.length > 1 && !showFilterControls && jsxRuntime.jsx(Badge, {
549
+ id: 'uikit-filters-selected-filter-count',
550
+ label: `${appliedFilters.length}`
551
+ })]
125
552
  })]
126
- }), jsxRuntime.jsx("div", {
553
+ }), jsxRuntime.jsx("hr", {
127
554
  css: horizontalDividerStyles
128
555
  }), jsxRuntime.jsx(CollapsibleMotion__default["default"], {
129
- isClosed: !showAddFilters,
130
- onToggle: () => setShowAddFilters(!showAddFilters),
131
- children: _ref => {
132
- let registerContentNode = _ref.registerContentNode,
133
- containerStyles = _ref.containerStyles;
556
+ isClosed: !showFilterControls,
557
+ onToggle: () => setShowFilterControls(!showFilterControls),
558
+ children: _ref8 => {
559
+ let registerContentNode = _ref8.registerContentNode,
560
+ containerStyles = _ref8.containerStyles;
134
561
  return jsxRuntime.jsx("div", {
135
562
  style: containerStyles,
136
563
  children: jsxRuntime.jsxs("div", {
137
564
  ref: registerContentNode,
138
565
  css: menuListStyles,
139
- children: [jsxRuntime.jsxs(Popover__namespace.Root, {
566
+ "aria-live": "polite",
567
+ children: [_mapInstanceProperty__default["default"](localVisibleFilters).call(localVisibleFilters, activeFilter => {
568
+ const activeFilterConfig = _findInstanceProperty__default["default"](filters).call(filters, filter => filter.key === activeFilter);
569
+ return jsxRuntime.jsx(FilterMenu, {
570
+ filterKey: activeFilterConfig.key,
571
+ label: activeFilterConfig.label,
572
+ operatorLabel: activeFilterConfig.operatorLabel,
573
+ isPersistent: activeFilterConfig.isPersistent,
574
+ isDisabled: activeFilterConfig.isDisabled,
575
+ renderMenuBody: activeFilterConfig.filterMenuConfiguration.renderMenuBody,
576
+ renderOperatorsInput: activeFilterConfig.filterMenuConfiguration.renderOperatorsInput,
577
+ renderApplyButton: activeFilterConfig.filterMenuConfiguration.renderApplyButton,
578
+ appliedFilterValues: _findInstanceProperty__default["default"](appliedFilters).call(appliedFilters, appliedFilter => activeFilter === appliedFilter.filterKey)?.values,
579
+ onClearRequest: activeFilterConfig.filterMenuConfiguration.onClearRequest,
580
+ onRemoveRequest: e => {
581
+ removeFilter(activeFilter);
582
+ activeFilterConfig.filterMenuConfiguration.onClearRequest(e);
583
+ },
584
+ onSortRequest: activeFilterConfig.filterMenuConfiguration.onSortRequest,
585
+ defaultOpen: activeFilterConfig.isPersistent || localVisibleFilters.length === visibleFiltersFromProps.length ? false : true
586
+ }, activeFilterConfig.key);
587
+ }), jsxRuntime.jsxs(Popover__namespace.Root, {
140
588
  children: [jsxRuntime.jsx(Popover__namespace.Trigger, {
141
589
  asChild: true,
142
590
  children: jsxRuntime.jsx("div", {
143
- css: _ref2,
591
+ css: _ref9,
144
592
  children: jsxRuntime.jsx(FlatButton__default["default"], {
145
- "data-testid": "add-filter-button",
146
593
  label: intl.formatMessage(messages.addFilterButtonLabel),
147
594
  icon: jsxRuntime.jsx(icons.PlusBoldIcon, {}),
148
- onClick: () => setShowAddFilters(true)
595
+ onClick: e => {
596
+ if (onAddFilterRequest) {
597
+ onAddFilterRequest(e);
598
+ }
599
+ setShowFilterControls(true);
600
+ }
149
601
  })
150
602
  })
151
603
  }), jsxRuntime.jsx(Popover__namespace.Portal, {
152
604
  children: jsxRuntime.jsx(Popover__namespace.Content, {
153
605
  side: "bottom",
154
606
  align: "start",
155
- css: menuStyles,
156
- children: jsxRuntime.jsx(SelectInput__default["default"], {})
607
+ css: [menuStyles, menuBodyStyle, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAyXoB","file":"filters.tsx","sourcesContent":["import {\n  type ReactNode,\n  type MouseEvent,\n  type KeyboardEvent,\n  useRef,\n  useState,\n} from 'react';\nimport { css } from '@emotion/react';\nimport * as Popover from '@radix-ui/react-popover';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport SelectInput, {\n  TOption,\n  TOptionObject,\n} from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { useIntl } from 'react-intl';\nimport FilterMenu, {\n  menuStyles,\n  menuBodyStyle,\n  type TAppliedFilterValue,\n} from './filter-menu';\nimport messages from './messages';\nimport { Badge } from './badge';\n\ninterface TAddFilterSelectOption extends TOption {\n  isDisabled?: boolean;\n}\n\ninterface TAddFilterOptionGroup extends TOptionObject {\n  options: TAddFilterSelectOption[];\n  label: ReactNode;\n  key: string;\n}\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\nexport type TFilterConfiguration = {\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n  /**\n   * formatted message to display the selected operator value\n   */\n  operatorLabel?: ReactNode;\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactNode;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactNode;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: (\n      event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n    ) => void;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * indicates whether the filter is disabled\n   */\n  isDisabled?: boolean;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   *\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   *\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n\n  /**\n   * controls the `clear all` (added filters) button from the menu list, meant to clear the parent application's filter state\n   */\n  onClearAllRequest: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * optional callback when the add filter button is clicked\n   */\n  onAddFilterRequest?: (\n    event?: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>\n  ) => void;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: ReactNode;\n  /**\n   * controls whether the filters list is initially open\n   */\n  defaultOpen?: boolean;\n};\n\nconst horizontalDividerStyles = css`\n  color: ${designTokens.colorNeutral90};\n  background-color: ${designTokens.colorNeutral90};\n  width: 100%;\n  height: 1px;\n  border: 0;\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  flex-wrap: wrap;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction getFilterOptions(\n  filters: TFilterConfiguration[],\n  filterGroups?: TFilterGroupConfiguration[]\n): (TAddFilterSelectOption | TAddFilterOptionGroup)[] {\n  let filterOptions: (TAddFilterSelectOption | TAddFilterOptionGroup)[] = [];\n  // define option groups\n  if (filterGroups) {\n    filterOptions = filterGroups.map((filterGroup) => ({\n      label: filterGroup.label,\n      key: filterGroup.key,\n      options: [],\n    }));\n  }\n  return filters.reduce((filterOptions, filter) => {\n    const formattedOption = {\n      value: filter.key,\n      label: filter.label,\n      isDisabled: filter.isDisabled,\n    };\n    //if theres a groupkey, filterGroups, and the groupKey matches a filterGroup, add option to its group\n    if (filter.groupKey && filterGroups) {\n      const optionGroup = filterOptions.find(\n        (option) => 'key' in option && option.key === filter.groupKey\n      );\n      if (optionGroup && 'options' in optionGroup) {\n        optionGroup.options.push(formattedOption);\n        return filterOptions;\n      }\n    }\n    // otherwise add option directly\n    return [formattedOption, ...filterOptions];\n  }, filterOptions);\n}\n\nfunction Filters({\n  appliedFilters,\n  filters,\n  filterGroups,\n  onClearAllRequest,\n  onAddFilterRequest,\n  renderSearchComponent,\n  defaultOpen = false,\n}: TFiltersProps) {\n  const intl = useIntl();\n  const [showFilterControls, setShowFilterControls] = useState(defaultOpen);\n\n  const handleFiltersClick = () => {\n    setShowFilterControls((currState) => !currState);\n  };\n  /**\n   * persisted filters: always visible\n   * applied filters: filters for which values have been selected\n   * visible filters = persisted + applied\n   *\n   * visibleFiltersFromProps = filters visible based on props\n   * localVisibleFilters = filters actually visible in component currently\n   */\n  const persistedFilterKeys = filters\n    .filter(({ isPersistent }) => isPersistent)\n    .map((filter) => filter.key);\n\n  const persistedFiltersRef = useRef<string[]>(persistedFilterKeys);\n\n  const appliedFilterKeys = appliedFilters.map(({ filterKey }) => filterKey);\n\n  // applied filters must have corresponding filter in `props.filters`,\n  const visibleFiltersFromProps = filters\n    .filter(({ key, isPersistent }) => {\n      const isVisible =\n        Boolean(isPersistent) || appliedFilterKeys.includes(key);\n      return isVisible;\n    })\n    // persistent filters should be first in filter list\n    .sort(({ isPersistent }) => (isPersistent ? -1 : 1));\n\n  // set initial state as visibleFiltersFromProps\n  const [localVisibleFilters, setLocalVisibleFilters] = useState<string[]>(\n    visibleFiltersFromProps.map(({ key }) => key)\n  );\n\n  //update localVisibleFilters if persisted filter count changes\n  if (persistedFiltersRef.current.length !== persistedFilterKeys.length) {\n    setLocalVisibleFilters(visibleFiltersFromProps.map(({ key }) => key));\n    persistedFiltersRef.current = persistedFilterKeys;\n  }\n\n  const removeFilter = (filterKey: string) =>\n    setLocalVisibleFilters((currentVisibleFilters) =>\n      currentVisibleFilters.filter(\n        (visibleFilterKey) => visibleFilterKey !== filterKey\n      )\n    );\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {renderSearchComponent}\n        </div>\n        <Spacings.Inline scale=\"s\" alignItems=\"center\">\n          <FlatButton\n            label={intl.formatMessage(messages.filtersButtonLabel)}\n            icon={<FilterIcon />}\n            onClick={handleFiltersClick}\n          />\n          {appliedFilters.length > 1 && !showFilterControls && (\n            <Badge\n              id={'uikit-filters-selected-filter-count'}\n              label={`${appliedFilters.length}`}\n            />\n          )}\n        </Spacings.Inline>\n      </Spacings.Inline>\n      <hr css={horizontalDividerStyles} />\n      <CollapsibleMotion\n        isClosed={!showFilterControls}\n        onToggle={() => setShowFilterControls(!showFilterControls)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div\n              ref={registerContentNode}\n              css={menuListStyles}\n              aria-live=\"polite\"\n            >\n              {localVisibleFilters.map((activeFilter) => {\n                const activeFilterConfig = filters.find(\n                  (filter) => filter.key === activeFilter\n                )!;\n                return (\n                  <FilterMenu\n                    key={activeFilterConfig.key}\n                    filterKey={activeFilterConfig.key}\n                    label={activeFilterConfig.label}\n                    operatorLabel={activeFilterConfig.operatorLabel}\n                    isPersistent={activeFilterConfig.isPersistent}\n                    isDisabled={activeFilterConfig.isDisabled}\n                    renderMenuBody={\n                      activeFilterConfig.filterMenuConfiguration.renderMenuBody\n                    }\n                    renderOperatorsInput={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderOperatorsInput\n                    }\n                    renderApplyButton={\n                      activeFilterConfig.filterMenuConfiguration\n                        .renderApplyButton\n                    }\n                    appliedFilterValues={\n                      appliedFilters.find(\n                        (appliedFilter) =>\n                          activeFilter === appliedFilter.filterKey\n                      )?.values\n                    }\n                    onClearRequest={\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest\n                    }\n                    onRemoveRequest={(e) => {\n                      removeFilter(activeFilter);\n                      activeFilterConfig.filterMenuConfiguration.onClearRequest(\n                        e\n                      );\n                    }}\n                    onSortRequest={\n                      activeFilterConfig.filterMenuConfiguration.onSortRequest\n                    }\n                    defaultOpen={\n                      activeFilterConfig.isPersistent ||\n                      localVisibleFilters.length ===\n                        visibleFiltersFromProps.length\n                        ? false\n                        : true\n                    }\n                  />\n                );\n              })}\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={(e) => {\n                        if (onAddFilterRequest) {\n                          onAddFilterRequest(e);\n                        }\n                        setShowFilterControls(true);\n                      }}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content\n                    side=\"bottom\"\n                    align=\"start\"\n                    css={[menuStyles, menuBodyStyle]}\n                  >\n                    <SelectInput\n                      id=\"ui-kit-add-filters-select\"\n                      name=\"select filters\"\n                      aria-label=\"select filters\"\n                      appearance=\"filter\"\n                      options={\n                        getFilterOptions(filters, filterGroups) as TOption[]\n                      }\n                      onChange={(e) => {\n                        setLocalVisibleFilters(\n                          Array.prototype.concat(\n                            e.target.value ? e.target.value : []\n                          )\n                        );\n                      }}\n                      value={localVisibleFilters}\n                      isMulti={true}\n                      // @ts-ignore\n                      isOptionDisabled={(option: TAddFilterSelectOption) =>\n                        option.isDisabled\n                      }\n                    />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              {appliedFilters.length > 1 && (\n                <>\n                  <div css={verticalDividerStyles} />\n                  <FlatButton\n                    icon={<CloseBoldIcon />}\n                    label={intl.formatMessage(\n                      messages.clearAllFiltersButtonLabel\n                    )}\n                    onClick={(e) => {\n                      onClearAllRequest(e);\n                      setLocalVisibleFilters(persistedFilterKeys);\n                    }}\n                    tone=\"secondary\"\n                  />\n                </>\n              )}\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"],
608
+ children: jsxRuntime.jsx(SelectInput__default["default"], {
609
+ id: "ui-kit-add-filters-select",
610
+ name: "select filters",
611
+ "aria-label": "select filters",
612
+ appearance: "filter",
613
+ options: getFilterOptions(filters, filterGroups),
614
+ onChange: e => {
615
+ var _context3;
616
+ setLocalVisibleFilters(_concatInstanceProperty__default["default"](_context3 = Array.prototype).call(_context3, e.target.value ? e.target.value : []));
617
+ },
618
+ value: localVisibleFilters,
619
+ isMulti: true
620
+ // @ts-ignore
621
+ ,
622
+ isOptionDisabled: option => option.isDisabled
623
+ })
157
624
  })
158
625
  })]
159
- }), jsxRuntime.jsx("div", {
160
- css: verticalDividerStyles
161
- }), jsxRuntime.jsx(FlatButton__default["default"], {
162
- icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
163
- label: intl.formatMessage(messages.clearAllFiltersButtonLabel),
164
- onClick: props.onClearAllRequest,
165
- tone: "secondary"
626
+ }), appliedFilters.length > 1 && jsxRuntime.jsxs(jsxRuntime.Fragment, {
627
+ children: [jsxRuntime.jsx("div", {
628
+ css: verticalDividerStyles
629
+ }), jsxRuntime.jsx(FlatButton__default["default"], {
630
+ icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
631
+ label: intl.formatMessage(messages.clearAllFiltersButtonLabel),
632
+ onClick: e => {
633
+ onClearAllRequest(e);
634
+ setLocalVisibleFilters(persistedFilterKeys);
635
+ },
636
+ tone: "secondary"
637
+ })]
166
638
  })]
167
639
  })
168
640
  });
@@ -176,31 +648,33 @@ Filters.propTypes = process.env.NODE_ENV !== "production" ? {
176
648
  values: _pt__default["default"].arrayOf(_pt__default["default"].any).isRequired
177
649
  })).isRequired,
178
650
  filters: _pt__default["default"].arrayOf(_pt__default["default"].shape({
651
+ key: _pt__default["default"].string.isRequired,
652
+ label: _pt__default["default"].node.isRequired,
653
+ operatorLabel: _pt__default["default"].node,
179
654
  filterMenuConfiguration: _pt__default["default"].shape({
180
655
  renderMenuBody: _pt__default["default"].func.isRequired,
181
656
  renderOperatorsInput: _pt__default["default"].func,
182
657
  renderApplyButton: _pt__default["default"].func,
183
- onClearRequest: _pt__default["default"].any.isRequired,
184
- onSortRequest: _pt__default["default"].any
658
+ onClearRequest: _pt__default["default"].func.isRequired,
659
+ onSortRequest: _pt__default["default"].func
185
660
  }).isRequired,
186
661
  groupKey: _pt__default["default"].string,
187
662
  isPersistent: _pt__default["default"].bool,
188
- isDisabled: _pt__default["default"].bool,
189
- key: _pt__default["default"].string.isRequired,
190
- label: _pt__default["default"].node.isRequired
663
+ isDisabled: _pt__default["default"].bool
191
664
  })).isRequired,
192
665
  filterGroups: _pt__default["default"].arrayOf(_pt__default["default"].shape({
193
666
  key: _pt__default["default"].string.isRequired,
194
667
  label: _pt__default["default"].node.isRequired
195
668
  })),
196
669
  onClearAllRequest: _pt__default["default"].func.isRequired,
197
- onAddFilterRequest: _pt__default["default"].any,
198
- renderSearchComponent: _pt__default["default"].func.isRequired
670
+ onAddFilterRequest: _pt__default["default"].func,
671
+ renderSearchComponent: _pt__default["default"].node.isRequired,
672
+ defaultOpen: _pt__default["default"].bool
199
673
  } : {};
200
674
  Filters.displayName = 'Filters';
201
675
 
202
676
  // NOTE: This string will be replaced on build time with the package version.
203
- var version = "19.15.0";
677
+ var version = "19.16.0";
204
678
 
205
679
  exports["default"] = Filters;
206
680
  exports.version = version;