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

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 (464) 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 +28 -28
  6. package/dist/OneBlinkFormBase.js +472 -472
  7. package/dist/OneBlinkFormStoreView.d.ts +8 -0
  8. package/dist/OneBlinkFormStoreView.js +55 -0
  9. package/dist/OneBlinkFormStoreView.js.map +1 -0
  10. package/dist/OneBlinkReadOnlyForm.d.ts +11 -11
  11. package/dist/OneBlinkReadOnlyForm.js +48 -48
  12. package/dist/components/AnnotationModal.d.ts +8 -0
  13. package/dist/components/AnnotationModal.js +104 -0
  14. package/dist/components/AnnotationModal.js.map +1 -0
  15. package/dist/components/AutocompleteDropdown.d.ts +26 -0
  16. package/dist/components/AutocompleteDropdown.js +174 -0
  17. package/dist/components/AutocompleteDropdown.js.map +1 -0
  18. package/dist/components/CopyToClipboardButton.d.ts +9 -0
  19. package/dist/components/CopyToClipboardButton.js +14 -0
  20. package/dist/components/CopyToClipboardButton.js.map +1 -0
  21. package/dist/components/CopyToClipboardIconButton.d.ts +10 -10
  22. package/dist/components/CopyToClipboardIconButton.js +32 -32
  23. package/dist/components/CustomAccordion.d.ts +27 -27
  24. package/dist/components/CustomAccordion.js +37 -37
  25. package/dist/components/CustomisableButtonInner.d.ts +7 -0
  26. package/dist/components/CustomisableButtonInner.js +9 -0
  27. package/dist/components/CustomisableButtonInner.js.map +1 -0
  28. package/dist/components/ErrorMessage.d.ts +13 -0
  29. package/dist/components/ErrorMessage.js +13 -0
  30. package/dist/components/ErrorMessage.js.map +1 -0
  31. package/dist/components/ErrorSnackbar.d.ts +8 -8
  32. package/dist/components/ErrorSnackbar.js +25 -25
  33. package/dist/components/FormElementLabelContainer.d.ts +12 -0
  34. package/dist/components/FormElementLabelContainer.js +16 -0
  35. package/dist/components/FormElementLabelContainer.js.map +1 -0
  36. package/dist/components/FormElementOptions.d.ts +9 -0
  37. package/dist/components/FormElementOptions.js +15 -0
  38. package/dist/components/FormElementOptions.js.map +1 -0
  39. package/dist/components/Lists.d.ts +25 -25
  40. package/dist/components/Lists.js +44 -44
  41. package/dist/components/LoadingWithMessage.d.ts +6 -6
  42. package/dist/components/LoadingWithMessage.js +11 -11
  43. package/dist/components/LookupButton.d.ts +10 -0
  44. package/dist/components/LookupButton.js +30 -0
  45. package/dist/components/LookupButton.js.map +1 -0
  46. package/dist/components/LookupNotification.d.ts +12 -0
  47. package/dist/components/LookupNotification.js +231 -0
  48. package/dist/components/LookupNotification.js.map +1 -0
  49. package/dist/components/Modal.d.ts +14 -0
  50. package/dist/components/Modal.js +15 -0
  51. package/dist/components/Modal.js.map +1 -0
  52. package/dist/components/NoResourcesYet.d.ts +12 -0
  53. package/dist/components/NoResourcesYet.js +7 -0
  54. package/dist/components/NoResourcesYet.js.map +1 -0
  55. package/dist/components/OnLoading.d.ts +10 -0
  56. package/dist/components/OnLoading.js +12 -0
  57. package/dist/components/OnLoading.js.map +1 -0
  58. package/dist/components/OneBlinkAppsErrorOriginalMessage.d.ts +7 -0
  59. package/dist/components/OneBlinkAppsErrorOriginalMessage.js +13 -0
  60. package/dist/components/OneBlinkAppsErrorOriginalMessage.js.map +1 -0
  61. package/dist/components/OneBlinkFormElements.d.ts +19 -0
  62. package/dist/components/OneBlinkFormElements.js +196 -0
  63. package/dist/components/OneBlinkFormElements.js.map +1 -0
  64. package/dist/components/PageFormElements.d.ts +17 -0
  65. package/dist/components/PageFormElements.js +49 -0
  66. package/dist/components/PageFormElements.js.map +1 -0
  67. package/dist/components/ToggleAllCheckbox.d.ts +13 -0
  68. package/dist/components/ToggleAllCheckbox.js +27 -0
  69. package/dist/components/ToggleAllCheckbox.js.map +1 -0
  70. package/dist/components/attachments/AttachmentStatus.d.ts +12 -0
  71. package/dist/components/attachments/AttachmentStatus.js +35 -0
  72. package/dist/components/attachments/AttachmentStatus.js.map +1 -0
  73. package/dist/components/attachments/FileCard.d.ts +18 -0
  74. package/dist/components/attachments/FileCard.js +58 -0
  75. package/dist/components/attachments/FileCard.js.map +1 -0
  76. package/dist/components/attachments/FileCardContent.d.ts +5 -0
  77. package/dist/components/attachments/FileCardContent.js +11 -0
  78. package/dist/components/attachments/FileCardContent.js.map +1 -0
  79. package/dist/components/attachments/Files.d.ts +14 -0
  80. package/dist/components/attachments/Files.js +27 -0
  81. package/dist/components/attachments/Files.js.map +1 -0
  82. package/dist/components/attachments/ImagePreviewUnavailable.d.ts +4 -0
  83. package/dist/components/attachments/ImagePreviewUnavailable.js +12 -0
  84. package/dist/components/attachments/ImagePreviewUnavailable.js.map +1 -0
  85. package/dist/components/attachments/UploadingAttachment.d.ts +4 -0
  86. package/dist/components/attachments/UploadingAttachment.js +13 -0
  87. package/dist/components/attachments/UploadingAttachment.js.map +1 -0
  88. package/dist/components/formStore/ColumnsConfigurationButton.d.ts +10 -0
  89. package/dist/components/formStore/ColumnsConfigurationButton.js +29 -0
  90. package/dist/components/formStore/ColumnsConfigurationButton.js.map +1 -0
  91. package/dist/components/formStore/DownloadSubmissionDataButton.d.ts +13 -0
  92. package/dist/components/formStore/DownloadSubmissionDataButton.js +45 -0
  93. package/dist/components/formStore/DownloadSubmissionDataButton.js.map +1 -0
  94. package/dist/components/formStore/FormStore.d.ts +9 -0
  95. package/dist/components/formStore/FormStore.js +103 -0
  96. package/dist/components/formStore/FormStore.js.map +1 -0
  97. package/dist/components/formStore/FormStoreTableProvider.d.ts +6 -6
  98. package/dist/components/formStore/FormStoreTableProvider.js +90 -90
  99. package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.d.ts +5 -5
  100. package/dist/components/formStore/OneBlinkFormStoreClearFiltersButton.js +19 -19
  101. package/dist/components/formStore/OneBlinkFormStoreColumnsButton.d.ts +5 -5
  102. package/dist/components/formStore/OneBlinkFormStoreColumnsButton.js +66 -66
  103. package/dist/components/formStore/OneBlinkFormStoreDownloadButton.d.ts +5 -5
  104. package/dist/components/formStore/OneBlinkFormStoreDownloadButton.js +86 -86
  105. package/dist/components/formStore/OneBlinkFormStoreProvider.d.ts +8 -8
  106. package/dist/components/formStore/OneBlinkFormStoreProvider.js +24 -24
  107. package/dist/components/formStore/OneBlinkFormStoreRefreshButton.d.ts +5 -5
  108. package/dist/components/formStore/OneBlinkFormStoreRefreshButton.js +11 -11
  109. package/dist/components/formStore/OneBlinkFormStoreTable.d.ts +4 -4
  110. package/dist/components/formStore/OneBlinkFormStoreTable.js +194 -194
  111. package/dist/components/formStore/display/ElementDisplay.d.ts +23 -23
  112. package/dist/components/formStore/display/ElementDisplay.js +77 -77
  113. package/dist/components/formStore/display/FormStoreIcon.d.ts +2 -2
  114. package/dist/components/formStore/display/FormStoreIcon.js +2 -2
  115. package/dist/components/formStore/table/ActionedByTableCell.d.ts +11 -11
  116. package/dist/components/formStore/table/ActionedByTableCell.js +43 -43
  117. package/dist/components/formStore/table/ColumnFilters.d.ts +9 -9
  118. package/dist/components/formStore/table/ColumnFilters.js +179 -179
  119. package/dist/components/formStore/table/FormElementTableCell.d.ts +10 -10
  120. package/dist/components/formStore/table/FormElementTableCell.js +228 -228
  121. package/dist/components/formStore/table/HeaderCellMoreButton.d.ts +9 -9
  122. package/dist/components/formStore/table/HeaderCellMoreButton.js +48 -48
  123. package/dist/components/formStore/table/RepeatableSetCell.d.ts +8 -8
  124. package/dist/components/formStore/table/RepeatableSetCell.js +62 -62
  125. package/dist/components/formStore/table/RepeatableSetCellAccordion.d.ts +9 -9
  126. package/dist/components/formStore/table/RepeatableSetCellAccordion.js +11 -11
  127. package/dist/components/formStore/table/TableCellCopyButton.d.ts +7 -7
  128. package/dist/components/formStore/table/TableCellCopyButton.js +27 -27
  129. package/dist/components/formStore/table/generateColumns.d.ts +24 -24
  130. package/dist/components/formStore/table/generateColumns.js +290 -290
  131. package/dist/components/formStore/table/index.d.ts +17 -0
  132. package/dist/components/formStore/table/index.js +194 -0
  133. package/dist/components/formStore/table/index.js.map +1 -0
  134. package/dist/components/formStore/table/useFormStoreTable.d.ts +52 -52
  135. package/dist/components/formStore/table/useFormStoreTable.js +157 -157
  136. package/dist/components/formStore/useFormStoreTableContext.d.ts +44 -44
  137. package/dist/components/formStore/useFormStoreTableContext.js +9 -9
  138. package/dist/components/messages/ErrorMessage.d.ts +12 -12
  139. package/dist/components/messages/ErrorMessage.js +12 -12
  140. package/dist/components/messages/LargeIconMessage.d.ts +18 -18
  141. package/dist/components/messages/LargeIconMessage.js +33 -33
  142. package/dist/components/messages/NoResourcesYet.d.ts +11 -11
  143. package/dist/components/messages/NoResourcesYet.js +6 -6
  144. package/dist/components/pickers/V4CompatibleDatePicker.d.ts +32 -32
  145. package/dist/components/pickers/V4CompatibleDatePicker.js +70 -70
  146. package/dist/components/pickers/V4CompatibleDateTimePicker.d.ts +32 -32
  147. package/dist/components/pickers/V4CompatibleDateTimePicker.js +70 -70
  148. package/dist/components/pickers/V4CompatibleTimePicker.d.ts +28 -28
  149. package/dist/components/pickers/V4CompatibleTimePicker.js +53 -53
  150. package/dist/components/renderer/AnnotationModal.d.ts +8 -8
  151. package/dist/components/renderer/AnnotationModal.js +101 -101
  152. package/dist/components/renderer/AutocompleteDropdown.d.ts +26 -26
  153. package/dist/components/renderer/AutocompleteDropdown.js +175 -175
  154. package/dist/components/renderer/CopyToClipboardButton.d.ts +8 -8
  155. package/dist/components/renderer/CopyToClipboardButton.js +13 -13
  156. package/dist/components/renderer/CustomisableButtonInner.d.ts +7 -7
  157. package/dist/components/renderer/CustomisableButtonInner.js +8 -8
  158. package/dist/components/renderer/FormElementLabelContainer.d.ts +12 -12
  159. package/dist/components/renderer/FormElementLabelContainer.js +15 -15
  160. package/dist/components/renderer/FormElementOptions.d.ts +9 -9
  161. package/dist/components/renderer/FormElementOptions.js +14 -14
  162. package/dist/components/renderer/LookupButton.d.ts +10 -10
  163. package/dist/components/renderer/LookupButton.js +29 -29
  164. package/dist/components/renderer/LookupNotification.d.ts +12 -12
  165. package/dist/components/renderer/LookupNotification.js +230 -230
  166. package/dist/components/renderer/Modal.d.ts +14 -14
  167. package/dist/components/renderer/Modal.js +14 -14
  168. package/dist/components/renderer/OnLoading.d.ts +10 -10
  169. package/dist/components/renderer/OnLoading.js +11 -11
  170. package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.d.ts +7 -7
  171. package/dist/components/renderer/OneBlinkAppsErrorOriginalMessage.js +12 -12
  172. package/dist/components/renderer/OneBlinkFormElements.d.ts +19 -19
  173. package/dist/components/renderer/OneBlinkFormElements.js +202 -202
  174. package/dist/components/renderer/PageFormElements.d.ts +17 -17
  175. package/dist/components/renderer/PageFormElements.js +48 -48
  176. package/dist/components/renderer/ProgressBar.d.ts +7 -0
  177. package/dist/components/renderer/ProgressBar.js +7 -0
  178. package/dist/components/renderer/ProgressBar.js.map +1 -0
  179. package/dist/components/renderer/ToggleAllCheckbox.d.ts +13 -13
  180. package/dist/components/renderer/ToggleAllCheckbox.js +26 -26
  181. package/dist/components/renderer/attachments/AttachmentStatus.d.ts +10 -10
  182. package/dist/components/renderer/attachments/AttachmentStatus.js +36 -30
  183. package/dist/components/renderer/attachments/AttachmentStatus.js.map +1 -1
  184. package/dist/components/renderer/attachments/FileCard.d.ts +19 -18
  185. package/dist/components/renderer/attachments/FileCard.js +60 -57
  186. package/dist/components/renderer/attachments/FileCard.js.map +1 -1
  187. package/dist/components/renderer/attachments/FileCardContent.d.ts +5 -5
  188. package/dist/components/renderer/attachments/FileCardContent.js +10 -10
  189. package/dist/components/renderer/attachments/Files.d.ts +14 -0
  190. package/dist/components/renderer/attachments/Files.js +27 -0
  191. package/dist/components/renderer/attachments/Files.js.map +1 -0
  192. package/dist/components/renderer/attachments/ImagePreviewUnavailable.d.ts +4 -4
  193. package/dist/components/renderer/attachments/ImagePreviewUnavailable.js +11 -11
  194. package/dist/components/renderer/attachments/ProgressBar.d.ts +8 -0
  195. package/dist/components/renderer/attachments/ProgressBar.js +34 -0
  196. package/dist/components/renderer/attachments/ProgressBar.js.map +1 -0
  197. package/dist/components/renderer/attachments/UploadingAttachment.d.ts +4 -4
  198. package/dist/components/renderer/attachments/UploadingAttachment.js +12 -12
  199. package/dist/form-elements/ComplianceButton.d.ts +10 -10
  200. package/dist/form-elements/ComplianceButton.js +11 -11
  201. package/dist/form-elements/FormElementABN.d.ts +14 -14
  202. package/dist/form-elements/FormElementABN.js +155 -155
  203. package/dist/form-elements/FormElementAutocomplete.d.ts +19 -19
  204. package/dist/form-elements/FormElementAutocomplete.js +81 -81
  205. package/dist/form-elements/FormElementBSB.d.ts +18 -18
  206. package/dist/form-elements/FormElementBSB.js +100 -100
  207. package/dist/form-elements/FormElementBarcodeScanner.d.ts +14 -14
  208. package/dist/form-elements/FormElementBarcodeScanner.js +306 -306
  209. package/dist/form-elements/FormElementBoolean.d.ts +14 -14
  210. package/dist/form-elements/FormElementBoolean.js +16 -16
  211. package/dist/form-elements/FormElementCalculation.d.ts +11 -11
  212. package/dist/form-elements/FormElementCalculation.js +179 -179
  213. package/dist/form-elements/FormElementCamera.d.ts +15 -15
  214. package/dist/form-elements/FormElementCamera.js +227 -220
  215. package/dist/form-elements/FormElementCamera.js.map +1 -1
  216. package/dist/form-elements/FormElementCaptcha.d.ts +12 -12
  217. package/dist/form-elements/FormElementCaptcha.js +14 -14
  218. package/dist/form-elements/FormElementCheckBoxes.d.ts +15 -15
  219. package/dist/form-elements/FormElementCheckBoxes.js +64 -64
  220. package/dist/form-elements/FormElementCivicaNameRecord.d.ts +8 -8
  221. package/dist/form-elements/FormElementCivicaNameRecord.js +51 -51
  222. package/dist/form-elements/FormElementCivicaStreetName.d.ts +15 -15
  223. package/dist/form-elements/FormElementCivicaStreetName.js +38 -38
  224. package/dist/form-elements/FormElementCompliance.d.ts +22 -22
  225. package/dist/form-elements/FormElementCompliance.js +129 -129
  226. package/dist/form-elements/FormElementDate.d.ts +14 -14
  227. package/dist/form-elements/FormElementDate.js +74 -74
  228. package/dist/form-elements/FormElementDateTime.d.ts +14 -14
  229. package/dist/form-elements/FormElementDateTime.js +67 -67
  230. package/dist/form-elements/FormElementEmail.d.ts +14 -14
  231. package/dist/form-elements/FormElementEmail.js +22 -22
  232. package/dist/form-elements/FormElementFile.d.ts +13 -13
  233. package/dist/form-elements/FormElementFile.js +31 -31
  234. package/dist/form-elements/FormElementFile.js.map +1 -1
  235. package/dist/form-elements/FormElementFiles/FormElementFile.d.ts +13 -0
  236. package/dist/form-elements/FormElementFiles/FormElementFile.js +32 -0
  237. package/dist/form-elements/FormElementFiles/FormElementFile.js.map +1 -0
  238. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.d.ts +10 -0
  239. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js +11 -0
  240. package/dist/form-elements/FormElementFiles/FormElementFileDisplay.js.map +1 -0
  241. package/dist/form-elements/FormElementFiles/FormElementFiles.d.ts +15 -0
  242. package/dist/form-elements/FormElementFiles/FormElementFiles.js +17 -0
  243. package/dist/form-elements/FormElementFiles/FormElementFiles.js.map +1 -0
  244. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.d.ts +7 -0
  245. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js +11 -0
  246. package/dist/form-elements/FormElementFiles/FormElementFilesInvalidAttachment.js.map +1 -0
  247. package/dist/form-elements/FormElementFiles/index.d.ts +17 -0
  248. package/dist/form-elements/FormElementFiles/index.js +18 -0
  249. package/dist/form-elements/FormElementFiles/index.js.map +1 -0
  250. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.d.ts +18 -0
  251. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js +61 -0
  252. package/dist/form-elements/FormElementFiles/legacy/FormElementFiles.js.map +1 -0
  253. package/dist/form-elements/FormElementFiles.d.ts +15 -15
  254. package/dist/form-elements/FormElementFiles.js +42 -42
  255. package/dist/form-elements/FormElementForm.d.ts +17 -17
  256. package/dist/form-elements/FormElementForm.js +63 -63
  257. package/dist/form-elements/FormElementFreshdeskDependentField.d.ts +8 -8
  258. package/dist/form-elements/FormElementFreshdeskDependentField.js +15 -15
  259. package/dist/form-elements/FormElementGeoscapeAddress.d.ts +15 -15
  260. package/dist/form-elements/FormElementGeoscapeAddress.js +62 -62
  261. package/dist/form-elements/FormElementHTML.d.ts +8 -8
  262. package/dist/form-elements/FormElementHTML.js +15 -15
  263. package/dist/form-elements/FormElementHeading.d.ts +8 -8
  264. package/dist/form-elements/FormElementHeading.js +23 -23
  265. package/dist/form-elements/FormElementImage.d.ts +8 -8
  266. package/dist/form-elements/FormElementImage.js +6 -6
  267. package/dist/form-elements/FormElementLocation.d.ts +20 -20
  268. package/dist/form-elements/FormElementLocation.js +204 -204
  269. package/dist/form-elements/FormElementNumber.d.ts +14 -14
  270. package/dist/form-elements/FormElementNumber.js +72 -72
  271. package/dist/form-elements/FormElementPointAddress.d.ts +15 -15
  272. package/dist/form-elements/FormElementPointAddress.js +69 -69
  273. package/dist/form-elements/FormElementRadio.d.ts +15 -15
  274. package/dist/form-elements/FormElementRadio.js +41 -41
  275. package/dist/form-elements/FormElementRepeatableSet.d.ts +19 -19
  276. package/dist/form-elements/FormElementRepeatableSet.js +126 -126
  277. package/dist/form-elements/FormElementSection.d.ts +8 -8
  278. package/dist/form-elements/FormElementSection.js +69 -69
  279. package/dist/form-elements/FormElementSelect.d.ts +15 -15
  280. package/dist/form-elements/FormElementSelect.js +44 -44
  281. package/dist/form-elements/FormElementSignature.d.ts +15 -15
  282. package/dist/form-elements/FormElementSignature.js +138 -135
  283. package/dist/form-elements/FormElementSignature.js.map +1 -1
  284. package/dist/form-elements/FormElementSummary.d.ts +11 -11
  285. package/dist/form-elements/FormElementSummary.js +159 -159
  286. package/dist/form-elements/FormElementTelephone.d.ts +14 -14
  287. package/dist/form-elements/FormElementTelephone.js +22 -22
  288. package/dist/form-elements/FormElementText.d.ts +14 -14
  289. package/dist/form-elements/FormElementText.js +29 -29
  290. package/dist/form-elements/FormElementTextarea.d.ts +14 -14
  291. package/dist/form-elements/FormElementTextarea.js +30 -30
  292. package/dist/form-elements/FormElementTime.d.ts +14 -14
  293. package/dist/form-elements/FormElementTime.js +53 -53
  294. package/dist/form-elements/OptionButton.d.ts +11 -11
  295. package/dist/form-elements/OptionButton.js +9 -9
  296. package/dist/hooks/attachments/useAttachment.d.ts +12 -11
  297. package/dist/hooks/attachments/useAttachment.js +242 -235
  298. package/dist/hooks/attachments/useAttachment.js.map +1 -1
  299. package/dist/hooks/attachments/useAttachmentBlobs.d.ts +19 -19
  300. package/dist/hooks/attachments/useAttachmentBlobs.js +23 -23
  301. package/dist/hooks/attachments/useAttachmentObjectURLs.d.ts +24 -0
  302. package/dist/hooks/attachments/useAttachmentObjectURLs.js +37 -0
  303. package/dist/hooks/attachments/useAttachmentObjectURLs.js.map +1 -0
  304. package/dist/hooks/attachments/useAttachments.d.ts +10 -10
  305. package/dist/hooks/attachments/useAttachments.js +69 -69
  306. package/dist/hooks/attachments/useLocalAttachmentBlobs.d.ts +24 -0
  307. package/dist/hooks/attachments/useLocalAttachmentBlobs.js +40 -0
  308. package/dist/hooks/attachments/useLocalAttachmentBlobs.js.map +1 -0
  309. package/dist/hooks/useAbnLookupAuthenticationGuid.d.ts +3 -3
  310. package/dist/hooks/useAbnLookupAuthenticationGuid.js +5 -5
  311. package/dist/hooks/useAuth.d.ts +15 -15
  312. package/dist/hooks/useAuth.js +42 -42
  313. package/dist/hooks/useBooleanState.d.ts +5 -5
  314. package/dist/hooks/useBooleanState.js +8 -8
  315. package/dist/hooks/useButtonsConfiguration.d.ts +45 -0
  316. package/dist/hooks/useButtonsConfiguration.js +6 -0
  317. package/dist/hooks/useButtonsConfiguration.js.map +1 -0
  318. package/dist/hooks/useCaptchaSiteKey.d.ts +3 -3
  319. package/dist/hooks/useCaptchaSiteKey.js +5 -5
  320. package/dist/hooks/useChangeEffect.d.ts +1 -0
  321. package/dist/hooks/useChangeEffect.js +14 -0
  322. package/dist/hooks/useChangeEffect.js.map +1 -0
  323. package/dist/hooks/useClickOutsideElement.d.ts +3 -3
  324. package/dist/hooks/useClickOutsideElement.js +14 -14
  325. package/dist/hooks/useConditionalLogic.d.ts +6 -6
  326. package/dist/hooks/useConditionalLogic.js +22 -22
  327. package/dist/hooks/useConditionallyShowOptionCallback.d.ts +5 -0
  328. package/dist/hooks/useConditionallyShowOptionCallback.js +20 -0
  329. package/dist/hooks/useConditionallyShowOptionCallback.js.map +1 -0
  330. package/dist/hooks/useContrastColor.d.ts +2 -2
  331. package/dist/hooks/useContrastColor.js +12 -12
  332. package/dist/hooks/useCustomValidation.d.ts +1 -0
  333. package/dist/hooks/useCustomValidation.js +9 -0
  334. package/dist/hooks/useCustomValidation.js.map +1 -0
  335. package/dist/hooks/useDynamicOptionsLoaderEffect.d.ts +7 -0
  336. package/dist/hooks/useDynamicOptionsLoaderEffect.js +45 -0
  337. package/dist/hooks/useDynamicOptionsLoaderEffect.js.map +1 -0
  338. package/dist/hooks/useDynamicOptionsLoaderState.d.ts +7 -7
  339. package/dist/hooks/useDynamicOptionsLoaderState.js +44 -44
  340. package/dist/hooks/useExecutedLookupCallback.d.ts +12 -12
  341. package/dist/hooks/useExecutedLookupCallback.js +15 -15
  342. package/dist/hooks/useFlatpickr.d.ts +10 -10
  343. package/dist/hooks/useFlatpickr.js +73 -73
  344. package/dist/hooks/useFlatpickrGuid.d.ts +7 -7
  345. package/dist/hooks/useFlatpickrGuid.js +11 -11
  346. package/dist/hooks/useFlattenElementsContext.d.ts +2 -2
  347. package/dist/hooks/useFlattenElementsContext.js +7 -7
  348. package/dist/hooks/useFormDefinition.d.ts +4 -4
  349. package/dist/hooks/useFormDefinition.js +9 -9
  350. package/dist/hooks/useFormElementOptions.d.ts +9 -9
  351. package/dist/hooks/useFormElementOptions.js +35 -35
  352. package/dist/hooks/useFormIsReadOnly.d.ts +3 -3
  353. package/dist/hooks/useFormIsReadOnly.js +5 -5
  354. package/dist/hooks/useFormSubmissionAutoSaveState.d.ts +24 -24
  355. package/dist/hooks/useFormSubmissionAutoSaveState.js +145 -145
  356. package/dist/hooks/useFormSubmissionModelContext.d.ts +15 -15
  357. package/dist/hooks/useFormSubmissionModelContext.js +32 -32
  358. package/dist/hooks/useFormSubmissionState.d.ts +10 -10
  359. package/dist/hooks/useFormSubmissionState.js +13 -13
  360. package/dist/hooks/useFormValidation.d.ts +7 -7
  361. package/dist/hooks/useFormValidation.js +29 -29
  362. package/dist/hooks/useGoogleMapsApiKey.d.ts +3 -3
  363. package/dist/hooks/useGoogleMapsApiKey.js +5 -5
  364. package/dist/hooks/useInfiniteScrollDataLoad.d.ts +30 -30
  365. package/dist/hooks/useInfiniteScrollDataLoad.js +124 -124
  366. package/dist/hooks/useInjectPages.d.ts +7 -7
  367. package/dist/hooks/useInjectPages.js +5 -5
  368. package/dist/hooks/useIsHovering.d.ts +5 -5
  369. package/dist/hooks/useIsHovering.js +12 -12
  370. package/dist/hooks/useIsMounted.d.ts +3 -3
  371. package/dist/hooks/useIsMounted.js +11 -11
  372. package/dist/hooks/useIsOffline.d.ts +6 -6
  373. package/dist/hooks/useIsOffline.js +26 -26
  374. package/dist/hooks/useIsPageVisible.d.ts +9 -9
  375. package/dist/hooks/useIsPageVisible.js +8 -8
  376. package/dist/hooks/useLegacyElements.d.ts +16 -0
  377. package/dist/hooks/useLegacyElements.js +55 -0
  378. package/dist/hooks/useLegacyElements.js.map +1 -0
  379. package/dist/hooks/useLoadDataState.d.ts +15 -15
  380. package/dist/hooks/useLoadDataState.js +54 -54
  381. package/dist/hooks/useLogin.d.ts +46 -46
  382. package/dist/hooks/useLogin.js +295 -295
  383. package/dist/hooks/useLookupNotification.d.ts +9 -9
  384. package/dist/hooks/useLookupNotification.js +10 -10
  385. package/dist/hooks/useLookups.d.ts +5 -5
  386. package/dist/hooks/useLookups.js +62 -62
  387. package/dist/hooks/useNullableState.d.ts +2 -2
  388. package/dist/hooks/useNullableState.js +6 -6
  389. package/dist/hooks/usePages.d.ts +24 -24
  390. package/dist/hooks/usePages.js +141 -141
  391. package/dist/hooks/useQuery.d.ts +2 -2
  392. package/dist/hooks/useQuery.js +7 -7
  393. package/dist/hooks/useSubmissionIdIsValid.d.ts +3 -3
  394. package/dist/hooks/useSubmissionIdIsValid.js +19 -19
  395. package/dist/hooks/useToggleAll.d.ts +6 -0
  396. package/dist/hooks/useToggleAll.js +24 -0
  397. package/dist/hooks/useToggleAll.js.map +1 -0
  398. package/dist/hooks/useToggleComplianceChildren.d.ts +3 -3
  399. package/dist/hooks/useToggleComplianceChildren.js +13 -13
  400. package/dist/index.d.ts +23 -22
  401. package/dist/index.js +23 -22
  402. package/dist/index.js.map +1 -1
  403. package/dist/services/attachments.d.ts +10 -10
  404. package/dist/services/attachments.js +72 -72
  405. package/dist/services/barcode-readers/quagger.d.ts +1 -1
  406. package/dist/services/barcode-readers/quagger.js +34 -34
  407. package/dist/services/blob-utils.d.ts +5 -5
  408. package/dist/services/blob-utils.js +73 -73
  409. package/dist/services/checkBsbsAreInvalid.d.ts +3 -3
  410. package/dist/services/checkBsbsAreInvalid.js +40 -40
  411. package/dist/services/checkIfAttachmentsAreUploading.d.ts +3 -3
  412. package/dist/services/checkIfAttachmentsAreUploading.js +57 -57
  413. package/dist/services/checkIfAttachmentsExist.d.ts +5 -5
  414. package/dist/services/checkIfAttachmentsExist.js +144 -144
  415. package/dist/services/checkIfBsbsAreValidating.d.ts +3 -3
  416. package/dist/services/checkIfBsbsAreValidating.js +40 -40
  417. package/dist/services/clean-form-elements-ctrl-model.d.ts +4 -0
  418. package/dist/services/clean-form-elements-ctrl-model.js +166 -0
  419. package/dist/services/clean-form-elements-ctrl-model.js.map +1 -0
  420. package/dist/services/cleanFormSubmissionModel.d.ts +6 -6
  421. package/dist/services/cleanFormSubmissionModel.js +203 -203
  422. package/dist/services/conditionally-show-element.d.ts +11 -0
  423. package/dist/services/conditionally-show-element.js +92 -0
  424. package/dist/services/conditionally-show-element.js.map +1 -0
  425. package/dist/services/conditionally-show-option.d.ts +3 -0
  426. package/dist/services/conditionally-show-option.js +135 -0
  427. package/dist/services/conditionally-show-option.js.map +1 -0
  428. package/dist/services/defaultCoordinates.d.ts +5 -5
  429. package/dist/services/defaultCoordinates.js +8 -8
  430. package/dist/services/download-file.d.ts +3 -3
  431. package/dist/services/download-file.js +90 -90
  432. package/dist/services/drawTimestampOnCanvas.d.ts +1 -1
  433. package/dist/services/drawTimestampOnCanvas.js +22 -22
  434. package/dist/services/flattenFormElements.d.ts +2 -0
  435. package/dist/services/flattenFormElements.js +13 -0
  436. package/dist/services/flattenFormElements.js.map +1 -0
  437. package/dist/services/form-validation.d.ts +10 -10
  438. package/dist/services/form-validation.js +561 -561
  439. package/dist/services/generate-default-data.d.ts +13 -13
  440. package/dist/services/generate-default-data.js +494 -494
  441. package/dist/services/generateCivicaNameRecordElements.d.ts +2 -2
  442. package/dist/services/generateCivicaNameRecordElements.js +140 -140
  443. package/dist/services/generateFreshdeskDependentFieldElements.d.ts +2 -2
  444. package/dist/services/generateFreshdeskDependentFieldElements.js +69 -69
  445. package/dist/services/getCorrectDateFromDateOnlyString.d.ts +2 -0
  446. package/dist/services/getCorrectDateFromDateOnlyString.js +4 -0
  447. package/dist/services/getCorrectDateFromDateOnlyString.js.map +1 -0
  448. package/dist/services/sanitize-html.d.ts +2 -2
  449. package/dist/services/sanitize-html.js +20 -20
  450. package/dist/services/scrolling-service.d.ts +7 -7
  451. package/dist/services/scrolling-service.js +38 -38
  452. package/dist/services/utils-service.d.ts +5 -5
  453. package/dist/services/utils-service.js +16 -16
  454. package/dist/styles/boolean.scss +12 -0
  455. package/dist/styles/ob-file.scss +63 -0
  456. package/dist/styles/progress.scss +8 -0
  457. package/dist/styles.css +7 -0
  458. package/dist/styles.css.map +1 -1
  459. package/dist/styles.scss +1 -0
  460. package/dist/types/attachments.d.ts +19 -19
  461. package/dist/types/attachments.js +1 -1
  462. package/dist/types/form.d.ts +40 -40
  463. package/dist/types/form.js +2 -2
  464. package/package.json +2 -2
