playbook_ui 13.19.0 → 13.20.0.pre.alpha.PLAY12572402

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 (88) 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/_advanced_table.scss +45 -0
  7. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +7 -4
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_collapsible_trail.md +1 -1
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.md +1 -1
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_loading.md +1 -1
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_subrow_headers.md +1 -1
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_options.md +1 -1
  13. data/app/pb_kits/playbook/pb_date/docs/_date_alignment_swift.md +26 -6
  14. data/app/pb_kits/playbook/pb_date/docs/_date_default_swift.md +27 -8
  15. data/app/pb_kits/playbook/pb_icon/_icon.tsx +28 -16
  16. data/app/pb_kits/playbook/pb_icon/docs/_icon_custom.html.erb +5 -11
  17. data/app/pb_kits/playbook/pb_icon/docs/_icon_custom.jsx +44 -18
  18. data/app/pb_kits/playbook/pb_icon/docs/_icon_custom.md +4 -8
  19. data/app/pb_kits/playbook/pb_icon/icon.html.erb +6 -4
  20. data/app/pb_kits/playbook/pb_icon/icon.rb +27 -10
  21. data/app/pb_kits/playbook/pb_message/docs/_description.md +1 -1
  22. data/app/pb_kits/playbook/pb_nav/_subtle_mixin.scss +4 -0
  23. data/app/pb_kits/playbook/pb_table/_table.tsx +99 -67
  24. data/app/pb_kits/playbook/pb_table/docs/_table_div.html.erb +34 -0
  25. data/app/pb_kits/playbook/pb_table/docs/_table_div.jsx +47 -0
  26. data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.jsx +24 -25
  27. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.jsx +47 -0
  28. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.md +7 -0
  29. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.html.erb +34 -0
  30. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.jsx +48 -0
  31. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.md +3 -0
  32. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.html.erb +34 -0
  33. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.md +7 -0
  34. data/app/pb_kits/playbook/pb_table/docs/example.yml +6 -0
  35. data/app/pb_kits/playbook/pb_table/docs/index.js +3 -0
  36. data/app/pb_kits/playbook/pb_table/styles/_content.scss +3 -3
  37. data/app/pb_kits/playbook/pb_table/styles/_desktop_collapse.scss +15 -15
  38. data/app/pb_kits/playbook/pb_table/styles/_headers.scss +3 -3
  39. data/app/pb_kits/playbook/pb_table/styles/_hover.scss +11 -11
  40. data/app/pb_kits/playbook/pb_table/styles/_mobile.scss +15 -15
  41. data/app/pb_kits/playbook/pb_table/styles/_mobile_collapse.scss +15 -15
  42. data/app/pb_kits/playbook/pb_table/styles/_reset.scss +3 -3
  43. data/app/pb_kits/playbook/pb_table/styles/_side_highlight.scss +2 -2
  44. data/app/pb_kits/playbook/pb_table/styles/_single-line.scss +4 -4
  45. data/app/pb_kits/playbook/pb_table/styles/_sticky_header.scss +2 -2
  46. data/app/pb_kits/playbook/pb_table/styles/_striped.scss +4 -4
  47. data/app/pb_kits/playbook/pb_table/styles/_structure.scss +22 -8
  48. data/app/pb_kits/playbook/pb_table/styles/_table-card.scss +7 -7
  49. data/app/pb_kits/playbook/pb_table/styles/_table-dark.scss +14 -14
  50. data/app/pb_kits/playbook/pb_table/styles/_table_header.scss +2 -2
  51. data/app/pb_kits/playbook/pb_table/styles/_tablet_collapse.scss +15 -15
  52. data/app/pb_kits/playbook/pb_table/styles/_vertical_border.scss +3 -4
  53. data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +64 -0
  54. data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +66 -0
  55. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +64 -0
  56. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +66 -0
  57. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +74 -0
  58. data/app/pb_kits/playbook/pb_table/subcomponents/index.tsx +5 -0
  59. data/app/pb_kits/playbook/pb_table/table.html.erb +12 -2
  60. data/app/pb_kits/playbook/pb_table/table.rb +3 -0
  61. data/app/pb_kits/playbook/pb_table/table.test.js +142 -1
  62. data/app/pb_kits/playbook/pb_table/table_body.html.erb +17 -0
  63. data/app/pb_kits/playbook/pb_table/table_body.rb +15 -0
  64. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +17 -0
  65. data/app/pb_kits/playbook/pb_table/table_cell.rb +17 -0
  66. data/app/pb_kits/playbook/pb_table/table_head.html.erb +17 -0
  67. data/app/pb_kits/playbook/pb_table/table_head.rb +15 -0
  68. data/app/pb_kits/playbook/pb_table/table_header.html.erb +49 -39
  69. data/app/pb_kits/playbook/pb_table/table_header.rb +8 -1
  70. data/app/pb_kits/playbook/pb_table/table_row.html.erb +17 -7
  71. data/app/pb_kits/playbook/pb_table/table_row.rb +8 -1
  72. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +9 -5
  73. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_add_on.jsx +20 -0
  74. data/app/pb_kits/playbook/pb_user/docs/_user_presence_indicator_swift.md +30 -0
  75. data/app/pb_kits/playbook/pb_user/docs/_user_props_table.md +2 -1
  76. data/app/pb_kits/playbook/pb_user/docs/example.yml +1 -0
  77. data/app/pb_kits/playbook/utilities/_positioning.scss +48 -7
  78. data/app/pb_kits/playbook/utilities/globalProps.ts +23 -1
  79. data/dist/playbook-rails.js +6 -6
  80. data/lib/playbook/bottom.rb +33 -0
  81. data/lib/playbook/classnames.rb +4 -0
  82. data/lib/playbook/kit_base.rb +8 -0
  83. data/lib/playbook/left.rb +33 -0
  84. data/lib/playbook/right.rb +33 -0
  85. data/lib/playbook/top.rb +33 -0
  86. data/lib/playbook/version.rb +2 -2
  87. metadata +32 -7
  88. data/app/pb_kits/playbook/pb_table/_table_row.tsx +0 -47
