@defra/forms-engine-plugin 4.7.2 → 4.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (407) hide show
  1. package/.public/javascripts/shared.min.js +1 -1
  2. package/.public/javascripts/shared.min.js.map +1 -1
  3. package/.server/client/javascripts/geospatial-map.d.ts +6 -6
  4. package/.server/client/javascripts/geospatial-map.js +3 -3
  5. package/.server/client/javascripts/location-map.d.ts +1 -1
  6. package/.server/client/javascripts/location-map.js +1 -1
  7. package/.server/client/javascripts/map.d.ts +5 -1
  8. package/.server/client/javascripts/map.js +10 -2
  9. package/.server/client/javascripts/map.js.map +1 -1
  10. package/.server/client/javascripts/shared.d.ts +7 -7
  11. package/.server/server/index.d.ts +1 -1
  12. package/.server/server/plugins/crumb.d.ts +1 -1
  13. package/.server/server/plugins/engine/beta/form-context.d.ts +6 -6
  14. package/.server/server/plugins/engine/components/AutocompleteField.d.ts +4 -4
  15. package/.server/server/plugins/engine/components/CheckboxesField.d.ts +2 -2
  16. package/.server/server/plugins/engine/components/CheckboxesField.js +2 -2
  17. package/.server/server/plugins/engine/components/CheckboxesField.js.map +1 -1
  18. package/.server/server/plugins/engine/components/ComponentBase.d.ts +5 -5
  19. package/.server/server/plugins/engine/components/ComponentCollection.d.ts +8 -8
  20. package/.server/server/plugins/engine/components/DatePartsField.d.ts +11 -11
  21. package/.server/server/plugins/engine/components/DeclarationField.d.ts +3 -3
  22. package/.server/server/plugins/engine/components/Details.d.ts +1 -1
  23. package/.server/server/plugins/engine/components/EastingNorthingField.d.ts +22 -22
  24. package/.server/server/plugins/engine/components/EmailAddressField.d.ts +4 -4
  25. package/.server/server/plugins/engine/components/FileUploadField.d.ts +3 -3
  26. package/.server/server/plugins/engine/components/FormComponent.d.ts +10 -10
  27. package/.server/server/plugins/engine/components/GeospatialField.d.ts +6 -6
  28. package/.server/server/plugins/engine/components/HiddenField.d.ts +2 -2
  29. package/.server/server/plugins/engine/components/Html.d.ts +1 -1
  30. package/.server/server/plugins/engine/components/InsetText.d.ts +1 -1
  31. package/.server/server/plugins/engine/components/LatLongField.d.ts +22 -22
  32. package/.server/server/plugins/engine/components/List.d.ts +8 -8
  33. package/.server/server/plugins/engine/components/ListFormComponent.d.ts +10 -10
  34. package/.server/server/plugins/engine/components/LocationFieldBase.d.ts +6 -6
  35. package/.server/server/plugins/engine/components/LocationFieldHelpers.d.ts +14 -14
  36. package/.server/server/plugins/engine/components/Markdown.d.ts +1 -1
  37. package/.server/server/plugins/engine/components/MonthYearField.d.ts +11 -11
  38. package/.server/server/plugins/engine/components/MultilineTextField.d.ts +5 -5
  39. package/.server/server/plugins/engine/components/NationalGridFieldNumberField.d.ts +1 -1
  40. package/.server/server/plugins/engine/components/NumberField.d.ts +3 -3
  41. package/.server/server/plugins/engine/components/OsGridRefField.d.ts +1 -1
  42. package/.server/server/plugins/engine/components/PaymentField.d.ts +12 -12
  43. package/.server/server/plugins/engine/components/RadiosField.d.ts +1 -1
  44. package/.server/server/plugins/engine/components/SelectField.d.ts +4 -4
  45. package/.server/server/plugins/engine/components/SelectionControlField.d.ts +10 -10
  46. package/.server/server/plugins/engine/components/TelephoneNumberField.d.ts +4 -4
  47. package/.server/server/plugins/engine/components/TextField.d.ts +2 -2
  48. package/.server/server/plugins/engine/components/UkAddressField.d.ts +11 -11
  49. package/.server/server/plugins/engine/components/YesNoField.d.ts +2 -2
  50. package/.server/server/plugins/engine/components/helpers/__stubs__/geospatial.d.ts +1 -1
  51. package/.server/server/plugins/engine/components/helpers/components.d.ts +5 -5
  52. package/.server/server/plugins/engine/components/helpers/geospatial.d.ts +1 -1
  53. package/.server/server/plugins/engine/components/index.d.ts +27 -27
  54. package/.server/server/plugins/engine/components/types.d.ts +1 -1
  55. package/.server/server/plugins/engine/configureEnginePlugin.d.ts +4 -4
  56. package/.server/server/plugins/engine/date-helper.d.ts +1 -1
  57. package/.server/server/plugins/engine/helpers.d.ts +8 -8
  58. package/.server/server/plugins/engine/index.d.ts +5 -5
  59. package/.server/server/plugins/engine/models/FormModel.d.ts +6 -6
  60. package/.server/server/plugins/engine/models/SummaryViewModel.d.ts +6 -6
  61. package/.server/server/plugins/engine/models/index.d.ts +2 -2
  62. package/.server/server/plugins/engine/models/types.d.ts +4 -4
  63. package/.server/server/plugins/engine/options.d.ts +1 -1
  64. package/.server/server/plugins/engine/options.js +1 -1
  65. package/.server/server/plugins/engine/options.test.js +1 -1
  66. package/.server/server/plugins/engine/outputFormatters/adapter/v1.d.ts +4 -4
  67. package/.server/server/plugins/engine/outputFormatters/human/v1.d.ts +4 -4
  68. package/.server/server/plugins/engine/outputFormatters/index.d.ts +5 -5
  69. package/.server/server/plugins/engine/outputFormatters/machine/v1.d.ts +4 -4
  70. package/.server/server/plugins/engine/outputFormatters/machine/v2.d.ts +4 -4
  71. package/.server/server/plugins/engine/pageControllers/FileUploadPageController.d.ts +8 -8
  72. package/.server/server/plugins/engine/pageControllers/PageController.d.ts +6 -6
  73. package/.server/server/plugins/engine/pageControllers/QuestionPageController.d.ts +8 -8
  74. package/.server/server/plugins/engine/pageControllers/RepeatPageController.d.ts +5 -5
  75. package/.server/server/plugins/engine/pageControllers/StartPageController.d.ts +4 -4
  76. package/.server/server/plugins/engine/pageControllers/StatusPageController.d.ts +4 -4
  77. package/.server/server/plugins/engine/pageControllers/SummaryPageController.d.ts +5 -5
  78. package/.server/server/plugins/engine/pageControllers/TerminalPageController.d.ts +3 -3
  79. package/.server/server/plugins/engine/pageControllers/__stubs__/request.d.ts +2 -2
  80. package/.server/server/plugins/engine/pageControllers/errors.d.ts +1 -1
  81. package/.server/server/plugins/engine/pageControllers/helpers/pages.d.ts +2 -2
  82. package/.server/server/plugins/engine/pageControllers/helpers/state.d.ts +5 -5
  83. package/.server/server/plugins/engine/pageControllers/helpers/state.js +1 -1
  84. package/.server/server/plugins/engine/pageControllers/helpers/state.js.map +1 -1
  85. package/.server/server/plugins/engine/pageControllers/helpers/submission.d.ts +1 -1
  86. package/.server/server/plugins/engine/pageControllers/index.d.ts +7 -7
  87. package/.server/server/plugins/engine/plugin.d.ts +1 -1
  88. package/.server/server/plugins/engine/routes/file-upload.d.ts +1 -1
  89. package/.server/server/plugins/engine/routes/index.d.ts +3 -3
  90. package/.server/server/plugins/engine/routes/payment-helper.d.ts +3 -3
  91. package/.server/server/plugins/engine/routes/payment-helper.js +2 -2
  92. package/.server/server/plugins/engine/routes/payment.js +5 -5
  93. package/.server/server/plugins/engine/routes/payment.test.js +1 -1
  94. package/.server/server/plugins/engine/routes/questions.d.ts +2 -2
  95. package/.server/server/plugins/engine/routes/repeaters/item-delete.d.ts +2 -2
  96. package/.server/server/plugins/engine/routes/repeaters/summary.d.ts +2 -2
  97. package/.server/server/plugins/engine/services/index.d.ts +3 -3
  98. package/.server/server/plugins/engine/services/notifyService.d.ts +4 -4
  99. package/.server/server/plugins/engine/services/uploadService.d.ts +2 -2
  100. package/.server/server/plugins/engine/services/uploadService.js +1 -1
  101. package/.server/server/plugins/engine/types/index.d.ts +10 -10
  102. package/.server/server/plugins/engine/types/schema.d.ts +1 -1
  103. package/.server/server/plugins/engine/types.d.ts +25 -16
  104. package/.server/server/plugins/engine/types.js.map +1 -1
  105. package/.server/server/plugins/engine/validationHelpers.d.ts +2 -2
  106. package/.server/server/plugins/engine/vision.d.ts +1 -1
  107. package/.server/server/plugins/map/index.d.ts +1 -1
  108. package/.server/server/plugins/map/index.js +1 -1
  109. package/.server/server/plugins/map/routes/get-os-token.d.ts +11 -1
  110. package/.server/server/plugins/map/routes/get-os-token.js +12 -2
  111. package/.server/server/plugins/map/routes/get-os-token.js.map +1 -1
  112. package/.server/server/plugins/map/routes/index.d.ts +4 -4
  113. package/.server/server/plugins/map/routes/index.js +3 -2
  114. package/.server/server/plugins/map/routes/index.js.map +1 -1
  115. package/.server/server/plugins/map/routes/vts/esri-aerial.json +23 -0
  116. package/.server/server/plugins/map/service.d.ts +1 -1
  117. package/.server/server/plugins/map/service.js +5 -2
  118. package/.server/server/plugins/map/service.js.map +1 -1
  119. package/.server/server/plugins/map/test/__stubs__/find.d.ts +1 -1
  120. package/.server/server/plugins/map/test/__stubs__/find.js +1 -1
  121. package/.server/server/plugins/nunjucks/context.d.ts +2 -2
  122. package/.server/server/plugins/nunjucks/context.js +2 -2
  123. package/.server/server/plugins/nunjucks/context.test.js +1 -1
  124. package/.server/server/plugins/nunjucks/enviroment.test.js +1 -1
  125. package/.server/server/plugins/nunjucks/environment.d.ts +3 -3
  126. package/.server/server/plugins/nunjucks/environment.js +3 -3
  127. package/.server/server/plugins/nunjucks/filters/answer.d.ts +1 -1
  128. package/.server/server/plugins/nunjucks/filters/answer.js +2 -2
  129. package/.server/server/plugins/nunjucks/filters/answer.test.js +1 -1
  130. package/.server/server/plugins/nunjucks/filters/evaluate.d.ts +1 -1
  131. package/.server/server/plugins/nunjucks/filters/evaluate.js +1 -1
  132. package/.server/server/plugins/nunjucks/filters/field.d.ts +1 -1
  133. package/.server/server/plugins/nunjucks/filters/field.js +1 -1
  134. package/.server/server/plugins/nunjucks/filters/field.test.js +1 -1
  135. package/.server/server/plugins/nunjucks/filters/href.d.ts +1 -1
  136. package/.server/server/plugins/nunjucks/filters/href.js +1 -1
  137. package/.server/server/plugins/nunjucks/filters/href.test.js +1 -1
  138. package/.server/server/plugins/nunjucks/filters/index.d.ts +8 -8
  139. package/.server/server/plugins/nunjucks/filters/page.d.ts +1 -1
  140. package/.server/server/plugins/nunjucks/filters/page.js +1 -1
  141. package/.server/server/plugins/nunjucks/filters/page.test.js +1 -1
  142. package/.server/server/plugins/nunjucks/index.d.ts +3 -3
  143. package/.server/server/plugins/nunjucks/render.d.ts +2 -2
  144. package/.server/server/plugins/nunjucks/render.js +1 -1
  145. package/.server/server/plugins/nunjucks/types.d.ts +1 -1
  146. package/.server/server/plugins/nunjucks/types.js +1 -1
  147. package/.server/server/plugins/payment/helper.d.ts +2 -2
  148. package/.server/server/plugins/payment/helper.js +1 -1
  149. package/.server/server/plugins/payment/service.d.ts +3 -3
  150. package/.server/server/plugins/payment/service.js +1 -1
  151. package/.server/server/plugins/postcode-lookup/index.d.ts +1 -1
  152. package/.server/server/plugins/postcode-lookup/index.js +1 -1
  153. package/.server/server/plugins/postcode-lookup/models/index.d.ts +6 -6
  154. package/.server/server/plugins/postcode-lookup/models/index.js +1 -1
  155. package/.server/server/plugins/postcode-lookup/routes/index.d.ts +6 -6
  156. package/.server/server/plugins/postcode-lookup/routes/index.js +15 -15
  157. package/.server/server/plugins/postcode-lookup/routes/index.js.map +1 -1
  158. package/.server/server/plugins/postcode-lookup/service.d.ts +1 -1
  159. package/.server/server/plugins/postcode-lookup/service.js +5 -2
  160. package/.server/server/plugins/postcode-lookup/service.js.map +1 -1
  161. package/.server/server/plugins/postcode-lookup/types.js +1 -1
  162. package/.server/server/routes/index.d.ts +2 -2
  163. package/.server/server/routes/types.d.ts +1 -1
  164. package/.server/server/schemas/index.d.ts +2 -2
  165. package/.server/server/services/cacheService.d.ts +8 -8
  166. package/.server/server/services/cacheService.js +2 -5
  167. package/.server/server/services/cacheService.js.map +1 -1
  168. package/.server/server/services/httpService.test.js +1 -1
  169. package/.server/server/services/index.d.ts +1 -1
  170. package/.server/server/types.d.ts +7 -7
  171. package/.server/server/utils/file-form-service.d.ts +2 -2
  172. package/.server/server/utils/file-form-service.js +1 -1
  173. package/package.json +8 -4
  174. package/src/client/javascripts/application.js +1 -1
  175. package/src/client/javascripts/geospatial-map.js +4 -4
  176. package/src/client/javascripts/location-map.js +2 -2
  177. package/src/client/javascripts/map.js +13 -4
  178. package/src/client/javascripts/shared.js +7 -7
  179. package/src/index.ts +3 -3
  180. package/src/server/common/helpers/logging/logger-options.ts +1 -1
  181. package/src/server/common/helpers/logging/logger.ts +1 -1
  182. package/src/server/common/helpers/logging/request-logger.ts +1 -1
  183. package/src/server/common/helpers/logging/request-tracing.js +1 -1
  184. package/src/server/common/helpers/redis-client.js +2 -2
  185. package/src/server/index.ts +13 -13
  186. package/src/server/plugins/crumb.ts +2 -2
  187. package/src/server/plugins/engine/beta/form-context.ts +9 -9
  188. package/src/server/plugins/engine/components/AutocompleteField.ts +3 -3
  189. package/src/server/plugins/engine/components/CheckboxesField.ts +7 -8
  190. package/src/server/plugins/engine/components/ComponentBase.ts +5 -5
  191. package/src/server/plugins/engine/components/ComponentCollection.ts +9 -9
  192. package/src/server/plugins/engine/components/DatePartsField.ts +8 -8
  193. package/src/server/plugins/engine/components/DeclarationField.ts +3 -3
  194. package/src/server/plugins/engine/components/Details.ts +1 -1
  195. package/src/server/plugins/engine/components/EastingNorthingField.ts +9 -9
  196. package/src/server/plugins/engine/components/EmailAddressField.ts +3 -3
  197. package/src/server/plugins/engine/components/FileUploadField.ts +6 -6
  198. package/src/server/plugins/engine/components/FormComponent.ts +4 -4
  199. package/src/server/plugins/engine/components/GeospatialField.ts +5 -5
  200. package/src/server/plugins/engine/components/HiddenField.ts +4 -4
  201. package/src/server/plugins/engine/components/Html.ts +1 -1
  202. package/src/server/plugins/engine/components/InsetText.ts +1 -1
  203. package/src/server/plugins/engine/components/LatLongField.ts +9 -9
  204. package/src/server/plugins/engine/components/List.ts +2 -2
  205. package/src/server/plugins/engine/components/ListFormComponent.ts +4 -4
  206. package/src/server/plugins/engine/components/LocationFieldBase.ts +5 -5
  207. package/src/server/plugins/engine/components/LocationFieldHelpers.ts +5 -5
  208. package/src/server/plugins/engine/components/Markdown.ts +1 -1
  209. package/src/server/plugins/engine/components/MonthYearField.ts +8 -8
  210. package/src/server/plugins/engine/components/MultilineTextField.ts +4 -4
  211. package/src/server/plugins/engine/components/NationalGridFieldNumberField.ts +2 -2
  212. package/src/server/plugins/engine/components/NumberField.ts +3 -3
  213. package/src/server/plugins/engine/components/OsGridRefField.ts +2 -2
  214. package/src/server/plugins/engine/components/PaymentField.ts +8 -8
  215. package/src/server/plugins/engine/components/RadiosField.ts +1 -1
  216. package/src/server/plugins/engine/components/SelectField.ts +2 -2
  217. package/src/server/plugins/engine/components/SelectionControlField.ts +4 -4
  218. package/src/server/plugins/engine/components/TelephoneNumberField.ts +4 -4
  219. package/src/server/plugins/engine/components/TextField.ts +3 -3
  220. package/src/server/plugins/engine/components/UkAddressField.ts +7 -7
  221. package/src/server/plugins/engine/components/YesNoField.ts +5 -5
  222. package/src/server/plugins/engine/components/helpers/__stubs__/geospatial.ts +1 -1
  223. package/src/server/plugins/engine/components/helpers/components.ts +8 -8
  224. package/src/server/plugins/engine/components/helpers/geospatial.ts +1 -1
  225. package/src/server/plugins/engine/components/index.ts +27 -27
  226. package/src/server/plugins/engine/components/types.ts +1 -1
  227. package/src/server/plugins/engine/configureEnginePlugin.ts +10 -10
  228. package/src/server/plugins/engine/date-helper.ts +1 -1
  229. package/src/server/plugins/engine/helpers.ts +8 -8
  230. package/src/server/plugins/engine/index.ts +8 -8
  231. package/src/server/plugins/engine/models/FormModel.ts +15 -15
  232. package/src/server/plugins/engine/models/SummaryViewModel.ts +10 -10
  233. package/src/server/plugins/engine/models/index.ts +2 -2
  234. package/src/server/plugins/engine/models/types.ts +4 -4
  235. package/src/server/plugins/engine/options.js +3 -3
  236. package/src/server/plugins/engine/outputFormatters/adapter/v1.ts +6 -6
  237. package/src/server/plugins/engine/outputFormatters/human/v1.ts +9 -9
  238. package/src/server/plugins/engine/outputFormatters/index.ts +8 -8
  239. package/src/server/plugins/engine/outputFormatters/machine/v1.ts +7 -7
  240. package/src/server/plugins/engine/outputFormatters/machine/v2.ts +6 -6
  241. package/src/server/plugins/engine/pageControllers/FileUploadPageController.ts +9 -9
  242. package/src/server/plugins/engine/pageControllers/PageController.ts +7 -7
  243. package/src/server/plugins/engine/pageControllers/QuestionPageController.ts +13 -13
  244. package/src/server/plugins/engine/pageControllers/RepeatPageController.ts +6 -6
  245. package/src/server/plugins/engine/pageControllers/StartPageController.ts +3 -3
  246. package/src/server/plugins/engine/pageControllers/StatusPageController.ts +5 -5
  247. package/src/server/plugins/engine/pageControllers/SummaryPageController.ts +12 -12
  248. package/src/server/plugins/engine/pageControllers/TerminalPageController.ts +3 -3
  249. package/src/server/plugins/engine/pageControllers/__stubs__/request.ts +3 -3
  250. package/src/server/plugins/engine/pageControllers/__stubs__/server.ts +2 -2
  251. package/src/server/plugins/engine/pageControllers/errors.ts +1 -1
  252. package/src/server/plugins/engine/pageControllers/helpers/pages.ts +2 -2
  253. package/src/server/plugins/engine/pageControllers/helpers/state.ts +9 -9
  254. package/src/server/plugins/engine/pageControllers/helpers/submission.ts +5 -5
  255. package/src/server/plugins/engine/pageControllers/index.ts +7 -7
  256. package/src/server/plugins/engine/pageControllers/validationOptions.ts +1 -1
  257. package/src/server/plugins/engine/plugin.ts +14 -14
  258. package/src/server/plugins/engine/routes/file-upload.ts +2 -2
  259. package/src/server/plugins/engine/routes/index.ts +10 -10
  260. package/src/server/plugins/engine/routes/payment-helper.js +4 -4
  261. package/src/server/plugins/engine/routes/payment.js +9 -9
  262. package/src/server/plugins/engine/routes/questions.ts +10 -10
  263. package/src/server/plugins/engine/routes/repeaters/item-delete.ts +6 -6
  264. package/src/server/plugins/engine/routes/repeaters/summary.ts +5 -5
  265. package/src/server/plugins/engine/services/formSubmissionService.js +2 -2
  266. package/src/server/plugins/engine/services/index.js +3 -3
  267. package/src/server/plugins/engine/services/localFormsService.js +2 -2
  268. package/src/server/plugins/engine/services/notifyService.ts +9 -9
  269. package/src/server/plugins/engine/services/uploadService.js +3 -3
  270. package/src/server/plugins/engine/types/index.ts +10 -10
  271. package/src/server/plugins/engine/types/schema.ts +2 -2
  272. package/src/server/plugins/engine/types.ts +22 -17
  273. package/src/server/plugins/engine/validationHelpers.ts +3 -3
  274. package/src/server/plugins/engine/vision.ts +3 -3
  275. package/src/server/plugins/map/index.js +2 -2
  276. package/src/server/plugins/map/routes/get-os-token.js +15 -3
  277. package/src/server/plugins/map/routes/index.js +7 -5
  278. package/src/server/plugins/map/routes/vts/esri-aerial.json +23 -0
  279. package/src/server/plugins/map/service.js +7 -4
  280. package/src/server/plugins/map/test/__stubs__/find.js +1 -1
  281. package/src/server/plugins/nunjucks/context.js +5 -5
  282. package/src/server/plugins/nunjucks/environment.js +6 -6
  283. package/src/server/plugins/nunjucks/filters/answer.js +3 -3
  284. package/src/server/plugins/nunjucks/filters/evaluate.js +2 -2
  285. package/src/server/plugins/nunjucks/filters/field.js +1 -1
  286. package/src/server/plugins/nunjucks/filters/href.js +2 -2
  287. package/src/server/plugins/nunjucks/filters/index.js +8 -8
  288. package/src/server/plugins/nunjucks/filters/page.js +1 -1
  289. package/src/server/plugins/nunjucks/index.js +3 -3
  290. package/src/server/plugins/nunjucks/plugin.js +3 -3
  291. package/src/server/plugins/nunjucks/render.js +2 -2
  292. package/src/server/plugins/nunjucks/types.js +1 -1
  293. package/src/server/plugins/payment/helper.js +2 -2
  294. package/src/server/plugins/payment/service.js +4 -4
  295. package/src/server/plugins/postcode-lookup/index.js +2 -2
  296. package/src/server/plugins/postcode-lookup/models/index.js +3 -3
  297. package/src/server/plugins/postcode-lookup/routes/index.js +24 -14
  298. package/src/server/plugins/postcode-lookup/service.js +7 -4
  299. package/src/server/plugins/postcode-lookup/types.js +1 -1
  300. package/src/server/plugins/session.ts +1 -1
  301. package/src/server/routes/index.ts +2 -2
  302. package/src/server/routes/public.ts +1 -1
  303. package/src/server/routes/types.ts +1 -1
  304. package/src/server/schemas/index.ts +2 -2
  305. package/src/server/secure-context.js +1 -1
  306. package/src/server/services/cacheService.ts +13 -18
  307. package/src/server/services/httpService.ts +1 -1
  308. package/src/server/services/index.ts +1 -1
  309. package/src/server/types.ts +7 -7
  310. package/src/server/utils/notify.ts +2 -2
  311. package/src/server/utils/utils.js +1 -1
  312. package/src/typings/hapi/index.d.ts +4 -4
  313. package/src/typings/joi/index.d.ts +1 -1
  314. package/src/server/common/helpers/logging/logger-options.test.ts +0 -50
  315. package/src/server/index.test.ts +0 -644
  316. package/src/server/plugins/engine/beta/form-context.test.ts +0 -373
  317. package/src/server/plugins/engine/components/AutocompleteField.test.ts +0 -362
  318. package/src/server/plugins/engine/components/CheckboxesField.test.ts +0 -486
  319. package/src/server/plugins/engine/components/DatePartsField.test.ts +0 -927
  320. package/src/server/plugins/engine/components/DeclarationField.test.ts +0 -560
  321. package/src/server/plugins/engine/components/Details.test.ts +0 -49
  322. package/src/server/plugins/engine/components/EastingNorthingField.test.ts +0 -727
  323. package/src/server/plugins/engine/components/EmailAddressField.test.ts +0 -445
  324. package/src/server/plugins/engine/components/FileUploadField.test.ts +0 -1079
  325. package/src/server/plugins/engine/components/GeospatialField.test.ts +0 -380
  326. package/src/server/plugins/engine/components/HiddenField.test.ts +0 -188
  327. package/src/server/plugins/engine/components/Html.test.ts +0 -48
  328. package/src/server/plugins/engine/components/InsetText.test.ts +0 -48
  329. package/src/server/plugins/engine/components/LatLongField.test.ts +0 -898
  330. package/src/server/plugins/engine/components/List.test.ts +0 -79
  331. package/src/server/plugins/engine/components/LocationFieldBase.test.ts +0 -253
  332. package/src/server/plugins/engine/components/LocationFieldHelpers.test.ts +0 -743
  333. package/src/server/plugins/engine/components/Markdown.test.ts +0 -48
  334. package/src/server/plugins/engine/components/MonthYearField.test.ts +0 -617
  335. package/src/server/plugins/engine/components/MultilineTextField.test.ts +0 -647
  336. package/src/server/plugins/engine/components/NationalGridFieldNumberField.test.ts +0 -449
  337. package/src/server/plugins/engine/components/NumberField.test.ts +0 -723
  338. package/src/server/plugins/engine/components/OsGridRefField.test.ts +0 -460
  339. package/src/server/plugins/engine/components/PaymentField.test.ts +0 -745
  340. package/src/server/plugins/engine/components/RadiosField.test.ts +0 -297
  341. package/src/server/plugins/engine/components/SelectField.test.ts +0 -289
  342. package/src/server/plugins/engine/components/TelephoneNumberField.test.ts +0 -384
  343. package/src/server/plugins/engine/components/TextField.test.ts +0 -521
  344. package/src/server/plugins/engine/components/UkAddressField.test.ts +0 -806
  345. package/src/server/plugins/engine/components/YesNoField.test.ts +0 -256
  346. package/src/server/plugins/engine/components/helpers/components.test.ts +0 -399
  347. package/src/server/plugins/engine/components/helpers/geospatial.test.js +0 -55
  348. package/src/server/plugins/engine/components/helpers/helpers.test.ts +0 -219
  349. package/src/server/plugins/engine/date-helper.test.ts +0 -47
  350. package/src/server/plugins/engine/helpers.test.ts +0 -868
  351. package/src/server/plugins/engine/models/FormModel.test.ts +0 -725
  352. package/src/server/plugins/engine/models/SummaryViewModel.test.ts +0 -472
  353. package/src/server/plugins/engine/options.test.js +0 -63
  354. package/src/server/plugins/engine/outputFormatters/adapter/v1.location.test.ts +0 -356
  355. package/src/server/plugins/engine/outputFormatters/adapter/v1.test.ts +0 -871
  356. package/src/server/plugins/engine/outputFormatters/human/v1.payment.test.ts +0 -147
  357. package/src/server/plugins/engine/outputFormatters/human/v1.test.ts +0 -145
  358. package/src/server/plugins/engine/outputFormatters/index.test.ts +0 -17
  359. package/src/server/plugins/engine/outputFormatters/machine/v1.test.ts +0 -268
  360. package/src/server/plugins/engine/outputFormatters/machine/v2.location.test.ts +0 -341
  361. package/src/server/plugins/engine/outputFormatters/machine/v2.payment.test.ts +0 -115
  362. package/src/server/plugins/engine/outputFormatters/machine/v2.test.ts +0 -311
  363. package/src/server/plugins/engine/pageControllers/FileUploadPageController.test.ts +0 -1372
  364. package/src/server/plugins/engine/pageControllers/PageController.test.ts +0 -246
  365. package/src/server/plugins/engine/pageControllers/QuestionPageController.test.ts +0 -1686
  366. package/src/server/plugins/engine/pageControllers/RepeatPageController.test.ts +0 -279
  367. package/src/server/plugins/engine/pageControllers/StartPageController.test.ts +0 -32
  368. package/src/server/plugins/engine/pageControllers/StatusPageController.test.ts +0 -32
  369. package/src/server/plugins/engine/pageControllers/SummaryPageController.test.ts +0 -89
  370. package/src/server/plugins/engine/pageControllers/TerminalController.test.ts +0 -37
  371. package/src/server/plugins/engine/pageControllers/errors.test.ts +0 -78
  372. package/src/server/plugins/engine/pageControllers/helpers/helpers.test.ts +0 -182
  373. package/src/server/plugins/engine/pageControllers/helpers/state.test.ts +0 -359
  374. package/src/server/plugins/engine/pageControllers/helpers/submission.test.ts +0 -373
  375. package/src/server/plugins/engine/referenceNumbers.test.ts +0 -74
  376. package/src/server/plugins/engine/routes/index.test.ts +0 -332
  377. package/src/server/plugins/engine/routes/payment-helper.test.js +0 -136
  378. package/src/server/plugins/engine/routes/payment.test.js +0 -180
  379. package/src/server/plugins/engine/routes/questions.test.ts +0 -502
  380. package/src/server/plugins/engine/routes/repeaters/item-delete.test.ts +0 -83
  381. package/src/server/plugins/engine/routes/repeaters/summary.test.ts +0 -75
  382. package/src/server/plugins/engine/services/formsService.test.js +0 -26
  383. package/src/server/plugins/engine/services/notifyService.test.ts +0 -310
  384. package/src/server/plugins/engine/types/schema.test.ts +0 -234
  385. package/src/server/plugins/engine/views/components/service-banner/template.test.js +0 -43
  386. package/src/server/plugins/engine/views/components/tag-env/template.test.js +0 -28
  387. package/src/server/plugins/engine/views/partials/preview-banner.test.js +0 -122
  388. package/src/server/plugins/map/routes/get-os-token.test.js +0 -55
  389. package/src/server/plugins/map/service.test.js +0 -144
  390. package/src/server/plugins/nunjucks/context.test.js +0 -109
  391. package/src/server/plugins/nunjucks/enviroment.test.js +0 -207
  392. package/src/server/plugins/nunjucks/filters/answer.test.js +0 -92
  393. package/src/server/plugins/nunjucks/filters/field.test.js +0 -75
  394. package/src/server/plugins/nunjucks/filters/href.test.js +0 -80
  395. package/src/server/plugins/nunjucks/filters/merge.test.js +0 -15
  396. package/src/server/plugins/nunjucks/filters/page.test.js +0 -65
  397. package/src/server/plugins/payment/helper.test.js +0 -29
  398. package/src/server/plugins/payment/service.test.js +0 -218
  399. package/src/server/plugins/postcode-lookup/service.test.js +0 -177
  400. package/src/server/postcode-lookup.test.ts +0 -64
  401. package/src/server/routes/dummy-api.test.ts +0 -97
  402. package/src/server/services/cacheService.test.ts +0 -308
  403. package/src/server/services/httpService.test.js +0 -491
  404. package/src/server/utils/file-form-service.test.js +0 -127
  405. package/src/server/utils/notify.test.ts +0 -37
  406. package/src/server/utils/secure-context/get-trust-store-certs.test.js +0 -19
  407. package/src/server/utils/utils.test.js +0 -69
