@orfium/ictinus 4.6.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 (55) hide show
  1. package/dist/components/Avatar/Avatar.d.ts +1 -1
  2. package/dist/components/Avatar/Avatar.js +17 -1
  3. package/dist/components/Avatar/Avatar.style.js +7 -1
  4. package/dist/components/Chip/Chip.d.ts +22 -20
  5. package/dist/components/Chip/Chip.js +55 -20
  6. package/dist/components/Chip/Chip.style.d.ts +2 -2
  7. package/dist/components/Chip/Chip.style.js +25 -53
  8. package/dist/components/Chip/components/Badge/Badge.d.ts +8 -0
  9. package/dist/components/Chip/components/Badge/Badge.js +31 -0
  10. package/dist/components/Chip/components/Badge/Badge.style.d.ts +4 -0
  11. package/dist/components/Chip/components/Badge/Badge.style.js +26 -0
  12. package/dist/components/Chip/components/Badge/index.d.ts +1 -0
  13. package/dist/components/Chip/components/Badge/index.js +10 -0
  14. package/dist/components/List/List.d.ts +5 -3
  15. package/dist/components/List/List.js +10 -2
  16. package/dist/components/List/List.style.d.ts +5 -0
  17. package/dist/components/List/List.style.js +21 -3
  18. package/dist/components/List/ListItem/ListItem.d.ts +3 -1
  19. package/dist/components/List/ListItem/ListItem.js +6 -33
  20. package/dist/components/List/ListItem/ListItem.style.d.ts +2 -1
  21. package/dist/components/List/ListItem/ListItem.style.js +4 -3
  22. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.d.ts +14 -0
  23. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.js +36 -0
  24. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.style.d.ts +8 -0
  25. package/dist/components/List/ListItemGroup/ListGroupTitle/ListGroupTitle.style.js +41 -0
  26. package/dist/components/List/ListItemGroup/ListGroupTitle/index.d.ts +1 -0
  27. package/dist/components/List/ListItemGroup/ListGroupTitle/index.js +10 -0
  28. package/dist/components/List/ListItemGroup/ListItemGroup.d.ts +18 -0
  29. package/dist/components/List/ListItemGroup/ListItemGroup.js +64 -0
  30. package/dist/components/List/ListItemGroup/index.d.ts +1 -0
  31. package/dist/components/List/ListItemGroup/index.js +10 -0
  32. package/dist/components/List/NormalList/NormalList.d.ts +1 -0
  33. package/dist/components/List/NormalList/NormalList.js +22 -21
  34. package/dist/components/List/NormalList/NormalList.style.d.ts +0 -7
  35. package/dist/components/List/NormalList/NormalList.style.js +1 -24
  36. package/dist/components/List/VirtualizedList/VirtualizedList.js +45 -14
  37. package/dist/components/List/utils.d.ts +1 -0
  38. package/dist/components/List/utils.js +26 -2
  39. package/dist/components/Select/Select.d.ts +1 -0
  40. package/dist/components/Select/Select.js +14 -2
  41. package/dist/components/Table/Table.d.ts +2 -0
  42. package/dist/components/Table/components/RenderRowOrNestedRow/RenderRowOrNestedRow.js +5 -1
  43. package/dist/components/Table/components/RenderRowOrNestedRow/components/ContentCell/ContentCell.d.ts +1 -0
  44. package/dist/components/Table/components/RenderRowOrNestedRow/components/ContentCell/ContentCell.js +9 -2
  45. package/dist/components/TruncatedContent/TruncatedContent.d.ts +11 -0
  46. package/dist/components/TruncatedContent/TruncatedContent.js +69 -0
  47. package/dist/components/TruncatedContent/TruncatedContent.style.d.ts +4 -0
  48. package/dist/components/TruncatedContent/TruncatedContent.style.js +26 -0
  49. package/dist/components/TruncatedContent/index.d.ts +1 -0
  50. package/dist/components/TruncatedContent/index.js +10 -0
  51. package/dist/index.d.ts +1 -0
  52. package/dist/index.js +5 -1
  53. package/dist/theme/typography.d.ts +1 -0
  54. package/dist/theme/typography.js +1 -0
  55. package/package.json +1 -1
@@ -5,16 +5,24 @@ exports["default"] = void 0;
5
5
 
6
6
  var _react = require("@emotion/react");
7
7
 
8
- var _react2 = _interopRequireDefault(require("react"));
8
+ 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 }; }
17
21
 
22
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
23
+
24
+ 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; }
25
+
18
26
  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)."; }
19
27
 
20
28
  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); }
