playbook_ui 14.14.0.pre.rc.5 → 14.15.0.pre.alpha.PBNTR617addgriddisplayglobalprop6700

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 (206) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +127 -0
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/TableActionBar.tsx +55 -0
  4. data/app/pb_kits/playbook/pb_advanced_table/Components/TablePagination.tsx +33 -0
  5. data/app/pb_kits/playbook/pb_advanced_table/Components/VirtualizedTableView.tsx +275 -0
  6. data/app/pb_kits/playbook/pb_advanced_table/Context/AdvancedTableContext.tsx +143 -3
  7. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableActions.ts +66 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +195 -0
  9. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +45 -99
  10. data/app/pb_kits/playbook/pb_advanced_table/Utilities/CellRendererUtils.tsx +73 -0
  11. data/app/pb_kits/playbook/pb_advanced_table/Utilities/RowUtils.ts +52 -0
  12. data/app/pb_kits/playbook/pb_advanced_table/Utilities/TableContainerStyles.ts +80 -0
  13. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +133 -7
  14. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +153 -298
  15. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +8 -1
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_headers_custom_cell.jsx +75 -0
  17. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.jsx +50 -0
  18. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_editing.jsx +102 -0
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_editing.md +4 -0
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props.html.erb +1 -1
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_rails.md +3 -1
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_react.md +1 -1
  23. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header.html.erb +33 -0
  24. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +3 -0
  25. data/app/pb_kits/playbook/pb_advanced_table/docs/advanced_table_mock_data_infinite_scroll.json +152002 -0
  26. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +4 -1
  27. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +3 -1
  28. data/app/pb_kits/playbook/pb_card/_card.tsx +2 -1
  29. data/app/pb_kits/playbook/pb_checkbox/_checkbox.tsx +17 -8
  30. data/app/pb_kits/playbook/pb_checkbox/checkbox.test.js +16 -0
  31. data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_react_hook.jsx +69 -0
  32. data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_react_hook.md +1 -0
  33. data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +2 -1
  34. data/app/pb_kits/playbook/pb_checkbox/docs/index.js +1 -0
  35. data/app/pb_kits/playbook/pb_currency/_currency.tsx +46 -31
  36. data/app/pb_kits/playbook/pb_currency/currency.html.erb +15 -8
  37. data/app/pb_kits/playbook/pb_currency/currency.rb +17 -2
  38. data/app/pb_kits/playbook/pb_currency/docs/_currency_null_display.html.erb +22 -0
  39. data/app/pb_kits/playbook/pb_currency/docs/_currency_null_display.jsx +34 -0
  40. data/app/pb_kits/playbook/pb_currency/docs/_currency_null_display_rails.md +1 -0
  41. data/app/pb_kits/playbook/pb_currency/docs/_currency_null_display_react.md +1 -0
  42. data/app/pb_kits/playbook/pb_currency/docs/example.yml +2 -0
  43. data/app/pb_kits/playbook/pb_currency/docs/index.js +2 -1
  44. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +4 -1
  45. data/app/pb_kits/playbook/pb_date_picker/date_picker.rb +2 -0
  46. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_hooks.md +3 -1
  47. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_on_change.html.erb +39 -0
  48. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_on_close.html.erb +39 -0
  49. data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +2 -0
  50. data/app/pb_kits/playbook/pb_date_picker/index.ts +38 -0
  51. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +5 -6
  52. data/app/pb_kits/playbook/pb_dialog/dialogHelper.js +2 -0
  53. data/app/pb_kits/playbook/pb_dialog/index.js +75 -0
  54. data/app/pb_kits/playbook/pb_drawer/_drawer.scss +43 -3
  55. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_behavior.html.erb +8 -0
  56. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.html.erb +33 -0
  57. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_borders.jsx +3 -3
  58. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.html.erb +0 -0
  59. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_breakpoints.jsx +20 -37
  60. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_default.html.erb +20 -1
  61. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.html.erb +24 -0
  62. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_menu.jsx +6 -6
  63. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.html.erb +21 -0
  64. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.jsx +1 -0
  65. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_overlay.md +1 -0
  66. data/app/pb_kits/playbook/pb_drawer/docs/_drawer_sizes.html.erb +49 -0
  67. data/app/pb_kits/playbook/pb_drawer/docs/example.yml +6 -0
  68. data/app/pb_kits/playbook/pb_drawer/drawer.html.erb +20 -12
  69. data/app/pb_kits/playbook/pb_drawer/drawer.rb +49 -1
  70. data/app/pb_kits/playbook/pb_drawer/index.js +257 -0
  71. data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.tsx +5 -4
  72. data/app/pb_kits/playbook/pb_filter/Filter/FilterSingle.tsx +2 -2
  73. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +2 -1
  74. data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +4 -3
  75. data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +9 -2
  76. data/app/pb_kits/playbook/pb_form_pill/_form_pill.tsx +4 -0
  77. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_wrapped.html.erb +40 -0
  78. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_wrapped.jsx +50 -0
  79. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_wrapped.md +3 -0
  80. data/app/pb_kits/playbook/pb_form_pill/docs/example.yml +2 -0
  81. data/app/pb_kits/playbook/pb_form_pill/docs/index.js +1 -0
  82. data/app/pb_kits/playbook/pb_form_pill/form_pill.rb +7 -1
  83. data/app/pb_kits/playbook/pb_icon_button/_icon_button.tsx +71 -0
  84. data/app/pb_kits/playbook/pb_icon_button/docs/_icon_button_default.jsx +17 -0
  85. data/app/pb_kits/playbook/pb_icon_button/docs/_icon_button_sizes.jsx +61 -0
  86. data/app/pb_kits/playbook/pb_icon_button/docs/example.yml +4 -0
  87. data/app/pb_kits/playbook/pb_icon_button/docs/index.js +2 -0
  88. data/app/pb_kits/playbook/pb_icon_button/icon_button.html.erb +1 -1
  89. data/app/pb_kits/playbook/pb_icon_button/icon_button.test.jsx +39 -0
  90. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.scss +7 -0
  91. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +45 -8
  92. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.html.erb +72 -0
  93. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.jsx +91 -0
  94. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.jsx +91 -0
  95. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.md +1 -0
  96. data/app/pb_kits/playbook/pb_multi_level_select/docs/example.yml +3 -1
  97. data/app/pb_kits/playbook/pb_multi_level_select/docs/index.js +2 -0
  98. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.rb +7 -1
  99. data/app/pb_kits/playbook/pb_overlay/_overlay.scss +13 -0
  100. data/app/pb_kits/playbook/pb_overlay/_overlay.tsx +11 -1
  101. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.html.erb +11 -0
  102. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar.jsx +37 -0
  103. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_rails.md +1 -0
  104. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_hide_scroll_bar_react.md +1 -0
  105. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.html.erb +11 -0
  106. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.jsx +37 -0
  107. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.md +1 -0
  108. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional_react.md +1 -0
  109. data/app/pb_kits/playbook/pb_overlay/docs/example.yml +4 -0
  110. data/app/pb_kits/playbook/pb_overlay/docs/index.js +2 -0
  111. data/app/pb_kits/playbook/pb_overlay/index.js +61 -0
  112. data/app/pb_kits/playbook/pb_overlay/overlay.html.erb +5 -3
  113. data/app/pb_kits/playbook/pb_overlay/overlay.rb +16 -1
  114. data/app/pb_kits/playbook/pb_overlay/overlay.test.jsx +12 -0
  115. data/app/pb_kits/playbook/pb_overlay/subcomponents/_overlay_token.tsx +48 -10
  116. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +6 -0
  117. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_default.html.erb +1 -1
  118. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_hidden_inputs.html.erb +5 -0
  119. data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_hidden_inputs.md +1 -0
  120. data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +3 -1
  121. data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +3 -0
  122. data/app/pb_kits/playbook/pb_popover/_popover.tsx +2 -2
  123. data/app/pb_kits/playbook/pb_popover/popover.test.js +1 -1
  124. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +1 -6
  125. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +1 -5
  126. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +1 -5
  127. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +3 -7
  128. data/app/pb_kits/playbook/pb_radio/_radio.tsx +85 -74
  129. data/app/pb_kits/playbook/pb_radio/docs/_radio_react_hook.jsx +60 -0
  130. data/app/pb_kits/playbook/pb_radio/docs/_radio_react_hook.md +1 -0
  131. data/app/pb_kits/playbook/pb_radio/docs/example.yml +2 -1
  132. data/app/pb_kits/playbook/pb_radio/docs/index.js +1 -0
  133. data/app/pb_kits/playbook/pb_radio/radio.html.erb +6 -11
  134. data/app/pb_kits/playbook/pb_radio/radio.test.js +16 -0
  135. data/app/pb_kits/playbook/pb_select/docs/_select_react_hook.jsx +58 -0
  136. data/app/pb_kits/playbook/pb_select/docs/_select_react_hook.md +1 -0
  137. data/app/pb_kits/playbook/pb_select/docs/example.yml +1 -0
  138. data/app/pb_kits/playbook/pb_select/docs/index.js +1 -0
  139. data/app/pb_kits/playbook/pb_select/index.js +38 -0
  140. data/app/pb_kits/playbook/pb_select/select.html.erb +3 -5
  141. data/app/pb_kits/playbook/pb_select/select.rb +8 -0
  142. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +1 -5
  143. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +1 -4
  144. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +1 -5
  145. data/app/pb_kits/playbook/pb_text_input/inputMask.ts +2 -3
  146. data/app/pb_kits/playbook/pb_timeline/_timeline.scss +2 -2
  147. data/app/pb_kits/playbook/pb_title/_title.scss +32 -0
  148. data/app/pb_kits/playbook/pb_title/_title.tsx +10 -1
  149. data/app/pb_kits/playbook/pb_title/docs/_title_default.html.erb +1 -2
  150. data/app/pb_kits/playbook/pb_title/docs/_title_default.jsx +1 -1
  151. data/app/pb_kits/playbook/pb_title/docs/_title_display_size.html.erb +7 -0
  152. data/app/pb_kits/playbook/pb_title/docs/_title_display_size.jsx +54 -0
  153. data/app/pb_kits/playbook/pb_title/docs/_title_display_size.md +1 -0
  154. data/app/pb_kits/playbook/pb_title/docs/example.yml +2 -0
  155. data/app/pb_kits/playbook/pb_title/docs/index.js +1 -0
  156. data/app/pb_kits/playbook/pb_title/title.rb +10 -1
  157. data/app/pb_kits/playbook/pb_tooltip/_tooltip.scss +0 -3
  158. data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +25 -0
  159. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.html.erb +39 -0
  160. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_delay_rails.md +3 -0
  161. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_icon_rails.html.erb +22 -0
  162. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_interaction.html.erb +26 -0
  163. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_sizing.jsx +69 -0
  164. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_sizing.md +3 -0
  165. data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +4 -1
  166. data/app/pb_kits/playbook/pb_tooltip/docs/index.js +1 -0
  167. data/app/pb_kits/playbook/pb_tooltip/floating_ui.js +282 -0
  168. data/app/pb_kits/playbook/pb_tooltip/index.js +2 -2
  169. data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +10 -2
  170. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +51 -5
  171. data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +5 -1
  172. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.html.erb +45 -0
  173. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options.md +5 -0
  174. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.html.erb +33 -0
  175. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_dynamic_options_pure_rails.md +3 -0
  176. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_react_hook.jsx +66 -0
  177. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_react_hook.md +1 -0
  178. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_custom_options.jsx +1 -1
  179. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async_users.jsx +1 -1
  180. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +3 -0
  181. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  182. data/app/pb_kits/playbook/pb_typeahead/index.ts +61 -8
  183. data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +17 -2
  184. data/app/pb_kits/playbook/tokens/_display.scss +3 -1
  185. data/app/pb_kits/playbook/utilities/_display.scss +6 -1
  186. data/app/pb_kits/playbook/utilities/object.test.js +99 -0
  187. data/app/pb_kits/playbook/utilities/object.ts +29 -1
  188. data/app/pb_kits/playbook/utilities/test/globalProps/display.test.js +1 -1
  189. data/dist/chunks/_typeahead-B8f4HM8I.js +36 -0
  190. data/dist/chunks/_weekday_stacked-BVO5G6au.js +45 -0
  191. data/dist/chunks/{lib-D3us1bGD.js → lib-5OzNgeeu.js} +2 -2
  192. data/dist/chunks/{pb_form_validation-BpihMSOQ.js → pb_form_validation-DGhKbZtO.js} +1 -1
  193. data/dist/chunks/vendor.js +1 -1
  194. data/dist/menu.yml +4 -4
  195. data/dist/playbook-doc.js +1 -1
  196. data/dist/playbook-rails-react-bindings.js +1 -1
  197. data/dist/playbook-rails.js +1 -1
  198. data/dist/playbook.css +1 -1
  199. data/lib/playbook/display.rb +2 -2
  200. data/lib/playbook/forms/builder/time_zone_select_field.rb +19 -0
  201. data/lib/playbook/forms/builder.rb +1 -0
  202. data/lib/playbook/version.rb +2 -2
  203. metadata +86 -7
  204. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_icon.erb +0 -10
  205. data/dist/chunks/_typeahead-CAIQfP7X.js +0 -36
  206. data/dist/chunks/_weekday_stacked-DstwbGUv.js +0 -45
