@formio/js 5.1.0-dev.6042.18ef5d3 → 5.1.0-dev.6042.603237d

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 (156) hide show
  1. package/Changelog.md +57 -402
  2. package/README.md +7 -0
  3. package/dist/formio.builder.css +1 -0
  4. package/dist/formio.builder.min.css +1 -1
  5. package/dist/formio.form.css +1 -0
  6. package/dist/formio.form.js +104 -126
  7. package/dist/formio.form.min.css +1 -1
  8. package/dist/formio.form.min.js +1 -1
  9. package/dist/formio.form.min.js.LICENSE.txt +3 -1
  10. package/dist/formio.full.css +1 -0
  11. package/dist/formio.full.js +111 -133
  12. package/dist/formio.full.min.css +1 -1
  13. package/dist/formio.full.min.js +1 -1
  14. package/dist/formio.full.min.js.LICENSE.txt +3 -1
  15. package/dist/formio.js +53 -64
  16. package/dist/formio.min.js +1 -1
  17. package/dist/formio.utils.js +66 -77
  18. package/dist/formio.utils.min.js +1 -1
  19. package/dist/formio.utils.min.js.LICENSE.txt +3 -1
  20. package/lib/cjs/Element.js +13 -36
  21. package/lib/cjs/EventEmitter.js +2 -25
  22. package/lib/cjs/Form.js +2 -25
  23. package/lib/cjs/PDF.js +1 -1
  24. package/lib/cjs/PDFBuilder.js +4 -5
  25. package/lib/cjs/Webform.js +8 -7
  26. package/lib/cjs/WebformBuilder.d.ts +1 -0
  27. package/lib/cjs/WebformBuilder.js +40 -14
  28. package/lib/cjs/Wizard.d.ts +1 -2
  29. package/lib/cjs/Wizard.js +18 -24
  30. package/lib/cjs/WizardBuilder.js +1 -1
  31. package/lib/cjs/components/_classes/component/Component.d.ts +26 -2
  32. package/lib/cjs/components/_classes/component/Component.js +97 -88
  33. package/lib/cjs/components/_classes/component/editForm/Component.edit.conditional.js +1 -1
  34. package/lib/cjs/components/_classes/component/editForm/Component.edit.logic.js +1 -1
  35. package/lib/cjs/components/_classes/componentModal/ComponentModal.js +1 -1
  36. package/lib/cjs/components/_classes/input/Input.js +1 -1
  37. package/lib/cjs/components/_classes/list/ListComponent.js +1 -1
  38. package/lib/cjs/components/_classes/nested/NestedComponent.js +7 -7
  39. package/lib/cjs/components/_classes/nestedarray/NestedArrayComponent.js +1 -1
  40. package/lib/cjs/components/_classes/nesteddata/NestedDataComponent.js +1 -1
  41. package/lib/cjs/components/address/Address.js +1 -1
  42. package/lib/cjs/components/alert/Alert.js +1 -1
  43. package/lib/cjs/components/button/Button.d.ts +1 -1
  44. package/lib/cjs/components/button/Button.js +7 -11
  45. package/lib/cjs/components/checkbox/Checkbox.js +1 -1
  46. package/lib/cjs/components/container/Container.js +1 -1
  47. package/lib/cjs/components/currency/Currency.js +1 -1
  48. package/lib/cjs/components/datagrid/DataGrid.js +5 -1
  49. package/lib/cjs/components/datetime/DateTime.d.ts +1 -1
  50. package/lib/cjs/components/datetime/DateTime.js +15 -13
  51. package/lib/cjs/components/day/Day.js +2 -2
  52. package/lib/cjs/components/editgrid/EditGrid.js +1 -1
  53. package/lib/cjs/components/editgrid/editForm/EditGrid.edit.display.js +1 -1
  54. package/lib/cjs/components/file/File.js +5 -6
  55. package/lib/cjs/components/form/Form.d.ts +0 -1
  56. package/lib/cjs/components/form/Form.js +26 -22
  57. package/lib/cjs/components/form/editForm/Form.edit.form.js +4 -3
  58. package/lib/cjs/components/number/Number.js +1 -1
  59. package/lib/cjs/components/panel/Panel.js +1 -1
  60. package/lib/cjs/components/radio/Radio.d.ts +8 -0
  61. package/lib/cjs/components/radio/Radio.js +16 -6
  62. package/lib/cjs/components/recaptcha/editForm/ReCaptcha.edit.display.js +1 -1
  63. package/lib/cjs/components/select/Select.d.ts +1 -0
  64. package/lib/cjs/components/select/Select.js +20 -4
  65. package/lib/cjs/components/select/editForm/Select.edit.data.js +1 -1
  66. package/lib/cjs/components/selectboxes/SelectBoxes.d.ts +6 -0
  67. package/lib/cjs/components/selectboxes/SelectBoxes.js +4 -1
  68. package/lib/cjs/components/signature/Signature.js +1 -1
  69. package/lib/cjs/components/survey/Survey.js +1 -1
  70. package/lib/cjs/components/tags/Tags.js +1 -1
  71. package/lib/cjs/components/textarea/TextArea.js +3 -3
  72. package/lib/cjs/components/textfield/TextField.js +9 -32
  73. package/lib/cjs/components/time/Time.js +1 -1
  74. package/lib/cjs/formio.form.js +3 -3
  75. package/lib/cjs/providers/storage/uploadAdapter.js +3 -3
  76. package/lib/cjs/translations/en.js +1 -1
  77. package/lib/cjs/utils/Evaluator.d.ts +20 -6
  78. package/lib/cjs/utils/Evaluator.js +38 -15
  79. package/lib/cjs/utils/builder.js +5 -5
  80. package/lib/cjs/utils/conditionOperators/IsEqualTo.js +3 -3
  81. package/lib/cjs/utils/formUtils.d.ts +2 -2
  82. package/lib/cjs/utils/index.d.ts +169 -2
  83. package/lib/cjs/utils/index.js +22 -2
  84. package/lib/cjs/utils/utils.d.ts +31 -37
  85. package/lib/cjs/utils/utils.js +79 -135
  86. package/lib/cjs/widgets/CalendarWidget.d.ts +1 -8
  87. package/lib/cjs/widgets/CalendarWidget.js +19 -40
  88. package/lib/mjs/Element.js +6 -6
  89. package/lib/mjs/EventEmitter.js +2 -2
  90. package/lib/mjs/Form.js +1 -1
  91. package/lib/mjs/PDF.js +1 -1
  92. package/lib/mjs/PDFBuilder.js +1 -2
  93. package/lib/mjs/Webform.js +6 -5
  94. package/lib/mjs/WebformBuilder.d.ts +1 -0
  95. package/lib/mjs/WebformBuilder.js +32 -7
  96. package/lib/mjs/Wizard.d.ts +1 -2
  97. package/lib/mjs/Wizard.js +17 -23
  98. package/lib/mjs/WizardBuilder.js +1 -1
  99. package/lib/mjs/components/_classes/component/Component.d.ts +26 -2
  100. package/lib/mjs/components/_classes/component/Component.js +70 -38
  101. package/lib/mjs/components/_classes/component/editForm/Component.edit.conditional.js +1 -1
  102. package/lib/mjs/components/_classes/component/editForm/Component.edit.logic.js +1 -1
  103. package/lib/mjs/components/_classes/componentModal/ComponentModal.js +1 -1
  104. package/lib/mjs/components/_classes/input/Input.js +1 -1
  105. package/lib/mjs/components/_classes/list/ListComponent.js +1 -1
  106. package/lib/mjs/components/_classes/nested/NestedComponent.js +7 -7
  107. package/lib/mjs/components/_classes/nestedarray/NestedArrayComponent.js +1 -1
  108. package/lib/mjs/components/_classes/nesteddata/NestedDataComponent.js +1 -1
  109. package/lib/mjs/components/address/Address.js +1 -1
  110. package/lib/mjs/components/alert/Alert.js +1 -1
  111. package/lib/mjs/components/button/Button.d.ts +1 -1
  112. package/lib/mjs/components/button/Button.js +7 -10
  113. package/lib/mjs/components/checkbox/Checkbox.js +1 -1
  114. package/lib/mjs/components/container/Container.js +1 -1
  115. package/lib/mjs/components/currency/Currency.js +1 -1
  116. package/lib/mjs/components/datagrid/DataGrid.js +5 -1
  117. package/lib/mjs/components/datetime/DateTime.d.ts +1 -1
  118. package/lib/mjs/components/datetime/DateTime.js +15 -13
  119. package/lib/mjs/components/day/Day.js +2 -2
  120. package/lib/mjs/components/editgrid/EditGrid.js +1 -1
  121. package/lib/mjs/components/editgrid/editForm/EditGrid.edit.display.js +1 -1
  122. package/lib/mjs/components/file/File.js +5 -6
  123. package/lib/mjs/components/form/Form.d.ts +0 -1
  124. package/lib/mjs/components/form/Form.js +25 -22
  125. package/lib/mjs/components/form/editForm/Form.edit.form.js +3 -2
  126. package/lib/mjs/components/number/Number.js +1 -1
  127. package/lib/mjs/components/panel/Panel.js +1 -1
  128. package/lib/mjs/components/radio/Radio.d.ts +8 -0
  129. package/lib/mjs/components/radio/Radio.js +16 -6
  130. package/lib/mjs/components/recaptcha/editForm/ReCaptcha.edit.display.js +1 -1
  131. package/lib/mjs/components/select/Select.d.ts +1 -0
  132. package/lib/mjs/components/select/Select.js +20 -4
  133. package/lib/mjs/components/select/editForm/Select.edit.data.js +1 -1
  134. package/lib/mjs/components/selectboxes/SelectBoxes.d.ts +6 -0
  135. package/lib/mjs/components/selectboxes/SelectBoxes.js +4 -1
  136. package/lib/mjs/components/signature/Signature.js +1 -1
  137. package/lib/mjs/components/survey/Survey.js +1 -1
  138. package/lib/mjs/components/tags/Tags.js +1 -1
  139. package/lib/mjs/components/textarea/TextArea.js +3 -3
  140. package/lib/mjs/components/textfield/TextField.js +3 -3
  141. package/lib/mjs/components/time/Time.js +1 -1
  142. package/lib/mjs/formio.form.js +2 -2
  143. package/lib/mjs/providers/storage/uploadAdapter.js +3 -3
  144. package/lib/mjs/translations/en.js +3 -0
  145. package/lib/mjs/utils/Evaluator.d.ts +20 -6
  146. package/lib/mjs/utils/Evaluator.js +31 -13
  147. package/lib/mjs/utils/builder.js +1 -1
  148. package/lib/mjs/utils/conditionOperators/IsEqualTo.js +1 -1
  149. package/lib/mjs/utils/formUtils.d.ts +2 -2
  150. package/lib/mjs/utils/index.d.ts +169 -2
  151. package/lib/mjs/utils/index.js +18 -1
  152. package/lib/mjs/utils/utils.d.ts +31 -37
  153. package/lib/mjs/utils/utils.js +71 -109
  154. package/lib/mjs/widgets/CalendarWidget.d.ts +1 -8
  155. package/lib/mjs/widgets/CalendarWidget.js +19 -40
  156. package/package.json +8 -6
