@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.
- package/dist/components/Filter/Filter.js +117 -46
- package/dist/components/Filter/Filter.style.d.ts +1 -1
- package/dist/components/Filter/Filter.style.js +5 -2
- package/dist/components/Filter/components/FilterBase/FilterBase.d.ts +1 -1
- package/dist/components/Filter/components/FilterBase/FilterBase.js +8 -4
- package/dist/components/Filter/components/MultiFilter/MultiFilter.d.ts +11 -0
- package/dist/components/Filter/components/MultiFilter/MultiFilter.js +57 -0
- package/dist/components/Filter/components/MultiFilter/MultiFilter.style.d.ts +3 -0
- package/dist/components/Filter/components/MultiFilter/MultiFilter.style.js +42 -0
- package/dist/components/Filter/components/MultiFilter/index.d.ts +1 -0
- package/dist/components/Filter/components/MultiFilter/index.js +10 -0
- package/dist/components/Filter/components/SingleFilter/SingleFilter.d.ts +12 -0
- package/dist/components/Filter/components/SingleFilter/SingleFilter.js +53 -0
- package/dist/components/Filter/components/{SearchInput → SingleFilter/components/SearchInput}/SearchInput.d.ts +1 -1
- package/dist/components/Filter/components/{SearchInput → SingleFilter/components/SearchInput}/SearchInput.js +6 -6
- package/dist/components/Filter/components/SingleFilter/components/SearchInput/SearchInput.style.js +34 -0
- package/dist/components/Filter/components/SingleFilter/components/SearchInput/index.d.ts +1 -0
- package/dist/components/Filter/components/SingleFilter/components/SearchInput/index.js +10 -0
- package/dist/components/Filter/components/SingleFilter/index.d.ts +1 -0
- package/dist/components/Filter/components/SingleFilter/index.js +10 -0
- package/dist/components/Filter/hooks/useMultiFilterUtils.d.ts +18 -0
- package/dist/components/Filter/hooks/useMultiFilterUtils.js +124 -0
- package/dist/components/Filter/types.d.ts +13 -1
- package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.d.ts → MultiSelectBase/MultiSelectBase.d.ts} +6 -2
- package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.js → MultiSelectBase/MultiSelectBase.js} +48 -71
- package/dist/components/{Select/components/MultiselectTextField/MultiselectTextField.style.d.ts → MultiSelectBase/MultiSelectBase.style.d.ts} +5 -1
- package/dist/components/MultiSelectBase/MultiSelectBase.style.js +156 -0
- package/dist/components/MultiSelectBase/hooks.d.ts +17 -0
- package/dist/components/MultiSelectBase/hooks.js +91 -0
- package/dist/components/MultiSelectBase/index.d.ts +1 -0
- package/dist/components/MultiSelectBase/index.js +10 -0
- package/dist/components/Select/Select.d.ts +15 -0
- package/dist/components/Select/Select.js +57 -22
- package/dist/components/Select/hooks/useMultiselectUtils.js +19 -3
- package/dist/components/TextInputBase/TextInputBase.d.ts +2 -0
- package/dist/components/TextInputBase/TextInputBase.js +4 -1
- package/dist/components/TextInputBase/TextInputBase.style.d.ts +1 -1
- package/dist/components/TextInputBase/TextInputBase.style.js +7 -6
- package/dist/components/utils/PositionInScreen/PositionInScreen.d.ts +6 -0
- package/dist/components/utils/PositionInScreen/PositionInScreen.js +3 -2
- package/dist/components/utils/PositionInScreen/PositionInScreen.style.d.ts +9 -2
- package/dist/components/utils/PositionInScreen/PositionInScreen.style.js +23 -4
- package/package.json +1 -1
- package/dist/components/Filter/components/SearchInput/SearchInput.style.js +0 -34
- package/dist/components/Select/components/MultiselectTextField/MultiselectTextField.style.js +0 -149
- package/dist/components/Select/components/MultiselectTextField/index.d.ts +0 -1
- package/dist/components/Select/components/MultiselectTextField/index.js +0 -10
- /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
|
|
16
|
+
var _MultiFilter = _interopRequireDefault(require("./components/MultiFilter/MultiFilter"));
|
|
17
17
|
|
|
18
|
-
var
|
|
18
|
+
var _SingleFilter = _interopRequireDefault(require("./components/SingleFilter/SingleFilter"));
|
|
19
19
|
|
|
20
|
-
var
|
|
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
|
|
76
|
-
|
|
77
|
-
|
|
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
|
|
120
|
+
return optionsToBeFiltered;
|
|
95
121
|
}
|
|
96
122
|
|
|
97
|
-
return
|
|
123
|
+
return optionsToBeFiltered.filter(function (item) {
|
|
98
124
|
return !searchValue || item.label.toLowerCase().includes(searchValue.toLowerCase());
|
|
99
125
|
});
|
|
100
|
-
}, [
|
|
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)(
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
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
|
|
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,
|
|
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",
|
|
103
|
-
|
|
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,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:
|
|
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("
|
|
6
|
+
var _useTheme = _interopRequireDefault(require("../../../../../../hooks/useTheme"));
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireWildcard(require("react"));
|
|
9
9
|
|
|
10
|
-
var _helpers = require("
|
|
10
|
+
var _helpers = require("../../../../../../utils/helpers");
|
|
11
11
|
|
|
12
|
-
var
|
|
12
|
+
var _SearchInput = require("./SearchInput.style");
|
|
13
13
|
|
|
14
|
-
var
|
|
14
|
+
var _Icon = _interopRequireDefault(require("../../../../../Icon"));
|
|
15
15
|
|
|
16
|
-
var
|
|
16
|
+
var _Loader = _interopRequireDefault(require("../../../../../Loader"));
|
|
17
17
|
|
|
18
|
-
var
|
|
18
|
+
var _TextField = _interopRequireDefault(require("../../../../../TextField"));
|
|
19
19
|
|
|
20
20
|
var _react2 = require("@emotion/react");
|
|
21
21
|
|