@nvs-dynamic-form/react-core 2.0.0 → 2.2.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.
- package/dist/cjs/nvs-dynamic-form/_style.css +5 -0
- package/dist/cjs/nvs-dynamic-form/_template.d.ts +1 -1
- package/dist/cjs/nvs-dynamic-form/_template.js +3 -1
- package/dist/cjs/nvs-dynamic-form/_template.js.map +1 -1
- package/dist/cjs/nvs-dynamic-form/_type.d.ts +6 -3
- package/dist/cjs/nvs-dynamic-form/elements/arrayField/_template.d.ts +1 -1
- package/dist/cjs/nvs-dynamic-form/elements/arrayField/_template.js +39 -7
- package/dist/cjs/nvs-dynamic-form/elements/arrayField/_template.js.map +1 -1
- package/dist/cjs/nvs-dynamic-form/elements/arrayField/_type.d.ts +4 -1
- package/dist/cjs/nvs-dynamic-form/services/generateFormContentUtils.d.ts +8 -1
- package/dist/cjs/nvs-dynamic-form/services/generateFormContentUtils.js +8 -3
- package/dist/cjs/nvs-dynamic-form/services/generateFormContentUtils.js.map +1 -1
- package/dist/cjs/types/array-field.type.d.ts +3 -0
- package/dist/cjs/types/array-field.type.js +4 -3
- package/dist/cjs/types/array-field.type.js.map +1 -1
- package/dist/cjs/types/index.d.ts +2 -0
- package/dist/cjs/types/index.js +2 -0
- package/dist/cjs/types/index.js.map +1 -1
- package/dist/cjs/types/label-options.type.d.ts +4 -0
- package/dist/cjs/types/label-options.type.js +10 -0
- package/dist/cjs/types/label-options.type.js.map +1 -0
- package/dist/esm/nvs-dynamic-form/_style.css +5 -0
- package/dist/esm/nvs-dynamic-form/_template.d.ts +1 -1
- package/dist/esm/nvs-dynamic-form/_template.js +3 -1
- package/dist/esm/nvs-dynamic-form/_template.js.map +1 -1
- package/dist/esm/nvs-dynamic-form/_type.d.ts +6 -3
- package/dist/esm/nvs-dynamic-form/elements/arrayField/_template.d.ts +1 -1
- package/dist/esm/nvs-dynamic-form/elements/arrayField/_template.js +17 -5
- package/dist/esm/nvs-dynamic-form/elements/arrayField/_template.js.map +1 -1
- package/dist/esm/nvs-dynamic-form/elements/arrayField/_type.d.ts +4 -1
- package/dist/esm/nvs-dynamic-form/services/generateFormContentUtils.d.ts +8 -1
- package/dist/esm/nvs-dynamic-form/services/generateFormContentUtils.js +9 -4
- package/dist/esm/nvs-dynamic-form/services/generateFormContentUtils.js.map +1 -1
- package/dist/esm/types/array-field.type.d.ts +3 -0
- package/dist/esm/types/array-field.type.js +4 -3
- package/dist/esm/types/array-field.type.js.map +1 -1
- package/dist/esm/types/index.d.ts +2 -0
- package/dist/esm/types/index.js +2 -0
- package/dist/esm/types/index.js.map +1 -1
- package/dist/esm/types/label-options.type.d.ts +4 -0
- package/dist/esm/types/label-options.type.js +6 -0
- package/dist/esm/types/label-options.type.js.map +1 -0
- package/lib/nvs-dynamic-form/_stories.tsx +2 -5
- package/lib/nvs-dynamic-form/_style.css +5 -0
- package/lib/nvs-dynamic-form/_template.tsx +4 -0
- package/lib/nvs-dynamic-form/_type.tsx +8 -2
- package/lib/nvs-dynamic-form/elements/arrayField/_template.tsx +52 -5
- package/lib/nvs-dynamic-form/elements/arrayField/_type.tsx +10 -1
- package/lib/nvs-dynamic-form/services/generateFormContentUtils.tsx +25 -2
- package/lib/types/array-field.type.tsx +7 -6
- package/lib/types/index.tsx +2 -0
- package/lib/types/label-options.type.tsx +7 -0
- package/package.json +1 -1
|
@@ -2,4 +2,4 @@ import "nvs-flexgrid";
|
|
|
2
2
|
import "./_style.css";
|
|
3
3
|
import { INvsDynamicForm } from "./_type";
|
|
4
4
|
import React from "react";
|
|
5
|
-
export declare const NvsDynamicForm: ({ onSubmit, formElements, fields, formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible, submitButtonLabel, submitButtonIsFullWidth, submitButtonPosition, submitButtonContainerClass, container, containerVisible, containerOptions, useContainersOutsideGroup, useGroupContainer, }: INvsDynamicForm) => React.JSX.Element;
|
|
5
|
+
export declare const NvsDynamicForm: ({ onSubmit, formElements, fields, formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible, submitButtonLabel, submitButtonIsFullWidth, submitButtonPosition, submitButtonContainerClass, container, containerVisible, containerOptions, useContainersOutsideGroup, useGroupContainer, addButtonDefaultOptions, removeButtonDefaultOptions, }: INvsDynamicForm) => React.JSX.Element;
|
|
@@ -10,7 +10,7 @@ const button_1 = require("./elements/button");
|
|
|
10
10
|
const formikForm_1 = require("./formikForm");
|
|
11
11
|
const generateFormContentUtils_1 = require("./services/generateFormContentUtils");
|
|
12
12
|
const react_1 = __importDefault(require("react"));
|
|
13
|
-
const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible = true, submitButtonLabel = submitButtonDefaultOptions.label, submitButtonIsFullWidth = submitButtonDefaultOptions.isFullWidth, submitButtonPosition = submitButtonDefaultOptions.position, submitButtonContainerClass, container = ({ children }) => react_1.default.createElement(react_1.default.Fragment, null, children), containerVisible = false, containerOptions = {}, useContainersOutsideGroup = false, useGroupContainer = false, }) => {
|
|
13
|
+
const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible = true, submitButtonLabel = submitButtonDefaultOptions.label, submitButtonIsFullWidth = submitButtonDefaultOptions.isFullWidth, submitButtonPosition = submitButtonDefaultOptions.position, submitButtonContainerClass, container = ({ children }) => react_1.default.createElement(react_1.default.Fragment, null, children), containerVisible = false, containerOptions = {}, useContainersOutsideGroup = false, useGroupContainer = false, addButtonDefaultOptions, removeButtonDefaultOptions, }) => {
|
|
14
14
|
const generateFormContentUtils = new generateFormContentUtils_1.GenerateFormContentUtils({
|
|
15
15
|
containerComponent: container,
|
|
16
16
|
formElements,
|
|
@@ -20,6 +20,8 @@ const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formClass, b
|
|
|
20
20
|
fields,
|
|
21
21
|
containerOptions,
|
|
22
22
|
buttonComponent,
|
|
23
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
24
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
23
25
|
});
|
|
24
26
|
const formikForm = (react_1.default.createElement(formikForm_1.FormikForm, { onSubmit: onSubmit, fields: fields, formClass: formClass },
|
|
25
27
|
generateFormContentUtils.createFormContent(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../lib/nvs-dynamic-form/_template.tsx"],"names":[],"mappings":";;;;;;AAAA,wBAAsB;AACtB,wBAAsB;AAEtB,8CAA2C;AAC3C,6CAA0C;AAC1C,kFAA+E;AAE/E,kDAA0B;AAEnB,MAAM,cAAc,GAAG,CAAC,EAC7B,QAAQ,EACR,YAAY,GAAG,EAAE,EACjB,MAAM,GAAG,EAAE,EACX,SAAS,EACT,eAAe,EACf,0BAA0B,EAC1B,mBAAmB,GAAG,IAAI,EAC1B,iBAAiB,GAAG,0BAA0B,CAAC,KAAK,EACpD,uBAAuB,GAAG,0BAA0B,CAAC,WAAW,EAChE,oBAAoB,GAAG,0BAA0B,CAAC,QAAQ,EAC1D,0BAA0B,EAC1B,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,8DAAG,QAAQ,CAAI,EAC7C,gBAAgB,GAAG,KAAK,EACxB,gBAAgB,GAAG,EAAE,EACrB,yBAAyB,GAAG,KAAK,EACjC,iBAAiB,GAAG,KAAK,
|
|
1
|
+
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../lib/nvs-dynamic-form/_template.tsx"],"names":[],"mappings":";;;;;;AAAA,wBAAsB;AACtB,wBAAsB;AAEtB,8CAA2C;AAC3C,6CAA0C;AAC1C,kFAA+E;AAE/E,kDAA0B;AAEnB,MAAM,cAAc,GAAG,CAAC,EAC7B,QAAQ,EACR,YAAY,GAAG,EAAE,EACjB,MAAM,GAAG,EAAE,EACX,SAAS,EACT,eAAe,EACf,0BAA0B,EAC1B,mBAAmB,GAAG,IAAI,EAC1B,iBAAiB,GAAG,0BAA0B,CAAC,KAAK,EACpD,uBAAuB,GAAG,0BAA0B,CAAC,WAAW,EAChE,oBAAoB,GAAG,0BAA0B,CAAC,QAAQ,EAC1D,0BAA0B,EAC1B,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,8DAAG,QAAQ,CAAI,EAC7C,gBAAgB,GAAG,KAAK,EACxB,gBAAgB,GAAG,EAAE,EACrB,yBAAyB,GAAG,KAAK,EACjC,iBAAiB,GAAG,KAAK,EACzB,uBAAuB,EACvB,0BAA0B,GACV,EAAE,EAAE;IACpB,MAAM,wBAAwB,GAAG,IAAI,mDAAwB,CAAC;QAC5D,kBAAkB,EAAE,SAAS;QAC7B,YAAY;QACZ,yBAAyB;QACzB,iBAAiB;QACjB,gBAAgB;QAChB,MAAM;QACN,gBAAgB;QAChB,eAAe;QACf,iCAAiC,EAAE,uBAAuB;QAC1D,oCAAoC,EAAE,0BAA0B;KACjE,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,CACjB,8BAAC,uBAAU,IAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS;QACjE,wBAAwB,CAAC,iBAAiB,EAAE;QAC7C,8BAAC,eAAM,IACL,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,mBAAmB,EAC5B,KAAK,EAAE,iBAAiB,EACxB,WAAW,EAAE,uBAAuB,EACpC,QAAQ,EAAE,oBAAoB,EAC9B,cAAc,EAAE,0BAA0B,GAC1C,CACS,CACd,CAAC;IAEF,OAAO,gBAAgB,IAAI,CAAC,yBAAyB;QACnD,CAAC,CAAC,wBAAwB,CAAC,eAAe,CAAC,UAAU,EAAE,gBAAgB,CAAC;QACxE,CAAC,CAAC,UAAU,CAAC;AACjB,CAAC,CAAC;AAlDW,QAAA,cAAc,kBAkDzB"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { ArrayField, FieldBase, GroupField, ISubmitButtonDefaultOptions } from "../types";
|
|
2
|
-
import { IButton } from "./elements/button/_type";
|
|
1
|
+
import { ArrayField, ArrayFieldAddButton, ArrayFieldRemoveButton, FieldBase, GroupField, ISubmitButtonDefaultOptions, LabelOptions } from "../types";
|
|
3
2
|
import { IField } from "./elements/field";
|
|
4
3
|
export type FieldType = FieldBase<any> | GroupField | ArrayField<any>;
|
|
5
|
-
export interface INvsDynamicForm extends
|
|
4
|
+
export interface INvsDynamicForm extends Omit<IField, "field"> {
|
|
6
5
|
onSubmit?: ((values: unknown) => void) | ((values: unknown) => Promise<void>);
|
|
7
6
|
fields: Array<FieldType>;
|
|
8
7
|
formClass?: string;
|
|
@@ -13,10 +12,14 @@ export interface INvsDynamicForm extends IButton, Omit<IField, "field"> {
|
|
|
13
12
|
containerVisible?: boolean;
|
|
14
13
|
useContainersOutsideGroup?: boolean;
|
|
15
14
|
useGroupContainer?: boolean;
|
|
15
|
+
buttonComponent: React.FC<any>;
|
|
16
16
|
submitButtonDefaultOptions: ISubmitButtonDefaultOptions;
|
|
17
17
|
submitButtonVisible?: boolean;
|
|
18
18
|
submitButtonLabel?: string;
|
|
19
19
|
submitButtonPosition?: "left" | "center" | "right";
|
|
20
20
|
submitButtonIsFullWidth?: boolean;
|
|
21
21
|
submitButtonContainerClass?: string;
|
|
22
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
23
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
24
|
+
labelDefaultOptions?: LabelOptions;
|
|
22
25
|
}
|
|
@@ -1,13 +1,38 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var
|
|
3
|
-
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
4
24
|
};
|
|
5
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
26
|
exports.ArrayField = void 0;
|
|
27
|
+
const lodash = __importStar(require("lodash"));
|
|
28
|
+
const types_1 = require("../../../types");
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
7
30
|
const formik_1 = require("formik");
|
|
8
31
|
const generateFormContentUtils_1 = require("../../services/generateFormContentUtils");
|
|
9
|
-
const
|
|
10
|
-
const
|
|
32
|
+
const ArrayField = ({ field: arrayField, formElements, containerComponent, containerVisible, useContainersOutsideGroup, useGroupContainer, buttonComponent: ButtonComponent, addButtonDefaultOptions, removeButtonDefaultOptions, labelDefaultOptions, }) => {
|
|
33
|
+
const [addButtonOptions] = (0, react_1.useState)(new types_1.ArrayFieldAddButton(lodash.merge(addButtonDefaultOptions ?? {}, arrayField.addButtonOptions ?? {})));
|
|
34
|
+
const [removeButtonOptions] = (0, react_1.useState)(new types_1.ArrayFieldRemoveButton(lodash.merge(removeButtonDefaultOptions ?? {}, arrayField.removeButtonOptions ?? {})));
|
|
35
|
+
const [labelOptions] = (0, react_1.useState)(new types_1.LabelOptions(lodash.merge(labelDefaultOptions ?? {}, arrayField.labelOptions ?? {})));
|
|
11
36
|
const generateFormContentUtils = new generateFormContentUtils_1.GenerateFormContentUtils({
|
|
12
37
|
containerComponent,
|
|
13
38
|
formElements,
|
|
@@ -15,6 +40,8 @@ const ArrayField = ({ field: arrayField, formElements, containerComponent, conta
|
|
|
15
40
|
useGroupContainer,
|
|
16
41
|
containerVisible: containerVisible,
|
|
17
42
|
fields: arrayField.fields,
|
|
43
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
44
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
18
45
|
});
|
|
19
46
|
const createArrayItem = (name, index) => {
|
|
20
47
|
return arrayField.fields.map((field) => ({
|
|
@@ -37,24 +64,29 @@ const ArrayField = ({ field: arrayField, formElements, containerComponent, conta
|
|
|
37
64
|
return (react_1.default.createElement("div", { className: "nvs-col-12" },
|
|
38
65
|
react_1.default.createElement(ButtonComponent, { onClick: () => {
|
|
39
66
|
onRemoveItem();
|
|
40
|
-
}, type: "button" },
|
|
67
|
+
}, type: "button", ...removeButtonOptions.options }, removeButtonOptions.label)));
|
|
41
68
|
};
|
|
42
69
|
const createArrayItemRemoveButton = (onRemoveItem) => {
|
|
43
70
|
return (react_1.default.createElement("div", { className: "df-array-field-remove-button" }, generateFormContentUtils.createContentContainer(createRemoveButton(onRemoveItem))));
|
|
44
71
|
};
|
|
45
72
|
const createFieldArrayContent = (onRemoveItem, index) => {
|
|
46
|
-
return (react_1.default.createElement("div", { className: `df-array-field remove-button-${
|
|
73
|
+
return (react_1.default.createElement("div", { className: `df-array-field remove-button-${removeButtonOptions.position}`, key: index },
|
|
47
74
|
createArrayFields(index),
|
|
48
75
|
createArrayItemRemoveButton(() => onRemoveItem(index))));
|
|
49
76
|
};
|
|
50
77
|
const createAddButton = (onAddItem) => {
|
|
51
78
|
return (react_1.default.createElement("div", { className: "df-array-field-add-button" },
|
|
52
|
-
react_1.default.createElement(ButtonComponent, { onClick: () => onAddItem(getDefaultItem()), type: "button" },
|
|
79
|
+
react_1.default.createElement(ButtonComponent, { onClick: () => onAddItem(getDefaultItem()), type: "button", ...addButtonOptions.options }, addButtonOptions.label)));
|
|
53
80
|
};
|
|
54
81
|
const createArrayItemAddButton = (onAddItem) => {
|
|
55
82
|
return generateFormContentUtils.createContentContainer(createAddButton(onAddItem));
|
|
56
83
|
};
|
|
84
|
+
const createArrayFieldLabel = () => {
|
|
85
|
+
return generateFormContentUtils.createContentContainer(react_1.default.createElement("div", { className: "nvs-col-12" },
|
|
86
|
+
react_1.default.createElement("label", { className: `df-array-field-label ${labelOptions.class}` }, arrayField.label)));
|
|
87
|
+
};
|
|
57
88
|
return (react_1.default.createElement(formik_1.FieldArray, { name: arrayField.id }, ({ push, remove, form }) => (react_1.default.createElement(react_1.default.Fragment, null,
|
|
89
|
+
arrayField.label && createArrayFieldLabel(),
|
|
58
90
|
form.values[arrayField.id]?.map((_, index) => createFieldArrayContent(remove, index)),
|
|
59
91
|
createArrayItemAddButton(push)))));
|
|
60
92
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../../../lib/nvs-dynamic-form/elements/arrayField/_template.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../../../lib/nvs-dynamic-form/elements/arrayField/_template.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ArrayField } from "../../../types";
|
|
1
|
+
import { ArrayField, ArrayFieldAddButton, ArrayFieldRemoveButton, LabelOptions } from "../../../types";
|
|
2
2
|
import { IField } from "../field";
|
|
3
3
|
export interface IArrayField extends IField {
|
|
4
4
|
field: ArrayField;
|
|
@@ -7,4 +7,7 @@ export interface IArrayField extends IField {
|
|
|
7
7
|
containerVisible: boolean;
|
|
8
8
|
useContainersOutsideGroup: boolean;
|
|
9
9
|
useGroupContainer: boolean;
|
|
10
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
11
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
12
|
+
labelDefaultOptions?: LabelOptions;
|
|
10
13
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { ArrayFieldAddButton, LabelOptions } from "../../types";
|
|
1
2
|
import { FieldType } from "../_type";
|
|
2
3
|
import { IFormElement } from "../elements/field";
|
|
3
4
|
import React from "react";
|
|
@@ -11,7 +12,10 @@ export declare class GenerateFormContentUtils {
|
|
|
11
12
|
private readonly fields;
|
|
12
13
|
private readonly containerOptions;
|
|
13
14
|
private readonly buttonComponent?;
|
|
14
|
-
|
|
15
|
+
private readonly fieldArrayAddButtonDefaultOptions;
|
|
16
|
+
private readonly fieldArrayRemoveButtonDefaultOptions;
|
|
17
|
+
private readonly labelDefaultOptions;
|
|
18
|
+
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, fieldArrayAddButtonDefaultOptions, fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions, }: {
|
|
15
19
|
containerComponent: React.FC<any>;
|
|
16
20
|
formElements: IFormElement;
|
|
17
21
|
useContainersOutsideGroup: boolean;
|
|
@@ -22,6 +26,9 @@ export declare class GenerateFormContentUtils {
|
|
|
22
26
|
containerOptions?: {
|
|
23
27
|
[key: string]: any;
|
|
24
28
|
};
|
|
29
|
+
fieldArrayAddButtonDefaultOptions?: ArrayFieldAddButton;
|
|
30
|
+
fieldArrayRemoveButtonDefaultOptions?: ArrayFieldAddButton;
|
|
31
|
+
labelDefaultOptions?: LabelOptions;
|
|
25
32
|
});
|
|
26
33
|
createContainer(content: ReactNode, containerProps: object): React.JSX.Element;
|
|
27
34
|
createFormContent(): React.JSX.Element;
|
|
@@ -11,15 +11,20 @@ const field_1 = require("../elements/field");
|
|
|
11
11
|
const groupField_1 = require("../elements/groupField");
|
|
12
12
|
const react_1 = __importDefault(require("react"));
|
|
13
13
|
class GenerateFormContentUtils {
|
|
14
|
-
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, }) {
|
|
14
|
+
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, fieldArrayAddButtonDefaultOptions, fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions, }) {
|
|
15
15
|
this.containerComponent = containerComponent;
|
|
16
16
|
this.formElements = formElements;
|
|
17
17
|
this.useContainersOutsideGroup = useContainersOutsideGroup;
|
|
18
18
|
this.useGroupContainer = useGroupContainer;
|
|
19
19
|
this.containerVisible = containerVisible;
|
|
20
20
|
this.fields = fields;
|
|
21
|
-
this.containerOptions = containerOptions
|
|
21
|
+
this.containerOptions = containerOptions ?? {};
|
|
22
22
|
this.buttonComponent = buttonComponent;
|
|
23
|
+
this.fieldArrayAddButtonDefaultOptions =
|
|
24
|
+
fieldArrayAddButtonDefaultOptions ?? {};
|
|
25
|
+
this.fieldArrayRemoveButtonDefaultOptions =
|
|
26
|
+
fieldArrayRemoveButtonDefaultOptions ?? {};
|
|
27
|
+
this.labelDefaultOptions = labelDefaultOptions ?? {};
|
|
23
28
|
}
|
|
24
29
|
createContainer(content, containerProps) {
|
|
25
30
|
return (react_1.default.createElement(container_1.Container, { containerComponent: this.containerComponent, options: containerProps }, content));
|
|
@@ -76,7 +81,7 @@ class GenerateFormContentUtils {
|
|
|
76
81
|
return (react_1.default.createElement(groupField_1.GroupField, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible }));
|
|
77
82
|
}
|
|
78
83
|
createArrayFieldElement(field) {
|
|
79
|
-
return (react_1.default.createElement(arrayField_1.ArrayField, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible, buttonComponent: this.buttonComponent }));
|
|
84
|
+
return (react_1.default.createElement(arrayField_1.ArrayField, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible, buttonComponent: this.buttonComponent, addButtonDefaultOptions: this.fieldArrayAddButtonDefaultOptions, removeButtonDefaultOptions: this.fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions: this.labelDefaultOptions }));
|
|
80
85
|
}
|
|
81
86
|
isSingleField(field) {
|
|
82
87
|
return !(field instanceof types_1.GroupField &&
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generateFormContentUtils.js","sourceRoot":"","sources":["../../../../lib/nvs-dynamic-form/services/generateFormContentUtils.tsx"],"names":[],"mappings":";;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"generateFormContentUtils.js","sourceRoot":"","sources":["../../../../lib/nvs-dynamic-form/services/generateFormContentUtils.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ArrayFieldAddButton, ArrayFieldRemoveButton } from "./array-field-action-button.type";
|
|
2
2
|
import { FieldBase } from "./field-base.type";
|
|
3
|
+
import { LabelOptions } from "./label-options.type";
|
|
3
4
|
export declare class ArrayField<ValueType = {
|
|
4
5
|
[key: string]: any;
|
|
5
6
|
}> {
|
|
@@ -9,5 +10,7 @@ export declare class ArrayField<ValueType = {
|
|
|
9
10
|
addButtonOptions?: ArrayFieldAddButton;
|
|
10
11
|
removeButtonOptions?: ArrayFieldRemoveButton;
|
|
11
12
|
defaultValues?: Array<ValueType>;
|
|
13
|
+
label?: string;
|
|
14
|
+
labelOptions?: LabelOptions;
|
|
12
15
|
constructor(options: ArrayField<ValueType>);
|
|
13
16
|
}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ArrayField = void 0;
|
|
4
|
-
const array_field_action_button_type_1 = require("./array-field-action-button.type");
|
|
5
4
|
class ArrayField {
|
|
6
5
|
constructor(options) {
|
|
7
6
|
this.fieldType = "fieldArray";
|
|
8
7
|
this.id = options.id;
|
|
9
8
|
this.fields = options.fields ?? [];
|
|
10
|
-
this.addButtonOptions =
|
|
11
|
-
this.removeButtonOptions =
|
|
9
|
+
this.addButtonOptions = options.addButtonOptions ?? {};
|
|
10
|
+
this.removeButtonOptions = options.removeButtonOptions ?? {};
|
|
12
11
|
this.defaultValues = options.defaultValues ?? [];
|
|
12
|
+
this.label = options.label;
|
|
13
|
+
this.labelOptions = options.labelOptions ?? {};
|
|
13
14
|
}
|
|
14
15
|
}
|
|
15
16
|
exports.ArrayField = ArrayField;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"array-field.type.js","sourceRoot":"","sources":["../../../lib/types/array-field.type.tsx"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"array-field.type.js","sourceRoot":"","sources":["../../../lib/types/array-field.type.tsx"],"names":[],"mappings":";;;AAQA,MAAa,UAAU;IAUrB,YAAY,OAA8B;QAT1C,cAAS,GAAY,YAAY,CAAC;QAUhC,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,EAAE,CAAC;QACvD,IAAI,CAAC,mBAAmB,GAAG,OAAO,CAAC,mBAAmB,IAAI,EAAE,CAAC;QAC7D,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC;QACjD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,EAAE,CAAC;IACjD,CAAC;CACF;AAnBD,gCAmBC"}
|
package/dist/cjs/types/index.js
CHANGED
|
@@ -20,4 +20,6 @@ __exportStar(require("./dynamic-object.type"), exports);
|
|
|
20
20
|
__exportStar(require("./submit-button-default-options.type"), exports);
|
|
21
21
|
__exportStar(require("./group-field.type"), exports);
|
|
22
22
|
__exportStar(require("./array-field.type"), exports);
|
|
23
|
+
__exportStar(require("./array-field-action-button.type"), exports);
|
|
24
|
+
__exportStar(require("./label-options.type"), exports);
|
|
23
25
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/types/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,qDAAmC;AACnC,wDAAsC;AACtC,uEAAqD;AACrD,qDAAmC;AACnC,qDAAmC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/types/index.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,oDAAkC;AAClC,qDAAmC;AACnC,wDAAsC;AACtC,uEAAqD;AACrD,qDAAmC;AACnC,qDAAmC;AACnC,mEAAiD;AACjD,uDAAqC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.LabelOptions = void 0;
|
|
4
|
+
class LabelOptions {
|
|
5
|
+
constructor(options) {
|
|
6
|
+
this.class = options.class ?? "";
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
exports.LabelOptions = LabelOptions;
|
|
10
|
+
//# sourceMappingURL=label-options.type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"label-options.type.js","sourceRoot":"","sources":["../../../lib/types/label-options.type.tsx"],"names":[],"mappings":";;;AAAA,MAAa,YAAY;IAGvB,YAAY,OAAqB;QAC/B,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;IACnC,CAAC;CACF;AAND,oCAMC"}
|
|
@@ -2,4 +2,4 @@ import "nvs-flexgrid";
|
|
|
2
2
|
import "./_style.css";
|
|
3
3
|
import { INvsDynamicForm } from "./_type";
|
|
4
4
|
import React from "react";
|
|
5
|
-
export declare const NvsDynamicForm: ({ onSubmit, formElements, fields, formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible, submitButtonLabel, submitButtonIsFullWidth, submitButtonPosition, submitButtonContainerClass, container, containerVisible, containerOptions, useContainersOutsideGroup, useGroupContainer, }: INvsDynamicForm) => React.JSX.Element;
|
|
5
|
+
export declare const NvsDynamicForm: ({ onSubmit, formElements, fields, formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible, submitButtonLabel, submitButtonIsFullWidth, submitButtonPosition, submitButtonContainerClass, container, containerVisible, containerOptions, useContainersOutsideGroup, useGroupContainer, addButtonDefaultOptions, removeButtonDefaultOptions, }: INvsDynamicForm) => React.JSX.Element;
|
|
@@ -4,7 +4,7 @@ import { Button } from "./elements/button";
|
|
|
4
4
|
import { FormikForm } from "./formikForm";
|
|
5
5
|
import { GenerateFormContentUtils } from "./services/generateFormContentUtils";
|
|
6
6
|
import React from "react";
|
|
7
|
-
export const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible = true, submitButtonLabel = submitButtonDefaultOptions.label, submitButtonIsFullWidth = submitButtonDefaultOptions.isFullWidth, submitButtonPosition = submitButtonDefaultOptions.position, submitButtonContainerClass, container = ({ children }) => React.createElement(React.Fragment, null, children), containerVisible = false, containerOptions = {}, useContainersOutsideGroup = false, useGroupContainer = false, }) => {
|
|
7
|
+
export const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formClass, buttonComponent, submitButtonDefaultOptions, submitButtonVisible = true, submitButtonLabel = submitButtonDefaultOptions.label, submitButtonIsFullWidth = submitButtonDefaultOptions.isFullWidth, submitButtonPosition = submitButtonDefaultOptions.position, submitButtonContainerClass, container = ({ children }) => React.createElement(React.Fragment, null, children), containerVisible = false, containerOptions = {}, useContainersOutsideGroup = false, useGroupContainer = false, addButtonDefaultOptions, removeButtonDefaultOptions, }) => {
|
|
8
8
|
const generateFormContentUtils = new GenerateFormContentUtils({
|
|
9
9
|
containerComponent: container,
|
|
10
10
|
formElements,
|
|
@@ -14,6 +14,8 @@ export const NvsDynamicForm = ({ onSubmit, formElements = {}, fields = [], formC
|
|
|
14
14
|
fields,
|
|
15
15
|
containerOptions,
|
|
16
16
|
buttonComponent,
|
|
17
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
18
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
17
19
|
});
|
|
18
20
|
const formikForm = (React.createElement(FormikForm, { onSubmit: onSubmit, fields: fields, formClass: formClass },
|
|
19
21
|
generateFormContentUtils.createFormContent(),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../lib/nvs-dynamic-form/_template.tsx"],"names":[],"mappings":"AAAA,OAAO,cAAc,CAAC;AACtB,OAAO,cAAc,CAAC;AAEtB,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAE/E,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,QAAQ,EACR,YAAY,GAAG,EAAE,EACjB,MAAM,GAAG,EAAE,EACX,SAAS,EACT,eAAe,EACf,0BAA0B,EAC1B,mBAAmB,GAAG,IAAI,EAC1B,iBAAiB,GAAG,0BAA0B,CAAC,KAAK,EACpD,uBAAuB,GAAG,0BAA0B,CAAC,WAAW,EAChE,oBAAoB,GAAG,0BAA0B,CAAC,QAAQ,EAC1D,0BAA0B,EAC1B,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,0CAAG,QAAQ,CAAI,EAC7C,gBAAgB,GAAG,KAAK,EACxB,gBAAgB,GAAG,EAAE,EACrB,yBAAyB,GAAG,KAAK,EACjC,iBAAiB,GAAG,KAAK,
|
|
1
|
+
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../lib/nvs-dynamic-form/_template.tsx"],"names":[],"mappings":"AAAA,OAAO,cAAc,CAAC;AACtB,OAAO,cAAc,CAAC;AAEtB,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EAAE,wBAAwB,EAAE,MAAM,qCAAqC,CAAC;AAE/E,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,QAAQ,EACR,YAAY,GAAG,EAAE,EACjB,MAAM,GAAG,EAAE,EACX,SAAS,EACT,eAAe,EACf,0BAA0B,EAC1B,mBAAmB,GAAG,IAAI,EAC1B,iBAAiB,GAAG,0BAA0B,CAAC,KAAK,EACpD,uBAAuB,GAAG,0BAA0B,CAAC,WAAW,EAChE,oBAAoB,GAAG,0BAA0B,CAAC,QAAQ,EAC1D,0BAA0B,EAC1B,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,0CAAG,QAAQ,CAAI,EAC7C,gBAAgB,GAAG,KAAK,EACxB,gBAAgB,GAAG,EAAE,EACrB,yBAAyB,GAAG,KAAK,EACjC,iBAAiB,GAAG,KAAK,EACzB,uBAAuB,EACvB,0BAA0B,GACV,EAAE,EAAE;IACpB,MAAM,wBAAwB,GAAG,IAAI,wBAAwB,CAAC;QAC5D,kBAAkB,EAAE,SAAS;QAC7B,YAAY;QACZ,yBAAyB;QACzB,iBAAiB;QACjB,gBAAgB;QAChB,MAAM;QACN,gBAAgB;QAChB,eAAe;QACf,iCAAiC,EAAE,uBAAuB;QAC1D,oCAAoC,EAAE,0BAA0B;KACjE,CAAC,CAAC;IAEH,MAAM,UAAU,GAAG,CACjB,oBAAC,UAAU,IAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS;QACjE,wBAAwB,CAAC,iBAAiB,EAAE;QAC7C,oBAAC,MAAM,IACL,eAAe,EAAE,eAAe,EAChC,OAAO,EAAE,mBAAmB,EAC5B,KAAK,EAAE,iBAAiB,EACxB,WAAW,EAAE,uBAAuB,EACpC,QAAQ,EAAE,oBAAoB,EAC9B,cAAc,EAAE,0BAA0B,GAC1C,CACS,CACd,CAAC;IAEF,OAAO,gBAAgB,IAAI,CAAC,yBAAyB;QACnD,CAAC,CAAC,wBAAwB,CAAC,eAAe,CAAC,UAAU,EAAE,gBAAgB,CAAC;QACxE,CAAC,CAAC,UAAU,CAAC;AACjB,CAAC,CAAC"}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
|
-
import { ArrayField, FieldBase, GroupField, ISubmitButtonDefaultOptions } from "../types";
|
|
2
|
-
import { IButton } from "./elements/button/_type";
|
|
1
|
+
import { ArrayField, ArrayFieldAddButton, ArrayFieldRemoveButton, FieldBase, GroupField, ISubmitButtonDefaultOptions, LabelOptions } from "../types";
|
|
3
2
|
import { IField } from "./elements/field";
|
|
4
3
|
export type FieldType = FieldBase<any> | GroupField | ArrayField<any>;
|
|
5
|
-
export interface INvsDynamicForm extends
|
|
4
|
+
export interface INvsDynamicForm extends Omit<IField, "field"> {
|
|
6
5
|
onSubmit?: ((values: unknown) => void) | ((values: unknown) => Promise<void>);
|
|
7
6
|
fields: Array<FieldType>;
|
|
8
7
|
formClass?: string;
|
|
@@ -13,10 +12,14 @@ export interface INvsDynamicForm extends IButton, Omit<IField, "field"> {
|
|
|
13
12
|
containerVisible?: boolean;
|
|
14
13
|
useContainersOutsideGroup?: boolean;
|
|
15
14
|
useGroupContainer?: boolean;
|
|
15
|
+
buttonComponent: React.FC<any>;
|
|
16
16
|
submitButtonDefaultOptions: ISubmitButtonDefaultOptions;
|
|
17
17
|
submitButtonVisible?: boolean;
|
|
18
18
|
submitButtonLabel?: string;
|
|
19
19
|
submitButtonPosition?: "left" | "center" | "right";
|
|
20
20
|
submitButtonIsFullWidth?: boolean;
|
|
21
21
|
submitButtonContainerClass?: string;
|
|
22
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
23
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
24
|
+
labelDefaultOptions?: LabelOptions;
|
|
22
25
|
}
|
|
@@ -1,7 +1,12 @@
|
|
|
1
|
+
import * as lodash from "lodash";
|
|
2
|
+
import { ArrayFieldAddButton, ArrayFieldRemoveButton, LabelOptions, } from "../../../types";
|
|
3
|
+
import React, { useState } from "react";
|
|
1
4
|
import { FieldArray } from "formik";
|
|
2
5
|
import { GenerateFormContentUtils } from "../../services/generateFormContentUtils";
|
|
3
|
-
|
|
4
|
-
|
|
6
|
+
export const ArrayField = ({ field: arrayField, formElements, containerComponent, containerVisible, useContainersOutsideGroup, useGroupContainer, buttonComponent: ButtonComponent, addButtonDefaultOptions, removeButtonDefaultOptions, labelDefaultOptions, }) => {
|
|
7
|
+
const [addButtonOptions] = useState(new ArrayFieldAddButton(lodash.merge(addButtonDefaultOptions ?? {}, arrayField.addButtonOptions ?? {})));
|
|
8
|
+
const [removeButtonOptions] = useState(new ArrayFieldRemoveButton(lodash.merge(removeButtonDefaultOptions ?? {}, arrayField.removeButtonOptions ?? {})));
|
|
9
|
+
const [labelOptions] = useState(new LabelOptions(lodash.merge(labelDefaultOptions ?? {}, arrayField.labelOptions ?? {})));
|
|
5
10
|
const generateFormContentUtils = new GenerateFormContentUtils({
|
|
6
11
|
containerComponent,
|
|
7
12
|
formElements,
|
|
@@ -9,6 +14,8 @@ export const ArrayField = ({ field: arrayField, formElements, containerComponent
|
|
|
9
14
|
useGroupContainer,
|
|
10
15
|
containerVisible: containerVisible,
|
|
11
16
|
fields: arrayField.fields,
|
|
17
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
18
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
12
19
|
});
|
|
13
20
|
const createArrayItem = (name, index) => {
|
|
14
21
|
return arrayField.fields.map((field) => ({
|
|
@@ -31,24 +38,29 @@ export const ArrayField = ({ field: arrayField, formElements, containerComponent
|
|
|
31
38
|
return (React.createElement("div", { className: "nvs-col-12" },
|
|
32
39
|
React.createElement(ButtonComponent, { onClick: () => {
|
|
33
40
|
onRemoveItem();
|
|
34
|
-
}, type: "button" },
|
|
41
|
+
}, type: "button", ...removeButtonOptions.options }, removeButtonOptions.label)));
|
|
35
42
|
};
|
|
36
43
|
const createArrayItemRemoveButton = (onRemoveItem) => {
|
|
37
44
|
return (React.createElement("div", { className: "df-array-field-remove-button" }, generateFormContentUtils.createContentContainer(createRemoveButton(onRemoveItem))));
|
|
38
45
|
};
|
|
39
46
|
const createFieldArrayContent = (onRemoveItem, index) => {
|
|
40
|
-
return (React.createElement("div", { className: `df-array-field remove-button-${
|
|
47
|
+
return (React.createElement("div", { className: `df-array-field remove-button-${removeButtonOptions.position}`, key: index },
|
|
41
48
|
createArrayFields(index),
|
|
42
49
|
createArrayItemRemoveButton(() => onRemoveItem(index))));
|
|
43
50
|
};
|
|
44
51
|
const createAddButton = (onAddItem) => {
|
|
45
52
|
return (React.createElement("div", { className: "df-array-field-add-button" },
|
|
46
|
-
React.createElement(ButtonComponent, { onClick: () => onAddItem(getDefaultItem()), type: "button" },
|
|
53
|
+
React.createElement(ButtonComponent, { onClick: () => onAddItem(getDefaultItem()), type: "button", ...addButtonOptions.options }, addButtonOptions.label)));
|
|
47
54
|
};
|
|
48
55
|
const createArrayItemAddButton = (onAddItem) => {
|
|
49
56
|
return generateFormContentUtils.createContentContainer(createAddButton(onAddItem));
|
|
50
57
|
};
|
|
58
|
+
const createArrayFieldLabel = () => {
|
|
59
|
+
return generateFormContentUtils.createContentContainer(React.createElement("div", { className: "nvs-col-12" },
|
|
60
|
+
React.createElement("label", { className: `df-array-field-label ${labelOptions.class}` }, arrayField.label)));
|
|
61
|
+
};
|
|
51
62
|
return (React.createElement(FieldArray, { name: arrayField.id }, ({ push, remove, form }) => (React.createElement(React.Fragment, null,
|
|
63
|
+
arrayField.label && createArrayFieldLabel(),
|
|
52
64
|
form.values[arrayField.id]?.map((_, index) => createFieldArrayContent(remove, index)),
|
|
53
65
|
createArrayItemAddButton(push)))));
|
|
54
66
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../../../lib/nvs-dynamic-form/elements/arrayField/_template.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"_template.js","sourceRoot":"","sources":["../../../../../lib/nvs-dynamic-form/elements/arrayField/_template.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ArrayField } from "../../../types";
|
|
1
|
+
import { ArrayField, ArrayFieldAddButton, ArrayFieldRemoveButton, LabelOptions } from "../../../types";
|
|
2
2
|
import { IField } from "../field";
|
|
3
3
|
export interface IArrayField extends IField {
|
|
4
4
|
field: ArrayField;
|
|
@@ -7,4 +7,7 @@ export interface IArrayField extends IField {
|
|
|
7
7
|
containerVisible: boolean;
|
|
8
8
|
useContainersOutsideGroup: boolean;
|
|
9
9
|
useGroupContainer: boolean;
|
|
10
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
11
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
12
|
+
labelDefaultOptions?: LabelOptions;
|
|
10
13
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { ArrayFieldAddButton, LabelOptions } from "../../types";
|
|
1
2
|
import { FieldType } from "../_type";
|
|
2
3
|
import { IFormElement } from "../elements/field";
|
|
3
4
|
import React from "react";
|
|
@@ -11,7 +12,10 @@ export declare class GenerateFormContentUtils {
|
|
|
11
12
|
private readonly fields;
|
|
12
13
|
private readonly containerOptions;
|
|
13
14
|
private readonly buttonComponent?;
|
|
14
|
-
|
|
15
|
+
private readonly fieldArrayAddButtonDefaultOptions;
|
|
16
|
+
private readonly fieldArrayRemoveButtonDefaultOptions;
|
|
17
|
+
private readonly labelDefaultOptions;
|
|
18
|
+
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, fieldArrayAddButtonDefaultOptions, fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions, }: {
|
|
15
19
|
containerComponent: React.FC<any>;
|
|
16
20
|
formElements: IFormElement;
|
|
17
21
|
useContainersOutsideGroup: boolean;
|
|
@@ -22,6 +26,9 @@ export declare class GenerateFormContentUtils {
|
|
|
22
26
|
containerOptions?: {
|
|
23
27
|
[key: string]: any;
|
|
24
28
|
};
|
|
29
|
+
fieldArrayAddButtonDefaultOptions?: ArrayFieldAddButton;
|
|
30
|
+
fieldArrayRemoveButtonDefaultOptions?: ArrayFieldAddButton;
|
|
31
|
+
labelDefaultOptions?: LabelOptions;
|
|
25
32
|
});
|
|
26
33
|
createContainer(content: ReactNode, containerProps: object): React.JSX.Element;
|
|
27
34
|
createFormContent(): React.JSX.Element;
|
|
@@ -1,19 +1,24 @@
|
|
|
1
|
-
import { ArrayField, GroupField } from "../../types";
|
|
1
|
+
import { ArrayField, GroupField, } from "../../types";
|
|
2
2
|
import { ArrayField as ArrayFieldElement } from "../elements/arrayField";
|
|
3
3
|
import { Container } from "../elements/container";
|
|
4
4
|
import { Field } from "../elements/field";
|
|
5
5
|
import { GroupField as GroupFieldElement } from "../elements/groupField";
|
|
6
6
|
import React from "react";
|
|
7
7
|
export class GenerateFormContentUtils {
|
|
8
|
-
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, }) {
|
|
8
|
+
constructor({ containerComponent, formElements, useContainersOutsideGroup, useGroupContainer, containerVisible, fields, containerOptions, buttonComponent, fieldArrayAddButtonDefaultOptions, fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions, }) {
|
|
9
9
|
this.containerComponent = containerComponent;
|
|
10
10
|
this.formElements = formElements;
|
|
11
11
|
this.useContainersOutsideGroup = useContainersOutsideGroup;
|
|
12
12
|
this.useGroupContainer = useGroupContainer;
|
|
13
13
|
this.containerVisible = containerVisible;
|
|
14
14
|
this.fields = fields;
|
|
15
|
-
this.containerOptions = containerOptions
|
|
15
|
+
this.containerOptions = containerOptions ?? {};
|
|
16
16
|
this.buttonComponent = buttonComponent;
|
|
17
|
+
this.fieldArrayAddButtonDefaultOptions =
|
|
18
|
+
fieldArrayAddButtonDefaultOptions ?? {};
|
|
19
|
+
this.fieldArrayRemoveButtonDefaultOptions =
|
|
20
|
+
fieldArrayRemoveButtonDefaultOptions ?? {};
|
|
21
|
+
this.labelDefaultOptions = labelDefaultOptions ?? {};
|
|
17
22
|
}
|
|
18
23
|
createContainer(content, containerProps) {
|
|
19
24
|
return (React.createElement(Container, { containerComponent: this.containerComponent, options: containerProps }, content));
|
|
@@ -70,7 +75,7 @@ export class GenerateFormContentUtils {
|
|
|
70
75
|
return (React.createElement(GroupFieldElement, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible }));
|
|
71
76
|
}
|
|
72
77
|
createArrayFieldElement(field) {
|
|
73
|
-
return (React.createElement(ArrayFieldElement, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible, buttonComponent: this.buttonComponent }));
|
|
78
|
+
return (React.createElement(ArrayFieldElement, { key: field.id, formElements: this.formElements, field: field, containerComponent: this.containerComponent, useContainersOutsideGroup: this.useContainersOutsideGroup, useGroupContainer: this.useGroupContainer, containerVisible: this.containerVisible, buttonComponent: this.buttonComponent, addButtonDefaultOptions: this.fieldArrayAddButtonDefaultOptions, removeButtonDefaultOptions: this.fieldArrayRemoveButtonDefaultOptions, labelDefaultOptions: this.labelDefaultOptions }));
|
|
74
79
|
}
|
|
75
80
|
isSingleField(field) {
|
|
76
81
|
return !(field instanceof GroupField &&
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"generateFormContentUtils.js","sourceRoot":"","sources":["../../../../lib/nvs-dynamic-form/services/generateFormContentUtils.tsx"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"generateFormContentUtils.js","sourceRoot":"","sources":["../../../../lib/nvs-dynamic-form/services/generateFormContentUtils.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ArrayFieldAddButton, ArrayFieldRemoveButton } from "./array-field-action-button.type";
|
|
2
2
|
import { FieldBase } from "./field-base.type";
|
|
3
|
+
import { LabelOptions } from "./label-options.type";
|
|
3
4
|
export declare class ArrayField<ValueType = {
|
|
4
5
|
[key: string]: any;
|
|
5
6
|
}> {
|
|
@@ -9,5 +10,7 @@ export declare class ArrayField<ValueType = {
|
|
|
9
10
|
addButtonOptions?: ArrayFieldAddButton;
|
|
10
11
|
removeButtonOptions?: ArrayFieldRemoveButton;
|
|
11
12
|
defaultValues?: Array<ValueType>;
|
|
13
|
+
label?: string;
|
|
14
|
+
labelOptions?: LabelOptions;
|
|
12
15
|
constructor(options: ArrayField<ValueType>);
|
|
13
16
|
}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
-
import { ArrayFieldAddButton, ArrayFieldRemoveButton, } from "./array-field-action-button.type";
|
|
2
1
|
export class ArrayField {
|
|
3
2
|
constructor(options) {
|
|
4
3
|
this.fieldType = "fieldArray";
|
|
5
4
|
this.id = options.id;
|
|
6
5
|
this.fields = options.fields ?? [];
|
|
7
|
-
this.addButtonOptions =
|
|
8
|
-
this.removeButtonOptions =
|
|
6
|
+
this.addButtonOptions = options.addButtonOptions ?? {};
|
|
7
|
+
this.removeButtonOptions = options.removeButtonOptions ?? {};
|
|
9
8
|
this.defaultValues = options.defaultValues ?? [];
|
|
9
|
+
this.label = options.label;
|
|
10
|
+
this.labelOptions = options.labelOptions ?? {};
|
|
10
11
|
}
|
|
11
12
|
}
|
|
12
13
|
//# sourceMappingURL=array-field.type.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"array-field.type.js","sourceRoot":"","sources":["../../../lib/types/array-field.type.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"array-field.type.js","sourceRoot":"","sources":["../../../lib/types/array-field.type.tsx"],"names":[],"mappings":"AAQA,MAAM,OAAO,UAAU;IAUrB,YAAY,OAA8B;QAT1C,cAAS,GAAY,YAAY,CAAC;QAUhC,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;QACrB,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,IAAI,EAAE,CAAC;QACnC,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,gBAAgB,IAAI,EAAE,CAAC;QACvD,IAAI,CAAC,mBAAmB,GAAG,OAAO,CAAC,mBAAmB,IAAI,EAAE,CAAC;QAC7D,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,EAAE,CAAC;QACjD,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;QAC3B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,IAAI,EAAE,CAAC;IACjD,CAAC;CACF"}
|
package/dist/esm/types/index.js
CHANGED
|
@@ -4,4 +4,6 @@ export * from "./dynamic-object.type";
|
|
|
4
4
|
export * from "./submit-button-default-options.type";
|
|
5
5
|
export * from "./group-field.type";
|
|
6
6
|
export * from "./array-field.type";
|
|
7
|
+
export * from "./array-field-action-button.type";
|
|
8
|
+
export * from "./label-options.type";
|
|
7
9
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/types/index.tsx"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../lib/types/index.tsx"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,sCAAsC,CAAC;AACrD,cAAc,oBAAoB,CAAC;AACnC,cAAc,oBAAoB,CAAC;AACnC,cAAc,kCAAkC,CAAC;AACjD,cAAc,sBAAsB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"label-options.type.js","sourceRoot":"","sources":["../../../lib/types/label-options.type.tsx"],"names":[],"mappings":"AAAA,MAAM,OAAO,YAAY;IAGvB,YAAY,OAAqB;QAC/B,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;IACnC,CAAC;CACF"}
|
|
@@ -323,12 +323,9 @@ export const FieldArray: { args: INvsDynamicForm; name: string } = {
|
|
|
323
323
|
}),
|
|
324
324
|
new ArrayField({
|
|
325
325
|
id: "addresses",
|
|
326
|
-
|
|
327
|
-
label: "-",
|
|
328
|
-
position: "right",
|
|
329
|
-
},
|
|
326
|
+
label: "Addresses",
|
|
330
327
|
addButtonOptions: {
|
|
331
|
-
label: "
|
|
328
|
+
label: "Add Address",
|
|
332
329
|
},
|
|
333
330
|
defaultValues: [
|
|
334
331
|
{ cityName: "İzmir", districtName: "Göztepe" },
|
|
@@ -24,6 +24,8 @@ export const NvsDynamicForm = ({
|
|
|
24
24
|
containerOptions = {},
|
|
25
25
|
useContainersOutsideGroup = false,
|
|
26
26
|
useGroupContainer = false,
|
|
27
|
+
addButtonDefaultOptions,
|
|
28
|
+
removeButtonDefaultOptions,
|
|
27
29
|
}: INvsDynamicForm) => {
|
|
28
30
|
const generateFormContentUtils = new GenerateFormContentUtils({
|
|
29
31
|
containerComponent: container,
|
|
@@ -34,6 +36,8 @@ export const NvsDynamicForm = ({
|
|
|
34
36
|
fields,
|
|
35
37
|
containerOptions,
|
|
36
38
|
buttonComponent,
|
|
39
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
40
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
37
41
|
});
|
|
38
42
|
|
|
39
43
|
const formikForm = (
|
|
@@ -1,16 +1,18 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ArrayField,
|
|
3
|
+
ArrayFieldAddButton,
|
|
4
|
+
ArrayFieldRemoveButton,
|
|
3
5
|
FieldBase,
|
|
4
6
|
GroupField,
|
|
5
7
|
ISubmitButtonDefaultOptions,
|
|
8
|
+
LabelOptions,
|
|
6
9
|
} from "../types";
|
|
7
10
|
|
|
8
|
-
import { IButton } from "./elements/button/_type";
|
|
9
11
|
import { IField } from "./elements/field";
|
|
10
12
|
|
|
11
13
|
export type FieldType = FieldBase<any> | GroupField | ArrayField<any>;
|
|
12
14
|
|
|
13
|
-
export interface INvsDynamicForm extends
|
|
15
|
+
export interface INvsDynamicForm extends Omit<IField, "field"> {
|
|
14
16
|
onSubmit?: ((values: unknown) => void) | ((values: unknown) => Promise<void>);
|
|
15
17
|
fields: Array<FieldType>;
|
|
16
18
|
formClass?: string;
|
|
@@ -19,10 +21,14 @@ export interface INvsDynamicForm extends IButton, Omit<IField, "field"> {
|
|
|
19
21
|
containerVisible?: boolean;
|
|
20
22
|
useContainersOutsideGroup?: boolean;
|
|
21
23
|
useGroupContainer?: boolean;
|
|
24
|
+
buttonComponent: React.FC<any>;
|
|
22
25
|
submitButtonDefaultOptions: ISubmitButtonDefaultOptions;
|
|
23
26
|
submitButtonVisible?: boolean;
|
|
24
27
|
submitButtonLabel?: string;
|
|
25
28
|
submitButtonPosition?: "left" | "center" | "right";
|
|
26
29
|
submitButtonIsFullWidth?: boolean;
|
|
27
30
|
submitButtonContainerClass?: string;
|
|
31
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
32
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
33
|
+
labelDefaultOptions?: LabelOptions;
|
|
28
34
|
}
|
|
@@ -1,7 +1,15 @@
|
|
|
1
|
+
import * as lodash from "lodash";
|
|
2
|
+
|
|
3
|
+
import {
|
|
4
|
+
ArrayFieldAddButton,
|
|
5
|
+
ArrayFieldRemoveButton,
|
|
6
|
+
LabelOptions,
|
|
7
|
+
} from "../../../types";
|
|
8
|
+
import React, { useState } from "react";
|
|
9
|
+
|
|
1
10
|
import { FieldArray } from "formik";
|
|
2
11
|
import { GenerateFormContentUtils } from "../../services/generateFormContentUtils";
|
|
3
12
|
import { IArrayField } from "./_type";
|
|
4
|
-
import React from "react";
|
|
5
13
|
|
|
6
14
|
export const ArrayField: React.FC<IArrayField> = ({
|
|
7
15
|
field: arrayField,
|
|
@@ -11,7 +19,31 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
11
19
|
useContainersOutsideGroup,
|
|
12
20
|
useGroupContainer,
|
|
13
21
|
buttonComponent: ButtonComponent,
|
|
14
|
-
|
|
22
|
+
addButtonDefaultOptions,
|
|
23
|
+
removeButtonDefaultOptions,
|
|
24
|
+
labelDefaultOptions,
|
|
25
|
+
}: IArrayField) => {
|
|
26
|
+
const [addButtonOptions] = useState(
|
|
27
|
+
new ArrayFieldAddButton(
|
|
28
|
+
lodash.merge(
|
|
29
|
+
addButtonDefaultOptions ?? {},
|
|
30
|
+
arrayField.addButtonOptions ?? {},
|
|
31
|
+
),
|
|
32
|
+
),
|
|
33
|
+
);
|
|
34
|
+
const [removeButtonOptions] = useState(
|
|
35
|
+
new ArrayFieldRemoveButton(
|
|
36
|
+
lodash.merge(
|
|
37
|
+
removeButtonDefaultOptions ?? {},
|
|
38
|
+
arrayField.removeButtonOptions ?? {},
|
|
39
|
+
),
|
|
40
|
+
),
|
|
41
|
+
);
|
|
42
|
+
const [labelOptions] = useState(
|
|
43
|
+
new LabelOptions(
|
|
44
|
+
lodash.merge(labelDefaultOptions ?? {}, arrayField.labelOptions ?? {}),
|
|
45
|
+
),
|
|
46
|
+
);
|
|
15
47
|
const generateFormContentUtils = new GenerateFormContentUtils({
|
|
16
48
|
containerComponent,
|
|
17
49
|
formElements,
|
|
@@ -19,6 +51,8 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
19
51
|
useGroupContainer,
|
|
20
52
|
containerVisible: containerVisible,
|
|
21
53
|
fields: arrayField.fields,
|
|
54
|
+
fieldArrayAddButtonDefaultOptions: addButtonDefaultOptions,
|
|
55
|
+
fieldArrayRemoveButtonDefaultOptions: removeButtonDefaultOptions,
|
|
22
56
|
});
|
|
23
57
|
|
|
24
58
|
const createArrayItem = (name: string, index: number) => {
|
|
@@ -57,8 +91,9 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
57
91
|
onRemoveItem();
|
|
58
92
|
}}
|
|
59
93
|
type="button"
|
|
94
|
+
{...removeButtonOptions.options}
|
|
60
95
|
>
|
|
61
|
-
{
|
|
96
|
+
{removeButtonOptions.label}
|
|
62
97
|
</ButtonComponent>
|
|
63
98
|
</div>
|
|
64
99
|
);
|
|
@@ -80,7 +115,7 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
80
115
|
) => {
|
|
81
116
|
return (
|
|
82
117
|
<div
|
|
83
|
-
className={`df-array-field remove-button-${
|
|
118
|
+
className={`df-array-field remove-button-${removeButtonOptions.position}`}
|
|
84
119
|
key={index}
|
|
85
120
|
>
|
|
86
121
|
{createArrayFields(index)}
|
|
@@ -95,8 +130,9 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
95
130
|
<ButtonComponent
|
|
96
131
|
onClick={() => onAddItem(getDefaultItem())}
|
|
97
132
|
type="button"
|
|
133
|
+
{...addButtonOptions.options}
|
|
98
134
|
>
|
|
99
|
-
{
|
|
135
|
+
{addButtonOptions.label}
|
|
100
136
|
</ButtonComponent>
|
|
101
137
|
</div>
|
|
102
138
|
);
|
|
@@ -108,10 +144,21 @@ export const ArrayField: React.FC<IArrayField> = ({
|
|
|
108
144
|
);
|
|
109
145
|
};
|
|
110
146
|
|
|
147
|
+
const createArrayFieldLabel = () => {
|
|
148
|
+
return generateFormContentUtils.createContentContainer(
|
|
149
|
+
<div className="nvs-col-12">
|
|
150
|
+
<label className={`df-array-field-label ${labelOptions.class}`}>
|
|
151
|
+
{arrayField.label}
|
|
152
|
+
</label>
|
|
153
|
+
</div>,
|
|
154
|
+
);
|
|
155
|
+
};
|
|
156
|
+
|
|
111
157
|
return (
|
|
112
158
|
<FieldArray name={arrayField.id}>
|
|
113
159
|
{({ push, remove, form }) => (
|
|
114
160
|
<>
|
|
161
|
+
{arrayField.label && createArrayFieldLabel()}
|
|
115
162
|
{form.values[arrayField.id]?.map((_: any, index: number) =>
|
|
116
163
|
createFieldArrayContent(remove, index),
|
|
117
164
|
)}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {
|
|
2
|
+
ArrayField,
|
|
3
|
+
ArrayFieldAddButton,
|
|
4
|
+
ArrayFieldRemoveButton,
|
|
5
|
+
LabelOptions,
|
|
6
|
+
} from "../../../types";
|
|
7
|
+
|
|
2
8
|
import { IField } from "../field";
|
|
3
9
|
|
|
4
10
|
export interface IArrayField extends IField {
|
|
@@ -8,4 +14,7 @@ export interface IArrayField extends IField {
|
|
|
8
14
|
containerVisible: boolean;
|
|
9
15
|
useContainersOutsideGroup: boolean;
|
|
10
16
|
useGroupContainer: boolean;
|
|
17
|
+
addButtonDefaultOptions?: ArrayFieldAddButton;
|
|
18
|
+
removeButtonDefaultOptions?: ArrayFieldRemoveButton;
|
|
19
|
+
labelDefaultOptions?: LabelOptions;
|
|
11
20
|
}
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import {
|
|
2
|
+
ArrayField,
|
|
3
|
+
ArrayFieldAddButton,
|
|
4
|
+
FieldBase,
|
|
5
|
+
GroupField,
|
|
6
|
+
LabelOptions,
|
|
7
|
+
} from "../../types";
|
|
2
8
|
|
|
3
9
|
import { ArrayField as ArrayFieldElement } from "../elements/arrayField";
|
|
4
10
|
import { Container } from "../elements/container";
|
|
@@ -18,6 +24,9 @@ export class GenerateFormContentUtils {
|
|
|
18
24
|
private readonly fields: Array<FieldType>;
|
|
19
25
|
private readonly containerOptions: { [key: string]: any };
|
|
20
26
|
private readonly buttonComponent?: React.FC<any>;
|
|
27
|
+
private readonly fieldArrayAddButtonDefaultOptions: ArrayFieldAddButton;
|
|
28
|
+
private readonly fieldArrayRemoveButtonDefaultOptions: ArrayFieldAddButton;
|
|
29
|
+
private readonly labelDefaultOptions: LabelOptions;
|
|
21
30
|
|
|
22
31
|
constructor({
|
|
23
32
|
containerComponent,
|
|
@@ -28,6 +37,9 @@ export class GenerateFormContentUtils {
|
|
|
28
37
|
fields,
|
|
29
38
|
containerOptions,
|
|
30
39
|
buttonComponent,
|
|
40
|
+
fieldArrayAddButtonDefaultOptions,
|
|
41
|
+
fieldArrayRemoveButtonDefaultOptions,
|
|
42
|
+
labelDefaultOptions,
|
|
31
43
|
}: {
|
|
32
44
|
containerComponent: React.FC<any>;
|
|
33
45
|
formElements: IFormElement;
|
|
@@ -37,6 +49,9 @@ export class GenerateFormContentUtils {
|
|
|
37
49
|
fields: Array<FieldType>;
|
|
38
50
|
buttonComponent?: React.FC<any>;
|
|
39
51
|
containerOptions?: { [key: string]: any };
|
|
52
|
+
fieldArrayAddButtonDefaultOptions?: ArrayFieldAddButton;
|
|
53
|
+
fieldArrayRemoveButtonDefaultOptions?: ArrayFieldAddButton;
|
|
54
|
+
labelDefaultOptions?: LabelOptions;
|
|
40
55
|
}) {
|
|
41
56
|
this.containerComponent = containerComponent;
|
|
42
57
|
this.formElements = formElements;
|
|
@@ -44,8 +59,13 @@ export class GenerateFormContentUtils {
|
|
|
44
59
|
this.useGroupContainer = useGroupContainer;
|
|
45
60
|
this.containerVisible = containerVisible;
|
|
46
61
|
this.fields = fields;
|
|
47
|
-
this.containerOptions = containerOptions
|
|
62
|
+
this.containerOptions = containerOptions ?? {};
|
|
48
63
|
this.buttonComponent = buttonComponent;
|
|
64
|
+
this.fieldArrayAddButtonDefaultOptions =
|
|
65
|
+
fieldArrayAddButtonDefaultOptions ?? {};
|
|
66
|
+
this.fieldArrayRemoveButtonDefaultOptions =
|
|
67
|
+
fieldArrayRemoveButtonDefaultOptions ?? {};
|
|
68
|
+
this.labelDefaultOptions = labelDefaultOptions ?? {};
|
|
49
69
|
}
|
|
50
70
|
|
|
51
71
|
createContainer(content: ReactNode, containerProps: object) {
|
|
@@ -154,6 +174,9 @@ export class GenerateFormContentUtils {
|
|
|
154
174
|
useGroupContainer={this.useGroupContainer}
|
|
155
175
|
containerVisible={this.containerVisible}
|
|
156
176
|
buttonComponent={this.buttonComponent!}
|
|
177
|
+
addButtonDefaultOptions={this.fieldArrayAddButtonDefaultOptions}
|
|
178
|
+
removeButtonDefaultOptions={this.fieldArrayRemoveButtonDefaultOptions}
|
|
179
|
+
labelDefaultOptions={this.labelDefaultOptions}
|
|
157
180
|
/>
|
|
158
181
|
);
|
|
159
182
|
}
|
|
@@ -4,6 +4,7 @@ import {
|
|
|
4
4
|
} from "./array-field-action-button.type";
|
|
5
5
|
|
|
6
6
|
import { FieldBase } from "./field-base.type";
|
|
7
|
+
import { LabelOptions } from "./label-options.type";
|
|
7
8
|
|
|
8
9
|
export class ArrayField<ValueType = { [key: string]: any }> {
|
|
9
10
|
fieldType?: string = "fieldArray";
|
|
@@ -12,16 +13,16 @@ export class ArrayField<ValueType = { [key: string]: any }> {
|
|
|
12
13
|
addButtonOptions?: ArrayFieldAddButton;
|
|
13
14
|
removeButtonOptions?: ArrayFieldRemoveButton;
|
|
14
15
|
defaultValues?: Array<ValueType>;
|
|
16
|
+
label?: string;
|
|
17
|
+
labelOptions?: LabelOptions;
|
|
15
18
|
|
|
16
19
|
constructor(options: ArrayField<ValueType>) {
|
|
17
20
|
this.id = options.id;
|
|
18
21
|
this.fields = options.fields ?? [];
|
|
19
|
-
this.addButtonOptions =
|
|
20
|
-
|
|
21
|
-
);
|
|
22
|
-
this.removeButtonOptions = new ArrayFieldRemoveButton(
|
|
23
|
-
options.removeButtonOptions ?? {},
|
|
24
|
-
);
|
|
22
|
+
this.addButtonOptions = options.addButtonOptions ?? {};
|
|
23
|
+
this.removeButtonOptions = options.removeButtonOptions ?? {};
|
|
25
24
|
this.defaultValues = options.defaultValues ?? [];
|
|
25
|
+
this.label = options.label;
|
|
26
|
+
this.labelOptions = options.labelOptions ?? {};
|
|
26
27
|
}
|
|
27
28
|
}
|
package/lib/types/index.tsx
CHANGED