@@ -1,231 +1,231 @@
1
- import * as React from 'react';
2
- import clsx from 'clsx';
3
- import { formService } from '@oneblink/apps';
4
- import { generateHeaders } from '@oneblink/apps/dist/services/fetch';
5
- import useIsOffline from '../../hooks/useIsOffline';
6
- import OnLoading from './OnLoading';
7
- import generateDefaultData from '../../services/generate-default-data';
8
- import { LookupNotificationContext } from '../../hooks/useLookupNotification';
9
- import useFormDefinition from '../../hooks/useFormDefinition';
10
- import useInjectPages from '../../hooks/useInjectPages';
11
- import useFormSubmissionModel from '../../hooks/useFormSubmissionModelContext';
12
- import useExecutedLookupCallback from '../../hooks/useExecutedLookupCallback';
13
- import useFormIsReadOnly from '../../hooks/useFormIsReadOnly';
14
- import { Sentry } from '@oneblink/apps';
15
- import useIsMounted from '../../hooks/useIsMounted';
16
- function LookupNotificationComponent({ autoLookupValue, stringifyAutoLookupValue, element, onLookup, children, }) {
17
- const isMounted = useIsMounted();
18
- const isOffline = useIsOffline();
19
- const definition = useFormDefinition();
20
- const injectPagesAfter = useInjectPages();
21
- const { executedLookup, executeLookupFailed } = useExecutedLookupCallback();
22
- const [onCancelLookup, setOnCancelLookup] = React.useState(undefined);
23
- const [isLookingUp, setIsLookingUp] = React.useState(false);
24
- const [hasLookupFailed, setHasLookupFailed] = React.useState(false);
25
- const [hasLookupSucceeded, setHasLookupSucceeded] = React.useState(false);
26
- const [isCancellable, setIsCancellable] = React.useState(false);
27
- const [isDisabled, setIsDisabled] = React.useState(false);
28
- const [lookupErrorHTML, setLookupErrorHTML] = React.useState(null);
29
- const formIsReadOnly = useFormIsReadOnly();
30
- const { formSubmissionModel: model } = useFormSubmissionModel();
31
- const mergeLookupData = React.useCallback((newValue, dataLookupResult, elementLookupResult) => {
32
- if (elementLookupResult) {
33
- if (elementLookupResult[0] && elementLookupResult[0].type === 'page') {
34
- injectPagesAfter(element, elementLookupResult, dataLookupResult);
35
- return;
36
- }
37
- }
38
- onLookup(({ submission, elements }) => {
39
- let allElements = elements;
40
- if (Array.isArray(elementLookupResult)) {
41
- const indexOfElement = elements.findIndex(({ id }) => id === element.id);
42
- if (indexOfElement === -1) {
43
- console.log('Could not find element', element);
44
- }
45
- else {
46
- // Filter out already injected elements
47
- allElements = elements.filter(
48
- // @ts-expect-error Sorry typescript, we need to check a property you don't approve of :(
49
- (e) => e.injectedByElementId !== element.id);
50
- allElements.splice(indexOfElement + 1, 0, ...elementLookupResult.map((e) => {
51
- // @ts-expect-error Sorry typescript, we need to check a property you don't approve of :(
52
- e.injectedByElementId = element.id;
53
- return e;
54
- }));
55
- }
56
- }
57
- return {
58
- elements: allElements,
59
- submission: generateDefaultData(allElements, {
60
- ...submission,
61
- [element.name]: newValue,
62
- ...dataLookupResult,
63
- }),
64
- };
65
- });
66
- }, [element, injectPagesAfter, onLookup]);
67
- const triggerLookup = React.useCallback(async (newValue) => {
68
- // No lookups for read only forms
69
- if (formIsReadOnly)
70
- return;
71
- // if the element triggering the lookup has no value..
72
- // ..return and do nothing
73
- if (newValue === undefined || newValue === null)
74
- return;
75
- setIsLookingUp(true);
76
- if (isOffline) {
77
- setHasLookupFailed(true);
78
- return;
79
- }
80
- executedLookup(element);
81
- setIsDisabled(true);
82
- setIsCancellable(false);
83
- setHasLookupFailed(false);
84
- setHasLookupSucceeded(false);
85
- setLookupErrorHTML(null);
86
- const abortController = new AbortController();
87
- setOnCancelLookup(() => () => abortController.abort());
88
- // After certain amount of time, show the cancel button
89
- const isCancellableTimeout = setTimeout(() => {
90
- setIsCancellable(!abortController.signal.aborted);
91
- }, 5000);
92
- const payload = {
93
- definition,
94
- submission: {
95
- ...model,
96
- [element.name]: newValue,
97
- },
98
- };
99
- try {
100
- const [dataLookupResult, elementLookupResult] = await Promise.all([
101
- fetchLookup(element.dataLookupId, definition === null || definition === void 0 ? void 0 : definition.organisationId, definition === null || definition === void 0 ? void 0 : definition.formsAppEnvironmentId, payload, abortController.signal),
102
- fetchLookup(element.elementLookupId, definition === null || definition === void 0 ? void 0 : definition.organisationId, definition === null || definition === void 0 ? void 0 : definition.formsAppEnvironmentId, payload, abortController.signal),
103
- ]);
104
- mergeLookupData(newValue, dataLookupResult, elementLookupResult);
105
- if (isMounted.current) {
106
- setHasLookupSucceeded(true);
107
- }
108
- // After certain amount of time, hide the lookup succeeded message
109
- await new Promise((resolve) => setTimeout(() => resolve(false), 750));
110
- if (isMounted.current) {
111
- setIsLookingUp(false);
112
- }
113
- }
114
- catch (error) {
115
- executeLookupFailed(element);
116
- if (!isMounted.current) {
117
- return;
118
- }
119
- // Cancelling will throw an error.
120
- if (abortController.signal.aborted) {
121
- console.log('Fetch aborted');
122
- setIsLookingUp(false);
123
- return;
124
- }
125
- setHasLookupFailed(true);
126
- setLookupErrorHTML(typeof error === 'string'
127
- ? error
128
- : 'It looks like something went wrong.<br/>Please try again.<br />If the issue continues, please contact support.');
129
- }
130
- finally {
131
- clearTimeout(isCancellableTimeout);
132
- if (isMounted.current) {
133
- setIsDisabled(false);
134
- setOnCancelLookup(undefined);
135
- }
136
- }
137
- }, [
138
- definition,
139
- element,
140
- executeLookupFailed,
141
- executedLookup,
142
- formIsReadOnly,
143
- isMounted,
144
- isOffline,
145
- mergeLookupData,
146
- model,
147
- ]);
148
- // For certain elements, do not add click event
149
- // instead, watch model for changes and trigger lookup function.
150
- // We add this stringify function here to allow the value to be
151
- // an object which may have a reference change, but the values
152
- // have not changed. e.g. the 'location' element's value
153
- const autoLookupValueString = stringifyAutoLookupValue
154
- ? stringifyAutoLookupValue(autoLookupValue)
155
- : autoLookupValue;
156
- React.useEffect(() => {
157
- if (autoLookupValue !== undefined) {
158
- triggerLookup(autoLookupValue);
159
- }
160
- // Wants to use "triggerLookup" as a dependency,
161
- // however, this will change on any change made on any
162
- // element. Checking if "value" has changed is enough
163
- // to trigger a lookup when the correct dependencies change
164
- // eslint-disable-next-line react-hooks/exhaustive-deps
165
- }, [autoLookupValueString]);
166
- const contextValue = React.useMemo(() => ({
167
- isLookup: true,
168
- isDisabled,
169
- onLookup: triggerLookup,
170
- }), [isDisabled, triggerLookup]);
171
- return (React.createElement(LookupNotificationContext.Provider, { value: contextValue },
172
- children,
173
- React.createElement("div", { className: clsx('ob-lookup__notification', {
174
- 'is-looking-up': isLookingUp,
175
- 'is-extended': hasLookupFailed || (isCancellable && !hasLookupSucceeded),
176
- }) },
177
- React.createElement("div", { className: "notification has-margin-top-7 has-text-centered" },
178
- hasLookupFailed && (React.createElement(React.Fragment, null,
179
- React.createElement("button", { type: "button", className: "delete fade-in", onClick: () => setIsLookingUp(false) }),
180
- React.createElement("div", null, isOffline ? (React.createElement("div", null,
181
- React.createElement("i", { className: "material-icons fade-in has-text-warning" }, "wifi_off"),
182
- React.createElement("p", { className: "fade-in" }, "It looks like you're offline. Please try again when connectivity is restored."))) : (React.createElement("div", null,
183
- React.createElement("i", { className: "material-icons fade-in has-text-danger" }, "error_outline"),
184
- React.createElement("p", { className: "fade-in", dangerouslySetInnerHTML: {
185
- __html: lookupErrorHTML || '',
186
- }, "ng-bind-html": "$ctrl.obLookupCtrl.lookupErrorMessage" })))))),
187
- hasLookupSucceeded && (React.createElement("i", { className: "material-icons has-text-success fade-in" }, "check_circle_outline")),
188
- !hasLookupSucceeded && !hasLookupFailed && React.createElement(OnLoading, { small: true }),
189
- isCancellable && !hasLookupSucceeded && !hasLookupFailed && (React.createElement("div", { className: "has-margin-top-5 fade-in" },
190
- React.createElement("p", null, "Taking longer than expected?"),
191
- React.createElement("button", { type: "button", className: "button has-margin-top-8", onClick: onCancelLookup }, "Cancel")))))));
192
- }
193
- export default function LookupNotification(props) {
194
- if (props.element.isDataLookup || props.element.isElementLookup) {
195
- return React.createElement(LookupNotificationComponent, { ...props });
196
- }
197
- return React.createElement(React.Fragment, null, props.children);
198
- }
199
- async function fetchLookup(formElementLookupId, organisationId, formsAppEnvironmentId, payload, abortSignal) {
200
- if (typeof formElementLookupId !== 'number' ||
201
- !organisationId ||
202
- typeof formsAppEnvironmentId !== 'number') {
203
- return;
204
- }
205
- console.log('Attempting to retrieve form element lookup for id:', formElementLookupId);
206
- const formElementLookup = await formService.getFormElementLookupById(organisationId, formsAppEnvironmentId, formElementLookupId);
207
- if (!formElementLookup || !formElementLookup.url) {
208
- console.log('Could not find URL for form element lookup for id:', formElementLookupId, formElementLookup);
209
- throw new Error('Could not find element lookup configuration');
210
- }
211
- const headers = await generateHeaders();
212
- console.log(`Attempting a ${formElementLookup.type} lookup request to:`, formElementLookup.url);
213
- const response = await fetch(formElementLookup.url, {
214
- method: 'POST',
215
- headers,
216
- body: JSON.stringify(payload),
217
- signal: abortSignal,
218
- });
219
- const data = await response.json();
220
- console.log('Response from lookup to: POST', formElementLookup.url, response.status, data);
221
- if (!response.ok) {
222
- Sentry.captureException(new Error(`Received ${response.status} status code from lookup`));
223
- if (response.status === 400 && data && data.message) {
224
- throw data.message;
225
- }
226
- throw new Error('Invalid response from lookup');
227
- }
228
- return data;
229
- }
230
- // Validate that an element with a lookup has had the lookup button pressed if the element is required
1
+ import * as React from 'react';
2
+ import clsx from 'clsx';
3
+ import { formService } from '@oneblink/apps';
4
+ import { generateHeaders } from '@oneblink/apps/dist/services/fetch';
5
+ import useIsOffline from '../../hooks/useIsOffline';
6
+ import OnLoading from './OnLoading';
7
+ import generateDefaultData from '../../services/generate-default-data';
8
+ import { LookupNotificationContext } from '../../hooks/useLookupNotification';
9
+ import useFormDefinition from '../../hooks/useFormDefinition';
10
+ import useInjectPages from '../../hooks/useInjectPages';
11
+ import useFormSubmissionModel from '../../hooks/useFormSubmissionModelContext';
12
+ import useExecutedLookupCallback from '../../hooks/useExecutedLookupCallback';
13
+ import useFormIsReadOnly from '../../hooks/useFormIsReadOnly';
14
+ import { Sentry } from '@oneblink/apps';
15
+ import useIsMounted from '../../hooks/useIsMounted';
16
+ function LookupNotificationComponent({ autoLookupValue, stringifyAutoLookupValue, element, onLookup, children, }) {
17
+ const isMounted = useIsMounted();
18
+ const isOffline = useIsOffline();
19
+ const definition = useFormDefinition();
20
+ const injectPagesAfter = useInjectPages();
21
+ const { executedLookup, executeLookupFailed } = useExecutedLookupCallback();
22
+ const [onCancelLookup, setOnCancelLookup] = React.useState(undefined);
23
+ const [isLookingUp, setIsLookingUp] = React.useState(false);
24
+ const [hasLookupFailed, setHasLookupFailed] = React.useState(false);
25
+ const [hasLookupSucceeded, setHasLookupSucceeded] = React.useState(false);
26
+ const [isCancellable, setIsCancellable] = React.useState(false);
27
+ const [isDisabled, setIsDisabled] = React.useState(false);
28
+ const [lookupErrorHTML, setLookupErrorHTML] = React.useState(null);
29
+ const formIsReadOnly = useFormIsReadOnly();
30
+ const { formSubmissionModel: model } = useFormSubmissionModel();
31
+ const mergeLookupData = React.useCallback((newValue, dataLookupResult, elementLookupResult) => {
32
+ if (elementLookupResult) {
33
+ if (elementLookupResult[0] && elementLookupResult[0].type === 'page') {
34
+ injectPagesAfter(element, elementLookupResult, dataLookupResult);
35
+ return;
36
+ }
37
+ }
38
+ onLookup(({ submission, elements }) => {
39
+ let allElements = elements;
40
+ if (Array.isArray(elementLookupResult)) {
41
+ const indexOfElement = elements.findIndex(({ id }) => id === element.id);
42
+ if (indexOfElement === -1) {
43
+ console.log('Could not find element', element);
44
+ }
45
+ else {
46
+ // Filter out already injected elements
47
+ allElements = elements.filter(
48
+ // @ts-expect-error Sorry typescript, we need to check a property you don't approve of :(
49
+ (e) => e.injectedByElementId !== element.id);
50
+ allElements.splice(indexOfElement + 1, 0, ...elementLookupResult.map((e) => {
51
+ // @ts-expect-error Sorry typescript, we need to check a property you don't approve of :(
52
+ e.injectedByElementId = element.id;
53
+ return e;
54
+ }));
55
+ }
56
+ }
57
+ return {
58
+ elements: allElements,
59
+ submission: generateDefaultData(allElements, {
60
+ ...submission,
61
+ [element.name]: newValue,
62
+ ...dataLookupResult,
63
+ }),
64
+ };
65
+ });
66
+ }, [element, injectPagesAfter, onLookup]);
67
+ const triggerLookup = React.useCallback(async (newValue) => {
68
+ // No lookups for read only forms
69
+ if (formIsReadOnly)
70
+ return;
71
+ // if the element triggering the lookup has no value..
72
+ // ..return and do nothing
73
+ if (newValue === undefined || newValue === null)
74
+ return;
75
+ setIsLookingUp(true);
76
+ if (isOffline) {
77
+ setHasLookupFailed(true);
78
+ return;
79
+ }
80
+ executedLookup(element);
81
+ setIsDisabled(true);
82
+ setIsCancellable(false);
83
+ setHasLookupFailed(false);
84
+ setHasLookupSucceeded(false);
85
+ setLookupErrorHTML(null);
86
+ const abortController = new AbortController();
87
+ setOnCancelLookup(() => () => abortController.abort());
88
+ // After certain amount of time, show the cancel button
89
+ const isCancellableTimeout = setTimeout(() => {
90
+ setIsCancellable(!abortController.signal.aborted);
91
+ }, 5000);
92
+ const payload = {
93
+ definition,
94
+ submission: {
95
+ ...model,
96
+ [element.name]: newValue,
97
+ },
98
+ };
99
+ try {
100
+ const [dataLookupResult, elementLookupResult] = await Promise.all([
101
+ fetchLookup(element.dataLookupId, definition === null || definition === void 0 ? void 0 : definition.organisationId, definition === null || definition === void 0 ? void 0 : definition.formsAppEnvironmentId, payload, abortController.signal),
102
+ fetchLookup(element.elementLookupId, definition === null || definition === void 0 ? void 0 : definition.organisationId, definition === null || definition === void 0 ? void 0 : definition.formsAppEnvironmentId, payload, abortController.signal),
103
+ ]);
104
+ mergeLookupData(newValue, dataLookupResult, elementLookupResult);
105
+ if (isMounted.current) {
106
+ setHasLookupSucceeded(true);
107
+ }
108
+ // After certain amount of time, hide the lookup succeeded message
109
+ await new Promise((resolve) => setTimeout(() => resolve(false), 750));
110
+ if (isMounted.current) {
111
+ setIsLookingUp(false);
112
+ }
113
+ }
114
+ catch (error) {
115
+ executeLookupFailed(element);
116
+ if (!isMounted.current) {
117
+ return;
118
+ }
119
+ // Cancelling will throw an error.
120
+ if (abortController.signal.aborted) {
121
+ console.log('Fetch aborted');
122
+ setIsLookingUp(false);
123
+ return;
124
+ }
125
+ setHasLookupFailed(true);
126
+ setLookupErrorHTML(typeof error === 'string'
127
+ ? error
128
+ : 'It looks like something went wrong.<br/>Please try again.<br />If the issue continues, please contact support.');
129
+ }
130
+ finally {
131
+ clearTimeout(isCancellableTimeout);
132
+ if (isMounted.current) {
133
+ setIsDisabled(false);
134
+ setOnCancelLookup(undefined);
135
+ }
136
+ }
137
+ }, [
138
+ definition,
139
+ element,
140
+ executeLookupFailed,
141
+ executedLookup,
142
+ formIsReadOnly,
143
+ isMounted,
144
+ isOffline,
145
+ mergeLookupData,
146
+ model,
147
+ ]);
148
+ // For certain elements, do not add click event
149
+ // instead, watch model for changes and trigger lookup function.
150
+ // We add this stringify function here to allow the value to be
151
+ // an object which may have a reference change, but the values
152
+ // have not changed. e.g. the 'location' element's value
153
+ const autoLookupValueString = stringifyAutoLookupValue
154
+ ? stringifyAutoLookupValue(autoLookupValue)
155
+ : autoLookupValue;
156
+ React.useEffect(() => {
157
+ if (autoLookupValue !== undefined) {
158
+ triggerLookup(autoLookupValue);
159
+ }
160
+ // Wants to use "triggerLookup" as a dependency,
161
+ // however, this will change on any change made on any
162
+ // element. Checking if "value" has changed is enough
163
+ // to trigger a lookup when the correct dependencies change
164
+ // eslint-disable-next-line react-hooks/exhaustive-deps
165
+ }, [autoLookupValueString]);
166
+ const contextValue = React.useMemo(() => ({
167
+ isLookup: true,
168
+ isDisabled,
169
+ onLookup: triggerLookup,
170
+ }), [isDisabled, triggerLookup]);
171
+ return (React.createElement(LookupNotificationContext.Provider, { value: contextValue },
172
+ children,
173
+ React.createElement("div", { className: clsx('ob-lookup__notification', {
174
+ 'is-looking-up': isLookingUp,
175
+ 'is-extended': hasLookupFailed || (isCancellable && !hasLookupSucceeded),
176
+ }) },
177
+ React.createElement("div", { className: "notification has-margin-top-7 has-text-centered" },
178
+ hasLookupFailed && (React.createElement(React.Fragment, null,
179
+ React.createElement("button", { type: "button", className: "delete fade-in", onClick: () => setIsLookingUp(false) }),
180
+ React.createElement("div", null, isOffline ? (React.createElement("div", null,
181
+ React.createElement("i", { className: "material-icons fade-in has-text-warning" }, "wifi_off"),
182
+ React.createElement("p", { className: "fade-in" }, "It looks like you're offline. Please try again when connectivity is restored."))) : (React.createElement("div", null,
183
+ React.createElement("i", { className: "material-icons fade-in has-text-danger" }, "error_outline"),
184
+ React.createElement("p", { className: "fade-in", dangerouslySetInnerHTML: {
185
+ __html: lookupErrorHTML || '',
186
+ }, "ng-bind-html": "$ctrl.obLookupCtrl.lookupErrorMessage" })))))),
187
+ hasLookupSucceeded && (React.createElement("i", { className: "material-icons has-text-success fade-in" }, "check_circle_outline")),
188
+ !hasLookupSucceeded && !hasLookupFailed && React.createElement(OnLoading, { small: true }),
189
+ isCancellable && !hasLookupSucceeded && !hasLookupFailed && (React.createElement("div", { className: "has-margin-top-5 fade-in" },
190
+ React.createElement("p", null, "Taking longer than expected?"),
191
+ React.createElement("button", { type: "button", className: "button has-margin-top-8", onClick: onCancelLookup }, "Cancel")))))));
192
+ }
193
+ export default function LookupNotification(props) {
194
+ if (props.element.isDataLookup || props.element.isElementLookup) {
195
+ return React.createElement(LookupNotificationComponent, { ...props });
196
+ }
197
+ return React.createElement(React.Fragment, null, props.children);
198
+ }
199
+ async function fetchLookup(formElementLookupId, organisationId, formsAppEnvironmentId, payload, abortSignal) {
200
+ if (typeof formElementLookupId !== 'number' ||
201
+ !organisationId ||
202
+ typeof formsAppEnvironmentId !== 'number') {
203
+ return;
204
+ }
205
+ console.log('Attempting to retrieve form element lookup for id:', formElementLookupId);
206
+ const formElementLookup = await formService.getFormElementLookupById(organisationId, formsAppEnvironmentId, formElementLookupId);
207
+ if (!formElementLookup || !formElementLookup.url) {
208
+ console.log('Could not find URL for form element lookup for id:', formElementLookupId, formElementLookup);
209
+ throw new Error('Could not find element lookup configuration');
210
+ }
211
+ const headers = await generateHeaders();
212
+ console.log(`Attempting a ${formElementLookup.type} lookup request to:`, formElementLookup.url);
213
+ const response = await fetch(formElementLookup.url, {
214
+ method: 'POST',
215
+ headers,
216
+ body: JSON.stringify(payload),
217
+ signal: abortSignal,
218
+ });
219
+ const data = await response.json();
220
+ console.log('Response from lookup to: POST', formElementLookup.url, response.status, data);
221
+ if (!response.ok) {
222
+ Sentry.captureException(new Error(`Received ${response.status} status code from lookup`));
223
+ if (response.status === 400 && data && data.message) {
224
+ throw data.message;
225
+ }
226
+ throw new Error('Invalid response from lookup');
227
+ }
228
+ return data;
229
+ }
230
+ // Validate that an element with a lookup has had the lookup button pressed if the element is required
231
231
  //# sourceMappingURL=LookupNotification.js.map
