playbook_ui 4.15.0 → 4.18.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 +7 -1
- data/app/pb_kits/playbook/data/menu.yml +5 -1
- data/app/pb_kits/playbook/index.js +5 -0
- data/app/pb_kits/playbook/packs/examples.js +8 -0
- data/app/pb_kits/playbook/packs/samples.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 +33 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx +81 -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 +2 -1
- 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 +58 -34
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.html.erb +1 -1
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.jsx +1 -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/FilterBackground.jsx +16 -14
- 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.html.erb +1 -0
- data/app/pb_kits/playbook/pb_label_value/_label_value.jsx +30 -18
- data/app/pb_kits/playbook/pb_layout/_layout.jsx +51 -45
- 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/example.yml +2 -0
- data/app/pb_kits/playbook/pb_layout/docs/index.js +1 -0
- 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.html.erb +1 -0
- data/app/pb_kits/playbook/pb_logistic/_logistic.jsx +26 -11
- data/app/pb_kits/playbook/pb_message/_message.html.erb +1 -0
- data/app/pb_kits/playbook/pb_message/_message.jsx +33 -11
- data/app/pb_kits/playbook/pb_message/docs/_message_default.jsx +1 -2
- data/app/pb_kits/playbook/pb_message/message.rb +1 -1
- 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 +5 -13
- data/app/pb_kits/playbook/pb_person/_person.html.erb +9 -2
- data/app/pb_kits/playbook/pb_person/_person.jsx +36 -18
- data/app/pb_kits/playbook/pb_person/docs/_person_default.html.erb +5 -1
- data/app/pb_kits/playbook/pb_person_contact/_person_contact.html.erb +1 -0
- data/app/pb_kits/playbook/pb_person_contact/_person_contact.jsx +73 -21
- data/app/pb_kits/playbook/pb_person_contact/docs/_person_contact_with_wrong_numbers.jsx +32 -0
- data/app/pb_kits/playbook/pb_person_contact/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_person_contact/docs/index.js +1 -0
- 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_progress_pills/_progress_pills.html.erb +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.jsx +41 -13
- data/app/pb_kits/playbook/pb_progress_simple/_progress_simple.jsx +15 -12
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.jsx +17 -10
- data/app/pb_kits/playbook/pb_radio/_radio.jsx +3 -1
- data/app/pb_kits/playbook/pb_section_separator/_section_separator.html.erb +1 -0
- data/app/pb_kits/playbook/pb_section_separator/_section_separator.jsx +30 -15
- data/app/pb_kits/playbook/pb_section_separator/docs/_section_separator_text.jsx +3 -1
- 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_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_timeline/_item.html.erb +28 -0
- data/app/pb_kits/playbook/pb_timeline/_item.jsx +54 -0
- data/app/pb_kits/playbook/pb_timeline/_timeline.html.erb +6 -0
- data/app/pb_kits/playbook/pb_timeline/_timeline.jsx +43 -0
- data/app/pb_kits/playbook/pb_timeline/_timeline.scss +271 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_description.md +3 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_default.html.erb +43 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_default.jsx +73 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_vertical.html.erb +43 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_vertical.jsx +73 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_date.html.erb +44 -0
- data/app/pb_kits/playbook/pb_timeline/docs/_timeline_with_date.jsx +85 -0
- data/app/pb_kits/playbook/pb_timeline/docs/example.yml +13 -0
- data/app/pb_kits/playbook/pb_timeline/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_timeline/item.rb +25 -0
- data/app/pb_kits/playbook/pb_timeline/timeline.rb +27 -0
- data/app/pb_kits/playbook/pb_timestamp/_timestamp.jsx +7 -14
- 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 +7 -18
- data/app/pb_kits/playbook/pb_toggle/_toggle.jsx +9 -11
- 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 +3 -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/views/playbook/samples/dashboards/index.html.erb +3 -1
- data/app/views/playbook/samples/registration/index.html.erb +316 -0
- data/app/views/playbook/samples/registration/index.jsx +476 -0
- data/lib/playbook/version.rb +1 -1
- metadata +88 -4
@@ -1,21 +1,121 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
1
3
|
import React from 'react'
|
2
|
-
import
|
4
|
+
import classnames from 'classnames'
|
5
|
+
|
6
|
+
import {
|
7
|
+
buildDataProps,
|
8
|
+
} from '../utilities/props'
|
9
|
+
import {
|
10
|
+
titleize,
|
11
|
+
} from '../utilities/text'
|
12
|
+
import {
|
13
|
+
Avatar,
|
14
|
+
Body,
|
15
|
+
Caption,
|
16
|
+
IconCircle,
|
17
|
+
Title,
|
18
|
+
} from '../'
|
3
19
|
|
4
|
-
|
5
|
-
className
|
6
|
-
|
20
|
+
type SourceProps = {
|
21
|
+
className?: String,
|
22
|
+
data?: object,
|
23
|
+
hideIcon: Boolean,
|
24
|
+
id?: String,
|
25
|
+
source?: String,
|
26
|
+
type: "events" | "inbound" | "outbound" | "prospecting" | "referral" | "retail" | "user",
|
27
|
+
user: object,
|
7
28
|
}
|
8
29
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
30
|
+
const Source = ({
|
31
|
+
className,
|
32
|
+
data = {},
|
33
|
+
hideIcon = false,
|
34
|
+
id,
|
35
|
+
source,
|
36
|
+
type = 'inbound',
|
37
|
+
user = {},
|
38
|
+
}: SourceProps) => {
|
39
|
+
const dataProps = buildDataProps(data)
|
40
|
+
|
41
|
+
const css = classnames([
|
42
|
+
'pb_source_kit',
|
43
|
+
className,
|
44
|
+
])
|
45
|
+
|
46
|
+
const avatar = () => {
|
47
|
+
if ((type === 'user' || type === 'referral') && user.name !== undefined) {
|
48
|
+
const avatarProps = { ...user }
|
49
|
+
avatarProps.size = 'sm'
|
50
|
+
delete avatarProps.userId
|
51
|
+
return avatarProps
|
52
|
+
}
|
16
53
|
}
|
17
|
-
}
|
18
54
|
|
19
|
-
|
55
|
+
const typeText = () => {
|
56
|
+
if (type === 'user' || (type === 'referral' && user.name !== undefined)) {
|
57
|
+
return user.name
|
58
|
+
} else {
|
59
|
+
return titleize(type)
|
60
|
+
}
|
61
|
+
}
|
62
|
+
|
63
|
+
const typeIconNames = {
|
64
|
+
events: 'calendar-alt',
|
65
|
+
outbound: 'sign-out',
|
66
|
+
prospecting: 'binoculars',
|
67
|
+
referral: 'handshake',
|
68
|
+
retail: 'shopping-bag',
|
69
|
+
inbound: 'sign-in',
|
70
|
+
}
|
71
|
+
|
72
|
+
const showIcon = () => type !== 'user' && (avatar() === undefined)
|
73
|
+
|
74
|
+
return (
|
75
|
+
<div
|
76
|
+
{...dataProps}
|
77
|
+
className={css}
|
78
|
+
id={id}
|
79
|
+
>
|
80
|
+
|
81
|
+
<div className="pb__source_layout">
|
82
|
+
<If condition={hideIcon === false}>
|
83
|
+
<If condition={showIcon()}>
|
84
|
+
<IconCircle
|
85
|
+
icon={typeIconNames[type]}
|
86
|
+
size="sm"
|
87
|
+
/>
|
88
|
+
<Else />
|
89
|
+
<Avatar
|
90
|
+
{...avatar()}
|
91
|
+
/>
|
92
|
+
</If>
|
93
|
+
</If>
|
94
|
+
|
95
|
+
<div className="pb__source_content">
|
96
|
+
<Title
|
97
|
+
size={4}
|
98
|
+
tag="h4"
|
99
|
+
text={source}
|
100
|
+
/>
|
101
|
+
|
102
|
+
<div className="pb__source_value">
|
103
|
+
<Body
|
104
|
+
color="light"
|
105
|
+
text={typeText()}
|
106
|
+
/>
|
107
|
+
|
108
|
+
<If condition={user.userId}>
|
109
|
+
<Caption
|
110
|
+
text={user.userId}
|
111
|
+
/>
|
112
|
+
</If>
|
113
|
+
</div>
|
114
|
+
</div>
|
115
|
+
</div>
|
116
|
+
|
117
|
+
</div>
|
118
|
+
)
|
119
|
+
}
|
20
120
|
|
21
121
|
export default Source
|
@@ -0,0 +1,37 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Source } from '../../'
|
3
|
+
|
4
|
+
const SourceDefault = () => (
|
5
|
+
<>
|
6
|
+
<Source
|
7
|
+
source="BJ's Johnston-208"
|
8
|
+
type="retail"
|
9
|
+
/>
|
10
|
+
|
11
|
+
<br />
|
12
|
+
<br />
|
13
|
+
|
14
|
+
<Source
|
15
|
+
source="Referral-phrg"
|
16
|
+
type="inbound"
|
17
|
+
/>
|
18
|
+
|
19
|
+
<br />
|
20
|
+
<br />
|
21
|
+
|
22
|
+
<Source
|
23
|
+
source="BJ's Future CB"
|
24
|
+
type="user"
|
25
|
+
user={
|
26
|
+
{ name: 'Anna Black',
|
27
|
+
image: {
|
28
|
+
url: 'https://randomuser.me/api/portraits/women/44.jpg',
|
29
|
+
},
|
30
|
+
userId: '48582',
|
31
|
+
}
|
32
|
+
}
|
33
|
+
/>
|
34
|
+
</>
|
35
|
+
)
|
36
|
+
|
37
|
+
export default SourceDefault
|
@@ -0,0 +1,40 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Source } from '../../'
|
3
|
+
|
4
|
+
const SourceNoicon = () => (
|
5
|
+
<>
|
6
|
+
<Source
|
7
|
+
hideIcon
|
8
|
+
source="BJ's Johnston-208"
|
9
|
+
type="retail"
|
10
|
+
/>
|
11
|
+
|
12
|
+
<br />
|
13
|
+
<br />
|
14
|
+
|
15
|
+
<Source
|
16
|
+
hideIcon
|
17
|
+
source="Referral-phrg"
|
18
|
+
type="inbound"
|
19
|
+
/>
|
20
|
+
|
21
|
+
<br />
|
22
|
+
<br />
|
23
|
+
|
24
|
+
<Source
|
25
|
+
hideIcon
|
26
|
+
source="BJ's Future CB"
|
27
|
+
type="user"
|
28
|
+
user={
|
29
|
+
{ name: 'Anna Black',
|
30
|
+
image: {
|
31
|
+
url: 'https://randomuser.me/api/portraits/women/44.jpg',
|
32
|
+
},
|
33
|
+
userId: '48582',
|
34
|
+
}
|
35
|
+
}
|
36
|
+
/>
|
37
|
+
</>
|
38
|
+
)
|
39
|
+
|
40
|
+
export default SourceNoicon
|
@@ -0,0 +1,85 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Source } from '../../'
|
3
|
+
|
4
|
+
const SourceTypes = () => (
|
5
|
+
<>
|
6
|
+
<Source
|
7
|
+
source="BJ's Johnston-208"
|
8
|
+
type="retail"
|
9
|
+
/>
|
10
|
+
|
11
|
+
<br />
|
12
|
+
<br />
|
13
|
+
|
14
|
+
<Source
|
15
|
+
source="Referral-phrg"
|
16
|
+
type="inbound"
|
17
|
+
/>
|
18
|
+
|
19
|
+
<br />
|
20
|
+
<br />
|
21
|
+
|
22
|
+
<Source
|
23
|
+
source="B.B.B. Outbound"
|
24
|
+
type="outbound"
|
25
|
+
/>
|
26
|
+
|
27
|
+
<br />
|
28
|
+
<br />
|
29
|
+
|
30
|
+
<Source
|
31
|
+
source="Contractor.com"
|
32
|
+
type="prospecting"
|
33
|
+
/>
|
34
|
+
|
35
|
+
<br />
|
36
|
+
<br />
|
37
|
+
|
38
|
+
<Source
|
39
|
+
source="Beards, Beers and Brats"
|
40
|
+
type="events"
|
41
|
+
/>
|
42
|
+
|
43
|
+
<br />
|
44
|
+
<br />
|
45
|
+
|
46
|
+
<Source
|
47
|
+
source="BJ's Johnston-208"
|
48
|
+
type="referral"
|
49
|
+
/>
|
50
|
+
|
51
|
+
<br />
|
52
|
+
<br />
|
53
|
+
|
54
|
+
<Source
|
55
|
+
source="Employee Referral"
|
56
|
+
type="referral"
|
57
|
+
user={
|
58
|
+
{ name: 'Anna Black',
|
59
|
+
image: {
|
60
|
+
url: 'https://randomuser.me/api/portraits/women/44.jpg',
|
61
|
+
},
|
62
|
+
userId: '48582',
|
63
|
+
}
|
64
|
+
}
|
65
|
+
/>
|
66
|
+
|
67
|
+
<br />
|
68
|
+
<br />
|
69
|
+
|
70
|
+
<Source
|
71
|
+
source="BJ's Future CB"
|
72
|
+
type="user"
|
73
|
+
user={
|
74
|
+
{ name: 'Anna Black',
|
75
|
+
image: {
|
76
|
+
url: 'https://randomuser.me/api/portraits/women/44.jpg',
|
77
|
+
},
|
78
|
+
userId: '48582',
|
79
|
+
}
|
80
|
+
}
|
81
|
+
/>
|
82
|
+
</>
|
83
|
+
)
|
84
|
+
|
85
|
+
export default SourceTypes
|
@@ -3,12 +3,16 @@
|
|
3
3
|
data: object.data,
|
4
4
|
class: object.classname) do %>
|
5
5
|
<%# Rating value %>
|
6
|
-
|
6
|
+
<% if object.hide_rating %>
|
7
|
+
<%= content_tag(:div, "", class: "pb_star_rating_number") %>
|
8
|
+
<% else %>
|
9
|
+
<%= content_tag(:div, object.rating, class: "pb_star_rating_number") %>
|
10
|
+
<% end %>
|
7
11
|
|
8
12
|
<%= content_tag(:div, class: "pb_star_rating_wrapper") do %>
|
9
13
|
<%# Gold stars generated by rating value %>
|
10
14
|
<%= content_tag(:div, class: "pb_star_rating_highlight") do %>
|
11
|
-
<% object.star_count.
|
15
|
+
<% object.star_count.times do %>
|
12
16
|
<%= pb_rails("icon", props: { icon: "star", fixed_width: true }) %>
|
13
17
|
<% end %>
|
14
18
|
<% unless object.star_full %>
|
@@ -1,21 +1,106 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
1
3
|
import React from 'react'
|
2
|
-
import
|
4
|
+
import classnames from 'classnames'
|
5
|
+
|
6
|
+
import {
|
7
|
+
buildAriaProps,
|
8
|
+
buildDataProps,
|
9
|
+
} from '../utilities/props'
|
10
|
+
|
11
|
+
import {
|
12
|
+
Icon,
|
13
|
+
} from '../'
|
3
14
|
|
4
|
-
|
5
|
-
|
6
|
-
|
15
|
+
type StarRatingProps = {
|
16
|
+
aria?: object,
|
17
|
+
className?: String,
|
18
|
+
data?: object,
|
19
|
+
fixedWidth?: Boolean,
|
20
|
+
hideRating: Boolean,
|
21
|
+
icon?: String,
|
22
|
+
id?: String,
|
23
|
+
rating: Numeric,
|
7
24
|
}
|
8
25
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
26
|
+
const StarRating = ({
|
27
|
+
aria = {},
|
28
|
+
className,
|
29
|
+
data = {},
|
30
|
+
hideRating = false,
|
31
|
+
id,
|
32
|
+
rating = 0,
|
33
|
+
}: StarRatingProps) => {
|
34
|
+
const ariaProps = buildAriaProps(aria)
|
35
|
+
const dataProps = buildDataProps(data)
|
36
|
+
const css = classnames([
|
37
|
+
'pb_star_rating_kit', className,
|
38
|
+
])
|
39
|
+
|
40
|
+
const starCount = () => (
|
41
|
+
[...Array(parseInt(rating))]
|
42
|
+
)
|
43
|
+
|
44
|
+
const hasHalfStar = () => (
|
45
|
+
parseFloat(rating) % 1 !== 0
|
46
|
+
)
|
47
|
+
|
48
|
+
return (
|
49
|
+
<div
|
50
|
+
{...ariaProps}
|
51
|
+
{...dataProps}
|
52
|
+
className={css}
|
53
|
+
id={id}
|
54
|
+
>
|
55
|
+
<div className="pb_star_rating_number">
|
56
|
+
<If condition={!hideRating}>
|
57
|
+
{rating}
|
58
|
+
</If>
|
14
59
|
</div>
|
15
|
-
)
|
16
|
-
}
|
17
|
-
}
|
18
60
|
|
19
|
-
|
61
|
+
<div className="pb_star_rating_wrapper">
|
62
|
+
<div className="pb_star_rating_highlight">
|
63
|
+
{starCount().map((_, index) => (
|
64
|
+
<Icon
|
65
|
+
fixedWidth
|
66
|
+
icon="star"
|
67
|
+
key={index}
|
68
|
+
/>
|
69
|
+
))}
|
70
|
+
|
71
|
+
<If condition={hasHalfStar()}>
|
72
|
+
<Icon
|
73
|
+
fixedWidth
|
74
|
+
icon="star-half"
|
75
|
+
/>
|
76
|
+
</If>
|
77
|
+
</div>
|
78
|
+
|
79
|
+
<div className="pb_star_rating_base">
|
80
|
+
<Icon
|
81
|
+
fixedWidth
|
82
|
+
icon="star"
|
83
|
+
/>
|
84
|
+
<Icon
|
85
|
+
fixedWidth
|
86
|
+
icon="star"
|
87
|
+
/>
|
88
|
+
<Icon
|
89
|
+
fixedWidth
|
90
|
+
icon="star"
|
91
|
+
/>
|
92
|
+
<Icon
|
93
|
+
fixedWidth
|
94
|
+
icon="star"
|
95
|
+
/>
|
96
|
+
<Icon
|
97
|
+
fixedWidth
|
98
|
+
icon="star"
|
99
|
+
/>
|
100
|
+
</div>
|
101
|
+
</div>
|
102
|
+
</div>
|
103
|
+
)
|
104
|
+
}
|
20
105
|
|
21
106
|
export default StarRating
|