@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.
Files changed (55) hide show
  1. package/README.md +17 -16
  2. package/dist/collections/FormSubmissions/hooks/createCharge.d.ts +1 -0
  3. package/dist/collections/FormSubmissions/hooks/createCharge.d.ts.map +1 -0
  4. package/dist/collections/FormSubmissions/hooks/createCharge.js +21 -55
  5. package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts +1 -0
  6. package/dist/collections/FormSubmissions/hooks/sendEmail.d.ts.map +1 -0
  7. package/dist/collections/FormSubmissions/hooks/sendEmail.js +69 -124
  8. package/dist/collections/FormSubmissions/index.d.ts +1 -0
  9. package/dist/collections/FormSubmissions/index.d.ts.map +1 -0
  10. package/dist/collections/FormSubmissions/index.js +70 -66
  11. package/dist/collections/Forms/DynamicFieldSelector.d.ts +2 -1
  12. package/dist/collections/Forms/DynamicFieldSelector.d.ts.map +1 -0
  13. package/dist/collections/Forms/DynamicFieldSelector.js +69 -53
  14. package/dist/collections/Forms/DynamicPriceSelector.d.ts +2 -1
  15. package/dist/collections/Forms/DynamicPriceSelector.d.ts.map +1 -0
  16. package/dist/collections/Forms/DynamicPriceSelector.js +82 -64
  17. package/dist/collections/Forms/fields.d.ts +2 -1
  18. package/dist/collections/Forms/fields.d.ts.map +1 -0
  19. package/dist/collections/Forms/fields.js +352 -270
  20. package/dist/collections/Forms/index.d.ts +1 -0
  21. package/dist/collections/Forms/index.d.ts.map +1 -0
  22. package/dist/collections/Forms/index.js +103 -106
  23. package/dist/index.d.ts +1 -0
  24. package/dist/index.d.ts.map +1 -0
  25. package/dist/index.js +51 -38
  26. package/dist/types.d.ts +70 -69
  27. package/dist/types.d.ts.map +1 -0
  28. package/dist/types.js +12 -8
  29. package/dist/utilities/getPaymentTotal.d.ts +1 -0
  30. package/dist/utilities/getPaymentTotal.d.ts.map +1 -0
  31. package/dist/utilities/getPaymentTotal.js +44 -34
  32. package/dist/utilities/replaceDoubleCurlys.d.ts +1 -0
  33. package/dist/utilities/replaceDoubleCurlys.d.ts.map +1 -0
  34. package/dist/utilities/replaceDoubleCurlys.js +16 -13
  35. package/dist/utilities/serializeRichText.d.ts +2 -1
  36. package/dist/utilities/serializeRichText.d.ts.map +1 -0
  37. package/dist/utilities/serializeRichText.js +83 -28
  38. package/package.json +27 -38
  39. package/types.d.ts +1 -1
  40. package/types.js +1 -1
  41. package/dist/collections/FormSubmissions/hooks/createCharge.js.map +0 -1
  42. package/dist/collections/FormSubmissions/hooks/sendEmail.js.map +0 -1
  43. package/dist/collections/FormSubmissions/index.js.map +0 -1
  44. package/dist/collections/Forms/DynamicFieldSelector.js.map +0 -1
  45. package/dist/collections/Forms/DynamicPriceSelector.js.map +0 -1
  46. package/dist/collections/Forms/fields.js.map +0 -1
  47. package/dist/collections/Forms/index.js.map +0 -1
  48. package/dist/index.js.map +0 -1
  49. package/dist/mocks/serverModule.d.ts +0 -2
  50. package/dist/mocks/serverModule.js +0 -4
  51. package/dist/mocks/serverModule.js.map +0 -1
  52. package/dist/types.js.map +0 -1
  53. package/dist/utilities/getPaymentTotal.js.map +0 -1
  54. package/dist/utilities/replaceDoubleCurlys.js.map +0 -1
  55. package/dist/utilities/serializeRichText.js.map +0 -1
@@ -1,503 +1,585 @@
1
1
  "use strict";
