playbook_ui 13.20.0 → 13.21.0.pre.alpha.PBNTR224letuserresetrowexpansion2466

Sign up to get free protection for your applications and to get access to all the features.
Files changed (221) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/index.js +1 -1
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/CollapsibleTrail.tsx +6 -1
  4. data/app/pb_kits/playbook/pb_advanced_table/Components/CustomCell.tsx +23 -17
  5. data/app/pb_kits/playbook/pb_advanced_table/Components/SortIconButton.tsx +6 -3
  6. data/app/pb_kits/playbook/pb_advanced_table/Components/SubRowHeaderRow.tsx +12 -8
  7. data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +14 -9
  8. data/app/pb_kits/playbook/pb_advanced_table/Components/ToggleIconButton.tsx +9 -5
  9. data/app/pb_kits/playbook/pb_advanced_table/README.md +2 -2
  10. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableBody.tsx +16 -10
  11. data/app/pb_kits/playbook/pb_advanced_table/SubKits/TableHeader.tsx +14 -8
  12. data/app/pb_kits/playbook/pb_advanced_table/Utilities/ExpansionControlHelpers.tsx +3 -2
  13. data/app/pb_kits/playbook/pb_advanced_table/Utilities/types.ts +0 -2
  14. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +50 -7
  15. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +86 -78
  16. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +14 -0
  17. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +19 -0
  18. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +54 -54
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_collapsible_trail.jsx +7 -7
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.jsx +7 -7
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_expanded_control.jsx +12 -7
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_row_loading.jsx +7 -7
  23. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_row_loading.md +1 -1
  24. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_loading.jsx +7 -7
  25. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort.jsx +7 -7
  26. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sort_control.jsx +7 -7
  27. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_subrow_headers.jsx +7 -7
  28. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_options.jsx +7 -7
  29. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props.jsx +7 -7
  30. data/app/pb_kits/playbook/pb_advanced_table/docs/_mock_data.js +1 -1
  31. data/app/pb_kits/playbook/pb_advanced_table/docs/_mock_data_inline_loading.js +1 -1
  32. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -0
  33. data/app/pb_kits/playbook/pb_advanced_table/scss_partials/_chrome_styles.scss +13 -0
  34. data/app/pb_kits/playbook/pb_advanced_table/table_body.html.erb +9 -0
  35. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +30 -0
  36. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +20 -0
  37. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +21 -0
  38. data/app/pb_kits/playbook/pb_advanced_table/table_row.html.erb +37 -0
  39. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +32 -0
  40. data/app/pb_kits/playbook/pb_avatar/avatar.html.erb +2 -1
  41. data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.html.erb +2 -1
  42. data/app/pb_kits/playbook/pb_background/background.html.erb +2 -1
  43. data/app/pb_kits/playbook/pb_badge/badge.html.erb +2 -1
  44. data/app/pb_kits/playbook/pb_body/body.html.erb +2 -1
  45. data/app/pb_kits/playbook/pb_bread_crumbs/_bread_crumbs.scss +0 -7
  46. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +2 -1
  47. data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +2 -1
  48. data/app/pb_kits/playbook/pb_button/button.html.erb +2 -1
  49. data/app/pb_kits/playbook/pb_button/button.rb +2 -3
  50. data/app/pb_kits/playbook/pb_button_toolbar/button_toolbar.html.erb +2 -1
  51. data/app/pb_kits/playbook/pb_caption/caption.html.erb +2 -1
  52. data/app/pb_kits/playbook/pb_card/card.html.erb +2 -1
  53. data/app/pb_kits/playbook/pb_card/card_body.html.erb +2 -1
  54. data/app/pb_kits/playbook/pb_card/card_header.html.erb +2 -1
  55. data/app/pb_kits/playbook/pb_checkbox/checkbox.html.erb +3 -1
  56. data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.html.erb +2 -1
  57. data/app/pb_kits/playbook/pb_collapsible/collapsible.html.erb +2 -1
  58. data/app/pb_kits/playbook/pb_collapsible/collapsible_content.html.erb +2 -1
  59. data/app/pb_kits/playbook/pb_collapsible/collapsible_main.html.erb +2 -1
  60. data/app/pb_kits/playbook/pb_contact/contact.html.erb +2 -1
  61. data/app/pb_kits/playbook/pb_currency/currency.html.erb +2 -1
  62. data/app/pb_kits/playbook/pb_dashboard_value/dashboard_value.html.erb +2 -1
  63. data/app/pb_kits/playbook/pb_date/date.html.erb +2 -1
  64. data/app/pb_kits/playbook/pb_date/docs/_date_alignment_swift.md +26 -6
  65. data/app/pb_kits/playbook/pb_date/docs/_date_default_swift.md +27 -8
  66. data/app/pb_kits/playbook/pb_date_picker/_date_picker.scss +1 -2
  67. data/app/pb_kits/playbook/pb_date_picker/_date_picker.tsx +3 -0
  68. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +4 -2
  69. data/app/pb_kits/playbook/pb_date_picker/date_picker.rb +2 -1
  70. data/app/pb_kits/playbook/pb_date_picker/date_picker.test.js +1 -1
  71. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +9 -7
  72. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_margin_bottom.html.erb +7 -0
  73. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_margin_bottom.jsx +41 -0
  74. data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +2 -0
  75. data/app/pb_kits/playbook/pb_date_picker/docs/index.js +1 -0
  76. data/app/pb_kits/playbook/pb_date_picker/sass_partials/_input_styles.scss +1 -2
  77. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.html.erb +2 -1
  78. data/app/pb_kits/playbook/pb_date_range_stacked/date_range_stacked.html.erb +2 -1
  79. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +2 -1
  80. data/app/pb_kits/playbook/pb_date_time/date_time.html.erb +2 -1
  81. data/app/pb_kits/playbook/pb_date_time_stacked/date_time_stacked.html.erb +3 -2
  82. data/app/pb_kits/playbook/pb_date_year_stacked/date_year_stacked.html.erb +2 -1
  83. data/app/pb_kits/playbook/pb_detail/detail.html.erb +2 -1
  84. data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +2 -1
  85. data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +3 -2
  86. data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +2 -1
  87. data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +3 -2
  88. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +2 -1
  89. data/app/pb_kits/playbook/pb_filter/filter.html.erb +2 -1
  90. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.scss +8 -3
  91. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.tsx +1 -0
  92. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line.html.erb +51 -1
  93. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line.jsx +62 -11
  94. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_positions.html.erb +7 -2
  95. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/fixed_confirmation_toast.html.erb +4 -3
  96. data/app/pb_kits/playbook/pb_flex/docs/_flex_spacing.html.erb +0 -4
  97. data/app/pb_kits/playbook/pb_flex/flex.html.erb +2 -1
  98. data/app/pb_kits/playbook/pb_flex/flex_item.html.erb +2 -1
  99. data/app/pb_kits/playbook/pb_form_group/form_group.html.erb +2 -1
  100. data/app/pb_kits/playbook/pb_form_pill/form_pill.html.erb +2 -2
  101. data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +2 -1
  102. data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +2 -1
  103. data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +2 -1
  104. data/app/pb_kits/playbook/pb_icon/_icon.tsx +1 -0
  105. data/app/pb_kits/playbook/pb_icon/icon.html.erb +2 -1
  106. data/app/pb_kits/playbook/pb_icon/icon.rb +3 -3
  107. data/app/pb_kits/playbook/pb_icon_circle/icon_circle.html.erb +2 -1
  108. data/app/pb_kits/playbook/pb_icon_stat_value/icon_stat_value.html.erb +2 -1
  109. data/app/pb_kits/playbook/pb_icon_value/icon_value.html.erb +2 -1
  110. data/app/pb_kits/playbook/pb_image/image.html.erb +2 -1
  111. data/app/pb_kits/playbook/pb_label_pill/label_pill.html.erb +2 -1
  112. data/app/pb_kits/playbook/pb_label_value/label_value.html.erb +3 -2
  113. data/app/pb_kits/playbook/pb_layout/body.html.erb +2 -1
  114. data/app/pb_kits/playbook/pb_layout/footer.html.erb +2 -1
  115. data/app/pb_kits/playbook/pb_layout/header.html.erb +2 -1
  116. data/app/pb_kits/playbook/pb_layout/item.html.erb +2 -1
  117. data/app/pb_kits/playbook/pb_layout/layout.html.erb +2 -1
  118. data/app/pb_kits/playbook/pb_layout/sidebar.html.erb +2 -1
  119. data/app/pb_kits/playbook/pb_legend/legend.html.erb +2 -1
  120. data/app/pb_kits/playbook/pb_list/item.html.erb +2 -1
  121. data/app/pb_kits/playbook/pb_list/list.html.erb +2 -1
  122. data/app/pb_kits/playbook/pb_loading_inline/loading_inline.html.erb +2 -1
  123. data/app/pb_kits/playbook/pb_message/docs/_description.md +1 -1
  124. data/app/pb_kits/playbook/pb_message/message.html.erb +2 -1
  125. data/app/pb_kits/playbook/pb_message/message_mention.html.erb +3 -2
  126. data/app/pb_kits/playbook/pb_multi_level_select/multi_level_select.html.erb +2 -1
  127. data/app/pb_kits/playbook/pb_multiple_users/multiple_users.html.erb +2 -1
  128. data/app/pb_kits/playbook/pb_multiple_users_stacked/multiple_users_stacked.html.erb +2 -1
  129. data/app/pb_kits/playbook/pb_nav/_subtle_mixin.scss +4 -0
  130. data/app/pb_kits/playbook/pb_nav/item.html.erb +4 -2
  131. data/app/pb_kits/playbook/pb_nav/nav.html.erb +2 -1
  132. data/app/pb_kits/playbook/pb_online_status/online_status.html.erb +2 -1
  133. data/app/pb_kits/playbook/pb_pagination/pagination.html.erb +2 -1
  134. data/app/pb_kits/playbook/pb_passphrase/passphrase.html.erb +1 -1
  135. data/app/pb_kits/playbook/pb_person/person.html.erb +2 -1
  136. data/app/pb_kits/playbook/pb_person_contact/person_contact.html.erb +2 -1
  137. data/app/pb_kits/playbook/pb_pill/pill.html.erb +2 -1
  138. data/app/pb_kits/playbook/pb_popover/popover.html.erb +2 -1
  139. data/app/pb_kits/playbook/pb_progress_pills/progress_pills.html.erb +2 -1
  140. data/app/pb_kits/playbook/pb_progress_simple/progress_simple.html.erb +2 -1
  141. data/app/pb_kits/playbook/pb_progress_step/progress_step.html.erb +2 -1
  142. data/app/pb_kits/playbook/pb_progress_step/progress_step_item.html.erb +2 -1
  143. data/app/pb_kits/playbook/pb_radio/radio.html.erb +2 -1
  144. data/app/pb_kits/playbook/pb_section_separator/section_separator.html.erb +2 -1
  145. data/app/pb_kits/playbook/pb_select/select.html.erb +2 -1
  146. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +2 -1
  147. data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.html.erb +2 -1
  148. data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.html.erb +2 -1
  149. data/app/pb_kits/playbook/pb_selectable_list/selectable_list.html.erb +2 -1
  150. data/app/pb_kits/playbook/pb_selectable_list/selectable_list_item.html.erb +2 -1
  151. data/app/pb_kits/playbook/pb_source/source.html.erb +2 -1
  152. data/app/pb_kits/playbook/pb_star_rating/star_rating.html.erb +2 -1
  153. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +2 -1
  154. data/app/pb_kits/playbook/pb_stat_value/stat_value.html.erb +2 -1
  155. data/app/pb_kits/playbook/pb_table/_table.tsx +13 -0
  156. data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.jsx +24 -25
  157. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.jsx +47 -0
  158. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents.md +7 -0
  159. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.html.erb +34 -0
  160. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.jsx +48 -0
  161. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_as_divs.md +3 -0
  162. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.html.erb +34 -0
  163. data/app/pb_kits/playbook/pb_table/docs/_table_with_subcomponents_rails.md +7 -0
  164. data/app/pb_kits/playbook/pb_table/docs/example.yml +6 -2
  165. data/app/pb_kits/playbook/pb_table/docs/index.js +2 -0
  166. data/app/pb_kits/playbook/pb_table/styles/_striped.scss +2 -2
  167. data/app/pb_kits/playbook/pb_table/styles/_structure.scss +4 -2
  168. data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +64 -0
  169. data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +66 -0
  170. data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +64 -0
  171. data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +66 -0
  172. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +74 -0
  173. data/app/pb_kits/playbook/pb_table/subcomponents/index.tsx +5 -0
  174. data/app/pb_kits/playbook/pb_table/table.html.erb +4 -2
  175. data/app/pb_kits/playbook/pb_table/table.test.js +142 -1
  176. data/app/pb_kits/playbook/pb_table/table_body.html.erb +19 -0
  177. data/app/pb_kits/playbook/pb_table/table_body.rb +15 -0
  178. data/app/pb_kits/playbook/pb_table/table_cell.html.erb +19 -0
  179. data/app/pb_kits/playbook/pb_table/table_cell.rb +17 -0
  180. data/app/pb_kits/playbook/pb_table/table_head.html.erb +19 -0
  181. data/app/pb_kits/playbook/pb_table/table_head.rb +15 -0
  182. data/app/pb_kits/playbook/pb_table/table_header.html.erb +50 -38
  183. data/app/pb_kits/playbook/pb_table/table_header.rb +8 -1
  184. data/app/pb_kits/playbook/pb_table/table_row.html.erb +18 -6
  185. data/app/pb_kits/playbook/pb_table/table_row.rb +8 -1
  186. data/app/pb_kits/playbook/pb_text_input/_text_input.scss +0 -1
  187. data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +9 -5
  188. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_add_on.jsx +20 -0
  189. data/app/pb_kits/playbook/pb_text_input/text_input.html.erb +2 -1
  190. data/app/pb_kits/playbook/pb_text_input/text_input.rb +2 -1
  191. data/app/pb_kits/playbook/pb_textarea/textarea.html.erb +2 -1
  192. data/app/pb_kits/playbook/pb_time/time.html.erb +2 -1
  193. data/app/pb_kits/playbook/pb_time_range_inline/time_range_inline.html.erb +3 -2
  194. data/app/pb_kits/playbook/pb_time_stacked/time_stacked.html.erb +2 -1
  195. data/app/pb_kits/playbook/pb_timeline/item.html.erb +2 -1
  196. data/app/pb_kits/playbook/pb_timeline/timeline.html.erb +2 -1
  197. data/app/pb_kits/playbook/pb_timestamp/timestamp.html.erb +2 -1
  198. data/app/pb_kits/playbook/pb_title/title.html.erb +3 -2
  199. data/app/pb_kits/playbook/pb_title_count/title_count.html.erb +2 -1
  200. data/app/pb_kits/playbook/pb_title_detail/title_detail.html.erb +2 -1
  201. data/app/pb_kits/playbook/pb_toggle/toggle.html.erb +2 -1
  202. data/app/pb_kits/playbook/pb_tooltip/tooltip.html.erb +2 -1
  203. data/app/pb_kits/playbook/pb_typeahead/typeahead.html.erb +2 -1
  204. data/app/pb_kits/playbook/pb_user/docs/_user_presence_indicator_swift.md +30 -0
  205. data/app/pb_kits/playbook/pb_user/docs/_user_props_table.md +2 -1
  206. data/app/pb_kits/playbook/pb_user/docs/example.yml +1 -0
  207. data/app/pb_kits/playbook/pb_user/user.html.erb +2 -1
  208. data/app/pb_kits/playbook/pb_user_badge/user_badge.html.erb +2 -1
  209. data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.html.erb +2 -1
  210. data/app/pb_kits/playbook/utilities/_positioning.scss +48 -7
  211. data/app/pb_kits/playbook/utilities/globalProps.ts +23 -1
  212. data/dist/playbook-rails.js +6 -6
  213. data/lib/playbook/bottom.rb +33 -0
  214. data/lib/playbook/classnames.rb +4 -0
  215. data/lib/playbook/kit_base.rb +26 -0
  216. data/lib/playbook/left.rb +33 -0
  217. data/lib/playbook/right.rb +33 -0
  218. data/lib/playbook/top.rb +33 -0
  219. data/lib/playbook/version.rb +2 -2
  220. metadata +41 -7
  221. data/app/pb_kits/playbook/pb_table/_table_row.tsx +0 -47
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 89bd4e938528cafc5784b31a33e8164edd9b132e4f63f2ebbf2ba1160b07738f
4
- data.tar.gz: b87c8966e25b1b0b6fc2a01b84ae7164436a4f2be860f49c7414f667d1c5d40f
3
+ metadata.gz: cf18b9275cd75d7a727f6e7a3891cb3e5fba5872bc687e8abeafc44082d0d773
4
+ data.tar.gz: c24eacd44ea5c95620641bf9859fc3eec5bbe5f94556c475b2ba419f6084997a
5
5
  SHA512:
