playbook_ui 7.0.0.pre.alpha1 → 7.0.0.pre.alpha6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/data/menu.yml +4 -3
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.html.erb +7 -4
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.jsx +29 -21
- data/app/pb_kits/playbook/pb_avatar_action_button/_avatar_action_button.scss +3 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions_dark.html.erb +17 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_actions_dark.jsx +21 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_dark.html.erb +9 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_dark.jsx +14 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_on_click_dark.html.erb +15 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_on_click_dark.jsx +16 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement_dark.html.erb +31 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_placement_dark.jsx +33 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/_avatar_action_button_tooltip_dark.html.erb +12 -0
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/example.yml +10 -3
- data/app/pb_kits/playbook/pb_avatar_action_button/docs/index.js +4 -0
- data/app/pb_kits/playbook/pb_badge/_badge.jsx +2 -6
- data/app/pb_kits/playbook/pb_badge/docs/_description.md +1 -0
- data/app/pb_kits/playbook/pb_body/_body.jsx +3 -3
- data/app/pb_kits/playbook/pb_body/_body.scss +12 -9
- data/app/pb_kits/playbook/pb_body/_body_mixins.scss +6 -3
- data/app/pb_kits/playbook/pb_body/body.rb +3 -3
- data/app/pb_kits/playbook/pb_caption/_caption.jsx +3 -1
- data/app/pb_kits/playbook/pb_caption/_caption.scss +6 -0
- data/app/pb_kits/playbook/pb_caption/caption.rb +4 -1
- data/app/pb_kits/playbook/pb_caption/docs/_caption_variants.html.erb +1 -0
- data/app/pb_kits/playbook/pb_caption/docs/_caption_variants.jsx +16 -0
- data/app/pb_kits/playbook/pb_caption/docs/_caption_variants.md +3 -0
- data/app/pb_kits/playbook/pb_caption/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_caption/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_card/_card.jsx +8 -12
- data/app/pb_kits/playbook/pb_card/_card.scss +1 -1
- data/app/pb_kits/playbook/pb_card/_card_mixin.scss +4 -4
- data/app/pb_kits/playbook/pb_card/card_header.rb +3 -3
- data/app/pb_kits/playbook/pb_card/docs/_card_header.html.erb +38 -7
- data/app/pb_kits/playbook/pb_card/docs/_card_header.jsx +54 -6
- data/app/pb_kits/playbook/pb_card/docs/_card_header.md +1 -1
- data/app/pb_kits/playbook/pb_checkbox/_checkbox.html.erb +1 -1
- data/app/pb_kits/playbook/pb_checkbox/checkbox.rb +5 -0
- data/app/pb_kits/playbook/pb_date/_date.html.erb +32 -8
- data/app/pb_kits/playbook/pb_date/_date.jsx +76 -67
- data/app/pb_kits/playbook/pb_date/_date.scss +25 -0
- data/app/pb_kits/playbook/pb_date/date.rb +20 -11
- data/app/pb_kits/playbook/pb_date/docs/_date_alignment.html.erb +24 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_alignment.jsx +32 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_default.html.erb +1 -9
- data/app/pb_kits/playbook/pb_date/docs/_date_default.jsx +5 -15
- data/app/pb_kits/playbook/pb_date/docs/_date_default_react.jsx +20 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_default_react.md +3 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_timezone.html.erb +51 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_timezone.md +6 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_variants.html.erb +27 -0
- data/app/pb_kits/playbook/pb_date/docs/_date_variants.jsx +39 -0
- data/app/pb_kits/playbook/pb_date/docs/_description.md +2 -0
- data/app/pb_kits/playbook/pb_date/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_date/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_dark.jsx +1 -1
- data/app/pb_kits/playbook/pb_date_time_stacked/docs/_date_time_stacked_default.jsx +1 -1
- data/app/pb_kits/playbook/pb_distribution_bar/distribution_bar.rb +10 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/_fixed_confirmation_toast.html.erb +1 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_dark.html.erb +21 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_dark.jsx +40 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line_dark.html.erb +5 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/_fixed_confirmation_toast_multi_line_dark.jsx +16 -0
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/example.yml +4 -1
- data/app/pb_kits/playbook/pb_fixed_confirmation_toast/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with.html.erb +1 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +1 -0
- data/app/pb_kits/playbook/pb_form/docs/_form_simple_form.html.erb +3 -1
- data/app/pb_kits/playbook/pb_form/docs/_form_simple_form_validate.html.erb +3 -1
- data/app/pb_kits/playbook/pb_form/form_builder.rb +1 -0
- data/app/pb_kits/playbook/pb_form/form_builder/checkbox_field.rb +29 -0
- data/app/pb_kits/playbook/pb_hashtag/_hashtag.html.erb +4 -4
- data/app/pb_kits/playbook/pb_hashtag/_hashtag.jsx +22 -8
- data/app/pb_kits/playbook/pb_hashtag/docs/_hashtag_dark.jsx +3 -0
- data/app/pb_kits/playbook/pb_hashtag/docs/_hashtag_default.jsx +3 -0
- data/app/pb_kits/playbook/pb_hashtag/hashtag.rb +1 -6
- data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.html.erb +4 -3
- data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.jsx +21 -6
- data/app/pb_kits/playbook/pb_icon_circle/_icon_circle.scss +4 -1
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color_dark.html.erb +42 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_color_dark.jsx +59 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_dark.html.erb +4 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_dark.jsx +16 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_sizes.html.erb +4 -4
- data/app/pb_kits/playbook/pb_icon_circle/docs/{_icon_circle_size.jsx → _icon_circle_sizes.jsx} +2 -2
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_sizes_dark.html.erb +29 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/_icon_circle_sizes_dark.jsx +34 -0
- data/app/pb_kits/playbook/pb_icon_circle/docs/example.yml +8 -1
- data/app/pb_kits/playbook/pb_icon_circle/docs/index.js +4 -1
- data/app/pb_kits/playbook/pb_icon_value/_icon_value.html.erb +4 -3
- data/app/pb_kits/playbook/pb_icon_value/_icon_value.jsx +9 -3
- data/app/pb_kits/playbook/pb_icon_value/_icon_value.scss +3 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_align.jsx +31 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_align_dark.html.erb +23 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_align_dark.jsx +34 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_dark.html.erb +21 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/_icon_value_dark.jsx +32 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_icon_value/docs/index.js +3 -0
- data/app/pb_kits/playbook/pb_label_value/_label_value.html.erb +1 -1
- data/app/pb_kits/playbook/pb_label_value/_label_value.jsx +6 -10
- data/app/pb_kits/playbook/pb_label_value/_label_value.scss +1 -1
- data/app/pb_kits/playbook/pb_label_value/label_value.rb +1 -6
- data/app/pb_kits/playbook/pb_legend/_legend.jsx +5 -5
- data/app/pb_kits/playbook/pb_legend/legend.rb +1 -13
- data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.html.erb +4 -3
- data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.jsx +25 -7
- data/app/pb_kits/playbook/pb_multiple_users/_multiple_users.scss +6 -0
- data/app/pb_kits/playbook/pb_multiple_users/docs/_multiple_users_dark.html.erb +41 -0
- data/app/pb_kits/playbook/pb_multiple_users/docs/_multiple_users_dark.jsx +52 -0
- data/app/pb_kits/playbook/pb_multiple_users/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_multiple_users/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_multiple_users_stacked/_multiple_users_stacked.html.erb +6 -4
- data/app/pb_kits/playbook/pb_multiple_users_stacked/_multiple_users_stacked.jsx +19 -8
- data/app/pb_kits/playbook/pb_multiple_users_stacked/_multiple_users_stacked.scss +12 -7
- data/app/pb_kits/playbook/pb_multiple_users_stacked/docs/_multiple_users_stacked_dark.html.erb +53 -0
- data/app/pb_kits/playbook/pb_multiple_users_stacked/docs/_multiple_users_stacked_dark.jsx +62 -0
- data/app/pb_kits/playbook/pb_multiple_users_stacked/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_multiple_users_stacked/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_nav/_item.html.erb +3 -2
- data/app/pb_kits/playbook/pb_nav/_item.jsx +36 -14
- data/app/pb_kits/playbook/pb_nav/_nav.html.erb +3 -2
- data/app/pb_kits/playbook/pb_nav/_nav.jsx +27 -13
- data/app/pb_kits/playbook/pb_nav/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_online_status/_online_status.html.erb +3 -2
- data/app/pb_kits/playbook/pb_online_status/_online_status.jsx +14 -4
- data/app/pb_kits/playbook/pb_online_status/_online_status_mixins.scss +5 -2
- data/app/pb_kits/playbook/pb_online_status/docs/_online_status_dark.html.erb +9 -0
- data/app/pb_kits/playbook/pb_online_status/docs/_online_status_dark.jsx +28 -0
- data/app/pb_kits/playbook/pb_online_status/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_online_status/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_pill/_pill.html.erb +3 -2
- data/app/pb_kits/playbook/pb_pill/_pill.jsx +21 -3
- data/app/pb_kits/playbook/pb_pill/_pill.scss +1 -1
- data/app/pb_kits/playbook/pb_pill/docs/_pill_dark.html.erb +52 -0
- data/app/pb_kits/playbook/pb_pill/docs/_pill_dark.jsx +69 -0
- data/app/pb_kits/playbook/pb_pill/docs/example.yml +3 -1
- data/app/pb_kits/playbook/pb_pill/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_popover/_popover.html.erb +3 -2
- data/app/pb_kits/playbook/pb_popover/_popover.jsx +16 -4
- data/app/pb_kits/playbook/pb_popover/docs/_popover_close_dark.html.erb +43 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_close_dark.jsx +102 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_dark.html.erb +25 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_dark.jsx +48 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_default.html.erb +1 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_list_dark.html.erb +13 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_list_dark.jsx +51 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_scroll_height_dark.html.erb +25 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_scroll_height_dark.jsx +54 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_z_index_dark.html.erb +14 -0
- data/app/pb_kits/playbook/pb_popover/docs/_popover_z_index_dark.jsx +52 -0
- data/app/pb_kits/playbook/pb_popover/docs/example.yml +10 -0
- data/app/pb_kits/playbook/pb_popover/docs/index.js +5 -0
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.html.erb +1 -1
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.jsx +2 -3
- data/app/pb_kits/playbook/pb_progress_pills/_progress_pills.scss +1 -2
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_status_dark.html.erb +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/_progress_pills_status_dark.jsx +19 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_progress_pills/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_progress_pills/progress_pills.rb +2 -13
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.html.erb +1 -1
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.jsx +5 -6
- data/app/pb_kits/playbook/pb_progress_step/_progress_step.scss +129 -366
- data/app/pb_kits/playbook/pb_progress_step/_progress_step_item.html.erb +4 -16
- data/app/pb_kits/playbook/pb_progress_step/_progress_step_item.jsx +10 -20
- data/app/pb_kits/playbook/pb_progress_step/docs/_description.md +5 -1
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_dark.html.erb +26 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_default.html.erb +20 -6
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_default.jsx +3 -15
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_tracker.html.erb +11 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_tracker.jsx +23 -0
- data/app/pb_kits/playbook/pb_progress_step/docs/_progress_step_vertical.html.erb +7 -1
- data/app/pb_kits/playbook/pb_progress_step/docs/example.yml +2 -1
- data/app/pb_kits/playbook/pb_progress_step/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_progress_step/progress_step.rb +9 -6
- data/app/pb_kits/playbook/pb_progress_step/progress_step_item.rb +2 -1
- data/app/pb_kits/playbook/pb_radio/_radio.html.erb +6 -5
- data/app/pb_kits/playbook/pb_radio/_radio.jsx +26 -21
- data/app/pb_kits/playbook/pb_radio/_radio.scss +1 -1
- data/app/pb_kits/playbook/pb_radio/docs/_radio_dark.jsx +5 -3
- data/app/pb_kits/playbook/pb_radio/docs/_radio_default.jsx +3 -1
- data/app/pb_kits/playbook/pb_radio/radio.rb +2 -8
- data/app/pb_kits/playbook/pb_select/_select.html.erb +3 -3
- data/app/pb_kits/playbook/pb_select/_select.jsx +6 -8
- data/app/pb_kits/playbook/pb_select/_select.scss +1 -1
- data/app/pb_kits/playbook/pb_select/select.rb +1 -6
- data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.jsx +2 -2
- data/app/pb_kits/playbook/pb_table/_table.html.erb +3 -2
- data/app/pb_kits/playbook/pb_table/_table.jsx +15 -2
- data/app/pb_kits/playbook/pb_table/_table_row.html.erb +3 -2
- data/app/pb_kits/playbook/pb_table/_table_row.jsx +22 -4
- data/app/pb_kits/playbook/pb_table/table.rb +3 -5
- data/app/pb_kits/playbook/pb_text_input/_text_input.html.erb +1 -0
- data/app/pb_kits/playbook/pb_text_input/_text_input.jsx +9 -6
- data/app/pb_kits/playbook/pb_text_input/_text_input.scss +5 -5
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_disabled.html.erb +1 -0
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_disabled.jsx +18 -0
- data/app/pb_kits/playbook/pb_text_input/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_text_input/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_text_input/text_input.rb +1 -7
- data/app/pb_kits/playbook/pb_textarea/_textarea.jsx +10 -8
- data/app/pb_kits/playbook/pb_textarea/_textarea.scss +1 -3
- data/app/pb_kits/playbook/pb_textarea/docs/_textarea_dark.jsx +0 -1
- data/app/pb_kits/playbook/pb_textarea/docs/_textarea_dark_error.jsx +0 -1
- data/app/pb_kits/playbook/pb_textarea/textarea.rb +1 -7
- data/app/pb_kits/playbook/pb_time/_time.jsx +7 -5
- data/app/pb_kits/playbook/pb_time/docs/_time_dark.jsx +0 -2
- data/app/pb_kits/playbook/pb_time/docs/_time_default.jsx +1 -3
- data/app/pb_kits/playbook/pb_time/docs/_time_timestamp.jsx +0 -3
- data/app/pb_kits/playbook/pb_time/docs/_time_timezone.jsx +59 -0
- data/app/pb_kits/playbook/pb_time/docs/_time_timezone.md +11 -0
- data/app/pb_kits/playbook/pb_time/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_time/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_title/_title.jsx +1 -1
- data/app/pb_kits/playbook/pb_title/_title.scss +5 -5
- data/app/pb_kits/playbook/pb_title/docs/_title_variants.html.erb +1 -0
- data/app/pb_kits/playbook/pb_title/docs/_title_variants.jsx +17 -0
- data/app/pb_kits/playbook/pb_title/docs/_title_variants.md +3 -0
- data/app/pb_kits/playbook/pb_title/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_title/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_title_count/_title_count.html.erb +5 -3
- data/app/pb_kits/playbook/pb_title_count/_title_count.jsx +7 -1
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_align_dark.html.erb +23 -0
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_align_dark.jsx +34 -0
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_dark.html.erb +23 -0
- data/app/pb_kits/playbook/pb_title_count/docs/_title_count_dark.jsx +34 -0
- data/app/pb_kits/playbook/pb_title_count/docs/example.yml +4 -0
- data/app/pb_kits/playbook/pb_title_count/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_title_detail/docs/_title_detail_dark.html.erb +19 -0
- data/app/pb_kits/playbook/pb_title_detail/docs/_title_detail_dark.jsx +29 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +1 -1
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.html.erb +2 -3
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.scss +1 -1
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_context_dark.html.erb +0 -1
- data/app/pb_kits/playbook/pb_typeahead/typeahead.rb +1 -9
- data/app/pb_kits/playbook/pb_user/_user.html.erb +3 -2
- data/app/pb_kits/playbook/pb_user/_user.jsx +51 -17
- data/app/pb_kits/playbook/pb_user/docs/_user_dark.jsx +55 -0
- data/app/pb_kits/playbook/pb_user/docs/_user_text_only_dark.jsx +26 -0
- data/app/pb_kits/playbook/pb_user/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_user/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_user/user.rb +1 -7
- data/app/pb_kits/playbook/pb_user_badge/_user_badge.html.erb +3 -2
- data/app/pb_kits/playbook/pb_user_badge/_user_badge.jsx +23 -3
- data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_dark.html.erb +13 -0
- data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_dark.jsx +27 -0
- data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_size_dark.html.erb +21 -0
- data/app/pb_kits/playbook/pb_user_badge/docs/_user_badge_size_dark.jsx +36 -0
- data/app/pb_kits/playbook/pb_user_badge/docs/example.yml +4 -0
- data/app/pb_kits/playbook/pb_user_badge/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.html.erb +3 -2
- data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.jsx +20 -6
- data/app/pb_kits/playbook/pb_weekday_stacked/weekday_stacked.rb +0 -3
- data/lib/playbook/version.rb +1 -1
- metadata +95 -3
@@ -2,82 +2,91 @@
|
|
2
2
|
|
3
3
|
import React from 'react'
|
4
4
|
import DateTime from '../pb_kit/dateTime.js'
|
5
|
-
import { Icon } from '../'
|
5
|
+
import { Body, Icon, Title } from '../'
|
6
6
|
import classnames from 'classnames'
|
7
7
|
import { globalProps } from '../utilities/globalProps.js'
|
8
|
+
import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'
|
8
9
|
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
const month = value.toMonth().toUpperCase()
|
19
|
-
const day = value.toDay()
|
20
|
-
|
21
|
-
return `${month} ${day}`
|
22
|
-
}
|
23
|
-
|
24
|
-
type DateSubcomponent = {
|
25
|
-
value: DateTime,
|
10
|
+
type PbDateProps = {
|
11
|
+
aria: Object,
|
12
|
+
date: string | date,
|
13
|
+
className?: string,
|
14
|
+
data?: Object,
|
15
|
+
id?: string,
|
16
|
+
showIcon?: boolean,
|
17
|
+
showDayOfWeek?: boolean,
|
18
|
+
alignment?: "left" | "center" | "right"
|
26
19
|
}
|
27
20
|
|
28
|
-
const
|
29
|
-
|
30
|
-
{
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
/>
|
40
|
-
{defaultDateString(value)}
|
41
|
-
</h3>
|
42
|
-
)
|
43
|
-
|
44
|
-
const LargeDate = ({ value, ...props }: DateSubcomponent) => (
|
45
|
-
<h3 className={classnames('pb_title_kit_3', globalProps(props))}>
|
46
|
-
{largeDateString(value)}
|
47
|
-
</h3>
|
48
|
-
)
|
21
|
+
const PbDate = (props: PbDateProps) => {
|
22
|
+
const {
|
23
|
+
aria = {},
|
24
|
+
alignment = 'left',
|
25
|
+
className,
|
26
|
+
date,
|
27
|
+
data = {},
|
28
|
+
id,
|
29
|
+
showDayOfWeek = false,
|
30
|
+
showIcon = false,
|
31
|
+
} = props
|
49
32
|
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
33
|
+
const dateTimestamp = new DateTime({ value: date })
|
34
|
+
const weekday = dateTimestamp.toWeekday()
|
35
|
+
const month = dateTimestamp.toMonth()
|
36
|
+
const day = dateTimestamp.toDay()
|
37
|
+
const year = dateTimestamp.toYear()
|
38
|
+
const currentYear = new Date().getFullYear().toString()
|
55
39
|
|
56
|
-
const
|
57
|
-
const
|
40
|
+
const ariaProps = buildAriaProps(aria)
|
41
|
+
const dataProps = buildDataProps(data)
|
58
42
|
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
value={date}
|
65
|
-
/>
|
66
|
-
)
|
67
|
-
if (size == 'lg')
|
68
|
-
return (
|
69
|
-
<LargeDate
|
70
|
-
{...props}
|
71
|
-
className={className}
|
72
|
-
value={date}
|
73
|
-
/>
|
74
|
-
)
|
43
|
+
const classes = classnames(
|
44
|
+
className,
|
45
|
+
buildCss('pb_date_kit', alignment),
|
46
|
+
globalProps(props)
|
47
|
+
)
|
75
48
|
return (
|
76
|
-
<
|
77
|
-
{...
|
78
|
-
|
79
|
-
|
80
|
-
|
49
|
+
<div
|
50
|
+
{...ariaProps}
|
51
|
+
{...dataProps}
|
52
|
+
className={classes}
|
53
|
+
id={id}
|
54
|
+
>
|
55
|
+
<Title
|
56
|
+
size={4}
|
57
|
+
tag="h4"
|
58
|
+
>
|
59
|
+
<If condition={showIcon}>
|
60
|
+
<Body
|
61
|
+
color="light"
|
62
|
+
tag="span"
|
63
|
+
>
|
64
|
+
<Icon
|
65
|
+
fixedWidth
|
66
|
+
icon="calendar-alt"
|
67
|
+
/>
|
68
|
+
</Body>
|
69
|
+
</If>
|
70
|
+
<If condition={showDayOfWeek}>
|
71
|
+
{weekday}
|
72
|
+
<Body
|
73
|
+
color="light"
|
74
|
+
tag="span"
|
75
|
+
text=" • "
|
76
|
+
/>
|
77
|
+
</If>
|
78
|
+
<span>
|
79
|
+
{month}
|
80
|
+
{' '}
|
81
|
+
{day}
|
82
|
+
</span>
|
83
|
+
<If condition={currentYear != year}>
|
84
|
+
<span>
|
85
|
+
{` , ${year}`}
|
86
|
+
</span>
|
87
|
+
</If>
|
88
|
+
</Title>
|
89
|
+
</div>
|
81
90
|
)
|
82
91
|
}
|
83
92
|
|
@@ -1,2 +1,27 @@
|
|
1
1
|
@import "../pb_icon/icon";
|
2
2
|
@import "../pb_title/title";
|
3
|
+
|
4
|
+
[class^=pb_date_kit] {
|
5
|
+
display: flex;
|
6
|
+
flex-direction: row;
|
7
|
+
align-items: center;
|
8
|
+
> div {
|
9
|
+
margin-right: 4px !important;
|
10
|
+
}
|
11
|
+
|
12
|
+
&[class*=_center] {
|
13
|
+
display: flex;
|
14
|
+
flex-direction: row;
|
15
|
+
align-items: center;
|
16
|
+
justify-content: center;
|
17
|
+
margin-right: 4px !important;
|
18
|
+
}
|
19
|
+
|
20
|
+
&[class*=_right] {
|
21
|
+
display: flex;
|
22
|
+
flex-direction: row;
|
23
|
+
align-items: center;
|
24
|
+
justify-content: flex-end;
|
25
|
+
margin-left: 4px !important;
|
26
|
+
}
|
27
|
+
}
|
@@ -10,30 +10,39 @@ module Playbook
|
|
10
10
|
partial "pb_date/date"
|
11
11
|
|
12
12
|
prop :date, required: true
|
13
|
-
prop :
|
14
|
-
|
15
|
-
|
13
|
+
prop :timezone, default: "America/New_York"
|
14
|
+
prop :alignment, type: Playbook::Props::Enum,
|
15
|
+
values: %w[left center right],
|
16
|
+
default: "left"
|
17
|
+
prop :show_icon, type: Playbook::Props::Boolean,
|
18
|
+
default: false
|
19
|
+
prop :show_day_of_week, type: Playbook::Props::Boolean,
|
20
|
+
default: false
|
16
21
|
|
17
22
|
def classname
|
18
|
-
generate_classname("pb_date_kit")
|
23
|
+
generate_classname("pb_date_kit", alignment)
|
19
24
|
end
|
20
25
|
|
21
|
-
def
|
22
|
-
|
26
|
+
def date_day_of_week
|
27
|
+
pb_date_time.to_day_of_week
|
23
28
|
end
|
24
29
|
|
25
|
-
def
|
26
|
-
|
30
|
+
def day
|
31
|
+
pb_date_time.to_day
|
27
32
|
end
|
28
33
|
|
29
|
-
def
|
30
|
-
|
34
|
+
def month
|
35
|
+
pb_date_time.to_month.capitalize
|
36
|
+
end
|
37
|
+
|
38
|
+
def year
|
39
|
+
pb_date_time.to_year
|
31
40
|
end
|
32
41
|
|
33
42
|
private
|
34
43
|
|
35
44
|
def pb_date_time
|
36
|
-
Playbook::PbKit::PbDateTime.new(date)
|
45
|
+
Playbook::PbKit::PbDateTime.new(date, timezone)
|
37
46
|
end
|
38
47
|
end
|
39
48
|
end
|
@@ -0,0 +1,24 @@
|
|
1
|
+
|
2
|
+
<%= pb_rails("date", props: {
|
3
|
+
date: DateTime.now,
|
4
|
+
show_icon: true,
|
5
|
+
show_day_of_week: true
|
6
|
+
}) %>
|
7
|
+
|
8
|
+
<br><br>
|
9
|
+
|
10
|
+
<%= pb_rails("date", props: {
|
11
|
+
date: DateTime.now,
|
12
|
+
show_icon: true,
|
13
|
+
show_day_of_week: true,
|
14
|
+
alignment: "center"
|
15
|
+
}) %>
|
16
|
+
|
17
|
+
<br><br>
|
18
|
+
|
19
|
+
<%= pb_rails("date", props: {
|
20
|
+
date: DateTime.now,
|
21
|
+
show_icon: true,
|
22
|
+
show_day_of_week: true,
|
23
|
+
alignment: "right"
|
24
|
+
}) %>
|
@@ -0,0 +1,32 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Date as FormattedDate } from '../..'
|
3
|
+
|
4
|
+
const DateAlignment = () => {
|
5
|
+
return (
|
6
|
+
<div>
|
7
|
+
<FormattedDate
|
8
|
+
date="1995-12-25"
|
9
|
+
dayOfWeek
|
10
|
+
icon
|
11
|
+
/>
|
12
|
+
|
13
|
+
<br />
|
14
|
+
|
15
|
+
<FormattedDate
|
16
|
+
alignment="center"
|
17
|
+
date="2020-12-25"
|
18
|
+
dayOfWeek
|
19
|
+
icon
|
20
|
+
/>
|
21
|
+
|
22
|
+
<br />
|
23
|
+
|
24
|
+
<FormattedDate
|
25
|
+
alignment="right"
|
26
|
+
date={new Date()}
|
27
|
+
/>
|
28
|
+
</div>
|
29
|
+
)
|
30
|
+
}
|
31
|
+
|
32
|
+
export default DateAlignment
|
@@ -1,17 +1,9 @@
|
|
1
1
|
<%= pb_rails("date", props: {
|
2
2
|
date: Date.today,
|
3
|
-
size: "lg"
|
4
3
|
}) %>
|
5
4
|
|
6
|
-
<br
|
7
|
-
|
8
|
-
<%= pb_rails("date", props: {
|
9
|
-
date: DateTime.now
|
10
|
-
}) %>
|
11
|
-
|
12
|
-
<br>
|
5
|
+
<br />
|
13
6
|
|
14
7
|
<%= pb_rails("date", props: {
|
15
8
|
date: "2012-08-02T15:49:29Z",
|
16
|
-
size: "xs"
|
17
9
|
}) %>
|
@@ -1,25 +1,15 @@
|
|
1
1
|
import React from 'react'
|
2
|
-
import { Date } from '../../'
|
2
|
+
import { Date as FormattedDate } from '../../'
|
3
3
|
|
4
4
|
const DateDefault = () => {
|
5
5
|
return (
|
6
6
|
<div>
|
7
|
-
<
|
8
|
-
|
9
|
-
value="1995-12-25"
|
7
|
+
<FormattedDate
|
8
|
+
date="2012-12-25"
|
10
9
|
/>
|
11
10
|
|
12
|
-
<
|
13
|
-
|
14
|
-
<Date
|
15
|
-
value="17 Mar 69"
|
16
|
-
/>
|
17
|
-
|
18
|
-
<br />
|
19
|
-
|
20
|
-
<Date
|
21
|
-
size="xs"
|
22
|
-
value="2020-04-20T04:20:00.000Z"
|
11
|
+
<FormattedDate
|
12
|
+
date={new Date()}
|
23
13
|
/>
|
24
14
|
</div>
|
25
15
|
)
|
@@ -0,0 +1,20 @@
|
|
1
|
+
import React from 'react'
|
2
|
+
import { Date as FormattedDate } from '../..'
|
3
|
+
|
4
|
+
const DateDefault = () => {
|
5
|
+
return (
|
6
|
+
<div>
|
7
|
+
<FormattedDate
|
8
|
+
date="2012-12-25"
|
9
|
+
/>
|
10
|
+
|
11
|
+
<br />
|
12
|
+
|
13
|
+
<FormattedDate
|
14
|
+
date={new Date()}
|
15
|
+
/>
|
16
|
+
</div>
|
17
|
+
)
|
18
|
+
}
|
19
|
+
|
20
|
+
export default DateDefault
|
@@ -0,0 +1,51 @@
|
|
1
|
+
<%= pb_rails("caption", props: { text: "East Coast (Default)"}) %>
|
2
|
+
<%= pb_rails("date", props: {
|
3
|
+
date: DateTime.now,
|
4
|
+
timezone: "America/New_York"
|
5
|
+
}) %>
|
6
|
+
|
7
|
+
<br>
|
8
|
+
|
9
|
+
<%= pb_rails("caption", props: { text: "West Coast"}) %>
|
10
|
+
<%= pb_rails("date", props: {
|
11
|
+
date: DateTime.now,
|
12
|
+
timezone: "America/Los_Angeles"
|
13
|
+
}) %>
|
14
|
+
|
15
|
+
<br>
|
16
|
+
|
17
|
+
<%= pb_rails("caption", props: { text: "Toyko, Japan"}) %>
|
18
|
+
<%= pb_rails("date", props: {
|
19
|
+
date: DateTime.now,
|
20
|
+
timezone: "Asia/Tokyo"
|
21
|
+
}) %>
|
22
|
+
|
23
|
+
<br>
|
24
|
+
|
25
|
+
<%= pb_rails("caption", props: { text: "Anti-pattern example"}) %>
|
26
|
+
|
27
|
+
<%= pb_rails("date", props: {
|
28
|
+
date: Date.today,
|
29
|
+
timezone: "Australia/Sydney"
|
30
|
+
}) %>
|
31
|
+
<%= pb_rails("body", props: { text: "Date.today ignores Timezone"}) %>
|
32
|
+
|
33
|
+
<br>
|
34
|
+
|
35
|
+
<%= pb_rails("caption", props: { text: "DateTime respects Timezone"}) %>
|
36
|
+
|
37
|
+
<%= pb_rails("date", props: {
|
38
|
+
date: DateTime.now,
|
39
|
+
timezone: "Australia/Sydney"
|
40
|
+
}) %>
|
41
|
+
|
42
|
+
<%= pb_rails("body", props: { text: "'.now' in Australia is tomorrow (if you're EST after 10am)"}) %>
|
43
|
+
|
44
|
+
<br>
|
45
|
+
|
46
|
+
<%= pb_rails("caption", props: { text: "String Dates"}) %>
|
47
|
+
<%= pb_rails("date", props: {
|
48
|
+
date: "2012-08-02T00:49:29Z",
|
49
|
+
}) %>
|
50
|
+
|
51
|
+
<%= pb_rails("body", props: { text: "Defaults to UTC, then changes due to EST Timezone."}) %>
|
@@ -0,0 +1,6 @@
|
|
1
|
+
Depending on the data you send to the `date` prop you might have unexpected results due to ruby `Date` and `DateTime` classes.
|
2
|
+
|
3
|
+
Don't care about timezones? Use `Date`.
|
4
|
+
|
5
|
+
If you need a date that recognizes a timezone, especially when paired with the [Time kit](/kits/time), leverage `DateTime`.
|
6
|
+
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<div>
|
2
|
+
<%= pb_rails("date", props: {
|
3
|
+
date: DateTime.now,
|
4
|
+
}) %>
|
5
|
+
|
6
|
+
<br><br>
|
7
|
+
|
8
|
+
<%= pb_rails("date", props: {
|
9
|
+
date: DateTime.now,
|
10
|
+
show_icon: true
|
11
|
+
}) %>
|
12
|
+
|
13
|
+
<br><br>
|
14
|
+
|
15
|
+
<%= pb_rails("date", props: {
|
16
|
+
date: DateTime.now,
|
17
|
+
show_day_of_week: true
|
18
|
+
}) %>
|
19
|
+
|
20
|
+
<br><br>
|
21
|
+
|
22
|
+
<%= pb_rails("date", props: {
|
23
|
+
date: DateTime.now,
|
24
|
+
show_icon: true,
|
25
|
+
show_day_of_week: true
|
26
|
+
}) %>
|
27
|
+
</div>
|