@salutejs/plasma-new-hope 0.149.0-canary.1418.10940499394.0 → 0.149.0-canary.1421.10946935893.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (237) hide show
  1. package/cjs/components/DatePicker/RangeDate/RangeDate.css +2 -0
  2. package/cjs/components/DatePicker/RangeDate/RangeDate.js +39 -2
  3. package/cjs/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  4. package/cjs/components/DatePicker/SingleDate/SingleDate.css +2 -0
  5. package/cjs/components/DatePicker/SingleDate/SingleDate.js +26 -2
  6. package/cjs/components/DatePicker/SingleDate/SingleDate.js.map +1 -1
  7. package/cjs/components/DatePicker/utils/setInitValue.js +12 -0
  8. package/cjs/components/DatePicker/utils/setInitValue.js.map +1 -0
  9. package/cjs/components/Slider/Slider.css +2 -0
  10. package/cjs/components/Slider/Slider.js +19 -6
  11. package/cjs/components/Slider/Slider.js.map +1 -1
  12. package/cjs/components/Slider/components/Double/Double.css +2 -0
  13. package/cjs/components/Slider/components/Double/Double.js +38 -2
  14. package/cjs/components/Slider/components/Double/Double.js.map +1 -1
  15. package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js +56 -0
  16. package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js.map +1 -0
  17. package/cjs/components/Slider/components/Single/Single.css +2 -0
  18. package/cjs/components/Slider/components/Single/Single.js +35 -12
  19. package/cjs/components/Slider/components/Single/Single.js.map +1 -1
  20. package/cjs/components/Slider/utils/index.js +6 -0
  21. package/cjs/components/Slider/utils/index.js.map +1 -1
  22. package/cjs/components/TextArea/TextArea.js +3 -2
  23. package/cjs/components/TextArea/TextArea.js.map +1 -1
  24. package/cjs/components/TextField/TextField.js +1 -3
  25. package/cjs/components/TextField/TextField.js.map +1 -1
  26. package/cjs/hooks/useForm.js +131 -0
  27. package/cjs/hooks/useForm.js.map +1 -0
  28. package/cjs/index.css +2 -0
  29. package/cjs/index.js +5 -2
  30. package/cjs/index.js.map +1 -1
  31. package/cjs/utils/index.js.map +1 -1
  32. package/cjs/utils/inputHidden.js +15 -0
  33. package/cjs/utils/inputHidden.js.map +1 -0
  34. package/cjs/utils/inputHidden_1ciypqb.css +1 -0
  35. package/cjs/utils/setRefList.js +28 -0
  36. package/cjs/utils/setRefList.js.map +1 -0
  37. package/emotion/cjs/components/DatePicker/RangeDate/RangeDate.js +39 -2
  38. package/emotion/cjs/components/DatePicker/SingleDate/SingleDate.js +26 -2
  39. package/emotion/cjs/components/DatePicker/utils/setInitValue.js +11 -0
  40. package/emotion/cjs/components/Slider/Slider.js +15 -6
  41. package/emotion/cjs/components/Slider/components/Double/Double.js +38 -2
  42. package/{styled-components/cjs/components/Mask/Mask.js → emotion/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js} +43 -39
  43. package/emotion/cjs/components/Slider/components/Single/Single.js +30 -7
  44. package/emotion/cjs/components/Slider/components/index.js +11 -0
  45. package/emotion/cjs/components/Slider/utils/index.js +6 -1
  46. package/emotion/cjs/components/TextArea/TextArea.js +3 -3
  47. package/emotion/cjs/components/TextField/TextField.js +2 -4
  48. package/emotion/cjs/examples/plasma_b2c/components/Form/Form.stories.tsx +245 -0
  49. package/emotion/cjs/hooks/index.js +8 -1
  50. package/emotion/cjs/hooks/useForm.js +137 -0
  51. package/emotion/cjs/index.js +0 -11
  52. package/emotion/cjs/utils/index.js +15 -0
  53. package/emotion/cjs/utils/inputHidden.js +10 -0
  54. package/emotion/cjs/utils/setRefList.js +27 -0
  55. package/emotion/es/components/DatePicker/RangeDate/RangeDate.js +39 -2
  56. package/emotion/es/components/DatePicker/SingleDate/SingleDate.js +26 -2
  57. package/emotion/es/components/DatePicker/utils/setInitValue.js +5 -0
  58. package/emotion/es/components/Slider/Slider.js +16 -6
  59. package/emotion/es/components/Slider/components/Double/Double.js +39 -3
  60. package/emotion/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js +51 -0
  61. package/emotion/es/components/Slider/components/Single/Single.js +31 -8
  62. package/emotion/es/components/Slider/components/index.js +1 -0
  63. package/emotion/es/components/Slider/utils/index.js +5 -0
  64. package/emotion/es/components/TextArea/TextArea.js +4 -4
  65. package/emotion/es/components/TextField/TextField.js +2 -4
  66. package/emotion/es/examples/plasma_b2c/components/Form/Form.stories.tsx +245 -0
  67. package/emotion/es/hooks/index.js +2 -1
  68. package/emotion/es/hooks/useForm.js +128 -0
  69. package/emotion/es/index.js +1 -2
  70. package/emotion/es/utils/index.js +1 -0
  71. package/emotion/es/utils/inputHidden.js +4 -0
  72. package/emotion/es/utils/setRefList.js +20 -0
  73. package/es/components/DatePicker/RangeDate/RangeDate.css +2 -0
  74. package/es/components/DatePicker/RangeDate/RangeDate.js +39 -2
  75. package/es/components/DatePicker/RangeDate/RangeDate.js.map +1 -1
  76. package/es/components/DatePicker/SingleDate/SingleDate.css +2 -0
  77. package/es/components/DatePicker/SingleDate/SingleDate.js +26 -2
  78. package/es/components/DatePicker/SingleDate/SingleDate.js.map +1 -1
  79. package/es/components/DatePicker/utils/setInitValue.js +8 -0
  80. package/es/components/DatePicker/utils/setInitValue.js.map +1 -0
  81. package/es/components/Slider/Slider.css +2 -0
  82. package/es/components/Slider/Slider.js +20 -7
  83. package/es/components/Slider/Slider.js.map +1 -1
  84. package/es/components/Slider/components/Double/Double.css +2 -0
  85. package/es/components/Slider/components/Double/Double.js +39 -3
  86. package/es/components/Slider/components/Double/Double.js.map +1 -1
  87. package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js +52 -0
  88. package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js.map +1 -0
  89. package/es/components/Slider/components/Single/Single.css +2 -0
  90. package/es/components/Slider/components/Single/Single.js +31 -8
  91. package/es/components/Slider/components/Single/Single.js.map +1 -1
  92. package/es/components/Slider/utils/index.js +6 -1
  93. package/es/components/Slider/utils/index.js.map +1 -1
  94. package/es/components/TextArea/TextArea.js +3 -2
  95. package/es/components/TextArea/TextArea.js.map +1 -1
  96. package/es/components/TextField/TextField.js +1 -3
  97. package/es/components/TextField/TextField.js.map +1 -1
  98. package/es/hooks/useForm.js +127 -0
  99. package/es/hooks/useForm.js.map +1 -0
  100. package/es/index.css +2 -0
  101. package/es/index.js +2 -1
  102. package/es/index.js.map +1 -1
  103. package/es/utils/index.js.map +1 -1
  104. package/es/utils/inputHidden.js +11 -0
  105. package/es/utils/inputHidden.js.map +1 -0
  106. package/es/utils/inputHidden_1ciypqb.css +1 -0
  107. package/es/utils/setRefList.js +23 -0
  108. package/es/utils/setRefList.js.map +1 -0
  109. package/package.json +3 -4
  110. package/styled-components/cjs/components/DatePicker/RangeDate/RangeDate.js +39 -2
  111. package/styled-components/cjs/components/DatePicker/SingleDate/SingleDate.js +26 -2
  112. package/styled-components/cjs/components/DatePicker/utils/setInitValue.js +11 -0
  113. package/styled-components/cjs/components/Slider/Slider.js +15 -6
  114. package/styled-components/cjs/components/Slider/components/Double/Double.js +38 -2
  115. package/{emotion/cjs/components/Mask/Mask.js → styled-components/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js} +43 -39
  116. package/styled-components/cjs/components/Slider/components/Single/Single.js +30 -7
  117. package/styled-components/cjs/components/Slider/components/index.js +11 -0
  118. package/styled-components/cjs/components/Slider/utils/index.js +6 -1
  119. package/styled-components/cjs/components/TextArea/TextArea.js +2 -2
  120. package/styled-components/cjs/components/TextField/TextField.js +1 -3
  121. package/styled-components/cjs/examples/plasma_b2c/components/Form/Form.stories.tsx +245 -0
  122. package/styled-components/cjs/hooks/index.js +8 -1
  123. package/styled-components/cjs/hooks/useForm.js +137 -0
  124. package/styled-components/cjs/index.js +0 -11
  125. package/styled-components/cjs/utils/index.js +15 -0
  126. package/styled-components/cjs/utils/inputHidden.js +10 -0
  127. package/styled-components/cjs/utils/setRefList.js +27 -0
  128. package/styled-components/es/components/DatePicker/RangeDate/RangeDate.js +39 -2
  129. package/styled-components/es/components/DatePicker/SingleDate/SingleDate.js +26 -2
  130. package/styled-components/es/components/DatePicker/utils/setInitValue.js +5 -0
  131. package/styled-components/es/components/Slider/Slider.js +16 -6
  132. package/styled-components/es/components/Slider/components/Double/Double.js +39 -3
  133. package/styled-components/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.js +51 -0
  134. package/styled-components/es/components/Slider/components/Single/Single.js +31 -8
  135. package/styled-components/es/components/Slider/components/index.js +1 -0
  136. package/styled-components/es/components/Slider/utils/index.js +5 -0
  137. package/styled-components/es/components/TextArea/TextArea.js +3 -3
  138. package/styled-components/es/components/TextField/TextField.js +1 -3
  139. package/styled-components/es/examples/plasma_b2c/components/Form/Form.stories.tsx +245 -0
  140. package/styled-components/es/hooks/index.js +2 -1
  141. package/styled-components/es/hooks/useForm.js +128 -0
  142. package/styled-components/es/index.js +1 -2
  143. package/styled-components/es/utils/index.js +1 -0
  144. package/styled-components/es/utils/inputHidden.js +4 -0
  145. package/styled-components/es/utils/setRefList.js +20 -0
  146. package/types/components/DatePicker/RangeDate/RangeDate.d.ts +2 -0
  147. package/types/components/DatePicker/RangeDate/RangeDate.d.ts.map +1 -1
  148. package/types/components/DatePicker/RangeDate/RangeDate.types.d.ts +4 -0
  149. package/types/components/DatePicker/RangeDate/RangeDate.types.d.ts.map +1 -1
  150. package/types/components/DatePicker/SingleDate/SingleDate.d.ts.map +1 -1
  151. package/types/components/DatePicker/SingleDate/SingleDate.types.d.ts +4 -0
  152. package/types/components/DatePicker/SingleDate/SingleDate.types.d.ts.map +1 -1
  153. package/types/components/DatePicker/utils/setInitValue.d.ts +2 -0
  154. package/types/components/DatePicker/utils/setInitValue.d.ts.map +1 -0
  155. package/types/components/Slider/Slider.d.ts.map +1 -1
  156. package/types/components/Slider/Slider.types.d.ts +2 -2
  157. package/types/components/Slider/Slider.types.d.ts.map +1 -1
  158. package/types/components/Slider/components/Double/Double.d.ts.map +1 -1
  159. package/types/components/Slider/components/Double/Double.types.d.ts +2 -0
  160. package/types/components/Slider/components/Double/Double.types.d.ts.map +1 -1
  161. package/types/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.d.ts +4 -0
  162. package/types/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.d.ts.map +1 -0
  163. package/types/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.d.ts +5 -0
  164. package/types/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.d.ts.map +1 -0
  165. package/types/components/Slider/components/Single/Single.d.ts.map +1 -1
  166. package/types/components/Slider/components/Single/Single.types.d.ts +3 -1
  167. package/types/components/Slider/components/Single/Single.types.d.ts.map +1 -1
  168. package/types/components/Slider/components/index.d.ts +2 -0
  169. package/types/components/Slider/components/index.d.ts.map +1 -1
  170. package/types/components/Slider/utils/index.d.ts +1 -0
  171. package/types/components/Slider/utils/index.d.ts.map +1 -1
  172. package/types/components/TextArea/TextArea.d.ts.map +1 -1
  173. package/types/components/TextField/TextField.d.ts.map +1 -1
  174. package/types/examples/plasma_b2c/components/DatePicker/DatePicker.d.ts +1 -0
  175. package/types/examples/plasma_b2c/components/DatePicker/DatePicker.d.ts.map +1 -1
  176. package/types/examples/plasma_b2c/components/Slider/Slider.d.ts +3 -1
  177. package/types/examples/plasma_b2c/components/Slider/Slider.d.ts.map +1 -1
  178. package/types/examples/plasma_web/components/DatePicker/DatePicker.d.ts +1 -0
  179. package/types/examples/plasma_web/components/DatePicker/DatePicker.d.ts.map +1 -1
  180. package/types/examples/plasma_web/components/Slider/Slider.d.ts +3 -1
  181. package/types/examples/plasma_web/components/Slider/Slider.d.ts.map +1 -1
  182. package/types/hooks/index.d.ts +1 -0
  183. package/types/hooks/index.d.ts.map +1 -1
  184. package/types/hooks/useForm.d.ts +10 -0
  185. package/types/hooks/useForm.d.ts.map +1 -0
  186. package/types/index.d.ts +0 -1
  187. package/types/index.d.ts.map +1 -1
  188. package/types/utils/index.d.ts +1 -0
  189. package/types/utils/index.d.ts.map +1 -1
  190. package/types/utils/inputHidden.d.ts +3 -0
  191. package/types/utils/inputHidden.d.ts.map +1 -0
  192. package/types/utils/setRefList.d.ts +6 -0
  193. package/types/utils/setRefList.d.ts.map +1 -0
  194. package/cjs/components/Mask/Mask.js +0 -46
  195. package/cjs/components/Mask/Mask.js.map +0 -1
  196. package/emotion/cjs/components/Mask/Mask.template-doc.mdx +0 -125
  197. package/emotion/cjs/components/Mask/index.js +0 -12
  198. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  199. package/emotion/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -127
  200. package/emotion/cjs/examples/plasma_web/components/Mask/Mask.js +0 -9
  201. package/emotion/cjs/examples/plasma_web/components/Mask/Mask.stories.tsx +0 -125
  202. package/emotion/es/components/Mask/Mask.js +0 -46
  203. package/emotion/es/components/Mask/Mask.template-doc.mdx +0 -125
  204. package/emotion/es/components/Mask/index.js +0 -1
  205. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  206. package/emotion/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -127
  207. package/emotion/es/examples/plasma_web/components/Mask/Mask.js +0 -3
  208. package/emotion/es/examples/plasma_web/components/Mask/Mask.stories.tsx +0 -125
  209. package/es/components/Mask/Mask.js +0 -42
  210. package/es/components/Mask/Mask.js.map +0 -1
  211. package/styled-components/cjs/components/Mask/Mask.template-doc.mdx +0 -125
  212. package/styled-components/cjs/components/Mask/index.js +0 -12
  213. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.js +0 -9
  214. package/styled-components/cjs/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -127
  215. package/styled-components/cjs/examples/plasma_web/components/Mask/Mask.js +0 -9
  216. package/styled-components/cjs/examples/plasma_web/components/Mask/Mask.stories.tsx +0 -125
  217. package/styled-components/es/components/Mask/Mask.js +0 -46
  218. package/styled-components/es/components/Mask/Mask.template-doc.mdx +0 -125
  219. package/styled-components/es/components/Mask/index.js +0 -1
  220. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.js +0 -3
  221. package/styled-components/es/examples/plasma_b2c/components/Mask/Mask.stories.tsx +0 -127
  222. package/styled-components/es/examples/plasma_web/components/Mask/Mask.js +0 -3
  223. package/styled-components/es/examples/plasma_web/components/Mask/Mask.stories.tsx +0 -125
  224. package/types/components/Mask/Mask.d.ts +0 -5
  225. package/types/components/Mask/Mask.d.ts.map +0 -1
  226. package/types/components/Mask/Mask.types.d.ts +0 -62
  227. package/types/components/Mask/Mask.types.d.ts.map +0 -1
  228. package/types/components/Mask/index.d.ts +0 -2
  229. package/types/components/Mask/index.d.ts.map +0 -1
  230. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts +0 -191
  231. package/types/examples/plasma_b2c/components/Mask/Mask.d.ts.map +0 -1
  232. package/types/examples/plasma_web/components/Mask/Mask.d.ts +0 -191
  233. package/types/examples/plasma_web/components/Mask/Mask.d.ts.map +0 -1
  234. /package/emotion/cjs/components/{Mask/Mask.types.js → Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.js} +0 -0
  235. /package/emotion/es/components/{Mask/Mask.types.js → Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.js} +0 -0
  236. /package/styled-components/cjs/components/{Mask/Mask.types.js → Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.js} +0 -0
  237. /package/styled-components/es/components/{Mask/Mask.types.js → Slider/components/DoubleUncontrolled/DoubleUncontrolled.types.js} +0 -0