@@ -1,14 +1,14 @@
1
- import * as React from 'react';
2
- declare type Props = {
3
- isOpen: boolean;
4
- title: string;
5
- children: React.ReactNode;
6
- actions: React.ReactNode | null;
7
- className?: string;
8
- cardClassName?: string;
9
- titleClassName?: string;
10
- bodyClassName?: string;
11
- };
12
- declare function Modal({ isOpen, title, children, className, cardClassName, titleClassName, bodyClassName, actions, }: Props): JSX.Element;
13
- declare const _default: React.MemoExoticComponent<typeof Modal>;
14
- export default _default;
1
+ import * as React from 'react';
2
+ declare type Props = {
3
+ isOpen: boolean;
4
+ title: string;
5
+ children: React.ReactNode;
6
+ actions: React.ReactNode | null;
7
+ className?: string;
8
+ cardClassName?: string;
9
+ titleClassName?: string;
10
+ bodyClassName?: string;
11
+ };
12
+ declare function Modal({ isOpen, title, children, className, cardClassName, titleClassName, bodyClassName, actions, }: Props): JSX.Element;
13
+ declare const _default: React.MemoExoticComponent<typeof Modal>;
14
+ export default _default;
@@ -1,15 +1,15 @@
1
- import * as React from 'react';
2
- import clsx from 'clsx';
3
- function Modal({ isOpen, title, children, className, cardClassName, titleClassName, bodyClassName, actions, }) {
4
- return (React.createElement("div", { className: clsx('modal ob-modal', className, {
5
- 'is-active': isOpen,
6
- }) },
7
- React.createElement("div", { className: "modal-background-faded" }),
8
- React.createElement("div", { className: clsx('modal-card', cardClassName) },
9
- React.createElement("header", { className: "modal-card-head" },
10
- React.createElement("p", { className: clsx('modal-card-title', titleClassName) }, title)),
11
- React.createElement("section", { className: clsx('modal-card-body', bodyClassName) }, children),
12
- actions && React.createElement("footer", { className: "modal-card-foot" }, actions))));
13
- }
14
- export default React.memo(Modal);
1
+ import * as React from 'react';
2
+ import clsx from 'clsx';
3
+ function Modal({ isOpen, title, children, className, cardClassName, titleClassName, bodyClassName, actions, }) {
4
+ return (React.createElement("div", { className: clsx('modal ob-modal', className, {
5
+ 'is-active': isOpen,
6
+ }) },
7
+ React.createElement("div", { className: "modal-background-faded" }),
8
+ React.createElement("div", { className: clsx('modal-card', cardClassName) },
9
+ React.createElement("header", { className: "modal-card-head" },
10
+ React.createElement("p", { className: clsx('modal-card-title', titleClassName) }, title)),
11
+ React.createElement("section", { className: clsx('modal-card-body', bodyClassName) }, children),
12
+ actions && React.createElement("footer", { className: "modal-card-foot" }, actions))));
13
+ }
14
+ export default React.memo(Modal);
15
15
  //# sourceMappingURL=Modal.js.map