@@ -20,6 +20,8 @@
20
20
 
21
21
  /*! @license DOMPurify 3.2.4 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.2.4/LICENSE */
22
22
 
23
+ /*! @license DOMPurify 3.2.5 | (c) Cure53 and other contributors | Released under the Apache license 2.0 and Mozilla Public License 2.0 | github.com/cure53/DOMPurify/blob/3.2.5/LICENSE */
24
+
23
25
  /*! formiojs v5.1.0-dev.2 | https://unpkg.com/formiojs@5.1.0-dev.2/LICENSE.txt */
24
26
 
25
27
  /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */
@@ -43,4 +45,4 @@
43
45
 
44
46
  //! moment.js
45
47
 
46
- //! version : 0.5.46
48
+ //! version : 0.5.48
@@ -1,38 +1,15 @@
1
1
  "use strict";
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;
24
- };
25
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
4
  };
28
5
  Object.defineProperty(exports, "__esModule", { value: true });
29
- const EventEmitter_1 = __importDefault(require("./EventEmitter"));
30
- const Formio_1 = require("./Formio");
31
- const FormioUtils = __importStar(require("./utils/utils"));
32
- const core_1 = require("@formio/core");
33
6
  const lodash_1 = __importDefault(require("lodash"));
34
7
  const moment_1 = __importDefault(require("moment"));
