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.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/_playbook.scss +0 -1
- data/app/pb_kits/playbook/pb_advanced_table/Components/RegularTableView.tsx +11 -1
- data/app/pb_kits/playbook/pb_advanced_table/Components/TableActionBar.tsx +175 -16
- data/app/pb_kits/playbook/pb_advanced_table/Components/TableHeaderCell.tsx +56 -25
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +23 -13
- data/app/pb_kits/playbook/pb_advanced_table/Utilities/VisibilityTree.ts +47 -0
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +6 -10
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +7 -2
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.html.erb +16 -8
- data/app/pb_kits/playbook/pb_advanced_table/advanced_table.rb +9 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_beta.md +5 -7
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility.jsx +57 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility.md +4 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_custom.jsx +62 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_custom.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_multi.jsx +82 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_multi.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_with_state.jsx +66 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_column_visibility_with_state.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_default.md +1 -1
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.html.erb +137 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_actions_rails.md +3 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header_rails.html.erb +40 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_header_rails.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_no_subrows_rails.md +5 -1
- 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
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_selectable_rows_rails.md +3 -2
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +9 -3
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +6 -2
- data/app/pb_kits/playbook/pb_advanced_table/flat_advanced_table.js +106 -0
- data/app/pb_kits/playbook/pb_advanced_table/index.js +370 -10
- data/app/pb_kits/playbook/pb_advanced_table/scss_partials/advanced_table_sticky_mixin.scss +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_action_bar.html.erb +23 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_action_bar.rb +19 -0
- data/app/pb_kits/playbook/pb_advanced_table/table_body.rb +9 -1
- data/app/pb_kits/playbook/pb_advanced_table/table_header.rb +4 -3
- data/app/pb_kits/playbook/pb_advanced_table/table_row.rb +1 -2
- data/app/pb_kits/playbook/pb_avatar/_avatar.scss +4 -0
- data/app/pb_kits/playbook/pb_avatar/_avatar.tsx +3 -0
- data/app/pb_kits/playbook/pb_avatar/avatar.html.erb +3 -3
- data/app/pb_kits/playbook/pb_avatar/avatar.rb +2 -0
- data/app/pb_kits/playbook/pb_avatar/avatar.test.js +18 -0
- data/app/pb_kits/playbook/pb_avatar/docs/_avatar_grayscale.html.erb +5 -0
- data/app/pb_kits/playbook/pb_avatar/docs/_avatar_grayscale.jsx +16 -0
- data/app/pb_kits/playbook/pb_avatar/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_avatar/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_card/card.html.erb +1 -1
- data/app/pb_kits/playbook/pb_card/card.rb +12 -0
- data/app/pb_kits/playbook/pb_date_picker/docs/_date_picker_error.html.erb +2 -2
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones.html.erb +22 -1
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line.html.erb +55 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_line_rails.md +5 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_drop_zones_rails.md +5 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners.jsx +59 -0
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_event_listeners_react.md +1 -0
- data/app/pb_kits/playbook/pb_draggable/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_draggable/docs/index.js +2 -1
- data/app/pb_kits/playbook/pb_draggable/draggable_container.rb +11 -1
- data/app/pb_kits/playbook/pb_draggable/draggable_item.rb +11 -1
- data/app/pb_kits/playbook/pb_draggable/index.js +4 -2
- data/app/pb_kits/playbook/pb_draggable/subcomponents/DraggableItem.tsx +33 -5
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.scss +6 -1
- data/app/pb_kits/playbook/pb_dropdown/_dropdown.tsx +82 -35
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.html.erb +31 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default_rails.md +5 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_error.html.erb +5 -2
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.jsx +56 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select.md +3 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.jsx +58 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display.md +3 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.html.erb +20 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_display_rails.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.html.erb +19 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_rails.md +3 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.html.erb +20 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.jsx +57 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_autocomplete.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.html.erb +50 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_custom_options.jsx +105 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.html.erb +22 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_multi_select_with_default.jsx +67 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.html.erb +28 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete.jsx +17 -64
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.html.erb +58 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/{_dropdown_with_autocomplete_and_custom_display.jsx → _dropdown_with_autocomplete_with_subcomponents.jsx} +11 -25
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_with_subcomponents.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.jsx +11 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display.md +1 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.html.erb +33 -2
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_custom_display_rails.md +3 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_external_control.md +1 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.jsx +61 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search.md +2 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.html.erb +52 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_search_rails.md +2 -0
- data/app/pb_kits/playbook/pb_dropdown/docs/example.yml +18 -5
- data/app/pb_kits/playbook/pb_dropdown/docs/index.js +7 -2
- data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +3 -3
- data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +20 -2
- data/app/pb_kits/playbook/pb_dropdown/dropdown.test.jsx +45 -1
- data/app/pb_kits/playbook/pb_dropdown/dropdown_container.html.erb +10 -0
- data/app/pb_kits/playbook/pb_dropdown/dropdown_container.rb +3 -0
- data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.html.erb +37 -6
- data/app/pb_kits/playbook/pb_dropdown/dropdown_trigger.rb +5 -1
- data/app/pb_kits/playbook/pb_dropdown/hooks/useHandleOnKeydown.tsx +0 -6
- data/app/pb_kits/playbook/pb_dropdown/index.js +380 -17
- data/app/pb_kits/playbook/pb_dropdown/keyboard_accessibility.js +64 -11
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownContainer.tsx +3 -4
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownOption.tsx +16 -12
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/DropdownTrigger.tsx +83 -17
- data/app/pb_kits/playbook/pb_dropdown/subcomponents/MultiSelectTriggerDisplay.tsx +58 -0
- data/app/pb_kits/playbook/pb_empty_state/_empty_state.scss +8 -1
- data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_alignment.html.erb +27 -0
- data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_default.html.erb +7 -0
- data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_orientation.html.erb +12 -0
- data/app/pb_kits/playbook/pb_empty_state/docs/_empty_state_size.html.erb +23 -0
- data/app/pb_kits/playbook/pb_empty_state/docs/example.yml +5 -1
- data/app/pb_kits/playbook/pb_empty_state/empty_state.html.erb +19 -0
- data/app/pb_kits/playbook/pb_empty_state/empty_state.rb +123 -0
- data/app/pb_kits/playbook/pb_file_upload/_file_upload.scss +13 -0
- data/app/pb_kits/playbook/pb_file_upload/_file_upload.tsx +11 -1
- data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_error.html.erb +1 -0
- data/app/pb_kits/playbook/pb_file_upload/docs/_file_upload_error.jsx +41 -0
- data/app/pb_kits/playbook/pb_file_upload/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_file_upload/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +1 -0
- data/app/pb_kits/playbook/pb_file_upload/file_upload.rb +7 -1
- data/app/pb_kits/playbook/pb_file_upload/fileupload.test.js +18 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +1 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +1 -0
- data/app/pb_kits/playbook/pb_form_group/_error_state_mixin.scss +2 -2
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.scss +19 -12
- data/app/pb_kits/playbook/pb_home_address_street/_home_address_street.tsx +13 -7
- data/app/pb_kits/playbook/pb_message/_message.tsx +3 -0
- data/app/pb_kits/playbook/pb_message/docs/_message_grayscale.html.erb +9 -0
- data/app/pb_kits/playbook/pb_message/docs/_message_grayscale.jsx +21 -0
- data/app/pb_kits/playbook/pb_message/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_message/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_message/message.html.erb +2 -1
- data/app/pb_kits/playbook/pb_message/message.rb +1 -0
- data/app/pb_kits/playbook/pb_multi_level_select/_multi_level_select.tsx +2 -2
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_color.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_color.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_default.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_default.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_default.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_default.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent_default.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_disabled_options_parent_default.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_error.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_label.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_react_hook.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_reset.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_return_all_selected.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_return_all_selected.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids.html.erb +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids.md +2 -0
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids_react.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_selected_ids_react.md +3 -1
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single.html.erb +22 -22
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single.jsx +22 -22
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single_children_only.html.erb +22 -22
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_single_children_only.jsx +22 -22
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_children.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_children_with_radios.jsx +11 -11
- data/app/pb_kits/playbook/pb_multi_level_select/docs/_multi_level_select_with_form.html.erb +11 -11
- data/app/pb_kits/playbook/pb_overlay/_overlay.scss +2 -1
- data/app/pb_kits/playbook/pb_overlay/docs/_overlay_vertical_dynamic_multi_directional.jsx +1 -1
- data/app/pb_kits/playbook/pb_overlay/subcomponents/_overlay_token.tsx +5 -4
- data/app/pb_kits/playbook/pb_person/_person.tsx +12 -2
- data/app/pb_kits/playbook/pb_phone_number_input/_phone_number_input.scss +9 -9
- data/app/pb_kits/playbook/pb_section_separator/_section_separator.tsx +2 -2
- data/app/pb_kits/playbook/pb_select/_select.scss +10 -0
- data/app/pb_kits/playbook/pb_select/docs/_select_error.html.erb +1 -1
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +7 -7
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +5 -5
- data/app/pb_kits/playbook/pb_text_input/_text_input.scss +4 -2
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_error.html.erb +1 -1
- data/app/pb_kits/playbook/pb_textarea/docs/_textarea_error.html.erb +5 -1
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +73 -3
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_error_state.html.erb +8 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.jsx +23 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_preserve_input.md +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_typeahead/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_user/_user.tsx +3 -0
- data/app/pb_kits/playbook/pb_user/docs/_user_grayscale.html.erb +6 -0
- data/app/pb_kits/playbook/pb_user/docs/_user_grayscale.jsx +16 -0
- data/app/pb_kits/playbook/pb_user/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_user/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_user/user.html.erb +2 -1
- data/app/pb_kits/playbook/pb_user/user.rb +1 -0
- data/dist/chunks/_typeahead-BmOWdDtp.js +22 -0
- data/dist/chunks/_weekday_stacked-CvcuQyr9.js +45 -0
- data/dist/chunks/lib-D5R1BjUn.js +29 -0
- data/dist/chunks/{pb_form_validation-BWjy4bFn.js → pb_form_validation-BZ2AVAi_.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +6 -14
- data/dist/playbook-doc.js +2 -2
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/kit_base.rb +3 -3
- data/lib/playbook/version.rb +2 -2
- metadata +76 -22
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_default.html.erb +0 -10
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_autocomplete_and_custom_display.md +0 -1
- data/app/pb_kits/playbook/pb_dropdown/docs/_dropdown_with_hook.jsx +0 -79
- data/app/pb_kits/playbook/pb_gantt_chart/_gantt_chart.scss +0 -3
- data/app/pb_kits/playbook/pb_gantt_chart/_gantt_chart.tsx +0 -72
- data/app/pb_kits/playbook/pb_gantt_chart/docs/_gantt_chart_default.jsx +0 -53
- data/app/pb_kits/playbook/pb_gantt_chart/docs/example.yml +0 -7
- data/app/pb_kits/playbook/pb_gantt_chart/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_gantt_chart/gantt_chart.test.jsx +0 -19
- data/dist/chunks/_typeahead-D8CsVBZO.js +0 -22
- data/dist/chunks/_weekday_stacked-D3oLTSkH.js +0 -45
- data/dist/chunks/lib-BmTAc7Nc.js +0 -29
- /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows_react.md → _advanced_table_selectable_rows.md} +0 -0
- /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
- /data/app/pb_kits/playbook/pb_advanced_table/docs/{_advanced_table_selectable_rows.html.erb → _advanced_table_selectable_rows_rails.html.erb} +0 -0
- /data/app/pb_kits/playbook/pb_draggable/docs/{_draggable_drop_zones_line.md → _draggable_drop_zones_line_react.md} +0 -0
- /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 %>
|
@@ -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
|
-
|
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("
|
32
|
-
<%= pb_rails("
|
33
|
-
|
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
|
@@ -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.
|
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
|
-
|
55
|
-
|
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
|
-
|
95
|
-
|
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
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
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
|
193
|
-
|
359
|
+
const optionEls = Array.from(
|
360
|
+
this.element.querySelectorAll(OPTION_SELECTOR)
|
361
|
+
);
|
194
362
|
const defaultValue = hiddenInput.dataset.defaultValue || "";
|
195
|
-
|
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
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
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
|
}
|