playbook_ui 15.2.0.pre.alpha.PLAY2542formatasyoutypebug11501 → 15.2.0.pre.alpha.PLAY2589advancedtableinlinerowloadingtoggleicon11641

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/_playbook.scss +2 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +3 -1
  4. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableHeader.tsx +3 -0
  5. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +3 -0
  6. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +2 -2
  7. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +59 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.html.erb +3 -3
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.md +3 -1
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_sort.html.erb +3 -3
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta_subrow_headers.html.erb +3 -3
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_collapsible_trail_rails.html.erb +2 -2
  13. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers_rails.html.erb +2 -2
  14. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +2 -2
  15. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_row_loading_show_toggle.jsx +59 -0
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_row_loading_show_toggle.md +5 -0
  17. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control_per_row_rails.html.erb +2 -2
  18. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control_rails.html.erb +2 -2
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.html.erb +2 -2
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_mock_data_inline_loading_empty_children.js +202 -0
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +1 -0
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +2 -1
  23. data/app/pb_kits/playbook/pb_advanced_table/index.js +5 -1
  24. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +6 -6
  25. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +6 -6
  26. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +1 -1
  27. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +5 -5
  28. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.scss +0 -1
  29. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.tsx +5 -3
  30. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_description.md +2 -0
  31. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.rb +4 -1
  32. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.test.js +10 -0
  33. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_description.md +3 -0
  34. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_description.md +3 -0
  35. data/app/pb_kits/playbook/pb_pb_gauge_chart/_pb_gauge_chart.scss +3 -0
  36. data/app/pb_kits/playbook/pb_pb_gauge_chart/_pb_gauge_chart.tsx +69 -0
  37. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_description.md +3 -0
  38. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_color.html.erb +12 -0
  39. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_color.jsx +24 -0
  40. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_color.md +5 -0
  41. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_complex.html.erb +45 -0
  42. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_complex.jsx +119 -0
  43. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_complex.md +1 -0
  44. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_default.html.erb +5 -0
  45. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_default.jsx +17 -0
  46. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_disable_animation.html.erb +12 -0
  47. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_disable_animation.jsx +24 -0
  48. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_full_circle.html.erb +23 -0
  49. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_full_circle.jsx +37 -0
  50. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_height.html.erb +40 -0
  51. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_height.jsx +56 -0
  52. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_live_data.jsx +64 -0
  53. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_min_max.html.erb +27 -0
  54. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_min_max.jsx +40 -0
  55. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_min_max.md +1 -0
  56. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_sizing.html.erb +19 -0
  57. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_sizing.jsx +65 -0
  58. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_sizing.md +3 -0
  59. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_title.html.erb +14 -0
  60. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_title.jsx +27 -0
  61. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_units.html.erb +39 -0
  62. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_units.jsx +58 -0
  63. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_units.md +1 -0
  64. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/example.yml +29 -0
  65. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/index.js +11 -0
  66. data/app/pb_kits/playbook/pb_pb_gauge_chart/pbGaugeGraphTheme.ts +91 -0
  67. data/app/pb_kits/playbook/pb_pb_gauge_chart/pb_gauge_chart.html.erb +1 -0
  68. data/app/pb_kits/playbook/pb_pb_gauge_chart/pb_gauge_chart.rb +25 -0
  69. data/app/pb_kits/playbook/pb_pb_gauge_chart/pb_gauge_chart.test.jsx +80 -0
  70. data/app/pb_kits/playbook/pb_pb_line_graph/docs/_description.md +1 -1
  71. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +13 -13
  72. data/app/pb_kits/playbook/pb_typeahead/_typeahead.test.jsx +35 -1
  73. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +71 -2
  74. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_options.html.erb +36 -0
  75. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_options.md +1 -0
  76. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_value.jsx +41 -0
  77. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_value.md +1 -0
  78. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +2 -0
  79. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  80. data/app/pb_kits/playbook/tokens/_positioning.scss +1 -0
  81. data/app/pb_kits/playbook/utilities/_positioning.scss +6 -1
  82. data/app/pb_kits/playbook/utilities/globalProps.ts +3 -1
  83. data/dist/chunks/{_line_graph-eXNg1pX_.js → _line_graph-D5MBnrO9.js} +1 -1
  84. data/dist/chunks/_typeahead-BjYBazGq.js +6 -0
  85. data/dist/chunks/{_weekday_stacked-D6SPyi5u.js → _weekday_stacked-B_Uc7-rO.js} +3 -3
  86. data/dist/chunks/vendor.js +1 -1
  87. data/dist/menu.yml +6 -0
  88. data/dist/playbook-doc.js +2 -2
  89. data/dist/playbook-rails-react-bindings.js +1 -1
  90. data/dist/playbook-rails.js +1 -1
  91. data/dist/playbook.css +1 -1
  92. data/lib/playbook/version.rb +1 -1
  93. data/lib/playbook/z_index.rb +1 -1
  94. metadata +49 -5
  95. data/dist/chunks/_typeahead-B6jpvyrP.js +0 -6
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 66bd84abefa68eb69260d4f315cd027b9109b9271e2ab828e245305934e7b34c
4
- data.tar.gz: 14d3cfdadac16c1960d4ef5a608d0e95d491cb3e4780fb804f6f778dc2ca0926
3
+ metadata.gz: 26ef9154b98ad4d5d762b37915fa398314c6020fc3cf0c0b42b9e074fd55f569
4
+ data.tar.gz: 5a79125ffb800db93c0ebe22ad143167bac0f9c018ebc33beba7a1c2049ec3fc
5
5
  SHA512:
