@dartcom/ui-kit 3.3.1 → 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.
Files changed (28) hide show
  1. package/dist/cjs/components/form/form.js +3 -12
  2. package/dist/cjs/components/form/form.js.map +1 -1
  3. package/dist/cjs/components/input/input.js +20 -5
  4. package/dist/cjs/components/input/input.js.map +1 -1
  5. package/dist/cjs/components/text-field/text-field.js +13 -0
  6. package/dist/cjs/components/text-field/text-field.js.map +1 -0
  7. package/dist/esm/components/form/form.js +1 -1
  8. package/dist/esm/components/form/form.js.map +1 -1
  9. package/dist/esm/components/input/input.js +1 -1
  10. package/dist/esm/components/input/input.js.map +1 -1
  11. package/dist/esm/components/text-field/text-field.js +2 -0
  12. package/dist/esm/components/text-field/text-field.js.map +1 -0
  13. package/dist/esm/types/components/buttons/delete/delete.stories.d.ts.map +1 -1
  14. package/dist/esm/types/components/form/form.d.ts +1 -13
  15. package/dist/esm/types/components/form/form.d.ts.map +1 -1
  16. package/dist/esm/types/components/form/form.stories.d.ts.map +1 -1
  17. package/dist/esm/types/components/input/index.d.ts +1 -0
  18. package/dist/esm/types/components/input/index.d.ts.map +1 -1
  19. package/dist/esm/types/components/input/input.d.ts.map +1 -1
  20. package/dist/esm/types/components/input/types.d.ts +2 -2
  21. package/dist/esm/types/components/input/types.d.ts.map +1 -1
  22. package/dist/esm/types/components/text-field/index.d.ts +3 -0
  23. package/dist/esm/types/components/text-field/index.d.ts.map +1 -0
  24. package/dist/esm/types/components/text-field/text-field.d.ts +5 -0
  25. package/dist/esm/types/components/text-field/text-field.d.ts.map +1 -0
  26. package/dist/esm/types/components/text-field/types.d.ts +3 -0
  27. package/dist/esm/types/components/text-field/types.d.ts.map +1 -0
  28. package/package.json +1 -1
@@ -17,22 +17,13 @@ var Box = require('../../node_modules/@mui/material/esm/Box/Box.js');
17
17
  *
18
18
  * @returns {JSX.Element} The rendered form component with form context.
19
19
  */