6
- metadata.gz: 7991e682deaf82d106bb0e2a29bb029a6299eba736a0c3e85de50366efa998db4f30026c9fcfc3cf4f7c2ac95f2fddaa38a90add59379d7c7b0890e070e8850a
7
- data.tar.gz: 6f649c427896f5010b9721ffd3a0e0c9f282f6eb6c65c666cdbd2487aab6132175a7660b7e48bc89cbe1133736ac4a79d9911f053bb481193096f6032220e6c9
6
+ metadata.gz: fb03d54205fa39f8c058cf7031a0b3264ca98bdf56ac13396761113154f3071380b5f36217ef514ba6daa4f8db2581161b25cc9ab73afa7b383cdf261f58a4f4
7
+ data.tar.gz: 535b35150645902fe5eb99fa49466bc31eb7a8ad4c7ea87a595406d33bb24b0ac42b56fa5c60aa4443e5fa4fb4af1e031acd2903ff43552e8216daec78264f50
@@ -93,7 +93,7 @@ export { default as StarRating } from './pb_star_rating/_star_rating'
93
93
  export { default as StatChange } from './pb_stat_change/_stat_change'
94
94
  export { default as StatValue } from './pb_stat_value/_stat_value'
95
95
  export { default as Table } from './pb_table/_table'
