@payloadcms/plugin-form-builder 1.0.15 → 1.0.16-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +17 -16
- package/dist/collections/FormSubmissions/hooks/createCharge.d.ts +1 -0
- package/dist/collections/FormSubmissions/hooks/createCharge.d.ts.map +1 -0
- package/dist/collections/FormSubmissions/hooks/createCharge.js +21 -55
- package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts +1 -0
- package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts.map +1 -0
- package/dist/collections/FormSubmissions/hooks/sendEmail.js +69 -124
- package/dist/collections/FormSubmissions/index.d.ts +1 -0
- package/dist/collections/FormSubmissions/index.d.ts.map +1 -0
- package/dist/collections/FormSubmissions/index.js +70 -66
- package/dist/collections/Forms/DynamicFieldSelector.d.ts +2 -1
- package/dist/collections/Forms/DynamicFieldSelector.d.ts.map +1 -0
- package/dist/collections/Forms/DynamicFieldSelector.js +69 -53
- package/dist/collections/Forms/DynamicPriceSelector.d.ts +2 -1
- package/dist/collections/Forms/DynamicPriceSelector.d.ts.map +1 -0
- package/dist/collections/Forms/DynamicPriceSelector.js +82 -64
- package/dist/collections/Forms/fields.d.ts +2 -1
- package/dist/collections/Forms/fields.d.ts.map +1 -0
- package/dist/collections/Forms/fields.js +352 -270
- package/dist/collections/Forms/index.d.ts +1 -0
- package/dist/collections/Forms/index.d.ts.map +1 -0
- package/dist/collections/Forms/index.js +103 -106
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +51 -38
- package/dist/types.d.ts +70 -69
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +12 -8
- package/dist/utilities/getPaymentTotal.d.ts +1 -0
- package/dist/utilities/getPaymentTotal.d.ts.map +1 -0
- package/dist/utilities/getPaymentTotal.js +44 -34
- package/dist/utilities/replaceDoubleCurlys.d.ts +1 -0
- package/dist/utilities/replaceDoubleCurlys.d.ts.map +1 -0
- package/dist/utilities/replaceDoubleCurlys.js +16 -13
- package/dist/utilities/serializeRichText.d.ts +2 -1
- package/dist/utilities/serializeRichText.d.ts.map +1 -0
- package/dist/utilities/serializeRichText.js +83 -28
- package/package.json +27 -38
- package/types.d.ts +1 -1
- package/types.js +1 -1
- package/dist/collections/FormSubmissions/hooks/createCharge.js.map +0 -1
- package/dist/collections/FormSubmissions/hooks/sendEmail.js.map +0 -1
- package/dist/collections/FormSubmissions/index.js.map +0 -1
- package/dist/collections/Forms/DynamicFieldSelector.js.map +0 -1
- package/dist/collections/Forms/DynamicPriceSelector.js.map +0 -1
- package/dist/collections/Forms/fields.js.map +0 -1
- package/dist/collections/Forms/index.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/mocks/serverModule.d.ts +0 -2
- package/dist/mocks/serverModule.js +0 -4
- package/dist/mocks/serverModule.js.map +0 -1
- package/dist/types.js.map +0 -1
- package/dist/utilities/getPaymentTotal.js.map +0 -1
- package/dist/utilities/replaceDoubleCurlys.js.map +0 -1
- package/dist/utilities/serializeRichText.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/collections/Forms/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAS,gBAAgB,EAAS,MAAM,eAAe,CAAA;AAInE,OAAO,KAAK,EAAe,YAAY,EAAE,MAAM,aAAa,CAAA;AAK5D,eAAO,MAAM,sBAAsB,eAAgB,YAAY,KAAG,gBAiOjE,CAAA"}
|
|
@@ -1,107 +1,101 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
return t;
|
|
10
|
-
};
|
|
11
|
-
return __assign.apply(this, arguments);
|
|
12
|
-
};
|
|
13
|
-
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
14
|
-
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
|
|
15
|
-
if (ar || !(i in from)) {
|
|
16
|
-
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
|
|
17
|
-
ar[i] = from[i];
|
|
18
|
-
}
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "generateFormCollection", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return generateFormCollection;
|
|
19
9
|
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
var generateFormCollection = function (formConfig) {
|
|
31
|
-
var _a, _b, _c, _d;
|
|
32
|
-
var redirect = {
|
|
10
|
+
});
|
|
11
|
+
const _deepmerge = /*#__PURE__*/ _interop_require_default(require("deepmerge"));
|
|
12
|
+
const _fields = require("./fields");
|
|
13
|
+
function _interop_require_default(obj) {
|
|
14
|
+
return obj && obj.__esModule ? obj : {
|
|
15
|
+
default: obj
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
const generateFormCollection = (formConfig)=>{
|
|
19
|
+
const redirect = {
|
|
33
20
|
name: 'redirect',
|
|
34
|
-
type: 'group',
|
|
35
21
|
admin: {
|
|
36
|
-
|
|
37
|
-
|
|
22
|
+
condition: (_, siblingData)=>siblingData?.confirmationType === 'redirect',
|
|
23
|
+
hideGutter: true
|
|
38
24
|
},
|
|
39
25
|
fields: [
|
|
40
26
|
{
|
|
41
27
|
name: 'url',
|
|
42
28
|
label: 'URL to redirect to',
|
|
43
|
-
type: 'text',
|
|
44
29
|
required: true,
|
|
45
|
-
|
|
30
|
+
type: 'text'
|
|
31
|
+
}
|
|
46
32
|
],
|
|
33
|
+
type: 'group'
|
|
47
34
|
};
|
|
48
35
|
if (formConfig.redirectRelationships) {
|
|
49
36
|
redirect.fields.unshift({
|
|
50
37
|
name: 'reference',
|
|
38
|
+
admin: {
|
|
39
|
+
condition: (_, siblingData)=>siblingData?.type === 'reference'
|
|
40
|
+
},
|
|
51
41
|
label: 'Document to link to',
|
|
52
|
-
|
|
42
|
+
maxDepth: 2,
|
|
53
43
|
relationTo: formConfig.redirectRelationships,
|
|
54
44
|
required: true,
|
|
55
|
-
|
|
56
|
-
admin: {
|
|
57
|
-
condition: function (_, siblingData) { return (siblingData === null || siblingData === void 0 ? void 0 : siblingData.type) === 'reference'; },
|
|
58
|
-
},
|
|
45
|
+
type: 'relationship'
|
|
59
46
|
});
|
|
60
47
|
redirect.fields.unshift({
|
|
61
48
|
name: 'type',
|
|
62
|
-
|
|
49
|
+
admin: {
|
|
50
|
+
layout: 'horizontal'
|
|
51
|
+
},
|
|
52
|
+
defaultValue: 'reference',
|
|
63
53
|
options: [
|
|
64
54
|
{
|
|
65
55
|
label: 'Internal link',
|
|
66
|
-
value: 'reference'
|
|
56
|
+
value: 'reference'
|
|
67
57
|
},
|
|
68
58
|
{
|
|
69
59
|
label: 'Custom URL',
|
|
70
|
-
value: 'custom'
|
|
71
|
-
}
|
|
60
|
+
value: 'custom'
|
|
61
|
+
}
|
|
72
62
|
],
|
|
73
|
-
|
|
74
|
-
admin: {
|
|
75
|
-
layout: 'horizontal',
|
|
76
|
-
},
|
|
63
|
+
type: 'radio'
|
|
77
64
|
});
|
|
78
|
-
if (redirect.fields[2].type !== 'row')
|
|
79
|
-
redirect.fields[2].label = 'Custom URL';
|
|
65
|
+
if (redirect.fields[2].type !== 'row') redirect.fields[2].label = 'Custom URL';
|
|
80
66
|
redirect.fields[2].admin = {
|
|
81
|
-
condition:
|
|
67
|
+
condition: (_, siblingData)=>siblingData?.type === 'custom'
|
|
82
68
|
};
|
|
83
69
|
}
|
|
84
|
-
|
|
70
|
+
const config = {
|
|
71
|
+
...formConfig?.formOverrides || {},
|
|
72
|
+
access: {
|
|
73
|
+
read: ()=>true,
|
|
74
|
+
...formConfig?.formOverrides?.access || {}
|
|
75
|
+
},
|
|
76
|
+
admin: {
|
|
77
|
+
enableRichTextRelationship: false,
|
|
78
|
+
useAsTitle: 'title',
|
|
79
|
+
...formConfig?.formOverrides?.admin || {}
|
|
80
|
+
},
|
|
81
|
+
fields: [
|
|
85
82
|
{
|
|
86
83
|
name: 'title',
|
|
87
|
-
type: 'text',
|
|
88
84
|
required: true,
|
|
85
|
+
type: 'text'
|
|
89
86
|
},
|
|
90
87
|
{
|
|
91
88
|
name: 'fields',
|
|
92
|
-
|
|
93
|
-
blocks: Object.entries((formConfig === null || formConfig === void 0 ? void 0 : formConfig.fields) || {})
|
|
94
|
-
.map(function (_a) {
|
|
95
|
-
var fieldKey = _a[0], fieldConfig = _a[1];
|
|
89
|
+
blocks: Object.entries(formConfig?.fields || {}).map(([fieldKey, fieldConfig])=>{
|
|
96
90
|
// let the config enable/disable fields with either boolean values or objects
|
|
97
91
|
if (fieldConfig !== false) {
|
|
98
|
-
|
|
92
|
+
const block = _fields.fields[fieldKey];
|
|
99
93
|
if (block === undefined && typeof fieldConfig === 'object') {
|
|
100
94
|
return fieldConfig;
|
|
101
95
|
}
|
|
102
96
|
if (typeof block === 'object' && typeof fieldConfig === 'object') {
|
|
103
|
-
return (0,
|
|
104
|
-
arrayMerge:
|
|
97
|
+
return (0, _deepmerge.default)(block, fieldConfig, {
|
|
98
|
+
arrayMerge: (_, sourceArray)=>sourceArray
|
|
105
99
|
});
|
|
106
100
|
}
|
|
107
101
|
if (typeof block === 'function') {
|
|
@@ -110,124 +104,127 @@ var generateFormCollection = function (formConfig) {
|
|
|
110
104
|
return block;
|
|
111
105
|
}
|
|
112
106
|
return null;
|
|
113
|
-
})
|
|
114
|
-
|
|
107
|
+
}).filter(Boolean),
|
|
108
|
+
type: 'blocks'
|
|
115
109
|
},
|
|
116
110
|
{
|
|
117
111
|
name: 'submitButtonLabel',
|
|
118
|
-
type: 'text',
|
|
119
112
|
localized: true,
|
|
113
|
+
type: 'text'
|
|
120
114
|
},
|
|
121
115
|
{
|
|
122
116
|
name: 'confirmationType',
|
|
123
|
-
type: 'radio',
|
|
124
117
|
admin: {
|
|
125
118
|
description: 'Choose whether to display an on-page message or redirect to a different page after they submit the form.',
|
|
126
|
-
layout: 'horizontal'
|
|
119
|
+
layout: 'horizontal'
|
|
127
120
|
},
|
|
121
|
+
defaultValue: 'message',
|
|
128
122
|
options: [
|
|
129
123
|
{
|
|
130
124
|
label: 'Message',
|
|
131
|
-
value: 'message'
|
|
125
|
+
value: 'message'
|
|
132
126
|
},
|
|
133
127
|
{
|
|
134
128
|
label: 'Redirect',
|
|
135
|
-
value: 'redirect'
|
|
136
|
-
}
|
|
129
|
+
value: 'redirect'
|
|
130
|
+
}
|
|
137
131
|
],
|
|
138
|
-
|
|
132
|
+
type: 'radio'
|
|
139
133
|
},
|
|
140
134
|
{
|
|
141
135
|
name: 'confirmationMessage',
|
|
142
|
-
type: 'richText',
|
|
143
|
-
localized: true,
|
|
144
|
-
required: true,
|
|
145
136
|
admin: {
|
|
146
|
-
condition:
|
|
137
|
+
condition: (_, siblingData)=>siblingData?.confirmationType === 'message'
|
|
147
138
|
},
|
|
139
|
+
localized: true,
|
|
140
|
+
required: true,
|
|
141
|
+
type: 'richText'
|
|
148
142
|
},
|
|
149
143
|
redirect,
|
|
150
144
|
{
|
|
151
145
|
name: 'emails',
|
|
152
|
-
type: 'array',
|
|
153
146
|
admin: {
|
|
154
|
-
description: "Send custom emails when the form submits. Use comma separated lists to send the same email to multiple recipients. To reference a value from this form, wrap that field's name with double curly brackets, i.e. {{firstName}}."
|
|
147
|
+
description: "Send custom emails when the form submits. Use comma separated lists to send the same email to multiple recipients. To reference a value from this form, wrap that field's name with double curly brackets, i.e. {{firstName}}."
|
|
155
148
|
},
|
|
156
149
|
fields: [
|
|
157
150
|
{
|
|
158
|
-
type: 'row',
|
|
159
151
|
fields: [
|
|
160
152
|
{
|
|
161
|
-
type: 'text',
|
|
162
153
|
name: 'emailTo',
|
|
163
|
-
label: 'Email To',
|
|
164
154
|
admin: {
|
|
165
|
-
width: '100%',
|
|
166
155
|
placeholder: '"Email Sender" <sender@email.com>',
|
|
156
|
+
width: '100%'
|
|
167
157
|
},
|
|
158
|
+
label: 'Email To',
|
|
159
|
+
type: 'text'
|
|
168
160
|
},
|
|
169
161
|
{
|
|
170
|
-
type: 'text',
|
|
171
162
|
name: 'cc',
|
|
172
|
-
label: 'CC',
|
|
173
163
|
admin: {
|
|
174
|
-
width: '50%'
|
|
164
|
+
width: '50%'
|
|
175
165
|
},
|
|
166
|
+
label: 'CC',
|
|
167
|
+
type: 'text'
|
|
176
168
|
},
|
|
177
169
|
{
|
|
178
|
-
type: 'text',
|
|
179
170
|
name: 'bcc',
|
|
180
|
-
label: 'BCC',
|
|
181
171
|
admin: {
|
|
182
|
-
width: '50%'
|
|
172
|
+
width: '50%'
|
|
183
173
|
},
|
|
184
|
-
|
|
174
|
+
label: 'BCC',
|
|
175
|
+
type: 'text'
|
|
176
|
+
}
|
|
185
177
|
],
|
|
178
|
+
type: 'row'
|
|
186
179
|
},
|
|
187
180
|
{
|
|
188
|
-
type: 'row',
|
|
189
181
|
fields: [
|
|
190
182
|
{
|
|
191
|
-
type: 'text',
|
|
192
183
|
name: 'replyTo',
|
|
193
|
-
label: 'Reply To',
|
|
194
184
|
admin: {
|
|
195
|
-
width: '50%',
|
|
196
185
|
placeholder: '"Reply To" <reply-to@email.com>',
|
|
186
|
+
width: '50%'
|
|
197
187
|
},
|
|
188
|
+
label: 'Reply To',
|
|
189
|
+
type: 'text'
|
|
198
190
|
},
|
|
199
191
|
{
|
|
200
|
-
type: 'text',
|
|
201
192
|
name: 'emailFrom',
|
|
202
|
-
label: 'Email From',
|
|
203
193
|
admin: {
|
|
204
|
-
width: '50%',
|
|
205
194
|
placeholder: '"Email From" <email-from@email.com>',
|
|
195
|
+
width: '50%'
|
|
206
196
|
},
|
|
207
|
-
|
|
197
|
+
label: 'Email From',
|
|
198
|
+
type: 'text'
|
|
199
|
+
}
|
|
208
200
|
],
|
|
201
|
+
type: 'row'
|
|
209
202
|
},
|
|
210
203
|
{
|
|
211
|
-
type: 'text',
|
|
212
204
|
name: 'subject',
|
|
213
|
-
label: 'Subject',
|
|
214
205
|
defaultValue: "You've received a new message.",
|
|
215
|
-
|
|
206
|
+
label: 'Subject',
|
|
216
207
|
localized: true,
|
|
208
|
+
required: true,
|
|
209
|
+
type: 'text'
|
|
217
210
|
},
|
|
218
211
|
{
|
|
219
|
-
type: 'richText',
|
|
220
212
|
name: 'message',
|
|
221
|
-
label: 'Message',
|
|
222
|
-
localized: true,
|
|
223
213
|
admin: {
|
|
224
|
-
description: 'Enter the message that should be sent in this email.'
|
|
214
|
+
description: 'Enter the message that should be sent in this email.'
|
|
225
215
|
},
|
|
226
|
-
|
|
216
|
+
label: 'Message',
|
|
217
|
+
localized: true,
|
|
218
|
+
type: 'richText'
|
|
219
|
+
}
|
|
227
220
|
],
|
|
228
|
-
|
|
229
|
-
|
|
221
|
+
type: 'array'
|
|
222
|
+
},
|
|
223
|
+
...formConfig?.formOverrides?.fields || []
|
|
224
|
+
],
|
|
225
|
+
slug: formConfig?.formOverrides?.slug || 'forms'
|
|
226
|
+
};
|
|
230
227
|
return config;
|
|
231
228
|
};
|
|
232
|
-
|
|
233
|
-
//# sourceMappingURL=index.js.map
|
|
229
|
+
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/Forms/index.ts"],"sourcesContent":["import type { Block, CollectionConfig, Field } from 'payload/types'\n\nimport merge from 'deepmerge'\n\nimport type { FieldConfig, PluginConfig } from '../../types'\n\nimport { fields } from './fields'\n\n// all settings can be overridden by the config\nexport const generateFormCollection = (formConfig: PluginConfig): CollectionConfig => {\n  const redirect: Field = {\n    name: 'redirect',\n    admin: {\n      condition: (_, siblingData) => siblingData?.confirmationType === 'redirect',\n      hideGutter: true,\n    },\n    fields: [\n      {\n        name: 'url',\n        label: 'URL to redirect to',\n        required: true,\n        type: 'text',\n      },\n    ],\n    type: 'group',\n  }\n\n  if (formConfig.redirectRelationships) {\n    redirect.fields.unshift({\n      name: 'reference',\n      admin: {\n        condition: (_, siblingData) => siblingData?.type === 'reference',\n      },\n      label: 'Document to link to',\n      maxDepth: 2,\n      relationTo: formConfig.redirectRelationships,\n      required: true,\n      type: 'relationship',\n    })\n\n    redirect.fields.unshift({\n      name: 'type',\n      admin: {\n        layout: 'horizontal',\n      },\n      defaultValue: 'reference',\n      options: [\n        {\n          label: 'Internal link',\n          value: 'reference',\n        },\n        {\n          label: 'Custom URL',\n          value: 'custom',\n        },\n      ],\n      type: 'radio',\n    })\n\n    if (redirect.fields[2].type !== 'row') redirect.fields[2].label = 'Custom URL'\n\n    redirect.fields[2].admin = {\n      condition: (_, siblingData) => siblingData?.type === 'custom',\n    }\n  }\n\n  const config: CollectionConfig = {\n    ...(formConfig?.formOverrides || {}),\n    access: {\n      read: () => true,\n      ...(formConfig?.formOverrides?.access || {}),\n    },\n    admin: {\n      enableRichTextRelationship: false,\n      useAsTitle: 'title',\n      ...(formConfig?.formOverrides?.admin || {}),\n    },\n    fields: [\n      {\n        name: 'title',\n        required: true,\n        type: 'text',\n      },\n      {\n        name: 'fields',\n        blocks: Object.entries(formConfig?.fields || {})\n          .map(([fieldKey, fieldConfig]) => {\n            // let the config enable/disable fields with either boolean values or objects\n            if (fieldConfig !== false) {\n              const block = fields[fieldKey]\n\n              if (block === undefined && typeof fieldConfig === 'object') {\n                return fieldConfig\n              }\n\n              if (typeof block === 'object' && typeof fieldConfig === 'object') {\n                return merge<FieldConfig>(block, fieldConfig, {\n                  arrayMerge: (_, sourceArray) => sourceArray,\n                })\n              }\n\n              if (typeof block === 'function') {\n                return block(fieldConfig)\n              }\n\n              return block\n            }\n\n            return null\n          })\n          .filter(Boolean) as Block[],\n        type: 'blocks',\n      },\n      {\n        name: 'submitButtonLabel',\n        localized: true,\n        type: 'text',\n      },\n      {\n        name: 'confirmationType',\n        admin: {\n          description:\n            'Choose whether to display an on-page message or redirect to a different page after they submit the form.',\n          layout: 'horizontal',\n        },\n        defaultValue: 'message',\n        options: [\n          {\n            label: 'Message',\n            value: 'message',\n          },\n          {\n            label: 'Redirect',\n            value: 'redirect',\n          },\n        ],\n        type: 'radio',\n      },\n      {\n        name: 'confirmationMessage',\n        admin: {\n          condition: (_, siblingData) => siblingData?.confirmationType === 'message',\n        },\n        localized: true,\n        required: true,\n        type: 'richText',\n      },\n      redirect,\n      {\n        name: 'emails',\n        admin: {\n          description:\n            \"Send custom emails when the form submits. Use comma separated lists to send the same email to multiple recipients. To reference a value from this form, wrap that field's name with double curly brackets, i.e. {{firstName}}.\",\n        },\n        fields: [\n          {\n            fields: [\n              {\n                name: 'emailTo',\n                admin: {\n                  placeholder: '\"Email Sender\" <sender@email.com>',\n                  width: '100%',\n                },\n                label: 'Email To',\n                type: 'text',\n              },\n              {\n                name: 'cc',\n                admin: {\n                  width: '50%',\n                },\n                label: 'CC',\n                type: 'text',\n              },\n              {\n                name: 'bcc',\n                admin: {\n                  width: '50%',\n                },\n                label: 'BCC',\n                type: 'text',\n              },\n            ],\n            type: 'row',\n          },\n          {\n            fields: [\n              {\n                name: 'replyTo',\n                admin: {\n                  placeholder: '\"Reply To\" <reply-to@email.com>',\n                  width: '50%',\n                },\n                label: 'Reply To',\n                type: 'text',\n              },\n              {\n                name: 'emailFrom',\n                admin: {\n                  placeholder: '\"Email From\" <email-from@email.com>',\n                  width: '50%',\n                },\n                label: 'Email From',\n                type: 'text',\n              },\n            ],\n            type: 'row',\n          },\n          {\n            name: 'subject',\n            defaultValue: \"You've received a new message.\",\n            label: 'Subject',\n            localized: true,\n            required: true,\n            type: 'text',\n          },\n          {\n            name: 'message',\n            admin: {\n              description: 'Enter the message that should be sent in this email.',\n            },\n            label: 'Message',\n            localized: true,\n            type: 'richText',\n          },\n        ],\n        type: 'array',\n      },\n      ...(formConfig?.formOverrides?.fields || []),\n    ],\n    slug: formConfig?.formOverrides?.slug || 'forms',\n  }\n\n  return config\n}\n"],"names":["generateFormCollection","formConfig","redirect","name","admin","condition","_","siblingData","confirmationType","hideGutter","fields","label","required","type","redirectRelationships","unshift","maxDepth","relationTo","layout","defaultValue","options","value","config","formOverrides","access","read","enableRichTextRelationship","useAsTitle","blocks","Object","entries","map","fieldKey","fieldConfig","block","undefined","merge","arrayMerge","sourceArray","filter","Boolean","localized","description","placeholder","width","slug"],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
|
@@ -4,3 +4,4 @@ export { fields } from './collections/Forms/fields';
|
|
|
4
4
|
export { getPaymentTotal } from './utilities/getPaymentTotal';
|
|
5
5
|
declare const FormBuilder: (incomingFormConfig: PluginConfig) => (config: Config) => Config;
|
|
6
6
|
export default FormBuilder;
|
|
7
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AAE5C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAK3C,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAA;AAE7D,QAAA,MAAM,WAAW,uBACM,YAAY,cACxB,MAAM,KAAG,MAwCjB,CAAA;AAEH,eAAe,WAAW,CAAA"}
|
package/dist/index.js
CHANGED
|
@@ -1,36 +1,47 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
fields: function() {
|
|
13
|
+
return _fields.fields;
|
|
14
|
+
},
|
|
15
|
+
getPaymentTotal: function() {
|
|
16
|
+
return _getPaymentTotal.getPaymentTotal;
|
|
17
|
+
},
|
|
18
|
+
default: function() {
|
|
19
|
+
return _default;
|
|
19
20
|
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
21
|
+
});
|
|
22
|
+
const _FormSubmissions = require("./collections/FormSubmissions");
|
|
23
|
+
const _Forms = require("./collections/Forms");
|
|
24
|
+
const _fields = require("./collections/Forms/fields");
|
|
25
|
+
const _getPaymentTotal = require("./utilities/getPaymentTotal");
|
|
26
|
+
const FormBuilder = (incomingFormConfig)=>(config)=>{
|
|
27
|
+
const formConfig = {
|
|
28
|
+
...incomingFormConfig,
|
|
29
|
+
fields: {
|
|
30
|
+
checkbox: true,
|
|
31
|
+
country: true,
|
|
32
|
+
email: true,
|
|
33
|
+
message: true,
|
|
34
|
+
number: true,
|
|
35
|
+
payment: false,
|
|
36
|
+
select: true,
|
|
37
|
+
state: true,
|
|
38
|
+
text: true,
|
|
39
|
+
textarea: true,
|
|
40
|
+
...incomingFormConfig.fields
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
return {
|
|
44
|
+
...config,
|
|
34
45
|
// admin: {
|
|
35
46
|
// ...config.admin,
|
|
36
47
|
// webpack: (webpackConfig) => ({
|
|
@@ -45,11 +56,13 @@ var FormBuilder = function (incomingFormConfig) {
|
|
|
45
56
|
// },
|
|
46
57
|
// })
|
|
47
58
|
// },
|
|
48
|
-
collections:
|
|
49
|
-
|
|
50
|
-
(0,
|
|
51
|
-
|
|
59
|
+
collections: [
|
|
60
|
+
...config?.collections || [],
|
|
61
|
+
(0, _Forms.generateFormCollection)(formConfig),
|
|
62
|
+
(0, _FormSubmissions.generateSubmissionCollection)(formConfig)
|
|
63
|
+
]
|
|
64
|
+
};
|
|
52
65
|
};
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
//# sourceMappingURL=
|
|
66
|
+
const _default = FormBuilder;
|
|
67
|
+
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENvbmZpZyB9IGZyb20gJ3BheWxvYWQvY29uZmlnJ1xuXG5pbXBvcnQgdHlwZSB7IFBsdWdpbkNvbmZpZyB9IGZyb20gJy4vdHlwZXMnXG5cbmltcG9ydCB7IGdlbmVyYXRlU3VibWlzc2lvbkNvbGxlY3Rpb24gfSBmcm9tICcuL2NvbGxlY3Rpb25zL0Zvcm1TdWJtaXNzaW9ucydcbmltcG9ydCB7IGdlbmVyYXRlRm9ybUNvbGxlY3Rpb24gfSBmcm9tICcuL2NvbGxlY3Rpb25zL0Zvcm1zJ1xuXG5leHBvcnQgeyBmaWVsZHMgfSBmcm9tICcuL2NvbGxlY3Rpb25zL0Zvcm1zL2ZpZWxkcydcbmV4cG9ydCB7IGdldFBheW1lbnRUb3RhbCB9IGZyb20gJy4vdXRpbGl0aWVzL2dldFBheW1lbnRUb3RhbCdcblxuY29uc3QgRm9ybUJ1aWxkZXIgPVxuICAoaW5jb21pbmdGb3JtQ29uZmlnOiBQbHVnaW5Db25maWcpID0+XG4gIChjb25maWc6IENvbmZpZyk6IENvbmZpZyA9PiB7XG4gICAgY29uc3QgZm9ybUNvbmZpZzogUGx1Z2luQ29uZmlnID0ge1xuICAgICAgLi4uaW5jb21pbmdGb3JtQ29uZmlnLFxuICAgICAgZmllbGRzOiB7XG4gICAgICAgIGNoZWNrYm94OiB0cnVlLFxuICAgICAgICBjb3VudHJ5OiB0cnVlLFxuICAgICAgICBlbWFpbDogdHJ1ZSxcbiAgICAgICAgbWVzc2FnZTogdHJ1ZSxcbiAgICAgICAgbnVtYmVyOiB0cnVlLFxuICAgICAgICBwYXltZW50OiBmYWxzZSxcbiAgICAgICAgc2VsZWN0OiB0cnVlLFxuICAgICAgICBzdGF0ZTogdHJ1ZSxcbiAgICAgICAgdGV4dDogdHJ1ZSxcbiAgICAgICAgdGV4dGFyZWE6IHRydWUsXG4gICAgICAgIC4uLmluY29taW5nRm9ybUNvbmZpZy5maWVsZHMsXG4gICAgICB9LFxuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAuLi5jb25maWcsXG4gICAgICAvLyBhZG1pbjoge1xuICAgICAgLy8gICAuLi5jb25maWcuYWRtaW4sXG4gICAgICAvLyAgIHdlYnBhY2s6ICh3ZWJwYWNrQ29uZmlnKSA9PiAoe1xuICAgICAgLy8gICAgIC4uLndlYnBhY2tDb25maWcsXG4gICAgICAvLyAgICAgcmVzb2x2ZToge1xuICAgICAgLy8gICAgICAgLi4ud2VicGFja0NvbmZpZy5yZXNvbHZlLFxuICAgICAgLy8gICAgICAgYWxpYXM6IHtcbiAgICAgIC8vICAgICAgICAgLi4ud2VicGFja0NvbmZpZy5yZXNvbHZlLmFsaWFzLFxuICAgICAgLy8gICAgICAgICBbcGF0aC5yZXNvbHZlKF9fZGlybmFtZSwgJ2NvbGxlY3Rpb25zL0Zvcm1TdWJtaXNzaW9ucy9ob29rcy9zZW5kRW1haWwudHMnKV06IHBhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICdtb2Nrcy9zZXJ2ZXJNb2R1bGUuanMnKSxcbiAgICAgIC8vICAgICAgICAgW3BhdGgucmVzb2x2ZShfX2Rpcm5hbWUsICdjb2xsZWN0aW9ucy9Gb3JtU3VibWlzc2lvbnMvaG9va3MvY3JlYXRlQ2hhcmdlLnRzJyldOiBwYXRoLnJlc29sdmUoX19kaXJuYW1lLCAnbW9ja3Mvc2VydmVyTW9kdWxlLmpzJyksXG4gICAgICAvLyAgICAgICB9LFxuICAgICAgLy8gICAgIH0sXG4gICAgICAvLyAgIH0pXG4gICAgICAvLyB9LFxuICAgICAgY29sbGVjdGlvbnM6IFtcbiAgICAgICAgLi4uKGNvbmZpZz8uY29sbGVjdGlvbnMgfHwgW10pLFxuICAgICAgICBnZW5lcmF0ZUZvcm1Db2xsZWN0aW9uKGZvcm1Db25maWcpLFxuICAgICAgICBnZW5lcmF0ZVN1Ym1pc3Npb25Db2xsZWN0aW9uKGZvcm1Db25maWcpLFxuICAgICAgXSxcbiAgICB9XG4gIH1cblxuZXhwb3J0IGRlZmF1bHQgRm9ybUJ1aWxkZXJcbiJdLCJuYW1lcyI6WyJmaWVsZHMiLCJnZXRQYXltZW50VG90YWwiLCJGb3JtQnVpbGRlciIsImluY29taW5nRm9ybUNvbmZpZyIsImNvbmZpZyIsImZvcm1Db25maWciLCJjaGVja2JveCIsImNvdW50cnkiLCJlbWFpbCIsIm1lc3NhZ2UiLCJudW1iZXIiLCJwYXltZW50Iiwic2VsZWN0Iiwic3RhdGUiLCJ0ZXh0IiwidGV4dGFyZWEiLCJjb2xsZWN0aW9ucyIsImdlbmVyYXRlRm9ybUNvbGxlY3Rpb24iLCJnZW5lcmF0ZVN1Ym1pc3Npb25Db2xsZWN0aW9uIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7OztJQU9TQSxNQUFNO2VBQU5BLGNBQU07O0lBQ05DLGVBQWU7ZUFBZkEsZ0NBQWU7O0lBOEN4QixPQUEwQjtlQUExQjs7O2lDQWxENkM7dUJBQ047d0JBRWhCO2lDQUNTO0FBRWhDLE1BQU1DLGNBQ0osQ0FBQ0MscUJBQ0QsQ0FBQ0M7UUFDQyxNQUFNQyxhQUEyQjtZQUMvQixHQUFHRixrQkFBa0I7WUFDckJILFFBQVE7Z0JBQ05NLFVBQVU7Z0JBQ1ZDLFNBQVM7Z0JBQ1RDLE9BQU87Z0JBQ1BDLFNBQVM7Z0JBQ1RDLFFBQVE7Z0JBQ1JDLFNBQVM7Z0JBQ1RDLFFBQVE7Z0JBQ1JDLE9BQU87Z0JBQ1BDLE1BQU07Z0JBQ05DLFVBQVU7Z0JBQ1YsR0FBR1osbUJBQW1CSCxNQUFNO1lBQzlCO1FBQ0Y7UUFFQSxPQUFPO1lBQ0wsR0FBR0ksTUFBTTtZQUNULFdBQVc7WUFDWCxxQkFBcUI7WUFDckIsbUNBQW1DO1lBQ25DLHdCQUF3QjtZQUN4QixpQkFBaUI7WUFDakIsa0NBQWtDO1lBQ2xDLGlCQUFpQjtZQUNqQiwwQ0FBMEM7WUFDMUMseUlBQXlJO1lBQ3pJLDRJQUE0STtZQUM1SSxXQUFXO1lBQ1gsU0FBUztZQUNULE9BQU87WUFDUCxLQUFLO1lBQ0xZLGFBQWE7bUJBQ1BaLFFBQVFZLGVBQWUsRUFBRTtnQkFDN0JDLElBQUFBLDZCQUFzQixFQUFDWjtnQkFDdkJhLElBQUFBLDZDQUE0QixFQUFDYjthQUM5QjtRQUNIO0lBQ0Y7TUFFRixXQUFlSCJ9
|