playbook_ui 14.19.0.pre.rc.2 → 14.20.0.pre.alpha.PLAY2140upgraderailsdependency8003
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 +14 -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_checkbox/checkbox.html.erb +4 -11
- data/app/pb_kits/playbook/pb_checkbox/checkbox.rb +10 -6
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_indeterminate.html.erb +2 -48
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_indeterminate_rails.md +1 -0
- data/app/pb_kits/playbook/pb_checkbox/index.js +56 -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 +153 -3
- 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 +404 -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_phone_number_input/_phone_number_input.tsx +4 -0
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_exclude_countries.html.erb +4 -0
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_exclude_countries.jsx +15 -0
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_exclude_countries.md +1 -0
- data/app/pb_kits/playbook/pb_phone_number_input/docs/_phone_number_input_only_countries.jsx +1 -1
- data/app/pb_kits/playbook/pb_phone_number_input/docs/example.yml +4 -3
- data/app/pb_kits/playbook/pb_phone_number_input/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_phone_number_input/phone_number_input.rb +3 -0
- 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_custom_select_subheaders.html.erb +12 -0
- data/app/pb_kits/playbook/pb_select/docs/_select_custom_select_subheaders.jsx +31 -0
- data/app/pb_kits/playbook/pb_select/docs/_select_custom_select_subheaders.md +1 -0
- data/app/pb_kits/playbook/pb_select/docs/_select_error.html.erb +1 -1
- data/app/pb_kits/playbook/pb_select/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_select/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +7 -7
- data/app/pb_kits/playbook/pb_table/docs/_table_with_selectable_rows.html.erb +3 -51
- 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-CRW6dJbW.js +22 -0
- data/dist/chunks/_weekday_stacked-C4d17aYW.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 +7 -15
- 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 +84 -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
| @@ -25,6 +25,7 @@ export type AvatarProps = { | |
| 25 25 | 
             
              },
         | 
| 26 26 | 
             
              dark?: boolean,
         | 
| 27 27 | 
             
              data?: {[key: string]: string},
         | 
| 28 | 
            +
              grayscale?:  boolean,
         | 
| 28 29 | 
             
              htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
         | 
| 29 30 | 
             
              id?: string,
         | 
| 30 31 | 
             
              imageAlt?: string,
         | 
| @@ -47,6 +48,7 @@ const Avatar = (props: AvatarProps): React.ReactElement => { | |
| 47 48 | 
             
                htmlOptions = {},
         | 
| 48 49 | 
             
                name = undefined,
         | 
| 49 50 | 
             
                componentOverlay,
         | 
| 51 | 
            +
                grayscale = false,
         | 
| 50 52 | 
             
                id = '',
         | 
| 51 53 | 
             
                imageAlt = '',
         | 
| 52 54 | 
             
                imageUrl,
         | 
| @@ -155,6 +157,7 @@ const Avatar = (props: AvatarProps): React.ReactElement => { | |
| 155 157 | 
             
                        {canShowImage && (
         | 
| 156 158 | 
             
                          <Image
         | 
| 157 159 | 
             
                              alt={imageAlt ? imageAlt : name}
         | 
| 160 | 
            +
                              className={grayscale ? "grayscale" : ""}
         | 
| 158 161 | 
             
                              onError={handleError}
         | 
| 159 162 | 
             
                              url={imageUrl}
         | 
| 160 163 | 
             
                          />
         | 
| @@ -3,7 +3,7 @@ | |
| 3 3 | 
             
              <% if object.component_overlay && object.component_overlay[:component] == "icon_circle" %>
         | 
| 4 4 | 
             
                <%= pb_rails("flex", props: { display: "display_inline_block", position: "relative" }) do %>
         | 
| 5 5 | 
             
                  <%= content_tag(:div, data: { initials: object.initials }, class: "avatar_wrapper") do %>
         | 
| 6 | 
            -
                    <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error }) if object.image_url.present? %>
         | 
| 6 | 
            +
                    <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error, classname: object.grayscale ? "grayscale" : "" }) if object.image_url.present? %>
         | 
| 7 7 | 
             
                  <% end %>
         | 
| 8 8 | 
             
                  <%= pb_rails("card", props: { border_none: true, border_radius: "rounded", dark: object.dark, position: "absolute" }.merge(specific_placement_style)) do %>
         | 
| 9 9 |  | 
| @@ -13,7 +13,7 @@ | |
| 13 13 | 
             
              <% elsif object.component_overlay && object.component_overlay[:component] == "badge" %>
         | 
| 14 14 | 
             
              <%= pb_rails("flex", props: { display: "display_inline_block", position: "relative" }) do %>
         | 
| 15 15 | 
             
                <%= content_tag(:div, data: { initials: object.initials }, class: "avatar_wrapper") do %>
         | 
| 16 | 
            -
                  <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error }) if object.image_url.present? %>
         | 
| 16 | 
            +
                  <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error, classname: object.grayscale ? "grayscale" : "" }) if object.image_url.present? %>
         | 
| 17 17 | 
             
                <% end %>
         | 
| 18 18 | 
             
                <%= pb_rails("card", props: { border_none: true, border_radius: "rounded", dark: object.dark, padding: "none", position: "absolute" }.merge(specific_placement_style)) do %>
         | 
| 19 19 | 
             
                <%= pb_rails("badge", props: { dark: object.dark, rounded: true, text: object.component_overlay[:text], variant: object.component_overlay[:variant] }) %>
         | 
| @@ -21,7 +21,7 @@ | |
| 21 21 | 
             
                <% end %>
         | 
| 22 22 | 
             
              <% else %>
         | 
| 23 23 | 
             
                <%= content_tag(:div, data: { initials: object.initials }, class: "avatar_wrapper") do %>
         | 
| 24 | 
            -
                  <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error }) if object.image_url.present? %>
         | 
| 24 | 
            +
                  <%= pb_rails("image", props: { alt: object.alt_text, url: object.image_url, on_error: object.handle_img_error, classname: object.grayscale ? "grayscale" : "" }) if object.image_url.present? %>
         | 