@@ -0,0 +1,245 @@
1
+ import { useForm as useReactHookForm, Controller } from 'react-hook-form';
2
+ import React, { useRef } from 'react';
3
+ import type { Meta, StoryObj } from '@storybook/react';
4
+
5
+ import { WithTheme } from '../../../_helpers';
6
+ import { Button } from '../Button/Button';
7
+ import { TextField } from '../TextField/TextField';
8
+ import { TextArea } from '../TextArea/TextArea';
9
+ import { Checkbox } from '../Checkbox/Checkbox';
10
+ import { Switch } from '../Switch/Switch';
11
+ import { Radiobox } from '../Radiobox/Radiobox';
12
+ import { RadioGroup } from '../../../../components/Radiobox';
13
+ import { Slider } from '../Slider/Slider';
14
+ import { useForm } from '../../../../hooks';
15
+ import { DatePicker, DatePickerRange } from '../DatePicker/DatePicker';
16
+
17
+ type StoryDropdownProps = {};
18
+
19
+ const langName = 'language';
20
+ const itemsRadiobox = [
21
+ { langName, value: 'c', label: 'C', disabled: false },
22
+ { langName, value: 'cpp', label: 'C++', disabled: false },
23
+ { langName, value: 'assembly', label: 'Assembly', disabled: false },
24
+ ];
25
+
26
+ const PlasmaForm = () => {
27
+ const onSubmit = (data) => {
28
+ console.log(data);
29
+ };
30
+
31
+ const { formRef, formData } = useForm(onSubmit, {
32
+ textfield: 'textfield',
33
+ textarea: 'textarea',
34
+ checkbox: 'checkobox',
35
+ switch: true,
36
+ radiobox: 'c',
37
+ slider: 10,
38
+ sliderd: [10, 20],
39
+ datepicker: '12.09.2024',
40
+ datepickerRange: ['09.09.2024', '12.09.2024'],
41
+ });
42
+
43
+ return (
44
+ <form onSubmit={formData} style={{ display: 'flex', flexDirection: 'column', gap: '20px' }} ref={formRef}>
45
+ <TextField name="textfield" placeholder="Textfield" required={false} />
46
+ <TextArea name="textarea" autoResize placeholder="Textarea" />
47
+ <Checkbox name="checkbox" label="Checkbox" />
48
+ <Switch name="switch" label="Switch" labelPosition="after" />
49
+ <RadioGroup aria-labelledby="radiogroup-title-id">
50
+ <div id="radiogroup-title-id" style={{ margin: '1rem 0', fontWeight: '600' }}>
51
+ Выберите язык программирования для изучения.
52
+ </div>
53
+ {itemsRadiobox.map((item) => (
54
+ <Radiobox
55
+ name="radiobox"
56
+ key={item.value}
57
+ value={item.value}
58
+ label={item.label}
59
+ disabled={item.disabled}
60
+ />
61
+ ))}
62
+ </RadioGroup>
63
+ <Slider name="slider" label="Slider" type="single" min={0} max={100} />
64
+ <Slider name="sliderd" label="Slider" type="double" min={0} max={100} />
65
+ <DatePicker label="DatePicker" name="datepicker" />
66
+ <DatePickerRange label="DatePicker" name="datepickerRange" />
67
+ <Button type="submit">Отправить</Button>
68
+ </form>
69
+ );
70
+ };
71
+
72
+ const meta: Meta<StoryDropdownProps> = {
73
+ title: 'plasma_b2c/Form',
74
+ decorators: [WithTheme],
75
+ component: PlasmaForm,
76
+ };
77
+
78
+ export default meta;
79
+
80
+ const StoryPlasmaForm = () => {
81
+ return <PlasmaForm />;
82
+ };
83
+
84
+ export const DefaultPlasmaForm: StoryObj<StoryDropdownProps> = {
85
+ render: () => <StoryPlasmaForm />,
86
+ };
87
+
88
+ const DefaultForm = () => {
89
+ const onSubmit = (event) => {
90
+ event.preventDefault();
91
+
92
+ const fData = new FormData(event.target);
93
+
94
+ for (const p of fData) {
95
+ const name = p[0];
96
+ const value = p[1];
97
+
98
+ console.log(name, value);
99
+ }
100
+ };
101
+ return (
102
+ <form onSubmit={onSubmit} style={{ display: 'flex', flexDirection: 'column', gap: '20px' }}>
103
+ <TextField name="textfield" placeholder="Textfield" required={false} />
104
+ <TextArea name="textarea" autoResize placeholder="Textarea" />
105
+ <Checkbox name="checkbox" label="Checkbox" />
106
+ <Switch name="switch" label="Switch" labelPosition="after" />
107
+ <RadioGroup aria-labelledby="radiogroup-title-id">
108
+ <div id="radiogroup-title-id" style={{ margin: '1rem 0', fontWeight: '600' }}>
109
+ Выберите язык программирования для изучения.
110
+ </div>
111
+ {itemsRadiobox.map((item) => (
112
+ <Radiobox
113
+ name="radiobox"
114
+ key={item.value}
115
+ value={item.value}
116
+ label={item.label}
117
+ disabled={item.disabled}
118
+ />
119
+ ))}
120
+ </RadioGroup>
121
+ <Slider name="slider" label="Slider" type="single" min={0} max={100} />
122
+ <Slider name="sliderd" label="Slider" type="double" min={0} max={100} />
123
+ <DatePicker label="DatePicker" name="datepicker" />
124
+ <DatePickerRange label="DatePicker" name="datepickerRange" />
125
+ <Button type="submit">Отправить</Button>
126
+ </form>
127
+ );
128
+ };
129
+
130
+ const StoryDefaultForm = () => {
131
+ return <DefaultForm />;
132
+ };
133
+
134
+ export const FormDefault: StoryObj<StoryDropdownProps> = {
135
+ render: () => <StoryDefaultForm />,
136
+ };
137
+
138
+ const DefaultUseForm = () => {
139
+ const { register, handleSubmit } = useReactHookForm({
140
+ defaultValues: {
141
+ textfield: 'John Doe',
142
+ textarea: 'Default description',
143
+ checkbox: true,
144
+ switch: true,
145
+ radiobox: 'c',
146
+ slider: 10,
147
+ },
148
+ });
149
+ const onSubmit = (data) => {
150
+ console.log(data);
151
+ };
152
+
153
+ return (
154
+ <form onSubmit={handleSubmit(onSubmit)} style={{ display: 'flex', flexDirection: 'column', gap: '20px' }}>
155
+ <TextField {...register('textfield')} placeholder="Textfield" required={false} />
156
+ <TextArea {...register('textarea')} autoResize placeholder="Textarea" />
157
+ <Checkbox {...register('checkbox')} label="Checkbox" />
158
+ <Switch {...register('switch')} label="Switch" labelPosition="after" />
159
+ <RadioGroup aria-labelledby="radiogroup-title-id">
160
+ <div id="radiogroup-title-id" style={{ margin: '1rem 0', fontWeight: '600' }}>
161
+ Выберите язык программирования для изучения.
162
+ </div>
163
+ {itemsRadiobox.map((item) => (
164
+ <Radiobox
165
+ {...register('radiobox')}
166
+ key={item.value}
167
+ value={item.value}
168
+ label={item.label}
169
+ disabled={item.disabled}
170
+ />
171
+ ))}
172
+ </RadioGroup>
173
+ <Button type="submit">Отправить</Button>
174
+ </form>
175
+ );
176
+ };
177
+
178
+ const StoryHookForm = () => {
179
+ return <DefaultUseForm />;
180
+ };
181
+
182
+ export const UseHookForm: StoryObj<StoryDropdownProps> = {
183
+ render: () => <StoryHookForm />,
184
+ };
185
+
186
+ const DefaultUseFormController = () => {
187
+ const { control, handleSubmit } = useReactHookForm({
188
+ defaultValues: {
189
+ textfield: 'John Doe',
190
+ textarea: 'Default description',
191
+ checkbox: true,
192
+ switch: true,
193
+ radiobox: 'c',
194
+ slider: 10,
195
+ sliderd: [10, 20],
196
+ },
197
+ });
198
+ const onSubmit = (data) => {
199
+ console.log(data);
200
+ };
201
+
202
+ return (
203
+ <form onSubmit={handleSubmit(onSubmit)} style={{ display: 'flex', flexDirection: 'column', gap: '20px' }}>
204
+ <Controller
205
+ name="textfield"
206
+ control={control}
207
+ render={({ field }) => <TextField {...field} label="TextField" />}
208
+ />
209
+ <Controller
210
+ name="textarea"
211
+ control={control}
212
+ render={({ field }) => <TextArea {...field} label="TextArea" />}
213
+ />
214
+ <Controller
215
+ name="checkbox"
216
+ control={control}
217
+ render={({ field }) => <Checkbox {...field} checked={field.value} label="Checkbox" />}
218
+ />
219
+ <Controller
220
+ name="switch"
221
+ control={control}
222
+ render={({ field }) => <Switch {...field} checked={field.value} labelPosition="after" label="Switch" />}
223
+ />
224
+ <Controller
225
+ name="slider"
226
+ control={control}
227
+ render={({ field }) => <Slider {...field} type="single" label="Slider" min={0} max={100} />}
228
+ />
229
+ <Controller
230
+ name="sliderd"
231
+ control={control}
232
+ render={({ field }) => <Slider {...field} type="double" label="Slider" min={0} max={100} />}
233
+ />
234
+ <Button type="submit">Отправить</Button>
235
+ </form>
236
+ );
237
+ };
238
+
239
+ const StoryHookFormController = () => {
240
+ return <DefaultUseFormController />;
241
+ };
242
+
243
+ export const UseHookFormController: StoryObj<StoryDropdownProps> = {
244
+ render: () => <StoryHookFormController />,
245
+ };
@@ -21,6 +21,12 @@ Object.defineProperty(exports, "useForceUpdate", {
21
21
  return _useForceUpdate.useForceUpdate;
22
22
  }
23
23
  });
