playbook_ui 13.20.0 → 13.21.0.pre.alpha.pbntr220improveexpansionspeed2431

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 (60) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/index.js +1 -1
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/CollapsibleTrail.tsx +6 -1
  4. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +2 -0
  5. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableHeader.tsx +2 -0
  6. data/app/pb_kits/playbook/pb_advanced_table/Utilities/ExpansionControlHelpers.tsx +20 -35
  7. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +45 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +7 -5
  9. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +15 -9
  10. data/app/pb_kits/playbook/pb_date/docs/_date_alignment_swift.md +26 -6
  11. data/app/pb_kits/playbook/pb_date/docs/_date_default_swift.md +27 -8
  12. data/app/pb_kits/playbook/pb_message/docs/_description.md +1 -1
  13. data/app/pb_kits/playbook/pb_nav/_subtle_mixin.scss +4 -0
  14. data/app/pb_kits/playbook/pb_table/_table.tsx +13 -0
  15. data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.jsx +24 -25
  16. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.jsx +47 -0
  17. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.md +7 -0
  18. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.html.erb +34 -0
  19. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.jsx +48 -0
  20. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.md +3 -0
  21. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.html.erb +34 -0
  22. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.md +7 -0
  23. data/app/pb_kits/playbook/pb_table/docs/example.yml +6 -2
  24. data/app/pb_kits/playbook/pb_table/docs/index.js +2 -0
  25. data/app/pb_kits/playbook/pb_table/styles/_striped.scss +2 -2
  26. data/app/pb_kits/playbook/pb_table/styles/_structure.scss +4 -2
  27. data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +64 -0
  28. data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +66 -0
  29. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +64 -0
  30. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +66 -0
  31. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +74 -0
  32. data/app/pb_kits/playbook/pb_table/subcomponents/index.tsx +5 -0
  33. data/app/pb_kits/playbook/pb_table/table.test.js +142 -1
  34. data/app/pb_kits/playbook/pb_table/table_body.html.erb +17 -0
  35. data/app/pb_kits/playbook/pb_table/table_body.rb +15 -0
  36. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +17 -0
  37. data/app/pb_kits/playbook/pb_table/table_cell.rb +17 -0
  38. data/app/pb_kits/playbook/pb_table/table_head.html.erb +17 -0
  39. data/app/pb_kits/playbook/pb_table/table_head.rb +15 -0
  40. data/app/pb_kits/playbook/pb_table/table_header.html.erb +49 -39
  41. data/app/pb_kits/playbook/pb_table/table_header.rb +8 -1
  42. data/app/pb_kits/playbook/pb_table/table_row.html.erb +17 -7
  43. data/app/pb_kits/playbook/pb_table/table_row.rb +8 -1
  44. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +9 -5
  45. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_add_on.jsx +20 -0
  46. data/app/pb_kits/playbook/pb_user/docs/_user_presence_indicator_swift.md +30 -0
  47. data/app/pb_kits/playbook/pb_user/docs/_user_props_table.md +2 -1
  48. data/app/pb_kits/playbook/pb_user/docs/example.yml +1 -0
  49. data/app/pb_kits/playbook/utilities/_positioning.scss +48 -7
  50. data/app/pb_kits/playbook/utilities/globalProps.ts +23 -1
  51. data/dist/playbook-rails.js +6 -6
  52. data/lib/playbook/bottom.rb +33 -0
  53. data/lib/playbook/classnames.rb +4 -0
  54. data/lib/playbook/kit_base.rb +8 -0
  55. data/lib/playbook/left.rb +33 -0
  56. data/lib/playbook/right.rb +33 -0
  57. data/lib/playbook/top.rb +33 -0
  58. data/lib/playbook/version.rb +2 -2
  59. metadata +31 -8
  60. data/app/pb_kits/playbook/pb_table/_table_row.tsx +0 -47
