@oneblink/apps-react 2.3.0-beta.2 → 2.3.0-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (455) hide show
  1. package/dist/OneBlinkAutoSaveForm.d.ts +10 -10
  2. package/dist/OneBlinkAutoSaveForm.js +28 -28
  3. package/dist/OneBlinkForm.d.ts +11 -11
  4. package/dist/OneBlinkForm.js +11 -11
  5. package/dist/OneBlinkFormBase.d.ts +29 -28
  6. package/dist/OneBlinkFormBase.js +479 -472
  7. package/dist/OneBlinkFormBase.js.map +1 -1
  8. package/dist/OneBlinkReadOnlyForm.d.ts +11 -11
  9. package/dist/OneBlinkReadOnlyForm.js +48 -48
  10. package/dist/components/CopyToClipboardIconButton.d.ts +10 -10
  11. package/dist/components/CopyToClipboardIconButton.js +32 -32
  12. package/dist/components/CustomAccordion.d.ts +27 -27
  13. package/dist/components/CustomAccordion.js +37 -37
  14. package/dist/components/ErrorSnackbar.d.ts +8 -8
  15. package/dist/components/ErrorSnackbar.js +25 -25
  16. package/dist/components/Lists.d.ts +25 -25
  17. package/dist/components/Lists.js +44 -44
  18. package/dist/components/LoadingWithMessage.d.ts +6 -6
  19. package/dist/components/LoadingWithMessage.js +11 -11
  20. package/dist/components/formStore/FormStoreTableProvider.d.ts +6 -6
  21. package/dist/components/formStore/FormStoreTableProvider.js +90 -90
  22. package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.d.ts +5 -5
  23. package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.js +19 -19
  24. package/dist/components/formStore/OneBlinkFormStoreColumnsButton.d.ts +5 -5
  25. package/dist/components/formStore/OneBlinkFormStoreColumnsButton.js +66 -66
  26. package/dist/components/formStore/OneBlinkFormStoreDownloadButton.d.ts +5 -5
  27. package/dist/components/formStore/OneBlinkFormStoreDownloadButton.js +86 -86
  28. package/dist/components/formStore/OneBlinkFormStoreProvider.d.ts +8 -8
  29. package/dist/components/formStore/OneBlinkFormStoreProvider.js +24 -24
  30. package/dist/components/formStore/OneBlinkFormStoreRefreshButton.d.ts +5 -5
  31. package/dist/components/formStore/OneBlinkFormStoreRefreshButton.js +11 -11
  32. package/dist/components/formStore/OneBlinkFormStoreTable.d.ts +4 -4
  33. package/dist/components/formStore/OneBlinkFormStoreTable.js +194 -194
  34. package/dist/components/formStore/display/ElementDisplay.d.ts +23 -23
  35. package/dist/components/formStore/display/ElementDisplay.js +77 -77
  36. package/dist/components/formStore/display/FormStoreIcon.d.ts +2 -2
  37. package/dist/components/formStore/display/FormStoreIcon.js +2 -2
  38. package/dist/components/formStore/table/ActionedByTableCell.d.ts +11 -11
  39. package/dist/components/formStore/table/ActionedByTableCell.js +43 -43
  40. package/dist/components/formStore/table/ColumnFilters.d.ts +9 -9
  41. package/dist/components/formStore/table/ColumnFilters.js +179 -179
  42. package/dist/components/formStore/table/FormElementTableCell.d.ts +10 -10
  43. package/dist/components/formStore/table/FormElementTableCell.js +228 -228
  44. package/dist/components/formStore/table/HeaderCellMoreButton.d.ts +9 -9
  45. package/dist/components/formStore/table/HeaderCellMoreButton.js +48 -48
  46. package/dist/components/formStore/table/RepeatableSetCell.d.ts +8 -8
  47. package/dist/components/formStore/table/RepeatableSetCell.js +62 -62
  48. package/dist/components/formStore/table/RepeatableSetCellAccordion.d.ts +9 -9
  49. package/dist/components/formStore/table/RepeatableSetCellAccordion.js +11 -11
  50. package/dist/components/formStore/table/TableCellCopyButton.d.ts +7 -7
  51. package/dist/components/formStore/table/TableCellCopyButton.js +27 -27
  52. package/dist/components/formStore/table/generateColumns.d.ts +24 -24
  53. package/dist/components/formStore/table/generateColumns.js +290 -290
  54. package/dist/components/formStore/table/useFormStoreTable.d.ts +52 -52
  55. package/dist/components/formStore/table/useFormStoreTable.js +157 -157
  56. package/dist/components/formStore/useFormStoreTableContext.d.ts +44 -44
  57. package/dist/components/formStore/useFormStoreTableContext.js +9 -9
  58. package/dist/components/messages/ErrorMessage.d.ts +12 -12
  59. package/dist/components/messages/ErrorMessage.js +12 -12
  60. package/dist/components/messages/LargeIconMessage.d.ts +18 -18
  61. package/dist/components/messages/LargeIconMessage.js +33 -33
  62. package/dist/components/messages/NoResourcesYet.d.ts +11 -11
  63. package/dist/components/messages/NoResourcesYet.js +6 -6
  64. package/dist/components/pickers/V4CompatibleDatePicker.d.ts +32 -32
  65. package/dist/components/pickers/V4CompatibleDatePicker.js +70 -70
  66. package/dist/components/pickers/V4CompatibleDateTimePicker.d.ts +32 -32
  67. package/dist/components/pickers/V4CompatibleDateTimePicker.js +70 -70
  68. package/dist/components/pickers/V4CompatibleTimePicker.d.ts +28 -28
  69. package/dist/components/pickers/V4CompatibleTimePicker.js +53 -53
  70. package/dist/components/renderer/AnnotationModal.d.ts +8 -8
  71. package/dist/components/renderer/AnnotationModal.js +101 -101
  72. package/dist/components/renderer/AutocompleteDropdown.d.ts +26 -26
  73. package/dist/components/renderer/AutocompleteDropdown.js +175 -175
  74. package/dist/components/renderer/CopyToClipboardButton.d.ts +8 -8
  75. package/dist/components/renderer/CopyToClipboardButton.js +13 -13
  76. package/dist/components/renderer/CustomisableButtonInner.d.ts +7 -7
  77. package/dist/components/renderer/CustomisableButtonInner.js +8 -8
  78. package/dist/components/renderer/FormElementLabelContainer.d.ts +12 -12
  79. package/dist/components/renderer/FormElementLabelContainer.js +15 -15
  80. package/dist/components/renderer/FormElementOptions.d.ts +9 -9
  81. package/dist/components/renderer/FormElementOptions.js +14 -14
  82. package/dist/components/renderer/LookupButton.d.ts +10 -10
  83. package/dist/components/renderer/LookupButton.js +29 -29
  84. package/dist/components/renderer/LookupNotification.d.ts +12 -12
  85. package/dist/components/renderer/LookupNotification.js +230 -230
  86. package/dist/components/renderer/Modal.d.ts +14 -14
  87. package/dist/components/renderer/Modal.js +14 -14
  88. package/dist/components/renderer/OnLoading.d.ts +10 -10
  89. package/dist/components/renderer/OnLoading.js +11 -11
  90. package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.d.ts +7 -7
  91. package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.js +12 -12
  92. package/dist/components/renderer/OneBlinkFormElements.d.ts +19 -19
  93. package/dist/components/renderer/OneBlinkFormElements.js +202 -202
  94. package/dist/components/renderer/PageFormElements.d.ts +17 -17
  95. package/dist/components/renderer/PageFormElements.js +48 -48
  96. package/dist/components/renderer/ProgressBar.d.ts +7 -7
  97. package/dist/components/renderer/ProgressBar.js +6 -6
  98. package/dist/components/renderer/ProgressBar.js.map +1 -1
  99. package/dist/components/renderer/ToggleAllCheckbox.d.ts +13 -13
  100. package/dist/components/renderer/ToggleAllCheckbox.js +26 -26
  101. package/dist/components/renderer/attachments/AttachmentStatus.d.ts +10 -10
  102. package/dist/components/renderer/attachments/AttachmentStatus.js +36 -36
  103. package/dist/components/renderer/attachments/FileCard.d.ts +19 -19
  104. package/dist/components/renderer/attachments/FileCard.js +60 -60
  105. package/dist/components/renderer/attachments/FileCardContent.d.ts +5 -5
  106. package/dist/components/renderer/attachments/FileCardContent.js +10 -10
  107. package/dist/components/renderer/attachments/ImagePreviewUnavailable.d.ts +4 -4
  108. package/dist/components/renderer/attachments/ImagePreviewUnavailable.js +11 -11
  109. package/dist/components/renderer/attachments/ProgressBar.d.ts +8 -8
  110. package/dist/components/renderer/attachments/ProgressBar.js +33 -33
  111. package/dist/form-elements/ComplianceButton.d.ts +10 -10
  112. package/dist/form-elements/ComplianceButton.js +11 -11
  113. package/dist/form-elements/FormElementABN.d.ts +14 -14
  114. package/dist/form-elements/FormElementABN.js +155 -155
  115. package/dist/form-elements/FormElementAutocomplete.d.ts +19 -19
  116. package/dist/form-elements/FormElementAutocomplete.js +81 -81
  117. package/dist/form-elements/FormElementBSB.d.ts +18 -18
  118. package/dist/form-elements/FormElementBSB.js +100 -100
  119. package/dist/form-elements/FormElementBarcodeScanner.d.ts +14 -14
  120. package/dist/form-elements/FormElementBarcodeScanner.js +306 -306
  121. package/dist/form-elements/FormElementBoolean.d.ts +14 -14
  122. package/dist/form-elements/FormElementBoolean.js +16 -16
  123. package/dist/form-elements/FormElementCalculation.d.ts +11 -11
  124. package/dist/form-elements/FormElementCalculation.js +179 -179
  125. package/dist/form-elements/FormElementCamera.d.ts +15 -15
  126. package/dist/form-elements/FormElementCamera.js +227 -227
  127. package/dist/form-elements/FormElementCaptcha.d.ts +12 -12
  128. package/dist/form-elements/FormElementCaptcha.js +14 -14
  129. package/dist/form-elements/FormElementCheckBoxes.d.ts +15 -15
  130. package/dist/form-elements/FormElementCheckBoxes.js +64 -64
  131. package/dist/form-elements/FormElementCivicaNameRecord.d.ts +8 -8
  132. package/dist/form-elements/FormElementCivicaNameRecord.js +51 -51
  133. package/dist/form-elements/FormElementCivicaStreetName.d.ts +15 -15
  134. package/dist/form-elements/FormElementCivicaStreetName.js +38 -38
  135. package/dist/form-elements/FormElementCompliance.d.ts +22 -22
  136. package/dist/form-elements/FormElementCompliance.js +129 -129
  137. package/dist/form-elements/FormElementDate.d.ts +14 -14
  138. package/dist/form-elements/FormElementDate.js +74 -74
  139. package/dist/form-elements/FormElementDateTime.d.ts +14 -14
  140. package/dist/form-elements/FormElementDateTime.js +67 -67
  141. package/dist/form-elements/FormElementEmail.d.ts +14 -14
  142. package/dist/form-elements/FormElementEmail.js +22 -22
  143. package/dist/form-elements/FormElementFile.d.ts +13 -13
  144. package/dist/form-elements/FormElementFile.js +31 -31
  145. package/dist/form-elements/FormElementFiles.d.ts +15 -15
  146. package/dist/form-elements/FormElementFiles.js +42 -42
  147. package/dist/form-elements/FormElementForm.d.ts +17 -17
  148. package/dist/form-elements/FormElementForm.js +63 -63
  149. package/dist/form-elements/FormElementFreshdeskDependentField.d.ts +8 -8
  150. package/dist/form-elements/FormElementFreshdeskDependentField.js +15 -15
  151. package/dist/form-elements/FormElementGeoscapeAddress.d.ts +15 -15
  152. package/dist/form-elements/FormElementGeoscapeAddress.js +62 -62
  153. package/dist/form-elements/FormElementHTML.d.ts +8 -8
  154. package/dist/form-elements/FormElementHTML.js +15 -15
  155. package/dist/form-elements/FormElementHeading.d.ts +8 -8
  156. package/dist/form-elements/FormElementHeading.js +23 -23
  157. package/dist/form-elements/FormElementImage.d.ts +8 -8
  158. package/dist/form-elements/FormElementImage.js +6 -6
  159. package/dist/form-elements/FormElementLocation.d.ts +20 -20
  160. package/dist/form-elements/FormElementLocation.js +204 -204
  161. package/dist/form-elements/FormElementNumber.d.ts +14 -14
  162. package/dist/form-elements/FormElementNumber.js +72 -72
  163. package/dist/form-elements/FormElementPointAddress.d.ts +15 -15
  164. package/dist/form-elements/FormElementPointAddress.js +69 -69
  165. package/dist/form-elements/FormElementRadio.d.ts +15 -15
  166. package/dist/form-elements/FormElementRadio.js +41 -41
  167. package/dist/form-elements/FormElementRepeatableSet.d.ts +19 -19
  168. package/dist/form-elements/FormElementRepeatableSet.js +126 -126
  169. package/dist/form-elements/FormElementSection.d.ts +8 -8
  170. package/dist/form-elements/FormElementSection.js +69 -69
  171. package/dist/form-elements/FormElementSelect.d.ts +15 -15
  172. package/dist/form-elements/FormElementSelect.js +44 -44
  173. package/dist/form-elements/FormElementSignature.d.ts +15 -15
  174. package/dist/form-elements/FormElementSignature.js +138 -138
  175. package/dist/form-elements/FormElementSummary.d.ts +11 -11
  176. package/dist/form-elements/FormElementSummary.js +159 -159
  177. package/dist/form-elements/FormElementTelephone.d.ts +14 -14
  178. package/dist/form-elements/FormElementTelephone.js +22 -22
  179. package/dist/form-elements/FormElementText.d.ts +14 -14
  180. package/dist/form-elements/FormElementText.js +29 -29
  181. package/dist/form-elements/FormElementTextarea.d.ts +14 -14
  182. package/dist/form-elements/FormElementTextarea.js +30 -30
  183. package/dist/form-elements/FormElementTime.d.ts +14 -14
  184. package/dist/form-elements/FormElementTime.js +53 -53
  185. package/dist/form-elements/OptionButton.d.ts +11 -11
  186. package/dist/form-elements/OptionButton.js +9 -9
  187. package/dist/hooks/attachments/useAttachment.d.ts +12 -12
  188. package/dist/hooks/attachments/useAttachment.js +242 -242
  189. package/dist/hooks/attachments/useAttachmentBlobs.d.ts +19 -19
  190. package/dist/hooks/attachments/useAttachmentBlobs.js +23 -23
  191. package/dist/hooks/attachments/useAttachments.d.ts +10 -10
  192. package/dist/hooks/attachments/useAttachments.js +69 -69
  193. package/dist/hooks/useAbnLookupAuthenticationGuid.d.ts +3 -3
  194. package/dist/hooks/useAbnLookupAuthenticationGuid.js +5 -5
  195. package/dist/hooks/useAuth.d.ts +15 -15
  196. package/dist/hooks/useAuth.js +42 -42
  197. package/dist/hooks/useBooleanState.d.ts +5 -5
  198. package/dist/hooks/useBooleanState.js +8 -8
  199. package/dist/hooks/useCaptchaSiteKey.d.ts +3 -3
  200. package/dist/hooks/useCaptchaSiteKey.js +5 -5
  201. package/dist/hooks/useClickOutsideElement.d.ts +3 -3
  202. package/dist/hooks/useClickOutsideElement.js +14 -14
  203. package/dist/hooks/useConditionalLogic.d.ts +6 -6
  204. package/dist/hooks/useConditionalLogic.js +22 -22
  205. package/dist/hooks/useContrastColor.d.ts +2 -2
  206. package/dist/hooks/useContrastColor.js +12 -12
  207. package/dist/hooks/useDynamicOptionsLoaderState.d.ts +7 -7
  208. package/dist/hooks/useDynamicOptionsLoaderState.js +44 -44
  209. package/dist/hooks/useExecutedLookupCallback.d.ts +12 -12
  210. package/dist/hooks/useExecutedLookupCallback.js +15 -15
  211. package/dist/hooks/useFlatpickr.d.ts +10 -10
  212. package/dist/hooks/useFlatpickr.js +73 -73
  213. package/dist/hooks/useFlatpickrGuid.d.ts +7 -7
  214. package/dist/hooks/useFlatpickrGuid.js +11 -11
  215. package/dist/hooks/useFlattenElementsContext.d.ts +2 -2
  216. package/dist/hooks/useFlattenElementsContext.js +7 -7
  217. package/dist/hooks/useFormDefinition.d.ts +4 -4
  218. package/dist/hooks/useFormDefinition.js +9 -9
  219. package/dist/hooks/useFormElementOptions.d.ts +9 -9
  220. package/dist/hooks/useFormElementOptions.js +35 -35
  221. package/dist/hooks/useFormIsReadOnly.d.ts +3 -3
  222. package/dist/hooks/useFormIsReadOnly.js +5 -5
  223. package/dist/hooks/useFormSubmissionAutoSaveState.d.ts +24 -24
  224. package/dist/hooks/useFormSubmissionAutoSaveState.js +145 -145
  225. package/dist/hooks/useFormSubmissionModelContext.d.ts +15 -15
  226. package/dist/hooks/useFormSubmissionModelContext.js +32 -32
  227. package/dist/hooks/useFormSubmissionState.d.ts +10 -10
  228. package/dist/hooks/useFormSubmissionState.js +13 -13
  229. package/dist/hooks/useFormValidation.d.ts +7 -7
  230. package/dist/hooks/useFormValidation.js +29 -29
  231. package/dist/hooks/useGoogleMapsApiKey.d.ts +3 -3
  232. package/dist/hooks/useGoogleMapsApiKey.js +5 -5
  233. package/dist/hooks/useInfiniteScrollDataLoad.d.ts +30 -30
  234. package/dist/hooks/useInfiniteScrollDataLoad.js +124 -124
  235. package/dist/hooks/useInjectPages.d.ts +7 -7
  236. package/dist/hooks/useInjectPages.js +5 -5
  237. package/dist/hooks/useIsHovering.d.ts +5 -5
  238. package/dist/hooks/useIsHovering.js +12 -12
  239. package/dist/hooks/useIsMounted.d.ts +3 -3
  240. package/dist/hooks/useIsMounted.js +11 -11
  241. package/dist/hooks/useIsOffline.d.ts +6 -6
  242. package/dist/hooks/useIsOffline.js +26 -26
  243. package/dist/hooks/useIsPageVisible.d.ts +9 -9
  244. package/dist/hooks/useIsPageVisible.js +8 -8
  245. package/dist/hooks/useLoadDataState.d.ts +15 -15
  246. package/dist/hooks/useLoadDataState.js +54 -54
  247. package/dist/hooks/useLogin.d.ts +46 -46
  248. package/dist/hooks/useLogin.js +295 -295
  249. package/dist/hooks/useLookupNotification.d.ts +9 -9
  250. package/dist/hooks/useLookupNotification.js +10 -10
  251. package/dist/hooks/useLookups.d.ts +5 -5
  252. package/dist/hooks/useLookups.js +62 -62
  253. package/dist/hooks/useNullableState.d.ts +2 -2
  254. package/dist/hooks/useNullableState.js +6 -6
  255. package/dist/hooks/usePages.d.ts +24 -24
  256. package/dist/hooks/usePages.js +141 -141
  257. package/dist/hooks/useQuery.d.ts +2 -2
  258. package/dist/hooks/useQuery.js +7 -7
  259. package/dist/hooks/useSubmissionIdIsValid.d.ts +3 -3
  260. package/dist/hooks/useSubmissionIdIsValid.js +19 -19
  261. package/dist/hooks/useToggleComplianceChildren.d.ts +3 -3
  262. package/dist/hooks/useToggleComplianceChildren.js +13 -13
  263. package/dist/index.d.ts +23 -23
  264. package/dist/index.js +23 -23
  265. package/dist/services/attachments.d.ts +10 -10
  266. package/dist/services/attachments.js +72 -72
  267. package/dist/services/barcode-readers/quagger.d.ts +1 -1
  268. package/dist/services/barcode-readers/quagger.js +34 -34
  269. package/dist/services/blob-utils.d.ts +5 -5
  270. package/dist/services/blob-utils.js +73 -73
  271. package/dist/services/checkBsbsAreInvalid.d.ts +3 -3
  272. package/dist/services/checkBsbsAreInvalid.js +40 -40
  273. package/dist/services/checkIfAttachmentsExist.d.ts +5 -5
  274. package/dist/services/checkIfAttachmentsExist.js +144 -144
  275. package/dist/services/checkIfBsbsAreValidating.d.ts +3 -3
  276. package/dist/services/checkIfBsbsAreValidating.js +40 -40
  277. package/dist/services/cleanFormSubmissionModel.d.ts +6 -6
  278. package/dist/services/cleanFormSubmissionModel.js +203 -203
  279. package/dist/services/defaultCoordinates.d.ts +5 -5
  280. package/dist/services/defaultCoordinates.js +8 -8
  281. package/dist/services/download-file.d.ts +3 -3
  282. package/dist/services/download-file.js +90 -90
  283. package/dist/services/drawTimestampOnCanvas.d.ts +1 -1
  284. package/dist/services/drawTimestampOnCanvas.js +22 -22
  285. package/dist/services/form-validation.d.ts +10 -10
  286. package/dist/services/form-validation.js +561 -561
  287. package/dist/services/generate-default-data.d.ts +13 -13
  288. package/dist/services/generate-default-data.js +494 -494
  289. package/dist/services/generateCivicaNameRecordElements.d.ts +2 -2
  290. package/dist/services/generateCivicaNameRecordElements.js +140 -140
  291. package/dist/services/generateFreshdeskDependentFieldElements.d.ts +2 -2
  292. package/dist/services/generateFreshdeskDependentFieldElements.js +69 -69
  293. package/dist/services/sanitize-html.d.ts +2 -2
  294. package/dist/services/sanitize-html.js +20 -20
  295. package/dist/services/scrolling-service.d.ts +7 -7
  296. package/dist/services/scrolling-service.js +38 -38
  297. package/dist/services/utils-service.d.ts +5 -5
  298. package/dist/services/utils-service.js +16 -16
  299. package/dist/types/attachments.d.ts +19 -19
  300. package/dist/types/attachments.js +1 -1
  301. package/dist/types/form.d.ts +40 -40
  302. package/dist/types/form.js +2 -2
  303. package/package.json +2 -2
  304. package/dist/OneBlinkFormStoreView.d.ts +0 -8
  305. package/dist/OneBlinkFormStoreView.js +0 -55
  306. package/dist/OneBlinkFormStoreView.js.map +0 -1
  307. package/dist/components/AnnotationModal.d.ts +0 -8
  308. package/dist/components/AnnotationModal.js +0 -104
  309. package/dist/components/AnnotationModal.js.map +0 -1
  310. package/dist/components/AutocompleteDropdown.d.ts +0 -26
  311. package/dist/components/AutocompleteDropdown.js +0 -174
  312. package/dist/components/AutocompleteDropdown.js.map +0 -1
  313. package/dist/components/CopyToClipboardButton.d.ts +0 -9
  314. package/dist/components/CopyToClipboardButton.js +0 -14
  315. package/dist/components/CopyToClipboardButton.js.map +0 -1
  316. package/dist/components/CustomisableButtonInner.d.ts +0 -7
  317. package/dist/components/CustomisableButtonInner.js +0 -9
  318. package/dist/components/CustomisableButtonInner.js.map +0 -1
  319. package/dist/components/ErrorMessage.d.ts +0 -13
  320. package/dist/components/ErrorMessage.js +0 -13
  321. package/dist/components/ErrorMessage.js.map +0 -1
  322. package/dist/components/FormElementLabelContainer.d.ts +0 -12
  323. package/dist/components/FormElementLabelContainer.js +0 -16
  324. package/dist/components/FormElementLabelContainer.js.map +0 -1
  325. package/dist/components/FormElementOptions.d.ts +0 -9
  326. package/dist/components/FormElementOptions.js +0 -15
  327. package/dist/components/FormElementOptions.js.map +0 -1
  328. package/dist/components/LookupButton.d.ts +0 -10
  329. package/dist/components/LookupButton.js +0 -30
  330. package/dist/components/LookupButton.js.map +0 -1
  331. package/dist/components/LookupNotification.d.ts +0 -12
  332. package/dist/components/LookupNotification.js +0 -231
  333. package/dist/components/LookupNotification.js.map +0 -1
  334. package/dist/components/Modal.d.ts +0 -14
  335. package/dist/components/Modal.js +0 -15
  336. package/dist/components/Modal.js.map +0 -1
  337. package/dist/components/NoResourcesYet.d.ts +0 -12
  338. package/dist/components/NoResourcesYet.js +0 -7
  339. package/dist/components/NoResourcesYet.js.map +0 -1
  340. package/dist/components/OnLoading.d.ts +0 -10
  341. package/dist/components/OnLoading.js +0 -12
  342. package/dist/components/OnLoading.js.map +0 -1
  343. package/dist/components/OneBlinkAppsErrorOriginalMessage.d.ts +0 -7
  344. package/dist/components/OneBlinkAppsErrorOriginalMessage.js +0 -13
  345. package/dist/components/OneBlinkAppsErrorOriginalMessage.js.map +0 -1
  346. package/dist/components/OneBlinkFormElements.d.ts +0 -19
  347. package/dist/components/OneBlinkFormElements.js +0 -196
  348. package/dist/components/OneBlinkFormElements.js.map +0 -1
  349. package/dist/components/PageFormElements.d.ts +0 -17
  350. package/dist/components/PageFormElements.js +0 -49
  351. package/dist/components/PageFormElements.js.map +0 -1
  352. package/dist/components/ToggleAllCheckbox.d.ts +0 -13
  353. package/dist/components/ToggleAllCheckbox.js +0 -27
  354. package/dist/components/ToggleAllCheckbox.js.map +0 -1
  355. package/dist/components/attachments/AttachmentStatus.d.ts +0 -12
  356. package/dist/components/attachments/AttachmentStatus.js +0 -35
  357. package/dist/components/attachments/AttachmentStatus.js.map +0 -1
  358. package/dist/components/attachments/FileCard.d.ts +0 -18
  359. package/dist/components/attachments/FileCard.js +0 -58
  360. package/dist/components/attachments/FileCard.js.map +0 -1
  361. package/dist/components/attachments/FileCardContent.d.ts +0 -5
  362. package/dist/components/attachments/FileCardContent.js +0 -11
  363. package/dist/components/attachments/FileCardContent.js.map +0 -1
  364. package/dist/components/attachments/Files.d.ts +0 -14
  365. package/dist/components/attachments/Files.js +0 -27
  366. package/dist/components/attachments/Files.js.map +0 -1
  367. package/dist/components/attachments/ImagePreviewUnavailable.d.ts +0 -4
  368. package/dist/components/attachments/ImagePreviewUnavailable.js +0 -12
  369. package/dist/components/attachments/ImagePreviewUnavailable.js.map +0 -1
  370. package/dist/components/attachments/UploadingAttachment.d.ts +0 -4
  371. package/dist/components/attachments/UploadingAttachment.js +0 -13
  372. package/dist/components/attachments/UploadingAttachment.js.map +0 -1
  373. package/dist/components/formStore/ColumnsConfigurationButton.d.ts +0 -10
  374. package/dist/components/formStore/ColumnsConfigurationButton.js +0 -29
  375. package/dist/components/formStore/ColumnsConfigurationButton.js.map +0 -1
  376. package/dist/components/formStore/DownloadSubmissionDataButton.d.ts +0 -13
  377. package/dist/components/formStore/DownloadSubmissionDataButton.js +0 -45
  378. package/dist/components/formStore/DownloadSubmissionDataButton.js.map +0 -1
  379. package/dist/components/formStore/FormStore.d.ts +0 -9
  380. package/dist/components/formStore/FormStore.js +0 -103
  381. package/dist/components/formStore/FormStore.js.map +0 -1
  382. package/dist/components/formStore/table/index.d.ts +0 -17
  383. package/dist/components/formStore/table/index.js +0 -194
  384. package/dist/components/formStore/table/index.js.map +0 -1
  385. package/dist/components/renderer/attachments/Files.d.ts +0 -14
  386. package/dist/components/renderer/attachments/Files.js +0 -27
  387. package/dist/components/renderer/attachments/Files.js.map +0 -1
  388. package/dist/components/renderer/attachments/UploadingAttachment.d.ts +0 -4
  389. package/dist/components/renderer/attachments/UploadingAttachment.js +0 -13
  390. package/dist/components/renderer/attachments/UploadingAttachment.js.map +0 -1
  391. package/dist/form-elements/FormElementFiles/FormElementFile.d.ts +0 -13
  392. package/dist/form-elements/FormElementFiles/FormElementFile.js +0 -32
  393. package/dist/form-elements/FormElementFiles/FormElementFile.js.map +0 -1
  394. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.d.ts +0 -10
  395. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js +0 -11
  396. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js.map +0 -1
  397. package/dist/form-elements/FormElementFiles/FormElementFiles.d.ts +0 -15
  398. package/dist/form-elements/FormElementFiles/FormElementFiles.js +0 -17
  399. package/dist/form-elements/FormElementFiles/FormElementFiles.js.map +0 -1
  400. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.d.ts +0 -7
  401. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js +0 -11
  402. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js.map +0 -1
  403. package/dist/form-elements/FormElementFiles/index.d.ts +0 -17
  404. package/dist/form-elements/FormElementFiles/index.js +0 -18
  405. package/dist/form-elements/FormElementFiles/index.js.map +0 -1
  406. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.d.ts +0 -18
  407. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js +0 -61
  408. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js.map +0 -1
  409. package/dist/hooks/attachments/useAttachmentObjectURLs.d.ts +0 -24
  410. package/dist/hooks/attachments/useAttachmentObjectURLs.js +0 -37
  411. package/dist/hooks/attachments/useAttachmentObjectURLs.js.map +0 -1
  412. package/dist/hooks/attachments/useLocalAttachmentBlobs.d.ts +0 -24
  413. package/dist/hooks/attachments/useLocalAttachmentBlobs.js +0 -40
  414. package/dist/hooks/attachments/useLocalAttachmentBlobs.js.map +0 -1
  415. package/dist/hooks/useButtonsConfiguration.d.ts +0 -45
  416. package/dist/hooks/useButtonsConfiguration.js +0 -6
  417. package/dist/hooks/useButtonsConfiguration.js.map +0 -1
  418. package/dist/hooks/useChangeEffect.d.ts +0 -1
  419. package/dist/hooks/useChangeEffect.js +0 -14
  420. package/dist/hooks/useChangeEffect.js.map +0 -1
  421. package/dist/hooks/useConditionallyShowOptionCallback.d.ts +0 -5
  422. package/dist/hooks/useConditionallyShowOptionCallback.js +0 -20
  423. package/dist/hooks/useConditionallyShowOptionCallback.js.map +0 -1
  424. package/dist/hooks/useCustomValidation.d.ts +0 -1
  425. package/dist/hooks/useCustomValidation.js +0 -9
  426. package/dist/hooks/useCustomValidation.js.map +0 -1
  427. package/dist/hooks/useDynamicOptionsLoaderEffect.d.ts +0 -7
  428. package/dist/hooks/useDynamicOptionsLoaderEffect.js +0 -45
  429. package/dist/hooks/useDynamicOptionsLoaderEffect.js.map +0 -1
  430. package/dist/hooks/useLegacyElements.d.ts +0 -16
  431. package/dist/hooks/useLegacyElements.js +0 -55
  432. package/dist/hooks/useLegacyElements.js.map +0 -1
  433. package/dist/hooks/useToggleAll.d.ts +0 -6
  434. package/dist/hooks/useToggleAll.js +0 -24
  435. package/dist/hooks/useToggleAll.js.map +0 -1
  436. package/dist/services/checkIfAttachmentsAreUploading.d.ts +0 -3
  437. package/dist/services/checkIfAttachmentsAreUploading.js +0 -58
  438. package/dist/services/checkIfAttachmentsAreUploading.js.map +0 -1
  439. package/dist/services/clean-form-elements-ctrl-model.d.ts +0 -4
  440. package/dist/services/clean-form-elements-ctrl-model.js +0 -166
  441. package/dist/services/clean-form-elements-ctrl-model.js.map +0 -1
  442. package/dist/services/conditionally-show-element.d.ts +0 -11
  443. package/dist/services/conditionally-show-element.js +0 -92
  444. package/dist/services/conditionally-show-element.js.map +0 -1
  445. package/dist/services/conditionally-show-option.d.ts +0 -3
  446. package/dist/services/conditionally-show-option.js +0 -135
  447. package/dist/services/conditionally-show-option.js.map +0 -1
  448. package/dist/services/flattenFormElements.d.ts +0 -2
  449. package/dist/services/flattenFormElements.js +0 -13
  450. package/dist/services/flattenFormElements.js.map +0 -1
  451. package/dist/services/getCorrectDateFromDateOnlyString.d.ts +0 -2
  452. package/dist/services/getCorrectDateFromDateOnlyString.js +0 -4
  453. package/dist/services/getCorrectDateFromDateOnlyString.js.map +0 -1
  454. package/dist/styles/boolean.scss +0 -12
  455. 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,6 +0,0 @@
1
- import * as React from 'react';
2
- export const ButtonsConfigurationContext = React.createContext({});
3
- export default function useButtonsConfiguration() {
4
- return React.useContext(ButtonsConfigurationContext);
5
- }
6
- //# sourceMappingURL=useButtonsConfiguration.js.map
@@ -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,9 +0,0 @@
1
- import * as React from 'react';
2
- const useCustomValidation = (element) => {
3
- return React.useMemo(() => {
4
- return {
5
- shouldUseRegexValidation: !!element.regexPattern,
6
- };
7
- }, []);
8
- };
9
- //# sourceMappingURL=useCustomValidation.js.map
@@ -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,3 +0,0 @@
1
- import { FormTypes } from '@oneblink/types';
2
- import { FormSubmissionModel } from '../types/form';
3
- export default function checkIfAttachmentsAreUploading(form: FormTypes.Form, submission: FormSubmissionModel): boolean;
@@ -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,4 +0,0 @@
1
- export default function cleanFormElementsCtrlModel(formElementsCtrl: FormElementsCtrl, formElementsConditionallyShown: FormElementsConditionallyShown | undefined, stripBinaryData: boolean): {
2
- model: FormElementsCtrl['model'];
3
- captchaTokens: string[];
4
- };
@@ -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;