24
+ Object.defineProperty(exports, "useForm", {
25
+ enumerable: true,
26
+ get: function get() {
27
+ return _useForm.useForm;
28
+ }
29
+ });
24
30
  Object.defineProperty(exports, "useIsomorphicLayoutEffect", {
25
31
  enumerable: true,
26
32
  get: function get() {
@@ -51,4 +57,5 @@ var _usePreviousValue = /*#__PURE__*/require("./usePreviousValue");
51
57
  var _useForceUpdate = /*#__PURE__*/require("./useForceUpdate");
52
58
  var _useDidMountEffect = /*#__PURE__*/require("./useDidMountEffect");
53
59
  var _useOutsideClick = /*#__PURE__*/require("./useOutsideClick");
54
- var _useIsomorphicLayoutEffect = /*#__PURE__*/require("./useIsomorphicLayoutEffect");
60
+ var _useIsomorphicLayoutEffect = /*#__PURE__*/require("./useIsomorphicLayoutEffect");
61
+ var _useForm = /*#__PURE__*/require("./useForm");
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.useForm = void 0;
8
+ var _react = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("react"));
9
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
10
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
11
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
12
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
13
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
14
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
15
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
16
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
17
+ var initData = function initData(ref, defaultValues) {
18
+ if (!ref.current) {
19
+ return;
20
+ }
21
+ var form = ref.current;
22
+ var items = form.elements;
23
+ for (var i = 0; i < items.length; i++) {
24
+ var item = items[i];
25
+ var _name = item.name,
26
+ value = item.value,
27
+ type = item.type;
28
+ if ((type === 'text' || type === 'textarea') && defaultValues[_name]) {
29
+ item.value = String(defaultValues[_name]);
30
+ }
31
+ if (type === 'checkbox' && defaultValues[_name]) {
32
+ item.checked = Boolean(defaultValues[_name]);
33
+ }
34
+ if (type === 'radio' && defaultValues[_name]) {
35
+ item.checked = defaultValues[_name] === value;
36
+ }
37
+ if (type === 'number' && defaultValues[_name]) {
38
+ var sliderType = item.getAttribute('datatype');
39
+ if (sliderType === 'slider-single') {
40
+ item.setAttribute('defaultValue', String(defaultValues[_name]));
41
+ var event = new Event('setInitValue');
42
+ item.dispatchEvent(event);
43
+ }
44
+ if (sliderType === 'slider-double') {
45
+ var isMax = item.getAttribute('data-slidertype') === 'max' ? 1 : 0;
46
+ var _data = defaultValues[_name];
47
+ item.setAttribute('defaultValue', String(_data[isMax]));
48
+ var _event = new Event('setInitValue');
49
+ item.dispatchEvent(_event);
50
+ }
51
+ }
52
+ if (type === 'hidden') {
53
+ var datepickerType = item.getAttribute('datatype');
54
+ if (datepickerType === 'datepicker-single') {
55
+ item.setAttribute('defaultValue', String(defaultValues[_name]));
56
+ var _event2 = new Event('setInitValue');
57
+ item.dispatchEvent(_event2);
58
+ }
59
+ if (datepickerType === 'datepicker-double') {
60
+ var isTo = item.getAttribute('data-datepicker') === 'to' ? 1 : 0;
61
+ var _data2 = defaultValues[_name];
62
+ item.setAttribute('defaultValue', String(_data2[isTo]));
63
+ var _event3 = new Event('setInitValue');
64
+ item.dispatchEvent(_event3);
65
+ }
66
+ }
67
+ }
68
+ };
69
+ var valideParams = function valideParams(name) {
70
+ return name && name !== '';
71
+ };
72
+ var useForm = exports.useForm = function useForm(onSubmit, defaultValues) {
73
+ var formRef = /*#__PURE__*/_react["default"].createRef();
74
+ (0, _react.useEffect)(function () {
75
+ initData(formRef, defaultValues);
76
+ }, []);
77
+ var formData = function formData(event) {
78
+ event.preventDefault();
79
+ var result = {};
80
+ var form = event.target;
81
+ var items = form.elements;
82
+ for (var i = 0; i < items.length; i++) {
83
+ var item = items[i];
84
+ var _name2 = item.name,
85
+ value = item.value,
86
+ type = item.type;
87
+ if ((type === 'text' || type === 'textarea') && valideParams(_name2)) {
88
+ result[_name2] = value;
89
+ }
90
+ if (type === 'checkbox' && valideParams(_name2)) {
91
+ result[_name2] = item.checked;
92
+ }
93
+ if (type === 'radio' && valideParams(_name2)) {
94
+ if (item.checked) {
95
+ result[_name2] = value;
96
+ } else if (!(_name2 in result)) {
97
+ result[_name2] = null;
98
+ }
99
+ }
100
+ if (type === 'number' && valideParams(_name2)) {
101
+ var sliderType = item.getAttribute('datatype');
102
+ if (sliderType === 'slider-single') {
103
+ result[_name2] = value;
104
+ }
105
+ if (sliderType === 'slider-double') {
106
+ var isMin = item.getAttribute('data-slidertype') === 'min';
107
+ if (isMin) {
108
+ result[_name2] = [Number(value)];
109
+ }
110
+ if (!isMin && Array.isArray(result[_name2])) {
111
+ result[_name2] = [].concat(_toConsumableArray(result[_name2]), [Number(value)]);
112
+ }
113
+ }
114
+ }
115
+ if (type === 'hidden' && valideParams(_name2)) {
116
+ var _sliderType = item.getAttribute('datatype');
117
+ if (_sliderType === 'datepicker-single') {
118
+ result[_name2] = value;
119
+ }
120
+ if (_sliderType === 'datepicker-double') {
121
+ var _isMin = item.getAttribute('data-datepicker') === 'from';
122
+ if (_isMin) {
123
+ result[_name2] = [String(value)];
124
+ }
125
+ if (!_isMin && Array.isArray(result[_name2])) {
126
+ result[_name2] = [].concat(_toConsumableArray(result[_name2]), [String(value)]);
127
+ }
128
+ }
129
+ }
130
+ }
131
+ onSubmit(result);
132
+ };
133
+ return {
134
+ formRef: formRef,
135
+ formData: formData
136
+ };
137
+ };
@@ -629,15 +629,4 @@ Object.keys(_Editable).forEach(function (key) {
629
629
  return _Editable[key];
630
630
  }
631
631
  });
632
- });
633
- var _Mask = /*#__PURE__*/require("./components/Mask");
634
- Object.keys(_Mask).forEach(function (key) {
635
- if (key === "default" || key === "__esModule") return;
636
- if (key in exports && exports[key] === _Mask[key]) return;
637
- Object.defineProperty(exports, key, {
638
- enumerable: true,
639
- get: function get() {
640
- return _Mask[key];
641
- }
642
- });
643
632
  });
