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.
Files changed (72) hide show
  1. checksums.yaml +4 -4
  2. data/app/pb_kits/playbook/pb_advanced_table/table_header.html.erb +5 -3
  3. data/app/pb_kits/playbook/pb_avatar/_avatar.scss +0 -2
  4. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.jsx +53 -49
  5. data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom_rails.html.erb +29 -36
  6. data/app/pb_kits/playbook/pb_body/_body.scss +14 -13
  7. data/app/pb_kits/playbook/pb_body/_body_mixins.scss +22 -16
  8. data/app/pb_kits/playbook/pb_bread_crumbs/docs/_bread_crumbs_default.jsx +6 -0
  9. data/app/pb_kits/playbook/pb_caption/_caption_mixin.scss +2 -1
  10. data/app/pb_kits/playbook/pb_card/_card_mixin.scss +1 -1
  11. data/app/pb_kits/playbook/pb_checkbox/_checkbox.tsx +33 -26
  12. data/app/pb_kits/playbook/pb_checkbox/docs/_checkbox_form.jsx +138 -0
  13. data/app/pb_kits/playbook/pb_checkbox/docs/example.yml +7 -6
  14. data/app/pb_kits/playbook/pb_checkbox/docs/index.js +1 -0
  15. data/app/pb_kits/playbook/pb_collapsible/_collapsible.tsx +9 -4
  16. data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleContent.tsx +2 -2
  17. data/app/pb_kits/playbook/pb_collapsible/child_kits/CollapsibleMain.tsx +2 -2
  18. data/app/pb_kits/playbook/pb_file_upload/_file_upload.scss +5 -0
  19. data/app/pb_kits/playbook/pb_file_upload/_file_upload.tsx +7 -2
  20. data/app/pb_kits/playbook/pb_file_upload/file_upload.html.erb +8 -2
  21. data/app/pb_kits/playbook/pb_link/_link.scss +3 -3
  22. data/app/pb_kits/playbook/pb_nav/_bold_mixin.scss +11 -1
  23. data/app/pb_kits/playbook/pb_nav/_collapsible_nav.scss +16 -2
  24. data/app/pb_kits/playbook/pb_nav/_vertical_nav.scss +1 -1
  25. data/app/pb_kits/playbook/pb_select/_select.tsx +18 -17
  26. data/app/pb_kits/playbook/pb_select/docs/_select_form.jsx +1 -0
  27. data/app/pb_kits/playbook/pb_selectable_card/_selectable_card.scss +4 -4
  28. data/app/pb_kits/playbook/pb_selectable_card/selectable_card.html.erb +1 -1
  29. data/app/pb_kits/playbook/pb_stat_change/_stat_change.tsx +44 -36
  30. data/app/pb_kits/playbook/pb_stat_change/stat_change.html.erb +4 -4
  31. data/app/pb_kits/playbook/pb_table/docs/_table_sticky_left_columns.html.erb +95 -0
  32. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.jsx +75 -0
  33. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible.md +1 -0
  34. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.jsx +108 -0
  35. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_click.md +2 -0
  36. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.jsx +94 -0
  37. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_custom_content.md +0 -0
  38. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.jsx +83 -0
  39. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_rows.md +3 -0
  40. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.jsx +120 -0
  41. data/app/pb_kits/playbook/pb_table/docs/_table_with_collapsible_with_nested_table.md +1 -0
  42. data/app/pb_kits/playbook/pb_table/docs/example.yml +5 -0
  43. data/app/pb_kits/playbook/pb_table/docs/index.js +5 -0
  44. data/app/pb_kits/playbook/pb_table/index.ts +100 -26
  45. data/app/pb_kits/playbook/pb_table/styles/_all.scss +2 -1
  46. data/app/pb_kits/playbook/pb_table/styles/_collapsible.scss +35 -0
  47. data/app/pb_kits/playbook/pb_table/subcomponents/_table_row.tsx +106 -1
  48. data/app/pb_kits/playbook/pb_table/table.html.erb +1 -1
  49. data/app/pb_kits/playbook/pb_table/table.rb +17 -2
  50. data/app/pb_kits/playbook/pb_title/_title.scss +6 -5
  51. data/app/pb_kits/playbook/pb_title/_title_mixin.scss +13 -0
  52. data/app/pb_kits/playbook/tokens/_titles.scss +0 -8
  53. data/app/pb_kits/playbook/utilities/_hover.scss +11 -2
  54. data/app/pb_kits/playbook/utilities/globalProps.ts +2 -0
  55. data/app/pb_kits/playbook/utilities/hookFormProps.ts +9 -3
  56. data/app/pb_kits/playbook/utilities/test/globalProps/hover.test.js +15 -0
  57. data/app/pb_kits/playbook/utilities/withReactHookForm.tsx +64 -0
  58. data/dist/chunks/_typeahead-BqHgiHoJ.js +22 -0
  59. data/dist/chunks/_weekday_stacked-BAk0aNPW.js +45 -0
  60. data/dist/chunks/{lib-SyD3buPZ.js → lib-CuCy3_xO.js} +3 -3
  61. data/dist/chunks/{pb_form_validation-Dt8UJgrJ.js → pb_form_validation-D37k10a0.js} +1 -1
  62. data/dist/chunks/vendor.js +1 -1
  63. data/dist/menu.yml +1 -1
  64. data/dist/playbook-doc.js +1 -1
  65. data/dist/playbook-rails-react-bindings.js +1 -1
  66. data/dist/playbook-rails.js +1 -1
  67. data/dist/playbook.css +1 -1
  68. data/lib/playbook/hover.rb +7 -1
  69. data/lib/playbook/version.rb +1 -1
  70. metadata +20 -6
  71. data/dist/chunks/_typeahead-B8fkIeXA.js +0 -22
  72. 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
