playbook_ui 13.31.0.pre.alpha.PLAY10863204 → 13.31.0.pre.alpha.play1262iconstyles3171
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_background/background.html.erb +11 -2
- data/app/pb_kits/playbook/pb_body/body.html.erb +6 -1
- data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumb_item.html.erb +6 -1
- data/app/pb_kits/playbook/pb_bread_crumbs/bread_crumbs.html.erb +6 -1
- data/app/pb_kits/playbook/pb_caption/caption.html.erb +6 -1
- data/app/pb_kits/playbook/pb_card/card.html.erb +7 -1
- data/app/pb_kits/playbook/pb_collapsible/__snapshots__/collapsible.test.js.snap +1 -1
- data/app/pb_kits/playbook/pb_date_year_stacked/docs/_date_year_stacked_default.jsx +1 -4
- data/app/pb_kits/playbook/pb_detail/detail.html.erb +6 -1
- data/app/pb_kits/playbook/pb_dialog/dialog.html.erb +6 -1
- data/app/pb_kits/playbook/pb_dialog/dialog_body.html.erb +6 -1
- data/app/pb_kits/playbook/pb_dialog/dialog_footer.html.erb +5 -2
- data/app/pb_kits/playbook/pb_dialog/dialog_header.html.erb +6 -1
- data/app/pb_kits/playbook/pb_draggable/context/index.tsx +1 -15
- data/app/pb_kits/playbook/pb_draggable/context/types.ts +0 -5
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_default.jsx +19 -14
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_default.md +3 -5
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_cards.md +3 -7
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_list.md +5 -3
- data/app/pb_kits/playbook/pb_draggable/docs/_draggable_with_selectable_list.md +5 -3
- data/app/pb_kits/playbook/pb_dropdown/dropdown.html.erb +1 -3
- data/app/pb_kits/playbook/pb_dropdown/dropdown.rb +0 -2
- data/app/pb_kits/playbook/pb_dropdown/index.js +4 -33
- data/app/pb_kits/playbook/pb_flex/flex.html.erb +5 -1
- data/app/pb_kits/playbook/pb_form/docs/_form_form_with_validate.html.erb +0 -9
- data/app/pb_kits/playbook/pb_hashtag/hashtag.html.erb +6 -1
- data/app/pb_kits/playbook/pb_highlight/highlight.html.erb +5 -1
- data/app/pb_kits/playbook/pb_home_address_street/home_address_street.html.erb +5 -1
- data/app/pb_kits/playbook/pb_icon/_icon.scss +223 -1
- data/app/pb_kits/playbook/pb_icon/_icon.tsx +99 -7
- data/app/pb_kits/playbook/pb_icon/icon.rb +22 -16
- data/app/pb_kits/playbook/pb_nav/_nav_item.test.js +2 -2
- data/app/pb_kits/playbook/pb_rich_text_editor/_rich_text_editor.tsx +23 -8
- data/app/pb_kits/playbook/pb_table/_table.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/index.ts +4 -4
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_body.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_cell.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_head.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_header.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +1 -1
- data/app/pb_kits/playbook/pb_table/table.test.js +0 -2
- data/app/pb_kits/playbook/pb_text_input/_text_input.tsx +1 -1
- data/app/pb_kits/playbook/pb_text_input/docs/_text_input_default.jsx +1 -1
- data/app/pb_kits/playbook/pb_textarea/_textarea.tsx +27 -45
- data/app/pb_kits/playbook/pb_textarea/index.tsx +3 -3
- data/app/pb_kits/playbook/pb_time/_time.tsx +3 -3
- data/app/pb_kits/playbook/pb_time_range_inline/_time_range_inline.tsx +1 -1
- data/app/pb_kits/playbook/pb_timeline/_item.tsx +1 -1
- data/app/pb_kits/playbook/pb_timeline/_timeline.tsx +1 -1
- data/app/pb_kits/playbook/pb_title_detail/_title_detail.tsx +10 -10
- data/app/pb_kits/playbook/pb_toggle/_toggle.tsx +1 -1
- data/app/pb_kits/playbook/pb_tooltip/_tooltip.tsx +2 -2
- data/app/pb_kits/playbook/pb_treemap_chart/_treemap_chart.tsx +2 -1
- data/app/pb_kits/playbook/pb_treemap_chart/treemapChart.test.js +0 -2
- data/app/pb_kits/playbook/pb_typeahead/_typeahead.tsx +3 -3
- data/app/pb_kits/playbook/pb_typeahead/components/ClearIndicator.tsx +4 -4
- data/app/pb_kits/playbook/pb_typeahead/components/Control.tsx +7 -11
- data/app/pb_kits/playbook/pb_typeahead/components/IndicatorsContainer.tsx +3 -8
- data/app/pb_kits/playbook/pb_typeahead/components/MenuList.tsx +1 -6
- data/app/pb_kits/playbook/pb_typeahead/components/MultiValue.tsx +19 -18
- data/app/pb_kits/playbook/pb_typeahead/components/Option.tsx +6 -6
- data/app/pb_kits/playbook/pb_typeahead/components/Placeholder.tsx +6 -6
- data/app/pb_kits/playbook/pb_typeahead/components/ValueContainer.tsx +3 -3
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_custom_menu_list.jsx +0 -2
- data/app/pb_kits/playbook/pb_typeahead/docs/_typeahead_with_pills_async.jsx +2 -2
- data/app/pb_kits/playbook/pb_typeahead/index.ts +31 -31
- data/app/pb_kits/playbook/pb_user/_user.tsx +1 -1
- data/app/pb_kits/playbook/pb_user_badge/_user_badge.tsx +6 -6
- data/app/pb_kits/playbook/pb_user_badge/badges/million-dollar.tsx +235 -236
- data/app/pb_kits/playbook/pb_user_badge/badges/veteran.tsx +1 -1
- data/app/pb_kits/playbook/pb_walkthrough/_walkthrough.tsx +63 -68
- data/app/pb_kits/playbook/pb_weekday_stacked/_weekday_stacked.tsx +2 -2
- data/dist/menu.yml +472 -566
- data/dist/playbook-rails.js +6 -6
- data/lib/playbook/version.rb +1 -1
- metadata +2 -2
@@ -52,15 +52,14 @@ const Textarea = ({
|
|
52
52
|
label,
|
53
53
|
maxCharacters,
|
54
54
|
name,
|
55
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
56
55
|
onChange = () => {},
|
57
56
|
placeholder,
|
58
57
|
required,
|
59
58
|
rows = 4,
|
60
59
|
value,
|
61
60
|
...props
|
62
|
-
}: TextareaProps) => {
|
63
|
-
|
61
|
+
}: TextareaProps, ref: any) => {
|
62
|
+
ref = useRef<HTMLTextAreaElement>(null)
|
64
63
|
useEffect(() => {
|
65
64
|
if (ref.current && resize === 'auto') {
|
66
65
|
PbTextarea.addMatch(ref.current)
|
@@ -72,75 +71,58 @@ const Textarea = ({
|
|
72
71
|
const resizeClass = `resize_${resize}`
|
73
72
|
const classes = classnames('pb_textarea_kit', errorClass, inlineClass, resizeClass, globalProps(props), className)
|
74
73
|
const noCount = typeof characterCount !== 'undefined'
|
75
|
-
const ariaProps: {[key: string]:
|
76
|
-
const dataProps: {[key: string]:
|
74
|
+
const ariaProps: {[key: string]: any} = buildAriaProps(aria)
|
75
|
+
const dataProps: {[key: string]: any} = buildDataProps(data)
|
77
76
|
const htmlProps = buildHtmlProps(htmlOptions)
|
78
|
-
const checkIfZero = (characterCount: string | number) => {
|
79
|
-
return characterCount == 0 ? characterCount.toString() : characterCount
|
80
|
-
}
|
81
77
|
const characterCounter = () => {
|
82
78
|
return maxCharacters && characterCount ? `${checkIfZero(characterCount)} / ${maxCharacters}` : `${checkIfZero(characterCount)}`
|
83
79
|
}
|
84
80
|
|
81
|
+
const checkIfZero = (characterCount: string | number) => {
|
82
|
+
return characterCount == 0 ? characterCount.toString() : characterCount
|
83
|
+
}
|
84
|
+
|
85
85
|
return (
|
86
86
|
<div
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
87
|
+
{...ariaProps}
|
88
|
+
{...dataProps}
|
89
|
+
{...htmlProps}
|
90
|
+
className={classes}
|
91
91
|
>
|
92
92
|
<Caption text={label} />
|
93
93
|
{children || (
|
94
94
|
<textarea
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
95
|
+
className="pb_textarea_kit"
|
96
|
+
disabled={disabled}
|
97
|
+
name={name}
|
98
|
+
onChange={onChange}
|
99
|
+
placeholder={placeholder}
|
100
|
+
ref={ref}
|
101
|
+
required={required}
|
102
|
+
rows={rows}
|
103
|
+
value={value}
|
104
|
+
{...props}
|
105
105
|
/>
|
106
106
|
)}
|
107
107
|
|
108
108
|
{error ? (
|
109
109
|
<>
|
110
110
|
{characterCount ? (
|
111
|
-
<Flex
|
112
|
-
spacing="between"
|
113
|
-
vertical="center"
|
114
|
-
>
|
111
|
+
<Flex spacing="between" vertical="center">
|
115
112
|
<FlexItem>
|
116
|
-
<Body
|
117
|
-
margin="none"
|
118
|
-
status="negative"
|
119
|
-
text={error}
|
120
|
-
/>
|
113
|
+
<Body margin="none" status="negative" text={error} />
|
121
114
|
</FlexItem>
|
122
115
|
<FlexItem>
|
123
|
-
<Caption
|
124
|
-
margin="none"
|
125
|
-
size="xs"
|
126
|
-
text={characterCounter()}
|
127
|
-
/>
|
116
|
+
<Caption margin="none" size="xs" text={characterCounter()} />
|
128
117
|
</FlexItem>
|
129
118
|
</Flex>
|
130
119
|
) : (
|
131
|
-
<Body
|
132
|
-
status="negative"
|
133
|
-
text={error}
|
134
|
-
/>
|
120
|
+
<Body status="negative" text={error} />
|
135
121
|
)}
|
136
122
|
</>
|
137
123
|
) : (
|
138
124
|
noCount && (
|
139
|
-
<Caption
|
140
|
-
margin="none"
|
141
|
-
size="xs"
|
142
|
-
text={characterCounter()}
|
143
|
-
/>
|
125
|
+
<Caption margin="none" size="xs" text={characterCounter()} />
|
144
126
|
)
|
145
127
|
)}
|
146
128
|
</div>
|
@@ -3,16 +3,16 @@ import PbEnhancedElement from '../pb_enhanced_element'
|
|
3
3
|
export default class PbTextarea extends PbEnhancedElement {
|
4
4
|
style: {[key: string]: string}
|
5
5
|
scrollHeight: string
|
6
|
-
static get selector()
|
6
|
+
static get selector() {
|
7
7
|
return '.resize_auto textarea'
|
8
8
|
}
|
9
9
|
|
10
|
-
onInput()
|
10
|
+
onInput() {
|
11
11
|
this.style.height = 'auto'
|
12
12
|
this.style.height = (this.scrollHeight) + 'px'
|
13
13
|
}
|
14
14
|
|
15
|
-
connect()
|
15
|
+
connect() {
|
16
16
|
this.element.setAttribute('style', 'height:' + (this.element.scrollHeight) + 'px;overflow-y:hidden;')
|
17
17
|
this.element.addEventListener('input', this.onInput, false)
|
18
18
|
}
|
@@ -24,7 +24,7 @@ type TimeProps = {
|
|
24
24
|
unstyled?: boolean;
|
25
25
|
} & GlobalProps
|
26
26
|
|
27
|
-
const Time = (props: TimeProps)
|
27
|
+
const Time = (props: TimeProps) => {
|
28
28
|
const {
|
29
29
|
align,
|
30
30
|
className,
|
@@ -47,8 +47,8 @@ const Time = (props: TimeProps): React.ReactElement => {
|
|
47
47
|
|
48
48
|
return (
|
49
49
|
<div
|
50
|
-
|
51
|
-
|
50
|
+
{...htmlProps}
|
51
|
+
className={classes}
|
52
52
|
>
|
53
53
|
{showIcon && (
|
54
54
|
unstyled
|
@@ -36,7 +36,7 @@ const dateTimeIso = (dateValue: Date) => {
|
|
36
36
|
return DateTime.toIso(dateValue)
|
37
37
|
}
|
38
38
|
|
39
|
-
const TimeRangeInline = (props: TimeRangeInlineProps)
|
39
|
+
const TimeRangeInline = (props: TimeRangeInlineProps) => {
|
40
40
|
const {
|
41
41
|
aria = {},
|
42
42
|
className,
|
@@ -26,7 +26,7 @@ const TimelineItem = ({
|
|
26
26
|
iconColor = 'default',
|
27
27
|
lineStyle = 'solid',
|
28
28
|
...props
|
29
|
-
}: ItemProps)
|
29
|
+
}: ItemProps) => {
|
30
30
|
const timelineItemCss = buildCss('pb_timeline_item_kit', lineStyle)
|
31
31
|
|
32
32
|
const htmlProps = buildHtmlProps(htmlOptions)
|
@@ -27,7 +27,7 @@ const Timeline = ({
|
|
27
27
|
orientation = 'horizontal',
|
28
28
|
showDate = false,
|
29
29
|
...props
|
30
|
-
}: TimelineProps)
|
30
|
+
}: TimelineProps) => {
|
31
31
|
const ariaProps = buildAriaProps(aria)
|
32
32
|
const dataProps = buildDataProps(data)
|
33
33
|
const htmlProps = buildHtmlProps(htmlOptions)
|
@@ -18,7 +18,7 @@ type TitleDetailProps = {
|
|
18
18
|
title: string,
|
19
19
|
} & GlobalProps
|
20
20
|
|
21
|
-
const TitleDetail = (props: TitleDetailProps)
|
21
|
+
const TitleDetail = (props: TitleDetailProps) => {
|
22
22
|
const {
|
23
23
|
align = "left",
|
24
24
|
aria = {},
|
@@ -37,19 +37,19 @@ const TitleDetail = (props: TitleDetailProps): React.ReactElement => {
|
|
37
37
|
|
38
38
|
return (
|
39
39
|
<div
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
40
|
+
{...ariaProps}
|
41
|
+
{...dataProps}
|
42
|
+
{...htmlProps}
|
43
|
+
className={classnames(pbCss, globalProps(props), className)}
|
44
|
+
id={id}
|
45
45
|
>
|
46
46
|
<Title
|
47
|
-
|
48
|
-
|
47
|
+
size={4}
|
48
|
+
text={title}
|
49
49
|
/>
|
50
50
|
<Body
|
51
|
-
|
52
|
-
|
51
|
+
color="light"
|
52
|
+
text={detail}
|
53
53
|
/>
|
54
54
|
</div>
|
55
55
|
)
|
@@ -50,8 +50,8 @@ const Tooltip = forwardRef((props: TooltipProps, ref: ForwardedRef<unknown>): Re
|
|
50
50
|
...rest
|
51
51
|
} = props
|
52
52
|
|
53
|
-
const dataProps: { [key: string]:
|
54
|
-
const ariaProps: { [key: string]:
|
53
|
+
const dataProps: { [key: string]: any } = buildDataProps(data)
|
54
|
+
const ariaProps: { [key: string]: any } = buildAriaProps(aria)
|
55
55
|
const htmlProps = buildHtmlProps(htmlOptions)
|
56
56
|
|
57
57
|
const css = classnames(
|
@@ -52,7 +52,7 @@ const TreemapChart = ({
|
|
52
52
|
tooltipHtml = '<span style="font-weight: bold; color:{point.color};">●</span>{point.name}: <b>{point.value}</b>',
|
53
53
|
type = "treemap",
|
54
54
|
...props
|
55
|
-
}: TreemapChartProps)
|
55
|
+
}: TreemapChartProps) => {
|
56
56
|
|
57
57
|
const ariaProps = buildAriaProps(aria)
|
58
58
|
const dataProps = buildDataProps(data)
|
@@ -98,6 +98,7 @@ const TreemapChart = ({
|
|
98
98
|
const [options, setOptions] = useState({});
|
99
99
|
|
100
100
|
useEffect(() => {
|
101
|
+
|
101
102
|
setOptions(merge(staticOptions, customOptions));
|
102
103
|
}, [chartData]);
|
103
104
|
|
@@ -42,8 +42,8 @@ type TypeaheadProps = {
|
|
42
42
|
id?: string,
|
43
43
|
label?: string,
|
44
44
|
loadOptions?: string | Noop,
|
45
|
-
getOptionLabel?: string | (() =>
|
46
|
-
getOptionValue?: string | (() =>
|
45
|
+
getOptionLabel?: string | (() => any),
|
46
|
+
getOptionValue?: string | (() => any),
|
47
47
|
name?: string,
|
48
48
|
}
|
49
49
|
|
@@ -77,7 +77,7 @@ const Typeahead = ({
|
|
77
77
|
id,
|
78
78
|
loadOptions = noop,
|
79
79
|
...props
|
80
|
-
}: TypeaheadProps)
|
80
|
+
}: TypeaheadProps) => {
|
81
81
|
const selectProps = {
|
82
82
|
cacheOptions: true,
|
83
83
|
components: {
|
@@ -1,16 +1,16 @@
|
|
1
1
|
import React, { useEffect } from 'react'
|
2
2
|
import { components } from 'react-select'
|
3
3
|
|
4
|
-
const ClearContainer = (props: any)
|
4
|
+
const ClearContainer = (props: any) => {
|
5
5
|
const { selectProps, clearValue } = props
|
6
6
|
useEffect(() => {
|
7
7
|
document.addEventListener(`pb-typeahead-kit-${selectProps.id}:clear`, clearValue)
|
8
|
-
}, [])
|
8
|
+
}, [true])
|
9
9
|
|
10
10
|
return (
|
11
11
|
<components.ClearIndicator
|
12
|
-
|
13
|
-
|
12
|
+
className="clear_indicator"
|
13
|
+
{...props}
|
14
14
|
/>
|
15
15
|
)
|
16
16
|
}
|
@@ -5,24 +5,20 @@ import Flex from '../../pb_flex/_flex'
|
|
5
5
|
import TextInput from '../../pb_text_input/_text_input'
|
6
6
|
|
7
7
|
type Props = {
|
8
|
-
selectProps:
|
9
|
-
dark?: boolean,
|
10
|
-
label: string,
|
11
|
-
error?: string,
|
12
|
-
},
|
8
|
+
selectProps: any,
|
13
9
|
}
|
14
10
|
|
15
|
-
const TypeaheadControl = (props: Props)
|
11
|
+
const TypeaheadControl = (props: Props) => (
|
16
12
|
<div className="pb_typeahead_wrapper">
|
17
13
|
<TextInput
|
18
|
-
|
19
|
-
|
20
|
-
|
14
|
+
dark={props.selectProps.dark}
|
15
|
+
error={props.selectProps.error}
|
16
|
+
label={props.selectProps.label}
|
21
17
|
>
|
22
18
|
<Flex>
|
23
19
|
<components.Control
|
24
|
-
|
25
|
-
|
20
|
+
className="text_input"
|
21
|
+
{...props}
|
26
22
|
/>
|
27
23
|
</Flex>
|
28
24
|
</TextInput>
|
@@ -1,15 +1,10 @@
|
|
1
1
|
import React from 'react'
|
2
2
|
import { components } from 'react-select'
|
3
3
|
|
4
|
-
|
5
|
-
children: React.ReactNode,
|
6
|
-
}
|
7
|
-
|
8
|
-
|
9
|
-
const IndicatorsContainer = (props: IndicatorsContainerProps): React.ReactElement => (
|
4
|
+
const IndicatorsContainer = (props: any) => (
|
10
5
|
<components.IndicatorsContainer
|
11
|
-
|
12
|
-
|
6
|
+
className="text_input_indicators"
|
7
|
+
{...props}
|
13
8
|
/>
|
14
9
|
)
|
15
10
|
|
@@ -1,12 +1,7 @@
|
|
1
1
|
import React from 'react'
|
2
2
|
import { components } from 'react-select'
|
3
3
|
|
4
|
-
|
5
|
-
children: React.ReactNode,
|
6
|
-
footer: React.ReactNode,
|
7
|
-
}
|
8
|
-
|
9
|
-
const MenuList = (props: MenuListProps): React.ReactElement => {
|
4
|
+
const MenuList = (props: any) => {
|
10
5
|
return (
|
11
6
|
<components.MenuList {...props}>
|
12
7
|
{props.children}
|
@@ -7,11 +7,12 @@ import { SelectValueType } from '../_typeahead'
|
|
7
7
|
|
8
8
|
type Props = {
|
9
9
|
data: SelectValueType,
|
10
|
+
multiValueTemplate: any,
|
10
11
|
removeProps: any,
|
11
12
|
selectProps: any,
|
12
13
|
}
|
13
14
|
|
14
|
-
const MultiValue = (props: Props)
|
15
|
+
const MultiValue = (props: Props) => {
|
15
16
|
const { removeProps } = props
|
16
17
|
const { imageUrl, label } = props.data
|
17
18
|
const { multiKit } = props.selectProps
|
@@ -26,36 +27,36 @@ const MultiValue = (props: Props): React.ReactElement => {
|
|
26
27
|
|
27
28
|
return (
|
28
29
|
<components.MultiValueContainer
|
29
|
-
|
30
|
-
|
30
|
+
className="text_input_multivalue_container"
|
31
|
+
{...props}
|
31
32
|
>
|
32
33
|
{multiKit === 'badge' &&
|
33
34
|
<Badge
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
35
|
+
closeProps={removeProps}
|
36
|
+
removeIcon
|
37
|
+
text={label}
|
38
|
+
variant="primary"
|
38
39
|
/>
|
39
40
|
}
|
40
41
|
|
41
42
|
{multiKit !== 'badge' && imageUrl &&
|
42
43
|
<FormPill
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
44
|
+
avatarUrl={imageUrl}
|
45
|
+
closeProps={removeProps}
|
46
|
+
marginRight="xs"
|
47
|
+
name={label}
|
48
|
+
size={multiKit === 'smallPill' ? 'small' : ''}
|
49
|
+
text=''
|
49
50
|
/>
|
50
51
|
}
|
51
52
|
|
52
53
|
{multiKit !== 'badge' && !imageUrl &&
|
53
54
|
<FormPill
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
55
|
+
closeProps={removeProps}
|
56
|
+
marginRight="xs"
|
57
|
+
name=''
|
58
|
+
size={multiKit === 'smallPill' ? 'small' : ''}
|
59
|
+
text={label}
|
59
60
|
/>
|
60
61
|
}
|
61
62
|
</components.MultiValueContainer>
|
@@ -3,7 +3,7 @@ import { components } from 'react-select'
|
|
3
3
|
|
4
4
|
import User from '../../pb_user/_user'
|
5
5
|
|
6
|
-
const Option = (props: any)
|
6
|
+
const Option = (props: any) => {
|
7
7
|
const {
|
8
8
|
imageUrl,
|
9
9
|
} = props.data
|
@@ -14,11 +14,11 @@ const Option = (props: any): React.ReactElement => {
|
|
14
14
|
<>
|
15
15
|
{!valueComponent && imageUrl &&
|
16
16
|
<User
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
17
|
+
align="left"
|
18
|
+
avatarUrl={imageUrl}
|
19
|
+
dark={props.selectProps.dark}
|
20
|
+
name={props.label}
|
21
|
+
orientation="horizontal"
|
22
22
|
/>
|
23
23
|
}
|
24
24
|
|
@@ -4,19 +4,19 @@ import { components } from 'react-select'
|
|
4
4
|
import Flex from '../../pb_flex/_flex'
|
5
5
|
import Icon from '../../pb_icon/_icon'
|
6
6
|
|
7
|
-
const Placeholder = (props: any)
|
7
|
+
const Placeholder = (props: any) => (
|
8
8
|
<>
|
9
9
|
<Flex
|
10
|
-
|
11
|
-
|
10
|
+
align="center"
|
11
|
+
className="placeholder"
|
12
12
|
>
|
13
13
|
<components.IndicatorsContainer
|
14
|
-
|
14
|
+
{...props}
|
15
15
|
/>
|
16
16
|
{props.selectProps.plusIcon &&
|
17
17
|
<Icon
|
18
|
-
|
19
|
-
|
18
|
+
className="typeahead-plus-icon"
|
19
|
+
icon="plus"
|
20
20
|
/>
|
21
21
|
}
|
22
22
|
</Flex>
|
@@ -1,10 +1,10 @@
|
|
1
1
|
import React from 'react'
|
2
2
|
import { components } from 'react-select'
|
3
3
|
|
4
|
-
const ValueContainer = (props: any)
|
4
|
+
const ValueContainer = (props: any) => (
|
5
5
|
<components.ValueContainer
|
6
|
-
|
7
|
-
|
6
|
+
className="text_input_value_container"
|
7
|
+
{...props}
|
8
8
|
/>
|
9
9
|
)
|
10
10
|
|
@@ -47,6 +47,8 @@ const promiseOptions = (inputValue) =>
|
|
47
47
|
|
48
48
|
const TypeaheadWithPillsAsync = (props) => {
|
49
49
|
const [users, setUsers] = useState([])
|
50
|
+
const handleOnChange = (value) => setUsers(formatUsers(value))
|
51
|
+
const formatValue = (users) => formatUsers(users)
|
50
52
|
const formatUsers = (users) => {
|
51
53
|
const results = () => (users.map((user) => {
|
52
54
|
if (Object.keys(user)[0] === 'name' || Object.keys(user)[1] === 'id'){
|
@@ -57,8 +59,6 @@ const TypeaheadWithPillsAsync = (props) => {
|
|
57
59
|
}))
|
58
60
|
return results()
|
59
61
|
}
|
60
|
-
const handleOnChange = (value) => setUsers(formatUsers(value))
|
61
|
-
const formatValue = (users) => formatUsers(users)
|
62
62
|
|
63
63
|
return (
|
64
64
|
<>
|