playbook_ui_docs 14.21.2.pre.alpha.PLAY2046advancedtableinfinitescroll8311 → 14.21.2.pre.alpha.PLAY2241tablestickycolumnsdatanotids8357
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_filter/docs/_filter_sidebar.jsx +224 -0
- data/app/pb_kits/playbook/pb_filter/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_filter/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns.html.erb +8 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_columns_rails.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns_rails.md +2 -2
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns.html.erb +12 -12
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_right_columns_rails.md +2 -2
- data/dist/playbook-doc.js +1 -1
- metadata +3 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: d120cac8061323593d96749236a1dc0e10b920fa9f880788af10ef928a3b908b
|
4
|
+
data.tar.gz: b1867b18ddaaba4d8dd700642aeb1d70608a3471ac54df8799589bfc554f3d76
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 8382f6ab7877f6a46ab5a3c5c3aaac743387476fd31c23017055b1fa3260a13c9648694fbf8ac7ed08936fd756ff8d75c90807caf376a36d6217f186f8b4fe27
|
7
|
+
data.tar.gz: 8bc10de13ca0a3ddaf52f3e6ec03972f1b9af010794d2eeff5c2408d62f8a613aa3dd2ffd6d65b83dc29edd2cdbcf4e22d8fd370e6eae370bd7a5c2735277359
|
@@ -0,0 +1,224 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
|
3
|
+
import Filter from '../../pb_filter/_filter'
|
4
|
+
import Select from '../../pb_select/_select'
|
5
|
+
import TextInput from '../../pb_text_input/_text_input'
|
6
|
+
import useCollapsible from '../../pb_collapsible/useCollapsible'
|
7
|
+
import SectionSeparator from '../../pb_section_separator/_section_separator'
|
8
|
+
import Checkbox from '../../pb_checkbox/_checkbox'
|
9
|
+
import Flex from '../../pb_flex/_flex'
|
10
|
+
import Table from '../../pb_table/_table'
|
11
|
+
import Caption from '../../pb_caption/_caption'
|
12
|
+
import Icon from '../../pb_icon/_icon'
|
13
|
+
|
14
|
+
const people = [
|
15
|
+
{ name: 'Hera Syndulla', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
|
16
|
+
{ name: 'Kanan Jarrus', territory: 'USA', products: ['Siding', 'Roofing', 'Gutters'] },
|
17
|
+
{ name: 'C1-10P', territory: 'USA', products: ['Roofing'] },
|
18
|
+
{ name: 'Anakin Skywalker', territory: 'A galaxy far far away, like really far away...', products: ['Doors', 'Windows', 'Solar'] },
|
19
|
+
{ name: 'Leia Organa', territory: 'Canada', products: ['Windows', 'Doors'] },
|
20
|
+
{ name: 'Luke Skywalker', territory: 'Brazil', products: ['Solar', 'Roofing'] },
|
21
|
+
{ name: 'Padmé Amidala', territory: 'Philippines', products: ['Siding', 'Gutters'] },
|
22
|
+
{ name: 'Obi-Wan Kenobi', territory: 'USA', products: ['Windows', 'Siding'] },
|
23
|
+
{ name: 'Ahsoka Tano', territory: 'Canada', products: ['Insulation', 'Solar'] },
|
24
|
+
{ name: 'Boba Fett', territory: 'Brazil', products: ['Roofing', 'Gutters'] },
|
25
|
+
{ name: 'Mace Windu', territory: 'Philippines', products: ['Doors', 'Siding'] },
|
26
|
+
{ name: 'Grogu', territory: 'A galaxy far far away, like really far away...', products: ['Insulation'] },
|
27
|
+
{ name: 'Sabine Wren', territory: 'Canada', products: ['Solar', 'Doors'] },
|
28
|
+
{ name: 'C-3PO', territory: 'Brazil', products: ['Windows'] },
|
29
|
+
{ name: 'R2-D2', territory: 'Philippines', products: ['Doors', 'Gutters'] },
|
30
|
+
]
|
31
|
+
|
32
|
+
const FilterSidebar = (props) => {
|
33
|
+
const [name, setName] = useState('')
|
34
|
+
const [ territory, setTerritory ] = useState('')
|
35
|
+
const [ products, setProducts ] = useState({})
|
36
|
+
const handleUpdateName = ({ target }) => {
|
37
|
+
setName(target.value)
|
38
|
+
}
|
39
|
+
const handleUpdateTerritory = ({ target }) => {
|
40
|
+
setTerritory(target.value)
|
41
|
+
}
|
42
|
+
const handleCheckboxChange = ({ target }) => {
|
43
|
+
setProducts(prev => ({
|
44
|
+
...prev,
|
45
|
+
[target.name]: !prev[target.name],
|
46
|
+
}))
|
47
|
+
}
|
48
|
+
const [isCollapsed, setIsCollapsed] = useCollapsible(true)
|
49
|
+
const [isProductsCollapsed, setIsProductsCollapsed] = useCollapsible(true)
|
50
|
+
const options = [
|
51
|
+
{ value: 'USA' },
|
52
|
+
{ value: 'Canada' },
|
53
|
+
{ value: 'Brazil' },
|
54
|
+
{ value: 'Philippines' },
|
55
|
+
{ value: 'A galaxy far far away, like really far away...' },
|
56
|
+
]
|
57
|
+
|
58
|
+
const filteredPeople = people.filter((person) => {
|
59
|
+
const matchesName = person.name.toLowerCase().includes(name.toLowerCase())
|
60
|
+
|
61
|
+
const matchesTerritory = territory === '' ? true : person.territory === territory
|
62
|
+
|
63
|
+
const matchesProducts = Object.values(products).every((product) => !product) ? true : person.products.some(product => products[product])
|
64
|
+
|
65
|
+
return matchesName && matchesTerritory && matchesProducts
|
66
|
+
})
|
67
|
+
|
68
|
+
return (
|
69
|
+
<>
|
70
|
+
<Flex>
|
71
|
+
<Filter
|
72
|
+
isCollapsed={isCollapsed}
|
73
|
+
marginRight="xs"
|
74
|
+
onCollapse={() => setIsCollapsed(!isCollapsed)}
|
75
|
+
results={filteredPeople.length}
|
76
|
+
sortOptions={{
|
77
|
+
popularity: 'Popularity',
|
78
|
+
// eslint-disable-next-line
|
79
|
+
manager_title: 'Manager\'s Title',
|
80
|
+
// eslint-disable-next-line
|
81
|
+
manager_name: 'Manager\'s Name',
|
82
|
+
}}
|
83
|
+
sortValue={[{ name: 'popularity', dir: 'desc' }]}
|
84
|
+
variant="sidebar"
|
85
|
+
width="xs"
|
86
|
+
{...props}
|
87
|
+
>
|
88
|
+
<Filter.Section
|
89
|
+
collapsed={isCollapsed}
|
90
|
+
headerText="Full Name"
|
91
|
+
>
|
92
|
+
<TextInput
|
93
|
+
onChange={handleUpdateName}
|
94
|
+
placeholder="Enter name"
|
95
|
+
value={name}
|
96
|
+
{...props}
|
97
|
+
/>
|
98
|
+
</Filter.Section>
|
99
|
+
<SectionSeparator />
|
100
|
+
<Filter.Section
|
101
|
+
collapsed={isCollapsed}
|
102
|
+
collapsible
|
103
|
+
headerText="Territory"
|
104
|
+
>
|
105
|
+
<Select
|
106
|
+
blankSelection="Select One..."
|
107
|
+
name="location"
|
108
|
+
onChange={handleUpdateTerritory}
|
109
|
+
options={options}
|
110
|
+
{...props}
|
111
|
+
/>
|
112
|
+
</Filter.Section>
|
113
|
+
<SectionSeparator />
|
114
|
+
<Filter.Section
|
115
|
+
collapsed={isCollapsed}
|
116
|
+
collapsible
|
117
|
+
headerText="Products"
|
118
|
+
>
|
119
|
+
<div>
|
120
|
+
<Checkbox
|
121
|
+
marginBottom="sm"
|
122
|
+
name="Doors"
|
123
|
+
onChange={handleCheckboxChange}
|
124
|
+
text="Doors"
|
125
|
+
/>
|
126
|
+
</div>
|
127
|
+
<div>
|
128
|
+
<Checkbox
|
129
|
+
marginBottom="sm"
|
130
|
+
name="Windows"
|
131
|
+
onChange={handleCheckboxChange}
|
132
|
+
text="Windows"
|
133
|
+
/>
|
134
|
+
</div>
|
135
|
+
<div>
|
136
|
+
<Checkbox
|
137
|
+
marginBottom="sm"
|
138
|
+
name="Siding"
|
139
|
+
onChange={handleCheckboxChange}
|
140
|
+
text="Siding"
|
141
|
+
/>
|
142
|
+
</div>
|
143
|
+
{!isProductsCollapsed &&
|
144
|
+
<>
|
145
|
+
<div>
|
146
|
+
<Checkbox
|
147
|
+
checked={products["Roofing"]}
|
148
|
+
marginBottom="sm"
|
149
|
+
name="Roofing"
|
150
|
+
onChange={handleCheckboxChange}
|
151
|
+
text="Roofing"
|
152
|
+
/>
|
153
|
+
</div>
|
154
|
+
<div>
|
155
|
+
<Checkbox
|
156
|
+
checked={products["Gutters"]}
|
157
|
+
marginBottom="sm"
|
158
|
+
name="Gutters"
|
159
|
+
onChange={handleCheckboxChange}
|
160
|
+
text="Gutters"
|
161
|
+
/>
|
162
|
+
</div>
|
163
|
+
<div>
|
164
|
+
<Checkbox
|
165
|
+
checked={products["Solar"]}
|
166
|
+
marginBottom="sm"
|
167
|
+
name="Solar"
|
168
|
+
onChange={handleCheckboxChange}
|
169
|
+
text="Solar"
|
170
|
+
/>
|
171
|
+
</div>
|
172
|
+
<div>
|
173
|
+
<Checkbox
|
174
|
+
checked={products["Insulation"]}
|
175
|
+
marginBottom="sm"
|
176
|
+
name="Insulation"
|
177
|
+
onChange={handleCheckboxChange}
|
178
|
+
text="Insulation"
|
179
|
+
/>
|
180
|
+
</div>
|
181
|
+
</>
|
182
|
+
}
|
183
|
+
<div onClick={() => setIsProductsCollapsed(!isProductsCollapsed)}>
|
184
|
+
<Flex
|
185
|
+
cursor="pointer"
|
186
|
+
marginBottom="sm"
|
187
|
+
>
|
188
|
+
<Caption
|
189
|
+
color="link"
|
190
|
+
marginRight="xxs"
|
191
|
+
size="xs"
|
192
|
+
text={isProductsCollapsed ? "Show More" : "Show Less"}
|
193
|
+
/>
|
194
|
+
<Icon
|
195
|
+
icon={isProductsCollapsed ? "chevron-down" : "chevron-up"}
|
196
|
+
/>
|
197
|
+
</Flex>
|
198
|
+
</div>
|
199
|
+
</Filter.Section>
|
200
|
+
</Filter>
|
201
|
+
<Table
|
202
|
+
size="sm"
|
203
|
+
>
|
204
|
+
<thead>
|
205
|
+
<tr>
|
206
|
+
<th>{'Name'}</th>
|
207
|
+
<th>{'Territory'}</th>
|
208
|
+
<th>{'Products'}</th>
|
209
|
+
</tr>
|
210
|
+
</thead>
|
211
|
+
<tbody>
|
212
|
+
{filteredPeople.map((person) => (<tr key={person.name}>
|
213
|
+
<td>{ person.name }</td>
|
214
|
+
<td>{ person.territory }</td>
|
215
|
+
<td>{ person.products.join(", ") }</td>
|
216
|
+
</tr>))}
|
217
|
+
</tbody>
|
218
|
+
</Table>
|
219
|
+
</Flex>
|
220
|
+
</>
|
221
|
+
)
|
222
|
+
}
|
223
|
+
|
224
|
+
export default FilterSidebar
|
@@ -8,3 +8,4 @@ export { default as FilterMaxWidth } from './_filter_max_width.jsx'
|
|
8
8
|
export { default as FilterMaxHeight } from './_filter_max_height.jsx'
|
9
9
|
export { default as FilterPlacement } from './_filter_placement.jsx'
|
10
10
|
export { default as FilterPopoverProps } from './_filter_popover_props.jsx'
|
11
|
+
export { default as FilterSidebar } from './_filter_sidebar.jsx'
|
@@ -1,7 +1,7 @@
|
|
1
1
|
<%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["a"], sticky_right_column: ["b"] }) do %>
|
2
2
|
<thead>
|
3
3
|
<tr>
|
4
|
-
<th id="a">Column 1</th>
|
4
|
+
<th data-sticky-id="a">Column 1</th>
|
5
5
|
<th>Column 2</th>
|
6
6
|
<th>Column 3</th>
|
7
7
|
<th>Column 4</th>
|
@@ -15,12 +15,12 @@
|
|
15
15
|
<th>Column 12</th>
|
16
16
|
<th>Column 13</th>
|
17
17
|
<th>Column 14</th>
|
18
|
-
<th id="b">Column 15</th>
|
18
|
+
<th data-sticky-id="b">Column 15</th>
|
19
19
|
</tr>
|
20
20
|
</thead>
|
21
21
|
<tbody>
|
22
22
|
<tr>
|
23
|
-
<td id="a">Value 1</td>
|
23
|
+
<td data-sticky-id="a">Value 1</td>
|
24
24
|
<td>Value 2</td>
|
25
25
|
<td>Value 3</td>
|
26
26
|
<td>Value 4</td>
|
@@ -34,10 +34,10 @@
|
|
34
34
|
<td>Value 12</td>
|
35
35
|
<td>Value 13</td>
|
36
36
|
<td>Value 14</td>
|
37
|
-
<td id="b">Value 15</td>
|
37
|
+
<td data-sticky-id="b">Value 15</td>
|
38
38
|
</tr>
|
39
39
|
<tr>
|
40
|
-
<td id="a">Value 1</td>
|
40
|
+
<td data-sticky-id="a">Value 1</td>
|
41
41
|
<td>Value 2</td>
|
42
42
|
<td>Value 3</td>
|
43
43
|
<td>Value 4</td>
|
@@ -51,10 +51,10 @@
|
|
51
51
|
<td>Value 12</td>
|
52
52
|
<td>Value 13</td>
|
53
53
|
<td>Value 14</td>
|
54
|
-
<td id="b">Value 15</td>
|
54
|
+
<td data-sticky-id="b">Value 15</td>
|
55
55
|
</tr>
|
56
56
|
<tr>
|
57
|
-
<td id="a">Value 1</td>
|
57
|
+
<td data-sticky-id="a">Value 1</td>
|
58
58
|
<td>Value 2</td>
|
59
59
|
<td>Value 3</td>
|
60
60
|
<td>Value 4</td>
|
@@ -68,7 +68,7 @@
|
|
68
68
|
<td>Value 12</td>
|
69
69
|
<td>Value 13</td>
|
70
70
|
<td>Value 14</td>
|
71
|
-
<td id="b">Value 15</td>
|
71
|
+
<td data-sticky-id="b">Value 15</td>
|
72
72
|
</tr>
|
73
73
|
</tbody>
|
74
74
|
<% end %>
|
@@ -1,3 +1,3 @@
|
|
1
1
|
The `sticky_left_column` and `sticky_right_column` props can be used together on the same table as needed.
|
2
2
|
|
3
|
-
Please ensure that unique
|
3
|
+
Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using props.
|
@@ -1,9 +1,9 @@
|
|
1
1
|
<%= pb_rails("table", props: { size: "md", responsive: "scroll", sticky_left_column: ["1", "2", "3"] }) do %>
|
2
2
|
<thead>
|
3
3
|
<tr>
|
4
|
-
<th id="1">Column 1</th>
|
5
|
-
<th id="2">Column 2</th>
|
6
|
-
<th id="3">Column 3</th>
|
4
|
+
<th data-sticky-id="1">Column 1</th>
|
5
|
+
<th data-sticky-id="2">Column 2</th>
|
6
|
+
<th data-sticky-id="3">Column 3</th>
|
7
7
|
<th>Column 4</th>
|
8
8
|
<th>Column 5</th>
|
9
9
|
<th>Column 6</th>
|
@@ -20,9 +20,9 @@
|
|
20
20
|
</thead>
|
21
21
|
<tbody>
|
22
22
|
<tr>
|
23
|
-
<td id="1">Value 1</td>
|
24
|
-
<td id="2">Value 2</td>
|
25
|
-
<td id="3">Value 3</td>
|
23
|
+
<td data-sticky-id="1">Value 1</td>
|
24
|
+
<td data-sticky-id="2">Value 2</td>
|
25
|
+
<td data-sticky-id="3">Value 3</td>
|
26
26
|
<td>Value 4</td>
|
27
27
|
<td>Value 5</td>
|
28
28
|
<td>Value 6</td>
|
@@ -38,9 +38,9 @@
|
|
38
38
|
|
39
39
|
</tr>
|
40
40
|
<tr>
|
41
|
-
<td id="1">Value 1</td>
|
42
|
-
<td id="2">Value 2</td>
|
43
|
-
<td id="3">Value 3</td>
|
41
|
+
<td data-sticky-id="1">Value 1</td>
|
42
|
+
<td data-sticky-id="2">Value 2</td>
|
43
|
+
<td data-sticky-id="3">Value 3</td>
|
44
44
|
<td>Value 4</td>
|
45
45
|
<td>Value 5</td>
|
46
46
|
<td>Value 6</td>
|
@@ -56,9 +56,9 @@
|
|
56
56
|
|
57
57
|
</tr>
|
58
58
|
<tr>
|
59
|
-
<td id="1">Value 1</td>
|
60
|
-
<td id="2">Value 2</td>
|
61
|
-
<td id="3">Value 3</td>
|
59
|
+
<td data-sticky-id="1">Value 1</td>
|
60
|
+
<td data-sticky-id="2">Value 2</td>
|
61
|
+
<td data-sticky-id="3">Value 3</td>
|
62
62
|
<td>Value 4</td>
|
63
63
|
<td>Value 5</td>
|
64
64
|
<td>Value 6</td>
|
@@ -1,3 +1,3 @@
|
|
1
|
-
The `sticky_left_column` prop expects an array of the column
|
1
|
+
The `sticky_left_column` prop expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
|
2
2
|
|
3
|
-
Please ensure that unique
|
3
|
+
Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using the `sticky_left_column`.
|
@@ -13,9 +13,9 @@
|
|
13
13
|
<th>Column 10</th>
|
14
14
|
<th>Column 11</th>
|
15
15
|
<th>Column 12</th>
|
16
|
-
<th id="13">Column 13</th>
|
17
|
-
<th id="14">Column 14</th>
|
18
|
-
<th id="15">Column 15</th>
|
16
|
+
<th data-sticky-id="13">Column 13</th>
|
17
|
+
<th data-sticky-id="14">Column 14</th>
|
18
|
+
<th data-sticky-id="15">Column 15</th>
|
19
19
|
</tr>
|
20
20
|
</thead>
|
21
21
|
<tbody>
|
@@ -32,9 +32,9 @@
|
|
32
32
|
<td>Value 10</td>
|
33
33
|
<td>Value 11</td>
|
34
34
|
<td>Value 12</td>
|
35
|
-
<td id="13">Value 13</td>
|
36
|
-
<td id="14">Value 14</td>
|
37
|
-
<td id="15">Value 15</td>
|
35
|
+
<td data-sticky-id="13">Value 13</td>
|
36
|
+
<td data-sticky-id="14">Value 14</td>
|
37
|
+
<td data-sticky-id="15">Value 15</td>
|
38
38
|
</tr>
|
39
39
|
<tr>
|
40
40
|
<td>Value 1</td>
|
@@ -49,9 +49,9 @@
|
|
49
49
|
<td>Value 10</td>
|
50
50
|
<td>Value 11</td>
|
51
51
|
<td>Value 12</td>
|
52
|
-
<td id="13">Value 13</td>
|
53
|
-
<td id="14">Value 14</td>
|
54
|
-
<td id="15">Value 15</td>
|
52
|
+
<td data-sticky-id="13">Value 13</td>
|
53
|
+
<td data-sticky-id="14">Value 14</td>
|
54
|
+
<td data-sticky-id="15">Value 15</td>
|
55
55
|
</tr>
|
56
56
|
<tr>
|
57
57
|
<td>Value 1</td>
|
@@ -66,9 +66,9 @@
|
|
66
66
|
<td>Value 10</td>
|
67
67
|
<td>Value 11</td>
|
68
68
|
<td>Value 12</td>
|
69
|
-
<td id="13">Value 13</td>
|
70
|
-
<td id="14">Value 14</td>
|
71
|
-
<td id="15">Value 15</td>
|
69
|
+
<td data-sticky-id="13">Value 13</td>
|
70
|
+
<td data-sticky-id="14">Value 14</td>
|
71
|
+
<td data-sticky-id="15">Value 15</td>
|
72
72
|
</tr>
|
73
73
|
</tbody>
|
74
74
|
<% end %>
|
@@ -1,3 +1,3 @@
|
|
1
|
-
The `sticky_right_column` prop works in the same way as the above `sticky_left_column` prop. It expects an array of the column
|
1
|
+
The `sticky_right_column` prop works in the same way as the above `sticky_left_column` prop. It expects an array of the column `data-sticky-id`s you want to be sticky. Make sure to add the corresponding `data-sticky-id` to the `<th>` and `<td>`.
|
2
2
|
|
3
|
-
Please ensure that unique
|
3
|
+
Please ensure that unique `data-sticky-id`s are used for all columns across multiple tables. Using the same columns `data-sticky-id`s on multiple tables can lead to issues when using the `sticky_right_column` prop.
|