6
- metadata.gz: 356228c23803a8da19fdd22c0a7262ddc6e52f826f6eaad2405af0ad6e8c7d474518c32f1594474f46f6c0154cc1d403446e6078dccc39cbc8b047f9dca1f692
7
- data.tar.gz: 70083aeae526b60e4a38d925b3c2bdea6e307224b5d3cce2544ec756f26aa243f66cf87256af2f5e8dc179feabacab828733f47a86d2f886bc38915bcd9fc4f2
6
+ metadata.gz: 812c93c1d3667ad67d5e7d810b5d4a399c3ac6d11c003b231b32ed8dafb8742e4097b37b215f8a7ea9d5474626b57d8ead7dc11d60483b72a701efeecc9c3063
7
+ data.tar.gz: d0eeafe285857f375b45699aed9f1d4a25915c99b50e6a50d148937b4de0ce6e2d99a67e986305d83ebf6e36a4d67b3e9daed119a0138ae1f3cf7ca858d04cd2
@@ -1,3 +1,4 @@
1
+
1
2
  @import 'pb_advanced_table/advanced_table';
2
3
  @import 'pb_avatar/avatar';
3
4
  @import 'pb_background/background';
@@ -70,6 +71,7 @@
70
71
  @import 'pb_passphrase/passphrase';
71
72
  @import 'pb_pb_bar_graph/pb_bar_graph';
72
73
  @import 'pb_pb_circle_chart/pb_circle_chart';
74
+ @import 'pb_pb_gauge_chart/pb_gauge_chart';
73
75
  @import 'pb_pb_line_graph/pb_line_graph';
74
76
  @import 'pb_person/person';
75
77
  @import 'pb_person_contact/person_contact';
@@ -30,6 +30,7 @@ type TableHeaderCellProps = {
30
30
  headerChildren?: React.ReactNode | React.ReactNode[]
31
31
  isPinnedLeft?: boolean
32
32
  loading?: boolean
33
+ showToggleWithInlineRowLoading?: boolean
33
34
  sortIcon?: string | string[]
34
35
  table?: Table<GenericObject>
35
36
  } & GlobalProps
@@ -58,6 +59,7 @@ export const TableHeaderCell = ({
58
59
  selectableRows,
59
60
  hasAnySubRows,
60
61
  showActionsBar,
62
+ showToggleWithInlineRowLoading,
61
63
  stickyLeftColumn,
62
64
  inlineRowLoading,
63
65
  isActionBarVisible,
@@ -220,7 +222,7 @@ const isToggleExpansionEnabled =
220
222
  />
221
223
  )
222
224
  }
