@dilicorp/ui 0.0.1

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 (228) hide show
  1. package/dist/atoms/button.d.ts +15 -0
  2. package/dist/atoms/button.d.ts.map +1 -0
  3. package/dist/atoms/button.js +31 -0
  4. package/dist/atoms/checkbox.d.ts +8 -0
  5. package/dist/atoms/checkbox.d.ts.map +1 -0
  6. package/dist/atoms/checkbox.js +17 -0
  7. package/dist/atoms/col.d.ts +8 -0
  8. package/dist/atoms/col.d.ts.map +1 -0
  9. package/dist/atoms/col.js +22 -0
  10. package/dist/atoms/container.d.ts +6 -0
  11. package/dist/atoms/container.d.ts.map +1 -0
  12. package/dist/atoms/container.js +18 -0
  13. package/dist/atoms/icon.d.ts +8 -0
  14. package/dist/atoms/icon.d.ts.map +1 -0
  15. package/dist/atoms/icon.js +10 -0
  16. package/dist/atoms/image.d.ts +12 -0
  17. package/dist/atoms/image.d.ts.map +1 -0
  18. package/dist/atoms/image.js +49 -0
  19. package/dist/atoms/input.d.ts +14 -0
  20. package/dist/atoms/input.d.ts.map +1 -0
  21. package/dist/atoms/input.js +48 -0
  22. package/dist/atoms/label.d.ts +8 -0
  23. package/dist/atoms/label.d.ts.map +1 -0
  24. package/dist/atoms/label.js +18 -0
  25. package/dist/atoms/link.d.ts +4 -0
  26. package/dist/atoms/link.d.ts.map +1 -0
  27. package/dist/atoms/link.js +27 -0
  28. package/dist/atoms/radio.d.ts +8 -0
  29. package/dist/atoms/radio.d.ts.map +1 -0
  30. package/dist/atoms/radio.js +17 -0
  31. package/dist/atoms/row.d.ts +9 -0
  32. package/dist/atoms/row.d.ts.map +1 -0
  33. package/dist/atoms/row.js +7 -0
  34. package/dist/atoms/separator.d.ts +6 -0
  35. package/dist/atoms/separator.d.ts.map +1 -0
  36. package/dist/atoms/separator.js +6 -0
  37. package/dist/atoms/spinner.d.ts +6 -0
  38. package/dist/atoms/spinner.d.ts.map +1 -0
  39. package/dist/atoms/spinner.js +5 -0
  40. package/dist/atoms/typography.d.ts +10 -0
  41. package/dist/atoms/typography.d.ts.map +1 -0
  42. package/dist/atoms/typography.js +18 -0
  43. package/dist/components/form-builder/_partials/form-group.d.ts +11 -0
  44. package/dist/components/form-builder/_partials/form-group.d.ts.map +1 -0
  45. package/dist/components/form-builder/_partials/form-group.js +13 -0
  46. package/dist/components/form-builder/components/button.d.ts +12 -0
  47. package/dist/components/form-builder/components/button.d.ts.map +1 -0
  48. package/dist/components/form-builder/components/button.js +20 -0
  49. package/dist/components/form-builder/components/checkbox.d.ts +15 -0
  50. package/dist/components/form-builder/components/checkbox.d.ts.map +1 -0
  51. package/dist/components/form-builder/components/checkbox.js +17 -0
  52. package/dist/components/form-builder/components/datepicker.d.ts +10 -0
  53. package/dist/components/form-builder/components/datepicker.d.ts.map +1 -0
  54. package/dist/components/form-builder/components/datepicker.js +17 -0
  55. package/dist/components/form-builder/components/dropzone.d.ts +16 -0
  56. package/dist/components/form-builder/components/dropzone.d.ts.map +1 -0
  57. package/dist/components/form-builder/components/dropzone.js +31 -0
  58. package/dist/components/form-builder/components/input.d.ts +18 -0
  59. package/dist/components/form-builder/components/input.d.ts.map +1 -0
  60. package/dist/components/form-builder/components/input.js +68 -0
  61. package/dist/components/form-builder/components/password.d.ts +10 -0
  62. package/dist/components/form-builder/components/password.d.ts.map +1 -0
  63. package/dist/components/form-builder/components/password.js +46 -0
  64. package/dist/components/form-builder/components/radio.d.ts +15 -0
  65. package/dist/components/form-builder/components/radio.d.ts.map +1 -0
  66. package/dist/components/form-builder/components/radio.js +21 -0
  67. package/dist/components/form-builder/components/select.d.ts +23 -0
  68. package/dist/components/form-builder/components/select.d.ts.map +1 -0
  69. package/dist/components/form-builder/components/select.js +19 -0
  70. package/dist/components/form-builder/form-builder-components-list.d.ts +11 -0
  71. package/dist/components/form-builder/form-builder-components-list.d.ts.map +1 -0
  72. package/dist/components/form-builder/form-builder-components-list.js +10 -0
  73. package/dist/components/form-builder/form-builder-element.d.ts +9 -0
  74. package/dist/components/form-builder/form-builder-element.d.ts.map +1 -0
  75. package/dist/components/form-builder/form-builder-element.js +26 -0
  76. package/dist/components/form-builder/form-builder.d.ts +9 -0
  77. package/dist/components/form-builder/form-builder.d.ts.map +1 -0
  78. package/dist/components/form-builder/form-builder.js +31 -0
  79. package/dist/components/form-builder/form-builder.types.d.ts +89 -0
  80. package/dist/components/form-builder/form-builder.types.d.ts.map +1 -0
  81. package/dist/components/form-builder/form-builder.types.js +1 -0
  82. package/dist/components/form-builder/utils/form-builder-helper.d.ts +18 -0
  83. package/dist/components/form-builder/utils/form-builder-helper.d.ts.map +1 -0
  84. package/dist/components/form-builder/utils/form-builder-helper.js +48 -0
  85. package/dist/components/form-builder/utils/form-builder-item-helper.d.ts +9 -0
  86. package/dist/components/form-builder/utils/form-builder-item-helper.d.ts.map +1 -0
  87. package/dist/components/form-builder/utils/form-builder-item-helper.js +18 -0
  88. package/dist/components/navbar/navbar.d.ts +9 -0
  89. package/dist/components/navbar/navbar.d.ts.map +1 -0
  90. package/dist/components/navbar/navbar.js +14 -0
  91. package/dist/components/page/filter-components/button-filter-clear.d.ts +12 -0
  92. package/dist/components/page/filter-components/button-filter-clear.d.ts.map +1 -0
  93. package/dist/components/page/filter-components/button-filter-clear.js +22 -0
  94. package/dist/components/page/filter-components/button-filter.d.ts +9 -0
  95. package/dist/components/page/filter-components/button-filter.d.ts.map +1 -0
  96. package/dist/components/page/filter-components/button-filter.js +11 -0
  97. package/dist/components/page/filter-components/button-filters.d.ts +10 -0
  98. package/dist/components/page/filter-components/button-filters.d.ts.map +1 -0
  99. package/dist/components/page/filter-components/button-filters.js +14 -0
  100. package/dist/components/page/filter-components/filter-form.d.ts +10 -0
  101. package/dist/components/page/filter-components/filter-form.d.ts.map +1 -0
  102. package/dist/components/page/filter-components/filter-form.js +26 -0
  103. package/dist/components/page/filters/filter-datepicker.d.ts +9 -0
  104. package/dist/components/page/filters/filter-datepicker.d.ts.map +1 -0
  105. package/dist/components/page/filters/filter-datepicker.js +11 -0
  106. package/dist/components/page/filters/filter-input.d.ts +10 -0
  107. package/dist/components/page/filters/filter-input.d.ts.map +1 -0
  108. package/dist/components/page/filters/filter-input.js +34 -0
  109. package/dist/components/page/filters/filter-select.d.ts +20 -0
  110. package/dist/components/page/filters/filter-select.d.ts.map +1 -0
  111. package/dist/components/page/filters/filter-select.js +29 -0
  112. package/dist/components/page/filters/index.d.ts +4 -0
  113. package/dist/components/page/filters/index.d.ts.map +1 -0
  114. package/dist/components/page/filters/index.js +3 -0
  115. package/dist/components/page/page-list-filters.d.ts +7 -0
  116. package/dist/components/page/page-list-filters.d.ts.map +1 -0
  117. package/dist/components/page/page-list-filters.js +4 -0
  118. package/dist/components/page/page-list-get-filters.d.ts +13 -0
  119. package/dist/components/page/page-list-get-filters.d.ts.map +1 -0
  120. package/dist/components/page/page-list-get-filters.js +41 -0
  121. package/dist/components/page/page-list.d.ts +33 -0
  122. package/dist/components/page/page-list.d.ts.map +1 -0
  123. package/dist/components/page/page-list.js +34 -0
  124. package/dist/components/page-create/page-create.d.ts +16 -0
  125. package/dist/components/page-create/page-create.d.ts.map +1 -0
  126. package/dist/components/page-create/page-create.js +16 -0
  127. package/dist/components/page-list/filter-components/button-filter-clear.d.ts +12 -0
  128. package/dist/components/page-list/filter-components/button-filter-clear.d.ts.map +1 -0
  129. package/dist/components/page-list/filter-components/button-filter-clear.js +22 -0
  130. package/dist/components/page-list/filter-components/button-filter.d.ts +9 -0
  131. package/dist/components/page-list/filter-components/button-filter.d.ts.map +1 -0
  132. package/dist/components/page-list/filter-components/button-filter.js +11 -0
  133. package/dist/components/page-list/filter-components/button-filters.d.ts +10 -0
  134. package/dist/components/page-list/filter-components/button-filters.d.ts.map +1 -0
  135. package/dist/components/page-list/filter-components/button-filters.js +14 -0
  136. package/dist/components/page-list/filter-components/filter-form.d.ts +10 -0
  137. package/dist/components/page-list/filter-components/filter-form.d.ts.map +1 -0
  138. package/dist/components/page-list/filter-components/filter-form.js +26 -0
  139. package/dist/components/page-list/filters/filter-datepicker.d.ts +9 -0
  140. package/dist/components/page-list/filters/filter-datepicker.d.ts.map +1 -0
  141. package/dist/components/page-list/filters/filter-datepicker.js +11 -0
  142. package/dist/components/page-list/filters/filter-input.d.ts +10 -0
  143. package/dist/components/page-list/filters/filter-input.d.ts.map +1 -0
  144. package/dist/components/page-list/filters/filter-input.js +34 -0
  145. package/dist/components/page-list/filters/filter-select.d.ts +20 -0
  146. package/dist/components/page-list/filters/filter-select.d.ts.map +1 -0
  147. package/dist/components/page-list/filters/filter-select.js +29 -0
  148. package/dist/components/page-list/filters/index.d.ts +4 -0
  149. package/dist/components/page-list/filters/index.d.ts.map +1 -0
  150. package/dist/components/page-list/filters/index.js +3 -0
  151. package/dist/components/page-list/page-list-filters.d.ts +7 -0
  152. package/dist/components/page-list/page-list-filters.d.ts.map +1 -0
  153. package/dist/components/page-list/page-list-filters.js +4 -0
  154. package/dist/components/page-list/page-list-get-filters.d.ts +13 -0
  155. package/dist/components/page-list/page-list-get-filters.d.ts.map +1 -0
  156. package/dist/components/page-list/page-list-get-filters.js +47 -0
  157. package/dist/components/page-list/page-list.d.ts +35 -0
  158. package/dist/components/page-list/page-list.d.ts.map +1 -0
  159. package/dist/components/page-list/page-list.js +38 -0
  160. package/dist/components/side-navigation-bar/side-navigation-bar-item.d.ts +8 -0
  161. package/dist/components/side-navigation-bar/side-navigation-bar-item.d.ts.map +1 -0
  162. package/dist/components/side-navigation-bar/side-navigation-bar-item.js +26 -0
  163. package/dist/components/side-navigation-bar/side-navigation-bar.d.ts +13 -0
  164. package/dist/components/side-navigation-bar/side-navigation-bar.d.ts.map +1 -0
  165. package/dist/components/side-navigation-bar/side-navigation-bar.js +28 -0
  166. package/dist/components/tabs/tab-list.d.ts +6 -0
  167. package/dist/components/tabs/tab-list.d.ts.map +1 -0
  168. package/dist/components/tabs/tab-list.js +4 -0
  169. package/dist/components/tabs/tab-panel.d.ts +7 -0
  170. package/dist/components/tabs/tab-panel.d.ts.map +1 -0
  171. package/dist/components/tabs/tab-panel.js +6 -0
  172. package/dist/components/tabs/tab.d.ts +7 -0
  173. package/dist/components/tabs/tab.d.ts.map +1 -0
  174. package/dist/components/tabs/tab.js +7 -0
  175. package/dist/components/tabs/tabs.d.ts +11 -0
  176. package/dist/components/tabs/tabs.d.ts.map +1 -0
  177. package/dist/components/tabs/tabs.js +33 -0
  178. package/dist/css/style.min.css +6 -0
  179. package/dist/index.d.ts +39 -0
  180. package/dist/index.d.ts.map +1 -0
  181. package/dist/index.js +43 -0
  182. package/dist/molecules/alert.d.ts +16 -0
  183. package/dist/molecules/alert.d.ts.map +1 -0
  184. package/dist/molecules/alert.js +24 -0
  185. package/dist/molecules/breadcrumb.d.ts +9 -0
  186. package/dist/molecules/breadcrumb.d.ts.map +1 -0
  187. package/dist/molecules/breadcrumb.js +11 -0
  188. package/dist/molecules/card.d.ts +10 -0
  189. package/dist/molecules/card.d.ts.map +1 -0
  190. package/dist/molecules/card.js +13 -0
  191. package/dist/molecules/dropdown/dropdown-item.d.ts +14 -0
  192. package/dist/molecules/dropdown/dropdown-item.d.ts.map +1 -0
  193. package/dist/molecules/dropdown/dropdown-item.js +19 -0
  194. package/dist/molecules/dropdown/dropdown.d.ts +12 -0
  195. package/dist/molecules/dropdown/dropdown.d.ts.map +1 -0
  196. package/dist/molecules/dropdown/dropdown.js +34 -0
  197. package/dist/molecules/paginate.d.ts +8 -0
  198. package/dist/molecules/paginate.d.ts.map +1 -0
  199. package/dist/molecules/paginate.js +30 -0
  200. package/dist/molecules/table.d.ts +43 -0
  201. package/dist/molecules/table.d.ts.map +1 -0
  202. package/dist/molecules/table.js +38 -0
  203. package/dist/utils/date-helper.d.ts +14 -0
  204. package/dist/utils/date-helper.d.ts.map +1 -0
  205. package/dist/utils/date-helper.js +46 -0
  206. package/dist/utils/number-helper.d.ts +9 -0
  207. package/dist/utils/number-helper.d.ts.map +1 -0
  208. package/dist/utils/number-helper.js +25 -0
  209. package/dist/utils/object-helper.d.ts +9 -0
  210. package/dist/utils/object-helper.d.ts.map +1 -0
  211. package/dist/utils/object-helper.js +26 -0
  212. package/dist/utils/storage-helper.d.ts +8 -0
  213. package/dist/utils/storage-helper.d.ts.map +1 -0
  214. package/dist/utils/storage-helper.js +17 -0
  215. package/dist/utils/string-helper.d.ts +10 -0
  216. package/dist/utils/string-helper.d.ts.map +1 -0
  217. package/dist/utils/string-helper.js +30 -0
  218. package/dist/utils/uri-helper.d.ts +11 -0
  219. package/dist/utils/uri-helper.d.ts.map +1 -0
  220. package/dist/utils/uri-helper.js +21 -0
  221. package/dist/utils/validations-helper.d.ts +6 -0
  222. package/dist/utils/validations-helper.d.ts.map +1 -0
  223. package/dist/utils/validations-helper.js +7 -0
  224. package/dist/utils/yup-helper.d.ts +3 -0
  225. package/dist/utils/yup-helper.d.ts.map +1 -0
  226. package/dist/utils/yup-helper.js +2 -0
  227. package/package.json +88 -0
  228. package/tsconfig.json +28 -0
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { FastField } from 'formik';
3
+ export default function Checkbox(props) {
4
+ const { name, actions, value, options, id = name, tabIndex = 0, disabled } = props;
5
+ if (!options.length)
6
+ return null;
7
+ const curValue = actions.values[name] || value;
8
+ const isChecked = (option) => {
9
+ const sanitized = curValue.map((value) => (value).toString());
10
+ return ({
11
+ checked: sanitized.includes((option.value).toString())
12
+ });
13
+ };
14
+ return options.map((option, index) => (React.createElement("div", { className: "form-check", key: `${name}-${index}` },
15
+ React.createElement(FastField, Object.assign({ value: option.value, name: name, id: `${id}-${index}` }, isChecked(option), { disabled }, { className: "form-check-input", type: "checkbox", tabIndex: tabIndex })),
16
+ React.createElement("label", { className: "form-check-label", htmlFor: `${id}-${index}` }, option.label))));
17
+ }
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { FormikProps } from 'formik';
3
+ declare type Props = {
4
+ name: string;
5
+ actions: FormikProps<any>;
6
+ value?: string;
7
+ };
8
+ export default function DatePicker(props: Props): JSX.Element;
9
+ export {};
10
+ //# sourceMappingURL=datepicker.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"datepicker.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/datepicker.tsx"],"names":[],"mappings":";AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAA;AAGpC,aAAK,KAAK,GAAG;IACX,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAA;AAKD,MAAM,CAAC,OAAO,UAAU,UAAU,CAAE,KAAK,EAAE,KAAK,eAwB/C"}
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import DateP, { registerLocale } from 'react-datepicker';
3
+ import ptBr from 'date-fns/locale/pt-BR';
4
+ import dateHelper from '../../../utils/date-helper';
5
+ registerLocale('pt_br', ptBr);
6
+ // example use https://reactdatepicker.com
7
+ export default function DatePicker(props) {
8
+ const { name, actions, value } = props;
9
+ const [date, setDate] = React.useState(dateHelper.stringToDate(value));
10
+ const handleDateSelect = (currentDate) => {
11
+ if (actions.setFieldValue) {
12
+ actions.setFieldValue(name, dateHelper.dateToString(currentDate));
13
+ setDate(currentDate);
14
+ }
15
+ };
16
+ return (React.createElement(DateP, { locale: "pt_br", className: "form-control", selected: date, onChange: handleDateSelect, dateFormat: "dd/MM/yyyy" }));
17
+ }
@@ -0,0 +1,16 @@
1
+ /// <reference types="react" />
2
+ import { DropzoneOptions } from 'react-dropzone';
3
+ import { FormikProps } from 'formik';
4
+ declare type Props = {
5
+ name: string;
6
+ id?: string;
7
+ actions: FormikProps<any>;
8
+ dropzoneOptions?: DropzoneOptions;
9
+ textFileSelect?: string;
10
+ textFileSelected?: string;
11
+ LabelAcceptedFile?: string;
12
+ labelFileRejection?: string;
13
+ };
14
+ export default function DropZone(props: Props): JSX.Element;
15
+ export {};
16
+ //# sourceMappingURL=dropzone.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropzone.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/dropzone.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,eAAe,EAAe,MAAM,gBAAgB,CAAA;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAA;AAEpC,aAAK,KAAK,GAAG;IACX,IAAI,EAAE,MAAM,CAAA;IACZ,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,eAAe,CAAC,EAAE,eAAe,CAAA;IACjC,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAA;CAC5B,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAE,KAAK,EAAE,KAAK,eA+D7C"}
@@ -0,0 +1,31 @@
1
+ import React from 'react';
2
+ import { useDropzone } from 'react-dropzone';
3
+ export default function DropZone(props) {
4
+ const { name, id = name, actions, dropzoneOptions, textFileSelect = 'Drop the files here ...', textFileSelected = 'Drag \'n\' drop some files here, or click to select files', labelFileRejection = 'Rejected files' } = props;
5
+ const onDrop = React.useCallback((acceptedFiles, rejectedFiles, event) => {
6
+ actions.setFieldValue(name, acceptedFiles);
7
+ if (dropzoneOptions === null || dropzoneOptions === void 0 ? void 0 : dropzoneOptions.onDrop) {
8
+ dropzoneOptions.onDrop(acceptedFiles, rejectedFiles, event);
9
+ }
10
+ }, []);
11
+ const { acceptedFiles, fileRejections, getRootProps, getInputProps, isDragActive } = useDropzone(Object.assign(Object.assign({}, dropzoneOptions), { onDrop, multiple: (dropzoneOptions === null || dropzoneOptions === void 0 ? void 0 : dropzoneOptions.multiple) || false }));
12
+ return (React.createElement("div", { className: "dropzone-container" },
13
+ React.createElement("div", Object.assign({}, getRootProps({ className: 'dropzone' })),
14
+ React.createElement("input", Object.assign({}, getInputProps({ name, id }))),
15
+ isDragActive
16
+ ? React.createElement("p", null, textFileSelect)
17
+ : React.createElement("p", null, textFileSelected)),
18
+ !!acceptedFiles.length && (React.createElement("ul", null, acceptedFiles.map(file => (React.createElement("li", { key: file.path },
19
+ file.path,
20
+ " - ",
21
+ file.size,
22
+ " bytes"))))),
23
+ !!fileRejections.length && (React.createElement(React.Fragment, null,
24
+ React.createElement("h3", null, labelFileRejection),
25
+ React.createElement("ul", null, fileRejections.map(({ file, errors }) => (React.createElement("li", { key: file.path },
26
+ file.path,
27
+ " - ",
28
+ file.size,
29
+ " bytes",
30
+ React.createElement("ul", null, errors.map(e => (React.createElement("li", { key: e.code }, e.message))))))))))));
31
+ }
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ import { FormikProps } from 'formik';
3
+ declare type Props = React.InputHTMLAttributes<HTMLInputElement> & {
4
+ name: string;
5
+ actions: FormikProps<any>;
6
+ type?: string;
7
+ value?: string;
8
+ mask?: string | Array<string | RegExp>;
9
+ onChange?: any;
10
+ multiple?: boolean;
11
+ currency?: {
12
+ locale: string;
13
+ format: string;
14
+ };
15
+ };
16
+ export default function Input(props: Props): JSX.Element;
17
+ export {};
18
+ //# sourceMappingURL=input.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"input.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/input.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAa,WAAW,EAAE,MAAM,QAAQ,CAAA;AAM/C,aAAK,KAAK,GAAG,KAAK,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,GAAG;IACzD,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,GAAC,KAAK,CAAC,MAAM,GAAC,MAAM,CAAC,CAAA;IAClC,QAAQ,CAAC,EAAE,GAAG,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE;QACT,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAA;KACf,CAAA;CACF,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,KAAK,CAAE,KAAK,EAAE,KAAK,eAiG1C"}
@@ -0,0 +1,68 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { FastField } from 'formik';
14
+ import InputMask from 'react-input-mask';
15
+ import classNames from 'classnames';
16
+ import numberHelper from '../../../utils/number-helper';
17
+ export default function Input(props) {
18
+ const { name, id = name, type = 'text', tabIndex = 0, actions, value = '', mask, multiple = false, currency, className } = props, elements = __rest(props, ["name", "id", "type", "tabIndex", "actions", "value", "mask", "multiple", "currency", "className"]);
19
+ const validOptions = {
20
+ alt: elements.alt,
21
+ autoComplete: elements.autoComplete,
22
+ autoFocus: elements.autoFocus,
23
+ checked: elements.checked,
24
+ disabled: elements.disabled,
25
+ max: elements.max,
26
+ maxLength: elements.maxLength,
27
+ min: elements.min,
28
+ minLength: elements.minLength,
29
+ placeholder: elements.placeholder,
30
+ readOnly: elements.readOnly,
31
+ required: elements.required
32
+ };
33
+ const handleChange = (event) => {
34
+ if (elements.onChange) {
35
+ elements.onChange({
36
+ currentTarget: Object.assign(Object.assign({}, event.currentTarget), { name })
37
+ });
38
+ }
39
+ if (actions.setFieldValue) {
40
+ actions.setFieldValue(name, event.currentTarget.value);
41
+ }
42
+ };
43
+ const curValue = actions.values[name] || value;
44
+ const classes = classNames(className, 'form-control');
45
+ const attrs = Object.assign(Object.assign({}, validOptions), { value: curValue, className: classes, name,
46
+ id,
47
+ type,
48
+ tabIndex, readOnly: true, autoComplete: 'none', onFocus: (event) => {
49
+ event.currentTarget.readOnly = false;
50
+ }, onChange: handleChange });
51
+ if (currency) {
52
+ const handleChangeCurrency = (event) => {
53
+ const { value } = event.currentTarget;
54
+ const sanitize = numberHelper.currencySanitize(value);
55
+ handleChange({
56
+ currentTarget: {
57
+ name,
58
+ value: sanitize ? numberHelper.currency(Number(sanitize), currency.locale, currency.format) : ''
59
+ }
60
+ });
61
+ };
62
+ return (React.createElement(FastField, { name: name }, ({ field }) => React.createElement("input", Object.assign({}, field, attrs, { onChange: handleChangeCurrency, min: "0", maxLength: 20 }))));
63
+ }
64
+ if (mask) {
65
+ return (React.createElement(FastField, { name: name }, ({ field }) => React.createElement(InputMask, Object.assign({}, field, attrs, { mask: mask }))));
66
+ }
67
+ return (React.createElement(FastField, Object.assign({}, attrs, { as: multiple ? 'textarea' : 'input' })));
68
+ }
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { FormikProps } from 'formik';
3
+ declare type Props = React.InputHTMLAttributes<HTMLInputElement> & {
4
+ name: string;
5
+ actions: FormikProps<any>;
6
+ labelButton?: string;
7
+ };
8
+ export default function Password(props: Props): JSX.Element;
9
+ export {};
10
+ //# sourceMappingURL=password.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"password.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/password.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAS,WAAW,EAAE,MAAM,QAAQ,CAAA;AAE3C,aAAK,KAAK,GAAG,KAAK,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,GAAG;IACzD,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,QAAQ,CAAE,KAAK,EAAE,KAAK,eA+D7C"}
@@ -0,0 +1,46 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { Field } from 'formik';
14
+ export default function Password(props) {
15
+ const { name, id = name, tabIndex = 0, actions, labelButton = 'show' } = props, elements = __rest(props, ["name", "id", "tabIndex", "actions", "labelButton"]);
16
+ const validOptions = {
17
+ alt: elements.alt,
18
+ autoComplete: elements.autoComplete,
19
+ autoFocus: elements.autoFocus,
20
+ checked: elements.checked,
21
+ disabled: elements.disabled,
22
+ max: elements.max,
23
+ maxLength: elements.maxLength,
24
+ min: elements.min,
25
+ minLength: elements.minLength,
26
+ multiple: elements.multiple,
27
+ placeholder: elements.placeholder,
28
+ readOnly: elements.readOnly,
29
+ required: elements.required
30
+ };
31
+ const [visible, setVisible] = React.useState(false);
32
+ const handleVisible = () => {
33
+ setVisible(prev => !prev);
34
+ };
35
+ const handleChange = (event) => {
36
+ if (actions.setFieldValue) {
37
+ actions.setFieldValue(name, event.currentTarget.value);
38
+ }
39
+ };
40
+ const handleFocus = (event) => {
41
+ event.currentTarget.readOnly = false;
42
+ };
43
+ return (React.createElement("div", { className: "position-relative" },
44
+ React.createElement("div", { role: "button", className: `form-password-button${visible ? ' visible' : ''}`, onClick: handleVisible }, labelButton),
45
+ React.createElement(Field, Object.assign({}, validOptions, { type: visible ? 'text' : 'password', className: "form-control", name: name, id: id, tabIndex: tabIndex, onChange: handleChange, readOnly: true, autoComplete: "off", onFocus: handleFocus }))));
46
+ }
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ import { FormikProps } from 'formik';
3
+ declare type Option = {
4
+ label: string | number;
5
+ value: string | number;
6
+ };
7
+ declare type Props = React.InputHTMLAttributes<HTMLInputElement> & {
8
+ name: string;
9
+ actions: FormikProps<any>;
10
+ value?: string;
11
+ options: Option[];
12
+ };
13
+ export default function Radio(props: Props): JSX.Element[] | null;
14
+ export {};
15
+ //# sourceMappingURL=radio.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/radio.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAa,WAAW,EAAE,MAAM,QAAQ,CAAA;AAE/C,aAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,GAAC,MAAM,CAAA;IACpB,KAAK,EAAE,MAAM,GAAC,MAAM,CAAA;CACrB,CAAA;AAED,aAAK,KAAK,GAAG,KAAK,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,GAAG;IACzD,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,OAAO,EAAE,MAAM,EAAE,CAAA;CAClB,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,KAAK,CAAE,KAAK,EAAE,KAAK,wBA2C1C"}
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ import { FastField } from 'formik';
3
+ export default function Radio(props) {
4
+ const { name, actions, value, options, id = name, tabIndex = 0, disabled } = props;
5
+ if (!options.length)
6
+ return null;
7
+ const curValue = actions.values[name] || value;
8
+ const isChecked = (option) => {
9
+ return ({
10
+ checked: (option.value).toString() === (curValue).toString()
11
+ });
12
+ };
13
+ const handleChange = (event) => {
14
+ if (actions.setFieldValue) {
15
+ actions.setFieldValue(name, event.currentTarget.value);
16
+ }
17
+ };
18
+ return options.map((option, index) => (React.createElement("div", { className: "form-check", key: `${name}-${index}` },
19
+ React.createElement(FastField, Object.assign({ value: option.value, name: name, id: `${id}-${index}` }, isChecked(option), { disabled }, { type: "radio", tabIndex: tabIndex, className: "form-check-input", onChange: handleChange })),
20
+ React.createElement("label", { className: "form-check-label", htmlFor: `${id}-${index}` }, option.label))));
21
+ }
@@ -0,0 +1,23 @@
1
+ /// <reference types="react" />
2
+ import { FormikProps } from 'formik';
3
+ declare type Option = {
4
+ label: string | number;
5
+ value: string | number;
6
+ };
7
+ declare type Props = {
8
+ name: string;
9
+ actions: FormikProps<any>;
10
+ options?: Option[];
11
+ id?: string;
12
+ value?: Option | Option[];
13
+ placeholder?: string;
14
+ isDisabled?: boolean;
15
+ isLoading?: boolean;
16
+ isClearable?: boolean;
17
+ isSearchable?: boolean;
18
+ isMulti?: boolean;
19
+ onChange?: any;
20
+ };
21
+ export default function Select(props: Props): JSX.Element;
22
+ export {};
23
+ //# sourceMappingURL=select.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/components/select.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAA;AAGpC,aAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,GAAC,MAAM,CAAA;IACpB,KAAK,EAAE,MAAM,GAAC,MAAM,CAAA;CACrB,CAAA;AAED,aAAK,KAAK,GAAG;IACX,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAA;IACzB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;IAClB,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,GAAC,MAAM,EAAE,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,QAAQ,CAAC,EAAE,GAAG,CAAA;CACf,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAE,KAAK,EAAE,KAAK,eA+C3C"}
@@ -0,0 +1,19 @@
1
+ import React, { useCallback, useState } from 'react';
2
+ import ReactSelect from 'react-select';
3
+ export default function Select(props) {
4
+ const { actions, options = [], name, id = name, value = null, placeholder, isDisabled = false, isLoading = false, isClearable = false, isSearchable = true, isMulti = false, onChange } = props;
5
+ const [currValue, setValue] = useState(value);
6
+ const handleChange = useCallback((newValue) => {
7
+ if (onChange) {
8
+ onChange({
9
+ currentTarget: {
10
+ value: newValue,
11
+ name
12
+ }
13
+ });
14
+ }
15
+ actions.setFieldValue(name, newValue);
16
+ setValue(newValue);
17
+ }, []);
18
+ return (React.createElement(ReactSelect, { placeholder: placeholder, className: "form-builder-select", classNamePrefix: "form-builder", options: options, name: name, id: id, defaultValue: currValue, isDisabled: isDisabled, isLoading: isLoading, isClearable: isClearable, isSearchable: isSearchable, isMulti: isMulti, onChange: handleChange }));
19
+ }
@@ -0,0 +1,11 @@
1
+ export declare const FormBuilderComponentsList: {
2
+ button: any;
3
+ checkbox: any;
4
+ datepicker: any;
5
+ dropzone: any;
6
+ input: any;
7
+ password: any;
8
+ radio: any;
9
+ select: any;
10
+ };
11
+ //# sourceMappingURL=form-builder-components-list.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-builder-components-list.d.ts","sourceRoot":"","sources":["../../../src/components/form-builder/form-builder-components-list.tsx"],"names":[],"mappings":"AAAA,eAAO,MAAM,yBAAyB;;;;;;;;;CASrC,CAAA"}
@@ -0,0 +1,10 @@
1
+ export const FormBuilderComponentsList = {
2
+ button: require('./components/button').default,
3
+ checkbox: require('./components/checkbox').default,
4
+ datepicker: require('./components/datepicker').default,
5
+ dropzone: require('./components/dropzone').default,
6
+ input: require('./components/input').default,
7
+ password: require('./components/password').default,
8
+ radio: require('./components/radio').default,
9
+ select: require('./components/select').default
10
+ };
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { FormikHelpers } from 'formik';
3
+ import { FormBuilderItem } from './form-builder.types';
4
+ declare type Props = FormBuilderItem & {
5
+ actions: FormikHelpers<any>;
6
+ };
7
+ export declare const FormBuilderElement: React.FC<Props>;
8
+ export {};
9
+ //# sourceMappingURL=form-builder-element.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-builder-element.d.ts","sourceRoot":"","sources":["../../../src/components/form-builder/form-builder-element.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAA;AAItD,aAAK,KAAK,GAAG,eAAe,GAAG;IAC7B,OAAO,EAAE,aAAa,CAAC,GAAG,CAAC,CAAA;CAC5B,CAAA;AAED,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,KAAK,CAuB9C,CAAA"}
@@ -0,0 +1,26 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { FormBuilderComponentsList } from './form-builder-components-list';
14
+ import { FormGroup } from './_partials/form-group';
15
+ export const FormBuilderElement = (props) => {
16
+ const { component, value, actions } = props, elements = __rest(props, ["component", "value", "actions"]);
17
+ const Component = (component && typeof component === 'object')
18
+ ? component
19
+ : (component != null
20
+ ? FormBuilderComponentsList[component]
21
+ : null);
22
+ if (!Component)
23
+ return null;
24
+ return (React.createElement(FormGroup, { name: props.name, title: props.title, validations: props.validations },
25
+ React.createElement(Component, Object.assign({}, elements, { value: value || '', actions: actions }))));
26
+ };
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ import { FormBuilderGroup } from './form-builder.types';
3
+ export declare type FormBuilderProps = {
4
+ data: FormBuilderGroup[];
5
+ onSubmit: any;
6
+ className?: string;
7
+ };
8
+ export declare const FormBuilder: React.FC<FormBuilderProps>;
9
+ //# sourceMappingURL=form-builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-builder.d.ts","sourceRoot":"","sources":["../../../src/components/form-builder/form-builder.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AAIvD,oBAAY,gBAAgB,GAAG;IAC7B,IAAI,EAAE,gBAAgB,EAAE,CAAA;IACxB,QAAQ,EAAE,GAAG,CAAA;IACb,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB,CAAA;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAuClD,CAAA"}
@@ -0,0 +1,31 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import React from 'react';
13
+ import { Form, Formik } from 'formik';
14
+ import { Row, Col, Typography } from '../../';
15
+ import { FormBuilderElement } from './form-builder-element';
16
+ import { FormBuilderHelper } from './utils/form-builder-helper';
17
+ export const FormBuilder = (props) => {
18
+ const { data, onSubmit, className } = props;
19
+ const options = Object.assign(Object.assign({ enableReinitialize: true }, FormBuilderHelper.init(data).build()), { onSubmit });
20
+ return (React.createElement("div", { className: "w-100" },
21
+ React.createElement(Formik, Object.assign({}, options), (actions) => (React.createElement(Form, { className: className }, data.map(({ name, customComponent: Component, items }, index) => (React.createElement("div", { key: index, className: "so-form-group" },
22
+ name && React.createElement(Typography, { tag: "h2", variant: "h5" }, name),
23
+ Boolean(Component) && Component,
24
+ React.createElement(Row, null, items
25
+ .filter(item => item === null || item === void 0 ? void 0 : item.component)
26
+ .map((_a) => {
27
+ var { column, columnClassName } = _a, item = __rest(_a, ["column", "columnClassName"]);
28
+ return (React.createElement(Col, { key: item.name, size: column || 12, className: columnClassName },
29
+ React.createElement(FormBuilderElement, Object.assign({}, item, { actions: actions }))));
30
+ }))))))))));
31
+ };
@@ -0,0 +1,89 @@
1
+ import { InputHTMLAttributes, ReactNode } from 'react';
2
+ import { DropzoneOptions } from 'react-dropzone';
3
+ declare type FormBuilderValidations = 'length' | 'min' | 'max' | 'matches' | 'email' | 'url' | 'uuid' | 'ensure' | 'trim' | 'lowercase' | 'uppercase' | 'nullable' | 'required' | 'defined' | 'notRequired' | 'oneOf' | 'equals';
4
+ declare type Option = {
5
+ label: string | number;
6
+ value: string | number;
7
+ };
8
+ declare type StringOrNumber = string | number;
9
+ declare type ColumnNumber = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
10
+ export declare type FormBuilderValidationProps = {
11
+ type: FormBuilderValidations;
12
+ params?: (StringOrNumber | RegExp)[];
13
+ };
14
+ interface FormBuilderBasicsItem extends InputHTMLAttributes<HTMLInputElement> {
15
+ name: string;
16
+ column?: ColumnNumber | ColumnNumber[];
17
+ columnClassName?: string;
18
+ title?: string;
19
+ placeholder?: string;
20
+ tabIndex?: number;
21
+ value?: StringOrNumber;
22
+ disabled?: boolean;
23
+ validations?: FormBuilderValidationProps[];
24
+ validationType?: string;
25
+ onChange?: any;
26
+ type?: string;
27
+ }
28
+ interface FormBuildItemInput extends FormBuilderBasicsItem {
29
+ component: 'input';
30
+ type?: 'text' | 'button' | 'checkbox' | 'email' | 'file' | 'hidden' | 'number' | 'submit' | 'reset' | 'color';
31
+ mask?: string;
32
+ multiple?: boolean;
33
+ currency?: {
34
+ locale: string;
35
+ format: string;
36
+ };
37
+ }
38
+ interface FormBuilderItemPassword extends FormBuilderBasicsItem {
39
+ component: 'password';
40
+ type?: 'password';
41
+ }
42
+ interface FormBuilderItemButton extends FormBuilderBasicsItem {
43
+ component: 'button';
44
+ type?: 'submit' | 'reset' | 'button';
45
+ color?: 'primary' | 'secondary' | 'success' | 'danger' | 'warning' | 'info';
46
+ label: string;
47
+ labelLoading?: string;
48
+ }
49
+ interface FormBuilderItemSelect extends Omit<FormBuilderBasicsItem, 'value'> {
50
+ component: 'select';
51
+ value?: Option | Option[];
52
+ options: Option[];
53
+ isDisabled?: boolean;
54
+ isLoading?: boolean;
55
+ isClearable?: boolean;
56
+ isSearchable?: boolean;
57
+ isMulti?: boolean;
58
+ }
59
+ interface FormBuilderItemDatePicker extends FormBuilderBasicsItem {
60
+ component?: 'datepicker';
61
+ }
62
+ interface FormBuilderItemDropZone extends FormBuilderBasicsItem {
63
+ component?: 'dropzone';
64
+ dropzoneOptions?: DropzoneOptions;
65
+ textFileSelect?: string;
66
+ textFileSelected?: string;
67
+ showAcceptedFile?: boolean;
68
+ LabelAcceptedFile?: string;
69
+ showFileRejection?: boolean;
70
+ labelFileRejection?: string;
71
+ }
72
+ interface FormBuilderItemRadio extends FormBuilderBasicsItem {
73
+ component?: 'radio';
74
+ value?: string;
75
+ options: Option[];
76
+ }
77
+ interface FormBuilderItemCheckbox extends Omit<FormBuilderBasicsItem, 'value'> {
78
+ component?: 'checkbox';
79
+ value?: string[];
80
+ options: Option[];
81
+ }
82
+ export declare type FormBuilderItem = FormBuildItemInput | FormBuilderItemPassword | FormBuilderItemButton | FormBuilderItemSelect | FormBuilderItemDropZone | FormBuilderItemDatePicker | FormBuilderItemRadio | FormBuilderItemCheckbox;
83
+ export declare type FormBuilderGroup = {
84
+ items: FormBuilderItem[];
85
+ name?: string;
86
+ customComponent?: ReactNode;
87
+ };
88
+ export {};
89
+ //# sourceMappingURL=form-builder.types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-builder.types.d.ts","sourceRoot":"","sources":["../../../src/components/form-builder/form-builder.types.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,18 @@
1
+ import * as Yup from 'yup';
2
+ import { FormikValues } from 'formik';
3
+ import { FormBuilderGroup } from '../form-builder.types';
4
+ export declare class FormBuilderHelper {
5
+ private readonly initialValues;
6
+ private readonly groups;
7
+ private fieldsWithValidations;
8
+ constructor(data: FormBuilderGroup[]);
9
+ private createYupSchema;
10
+ private validateSchema;
11
+ private mapper;
12
+ static init(data: FormBuilderGroup[]): FormBuilderHelper;
13
+ build(): {
14
+ initialValues: FormikValues;
15
+ validationSchema: Yup.ObjectSchema<any, import("yup/lib/object").AnyObject, import("yup/lib/object").TypeOfShape<any>, import("yup/lib/object").AssertsShape<any>>;
16
+ };
17
+ }
18
+ //# sourceMappingURL=form-builder-helper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-builder-helper.d.ts","sourceRoot":"","sources":["../../../../src/components/form-builder/utils/form-builder-helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,GAAG,MAAM,KAAK,CAAA;AAC1B,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAA;AACrC,OAAO,EAAE,gBAAgB,EAAmB,MAAM,uBAAuB,CAAA;AAEzE,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAc;IAC5C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAC3C,OAAO,CAAC,qBAAqB,CAAyB;gBAEzC,IAAI,EAAE,gBAAgB,EAAE;IAMrC,OAAO,CAAC,eAAe;IAiBvB,OAAO,CAAC,cAAc;IAKtB,OAAO,CAAC,MAAM;IAkBd,MAAM,CAAC,IAAI,CAAE,IAAI,EAAE,gBAAgB,EAAE;IAIrC,KAAK;;;;CAGN"}