@@ -0,0 +1,48 @@
1
+ import React from 'react'
2
+
3
+ import Table from '../_table'
4
+
5
+ const TableWithSubcomponentsAsDivs = (props) => {
6
+ return (
7
+ <Table
8
+ size="sm"
9
+ tag="div"
10
+ {...props}
11
+ >
12
+ <Table.Head tag="div">
13
+ <Table.Row tag="div">
14
+ <Table.Header tag="div">{'Column 1'}</Table.Header>
15
+ <Table.Header tag="div">{'Column 2'}</Table.Header>
16
+ <Table.Header tag="div">{'Column 3'}</Table.Header>
17
+ <Table.Header tag="div">{'Column 4'}</Table.Header>
18
+ <Table.Header tag="div">{'Column 5'}</Table.Header>
19
+ </Table.Row>
20
+ </Table.Head>
21
+ <Table.Body tag="div">
22
+ <Table.Row tag="div">
23
+ <Table.Cell tag="div">{'Value 1'}</Table.Cell>
24
+ <Table.Cell tag="div">{'Value 2'}</Table.Cell>
25
+ <Table.Cell tag="div">{'Value 3'}</Table.Cell>
26
+ <Table.Cell tag="div">{'Value 4'}</Table.Cell>
27
+ <Table.Cell tag="div">{'Value 5'}</Table.Cell>
28
+ </Table.Row>
29
+ <Table.Row tag="div">
30
+ <Table.Cell tag="div">{'Value 1'}</Table.Cell>
31
+ <Table.Cell tag="div">{'Value 2'}</Table.Cell>
32
+ <Table.Cell tag="div">{'Value 3'}</Table.Cell>
33
+ <Table.Cell tag="div">{'Value 4'}</Table.Cell>
34
+ <Table.Cell tag="div">{'Value 5'}</Table.Cell>
35
+ </Table.Row>
36
+ <Table.Row>
37
+ <Table.Cell tag="div">{'Value 1'}</Table.Cell>
38
+ <Table.Cell tag="div">{'Value 2'}</Table.Cell>
39
+ <Table.Cell tag="div">{'Value 3'}</Table.Cell>
40
+ <Table.Cell tag="div">{'Value 4'}</Table.Cell>
41
+ <Table.Cell tag="div">{'Value 5'}</Table.Cell>
42
+ </Table.Row>
43
+ </Table.Body>
44
+ </Table>
45
+ )
46
+ }
47
+
48
+ export default TableWithSubcomponentsAsDivs
@@ -0,0 +1,3 @@
1
+ Optionally build your table with divs by passing `div` to the `tag` prop of all* your sub-components.
2
+
3
+ *NOTE: The `tag` prop defaults to `table`, which returns html elements. If divs are desired, sub-components must be used and all table elements, including the initial kit call, must use `div` as their `tag` in order for the table to render properly.
@@ -0,0 +1,34 @@
1
+ <%= pb_rails("table", props: { size: "sm" }) do %>
2
+ <%= pb_rails("table/table_head") do %>
3
+ <%= pb_rails("table/table_row") do %>
4
+ <%= pb_rails("table/table_header", props: { text: "Column 1"}) %>
5
+ <%= pb_rails("table/table_header", props: { text: "Column 2"}) %>
6
+ <%= pb_rails("table/table_header", props: { text: "Column 3"}) %>
7
+ <%= pb_rails("table/table_header", props: { text: "Column 4"}) %>
8
+ <%= pb_rails("table/table_header", props: { text: "Column 5"}) %>
9
+ <% end %>
10
+ <% end %>
11
+ <%= pb_rails("table/table_body") do %>
12
+ <%= pb_rails("table/table_row") do %>
13
+ <%= pb_rails("table/table_cell", props: { text: "Value 1"}) %>
14
+ <%= pb_rails("table/table_cell", props: { text: "Value 2"}) %>
15
+ <%= pb_rails("table/table_cell", props: { text: "Value 3"}) %>
16
+ <%= pb_rails("table/table_cell", props: { text: "Value 4"}) %>
17
+ <%= pb_rails("table/table_cell", props: { text: "Value 5"}) %>
18
+ <% end %>
19
+ <%= pb_rails("table/table_row") do %>
20
+ <%= pb_rails("table/table_cell", props: { text: "Value 1"}) %>
21
+ <%= pb_rails("table/table_cell", props: { text: "Value 2"}) %>
22
+ <%= pb_rails("table/table_cell", props: { text: "Value 3"}) %>
23
+ <%= pb_rails("table/table_cell", props: { text: "Value 4"}) %>
24
+ <%= pb_rails("table/table_cell", props: { text: "Value 5"}) %>
25
+ <% end %>
26
+ <%= pb_rails("table/table_row") do %>
27
+ <%= pb_rails("table/table_cell", props: { text: "Value 1"}) %>
28
+ <%= pb_rails("table/table_cell", props: { text: "Value 2"}) %>
29
+ <%= pb_rails("table/table_cell", props: { text: "Value 3"}) %>
30
+ <%= pb_rails("table/table_cell", props: { text: "Value 4"}) %>
31
+ <%= pb_rails("table/table_cell", props: { text: "Value 5"}) %>
32
+ <% end %>
33
+ <% end %>
34
+ <% end %>
@@ -0,0 +1,7 @@
1
+ You can optionally build your table using our sub-components, which map to their respective html table elements:
2
+
3
+ `table_head` = `thead`
4
+ `table_body` = `tbody`
5
+ `table_row` = `tr`
6
+ `table_header` = `th`
7
+ `table_cell` = `td`
@@ -1,6 +1,5 @@
1
1
  examples:
2
2
  rails:
3
- # - table_div: Div
4
3
  - table_sm: Small
5
4
  - table_md: Medium
6
5
  - table_lg: Large
@@ -25,9 +24,11 @@ examples:
25
24
  - table_with_background_kit: Table With Background Kit
26
25
  - table_vertical_border: Vertical Borders
27
26
  - table_striped: Striped Table
27
+ - table_with_subcomponents_rails: Table with Sub Components (Table Elements)
28
+ - table_with_subcomponents_as_divs: Table with Sub Components (Divs)
29
+
28
30
 
29
31
  react:
30
- # - table_div: Div
31
32
  - table_sm: Small
32
33
  - table_md: Medium
33
34
  - table_lg: Large
@@ -51,3 +52,6 @@ examples:
51
52
  - table_with_background_kit: Table With Background Kit
52
53
  - table_vertical_border: Vertical Borders
53
54
  - table_striped: Striped Table
55
+ - table_with_subcomponents: Table with Sub Components (Table Elements)
56
+ - table_with_subcomponents_as_divs: Table with Sub Components (Divs)
57
+
@@ -22,3 +22,5 @@ export { default as TableWithBackgroundKit } from './_table_with_background_kit.
22
22
  export { default as TableVerticalBorder } from './_table_vertical_border.jsx'
23
23
  export { default as TableStriped } from './_table_striped.jsx'
24
24
  export { default as TableDiv } from './_table_div.jsx'