20
- function CustomForm({ form, sx = {}, fields, buttons, observers, onSubmit, }) {
20
+ function CustomForm({ form, sx = {}, onSubmit, children, }) {
21
21
  const { handleSubmit } = form;
22
- return (jsxRuntime.jsx(index_esm.FormProvider, { ...form, children: jsxRuntime.jsxs(Box.default, { component: "form", sx: {
22
+ return (jsxRuntime.jsx(index_esm.FormProvider, { ...form, children: jsxRuntime.jsx(Box.default, { component: "form", sx: {
23
23
  display: 'grid',
24
24
  gap: '15px',
25
25
  ...sx,
26
- }, onSubmit: handleSubmit(onSubmit), children: [jsxRuntime.jsx(Box.default, { sx: {
27
- display: 'grid',
28
- gap: '15px',
29
- ...fields.sx,
30
- }, children: fields.content }), buttons?.content ? (jsxRuntime.jsx(Box.default, { sx: {
31
- display: 'flex',
32
- alignItems: 'center',
33
- gap: '15px',
34
- ...buttons.sx,
35
- }, children: buttons.content })) : null, observers?.content] }) }));
26
+ }, onSubmit: handleSubmit(onSubmit), children: children }) }));
36
27
  }
37
28
 
38
29
  exports.default = CustomForm;
@@ -1 +1 @@
1
- {"version":3,"file":"form.js","sources":["../../../../src/components/form/form.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport { 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 fields: {\r\n content: React.ReactNode;\r\n sx?: SxProps;\r\n };\r\n\r\n buttons?: {\r\n content?: React.ReactNode;\r\n sx?: SxProps;\r\n };\r\n\r\n observers?: {\r\n content?: React.ReactNode;\r\n };\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 fields,\r\n buttons,\r\n observers,\r\n onSubmit,\r\n}: 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 <Box\r\n sx={{\r\n display: 'grid',\r\n\r\n gap: '15px',\r\n\r\n ...fields.sx,\r\n }}>\r\n {fields.content}\r\n </Box>\r\n\r\n {buttons?.content ? (\r\n <Box\r\n sx={{\r\n display: 'flex',\r\n\r\n alignItems: 'center',\r\n\r\n gap: '15px',\r\n\r\n ...buttons.sx,\r\n }}>\r\n {buttons.content}\r\n </Box>\r\n ) : null}\r\n {observers?.content}\r\n </Box>\r\n </FormProvider>\r\n );\r\n}\r\n\r\nexport default CustomForm;\r\n"],"names":["_jsx","FormProvider","_jsxs","Box"],"mappings":";;;;;;;;AA+BA;;;;;;;;;;AAUG;AACH,SAAS,UAAU,CAAwB,EACzC,IAAI,EACJ,EAAE,GAAG,EAAE,EACP,MAAM,EACN,OAAO,EACP,SAAS,EACT,QAAQ,GACU,EAAA;AAClB,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI;AAE7B,IAAA,QACEA,cAAA,CAACC,sBAAY,EAAA,EAAA,GAAK,IAAI,EAAA,QAAA,EACpBC,eAAA,CAACC,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,EAAA,CAChCH,cAAA,CAACG,WAAG,EAAA,EACF,EAAE,EAAE;AACF,wBAAA,OAAO,EAAE,MAAM;AAEf,wBAAA,GAAG,EAAE,MAAM;wBAEX,GAAG,MAAM,CAAC,EAAE;AACb,qBAAA,EAAA,QAAA,EACA,MAAM,CAAC,OAAO,EAAA,CACX,EAEL,OAAO,EAAE,OAAO,IACfH,cAAA,CAACG,WAAG,EAAA,EACF,EAAE,EAAE;AACF,wBAAA,OAAO,EAAE,MAAM;AAEf,wBAAA,UAAU,EAAE,QAAQ;AAEpB,wBAAA,GAAG,EAAE,MAAM;wBAEX,GAAG,OAAO,CAAC,EAAE;AACd,qBAAA,EAAA,QAAA,EACA,OAAO,CAAC,OAAO,EAAA,CACZ,IACJ,IAAI,EACP,SAAS,EAAE,OAAO,CAAA,EAAA,CACf,EAAA,CACO;AAEnB;;;;"}
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 TextField = require('../../node_modules/@mui/material/esm/TextField/TextField.js');
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
- return (jsxRuntime.jsx(TextField.default, { id: textFieldId, ...props, ...field, size: "small" }));
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 { TextField } from '@mui/material';\r\nimport { Controller, useFormContext } from 'react-hook-form';\r\n\r\nimport { CustomInputProps } from './types';\r\n\r\nfunction CustomInput<T>(props: CustomInputProps<T>) {\r\n const { name } = 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 return (\r\n <TextField id={textFieldId} {...props} {...field} size=\"small\" />\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,SAAS,WAAW,CAAI,KAA0B,EAAA;AAChD,IAAA,MAAM,EAAE,IAAI,EAAE,GAAG,KAAK;AAEtB,IAAA,MAAM,WAAW,GAAGA,gBAAK,CAAC,KAAK,EAAE;AAEjC,IAAA,MAAM,EAAE,OAAO,EAAE,GAAGC,wBAAc,EAAE;AAEpC,IAAA,QACEC,cAAA,CAACC,oBAAU,IACT,IAAI,EAAE,IAAI,EACV,OAAO,EAAE,OAAO,EAChB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,KAAI;AACpB,YAAA,QACED,cAAA,CAACE,iBAAS,EAAA,EAAC,EAAE,EAAE,WAAW,EAAA,GAAM,KAAK,EAAA,GAAM,KAAK,EAAE,IAAI,EAAC,OAAO,EAAA,CAAG;QAErE,CAAC,EAAA,CACD;AAEN;;;;"}
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;;;;"}
@@ -1,2 +1,2 @@
1
- import{jsx as e,jsxs as o}from"react/jsx-runtime";import{FormProvider as n}from"../../node_modules/react-hook-form/dist/index.esm.js";import t from"../../node_modules/@mui/material/esm/Box/Box.js";function r({form:r,sx:s={},fields:i,buttons:m,observers:d,onSubmit:l}){const{handleSubmit:x}=r;return e(n,{...r,children:o(t,{component:"form",sx:{display:"grid",gap:"15px",...s},onSubmit:x(l),children:[e(t,{sx:{display:"grid",gap:"15px",...i.sx},children:i.content}),m?.content?e(t,{sx:{display:"flex",alignItems:"center",gap:"15px",...m.sx},children:m.content}):null,d?.content]})})}export{r as default};
1
+ import{jsx as o}from"react/jsx-runtime";import{FormProvider as m}from"../../node_modules/react-hook-form/dist/index.esm.js";import r from"../../node_modules/@mui/material/esm/Box/Box.js";function e({form:e,sx:i={},onSubmit:t,children:n}){const{handleSubmit:d}=e;return o(m,{...e,children:o(r,{component:"form",sx:{display:"grid",gap:"15px",...i},onSubmit:d(t),children:n})})}export{e as default};
2
2
  //# sourceMappingURL=form.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.js","sources":["../../../../src/components/form/form.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport { 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 fields: {\r\n content: React.ReactNode;\r\n sx?: SxProps;\r\n };\r\n\r\n buttons?: {\r\n content?: React.ReactNode;\r\n sx?: SxProps;\r\n };\r\n\r\n observers?: {\r\n content?: React.ReactNode;\r\n };\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 fields,\r\n buttons,\r\n observers,\r\n onSubmit,\r\n}: 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 <Box\r\n sx={{\r\n display: 'grid',\r\n\r\n gap: '15px',\r\n\r\n ...fields.sx,\r\n }}>\r\n {fields.content}\r\n </Box>\r\n\r\n {buttons?.content ? (\r\n <Box\r\n sx={{\r\n display: 'flex',\r\n\r\n alignItems: 'center',\r\n\r\n gap: '15px',\r\n\r\n ...buttons.sx,\r\n }}>\r\n {buttons.content}\r\n </Box>\r\n ) : null}\r\n {observers?.content}\r\n </Box>\r\n </FormProvider>\r\n );\r\n}\r\n\r\nexport default CustomForm;\r\n"],"names":["CustomForm","form","sx","fields","buttons","observers","onSubmit","handleSubmit","_jsx","FormProvider","children","_jsxs","Box","component","display","gap","content","alignItems"],"mappings":"qMA0CA,SAASA,GAAkCC,KACzCA,EAAIC,GACJA,EAAK,CAAA,EAAEC,OACPA,EAAMC,QACNA,EAAOC,UACPA,EAASC,SACTA,IAEA,MAAMC,aAAEA,GAAiBN,EAEzB,OACEO,EAACC,EAAY,IAAKR,EAAIS,SACpBC,EAACC,EAAG,CACFC,UAAU,OACVX,GAAI,CACFY,QAAS,OAETC,IAAK,UAEFb,GAELI,SAAUC,EAAaD,GAASI,SAAA,CAChCF,EAACI,EAAG,CACFV,GAAI,CACFY,QAAS,OAETC,IAAK,UAEFZ,EAAOD,IACXQ,SACAP,EAAOa,UAGTZ,GAASY,QACRR,EAACI,EAAG,CACFV,GAAI,CACFY,QAAS,OAETG,WAAY,SAEZF,IAAK,UAEFX,EAAQF,IACZQ,SACAN,EAAQY,UAET,KACHX,GAAWW,YAIpB"}
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":["CustomForm","form","sx","onSubmit","children","handleSubmit","_jsx","FormProvider","Box","component","display","gap"],"mappings":"2LA2BA,SAASA,GAAkCC,KACzCA,EAAIC,GACJA,EAAK,CAAA,EAAEC,SACPA,EAAQC,SACRA,IAEA,MAAMC,aAAEA,GAAiBJ,EAEzB,OACEK,EAACC,EAAY,IAAKN,EAAIG,SACpBE,EAACE,EAAG,CACFC,UAAU,OACVP,GAAI,CACFQ,QAAS,OAETC,IAAK,UAEFT,GAELC,SAAUE,EAAaF,GAASC,SAC/BA,KAIT"}
@@ -1,2 +1,2 @@
1
- import{jsx as e}from"react/jsx-runtime";import*as o from"react";import{useFormContext as r,Controller as m}from"../../node_modules/react-hook-form/dist/index.esm.js";import t from"../../node_modules/@mui/material/esm/TextField/TextField.js";function i(i){const{name:s}=i,d=o.useId(),{control:n}=r();return e(m,{name:s,control:n,render:({field:o})=>e(t,{id:d,...i,...o,size:"small"})})}export{i as default};
1
+ import{jsx as e}from"react/jsx-runtime";import*as o from"react";import{useFormContext as t,Controller as r}from"../../node_modules/react-hook-form/dist/index.esm.js";import n from"../text-field/text-field.js";function m(m){const{name:a,type:i}=m,s=o.useId(),{control:d}=t();return e(r,{name:a,control:d,render:({field:o})=>e(n,{id:s,...m,...o,onChange:e=>{const{target:t}=e,{value:r}=t;if("number"===i)""===r?o.onChange():o.onChange(Number(r));else o.onChange(e)}})})}export{m as default};
2
2
  //# sourceMappingURL=input.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"input.js","sources":["../../../../src/components/input/input.tsx"],"sourcesContent":["import * as React from 'react';\r\nimport { TextField } from '@mui/material';\r\nimport { Controller, useFormContext } from 'react-hook-form';\r\n\r\nimport { CustomInputProps } from './types';\r\n\r\nfunction CustomInput<T>(props: CustomInputProps<T>) {\r\n const { name } = 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 return (\r\n <TextField id={textFieldId} {...props} {...field} size=\"small\" />\r\n );\r\n }}\r\n />\r\n );\r\n}\r\n\r\nexport default CustomInput;\r\n"],"names":["CustomInput","props","name","textFieldId","React","useId","control","useFormContext","_jsx","Controller","render","field","TextField","id","size"],"mappings":"iPAMA,SAASA,EAAeC,GACtB,MAAMC,KAAEA,GAASD,EAEXE,EAAcC,EAAMC,SAEpBC,QAAEA,GAAYC,IAEpB,OACEC,EAACC,GACCP,KAAMA,EACNI,QAASA,EACTI,OAAQ,EAAGC,WAEPH,EAACI,EAAS,CAACC,GAAIV,KAAiBF,KAAWU,EAAOG,KAAK,WAKjE"}
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":["CustomInput","props","name","type","textFieldId","React","useId","control","useFormContext","_jsx","Controller","render","field","TextField","id","onChange","event","target","value","Number"],"mappings":"iNAOA,SAASA,EAAeC,GACtB,MAAMC,KAAEA,EAAIC,KAAEA,GAASF,EAEjBG,EAAcC,EAAMC,SAEpBC,QAAEA,GAAYC,IAEpB,OACEC,EAACC,EAAU,CACTR,KAAMA,EACNK,QAASA,EACTI,OAAQ,EAAGC,WACTH,EAACI,EAAS,CACRC,GAAIV,KACAH,KACAW,EACJG,SAAWC,IACT,MAAMC,OAAEA,GAAWD,GAEbE,MAAEA,GAAUD,EAElB,GACO,WADCd,EAEU,KAAVe,EACFN,EAAMG,WAENH,EAAMG,SAASI,OAAOD,SAOxBN,EAAMG,SAASC,OAQ/B"}
@@ -0,0 +1,2 @@
1
+ import{jsx as e}from"react/jsx-runtime";import m from"../../node_modules/@mui/material/esm/TextField/TextField.js";const t=t=>e(m,{size:"small",...t});export{t as default};
2
+ //# 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":["CustomTextField","props","_jsx","TextField","size"],"mappings":"mHAKA,MAAMA,EAAmDC,GAChDC,EAACC,EAAS,CAACC,KAAK,WAAYH"}
@@ -1 +1 @@
1
- {"version":3,"file":"delete.stories.d.ts","sourceRoot":"","sources":["../../../../../../src/components/buttons/delete/delete.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEvD,OAAO,EAAE,YAAY,EAAE,MAAM,GAAG,CAAC;AAEjC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,YAAY,CAUnC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAErB,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,KAS9B,CAAC"}
1
+ {"version":3,"file":"delete.stories.d.ts","sourceRoot":"","sources":["../../../../../../src/components/buttons/delete/delete.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAGvD,OAAO,EAAE,YAAY,EAAE,MAAM,GAAG,CAAC;AAEjC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,YAAY,CAYnC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,IAAI,CAAC,CAAC;AAEnC,eAAO,MAAM,OAAO,EAAE,KAErB,CAAC;AAEF,eAAO,MAAM,gBAAgB,EAAE,KAS9B,CAAC"}
@@ -1,21 +1,9 @@
1
- import * as React from 'react';
2
1
  import { SxProps } from '@mui/material';
3
2
  import { FieldValues, SubmitHandler, UseFormReturn } from 'react-hook-form';
4
3
  interface CustomFormProp<T extends FieldValues> {
5
4
  form: UseFormReturn<T>;
6
5
  onSubmit: SubmitHandler<T>;
7
6
  sx?: SxProps;
8
- fields: {
9
- content: React.ReactNode;
10
- sx?: SxProps;
11
- };
12
- buttons?: {
13
- content?: React.ReactNode;
14
- sx?: SxProps;
15
- };
16
- observers?: {
17
- content?: React.ReactNode;
18
- };
19
7
  }
20
8
  /**
21
9
  * Используем этот компонент как основную обертку для формы
@@ -28,6 +16,6 @@ interface CustomFormProp<T extends FieldValues> {
28
16
  *
29
17
  * @returns {JSX.Element} The rendered form component with form context.
30
18
  */
31
- declare function CustomForm<T extends FieldValues>({ form, sx, fields, buttons, observers, onSubmit, }: CustomFormProp<T>): import("react/jsx-runtime").JSX.Element;
19
+ declare function CustomForm<T extends FieldValues>({ form, sx, onSubmit, children, }: React.PropsWithChildren<CustomFormProp<T>>): import("react/jsx-runtime").JSX.Element;
32
20
  export default CustomForm;
33
21
  //# sourceMappingURL=form.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/form.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAO,OAAO,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EACL,WAAW,EAEX,aAAa,EACb,aAAa,EACd,MAAM,iBAAiB,CAAC;AAEzB,UAAU,cAAc,CAAC,CAAC,SAAS,WAAW;IAC5C,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;IAEvB,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;IAE3B,EAAE,CAAC,EAAE,OAAO,CAAC;IAEb,MAAM,EAAE;QACN,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;QACzB,EAAE,CAAC,EAAE,OAAO,CAAC;KACd,CAAC;IAEF,OAAO,CAAC,EAAE;QACR,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;QAC1B,EAAE,CAAC,EAAE,OAAO,CAAC;KACd,CAAC;IAEF,SAAS,CAAC,EAAE;QACV,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;KAC3B,CAAC;CACH;AAED;;;;;;;;;;GAUG;AACH,iBAAS,UAAU,CAAC,CAAC,SAAS,WAAW,EAAE,EACzC,IAAI,EACJ,EAAO,EACP,MAAM,EACN,OAAO,EACP,SAAS,EACT,QAAQ,GACT,EAAE,cAAc,CAAC,CAAC,CAAC,2CA4CnB;AAED,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"form.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/form.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAO,OAAO,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EACL,WAAW,EAEX,aAAa,EACb,aAAa,EACd,MAAM,iBAAiB,CAAC;AAEzB,UAAU,cAAc,CAAC,CAAC,SAAS,WAAW;IAC5C,IAAI,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;IAEvB,QAAQ,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC;IAE3B,EAAE,CAAC,EAAE,OAAO,CAAC;CACd;AAED;;;;;;;;;;GAUG;AACH,iBAAS,UAAU,CAAC,CAAC,SAAS,WAAW,EAAE,EACzC,IAAI,EACJ,EAAO,EACP,QAAQ,EACR,QAAQ,GACT,EAAE,KAAK,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,2CAmB5C;AAED,eAAe,UAAU,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"form.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/form.stories.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAMvD,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC;AAEzB,KAAK,QAAQ,GAAG,OAAO,IAAI,CAAC;AAE5B,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,QAAQ,CAGxB,CAAC;AAMF,KAAK,KAAK,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAEhC,eAAO,MAAM,IAAI,EAAE,KAoClB,CAAC;AAEF,eAAe,IAAI,CAAC"}
1
+ {"version":3,"file":"form.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/form/form.stories.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAMvD,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC;AAEzB,KAAK,QAAQ,GAAG,OAAO,IAAI,CAAC;AAE5B,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,QAAQ,CAGxB,CAAC;AAOF,KAAK,KAAK,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAEhC,eAAO,MAAM,IAAI,EAAE,KAwDlB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -1,2 +1,3 @@
1
1
  export { default as Input } from './input';
2
+ export * from './types';
2
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,MAAM,SAAS,CAAC;AAC3C,cAAc,SAAS,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"input.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/input.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,iBAAS,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC,2CAkBjD;AAED,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"input.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/input.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAE3C,iBAAS,WAAW,CAAC,CAAC,EAAE,KAAK,EAAE,gBAAgB,CAAC,CAAC,CAAC,2CAyCjD;AAED,eAAe,WAAW,CAAC"}
@@ -1,6 +1,6 @@
1
- import { TextFieldProps } from '@mui/material';
2
1
  import { Path } from 'react-hook-form';
3
- export type CustomInputProps<T> = TextFieldProps & {
2
+ import { CustomTextFieldProps } from '../text-field';
3
+ export type CustomInputProps<T> = CustomTextFieldProps & {
4
4
  name: Path<T>;
5
5
  };
6
6
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAEvC,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,cAAc,GAAG;IACjD,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;CACf,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/components/input/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAEvC,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErD,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,oBAAoB,GAAG;IACvD,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;CACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { default as TextField } from './text-field';
2
+ export * from './types';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/components/text-field/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,SAAS,EAAE,MAAM,cAAc,CAAC;AACpD,cAAc,SAAS,CAAC"}
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ import { CustomTextFieldProps } from './types';
3
+ declare const CustomTextField: React.FC<CustomTextFieldProps>;
4
+ export default CustomTextField;
5
+ //# sourceMappingURL=text-field.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text-field.d.ts","sourceRoot":"","sources":["../../../../../src/components/text-field/text-field.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAG/B,OAAO,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAE/C,QAAA,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAEnD,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { TextFieldProps } from '@mui/material';
2
+ export type CustomTextFieldProps = TextFieldProps & {};
3
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../src/components/text-field/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,MAAM,MAAM,oBAAoB,GAAG,cAAc,GAAG,EAAE,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dartcom/ui-kit",
3
- "version": "3.3.1",
3
+ "version": "3.4.0",
4
4
  "description": "Кастомная библиотека комопнентов Dartcom",
5
5
  "type": "module",
6
6
  "main": "dist/cjs/index.js",