96
- export { default as TableRow } from './pb_table/_table_row'
96
+ export { default as TableRow } from './pb_table/subcomponents/_table_row'
97
97
  export { default as TextInput } from './pb_text_input/_text_input'
98
98
  export { default as Textarea } from './pb_textarea/_textarea'
99
99
  export { default as Time } from './pb_time/_time'
@@ -11,7 +11,12 @@ const CollapsibleTrail = ({ leftOffset }: { leftOffset: number }) => {
11
11
  backgroundColor: "#E4E8F0",
12
12
  }
13
13
 
14
- return <div style={style} />
14
+ return (
15
+ <div
16
+ className="collapsible-trail"
17
+ style={style}
18
+ />
19
+ )
15
20
  }
16
21
 
17
22
  // Updated function to render multiple trails depending on depth
@@ -1,19 +1,21 @@
1
- import React, { useContext } from "react";
1
+ import React, { useContext } from "react"
2
+ import { Getter, Row } from "@tanstack/react-table"
2
3
 
3
- import Flex from "../../pb_flex/_flex";
4
- import FlexItem from "../../pb_flex/_flex_item";
5
- import Icon from "../../pb_icon/_icon";
6
- import { GlobalProps } from "../../utilities/globalProps";
4
+ import { GenericObject } from "../../types"
7
5
 