223
- {isToggleExpansionEnabled && hasAnySubRows && !expandByDepth && (
225
+ {isToggleExpansionEnabled && ((hasAnySubRows) || (inlineRowLoading && showToggleWithInlineRowLoading)) && !expandByDepth && (
224
226
  <ToggleIconButton onClick={handleExpandOrCollapse} />
225
227
  )}
226
228
  {isToggleExpansionEnabled && hasAnySubRows && expandByDepth && (
@@ -39,6 +39,7 @@ export const TableHeader = ({
39
39
  hasAnySubRows,
40
40
  showActionsBar,
41
41
  selectableRows,
42
+ showToggleWithInlineRowLoading,
42
43
  responsive,
43
44
  headerRef,
44
45
  virtualizedRows,
@@ -92,6 +93,7 @@ export const TableHeader = ({
92
93
  isPinnedLeft={isPinnedLeft}
93
94
  key={`${header.id}-header`}
94
95
  loading={loading}
96
+ showToggleWithInlineRowLoading={showToggleWithInlineRowLoading}
95
97
  sortIcon={sortIcon}
96
98
  table={table}
97
99
  />
@@ -136,6 +138,7 @@ export const TableHeader = ({
136
138
  isVirtualized
137
139
  key={`${header.id}-header-virtualized`}
138
140
  loading={loading}
141
+ showToggleWithInlineRowLoading={showToggleWithInlineRowLoading}
139
142
  sortIcon={sortIcon}
140
143
  table={table}
141
144
  />
@@ -63,6 +63,7 @@ type AdvancedTableProps = {
63
63
  scrollBarNone?: boolean,
64
64
  selectableRows?: boolean,
65
65
  showActionsBar?: boolean,
66
+ showToggleWithInlineRowLoading?: boolean,
66
67
  sortControl?: GenericObject
67
68
  tableData: GenericObject[]
68
69
  tableOptions?: GenericObject
@@ -109,6 +110,7 @@ const AdvancedTable = (props: AdvancedTableProps) => {
109
110
  scrollBarNone= false,
110
111
  showActionsBar = true,
111
112
  selectableRows,
113
+ showToggleWithInlineRowLoading = false,
112
114
  sortControl,
113
115
  stickyLeftColumn,
114
116
  tableData,
@@ -355,6 +357,7 @@ const AdvancedTable = (props: AdvancedTableProps) => {
355
357
  selectableRows={selectableRows}
356
358
  setExpanded={setExpanded}
357
359
  showActionsBar={showActionsBar}
360
+ showToggleWithInlineRowLoading={showToggleWithInlineRowLoading}
358
361
  sortControl={sortControl}
359
362
  stickyLeftColumn={stickyLeftColumn}
360
363
  subRowHeaders={tableOptions?.subRowHeaders}
@@ -11,8 +11,8 @@
11
11
  <% if content.present? %>
12
12
  <% content.presence %>
13
13
  <% else %>
14
- <%= pb_rails("advanced_table/table_header", props: { id: object.id, column_definitions: object.column_definitions, enable_toggle_expansion: object.enable_toggle_expansion, responsive: object.responsive, loading: object.loading, selectable_rows: object.selectable_rows, show_actions_bar: object.show_actions_bar }) %>
15
- <%= pb_rails("advanced_table/table_body", props: { id: object.id, table_data: object.table_data, column_definitions: object.column_definitions, responsive: object.responsive, loading: object.loading, selectable_rows: object.selectable_rows, enable_toggle_expansion: object.enable_toggle_expansion, row_styling: object.row_styling }) %>
14
+ <%= pb_rails("advanced_table/table_header", props: { table_id: object.id, column_definitions: object.column_definitions, enable_toggle_expansion: object.enable_toggle_expansion, responsive: object.responsive, loading: object.loading, selectable_rows: object.selectable_rows, show_actions_bar: object.show_actions_bar }) %>
15
+ <%= pb_rails("advanced_table/table_body", props: { table_id: object.id, table_data: object.table_data, column_definitions: object.column_definitions, responsive: object.responsive, loading: object.loading, selectable_rows: object.selectable_rows, enable_toggle_expansion: object.enable_toggle_expansion, row_styling: object.row_styling }) %>
16
16
  <% end %>
17
17
  <% end %>
18
18
  <% end %>
@@ -108,6 +108,48 @@ const MOCK_DATA_WITH_ID = [
108
108
  },
109
109
  ]
110
110
 
111
+ const MOCK_DATA_NO_SUBROWS = [
112
+ {
113
+ year: "2021",
114
+ quarter: null,
115
+ month: null,
116
+ day: null,
117
+ newEnrollments: "20",
118
+ scheduledMeetings: "10",
119
+ attendanceRate: "51%",
120
+ completedClasses: "3",
121
+ classCompletionRate: "33%",
122
+ graduatedStudents: "19",
123
+ children: [],
124
+ },
125
+ {
126
+ year: "2022",
127
+ quarter: null,
128
+ month: null,
129
+ day: null,
130
+ newEnrollments: "25",
131
+ scheduledMeetings: "17",
132
+ attendanceRate: "75%",
133
+ completedClasses: "5",
134
+ classCompletionRate: "45%",
135
+ graduatedStudents: "32",
136
+ children: [],
137
+ },
138
+ {
139
+ year: "2023",
140
+ quarter: null,
141
+ month: null,
142
+ day: null,
143
+ newEnrollments: "30",
144
+ scheduledMeetings: "22",
145
+ attendanceRate: "80%",
146
+ completedClasses: "7",
147
+ classCompletionRate: "55%",
148
+ graduatedStudents: "45",
149
+ children: [],
150
+ },
151
+ ]
152
+
111
153
  const columnDefinitions = [
112
154
  {
113
155
  accessor: "year",
@@ -509,6 +551,23 @@ test("inlineRowLoading prop renders inline loading if true", () => {
509
551
  expect(inlineLoading).toBeInTheDocument()
510
552
  })
511
553
 
554
+ test("showToggleWithInlineRowLoading prop shows header toggle when inlineRowLoading is true", () => {
555
+ render(
556
+ <AdvancedTable
557
+ columnDefinitions={columnDefinitions}
558
+ data={{ testid: testId }}
559
+ enableToggleExpansion="all"
560
+ inlineRowLoading
561
+ showToggleWithInlineRowLoading
562
+ tableData={MOCK_DATA_NO_SUBROWS}
563
+ />
564
+ )
565
+
566
+ const kit = screen.getByTestId(testId)
567
+ const headerToggleButton = kit.querySelector(".gray-icon.toggle-all-icon")
568
+ expect(headerToggleButton).toBeInTheDocument()
569
+ })
570
+
512
571
  test("responsive prop functions as expected", () => {
513
572
  render(
514
573
  <AdvancedTable
@@ -33,7 +33,7 @@
33
33
  }
34
34
  ] %>
35
35
 
36
- <%= pb_rails("advanced_table", props: { id: "padding-control", table_data: @table_data, column_definitions: column_definitions }) do %>
37
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
38
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data, column_definitions: column_definitions }) %>
36
+ <%= pb_rails("advanced_table", props: { id: "background-control", table_data: @table_data, column_definitions: column_definitions }) do %>
37
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "background-control", column_definitions: column_definitions }) %>
38
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "background-control", table_data: @table_data, column_definitions: column_definitions }) %>
39
39
  <% end %>
@@ -2,7 +2,9 @@ The AdvancedTable kit accepts tree data and automatically renders expansion cont
2
2
 
3
3
  ### id
4
4
 
5
- A unique `id` is required to allow the table functionality to work properly. Without it, certain functions like the action bar will not be able to properly reference the correct table.
5
+ A unique `id` is required to allow the table functionality to work properly. Without it, certain functions like the action bar, expand/collapse caching, or selectable rows will not be able to properly reference the correct table.
6
+
7
+ You must also set `table_id` when using subcomponents like `table_header` or `table_body`.
6
8
 
7
9
  ### table_data
8
10
 
@@ -51,7 +51,7 @@
51
51
  ]
52
52
  %>
53
53
 
54
- <%= pb_rails("advanced_table", props: { table_data: @table_data, column_definitions: column_definitions, id: "beta_sort" }) do %>
55
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
56
- <%= pb_rails("advanced_table/table_body", props: { id: "beta_sort", table_data: @table_data, column_definitions: column_definitions, enable_toggle_expansion: "all" }) %>
54
+ <%= pb_rails("advanced_table", props: { id: "sort", table_data: @table_data, column_definitions: column_definitions, id: "beta_sort" }) do %>
55
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "sort", column_definitions: column_definitions }) %>
56
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "sort", table_data: @table_data, column_definitions: column_definitions, enable_toggle_expansion: "all" }) %>
57
57
  <% end %>
@@ -34,7 +34,7 @@
34
34
  subrow_headers = ["Quarter", "Month", "Day"]
35
35
  %>
36
36
 
37
- <%= pb_rails("advanced_table", props: { table_data: @table_data, column_definitions: column_definitions, id: "test_table" }) do %>
38
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
39
- <%= pb_rails("advanced_table/table_body", props: { id: "test_table", table_data: @table_data, column_definitions: column_definitions, subrow_headers: subrow_headers, enable_toggle_expansion: "all" }) %>
37
+ <%= pb_rails("advanced_table", props: { id: "subrow-headers", table_data: @table_data, column_definitions: column_definitions, id: "test_table" }) do %>
38
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "subrow-headers", column_definitions: column_definitions }) %>
39
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "subrow-headers", table_data: @table_data, column_definitions: column_definitions, subrow_headers: subrow_headers, enable_toggle_expansion: "all" }) %>
40
40
  <% end %>