| 25 25 | 
             
                <% end %>
         | 
| 26 26 | 
             
                <%= pb_rails("online_status", props: object.online_status_props) if object.status %>
         | 
| 27 27 | 
             
              <% end %>
         | 
| @@ -106,3 +106,21 @@ test('renders with online status', () => { | |
| 106 106 | 
             
              const onlineStatus = onlineStatusAvatar.querySelector('.pb_online_status_kit_online_size_md')
         | 
| 107 107 | 
             
              expect(onlineStatus).toBeInTheDocument();
         | 
| 108 108 | 
             
            });
         | 
| 109 | 
            +
             | 
| 110 | 
            +
            test('renders with grayscale filter', () => {
         | 
| 111 | 
            +
              render(
         | 
| 112 | 
            +
                <Avatar
         | 
| 113 | 
            +
                    data={{ testid: testId }}
         | 
| 114 | 
            +
                    grayscale
         | 
| 115 | 
            +
                    imageAlt={imageAlt}
         | 
| 116 | 
            +
                    imageUrl={imageUrl}
         | 
| 117 | 
            +
                    name={name}
         | 
| 118 | 
            +
                />
         | 
| 119 | 
            +
              );
         | 
| 120 | 
            +
             | 
| 121 | 
            +
              const grayscaleAvatar = screen.getByTestId(testId);
         | 
| 122 | 
            +
              expect(grayscaleAvatar).toBeInTheDocument();
         | 
| 123 | 
            +
             | 
| 124 | 
            +
              const grayscaleImage = grayscaleAvatar.querySelector('.grayscale')
         | 
| 125 | 
            +
              expect(grayscaleImage).toBeInTheDocument();
         | 
| 126 | 
            +
            });
         | 
| @@ -0,0 +1,16 @@ | |
| 1 | 
            +
            import React from 'react'
         | 
| 2 | 
            +
            import Avatar from '../../pb_avatar/_avatar'
         | 
| 3 | 
            +
             | 
| 4 | 
            +
            const AvatarGrayscale = (props) => {
         | 
| 5 | 
            +
              return (
         | 
| 6 | 
            +
                <Avatar
         | 
| 7 | 
            +
                    grayscale
         | 
| 8 | 
            +
                    imageAlt="Terry Johnson Standing"
         | 
| 9 | 
            +
                    imageUrl="https://randomuser.me/api/portraits/men/44.jpg"
         | 
| 10 | 
            +
                    name="Terry Johnson"
         | 
| 11 | 
            +
                    {...props}
         | 
| 12 | 
            +
                />
         | 
| 13 | 
            +
              )
         | 
| 14 | 
            +
            }
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            export default AvatarGrayscale
         | 
| @@ -6,6 +6,7 @@ examples: | |
| 6 6 | 
             
                - avatar_status: Status
         | 
| 7 7 | 
             
                - avatar_circle_icon_component_overlay: Icon Circle Component Overlay
         | 
| 8 8 | 
             
                - avatar_badge_component_overlay: Badge Component Overlay
         | 
| 9 | 
            +
                - avatar_grayscale: Grayscale
         | 
| 9 10 | 
             
              react:
         | 
| 10 11 | 
             
                - avatar_default: Default
         | 
| 11 12 | 
             
                - avatar_monogram: Monogram
         | 
| @@ -13,6 +14,7 @@ examples: | |
| 13 14 | 
             
                - avatar_status: Status
         | 
| 14 15 | 
             
                - avatar_circle_icon_component_overlay: Icon Circle Component Overlay
         | 
| 15 16 | 
             
                - avatar_badge_component_overlay: Badge Component Overlay
         | 
| 17 | 
            +
                - avatar_grayscale: Grayscale
         | 
| 16 18 | 
             
              swift:
         | 
| 17 19 | 
             
                - avatar_default_swift: Default
         | 
| 18 20 | 
             
                - avatar_monogram_swift: Monogram
         | 
| @@ -4,3 +4,4 @@ export { default as AvatarStatus } from './_avatar_status.jsx' | |
| 4 4 | 
             
            export { default as AvatarNoImage } from './_avatar_no_image.jsx'
         | 
| 5 5 | 
             
            export { default as AvatarCircleIconComponentOverlay } from './_avatar_circle_icon_component_overlay.jsx'
         | 
| 6 6 | 
             
            export { default as AvatarBadgeComponentOverlay } from './_avatar_badge_component_overlay.jsx'
         | 
| 7 | 
            +
            export { default as AvatarGrayscale } from './_avatar_grayscale.jsx'
         | 
| @@ -1,5 +1,5 @@ | |
| 1 1 | 
             
            <% if object.draggable_item %>
         | 
| 2 | 
            -
                <%= pb_rails("draggable/draggable_item", props:{drag_id: object.drag_id}) do %>
         | 
| 2 | 
            +
                <%= pb_rails("draggable/draggable_item", props:{drag_id: object.drag_id, classname: drop_zone_line_color ? line_color_class : nil}) do %>
         | 
| 3 3 | 
             
                    <%= pb_content_tag(object.tag) do %>
         | 
| 4 4 | 
             
                        <% if object.draggable_item %>
         | 
| 5 5 | 
             
                            <%= pb_rails("flex", props: { align: "center" }) do %>
         | 
| @@ -24,6 +24,9 @@ module Playbook | |
| 24 24 | 
             
                                     default: true
         | 
| 25 25 | 
             
                  prop :items, type: Playbook::Props::Array,
         | 
| 26 26 | 
             
                               default: []
         | 
| 27 | 
            +
                  prop :drop_zone_line_color, type: Playbook::Props::Enum,
         | 
| 28 | 
            +
                                              values: ["primary", "purple", nil],
         | 
| 29 | 
            +
                                              default: nil
         | 
| 27 30 |  | 
| 28 31 | 
             
                  def classname
         | 
