@popsure/dirty-swan 0.54.2 → 0.54.3

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 (106) hide show
  1. package/dist/cjs/index.js +329 -239
  2. package/dist/cjs/index.js.map +1 -1
  3. package/dist/cjs/lib/components/table/components/TableCell/BaseCell/BaseCell.d.ts +17 -0
  4. package/dist/cjs/lib/components/table/components/TableCell/BaseCell/BaseCell.stories.d.ts +22 -0
  5. package/dist/cjs/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.d.ts +3 -0
  6. package/dist/cjs/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.stories.d.ts +25 -0
  7. package/dist/cjs/lib/components/table/components/TableCell/ButtonCell/ButtonCell.d.ts +9 -0
  8. package/dist/cjs/lib/components/table/components/TableCell/ButtonCell/ButtonCell.stories.d.ts +17 -0
  9. package/dist/cjs/lib/components/table/components/TableCell/CTACell/CTACell.d.ts +9 -0
  10. package/dist/cjs/lib/components/table/components/TableCell/CTACell/CTACell.stories.d.ts +17 -0
  11. package/dist/cjs/lib/components/table/components/TableCell/TableCell.d.ts +5 -17
  12. package/dist/cjs/lib/components/table/types.d.ts +11 -2
  13. package/dist/cjs/lib/components/table/utils/useTableNavigation/useTableNavigation.d.ts +1 -2
  14. package/dist/esm/components/cards/card/index.stories.js +2 -2
  15. package/dist/esm/components/cards/card/index.stories.js.map +1 -1
  16. package/dist/esm/components/comparisonTable/components/TableInfoButton/index.js +2 -2
  17. package/dist/esm/components/comparisonTable/components/TableInfoButton/index.js.map +1 -1
  18. package/dist/esm/components/comparisonTable/index.js +3 -1526
  19. package/dist/esm/components/comparisonTable/index.js.map +1 -1
  20. package/dist/esm/components/comparisonTable/index.stories.js +1 -0
  21. package/dist/esm/components/comparisonTable/index.stories.js.map +1 -1
  22. package/dist/esm/components/icon/icons/Info.js +2 -2
  23. package/dist/esm/components/icon/icons/Info.js.map +1 -1
  24. package/dist/esm/components/icon/icons.stories.js +1 -1
  25. package/dist/esm/components/icon/index.stories.js +1 -1
  26. package/dist/esm/components/table/Table.js +26 -12
  27. package/dist/esm/components/table/Table.js.map +1 -1
  28. package/dist/esm/components/table/Table.stories.js +54 -12
  29. package/dist/esm/components/table/Table.stories.js.map +1 -1
  30. package/dist/esm/components/table/Table.test.js +12 -6
  31. package/dist/esm/components/table/Table.test.js.map +1 -1
  32. package/dist/esm/components/table/components/TableCell/BaseCell/BaseCell.js +50 -0
  33. package/dist/esm/components/table/components/TableCell/BaseCell/BaseCell.js.map +1 -0
  34. package/dist/esm/components/table/components/TableCell/BaseCell/BaseCell.stories.js +43 -0
  35. package/dist/esm/components/table/components/TableCell/BaseCell/BaseCell.stories.js.map +1 -0
  36. package/dist/esm/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js +15 -0
  37. package/dist/esm/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js.map +1 -0
  38. package/dist/esm/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.stories.js +31 -0
  39. package/dist/esm/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.stories.js.map +1 -0
  40. package/dist/esm/components/table/components/TableCell/ButtonCell/ButtonCell.js +23 -0
  41. package/dist/esm/components/table/components/TableCell/ButtonCell/ButtonCell.js.map +1 -0
  42. package/dist/esm/components/table/components/TableCell/ButtonCell/ButtonCell.stories.js +28 -0
  43. package/dist/esm/components/table/components/TableCell/ButtonCell/ButtonCell.stories.js.map +1 -0
  44. package/dist/esm/components/table/components/TableCell/CTACell/CTACell.js +21 -0
  45. package/dist/esm/components/table/components/TableCell/CTACell/CTACell.js.map +1 -0
  46. package/dist/esm/components/table/components/TableCell/CTACell/CTACell.stories.js +25 -0
  47. package/dist/esm/components/table/components/TableCell/CTACell/CTACell.stories.js.map +1 -0
  48. package/dist/esm/components/table/components/TableCell/TableCell.js +21 -20
  49. package/dist/esm/components/table/components/TableCell/TableCell.js.map +1 -1
  50. package/dist/esm/components/table/components/TableCell/TableCell.test.js +28 -14
  51. package/dist/esm/components/table/components/TableCell/TableCell.test.js.map +1 -1
  52. package/dist/esm/components/table/components/TableContents/TableContents.js +10 -2
  53. package/dist/esm/components/table/components/TableContents/TableContents.js.map +1 -1
  54. package/dist/esm/components/table/components/TableContents/TableContents.test.js +9 -2
  55. package/dist/esm/components/table/components/TableContents/TableContents.test.js.map +1 -1
  56. package/dist/esm/components/table/components/TableSection/TableSection.js +39 -7
  57. package/dist/esm/components/table/components/TableSection/TableSection.js.map +1 -1
  58. package/dist/esm/components/table/components/TableSection/TableSection.test.js +9 -2
  59. package/dist/esm/components/table/components/TableSection/TableSection.test.js.map +1 -1
  60. package/dist/esm/components/table/utils/useTableNavigation/useTableNavigation.test.js +1 -5
  61. package/dist/esm/components/table/utils/useTableNavigation/useTableNavigation.test.js.map +1 -1
  62. package/dist/esm/index-3d286178.js +1529 -0
  63. package/dist/esm/index-3d286178.js.map +1 -0
  64. package/dist/esm/{index-0bb5a2ee.js → index-7506ae25.js} +3 -3
  65. package/dist/esm/{index-0bb5a2ee.js.map → index-7506ae25.js.map} +1 -1
  66. package/dist/esm/index.js +6 -1
  67. package/dist/esm/index.js.map +1 -1
  68. package/dist/esm/lib/components/table/components/TableCell/BaseCell/BaseCell.d.ts +17 -0
  69. package/dist/esm/lib/components/table/components/TableCell/BaseCell/BaseCell.stories.d.ts +22 -0
  70. package/dist/esm/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.d.ts +3 -0
  71. package/dist/esm/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.stories.d.ts +25 -0
  72. package/dist/esm/lib/components/table/components/TableCell/ButtonCell/ButtonCell.d.ts +9 -0
  73. package/dist/esm/lib/components/table/components/TableCell/ButtonCell/ButtonCell.stories.d.ts +17 -0
  74. package/dist/esm/lib/components/table/components/TableCell/CTACell/CTACell.d.ts +9 -0
  75. package/dist/esm/lib/components/table/components/TableCell/CTACell/CTACell.stories.d.ts +17 -0
  76. package/dist/esm/lib/components/table/components/TableCell/TableCell.d.ts +5 -17
  77. package/dist/esm/lib/components/table/types.d.ts +11 -2
  78. package/dist/esm/lib/components/table/utils/useTableNavigation/useTableNavigation.d.ts +1 -2
  79. package/dist/esm/{useTableNavigation-8e50b121.js → useTableNavigation-2899712c.js} +12 -16
  80. package/dist/esm/useTableNavigation-2899712c.js.map +1 -0
  81. package/package.json +1 -1
  82. package/src/lib/components/table/Table.stories.tsx +41 -5
  83. package/src/lib/components/table/Table.test.tsx +1 -1
  84. package/src/lib/components/table/Table.tsx +17 -8
  85. package/src/lib/components/table/components/TableCell/BaseCell/BaseCell.module.scss +36 -0
  86. package/src/lib/components/table/components/TableCell/BaseCell/BaseCell.stories.tsx +45 -0
  87. package/src/lib/components/table/components/TableCell/BaseCell/BaseCell.tsx +160 -0
  88. package/src/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.module.scss +44 -0
  89. package/src/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.stories.tsx +29 -0
  90. package/src/lib/components/table/components/TableCell/BaseCell/MiniProgressBar/MiniProgressBar.tsx +35 -0
  91. package/src/lib/components/table/components/TableCell/ButtonCell/ButtonCell.module.scss +43 -0
  92. package/src/lib/components/table/components/TableCell/ButtonCell/ButtonCell.stories.tsx +65 -0
  93. package/src/lib/components/table/components/TableCell/ButtonCell/ButtonCell.tsx +40 -0
  94. package/src/lib/components/table/components/TableCell/CTACell/CTACell.module.scss +3 -0
  95. package/src/lib/components/table/components/TableCell/CTACell/CTACell.stories.tsx +34 -0
  96. package/src/lib/components/table/components/TableCell/CTACell/CTACell.tsx +40 -0
  97. package/src/lib/components/table/components/TableCell/TableCell.module.scss +0 -43
  98. package/src/lib/components/table/components/TableCell/TableCell.test.tsx +25 -13
  99. package/src/lib/components/table/components/TableCell/TableCell.tsx +16 -122
  100. package/src/lib/components/table/components/TableContents/TableContents.test.tsx +2 -2
  101. package/src/lib/components/table/components/TableSection/TableSection.test.tsx +3 -3
  102. package/src/lib/components/table/components/TableSection/TableSection.tsx +40 -13
  103. package/src/lib/components/table/types.ts +9 -2
  104. package/src/lib/components/table/utils/useTableNavigation/useTableNavigation.test.tsx +0 -4
  105. package/src/lib/components/table/utils/useTableNavigation/useTableNavigation.ts +13 -20
  106. package/dist/esm/useTableNavigation-8e50b121.js.map +0 -1
@@ -1,23 +1,31 @@
1
- import { a as __assign } from '../../../../tslib.es6-a39f91fc.js';
2
- import { jsx, jsxs } from 'react/jsx-runtime';
3
- import { Button } from '../../../button/index.js';
4
- import CheckIcon from '../../../icon/icons/Check.js';
5
- import InfoIcon from '../../../icon/icons/Info.js';
6
- import StarFilledIcon from '../../../icon/icons/StarFilled.js';
7
- import XIcon from '../../../icon/icons/X.js';
8
- import ZapFilledIcon from '../../../icon/icons/ZapFilled.js';
1
+ import { b as __rest, a as __assign } from '../../../../tslib.es6-a39f91fc.js';
2
+ import { jsxs, jsx } from 'react/jsx-runtime';
9
3
  import { c as classNames } from '../../../../index-6ea95111.js';
10
4
  import { s as styleInject } from '../../../../style-inject.es-1f59c1d0.js';
5
+ import { BaseCell } from './BaseCell/BaseCell.js';
6
+ import { CTACell } from './CTACell/CTACell.js';
7
+ import { ButtonCell } from './ButtonCell/ButtonCell.js';
8
+ import '../../../icon/icons/Check.js';
11
9
  import 'react';
12
10
  import '../../../icon/IconWrapper/IconWrapper.js';
11
+ import '../../../icon/icons/StarFilled.js';
12
+ import '../../../icon/icons/X.js';
13
+ import '../../../icon/icons/ZapFilled.js';
14
+ import './BaseCell/MiniProgressBar/MiniProgressBar.js';
15
+ import '../../../../index-3d286178.js';
16
+ import '../../../../_commonjsHelpers-4730bd53.js';
17
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
18
+ import '../../../icon/icons/Info.js';
19
+ import '../../../../index-5e72c3d4.js';
20
+ import '../../../button/index.js';
13
21
 