@@ -13,6 +13,8 @@ var _exportNames = {
13
13
  IS_REACT_18: true,
14
14
  safeUseId: true,
15
15
  isNumber: true,
16
+ mergeRefs: true,
17
+ setRefList: true,
16
18
  isEmpty: true,
17
19
  constants: true
18
20
  };
@@ -53,17 +55,30 @@ Object.defineProperty(exports, "isNumber", {
53
55
  return _isNumber.isNumber;
54
56
  }
55
57
  });
58
+ Object.defineProperty(exports, "mergeRefs", {
59
+ enumerable: true,
60
+ get: function get() {
61
+ return _setRefList.mergeRefs;
62
+ }
63
+ });
56
64
  Object.defineProperty(exports, "safeUseId", {
57
65
  enumerable: true,
58
66
  get: function get() {
59
67
  return _react.safeUseId;
60
68
  }
61
69
  });
70
+ Object.defineProperty(exports, "setRefList", {
71
+ enumerable: true,
72
+ get: function get() {
73
+ return _setRefList.setRefList;
74
+ }
75
+ });
62
76
  var _canUseDOM = /*#__PURE__*/require("./canUseDOM");
63
77
  var _extractTextFrom = /*#__PURE__*/require("./extractTextFrom");
64
78
  var _getSizeValueFromProp = /*#__PURE__*/require("./getSizeValueFromProp");