| 29 32 | 
             
                    generate_classname("pb_card_kit",
         | 
| @@ -60,6 +63,15 @@ module Playbook | |
| 60 63 | 
             
                  def border_radius_class
         | 
| 61 64 | 
             
                    border_radius != "md" ? "border_radius_#{border_radius}" : nil
         | 
| 62 65 | 
             
                  end
         | 
| 66 | 
            +
             | 
| 67 | 
            +
                  def line_color_class
         | 
| 68 | 
            +
                    case drop_zone_line_color
         | 
| 69 | 
            +
                    when "primary"
         | 
| 70 | 
            +
                      "drop_zone_color_primary"
         | 
| 71 | 
            +
                    when "purple"
         | 
| 72 | 
            +
                      "drop_zone_color_purple"
         | 
| 73 | 
            +
                    end
         | 
| 74 | 
            +
                  end
         | 
| 63 75 | 
             
                end
         | 
| 64 76 | 
             
              end
         | 
| 65 77 | 
             
            end
         | 
| @@ -1,16 +1,9 @@ | |
| 1 1 | 
             
            <%= pb_content_tag(:label) do %>
         | 
| 2 2 | 
             
              <%= content.presence || object.input %>
         | 
| 3 | 
            -
               | 
| 4 | 
            -
                 | 
| 5 | 
            -
             | 
| 6 | 
            -
             | 
| 7 | 
            -
                </span>
         | 
| 8 | 
            -
              <% else %>
         | 
| 9 | 
            -
                <span data-pb-checkbox-icon-span="true" class="pb_checkbox_checkmark">
         | 
| 10 | 
            -
                  <%= pb_rails("icon", props: { icon: "check", classname: "check_icon", fixed_width: true}) %>
         | 
| 11 | 
            -
                  <%= pb_rails("icon", props: { icon: "minus", classname: "indeterminate_icon hidden", fixed_width: true}) %>
         | 
| 12 | 
            -
                </span>
         | 
| 13 | 
            -
              <% end %>
         | 
| 3 | 
            +
              <span data-pb-checkbox-icon-span="true" class="pb_checkbox_checkmark">
         | 
| 4 | 
            +
                <%= pb_rails("icon", props: { icon: "check", classname: "check_icon", fixed_width: true}) %>
         | 
| 5 | 
            +
                <%= pb_rails("icon", props: { icon: "minus", classname: "indeterminate_icon hidden", fixed_width: true}) %>
         | 
| 6 | 
            +
              </span>
         | 
| 14 7 | 
             
              <span class="pb_checkbox_label">
         | 
| 15 8 | 
             
                <%= pb_rails("body", props: { status: object.checkbox_label_status, text: object.text, dark: object.dark, margin_right: object.form_spacing ? "xs" : "" }) %>
         | 
| 16 9 | 
             
              </span>
         | 
| @@ -5,7 +5,8 @@ module Playbook | |
| 5 5 | 
             
                class Checkbox < Playbook::KitBase
         | 
| 6 6 | 
             
                  prop :error, type: Playbook::Props::Boolean, default: false
         | 
| 7 7 | 
             
                  prop :checked, type: Playbook::Props::Boolean, default: false
         | 
| 8 | 
            -
                  prop : | 
| 8 | 
            +
                  prop :indeterminate_main, type: Playbook::Props::Boolean, default: false
         | 
| 9 | 
            +
                  prop :indeterminate_parent
         | 
| 9 10 | 
             
                  prop :text
         | 
| 10 11 | 
             
                  prop :value
         | 
| 11 12 | 
             
                  prop :name
         | 
| @@ -19,7 +20,7 @@ module Playbook | |
| 19 20 | 
             
                                      default: false
         | 
| 20 21 |  | 
| 21 22 | 
             
                  def classname
         | 
| 22 | 
            -
                    generate_classname("pb_checkbox_kit", checked_class) +  | 
| 23 | 
            +
                    generate_classname("pb_checkbox_kit", checked_class) + error_class
         | 
| 23 24 | 
             
                  end
         | 
| 24 25 |  | 
| 25 26 | 
             
                  def input
         | 
| @@ -30,6 +31,13 @@ module Playbook | |
| 30 31 | 
             
                    error ? "negative" : nil
         | 
| 31 32 | 
             
                  end
         | 
| 32 33 |  | 
| 34 | 
            +
                  def data
         | 
| 35 | 
            +
                    Hash(prop(:data)).merge(
         | 
| 36 | 
            +
                      pb_checkbox_indeterminate_main: indeterminate_main,
         | 
| 37 | 
            +
                      pb_checkbox_indeterminate_parent: indeterminate_parent
         | 
| 38 | 
            +
                    )
         | 
| 39 | 
            +
                  end
         | 
| 40 | 
            +
             | 
| 33 41 | 
             
                private
         | 
| 34 42 |  | 
| 35 43 | 
             
                  def error_class
         | 
| @@ -39,10 +47,6 @@ module Playbook | |
| 39 47 | 
             
                  def checked_class
         | 
| 40 48 | 
             
                    checked ? "on" : "off"
         | 
| 41 49 | 
             
                  end
         | 
| 42 | 
            -
             | 
| 43 | 
            -
                  def indeterminate_class
         | 
| 44 | 
            -
                    indeterminate ? " indeterminate" : ""
         | 
| 45 | 
            -
                  end
         | 
| 46 50 | 
             
                end
         | 
| 47 51 | 
             
              end
         | 
| 48 52 | 
             
            end
         | 
| @@ -9,11 +9,10 @@ | |
| 9 9 | 
             
                <tr>
         | 
| 10 10 | 
             
                  <th>
         | 
| 11 11 | 
             
                    <%= pb_rails("checkbox", props: {
         | 
| 12 | 
            -
                      checked: true,
         | 
| 13 12 | 
             
                      text: "Uncheck All",
         | 
| 14 13 | 
             
                      value: "checkbox-value",
         | 
| 15 14 | 
             
                      name: "main-checkbox",
         | 
| 16 | 
            -
                       | 
| 15 | 
            +
                      indeterminate_main: true,
         | 
| 17 16 | 
             
                      id: "indeterminate-checkbox"
         | 
| 18 17 | 
             
                    }) %>
         | 
| 19 18 | 
             
                  </th>
         | 
| @@ -30,55 +29,10 @@ | |
| 30 29 | 
             
                        value: checkbox[:id],
         | 
| 31 30 | 
             
                        name: "#{checkbox[:id]}-indeterminate-checkbox",
         | 
| 32 31 | 
             
                        id: "#{checkbox[:id]}-indeterminate-checkbox",
         | 
| 32 | 
            +
                        indeterminate_parent: "indeterminate-checkbox",
         | 
| 33 33 | 
             
                      }) %>
         | 
