@orfium/ictinus 4.8.1 → 4.9.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 (25) hide show
  1. package/dist/components/List/List.style.d.ts +5 -0
  2. package/dist/components/List/List.style.js +21 -3
  3. package/dist/components/List/ListItem/ListItem.d.ts +3 -1
  4. package/dist/components/List/ListItem/ListItem.js +6 -33
  5. package/dist/components/List/ListItem/ListItem.style.d.ts +2 -1
  6. package/dist/components/List/ListItem/ListItem.style.js +4 -3
  7. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.d.ts +14 -0
  8. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.js +36 -0
  9. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.style.d.ts +8 -0
  10. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.style.js +41 -0
  11. package/dist/components/List/ListItemGroup/ListGroupTitle/index.d.ts +1 -0
  12. package/dist/components/List/ListItemGroup/ListGroupTitle/index.js +10 -0
  13. package/dist/components/List/ListItemGroup/ListItemGroup.d.ts +18 -0
  14. package/dist/components/List/ListItemGroup/ListItemGroup.js +64 -0
  15. package/dist/components/List/ListItemGroup/index.d.ts +1 -0
  16. package/dist/components/List/ListItemGroup/index.js +10 -0
  17. package/dist/components/List/NormalList/NormalList.js +15 -4
  18. package/dist/components/List/NormalList/NormalList.style.d.ts +0 -7
  19. package/dist/components/List/NormalList/NormalList.style.js +1 -24
  20. package/dist/components/List/VirtualizedList/VirtualizedList.js +35 -7
  21. package/dist/components/List/utils.d.ts +1 -0
  22. package/dist/components/List/utils.js +26 -2
  23. package/dist/components/Select/Select.d.ts +1 -0
  24. package/dist/components/Select/Select.js +14 -2
  25. package/package.json +1 -1
@@ -4,3 +4,8 @@ export declare const wrapperStyle: ({ width, isSearchable, }: {
4
4
  width: number | undefined;
5
5
  isSearchable?: boolean | undefined;
6
6
  }) => (theme: Theme) => SerializedStyles;
7
+ export declare const listStyle: ({ width, height, isSearchable, }: {
8
+ width?: number | undefined;
9
+ height?: number | undefined;
10
+ isSearchable?: boolean | undefined;
11
+ }) => (theme: Theme) => SerializedStyles;
@@ -1,10 +1,12 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.wrapperStyle = void 0;
4
+ exports.listStyle = exports.wrapperStyle = void 0;
5
5
 
6
6
  var _react = require("@emotion/react");
7
7
 
8
+ var _utils = require("../../theme/utils");
9
+
8
10
  var wrapperStyle = function wrapperStyle(_ref) {
9
11
  var width = _ref.width,
10
12
  isSearchable = _ref.isSearchable;
@@ -13,9 +15,25 @@ var wrapperStyle = function wrapperStyle(_ref) {
13
15
  /*#__PURE__*/
14
16
 
15
17
  /*#__PURE__*/
16
- (0, _react.css)("border:", isSearchable ? 'initial' : "1px solid " + theme.utils.getColor('lightGrey', 100), ";border-radius:", isSearchable ? 'initial' : theme.spacing.xsm, ";width:", width + "px" || '100%', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdC5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTNkMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTGlzdC9MaXN0LnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVyU3R5bGUgPSAoe1xuICB3aWR0aCxcbiAgaXNTZWFyY2hhYmxlLFxufToge1xuICB3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICBpc1NlYXJjaGFibGU/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBib3JkZXI6ICR7aXNTZWFyY2hhYmxlID8gJ2luaXRpYWwnIDogYDFweCBzb2xpZCAke3RoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCAxMDApfWB9O1xuICBib3JkZXItcmFkaXVzOiAke2lzU2VhcmNoYWJsZSA/ICdpbml0aWFsJyA6IHRoZW1lLnNwYWNpbmcueHNtfTtcbiAgd2lkdGg6ICR7YCR7d2lkdGh9cHhgIHx8ICcxMDAlJ307XG5gO1xuIl19 */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;")
18
+ (0, _react.css)("border:", isSearchable ? 'initial' : "1px solid " + theme.utils.getColor('lightGrey', 100), ";border-radius:", isSearchable ? 'initial' : theme.spacing.xsm, ";width:", width + "px" || '100%', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdC5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFVNkMiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTGlzdC9MaXN0LnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmV4cG9ydCBjb25zdCB3cmFwcGVyU3R5bGUgPSAoe1xuICB3aWR0aCxcbiAgaXNTZWFyY2hhYmxlLFxufToge1xuICB3aWR0aDogbnVtYmVyIHwgdW5kZWZpbmVkO1xuICBpc1NlYXJjaGFibGU/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBib3JkZXI6ICR7aXNTZWFyY2hhYmxlID8gJ2luaXRpYWwnIDogYDFweCBzb2xpZCAke3RoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCAxMDApfWB9O1xuICBib3JkZXItcmFkaXVzOiAke2lzU2VhcmNoYWJsZSA/ICdpbml0aWFsJyA6IHRoZW1lLnNwYWNpbmcueHNtfTtcbiAgd2lkdGg6ICR7YCR7d2lkdGh9cHhgIHx8ICcxMDAlJ307XG5gO1xuXG5leHBvcnQgY29uc3QgbGlzdFN0eWxlID0gKHtcbiAgd2lkdGgsXG4gIGhlaWdodCxcbiAgaXNTZWFyY2hhYmxlLFxufToge1xuICB3aWR0aD86IG51bWJlcjtcbiAgaGVpZ2h0PzogbnVtYmVyO1xuICBpc1NlYXJjaGFibGU/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBwYWRkaW5nLWxlZnQ6IDA7XG4gIG1hcmdpbi10b3A6IDA7XG4gIG1hcmdpbi1ib3R0b206IDA7XG4gIGJvcmRlci1yYWRpdXM6ICR7aXNTZWFyY2hhYmxlID8gJ2luaXRpYWwnIDogdGhlbWUuc3BhY2luZy54c219O1xuICB3aWR0aDogJHt3aWR0aCA/IHJlbSh3aWR0aCkgOiAnMTAwJSd9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0ID8gcmVtKGhlaWdodCkgOiAnMTAwJSd9O1xuICBvdmVyZmxvdzogYXV0bztcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xuYDtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:wrapperStyle;")
19
+ );
20
+ };
21
+ };
22
+
23
+ exports.wrapperStyle = wrapperStyle;
24
+
25
+ var listStyle = function listStyle(_ref2) {
26
+ var width = _ref2.width,
27
+ height = _ref2.height,
28
+ isSearchable = _ref2.isSearchable;
29
+ return function (theme) {
30
+ return (
31
+ /*#__PURE__*/
32
+
33
+ /*#__PURE__*/
34
+ (0, _react.css)("padding-left:0;margin-top:0;margin-bottom:0;border-radius:", isSearchable ? 'initial' : theme.spacing.xsm, ";width:", width ? (0, _utils.rem)(width) : '100%', ";height:", height ? (0, _utils.rem)(height) : '100%', ";overflow:auto;overflow-x:hidden;" + (process.env.NODE_ENV === "production" ? "" : ";label:listStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdC5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QjZDIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdC5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IFRoZW1lIH0gZnJvbSAndGhlbWUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAndGhlbWUvdXRpbHMnO1xuXG5leHBvcnQgY29uc3Qgd3JhcHBlclN0eWxlID0gKHtcbiAgd2lkdGgsXG4gIGlzU2VhcmNoYWJsZSxcbn06IHtcbiAgd2lkdGg6IG51bWJlciB8IHVuZGVmaW5lZDtcbiAgaXNTZWFyY2hhYmxlPzogYm9vbGVhbjtcbn0pID0+ICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+IGNzc2BcbiAgYm9yZGVyOiAke2lzU2VhcmNoYWJsZSA/ICdpbml0aWFsJyA6IGAxcHggc29saWQgJHt0aGVtZS51dGlscy5nZXRDb2xvcignbGlnaHRHcmV5JywgMTAwKX1gfTtcbiAgYm9yZGVyLXJhZGl1czogJHtpc1NlYXJjaGFibGUgPyAnaW5pdGlhbCcgOiB0aGVtZS5zcGFjaW5nLnhzbX07XG4gIHdpZHRoOiAke2Ake3dpZHRofXB4YCB8fCAnMTAwJSd9O1xuYDtcblxuZXhwb3J0IGNvbnN0IGxpc3RTdHlsZSA9ICh7XG4gIHdpZHRoLFxuICBoZWlnaHQsXG4gIGlzU2VhcmNoYWJsZSxcbn06IHtcbiAgd2lkdGg/OiBudW1iZXI7XG4gIGhlaWdodD86IG51bWJlcjtcbiAgaXNTZWFyY2hhYmxlPzogYm9vbGVhbjtcbn0pID0+ICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+IGNzc2BcbiAgcGFkZGluZy1sZWZ0OiAwO1xuICBtYXJnaW4tdG9wOiAwO1xuICBtYXJnaW4tYm90dG9tOiAwO1xuICBib3JkZXItcmFkaXVzOiAke2lzU2VhcmNoYWJsZSA/ICdpbml0aWFsJyA6IHRoZW1lLnNwYWNpbmcueHNtfTtcbiAgd2lkdGg6ICR7d2lkdGggPyByZW0od2lkdGgpIDogJzEwMCUnfTtcbiAgaGVpZ2h0OiAke2hlaWdodCA/IHJlbShoZWlnaHQpIDogJzEwMCUnfTtcbiAgb3ZlcmZsb3c6IGF1dG87XG4gIG92ZXJmbG93LXg6IGhpZGRlbjtcbmA7XG4iXX0= */", process.env.NODE_ENV === "production" ? "" : ";label:listStyle;")
17
35
  );
18
36
  };
19
37
  };
20
38
 
21
- exports.wrapperStyle = wrapperStyle;
39
+ exports.listStyle = listStyle;
@@ -7,7 +7,7 @@ declare const ListItem: React.ForwardRefExoticComponent<{
7
7
  /** Content of the ListItem */
8
8
  content: ListItemType;
9
9
  /** Index, for test-id calculation */
10
- index: number;
10
+ index: number | string;
11
11
  /** Selected state */
12
12
  selected?: boolean | undefined;
13
13
  /** Whether the text of the ListItem is highlighted or not. eg: Filter - Default Value */
@@ -18,5 +18,7 @@ declare const ListItem: React.ForwardRefExoticComponent<{
18
18
  searchTerm?: string | undefined;
19
19
  /** Option Click handler for SelectOption[] data case */
20
20
  handleOptionClick?: SelectHandlerType | undefined;
21
+ /** Determines the left padding */
22
+ isGroupItem?: boolean | undefined;
21
23
  } & TestProps & React.RefAttributes<HTMLDivElement>>;
22
24
  export default ListItem;
@@ -5,7 +5,7 @@ exports["default"] = void 0;
5
5
 
6
6
  var _react = _interopRequireDefault(require("react"));
7
7
 
8
- var _reactHighlightWords = _interopRequireDefault(require("react-highlight-words"));
8
+ var _utils = require("../utils");
9
9
 
10
10
  var _ListItem = require("./ListItem.style");
11
11
 
@@ -25,7 +25,8 @@ var ListItem = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
25
25
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
26
26
  handleOptionClick = _ref.handleOptionClick,
27
27
  searchTerm = _ref.searchTerm,
28
- dataTestId = _ref.dataTestId;
28
+ dataTestId = _ref.dataTestId,
29
+ isGroupItem = _ref.isGroupItem;
29
30
 
30
31
  var handleListItemSelect = function handleListItemSelect() {
31
32
  if (content && handleOptionClick) {
@@ -33,41 +34,13 @@ var ListItem = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
33
34
  }
34
35
  };
35
36
 
36
- var renderContent = function renderContent(content) {
37
- /**
38
- * Check if list item is not react element because it can be
39
- * and also checks if its object with property 'value'
40
- * @TODO Typescript 4.4 will solve this in one constant
41
- * **/
42
- if (searchTerm && content && ! /*#__PURE__*/_react["default"].isValidElement(content) && typeof content === 'object' && !Array.isArray(content) && 'label' in content && content != null && content.label) {
43
- return (0, _react2.jsx)(_reactHighlightWords["default"], {
44
- highlightClassName: "search-text",
45
- highlightTag: 'strong',
46
- searchWords: [searchTerm],
47
- autoEscape: true,
48
- textToHighlight: content.label
49
- });
50
- }
51
- /**
52
- * Check if list item is not react element because it can be
53
- * and also checks if its object with property 'value'
54
- * @TODO Typescript 4.4 will solve this in one constant
55
- * **/
56
-
57
-
58
- if (content && ! /*#__PURE__*/_react["default"].isValidElement(content) && typeof content === 'object' && !Array.isArray(content) && 'label' in content && content != null && content.label) {
59
- return content.label;
60
- }
61
-
62
- return content;
63
- };
64
-
65
37
  return (0, _react2.jsx)("div", {
66
38
  css: (0, _ListItem.listItemStyle)({
67
39
  size: size,
68
40
  selected: selected,
69
41
  highlighted: highlighted,
70
- disabled: disabled
42
+ disabled: disabled,
43
+ isGroupItem: isGroupItem
71
44
  }),
72
45
  ref: selected ? ref : null,
73
46
  onClick: handleListItemSelect,
@@ -79,7 +52,7 @@ var ListItem = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
79
52
  css: (0, _ListItem.contentStyle)()
80
53
  },
81
54
  /** @TODO latest version typescript 4.4 is solving this as a constant */
82
- renderContent(content)));
55
+ (0, _utils.renderContent)(content, searchTerm)));
83
56
  });