65
79
  var _react = /*#__PURE__*/require("./react");
66
80
  var _isNumber = /*#__PURE__*/require("./isNumber");
81
+ var _setRefList = /*#__PURE__*/require("./setRefList");
67
82
  var _isEmpty = /*#__PURE__*/require("./isEmpty");
68
83
  var _constants = /*#__PURE__*/_interopRequireWildcard( /*#__PURE__*/require("./constants"));
69
84
  exports.constants = _constants;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.InputHidden = void 0;
7
+ var _react = /*#__PURE__*/require("@linaria/react");
8
+ var _templateObject;
9
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
10
+ var InputHidden = exports.InputHidden = /*#__PURE__*/_react.styled.input(_templateObject || (_templateObject = /*#__PURE__*/_taggedTemplateLiteral(["\n visibility: hidden;\n width: 0;\n height: 0;\n opacity: 0;\n margin: 0;\n padding: 0;\n border: none;\n"])));
@@ -0,0 +1,27 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.mergeRefs = mergeRefs;
7
+ exports.setRefList = setRefList;
8
+ function mergeRefs() {
9
+ for (var _len = arguments.length, refs = new Array(_len), _key = 0; _key < _len; _key++) {
10
+ refs[_key] = arguments[_key];
11
+ }
12
+ return function (val) {
13
+ setRefList.apply(void 0, [val].concat(refs));
14
+ };
15
+ }
16
+ function setRefList(val) {
17
+ for (var _len2 = arguments.length, refs = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
18
+ refs[_key2 - 1] = arguments[_key2];
19
+ }
20
+ refs.forEach(function (ref) {
21
+ if (typeof ref === 'function') {
22
+ ref(val);
23
+ } else if (ref != null) {
24
+ ref.current = val;
25
+ }
26
+ });
27
+ }
@@ -1,4 +1,4 @@
1
- var _excluded = ["className", "isDoubleCalendar", "opened", "label", "leftHelper", "contentLeft", "contentRight", "view", "size", "readOnly", "disabled", "dividerVariant", "dividerIcon", "defaultFirstDate", "defaultSecondDate", "firstValueError", "secondValueError", "firstValueSuccess", "secondValueSuccess", "firstPlaceholder", "secondPlaceholder", "firstTextfieldContentLeft", "firstTextfieldContentRight", "secondTextfieldContentLeft", "secondTextfieldContentRight", "firstTextfieldTextBefore", "secondTextfieldTextBefore", "firstTextfieldTextAfter", "secondTextfieldTextAfter", "format", "lang", "maskWithFormat", "min", "max", "includeEdgeDates", "eventList", "disabledList", "eventMonthList", "disabledMonthList", "eventQuarterList", "disabledQuarterList", "eventYearList", "disabledYearList", "type", "placement", "closeOnOverlayClick", "closeOnEsc", "offset", "onToggle", "onChangeFirstValue", "onChangeSecondValue", "onCommitFirstDate", "onCommitSecondDate", "onFocusFirstTextfield", "onFocusSecondTextfield", "onBlurFirstTextfield", "onBlurSecondTextfield"];
1
+ var _excluded = ["className", "isDoubleCalendar", "opened", "label", "leftHelper", "contentLeft", "contentRight", "view", "size", "readOnly", "disabled", "name", "dividerVariant", "dividerIcon", "defaultFirstDate", "defaultSecondDate", "firstValueError", "secondValueError", "firstValueSuccess", "secondValueSuccess", "firstPlaceholder", "secondPlaceholder", "firstTextfieldContentLeft", "firstTextfieldContentRight", "secondTextfieldContentLeft", "secondTextfieldContentRight", "firstTextfieldTextBefore", "secondTextfieldTextBefore", "firstTextfieldTextAfter", "secondTextfieldTextAfter", "format", "lang", "maskWithFormat", "min", "max", "includeEdgeDates", "eventList", "disabledList", "eventMonthList", "disabledMonthList", "eventQuarterList", "disabledQuarterList", "eventYearList", "disabledYearList", "type", "placement", "closeOnOverlayClick", "closeOnEsc", "offset", "onToggle", "onChangeFirstValue", "onChangeSecondValue", "onCommitFirstDate", "onCommitSecondDate", "onFocusFirstTextfield", "onFocusSecondTextfield", "onBlurFirstTextfield", "onBlurSecondTextfield"];
2
2
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
3
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
4
4
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -14,6 +14,8 @@ import { formatCalendarValue, formatInputValue, getDateFormatDelimiter } from '.
14
14
  import { useDatePicker } from '../hooks/useDatePicker';
