playbook_ui 15.4.0.pre.rc.1 → 15.4.0.pre.rc.3
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/RegularTableView.tsx +2 -1
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +63 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.html.erb +4 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.jsx +3 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.md +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.jsx +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.md +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.jsx +9 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_react.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header.jsx +16 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.html.erb +104 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_rails.html.erb +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +90 -20
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +31 -2
- data/app/pb_kits/playbook/pb_background/background.html.erb +10 -2
- data/app/pb_kits/playbook/pb_background/docs/_background_category.md +1 -1
- data/app/pb_kits/playbook/pb_badge/_badge.tsx +4 -1
- data/app/pb_kits/playbook/pb_badge/badge.test.js +13 -0
- data/app/pb_kits/playbook/pb_card/docs/_card_background.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_highlight.md +1 -1
- data/app/pb_kits/playbook/pb_card/docs/_card_light.md +1 -1
- data/app/pb_kits/playbook/pb_currency/_currency.tsx +20 -7
- data/app/pb_kits/playbook/pb_currency/currency.rb +35 -8
- data/app/pb_kits/playbook/pb_currency/currency.test.js +47 -0
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.html.erb +1 -1
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.jsx +1 -1
- data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.md +1 -0
- data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +16 -4
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.jsx +38 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.md +14 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_date_picker/docs/index.js +2 -1
- data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +1 -0
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +111 -6
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.jsx +18 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.md +4 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.jsx +18 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.jsx +19 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.jsx +38 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.md +14 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_active_style_options_react.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +5 -1
- data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +148 -2
- data/app/pb_kits/playbook/pb_dropdown/quickpick/index.ts +60 -0
- data/app/pb_kits/playbook/pb_filter/docs/_filter_max_width.md +1 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_auto_close.html.erb +15 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line.html.erb +9 -8
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_positions.html.erb +11 -10
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.tsx +1 -1
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_rails.md +1 -1
- data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_react.md +1 -1
- data/app/pb_kits/playbook/pb_icon/docs/_icon_color.md +1 -1
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color.md +1 -1
- data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.html.erb +7 -14
- data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.jsx +6 -15
- data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.md +1 -1
- data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_item_spacing.md +1 -1
- data/app/pb_kits/playbook/pb_nav/docs/_nav_with_spacing_control.md +1 -1
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_layout.md +1 -1
- data/app/pb_kits/playbook/pb_pill/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_rich_text_editor/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_section_separator/docs/_description.md +1 -1
- data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +29 -0
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_rails.md +1 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_react.md +1 -1
- data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_layout.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_sm.md +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.html.erb +63 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.jsx +89 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_rails.md +4 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_react.md +3 -0
- data/app/pb_kits/playbook/pb_table/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_table/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +7 -0
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.test.jsx +64 -1
- data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +33 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_truncated_text.md +1 -1
- data/dist/chunks/{_line_graph-CqE0-dq5.js → _line_graph-BRirnhGy.js} +1 -1
- data/dist/chunks/_typeahead-CFOqvZNu.js +6 -0
- data/dist/chunks/_weekday_stacked-B_wdjzzt.js +37 -0
- data/dist/chunks/{lib-CGxXTQ75.js → lib-BXBHAZMY.js} +1 -1
- data/dist/chunks/{pb_form_validation-DebqlUKZ.js → pb_form_validation-BZppqQZM.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +2 -2
- 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 +25 -7
- data/dist/chunks/_typeahead-3ZAbZUqU.js +0 -6
- data/dist/chunks/_weekday_stacked-BFB3mjtE.js +0 -37
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 7a975771e592077ab2a8652b98d0c50e77edd015d6e5c964d2c3e7fe0d890e09
|
|
4
|
+
data.tar.gz: 4c8a3c69a78fa1d417f713593e5faa75e9010845cccd8f5be2dad9a5af238743
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: a36fe08a2d86ba2bb19c793924278976be3cad2c41ef906d1cac3e5a141be6ed88aadae46cbc15e1a3f47da0d98ccd3cb2b7a7deba78d262a3bbe9568884e6b5
|
|
7
|
+
data.tar.gz: 9b75de07f0692daa2d4a8e72187c3b13f877442be7237853589fda95ad1b27c27f978bed809e40c83947c3e2d224cf9dac6edefc44cf7c83d0610d21d4fe14b3
|
|
@@ -66,6 +66,7 @@ const TableCellRenderer = ({
|
|
|
66
66
|
// Find the “owning” colDefinition by accessor. Needed for multi column logic
|
|
67
67
|
const colDef = findColumnDefByAccessor(columnDefinitions ?? [], column.id)
|
|
68
68
|
const cellAlignment = colDef?.columnStyling?.cellAlignment ?? "right"
|
|
69
|
+
const cellFontColor = colDef?.columnStyling?.fontColor
|
|
69
70
|
const paddingValue = colDef?.columnStyling?.cellPadding ?? customRowStyle?.cellPadding
|
|
70
71
|
const paddingClass = paddingValue ? `p_${paddingValue}` : undefined
|
|
71
72
|
|
|
@@ -88,7 +89,7 @@ const TableCellRenderer = ({
|
|
|
88
89
|
: `${column.getStart("left")}px`
|
|
89
90
|
: undefined,
|
|
90
91
|
backgroundColor: i === 0 && customRowStyle?.backgroundColor,
|
|
91
|
-
color: customRowStyle?.fontColor,
|
|
92
|
+
color: cellFontColor || customRowStyle?.fontColor,
|
|
92
93
|
}}
|
|
93
94
|
>
|
|
94
95
|
{collapsibleTrail && i === 0 && row.depth > 0 && renderCollapsibleTrail(row.depth)}
|
|
@@ -740,6 +740,69 @@ test("columnStyling.cellPadding sets cell padding", () => {
|
|
|
740
740
|
expect(firstEnrollmentCell).toHaveClass('p_none')
|
|
741
741
|
});
|
|
742
742
|
|
|
743
|
+
test("columnStyling.fontColor sets cell font color", () => {
|
|
744
|
+
const styledColumnDefs = [
|
|
745
|
+
{
|
|
746
|
+
accessor: "year",
|
|
747
|
+
label: "Year",
|
|
748
|
+
cellAccessors: ["quarter", "month", "day"],
|
|
749
|
+
},
|
|
750
|
+
{
|
|
751
|
+
accessor: "newEnrollments",
|
|
752
|
+
label: "New Enrollments",
|
|
753
|
+
columnStyling: { fontColor: colors.category_1 },
|
|
754
|
+
},
|
|
755
|
+
{
|
|
756
|
+
accessor: "scheduledMeetings",
|
|
757
|
+
label: "Scheduled Meetings",
|
|
758
|
+
},
|
|
759
|
+
];
|
|
760
|
+
|
|
761
|
+
render(
|
|
762
|
+
<AdvancedTable
|
|
763
|
+
columnDefinitions={styledColumnDefs}
|
|
764
|
+
data={{ testid: testId }}
|
|
765
|
+
tableData={MOCK_DATA}
|
|
766
|
+
/>
|
|
767
|
+
);
|
|
768
|
+
|
|
769
|
+
const firstEnrollmentCell = screen.getAllByText("20")[0].closest("td");
|
|
770
|
+
expect(firstEnrollmentCell).toHaveStyle({ color: colors.category_1 });
|
|
771
|
+
});
|
|
772
|
+
|
|
773
|
+
test("columnStyling.fontColor works with background color", () => {
|
|
774
|
+
const styledColumnDefs = [
|
|
775
|
+
{
|
|
776
|
+
accessor: "year",
|
|
777
|
+
label: "Year",
|
|
778
|
+
cellAccessors: ["quarter", "month", "day"],
|
|
779
|
+
},
|
|
780
|
+
{
|
|
781
|
+
accessor: "newEnrollments",
|
|
782
|
+
label: "New Enrollments",
|
|
783
|
+
columnStyling: {
|
|
784
|
+
cellBackgroundColor: (row) => row.newEnrollments > 20 ? "success_secondary" : "warning_secondary",
|
|
785
|
+
fontColor: colors.white
|
|
786
|
+
},
|
|
787
|
+
},
|
|
788
|
+
{
|
|
789
|
+
accessor: "scheduledMeetings",
|
|
790
|
+
label: "Scheduled Meetings",
|
|
791
|
+
},
|
|
792
|
+
];
|
|
793
|
+
|
|
794
|
+
render(
|
|
795
|
+
<AdvancedTable
|
|
796
|
+
columnDefinitions={styledColumnDefs}
|
|
797
|
+
data={{ testid: testId }}
|
|
798
|
+
tableData={MOCK_DATA}
|
|
799
|
+
/>
|
|
800
|
+
);
|
|
801
|
+
|
|
802
|
+
const firstEnrollmentCell = screen.getAllByText("20")[0].closest("td");
|
|
803
|
+
expect(firstEnrollmentCell).toHaveStyle({ color: colors.white });
|
|
804
|
+
});
|
|
805
|
+
|
|
743
806
|
test("renders virtualized table rows and header", () => {
|
|
744
807
|
render(
|
|
745
808
|
<AdvancedTable
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.md
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
`column_styling` can also be used to control the background color on all cells in a given column via the use of the `cell_background_color` key/value pair. Use `cell_background_color` to achieve custom background colors for individual cells as seen here.
|
|
1
|
+
`column_styling` can also be used to control the background color on all cells in a given column via the use of the `cell_background_color` key/value pair. Use `cell_background_color` to achieve custom background colors for individual cells as seen here. Use `font_color` to achieve better contrast between cell content and background for darker backgrounds.
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
The borders of column groups can be set to a different color using the `columnGroupBorderColor` prop. In order for these borders to be visible, this prop must be used with `tableProps` and `verticalBorder` set to true.
|
|
2
2
|
|
|
3
|
-
The available colors for the border are Playbook's Text Colors, which can be found [here](https://playbook.powerapp.cloud/
|
|
3
|
+
The available colors for the border are Playbook's Text Colors, which can be found [here](https://playbook.powerapp.cloud/tokens/colors).
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.md
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
The borders of column groups can be set to a different color using the `column_group_border_color` prop. In order for these borders to be visible, this prop must be used with `table_props` and `vertical_border` set to true.
|
|
2
2
|
|
|
3
|
-
The available colors for the border are Playbook's Text Colors, which can be found [here](https://playbook.powerapp.cloud/
|
|
3
|
+
The available colors for the border are Playbook's Text Colors, which can be found [here](https://playbook.powerapp.cloud/tokens/colors).
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import React from "react"
|
|
2
|
-
import AdvancedTable from
|
|
2
|
+
import { AdvancedTable, colors } from "playbook-ui"
|
|
3
3
|
import MOCK_DATA from "./advanced_table_mock_data.json"
|
|
4
4
|
|
|
5
|
+
|
|
5
6
|
const AdvancedTableColumnStyling = (props) => {
|
|
6
7
|
const columnDefinitions = [
|
|
7
8
|
{
|
|
@@ -34,6 +35,7 @@ const AdvancedTableColumnStyling = (props) => {
|
|
|
34
35
|
{
|
|
35
36
|
accessor: "graduatedStudents",
|
|
36
37
|
label: "Graduated Students",
|
|
38
|
+
columnStyling:{fontColor: colors.data_8},
|
|
37
39
|
},
|
|
38
40
|
]
|
|
39
41
|
|
|
@@ -4,4 +4,6 @@ The `columnStyling` prop is an optional item that can be used within `columnDefi
|
|
|
4
4
|
|
|
5
5
|
2) `cellAlignment`: This will allow you to control alignment of content within all cells in the given column. This is set to right aligned by default. you can set this to `left`, `right` or `center`.
|
|
6
6
|
|
|
7
|
+
3) `fontColor`: This will allow you to control the font color for a given column.
|
|
8
|
+
|
|
7
9
|
`columnStyling` can be used within the columnDefinition of all the columns or some of them, as shown. Each column has its own individual control in this way.
|
|
@@ -4,4 +4,6 @@ The `column_styling` prop is an optional item that can be used within `column_de
|
|
|
4
4
|
|
|
5
5
|
2) `cell_alignment`: This will allow you to control alignment of content within all cells in the given column. This is set to right aligned by default. you can set this to `left`, `right` or `center`.
|
|
6
6
|
|
|
7
|
+
3) `font_color`: This will allow you to control the font color for a given column.
|
|
8
|
+
|
|
7
9
|
`column_styling` can be used within the column_definition of all the columns or some of them, as shown. Each column has its own individual control in this way.
|
|
@@ -22,7 +22,6 @@ const AdvancedTablePaddingControl = (props) => {
|
|
|
22
22
|
{value}
|
|
23
23
|
</Background>
|
|
24
24
|
),
|
|
25
|
-
|
|
26
25
|
},
|
|
27
26
|
{
|
|
28
27
|
accessor: "scheduledMeetings",
|
|
@@ -39,6 +38,15 @@ const AdvancedTablePaddingControl = (props) => {
|
|
|
39
38
|
{
|
|
40
39
|
accessor: "classCompletionRate",
|
|
41
40
|
label: "Class Completion Rate",
|
|
41
|
+
columnStyling:{cellPadding: "none", fontColor: "white"},
|
|
42
|
+
customRenderer: (row, value) => (
|
|
43
|
+
<Background
|
|
44
|
+
backgroundColor={"category_1"}
|
|
45
|
+
padding="xs"
|
|
46
|
+
>
|
|
47
|
+
{value}
|
|
48
|
+
</Background>
|
|
49
|
+
),
|
|
42
50
|
},
|
|
43
51
|
{
|
|
44
52
|
accessor: "graduatedStudents",
|
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
`columnStyling` can also be used to control padding on all cells in a given column via the use of the `cellPadding` key/value pair. `cellPadding` lets you use 'xxs', 'xs', 'sm', 'md', 'lg', 'xl' and 'none'.
|
|
2
2
|
|
|
3
|
-
This control can be used in conjunction with the `customRenderer` item within each columnDefinition to achieve custom background colors for individual cells as seen here.
|
|
3
|
+
This control can be used in conjunction with the `customRenderer` item within each columnDefinition to achieve custom background colors for individual cells as seen here. Use `fontColor` to achieve better contrast between cell content and background for darker backgrounds.
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.md
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
To achieve a sticky header AND sticky columns together, in addition to the `stickyLeftColumn` logic outlined above, you can:
|
|
2
2
|
|
|
3
3
|
- Set `sticky: true` via `tableProps`
|
|
4
|
-
- Give the AdvancedTable a `maxHeight` using our [Max Height](https://playbook.powerapp.cloud/
|
|
4
|
+
- Give the AdvancedTable a `maxHeight` using our [Max Height](https://playbook.powerapp.cloud//global_props/max_height) global prop.
|
|
5
5
|
|
|
6
6
|
**NOTE**: This behavior requires a `maxHeight` to work. The header is sticky within the table container, allowing for it to work along with the column stickiness.
|
|
7
7
|
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Create a sticky header that works for responsive Advanced Tables by setting `sticky: true` via `table_props` and giving the AdvancedTable a `max_height` using our [Max Height](https://playbook.powerapp.cloud/
|
|
1
|
+
Create a sticky header that works for responsive Advanced Tables by setting `sticky: true` via `table_props` and giving the AdvancedTable a `max_height` using our [Max Height](https://playbook.powerapp.cloud/global_props/max_height) global prop.
|
|
2
2
|
|
|
3
3
|
**NOTE**: This behavior requires a `max_height` to work. The header is sticky within the table container, allowing for it to work along with the first column stickiness of a responsive table on smaller screen sizes.
|
|
4
4
|
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_react.md
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Create a sticky header that works for responsive Advanced Tables by setting `sticky: true` via `tableProps` and giving the AdvancedTable a `maxHeight` using our [Max Height](https://playbook.powerapp.cloud/
|
|
1
|
+
Create a sticky header that works for responsive Advanced Tables by setting `sticky: true` via `tableProps` and giving the AdvancedTable a `maxHeight` using our [Max Height](https://playbook.powerapp.cloud/global_props/max_height) global prop.
|
|
2
2
|
|
|
3
3
|
**NOTE**: This behavior requires a `maxHeight` to work. The header is sticky within the table container, allowing for it to work along with the first column stickiness of a responsive table on smaller screen sizes.
|
|
4
4
|
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header.jsx
CHANGED
|
@@ -76,6 +76,22 @@ const columnDefinitions = [
|
|
|
76
76
|
{
|
|
77
77
|
label: "Attendance",
|
|
78
78
|
id: "attendance",
|
|
79
|
+
header: () => (
|
|
80
|
+
<Flex alignItems="center"
|
|
81
|
+
justifyContent="center"
|
|
82
|
+
>
|
|
83
|
+
<Caption marginRight="xs">Attendance</Caption>
|
|
84
|
+
<Tooltip placement="top"
|
|
85
|
+
text="Whoa. I'm a Tooltip Too!"
|
|
86
|
+
zIndex={10}
|
|
87
|
+
>
|
|
88
|
+
<Icon cursor="pointer"
|
|
89
|
+
icon="info"
|
|
90
|
+
size="xs"
|
|
91
|
+
/>
|
|
92
|
+
</Tooltip>
|
|
93
|
+
</Flex>
|
|
94
|
+
),
|
|
79
95
|
columns: [
|
|
80
96
|
{
|
|
81
97
|
accessor: "attendanceRate",
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
<%
|
|
2
|
+
column_definitions = [
|
|
3
|
+
{
|
|
4
|
+
accessor: "year",
|
|
5
|
+
label: "Year",
|
|
6
|
+
id: "year",
|
|
7
|
+
cellAccessors: ["quarter", "month", "day"],
|
|
8
|
+
},
|
|
9
|
+
{
|
|
10
|
+
label: "Enrollment Data",
|
|
11
|
+
id: "enrollmentData",
|
|
12
|
+
header: ->(cell, label) {
|
|
13
|
+
capture do
|
|
14
|
+
pb_rails("flex", props: { align_items: "center", justify_content: "center" }) do
|
|
15
|
+
pb_rails("caption", props: { margin_right: "xs", text: "Enrollment Data" }) +
|
|
16
|
+
pb_rails("icon", props: { id: "tooltip-interact-multi", icon: "info", size: "xs", cursor: "pointer" }) +
|
|
17
|
+
pb_rails("tooltip", props: {
|
|
18
|
+
trigger_element_id: "tooltip-interact-multi",
|
|
19
|
+
tooltip_id: "example-custom-tooltip-multi",
|
|
20
|
+
position: "top",
|
|
21
|
+
z_index: "10"
|
|
22
|
+
}) do
|
|
23
|
+
"Whoa. I'm a Tooltip"
|
|
24
|
+
end
|
|
25
|
+
end
|
|
26
|
+
end
|
|
27
|
+
},
|
|
28
|
+
columns: [
|
|
29
|
+
{
|
|
30
|
+
label: "Enrollment Stats",
|
|
31
|
+
id: "enrollmentStats",
|
|
32
|
+
columns: [
|
|
33
|
+
{
|
|
34
|
+
accessor: "newEnrollments",
|
|
35
|
+
id: "newEnrollments",
|
|
36
|
+
label: "New Enrollments",
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
accessor: "scheduledMeetings",
|
|
40
|
+
id: "scheduledMeetings",
|
|
41
|
+
label: "Scheduled Meetings",
|
|
42
|
+
},
|
|
43
|
+
],
|
|
44
|
+
},
|
|
45
|
+
],
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
label: "Performance Data",
|
|
49
|
+
id: "performanceData",
|
|
50
|
+
columns: [
|
|
51
|
+
{
|
|
52
|
+
label: "Completion Metrics",
|
|
53
|
+
id: "completionMetrics",
|
|
54
|
+
columns: [
|
|
55
|
+
{
|
|
56
|
+
accessor: "completedClasses",
|
|
57
|
+
id: "completedClasses",
|
|
58
|
+
label: "Completed Classes",
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
accessor: "classCompletionRate",
|
|
62
|
+
id: "classCompletionRate",
|
|
63
|
+
label: "Class Completion Rate",
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
label: "Attendance",
|
|
69
|
+
id: "attendance",
|
|
70
|
+
header: ->(cell, label) {
|
|
71
|
+
capture do
|
|
72
|
+
pb_rails("flex", props: { align_items: "center", justify_content: "center" }) do
|
|
73
|
+
pb_rails("caption", props: { margin_right: "xs", text: "Attendance" }) +
|
|
74
|
+
pb_rails("icon", props: { id: "tooltip-interact-multi-2", icon: "info", size: "xs", cursor: "pointer" }) +
|
|
75
|
+
pb_rails("tooltip", props: {
|
|
76
|
+
trigger_element_id: "tooltip-interact-multi-2",
|
|
77
|
+
tooltip_id: "example-custom-tooltip-multi-2",
|
|
78
|
+
position: "top",
|
|
79
|
+
z_index: "10"
|
|
80
|
+
}) do
|
|
81
|
+
"Whoa. I'm a Tooltip Too!"
|
|
82
|
+
end
|
|
83
|
+
end
|
|
84
|
+
end
|
|
85
|
+
},
|
|
86
|
+
columns: [
|
|
87
|
+
{
|
|
88
|
+
accessor: "attendanceRate",
|
|
89
|
+
id: "attendanceRate",
|
|
90
|
+
label: "Attendance Rate",
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
accessor: "scheduledMeetings",
|
|
94
|
+
id: "scheduledMeetings",
|
|
95
|
+
label: "Scheduled Meetings",
|
|
96
|
+
},
|
|
97
|
+
],
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
},
|
|
101
|
+
]
|
|
102
|
+
%>
|
|
103
|
+
|
|
104
|
+
<%= pb_rails("advanced_table", props: { id: "custom_header_multi_header_table", table_data: @table_data, column_definitions: column_definitions }) %>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
The optional `header` item within `column_definitions` can also be used with multi headers as seen here.
|
data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_rails.html.erb
CHANGED
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
capture do
|
|
13
13
|
pb_rails("flex", props: { align_items: "center", justify_content: "center" }) do
|
|
14
14
|
pb_rails("caption", props: { margin_right: "xs", text: "New Enrollments" }) +
|
|
15
|
-
pb_rails("icon", props: { id: "tooltip-interact", icon: "info", size: "xs" }) +
|
|
15
|
+
pb_rails("icon", props: { id: "tooltip-interact", icon: "info", size: "xs", cursor: "pointer" }) +
|
|
16
16
|
pb_rails("tooltip", props: {
|
|
17
17
|
trigger_element_id: "tooltip-interact",
|
|
18
18
|
tooltip_id: "example-custom-tooltip",
|
|
@@ -11,6 +11,7 @@ examples:
|
|
|
11
11
|
- advanced_table_responsive: Responsive Tables
|
|
12
12
|
- advanced_table_custom_cell_rails: Custom Components for Cells
|
|
13
13
|
- advanced_table_with_custom_header_rails: Custom Header Cell
|
|
14
|
+
- advanced_table_with_custom_header_multi_header_rails: Custom Header with Multiple Headers
|
|
14
15
|
- advanced_table_column_headers: Multi-Header Columns
|
|
15
16
|
- advanced_table_column_headers_multiple: Multi-Header Columns (Multiple Levels)
|
|
16
17
|
- advanced_table_column_headers_vertical_border: Multi-Header Columns with Vertical Borders
|
|
@@ -82,32 +82,62 @@ module Playbook
|
|
|
82
82
|
end
|
|
83
83
|
end
|
|
84
84
|
|
|
85
|
-
# Get original column definition for custom rendering
|
|
85
|
+
# Get original column definition for custom rendering by accessor
|
|
86
86
|
def find_original_column_def(accessor)
|
|
87
87
|
find_column_def_by_accessor(column_definitions, accessor)
|
|
88
88
|
end
|
|
89
89
|
|
|
90
|
+
# Get original column definition for custom rendering by id
|
|
91
|
+
def find_original_column_def_by_id(id)
|
|
92
|
+
find_column_def_by_id(column_definitions, id)
|
|
93
|
+
end
|
|
94
|
+
|
|
90
95
|
# Check if a header cell has a custom renderer
|
|
91
96
|
def has_header_renderer?(cell)
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
97
|
+
original_def = find_original_column_def_for_cell(cell)
|
|
98
|
+
original_def&.dig(:header).present?
|
|
99
|
+
rescue
|
|
100
|
+
false
|
|
96
101
|
end
|
|
97
102
|
|
|
98
103
|
# Render custom header content
|
|
99
104
|
def render_header(cell)
|
|
100
105
|
return cell[:label] unless has_header_renderer?(cell)
|
|
101
106
|
|
|
102
|
-
original_def =
|
|
107
|
+
original_def = find_original_column_def_for_cell(cell)
|
|
108
|
+
return cell[:label] unless original_def
|
|
109
|
+
|
|
103
110
|
custom_renderer = original_def[:header]
|
|
111
|
+
return cell[:label] unless custom_renderer
|
|
104
112
|
|
|
105
113
|
# Call the custom renderer with the cell data and label
|
|
106
|
-
|
|
114
|
+
begin
|
|
115
|
+
result = custom_renderer.call(cell, cell[:label])
|
|
116
|
+
result.present? ? result.to_s : cell[:label]
|
|
117
|
+
rescue
|
|
118
|
+
cell[:label]
|
|
119
|
+
end
|
|
107
120
|
end
|
|
108
121
|
|
|
109
122
|
private
|
|
110
123
|
|
|
124
|
+
# Find the original column definition for a cell
|
|
125
|
+
def find_original_column_def_for_cell(cell)
|
|
126
|
+
# Try accessor first (for leaf columns)
|
|
127
|
+
if cell[:accessor].present?
|
|
128
|
+
found = find_original_column_def(cell[:accessor])
|
|
129
|
+
return found if found
|
|
130
|
+
end
|
|
131
|
+
|
|
132
|
+
# Try id if accessor lookup didn't find it (for grouped columns or leaf columns with id)
|
|
133
|
+
if cell[:id].present?
|
|
134
|
+
found = find_original_column_def_by_id(cell[:id])
|
|
135
|
+
return found if found
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
nil
|
|
139
|
+
end
|
|
140
|
+
|
|
111
141
|
def compute_max_depth(columns)
|
|
112
142
|
columns.map do |col|
|
|
113
143
|
col[:columns] ? 1 + compute_max_depth(col[:columns]) : 1
|
|
@@ -118,21 +148,24 @@ module Playbook
|
|
|
118
148
|
total_columns = columns.size
|
|
119
149
|
columns.each_with_index do |col, index|
|
|
120
150
|
is_last = index == total_columns - 1
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
151
|
+
nested_columns = col[:columns]
|
|
152
|
+
if nested_columns
|
|
153
|
+
colspan = compute_leaf_columns(nested_columns)
|
|
154
|
+
cell_hash = {
|
|
124
155
|
label: col[:label],
|
|
125
156
|
colspan: colspan,
|
|
126
157
|
is_last_in_group: is_last && current_depth.positive?,
|
|
127
158
|
}
|
|
159
|
+
cell_hash[:id] = col[:id] if col[:id].present?
|
|
160
|
+
rows[current_depth] << cell_hash
|
|
128
161
|
|
|
129
|
-
process_columns(
|
|
162
|
+
process_columns(nested_columns, rows, current_depth + 1, max_depth)
|
|
130
163
|
else
|
|
131
|
-
raw_styling
|
|
132
|
-
header_alignment
|
|
164
|
+
raw_styling = col[:column_styling] || {}
|
|
165
|
+
header_alignment = raw_styling[:header_alignment]
|
|
133
166
|
|
|
134
167
|
colspan = 1
|
|
135
|
-
|
|
168
|
+
cell_hash = {
|
|
136
169
|
label: col[:label],
|
|
137
170
|
colspan: colspan,
|
|
138
171
|
accessor: col[:accessor],
|
|
@@ -140,6 +173,8 @@ module Playbook
|
|
|
140
173
|
is_last_in_group: is_last && current_depth.positive?,
|
|
141
174
|
header_alignment: header_alignment,
|
|
142
175
|
}
|
|
176
|
+
cell_hash[:id] = col[:id] if col[:id].present?
|
|
177
|
+
rows[current_depth] << cell_hash
|
|
143
178
|
end
|
|
144
179
|
end
|
|
145
180
|
end
|
|
@@ -154,11 +189,15 @@ module Playbook
|
|
|
154
189
|
max_depth = compute_max_depth(column_definitions)
|
|
155
190
|
|
|
156
191
|
column_definitions.map do |col|
|
|
157
|
-
if col
|
|
158
|
-
|
|
192
|
+
if col[:columns]
|
|
193
|
+
nested_columns = col[:columns]
|
|
194
|
+
wrapped = {
|
|
159
195
|
label: col[:label],
|
|
160
|
-
columns: wrap_leaf_columns(
|
|
196
|
+
columns: wrap_leaf_columns(nested_columns),
|
|
161
197
|
}
|
|
198
|
+
wrapped[:id] = col[:id] if col[:id].present?
|
|
199
|
+
wrapped[:header] = col[:header] if col[:header].present?
|
|
200
|
+
wrapped
|
|
162
201
|
else
|
|
163
202
|
# For leaf columns, wrap with empty labels up to max depth to get proper structure
|
|
164
203
|
wrap_leaf_column(col, max_depth)
|
|
@@ -173,6 +212,7 @@ module Playbook
|
|
|
173
212
|
sort_menu: col[:sort_menu] || nil,
|
|
174
213
|
column_styling: col[:column_styling] || {},
|
|
175
214
|
}
|
|
215
|
+
wrapped[:id] = col[:id] if col[:id].present?
|
|
176
216
|
(max_depth - 1).times do
|
|
177
217
|
wrapped = { label: "", columns: [wrapped] }
|
|
178
218
|
end
|
|
@@ -180,11 +220,41 @@ module Playbook
|
|
|
180
220
|
end
|
|
181
221
|
|
|
182
222
|
def find_column_def_by_accessor(defs, target_accessor)
|
|
223
|
+
return nil if target_accessor.blank?
|
|
224
|
+
|
|
183
225
|
defs.each do |col|
|
|
184
|
-
|
|
226
|
+
col_accessor = col[:accessor]
|
|
227
|
+
next if col_accessor.blank?
|
|
228
|
+
|
|
229
|
+
return col if col_accessor.to_s == target_accessor.to_s
|
|
230
|
+
|
|
231
|
+
nested_columns = col[:columns]
|
|
232
|
+
if nested_columns.is_a?(Array)
|
|
233
|
+
found = find_column_def_by_accessor(nested_columns, target_accessor)
|
|
234
|
+
return found if found
|
|
235
|
+
end
|
|
236
|
+
end
|
|
237
|
+
nil
|
|
238
|
+
end
|
|
239
|
+
|
|
240
|
+
def find_column_def_by_id(defs, target_id)
|
|
241
|
+
return nil if target_id.blank?
|
|
242
|
+
|
|
243
|
+
defs.each do |col|
|
|
244
|
+
col_id = col[:id]
|
|
245
|
+
|
|
246
|
+
return col if col_id.present? && col_id.to_s == target_id.to_s
|
|
247
|
+
|
|
248
|
+
# Recursively search nested columns, even if current col has no id or doesn't match
|
|
249
|
+
nested_columns = col[:columns]
|
|
250
|
+
|
|
251
|
+
next unless nested_columns.present?
|
|
252
|
+
|
|
253
|
+
# Convert to array if needed (for edge cases where is_a?(Array) might fail)
|
|
254
|
+
array_columns = Array(nested_columns)
|
|
185
255
|
|
|
186
|
-
if
|
|
187
|
-
found =
|
|
256
|
+
if array_columns.any?
|
|
257
|
+
found = find_column_def_by_id(array_columns, target_id)
|
|
188
258
|
return found if found
|
|
189
259
|
end
|
|
190
260
|
end
|
|
@@ -79,15 +79,44 @@ module Playbook
|
|
|
79
79
|
cell_background_color(column).present?
|
|
80
80
|
end
|
|
81
81
|
|
|
82
|
+
def cell_font_color(column)
|
|
83
|
+
return nil unless column[:accessor].present?
|
|
84
|
+
|
|
85
|
+
orig_def = find_column_def_by_accessor(column_definitions, column[:accessor])
|
|
86
|
+
if orig_def && orig_def[:column_styling].is_a?(Hash) && orig_def[:column_styling][:font_color].present?
|
|
87
|
+
font_color = orig_def[:column_styling][:font_color]
|
|
88
|
+
if font_color.respond_to?(:call)
|
|
89
|
+
font_color.call(row)
|
|
90
|
+
else
|
|
91
|
+
font_color
|
|
92
|
+
end
|
|
93
|
+
end
|
|
94
|
+
end
|
|
95
|
+
|
|
82
96
|
# Uses a regular table/table_cell component if there is no custom background color; if there is a cell_background_color uses a background component with tag "td"
|
|
83
97
|
def cell_component_info(column, index, bg_color, font_color)
|
|
98
|
+
column_font_color = cell_font_color(column)
|
|
99
|
+
effective_font_color = column_font_color || font_color
|
|
100
|
+
|
|
84
101
|
if has_custom_background_color?(column)
|
|
85
102
|
custom_bg_color = cell_background_color(column)
|
|
86
103
|
component_name = "background"
|
|
87
|
-
component_props = {
|
|
104
|
+
component_props = {
|
|
105
|
+
background_color: custom_bg_color,
|
|
106
|
+
tag: "td",
|
|
107
|
+
classname: td_classname(column, index),
|
|
108
|
+
}
|
|
109
|
+
component_props[:html_options] = { style: { color: effective_font_color } } if effective_font_color.present?
|
|
88
110
|
else
|
|
89
111
|
component_name = "table/table_cell"
|
|
90
|
-
|
|
112
|
+
style_hash = { "background-color": bg_color }
|
|
113
|
+
style_hash[:color] = effective_font_color if effective_font_color.present?
|
|
114
|
+
component_props = {
|
|
115
|
+
html_options: {
|
|
116
|
+
style: style_hash,
|
|
117
|
+
},
|
|
118
|
+
classname: td_classname(column, index),
|
|
119
|
+
}
|
|
91
120
|
end
|
|
92
121
|
|
|
93
122
|
{ name: component_name, props: component_props }
|
|
@@ -1,3 +1,11 @@
|
|
|
1
|
+
<%
|
|
2
|
+
html_options_style = ""
|
|
3
|
+
if object.html_options[:style].is_a?(Hash)
|
|
4
|
+
html_options_style = object.html_options[:style].map { |k, v| "#{k.to_s.tr('_', '-')}: #{v}" }.join("; ")
|
|
5
|
+
elsif object.html_options[:style].is_a?(String)
|
|
6
|
+
html_options_style = object.html_options[:style]
|
|
7
|
+
end
|
|
8
|
+
%>
|
|
1
9
|
<% if object.image_url.present? %>
|
|
2
10
|
<%= pb_content_tag(object.tag,
|
|
3
11
|
style: "background-image: url('#{object.image_url}');
|
|
@@ -9,8 +17,8 @@
|
|
|
9
17
|
<% end %>
|
|
10
18
|
<% else %>
|
|
11
19
|
<%= pb_content_tag(object.tag,
|
|
12
|
-
style: object.custom_background_color
|
|
20
|
+
style: "#{object.custom_background_color}#{html_options_style.present? ? "; #{html_options_style}" : ""}"
|
|
13
21
|
) do %>
|
|
14
22
|
<%= content.presence %>
|
|
15
23
|
<% end %>
|
|
16
|
-
<% end %>
|
|
24
|
+
<% end %>
|
|
@@ -1 +1 @@
|
|
|
1
|
-
Category colors can be passed into the background kit. Values `category_1` to `category_21` are accepted. List of all category and status colors can be viewed <a href="https://playbook.powerapp.cloud/
|
|
1
|
+
Category colors can be passed into the background kit. Values `category_1` to `category_21` are accepted. List of all category and status colors can be viewed <a href="https://playbook.powerapp.cloud/tokens/colors" target="_blank">here</a>.
|