@oneblink/apps-react 2.3.0-beta.2 → 2.3.0-beta.3
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/OneBlinkAutoSaveForm.d.ts +10 -10
- package/dist/OneBlinkAutoSaveForm.js +28 -28
- package/dist/OneBlinkForm.d.ts +11 -11
- package/dist/OneBlinkForm.js +11 -11
- package/dist/OneBlinkFormBase.d.ts +29 -28
- package/dist/OneBlinkFormBase.js +476 -472
- package/dist/OneBlinkFormBase.js.map +1 -1
- package/dist/OneBlinkReadOnlyForm.d.ts +11 -11
- package/dist/OneBlinkReadOnlyForm.js +48 -48
- package/dist/components/CopyToClipboardIconButton.d.ts +10 -10
- package/dist/components/CopyToClipboardIconButton.js +32 -32
- package/dist/components/CustomAccordion.d.ts +27 -27
- package/dist/components/CustomAccordion.js +37 -37
- package/dist/components/ErrorSnackbar.d.ts +8 -8
- package/dist/components/ErrorSnackbar.js +25 -25
- package/dist/components/Lists.d.ts +25 -25
- package/dist/components/Lists.js +44 -44
- package/dist/components/LoadingWithMessage.d.ts +6 -6
- package/dist/components/LoadingWithMessage.js +11 -11
- package/dist/components/formStore/FormStoreTableProvider.d.ts +6 -6
- package/dist/components/formStore/FormStoreTableProvider.js +90 -90
- package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.d.ts +5 -5
- package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.js +19 -19
- package/dist/components/formStore/OneBlinkFormStoreColumnsButton.d.ts +5 -5
- package/dist/components/formStore/OneBlinkFormStoreColumnsButton.js +66 -66
- package/dist/components/formStore/OneBlinkFormStoreDownloadButton.d.ts +5 -5
- package/dist/components/formStore/OneBlinkFormStoreDownloadButton.js +86 -86
- package/dist/components/formStore/OneBlinkFormStoreProvider.d.ts +8 -8
- package/dist/components/formStore/OneBlinkFormStoreProvider.js +24 -24
- package/dist/components/formStore/OneBlinkFormStoreRefreshButton.d.ts +5 -5
- package/dist/components/formStore/OneBlinkFormStoreRefreshButton.js +11 -11
- package/dist/components/formStore/OneBlinkFormStoreTable.d.ts +4 -4
- package/dist/components/formStore/OneBlinkFormStoreTable.js +194 -194
- package/dist/components/formStore/display/ElementDisplay.d.ts +23 -23
- package/dist/components/formStore/display/ElementDisplay.js +77 -77
- package/dist/components/formStore/display/FormStoreIcon.d.ts +2 -2
- package/dist/components/formStore/display/FormStoreIcon.js +2 -2
- package/dist/components/formStore/table/ActionedByTableCell.d.ts +11 -11
- package/dist/components/formStore/table/ActionedByTableCell.js +43 -43
- package/dist/components/formStore/table/ColumnFilters.d.ts +9 -9
- package/dist/components/formStore/table/ColumnFilters.js +179 -179
- package/dist/components/formStore/table/FormElementTableCell.d.ts +10 -10
- package/dist/components/formStore/table/FormElementTableCell.js +228 -228
- package/dist/components/formStore/table/HeaderCellMoreButton.d.ts +9 -9
- package/dist/components/formStore/table/HeaderCellMoreButton.js +48 -48
- package/dist/components/formStore/table/RepeatableSetCell.d.ts +8 -8
- package/dist/components/formStore/table/RepeatableSetCell.js +62 -62
- package/dist/components/formStore/table/RepeatableSetCellAccordion.d.ts +9 -9
- package/dist/components/formStore/table/RepeatableSetCellAccordion.js +11 -11
- package/dist/components/formStore/table/TableCellCopyButton.d.ts +7 -7
- package/dist/components/formStore/table/TableCellCopyButton.js +27 -27
- package/dist/components/formStore/table/generateColumns.d.ts +24 -24
- package/dist/components/formStore/table/generateColumns.js +290 -290
- package/dist/components/formStore/table/useFormStoreTable.d.ts +52 -52
- package/dist/components/formStore/table/useFormStoreTable.js +157 -157
- package/dist/components/formStore/useFormStoreTableContext.d.ts +44 -44
- package/dist/components/formStore/useFormStoreTableContext.js +9 -9
- package/dist/components/messages/ErrorMessage.d.ts +12 -12
- package/dist/components/messages/ErrorMessage.js +12 -12
- package/dist/components/messages/LargeIconMessage.d.ts +18 -18
- package/dist/components/messages/LargeIconMessage.js +33 -33
- package/dist/components/messages/NoResourcesYet.d.ts +11 -11
- package/dist/components/messages/NoResourcesYet.js +6 -6
- package/dist/components/pickers/V4CompatibleDatePicker.d.ts +32 -32
- package/dist/components/pickers/V4CompatibleDatePicker.js +70 -70
- package/dist/components/pickers/V4CompatibleDateTimePicker.d.ts +32 -32
- package/dist/components/pickers/V4CompatibleDateTimePicker.js +70 -70
- package/dist/components/pickers/V4CompatibleTimePicker.d.ts +28 -28
- package/dist/components/pickers/V4CompatibleTimePicker.js +53 -53
- package/dist/components/renderer/AnnotationModal.d.ts +8 -8
- package/dist/components/renderer/AnnotationModal.js +101 -101
- package/dist/components/renderer/AutocompleteDropdown.d.ts +26 -26
- package/dist/components/renderer/AutocompleteDropdown.js +175 -175
- package/dist/components/renderer/CopyToClipboardButton.d.ts +8 -8
- package/dist/components/renderer/CopyToClipboardButton.js +13 -13
- package/dist/components/renderer/CustomisableButtonInner.d.ts +7 -7
- package/dist/components/renderer/CustomisableButtonInner.js +8 -8
- package/dist/components/renderer/FormElementLabelContainer.d.ts +12 -12
- package/dist/components/renderer/FormElementLabelContainer.js +15 -15
- package/dist/components/renderer/FormElementOptions.d.ts +9 -9
- package/dist/components/renderer/FormElementOptions.js +14 -14
- package/dist/components/renderer/LookupButton.d.ts +10 -10
- package/dist/components/renderer/LookupButton.js +29 -29
- package/dist/components/renderer/LookupNotification.d.ts +12 -12
- package/dist/components/renderer/LookupNotification.js +230 -230
- package/dist/components/renderer/Modal.d.ts +14 -14
- package/dist/components/renderer/Modal.js +14 -14
- package/dist/components/renderer/OnLoading.d.ts +10 -10
- package/dist/components/renderer/OnLoading.js +11 -11
- package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.d.ts +7 -7
- package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.js +12 -12
- package/dist/components/renderer/OneBlinkFormElements.d.ts +19 -19
- package/dist/components/renderer/OneBlinkFormElements.js +202 -202
- package/dist/components/renderer/PageFormElements.d.ts +17 -17
- package/dist/components/renderer/PageFormElements.js +48 -48
- package/dist/components/renderer/ProgressBar.d.ts +7 -7
- package/dist/components/renderer/ProgressBar.js +6 -6
- package/dist/components/renderer/ProgressBar.js.map +1 -1
- package/dist/components/renderer/ToggleAllCheckbox.d.ts +13 -13
- package/dist/components/renderer/ToggleAllCheckbox.js +26 -26
- package/dist/components/renderer/attachments/AttachmentStatus.d.ts +10 -10
- package/dist/components/renderer/attachments/AttachmentStatus.js +36 -36
- package/dist/components/renderer/attachments/FileCard.d.ts +19 -19
- package/dist/components/renderer/attachments/FileCard.js +60 -60
- package/dist/components/renderer/attachments/FileCardContent.d.ts +5 -5
- package/dist/components/renderer/attachments/FileCardContent.js +10 -10
- package/dist/components/renderer/attachments/ImagePreviewUnavailable.d.ts +4 -4
- package/dist/components/renderer/attachments/ImagePreviewUnavailable.js +11 -11
- package/dist/components/renderer/attachments/ProgressBar.d.ts +8 -8
- package/dist/components/renderer/attachments/ProgressBar.js +33 -33
- package/dist/form-elements/ComplianceButton.d.ts +10 -10
- package/dist/form-elements/ComplianceButton.js +11 -11
- package/dist/form-elements/FormElementABN.d.ts +14 -14
- package/dist/form-elements/FormElementABN.js +155 -155
- package/dist/form-elements/FormElementAutocomplete.d.ts +19 -19
- package/dist/form-elements/FormElementAutocomplete.js +81 -81
- package/dist/form-elements/FormElementBSB.d.ts +18 -18
- package/dist/form-elements/FormElementBSB.js +100 -100
- package/dist/form-elements/FormElementBarcodeScanner.d.ts +14 -14
- package/dist/form-elements/FormElementBarcodeScanner.js +306 -306
- package/dist/form-elements/FormElementBoolean.d.ts +14 -14
- package/dist/form-elements/FormElementBoolean.js +16 -16
- package/dist/form-elements/FormElementCalculation.d.ts +11 -11
- package/dist/form-elements/FormElementCalculation.js +179 -179
- package/dist/form-elements/FormElementCamera.d.ts +15 -15
- package/dist/form-elements/FormElementCamera.js +227 -227
- package/dist/form-elements/FormElementCaptcha.d.ts +12 -12
- package/dist/form-elements/FormElementCaptcha.js +14 -14
- package/dist/form-elements/FormElementCheckBoxes.d.ts +15 -15
- package/dist/form-elements/FormElementCheckBoxes.js +64 -64
- package/dist/form-elements/FormElementCivicaNameRecord.d.ts +8 -8
- package/dist/form-elements/FormElementCivicaNameRecord.js +51 -51
- package/dist/form-elements/FormElementCivicaStreetName.d.ts +15 -15
- package/dist/form-elements/FormElementCivicaStreetName.js +38 -38
- package/dist/form-elements/FormElementCompliance.d.ts +22 -22
- package/dist/form-elements/FormElementCompliance.js +129 -129
- package/dist/form-elements/FormElementDate.d.ts +14 -14
- package/dist/form-elements/FormElementDate.js +74 -74
- package/dist/form-elements/FormElementDateTime.d.ts +14 -14
- package/dist/form-elements/FormElementDateTime.js +67 -67
- package/dist/form-elements/FormElementEmail.d.ts +14 -14
- package/dist/form-elements/FormElementEmail.js +22 -22
- package/dist/form-elements/FormElementFile.d.ts +13 -13
- package/dist/form-elements/FormElementFile.js +31 -31
- package/dist/form-elements/FormElementFiles.d.ts +15 -15
- package/dist/form-elements/FormElementFiles.js +42 -42
- package/dist/form-elements/FormElementForm.d.ts +17 -17
- package/dist/form-elements/FormElementForm.js +63 -63
- package/dist/form-elements/FormElementFreshdeskDependentField.d.ts +8 -8
- package/dist/form-elements/FormElementFreshdeskDependentField.js +15 -15
- package/dist/form-elements/FormElementGeoscapeAddress.d.ts +15 -15
- package/dist/form-elements/FormElementGeoscapeAddress.js +62 -62
- package/dist/form-elements/FormElementHTML.d.ts +8 -8
- package/dist/form-elements/FormElementHTML.js +15 -15
- package/dist/form-elements/FormElementHeading.d.ts +8 -8
- package/dist/form-elements/FormElementHeading.js +23 -23
- package/dist/form-elements/FormElementImage.d.ts +8 -8
- package/dist/form-elements/FormElementImage.js +6 -6
- package/dist/form-elements/FormElementLocation.d.ts +20 -20
- package/dist/form-elements/FormElementLocation.js +204 -204
- package/dist/form-elements/FormElementNumber.d.ts +14 -14
- package/dist/form-elements/FormElementNumber.js +72 -72
- package/dist/form-elements/FormElementPointAddress.d.ts +15 -15
- package/dist/form-elements/FormElementPointAddress.js +69 -69
- package/dist/form-elements/FormElementRadio.d.ts +15 -15
- package/dist/form-elements/FormElementRadio.js +41 -41
- package/dist/form-elements/FormElementRepeatableSet.d.ts +19 -19
- package/dist/form-elements/FormElementRepeatableSet.js +126 -126
- package/dist/form-elements/FormElementSection.d.ts +8 -8
- package/dist/form-elements/FormElementSection.js +69 -69
- package/dist/form-elements/FormElementSelect.d.ts +15 -15
- package/dist/form-elements/FormElementSelect.js +44 -44
- package/dist/form-elements/FormElementSignature.d.ts +15 -15
- package/dist/form-elements/FormElementSignature.js +138 -138
- package/dist/form-elements/FormElementSummary.d.ts +11 -11
- package/dist/form-elements/FormElementSummary.js +159 -159
- package/dist/form-elements/FormElementTelephone.d.ts +14 -14
- package/dist/form-elements/FormElementTelephone.js +22 -22
- package/dist/form-elements/FormElementText.d.ts +14 -14
- package/dist/form-elements/FormElementText.js +29 -29
- package/dist/form-elements/FormElementTextarea.d.ts +14 -14
- package/dist/form-elements/FormElementTextarea.js +30 -30
- package/dist/form-elements/FormElementTime.d.ts +14 -14
- package/dist/form-elements/FormElementTime.js +53 -53
- package/dist/form-elements/OptionButton.d.ts +11 -11
- package/dist/form-elements/OptionButton.js +9 -9
- package/dist/hooks/attachments/useAttachment.d.ts +12 -12
- package/dist/hooks/attachments/useAttachment.js +242 -242
- package/dist/hooks/attachments/useAttachmentBlobs.d.ts +19 -19
- package/dist/hooks/attachments/useAttachmentBlobs.js +23 -23
- package/dist/hooks/attachments/useAttachments.d.ts +10 -10
- package/dist/hooks/attachments/useAttachments.js +69 -69
- package/dist/hooks/useAbnLookupAuthenticationGuid.d.ts +3 -3
- package/dist/hooks/useAbnLookupAuthenticationGuid.js +5 -5
- package/dist/hooks/useAuth.d.ts +15 -15
- package/dist/hooks/useAuth.js +42 -42
- package/dist/hooks/useBooleanState.d.ts +5 -5
- package/dist/hooks/useBooleanState.js +8 -8
- package/dist/hooks/useCaptchaSiteKey.d.ts +3 -3
- package/dist/hooks/useCaptchaSiteKey.js +5 -5
- package/dist/hooks/useClickOutsideElement.d.ts +3 -3
- package/dist/hooks/useClickOutsideElement.js +14 -14
- package/dist/hooks/useConditionalLogic.d.ts +6 -6
- package/dist/hooks/useConditionalLogic.js +22 -22
- package/dist/hooks/useContrastColor.d.ts +2 -2
- package/dist/hooks/useContrastColor.js +12 -12
- package/dist/hooks/useDynamicOptionsLoaderState.d.ts +7 -7
- package/dist/hooks/useDynamicOptionsLoaderState.js +44 -44
- package/dist/hooks/useExecutedLookupCallback.d.ts +12 -12
- package/dist/hooks/useExecutedLookupCallback.js +15 -15
- package/dist/hooks/useFlatpickr.d.ts +10 -10
- package/dist/hooks/useFlatpickr.js +73 -73
- package/dist/hooks/useFlatpickrGuid.d.ts +7 -7
- package/dist/hooks/useFlatpickrGuid.js +11 -11
- package/dist/hooks/useFlattenElementsContext.d.ts +2 -2
- package/dist/hooks/useFlattenElementsContext.js +7 -7
- package/dist/hooks/useFormDefinition.d.ts +4 -4
- package/dist/hooks/useFormDefinition.js +9 -9
- package/dist/hooks/useFormElementOptions.d.ts +9 -9
- package/dist/hooks/useFormElementOptions.js +35 -35
- package/dist/hooks/useFormIsReadOnly.d.ts +3 -3
- package/dist/hooks/useFormIsReadOnly.js +5 -5
- package/dist/hooks/useFormSubmissionAutoSaveState.d.ts +24 -24
- package/dist/hooks/useFormSubmissionAutoSaveState.js +145 -145
- package/dist/hooks/useFormSubmissionModelContext.d.ts +15 -15
- package/dist/hooks/useFormSubmissionModelContext.js +32 -32
- package/dist/hooks/useFormSubmissionState.d.ts +10 -10
- package/dist/hooks/useFormSubmissionState.js +13 -13
- package/dist/hooks/useFormValidation.d.ts +7 -7
- package/dist/hooks/useFormValidation.js +29 -29
- package/dist/hooks/useGoogleMapsApiKey.d.ts +3 -3
- package/dist/hooks/useGoogleMapsApiKey.js +5 -5
- package/dist/hooks/useInfiniteScrollDataLoad.d.ts +30 -30
- package/dist/hooks/useInfiniteScrollDataLoad.js +124 -124
- package/dist/hooks/useInjectPages.d.ts +7 -7
- package/dist/hooks/useInjectPages.js +5 -5
- package/dist/hooks/useIsHovering.d.ts +5 -5
- package/dist/hooks/useIsHovering.js +12 -12
- package/dist/hooks/useIsMounted.d.ts +3 -3
- package/dist/hooks/useIsMounted.js +11 -11
- package/dist/hooks/useIsOffline.d.ts +6 -6
- package/dist/hooks/useIsOffline.js +26 -26
- package/dist/hooks/useIsPageVisible.d.ts +9 -9
- package/dist/hooks/useIsPageVisible.js +8 -8
- package/dist/hooks/useLoadDataState.d.ts +15 -15
- package/dist/hooks/useLoadDataState.js +54 -54
- package/dist/hooks/useLogin.d.ts +46 -46
- package/dist/hooks/useLogin.js +295 -295
- package/dist/hooks/useLookupNotification.d.ts +9 -9
- package/dist/hooks/useLookupNotification.js +10 -10
- package/dist/hooks/useLookups.d.ts +5 -5
- package/dist/hooks/useLookups.js +62 -62
- package/dist/hooks/useNullableState.d.ts +2 -2
- package/dist/hooks/useNullableState.js +6 -6
- package/dist/hooks/usePages.d.ts +24 -24
- package/dist/hooks/usePages.js +141 -141
- package/dist/hooks/useQuery.d.ts +2 -2
- package/dist/hooks/useQuery.js +7 -7
- package/dist/hooks/useSubmissionIdIsValid.d.ts +3 -3
- package/dist/hooks/useSubmissionIdIsValid.js +19 -19
- package/dist/hooks/useToggleComplianceChildren.d.ts +3 -3
- package/dist/hooks/useToggleComplianceChildren.js +13 -13
- package/dist/index.d.ts +23 -23
- package/dist/index.js +23 -23
- package/dist/services/attachments.d.ts +10 -10
- package/dist/services/attachments.js +72 -72
- package/dist/services/barcode-readers/quagger.d.ts +1 -1
- package/dist/services/barcode-readers/quagger.js +34 -34
- package/dist/services/blob-utils.d.ts +5 -5
- package/dist/services/blob-utils.js +73 -73
- package/dist/services/checkBsbsAreInvalid.d.ts +3 -3
- package/dist/services/checkBsbsAreInvalid.js +40 -40
- package/dist/services/checkIfAttachmentsExist.d.ts +5 -5
- package/dist/services/checkIfAttachmentsExist.js +144 -144
- package/dist/services/checkIfBsbsAreValidating.d.ts +3 -3
- package/dist/services/checkIfBsbsAreValidating.js +40 -40
- package/dist/services/cleanFormSubmissionModel.d.ts +6 -6
- package/dist/services/cleanFormSubmissionModel.js +203 -203
- package/dist/services/defaultCoordinates.d.ts +5 -5
- package/dist/services/defaultCoordinates.js +8 -8
- package/dist/services/download-file.d.ts +3 -3
- package/dist/services/download-file.js +90 -90
- package/dist/services/drawTimestampOnCanvas.d.ts +1 -1
- package/dist/services/drawTimestampOnCanvas.js +22 -22
- package/dist/services/form-validation.d.ts +10 -10
- package/dist/services/form-validation.js +561 -561
- package/dist/services/generate-default-data.d.ts +13 -13
- package/dist/services/generate-default-data.js +494 -494
- package/dist/services/generateCivicaNameRecordElements.d.ts +2 -2
- package/dist/services/generateCivicaNameRecordElements.js +140 -140
- package/dist/services/generateFreshdeskDependentFieldElements.d.ts +2 -2
- package/dist/services/generateFreshdeskDependentFieldElements.js +69 -69
- package/dist/services/sanitize-html.d.ts +2 -2
- package/dist/services/sanitize-html.js +20 -20
- package/dist/services/scrolling-service.d.ts +7 -7
- package/dist/services/scrolling-service.js +38 -38
- package/dist/services/utils-service.d.ts +5 -5
- package/dist/services/utils-service.js +16 -16
- package/dist/types/attachments.d.ts +19 -19
- package/dist/types/attachments.js +1 -1
- package/dist/types/form.d.ts +40 -40
- package/dist/types/form.js +2 -2
- package/package.json +2 -2
- package/dist/OneBlinkFormStoreView.d.ts +0 -8
- package/dist/OneBlinkFormStoreView.js +0 -55
- package/dist/OneBlinkFormStoreView.js.map +0 -1
- package/dist/components/AnnotationModal.d.ts +0 -8
- package/dist/components/AnnotationModal.js +0 -104
- package/dist/components/AnnotationModal.js.map +0 -1
- package/dist/components/AutocompleteDropdown.d.ts +0 -26
- package/dist/components/AutocompleteDropdown.js +0 -174
- package/dist/components/AutocompleteDropdown.js.map +0 -1
- package/dist/components/CopyToClipboardButton.d.ts +0 -9
- package/dist/components/CopyToClipboardButton.js +0 -14
- package/dist/components/CopyToClipboardButton.js.map +0 -1
- package/dist/components/CustomisableButtonInner.d.ts +0 -7
- package/dist/components/CustomisableButtonInner.js +0 -9
- package/dist/components/CustomisableButtonInner.js.map +0 -1
- package/dist/components/ErrorMessage.d.ts +0 -13
- package/dist/components/ErrorMessage.js +0 -13
- package/dist/components/ErrorMessage.js.map +0 -1
- package/dist/components/FormElementLabelContainer.d.ts +0 -12
- package/dist/components/FormElementLabelContainer.js +0 -16
- package/dist/components/FormElementLabelContainer.js.map +0 -1
- package/dist/components/FormElementOptions.d.ts +0 -9
- package/dist/components/FormElementOptions.js +0 -15
- package/dist/components/FormElementOptions.js.map +0 -1
- package/dist/components/LookupButton.d.ts +0 -10
- package/dist/components/LookupButton.js +0 -30
- package/dist/components/LookupButton.js.map +0 -1
- package/dist/components/LookupNotification.d.ts +0 -12
- package/dist/components/LookupNotification.js +0 -231
- package/dist/components/LookupNotification.js.map +0 -1
- package/dist/components/Modal.d.ts +0 -14
- package/dist/components/Modal.js +0 -15
- package/dist/components/Modal.js.map +0 -1
- package/dist/components/NoResourcesYet.d.ts +0 -12
- package/dist/components/NoResourcesYet.js +0 -7
- package/dist/components/NoResourcesYet.js.map +0 -1
- package/dist/components/OnLoading.d.ts +0 -10
- package/dist/components/OnLoading.js +0 -12
- package/dist/components/OnLoading.js.map +0 -1
- package/dist/components/OneBlinkAppsErrorOriginalMessage.d.ts +0 -7
- package/dist/components/OneBlinkAppsErrorOriginalMessage.js +0 -13
- package/dist/components/OneBlinkAppsErrorOriginalMessage.js.map +0 -1
- package/dist/components/OneBlinkFormElements.d.ts +0 -19
- package/dist/components/OneBlinkFormElements.js +0 -196
- package/dist/components/OneBlinkFormElements.js.map +0 -1
- package/dist/components/PageFormElements.d.ts +0 -17
- package/dist/components/PageFormElements.js +0 -49
- package/dist/components/PageFormElements.js.map +0 -1
- package/dist/components/ToggleAllCheckbox.d.ts +0 -13
- package/dist/components/ToggleAllCheckbox.js +0 -27
- package/dist/components/ToggleAllCheckbox.js.map +0 -1
- package/dist/components/attachments/AttachmentStatus.d.ts +0 -12
- package/dist/components/attachments/AttachmentStatus.js +0 -35
- package/dist/components/attachments/AttachmentStatus.js.map +0 -1
- package/dist/components/attachments/FileCard.d.ts +0 -18
- package/dist/components/attachments/FileCard.js +0 -58
- package/dist/components/attachments/FileCard.js.map +0 -1
- package/dist/components/attachments/FileCardContent.d.ts +0 -5
- package/dist/components/attachments/FileCardContent.js +0 -11
- package/dist/components/attachments/FileCardContent.js.map +0 -1
- package/dist/components/attachments/Files.d.ts +0 -14
- package/dist/components/attachments/Files.js +0 -27
- package/dist/components/attachments/Files.js.map +0 -1
- package/dist/components/attachments/ImagePreviewUnavailable.d.ts +0 -4
- package/dist/components/attachments/ImagePreviewUnavailable.js +0 -12
- package/dist/components/attachments/ImagePreviewUnavailable.js.map +0 -1
- package/dist/components/attachments/UploadingAttachment.d.ts +0 -4
- package/dist/components/attachments/UploadingAttachment.js +0 -13
- package/dist/components/attachments/UploadingAttachment.js.map +0 -1
- package/dist/components/formStore/ColumnsConfigurationButton.d.ts +0 -10
- package/dist/components/formStore/ColumnsConfigurationButton.js +0 -29
- package/dist/components/formStore/ColumnsConfigurationButton.js.map +0 -1
- package/dist/components/formStore/DownloadSubmissionDataButton.d.ts +0 -13
- package/dist/components/formStore/DownloadSubmissionDataButton.js +0 -45
- package/dist/components/formStore/DownloadSubmissionDataButton.js.map +0 -1
- package/dist/components/formStore/FormStore.d.ts +0 -9
- package/dist/components/formStore/FormStore.js +0 -103
- package/dist/components/formStore/FormStore.js.map +0 -1
- package/dist/components/formStore/table/index.d.ts +0 -17
- package/dist/components/formStore/table/index.js +0 -194
- package/dist/components/formStore/table/index.js.map +0 -1
- package/dist/components/renderer/attachments/Files.d.ts +0 -14
- package/dist/components/renderer/attachments/Files.js +0 -27
- package/dist/components/renderer/attachments/Files.js.map +0 -1
- package/dist/components/renderer/attachments/UploadingAttachment.d.ts +0 -4
- package/dist/components/renderer/attachments/UploadingAttachment.js +0 -13
- package/dist/components/renderer/attachments/UploadingAttachment.js.map +0 -1
- package/dist/form-elements/FormElementFiles/FormElementFile.d.ts +0 -13
- package/dist/form-elements/FormElementFiles/FormElementFile.js +0 -32
- package/dist/form-elements/FormElementFiles/FormElementFile.js.map +0 -1
- package/dist/form-elements/FormElementFiles/FormElementFileDisplay.d.ts +0 -10
- package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js +0 -11
- package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js.map +0 -1
- package/dist/form-elements/FormElementFiles/FormElementFiles.d.ts +0 -15
- package/dist/form-elements/FormElementFiles/FormElementFiles.js +0 -17
- package/dist/form-elements/FormElementFiles/FormElementFiles.js.map +0 -1
- package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.d.ts +0 -7
- package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js +0 -11
- package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js.map +0 -1
- package/dist/form-elements/FormElementFiles/index.d.ts +0 -17
- package/dist/form-elements/FormElementFiles/index.js +0 -18
- package/dist/form-elements/FormElementFiles/index.js.map +0 -1
- package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.d.ts +0 -18
- package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js +0 -61
- package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js.map +0 -1
- package/dist/hooks/attachments/useAttachmentObjectURLs.d.ts +0 -24
- package/dist/hooks/attachments/useAttachmentObjectURLs.js +0 -37
- package/dist/hooks/attachments/useAttachmentObjectURLs.js.map +0 -1
- package/dist/hooks/attachments/useLocalAttachmentBlobs.d.ts +0 -24
- package/dist/hooks/attachments/useLocalAttachmentBlobs.js +0 -40
- package/dist/hooks/attachments/useLocalAttachmentBlobs.js.map +0 -1
- package/dist/hooks/useButtonsConfiguration.d.ts +0 -45
- package/dist/hooks/useButtonsConfiguration.js +0 -6
- package/dist/hooks/useButtonsConfiguration.js.map +0 -1
- package/dist/hooks/useChangeEffect.d.ts +0 -1
- package/dist/hooks/useChangeEffect.js +0 -14
- package/dist/hooks/useChangeEffect.js.map +0 -1
- package/dist/hooks/useConditionallyShowOptionCallback.d.ts +0 -5
- package/dist/hooks/useConditionallyShowOptionCallback.js +0 -20
- package/dist/hooks/useConditionallyShowOptionCallback.js.map +0 -1
- package/dist/hooks/useCustomValidation.d.ts +0 -1
- package/dist/hooks/useCustomValidation.js +0 -9
- package/dist/hooks/useCustomValidation.js.map +0 -1
- package/dist/hooks/useDynamicOptionsLoaderEffect.d.ts +0 -7
- package/dist/hooks/useDynamicOptionsLoaderEffect.js +0 -45
- package/dist/hooks/useDynamicOptionsLoaderEffect.js.map +0 -1
- package/dist/hooks/useLegacyElements.d.ts +0 -16
- package/dist/hooks/useLegacyElements.js +0 -55
- package/dist/hooks/useLegacyElements.js.map +0 -1
- package/dist/hooks/useToggleAll.d.ts +0 -6
- package/dist/hooks/useToggleAll.js +0 -24
- package/dist/hooks/useToggleAll.js.map +0 -1
- package/dist/services/checkIfAttachmentsAreUploading.d.ts +0 -3
- package/dist/services/checkIfAttachmentsAreUploading.js +0 -58
- package/dist/services/checkIfAttachmentsAreUploading.js.map +0 -1
- package/dist/services/clean-form-elements-ctrl-model.d.ts +0 -4
- package/dist/services/clean-form-elements-ctrl-model.js +0 -166
- package/dist/services/clean-form-elements-ctrl-model.js.map +0 -1
- package/dist/services/conditionally-show-element.d.ts +0 -11
- package/dist/services/conditionally-show-element.js +0 -92
- package/dist/services/conditionally-show-element.js.map +0 -1
- package/dist/services/conditionally-show-option.d.ts +0 -3
- package/dist/services/conditionally-show-option.js +0 -135
- package/dist/services/conditionally-show-option.js.map +0 -1
- package/dist/services/flattenFormElements.d.ts +0 -2
- package/dist/services/flattenFormElements.js +0 -13
- package/dist/services/flattenFormElements.js.map +0 -1
- package/dist/services/getCorrectDateFromDateOnlyString.d.ts +0 -2
- package/dist/services/getCorrectDateFromDateOnlyString.js +0 -4
- package/dist/services/getCorrectDateFromDateOnlyString.js.map +0 -1
- package/dist/styles/boolean.scss +0 -12
- package/dist/styles/ob-file.scss +0 -63
@@ -1,45 +0,0 @@
|
|
1
|
-
import * as React from 'react';
|
2
|
-
export declare const ButtonsConfigurationContext: React.Context<{
|
3
|
-
submit?: {
|
4
|
-
icon?: string | undefined;
|
5
|
-
label?: string | undefined;
|
6
|
-
} | undefined;
|
7
|
-
cancel?: {
|
8
|
-
icon?: string | undefined;
|
9
|
-
label?: string | undefined;
|
10
|
-
} | undefined;
|
11
|
-
saveDraft?: {
|
12
|
-
icon?: string | undefined;
|
13
|
-
label?: string | undefined;
|
14
|
-
} | undefined;
|
15
|
-
cancelPromptYes?: {
|
16
|
-
icon?: string | undefined;
|
17
|
-
label?: string | undefined;
|
18
|
-
} | undefined;
|
19
|
-
cancelPromptNo?: {
|
20
|
-
icon?: string | undefined;
|
21
|
-
label?: string | undefined;
|
22
|
-
} | undefined;
|
23
|
-
} | undefined>;
|
24
|
-
export default function useButtonsConfiguration(): {
|
25
|
-
submit?: {
|
26
|
-
icon?: string | undefined;
|
27
|
-
label?: string | undefined;
|
28
|
-
} | undefined;
|
29
|
-
cancel?: {
|
30
|
-
icon?: string | undefined;
|
31
|
-
label?: string | undefined;
|
32
|
-
} | undefined;
|
33
|
-
saveDraft?: {
|
34
|
-
icon?: string | undefined;
|
35
|
-
label?: string | undefined;
|
36
|
-
} | undefined;
|
37
|
-
cancelPromptYes?: {
|
38
|
-
icon?: string | undefined;
|
39
|
-
label?: string | undefined;
|
40
|
-
} | undefined;
|
41
|
-
cancelPromptNo?: {
|
42
|
-
icon?: string | undefined;
|
43
|
-
label?: string | undefined;
|
44
|
-
} | undefined;
|
45
|
-
} | undefined;
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useButtonsConfiguration.js","sourceRoot":"","sources":["../../src/hooks/useButtonsConfiguration.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,MAAM,CAAC,MAAM,2BAA2B,GAAG,KAAK,CAAC,aAAa,CAE5D,EAAE,CAAC,CAAA;AAEL,MAAM,CAAC,OAAO,UAAU,uBAAuB;IAC7C,OAAO,KAAK,CAAC,UAAU,CAAC,2BAA2B,CAAC,CAAA;AACtD,CAAC","sourcesContent":["import * as React from 'react'\nimport { FormsAppsTypes } from '@oneblink/types'\nexport const ButtonsConfigurationContext = React.createContext<\n FormsAppsTypes.FormsListStyles['buttons']\n>({})\n\nexport default function useButtonsConfiguration() {\n return React.useContext(ButtonsConfigurationContext)\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
export default function useChangeEffect(effect: () => void | (() => void), dependencies: unknown[]): void;
|
@@ -1,14 +0,0 @@
|
|
1
|
-
import * as React from 'react';
|
2
|
-
export default function useChangeEffect(effect, dependencies) {
|
3
|
-
const initializeRef = React.useRef(false);
|
4
|
-
React.useEffect(() => {
|
5
|
-
if (initializeRef.current) {
|
6
|
-
return effect();
|
7
|
-
}
|
8
|
-
else {
|
9
|
-
initializeRef.current = true;
|
10
|
-
}
|
11
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
12
|
-
}, [dependencies]);
|
13
|
-
}
|
14
|
-
//# sourceMappingURL=useChangeEffect.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useChangeEffect.js","sourceRoot":"","sources":["../../src/hooks/useChangeEffect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,MAAM,CAAC,OAAO,UAAU,eAAe,CACrC,MAAiC,EACjC,YAAuB;IAEvB,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;IAEzC,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,aAAa,CAAC,OAAO,EAAE;YACzB,OAAO,MAAM,EAAE,CAAA;SAChB;aAAM;YACL,aAAa,CAAC,OAAO,GAAG,IAAI,CAAA;SAC7B;QACD,uDAAuD;IACzD,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;AACpB,CAAC","sourcesContent":["import * as React from 'react'\n\nexport default function useChangeEffect(\n effect: () => void | (() => void),\n dependencies: unknown[],\n) {\n const initializeRef = React.useRef(false)\n\n React.useEffect(() => {\n if (initializeRef.current) {\n return effect()\n } else {\n initializeRef.current = true\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [dependencies])\n}\n"]}
|
@@ -1,5 +0,0 @@
|
|
1
|
-
import { FormTypes } from '@oneblink/types';
|
2
|
-
import * as React from 'react';
|
3
|
-
export declare type ConditionallyShowOptionCallbackContextValue = (formElementsCtrl: FormElementsCtrl, formElementWithOptions: FormTypes.FormElementWithOptions, choiceElementOption: FormTypes.ChoiceElementOption) => boolean;
|
4
|
-
export declare const ConditionallyShowOptionCallbackContext: React.Context<ConditionallyShowOptionCallbackContextValue>;
|
5
|
-
export default function useConditionallyShowOptionCallback(formElementsCtrl: FormElementsCtrl, element: FormTypes.FormElement): (option: FormTypes.ChoiceElementOption) => boolean;
|
@@ -1,20 +0,0 @@
|
|
1
|
-
import * as React from 'react';
|
2
|
-
const defaultContext = () => true;
|
3
|
-
export const ConditionallyShowOptionCallbackContext = React.createContext(defaultContext);
|
4
|
-
export default function useConditionallyShowOptionCallback(formElementsCtrl, element) {
|
5
|
-
const onConditionallyShowOption = React.useContext(ConditionallyShowOptionCallbackContext);
|
6
|
-
return React.useMemo(() => {
|
7
|
-
if ((element.type !== 'select' &&
|
8
|
-
element.type !== 'compliance' &&
|
9
|
-
element.type !== 'radio' &&
|
10
|
-
element.type !== 'checkboxes' &&
|
11
|
-
element.type !== 'autocomplete') ||
|
12
|
-
!element.conditionallyShowOptions) {
|
13
|
-
return defaultContext;
|
14
|
-
}
|
15
|
-
return (option) => {
|
16
|
-
return onConditionallyShowOption(formElementsCtrl, element, option);
|
17
|
-
};
|
18
|
-
}, [element, formElementsCtrl, onConditionallyShowOption]);
|
19
|
-
}
|
20
|
-
//# sourceMappingURL=useConditionallyShowOptionCallback.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useConditionallyShowOptionCallback.js","sourceRoot":"","sources":["../../src/hooks/useConditionallyShowOptionCallback.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAQ9B,MAAM,cAAc,GAAG,GAAG,EAAE,CAAC,IAAI,CAAA;AAEjC,MAAM,CAAC,MAAM,sCAAsC,GAAG,KAAK,CAAC,aAAa,CACvE,cAAc,CACf,CAAA;AAED,MAAM,CAAC,OAAO,UAAU,kCAAkC,CACxD,gBAAkC,EAClC,OAA8B;IAE9B,MAAM,yBAAyB,GAAG,KAAK,CAAC,UAAU,CAChD,sCAAsC,CACvC,CAAA;IAED,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxB,IACE,CAAC,OAAO,CAAC,IAAI,KAAK,QAAQ;YACxB,OAAO,CAAC,IAAI,KAAK,YAAY;YAC7B,OAAO,CAAC,IAAI,KAAK,OAAO;YACxB,OAAO,CAAC,IAAI,KAAK,YAAY;YAC7B,OAAO,CAAC,IAAI,KAAK,cAAc,CAAC;YAClC,CAAC,OAAO,CAAC,wBAAwB,EACjC;YACA,OAAO,cAAc,CAAA;SACtB;QAED,OAAO,CAAC,MAAqC,EAAE,EAAE;YAC/C,OAAO,yBAAyB,CAAC,gBAAgB,EAAE,OAAO,EAAE,MAAM,CAAC,CAAA;QACrE,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,OAAO,EAAE,gBAAgB,EAAE,yBAAyB,CAAC,CAAC,CAAA;AAC5D,CAAC","sourcesContent":["import { FormTypes } from '@oneblink/types'\nimport * as React from 'react'\n\nexport type ConditionallyShowOptionCallbackContextValue = (\n formElementsCtrl: FormElementsCtrl,\n formElementWithOptions: FormTypes.FormElementWithOptions,\n choiceElementOption: FormTypes.ChoiceElementOption,\n) => boolean\n\nconst defaultContext = () => true\n\nexport const ConditionallyShowOptionCallbackContext = React.createContext<ConditionallyShowOptionCallbackContextValue>(\n defaultContext,\n)\n\nexport default function useConditionallyShowOptionCallback(\n formElementsCtrl: FormElementsCtrl,\n element: FormTypes.FormElement,\n) {\n const onConditionallyShowOption = React.useContext(\n ConditionallyShowOptionCallbackContext,\n )\n\n return React.useMemo(() => {\n if (\n (element.type !== 'select' &&\n element.type !== 'compliance' &&\n element.type !== 'radio' &&\n element.type !== 'checkboxes' &&\n element.type !== 'autocomplete') ||\n !element.conditionallyShowOptions\n ) {\n return defaultContext\n }\n\n return (option: FormTypes.ChoiceElementOption) => {\n return onConditionallyShowOption(formElementsCtrl, element, option)\n }\n }, [element, formElementsCtrl, onConditionallyShowOption])\n}\n"]}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useCustomValidation.js","sourceRoot":"","sources":["../../src/hooks/useCustomValidation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B,MAAM,mBAAmB,GAAG,CAG1B,OAAU,EACV,EAAE;IACF,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxB,OAAO;YACL,wBAAwB,EAAE,CAAC,CAAC,OAAO,CAAC,YAAY;SACjD,CAAA;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;AACR,CAAC,CAAA","sourcesContent":["import * as React from 'react'\nimport { FormTypes } from '@oneblink/types'\n\nconst useCustomValidation = <\n T extends FormTypes.FormElementWithInput<T['defaultValue']>,\n>(\n element: T,\n) => {\n return React.useMemo(() => {\n return {\n shouldUseRegexValidation: !!element.regexPattern,\n }\n }, [])\n}\n"]}
|
@@ -1,7 +0,0 @@
|
|
1
|
-
import { OneBlinkAppsError } from '@oneblink/apps';
|
2
|
-
import { FormTypes } from '@oneblink/types';
|
3
|
-
import { SetFormSubmission } from '../types/form';
|
4
|
-
export default function useDynamicOptionsLoaderState(form: FormTypes.Form, setFormSubmission: SetFormSubmission): {
|
5
|
-
elementId: string;
|
6
|
-
error: OneBlinkAppsError;
|
7
|
-
} | null;
|
@@ -1,45 +0,0 @@
|
|
1
|
-
import * as React from 'react';
|
2
|
-
import _cloneDeep from 'lodash.clonedeep';
|
3
|
-
import { formElementsService } from '@oneblink/sdk-core';
|
4
|
-
import { formService } from '@oneblink/apps';
|
5
|
-
export default function useDynamicOptionsLoaderState(form, setFormSubmission) {
|
6
|
-
const [state, setState] = React.useState(null);
|
7
|
-
React.useEffect(() => {
|
8
|
-
if (state) {
|
9
|
-
return;
|
10
|
-
}
|
11
|
-
let ignore = false;
|
12
|
-
(async () => {
|
13
|
-
const optionsByElementId = await formService.getFormElementDynamicOptions(form);
|
14
|
-
if (ignore || !optionsByElementId.length) {
|
15
|
-
return;
|
16
|
-
}
|
17
|
-
const nonOkResponse = optionsByElementId.find((optionsForElementId) => !optionsForElementId.ok);
|
18
|
-
if (nonOkResponse && !nonOkResponse.ok) {
|
19
|
-
setState(nonOkResponse);
|
20
|
-
return;
|
21
|
-
}
|
22
|
-
setFormSubmission((currentFormSubmission) => {
|
23
|
-
const clonedForm = _cloneDeep(currentFormSubmission.definition);
|
24
|
-
for (const optionsForElementId of optionsByElementId) {
|
25
|
-
if (optionsForElementId.ok) {
|
26
|
-
formElementsService.forEachFormElementWithOptions(clonedForm.elements, (formElement) => {
|
27
|
-
if (formElement.id === optionsForElementId.elementId) {
|
28
|
-
formElement.options = optionsForElementId.options;
|
29
|
-
}
|
30
|
-
});
|
31
|
-
}
|
32
|
-
}
|
33
|
-
return {
|
34
|
-
...currentFormSubmission,
|
35
|
-
definition: clonedForm,
|
36
|
-
};
|
37
|
-
});
|
38
|
-
})();
|
39
|
-
return () => {
|
40
|
-
ignore = true;
|
41
|
-
};
|
42
|
-
}, [form, setFormSubmission, state]);
|
43
|
-
return state;
|
44
|
-
}
|
45
|
-
//# sourceMappingURL=useDynamicOptionsLoaderEffect.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useDynamicOptionsLoaderEffect.js","sourceRoot":"","sources":["../../src/hooks/useDynamicOptionsLoaderEffect.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAC9B,OAAO,UAAU,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAA;AACxD,OAAO,EAAE,WAAW,EAAqB,MAAM,gBAAgB,CAAA;AAI/D,MAAM,CAAC,OAAO,UAAU,4BAA4B,CAClD,IAAoB,EACpB,iBAAoC;IAKpC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GACrB,KAAK,CAAC,QAAQ,CAAkD,IAAI,CAAC,CAAA;IACvE,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACnB,IAAI,KAAK,EAAE;YACT,OAAM;SACP;QAED,IAAI,MAAM,GAAG,KAAK,CAEjB;QAAA,CAAC,KAAK,IAAI,EAAE;YACX,MAAM,kBAAkB,GAAG,MAAM,WAAW,CAAC,4BAA4B,CACvE,IAAI,CACL,CAAA;YAED,IAAI,MAAM,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE;gBACxC,OAAM;aACP;YAED,MAAM,aAAa,GAAG,kBAAkB,CAAC,IAAI,CAC3C,CAAC,mBAAmB,EAAE,EAAE,CAAC,CAAC,mBAAmB,CAAC,EAAE,CACjD,CAAA;YACD,IAAI,aAAa,IAAI,CAAC,aAAa,CAAC,EAAE,EAAE;gBACtC,QAAQ,CAAC,aAAa,CAAC,CAAA;gBACvB,OAAM;aACP;YAED,iBAAiB,CAAC,CAAC,qBAAqB,EAAE,EAAE;gBAC1C,MAAM,UAAU,GAAmB,UAAU,CAC3C,qBAAqB,CAAC,UAAU,CACjC,CAAA;gBACD,KAAK,MAAM,mBAAmB,IAAI,kBAAkB,EAAE;oBACpD,IAAI,mBAAmB,CAAC,EAAE,EAAE;wBAC1B,mBAAmB,CAAC,6BAA6B,CAC/C,UAAU,CAAC,QAAQ,EACnB,CAAC,WAAW,EAAE,EAAE;4BACd,IAAI,WAAW,CAAC,EAAE,KAAK,mBAAmB,CAAC,SAAS,EAAE;gCACpD,WAAW,CAAC,OAAO,GAAG,mBAAmB,CAAC,OAAO,CAAA;6BAClD;wBACH,CAAC,CACF,CAAA;qBACF;iBACF;gBACD,OAAO;oBACL,GAAG,qBAAqB;oBACxB,UAAU,EAAE,UAAU;iBACvB,CAAA;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,EAAE,CAAA;QAEJ,OAAO,GAAG,EAAE;YACV,MAAM,GAAG,IAAI,CAAA;QACf,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,IAAI,EAAE,iBAAiB,EAAE,KAAK,CAAC,CAAC,CAAA;IAEpC,OAAO,KAAK,CAAA;AACd,CAAC","sourcesContent":["import * as React from 'react'\nimport _cloneDeep from 'lodash.clonedeep'\nimport { formElementsService } from '@oneblink/sdk-core'\nimport { formService, OneBlinkAppsError } from '@oneblink/apps'\nimport { FormTypes } from '@oneblink/types'\nimport { SetFormSubmission } from '../types/form'\n\nexport default function useDynamicOptionsLoaderState(\n form: FormTypes.Form,\n setFormSubmission: SetFormSubmission,\n): {\n elementId: string\n error: OneBlinkAppsError\n} | null {\n const [state, setState] =\n React.useState<ReturnType<typeof useDynamicOptionsLoaderState>>(null)\n React.useEffect(() => {\n if (state) {\n return\n }\n\n let ignore = false\n\n ;(async () => {\n const optionsByElementId = await formService.getFormElementDynamicOptions(\n form,\n )\n\n if (ignore || !optionsByElementId.length) {\n return\n }\n\n const nonOkResponse = optionsByElementId.find(\n (optionsForElementId) => !optionsForElementId.ok,\n )\n if (nonOkResponse && !nonOkResponse.ok) {\n setState(nonOkResponse)\n return\n }\n\n setFormSubmission((currentFormSubmission) => {\n const clonedForm: FormTypes.Form = _cloneDeep(\n currentFormSubmission.definition,\n )\n for (const optionsForElementId of optionsByElementId) {\n if (optionsForElementId.ok) {\n formElementsService.forEachFormElementWithOptions(\n clonedForm.elements,\n (formElement) => {\n if (formElement.id === optionsForElementId.elementId) {\n formElement.options = optionsForElementId.options\n }\n },\n )\n }\n }\n return {\n ...currentFormSubmission,\n definition: clonedForm,\n }\n })\n })()\n\n return () => {\n ignore = true\n }\n }, [form, setFormSubmission, state])\n\n return state\n}\n"]}
|
@@ -1,16 +0,0 @@
|
|
1
|
-
import { FormTypes } from '@oneblink/types';
|
2
|
-
export declare const legacyNameRegex: RegExp;
|
3
|
-
declare const useLegacyFormElements: (formElements: FormTypes.FormElement[]) => {
|
4
|
-
formElementsUsingLegacyStorage: {
|
5
|
-
name: string;
|
6
|
-
label: string;
|
7
|
-
id: string;
|
8
|
-
}[];
|
9
|
-
formElementsUsingLegacyNames: {
|
10
|
-
name: string;
|
11
|
-
label: string;
|
12
|
-
id: string;
|
13
|
-
}[];
|
14
|
-
};
|
15
|
-
export default useLegacyFormElements;
|
16
|
-
export declare const useFormElementLegacyConfigMessage: (formElement: FormTypes.FormElement) => string | undefined;
|
@@ -1,55 +0,0 @@
|
|
1
|
-
import { useMemo } from 'react';
|
2
|
-
import { formElementsService, typeCastService } from '@oneblink/sdk-core';
|
3
|
-
export const legacyNameRegex = /[^a-zA-Z\d_-]/;
|
4
|
-
const checkStorageType = (element) => {
|
5
|
-
const storageElement = typeCastService.formElements.toStorageElement(element);
|
6
|
-
if (storageElement &&
|
7
|
-
(!storageElement.storageType || storageElement.storageType === 'legacy')) {
|
8
|
-
return {
|
9
|
-
label: storageElement.label,
|
10
|
-
name: storageElement.name,
|
11
|
-
id: storageElement.id,
|
12
|
-
};
|
13
|
-
}
|
14
|
-
};
|
15
|
-
const checkName = (element) => {
|
16
|
-
const namedElement = typeCastService.formElements.toNamedElement(element);
|
17
|
-
if (!!namedElement && legacyNameRegex.test(namedElement.name)) {
|
18
|
-
const formElementWithoutForm = typeCastService.formElements.toFormElementWithoutForm(namedElement);
|
19
|
-
return {
|
20
|
-
name: namedElement.name,
|
21
|
-
label: (formElementWithoutForm === null || formElementWithoutForm === void 0 ? void 0 : formElementWithoutForm.label) || 'Nested Form',
|
22
|
-
id: namedElement.id,
|
23
|
-
};
|
24
|
-
}
|
25
|
-
};
|
26
|
-
const useLegacyFormElements = (formElements) => {
|
27
|
-
return useMemo(() => {
|
28
|
-
const formElementsUsingLegacyStorage = [];
|
29
|
-
const formElementsUsingLegacyNames = [];
|
30
|
-
formElementsService.forEachFormElement(formElements || [], (element) => {
|
31
|
-
const legacyStorageType = checkStorageType(element);
|
32
|
-
if (legacyStorageType) {
|
33
|
-
formElementsUsingLegacyStorage.push(legacyStorageType);
|
34
|
-
}
|
35
|
-
const legacyName = checkName(element);
|
36
|
-
if (legacyName) {
|
37
|
-
formElementsUsingLegacyNames.push(legacyName);
|
38
|
-
}
|
39
|
-
});
|
40
|
-
return {
|
41
|
-
formElementsUsingLegacyStorage,
|
42
|
-
formElementsUsingLegacyNames,
|
43
|
-
};
|
44
|
-
}, [formElements]);
|
45
|
-
};
|
46
|
-
export default useLegacyFormElements;
|
47
|
-
const formElementLegacyConfigMessage = 'Element is using unsupported configuration';
|
48
|
-
export const useFormElementLegacyConfigMessage = (formElement) => {
|
49
|
-
return useMemo(() => {
|
50
|
-
if (checkStorageType(formElement) || checkName(formElement)) {
|
51
|
-
return formElementLegacyConfigMessage;
|
52
|
-
}
|
53
|
-
}, [formElement]);
|
54
|
-
};
|
55
|
-
//# sourceMappingURL=useLegacyElements.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useLegacyElements.js","sourceRoot":"","sources":["../../src/hooks/useLegacyElements.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAA;AAC/B,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAGzE,MAAM,CAAC,MAAM,eAAe,GAAG,eAAe,CAAA;AAE9C,MAAM,gBAAgB,GAAG,CAAC,OAA8B,EAAE,EAAE;IAC1D,MAAM,cAAc,GAAG,eAAe,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;IAC7E,IACE,cAAc;QACd,CAAC,CAAC,cAAc,CAAC,WAAW,IAAI,cAAc,CAAC,WAAW,KAAK,QAAQ,CAAC,EACxE;QACA,OAAO;YACL,KAAK,EAAE,cAAc,CAAC,KAAK;YAC3B,IAAI,EAAE,cAAc,CAAC,IAAI;YACzB,EAAE,EAAE,cAAc,CAAC,EAAE;SACtB,CAAA;KACF;AACH,CAAC,CAAA;AAED,MAAM,SAAS,GAAG,CAAC,OAA8B,EAAE,EAAE;IACnD,MAAM,YAAY,GAChB,eAAe,CAAC,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAA;IACtD,IAAI,CAAC,CAAC,YAAY,IAAI,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE;QAC7D,MAAM,sBAAsB,GAC1B,eAAe,CAAC,YAAY,CAAC,wBAAwB,CAAC,YAAY,CAAC,CAAA;QACrE,OAAO;YACL,IAAI,EAAE,YAAY,CAAC,IAAI;YACvB,KAAK,EAAE,CAAA,sBAAsB,aAAtB,sBAAsB,uBAAtB,sBAAsB,CAAE,KAAK,KAAI,aAAa;YACrD,EAAE,EAAE,YAAY,CAAC,EAAE;SACpB,CAAA;KACF;AACH,CAAC,CAAA;AAED,MAAM,qBAAqB,GAAG,CAAC,YAAqC,EAAE,EAAE;IACtE,OAAO,OAAO,CAAC,GAAG,EAAE;QAClB,MAAM,8BAA8B,GAI/B,EAAE,CAAA;QACP,MAAM,4BAA4B,GAI7B,EAAE,CAAA;QACP,mBAAmB,CAAC,kBAAkB,CAAC,YAAY,IAAI,EAAE,EAAE,CAAC,OAAO,EAAE,EAAE;YACrE,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACnD,IAAI,iBAAiB,EAAE;gBACrB,8BAA8B,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAA;aACvD;YAED,MAAM,UAAU,GAAG,SAAS,CAAC,OAAO,CAAC,CAAA;YACrC,IAAI,UAAU,EAAE;gBACd,4BAA4B,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;aAC9C;QACH,CAAC,CAAC,CAAA;QACF,OAAO;YACL,8BAA8B;YAC9B,4BAA4B;SAC7B,CAAA;IACH,CAAC,EAAE,CAAC,YAAY,CAAC,CAAC,CAAA;AACpB,CAAC,CAAA;AAED,eAAe,qBAAqB,CAAA;AAEpC,MAAM,8BAA8B,GAClC,4CAA4C,CAAA;AAC9C,MAAM,CAAC,MAAM,iCAAiC,GAAG,CAC/C,WAAkC,EAClC,EAAE;IACF,OAAO,OAAO,CAAqB,GAAG,EAAE;QACtC,IAAI,gBAAgB,CAAC,WAAW,CAAC,IAAI,SAAS,CAAC,WAAW,CAAC,EAAE;YAC3D,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAA;AACnB,CAAC,CAAA","sourcesContent":["import { useMemo } from 'react'\nimport { formElementsService, typeCastService } from '@oneblink/sdk-core'\nimport { FormTypes } from '@oneblink/types'\n\nexport const legacyNameRegex = /[^a-zA-Z\\d_-]/\n\nconst checkStorageType = (element: FormTypes.FormElement) => {\n const storageElement = typeCastService.formElements.toStorageElement(element)\n if (\n storageElement &&\n (!storageElement.storageType || storageElement.storageType === 'legacy')\n ) {\n return {\n label: storageElement.label,\n name: storageElement.name,\n id: storageElement.id,\n }\n }\n}\n\nconst checkName = (element: FormTypes.FormElement) => {\n const namedElement: FormTypes.FormElementWithName | undefined =\n typeCastService.formElements.toNamedElement(element)\n if (!!namedElement && legacyNameRegex.test(namedElement.name)) {\n const formElementWithoutForm =\n typeCastService.formElements.toFormElementWithoutForm(namedElement)\n return {\n name: namedElement.name,\n label: formElementWithoutForm?.label || 'Nested Form',\n id: namedElement.id,\n }\n }\n}\n\nconst useLegacyFormElements = (formElements: FormTypes.FormElement[]) => {\n return useMemo(() => {\n const formElementsUsingLegacyStorage: Array<{\n name: string\n label: string\n id: string\n }> = []\n const formElementsUsingLegacyNames: Array<{\n name: string\n label: string\n id: string\n }> = []\n formElementsService.forEachFormElement(formElements || [], (element) => {\n const legacyStorageType = checkStorageType(element)\n if (legacyStorageType) {\n formElementsUsingLegacyStorage.push(legacyStorageType)\n }\n\n const legacyName = checkName(element)\n if (legacyName) {\n formElementsUsingLegacyNames.push(legacyName)\n }\n })\n return {\n formElementsUsingLegacyStorage,\n formElementsUsingLegacyNames,\n }\n }, [formElements])\n}\n\nexport default useLegacyFormElements\n\nconst formElementLegacyConfigMessage =\n 'Element is using unsupported configuration'\nexport const useFormElementLegacyConfigMessage = (\n formElement: FormTypes.FormElement,\n) => {\n return useMemo<string | undefined>(() => {\n if (checkStorageType(formElement) || checkName(formElement)) {\n return formElementLegacyConfigMessage\n }\n }, [formElement])\n}\n"]}
|
@@ -1,6 +0,0 @@
|
|
1
|
-
import { FormTypes } from '@oneblink/types';
|
2
|
-
declare const useToggleAll: (element: FormTypes.CheckboxElement | FormTypes.SelectElement, filteredOptions: FormTypes.ChoiceElementOption[], selectedValues: string[], onChange: FormElementValueChangeHandler<string[]>) => {
|
3
|
-
allOptionsAreSelected: boolean;
|
4
|
-
handleToggleAll: (isSelectingAll: boolean) => void;
|
5
|
-
};
|
6
|
-
export default useToggleAll;
|
@@ -1,24 +0,0 @@
|
|
1
|
-
import * as React from 'react';
|
2
|
-
const useToggleAll = (element, filteredOptions, selectedValues, onChange) => {
|
3
|
-
const allOptionsAreSelected = React.useMemo(() => {
|
4
|
-
return filteredOptions.every((option) => {
|
5
|
-
return selectedValues.includes(option.value);
|
6
|
-
});
|
7
|
-
}, [filteredOptions, selectedValues]);
|
8
|
-
const handleToggleAll = React.useCallback((isSelectingAll) => {
|
9
|
-
if (isSelectingAll) {
|
10
|
-
onChange(element, filteredOptions.map((opt) => opt.value));
|
11
|
-
}
|
12
|
-
else {
|
13
|
-
onChange(element, undefined);
|
14
|
-
}
|
15
|
-
}, [element, filteredOptions, onChange]);
|
16
|
-
return React.useMemo(() => {
|
17
|
-
return {
|
18
|
-
allOptionsAreSelected,
|
19
|
-
handleToggleAll,
|
20
|
-
};
|
21
|
-
}, [allOptionsAreSelected, handleToggleAll]);
|
22
|
-
};
|
23
|
-
export default useToggleAll;
|
24
|
-
//# sourceMappingURL=useToggleAll.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"useToggleAll.js","sourceRoot":"","sources":["../../src/hooks/useToggleAll.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,MAAM,YAAY,GAAG,CACnB,OAA4D,EAC5D,eAAgD,EAChD,cAAwB,EACxB,QAAiD,EACjD,EAAE;IACF,MAAM,qBAAqB,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QAC/C,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE;YACtC,OAAO,cAAc,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC9C,CAAC,CAAC,CAAA;IACJ,CAAC,EAAE,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC,CAAA;IAErC,MAAM,eAAe,GAAG,KAAK,CAAC,WAAW,CACvC,CAAC,cAAuB,EAAE,EAAE;QAC1B,IAAI,cAAc,EAAE;YAClB,QAAQ,CACN,OAAO,EACP,eAAe,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,CACxC,CAAA;SACF;aAAM;YACL,QAAQ,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;SAC7B;IACH,CAAC,EACD,CAAC,OAAO,EAAE,eAAe,EAAE,QAAQ,CAAC,CACrC,CAAA;IAED,OAAO,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE;QACxB,OAAO;YACL,qBAAqB;YACrB,eAAe;SAChB,CAAA;IACH,CAAC,EAAE,CAAC,qBAAqB,EAAE,eAAe,CAAC,CAAC,CAAA;AAC9C,CAAC,CAAA;AAED,eAAe,YAAY,CAAA","sourcesContent":["import * as React from 'react'\nimport { FormTypes } from '@oneblink/types'\nconst useToggleAll = (\n element: FormTypes.CheckboxElement | FormTypes.SelectElement,\n filteredOptions: FormTypes.ChoiceElementOption[],\n selectedValues: string[],\n onChange: FormElementValueChangeHandler<string[]>,\n) => {\n const allOptionsAreSelected = React.useMemo(() => {\n return filteredOptions.every((option) => {\n return selectedValues.includes(option.value)\n })\n }, [filteredOptions, selectedValues])\n\n const handleToggleAll = React.useCallback(\n (isSelectingAll: boolean) => {\n if (isSelectingAll) {\n onChange(\n element,\n filteredOptions.map((opt) => opt.value),\n )\n } else {\n onChange(element, undefined)\n }\n },\n [element, filteredOptions, onChange],\n )\n\n return React.useMemo(() => {\n return {\n allOptionsAreSelected,\n handleToggleAll,\n }\n }, [allOptionsAreSelected, handleToggleAll])\n}\n\nexport default useToggleAll\n"]}
|
@@ -1,58 +0,0 @@
|
|
1
|
-
function checkIfAttachmentsAreUploadingForFormElements(formElements, submission) {
|
2
|
-
return formElements.some((formElement) => {
|
3
|
-
var _a;
|
4
|
-
switch (formElement.type) {
|
5
|
-
case 'section':
|
6
|
-
case 'page': {
|
7
|
-
return checkIfAttachmentsAreUploadingForFormElements(formElement.elements, submission);
|
8
|
-
}
|
9
|
-
case 'form': {
|
10
|
-
const nestedSubmission = submission[formElement.name];
|
11
|
-
if (!nestedSubmission || typeof nestedSubmission !== 'object') {
|
12
|
-
break;
|
13
|
-
}
|
14
|
-
return checkIfAttachmentsAreUploadingForFormElements(formElement.elements || [], nestedSubmission);
|
15
|
-
}
|
16
|
-
case 'repeatableSet': {
|
17
|
-
const entries = submission[formElement.name];
|
18
|
-
if (!Array.isArray(entries)) {
|
19
|
-
break;
|
20
|
-
}
|
21
|
-
return entries.some((entry) => {
|
22
|
-
return (typeof entry === 'object' &&
|
23
|
-
checkIfAttachmentsAreUploadingForFormElements(formElement.elements, entry));
|
24
|
-
});
|
25
|
-
}
|
26
|
-
case 'camera':
|
27
|
-
case 'draw':
|
28
|
-
case 'compliance':
|
29
|
-
case 'files': {
|
30
|
-
const value = submission[formElement.name];
|
31
|
-
if (!value) {
|
32
|
-
break;
|
33
|
-
}
|
34
|
-
// If the attachment has a type, it has not finished uploading
|
35
|
-
switch (formElement.type) {
|
36
|
-
case 'camera':
|
37
|
-
case 'draw': {
|
38
|
-
return !!(value === null || value === void 0 ? void 0 : value.type);
|
39
|
-
}
|
40
|
-
case 'compliance': {
|
41
|
-
return (_a = value.files) === null || _a === void 0 ? void 0 : _a.some((file) => {
|
42
|
-
return !!(file === null || file === void 0 ? void 0 : file.type);
|
43
|
-
});
|
44
|
-
}
|
45
|
-
case 'files': {
|
46
|
-
return value === null || value === void 0 ? void 0 : value.some((attachment) => {
|
47
|
-
return !!(attachment === null || attachment === void 0 ? void 0 : attachment.type);
|
48
|
-
});
|
49
|
-
}
|
50
|
-
}
|
51
|
-
}
|
52
|
-
}
|
53
|
-
});
|
54
|
-
}
|
55
|
-
export default function checkIfAttachmentsAreUploading(form, submission) {
|
56
|
-
return checkIfAttachmentsAreUploadingForFormElements(form.elements, submission);
|
57
|
-
}
|
58
|
-
//# sourceMappingURL=checkIfAttachmentsAreUploading.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"checkIfAttachmentsAreUploading.js","sourceRoot":"","sources":["../../src/services/checkIfAttachmentsAreUploading.ts"],"names":[],"mappings":"AAKA,SAAS,6CAA6C,CACpD,YAAqC,EACrC,UAA+B;IAE/B,OAAO,YAAY,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,EAAE;;QACvC,QAAQ,WAAW,CAAC,IAAI,EAAE;YACxB,KAAK,SAAS,CAAC;YACf,KAAK,MAAM,CAAC,CAAC;gBACX,OAAO,6CAA6C,CAClD,WAAW,CAAC,QAAQ,EACpB,UAAU,CACX,CAAA;aACF;YACD,KAAK,MAAM,CAAC,CAAC;gBACX,MAAM,gBAAgB,GAAG,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;gBACrD,IAAI,CAAC,gBAAgB,IAAI,OAAO,gBAAgB,KAAK,QAAQ,EAAE;oBAC7D,MAAK;iBACN;gBACD,OAAO,6CAA6C,CAClD,WAAW,CAAC,QAAQ,IAAI,EAAE,EAC1B,gBAAuC,CACxC,CAAA;aACF;YACD,KAAK,eAAe,CAAC,CAAC;gBACpB,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;gBAC5C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;oBAC3B,MAAK;iBACN;gBACD,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;oBAC5B,OAAO,CACL,OAAO,KAAK,KAAK,QAAQ;wBACzB,6CAA6C,CAC3C,WAAW,CAAC,QAAQ,EACpB,KAAK,CACN,CACF,CAAA;gBACH,CAAC,CAAC,CAAA;aACH;YACD,KAAK,QAAQ,CAAC;YACd,KAAK,MAAM,CAAC;YACZ,KAAK,YAAY,CAAC;YAClB,KAAK,OAAO,CAAC,CAAC;gBACZ,MAAM,KAAK,GAAG,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;gBAC1C,IAAI,CAAC,KAAK,EAAE;oBACV,MAAK;iBACN;gBAED,8DAA8D;gBAC9D,QAAQ,WAAW,CAAC,IAAI,EAAE;oBACxB,KAAK,QAAQ,CAAC;oBACd,KAAK,MAAM,CAAC,CAAC;wBACX,OAAO,CAAC,CAAC,CAAC,KAAoB,aAApB,KAAK,uBAAL,KAAK,CAAiB,IAAI,CAAA,CAAA;qBACrC;oBACD,KAAK,YAAY,CAAC,CAAC;wBACjB,OAAO,MAAC,KAAoC,CAAC,KAAK,0CAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;4BAChE,OAAO,CAAC,CAAC,CAAC,IAAmB,aAAnB,IAAI,uBAAJ,IAAI,CAAiB,IAAI,CAAA,CAAA;wBACrC,CAAC,CAAC,CAAA;qBACH;oBACD,KAAK,OAAO,CAAC,CAAC;wBACZ,OAAQ,KAAsB,aAAtB,KAAK,uBAAL,KAAK,CAAmB,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE;4BAClD,OAAO,CAAC,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI,CAAA,CAAA;wBAC3B,CAAC,CAAC,CAAA;qBACH;iBACF;aACF;SACF;IACH,CAAC,CAAC,CAAA;AACJ,CAAC;AAED,MAAM,CAAC,OAAO,UAAU,8BAA8B,CACpD,IAAoB,EACpB,UAA+B;IAE/B,OAAO,6CAA6C,CAClD,IAAI,CAAC,QAAQ,EACb,UAAU,CACX,CAAA;AACH,CAAC","sourcesContent":["import { FormTypes } from '@oneblink/types'\nimport { Attachment } from '../types/attachments'\nimport { Value as FormElementComplianceValue } from '../form-elements/FormElementCompliance'\nimport { FormSubmissionModel } from '../types/form'\n\nfunction checkIfAttachmentsAreUploadingForFormElements(\n formElements: FormTypes.FormElement[],\n submission: FormSubmissionModel,\n): boolean {\n return formElements.some((formElement) => {\n switch (formElement.type) {\n case 'section':\n case 'page': {\n return checkIfAttachmentsAreUploadingForFormElements(\n formElement.elements,\n submission,\n )\n }\n case 'form': {\n const nestedSubmission = submission[formElement.name]\n if (!nestedSubmission || typeof nestedSubmission !== 'object') {\n break\n }\n return checkIfAttachmentsAreUploadingForFormElements(\n formElement.elements || [],\n nestedSubmission as FormSubmissionModel,\n )\n }\n case 'repeatableSet': {\n const entries = submission[formElement.name]\n if (!Array.isArray(entries)) {\n break\n }\n return entries.some((entry) => {\n return (\n typeof entry === 'object' &&\n checkIfAttachmentsAreUploadingForFormElements(\n formElement.elements,\n entry,\n )\n )\n })\n }\n case 'camera':\n case 'draw':\n case 'compliance':\n case 'files': {\n const value = submission[formElement.name]\n if (!value) {\n break\n }\n\n // If the attachment has a type, it has not finished uploading\n switch (formElement.type) {\n case 'camera':\n case 'draw': {\n return !!(value as Attachment)?.type\n }\n case 'compliance': {\n return (value as FormElementComplianceValue).files?.some((file) => {\n return !!(file as Attachment)?.type\n })\n }\n case 'files': {\n return (value as Attachment[])?.some((attachment) => {\n return !!attachment?.type\n })\n }\n }\n }\n }\n })\n}\n\nexport default function checkIfAttachmentsAreUploading(\n form: FormTypes.Form,\n submission: FormSubmissionModel,\n): boolean {\n return checkIfAttachmentsAreUploadingForFormElements(\n form.elements,\n submission,\n )\n}\n"]}
|
@@ -1,166 +0,0 @@
|
|
1
|
-
function cleanElementValue(formElementsCtrl, formElementsConditionallyShown, stripBinaryData, captchaTokens) {
|
2
|
-
// Clear data from submission on fields that are hidden on visible pages
|
3
|
-
return formElementsCtrl.elements.reduce((model, element) => {
|
4
|
-
var _a, _b, _c, _d, _e, _f;
|
5
|
-
switch (element.type) {
|
6
|
-
// For content element types, we just need to set true for shown and false for hidden.
|
7
|
-
// This is to allow renderers of the data to know when to show/hide the content
|
8
|
-
case 'image':
|
9
|
-
case 'heading':
|
10
|
-
case 'html': {
|
11
|
-
if (!stripBinaryData &&
|
12
|
-
((_a = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _a === void 0 ? void 0 : _a.isShown) !== false) {
|
13
|
-
model[element.name] = true;
|
14
|
-
}
|
15
|
-
break;
|
16
|
-
}
|
17
|
-
// Need to remove captcha tokens and save
|
18
|
-
// them to POST them to the server for validation
|
19
|
-
case 'captcha': {
|
20
|
-
const token = formElementsCtrl.model[element.name];
|
21
|
-
if (typeof token === 'string') {
|
22
|
-
captchaTokens.push(token);
|
23
|
-
model[element.name] = token;
|
24
|
-
}
|
25
|
-
break;
|
26
|
-
}
|
27
|
-
case 'camera':
|
28
|
-
case 'files':
|
29
|
-
case 'file':
|
30
|
-
case 'draw': {
|
31
|
-
if (!stripBinaryData &&
|
32
|
-
((_b = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _b === void 0 ? void 0 : _b.isShown) !== false) {
|
33
|
-
model[element.name] = formElementsCtrl.model[element.name];
|
34
|
-
}
|
35
|
-
break;
|
36
|
-
}
|
37
|
-
case 'infoPage':
|
38
|
-
case 'form': {
|
39
|
-
// Here we will check to make sure that each embedded form
|
40
|
-
// also has its values wiped if the element is hidden based on conditional logic
|
41
|
-
const nestedElements = element.elements;
|
42
|
-
const nestedModel = formElementsCtrl.model[element.name];
|
43
|
-
const nestedFormElementConditionallyShown = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name];
|
44
|
-
if (((_c = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _c === void 0 ? void 0 : _c.isShown) !== false &&
|
45
|
-
Array.isArray(nestedElements) &&
|
46
|
-
nestedElements.length &&
|
47
|
-
nestedModel) {
|
48
|
-
model[element.name] = cleanElementValue({
|
49
|
-
elements: nestedElements,
|
50
|
-
model: nestedModel,
|
51
|
-
parentFormElementsCtrl: formElementsCtrl,
|
52
|
-
}, (nestedFormElementConditionallyShown === null || nestedFormElementConditionallyShown === void 0 ? void 0 : nestedFormElementConditionallyShown.type) === 'formElements'
|
53
|
-
? nestedFormElementConditionallyShown.formElements
|
54
|
-
: undefined, stripBinaryData, captchaTokens);
|
55
|
-
}
|
56
|
-
break;
|
57
|
-
}
|
58
|
-
case 'repeatableSet': {
|
59
|
-
// Here we will check to make sure that each repeatable set entry
|
60
|
-
// also has its values wiped if the element is hidden based on conditional logic
|
61
|
-
const nestedElements = element.elements;
|
62
|
-
const entries = formElementsCtrl.model[element.name];
|
63
|
-
const formElementConditionallyShown = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name];
|
64
|
-
if ((formElementConditionallyShown === null || formElementConditionallyShown === void 0 ? void 0 : formElementConditionallyShown.isShown) !== false &&
|
65
|
-
Array.isArray(nestedElements) &&
|
66
|
-
Array.isArray(entries) &&
|
67
|
-
entries.length) {
|
68
|
-
model[element.name] = entries.map((entry, index) => {
|
69
|
-
var _a;
|
70
|
-
return cleanElementValue({
|
71
|
-
elements: nestedElements,
|
72
|
-
model: entry || {},
|
73
|
-
parentFormElementsCtrl: formElementsCtrl,
|
74
|
-
}, (formElementConditionallyShown === null || formElementConditionallyShown === void 0 ? void 0 : formElementConditionallyShown.type) === 'repeatableSet'
|
75
|
-
? (_a = formElementConditionallyShown.entries) === null || _a === void 0 ? void 0 : _a[index.toString()]
|
76
|
-
: undefined, stripBinaryData, captchaTokens);
|
77
|
-
});
|
78
|
-
}
|
79
|
-
break;
|
80
|
-
}
|
81
|
-
case 'civicaNameRecord': {
|
82
|
-
const civicaNameRecord = formElementsCtrl.model[element.name];
|
83
|
-
if (((_d = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _d === void 0 ? void 0 : _d.isShown) === false ||
|
84
|
-
!civicaNameRecord) {
|
85
|
-
break;
|
86
|
-
}
|
87
|
-
for (const key in civicaNameRecord) {
|
88
|
-
if (civicaNameRecord[key] ===
|
89
|
-
undefined) {
|
90
|
-
continue;
|
91
|
-
}
|
92
|
-
if (!element.useGeoscapeAddressing ||
|
93
|
-
!Array.isArray(civicaNameRecord.streetAddress)) {
|
94
|
-
model[element.name] = civicaNameRecord;
|
95
|
-
break;
|
96
|
-
}
|
97
|
-
const streetAddresses = civicaNameRecord.streetAddress.map((streetAddress) => {
|
98
|
-
var _a, _b, _c, _d, _e;
|
99
|
-
if (typeof streetAddress.address1 === 'object') {
|
100
|
-
const geoscapeAddress = streetAddress.address1;
|
101
|
-
return {
|
102
|
-
address1: [
|
103
|
-
(_a = geoscapeAddress === null || geoscapeAddress === void 0 ? void 0 : geoscapeAddress.addressDetails) === null || _a === void 0 ? void 0 : _a.streetNumber1,
|
104
|
-
(_b = geoscapeAddress === null || geoscapeAddress === void 0 ? void 0 : geoscapeAddress.addressDetails) === null || _b === void 0 ? void 0 : _b.streetName,
|
105
|
-
(_c = geoscapeAddress === null || geoscapeAddress === void 0 ? void 0 : geoscapeAddress.addressDetails) === null || _c === void 0 ? void 0 : _c.streetType,
|
106
|
-
]
|
107
|
-
.filter((str) => !!str)
|
108
|
-
.join(' '),
|
109
|
-
address2: (_d = geoscapeAddress === null || geoscapeAddress === void 0 ? void 0 : geoscapeAddress.addressDetails) === null || _d === void 0 ? void 0 : _d.localityName,
|
110
|
-
postcode: (_e = geoscapeAddress === null || geoscapeAddress === void 0 ? void 0 : geoscapeAddress.addressDetails) === null || _e === void 0 ? void 0 : _e.postcode,
|
111
|
-
};
|
112
|
-
}
|
113
|
-
return streetAddress;
|
114
|
-
});
|
115
|
-
model[element.name] = {
|
116
|
-
...civicaNameRecord,
|
117
|
-
streetAddress: streetAddresses,
|
118
|
-
};
|
119
|
-
}
|
120
|
-
break;
|
121
|
-
}
|
122
|
-
case 'compliance': {
|
123
|
-
if (((_e = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _e === void 0 ? void 0 : _e.isShown) === false ||
|
124
|
-
!formElementsCtrl.model[element.name]) {
|
125
|
-
break;
|
126
|
-
}
|
127
|
-
if (stripBinaryData) {
|
128
|
-
model[element.name] = {
|
129
|
-
...formElementsCtrl.model[element.name],
|
130
|
-
files: undefined,
|
131
|
-
};
|
132
|
-
}
|
133
|
-
else {
|
134
|
-
model[element.name] = formElementsCtrl.model[element.name];
|
135
|
-
}
|
136
|
-
break;
|
137
|
-
}
|
138
|
-
case 'page':
|
139
|
-
case 'section': {
|
140
|
-
const nestedModel = cleanElementValue({
|
141
|
-
elements: element.elements,
|
142
|
-
model: formElementsCtrl.model,
|
143
|
-
parentFormElementsCtrl: formElementsCtrl.parentFormElementsCtrl,
|
144
|
-
}, formElementsConditionallyShown, stripBinaryData, captchaTokens);
|
145
|
-
Object.assign(model, nestedModel);
|
146
|
-
break;
|
147
|
-
}
|
148
|
-
default: {
|
149
|
-
if (((_f = formElementsConditionallyShown === null || formElementsConditionallyShown === void 0 ? void 0 : formElementsConditionallyShown[element.name]) === null || _f === void 0 ? void 0 : _f.isShown) !== false) {
|
150
|
-
model[element.name] = formElementsCtrl.model[element.name];
|
151
|
-
}
|
152
|
-
}
|
153
|
-
}
|
154
|
-
return model;
|
155
|
-
}, {});
|
156
|
-
}
|
157
|
-
export default function cleanFormElementsCtrlModel(formElementsCtrl, formElementsConditionallyShown, stripBinaryData) {
|
158
|
-
// Clear data from submission on fields that are hidden on visible pages
|
159
|
-
const captchaTokens = [];
|
160
|
-
const model = cleanElementValue(formElementsCtrl, formElementsConditionallyShown, stripBinaryData, captchaTokens);
|
161
|
-
return {
|
162
|
-
model,
|
163
|
-
captchaTokens,
|
164
|
-
};
|
165
|
-
}
|
166
|
-
//# sourceMappingURL=clean-form-elements-ctrl-model.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"clean-form-elements-ctrl-model.js","sourceRoot":"","sources":["../../src/services/clean-form-elements-ctrl-model.ts"],"names":[],"mappings":"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","sourcesContent":["import { CivicaTypes, GeoscapeTypes } from '@oneblink/types'\nimport { Value as ComplianceValue } from '../form-elements/FormElementCompliance'\n\nfunction cleanElementValue(\n formElementsCtrl: FormElementsCtrl,\n formElementsConditionallyShown: FormElementsConditionallyShown | undefined,\n stripBinaryData: boolean,\n captchaTokens: string[],\n): FormElementsCtrl['model'] {\n // Clear data from submission on fields that are hidden on visible pages\n return formElementsCtrl.elements.reduce<FormElementsCtrl['model']>(\n (model, element) => {\n switch (element.type) {\n // For content element types, we just need to set true for shown and false for hidden.\n // This is to allow renderers of the data to know when to show/hide the content\n case 'image':\n case 'heading':\n case 'html': {\n if (\n !stripBinaryData &&\n formElementsConditionallyShown?.[element.name]?.isShown !== false\n ) {\n model[element.name] = true\n }\n break\n }\n // Need to remove captcha tokens and save\n // them to POST them to the server for validation\n case 'captcha': {\n const token = formElementsCtrl.model[element.name]\n if (typeof token === 'string') {\n captchaTokens.push(token)\n model[element.name] = token\n }\n break\n }\n case 'camera':\n case 'files':\n case 'file':\n case 'draw': {\n if (\n !stripBinaryData &&\n formElementsConditionallyShown?.[element.name]?.isShown !== false\n ) {\n model[element.name] = formElementsCtrl.model[element.name]\n }\n break\n }\n case 'infoPage':\n case 'form': {\n // Here we will check to make sure that each embedded form\n // also has its values wiped if the element is hidden based on conditional logic\n const nestedElements = element.elements\n const nestedModel = formElementsCtrl.model[element.name] as\n | FormElementsCtrl['model']\n | undefined\n const nestedFormElementConditionallyShown =\n formElementsConditionallyShown?.[element.name]\n if (\n formElementsConditionallyShown?.[element.name]?.isShown !== false &&\n Array.isArray(nestedElements) &&\n nestedElements.length &&\n nestedModel\n ) {\n model[element.name] = cleanElementValue(\n {\n elements: nestedElements,\n model: nestedModel,\n parentFormElementsCtrl: formElementsCtrl,\n },\n nestedFormElementConditionallyShown?.type === 'formElements'\n ? nestedFormElementConditionallyShown.formElements\n : undefined,\n stripBinaryData,\n captchaTokens,\n )\n }\n break\n }\n case 'repeatableSet': {\n // Here we will check to make sure that each repeatable set entry\n // also has its values wiped if the element is hidden based on conditional logic\n const nestedElements = element.elements\n const entries = formElementsCtrl.model[element.name] as\n | Array<FormElementsCtrl['model']>\n | undefined\n const formElementConditionallyShown =\n formElementsConditionallyShown?.[element.name]\n if (\n formElementConditionallyShown?.isShown !== false &&\n Array.isArray(nestedElements) &&\n Array.isArray(entries) &&\n entries.length\n ) {\n model[element.name] = entries.map((entry, index) => {\n return cleanElementValue(\n {\n elements: nestedElements,\n model: entry || {},\n parentFormElementsCtrl: formElementsCtrl,\n },\n formElementConditionallyShown?.type === 'repeatableSet'\n ? formElementConditionallyShown.entries?.[index.toString()]\n : undefined,\n stripBinaryData,\n captchaTokens,\n )\n })\n }\n break\n }\n case 'civicaNameRecord': {\n const civicaNameRecord = formElementsCtrl.model[element.name] as\n | CivicaTypes.CivicaNameRecord\n | undefined\n if (\n formElementsConditionallyShown?.[element.name]?.isShown === false ||\n !civicaNameRecord\n ) {\n break\n }\n\n for (const key in civicaNameRecord) {\n if (\n civicaNameRecord[key as keyof CivicaTypes.CivicaNameRecord] ===\n undefined\n ) {\n continue\n }\n\n if (\n !element.useGeoscapeAddressing ||\n !Array.isArray(civicaNameRecord.streetAddress)\n ) {\n model[element.name] = civicaNameRecord\n break\n }\n\n const streetAddresses = civicaNameRecord.streetAddress.map(\n (streetAddress) => {\n if (typeof streetAddress.address1 === 'object') {\n const geoscapeAddress = streetAddress.address1 as\n | GeoscapeTypes.GeoscapeAddress\n | undefined\n return {\n address1: [\n geoscapeAddress?.addressDetails?.streetNumber1,\n geoscapeAddress?.addressDetails?.streetName,\n geoscapeAddress?.addressDetails?.streetType,\n ]\n .filter((str) => !!str)\n .join(' '),\n address2: geoscapeAddress?.addressDetails?.localityName,\n postcode: geoscapeAddress?.addressDetails?.postcode,\n }\n }\n return streetAddress\n },\n )\n model[element.name] = {\n ...civicaNameRecord,\n streetAddress: streetAddresses,\n }\n }\n break\n }\n case 'compliance': {\n if (\n formElementsConditionallyShown?.[element.name]?.isShown === false ||\n !formElementsCtrl.model[element.name]\n ) {\n break\n }\n if (stripBinaryData) {\n model[element.name] = {\n ...(formElementsCtrl.model[element.name] as ComplianceValue),\n files: undefined,\n }\n } else {\n model[element.name] = formElementsCtrl.model[element.name]\n }\n break\n }\n case 'page':\n case 'section': {\n const nestedModel = cleanElementValue(\n {\n elements: element.elements,\n model: formElementsCtrl.model,\n parentFormElementsCtrl: formElementsCtrl.parentFormElementsCtrl,\n },\n formElementsConditionallyShown,\n stripBinaryData,\n captchaTokens,\n )\n Object.assign(model, nestedModel)\n break\n }\n default: {\n if (\n formElementsConditionallyShown?.[element.name]?.isShown !== false\n ) {\n model[element.name] = formElementsCtrl.model[element.name]\n }\n }\n }\n\n return model\n },\n {},\n )\n}\n\nexport default function cleanFormElementsCtrlModel(\n formElementsCtrl: FormElementsCtrl,\n formElementsConditionallyShown: FormElementsConditionallyShown | undefined,\n stripBinaryData: boolean,\n): {\n model: FormElementsCtrl['model']\n captchaTokens: string[]\n} {\n // Clear data from submission on fields that are hidden on visible pages\n const captchaTokens: string[] = []\n const model = cleanElementValue(\n formElementsCtrl,\n formElementsConditionallyShown,\n stripBinaryData,\n captchaTokens,\n )\n return {\n model,\n captchaTokens,\n }\n}\n"]}
|
@@ -1,11 +0,0 @@
|
|
1
|
-
import { FormTypes } from '@oneblink/types';
|
2
|
-
import { FormSubmissionModel } from '../types/form';
|
3
|
-
export declare type FormElementsCtrl = {
|
4
|
-
model: FormSubmissionModel;
|
5
|
-
flattenedElements: import('@oneblink/types').FormTypes.FormElement[];
|
6
|
-
parentFormElementsCtrl?: FormElementsCtrl;
|
7
|
-
};
|
8
|
-
export default function conditionallyShowElement(formElementsCtrl: FormElementsCtrl, elementToEvaluate: FormTypes.FormElement, elementsEvaluated: Array<{
|
9
|
-
id: string;
|
10
|
-
label: string;
|
11
|
-
}>): boolean;
|