@@ -31,6 +31,6 @@
31
31
  ] %>
32
32
 
33
33
  <%= pb_rails("advanced_table", props: { id: "collapsible_trail", table_data: @table_data, column_definitions: column_definitions }) do %>
34
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
35
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data, column_definitions: column_definitions, collapsible_trail: false }) %>
34
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "collapsible_trail", column_definitions: column_definitions }) %>
35
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "collapsible_trail", table_data: @table_data, column_definitions: column_definitions, collapsible_trail: false }) %>
36
36
  <% end %>
@@ -58,6 +58,6 @@
58
58
  ] %>
59
59
 
60
60
  <%= pb_rails("advanced_table", props: { id: "column-styling-multi", table_data: @table_data, column_definitions: column_definitions }) do %>
61
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
62
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data, column_definitions: column_definitions }) %>
61
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "column-styling-multi", column_definitions: column_definitions }) %>
62
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "column-styling-multi", table_data: @table_data, column_definitions: column_definitions }) %>
63
63
  <% end %>
@@ -33,6 +33,6 @@
33
33
  ] %>
34
34
 
35
35
  <%= pb_rails("advanced_table", props: { id: "column-styling", table_data: @table_data, column_definitions: column_definitions }) do %>
36
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
37
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data, column_definitions: column_definitions }) %>
36
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "column-styling", column_definitions: column_definitions }) %>
37
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "column-styling", table_data: @table_data, column_definitions: column_definitions }) %>
38
38
  <% end %>
