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