| 34 34 | 
             
                    </td>
         | 
| 35 35 | 
             
                  </tr>
         | 
| 36 36 | 
             
                <% end %>
         | 
| 37 37 | 
             
              </tbody>
         | 
| 38 38 | 
             
            <% end %>
         | 
| 39 | 
            -
             | 
| 40 | 
            -
            <script>
         | 
| 41 | 
            -
              document.addEventListener('DOMContentLoaded', function() {
         | 
| 42 | 
            -
                const mainCheckboxWrapper = document.getElementById('indeterminate-checkbox');
         | 
| 43 | 
            -
                const mainCheckbox = document.getElementsByName("main-checkbox")[0];
         | 
| 44 | 
            -
                const childCheckboxes = document.querySelectorAll('input[type="checkbox"][id$="indeterminate-checkbox"]');
         | 
| 45 | 
            -
             | 
| 46 | 
            -
                const updateMainCheckbox = () => {
         | 
| 47 | 
            -
                  // Count the number of checked child checkboxes
         | 
| 48 | 
            -
                  const checkedCount = Array.from(childCheckboxes).filter(cb => cb.checked).length;
         | 
| 49 | 
            -
                  // Determine if the main checkbox should be in an indeterminate state
         | 
| 50 | 
            -
                  const indeterminate = checkedCount > 0 && checkedCount < childCheckboxes.length;
         | 
| 51 | 
            -
                  
         | 
| 52 | 
            -
                  // Set the main checkbox states
         | 
| 53 | 
            -
                  mainCheckbox.indeterminate = indeterminate;
         | 
| 54 | 
            -
                  mainCheckbox.checked = checkedCount > 0;
         | 
| 55 | 
            -
             | 
| 56 | 
            -
                  // Determine the main checkbox label based on the number of checked checkboxes
         | 
| 57 | 
            -
                  const text = checkedCount === 0 ? 'Check All' : 'Uncheck All';
         | 
| 58 | 
            -
             | 
| 59 | 
            -
                  // Determine the icon class to add and remove based on the number of checked checkboxes
         | 
| 60 | 
            -
                  const iconClassToAdd = checkedCount === 0 ? 'pb_checkbox_checkmark' : 'pb_checkbox_indeterminate';
         | 
| 61 | 
            -
                  const iconClassToRemove = checkedCount === 0 ? 'pb_checkbox_indeterminate' : 'pb_checkbox_checkmark';
         | 
| 62 | 
            -
             | 
| 63 | 
            -
                  // Update main checkbox label
         | 
| 64 | 
            -
                  mainCheckboxWrapper.getElementsByClassName('pb_body_kit')[0].textContent = text;
         | 
| 65 | 
            -
                  
         | 
| 66 | 
            -
                  // Add and remove the icon class to the main checkbox wrapper
         | 
| 67 | 
            -
                  mainCheckboxWrapper.querySelector('[data-pb-checkbox-icon-span]').classList.add(iconClassToAdd);
         | 
| 68 | 
            -
                  mainCheckboxWrapper.querySelector('[data-pb-checkbox-icon-span]').classList.remove(iconClassToRemove);
         | 
| 69 | 
            -
                  
         | 
| 70 | 
            -
                  // Toggle the visibility of the checkbox icon based on the indeterminate state
         | 
| 71 | 
            -
                  mainCheckboxWrapper.getElementsByClassName("indeterminate_icon")[0].classList.toggle('hidden', !indeterminate);
         | 
| 72 | 
            -
                  mainCheckboxWrapper.getElementsByClassName("check_icon")[0].classList.toggle('hidden', indeterminate);
         | 
| 73 | 
            -
                };
         | 
| 74 | 
            -
             | 
| 75 | 
            -
                mainCheckbox.addEventListener('change', function() {
         | 
| 76 | 
            -
                  childCheckboxes.forEach(cb => cb.checked = this.checked);
         | 
| 77 | 
            -
                  updateMainCheckbox();
         | 
| 78 | 
            -
                });
         | 
| 79 | 
            -
             | 
| 80 | 
            -
                childCheckboxes.forEach(cb => {
         | 
| 81 | 
            -
                  cb.addEventListener('change', updateMainCheckbox);
         | 
| 82 | 
            -
                });
         | 
| 83 | 
            -
              });
         | 
| 84 | 
            -
            </script>
         | 
| @@ -0,0 +1 @@ | |
| 1 | 
            +
            If you want to use indeterminate, "check/uncheck all" checkboxes, add `indeterminate_main: true` and an `id` to the main checkbox. Then, add an `indeterminate_parent` prop with the main checkbox's `id` to the children checkboxes.
         | 
