@commercetools-uikit/filters 19.12.1 → 19.14.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.
@@ -2,28 +2,205 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var react = require('@emotion/react');
6
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
7
+ var _pt = require('prop-types');
8
+ var Popover = require('@radix-ui/react-popover');
9
+ var FlatButton = require('@commercetools-uikit/flat-button');
10
+ var SelectInput = require('@commercetools-uikit/select-input');
11
+ var icons = require('@commercetools-uikit/icons');
12
+ var react$1 = require('react');
13
+ var Spacings = require('@commercetools-uikit/spacings');
5
14
  var designSystem = require('@commercetools-uikit/design-system');
15
+ var reactIntl = require('react-intl');
6
16
  var jsxRuntime = require('@emotion/react/jsx-runtime');
17
+ var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
7
18
 
19
+ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
20
+
21
+ function _interopNamespace(e) {
22
+ if (e && e.__esModule) return e;
23
+ var n = Object.create(null);
24
+ if (e) {
25
+ Object.keys(e).forEach(function (k) {
26
+ if (k !== 'default') {
27
+ var d = Object.getOwnPropertyDescriptor(e, k);
28
+ Object.defineProperty(n, k, d.get ? d : {
29
+ enumerable: true,
30
+ get: function () { return e[k]; }
31
+ });
32
+ }
33
+ });
34
+ }
35
+ n["default"] = e;
36
+ return Object.freeze(n);
37
+ }
38
+
39
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
40
+ var Popover__namespace = /*#__PURE__*/_interopNamespace(Popover);
41
+ var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
42
+ var SelectInput__default = /*#__PURE__*/_interopDefault(SelectInput);
43
+ var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
44
+ var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
45
+
46
+ var messages = reactIntl.defineMessages({
47
+ addFilterButtonLabel: {
48
+ id: 'UIKit.AddFilterButton.addFilterButtonLabel',
49
+ description: 'Label for the add filter button',
50
+ defaultMessage: 'Add filter'
51
+ },
52
+ clearAllFiltersButtonLabel: {
53
+ id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
54
+ description: 'Label for the clear all filters button',
55
+ defaultMessage: 'Clear all'
56
+ },
57
+ filtersButtonLabel: {
58
+ id: 'UIKit.FiltersButton.filtersButtonLabel',
59
+ description: 'Label for the filters button',
60
+ defaultMessage: 'Filters'
61
+ }
62
+ });
63
+
64
+ function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
65
+ const menuStyles = /*#__PURE__*/react.css("display:flex;flex-direction:column;align-items:flex-start;gap:", designSystem.designTokens.spacing30, ";width:", designSystem.designTokens.constraint6, ";padding:", designSystem.designTokens.spacing20, " ", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius8, ";box-shadow:", designSystem.designTokens.shadow18, ";animation-duration:", designSystem.designTokens.transitionStandard, ";will-change:'transform, opacity';margin-top:", designSystem.designTokens.spacing10, ";position:relative;z-index:5;" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2RjZCIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIHRoZSB2YWx1ZXMgYXBwbGllZCB0byB0aGlzIGZpbHRlciBieSB0aGUgdXNlclxuICAgKi9cbiAgYXBwbGllZEZpbHRlclZhbHVlczogVEFwcGxpZWRGaWx0ZXJWYWx1ZVtdIHwgdW5kZWZpbmVkIHwgbnVsbDtcbiAgLyoqXG4gICAqIGluZGljYXRlcyB3aGV0aGVyIEZpbHRlck1lbnUgY2FuIGJlIHJlbW92ZWQgZnJvbSB0aGUgZmlsdGVyc0xpc3RcbiAgICovXG4gIGlzUGVyc2lzdGVudD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiB3aGV0aGVyIG9yIG5vdCB0aGUgZmlsdGVyIGlzIGRpc2FibGVkXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgYHhgIGluIFRyaWdnZXIgQnV0dG9uIGlzIGRpc3BsYXllZCAtIHJlcXVpcmVkIGlmIGBpc1BlcnNpc3RlbnRgIGlzIGBmYWxzZWBcbiAgICovXG4gIG9uUmVtb3ZlUmVxdWVzdD86IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuY29uc3QgbWVudUJvZHlTdHlsZSA9IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3QgZGVmYXVsdE9wZW49e3Byb3BzLmlzRGlzYWJsZWQgPyBmYWxzZSA6IHByb3BzLmRlZmF1bHRPcGVufT5cbiAgICAgIDxQb3BvdmVyLlRyaWdnZXIgYXNDaGlsZD5cbiAgICAgICAgPFRyaWdnZXJCdXR0b25cbiAgICAgICAgICBmaWx0ZXJLZXk9e3Byb3BzLmZpbHRlcktleX1cbiAgICAgICAgICBsYWJlbD17cHJvcHMubGFiZWx9XG4gICAgICAgICAgYXBwbGllZEZpbHRlclZhbHVlcz17cHJvcHMuYXBwbGllZEZpbHRlclZhbHVlc31cbiAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgIGlzUGVyc2lzdGVudD17cHJvcHMuaXNQZXJzaXN0ZW50fVxuICAgICAgICAgIG9uUmVtb3ZlUmVxdWVzdD17cHJvcHMub25SZW1vdmVSZXF1ZXN0fVxuICAgICAgICAvPlxuICAgICAgPC9Qb3BvdmVyLlRyaWdnZXI+XG4gICAgICA8UG9wb3Zlci5Qb3J0YWw+XG4gICAgICAgIDxQb3BvdmVyLkNvbnRlbnRcbiAgICAgICAgICBzaWRlPVwiYm90dG9tXCJcbiAgICAgICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICAgICAgICBjc3M9e21lbnVTdHlsZXN9XG4gICAgICAgICAgb25PcGVuQXV0b0ZvY3VzPXtmb2N1c01lbnVCb2R5fVxuICAgICAgICA+XG4gICAgICAgICAgPEhlYWRlclxuICAgICAgICAgICAgbGFiZWw9e3Byb3BzLmxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyT3BlcmF0b3JzSW5wdXQ9e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0fVxuICAgICAgICAgICAgb25Tb3J0UmVxdWVzdD17cHJvcHMub25Tb3J0UmVxdWVzdH1cbiAgICAgICAgICAvPlxuICAgICAgICAgIDxkaXYgY3NzPXttZW51Qm9keVN0eWxlfSByZWY9e21lbnVCb2R5UmVmfT5cbiAgICAgICAgICAgIHtwcm9wcy5yZW5kZXJNZW51Qm9keSgpfVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxGb290ZXJcbiAgICAgICAgICAgIG9uQ2xlYXJSZXF1ZXN0PXtwcm9wcy5vbkNsZWFyUmVxdWVzdH1cbiAgICAgICAgICAgIHJlbmRlckFwcGx5QnV0dG9uPXtwcm9wcy5yZW5kZXJBcHBseUJ1dHRvbn1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1BvcG92ZXIuQ29udGVudD5cbiAgICAgIDwvUG9wb3Zlci5Qb3J0YWw+XG4gICAgPC9Qb3BvdmVyLlJvb3Q+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEZpbHRlck1lbnU7XG4iXX0= */");
66
+ process.env.NODE_ENV === "production" ? {
67
+ name: "1d3w5wq",
68
+ styles: "width:100%"
69
+ } : {
70
+ name: "11z4rpd-menuBodyStyle",
71
+ styles: "width:100%;label:menuBodyStyle;",
72
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImZpbHRlci1tZW51LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUErR3lCIiwiZmlsZSI6ImZpbHRlci1tZW51LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgUmVhY3ROb2RlLFxuICB0eXBlIE1vdXNlRXZlbnQsXG4gIHR5cGUgS2V5Ym9hcmRFdmVudCxcbiAgdXNlUmVmLFxuICB1c2VDYWxsYmFjayxcbn0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgKiBhcyBQb3BvdmVyIGZyb20gJ0ByYWRpeC11aS9yZWFjdC1wb3BvdmVyJztcbmltcG9ydCB7IEZvb3RlciB9IGZyb20gJy4vZm9vdGVyJztcbmltcG9ydCB7IEhlYWRlciB9IGZyb20gJy4vaGVhZGVyJztcbmltcG9ydCB7IFRyaWdnZXJCdXR0b24gfSBmcm9tICcuL3RyaWdnZXItYnV0dG9uJztcblxuLyoqXG4gKiBDU1Mgc2VsZWN0b3IgdG8gZmluZCBmb2N1c2FibGUgZWxlbWVudHMuXG4gKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9taWNyb3NvZnQvdGFic3Rlci9ibG9iLzZiZmQ1NGE0NWY1YjIwZWNjZDE3YjhhMDVmNmM4NmMyNDFiOTkyYzMvc3JjL0ZvY3VzYWJsZS50cyNMMTctTDI1XG4gKiBUT0RPOiBtYWtlIGF2YWlsYWJsZSBhcyBhIHV0aWwgZm9yIGdlbmVyYWwgdXNlXG4gKi9cbmNvbnN0IEZPQ1VTQUJMRV9DU1NfU0VMRUNUT1IgPSBgYVtocmVmXSwgYnV0dG9uOm5vdChbZGlzYWJsZWRdKSwgaW5wdXQ6bm90KFtkaXNhYmxlZF0pLCBzZWxlY3Q6bm90KFtkaXNhYmxlZF0pLCB0ZXh0YXJlYTpub3QoW2Rpc2FibGVkXSksICpbdGFiaW5kZXhdLCAqW2NvbnRlbnRlZGl0YWJsZV1gO1xuXG4vKipcbiAqIEZpbmQgdGhlIGZpcnN0IGZvY3VzYWJsZSBlbGVtZW50IGluIHRoZSBnaXZlbiBjb250YWluZXIsXG4gKiBzdWNoIGFzIHRoZSBmaXJzdCBmb2N1c2FibGUgbGlzdCBpdGVtLlxuICogQHBhcmFtIHtIVE1MRWxlbWVudH0gY29udGFpbmVyXG4gKiBAcmV0dXJucyB7SFRNTEVsZW1lbnQgfCBudWxsfVxuICovXG5mdW5jdGlvbiBmaW5kRmlyc3RGb2N1c2FibGU8VCBleHRlbmRzIEhUTUxFbGVtZW50Pihjb250YWluZXI6IFQpOiBUIHwgbnVsbCB7XG4gIHJldHVybiBjb250YWluZXIucXVlcnlTZWxlY3RvcihGT0NVU0FCTEVfQ1NTX1NFTEVDVE9SKTtcbn1cblxuZXhwb3J0IHR5cGUgVEFwcGxpZWRGaWx0ZXJWYWx1ZSA9IHtcbiAgdmFsdWU6IHN0cmluZztcbiAgbGFiZWw6IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRGaWx0ZXJNZW51UHJvcHMgPSB7XG4gIC8qKlxuICAgKiB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIGZpbHRlclxuICAgKi9cbiAgZmlsdGVyS2V5OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBmb3JtYXR0ZWQgbWVzc2FnZSB0byBkaXNwbGF5IHRoZSBmaWx0ZXIncyBuYW1lXG4gICAqL1xuICBsYWJlbDogUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIHNlbGVjdHMgdmFsdWVzIGZvciB0aGUgZmlsdGVyXG4gICAqL1xuICByZW5kZXJNZW51Qm9keTogKCkgPT4gUmVhY3ROb2RlO1xuICAvKipcbiAgICogdGhlIGlucHV0IGluIHdoaWNoIHRoZSB1c2VyIGNhbiBzZWxlY3Qgd2hpY2ggb3BlcmF0b3Igc2hvdWxkIGJlIHVzZWQgZm9yIHRoaXMgZmlsdGVyXG4gICAqL1xuICByZW5kZXJPcGVyYXRvcnNJbnB1dD86ICgpID0+IFJlYWN0Tm9kZTtcbiAgLyoqXG4gICAqIHRoZSB2YWx1ZXMgYXBwbGllZCB0byB0aGlzIGZpbHRlciBieSB0aGUgdXNlclxuICAgKi9cbiAgYXBwbGllZEZpbHRlclZhbHVlczogVEFwcGxpZWRGaWx0ZXJWYWx1ZVtdIHwgdW5kZWZpbmVkIHwgbnVsbDtcbiAgLyoqXG4gICAqIGluZGljYXRlcyB3aGV0aGVyIEZpbHRlck1lbnUgY2FuIGJlIHJlbW92ZWQgZnJvbSB0aGUgZmlsdGVyc0xpc3RcbiAgICovXG4gIGlzUGVyc2lzdGVudD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiB3aGV0aGVyIG9yIG5vdCB0aGUgZmlsdGVyIGlzIGRpc2FibGVkXG4gICAqL1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgYHhgIGluIFRyaWdnZXIgQnV0dG9uIGlzIGRpc3BsYXllZCAtIHJlcXVpcmVkIGlmIGBpc1BlcnNpc3RlbnRgIGlzIGBmYWxzZWBcbiAgICovXG4gIG9uUmVtb3ZlUmVxdWVzdD86IChcbiAgICBldmVudDogTW91c2VFdmVudDxIVE1MQnV0dG9uRWxlbWVudD4gfCBLZXlib2FyZEV2ZW50PEhUTUxCdXR0b25FbGVtZW50PlxuICApID0+IHZvaWQ7XG4gIC8qKlxuICAgKiBvcHRpb25hbCBidXR0b24gdGhhdCBhbGxvd3MgdGhlIHVzZXIgdG8gYXBwbHkgc2VsZWN0ZWQgZmlsdGVyIHZhbHVlc1xuICAgKi9cbiAgcmVuZGVyQXBwbHlCdXR0b24/OiAoKSA9PiBSZWFjdE5vZGU7XG4gIC8qKlxuICAgKiBjb250cm9scyB3aGV0aGVyIGBjbGVhciBhbGxgIGJ1dHRvbiBpbiBNZW51IEJvZHkgRm9vdGVyIGlzIGRpc3BsYXllZFxuICAgKi9cbiAgb25DbGVhclJlcXVlc3Q/OiAoXG4gICAgZXZlbnQ6IE1vdXNlRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+IHwgS2V5Ym9hcmRFdmVudDxIVE1MQnV0dG9uRWxlbWVudD5cbiAgKSA9PiB2b2lkO1xuICAvKipcbiAgICogY29udHJvbHMgd2hldGhlciBgc29ydGAgYnV0dG9uIGluIE1lbnUgQm9keSBIZWFkZXIgaXMgZGlzcGxheWVkXG4gICAqL1xuICBvblNvcnRSZXF1ZXN0PzogKFxuICAgIGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50PiB8IEtleWJvYXJkRXZlbnQ8SFRNTEJ1dHRvbkVsZW1lbnQ+XG4gICkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIGNvbnRyb2xzIHdoZXRoZXIgbWVudSBpcyBvcGVuIG9uIGluaXRpYWwgcmVuZGVyXG4gICAqL1xuICBkZWZhdWx0T3Blbj86IGJvb2xlYW47XG59O1xuXG5leHBvcnQgY29uc3QgbWVudVN0eWxlcyA9IGNzc2BcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzMwfTtcbiAgd2lkdGg6ICR7ZGVzaWduVG9rZW5zLmNvbnN0cmFpbnQ2fTtcbiAgcGFkZGluZzogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzIwfSAke2Rlc2lnblRva2Vucy5zcGFjaW5nMzB9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXI6IDFweCBzb2xpZCAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBib3JkZXItcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXM4fTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93MTh9O1xuICBhbmltYXRpb24tZHVyYXRpb246ICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIHdpbGwtY2hhbmdlOiAndHJhbnNmb3JtLCBvcGFjaXR5JztcbiAgbWFyZ2luLXRvcDogJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB6LWluZGV4OiA1O1xuYDtcblxuY29uc3QgbWVudUJvZHlTdHlsZSA9IGNzc2BcbiAgd2lkdGg6IDEwMCU7XG5gO1xuXG5mdW5jdGlvbiBGaWx0ZXJNZW51KHByb3BzOiBURmlsdGVyTWVudVByb3BzKSB7XG4gIGNvbnN0IG1lbnVCb2R5UmVmID0gdXNlUmVmPEhUTUxEaXZFbGVtZW50PihudWxsKTtcblxuICBjb25zdCBmb2N1c01lbnVCb2R5ID0gdXNlQ2FsbGJhY2soXG4gICAgKGUpID0+IHtcbiAgICAgIGlmIChtZW51Qm9keVJlZi5jdXJyZW50KSB7XG4gICAgICAgIGNvbnN0IGZpcnN0Rm9jdXNhYmxlRWxlbWVudEluTWVudUJvZHkgPSBmaW5kRmlyc3RGb2N1c2FibGUoXG4gICAgICAgICAgbWVudUJvZHlSZWYuY3VycmVudFxuICAgICAgICApO1xuICAgICAgICBpZiAoZmlyc3RGb2N1c2FibGVFbGVtZW50SW5NZW51Qm9keSkge1xuICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgICBmaXJzdEZvY3VzYWJsZUVsZW1lbnRJbk1lbnVCb2R5LmZvY3VzKCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9LFxuICAgIFttZW51Qm9keVJlZl1cbiAgKTtcblxuICByZXR1cm4gKFxuICAgIDxQb3BvdmVyLlJvb3QgZGVmYXVsdE9wZW49e3Byb3BzLmlzRGlzYWJsZWQgPyBmYWxzZSA6IHByb3BzLmRlZmF1bHRPcGVufT5cbiAgICAgIDxQb3BvdmVyLlRyaWdnZXIgYXNDaGlsZD5cbiAgICAgICAgPFRyaWdnZXJCdXR0b25cbiAgICAgICAgICBmaWx0ZXJLZXk9e3Byb3BzLmZpbHRlcktleX1cbiAgICAgICAgICBsYWJlbD17cHJvcHMubGFiZWx9XG4gICAgICAgICAgYXBwbGllZEZpbHRlclZhbHVlcz17cHJvcHMuYXBwbGllZEZpbHRlclZhbHVlc31cbiAgICAgICAgICBpc0Rpc2FibGVkPXtwcm9wcy5pc0Rpc2FibGVkfVxuICAgICAgICAgIGlzUGVyc2lzdGVudD17cHJvcHMuaXNQZXJzaXN0ZW50fVxuICAgICAgICAgIG9uUmVtb3ZlUmVxdWVzdD17cHJvcHMub25SZW1vdmVSZXF1ZXN0fVxuICAgICAgICAvPlxuICAgICAgPC9Qb3BvdmVyLlRyaWdnZXI+XG4gICAgICA8UG9wb3Zlci5Qb3J0YWw+XG4gICAgICAgIDxQb3BvdmVyLkNvbnRlbnRcbiAgICAgICAgICBzaWRlPVwiYm90dG9tXCJcbiAgICAgICAgICBhbGlnbj1cInN0YXJ0XCJcbiAgICAgICAgICBjc3M9e21lbnVTdHlsZXN9XG4gICAgICAgICAgb25PcGVuQXV0b0ZvY3VzPXtmb2N1c01lbnVCb2R5fVxuICAgICAgICA+XG4gICAgICAgICAgPEhlYWRlclxuICAgICAgICAgICAgbGFiZWw9e3Byb3BzLmxhYmVsfVxuICAgICAgICAgICAgcmVuZGVyT3BlcmF0b3JzSW5wdXQ9e3Byb3BzLnJlbmRlck9wZXJhdG9yc0lucHV0fVxuICAgICAgICAgICAgb25Tb3J0UmVxdWVzdD17cHJvcHMub25Tb3J0UmVxdWVzdH1cbiAgICAgICAgICAvPlxuICAgICAgICAgIDxkaXYgY3NzPXttZW51Qm9keVN0eWxlfSByZWY9e21lbnVCb2R5UmVmfT5cbiAgICAgICAgICAgIHtwcm9wcy5yZW5kZXJNZW51Qm9keSgpfVxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDxGb290ZXJcbiAgICAgICAgICAgIG9uQ2xlYXJSZXF1ZXN0PXtwcm9wcy5vbkNsZWFyUmVxdWVzdH1cbiAgICAgICAgICAgIHJlbmRlckFwcGx5QnV0dG9uPXtwcm9wcy5yZW5kZXJBcHBseUJ1dHRvbn1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1BvcG92ZXIuQ29udGVudD5cbiAgICAgIDwvUG9wb3Zlci5Qb3J0YWw+XG4gICAgPC9Qb3BvdmVyLlJvb3Q+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEZpbHRlck1lbnU7XG4iXX0= */",
73
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
74
+ };
75
+ process.env.NODE_ENV !== "production" ? {
76
+ filterKey: _pt__default["default"].string.isRequired,
77
+ label: _pt__default["default"].node.isRequired,
78
+ renderMenuBody: _pt__default["default"].func.isRequired,
79
+ renderOperatorsInput: _pt__default["default"].func,
80
+ isPersistent: _pt__default["default"].bool,
81
+ isDisabled: _pt__default["default"].bool,
82
+ onRemoveRequest: _pt__default["default"].func,
83
+ renderApplyButton: _pt__default["default"].func,
84
+ onClearRequest: _pt__default["default"].func,
85
+ onSortRequest: _pt__default["default"].func,
86
+ defaultOpen: _pt__default["default"].bool
87
+ } : {};
88
+
89
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
90
+ const horizontalDividerStyles = /*#__PURE__*/react.css("width:100%;height:1px;border:1px solid ", designSystem.designTokens.colorNeutral90, ";margin-top:", designSystem.designTokens.spacing25, ";margin-bottom:", designSystem.designTokens.spacing30, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:horizontalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAqHmC","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
91
+ const verticalDividerStyles = /*#__PURE__*/react.css("width:1px;height:", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorNeutral90, ";margin:0 ", designSystem.designTokens.spacing20, " 0 ", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:verticalDividerStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA6HiC","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
92
+ const menuListStyles = /*#__PURE__*/react.css("width:100%;display:flex;align-items:center;gap:", designSystem.designTokens.spacing20, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuListStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAoI0B","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */");
93
+ var _ref2 = process.env.NODE_ENV === "production" ? {
94
+ name: "1lv1yo7",
95
+ styles: "display:inline-flex"
96
+ } : {
97
+ name: "irmyae-Filters",
98
+ styles: "display:inline-flex;label:Filters;",
99
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AA2KuB","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */",
100
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
+ };
8
102
  function Filters(props) {
9
- return jsxRuntime.jsxs("div", {
10
- style: {
11
- display: 'flex',
12
- gap: designSystem.designTokens.spacing20
13
- },
14
- children: [jsxRuntime.jsx("div", {
15
- children: props.label
103
+ const intl = reactIntl.useIntl();
104
+ const _useState = react$1.useState(false),
105
+ _useState2 = _slicedToArray(_useState, 2),
106
+ showAddFilters = _useState2[0],
107
+ setShowAddFilters = _useState2[1];
108
+ const handleFiltersClick = () => {
109
+ setShowAddFilters(currState => !currState);
110
+ };
111
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
112
+ children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
113
+ scale: "m",
114
+ alignItems: "center",
115
+ children: [jsxRuntime.jsx("div", {
116
+ css: /*#__PURE__*/react.css({
117
+ maxWidth: `${designSystem.designTokens.constraint16}`
118
+ }, process.env.NODE_ENV === "production" ? "" : ";label:Filters;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["filters.tsx"],"names":[],"mappings":"AAsJa","file":"filters.tsx","sourcesContent":["import * as Popover from '@radix-ui/react-popover';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport SelectInput from '@commercetools-uikit/select-input';\nimport {\n  CloseBoldIcon,\n  FilterIcon,\n  PlusBoldIcon,\n} from '@commercetools-uikit/icons';\nimport { ReactElement, ReactNode, useState } from 'react';\nimport { type TAppliedFilterValue } from './filter-menu/filter-menu';\nimport { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';\nimport { type TSelectInputProps } from '@commercetools-uikit/select-input';\nimport Spacings from '@commercetools-uikit/spacings';\nimport { designTokens } from '@commercetools-uikit/design-system';\nimport { css } from '@emotion/react';\nimport messages from './messages';\nimport { useIntl } from 'react-intl';\nimport { menuStyles } from './filter-menu/filter-menu';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\n\ntype TAppliedFilter = {\n  /**\n   * unique identifier for the filter\n   */\n  filterKey: string;\n  /**\n   * the values applied to this filter by the user\n   */\n  values: TAppliedFilterValue[];\n};\n\ntype TFilterConfiguration = {\n  /**\n   * configuration object for the filter menu.\n   */\n  filterMenuConfiguration: {\n    /**\n     * the input in which the user selects values for the filter\n     */\n    renderMenuBody: () => ReactNode;\n    /**\n     * the input in which the user can select which operator should be used for this filter\n     */\n    renderOperatorsInput?: () => ReactElement<TSelectInputProps>;\n    /**\n     * optional button that allows the user to apply selected filter values\n     */\n    renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;\n    /**\n     * controls whether `clear` button in Menu Body Footer is displayed\n     */\n    onClearRequest: Function;\n    /**\n     * controls whether `sort` button in Menu Body Header is displayed\n     */\n    onSortRequest?: Function;\n  };\n  /**\n   * optional key to group filters together.\n   */\n  groupKey?: string;\n  /**\n   * indicates whether filter menu can be removed from filters\n   */\n  isPersistent?: boolean;\n  /**\n   * whether or not the filter is disabled\n   */\n  isDisabled?: boolean;\n  /**\n   * unique identifier for the filter\n   */\n  key: string;\n  /**\n   * formatted message to display the filter name\n   */\n  label: ReactNode;\n};\n\ntype TFilterGroupConfiguration = {\n  /**\n   * unique identifier for the filter group\n   */\n  key: string;\n  /**\n   * formatted message to display the filter group name\n   */\n  label: ReactNode;\n};\n\nexport type TFiltersProps = {\n  /**\n   * array of applied filters, each containing a unique key and an array of values.\n   */\n  appliedFilters: TAppliedFilter[];\n  /**\n   * configuration for the available filters.\n   */\n  filters: TFilterConfiguration[];\n  /**\n   * optional configuration for filter groups.\n   */\n  filterGroups?: TFilterGroupConfiguration[];\n  /**\n   * controls the `clear all` (added filters) button from the menu list\n   */\n  onClearAllRequest: () => void;\n  /**\n   * optional callback trigger to add a new filter.\n   */\n  onAddFilterRequest?: Function;\n  /**\n   * function to render a search input, selectable from applicable UI Kit components.\n   */\n  renderSearchComponent: () => ReactNode;\n};\n\nconst horizontalDividerStyles = css`\n  width: 100%;\n  height: 1px;\n  border: 1px solid ${designTokens.colorNeutral90};\n  margin-top: ${designTokens.spacing25};\n  margin-bottom: ${designTokens.spacing30};\n`;\n\nconst verticalDividerStyles = css`\n  width: 1px;\n  height: ${designTokens.spacing30};\n  background-color: ${designTokens.colorNeutral90};\n  margin: 0 ${designTokens.spacing20} 0 ${designTokens.spacing20};\n`;\n\nconst menuListStyles = css`\n  width: 100%;\n  display: flex;\n  align-items: center;\n  gap: ${designTokens.spacing20};\n`;\n\nfunction Filters(props: TFiltersProps) {\n  const intl = useIntl();\n  const [showAddFilters, setShowAddFilters] = useState(false);\n\n  const handleFiltersClick = () => {\n    setShowAddFilters((currState) => !currState);\n  };\n\n  return (\n    <>\n      <Spacings.Inline scale=\"m\" alignItems=\"center\">\n        <div css={{ maxWidth: `${designTokens.constraint16}` }}>\n          {props.renderSearchComponent()}\n        </div>\n        <FlatButton\n          data-testid=\"filters-button\"\n          label={intl.formatMessage(messages.filtersButtonLabel)}\n          icon={<FilterIcon />}\n          onClick={handleFiltersClick}\n        />\n      </Spacings.Inline>\n      <div css={horizontalDividerStyles} />\n\n      <CollapsibleMotion\n        isClosed={!showAddFilters}\n        onToggle={() => setShowAddFilters(!showAddFilters)}\n      >\n        {({ registerContentNode, containerStyles }) => (\n          <div style={containerStyles}>\n            <div ref={registerContentNode} css={menuListStyles}>\n              <Popover.Root>\n                <Popover.Trigger asChild>\n                  <div css={{ display: 'inline-flex' }}>\n                    <FlatButton\n                      data-testid=\"add-filter-button\"\n                      label={intl.formatMessage(messages.addFilterButtonLabel)}\n                      icon={<PlusBoldIcon />}\n                      onClick={() => setShowAddFilters(true)}\n                    />\n                  </div>\n                </Popover.Trigger>\n                <Popover.Portal>\n                  <Popover.Content side=\"bottom\" align=\"start\" css={menuStyles}>\n                    <SelectInput />\n                  </Popover.Content>\n                </Popover.Portal>\n              </Popover.Root>\n              <div css={verticalDividerStyles} />\n              <FlatButton\n                icon={<CloseBoldIcon />}\n                label={intl.formatMessage(messages.clearAllFiltersButtonLabel)}\n                onClick={props.onClearAllRequest}\n                tone=\"secondary\"\n              />\n            </div>\n          </div>\n        )}\n      </CollapsibleMotion>\n    </>\n  );\n}\n\nFilters.displayName = 'Filters';\nexport default Filters;\n"]} */"),
119
+ children: props.renderSearchComponent()
120
+ }), jsxRuntime.jsx(FlatButton__default["default"], {
121
+ "data-testid": "filters-button",
122
+ label: intl.formatMessage(messages.filtersButtonLabel),
123
+ icon: jsxRuntime.jsx(icons.FilterIcon, {}),
124
+ onClick: handleFiltersClick
125
+ })]
16
126
  }), jsxRuntime.jsx("div", {
17
- style: {
18
- display: 'flex',
19
- gap: designSystem.designTokens.spacing20
127
+ css: horizontalDividerStyles
128
+ }), jsxRuntime.jsx(CollapsibleMotion__default["default"], {
129
+ isClosed: !showAddFilters,
130
+ onToggle: () => setShowAddFilters(!showAddFilters),
131
+ children: _ref => {
132
+ let registerContentNode = _ref.registerContentNode,
133
+ containerStyles = _ref.containerStyles;
134
+ return jsxRuntime.jsx("div", {
135
+ style: containerStyles,
136
+ children: jsxRuntime.jsxs("div", {
137
+ ref: registerContentNode,
138
+ css: menuListStyles,
139
+ children: [jsxRuntime.jsxs(Popover__namespace.Root, {
140
+ children: [jsxRuntime.jsx(Popover__namespace.Trigger, {
141
+ asChild: true,
142
+ children: jsxRuntime.jsx("div", {
143
+ css: _ref2,
144
+ children: jsxRuntime.jsx(FlatButton__default["default"], {
145
+ "data-testid": "add-filter-button",
146
+ label: intl.formatMessage(messages.addFilterButtonLabel),
147
+ icon: jsxRuntime.jsx(icons.PlusBoldIcon, {}),
148
+ onClick: () => setShowAddFilters(true)
149
+ })
150
+ })
151
+ }), jsxRuntime.jsx(Popover__namespace.Portal, {
152
+ children: jsxRuntime.jsx(Popover__namespace.Content, {
153
+ side: "bottom",
154
+ align: "start",
155
+ css: menuStyles,
156
+ children: jsxRuntime.jsx(SelectInput__default["default"], {})
157
+ })
158
+ })]
159
+ }), jsxRuntime.jsx("div", {
160
+ css: verticalDividerStyles
161
+ }), jsxRuntime.jsx(FlatButton__default["default"], {
162
+ icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
163
+ label: intl.formatMessage(messages.clearAllFiltersButtonLabel),
164
+ onClick: props.onClearAllRequest,
165
+ tone: "secondary"
166
+ })]
167
+ })
168
+ });
20
169
  }
21
170
  })]
22
171
  });
23
172
  }
173
+ Filters.propTypes = process.env.NODE_ENV !== "production" ? {
174
+ appliedFilters: _pt__default["default"].arrayOf(_pt__default["default"].shape({
175
+ filterKey: _pt__default["default"].string.isRequired,
176
+ values: _pt__default["default"].arrayOf(_pt__default["default"].any).isRequired
177
+ })).isRequired,
178
+ filters: _pt__default["default"].arrayOf(_pt__default["default"].shape({
179
+ filterMenuConfiguration: _pt__default["default"].shape({
180
+ renderMenuBody: _pt__default["default"].func.isRequired,
181
+ renderOperatorsInput: _pt__default["default"].func,
182
+ renderApplyButton: _pt__default["default"].func,
183
+ onClearRequest: _pt__default["default"].any.isRequired,
184
+ onSortRequest: _pt__default["default"].any
185
+ }).isRequired,
186
+ groupKey: _pt__default["default"].string,
187
+ isPersistent: _pt__default["default"].bool,
188
+ isDisabled: _pt__default["default"].bool,
189
+ key: _pt__default["default"].string.isRequired,
190
+ label: _pt__default["default"].node.isRequired
191
+ })).isRequired,
192
+ filterGroups: _pt__default["default"].arrayOf(_pt__default["default"].shape({
193
+ key: _pt__default["default"].string.isRequired,
194
+ label: _pt__default["default"].node.isRequired
195
+ })),
196
+ onClearAllRequest: _pt__default["default"].func.isRequired,
197
+ onAddFilterRequest: _pt__default["default"].any,
198
+ renderSearchComponent: _pt__default["default"].func.isRequired
199
+ } : {};
200
+ Filters.displayName = 'Filters';
24
201
 
25
202
  // NOTE: This string will be replaced on build time with the package version.
26
- var version = "19.12.1";
203
+ var version = "19.14.0";
27
204
 
28
205
  exports["default"] = Filters;
29
206
  exports.version = version;
@@ -2,28 +2,149 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
+ var react = require('@emotion/react');
6
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
7
+ require('prop-types');
8
+ var Popover = require('@radix-ui/react-popover');
9
+ var FlatButton = require('@commercetools-uikit/flat-button');
10
+ var SelectInput = require('@commercetools-uikit/select-input');
11
+ var icons = require('@commercetools-uikit/icons');
12
+ var react$1 = require('react');
13
+ var Spacings = require('@commercetools-uikit/spacings');
5
14
  var designSystem = require('@commercetools-uikit/design-system');
15
+ var reactIntl = require('react-intl');
6
16
  var jsxRuntime = require('@emotion/react/jsx-runtime');
17
+ var CollapsibleMotion = require('@commercetools-uikit/collapsible-motion');
7
18
 
19
+ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
20
+
21
+ function _interopNamespace(e) {
22
+ if (e && e.__esModule) return e;
23
+ var n = Object.create(null);
24
+ if (e) {
25
+ Object.keys(e).forEach(function (k) {
26
+ if (k !== 'default') {
27
+ var d = Object.getOwnPropertyDescriptor(e, k);
28
+ Object.defineProperty(n, k, d.get ? d : {
29
+ enumerable: true,
30
+ get: function () { return e[k]; }
31
+ });
32
+ }
33
+ });
34
+ }
35
+ n["default"] = e;
36
+ return Object.freeze(n);
37
+ }
38
+
39
+ var Popover__namespace = /*#__PURE__*/_interopNamespace(Popover);
40
+ var FlatButton__default = /*#__PURE__*/_interopDefault(FlatButton);
41
+ var SelectInput__default = /*#__PURE__*/_interopDefault(SelectInput);
42
+ var Spacings__default = /*#__PURE__*/_interopDefault(Spacings);
43
+ var CollapsibleMotion__default = /*#__PURE__*/_interopDefault(CollapsibleMotion);
44
+
45
+ var messages = reactIntl.defineMessages({
46
+ addFilterButtonLabel: {
47
+ id: 'UIKit.AddFilterButton.addFilterButtonLabel',
48
+ description: 'Label for the add filter button',
49
+ defaultMessage: 'Add filter'
50
+ },
51
+ clearAllFiltersButtonLabel: {
52
+ id: 'UIKit.ClearAllFiltersButton.clearAllFiltersButtonLabel',
53
+ description: 'Label for the clear all filters button',
54
+ defaultMessage: 'Clear all'
55
+ },
56
+ filtersButtonLabel: {
57
+ id: 'UIKit.FiltersButton.filtersButtonLabel',
58
+ description: 'Label for the filters button',
59
+ defaultMessage: 'Filters'
60
+ }
61
+ });
62
+
63
+ const menuStyles = /*#__PURE__*/react.css("display:flex;flex-direction:column;align-items:flex-start;gap:", designSystem.designTokens.spacing30, ";width:", designSystem.designTokens.constraint6, ";padding:", designSystem.designTokens.spacing20, " ", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorSurface, ";border:1px solid ", designSystem.designTokens.colorSurface, ";border-radius:", designSystem.designTokens.borderRadius8, ";box-shadow:", designSystem.designTokens.shadow18, ";animation-duration:", designSystem.designTokens.transitionStandard, ";will-change:'transform, opacity';margin-top:", designSystem.designTokens.spacing10, ";position:relative;z-index:5;" + ("" ), "" );
64
+
65
+ const horizontalDividerStyles = /*#__PURE__*/react.css("width:100%;height:1px;border:1px solid ", designSystem.designTokens.colorNeutral90, ";margin-top:", designSystem.designTokens.spacing25, ";margin-bottom:", designSystem.designTokens.spacing30, ";" + ("" ), "" );
66
+ const verticalDividerStyles = /*#__PURE__*/react.css("width:1px;height:", designSystem.designTokens.spacing30, ";background-color:", designSystem.designTokens.colorNeutral90, ";margin:0 ", designSystem.designTokens.spacing20, " 0 ", designSystem.designTokens.spacing20, ";" + ("" ), "" );
67
+ const menuListStyles = /*#__PURE__*/react.css("width:100%;display:flex;align-items:center;gap:", designSystem.designTokens.spacing20, ";" + ("" ), "" );
68
+ var _ref2 = {
69
+ name: "1lv1yo7",
70
+ styles: "display:inline-flex"
71
+ } ;
8
72
  function Filters(props) {
9
- return jsxRuntime.jsxs("div", {
10
- style: {
11
- display: 'flex',
12
- gap: designSystem.designTokens.spacing20
13
- },
14
- children: [jsxRuntime.jsx("div", {
15
- children: props.label
73
+ const intl = reactIntl.useIntl();
74
+ const _useState = react$1.useState(false),
75
+ _useState2 = _slicedToArray(_useState, 2),
76
+ showAddFilters = _useState2[0],
77
+ setShowAddFilters = _useState2[1];
78
+ const handleFiltersClick = () => {
79
+ setShowAddFilters(currState => !currState);
80
+ };
81
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
82
+ children: [jsxRuntime.jsxs(Spacings__default["default"].Inline, {
83
+ scale: "m",
84
+ alignItems: "center",
85
+ children: [jsxRuntime.jsx("div", {
86
+ css: /*#__PURE__*/react.css({
87
+ maxWidth: `${designSystem.designTokens.constraint16}`
88
+ }, "" , "" ),
89
+ children: props.renderSearchComponent()
90
+ }), jsxRuntime.jsx(FlatButton__default["default"], {
91
+ "data-testid": "filters-button",
92
+ label: intl.formatMessage(messages.filtersButtonLabel),
93
+ icon: jsxRuntime.jsx(icons.FilterIcon, {}),
94
+ onClick: handleFiltersClick
95
+ })]
16
96
  }), jsxRuntime.jsx("div", {
17
- style: {
18
- display: 'flex',
19
- gap: designSystem.designTokens.spacing20
97
+ css: horizontalDividerStyles
98
+ }), jsxRuntime.jsx(CollapsibleMotion__default["default"], {
99
+ isClosed: !showAddFilters,
100
+ onToggle: () => setShowAddFilters(!showAddFilters),
101
+ children: _ref => {
102
+ let registerContentNode = _ref.registerContentNode,
103
+ containerStyles = _ref.containerStyles;
104
+ return jsxRuntime.jsx("div", {
105
+ style: containerStyles,
106
+ children: jsxRuntime.jsxs("div", {
107
+ ref: registerContentNode,
108
+ css: menuListStyles,
109
+ children: [jsxRuntime.jsxs(Popover__namespace.Root, {
110
+ children: [jsxRuntime.jsx(Popover__namespace.Trigger, {
111
+ asChild: true,
112
+ children: jsxRuntime.jsx("div", {
113
+ css: _ref2,
114
+ children: jsxRuntime.jsx(FlatButton__default["default"], {
115
+ "data-testid": "add-filter-button",
116
+ label: intl.formatMessage(messages.addFilterButtonLabel),
117
+ icon: jsxRuntime.jsx(icons.PlusBoldIcon, {}),
118
+ onClick: () => setShowAddFilters(true)
119
+ })
120
+ })
121
+ }), jsxRuntime.jsx(Popover__namespace.Portal, {
122
+ children: jsxRuntime.jsx(Popover__namespace.Content, {
123
+ side: "bottom",
124
+ align: "start",
125
+ css: menuStyles,
126
+ children: jsxRuntime.jsx(SelectInput__default["default"], {})
127
+ })
128
+ })]
129
+ }), jsxRuntime.jsx("div", {
130
+ css: verticalDividerStyles
131
+ }), jsxRuntime.jsx(FlatButton__default["default"], {
132
+ icon: jsxRuntime.jsx(icons.CloseBoldIcon, {}),
133
+ label: intl.formatMessage(messages.clearAllFiltersButtonLabel),
134
+ onClick: props.onClearAllRequest,
135
+ tone: "secondary"
136
+ })]
137
+ })
138
+ });
20
139
  }
21
140
  })]
22
141
  });
23
142
  }
143
+ Filters.propTypes = {};
144
+ Filters.displayName = 'Filters';
24
145
 
25
146
  // NOTE: This string will be replaced on build time with the package version.
26
- var version = "19.12.1";
147
+ var version = "19.14.0";
27
148
 
28
149
  exports["default"] = Filters;
29
150
  exports.version = version;
@@ -1,24 +1,174 @@
1
+ import { css } from '@emotion/react';
2
+ import _slicedToArray from '@babel/runtime-corejs3/helpers/esm/slicedToArray';
3
+ import _pt from 'prop-types';
4
+ import * as Popover from '@radix-ui/react-popover';
5
+ import FlatButton from '@commercetools-uikit/flat-button';
6
+ import SelectInput from '@commercetools-uikit/select-input';
7
+ import { FilterIcon, PlusBoldIcon, CloseBoldIcon } from '@commercetools-uikit/icons';
8
+ import { useState } from 'react';
9
+ import Spacings from '@commercetools-uikit/spacings';
1
10
  import { designTokens } from '@commercetools-uikit/design-system';
2
- import { jsxs, jsx } from '@emotion/react/jsx-runtime';
11
+ import { defineMessages, useIntl } from 'react-intl';
12
+ import { jsxs, Fragment, jsx } from '@emotion/react/jsx-runtime';
13
+ import CollapsibleMotion from '@commercetools-uikit/collapsible-motion';
3
14
 
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',
24
+ defaultMessage: 'Clear all'
25
+ },
26
+ filtersButtonLabel: {
27
+ id: 'UIKit.FiltersButton.filtersButtonLabel',
28
+ description: 'Label for the filters button',
29
+ defaultMessage: 'Filters'
30
+ }
31
+ });
32
+
33
+ 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%"
38
+ } : {
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= */",
42
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$1
43
+ };
44
+ process.env.NODE_ENV !== "production" ? {
45
+ filterKey: _pt.string.isRequired,
46
+ label: _pt.node.isRequired,
47
+ renderMenuBody: _pt.func.isRequired,
48
+ renderOperatorsInput: _pt.func,
49
+ isPersistent: _pt.bool,
50
+ isDisabled: _pt.bool,
51
+ onRemoveRequest: _pt.func,
52
+ renderApplyButton: _pt.func,
53
+ onClearRequest: _pt.func,
54
+ onSortRequest: _pt.func,
55
+ defaultOpen: _pt.bool
56
+ } : {};
57
+
58
+ 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" ? {
63
+ name: "1lv1yo7",
64
+ styles: "display:inline-flex"
65
+ } : {
66
+ name: "irmyae-Filters",
67
+ 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"]} */",
69
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
70
+ };
4
71
  function Filters(props) {
5
- return jsxs("div", {
6
- style: {
7
- display: 'flex',
8
- gap: designTokens.spacing20
9
- },
10
- children: [jsx("div", {
11
- children: props.label
72
+ const intl = useIntl();
73
+ const _useState = useState(false),
74
+ _useState2 = _slicedToArray(_useState, 2),
75
+ showAddFilters = _useState2[0],
76
+ setShowAddFilters = _useState2[1];
77
+ const handleFiltersClick = () => {
78
+ setShowAddFilters(currState => !currState);
79
+ };
80
+ return jsxs(Fragment, {
81
+ children: [jsxs(Spacings.Inline, {
82
+ scale: "m",
83
+ alignItems: "center",
84
+ children: [jsx("div", {
85
+ css: /*#__PURE__*/css({
86
+ 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
94
+ })]
12
95
  }), jsx("div", {
13
- style: {
14
- display: 'flex',
15
- gap: designTokens.spacing20
96
+ css: horizontalDividerStyles
97
+ }), jsx(CollapsibleMotion, {
98
+ isClosed: !showAddFilters,
99
+ onToggle: () => setShowAddFilters(!showAddFilters),
100
+ children: _ref => {
101
+ let registerContentNode = _ref.registerContentNode,
102
+ containerStyles = _ref.containerStyles;
103
+ return jsx("div", {
104
+ style: containerStyles,
105
+ children: jsxs("div", {
106
+ ref: registerContentNode,
107
+ css: menuListStyles,
108
+ children: [jsxs(Popover.Root, {
109
+ children: [jsx(Popover.Trigger, {
110
+ asChild: true,
111
+ children: jsx("div", {
112
+ css: _ref2,
113
+ children: jsx(FlatButton, {
114
+ "data-testid": "add-filter-button",
115
+ label: intl.formatMessage(messages.addFilterButtonLabel),
116
+ icon: jsx(PlusBoldIcon, {}),
117
+ onClick: () => setShowAddFilters(true)
118
+ })
119
+ })
120
+ }), jsx(Popover.Portal, {
121
+ children: jsx(Popover.Content, {
122
+ side: "bottom",
123
+ align: "start",
124
+ css: menuStyles,
125
+ children: jsx(SelectInput, {})
126
+ })
127
+ })]
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"
135
+ })]
136
+ })
137
+ });
16
138
  }
17
139
  })]
18
140
  });
19
141
  }
142
+ Filters.propTypes = process.env.NODE_ENV !== "production" ? {
143
+ appliedFilters: _pt.arrayOf(_pt.shape({
144
+ filterKey: _pt.string.isRequired,
145
+ values: _pt.arrayOf(_pt.any).isRequired
146
+ })).isRequired,
147
+ filters: _pt.arrayOf(_pt.shape({
148
+ filterMenuConfiguration: _pt.shape({
149
+ renderMenuBody: _pt.func.isRequired,
150
+ renderOperatorsInput: _pt.func,
151
+ renderApplyButton: _pt.func,
152
+ onClearRequest: _pt.any.isRequired,
153
+ onSortRequest: _pt.any
154
+ }).isRequired,
155
+ groupKey: _pt.string,
156
+ isPersistent: _pt.bool,
157
+ isDisabled: _pt.bool,
158
+ key: _pt.string.isRequired,
159
+ label: _pt.node.isRequired
160
+ })).isRequired,
161
+ filterGroups: _pt.arrayOf(_pt.shape({
162
+ key: _pt.string.isRequired,
163
+ label: _pt.node.isRequired
164
+ })),
165
+ onClearAllRequest: _pt.func.isRequired,
166
+ onAddFilterRequest: _pt.any,
167
+ renderSearchComponent: _pt.func.isRequired
168
+ } : {};
169
+ Filters.displayName = 'Filters';
20
170
 
21
171
  // NOTE: This string will be replaced on build time with the package version.
22
- var version = "19.12.1";
172
+ var version = "19.14.0";
23
173
 
24
174
  export { Filters as default, version };
@@ -0,0 +1,58 @@
1
+ import { type ReactNode, type MouseEvent, type KeyboardEvent } from 'react';
2
+ export type TAppliedFilterValue = {
3
+ value: string;
4
+ label: ReactNode;
5
+ };
6
+ export type TFilterMenuProps = {
7
+ /**
8
+ * unique identifier for the filter
9
+ */
10
+ filterKey: string;
11
+ /**
12
+ * formatted message to display the filter's name
13
+ */
14
+ label: ReactNode;
15
+ /**
16
+ * the input in which the user selects values for the filter
17
+ */
18
+ renderMenuBody: () => ReactNode;
19
+ /**
20
+ * the input in which the user can select which operator should be used for this filter
21
+ */
22
+ renderOperatorsInput?: () => ReactNode;
23
+ /**
24
+ * the values applied to this filter by the user
25
+ */
26
+ appliedFilterValues: TAppliedFilterValue[] | undefined | null;
27
+ /**
28
+ * indicates whether FilterMenu can be removed from the filtersList
29
+ */
30
+ isPersistent?: boolean;
31
+ /**
32
+ * whether or not the filter is disabled
33
+ */
34
+ isDisabled?: boolean;
35
+ /**
36
+ * controls whether `x` in Trigger Button is displayed - required if `isPersistent` is `false`
37
+ */
38
+ onRemoveRequest?: (event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>) => void;
39
+ /**
40
+ * optional button that allows the user to apply selected filter values
41
+ */
42
+ renderApplyButton?: () => ReactNode;
43
+ /**
44
+ * controls whether `clear all` button in Menu Body Footer is displayed
45
+ */
46
+ onClearRequest?: (event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>) => void;
47
+ /**
48
+ * controls whether `sort` button in Menu Body Header is displayed
49
+ */
50
+ onSortRequest?: (event: MouseEvent<HTMLButtonElement> | KeyboardEvent<HTMLButtonElement>) => void;
51
+ /**
52
+ * controls whether menu is open on initial render
53
+ */
54
+ defaultOpen?: boolean;
55
+ };
56
+ export declare const menuStyles: import("@emotion/react").SerializedStyles;
57
+ declare function FilterMenu(props: TFilterMenuProps): import("@emotion/react/jsx-runtime").JSX.Element;
58
+ export default FilterMenu;
@@ -1,8 +1,102 @@
1
+ import { ReactElement, ReactNode } from 'react';
2
+ import { type TAppliedFilterValue } from "./filter-menu/filter-menu.js";
3
+ import { type TPrimaryButtonProps } from '@commercetools-uikit/primary-button';
4
+ import { type TSelectInputProps } from '@commercetools-uikit/select-input';
5
+ type TAppliedFilter = {
6
+ /**
7
+ * unique identifier for the filter
8
+ */
9
+ filterKey: string;
10
+ /**
11
+ * the values applied to this filter by the user
12
+ */
13
+ values: TAppliedFilterValue[];
14
+ };
15
+ type TFilterConfiguration = {
16
+ /**
17
+ * configuration object for the filter menu.
18
+ */
19
+ filterMenuConfiguration: {
20
+ /**
21
+ * the input in which the user selects values for the filter
22
+ */
23
+ renderMenuBody: () => ReactNode;
24
+ /**
25
+ * the input in which the user can select which operator should be used for this filter
26
+ */
27
+ renderOperatorsInput?: () => ReactElement<TSelectInputProps>;
28
+ /**
29
+ * optional button that allows the user to apply selected filter values
30
+ */
31
+ renderApplyButton?: () => ReactElement<TPrimaryButtonProps>;
32
+ /**
33
+ * controls whether `clear` button in Menu Body Footer is displayed
34
+ */
35
+ onClearRequest: Function;
36
+ /**
37
+ * controls whether `sort` button in Menu Body Header is displayed
38
+ */
39
+ onSortRequest?: Function;
40
+ };
41
+ /**
42
+ * optional key to group filters together.
43
+ */
44
+ groupKey?: string;
45
+ /**
46
+ * indicates whether filter menu can be removed from filters
47
+ */
48
+ isPersistent?: boolean;
49
+ /**
50
+ * whether or not the filter is disabled
51
+ */
52
+ isDisabled?: boolean;
53
+ /**
54
+ * unique identifier for the filter
55
+ */
56
+ key: string;
57
+ /**
58
+ * formatted message to display the filter name
59
+ */
60
+ label: ReactNode;
61
+ };
62
+ type TFilterGroupConfiguration = {
63
+ /**
64
+ * unique identifier for the filter group
65
+ */
66
+ key: string;
67
+ /**
68
+ * formatted message to display the filter group name
69
+ */
70
+ label: ReactNode;
71
+ };
1
72
  export type TFiltersProps = {
2
73
  /**
3
- * This is a stub prop
74
+ * array of applied filters, each containing a unique key and an array of values.
75
+ */
76
+ appliedFilters: TAppliedFilter[];
77
+ /**
78
+ * configuration for the available filters.
79
+ */
80
+ filters: TFilterConfiguration[];
81
+ /**
82
+ * optional configuration for filter groups.
83
+ */
84
+ filterGroups?: TFilterGroupConfiguration[];
85
+ /**
86
+ * controls the `clear all` (added filters) button from the menu list
87
+ */
88
+ onClearAllRequest: () => void;
89
+ /**
90
+ * optional callback trigger to add a new filter.
91
+ */
92
+ onAddFilterRequest?: Function;
93
+ /**
94
+ * function to render a search input, selectable from applicable UI Kit components.
4
95
  */
5
- label?: string;
96
+ renderSearchComponent: () => ReactNode;
6
97
  };
7
98
  declare function Filters(props: TFiltersProps): import("@emotion/react/jsx-runtime").JSX.Element;
99
+ declare namespace Filters {
100
+ var displayName: string;
101
+ }
8
102
  export default Filters;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@commercetools-uikit/filters",
3
3
  "description": "The `Filters` component displays filter controls.",
4
- "version": "19.12.1",
4
+ "version": "19.14.0",
5
5
  "bugs": "https://github.com/commercetools/ui-kit/issues",
6
6
  "repository": {
7
7
  "type": "git",
@@ -21,11 +21,19 @@
21
21
  "dependencies": {
22
22
  "@babel/runtime": "^7.20.13",
23
23
  "@babel/runtime-corejs3": "^7.20.13",
24
+ "@commercetools-uikit/collapsible-motion": "workspace:^",
24
25
  "@commercetools-uikit/design-system": "workspace:^",
25
26
  "@commercetools-uikit/dropdown-menu": "workspace:^",
27
+ "@commercetools-uikit/flat-button": "workspace:^",
28
+ "@commercetools-uikit/icon-button": "workspace:^",
29
+ "@commercetools-uikit/icons": "workspace:^",
30
+ "@commercetools-uikit/secondary-icon-button": "workspace:^",
31
+ "@commercetools-uikit/select-input": "workspace:^",
32
+ "@commercetools-uikit/spacings": "workspace:^",
26
33
  "@commercetools-uikit/utils": "workspace:^",
27
34
  "@emotion/react": "^11.10.5",
28
35
  "@emotion/styled": "^11.10.5",
36
+ "@radix-ui/react-popover": "^1.1.2",
29
37
  "prop-types": "15.8.1",
30
38
  "react-intl": "^6.3.2"
31
39
  },