playbook_ui 14.19.0.pre.rc.2 → 14.20.0.pre.alpha.PLAY21817891

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 (231) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/_playbook.scss +0 -1
  3. data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +11 -1
  4. data/app/pb_kits/playbook/pb_advanced_table/Components/TableActionBar.tsx +175 -16
  5. data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +56 -25
  6. data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +23 -13
  7. data/app/pb_kits/playbook/pb_advanced_table/Utilities/VisibilityTree.ts +47 -0
  8. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +6 -10
  9. data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +7 -2
  10. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +16 -8
  11. data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +9 -0
  12. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.md +5 -7
  13. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility.jsx +57 -0
  14. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility.md +4 -0
  15. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_custom.jsx +62 -0
  16. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_custom.md +1 -0
  17. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_multi.jsx +82 -0
  18. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_multi.md +1 -0
  19. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_with_state.jsx +66 -0
  20. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_with_state.md +3 -0
  21. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.md +1 -1
  22. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.html.erb +137 -0
  23. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.md +3 -0
  24. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header_rails.html.erb +40 -0
  25. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header_rails.md +1 -0
  26. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_rails.md +5 -1
  27. data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_no_subrows.jsx → _advanced_table_selectable_rows_no_subrows_react.jsx} +2 -2
  28. data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.md +3 -2
  29. data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +9 -3
  30. data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +6 -2
  31. data/app/pb_kits/playbook/pb_advanced_table/flat_advanced_table.js +106 -0
  32. data/app/pb_kits/playbook/pb_advanced_table/index.js +370 -10
  33. data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +1 -0
  34. data/app/pb_kits/playbook/pb_advanced_table/table_action_bar.html.erb +23 -0
  35. data/app/pb_kits/playbook/pb_advanced_table/table_action_bar.rb +19 -0
  36. data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +9 -1
  37. data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +4 -3
  38. data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +1 -2
  39. data/app/pb_kits/playbook/pb_avatar/_avatar.scss +4 -0
  40. data/app/pb_kits/playbook/pb_avatar/_avatar.tsx +3 -0
  41. data/app/pb_kits/playbook/pb_avatar/avatar.html.erb +3 -3
  42. data/app/pb_kits/playbook/pb_avatar/avatar.rb +2 -0
  43. data/app/pb_kits/playbook/pb_avatar/avatar.test.js +18 -0
  44. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_grayscale.html.erb +5 -0
  45. data/app/pb_kits/playbook/pb_avatar/docs/_avatar_grayscale.jsx +16 -0
  46. data/app/pb_kits/playbook/pb_avatar/docs/example.yml +2 -0
  47. data/app/pb_kits/playbook/pb_avatar/docs/index.js +1 -0
  48. data/app/pb_kits/playbook/pb_card/card.html.erb +1 -1
  49. data/app/pb_kits/playbook/pb_card/card.rb +12 -0
  50. data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_error.html.erb +2 -2
  51. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.html.erb +22 -1
  52. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line.html.erb +55 -0
  53. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line_rails.md +5 -0
  54. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_rails.md +5 -0
  55. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners.jsx +59 -0
  56. data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners_react.md +1 -0
  57. data/app/pb_kits/playbook/pb_draggable/docs/example.yml +2 -0
  58. data/app/pb_kits/playbook/pb_draggable/docs/index.js +2 -1
  59. data/app/pb_kits/playbook/pb_draggable/draggable_container.rb +11 -1
  60. data/app/pb_kits/playbook/pb_draggable/draggable_item.rb +11 -1
  61. data/app/pb_kits/playbook/pb_draggable/index.js +4 -2
  62. data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableItem.tsx +33 -5
  63. data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +6 -1
  64. data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +82 -35
  65. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb +31 -0
  66. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.md +5 -0
  67. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +5 -2
  68. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.jsx +56 -0
  69. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.md +3 -0
  70. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.jsx +58 -0
  71. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.md +3 -0
  72. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.html.erb +20 -0
  73. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.md +1 -0
  74. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.html.erb +19 -0
  75. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.md +3 -0
  76. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.html.erb +20 -0
  77. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.jsx +57 -0
  78. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.md +1 -0
  79. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.html.erb +50 -0
  80. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.jsx +105 -0
  81. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.html.erb +22 -0
  82. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.jsx +67 -0
  83. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.html.erb +28 -0
  84. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +17 -64
  85. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.html.erb +58 -0
  86. data/app/pb_kits/playbook/pb_dropdown/docs/{_dropdown_with_autocomplete_and_custom_display.jsx → _dropdown_with_autocomplete_with_subcomponents.jsx} +11 -25
  87. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.md +1 -0
  88. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +11 -0
  89. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.md +1 -1
  90. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +33 -2
  91. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.md +3 -1
  92. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.md +1 -0
  93. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.jsx +61 -0
  94. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.md +2 -0
  95. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.html.erb +52 -0
  96. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.md +2 -0
  97. data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +18 -5
  98. data/app/pb_kits/playbook/pb_dropdown/docs/index.js +7 -2
  99. data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +3 -3
  100. data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +20 -2
  101. data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +45 -1
  102. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +10 -0
  103. data/app/pb_kits/playbook/pb_dropdown/dropdown_container.rb +3 -0
  104. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +37 -6
  105. data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.rb +5 -1
  106. data/app/pb_kits/playbook/pb_dropdown/hooks/useHandleOnKeydown.tsx +0 -6
  107. data/app/pb_kits/playbook/pb_dropdown/index.js +380 -17
  108. data/app/pb_kits/playbook/pb_dropdown/keyboard_accessibility.js +64 -11
  109. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownContainer.tsx +3 -4
  110. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +16 -12
  111. data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +83 -17
  112. data/app/pb_kits/playbook/pb_dropdown/subcomponents/MultiSelectTriggerDisplay.tsx +58 -0
  113. data/app/pb_kits/playbook/pb_empty_state/_empty_state.scss +8 -1
  114. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_alignment.html.erb +27 -0
  115. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_default.html.erb +7 -0
  116. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_orientation.html.erb +12 -0
  117. data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_size.html.erb +23 -0
  118. data/app/pb_kits/playbook/pb_empty_state/docs/example.yml +5 -1
  119. data/app/pb_kits/playbook/pb_empty_state/empty_state.html.erb +19 -0
  120. data/app/pb_kits/playbook/pb_empty_state/empty_state.rb +123 -0
  121. data/app/pb_kits/playbook/pb_file_upload/_file_upload.scss +13 -0
  122. data/app/pb_kits/playbook/pb_file_upload/_file_upload.tsx +11 -1
  123. data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_error.html.erb +1 -0
  124. data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_error.jsx +41 -0
  125. data/app/pb_kits/playbook/pb_file_upload/docs/example.yml +2 -0
  126. data/app/pb_kits/playbook/pb_file_upload/docs/index.js +1 -0
  127. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +1 -0
  128. data/app/pb_kits/playbook/pb_file_upload/file_upload.rb +7 -1
  129. data/app/pb_kits/playbook/pb_file_upload/fileupload.test.js +18 -0
  130. data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +1 -0
  131. data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +1 -0
  132. data/app/pb_kits/playbook/pb_form_group/_error_state_mixin.scss +2 -2
  133. data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +19 -12
  134. data/app/pb_kits/playbook/pb_home_address_street/_home_address_street.tsx +13 -7
  135. data/app/pb_kits/playbook/pb_message/_message.tsx +3 -0
  136. data/app/pb_kits/playbook/pb_message/docs/_message_grayscale.html.erb +9 -0
  137. data/app/pb_kits/playbook/pb_message/docs/_message_grayscale.jsx +21 -0
  138. data/app/pb_kits/playbook/pb_message/docs/example.yml +2 -0
  139. data/app/pb_kits/playbook/pb_message/docs/index.js +1 -0
  140. data/app/pb_kits/playbook/pb_message/message.html.erb +2 -1
  141. data/app/pb_kits/playbook/pb_message/message.rb +1 -0
  142. data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +2 -2
  143. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_color.html.erb +11 -11
  144. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_color.jsx +11 -11
  145. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_default.html.erb +11 -11
  146. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_default.jsx +11 -11
  147. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.html.erb +11 -11
  148. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.jsx +11 -11
  149. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options.html.erb +11 -11
  150. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options.jsx +11 -11
  151. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_default.html.erb +11 -11
  152. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_default.jsx +11 -11
  153. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent.html.erb +11 -11
  154. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent.jsx +11 -11
  155. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent_default.html.erb +11 -11
  156. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent_default.jsx +11 -11
  157. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.html.erb +11 -11
  158. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.jsx +11 -11
  159. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.html.erb +11 -11
  160. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.jsx +11 -11
  161. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.jsx +11 -11
  162. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_reset.html.erb +11 -11
  163. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_return_all_selected.html.erb +11 -11
  164. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_return_all_selected.jsx +11 -11
  165. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids.html.erb +11 -11
  166. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids.md +2 -0
  167. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids_react.jsx +11 -11
  168. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids_react.md +3 -1
  169. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single.html.erb +22 -22
  170. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single.jsx +22 -22
  171. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single_children_only.html.erb +22 -22
  172. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single_children_only.jsx +22 -22
  173. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_children.jsx +11 -11
  174. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_children_with_radios.jsx +11 -11
  175. data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_form.html.erb +11 -11
  176. data/app/pb_kits/playbook/pb_overlay/_overlay.scss +2 -1
  177. data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.jsx +1 -1
  178. data/app/pb_kits/playbook/pb_overlay/subcomponents/_overlay_token.tsx +5 -4
  179. data/app/pb_kits/playbook/pb_person/_person.tsx +12 -2
  180. data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.scss +9 -9
  181. data/app/pb_kits/playbook/pb_section_separator/_section_separator.tsx +2 -2
  182. data/app/pb_kits/playbook/pb_select/_select.scss +10 -0
  183. data/app/pb_kits/playbook/pb_select/docs/_select_error.html.erb +1 -1
  184. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +7 -7
  185. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +5 -5
  186. data/app/pb_kits/playbook/pb_text_input/_text_input.scss +4 -2
  187. data/app/pb_kits/playbook/pb_text_input/docs/_text_input_error.html.erb +1 -1
  188. data/app/pb_kits/playbook/pb_textarea/docs/_textarea_error.html.erb +5 -1
  189. data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +73 -3
  190. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_error_state.html.erb +8 -1
  191. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.jsx +23 -0
  192. data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.md +1 -0
  193. data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +1 -0
  194. data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
  195. data/app/pb_kits/playbook/pb_user/_user.tsx +3 -0
  196. data/app/pb_kits/playbook/pb_user/docs/_user_grayscale.html.erb +6 -0
  197. data/app/pb_kits/playbook/pb_user/docs/_user_grayscale.jsx +16 -0
  198. data/app/pb_kits/playbook/pb_user/docs/example.yml +2 -0
  199. data/app/pb_kits/playbook/pb_user/docs/index.js +1 -0
  200. data/app/pb_kits/playbook/pb_user/user.html.erb +2 -1
  201. data/app/pb_kits/playbook/pb_user/user.rb +1 -0
  202. data/dist/chunks/_typeahead-BmOWdDtp.js +22 -0
  203. data/dist/chunks/_weekday_stacked-CvcuQyr9.js +45 -0
  204. data/dist/chunks/lib-D5R1BjUn.js +29 -0
  205. data/dist/chunks/{pb_form_validation-BWjy4bFn.js → pb_form_validation-BZ2AVAi_.js} +1 -1
  206. data/dist/chunks/vendor.js +1 -1
  207. data/dist/menu.yml +6 -14
  208. data/dist/playbook-doc.js +2 -2
  209. data/dist/playbook-rails-react-bindings.js +1 -1
  210. data/dist/playbook-rails.js +1 -1
  211. data/dist/playbook.css +1 -1
  212. data/lib/playbook/kit_base.rb +3 -3
  213. data/lib/playbook/version.rb +2 -2
  214. metadata +76 -22
  215. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.html.erb +0 -10
  216. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.md +0 -1
  217. data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_hook.jsx +0 -79
  218. data/app/pb_kits/playbook/pb_gantt_chart/_gantt_chart.scss +0 -3
  219. data/app/pb_kits/playbook/pb_gantt_chart/_gantt_chart.tsx +0 -72
  220. data/app/pb_kits/playbook/pb_gantt_chart/docs/_gantt_chart_default.jsx +0 -53
  221. data/app/pb_kits/playbook/pb_gantt_chart/docs/example.yml +0 -7
  222. data/app/pb_kits/playbook/pb_gantt_chart/docs/index.js +0 -1
  223. data/app/pb_kits/playbook/pb_gantt_chart/gantt_chart.test.jsx +0 -19
  224. data/dist/chunks/_typeahead-D8CsVBZO.js +0 -22
  225. data/dist/chunks/_weekday_stacked-D3oLTSkH.js +0 -45
  226. data/dist/chunks/lib-BmTAc7Nc.js +0 -29
  227. /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_react.md → _advanced_table_selectable_rows.md} +0 -0
  228. /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_no_subrows.html.erb → _advanced_table_selectable_rows_no_subrows_rails.html.erb} +0 -0
  229. /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows.html.erb → _advanced_table_selectable_rows_rails.html.erb} +0 -0
  230. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_drop_zones_line.md → _draggable_drop_zones_line_react.md} +0 -0
  231. /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_event_listeners.md → _draggable_event_listeners_rails.md} +0 -0