84
57
 
85
58
  ListItem.displayName = 'ListItem';
@@ -1,10 +1,11 @@
1
1
  import { SerializedStyles } from '@emotion/react';
2
2
  import { Theme } from 'theme';
3
3
  import { ListRowSize } from '../types';
4
- export declare const listItemStyle: ({ size, selected, highlighted, disabled, }: {
4
+ export declare const listItemStyle: ({ size, selected, highlighted, disabled, isGroupItem, }: {
5
5
  size: ListRowSize;
6
6
  selected: boolean;
7
7
  highlighted: boolean;
8
8
  disabled: boolean;
9
+ isGroupItem?: boolean | undefined;
9
10
  }) => (theme: Theme) => SerializedStyles;
10
11
  export declare const contentStyle: () => SerializedStyles;
@@ -13,13 +13,14 @@ var listItemStyle = function listItemStyle(_ref2) {
13
13
  var size = _ref2.size,
14
14
  selected = _ref2.selected,
15
15
  highlighted = _ref2.highlighted,
16
- disabled = _ref2.disabled;
16
+ disabled = _ref2.disabled,
17
+ isGroupItem = _ref2.isGroupItem;
17
18
  return function (theme) {
18
19
  return (
19
20
  /*#__PURE__*/
20
21
 
21
22
  /*#__PURE__*/
22
- (0, _react.css)("height:", size === 'normal' ? (0, _utils.rem)(56) : (0, _utils.rem)(46), ";font-size:", theme.typography.fontSizes[size === 'normal' ? '16' : '14'], ";background-color:", selected ? theme.utils.getColor('blue', 50) : theme.palette.white, ";display:flex;align-items:center;padding:0px ", theme.spacing.md, ";font-weight:", selected && theme.typography.weights.medium, ";", highlighted && 'font-weight: 500;', " &:hover{background-color:", theme.utils.getColor('lightGrey', 50), ";}", disabled && "\n opacity: 0.5;\n cursor: not-allowed;\n ", ";" + (process.env.NODE_ENV === "production" ? "" : ";label:listItemStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW0vTGlzdEl0ZW0uc3R5bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0I2QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9MaXN0L0xpc3RJdGVtL0xpc3RJdGVtLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IExpc3RSb3dTaXplIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbGlzdEl0ZW1TdHlsZSA9ICh7XG4gIHNpemUsXG4gIHNlbGVjdGVkLFxuICBoaWdobGlnaHRlZCxcbiAgZGlzYWJsZWQsXG59OiB7XG4gIHNpemU6IExpc3RSb3dTaXplO1xuICBzZWxlY3RlZDogYm9vbGVhbjtcbiAgaGlnaGxpZ2h0ZWQ6IGJvb2xlYW47XG4gIGRpc2FibGVkOiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBoZWlnaHQ6ICR7c2l6ZSA9PT0gJ25vcm1hbCcgPyByZW0oNTYpIDogcmVtKDQ2KX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbm9ybWFsJyA/ICcxNicgOiAnMTQnXX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7c2VsZWN0ZWQgPyB0aGVtZS51dGlscy5nZXRDb2xvcignYmx1ZScsIDUwKSA6IHRoZW1lLnBhbGV0dGUud2hpdGV9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiAwcHggJHt0aGVtZS5zcGFjaW5nLm1kfTtcbiAgZm9udC13ZWlnaHQ6ICR7c2VsZWN0ZWQgJiYgdGhlbWUudHlwb2dyYXBoeS53ZWlnaHRzLm1lZGl1bX07XG5cbiAgJHtoaWdobGlnaHRlZCAmJiAnZm9udC13ZWlnaHQ6IDUwMDsnfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDUwKX07XG4gIH1cblxuICAke2Rpc2FibGVkICYmXG4gICAgYFxuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBjb250ZW50U3R5bGUgPSAoKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuYDtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:listItemStyle;")
23
+ (0, _react.css)("height:", size === 'normal' ? (0, _utils.rem)(56) : (0, _utils.rem)(46), ";font-size:", theme.typography.fontSizes[size === 'normal' ? '16' : '14'], ";background-color:", selected ? theme.utils.getColor('blue', 50) : theme.palette.white, ";display:flex;align-items:center;padding:0px ", theme.spacing.md, " 0px ", isGroupItem ? theme.spacing.xl : theme.spacing.md, ";font-weight:", selected && theme.typography.weights.medium, ";", highlighted && 'font-weight: 500;', " &:hover{background-color:", theme.utils.getColor('lightGrey', 50), ";}", disabled && "\n opacity: 0.5;\n cursor: not-allowed;\n ", ";" + (process.env.NODE_ENV === "production" ? "" : ";label:listItemStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW0vTGlzdEl0ZW0uc3R5bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0I2QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9MaXN0L0xpc3RJdGVtL0xpc3RJdGVtLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IExpc3RSb3dTaXplIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbGlzdEl0ZW1TdHlsZSA9ICh7XG4gIHNpemUsXG4gIHNlbGVjdGVkLFxuICBoaWdobGlnaHRlZCxcbiAgZGlzYWJsZWQsXG4gIGlzR3JvdXBJdGVtLFxufToge1xuICBzaXplOiBMaXN0Um93U2l6ZTtcbiAgc2VsZWN0ZWQ6IGJvb2xlYW47XG4gIGhpZ2hsaWdodGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNHcm91cEl0ZW0/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBoZWlnaHQ6ICR7c2l6ZSA9PT0gJ25vcm1hbCcgPyByZW0oNTYpIDogcmVtKDQ2KX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbm9ybWFsJyA/ICcxNicgOiAnMTQnXX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7c2VsZWN0ZWQgPyB0aGVtZS51dGlscy5nZXRDb2xvcignYmx1ZScsIDUwKSA6IHRoZW1lLnBhbGV0dGUud2hpdGV9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiAwcHggJHt0aGVtZS5zcGFjaW5nLm1kfSAwcHggJHtpc0dyb3VwSXRlbSA/IHRoZW1lLnNwYWNpbmcueGwgOiB0aGVtZS5zcGFjaW5nLm1kfTtcbiAgZm9udC13ZWlnaHQ6ICR7c2VsZWN0ZWQgJiYgdGhlbWUudHlwb2dyYXBoeS53ZWlnaHRzLm1lZGl1bX07XG5cbiAgJHtoaWdobGlnaHRlZCAmJiAnZm9udC13ZWlnaHQ6IDUwMDsnfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDUwKX07XG4gIH1cblxuICAke2Rpc2FibGVkICYmXG4gICAgYFxuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBjb250ZW50U3R5bGUgPSAoKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuYDtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:listItemStyle;")
23
24
  );
24
25
  };
25
26
  };
@@ -32,7 +33,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
32
33
  } : {
33
34
  name: "4irdtt-contentStyle",
34
35
  styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis;label:contentStyle;",
35
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW0vTGlzdEl0ZW0uc3R5bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBc0N1RCIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9MaXN0L0xpc3RJdGVtL0xpc3RJdGVtLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IExpc3RSb3dTaXplIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbGlzdEl0ZW1TdHlsZSA9ICh7XG4gIHNpemUsXG4gIHNlbGVjdGVkLFxuICBoaWdobGlnaHRlZCxcbiAgZGlzYWJsZWQsXG59OiB7XG4gIHNpemU6IExpc3RSb3dTaXplO1xuICBzZWxlY3RlZDogYm9vbGVhbjtcbiAgaGlnaGxpZ2h0ZWQ6IGJvb2xlYW47XG4gIGRpc2FibGVkOiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBoZWlnaHQ6ICR7c2l6ZSA9PT0gJ25vcm1hbCcgPyByZW0oNTYpIDogcmVtKDQ2KX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbm9ybWFsJyA/ICcxNicgOiAnMTQnXX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7c2VsZWN0ZWQgPyB0aGVtZS51dGlscy5nZXRDb2xvcignYmx1ZScsIDUwKSA6IHRoZW1lLnBhbGV0dGUud2hpdGV9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiAwcHggJHt0aGVtZS5zcGFjaW5nLm1kfTtcbiAgZm9udC13ZWlnaHQ6ICR7c2VsZWN0ZWQgJiYgdGhlbWUudHlwb2dyYXBoeS53ZWlnaHRzLm1lZGl1bX07XG5cbiAgJHtoaWdobGlnaHRlZCAmJiAnZm9udC13ZWlnaHQ6IDUwMDsnfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDUwKX07XG4gIH1cblxuICAke2Rpc2FibGVkICYmXG4gICAgYFxuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBjb250ZW50U3R5bGUgPSAoKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuYDtcbiJdfQ== */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW0vTGlzdEl0ZW0uc3R5bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0N1RCIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9MaXN0L0xpc3RJdGVtL0xpc3RJdGVtLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IExpc3RSb3dTaXplIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbGlzdEl0ZW1TdHlsZSA9ICh7XG4gIHNpemUsXG4gIHNlbGVjdGVkLFxuICBoaWdobGlnaHRlZCxcbiAgZGlzYWJsZWQsXG4gIGlzR3JvdXBJdGVtLFxufToge1xuICBzaXplOiBMaXN0Um93U2l6ZTtcbiAgc2VsZWN0ZWQ6IGJvb2xlYW47XG4gIGhpZ2hsaWdodGVkOiBib29sZWFuO1xuICBkaXNhYmxlZDogYm9vbGVhbjtcbiAgaXNHcm91cEl0ZW0/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBoZWlnaHQ6ICR7c2l6ZSA9PT0gJ25vcm1hbCcgPyByZW0oNTYpIDogcmVtKDQ2KX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbm9ybWFsJyA/ICcxNicgOiAnMTQnXX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7c2VsZWN0ZWQgPyB0aGVtZS51dGlscy5nZXRDb2xvcignYmx1ZScsIDUwKSA6IHRoZW1lLnBhbGV0dGUud2hpdGV9O1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBwYWRkaW5nOiAwcHggJHt0aGVtZS5zcGFjaW5nLm1kfSAwcHggJHtpc0dyb3VwSXRlbSA/IHRoZW1lLnNwYWNpbmcueGwgOiB0aGVtZS5zcGFjaW5nLm1kfTtcbiAgZm9udC13ZWlnaHQ6ICR7c2VsZWN0ZWQgJiYgdGhlbWUudHlwb2dyYXBoeS53ZWlnaHRzLm1lZGl1bX07XG5cbiAgJHtoaWdobGlnaHRlZCAmJiAnZm9udC13ZWlnaHQ6IDUwMDsnfVxuXG4gICY6aG92ZXIge1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUudXRpbHMuZ2V0Q29sb3IoJ2xpZ2h0R3JleScsIDUwKX07XG4gIH1cblxuICAke2Rpc2FibGVkICYmXG4gICAgYFxuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBjb250ZW50U3R5bGUgPSAoKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuYDtcbiJdfQ== */",
36
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
37
38
  };
38
39
 
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ import { TestProps } from 'utils/types';
3
+ import { ListItemType, ListRowSize } from 'components/List/types';
4
+ declare const ListGroupTitle: React.ForwardRefExoticComponent<{
5
+ /** Size of the ListGroupTitle (translates to height) */
6
+ size: ListRowSize;
7
+ /** Content of the ListItem */
8
+ content: ListItemType;
9
+ /** Index, for test-id calculation */
10
+ index: number;
11
+ /** Search Term to be highlighted in list items */
12
+ searchTerm?: string | undefined;
13
+ } & TestProps & React.RefAttributes<HTMLDivElement>>;
14
+ export default ListGroupTitle;
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _react = _interopRequireDefault(require("react"));
7
+
8
+ var _ListGroupTitle = require("./ListGroupTitle.style");
9
+
10
+ var _utils = require("../../utils");
11
+
12
+ var _react2 = require("@emotion/react");
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
15
+
16
+ var ListGroupTitle = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
17
+ var size = _ref.size,
18
+ content = _ref.content,
19
+ index = _ref.index,
20
+ searchTerm = _ref.searchTerm,
21
+ dataTestId = _ref.dataTestId;
22
+ return (0, _react2.jsx)("div", {
23
+ css: (0, _ListGroupTitle.listGroupTitleStyle)({
24
+ size: size,
25
+ disabled: content.isDisabled
26
+ }),
27
+ ref: ref,
28
+ "data-testid": dataTestId != null ? dataTestId : 'ictinus_list' + ('_group_title_' + index)
29
+ }, (0, _react2.jsx)("div", {
30
+ css: (0, _ListGroupTitle.contentStyle)()
31
+ }, (0, _utils.renderContent)(content, searchTerm)));
32
+ });
33
+
34
+ ListGroupTitle.displayName = 'ListGroupTitle';
35
+ var _default = ListGroupTitle;
36
+ exports["default"] = _default;
@@ -0,0 +1,8 @@
1
+ import { SerializedStyles } from '@emotion/react';
2
+ import { Theme } from 'theme';
3
+ import { ListRowSize } from '../../types';
4
+ export declare const listGroupTitleStyle: ({ size, disabled, }: {
5
+ size: ListRowSize;
6
+ disabled?: boolean | undefined;
7
+ }) => (theme: Theme) => SerializedStyles;
8
+ export declare const contentStyle: () => SerializedStyles;
@@ -0,0 +1,41 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.contentStyle = exports.listGroupTitleStyle = void 0;
5
+
6
+ var _react = require("@emotion/react");
7
+
8
+ var _utils = require("../../../../theme/utils");
9
+
10
+ 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)."; }
11
+
12
+ var listGroupTitleStyle = function listGroupTitleStyle(_ref2) {
13
+ var size = _ref2.size,
14
+ disabled = _ref2.disabled;
15
+ return function (theme) {
16
+ return (
17
+ /*#__PURE__*/
18
+
19
+ /*#__PURE__*/
20
+ (0, _react.css)("height:", size === 'normal' ? (0, _utils.rem)(56) : (0, _utils.rem)(46), ";font-size:", theme.typography.fontSizes[size === 'normal' ? '13' : '11'], ";background-color:", theme.palette.white, ";color:", theme.utils.getColor('lightGrey', 650), ";display:flex;align-items:center;padding:0px ", theme.spacing.md, ";font-weight:", theme.typography.weights.bold, ";", disabled && "\n opacity: 0.5;\n cursor: not-allowed;\n ", ";" + (process.env.NODE_ENV === "production" ? "" : ";label:listGroupTitleStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW1Hcm91cC9MaXN0R3JvdXBUaXRsZS9MaXN0R3JvdXBUaXRsZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFZNkMiLCJmaWxlIjoiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvTGlzdC9MaXN0SXRlbUdyb3VwL0xpc3RHcm91cFRpdGxlL0xpc3RHcm91cFRpdGxlLnN0eWxlLnRzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3NzLCBTZXJpYWxpemVkU3R5bGVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgVGhlbWUgfSBmcm9tICd0aGVtZSc7XG5pbXBvcnQgeyByZW0gfSBmcm9tICd0aGVtZS91dGlscyc7XG5cbmltcG9ydCB7IExpc3RSb3dTaXplIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgbGlzdEdyb3VwVGl0bGVTdHlsZSA9ICh7XG4gIHNpemUsXG4gIGRpc2FibGVkLFxufToge1xuICBzaXplOiBMaXN0Um93U2l6ZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBoZWlnaHQ6ICR7c2l6ZSA9PT0gJ25vcm1hbCcgPyByZW0oNTYpIDogcmVtKDQ2KX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmZvbnRTaXplc1tzaXplID09PSAnbm9ybWFsJyA/ICcxMycgOiAnMTEnXX07XG4gIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUucGFsZXR0ZS53aGl0ZX07XG4gIGNvbG9yOiAke3RoZW1lLnV0aWxzLmdldENvbG9yKCdsaWdodEdyZXknLCA2NTApfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogMHB4ICR7dGhlbWUuc3BhY2luZy5tZH07XG4gIGZvbnQtd2VpZ2h0OiAke3RoZW1lLnR5cG9ncmFwaHkud2VpZ2h0cy5ib2xkfTtcblxuICAke2Rpc2FibGVkICYmXG4gICAgYFxuICAgICAgICBvcGFjaXR5OiAwLjU7XG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBjb250ZW50U3R5bGUgPSAoKTogU2VyaWFsaXplZFN0eWxlcyA9PiBjc3NgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuYDtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:listGroupTitleStyle;")
21
+ );
22
+ };
23
+ };
24
+
25
+ exports.listGroupTitleStyle = listGroupTitleStyle;
26
+
27
+ var _ref = process.env.NODE_ENV === "production" ? {
28
+ name: "l8l8b8",
29
+ styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis"
30
+ } : {
31
+ name: "4irdtt-contentStyle",
32
+ styles: "white-space:nowrap;overflow:hidden;text-overflow:ellipsis;label:contentStyle;",
33
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW1Hcm91cC9MaXN0R3JvdXBUaXRsZS9MaXN0R3JvdXBUaXRsZS5zdHlsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUE2QnVEIiwiZmlsZSI6Ii4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTGlzdEl0ZW1Hcm91cC9MaXN0R3JvdXBUaXRsZS9MaXN0R3JvdXBUaXRsZS5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IFRoZW1lIH0gZnJvbSAndGhlbWUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAndGhlbWUvdXRpbHMnO1xuXG5pbXBvcnQgeyBMaXN0Um93U2l6ZSB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGxpc3RHcm91cFRpdGxlU3R5bGUgPSAoe1xuICBzaXplLFxuICBkaXNhYmxlZCxcbn06IHtcbiAgc2l6ZTogTGlzdFJvd1NpemU7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbn0pID0+ICh0aGVtZTogVGhlbWUpOiBTZXJpYWxpemVkU3R5bGVzID0+IGNzc2BcbiAgaGVpZ2h0OiAke3NpemUgPT09ICdub3JtYWwnID8gcmVtKDU2KSA6IHJlbSg0Nil9O1xuICBmb250LXNpemU6ICR7dGhlbWUudHlwb2dyYXBoeS5mb250U2l6ZXNbc2l6ZSA9PT0gJ25vcm1hbCcgPyAnMTMnIDogJzExJ119O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3RoZW1lLnBhbGV0dGUud2hpdGV9O1xuICBjb2xvcjogJHt0aGVtZS51dGlscy5nZXRDb2xvcignbGlnaHRHcmV5JywgNjUwKX07XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIHBhZGRpbmc6IDBweCAke3RoZW1lLnNwYWNpbmcubWR9O1xuICBmb250LXdlaWdodDogJHt0aGVtZS50eXBvZ3JhcGh5LndlaWdodHMuYm9sZH07XG5cbiAgJHtkaXNhYmxlZCAmJlxuICAgIGBcbiAgICAgICAgb3BhY2l0eTogMC41O1xuICAgICAgICBjdXJzb3I6IG5vdC1hbGxvd2VkO1xuICAgIGB9XG5gO1xuXG5leHBvcnQgY29uc3QgY29udGVudFN0eWxlID0gKCk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBvdmVyZmxvdzogaGlkZGVuO1xuICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbmA7XG4iXX0= */",
34
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
35
+ };
36
+
37
+ var contentStyle = function contentStyle() {
38
+ return _ref;
39
+ };
40
+
41
+ exports.contentStyle = contentStyle;
@@ -0,0 +1 @@
1
+ export { default } from './ListGroupTitle';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _ListGroupTitle = _interopRequireDefault(require("./ListGroupTitle"));
7
+
8
+ exports["default"] = _ListGroupTitle["default"];
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import { TestProps } from 'utils/types';
3
+ import { ListItemType, ListRowSize, SelectHandlerType } from '../types';
4
+ declare const ListItemGroup: React.ForwardRefExoticComponent<{
5
+ /** Size of the ListItem (translates to height) */
6
+ size: ListRowSize;
7
+ /** Content of the ListItemGroup */
8
+ content: ListItemType;
9
+ /** groupIndex, for test-id calculation */
10
+ groupIndex: number;
11
+ /** Selected Item */
12
+ selectedItem?: ListItemType;
13
+ /** Search Term to be highlighted in list items */
14
+ searchTerm?: string | undefined;
15
+ /** Option Click handler for SelectOption[] data case */
16
+ handleOptionClick?: SelectHandlerType | undefined;
17
+ } & TestProps & React.RefAttributes<HTMLDivElement>>;
18
+ export default ListItemGroup;
@@ -0,0 +1,64 @@
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 _List = require("../List.style");
11
+
12
+ var _ListItem = _interopRequireDefault(require("../ListItem"));
13
+
14
+ var _utils = require("../utils");
15
+
16
+ var _ListGroupTitle = _interopRequireDefault(require("./ListGroupTitle"));
17
+
18
+ var _react2 = require("@emotion/react");
19
+
20
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
21
+
22
+ var ListItemGroup = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
23
+ var _options;
24
+
25
+ var size = _ref.size,
26
+ content = _ref.content,
27
+ groupIndex = _ref.groupIndex,
28
+ selectedItem = _ref.selectedItem,
29
+ searchTerm = _ref.searchTerm,
30
+ handleOptionClick = _ref.handleOptionClick,
31
+ dataTestId = _ref.dataTestId;
32
+ return (0, _react2.jsx)("li", null, (0, _react2.jsx)(_ListGroupTitle["default"], {
33
+ content: content,
34
+ size: size,
35
+ index: groupIndex,
36
+ ref: ref,
37
+ searchTerm: searchTerm,
38
+ dataTestId: dataTestId
39
+ }), (0, _react2.jsx)("ul", {
40
+ css: (0, _List.listStyle)({})
41
+ }, (_options = content.options) == null ? void 0 : _options.map(function (option, index) {
42
+ return (0, _react2.jsx)("li", {
43
+ key: (0, _helpers.generateUniqueID)('list_item' + groupIndex + index)
44
+ }, (0, _react2.jsx)(_ListItem["default"], {
45
+ content: option,
46
+ size: size,
47
+ index: '' + groupIndex + index,
48
+ ref: ref,
49
+ searchTerm: searchTerm,
50
+ disabled: option == null ? void 0 : option.isDisabled,
51
+ dataTestId: dataTestId,
52
+ handleOptionClick: handleOptionClick,
53
+ selected: (0, _utils.isSelected)({
54
+ item: option,
55
+ selectedItem: selectedItem
56
+ }),
57
+ isGroupItem: true
58
+ }));
59
+ })));
60
+ });
61
+
62
+ ListItemGroup.displayName = 'ListItemGroup';
63
+ var _default = ListItemGroup;
64
+ exports["default"] = _default;
@@ -0,0 +1 @@
1
+ export { default } from './ListItemGroup';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _ListItemGroup = _interopRequireDefault(require("./ListItemGroup"));
7
+
8
+ exports["default"] = _ListItemGroup["default"];
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
@@ -9,11 +9,13 @@ var _react = _interopRequireDefault(require("react"));
9
9
 