| @@ -0,0 +1,56 @@ | |
| 1 | 
            +
            import PbEnhancedElement from "../pb_enhanced_element"
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            const INDETERMINATE_MAIN_CHECKBOX_SELECTOR = "[data-pb-checkbox-indeterminate-main='true']"
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            export default class PbCheckbox extends PbEnhancedElement {
         | 
| 6 | 
            +
              static get selector() {
         | 
| 7 | 
            +
                return INDETERMINATE_MAIN_CHECKBOX_SELECTOR
         | 
| 8 | 
            +
              }
         | 
| 9 | 
            +
             | 
| 10 | 
            +
              connect() {
         | 
| 11 | 
            +
                const mainCheckboxWrapper = this.element;
         | 
| 12 | 
            +
                const mainCheckbox = mainCheckboxWrapper.querySelector('input')
         | 
| 13 | 
            +
                const childCheckboxes = document.querySelectorAll(`[data-pb-checkbox-indeterminate-parent="${this.element.id}"] input[type="checkbox"]`);
         | 
| 14 | 
            +
             | 
| 15 | 
            +
                const updateMainCheckbox = () => {
         | 
| 16 | 
            +
                  // Count the number of checked child checkboxes
         | 
| 17 | 
            +
                  const checkedCount = Array.from(childCheckboxes).filter(cb => cb.checked).length;
         | 
| 18 | 
            +
                  // Determine if the main checkbox should be in an indeterminate state
         | 
| 19 | 
            +
                  const indeterminate = checkedCount > 0 && checkedCount < childCheckboxes.length;
         | 
| 20 | 
            +
                  
         | 
| 21 | 
            +
                  // Set the main checkbox states
         | 
| 22 | 
            +
                  mainCheckbox.indeterminate = indeterminate;
         | 
| 23 | 
            +
                  mainCheckbox.checked = checkedCount > 0;
         | 
| 24 | 
            +
             | 
| 25 | 
            +
                  // Determine the main checkbox label based on the number of checked checkboxes
         | 
| 26 | 
            +
                  const text = checkedCount === 0 ? 'Check All' : 'Uncheck All';
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                  // Determine the icon class to add and remove based on the number of checked checkboxes
         | 
| 29 | 
            +
                  const iconClassToAdd = checkedCount === 0 ? 'pb_checkbox_checkmark' : 'pb_checkbox_indeterminate';
         | 
| 30 | 
            +
                  const iconClassToRemove = checkedCount === 0 ? 'pb_checkbox_indeterminate' : 'pb_checkbox_checkmark';
         | 
| 31 | 
            +
             | 
| 32 | 
            +
                  // Update main checkbox label
         | 
| 33 | 
            +
                  mainCheckboxWrapper.getElementsByClassName('pb_body_kit')[0].textContent = text;
         | 
| 34 | 
            +
                  
         | 
| 35 | 
            +
                  // Add and remove the icon class to the main checkbox wrapper
         | 
| 36 | 
            +
                  mainCheckboxWrapper.querySelector('[data-pb-checkbox-icon-span]').classList.add(iconClassToAdd);
         | 
| 37 | 
            +
                  mainCheckboxWrapper.querySelector('[data-pb-checkbox-icon-span]').classList.remove(iconClassToRemove);
         | 
| 38 | 
            +
                  
         | 
| 39 | 
            +
                  // Toggle the visibility of the checkbox icon based on the indeterminate state
         | 
| 40 | 
            +
                  mainCheckboxWrapper.getElementsByClassName("indeterminate_icon")[0].classList.toggle('hidden', !indeterminate);
         | 
| 41 | 
            +
                  mainCheckboxWrapper.getElementsByClassName("check_icon")[0].classList.toggle('hidden', indeterminate);
         | 
| 42 | 
            +
                };
         | 
| 43 | 
            +
             | 
| 44 | 
            +
                // Set indeterminate icon on main checkbox if initial children checkboxes are checked
         | 
| 45 | 
            +
                updateMainCheckbox();
         | 
| 46 | 
            +
             | 
| 47 | 
            +
                this.element.querySelector('input').addEventListener('change', function() {
         | 
| 48 | 
            +
                  childCheckboxes.forEach(cb => cb.checked = this.checked);
         | 
| 49 | 
            +
                  updateMainCheckbox();
         | 
| 50 | 
            +
                });
         | 
| 51 | 
            +
             | 
| 52 | 
            +
                childCheckboxes.forEach(cb => {
         | 
| 53 | 
            +
                  cb.addEventListener('change', updateMainCheckbox);
         | 
| 54 | 
            +
                });
         | 
| 55 | 
            +
              }
         | 
| 56 | 
            +
            }
         | 