15
15
  import { classes } from '../DatePicker.tokens';
16
16
  import { useKeyNavigation } from '../hooks/useKeyboardNavigation';
17
+ import { setInitValue } from '../utils/setInitValue';
18
+ import { InputHidden } from '../../../utils/inputHidden';
17
19
  import { base as sizeCSS } from './variations/_size/base';
18
20
  import { base as viewCSS } from './variations/_view/base';
19
21
  import { base as disabledCSS } from './variations/_disabled/base';
@@ -38,6 +40,7 @@ export var datePickerRangeRoot = function datePickerRangeRoot(Root) {
38
40
  readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
39
41
  _ref$disabled = _ref.disabled,
40
42
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
43
+ name = _ref.name,
41
44
  _ref$dividerVariant = _ref.dividerVariant,
42
45
  dividerVariant = _ref$dividerVariant === void 0 ? 'dash' : _ref$dividerVariant,
43
46
  dividerIcon = _ref.dividerIcon,
@@ -97,6 +100,8 @@ export var datePickerRangeRoot = function datePickerRangeRoot(Root) {
97
100
  rest = _objectWithoutProperties(_ref, _excluded);
98
101
  var rangeRef = ref && 'current' in ref ? ref : /*#__PURE__*/createRef();
99
102
  var rootRef = useRef(null);
103
+ var innerRefFirst = useRef(null);
104
+ var innerRefSecond = useRef(null);
100
105
  var _useState = useState(rangeRef === null || rangeRef === void 0 || (_rangeRef$current = rangeRef.current) === null || _rangeRef$current === void 0 ? void 0 : _rangeRef$current.firstTextField()),
101
106
  _useState2 = _slicedToArray(_useState, 2),
102
107
  firstInputRef = _useState2[0],
@@ -190,6 +195,23 @@ export var datePickerRangeRoot = function datePickerRangeRoot(Root) {
190
195
  onToggle: handleToggle
191
196
  }),
192
197
  onKeyDown = _useKeyNavigation.onKeyDown;
198
+ var setValue = function setValue(e) {
199
+ var firstElement = innerRefFirst.current;
200
+ var firstValueInit = String(firstElement.getAttribute('defaultValue'));
201
+ var secondValueInit = setInitValue(e);
202
+ handleCommitFirstDate(firstValueInit, true, false);
203
+ handleCommitSecondDate(secondValueInit, true, false);
204
+ };
205
+ useEffect(function () {
206
+ if (innerRefSecond.current) {
207
+ innerRefSecond.current.addEventListener('setInitValue', setValue);
208
+ }
209
+ return function () {
210
+ if (innerRefSecond.current) {
211
+ innerRefSecond.current.removeEventListener('setInitValue', setValue);
212
+ }
213
+ };
214
+ }, [innerRefSecond]);
193
215
  var RangeComponent = /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(StyledRange, {
194
216
  ref: rangeRef,
195
217
  dividerIcon: dividerIcon,
@@ -216,6 +238,7 @@ export var datePickerRangeRoot = function datePickerRangeRoot(Root) {
216
238
  secondValueSuccess: secondValueSuccess,
217
239
  onChangeFirstValue: handleChangeFirstValue,
218
240
  onChangeSecondValue: handleChangeSecondValue,
241
+ name: name,
219
242
  onSearchFirstValue: function onSearchFirstValue(_, date) {
220
243
  handleCommitFirstDate(String(date), true, false);
221
244
  if (!calendarSecondValue || secondValueError) {
@@ -319,7 +342,21 @@ export var datePickerRangeRoot = function datePickerRangeRoot(Root) {
319
342
  setIsInnerOpen(false);
320
343
  }
321
344
  }
322
- }), leftHelper && /*#__PURE__*/React.createElement(LeftHelper, null, leftHelper));
345
+ }), leftHelper && /*#__PURE__*/React.createElement(LeftHelper, null, leftHelper), /*#__PURE__*/React.createElement(InputHidden, {
346
+ name: name,
347
+ type: "hidden",
348
+ datatype: "datepicker-double",
349
+ "data-datepicker": "from",
350
+ value: inputFirstValue,
351
+ ref: innerRefFirst
352
+ }), /*#__PURE__*/React.createElement(InputHidden, {
353
+ name: name,
354
+ type: "hidden",
355
+ datatype: "datepicker-double",
356
+ "data-datepicker": "to",
357
+ value: inputSecondValue,
358
+ ref: innerRefSecond
359
+ }));
323
360
  });