2
- var __assign = (this && this.__assign) || function () {
3
- __assign = Object.assign || function(t) {
4
- for (var s, i = 1, n = arguments.length; i < n; i++) {
5
- s = arguments[i];
6
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
- t[p] = s[p];
8
- }
9
- return t;
10
- };
11
- return __assign.apply(this, arguments);
12
- };
13
- Object.defineProperty(exports, "__esModule", { value: true });
14
- exports.fields = void 0;
15
- var DynamicFieldSelector_1 = require("./DynamicFieldSelector");
16
- var DynamicPriceSelector_1 = require("./DynamicPriceSelector");
17
- var name = {
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;
14
+ },
15
+ default: function() {
16
+ return _default;
17
+ }
18
+ });
19
+ const _DynamicFieldSelector = require("./DynamicFieldSelector");
20
+ const _DynamicPriceSelector = require("./DynamicPriceSelector");
21
+ const name = {
18
22
  name: 'name',
19
23
  label: 'Name (lowercase, no special characters)',
20
- type: 'text',
21
24
  required: true,
25
+ type: 'text'
22
26
  };
23
- var label = {
27
+ const label = {
24
28
  name: 'label',
25
29
  label: 'Label',
26
- type: 'text',
27
30
  localized: true,
31
+ type: 'text'
28
32
  };
29
- var required = {
33
+ const required = {
30
34
  name: 'required',
31
35
  label: 'Required',
32
- type: 'checkbox',
36
+ type: 'checkbox'
33
37
  };
34
- var width = {
38
+ const width = {
35
39
  name: 'width',
36
40
  label: 'Field Width (percentage)',
37
- type: 'number',
41
+ type: 'number'
38
42
  };
39
- var Select = {
40
- slug: 'select',
41
- labels: {
42
- singular: 'Select',
43
- plural: 'Select Fields',
44
- },
43
+ const Select = {
45
44
  fields: [
46
45
  {
47
- type: 'row',
48
46
  fields: [
49
- __assign(__assign({}, name), { admin: {
50
- width: '50%',
51
- } }),
52
- __assign(__assign({}, label), { admin: {
53
- width: '50%',
54
- } }),
47
+ {
48
+ ...name,
49
+ admin: {
50
+ width: '50%'
51
+ }
52
+ },
53
+ {
54
+ ...label,
55
+ admin: {
56
+ width: '50%'
57
+ }
58
+ }
55
59
  ],
60
+ type: 'row'
56
61
  },
57
62
  {
58
- type: 'row',
59
63
  fields: [
60
- __assign(__assign({}, width), { admin: {
61
- width: '50%',
62
- } }),
64
+ {
65
+ ...width,
66
+ admin: {
67
+ width: '50%'
68
+ }
69
+ },
63
70
  {
64
71
  name: 'defaultValue',
65
- label: 'Default Value',
66
- localized: true,
67
- type: 'text',
68
72
  admin: {
69
- width: '50%',
73
+ width: '50%'
70
74
  },
71
- },
75
+ label: 'Default Value',
76
+ localized: true,
77
+ type: 'text'
78
+ }
72
79
  ],
80
+ type: 'row'
73
81
  },
74
82
  {
75
83
  name: 'options',
76
- label: 'Select Attribute Options',
77
- type: 'array',
78
- labels: {
79
- singular: 'Option',
80
- plural: 'Options',
81
- },
82
84
  fields: [
83
85
  {
84
- type: 'row',
85
86
  fields: [
86
87
  {
87
88
  name: 'label',
88
- label: 'Label',
89
- type: 'text',
90
- required: true,
91
- localized: true,
92
89
  admin: {
93
- width: '50%',
90
+ width: '50%'
94
91
  },
92
+ label: 'Label',
93
+ localized: true,
94
+ required: true,
95
+ type: 'text'
95
96
  },
96
97
  {
97
98
  name: 'value',
98
- label: 'Value',
99
- type: 'text',
100
- required: true,
101
99
  admin: {
102
- width: '50%',
100
+ width: '50%'
103
101
  },
104
- },
102
+ label: 'Value',
103
+ required: true,
104
+ type: 'text'
105
+ }
105
106
  ],
106
- },
107
+ type: 'row'
108
+ }
107
109
  ],
110
+ label: 'Select Attribute Options',
111
+ labels: {
112
+ plural: 'Options',
113
+ singular: 'Option'
114
+ },
115
+ type: 'array'
108
116
  },
109
- required,
117
+ required
110
118
  ],
111
- };
112
- var Text = {
113
- slug: 'text',
114
119
  labels: {
115
- singular: 'Text',
116
- plural: 'Text Fields',
120
+ plural: 'Select Fields',
121
+ singular: 'Select'
117
122
  },
123
+ slug: 'select'
124
+ };
125
+ const Text = {
118
126
  fields: [
119
127
  {
120
- type: 'row',
121
128
  fields: [
122
- __assign(__assign({}, name), { admin: {
123
- width: '50%',
124
- } }),
125
- __assign(__assign({}, label), { admin: {
126
- width: '50%',
127
- } }),
129
+ {
130
+ ...name,
131
+ admin: {
132
+ width: '50%'
133
+ }
134
+ },
135
+ {
136
+ ...label,
137
+ admin: {
138
+ width: '50%'
139
+ }
140
+ }
128
141
  ],
142
+ type: 'row'
129
143
  },
130
144
  {
131
- type: 'row',
132
145
  fields: [
133
- __assign(__assign({}, width), { admin: {
134
- width: '50%',
135
- } }),
146
+ {
147
+ ...width,
148
+ admin: {
149
+ width: '50%'
150
+ }
151
+ },
136
152
  {
137
153
  name: 'defaultValue',
138
- label: 'Default Value',
139
- type: 'text',
140
- localized: true,
141
154
  admin: {
142
- width: '50%',
155
+ width: '50%'
143
156
  },
144
- },
157
+ label: 'Default Value',
158
+ localized: true,
159
+ type: 'text'
160
+ }
145
161
  ],
162
+ type: 'row'
146
163
  },
147
- required,
164
+ required
148
165
  ],
149
- };
150
- var TextArea = {
151
- slug: 'textarea',
152
166
  labels: {
153
- singular: 'Text Area',
154
- plural: 'Text Area Fields',
167
+ plural: 'Text Fields',
168
+ singular: 'Text'
155
169
  },
170
+ slug: 'text'
171
+ };
172
+ const TextArea = {
156
173
  fields: [
157
174
  {
158
- type: 'row',
159
175
  fields: [
160
- __assign(__assign({}, name), { admin: {
161
- width: '50%',
162
- } }),
163
- __assign(__assign({}, label), { admin: {
164
- width: '50%',
165
- } }),
176
+ {
177
+ ...name,
178
+ admin: {
179
+ width: '50%'
180
+ }
181
+ },
182
+ {
183
+ ...label,
184
+ admin: {
185
+ width: '50%'
186
+ }
187
+ }
166
188
  ],
189
+ type: 'row'
167
190
  },
168
191
  {
169
- type: 'row',
170
192
  fields: [
171
- __assign(__assign({}, width), { admin: {
172
- width: '50%',
173
- } }),
193
+ {
194
+ ...width,
195
+ admin: {
196
+ width: '50%'
197
+ }
198
+ },
174
199
  {
175
200
  name: 'defaultValue',
176
- label: 'Default Value',
177
- localized: true,
178
- type: 'text',
179
201
  admin: {
180
- width: '50%',
202
+ width: '50%'
181
203
  },
182
- },
204
+ label: 'Default Value',
205
+ localized: true,
206
+ type: 'text'
207
+ }
183
208
  ],
209
+ type: 'row'
184
210
  },
185
- required,
211
+ required
186
212
  ],