@@ -0,0 +1,102 @@
1
+ import React, { useState } from "react";
2
+ import { AdvancedTable, TextInput, Body } from "playbook-ui";
3
+ import MOCK_DATA from "./advanced_table_mock_data.json";
4
+
5
+ const AdvancedTableInlineEditing = (props) => {
6
+ const [editedValues, setEditedValues] = useState({});
7
+
8
+ const EditableCell = ({ rowId, originalValue, onSave }) => {
9
+ const [localValue, setLocalValue] = useState(originalValue);
10
+
11
+ const handleChange = (e) => setLocalValue(e.target.value);
12
+
13
+ const handleBlur = () => {
14
+ originalValue !== localValue && onSave(rowId, localValue);
15
+ };
16
+
17
+ return (
18
+ <TextInput inline
19
+ marginBottom="none"
20
+ {...props}
21
+ >
22
+ <input
23
+ onBlur={handleBlur}
24
+ onChange={handleChange}
25
+ onKeyDown={(e) => e.key === 'Enter' && handleBlur()}
26
+ value={localValue}
27
+ />
28
+ </TextInput>
29
+ );
30
+ };
31
+
32
+ const columnDefinitions = [
33
+ {
34
+ accessor: "year",
35
+ label: "Year",
36
+ cellAccessors: ["quarter", "month", "day"],
37
+ },
38
+ {
39
+ accessor: "newEnrollments",
40
+ label: "New Enrollments",
41
+ },
42
+ {
43
+ accessor: "scheduledMeetings",
44
+ label: "Scheduled Meetings",
45
+ editable: true,
46
+ customRenderer: (row) => {
47
+ return (
48
+ <EditableCell
49
+ onSave={(id, val) => {
50
+ setEditedValues((prev) => ({ ...prev, [id]: val }));
51
+ }}
52
+ originalValue={
53
+ editedValues[row.id] ?? row.original.scheduledMeetings
54
+ }
55
+ rowId={row.id}
56
+ />
57
+ );
58
+ },
59
+ },
60
+ {
61
+ accessor: "attendanceRate",
62
+ label: "Attendance Rate",
63
+ },
64
+ {
65
+ accessor: "completedClasses",
66
+ label: "Completed Classes",
67
+ },
68
+ {
69
+ accessor: "classCompletionRate",
70
+ label: "Class Completion Rate",
71
+ },
72
+ {
73
+ accessor: "graduatedStudents",
74
+ label: "Graduated Students",
75
+ },
76
+ ];
77
+
78
+ return (
79
+ <div className="App">
80
+ <AdvancedTable
81
+ columnDefinitions={columnDefinitions}
82
+ tableData={MOCK_DATA}
83
+ {...props}
84
+ />
85
+ {
86
+ editedValues && Object.keys(editedValues).length > 0 && (
87
+ <>
88
+ <Body
89
+ marginTop="md"
90
+ {...props}
91
+ >
92
+ Edited Values by Row Id:
93
+ </Body>
94
+ <pre style={{color: 'white'}}>{JSON.stringify(editedValues, null, 2)}</pre>
95
+ </>
96
+ )
97
+ }
98
+ </div>
99
+ );
100
+ };
101
+
102
+ export default AdvancedTableInlineEditing;
@@ -0,0 +1,4 @@
1
+ Inline Cell Editing can be achieved with a combination of our `TextInput` kit and the `customRenderer` method available through columnDefinitions.
2
+
3
+ Hover over any cell within the 'Scheduled Meetings' column to see the TextInput and type in to change values. Values can be saved by clicking away from the TextInput or by hitting 'Enter'.
4
+ See the code snippet below to see how this was achieved. Devs must manage state themselves as shown.
@@ -30,4 +30,4 @@
30
30
  }
