@orfium/ictinus 4.64.0 → 4.66.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.
Files changed (48) hide show
  1. package/dist/components/Filter/Filter.js +117 -46
  2. package/dist/components/Filter/Filter.style.d.ts +1 -1
  3. package/dist/components/Filter/Filter.style.js +5 -2
  4. package/dist/components/Filter/components/FilterBase/FilterBase.d.ts +1 -1
  5. package/dist/components/Filter/components/FilterBase/FilterBase.js +8 -4
  6. package/dist/components/Filter/components/MultiFilter/MultiFilter.d.ts +11 -0
  7. package/dist/components/Filter/components/MultiFilter/MultiFilter.js +57 -0
  8. package/dist/components/Filter/components/MultiFilter/MultiFilter.style.d.ts +3 -0
  9. package/dist/components/Filter/components/MultiFilter/MultiFilter.style.js +42 -0
  10. package/dist/components/Filter/components/MultiFilter/index.d.ts +1 -0
  11. package/dist/components/Filter/components/MultiFilter/index.js +10 -0
  12. package/dist/components/Filter/components/SingleFilter/SingleFilter.d.ts +12 -0
  13. package/dist/components/Filter/components/SingleFilter/SingleFilter.js +53 -0
  14. package/dist/components/Filter/components/{SearchInput → SingleFilter/components/SearchInput}/SearchInput.d.ts +1 -1
  15. package/dist/components/Filter/components/{SearchInput → SingleFilter/components/SearchInput}/SearchInput.js +6 -6
  16. package/dist/components/Filter/components/SingleFilter/components/SearchInput/SearchInput.style.js +34 -0
  17. package/dist/components/Filter/components/SingleFilter/components/SearchInput/index.d.ts +1 -0
  18. package/dist/components/Filter/components/SingleFilter/components/SearchInput/index.js +10 -0
  19. package/dist/components/Filter/components/SingleFilter/index.d.ts +1 -0
  20. package/dist/components/Filter/components/SingleFilter/index.js +10 -0
  21. package/dist/components/Filter/hooks/useMultiFilterUtils.d.ts +18 -0
  22. package/dist/components/Filter/hooks/useMultiFilterUtils.js +124 -0
  23. package/dist/components/Filter/types.d.ts +13 -1
  24. package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.d.ts → MultiSelectBase/MultiSelectBase.d.ts} +6 -2
  25. package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.js → MultiSelectBase/MultiSelectBase.js} +48 -71
  26. package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.style.d.ts → MultiSelectBase/MultiSelectBase.style.d.ts} +5 -1
  27. package/dist/components/MultiSelectBase/MultiSelectBase.style.js +156 -0
  28. package/dist/components/MultiSelectBase/hooks.d.ts +17 -0
  29. package/dist/components/MultiSelectBase/hooks.js +91 -0
  30. package/dist/components/MultiSelectBase/index.d.ts +1 -0
  31. package/dist/components/MultiSelectBase/index.js +10 -0
  32. package/dist/components/Select/Select.d.ts +15 -0
  33. package/dist/components/Select/Select.js +57 -22
  34. package/dist/components/Select/hooks/useMultiselectUtils.js +19 -3
  35. package/dist/components/TextInputBase/TextInputBase.d.ts +2 -0
  36. package/dist/components/TextInputBase/TextInputBase.js +4 -1
  37. package/dist/components/TextInputBase/TextInputBase.style.d.ts +1 -1
  38. package/dist/components/TextInputBase/TextInputBase.style.js +7 -6
  39. package/dist/components/utils/PositionInScreen/PositionInScreen.d.ts +6 -0
  40. package/dist/components/utils/PositionInScreen/PositionInScreen.js +3 -2
  41. package/dist/components/utils/PositionInScreen/PositionInScreen.style.d.ts +9 -2
  42. package/dist/components/utils/PositionInScreen/PositionInScreen.style.js +23 -4
  43. package/package.json +1 -1
  44. package/dist/components/Filter/components/SearchInput/SearchInput.style.js +0 -34
  45. package/dist/components/Select/components/MultiselectTextField/MultiselectTextField.style.js +0 -149
  46. package/dist/components/Select/components/MultiselectTextField/index.d.ts +0 -1
  47. package/dist/components/Select/components/MultiselectTextField/index.js +0 -10
  48. /package/dist/components/Filter/components/{SearchInput → SingleFilter/components/SearchInput}/SearchInput.style.d.ts +0 -0