14
- var css_248z = ".TableCell-module_button__2MKH1 {\n min-height: initial;\n height: initial;\n width: initial;\n padding: 0;\n}\n\n.TableCell-module_icon__2o49x {\n margin: 2px;\n}\n\n.TableCell-module_th__2rjCU {\n vertical-align: middle;\n scroll-snap-align: end;\n width: 50%;\n}\n@media (min-width: 34rem) {\n .TableCell-module_th__2rjCU {\n width: auto;\n scroll-snap-align: unset;\n }\n}\n\n.TableCell-module_thRow__3Qp3k {\n position: sticky;\n top: 0;\n}\n\n.TableCell-module_thCol__34DMO {\n text-align: left;\n}\n\n.TableCell-module_fixedCell__cL3-m {\n position: sticky;\n left: 0;\n z-index: 2;\n}\n.TableCell-module_fixedCell__cL3-m:after {\n content: \"\";\n position: absolute;\n top: 0;\n bottom: 0;\n right: 0;\n width: 1px;\n background-color: #f5f6fb;\n}\n\n.TableCell-module_topLeftCell__3npat {\n position: relative;\n display: none;\n}\n.TableCell-module_topLeftCell__3npat:after {\n content: \"\";\n display: block;\n position: absolute;\n top: calc( 50% + 16px );\n height: 4px;\n width: 100%;\n max-width: 140px;\n background-color: #8e8cee;\n}\n@media (min-width: 34rem) {\n .TableCell-module_topLeftCell__3npat {\n display: flex;\n }\n}";
15
- var styles = {"button":"TableCell-module_button__2MKH1","icon":"TableCell-module_icon__2o49x","th":"TableCell-module_th__2rjCU","thRow":"TableCell-module_thRow__3Qp3k","thCol":"TableCell-module_thCol__34DMO","fixedCell":"TableCell-module_fixedCell__cL3-m","topLeftCell":"TableCell-module_topLeftCell__3npat"};
22
+ var css_248z = ".TableCell-module_th__2rjCU {\n vertical-align: middle;\n scroll-snap-align: end;\n width: 50%;\n}\n@media (min-width: 34rem) {\n .TableCell-module_th__2rjCU {\n width: auto;\n scroll-snap-align: unset;\n }\n}\n\n.TableCell-module_fixedCell__cL3-m {\n position: sticky;\n left: 0;\n z-index: 2;\n}\n.TableCell-module_fixedCell__cL3-m:after {\n content: \"\";\n position: absolute;\n top: 0;\n bottom: 0;\n right: 0;\n width: 1px;\n background-color: #f5f6fb;\n}";
23
+ var styles = {"th":"TableCell-module_th__2rjCU","fixedCell":"TableCell-module_fixedCell__cL3-m"};
16
24
  styleInject(css_248z);
17
25
 