187
- };
188
- var Number = {
189
- slug: 'number',
190
213
  labels: {
191
- singular: 'Number',
192
- plural: 'Number Fields',
214
+ plural: 'Text Area Fields',
215
+ singular: 'Text Area'
193
216
  },
217
+ slug: 'textarea'
218
+ };
219
+ const Number = {
194
220
  fields: [
195
221
  {
196
- type: 'row',
197
222
  fields: [
198
- __assign(__assign({}, name), { admin: {
199
- width: '50%',
200
- } }),
201
- __assign(__assign({}, label), { admin: {
202
- width: '50%',
203
- } }),
223
+ {
224
+ ...name,
225
+ admin: {
226
+ width: '50%'
227
+ }
228
+ },
229
+ {
230
+ ...label,
231
+ admin: {
232
+ width: '50%'
233
+ }
234
+ }
204
235
  ],
236
+ type: 'row'
205
237
  },
206
238
  {
207
- type: 'row',
208
239
  fields: [
209
- __assign(__assign({}, width), { admin: {
210
- width: '50%',
211
- } }),
240
+ {
241
+ ...width,
242
+ admin: {
243
+ width: '50%'
244
+ }
245
+ },
212
246
  {
213
247
  name: 'defaultValue',
214
- label: 'Default Value',
215
- type: 'number',
216
248
  admin: {
217
- width: '50%',
249
+ width: '50%'
218
250
  },
219
- },
251
+ label: 'Default Value',
252
+ type: 'number'
253
+ }
220
254
  ],
255
+ type: 'row'
221
256
  },
222
- required,
257
+ required
223
258
  ],
