graphql-form 0.0.15 → 0.0.18
Sign up to get free protection for your applications and to get access to all the features.
- package/lib/models.d.ts +7 -1
- package/lib/models.js +6 -0
- package/lib/models.js.map +1 -1
- package/lib/outsideUse.d.ts +7 -2
- package/lib/outsideUse.js +106 -5
- package/lib/outsideUse.js.map +1 -1
- package/package.json +1 -1
- package/src/models.ts +8 -1
- package/src/outsideUse.tsx +130 -4
package/lib/models.d.ts
CHANGED
@@ -12,6 +12,10 @@ export declare type WidgetSavedData = {
|
|
12
12
|
export declare type SavedWidgets = {
|
13
13
|
[selector: string]: WidgetSavedData | undefined;
|
14
14
|
};
|
15
|
+
export declare const enum Errs {
|
16
|
+
REQUIRED = "REQUIRED",
|
17
|
+
VALUE_IN_ARRAY_REQUIRED = "VALUE_IN_ARRAY_REQUIRED"
|
18
|
+
}
|
15
19
|
export declare type Errors = {
|
16
20
|
[selector: string]: string;
|
17
21
|
};
|
@@ -36,8 +40,8 @@ export declare type PassedFormProps<WidgetData = ReturnedDictType> = {
|
|
36
40
|
widgetVariants?: WidgetVariantType[];
|
37
41
|
currentPath: string;
|
38
42
|
widgets?: SavedWidgets;
|
39
|
-
errors?: Errors;
|
40
43
|
widgetData?: WidgetData;
|
44
|
+
errors?: Errors;
|
41
45
|
components: {
|
42
46
|
ArrayField: FieldComponent;
|
43
47
|
ObjectField: FieldComponent;
|
@@ -75,6 +79,8 @@ export declare type WidgetType = {
|
|
75
79
|
name: string;
|
76
80
|
};
|
77
81
|
export declare type FormValue = {
|
82
|
+
value: FormValue;
|
83
|
+
} | {
|
78
84
|
[x: string]: FormValue;
|
79
85
|
} | string | boolean | number | null | undefined | FormObject | Array<FormValue>;
|
80
86
|
export declare type FormObject = {
|
package/lib/models.js
CHANGED
@@ -1,3 +1,9 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Errs = void 0;
|
4
|
+
var Errs;
|
5
|
+
(function (Errs) {
|
6
|
+
Errs["REQUIRED"] = "REQUIRED";
|
7
|
+
Errs["VALUE_IN_ARRAY_REQUIRED"] = "VALUE_IN_ARRAY_REQUIRED";
|
8
|
+
})(Errs = exports.Errs || (exports.Errs = {}));
|
3
9
|
//# sourceMappingURL=models.js.map
|
package/lib/models.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"models.js","sourceRoot":"","sources":["../src/models.ts"],"names":[],"mappings":""}
|
1
|
+
{"version":3,"file":"models.js","sourceRoot":"","sources":["../src/models.ts"],"names":[],"mappings":";;;AAgBA,IAAkB,IAGjB;AAHD,WAAkB,IAAI;IAClB,6BAAqB,CAAA;IACrB,2DAAmD,CAAA;AACvD,CAAC,EAHiB,IAAI,GAAJ,YAAI,KAAJ,YAAI,QAGrB"}
|
package/lib/outsideUse.d.ts
CHANGED
@@ -1,6 +1,11 @@
|
|
1
|
-
import { PassedFormProps } from "./models";
|
1
|
+
import { Errs, FormFile, FormObject, FormValue, PassedFormProps } from "./models";
|
2
|
+
import { ParserField } from 'graphql-js-tree';
|
2
3
|
export declare const getWidgetFromProps: (props: PassedFormProps) => {
|
3
4
|
data: any;
|
4
5
|
widget: import("./models").WidgetType;
|
5
6
|
} | undefined;
|
6
|
-
export declare const
|
7
|
+
export declare const getErrorFromProps: (props: PassedFormProps) => string | undefined;
|
8
|
+
export declare const validateValue: (f: FormValue, nodes: ParserField[], path: string, pushErrors: (path: string, value: Errs) => void) => void;
|
9
|
+
export declare const validateForm: (v: FormFile, nodes: ParserField[], errors: Record<Errs, string>) => Record<string, string>;
|
10
|
+
export declare const eraseValue: (f: FormObject, nodes: ParserField[]) => FormObject;
|
11
|
+
export declare const eraseForm: (v: FormFile, nodes: ParserField[]) => FormFile;
|
package/lib/outsideUse.js
CHANGED
@@ -11,7 +11,9 @@ var __assign = (this && this.__assign) || function () {
|
|
11
11
|
return __assign.apply(this, arguments);
|
12
12
|
};
|
13
13
|
Object.defineProperty(exports, "__esModule", { value: true });
|
14
|
-
exports.
|
14
|
+
exports.eraseForm = exports.eraseValue = exports.validateForm = exports.validateValue = exports.getErrorFromProps = exports.getWidgetFromProps = void 0;
|
15
|
+
var models_1 = require("./models");
|
16
|
+
var graphql_js_tree_1 = require("graphql-js-tree");
|
15
17
|
var getWidgetFromProps = function (props) {
|
16
18
|
var _a, _b;
|
17
19
|
var w = (_a = props.widgets) === null || _a === void 0 ? void 0 : _a[props.currentPath];
|
@@ -36,10 +38,109 @@ var getWidgetFromProps = function (props) {
|
|
36
38
|
};
|
37
39
|
};
|
38
40
|
exports.getWidgetFromProps = getWidgetFromProps;
|
39
|
-
var
|
41
|
+
var getErrorFromProps = function (props) {
|
40
42
|
var _a;
|
41
|
-
|
42
|
-
return e;
|
43
|
+
return (_a = props.errors) === null || _a === void 0 ? void 0 : _a[props.currentPath];
|
43
44
|
};
|
44
|
-
exports.
|
45
|
+
exports.getErrorFromProps = getErrorFromProps;
|
46
|
+
var validateValue = function (f, nodes, path, pushErrors) {
|
47
|
+
if (f === null ||
|
48
|
+
typeof f === 'string' ||
|
49
|
+
typeof f === 'boolean' ||
|
50
|
+
typeof f === 'number' ||
|
51
|
+
typeof f === 'undefined') {
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
if ('node' in f &&
|
55
|
+
typeof f.node === 'object' &&
|
56
|
+
f.node !== null &&
|
57
|
+
'args' in f.node &&
|
58
|
+
'data' in f.node &&
|
59
|
+
typeof f.node.data === 'object' &&
|
60
|
+
!!f.node.data &&
|
61
|
+
'type' in f.node.data &&
|
62
|
+
'directives' in f.node) {
|
63
|
+
var _a = f, node = _a.node, value = _a.value;
|
64
|
+
if (node.data.type === graphql_js_tree_1.ValueDefinition.InputValueDefinition) {
|
65
|
+
if (node.type.fieldType.type === graphql_js_tree_1.Options.required) {
|
66
|
+
if (!value) {
|
67
|
+
pushErrors(path, models_1.Errs.REQUIRED);
|
68
|
+
}
|
69
|
+
if (node.type.fieldType.nest.type === graphql_js_tree_1.Options.array &&
|
70
|
+
node.type.fieldType.nest.nest.type === graphql_js_tree_1.Options.required) {
|
71
|
+
if (Array.isArray(value)) {
|
72
|
+
for (var _i = 0, value_1 = value; _i < value_1.length; _i++) {
|
73
|
+
var v = value_1[_i];
|
74
|
+
if (!v) {
|
75
|
+
pushErrors(path, models_1.Errs.VALUE_IN_ARRAY_REQUIRED);
|
76
|
+
}
|
77
|
+
}
|
78
|
+
}
|
79
|
+
}
|
80
|
+
}
|
81
|
+
}
|
82
|
+
}
|
83
|
+
if ('value' in f && !!f.value) {
|
84
|
+
var value = f.value;
|
85
|
+
if (Array.isArray(value)) {
|
86
|
+
value.map(function (vv) { return (0, exports.validateValue)(vv, nodes, path, pushErrors); });
|
87
|
+
return;
|
88
|
+
}
|
89
|
+
if (typeof value === 'object' && !!value) {
|
90
|
+
Object.entries(value).forEach(function (_a) {
|
91
|
+
var k = _a[0], v = _a[1];
|
92
|
+
return (0, exports.validateValue)(v, nodes, "".concat(path, ".").concat(k), pushErrors);
|
93
|
+
});
|
94
|
+
return;
|
95
|
+
}
|
96
|
+
}
|
97
|
+
return;
|
98
|
+
};
|
99
|
+
exports.validateValue = validateValue;
|
100
|
+
var validateForm = function (v, nodes, errors) {
|
101
|
+
var errorDict = {};
|
102
|
+
if (!v.forms)
|
103
|
+
return errorDict;
|
104
|
+
Object.entries(v.forms).forEach(function (_a) {
|
105
|
+
var k = _a[0], val = _a[1];
|
106
|
+
(0, exports.validateValue)(val, nodes, k, function (p, err) {
|
107
|
+
errorDict[p] = errors[err];
|
108
|
+
});
|
109
|
+
});
|
110
|
+
return errorDict;
|
111
|
+
};
|
112
|
+
exports.validateForm = validateForm;
|
113
|
+
var eraseValue = function (f, nodes) {
|
114
|
+
var value = f.value, node = f.node;
|
115
|
+
var seekNode = nodes.find(function (n) { return n.name === (0, graphql_js_tree_1.getTypeName)(node.type.fieldType); });
|
116
|
+
if (!seekNode ||
|
117
|
+
(seekNode === null || seekNode === void 0 ? void 0 : seekNode.data.type) === graphql_js_tree_1.TypeDefinition.EnumTypeDefinition ||
|
118
|
+
(seekNode === null || seekNode === void 0 ? void 0 : seekNode.data.type) === graphql_js_tree_1.TypeDefinition.ScalarTypeDefinition) {
|
119
|
+
return __assign(__assign({}, f), { value: undefined });
|
120
|
+
}
|
121
|
+
if ((seekNode || node.data.type === graphql_js_tree_1.TypeSystemDefinition.FieldDefinition) && value) {
|
122
|
+
return __assign(__assign({}, f), { value: Object.fromEntries(Object.entries(value).map(function (_a) {
|
123
|
+
var k = _a[0], v = _a[1];
|
124
|
+
return [k, (0, exports.eraseValue)(v, nodes)];
|
125
|
+
})) });
|
126
|
+
}
|
127
|
+
return __assign(__assign({}, f), { value: undefined });
|
128
|
+
};
|
129
|
+
exports.eraseValue = eraseValue;
|
130
|
+
var eraseForm = function (v, nodes) {
|
131
|
+
if (!v.forms)
|
132
|
+
return v;
|
133
|
+
var forms = Object.entries(v.forms)
|
134
|
+
.map(function (_a) {
|
135
|
+
var k = _a[0], val = _a[1];
|
136
|
+
return [k, (0, exports.eraseValue)(val, nodes)];
|
137
|
+
})
|
138
|
+
.reduce(function (a, _a) {
|
139
|
+
var _b;
|
140
|
+
var k = _a[0], val = _a[1];
|
141
|
+
return (__assign(__assign({}, a), (_b = {}, _b[k] = val, _b)));
|
142
|
+
}, {});
|
143
|
+
return __assign(__assign({}, v), { forms: forms });
|
144
|
+
};
|
145
|
+
exports.eraseForm = eraseForm;
|
45
146
|
//# sourceMappingURL=outsideUse.js.map
|
package/lib/outsideUse.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"outsideUse.js","sourceRoot":"","sources":["../src/outsideUse.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;
|
1
|
+
{"version":3,"file":"outsideUse.js","sourceRoot":"","sources":["../src/outsideUse.tsx"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/src/models.ts
CHANGED
@@ -13,6 +13,12 @@ export type WidgetSavedData = {
|
|
13
13
|
export type SavedWidgets = {
|
14
14
|
[selector: string]: WidgetSavedData | undefined;
|
15
15
|
};
|
16
|
+
|
17
|
+
export const enum Errs {
|
18
|
+
REQUIRED = 'REQUIRED',
|
19
|
+
VALUE_IN_ARRAY_REQUIRED = 'VALUE_IN_ARRAY_REQUIRED',
|
20
|
+
}
|
21
|
+
|
16
22
|
export type Errors = {
|
17
23
|
[selector: string]: string;
|
18
24
|
};
|
@@ -41,8 +47,8 @@ export type PassedFormProps<WidgetData = ReturnedDictType> = {
|
|
41
47
|
widgetVariants?: WidgetVariantType[];
|
42
48
|
currentPath: string;
|
43
49
|
widgets?: SavedWidgets;
|
44
|
-
errors?: Errors;
|
45
50
|
widgetData?: WidgetData;
|
51
|
+
errors?: Errors;
|
46
52
|
components: {
|
47
53
|
ArrayField: FieldComponent;
|
48
54
|
ObjectField: FieldComponent;
|
@@ -94,6 +100,7 @@ export type WidgetType = {
|
|
94
100
|
};
|
95
101
|
|
96
102
|
export type FormValue =
|
103
|
+
| { value: FormValue }
|
97
104
|
| {
|
98
105
|
[x: string]: FormValue;
|
99
106
|
}
|
package/src/outsideUse.tsx
CHANGED
@@ -1,4 +1,12 @@
|
|
1
|
-
import { PassedFormProps } from '@/models';
|
1
|
+
import { Errs, FormFile, FormObject, FormValue, PassedFormProps } from '@/models';
|
2
|
+
import {
|
3
|
+
getTypeName,
|
4
|
+
Options,
|
5
|
+
ParserField,
|
6
|
+
TypeDefinition,
|
7
|
+
TypeSystemDefinition,
|
8
|
+
ValueDefinition,
|
9
|
+
} from 'graphql-js-tree';
|
2
10
|
|
3
11
|
export const getWidgetFromProps = (props: PassedFormProps) => {
|
4
12
|
const w = props.widgets?.[props.currentPath];
|
@@ -25,7 +33,125 @@ export const getWidgetFromProps = (props: PassedFormProps) => {
|
|
25
33
|
widget: FoundBasicWidget,
|
26
34
|
};
|
27
35
|
};
|
28
|
-
export const
|
29
|
-
|
30
|
-
|
36
|
+
export const getErrorFromProps = (props: PassedFormProps) => {
|
37
|
+
return props.errors?.[props.currentPath];
|
38
|
+
};
|
39
|
+
|
40
|
+
export const validateValue = (
|
41
|
+
f: FormValue,
|
42
|
+
nodes: ParserField[],
|
43
|
+
path: string,
|
44
|
+
pushErrors: (path: string, value: Errs) => void,
|
45
|
+
) => {
|
46
|
+
if (
|
47
|
+
f === null ||
|
48
|
+
typeof f === 'string' ||
|
49
|
+
typeof f === 'boolean' ||
|
50
|
+
typeof f === 'number' ||
|
51
|
+
typeof f === 'undefined'
|
52
|
+
) {
|
53
|
+
return;
|
54
|
+
}
|
55
|
+
if (
|
56
|
+
'node' in f &&
|
57
|
+
typeof f.node === 'object' &&
|
58
|
+
f.node !== null &&
|
59
|
+
'args' in f.node &&
|
60
|
+
'data' in f.node &&
|
61
|
+
typeof f.node.data === 'object' &&
|
62
|
+
!!f.node.data &&
|
63
|
+
'type' in f.node.data &&
|
64
|
+
'directives' in f.node
|
65
|
+
) {
|
66
|
+
const { node, value } = f as FormObject;
|
67
|
+
if (node.data.type === ValueDefinition.InputValueDefinition) {
|
68
|
+
if (node.type.fieldType.type === Options.required) {
|
69
|
+
if (!value) {
|
70
|
+
pushErrors(path, Errs.REQUIRED);
|
71
|
+
}
|
72
|
+
if (
|
73
|
+
node.type.fieldType.nest.type === Options.array &&
|
74
|
+
node.type.fieldType.nest.nest.type === Options.required
|
75
|
+
) {
|
76
|
+
if (Array.isArray(value)) {
|
77
|
+
for (const v of value) {
|
78
|
+
if (!v) {
|
79
|
+
pushErrors(path, Errs.VALUE_IN_ARRAY_REQUIRED);
|
80
|
+
}
|
81
|
+
}
|
82
|
+
}
|
83
|
+
}
|
84
|
+
}
|
85
|
+
}
|
86
|
+
}
|
87
|
+
if ('value' in f && !!f.value) {
|
88
|
+
const { value } = f;
|
89
|
+
if (Array.isArray(value)) {
|
90
|
+
value.map((vv) => validateValue(vv, nodes, path, pushErrors));
|
91
|
+
return;
|
92
|
+
}
|
93
|
+
if (typeof value === 'object' && !!value) {
|
94
|
+
Object.entries(value).forEach(([k, v]) =>
|
95
|
+
validateValue(v as FormObject, nodes, `${path}.${k}`, pushErrors),
|
96
|
+
);
|
97
|
+
return;
|
98
|
+
}
|
99
|
+
}
|
100
|
+
return;
|
101
|
+
};
|
102
|
+
|
103
|
+
export const validateForm = (v: FormFile, nodes: ParserField[], errors: Record<Errs, string>) => {
|
104
|
+
const errorDict: Record<string, string> = {};
|
105
|
+
if (!v.forms) return errorDict;
|
106
|
+
Object.entries(v.forms).forEach(([k, val]) => {
|
107
|
+
validateValue(val, nodes, k, (p, err) => {
|
108
|
+
errorDict[p] = errors[err];
|
109
|
+
});
|
110
|
+
});
|
111
|
+
return errorDict;
|
112
|
+
};
|
113
|
+
|
114
|
+
export const eraseValue = (f: FormObject, nodes: ParserField[]): FormObject => {
|
115
|
+
const { value, node } = f;
|
116
|
+
|
117
|
+
const seekNode = nodes.find((n) => n.name === getTypeName(node.type.fieldType));
|
118
|
+
if (
|
119
|
+
!seekNode ||
|
120
|
+
seekNode?.data.type === TypeDefinition.EnumTypeDefinition ||
|
121
|
+
seekNode?.data.type === TypeDefinition.ScalarTypeDefinition
|
122
|
+
) {
|
123
|
+
return {
|
124
|
+
...f,
|
125
|
+
value: undefined,
|
126
|
+
};
|
127
|
+
}
|
128
|
+
if ((seekNode || node.data.type === TypeSystemDefinition.FieldDefinition) && value) {
|
129
|
+
return {
|
130
|
+
...f,
|
131
|
+
value: Object.fromEntries(Object.entries(value).map(([k, v]) => [k, eraseValue(v as FormObject, nodes)])),
|
132
|
+
};
|
133
|
+
}
|
134
|
+
return {
|
135
|
+
...f,
|
136
|
+
value: undefined,
|
137
|
+
};
|
138
|
+
};
|
139
|
+
|
140
|
+
export const eraseForm = (v: FormFile, nodes: ParserField[]) => {
|
141
|
+
if (!v.forms) return v;
|
142
|
+
const forms = Object.entries(v.forms)
|
143
|
+
.map(([k, val]) => {
|
144
|
+
return [k, eraseValue(val, nodes)] as const;
|
145
|
+
})
|
146
|
+
.reduce(
|
147
|
+
(a, [k, val]) => ({
|
148
|
+
...a,
|
149
|
+
[k]: val,
|
150
|
+
}),
|
151
|
+
{} as FormFile['forms'],
|
152
|
+
);
|
153
|
+
return {
|
154
|
+
...v,
|
155
|
+
forms,
|
156
|
+
};
|
31
157
|
};
|