324
361
  };
325
362
  export var datePickerRangeConfig = {
@@ -1,4 +1,4 @@
1
- var _excluded = ["className", "opened", "label", "labelPlacement", "placeholder", "leftHelper", "contentLeft", "contentRight", "textBefore", "textAfter", "view", "size", "readOnly", "disabled", "defaultDate", "valueError", "valueSuccess", "format", "lang", "maskWithFormat", "min", "max", "includeEdgeDates", "eventList", "disabledList", "eventMonthList", "disabledMonthList", "eventQuarterList", "disabledQuarterList", "eventYearList", "disabledYearList", "type", "placement", "closeOnOverlayClick", "offset", "onChangeValue", "onCommitDate", "onToggle", "onFocus", "onBlur"];
1
+ var _excluded = ["className", "opened", "label", "labelPlacement", "placeholder", "leftHelper", "contentLeft", "contentRight", "textBefore", "textAfter", "view", "size", "readOnly", "disabled", "name", "defaultDate", "valueError", "valueSuccess", "format", "lang", "maskWithFormat", "min", "max", "includeEdgeDates", "eventList", "disabledList", "eventMonthList", "disabledMonthList", "eventQuarterList", "disabledQuarterList", "eventYearList", "disabledYearList", "type", "placement", "closeOnOverlayClick", "offset", "onChangeValue", "onCommitDate", "onToggle", "onFocus", "onBlur"];
2
2
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
3
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
4
4
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -15,6 +15,8 @@ import { useDatePicker } from '../hooks/useDatePicker';
15
15
  import { classes } from '../DatePicker.tokens';
16
16
  import { StyledCalendar } from '../DatePickerBase.styles';
17
17
  import { useKeyNavigation } from '../hooks/useKeyboardNavigation';
18
+ import { setInitValue } from '../utils/setInitValue';
19
+ import { InputHidden } from '../../../utils/inputHidden';
18
20
  import { base as sizeCSS } from './variations/_size/base';
19
21
  import { base as viewCSS } from './variations/_view/base';
20
22
  import { base as disabledCSS } from './variations/_disabled/base';
@@ -40,6 +42,7 @@ export var datePickerRoot = function datePickerRoot(Root) {
40
42
  readOnly = _ref$readOnly === void 0 ? false : _ref$readOnly,
41
43
  _ref$disabled = _ref.disabled,
42
44
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
45
+ name = _ref.name,
43
46
  _ref$defaultDate = _ref.defaultDate,
44
47
  defaultDate = _ref$defaultDate === void 0 ? '' : _ref$defaultDate,
45
48
  valueError = _ref.valueError,
@@ -75,6 +78,7 @@ export var datePickerRoot = function datePickerRoot(Root) {
75
78
  onBlur = _ref.onBlur,
76
79
  rest = _objectWithoutProperties(_ref, _excluded);
77
80
  var inputRef = useRef(null);
81
+ var innerRef = useRef(null);
78
82
  var _useState = useState(opened),
79
83
  _useState2 = _slicedToArray(_useState, 2),
80
84
  isInnerOpen = _useState2[0],
@@ -167,6 +171,20 @@ export var datePickerRoot = function datePickerRoot(Root) {
167
171
  lang: lang
168
172
  }));
169
173
  }, [format, lang]);