224
- };
225
- var Email = {
226
- slug: 'email',
227
259
  labels: {
228
- singular: 'Email',
229
- plural: 'Email Fields',
260
+ plural: 'Number Fields',
261
+ singular: 'Number'
230
262
  },
263
+ slug: 'number'
264
+ };
265
+ const Email = {
231
266
  fields: [
232
267
  {
233
- type: 'row',
234
268
  fields: [
235
- __assign(__assign({}, name), { admin: {
236
- width: '50%',
237
- } }),
238
- __assign(__assign({}, label), { admin: {
239
- width: '50%',
240
- } }),
269
+ {
270
+ ...name,
271
+ admin: {
272
+ width: '50%'
273
+ }
274
+ },
275
+ {
276
+ ...label,
277
+ admin: {
278
+ width: '50%'
279
+ }
280
+ }
241
281
  ],
282
+ type: 'row'
242
283
  },
243
284
  width,
244
- required,
285
+ required
245
286
  ],
246
- };
247
- var State = {
248
- slug: 'state',
249
287
  labels: {
250
- singular: 'State',
251
- plural: 'State Fields',
288
+ plural: 'Email Fields',
289
+ singular: 'Email'
252
290
  },
291
+ slug: 'email'
292
+ };
293
+ const State = {
253
294
  fields: [
254
295
  {
255
- type: 'row',
256
296
  fields: [
257
- __assign(__assign({}, name), { admin: {
258
- width: '50%',
259
- } }),
260
- __assign(__assign({}, label), { admin: {
261
- width: '50%',
262
- } }),
297
+ {
298
+ ...name,
299
+ admin: {
300
+ width: '50%'
301
+ }
302
+ },
303
+ {
304
+ ...label,
305
+ admin: {
306
+ width: '50%'
307
+ }
308
+ }
263
309
  ],
310
+ type: 'row'
264
311
  },
265
312
  width,
266
- required,
313
+ required
267
314
  ],
268
- };
269
- var Country = {
270
- slug: 'country',
271
315
  labels: {
272
- singular: 'Country',
273
- plural: 'Country Fields',
316
+ plural: 'State Fields',
317
+ singular: 'State'
274
318
  },
319
+ slug: 'state'
320
+ };
321
+ const Country = {
275
322
  fields: [
276
323
  {
277
- type: 'row',
278
324
  fields: [
279
- __assign(__assign({}, name), { admin: {
280
- width: '50%',
281
- } }),
282
- __assign(__assign({}, label), { admin: {
283
- width: '50%',
284
- } }),
325
+ {
326
+ ...name,
327
+ admin: {
328
+ width: '50%'
329
+ }
330
+ },
331
+ {
332
+ ...label,
333
+ admin: {
334
+ width: '50%'
335
+ }
336
+ }
285
337
  ],
338
+ type: 'row'
286
339
  },
287
340
  width,
288
- required,
341
+ required
289
342
  ],
290
- };
291
- var Checkbox = {
292
- slug: 'checkbox',
293
343
  labels: {
294
- singular: 'Checkbox',
295
- plural: 'Checkbox Fields',
344
+ plural: 'Country Fields',
345
+ singular: 'Country'
296
346
  },
347
+ slug: 'country'
348
+ };
349
+ const Checkbox = {
297
350
  fields: [
298
351
  {
299
- type: 'row',
300
352
  fields: [
301
- __assign(__assign({}, name), { admin: {
302
- width: '50%',
303
- } }),
304
- __assign(__assign({}, label), { admin: {
305
- width: '50%',
306
- } }),
353
+ {
354
+ ...name,
355
+ admin: {
356
+ width: '50%'
357
+ }
358
+ },
359
+ {
360
+ ...label,
361
+ admin: {
362
+ width: '50%'
363
+ }
364
+ }
307
365
  ],
366
+ type: 'row'
308
367
  },
309
368
  {
310
- type: 'row',
311
369
  fields: [
312
- __assign(__assign({}, width), { admin: {
313
- width: '50%',
314
- } }),
315
- __assign(__assign({}, required), { admin: {
316
- width: '50%',
317
- } }),
370
+ {
371
+ ...width,
372
+ admin: {
373
+ width: '50%'
374
+ }
375
+ },
376
+ {
377
+ ...required,
378
+ admin: {
379
+ width: '50%'
380
+ }
381
+ }
318
382
  ],
383
+ type: 'row'
319
384
  },
320
385
  {
321
386
  name: 'defaultValue',
322
387
  label: 'Default Value',
323
- type: 'checkbox',
324
- },
388
+ type: 'checkbox'
389
+ }
325
390
  ],