31
31
  ] %>
32
32
 
33
- <%= pb_rails("advanced_table", props: { id: "table_props_table", table_data: @table_data, column_definitions: column_definitions, table_props: { container: false, sticky: true }}) %>
33
+ <%= pb_rails("advanced_table", props: { id: "table_props_table", table_data: @table_data, column_definitions: column_definitions, responsive: "none", table_props: { container: false, sticky: true }}) %>
@@ -1 +1,3 @@
1
- This kit uses the [Table kit](https://playbook.powerapp.cloud/kits/table) under the hood which comes with it's own set of props. If you want to apply certain Table props to that underlying kit, you can do so by using the optional `table_props` prop. This prop must be an object that contains valid Table props. For a full list of Table props, see [here](https://playbook.powerapp.cloud/kits/table).
1
+ This kit uses the [Table kit](https://playbook.powerapp.cloud/kits/table) under the hood which comes with its own set of props. If you want to apply certain Table props to that underlying kit, you can do so by using the optional `table_props` prop. This prop must be an object that contains valid Table props. For a full list of Table props, see [here](https://playbook.powerapp.cloud/kits/table).
2
+
3
+ This doc example showcases how to set a sticky header for a nonresponsive table. To achieve sticky header AND responsive functionality, see the ["Table Props Sticky Header"](https://playbook.powerapp.cloud/kits/advanced_table#table-props-sticky-header) doc example below.
@@ -1,3 +1,3 @@
1
- This kit uses the [Table kit](https://playbook.powerapp.cloud/kits/table/react) under the hood which comes with it's own set of props. If you want to apply certain Table props to that underlying kit, you can do so by using the optional `tableProps` prop. This prop must be an object that contains valid Table props. For a full list of Table props, see [here](https://playbook.powerapp.cloud/kits/table/react).
1
+ This kit uses the [Table kit](https://playbook.powerapp.cloud/kits/table/react) under the hood which comes with its own set of props. If you want to apply certain Table props to that underlying kit, you can do so by using the optional `tableProps` prop. This prop must be an object that contains valid Table props. For a full list of Table props, see [here](https://playbook.powerapp.cloud/kits/table/react).
2
2
 
3
3
  This doc example showcases how to set a sticky header for a nonresponsive table. To achieve sticky header AND responsive functionality, see the ["Table Props Sticky Header"](https://playbook.powerapp.cloud/kits/advanced_table/react#table-props-sticky-header) doc example below.
@@ -0,0 +1,33 @@
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: "table_props_table", table_data: @table_data, column_definitions: column_definitions, max_height: "xs", table_props: { sticky: true }}) %>
@@ -0,0 +1,3 @@
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/visual_guidelines/max_height) global prop. 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.
2
+
3
+ A sticky header on a nonresponsive table is demonstrated in the ["Table Props"](https://playbook.powerapp.cloud/kits/advanced_table#table-props) doc example above.