@@ -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,9 +1,19 @@
1
1
  <%= content_tag(:div) do %>
2
- <%= content_tag(:table,
2
+ <% if object.tag == "table" %>
3
+ <%= content_tag(:table,
3
4
  aria: object.aria,
4
5
  class: object.classname,
5
6
  data: object.data,
6
7
  id: object.id) do %>
7
- <%= content.presence %>
8
+ <%= content.presence %>
9
+ <% end %>
10
+ <% else %>
11
+ <%= content_tag(:div,
12
+ aria: object.aria,
13
+ class: object.classname,
14
+ data: object.data,
15
+ id: object.id) do %>
16
+ <%= content.presence %>
17
+ <% end %>
8
18
  <% end %>
9
19
  <% end %>
@@ -27,6 +27,9 @@ module Playbook
27
27
  default: false
28
28
  prop :striped, type: Playbook::Props::Boolean,
29
29
  default: false
30
+ prop :tag, type: Playbook::Props::Enum,
31
+ values: %w[table div],
32
+ default: "table"
30
33
 
31
34
  def classname
32
35
  generate_classname(
@@ -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 %>
@@ -0,0 +1,15 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbTable
5
+ class TableBody < Playbook::KitBase
6
+ prop :tag, type: Playbook::Props::Enum,
7
+ values: %w[table div],
8
+ default: "table"
9
+
10
+ def classname
11
+ generate_classname("pb_table_tbody")
12
+ end
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,17 @@
1
+ <% if object.tag == "table" %>
2
+ <%= content_tag(:td,
3
+ aria: object.aria,
4
+ class: object.classname,
5
+ data: object.data,
6
+ id: object.id) do %>
7
+ <%= content.presence || object.text %>
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 || object.text %>
16
+ <% end %>
17
+ <% end %>
@@ -0,0 +1,17 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbTable
5
+ class TableCell < Playbook::KitBase
6
+ prop :tag, type: Playbook::Props::Enum,
7
+ values: %w[table div],
8
+ default: "table"
9
+ prop :text, type: Playbook::Props::String,
10
+ default: ""
11
+
12
+ def classname
13
+ generate_classname("pb_table_td")
14
+ end
15
+ end
16
+ end
17
+ end
@@ -0,0 +1,17 @@
1
+ <% if object.tag == "table" %>
2
+ <%= content_tag(:thead,
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 %>
@@ -0,0 +1,15 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Playbook
4
+ module PbTable
5
+ class TableHead < Playbook::KitBase
6
+ prop :tag, type: Playbook::Props::Enum,
7
+ values: %w[table div],
8
+ default: "table"
9
+
10
+ def classname
11
+ generate_classname("pb_table_thead")
12
+ end
13
+ end
14
+ end
15
+ end