391
+ labels: {
392
+ plural: 'Checkbox Fields',
393
+ singular: 'Checkbox'
394
+ },
395
+ slug: 'checkbox'
326
396
  };
327
- var Payment = function (fieldConfig) {
328
- var paymentProcessorField = null;
329
- if (fieldConfig === null || fieldConfig === void 0 ? void 0 : fieldConfig.paymentProcessor) {
330
- paymentProcessorField = __assign({ type: 'select', options: [], name: 'paymentProcessor', label: 'Payment Processor' }, fieldConfig.paymentProcessor);
397
+ const Payment = (fieldConfig)=>{
398
+ let paymentProcessorField = null;
399
+ if (fieldConfig?.paymentProcessor) {
400
+ paymentProcessorField = {
401
+ name: 'paymentProcessor',
402
+ label: 'Payment Processor',
403
+ options: [],
404
+ type: 'select',
405
+ ...fieldConfig.paymentProcessor
406
+ };
331
407
  }
332
- var fields = {
333
- slug: 'payment',
334
- labels: {
335
- singular: 'Payment',
336
- plural: 'Payment Fields',
337
- },
408
+ const fields = {
338
409
  fields: [
339
410
  {
340
- type: 'row',
341
411
  fields: [
342
- __assign(__assign({}, name), { admin: {
343
- width: '50%',
344
- } }),
345
- __assign(__assign({}, label), { admin: {
346
- width: '50%',
347
- } }),
412
+ {
413
+ ...name,
414
+ admin: {
415
+ width: '50%'
416
+ }
417
+ },
418
+ {
419
+ ...label,
420
+ admin: {
421
+ width: '50%'
422
+ }
423
+ }
348
424
  ],
425
+ type: 'row'
349
426
  },
350
427
  {
351
- type: 'row',
352
428
  fields: [
353
- __assign(__assign({}, width), { admin: {
354
- width: '50%',
355
- } }),
429
+ {
430
+ ...width,
431
+ admin: {
432
+ width: '50%'
433
+ }
434
+ },
356
435
  {
357
436
  name: 'basePrice',
358
- type: 'number',
359
- label: 'Base Price',
360
437
  admin: {
361
- width: '50%',
438
+ width: '50%'
362
439
  },
363
- },
440
+ label: 'Base Price',
441
+ type: 'number'
442
+ }
364
443
  ],
444
+ type: 'row'
365
445
  },
366
446
  paymentProcessorField,
367
447
  {
368
448
  name: 'priceConditions',
369
- labels: {
370
- singular: 'Price Condition',
371
- plural: 'Price Conditions',
372
- },
373
- type: 'array',
374
- label: 'Price Conditions',
375
449
  fields: [
376
450
  {
377
451
  name: 'fieldToUse',
378
- type: 'text',
379
452
  admin: {
380
453
  components: {
381
- Field: DynamicFieldSelector_1.DynamicFieldSelector,
382
- },
454
+ Field: _DynamicFieldSelector.DynamicFieldSelector
455
+ }
383
456
  },
457
+ type: 'text'
384
458
  },
385
459
  {
386
460
  name: 'condition',
387
- label: 'Condition',
388
- type: 'select',
389
461
  defaultValue: 'hasValue',
462
+ label: 'Condition',
390
463
  options: [
391
464
  {
392
- value: 'hasValue',
393
465
  label: 'Has Any Value',
466
+ value: 'hasValue'
394
467
  },
395
468
  {
396
- value: 'equals',
397
469
  label: 'Equals',
470
+ value: 'equals'
398
471
  },
399
472
  {
400
- value: 'notEquals',
401
473
  label: 'Does Not Equal',
402
- },
474
+ value: 'notEquals'
475
+ }
403
476
  ],
477
+ type: 'select'
404
478
  },
405
479
  {
406
480
  name: 'valueForCondition',
407
- label: 'Value',
408
- type: 'text',
409
481
  admin: {
410
- condition: function (_, _a) {
411
- var condition = _a.condition;
412
- return condition === 'equals' || condition === 'notEquals';
413
- },
482
+ condition: (_, { condition })=>condition === 'equals' || condition === 'notEquals'
414
483
  },
484
+ label: 'Value',
485
+ type: 'text'
415
486
  },
416
487
  {
417
488
  name: 'operator',
418
- type: 'select',
419
489
  defaultValue: 'add',
420
490
  options: [
421
491
  {
422
- value: 'add',
423
492
  label: 'Add',
493
+ value: 'add'
424
494
  },
425
495
  {
426
- value: 'subtract',
427
496
  label: 'Subtract',
497
+ value: 'subtract'
428
498
  },
429
499
  {
430
- value: 'multiply',
431
500
  label: 'Multiply',
501
+ value: 'multiply'
432
502
  },
433
503
  {
434
- value: 'divide',
435
504
  label: 'Divide',
436
- },
505
+ value: 'divide'
506
+ }
437
507
  ],
508
+ type: 'select'
438
509
  },
439
510
  {
440
511
  name: 'valueType',
441
- label: 'Value Type',
442
- type: 'radio',
443
512
  admin: {
444
- width: '100%',
513
+ width: '100%'
445
514
  },
446
515
  defaultValue: 'static',
516
+ label: 'Value Type',
447
517
  options: [
448
518
  {
449
519
  label: 'Static Value',
450
- value: 'static',
520
+ value: 'static'
451
521
  },
452
522
  {
453
523
  label: 'Value Of Field',
454
- value: 'valueOfField',
455
- },
524
+ value: 'valueOfField'
525
+ }
456
526
  ],
527
+ type: 'radio'
457
528
  },
458
529
  {
459
530
  name: 'valueForOperator',
460
- label: 'Value',
461
- type: 'text',
462
531
  admin: {
463
532
  components: {
464
- Field: DynamicPriceSelector_1.DynamicPriceSelector,
465
- },
533
+ Field: _DynamicPriceSelector.DynamicPriceSelector
534
+ }
466
535
  },
467
- },
536
+ label: 'Value',
537
+ type: 'text'
538
+ }
468
539
  ],