@@ -13,16 +13,18 @@ var _ClickAwayListener = _interopRequireDefault(require("../utils/ClickAwayListe
13
13
 
14
14
  var _FilterBase = _interopRequireDefault(require("./components/FilterBase"));
15
15
 
16
- var _Options = _interopRequireDefault(require("./components/Options/Options"));
16
+ var _MultiFilter = _interopRequireDefault(require("./components/MultiFilter/MultiFilter"));
17
17
 
18
- var _SearchInput = _interopRequireDefault(require("./components/SearchInput/SearchInput"));
18
+ var _SingleFilter = _interopRequireDefault(require("./components/SingleFilter/SingleFilter"));
19
19
 
20
- var _Filter = require("./Filter.style");
20
+ var _useMultiFilterUtils2 = _interopRequireDefault(require("./hooks/useMultiFilterUtils"));
21
21
 
22
22
  var _utils = require("./utils");
23
23
 
24
24
  var _handleSearch = _interopRequireDefault(require("../utils/handleSearch"));
25
25
 
26
+ var _PositionInScreen = _interopRequireDefault(require("../utils/PositionInScreen/PositionInScreen"));
27
+
26
28
  var _react2 = require("@emotion/react");
27
29
 
28
30
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
@@ -32,8 +34,6 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
32
34
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
35
 
34
36
  var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
35
- var _selectedItem$label;
36
-
37
37
  var items = props.items,
38
38
  onSelect = props.onSelect,
39
39
  selectedItem = props.selectedItem,
@@ -57,8 +57,16 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
57
57
  isLoading = _props$isLoading === void 0 ? false : _props$isLoading,
58
58
  _props$isVirtualized = props.isVirtualized,
59
59
  isVirtualized = _props$isVirtualized === void 0 ? false : _props$isVirtualized,
60
+ _props$multi = props.multi,
61
+ multi = _props$multi === void 0 ? false : _props$multi,
62
+ _props$selectedItems = props.selectedItems,
63
+ selectedItems = _props$selectedItems === void 0 ? [] : _props$selectedItems,
60
64
  _props$onClear = props.onClear,
61
- onClear = _props$onClear === void 0 ? function () {} : _props$onClear;
65
+ onClear = _props$onClear === void 0 ? function () {} : _props$onClear,
66
+ _props$onFilterDelete = props.onFilterDelete,
67
+ onFilterDelete = _props$onFilterDelete === void 0 ? function () {} : _props$onFilterDelete,
68
+ _props$hasSelectAllOp = props.hasSelectAllOption,
69
+ hasSelectAllOption = _props$hasSelectAllOp === void 0 ? false : _props$hasSelectAllOp;
62
70
  (0, _helpers.errorHandler)(_utils.errors, props);
63
71
 
64
72
  var _React$useState = _react["default"].useState(false),
@@ -69,19 +77,35 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
69
77
  searchValue = _React$useState2[0],
70
78
  setSearchValue = _React$useState2[1];
71
79
 
80
+ var _React$useState3 = _react["default"].useState(defaultValue.label),
81
+ filterLabel = _React$useState3[0],
82
+ setFilterLabel = _React$useState3[1];
83
+
72
84
  var hasSelectedValue = Boolean(selectedItem == null ? void 0 : selectedItem.value) && (selectedItem == null ? void 0 : selectedItem.value) !== defaultValue.value;
73
85
  var iconName = isOpen ? 'triangleUp' : 'triangleDown';
74
86
 
75
- var handleSelect = function handleSelect(option) {
76
- setIsOpen(false);
77
- onSelect(option);
78
- };
87
+ var _useMultiFilterUtils = (0, _useMultiFilterUtils2["default"])({
88
+ multi: multi,
89
+ selectedItems: selectedItems,
90
+ items: items,
91
+ defaultValue: defaultValue,
92
+ setFilterLabel: setFilterLabel,
93
+ setIsOpen: setIsOpen,
94
+ onClear: onClear,
95
+ setSearchValue: setSearchValue,
96
+ onFilterDelete: onFilterDelete
97
+ }),
98
+ availableMultiFilters = _useMultiFilterUtils.availableMultiFilters,
99
+ multiFilters = _useMultiFilterUtils.multiFilters,
100
+ handleOptionDelete = _useMultiFilterUtils.handleOptionDelete,
101
+ handleClearAllOptions = _useMultiFilterUtils.handleClearAllOptions,
102
+ handleMultiSelectOptionClick = _useMultiFilterUtils.handleMultiSelectOptionClick;
79
103
 
80
104
  var handleChange = function handleChange(event) {
81
105
  var isAsync = typeof onAsyncSearch === 'function';
82
106
  (0, _handleSearch["default"])({
83
107
  event: event,
84
- isSearchable: isSearchable,
108
+ isSearchable: isSearchable || multi,
85
109
  isAsync: isAsync,
86
110
  setSearchValue: setSearchValue,
87
111
  onChange: debouncedOnChange,
@@ -90,14 +114,16 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
90
114
  };
91
115
 
92
116
  var filteredOptions = (0, _react.useMemo)(function () {
117
+ var optionsToBeFiltered = multi ? availableMultiFilters : items;
118
+
93
119
  if (onAsyncSearch) {
94
- return items;
120
+ return optionsToBeFiltered;
95
121
  }
96
122
 
97
- return items.filter(function (item) {
123
+ return optionsToBeFiltered.filter(function (item) {
98
124
  return !searchValue || item.label.toLowerCase().includes(searchValue.toLowerCase());
99
125
  });
100
- }, [searchValue, items, onAsyncSearch]);
126
+ }, [multi, availableMultiFilters, items, onAsyncSearch, searchValue]);
101
127
  var shouldDisplayDefaultOption = searchValue === '' && !!items.length;
102
128
 
103
129
  var handleOpen = function handleOpen() {
@@ -109,42 +135,87 @@ var Filter = /*#__PURE__*/_react["default"].forwardRef(function (props, ref) {
109
135
  onAsyncSearch == null ? void 0 : onAsyncSearch(value);
110
136
  }, 400), []);
111
137
 
138
+ var handleSelect = function handleSelect(option) {
139
+ if (multi) {
140
+ handleMultiSelectOptionClick(option);
141
+ } else {
142
+ setIsOpen(false);
143
+ setFilterLabel(option.label);
144
+ }
145
+
146
+ if (isSearchable || multi) {
147
+ setSearchValue('');
148
+ }
149
+
150
+ onSelect(option);
151
+ };
152
+
153
+ var handleClear = function handleClear() {
154
+ if (filterType === 'added' && !multi) {
155
+ setFilterLabel(defaultValue.label);
156
+ }
157
+
158
+ if (onClear) {
159
+ onClear();
160
+ }
161
+ };
162
+
163
+ var getFilter = function getFilter() {
164
+ return multi ? (0, _react2.jsx)(_MultiFilter["default"], {
165
+ selectedItems: multiFilters,
166
+ items: filteredOptions,
167
+ onInput: handleChange,
168
+ onOptionDelete: handleOptionDelete,
169
+ onClearAllOptions: handleClearAllOptions,
170
+ onOptionClick: handleSelect,
171
+ searchValue: searchValue,
172
+ isLoading: isLoading,
173
+ hasSelectAllOption: hasSelectAllOption
174
+ }) : (0, _react2.jsx)(_SingleFilter["default"], {
175
+ isSearchable: isSearchable,
176
+ dataTestId: dataTestId,
177
+ searchValue: searchValue,
178
+ handleChange: handleChange,
179
+ isLoading: isLoading,
180
+ filteredOptions: filteredOptions,
181
+ isVirtualized: isVirtualized,
182
+ defaultValue: defaultValue,
183
+ selectedItem: selectedItem,
184
+ handleSelect: handleSelect,
185
+ shouldDisplayDefaultOption: shouldDisplayDefaultOption
186
+ });
187
+ };
188
+
112
189
  return (0, _react2.jsx)(_ClickAwayListener["default"], {
113
190
  onClick: function onClick() {
114
191
  return setIsOpen(false);
115
192
  }
116
- }, (0, _react2.jsx)(_FilterBase["default"], {
117
- ref: ref,
118
- dataTestId: dataTestId,
119
- handleOpen: handleOpen,
120
- disabled: disabled,
121
- onClear: onClear,
122
- selectedItemLabel: (_selectedItem$label = selectedItem == null ? void 0 : selectedItem.label) != null ? _selectedItem$label : defaultValue.label,
123
- open: isOpen,
124
- hasSelectedValue: hasSelectedValue,
125
- label: label,
126
- iconName: iconName,
127
- filterType: filterType,
128
- buttonType: buttonType,
129
- styleType: styleType
130
- }, isOpen && (0, _react2.jsx)("div", {
131
- css: (0, _Filter.menuStyle)(),
132
- "data-testid": (0, _helpers.generateTestDataId)('filter-menu', dataTestId)
133
- }, isSearchable && (0, _react2.jsx)(_SearchInput["default"], {
134
- value: searchValue,
135
- onChange: handleChange,
136
- dataTestId: dataTestId,
137
- isLoading: isLoading
138
- }), (0, _react2.jsx)(_Options["default"], {
139
- dataTestId: dataTestId,
140
- items: filteredOptions,
141
- isVirtualized: isVirtualized,
142
- defaultValue: defaultValue,
143
- isSearchable: isSearchable,
144
- selectedItem: selectedItem,
145
- onSelect: handleSelect,
146
- shouldDisplayDefaultOption: shouldDisplayDefaultOption
147
- }))));
193
+ }, (0, _react2.jsx)(_PositionInScreen["default"], {
194
+ visible: isOpen,
195
+ hasWrapperWidth: true,
196
+ offsetY: 8,
197
+ sx: {
198
+ container: {
199
+ width: 'max-content'
200
+ }
201
+ },
202
+ parent: (0, _react2.jsx)(_FilterBase["default"], {
203
+ ref: ref,
204
+ dataTestId: dataTestId,
205
+ handleOpen: handleOpen,
206
+ disabled: disabled,
207
+ onClear: handleClear,
208
+ selectedItemLabel: filterLabel,
209
+ open: isOpen,
210
+ hasSelectedValue: hasSelectedValue,
211
+ label: label,
212
+ iconName: iconName,
213
+ filterType: filterType,
214
+ buttonType: buttonType,
215
+ styleType: styleType,
216
+ multi: multi
217
+ })
218
+ }, isOpen && getFilter()));
148
219
  });