10
10
  var _helpers = require("../../../utils/helpers");
11
11
 
12
+ var _List = require("../List.style");
13
+
12
14
  var _ListItem = _interopRequireDefault(require("../ListItem"));
13
15
 
14
- var _utils = require("../utils");
16
+ var _ListItemGroup = _interopRequireDefault(require("../ListItemGroup"));
15
17
 
16
- var _NormalList = require("./NormalList.style");
18
+ var _utils = require("../utils");
17
19
 
18
20
  var _react2 = require("@emotion/react");
19
21
 
@@ -34,13 +36,22 @@ var NormalList = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref)
34
36
  return (0, _react2.jsx)("div", {
35
37
  "data-testid": dataTestId ? dataTestId + "_list" : 'ictinus_list'
36
38
  }, (0, _react2.jsx)("ul", {
37
- css: (0, _NormalList.listStyle)({
39
+ css: (0, _List.listStyle)({
38
40
  width: width,
39
41
  height: height,
40
42
  isSearchable: isSearchable
41
43
  })
42
44
  }, newItems.map(function (item, index) {
43
- return (0, _react2.jsx)("li", {
45
+ return item != null && item.options ? (0, _react2.jsx)(_ListItemGroup["default"], {
46
+ content: item,
47
+ size: rowSize,
48
+ groupIndex: index,
49
+ ref: ref,
50
+ searchTerm: searchTerm,
51
+ dataTestId: dataTestId,
52
+ handleOptionClick: handleOptionClick,
53
+ selectedItem: selectedItem
54
+ }) : (0, _react2.jsx)("li", {
44
55
  key: (0, _helpers.generateUniqueID)('list_item' + index)
45
56
  }, (0, _react2.jsx)(_ListItem["default"], {
46
57
  content: item,
@@ -1,7 +0,0 @@
1
- import { SerializedStyles } from '@emotion/react';
2
- import { Theme } from 'theme';
3
- export declare const listStyle: ({ width, height, isSearchable, }: {
4
- width?: number | undefined;
5
- height?: number | undefined;
6
- isSearchable?: boolean | undefined;
7
- }) => (theme: Theme) => SerializedStyles;
@@ -1,24 +1 @@
1
- "use strict";
2
-
3
- exports.__esModule = true;
4
- exports.listStyle = void 0;
5
-
6
- var _react = require("@emotion/react");
7
-
8
- var _utils = require("../../../theme/utils");
9
-
10
- var listStyle = function listStyle(_ref) {
11
- var width = _ref.width,
12
- height = _ref.height,
13
- isSearchable = _ref.isSearchable;
14
- return function (theme) {
15
- return (
16
- /*#__PURE__*/
17
-
18
- /*#__PURE__*/
19
- (0, _react.css)("padding-left:0;margin-top:0;margin-bottom:0;border-radius:", isSearchable ? 'initial' : theme.spacing.xsm, ";width:", width ? (0, _utils.rem)(width) : '100%', ";height:", height ? (0, _utils.rem)(height) : '100%', ";overflow:auto;overflow-x:hidden;" + (process.env.NODE_ENV === "production" ? "" : ";label:listStyle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvTm9ybWFsTGlzdC9Ob3JtYWxMaXN0LnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVk2QyIsImZpbGUiOiIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9MaXN0L05vcm1hbExpc3QvTm9ybWFsTGlzdC5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcywgU2VyaWFsaXplZFN0eWxlcyB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcbmltcG9ydCB7IFRoZW1lIH0gZnJvbSAndGhlbWUnO1xuaW1wb3J0IHsgcmVtIH0gZnJvbSAndGhlbWUvdXRpbHMnO1xuXG5leHBvcnQgY29uc3QgbGlzdFN0eWxlID0gKHtcbiAgd2lkdGgsXG4gIGhlaWdodCxcbiAgaXNTZWFyY2hhYmxlLFxufToge1xuICB3aWR0aD86IG51bWJlcjtcbiAgaGVpZ2h0PzogbnVtYmVyO1xuICBpc1NlYXJjaGFibGU/OiBib29sZWFuO1xufSkgPT4gKHRoZW1lOiBUaGVtZSk6IFNlcmlhbGl6ZWRTdHlsZXMgPT4gY3NzYFxuICBwYWRkaW5nLWxlZnQ6IDA7XG4gIG1hcmdpbi10b3A6IDA7XG4gIG1hcmdpbi1ib3R0b206IDA7XG4gIGJvcmRlci1yYWRpdXM6ICR7aXNTZWFyY2hhYmxlID8gJ2luaXRpYWwnIDogdGhlbWUuc3BhY2luZy54c219O1xuICB3aWR0aDogJHt3aWR0aCA/IHJlbSh3aWR0aCkgOiAnMTAwJSd9O1xuICBoZWlnaHQ6ICR7aGVpZ2h0ID8gcmVtKGhlaWdodCkgOiAnMTAwJSd9O1xuICBvdmVyZmxvdzogYXV0bztcbiAgb3ZlcmZsb3cteDogaGlkZGVuO1xuYDtcbiJdfQ== */", process.env.NODE_ENV === "production" ? "" : ";label:listStyle;")
20
- );
21
- };
22
- };
23
-
24
- exports.listStyle = listStyle;
1
+ "use strict";
@@ -9,8 +9,12 @@ var _react2 = _interopRequireWildcard(require("react"));
9
9
 
10
10
  var _reactWindow = require("react-window");
11
11
 
12
+ var _List = require("../List.style");
13
+
12
14
  var _ListItem = _interopRequireDefault(require("../ListItem"));
13
15
 
16
+ var _ListItemGroup = _interopRequireDefault(require("../ListItemGroup"));
17
+
14
18
  var _utils = require("../utils");
15
19
 
16
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
@@ -29,7 +33,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
29
33
  } : {
30
34
  name: "pczpeh-VirtualizedList",
31
35
  styles: "overflow-x:hidden;label:VirtualizedList;",
32
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEVRIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IEZpeGVkU2l6ZUxpc3QgYXMgVkxpc3QgfSBmcm9tICdyZWFjdC13aW5kb3cnO1xuaW1wb3J0IHsgQ1NTUHJvcGVydGllcyB9IGZyb20gJ3N0eWxlZC1jb21wb25lbnRzJztcbmltcG9ydCB7IFRlc3RQcm9wcyB9IGZyb20gJ3V0aWxzL3R5cGVzJztcblxuaW1wb3J0IHsgU2VsZWN0T3B0aW9uIH0gZnJvbSAnLi4vLi4vU2VsZWN0L1NlbGVjdCc7XG5pbXBvcnQgTGlzdEl0ZW0gZnJvbSAnLi4vTGlzdEl0ZW0nO1xuaW1wb3J0IHsgTGlzdEl0ZW1UeXBlLCBMaXN0Um93U2l6ZSwgU2VsZWN0SGFuZGxlclR5cGUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBpc1NlbGVjdGVkLCBNQVhfTEFSR0VfSEVJR0hULCBNQVhfU01BTExfSEVJR0hUIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG50eXBlIFByb3BzID0ge1xuICBpdGVtczogTGlzdEl0ZW1UeXBlW107XG4gIC8qKiBTaXplIG9mIHRoZSBsaXN0J3Mgcm93IChoZWlnaHQgb2YgTGlzdEl0ZW0gQ29tcG9uZW50KSAgKi9cbiAgcm93U2l6ZTogTGlzdFJvd1NpemU7XG4gIC8qKiBXaWR0aCBvZiB0aGUgbGlzdCAqL1xuICBjdXN0b21XaWR0aD86IG51bWJlcjtcbiAgLyoqIEhlaWdodCBvZiB0aGUgbGlzdCAqL1xuICBjdXN0b21IZWlnaHQ/OiBudW1iZXI7XG4gIC8qKiBTZWxlY3RlZCBJdGVtICovXG4gIHNlbGVjdGVkSXRlbT86IExpc3RJdGVtVHlwZTtcbiAgLyoqIERlZmF1bHQgb3B0aW9uLiBSZW5kZXJzIG9uIHRvcCBvZiB0aGUgbGlzdCwgaGlnaGxpZ2h0ZWQgKi9cbiAgZGVmYXVsdE9wdGlvbj86IExpc3RJdGVtVHlwZTtcbiAgLyoqIFNlYXJjaCBUZXJtIHRvIGJlIGhpZ2hsaWdodGVkIGluIGxpc3QgaXRlbXMgKi9cbiAgc2VhcmNoVGVybT86IHN0cmluZztcbiAgLyoqIE9wdGlvbiBDbGljayBoYW5kbGVyIGZvciBTZWxlY3RPcHRpb25bXSBkYXRhIGNhc2UgKi9cbiAgaGFuZGxlT3B0aW9uQ2xpY2s/OiBTZWxlY3RIYW5kbGVyVHlwZTtcbn0gJiBUZXN0UHJvcHM7XG5cbmNvbnN0IFZpcnR1YWxpemVkTGlzdCA9IFJlYWN0LmZvcndhcmRSZWY8SFRNTERpdkVsZW1lbnQsIFByb3BzPihcbiAgKFxuICAgIHtcbiAgICAgIGl0ZW1zLFxuICAgICAgY3VzdG9tV2lkdGgsXG4gICAgICBjdXN0b21IZWlnaHQsXG4gICAgICByb3dTaXplLFxuICAgICAgc2VsZWN0ZWRJdGVtLFxuICAgICAgZGVmYXVsdE9wdGlvbixcbiAgICAgIHNlYXJjaFRlcm0sXG4gICAgICBoYW5kbGVPcHRpb25DbGljayxcbiAgICAgIGRhdGFUZXN0SWQsXG4gICAgfSxcbiAgICByZWZcbiAgKSA9PiB7XG4gICAgY29uc3QgZGF0YSA9IHVzZU1lbW8oKCkgPT4gKGRlZmF1bHRPcHRpb24gPyBbZGVmYXVsdE9wdGlvbiwgLi4uaXRlbXNdIDogaXRlbXMpLCBbXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgaXRlbXMsXG4gICAgXSk7XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgIHNpemU9e3Jvd1NpemV9XG4gICAgICAgICAgICBjb250ZW50PXtkYXRhW2luZGV4XX1cbiAgICAgICAgICAgIGluZGV4PXtpbmRleH1cbiAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgZGlzYWJsZWQ9eyhkYXRhW2luZGV4XSBhcyBTZWxlY3RPcHRpb24pPy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgc2VsZWN0ZWQ9e2lzU2VsZWN0ZWQoeyBpdGVtOiBkYXRhW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGRhdGFUZXN0SWQ9e2RhdGFUZXN0SWQgKyBgJHtkZWZhdWx0T3B0aW9uICYmIGluZGV4ID09PSAwICYmICdkZWZhdWx0J31gfVxuICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17ZGF0YS5sZW5ndGh9XG4gICAgICAgIGl0ZW1TaXplPXtyb3dTaXplID09PSAnbm9ybWFsJyA/IDU2IDogNDZ9XG4gICAgICAgIGNzcz17eyBvdmVyZmxvd1g6ICdoaWRkZW4nIH19XG4gICAgICA+XG4gICAgICAgIHtyb3dSZW5kZXJlcn1cbiAgICAgIDwvVkxpc3Q+XG4gICAgKTtcbiAgfVxuKTtcblZpcnR1YWxpemVkTGlzdC5kaXNwbGF5TmFtZSA9ICdWaXJ0dWFsaXplZExpc3QnO1xuXG5leHBvcnQgZGVmYXVsdCBWaXJ0dWFsaXplZExpc3Q7XG4iXX0= */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUdRIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBWYXJpYWJsZVNpemVMaXN0IGFzIFZMaXN0IH0gZnJvbSAncmVhY3Qtd2luZG93JztcbmltcG9ydCB7IENTU1Byb3BlcnRpZXMgfSBmcm9tICdzdHlsZWQtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBUZXN0UHJvcHMgfSBmcm9tICd1dGlscy90eXBlcyc7XG5cbmltcG9ydCB7IFNlbGVjdE9wdGlvbiB9IGZyb20gJy4uLy4uL1NlbGVjdC9TZWxlY3QnO1xuaW1wb3J0IHsgbGlzdFN0eWxlIH0gZnJvbSAnLi4vTGlzdC5zdHlsZSc7XG5pbXBvcnQgTGlzdEl0ZW0gZnJvbSAnLi4vTGlzdEl0ZW0nO1xuaW1wb3J0IExpc3RJdGVtR3JvdXAgZnJvbSAnLi4vTGlzdEl0ZW1Hcm91cCc7XG5pbXBvcnQgeyBMaXN0SXRlbVR5cGUsIExpc3RSb3dTaXplLCBTZWxlY3RIYW5kbGVyVHlwZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGlzU2VsZWN0ZWQsIE1BWF9MQVJHRV9IRUlHSFQsIE1BWF9TTUFMTF9IRUlHSFQgfSBmcm9tICcuLi91dGlscyc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGl0ZW1zOiBMaXN0SXRlbVR5cGVbXTtcbiAgLyoqIFNpemUgb2YgdGhlIGxpc3QncyByb3cgKGhlaWdodCBvZiBMaXN0SXRlbSBDb21wb25lbnQpICAqL1xuICByb3dTaXplOiBMaXN0Um93U2l6ZTtcbiAgLyoqIFdpZHRoIG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbVdpZHRoPzogbnVtYmVyO1xuICAvKiogSGVpZ2h0IG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbUhlaWdodD86IG51bWJlcjtcbiAgLyoqIFNlbGVjdGVkIEl0ZW0gKi9cbiAgc2VsZWN0ZWRJdGVtPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogRGVmYXVsdCBvcHRpb24uIFJlbmRlcnMgb24gdG9wIG9mIHRoZSBsaXN0LCBoaWdobGlnaHRlZCAqL1xuICBkZWZhdWx0T3B0aW9uPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogU2VhcmNoIFRlcm0gdG8gYmUgaGlnaGxpZ2h0ZWQgaW4gbGlzdCBpdGVtcyAqL1xuICBzZWFyY2hUZXJtPzogc3RyaW5nO1xuICAvKiogT3B0aW9uIENsaWNrIGhhbmRsZXIgZm9yIFNlbGVjdE9wdGlvbltdIGRhdGEgY2FzZSAqL1xuICBoYW5kbGVPcHRpb25DbGljaz86IFNlbGVjdEhhbmRsZXJUeXBlO1xufSAmIFRlc3RQcm9wcztcblxuY29uc3QgVmlydHVhbGl6ZWRMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgICBjdXN0b21XaWR0aCxcbiAgICAgIGN1c3RvbUhlaWdodCxcbiAgICAgIHJvd1NpemUsXG4gICAgICBzZWxlY3RlZEl0ZW0sXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgc2VhcmNoVGVybSxcbiAgICAgIGhhbmRsZU9wdGlvbkNsaWNrLFxuICAgICAgZGF0YVRlc3RJZCxcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBjb25zdCBkYXRhID0gdXNlTWVtbygoKSA9PiAoZGVmYXVsdE9wdGlvbiA/IFtkZWZhdWx0T3B0aW9uLCAuLi5pdGVtc10gOiBpdGVtcyksIFtcbiAgICAgIGRlZmF1bHRPcHRpb24sXG4gICAgICBpdGVtcyxcbiAgICBdKTtcblxuICAgIGNvbnN0IGl0ZW1TaXplID0gdXNlQ2FsbGJhY2soKGluZGV4OiBudW1iZXIpID0+IHtcbiAgICAgIGNvbnN0IHNpemVCYXNlID0gcm93U2l6ZSA9PT0gJ25vcm1hbCcgPyA1NiA6IDQ2O1xuXG4gICAgICBpZiAoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMpIHtcbiAgICAgICAgcmV0dXJuICgoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnM/Lmxlbmd0aCBhcyBudW1iZXIpICsgMSkgKiBzaXplQmFzZTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNpemVCYXNlO1xuICAgIH0sIFtkYXRhLCByb3dTaXplXSk7XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICB7KGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMgPyAoXG4gICAgICAgICAgICA8dWwgY3NzPXtsaXN0U3R5bGUoe30pfT5cbiAgICAgICAgICAgICAgPExpc3RJdGVtR3JvdXBcbiAgICAgICAgICAgICAgICBzaXplPXtyb3dTaXplfVxuICAgICAgICAgICAgICAgIGNvbnRlbnQ9e2RhdGFbaW5kZXhdfVxuICAgICAgICAgICAgICAgIGdyb3VwSW5kZXg9e2luZGV4fVxuICAgICAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgICAgIHNlYXJjaFRlcm09e3NlYXJjaFRlcm19XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgICAgICAgc2VsZWN0ZWRJdGVtPXtzZWxlY3RlZEl0ZW19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L3VsPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgICAgc2l6ZT17cm93U2l6ZX1cbiAgICAgICAgICAgICAgY29udGVudD17ZGF0YVtpbmRleF19XG4gICAgICAgICAgICAgIGluZGV4PXtpbmRleH1cbiAgICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXsoZGF0YVtpbmRleF0gYXMgU2VsZWN0T3B0aW9uKT8uaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgc2VsZWN0ZWQ9e2lzU2VsZWN0ZWQoeyBpdGVtOiBkYXRhW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgICBkYXRhVGVzdElkPXtkYXRhVGVzdElkICsgYCR7ZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCAmJiAnZGVmYXVsdCd9YH1cbiAgICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICAgIGhhbmRsZU9wdGlvbkNsaWNrPXtoYW5kbGVPcHRpb25DbGlja31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17ZGF0YS5sZW5ndGh9XG4gICAgICAgIGl0ZW1TaXplPXtpdGVtU2l6ZX1cbiAgICAgICAgY3NzPXt7IG92ZXJmbG93WDogJ2hpZGRlbicgfX1cbiAgICAgID5cbiAgICAgICAge3Jvd1JlbmRlcmVyfVxuICAgICAgPC9WTGlzdD5cbiAgICApO1xuICB9XG4pO1xuVmlydHVhbGl6ZWRMaXN0LmRpc3BsYXlOYW1lID0gJ1ZpcnR1YWxpemVkTGlzdCc7XG5cbmV4cG9ydCBkZWZhdWx0IFZpcnR1YWxpemVkTGlzdDtcbiJdfQ== */",
33
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
34
38
  };
35
39
 
@@ -46,20 +50,44 @@ var VirtualizedList = /*#__PURE__*/_react2["default"].forwardRef(function (_ref,
46
50
  var data = (0, _react2.useMemo)(function () {
47
51
  return defaultOption ? [defaultOption].concat(items) : items;
48
52
  }, [defaultOption, items]);
53
+ var itemSize = (0, _react2.useCallback)(function (index) {
54
+ var _data$index;
55
+
56
+ var sizeBase = rowSize === 'normal' ? 56 : 46;
57
+
58
+ if ((_data$index = data[index]) != null && _data$index.options) {
59
+ var _data$index2, _data$index2$options;
60
+
61
+ return (((_data$index2 = data[index]) == null ? void 0 : (_data$index2$options = _data$index2.options) == null ? void 0 : _data$index2$options.length) + 1) * sizeBase;
62
+ }
63
+
64
+ return sizeBase;
65
+ }, [data, rowSize]);
49
66
 
50
67
  var rowRenderer = function rowRenderer(_ref2) {
51
- var _data$index;
68
+ var _data$index3, _data$index4;
52
69
 
53
70
  var index = _ref2.index,
54
71
  style = _ref2.style;
55
72
  return (0, _react.jsx)("span", {
56
- css: /*#__PURE__*/(0, _react.css)(_extends({}, style), process.env.NODE_ENV === "production" ? "" : ";label:rowRenderer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0RjIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IEZpeGVkU2l6ZUxpc3QgYXMgVkxpc3QgfSBmcm9tICdyZWFjdC13aW5kb3cnO1xuaW1wb3J0IHsgQ1NTUHJvcGVydGllcyB9IGZyb20gJ3N0eWxlZC1jb21wb25lbnRzJztcbmltcG9ydCB7IFRlc3RQcm9wcyB9IGZyb20gJ3V0aWxzL3R5cGVzJztcblxuaW1wb3J0IHsgU2VsZWN0T3B0aW9uIH0gZnJvbSAnLi4vLi4vU2VsZWN0L1NlbGVjdCc7XG5pbXBvcnQgTGlzdEl0ZW0gZnJvbSAnLi4vTGlzdEl0ZW0nO1xuaW1wb3J0IHsgTGlzdEl0ZW1UeXBlLCBMaXN0Um93U2l6ZSwgU2VsZWN0SGFuZGxlclR5cGUgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBpc1NlbGVjdGVkLCBNQVhfTEFSR0VfSEVJR0hULCBNQVhfU01BTExfSEVJR0hUIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG50eXBlIFByb3BzID0ge1xuICBpdGVtczogTGlzdEl0ZW1UeXBlW107XG4gIC8qKiBTaXplIG9mIHRoZSBsaXN0J3Mgcm93IChoZWlnaHQgb2YgTGlzdEl0ZW0gQ29tcG9uZW50KSAgKi9cbiAgcm93U2l6ZTogTGlzdFJvd1NpemU7XG4gIC8qKiBXaWR0aCBvZiB0aGUgbGlzdCAqL1xuICBjdXN0b21XaWR0aD86IG51bWJlcjtcbiAgLyoqIEhlaWdodCBvZiB0aGUgbGlzdCAqL1xuICBjdXN0b21IZWlnaHQ/OiBudW1iZXI7XG4gIC8qKiBTZWxlY3RlZCBJdGVtICovXG4gIHNlbGVjdGVkSXRlbT86IExpc3RJdGVtVHlwZTtcbiAgLyoqIERlZmF1bHQgb3B0aW9uLiBSZW5kZXJzIG9uIHRvcCBvZiB0aGUgbGlzdCwgaGlnaGxpZ2h0ZWQgKi9cbiAgZGVmYXVsdE9wdGlvbj86IExpc3RJdGVtVHlwZTtcbiAgLyoqIFNlYXJjaCBUZXJtIHRvIGJlIGhpZ2hsaWdodGVkIGluIGxpc3QgaXRlbXMgKi9cbiAgc2VhcmNoVGVybT86IHN0cmluZztcbiAgLyoqIE9wdGlvbiBDbGljayBoYW5kbGVyIGZvciBTZWxlY3RPcHRpb25bXSBkYXRhIGNhc2UgKi9cbiAgaGFuZGxlT3B0aW9uQ2xpY2s/OiBTZWxlY3RIYW5kbGVyVHlwZTtcbn0gJiBUZXN0UHJvcHM7XG5cbmNvbnN0IFZpcnR1YWxpemVkTGlzdCA9IFJlYWN0LmZvcndhcmRSZWY8SFRNTERpdkVsZW1lbnQsIFByb3BzPihcbiAgKFxuICAgIHtcbiAgICAgIGl0ZW1zLFxuICAgICAgY3VzdG9tV2lkdGgsXG4gICAgICBjdXN0b21IZWlnaHQsXG4gICAgICByb3dTaXplLFxuICAgICAgc2VsZWN0ZWRJdGVtLFxuICAgICAgZGVmYXVsdE9wdGlvbixcbiAgICAgIHNlYXJjaFRlcm0sXG4gICAgICBoYW5kbGVPcHRpb25DbGljayxcbiAgICAgIGRhdGFUZXN0SWQsXG4gICAgfSxcbiAgICByZWZcbiAgKSA9PiB7XG4gICAgY29uc3QgZGF0YSA9IHVzZU1lbW8oKCkgPT4gKGRlZmF1bHRPcHRpb24gPyBbZGVmYXVsdE9wdGlvbiwgLi4uaXRlbXNdIDogaXRlbXMpLCBbXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgaXRlbXMsXG4gICAgXSk7XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgIHNpemU9e3Jvd1NpemV9XG4gICAgICAgICAgICBjb250ZW50PXtkYXRhW2luZGV4XX1cbiAgICAgICAgICAgIGluZGV4PXtpbmRleH1cbiAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgZGlzYWJsZWQ9eyhkYXRhW2luZGV4XSBhcyBTZWxlY3RPcHRpb24pPy5pc0Rpc2FibGVkfVxuICAgICAgICAgICAgc2VsZWN0ZWQ9e2lzU2VsZWN0ZWQoeyBpdGVtOiBkYXRhW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGRhdGFUZXN0SWQ9e2RhdGFUZXN0SWQgKyBgJHtkZWZhdWx0T3B0aW9uICYmIGluZGV4ID09PSAwICYmICdkZWZhdWx0J31gfVxuICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17ZGF0YS5sZW5ndGh9XG4gICAgICAgIGl0ZW1TaXplPXtyb3dTaXplID09PSAnbm9ybWFsJyA/IDU2IDogNDZ9XG4gICAgICAgIGNzcz17eyBvdmVyZmxvd1g6ICdoaWRkZW4nIH19XG4gICAgICA+XG4gICAgICAgIHtyb3dSZW5kZXJlcn1cbiAgICAgIDwvVkxpc3Q+XG4gICAgKTtcbiAgfVxuKTtcblZpcnR1YWxpemVkTGlzdC5kaXNwbGF5TmFtZSA9ICdWaXJ0dWFsaXplZExpc3QnO1xuXG5leHBvcnQgZGVmYXVsdCBWaXJ0dWFsaXplZExpc3Q7XG4iXX0= */")
57
- }, (0, _react.jsx)(_ListItem["default"], {
73
+ css: /*#__PURE__*/(0, _react.css)(_extends({}, style), process.env.NODE_ENV === "production" ? "" : ";label:rowRenderer;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBOERjIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBWYXJpYWJsZVNpemVMaXN0IGFzIFZMaXN0IH0gZnJvbSAncmVhY3Qtd2luZG93JztcbmltcG9ydCB7IENTU1Byb3BlcnRpZXMgfSBmcm9tICdzdHlsZWQtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBUZXN0UHJvcHMgfSBmcm9tICd1dGlscy90eXBlcyc7XG5cbmltcG9ydCB7IFNlbGVjdE9wdGlvbiB9IGZyb20gJy4uLy4uL1NlbGVjdC9TZWxlY3QnO1xuaW1wb3J0IHsgbGlzdFN0eWxlIH0gZnJvbSAnLi4vTGlzdC5zdHlsZSc7XG5pbXBvcnQgTGlzdEl0ZW0gZnJvbSAnLi4vTGlzdEl0ZW0nO1xuaW1wb3J0IExpc3RJdGVtR3JvdXAgZnJvbSAnLi4vTGlzdEl0ZW1Hcm91cCc7XG5pbXBvcnQgeyBMaXN0SXRlbVR5cGUsIExpc3RSb3dTaXplLCBTZWxlY3RIYW5kbGVyVHlwZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGlzU2VsZWN0ZWQsIE1BWF9MQVJHRV9IRUlHSFQsIE1BWF9TTUFMTF9IRUlHSFQgfSBmcm9tICcuLi91dGlscyc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGl0ZW1zOiBMaXN0SXRlbVR5cGVbXTtcbiAgLyoqIFNpemUgb2YgdGhlIGxpc3QncyByb3cgKGhlaWdodCBvZiBMaXN0SXRlbSBDb21wb25lbnQpICAqL1xuICByb3dTaXplOiBMaXN0Um93U2l6ZTtcbiAgLyoqIFdpZHRoIG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbVdpZHRoPzogbnVtYmVyO1xuICAvKiogSGVpZ2h0IG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbUhlaWdodD86IG51bWJlcjtcbiAgLyoqIFNlbGVjdGVkIEl0ZW0gKi9cbiAgc2VsZWN0ZWRJdGVtPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogRGVmYXVsdCBvcHRpb24uIFJlbmRlcnMgb24gdG9wIG9mIHRoZSBsaXN0LCBoaWdobGlnaHRlZCAqL1xuICBkZWZhdWx0T3B0aW9uPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogU2VhcmNoIFRlcm0gdG8gYmUgaGlnaGxpZ2h0ZWQgaW4gbGlzdCBpdGVtcyAqL1xuICBzZWFyY2hUZXJtPzogc3RyaW5nO1xuICAvKiogT3B0aW9uIENsaWNrIGhhbmRsZXIgZm9yIFNlbGVjdE9wdGlvbltdIGRhdGEgY2FzZSAqL1xuICBoYW5kbGVPcHRpb25DbGljaz86IFNlbGVjdEhhbmRsZXJUeXBlO1xufSAmIFRlc3RQcm9wcztcblxuY29uc3QgVmlydHVhbGl6ZWRMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgICBjdXN0b21XaWR0aCxcbiAgICAgIGN1c3RvbUhlaWdodCxcbiAgICAgIHJvd1NpemUsXG4gICAgICBzZWxlY3RlZEl0ZW0sXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgc2VhcmNoVGVybSxcbiAgICAgIGhhbmRsZU9wdGlvbkNsaWNrLFxuICAgICAgZGF0YVRlc3RJZCxcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBjb25zdCBkYXRhID0gdXNlTWVtbygoKSA9PiAoZGVmYXVsdE9wdGlvbiA/IFtkZWZhdWx0T3B0aW9uLCAuLi5pdGVtc10gOiBpdGVtcyksIFtcbiAgICAgIGRlZmF1bHRPcHRpb24sXG4gICAgICBpdGVtcyxcbiAgICBdKTtcblxuICAgIGNvbnN0IGl0ZW1TaXplID0gdXNlQ2FsbGJhY2soKGluZGV4OiBudW1iZXIpID0+IHtcbiAgICAgIGNvbnN0IHNpemVCYXNlID0gcm93U2l6ZSA9PT0gJ25vcm1hbCcgPyA1NiA6IDQ2O1xuXG4gICAgICBpZiAoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMpIHtcbiAgICAgICAgcmV0dXJuICgoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnM/Lmxlbmd0aCBhcyBudW1iZXIpICsgMSkgKiBzaXplQmFzZTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNpemVCYXNlO1xuICAgIH0sIFtkYXRhLCByb3dTaXplXSk7XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICB7KGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMgPyAoXG4gICAgICAgICAgICA8dWwgY3NzPXtsaXN0U3R5bGUoe30pfT5cbiAgICAgICAgICAgICAgPExpc3RJdGVtR3JvdXBcbiAgICAgICAgICAgICAgICBzaXplPXtyb3dTaXplfVxuICAgICAgICAgICAgICAgIGNvbnRlbnQ9e2RhdGFbaW5kZXhdfVxuICAgICAgICAgICAgICAgIGdyb3VwSW5kZXg9e2luZGV4fVxuICAgICAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgICAgIHNlYXJjaFRlcm09e3NlYXJjaFRlcm19XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgICAgICAgc2VsZWN0ZWRJdGVtPXtzZWxlY3RlZEl0ZW19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L3VsPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgICAgc2l6ZT17cm93U2l6ZX1cbiAgICAgICAgICAgICAgY29udGVudD17ZGF0YVtpbmRleF19XG4gICAgICAgICAgICAgIGluZGV4PXtpbmRleH1cbiAgICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXsoZGF0YVtpbmRleF0gYXMgU2VsZWN0T3B0aW9uKT8uaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgc2VsZWN0ZWQ9e2lzU2VsZWN0ZWQoeyBpdGVtOiBkYXRhW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgICBkYXRhVGVzdElkPXtkYXRhVGVzdElkICsgYCR7ZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCAmJiAnZGVmYXVsdCd9YH1cbiAgICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICAgIGhhbmRsZU9wdGlvbkNsaWNrPXtoYW5kbGVPcHRpb25DbGlja31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17ZGF0YS5sZW5ndGh9XG4gICAgICAgIGl0ZW1TaXplPXtpdGVtU2l6ZX1cbiAgICAgICAgY3NzPXt7IG92ZXJmbG93WDogJ2hpZGRlbicgfX1cbiAgICAgID5cbiAgICAgICAge3Jvd1JlbmRlcmVyfVxuICAgICAgPC9WTGlzdD5cbiAgICApO1xuICB9XG4pO1xuVmlydHVhbGl6ZWRMaXN0LmRpc3BsYXlOYW1lID0gJ1ZpcnR1YWxpemVkTGlzdCc7XG5cbmV4cG9ydCBkZWZhdWx0IFZpcnR1YWxpemVkTGlzdDtcbiJdfQ== */")
74
+ }, (_data$index3 = data[index]) != null && _data$index3.options ? (0, _react.jsx)("ul", {
75
+ css: (0, _List.listStyle)({})
76
+ }, (0, _react.jsx)(_ListItemGroup["default"], {
77
+ size: rowSize,
78
+ content: data[index],
79
+ groupIndex: index,
80
+ ref: ref,
81
+ searchTerm: searchTerm,
82
+ dataTestId: dataTestId,
83
+ handleOptionClick: handleOptionClick,
84
+ selectedItem: selectedItem
85
+ })) : (0, _react.jsx)(_ListItem["default"], {
58
86
  size: rowSize,
59
87
  content: data[index],
60
88
  index: index,
61
89
  ref: ref,
62
- disabled: (_data$index = data[index]) == null ? void 0 : _data$index.isDisabled,
90
+ disabled: (_data$index4 = data[index]) == null ? void 0 : _data$index4.isDisabled,
63
91
  selected: (0, _utils.isSelected)({
64
92
  item: data[index],
65
93
  selectedItem: selectedItem
@@ -71,12 +99,12 @@ var VirtualizedList = /*#__PURE__*/_react2["default"].forwardRef(function (_ref,
71
99
  }));
72
100
  };
73
101
 
74
- return (0, _react.jsx)(_reactWindow.FixedSizeList, {
102
+ return (0, _react.jsx)(_reactWindow.VariableSizeList, {
75
103
  "data-testid": dataTestId ? dataTestId + "_list" : 'ictinus_list',
76
104
  height: customHeight || rowSize === 'normal' ? _utils.MAX_LARGE_HEIGHT : _utils.MAX_SMALL_HEIGHT,
77
105
  width: customWidth || '100%',
78
106
  itemCount: data.length,
79
- itemSize: rowSize === 'normal' ? 56 : 46,
107
+ itemSize: itemSize,
80
108
  css: _ref3
81
109
  }, rowRenderer);
82
110
  });
@@ -9,3 +9,4 @@ export declare const isSelected: ({ item, selectedItem, }: {
9
9
  item: ListItemType;
10
10
  selectedItem: ListItemType | undefined;
11
11
  }) => boolean;
12
+ export declare const renderContent: (content: ListItemType, searchTerm?: string | undefined) => {} | null | undefined;
@@ -1,10 +1,14 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.isSelected = exports.MAX_SMALL_HEIGHT = exports.MAX_LARGE_HEIGHT = exports.MAX_NON_VIRTUALIZED_ITEMS_SELECT = exports.MAX_NON_VIRTUALIZED_ITEMS_FILTER = void 0;
4
+ exports.renderContent = exports.isSelected = exports.MAX_SMALL_HEIGHT = exports.MAX_LARGE_HEIGHT = exports.MAX_NON_VIRTUALIZED_ITEMS_SELECT = exports.MAX_NON_VIRTUALIZED_ITEMS_FILTER = void 0;
5
5
 
6
6
  var _react = _interopRequireDefault(require("react"));
7
7
 
8
+ var _reactHighlightWords = _interopRequireDefault(require("react-highlight-words"));
9
+
10
+ var _react2 = require("@emotion/react");
11
+
8
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
9
13
 
10
14
  /** For this amount of List Items the list of Filter will be non-virtualized */
@@ -45,4 +49,24 @@ var isSelected = function isSelected(_ref) {
45
49
  return itemValue === selectedItemValue;
46
50
  };
47
51
 
48
- exports.isSelected = isSelected;
52
+ exports.isSelected = isSelected;
53
+
54
+ var renderContent = function renderContent(content, searchTerm) {
55
+ if (searchTerm && content && ! /*#__PURE__*/_react["default"].isValidElement(content) && typeof content === 'object' && !Array.isArray(content) && 'label' in content && content != null && content.label) {
56
+ return (0, _react2.jsx)(_reactHighlightWords["default"], {
57
+ highlightClassName: "search-text",
58
+ highlightTag: 'strong',
59
+ searchWords: [searchTerm],
60
+ autoEscape: true,
61
+ textToHighlight: content.label
62
+ });
63
+ }
64
+
65
+ if (content && ! /*#__PURE__*/_react["default"].isValidElement(content) && typeof content === 'object' && !Array.isArray(content) && 'label' in content && content != null && content.label) {
66
+ return content.label;
67
+ }
68
+
69
+ return content;
70
+ };
71
+
72
+ exports.renderContent = renderContent;
@@ -5,6 +5,7 @@ export declare type SelectOption = {
5
5
  label: string;
6
6
  isDisabled?: boolean;
7
7
  tooltipInfo?: string;
8
+ options?: SelectOption[];
8
9
  };
9
10
  export declare type Props = {
10
11
  /** The function that is used to return the selected options */
@@ -145,7 +145,19 @@ var Select = /*#__PURE__*/_react2["default"].forwardRef(function (_ref, ref) {
145
145
  }
146
146
 
147
147
  return options.filter(function (option) {
148
- return !searchValue || option.label.toLowerCase().includes(searchValue.toLowerCase());
148
+ var _option$options;
149
+
150
+ return !searchValue || option.label.toLowerCase().includes(searchValue.toLowerCase()) || !!((_option$options = option.options) != null && _option$options.find(function (option) {
151
+ return option.label.toLowerCase().includes(searchValue.toLowerCase());
152
+ }));
153
+ }).map(function (option) {
154
+ var _option$options2;
155
+
156
+ return option.label.toLowerCase().includes(searchValue.toLowerCase()) ? option : _extends({}, option, {
157
+ options: (_option$options2 = option.options) == null ? void 0 : _option$options2.filter(function (option) {
158
+ return option.label.toLowerCase().includes(searchValue.toLowerCase());
159
+ })
160
+ });
149
161
  });
150
162
  }, [searchValue, options, isAsync]);
151
163
  var rightIconRender = (0, _react2.useMemo)(function () {
@@ -154,7 +166,7 @@ var Select = /*#__PURE__*/_react2["default"].forwardRef(function (_ref, ref) {
154
166
  /*#__PURE__*/
155
167
 
156
168
  /*#__PURE__*/
157
- (0, _react.css)("display:flex;gap:", (0, _utils.rem)(25), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:rightIconRender;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Select/Select.tsx"],"names":[],"mappings":"AAsJkB","file":"../../../src/components/Select/Select.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { debounce } from 'lodash';\nimport React, { InputHTMLAttributes, useEffect, useMemo, KeyboardEvent } from 'react';\nimport { rem } from 'theme/utils';\nimport { generateTestDataId } from 'utils/helpers';\n\nimport useCombinedRefs from '../../hooks/useCombinedRefs';\nimport useTheme from '../../hooks/useTheme';\nimport { ChangeEvent } from '../../utils/common';\nimport Icon from '../Icon';\nimport TextField from '../TextField';\nimport { Props as TextFieldProps } from '../TextField/TextField';\nimport ClickAwayListener from '../utils/ClickAwayListener';\nimport handleSearch from '../utils/handleSearch';\nimport SelectMenu from './components/SelectMenu/SelectMenu';\nimport { selectWrapper } from './Select.style';\nimport Loader from 'components/Loader';\n\nexport type SelectOption = {\n  value: string | number;\n  label: string;\n  isDisabled?: boolean;\n  tooltipInfo?: string;\n};\n\nexport type Props = {\n  /** The function that is used to return the selected options */\n  handleSelectedOption?: (selectedOption: SelectOption) => void;\n  /** the default value of the select if needed */\n  /** TODO: defaultValue is duplication of selectedOption*/\n  defaultValue?: SelectOption;\n  /** the value of the select if select is controlled */\n  selectedOption?: SelectOption;\n  /** if the select has tags */\n  multi?: boolean;\n  /** Options for the select dropdown */\n  options: SelectOption[];\n  /** if the component is used asynchronously */\n  isAsync?: boolean;\n  /** the function to fetch new options */\n  asyncSearch?: (term: string) => void;\n  /** after how many characters to start searching (default = 0) */\n  minCharactersToSearch?: number;\n  /** if searched text should be highlighted in available options */\n  highlightSearch?: boolean;\n  /** if the options are searchable */\n  isSearchable?: boolean;\n  /** data-testid suffix */\n  dataTestId?: string;\n  /** if component is loading */\n  isLoading?: boolean;\n  /** if options list is virtualized */\n  isVirtualized?: boolean;\n} & TextFieldProps;\n\nconst emptyValue = { label: '', value: '' };\n\n// Mocks onChange to avoid readonly warning for TextField Component\nconst ON_CHANGE_MOCK = () => {};\n\ntype InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;\n\nconst Select = React.forwardRef<HTMLInputElement, Props & InputProps>(\n  (\n    {\n      handleSelectedOption = () => {},\n      defaultValue = undefined,\n      selectedOption = emptyValue,\n      multi = false,\n      options,\n      isAsync = false,\n      isLoading = false,\n      asyncSearch = () => {},\n      status = 'normal',\n      minCharactersToSearch = 0,\n      highlightSearch = false,\n      isSearchable = true,\n      isVirtualized = false,\n      styleType,\n      disabled,\n      locked,\n      dataTestId,\n      ...restInputProps\n    },\n    ref\n  ) => {\n    const theme = useTheme();\n    const [open, setOpen] = React.useState(false);\n    const inputRef = React.useRef<HTMLInputElement>(null);\n    const combinedRefs = useCombinedRefs(inputRef, ref);\n    const [inputValue, setInputValue] = React.useState(defaultValue || selectedOption);\n    const [searchValue, setSearchValue] = React.useState('');\n\n    useEffect(() => {\n      setInputValue(defaultValue || selectedOption);\n    }, [defaultValue, selectedOption]);\n\n    const handleOptionClick = (option: SelectOption) => {\n      setInputValue(option);\n      setOpen(false);\n\n      if (isSearchable) {\n        setSearchValue('');\n      }\n      handleSelectedOption(option);\n    };\n\n    const handleOnKeyDown = (e: KeyboardEvent<HTMLInputElement>) => {\n      const isBackspaceKey = e.keyCode === 8;\n\n      if (isBackspaceKey) {\n        setInputValue(emptyValue);\n        debouncedOnChange('');\n      }\n    };\n\n    const debouncedOnChange = React.useCallback(\n      debounce(term => {\n        asyncSearch(term);\n      }, 400),\n      []\n    );\n\n    const handleOnInput = React.useCallback(\n      (event: ChangeEvent) => {\n        handleSearch({\n          event,\n          isSearchable,\n          isAsync,\n          setSearchValue,\n          onChange: debouncedOnChange,\n          minCharactersToSearch,\n        });\n      },\n      [debouncedOnChange, isAsync, isSearchable, minCharactersToSearch]\n    );\n\n    const filteredOptions = useMemo(() => {\n      if (isAsync) {\n        return options;\n      }\n\n      return options.filter(\n        option => !searchValue || option.label.toLowerCase().includes(searchValue.toLowerCase())\n      );\n    }, [searchValue, options, isAsync]);\n\n    const rightIconRender = useMemo(\n      () => (\n        <div\n          css={css`\n            display: flex;\n            gap: ${rem(25)};\n          `}\n        >\n          {isLoading && <Loader />}\n          <Icon\n            size={20}\n            name={open ? 'chevronLargeUp' : 'chevronLargeDown'}\n            color={theme.utils.getColor('lightGrey', 650)}\n            onClick={() => isSearchable && open && setOpen(!open)}\n          />\n        </div>\n      ),\n      [open, theme.utils, setOpen, isSearchable, isLoading]\n    );\n\n    const handleClick = () => {\n      if (!open) {\n        setOpen(true);\n        combinedRefs?.current?.focus();\n      } else if (!isSearchable) {\n        setOpen(false);\n        combinedRefs?.current?.blur();\n      }\n    };\n\n    return (\n      <ClickAwayListener\n        onClick={() => {\n          setOpen(false);\n          setSearchValue('');\n        }}\n      >\n        <div\n          {...(!(disabled || locked) && { onClick: handleClick })}\n          css={selectWrapper({ open, status, styleType, isSearchable })}\n        >\n          <TextField\n            styleType={styleType}\n            rightIcon={rightIconRender}\n            onKeyDown={handleOnKeyDown}\n            onInput={handleOnInput}\n            onChange={ON_CHANGE_MOCK}\n            readOnly={!isSearchable}\n            disabled={disabled}\n            locked={locked}\n            data-testid={generateTestDataId('select-input', dataTestId)}\n            {...restInputProps}\n            status={status}\n            value={searchValue || inputValue.label}\n            ref={combinedRefs}\n          />\n          {open && (\n            <SelectMenu\n              filteredOptions={filteredOptions}\n              handleOptionClick={handleOptionClick}\n              selectedOption={inputValue.value}\n              size={restInputProps.size}\n              status={status}\n              isLoading={isLoading}\n              isVirtualized={isVirtualized}\n              searchTerm={highlightSearch ? searchValue : undefined}\n            />\n          )}\n        </div>\n      </ClickAwayListener>\n    );\n  }\n);\n\nSelect.displayName = 'Select';\n\nexport default Select;\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:rightIconRender;")
169
+ (0, _react.css)("display:flex;gap:", (0, _utils.rem)(25), ";" + (process.env.NODE_ENV === "production" ? "" : ";label:rightIconRender;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Select/Select.tsx"],"names":[],"mappings":"AAuKkB","file":"../../../src/components/Select/Select.tsx","sourcesContent":["import { css } from '@emotion/react';\nimport { debounce } from 'lodash';\nimport React, { InputHTMLAttributes, useEffect, useMemo, KeyboardEvent } from 'react';\nimport { rem } from 'theme/utils';\nimport { generateTestDataId } from 'utils/helpers';\n\nimport useCombinedRefs from '../../hooks/useCombinedRefs';\nimport useTheme from '../../hooks/useTheme';\nimport { ChangeEvent } from '../../utils/common';\nimport Icon from '../Icon';\nimport TextField from '../TextField';\nimport { Props as TextFieldProps } from '../TextField/TextField';\nimport ClickAwayListener from '../utils/ClickAwayListener';\nimport handleSearch from '../utils/handleSearch';\nimport SelectMenu from './components/SelectMenu/SelectMenu';\nimport { selectWrapper } from './Select.style';\nimport Loader from 'components/Loader';\n\nexport type SelectOption = {\n  value: string | number;\n  label: string;\n  isDisabled?: boolean;\n  tooltipInfo?: string;\n  options?: SelectOption[];\n};\n\nexport type Props = {\n  /** The function that is used to return the selected options */\n  handleSelectedOption?: (selectedOption: SelectOption) => void;\n  /** the default value of the select if needed */\n  /** TODO: defaultValue is duplication of selectedOption*/\n  defaultValue?: SelectOption;\n  /** the value of the select if select is controlled */\n  selectedOption?: SelectOption;\n  /** if the select has tags */\n  multi?: boolean;\n  /** Options for the select dropdown */\n  options: SelectOption[];\n  /** if the component is used asynchronously */\n  isAsync?: boolean;\n  /** the function to fetch new options */\n  asyncSearch?: (term: string) => void;\n  /** after how many characters to start searching (default = 0) */\n  minCharactersToSearch?: number;\n  /** if searched text should be highlighted in available options */\n  highlightSearch?: boolean;\n  /** if the options are searchable */\n  isSearchable?: boolean;\n  /** data-testid suffix */\n  dataTestId?: string;\n  /** if component is loading */\n  isLoading?: boolean;\n  /** if options list is virtualized */\n  isVirtualized?: boolean;\n} & TextFieldProps;\n\nconst emptyValue = { label: '', value: '' };\n\n// Mocks onChange to avoid readonly warning for TextField Component\nconst ON_CHANGE_MOCK = () => {};\n\ntype InputProps = Partial<Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>>;\n\nconst Select = React.forwardRef<HTMLInputElement, Props & InputProps>(\n  (\n    {\n      handleSelectedOption = () => {},\n      defaultValue = undefined,\n      selectedOption = emptyValue,\n      multi = false,\n      options,\n      isAsync = false,\n      isLoading = false,\n      asyncSearch = () => {},\n      status = 'normal',\n      minCharactersToSearch = 0,\n      highlightSearch = false,\n      isSearchable = true,\n      isVirtualized = false,\n      styleType,\n      disabled,\n      locked,\n      dataTestId,\n      ...restInputProps\n    },\n    ref\n  ) => {\n    const theme = useTheme();\n    const [open, setOpen] = React.useState(false);\n    const inputRef = React.useRef<HTMLInputElement>(null);\n    const combinedRefs = useCombinedRefs(inputRef, ref);\n    const [inputValue, setInputValue] = React.useState(defaultValue || selectedOption);\n    const [searchValue, setSearchValue] = React.useState('');\n\n    useEffect(() => {\n      setInputValue(defaultValue || selectedOption);\n    }, [defaultValue, selectedOption]);\n\n    const handleOptionClick = (option: SelectOption) => {\n      setInputValue(option);\n      setOpen(false);\n\n      if (isSearchable) {\n        setSearchValue('');\n      }\n      handleSelectedOption(option);\n    };\n\n    const handleOnKeyDown = (e: KeyboardEvent<HTMLInputElement>) => {\n      const isBackspaceKey = e.keyCode === 8;\n\n      if (isBackspaceKey) {\n        setInputValue(emptyValue);\n        debouncedOnChange('');\n      }\n    };\n\n    const debouncedOnChange = React.useCallback(\n      debounce(term => {\n        asyncSearch(term);\n      }, 400),\n      []\n    );\n\n    const handleOnInput = React.useCallback(\n      (event: ChangeEvent) => {\n        handleSearch({\n          event,\n          isSearchable,\n          isAsync,\n          setSearchValue,\n          onChange: debouncedOnChange,\n          minCharactersToSearch,\n        });\n      },\n      [debouncedOnChange, isAsync, isSearchable, minCharactersToSearch]\n    );\n\n    const filteredOptions = useMemo(() => {\n      if (isAsync) {\n        return options;\n      }\n\n      return options\n        .filter(\n          option =>\n            !searchValue ||\n            option.label.toLowerCase().includes(searchValue.toLowerCase()) ||\n            !!option.options?.find(option =>\n              option.label.toLowerCase().includes(searchValue.toLowerCase())\n            )\n        )\n        .map(option => {\n          return option.label.toLowerCase().includes(searchValue.toLowerCase())\n            ? option\n            : {\n                ...option,\n                options: option.options?.filter(option =>\n                  option.label.toLowerCase().includes(searchValue.toLowerCase())\n                ),\n              };\n        });\n    }, [searchValue, options, isAsync]);\n\n    const rightIconRender = useMemo(\n      () => (\n        <div\n          css={css`\n            display: flex;\n            gap: ${rem(25)};\n          `}\n        >\n          {isLoading && <Loader />}\n          <Icon\n            size={20}\n            name={open ? 'chevronLargeUp' : 'chevronLargeDown'}\n            color={theme.utils.getColor('lightGrey', 650)}\n            onClick={() => isSearchable && open && setOpen(!open)}\n          />\n        </div>\n      ),\n      [open, theme.utils, setOpen, isSearchable, isLoading]\n    );\n\n    const handleClick = () => {\n      if (!open) {\n        setOpen(true);\n        combinedRefs?.current?.focus();\n      } else if (!isSearchable) {\n        setOpen(false);\n        combinedRefs?.current?.blur();\n      }\n    };\n\n    return (\n      <ClickAwayListener\n        onClick={() => {\n          setOpen(false);\n          setSearchValue('');\n        }}\n      >\n        <div\n          {...(!(disabled || locked) && { onClick: handleClick })}\n          css={selectWrapper({ open, status, styleType, isSearchable })}\n        >\n          <TextField\n            styleType={styleType}\n            rightIcon={rightIconRender}\n            onKeyDown={handleOnKeyDown}\n            onInput={handleOnInput}\n            onChange={ON_CHANGE_MOCK}\n            readOnly={!isSearchable}\n            disabled={disabled}\n            locked={locked}\n            data-testid={generateTestDataId('select-input', dataTestId)}\n            {...restInputProps}\n            status={status}\n            value={searchValue || inputValue.label}\n            ref={combinedRefs}\n          />\n          {open && (\n            <SelectMenu\n              filteredOptions={filteredOptions}\n              handleOptionClick={handleOptionClick}\n              selectedOption={inputValue.value}\n              size={restInputProps.size}\n              status={status}\n              isLoading={isLoading}\n              isVirtualized={isVirtualized}\n              searchTerm={highlightSearch ? searchValue : undefined}\n            />\n          )}\n        </div>\n      </ClickAwayListener>\n    );\n  }\n);\n\nSelect.displayName = 'Select';\n\nexport default Select;\n"]} */", process.env.NODE_ENV === "production" ? "" : ";label:rightIconRender;")
158
170
  }, isLoading && (0, _react.jsx)(_Loader["default"], null), (0, _react.jsx)(_Icon["default"], {
159
171
  size: 20,
160
172
  name: open ? 'chevronLargeUp' : 'chevronLargeDown',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@orfium/ictinus",
3
- "version": "4.8.1",
3
+ "version": "4.9.0",
4
4
  "main": "./dist/index.js",
5
5
  "types": "./dist/index.d.ts",
6
6
  "license": "MIT",