@commercetools-uikit/filters 19.13.0 → 19.15.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.
- package/dist/commercetools-uikit-filters.cjs.dev.js +191 -9
- package/dist/commercetools-uikit-filters.cjs.prod.js +135 -9
- package/dist/commercetools-uikit-filters.esm.js +165 -10
- package/dist/declarations/src/filter-menu/filter-menu.d.ts +58 -0
- package/dist/declarations/src/filters.d.ts +96 -2
- package/package.json +6 -2
|
@@ -2,23 +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
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
+
})]
|
|
126
|
+
}), jsxRuntime.jsx("div", {
|
|
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
|
+
});
|
|
169
|
+
}
|
|
170
|
+
})]
|
|
17
171
|
});
|
|
18
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';
|
|
19
201
|
|
|
20
202
|
// NOTE: This string will be replaced on build time with the package version.
|
|
21
|
-
var version = "19.
|
|
203
|
+
var version = "19.15.0";
|
|
22
204
|
|
|
23
205
|
exports["default"] = Filters;
|
|
24
206
|
exports.version = version;
|
|
@@ -2,23 +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
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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
|
+
})]
|
|
96
|
+
}), jsxRuntime.jsx("div", {
|
|
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
|
+
});
|
|
139
|
+
}
|
|
140
|
+
})]
|
|
17
141
|
});
|
|
18
142
|
}
|
|
143
|
+
Filters.propTypes = {};
|
|
144
|
+
Filters.displayName = 'Filters';
|
|
19
145
|
|
|
20
146
|
// NOTE: This string will be replaced on build time with the package version.
|
|
21
|
-
var version = "19.
|
|
147
|
+
var version = "19.15.0";
|
|
22
148
|
|
|
23
149
|
exports["default"] = Filters;
|
|
24
150
|
exports.version = version;
|
|
@@ -1,19 +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 {
|
|
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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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
|
+
})]
|
|
95
|
+
}), jsx("div", {
|
|
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
|
+
});
|
|
138
|
+
}
|
|
139
|
+
})]
|
|
13
140
|
});
|
|
14
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';
|
|
15
170
|
|
|
16
171
|
// NOTE: This string will be replaced on build time with the package version.
|
|
17
|
-
var version = "19.
|
|
172
|
+
var version = "19.15.0";
|
|
18
173
|
|
|
19
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
|
-
*
|
|
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
|
-
|
|
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.
|
|
4
|
+
"version": "19.15.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,11 +21,15 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/
|
|
24
|
+
"@commercetools-uikit/collapsible-motion": "workspace:^",
|
|
25
25
|
"@commercetools-uikit/design-system": "workspace:^",
|
|
26
26
|
"@commercetools-uikit/dropdown-menu": "workspace:^",
|
|
27
|
+
"@commercetools-uikit/flat-button": "workspace:^",
|
|
28
|
+
"@commercetools-uikit/icon-button": "workspace:^",
|
|
27
29
|
"@commercetools-uikit/icons": "workspace:^",
|
|
28
30
|
"@commercetools-uikit/secondary-icon-button": "workspace:^",
|
|
31
|
+
"@commercetools-uikit/select-input": "workspace:^",
|
|
32
|
+
"@commercetools-uikit/spacings": "workspace:^",
|
|
29
33
|
"@commercetools-uikit/utils": "workspace:^",
|
|
30
34
|
"@emotion/react": "^11.10.5",
|
|
31
35
|
"@emotion/styled": "^11.10.5",
|