8
- import { Getter, Row } from "@tanstack/react-table";
9
- import { DataType } from "../Utilities/types";
10
- import AdvancedTableContext from "../Context/AdvancedTableContext";
6
+ import { GlobalProps } from "../../utilities/globalProps"
7
+
8
+ import Flex from "../../pb_flex/_flex"
9
+ import FlexItem from "../../pb_flex/_flex_item"
10
+ import Icon from "../../pb_icon/_icon"
11
+
12
+ import AdvancedTableContext from "../Context/AdvancedTableContext"
11
13
 
12
14
  interface CustomCellProps {
13
- getValue?: Getter<string>;
14
- onRowToggleClick?: (arg: Row<DataType>) => void;
15
- row: Row<DataType>;
16
- value?: string;
15
+ getValue?: Getter<string>
16
+ onRowToggleClick?: (arg: Row<GenericObject>) => void
17
+ row: Row<GenericObject>
18
+ value?: string
17
19
  }
18
20
 
19
21
  export const CustomCell = ({
@@ -22,12 +24,16 @@ export const CustomCell = ({
22
24
  row,
23
25
  value,
24
26
  }: CustomCellProps & GlobalProps) => {
25
- const { setExpanded, expanded, inlineRowLoading } = useContext(AdvancedTableContext);
27
+ const { setExpanded, expanded, expandedControl, inlineRowLoading } = useContext(AdvancedTableContext);
26
28
 
27
- const handleOnExpand = (row: Row<DataType>) => {
29
+ const handleOnExpand = (row: Row<GenericObject>) => {
28
30
  onRowToggleClick && onRowToggleClick(row);
29
- setExpanded({ ...expanded, [row.id]: !row.getIsExpanded() });
31
+
32
+ if (!expandedControl) {
33
+ setExpanded({ ...expanded, [row.id]: !row.getIsExpanded() });
34
+ }
30
35
  };
36
+
31
37
  const RowHasChildren = row.original.children ? true : false
32
38
  const renderButton = inlineRowLoading ? RowHasChildren : row.getCanExpand()
33
39
 
@@ -59,5 +65,5 @@ export const CustomCell = ({
59
65
  </FlexItem>
60
66
  </Flex>
61
67
  </div>
62
- );
63
- };
68
+ )
69
+ }
@@ -1,11 +1,14 @@
1
1
  import React from "react"
2
- import Icon from "../../pb_icon/_icon"
3
2
  import { Header } from "@tanstack/react-table"
4
- import { DataType } from "../Utilities/types"
3
+
4
+ import { GenericObject } from "../../types"
5
+
6
+ import Icon from "../../pb_icon/_icon"
7
+
5
8
  import { displayIcon } from "../Utilities/IconHelpers"
6
9
 
7
10
  type SortIconButtonProps = {
8
- header: Header<DataType, unknown>
11
+ header: Header<GenericObject, unknown>
9
12
  sortIcon?: string | string[]
10
13
  }
11
14
  export const SortIconButton = ({ header, sortIcon }: SortIconButtonProps) => {
@@ -1,23 +1,27 @@
1
1
  import React, { useContext } from "react"
2
+ import { Row, Table } from "@tanstack/react-table"
3
+
4
+ import { GenericObject } from "../../types"
5
+
6
+ import { GlobalProps } from "../../utilities/globalProps"
7
+
2
8
  import Flex from "../../pb_flex/_flex"
3
9
  import Caption from "../../pb_caption/_caption"
4
- import { Row, Table } from "@tanstack/react-table"
5
10
 
6
- import AdvancedTableContext from "../Context/AdvancedTableContext";
7
11
  import { ToggleIconButton } from "./ToggleIconButton"
8
12
  import { renderCollapsibleTrail } from "./CollapsibleTrail"
9
13
 
10
14
  import { isChrome } from "../Utilities/BrowserCheck"
11
- import { DataType } from "../Utilities/types"
12
- import { GlobalProps } from "../../utilities/globalProps"
15
+
16
+ import AdvancedTableContext from "../Context/AdvancedTableContext"
13
17
 
14
18
  interface SubRowHeaderRowProps {
15
19
  collapsibleTrail?: boolean
16
20
  enableToggleExpansion?: "all" | "header" | "none"
17
- onClick: (row: Row<DataType>) => void
18
- row: Row<DataType>
21
+ onClick: (row: Row<GenericObject>) => void
22
+ row: Row<GenericObject>
19
23
  subRowHeaders?: string[]
20
- table: Table<DataType>
24
+ table: Table<GenericObject>
21
25
  }
22
26
 
23
27
  export const SubRowHeaderRow = ({
@@ -28,7 +32,7 @@ export const SubRowHeaderRow = ({
28
32
  subRowHeaders,
29
33
  table,
30
34
  }: SubRowHeaderRowProps & GlobalProps) => {
31
- const { inlineRowLoading } = useContext(AdvancedTableContext);
35
+ const { inlineRowLoading } = useContext(AdvancedTableContext)
32
36
 
33
37
  const numberOfColumns = table.getAllFlatColumns().length
34
38
  const rowHasChildren = row.original.children ? true : false
@@ -1,20 +1,25 @@
1
1
  import React, { useContext } from "react"
2
- import classnames from "classnames";
3
- import Flex from "../../pb_flex/_flex"
2
+ import classnames from "classnames"
4
3
  import { flexRender, Header } from "@tanstack/react-table"
5
4
 
5
+ import { GenericObject } from "../../types"
6
+
7
+ import { GlobalProps } from "../../utilities/globalProps"
8
+
9
+ import Flex from "../../pb_flex/_flex"
10
+
6
11
  import { SortIconButton } from "./SortIconButton"
7
12
  import { ToggleIconButton } from "./ToggleIconButton"
13
+
8
14
  import { isChrome } from "../Utilities/BrowserCheck"
9
- import { DataType } from "../Utilities/types"
15
+
10
16
  import AdvancedTableContext from "../Context/AdvancedTableContext"
11
- import { GlobalProps } from "../../utilities/globalProps"
12
17
 
13
18
  type TableHeaderCellProps = {
14
19
  enableSorting?: boolean
15
20
  enableToggleExpansion?: "all" | "header" | "none"
16
21
  handleExpandOrCollapse?: () => void
17
- header?: Header<DataType, unknown>
22
+ header?: Header<GenericObject, unknown>
18
23
  headerChildren?: React.ReactNode | React.ReactNode[]
19
24
  loading?: boolean
20
25
  sortIcon?: string | string[]
@@ -45,24 +50,24 @@ export const TableHeaderCell = ({
45
50
  const cellClassName = classnames("table-header-cells",
46
51
  `${isChrome() ? "chrome-styles" : ""}`,
47
52
  `${enableSorting ? "table-header-cells-active" : ""}`
48
- );
53
+ )
49
54
 
50
55
  const cellId = `${loading ?
51
56
  `loading-${header.id}`
52
57
  : `${header.id}`
53
- }`;
58
+ }`
54
59
 
55
60
  const isToggleExpansionEnabledLoading =
56
61
  header.index === 0 &&
57
62
  loading &&
58
63
  (enableToggleExpansion === "all" || "header") &&
59
- enableToggleExpansion !== "none";
64
+ enableToggleExpansion !== "none"
60
65
 
61
66
  const isToggleExpansionEnabled =
62
67
  header.index === 0 &&
63
68
  !loading &&
64
69
  (enableToggleExpansion === "all" || "header") &&
65
- enableToggleExpansion !== "none";
70
+ enableToggleExpansion !== "none"
66
71
 
67
72
  return (
68
73
  <th
@@ -1,13 +1,17 @@
1
1
  import React, { useContext } from "react"
2
- import Icon from "../../pb_icon/_icon"
3
2
  import { Row } from "@tanstack/react-table"
4
- import AdvancedTableContext from "../Context/AdvancedTableContext"
5
- import { DataType } from "../Utilities/types"
3
+
4
+ import { GenericObject } from "../../types"
5
+
6
+ import Icon from "../../pb_icon/_icon"
7
+
6
8
  import { displayIcon } from "../Utilities/IconHelpers"
7
9
 
10
+ import AdvancedTableContext from "../Context/AdvancedTableContext"
11
+
8
12
  interface ToggleIconButtonProps {
9
- onClick: (row: Row<DataType>) => void
10
- row?: Row<DataType>
13
+ onClick: (row: Row<GenericObject>) => void
14
+ row?: Row<GenericObject>
11
15
  }
12
16
 
13
17
  export const ToggleIconButton = ({ row, onClick }: ToggleIconButtonProps) => {
@@ -81,7 +81,7 @@ const MOCK_DATA = [
81
81
  graduatedStudents: "43",
82
82
  children: [
83
83
  {
84
- year: "2011",
84
+ year: "2021",
85
85
  quarter: "Q1",
86
86
  month: "February",
87
87
  day: "15",
@@ -173,7 +173,7 @@ const MOCK_DATA = [
173
173
  graduatedStudents: "43",
174
174
  children: [
175
175
  {
176
- year: "2011",
176
+ year: "2022",
177
177
  quarter: "Q1",
178
178
  month: "May",
179
179
  day: "2",
@@ -1,27 +1,33 @@
1
1
  import React, { useContext } from "react"
2
- import classnames from "classnames";
3
- import { buildCss } from "../../utilities/props";
4
- import { globalProps } from "../../utilities/globalProps";
5
- import LoadingInline from "../../pb_loading_inline/_loading_inline"
2
+ import classnames from "classnames"
6
3
  import { flexRender, Row } from "@tanstack/react-table"
7
4
 
5
+ import { GenericObject } from "../../types"
6
+
7
+ import { buildCss } from "../../utilities/props"
8
+ import { globalProps } from "../../utilities/globalProps"
9
+ import { isChrome } from "../Utilities/BrowserCheck"
10
+
11
+ import LoadingInline from "../../pb_loading_inline/_loading_inline"
12
+
8
13
  import { SubRowHeaderRow } from "../Components/SubRowHeaderRow"
9
14
  import { LoadingCell } from "../Components/LoadingCell"
10
15
  import { renderCollapsibleTrail } from "../Components/CollapsibleTrail"
16
+
11
17
  import AdvancedTableContext from "../Context/AdvancedTableContext"
12
- import { isChrome } from "../Utilities/BrowserCheck"
13
- import { DataType } from "../Utilities/types"
14
18
 
15
19
  type TableBodyProps = {
16
- className?: string;
20
+ className?: string
17
21
  collapsibleTrail?: boolean
18
- id?: string;
22
+ dark?: boolean
23
+ id?: string
19
24
  subRowHeaders?: string[]
20
25
  }
21
26
 
22
27
  export const TableBody = ({
23
28
  className,
24
29
  collapsibleTrail = true,
30
+ dark = false,
25
31
  id,
26
32
  subRowHeaders,
27
33
  ...props
@@ -40,14 +46,14 @@ export const TableBody = ({
40
46
  buildCss("pb_advanced_table_body"),
41
47
  globalProps(props),
42
48
  className
43
- );
49
+ )
44
50
 
45
51
  return (
46
52
  <>
47
53
  <tbody className={classes}
48
54
  id={id}
49
55
  >
50
- {table.getRowModel().rows.map((row: Row<DataType>) => {
56
+ {table.getRowModel().rows.map((row: Row<GenericObject>) => {
51
57
  const isExpandable = row.getIsExpanded()
52
58
  const isFirstChildofSubrow = row.depth > 0 && row.index === 0
53
59
  const rowHasNoChildren = row.original.children && !row.original.children.length ? true : false
@@ -1,23 +1,29 @@
1
1
  import React, { useContext } from "react"
2
- import classnames from "classnames";
3
- import { buildCss } from "../../utilities/props";
4
- import { globalProps } from "../../utilities/globalProps";
2
+ import classnames from "classnames"
5
3
  import { HeaderGroup } from "@tanstack/react-table"
6
- import AdvancedTableContext from "../Context/AdvancedTableContext"
4
+
5
+ import { GenericObject } from "../../types"
6
+
7
+ import { buildCss } from "../../utilities/props"
8
+ import { globalProps } from "../../utilities/globalProps"
9
+
7
10
  import { TableHeaderCell } from "../Components/TableHeaderCell"
8
- import { DataType } from "../Utilities/types"
11
+
12
+ import AdvancedTableContext from "../Context/AdvancedTableContext"
9
13
 
10
14
  type TableHeaderProps = {
11
15
  children?: React.ReactNode | React.ReactNode[]
12
16
  className?: string
17
+ dark?: boolean,
13
18
  enableSorting?: boolean
14
- id?: string;
19
+ id?: string
15
20
  sortIcon?: string | string[]
16
21
  }
17
22
 
18
23
  export const TableHeader = ({
19
24
  children,
20
25
  className,
26
+ dark = false,
21
27
  enableSorting = false,
22
28
  id,
23
29
  sortIcon = ["arrow-up-short-wide", "arrow-down-short-wide"],
@@ -34,7 +40,7 @@ export const TableHeader = ({
34
40
  buildCss("pb_advanced_table_header"),
35
41
  globalProps(props),
36
42
  className
37
- );
43
+ )
38
44
 
39
45
 
40
46
  return (
@@ -43,7 +49,7 @@ export const TableHeader = ({
43
49
  id={id}
44
50
  >
45
51
  {/* Get the header groups (only one in this example) */}
46
- {table.getHeaderGroups().map((headerGroup: HeaderGroup<DataType>) => (
52
+ {table.getHeaderGroups().map((headerGroup: HeaderGroup<GenericObject>) => (
47
53
  <tr key={`${headerGroup.id}-headerGroup`}>
48
54
  {headerGroup.headers.map(header => (
49
55
  <TableHeaderCell
@@ -1,5 +1,6 @@
1
1
  import { RowModel } from "@tanstack/react-table"
2
- import { DataType, ExpandedStateObject } from "./types"
2
+ import { ExpandedStateObject } from "./types"
3
+ import { GenericObject } from "../../types"
3
4
 
4
5
  const filterExpandableRows = (expandedState: Record<string, boolean>) => {
5
6
  for (const expandedRow in expandedState) {
@@ -11,7 +12,7 @@ const filterExpandableRows = (expandedState: Record<string, boolean>) => {
11
12
  }
12
13
 
13
14
  export const updateExpandAndCollapseState = (
14
- tableRows: RowModel<DataType>,
15
+ tableRows: RowModel<GenericObject>,
15
16
  expanded: Record<string, boolean>,
16
17
  targetParent: string
17
18
  ) => {
@@ -4,5 +4,3 @@ export type ExpandedStateObject = Extract<
4
4
  ExpandedState,
5
5
  Record<string, boolean>
6
6
  >
7
-
8
- export type DataType = { [key: string]: any }
@@ -4,6 +4,7 @@
4
4
  @import "../tokens/spacing";
5
5
  @import "./scss_partials/loading";
6
6
  @import "./scss_partials/pseudo_states";
7
+ @import "./scss_partials/chrome_styles";
7
8
 
8
9
  .pb_advanced_table {
9
10
  $border-color: 1px solid $border_light !important;
@@ -82,17 +83,59 @@
82
83
 
83
84
  // Vertical separator
84
85
  .table-header-cells:first-child,
85
- td:first-child {
86
- box-shadow: 1px 0px 0px 0px #e4e8f0 !important;
86
+ td:first-child,
87
+ .pb_table_td:first-child {
88
+ box-shadow: 1px 0px 0px 0px $border_light !important;
87
89
  }
88
90
 
89
- .chrome-styles:first-child {
90
- border-right: $border-color;
91
+ @include chrome_styles($border-color);
92
+
93
+ tr:hover {
94
+ position: relative;
91
95
  }
92
96
 
93
- .table-card {
94
- .chrome-styles:first-child {
95
- border-right: $transparent !important;
97
+ &.dark {
98
+ .bg-white {
99
+ background: $bg_dark_card;
100
+ }
101
+
102
+ .bg-silver {
103
+ background: $bg_dark;
104
+ }
105
+
106
+ .table-header-cells:first-child, td:first-child {
107
+ box-shadow: 1px 0px 0px 0px $border_dark !important;
108
+ }
109
+
110
+ .collapsible-trail {
111
+ background-color: $border_dark !important;
112
+ }
113
+
114
+ .sort-button-icon, .header-sort-button > div {
115
+ color: $white !important;
116
+ }
117
+
118
+ .gray-icon {
119
+ color: $text_dk_light !important;
120
+ }
121
+
122
+ .sticky-header {
123
+ background-color: $bg_dark_card;
124
+ }
125
+
126
+ .loading-toggle-icon,
127
+ .loading-cell {
128
+ &::after {
129
+ background-color: $bg_dark !important;
130
+ background-image: linear-gradient(
131
+ to left,
132
+ $bg_dark 0%,
133
+ lighten($bg_dark, 1%) 50%,
134
+ lighten($bg_dark, 2%) 60%,
135
+ $bg_dark 80%,
136
+ $bg_dark 100%
137
+ ) !important;
138
+ }
96
139
  }
97
140
  }
98
141
  }