@@ -0,0 +1,59 @@
1
+ import React from "react"
2
+ import AdvancedTable from '../_advanced_table'
3
+ import { MOCK_DATA_INLINE_LOADING_EMPTY_CHILDREN } from "./_mock_data_inline_loading_empty_children"
4
+
5
+ const AdvancedTableInlineRowLoadingShowToggle = (props) => {
6
+ const columnDefinitions = [
7
+ {
8
+ accessor: "year",
9
+ label: "Year",
10
+ cellAccessors: ["quarter", "month", "day"],
11
+ },
12
+ {
13
+ accessor: "newEnrollments",
14
+ label: "New Enrollments",
15
+ },
16
+ {
17
+ accessor: "scheduledMeetings",
18
+ label: "Scheduled Meetings",
19
+ },
20
+ {
21
+ accessor: "attendanceRate",
22
+ label: "Attendance Rate",
23
+ },
24
+ {
25
+ accessor: "completedClasses",
26
+ label: "Completed Classes",
27
+ },
28
+ {
29
+ accessor: "classCompletionRate",
30
+ label: "Class Completion Rate",
31
+ },
32
+ {
33
+ accessor: "graduatedStudents",
34
+ label: "Graduated Students",
35
+ },
36
+ ]
37
+
38
+ //Render the subRow header rows
39
+ const subRowHeaders = ["Quarter", "Month", "Day"]
40
+
41
+
42
+ return (
43
+ <div>
44
+ <AdvancedTable
45
+ columnDefinitions={columnDefinitions}
46
+ enableToggleExpansion="all"
47
+ inlineRowLoading
48
+ showToggleWithInlineRowLoading
49
+ tableData={MOCK_DATA_INLINE_LOADING_EMPTY_CHILDREN}
50
+ {...props}
51
+ >
52
+ <AdvancedTable.Header />
53
+ <AdvancedTable.Body subRowHeaders={subRowHeaders}/>
54
+ </AdvancedTable>
55
+ </div>
56
+ )
57
+ }
58
+
59
+ export default AdvancedTableInlineRowLoadingShowToggle
@@ -0,0 +1,5 @@
1
+ The `showToggleWithInlineRowLoading` is a boolean prop that renders the toggle-all icon in the top left header cell for complex datasets with enoty `children` arrays and advanced querying logic explained in the preceeding doc example. Your logic may require an additional query helper file to update data specifically from requerying via toggle all buttons.
2
+
3
+ In this code example, all 3 rows have empty children arrays. The toggle all button would not render (prior to an initial row expansion) without `showToggleWithInlineRowLoading` in place.
4
+
5
+ This prop is set to false by default and should only be used in conjunction with `inlineRowLoading`.
@@ -46,6 +46,6 @@
46
46
  ] %>
47
47
 
48
48
  <%= pb_rails("advanced_table", props: { id: "padding-control-per-row", table_data: @table_data_with_id, column_definitions: column_definitions, row_styling: row_styling }) do %>