149
220
 
150
221
  Filter.displayName = 'Filter';
@@ -11,7 +11,7 @@ export declare const buttonSpanStyle: () => () => {
11
11
  gap: string;
12
12
  height: string;
13
13
  };
14
- export declare const buttonWrapperStyle: ({ disabled, open, hasSelectedValue, calculatedColor, styleType, }: ButtonStyleProps) => (theme: Theme) => {
14
+ export declare const buttonWrapperStyle: ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) => (theme: Theme) => {
15
15
  background: string;
16
16
  border: string;
17
17
  display: string;
@@ -11,6 +11,8 @@ var _states = require("../../theme/states");
11
11
 
12
12
  var _utils2 = require("./utils");
13
13
 
14
+ var _config = require("../TextInputBase/config");
15
+
14
16
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
15
17
 
16
18
  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)."; }
@@ -271,7 +273,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
271
273
  } : {
272
274
  name: "aqyt6f-valueSpanStyle",
273
275
  styles: "text-overflow:ellipsis;overflow:hidden;white-space:nowrap;display:inline-block;label:valueSpanStyle;",
274
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAqOuC","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle = ({\n  disabled,\n  open,\n  hasSelectedValue,\n  calculatedColor,\n  styleType,\n}: ButtonStyleProps) => (theme: Theme) => {\n  const activeAndClosed = !disabled && !open;\n  const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n  return {\n    background: 'none',\n    border: 'none',\n    display: 'flex',\n    padding: '0',\n    alignItems: 'center',\n    height: '100%',\n    minWidth: rem(110),\n\n    // If is active and not disabled and not visited global states applied\n    // else it's using the global states function with calculated color\n    ':hover > div': {\n      backgroundColor: activeAndClosed\n        ? hasSelectedValue\n          ? getHover({ theme, color: calculatedColor.color, shade: HAS_SELECTED_VALUE_COLOR_SHADE })\n              .backgroundColor\n          : getHover({ theme }).backgroundColor\n        : undefined,\n    },\n\n    // If is active and not disabled and not visited global states applied\n    // else it's using the global states function with calculated color\n    ':active > div': {\n      backgroundColor: activeAndClosed\n        ? hasSelectedValue\n          ? getPressed({\n              theme,\n              color: calculatedColor.color,\n              shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n            }).backgroundColor\n          : getPressed({ theme }).backgroundColor\n        : undefined,\n    },\n\n    // on focus change the two divs of added\n    ':focus-visible > div': {\n      border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n    },\n    // target the divider on focus\n    ':focus-visible > span': {\n      borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n    },\n  };\n};\n\nexport const buttonBaseStyle = ({\n  calculatedColor,\n  disabled,\n  open,\n  styleType,\n  hasSelectedValue,\n  filterType,\n}: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    fontSize: theme.typography.fontSizes['13'],\n    cursor: disabled ? 'not-allowed' : 'pointer',\n    height: '100%',\n    opacity: disabled ? 0.5 : 1,\n    transition: 'all 150ms linear',\n    color: getTextColor({\n      theme,\n      open,\n      calculatedColor,\n      hasSelectedValue,\n    }),\n    backgroundColor: getBackgroundColor({\n      theme,\n      open,\n      styleType,\n      hasSelectedValue,\n      calculatedColor,\n    }),\n    border: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    display: 'flex',\n    justifyContent: 'center',\n    width: '100%',\n    '&:hover': {\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n        state: 'hover',\n      })}`,\n    },\n  };\n};\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => css`\n  position: absolute;\n  top: ${rem(48)};\n  min-width: ${rem(280)};\n  left: 0;\n  height: auto;\n  border-radius: ${theme.spacing.xsm};\n  background-color: ${theme.palette.white};\n  box-shadow: ${theme.elevation['02']};\n  z-index: 500;\n  overflow: hidden;\n  min-width: 100%;\n  max-width: ${rem(620)};\n`;\n"]} */",
276
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAuOuC","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    position: absolute;\n    left: 0;\n    height: auto;\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    z-index: 500;\n    overflow: hidden;\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */",
275
277
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
276
278
  };
277
279
 
@@ -283,11 +285,12 @@ exports.valueSpanStyle = valueSpanStyle;
283
285
 
284
286
  var menuStyle = function menuStyle() {
285
287
  return function (theme) {
288
+ var borderConfig = _config.textInputConfig.types[theme.colorScheme].outlined.border;
286
289
  return (
287
290
  /*#__PURE__*/
288
291
 
289
292
  /*#__PURE__*/
290
- (0, _react.css)("position:absolute;top:", (0, _utils.rem)(48), ";min-width:", (0, _utils.rem)(280), ";left:0;height:auto;border-radius:", theme.spacing.xsm, ";background-color:", theme.palette.white, ";box-shadow:", theme.elevation['02'], ";z-index:500;overflow:hidden;min-width:100%;max-width:", (0, _utils.rem)(620), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AA4OoD","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle = ({\n  disabled,\n  open,\n  hasSelectedValue,\n  calculatedColor,\n  styleType,\n}: ButtonStyleProps) => (theme: Theme) => {\n  const activeAndClosed = !disabled && !open;\n  const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n  return {\n    background: 'none',\n    border: 'none',\n    display: 'flex',\n    padding: '0',\n    alignItems: 'center',\n    height: '100%',\n    minWidth: rem(110),\n\n    // If is active and not disabled and not visited global states applied\n    // else it's using the global states function with calculated color\n    ':hover > div': {\n      backgroundColor: activeAndClosed\n        ? hasSelectedValue\n          ? getHover({ theme, color: calculatedColor.color, shade: HAS_SELECTED_VALUE_COLOR_SHADE })\n              .backgroundColor\n          : getHover({ theme }).backgroundColor\n        : undefined,\n    },\n\n    // If is active and not disabled and not visited global states applied\n    // else it's using the global states function with calculated color\n    ':active > div': {\n      backgroundColor: activeAndClosed\n        ? hasSelectedValue\n          ? getPressed({\n              theme,\n              color: calculatedColor.color,\n              shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n            }).backgroundColor\n          : getPressed({ theme }).backgroundColor\n        : undefined,\n    },\n\n    // on focus change the two divs of added\n    ':focus-visible > div': {\n      border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n    },\n    // target the divider on focus\n    ':focus-visible > span': {\n      borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n    },\n  };\n};\n\nexport const buttonBaseStyle = ({\n  calculatedColor,\n  disabled,\n  open,\n  styleType,\n  hasSelectedValue,\n  filterType,\n}: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    fontSize: theme.typography.fontSizes['13'],\n    cursor: disabled ? 'not-allowed' : 'pointer',\n    height: '100%',\n    opacity: disabled ? 0.5 : 1,\n    transition: 'all 150ms linear',\n    color: getTextColor({\n      theme,\n      open,\n      calculatedColor,\n      hasSelectedValue,\n    }),\n    backgroundColor: getBackgroundColor({\n      theme,\n      open,\n      styleType,\n      hasSelectedValue,\n      calculatedColor,\n    }),\n    border: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    display: 'flex',\n    justifyContent: 'center',\n    width: '100%',\n    '&:hover': {\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n        state: 'hover',\n      })}`,\n    },\n  };\n};\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => css`\n  position: absolute;\n  top: ${rem(48)};\n  min-width: ${rem(280)};\n  left: 0;\n  height: auto;\n  border-radius: ${theme.spacing.xsm};\n  background-color: ${theme.palette.white};\n  box-shadow: ${theme.elevation['02']};\n  z-index: 500;\n  overflow: hidden;\n  min-width: 100%;\n  max-width: ${rem(620)};\n`;\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;")
293
+ (0, _react.css)("position:absolute;left:0;height:auto;border:", (0, _utils.rem)(borderConfig.width), " solid ", theme.utils.getColor(borderConfig.color["default"].name, borderConfig.color["default"].shade), ";border-radius:", theme.spacing.xsm, ";background-color:", theme.palette.white, ";box-shadow:", theme.elevation['02'], ";z-index:500;overflow:hidden;min-width:100%;max-width:", (0, _utils.rem)(440), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Filter/Filter.style.ts"],"names":[],"mappings":"AAiPY","file":"../../../src/components/Filter/Filter.style.ts","sourcesContent":["import { css } from '@emotion/react';\nimport { rem } from 'theme/utils';\n\nimport { Theme } from '../../theme';\nimport { getFocus, getHover, getPressed } from '../../theme/states';\nimport { ButtonStyleProps } from './types';\nimport {\n  borderStyleParams,\n  focusBorderWidth,\n  getBackgroundColor,\n  getBorder,\n  getTextColor,\n  HAS_SELECTED_VALUE_COLOR_SHADE,\n  transparentFocusBorderWidth,\n} from './utils';\nimport { textInputConfig } from 'components/TextInputBase/config';\n\nexport const wrapperStyle = () => () => {\n  return {\n    position: 'relative' as const,\n    display: 'inline-block',\n    height: rem(36),\n  };\n};\n\nexport const buttonSpanStyle = () => () => {\n  return {\n    display: 'flex',\n    alignItems: 'center',\n    gap: rem(4),\n    height: '100%',\n  };\n};\n\nexport const buttonWrapperStyle =\n  ({ disabled, open, hasSelectedValue, calculatedColor, styleType }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    const activeAndClosed = !disabled && !open;\n    const borderWidth = styleType === 'filled' ? focusBorderWidth : transparentFocusBorderWidth;\n\n    return {\n      background: 'none',\n      border: 'none',\n      display: 'flex',\n      padding: '0',\n      alignItems: 'center',\n      height: '100%',\n      minWidth: rem(110),\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':hover > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getHover({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getHover({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // If is active and not disabled and not visited global states applied\n      // else it's using the global states function with calculated color\n      ':active > div': {\n        backgroundColor: activeAndClosed\n          ? hasSelectedValue\n            ? getPressed({\n                theme,\n                color: calculatedColor.color,\n                shade: HAS_SELECTED_VALUE_COLOR_SHADE,\n              }).backgroundColor\n            : getPressed({ theme }).backgroundColor\n          : undefined,\n      },\n\n      // on focus change the two divs of added\n      ':focus-visible > div': {\n        border: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n      // target the divider on focus\n      ':focus-visible > span': {\n        borderTop: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n        borderBottom: getFocus({ theme, borderWidth: borderWidth }).styleBorder,\n      },\n    };\n  };\n\nexport const buttonBaseStyle =\n  ({\n    calculatedColor,\n    disabled,\n    open,\n    styleType,\n    hasSelectedValue,\n    filterType,\n  }: ButtonStyleProps) =>\n  (theme: Theme) => {\n    return {\n      fontSize: theme.typography.fontSizes['13'],\n      cursor: disabled ? 'not-allowed' : 'pointer',\n      height: '100%',\n      opacity: disabled ? 0.5 : 1,\n      transition: 'all 150ms linear',\n      color: getTextColor({\n        theme,\n        open,\n        calculatedColor,\n        hasSelectedValue,\n      }),\n      backgroundColor: getBackgroundColor({\n        theme,\n        open,\n        styleType,\n        hasSelectedValue,\n        calculatedColor,\n      }),\n      border: `${borderStyleParams} ${getBorder({\n        styleType,\n        theme,\n        hasSelectedValue,\n        filterType,\n        calculatedColor,\n        open,\n      })}`,\n      display: 'flex',\n      justifyContent: 'center',\n      width: '100%',\n      '&:hover': {\n        border: `${borderStyleParams} ${getBorder({\n          styleType,\n          theme,\n          hasSelectedValue,\n          filterType,\n          calculatedColor,\n          open,\n          state: 'hover',\n        })}`,\n      },\n    };\n  };\n\nexport const divider = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { open, calculatedColor, styleType, hasSelectedValue, filterType } = props;\n\n  return {\n    height: '100%',\n    width: rem(1),\n    position: 'relative' as const,\n    minWidth: rem(1),\n    transition: 'all 150ms linear',\n    backgroundColor: getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n      isDivider: true,\n    }),\n    borderTop: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n    borderBottom: `${borderStyleParams} ${getBorder({\n      styleType,\n      theme,\n      hasSelectedValue,\n      filterType,\n      calculatedColor,\n      open,\n    })}`,\n  };\n};\n\nexport const dividedButtonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  return {\n    ...buttonBaseStyle(props)(theme),\n    borderLeft: '0 !important',\n    paddingLeft: rem(4),\n    paddingRight: rem(4),\n    display: 'flex',\n    alignItems: 'center',\n    justifyContent: 'center',\n    width: rem(34),\n    borderTopRightRadius: theme.spacing.lg,\n    borderBottomRightRadius: theme.spacing.lg,\n  };\n};\n\nexport const buttonStyle = (props: ButtonStyleProps) => (theme: Theme) => {\n  const { filterType } = props;\n  const isPreset = filterType === 'preset';\n\n  return {\n    ...buttonBaseStyle(props)(theme),\n    padding: `0 ${!isPreset ? theme.spacing.xsm : theme.spacing.md} 0 ${theme.spacing.md}`,\n    borderRadius: theme.spacing.lg,\n    borderRight: !isPreset ? '0 !important' : undefined,\n    borderTopRightRadius: !isPreset ? 0 : undefined,\n    borderBottomRightRadius: !isPreset ? 0 : undefined,\n  };\n};\n\nexport const childrenWrapperStyle = () => () => {\n  return {\n    lineHeight: rem(15),\n    marginLeft: 0,\n  };\n};\n\nexport const labelSpanStyle = (open: boolean, hasSelectedValue: boolean) => (theme: Theme) => {\n  return {\n    fontWeight:\n      open || hasSelectedValue ? theme.typography.weights.bold : theme.typography.weights.regular,\n    display: 'flex',\n    alignItems: 'center',\n    div: {\n      flex: 'none',\n    },\n    span: {\n      fontWeight: theme.typography.weights.bold,\n    },\n  };\n};\n\nexport const valueSpanStyle = () => css`\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n  display: inline-block;\n`;\n\nexport const menuStyle = () => (theme: Theme) => {\n  const borderConfig = textInputConfig.types[theme.colorScheme].outlined.border;\n\n  return css`\n    position: absolute;\n    left: 0;\n    height: auto;\n    border: ${rem(borderConfig.width)} solid\n      ${theme.utils.getColor(borderConfig.color.default.name, borderConfig.color.default.shade)};\n    border-radius: ${theme.spacing.xsm};\n    background-color: ${theme.palette.white};\n    box-shadow: ${theme.elevation['02']};\n    z-index: 500;\n    overflow: hidden;\n    min-width: 100%;\n    max-width: ${rem(440)};\n  `;\n};\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:menuStyle;")
291
294
  );
292
295
  };
293
296
  };
@@ -11,5 +11,5 @@ declare type FilterBaseProps = {
11
11
  open: boolean;
12
12
  hasSelectedValue: boolean;
13
13
  };
14
- export declare const FilterBase: React.ForwardRefExoticComponent<FilterBaseProps & Pick<Props, "disabled" | "label" | "dataTestId" | "buttonType" | "styleType" | "filterType"> & React.RefAttributes<HTMLButtonElement>>;
14
+ export declare const FilterBase: React.ForwardRefExoticComponent<FilterBaseProps & Pick<Props, "disabled" | "label" | "dataTestId" | "buttonType" | "styleType" | "multi" | "filterType"> & React.RefAttributes<HTMLButtonElement>>;
15
15
  export default FilterBase;
@@ -42,7 +42,8 @@ var FilterBase = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
42
42
  _props$filterType = props.filterType,
43
43
  filterType = _props$filterType === void 0 ? 'preset' : _props$filterType,
44
44
  styleType = props.styleType,
45
- children = props.children;
45
+ children = props.children,
46
+ multi = props.multi;
46
47
 
47
48
  var _useTypeColorToColorM = (0, _useTypeColorToColorMatch.useTypeColorToColorMatch)(),
48
49
  calculateColorBetweenColorAndType = _useTypeColorToColorM.calculateColorBetweenColorAndType;
@@ -99,13 +100,16 @@ var FilterBase = /*#__PURE__*/(0, _react.forwardRef)(function (props, ref) {
99
100
  css: (0, _Filter.childrenWrapperStyle)()
100
101
  }, (0, _react2.jsx)("span", {
101
102
  css: (0, _Filter.labelSpanStyle)(open, hasSelectedValue)
102
- }, label && (0, _react2.jsx)("div", null, label, " ", !isDatePicker ? (0, _react2.jsx)(_react["default"].Fragment, null, ":\xA0") : ''), selectedItemLabel && (0, _react2.jsx)("span", {
103
- css: (0, _Filter.valueSpanStyle)()
103
+ }, label && (0, _react2.jsx)("div", {
104
+ "data-testid": "filter-label"
105
+ }, label, " ", !isDatePicker ? (0, _react2.jsx)(_react["default"].Fragment, null, ":\xA0") : ''), selectedItemLabel && (0, _react2.jsx)("span", {
106
+ css: (0, _Filter.valueSpanStyle)(),
107
+ "data-testid": "filter-selected-item-label"
104
108
  }, selectedItemLabel))), (0, _react2.jsx)(_Icon["default"], {
105
109
  name: iconName,
106
110
  size: isDatePicker ? 14 : 7,
107
111
  color: pickIconColor()
108
- }))), filterType === 'added' && (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)("span", {
112
+ }))), filterType === 'added' && !multi && (0, _react2.jsx)(_react["default"].Fragment, null, (0, _react2.jsx)("span", {
109
113
  css: (0, _Filter.divider)(buttonStyleProps)
110
114
  }), (0, _react2.jsx)("div", {
111
115
  css: (0, _Filter.dividedButtonStyle)(buttonStyleProps)
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import { FilterOption, Props as FilterProps } from '../../types';
3
+ declare type Props = Pick<FilterProps, 'selectedItems' | 'items' | 'isLoading' | 'hasSelectAllOption'> & {
4
+ onInput?: React.EventHandler<any>;
5
+ onOptionDelete: (option?: FilterOption | undefined) => void;
6
+ onClearAllOptions: () => void;
7
+ onOptionClick: (option: FilterOption) => void;
8
+ searchValue: string;
9
+ };
10
+ declare const MultiFilter: React.FC<Props>;
11
+ export default MultiFilter;
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _react = _interopRequireDefault(require("react"));
7
+
8
+ var _Options = _interopRequireDefault(require("../Options/Options"));
9
+
10
+ var _MultiFilter = require("./MultiFilter.style");
11
+
12
+ var _Filter = require("../../Filter.style");
13
+
14
+ var _MultiSelectBase = _interopRequireDefault(require("../../../MultiSelectBase/MultiSelectBase"));
15
+
16
+ var _constants = require("../../../Select/constants");
17
+
18
+ var _react2 = require("@emotion/react");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
+
22
+ var MultiFilter = function MultiFilter(_ref) {
23
+ var selectedItems = _ref.selectedItems,
24
+ items = _ref.items,
25
+ onInput = _ref.onInput,
26
+ onOptionDelete = _ref.onOptionDelete,
27
+ onClearAllOptions = _ref.onClearAllOptions,
28
+ onOptionClick = _ref.onOptionClick,
29
+ searchValue = _ref.searchValue,
30
+ isLoading = _ref.isLoading,
31
+ hasSelectAllOption = _ref.hasSelectAllOption;
32
+ return (0, _react2.jsx)("div", {
33
+ css: (0, _Filter.menuStyle)()
34
+ }, (0, _react2.jsx)("div", {
35
+ css: (0, _MultiFilter.textFieldWrapper)()
36
+ }, (0, _react2.jsx)(_MultiSelectBase["default"], {
37
+ selectedOptions: selectedItems,
38
+ onInput: onInput,
39
+ onOptionDelete: onOptionDelete,
40
+ onClearAllOptions: onClearAllOptions,
41
+ isInteractive: false,
42
+ value: searchValue,
43
+ placeholder: "Search",
44
+ isResponsive: true,
45
+ isLoading: isLoading
46
+ })), (0, _react2.jsx)("div", {
47
+ css: (0, _MultiFilter.optionsWrapper)()
48
+ }, (0, _react2.jsx)(_Options["default"], {
49
+ items: items,
50
+ onSelect: onOptionClick,
51
+ defaultValue: _constants.SELECT_ALL_OPTION,
52
+ shouldDisplayDefaultOption: hasSelectAllOption != null ? hasSelectAllOption : false
53
+ })));
54
+ };
55
+
56
+ var _default = MultiFilter;
57
+ exports["default"] = _default;
@@ -0,0 +1,3 @@
1
+ import { Theme } from 'theme';
2
+ export declare const textFieldWrapper: () => import("@emotion/react").SerializedStyles;
3
+ export declare const optionsWrapper: () => (theme: Theme) => import("@emotion/react").SerializedStyles;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.optionsWrapper = exports.textFieldWrapper = void 0;
5
+
6
+ var _react = require("@emotion/react");
7
+
8
+ var _utils = require("../../../../theme/utils");
9
+
10
+ var _config = require("../../../TextInputBase/config");
11
+
12
+ 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)."; }
13
+
14
+ var _ref = process.env.NODE_ENV === "production" ? {
15
+ name: "15pt3w9",
16
+ styles: "&>div>div{border-bottom-left-radius:0;border-bottom-right-radius:0;}"
17
+ } : {
18
+ name: "16du9gm-textFieldWrapper",
19
+ styles: "&>div>div{border-bottom-left-radius:0;border-bottom-right-radius:0;};label:textFieldWrapper;",
20
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0ZpbHRlci9jb21wb25lbnRzL011bHRpRmlsdGVyL011bHRpRmlsdGVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9LIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0ZpbHRlci9jb21wb25lbnRzL011bHRpRmlsdGVyL011bHRpRmlsdGVyLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IHRleHRJbnB1dENvbmZpZyB9IGZyb20gJ2NvbXBvbmVudHMvVGV4dElucHV0QmFzZS9jb25maWcnO1xuXG5leHBvcnQgY29uc3QgdGV4dEZpZWxkV3JhcHBlciA9ICgpID0+XG4gIGNzc2BcbiAgICAmID4gZGl2ID4gZGl2IHtcbiAgICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6IDA7XG4gICAgICBib3JkZXItYm90dG9tLXJpZ2h0LXJhZGl1czogMDtcbiAgICB9XG4gIGA7XG5cbmV4cG9ydCBjb25zdCBvcHRpb25zV3JhcHBlciA9ICgpID0+ICh0aGVtZTogVGhlbWUpID0+IHtcbiAgY29uc3QgYm9yZGVyQ29uZmlnID0gdGV4dElucHV0Q29uZmlnLnR5cGVzW3RoZW1lLmNvbG9yU2NoZW1lXS5vdXRsaW5lZC5ib3JkZXI7XG5cbiAgcmV0dXJuIGNzc2BcbiAgICAmID4gZGl2IHtcbiAgICAgIGJveC1zaGFkb3c6IDAgMCAwICR7cmVtKGJvcmRlckNvbmZpZy53aWR0aCl9XG4gICAgICAgICR7dGhlbWUudXRpbHMuZ2V0Q29sb3IoYm9yZGVyQ29uZmlnLmNvbG9yLmRlZmF1bHQubmFtZSwgYm9yZGVyQ29uZmlnLmNvbG9yLmRlZmF1bHQuc2hhZGUpfTtcbiAgICAgIGJvcmRlcjogbm9uZTtcbiAgICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6IDA7XG4gICAgICBib3JkZXItdG9wLXJpZ2h0LXJhZGl1czogMDtcbiAgICB9XG4gIGA7XG59O1xuXG5cbiJdfQ== */",
21
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
+ };
23
+
24
+ var textFieldWrapper = function textFieldWrapper() {
25
+ return _ref;
26
+ };
27
+
28
+ exports.textFieldWrapper = textFieldWrapper;
29
+
30
+ var optionsWrapper = function optionsWrapper() {
31
+ return function (theme) {
32
+ var borderConfig = _config.textInputConfig.types[theme.colorScheme].outlined.border;
33
+ return (
34
+ /*#__PURE__*/
35
+
36
+ /*#__PURE__*/
37
+ (0, _react.css)("&>div{box-shadow:0 0 0 ", (0, _utils.rem)(borderConfig.width), " ", theme.utils.getColor(borderConfig.color["default"].name, borderConfig.color["default"].shade), ";border:none;border-top-left-radius:0;border-top-right-radius:0;}" + (process.env.NODE_ENV === "production" ? "" : ";label:optionsWrapper;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0ZpbHRlci9jb21wb25lbnRzL011bHRpRmlsdGVyL011bHRpRmlsdGVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCWSIsImZpbGUiOiIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9GaWx0ZXIvY29tcG9uZW50cy9NdWx0aUZpbHRlci9NdWx0aUZpbHRlci5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IFRoZW1lIH0gZnJvbSAndGhlbWUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAndGhlbWUvdXRpbHMnO1xuXG5pbXBvcnQgeyB0ZXh0SW5wdXRDb25maWcgfSBmcm9tICdjb21wb25lbnRzL1RleHRJbnB1dEJhc2UvY29uZmlnJztcblxuZXhwb3J0IGNvbnN0IHRleHRGaWVsZFdyYXBwZXIgPSAoKSA9PlxuICBjc3NgXG4gICAgJiA+IGRpdiA+IGRpdiB7XG4gICAgICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAwO1xuICAgICAgYm9yZGVyLWJvdHRvbS1yaWdodC1yYWRpdXM6IDA7XG4gICAgfVxuICBgO1xuXG5leHBvcnQgY29uc3Qgb3B0aW9uc1dyYXBwZXIgPSAoKSA9PiAodGhlbWU6IFRoZW1lKSA9PiB7XG4gIGNvbnN0IGJvcmRlckNvbmZpZyA9IHRleHRJbnB1dENvbmZpZy50eXBlc1t0aGVtZS5jb2xvclNjaGVtZV0ub3V0bGluZWQuYm9yZGVyO1xuXG4gIHJldHVybiBjc3NgXG4gICAgJiA+IGRpdiB7XG4gICAgICBib3gtc2hhZG93OiAwIDAgMCAke3JlbShib3JkZXJDb25maWcud2lkdGgpfVxuICAgICAgICAke3RoZW1lLnV0aWxzLmdldENvbG9yKGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0Lm5hbWUsIGJvcmRlckNvbmZpZy5jb2xvci5kZWZhdWx0LnNoYWRlKX07XG4gICAgICBib3JkZXI6IG5vbmU7XG4gICAgICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAwO1xuICAgICAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDA7XG4gICAgfVxuICBgO1xufTtcblxuXG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:optionsWrapper;")
38
+ );
39
+ };
40
+ };
41
+
42
+ exports.optionsWrapper = optionsWrapper;
@@ -0,0 +1 @@
1
+ export { default } from './MultiFilter';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _MultiFilter = _interopRequireDefault(require("./MultiFilter"));
7
+
8
+ exports["default"] = _MultiFilter["default"];
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import { Props as FilterProps } from '../../types';
3
+ import { FilterOption } from 'components/Filter/types';
4
+ declare type Props = Pick<FilterProps, 'isSearchable' | 'dataTestId' | 'isLoading' | 'isVirtualized' | 'defaultValue' | 'selectedItem'> & {
5
+ searchValue: string;
6
+ handleChange: (event: React.ChangeEvent<HTMLInputElement>) => void;
7
+ filteredOptions: FilterOption[];
8
+ handleSelect: (option: FilterOption) => void;
9
+ shouldDisplayDefaultOption: boolean;
10
+ };
11
+ declare const SingleFilter: React.FC<Props>;
12
+ export default SingleFilter;
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _react = _interopRequireDefault(require("react"));
7
+
8
+ var _helpers = require("../../../../utils/helpers");
9
+
10
+ var _Options = _interopRequireDefault(require("../Options/Options"));
11
+
12
+ var _SearchInput = _interopRequireDefault(require("./components/SearchInput"));
13
+
14
+ var _Filter = require("../../Filter.style");
15
+
16
+ var _react2 = require("@emotion/react");
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
+
20
+ var SingleFilter = function SingleFilter(_ref) {
21
+ var isSearchable = _ref.isSearchable,
22
+ dataTestId = _ref.dataTestId,
23
+ searchValue = _ref.searchValue,
24
+ handleChange = _ref.handleChange,
25
+ isLoading = _ref.isLoading,
26
+ filteredOptions = _ref.filteredOptions,
27
+ isVirtualized = _ref.isVirtualized,
28
+ defaultValue = _ref.defaultValue,
29
+ selectedItem = _ref.selectedItem,
30
+ handleSelect = _ref.handleSelect,
31
+ shouldDisplayDefaultOption = _ref.shouldDisplayDefaultOption;
32
+ return (0, _react2.jsx)("div", {
33
+ css: (0, _Filter.menuStyle)(),
34
+ "data-testid": (0, _helpers.generateTestDataId)('filter-menu', dataTestId)
35
+ }, isSearchable && (0, _react2.jsx)(_SearchInput["default"], {
36
+ value: searchValue,
37
+ onChange: handleChange,
38
+ dataTestId: dataTestId,
39
+ isLoading: isLoading
40
+ }), (0, _react2.jsx)(_Options["default"], {
41
+ dataTestId: dataTestId,
42
+ items: filteredOptions,
43
+ isVirtualized: isVirtualized,
44
+ defaultValue: defaultValue,
45
+ isSearchable: isSearchable,
46
+ selectedItem: selectedItem,
47
+ onSelect: handleSelect,
48
+ shouldDisplayDefaultOption: shouldDisplayDefaultOption
49
+ }));
50
+ };
51
+
52
+ var _default = SingleFilter;
53
+ exports["default"] = _default;
@@ -5,5 +5,5 @@ interface Props {
5
5
  dataTestId?: string;
6
6
  isLoading?: boolean;
7
7
  }
8
- declare const SearchInput: ({ onChange, value, dataTestId, isLoading }: Props) => import("@emotion/react/jsx-runtime").JSX.Element;
8
+ declare const SearchInput: React.FC<Props>;
9
9
  export default SearchInput;
@@ -3,19 +3,19 @@
3
3
  exports.__esModule = true;
4
4
  exports["default"] = void 0;
5
5
 
6
- var _useTheme = _interopRequireDefault(require("../../../../hooks/useTheme"));
6
+ var _useTheme = _interopRequireDefault(require("../../../../../../hooks/useTheme"));
7
7
 
8
8
  var _react = _interopRequireWildcard(require("react"));
9
9
 
10
- var _helpers = require("../../../../utils/helpers");
10
+ var _helpers = require("../../../../../../utils/helpers");
11
11
 
12
- var _Icon = _interopRequireDefault(require("../../../Icon"));
12
+ var _SearchInput = require("./SearchInput.style");
13
13
 
14
- var _Loader = _interopRequireDefault(require("../../../Loader"));
14
+ var _Icon = _interopRequireDefault(require("../../../../../Icon"));
15
15
 
16
- var _TextField = _interopRequireDefault(require("../../../TextField"));
16
+ var _Loader = _interopRequireDefault(require("../../../../../Loader"));
17
17
 
18
- var _SearchInput = require("./SearchInput.style");
18
+ var _TextField = _interopRequireDefault(require("../../../../../TextField"));
19
19
 
20
20
  var _react2 = require("@emotion/react");
21
21