@dartcom/ui-kit 3.3.0 → 3.4.0
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.
- package/dist/cjs/components/form/form.js +7 -15
- package/dist/cjs/components/form/form.js.map +1 -1
- package/dist/cjs/components/input/input.js +20 -5
- package/dist/cjs/components/input/input.js.map +1 -1
- package/dist/cjs/components/text-field/text-field.js +13 -0
- package/dist/cjs/components/text-field/text-field.js.map +1 -0
- package/dist/cjs/node_modules/react-hook-form/dist/index.esm.js +35 -0
- package/dist/cjs/node_modules/react-hook-form/dist/index.esm.js.map +1 -1
- package/dist/esm/components/form/form.js +1 -1
- package/dist/esm/components/form/form.js.map +1 -1
- package/dist/esm/components/input/input.js +1 -1
- package/dist/esm/components/input/input.js.map +1 -1
- package/dist/esm/components/text-field/text-field.js +2 -0
- package/dist/esm/components/text-field/text-field.js.map +1 -0
- package/dist/esm/node_modules/react-hook-form/dist/index.esm.js +1 -1
- package/dist/esm/node_modules/react-hook-form/dist/index.esm.js.map +1 -1
- package/dist/esm/types/components/buttons/delete/delete.stories.d.ts.map +1 -1
- package/dist/esm/types/components/form/form.d.ts +1 -13
- package/dist/esm/types/components/form/form.d.ts.map +1 -1
- package/dist/esm/types/components/form/form.stories.d.ts.map +1 -1
- package/dist/esm/types/components/input/index.d.ts +1 -0
- package/dist/esm/types/components/input/index.d.ts.map +1 -1
- package/dist/esm/types/components/input/input.d.ts.map +1 -1
- package/dist/esm/types/components/input/types.d.ts +2 -2
- package/dist/esm/types/components/input/types.d.ts.map +1 -1
- package/dist/esm/types/components/text-field/index.d.ts +3 -0
- package/dist/esm/types/components/text-field/index.d.ts.map +1 -0
- package/dist/esm/types/components/text-field/text-field.d.ts +5 -0
- package/dist/esm/types/components/text-field/text-field.d.ts.map +1 -0
- package/dist/esm/types/components/text-field/types.d.ts +3 -0
- package/dist/esm/types/components/text-field/types.d.ts.map +1 -0
- package/package.json +1 -1
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
5
|
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var index_esm = require('../../node_modules/react-hook-form/dist/index.esm.js');
|
|
6
7
|
var Box = require('../../node_modules/@mui/material/esm/Box/Box.js');
|
|
7
8
|
|
|
8
9
|
/**
|
|
@@ -16,22 +17,13 @@ var Box = require('../../node_modules/@mui/material/esm/Box/Box.js');
|
|
|
16
17
|
*
|
|
17
18
|
* @returns {JSX.Element} The rendered form component with form context.
|
|
18
19
|
*/
|
|
19
|
-
function CustomForm({ form, sx = {},
|
|
20
|
+
function CustomForm({ form, sx = {}, onSubmit, children, }) {
|
|
20
21
|
const { handleSubmit } = form;
|
|
21
|
-
return (jsxRuntime.
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
display: 'grid',
|
|
27
|
-
gap: '15px',
|
|
28
|
-
...fields.sx,
|
|
29
|
-
}, children: fields.content }), buttons?.content ? (jsxRuntime.jsx(Box.default, { sx: {
|
|
30
|
-
display: 'flex',
|
|
31
|
-
alignItems: 'center',
|
|
32
|
-
gap: '15px',
|
|
33
|
-
...buttons.sx,
|
|
34
|
-
}, children: buttons.content })) : null, observers?.content] }));
|
|
22
|
+
return (jsxRuntime.jsx(index_esm.FormProvider, { ...form, children: jsxRuntime.jsx(Box.default, { component: "form", sx: {
|
|
23
|
+
display: 'grid',
|
|
24
|
+
gap: '15px',
|
|
25
|
+
...sx,
|
|
26
|
+
}, onSubmit: handleSubmit(onSubmit), children: children }) }));
|
|
35
27
|
}
|
|
36
28
|
|
|
37
29
|
exports.default = CustomForm;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"form.js","sources":["../../../../src/components/form/form.tsx"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"file":"form.js","sources":["../../../../src/components/form/form.tsx"],"sourcesContent":["import { Box, SxProps } from '@mui/material';\r\nimport {\r\n FieldValues,\r\n FormProvider,\r\n SubmitHandler,\r\n UseFormReturn,\r\n} from 'react-hook-form';\r\n\r\ninterface CustomFormProp<T extends FieldValues> {\r\n form: UseFormReturn<T>;\r\n\r\n onSubmit: SubmitHandler<T>;\r\n\r\n sx?: SxProps;\r\n}\r\n\r\n/**\r\n * Используем этот компонент как основную обертку для формы\r\n * Все поля должны хранится при инициализации формы и быть доступны через контекст формы\r\n * @template T - Интрефейс данных формы.\r\n * @param {React.ReactNode} children - Все компоненты, которым нужен контекст фор.\r\n * @param {UseFormReturn<T>} form - Форма useForm, которая содержит все поля.\r\n * @param {SxProps} [sx={}] - Опциональные стили самой формы.\r\n * @param {SubmitHandler<T>} onSubmit - Функция обработки отправки формы.\r\n *\r\n * @returns {JSX.Element} The rendered form component with form context.\r\n */\r\nfunction CustomForm<T extends FieldValues>({\r\n form,\r\n sx = {},\r\n onSubmit,\r\n children,\r\n}: React.PropsWithChildren<CustomFormProp<T>>) {\r\n const { handleSubmit } = form;\r\n\r\n return (\r\n <FormProvider {...form}>\r\n <Box\r\n component=\"form\"\r\n sx={{\r\n display: 'grid',\r\n\r\n gap: '15px',\r\n\r\n ...sx,\r\n }}\r\n onSubmit={handleSubmit(onSubmit)}>\r\n {children}\r\n </Box>\r\n </FormProvider>\r\n );\r\n}\r\n\r\nexport default CustomForm;\r\n"],"names":["_jsx","FormProvider","Box"],"mappings":";;;;;;;;AAgBA;;;;;;;;;;AAUG;AACH,SAAS,UAAU,CAAwB,EACzC,IAAI,EACJ,EAAE,GAAG,EAAE,EACP,QAAQ,EACR,QAAQ,GACmC,EAAA;AAC3C,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI;AAE7B,IAAA,QACEA,cAAA,CAACC,sBAAY,EAAA,EAAA,GAAK,IAAI,EAAA,QAAA,EACpBD,cAAA,CAACE,WAAG,EAAA,EACF,SAAS,EAAC,MAAM,EAChB,EAAE,EAAE;AACF,gBAAA,OAAO,EAAE,MAAM;AAEf,gBAAA,GAAG,EAAE,MAAM;AAEX,gBAAA,GAAG,EAAE;aACN,EACD,QAAQ,EAAE,YAAY,CAAC,QAAQ,CAAC,EAAA,QAAA,EAC/B,QAAQ,EAAA,CACL,EAAA,CACO;AAEnB;;;;"}
|
|
@@ -5,7 +5,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
5
5
|
var jsxRuntime = require('react/jsx-runtime');
|
|
6
6
|
var React = require('react');
|
|
7
7
|
var index_esm = require('../../node_modules/react-hook-form/dist/index.esm.js');
|
|
8
|
-
var
|
|
8
|
+
var textField = require('../text-field/text-field.js');
|
|
9
9
|
|
|
10
10
|
function _interopNamespaceDefault(e) {
|
|
11
11
|
var n = Object.create(null);
|
|
@@ -27,12 +27,27 @@ function _interopNamespaceDefault(e) {
|
|
|
27
27
|
var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
|
|
28
28
|
|
|
29
29
|
function CustomInput(props) {
|
|
30
|
-
const { name } = props;
|
|
30
|
+
const { name, type } = props;
|
|
31
31
|
const textFieldId = React__namespace.useId();
|
|
32
32
|
const { control } = index_esm.useFormContext();
|
|
33
|
-
return (jsxRuntime.jsx(index_esm.Controller, { name: name, control: control, render: ({ field }) => {
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
return (jsxRuntime.jsx(index_esm.Controller, { name: name, control: control, render: ({ field }) => (jsxRuntime.jsx(textField.default, { id: textFieldId, ...props, ...field, onChange: (event) => {
|
|
34
|
+
const { target } = event;
|
|
35
|
+
const { value } = target;
|
|
36
|
+
switch (type) {
|
|
37
|
+
case 'number': {
|
|
38
|
+
if (value === '') {
|
|
39
|
+
field.onChange();
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
field.onChange(Number(value));
|
|
43
|
+
}
|
|
44
|
+
break;
|
|
45
|
+
}
|
|
46
|
+
default: {
|
|
47
|
+
field.onChange(event);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
} })) }));
|
|
36
51
|
}
|
|
37
52
|
|
|
38
53
|
exports.default = CustomInput;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"input.js","sources":["../../../../src/components/input/input.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport {
|
|
1
|
+
{"version":3,"file":"input.js","sources":["../../../../src/components/input/input.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport { Controller, useFormContext } from 'react-hook-form';\r\n\r\nimport { TextField } from '../text-field';\r\n\r\nimport { CustomInputProps } from './types';\r\n\r\nfunction CustomInput<T>(props: CustomInputProps<T>) {\r\n const { name, type } = props;\r\n\r\n const textFieldId = React.useId();\r\n\r\n const { control } = useFormContext();\r\n\r\n return (\r\n <Controller\r\n name={name}\r\n control={control}\r\n render={({ field }) => (\r\n <TextField\r\n id={textFieldId}\r\n {...props}\r\n {...field}\r\n onChange={(event) => {\r\n const { target } = event;\r\n\r\n const { value } = target;\r\n\r\n switch (type) {\r\n case 'number': {\r\n if (value === '') {\r\n field.onChange();\r\n } else {\r\n field.onChange(Number(value));\r\n }\r\n\r\n break;\r\n }\r\n\r\n default: {\r\n field.onChange(event);\r\n }\r\n }\r\n }}\r\n />\r\n )}\r\n />\r\n );\r\n}\r\n\r\nexport default CustomInput;\r\n"],"names":["React","useFormContext","_jsx","Controller","TextField"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,SAAS,WAAW,CAAI,KAA0B,EAAA;AAChD,IAAA,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,KAAK;AAE5B,IAAA,MAAM,WAAW,GAAGA,gBAAK,CAAC,KAAK,EAAE;AAEjC,IAAA,MAAM,EAAE,OAAO,EAAE,GAAGC,wBAAc,EAAE;AAEpC,IAAA,QACEC,cAAA,CAACC,oBAAU,EAAA,EACT,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,MAChBD,cAAA,CAACE,iBAAS,EAAA,EACR,EAAE,EAAE,WAAW,EAAA,GACX,KAAK,EAAA,GACL,KAAK,EACT,QAAQ,EAAE,CAAC,KAAK,KAAI;AAClB,gBAAA,MAAM,EAAE,MAAM,EAAE,GAAG,KAAK;AAExB,gBAAA,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM;gBAExB,QAAQ,IAAI;oBACV,KAAK,QAAQ,EAAE;AACb,wBAAA,IAAI,KAAK,KAAK,EAAE,EAAE;4BAChB,KAAK,CAAC,QAAQ,EAAE;wBAClB;6BAAO;4BACL,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;wBAC/B;wBAEA;oBACF;oBAEA,SAAS;AACP,wBAAA,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;oBACvB;;AAEJ,YAAA,CAAC,EAAA,CACD,CACH,EAAA,CACD;AAEN;;;;"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
6
|
+
var TextField = require('../../node_modules/@mui/material/esm/TextField/TextField.js');
|
|
7
|
+
|
|
8
|
+
const CustomTextField = (props) => {
|
|
9
|
+
return jsxRuntime.jsx(TextField.default, { size: "small", ...props });
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
exports.default = CustomTextField;
|
|
13
|
+
//# sourceMappingURL=text-field.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"text-field.js","sources":["../../../../src/components/text-field/text-field.tsx"],"sourcesContent":["import * as React from 'react';\nimport { TextField } from '@mui/material';\n\nimport { CustomTextFieldProps } from './types';\n\nconst CustomTextField: React.FC<CustomTextFieldProps> = (props) => {\n return <TextField size=\"small\" {...props} />;\n};\n\nexport default CustomTextField;\n"],"names":["_jsx","TextField"],"mappings":";;;;;;;AAKA,MAAM,eAAe,GAAmC,CAAC,KAAK,KAAI;IAChE,OAAOA,cAAA,CAACC,iBAAS,EAAA,EAAC,IAAI,EAAC,OAAO,EAAA,GAAK,KAAK,EAAA,CAAI;AAC9C;;;;"}
|
|
@@ -148,6 +148,40 @@ HookFormContext.displayName = 'HookFormContext';
|
|
|
148
148
|
* ```
|
|
149
149
|
*/
|
|
150
150
|
const useFormContext = () => React.useContext(HookFormContext);
|
|
151
|
+
/**
|
|
152
|
+
* A provider component that propagates the `useForm` methods to all children components via [React Context](https://reactjs.org/docs/context.html) API. To be used with {@link useFormContext}.
|
|
153
|
+
*
|
|
154
|
+
* @remarks
|
|
155
|
+
* [API](https://react-hook-form.com/docs/useformcontext) • [Demo](https://codesandbox.io/s/react-hook-form-v7-form-context-ytudi)
|
|
156
|
+
*
|
|
157
|
+
* @param props - all useForm methods
|
|
158
|
+
*
|
|
159
|
+
* @example
|
|
160
|
+
* ```tsx
|
|
161
|
+
* function App() {
|
|
162
|
+
* const methods = useForm();
|
|
163
|
+
* const onSubmit = data => console.log(data);
|
|
164
|
+
*
|
|
165
|
+
* return (
|
|
166
|
+
* <FormProvider {...methods} >
|
|
167
|
+
* <form onSubmit={methods.handleSubmit(onSubmit)}>
|
|
168
|
+
* <NestedInput />
|
|
169
|
+
* <input type="submit" />
|
|
170
|
+
* </form>
|
|
171
|
+
* </FormProvider>
|
|
172
|
+
* );
|
|
173
|
+
* }
|
|
174
|
+
*
|
|
175
|
+
* function NestedInput() {
|
|
176
|
+
* const { register } = useFormContext(); // retrieve all hook methods
|
|
177
|
+
* return <input {...register("test")} />;
|
|
178
|
+
* }
|
|
179
|
+
* ```
|
|
180
|
+
*/
|
|
181
|
+
const FormProvider = (props) => {
|
|
182
|
+
const { children, ...data } = props;
|
|
183
|
+
return (React.createElement(HookFormContext.Provider, { value: data }, children));
|
|
184
|
+
};
|
|
151
185
|
|
|
152
186
|
var getProxyFormState = (formState, control, localProxyFormState, isRoot = true) => {
|
|
153
187
|
const result = {
|
|
@@ -532,6 +566,7 @@ function useController(props) {
|
|
|
532
566
|
const Controller = (props) => props.render(useController(props));
|
|
533
567
|
|
|
534
568
|
exports.Controller = Controller;
|
|
569
|
+
exports.FormProvider = FormProvider;
|
|
535
570
|
exports.get = get;
|
|
536
571
|
exports.set = set;
|
|
537
572
|
exports.useController = useController;
|