- - 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
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
- <div
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
- </div>
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 })
@@ -11,3 +11,8 @@
11
11
  }
12
12
  }
13
13
 
14
+ .dark [class*='pb_file_upload_kit'] {
15
+ [class*='pb_card_kit'] {
16
+ border: 1px $text_dk_lighter dashed;
17
+ }
18
+ }
@@ -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 color="light">
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 for="upload-<%= object.id %>" class="pb_button_kit_secondary_inline_enabled"><%= "#{object.label}" %></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: $data_3;
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: $data_3;
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: $data_3;
51
+ color: darken($primary_action, 10%);
52
52
  }
53
53
  }
54
54
  }
@@ -19,6 +19,16 @@
19
19
  font-weight: $bolder;
20
20
  }
21
21
  }
22
- }
22
+ }
23
+ }
24
+
25
+ .dark & {
26
+ [class*=pb_nav_list_kit_item][class*=pb_nav_list_item] {
27
+ &[class*=_link] {
28
+ &[class*=_active] {
29
+ box-shadow: 0 2px 10px 0 $shadow_dark;
30
+ }
31
+ }
32
+ }
23
33
  }
24
34
  }
@@ -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
  }
@@ -115,7 +115,7 @@ $selector: ".pb_nav_list";
115
115
  }
116
116
  [class*="_item_text"],
117
117
  [class*="_item_icon"] {
118
- color: $text_dk_lighter !important;
118
+ color: $text_dk_light !important;
119
119
  }
120
120
  &[class*="_link"] {
121
121
  &:hover {
@@ -1,12 +1,12 @@
1
- import React, { forwardRef } from '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<T extends FieldValues = FieldValues> = {
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: string,
37
- marginTop: string,
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 & Partial<HookFormProps<T>>
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 = <T extends FieldValues = FieldValues>({
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
- }: SelectProps<T>, ref: React.LegacyRef<HTMLSelectElement>) => {
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 as { [key: string]: SVGElement }
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 || hookFormProps.onChange}
115
- ref={ref || hookFormProps.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
- export default forwardRef(Select)
163
+ const SelectWithHookForm = withReactHookForm(Select)
164
+ export default SelectWithHookForm
@@ -81,6 +81,7 @@ const SelectForm = (props) => {
81
81
  />
82
82
 
83
83
  <Button
84
+ htmlType="submit"
84
85
  marginTop="lg"
85
86
  text="Submit"
86
87
  type="submit"
@@ -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 $primary;
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: transparent;
164
+ background: $bg_dark_card;
165
165
 
166
166
  .pb_selectable_card_circle {
167
167
  border-color: $bg_dark;
168
- background: $primary-action;
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: transparent;
176
+ background: $bg_dark_card;
177
177
  }
178
178
  }
179
179
 
@@ -35,7 +35,7 @@
35
35
  <% end %>
36
36
  <% else %>
37
37
  <% if content.nil? %>
38
- <%= pb_rails("body", props: { text: object.text }) %>
38
+ <%= pb_rails("body", props: { text: object.text, dark: object.dark }) %>
39
39
  <% else %>
40
40
  <%= content %>
41
41
  <% end %>