playbook_ui 4.14.0 → 4.17.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +0 -1
- data/app/pb_kits/playbook/_playbook.scss +8 -1
- data/app/pb_kits/playbook/data/menu.yml +5 -0
- data/app/pb_kits/playbook/index.js +8 -1
- data/app/pb_kits/playbook/packs/examples.js +8 -0
- data/app/pb_kits/playbook/packs/kits/pb_progress_step.js +2 -0
- data/app/pb_kits/playbook/packs/site_styles/docs/_markdown.scss +1 -1
- data/app/pb_kits/playbook/pb_avatar/_avatar.jsx +24 -15
- data/app/pb_kits/playbook/pb_avatar/docs/_avatar_status.jsx +45 -0
- data/app/pb_kits/playbook/pb_avatar/docs/example.yml +6 -5
- data/app/pb_kits/playbook/pb_avatar/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.html.erb +32 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx +78 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.scss +63 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/avatar_action_button.rb +44 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions.html.erb +15 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions.jsx +19 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_default.html.erb +8 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_default.jsx +13 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_on_click.jsx +15 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_onclick.html.erb +14 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement.html.erb +27 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement.jsx +29 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_tooltip.html.erb +11 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/example.yml +16 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/index.js +4 -0
- data/app/pb_kits/playbook/pb_badge/_badge.jsx +20 -14
- data/app/pb_kits/playbook/pb_bar_graph/_bar_graph.jsx +9 -2
- data/app/pb_kits/playbook/pb_bar_graph/bar_graph.rb +5 -1
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_default.html.erb +2 -2
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_default.jsx +2 -2
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.html.erb +26 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.jsx +36 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend.html.erb +14 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend.jsx +23 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_description.md +3 -1
- data/app/pb_kits/playbook/pb_bar_graph/docs/example.yml +4 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_body/_body.jsx +2 -1
- data/app/pb_kits/playbook/pb_body/docs/_body_light.jsx +4 -0
- data/app/pb_kits/playbook/pb_button/_button.jsx +11 -2
- data/app/pb_kits/playbook/pb_button/docs/_button_default.jsx +6 -0
- data/app/pb_kits/playbook/pb_caption/_caption.jsx +19 -17
- data/app/pb_kits/playbook/pb_card/_card.html.erb +1 -1
- data/app/pb_kits/playbook/pb_card/_card.jsx +35 -38
- data/app/pb_kits/playbook/pb_card/_card.scss +0 -10
- data/app/pb_kits/playbook/pb_card/card.rb +9 -3
- data/app/pb_kits/playbook/pb_card/card_body.rb +1 -5
- data/app/pb_kits/playbook/pb_card/card_header.rb +0 -3
- data/app/pb_kits/playbook/pb_card/docs/_card_light.html.erb +2 -1
- data/app/pb_kits/playbook/pb_checkbox/_checkbox.jsx +17 -18
- data/app/pb_kits/playbook/pb_circle_icon_button/_circle_icon_button.html.erb +1 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/_circle_icon_button.jsx +10 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/circle_icon_button.rb +3 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_link.html.erb +11 -0
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/_circle_icon_button_link.jsx +25 -0
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/example.yml +3 -1
- data/app/pb_kits/playbook/pb_circle_icon_button/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_contact/_contact.html.erb +16 -3
- data/app/pb_kits/playbook/pb_contact/_contact.jsx +59 -34
- data/app/pb_kits/playbook/pb_contact/contact.rb +2 -0
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.html.erb +6 -1
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.jsx +5 -0
- data/app/pb_kits/playbook/pb_contact/docs/_contact_with_detail.html.erb +6 -0
- data/app/pb_kits/playbook/pb_contact/docs/_contact_with_detail.jsx +5 -0
- data/app/pb_kits/playbook/pb_currency/_currency.html.erb +7 -9
- data/app/pb_kits/playbook/pb_currency/_currency.jsx +37 -21
- data/app/pb_kits/playbook/pb_currency/currency.rb +22 -29
- data/app/pb_kits/playbook/pb_currency/docs/_currency_dark.html.erb +3 -3
- data/app/pb_kits/playbook/pb_currency/docs/_currency_dark.jsx +2 -3
- data/app/pb_kits/playbook/pb_currency/docs/_currency_large.jsx +2 -3
- data/app/pb_kits/playbook/pb_currency/docs/_currency_medium.jsx +2 -2
- data/app/pb_kits/playbook/pb_currency/docs/_currency_small.html.erb +1 -1
- data/app/pb_kits/playbook/pb_currency/docs/_currency_small.jsx +5 -2
- data/app/pb_kits/playbook/pb_dashboard_value/_dashboard_value.jsx +2 -2
- data/app/pb_kits/playbook/pb_date/_date.jsx +39 -15
- data/app/pb_kits/playbook/pb_date/docs/_date_default.jsx +3 -1
- data/app/pb_kits/playbook/pb_date_range_inline/_date_range_inline.jsx +43 -37
- data/app/pb_kits/playbook/pb_date_range_inline/docs/_date_range_inline_default.jsx +2 -2
- data/app/pb_kits/playbook/pb_date_range_stacked/_date_range_stacked.jsx +6 -16
- data/app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx +21 -18
- data/app/pb_kits/playbook/pb_date_time_stacked/_date_time_stacked.jsx +30 -33
- data/app/pb_kits/playbook/pb_date_year_stacked/_date_year_stacked.jsx +10 -15
- data/app/pb_kits/playbook/pb_distribution_bar/_distribution_bar.jsx +8 -8
- data/app/pb_kits/playbook/pb_file_upload/_file_upload.jsx +13 -23
- data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.jsx +56 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterBackground.jsx +28 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterDouble.jsx +58 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterSingle.jsx +46 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FiltersPopover.jsx +37 -0
- data/app/pb_kits/playbook/pb_filter/Filter/ResultsCount.jsx +34 -0
- data/app/pb_kits/playbook/pb_filter/Filter/SortMenu.jsx +85 -0
- data/app/pb_kits/playbook/pb_filter/Filter/index.jsx +26 -0
- data/app/pb_kits/playbook/pb_filter/_filter.jsx +1 -222
- data/app/pb_kits/playbook/pb_filter/_filter.scss +16 -13
- data/app/pb_kits/playbook/pb_filter/docs/_filter_default.html.erb +34 -41
- data/app/pb_kits/playbook/pb_filter/docs/_filter_default.jsx +13 -9
- data/app/pb_kits/playbook/pb_filter/docs/_filter_no_background.html.erb +69 -74
- data/app/pb_kits/playbook/pb_filter/docs/_filter_no_background.jsx +12 -9
- data/app/pb_kits/playbook/pb_filter/docs/_filter_only.html.erb +28 -35
- data/app/pb_kits/playbook/pb_filter/docs/_filter_only.jsx +5 -6
- data/app/pb_kits/playbook/pb_filter/docs/_filter_single.html.erb +35 -41
- data/app/pb_kits/playbook/pb_filter/docs/_filter_single.jsx +12 -10
- data/app/pb_kits/playbook/pb_filter/docs/_sort_only.html.erb +12 -18
- data/app/pb_kits/playbook/pb_filter/docs/_sort_only.jsx +14 -44
- data/app/pb_kits/playbook/pb_filter/templates/_default.html.erb +1 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.jsx +13 -12
- data/app/pb_kits/playbook/pb_flex/_flex.jsx +35 -20
- data/app/pb_kits/playbook/pb_flex/_flex_item.jsx +6 -9
- data/app/pb_kits/playbook/pb_form_pill/_form_pill.jsx +14 -19
- data/app/pb_kits/playbook/pb_hashtag/_hashtag.jsx +26 -22
- data/app/pb_kits/playbook/pb_highlight/_highlight.jsx +13 -12
- data/app/pb_kits/playbook/pb_home_address_street/_home_address_street.jsx +85 -80
- data/app/pb_kits/playbook/pb_icon/_icon.jsx +54 -33
- data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.jsx +13 -9
- data/app/pb_kits/playbook/pb_icon_value/_icon_value.jsx +16 -20
- data/app/pb_kits/playbook/pb_image/_image.jsx +12 -10
- data/app/pb_kits/playbook/pb_label_pill/_label_pill.html.erb +1 -0
- data/app/pb_kits/playbook/pb_label_pill/_label_pill.jsx +49 -14
- data/app/pb_kits/playbook/pb_label_pill/docs/_label_pill_default.jsx +50 -0
- data/app/pb_kits/playbook/pb_label_pill/docs/example.yml +4 -3
- data/app/pb_kits/playbook/pb_label_pill/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_label_pill/label_pill.rb +1 -1
- data/app/pb_kits/playbook/pb_label_value/_label_value.jsx +10 -17
- data/app/pb_kits/playbook/pb_layout/_layout.jsx +85 -29
- data/app/pb_kits/playbook/pb_layout/_layout.scss +76 -57
- data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.html.erb +54 -0
- data/app/pb_kits/playbook/pb_layout/docs/_layout_collection.jsx +27 -0
- data/app/pb_kits/playbook/pb_layout/docs/_layout_colors.jsx +63 -0
- data/app/pb_kits/playbook/pb_layout/docs/_layout_sizes.jsx +87 -0
- data/app/pb_kits/playbook/pb_layout/docs/_layout_sizes_dark.jsx +92 -0
- data/app/pb_kits/playbook/pb_layout/docs/_layout_transparent.jsx +24 -0
- data/app/pb_kits/playbook/pb_layout/docs/example.yml +6 -1
- data/app/pb_kits/playbook/pb_layout/docs/index.js +5 -1
- data/app/pb_kits/playbook/pb_layout/layout.rb +10 -2
- data/app/pb_kits/playbook/pb_legend/_legend.jsx +17 -15
- data/app/pb_kits/playbook/pb_line_graph/_line_graph.jsx +9 -2
- data/app/pb_kits/playbook/pb_line_graph/docs/_description.md +3 -1
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_default.html.erb +8 -8
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_default.jsx +1 -1
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_height.html.erb +26 -0
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_height.jsx +35 -0
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_legend.html.erb +15 -0
- data/app/pb_kits/playbook/pb_line_graph/docs/_line_graph_legend.jsx +23 -0
- data/app/pb_kits/playbook/pb_line_graph/docs/example.yml +5 -1
- data/app/pb_kits/playbook/pb_line_graph/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_line_graph/line_graph.rb +6 -0
- data/app/pb_kits/playbook/pb_list/_list.jsx +24 -21
- data/app/pb_kits/playbook/pb_list/docs/_description.md +7 -1
- data/app/pb_kits/playbook/pb_list/docs/_list_layout_left.html.erb +8 -0
- data/app/pb_kits/playbook/pb_list/docs/_list_layout_right.html.erb +8 -0
- data/app/pb_kits/playbook/pb_list/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_loading_inline/_loading_inline.jsx +21 -19
- data/app/pb_kits/playbook/pb_logistic/_logistic.jsx +4 -11
- data/app/pb_kits/playbook/pb_message/_message.jsx +15 -11
- data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.jsx +10 -10
- data/app/pb_kits/playbook/pb_multiple_users_stacked/_multiple_users_stacked.jsx +7 -19
- data/app/pb_kits/playbook/pb_nav/_nav.jsx +17 -14
- data/app/pb_kits/playbook/pb_online_status/_online_status.jsx +23 -14
- data/app/pb_kits/playbook/pb_online_status/docs/_online_status_default.jsx +19 -0
- data/app/pb_kits/playbook/pb_online_status/docs/example.yml +3 -3
- data/app/pb_kits/playbook/pb_online_status/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_person/_person.jsx +5 -11
- data/app/pb_kits/playbook/pb_person_contact/_person_contact.jsx +20 -20
- data/app/pb_kits/playbook/pb_pill/_pill.jsx +5 -10
- data/app/pb_kits/playbook/pb_popover/_popover.jsx +52 -41
- data/app/pb_kits/playbook/pb_popover/docs/example.yml +0 -2
- data/app/pb_kits/playbook/pb_popover/docs/index.js +0 -1
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.jsx +16 -12
- data/app/pb_kits/playbook/pb_progress_simple/_progress_simple.jsx +15 -12
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.html.erb +6 -0
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.jsx +42 -0
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.scss +388 -0
- data/app/pb_kits/playbook/pb_progress_step/_progress_step_item.html.erb +23 -0
- data/app/pb_kits/playbook/pb_progress_step/_progress_step_item.jsx +44 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_description.md +1 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_dark.html.erb +8 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_dark.jsx +18 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_default.html.erb +33 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_default.jsx +39 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_vertical.html.erb +33 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_vertical.jsx +40 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/example.yml +12 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_progress_step/progress_step.rb +33 -0
- data/app/pb_kits/playbook/pb_progress_step/progress_step_item.rb +19 -0
- data/app/pb_kits/playbook/pb_radio/_radio.jsx +3 -1
- data/app/pb_kits/playbook/pb_section_separator/_section_separator.jsx +19 -13
- data/app/pb_kits/playbook/pb_select/_select.jsx +4 -2
- data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.jsx +12 -7
- data/app/pb_kits/playbook/pb_selectable_card_icon/_selectable_card_icon.html.erb +30 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/_selectable_card_icon.jsx +97 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/_selectable_card_icon.scss +74 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_checkmark.html.erb +29 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_checkmark.jsx +41 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_dark.html.erb +30 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_dark.jsx +40 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_default.html.erb +26 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_default.jsx +37 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_single_select.html.erb +27 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/_selectable_card_icon_single_select.jsx +40 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/example.yml +16 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/docs/index.js +4 -0
- data/app/pb_kits/playbook/pb_selectable_card_icon/selectable_card_icon.rb +50 -0
- data/app/pb_kits/playbook/pb_selectable_icon/_selectable_icon.html.erb +24 -0
- data/app/pb_kits/playbook/pb_selectable_icon/_selectable_icon.jsx +107 -0
- data/app/pb_kits/playbook/pb_selectable_icon/_selectable_icon.scss +85 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_dark.html.erb +26 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_dark.jsx +43 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_default.html.erb +23 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_default.jsx +40 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_single_select.html.erb +27 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/_selectable_icon_single_select.jsx +46 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/example.yml +12 -0
- data/app/pb_kits/playbook/pb_selectable_icon/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_selectable_icon/selectable_icon.rb +55 -0
- data/app/pb_kits/playbook/pb_source/_source.jsx +113 -13
- data/app/pb_kits/playbook/pb_source/docs/_source_default.html.erb +3 -1
- data/app/pb_kits/playbook/pb_source/docs/_source_default.jsx +37 -0
- data/app/pb_kits/playbook/pb_source/docs/_source_noicon.jsx +40 -0
- data/app/pb_kits/playbook/pb_source/docs/_source_types.jsx +85 -0
- data/app/pb_kits/playbook/pb_source/docs/example.yml +3 -0
- data/app/pb_kits/playbook/pb_source/docs/index.js +5 -0
- data/app/pb_kits/playbook/pb_star_rating/_star_rating.html.erb +6 -2
- data/app/pb_kits/playbook/pb_star_rating/_star_rating.jsx +98 -13
- data/app/pb_kits/playbook/pb_star_rating/docs/_star_rating_default.jsx +28 -0
- data/app/pb_kits/playbook/pb_star_rating/docs/_star_rating_hide.jsx +13 -0
- data/app/pb_kits/playbook/pb_star_rating/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_star_rating/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_star_rating/star_rating.rb +2 -1
- data/app/pb_kits/playbook/pb_stat_change/_stat_change.jsx +14 -13
- data/app/pb_kits/playbook/pb_stat_change/docs/_stat_change_default.html.erb +1 -1
- data/app/pb_kits/playbook/pb_stat_change/docs/_stat_change_default.jsx +1 -1
- data/app/pb_kits/playbook/pb_stat_change/stat_change.rb +1 -1
- data/app/pb_kits/playbook/pb_stat_value/_stat_value.jsx +2 -1
- data/app/pb_kits/playbook/pb_table/_table.jsx +29 -28
- data/app/pb_kits/playbook/pb_table/_table.scss +1 -1
- data/app/pb_kits/playbook/pb_table/_table_row.jsx +6 -7
- data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.html.erb +52 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.jsx +52 -8
- data/app/pb_kits/playbook/pb_table/docs/_table_side_highlight.md +3 -1
- data/app/pb_kits/playbook/pb_text_input/_text_input.html.erb +5 -3
- data/app/pb_kits/playbook/pb_text_input/_text_input.jsx +21 -5
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.html.erb +31 -5
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.jsx +3 -0
- data/app/pb_kits/playbook/pb_text_input/text_input.rb +1 -1
- data/app/pb_kits/playbook/pb_textarea/_textarea.jsx +2 -1
- data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.jsx +38 -18
- data/app/pb_kits/playbook/pb_time_stacked/_time_stacked.jsx +12 -11
- data/app/pb_kits/playbook/pb_timestamp/_timestamp.jsx +32 -14
- data/app/pb_kits/playbook/pb_timestamp/docs/_timestamp_default.jsx +8 -0
- data/app/pb_kits/playbook/pb_timestamp/docs/example.yml +3 -3
- data/app/pb_kits/playbook/pb_timestamp/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_title/_title.jsx +12 -13
- data/app/pb_kits/playbook/pb_title/docs/_title_light.html.erb +1 -1
- data/app/pb_kits/playbook/pb_title_count/_title_count.jsx +49 -28
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_align.jsx +31 -0
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_default.jsx +13 -2
- data/app/pb_kits/playbook/pb_title_count/docs/example.yml +4 -5
- data/app/pb_kits/playbook/pb_title_count/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_title_detail/_title_detail.jsx +36 -14
- data/app/pb_kits/playbook/pb_title_detail/docs/_title_detail_default.jsx +26 -0
- data/app/pb_kits/playbook/pb_title_detail/docs/example.yml +3 -3
- data/app/pb_kits/playbook/pb_title_detail/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_toggle/_toggle.jsx +9 -11
- data/app/pb_kits/playbook/pb_tooltip/_tooltip.html.erb +10 -0
- data/app/pb_kits/playbook/pb_tooltip/_tooltip.scss +105 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_default.html.erb +10 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_white.html.erb +9 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +80 -0
- data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +34 -0
- data/app/pb_kits/playbook/pb_user/_user.jsx +37 -37
- data/app/pb_kits/playbook/pb_user_badge/_user_badge.jsx +7 -7
- data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.jsx +32 -30
- data/app/pb_kits/playbook/plugins/pb_chart.js +4 -0
- data/app/pb_kits/playbook/props.rb +48 -0
- data/app/pb_kits/playbook/tokens/_colors.scss +7 -3
- data/app/pb_kits/playbook/tokens/_spacing.scss +1 -0
- data/app/pb_kits/playbook/utilities/_spacing.scss +42 -0
- data/app/pb_kits/playbook/utilities/spacing.js +33 -0
- data/app/pb_kits/playbook/vendor.js +3 -0
- data/app/views/playbook/samples/dashboards/index.html.erb +3 -1
- data/lib/playbook/version.rb +1 -1
- metadata +109 -10
- data/app/pb_kits/playbook/pb_layout/_body.jsx +0 -26
- data/app/pb_kits/playbook/pb_layout/_sidebar.jsx +0 -26
- data/app/pb_kits/playbook/pb_layout/docs/_layout_default.jsx +0 -14
- data/app/pb_kits/playbook/pb_popover/docs/_popover_with_button.html.erb +0 -4
@@ -2,18 +2,18 @@
|
|
2
2
|
|
3
3
|
import React from 'react'
|
4
4
|
import classnames from 'classnames'
|
5
|
-
|
6
5
|
import DateTime from '../pb_kit/dateTime.js'
|
7
6
|
import { buildCss } from '../utilities/props'
|
8
7
|
import { Caption, Title } from '../'
|
8
|
+
import { spacing } from '../utilities/spacing.js'
|
9
9
|
|
10
10
|
type DateStackedProps = {
|
11
|
-
align?:
|
11
|
+
align?: "left" | "center" | "right",
|
12
12
|
className?: String | Array<String>,
|
13
13
|
dark?: Boolean,
|
14
14
|
data?: String,
|
15
15
|
date: String,
|
16
|
-
size?:
|
16
|
+
size?: "sm" | "md",
|
17
17
|
id?: String,
|
18
18
|
reverse?: Boolean,
|
19
19
|
}
|
@@ -23,18 +23,23 @@ const sizes = {
|
|
23
23
|
md: 3,
|
24
24
|
}
|
25
25
|
|
26
|
-
const DateStacked = ({
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
26
|
+
const DateStacked = (props: DateStackedProps) => {
|
27
|
+
const {
|
28
|
+
align = 'left',
|
29
|
+
reverse = false,
|
30
|
+
className,
|
31
|
+
dark = false,
|
32
|
+
date,
|
33
|
+
size = 'sm',
|
34
|
+
} = props
|
35
|
+
const classes = classnames(
|
36
|
+
className,
|
37
|
+
buildCss('pb_date_stacked_kit', align, size, {
|
38
|
+
dark: dark,
|
39
|
+
reverse: reverse,
|
40
|
+
}),
|
41
|
+
spacing(props)
|
42
|
+
)
|
38
43
|
|
39
44
|
const currentYear = new Date().getFullYear().toString()
|
40
45
|
const dateTimestamp = new DateTime({ value: date })
|
@@ -43,9 +48,7 @@ const DateStacked = ({
|
|
43
48
|
return (
|
44
49
|
<div className={classes}>
|
45
50
|
<div className="pb_date_stacked_day_month">
|
46
|
-
<Caption
|
47
|
-
text={dateTimestamp.toMonth().toUpperCase()}
|
48
|
-
/>
|
51
|
+
<Caption text={dateTimestamp.toMonth().toUpperCase()} />
|
49
52
|
<Title
|
50
53
|
dark={dark}
|
51
54
|
size={sizes[size]}
|
@@ -1,12 +1,8 @@
|
|
1
1
|
/* @flow */
|
2
2
|
|
3
3
|
import React from 'react'
|
4
|
-
import {
|
5
|
-
|
6
|
-
Flex,
|
7
|
-
FlexItem,
|
8
|
-
TimeStacked,
|
9
|
-
} from '../'
|
4
|
+
import { DateStacked, Flex, FlexItem, TimeStacked } from '../'
|
5
|
+
import { spacing } from '../utilities/spacing.js'
|
10
6
|
|
11
7
|
type DateTimeStackedProps = {
|
12
8
|
data?: String,
|
@@ -15,32 +11,33 @@ type DateTimeStackedProps = {
|
|
15
11
|
dark: Boolean,
|
16
12
|
}
|
17
13
|
|
18
|
-
const DateTimeStacked = ({
|
19
|
-
date,
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
)
|
14
|
+
const DateTimeStacked = (props: DateTimeStackedProps) => {
|
15
|
+
const { date, dark } = props
|
16
|
+
return (
|
17
|
+
<Flex
|
18
|
+
className={spacing(props)}
|
19
|
+
orientation="row"
|
20
|
+
vertical="center"
|
21
|
+
>
|
22
|
+
<FlexItem>
|
23
|
+
<DateStacked
|
24
|
+
align="right"
|
25
|
+
dark={dark}
|
26
|
+
date={date}
|
27
|
+
reverse
|
28
|
+
size="sm"
|
29
|
+
/>
|
30
|
+
</FlexItem>
|
31
|
+
<FlexItem>
|
32
|
+
<TimeStacked
|
33
|
+
className="pb_date_time_stacked_kit"
|
34
|
+
dark={dark}
|
35
|
+
date={date}
|
36
|
+
tag="caption"
|
37
|
+
/>
|
38
|
+
</FlexItem>
|
39
|
+
</Flex>
|
40
|
+
)
|
41
|
+
}
|
45
42
|
|
46
43
|
export default DateTimeStacked
|
@@ -2,17 +2,14 @@
|
|
2
2
|
|
3
3
|
import React from 'react'
|
4
4
|
import classnames from 'classnames'
|
5
|
-
|
6
5
|
import { buildCss } from '../utilities/props'
|
7
6
|
import DateTime from '../pb_kit/dateTime.js'
|
7
|
+
import { spacing } from '../utilities/spacing.js'
|
8
8
|
|
9
|
-
import {
|
10
|
-
Body,
|
11
|
-
Title,
|
12
|
-
} from '../'
|
9
|
+
import { Body, Title } from '../'
|
13
10
|
|
14
11
|
type DateYearStackedProps = {
|
15
|
-
align?:
|
12
|
+
align?: "left" | "center" | "right",
|
16
13
|
className?: String | Array<String>,
|
17
14
|
dark?: Boolean,
|
18
15
|
data?: String,
|
@@ -20,23 +17,21 @@ type DateYearStackedProps = {
|
|
20
17
|
id?: String,
|
21
18
|
}
|
22
19
|
|
23
|
-
const DateYearStacked = ({
|
24
|
-
align,
|
25
|
-
className,
|
26
|
-
dark = false,
|
27
|
-
date,
|
28
|
-
}: DateYearStackedProps) => {
|
20
|
+
const DateYearStacked = (props: DateYearStackedProps) => {
|
21
|
+
const { align = 'left', className, dark = false, date } = props
|
29
22
|
const dateTimestamp = new DateTime({ value: date })
|
30
|
-
const css = classnames(className, buildCss('pb_date_year_stacked', align))
|
23
|
+
const css = classnames(className, buildCss('pb_date_year_stacked', align), spacing(props))
|
31
24
|
|
32
25
|
return (
|
33
26
|
<div className={css}>
|
34
27
|
<Title
|
35
28
|
dark={dark}
|
36
29
|
size={4}
|
37
|
-
text={`${dateTimestamp.toDay()} ${dateTimestamp
|
30
|
+
text={`${dateTimestamp.toDay()} ${dateTimestamp
|
31
|
+
.toMonth()
|
32
|
+
.toUpperCase()}`}
|
38
33
|
/>
|
39
|
-
<Body color="light">{
|
34
|
+
<Body color="light">{dateTimestamp.toYear()}</Body>
|
40
35
|
</div>
|
41
36
|
)
|
42
37
|
}
|
@@ -1,12 +1,14 @@
|
|
1
1
|
/* @flow */
|
2
2
|
|
3
3
|
import React from 'react'
|
4
|
+
import classnames from 'classnames'
|
5
|
+
import { spacing } from '../utilities/spacing.js'
|
4
6
|
|
5
7
|
type DistributionBarProps = {
|
6
8
|
className?: String,
|
7
9
|
data?: String,
|
8
10
|
id?: String,
|
9
|
-
size?:
|
11
|
+
size?: "lg" | "sm",
|
10
12
|
widths?: Array<Number>,
|
11
13
|
}
|
12
14
|
|
@@ -17,27 +19,25 @@ const normalizeCharacters = (widths) => {
|
|
17
19
|
}
|
18
20
|
|
19
21
|
const barValues = (normalizedValues) => {
|
20
|
-
const arrSum = (value) => value.reduce((a, b) =>
|
22
|
+
const arrSum = (value) => value.reduce((a, b) => a + b, 0)
|
21
23
|
const widthSum = arrSum(normalizedValues)
|
22
24
|
return normalizedValues.map((value, i) => {
|
23
25
|
return (
|
24
26
|
<div
|
25
27
|
className="pb_distribution_width"
|
26
28
|
key={i}
|
27
|
-
style={{ width: `${value * 100 / widthSum}%` }}
|
29
|
+
style={{ width: `${(value * 100) / widthSum}%` }}
|
28
30
|
/>
|
29
31
|
)
|
30
32
|
})
|
31
33
|
}
|
32
34
|
|
33
|
-
const DistributionBar = ({
|
34
|
-
size = 'lg',
|
35
|
-
widths = [1],
|
36
|
-
}: DistributionBarProps) => {
|
35
|
+
const DistributionBar = (props: DistributionBarProps) => {
|
36
|
+
const { size = 'lg', widths = [1] } = props
|
37
37
|
const normalizedValues = normalizeCharacters(widths)
|
38
38
|
|
39
39
|
return (
|
40
|
-
<div className={`pb_distribution_bar_${size}
|
40
|
+
<div className={classnames(`pb_distribution_bar_${size}`, spacing(props))}>
|
41
41
|
{barValues(normalizedValues)}
|
42
42
|
</div>
|
43
43
|
)
|
@@ -2,18 +2,13 @@
|
|
2
2
|
|
3
3
|
import React, { useCallback } from 'react'
|
4
4
|
import { useDropzone } from 'react-dropzone'
|
5
|
-
|
6
|
-
import
|
7
|
-
|
8
|
-
noop,
|
9
|
-
} from '../utilities/props'
|
5
|
+
import { buildCss, noop } from '../utilities/props'
|
6
|
+
import classnames from 'classnames'
|
7
|
+
import { spacing } from '../utilities/spacing.js'
|
10
8
|
|
11
9
|
import type { Callback } from '../types.js'
|
12
10
|
|
13
|
-
import {
|
14
|
-
Body,
|
15
|
-
Card,
|
16
|
-
} from '..'
|
11
|
+
import { Body, Card } from '..'
|
17
12
|
|
18
13
|
type FileUploadProps = {
|
19
14
|
accept?: Array<String>,
|
@@ -21,34 +16,29 @@ type FileUploadProps = {
|
|
21
16
|
onFilesAccepted: Callback,
|
22
17
|
}
|
23
18
|
|
24
|
-
const FileUpload = ({
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
19
|
+
const FileUpload = (props: FileUploadProps) => {
|
20
|
+
const {
|
21
|
+
accept = ['image/png', 'image/jpg', 'image/jpeg', 'image/svg+xml'],
|
22
|
+
className,
|
23
|
+
onFilesAccepted = noop,
|
24
|
+
} = props
|
29
25
|
const onDrop = useCallback((files) => {
|
30
26
|
onFilesAccepted(files)
|
31
27
|
})
|
32
28
|
|
33
|
-
const {
|
34
|
-
getRootProps,
|
35
|
-
getInputProps,
|
36
|
-
isDragActive,
|
37
|
-
} = useDropzone({
|
29
|
+
const { getRootProps, getInputProps, isDragActive } = useDropzone({
|
38
30
|
accept,
|
39
31
|
onDrop,
|
40
32
|
})
|
41
33
|
|
42
34
|
return (
|
43
35
|
<div
|
44
|
-
className={buildCss('pb_file_upload_kit', className)}
|
36
|
+
className={classnames(buildCss('pb_file_upload_kit', className), spacing(props))}
|
45
37
|
{...getRootProps()}
|
46
38
|
>
|
47
39
|
<Card>
|
48
40
|
<input {...getInputProps()} />
|
49
|
-
<Body
|
50
|
-
color="light"
|
51
|
-
>
|
41
|
+
<Body color="light">
|
52
42
|
<If condition={isDragActive}>
|
53
43
|
<p>{'Drop the files here ...'}</p>
|
54
44
|
<Else />
|
@@ -0,0 +1,56 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
3
|
+
import React from 'react'
|
4
|
+
import { isEmpty, map, omitBy } from 'lodash'
|
5
|
+
import { Caption, Title } from '../../'
|
6
|
+
|
7
|
+
export type FilterDescription = {
|
8
|
+
[key: string]: ?string | boolean,
|
9
|
+
}
|
10
|
+
|
11
|
+
export type CurrentFiltersProps = {
|
12
|
+
filters: FilterDescription,
|
13
|
+
}
|
14
|
+
|
15
|
+
const hiddenFilters = (value) => isEmpty(value) && value !== true
|
16
|
+
|
17
|
+
const CurrentFilters = ({ filters }: CurrentFiltersProps) => {
|
18
|
+
const displayableFilters = omitBy(filters, hiddenFilters)
|
19
|
+
|
20
|
+
return (
|
21
|
+
<div className="maskContainer">
|
22
|
+
<If condition={!isEmpty(filters)}>
|
23
|
+
<div className="filters">
|
24
|
+
<div className="left_gradient" />
|
25
|
+
{map(displayableFilters, (value, name) => (
|
26
|
+
<div
|
27
|
+
className="filter"
|
28
|
+
key={`filter-${name}`}
|
29
|
+
>
|
30
|
+
<Choose>
|
31
|
+
<When condition={value === true}>
|
32
|
+
<Title
|
33
|
+
size={4}
|
34
|
+
tag="h4"
|
35
|
+
text={name}
|
36
|
+
/>
|
37
|
+
</When>
|
38
|
+
<Otherwise>
|
39
|
+
<Caption text={name} />
|
40
|
+
<Title
|
41
|
+
size={4}
|
42
|
+
tag="h4"
|
43
|
+
text={value}
|
44
|
+
/>
|
45
|
+
</Otherwise>
|
46
|
+
</Choose>
|
47
|
+
</div>
|
48
|
+
))}
|
49
|
+
<div className="right_gradient" />
|
50
|
+
</div>
|
51
|
+
</If>
|
52
|
+
</div>
|
53
|
+
)
|
54
|
+
}
|
55
|
+
|
56
|
+
export default CurrentFilters
|
@@ -0,0 +1,28 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
3
|
+
import React, { Node } from 'react'
|
4
|
+
import { Card } from '../../'
|
5
|
+
import classnames from 'classnames'
|
6
|
+
import { spacing } from '../../utilities/spacing.js'
|
7
|
+
|
8
|
+
type FilterBackgroundProps = {
|
9
|
+
background: boolean,
|
10
|
+
className: string,
|
11
|
+
children: Node,
|
12
|
+
}
|
13
|
+
const FilterBackground = (props: FilterBackgroundProps) => {
|
14
|
+
const { background = true, className, children } = props
|
15
|
+
|
16
|
+
return (
|
17
|
+
<div className={classnames(`pb_filter_kit ${className}`, spacing(props))}>
|
18
|
+
<Choose>
|
19
|
+
<When condition={background}>
|
20
|
+
<Card padding="none">{children}</Card>
|
21
|
+
</When>
|
22
|
+
<Otherwise>{children}</Otherwise>
|
23
|
+
</Choose>
|
24
|
+
</div>
|
25
|
+
)
|
26
|
+
}
|
27
|
+
|
28
|
+
export default FilterBackground
|
@@ -0,0 +1,58 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
3
|
+
import React from 'react'
|
4
|
+
import { Caption, Flex, SectionSeparator } from '../../'
|
5
|
+
|
6
|
+
import CurrentFilters, { FilterDescription } from './CurrentFilters'
|
7
|
+
import FilterBackground, { FilterBackgroundProps } from './FilterBackground'
|
8
|
+
import FiltersPopover from './FiltersPopover'
|
9
|
+
import ResultsCount from './ResultsCount'
|
10
|
+
import SortMenu, { SortingChangeCallback, SortOptions, SortValue } from './SortMenu'
|
11
|
+
|
12
|
+
export type FilterDoubleProps = {
|
13
|
+
children: Node,
|
14
|
+
filters?: FilterDescription,
|
15
|
+
onSortChange: SortingChangeCallback,
|
16
|
+
results?: number,
|
17
|
+
sortOptions: SortOptions,
|
18
|
+
sortValue?: SortValue,
|
19
|
+
} & FilterBackgroundProps
|
20
|
+
|
21
|
+
const FilterDouble = ({ onSortChange, sortOptions, sortValue, filters, results, children, ...bgProps }: FilterDoubleProps) => (
|
22
|
+
<FilterBackground {...bgProps}>
|
23
|
+
<Flex
|
24
|
+
orientation="row"
|
25
|
+
vertical="center"
|
26
|
+
>
|
27
|
+
<FiltersPopover>
|
28
|
+
{children}
|
29
|
+
</FiltersPopover>
|
30
|
+
<CurrentFilters filters={filters} />
|
31
|
+
</Flex>
|
32
|
+
<SectionSeparator />
|
33
|
+
<Flex
|
34
|
+
className="filter-bottom"
|
35
|
+
orientation="row"
|
36
|
+
spacing="between"
|
37
|
+
vertical="center"
|
38
|
+
>
|
39
|
+
<ResultsCount
|
40
|
+
results={results}
|
41
|
+
title
|
42
|
+
/>
|
43
|
+
<Flex
|
44
|
+
orientation="row"
|
45
|
+
vertical="center"
|
46
|
+
>
|
47
|
+
<Caption text="sort by:" />
|
48
|
+
<SortMenu
|
49
|
+
onChange={onSortChange}
|
50
|
+
options={sortOptions}
|
51
|
+
value={sortValue}
|
52
|
+
/>
|
53
|
+
</Flex>
|
54
|
+
</Flex>
|
55
|
+
</FilterBackground>
|
56
|
+
)
|
57
|
+
|
58
|
+
export default FilterDouble
|