@formio/js 5.2.3 → 5.2.4-rc.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/dist/formio.builder.css +161 -50
- package/dist/formio.builder.min.css +1 -1
- package/dist/formio.embed.js +1 -1
- package/dist/formio.embed.min.js +1 -1
- package/dist/formio.embed.min.js.LICENSE.txt +1 -1
- package/dist/formio.form.css +158 -49
- package/dist/formio.form.js +152 -108
- package/dist/formio.form.min.css +1 -1
- package/dist/formio.form.min.js +1 -1
- package/dist/formio.form.min.js.LICENSE.txt +1 -1
- package/dist/formio.full.css +161 -50
- package/dist/formio.full.js +401 -227
- package/dist/formio.full.min.css +1 -1
- package/dist/formio.full.min.js +1 -1
- package/dist/formio.full.min.js.LICENSE.txt +1 -1
- package/dist/formio.js +51 -18
- package/dist/formio.min.js +1 -1
- package/dist/formio.min.js.LICENSE.txt +1 -1
- package/dist/formio.utils.js +47 -14
- package/dist/formio.utils.min.js +1 -1
- package/dist/formio.utils.min.js.LICENSE.txt +1 -1
- package/lib/cjs/CDN.js +12 -12
- package/lib/cjs/Element.d.ts +3 -2
- package/lib/cjs/Element.js +27 -21
- package/lib/cjs/Embed.js +74 -40
- package/lib/cjs/EventEmitter.js +1 -1
- package/lib/cjs/Form.d.ts +371 -341
- package/lib/cjs/Form.js +153 -39
- package/lib/cjs/FormBuilder.d.ts +3 -3
- package/lib/cjs/FormBuilder.js +2 -3
- package/lib/cjs/Formio.js +26 -23
- package/lib/cjs/InlineEmbed.js +23 -17
- package/lib/cjs/PDF.d.ts +1 -0
- package/lib/cjs/PDF.js +18 -15
- package/lib/cjs/PDFBuilder.js +51 -36
- package/lib/cjs/Webform.d.ts +8 -366
- package/lib/cjs/Webform.js +176 -235
- package/lib/cjs/WebformBuilder.js +217 -144
- package/lib/cjs/Wizard.js +92 -62
- package/lib/cjs/WizardBuilder.js +27 -19
- package/lib/cjs/addons/FormioAddon.js +1 -1
- package/lib/cjs/addons/PasswordStrength/PasswordStrengthAddon.form.js +59 -57
- package/lib/cjs/addons/PasswordStrength/PasswordStrengthAddon.js +24 -16
- package/lib/cjs/addons/index.js +3 -3
- package/lib/cjs/components/Components.js +0 -4
- package/lib/cjs/components/_classes/component/Component.form.js +11 -11
- package/lib/cjs/components/_classes/component/Component.js +298 -179
- package/lib/cjs/components/_classes/component/editForm/Component.edit.addons.js +2 -4
- package/lib/cjs/components/_classes/component/editForm/Component.edit.api.js +5 -5
- package/lib/cjs/components/_classes/component/editForm/Component.edit.conditional.js +9 -11
- package/lib/cjs/components/_classes/component/editForm/Component.edit.data.d.ts +37 -0
- package/lib/cjs/components/_classes/component/editForm/Component.edit.data.js +39 -25
- package/lib/cjs/components/_classes/component/editForm/Component.edit.display.js +47 -29
- package/lib/cjs/components/_classes/component/editForm/Component.edit.layout.js +9 -9
- package/lib/cjs/components/_classes/component/editForm/Component.edit.logic.js +5 -7
- package/lib/cjs/components/_classes/component/editForm/Component.edit.validation.js +37 -34
- package/lib/cjs/components/_classes/component/editForm/utils.js +12 -16
- package/lib/cjs/components/_classes/componentModal/ComponentModal.js +6 -6
- package/lib/cjs/components/_classes/field/Field.js +7 -1
- package/lib/cjs/components/_classes/input/Input.js +30 -26
- package/lib/cjs/components/_classes/list/ListComponent.form.js +1 -1
- package/lib/cjs/components/_classes/list/ListComponent.js +27 -18
- package/lib/cjs/components/_classes/list/editForm/ListComponent.edit.data.js +36 -9
- package/lib/cjs/components/_classes/multivalue/Multivalue.js +32 -13
- package/lib/cjs/components/_classes/nested/NestedComponent.form.js +3 -3
- package/lib/cjs/components/_classes/nested/NestedComponent.js +36 -32
- package/lib/cjs/components/_classes/nestedarray/NestedArrayComponent.js +19 -14
- package/lib/cjs/components/_classes/nesteddata/NestedDataComponent.js +19 -17
- package/lib/cjs/components/address/Address.js +52 -45
- package/lib/cjs/components/address/editForm/Address.edit.data.js +2 -2
- package/lib/cjs/components/address/editForm/Address.edit.display.js +2 -2
- package/lib/cjs/components/address/editForm/Address.edit.provider.js +53 -11
- package/lib/cjs/components/alert/Alert.js +21 -15
- package/lib/cjs/components/button/Button.form.js +1 -1
- package/lib/cjs/components/button/Button.js +50 -27
- package/lib/cjs/components/button/editForm/Button.edit.display.js +49 -9
- package/lib/cjs/components/checkbox/Checkbox.d.ts +1 -1
- package/lib/cjs/components/checkbox/Checkbox.form.js +3 -3
- package/lib/cjs/components/checkbox/Checkbox.js +28 -20
- package/lib/cjs/components/checkbox/editForm/Checkbox.edit.data.js +1 -1
- package/lib/cjs/components/checkbox/editForm/Checkbox.edit.display.js +13 -3
- package/lib/cjs/components/checkbox/editForm/Checkbox.edit.validation.js +2 -2
- package/lib/cjs/components/columns/Columns.form.js +1 -1
- package/lib/cjs/components/columns/Columns.js +24 -12
- package/lib/cjs/components/columns/editForm/Columns.edit.display.js +17 -17
- package/lib/cjs/components/container/Container.form.js +2 -2
- package/lib/cjs/components/container/Container.js +6 -4
- package/lib/cjs/components/container/editForm/Container.edit.data.js +3 -3
- package/lib/cjs/components/container/editForm/Container.edit.display.js +4 -4
- package/lib/cjs/components/content/Content.form.js +4 -2
- package/lib/cjs/components/content/Content.js +10 -8
- package/lib/cjs/components/content/editForm/Content.edit.display.js +10 -10
- package/lib/cjs/components/currency/Currency.form.js +3 -3
- package/lib/cjs/components/currency/Currency.js +19 -10
- package/lib/cjs/components/currency/editForm/Currency.edit.data.js +5 -5
- package/lib/cjs/components/currency/editForm/Currency.edit.display.js +8 -8
- package/lib/cjs/components/datagrid/DataGrid.form.js +3 -3
- package/lib/cjs/components/datagrid/DataGrid.js +89 -38
- package/lib/cjs/components/datagrid/editForm/DataGrid.edit.data.js +1 -1
- package/lib/cjs/components/datagrid/editForm/DataGrid.edit.display.js +14 -14
- package/lib/cjs/components/datagrid/editForm/DataGrid.edit.validation.js +3 -3
- package/lib/cjs/components/datamap/DataMap.form.js +2 -2
- package/lib/cjs/components/datamap/DataMap.js +44 -31
- package/lib/cjs/components/datamap/editForm/DataMap.edit.data.js +1 -1
- package/lib/cjs/components/datamap/editForm/DataMap.edit.display.js +8 -8
- package/lib/cjs/components/datetime/DateTime.form.js +5 -5
- package/lib/cjs/components/datetime/DateTime.js +30 -15
- package/lib/cjs/components/datetime/editForm/DateTime.edit.data.js +4 -3
- package/lib/cjs/components/datetime/editForm/DateTime.edit.date.js +10 -10
- package/lib/cjs/components/datetime/editForm/DateTime.edit.display.js +22 -17
- package/lib/cjs/components/datetime/editForm/DateTime.edit.time.js +5 -5
- package/lib/cjs/components/datetime/editForm/DateTime.edit.validation.js +3 -3
- package/lib/cjs/components/day/Day.form.js +5 -5
- package/lib/cjs/components/day/Day.js +146 -56
- package/lib/cjs/components/day/editForm/Day.edit.day.js +13 -9
- package/lib/cjs/components/day/editForm/Day.edit.display.js +7 -7
- package/lib/cjs/components/day/editForm/Day.edit.month.js +12 -8
- package/lib/cjs/components/day/editForm/Day.edit.validation.js +7 -7
- package/lib/cjs/components/day/editForm/Day.edit.year.js +8 -8
- package/lib/cjs/components/editgrid/EditGrid.form.js +2 -2
- package/lib/cjs/components/editgrid/EditGrid.js +137 -89
- package/lib/cjs/components/editgrid/editForm/EditGrid.edit.data.js +2 -2
- package/lib/cjs/components/editgrid/editForm/EditGrid.edit.display.js +7 -2
- package/lib/cjs/components/editgrid/editForm/EditGrid.edit.templates.js +16 -16
- package/lib/cjs/components/editgrid/editForm/EditGrid.edit.validation.js +3 -3
- package/lib/cjs/components/email/Email.js +4 -4
- package/lib/cjs/components/email/editForm/Email.edit.display.js +3 -3
- package/lib/cjs/components/email/editForm/Email.edit.validation.js +6 -6
- package/lib/cjs/components/fieldset/Fieldset.form.js +1 -1
- package/lib/cjs/components/fieldset/Fieldset.js +2 -2
- package/lib/cjs/components/fieldset/editForm/Fieldset.edit.display.js +8 -8
- package/lib/cjs/components/file/File.form.js +4 -4
- package/lib/cjs/components/file/File.js +126 -80
- package/lib/cjs/components/file/editForm/File.edit.display.js +9 -5
- package/lib/cjs/components/file/editForm/File.edit.file.d.ts +37 -16
- package/lib/cjs/components/file/editForm/File.edit.file.js +169 -72
- package/lib/cjs/components/file/editForm/File.edit.validation.js +2 -2
- package/lib/cjs/components/form/Form.form.js +3 -3
- package/lib/cjs/components/form/Form.js +67 -51
- package/lib/cjs/components/form/editForm/Form.edit.data.js +1 -3
- package/lib/cjs/components/form/editForm/Form.edit.display.js +6 -7
- package/lib/cjs/components/form/editForm/Form.edit.form.js +11 -9
- package/lib/cjs/components/hidden/Hidden.form.js +4 -4
- package/lib/cjs/components/hidden/Hidden.js +2 -2
- package/lib/cjs/components/hidden/editForm/Hidden.edit.data.js +3 -3
- package/lib/cjs/components/hidden/editForm/Hidden.edit.display.js +10 -10
- package/lib/cjs/components/html/HTML.js +23 -17
- package/lib/cjs/components/html/editForm/HTML.edit.display.js +17 -17
- package/lib/cjs/components/html/editForm/HTML.edit.logic.js +2 -2
- package/lib/cjs/components/number/Number.form.js +3 -3
- package/lib/cjs/components/number/Number.js +27 -11
- package/lib/cjs/components/number/editForm/Number.edit.data.js +3 -3
- package/lib/cjs/components/number/editForm/Number.edit.display.js +4 -4
- package/lib/cjs/components/number/editForm/Number.edit.validation.js +9 -9
- package/lib/cjs/components/panel/Panel.form.js +1 -1
- package/lib/cjs/components/panel/Panel.js +2 -2
- package/lib/cjs/components/panel/editForm/Panel.edit.conditional.js +5 -7
- package/lib/cjs/components/panel/editForm/Panel.edit.display.js +55 -29
- package/lib/cjs/components/password/Password.form.js +3 -3
- package/lib/cjs/components/password/Password.js +5 -2
- package/lib/cjs/components/password/editForm/Password.edit.data.js +11 -11
- package/lib/cjs/components/password/editForm/Password.edit.display.js +3 -3
- package/lib/cjs/components/password/editForm/Password.edit.validation.js +3 -3
- package/lib/cjs/components/phonenumber/PhoneNumber.form.js +8 -8
- package/lib/cjs/components/phonenumber/PhoneNumber.js +3 -3
- package/lib/cjs/components/phonenumber/editForm/PhoneNumber.edit.validation.js +6 -6
- package/lib/cjs/components/radio/Radio.form.js +3 -3
- package/lib/cjs/components/radio/Radio.js +55 -26
- package/lib/cjs/components/radio/editForm/Radio.edit.data.js +23 -9
- package/lib/cjs/components/radio/editForm/Radio.edit.display.js +6 -6
- package/lib/cjs/components/radio/editForm/Radio.edit.validation.js +2 -2
- package/lib/cjs/components/recaptcha/ReCaptcha.form.js +5 -5
- package/lib/cjs/components/recaptcha/ReCaptcha.js +7 -5
- package/lib/cjs/components/recaptcha/editForm/ReCaptcha.edit.display.js +24 -24
- package/lib/cjs/components/select/Select.form.js +3 -3
- package/lib/cjs/components/select/Select.js +235 -129
- package/lib/cjs/components/select/editForm/Select.edit.data.d.ts +1 -1
- package/lib/cjs/components/select/editForm/Select.edit.data.js +191 -57
- package/lib/cjs/components/select/editForm/Select.edit.display.js +2 -2
- package/lib/cjs/components/select/editForm/Select.edit.validation.js +4 -4
- package/lib/cjs/components/selectboxes/SelectBoxes.form.js +3 -3
- package/lib/cjs/components/selectboxes/SelectBoxes.js +31 -15
- package/lib/cjs/components/selectboxes/editForm/SelectBoxes.edit.validation.js +5 -5
- package/lib/cjs/components/signature/Signature.form.js +3 -3
- package/lib/cjs/components/signature/Signature.js +25 -15
- package/lib/cjs/components/signature/editForm/Signature.edit.display.js +19 -10
- package/lib/cjs/components/survey/Survey.form.js +3 -3
- package/lib/cjs/components/survey/Survey.js +30 -17
- package/lib/cjs/components/survey/editForm/Survey.edit.data.js +23 -11
- package/lib/cjs/components/survey/editForm/Survey.edit.display.js +1 -1
- package/lib/cjs/components/survey/editForm/Survey.edit.validation.js +1 -1
- package/lib/cjs/components/table/Table.form.js +1 -1
- package/lib/cjs/components/table/Table.js +7 -5
- package/lib/cjs/components/table/editForm/Table.edit.display.js +22 -22
- package/lib/cjs/components/tabs/Tabs.form.js +1 -1
- package/lib/cjs/components/tabs/Tabs.js +26 -8
- package/lib/cjs/components/tabs/editForm/Tabs.edit.display.js +21 -17
- package/lib/cjs/components/tags/Tags.form.js +1 -1
- package/lib/cjs/components/tags/Tags.js +28 -12
- package/lib/cjs/components/tags/editForm/Tags.edit.data.js +7 -7
- package/lib/cjs/components/textarea/TextArea.form.js +2 -2
- package/lib/cjs/components/textarea/TextArea.js +63 -45
- package/lib/cjs/components/textarea/editForm/TextArea.edit.display.js +96 -72
- package/lib/cjs/components/textarea/editForm/TextArea.edit.validation.js +3 -3
- package/lib/cjs/components/textfield/TextField.form.js +3 -3
- package/lib/cjs/components/textfield/TextField.js +32 -21
- package/lib/cjs/components/textfield/editForm/TextField.edit.data.js +15 -13
- package/lib/cjs/components/textfield/editForm/TextField.edit.display.js +31 -21
- package/lib/cjs/components/textfield/editForm/TextField.edit.validation.js +6 -6
- package/lib/cjs/components/time/Time.js +17 -10
- package/lib/cjs/components/time/editForm/Time.edit.display.js +2 -2
- package/lib/cjs/components/unknown/Unknown.form.js +5 -5
- package/lib/cjs/components/unknown/Unknown.js +2 -2
- package/lib/cjs/components/unknown/editForm/Unknown.edit.display.js +3 -3
- package/lib/cjs/components/url/Url.form.js +3 -3
- package/lib/cjs/components/url/Url.js +2 -2
- package/lib/cjs/components/url/editForm/Url.edit.display.js +3 -3
- package/lib/cjs/components/url/editForm/Url.edit.validation.js +1 -1
- package/lib/cjs/components/well/Well.form.js +1 -1
- package/lib/cjs/components/well/Well.js +2 -2
- package/lib/cjs/components/well/editForm/Well.edit.display.js +10 -10
- package/lib/cjs/formio.form.d.ts +2 -1
- package/lib/cjs/formio.form.js +38 -12
- package/lib/cjs/i18n.d.ts +4 -0
- package/lib/cjs/i18n.js +7 -3
- package/lib/cjs/package.json +1 -1
- package/lib/cjs/providers/address/AddressProvider.js +8 -5
- package/lib/cjs/providers/address/GoogleAddressProvider.d.ts +3 -3
- package/lib/cjs/providers/address/GoogleAddressProvider.js +24 -13
- package/lib/cjs/providers/processor/fileProcessor.js +3 -1
- package/lib/cjs/providers/storage/azure.js +5 -2
- package/lib/cjs/providers/storage/dropbox.js +4 -5
- package/lib/cjs/providers/storage/googleDrive.js +3 -4
- package/lib/cjs/providers/storage/index.js +1 -1
- package/lib/cjs/providers/storage/indexeddb.js +16 -6
- package/lib/cjs/providers/storage/s3.js +17 -6
- package/lib/cjs/providers/storage/uploadAdapter.js +17 -11
- package/lib/cjs/providers/storage/url.js +13 -11
- package/lib/cjs/providers/storage/xhr.js +17 -9
- package/lib/cjs/templates/index.js +1 -1
- package/lib/cjs/translations/de.d.ts +80 -0
- package/lib/cjs/translations/de.js +81 -0
- package/lib/cjs/translations/en.d.ts +0 -2
- package/lib/cjs/translations/en.js +7 -9
- package/lib/cjs/utils/ChoicesWrapper.js +2 -2
- package/lib/cjs/utils/builder.js +31 -7
- package/lib/cjs/utils/calendarUtils.js +7 -5
- package/lib/cjs/utils/conditionOperators/ConditionOperator.js +1 -1
- package/lib/cjs/utils/conditionOperators/DateGreaterThan.js +12 -4
- package/lib/cjs/utils/conditionOperators/IsEmptyValue.js +3 -1
- package/lib/cjs/utils/conditionOperators/IsEqualTo.js +10 -6
- package/lib/cjs/utils/conditionOperators/index.js +1 -1
- package/lib/cjs/utils/formUtils.js +1 -1
- package/lib/cjs/utils/i18n.js +7 -1
- package/lib/cjs/utils/index.d.ts +2 -1
- package/lib/cjs/utils/index.js +2 -2
- package/lib/cjs/utils/utils.d.ts +10 -1
- package/lib/cjs/utils/utils.js +175 -92
- package/lib/cjs/widgets/CalendarWidget.js +66 -49
- package/lib/cjs/widgets/InputWidget.js +6 -4
- package/lib/cjs/widgets/index.js +1 -1
- package/lib/mjs/CDN.js +12 -12
- package/lib/mjs/Element.d.ts +3 -2
- package/lib/mjs/Element.js +27 -21
- package/lib/mjs/Embed.js +76 -42
- package/lib/mjs/EventEmitter.js +1 -1
- package/lib/mjs/Form.d.ts +371 -341
- package/lib/mjs/Form.js +142 -126
- package/lib/mjs/FormBuilder.d.ts +3 -3
- package/lib/mjs/FormBuilder.js +2 -3
- package/lib/mjs/Formio.js +26 -23
- package/lib/mjs/InlineEmbed.js +23 -17
- package/lib/mjs/PDF.d.ts +1 -0
- package/lib/mjs/PDF.js +18 -15
- package/lib/mjs/PDFBuilder.js +51 -36
- package/lib/mjs/Webform.d.ts +8 -366
- package/lib/mjs/Webform.js +183 -250
- package/lib/mjs/WebformBuilder.js +220 -147
- package/lib/mjs/Wizard.js +93 -63
- package/lib/mjs/WizardBuilder.js +27 -19
- package/lib/mjs/addons/FormioAddon.js +1 -1
- package/lib/mjs/addons/PasswordStrength/PasswordStrengthAddon.form.js +59 -57
- package/lib/mjs/addons/PasswordStrength/PasswordStrengthAddon.js +24 -16
- package/lib/mjs/addons/index.js +3 -3
- package/lib/mjs/components/Components.js +0 -4
- package/lib/mjs/components/_classes/component/Component.form.js +11 -11
- package/lib/mjs/components/_classes/component/Component.js +303 -184
- package/lib/mjs/components/_classes/component/editForm/Component.edit.addons.js +2 -4
- package/lib/mjs/components/_classes/component/editForm/Component.edit.api.js +5 -5
- package/lib/mjs/components/_classes/component/editForm/Component.edit.conditional.js +9 -11
- package/lib/mjs/components/_classes/component/editForm/Component.edit.data.d.ts +37 -0
- package/lib/mjs/components/_classes/component/editForm/Component.edit.data.js +39 -25
- package/lib/mjs/components/_classes/component/editForm/Component.edit.display.js +47 -29
- package/lib/mjs/components/_classes/component/editForm/Component.edit.layout.js +9 -9
- package/lib/mjs/components/_classes/component/editForm/Component.edit.logic.js +5 -7
- package/lib/mjs/components/_classes/component/editForm/Component.edit.validation.js +37 -34
- package/lib/mjs/components/_classes/component/editForm/utils.js +12 -16
- package/lib/mjs/components/_classes/componentModal/ComponentModal.js +2 -2
- package/lib/mjs/components/_classes/field/Field.js +8 -2
- package/lib/mjs/components/_classes/input/Input.js +27 -23
- package/lib/mjs/components/_classes/list/ListComponent.form.js +1 -1
- package/lib/mjs/components/_classes/list/ListComponent.js +27 -18
- package/lib/mjs/components/_classes/list/editForm/ListComponent.edit.data.js +36 -9
- package/lib/mjs/components/_classes/multivalue/Multivalue.js +32 -13
- package/lib/mjs/components/_classes/nested/NestedComponent.form.js +3 -3
- package/lib/mjs/components/_classes/nested/NestedComponent.js +32 -28
- package/lib/mjs/components/_classes/nestedarray/NestedArrayComponent.js +20 -15
- package/lib/mjs/components/_classes/nesteddata/NestedDataComponent.js +19 -17
- package/lib/mjs/components/address/Address.js +57 -46
- package/lib/mjs/components/address/editForm/Address.edit.data.js +2 -2
- package/lib/mjs/components/address/editForm/Address.edit.display.js +2 -2
- package/lib/mjs/components/address/editForm/Address.edit.provider.js +53 -11
- package/lib/mjs/components/alert/Alert.js +22 -16
- package/lib/mjs/components/button/Button.form.js +1 -1
- package/lib/mjs/components/button/Button.js +51 -28
- package/lib/mjs/components/button/editForm/Button.edit.display.js +49 -9
- package/lib/mjs/components/checkbox/Checkbox.d.ts +1 -1
- package/lib/mjs/components/checkbox/Checkbox.form.js +3 -3
- package/lib/mjs/components/checkbox/Checkbox.js +29 -21
- package/lib/mjs/components/checkbox/editForm/Checkbox.edit.data.js +1 -1
- package/lib/mjs/components/checkbox/editForm/Checkbox.edit.display.js +13 -3
- package/lib/mjs/components/checkbox/editForm/Checkbox.edit.validation.js +2 -2
- package/lib/mjs/components/columns/Columns.form.js +1 -1
- package/lib/mjs/components/columns/Columns.js +24 -12
- package/lib/mjs/components/columns/editForm/Columns.edit.display.js +17 -17
- package/lib/mjs/components/container/Container.form.js +2 -2
- package/lib/mjs/components/container/Container.js +6 -4
- package/lib/mjs/components/container/editForm/Container.edit.data.js +3 -3
- package/lib/mjs/components/container/editForm/Container.edit.display.js +4 -4
- package/lib/mjs/components/content/Content.form.js +4 -2
- package/lib/mjs/components/content/Content.js +10 -8
- package/lib/mjs/components/content/editForm/Content.edit.display.js +10 -10
- package/lib/mjs/components/currency/Currency.form.js +3 -3
- package/lib/mjs/components/currency/Currency.js +19 -10
- package/lib/mjs/components/currency/editForm/Currency.edit.data.js +5 -5
- package/lib/mjs/components/currency/editForm/Currency.edit.display.js +8 -8
- package/lib/mjs/components/datagrid/DataGrid.form.js +3 -3
- package/lib/mjs/components/datagrid/DataGrid.js +90 -39
- package/lib/mjs/components/datagrid/editForm/DataGrid.edit.data.js +1 -1
- package/lib/mjs/components/datagrid/editForm/DataGrid.edit.display.js +14 -14
- package/lib/mjs/components/datagrid/editForm/DataGrid.edit.validation.js +3 -3
- package/lib/mjs/components/datamap/DataMap.form.js +2 -2
- package/lib/mjs/components/datamap/DataMap.js +44 -31
- package/lib/mjs/components/datamap/editForm/DataMap.edit.data.js +1 -1
- package/lib/mjs/components/datamap/editForm/DataMap.edit.display.js +8 -8
- package/lib/mjs/components/datetime/DateTime.form.js +5 -5
- package/lib/mjs/components/datetime/DateTime.js +31 -16
- package/lib/mjs/components/datetime/editForm/DateTime.edit.data.js +4 -3
- package/lib/mjs/components/datetime/editForm/DateTime.edit.date.js +10 -10
- package/lib/mjs/components/datetime/editForm/DateTime.edit.display.js +22 -17
- package/lib/mjs/components/datetime/editForm/DateTime.edit.time.js +5 -5
- package/lib/mjs/components/datetime/editForm/DateTime.edit.validation.js +3 -3
- package/lib/mjs/components/day/Day.form.js +5 -5
- package/lib/mjs/components/day/Day.js +147 -57
- package/lib/mjs/components/day/editForm/Day.edit.day.js +13 -9
- package/lib/mjs/components/day/editForm/Day.edit.display.js +7 -7
- package/lib/mjs/components/day/editForm/Day.edit.month.js +12 -8
- package/lib/mjs/components/day/editForm/Day.edit.validation.js +7 -7
- package/lib/mjs/components/day/editForm/Day.edit.year.js +8 -8
- package/lib/mjs/components/editgrid/EditGrid.form.js +2 -2
- package/lib/mjs/components/editgrid/EditGrid.js +138 -90
- package/lib/mjs/components/editgrid/editForm/EditGrid.edit.data.js +2 -2
- package/lib/mjs/components/editgrid/editForm/EditGrid.edit.display.js +7 -2
- package/lib/mjs/components/editgrid/editForm/EditGrid.edit.templates.js +16 -16
- package/lib/mjs/components/editgrid/editForm/EditGrid.edit.validation.js +3 -3
- package/lib/mjs/components/email/Email.js +4 -4
- package/lib/mjs/components/email/editForm/Email.edit.display.js +3 -3
- package/lib/mjs/components/email/editForm/Email.edit.validation.js +6 -6
- package/lib/mjs/components/fieldset/Fieldset.form.js +1 -1
- package/lib/mjs/components/fieldset/Fieldset.js +2 -2
- package/lib/mjs/components/fieldset/editForm/Fieldset.edit.display.js +8 -8
- package/lib/mjs/components/file/File.form.js +4 -4
- package/lib/mjs/components/file/File.js +131 -84
- package/lib/mjs/components/file/editForm/File.edit.display.js +9 -5
- package/lib/mjs/components/file/editForm/File.edit.file.d.ts +37 -16
- package/lib/mjs/components/file/editForm/File.edit.file.js +169 -72
- package/lib/mjs/components/file/editForm/File.edit.validation.js +2 -2
- package/lib/mjs/components/form/Form.form.js +3 -3
- package/lib/mjs/components/form/Form.js +67 -51
- package/lib/mjs/components/form/editForm/Form.edit.data.js +1 -3
- package/lib/mjs/components/form/editForm/Form.edit.display.js +6 -7
- package/lib/mjs/components/form/editForm/Form.edit.form.js +10 -8
- package/lib/mjs/components/hidden/Hidden.form.js +4 -4
- package/lib/mjs/components/hidden/Hidden.js +2 -2
- package/lib/mjs/components/hidden/editForm/Hidden.edit.data.js +3 -3
- package/lib/mjs/components/hidden/editForm/Hidden.edit.display.js +10 -10
- package/lib/mjs/components/html/HTML.js +23 -17
- package/lib/mjs/components/html/editForm/HTML.edit.display.js +17 -17
- package/lib/mjs/components/html/editForm/HTML.edit.logic.js +2 -2
- package/lib/mjs/components/number/Number.form.js +3 -3
- package/lib/mjs/components/number/Number.js +28 -12
- package/lib/mjs/components/number/editForm/Number.edit.data.js +3 -3
- package/lib/mjs/components/number/editForm/Number.edit.display.js +4 -4
- package/lib/mjs/components/number/editForm/Number.edit.validation.js +9 -9
- package/lib/mjs/components/panel/Panel.form.js +1 -1
- package/lib/mjs/components/panel/Panel.js +2 -2
- package/lib/mjs/components/panel/editForm/Panel.edit.conditional.js +6 -8
- package/lib/mjs/components/panel/editForm/Panel.edit.display.js +55 -29
- package/lib/mjs/components/password/Password.form.js +3 -3
- package/lib/mjs/components/password/Password.js +5 -2
- package/lib/mjs/components/password/editForm/Password.edit.data.js +11 -11
- package/lib/mjs/components/password/editForm/Password.edit.display.js +3 -3
- package/lib/mjs/components/password/editForm/Password.edit.validation.js +3 -3
- package/lib/mjs/components/phonenumber/PhoneNumber.form.js +8 -8
- package/lib/mjs/components/phonenumber/PhoneNumber.js +3 -3
- package/lib/mjs/components/phonenumber/editForm/PhoneNumber.edit.validation.js +6 -6
- package/lib/mjs/components/radio/Radio.form.js +3 -3
- package/lib/mjs/components/radio/Radio.js +56 -27
- package/lib/mjs/components/radio/editForm/Radio.edit.data.js +23 -9
- package/lib/mjs/components/radio/editForm/Radio.edit.display.js +6 -6
- package/lib/mjs/components/radio/editForm/Radio.edit.validation.js +2 -2
- package/lib/mjs/components/recaptcha/ReCaptcha.form.js +5 -5
- package/lib/mjs/components/recaptcha/ReCaptcha.js +7 -5
- package/lib/mjs/components/recaptcha/editForm/ReCaptcha.edit.display.js +24 -24
- package/lib/mjs/components/select/Select.form.js +3 -3
- package/lib/mjs/components/select/Select.js +240 -134
- package/lib/mjs/components/select/editForm/Select.edit.data.d.ts +1 -1
- package/lib/mjs/components/select/editForm/Select.edit.data.js +191 -57
- package/lib/mjs/components/select/editForm/Select.edit.display.js +2 -2
- package/lib/mjs/components/select/editForm/Select.edit.validation.js +4 -4
- package/lib/mjs/components/selectboxes/SelectBoxes.form.js +3 -3
- package/lib/mjs/components/selectboxes/SelectBoxes.js +32 -16
- package/lib/mjs/components/selectboxes/editForm/SelectBoxes.edit.validation.js +5 -5
- package/lib/mjs/components/signature/Signature.form.js +3 -3
- package/lib/mjs/components/signature/Signature.js +25 -15
- package/lib/mjs/components/signature/editForm/Signature.edit.display.js +19 -10
- package/lib/mjs/components/survey/Survey.form.js +3 -3
- package/lib/mjs/components/survey/Survey.js +30 -17
- package/lib/mjs/components/survey/editForm/Survey.edit.data.js +23 -11
- package/lib/mjs/components/survey/editForm/Survey.edit.display.js +1 -1
- package/lib/mjs/components/survey/editForm/Survey.edit.validation.js +1 -1
- package/lib/mjs/components/table/Table.form.js +1 -1
- package/lib/mjs/components/table/Table.js +7 -5
- package/lib/mjs/components/table/editForm/Table.edit.display.js +22 -22
- package/lib/mjs/components/tabs/Tabs.form.js +1 -1
- package/lib/mjs/components/tabs/Tabs.js +26 -8
- package/lib/mjs/components/tabs/editForm/Tabs.edit.display.js +21 -17
- package/lib/mjs/components/tags/Tags.form.js +1 -1
- package/lib/mjs/components/tags/Tags.js +28 -12
- package/lib/mjs/components/tags/editForm/Tags.edit.data.js +7 -7
- package/lib/mjs/components/textarea/TextArea.form.js +2 -2
- package/lib/mjs/components/textarea/TextArea.js +75 -51
- package/lib/mjs/components/textarea/editForm/TextArea.edit.display.js +96 -72
- package/lib/mjs/components/textarea/editForm/TextArea.edit.validation.js +3 -3
- package/lib/mjs/components/textfield/TextField.form.js +3 -3
- package/lib/mjs/components/textfield/TextField.js +34 -23
- package/lib/mjs/components/textfield/editForm/TextField.edit.data.js +15 -13
- package/lib/mjs/components/textfield/editForm/TextField.edit.display.js +31 -21
- package/lib/mjs/components/textfield/editForm/TextField.edit.validation.js +6 -6
- package/lib/mjs/components/time/Time.js +17 -10
- package/lib/mjs/components/time/editForm/Time.edit.display.js +2 -2
- package/lib/mjs/components/unknown/Unknown.form.js +5 -5
- package/lib/mjs/components/unknown/Unknown.js +2 -2
- package/lib/mjs/components/unknown/editForm/Unknown.edit.display.js +3 -3
- package/lib/mjs/components/url/Url.form.js +3 -3
- package/lib/mjs/components/url/Url.js +2 -2
- package/lib/mjs/components/url/editForm/Url.edit.display.js +3 -3
- package/lib/mjs/components/url/editForm/Url.edit.validation.js +1 -1
- package/lib/mjs/components/well/Well.form.js +1 -1
- package/lib/mjs/components/well/Well.js +2 -2
- package/lib/mjs/components/well/editForm/Well.edit.display.js +10 -10
- package/lib/mjs/formio.form.d.ts +2 -1
- package/lib/mjs/formio.form.js +10 -8
- package/lib/mjs/i18n.d.ts +4 -0
- package/lib/mjs/i18n.js +7 -3
- package/lib/mjs/package.json +1 -1
- package/lib/mjs/providers/address/AddressProvider.js +8 -5
- package/lib/mjs/providers/address/GoogleAddressProvider.d.ts +3 -3
- package/lib/mjs/providers/address/GoogleAddressProvider.js +24 -13
- package/lib/mjs/providers/processor/fileProcessor.js +3 -1
- package/lib/mjs/providers/storage/azure.js +5 -2
- package/lib/mjs/providers/storage/dropbox.js +4 -5
- package/lib/mjs/providers/storage/googleDrive.js +3 -4
- package/lib/mjs/providers/storage/index.js +1 -1
- package/lib/mjs/providers/storage/indexeddb.js +16 -6
- package/lib/mjs/providers/storage/s3.js +19 -8
- package/lib/mjs/providers/storage/uploadAdapter.js +17 -11
- package/lib/mjs/providers/storage/url.js +13 -11
- package/lib/mjs/providers/storage/xhr.js +17 -9
- package/lib/mjs/templates/index.js +1 -1
- package/lib/mjs/translations/de.d.ts +80 -0
- package/lib/mjs/translations/de.js +79 -0
- package/lib/mjs/translations/en.d.ts +0 -2
- package/lib/mjs/translations/en.js +7 -9
- package/lib/mjs/utils/ChoicesWrapper.js +2 -2
- package/lib/mjs/utils/builder.js +31 -7
- package/lib/mjs/utils/calendarUtils.js +7 -5
- package/lib/mjs/utils/conditionOperators/ConditionOperator.js +1 -1
- package/lib/mjs/utils/conditionOperators/DateGreaterThan.js +16 -5
- package/lib/mjs/utils/conditionOperators/IsEmptyValue.js +3 -1
- package/lib/mjs/utils/conditionOperators/IsEqualTo.js +10 -6
- package/lib/mjs/utils/conditionOperators/index.js +1 -1
- package/lib/mjs/utils/formUtils.js +2 -2
- package/lib/mjs/utils/i18n.js +7 -1
- package/lib/mjs/utils/index.d.ts +2 -1
- package/lib/mjs/utils/index.js +3 -3
- package/lib/mjs/utils/utils.d.ts +10 -1
- package/lib/mjs/utils/utils.js +178 -91
- package/lib/mjs/widgets/CalendarWidget.js +67 -50
- package/lib/mjs/widgets/InputWidget.js +6 -4
- package/lib/mjs/widgets/index.js +1 -1
- package/package.json +3 -3
- package/lib/cjs/pdf.image.d.ts +0 -2
- package/lib/cjs/pdf.image.js +0 -94
- package/lib/cjs/utils/jsonlogic/operators.d.ts +0 -1
- package/lib/cjs/utils/jsonlogic/operators.js +0 -265
- package/lib/mjs/pdf.image.d.ts +0 -2
- package/lib/mjs/pdf.image.js +0 -94
- package/lib/mjs/utils/jsonlogic/operators.d.ts +0 -1
- package/lib/mjs/utils/jsonlogic/operators.js +0 -262
|
@@ -5,7 +5,7 @@ export default [
|
|
|
5
5
|
key: 'validate.minSelectedCount',
|
|
6
6
|
label: 'Minimum checked number',
|
|
7
7
|
tooltip: 'Minimum checkboxes required before form can be submitted.',
|
|
8
|
-
weight: 250
|
|
8
|
+
weight: 250,
|
|
9
9
|
},
|
|
10
10
|
{
|
|
11
11
|
type: 'number',
|
|
@@ -13,7 +13,7 @@ export default [
|
|
|
13
13
|
key: 'validate.maxSelectedCount',
|
|
14
14
|
label: 'Maximum checked number',
|
|
15
15
|
tooltip: 'Maximum checkboxes possible before form can be submitted.',
|
|
16
|
-
weight: 250
|
|
16
|
+
weight: 250,
|
|
17
17
|
},
|
|
18
18
|
{
|
|
19
19
|
type: 'textfield',
|
|
@@ -21,7 +21,7 @@ export default [
|
|
|
21
21
|
key: 'minSelectedCountMessage',
|
|
22
22
|
label: 'Minimum checked error message',
|
|
23
23
|
tooltip: 'Error message displayed if minimum number of items not checked.',
|
|
24
|
-
weight: 250
|
|
24
|
+
weight: 250,
|
|
25
25
|
},
|
|
26
26
|
{
|
|
27
27
|
type: 'textfield',
|
|
@@ -29,6 +29,6 @@ export default [
|
|
|
29
29
|
key: 'maxSelectedCountMessage',
|
|
30
30
|
label: 'Maximum checked error message',
|
|
31
31
|
tooltip: 'Error message displayed if maximum number of items checked.',
|
|
32
|
-
weight: 250
|
|
33
|
-
}
|
|
32
|
+
weight: 250,
|
|
33
|
+
},
|
|
34
34
|
];
|
|
@@ -11,15 +11,15 @@ export default function (...extend) {
|
|
|
11
11
|
return Components.baseEditForm([
|
|
12
12
|
{
|
|
13
13
|
key: 'display',
|
|
14
|
-
components: SignatureEditDisplay
|
|
14
|
+
components: SignatureEditDisplay,
|
|
15
15
|
},
|
|
16
16
|
{
|
|
17
17
|
key: 'data',
|
|
18
|
-
components: SignatureEditData
|
|
18
|
+
components: SignatureEditData,
|
|
19
19
|
},
|
|
20
20
|
{
|
|
21
21
|
key: 'validation',
|
|
22
|
-
components: SignatureEditValidation
|
|
22
|
+
components: SignatureEditValidation,
|
|
23
23
|
},
|
|
24
24
|
], ...extend);
|
|
25
25
|
}
|
|
@@ -25,7 +25,7 @@ export default class SignatureComponent extends Input {
|
|
|
25
25
|
icon: 'pencil',
|
|
26
26
|
weight: 120,
|
|
27
27
|
documentation: '/developers/integrations/esign/esign-integrations#signature-component',
|
|
28
|
-
schema: SignatureComponent.schema()
|
|
28
|
+
schema: SignatureComponent.schema(),
|
|
29
29
|
};
|
|
30
30
|
}
|
|
31
31
|
static get serverConditionSettings() {
|
|
@@ -34,12 +34,17 @@ export default class SignatureComponent extends Input {
|
|
|
34
34
|
static get conditionOperatorsSettings() {
|
|
35
35
|
return {
|
|
36
36
|
...super.conditionOperatorsSettings,
|
|
37
|
-
operators: [
|
|
37
|
+
operators: [
|
|
38
|
+
'isEmpty',
|
|
39
|
+
'isNotEmpty',
|
|
40
|
+
],
|
|
38
41
|
};
|
|
39
42
|
}
|
|
40
43
|
static savedValueTypes(schema) {
|
|
41
44
|
schema = schema || {};
|
|
42
|
-
return getComponentSavedTypes(schema) || [
|
|
45
|
+
return (getComponentSavedTypes(schema) || [
|
|
46
|
+
componentValueTypes.string,
|
|
47
|
+
]);
|
|
43
48
|
}
|
|
44
49
|
init() {
|
|
45
50
|
super.init();
|
|
@@ -51,10 +56,10 @@ export default class SignatureComponent extends Input {
|
|
|
51
56
|
if (!this.component.height) {
|
|
52
57
|
this.component.height = '200px';
|
|
53
58
|
}
|
|
54
|
-
if (this.component.keepOverlayRatio
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
59
|
+
if (this.component.keepOverlayRatio &&
|
|
60
|
+
this.options?.display === 'pdf' &&
|
|
61
|
+
this.component.overlay?.width &&
|
|
62
|
+
this.component.overlay?.height) {
|
|
58
63
|
this.ratio = this.component.overlay?.width / this.component.overlay?.height;
|
|
59
64
|
this.component.width = '100%';
|
|
60
65
|
this.component.height = 'auto';
|
|
@@ -137,7 +142,8 @@ export default class SignatureComponent extends Input {
|
|
|
137
142
|
}
|
|
138
143
|
}
|
|
139
144
|
checkSize(force, scale) {
|
|
140
|
-
if (this.refs.padBody &&
|
|
145
|
+
if (this.refs.padBody &&
|
|
146
|
+
(force || (this.refs.padBody && this.refs.padBody.offsetWidth !== this.currentWidth))) {
|
|
141
147
|
this.scale = force ? scale : this.scale;
|
|
142
148
|
this.currentWidth = this.refs.padBody.offsetWidth;
|
|
143
149
|
const width = this.currentWidth * this.scale;
|
|
@@ -149,7 +155,7 @@ export default class SignatureComponent extends Input {
|
|
|
149
155
|
this.refs.canvas.style.maxHeight = `${maxHeight}px`;
|
|
150
156
|
const ctx = this.refs.canvas.getContext('2d');
|
|
151
157
|
ctx.setTransform(1, 0, 0, 1, 0, 0);
|
|
152
|
-
ctx.scale(
|
|
158
|
+
ctx.scale(1 / this.scale, 1 / this.scale);
|
|
153
159
|
ctx.fillStyle = this.signaturePad.backgroundColor;
|
|
154
160
|
ctx.fillRect(0, 0, this.refs.canvas.width, this.refs.canvas.height);
|
|
155
161
|
this.signaturePad.clear();
|
|
@@ -172,13 +178,18 @@ export default class SignatureComponent extends Input {
|
|
|
172
178
|
}
|
|
173
179
|
getModalPreviewTemplate() {
|
|
174
180
|
return this.renderModalPreview({
|
|
175
|
-
previewText: this.dataValue
|
|
176
|
-
`<img src=${this.dataValue} ${this._referenceAttributeName}='openModal' style="width: 100%;height: 100%;" />`
|
|
177
|
-
this.t('Click to Sign')
|
|
181
|
+
previewText: this.dataValue
|
|
182
|
+
? `<img src=${this.dataValue} ${this._referenceAttributeName}='openModal' style="width: 100%;height: 100%;" />`
|
|
183
|
+
: this.t('Click to Sign'),
|
|
178
184
|
});
|
|
179
185
|
}
|
|
180
186
|
attach(element) {
|
|
181
|
-
this.loadRefs(element, {
|
|
187
|
+
this.loadRefs(element, {
|
|
188
|
+
canvas: 'single',
|
|
189
|
+
refresh: 'single',
|
|
190
|
+
padBody: 'single',
|
|
191
|
+
signatureImage: 'single',
|
|
192
|
+
});
|
|
182
193
|
const superAttach = super.attach(element);
|
|
183
194
|
if (this.refs.refresh && this.options.readOnly) {
|
|
184
195
|
this.refs.refresh.classList.add('disabled');
|
|
@@ -189,7 +200,7 @@ export default class SignatureComponent extends Input {
|
|
|
189
200
|
minWidth: this.component.minWidth,
|
|
190
201
|
maxWidth: this.component.maxWidth,
|
|
191
202
|
penColor: this.component.penColor,
|
|
192
|
-
backgroundColor: this.component.backgroundColor
|
|
203
|
+
backgroundColor: this.component.backgroundColor,
|
|
193
204
|
});
|
|
194
205
|
this.signaturePad.addEventListener('endStroke', () => this.setValue(this.signaturePad.toDataURL()));
|
|
195
206
|
this.refs.signatureImage.setAttribute('src', this.signaturePad.toDataURL());
|
|
@@ -225,7 +236,6 @@ export default class SignatureComponent extends Input {
|
|
|
225
236
|
this.setValue(this.dataValue);
|
|
226
237
|
return superAttach;
|
|
227
238
|
}
|
|
228
|
-
/* eslint-enable max-statements */
|
|
229
239
|
detach() {
|
|
230
240
|
if (this.observer) {
|
|
231
241
|
this.observer.disconnect();
|
|
@@ -6,7 +6,7 @@ export default [
|
|
|
6
6
|
label: 'Footer Label',
|
|
7
7
|
tooltip: 'The footer text that appears below the signature area.',
|
|
8
8
|
placeholder: 'Footer Label',
|
|
9
|
-
weight: 10
|
|
9
|
+
weight: 10,
|
|
10
10
|
},
|
|
11
11
|
{
|
|
12
12
|
type: 'textfield',
|
|
@@ -16,9 +16,13 @@ export default [
|
|
|
16
16
|
tooltip: 'The width of the signature area.',
|
|
17
17
|
placeholder: 'Width',
|
|
18
18
|
conditional: {
|
|
19
|
-
json: {
|
|
19
|
+
json: {
|
|
20
|
+
'!': [
|
|
21
|
+
{ var: 'data.keepOverlayRatio' },
|
|
22
|
+
],
|
|
23
|
+
},
|
|
20
24
|
},
|
|
21
|
-
weight: 50
|
|
25
|
+
weight: 50,
|
|
22
26
|
},
|
|
23
27
|
{
|
|
24
28
|
type: 'textfield',
|
|
@@ -26,10 +30,15 @@ export default [
|
|
|
26
30
|
key: 'height',
|
|
27
31
|
label: 'Height',
|
|
28
32
|
tooltip: 'The height of the signature area.',
|
|
29
|
-
placeholder: 'Height',
|
|
30
|
-
|
|
33
|
+
placeholder: 'Height',
|
|
34
|
+
conditional: {
|
|
35
|
+
json: {
|
|
36
|
+
'!': [
|
|
37
|
+
{ var: 'data.keepOverlayRatio' },
|
|
38
|
+
],
|
|
39
|
+
},
|
|
31
40
|
},
|
|
32
|
-
weight: 51
|
|
41
|
+
weight: 51,
|
|
33
42
|
},
|
|
34
43
|
{
|
|
35
44
|
weight: 52,
|
|
@@ -37,8 +46,8 @@ export default [
|
|
|
37
46
|
label: 'Keep Overlay Aspect Ratio',
|
|
38
47
|
tooltip: 'If checked, the field will have the same aspect ratio as its preview.',
|
|
39
48
|
key: 'keepOverlayRatio',
|
|
40
|
-
customConditional: ({ options }) =>
|
|
41
|
-
input: true
|
|
49
|
+
customConditional: ({ options }) => options?.editForm?.display === 'pdf',
|
|
50
|
+
input: true,
|
|
42
51
|
},
|
|
43
52
|
{
|
|
44
53
|
type: 'textfield',
|
|
@@ -47,7 +56,7 @@ export default [
|
|
|
47
56
|
label: 'Background Color',
|
|
48
57
|
tooltip: 'The background color of the signature area.',
|
|
49
58
|
placeholder: 'Background Color',
|
|
50
|
-
weight: 52
|
|
59
|
+
weight: 52,
|
|
51
60
|
},
|
|
52
61
|
{
|
|
53
62
|
type: 'textfield',
|
|
@@ -56,7 +65,7 @@ export default [
|
|
|
56
65
|
label: 'Pen Color',
|
|
57
66
|
tooltip: 'The ink color for the signature area.',
|
|
58
67
|
placeholder: 'Pen Color',
|
|
59
|
-
weight: 53
|
|
68
|
+
weight: 53,
|
|
60
69
|
},
|
|
61
70
|
{
|
|
62
71
|
key: 'placeholder',
|
|
@@ -11,15 +11,15 @@ export default function (...extend) {
|
|
|
11
11
|
return Components.baseEditForm([
|
|
12
12
|
{
|
|
13
13
|
key: 'display',
|
|
14
|
-
components: SurveyEditDisplay
|
|
14
|
+
components: SurveyEditDisplay,
|
|
15
15
|
},
|
|
16
16
|
{
|
|
17
17
|
key: 'data',
|
|
18
|
-
components: SurveyEditData
|
|
18
|
+
components: SurveyEditData,
|
|
19
19
|
},
|
|
20
20
|
{
|
|
21
21
|
key: 'validation',
|
|
22
|
-
components: SurveyEditValidation
|
|
22
|
+
components: SurveyEditValidation,
|
|
23
23
|
},
|
|
24
24
|
], ...extend);
|
|
25
25
|
}
|
|
@@ -8,7 +8,7 @@ export default class SurveyComponent extends Field {
|
|
|
8
8
|
label: 'Survey',
|
|
9
9
|
key: 'survey',
|
|
10
10
|
questions: [],
|
|
11
|
-
values: []
|
|
11
|
+
values: [],
|
|
12
12
|
}, ...extend);
|
|
13
13
|
}
|
|
14
14
|
static get builderInfo() {
|
|
@@ -18,7 +18,7 @@ export default class SurveyComponent extends Field {
|
|
|
18
18
|
icon: 'list',
|
|
19
19
|
weight: 110,
|
|
20
20
|
documentation: '/userguide/form-building/advanced-components#survey',
|
|
21
|
-
schema: SurveyComponent.schema()
|
|
21
|
+
schema: SurveyComponent.schema(),
|
|
22
22
|
};
|
|
23
23
|
}
|
|
24
24
|
static get serverConditionSettings() {
|
|
@@ -27,11 +27,16 @@ export default class SurveyComponent extends Field {
|
|
|
27
27
|
static get conditionOperatorsSettings() {
|
|
28
28
|
return {
|
|
29
29
|
...super.conditionOperatorsSettings,
|
|
30
|
-
operators: [
|
|
30
|
+
operators: [
|
|
31
|
+
'isEmpty',
|
|
32
|
+
'isNotEmpty',
|
|
33
|
+
],
|
|
31
34
|
};
|
|
32
35
|
}
|
|
33
36
|
static savedValueTypes(schema) {
|
|
34
|
-
return getComponentSavedTypes(schema) || [
|
|
37
|
+
return (getComponentSavedTypes(schema) || [
|
|
38
|
+
componentValueTypes.object,
|
|
39
|
+
]);
|
|
35
40
|
}
|
|
36
41
|
get defaultSchema() {
|
|
37
42
|
return SurveyComponent.schema();
|
|
@@ -48,7 +53,7 @@ export default class SurveyComponent extends Field {
|
|
|
48
53
|
}
|
|
49
54
|
else {
|
|
50
55
|
this.addEventListener(input, 'change', () => this.updateValue(null, {
|
|
51
|
-
modified: true
|
|
56
|
+
modified: true,
|
|
52
57
|
}));
|
|
53
58
|
}
|
|
54
59
|
});
|
|
@@ -62,7 +67,7 @@ export default class SurveyComponent extends Field {
|
|
|
62
67
|
_.each(this.component.questions, (question) => {
|
|
63
68
|
_.each(this.refs.input, (input) => {
|
|
64
69
|
if (input.name === this.getInputName(question)) {
|
|
65
|
-
input.checked =
|
|
70
|
+
input.checked = input.value === value[question.value];
|
|
66
71
|
}
|
|
67
72
|
});
|
|
68
73
|
});
|
|
@@ -78,9 +83,11 @@ export default class SurveyComponent extends Field {
|
|
|
78
83
|
get defaultValue() {
|
|
79
84
|
const defaultValue = super.defaultValue;
|
|
80
85
|
//support for default values created in old formio.js versions
|
|
81
|
-
if (defaultValue &&
|
|
86
|
+
if (defaultValue &&
|
|
87
|
+
!_.isObject(defaultValue) &&
|
|
88
|
+
this.component.values.some((value) => value.value === defaultValue)) {
|
|
82
89
|
const adoptedDefaultValue = {};
|
|
83
|
-
this.component.questions.forEach(question => {
|
|
90
|
+
this.component.questions.forEach((question) => {
|
|
84
91
|
adoptedDefaultValue[question.value] = defaultValue;
|
|
85
92
|
});
|
|
86
93
|
return adoptedDefaultValue;
|
|
@@ -94,7 +101,7 @@ export default class SurveyComponent extends Field {
|
|
|
94
101
|
const value = {};
|
|
95
102
|
_.each(this.component.questions, (question) => {
|
|
96
103
|
_.each(this.refs.input, (input) => {
|
|
97
|
-
if (input.checked &&
|
|
104
|
+
if (input.checked && input.name === this.getInputName(question)) {
|
|
98
105
|
value[question.value] = input.value;
|
|
99
106
|
return false;
|
|
100
107
|
}
|
|
@@ -122,7 +129,7 @@ export default class SurveyComponent extends Field {
|
|
|
122
129
|
}
|
|
123
130
|
getValueAsString(value, options) {
|
|
124
131
|
if (options?.email) {
|
|
125
|
-
let result =
|
|
132
|
+
let result = `
|
|
126
133
|
<table border="1" style="width:100%">
|
|
127
134
|
<thead>
|
|
128
135
|
<tr>
|
|
@@ -131,19 +138,25 @@ export default class SurveyComponent extends Field {
|
|
|
131
138
|
</tr>
|
|
132
139
|
</thead>
|
|
133
140
|
<tbody>
|
|
134
|
-
|
|
141
|
+
`;
|
|
135
142
|
_.forIn(value, (value, key) => {
|
|
136
|
-
const question = _.find(this.component.questions, [
|
|
137
|
-
|
|
143
|
+
const question = _.find(this.component.questions, [
|
|
144
|
+
'value',
|
|
145
|
+
key,
|
|
146
|
+
]);
|
|
147
|
+
const answer = _.find(this.component.values, [
|
|
148
|
+
'value',
|
|
149
|
+
value,
|
|
150
|
+
]);
|
|
138
151
|
if (!question || !answer) {
|
|
139
152
|
return;
|
|
140
153
|
}
|
|
141
|
-
result +=
|
|
154
|
+
result += `
|
|
142
155
|
<tr>
|
|
143
156
|
<td style="text-align:center;padding: 5px 10px;">${question.label}</td>
|
|
144
157
|
<td style="text-align:center;padding: 5px 10px;">${answer.label}</td>
|
|
145
158
|
</tr>
|
|
146
|
-
|
|
159
|
+
`;
|
|
147
160
|
});
|
|
148
161
|
result += '</tbody></table>';
|
|
149
162
|
return result;
|
|
@@ -153,8 +166,8 @@ export default class SurveyComponent extends Field {
|
|
|
153
166
|
return _.isEmpty(value)
|
|
154
167
|
? ''
|
|
155
168
|
: _.map(value, (v, q) => {
|
|
156
|
-
const valueLabel = _.get(_.find(values, val => _.isEqual(val.value, v)), 'label', v);
|
|
157
|
-
const questionLabel = _.get(_.find(questions, quest => _.isEqual(quest.value, q)), 'label', q);
|
|
169
|
+
const valueLabel = _.get(_.find(values, (val) => _.isEqual(val.value, v)), 'label', v);
|
|
170
|
+
const questionLabel = _.get(_.find(questions, (quest) => _.isEqual(quest.value, q)), 'label', q);
|
|
158
171
|
return `${questionLabel}: ${valueLabel}`;
|
|
159
172
|
}).join('; ');
|
|
160
173
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export default [
|
|
2
2
|
{
|
|
3
3
|
key: 'multiple',
|
|
4
|
-
ignore: true
|
|
4
|
+
ignore: true,
|
|
5
5
|
},
|
|
6
6
|
{
|
|
7
7
|
type: 'datagrid',
|
|
@@ -11,13 +11,15 @@ export default [
|
|
|
11
11
|
tooltip: 'The questions you would like to ask in this survey question.',
|
|
12
12
|
weight: 0,
|
|
13
13
|
reorder: true,
|
|
14
|
-
defaultValue: [
|
|
14
|
+
defaultValue: [
|
|
15
|
+
{ label: '', value: '' },
|
|
16
|
+
],
|
|
15
17
|
components: [
|
|
16
18
|
{
|
|
17
19
|
label: 'Label',
|
|
18
20
|
key: 'label',
|
|
19
21
|
input: true,
|
|
20
|
-
type: 'textfield'
|
|
22
|
+
type: 'textfield',
|
|
21
23
|
},
|
|
22
24
|
{
|
|
23
25
|
label: 'Value',
|
|
@@ -25,7 +27,11 @@ export default [
|
|
|
25
27
|
input: true,
|
|
26
28
|
type: 'textfield',
|
|
27
29
|
allowCalculateOverride: true,
|
|
28
|
-
calculateValue: {
|
|
30
|
+
calculateValue: {
|
|
31
|
+
_camelCase: [
|
|
32
|
+
{ var: 'row.label' },
|
|
33
|
+
],
|
|
34
|
+
},
|
|
29
35
|
},
|
|
30
36
|
{
|
|
31
37
|
label: 'Tooltip',
|
|
@@ -33,23 +39,25 @@ export default [
|
|
|
33
39
|
input: true,
|
|
34
40
|
type: 'textfield',
|
|
35
41
|
},
|
|
36
|
-
]
|
|
42
|
+
],
|
|
37
43
|
},
|
|
38
44
|
{
|
|
39
45
|
type: 'datagrid',
|
|
40
46
|
input: true,
|
|
41
47
|
label: 'Values',
|
|
42
48
|
key: 'values',
|
|
43
|
-
tooltip:
|
|
49
|
+
tooltip: "The values that can be selected per question. Example: 'Satisfied', 'Very Satisfied', etc.",
|
|
44
50
|
weight: 1,
|
|
45
51
|
reorder: true,
|
|
46
|
-
defaultValue: [
|
|
52
|
+
defaultValue: [
|
|
53
|
+
{ label: '', value: '' },
|
|
54
|
+
],
|
|
47
55
|
components: [
|
|
48
56
|
{
|
|
49
57
|
label: 'Label',
|
|
50
58
|
key: 'label',
|
|
51
59
|
input: true,
|
|
52
|
-
type: 'textfield'
|
|
60
|
+
type: 'textfield',
|
|
53
61
|
},
|
|
54
62
|
{
|
|
55
63
|
label: 'Value',
|
|
@@ -57,7 +65,11 @@ export default [
|
|
|
57
65
|
input: true,
|
|
58
66
|
type: 'textfield',
|
|
59
67
|
allowCalculateOverride: true,
|
|
60
|
-
calculateValue: {
|
|
68
|
+
calculateValue: {
|
|
69
|
+
_camelCase: [
|
|
70
|
+
{ var: 'row.label' },
|
|
71
|
+
],
|
|
72
|
+
},
|
|
61
73
|
},
|
|
62
74
|
{
|
|
63
75
|
label: 'Tooltip',
|
|
@@ -65,6 +77,6 @@ export default [
|
|
|
65
77
|
input: true,
|
|
66
78
|
type: 'textfield',
|
|
67
79
|
},
|
|
68
|
-
]
|
|
69
|
-
}
|
|
80
|
+
],
|
|
81
|
+
},
|
|
70
82
|
];
|
|
@@ -29,7 +29,7 @@ export default class TableComponent extends NestedComponent {
|
|
|
29
29
|
bordered: false,
|
|
30
30
|
hover: false,
|
|
31
31
|
condensed: false,
|
|
32
|
-
persistent: false
|
|
32
|
+
persistent: false,
|
|
33
33
|
}, ...extend);
|
|
34
34
|
}
|
|
35
35
|
static get builderInfo() {
|
|
@@ -40,7 +40,7 @@ export default class TableComponent extends NestedComponent {
|
|
|
40
40
|
weight: 40,
|
|
41
41
|
documentation: '/userguide/form-building/layout-components#table',
|
|
42
42
|
showPreview: false,
|
|
43
|
-
schema: TableComponent.schema()
|
|
43
|
+
schema: TableComponent.schema(),
|
|
44
44
|
};
|
|
45
45
|
}
|
|
46
46
|
static savedValueTypes() {
|
|
@@ -103,7 +103,9 @@ export default class TableComponent extends NestedComponent {
|
|
|
103
103
|
for (let rowIndex = 0; rowIndex < this.component.numRows; rowIndex++) {
|
|
104
104
|
this.component.rows[rowIndex] = this.component.rows[rowIndex] || [];
|
|
105
105
|
for (let colIndex = 0; colIndex < this.component.numCols; colIndex++) {
|
|
106
|
-
this.component.rows[rowIndex][colIndex] = this.component.rows[rowIndex][colIndex] || {
|
|
106
|
+
this.component.rows[rowIndex][colIndex] = this.component.rows[rowIndex][colIndex] || {
|
|
107
|
+
components: [],
|
|
108
|
+
};
|
|
107
109
|
}
|
|
108
110
|
this.component.rows[rowIndex] = this.component.rows[rowIndex].slice(0, this.component.numCols);
|
|
109
111
|
}
|
|
@@ -130,7 +132,7 @@ export default class TableComponent extends NestedComponent {
|
|
|
130
132
|
columnComponent = comp;
|
|
131
133
|
}
|
|
132
134
|
else {
|
|
133
|
-
columnComponent = { ...comp, id:
|
|
135
|
+
columnComponent = { ...comp, id: comp.id + rowIndex };
|
|
134
136
|
}
|
|
135
137
|
const component = this.createComponent(columnComponent);
|
|
136
138
|
component.tableRow = rowIndex;
|
|
@@ -145,7 +147,7 @@ export default class TableComponent extends NestedComponent {
|
|
|
145
147
|
cellClassName: this.cellClassName,
|
|
146
148
|
tableKey: this.tableKey,
|
|
147
149
|
colWidth: this.colWidth,
|
|
148
|
-
tableComponents: this.table.map(row => row.map(column => this.renderComponents(column)))
|
|
150
|
+
tableComponents: this.table.map((row) => row.map((column) => this.renderComponents(column))),
|
|
149
151
|
}));
|
|
150
152
|
}
|
|
151
153
|
attach(element) {
|
|
@@ -1,39 +1,39 @@
|
|
|
1
1
|
export default [
|
|
2
2
|
{
|
|
3
3
|
key: 'labelPosition',
|
|
4
|
-
ignore: true
|
|
4
|
+
ignore: true,
|
|
5
5
|
},
|
|
6
6
|
{
|
|
7
7
|
key: 'placeholder',
|
|
8
|
-
ignore: true
|
|
8
|
+
ignore: true,
|
|
9
9
|
},
|
|
10
10
|
{
|
|
11
11
|
key: 'description',
|
|
12
|
-
ignore: true
|
|
12
|
+
ignore: true,
|
|
13
13
|
},
|
|
14
14
|
{
|
|
15
15
|
key: 'autofocus',
|
|
16
|
-
ignore: true
|
|
16
|
+
ignore: true,
|
|
17
17
|
},
|
|
18
18
|
{
|
|
19
19
|
key: 'tooltip',
|
|
20
|
-
ignore: true
|
|
20
|
+
ignore: true,
|
|
21
21
|
},
|
|
22
22
|
{
|
|
23
23
|
key: 'tabindex',
|
|
24
|
-
ignore: true
|
|
24
|
+
ignore: true,
|
|
25
25
|
},
|
|
26
26
|
{
|
|
27
27
|
key: 'disabled',
|
|
28
|
-
ignore: true
|
|
28
|
+
ignore: true,
|
|
29
29
|
},
|
|
30
30
|
{
|
|
31
31
|
key: 'tableView',
|
|
32
|
-
ignore: true
|
|
32
|
+
ignore: true,
|
|
33
33
|
},
|
|
34
34
|
{
|
|
35
35
|
key: 'hideLabel',
|
|
36
|
-
ignore: true
|
|
36
|
+
ignore: true,
|
|
37
37
|
},
|
|
38
38
|
{
|
|
39
39
|
weight: 0,
|
|
@@ -44,10 +44,10 @@ export default [
|
|
|
44
44
|
placeholder: 'Field Label',
|
|
45
45
|
tooltip: 'The label for this field.',
|
|
46
46
|
validate: {
|
|
47
|
-
required: true
|
|
47
|
+
required: true,
|
|
48
48
|
},
|
|
49
49
|
autofocus: true,
|
|
50
|
-
overrideEditForm: true
|
|
50
|
+
overrideEditForm: true,
|
|
51
51
|
},
|
|
52
52
|
{
|
|
53
53
|
type: 'number',
|
|
@@ -56,7 +56,7 @@ export default [
|
|
|
56
56
|
input: true,
|
|
57
57
|
weight: 1,
|
|
58
58
|
placeholder: 'Number of Rows',
|
|
59
|
-
tooltip: 'Enter the number or rows that should be displayed by this table.'
|
|
59
|
+
tooltip: 'Enter the number or rows that should be displayed by this table.',
|
|
60
60
|
},
|
|
61
61
|
{
|
|
62
62
|
type: 'number',
|
|
@@ -65,7 +65,7 @@ export default [
|
|
|
65
65
|
input: true,
|
|
66
66
|
weight: 2,
|
|
67
67
|
placeholder: 'Number of Columns',
|
|
68
|
-
tooltip: 'Enter the number or columns that should be displayed by this table.'
|
|
68
|
+
tooltip: 'Enter the number or columns that should be displayed by this table.',
|
|
69
69
|
},
|
|
70
70
|
{
|
|
71
71
|
type: 'checkbox',
|
|
@@ -73,7 +73,7 @@ export default [
|
|
|
73
73
|
key: 'cloneRows',
|
|
74
74
|
input: true,
|
|
75
75
|
weight: 3,
|
|
76
|
-
tooltip:
|
|
76
|
+
tooltip: "Check this if you would like to 'clone' the first row of components to all additional empty rows of the table.",
|
|
77
77
|
},
|
|
78
78
|
{
|
|
79
79
|
type: 'select',
|
|
@@ -86,11 +86,11 @@ export default [
|
|
|
86
86
|
values: [
|
|
87
87
|
{ label: 'Left', value: 'left' },
|
|
88
88
|
{ label: 'Center', value: 'center' },
|
|
89
|
-
{ label: 'Right', value: 'right' }
|
|
90
|
-
]
|
|
89
|
+
{ label: 'Right', value: 'right' },
|
|
90
|
+
],
|
|
91
91
|
},
|
|
92
92
|
defaultValue: 'left',
|
|
93
|
-
weight: 3
|
|
93
|
+
weight: 3,
|
|
94
94
|
},
|
|
95
95
|
{
|
|
96
96
|
type: 'checkbox',
|
|
@@ -98,7 +98,7 @@ export default [
|
|
|
98
98
|
key: 'striped',
|
|
99
99
|
tooltip: 'This will stripe the table if checked.',
|
|
100
100
|
input: true,
|
|
101
|
-
weight: 701
|
|
101
|
+
weight: 701,
|
|
102
102
|
},
|
|
103
103
|
{
|
|
104
104
|
type: 'checkbox',
|
|
@@ -106,7 +106,7 @@ export default [
|
|
|
106
106
|
key: 'bordered',
|
|
107
107
|
input: true,
|
|
108
108
|
tooltip: 'This will border the table if checked.',
|
|
109
|
-
weight: 702
|
|
109
|
+
weight: 702,
|
|
110
110
|
},
|
|
111
111
|
{
|
|
112
112
|
type: 'checkbox',
|
|
@@ -114,7 +114,7 @@ export default [
|
|
|
114
114
|
key: 'hover',
|
|
115
115
|
input: true,
|
|
116
116
|
tooltip: 'Highlight a row on hover.',
|
|
117
|
-
weight: 703
|
|
117
|
+
weight: 703,
|
|
118
118
|
},
|
|
119
119
|
{
|
|
120
120
|
type: 'checkbox',
|
|
@@ -122,10 +122,10 @@ export default [
|
|
|
122
122
|
key: 'condensed',
|
|
123
123
|
input: true,
|
|
124
124
|
tooltip: 'Condense the size of the table.',
|
|
125
|
-
weight: 704
|
|
125
|
+
weight: 704,
|
|
126
126
|
},
|
|
127
127
|
{
|
|
128
128
|
key: 'hideLabel',
|
|
129
|
-
ignore: true
|
|
129
|
+
ignore: true,
|
|
130
130
|
},
|
|
131
131
|
];
|