@@ -1,898 +0,0 @@
1
- import { ComponentType, type LatLongFieldComponent } from '@defra/forms-model'
2
-
3
- import { ComponentCollection } from '~/src/server/plugins/engine/components/ComponentCollection.js'
4
- import { LatLongField } from '~/src/server/plugins/engine/components/LatLongField.js'
5
- import {
6
- getAnswer,
7
- type Field
8
- } from '~/src/server/plugins/engine/components/helpers/components.js'
9
- import { FormModel } from '~/src/server/plugins/engine/models/FormModel.js'
10
- import { type FormSubmissionError } from '~/src/server/plugins/engine/types.js'
11
- import definition from '~/test/form/definitions/blank.js'
12
-
13
- describe('LatLongField', () => {
14
- let model: FormModel
15
-
16
- beforeEach(() => {
17
- model = new FormModel(definition, {
18
- basePath: 'test'
19
- })
20
- })
21
-
22
- describe('Defaults', () => {
23
- let def: LatLongFieldComponent
24
- let collection: ComponentCollection
25
- let field: Field
26
-
27
- beforeEach(() => {
28
- def = {
29
- title: 'Example lat long',
30
- shortDescription: 'Example location',
31
- name: 'myComponent',
32
- type: ComponentType.LatLongField,
33
- options: {},
34
- schema: {}
35
- } satisfies LatLongFieldComponent
36
-
37
- collection = new ComponentCollection([def], { model })
38
- field = collection.fields[0]
39
- })
40
-
41
- describe('Schema', () => {
42
- it('uses collection titles as labels', () => {
43
- const { formSchema } = collection
44
- const { keys } = formSchema.describe()
45
-
46
- expect(keys).toHaveProperty(
47
- 'myComponent__latitude',
48
- expect.objectContaining({
49
- flags: expect.objectContaining({ label: 'Latitude' })
50
- })
51
- )
52
-
53
- expect(keys).toHaveProperty(
54
- 'myComponent__longitude',
55
- expect.objectContaining({
56
- flags: expect.objectContaining({ label: 'Longitude' })
57
- })
58
- )
59
- })
60
-
61
- it('uses collection names as keys', () => {
62
- const { formSchema } = collection
63
- const { keys } = formSchema.describe()
64
-
65
- expect(field.keys).toEqual([
66
- 'myComponent',
67
- 'myComponent__latitude',
68
- 'myComponent__longitude'
69
- ])
70
-
71
- expect(field.collection?.keys).not.toHaveProperty('myComponent')
72
-
73
- for (const key of field.collection?.keys ?? []) {
74
- expect(keys).toHaveProperty(key)
75
- }
76
- })
77
-
78
- it('is required by default', () => {
79
- const { formSchema } = collection
80
- const { keys } = formSchema.describe()
81
-
82
- expect(keys).toHaveProperty(
83
- 'myComponent__latitude',
84
- expect.objectContaining({
85
- flags: expect.objectContaining({ presence: 'required' })
86
- })
87
- )
88
-
89
- expect(keys).toHaveProperty(
90
- 'myComponent__longitude',
91
- expect.objectContaining({
92
- flags: expect.objectContaining({ presence: 'required' })
93
- })
94
- )
95
- })
96
-
97
- it('is optional when configured', () => {
98
- const collectionOptional = new ComponentCollection(
99
- [
100
- {
101
- title: 'Example lat long',
102
- name: 'myComponent',
103
- type: ComponentType.LatLongField,
104
- options: { required: false },
105
- schema: {}
106
- }
107
- ],
108
- { model }
109
- )
110
-
111
- const { formSchema } = collectionOptional
112
- const { keys } = formSchema.describe()
113
-
114
- expect(keys).toHaveProperty(
115
- 'myComponent__latitude',
116
- expect.objectContaining({ allow: [''] })
117
- )
118
-
119
- expect(keys).toHaveProperty(
120
- 'myComponent__longitude',
121
- expect.objectContaining({ allow: [''] })
122
- )
123
-
124
- const result1 = collectionOptional.validate(
125
- getFormData({
126
- latitude: '',
127
- longitude: ''
128
- })
129
- )
130
-
131
- const result2 = collectionOptional.validate(
132
- getFormData({
133
- latitude: '51.5',
134
- longitude: ''
135
- })
136
- )
137
-
138
- expect(result1.errors).toBeUndefined()
139
- expect(result2.errors).toBeTruthy()
140
- expect(result2.errors?.length).toBeGreaterThan(0)
141
- })
142
-
143
- it('accepts valid values', () => {
144
- const result1 = collection.validate(
145
- getFormData({
146
- latitude: '51.519450',
147
- longitude: '-0.127758'
148
- })
149
- )
150
-
151
- const result2 = collection.validate(
152
- getFormData({
153
- latitude: '50.5',
154
- longitude: '-8.9'
155
- })
156
- )
157
-
158
- expect(result1.errors).toBeUndefined()
159
- expect(result2.errors).toBeUndefined()
160
- })
161
-
162
- it('adds errors for empty value when short description exists', () => {
163
- const result = collection.validate(
164
- getFormData({
165
- latitude: '',
166
- longitude: ''
167
- })
168
- )
169
-
170
- expect(result.errors).toBeTruthy()
171
- expect(result.errors?.length).toBe(2)
172
- })
173
-
174
- it('adds errors for invalid values', () => {
175
- const result1 = collection.validate(
176
- getFormData({
177
- latitude: 'invalid',
178
- longitude: 'invalid'
179
- })
180
- )
181
-
182
- expect(result1.errors).toBeTruthy()
183
- })
184
- })
185
-
186
- describe('State', () => {
187
- it('returns text from state', () => {
188
- const state1 = getFormState({
189
- latitude: 51.51945,
190
- longitude: -0.127758
191
- })
192
- const state2 = getFormState({})
193
-
194
- const answer1 = getAnswer(field, state1)
195
- const answer2 = getAnswer(field, state2)
196
-
197
- expect(answer1).toBe('Latitude: 51.51945<br>Longitude: -0.127758<br>')
198
- expect(answer2).toBe('')
199
- })
200
-
201
- it('returns payload from state', () => {
202
- const state1 = getFormState({
203
- latitude: 51.51945,
204
- longitude: -0.127758
205
- })
206
- const state2 = getFormState({})
207
-
208
- const payload1 = field.getFormDataFromState(state1)
209
- const payload2 = field.getFormDataFromState(state2)
210
-
211
- expect(payload1).toEqual(
212
- getFormData({
213
- latitude: 51.51945,
214
- longitude: -0.127758
215
- })
216
- )
217
- expect(payload2).toEqual(getFormData({}))
218
- })
219
-
220
- it('returns value from state', () => {
221
- const state1 = getFormState({
222
- latitude: 51.51945,
223
- longitude: -0.127758
224
- })
225
- const state2 = getFormState({})
226
-
227
- const value1 = field.getFormValueFromState(state1)
228
- const value2 = field.getFormValueFromState(state2)
229
-
230
- expect(value1).toEqual({
231
- latitude: 51.51945,
232
- longitude: -0.127758
233
- })
234
-
235
- expect(value2).toBeUndefined()
236
- })
237
-
238
- it('returns context for conditions and form submission', () => {
239
- const state1 = getFormState({
240
- latitude: 51.51945,
241
- longitude: -0.127758
242
- })
243
- const state2 = getFormState({})
244
-
245
- const value1 = field.getContextValueFromState(state1)
246
- const value2 = field.getContextValueFromState(state2)
247
-
248
- expect(value1).toBe('Latitude: 51.51945\nLongitude: -0.127758')
249
- expect(value2).toBeNull()
250
- })
251
-
252
- it('returns state from payload', () => {
253
- const payload1 = getFormData({
254
- latitude: 51.51945,
255
- longitude: -0.127758
256
- })
257
- const payload2 = getFormData({})
258
-
259
- const value1 = field.getStateFromValidForm(payload1)
260
- const value2 = field.getStateFromValidForm(payload2)
261
-
262
- expect(value1).toEqual(
263
- getFormState({
264
- latitude: 51.51945,
265
- longitude: -0.127758
266
- })
267
- )
268
- expect(value2).toEqual(getFormState({}))
269
- })
270
- })
271
-
272
- describe('View model', () => {
273
- it('sets Nunjucks component defaults', () => {
274
- const payload = getFormData({
275
- latitude: 51.51945,
276
- longitude: -0.127758
277
- })
278
- const viewModel = field.getViewModel(payload)
279
-
280
- expect(viewModel).toEqual(
281
- expect.objectContaining({
282
- fieldset: {
283
- legend: {
284
- text: def.title,
285
- classes: 'govuk-fieldset__legend--m'
286
- }
287
- },
288
- items: [
289
- expect.objectContaining({
290
- label: expect.objectContaining({ text: 'Latitude' }),
291
- name: 'myComponent__latitude',
292
- id: 'myComponent__latitude',
293
- value: 51.51945
294
- }),
295
- expect.objectContaining({
296
- label: expect.objectContaining({ text: 'Longitude' }),
297
- name: 'myComponent__longitude',
298
- id: 'myComponent__longitude',
299
- value: -0.127758
300
- })
301
- ]
302
- })
303
- )
304
- })
305
-
306
- it('includes instruction text when provided', () => {
307
- const componentWithInstruction = new LatLongField(
308
- {
309
- ...def,
310
- options: { instructionText: 'Enter coordinates in **decimal**' }
311
- },
312
- { model }
313
- )
314
-
315
- const viewModel = componentWithInstruction.getViewModel(
316
- getFormData({
317
- latitude: 51.51945,
318
- longitude: -0.127758
319
- })
320
- )
321
-
322
- const instructionText =
323
- 'instructionText' in viewModel ? viewModel.instructionText : undefined
324
- expect(instructionText).toBeTruthy()
325
- expect(instructionText).toContain('decimal')
326
- })
327
-
328
- it('handles errors when component has validation errors', () => {
329
- const payload = getFormData({
330
- latitude: '',
331
- longitude: ''
332
- })
333
-
334
- const errors = [
335
- {
336
- name: 'myComponent',
337
- text: 'Error message',
338
- path: ['myComponent'],
339
- href: '#myComponent'
340
- }
341
- ]
342
-
343
- const viewModel = field.getViewModel(payload, errors)
344
-
345
- // Check that error is passed to the viewModel
346
- expect(viewModel.errors).toEqual(errors)
347
-
348
- // Items should be present with their basic structure
349
- expect(viewModel.items?.[0]).toEqual(
350
- expect.objectContaining({
351
- id: 'myComponent__latitude',
352
- name: 'myComponent__latitude'
353
- })
354
- )
355
-
356
- expect(viewModel.items?.[1]).toEqual(
357
- expect.objectContaining({
358
- id: 'myComponent__longitude',
359
- name: 'myComponent__longitude'
360
- })
361
- )
362
- })
363
-
364
- it('getViewErrors returns all errors for error summary', () => {
365
- const errors: FormSubmissionError[] = [
366
- {
367
- name: 'myComponent__latitude',
368
- text: 'Enter valid latitude',
369
- path: ['myComponent__latitude'],
370
- href: '#myComponent__latitude'
371
- },
372
- {
373
- name: 'myComponent__longitude',
374
- text: 'Enter valid longitude',
375
- path: ['myComponent__longitude'],
376
- href: '#myComponent__longitude'
377
- }
378
- ]
379
-
380
- const viewErrors = field.getViewErrors(errors)
381
-
382
- expect(viewErrors).toHaveLength(2)
383
- expect(viewErrors).toEqual([
384
- expect.objectContaining({ text: 'Enter valid latitude' }),
385
- expect.objectContaining({ text: 'Enter valid longitude' })
386
- ])
387
- })
388
- })
389
-
390
- describe('AllPossibleErrors', () => {
391
- it('should return errors from instance method', () => {
392
- const errors = field.getAllPossibleErrors()
393
- expect(errors.baseErrors).not.toBeEmpty()
394
- expect(errors.advancedSettingsErrors).not.toBeEmpty()
395
- })
396
-
397
- it('should return errors from static method', () => {
398
- const staticErrors = LatLongField.getAllPossibleErrors()
399
- expect(staticErrors.baseErrors).not.toBeEmpty()
400
- expect(staticErrors.advancedSettingsErrors).not.toBeEmpty()
401
- })
402
-
403
- it('instance method should delegate to static method', () => {
404
- const staticResult = LatLongField.getAllPossibleErrors()
405
- const instanceResult = field.getAllPossibleErrors()
406
-
407
- // Compare structure and content
408
- expect(instanceResult.baseErrors).toHaveLength(
409
- staticResult.baseErrors.length
410
- )
411
- expect(instanceResult.advancedSettingsErrors).toHaveLength(
412
- staticResult.advancedSettingsErrors.length
413
- )
414
-
415
- // Compare error types
416
- expect(instanceResult.baseErrors.map((e) => e.type)).toEqual(
417
- staticResult.baseErrors.map((e) => e.type)
418
- )
419
- expect(
420
- instanceResult.advancedSettingsErrors.map((e) => e.type)
421
- ).toEqual(staticResult.advancedSettingsErrors.map((e) => e.type))
422
-
423
- // Compare rendered templates
424
- expect(
425
- instanceResult.baseErrors.map((e) =>
426
- typeof e.template === 'object' && 'rendered' in e.template
427
- ? e.template.rendered
428
- : e.template
429
- )
430
- ).toEqual(
431
- staticResult.baseErrors.map((e) =>
432
- typeof e.template === 'object' && 'rendered' in e.template
433
- ? e.template.rendered
434
- : e.template
435
- )
436
- )
437
- })
438
- })
439
- })
440
-
441
- describe('Validation', () => {
442
- describe.each([
443
- {
444
- description: 'Trim empty spaces',
445
- component: createLatLongComponent(),
446
- assertions: [
447
- {
448
- input: getFormData({
449
- latitude: ' 51.5',
450
- longitude: ' -0.1'
451
- }),
452
- output: {
453
- value: getFormData({
454
- latitude: 51.5,
455
- longitude: -0.1
456
- })
457
- }
458
- },
459
- {
460
- input: getFormData({
461
- latitude: '51.5 ',
462
- longitude: '-0.1 '
463
- }),
464
- output: {
465
- value: getFormData({
466
- latitude: 51.5,
467
- longitude: -0.1
468
- })
469
- }
470
- }
471
- ]
472
- },
473
- {
474
- description: 'Schema min and max for latitude',
475
- component: {
476
- title: 'Example lat long',
477
- name: 'myComponent',
478
- type: ComponentType.LatLongField,
479
- options: {},
480
- schema: {
481
- latitude: {
482
- min: 50,
483
- max: 55
484
- }
485
- }
486
- } satisfies LatLongFieldComponent,
487
- assertions: [
488
- {
489
- input: getFormData({
490
- latitude: '49.9',
491
- longitude: '-0.1'
492
- }),
493
- output: {
494
- value: getFormData({
495
- latitude: 49.9,
496
- longitude: -0.1
497
- }),
498
- errors: [
499
- expect.objectContaining({
500
- text: expect.stringMatching(
501
- /Latitude for .* must be between 50 and 55/
502
- )
503
- })
504
- ]
505
- }
506
- },
507
- {
508
- input: getFormData({
509
- latitude: '55.1',
510
- longitude: '-0.1'
511
- }),
512
- output: {
513
- value: getFormData({
514
- latitude: 55.1,
515
- longitude: -0.1
516
- }),
517
- errors: [
518
- expect.objectContaining({
519
- text: expect.stringMatching(
520
- /Latitude for .* must be between 50 and 55/
521
- )
522
- })
523
- ]
524
- }
525
- }
526
- ]
527
- },
528
- {
529
- description: 'Schema min and max for longitude',
530
- component: {
531
- title: 'Example lat long',
532
- name: 'myComponent',
533
- type: ComponentType.LatLongField,
534
- options: {},
535
- schema: {
536
- longitude: {
537
- min: -5,
538
- max: 1
539
- }
540
- }
541
- } satisfies LatLongFieldComponent,
542
- assertions: [
543
- {
544
- input: getFormData({
545
- latitude: '51.5',
546
- longitude: '-5.1'
547
- }),
548
- output: {
549
- value: getFormData({
550
- latitude: 51.5,
551
- longitude: -5.1
552
- }),
553
- errors: [
554
- expect.objectContaining({
555
- text: expect.stringMatching(
556
- /Longitude for .* must be between -5 and 1/
557
- )
558
- })
559
- ]
560
- }
561
- },
562
- {
563
- input: getFormData({
564
- latitude: '51.5',
565
- longitude: '1.1'
566
- }),
567
- output: {
568
- value: getFormData({
569
- latitude: 51.5,
570
- longitude: 1.1
571
- }),
572
- errors: [
573
- expect.objectContaining({
574
- text: expect.stringMatching(
575
- /Longitude for .* must be between -5 and 1/
576
- )
577
- })
578
- ]
579
- }
580
- }
581
- ]
582
- },
583
- {
584
- description: 'Precision validation',
585
- component: {
586
- title: 'Example lat long',
587
- name: 'myComponent',
588
- type: ComponentType.LatLongField,
589
- options: {},
590
- schema: {}
591
- } satisfies LatLongFieldComponent,
592
- assertions: [
593
- {
594
- input: getFormData({
595
- latitude: '51.12345678',
596
- longitude: '-0.1'
597
- }),
598
- output: {
599
- value: getFormData({
600
- latitude: 51.12345678,
601
- longitude: -0.1
602
- }),
603
- errors: [
604
- expect.objectContaining({
605
- text: 'Latitude must have no more than 7 decimal places'
606
- })
607
- ]
608
- }
609
- },
610
- {
611
- input: getFormData({
612
- latitude: '51.5',
613
- longitude: '-0.12345678'
614
- }),
615
- output: {
616
- value: getFormData({
617
- latitude: 51.5,
618
- longitude: -0.12345678
619
- }),
620
- errors: [
621
- expect.objectContaining({
622
- text: 'Longitude must have no more than 7 decimal places'
623
- })
624
- ]
625
- }
626
- }
627
- ]
628
- },
629
- {
630
- description: 'Minimum precision validation',
631
- component: createLatLongComponent(),
632
- assertions: [
633
- {
634
- input: getFormData({
635
- latitude: '52',
636
- longitude: '-1'
637
- }),
638
- output: {
639
- value: getFormData({
640
- latitude: 52,
641
- longitude: -1
642
- })
643
- }
644
- },
645
- {
646
- input: getFormData({
647
- latitude: '52.1',
648
- longitude: '-1.5'
649
- }),
650
- output: {
651
- value: getFormData({
652
- latitude: 52.1,
653
- longitude: -1.5
654
- })
655
- }
656
- },
657
- {
658
- input: getFormData({
659
- latitude: '52.123456',
660
- longitude: '-1.123456'
661
- }),
662
- output: {
663
- value: getFormData({
664
- latitude: 52.123456,
665
- longitude: -1.123456
666
- })
667
- }
668
- }
669
- ]
670
- },
671
- {
672
- description: 'Length and precision validation',
673
- component: createLatLongComponent(),
674
- assertions: [
675
- {
676
- input: getFormData({
677
- latitude: '52',
678
- longitude: '-1.5'
679
- }),
680
- output: {
681
- value: getFormData({
682
- latitude: 52,
683
- longitude: -1.5
684
- })
685
- }
686
- },
687
- // Latitude too long
688
- {
689
- input: getFormData({
690
- latitude: '52.12345678',
691
- longitude: '-1.5'
692
- }),
693
- output: {
694
- value: getFormData({
695
- latitude: 52.12345678,
696
- longitude: -1.5
697
- }),
698
- errors: [
699
- expect.objectContaining({
700
- text: 'Latitude must have no more than 7 decimal places'
701
- })
702
- ]
703
- }
704
- },
705
- {
706
- input: getFormData({
707
- latitude: '52.1',
708
- longitude: '-1'
709
- }),
710
- output: {
711
- value: getFormData({
712
- latitude: 52.1,
713
- longitude: -1
714
- })
715
- }
716
- },
717
- // Longitude too long
718
- {
719
- input: getFormData({
720
- latitude: '52.1',
721
- longitude: '-1.12345678'
722
- }),
723
- output: {
724
- value: getFormData({
725
- latitude: 52.1,
726
- longitude: -1.12345678
727
- }),
728
- errors: [
729
- expect.objectContaining({
730
- text: 'Longitude must have no more than 7 decimal places'
731
- })
732
- ]
733
- }
734
- },
735
- // Valid values
736
- {
737
- input: getFormData({
738
- latitude: '52.1',
739
- longitude: '-1.5'
740
- }),
741
- output: {
742
- value: getFormData({
743
- latitude: 52.1,
744
- longitude: -1.5
745
- })
746
- }
747
- },
748
- {
749
- input: getFormData({
750
- latitude: '52.1234',
751
- longitude: '-1.123'
752
- }),
753
- output: {
754
- value: getFormData({
755
- latitude: 52.1234,
756
- longitude: -1.123
757
- })
758
- }
759
- }
760
- ]
761
- },
762
- {
763
- description: 'Invalid format',
764
- component: createLatLongComponent(),
765
- assertions: [
766
- {
767
- input: getFormData({
768
- latitude: 'invalid',
769
- longitude: '-0.1'
770
- }),
771
- output: {
772
- value: getFormData({
773
- latitude: 'invalid',
774
- longitude: -0.1
775
- }),
776
- errors: [
777
- expect.objectContaining({
778
- text: expect.stringMatching(
779
- /Enter a valid latitude for .* like 51.519450/
780
- )
781
- })
782
- ]
783
- }
784
- },
785
- {
786
- input: getFormData({
787
- latitude: '51.5',
788
- longitude: 'invalid'
789
- }),
790
- output: {
791
- value: getFormData({
792
- latitude: 51.5,
793
- longitude: 'invalid'
794
- }),
795
- errors: [
796
- expect.objectContaining({
797
- text: expect.stringMatching(
798
- /Enter a valid longitude for .* like -0.127758/
799
- )
800
- })
801
- ]
802
- }
803
- }
804
- ]
805
- },
806
- {
807
- description: 'Optional field',
808
- component: {
809
- title: 'Example lat long',
810
- name: 'myComponent',
811
- type: ComponentType.LatLongField,
812
- options: {
813
- required: false
814
- },
815
- schema: {}
816
- } satisfies LatLongFieldComponent,
817
- assertions: [
818
- {
819
- input: getFormData({
820
- latitude: '',
821
- longitude: ''
822
- }),
823
- output: {
824
- value: getFormData({
825
- latitude: '',
826
- longitude: ''
827
- })
828
- }
829
- }
830
- ]
831
- }
832
- ])('$description', ({ component: def, assertions }) => {
833
- let collection: ComponentCollection
834
-
835
- beforeEach(() => {
836
- collection = new ComponentCollection([def], { model })
837
- })
838
-
839
- it.each([...assertions])(
840
- 'validates custom example',
841
- ({ input, output }) => {
842
- const result = collection.validate(input)
843
- expect(result).toEqual(output)
844
- }
845
- )
846
- })
847
- })
848
- })
849
-
850
- /**
851
- * Factory function to create a default LatLongField component with optional overrides
852
- */
853
- function createLatLongComponent(
854
- overrides: Partial<LatLongFieldComponent> = {}
855
- ): LatLongFieldComponent {
856
- return {
857
- title: 'Example lat long',
858
- name: 'myComponent',
859
- type: ComponentType.LatLongField,
860
- options: {},
861
- schema: {},
862
- ...overrides
863
- } satisfies LatLongFieldComponent
864
- }
865
-
866
- function getFormData(
867
- value:
868
- | { latitude?: string | number; longitude?: string | number }
869
- | Record<string, never>
870
- ) {
871
- if ('latitude' in value || 'longitude' in value) {
872
- return {
873
- myComponent__latitude: value.latitude,
874
- myComponent__longitude: value.longitude
875
- }
876
- }
877
- return {}
878
- }
879
-
880
- function getFormState(
881
- value:
882
- | {
883
- latitude?: number
884
- longitude?: number
885
- }
886
- | Record<string, never>
887
- ) {
888
- if ('latitude' in value || 'longitude' in value) {
889
- return {
890
- myComponent__latitude: value.latitude ?? null,
891
- myComponent__longitude: value.longitude ?? null
892
- }
893
- }
894
- return {
895
- myComponent__latitude: null,
896
- myComponent__longitude: null
897
- }
898
- }