540
+ label: 'Price Conditions',
541
+ labels: {
542
+ plural: 'Price Conditions',
543
+ singular: 'Price Condition'
544
+ },
545
+ type: 'array'
469
546
  },
470
- required,
547
+ required
471
548
  ].filter(Boolean),
549
+ labels: {
550
+ plural: 'Payment Fields',
551
+ singular: 'Payment'
552
+ },
553
+ slug: 'payment'
472
554
  };
473
555
  return fields;
474
556
  };
475
- var Message = {
476
- slug: 'message',
477
- labels: {
478
- singular: 'Message',
479
- plural: 'Message Blocks',
480
- },
557
+ const Message = {
481
558
  fields: [
482
559
  {
483
560
  name: 'message',
484
- type: 'richText',
485
561
  localized: true,
486
- },
562
+ type: 'richText'
563
+ }
487
564
  ],
565
+ labels: {
566
+ plural: 'Message Blocks',
567
+ singular: 'Message'
568
+ },
569
+ slug: 'message'
488
570
  };
489
- // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
490
- exports.fields = {
491
- select: Select,
571
+ const fields = {
492
572
  checkbox: Checkbox,
493
- text: Text,
494
- textarea: TextArea,
573
+ country: Country,
495
574
  email: Email,
496
575
  message: Message,
497
576
  number: Number,
498
- country: Country,
499
- state: State,
500
577
  payment: Payment,
578
+ select: Select,
579
+ state: State,
580
+ text: Text,
581
+ textarea: TextArea
501
582
  };
502
- exports.default = exports.fields;
503
- //# sourceMappingURL=fields.js.map
583
+ const _default = fields;
584
+
585
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/Forms/fields.ts"],"sourcesContent":["import type { Block, Field } from 'payload/types'\n\nimport type { FieldConfig, PaymentFieldConfig } from '../../types'\n\nimport { DynamicFieldSelector } from './DynamicFieldSelector'\nimport { DynamicPriceSelector } from './DynamicPriceSelector'\n\nconst name: Field = {\n  name: 'name',\n  label: 'Name (lowercase, no special characters)',\n  required: true,\n  type: 'text',\n}\n\nconst label: Field = {\n  name: 'label',\n  label: 'Label',\n  localized: true,\n  type: 'text',\n}\n\nconst required: Field = {\n  name: 'required',\n  label: 'Required',\n  type: 'checkbox',\n}\n\nconst width: Field = {\n  name: 'width',\n  label: 'Field Width (percentage)',\n  type: 'number',\n}\n\nconst Select: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      fields: [\n        {\n          ...width,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          name: 'defaultValue',\n          admin: {\n            width: '50%',\n          },\n          label: 'Default Value',\n          localized: true,\n          type: 'text',\n        },\n      ],\n      type: 'row',\n    },\n    {\n      name: 'options',\n      fields: [\n        {\n          fields: [\n            {\n              name: 'label',\n              admin: {\n                width: '50%',\n              },\n              label: 'Label',\n              localized: true,\n              required: true,\n              type: 'text',\n            },\n            {\n              name: 'value',\n              admin: {\n                width: '50%',\n              },\n              label: 'Value',\n              required: true,\n              type: 'text',\n            },\n          ],\n          type: 'row',\n        },\n      ],\n      label: 'Select Attribute Options',\n      labels: {\n        plural: 'Options',\n        singular: 'Option',\n      },\n      type: 'array',\n    },\n    required,\n  ],\n  labels: {\n    plural: 'Select Fields',\n    singular: 'Select',\n  },\n  slug: 'select',\n}\n\nconst Text: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      fields: [\n        {\n          ...width,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          name: 'defaultValue',\n          admin: {\n            width: '50%',\n          },\n          label: 'Default Value',\n          localized: true,\n          type: 'text',\n        },\n      ],\n      type: 'row',\n    },\n    required,\n  ],\n  labels: {\n    plural: 'Text Fields',\n    singular: 'Text',\n  },\n  slug: 'text',\n}\n\nconst TextArea: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      fields: [\n        {\n          ...width,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          name: 'defaultValue',\n          admin: {\n            width: '50%',\n          },\n          label: 'Default Value',\n          localized: true,\n          type: 'text',\n        },\n      ],\n      type: 'row',\n    },\n    required,\n  ],\n  labels: {\n    plural: 'Text Area Fields',\n    singular: 'Text Area',\n  },\n  slug: 'textarea',\n}\n\nconst Number: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      fields: [\n        {\n          ...width,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          name: 'defaultValue',\n          admin: {\n            width: '50%',\n          },\n          label: 'Default Value',\n          type: 'number',\n        },\n      ],\n      type: 'row',\n    },\n    required,\n  ],\n  labels: {\n    plural: 'Number Fields',\n    singular: 'Number',\n  },\n  slug: 'number',\n}\n\nconst Email: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    width,\n    required,\n  ],\n  labels: {\n    plural: 'Email Fields',\n    singular: 'Email',\n  },\n  slug: 'email',\n}\n\nconst State: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    width,\n    required,\n  ],\n  labels: {\n    plural: 'State Fields',\n    singular: 'State',\n  },\n  slug: 'state',\n}\n\nconst Country: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    width,\n    required,\n  ],\n  labels: {\n    plural: 'Country Fields',\n    singular: 'Country',\n  },\n  slug: 'country',\n}\n\nconst Checkbox: Block = {\n  fields: [\n    {\n      fields: [\n        {\n          ...name,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...label,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      fields: [\n        {\n          ...width,\n          admin: {\n            width: '50%',\n          },\n        },\n        {\n          ...required,\n          admin: {\n            width: '50%',\n          },\n        },\n      ],\n      type: 'row',\n    },\n    {\n      name: 'defaultValue',\n      label: 'Default Value',\n      type: 'checkbox',\n    },\n  ],\n  labels: {\n    plural: 'Checkbox Fields',\n    singular: 'Checkbox',\n  },\n  slug: 'checkbox',\n}\n\nconst Payment = (fieldConfig: PaymentFieldConfig): Block => {\n  let paymentProcessorField = null\n  if (fieldConfig?.paymentProcessor) {\n    paymentProcessorField = {\n      name: 'paymentProcessor',\n      label: 'Payment Processor',\n      options: [],\n      type: 'select',\n      ...fieldConfig.paymentProcessor,\n    }\n  }\n\n  const fields = {\n    fields: [\n      {\n        fields: [\n          {\n            ...name,\n            admin: {\n              width: '50%',\n            },\n          },\n          {\n            ...label,\n            admin: {\n              width: '50%',\n            },\n          },\n        ],\n        type: 'row',\n      },\n      {\n        fields: [\n          {\n            ...width,\n            admin: {\n              width: '50%',\n            },\n          },\n          {\n            name: 'basePrice',\n            admin: {\n              width: '50%',\n            },\n            label: 'Base Price',\n            type: 'number',\n          },\n        ],\n        type: 'row',\n      },\n      paymentProcessorField,\n      {\n        name: 'priceConditions',\n        fields: [\n          {\n            name: 'fieldToUse',\n            admin: {\n              components: {\n                Field: DynamicFieldSelector,\n              },\n            },\n            type: 'text',\n          },\n          {\n            name: 'condition',\n            defaultValue: 'hasValue',\n            label: 'Condition',\n            options: [\n              {\n                label: 'Has Any Value',\n                value: 'hasValue',\n              },\n              {\n                label: 'Equals',\n                value: 'equals',\n              },\n              {\n                label: 'Does Not Equal',\n                value: 'notEquals',\n              },\n            ],\n            type: 'select',\n          },\n          {\n            name: 'valueForCondition',\n            admin: {\n              condition: (_: any, { condition }: any) =>\n                condition === 'equals' || condition === 'notEquals',\n            },\n            label: 'Value',\n            type: 'text',\n          },\n          {\n            name: 'operator',\n            defaultValue: 'add',\n            options: [\n              {\n                label: 'Add',\n                value: 'add',\n              },\n              {\n                label: 'Subtract',\n                value: 'subtract',\n              },\n              {\n                label: 'Multiply',\n                value: 'multiply',\n              },\n              {\n                label: 'Divide',\n                value: 'divide',\n              },\n            ],\n            type: 'select',\n          },\n          {\n            name: 'valueType',\n            admin: {\n              width: '100%',\n            },\n            defaultValue: 'static',\n            label: 'Value Type',\n            options: [\n              {\n                label: 'Static Value',\n                value: 'static',\n              },\n              {\n                label: 'Value Of Field',\n                value: 'valueOfField',\n              },\n            ],\n            type: 'radio',\n          },\n          {\n            name: 'valueForOperator',\n            admin: {\n              components: {\n                Field: DynamicPriceSelector,\n              },\n            },\n            label: 'Value',\n            type: 'text',\n          },\n        ],\n        label: 'Price Conditions',\n        labels: {\n          plural: 'Price Conditions',\n          singular: 'Price Condition',\n        },\n        type: 'array',\n      },\n      required,\n    ].filter(Boolean) as Field[],\n    labels: {\n      plural: 'Payment Fields',\n      singular: 'Payment',\n    },\n    slug: 'payment',\n  }\n\n  return fields\n}\n\nconst Message: Block = {\n  fields: [\n    {\n      name: 'message',\n      localized: true,\n      type: 'richText',\n    },\n  ],\n  labels: {\n    plural: 'Message Blocks',\n    singular: 'Message',\n  },\n  slug: 'message',\n}\n\n// eslint-disable-next-line @typescript-eslint/consistent-type-assertions\nexport const fields = {\n  checkbox: Checkbox,\n  country: Country,\n  email: Email,\n  message: Message,\n  number: Number,\n  payment: Payment,\n  select: Select,\n  state: State,\n  text: Text,\n  textarea: TextArea,\n} as {\n  [key: string]: ((fieldConfig?: FieldConfig | boolean) => Block) | Block\n}\n\nexport default fields\n"],"names":["fields","name","label","required","type","localized","width","Select","admin","labels","plural","singular","slug","Text","TextArea","Number","Email","State","Country","Checkbox","Payment","fieldConfig","paymentProcessorField","paymentProcessor","options","components","Field","DynamicFieldSelector","defaultValue","value","condition","_","DynamicPriceSelector","filter","Boolean","Message","checkbox","country","email","message","number","payment","select","state","text","textarea"],"mappings":"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"}