49
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
50
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data_with_id, column_definitions: column_definitions, row_styling: row_styling }) %>
49
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "padding-control-per-row", column_definitions: column_definitions }) %>
50
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "padding-control-per-row", table_data: @table_data_with_id, column_definitions: column_definitions, row_styling: row_styling }) %>
51
51
  <% end %>
@@ -35,6 +35,6 @@
35
35
  ] %>
36
36
 
37
37
  <%= pb_rails("advanced_table", props: { id: "padding-control", table_data: @table_data, column_definitions: column_definitions }) do %>
38
- <%= pb_rails("advanced_table/table_header", props: { column_definitions: column_definitions }) %>
39
- <%= pb_rails("advanced_table/table_body", props: { table_data: @table_data, column_definitions: column_definitions }) %>
38
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "padding-control", column_definitions: column_definitions }) %>
39
+ <%= pb_rails("advanced_table/table_body", props: { table_id: "padding-control", table_data: @table_data, column_definitions: column_definitions }) %>
40
40
  <% end %>
@@ -34,6 +34,6 @@
34
34
  %>
35
35
 
36
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: { id: "selectable_rows", 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 }) %>
37
+ <%= pb_rails("advanced_table/table_header", props: { table_id: "selectable_rows", column_definitions: column_definitions, selectable_rows: true }) %>
38
+ <%= pb_rails("advanced_table/table_body", props: { table_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
39
  <% end %>
@@ -0,0 +1,202 @@
1
+ export const MOCK_DATA_INLINE_LOADING_EMPTY_CHILDREN = [
2
+ {
3
+ year: "2021",
4
+ quarter: null,
5
+ month: null,
6
+ day: null,
7
+ newEnrollments: "20",
8
+ scheduledMeetings: "10",
9
+ attendanceRate: "51%",
10
+ completedClasses: "3",
11
+ classCompletionRate: "33%",
12
+ graduatedStudents: "19",
13
+ children: [],
14
+ },
15
+ {
16
+ year: "2022",
17
+ quarter: null,
18
+ month: null,
19
+ day: null,
20
+ newEnrollments: "25",
21
+ scheduledMeetings: "17",
22
+ attendanceRate: "75%",
23
+ completedClasses: "5",
24
+ classCompletionRate: "45%",
25
+ graduatedStudents: "32",
26
+ children: [],
27
+ // children: [
28
+ // {
29
+ // year: "2022",
30
+ // quarter: "Q1",
31
+ // month: null,
32
+ // day: null,
33
+ // newEnrollments: "2",
34
+ // scheduledMeetings: "35",
35
+ // attendanceRate: "32%",
36
+ // completedClasses: "15",
37
+ // classCompletionRate: "52%",
38
+ // graduatedStudents: "36",
39
+ // children: [
40
+ // {
41
+ // year: "2022",
42
+ // quarter: "Q1",
43
+ // month: "January",
44
+ // day: null,
45
+ // newEnrollments: "16",
46
+ // scheduledMeetings: "20",
47
+ // attendanceRate: "11%",
48
+ // completedClasses: "13",
49
+ // classCompletionRate: "47%",
50
+ // graduatedStudents: "28",
51
+ // children: [
52
+ // {
53
+ // year: "2022",
54
+ // quarter: "Q1",
55
+ // month: "January",
56
+ // day: "15",
57
+ // newEnrollments: "34",
58
+ // scheduledMeetings: "28",
59
+ // attendanceRate: "97%",
60
+ // completedClasses: "20",
61
+ // classCompletionRate: "15%",
62
+ // graduatedStudents: "17",
63
+ // },
64
+ // {
65
+ // year: "2022",
66
+ // quarter: "Q1",
67
+ // month: "January",
68
+ // day: "25",
69
+ // newEnrollments: "43",
70
+ // scheduledMeetings: "23",
71
+ // attendanceRate: "66%",
72
+ // completedClasses: "26",
73
+ // classCompletionRate: "47%",
74
+ // graduatedStudents: "9",
75
+ // },
76
+ // ],
77
+ // },
78
+ // {
79
+ // year: "2022",
80
+ // quarter: "Q1",
81
+ // month: "May",
82
+ // day: null,
83
+ // newEnrollments: "20",
84
+ // scheduledMeetings: "41",
85
+ // attendanceRate: "95%",
86
+ // completedClasses: "26",
87
+ // classCompletionRate: "83%",
88
+ // graduatedStudents: "43",
89
+ // children: [
90
+ // {
91
+ // year: "2011",
92
+ // quarter: "Q1",
93
+ // month: "May",
94
+ // day: "2",
95
+ // newEnrollments: "19",
96
+ // scheduledMeetings: "35",
97
+ // attendanceRate: "69%",
98
+ // completedClasses: "8",
99
+ // classCompletionRate: "75%",
100
+ // graduatedStudents: "23",
101
+ // },
102
+ // ],
103
+ // },
104
+ // ],
105
+ // },
106
+ // ],
107
+ },
108
+ {
109
+ year: "2023",
110
+ quarter: null,
111
+ month: null,
112
+ day: null,
113
+ newEnrollments: "10",
114
+ scheduledMeetings: "15",
115
+ attendanceRate: "65%",
116
+ completedClasses: "4",
117
+ classCompletionRate: "49%",
118
+ graduatedStudents: "29",
119
+ children: [],
120
+ // children: [
121
+ // {
122
+ // year: "2023",
123
+ // quarter: "Q1",
124
+ // month: null,
125
+ // day: null,
126
+ // newEnrollments: "2",
127
+ // scheduledMeetings: "35",
128
+ // attendanceRate: "32%",
129
+ // completedClasses: "15",
130
+ // classCompletionRate: "52%",
131
+ // graduatedStudents: "36",
132
+ // children: [
133
+ // {
134
+ // year: "2023",
135
+ // quarter: "Q1",
136
+ // month: "March",
137
+ // day: null,
138
+ // newEnrollments: "16",
139
+ // scheduledMeetings: "20",
140
+ // attendanceRate: "11%",
141
+ // completedClasses: "13",
142
+ // classCompletionRate: "47%",
143
+ // graduatedStudents: "28",
144
+ // children: [
145
+ // {
146
+ // year: "2023",
147
+ // quarter: "Q1",
148
+ // month: "March",
149
+ // day: "10",
150
+ // newEnrollments: "34",
151
+ // scheduledMeetings: "28",
152
+ // attendanceRate: "97%",
153
+ // completedClasses: "20",
154
+ // classCompletionRate: "15%",
155
+ // graduatedStudents: "17",
156
+ // },
157
+ // {
158
+ // year: "2023",
159
+ // quarter: "Q1",
160
+ // month: "March",
161
+ // day: "11",
162
+ // newEnrollments: "43",
163
+ // scheduledMeetings: "23",
164
+ // attendanceRate: "66%",
165
+ // completedClasses: "26",
166
+ // classCompletionRate: "47%",
167
+ // graduatedStudents: "9",
168
+ // },
169
+ // ],
170
+ // },
171
+ // {
172
+ // year: "2023",
173
+ // quarter: "Q1",
174
+ // month: "April",
175
+ // day: null,
176
+ // newEnrollments: "20",
177
+ // scheduledMeetings: "41",
178
+ // attendanceRate: "95%",
179
+ // completedClasses: "26",
180
+ // classCompletionRate: "83%",
181
+ // graduatedStudents: "43",
182
+ // children: [
183
+ // {
184
+ // year: "2023",
185
+ // quarter: "Q1",
186
+ // month: "April",
187
+ // day: "15",
188
+ // newEnrollments: "19",
189
+ // scheduledMeetings: "35",
190
+ // attendanceRate: "69%",
191
+ // completedClasses: "8",
192
+ // classCompletionRate: "75%",
193
+ // graduatedStudents: "23",
194
+ // },
195
+ // ],
196
+ // },
197
+ // ],
198
+ // },
199
+ // ],
200
+ },
201
+ ]
202
+
@@ -54,6 +54,7 @@ examples:
54
54
  - advanced_table_pagination_with_props: Pagination Props
55
55
  - advanced_table_loading: Loading State
56
56
  - advanced_table_inline_row_loading: Inline Row Loading
57
+ - advanced_table_inline_row_loading_show_toggle: Inline Row Loading with Show Toggle
57
58
  - advanced_table_column_headers: Multi-Header Columns
58
59
  - advanced_table_column_headers_multiple: Multi-Header Columns (Multiple Levels)
59
60
  - advanced_table_column_headers_custom_cell: Multi-Header Columns with Custom Cells
@@ -45,4 +45,5 @@ export { default as AdvancedTableWithCustomHeaderMultiHeader } from './_advanced
45
45
  export { default as AdvancedTableSortPerColumn } from './_advanced_table_sort_per_column.jsx'
46
46
  export { default as AdvancedTableSortPerColumnForMultiColumn } from './_advanced_table_sort_per_column_for_multi_column.jsx'
47
47
  export { default as AdvancedTablePaddingControl } from './_advanced_table_padding_control.jsx'
48
- export { default as AdvancedTablePaddingControlPerRow } from './_advanced_table_padding_control_per_row.jsx'
48
+ export { default as AdvancedTablePaddingControlPerRow } from './_advanced_table_padding_control_per_row.jsx'
49
+ export { default as AdvancedTableInlineRowLoadingShowToggle } from './_advanced_table_inline_row_loading_show_toggle.jsx'
@@ -331,8 +331,12 @@ export default class PbAdvancedTable extends PbEnhancedElement {
331
331
  // Split the dataContent to get all ancestor IDs, check against ExpandedRows
332
332
  const ancestorIds = dataContent.split("-").slice(0, -1);
333
333
 
334
+ // Get the table_id from the child row's parent to construct proper prefixed IDs
335
+ const parentRowId = childRow.dataset.rowParent;
336
+ const tableId = parentRowId ? parentRowId.split('_').slice(0, -1).join('_') : '';
337
+
334
338
  const prefixedAncestorIds = ancestorIds.map(
335
- (id) => `${childRow.id}_${id}`
339
+ (id) => `${tableId}_${id}`
336
340
  );
337
341
  const allAncestorsExpanded = prefixedAncestorIds.every((id) =>
338
342
  PbAdvancedTable.expandedRows.has(id)
@@ -3,8 +3,8 @@
3
3
  module Playbook
4
4
  module PbAdvancedTable
5
5
  class TableBody < Playbook::KitBase
6
- prop :id, type: Playbook::Props::String,
7
- default: ""
6
+ prop :table_id, type: Playbook::Props::String,
7
+ default: ""
8
8
  prop :table_data, type: Playbook::Props::Array,
9
9
  default: []
10
10
  prop :column_definitions, type: Playbook::Props::Array,
@@ -53,7 +53,7 @@ module Playbook
53
53
  subrow_data_attributes = {
54
54
  advanced_table_content: subrow_ancestor_ids.join("-"),
55
55
  row_depth: current_depth,
56
- row_parent: "#{id}_#{ancestor_ids.last}",
56
+ row_parent: "#{table_id}_#{ancestor_ids.last}",
57
57
  }
58
58
  # Subrow header if applicable
59
59
  output << pb_rails("advanced_table/table_subrow_header", props: { row: row, column_definitions: leaf_columns, depth: current_depth, subrow_header: subrow_headers[current_depth - 1], collapsible_trail: collapsible_trail, classname: "toggle-content", responsive: responsive, subrow_data_attributes: subrow_data_attributes, last_row: last_row, immediate_parent_row_id: immediate_parent_row_id }) if is_first_child_of_subrow && enable_toggle_expansion == "all"
@@ -69,7 +69,7 @@ module Playbook
69
69
  end
70
70
 
71
71
  # Additional class and data attributes needed for toggle logic
72
- output << pb_rails("advanced_table/table_row", props: { id: id, row: row, column_definitions: leaf_columns, depth: current_depth, collapsible_trail: collapsible_trail, classname: additional_classes, table_data_attributes: current_data_attributes, responsive: responsive, loading: loading, selectable_rows: selectable_rows, row_id: row[:id], enable_toggle_expansion: enable_toggle_expansion, row_styling: row_styling, last_row: last_row, immediate_parent_row_id: immediate_parent_row_id })
72
+ output << pb_rails("advanced_table/table_row", props: { table_id: table_id, row: row, column_definitions: leaf_columns, depth: current_depth, collapsible_trail: collapsible_trail, classname: additional_classes, table_data_attributes: current_data_attributes, responsive: responsive, loading: loading, selectable_rows: selectable_rows, row_id: row[:id], enable_toggle_expansion: enable_toggle_expansion, row_styling: row_styling, last_row: last_row, immediate_parent_row_id: immediate_parent_row_id })
73
73
 
74
74
  if row[:children].present?
75
75
  row[:children].each do |child_row|
@@ -78,9 +78,9 @@ module Playbook
78
78
  data_content = new_ancestor_ids.join("-") + "-#{child_row.object_id}"
79
79
 
80
80
  child_data_attributes = {
81
- top_parent: "#{id}_#{top_parent_id}",
81
+ top_parent: "#{table_id}_#{top_parent_id}",
82
82
  row_depth: current_depth + 1,
83
- row_parent: "#{id}_#{immediate_parent_id}",
83
+ row_parent: "#{table_id}_#{immediate_parent_id}",
84
84
  advanced_table_content: data_content,
85
85
  }
86
86