@@ -1,10 +1,10 @@
1
- import * as React from 'react';
2
- declare type Props = {
3
- className?: string;
4
- small?: boolean;
5
- large?: boolean;
6
- tiny?: boolean;
7
- };
8
- declare function OnLoading({ className, small, large, tiny }: Props): JSX.Element;
9
- declare const _default: React.MemoExoticComponent<typeof OnLoading>;
10
- export default _default;
1
+ import * as React from 'react';
2
+ declare type Props = {
3
+ className?: string;
4
+ small?: boolean;
5
+ large?: boolean;
6
+ tiny?: boolean;
7
+ };
8
+ declare function OnLoading({ className, small, large, tiny }: Props): JSX.Element;
9
+ declare const _default: React.MemoExoticComponent<typeof OnLoading>;
10
+ export default _default;
@@ -1,12 +1,12 @@
1
- import * as React from 'react';
2
- import clsx from 'clsx';
3
- function OnLoading({ className, small, large, tiny }) {
4
- return (React.createElement("on-loading", { className: className },
5
- React.createElement("div", { className: clsx('ob-loading on-loading', {
6
- small: small,
7
- large: large,
8
- tiny: tiny,
9
- }) })));
10
- }
11
- export default React.memo(OnLoading);
1
+ import * as React from 'react';
2
+ import clsx from 'clsx';
3
+ function OnLoading({ className, small, large, tiny }) {
4
+ return (React.createElement("on-loading", { className: className },
5
+ React.createElement("div", { className: clsx('ob-loading on-loading', {
6
+ small: small,
7
+ large: large,
8
+ tiny: tiny,
9
+ }) })));
10
+ }
11
+ export default React.memo(OnLoading);
12
12
  //# sourceMappingURL=OnLoading.js.map
