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