| @@ -1,4 +1,4 @@ | |
| 1 | 
            -
            <%= pb_rails("date_picker", props: { | 
| 2 | 
            -
              error: "Invalid date. Please pick a valid date.",
         | 
| 1 | 
            +
            <%= pb_rails("date_picker", props: {
         | 
| 2 | 
            +
              error: raw(pb_rails("icon", props: { icon: "warning" }) + " Invalid date. Please pick a valid date."),
         | 
| 3 3 | 
             
              picker_id: "date-picker-error"
         | 
| 4 4 | 
             
            }) %>
         | 
| @@ -10,7 +10,13 @@ | |
| 10 10 | 
             
              { id: "63", text: "Task 3" }
         | 
| 11 11 | 
             
            ] %>
         | 
| 12 12 |  | 
| 13 | 
            -
             | 
| 13 | 
            +
            <% data_line = [
         | 
| 14 | 
            +
              { id: "71", text: "Task 1" },
         | 
| 15 | 
            +
              { id: "72", text: "Task 2" },
         | 
| 16 | 
            +
              { id: "73", text: "Task 3" }
         | 
| 17 | 
            +
            ] %>
         | 
| 18 | 
            +
             | 
| 19 | 
            +
            <%= pb_rails("flex", props: { justify: "between" }) do %>
         | 
| 14 20 | 
             
              <%= pb_rails("flex/flex_item", props: { margin_right: "xl" }) do %>
         | 
| 15 21 | 
             
                <%= pb_rails("draggable", props: { drop_zone_type: "shadow", initial_items: data_shadow }) do %>
         | 
| 16 22 | 
             
                  <%= pb_rails("caption", props: { margin_bottom: "xs", text: "Shadow", text_align: "center" }) %>
         | 
| @@ -40,4 +46,19 @@ | |
| 40 46 | 
             
                  <% end %>
         | 
| 41 47 | 
             
                <% end %>
         | 
| 42 48 | 
             
              <% end %>
         | 
| 49 | 
            +
             | 
| 50 | 
            +
              <%= pb_rails("flex/flex_item", props: { margin_right: "xl" }) do %>
         | 
| 51 | 
            +
                <%= pb_rails("draggable", props: { drop_zone_type: "line", initial_items: data_line }) do %>
         | 
| 52 | 
            +
                  <%= pb_rails("caption", props: { margin_bottom: "xs", text: "Line", text_align: "center" }) %>
         | 
| 53 | 
            +
                  <%= pb_rails("draggable/draggable_container", props: { drop_zone_direction: "vertical", html_options: { style: { width: "200px" } } }) do %>
         | 
| 54 | 
            +
                    <% data_line.each do |item| %>
         | 
| 55 | 
            +
                      <%= pb_rails("card", props: { drag_id: item[:id], draggable_item: true, margin_bottom: "xs", padding: "xs", padding_right: "xl", drop_zone_line_color: "primary" }) do %>
         | 
| 56 | 
            +
                        <%= pb_rails("flex", props: { align_items: "stretch", flex_direction: "column" }) do %>
         | 
| 57 | 
            +
                          <%= pb_rails("body", props: { text: item[:text] }) %>
         | 
| 58 | 
            +
                        <% end %>
         | 
| 59 | 
            +
                      <% end %>
         | 
| 60 | 
            +
                    <% end %>
         | 
| 61 | 
            +
                  <% end %>
         | 
| 62 | 
            +
                <% end %>
         | 
| 63 | 
            +
              <% end %>
         | 
| 43 64 | 
             
            <% end %>
         | 
| @@ -0,0 +1,55 @@ | |
| 1 | 
            +
            <% initial_items = [
         | 
| 2 | 
            +
              {
         | 
| 3 | 
            +
                id: "211",
         | 
| 4 | 
            +
                url: "https://unsplash.it/500/400/?image=633",
         | 
| 5 | 
            +
              },
         | 
| 6 | 
            +
              {
         | 
| 7 | 
            +
                id: "212",
         | 
| 8 | 
            +
                url: "https://unsplash.it/500/400/?image=634",
         | 
| 9 | 
            +
              },
         | 
| 10 | 
            +
              {
         | 
| 11 | 
            +
                id: "213",
         | 
| 12 | 
            +
                url: "https://unsplash.it/500/400/?image=637",
         | 
| 13 | 
            +
              },
         | 
| 14 | 
            +
            ] %>
         | 
| 15 | 
            +
             | 
| 16 | 
            +
            <% next_init_items = [
         | 
| 17 | 
            +
              {
         | 
| 18 | 
            +
                id: "2111",
         | 
| 19 | 
            +
                url: "https://unsplash.it/500/400/?image=633",
         | 
| 20 | 
            +
              },
         | 
| 21 | 
            +
              {
         | 
| 22 | 
            +
                id: "2112",
         | 
| 23 | 
            +
                url: "https://unsplash.it/500/400/?image=634",
         | 
| 24 | 
            +
              },
         | 
| 25 | 
            +
              {
         | 
| 26 | 
            +
                id: "2113",
         | 
| 27 | 
            +
                url: "https://unsplash.it/500/400/?image=637",
         | 
| 28 | 
            +
              },
         | 
| 29 | 
            +
            ] %>
         | 
| 30 | 
            +
             | 
| 31 | 
            +
            <%= pb_rails("draggable", props: {initial_items: initial_items, drop_zone_type: "line"}) do %>
         | 
| 32 | 
            +
              <%= pb_rails("draggable/draggable_container", props: { drop_zone_direction: "vertical" }) do %>
         | 
| 33 | 
            +
                <%= pb_rails("flex", props: { gap: "sm", orientation: "column", height: "367px" }) do %>
         | 
| 34 | 
            +
                  <% initial_items.each do |item| %>
         | 
| 35 | 
            +
                    <%= pb_rails("draggable/draggable_item", props:{drag_id: item[:id], drop_zone_line_color: "purple"}) do %>
         | 
| 36 | 
            +
                      <%= pb_rails("image", props: { alt: item[:id], size: "md", url: item[:url] }) %>
         | 
| 37 | 
            +
                    <% end %>
         | 
| 38 | 
            +
                  <% end %>
         | 
| 39 | 
            +
                <% end %>
         | 
| 40 | 
            +
              <% end %>
         | 
| 41 | 
            +
            <% end %>
         | 
| 42 | 
            +
             | 
| 43 | 
            +
            <br/>
         | 
| 44 | 
            +
             | 
| 45 | 
            +
            <%= pb_rails("draggable", props: {initial_items: next_init_items, drop_zone_type: "line"}) do %>
         | 
| 46 | 
            +
              <%= pb_rails("draggable/draggable_container", props: { drop_zone_direction: "horizontal" }) do %>
         | 
| 47 | 
            +
                <%= pb_rails("flex", props: { gap: "sm", html_options: { style: "width: 332px;" } }) do %>
         | 
| 48 | 
            +
                  <% initial_items.each do |item| %>
         | 
| 49 | 
            +
                    <%= pb_rails("draggable/draggable_item", props:{drag_id: item[:id], drop_zone_line_color: "primary"}) do %>
         | 
| 50 | 
            +
                      <%= pb_rails("image", props: { alt: item[:id], size: "md", url: item[:url] }) %>
         | 
| 51 | 
            +
                    <% end %>
         | 
| 52 | 
            +
                  <% end %>
         | 
| 53 | 
            +
                <% end %>
         | 
| 54 | 
            +
              <% end %>
         | 
| 55 | 
            +
            <% end %>
         | 
| @@ -0,0 +1,5 @@ | |
| 1 | 
            +
            When using the "line" style, make sure to set the appropriate `direction` attribute within the `drop_zone_direction` prop on the `draggable/draggable_container` component based on the orientation of your draggable view: "vertical" or "horizontal." Note that the direction attribute only applies to the "line" style and does not affect other drop zone styles. Also, set the `drop_zone_line_color` prop on the `draggable/draggable_item` component to "primary" or "purple".
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            The length of the line is calculated based off of the width (for "vertical") or height (for "horizontal") of the parent container holding the draggable items. 
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            Additionally, if the parent container of the `draggable`/`draggable/draggable_container` (or a subcontainer within) does not have a set height (for "vertical") or width (for "horizontal"), like the [Draggable Drop Zones doc example](https://playbook.powerapp.cloud/kits/draggable/rails#draggable-drop-zones) does, elements on the page may jump up (for "vertical") or to the left (for "horizontal") when an item is actively being dragged. To prevent this, give a parent element a fixed height (for "vertical") or width (for "horizontal") as demonstrated in this doc example.
         | 
| @@ -0,0 +1,5 @@ | |
| 1 | 
            +
            The Draggable kit lets you customize the style of drop zones that appear when dragging an item.
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            By default, drop zones are in the "ghost" style, but you can also choose from "shadow," "outline," and "line."
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            When using the "line" type, make sure to set the appropriate `direction` attribute on the `draggable/draggable_container` component based on the orientation of your draggable view: "vertical" or "horizontal." Note that the direction attribute only applies to the "line" type and does not affect other drop zone styles. For more on the "line" style in particular, check out the [Draggable Drop Zones Line doc example](https://playbook.powerapp.cloud/kits/draggable/rails#draggable-drop-zones-line).
         | 
| @@ -0,0 +1,59 @@ | |
| 1 | 
            +
            import React, { useState } from "react";
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            import Flex from '../../pb_flex/_flex'
         | 
| 4 | 
            +
            import Image from '../../pb_image/_image'
         | 
| 5 | 
            +
            import Draggable from '../../pb_draggable/_draggable'
         | 
| 6 | 
            +
            import { DraggableProvider } from '../../pb_draggable/context'
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            const data = [
         | 
| 9 | 
            +
              {
         | 
| 10 | 
            +
                id: "100",
         | 
| 11 | 
            +
                url: "https://unsplash.it/500/400/?image=638",
         | 
| 12 | 
            +
              },
         | 
| 13 | 
            +
              {
         | 
| 14 | 
            +
                id: "200",
         | 
| 15 | 
            +
                url: "https://unsplash.it/500/400/?image=639",
         | 
| 16 | 
            +
              },
         | 
| 17 | 
            +
              {
         | 
| 18 | 
            +
                id: "300",
         | 
| 19 | 
            +
                url: "https://unsplash.it/500/400/?image=640",
         | 
| 20 | 
            +
              },
         | 
| 21 | 
            +
            ];
         | 
| 22 | 
            +
             | 
| 23 | 
            +
            const DraggableDefault = (props) => {
         | 
| 24 | 
            +
              const [initialState, setInitialState] = useState(data);
         | 
| 25 | 
            +
             | 
| 26 | 
            +
              return (
         | 
| 27 | 
            +
                <>
         | 
| 28 | 
            +
                <DraggableProvider initialItems={data}
         | 
| 29 | 
            +
                    onReorder={(items) => setInitialState(items)}
         | 
| 30 | 
            +
                >
         | 
| 31 | 
            +
                    <Draggable.Container {...props}>
         | 
| 32 | 
            +
                    <Flex>
         | 
| 33 | 
            +
                        {initialState.map(({ id, url }) => (
         | 
| 34 | 
            +
                          <Draggable.Item dragId={id} 
         | 
| 35 | 
            +
                              key={id}
         | 
| 36 | 
            +
                              onDrag={() => console.log(`${id} drag!`)}
         | 
| 37 | 
            +
                              onDragEnd={() => console.log(`${id} drag end!`)}
         | 
| 38 | 
            +
                              onDragEnter={() => console.log(`${id} drag enter!`)}
         | 
| 39 | 
            +
                              onDragLeave={() => console.log(`${id} drag leave!`)}
         | 
| 40 | 
            +
                              onDragOver={() => console.log(`${id} drag over!`)}
         | 
| 41 | 
            +
                              onDragStart={() => console.log(`${id} drag start!`)}
         | 
| 42 | 
            +
                              onDrop={() => console.log(`${id} drop!`)}
         | 
| 43 | 
            +
                          >
         | 
| 44 | 
            +
                            <Image alt={id} 
         | 
| 45 | 
            +
                                margin="xs"
         | 
| 46 | 
            +
                                size="md" 
         | 
| 47 | 
            +
                                url={url} 
         | 
| 48 | 
            +
                            />
         | 
| 49 | 
            +
                          </Draggable.Item>
         | 
| 50 | 
            +
                        ))}
         | 
| 51 | 
            +
                     </Flex>
         | 
| 52 | 
            +
                    </Draggable.Container>
         | 
| 53 | 
            +
                </DraggableProvider>
         | 
| 54 | 
            +
                </>
         | 
| 55 | 
            +
             | 
| 56 | 
            +
              );
         | 
| 57 | 
            +
            };
         | 
| 58 | 
            +
             | 
| 59 | 
            +
            export default DraggableDefault;
         | 
| @@ -0,0 +1 @@ | |
| 1 | 
            +
            You can add drag event listeners for `onDrag`, `onDragEnd`, `onDragEnter`, `onDragLeave`, `onDragOver`, `onDragStart`, and `onDrop`.
         | 
| @@ -9,6 +9,7 @@ examples: | |
| 9 9 | 
             
              - draggable_drop_zones: Draggable Drop Zones
         | 
| 10 10 | 
             
              - draggable_drop_zones_colors: Draggable Drop Zones Colors
         | 
| 11 11 | 
             
              - draggable_drop_zones_line: Draggable Drop Zones Line
         | 
| 12 | 
            +
              - draggable_event_listeners: Draggable Event Listeners
         | 
| 12 13 |  | 
| 13 14 | 
             
              rails:
         | 
| 14 15 | 
             
              - draggable_default: Default
         | 
| @@ -19,4 +20,5 @@ examples: | |
| 19 20 | 
             
              - draggable_multiple_containers: Dragging Across Multiple Containers
         | 
| 20 21 | 
             
              - draggable_drop_zones: Draggable Drop Zones
         | 
| 21 22 | 
             
              - draggable_drop_zones_colors: Draggable Drop Zones Colors
         | 
| 23 | 
            +
              - draggable_drop_zones_line: Draggable Drop Zones Line
         | 
| 22 24 | 
             
              - draggable_event_listeners: Draggable Event Listeners
         | 
| @@ -6,4 +6,5 @@ export { default as DraggableMultipleContainers } from './_draggable_multiple_co | |
| 6 6 | 
             
            export { default as DraggableWithTable } from './_draggable_with_table.jsx'
         | 
| 7 7 | 
             
            export { default as DraggableDropZones } from './_draggable_drop_zones.jsx'
         | 
| 8 8 | 
             
            export { default as DraggableDropZonesColors } from './_draggable_drop_zones_colors.jsx'
         | 
| 9 | 
            -
            export { default as DraggableDropZonesLine } from './_draggable_drop_zones_line.jsx'
         | 
| 9 | 
            +
            export { default as DraggableDropZonesLine } from './_draggable_drop_zones_line.jsx'
         | 
| 10 | 
            +
            export { default as DraggableEventListeners } from './_draggable_event_listeners.jsx'
         | 
| @@ -7,13 +7,23 @@ module Playbook | |
| 7 7 | 
             
                             default: "div"
         | 
| 8 8 | 
             
                  prop :container, type: Playbook::Props::String,
         | 
| 9 9 | 
             
                                   default: ""
         | 
| 10 | 
            +
                  prop :drop_zone_direction, type: Playbook::Props::Enum,
         | 
| 11 | 
            +
                                             values: ["horizontal", "vertical", nil],
         | 
| 12 | 
            +
                                             default: nil
         | 
| 10 13 |  | 
| 11 14 | 
             
                  def data
         | 
| 12 15 | 
             
                    Hash(prop(:data)).merge(pb_draggable_container: true)
         | 
| 13 16 | 
             
                  end
         | 
| 14 17 |  | 
| 15 18 | 
             
                  def classname
         | 
| 16 | 
            -
                     | 
| 19 | 
            +
                    direction_class = case drop_zone_direction
         | 
| 20 | 
            +
                                      when "horizontal"
         | 
| 21 | 
            +
                                        "line_horizontal"
         | 
| 22 | 
            +
                                      when "vertical"
         | 
| 23 | 
            +
                                        "line_vertical"
         | 
| 24 | 
            +
                                      end
         | 
| 25 | 
            +
             | 
| 26 | 
            +
                    generate_classname("pb_draggable_container", direction_class, separator: " ")
         | 
| 17 27 | 
             
                  end
         | 
| 18 28 | 
             
                end
         | 
| 19 29 | 
             
              end
         | 
| @@ -9,13 +9,23 @@ module Playbook | |
| 9 9 | 
             
                             default: "div"
         | 
| 10 10 | 
             
                  prop :container, type: Playbook::Props::String,
         | 
| 11 11 | 
             
                                   default: ""
         | 
| 12 | 
            +
                  prop :drop_zone_line_color, type: Playbook::Props::Enum,
         | 
| 13 | 
            +
                                              values: ["primary", "purple", nil],
         | 
| 14 | 
            +
                                              default: nil
         | 
| 12 15 |  | 
| 13 16 | 
             
                  def data
         | 
| 14 17 | 
             
                    Hash(prop(:data)).merge(pb_draggable_item: true)
         | 
| 15 18 | 
             
                  end
         | 
| 16 19 |  | 
| 17 20 | 
             
                  def classname
         | 
| 18 | 
            -
                     | 
| 21 | 
            +
                    line_color_class = case drop_zone_line_color
         | 
| 22 | 
            +
                                       when "primary"
         | 
| 23 | 
            +
                                         "drop_zone_color_primary"
         | 
| 24 | 
            +
                                       when "purple"
         | 
| 25 | 
            +
                                         "drop_zone_color_purple"
         | 
| 26 | 
            +
                                       end
         | 
| 27 | 
            +
             | 
| 28 | 
            +
                    generate_classname("pb_draggable_item", line_color_class, separator: " ")
         | 
| 19 29 | 
             
                  end
         | 
| 20 30 | 
             
                end
         | 
| 21 31 | 
             
              end
         | 
| @@ -2,7 +2,7 @@ import PbEnhancedElement from "../pb_enhanced_element"; | |
| 2 2 |  | 
| 3 3 | 
             
            const DRAGGABLE_SELECTOR  = "[data-pb-draggable]";
         | 
| 4 4 | 
             
            const DRAGGABLE_CONTAINER = ".pb_draggable_container";
         | 
| 5 | 
            -
            const NEEDS_CLONE         = ["shadow", "outline"];   // clone only for these types
         | 
| 5 | 
            +
            const NEEDS_CLONE         = ["shadow", "outline", "line"];   // clone only for these types
         | 
| 6 6 |  | 
| 7 7 | 
             
            export default class PbDraggable extends PbEnhancedElement {
         | 
| 8 8 | 
             
              static get selector() { return DRAGGABLE_SELECTOR; }
         | 
| @@ -116,7 +116,9 @@ export default class PbDraggable extends PbEnhancedElement { | |
| 116 116 | 
             
                  /* ---------------------------------------------------------------- */
         | 
| 117 117 | 
             
                }
         | 
| 118 118 |  | 
| 119 | 
            -
                 | 
| 119 | 
            +
                if (this.dragZoneType !== "line") {
         | 
| 120 | 
            +
                  requestAnimationFrame(() => (event.target.style.opacity = "0.5"));
         | 
| 121 | 
            +
                }
         | 
| 120 122 | 
             
              }
         | 
| 121 123 |  | 
| 122 124 | 
             
              /* ---------------- DRAG ENTER ---------------- */
         |