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