playbook_ui 14.9.0.pre.alpha.PLAY16264818 → 14.9.0.pre.alpha.PLAY16264952
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_advanced_table/table_header.html.erb +5 -3
- data/app/pb_kits/playbook/pb_avatar/_avatar.scss +0 -2
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.jsx +53 -49
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom_rails.html.erb +29 -36
- data/app/pb_kits/playbook/pb_body/_body.scss +14 -13
- data/app/pb_kits/playbook/pb_body/_body_mixins.scss +22 -16
- data/app/pb_kits/playbook/pb_bread_crumbs/docs/_bread_crumbs_default.jsx +6 -0
- data/app/pb_kits/playbook/pb_caption/_caption_mixin.scss +2 -1
- data/app/pb_kits/playbook/pb_card/_card_mixin.scss +1 -1
- data/app/pb_kits/playbook/pb_checkbox/_checkbox.tsx +33 -26
- data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_form.jsx +138 -0
- data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +7 -6
- data/app/pb_kits/playbook/pb_checkbox/docs/index.js +1 -0
- data/app/pb_kits/playbook/pb_collapsible/_collapsible.tsx +9 -4
- data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleContent.tsx +2 -2
- data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleMain.tsx +2 -2
- data/app/pb_kits/playbook/pb_file_upload/_file_upload.scss +5 -0
- data/app/pb_kits/playbook/pb_file_upload/_file_upload.tsx +7 -2
- data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +8 -2
- data/app/pb_kits/playbook/pb_link/_link.scss +3 -3
- data/app/pb_kits/playbook/pb_nav/_bold_mixin.scss +11 -1
- data/app/pb_kits/playbook/pb_nav/_collapsible_nav.scss +16 -2
- data/app/pb_kits/playbook/pb_nav/_vertical_nav.scss +1 -1
- data/app/pb_kits/playbook/pb_select/_select.tsx +18 -17
- data/app/pb_kits/playbook/pb_select/docs/_select_form.jsx +1 -0
- data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +4 -4
- data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +1 -1
- data/app/pb_kits/playbook/pb_stat_change/_stat_change.tsx +44 -36
- data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +4 -4
- data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +95 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.jsx +75 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +108 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.md +2 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.jsx +94 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.md +0 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.jsx +83 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.md +3 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.jsx +120 -0
- data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.md +1 -0
- data/app/pb_kits/playbook/pb_table/docs/example.yml +5 -0
- data/app/pb_kits/playbook/pb_table/docs/index.js +5 -0
- data/app/pb_kits/playbook/pb_table/index.ts +100 -26
- data/app/pb_kits/playbook/pb_table/styles/_all.scss +2 -1
- data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +35 -0
- data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +106 -1
- data/app/pb_kits/playbook/pb_table/table.html.erb +1 -1
- data/app/pb_kits/playbook/pb_table/table.rb +17 -2
- data/app/pb_kits/playbook/pb_title/_title.scss +6 -5
- data/app/pb_kits/playbook/pb_title/_title_mixin.scss +13 -0
- data/app/pb_kits/playbook/tokens/_titles.scss +0 -8
- data/app/pb_kits/playbook/utilities/_hover.scss +11 -2
- data/app/pb_kits/playbook/utilities/globalProps.ts +2 -0
- data/app/pb_kits/playbook/utilities/hookFormProps.ts +9 -3
- data/app/pb_kits/playbook/utilities/test/globalProps/hover.test.js +15 -0
- data/app/pb_kits/playbook/utilities/withReactHookForm.tsx +64 -0
- data/dist/chunks/_typeahead-BqHgiHoJ.js +22 -0
- data/dist/chunks/_weekday_stacked-BAk0aNPW.js +45 -0
- data/dist/chunks/{lib-SyD3buPZ.js → lib-CuCy3_xO.js} +3 -3
- data/dist/chunks/{pb_form_validation-Dt8UJgrJ.js → pb_form_validation-D37k10a0.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/menu.yml +1 -1
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/hover.rb +7 -1
- data/lib/playbook/version.rb +1 -1
- metadata +20 -6
- data/dist/chunks/_typeahead-B8fkIeXA.js +0 -22
- data/dist/chunks/_weekday_stacked-DxlPBh55.js +0 -45
@@ -0,0 +1,138 @@
|
|
1
|
+
import React from "react"
|
2
|
+
import { useForm } from "react-hook-form"
|
3
|
+
import { Checkbox, Card, Body, Button } from "playbook-ui"
|
4
|
+
|
5
|
+
const CheckboxForm = () => {
|
6
|
+
const {
|
7
|
+
register,
|
8
|
+
handleSubmit,
|
9
|
+
formState: { errors },
|
10
|
+
watch,
|
11
|
+
} = useForm({
|
12
|
+
defaultValues: {
|
13
|
+
termsAccepted: false,
|
14
|
+
newsletter: false,
|
15
|
+
interests: [],
|
16
|
+
preferences: {
|
17
|
+
emailUpdates: false,
|
18
|
+
smsUpdates: false,
|
19
|
+
pushNotifications: false,
|
20
|
+
},
|
21
|
+
},
|
22
|
+
})
|
23
|
+
|
24
|
+
const onSubmit = (data) => {
|
25
|
+
console.log("Form submitted:", data)
|
26
|
+
}
|
27
|
+
|
28
|
+
const formValues = watch()
|
29
|
+
|
30
|
+
return (
|
31
|
+
<div>
|
32
|
+
<Card padding='md'>
|
33
|
+
<form onSubmit={handleSubmit(onSubmit)}>
|
34
|
+
<div>
|
35
|
+
<Body marginBottom='xs'
|
36
|
+
text='Terms and Conditions'
|
37
|
+
/>
|
38
|
+
<Checkbox
|
39
|
+
error={errors.termsAccepted?.message}
|
40
|
+
name='termsAccepted'
|
41
|
+
register={register}
|
42
|
+
rules={{
|
43
|
+
required: "You must accept the terms and conditions",
|
44
|
+
}}
|
45
|
+
text='I accept the terms and conditions'
|
46
|
+
/>
|
47
|
+
</div>
|
48
|
+
<div className='mt-4'>
|
49
|
+
<Body marginBottom='xs'
|
50
|
+
text='Newsletter Subscription'
|
51
|
+
/>
|
52
|
+
<Checkbox
|
53
|
+
name='newsletter'
|
54
|
+
register={register}
|
55
|
+
text='Subscribe to our newsletter'
|
56
|
+
/>
|
57
|
+
</div>
|
58
|
+
<div className='mt-4'>
|
59
|
+
<Body marginBottom='xs'
|
60
|
+
text='Your Interests'
|
61
|
+
/>
|
62
|
+
<Checkbox
|
63
|
+
error={errors.interests?.message}
|
64
|
+
name='interests'
|
65
|
+
register={register}
|
66
|
+
rules={{
|
67
|
+
validate: (value) => {
|
68
|
+
const selectedInterests = Object.values(value).filter(Boolean)
|
69
|
+
return (
|
70
|
+
selectedInterests.length >= 1 ||
|
71
|
+
"Please select at least one interest"
|
72
|
+
)
|
73
|
+
},
|
74
|
+
}}
|
75
|
+
text='Technology'
|
76
|
+
value='technology'
|
77
|
+
/>
|
78
|
+
<Checkbox
|
79
|
+
name='interests'
|
80
|
+
register={register}
|
81
|
+
text='Design'
|
82
|
+
value='design'
|
83
|
+
/>
|
84
|
+
<Checkbox
|
85
|
+
name='interests'
|
86
|
+
register={register}
|
87
|
+
text='Business'
|
88
|
+
value='business'
|
89
|
+
/>
|
90
|
+
<Checkbox
|
91
|
+
name='interests'
|
92
|
+
register={register}
|
93
|
+
text='Marketing'
|
94
|
+
value='marketing'
|
95
|
+
/>
|
96
|
+
</div>
|
97
|
+
<div className='mt-4'>
|
98
|
+
<Body marginBottom='xs'
|
99
|
+
text='Communication Preferences'
|
100
|
+
/>
|
101
|
+
<Checkbox
|
102
|
+
name='preferences.emailUpdates'
|
103
|
+
register={register}
|
104
|
+
text='Email Updates'
|
105
|
+
/>
|
106
|
+
<Checkbox
|
107
|
+
name='preferences.smsUpdates'
|
108
|
+
register={register}
|
109
|
+
text='SMS Updates'
|
110
|
+
/>
|
111
|
+
<Checkbox
|
112
|
+
name='preferences.pushNotifications'
|
113
|
+
register={register}
|
114
|
+
text='Push Notifications'
|
115
|
+
/>
|
116
|
+
</div>
|
117
|
+
<Button
|
118
|
+
htmlType="submit"
|
119
|
+
marginTop='lg'
|
120
|
+
text='Submit'
|
121
|
+
type='submit'
|
122
|
+
variant='primary'
|
123
|
+
/>
|
124
|
+
</form>
|
125
|
+
<Card marginTop='lg'>
|
126
|
+
<Body text='Current Form Values:'
|
127
|
+
variant='bold'
|
128
|
+
/>
|
129
|
+
<pre style={{ marginTop: "8px", color: "white" }}>
|
130
|
+
{JSON.stringify(formValues, null, 2)}
|
131
|
+
</pre>
|
132
|
+
</Card>
|
133
|
+
</Card>
|
134
|
+
</div>
|
135
|
+
)
|
136
|
+
}
|
137
|
+
|
138
|
+
export default CheckboxForm
|
@@ -9,12 +9,13 @@ examples:
|
|
9
9
|
- checkbox_disabled: Disabled Checkbox
|
10
10
|
|
11
11
|
react:
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
12
|
+
- checkbox_default: Default
|
13
|
+
- checkbox_checked: Load as checked
|
14
|
+
- checkbox_custom: Custom Checkbox
|
15
|
+
- checkbox_error: Default w/ Error
|
16
|
+
- checkbox_indeterminate: Indeterminate Checkbox
|
17
|
+
- checkbox_disabled: Disabled Checkbox
|
18
|
+
- checkbox_form: Checkbox Form
|
18
19
|
|
19
20
|
swift:
|
20
21
|
- checkbox_default_swift: Default
|
@@ -4,3 +4,4 @@ export { default as CheckboxError } from './_checkbox_error.jsx'
|
|
4
4
|
export { default as CheckboxChecked } from './_checkbox_checked.jsx'
|
5
5
|
export { default as CheckboxIndeterminate } from './_checkbox_indeterminate.jsx'
|
6
6
|
export { default as CheckboxDisabled } from './_checkbox_disabled.jsx'
|
7
|
+
export { default as CheckboxForm } from './_checkbox_form.jsx'
|
@@ -2,7 +2,7 @@ import React, { useEffect, ReactElement } from 'react'
|
|
2
2
|
import classnames from 'classnames'
|
3
3
|
import useCollapsible from './useCollapsible'
|
4
4
|
|
5
|
-
import { globalProps, globalInlineProps } from '../utilities/globalProps'
|
5
|
+
import { globalProps, globalInlineProps, GlobalProps } from '../utilities/globalProps'
|
6
6
|
import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props'
|
7
7
|
|
8
8
|
import CollapsibleContent from './child_kits/CollapsibleContent'
|
@@ -32,6 +32,7 @@ type CollapsibleProps = {
|
|
32
32
|
onClick?: ()=> void,
|
33
33
|
htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
|
34
34
|
id?: string,
|
35
|
+
tag?: 'h1' | 'h2' | 'h3' | 'h4' | 'h5' | 'h6' | 'p' | 'span' | 'div' | 'tr' | 'th' | 'td' | 'thead' | 'col',
|
35
36
|
}
|
36
37
|
|
37
38
|
const Collapsible = ({
|
@@ -47,8 +48,9 @@ const Collapsible = ({
|
|
47
48
|
onIconClick,
|
48
49
|
onClick,
|
49
50
|
id,
|
51
|
+
tag = 'div',
|
50
52
|
...props
|
51
|
-
}: CollapsibleProps): React.ReactElement => {
|
53
|
+
}: CollapsibleProps & GlobalProps): React.ReactElement => {
|
52
54
|
const [isCollapsed, toggle, setIsCollapsed] = useCollapsible(collapsed)
|
53
55
|
|
54
56
|
useEffect(()=> {
|
@@ -76,9 +78,12 @@ const Collapsible = ({
|
|
76
78
|
className
|
77
79
|
)
|
78
80
|
const dynamicInlineProps = globalInlineProps(props)
|
81
|
+
|
82
|
+
const Tag: React.ReactElement | any = `${tag}`;
|
83
|
+
|
79
84
|
return (
|
80
85
|
<CollapsibleContext.Provider value={{ collapsed: isCollapsed, toggle, icon, iconSize, iconColor, onIconClick, onClick }}>
|
81
|
-
<
|
86
|
+
<Tag
|
82
87
|
{...ariaProps}
|
83
88
|
{...dataProps}
|
84
89
|
{...htmlProps}
|
@@ -96,7 +101,7 @@ const Collapsible = ({
|
|
96
101
|
<CollapsibleContent {...contentProps}>
|
97
102
|
{contentChildren}
|
98
103
|
</CollapsibleContent>
|
99
|
-
</
|
104
|
+
</Tag>
|
100
105
|
</CollapsibleContext.Provider>
|
101
106
|
)
|
102
107
|
}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import classnames from 'classnames'
|
2
2
|
import React, { useContext, useRef, useEffect } from 'react'
|
3
3
|
import { buildCss } from '../../utilities/props'
|
4
|
-
import { globalProps } from '../../utilities/globalProps'
|
4
|
+
import { globalProps, GlobalProps } from '../../utilities/globalProps'
|
5
5
|
import { hideElement, showElement } from '../_helper_functions'
|
6
6
|
|
7
7
|
import CollapsibleContext from '../context'
|
@@ -15,7 +15,7 @@ const CollapsibleContent = ({
|
|
15
15
|
children,
|
16
16
|
className,
|
17
17
|
...props
|
18
|
-
}: CollapsibleContentProps): React.ReactElement => {
|
18
|
+
}: CollapsibleContentProps & GlobalProps): React.ReactElement => {
|
19
19
|
const context: {[key: string]: boolean | string} = useContext(CollapsibleContext)
|
20
20
|
const contentCSS = buildCss('pb_collapsible_content_kit')
|
21
21
|
const contentSpacing = globalProps(props)
|
@@ -3,7 +3,7 @@
|
|
3
3
|
import classnames from 'classnames'
|
4
4
|
import React, { useContext } from 'react'
|
5
5
|
import { buildCss } from '../../utilities/props'
|
6
|
-
import { globalProps } from '../../utilities/globalProps'
|
6
|
+
import { globalProps, GlobalProps } from '../../utilities/globalProps'
|
7
7
|
|
8
8
|
import Flex from '../../pb_flex/_flex'
|
9
9
|
import FlexItem from '../../pb_flex/_flex_item'
|
@@ -25,7 +25,7 @@ const CollapsibleMain = ({
|
|
25
25
|
className,
|
26
26
|
cursor = 'pointer',
|
27
27
|
...props
|
28
|
-
}: CollapsibleMainProps): React.ReactElement=> {
|
28
|
+
}: CollapsibleMainProps & GlobalProps): React.ReactElement=> {
|
29
29
|
const {collapsed, toggle, icon, iconSize, iconColor, onIconClick, onClick}: any = useContext(CollapsibleContext)
|
30
30
|
const mainCSS = buildCss('pb_collapsible_main_kit')
|
31
31
|
const mainSpacing = globalProps(props, { cursor })
|
@@ -13,6 +13,7 @@ type FileUploadProps = {
|
|
13
13
|
accept?: string[],
|
14
14
|
className?: string,
|
15
15
|
customMessage?: string,
|
16
|
+
dark?: boolean,
|
16
17
|
data?: {[key: string]: string | number},
|
17
18
|
htmlOptions?: {[key: string]: string | number | boolean | (() => void)},
|
18
19
|
acceptedFilesDescription?: string,
|
@@ -31,6 +32,7 @@ const FileUpload = (props: FileUploadProps): React.ReactElement => {
|
|
31
32
|
acceptedFilesDescription = '',
|
32
33
|
className,
|
33
34
|
customMessage,
|
35
|
+
dark = false,
|
34
36
|
data = {},
|
35
37
|
htmlOptions = {},
|
36
38
|
maxSize,
|
@@ -94,9 +96,12 @@ const FileUpload = (props: FileUploadProps): React.ReactElement => {
|
|
94
96
|
{...htmlProps}
|
95
97
|
{...getRootProps()}
|
96
98
|
>
|
97
|
-
<Card>
|
99
|
+
<Card dark={dark}>
|
98
100
|
<input {...getInputProps()} />
|
99
|
-
<Body
|
101
|
+
<Body
|
102
|
+
color="light"
|
103
|
+
dark={dark}
|
104
|
+
>
|
100
105
|
{isDragActive ?
|
101
106
|
<p>{'Drop the files here ...'}</p>
|
102
107
|
:
|
@@ -5,11 +5,17 @@
|
|
5
5
|
id: object.id,
|
6
6
|
**combined_html_options) do %>
|
7
7
|
<%= pb_rails("form_group", props: {cursor: "pointer", full_width: object.full_width}) do %>
|
8
|
-
<label
|
8
|
+
<label
|
9
|
+
for="upload-<%= object.id %>"
|
10
|
+
class="pb_button_kit_secondary_inline_enabled <%= 'dark' if object.dark %>"
|
11
|
+
>
|
12
|
+
<%= "#{object.label}" %>
|
13
|
+
</label>
|
9
14
|
<%= pb_rails("text_input", props: {
|
10
15
|
type: "file",
|
16
|
+
dark: object.dark,
|
11
17
|
input_options: {
|
12
|
-
id: "upload-#{object.id}",
|
18
|
+
id: "upload-#{object.id}",
|
13
19
|
classname: "cursor_pointer",
|
14
20
|
}.merge(object.input_options)
|
15
21
|
}) %>
|
@@ -17,7 +17,7 @@
|
|
17
17
|
outline-offset: 2px;
|
18
18
|
}
|
19
19
|
&:visited {
|
20
|
-
color: $
|
20
|
+
color: darken($primary_action, 10%);
|
21
21
|
}
|
22
22
|
&.dark {
|
23
23
|
@include pb_link($active_dark);
|
@@ -34,7 +34,7 @@
|
|
34
34
|
}
|
35
35
|
|
36
36
|
&:visited {
|
37
|
-
color: $
|
37
|
+
color: darken($primary_action, 10%);
|
38
38
|
}
|
39
39
|
}
|
40
40
|
}
|
@@ -48,7 +48,7 @@
|
|
48
48
|
}
|
49
49
|
|
50
50
|
&:visited {
|
51
|
-
color: $
|
51
|
+
color: darken($primary_action, 10%);
|
52
52
|
}
|
53
53
|
}
|
54
54
|
}
|
@@ -223,6 +223,7 @@
|
|
223
223
|
}
|
224
224
|
}
|
225
225
|
[class*="pb_collapsible_nav_item"][class*="pb_nav_list_item_link_collapsible"][class*="pb_nav_list_kit_item"] {
|
226
|
+
box-shadow: unset !important;
|
226
227
|
.pb_nav_list_item_text_collapsible {
|
227
228
|
color: $white !important;
|
228
229
|
}
|
@@ -240,11 +241,17 @@
|
|
240
241
|
|
241
242
|
.pb_collapsible_main_kit:hover {
|
242
243
|
background-color: mix($white, $card_dark, 20%);
|
243
|
-
.pb_nav_list_item_text_collapsible
|
244
|
-
svg {
|
244
|
+
.pb_nav_list_item_text_collapsible {
|
245
245
|
color: $white !important;
|
246
246
|
}
|
247
247
|
}
|
248
|
+
|
249
|
+
.pb_collapsible_main_kit {
|
250
|
+
svg {
|
251
|
+
color: $text_dk_default !important;
|
252
|
+
}
|
253
|
+
}
|
254
|
+
|
248
255
|
.icon_wrapper:hover {
|
249
256
|
background-color: mix($white, $card_dark, 40%);
|
250
257
|
}
|
@@ -256,6 +263,13 @@
|
|
256
263
|
}
|
257
264
|
}
|
258
265
|
}
|
266
|
+
|
267
|
+
&[class*="_active"] {
|
268
|
+
> .pb_collapsible_main_kit {
|
269
|
+
background-color: $primary;
|
270
|
+
box-shadow: 0 2px 10px 0 $shadow_dark;
|
271
|
+
}
|
272
|
+
}
|
259
273
|
}
|
260
274
|
}
|
261
275
|
}
|
@@ -1,12 +1,12 @@
|
|
1
|
-
import React
|
1
|
+
import React from 'react'
|
2
2
|
import classnames from 'classnames'
|
3
3
|
import { FieldValues } from 'react-hook-form'
|
4
4
|
|
5
5
|
import { buildAriaProps, buildCss, buildDataProps, buildHtmlProps } from '../utilities/props'
|
6
6
|
import { globalProps, GlobalProps, domSafeProps } from '../utilities/globalProps'
|
7
|
-
import { HookFormProps, withHookForm } from '../utilities/hookFormProps'
|
8
7
|
import type { InputCallback } from '../types'
|
9
8
|
import { getAllIcons } from "../utilities/icons/allicons"
|
9
|
+
import { withReactHookForm, WithReactHookFormProps } from '../utilities/withReactHookForm'
|
10
10
|
|
11
11
|
import Body from '../pb_body/_body'
|
12
12
|
import Caption from '../pb_caption/_caption'
|
@@ -18,7 +18,7 @@ type SelectOption = {
|
|
18
18
|
disabled?: boolean,
|
19
19
|
}
|
20
20
|
|
21
|
-
type SelectProps
|
21
|
+
type SelectProps = {
|
22
22
|
aria?: { [key: string]: string },
|
23
23
|
blankSelection?: string,
|
24
24
|
children?: Node,
|
@@ -33,8 +33,8 @@ type SelectProps<T extends FieldValues = FieldValues> = {
|
|
33
33
|
inline?: boolean,
|
34
34
|
label?: string,
|
35
35
|
margin?: string,
|
36
|
-
marginBottom
|
37
|
-
marginTop
|
36
|
+
marginBottom?: string,
|
37
|
+
marginTop?: string,
|
38
38
|
multiple?: boolean,
|
39
39
|
name?: string,
|
40
40
|
onChange?: InputCallback<HTMLSelectElement>,
|
@@ -42,7 +42,7 @@ type SelectProps<T extends FieldValues = FieldValues> = {
|
|
42
42
|
required?: boolean,
|
43
43
|
showArrow?: boolean,
|
44
44
|
value?: string,
|
45
|
-
} & GlobalProps
|
45
|
+
} & GlobalProps
|
46
46
|
|
47
47
|
const createOptions = (options: SelectOption[]) => options.map((option, index) => (
|
48
48
|
<option
|
@@ -54,7 +54,7 @@ const createOptions = (options: SelectOption[]) => options.map((option, index) =
|
|
54
54
|
</option>
|
55
55
|
))
|
56
56
|
|
57
|
-
const Select = <
|
57
|
+
const Select = React.forwardRef<HTMLSelectElement, SelectProps>(({
|
58
58
|
aria = {},
|
59
59
|
blankSelection,
|
60
60
|
children,
|
@@ -70,18 +70,15 @@ const Select = <T extends FieldValues = FieldValues>({
|
|
70
70
|
name,
|
71
71
|
onChange,
|
72
72
|
options = [],
|
73
|
-
register,
|
74
73
|
required = false,
|
75
|
-
rules,
|
76
74
|
showArrow = false,
|
77
75
|
value,
|
78
76
|
...props
|
79
|
-
}
|
77
|
+
}, ref) => {
|
80
78
|
const ariaProps = buildAriaProps(aria)
|
81
79
|
const dataProps = buildDataProps(data)
|
82
80
|
const htmlProps = buildHtmlProps(htmlOptions)
|
83
81
|
const optionsList = createOptions(options)
|
84
|
-
const hookFormProps = name ? withHookForm({ register, name, rules }) : {}
|
85
82
|
|
86
83
|
const inlineClass = inline ? 'inline' : null
|
87
84
|
const compactClass = compact ? 'compact' : null
|
@@ -98,7 +95,7 @@ const Select = <T extends FieldValues = FieldValues>({
|
|
98
95
|
);
|
99
96
|
|
100
97
|
const icons = getAllIcons()
|
101
|
-
const angleDown = icons?.angleDown?.icon
|
98
|
+
const angleDown = icons?.angleDown?.icon
|
102
99
|
|
103
100
|
const selectWrapperClass = classnames(buildCss('pb_select_kit_wrapper'), { error }, className)
|
104
101
|
const selectBody =(() =>{
|
@@ -106,13 +103,12 @@ const Select = <T extends FieldValues = FieldValues>({
|
|
106
103
|
return (
|
107
104
|
<select
|
108
105
|
{...domSafeProps(props)}
|
109
|
-
{...hookFormProps}
|
110
106
|
disabled={disabled}
|
111
107
|
id={name}
|
112
108
|
multiple={multiple}
|
113
109
|
name={name}
|
114
|
-
onChange={onChange
|
115
|
-
ref={ref
|
110
|
+
onChange={onChange}
|
111
|
+
ref={ref}
|
116
112
|
required={required}
|
117
113
|
value={value}
|
118
114
|
>
|
@@ -158,6 +154,11 @@ const Select = <T extends FieldValues = FieldValues>({
|
|
158
154
|
</label>
|
159
155
|
</div>
|
160
156
|
)
|
161
|
-
}
|
157
|
+
})
|
158
|
+
|
159
|
+
Select.displayName = 'Select'
|
160
|
+
|
161
|
+
export type SelectWithHookFormProps<T extends FieldValues = FieldValues> = SelectProps & WithReactHookFormProps<T>
|
162
162
|
|
163
|
-
|
163
|
+
const SelectWithHookForm = withReactHookForm(Select)
|
164
|
+
export default SelectWithHookForm
|
@@ -151,7 +151,7 @@ $pb_selectable_paddings: (
|
|
151
151
|
input[type="radio"] {
|
152
152
|
&:checked ~ label {
|
153
153
|
border-width: $pb_card_border_width;
|
154
|
-
outline: 1px solid $
|
154
|
+
outline: 1px solid $primary_action_dark;
|
155
155
|
}
|
156
156
|
}
|
157
157
|
}
|
@@ -161,11 +161,11 @@ $pb_selectable_paddings: (
|
|
161
161
|
color: $white;
|
162
162
|
> label {
|
163
163
|
@include pb_card_dark;
|
164
|
-
background:
|
164
|
+
background: $bg_dark_card;
|
165
165
|
|
166
166
|
.pb_selectable_card_circle {
|
167
167
|
border-color: $bg_dark;
|
168
|
-
background: $
|
168
|
+
background: $primary_action_dark;
|
169
169
|
}
|
170
170
|
}
|
171
171
|
|
@@ -173,7 +173,7 @@ $pb_selectable_paddings: (
|
|
173
173
|
input[type="radio"] {
|
174
174
|
&:checked ~ label {
|
175
175
|
@include pb_card_selected_dark;
|
176
|
-
background:
|
176
|
+
background: $bg_dark_card;
|
177
177
|
}
|
178
178
|
}
|
179
179
|
|