playbook_ui 15.4.0.pre.alpha.testingseparation12413 → 15.4.0.pre.rc.0

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 (243) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +1 -2
  3. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +0 -15
  4. data/app/pb_kits/playbook/pb_advanced_table/Utilities/RowUtils.ts +1 -1
  5. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +4 -4
  6. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.test.jsx +5 -68
  7. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.html.erb +0 -4
  8. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_background_control_rails.md +1 -1
  9. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color.md +1 -1
  10. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_border_color_rails.md +1 -1
  11. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.jsx +1 -4
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling.md +0 -2
  13. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_column_headers.jsx +1 -1
  14. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.html.erb +0 -1
  15. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_styling_rails.md +0 -2
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_fullscreen.jsx +1 -3
  17. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_infinite_scroll.jsx +1 -1
  18. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_inline_editing.jsx +1 -3
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.jsx +1 -9
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_padding_control.md +1 -1
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination_with_props.jsx +1 -4
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_pagination_with_props.md +2 -3
  23. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_row_styling.jsx +1 -2
  24. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_sticky_columns_and_header.md +1 -1
  25. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_rails.md +1 -1
  26. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_table_props_sticky_header_react.md +1 -1
  27. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header.jsx +0 -16
  28. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_rails.html.erb +1 -1
  29. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +0 -1
  30. data/app/pb_kits/playbook/pb_advanced_table/flat_advanced_table.js +2 -2
  31. data/app/pb_kits/playbook/pb_advanced_table/index.js +7 -7
  32. data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +2 -2
  33. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +20 -90
  34. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +3 -32
  35. data/app/pb_kits/playbook/pb_background/background.html.erb +2 -10
  36. data/app/pb_kits/playbook/pb_background/docs/_background_category.md +1 -1
  37. data/app/pb_kits/playbook/pb_badge/_badge.tsx +1 -4
  38. data/app/pb_kits/playbook/pb_badge/badge.test.js +0 -13
  39. data/app/pb_kits/playbook/pb_card/docs/_card_background.md +1 -1
  40. data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
  41. data/app/pb_kits/playbook/pb_card/docs/_card_highlight.md +1 -1
  42. data/app/pb_kits/playbook/pb_card/docs/_card_light.md +1 -1
  43. data/app/pb_kits/playbook/pb_currency/_currency.tsx +7 -20
  44. data/app/pb_kits/playbook/pb_currency/currency.rb +8 -35
  45. data/app/pb_kits/playbook/pb_currency/currency.test.js +0 -47
  46. data/app/pb_kits/playbook/pb_currency/docs/_currency_negative.html.erb +0 -10
  47. data/app/pb_kits/playbook/pb_currency/docs/_currency_negative.jsx +0 -10
  48. data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.html.erb +1 -8
  49. data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.jsx +1 -8
  50. data/app/pb_kits/playbook/pb_currency/docs/_description.md +2 -2
  51. data/app/pb_kits/playbook/pb_date_picker/date_picker.html.erb +11 -25
  52. data/app/pb_kits/playbook/pb_date_picker/date_picker.rb +0 -2
  53. data/app/pb_kits/playbook/pb_date_picker/date_picker_helper.ts +7 -60
  54. data/app/pb_kits/playbook/pb_date_picker/docs/example.yml +1 -2
  55. data/app/pb_kits/playbook/pb_date_picker/docs/index.js +1 -2
  56. data/app/pb_kits/playbook/pb_date_range_inline/_date_range_inline.tsx +13 -20
  57. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.rb +4 -6
  58. data/app/pb_kits/playbook/pb_date_range_inline/date_range_inline.test.js +0 -17
  59. data/app/pb_kits/playbook/pb_date_range_inline/docs/_description.md +1 -1
  60. data/app/pb_kits/playbook/pb_date_range_inline/docs/example.yml +2 -3
  61. data/app/pb_kits/playbook/pb_date_range_inline/docs/index.js +0 -1
  62. data/app/pb_kits/playbook/pb_date_stacked/_date_stacked.tsx +4 -6
  63. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.html.erb +3 -2
  64. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.rb +5 -11
  65. data/app/pb_kits/playbook/pb_date_stacked/date_stacked.test.js +9 -26
  66. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_default.html.erb +1 -1
  67. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_default.jsx +1 -1
  68. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_not_current_year.html.erb +5 -0
  69. data/app/pb_kits/playbook/pb_date_stacked/docs/{_date_stacked_current_year.jsx → _date_stacked_not_current_year.jsx} +5 -6
  70. data/app/pb_kits/playbook/pb_date_stacked/docs/_description.md +1 -1
  71. data/app/pb_kits/playbook/pb_date_stacked/docs/example.yml +2 -2
  72. data/app/pb_kits/playbook/pb_date_stacked/docs/index.js +1 -1
  73. data/app/pb_kits/playbook/pb_dialog/docs/_dialog_compound_components.html.erb +2 -2
  74. data/app/pb_kits/playbook/pb_distribution_bar/docs/_distribution_bar_custom_colors.md +1 -1
  75. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +0 -1
  76. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +6 -111
  77. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_active_style_options_react.md +1 -1
  78. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +0 -5
  79. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +1 -5
  80. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +2 -148
  81. data/app/pb_kits/playbook/pb_dropdown/index.js +1 -1
  82. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_alignment.jsx +1 -2
  83. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_default.jsx +1 -2
  84. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_orientation.jsx +1 -2
  85. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_size.jsx +1 -2
  86. data/app/pb_kits/playbook/pb_filter/docs/_filter_max_width.md +1 -1
  87. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.tsx +9 -31
  88. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_auto_close.html.erb +1 -15
  89. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line.html.erb +8 -9
  90. data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_positions.html.erb +10 -11
  91. data/app/pb_kits/playbook/pb_flex/_flex_item.tsx +5 -12
  92. data/app/pb_kits/playbook/pb_flex/docs/_flex_item_example.jsx +0 -1
  93. data/app/pb_kits/playbook/pb_form/pb_form_validation.js +11 -44
  94. data/app/pb_kits/playbook/pb_form_pill/_form_pill.tsx +1 -1
  95. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_rails.md +1 -1
  96. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_truncated_text_react.md +1 -1
  97. data/app/pb_kits/playbook/pb_form_pill/docs/_form_pill_wrapped.jsx +1 -4
  98. data/app/pb_kits/playbook/pb_icon/docs/_icon_color.md +1 -1
  99. data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color.md +1 -1
  100. data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.html.erb +14 -7
  101. data/app/pb_kits/playbook/pb_icon_stat_value/docs/_icon_stat_value_color.jsx +15 -6
  102. data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.md +1 -1
  103. data/app/pb_kits/playbook/pb_loading_inline/docs/_loading_inline_variant.jsx +1 -1
  104. data/app/pb_kits/playbook/pb_nav/_item.tsx +4 -18
  105. data/app/pb_kits/playbook/pb_nav/_nav.scss +5 -30
  106. data/app/pb_kits/playbook/pb_nav/_nav_item.test.js +0 -192
  107. data/app/pb_kits/playbook/pb_nav/_vertical_nav.scss +1 -1
  108. data/app/pb_kits/playbook/pb_nav/docs/_collapsible_nav_item_spacing.md +1 -1
  109. data/app/pb_kits/playbook/pb_nav/docs/_nav_with_spacing_control.md +1 -1
  110. data/app/pb_kits/playbook/pb_nav/docs/example.yml +0 -4
  111. data/app/pb_kits/playbook/pb_nav/docs/index.js +1 -3
  112. data/app/pb_kits/playbook/pb_nav/item.html.erb +4 -6
  113. data/app/pb_kits/playbook/pb_nav/item.rb +2 -11
  114. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_layout.md +1 -1
  115. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_description.md +1 -3
  116. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_colors.jsx +1 -1
  117. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_default.jsx +1 -1
  118. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_height.jsx +1 -1
  119. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_horizontal.jsx +1 -1
  120. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_legend.jsx +1 -1
  121. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_legend_non_clickable.jsx +2 -1
  122. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_legend_position.html.erb +1 -1
  123. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_legend_position.jsx +1 -1
  124. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_negative_numbers.jsx +1 -1
  125. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_secondary_y_axis.jsx +1 -1
  126. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_spline.jsx +2 -1
  127. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_stacked.jsx +2 -1
  128. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_description.md +1 -3
  129. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_block_content.jsx +1 -2
  130. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_color_overrides.jsx +1 -2
  131. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_custom_tooltip.jsx +1 -1
  132. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_custom_tooltip.md +1 -2
  133. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_data_legend_position.jsx +1 -2
  134. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_data_with_labels.jsx +1 -1
  135. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_data_with_legend.jsx +1 -1
  136. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_default.jsx +1 -1
  137. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_inner_sizes.jsx +1 -1
  138. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_live_data.jsx +1 -2
  139. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_rounded.jsx +1 -1
  140. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_with_title.jsx +1 -1
  141. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_description.md +1 -3
  142. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_color.jsx +1 -1
  143. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_color.md +2 -2
  144. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_complex.jsx +1 -2
  145. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_full_circle.jsx +1 -2
  146. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_height.jsx +1 -2
  147. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_min_max.jsx +1 -2
  148. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_units.jsx +1 -2
  149. data/app/pb_kits/playbook/pb_pb_line_graph/docs/_description.md +1 -3
  150. data/app/pb_kits/playbook/pb_pb_line_graph/docs/_pb_line_graph_colors.jsx +1 -1
  151. data/app/pb_kits/playbook/pb_pb_line_graph/docs/_pb_line_graph_legend_position.html.erb +1 -1
  152. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.tsx +17 -110
  153. data/app/pb_kits/playbook/pb_pill/docs/_description.md +1 -1
  154. data/app/pb_kits/playbook/pb_popover/_popover.tsx +34 -69
  155. data/app/pb_kits/playbook/pb_popover/docs/example.yml +0 -1
  156. data/app/pb_kits/playbook/pb_popover/docs/index.js +0 -1
  157. data/app/pb_kits/playbook/pb_popover/popover.test.js +0 -80
  158. data/app/pb_kits/playbook/pb_radio/docs/_radio_react_hook.jsx +1 -3
  159. data/app/pb_kits/playbook/pb_rich_text_editor/docs/_description.md +1 -1
  160. data/app/pb_kits/playbook/pb_section_separator/docs/_description.md +1 -1
  161. data/app/pb_kits/playbook/pb_select/docs/_select_react_hook.jsx +1 -3
  162. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +0 -29
  163. data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_rails.md +1 -1
  164. data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_border_radius_react.md +1 -1
  165. data/app/pb_kits/playbook/pb_skeleton_loading/docs/_skeleton_loading_layout.md +1 -1
  166. data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.md +1 -1
  167. data/app/pb_kits/playbook/pb_table/docs/_table_sm.md +1 -1
  168. data/app/pb_kits/playbook/pb_table/docs/example.yml +0 -2
  169. data/app/pb_kits/playbook/pb_table/docs/index.js +0 -1
  170. data/app/pb_kits/playbook/pb_text_input/text_input.rb +2 -2
  171. data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_sizing.jsx +1 -4
  172. data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +0 -7
  173. data/app/pb_kits/playbook/pb_typeahead/_typeahead.test.jsx +1 -105
  174. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +9 -23
  175. data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +1 -33
  176. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_options.html.erb +1 -67
  177. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_default_value.jsx +6 -68
  178. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_react_hook.jsx +1 -2
  179. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_truncated_text.md +1 -1
  180. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +0 -2
  181. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -2
  182. data/app/pb_kits/playbook/pb_user/docs/_user_font_options.jsx +1 -1
  183. data/dist/chunks/_line_graph-h5H-imfn.js +1 -0
  184. data/dist/chunks/_typeahead-U8AjZIIW.js +6 -0
  185. data/dist/chunks/_weekday_stacked-c6_R08J-.js +37 -0
  186. data/dist/chunks/componentRegistry-DzmmLR2x.js +1 -0
  187. data/dist/chunks/lib-CGxXTQ75.js +29 -0
  188. data/dist/chunks/pb_form_validation-DebqlUKZ.js +1 -0
  189. data/dist/chunks/vendor.js +1 -37
  190. data/dist/playbook-doc.js +19 -0
  191. data/dist/playbook-rails-react-bindings.js +1 -1
  192. data/dist/playbook-rails.js +1 -1
  193. data/dist/playbook.css +1 -1
  194. data/lib/playbook/version.rb +2 -2
  195. metadata +12 -51
  196. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.html.erb +0 -104
  197. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header_multi_header_rails.md +0 -1
  198. data/app/pb_kits/playbook/pb_currency/docs/_currency_abbreviated.md +0 -1
  199. data/app/pb_kits/playbook/pb_currency/docs/_currency_matching_decimals_rails.md +0 -1
  200. data/app/pb_kits/playbook/pb_currency/docs/_currency_matching_decimals_react.md +0 -1
  201. data/app/pb_kits/playbook/pb_currency/docs/_currency_negative.md +0 -1
  202. data/app/pb_kits/playbook/pb_currency/docs/_currency_no_symbol_rails.md +0 -1
  203. data/app/pb_kits/playbook/pb_currency/docs/_currency_no_symbol_react.md +0 -1
  204. data/app/pb_kits/playbook/pb_currency/docs/_currency_variants.md +0 -1
  205. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.jsx +0 -38
  206. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_and_dropdown_range.md +0 -14
  207. data/app/pb_kits/playbook/pb_date_range_inline/docs/_date_range_inline_show_current_year.html.erb +0 -4
  208. data/app/pb_kits/playbook/pb_date_range_inline/docs/_date_range_inline_show_current_year.jsx +0 -43
  209. data/app/pb_kits/playbook/pb_date_range_inline/docs/_date_range_inline_show_current_year.md +0 -1
  210. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_current_year.html.erb +0 -12
  211. data/app/pb_kits/playbook/pb_date_stacked/docs/_date_stacked_current_year.md +0 -1
  212. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.jsx +0 -18
  213. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick.md +0 -4
  214. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.jsx +0 -18
  215. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_default_dates.md +0 -1
  216. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.jsx +0 -19
  217. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_range_end.md +0 -1
  218. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.jsx +0 -38
  219. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_quickpick_with_date_pickers.md +0 -14
  220. data/app/pb_kits/playbook/pb_dropdown/quickpick/index.ts +0 -60
  221. data/app/pb_kits/playbook/pb_nav/docs/_horizontal_nav_disabled.html.erb +0 -21
  222. data/app/pb_kits/playbook/pb_nav/docs/_horizontal_nav_disabled.jsx +0 -113
  223. data/app/pb_kits/playbook/pb_nav/docs/_horizontal_nav_disabled.md +0 -1
  224. data/app/pb_kits/playbook/pb_nav/docs/_vertical_nav_disabled.html.erb +0 -30
  225. data/app/pb_kits/playbook/pb_nav/docs/_vertical_nav_disabled.jsx +0 -117
  226. data/app/pb_kits/playbook/pb_nav/docs/_vertical_nav_disabled.md +0 -1
  227. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_default.md +0 -1
  228. data/app/pb_kits/playbook/pb_pb_bar_graph/docs/_pb_bar_graph_legend_position.md +0 -11
  229. data/app/pb_kits/playbook/pb_pb_circle_chart/docs/_pb_circle_chart_default.md +0 -1
  230. data/app/pb_kits/playbook/pb_pb_gauge_chart/docs/_pb_gauge_chart_default.md +0 -1
  231. data/app/pb_kits/playbook/pb_pb_line_graph/docs/_pb_line_graph_default.md +0 -1
  232. data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to.jsx +0 -71
  233. data/app/pb_kits/playbook/pb_popover/docs/_popover_append_to_react.md +0 -1
  234. data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.html.erb +0 -63
  235. data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible.jsx +0 -89
  236. data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_rails.md +0 -4
  237. data/app/pb_kits/playbook/pb_table/docs/_table_with_dynamic_collapsible_react.md +0 -3
  238. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.html.erb +0 -64
  239. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.jsx +0 -70
  240. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_options.md +0 -1
  241. data/dist/chunks/_typeahead-BUTLC28y.js +0 -6
  242. data/dist/chunks/lib-CgpqUb6l.js +0 -29
  243. /data/app/pb_kits/playbook/pb_popover/docs/{_popover_append_to_rails.md → _popover_append_to.md} +0 -0