@@ -1,4 +1,14 @@
1
1
  <%= pb_content_tag do %>
2
+ <% if object.searchbar %>
3
+ <%= pb_rails("text_input", props: {padding_top:"xs", padding_x:"xs"}) do %>
4
+ <input
5
+ type="text"
6
+ placeholder="Search…"
7
+ data-dropdown-search
8
+ autocomplete="off"
9
+ />
10
+ <% end %>
11
+ <% end %>
2
12
  <%= pb_rails("list", props: {ordered: false, borderless: false}) do %>
3
13
  <% if content.present? %>
4
14
  <%= content.presence %>
@@ -3,6 +3,9 @@
3
3
  module Playbook
4
4
  module PbDropdown
5
5
  class DropdownContainer < Playbook::KitBase
6
+ prop :searchbar, type: Playbook::Props::Boolean,
7
+ default: false
8
+
6
9
  def classname
7
10
  generate_classname("pb_dropdown_container", "close", separator: " ")
8
11
  end
@@ -8,13 +8,13 @@
8
8
  align: "center",
9
9
  border_radius:"lg",
10
10
  classname: object.trigger_wrapper_classes,
11
- cursor: "pointer",
11
+ cursor: object.autocomplete ? "text" : "pointer",
12
12
  justify: "between",
13
13
  padding_x:"sm",