@@ -25,7 +33,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
25
33
  } : {
26
34
  name: "pczpeh-VirtualizedList",
27
35
  styles: "overflow-x:hidden;label:VirtualizedList;",
28
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBeUVRIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgRml4ZWRTaXplTGlzdCBhcyBWTGlzdCB9IGZyb20gJ3JlYWN0LXdpbmRvdyc7XG5pbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgVGVzdFByb3BzIH0gZnJvbSAndXRpbHMvdHlwZXMnO1xuXG5pbXBvcnQgeyBTZWxlY3RPcHRpb24gfSBmcm9tICcuLi8uLi9TZWxlY3QvU2VsZWN0JztcbmltcG9ydCBMaXN0SXRlbSBmcm9tICcuLi9MaXN0SXRlbSc7XG5pbXBvcnQgeyBMaXN0SXRlbVR5cGUsIExpc3RSb3dTaXplLCBTZWxlY3RIYW5kbGVyVHlwZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGlzU2VsZWN0ZWQsIE1BWF9MQVJHRV9IRUlHSFQsIE1BWF9TTUFMTF9IRUlHSFQgfSBmcm9tICcuLi91dGlscyc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGl0ZW1zOiBMaXN0SXRlbVR5cGVbXTtcbiAgLyoqIFNpemUgb2YgdGhlIGxpc3QncyByb3cgKGhlaWdodCBvZiBMaXN0SXRlbSBDb21wb25lbnQpICAqL1xuICByb3dTaXplOiBMaXN0Um93U2l6ZTtcbiAgLyoqIFdpZHRoIG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbVdpZHRoPzogbnVtYmVyO1xuICAvKiogSGVpZ2h0IG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbUhlaWdodD86IG51bWJlcjtcbiAgLyoqIFNlbGVjdGVkIEl0ZW0gKi9cbiAgc2VsZWN0ZWRJdGVtPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogRGVmYXVsdCBvcHRpb24uIFJlbmRlcnMgb24gdG9wIG9mIHRoZSBsaXN0LCBoaWdobGlnaHRlZCAqL1xuICBkZWZhdWx0T3B0aW9uPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogU2VhcmNoIFRlcm0gdG8gYmUgaGlnaGxpZ2h0ZWQgaW4gbGlzdCBpdGVtcyAqL1xuICBzZWFyY2hUZXJtPzogc3RyaW5nO1xuICAvKiogT3B0aW9uIENsaWNrIGhhbmRsZXIgZm9yIFNlbGVjdE9wdGlvbltdIGRhdGEgY2FzZSAqL1xuICBoYW5kbGVPcHRpb25DbGljaz86IFNlbGVjdEhhbmRsZXJUeXBlO1xufSAmIFRlc3RQcm9wcztcblxuY29uc3QgVmlydHVhbGl6ZWRMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgICBjdXN0b21XaWR0aCxcbiAgICAgIGN1c3RvbUhlaWdodCxcbiAgICAgIHJvd1NpemUsXG4gICAgICBzZWxlY3RlZEl0ZW0sXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgc2VhcmNoVGVybSxcbiAgICAgIGhhbmRsZU9wdGlvbkNsaWNrLFxuICAgICAgZGF0YVRlc3RJZCxcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBpZiAoZGVmYXVsdE9wdGlvbikge1xuICAgICAgaXRlbXMudW5zaGlmdChkZWZhdWx0T3B0aW9uKTtcbiAgICB9XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgIHNpemU9e3Jvd1NpemV9XG4gICAgICAgICAgICBjb250ZW50PXtpdGVtc1tpbmRleF19XG4gICAgICAgICAgICBpbmRleD17aW5kZXh9XG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIGRpc2FibGVkPXsoaXRlbXNbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/LmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBzZWxlY3RlZD17aXNTZWxlY3RlZCh7IGl0ZW06IGl0ZW1zW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGRhdGFUZXN0SWQ9e2RhdGFUZXN0SWQgKyBgJHtkZWZhdWx0T3B0aW9uICYmIGluZGV4ID09PSAwICYmICdkZWZhdWx0J31gfVxuICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17aXRlbXMubGVuZ3RofVxuICAgICAgICBpdGVtU2l6ZT17cm93U2l6ZSA9PT0gJ25vcm1hbCcgPyA1NiA6IDQ2fVxuICAgICAgICBjc3M9e3sgb3ZlcmZsb3dYOiAnaGlkZGVuJyB9fVxuICAgICAgPlxuICAgICAgICB7cm93UmVuZGVyZXJ9XG4gICAgICA8L1ZMaXN0PlxuICAgICk7XG4gIH1cbik7XG5WaXJ0dWFsaXplZExpc3QuZGlzcGxheU5hbWUgPSAnVmlydHVhbGl6ZWRMaXN0JztcblxuZXhwb3J0IGRlZmF1bHQgVmlydHVhbGl6ZWRMaXN0O1xuIl19 */",
36
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUdRIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBWYXJpYWJsZVNpemVMaXN0IGFzIFZMaXN0IH0gZnJvbSAncmVhY3Qtd2luZG93JztcbmltcG9ydCB7IENTU1Byb3BlcnRpZXMgfSBmcm9tICdzdHlsZWQtY29tcG9uZW50cyc7XG5pbXBvcnQgeyBUZXN0UHJvcHMgfSBmcm9tICd1dGlscy90eXBlcyc7XG5cbmltcG9ydCB7IFNlbGVjdE9wdGlvbiB9IGZyb20gJy4uLy4uL1NlbGVjdC9TZWxlY3QnO1xuaW1wb3J0IHsgbGlzdFN0eWxlIH0gZnJvbSAnLi4vTGlzdC5zdHlsZSc7XG5pbXBvcnQgTGlzdEl0ZW0gZnJvbSAnLi4vTGlzdEl0ZW0nO1xuaW1wb3J0IExpc3RJdGVtR3JvdXAgZnJvbSAnLi4vTGlzdEl0ZW1Hcm91cCc7XG5pbXBvcnQgeyBMaXN0SXRlbVR5cGUsIExpc3RSb3dTaXplLCBTZWxlY3RIYW5kbGVyVHlwZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGlzU2VsZWN0ZWQsIE1BWF9MQVJHRV9IRUlHSFQsIE1BWF9TTUFMTF9IRUlHSFQgfSBmcm9tICcuLi91dGlscyc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGl0ZW1zOiBMaXN0SXRlbVR5cGVbXTtcbiAgLyoqIFNpemUgb2YgdGhlIGxpc3QncyByb3cgKGhlaWdodCBvZiBMaXN0SXRlbSBDb21wb25lbnQpICAqL1xuICByb3dTaXplOiBMaXN0Um93U2l6ZTtcbiAgLyoqIFdpZHRoIG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbVdpZHRoPzogbnVtYmVyO1xuICAvKiogSGVpZ2h0IG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbUhlaWdodD86IG51bWJlcjtcbiAgLyoqIFNlbGVjdGVkIEl0ZW0gKi9cbiAgc2VsZWN0ZWRJdGVtPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogRGVmYXVsdCBvcHRpb24uIFJlbmRlcnMgb24gdG9wIG9mIHRoZSBsaXN0LCBoaWdobGlnaHRlZCAqL1xuICBkZWZhdWx0T3B0aW9uPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogU2VhcmNoIFRlcm0gdG8gYmUgaGlnaGxpZ2h0ZWQgaW4gbGlzdCBpdGVtcyAqL1xuICBzZWFyY2hUZXJtPzogc3RyaW5nO1xuICAvKiogT3B0aW9uIENsaWNrIGhhbmRsZXIgZm9yIFNlbGVjdE9wdGlvbltdIGRhdGEgY2FzZSAqL1xuICBoYW5kbGVPcHRpb25DbGljaz86IFNlbGVjdEhhbmRsZXJUeXBlO1xufSAmIFRlc3RQcm9wcztcblxuY29uc3QgVmlydHVhbGl6ZWRMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgICBjdXN0b21XaWR0aCxcbiAgICAgIGN1c3RvbUhlaWdodCxcbiAgICAgIHJvd1NpemUsXG4gICAgICBzZWxlY3RlZEl0ZW0sXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgc2VhcmNoVGVybSxcbiAgICAgIGhhbmRsZU9wdGlvbkNsaWNrLFxuICAgICAgZGF0YVRlc3RJZCxcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBjb25zdCBkYXRhID0gdXNlTWVtbygoKSA9PiAoZGVmYXVsdE9wdGlvbiA/IFtkZWZhdWx0T3B0aW9uLCAuLi5pdGVtc10gOiBpdGVtcyksIFtcbiAgICAgIGRlZmF1bHRPcHRpb24sXG4gICAgICBpdGVtcyxcbiAgICBdKTtcblxuICAgIGNvbnN0IGl0ZW1TaXplID0gdXNlQ2FsbGJhY2soKGluZGV4OiBudW1iZXIpID0+IHtcbiAgICAgIGNvbnN0IHNpemVCYXNlID0gcm93U2l6ZSA9PT0gJ25vcm1hbCcgPyA1NiA6IDQ2O1xuXG4gICAgICBpZiAoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMpIHtcbiAgICAgICAgcmV0dXJuICgoKGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnM/Lmxlbmd0aCBhcyBudW1iZXIpICsgMSkgKiBzaXplQmFzZTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHNpemVCYXNlO1xuICAgIH0sIFtkYXRhLCByb3dTaXplXSk7XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICB7KGRhdGFbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/Lm9wdGlvbnMgPyAoXG4gICAgICAgICAgICA8dWwgY3NzPXtsaXN0U3R5bGUoe30pfT5cbiAgICAgICAgICAgICAgPExpc3RJdGVtR3JvdXBcbiAgICAgICAgICAgICAgICBzaXplPXtyb3dTaXplfVxuICAgICAgICAgICAgICAgIGNvbnRlbnQ9e2RhdGFbaW5kZXhdfVxuICAgICAgICAgICAgICAgIGdyb3VwSW5kZXg9e2luZGV4fVxuICAgICAgICAgICAgICAgIHJlZj17cmVmfVxuICAgICAgICAgICAgICAgIHNlYXJjaFRlcm09e3NlYXJjaFRlcm19XG4gICAgICAgICAgICAgICAgZGF0YVRlc3RJZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgICAgICAgc2VsZWN0ZWRJdGVtPXtzZWxlY3RlZEl0ZW19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L3VsPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgICAgc2l6ZT17cm93U2l6ZX1cbiAgICAgICAgICAgICAgY29udGVudD17ZGF0YVtpbmRleF19XG4gICAgICAgICAgICAgIGluZGV4PXtpbmRleH1cbiAgICAgICAgICAgICAgcmVmPXtyZWZ9XG4gICAgICAgICAgICAgIGRpc2FibGVkPXsoZGF0YVtpbmRleF0gYXMgU2VsZWN0T3B0aW9uKT8uaXNEaXNhYmxlZH1cbiAgICAgICAgICAgICAgc2VsZWN0ZWQ9e2lzU2VsZWN0ZWQoeyBpdGVtOiBkYXRhW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgICBzZWFyY2hUZXJtPXtzZWFyY2hUZXJtfVxuICAgICAgICAgICAgICBkYXRhVGVzdElkPXtkYXRhVGVzdElkICsgYCR7ZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCAmJiAnZGVmYXVsdCd9YH1cbiAgICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICAgIGhhbmRsZU9wdGlvbkNsaWNrPXtoYW5kbGVPcHRpb25DbGlja31cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17ZGF0YS5sZW5ndGh9XG4gICAgICAgIGl0ZW1TaXplPXtpdGVtU2l6ZX1cbiAgICAgICAgY3NzPXt7IG92ZXJmbG93WDogJ2hpZGRlbicgfX1cbiAgICAgID5cbiAgICAgICAge3Jvd1JlbmRlcmVyfVxuICAgICAgPC9WTGlzdD5cbiAgICApO1xuICB9XG4pO1xuVmlydHVhbGl6ZWRMaXN0LmRpc3BsYXlOYW1lID0gJ1ZpcnR1YWxpemVkTGlzdCc7XG5cbmV4cG9ydCBkZWZhdWx0IFZpcnR1YWxpemVkTGlzdDtcbiJdfQ== */",
29
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
38
  };