18
26
  var TableCell = function (_a) {
19
27
  var _b;
20
- var _c = _a.align, align = _c === void 0 ? 'center' : _c, checkmarkValue = _a.checkmarkValue, _d = _a.content, content = _d === void 0 ? '' : _d, _e = _a.isFirstCellInRow, isFirstCellInRow = _e === void 0 ? false : _e, _f = _a.isHeader, isHeader = _f === void 0 ? false : _f, _g = _a.isNavigation, isNavigation = _g === void 0 ? false : _g, _h = _a.isTopLeftCell, isTopLeftCell = _h === void 0 ? false : _h, _j = _a.modalContent, modalContent = _j === void 0 ? '' : _j, openModal = _a.openModal, rating = _a.rating, _k = _a.subContent, subContent = _k === void 0 ? '' : _k;
28
+ var _c = _a.isFirstCellInRow, isFirstCellInRow = _c === void 0 ? false : _c, _d = _a.isHeader, isHeader = _d === void 0 ? false : _d, _e = _a.isNavigation, isNavigation = _e === void 0 ? false : _e, _f = _a.isTopLeftCell, isTopLeftCell = _f === void 0 ? false : _f, cellProps = __rest(_a, ["isFirstCellInRow", "isHeader", "isNavigation", "isTopLeftCell"]);
21
29
  // prettier-ignore
22
30
  var Tag = isNavigation
23
31
  ? 'div'
@@ -29,19 +37,12 @@ var TableCell = function (_a) {
29
37
  var scope = {
30
38
  scope: thScope,
31
39
  };
32
- var alignClassName = {
33
- center: 'ta-center jc-center',
34
- left: 'ta-left jc-start',
35
- right: 'ta-right',
36
- }[align];
37
- var validRatingValues = [1, 2, 3];
38
- var SelectedIcon = (rating === null || rating === void 0 ? void 0 : rating.type) === 'zap' ? ZapFilledIcon : StarFilledIcon;
39
- return (jsx(Tag, __assign({}, scope, { className: classNames('bg-white py24 px8', styles.th, (_b = {
40
+ return (jsxs(Tag, __assign({}, scope, { className: classNames('bg-white py24 px8', styles.th, (_b = {
40
41
  'ta-left': isFirstCellInRow
41
42
  },
42
43
  _b[styles.fixedCell] = isFirstCellInRow,
43
44
  _b.pl32 = isFirstCellInRow,
44
- _b)), children: jsxs("div", { className: "d-flex fd-column gap8", children: [jsxs("div", { className: classNames('d-flex gap8 ai-center', alignClassName), children: [(rating === null || rating === void 0 ? void 0 : rating.value) && (jsx("span", { "data-testid": "table-cell-rating", title: "".concat(rating === null || rating === void 0 ? void 0 : rating.value, " out of 3"), children: validRatingValues.map(function (value) { return (jsx(SelectedIcon, { "aria-hidden": "true", color: value <= (rating === null || rating === void 0 ? void 0 : rating.value) ? 'primary-500' : 'grey-400', className: styles.icon }, value)); }) })), checkmarkValue !== undefined && (jsx("span", { title: checkmarkValue ? 'Yes' : 'No', children: checkmarkValue ? (jsx(CheckIcon, { "data-testid": "table-cell-boolean-yes", size: 24, "aria-hidden": true, color: "primary-500" })) : (jsx(XIcon, { "data-testid": "table-cell-boolean-no", size: 24, "aria-hidden": true, color: "grey-400" })) })), content && !isTopLeftCell && (jsx("div", { className: "p-p", "data-testid": "table-cell-content", children: content })), content && isTopLeftCell && (jsx("div", { "aria-hidden": true, className: classNames('tc-grey-800 p-h2 p--serif', styles.topLeftCell), children: content })), modalContent && openModal && (jsx(Button, { className: styles.button, hideLabel: true, leftIcon: jsx(InfoIcon, { size: 20 }), onClick: function () { return openModal(modalContent); }, type: "button", variant: "textColor", children: "View more info" }))] }), subContent && (jsx("div", { className: classNames('d-flex p-p--small tc-grey-500', alignClassName), children: subContent }))] }) })));
45
+ _b)), children: [!cellProps.type && (jsx(BaseCell, __assign({}, cellProps, { contentFontVariant: isTopLeftCell ? 'BIG_WITH_UNDERLINE' : 'NORMAL' }))), cellProps.type === 'CTA' && jsx(CTACell, __assign({}, cellProps)), cellProps.type === 'BUTTON' && jsx(ButtonCell, __assign({}, cellProps))] })));
45
46
  };
46
47
 
47
48
  export { TableCell };
@@ -1 +1 @@
1
- {"version":3,"file":"TableCell.js","sources":["../../../../../../../src/lib/components/table/components/TableCell/TableCell.tsx"],"sourcesContent":["import { ReactNode } from 'react';\nimport { Button } from '../../../button';\nimport {\n CheckIcon,\n InfoIcon,\n StarFilledIcon,\n XIcon,\n ZapFilledIcon,\n} from '../../../icon';\nimport classNames from 'classnames';\n\nimport styles from './TableCell.module.scss';\n\ninterface BaseTableCellProps {\n align?: 'center' | 'left' | 'right';\n checkmarkValue?: boolean;\n content?: ReactNode;\n modalContent?: ReactNode;\n openModal?: (modalContent: ReactNode) => void;\n subContent?: ReactNode;\n rating?: {\n value: number;\n type: 'zap' | 'star';\n };\n}\n\ninterface PositionalTableCellProps {\n isHeader?: boolean;\n isFirstCellInRow?: boolean;\n isTopLeftCell?: boolean;\n isNavigation?: boolean;\n}\n\nexport type TableCellProps = BaseTableCellProps & PositionalTableCellProps;\n\nconst TableCell = ({\n align = 'center',\n checkmarkValue,\n content = '',\n isFirstCellInRow = false,\n isHeader = false,\n isNavigation = false,\n isTopLeftCell = false,\n modalContent = '',\n openModal,\n rating,\n subContent = '',\n}: TableCellProps) => {\n // prettier-ignore\n const Tag = isNavigation\n ? 'div'\n : isHeader || isFirstCellInRow ? 'th' : 'td';\n\n // prettier-ignore\n const thScope = isHeader\n ? 'col'\n : isFirstCellInRow ? 'row' : undefined;\n\n const scope = {\n scope: thScope,\n };\n\n const alignClassName = {\n center: 'ta-center jc-center',\n left: 'ta-left jc-start',\n right: 'ta-right',\n }[align];\n\n const validRatingValues: number[] = [1, 2, 3];\n const SelectedIcon = rating?.type === 'zap' ? ZapFilledIcon : StarFilledIcon;\n\n return (\n <Tag\n {...scope}\n className={classNames('bg-white py24 px8', styles.th, {\n 'ta-left': isFirstCellInRow,\n [styles.fixedCell]: isFirstCellInRow,\n pl32: isFirstCellInRow,\n })}\n >\n <div className=\"d-flex fd-column gap8\">\n <div className={classNames('d-flex gap8 ai-center', alignClassName)}>\n {rating?.value && (\n <span\n data-testid=\"table-cell-rating\"\n title={`${rating?.value} out of 3`}\n >\n {validRatingValues.map((value) => (\n <SelectedIcon\n aria-hidden=\"true\"\n key={value}\n color={value <= rating?.value ? 'primary-500' : 'grey-400'}\n className={styles.icon}\n />\n ))}\n </span>\n )}\n\n {checkmarkValue !== undefined && (\n <span title={checkmarkValue ? 'Yes' : 'No'}>\n {checkmarkValue ? (\n <CheckIcon\n data-testid=\"table-cell-boolean-yes\"\n size={24}\n aria-hidden\n color=\"primary-500\"\n />\n ) : (\n <XIcon\n data-testid=\"table-cell-boolean-no\"\n size={24}\n aria-hidden\n color=\"grey-400\"\n />\n )}\n </span>\n )}\n\n {content && !isTopLeftCell && (\n <div className=\"p-p\" data-testid=\"table-cell-content\">\n {content}\n </div>\n )}\n\n {content && isTopLeftCell && (\n <div\n aria-hidden\n className={classNames(\n 'tc-grey-800 p-h2 p--serif',\n styles.topLeftCell\n )}\n >\n {content}\n </div>\n )}\n\n {modalContent && openModal && (\n <Button\n className={styles.button}\n hideLabel\n leftIcon={<InfoIcon size={20} />}\n onClick={() => openModal(modalContent)}\n type=\"button\"\n variant=\"textColor\"\n >\n View more info\n </Button>\n )}\n </div>\n\n {subContent && (\n <div\n className={classNames(\n 'd-flex p-p--small tc-grey-500',\n alignClassName\n )}\n >\n {subContent}\n </div>\n )}\n </div>\n </Tag>\n );\n};\n\nexport { TableCell };\n"],"names":["_jsx","_jsxs"],"mappings":"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"}
1
+ {"version":3,"file":"TableCell.js","sources":["../../../../../../../src/lib/components/table/components/TableCell/TableCell.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport styles from './TableCell.module.scss';\nimport { BaseCell, BaseCellProps } from './BaseCell/BaseCell';\nimport { TableCellData } from '../../types';\nimport { CTACell } from './CTACell/CTACell';\nimport { ButtonCell } from './ButtonCell/ButtonCell';\n\ntype PositionalTableCellProps = {\n isHeader?: boolean;\n isFirstCellInRow?: boolean;\n isTopLeftCell?: boolean;\n isNavigation?: boolean;\n};\n\nexport type TableCellProps = TableCellData & PositionalTableCellProps;\n\nconst TableCell = ({\n isFirstCellInRow = false,\n isHeader = false,\n isNavigation = false,\n isTopLeftCell = false,\n ...cellProps\n}: TableCellProps) => {\n // prettier-ignore\n const Tag = isNavigation\n ? 'div'\n : isHeader || isFirstCellInRow ? 'th' : 'td';\n\n // prettier-ignore\n const thScope = isHeader\n ? 'col'\n : isFirstCellInRow ? 'row' : undefined;\n\n const scope = {\n scope: thScope,\n };\n\n return (\n <Tag\n {...scope}\n className={classNames('bg-white py24 px8', styles.th, {\n 'ta-left': isFirstCellInRow,\n [styles.fixedCell]: isFirstCellInRow,\n pl32: isFirstCellInRow,\n })}\n >\n {!cellProps.type && (\n <BaseCell\n {...cellProps}\n contentFontVariant={isTopLeftCell ? 'BIG_WITH_UNDERLINE' : 'NORMAL'}\n />\n )}\n {cellProps.type === 'CTA' && <CTACell {...cellProps} />}\n {cellProps.type === 'BUTTON' && <ButtonCell {...cellProps} />}\n </Tag>\n );\n};\n\nexport { TableCell };\n"],"names":["_jsxs","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;IAiBM,SAAS,GAAG,UAAC,EAMF;;IALf,IAAA,wBAAwB,EAAxB,gBAAgB,mBAAG,KAAK,KAAA,EACxB,gBAAgB,EAAhB,QAAQ,mBAAG,KAAK,KAAA,EAChB,oBAAoB,EAApB,YAAY,mBAAG,KAAK,KAAA,EACpB,qBAAqB,EAArB,aAAa,mBAAG,KAAK,KAAA,EAClB,SAAS,cALK,iEAMlB,CADa;;IAGZ,IAAM,GAAG,GAAG,YAAY;UACpB,KAAK;UACL,QAAQ,IAAI,gBAAgB,GAAG,IAAI,GAAG,IAAI,CAAC;;IAG/C,IAAM,OAAO,GAAG,QAAQ;UACpB,KAAK;UACL,gBAAgB,GAAG,KAAK,GAAG,SAAS,CAAC;IAEzC,IAAM,KAAK,GAAG;QACZ,KAAK,EAAE,OAAO;KACf,CAAC;IAEF,QACEA,KAAC,GAAG,eACE,KAAK,IACT,SAAS,EAAE,UAAU,CAAC,mBAAmB,EAAE,MAAM,CAAC,EAAE;gBAClD,SAAS,EAAE,gBAAgB;;YAC3B,GAAC,MAAM,CAAC,SAAS,IAAG,gBAAgB;YACpC,OAAI,GAAE,gBAAgB;gBACtB,aAED,CAAC,SAAS,CAAC,IAAI,KACdC,IAAC,QAAQ,eACH,SAAS,IACb,kBAAkB,EAAE,aAAa,GAAG,oBAAoB,GAAG,QAAQ,IACnE,CACH,EACA,SAAS,CAAC,IAAI,KAAK,KAAK,IAAIA,IAAC,OAAO,eAAK,SAAS,EAAI,EACtD,SAAS,CAAC,IAAI,KAAK,QAAQ,IAAIA,IAAC,UAAU,eAAK,SAAS,EAAI,KACzD,EACN;AACJ;;;;"}
@@ -1,64 +1,78 @@
1
+ import { a as __assign, b as __rest } from '../../../../tslib.es6-a39f91fc.js';
1
2
  import { jsx } from 'react/jsx-runtime';
2
3
  import { c as customRender, s as screen } from '../../../../customRender-d03c10b6.js';
3
4
  import { TableCell } from './TableCell.js';
4
- import '../../../../tslib.es6-a39f91fc.js';
5
5
  import 'react';
6
6
  import 'react-dom';
7
7
  import '../../../../_commonjsHelpers-4730bd53.js';
8
8
  import 'react-dom/test-utils';
9
- import '../../../button/index.js';
10
9
  import '../../../../index-6ea95111.js';
10
+ import '../../../../style-inject.es-1f59c1d0.js';
11
+ import './BaseCell/BaseCell.js';
11
12
  import '../../../icon/icons/Check.js';
12
13
  import '../../../icon/IconWrapper/IconWrapper.js';
13
- import '../../../../style-inject.es-1f59c1d0.js';
14
- import '../../../icon/icons/Info.js';
15
14
  import '../../../icon/icons/StarFilled.js';
16
15
  import '../../../icon/icons/X.js';
17
16
  import '../../../icon/icons/ZapFilled.js';
17
+ import './BaseCell/MiniProgressBar/MiniProgressBar.js';
18
+ import '../../../../index-3d286178.js';
19
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
20
+ import '../../../icon/icons/Info.js';
21
+ import '../../../../index-5e72c3d4.js';
22
+ import './CTACell/CTACell.js';
23
+ import './ButtonCell/ButtonCell.js';
24
+ import '../../../button/index.js';
18
25
 
19
26
  var openModal = jest.fn();
27
+ var setup = function (_a) {
28
+ if (_a === void 0) { _a = {}; }
29
+ var isNavigation = _a.isNavigation, rest = __rest(_a, ["isNavigation"]);
30
+ return customRender(isNavigation
31
+ ? jsx(TableCell, __assign({}, rest, { isNavigation: true }))
32
+ : (jsx("table", { children: jsx("tbody", { children: jsx("tr", { children: jsx(TableCell, __assign({}, rest)) }) }) })));
33
+ };
20
34
  describe('TableCell', function () {
21
35
  it('renders the component with boolean true', function () {
22
- customRender(jsx(TableCell, { checkmarkValue: true }));
36
+ setup({ checkmarkValue: true });
23
37
  expect(screen.getByTitle('Yes')).toBeInTheDocument();
24
38
  expect(screen.getByTestId('table-cell-boolean-yes')).toBeInTheDocument();
25
39
  });
26
40
  it('renders the component with boolean false', function () {
27
- customRender(jsx(TableCell, { checkmarkValue: false }));
41
+ setup({ checkmarkValue: false });
28
42
  expect(screen.getByTitle('No')).toBeInTheDocument();
29
43
  expect(screen.getByTestId('table-cell-boolean-no')).toBeInTheDocument();
30
44
  });
31
45
  it('renders the component without boolean', function () {
32
- customRender(jsx(TableCell, {}));
46
+ setup();
33
47
  expect(screen.queryByTitle('Yes')).not.toBeInTheDocument();
34
48
  expect(screen.queryByTitle('No')).not.toBeInTheDocument();
35
49
  expect(screen.queryByTestId('table-cell-boolean-yes')).not.toBeInTheDocument();
36
50
  expect(screen.queryByTestId('table-cell-boolean-no')).not.toBeInTheDocument();
37
51
  });
38
52
  it('renders the component with rating', function () {
39
- customRender(jsx(TableCell, { rating: { type: 'star', value: 2 } }));
53
+ setup({ rating: { type: 'star', value: 2 } });
40
54
  expect(screen.getByTitle('2 out of 3')).toBeInTheDocument();
41
55
  });
42
56
  it('renders the component without rating', function () {
43
- customRender(jsx(TableCell, {}));
57
+ setup();
44
58
  expect(screen.queryByTestId('table-cell-rating')).not.toBeInTheDocument();
45
59
  });
46
60
  it('renders the component with text', function () {
47
- customRender(jsx(TableCell, { content: "Sample text" }));
61
+ setup({ content: "Sample text" });
48
62
  expect(screen.getByText('Sample text')).toBeInTheDocument();
49
63
  });
50
64
  it('renders the component without text', function () {
51
- customRender(jsx(TableCell, {}));
65
+ setup();
52
66
  expect(screen.queryByTestId('table-cell-text')).not.toBeInTheDocument();
53
67
  });
54
68
  it('renders the component without info', function () {
55
- customRender(jsx(TableCell, {}));
69
+ setup();
56
70
  expect(screen.queryByText('View more info')).not.toBeInTheDocument();
57
71
  });
58
72
  it('calls openModal when info button is clicked', function () {
59
- customRender(jsx(TableCell, { modalContent: "Additional information", openModal: openModal }));
73
+ setup({ modalContent: "Additional information", openModal: openModal });
60
74
  // Click info button
61
- screen.getByText('View more info').click();
75
+ screen.getByTestId('ds-table-info-button').click();
62
76
  // Assert openModal is called with info prop
63
77
  expect(openModal).toHaveBeenCalledWith('Additional information');
64
78
  });
@@ -1 +1 @@
1
- {"version":3,"file":"TableCell.test.js","sources":["../../../../../../../src/lib/components/table/components/TableCell/TableCell.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableCell } from './TableCell';\n\nconst openModal = jest.fn();\n\ndescribe('TableCell', () => {\n it('renders the component with boolean true', () => {\n render(<TableCell checkmarkValue={true} />);\n\n expect(screen.getByTitle('Yes')).toBeInTheDocument();\n expect(screen.getByTestId('table-cell-boolean-yes')).toBeInTheDocument();\n });\n\n it('renders the component with boolean false', () => {\n render(<TableCell checkmarkValue={false} />);\n\n expect(screen.getByTitle('No')).toBeInTheDocument();\n expect(screen.getByTestId('table-cell-boolean-no')).toBeInTheDocument();\n });\n\n it('renders the component without boolean', () => {\n render(<TableCell />);\n\n expect(screen.queryByTitle('Yes')).not.toBeInTheDocument();\n expect(screen.queryByTitle('No')).not.toBeInTheDocument();\n expect(\n screen.queryByTestId('table-cell-boolean-yes')\n ).not.toBeInTheDocument();\n expect(\n screen.queryByTestId('table-cell-boolean-no')\n ).not.toBeInTheDocument();\n });\n\n it('renders the component with rating', () => {\n render(<TableCell rating={{ type: 'star', value: 2 }} />);\n\n expect(screen.getByTitle('2 out of 3')).toBeInTheDocument();\n });\n\n it('renders the component without rating', () => {\n render(<TableCell />);\n\n expect(screen.queryByTestId('table-cell-rating')).not.toBeInTheDocument();\n });\n\n it('renders the component with text', () => {\n render(<TableCell content=\"Sample text\" />);\n\n expect(screen.getByText('Sample text')).toBeInTheDocument();\n });\n\n it('renders the component without text', () => {\n render(<TableCell />);\n\n expect(screen.queryByTestId('table-cell-text')).not.toBeInTheDocument();\n });\n\n it('renders the component without info', () => {\n render(<TableCell />);\n\n expect(screen.queryByText('View more info')).not.toBeInTheDocument();\n });\n\n it('calls openModal when info button is clicked', () => {\n render(\n <TableCell modalContent=\"Additional information\" openModal={openModal} />\n );\n\n // Click info button\n screen.getByText('View more info').click();\n\n // Assert openModal is called with info prop\n expect(openModal).toHaveBeenCalledWith('Additional information');\n });\n});\n"],"names":["render","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"TableCell.test.js","sources":["../../../../../../../src/lib/components/table/components/TableCell/TableCell.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableCell, TableCellProps } from './TableCell';\n\nconst openModal = jest.fn();\n\nconst setup = ({ isNavigation, ...rest }: TableCellProps = {}) => render(\n isNavigation \n ? <TableCell {...rest} isNavigation />\n : (\n <table>\n <tbody>\n <tr>\n <TableCell {...rest} />\n </tr>\n </tbody>\n </table> \n )\n );\n\ndescribe('TableCell', () => {\n it('renders the component with boolean true', () => {\n setup({ checkmarkValue: true });\n\n expect(screen.getByTitle('Yes')).toBeInTheDocument();\n expect(screen.getByTestId('table-cell-boolean-yes')).toBeInTheDocument();\n });\n\n it('renders the component with boolean false', () => {\n setup({ checkmarkValue: false });\n\n expect(screen.getByTitle('No')).toBeInTheDocument();\n expect(screen.getByTestId('table-cell-boolean-no')).toBeInTheDocument();\n });\n\n it('renders the component without boolean', () => {\n setup();\n\n expect(screen.queryByTitle('Yes')).not.toBeInTheDocument();\n expect(screen.queryByTitle('No')).not.toBeInTheDocument();\n expect(\n screen.queryByTestId('table-cell-boolean-yes')\n ).not.toBeInTheDocument();\n expect(\n screen.queryByTestId('table-cell-boolean-no')\n ).not.toBeInTheDocument();\n });\n\n it('renders the component with rating', () => {\n setup({ rating: { type: 'star', value: 2 } });\n\n expect(screen.getByTitle('2 out of 3')).toBeInTheDocument();\n });\n\n it('renders the component without rating', () => {\n setup();\n\n expect(screen.queryByTestId('table-cell-rating')).not.toBeInTheDocument();\n });\n\n it('renders the component with text', () => {\n setup({ content: \"Sample text\" });\n\n expect(screen.getByText('Sample text')).toBeInTheDocument();\n });\n\n it('renders the component without text', () => {\n setup();\n\n expect(screen.queryByTestId('table-cell-text')).not.toBeInTheDocument();\n });\n\n it('renders the component without info', () => {\n setup();\n\n expect(screen.queryByText('View more info')).not.toBeInTheDocument();\n });\n\n it('calls openModal when info button is clicked', () => {\n setup({ modalContent: \"Additional information\", openModal });\n\n // Click info button\n screen.getByTestId('ds-table-info-button').click();\n\n // Assert openModal is called with info prop\n expect(openModal).toHaveBeenCalledWith('Additional information');\n });\n});\n"],"names":["render","_jsx"],"mappings":"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"}
@@ -9,13 +9,21 @@ import { s as styleInject } from '../../../../style-inject.es-1f59c1d0.js';
9
9
  import { c as classNames } from '../../../../index-6ea95111.js';
10
10
  import { C as Collapsible } from '../../../../Collapsible-a355828b.js';
11
11
  import '../TableCell/TableCell.js';
12
- import '../../../button/index.js';
12
+ import '../TableCell/BaseCell/BaseCell.js';
13
13
  import '../../../icon/icons/Check.js';
14
14
  import '../../../icon/IconWrapper/IconWrapper.js';
15
- import '../../../icon/icons/Info.js';
16
15
  import '../../../icon/icons/StarFilled.js';
17
16
  import '../../../icon/icons/X.js';
18
17
  import '../../../icon/icons/ZapFilled.js';
18
+ import '../TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js';
19
+ import '../../../../index-3d286178.js';
20
+ import '../../../../_commonjsHelpers-4730bd53.js';
21
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
22
+ import '../../../icon/icons/Info.js';
23
+ import '../../../../index-5e72c3d4.js';
24
+ import '../TableCell/CTACell/CTACell.js';
25
+ import '../TableCell/ButtonCell/ButtonCell.js';
26
+ import '../../../button/index.js';
19
27
  import '../../../icon/icons/ChevronRight.js';
20
28
  import '../../../../index-a0ef2ab4.js';
21
29
 
@@ -1 +1 @@
1
- {"version":3,"file":"TableContents.js","sources":["../../../../../../../src/lib/components/table/components/TableContents/TableContents.tsx"],"sourcesContent":["import { useState } from 'react';\nimport { TableSection } from '../TableSection/TableSection';\nimport { ChevronDownIcon, ChevronUpIcon } from '../../../icon';\nimport { Card } from '../../../cards/card';\n\nimport styles from './TableContents.module.scss';\nimport classNames from 'classnames';\nimport { Collapsible } from './Collapsible';\nimport { ModalFunction, TableData } from '../../types';\n\nexport interface TableContentsProps {\n className?: string;\n collapsibleSections?: boolean;\n tableData: TableData;\n hideDetails?: boolean;\n isMobile?: boolean;\n openModal?: ModalFunction;\n shouldHideDetails?: boolean;\n title: string;\n}\n\nconst TableContents = ({\n className,\n collapsibleSections,\n tableData,\n hideDetails,\n isMobile,\n openModal,\n shouldHideDetails,\n title,\n}: TableContentsProps) => {\n const [isSectionOpen, setOpenSection] = useState<number | null>(null);\n const firstHeadRow = tableData?.[0]?.rows?.[0];\n const tableWidth = isMobile ? `${firstHeadRow?.length * 50}%` : '';\n const handleToggleSection = (index: number) => {\n setOpenSection((currentSection) =>\n currentSection === index ? null : index\n );\n };\n\n return (\n <div style={{ width: tableWidth }}>\n {tableData.map(({ rows, section = {} }, index) => {\n const isFirstSection = index === 0;\n const isExpanded = !collapsibleSections\n ? true\n : isSectionOpen === index || isFirstSection;\n const isVisible = hideDetails ? !shouldHideDetails : true;\n\n return (\n (isFirstSection || isVisible) && (\n <div key={index}>\n {section?.title && (\n <div className={styles.cardWrapper}>\n <div className={classNames(styles.card, 'p8')}>\n <Card\n actionIcon={\n isExpanded ? (\n <ChevronUpIcon size={24} />\n ) : (\n <ChevronDownIcon size={24} />\n )\n }\n aria-expanded={isExpanded ? 'true' : 'false'}\n aria-hidden\n classNames={{\n wrapper: 'bg-grey-200',\n icon: 'tc-grey-900',\n }}\n dropShadow={false}\n icon={section?.icon}\n title={section.title}\n titleVariant=\"medium\"\n {...(collapsibleSections\n ? {\n onClick: () => handleToggleSection(index),\n }\n : {})}\n />\n </div>\n </div>\n )}\n\n <Collapsible isExpanded={isExpanded} isMobile={isMobile}>\n <TableSection\n className={classNames(className, 'mb24')}\n tableCellRows={\n isFirstSection ? rows : [firstHeadRow, ...rows]\n }\n hideHeader\n openModal={openModal}\n title={`${title}${\n section?.title ? ` - ${section.title}` : ''\n }`}\n width={tableWidth}\n />\n </Collapsible>\n </div>\n )\n );\n })}\n </div>\n );\n};\n\nexport { TableContents };\n"],"names":["_jsx","_jsxs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;IAqBM,aAAa,GAAG,UAAC,EASF;;QARnB,SAAS,eAAA,EACT,mBAAmB,yBAAA,EACnB,SAAS,eAAA,EACT,WAAW,iBAAA,EACX,QAAQ,cAAA,EACR,SAAS,eAAA,EACT,iBAAiB,uBAAA,EACjB,KAAK,WAAA;IAEC,IAAA,KAAkC,QAAQ,CAAgB,IAAI,CAAC,EAA9D,aAAa,QAAA,EAAE,cAAc,QAAiC,CAAC;IACtE,IAAM,YAAY,GAAG,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,CAAC,CAAC,0CAAE,IAAI,0CAAG,CAAC,CAAC,CAAC;IAC/C,IAAM,UAAU,GAAG,QAAQ,GAAG,UAAG,CAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,MAAM,IAAG,EAAE,MAAG,GAAG,EAAE,CAAC;IACnE,IAAM,mBAAmB,GAAG,UAAC,KAAa;QACxC,cAAc,CAAC,UAAC,cAAc;YAC5B,OAAA,cAAc,KAAK,KAAK,GAAG,IAAI,GAAG,KAAK;SAAA,CACxC,CAAC;KACH,CAAC;IAEF,QACEA,aAAK,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,YAC9B,SAAS,CAAC,GAAG,CAAC,UAAC,EAAsB,EAAE,KAAK;gBAA3B,IAAI,UAAA,EAAE,eAAY,EAAZ,OAAO,mBAAG,EAAE,KAAA;YAClC,IAAM,cAAc,GAAG,KAAK,KAAK,CAAC,CAAC;YACnC,IAAM,UAAU,GAAG,CAAC,mBAAmB;kBACnC,IAAI;kBACJ,aAAa,KAAK,KAAK,IAAI,cAAc,CAAC;YAC9C,IAAM,SAAS,GAAG,WAAW,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAE1D,QACE,CAAC,cAAc,IAAI,SAAS,MAC1BC,yBACG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,MACbD,aAAK,SAAS,EAAE,MAAM,CAAC,WAAW,YAChCA,aAAK,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,YAC3CA,IAAC,IAAI,aACH,UAAU,EACR,UAAU,IACRA,IAAC,aAAa,IAAC,IAAI,EAAE,EAAE,GAAI,KAE3BA,IAAC,eAAe,IAAC,IAAI,EAAE,EAAE,GAAI,CAC9B,mBAEY,UAAU,GAAG,MAAM,GAAG,OAAO,uBAE5C,UAAU,EAAE;oCACV,OAAO,EAAE,aAAa;oCACtB,IAAI,EAAE,aAAa;iCACpB,EACD,UAAU,EAAE,KAAK,EACjB,IAAI,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,EACnB,KAAK,EAAE,OAAO,CAAC,KAAK,EACpB,YAAY,EAAC,QAAQ,KAChB,mBAAmB;kCACpB;oCACE,OAAO,EAAE,cAAM,OAAA,mBAAmB,CAAC,KAAK,CAAC,GAAA;iCAC1C;kCACD,EAAE,GACN,GACE,GACF,CACP,EAEDA,IAAC,WAAW,IAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,YACrDA,IAAC,YAAY,IACX,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,MAAM,CAAC,EACxC,aAAa,EACX,cAAc,GAAG,IAAI,kBAAI,YAAY,GAAK,IAAI,OAAC,EAEjD,UAAU,QACV,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,UAAG,KAAK,SACb,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,IAAG,aAAM,OAAO,CAAC,KAAK,CAAE,GAAG,EAAE,CAC3C,EACF,KAAK,EAAE,UAAU,GACjB,GACU,KA7CN,KAAK,CA8CT,CACP,EACD;SACH,CAAC,GACE,EACN;AACJ;;;;"}
1
+ {"version":3,"file":"TableContents.js","sources":["../../../../../../../src/lib/components/table/components/TableContents/TableContents.tsx"],"sourcesContent":["import { useState } from 'react';\nimport { TableSection } from '../TableSection/TableSection';\nimport { ChevronDownIcon, ChevronUpIcon } from '../../../icon';\nimport { Card } from '../../../cards/card';\n\nimport styles from './TableContents.module.scss';\nimport classNames from 'classnames';\nimport { Collapsible } from './Collapsible';\nimport { ModalFunction, TableData } from '../../types';\n\nexport interface TableContentsProps {\n className?: string;\n collapsibleSections?: boolean;\n tableData: TableData;\n hideDetails?: boolean;\n isMobile?: boolean;\n openModal?: ModalFunction;\n shouldHideDetails?: boolean;\n title: string;\n}\n\nconst TableContents = ({\n className,\n collapsibleSections,\n tableData,\n hideDetails,\n isMobile,\n openModal,\n shouldHideDetails,\n title,\n}: TableContentsProps) => {\n const [isSectionOpen, setOpenSection] = useState<number | null>(null);\n const firstHeadRow = tableData?.[0]?.rows?.[0];\n const tableWidth = isMobile ? `${firstHeadRow?.length * 50}%` : '';\n const handleToggleSection = (index: number) => {\n setOpenSection((currentSection) =>\n currentSection === index ? null : index\n );\n };\n\n return (\n <div style={{ width: tableWidth }}>\n {tableData.map(({ rows, section = {} }, index) => {\n const isFirstSection = index === 0;\n const isExpanded = !collapsibleSections\n ? true\n : isSectionOpen === index || isFirstSection;\n const isVisible = hideDetails ? !shouldHideDetails : true;\n\n return (\n (isFirstSection || isVisible) && (\n <div key={index}>\n {section?.title && (\n <div className={styles.cardWrapper}>\n <div className={classNames(styles.card, 'p8')}>\n <Card\n actionIcon={\n isExpanded ? (\n <ChevronUpIcon size={24} />\n ) : (\n <ChevronDownIcon size={24} />\n )\n }\n aria-expanded={isExpanded ? 'true' : 'false'}\n aria-hidden\n classNames={{\n wrapper: 'bg-grey-200',\n icon: 'tc-grey-900',\n }}\n dropShadow={false}\n icon={section?.icon}\n title={section.title}\n titleVariant=\"medium\"\n {...(collapsibleSections\n ? {\n onClick: () => handleToggleSection(index),\n }\n : {})}\n />\n </div>\n </div>\n )}\n\n <Collapsible isExpanded={isExpanded} isMobile={isMobile}>\n <TableSection\n className={classNames(className, 'mb24')}\n tableCellRows={\n isFirstSection ? rows : [firstHeadRow, ...rows]\n }\n hideHeader\n openModal={openModal}\n title={`${title}${\n section?.title ? ` - ${section.title}` : ''\n }`}\n width={tableWidth}\n />\n </Collapsible>\n </div>\n )\n );\n })}\n </div>\n );\n};\n\nexport { TableContents };\n"],"names":["_jsx","_jsxs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAqBM,aAAa,GAAG,UAAC,EASF;;QARnB,SAAS,eAAA,EACT,mBAAmB,yBAAA,EACnB,SAAS,eAAA,EACT,WAAW,iBAAA,EACX,QAAQ,cAAA,EACR,SAAS,eAAA,EACT,iBAAiB,uBAAA,EACjB,KAAK,WAAA;IAEC,IAAA,KAAkC,QAAQ,CAAgB,IAAI,CAAC,EAA9D,aAAa,QAAA,EAAE,cAAc,QAAiC,CAAC;IACtE,IAAM,YAAY,GAAG,MAAA,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,CAAC,CAAC,0CAAE,IAAI,0CAAG,CAAC,CAAC,CAAC;IAC/C,IAAM,UAAU,GAAG,QAAQ,GAAG,UAAG,CAAA,YAAY,aAAZ,YAAY,uBAAZ,YAAY,CAAE,MAAM,IAAG,EAAE,MAAG,GAAG,EAAE,CAAC;IACnE,IAAM,mBAAmB,GAAG,UAAC,KAAa;QACxC,cAAc,CAAC,UAAC,cAAc;YAC5B,OAAA,cAAc,KAAK,KAAK,GAAG,IAAI,GAAG,KAAK;SAAA,CACxC,CAAC;KACH,CAAC;IAEF,QACEA,aAAK,KAAK,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,YAC9B,SAAS,CAAC,GAAG,CAAC,UAAC,EAAsB,EAAE,KAAK;gBAA3B,IAAI,UAAA,EAAE,eAAY,EAAZ,OAAO,mBAAG,EAAE,KAAA;YAClC,IAAM,cAAc,GAAG,KAAK,KAAK,CAAC,CAAC;YACnC,IAAM,UAAU,GAAG,CAAC,mBAAmB;kBACnC,IAAI;kBACJ,aAAa,KAAK,KAAK,IAAI,cAAc,CAAC;YAC9C,IAAM,SAAS,GAAG,WAAW,GAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAE1D,QACE,CAAC,cAAc,IAAI,SAAS,MAC1BC,yBACG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,MACbD,aAAK,SAAS,EAAE,MAAM,CAAC,WAAW,YAChCA,aAAK,SAAS,EAAE,UAAU,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,YAC3CA,IAAC,IAAI,aACH,UAAU,EACR,UAAU,IACRA,IAAC,aAAa,IAAC,IAAI,EAAE,EAAE,GAAI,KAE3BA,IAAC,eAAe,IAAC,IAAI,EAAE,EAAE,GAAI,CAC9B,mBAEY,UAAU,GAAG,MAAM,GAAG,OAAO,uBAE5C,UAAU,EAAE;oCACV,OAAO,EAAE,aAAa;oCACtB,IAAI,EAAE,aAAa;iCACpB,EACD,UAAU,EAAE,KAAK,EACjB,IAAI,EAAE,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,IAAI,EACnB,KAAK,EAAE,OAAO,CAAC,KAAK,EACpB,YAAY,EAAC,QAAQ,KAChB,mBAAmB;kCACpB;oCACE,OAAO,EAAE,cAAM,OAAA,mBAAmB,CAAC,KAAK,CAAC,GAAA;iCAC1C;kCACD,EAAE,GACN,GACE,GACF,CACP,EAEDA,IAAC,WAAW,IAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,YACrDA,IAAC,YAAY,IACX,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,MAAM,CAAC,EACxC,aAAa,EACX,cAAc,GAAG,IAAI,kBAAI,YAAY,GAAK,IAAI,OAAC,EAEjD,UAAU,QACV,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,UAAG,KAAK,SACb,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,IAAG,aAAM,OAAO,CAAC,KAAK,CAAE,GAAG,EAAE,CAC3C,EACF,KAAK,EAAE,UAAU,GACjB,GACU,KA7CN,KAAK,CA8CT,CACP,EACD;SACH,CAAC,GACE,EACN;AACJ;;;;"}
@@ -10,13 +10,20 @@ import '../TableSection/TableSection.js';
10
10
  import '../../../../index-6ea95111.js';
11
11
  import '../../../../style-inject.es-1f59c1d0.js';
12
12
  import '../TableCell/TableCell.js';
13
- import '../../../button/index.js';
13
+ import '../TableCell/BaseCell/BaseCell.js';
14
14
  import '../../../icon/icons/Check.js';
15
15
  import '../../../icon/IconWrapper/IconWrapper.js';
16
- import '../../../icon/icons/Info.js';
17
16
  import '../../../icon/icons/StarFilled.js';
18
17
  import '../../../icon/icons/X.js';
19
18
  import '../../../icon/icons/ZapFilled.js';
19
+ import '../TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js';
20
+ import '../../../../index-3d286178.js';
21
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
22
+ import '../../../icon/icons/Info.js';
23
+ import '../../../../index-5e72c3d4.js';
24
+ import '../TableCell/CTACell/CTACell.js';
25
+ import '../TableCell/ButtonCell/ButtonCell.js';
26
+ import '../../../button/index.js';
20
27
  import '../../../icon/icons/ChevronDown.js';
21
28
  import '../../../icon/icons/ChevronUp.js';
22
29
  import '../../../cards/card/index.js';
@@ -1 +1 @@
1
- {"version":3,"file":"TableContents.test.js","sources":["../../../../../../../src/lib/components/table/components/TableContents/TableContents.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableContents, TableSectionProps } from './TableContents';\n\nconst mockData: TableSectionProps['tableData'] = [\n {\n rows: [\n [{ content: 'Item 1.1.1' }, { content: 'Item 1.1.2' }],\n [{ content: 'Item 1.2.1' }, { content: 'Item 1.2.2' }],\n ],\n },\n {\n section: {\n title: 'Section 2',\n },\n rows: [\n [{ content: 'Item 2.1.1' }, { content: 'Item 2.1.2' }],\n [{ content: 'Item 2.2.1' }, { content: 'Item 2.2.2' }],\n ],\n },\n];\n\ndescribe('TableContents', () => {\n it('renders the table sections with sections', () => {\n render(\n <TableContents collapsibleSections tableData={mockData} title=\"Table\" />\n );\n\n expect(screen.getByText('Section 2')).toBeInTheDocument();\n });\n\n it('renders the table sections with sections data', () => {\n render(\n <TableContents collapsibleSections tableData={mockData} title=\"Table\" />\n );\n\n expect(screen.getByText('Item 1.2.1')).toBeInTheDocument();\n expect(screen.getByText('Item 1.2.2')).toBeInTheDocument();\n expect(screen.getByText('Item 2.1.2')).toBeInTheDocument();\n expect(screen.getByText('Item 2.2.1')).toBeInTheDocument();\n });\n\n it('hides the table sections when hideDetails and shouldHideDetails is true', () => {\n render(\n <TableContents\n hideDetails\n shouldHideDetails\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.queryByText('Section 2')).not.toBeInTheDocument();\n expect(screen.queryByText('Item 2.1.1')).not.toBeInTheDocument();\n });\n\n it('hides the table sections details when collapsibleSections is true', () => {\n render(\n <TableContents\n collapsibleSections\n isMobile\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.getByText('Section 2')).toBeVisible();\n expect(screen.queryByText('Item 2.1.1')).not.toBeVisible();\n });\n\n it('shows the table sections when hideDetails is collapsibleSections true has expanded ', async () => {\n const { user } = render(\n <TableContents\n collapsibleSections\n isMobile\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.queryByText('Item 2.1.1')).not.toBeVisible();\n\n await user.click(screen.getByText('Section 2'));\n\n expect(screen.getByText('Item 2.1.1')).toBeVisible();\n });\n});\n"],"names":["render","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"TableContents.test.js","sources":["../../../../../../../src/lib/components/table/components/TableContents/TableContents.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableContents, TableContentsProps } from './TableContents';\n\nconst mockData: TableContentsProps['tableData'] = [\n {\n rows: [\n [{ content: 'Item 1.1.1' }, { content: 'Item 1.1.2' }],\n [{ content: 'Item 1.2.1' }, { content: 'Item 1.2.2' }],\n ],\n },\n {\n section: {\n title: 'Section 2',\n },\n rows: [\n [{ content: 'Item 2.1.1' }, { content: 'Item 2.1.2' }],\n [{ content: 'Item 2.2.1' }, { content: 'Item 2.2.2' }],\n ],\n },\n];\n\ndescribe('TableContents', () => {\n it('renders the table sections with sections', () => {\n render(\n <TableContents collapsibleSections tableData={mockData} title=\"Table\" />\n );\n\n expect(screen.getByText('Section 2')).toBeInTheDocument();\n });\n\n it('renders the table sections with sections data', () => {\n render(\n <TableContents collapsibleSections tableData={mockData} title=\"Table\" />\n );\n\n expect(screen.getByText('Item 1.2.1')).toBeInTheDocument();\n expect(screen.getByText('Item 1.2.2')).toBeInTheDocument();\n expect(screen.getByText('Item 2.1.2')).toBeInTheDocument();\n expect(screen.getByText('Item 2.2.1')).toBeInTheDocument();\n });\n\n it('hides the table sections when hideDetails and shouldHideDetails is true', () => {\n render(\n <TableContents\n hideDetails\n shouldHideDetails\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.queryByText('Section 2')).not.toBeInTheDocument();\n expect(screen.queryByText('Item 2.1.1')).not.toBeInTheDocument();\n });\n\n it('hides the table sections details when collapsibleSections is true', () => {\n render(\n <TableContents\n collapsibleSections\n isMobile\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.getByText('Section 2')).toBeVisible();\n expect(screen.queryByText('Item 2.1.1')).not.toBeVisible();\n });\n\n it('shows the table sections when hideDetails is collapsibleSections true has expanded ', async () => {\n const { user } = render(\n <TableContents\n collapsibleSections\n isMobile\n tableData={mockData}\n title=\"Table\"\n />\n );\n\n expect(screen.queryByText('Item 2.1.1')).not.toBeVisible();\n\n await user.click(screen.getByText('Section 2'));\n\n expect(screen.getByText('Item 2.1.1')).toBeVisible();\n });\n});\n"],"names":["render","_jsx"],"mappings":"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"}
@@ -1,16 +1,24 @@
1
1
  import { a as __assign } from '../../../../tslib.es6-a39f91fc.js';
2
+ import { useCallback, createElement } from 'react';
2
3
  import { jsxs, jsx } from 'react/jsx-runtime';
3
4
  import { c as classNames } from '../../../../index-6ea95111.js';
4
5
  import { s as styleInject } from '../../../../style-inject.es-1f59c1d0.js';
5
6
  import { TableCell } from '../TableCell/TableCell.js';
6
- import { useCallback } from 'react';
7
- import '../../../button/index.js';
7
+ import '../TableCell/BaseCell/BaseCell.js';
8
8
  import '../../../icon/icons/Check.js';
9
9
  import '../../../icon/IconWrapper/IconWrapper.js';
10
- import '../../../icon/icons/Info.js';
11
10
  import '../../../icon/icons/StarFilled.js';
12
11
  import '../../../icon/icons/X.js';
13
12
  import '../../../icon/icons/ZapFilled.js';
13
+ import '../TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js';
14
+ import '../../../../index-3d286178.js';
15
+ import '../../../../_commonjsHelpers-4730bd53.js';
16
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
17
+ import '../../../icon/icons/Info.js';
18
+ import '../../../../index-5e72c3d4.js';
19
+ import '../TableCell/CTACell/CTACell.js';
20
+ import '../TableCell/ButtonCell/ButtonCell.js';
21
+ import '../../../button/index.js';
14
22
 
15
23
  var css_248z = ".TableSection-module_table__sNbDq {\n border-collapse: collapse;\n table-layout: fixed;\n}\n@media (min-width: 34rem) {\n .TableSection-module_table__sNbDq {\n min-width: 845px;\n }\n}\n\n.TableSection-module_tr__UbkbE {\n min-height: 72px;\n}";
16
24
  var styles = {"table":"TableSection-module_table__sNbDq","tr":"TableSection-module_tr__UbkbE"};
@@ -29,15 +37,27 @@ var TableSection = function (_a) {
29
37
  };
30
38
  return (jsxs("table", { className: classNames(className, 'w100', styles.table), width: width, children: [jsx("caption", { className: "sr-only", children: title }), headerRow && (jsx("thead", { className: hideHeader ? 'sr-only' : '', children: jsx("tr", { children: headerRow.map(function (tableCellProps, cellIndex) {
31
39
  var isFirstCellInRow = cellIndex === 0;
32
- return (jsx(TableCell, __assign({ isHeader: true, isFirstCellInRow: isFirstCellInRow, isTopLeftCell: isFirstCellInRow, align: isFirstCellInRow ? 'left' : 'center', openModal: function (body) {
40
+ var isBaseCell = !tableCellProps.type;
41
+ var openModal;
42
+ var align = 'left';
43
+ if (isBaseCell) {
44
+ openModal = function (body) {
33
45
  return handleOpenModal({
34
46
  cellIndex: cellIndex,
35
47
  body: body,
36
48
  title: tableCellProps === null || tableCellProps === void 0 ? void 0 : tableCellProps.content,
37
49
  });
38
- } }, tableCellProps), cellIndex));
50
+ };
51
+ align = isFirstCellInRow ? 'left' : 'center';
52
+ }
53
+ return (jsx(TableCell, __assign({ isHeader: true, isFirstCellInRow: isFirstCellInRow, isTopLeftCell: isFirstCellInRow }, tableCellProps, (isBaseCell
54
+ ? {
55
+ openModal: openModal,
56
+ align: align,
57
+ }
58
+ : {})), cellIndex));
39
59
  }) }) })), jsx("tbody", { children: tableCellRows.map(function (row, rowIndex) {
40
- var isSingleCell = row.length === 1;
60
+ row.length === 1;
41
61
  return (rowIndex > 0 && (jsx("tr", { className: styles.tr, children: row.map(function (tableCellProps, cellIndex) {
42
62
  var key = "".concat(rowIndex, "-").concat(cellIndex);
43
63
  var isFirstCellInRow = cellIndex === 0;
@@ -50,7 +70,19 @@ var TableSection = function (_a) {
50
70
  : undefined,
51
71
  });
52
72
  };
53
- return (jsx(TableCell, __assign({ align: isFirstCellInRow && !isSingleCell ? 'left' : 'center', isFirstCellInRow: isFirstCellInRow, openModal: onCelInfoClick }, tableCellProps), key));
73
+ var openModal;
74
+ var align = 'left';
75
+ var isBaseCell = !tableCellProps.type;
76
+ if (isBaseCell) {
77
+ openModal = onCelInfoClick;
78
+ align = isFirstCellInRow ? 'left' : 'center';
79
+ }
80
+ return (createElement(TableCell, __assign({}, (isBaseCell
81
+ ? {
82
+ openModal: openModal,
83
+ align: align,
84
+ }
85
+ : {}), { isFirstCellInRow: isFirstCellInRow, key: key }, tableCellProps)));
54
86
  }) }, rowIndex)));
55
87
  }) })] }));
56
88
  };
@@ -1 +1 @@
1
- {"version":3,"file":"TableSection.js","sources":["../../../../../../../src/lib/components/table/components/TableSection/TableSection.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport styles from './TableSection.module.scss';\nimport { TableCell, TableCellProps } from '../TableCell/TableCell';\nimport { ReactNode, useCallback } from 'react';\nimport { ModalData, ModalFunction, TableCellRowData } from '../../types';\n\nexport interface TableSectionProps {\n className?: string;\n tableCellRows: TableCellRowData[];\n hideHeader?: boolean;\n openModal?: ModalFunction;\n title: string;\n width?: number | string;\n}\n\nconst TableSection = ({\n className,\n tableCellRows,\n hideHeader,\n openModal,\n title,\n width,\n}: TableSectionProps) => {\n const headerRow = tableCellRows?.[0];\n\n const getColumnContentByKey = useCallback(\n (key: number) => tableCellRows?.[0]?.[key]?.content || '',\n [tableCellRows]\n );\n\n const handleOpenModal = ({\n cellIndex,\n body,\n title,\n }: ModalData & {\n cellIndex: number;\n }) =>\n openModal?.({\n body,\n title: title || getColumnContentByKey(cellIndex),\n });\n\n return (\n <table\n className={classNames(className, 'w100', styles.table)}\n width={width}\n >\n <caption className=\"sr-only\">{title}</caption>\n\n {headerRow && (\n <thead className={hideHeader ? 'sr-only' : ''}>\n <tr>\n {headerRow.map((tableCellProps, cellIndex) => {\n const isFirstCellInRow = cellIndex === 0;\n return (\n <TableCell\n key={cellIndex}\n isHeader\n isFirstCellInRow={isFirstCellInRow}\n isTopLeftCell={isFirstCellInRow}\n align={isFirstCellInRow ? 'left' : 'center'}\n openModal={(body) =>\n handleOpenModal({\n cellIndex,\n body,\n title: tableCellProps?.content,\n })\n }\n {...tableCellProps}\n />\n );\n })}\n </tr>\n </thead>\n )}\n\n <tbody>\n {tableCellRows.map((row, rowIndex) => {\n const isSingleCell = row.length === 1;\n\n return (\n rowIndex > 0 && (\n <tr key={rowIndex} className={styles.tr}>\n {row.map((tableCellProps, cellIndex) => {\n const key = `${rowIndex}-${cellIndex}`;\n const isFirstCellInRow = cellIndex === 0;\n\n const onCelInfoClick = (body: ReactNode) =>\n handleOpenModal({\n cellIndex,\n body,\n title: isFirstCellInRow\n ? tableCellProps.content\n : undefined,\n });\n\n return (\n <TableCell\n align={\n isFirstCellInRow && !isSingleCell ? 'left' : 'center'\n }\n isFirstCellInRow={isFirstCellInRow}\n openModal={onCelInfoClick}\n key={key}\n {...tableCellProps}\n />\n );\n })}\n </tr>\n )\n );\n })}\n </tbody>\n </table>\n );\n};\n\nexport type { TableCellProps };\n\nexport { TableSection };\n"],"names":["_jsxs","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;IAgBM,YAAY,GAAG,UAAC,EAOF;QANlB,SAAS,eAAA,EACT,aAAa,mBAAA,EACb,UAAU,gBAAA,EACV,SAAS,eAAA,EACT,KAAK,WAAA,EACL,KAAK,WAAA;IAEL,IAAM,SAAS,GAAG,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,CAAC,CAAC,CAAC;IAErC,IAAM,qBAAqB,GAAG,WAAW,CACvC,UAAC,GAAW,gBAAK,OAAA,CAAA,MAAA,MAAA,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,CAAC,CAAC,0CAAG,GAAG,CAAC,0CAAE,OAAO,KAAI,EAAE,CAAA,EAAA,EACzD,CAAC,aAAa,CAAC,CAChB,CAAC;IAEF,IAAM,eAAe,GAAG,UAAC,EAMxB;YALC,SAAS,eAAA,EACT,IAAI,UAAA,EACJ,KAAK,WAAA;QAIL,OAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG;YACV,IAAI,MAAA;YACJ,KAAK,EAAE,KAAK,IAAI,qBAAqB,CAAC,SAAS,CAAC;SACjD,CAAC;KAAA,CAAC;IAEL,QACEA,gBACE,SAAS,EAAE,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,EACtD,KAAK,EAAE,KAAK,aAEZC,iBAAS,SAAS,EAAC,SAAS,YAAE,KAAK,GAAW,EAE7C,SAAS,KACRA,eAAO,SAAS,EAAE,UAAU,GAAG,SAAS,GAAG,EAAE,YAC3CA,sBACG,SAAS,CAAC,GAAG,CAAC,UAAC,cAAc,EAAE,SAAS;wBACvC,IAAM,gBAAgB,GAAG,SAAS,KAAK,CAAC,CAAC;wBACzC,QACEA,IAAC,SAAS,aAER,QAAQ,QACR,gBAAgB,EAAE,gBAAgB,EAClC,aAAa,EAAE,gBAAgB,EAC/B,KAAK,EAAE,gBAAgB,GAAG,MAAM,GAAG,QAAQ,EAC3C,SAAS,EAAE,UAAC,IAAI;gCACd,OAAA,eAAe,CAAC;oCACd,SAAS,WAAA;oCACT,IAAI,MAAA;oCACJ,KAAK,EAAE,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,OAAO;iCAC/B,CAAC;6BAAA,IAEA,cAAc,GAZb,SAAS,CAad,EACF;qBACH,CAAC,GACC,GACC,CACT,EAEDA,yBACG,aAAa,CAAC,GAAG,CAAC,UAAC,GAAG,EAAE,QAAQ;oBAC/B,IAAM,YAAY,GAAG,GAAG,CAAC,MAAM,KAAK,CAAC,CAAC;oBAEtC,QACE,QAAQ,GAAG,CAAC,KACVA,YAAmB,SAAS,EAAE,MAAM,CAAC,EAAE,YACpC,GAAG,CAAC,GAAG,CAAC,UAAC,cAAc,EAAE,SAAS;4BACjC,IAAM,GAAG,GAAG,UAAG,QAAQ,cAAI,SAAS,CAAE,CAAC;4BACvC,IAAM,gBAAgB,GAAG,SAAS,KAAK,CAAC,CAAC;4BAEzC,IAAM,cAAc,GAAG,UAAC,IAAe;gCACrC,OAAA,eAAe,CAAC;oCACd,SAAS,WAAA;oCACT,IAAI,MAAA;oCACJ,KAAK,EAAE,gBAAgB;0CACnB,cAAc,CAAC,OAAO;0CACtB,SAAS;iCACd,CAAC;6BAAA,CAAC;4BAEL,QACEA,IAAC,SAAS,aACR,KAAK,EACH,gBAAgB,IAAI,CAAC,YAAY,GAAG,MAAM,GAAG,QAAQ,EAEvD,gBAAgB,EAAE,gBAAgB,EAClC,SAAS,EAAE,cAAc,IAErB,cAAc,GADb,GAAG,CAER,EACF;yBACH,CAAC,IAzBK,QAAQ,CA0BZ,CACN,EACD;iBACH,CAAC,GACI,IACF,EACR;AACJ;;;;"}
1
+ {"version":3,"file":"TableSection.js","sources":["../../../../../../../src/lib/components/table/components/TableSection/TableSection.tsx"],"sourcesContent":["import classNames from 'classnames';\n\nimport styles from './TableSection.module.scss';\nimport { TableCell, TableCellProps } from '../TableCell/TableCell';\nimport React, { ReactNode, useCallback } from 'react';\nimport { ModalData, ModalFunction, TableCellRowData } from '../../types';\nimport { Alignment } from '../TableCell/BaseCell/BaseCell';\n\nexport interface TableSectionProps {\n className?: string;\n tableCellRows: TableCellRowData[];\n hideHeader?: boolean;\n openModal?: ModalFunction;\n title: string;\n width?: number | string;\n}\n\nconst TableSection = ({\n className,\n tableCellRows,\n hideHeader,\n openModal,\n title,\n width,\n}: TableSectionProps) => {\n const headerRow = tableCellRows?.[0];\n\n const getColumnContentByKey = useCallback(\n (key: number) => tableCellRows?.[0]?.[key]?.content || '',\n [tableCellRows]\n );\n\n const handleOpenModal = ({\n cellIndex,\n body,\n title,\n }: ModalData & {\n cellIndex: number;\n }) =>\n openModal?.({\n body,\n title: title || getColumnContentByKey(cellIndex),\n });\n\n return (\n <table\n className={classNames(className, 'w100', styles.table)}\n width={width}\n >\n <caption className=\"sr-only\">{title}</caption>\n\n {headerRow && (\n <thead className={hideHeader ? 'sr-only' : ''}>\n <tr>\n {headerRow.map((tableCellProps, cellIndex) => {\n const isFirstCellInRow = cellIndex === 0;\n\n const isBaseCell = !tableCellProps.type;\n\n let openModal;\n let align: Alignment = 'left';\n\n if (isBaseCell) {\n openModal = (body: ReactNode) =>\n handleOpenModal({\n cellIndex,\n body,\n title: tableCellProps?.content,\n });\n align = isFirstCellInRow ? 'left' : 'center';\n }\n\n return (\n <TableCell\n key={cellIndex}\n isHeader\n isFirstCellInRow={isFirstCellInRow}\n isTopLeftCell={isFirstCellInRow}\n {...tableCellProps}\n {...(isBaseCell\n ? {\n openModal,\n align,\n }\n : {})}\n />\n );\n })}\n </tr>\n </thead>\n )}\n\n <tbody>\n {tableCellRows.map((row, rowIndex) => {\n const isSingleCell = row.length === 1;\n\n return (\n rowIndex > 0 && (\n <tr key={rowIndex} className={styles.tr}>\n {row.map((tableCellProps, cellIndex) => {\n const key = `${rowIndex}-${cellIndex}`;\n const isFirstCellInRow = cellIndex === 0;\n\n const onCelInfoClick = (body: ReactNode) =>\n handleOpenModal({\n cellIndex,\n body,\n title: isFirstCellInRow\n ? tableCellProps.content\n : undefined,\n });\n\n let openModal;\n let align: Alignment = 'left';\n\n const isBaseCell = !tableCellProps.type;\n\n if (isBaseCell) {\n openModal = onCelInfoClick;\n align = isFirstCellInRow ? 'left' : 'center';\n }\n\n return (\n <TableCell\n {...(isBaseCell\n ? {\n openModal,\n align,\n }\n : {})}\n isFirstCellInRow={isFirstCellInRow}\n key={key}\n {...tableCellProps}\n />\n );\n })}\n </tr>\n )\n );\n })}\n </tbody>\n </table>\n );\n};\n\nexport type { TableCellProps };\n\nexport { TableSection };\n"],"names":["_jsxs","_jsx","_createElement"],"mappings":"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"}
@@ -9,13 +9,20 @@ import 'react-dom/test-utils';
9
9
  import '../../../../index-6ea95111.js';
10
10
  import '../../../../style-inject.es-1f59c1d0.js';
11
11
  import '../TableCell/TableCell.js';
12
- import '../../../button/index.js';
12
+ import '../TableCell/BaseCell/BaseCell.js';
13
13
  import '../../../icon/icons/Check.js';
14
14
  import '../../../icon/IconWrapper/IconWrapper.js';
15
- import '../../../icon/icons/Info.js';
16
15
  import '../../../icon/icons/StarFilled.js';
17
16
  import '../../../icon/icons/X.js';
18
17
  import '../../../icon/icons/ZapFilled.js';
18
+ import '../TableCell/BaseCell/MiniProgressBar/MiniProgressBar.js';
19
+ import '../../../../index-3d286178.js';
20
+ import '../../../comparisonTable/components/TableInfoButton/index.js';
21
+ import '../../../icon/icons/Info.js';
22
+ import '../../../../index-5e72c3d4.js';
23
+ import '../TableCell/CTACell/CTACell.js';
24
+ import '../TableCell/ButtonCell/ButtonCell.js';
25
+ import '../../../button/index.js';
19
26
 
20
27
  var tableCellRows = [
21
28
  [{ content: 'Cell 1.1' }, { content: 'Cell 1.2' }, { content: 'Cell 1.3' }],
@@ -1 +1 @@
1
- {"version":3,"file":"TableSection.test.js","sources":["../../../../../../../src/lib/components/table/components/TableSection/TableSection.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableSection, TableContentProps } from './TableSection';\n\nconst tableCellRows: TableContentProps['tableCellRows'] = [\n [{ content: 'Cell 1.1' }, { content: 'Cell 1.2' }, { content: 'Cell 1.3' }],\n [{ content: 'Cell 2.1' }, { content: 'Cell 2.2' }, { content: 'Cell 2.3' }],\n];\n\nconst mockTitle = 'Test Table';\n\nconst mockOpenModal = jest.fn();\n\nconst defaultProps: TableContentProps = {\n tableCellRows,\n title: mockTitle,\n openModal: mockOpenModal,\n};\n\ndescribe('TableSection', () => {\n it('renders the table caption', () => {\n render(<TableSection {...defaultProps} />);\n\n expect(screen.getByText(mockTitle)).toBeInTheDocument();\n });\n\n it('renders the table with correct data', () => {\n render(<TableSection {...defaultProps} />);\n\n expect(screen.getByText('Cell 1.1')).toBeInTheDocument();\n expect(screen.getByText('Cell 1.2')).toBeInTheDocument();\n expect(screen.getByText('Cell 1.3')).toBeInTheDocument();\n\n expect(screen.getByText('Cell 2.1')).toBeInTheDocument();\n expect(screen.getByText('Cell 2.2')).toBeInTheDocument();\n expect(screen.getByText('Cell 2.3')).toBeInTheDocument();\n });\n\n it('should render table headers', () => {\n const { container } = render(<TableSection {...defaultProps} />);\n\n const thElements = container.querySelectorAll('th');\n\n expect(thElements.length).toBe(4);\n expect(thElements[0]).toHaveTextContent('Cell 1.1');\n expect(thElements[3]).toHaveTextContent('Cell 2.1');\n });\n\n it('should render table data cells', () => {\n const { container } = render(<TableSection {...defaultProps} />);\n\n const tdElements = container.querySelectorAll('td');\n expect(tdElements.length).toBe(2);\n expect(tdElements[0]).toHaveTextContent('Cell 2.2');\n expect(tdElements[1]).toHaveTextContent('Cell 2.3');\n });\n});\n"],"names":["render","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;;AAGA,IAAM,aAAa,GAAuC;IACxD,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;IAC3E,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;CAC5E,CAAC;AAEF,IAAM,SAAS,GAAG,YAAY,CAAC;AAE/B,IAAM,aAAa,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAEhC,IAAM,YAAY,GAAsB;IACtC,aAAa,eAAA;IACb,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,aAAa;CACzB,CAAC;AAEF,QAAQ,CAAC,cAAc,EAAE;IACvB,EAAE,CAAC,2BAA2B,EAAE;QAC9BA,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,CAAC;QAE3C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;KACzD,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;QACxCD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,CAAC;QAE3C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAEzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;KAC1D,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE;QACxB,IAAA,SAAS,GAAKD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,UAA/C,CAAgD;QAEjE,IAAM,UAAU,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;KACrD,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QAC3B,IAAA,SAAS,GAAKD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,UAA/C,CAAgD;QAEjE,IAAM,UAAU,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;KACrD,CAAC,CAAC;AACL,CAAC,CAAC"}
1
+ {"version":3,"file":"TableSection.test.js","sources":["../../../../../../../src/lib/components/table/components/TableSection/TableSection.test.tsx"],"sourcesContent":["import { render, screen } from '../../../../util/testUtils';\nimport { TableSection, TableSectionProps } from './TableSection';\n\nconst tableCellRows: TableSectionProps['tableCellRows'] = [\n [{ content: 'Cell 1.1' }, { content: 'Cell 1.2' }, { content: 'Cell 1.3' }],\n [{ content: 'Cell 2.1' }, { content: 'Cell 2.2' }, { content: 'Cell 2.3' }],\n];\n\nconst mockTitle = 'Test Table';\n\nconst mockOpenModal = jest.fn();\n\nconst defaultProps: TableSectionProps = {\n tableCellRows,\n title: mockTitle,\n openModal: mockOpenModal,\n};\n\ndescribe('TableSection', () => {\n it('renders the table caption', () => {\n render(<TableSection {...defaultProps} />);\n\n expect(screen.getByText(mockTitle)).toBeInTheDocument();\n });\n\n it('renders the table with correct data', () => {\n render(<TableSection {...defaultProps} />);\n\n expect(screen.getByText('Cell 1.1')).toBeInTheDocument();\n expect(screen.getByText('Cell 1.2')).toBeInTheDocument();\n expect(screen.getByText('Cell 1.3')).toBeInTheDocument();\n\n expect(screen.getByText('Cell 2.1')).toBeInTheDocument();\n expect(screen.getByText('Cell 2.2')).toBeInTheDocument();\n expect(screen.getByText('Cell 2.3')).toBeInTheDocument();\n });\n\n it('should render table headers', () => {\n const { container } = render(<TableSection {...defaultProps} />);\n\n const thElements = container.querySelectorAll('th');\n\n expect(thElements.length).toBe(4);\n expect(thElements[0]).toHaveTextContent('Cell 1.1');\n expect(thElements[3]).toHaveTextContent('Cell 2.1');\n });\n\n it('should render table data cells', () => {\n const { container } = render(<TableSection {...defaultProps} />);\n\n const tdElements = container.querySelectorAll('td');\n expect(tdElements.length).toBe(2);\n expect(tdElements[0]).toHaveTextContent('Cell 2.2');\n expect(tdElements[1]).toHaveTextContent('Cell 2.3');\n });\n});\n"],"names":["render","_jsx"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,IAAM,aAAa,GAAuC;IACxD,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;IAC3E,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;CAC5E,CAAC;AAEF,IAAM,SAAS,GAAG,YAAY,CAAC;AAE/B,IAAM,aAAa,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;AAEhC,IAAM,YAAY,GAAsB;IACtC,aAAa,eAAA;IACb,KAAK,EAAE,SAAS;IAChB,SAAS,EAAE,aAAa;CACzB,CAAC;AAEF,QAAQ,CAAC,cAAc,EAAE;IACvB,EAAE,CAAC,2BAA2B,EAAE;QAC9BA,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,CAAC;QAE3C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;KACzD,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE;QACxCD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,CAAC;QAE3C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QAEzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;QACzD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC;KAC1D,CAAC,CAAC;IAEH,EAAE,CAAC,6BAA6B,EAAE;QACxB,IAAA,SAAS,GAAKD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,UAA/C,CAAgD;QAEjE,IAAM,UAAU,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAEpD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;KACrD,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE;QAC3B,IAAA,SAAS,GAAKD,YAAM,CAACC,IAAC,YAAY,eAAK,YAAY,EAAI,CAAC,UAA/C,CAAgD;QAEjE,IAAM,UAAU,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACpD,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;KACrD,CAAC,CAAC;AACL,CAAC,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { l as lib } from '../../../../index-e45b0af1.js';
2
- import { u as useTableNavigation } from '../../../../useTableNavigation-8e50b121.js';
2
+ import { u as useTableNavigation } from '../../../../useTableNavigation-2899712c.js';
3
3
  import '../../../../_commonjsHelpers-4730bd53.js';
4
4
  import '../../../../index-5e72c3d4.js';
5
5
  import 'react';
@@ -13,7 +13,6 @@ var defaultContainerRef = {
13
13
  },
14
14
  };
15
15
  describe('useTableNavigation', function () {
16
- var columnsLength = 4;
17
16
  var onSelectionChanged = jest.fn();
18
17
  var containerRef = defaultContainerRef;
19
18
  beforeEach(function () {
@@ -26,7 +25,6 @@ describe('useTableNavigation', function () {
26
25
  return useTableNavigation({
27
26
  enabled: false,
28
27
  containerRef: containerRef,
29
- columnsLength: columnsLength,
30
28
  onSelectionChanged: onSelectionChanged,
31
29
  });
32
30
  }).result;
@@ -43,7 +41,6 @@ describe('useTableNavigation', function () {
43
41
  return useTableNavigation({
44
42
  enabled: true,
45
43
  containerRef: containerRef,
46
- columnsLength: columnsLength,
47
44
  onSelectionChanged: onSelectionChanged,
48
45
  });
49
46
  }).result;
@@ -64,7 +61,6 @@ describe('useTableNavigation', function () {
64
61
  return useTableNavigation({
65
62
  enabled: true,
66
63
  containerRef: containerRef,
67
- columnsLength: columnsLength,
68
64
  onSelectionChanged: onSelectionChanged,
69
65
  });
70
66
  }).result;
@@ -1 +1 @@
1
- {"version":3,"file":"useTableNavigation.test.js","sources":["../../../../../../../src/lib/components/table/utils/useTableNavigation/useTableNavigation.test.tsx"],"sourcesContent":["import { renderHook, act } from '@testing-library/react-hooks';\nimport { useTableNavigation } from './useTableNavigation';\nimport { RefObject } from 'react';\nconst defaultContainerRef = {\n current: {\n scroll: jest.fn(),\n addEventListener: jest.fn(),\n removeEventListener: jest.fn(),\n getBoundingClientRect: jest.fn(() => ({ width: 800 })),\n },\n} as unknown as RefObject<HTMLElement>;\n\ndescribe('useTableNavigation', () => {\n const columnsLength = 4;\n let onSelectionChanged = jest.fn();\n let containerRef = defaultContainerRef;\n\n beforeEach(() => {\n containerRef = defaultContainerRef;\n onSelectionChanged = jest.fn();\n });\n\n it('should not navigate when enabled is false', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: false,\n containerRef,\n columnsLength,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(true);\n });\n\n expect(result.current.activeSection).toBe(1);\n expect(containerRef.current?.scroll).not.toHaveBeenCalled();\n expect(onSelectionChanged).not.toHaveBeenCalled();\n });\n\n it('should navigate to the next section when increase is true', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: true,\n containerRef,\n columnsLength,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(true);\n });\n\n expect(result.current.activeSection).toBe(2);\n expect(containerRef.current?.scroll).toHaveBeenCalledWith({\n top: 0,\n left: expect.any(Number),\n behavior: 'smooth',\n });\n expect(onSelectionChanged).toHaveBeenCalledWith(2);\n });\n\n it('should navigate to the previous section when increase is false', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: true,\n containerRef,\n columnsLength,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(false);\n });\n\n expect(result.current.activeSection).toBe(0);\n expect(containerRef.current?.scroll).toHaveBeenCalledWith({\n top: 0,\n left: expect.any(Number),\n behavior: 'smooth',\n });\n expect(onSelectionChanged).toHaveBeenCalledWith(0);\n });\n});\n"],"names":["renderHook","act"],"mappings":"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"}
1
+ {"version":3,"file":"useTableNavigation.test.js","sources":["../../../../../../../src/lib/components/table/utils/useTableNavigation/useTableNavigation.test.tsx"],"sourcesContent":["import { renderHook, act } from '@testing-library/react-hooks';\nimport { useTableNavigation } from './useTableNavigation';\nimport { RefObject } from 'react';\nconst defaultContainerRef = {\n current: {\n scroll: jest.fn(),\n addEventListener: jest.fn(),\n removeEventListener: jest.fn(),\n getBoundingClientRect: jest.fn(() => ({ width: 800 })),\n },\n} as unknown as RefObject<HTMLElement>;\n\ndescribe('useTableNavigation', () => {\n let onSelectionChanged = jest.fn();\n let containerRef = defaultContainerRef;\n\n beforeEach(() => {\n containerRef = defaultContainerRef;\n onSelectionChanged = jest.fn();\n });\n\n it('should not navigate when enabled is false', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: false,\n containerRef,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(true);\n });\n\n expect(result.current.activeSection).toBe(1);\n expect(containerRef.current?.scroll).not.toHaveBeenCalled();\n expect(onSelectionChanged).not.toHaveBeenCalled();\n });\n\n it('should navigate to the next section when increase is true', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: true,\n containerRef,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(true);\n });\n\n expect(result.current.activeSection).toBe(2);\n expect(containerRef.current?.scroll).toHaveBeenCalledWith({\n top: 0,\n left: expect.any(Number),\n behavior: 'smooth',\n });\n expect(onSelectionChanged).toHaveBeenCalledWith(2);\n });\n\n it('should navigate to the previous section when increase is false', () => {\n const { result } = renderHook(() =>\n useTableNavigation({\n enabled: true,\n containerRef,\n onSelectionChanged,\n })\n );\n\n act(() => {\n result.current.navigateTable(false);\n });\n\n expect(result.current.activeSection).toBe(0);\n expect(containerRef.current?.scroll).toHaveBeenCalledWith({\n top: 0,\n left: expect.any(Number),\n behavior: 'smooth',\n });\n expect(onSelectionChanged).toHaveBeenCalledWith(0);\n });\n});\n"],"names":["renderHook","act"],"mappings":";;;;;;AAGA,IAAM,mBAAmB,GAAG;IAC1B,OAAO,EAAE;QACP,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE;QACjB,gBAAgB,EAAE,IAAI,CAAC,EAAE,EAAE;QAC3B,mBAAmB,EAAE,IAAI,CAAC,EAAE,EAAE;QAC9B,qBAAqB,EAAE,IAAI,CAAC,EAAE,CAAC,cAAM,QAAC,EAAE,KAAK,EAAE,GAAG,EAAE,IAAC,CAAC;KACvD;CACmC,CAAC;AAEvC,QAAQ,CAAC,oBAAoB,EAAE;IAC7B,IAAI,kBAAkB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;IACnC,IAAI,YAAY,GAAG,mBAAmB,CAAC;IAEvC,UAAU,CAAC;QACT,YAAY,GAAG,mBAAmB,CAAC;QACnC,kBAAkB,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC;KAChC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE;;QACtC,IAAA,MAAM,GAAKA,cAAU,CAAC;YAC5B,OAAA,kBAAkB,CAAC;gBACjB,OAAO,EAAE,KAAK;gBACd,YAAY,cAAA;gBACZ,kBAAkB,oBAAA;aACnB,CAAC;SAAA,CACH,OANa,CAMZ;QAEFC,OAAG,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SACpC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAA,YAAY,CAAC,OAAO,0CAAE,MAAM,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;QAC5D,MAAM,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAC;KACnD,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE;;QACtD,IAAA,MAAM,GAAKD,cAAU,CAAC;YAC5B,OAAA,kBAAkB,CAAC;gBACjB,OAAO,EAAE,IAAI;gBACb,YAAY,cAAA;gBACZ,kBAAkB,oBAAA;aACnB,CAAC;SAAA,CACH,OANa,CAMZ;QAEFC,OAAG,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SACpC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAA,YAAY,CAAC,OAAO,0CAAE,MAAM,CAAC,CAAC,oBAAoB,CAAC;YACxD,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC;YACxB,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;QACH,MAAM,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC;KACpD,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE;;QAC3D,IAAA,MAAM,GAAKD,cAAU,CAAC;YAC5B,OAAA,kBAAkB,CAAC;gBACjB,OAAO,EAAE,IAAI;gBACb,YAAY,cAAA;gBACZ,kBAAkB,oBAAA;aACnB,CAAC;SAAA,CACH,OANa,CAMZ;QAEFC,OAAG,CAAC;YACF,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;SACrC,CAAC,CAAC;QAEH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAA,YAAY,CAAC,OAAO,0CAAE,MAAM,CAAC,CAAC,oBAAoB,CAAC;YACxD,GAAG,EAAE,CAAC;YACN,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC;YACxB,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;QACH,MAAM,CAAC,kBAAkB,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC;KACpD,CAAC,CAAC;AACL,CAAC,CAAC"}