174
+ useEffect(function () {
175
+ if (innerRef.current) {
176
+ innerRef.current.addEventListener('setInitValue', function (e) {
177
+ return handleCommitDate(setInitValue(e), true, false);
178
+ });
179
+ }
180
+ return function () {
181
+ if (innerRef.current) {
182
+ innerRef.current.removeEventListener('setInitValue', function (e) {
183
+ return handleCommitDate(setInitValue(e), true, false);
184
+ });
185
+ }
186
+ };
187
+ }, [innerRef]);
170
188
  return /*#__PURE__*/React.createElement(Root, _extends({
171
189
  view: view,
172
190
  size: size,
@@ -204,7 +222,13 @@ export var datePickerRoot = function datePickerRoot(Root) {
204
222
  onChangeValue: function onChangeValue(date, dateInfo) {
205
223
  return handleCommitDate(date, false, true, dateInfo);
206
224
  }
207
- })), leftHelper && /*#__PURE__*/React.createElement(LeftHelper, null, leftHelper));
225
+ })), leftHelper && /*#__PURE__*/React.createElement(LeftHelper, null, leftHelper), /*#__PURE__*/React.createElement(InputHidden, {
226
+ type: "hidden",
227
+ datatype: "datepicker-single",
228
+ name: name,
229
+ value: inputValue,
230
+ ref: innerRef
231
+ }));
208
232
  });
209
233
  };
210
234
  export var datePickerConfig = {
@@ -0,0 +1,5 @@
1
+ export var setInitValue = function setInitValue(e) {
2
+ var item = e.target;
3
+ var defaultValue = String(item.getAttribute('defaultValue'));
4
+ return defaultValue;
5
+ };