@@ -1,7 +1,7 @@
1
- import * as React from 'react';
2
- declare type Props = {
3
- error?: Error;
4
- };
5
- declare function OneBlinkAppsErrorOriginalMessage({ error }: Props): JSX.Element | null;
6
- declare const _default: React.MemoExoticComponent<typeof OneBlinkAppsErrorOriginalMessage>;
7
- export default _default;
1
+ import * as React from 'react';
2
+ declare type Props = {
3
+ error?: Error;
4
+ };
5
+ declare function OneBlinkAppsErrorOriginalMessage({ error }: Props): JSX.Element | null;
6
+ declare const _default: React.MemoExoticComponent<typeof OneBlinkAppsErrorOriginalMessage>;
7
+ export default _default;
@@ -1,13 +1,13 @@
1
- import * as React from 'react';
2
- import { OneBlinkAppsError } from '@oneblink/apps';
3
- function OneBlinkAppsErrorOriginalMessage({ error }) {
4
- if (!error) {
5
- return null;
6
- }
7
- return (React.createElement(React.Fragment, null,
8
- React.createElement("div", { className: "content has-margin-top-6" },
9
- React.createElement("pre", null, error.message)),
10
- error instanceof OneBlinkAppsError && (React.createElement(OneBlinkAppsErrorOriginalMessage, { error: error.originalError }))));
11
- }
12
- export default React.memo(OneBlinkAppsErrorOriginalMessage);
1
+ import * as React from 'react';
2
+ import { OneBlinkAppsError } from '@oneblink/apps';
3
+ function OneBlinkAppsErrorOriginalMessage({ error }) {
4
+ if (!error) {
5
+ return null;
6
+ }
7
+ return (React.createElement(React.Fragment, null,
8
+ React.createElement("div", { className: "content has-margin-top-6" },
9
+ React.createElement("pre", null, error.message)),
10
+ error instanceof OneBlinkAppsError && (React.createElement(OneBlinkAppsErrorOriginalMessage, { error: error.originalError }))));
11
+ }
12
+ export default React.memo(OneBlinkAppsErrorOriginalMessage);
13
13
  //# sourceMappingURL=OneBlinkAppsErrorOriginalMessage.js.map