25
+ export { default as TableWithSubcomponents } from './_table_with_subcomponents.jsx'
26
+ export { default as TableWithSubcomponentsAsDivs } from './_table_with_subcomponents_as_divs.jsx'
@@ -1,7 +1,7 @@
1
1
  [class^=pb_table] {
2
2
  &.striped {
3
3
  tbody, .pb_table_tbody {
4
- tr:nth-child(odd), .tr:nth-child(odd) {
4
+ tr:nth-child(odd), .pb_table_tr:nth-child(odd) {
5
5
  background-color: $bg_light;
6
6
  }
7
7
  }
@@ -10,7 +10,7 @@
10
10
  &.dark {
11
11
  &.striped {
12
12
  tbody, .pb_table_tbody {
13
- tr:nth-child(odd), .tr:nth-child(odd) {
13
+ tr:nth-child(odd), .pb_table_tr:nth-child(odd) {
14
14
  background-color: $bg_dark;
15
15
  }
16
16
  }
@@ -48,7 +48,8 @@
48
48
  }
49
49
  }
50
50
  &.data_table {
51
- thead tr th {
51
+ thead tr th,
52
+ .pb_table_thead .pb_table_tr .pb_table_th {
52
53
  padding-top: $cell-pad-sm;
53
54
  padding-bottom: $cell-pad-sm;
54
55
  &:first-child {
@@ -58,7 +59,8 @@
58
59
  padding-right: $cell-pad-sm;
59
60
  }
60
61
  }
61
- tbody tr td {
62
+ tbody tr td,
63
+ .pb_table_tbody .pb_table_tr .pb_table_td {
62
64
  padding-top: $cell-pad-sm;
63
65
  padding-bottom: $cell-pad-sm;
64
66
  &:first-child {
@@ -0,0 +1,64 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import {
4
+ buildAriaProps,
5
+ buildDataProps,
6
+ buildHtmlProps,
7
+ } from "../../utilities/props";
8
+ import { globalProps } from "../../utilities/globalProps";
9
+
10
+ type TableBodyPropTypes = {
11
+ aria?: { [key: string]: string };
12
+ children: React.ReactNode[] | React.ReactNode;
13
+ className: string;
14
+ data?: { [key: string]: string };
15
+ htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
16
+ id?: string;
17
+ tag?: "table" | "div";
18
+ };
19
+
20
+ const TableBody = (props: TableBodyPropTypes) => {
21
+ const {
22
+ aria = {},
23
+ children,
24
+ className,
25
+ data = {},
26
+ htmlOptions = {},
27
+ id,
28
+ tag = "table",
29
+ } = props;
30
+
31
+ const ariaProps = buildAriaProps(aria);
32
+ const dataProps = buildDataProps(data);
33
+ const htmlProps = buildHtmlProps(htmlOptions);
34
+ const classes = classnames("pb_table_tbody", globalProps(props), className);
35
+ const isTableTag = tag === "table";
36
+
37
+ return (
38
+ <>
39
+ {isTableTag ? (
40
+ <tbody
41
+ {...ariaProps}
42
+ {...dataProps}
43
+ {...htmlProps}
44
+ className={classes}
45
+ id={id}
46
+ >
47
+ {children}
48
+ </tbody>
49
+ ) : (
50
+ <div
51
+ {...ariaProps}
52
+ {...dataProps}
53
+ {...htmlProps}
54
+ className={classes}
55
+ id={id}
56
+ >
57
+ {children}
58
+ </div>
59
+ )}
60
+ </>
61
+ );
62
+ };
63
+
64
+ export default TableBody;
@@ -0,0 +1,66 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import {
4
+ buildAriaProps,
5
+ buildDataProps,
6
+ buildHtmlProps,
7
+ } from "../../utilities/props";
8
+ import { globalProps } from "../../utilities/globalProps";
9
+
10
+ type TableCellPropTypes = {
11
+ aria?: { [key: string]: string };
12
+ children: React.ReactNode[] | React.ReactNode;
13
+ className: string;
14
+ data?: { [key: string]: string };
15
+ htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
16
+ id?: string;
17
+ tag?: "table" | "div";
18
+ text?: string
19
+ };
20
+
21
+ const TableCell = (props: TableCellPropTypes) => {
22
+ const {
23
+ aria = {},
24
+ children,
25
+ className,
26
+ data = {},
27
+ htmlOptions = {},
28
+ id,
29
+ tag = "table",
30
+ text,
31
+ } = props;
32
+
33
+ const ariaProps = buildAriaProps(aria);
34
+ const dataProps = buildDataProps(data);
35
+ const htmlProps = buildHtmlProps(htmlOptions);
36
+ const classes = classnames("pb_table_td", globalProps(props), className);
37
+ const isTableTag = tag === "table";
38
+
39
+ return (
40
+ <>
41
+ {isTableTag ? (
42
+ <td
43
+ {...ariaProps}
44
+ {...dataProps}
45
+ {...htmlProps}
46
+ className={classes}
47
+ id={id}
48
+ >
49
+ {text || children}
50
+ </td>
51
+ ) : (
52
+ <div
53
+ {...ariaProps}
54
+ {...dataProps}
55
+ {...htmlProps}
56
+ className={classes}
57
+ id={id}
58
+ >
59
+ {text || children}
60
+ </div>
61
+ )}
62
+ </>
63
+ );
64
+ };
65
+
66
+ export default TableCell;
@@ -0,0 +1,64 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import {
4
+ buildAriaProps,
5
+ buildDataProps,
6
+ buildHtmlProps,
7
+ } from "../../utilities/props";
8
+ import { globalProps } from "../../utilities/globalProps";
9
+
10
+ type TableHeadPropTypes = {
11
+ aria?: { [key: string]: string };
12
+ children: React.ReactNode[] | React.ReactNode;
13
+ className: string;
14
+ data?: { [key: string]: string };
15
+ htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
16
+ id?: string;
17
+ tag?: "table" | "div";
18
+ };
19
+
20
+ const TableHead = (props: TableHeadPropTypes) => {
21
+ const {
22
+ aria = {},
23
+ children,
24
+ className,
25
+ data = {},
26
+ htmlOptions = {},
27
+ id,
28
+ tag = "table",
29
+ } = props;
30
+
31
+ const ariaProps = buildAriaProps(aria);
32
+ const dataProps = buildDataProps(data);
33
+ const htmlProps = buildHtmlProps(htmlOptions);
34
+ const classes = classnames("pb_table_thead", globalProps(props), className);
35
+ const isTableTag = tag === "table";
36
+
37
+ return (
38
+ <>
39
+ {isTableTag ? (
40
+ <thead
41
+ {...ariaProps}
42
+ {...dataProps}
43
+ {...htmlProps}
44
+ className={classes}
45
+ id={id}
46
+ >
47
+ {children}
48
+ </thead>
49
+ ) : (
50
+ <div
51
+ {...ariaProps}
52
+ {...dataProps}
53
+ {...htmlProps}
54
+ className={classes}
55
+ id={id}
56
+ >
57
+ {children}
58
+ </div>
59
+ )}
60
+ </>
61
+ );
62
+ };
63
+
64
+ export default TableHead;
@@ -0,0 +1,66 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import {
4
+ buildAriaProps,
5
+ buildDataProps,
6
+ buildHtmlProps,
7
+ } from "../../utilities/props";
8
+ import { globalProps } from "../../utilities/globalProps";
9
+
10
+ type TableHeaderPropTypes = {
11
+ aria?: { [key: string]: string };
12
+ children: React.ReactNode[] | React.ReactNode;
13
+ className: string;
14
+ data?: { [key: string]: string };
15
+ htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
16
+ id?: string;
17
+ tag?: "table" | "div";
18
+ text?: string;
19
+ };
20
+
21
+ const TableHeader = (props: TableHeaderPropTypes) => {
22
+ const {
23
+ aria = {},
24
+ children,
25
+ className,
26
+ data = {},
27
+ htmlOptions = {},
28
+ id,
29
+ tag = "table",
30
+ text
31
+ } = props;
32
+
33
+ const ariaProps = buildAriaProps(aria);
34
+ const dataProps = buildDataProps(data);
35
+ const htmlProps = buildHtmlProps(htmlOptions);
36
+ const classes = classnames("pb_table_th", globalProps(props), className);
37
+ const isTableTag = tag === "table";
38
+
39
+ return (
40
+ <>
41
+ {isTableTag ? (
42
+ <th
43
+ {...ariaProps}
44
+ {...dataProps}
45
+ {...htmlProps}
46
+ className={classes}
47
+ id={id}
48
+ >
49
+ {text || children}
50
+ </th>
51
+ ) : (
52
+ <div
53
+ {...ariaProps}
54
+ {...dataProps}
55
+ {...htmlProps}
56
+ className={classes}
57
+ id={id}
58
+ >
59
+ {text || children}
60
+ </div>
61
+ )}
62
+ </>
63
+ );
64
+ };
65
+
66
+ export default TableHeader;
@@ -0,0 +1,74 @@
1
+ import React from "react";
2
+ import classnames from "classnames";
3
+ import {
4
+ buildAriaProps,
5
+ buildCss,
6
+ buildDataProps,
7
+ buildHtmlProps,
8
+ } from "../../utilities/props";
9
+ import { globalProps } from "../../utilities/globalProps";
10
+
11
+ type TableRowPropTypes = {
12
+ aria?: { [key: string]: string };
13
+ children: React.ReactNode[] | React.ReactNode;
14
+ className: string;
15
+ data?: { [key: string]: string };
16
+ htmlOptions?: { [key: string]: string | number | boolean | (() => void) };
17
+ id?: string;
18
+ sideHighlightColor: string;
19
+ tag?: "table" | "div";
20
+ };
21
+
22
+ const TableRow = (props: TableRowPropTypes) => {
23
+ const {
24
+ aria = {},
25
+ children,
26
+ className,
27
+ data = {},
28
+ htmlOptions = {},
29
+ id,
30
+ sideHighlightColor = "none",
31
+ tag = "table",
32
+ } = props;
33
+
34
+ const ariaProps = buildAriaProps(aria);
35
+ const dataProps = buildDataProps(data);
36
+ const htmlProps = buildHtmlProps(htmlOptions);
37
+ const sideHighlightClass =
38
+ sideHighlightColor != "" ? `side_highlight_${sideHighlightColor}` : null;
39
+ const classes = classnames(
40
+ buildCss("pb_table_row_kit", sideHighlightClass),
41
+ "pb_table_tr",
42
+ globalProps(props),
43
+ className
44
+ );
45
+ const isTableTag = tag === "table";
46
+
47
+ return (
48
+ <>
49
+ {isTableTag ? (
50
+ <tr
51
+ {...ariaProps}
52
+ {...dataProps}
53
+ {...htmlProps}
54
+ className={classes}
55
+ id={id}
56
+ >
57
+ {children}
58
+ </tr>
59
+ ) : (
60
+ <div
61
+ {...ariaProps}
62
+ {...dataProps}
63
+ {...htmlProps}
64
+ className={classes}
65
+ id={id}
66
+ >
67
+ {children}
68
+ </div>
69
+ )}
70
+ </>
71
+ );
72
+ };
73
+
74
+ export default TableRow;
@@ -0,0 +1,5 @@
1
+ export { default as TableHead } from './_table_head';
2
+ export { default as TableHeader } from './_table_header';
3
+ export { default as TableBody } from './_table_body';
4
+ export { default as TableRow } from './_table_row';
5
+ export { default as TableCell } from './_table_cell';
@@ -1,7 +1,58 @@
1
- import { ensureAccessible, renderKit } from "../utilities/test-utils"
1
+ import React from "react";
2
+ import { ensureAccessible, renderKit, render, screen } from "../utilities/test-utils"
2
3
 
3
4
  import Table from "./_table"
4
5
 
6
+ const DivsTable = () => {
7
+ return (
8
+ <>
9
+ <Table
10
+ data={{testid: "table"}}
11
+ size="sm"
12
+ tag="div"
13
+ >
14
+ <Table.Head tag="div">
15
+ <Table.Row tag="div">
16
+ <Table.Header tag="div">{"Column 1"}</Table.Header>
17
+ <Table.Header tag="div">{"Column 2"}</Table.Header>
18
+ </Table.Row>
19
+ </Table.Head>
20
+ <Table.Body tag="div">
21
+ <Table.Row tag="div">
22
+ <Table.Cell tag="div">{"Value 1"}</Table.Cell>
23
+ <Table.Cell tag="div">{"Value 2"}</Table.Cell>
24
+ </Table.Row>
25
+ </Table.Body>
26
+ </Table>
27
+ </>
28
+ );
29
+ };
30
+
31
+ const TableTagTable = () => {
32
+ return (
33
+ <>
34
+ <Table
35
+ data={{testid: "table"}}
36
+ size="sm"
37
+ >
38
+ <Table.Head>
39
+ <Table.Row>
40
+ <Table.Header>{"Column 1"}</Table.Header>
41
+ <Table.Header>{"Column 2"}</Table.Header>
42
+ </Table.Row>
43
+ </Table.Head>
44
+ <Table.Body>
45
+ <Table.Row>
46
+ <Table.Cell>{"Value 1"}</Table.Cell>
47
+ <Table.Cell>{"Value 2"}</Table.Cell>
48
+ </Table.Row>
49
+ </Table.Body>
50
+ </Table>
51
+ </>
52
+ );
53
+ };
54
+
55
+
5
56
  const props = {
6
57
  data: { testid: "table" },
7
58
  sticky: false
@@ -20,3 +71,93 @@ test("when striped is true", () => {
20
71
  const kit = renderKit(Table, props, { striped: true })
21
72
  expect(kit).toHaveClass("pb_table table-sm table-responsive-collapse table-card striped table-collapse-sm")
22
73
  })
74
+
75
+ test("Renders Table.Head subkit for Div Table", () => {
76
+ render (<DivsTable/>)
77
+
78
+ const kit = screen.getByTestId("table")
79
+ const head = kit.querySelector(".pb_table_thead")
80
+ expect(head).toBeInTheDocument()
81
+ expect(head.tagName).toBe("DIV")
82
+ })
83
+
84
+ test("Renders Table.Header subkit for Div Table", () => {
85
+ render (<DivsTable/>)
86
+
87
+ const kit = screen.getByTestId("table")
88
+ const head = kit.querySelector(".pb_table_th")
89
+ expect(head).toBeInTheDocument()
90
+ expect(head.tagName).toBe("DIV")
91
+ })
92
+
93
+ test("Renders Table.Body subkit for Div Table", () => {
94
+ render (<DivsTable/>)
95
+
96
+ const kit = screen.getByTestId("table")
97
+ const head = kit.querySelector(".pb_table_tbody")
98
+ expect(head).toBeInTheDocument()
99
+ expect(head.tagName).toBe("DIV")
100
+ })
101
+
102
+ test("Renders Table.Row subkit for Div Table", () => {
103
+ render (<DivsTable/>)
104
+
105
+ const kit = screen.getByTestId("table")
106
+ const head = kit.querySelector(".pb_table_tr")
107
+ expect(head).toBeInTheDocument()
108
+ expect(head.tagName).toBe("DIV")
109
+ })
110
+
111
+ test("Renders Table.Cell subkit for Div Table", () => {
112
+ render (<DivsTable/>)
113
+
114
+ const kit = screen.getByTestId("table")
115
+ const head = kit.querySelector(".pb_table_td")
116
+ expect(head).toBeInTheDocument()
117
+ expect(head.tagName).toBe("DIV")
118
+ })
119
+
120
+ test("Renders Table.Head subkit for HTML Table elements Table", () => {
121
+ render (<TableTagTable/>)
122
+
123
+ const kit = screen.getByTestId("table")
124
+ const head = kit.querySelector(".pb_table_thead")
125
+ expect(head).toBeInTheDocument()
126
+ expect(head.tagName).toBe("THEAD")
127
+ })
128
+
129
+ test("Renders Table.Header subkit for HTML Table elements Table", () => {
130
+ render (<TableTagTable/>)
131
+
132
+ const kit = screen.getByTestId("table")
133
+ const head = kit.querySelector(".pb_table_th")
134
+ expect(head).toBeInTheDocument()
135
+ expect(head.tagName).toBe("TH")
136
+ })
137
+
138
+ test("Renders Table.Body subkit for HTML Table elements Table", () => {
139
+ render (<TableTagTable/>)
140
+
141
+ const kit = screen.getByTestId("table")
142
+ const head = kit.querySelector(".pb_table_tbody")
143
+ expect(head).toBeInTheDocument()
144
+ expect(head.tagName).toBe("TBODY")
145
+ })
146
+
147
+ test("Renders Table.Row subkit for HTML Table elements Table", () => {
148
+ render (<TableTagTable/>)
149
+
150
+ const kit = screen.getByTestId("table")
151
+ const head = kit.querySelector(".pb_table_tr")
152
+ expect(head).toBeInTheDocument()
153
+ expect(head.tagName).toBe("TR")
154
+ })
155
+
156
+ test("Renders Table.Cell subkit for HTML Table elements Table", () => {
157
+ render (<TableTagTable/>)
158
+
159
+ const kit = screen.getByTestId("table")
160
+ const head = kit.querySelector(".pb_table_td")
161
+ expect(head).toBeInTheDocument()
162
+ expect(head.tagName).toBe("TD")
163
+ })
@@ -0,0 +1,17 @@
1
+ <% if object.tag == "table" %>
2
+ <%= content_tag(:tbody,
3
+ aria: object.aria,
4
+ class: object.classname,
5
+ data: object.data,
6
+ id: object.id) do %>
7
+ <%= content.presence %>
8
+ <% end %>
9
+ <% else %>
10
+ <%= content_tag(:div,
11
+ aria: object.aria,
12
+ class: object.classname,
13
+ data: object.data,
14
+ id: object.id) do %>
15
+ <%= content.presence %>
16
+ <% end %>
17
+ <% end %>