playbook_ui 14.9.0.pre.alpha.PBNTR746datepickerdefaultbug4901 → 14.9.0.pre.alpha.PBNTR775formmatingmaskdefaultvalue5120
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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/Components/CollapsibleTrail.tsx +1 -6
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +11 -3
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_collapsible_trail_rails.html.erb +36 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_collapsible_trail_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +4 -2
- data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +8 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.html.erb +8 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_subrow_header.rb +2 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.jsx +53 -49
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom_rails.html.erb +29 -36
- data/app/pb_kits/playbook/pb_card/_card.tsx +7 -7
- data/app/pb_kits/playbook/pb_card/_card_mixin.scss +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_header.html.erb +21 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_header.jsx +50 -0
- data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
- data/app/pb_kits/playbook/pb_collapsible/_collapsible.tsx +9 -4
- data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleContent.tsx +2 -2
- data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleMain.tsx +2 -2
- data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +2 -4
- data/app/pb_kits/playbook/pb_drawer/_drawer.tsx +2 -2
- data/app/pb_kits/playbook/pb_form_group/_error_state_mixin.scss +57 -0
- data/app/pb_kits/playbook/pb_form_group/_form_group.scss +11 -2
- data/app/pb_kits/playbook/pb_gauge/_gauge.scss +31 -1
- data/app/pb_kits/playbook/pb_gauge/_gauge.tsx +3 -3
- data/app/pb_kits/playbook/pb_gauge/docs/_gauge_complex.jsx +25 -5
- data/app/pb_kits/playbook/pb_home_address_street/_home_address_street.tsx +17 -1
- data/app/pb_kits/playbook/pb_home_address_street/docs/_home_address_street_emphasis.html.erb +17 -1
- data/app/pb_kits/playbook/pb_home_address_street/docs/_home_address_street_emphasis.jsx +15 -0
- data/app/pb_kits/playbook/pb_home_address_street/docs/_home_address_street_emphasis.md +2 -1
- data/app/pb_kits/playbook/pb_home_address_street/home_address_street.rb +15 -1
- data/app/pb_kits/playbook/pb_home_address_street/none_emphasis.html.erb +32 -0
- data/app/pb_kits/playbook/pb_home_address_street/none_emphasis.rb +29 -0
- data/app/pb_kits/playbook/pb_layout/_layout.tsx +30 -11
- data/app/pb_kits/playbook/pb_link/_link.scss +3 -3
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_filter.jsx +166 -0
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_height_width.jsx +2 -0
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_user.jsx +89 -0
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_table/_table.tsx +6 -6
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +30 -48
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.jsx +75 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +108 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.md +2 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.jsx +94 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.md +0 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.jsx +83 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.md +3 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.jsx +120 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/example.yml +7 -0
- data/app/pb_kits/playbook/pb_table/docs/index.js +5 -0
- data/app/pb_kits/playbook/pb_table/index.ts +5 -3
- data/app/pb_kits/playbook/pb_table/styles/_all.scss +2 -1
- data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +35 -0
- data/app/pb_kits/playbook/pb_table/styles/_scroll.scss +28 -3
- data/app/pb_kits/playbook/pb_table/styles/_sticky_columns.scss +0 -1
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +106 -1
- data/app/pb_kits/playbook/pb_table/table.html.erb +7 -1
- data/app/pb_kits/playbook/pb_table/table.rb +4 -0
- data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +41 -4
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_mask.jsx +88 -0
- data/app/pb_kits/playbook/pb_text_input/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_text_input/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_text_input/inputMask.ts +64 -0
- data/app/pb_kits/playbook/pb_text_input/text_input.test.js +139 -2
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +115 -46
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_highlight.jsx +9 -2
- data/app/pb_kits/playbook/pb_typeahead/typeahead.html.erb +3 -2
- data/dist/chunks/_typeahead-BdFkerD3.js +22 -0
- data/dist/chunks/_weekday_stacked-BiePMYeU.js +45 -0
- data/dist/chunks/lib-sMFo2JZy.js +29 -0
- data/dist/chunks/{pb_form_validation-CpZ6iNar.js → pb_form_validation-CgvjWbOK.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +1 -1
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +1 -1
- metadata +27 -6
- data/dist/chunks/_typeahead-DzDn3x6q.js +0 -22
- data/dist/chunks/_weekday_stacked-BUDMgWLS.js +0 -45
- data/dist/chunks/lib-ByNfnFq7.js +0 -29
@@ -0,0 +1,166 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { Button, Card, Filter, Flex, Select, SkeletonLoading, TextInput } from "playbook-ui";
|
3
|
+
|
4
|
+
const SortingChangeCallback = (sortOptions) => {
|
5
|
+
alert(JSON.stringify(sortOptions[0]))
|
6
|
+
}
|
7
|
+
|
8
|
+
const SkeletonLoadingFilter = (props) => {
|
9
|
+
const isLoading = true
|
10
|
+
|
11
|
+
const options = [
|
12
|
+
{ value: 'USA' },
|
13
|
+
{ value: 'Canada' },
|
14
|
+
{ value: 'Brazil' },
|
15
|
+
{ value: 'Philippines' },
|
16
|
+
{ value: 'A galaxy far far away, like really far away...' },
|
17
|
+
]
|
18
|
+
|
19
|
+
return (
|
20
|
+
<div>
|
21
|
+
<div>
|
22
|
+
{isLoading ? (
|
23
|
+
<Card
|
24
|
+
marginBottom="lg"
|
25
|
+
{...props}
|
26
|
+
>
|
27
|
+
<Flex
|
28
|
+
alignItems="center"
|
29
|
+
justify="between"
|
30
|
+
orientation="row"
|
31
|
+
>
|
32
|
+
<Flex
|
33
|
+
alignItems="center"
|
34
|
+
justify="start"
|
35
|
+
orientation="row"
|
36
|
+
>
|
37
|
+
<SkeletonLoading
|
38
|
+
borderRadius="rounded"
|
39
|
+
height="40px"
|
40
|
+
marginRight="sm"
|
41
|
+
width="40px"
|
42
|
+
{...props}
|
43
|
+
/>
|
44
|
+
<SkeletonLoading
|
45
|
+
height="16px"
|
46
|
+
marginRight="md"
|
47
|
+
width="80px"
|
48
|
+
{...props}
|
49
|
+
/>
|
50
|
+
</Flex>
|
51
|
+
<Flex
|
52
|
+
alignItems="center"
|
53
|
+
justify="end"
|
54
|
+
orientation="row"
|
55
|
+
>
|
56
|
+
<SkeletonLoading
|
57
|
+
height="18px"
|
58
|
+
width="120px"
|
59
|
+
{...props}
|
60
|
+
/>
|
61
|
+
</Flex>
|
62
|
+
</Flex>
|
63
|
+
</Card>
|
64
|
+
) : (
|
65
|
+
<Filter
|
66
|
+
filters={{ 'Full Name': 'John Wick' }}
|
67
|
+
marginBottom="lg"
|
68
|
+
minWidth="375px"
|
69
|
+
results={546}
|
70
|
+
sortOptions={{
|
71
|
+
popularity: 'Popularity',
|
72
|
+
// eslint-disable-next-line
|
73
|
+
manager_title: 'Manager\'s Title',
|
74
|
+
// eslint-disable-next-line
|
75
|
+
manager_name: 'Manager\'s Name',
|
76
|
+
}}
|
77
|
+
sortValue={[{ name: 'popularity', dir: 'desc' }]}
|
78
|
+
>
|
79
|
+
{({ closePopover }) => (
|
80
|
+
<form>
|
81
|
+
<TextInput
|
82
|
+
label="Example Text Field"
|
83
|
+
placeholder="Enter Text"
|
84
|
+
/>
|
85
|
+
<Select
|
86
|
+
blankSelection="Select One..."
|
87
|
+
label="Example Collection Select"
|
88
|
+
name="Collection Select"
|
89
|
+
options={options}
|
90
|
+
/>
|
91
|
+
<Flex spacing="between">
|
92
|
+
<Button
|
93
|
+
onClick={closePopover}
|
94
|
+
text="Filter"
|
95
|
+
/>
|
96
|
+
<Button
|
97
|
+
text="Defaults"
|
98
|
+
variant="secondary"
|
99
|
+
/>
|
100
|
+
</Flex>
|
101
|
+
</form>
|
102
|
+
)}
|
103
|
+
</Filter>
|
104
|
+
)}
|
105
|
+
</div>
|
106
|
+
<div>
|
107
|
+
{isLoading ? (
|
108
|
+
<SkeletonLoading
|
109
|
+
height="127px"
|
110
|
+
marginBottom="lg"
|
111
|
+
width="100%"
|
112
|
+
{...props}
|
113
|
+
/>
|
114
|
+
) : (
|
115
|
+
<Filter
|
116
|
+
double
|
117
|
+
filters={{
|
118
|
+
'Full Name': 'John Wick',
|
119
|
+
'City': 'San Francisco',
|
120
|
+
}}
|
121
|
+
marginBottom="xl"
|
122
|
+
minWidth="375px"
|
123
|
+
onSortChange={SortingChangeCallback}
|
124
|
+
results={1}
|
125
|
+
sortOptions={{
|
126
|
+
popularity: 'Popularity',
|
127
|
+
// eslint-disable-next-line
|
128
|
+
manager_title: 'Manager\'s Title',
|
129
|
+
// eslint-disable-next-line
|
130
|
+
manager_name: 'Manager\'s Name',
|
131
|
+
}}
|
132
|
+
sortValue={[{ name: 'popularity', dir: 'desc' }]}
|
133
|
+
>
|
134
|
+
{({ closePopover }) => (
|
135
|
+
<form>
|
136
|
+
<TextInput
|
137
|
+
label="Full Name"
|
138
|
+
placeholder="Enter name"
|
139
|
+
/>
|
140
|
+
<Select
|
141
|
+
blankSelection="Select One..."
|
142
|
+
label="Territory"
|
143
|
+
maxWidth="sm"
|
144
|
+
name="location"
|
145
|
+
options={options}
|
146
|
+
/>
|
147
|
+
<Flex spacing="between">
|
148
|
+
<Button
|
149
|
+
onClick={closePopover}
|
150
|
+
text="Filter"
|
151
|
+
/>
|
152
|
+
<Button
|
153
|
+
text="Defaults"
|
154
|
+
variant="secondary"
|
155
|
+
/>
|
156
|
+
</Flex>
|
157
|
+
</form>
|
158
|
+
)}
|
159
|
+
</Filter>
|
160
|
+
)}
|
161
|
+
</div>
|
162
|
+
</div>
|
163
|
+
)
|
164
|
+
}
|
165
|
+
|
166
|
+
export default SkeletonLoadingFilter;
|
@@ -20,6 +20,7 @@ const SkeletonLoadingHeightWidth = (props) => (
|
|
20
20
|
<Card htmlOptions={{ style: { height: '200px', width: '100%' }}}
|
21
21
|
marginBottom="md"
|
22
22
|
padding="none"
|
23
|
+
{...props}
|
23
24
|
>
|
24
25
|
<SkeletonLoading
|
25
26
|
borderRadius="md"
|
@@ -31,6 +32,7 @@ const SkeletonLoadingHeightWidth = (props) => (
|
|
31
32
|
</Card>
|
32
33
|
<Card htmlOptions={{ style: { height: '200px', width: '100%' }}}
|
33
34
|
padding="none"
|
35
|
+
{...props}
|
34
36
|
>
|
35
37
|
<SkeletonLoading
|
36
38
|
borderRadius="md"
|
@@ -0,0 +1,89 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { Flex, SkeletonLoading, User } from "playbook-ui";
|
3
|
+
|
4
|
+
const SkeletonLoadingUser = (props) => {
|
5
|
+
const isLoading = true
|
6
|
+
|
7
|
+
return (
|
8
|
+
<div>
|
9
|
+
<div>
|
10
|
+
{isLoading ? (
|
11
|
+
<Flex alignItems="center">
|
12
|
+
<SkeletonLoading
|
13
|
+
borderRadius="rounded"
|
14
|
+
height="38px"
|
15
|
+
paddingRight="sm"
|
16
|
+
width="38px"
|
17
|
+
{...props}
|
18
|
+
/>
|
19
|
+
<SkeletonLoading
|
20
|
+
gap="xxs"
|
21
|
+
height="18px"
|
22
|
+
stack="2"
|
23
|
+
width="161px"
|
24
|
+
{...props}
|
25
|
+
/>
|
26
|
+
</Flex>
|
27
|
+
) : (
|
28
|
+
<User
|
29
|
+
align="left"
|
30
|
+
avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
|
31
|
+
name="Anna Black"
|
32
|
+
orientation="horizontal"
|
33
|
+
title="Remodeling Consultant"
|
34
|
+
{...props}
|
35
|
+
/>
|
36
|
+
)}
|
37
|
+
</div>
|
38
|
+
<div>
|
39
|
+
{isLoading ? (
|
40
|
+
<Flex
|
41
|
+
alignItems="start"
|
42
|
+
paddingTop="md"
|
43
|
+
>
|
44
|
+
<Flex
|
45
|
+
alignItems="center"
|
46
|
+
flexDirection="column"
|
47
|
+
>
|
48
|
+
<SkeletonLoading
|
49
|
+
borderRadius="rounded"
|
50
|
+
height="80px"
|
51
|
+
paddingBottom="xs"
|
52
|
+
width="80px"
|
53
|
+
{...props}
|
54
|
+
/>
|
55
|
+
<SkeletonLoading
|
56
|
+
height="32px"
|
57
|
+
paddingBottom="xxs"
|
58
|
+
width="144px"
|
59
|
+
{...props}
|
60
|
+
/>
|
61
|
+
<SkeletonLoading
|
62
|
+
height="21px"
|
63
|
+
width="164px"
|
64
|
+
{...props}
|
65
|
+
/>
|
66
|
+
</Flex>
|
67
|
+
</Flex>
|
68
|
+
) : (
|
69
|
+
<Flex
|
70
|
+
alignItems="start"
|
71
|
+
paddingTop="md"
|
72
|
+
>
|
73
|
+
<User
|
74
|
+
align="center"
|
75
|
+
avatarUrl="https://randomuser.me/api/portraits/women/44.jpg"
|
76
|
+
name="Anna Black"
|
77
|
+
orientation="vertical"
|
78
|
+
size="lg"
|
79
|
+
title="Remodeling Consultant"
|
80
|
+
{...props}
|
81
|
+
/>
|
82
|
+
</Flex>
|
83
|
+
)}
|
84
|
+
</div>
|
85
|
+
</div>
|
86
|
+
)
|
87
|
+
}
|
88
|
+
|
89
|
+
export default SkeletonLoadingUser;
|
@@ -3,3 +3,5 @@ export { default as SkeletonLoadingColor } from './_skeleton_loading_color.jsx'
|
|
3
3
|
export { default as SkeletonLoadingLayout } from './_skeleton_loading_layout.jsx'
|
4
4
|
export { default as SkeletonLoadingBorderRadius } from './_skeleton_loading_border_radius.jsx'
|
5
5
|
export { default as SkeletonLoadingHeightWidth } from './_skeleton_loading_height_width.jsx'
|
6
|
+
export { default as SkeletonLoadingUser } from './_skeleton_loading_user.jsx'
|
7
|
+
export { default as SkeletonLoadingFilter } from './_skeleton_loading_filter.jsx'
|
@@ -92,16 +92,16 @@ const Table = (props: TableProps): React.ReactElement => {
|
|
92
92
|
useEffect(() => {
|
93
93
|
const handleStickyColumns = () => {
|
94
94
|
let accumulatedWidth = 0;
|
95
|
-
|
95
|
+
|
96
96
|
stickyLeftcolumn.forEach((colId, index) => {
|
97
97
|
const isLastColumn = index === stickyLeftcolumn.length - 1;
|
98
98
|
const header = document.querySelector(`th[id="${colId}"]`);
|
99
99
|
const cells = document.querySelectorAll(`td[id="${colId}"]`);
|
100
|
-
|
100
|
+
|
101
101
|
if (header) {
|
102
102
|
header.classList.add('sticky');
|
103
103
|
(header as HTMLElement).style.left = `${accumulatedWidth}px`;
|
104
|
-
|
104
|
+
|
105
105
|
if (!isLastColumn) {
|
106
106
|
header.classList.add('with-border');
|
107
107
|
header.classList.remove('sticky-shadow');
|
@@ -109,14 +109,14 @@ const Table = (props: TableProps): React.ReactElement => {
|
|
109
109
|
header.classList.remove('with-border');
|
110
110
|
header.classList.add('sticky-shadow');
|
111
111
|
}
|
112
|
-
|
112
|
+
|
113
113
|
accumulatedWidth += (header as HTMLElement).offsetWidth;
|
114
114
|
}
|
115
|
-
|
115
|
+
|
116
116
|
cells.forEach((cell) => {
|
117
117
|
cell.classList.add('sticky');
|
118
118
|
(cell as HTMLElement).style.left = `${accumulatedWidth - (header as HTMLElement).offsetWidth}px`;
|
119
|
-
|
119
|
+
|
120
120
|
if (!isLastColumn) {
|
121
121
|
cell.classList.add('with-border');
|
122
122
|
cell.classList.remove('sticky-shadow');
|
@@ -25,16 +25,16 @@
|
|
25
25
|
<td id="3">Value 3</td>
|
26
26
|
<td>Value 4</td>
|
27
27
|
<td>Value 5</td>
|
28
|
-
<td>
|
29
|
-
<td>
|
30
|
-
<td>
|
31
|
-
<td>
|
32
|
-
<td>
|
33
|
-
<td>
|
34
|
-
<td>
|
35
|
-
<td>
|
36
|
-
<td>
|
37
|
-
<td>
|
28
|
+
<td>Value 6</td>
|
29
|
+
<td>Value 7</td>
|
30
|
+
<td>Value 8</td>
|
31
|
+
<td>Value 9</td>
|
32
|
+
<td>Value 10</td>
|
33
|
+
<td>Value 11</td>
|
34
|
+
<td>Value 12</td>
|
35
|
+
<td>Value 13</td>
|
36
|
+
<td>Value 14</td>
|
37
|
+
<td>Value 15</td>
|
38
38
|
|
39
39
|
</tr>
|
40
40
|
<tr>
|
@@ -43,16 +43,16 @@
|
|
43
43
|
<td id="3">Value 3</td>
|
44
44
|
<td>Value 4</td>
|
45
45
|
<td>Value 5</td>
|
46
|
-
<td>
|
47
|
-
<td>
|
48
|
-
<td>
|
49
|
-
<td>
|
50
|
-
<td>
|
51
|
-
<td>
|
52
|
-
<td>
|
53
|
-
<td>
|
54
|
-
<td>
|
55
|
-
<td>
|
46
|
+
<td>Value 6</td>
|
47
|
+
<td>Value 7</td>
|
48
|
+
<td>Value 8</td>
|
49
|
+
<td>Value 9</td>
|
50
|
+
<td>Value 10</td>
|
51
|
+
<td>Value 11</td>
|
52
|
+
<td>Value 12</td>
|
53
|
+
<td>Value 13</td>
|
54
|
+
<td>Value 14</td>
|
55
|
+
<td>Value 15</td>
|
56
56
|
|
57
57
|
</tr>
|
58
58
|
<tr>
|
@@ -61,34 +61,16 @@
|
|
61
61
|
<td id="3">Value 3</td>
|
62
62
|
<td>Value 4</td>
|
63
63
|
<td>Value 5</td>
|
64
|
-
<td>
|
65
|
-
<td>
|
66
|
-
<td>
|
67
|
-
<td>
|
68
|
-
<td>
|
69
|
-
<td>
|
70
|
-
<td>
|
71
|
-
<td>
|
72
|
-
<td>
|
73
|
-
<td>
|
74
|
-
|
75
|
-
</tr>
|
76
|
-
<tr>
|
77
|
-
<td id="1">Value 1</td>
|
78
|
-
<td id="2">Value 2</td>
|
79
|
-
<td id="3">Value 3</td>
|
80
|
-
<td>Value 4</td>
|
81
|
-
<td>Value 5</td>
|
82
|
-
<td>Column 6</td>
|
83
|
-
<td>Column 7</td>
|
84
|
-
<td>Column 8</td>
|
85
|
-
<td>Column 9</td>
|
86
|
-
<td>Column 10</td>
|
87
|
-
<td>Column 11</td>
|
88
|
-
<td>Column 12</td>
|
89
|
-
<td>Column 13</td>
|
90
|
-
<td>Column 14</td>
|
91
|
-
<td>Column 15</td>
|
64
|
+
<td>Value 6</td>
|
65
|
+
<td>Value 7</td>
|
66
|
+
<td>Value 8</td>
|
67
|
+
<td>Value 9</td>
|
68
|
+
<td>Value 10</td>
|
69
|
+
<td>Value 11</td>
|
70
|
+
<td>Value 12</td>
|
71
|
+
<td>Value 13</td>
|
72
|
+
<td>Value 14</td>
|
73
|
+
<td>Value 15</td>
|
92
74
|
|
93
75
|
</tr>
|
94
76
|
</tbody>
|
@@ -0,0 +1 @@
|
|
1
|
+
The `stickyLeftColumn` prop expects an array of the column ids you want to be sticky. Make sure to add the corresponding id to the `<th>` and `<td>`.
|
@@ -0,0 +1,75 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Table, Icon, Body, Card } from 'playbook-ui'
|
3
|
+
|
4
|
+
const TableWithCollapsible = (props) => {
|
5
|
+
|
6
|
+
const Content = () => {
|
7
|
+
return (
|
8
|
+
<Card
|
9
|
+
borderNone
|
10
|
+
borderRadius="none"
|
11
|
+
padding="md"
|
12
|
+
{...props}
|
13
|
+
>
|
14
|
+
<Body {...props}>Nested content inside a Table Row</Body>
|
15
|
+
</Card>
|
16
|
+
);
|
17
|
+
};
|
18
|
+
|
19
|
+
return (
|
20
|
+
<Table
|
21
|
+
size="sm"
|
22
|
+
{...props}
|
23
|
+
>
|
24
|
+
<Table.Head>
|
25
|
+
<Table.Row>
|
26
|
+
<Table.Header>{'Column 1'}</Table.Header>
|
27
|
+
<Table.Header>{'Column 2'}</Table.Header>
|
28
|
+
<Table.Header>{'Column 3'}</Table.Header>
|
29
|
+
<Table.Header>{'Column 4'}</Table.Header>
|
30
|
+
<Table.Header>{'Column 5'}</Table.Header>
|
31
|
+
<Table.Header>{''}</Table.Header>
|
32
|
+
</Table.Row>
|
33
|
+
|
34
|
+
</Table.Head>
|
35
|
+
<Table.Body>
|
36
|
+
<Table.Row collapsible
|
37
|
+
collapsibleContent={<Content/>}
|
38
|
+
{...props}
|
39
|
+
>
|
40
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
41
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
42
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
43
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
44
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
45
|
+
<Table.Cell textAlign="right">{
|
46
|
+
<Icon
|
47
|
+
color="primary"
|
48
|
+
fixedWidth
|
49
|
+
icon="chevron-down"
|
50
|
+
/>}
|
51
|
+
</Table.Cell>
|
52
|
+
|
53
|
+
</Table.Row>
|
54
|
+
<Table.Row>
|
55
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
56
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
57
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
58
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
59
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
60
|
+
<Table.Cell>{''}</Table.Cell>
|
61
|
+
</Table.Row>
|
62
|
+
<Table.Row>
|
63
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
64
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
65
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
66
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
67
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
68
|
+
<Table.Cell>{''}</Table.Cell>
|
69
|
+
</Table.Row>
|
70
|
+
</Table.Body>
|
71
|
+
</Table>
|
72
|
+
)
|
73
|
+
}
|
74
|
+
|
75
|
+
export default TableWithCollapsible
|
@@ -0,0 +1 @@
|
|
1
|
+
The `collapsible` prop can be used on any Table Row to add a collapsible area. Use the additional `collapsibleContent` prop to add any content to the collapsible Row.
|
@@ -0,0 +1,108 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Table, Card, Icon, Body } from 'playbook-ui'
|
3
|
+
|
4
|
+
const TableWithCollapsibleWithCustomClick = (props) => {
|
5
|
+
|
6
|
+
const Content = () => {
|
7
|
+
return (
|
8
|
+
<Card
|
9
|
+
borderNone
|
10
|
+
borderRadius="none"
|
11
|
+
padding="md"
|
12
|
+
{...props}
|
13
|
+
>
|
14
|
+
<Body {...props}>Nested content inside a Table Row</Body>
|
15
|
+
</Card>
|
16
|
+
);
|
17
|
+
};
|
18
|
+
|
19
|
+
|
20
|
+
return (
|
21
|
+
<Table
|
22
|
+
size="sm"
|
23
|
+
{...props}
|
24
|
+
>
|
25
|
+
<Table.Head>
|
26
|
+
<Table.Row>
|
27
|
+
<Table.Header>{'Column 1'}</Table.Header>
|
28
|
+
<Table.Header>{'Column 2'}</Table.Header>
|
29
|
+
<Table.Header>{'Column 3'}</Table.Header>
|
30
|
+
<Table.Header>{'Column 4'}</Table.Header>
|
31
|
+
<Table.Header>{'Column 5'}</Table.Header>
|
32
|
+
<Table.Header>{''}</Table.Header>
|
33
|
+
</Table.Row>
|
34
|
+
|
35
|
+
</Table.Head>
|
36
|
+
<Table.Body>
|
37
|
+
<Table.Row collapsible
|
38
|
+
collapsibleContent={<Content/>}
|
39
|
+
toggleCellId="cell-1"
|
40
|
+
{...props}
|
41
|
+
>
|
42
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
43
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
44
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
45
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
46
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
47
|
+
<Table.Cell cursor="pointer"
|
48
|
+
id="cell-1"
|
49
|
+
textAlign="right"
|
50
|
+
>
|
51
|
+
<Icon
|
52
|
+
color="primary"
|
53
|
+
fixedWidth
|
54
|
+
icon="chevron-down"
|
55
|
+
/>
|
56
|
+
</Table.Cell>
|
57
|
+
|
58
|
+
</Table.Row>
|
59
|
+
<Table.Row collapsible
|
60
|
+
collapsibleContent={<Content/>}
|
61
|
+
toggleCellId="cell-2"
|
62
|
+
{...props}
|
63
|
+
>
|
64
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
65
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
66
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
67
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
68
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
69
|
+
<Table.Cell cursor="pointer"
|
70
|
+
id="cell-2"
|
71
|
+
textAlign="right"
|
72
|
+
>
|
73
|
+
<Icon
|
74
|
+
color="primary"
|
75
|
+
fixedWidth
|
76
|
+
icon="chevron-down"
|
77
|
+
/>
|
78
|
+
</Table.Cell>
|
79
|
+
|
80
|
+
</Table.Row>
|
81
|
+
<Table.Row collapsible
|
82
|
+
collapsibleContent={<Content/>}
|
83
|
+
toggleCellId="cell-3"
|
84
|
+
{...props}
|
85
|
+
>
|
86
|
+
<Table.Cell>{'Value 1'}</Table.Cell>
|
87
|
+
<Table.Cell>{'Value 2'}</Table.Cell>
|
88
|
+
<Table.Cell>{'Value 3'}</Table.Cell>
|
89
|
+
<Table.Cell>{'Value 4'}</Table.Cell>
|
90
|
+
<Table.Cell>{'Value 5'}</Table.Cell>
|
91
|
+
<Table.Cell cursor="pointer"
|
92
|
+
id="cell-3"
|
93
|
+
textAlign="right"
|
94
|
+
>
|
95
|
+
<Icon
|
96
|
+
color="primary"
|
97
|
+
fixedWidth
|
98
|
+
icon="chevron-down"
|
99
|
+
/>
|
100
|
+
</Table.Cell>
|
101
|
+
|
102
|
+
</Table.Row>
|
103
|
+
</Table.Body>
|
104
|
+
</Table>
|
105
|
+
)
|
106
|
+
}
|
107
|
+
|
108
|
+
export default TableWithCollapsibleWithCustomClick
|
@@ -0,0 +1,2 @@
|
|
1
|
+
When using the `collapsible` prop, the default functionality is that the entire Row will be clickable to toggle the Row. To limit the click event to a specific Table Cell, you can use the `toggleCellId` prop to pass in the id of the Cell you want to use as the trigger.
|
2
|
+
__NOTE__: `toggleCellId` and the id on the Cell you want to use as the trigger MUST be the same.
|