@@ -1,7 +1,7 @@
1
1
  <%= pb_rails("button", props: { text: "Open Complex Dialog", data:{"open-dialog": "dialog-complex"} }) %>
2
2
 
3
3
  <%= pb_rails("dialog", props: { id:"dialog-complex", size: "lg", full_height: true }) do %>
4
- <%= pb_form_with(scope: :example, method: :get, url: "", options: { remote: true }) do |form| %>
4
+ <form>
5
5
  <%= pb_rails("dialog/dialog_header", props: { id: "dialog-complex" } ) do %>
6
6
  <%= pb_rails("body", props: { text: "What do you need us to take care of?" }) %>
7
7
  <% end %>
@@ -13,5 +13,5 @@
13
13
 
14
14
  <% end %>
15
15
  <%= pb_rails("dialog/dialog_footer", props: {cancel_button: "Back", confirm_button: "Send my Issue", confirm_button_id:"confirm-complex", id: "dialog-complex"}) %>
16
- <% end %>
16
+ </form>
17
17
  <% end %>
@@ -1 +1 @@
1
- You can customize the order of the colors you would like to use by using the `colors` prop. Only the data and status colors will work for Playbook charts. See the [design page](https://playbook.powerapp.cloud/token/colors) for reference.
1
+ You can customize the order of the colors you would like to use by using the `colors` prop. Only the data and status colors will work for Playbook charts. See the [design page](/visual_guidelines) for reference.
@@ -12,7 +12,6 @@
12
12
 
13
13
  .pb_dropdown_default,
14
14
  .pb_dropdown_subtle,
15
- .pb_dropdown_quickpick,
16
15
  .pb_dropdown_default_separators_hidden,
17
16
  .pb_dropdown_subtle_separators_hidden {
18
17
  .dropdown_wrapper {
@@ -12,7 +12,6 @@ import DropdownContext from "./context";
12
12
  import DropdownOption from "./subcomponents/DropdownOption";
13
13
  import DropdownTrigger from "./subcomponents/DropdownTrigger";
14
14
  import useDropdown from "./hooks/useDropdown";
15
- import getQuickPickOptions from "./quickpick";
16
15
 
17
16
  import {
18
17
  separateChildComponents,
@@ -37,12 +36,9 @@ type DropdownProps = {
37
36
  label?: string;
38
37
  multiSelect?: boolean;
39
38
  onSelect?: (arg: GenericObject) => null;
40
- options?: GenericObject;
39
+ options: GenericObject;
41
40
  separators?: boolean;
42
- variant?: "default" | "subtle" | "quickpick";
43
- rangeEndsToday?: boolean;
44
- controlsStartId?: string;
45
- controlsEndId?: string;
41
+ variant?: "default" | "subtle";
46
42
  activeStyle?: {
47
43
  backgroundColor?: string;
48
44
  fontColor?: string;
@@ -75,9 +71,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
75
71
  formPillProps,
76
72
  onSelect,
77
73
  options,
78
- rangeEndsToday = false,
79
- controlsStartId,
80
- controlsEndId,
81
74
  separators = true,
82
75
  variant = "default",
83
76
  activeStyle,
@@ -92,25 +85,11 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
92
85
  globalProps(props),
93
86
  className
94
87
  );
95
- // ------------- Quick Pick ---------------------------------
96
- // Use QuickPick options when variant is "quickpick"
97
- const dropdownOptions = variant === "quickpick"
98
- ? getQuickPickOptions(rangeEndsToday)
99
- : (options || []);
100
- // ----------------------------------------------------------
101
88
 
102
89
  const [isDropDownClosed, setIsDropDownClosed, toggleDropdown] = useDropdown(isClosed);
103
90
 
104
91
  const [filterItem, setFilterItem] = useState("");
105
92
  const initialSelected = useMemo(() => {
106
- // Handle quickpick variant with string defaultValue (e.g., "This Month")
107
- if (variant === "quickpick" && typeof defaultValue === "string" && defaultValue) {
108
- const matchedOption = dropdownOptions.find(
109
- (opt: GenericObject) => opt.label?.toLowerCase() === (defaultValue as string).toLowerCase()
110
- );
111
- return matchedOption || {};
112
- }
113
-
114
93
  if (multiSelect) {
115
94
  if (Array.isArray(defaultValue)) return defaultValue;
116
95
  return defaultValue && Object.keys(defaultValue).length
@@ -118,7 +97,7 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
118
97
  : [];
119
98
  }
120
99
  return defaultValue || {};
121
- }, [multiSelect, defaultValue, variant, dropdownOptions]);
100
+ }, [multiSelect, defaultValue]);
122
101
 
123
102
  const [selected, setSelected] = useState<GenericObject | GenericObject[]>(
124
103
  initialSelected
@@ -172,7 +151,7 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
172
151
  }, [isClosed])
173
152
 
174
153
  const blankSelectionOption: GenericObject = blankSelection ? [{ label: blankSelection, value: "" }] : [];
175
- const optionsWithBlankSelection = blankSelectionOption.concat(dropdownOptions);
154
+ const optionsWithBlankSelection = blankSelectionOption.concat(options);
176
155
 
177
156
  const availableOptions = useMemo(()=> {
178
157
  if (!multiSelect) return optionsWithBlankSelection;
@@ -224,21 +203,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
224
203
  setFilterItem("");
225
204
  setIsDropDownClosed(true);
226
205
  onSelect && onSelect(clickedItem);
227
-
228
- // Sync with DatePickers if this is a quickpick variant
229
- if (variant === "quickpick" && Array.isArray(clickedItem.value)) {
230
- const [start, end] = clickedItem.value;
231
-
232
- if (controlsStartId) {
233
- const startPicker = (document.querySelector(`#${controlsStartId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
234
- startPicker?.setDate(start, true);
235
- }
236
-
237
- if (controlsEndId) {
238
- const endPicker = (document.querySelector(`#${controlsEndId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
239
- endPicker?.setDate(end, true);
240
- }
241
- }
242
206
  }
243
207
  };
244
208
 
@@ -255,19 +219,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
255
219
  setSelected({});
256
220
  onSelect && onSelect(null);
257
221
  setFocusedOptionIndex(-1);
258
-
259
- // Clear linked DatePickers as well if this is a quickpick variant with controls
260
- if (variant === "quickpick") {
261
- if (controlsStartId) {
262
- const startPicker = (document.querySelector(`#${controlsStartId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
263
- startPicker?.clear();
264
- }
265
-
266
- if (controlsEndId) {
267
- const endPicker = (document.querySelector(`#${controlsEndId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
268
- endPicker?.clear();
269
- }
270
- }
271
222
  }
272
223
  };
273
224
 
@@ -281,8 +232,7 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
281
232
  dark
282
233
  });
283
234
 
284
- // Create an internal ref object that holds the imperative handle methods
285
- const imperativeRef = useRef({
235
+ useImperativeHandle(ref, () => ({
286
236
  clearSelected: () => {
287
237
  if (multiSelect) {
288
238
  setSelected([]);
@@ -294,61 +244,7 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
294
244
  setFilterItem("");
295
245
  setIsDropDownClosed(true);
296
246
  },
297
- });
298
-
299
- // Update imperativeRef whenever dependencies change
300
- // (needed for external clearing of normal Dropdown + DatePicker-synced QuickPick Dropdown)
301
- useEffect(() => {
302
- imperativeRef.current = {
303
- clearSelected: () => {
304
- if (multiSelect) {
305
- setSelected([]);
306
- onSelect && onSelect([]);
307
- } else {
308
- setSelected({});
309
- onSelect && onSelect(null);
310
- }
311
- setFilterItem("");
312
- setIsDropDownClosed(true);
313
- },
314
- };
315
- }, [multiSelect, onSelect, setSelected, setFilterItem, setIsDropDownClosed]);
316
-
317
- useImperativeHandle(ref, () => imperativeRef.current);
318
-
319
- // Create a ref to the outer div to attach the dropdown ref for DatePicker sync
320
- const outerDivRef = useRef<HTMLDivElement>(null);
321
-
322
- useEffect(() => {
323
- // Attach the ref to the DOM element so DatePicker can access it
324
- if (outerDivRef.current && variant === "quickpick" && id) {
325
- (outerDivRef.current as any)._dropdownRef = imperativeRef;
326
- }
327
- }, [variant, id]);
328
-
329
- // Sync defaultValue with DatePickers on mount when 3 input pattern is used
330
- useEffect(() => {
331
- if (variant === "quickpick" && initialSelected && typeof initialSelected === "object" && !Array.isArray(initialSelected)) {
332
- const value = initialSelected.value;
333
-
334
- if (Array.isArray(value) && value.length === 2) {
335
- const [start, end] = value;
336
-
337
- // Wait for DatePickers to be initialized
338
- setTimeout(() => {
339
- if (controlsStartId) {
340
- const startPicker = (document.querySelector(`#${controlsStartId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
341
- startPicker?.setDate(start, true);
342
- }
343
-
344
- if (controlsEndId) {
345
- const endPicker = (document.querySelector(`#${controlsEndId}`) as HTMLElement & { _flatpickr?: any })?._flatpickr;
346
- endPicker?.setDate(end, true);
347
- }
348
- }, 0);
349
- }
350
- }
351
- }, [variant, initialSelected, controlsStartId, controlsEndId]);
247
+ }));
352
248
 
353
249
  return (
354
250
  <div {...ariaProps}
@@ -356,7 +252,6 @@ let Dropdown = (props: DropdownProps, ref: any): React.ReactElement | null => {
356
252
  {...htmlProps}
357
253
  className={classes}
358
254
  id={id}
359
- ref={outerDivRef}
360
255
  style={{position: "relative"}}
361
256
  >
362
257
  <DropdownContext.Provider
@@ -1,4 +1,4 @@
1
1
  The `activeStyle` prop can be used to customize the appearance of the dropdown selection indicator. It accepts an object with the following keys: `backgroundColor` sets the background color of the selected item (and its hover state); `fontColor` sets the font color of the selected item.
2
2
 
3
3
  `backgroundColor` **Type**: String | **Values**: bg_light | white | **Default**: (no selection) is primary
4
- `fontColor` **Type**: String | **Values**: primary | all [Playbook Text Colors](https://playbook.powerapp.cloud/global_props/colors) | **Default**: (no selection) is white
4
+ `fontColor` **Type**: String | **Values**: primary | all [Playbook Text Colors](https://playbook.powerapp.cloud/visual_guidelines/colors) | **Default**: (no selection) is white
@@ -49,9 +49,4 @@ examples:
49
49
  - dropdown_clear_selection: Clear Selection
50
50
  - dropdown_separators_hidden: Separators Hidden
51
51
  - dropdown_with_external_control: useDropdown Hook
52
- - dropdown_quickpick: Quick Pick Variant
53
- - dropdown_quickpick_range_end: Quick Pick Variant (Range Ends Today)
54
- - dropdown_quickpick_default_dates: Quick Pick Variant (Default Dates)
55
- - dropdown_quickpick_with_date_pickers: Quick Pick Variant with Date Pickers
56
-
57
52
 
@@ -22,8 +22,4 @@ export { default as DropdownMultiSelectWithDefault } from './_dropdown_multi_sel
22
22
  export { default as DropdownMultiSelectWithCustomOptions } from './_dropdown_multi_select_with_custom_options.jsx'
23
23
  export {default as DropdownWithCustomIconOptions} from './_dropdown_with_custom_icon_options.jsx'
24
24
  export {default as DropdownWithCustomRadioOptions} from './_dropdown_with_custom_radio_options.jsx'
25
- export {default as DropdownWithCustomActiveStyleOptions} from './_dropdown_with_custom_active_style_options.jsx'
26
- export { default as DropdownQuickpick } from './_dropdown_quickpick.jsx'
27
- export { default as DropdownQuickpickRangeEnd } from './_dropdown_quickpick_range_end.jsx'
28
- export { default as DropdownQuickpickDefaultDates } from './_dropdown_quickpick_default_dates.jsx'
29
- export { default as DropdownQuickpickWithDatePickers } from './_dropdown_quickpick_with_date_pickers.jsx'
25
+ export {default as DropdownWithCustomActiveStyleOptions} from './_dropdown_with_custom_active_style_options.jsx'
@@ -1,4 +1,4 @@
1
- import React, { useState } from "react"
1
+ import React from "react"
2
2
  import { render, screen, fireEvent } from "../utilities/test-utils"
3
3
 
4
4
  import { Dropdown, Icon, IconCircle } from 'playbook-ui'
@@ -393,150 +393,4 @@ test("applies activeStyle backgroundColor and fontColor when selected", () => {
393
393
  expect(selected).toBeInTheDocument()
394
394
  expect(selected).toHaveClass("bg-bg_light")
395
395
  expect(selected).toHaveClass("font-primary")
396
- })
397
-
398
- test("renders quickpick variant with auto-generated options", () => {
399
- render(
400
- <Dropdown
401
- data={{ testid: testId }}
402
- variant="quickpick"
403
- />
404
- )
405
-
406
- const kit = screen.getByTestId(testId)
407
- expect(kit).toHaveClass('pb_dropdown_quickpick')
408
-
409
- // Check that quickpick options are generated
410
- const options = kit.querySelectorAll('.pb_dropdown_option_list')
411
- expect(options.length).toBe(10)
412
- expect(options[0]).toHaveTextContent("Today")
413
- })
414
-
415
- test("quickpick variant accepts string defaultValue", () => {
416
- render(
417
- <Dropdown
418
- data={{ testid: testId }}
419
- defaultValue="This Month"
420
- variant="quickpick"
421
- />
422
- )
423
-
424
- const kit = screen.getByTestId(testId)
425
- const trigger = kit.querySelector('.pb_dropdown_trigger')
426
-
427
- expect(trigger).toHaveTextContent("This Month")
428
- })
429
-
430
- test("quickpick attaches _dropdownRef to DOM element when id is provided", () => {
431
- render(
432
- <Dropdown
433
- data={{ testid: testId }}
434
- id="test-quickpick"
435
- variant="quickpick"
436
- />
437
- )
438
-
439
- const kit = screen.getByTestId(testId)
440
-
441
- // Check that the element has the _dropdownRef attached
442
- expect(kit._dropdownRef).toBeDefined()
443
- expect(kit._dropdownRef.current).toBeDefined()
444
- expect(kit._dropdownRef.current.clearSelected).toBeDefined()
445
- })
446
-
447
- test("quickpick clears selection when clicking X icon", () => {
448
- render(
449
- <Dropdown
450
- data={{ testid: testId }}
451
- defaultValue="This Week"
452
- variant="quickpick"
453
- />
454
- )
455
-
456
- const kit = screen.getByTestId(testId)
457
- const trigger = kit.querySelector('.pb_dropdown_trigger')
458
-
459
- expect(trigger).toHaveTextContent("This Week")
460
-
461
- const clearIcon = kit.querySelector('[aria-label="times icon"]')
462
- expect(clearIcon).toBeInTheDocument()
463
-
464
- fireEvent.click(clearIcon.parentElement)
465
-
466
- expect(trigger).toHaveTextContent("Select...")
467
- })
468
-
469
- test("quickpick returns date array values when option selected", () => {
470
- const TestComponent = () => {
471
- const [selected, setSelected] = useState(null)
472
- return (
473
- <>
474
- <Dropdown
475
- data={{ testid: testId }}
476
- onSelect={(item) => setSelected(item)}
477
- variant="quickpick"
478
- />
479
- {selected && (
480
- <div data-testid="selected-value">
481
- {JSON.stringify({
482
- label: selected.label,
483
- hasValue: !!selected.value,
484
- isArray: Array.isArray(selected.value),
485
- valueLength: selected.value?.length
486
- })}
487
- </div>
488
- )}
489
- </>
490
- )
491
- }
492
-
493
- render(<TestComponent />)
494
-
495
- const kit = screen.getByTestId(testId)
496
- const options = kit.querySelectorAll('.pb_dropdown_option_list')
497
-
498
- fireEvent.click(options[0])
499
-
500
- const selectedValue = screen.getByTestId('selected-value')
501
- const data = JSON.parse(selectedValue.textContent)
502
-
503
- expect(data.label).toBe("Today")
504
- expect(data.hasValue).toBe(true)
505
- expect(data.isArray).toBe(true)
506
- expect(data.valueLength).toBe(2)
507
- })
508
-
509
- test("quickpick option values are Date objects", () => {
510
- const onSelectMock = jest.fn()
511
-
512
- render(
513
- <Dropdown
514
- data={{ testid: testId }}
515
- onSelect={onSelectMock}
516
- variant="quickpick"
517
- />
518
- )
519
-
520
- const kit = screen.getByTestId(testId)
521
- const options = kit.querySelectorAll('.pb_dropdown_option_list')
522
-
523
- const thisMonthOption = Array.from(options).find(opt => opt.textContent === 'This Month')
524
- fireEvent.click(thisMonthOption)
525
-
526
- const selectedItem = onSelectMock.mock.calls[0][0]
527
-
528
- expect(selectedItem.label).toBe("This Month")
529
- expect(selectedItem.value).toBeDefined()
530
- expect(Array.isArray(selectedItem.value)).toBe(true)
531
- expect(selectedItem.value.length).toBe(2)
532
-
533
- const [startDate, endDate] = selectedItem.value
534
-
535
- expect(startDate instanceof Date).toBe(true)
536
- expect(endDate instanceof Date).toBe(true)
537
-
538
- expect(startDate.getTime()).not.toBeNaN()
539
- expect(endDate.getTime()).not.toBeNaN()
540
-
541
- expect(endDate.getTime()).toBeGreaterThanOrEqual(startDate.getTime())
542
- })
396
+ })
@@ -126,7 +126,7 @@ export default class PbDropdown extends PbEnhancedElement {
126
126
  .label.toString()
127
127
  .toLowerCase();
128
128
 
129
- // hide or show option
129
+ // hide or show option
130
130
  const match = label.includes(lcTerm);
131
131
  opt.style.display = match ? "" : "none";
132
132
  if (match) hasMatch = true
@@ -1,6 +1,5 @@
1
1
  import React from 'react'
2
- import EmptyState from '../_empty_state'
3
- import Flex from '../../pb_flex/_flex'
2
+ import { EmptyState, Flex } from 'playbook-ui'
4
3
 
5
4
  const EmptyStateAlignment = (props) => (
6
5
  <Flex align="center"
@@ -1,6 +1,5 @@
1
1
  import React from 'react'
2
- import EmptyState from '../_empty_state'
3
- import Flex from '../../pb_flex/_flex'
2
+ import { EmptyState, Flex } from 'playbook-ui'
4
3
 
5
4
  const EmptyStateDefault = (props) => (
6
5
  <Flex align="center"
@@ -1,6 +1,5 @@
1
1
  import React from 'react'
2
- import EmptyState from '../_empty_state'
3
- import Flex from '../../pb_flex/_flex'
2
+ import { EmptyState, Flex } from 'playbook-ui'
4
3
 
5
4
  const EmptyStateOrientation = (props) => (
6
5
  <Flex align="center"
@@ -1,6 +1,5 @@
1
1
  import React from 'react'
2
- import EmptyState from '../_empty_state'
3
- import Flex from '../../pb_flex/_flex'
2
+ import { EmptyState, Flex } from 'playbook-ui'
4
3
 
5
4
  const EmptyStateSize = (props) => (
6
5
  <Flex align="center"
@@ -1 +1 @@
1
- Filter can leverage the max-width property. Learn more in our <a href="https://playbook.powerapp.cloud/global_props/max_width" target="_blank">visual guidelines.</a>
1
+ Filter can leverage the max-width property. Learn more in our <a href="https://playbook.powerapp.cloud/visual_guidelines" target="_blank">visual guidelines.</a>
@@ -1,4 +1,4 @@
1
- import React, { useEffect, useState, useRef } from "react";
1
+ import React, { useEffect, useState } from "react";
2
2
  import classnames from "classnames";
3
3
 
4
4
  import { globalProps, GlobalProps } from "../utilities/globalProps";
@@ -36,7 +36,6 @@ type FixedConfirmationToastProps = {
36
36
 
37
37
  const FixedConfirmationToast = (props: FixedConfirmationToastProps): React.ReactElement => {
38
38
  const [showToast, toggleToast] = useState(true);
39
- const timeoutRef = useRef<NodeJS.Timeout | null>(null);
40
39
 
41
40
  const {
42
41
  autoClose = 0,
@@ -68,42 +67,21 @@ const FixedConfirmationToast = (props: FixedConfirmationToastProps): React.React
68
67
 
69
68
  const htmlProps = buildHtmlProps(htmlOptions);
70
69
 
71
- useEffect(() => {
72
- toggleToast(open);
73
- }, [open]);
74
-
75
- // Manage auto-close timeout separately
76
- useEffect(() => {
77
- // Clear any existing timeout
78
- if (timeoutRef.current) {
79
- clearTimeout(timeoutRef.current);
80
- timeoutRef.current = null;
81
- }
82
-
83
- // Set new timeout if autoClose is enabled and toast is open
84
- if (autoClose && open && showToast) {
85
- timeoutRef.current = setTimeout(() => {
70
+ const autoCloseToast = () => {
71
+ if (autoClose && open) {
72
+ setTimeout(() => {
86
73
  toggleToast(false);
87
74
  onClose();
88
- timeoutRef.current = null;
89
75
  }, autoClose);
90
76
  }
77
+ };
91
78
 
92
- // Cleanup function to clear timeout on unmount or when dependencies change
93
- return () => {
94
- if (timeoutRef.current) {
95
- clearTimeout(timeoutRef.current);
96
- timeoutRef.current = null;
97
- }
98
- };
99
- }, [autoClose, open, showToast, onClose]);
79
+ useEffect(() => {
80
+ toggleToast(open);
81
+ autoCloseToast();
82
+ }, [open]);
100
83
 
101
84
  const handleClick = () => {
102
- // Clear autoClose timeout when manually closing
103
- if (timeoutRef.current) {
104
- clearTimeout(timeoutRef.current);
105
- timeoutRef.current = null;
106
- }
107
85
  toggleToast(!closeable);
108
86
  onClose();
109
87
  };
@@ -22,27 +22,13 @@
22
22
  }) %>
23
23
 
24
24
  <script>
25
- // Hide toasts immediately
26
- const hideAutoToasts = () => {
27
- const toastAuto = document.getElementById('toast-auto-close');
28
- const toastAutoCloseable = document.getElementById('toast-auto-close-closeable');
29
- if (toastAuto) toastAuto.style.display = 'none';
30
- if (toastAutoCloseable) toastAutoCloseable.style.display = 'none';
31
- }
32
- hideAutoToasts();
33
-
34
- // Handle various page load/restore events
35
- window.addEventListener('pageshow', hideAutoToasts)
36
- document.addEventListener('turbolinks:load', hideAutoToasts)
37
- document.addEventListener('turbo:load', hideAutoToasts)
38
-
39
25
  document.addEventListener('DOMContentLoaded', () => {
40
26
  // Initialize toast elements and buttons
41
27
  const toasts = {
42
28
  '#toast-auto-close': document.querySelector("#toast-auto-close"),
43
29
  '#toast-auto-close-closeable': document.querySelector("#toast-auto-close-closeable")
44
30
  }
45
-
31
+
46
32
  const buttons = {
47
33
  '#toast-auto-close': document.querySelector("button[data-toast='#toast-auto-close']"),
48
34
  '#toast-auto-close-closeable': document.querySelector("button[data-toast='#toast-auto-close-closeable']")
@@ -24,6 +24,7 @@
24
24
  horizontal: "center"
25
25
  }) %>
26
26
 
27
+
27
28
  <script type="text/javascript">
28
29
  const multitoasts = document.querySelectorAll(".multitoast-to-hide")
29
30
  const multibuttons = document.querySelectorAll("button[data-multitoast]")
@@ -34,15 +35,6 @@
34
35
  })
35
36
  }
36
37
 
37
- // Hide toasts immediately
38
- hideMultiToasts()
39
-
40
- // Handle various page load/restore events
41
- window.addEventListener('pageshow', hideMultiToasts)
42
- document.addEventListener('DOMContentLoaded', hideMultiToasts)
43
- document.addEventListener('turbolinks:load', hideMultiToasts)
44
- document.addEventListener('turbo:load', hideMultiToasts)
45
-
46
38
  multibuttons.forEach((button) => {
47
39
  button.onclick = () => {
48
40
  hideMultiToasts()
@@ -54,3 +46,10 @@
54
46
  }
55
47
  })
56
48
  </script>
49
+
50
+ <!-- hiding toast on page load -->
51
+ <style>
52
+ #toast-long, #toast-short {
53
+ display: none;
54
+ }
55
+ </style>
@@ -69,28 +69,27 @@
69
69
  const toasts = document.querySelectorAll(".toast-to-hide")
70
70
  const buttons = document.querySelectorAll("button[data-toast]")
71
71
 
72
- const hidePositionToasts = () => {
72
+ const hideToasts = () => {
73
73
  toasts.forEach((toast) => {
74
74
  toast.style.display = "none"
75
75
  })
76
76
  }
77
77
 
78
- // Hide toasts immediately
79
- hidePositionToasts()
80
-
81
- // Handle various page load/restore events
82
- window.addEventListener('pageshow', hidePositionToasts)
83
- document.addEventListener('DOMContentLoaded', hidePositionToasts)
84
- document.addEventListener('turbolinks:load', hidePositionToasts)
85
- document.addEventListener('turbo:load', hidePositionToasts)
86
-
87
78
  buttons.forEach((button) => {
88
79
  button.onclick = () => {
89
- hidePositionToasts()
80
+ hideToasts()
90
81
  let toast = document.querySelector(button.getAttribute("data-toast"))
82
+
91
83
  if (toast) {
92
84
  toast.style.display = "flex"
93
85
  }
94
86
  }
95
87
  })
96
88
  </script>
89
+
90
+ <!-- hiding toast on page load -->
91
+ <style>
92
+ #toast-top-center, #toast-top-right, #toast-top-left, #toast-bottom-center, #toast-bottom-right, #toast-bottom-left {
93
+ display: none;
94
+ }
95
+ </style>