31
39
 
@@ -39,26 +47,49 @@ var VirtualizedList = /*#__PURE__*/_react2["default"].forwardRef(function (_ref,
39
47
  searchTerm = _ref.searchTerm,
40
48
  handleOptionClick = _ref.handleOptionClick,
41
49
  dataTestId = _ref.dataTestId;
50
+ var data = (0, _react2.useMemo)(function () {
51
+ return defaultOption ? [defaultOption].concat(items) : items;
52
+ }, [defaultOption, items]);
53
+ var itemSize = (0, _react2.useCallback)(function (index) {
54
+ var _data$index;
55
+
56
+ var sizeBase = rowSize === 'normal' ? 56 : 46;
42
57
 
43
- if (defaultOption) {
44
- items.unshift(defaultOption);
45
- }
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]);
46
66
 
47
67
  var rowRenderer = function rowRenderer(_ref2) {
48
- var _items$index;
68
+ var _data$index3, _data$index4;
49
69
 
50
70
  var index = _ref2.index,
51
71
  style = _ref2.style;
52
72
  return (0, _react.jsx)("span", {
53
- 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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaURjIiwiZmlsZSI6Ii4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpc3QvVmlydHVhbGl6ZWRMaXN0L1ZpcnR1YWxpemVkTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgRml4ZWRTaXplTGlzdCBhcyBWTGlzdCB9IGZyb20gJ3JlYWN0LXdpbmRvdyc7XG5pbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgVGVzdFByb3BzIH0gZnJvbSAndXRpbHMvdHlwZXMnO1xuXG5pbXBvcnQgeyBTZWxlY3RPcHRpb24gfSBmcm9tICcuLi8uLi9TZWxlY3QvU2VsZWN0JztcbmltcG9ydCBMaXN0SXRlbSBmcm9tICcuLi9MaXN0SXRlbSc7XG5pbXBvcnQgeyBMaXN0SXRlbVR5cGUsIExpc3RSb3dTaXplLCBTZWxlY3RIYW5kbGVyVHlwZSB9IGZyb20gJy4uL3R5cGVzJztcbmltcG9ydCB7IGlzU2VsZWN0ZWQsIE1BWF9MQVJHRV9IRUlHSFQsIE1BWF9TTUFMTF9IRUlHSFQgfSBmcm9tICcuLi91dGlscyc7XG5cbnR5cGUgUHJvcHMgPSB7XG4gIGl0ZW1zOiBMaXN0SXRlbVR5cGVbXTtcbiAgLyoqIFNpemUgb2YgdGhlIGxpc3QncyByb3cgKGhlaWdodCBvZiBMaXN0SXRlbSBDb21wb25lbnQpICAqL1xuICByb3dTaXplOiBMaXN0Um93U2l6ZTtcbiAgLyoqIFdpZHRoIG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbVdpZHRoPzogbnVtYmVyO1xuICAvKiogSGVpZ2h0IG9mIHRoZSBsaXN0ICovXG4gIGN1c3RvbUhlaWdodD86IG51bWJlcjtcbiAgLyoqIFNlbGVjdGVkIEl0ZW0gKi9cbiAgc2VsZWN0ZWRJdGVtPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogRGVmYXVsdCBvcHRpb24uIFJlbmRlcnMgb24gdG9wIG9mIHRoZSBsaXN0LCBoaWdobGlnaHRlZCAqL1xuICBkZWZhdWx0T3B0aW9uPzogTGlzdEl0ZW1UeXBlO1xuICAvKiogU2VhcmNoIFRlcm0gdG8gYmUgaGlnaGxpZ2h0ZWQgaW4gbGlzdCBpdGVtcyAqL1xuICBzZWFyY2hUZXJtPzogc3RyaW5nO1xuICAvKiogT3B0aW9uIENsaWNrIGhhbmRsZXIgZm9yIFNlbGVjdE9wdGlvbltdIGRhdGEgY2FzZSAqL1xuICBoYW5kbGVPcHRpb25DbGljaz86IFNlbGVjdEhhbmRsZXJUeXBlO1xufSAmIFRlc3RQcm9wcztcblxuY29uc3QgVmlydHVhbGl6ZWRMaXN0ID0gUmVhY3QuZm9yd2FyZFJlZjxIVE1MRGl2RWxlbWVudCwgUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgaXRlbXMsXG4gICAgICBjdXN0b21XaWR0aCxcbiAgICAgIGN1c3RvbUhlaWdodCxcbiAgICAgIHJvd1NpemUsXG4gICAgICBzZWxlY3RlZEl0ZW0sXG4gICAgICBkZWZhdWx0T3B0aW9uLFxuICAgICAgc2VhcmNoVGVybSxcbiAgICAgIGhhbmRsZU9wdGlvbkNsaWNrLFxuICAgICAgZGF0YVRlc3RJZCxcbiAgICB9LFxuICAgIHJlZlxuICApID0+IHtcbiAgICBpZiAoZGVmYXVsdE9wdGlvbikge1xuICAgICAgaXRlbXMudW5zaGlmdChkZWZhdWx0T3B0aW9uKTtcbiAgICB9XG5cbiAgICBjb25zdCByb3dSZW5kZXJlciA9ICh7IGluZGV4LCBzdHlsZSB9OiB7IGluZGV4OiBudW1iZXI7IHN0eWxlOiBDU1NQcm9wZXJ0aWVzIH0pID0+IHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxzcGFuIGNzcz17eyAuLi5zdHlsZSB9fT5cbiAgICAgICAgICA8TGlzdEl0ZW1cbiAgICAgICAgICAgIHNpemU9e3Jvd1NpemV9XG4gICAgICAgICAgICBjb250ZW50PXtpdGVtc1tpbmRleF19XG4gICAgICAgICAgICBpbmRleD17aW5kZXh9XG4gICAgICAgICAgICByZWY9e3JlZn1cbiAgICAgICAgICAgIGRpc2FibGVkPXsoaXRlbXNbaW5kZXhdIGFzIFNlbGVjdE9wdGlvbik/LmlzRGlzYWJsZWR9XG4gICAgICAgICAgICBzZWxlY3RlZD17aXNTZWxlY3RlZCh7IGl0ZW06IGl0ZW1zW2luZGV4XSwgc2VsZWN0ZWRJdGVtIH0pfVxuICAgICAgICAgICAgc2VhcmNoVGVybT17c2VhcmNoVGVybX1cbiAgICAgICAgICAgIGRhdGFUZXN0SWQ9e2RhdGFUZXN0SWQgKyBgJHtkZWZhdWx0T3B0aW9uICYmIGluZGV4ID09PSAwICYmICdkZWZhdWx0J31gfVxuICAgICAgICAgICAgaGlnaGxpZ2h0ZWQ9e0Jvb2xlYW4oZGVmYXVsdE9wdGlvbiAmJiBpbmRleCA9PT0gMCl9XG4gICAgICAgICAgICBoYW5kbGVPcHRpb25DbGljaz17aGFuZGxlT3B0aW9uQ2xpY2t9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgKTtcbiAgICB9O1xuXG4gICAgcmV0dXJuIChcbiAgICAgIDxWTGlzdFxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZCA/IGAke2RhdGFUZXN0SWR9X2xpc3RgIDogJ2ljdGludXNfbGlzdCd9XG4gICAgICAgIGhlaWdodD17Y3VzdG9tSGVpZ2h0IHx8IHJvd1NpemUgPT09ICdub3JtYWwnID8gTUFYX0xBUkdFX0hFSUdIVCA6IE1BWF9TTUFMTF9IRUlHSFR9XG4gICAgICAgIHdpZHRoPXtjdXN0b21XaWR0aCB8fCAnMTAwJSd9XG4gICAgICAgIGl0ZW1Db3VudD17aXRlbXMubGVuZ3RofVxuICAgICAgICBpdGVtU2l6ZT17cm93U2l6ZSA9PT0gJ25vcm1hbCcgPyA1NiA6IDQ2fVxuICAgICAgICBjc3M9e3sgb3ZlcmZsb3dYOiAnaGlkZGVuJyB9fVxuICAgICAgPlxuICAgICAgICB7cm93UmVuZGVyZXJ9XG4gICAgICA8L1ZMaXN0PlxuICAgICk7XG4gIH1cbik7XG5WaXJ0dWFsaXplZExpc3QuZGlzcGxheU5hbWUgPSAnVmlydHVhbGl6ZWRMaXN0JztcblxuZXhwb3J0IGRlZmF1bHQgVmlydHVhbGl6ZWRMaXN0O1xuIl19 */")
54
- }, (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"], {
55
86
  size: rowSize,
56
- content: items[index],
87
+ content: data[index],
57
88
  index: index,
58
89
  ref: ref,
59
- disabled: (_items$index = items[index]) == null ? void 0 : _items$index.isDisabled,
90
+ disabled: (_data$index4 = data[index]) == null ? void 0 : _data$index4.isDisabled,
60
91
  selected: (0, _utils.isSelected)({
61
- item: items[index],
92
+ item: data[index],
62
93
  selectedItem: selectedItem
63
94
  }),
64
95
  searchTerm: searchTerm,
@@ -68,12 +99,12 @@ var VirtualizedList = /*#__PURE__*/_react2["default"].forwardRef(function (_ref,
68
99
  }));
69
100
  };
70
101
 
71
- return (0, _react.jsx)(_reactWindow.FixedSizeList, {
102
+ return (0, _react.jsx)(_reactWindow.VariableSizeList, {
72
103
  "data-testid": dataTestId ? dataTestId + "_list" : 'ictinus_list',
73
104
  height: customHeight || rowSize === 'normal' ? _utils.MAX_LARGE_HEIGHT : _utils.MAX_SMALL_HEIGHT,
74
105
  width: customWidth || '100%',
75
- itemCount: items.length,
76
- itemSize: rowSize === 'normal' ? 56 : 46,
106
+ itemCount: data.length,
107
+ itemSize: itemSize,
77
108
  css: _ref3
78
109
  }, rowRenderer);
79
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',
@@ -3,6 +3,8 @@ import { ExtendedColumn, Sort, SortingOrder } from './types';
3
3
  export declare type ContentComponent<T> = (data: Cell<T>) => React.Component | JSX.Element;
4
4
  export declare type Cell<T> = {
5
5
  content: number | string | ContentComponent<T>;
6
+ tooltipContent?: string;
7
+ hasTruncatedTooltip?: boolean;
6
8
  colSpan?: number;
7
9
  type?: 'financial' | 'normal';
8
10
  align?: 'left' | 'right';
@@ -86,16 +86,20 @@ var RenderRowWithCells = /*#__PURE__*/React.memo(function (_ref) {
86
86
  onClick: tChange
87
87
  }))), (_row$cells2 = row.cells) == null ? void 0 : _row$cells2.map(function (_ref2, index) {
88
88
  var content = _ref2.content,
89
+ tooltipContent = _ref2.tooltipContent,
90
+ _ref2$hasTruncatedToo = _ref2.hasTruncatedTooltip,
91
+ hasTruncatedTooltip = _ref2$hasTruncatedToo === void 0 ? true : _ref2$hasTruncatedToo,
89
92
  colSpan = _ref2.colSpan,
90
93
  cellType = _ref2.type,
91
94
  align = _ref2.align;
92
95
  return (0, _react2.jsx)(_ContentCell["default"], {
93
96
  key: row.id + "-" + index,
94
97
  cellCounter: index,
98
+ columnWidth: columnsWithWidth[index],
95
99
  columns: columns,
100
+ tooltipContent: hasTruncatedTooltip ? (0, _helpers.isComponentFunctionType)(content) ? tooltipContent : tooltipContent != null ? tooltipContent : content.toString() : undefined,
96
101
  padded: padded,
97
102
  colSpan: colSpan,
98
- columnWidth: columnsWithWidth[index],
99
103
  content: content,
100
104
  cellType: cellType,
101
105
  rowType: type,
@@ -3,6 +3,7 @@ import { ContentComponent, TableType } from '../../../../Table';
3
3
  declare type Props = {
4
4
  columns: string[];
5
5
  padded: boolean;
6
+ tooltipContent?: string;
6
7
  columnWidth?: number;
7
8
  content: number | string | ContentComponent<any>;
8
9
  colSpan?: number;
@@ -7,6 +7,8 @@ var _react = _interopRequireDefault(require("react"));
7
7
 
8
8
  var _helpers = require("../../../../../../utils/helpers");
9
9
 
10
+ var _TruncatedContent = _interopRequireDefault(require("../../../../../TruncatedContent"));
11
+
10
12
  var _TableCell = _interopRequireDefault(require("../../../TableCell"));
11
13
 
12
14
  var _ContentCell = require("./ContentCell.style");
@@ -19,6 +21,7 @@ var ContentCell = function ContentCell(_ref) {
19
21
  var columns = _ref.columns,
20
22
  padded = _ref.padded,
21
23
  columnWidth = _ref.columnWidth,
24
+ tooltipContent = _ref.tooltipContent,
22
25
  content = _ref.content,
23
26
  colSpan = _ref.colSpan,
24
27
  rowType = _ref.rowType,
@@ -40,12 +43,16 @@ var ContentCell = function ContentCell(_ref) {
40
43
  index: index
41
44
  }, rowType === 'nested-header' && (0, _react2.jsx)("div", {
42
45
  css: (0, _ContentCell.nestedHeaderStyle)()
43
- }, columns[cellCounter]), (0, _helpers.isComponentFunctionType)(content) ? content({
46
+ }, columns[cellCounter]), (0, _react2.jsx)(_TruncatedContent["default"], {
47
+ placement: 'bottom',
48
+ shouldAlwaysShow: (0, _helpers.isComponentFunctionType)(content) && !!tooltipContent,
49
+ tooltipContent: tooltipContent
50
+ }, (0, _helpers.isComponentFunctionType)(content) ? content({
44
51
  content: content,
45
52
  colSpan: colSpan
46
53
  }) : (0, _react2.jsx)("span", {
47
54
  "data-column": columns[cellCounter]
48
- }, content));
55
+ }, content)));
49
56
  };
50
57
 
51
58
  var _default = /*#__PURE__*/_react["default"].memo(ContentCell);
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ declare type Props = {
3
+ /** The content of the tooltip */
4
+ tooltipContent: string | undefined;
5
+ /** Flag for overriding other settings to always show the tooltip */
6
+ shouldAlwaysShow?: boolean;
7
+ /** The placement of the tooltip */
8
+ placement?: 'top' | 'bottom' | 'right' | 'left';
9
+ };
10
+ declare const TruncatedContent: React.FC<Props>;
11
+ export default TruncatedContent;
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _react = _interopRequireWildcard(require("react"));
7
+
8
+ var _TruncatedContent = require("./TruncatedContent.style");
9
+
10
+ var _Tooltip = _interopRequireDefault(require("../Tooltip"));
11
+
12
+ var _react2 = require("@emotion/react");
13
+
14
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
15
+
16
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
17
+
18
+ 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; }
19
+
20
+ var TruncatedContent = function TruncatedContent(_ref) {
21
+ var children = _ref.children,
22
+ _ref$shouldAlwaysShow = _ref.shouldAlwaysShow,
23
+ shouldAlwaysShow = _ref$shouldAlwaysShow === void 0 ? false : _ref$shouldAlwaysShow,
24
+ tooltipContent = _ref.tooltipContent,
25
+ _ref$placement = _ref.placement,
26
+ placement = _ref$placement === void 0 ? 'bottom' : _ref$placement;
27
+
28
+ var _useState = (0, _react.useState)(false),
29
+ isHovered = _useState[0],
30
+ setIsHovered = _useState[1];
31
+
32
+ var targetRef = (0, _react.useRef)(null);
33
+ var target = targetRef.current;
34
+ var handleMouseEnter = (0, _react.useCallback)(function () {
35
+ setIsHovered(true);
36
+ }, []);
37
+ var handleMouseLeave = (0, _react.useCallback)(function () {
38
+ setIsHovered(false);
39
+ }, []);
40
+ var isTruncated = (0, _react.useMemo)(function () {
41
+ return !!target && target.scrollWidth > target.offsetWidth;
42
+ }, [target]);
43
+ var showTooltip = (0, _react.useCallback)(function (tooltipContent, isHovered, isTruncated, shouldAlwaysShow) {
44
+ if (tooltipContent === undefined) {
45
+ return false;
46
+ }
47
+
48
+ if (shouldAlwaysShow) {
49
+ return true;
50
+ }
51
+
52
+ return isHovered && isTruncated;
53
+ }, []);
54
+ return showTooltip(tooltipContent, isHovered, isTruncated, shouldAlwaysShow) ? (0, _react2.jsx)(_Tooltip["default"], {
55
+ placement: placement,
56
+ content: tooltipContent
57
+ }, (0, _react2.jsx)(_TruncatedContent.TruncationDiv, {
58
+ ref: targetRef,
59
+ onMouseEnter: handleMouseEnter,
60
+ onMouseLeave: handleMouseLeave
61
+ }, children)) : (0, _react2.jsx)(_TruncatedContent.TruncationDiv, {
62
+ ref: targetRef,
63
+ onMouseEnter: handleMouseEnter,
64
+ onMouseLeave: handleMouseLeave
65
+ }, children);
66
+ };
67
+
68
+ var _default = TruncatedContent;
69
+ exports["default"] = _default;
@@ -0,0 +1,4 @@
1
+ export declare const TruncationDiv: import("@emotion/styled").StyledComponent<{
2
+ theme?: import("@emotion/react").Theme | undefined;
3
+ as?: import("react").ElementType<any> | undefined;
4
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
@@ -0,0 +1,26 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.TruncationDiv = void 0;
5
+
6
+ var _base = _interopRequireDefault(require("@emotion/styled/base"));
7
+
8
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
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 TruncationDiv = (0, _base["default"])("div", process.env.NODE_ENV === "production" ? {
13
+ target: "ep8j7z50"
14
+ } : {
15
+ target: "ep8j7z50",
16
+ label: "TruncationDiv"
17
+ })(process.env.NODE_ENV === "production" ? {
18
+ name: "1h52dri",
19
+ styles: "overflow:hidden;text-overflow:ellipsis;white-space:nowrap"
20
+ } : {
21
+ name: "1h52dri",
22
+ styles: "overflow:hidden;text-overflow:ellipsis;white-space:nowrap",
23
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RydW5jYXRlZENvbnRlbnQvVHJ1bmNhdGVkQ29udGVudC5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRXVDIiwiZmlsZSI6Ii4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RydW5jYXRlZENvbnRlbnQvVHJ1bmNhdGVkQ29udGVudC5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmV4cG9ydCBjb25zdCBUcnVuY2F0aW9uRGl2ID0gc3R5bGVkLmRpdmBcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xuIl19 */",
24
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
25
+ });
26
+ exports.TruncationDiv = TruncationDiv;
@@ -0,0 +1 @@
1
+ export { default } from './TruncatedContent';
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = void 0;
5
+
6
+ var _TruncatedContent = _interopRequireDefault(require("./TruncatedContent"));
7
+
8
+ exports["default"] = _TruncatedContent["default"];
9
+
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
package/dist/index.d.ts CHANGED
@@ -52,5 +52,6 @@ export { default as useTheme } from './hooks/useTheme';
52
52
  export { default as useBreakpoints } from './hooks/useBreakpoints';
53
53
  export { default as useEscape } from './hooks/useEscape';
54
54
  export { default as Filter } from './components/Filter';
55
+ export { default as TruncatedContent } from './components/TruncatedContent';
55
56
  export { default as themeConfig } from './theme';
56
57
  export { themeFunctions, palette, spacing, typography, elevation, overrides, queriesSizes, };
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
 
3
3
  exports.__esModule = true;
4
- exports.typography = exports.spacing = exports.palette = exports.overrides = exports.themeFunctions = exports.elevation = exports.themeConfig = exports.Filter = exports.useEscape = exports.useBreakpoints = exports.useTheme = exports.TopNavBar = exports.Tooltip = exports.Toast = exports.ThemeProvider = exports.TextArea = exports.SearchField = exports.TextField = exports.Table = exports.Select = exports.RadioGroup = exports.Radio = exports.Pagination = exports.Snackbar = exports.Banner = exports.NotificationVisual = exports.NotificationsContainer = exports.InlineNotification = exports.Modal = exports.Menu = exports.Loader = exports.List = exports.Label = exports.IconButton = exports.Icon = exports.ExpandCollapse = exports.Drawer = exports.DatePicker = exports.Chip = exports.CheckBox = exports.DonutChart = exports.BarChart = exports.LineChart = exports.Card = exports.Button = exports.Breadcrumb = exports.Avatar = void 0;
4
+ exports.typography = exports.spacing = exports.palette = exports.overrides = exports.themeFunctions = exports.elevation = exports.themeConfig = exports.TruncatedContent = exports.Filter = exports.useEscape = exports.useBreakpoints = exports.useTheme = exports.TopNavBar = exports.Tooltip = exports.Toast = exports.ThemeProvider = exports.TextArea = exports.SearchField = exports.TextField = exports.Table = exports.Select = exports.RadioGroup = exports.Radio = exports.Pagination = exports.Snackbar = exports.Banner = exports.NotificationVisual = exports.NotificationsContainer = exports.InlineNotification = exports.Modal = exports.Menu = exports.Loader = exports.List = exports.Label = exports.IconButton = exports.Icon = exports.ExpandCollapse = exports.Drawer = exports.DatePicker = exports.Chip = exports.CheckBox = exports.DonutChart = exports.BarChart = exports.LineChart = exports.Card = exports.Button = exports.Breadcrumb = exports.Avatar = void 0;
5
5
 
6
6
  var _useBreakpoints = _interopRequireWildcard(require("./hooks/useBreakpoints"));
7
7
 
@@ -188,6 +188,10 @@ var _Filter = _interopRequireDefault(require("./components/Filter"));
188
188
 
189
189
  exports.Filter = _Filter["default"];
190
190
 
191
+ var _TruncatedContent = _interopRequireDefault(require("./components/TruncatedContent"));
192
+
193
+ exports.TruncatedContent = _TruncatedContent["default"];
194
+
191
195
  var _theme = _interopRequireDefault(require("./theme"));
192
196
 
193
197
  exports.themeConfig = _theme["default"];
@@ -8,6 +8,7 @@ declare const weights: {
8
8
  export declare type Typography = {
9
9
  globalFontSize: number;
10
10
  fontSizes: {
11
+ 8: string;
11
12
  10: string;
12
13
  11: string;
13
14
  12: string;
@@ -14,6 +14,7 @@ var weights = {
14
14
  black: 900
15
15
  };
16
16
  var fontSizes = {
17
+ 8: (0, _utils.rem)('8px'),
17
18
  10: (0, _utils.rem)('10px'),
18
19
  11: (0, _utils.rem)('11px'),
19
20
  12: (0, _utils.rem)('12px'),
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@orfium/ictinus",
3
- "version": "4.6.1",
3
+ "version": "4.9.0",
4
4
  "main": "./dist/index.js",
5
5
  "types": "./dist/index.d.ts",
6
6
  "license": "MIT",