14
14
  padding_y:"xs",
15
15
  html_options: {tabindex:"0"}
16
16
  }) do %>
17
- <%= pb_rails("flex/flex_item") do %>
17
+ <%= pb_rails("flex/flex_item", props: { fixed_size: object.multi_select ? "85%" : "" }) do %>
18
18
  <%= pb_rails("flex", props: {align: "center"}) do %>
19
19
  <% if object.custom_display.present? %>
20
20
  <%= pb_rails("flex", props: {align: "center"}) do %>
@@ -24,13 +24,44 @@
24
24
  <%= pb_rails("body", props: {text: object.default_display_placeholder, id: "dropdown_trigger_display"}) %>
25
25
  <% end %>
26
26
  <% else %>
27
- <%= pb_rails("body", props: {text: object.default_display_placeholder, id: "dropdown_trigger_display"}) %>
27
+ <% if object.multi_select %>
28
+ <%= pb_rails("flex", props: { align: "center", wrap: true }) do %>
29
+ <%= pb_rails("flex", props: { id:"dropdown_pills_wrapper", wrap: true }) do %>
30
+ <% end %>
31
+ <% if object.autocomplete %>
32
+ <input
33
+ data-dropdown-autocomplete
34
+ class="dropdown_input"
35
+ type="text"
36
+ placeholder="<%= object.placeholder || 'Select…' %>"
37
+ autocomplete="off"
38
+ />
39
+ <% else %>
40
+ <%= pb_rails("body", props: {text: object.default_display_placeholder, id: "dropdown_trigger_display_multi_select"}) %>
41
+ <% end %>
42
+ <% end %>
43
+ <% else %>
44
+ <% if object.autocomplete %>
45
+ <input
46
+ data-dropdown-autocomplete
47
+ class="dropdown_input"
48
+ type="text"
49
+ placeholder="<%= object.placeholder || 'Select…' %>"
50
+ autocomplete="off"
51
+ />
52
+ <% else %>
53
+ <%= pb_rails("body", props: {text: object.default_display_placeholder, id: "dropdown_trigger_display"}) %>
54
+ <% end %>
55
+ <% end %>
28
56
  <% end %>