35
8
  const vanilla_text_mask_1 = __importDefault(require("@formio/vanilla-text-mask"));
9
+ const EventEmitter_1 = __importDefault(require("./EventEmitter"));
10
+ const Formio_1 = require("./Formio");
11
+ const utils_1 = __importDefault(require("./utils"));
12
+ const core_1 = require("@formio/core");
36
13
  const en_1 = __importDefault(require("./translations/en"));
37
14
  /**
38
15
  * The root component for all elements within the Form.io renderer.
@@ -57,7 +34,7 @@ class Element {
57
34
  * can also be provided from the component.id value passed into the constructor.
58
35
  * @type {string}
59
36
  */
60
- this.id = FormioUtils.getRandomComponentId();
37
+ this.id = utils_1.default.getRandomComponentId();
61
38
  /**
62
39
  * An array of event handlers so that the destry command can deregister them.
63
40
  * @type {Array}
@@ -386,7 +363,7 @@ class Element {
386
363
  */
387
364
  setInputMask(input, inputMask, usePlaceholder) {
388
365
  if (input && inputMask) {
389
- const mask = FormioUtils.getInputMask(inputMask, this.placeholderChar);
366
+ const mask = utils_1.default.getInputMask(inputMask, this.placeholderChar);
390
367
  this.defaultMask = mask;
391
368
  try {
392
369
  //destroy previous mask
@@ -524,8 +501,8 @@ class Element {
524
501
  var _a;
525
502
  return Object.assign({
526
503
  _: lodash_1.default,
527
- utils: FormioUtils,
528
- util: FormioUtils,
504
+ utils: utils_1.default,
505
+ util: utils_1.default,
529
506
  user: Formio_1.Formio.getUser(),
530
507
  moment: moment_1.default,
531
508
  instance: this,
@@ -550,15 +527,15 @@ class Element {
550
527
  */
551
528
  interpolate(string, data, options = {}) {
552
529
  if (typeof string !== 'function' && (this.component.content || this.component.html)
553
- && !FormioUtils.Evaluator.templateSettings.interpolate.test(string)) {
554
- string = FormioUtils.translateHTMLTemplate(String(string), (value) => this.t(value));
530
+ && !utils_1.default.Evaluator.templateSettings.interpolate.test(string)) {
531
+ string = utils_1.default.translateHTMLTemplate(String(string), (value) => this.t(value));
555
532
  }
556
533
  if (this.component.filter === string && !this.options.building) {
557
534
  const evalContext = this.evalContext(data);
558
535
  evalContext.data = lodash_1.default.mapValues(evalContext.data, (val) => lodash_1.default.isString(val) ? encodeURIComponent(val) : val);
559
- return FormioUtils.interpolate(string, evalContext, options);
536
+ return utils_1.default.Evaluator.interpolate(string, evalContext, options);
560
537
  }
561
- return FormioUtils.interpolate(string, this.evalContext(data), options);
538
+ return utils_1.default.Evaluator.interpolate(string, this.evalContext(data), options);
562
539
  }
563
540
  /**
564
541
  * Performs an evaluation using the evaluation context of this component.
@@ -570,7 +547,7 @@ class Element {
570
547
  * @returns {*} - The result of the evaluation.
571
548
  */
572
549
  evaluate(func, args, ret, interpolate, options = {}) {
573
- return FormioUtils.evaluate(func, this.evalContext(args), ret, interpolate, options);
550
+ return utils_1.default.evaluate(func, this.evalContext(args), ret, interpolate, options);
574
551
  }
575
552
  /**
576
553
  * Allow for options to hook into the functionality of this renderer.
@@ -1,30 +1,7 @@
1
1
  "use strict";
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;
24
- };
25
2
  Object.defineProperty(exports, "__esModule", { value: true });
26
3
  const eventemitter3_1 = require("eventemitter3");
27
- const utils = __importStar(require("./utils/utils"));
4
+ const utils_1 = require("./utils");
28
5
  class EventEmitter extends eventemitter3_1.EventEmitter {
29
6
  constructor(conf = {}) {
30
7
  const { loadLimit = 1000, eventsSafeInterval = 300 } = conf;
@@ -38,7 +15,7 @@ class EventEmitter extends eventemitter3_1.EventEmitter {
38
15
  const overloadHandler = () => {
39
16
  console.warn(`There were more than ${loadLimit} events emitted in ${eventsSafeInterval} ms. It might be caused by events' infinite loop`, this.id);
40
17
  };
41
- const dispatch = utils.observeOverload(overloadHandler, {
18
+ const dispatch = (0, utils_1.observeOverload)(overloadHandler, {
42
19
  limit: loadLimit,
43
20
  delay: eventsSafeInterval
44
21
  });
package/lib/cjs/Form.js CHANGED
@@ -1,27 +1,4 @@
1
1
  "use strict";
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;
24
- };
25
2
  var __importDefault = (this && this.__importDefault) || function (mod) {
26
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
4
  };
@@ -30,7 +7,7 @@ const Element_1 = __importDefault(require("./Element"));
30
7
  const Formio_1 = require("./Formio");
31
8
  const displays_1 = __importDefault(require("./displays"));
32
9
  const templates_1 = __importDefault(require("./templates"));
33
- const FormioUtils = __importStar(require("./utils/utils"));
10
+ const utils_1 = __importDefault(require("./utils"));
34
11
  class Form extends Element_1.default {
35
12
  constructor(elementOrForm, formOrOptions, options = {}) {
36
13
  let element, form, formOptions;
@@ -324,7 +301,7 @@ class Form extends Element_1.default {
324
301
  if (this.options.sanitize === false && !forceSanitize) {
325
302
  return dirty;
326
303
  }
327
- return FormioUtils.sanitize(dirty, this.options);
304
+ return utils_1.default.sanitize(dirty, this.options);
328
305
  }
329
306
  setContent(element, content, forceSanitize) {
330
307
  if (element instanceof HTMLElement) {
package/lib/cjs/PDF.js CHANGED
@@ -5,7 +5,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const Formio_1 = require("./Formio");
7
7
  const Webform_1 = __importDefault(require("./Webform"));
8
- const utils_1 = require("./utils/utils");
8
+ const utils_1 = require("./utils");
9
9
  class PDF extends Webform_1.default {
10
10
  constructor(element, options) {
11
11
  options.display = 'pdf';
@@ -6,8 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const lodash_1 = __importDefault(require("lodash"));
7
7
  const Formio_1 = require("./Formio");
8
8
  const WebformBuilder_1 = __importDefault(require("./WebformBuilder"));
9
- const utils_1 = require("./utils/utils");
10
- const formUtils_1 = require("./utils/formUtils");
9
+ const utils_1 = require("./utils");
11
10
  const builder_1 = __importDefault(require("./utils/builder"));
12
11
  const PDF_1 = __importDefault(require("./PDF"));
13
12
  class PDFBuilder extends WebformBuilder_1.default {
@@ -272,7 +271,7 @@ class PDFBuilder extends WebformBuilder_1.default {
272
271
  getParentContainer(component) {
273
272
  let container = [];
274
273
  let originalComponent = null;
275
- (0, formUtils_1.eachComponent)(this.webform._form.components, (comp, path, components) => {
274
+ (0, utils_1.eachComponent)(this.webform._form.components, (comp, path, components) => {
276
275
  if (comp.id === component.component.id) {
277
276
  container = components;
278
277
  originalComponent = comp;
@@ -455,7 +454,7 @@ class PDFBuilder extends WebformBuilder_1.default {
455
454
  const repeatablePaths = this.findRepeatablePaths();
456
455
  // update elements which path was duplicated if any pathes have been changed
457
456
  if (!lodash_1.default.isEqual(this.repeatablePaths, repeatablePaths)) {
458
- (0, formUtils_1.eachComponent)(this.webform.getComponents(), (comp, path) => {
457
+ (0, utils_1.eachComponent)(this.webform.getComponents(), (comp, path) => {
459
458
  if (this.repeatablePaths.includes(path)) {
460
459
  this.webform.postMessage({ name: 'updateElement', data: comp.component });
461
460
  }
@@ -465,7 +464,7 @@ class PDFBuilder extends WebformBuilder_1.default {
465
464
  if (!repeatablePaths.length) {
466
465
  return;
467
466
  }
468
- (0, formUtils_1.eachComponent)(this.webform.getComponents(), (comp, path) => {
467
+ (0, utils_1.eachComponent)(this.webform.getComponents(), (comp, path) => {
469
468
  if (this.repeatablePaths.includes(path)) {
470
469
  this.webform.postMessage({
471
470
  name: 'showBuilderErrors',
@@ -4,15 +4,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const lodash_1 = __importDefault(require("lodash"));
7
- const moment_1 = __importDefault(require("moment"));
8
7
  const compare_versions_1 = require("compare-versions");
9
8
  const EventEmitter_1 = __importDefault(require("./EventEmitter"));
10
9
  const en_1 = __importDefault(require("./translations/en"));
11
10
  const Formio_1 = require("./Formio");
12
11
  const Components_1 = __importDefault(require("./components/Components"));
13
12
  const NestedDataComponent_1 = __importDefault(require("./components/_classes/nesteddata/NestedDataComponent"));
14
- const utils_1 = require("./utils/utils");
15
- const formUtils_1 = require("./utils/formUtils");
13
+ const utils_1 = require("./utils");
14
+ const dayjs_1 = __importDefault(require("dayjs"));
16
15
  // We need this here because dragula pulls in CustomEvent class that requires global to exist.
17
16
  if (typeof window !== 'undefined' && typeof window.global === 'undefined') {
18
17
  window.global = window;
@@ -661,7 +660,9 @@ class Webform extends NestedDataComponent_1.default {
661
660
  const rebuild = this.rebuild() || Promise.resolve();
662
661
  return rebuild.then(() => {
663
662
  this.emit('formLoad', form);
664
- this.triggerCaptcha();
663
+ if (!this.options.server) {
664
+ this.triggerCaptcha();
665
+ }
665
666
  // Make sure to trigger onChange after a render event occurs to speed up form rendering.
666
667
  setTimeout(() => {
667
668
  this.onChange(flags);
@@ -990,7 +991,7 @@ class Webform extends NestedDataComponent_1.default {
990
991
  }
991
992
  hasRequiredFields() {
992
993
  let result = false;
993
- (0, formUtils_1.eachComponent)(this.form.components, (component) => {
994
+ (0, utils_1.eachComponent)(this.form.components, (component) => {
994
995
  if (component.validate.required) {
995
996
  result = true;
996
997
  return true;
@@ -1312,7 +1313,7 @@ class Webform extends NestedDataComponent_1.default {
1312
1313
  submission.metadata = submission.metadata || {};
1313
1314
  lodash_1.default.defaults(submission.metadata, {
1314
1315
  timezone: lodash_1.default.get(this, '_submission.metadata.timezone', (0, utils_1.currentTimezone)()),
1315
- offset: parseInt(lodash_1.default.get(this, '_submission.metadata.offset', (0, moment_1.default)().utcOffset()), 10),
1316
+ offset: parseInt(lodash_1.default.get(this, '_submission.metadata.offset', (0, dayjs_1.default)().utcOffset()), 10),
1316
1317
  origin: document.location.origin,
1317
1318
  referrer: document.referrer,
1318
1319
  browserName: navigator.appName,
@@ -1537,7 +1538,7 @@ class Webform extends NestedDataComponent_1.default {
1537
1538
  return;
1538
1539
  }
1539
1540
  const captchaComponent = [];
1540
- (0, formUtils_1.eachComponent)(components || this.components, (component) => {
1541
+ (0, utils_1.eachComponent)(components || this.components, (component) => {
1541
1542
  if (/^(re)?captcha$/.test(component.type) && component.component.eventType === 'formLoad') {
1542
1543
  captchaComponent.push(component);
1543
1544
  }
@@ -77,6 +77,7 @@ export default class WebformBuilder extends Component {
77
77
  removeComponent(component: any, parent: any, original: any, componentInstance: any): boolean | undefined;
78
78
  replaceDoubleQuotes(data: any, fieldsToRemoveDoubleQuotes?: any[]): any;
79
79
  updateComponent(component: any, changed: any): void;
80
+ originalDefaultValue: any;
80
81
  findRepeatablePaths(): any[];
81
82
  highlightInvalidComponents(): void;
82
83
  /**
@@ -8,8 +8,7 @@ const Component_1 = __importDefault(require("./components/_classes/component/Com
8
8
  const tippy_js_1 = __importDefault(require("tippy.js"));
9
9
  const Components_1 = __importDefault(require("./components/Components"));
10
10
  const Formio_1 = require("./Formio");
11
- const utils_1 = require("./utils/utils");
12
- const formUtils_1 = require("./utils/formUtils");
11
+ const utils_1 = require("./utils");
13
12
  const builder_1 = __importDefault(require("./utils/builder"));
14
13
  const lodash_1 = __importDefault(require("lodash"));
15
14
  const dom_autoscroller_1 = __importDefault(require("dom-autoscroller"));
@@ -284,7 +283,7 @@ class WebformBuilder extends Component_1.default {
284
283
  componentOrder: [],
285
284
  default: index === 0,
286
285
  };
287
- (0, formUtils_1.eachComponent)(resource.components, (component) => {
286
+ (0, utils_1.eachComponent)(resource.components, (component) => {
288
287
  if (component.type === 'button')
289
288
  return;
290
289
  if (this.options &&
@@ -450,7 +449,7 @@ class WebformBuilder extends Component_1.default {
450
449
  return [...componentSchema.components, componentSchema];
451
450
  }
452
451
  // Get the namespace component so we have the original object.
453
- const namespaceComponent = (0, formUtils_1.getComponent)(this.form.components, namespaceKey, true);
452
+ const namespaceComponent = (0, utils_1.getComponent)(this.form.components, namespaceKey, true);
454
453
  return namespaceComponent ? namespaceComponent.components : comp.components;
455
454
  }
456
455
  recurseNamespace(component) {
@@ -812,7 +811,7 @@ class WebformBuilder extends Component_1.default {
812
811
  const draggableComponent = ((_a = this.groups[group]) === null || _a === void 0 ? void 0 : _a.components[compKey]) || {};
813
812
  if (draggableComponent.disableSiblings || draggableComponent.uniqueComponent) {
814
813
  let isCompAlreadyExists = false;
815
- (0, formUtils_1.eachComponent)(this.webform.components, (component) => {
814
+ (0, utils_1.eachComponent)(this.webform.components, (component) => {
816
815
  if ((draggableComponent.disableSiblings && component.type === draggableComponent.schema.type) ||
817
816
  (draggableComponent.uniqueComponent && component.component.key === draggableComponent.schema.key)) {
818
817
  isCompAlreadyExists = true;
@@ -947,7 +946,7 @@ class WebformBuilder extends Component_1.default {
947
946
  //populate isEnabled for captcha form settings
948
947
  let isCaptchaEnabled = false;
949
948
  if (this.form.components) {
950
- (0, formUtils_1.eachComponent)(form.components, component => {
949
+ (0, utils_1.eachComponent)(form.components, component => {
951
950
  if (isCaptchaEnabled) {
952
951
  return;
953
952
  }
@@ -1042,7 +1041,7 @@ class WebformBuilder extends Component_1.default {
1042
1041
  }
1043
1042
  }
1044
1043
  // Change the "default value" field to be reflective of this component.
1045
- const defaultValueComponent = (0, formUtils_1.getComponent)(this.editForm.components, 'defaultValue', true);
1044
+ const defaultValueComponent = (0, utils_1.getComponent)(this.editForm.components, 'defaultValue', true);
1046
1045
  if (defaultValueComponent && component.type !== 'hidden') {
1047
1046
  const defaultChanged = changed && ((changed.component && changed.component.key === 'defaultValue')
1048
1047
  || (changed.instance && defaultValueComponent.hasComponent && defaultValueComponent.hasComponent(changed.instance)));
@@ -1070,6 +1069,17 @@ class WebformBuilder extends Component_1.default {
1070
1069
  'fields.month.required',
1071
1070
  'fields.year.required',
1072
1071
  ]));
1072
+ if (defaultValueComponent.component.components) {
1073
+ if (!this.originalDefaultValue) {
1074
+ this.originalDefaultValue = (0, utils_1.fastCloneDeep)(defaultValueComponent.component);
1075
+ }
1076
+ (0, utils_1.eachComponent)(defaultValueComponent.component.components, (comp => {
1077
+ var _a;
1078
+ if ((_a = comp.validate) === null || _a === void 0 ? void 0 : _a.required) {
1079
+ comp.validate.required = false;
1080
+ }
1081
+ }));
1082
+ }
1073
1083
  const parentComponent = defaultValueComponent.parent;
1074
1084
  let tabIndex = -1;
1075
1085
  let index = -1;
@@ -1118,12 +1128,15 @@ class WebformBuilder extends Component_1.default {
1118
1128
  findRepeatablePaths() {
1119
1129
  const repeatablePaths = [];
1120
1130
  const keys = new Map();
1121
- (0, formUtils_1.eachComponent)(this.form.components, (comp, path, components, parent, paths) => {
1122
- if (keys.has(paths.dataPath)) {
1123
- repeatablePaths.push(paths.dataPath);
1124
- }
1125
- else {
1126
- keys.set(paths.dataPath, true);
1131
+ (0, utils_1.eachComponent)(this.form.components, (comp, path, components, parent, paths) => {
1132
+ const isLayout = (0, utils_1.componentInfo)(comp).layout;
1133
+ if (!isLayout) {
1134
+ if (keys.has(paths.dataPath)) {
1135
+ repeatablePaths.push(paths.dataPath);
1136
+ }
1137
+ else {
1138
+ keys.set(paths.dataPath, true);
1139
+ }
1127
1140
  }
1128
1141
  }, true);
1129
1142
  return repeatablePaths;
@@ -1131,12 +1144,22 @@ class WebformBuilder extends Component_1.default {
1131
1144
  highlightInvalidComponents() {
1132
1145
  const repeatablePaths = this.findRepeatablePaths();
1133
1146
  let hasInvalidComponents = false;
1147
+ // Matches anything expect letters and '_' at the beginning of the key and anything except of letters, numbers,
1148
+ // '-', '.' and '_' in the rest of the key
1149
+ const badCharacters = /^[^A-Za-z_]+|[^A-Za-z0-9\-._]+/g;
1134
1150
  this.webform.everyComponent((comp) => {
1135
1151
  const path = comp.path;
1136
1152
  if (repeatablePaths.includes(path)) {
1137
1153
  comp.setCustomValidity(this.t('apiKey', { key: comp.key }));
1138
1154
  hasInvalidComponents = true;
1139
1155
  }
1156
+ else if (comp.key.replace(badCharacters, '') === '') {
1157
+ comp.setCustomValidity(this.t('apiKeyNotValid', { key: comp.key }));
1158
+ hasInvalidComponents = true;
1159
+ }
1160
+ else {
1161
+ comp.setCustomValidity();
1162
+ }
1140
1163
  });
1141
1164
  this.emit('builderFormValidityChange', hasInvalidComponents);
1142
1165
  }
@@ -1161,6 +1184,9 @@ class WebformBuilder extends Component_1.default {
1161
1184
  if (index !== -1) {
1162
1185
  let submissionData = this.editForm.submission.data;
1163
1186
  submissionData = submissionData.componentJson || submissionData;
1187
+ if (submissionData.components && this.originalDefaultValue) {
1188
+ submissionData.components = this.originalDefaultValue.components;
1189
+ }
1164
1190
  const fieldsToRemoveDoubleQuotes = ['label', 'tooltip'];
1165
1191
  this.replaceDoubleQuotes(submissionData, fieldsToRemoveDoubleQuotes);
1166
1192
  this.hook('beforeSaveComponentSettings', submissionData);
@@ -1627,7 +1653,7 @@ class WebformBuilder extends Component_1.default {
1627
1653
  if (!Components_1.default.components[type === 'custom' ? 'unknown' : type]) {
1628
1654
  return false;
1629
1655
  }
1630
- const editTabs = (0, formUtils_1.getComponent)(Components_1.default.components[type === 'custom' ? 'unknown' : type].editForm().components, 'tabs', true).components;
1656
+ const editTabs = (0, utils_1.getComponent)(Components_1.default.components[type === 'custom' ? 'unknown' : type].editForm().components, 'tabs', true).components;
1631
1657
  const hiddenEditTabs = lodash_1.default.filter(lodash_1.default.get(this.options, `editForm.${type}`, []), 'ignore');
1632
1658
  return lodash_1.default.intersectionBy(editTabs, hiddenEditTabs, 'key').length !== editTabs.length;
1633
1659
  }
@@ -6,7 +6,6 @@ declare class Wizard extends Webform {
6
6
  originalComponents: any[];
7
7
  page: number;
8
8
  currentPanel: any;
9
- currentPanels: any[] | null;
10
9
  currentNextPage: number;
11
10
  _seenPages: number[];
12
11
  subWizards: any[];
@@ -17,7 +16,7 @@ declare class Wizard extends Webform {
17
16
  originalOptions: any;
18
17
  isLastPage(): any;
19
18
  getPages(args?: {}): any[];
20
- get hasExtraPages(): boolean;
19
+ get hasSubWizards(): boolean;
21
20
  get localData(): any;
22
21
  get wizardKey(): string;
23
22
  set wizard(form: object);
package/lib/cjs/Wizard.js CHANGED
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const lodash_1 = __importDefault(require("lodash"));
7
7
  const Webform_1 = __importDefault(require("./Webform"));
8
8
  const Formio_1 = require("./Formio");
9
- const utils_1 = require("./utils/utils");
9
+ const utils_1 = require("./utils");
10
10
  class Wizard extends Webform_1.default {
11
11
  /**
12
12
  * Constructor for wizard-based forms.
@@ -34,7 +34,6 @@ class Wizard extends Webform_1.default {
34
34
  this.originalComponents = [];
35
35
  this.page = 0;
36
36
  this.currentPanel = null;
37
- this.currentPanels = null;
38
37
  this.currentNextPage = 0;
39
38
  this._seenPages = [0];
40
39
  this.subWizards = [];
@@ -53,12 +52,12 @@ class Wizard extends Webform_1.default {
53
52
  }
54
53
  getPages(args = {}) {
55
54
  const { all = false } = args;
56
- const pages = this.hasExtraPages ? this.components : this.pages;
55
+ const pages = this.hasSubWizards ? this.components : this.pages;
57
56
  const filteredPages = pages
58
57
  .filter(all ? lodash_1.default.identity : (p, index) => this._seenPages.includes(index));
59
58
  return filteredPages;
60
59
  }
61
- get hasExtraPages() {
60
+ get hasSubWizards() {
62
61
  return !lodash_1.default.isEmpty(this.subWizards);
63
62
  }
64
63
  get data() {
@@ -187,9 +186,9 @@ class Wizard extends Webform_1.default {
187
186
  }
188
187
  render() {
189
188
  const ctx = this.renderContext;
190
- if (this.component.key) {
191
- ctx.panels.map(panel => {
192
- if (panel.key === this.component.key) {
189
+ if (this.component.id) {
190
+ ctx.panels.forEach(panel => {
191
+ if (panel.id === this.component.id) {
193
192
  this.currentPanel = panel;
194
193
  ctx.wizardPageTooltip = this.getFormattedTooltip(panel.tooltip);
195
194
  }
@@ -587,7 +586,7 @@ class Wizard extends Webform_1.default {
587
586
  this.pageFieldLogic(num);
588
587
  this.getNextPage();
589
588
  let parentNum = num;
590
- if (this.hasExtraPages) {
589
+ if (this.hasSubWizards) {
591
590
  const pageFromPages = this.pages[num];
592
591
  const pageFromComponents = this.components[num];
593
592
  if (!pageFromComponents || (pageFromPages === null || pageFromPages === void 0 ? void 0 : pageFromPages.id) !== pageFromComponents.id) {
@@ -873,7 +872,7 @@ class Wizard extends Webform_1.default {
873
872
  }
874
873
  }
875
874
  onChange(flags, changed, modified, changes) {
876
- var _a, _b;
875
+ var _a;
877
876
  super.onChange(flags, changed, modified, changes);
878
877
  // The onChange loop doesn't need all components for wizards
879
878
  const errors = this.submitted ? this.validate(this.localData, { dirty: true }) : this.validateCurrentPage();
@@ -881,23 +880,18 @@ class Wizard extends Webform_1.default {
881
880
  this.showErrors(errors, true, true);
882
881
  }
883
882
  // If the pages change, need to redraw the header.
884
- let currentPanels;
885
- let panels;
883
+ const currentPanels = this.pages;
884
+ // calling this.establishPages() updates/mutates this.pages to be the current pages
885
+ this.establishPages();
886
+ const newPanels = this.pages;
886
887
  const currentNextPage = this.currentNextPage;
887
- if (this.hasExtraPages) {
888
- currentPanels = this.pages.map(page => page.component.key);
889
- this.establishPages();
890
- panels = this.pages.map(page => page.component.key);
891
- }
892
- else {
893
- currentPanels = this.currentPanels || this.pages.map(page => page.component.key);
894
- panels = this.establishPages().map(panel => panel.key);
895
- this.currentPanels = panels;
896
- if (((_a = this.currentPanel) === null || _a === void 0 ? void 0 : _a.key) && ((_b = this.currentPanels) === null || _b === void 0 ? void 0 : _b.length)) {
897
- this.setPage(this.currentPanels.findIndex(panel => panel === this.currentPanel.key));
898
- }
888
+ const panelsUpdated = !lodash_1.default.isEqual(newPanels, currentPanels);
889
+ if (((_a = this.currentPanel) === null || _a === void 0 ? void 0 : _a.id) && this.pages.length && (!this.hasSubWizards || (this.hasSubWizards && panelsUpdated))) {
890
+ const newIndex = this.pages.findIndex(page => page.id === this.currentPanel.id);
891
+ if (newIndex !== -1)
892
+ this.setPage(newIndex);
899
893
  }
900
- if (!lodash_1.default.isEqual(panels, currentPanels) || (flags && flags.fromSubmission)) {
894
+ if (panelsUpdated || (flags && flags.fromSubmission)) {
901
895
  this.redrawHeader();
902
896
  }
903
897
  // If the next page changes, then make sure to redraw navigation.
@@ -7,7 +7,7 @@ const WebformBuilder_1 = __importDefault(require("./WebformBuilder"));
7
7
  const Webform_1 = __importDefault(require("./Webform"));
8
8
  const builder_1 = __importDefault(require("./utils/builder"));
9
9
  const lodash_1 = __importDefault(require("lodash"));
10
- const utils_1 = require("./utils/utils");
10
+ const utils_1 = require("./utils");
11
11
  class WizardBuilder extends WebformBuilder_1.default {
12
12
  constructor() {
13
13
  let element, options;
@@ -163,8 +163,17 @@ declare class Component extends Element {
163
163
  */
164
164
  info: any;
165
165
  get componentsMap(): object;
166
+ /**
167
+ * Returns if the parent should conditionally clear.
168
+ * @returns {boolean} - If the parent should conditionally clear.
169
+ */
166
170
  parentShouldConditionallyClear(): boolean;
167
171
  parentConditionallyHidden(): boolean;
172
+ /**
173
+ * Returns true if any of the parents default their component "hidden" property to true.
174
+ * @returns {boolean} - If any parent defaults the hidden property to true.
175
+ */
176
+ anyParentDefaultsHidden(): boolean;
168
177
  set data(value: any);
169
178
  get data(): any;
170
179
  mergeSchema(component?: {}): any;
@@ -228,8 +237,23 @@ declare class Component extends Element {
228
237
  get visible(): boolean;
229
238
  get logicallyHidden(): any;
230
239
  _logicallyHidden: any;
231
- shouldConditionallyClear(skipParent?: boolean): boolean;
232
- conditionallyHidden(skipParent?: boolean): boolean;
240
+ /**
241
+ * Determines if the component should clear its value when the root form is pristine.
242
+ * @returns {boolean} - If the component should clear its value when the root form is pristine.
243
+ */
244
+ shouldConditionallyClearOnPristine(): boolean;
245
+ /**
246
+ * Returns if the component should clear its value when conditionally hidden.
247
+ * @returns {boolean} - If the component should clear its value when conditionally hidden.
248
+ */
249
+ shouldConditionallyClear(): boolean;
250
+ _conditionallyClear: boolean | undefined;
251
+ /**
252
+ * Returns if the component is conditionally hidden.
253
+ * @returns {boolean} - If the component is conditionally hidden.
254
+ */
255
+ conditionallyHidden(): boolean;
256
+ _conditionallyHidden: boolean | undefined;
233
257
  set currentForm(instance: any);
234
258
  get currentForm(): any;
235
259
  _currentForm: any;