playbook_ui 4.13.1 → 4.17.0.pre.alpha1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +6 -1
- data/app/pb_kits/playbook/_playbook.scss +6 -1
- data/app/pb_kits/playbook/data/menu.yml +7 -0
- data/app/pb_kits/playbook/index.js +11 -1
- data/app/pb_kits/playbook/packs/examples.js +6 -0
- data/app/pb_kits/playbook/packs/kits/pb_progress_step.js +2 -0
- data/app/pb_kits/playbook/pb_bar_graph/_bar_graph.jsx +6 -0
- 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_button/_button.jsx +9 -1
- data/app/pb_kits/playbook/pb_circle_chart/_circle_chart.html.erb +12 -0
- data/app/pb_kits/playbook/pb_circle_chart/_circle_chart.scss +6 -0
- data/app/pb_kits/playbook/pb_circle_chart/circle_chart.rb +81 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_default.html.erb +19 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_inner_sizes.html.erb +136 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_labels.html.erb +37 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_legend_kit.html.erb +22 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/_circle_chart_with_title.html.erb +38 -0
- data/app/pb_kits/playbook/pb_circle_chart/docs/example.yml +9 -0
- 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 +6 -0
- 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.jsx +1 -0
- data/app/pb_kits/playbook/pb_contact/contact.rb +2 -0
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.html.erb +5 -0
- data/app/pb_kits/playbook/pb_contact/docs/_contact_default.jsx +4 -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 +6 -9
- data/app/pb_kits/playbook/pb_currency/currency.rb +22 -29
- data/app/pb_kits/playbook/pb_dashboard/pbChartsLightTheme.js +26 -1
- data/app/pb_kits/playbook/pb_date_year_stacked/_date_year_stacked.jsx +2 -2
- data/app/pb_kits/playbook/pb_filter/Filter/CurrentFilters.jsx +56 -0
- data/app/pb_kits/playbook/pb_filter/Filter/FilterBackground.jsx +26 -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_label_pill/_label_pill.html.erb +1 -0
- data/app/pb_kits/playbook/pb_label_pill/_label_pill.jsx +59 -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_layout/_layout.jsx +66 -14
- 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 +4 -1
- data/app/pb_kits/playbook/pb_layout/docs/index.js +4 -1
- data/app/pb_kits/playbook/pb_line_graph/_line_graph.jsx +6 -0
- 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_online_status/_online_status.jsx +31 -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_popover/_popover.jsx +26 -19
- data/app/pb_kits/playbook/pb_popover/docs/example.yml +0 -3
- data/app/pb_kits/playbook/pb_popover/docs/index.js +0 -2
- 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 +35 -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 +16 -16
- data/app/pb_kits/playbook/pb_select/_select.jsx +2 -0
- 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/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_text_input/_text_input.html.erb +5 -3
- data/app/pb_kits/playbook/pb_text_input/_text_input.jsx +21 -1
- 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 -0
- data/app/pb_kits/playbook/pb_timestamp/_timestamp.jsx +39 -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_detail/_title_detail.jsx +47 -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_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/plugins/pb_chart.js +53 -1
- data/app/pb_kits/playbook/tokens/_colors.scss +7 -3
- data/app/pb_kits/playbook/vendor.js +3 -0
- data/lib/playbook/version.rb +1 -1
- data/lib/tasks/pb_release.rake +2 -0
- metadata +98 -12
- 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_portal.jsx +0 -34
- data/app/pb_kits/playbook/pb_popover/docs/_popover_with_button.html.erb +0 -4
@@ -0,0 +1,107 @@
|
|
1
|
+
/* @flow */
|
2
|
+
|
3
|
+
import React from 'react'
|
4
|
+
import classnames from 'classnames'
|
5
|
+
import { Icon, Title } from '../'
|
6
|
+
|
7
|
+
import {
|
8
|
+
buildAriaProps,
|
9
|
+
buildCss,
|
10
|
+
buildDataProps,
|
11
|
+
} from '../utilities/props'
|
12
|
+
|
13
|
+
type SelectableIconProps = {
|
14
|
+
aria?: Object,
|
15
|
+
checked?: Boolean,
|
16
|
+
className?: String,
|
17
|
+
disabled?: Boolean,
|
18
|
+
dark?: Boolean,
|
19
|
+
data?: Object,
|
20
|
+
icon: String,
|
21
|
+
inputId: String,
|
22
|
+
inputs: String,
|
23
|
+
multi?: Boolean,
|
24
|
+
name: String,
|
25
|
+
text: String,
|
26
|
+
value?: String
|
27
|
+
}
|
28
|
+
|
29
|
+
const SelectableIcon = ({
|
30
|
+
aria = {},
|
31
|
+
className,
|
32
|
+
checked = false,
|
33
|
+
dark = false,
|
34
|
+
data = {},
|
35
|
+
disabled = false,
|
36
|
+
icon,
|
37
|
+
inputId,
|
38
|
+
inputs = 'enabled',
|
39
|
+
multi = true,
|
40
|
+
name,
|
41
|
+
text,
|
42
|
+
value,
|
43
|
+
...props
|
44
|
+
}: SelectableIconProps) => {
|
45
|
+
const ariaProps = buildAriaProps(aria)
|
46
|
+
const dataProps = buildDataProps(data)
|
47
|
+
|
48
|
+
const css = buildCss({
|
49
|
+
'pb_selectable_icon_kit': true,
|
50
|
+
'checked': checked,
|
51
|
+
'dark': dark,
|
52
|
+
'disabled': disabled,
|
53
|
+
'enabled': !disabled,
|
54
|
+
})
|
55
|
+
|
56
|
+
const inputType = multi === false ? 'radio' : 'checkbox'
|
57
|
+
|
58
|
+
const inputIdPresent = inputId !== null ? inputId : name
|
59
|
+
|
60
|
+
return (
|
61
|
+
<div
|
62
|
+
{...ariaProps}
|
63
|
+
{...dataProps}
|
64
|
+
className={classnames(css, className)}
|
65
|
+
>
|
66
|
+
<If condition={inputs === 'disabled'}>
|
67
|
+
<>
|
68
|
+
<Icon
|
69
|
+
icon={icon}
|
70
|
+
size="2x"
|
71
|
+
/>
|
72
|
+
<Title
|
73
|
+
size={4}
|
74
|
+
tag="h4"
|
75
|
+
text={text}
|
76
|
+
/>
|
77
|
+
</>
|
78
|
+
</If>
|
79
|
+
<If condition={inputs === 'enabled'}>
|
80
|
+
<>
|
81
|
+
<input
|
82
|
+
{...props}
|
83
|
+
checked={checked}
|
84
|
+
disabled={disabled}
|
85
|
+
id={inputIdPresent}
|
86
|
+
name={name}
|
87
|
+
type={inputType}
|
88
|
+
value={value}
|
89
|
+
/>
|
90
|
+
<label htmlFor={inputIdPresent}>
|
91
|
+
<Icon
|
92
|
+
icon={icon}
|
93
|
+
size="2x"
|
94
|
+
/>
|
95
|
+
<Title
|
96
|
+
size={4}
|
97
|
+
tag="h4"
|
98
|
+
text={text}
|
99
|
+
/>
|
100
|
+
</label>
|
101
|
+
</>
|
102
|
+
</If>
|
103
|
+
</div>
|
104
|
+
)
|
105
|
+
}
|
106
|
+
|
107
|
+
export default SelectableIcon
|
@@ -0,0 +1,85 @@
|
|
1
|
+
[class^=pb_selectable_icon] {
|
2
|
+
|
3
|
+
text-align: center;
|
4
|
+
cursor: pointer;
|
5
|
+
|
6
|
+
:hover * {
|
7
|
+
filter: drop-shadow(0 0 8px rgba($shadow, 0.25));
|
8
|
+
transition-duration: $transition_short;
|
9
|
+
transition-timing-function: $easeIn;
|
10
|
+
}
|
11
|
+
|
12
|
+
* {
|
13
|
+
cursor: pointer;
|
14
|
+
}
|
15
|
+
|
16
|
+
h4 {
|
17
|
+
margin-top: $space_xs !important;
|
18
|
+
user-select: none;
|
19
|
+
}
|
20
|
+
|
21
|
+
&[class*=_disabled] {
|
22
|
+
opacity: $opacity_6;
|
23
|
+
cursor: not-allowed;
|
24
|
+
|
25
|
+
* {
|
26
|
+
cursor: not-allowed;
|
27
|
+
}
|
28
|
+
}
|
29
|
+
|
30
|
+
input[type="checkbox"],
|
31
|
+
input[type="radio"] {
|
32
|
+
-webkit-appearance: none;
|
33
|
+
-moz-appearance: none;
|
34
|
+
display: none;
|
35
|
+
appearance: none;
|
36
|
+
|
37
|
+
transition-property: color;
|
38
|
+
transition-duration: $transition_short;
|
39
|
+
|
40
|
+
&:checked ~ label * {
|
41
|
+
transition-timing-function: $easeIn;
|
42
|
+
color: $primary;
|
43
|
+
}
|
44
|
+
|
45
|
+
&:not(:checked) ~ label {
|
46
|
+
transition-timing-function: $easeOut;
|
47
|
+
color: $slate;
|
48
|
+
|
49
|
+
h4 {
|
50
|
+
transition-delay: .15s;
|
51
|
+
}
|
52
|
+
}
|
53
|
+
}
|
54
|
+
|
55
|
+
|
56
|
+
&[class*=_dark] {
|
57
|
+
|
58
|
+
input[type="checkbox"],
|
59
|
+
input[type="radio"] {
|
60
|
+
-webkit-appearance: none;
|
61
|
+
-moz-appearance: none;
|
62
|
+
display: none;
|
63
|
+
appearance: none;
|
64
|
+
|
65
|
+
transition-property: color;
|
66
|
+
transition-duration: $transition_short;
|
67
|
+
|
68
|
+
|
69
|
+
&:checked ~ label * {
|
70
|
+
transition-timing-function: $easeIn;
|
71
|
+
color: $active_dark !important;
|
72
|
+
}
|
73
|
+
|
74
|
+
&:not(:checked) ~ label {
|
75
|
+
transition-timing-function: $easeOut;
|
76
|
+
color: $text_dk_lighter;
|
77
|
+
|
78
|
+
h4 {
|
79
|
+
transition-delay: .15s;
|
80
|
+
color: $text_dk_default;
|
81
|
+
}
|
82
|
+
}
|
83
|
+
}
|
84
|
+
}
|
85
|
+
}
|
@@ -0,0 +1,26 @@
|
|
1
|
+
<div class="pb--doc-demo-row">
|
2
|
+
|
3
|
+
<%= pb_rails("selectable_icon", props: {
|
4
|
+
icon: "file-word",
|
5
|
+
dark: true,
|
6
|
+
input_id: 7,
|
7
|
+
checked: true,
|
8
|
+
text: "Doc"
|
9
|
+
}) %>
|
10
|
+
|
11
|
+
<%= pb_rails("selectable_icon", props: {
|
12
|
+
icon: "file-pdf",
|
13
|
+
dark: true,
|
14
|
+
input_id: 8,
|
15
|
+
text: "PDF"
|
16
|
+
}) %>
|
17
|
+
|
18
|
+
<%= pb_rails("selectable_icon", props: {
|
19
|
+
icon: "file-image",
|
20
|
+
dark: true,
|
21
|
+
input_id: 9,
|
22
|
+
disabled: true,
|
23
|
+
text: "PNG"
|
24
|
+
}) %>
|
25
|
+
|
26
|
+
</div>
|
@@ -0,0 +1,43 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { SelectableIcon } from '../../'
|
3
|
+
|
4
|
+
const SelectableIconDark = () => {
|
5
|
+
const [ checkSelected, toggleSelected ] = useState(true)
|
6
|
+
const [ checkUnselected, toggleUnselected ] = useState(false)
|
7
|
+
const [ checkDisabled, toggleDisabled ] = useState(false)
|
8
|
+
|
9
|
+
return (
|
10
|
+
|
11
|
+
<div className="pb--doc-demo-row">
|
12
|
+
<SelectableIcon
|
13
|
+
checked={checkSelected}
|
14
|
+
dark
|
15
|
+
icon="file-word"
|
16
|
+
inputId={16}
|
17
|
+
onChange={() => toggleSelected(!checkSelected)}
|
18
|
+
text="Doc"
|
19
|
+
/>
|
20
|
+
|
21
|
+
<SelectableIcon
|
22
|
+
checked={checkUnselected}
|
23
|
+
dark
|
24
|
+
icon="file-pdf"
|
25
|
+
inputId={17}
|
26
|
+
onChange={() => toggleUnselected(!checkUnselected)}
|
27
|
+
text="PDF"
|
28
|
+
/>
|
29
|
+
|
30
|
+
<SelectableIcon
|
31
|
+
checked={checkDisabled}
|
32
|
+
dark
|
33
|
+
disabled
|
34
|
+
icon="file-image"
|
35
|
+
inputId={18}
|
36
|
+
onChange={() => toggleDisabled(!checkDisabled)}
|
37
|
+
text="PNG"
|
38
|
+
/>
|
39
|
+
</div>
|
40
|
+
)
|
41
|
+
}
|
42
|
+
|
43
|
+
export default SelectableIconDark
|
@@ -0,0 +1,23 @@
|
|
1
|
+
<div class="pb--doc-demo-row">
|
2
|
+
|
3
|
+
<%= pb_rails("selectable_icon", props: {
|
4
|
+
icon: "dollar-sign",
|
5
|
+
input_id: 1,
|
6
|
+
checked: true,
|
7
|
+
text: "US Dollar"
|
8
|
+
}) %>
|
9
|
+
|
10
|
+
<%= pb_rails("selectable_icon", props: {
|
11
|
+
icon: "euro-sign",
|
12
|
+
input_id: 2,
|
13
|
+
text: "Euro"
|
14
|
+
}) %>
|
15
|
+
|
16
|
+
<%= pb_rails("selectable_icon", props: {
|
17
|
+
icon: "yen-sign",
|
18
|
+
input_id: 3,
|
19
|
+
disabled: true,
|
20
|
+
text: "Yen"
|
21
|
+
}) %>
|
22
|
+
|
23
|
+
</div>
|
@@ -0,0 +1,40 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { SelectableIcon } from '../../'
|
3
|
+
|
4
|
+
const SelectableIconDefault = () => {
|
5
|
+
const [ checkSelected, toggleSelected ] = useState(true)
|
6
|
+
const [ checkUnselected, toggleUnselected ] = useState(false)
|
7
|
+
const [ checkDisabled, toggleDisabled ] = useState(false)
|
8
|
+
|
9
|
+
return (
|
10
|
+
|
11
|
+
<div className="pb--doc-demo-row">
|
12
|
+
<SelectableIcon
|
13
|
+
checked={checkSelected}
|
14
|
+
icon="dollar-sign"
|
15
|
+
inputId={10}
|
16
|
+
onChange={() => toggleSelected(!checkSelected)}
|
17
|
+
text="US Dollar"
|
18
|
+
/>
|
19
|
+
|
20
|
+
<SelectableIcon
|
21
|
+
checked={checkUnselected}
|
22
|
+
icon="euro-sign"
|
23
|
+
inputId={11}
|
24
|
+
onChange={() => toggleUnselected(!checkUnselected)}
|
25
|
+
text="Euro"
|
26
|
+
/>
|
27
|
+
|
28
|
+
<SelectableIcon
|
29
|
+
checked={checkDisabled}
|
30
|
+
disabled
|
31
|
+
icon="yen-sign"
|
32
|
+
inputId={12}
|
33
|
+
onChange={() => toggleDisabled(!checkDisabled)}
|
34
|
+
text="Yen"
|
35
|
+
/>
|
36
|
+
</div>
|
37
|
+
)
|
38
|
+
}
|
39
|
+
|
40
|
+
export default SelectableIconDefault
|
@@ -0,0 +1,27 @@
|
|
1
|
+
<div class="pb--doc-demo-row">
|
2
|
+
|
3
|
+
<%= pb_rails("selectable_icon", props: {
|
4
|
+
icon: "cassette-tape",
|
5
|
+
input_id: 4,
|
6
|
+
multi: false,
|
7
|
+
name: "select",
|
8
|
+
text: "Cassette"
|
9
|
+
}) %>
|
10
|
+
|
11
|
+
<%= pb_rails("selectable_icon", props: {
|
12
|
+
icon: "compact-disc",
|
13
|
+
input_id: 5,
|
14
|
+
multi: false,
|
15
|
+
name: "select",
|
16
|
+
text: "CD"
|
17
|
+
}) %>
|
18
|
+
|
19
|
+
<%= pb_rails("selectable_icon", props: {
|
20
|
+
icon: "album-collection",
|
21
|
+
input_id: 6,
|
22
|
+
multi: false,
|
23
|
+
name: "select",
|
24
|
+
text: "Vinyl"
|
25
|
+
}) %>
|
26
|
+
|
27
|
+
</div>
|
@@ -0,0 +1,46 @@
|
|
1
|
+
import React, { useState } from 'react'
|
2
|
+
import { SelectableIcon } from '../../'
|
3
|
+
|
4
|
+
const SelectableIconSingleSelect = () => {
|
5
|
+
const [ selectedFormat, toggleFormat ] = useState(null)
|
6
|
+
|
7
|
+
return (
|
8
|
+
|
9
|
+
<div className="pb--doc-demo-row">
|
10
|
+
<SelectableIcon
|
11
|
+
checked={selectedFormat === 'Cassette'}
|
12
|
+
icon="cassette-tape"
|
13
|
+
inputId={13}
|
14
|
+
multi={false}
|
15
|
+
name="music-format"
|
16
|
+
onChange={() => toggleFormat('Cassette')}
|
17
|
+
text="Cassette"
|
18
|
+
value="Cassette"
|
19
|
+
/>
|
20
|
+
|
21
|
+
<SelectableIcon
|
22
|
+
checked={selectedFormat === 'CD'}
|
23
|
+
icon="compact-disc"
|
24
|
+
inputId={14}
|
25
|
+
multi={false}
|
26
|
+
name="music-format"
|
27
|
+
onChange={() => toggleFormat('CD')}
|
28
|
+
text="CD"
|
29
|
+
value="CD"
|
30
|
+
/>
|
31
|
+
|
32
|
+
<SelectableIcon
|
33
|
+
checked={selectedFormat === 'Vinyl'}
|
34
|
+
icon="album-collection"
|
35
|
+
inputId={15}
|
36
|
+
multi={false}
|
37
|
+
name="music-format"
|
38
|
+
onChange={() => toggleFormat('Vinyl')}
|
39
|
+
text="Vinyl"
|
40
|
+
value="Vinyl"
|
41
|
+
/>
|
42
|
+
</div>
|
43
|
+
)
|
44
|
+
}
|
45
|
+
|
46
|
+
export default SelectableIconSingleSelect
|
@@ -0,0 +1,12 @@
|
|
1
|
+
examples:
|
2
|
+
|
3
|
+
rails:
|
4
|
+
- selectable_icon_default: Default
|
5
|
+
- selectable_icon_single_select: Single Select
|
6
|
+
- selectable_icon_dark: Dark
|
7
|
+
|
8
|
+
react:
|
9
|
+
- selectable_icon_default: Default
|
10
|
+
- selectable_icon_single_select: Single Select
|
11
|
+
- selectable_icon_dark: Dark
|
12
|
+
|
@@ -0,0 +1,55 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module Playbook
|
4
|
+
module PbSelectableIcon
|
5
|
+
class SelectableIcon
|
6
|
+
include Playbook::Props
|
7
|
+
|
8
|
+
partial "pb_selectable_icon/selectable_icon"
|
9
|
+
|
10
|
+
# Icon props
|
11
|
+
prop :icon, type: Playbook::Props::String
|
12
|
+
prop :dark, type: Playbook::Props::Boolean,
|
13
|
+
default: false
|
14
|
+
# Title text
|
15
|
+
prop :text, type: Playbook::Props::String
|
16
|
+
|
17
|
+
# Form Props
|
18
|
+
prop :input_id, type: Playbook::Props::String
|
19
|
+
prop :name, type: Playbook::Props::String
|
20
|
+
prop :multi, type: Playbook::Props::Boolean,
|
21
|
+
default: true
|
22
|
+
prop :checked, type: Playbook::Props::Boolean,
|
23
|
+
default: false
|
24
|
+
prop :disabled, type: Playbook::Props::Boolean,
|
25
|
+
default: false
|
26
|
+
prop :value
|
27
|
+
|
28
|
+
# Conditional rendering for input field
|
29
|
+
prop :inputs, type: Playbook::Props::String,
|
30
|
+
default: "enabled"
|
31
|
+
|
32
|
+
def classname
|
33
|
+
generate_classname("pb_selectable_icon_kit", checked_class, dark_class, enabled_disabled_class)
|
34
|
+
end
|
35
|
+
|
36
|
+
def input_id_present
|
37
|
+
input_id.present? ? input_id : name
|
38
|
+
end
|
39
|
+
|
40
|
+
private
|
41
|
+
|
42
|
+
def checked_class
|
43
|
+
checked ? "checked" : nil
|
44
|
+
end
|
45
|
+
|
46
|
+
def dark_class
|
47
|
+
dark ? "dark" : nil
|
48
|
+
end
|
49
|
+
|
50
|
+
def enabled_disabled_class
|
51
|
+
disabled ? "disabled" : "enabled"
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
55
|
+
end
|