playbook_ui 14.16.0.pre.alpha.PLAY1929bracketlayout6957 → 14.16.0.pre.alpha.PLAY1938completetooltipfloatinguitransition6830
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/_advanced_table.scss +2 -34
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +84 -86
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +0 -10
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination.jsx +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_advanced_table/index.js +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +2 -4
- data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +9 -19
- data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +1 -38
- data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +37 -49
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +0 -39
- data/app/pb_kits/playbook/pb_button/_button.scss +5 -5
- data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +34 -34
- data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +2 -2
- data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +0 -16
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.html.erb +11 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_inline.jsx +7 -0
- data/app/pb_kits/playbook/pb_date_picker/sass_partials/_inline_styles.scss +24 -28
- data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.tsx +4 -3
- data/app/pb_kits/playbook/pb_filter/Filter/SortMenu.tsx +3 -2
- data/app/pb_kits/playbook/pb_form/pb_form_validation.js +1 -1
- data/app/pb_kits/playbook/pb_layout/_layout.scss +0 -58
- data/app/pb_kits/playbook/pb_layout/_layout.tsx +7 -20
- data/app/pb_kits/playbook/pb_layout/docs/example.yml +0 -1
- data/app/pb_kits/playbook/pb_layout/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_layout/layout.test.js +0 -4
- data/app/pb_kits/playbook/pb_lightbox/hooks/useVisibility.js +1 -1
- data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +1 -2
- data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +11 -29
- data/app/pb_kits/playbook/pb_rich_text_editor/docs/_rich_text_editor_default.html.erb +1 -1
- data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.html.erb +4 -4
- data/app/pb_kits/playbook/pb_rich_text_editor/rich_text_editor.rb +0 -2
- data/app/pb_kits/playbook/pb_table/_table.tsx +0 -4
- data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_table/docs/index.js +0 -2
- data/app/pb_kits/playbook/pb_table/styles/_headers.scss +0 -76
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +1 -11
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +1 -11
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +0 -5
- data/app/pb_kits/playbook/pb_table/table.test.js +0 -17
- data/app/pb_kits/playbook/pb_tooltip/index.js +1 -1
- data/app/pb_kits/playbook/pb_typeahead/index.ts +2 -2
- data/app/pb_kits/playbook/utilities/globalProps.ts +1 -1
- data/app/pb_kits/playbook/utilities/object.test.js +1 -149
- data/app/pb_kits/playbook/utilities/object.ts +42 -124
- data/dist/chunks/_typeahead-BEyzuDQy.js +22 -0
- data/dist/chunks/_weekday_stacked-BWYgED9z.js +45 -0
- data/dist/chunks/{lib-BGzBzFZX.js → lib-BgzBJfYr.js} +3 -3
- data/dist/chunks/{pb_form_validation-BvNy9Bd6.js → pb_form_validation-CJD-PyIw.js} +1 -1
- data/dist/chunks/vendor.js +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 +8 -20
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows.html.erb +0 -39
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.html.erb +0 -33
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_rails.md +0 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.md +0 -6
- data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.jsx +0 -190
- data/app/pb_kits/playbook/pb_layout/docs/_layout_bracket.md +0 -5
- data/app/pb_kits/playbook/pb_layout/subcomponents/_game.tsx +0 -90
- data/app/pb_kits/playbook/pb_layout/subcomponents/_round.tsx +0 -57
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless.jsx +0 -50
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless_react.md +0 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating.jsx +0 -59
- data/app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_react.md +0 -1
- data/dist/chunks/_typeahead-Djo6qCne.js +0 -22
- data/dist/chunks/_weekday_stacked-C9nJ2j2C.js +0 -45
- /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_react.md → _advanced_table_selectable_rows.md} +0 -0
- /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_no_subrows_react.md → _advanced_table_selectable_rows_no_subrows.md} +0 -0
data/lib/playbook/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: playbook_ui
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 14.16.0.pre.alpha.
|
4
|
+
version: 14.16.0.pre.alpha.PLAY1938completetooltipfloatinguitransition6830
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Power UX
|
@@ -9,7 +9,7 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date: 2025-03-
|
12
|
+
date: 2025-03-24 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: actionpack
|
@@ -326,18 +326,14 @@ files:
|
|
326
326
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_responsive.html.erb
|
327
327
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_responsive.jsx
|
328
328
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_responsive.md
|
329
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows.html.erb
|
330
329
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows.jsx
|
330
|
+
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows.md
|
331
331
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions.jsx
|
332
332
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions.md
|
333
333
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header.jsx
|
334
334
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header.md
|
335
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.html.erb
|
336
335
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.jsx
|
337
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/
|
338
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_react.md
|
339
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.md
|
340
|
-
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_react.md
|
336
|
+
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.md
|
341
337
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort.jsx
|
342
338
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort.md
|
343
339
|
- app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort_control.jsx
|
@@ -1795,8 +1791,6 @@ files:
|
|
1795
1791
|
- app/pb_kits/playbook/pb_layout/body.html.erb
|
1796
1792
|
- app/pb_kits/playbook/pb_layout/body.rb
|
1797
1793
|
- app/pb_kits/playbook/pb_layout/docs/_description.md
|
1798
|
-
- app/pb_kits/playbook/pb_layout/docs/_layout_bracket.jsx
|
1799
|
-
- app/pb_kits/playbook/pb_layout/docs/_layout_bracket.md
|
1800
1794
|
- app/pb_kits/playbook/pb_layout/docs/_layout_collection.html.erb
|
1801
1795
|
- app/pb_kits/playbook/pb_layout/docs/_layout_collection.jsx
|
1802
1796
|
- app/pb_kits/playbook/pb_layout/docs/_layout_collection.md
|
@@ -1830,8 +1824,6 @@ files:
|
|
1830
1824
|
- app/pb_kits/playbook/pb_layout/layout.test.js
|
1831
1825
|
- app/pb_kits/playbook/pb_layout/sidebar.html.erb
|
1832
1826
|
- app/pb_kits/playbook/pb_layout/sidebar.rb
|
1833
|
-
- app/pb_kits/playbook/pb_layout/subcomponents/_game.tsx
|
1834
|
-
- app/pb_kits/playbook/pb_layout/subcomponents/_round.tsx
|
1835
1827
|
- app/pb_kits/playbook/pb_legend/_legend.scss
|
1836
1828
|
- app/pb_kits/playbook/pb_legend/_legend.tsx
|
1837
1829
|
- app/pb_kits/playbook/pb_legend/docs/_description.md
|
@@ -2864,10 +2856,6 @@ files:
|
|
2864
2856
|
- app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.md
|
2865
2857
|
- app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table_rails.html.erb
|
2866
2858
|
- app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table_rails.md
|
2867
|
-
- app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless.jsx
|
2868
|
-
- app/pb_kits/playbook/pb_table/docs/_table_with_header_style_borderless_react.md
|
2869
|
-
- app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating.jsx
|
2870
|
-
- app/pb_kits/playbook/pb_table/docs/_table_with_header_style_floating_react.md
|
2871
2859
|
- app/pb_kits/playbook/pb_table/docs/_table_with_selectable_rows.html.erb
|
2872
2860
|
- app/pb_kits/playbook/pb_table/docs/_table_with_selectable_rows.jsx
|
2873
2861
|
- app/pb_kits/playbook/pb_table/docs/_table_with_selectable_rows.md
|
@@ -3464,11 +3452,11 @@ files:
|
|
3464
3452
|
- app/pb_kits/playbook/utilities/test/globalProps/truncate.test.js
|
3465
3453
|
- app/pb_kits/playbook/utilities/text.ts
|
3466
3454
|
- app/pb_kits/playbook/utilities/validEmojiChecker.ts
|
3467
|
-
- dist/chunks/_typeahead-
|
3468
|
-
- dist/chunks/_weekday_stacked-
|
3455
|
+
- dist/chunks/_typeahead-BEyzuDQy.js
|
3456
|
+
- dist/chunks/_weekday_stacked-BWYgED9z.js
|
3469
3457
|
- dist/chunks/lazysizes-B7xYodB-.js
|
3470
|
-
- dist/chunks/lib-
|
3471
|
-
- dist/chunks/pb_form_validation-
|
3458
|
+
- dist/chunks/lib-BgzBJfYr.js
|
3459
|
+
- dist/chunks/pb_form_validation-CJD-PyIw.js
|
3472
3460
|
- dist/chunks/vendor.js
|
3473
3461
|
- dist/menu.yml
|
3474
3462
|
- dist/playbook-doc.js
|
@@ -1,39 +0,0 @@
|
|
1
|
-
<% column_definitions = [
|
2
|
-
{
|
3
|
-
accessor: "year",
|
4
|
-
label: "Year",
|
5
|
-
cellAccessors: ["quarter", "month", "day"],
|
6
|
-
},
|
7
|
-
{
|
8
|
-
accessor: "newEnrollments",
|
9
|
-
label: "New Enrollments",
|
10
|
-
},
|
11
|
-
{
|
12
|
-
accessor: "scheduledMeetings",
|
13
|
-
label: "Scheduled Meetings",
|
14
|
-
},
|
15
|
-
{
|
16
|
-
accessor: "attendanceRate",
|
17
|
-
label: "Attendance Rate",
|
18
|
-
},
|
19
|
-
{
|
20
|
-
accessor: "completedClasses",
|
21
|
-
label: "Completed Classes",
|
22
|
-
},
|
23
|
-
{
|
24
|
-
accessor: "classCompletionRate",
|
25
|
-
label: "Class Completion Rate",
|
26
|
-
},
|
27
|
-
{
|
28
|
-
accessor: "graduatedStudents",
|
29
|
-
label: "Graduated Students",
|
30
|
-
}
|
31
|
-
]
|
32
|
-
|
33
|
-
subrow_headers = ["Quarter", "Month", "Day"]
|
34
|
-
%>
|
35
|
-
|
36
|
-
<%= pb_rails("advanced_table", props: { id: "selectable_rows", table_data: @table_data_with_id, column_definitions: column_definitions, selectable_rows: true }) do %>
|
37
|
-
<%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions, selectable_rows: true }) %>
|
38
|
-
<%= pb_rails("advanced_table/table_body", props: { id: "selectable_rows", table_data: @table_data_with_id, column_definitions: column_definitions, subrow_headers: subrow_headers, enable_toggle_expansion: "all", selectable_rows: true }) %>
|
39
|
-
<% end %>
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows.html.erb
DELETED
@@ -1,33 +0,0 @@
|
|
1
|
-
<% column_definitions = [
|
2
|
-
{
|
3
|
-
accessor: "year",
|
4
|
-
label: "Year",
|
5
|
-
cellAccessors: ["quarter", "month", "day"],
|
6
|
-
},
|
7
|
-
{
|
8
|
-
accessor: "newEnrollments",
|
9
|
-
label: "New Enrollments",
|
10
|
-
},
|
11
|
-
{
|
12
|
-
accessor: "scheduledMeetings",
|
13
|
-
label: "Scheduled Meetings",
|
14
|
-
},
|
15
|
-
{
|
16
|
-
accessor: "attendanceRate",
|
17
|
-
label: "Attendance Rate",
|
18
|
-
},
|
19
|
-
{
|
20
|
-
accessor: "completedClasses",
|
21
|
-
label: "Completed Classes",
|
22
|
-
},
|
23
|
-
{
|
24
|
-
accessor: "classCompletionRate",
|
25
|
-
label: "Class Completion Rate",
|
26
|
-
},
|
27
|
-
{
|
28
|
-
accessor: "graduatedStudents",
|
29
|
-
label: "Graduated Students",
|
30
|
-
}
|
31
|
-
] %>
|
32
|
-
|
33
|
-
<%= pb_rails("advanced_table", props: { id: "selectable_rows_no_subrows", table_data: @table_data_no_subrows, column_definitions: column_definitions, selectable_rows: true, enable_toggle_expansion: "none", }) %>
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_rails.md
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
`selectable_rows` can also be used with tables without nested row data. Set `enable_toggle_expansion: none` to adjust the Advanced Table styling to fit a table without subrows.
|
@@ -1,6 +0,0 @@
|
|
1
|
-
`selectable_rows` is a boolean prop that if present will add checkboxes to all rows that will allow for selecting rows.
|
2
|
-
|
3
|
-
When a parent row is clicked, it will check all nested children rows, Children rows can be manually checked or unchecked as well.
|
4
|
-
|
5
|
-
__ALERT TO DEVS__: UPDATE THIS PARAGRAPH IN THE FOLLOW UP STORY WHEN CHECKBOX FUNCTIONALITY IS SET PLEASE
|
6
|
-
The `onRowSelectionChange` prop returns an array of ids of all Rows that have been selected. Open the console on this example and check and uncheck checkboxes to see this is action! __NOTE__: Each object within the `tableData`Array must contain a unique id in order to attach an id to all Rows for this to function.
|
@@ -1,190 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
|
3
|
-
import Layout from '../../pb_layout/_layout'
|
4
|
-
import Flex from '../../pb_flex/_flex'
|
5
|
-
import Body from '../../pb_body/_body'
|
6
|
-
import Caption from '../../pb_caption/_caption'
|
7
|
-
import SectionSeparator from '../../pb_section_separator/_section_separator'
|
8
|
-
|
9
|
-
const LayoutBracket = () => {
|
10
|
-
return (
|
11
|
-
<div>
|
12
|
-
<Layout
|
13
|
-
layout="bracket"
|
14
|
-
>
|
15
|
-
<Layout.RoundLabel>
|
16
|
-
<Caption>Wild Card</Caption>
|
17
|
-
<SectionSeparator marginY="sm"/>
|
18
|
-
</Layout.RoundLabel>
|
19
|
-
<Layout.Round marginBottom={{ xs: "md", sm: "md" }}>
|
20
|
-
<Layout.Game>
|
21
|
-
<Flex justify="between">
|
22
|
-
<Body>Packers</Body>
|
23
|
-
<Body>10</Body>
|
24
|
-
</Flex>
|
25
|
-
<Flex justify="between">
|
26
|
-
<Body><strong>Eagles</strong></Body>
|
27
|
-
<Body>22</Body>
|
28
|
-
</Flex>
|
29
|
-
</Layout.Game>
|
30
|
-
<Layout.Game>
|
31
|
-
<Flex justify="between">
|
32
|
-
<Body>Vikings</Body>
|
33
|
-
<Body>9</Body>
|
34
|
-
</Flex>
|
35
|
-
<Flex justify="between">
|
36
|
-
<Body><strong>Rams</strong></Body>
|
37
|
-
<Body>27</Body>
|
38
|
-
</Flex>
|
39
|
-
</Layout.Game>
|
40
|
-
<Layout.Game>
|
41
|
-
<Flex justify="between">
|
42
|
-
<Body><strong>Lions</strong></Body>
|
43
|
-
</Flex>
|
44
|
-
<Flex justify="between">
|
45
|
-
<Body>BYE</Body>
|
46
|
-
</Flex>
|
47
|
-
</Layout.Game>
|
48
|
-
<Layout.Game>
|
49
|
-
<Flex justify="between">
|
50
|
-
<Body><strong>Commanders</strong></Body>
|
51
|
-
<Body>23</Body>
|
52
|
-
</Flex>
|
53
|
-
<Flex justify="between">
|
54
|
-
<Body>Buccaneers</Body>
|
55
|
-
<Body>20</Body>
|
56
|
-
</Flex>
|
57
|
-
</Layout.Game>
|
58
|
-
<Layout.Game>
|
59
|
-
<Flex justify="between">
|
60
|
-
<Body><strong>Chiefs</strong></Body>
|
61
|
-
</Flex>
|
62
|
-
<Flex justify="between">
|
63
|
-
<Body>BYE</Body>
|
64
|
-
</Flex>
|
65
|
-
</Layout.Game>
|
66
|
-
<Layout.Game>
|
67
|
-
<Flex justify="between">
|
68
|
-
<Body>Chargers</Body>
|
69
|
-
<Body>12</Body>
|
70
|
-
</Flex>
|
71
|
-
<Flex justify="between">
|
72
|
-
<Body><strong>Texans</strong></Body>
|
73
|
-
<Body>32</Body>
|
74
|
-
</Flex>
|
75
|
-
</Layout.Game>
|
76
|
-
<Layout.Game>
|
77
|
-
<Flex justify="between">
|
78
|
-
<Body>Broncos</Body>
|
79
|
-
<Body>7</Body>
|
80
|
-
</Flex>
|
81
|
-
<Flex justify="between">
|
82
|
-
<Body><strong>Bills</strong></Body>
|
83
|
-
<Body>31</Body>
|
84
|
-
</Flex>
|
85
|
-
</Layout.Game>
|
86
|
-
<Layout.Game>
|
87
|
-
<Flex justify="between">
|
88
|
-
<Body>Steelers</Body>
|
89
|
-
<Body>14</Body>
|
90
|
-
</Flex>
|
91
|
-
<Flex justify="between">
|
92
|
-
<Body><strong>Ravens</strong></Body>
|
93
|
-
<Body>28</Body>
|
94
|
-
</Flex>
|
95
|
-
</Layout.Game>
|
96
|
-
</Layout.Round>
|
97
|
-
<Layout.RoundLabel>
|
98
|
-
<Caption>Divisional</Caption>
|
99
|
-
<SectionSeparator marginY="sm"/>
|
100
|
-
</Layout.RoundLabel>
|
101
|
-
<Layout.Round marginBottom={{ xs: "md", sm: "md" }}>
|
102
|
-
<Layout.Game>
|
103
|
-
<Flex justify="between">
|
104
|
-
<Body>Rams</Body>
|
105
|
-
<Body>22</Body>
|
106
|
-
</Flex>
|
107
|
-
<Flex justify="between">
|
108
|
-
<Body><strong>Eagles</strong></Body>
|
109
|
-
<Body>28</Body>
|
110
|
-
</Flex>
|
111
|
-
</Layout.Game>
|
112
|
-
<Layout.Game>
|
113
|
-
<Flex justify="between">
|
114
|
-
<Body><strong>Commanders</strong></Body>
|
115
|
-
<Body>45</Body>
|
116
|
-
</Flex>
|
117
|
-
<Flex justify="between">
|
118
|
-
<Body>Lions</Body>
|
119
|
-
<Body>31</Body>
|
120
|
-
</Flex>
|
121
|
-
</Layout.Game>
|
122
|
-
<Layout.Game>
|
123
|
-
<Flex justify="between">
|
124
|
-
<Body>Texans</Body>
|
125
|
-
<Body>14</Body>
|
126
|
-
</Flex>
|
127
|
-
<Flex justify="between">
|
128
|
-
<Body><strong>Chiefs</strong></Body>
|
129
|
-
<Body>23</Body>
|
130
|
-
</Flex>
|
131
|
-
</Layout.Game>
|
132
|
-
<Layout.Game>
|
133
|
-
<Flex justify="between">
|
134
|
-
<Body>Ravens</Body>
|
135
|
-
<Body>25</Body>
|
136
|
-
</Flex>
|
137
|
-
<Flex justify="between">
|
138
|
-
<Body><strong>Bills</strong></Body>
|
139
|
-
<Body>27</Body>
|
140
|
-
</Flex>
|
141
|
-
</Layout.Game>
|
142
|
-
</Layout.Round>
|
143
|
-
<Layout.RoundLabel>
|
144
|
-
<Caption>Conference</Caption>
|
145
|
-
<SectionSeparator marginY="sm"/>
|
146
|
-
</Layout.RoundLabel>
|
147
|
-
<Layout.Round marginBottom={{ xs: "md", sm: "md" }}>
|
148
|
-
<Layout.Game>
|
149
|
-
<Flex justify="between">
|
150
|
-
<Body>Commanders</Body>
|
151
|
-
<Body>23</Body>
|
152
|
-
</Flex>
|
153
|
-
<Flex justify="between">
|
154
|
-
<Body><strong>Eagles</strong></Body>
|
155
|
-
<Body>55</Body>
|
156
|
-
</Flex>
|
157
|
-
</Layout.Game>
|
158
|
-
<Layout.Game>
|
159
|
-
<Flex justify="between">
|
160
|
-
<Body>Bills</Body>
|
161
|
-
<Body>29</Body>
|
162
|
-
</Flex>
|
163
|
-
<Flex justify="between">
|
164
|
-
<Body><strong>Chiefs</strong></Body>
|
165
|
-
<Body>32</Body>
|
166
|
-
</Flex>
|
167
|
-
</Layout.Game>
|
168
|
-
</Layout.Round>
|
169
|
-
<Layout.RoundLabel>
|
170
|
-
<Caption>Super Bowl</Caption>
|
171
|
-
<SectionSeparator marginY="sm"/>
|
172
|
-
</Layout.RoundLabel>
|
173
|
-
<Layout.Round>
|
174
|
-
<Layout.Game>
|
175
|
-
<Flex justify="between">
|
176
|
-
<Body>Chiefs</Body>
|
177
|
-
<Body>22</Body>
|
178
|
-
</Flex>
|
179
|
-
<Flex justify="between">
|
180
|
-
<Body><strong>Eagles</strong></Body>
|
181
|
-
<Body>40</Body>
|
182
|
-
</Flex>
|
183
|
-
</Layout.Game>
|
184
|
-
</Layout.Round>
|
185
|
-
</Layout>
|
186
|
-
</div>
|
187
|
-
)
|
188
|
-
}
|
189
|
-
|
190
|
-
export default LayoutBracket
|
@@ -1,5 +0,0 @@
|
|
1
|
-
Use `<Layout.RoundLabel>`, `<Layout.Round>`, and `<Layout.Game>` to make a bracket layout.
|
2
|
-
|
3
|
-
On mobile devices, `<Layout.RoundLabel>` will display (on desktop these components are hidden) and the bracket will be in one column.
|
4
|
-
|
5
|
-
Ensure that each `<Layout.Game>` maintains a consistent height for the bracket lines to lay out properly.
|
@@ -1,90 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import classnames from 'classnames'
|
3
|
-
|
4
|
-
import { GlobalProps, globalProps, globalInlineProps } from '../../utilities/globalProps'
|
5
|
-
|
6
|
-
import Card from '../../pb_card/_card'
|
7
|
-
import SectionSeparator from '../../pb_section_separator/_section_separator'
|
8
|
-
|
9
|
-
type LayoutGameProps = {
|
10
|
-
children: React.ReactNode[] | React.ReactNode,
|
11
|
-
className?: string,
|
12
|
-
numberOfRounds: number,
|
13
|
-
numberOfGames: number,
|
14
|
-
isOdd: boolean,
|
15
|
-
} & GlobalProps
|
16
|
-
|
17
|
-
// Game component (modeled after Item)
|
18
|
-
const Game = (props: LayoutGameProps) => {
|
19
|
-
const { children, className, numberOfRounds, numberOfGames, isOdd } = props
|
20
|
-
const dynamicInlineProps = globalInlineProps(props)
|
21
|
-
|
22
|
-
const numberOfChildren = Array.isArray(children) ? children.length : 0
|
23
|
-
|
24
|
-
const isMultiple = Array.isArray(children)
|
25
|
-
|
26
|
-
let ratio = 0
|
27
|
-
let exponent
|
28
|
-
if (numberOfGames > 1) {
|
29
|
-
exponent = (numberOfRounds) - Math.log2(numberOfGames) - 1
|
30
|
-
ratio = 2 ** exponent
|
31
|
-
}
|
32
|
-
|
33
|
-
if (numberOfChildren === 2) {
|
34
|
-
const [firstChild, secondChild] = React.Children.toArray(children)
|
35
|
-
|
36
|
-
if (React.isValidElement(firstChild) && React.isValidElement(secondChild)) {
|
37
|
-
return (
|
38
|
-
<div
|
39
|
-
className={classnames('layout_game', globalProps(props), className)}
|
40
|
-
style={dynamicInlineProps}
|
41
|
-
>
|
42
|
-
<Card
|
43
|
-
marginY="xs"
|
44
|
-
padding="none"
|
45
|
-
shadow="deep"
|
46
|
-
>
|
47
|
-
<Card.Body padding="xs">{firstChild}</Card.Body>
|
48
|
-
<SectionSeparator />
|
49
|
-
<Card.Body padding="xs">{secondChild}</Card.Body>
|
50
|
-
</Card>
|
51
|
-
{isOdd && numberOfGames > 1 &&
|
52
|
-
<div
|
53
|
-
className="half_box"
|
54
|
-
style={{ height: `calc(${ratio} * 100% + 4px)` }}
|
55
|
-
/>
|
56
|
-
}
|
57
|
-
</div>
|
58
|
-
)
|
59
|
-
}
|
60
|
-
}
|
61
|
-
|
62
|
-
return (
|
63
|
-
<div
|
64
|
-
className={classnames('layout_game', globalProps(props), className)}
|
65
|
-
style={dynamicInlineProps}
|
66
|
-
>
|
67
|
-
{((!isMultiple && children) || numberOfChildren >= 1 )? (
|
68
|
-
children
|
69
|
-
) : (
|
70
|
-
<Card
|
71
|
-
marginY="xs"
|
72
|
-
padding="none"
|
73
|
-
shadow="deep"
|
74
|
-
>
|
75
|
-
<Card.Body padding="xs">To be determined...</Card.Body>
|
76
|
-
<SectionSeparator />
|
77
|
-
<Card.Body padding="xs">To be determined...</Card.Body>
|
78
|
-
</Card>
|
79
|
-
)}
|
80
|
-
{isOdd && numberOfGames > 1 &&
|
81
|
-
<div
|
82
|
-
className="half_box"
|
83
|
-
style={{ height: `calc(${ratio} * 100% + 4px)` }}
|
84
|
-
/>
|
85
|
-
}
|
86
|
-
</div>
|
87
|
-
)
|
88
|
-
}
|
89
|
-
|
90
|
-
export default Game
|
@@ -1,57 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
import classnames from 'classnames'
|
3
|
-
|
4
|
-
import { GlobalProps, globalProps, globalInlineProps } from '../../utilities/globalProps'
|
5
|
-
|
6
|
-
type LayoutRoundLabelProps = {
|
7
|
-
children: React.ReactNode[] | React.ReactNode,
|
8
|
-
className?: string,
|
9
|
-
} & GlobalProps
|
10
|
-
|
11
|
-
export const RoundLabel = (props: LayoutRoundLabelProps) => {
|
12
|
-
const { children, className } = props
|
13
|
-
const dynamicInlineProps = globalInlineProps(props)
|
14
|
-
return (
|
15
|
-
<div
|
16
|
-
className={classnames('layout_round_label', className)}
|
17
|
-
style={dynamicInlineProps}
|
18
|
-
>
|
19
|
-
{children}
|
20
|
-
</div>
|
21
|
-
)
|
22
|
-
}
|
23
|
-
|
24
|
-
type LayoutRoundProps = {
|
25
|
-
children: React.ReactNode[] | React.ReactNode,
|
26
|
-
className?: string,
|
27
|
-
numberOfRounds: number,
|
28
|
-
} & GlobalProps
|
29
|
-
|
30
|
-
export const Round = (props: LayoutRoundProps) => {
|
31
|
-
const { children, className, numberOfRounds } = props
|
32
|
-
const dynamicInlineProps = globalInlineProps(props)
|
33
|
-
const numberOfChildren = Array.isArray(children) ? children.length : 0
|
34
|
-
|
35
|
-
const childrenWithProps = Array.isArray(children) ? children.map((child, index) =>
|
36
|
-
React.isValidElement(child) ? React.cloneElement(child, { numberOfRounds, numberOfGames: numberOfChildren, isOdd: index % 2 === 0, key: `child_${index}` }) : child
|
37
|
-
) : children
|
38
|
-
|
39
|
-
const rightConnectors = Array.from({ length: numberOfChildren / 2 }, (_, index) => (
|
40
|
-
<div
|
41
|
-
className="right_connector"
|
42
|
-
key={`right_connector_${index}`}
|
43
|
-
/>
|
44
|
-
))
|
45
|
-
|
46
|
-
return (
|
47
|
-
<>
|
48
|
-
<div
|
49
|
-
className={classnames('layout_round', globalProps(props), className)}
|
50
|
-
style={dynamicInlineProps}
|
51
|
-
>
|
52
|
-
{childrenWithProps}
|
53
|
-
</div>
|
54
|
-
<div className="connector_container">{rightConnectors}</div>
|
55
|
-
</>
|
56
|
-
)
|
57
|
-
}
|
@@ -1,50 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
|
3
|
-
import Table from '../../pb_table/_table'
|
4
|
-
|
5
|
-
const TableWithHeaderStyleBorderless = (props) => {
|
6
|
-
return (
|
7
|
-
<>
|
8
|
-
<Table
|
9
|
-
headerStyle="borderless"
|
10
|
-
size="sm"
|
11
|
-
{...props}
|
12
|
-
>
|
13
|
-
<thead>
|
14
|
-
<tr>
|
15
|
-
<th>{'Column 1'}</th>
|
16
|
-
<th>{'Column 2'}</th>
|
17
|
-
<th>{'Column 3'}</th>
|
18
|
-
<th>{'Column 4'}</th>
|
19
|
-
<th>{'Column 5'}</th>
|
20
|
-
</tr>
|
21
|
-
</thead>
|
22
|
-
<tbody>
|
23
|
-
<tr>
|
24
|
-
<td>{'Value 1'}</td>
|
25
|
-
<td>{'Value 2'}</td>
|
26
|
-
<td>{'Value 3'}</td>
|
27
|
-
<td>{'Value 4'}</td>
|
28
|
-
<td>{'Value 5'}</td>
|
29
|
-
</tr>
|
30
|
-
<tr>
|
31
|
-
<td>{'Value 1'}</td>
|
32
|
-
<td>{'Value 2'}</td>
|
33
|
-
<td>{'Value 3'}</td>
|
34
|
-
<td>{'Value 4'}</td>
|
35
|
-
<td>{'Value 5'}</td>
|
36
|
-
</tr>
|
37
|
-
<tr>
|
38
|
-
<td>{'Value 1'}</td>
|
39
|
-
<td>{'Value 2'}</td>
|
40
|
-
<td>{'Value 3'}</td>
|
41
|
-
<td>{'Value 4'}</td>
|
42
|
-
<td>{'Value 5'}</td>
|
43
|
-
</tr>
|
44
|
-
</tbody>
|
45
|
-
</Table>
|
46
|
-
</>
|
47
|
-
)
|
48
|
-
}
|
49
|
-
|
50
|
-
export default TableWithHeaderStyleBorderless
|
@@ -1 +0,0 @@
|
|
1
|
-
Customize your header by removing the header borders with the `headerStyle="borderless"` prop.
|
@@ -1,59 +0,0 @@
|
|
1
|
-
import React from 'react'
|
2
|
-
|
3
|
-
import Background from '../../pb_background/_background'
|
4
|
-
import Card from '../../pb_card/_card'
|
5
|
-
import Table from '../../pb_table/_table'
|
6
|
-
|
7
|
-
const TableWithHeaderStyleFloating = (props) => {
|
8
|
-
return (
|
9
|
-
<>
|
10
|
-
<Card background="light"
|
11
|
-
{...props}
|
12
|
-
>
|
13
|
-
<Table
|
14
|
-
headerStyle="floating"
|
15
|
-
size="sm"
|
16
|
-
{...props}
|
17
|
-
>
|
18
|
-
<Table.Head>
|
19
|
-
<Background backgroundColor="light"
|
20
|
-
tag="tr"
|
21
|
-
{...props}
|
22
|
-
>
|
23
|
-
<Table.Header>{'Column 1'}</Table.Header>
|
24
|
-
<Table.Header>{'Column 2'}</Table.Header>
|
25
|
-
<Table.Header>{'Column 3'}</Table.Header>
|
26
|
-
<Table.Header>{'Column 4'}</Table.Header>
|
27
|
-
<Table.Header>{'Column 5'}</Table.Header>
|
28
|
-
</Background>
|
29
|
-
</Table.Head>
|
30
|
-
<Table.Body>
|
31
|
-
<Table.Row>
|
32
|
-
<Table.Cell>{'Value 1'}</Table.Cell>
|
33
|
-
<Table.Cell>{'Value 2'}</Table.Cell>
|
34
|
-
<Table.Cell>{'Value 3'}</Table.Cell>
|
35
|
-
<Table.Cell>{'Value 4'}</Table.Cell>
|
36
|
-
<Table.Cell>{'Value 5'}</Table.Cell>
|
37
|
-
</Table.Row>
|
38
|
-
<Table.Row>
|
39
|
-
<Table.Cell>{'Value 1'}</Table.Cell>
|
40
|
-
<Table.Cell>{'Value 2'}</Table.Cell>
|
41
|
-
<Table.Cell>{'Value 3'}</Table.Cell>
|
42
|
-
<Table.Cell>{'Value 4'}</Table.Cell>
|
43
|
-
<Table.Cell>{'Value 5'}</Table.Cell>
|
44
|
-
</Table.Row>
|
45
|
-
<Table.Row>
|
46
|
-
<Table.Cell>{'Value 1'}</Table.Cell>
|
47
|
-
<Table.Cell>{'Value 2'}</Table.Cell>
|
48
|
-
<Table.Cell>{'Value 3'}</Table.Cell>
|
49
|
-
<Table.Cell>{'Value 4'}</Table.Cell>
|
50
|
-
<Table.Cell>{'Value 5'}</Table.Cell>
|
51
|
-
</Table.Row>
|
52
|
-
</Table.Body>
|
53
|
-
</Table>
|
54
|
-
</Card>
|
55
|
-
</>
|
56
|
-
)
|
57
|
-
}
|
58
|
-
|
59
|
-
export default TableWithHeaderStyleFloating
|
@@ -1 +0,0 @@
|
|
1
|
-
Further customize your header by using the [table with background kit](https://playbook.powerapp.cloud/kits/table/react#table-with-background-kit) logic to give your table header a custom background color. Use the `headerStyle="floating"` prop to visually nest the borderless table within a card or collapsible with a matching background color (the `backgroundColor` passed to Background kit should match the `backgroundColor` for the element in which it is nested).
|