29
57
  <% end %>
30
58
  <% end %>
31
- <%= pb_rails("body", props: {display: "flex"}) do %>
32
- <%= pb_rails("icon", props: {icon: "chevron-down", cursor: "pointer", size:"sm", id: "dropdown_open_icon"}) %>
33
- <%= pb_rails("icon", props: {icon: "chevron-up", cursor: "pointer", size:"sm", id: "dropdown_close_icon"}) %>
59
+ <%= pb_rails("flex/flex_item") do %>
60
+ <%= pb_rails("body", props: {display: "flex", align_items:"center" }) do %>
61
+ <%= pb_rails("icon", props: {icon: "times", cursor: "pointer", size:"sm", id: "dropdown_clear_icon", padding_right:"xs" }) %>
62
+ <%= pb_rails("icon", props: {icon: "chevron-down", cursor: "pointer", size:"sm", id: "dropdown_open_icon"}) %>
63
+ <%= pb_rails("icon", props: {icon: "chevron-up", cursor: "pointer", size:"sm", id: "dropdown_close_icon"}) %>
64
+ <% end %>
34
65
  <% end %>
35
66
  <% end %>
36
67
  <% end %>
@@ -9,6 +9,10 @@ module Playbook
9
9
  default: ""
10
10
  prop :placeholder, type: Playbook::Props::String
11
11
  prop :custom_display
12
+ prop :autocomplete, type: Playbook::Props::Boolean,
13
+ default: false
14
+ prop :multi_select, type: Playbook::Props::Boolean,
15
+ default: false
12
16
 
13
17
  def data
14
18
  Hash(prop(:data)).merge(dropdown_trigger: true, dropdown_placeholder: default_display_placeholder)
@@ -23,7 +27,7 @@ module Playbook
23
27
  end
24
28
 
25
29
  def trigger_wrapper_classes
26
- generate_classname("dropdown_trigger_wrapper", "select_only")
30
+ generate_classname("dropdown_trigger_wrapper", ("select_only" unless autocomplete || multi_select))
27
31
  end
28
32
  end
29
33
  end
@@ -22,12 +22,6 @@ const {
22
22
  }
23
23
 
24
24
  switch (e.key) {
25
- case "Backspace":
26
- case "Delete":
27
- if (autocomplete) {
28
- handleBackspace();
29
- }
30
- break;
31
25
  case "ArrowDown": {
32
26
  e.preventDefault();
33
27
  setIsDropDownClosed(false);
@@ -11,6 +11,9 @@ const CUSTOM_DISPLAY_SELECTOR = "[data-dropdown-custom-trigger]";
11
11
  const DROPDOWN_TRIGGER_DISPLAY = "#dropdown_trigger_display";
12
12
  const DROPDOWN_PLACEHOLDER = "[data-dropdown-placeholder]";
13
13
  const DROPDOWN_INPUT = "#dropdown-selected-option";
14
+ const SEARCH_INPUT_SELECTOR = "[data-dropdown-autocomplete]";
15
+ const SEARCH_BAR_SELECTOR = "[data-dropdown-search]";
16
+ const CLEAR_ICON_SELECTOR = "#dropdown_clear_icon";
14
17
 
15
18
  export default class PbDropdown extends PbEnhancedElement {
16
19
  static get selector() {
@@ -18,16 +21,45 @@ export default class PbDropdown extends PbEnhancedElement {
18
21
  }
19
22
 
20
23
  get target() {
21
- return this.element.parentNode.querySelector(CONTAINER_SELECTOR);
24
+ return this.element.querySelector(CONTAINER_SELECTOR);
22
25
  }
23
26
 
27
+ selectedOptions = new Set();
28
+ clearBtn = null;
29
+
24
30
  connect() {
25
31
  this.keyboardHandler = new PbDropdownKeyboard(this);
32
+ this.isMultiSelect = this.element.dataset.pbDropdownMultiSelect === "true";
33
+ this.formPillProps = this.element.dataset.formPillProps
34
+ ? JSON.parse(this.element.dataset.formPillProps)
35
+ : {};
26
36
  this.setDefaultValue();
27
37
  this.bindEventListeners();
38
+ this.bindSearchInput();
28
39
  this.updateArrowDisplay(false);
29
40
  this.handleFormValidation();
30
41
  this.handleFormReset();
42
+ this.bindSearchBar();
43
+ this.updatePills();
44
+
45
+ this.clearBtn = this.element.querySelector(CLEAR_ICON_SELECTOR);
46
+ if (this.clearBtn) {
47
+ this.clearBtn.style.display = "none";
48
+ this.clearBtn.addEventListener("click", (e) => {
49
+ e.stopPropagation();
50
+ this.clearSelection();
51
+ });
52
+ }
53
+ this.updateClearButton();
54
+ }
55
+
56
+ updateClearButton() {
57
+ if (!this.clearBtn) return;
58
+ const hasSelection = this.isMultiSelect
59
+ ? this.selectedOptions.size > 0
60
+ : Boolean(this.element.querySelector(DROPDOWN_INPUT).value);
61
+
62
+ this.clearBtn.style.display = hasSelection ? "" : "none";
31
63
  }
32
64
 
33
65
  bindEventListeners() {
@@ -45,20 +77,93 @@ export default class PbDropdown extends PbEnhancedElement {
45
77
  );
46
78
  }
47
79
 
80
+ bindSearchBar() {
81
+ this.searchBar = this.element.querySelector(SEARCH_BAR_SELECTOR);
82
+ if (!this.searchBar) return;
83
+
84
+ this.searchBar.addEventListener("input", (e) =>
85
+ this.handleSearch(e.target.value)
86
+ );
87
+ }
88
+
89
+ bindSearchInput() {
90
+ this.searchInput = this.element.querySelector(SEARCH_INPUT_SELECTOR);
91
+ if (!this.searchInput) return;
92
+
93
+ // Focus the input when anyone clicks the wrapper
94
+ this.element
95
+ .querySelector(TRIGGER_SELECTOR)
96
+ ?.addEventListener("click", () => this.searchInput.focus());
97
+
98
+ // Live filter
99
+ this.searchInput.addEventListener("input", (e) =>
100
+ this.handleSearch(e.target.value)
101
+ );
102
+ }
103
+
104
+ adjustDropdownHeight() {
105
+ if (this.target.classList.contains("open")) {
106
+ const el = this.target;
107
+ el.style.height = "auto";
108
+ requestAnimationFrame(() => {
109
+ const newHeight = el.scrollHeight + "px";
110
+ el.offsetHeight; // force reflow
111
+ el.style.height = newHeight;
112
+ });
113
+ }
114
+ }
115
+
116
+ handleSearch(term = "") {
117
+ const lcTerm = term.toLowerCase();
118
+ this.element.querySelectorAll(OPTION_SELECTOR).forEach((opt) => {
119
+ //make it so that if the option is selected, it will not show up in the search results
120
+ if (this.isMultiSelect && this.selectedOptions.has(opt.dataset.dropdownOptionLabel)) {
121
+ opt.style.display = "none";
122
+ return;
123
+ }
124
+ const label = JSON.parse(opt.dataset.dropdownOptionLabel)
125
+ .label.toString()
126
+ .toLowerCase();
127
+
128
+ // hide or show option
129
+ const match = label.includes(lcTerm);
130
+ opt.style.display = match ? "" : "none";
131
+ });
132
+
133
+ this.adjustDropdownHeight();
134
+ }
135
+
48
136
  handleOptionClick(event) {
49
137
  const option = event.target.closest(OPTION_SELECTOR);
50
138
  const hiddenInput = this.element.querySelector(DROPDOWN_INPUT);
51
139
 
52
140
  if (option) {
53
141
  const value = option.dataset.dropdownOptionLabel;
54
- hiddenInput.value = JSON.parse(value).id;
55
- this.clearFormValidation(hiddenInput);
142
+ if (this.isMultiSelect) {
143
+ const alreadySelected = this.selectedOptions.has(value);
144
+ if (alreadySelected) {
145
+ this.selectedOptions.delete(value);
146
+ } else {
147
+ this.selectedOptions.add(value);
148
+ }
149
+ this.updatePills();
150
+ this.syncHiddenInputs();
151
+ if (this.searchInput && this.isMultiSelect) {
152
+ this.searchInput.value = "";
153
+ this.handleBackspaceClear();
154
+ }
155
+ } else {
156
+ hiddenInput.value = JSON.parse(value).id;
157
+ }
56
158
 
159
+ this.clearFormValidation(hiddenInput);
57
160
  this.onOptionSelected(value, option);
161
+ this.updateClearButton();
58
162
  }
59
163
  }
60
164
 
61
165
  handleDocumentClick(event) {
166
+ if (event.target.closest(SEARCH_BAR_SELECTOR)) return;
62
167
  if (this.isClickOutside(event) && this.target.classList.contains("open")) {
63
168
  this.hideElement(this.target);
64
169
  this.updateArrowDisplay(false);
@@ -85,20 +190,56 @@ export default class PbDropdown extends PbEnhancedElement {
85
190
  }
86
191
  }
87
192
 
193
+ emitSelectionChange() {
194
+ let detail;
195
+
196
+ if (this.isMultiSelect) {
197
+ detail = Array.from(this.selectedOptions).map(JSON.parse);
198
+ } else {
199
+ const hiddenInput = this.element.querySelector(DROPDOWN_INPUT);
200
+ detail = hiddenInput.value
201
+ ? JSON.parse(
202
+ this.element.querySelector(
203
+ OPTION_SELECTOR +
204
+ `[data-dropdown-option-label*='"id":"${hiddenInput.value}"']`
205
+ ).dataset.dropdownOptionLabel
206
+ )
207
+ : null;
208
+ }
209
+ this.element.setAttribute("data-option-selected", JSON.stringify(detail));
210
+ this.element.dispatchEvent(
211
+ new CustomEvent("pb:dropdown:selected", {
212
+ detail,
213
+ bubbles: true,
214
+ })
215
+ );
216
+ }
217
+
88
218
  onOptionSelected(value, selectedOption) {
89
219
  const triggerElement = this.element.querySelector(DROPDOWN_TRIGGER_DISPLAY);
90
220
  const customDisplayElement = this.element.querySelector(
91
221
  "#dropdown_trigger_custom_display"
92
222
  );
223
+
93
224
  if (triggerElement) {
94
- const selectedLabel = JSON.parse(value).label;
95
- triggerElement.textContent = selectedLabel;
225
+ if (!this.isMultiSelect) {
226
+ const selectedLabel = JSON.parse(value).label;
227
+ triggerElement.textContent = selectedLabel;
228
+ this.emitSelectionChange();
229
+ }
96
230
  if (customDisplayElement) {
231
+ triggerElement.textContent = "";
97
232
  customDisplayElement.style.display = "block";
98
233
  customDisplayElement.style.paddingRight = "8px";
99
234
  }
100
235
  }
101
236
 
237
+ const autocompleteInput = this.element.querySelector(SEARCH_INPUT_SELECTOR);
238
+ if (autocompleteInput && !this.isMultiSelect) {
239
+ autocompleteInput.value = JSON.parse(value).label;
240
+ this.emitSelectionChange();
241
+ }
242
+
102
243
  const customTrigger = this.element.querySelector(CUSTOM_DISPLAY_SELECTOR);
103
244
  if (customTrigger) {
104
245
  if (this.target.classList.contains("open")) {
@@ -108,10 +249,24 @@ export default class PbDropdown extends PbEnhancedElement {
108
249
  }
109
250
 
110
251
  const options = this.element.querySelectorAll(OPTION_SELECTOR);
111
- options.forEach((option) => {
112
- option.classList.remove("pb_dropdown_option_selected");
113
- });
114
- selectedOption.classList.add("pb_dropdown_option_selected");
252
+ if (this.isMultiSelect) {
253
+ this.emitSelectionChange();
254
+ Array.from(this.selectedOptions).map((option) => {
255
+ if (
256
+ JSON.parse(option).id ===
257
+ JSON.parse(selectedOption.dataset.dropdownOptionLabel).id
258
+ ) {
259
+ selectedOption.style.display = "none";
260
+ this.adjustDropdownHeight();
261
+ }
262
+ });
263
+ } else {
264
+ options.forEach((option) => {
265
+ option.classList.remove("pb_dropdown_option_selected");
266
+ });
267
+ selectedOption.classList.add("pb_dropdown_option_selected");
268
+ }
269
+ this.updateClearButton();
115
270
  }
116
271
 
117
272
  showElement(elem) {
@@ -185,21 +340,66 @@ export default class PbDropdown extends PbEnhancedElement {
185
340
  errorLabelElement.remove();
186
341
  }
187
342
  }
343
+ if (this.isMultiSelect) {
344
+ if (this.selectedOptions.size > 0) {
345
+ const dropdownWrapperElement = input.closest(".dropdown_wrapper");
346
+ dropdownWrapperElement.classList.remove("error");
347
+ const errorLabelElement = dropdownWrapperElement.querySelector(
348
+ ".pb_body_kit_negative"
349
+ );
350
+ if (errorLabelElement) {
351
+ errorLabelElement.remove();
352
+ }
353
+ }
354
+ }
188
355
  }
189
356
 
190
357
  setDefaultValue() {
191
358
  const hiddenInput = this.element.querySelector(DROPDOWN_INPUT);
192
- const options = this.element.querySelectorAll(OPTION_SELECTOR);
193
-
359
+ const optionEls = Array.from(
360
+ this.element.querySelectorAll(OPTION_SELECTOR)
361
+ );
194
362
  const defaultValue = hiddenInput.dataset.defaultValue || "";
195
- hiddenInput.value = defaultValue;
363
+ if (!defaultValue) return;
364
+
365
+ if (this.isMultiSelect) {
366
+ const ids = defaultValue.split(",");
367
+ ids.forEach((id) => {
368
+ const selectedOption = optionEls.find((opt) => {
369
+ try {
370
+ return JSON.parse(opt.dataset.dropdownOptionLabel).id === id;
371
+ } catch {
372
+ return false;
373
+ }
374
+ });
375
+ if (!selectedOption) {
376
+ console.warn(`Dropdown default ID ${id} not found`);
377
+ return;
378
+ }
196
379
 
197
- if (defaultValue) {
198
- const selectedOption = Array.from(options).find((option) => {
199
- return (
200
- JSON.parse(option.dataset.dropdownOptionLabel).id === defaultValue
201
- );
380
+ const raw = selectedOption.dataset.dropdownOptionLabel;
381
+ this.selectedOptions.add(raw);
382
+
383
+ selectedOption.style.display = "none";
384
+ });
385
+
386
+ this.updatePills();
387
+ this.updateClearButton();
388
+ this.adjustDropdownHeight();
389
+ this.syncHiddenInputs();
390
+ } else {
391
+ hiddenInput.value = defaultValue;
392
+ const selectedOption = optionEls.find((opt) => {
393
+ try {
394
+ return (
395
+ JSON.parse(opt.dataset.dropdownOptionLabel).id === defaultValue
396
+ );
397
+ } catch {
398
+ return false;
399
+ }
202
400
  });
401
+ if (!selectedOption) return;
402
+
203
403
  selectedOption.classList.add("pb_dropdown_option_selected");
204
404
  this.setTriggerElementText(
205
405
  JSON.parse(selectedOption.dataset.dropdownOptionLabel).label
@@ -222,12 +422,32 @@ export default class PbDropdown extends PbEnhancedElement {
222
422
  const options = this.element.querySelectorAll(OPTION_SELECTOR);
223
423
  options.forEach((option) => {
224
424
  option.classList.remove("pb_dropdown_option_selected");
425
+ option.style.display = "";
225
426
  });
226
427
 
227
428
  hiddenInput.value = "";
228
429
 
229
430
  const defaultPlaceholder = this.element.querySelector(DROPDOWN_PLACEHOLDER);
230
431
  this.setTriggerElementText(defaultPlaceholder.dataset.dropdownPlaceholder);
432
+
433
+ if (this.searchInput) {
434
+ this.searchInput.value = "";
435
+ if (this.target.classList.contains("open")) {
436
+ const el = this.target;
437
+ el.style.height = "auto";
438
+ requestAnimationFrame(() => {
439
+ const newHeight = el.scrollHeight + "px";
440
+ el.offsetHeight; // force reflow
441
+ el.style.height = newHeight;
442
+ });
443
+ }
444
+ }
445
+ if (this.isMultiSelect) {
446
+ this.selectedOptions.clear();
447
+ this.updatePills();
448
+ this.updateClearButton();
449
+ this.syncHiddenInputs();
450
+ }
231
451
  }
232
452
 
233
453
  setTriggerElementText(text) {
@@ -236,4 +456,147 @@ export default class PbDropdown extends PbEnhancedElement {
236
456
  triggerElement.textContent = text;
237
457
  }
238
458
  }
459
+
460
+ updatePills() {
461
+ if (!this.isMultiSelect) return;
462
+
463
+ const wrapper = this.element.querySelector("#dropdown_pills_wrapper");
464
+ const placeholder = this.element.querySelector(
465
+ "#dropdown_trigger_display_multi_select"
466
+ );
467
+ if (!wrapper) return;
468
+
469
+ wrapper.innerHTML = "";
470
+ // Show or hide the placeholder based on selected options
471
+ if (placeholder) {
472
+ if (this.selectedOptions.size > 0) {
473
+ placeholder.style.display = "none";
474
+ } else {
475
+ placeholder.style.display = "";
476
+ }
477
+ }
478
+
479
+ Array.from(this.selectedOptions).map((option) => {
480
+ // Create a form pill for each selected option
481
+ const pill = document.createElement("div");
482
+ const color = this.formPillProps.color || "primary";
483
+ pill.classList.add(`pb_form_pill_kit_${color}`, "mr_xs");
484
+ if (this.formPillProps.size === "small") {
485
+ pill.classList.add("small");
486
+ }
487
+ pill.tabIndex = 0;
488
+ pill.dataset.pillId = JSON.parse(option).id;
489
+ const innerDiv = document.createElement("h3");
490
+ innerDiv.className = "pb_title_kit_size_4 pb_form_pill_text";
491
+ innerDiv.textContent = JSON.parse(option).label;
492
+ pill.appendChild(innerDiv);
493
+
494
+ const closeIcon = document.createElement("div");
495
+ closeIcon.className = "pb_form_pill_close";
496
+ closeIcon.innerHTML = `<svg class="pb_custom_icon svg-inline--fa svg_${
497
+ this.formPillProps.size === "small" ? "xs" : "sm"
498
+ } svg_fw" xmlns="http://www.w3.org/2000/svg" width="auto" height="auto" viewBox="0 0 31 25"><path fill="currentColor" d="M23.0762 6.77734L17.4512 12.4023L23.0293 17.9805C23.498 18.4023 23.498 19.1055 23.0293 19.5273C22.6074 19.9961 21.9043 19.9961 21.4824 19.5273L15.8574 13.9492L10.2793 19.5273C9.85742 19.9961 9.1543 19.9961 8.73242 19.5273C8.26367 19.1055 8.26367 18.4023 8.73242 17.9336L14.3105 12.3555L8.73242 6.77734C8.26367 6.35547 8.26367 5.65234 8.73242 5.18359C9.1543 4.76172 9.85742 4.76172 10.3262 5.18359L15.9043 10.8086L21.4824 5.23047C21.9043 4.76172 22.6074 4.76172 23.0762 5.23047C23.498 5.65234 23.498 6.35547 23.0762 6.77734Z"/></svg>`;
499
+ pill.appendChild(closeIcon);
500
+
501
+ closeIcon.addEventListener("click", (e) => {
502
+ e.stopPropagation();
503
+ const id = pill.dataset.pillId;
504
+ this.selectedOptions.delete(option);
505
+
506
+ const optEl = this.element.querySelector(
507
+ `${OPTION_SELECTOR}[data-dropdown-option-label*='"id":${JSON.stringify(
508
+ id
509
+ )}']`
510
+ );
511
+ if (optEl) {
512
+ optEl.style.display = "";
513
+ if (this.target.classList.contains("open")) {
514
+ this.showElement(this.target);
515
+ }
516
+ }
517
+
518
+ this.updatePills();
519
+ this.updateClearButton();
520
+ this.emitSelectionChange();
521
+ this.syncHiddenInputs();
522
+ });
523
+ wrapper.appendChild(pill);
524
+ });
525
+ }
526
+
527
+ clearSelection() {
528
+ if (this.isMultiSelect) {
529
+ this.selectedOptions.clear();
530
+ this.element.querySelectorAll(OPTION_SELECTOR).forEach((opt) => {
531
+ opt.style.display = "";
532
+ });
533
+ if (this.target.classList.contains("open")) {
534
+ this.showElement(this.target);
535
+ }
536
+ }
537
+ const customDisplay = this.element.querySelector(
538
+ "#dropdown_trigger_custom_display"
539
+ );
540
+ if (customDisplay) {
541
+ customDisplay.style.display = "none";
542
+ }
543
+ this.resetDropdownValue();
544
+ this.updatePills();
545
+ this.updateClearButton();
546
+ this.syncHiddenInputs();
547
+ this.emitSelectionChange();
548
+ }
549
+
550
+ syncHiddenInputs() {
551
+ if (!this.isMultiSelect) return;
552
+ this.element
553
+ .querySelectorAll('input[data-generated="true"]')
554
+ .forEach((n) => n.remove());
555
+
556
+ const baseInput = this.element.querySelector(DROPDOWN_INPUT);
557
+ if (!baseInput) return;
558
+ // for multi_select, for each selectedOption, create a hidden input
559
+ const name = baseInput.getAttribute("name");
560
+ this.selectedOptions.forEach((raw) => {
561
+ const id = JSON.parse(raw).id;
562
+ const inp = document.createElement("input");
563
+ inp.type = "hidden";
564
+ inp.name = name;
565
+ inp.value = id;
566
+ inp.dataset.generated = "true";
567
+ baseInput.insertAdjacentElement("afterend", inp);
568
+ });
569
+ baseInput.value = "";
570
+ }
571
+
572
+ handleBackspaceClear() {
573
+ if (!this.isMultiSelect) {
574
+ this.element.querySelectorAll(OPTION_SELECTOR).forEach((opt) => {
575
+ opt.classList.remove("pb_dropdown_option_selected");
576
+ opt.style.display = "";
577
+ this.adjustDropdownHeight();
578
+ });
579
+
580
+ const hiddenInput = this.element.querySelector(DROPDOWN_INPUT);
581
+ if (hiddenInput) hiddenInput.value = "";
582
+
583
+ const placeholder = this.element.querySelector(DROPDOWN_PLACEHOLDER);
584
+ if (placeholder)
585
+ this.setTriggerElementText(placeholder.dataset.dropdownPlaceholder);
586
+ }
587
+ if (this.isMultiSelect) {
588
+ this.element.querySelectorAll(OPTION_SELECTOR).forEach((opt) => {
589
+ const optValue = opt.dataset.dropdownOptionLabel;
590
+ if (
591
+ this.selectedOptions.size > 0 &&
592
+ this.selectedOptions.has(optValue)
593
+ ) {
594
+ opt.style.display = "none";
595
+ } else {
596
+ opt.style.display = "";
597
+ }
598
+ this.adjustDropdownHeight();
599
+ });
600
+ }
601
+ }
239
602
  }