@ukhomeoffice/cop-react-form-renderer 7.3.2 → 8.0.0-alpha

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 (761) hide show
  1. package/README.md +106 -32
  2. package/dist/components/CheckYourAnswers/Answer.d.ts +10 -0
  3. package/dist/components/CheckYourAnswers/CheckYourAnswers.d.ts +35 -0
  4. package/dist/components/CheckYourAnswers/index.d.ts +2 -0
  5. package/dist/components/CollectionPage/CollectionPage.d.ts +24 -0
  6. package/dist/components/CollectionPage/index.d.ts +1 -0
  7. package/dist/components/CollectionSummary/BannerStrip.d.ts +9 -0
  8. package/dist/components/CollectionSummary/CollectionSummary.d.ts +53 -0
  9. package/dist/components/CollectionSummary/Confirmation.d.ts +15 -0
  10. package/dist/components/CollectionSummary/RenderListView.d.ts +42 -0
  11. package/dist/components/CollectionSummary/SummaryCard.d.ts +62 -0
  12. package/dist/components/CollectionSummary/SummaryCardButtons.d.ts +21 -0
  13. package/dist/components/CollectionSummary/SummaryCardDetails.d.ts +14 -0
  14. package/dist/components/CollectionSummary/SummaryCardValidationContext.d.ts +9 -0
  15. package/dist/components/CollectionSummary/index.d.ts +2 -0
  16. package/dist/components/FormComponent/Collection.d.ts +39 -0
  17. package/dist/components/FormComponent/Container.d.ts +26 -0
  18. package/dist/components/FormComponent/FormComponent.d.ts +39 -0
  19. package/dist/components/FormComponent/helpers/addLabel.d.ts +7 -0
  20. package/dist/components/FormComponent/helpers/getComponentDisabled.d.ts +2 -0
  21. package/dist/components/FormComponent/helpers/getComponentError.d.ts +4 -0
  22. package/dist/components/FormComponent/helpers/getComponentFieldSet.d.ts +2 -0
  23. package/dist/components/FormComponent/helpers/index.d.ts +5 -0
  24. package/dist/components/FormComponent/index.d.ts +2 -0
  25. package/dist/components/FormPage/FormPage.d.ts +36 -0
  26. package/dist/components/FormPage/index.d.ts +2 -0
  27. package/dist/components/FormRenderer/FormRenderer.d.ts +39 -0
  28. package/dist/components/FormRenderer/handlers/cyaAction.d.ts +9 -0
  29. package/dist/components/FormRenderer/handlers/getPageId.d.ts +8 -0
  30. package/dist/components/FormRenderer/handlers/index.d.ts +6 -0
  31. package/dist/components/FormRenderer/handlers/navigate.d.ts +10 -0
  32. package/dist/components/FormRenderer/handlers/submissionError.d.ts +7 -0
  33. package/dist/components/FormRenderer/helpers/canActionProceed.d.ts +12 -0
  34. package/dist/components/FormRenderer/helpers/canCYASubmit.d.ts +10 -0
  35. package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.d.ts +2 -0
  36. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.d.ts +51 -0
  37. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.d.ts +179 -0
  38. package/dist/components/FormRenderer/helpers/getCYA.d.ts +20 -0
  39. package/dist/components/FormRenderer/helpers/getFormState.d.ts +25 -0
  40. package/dist/components/FormRenderer/helpers/getNextPageId.d.ts +2 -0
  41. package/dist/components/FormRenderer/helpers/getPage.d.ts +9 -0
  42. package/dist/components/FormRenderer/helpers/getRelevantPages.d.ts +2 -0
  43. package/dist/components/FormRenderer/helpers/getSubmissionStatus.d.ts +2 -0
  44. package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.d.ts +10 -0
  45. package/dist/components/FormRenderer/helpers/index.d.ts +29 -0
  46. package/dist/components/FormRenderer/index.d.ts +2 -0
  47. package/dist/components/FormRenderer/onCYAAction.d.ts +6 -0
  48. package/dist/components/FormRenderer/onPageAction.d.ts +2 -0
  49. package/dist/components/FormRenderer/onTaskAction.d.ts +2 -0
  50. package/dist/components/PageActions/ActionButton.d.ts +7 -0
  51. package/dist/components/PageActions/PageActions.d.ts +7 -0
  52. package/dist/components/PageActions/index.d.ts +2 -0
  53. package/dist/components/SummaryList/GroupAction.d.ts +12 -0
  54. package/dist/components/SummaryList/RowAction.d.ts +12 -0
  55. package/dist/components/SummaryList/SummaryList.d.ts +28 -0
  56. package/dist/components/SummaryList/SummaryList.stories.d.ts +10 -0
  57. package/dist/components/SummaryList/SummaryListHeadingRow.d.ts +7 -0
  58. package/dist/components/SummaryList/SummaryListHeadingRowWithAction.d.ts +16 -0
  59. package/dist/components/SummaryList/SummaryListRow.d.ts +19 -0
  60. package/dist/components/SummaryList/SummaryListTitleRow.d.ts +7 -0
  61. package/dist/components/SummaryList/helpers/getGroupActionAttributes.d.ts +17 -0
  62. package/dist/components/SummaryList/helpers/getRowActionAttributes.d.ts +17 -0
  63. package/dist/components/SummaryList/helpers/index.d.ts +2 -0
  64. package/dist/components/SummaryList/index.d.ts +2 -0
  65. package/dist/components/TaskList/Task.d.ts +12 -0
  66. package/dist/components/TaskList/TaskList.d.ts +40 -0
  67. package/dist/components/TaskList/TaskState.d.ts +6 -0
  68. package/dist/components/TaskList/index.d.ts +2 -0
  69. package/dist/components/index.d.ts +8 -0
  70. package/dist/context/HooksContext/HooksContext.d.ts +23 -0
  71. package/dist/context/HooksContext/index.d.ts +3 -0
  72. package/dist/context/ValidationContext/ValidationContext.d.ts +7 -0
  73. package/dist/context/ValidationContext/index.d.ts +3 -0
  74. package/dist/context/index.d.ts +3 -0
  75. package/dist/hooks/index.d.ts +6 -0
  76. package/dist/hooks/useAxios.d.ts +2 -0
  77. package/dist/hooks/useGetRequest.d.ts +12 -0
  78. package/dist/hooks/useHooks.d.ts +2 -0
  79. package/dist/hooks/useRefData.d.ts +7 -0
  80. package/dist/hooks/useValidation.d.ts +2 -0
  81. package/dist/index.cjs +5 -0
  82. package/dist/index.css +1 -0
  83. package/dist/index.d.ts +6 -0
  84. package/dist/index.js +6124 -81
  85. package/dist/models/CollectionLabels.d.ts +7 -0
  86. package/dist/models/ComponentTypes.d.ts +27 -0
  87. package/dist/models/EventTypes.d.ts +6 -0
  88. package/dist/models/FormPages.d.ts +6 -0
  89. package/dist/models/FormTypes.d.ts +10 -0
  90. package/dist/models/HubFormats.d.ts +5 -0
  91. package/dist/models/PageAction.d.ts +89 -0
  92. package/dist/models/TaskStates.d.ts +39 -0
  93. package/dist/models/index.d.ts +143 -0
  94. package/dist/setupTests.d.ts +14 -0
  95. package/dist/utils/CheckYourAnswers/getCYAAction.d.ts +20 -0
  96. package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.d.ts +22 -0
  97. package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.d.ts +22 -0
  98. package/dist/utils/CheckYourAnswers/getCYARow.d.ts +26 -0
  99. package/dist/utils/CheckYourAnswers/getCYARowForGroup.d.ts +17 -0
  100. package/dist/utils/CheckYourAnswers/getCYARowsForCollection.d.ts +2 -0
  101. package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.d.ts +23 -0
  102. package/dist/utils/CheckYourAnswers/getCYARowsForContainer.d.ts +2 -0
  103. package/dist/utils/CheckYourAnswers/getCYARowsForPage.d.ts +11 -0
  104. package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.d.ts +3 -0
  105. package/dist/utils/CheckYourAnswers/index.d.ts +5 -0
  106. package/dist/utils/CheckYourAnswers/showComponentCYA.d.ts +11 -0
  107. package/dist/utils/CollectionPage/addCollectionPageEntry.d.ts +12 -0
  108. package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.d.ts +13 -0
  109. package/dist/utils/CollectionPage/duplicateCollectionPageEntry.d.ts +13 -0
  110. package/dist/utils/CollectionPage/getCollectionPageActiveId.d.ts +14 -0
  111. package/dist/utils/CollectionPage/getCollectionPageActiveIndex.d.ts +15 -0
  112. package/dist/utils/CollectionPage/getCollectionPageData.d.ts +15 -0
  113. package/dist/utils/CollectionPage/getErrorsForCollection.d.ts +2 -0
  114. package/dist/utils/CollectionPage/getQuickEditPage.d.ts +40 -0
  115. package/dist/utils/CollectionPage/index.d.ts +13 -0
  116. package/dist/utils/CollectionPage/mergeCollectionPages.d.ts +13 -0
  117. package/dist/utils/CollectionPage/removeCollectionPageEntry.d.ts +11 -0
  118. package/dist/utils/CollectionPage/setCollectionPageData.d.ts +16 -0
  119. package/dist/utils/Component/addShowWhen.d.ts +13 -0
  120. package/dist/utils/Component/applyToComponentTree.d.ts +15 -0
  121. package/dist/utils/Component/cleanAttributes.d.ts +14 -0
  122. package/dist/utils/Component/elevateNestedComponents.d.ts +28 -0
  123. package/dist/utils/Component/getDefaultValue.d.ts +2 -0
  124. package/dist/utils/Component/getDefaultValueFromConfig.d.ts +2 -0
  125. package/dist/utils/Component/index.d.ts +12 -0
  126. package/dist/utils/Component/isEditable.d.ts +3 -0
  127. package/dist/utils/Component/optionIsSelected.d.ts +10 -0
  128. package/dist/utils/Component/setupContainerComponentsPath.d.ts +2 -0
  129. package/dist/utils/Component/showComponent.d.ts +2 -0
  130. package/dist/utils/Condition/index.d.ts +6 -0
  131. package/dist/utils/Condition/meetsAllConditions.d.ts +8 -0
  132. package/dist/utils/Condition/meetsCondition.d.ts +14 -0
  133. package/dist/utils/Condition/meetsOneCondition.d.ts +8 -0
  134. package/dist/utils/Condition/setupConditions.d.ts +2 -0
  135. package/dist/utils/Container/getEditableComponents.d.ts +7 -0
  136. package/dist/utils/Container/index.d.ts +6 -0
  137. package/dist/utils/Container/setupNesting.d.ts +2 -0
  138. package/dist/utils/Container/showContainer.d.ts +8 -0
  139. package/dist/utils/Data/applyFormula.d.ts +2 -0
  140. package/dist/utils/Data/deleteValues.d.ts +8 -0
  141. package/dist/utils/Data/getAutocompleteSource.d.ts +2 -0
  142. package/dist/utils/Data/getDataPath.d.ts +21 -0
  143. package/dist/utils/Data/getOptions.d.ts +2 -0
  144. package/dist/utils/Data/getSourceData.d.ts +17 -0
  145. package/dist/utils/Data/index.d.ts +15 -0
  146. package/dist/utils/Data/nestInRefdataOptions.d.ts +10 -0
  147. package/dist/utils/Data/refDataToOptions.d.ts +8 -0
  148. package/dist/utils/Data/setDataItem.d.ts +2 -0
  149. package/dist/utils/Data/setupFormData.d.ts +15 -0
  150. package/dist/utils/Data/setupRefDataUrlForComponent.d.ts +2 -0
  151. package/dist/utils/FormPage/applyConditionalProperties.d.ts +8 -0
  152. package/dist/utils/FormPage/getConditionalText.d.ts +23 -0
  153. package/dist/utils/FormPage/getFormPage.d.ts +9 -0
  154. package/dist/utils/FormPage/getFormPages.d.ts +9 -0
  155. package/dist/utils/FormPage/getPageActions.d.ts +13 -0
  156. package/dist/utils/FormPage/getParagraphFromText.d.ts +11 -0
  157. package/dist/utils/FormPage/index.d.ts +10 -0
  158. package/dist/utils/FormPage/showFormPage.d.ts +8 -0
  159. package/dist/utils/FormPage/showFormPageCYA.d.ts +8 -0
  160. package/dist/utils/FormPage/useComponent.d.ts +9 -0
  161. package/dist/utils/Format/formatData.d.ts +8 -0
  162. package/dist/utils/Format/formatDataForComponent.d.ts +15 -0
  163. package/dist/utils/Format/formatDataForForm.d.ts +8 -0
  164. package/dist/utils/Format/formatDataForPage.d.ts +15 -0
  165. package/dist/utils/Format/index.d.ts +7 -0
  166. package/dist/utils/Hub/getFormHub.d.ts +15 -0
  167. package/dist/utils/Hub/index.d.ts +4 -0
  168. package/dist/utils/Meta/constants.d.ts +2 -0
  169. package/dist/utils/Meta/documents/getDocuments.d.ts +2 -0
  170. package/dist/utils/Meta/documents/index.d.ts +6 -0
  171. package/dist/utils/Meta/documents/setDocumentsForField.d.ts +2 -0
  172. package/dist/utils/Meta/index.d.ts +9 -0
  173. package/dist/utils/Operate/checkValueIsTruthy.d.ts +9 -0
  174. package/dist/utils/Operate/deleteValueInFormData.d.ts +8 -0
  175. package/dist/utils/Operate/doesContainValue.d.ts +11 -0
  176. package/dist/utils/Operate/getFirstOf.d.ts +2 -0
  177. package/dist/utils/Operate/getIndexOfMatchingValueIn.d.ts +11 -0
  178. package/dist/utils/Operate/getLength.d.ts +11 -0
  179. package/dist/utils/Operate/index.d.ts +4 -0
  180. package/dist/utils/Operate/persistValueInFormData.d.ts +9 -0
  181. package/dist/utils/Operate/runPageOperations.d.ts +19 -0
  182. package/dist/utils/Operate/setValueInFormData.d.ts +2 -0
  183. package/dist/utils/Operate/shouldRun.d.ts +9 -0
  184. package/dist/utils/Validate/additional/conditionallyPermittedChange.d.ts +14 -0
  185. package/dist/utils/Validate/additional/conditionallyRequired.d.ts +11 -0
  186. package/dist/utils/Validate/additional/index.d.ts +2 -0
  187. package/dist/utils/Validate/additional/mustBeAfter.d.ts +14 -0
  188. package/dist/utils/Validate/additional/mustBeBefore.d.ts +14 -0
  189. package/dist/utils/Validate/additional/mustBeEarlierDateTime.d.ts +15 -0
  190. package/dist/utils/Validate/additional/mustBeGreaterThan.d.ts +7 -0
  191. package/dist/utils/Validate/additional/mustBeInTheFuture.d.ts +8 -0
  192. package/dist/utils/Validate/additional/mustBeInThePast.d.ts +9 -0
  193. package/dist/utils/Validate/additional/mustBeLessThan.d.ts +7 -0
  194. package/dist/utils/Validate/additional/mustBeLongerThan.d.ts +9 -0
  195. package/dist/utils/Validate/additional/mustBeNumbersOnly.d.ts +9 -0
  196. package/dist/utils/Validate/additional/mustBeOneOf.d.ts +8 -0
  197. package/dist/utils/Validate/additional/mustBeShorterThan.d.ts +9 -0
  198. package/dist/utils/Validate/additional/mustBeUniqueInCollection.d.ts +10 -0
  199. package/dist/utils/Validate/additional/mustEnterAtLeastOne.d.ts +9 -0
  200. package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.d.ts +7 -0
  201. package/dist/utils/Validate/additional/mustNotContainSql.d.ts +2 -0
  202. package/dist/utils/Validate/additional/mustSelectOnlyOne.d.ts +8 -0
  203. package/dist/utils/Validate/additional/utils.d.ts +4 -0
  204. package/dist/utils/Validate/index.d.ts +42 -0
  205. package/dist/utils/Validate/validateCollection.d.ts +9 -0
  206. package/dist/utils/Validate/validateComponent.d.ts +16 -0
  207. package/dist/utils/Validate/validateContainer.d.ts +12 -0
  208. package/dist/utils/Validate/validateDate.d.ts +29 -0
  209. package/dist/utils/Validate/validateEmail.d.ts +13 -0
  210. package/dist/utils/Validate/validateMultifile.d.ts +3 -0
  211. package/dist/utils/Validate/validateOnPageLoad.d.ts +1 -0
  212. package/dist/utils/Validate/validatePage.d.ts +8 -0
  213. package/dist/utils/Validate/validateRegex.d.ts +13 -0
  214. package/dist/utils/Validate/validateRequired.d.ts +9 -0
  215. package/dist/utils/Validate/validateTextArea.d.ts +13 -0
  216. package/dist/utils/Validate/validateTime.d.ts +20 -0
  217. package/dist/utils/canOverrideFieldRequired.d.ts +9 -0
  218. package/dist/utils/index.d.ts +140 -0
  219. package/package.json +80 -167
  220. package/LICENCE.md +0 -21
  221. package/dist/components/CheckYourAnswers/Answer.js +0 -59
  222. package/dist/components/CheckYourAnswers/Answer.test.js +0 -142
  223. package/dist/components/CheckYourAnswers/CheckYourAnswers.js +0 -252
  224. package/dist/components/CheckYourAnswers/CheckYourAnswers.scss +0 -43
  225. package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +0 -409
  226. package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +0 -603
  227. package/dist/components/CheckYourAnswers/index.js +0 -10
  228. package/dist/components/CollectionPage/CollectionPage.js +0 -178
  229. package/dist/components/CollectionPage/CollectionPage.test.js +0 -507
  230. package/dist/components/CollectionPage/index.js +0 -10
  231. package/dist/components/CollectionSummary/BannerStrip.js +0 -65
  232. package/dist/components/CollectionSummary/BannerStrip.scss +0 -60
  233. package/dist/components/CollectionSummary/BannerStrip.test.js +0 -167
  234. package/dist/components/CollectionSummary/CollectionSummary.js +0 -362
  235. package/dist/components/CollectionSummary/CollectionSummary.scss +0 -26
  236. package/dist/components/CollectionSummary/CollectionSummary.test.js +0 -368
  237. package/dist/components/CollectionSummary/Confirmation.js +0 -65
  238. package/dist/components/CollectionSummary/Confirmation.scss +0 -26
  239. package/dist/components/CollectionSummary/Confirmation.test.js +0 -109
  240. package/dist/components/CollectionSummary/RenderListView.js +0 -162
  241. package/dist/components/CollectionSummary/RenderListView.scss +0 -295
  242. package/dist/components/CollectionSummary/RenderListView.test.js +0 -303
  243. package/dist/components/CollectionSummary/SummaryCard.js +0 -277
  244. package/dist/components/CollectionSummary/SummaryCard.scss +0 -114
  245. package/dist/components/CollectionSummary/SummaryCard.test.js +0 -1442
  246. package/dist/components/CollectionSummary/SummaryCardButtons.js +0 -76
  247. package/dist/components/CollectionSummary/SummaryCardButtons.test.js +0 -87
  248. package/dist/components/CollectionSummary/SummaryCardDetails.js +0 -206
  249. package/dist/components/CollectionSummary/SummaryCardDetails.scss +0 -216
  250. package/dist/components/CollectionSummary/SummaryCardDetails.test.js +0 -654
  251. package/dist/components/CollectionSummary/SummaryCardValidationContext.js +0 -79
  252. package/dist/components/CollectionSummary/SummaryCardValidationContext.test.js +0 -104
  253. package/dist/components/CollectionSummary/index.js +0 -10
  254. package/dist/components/FormComponent/Collection.js +0 -234
  255. package/dist/components/FormComponent/Collection.scss +0 -24
  256. package/dist/components/FormComponent/Collection.test.js +0 -934
  257. package/dist/components/FormComponent/Container.js +0 -130
  258. package/dist/components/FormComponent/Container.scss +0 -15
  259. package/dist/components/FormComponent/Container.test.js +0 -456
  260. package/dist/components/FormComponent/FormComponent.js +0 -238
  261. package/dist/components/FormComponent/FormComponent.stories.mdx +0 -186
  262. package/dist/components/FormComponent/FormComponent.test.js +0 -436
  263. package/dist/components/FormComponent/helpers/addLabel.js +0 -25
  264. package/dist/components/FormComponent/helpers/getComponentDisabled.js +0 -15
  265. package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +0 -27
  266. package/dist/components/FormComponent/helpers/getComponentError.js +0 -23
  267. package/dist/components/FormComponent/helpers/getComponentError.test.js +0 -51
  268. package/dist/components/FormComponent/helpers/getComponentFieldSet.js +0 -11
  269. package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +0 -30
  270. package/dist/components/FormComponent/helpers/index.js +0 -35
  271. package/dist/components/FormComponent/index.js +0 -10
  272. package/dist/components/FormPage/FormPage.js +0 -212
  273. package/dist/components/FormPage/FormPage.scss +0 -7
  274. package/dist/components/FormPage/FormPage.stories.mdx +0 -157
  275. package/dist/components/FormPage/FormPage.test.js +0 -454
  276. package/dist/components/FormPage/index.js +0 -10
  277. package/dist/components/FormRenderer/FormRenderer.js +0 -426
  278. package/dist/components/FormRenderer/FormRenderer.scss +0 -5
  279. package/dist/components/FormRenderer/FormRenderer.stories.mdx +0 -178
  280. package/dist/components/FormRenderer/FormRenderer.test.js +0 -799
  281. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/cop-reassign-task-to-rcc.json +0 -446
  282. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-containerised.json +0 -120
  283. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested-block.json +0 -113
  284. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested.json +0 -106
  285. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-refdata.json +0 -106
  286. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-target-component-nested.json +0 -99
  287. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens.json +0 -106
  288. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-show-whens-page-hidden.json +0 -113
  289. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-airpax.json +0 -26408
  290. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-mandec.json +0 -9405
  291. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component-dependent-on-external-data.json +0 -158
  292. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component.json +0 -86
  293. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-collection.json +0 -173
  294. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-hidden-collection.json +0 -202
  295. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-show-when-in-component-and-page.json +0 -63
  296. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions-visible-elsewhere.json +0 -118
  297. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions.json +0 -112
  298. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component.json +0 -58
  299. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-containerised-component.json +0 -97
  300. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-collection-component.json +0 -83
  301. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-component.json +0 -55
  302. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-entire-collection.json +0 -114
  303. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component-leaf-hidden.json +0 -106
  304. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component.json +0 -106
  305. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-options.json +0 -99
  306. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-collection.json +0 -128
  307. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-component-used-elsewhere.json +0 -109
  308. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-same-component-reused.json +0 -62
  309. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page.json +0 -96
  310. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option-visible-elsewhere.json +0 -113
  311. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option.json +0 -112
  312. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-component.json +0 -26003
  313. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-radio-component.json +0 -201
  314. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-same-component-reused-one-shown.json +0 -75
  315. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-variance-breach.json +0 -4272
  316. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-carrier.json +0 -407
  317. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-change-what-happened-before.json +0 -300
  318. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-remove-photos-before.json +0 -384
  319. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-business-interests-before.json +0 -140
  320. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-criminality-before.json +0 -186
  321. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-unspent-convictions-before.json +0 -143
  322. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-variance-breach-with-upload-files.json +0 -1264
  323. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-containerised.json +0 -11
  324. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested-block.json +0 -10
  325. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested.json +0 -9
  326. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-refdata.json +0 -11
  327. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-target-component-nested.json +0 -9
  328. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens.json +0 -9
  329. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-show-whens-page-hidden.json +0 -9
  330. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component-dependent-on-external-data.json +0 -26
  331. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component.json +0 -15
  332. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-collection.json +0 -25
  333. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-hidden-collection.json +0 -26
  334. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-show-when-in-component-and-page.json +0 -6
  335. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions-visible-elsewhere.json +0 -12
  336. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions.json +0 -12
  337. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component.json +0 -5
  338. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-containerised-component.json +0 -11
  339. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-collection-component.json +0 -15
  340. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-component.json +0 -5
  341. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-entire-collection.json +0 -20
  342. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component-leaf-hidden.json +0 -14
  343. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component.json +0 -14
  344. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-options.json +0 -10
  345. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-collection.json +0 -18
  346. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-component-used-elsewhere.json +0 -9
  347. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-same-component-reused.json +0 -6
  348. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page.json +0 -9
  349. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option-visible-elsewhere.json +0 -12
  350. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option.json +0 -12
  351. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-component.json +0 -63
  352. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-radio-component.json +0 -45
  353. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-same-component-reused-one-shown.json +0 -8
  354. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/reassign-to-rcc.json +0 -72
  355. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-change-what-happened-after.json +0 -280
  356. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-remove-photos-after.json +0 -355
  357. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-base-file.json +0 -80
  358. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-business-interests-after.json +0 -122
  359. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-criminality-after.json +0 -86
  360. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-unspent-convictions-after.json +0 -127
  361. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-containerised-removed.json +0 -11
  362. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-block-removed.json +0 -7
  363. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-removed.json +0 -7
  364. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-refdata-removed.json +0 -7
  365. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-removed.json +0 -7
  366. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-target-component-nested-removed.json +0 -6
  367. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-show-whens-page-hidden-removed.json +0 -6
  368. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-dependent-on-external-data-removed.json +0 -23
  369. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-removed.json +0 -4
  370. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-collection-removed.json +0 -21
  371. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-hidden-collection-removed.json +0 -6
  372. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-removed.json +0 -4
  373. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-show-when-in-component-and-page-removed.json +0 -5
  374. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-removed.json +0 -10
  375. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-visible-elsewhere-removed.json +0 -11
  376. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-containerised-component-removed.json +0 -10
  377. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-collection-component-removed.json +0 -4
  378. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-component-removed.json +0 -4
  379. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-entire-collection-removed.json +0 -3
  380. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-leaf-hidden-removed.json +0 -13
  381. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-removed.json +0 -10
  382. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-options-removed.json +0 -8
  383. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-collection-removed.json +0 -15
  384. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-component-used-elsewhere-removed.json +0 -5
  385. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-removed.json +0 -4
  386. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-same-component-reused-removed.json +0 -5
  387. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-removed.json +0 -11
  388. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-visible-elsewhere-removed.json +0 -12
  389. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-component.json +0 -63
  390. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-radio-component-removed.json +0 -45
  391. package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-same-component-reused-one-shown-removed.json +0 -7
  392. package/dist/components/FormRenderer/handlers/cyaAction.js +0 -23
  393. package/dist/components/FormRenderer/handlers/getPageId.js +0 -15
  394. package/dist/components/FormRenderer/handlers/getPageId.test.js +0 -35
  395. package/dist/components/FormRenderer/handlers/handlers.test.js +0 -81
  396. package/dist/components/FormRenderer/handlers/index.js +0 -17
  397. package/dist/components/FormRenderer/handlers/navigate.js +0 -25
  398. package/dist/components/FormRenderer/handlers/submissionError.js +0 -18
  399. package/dist/components/FormRenderer/helpers/canActionProceed.js +0 -27
  400. package/dist/components/FormRenderer/helpers/canActionProceed.test.js +0 -84
  401. package/dist/components/FormRenderer/helpers/canCYASubmit.js +0 -17
  402. package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +0 -75
  403. package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +0 -63
  404. package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +0 -191
  405. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.js +0 -338
  406. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.test.js +0 -434
  407. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.js +0 -399
  408. package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.test.js +0 -559
  409. package/dist/components/FormRenderer/helpers/getCYA.js +0 -42
  410. package/dist/components/FormRenderer/helpers/getCYA.test.js +0 -46
  411. package/dist/components/FormRenderer/helpers/getFormState.js +0 -25
  412. package/dist/components/FormRenderer/helpers/getFormState.test.js +0 -60
  413. package/dist/components/FormRenderer/helpers/getNextPageId.js +0 -76
  414. package/dist/components/FormRenderer/helpers/getNextPageId.test.js +0 -292
  415. package/dist/components/FormRenderer/helpers/getPage.js +0 -27
  416. package/dist/components/FormRenderer/helpers/getPage.test.js +0 -45
  417. package/dist/components/FormRenderer/helpers/getRelevantPages.js +0 -27
  418. package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +0 -70
  419. package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +0 -65
  420. package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +0 -309
  421. package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +0 -201
  422. package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +0 -473
  423. package/dist/components/FormRenderer/helpers/index.js +0 -33
  424. package/dist/components/FormRenderer/index.js +0 -10
  425. package/dist/components/FormRenderer/onCYAAction.js +0 -150
  426. package/dist/components/FormRenderer/onCYAAction.test.js +0 -741
  427. package/dist/components/FormRenderer/onPageAction.js +0 -227
  428. package/dist/components/FormRenderer/onPageAction.test.js +0 -960
  429. package/dist/components/FormRenderer/onTaskAction.js +0 -47
  430. package/dist/components/FormRenderer/onTaskAction.test.js +0 -247
  431. package/dist/components/PageActions/ActionButton.js +0 -48
  432. package/dist/components/PageActions/ActionButton.test.js +0 -73
  433. package/dist/components/PageActions/PageActions.js +0 -37
  434. package/dist/components/PageActions/PageActions.stories.mdx +0 -74
  435. package/dist/components/PageActions/PageActions.test.js +0 -106
  436. package/dist/components/PageActions/index.js +0 -10
  437. package/dist/components/SummaryList/GroupAction.js +0 -50
  438. package/dist/components/SummaryList/GroupAction.test.js +0 -86
  439. package/dist/components/SummaryList/RowAction.js +0 -48
  440. package/dist/components/SummaryList/RowAction.test.js +0 -86
  441. package/dist/components/SummaryList/SummaryList.js +0 -128
  442. package/dist/components/SummaryList/SummaryList.scss +0 -79
  443. package/dist/components/SummaryList/SummaryList.stories.mdx +0 -84
  444. package/dist/components/SummaryList/SummaryList.test.js +0 -504
  445. package/dist/components/SummaryList/SummaryListHeadingRow.js +0 -39
  446. package/dist/components/SummaryList/SummaryListHeadingRowWithAction.js +0 -65
  447. package/dist/components/SummaryList/SummaryListHeadingRowWithAction.scss +0 -38
  448. package/dist/components/SummaryList/SummaryListRow.js +0 -58
  449. package/dist/components/SummaryList/SummaryListTitleRow.js +0 -32
  450. package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +0 -29
  451. package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +0 -72
  452. package/dist/components/SummaryList/helpers/getRowActionAttributes.js +0 -29
  453. package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +0 -72
  454. package/dist/components/SummaryList/helpers/index.js +0 -14
  455. package/dist/components/SummaryList/index.js +0 -10
  456. package/dist/components/TaskList/Task.js +0 -62
  457. package/dist/components/TaskList/Task.test.js +0 -176
  458. package/dist/components/TaskList/TaskList.js +0 -175
  459. package/dist/components/TaskList/TaskList.scss +0 -123
  460. package/dist/components/TaskList/TaskList.stories.mdx +0 -164
  461. package/dist/components/TaskList/TaskList.test.js +0 -535
  462. package/dist/components/TaskList/TaskState.js +0 -37
  463. package/dist/components/TaskList/TaskState.test.js +0 -95
  464. package/dist/components/TaskList/index.js +0 -10
  465. package/dist/components/index.js +0 -56
  466. package/dist/context/HooksContext/HooksContext.js +0 -122
  467. package/dist/context/HooksContext/HooksContext.test.js +0 -45
  468. package/dist/context/HooksContext/index.js +0 -16
  469. package/dist/context/ValidationContext/ValidationContext.js +0 -98
  470. package/dist/context/ValidationContext/ValidationContext.test.js +0 -107
  471. package/dist/context/ValidationContext/index.js +0 -16
  472. package/dist/context/index.js +0 -21
  473. package/dist/hooks/index.js +0 -55
  474. package/dist/hooks/useAxios.js +0 -36
  475. package/dist/hooks/useGetRequest.js +0 -89
  476. package/dist/hooks/useHooks.js +0 -15
  477. package/dist/hooks/useRefData.js +0 -62
  478. package/dist/hooks/useValidation.js +0 -15
  479. package/dist/json/actions.json +0 -17
  480. package/dist/json/actionsNoSave.json +0 -17
  481. package/dist/json/addressDetails.json +0 -149
  482. package/dist/json/areYouACivilServant.json +0 -7
  483. package/dist/json/firstForm.json +0 -94
  484. package/dist/json/grade.json +0 -108
  485. package/dist/json/group.data.json +0 -21
  486. package/dist/json/group.json +0 -402
  487. package/dist/json/groupOfRow.json +0 -137
  488. package/dist/json/groupOfRowData.json +0 -15
  489. package/dist/json/port.json +0 -346
  490. package/dist/json/saveAndContinue.json +0 -98
  491. package/dist/json/sublocation.json +0 -859
  492. package/dist/json/taskList.json +0 -265
  493. package/dist/json/team.json +0 -17351
  494. package/dist/json/terminal.json +0 -81
  495. package/dist/json/userProfile.data.json +0 -21
  496. package/dist/json/userProfile.json +0 -276
  497. package/dist/models/CollectionLabels.js +0 -15
  498. package/dist/models/ComponentTypes.js +0 -58
  499. package/dist/models/EventTypes.js +0 -16
  500. package/dist/models/FormPages.js +0 -16
  501. package/dist/models/FormTypes.js +0 -24
  502. package/dist/models/HubFormats.js +0 -14
  503. package/dist/models/PageAction.js +0 -65
  504. package/dist/models/TaskStates.js +0 -46
  505. package/dist/models/index.js +0 -77
  506. package/dist/setupTests.js +0 -54
  507. package/dist/utils/CheckYourAnswers/getCYAAction.js +0 -44
  508. package/dist/utils/CheckYourAnswers/getCYAAction.test.js +0 -120
  509. package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +0 -57
  510. package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +0 -162
  511. package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +0 -66
  512. package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +0 -198
  513. package/dist/utils/CheckYourAnswers/getCYARow.js +0 -58
  514. package/dist/utils/CheckYourAnswers/getCYARow.test.js +0 -373
  515. package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +0 -69
  516. package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +0 -70
  517. package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +0 -71
  518. package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +0 -285
  519. package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +0 -237
  520. package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +0 -844
  521. package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +0 -45
  522. package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +0 -535
  523. package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +0 -72
  524. package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +0 -343
  525. package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.js +0 -42
  526. package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.test.js +0 -56
  527. package/dist/utils/CheckYourAnswers/index.js +0 -15
  528. package/dist/utils/CheckYourAnswers/showComponentCYA.js +0 -53
  529. package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +0 -149
  530. package/dist/utils/CollectionPage/addCollectionPageEntry.js +0 -23
  531. package/dist/utils/CollectionPage/addCollectionPageEntry.test.js +0 -17
  532. package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +0 -26
  533. package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +0 -70
  534. package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +0 -51
  535. package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +0 -125
  536. package/dist/utils/CollectionPage/getCollectionPageActiveId.js +0 -24
  537. package/dist/utils/CollectionPage/getCollectionPageActiveId.test.js +0 -26
  538. package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +0 -44
  539. package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +0 -88
  540. package/dist/utils/CollectionPage/getCollectionPageData.js +0 -53
  541. package/dist/utils/CollectionPage/getCollectionPageData.test.js +0 -103
  542. package/dist/utils/CollectionPage/getErrorsForCollection.js +0 -55
  543. package/dist/utils/CollectionPage/getErrorsForCollection.test.js +0 -154
  544. package/dist/utils/CollectionPage/getQuickEditPage.js +0 -122
  545. package/dist/utils/CollectionPage/getQuickEditPage.test.js +0 -143
  546. package/dist/utils/CollectionPage/index.js +0 -33
  547. package/dist/utils/CollectionPage/mergeCollectionPages.js +0 -128
  548. package/dist/utils/CollectionPage/mergeCollectionPages.test.js +0 -198
  549. package/dist/utils/CollectionPage/removeCollectionPageEntry.js +0 -36
  550. package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +0 -62
  551. package/dist/utils/CollectionPage/setCollectionPageData.js +0 -60
  552. package/dist/utils/CollectionPage/setCollectionPageData.test.js +0 -182
  553. package/dist/utils/Component/addShowWhen.js +0 -43
  554. package/dist/utils/Component/addShowWhen.test.js +0 -217
  555. package/dist/utils/Component/applyToComponentTree.js +0 -68
  556. package/dist/utils/Component/applyToComponentTree.test.js +0 -125
  557. package/dist/utils/Component/cleanAttributes.js +0 -42
  558. package/dist/utils/Component/cleanAttributes.test.js +0 -67
  559. package/dist/utils/Component/elevateNestedComponents.js +0 -58
  560. package/dist/utils/Component/elevateNestedComponents.test.js +0 -305
  561. package/dist/utils/Component/getComponent.js +0 -305
  562. package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +0 -73
  563. package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +0 -251
  564. package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +0 -156
  565. package/dist/utils/Component/getComponentTests/getComponent.date.test.js +0 -104
  566. package/dist/utils/Component/getComponentTests/getComponent.details.test.js +0 -56
  567. package/dist/utils/Component/getComponentTests/getComponent.email.test.js +0 -60
  568. package/dist/utils/Component/getComponentTests/getComponent.file.test.js +0 -60
  569. package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +0 -31
  570. package/dist/utils/Component/getComponentTests/getComponent.html.test.js +0 -42
  571. package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +0 -29
  572. package/dist/utils/Component/getComponentTests/getComponent.list.test.js +0 -47
  573. package/dist/utils/Component/getComponentTests/getComponent.multifile.test.js +0 -66
  574. package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +0 -211
  575. package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +0 -46
  576. package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +0 -60
  577. package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +0 -221
  578. package/dist/utils/Component/getComponentTests/getComponent.select.test.js +0 -62
  579. package/dist/utils/Component/getComponentTests/getComponent.text.test.js +0 -60
  580. package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +0 -104
  581. package/dist/utils/Component/getComponentTests/getComponent.time.test.js +0 -80
  582. package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +0 -14
  583. package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +0 -29
  584. package/dist/utils/Component/getDefaultValue.js +0 -22
  585. package/dist/utils/Component/getDefaultValue.test.js +0 -62
  586. package/dist/utils/Component/getDefaultValueFromConfig.js +0 -106
  587. package/dist/utils/Component/getDefaultValueFromConfig.test.js +0 -141
  588. package/dist/utils/Component/index.js +0 -29
  589. package/dist/utils/Component/isEditable.js +0 -13
  590. package/dist/utils/Component/isEditable.test.js +0 -42
  591. package/dist/utils/Component/optionIsSelected.js +0 -25
  592. package/dist/utils/Component/optionIsSelected.test.js +0 -69
  593. package/dist/utils/Component/setupContainerComponentsPath.js +0 -35
  594. package/dist/utils/Component/setupContainerComponentsPath.test.js +0 -79
  595. package/dist/utils/Component/showComponent.js +0 -25
  596. package/dist/utils/Component/showComponent.test.js +0 -157
  597. package/dist/utils/Component/wrapInFormGroup.js +0 -26
  598. package/dist/utils/Condition/index.js +0 -17
  599. package/dist/utils/Condition/meetsAllConditions.js +0 -44
  600. package/dist/utils/Condition/meetsAllConditions.test.js +0 -109
  601. package/dist/utils/Condition/meetsCondition.js +0 -165
  602. package/dist/utils/Condition/meetsCondition.test.js +0 -899
  603. package/dist/utils/Condition/meetsOneCondition.js +0 -32
  604. package/dist/utils/Condition/meetsOneCondition.test.js +0 -101
  605. package/dist/utils/Condition/setupConditions.js +0 -36
  606. package/dist/utils/Condition/setupConditions.test.js +0 -34
  607. package/dist/utils/Container/getEditableComponents.js +0 -29
  608. package/dist/utils/Container/getEditableComponents.test.js +0 -134
  609. package/dist/utils/Container/index.js +0 -17
  610. package/dist/utils/Container/setupNesting.js +0 -53
  611. package/dist/utils/Container/setupNesting.test.js +0 -143
  612. package/dist/utils/Container/showContainer.js +0 -52
  613. package/dist/utils/Container/showContainer.test.js +0 -179
  614. package/dist/utils/Data/applyFormula.js +0 -90
  615. package/dist/utils/Data/applyFormula.test.js +0 -264
  616. package/dist/utils/Data/deleteValues.js +0 -19
  617. package/dist/utils/Data/deleteValues.test.js +0 -58
  618. package/dist/utils/Data/getAutocompleteSource.js +0 -87
  619. package/dist/utils/Data/getAutocompleteSource.test.js +0 -335
  620. package/dist/utils/Data/getDataPath.js +0 -66
  621. package/dist/utils/Data/getDataPath.test.js +0 -49
  622. package/dist/utils/Data/getOptions.js +0 -86
  623. package/dist/utils/Data/getOptions.test.js +0 -279
  624. package/dist/utils/Data/getSourceData.js +0 -44
  625. package/dist/utils/Data/getSourceData.test.js +0 -158
  626. package/dist/utils/Data/index.js +0 -35
  627. package/dist/utils/Data/nestInRefdataOptions.js +0 -47
  628. package/dist/utils/Data/nestInRefdataOptions.test.js +0 -237
  629. package/dist/utils/Data/refDataToOptions.js +0 -44
  630. package/dist/utils/Data/refDataToOptions.test.js +0 -197
  631. package/dist/utils/Data/setDataItem.js +0 -26
  632. package/dist/utils/Data/setDataItem.test.js +0 -136
  633. package/dist/utils/Data/setupFormData.js +0 -49
  634. package/dist/utils/Data/setupFormData.test.js +0 -215
  635. package/dist/utils/Data/setupRefDataUrlForComponent.js +0 -44
  636. package/dist/utils/Data/setupRefDataUrlForComponent.test.js +0 -150
  637. package/dist/utils/FormPage/applyConditionalProperties.js +0 -34
  638. package/dist/utils/FormPage/applyConditionalProperties.test.js +0 -61
  639. package/dist/utils/FormPage/getConditionalText.js +0 -55
  640. package/dist/utils/FormPage/getConditionalText.test.js +0 -163
  641. package/dist/utils/FormPage/getFormPage.js +0 -54
  642. package/dist/utils/FormPage/getFormPage.test.js +0 -206
  643. package/dist/utils/FormPage/getFormPages.js +0 -30
  644. package/dist/utils/FormPage/getFormPages.test.js +0 -97
  645. package/dist/utils/FormPage/getPageActions.js +0 -58
  646. package/dist/utils/FormPage/getPageActions.test.js +0 -115
  647. package/dist/utils/FormPage/getParagraphFromText.js +0 -21
  648. package/dist/utils/FormPage/getParagraphFromText.test.js +0 -28
  649. package/dist/utils/FormPage/index.js +0 -24
  650. package/dist/utils/FormPage/showFormPage.js +0 -52
  651. package/dist/utils/FormPage/showFormPage.test.js +0 -181
  652. package/dist/utils/FormPage/showFormPageCYA.js +0 -23
  653. package/dist/utils/FormPage/showFormPageCYA.test.js +0 -29
  654. package/dist/utils/FormPage/useComponent.js +0 -83
  655. package/dist/utils/FormPage/useComponent.test.js +0 -216
  656. package/dist/utils/Format/formatData.js +0 -27
  657. package/dist/utils/Format/formatData.test.js +0 -46
  658. package/dist/utils/Format/formatDataForComponent.js +0 -35
  659. package/dist/utils/Format/formatDataForComponent.test.js +0 -114
  660. package/dist/utils/Format/formatDataForForm.js +0 -27
  661. package/dist/utils/Format/formatDataForForm.test.js +0 -79
  662. package/dist/utils/Format/formatDataForPage.js +0 -31
  663. package/dist/utils/Format/formatDataForPage.test.js +0 -94
  664. package/dist/utils/Format/index.js +0 -21
  665. package/dist/utils/Hub/getFormHub.js +0 -40
  666. package/dist/utils/Hub/getFormHub.test.js +0 -105
  667. package/dist/utils/Hub/index.js +0 -15
  668. package/dist/utils/Meta/constants.js +0 -9
  669. package/dist/utils/Meta/documents/getDocuments.js +0 -15
  670. package/dist/utils/Meta/documents/getDocuments.test.js +0 -46
  671. package/dist/utils/Meta/documents/index.js +0 -19
  672. package/dist/utils/Meta/documents/setDocumentsForField.js +0 -30
  673. package/dist/utils/Meta/documents/setDocumentsForField.test.js +0 -97
  674. package/dist/utils/Meta/index.js +0 -17
  675. package/dist/utils/Operate/checkValueIsTruthy.js +0 -29
  676. package/dist/utils/Operate/checkValueIsTruthy.test.js +0 -43
  677. package/dist/utils/Operate/deleteValueInFormData.js +0 -27
  678. package/dist/utils/Operate/deleteValueInFormData.test.js +0 -61
  679. package/dist/utils/Operate/doesContainValue.js +0 -35
  680. package/dist/utils/Operate/doesContainValue.test.js +0 -76
  681. package/dist/utils/Operate/getFirstOf.js +0 -31
  682. package/dist/utils/Operate/getFirstOf.test.js +0 -87
  683. package/dist/utils/Operate/getIndexOfMatchingValueIn.js +0 -68
  684. package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +0 -158
  685. package/dist/utils/Operate/getLength.js +0 -51
  686. package/dist/utils/Operate/getLength.test.js +0 -90
  687. package/dist/utils/Operate/index.js +0 -13
  688. package/dist/utils/Operate/persistValueInFormData.js +0 -40
  689. package/dist/utils/Operate/persistValueInFormData.test.js +0 -118
  690. package/dist/utils/Operate/runPageOperations.js +0 -75
  691. package/dist/utils/Operate/runPageOperations.test.js +0 -105
  692. package/dist/utils/Operate/setValueInFormData.js +0 -22
  693. package/dist/utils/Operate/setValueInFormData.test.js +0 -45
  694. package/dist/utils/Operate/shouldRun.js +0 -57
  695. package/dist/utils/Operate/shouldRun.test.js +0 -65
  696. package/dist/utils/Validate/additional/conditionallyPermittedChange.js +0 -26
  697. package/dist/utils/Validate/additional/conditionallyPermittedChange.test.js +0 -34
  698. package/dist/utils/Validate/additional/conditionallyRequired.js +0 -24
  699. package/dist/utils/Validate/additional/conditionallyRequired.test.js +0 -74
  700. package/dist/utils/Validate/additional/index.js +0 -74
  701. package/dist/utils/Validate/additional/index.test.js +0 -130
  702. package/dist/utils/Validate/additional/mustBeAfter.js +0 -34
  703. package/dist/utils/Validate/additional/mustBeAfter.test.js +0 -109
  704. package/dist/utils/Validate/additional/mustBeBefore.js +0 -34
  705. package/dist/utils/Validate/additional/mustBeBefore.test.js +0 -77
  706. package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +0 -57
  707. package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +0 -128
  708. package/dist/utils/Validate/additional/mustBeGreaterThan.js +0 -22
  709. package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +0 -57
  710. package/dist/utils/Validate/additional/mustBeInTheFuture.js +0 -33
  711. package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +0 -32
  712. package/dist/utils/Validate/additional/mustBeInThePast.js +0 -36
  713. package/dist/utils/Validate/additional/mustBeInThePast.test.js +0 -32
  714. package/dist/utils/Validate/additional/mustBeLessThan.js +0 -22
  715. package/dist/utils/Validate/additional/mustBeLessThan.test.js +0 -53
  716. package/dist/utils/Validate/additional/mustBeLongerThan.js +0 -23
  717. package/dist/utils/Validate/additional/mustBeLongerThan.test.js +0 -49
  718. package/dist/utils/Validate/additional/mustBeNumbersOnly.js +0 -24
  719. package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +0 -45
  720. package/dist/utils/Validate/additional/mustBeOneOf.js +0 -22
  721. package/dist/utils/Validate/additional/mustBeOneOf.test.js +0 -37
  722. package/dist/utils/Validate/additional/mustBeShorterThan.js +0 -23
  723. package/dist/utils/Validate/additional/mustBeShorterThan.test.js +0 -49
  724. package/dist/utils/Validate/additional/mustBeUniqueInCollection.js +0 -40
  725. package/dist/utils/Validate/additional/mustBeUniqueInCollection.test.js +0 -163
  726. package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +0 -26
  727. package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +0 -37
  728. package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +0 -19
  729. package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +0 -37
  730. package/dist/utils/Validate/additional/mustNotContainSql.js +0 -19
  731. package/dist/utils/Validate/additional/mustNotContainSql.test.js +0 -33
  732. package/dist/utils/Validate/additional/mustSelectOnlyOne.js +0 -29
  733. package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +0 -55
  734. package/dist/utils/Validate/additional/utils.js +0 -35
  735. package/dist/utils/Validate/index.js +0 -33
  736. package/dist/utils/Validate/validateCollection.js +0 -50
  737. package/dist/utils/Validate/validateCollection.test.js +0 -134
  738. package/dist/utils/Validate/validateComponent.js +0 -126
  739. package/dist/utils/Validate/validateComponent.test.js +0 -435
  740. package/dist/utils/Validate/validateContainer.js +0 -52
  741. package/dist/utils/Validate/validateContainer.test.js +0 -115
  742. package/dist/utils/Validate/validateDate.js +0 -112
  743. package/dist/utils/Validate/validateDate.test.js +0 -133
  744. package/dist/utils/Validate/validateEmail.js +0 -45
  745. package/dist/utils/Validate/validateEmail.test.js +0 -78
  746. package/dist/utils/Validate/validateMultifile.js +0 -29
  747. package/dist/utils/Validate/validateMultifile.test.js +0 -46
  748. package/dist/utils/Validate/validateOnPageLoad.js +0 -24
  749. package/dist/utils/Validate/validateOnPageLoad.test.js +0 -89
  750. package/dist/utils/Validate/validatePage.js +0 -56
  751. package/dist/utils/Validate/validatePage.test.js +0 -795
  752. package/dist/utils/Validate/validateRegex.js +0 -41
  753. package/dist/utils/Validate/validateRegex.test.js +0 -43
  754. package/dist/utils/Validate/validateRequired.js +0 -37
  755. package/dist/utils/Validate/validateRequired.test.js +0 -64
  756. package/dist/utils/Validate/validateTextArea.js +0 -36
  757. package/dist/utils/Validate/validateTextArea.test.js +0 -71
  758. package/dist/utils/Validate/validateTime.js +0 -76
  759. package/dist/utils/Validate/validateTime.test.js +0 -116
  760. package/dist/utils/canOverrideFieldRequired.js +0 -23
  761. package/dist/utils/index.js +0 -42
@@ -1,399 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.toArray = exports.removeObjectWithOnlySingleIdField = exports.removeEmptyArraysAndUnusedCollectionIDs = exports.pruneCollectionEntry = exports.iterateOptions = exports.isShowEntity = exports.getNestedQuestionPath = exports.getImmediateParent = exports.getDependencyObjectFromPath = exports.getDependencies = exports.findComponentDefinitionInForm = exports.deleteNodeByPath = exports.deleteCorrespondingMetaInfo = exports.deleteComponentData = exports.addValue = void 0;
7
- var _Condition = _interopRequireDefault(require("../../../utils/Condition"));
8
- function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
9
- /* eslint-disable no-param-reassign */
10
-
11
- /**
12
- * Add a value to a map of arrays. If the key exists, append the value to the array.
13
- * If not, create the map entry with that key.
14
- *
15
- * @param {*} key
16
- * @param {*} value
17
- * @param {*} multiMap
18
- */
19
- const addValue = (key, value, multiMap) => {
20
- if (!multiMap.has(key)) {
21
- multiMap.set(key, []);
22
- }
23
- multiMap.get(key).push(value);
24
- };
25
-
26
- /**
27
- * Given a path, remove a node from this path within an object.
28
- *
29
- * @param {Object} payload Javascript object from which the node will be deleted. Updated by the method.
30
- * @param {String} path A string containing a decimal point delimited path specifying the node to delete.
31
- * @return {void}, obj above updated.
32
- */
33
- exports.addValue = addValue;
34
- const deleteNodeByPath = (payload, path) => {
35
- if (Array.isArray(payload)) {
36
- // If payload is an array, recursively call deleteNodeByPath on each element
37
- for (let i = 0; i < payload.length; i += 1) {
38
- deleteNodeByPath(payload[i], path);
39
- }
40
- }
41
- const keys = path.split('.');
42
- let current = payload;
43
- for (let i = 0; i < keys.length - 1; i += 1) {
44
- current = current[keys[i]];
45
- if (current === undefined) {
46
- return;
47
- }
48
- }
49
- if (current[keys[keys.length - 1]]) {
50
- delete current[keys[keys.length - 1]];
51
- }
52
- };
53
-
54
- /**
55
- * Return the immediate parent of a path string passed in.
56
- * Useful for processing 'options' in a form, as nested fieldIds are placed in the payload at
57
- * the same level in the heirarchy as the option question they relate to.
58
- *
59
- * @param {String} path Decimal point delimited path.
60
- * @returns {String} Immediate parent of the path passed in.
61
- */
62
- exports.deleteNodeByPath = deleteNodeByPath;
63
- const getImmediateParent = path => {
64
- if (typeof path !== 'string' || !path.includes('.')) {
65
- return null;
66
- }
67
- const parts = path.split('.');
68
- parts.pop();
69
- return parts.join('.');
70
- };
71
-
72
- /**
73
- * Questions can be nested within options, eg if you answer 'yes' to a radio question, this can
74
- * reveal additional nested questions.
75
- * The path of the fields from these nested questions are at the same level as the original option
76
- * answer, so this utility derives the nested question path from the option path.
77
- *
78
- * @param {String} optionPath Decimal point delimited path
79
- * @param {String} nestedFieldId fieldId (dataname) of the nested question within the above option
80
- * @returns {String} Fully qualified path of the nested question
81
- */
82
- exports.getImmediateParent = getImmediateParent;
83
- const getNestedQuestionPath = (optionPath, nestedFieldId) => {
84
- const parentPath = getImmediateParent(optionPath);
85
- return parentPath ? "".concat(parentPath, ".").concat(nestedFieldId) : nestedFieldId;
86
- };
87
-
88
- /**
89
- * Pruning a collection payload may have resulted in objects that are only left with their 'id' field, which isn't data
90
- * but added by the renderer to find the activeId. If so, remove these objects entirely as they have been pruned.
91
- *
92
- * @param {Array} array Array of objects. Each object which has only 1 remaining field called 'id' should be removed.
93
- * @return {void}, array above updated.
94
- */
95
- exports.getNestedQuestionPath = getNestedQuestionPath;
96
- const removeObjectWithOnlySingleIdField = array => {
97
- for (let i = array.length - 1; i >= 0; i -= 1) {
98
- const obj = array[i];
99
- if (Object.keys(obj).length === 1 && Object.keys(obj)[0] === 'id') {
100
- array.splice(i, 1);
101
- }
102
- }
103
- };
104
-
105
- /**
106
- * Helper method to establish all the payload paths (dependencies) that an entity (page or component) is
107
- * dependent on through its show_when rule.
108
- *
109
- * This will be used to build a graph of chained dependencies to establish in which order
110
- * to resolve dependencies. The exact rule is not required at this point, just the dependencies.
111
- *
112
- * The form specification allows complex show_when blocks including 1...n levels of nesting, so
113
- * recursively search through the show_when block looking for all 'field' data items.
114
- *
115
- * @param {Object} entity Entity whose show_when rule is to be searched for 'field' data items within.
116
- * @returns {Set} Set of payload paths that the entity (page or component) is dependent on.
117
- */
118
- exports.removeObjectWithOnlySingleIdField = removeObjectWithOnlySingleIdField;
119
- const getDependencies = entity => {
120
- const findShowWhenFields = (showWhenObject, showWhenFields) => {
121
- if (typeof showWhenObject === 'object' && showWhenObject !== null) {
122
- if (Array.isArray(showWhenObject)) {
123
- showWhenObject.forEach(value => {
124
- findShowWhenFields(value, showWhenFields);
125
- });
126
- } else {
127
- Object.keys(showWhenObject).forEach(key => {
128
- if (key === 'field') {
129
- showWhenFields.push(showWhenObject[key]);
130
- }
131
- findShowWhenFields(showWhenObject[key], showWhenFields);
132
- });
133
- }
134
- }
135
- return showWhenFields;
136
- };
137
- return entity.show_when ? new Set(findShowWhenFields(entity.show_when, []) || []) : null;
138
- };
139
-
140
- /**
141
- * Some show_when field values point to data items that are within objects provided by
142
- * external calls to refdata, eg modeOfTransport.id. These won't map directly to the path
143
- * keyed components in the allComponents map, so go back up levels in the path until we find
144
- * the component that creates this field.
145
- *
146
- * This component might not be found at all, as the dependency might be on a field that is either
147
- * provided by cop-ui (eg jobHolderStaffDetails.linemanagerEmail), or by the "addToFormData" function
148
- * (eg epmsSubmitted). These will be leaf level in the dependency chain so component is not required.
149
- *
150
- * @param {String} optionPath Decimal point delimited path
151
- * @param {String} nestedFieldId fieldId (dataname) of the nested question within the above option
152
- * @returns {String} Fully qualified path of the nested question
153
- *
154
- */
155
- exports.getDependencies = getDependencies;
156
- const getDependencyObjectFromPath = (dependencyPath, allComponents) => {
157
- const segments = dependencyPath.split(".");
158
- for (let i = segments.length; i > 0; i -= 1) {
159
- const currentPath = segments.slice(0, i).join(".");
160
- const dependencyObject = allComponents.get(currentPath);
161
- if (dependencyObject) return dependencyObject;
162
- }
163
- return null;
164
- };
165
-
166
- /**
167
- *
168
- * Evaluate the show_when rule to establish if the component should be shown (and the
169
- * payload data should not be pruned). If there is no show_when rule, then return true.
170
- *
171
- * @param {*} entity A page or component that may have a show_when rule associated with it
172
- * @param {*} data The payload data used to evaluate the show_when rule
173
- * @returns {boolean} true if the show_when rule evaluate to true, or there is no show_when rule
174
- */
175
- exports.getDependencyObjectFromPath = getDependencyObjectFromPath;
176
- const isShowEntity = (entity, data) => {
177
- var _entity$show_when;
178
- // If there is no rule set, then the entity can be shown
179
- if (!entity.show_when) {
180
- return true;
181
- }
182
- if (((_entity$show_when = entity.show_when) === null || _entity$show_when === void 0 ? void 0 : _entity$show_when.type) === "or") {
183
- return _Condition.default.meetsOne(entity, data);
184
- }
185
- return _Condition.default.meetsAll(entity, data);
186
- };
187
-
188
- /**
189
- *
190
- * Components can be assigned to pages in 2 ways in the form specification:
191
- *
192
- * 1 - They can be included in the page's components array with the 'use' field, e.g.
193
- * {
194
- * "use": "port"
195
- * }
196
- * This "use" value will normally match a component's id, but can match its fieldId
197
- * NB. In this case, a show_when rule can be applied here, which will supercede any show_when in the component. e.g.
198
- *
199
- * {
200
- * "use": "port",
201
- * "show_when": ....
202
- * }
203
- *
204
- * 2 - The entire component can be embedded as an entry in the page's component array.
205
- *
206
- *
207
- * @param {*} componentId The id of the component to find in the form.
208
- * @param {*} componentByIdMap A map of all the form's components keyed on Id, for better performance than searching the form.
209
- * @param {*} componentByFieldIdMap A map of all the form's components keyed on fieldId, for better performance than searching the form.
210
- * @returns {Object} A cloned component object, containing the full definition of that component.
211
- */
212
- exports.isShowEntity = isShowEntity;
213
- const findComponentDefinitionInForm = (pageComponentDef, componentByIdMap, componentByFieldIdMap) => {
214
- var _ref, _componentByIdMap$get;
215
- const componentInForm = (_ref = (_componentByIdMap$get = componentByIdMap.get(pageComponentDef.use)) !== null && _componentByIdMap$get !== void 0 ? _componentByIdMap$get : componentByFieldIdMap.get(pageComponentDef.use)) !== null && _ref !== void 0 ? _ref : pageComponentDef;
216
-
217
- // Create clone of component, so processing can make changes to it without changing the form
218
- const componentInFormClone = JSON.parse(JSON.stringify(componentInForm));
219
- if (pageComponentDef.use && pageComponentDef.show_when) {
220
- componentInFormClone.show_when = pageComponentDef.show_when;
221
- }
222
- return componentInFormClone;
223
- };
224
-
225
- /**
226
- *
227
- * When documents are added to the payload of type multifile, they are also added to a section of the payload
228
- * 'meta', specifically an array 'documents'. When we remove the multifile elements, we need to remove
229
- * the corresponding meta.document entries.
230
- *
231
- * @param {*} component The component definition being deleted that needs corresponding meta data also deleted
232
- * @param {*} collectionDataObject The payload containing the file data being deleted (for which the corresponding meta needs deleting)
233
- * @param {*} formData The entire payload, which will include the meta section
234
- * @returns {void}, as the formData will be updated in situ
235
- */
236
- exports.findComponentDefinitionInForm = findComponentDefinitionInForm;
237
- const deleteCorrespondingMetaInfo = (component, collectionDataObject, formData) => {
238
- const {
239
- meta: {
240
- documents
241
- }
242
- } = formData;
243
- const fileDataBeingDeleted = collectionDataObject[component.fieldId];
244
- if (!documents || !fileDataBeingDeleted) return;
245
- const fileDataAsArray = Array.isArray(fileDataBeingDeleted) ? fileDataBeingDeleted : [fileDataBeingDeleted];
246
- // Iterate backwards to avoid index shifting when removing elements
247
- for (let i = fileDataAsArray.length - 1; i >= 0; i -= 1) {
248
- const matchIndex = documents.findIndex(metaDocument => metaDocument.url === fileDataAsArray[i].url);
249
- if (matchIndex !== -1) {
250
- documents.splice(matchIndex, 1);
251
- }
252
- }
253
- };
254
-
255
- /**
256
- * After the payload has been cleansed of individual data items, empty arrays and objects may remain.
257
- * Removing an array (when the payload for a collection) may leave a redundant activeId field. The active Id
258
- * fields are not part of the payload data, but added by the react renderer to track which collection object
259
- * is currently being worked on, so can be removed.
260
- *
261
- * To tidy this all up, recursively empty arrays and their associated "ActiveId" fields from a nested payload.
262
- *
263
- * This function traverses a given payload, which can be an array or an object, and performs the following operations:
264
- * 1. If an empty array is found inside an array, it is removed using `splice`.
265
- * 2. If an empty array is found inside an object:
266
- * - It is removed from the object.
267
- * - If there is a corresponding `<key>ActiveId` field, that field is also removed.
268
- * 3. The function operates recursively to handle deeply nested structures.
269
- *
270
- * @param {any} payload - The input data structure, which can be an array or an object.
271
- *
272
- */
273
- exports.deleteCorrespondingMetaInfo = deleteCorrespondingMetaInfo;
274
- const removeEmptyArraysAndUnusedCollectionIDs = payload => {
275
- if (Array.isArray(payload)) {
276
- for (let i = payload.length - 1; i >= 0; i -= 1) {
277
- if (Array.isArray(payload[i]) && payload[i].length === 0) {
278
- payload.splice(i, 1);
279
- } else {
280
- removeEmptyArraysAndUnusedCollectionIDs(payload[i]); // Recurse for nested structures
281
- }
282
- // When unwinding out of the recursion, we may have emptied an object which is the remaining element of an
283
- // array, in which case remove the element
284
- if (typeof payload[i] === 'object' && Object.keys(payload[i]).length === 0) {
285
- payload.splice(i, 1);
286
- }
287
- }
288
- } else if (payload !== null && typeof payload === 'object') {
289
- Object.keys(payload).forEach(key => {
290
- if (Array.isArray(payload[key]) && payload[key].length === 0) {
291
- // If the array being removed has an activeId associated with it, remove it
292
- if (payload["".concat(key, "ActiveId")]) {
293
- delete payload["".concat(key, "ActiveId")];
294
- }
295
- delete payload["".concat(key, "ActiveId")];
296
- if (payload[key]) {
297
- delete payload[key];
298
- }
299
- } else {
300
- removeEmptyArraysAndUnusedCollectionIDs(payload[key]); // Recurse for nested structures
301
- }
302
- });
303
- }
304
- };
305
-
306
- /**
307
- * Helper method to go through each option calling a passed in function for any nested fields.
308
- * @param {Object} component The form component representing the path being deleted
309
- * @param {Function} action The action to perform on each nested question. Varies for collections and non-collections
310
- * @return {void}, obj above updated.
311
- */
312
- exports.removeEmptyArraysAndUnusedCollectionIDs = removeEmptyArraysAndUnusedCollectionIDs;
313
- const iterateOptions = (component, action) => {
314
- var _component$data;
315
- if (component !== null && component !== void 0 && (_component$data = component.data) !== null && _component$data !== void 0 && _component$data.options) {
316
- var _component$data2;
317
- component === null || component === void 0 || (_component$data2 = component.data) === null || _component$data2 === void 0 || (_component$data2 = _component$data2.options) === null || _component$data2 === void 0 || _component$data2.forEach(option => {
318
- var _option$nested;
319
- (_option$nested = option.nested) === null || _option$nested === void 0 || _option$nested.forEach(action);
320
- });
321
- }
322
- };
323
-
324
- /**
325
- * Delete a component's payload item from the overall payload.
326
- * A component can be defined in >1 places in the form spec. To cater for this,
327
- * if the componentsToKeep counter tells us that there is > 1 uses of this component
328
- * still unaccounted for in the form then don't delete, but reduce the count by 1.
329
- *
330
- * When the counter reaches 1 we know all other occurences of the component have been resolved
331
- * so it is safe to delete.
332
- *
333
- *
334
- * @param {*} payload The form payload from which to delete the component data
335
- * @param {*} path The payload path of the component
336
- * @param {*} component The component whose data we should attempt to delete
337
- * @param {*} componentsToKeep A list of all components with a count of their number of uses in the form
338
- */
339
- exports.iterateOptions = iterateOptions;
340
- const deleteComponentData = (payload, path, component, componentsToKeep) => {
341
- if (componentsToKeep[path] > 1) {
342
- componentsToKeep[path] -= 1;
343
- } else {
344
- if (component.preserveInPayload) return;
345
- deleteNodeByPath(payload, path);
346
-
347
- // If the component has options, go through each option removing the data for any nested fields. Required as nested options are in the payload at the same heirarchical level.
348
- iterateOptions(component, nested => {
349
- const nestedQuestionPath = getNestedQuestionPath(path, nested.fieldId);
350
- if (componentsToKeep[nestedQuestionPath] > 1) {
351
- componentsToKeep[nestedQuestionPath] -= 1;
352
- } else {
353
- deleteNodeByPath(payload, nestedQuestionPath);
354
- }
355
- });
356
- }
357
- };
358
-
359
- /**
360
- *
361
- * Takes a single page collection payload object and removes the payload items specified in the componentsToPrune list
362
- * as long as they don't appear in the componentsToKeep list.
363
- *
364
- * Additionally, if the component type is multifile, remove the corresponding data entries that will have been created
365
- * in the meta section of the payload by the form renderer.
366
- *
367
- * @param {Set} pathsToKeep paths that we cannot delete from the collectionDataObject
368
- * @param {Map} componentsToPrune paths that we should delete, as long as they are not in the pathsToKeep
369
- * @param {Object} collectionDataObject the payload from which to delete the paths
370
- * @param {Object} formData The form data, whose meta section may include corresponding documents entries for multifile entries
371
- */
372
- exports.deleteComponentData = deleteComponentData;
373
- const pruneCollectionEntry = (pathsToKeep, componentsToPrune, collectionDataObject, formData) => {
374
- componentsToPrune.forEach(component => {
375
- if (!pathsToKeep.has(component.fieldId)) {
376
- if (component.type === "multifile") {
377
- deleteCorrespondingMetaInfo(component, collectionDataObject, formData);
378
- }
379
- if (component.preserveInPayload) return;
380
- deleteNodeByPath(collectionDataObject, component.fieldId);
381
-
382
- // If the component has options, go through each option removing the data for any nested fields. Required as nested options are in the payload at the same heirarchical level.
383
- iterateOptions(component, nested => {
384
- const nestedQuestionPath = getNestedQuestionPath(component.fieldId, nested.fieldId);
385
- if (!pathsToKeep.has(nestedQuestionPath)) {
386
- deleteNodeByPath(collectionDataObject, nestedQuestionPath);
387
- }
388
- });
389
- }
390
- });
391
- };
392
-
393
- /*
394
- * Converts an object to an array if it isn't already, for use when combining show when rules.
395
- */
396
- exports.pruneCollectionEntry = pruneCollectionEntry;
397
- const toArray = value => Array.isArray(value) ? value : [value];
398
- exports.toArray = toArray;
399
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQ29uZGl0aW9uIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJhZGRWYWx1ZSIsImtleSIsInZhbHVlIiwibXVsdGlNYXAiLCJoYXMiLCJzZXQiLCJnZXQiLCJwdXNoIiwiZXhwb3J0cyIsImRlbGV0ZU5vZGVCeVBhdGgiLCJwYXlsb2FkIiwicGF0aCIsIkFycmF5IiwiaXNBcnJheSIsImkiLCJsZW5ndGgiLCJrZXlzIiwic3BsaXQiLCJjdXJyZW50IiwidW5kZWZpbmVkIiwiZ2V0SW1tZWRpYXRlUGFyZW50IiwiaW5jbHVkZXMiLCJwYXJ0cyIsInBvcCIsImpvaW4iLCJnZXROZXN0ZWRRdWVzdGlvblBhdGgiLCJvcHRpb25QYXRoIiwibmVzdGVkRmllbGRJZCIsInBhcmVudFBhdGgiLCJjb25jYXQiLCJyZW1vdmVPYmplY3RXaXRoT25seVNpbmdsZUlkRmllbGQiLCJhcnJheSIsIm9iaiIsIk9iamVjdCIsInNwbGljZSIsImdldERlcGVuZGVuY2llcyIsImVudGl0eSIsImZpbmRTaG93V2hlbkZpZWxkcyIsInNob3dXaGVuT2JqZWN0Iiwic2hvd1doZW5GaWVsZHMiLCJmb3JFYWNoIiwic2hvd193aGVuIiwiU2V0IiwiZ2V0RGVwZW5kZW5jeU9iamVjdEZyb21QYXRoIiwiZGVwZW5kZW5jeVBhdGgiLCJhbGxDb21wb25lbnRzIiwic2VnbWVudHMiLCJjdXJyZW50UGF0aCIsInNsaWNlIiwiZGVwZW5kZW5jeU9iamVjdCIsImlzU2hvd0VudGl0eSIsImRhdGEiLCJfZW50aXR5JHNob3dfd2hlbiIsInR5cGUiLCJDb25kaXRpb24iLCJtZWV0c09uZSIsIm1lZXRzQWxsIiwiZmluZENvbXBvbmVudERlZmluaXRpb25JbkZvcm0iLCJwYWdlQ29tcG9uZW50RGVmIiwiY29tcG9uZW50QnlJZE1hcCIsImNvbXBvbmVudEJ5RmllbGRJZE1hcCIsIl9yZWYiLCJfY29tcG9uZW50QnlJZE1hcCRnZXQiLCJjb21wb25lbnRJbkZvcm0iLCJ1c2UiLCJjb21wb25lbnRJbkZvcm1DbG9uZSIsIkpTT04iLCJwYXJzZSIsInN0cmluZ2lmeSIsImRlbGV0ZUNvcnJlc3BvbmRpbmdNZXRhSW5mbyIsImNvbXBvbmVudCIsImNvbGxlY3Rpb25EYXRhT2JqZWN0IiwiZm9ybURhdGEiLCJtZXRhIiwiZG9jdW1lbnRzIiwiZmlsZURhdGFCZWluZ0RlbGV0ZWQiLCJmaWVsZElkIiwiZmlsZURhdGFBc0FycmF5IiwibWF0Y2hJbmRleCIsImZpbmRJbmRleCIsIm1ldGFEb2N1bWVudCIsInVybCIsInJlbW92ZUVtcHR5QXJyYXlzQW5kVW51c2VkQ29sbGVjdGlvbklEcyIsIml0ZXJhdGVPcHRpb25zIiwiYWN0aW9uIiwiX2NvbXBvbmVudCRkYXRhIiwib3B0aW9ucyIsIl9jb21wb25lbnQkZGF0YTIiLCJvcHRpb24iLCJfb3B0aW9uJG5lc3RlZCIsIm5lc3RlZCIsImRlbGV0ZUNvbXBvbmVudERhdGEiLCJjb21wb25lbnRzVG9LZWVwIiwicHJlc2VydmVJblBheWxvYWQiLCJuZXN0ZWRRdWVzdGlvblBhdGgiLCJwcnVuZUNvbGxlY3Rpb25FbnRyeSIsInBhdGhzVG9LZWVwIiwiY29tcG9uZW50c1RvUHJ1bmUiLCJ0b0FycmF5Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvRm9ybVJlbmRlcmVyL2hlbHBlcnMvY2xlYXJPdXRVbmNvbXBsZXRlZFJvdXRlc1V0aWxzLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb25kaXRpb24gZnJvbSBcIi4uLy4uLy4uL3V0aWxzL0NvbmRpdGlvblwiO1xuXG4vKiBlc2xpbnQtZGlzYWJsZSBuby1wYXJhbS1yZWFzc2lnbiAqL1xuXG4vKipcbiAqIEFkZCBhIHZhbHVlIHRvIGEgbWFwIG9mIGFycmF5cy4gSWYgdGhlIGtleSBleGlzdHMsIGFwcGVuZCB0aGUgdmFsdWUgdG8gdGhlIGFycmF5LlxuICogSWYgbm90LCBjcmVhdGUgdGhlIG1hcCBlbnRyeSB3aXRoIHRoYXQga2V5LlxuICogXG4gKiBAcGFyYW0geyp9IGtleSBcbiAqIEBwYXJhbSB7Kn0gdmFsdWUgXG4gKiBAcGFyYW0geyp9IG11bHRpTWFwIFxuICovXG5leHBvcnQgY29uc3QgYWRkVmFsdWUgPSAoa2V5LCB2YWx1ZSwgbXVsdGlNYXApID0+IHtcbiAgICBpZiAoIW11bHRpTWFwLmhhcyhrZXkpKSB7XG4gICAgICAgIG11bHRpTWFwLnNldChrZXksIFtdKTtcbiAgICB9XG4gICAgbXVsdGlNYXAuZ2V0KGtleSkucHVzaCh2YWx1ZSk7XG59O1xuXG4vKipcbiAqIEdpdmVuIGEgcGF0aCwgcmVtb3ZlIGEgbm9kZSBmcm9tIHRoaXMgcGF0aCB3aXRoaW4gYW4gb2JqZWN0LiBcbiAqIFxuICogQHBhcmFtIHtPYmplY3R9IHBheWxvYWQgSmF2YXNjcmlwdCBvYmplY3QgZnJvbSB3aGljaCB0aGUgbm9kZSB3aWxsIGJlIGRlbGV0ZWQuIFVwZGF0ZWQgYnkgdGhlIG1ldGhvZC5cbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXRoIEEgc3RyaW5nIGNvbnRhaW5pbmcgYSBkZWNpbWFsIHBvaW50IGRlbGltaXRlZCBwYXRoIHNwZWNpZnlpbmcgdGhlIG5vZGUgdG8gZGVsZXRlLlxuICogQHJldHVybiB7dm9pZH0sIG9iaiBhYm92ZSB1cGRhdGVkLlxuICovXG5leHBvcnQgY29uc3QgZGVsZXRlTm9kZUJ5UGF0aCA9IChwYXlsb2FkLCBwYXRoKSA9PiB7XG4gICAgaWYgKEFycmF5LmlzQXJyYXkocGF5bG9hZCkpIHtcbiAgICAgICAgLy8gSWYgcGF5bG9hZCBpcyBhbiBhcnJheSwgcmVjdXJzaXZlbHkgY2FsbCBkZWxldGVOb2RlQnlQYXRoIG9uIGVhY2ggZWxlbWVudFxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHBheWxvYWQubGVuZ3RoOyBpICs9IDEpIHtcbiAgICAgICAgICAgIGRlbGV0ZU5vZGVCeVBhdGgocGF5bG9hZFtpXSwgcGF0aCk7XG4gICAgICAgIH1cbiAgICB9XG4gICAgY29uc3Qga2V5cyA9IHBhdGguc3BsaXQoJy4nKTtcbiAgICBsZXQgY3VycmVudCA9IHBheWxvYWQ7XG5cbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IGtleXMubGVuZ3RoIC0gMTsgaSArPSAxKSB7XG4gICAgICAgIGN1cnJlbnQgPSBjdXJyZW50W2tleXNbaV1dO1xuICAgICAgICBpZiAoY3VycmVudCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoY3VycmVudFtrZXlzW2tleXMubGVuZ3RoIC0gMV1dKSB7XG4gICAgICAgIGRlbGV0ZSBjdXJyZW50W2tleXNba2V5cy5sZW5ndGggLSAxXV07XG4gICAgfVxufTtcblxuLyoqXG4gKiBSZXR1cm4gdGhlIGltbWVkaWF0ZSBwYXJlbnQgb2YgYSBwYXRoIHN0cmluZyBwYXNzZWQgaW4uXG4gKiBVc2VmdWwgZm9yIHByb2Nlc3NpbmcgJ29wdGlvbnMnIGluIGEgZm9ybSwgYXMgbmVzdGVkIGZpZWxkSWRzIGFyZSBwbGFjZWQgaW4gdGhlIHBheWxvYWQgYXQgXG4gKiB0aGUgc2FtZSBsZXZlbCBpbiB0aGUgaGVpcmFyY2h5IGFzIHRoZSBvcHRpb24gcXVlc3Rpb24gdGhleSByZWxhdGUgdG8uXG4gKiBcbiAqIEBwYXJhbSB7U3RyaW5nfSBwYXRoIERlY2ltYWwgcG9pbnQgZGVsaW1pdGVkIHBhdGguXG4gKiBAcmV0dXJucyB7U3RyaW5nfSBJbW1lZGlhdGUgcGFyZW50IG9mIHRoZSBwYXRoIHBhc3NlZCBpbi5cbiAqL1xuZXhwb3J0IGNvbnN0IGdldEltbWVkaWF0ZVBhcmVudCA9IChwYXRoKSA9PiB7XG4gICAgaWYgKHR5cGVvZiBwYXRoICE9PSAnc3RyaW5nJyB8fCAhcGF0aC5pbmNsdWRlcygnLicpKSB7XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbiAgICBjb25zdCBwYXJ0cyA9IHBhdGguc3BsaXQoJy4nKTtcbiAgICBwYXJ0cy5wb3AoKTtcbiAgICByZXR1cm4gcGFydHMuam9pbignLicpO1xufTtcblxuLyoqXG4gKiBRdWVzdGlvbnMgY2FuIGJlIG5lc3RlZCB3aXRoaW4gb3B0aW9ucywgZWcgaWYgeW91IGFuc3dlciAneWVzJyB0byBhIHJhZGlvIHF1ZXN0aW9uLCB0aGlzIGNhbiBcbiAqIHJldmVhbCBhZGRpdGlvbmFsIG5lc3RlZCBxdWVzdGlvbnMuXG4gKiBUaGUgcGF0aCBvZiB0aGUgZmllbGRzIGZyb20gdGhlc2UgbmVzdGVkIHF1ZXN0aW9ucyBhcmUgYXQgdGhlIHNhbWUgbGV2ZWwgYXMgdGhlIG9yaWdpbmFsIG9wdGlvblxuICogYW5zd2VyLCBzbyB0aGlzIHV0aWxpdHkgZGVyaXZlcyB0aGUgbmVzdGVkIHF1ZXN0aW9uIHBhdGggZnJvbSB0aGUgb3B0aW9uIHBhdGguXG4gKiBcbiAqIEBwYXJhbSB7U3RyaW5nfSBvcHRpb25QYXRoIERlY2ltYWwgcG9pbnQgZGVsaW1pdGVkIHBhdGhcbiAqIEBwYXJhbSB7U3RyaW5nfSBuZXN0ZWRGaWVsZElkIGZpZWxkSWQgKGRhdGFuYW1lKSBvZiB0aGUgbmVzdGVkIHF1ZXN0aW9uIHdpdGhpbiB0aGUgYWJvdmUgb3B0aW9uXG4gKiBAcmV0dXJucyB7U3RyaW5nfSBGdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgbmVzdGVkIHF1ZXN0aW9uXG4gKi9cbmV4cG9ydCBjb25zdCBnZXROZXN0ZWRRdWVzdGlvblBhdGggPSAob3B0aW9uUGF0aCwgbmVzdGVkRmllbGRJZCkgPT4ge1xuICAgIGNvbnN0IHBhcmVudFBhdGggPSBnZXRJbW1lZGlhdGVQYXJlbnQob3B0aW9uUGF0aCk7XG4gICAgcmV0dXJuIHBhcmVudFBhdGggPyBgJHtwYXJlbnRQYXRofS4ke25lc3RlZEZpZWxkSWR9YCA6IG5lc3RlZEZpZWxkSWQ7XG59O1xuXG4vKipcbiAqIFBydW5pbmcgYSBjb2xsZWN0aW9uIHBheWxvYWQgbWF5IGhhdmUgcmVzdWx0ZWQgaW4gb2JqZWN0cyB0aGF0IGFyZSBvbmx5IGxlZnQgd2l0aCB0aGVpciAnaWQnIGZpZWxkLCB3aGljaCBpc24ndCBkYXRhIFxuICogYnV0IGFkZGVkIGJ5IHRoZSByZW5kZXJlciB0byBmaW5kIHRoZSBhY3RpdmVJZC4gSWYgc28sIHJlbW92ZSB0aGVzZSBvYmplY3RzIGVudGlyZWx5IGFzIHRoZXkgaGF2ZSBiZWVuIHBydW5lZC5cbiAqIFxuICogQHBhcmFtIHtBcnJheX0gYXJyYXkgQXJyYXkgb2Ygb2JqZWN0cy4gRWFjaCBvYmplY3Qgd2hpY2ggaGFzIG9ubHkgMSByZW1haW5pbmcgZmllbGQgY2FsbGVkICdpZCcgc2hvdWxkIGJlIHJlbW92ZWQuXG4gKiBAcmV0dXJuIHt2b2lkfSwgYXJyYXkgYWJvdmUgdXBkYXRlZC5cbiAqL1xuZXhwb3J0IGNvbnN0IHJlbW92ZU9iamVjdFdpdGhPbmx5U2luZ2xlSWRGaWVsZCA9IChhcnJheSkgPT4ge1xuICAgIGZvciAobGV0IGkgPSBhcnJheS5sZW5ndGggLSAxOyBpID49IDA7IGkgLT0gMSkge1xuICAgICAgICBjb25zdCBvYmogPSBhcnJheVtpXTtcbiAgICAgICAgaWYgKE9iamVjdC5rZXlzKG9iaikubGVuZ3RoID09PSAxICYmIE9iamVjdC5rZXlzKG9iailbMF0gPT09ICdpZCcpIHtcbiAgICAgICAgICAgIGFycmF5LnNwbGljZShpLCAxKTtcbiAgICAgICAgfVxuICAgIH1cbn07XG5cbi8qKlxuICogSGVscGVyIG1ldGhvZCB0byBlc3RhYmxpc2ggYWxsIHRoZSBwYXlsb2FkIHBhdGhzIChkZXBlbmRlbmNpZXMpIHRoYXQgYW4gZW50aXR5IChwYWdlIG9yIGNvbXBvbmVudCkgaXMgXG4gKiBkZXBlbmRlbnQgb24gdGhyb3VnaCBpdHMgc2hvd193aGVuIHJ1bGUuXG4gKiBcbiAqIFRoaXMgd2lsbCBiZSB1c2VkIHRvIGJ1aWxkIGEgZ3JhcGggb2YgY2hhaW5lZCBkZXBlbmRlbmNpZXMgdG8gZXN0YWJsaXNoIGluIHdoaWNoIG9yZGVyXG4gKiB0byByZXNvbHZlIGRlcGVuZGVuY2llcy4gVGhlIGV4YWN0IHJ1bGUgaXMgbm90IHJlcXVpcmVkIGF0IHRoaXMgcG9pbnQsIGp1c3QgdGhlIGRlcGVuZGVuY2llcy5cbiAqIFxuICogVGhlIGZvcm0gc3BlY2lmaWNhdGlvbiBhbGxvd3MgY29tcGxleCBzaG93X3doZW4gYmxvY2tzIGluY2x1ZGluZyAxLi4ubiBsZXZlbHMgb2YgbmVzdGluZywgc29cbiAqIHJlY3Vyc2l2ZWx5IHNlYXJjaCB0aHJvdWdoIHRoZSBzaG93X3doZW4gYmxvY2sgbG9va2luZyBmb3IgYWxsICdmaWVsZCcgZGF0YSBpdGVtcy5cbiAqICAgXG4gKiBAcGFyYW0ge09iamVjdH0gZW50aXR5IEVudGl0eSB3aG9zZSBzaG93X3doZW4gcnVsZSBpcyB0byBiZSBzZWFyY2hlZCBmb3IgJ2ZpZWxkJyBkYXRhIGl0ZW1zIHdpdGhpbi5cbiAqIEByZXR1cm5zIHtTZXR9IFNldCBvZiBwYXlsb2FkIHBhdGhzIHRoYXQgdGhlIGVudGl0eSAocGFnZSBvciBjb21wb25lbnQpIGlzIGRlcGVuZGVudCBvbi5cbiAqL1xuZXhwb3J0IGNvbnN0IGdldERlcGVuZGVuY2llcyA9IChlbnRpdHkpID0+IHtcblxuICAgIGNvbnN0IGZpbmRTaG93V2hlbkZpZWxkcyA9IChzaG93V2hlbk9iamVjdCwgc2hvd1doZW5GaWVsZHMpID0+IHtcbiAgICAgICAgaWYgKHR5cGVvZiBzaG93V2hlbk9iamVjdCA9PT0gJ29iamVjdCcgJiYgc2hvd1doZW5PYmplY3QgIT09IG51bGwpIHtcbiAgICAgICAgICAgIGlmIChBcnJheS5pc0FycmF5KHNob3dXaGVuT2JqZWN0KSkge1xuICAgICAgICAgICAgICAgIHNob3dXaGVuT2JqZWN0LmZvckVhY2goKHZhbHVlKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGZpbmRTaG93V2hlbkZpZWxkcyh2YWx1ZSwgc2hvd1doZW5GaWVsZHMpO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICBPYmplY3Qua2V5cyhzaG93V2hlbk9iamVjdCkuZm9yRWFjaCgoa2V5KSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChrZXkgPT09ICdmaWVsZCcpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHNob3dXaGVuRmllbGRzLnB1c2goc2hvd1doZW5PYmplY3Rba2V5XSk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgZmluZFNob3dXaGVuRmllbGRzKHNob3dXaGVuT2JqZWN0W2tleV0sIHNob3dXaGVuRmllbGRzKTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gc2hvd1doZW5GaWVsZHM7XG4gICAgfTtcbiAgICByZXR1cm4gZW50aXR5LnNob3dfd2hlbiA/IG5ldyBTZXQoZmluZFNob3dXaGVuRmllbGRzKGVudGl0eS5zaG93X3doZW4sIFtdKSB8fCBbXSkgOiBudWxsO1xufTtcblxuLyoqXG4gKiBTb21lIHNob3dfd2hlbiBmaWVsZCB2YWx1ZXMgcG9pbnQgdG8gZGF0YSBpdGVtcyB0aGF0IGFyZSB3aXRoaW4gb2JqZWN0cyBwcm92aWRlZCBieSBcbiAqIGV4dGVybmFsIGNhbGxzIHRvIHJlZmRhdGEsIGVnIG1vZGVPZlRyYW5zcG9ydC5pZC4gVGhlc2Ugd29uJ3QgbWFwIGRpcmVjdGx5IHRvIHRoZSBwYXRoIFxuICoga2V5ZWQgY29tcG9uZW50cyBpbiB0aGUgYWxsQ29tcG9uZW50cyBtYXAsIHNvIGdvIGJhY2sgdXAgbGV2ZWxzIGluIHRoZSBwYXRoIHVudGlsIHdlIGZpbmQgXG4gKiB0aGUgY29tcG9uZW50IHRoYXQgY3JlYXRlcyB0aGlzIGZpZWxkLlxuICogXG4gKiBUaGlzIGNvbXBvbmVudCBtaWdodCBub3QgYmUgZm91bmQgYXQgYWxsLCBhcyB0aGUgZGVwZW5kZW5jeSBtaWdodCBiZSBvbiBhIGZpZWxkIHRoYXQgaXMgZWl0aGVyIFxuICogcHJvdmlkZWQgYnkgY29wLXVpIChlZyBqb2JIb2xkZXJTdGFmZkRldGFpbHMubGluZW1hbmFnZXJFbWFpbCksIG9yIGJ5IHRoZSBcImFkZFRvRm9ybURhdGFcIiBmdW5jdGlvbiBcbiAqIChlZyBlcG1zU3VibWl0dGVkKS4gVGhlc2Ugd2lsbCBiZSBsZWFmIGxldmVsIGluIHRoZSBkZXBlbmRlbmN5IGNoYWluIHNvIGNvbXBvbmVudCBpcyBub3QgcmVxdWlyZWQuXG4gKiBcbiAqIEBwYXJhbSB7U3RyaW5nfSBvcHRpb25QYXRoIERlY2ltYWwgcG9pbnQgZGVsaW1pdGVkIHBhdGhcbiAqIEBwYXJhbSB7U3RyaW5nfSBuZXN0ZWRGaWVsZElkIGZpZWxkSWQgKGRhdGFuYW1lKSBvZiB0aGUgbmVzdGVkIHF1ZXN0aW9uIHdpdGhpbiB0aGUgYWJvdmUgb3B0aW9uXG4gKiBAcmV0dXJucyB7U3RyaW5nfSBGdWxseSBxdWFsaWZpZWQgcGF0aCBvZiB0aGUgbmVzdGVkIHF1ZXN0aW9uXG4gKiBcbiAqL1xuZXhwb3J0IGNvbnN0IGdldERlcGVuZGVuY3lPYmplY3RGcm9tUGF0aCA9IChkZXBlbmRlbmN5UGF0aCwgYWxsQ29tcG9uZW50cykgPT4ge1xuICAgIGNvbnN0IHNlZ21lbnRzID0gZGVwZW5kZW5jeVBhdGguc3BsaXQoXCIuXCIpO1xuICAgIGZvciAobGV0IGkgPSBzZWdtZW50cy5sZW5ndGg7IGkgPiAwOyBpIC09IDEpIHtcbiAgICAgICAgY29uc3QgY3VycmVudFBhdGggPSBzZWdtZW50cy5zbGljZSgwLCBpKS5qb2luKFwiLlwiKTtcbiAgICAgICAgY29uc3QgZGVwZW5kZW5jeU9iamVjdCA9IGFsbENvbXBvbmVudHMuZ2V0KGN1cnJlbnRQYXRoKTtcbiAgICAgICAgaWYgKGRlcGVuZGVuY3lPYmplY3QpIHJldHVybiBkZXBlbmRlbmN5T2JqZWN0O1xuICAgIH1cbiAgICByZXR1cm4gbnVsbDtcbn07XG5cbi8qKlxuICogXG4gKiBFdmFsdWF0ZSB0aGUgc2hvd193aGVuIHJ1bGUgdG8gZXN0YWJsaXNoIGlmIHRoZSBjb21wb25lbnQgc2hvdWxkIGJlIHNob3duIChhbmQgdGhlIFxuICogcGF5bG9hZCBkYXRhIHNob3VsZCBub3QgYmUgcHJ1bmVkKS4gSWYgdGhlcmUgaXMgbm8gc2hvd193aGVuIHJ1bGUsIHRoZW4gcmV0dXJuIHRydWUuXG4gKiAgXG4gKiBAcGFyYW0geyp9IGVudGl0eSBBIHBhZ2Ugb3IgY29tcG9uZW50IHRoYXQgbWF5IGhhdmUgYSBzaG93X3doZW4gcnVsZSBhc3NvY2lhdGVkIHdpdGggaXRcbiAqIEBwYXJhbSB7Kn0gZGF0YSBUaGUgcGF5bG9hZCBkYXRhIHVzZWQgdG8gZXZhbHVhdGUgdGhlIHNob3dfd2hlbiBydWxlXG4gKiBAcmV0dXJucyB7Ym9vbGVhbn0gdHJ1ZSBpZiB0aGUgc2hvd193aGVuIHJ1bGUgZXZhbHVhdGUgdG8gdHJ1ZSwgb3IgdGhlcmUgaXMgbm8gc2hvd193aGVuIHJ1bGVcbiAqL1xuZXhwb3J0IGNvbnN0IGlzU2hvd0VudGl0eSA9IChlbnRpdHksIGRhdGEpID0+IHtcbiAgICAvLyBJZiB0aGVyZSBpcyBubyBydWxlIHNldCwgdGhlbiB0aGUgZW50aXR5IGNhbiBiZSBzaG93blxuICAgIGlmICghZW50aXR5LnNob3dfd2hlbikge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKGVudGl0eS5zaG93X3doZW4/LnR5cGUgPT09IFwib3JcIikge1xuICAgICAgICByZXR1cm4gQ29uZGl0aW9uLm1lZXRzT25lKGVudGl0eSwgZGF0YSlcbiAgICB9XG4gICAgcmV0dXJuIENvbmRpdGlvbi5tZWV0c0FsbChlbnRpdHksIGRhdGEpO1xufTtcblxuLyoqXG4gKiBcbiAqIENvbXBvbmVudHMgY2FuIGJlIGFzc2lnbmVkIHRvIHBhZ2VzIGluIDIgd2F5cyBpbiB0aGUgZm9ybSBzcGVjaWZpY2F0aW9uOlxuICogXG4gKiAxIC0gVGhleSBjYW4gYmUgaW5jbHVkZWQgaW4gdGhlIHBhZ2UncyBjb21wb25lbnRzIGFycmF5IHdpdGggdGhlICd1c2UnIGZpZWxkLCBlLmcuXG4gKiAge1xuICogICAgICBcInVzZVwiOiBcInBvcnRcIlxuICogIH1cbiAqIFRoaXMgXCJ1c2VcIiB2YWx1ZSB3aWxsIG5vcm1hbGx5IG1hdGNoIGEgY29tcG9uZW50J3MgaWQsIGJ1dCBjYW4gbWF0Y2ggaXRzIGZpZWxkSWRcbiAqIE5CLiBJbiB0aGlzIGNhc2UsIGEgc2hvd193aGVuIHJ1bGUgY2FuIGJlIGFwcGxpZWQgaGVyZSwgd2hpY2ggd2lsbCBzdXBlcmNlZGUgYW55IHNob3dfd2hlbiBpbiB0aGUgY29tcG9uZW50LiBlLmcuXG4gKiBcbiAqICB7XG4gKiAgICAgIFwidXNlXCI6IFwicG9ydFwiLFxuICogICAgICBcInNob3dfd2hlblwiOiAuLi4uXG4gKiAgfVxuICogXG4gKiAyIC0gVGhlIGVudGlyZSBjb21wb25lbnQgY2FuIGJlIGVtYmVkZGVkIGFzIGFuIGVudHJ5IGluIHRoZSBwYWdlJ3MgY29tcG9uZW50IGFycmF5LlxuICogICBcbiAqIFxuICogQHBhcmFtIHsqfSBjb21wb25lbnRJZCBUaGUgaWQgb2YgdGhlIGNvbXBvbmVudCB0byBmaW5kIGluIHRoZSBmb3JtLiBcbiAqIEBwYXJhbSB7Kn0gY29tcG9uZW50QnlJZE1hcCBBIG1hcCBvZiBhbGwgdGhlIGZvcm0ncyBjb21wb25lbnRzIGtleWVkIG9uIElkLCBmb3IgYmV0dGVyIHBlcmZvcm1hbmNlIHRoYW4gc2VhcmNoaW5nIHRoZSBmb3JtLiAgXG4gKiBAcGFyYW0geyp9IGNvbXBvbmVudEJ5RmllbGRJZE1hcCBBIG1hcCBvZiBhbGwgdGhlIGZvcm0ncyBjb21wb25lbnRzIGtleWVkIG9uIGZpZWxkSWQsIGZvciBiZXR0ZXIgcGVyZm9ybWFuY2UgdGhhbiBzZWFyY2hpbmcgdGhlIGZvcm0uICBcbiAqIEByZXR1cm5zIHtPYmplY3R9IEEgY2xvbmVkIGNvbXBvbmVudCBvYmplY3QsIGNvbnRhaW5pbmcgdGhlIGZ1bGwgZGVmaW5pdGlvbiBvZiB0aGF0IGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGNvbnN0IGZpbmRDb21wb25lbnREZWZpbml0aW9uSW5Gb3JtID0gKHBhZ2VDb21wb25lbnREZWYsIGNvbXBvbmVudEJ5SWRNYXAsIGNvbXBvbmVudEJ5RmllbGRJZE1hcCkgPT4ge1xuICAgIGNvbnN0IGNvbXBvbmVudEluRm9ybSA9XG4gICAgICAgIGNvbXBvbmVudEJ5SWRNYXAuZ2V0KHBhZ2VDb21wb25lbnREZWYudXNlKSA/P1xuICAgICAgICBjb21wb25lbnRCeUZpZWxkSWRNYXAuZ2V0KHBhZ2VDb21wb25lbnREZWYudXNlKSA/P1xuICAgICAgICBwYWdlQ29tcG9uZW50RGVmO1xuXG4gICAgLy8gQ3JlYXRlIGNsb25lIG9mIGNvbXBvbmVudCwgc28gcHJvY2Vzc2luZyBjYW4gbWFrZSBjaGFuZ2VzIHRvIGl0IHdpdGhvdXQgY2hhbmdpbmcgdGhlIGZvcm1cbiAgICBjb25zdCBjb21wb25lbnRJbkZvcm1DbG9uZSA9IEpTT04ucGFyc2UoSlNPTi5zdHJpbmdpZnkoY29tcG9uZW50SW5Gb3JtKSk7XG5cbiAgICBpZiAocGFnZUNvbXBvbmVudERlZi51c2UgJiYgcGFnZUNvbXBvbmVudERlZi5zaG93X3doZW4pIHtcbiAgICAgICAgY29tcG9uZW50SW5Gb3JtQ2xvbmUuc2hvd193aGVuID0gcGFnZUNvbXBvbmVudERlZi5zaG93X3doZW47XG4gICAgfVxuXG4gICAgcmV0dXJuIGNvbXBvbmVudEluRm9ybUNsb25lO1xufTtcblxuLyoqXG4gKiBcbiAqIFdoZW4gZG9jdW1lbnRzIGFyZSBhZGRlZCB0byB0aGUgcGF5bG9hZCBvZiB0eXBlIG11bHRpZmlsZSwgdGhleSBhcmUgYWxzbyBhZGRlZCB0byBhIHNlY3Rpb24gb2YgdGhlIHBheWxvYWRcbiAqICdtZXRhJywgc3BlY2lmaWNhbGx5IGFuIGFycmF5ICdkb2N1bWVudHMnLiBXaGVuIHdlIHJlbW92ZSB0aGUgbXVsdGlmaWxlIGVsZW1lbnRzLCB3ZSBuZWVkIHRvIHJlbW92ZVxuICogdGhlIGNvcnJlc3BvbmRpbmcgbWV0YS5kb2N1bWVudCBlbnRyaWVzLlxuICogXG4gKiBAcGFyYW0geyp9IGNvbXBvbmVudCBUaGUgY29tcG9uZW50IGRlZmluaXRpb24gYmVpbmcgZGVsZXRlZCB0aGF0IG5lZWRzIGNvcnJlc3BvbmRpbmcgbWV0YSBkYXRhIGFsc28gZGVsZXRlZFxuICogQHBhcmFtIHsqfSBjb2xsZWN0aW9uRGF0YU9iamVjdCBUaGUgcGF5bG9hZCBjb250YWluaW5nIHRoZSBmaWxlIGRhdGEgYmVpbmcgZGVsZXRlZCAoZm9yIHdoaWNoIHRoZSBjb3JyZXNwb25kaW5nIG1ldGEgbmVlZHMgZGVsZXRpbmcpXG4gKiBAcGFyYW0geyp9IGZvcm1EYXRhIFRoZSBlbnRpcmUgcGF5bG9hZCwgd2hpY2ggd2lsbCBpbmNsdWRlIHRoZSBtZXRhIHNlY3Rpb25cbiAqIEByZXR1cm5zIHt2b2lkfSwgYXMgdGhlIGZvcm1EYXRhIHdpbGwgYmUgdXBkYXRlZCBpbiBzaXR1XG4gKi9cbmV4cG9ydCBjb25zdCBkZWxldGVDb3JyZXNwb25kaW5nTWV0YUluZm8gPSAoY29tcG9uZW50LCBjb2xsZWN0aW9uRGF0YU9iamVjdCwgZm9ybURhdGEpID0+IHtcbiAgICBjb25zdCB7IG1ldGE6IHsgZG9jdW1lbnRzIH0gfSA9IGZvcm1EYXRhO1xuICAgIGNvbnN0IGZpbGVEYXRhQmVpbmdEZWxldGVkID0gY29sbGVjdGlvbkRhdGFPYmplY3RbY29tcG9uZW50LmZpZWxkSWRdO1xuICAgIGlmICghZG9jdW1lbnRzIHx8ICFmaWxlRGF0YUJlaW5nRGVsZXRlZCkgcmV0dXJuO1xuXG4gICAgY29uc3QgZmlsZURhdGFBc0FycmF5ID0gQXJyYXkuaXNBcnJheShmaWxlRGF0YUJlaW5nRGVsZXRlZCkgPyBmaWxlRGF0YUJlaW5nRGVsZXRlZCA6IFtmaWxlRGF0YUJlaW5nRGVsZXRlZF07XG4gICAgLy8gSXRlcmF0ZSBiYWNrd2FyZHMgdG8gYXZvaWQgaW5kZXggc2hpZnRpbmcgd2hlbiByZW1vdmluZyBlbGVtZW50c1xuICAgIGZvciAobGV0IGkgPSBmaWxlRGF0YUFzQXJyYXkubGVuZ3RoIC0gMTsgaSA+PSAwOyBpIC09IDEpIHtcbiAgICAgICAgY29uc3QgbWF0Y2hJbmRleCA9IGRvY3VtZW50cy5maW5kSW5kZXgobWV0YURvY3VtZW50ID0+IG1ldGFEb2N1bWVudC51cmwgPT09IGZpbGVEYXRhQXNBcnJheVtpXS51cmwpO1xuICAgICAgICBpZiAobWF0Y2hJbmRleCAhPT0gLTEpIHtcbiAgICAgICAgICAgIGRvY3VtZW50cy5zcGxpY2UobWF0Y2hJbmRleCwgMSk7XG4gICAgICAgIH1cbiAgICB9XG59O1xuXG4vKipcbiAqIEFmdGVyIHRoZSBwYXlsb2FkIGhhcyBiZWVuIGNsZWFuc2VkIG9mIGluZGl2aWR1YWwgZGF0YSBpdGVtcywgZW1wdHkgYXJyYXlzIGFuZCBvYmplY3RzIG1heSByZW1haW4uXG4gKiBSZW1vdmluZyBhbiBhcnJheSAod2hlbiB0aGUgcGF5bG9hZCBmb3IgYSBjb2xsZWN0aW9uKSBtYXkgbGVhdmUgYSByZWR1bmRhbnQgYWN0aXZlSWQgZmllbGQuIFRoZSBhY3RpdmUgSWQgXG4gKiBmaWVsZHMgYXJlIG5vdCBwYXJ0IG9mIHRoZSBwYXlsb2FkIGRhdGEsIGJ1dCBhZGRlZCBieSB0aGUgcmVhY3QgcmVuZGVyZXIgdG8gdHJhY2sgd2hpY2ggY29sbGVjdGlvbiBvYmplY3QgXG4gKiBpcyBjdXJyZW50bHkgYmVpbmcgd29ya2VkIG9uLCBzbyBjYW4gYmUgcmVtb3ZlZC5cbiAqIFxuICogVG8gdGlkeSB0aGlzIGFsbCB1cCwgcmVjdXJzaXZlbHkgZW1wdHkgYXJyYXlzIGFuZCB0aGVpciBhc3NvY2lhdGVkIFwiQWN0aXZlSWRcIiBmaWVsZHMgZnJvbSBhIG5lc3RlZCBwYXlsb2FkLlxuICpcbiAqIFRoaXMgZnVuY3Rpb24gdHJhdmVyc2VzIGEgZ2l2ZW4gcGF5bG9hZCwgd2hpY2ggY2FuIGJlIGFuIGFycmF5IG9yIGFuIG9iamVjdCwgYW5kIHBlcmZvcm1zIHRoZSBmb2xsb3dpbmcgb3BlcmF0aW9uczpcbiAqIDEuIElmIGFuIGVtcHR5IGFycmF5IGlzIGZvdW5kIGluc2lkZSBhbiBhcnJheSwgaXQgaXMgcmVtb3ZlZCB1c2luZyBgc3BsaWNlYC5cbiAqIDIuIElmIGFuIGVtcHR5IGFycmF5IGlzIGZvdW5kIGluc2lkZSBhbiBvYmplY3Q6XG4gKiAgICAtIEl0IGlzIHJlbW92ZWQgZnJvbSB0aGUgb2JqZWN0LlxuICogICAgLSBJZiB0aGVyZSBpcyBhIGNvcnJlc3BvbmRpbmcgYDxrZXk+QWN0aXZlSWRgIGZpZWxkLCB0aGF0IGZpZWxkIGlzIGFsc28gcmVtb3ZlZC5cbiAqIDMuIFRoZSBmdW5jdGlvbiBvcGVyYXRlcyByZWN1cnNpdmVseSB0byBoYW5kbGUgZGVlcGx5IG5lc3RlZCBzdHJ1Y3R1cmVzLlxuICpcbiAqIEBwYXJhbSB7YW55fSBwYXlsb2FkIC0gVGhlIGlucHV0IGRhdGEgc3RydWN0dXJlLCB3aGljaCBjYW4gYmUgYW4gYXJyYXkgb3IgYW4gb2JqZWN0LlxuICogXG4gKi9cbmV4cG9ydCBjb25zdCByZW1vdmVFbXB0eUFycmF5c0FuZFVudXNlZENvbGxlY3Rpb25JRHMgPSAocGF5bG9hZCkgPT4ge1xuICAgIGlmIChBcnJheS5pc0FycmF5KHBheWxvYWQpKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSBwYXlsb2FkLmxlbmd0aCAtIDE7IGkgPj0gMDsgaSAtPSAxKSB7XG4gICAgICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShwYXlsb2FkW2ldKSAmJiBwYXlsb2FkW2ldLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgICAgIHBheWxvYWQuc3BsaWNlKGksIDEpO1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZW1vdmVFbXB0eUFycmF5c0FuZFVudXNlZENvbGxlY3Rpb25JRHMocGF5bG9hZFtpXSk7IC8vIFJlY3Vyc2UgZm9yIG5lc3RlZCBzdHJ1Y3R1cmVzXG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAvLyBXaGVuIHVud2luZGluZyBvdXQgb2YgdGhlIHJlY3Vyc2lvbiwgd2UgbWF5IGhhdmUgZW1wdGllZCBhbiBvYmplY3Qgd2hpY2ggaXMgdGhlIHJlbWFpbmluZyBlbGVtZW50IG9mIGFuIFxuICAgICAgICAgICAgLy8gYXJyYXksIGluIHdoaWNoIGNhc2UgcmVtb3ZlIHRoZSBlbGVtZW50XG4gICAgICAgICAgICBpZiAodHlwZW9mIHBheWxvYWRbaV0gPT09ICdvYmplY3QnICYmIE9iamVjdC5rZXlzKHBheWxvYWRbaV0pLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgICAgIHBheWxvYWQuc3BsaWNlKGksIDEpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfSBlbHNlIGlmIChwYXlsb2FkICE9PSBudWxsICYmIHR5cGVvZiBwYXlsb2FkID09PSAnb2JqZWN0Jykge1xuICAgICAgICBPYmplY3Qua2V5cyhwYXlsb2FkKS5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgICAgICAgIGlmIChBcnJheS5pc0FycmF5KHBheWxvYWRba2V5XSkgJiYgcGF5bG9hZFtrZXldLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICAgICAgICAgIC8vIElmIHRoZSBhcnJheSBiZWluZyByZW1vdmVkIGhhcyBhbiBhY3RpdmVJZCBhc3NvY2lhdGVkIHdpdGggaXQsIHJlbW92ZSBpdFxuICAgICAgICAgICAgICAgIGlmIChwYXlsb2FkW2Ake2tleX1BY3RpdmVJZGBdKSB7XG4gICAgICAgICAgICAgICAgICAgIGRlbGV0ZSBwYXlsb2FkW2Ake2tleX1BY3RpdmVJZGBdO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBkZWxldGUgcGF5bG9hZFtgJHtrZXl9QWN0aXZlSWRgXTtcbiAgICAgICAgICAgICAgICBpZiAocGF5bG9hZFtrZXldKSB7XG4gICAgICAgICAgICAgICAgICAgIGRlbGV0ZSBwYXlsb2FkW2tleV07XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZW1vdmVFbXB0eUFycmF5c0FuZFVudXNlZENvbGxlY3Rpb25JRHMocGF5bG9hZFtrZXldKTsgLy8gUmVjdXJzZSBmb3IgbmVzdGVkIHN0cnVjdHVyZXNcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxufTtcblxuLyoqIFxuICogSGVscGVyIG1ldGhvZCB0byBnbyB0aHJvdWdoIGVhY2ggb3B0aW9uIGNhbGxpbmcgYSBwYXNzZWQgaW4gZnVuY3Rpb24gZm9yIGFueSBuZXN0ZWQgZmllbGRzLiBcbiAqIEBwYXJhbSB7T2JqZWN0fSBjb21wb25lbnQgVGhlIGZvcm0gY29tcG9uZW50IHJlcHJlc2VudGluZyB0aGUgcGF0aCBiZWluZyBkZWxldGVkXG4gKiBAcGFyYW0ge0Z1bmN0aW9ufSBhY3Rpb24gVGhlIGFjdGlvbiB0byBwZXJmb3JtIG9uIGVhY2ggbmVzdGVkIHF1ZXN0aW9uLiBWYXJpZXMgZm9yIGNvbGxlY3Rpb25zIGFuZCBub24tY29sbGVjdGlvbnNcbiAqIEByZXR1cm4ge3ZvaWR9LCBvYmogYWJvdmUgdXBkYXRlZC5cbiAqL1xuZXhwb3J0IGNvbnN0IGl0ZXJhdGVPcHRpb25zID0gKGNvbXBvbmVudCwgYWN0aW9uKSA9PiB7XG5cbiAgICBpZiAoY29tcG9uZW50Py5kYXRhPy5vcHRpb25zKSB7XG4gICAgICAgIGNvbXBvbmVudD8uZGF0YT8ub3B0aW9ucz8uZm9yRWFjaCgob3B0aW9uKSA9PiB7XG4gICAgICAgICAgICBvcHRpb24ubmVzdGVkPy5mb3JFYWNoKGFjdGlvbilcbiAgICAgICAgfSk7XG4gICAgfVxufTtcblxuLyoqXG4gKiBEZWxldGUgYSBjb21wb25lbnQncyBwYXlsb2FkIGl0ZW0gZnJvbSB0aGUgb3ZlcmFsbCBwYXlsb2FkLlxuICogQSBjb21wb25lbnQgY2FuIGJlIGRlZmluZWQgaW4gPjEgcGxhY2VzIGluIHRoZSBmb3JtIHNwZWMuIFRvIGNhdGVyIGZvciB0aGlzLCBcbiAqIGlmIHRoZSBjb21wb25lbnRzVG9LZWVwIGNvdW50ZXIgdGVsbHMgdXMgdGhhdCB0aGVyZSBpcyA+IDEgdXNlcyBvZiB0aGlzIGNvbXBvbmVudFxuICogc3RpbGwgdW5hY2NvdW50ZWQgZm9yIGluIHRoZSBmb3JtIHRoZW4gZG9uJ3QgZGVsZXRlLCBidXQgcmVkdWNlIHRoZSBjb3VudCBieSAxLlxuICogXG4gKiBXaGVuIHRoZSBjb3VudGVyIHJlYWNoZXMgMSB3ZSBrbm93IGFsbCBvdGhlciBvY2N1cmVuY2VzIG9mIHRoZSBjb21wb25lbnQgaGF2ZSBiZWVuIHJlc29sdmVkXG4gKiBzbyBpdCBpcyBzYWZlIHRvIGRlbGV0ZS5cbiAqIFxuICogXG4gKiBAcGFyYW0geyp9IHBheWxvYWQgVGhlIGZvcm0gcGF5bG9hZCBmcm9tIHdoaWNoIHRvIGRlbGV0ZSB0aGUgY29tcG9uZW50IGRhdGFcbiAqIEBwYXJhbSB7Kn0gcGF0aCBUaGUgcGF5bG9hZCBwYXRoIG9mIHRoZSBjb21wb25lbnRcbiAqIEBwYXJhbSB7Kn0gY29tcG9uZW50IFRoZSBjb21wb25lbnQgd2hvc2UgZGF0YSB3ZSBzaG91bGQgYXR0ZW1wdCB0byBkZWxldGVcbiAqIEBwYXJhbSB7Kn0gY29tcG9uZW50c1RvS2VlcCBBIGxpc3Qgb2YgYWxsIGNvbXBvbmVudHMgd2l0aCBhIGNvdW50IG9mIHRoZWlyIG51bWJlciBvZiB1c2VzIGluIHRoZSBmb3JtXG4gKi9cbmV4cG9ydCBjb25zdCBkZWxldGVDb21wb25lbnREYXRhID0gKHBheWxvYWQsIHBhdGgsIGNvbXBvbmVudCwgY29tcG9uZW50c1RvS2VlcCkgPT4ge1xuXG4gICAgaWYgKGNvbXBvbmVudHNUb0tlZXBbcGF0aF0gPiAxKSB7XG4gICAgICAgIGNvbXBvbmVudHNUb0tlZXBbcGF0aF0gLT0gMTtcbiAgICB9IGVsc2Uge1xuXG4gICAgICAgIGlmIChjb21wb25lbnQucHJlc2VydmVJblBheWxvYWQpIHJldHVybjtcblxuICAgICAgICBkZWxldGVOb2RlQnlQYXRoKHBheWxvYWQsIHBhdGgpO1xuIFxuICAgICAgICAvLyBJZiB0aGUgY29tcG9uZW50IGhhcyBvcHRpb25zLCBnbyB0aHJvdWdoIGVhY2ggb3B0aW9uIHJlbW92aW5nIHRoZSBkYXRhIGZvciBhbnkgbmVzdGVkIGZpZWxkcy4gUmVxdWlyZWQgYXMgbmVzdGVkIG9wdGlvbnMgYXJlIGluIHRoZSBwYXlsb2FkIGF0IHRoZSBzYW1lIGhlaXJhcmNoaWNhbCBsZXZlbC5cbiAgICAgICAgaXRlcmF0ZU9wdGlvbnMoY29tcG9uZW50LCBuZXN0ZWQgPT4ge1xuICAgICAgICAgICAgY29uc3QgbmVzdGVkUXVlc3Rpb25QYXRoID0gZ2V0TmVzdGVkUXVlc3Rpb25QYXRoKHBhdGgsIG5lc3RlZC5maWVsZElkKTtcbiAgICAgICAgICAgIGlmIChjb21wb25lbnRzVG9LZWVwW25lc3RlZFF1ZXN0aW9uUGF0aF0gPiAxKSB7XG4gICAgICAgICAgICAgICAgY29tcG9uZW50c1RvS2VlcFtuZXN0ZWRRdWVzdGlvblBhdGhdIC09IDE7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIGRlbGV0ZU5vZGVCeVBhdGgocGF5bG9hZCwgbmVzdGVkUXVlc3Rpb25QYXRoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgfVxufTtcblxuLyoqXG4gKiBcbiAqIFRha2VzIGEgc2luZ2xlIHBhZ2UgY29sbGVjdGlvbiBwYXlsb2FkIG9iamVjdCBhbmQgcmVtb3ZlcyB0aGUgcGF5bG9hZCBpdGVtcyBzcGVjaWZpZWQgaW4gdGhlIGNvbXBvbmVudHNUb1BydW5lIGxpc3RcbiAqIGFzIGxvbmcgYXMgdGhleSBkb24ndCBhcHBlYXIgaW4gdGhlIGNvbXBvbmVudHNUb0tlZXAgbGlzdC5cbiAqIFxuICogQWRkaXRpb25hbGx5LCBpZiB0aGUgY29tcG9uZW50IHR5cGUgaXMgbXVsdGlmaWxlLCByZW1vdmUgdGhlIGNvcnJlc3BvbmRpbmcgZGF0YSBlbnRyaWVzIHRoYXQgd2lsbCBoYXZlIGJlZW4gY3JlYXRlZCBcbiAqIGluIHRoZSBtZXRhIHNlY3Rpb24gb2YgdGhlIHBheWxvYWQgYnkgdGhlIGZvcm0gcmVuZGVyZXIuXG4gKiBcbiAqIEBwYXJhbSB7U2V0fSBwYXRoc1RvS2VlcCBwYXRocyB0aGF0IHdlIGNhbm5vdCBkZWxldGUgZnJvbSB0aGUgY29sbGVjdGlvbkRhdGFPYmplY3RcbiAqIEBwYXJhbSB7TWFwfSBjb21wb25lbnRzVG9QcnVuZSBwYXRocyB0aGF0IHdlIHNob3VsZCBkZWxldGUsIGFzIGxvbmcgYXMgdGhleSBhcmUgbm90IGluIHRoZSBwYXRoc1RvS2VlcFxuICogQHBhcmFtIHtPYmplY3R9IGNvbGxlY3Rpb25EYXRhT2JqZWN0IHRoZSBwYXlsb2FkIGZyb20gd2hpY2ggdG8gZGVsZXRlIHRoZSBwYXRoc1xuICogQHBhcmFtIHtPYmplY3R9IGZvcm1EYXRhIFRoZSBmb3JtIGRhdGEsIHdob3NlIG1ldGEgc2VjdGlvbiBtYXkgaW5jbHVkZSBjb3JyZXNwb25kaW5nIGRvY3VtZW50cyBlbnRyaWVzIGZvciBtdWx0aWZpbGUgZW50cmllc1xuICovXG5leHBvcnQgY29uc3QgcHJ1bmVDb2xsZWN0aW9uRW50cnkgPSAocGF0aHNUb0tlZXAsIGNvbXBvbmVudHNUb1BydW5lLCBjb2xsZWN0aW9uRGF0YU9iamVjdCwgZm9ybURhdGEpID0+IHtcblxuICAgIGNvbXBvbmVudHNUb1BydW5lLmZvckVhY2goY29tcG9uZW50ID0+IHtcbiAgICAgICAgaWYgKCFwYXRoc1RvS2VlcC5oYXMoY29tcG9uZW50LmZpZWxkSWQpKSB7XG4gICAgICAgICAgICBpZiAoY29tcG9uZW50LnR5cGUgPT09IFwibXVsdGlmaWxlXCIpIHtcbiAgICAgICAgICAgICAgICBkZWxldGVDb3JyZXNwb25kaW5nTWV0YUluZm8oY29tcG9uZW50LCBjb2xsZWN0aW9uRGF0YU9iamVjdCwgZm9ybURhdGEpO1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBpZiAoY29tcG9uZW50LnByZXNlcnZlSW5QYXlsb2FkKSByZXR1cm47XG5cbiAgICAgICAgICAgIGRlbGV0ZU5vZGVCeVBhdGgoY29sbGVjdGlvbkRhdGFPYmplY3QsIGNvbXBvbmVudC5maWVsZElkKTtcblxuICAgICAgICAgICAgLy8gSWYgdGhlIGNvbXBvbmVudCBoYXMgb3B0aW9ucywgZ28gdGhyb3VnaCBlYWNoIG9wdGlvbiByZW1vdmluZyB0aGUgZGF0YSBmb3IgYW55IG5lc3RlZCBmaWVsZHMuIFJlcXVpcmVkIGFzIG5lc3RlZCBvcHRpb25zIGFyZSBpbiB0aGUgcGF5bG9hZCBhdCB0aGUgc2FtZSBoZWlyYXJjaGljYWwgbGV2ZWwuXG4gICAgICAgICAgICBpdGVyYXRlT3B0aW9ucyhjb21wb25lbnQsIG5lc3RlZCA9PiB7XG4gICAgICAgICAgICAgICAgY29uc3QgbmVzdGVkUXVlc3Rpb25QYXRoID0gZ2V0TmVzdGVkUXVlc3Rpb25QYXRoKGNvbXBvbmVudC5maWVsZElkLCBuZXN0ZWQuZmllbGRJZCk7XG4gICAgICAgICAgICAgICAgaWYgKCFwYXRoc1RvS2VlcC5oYXMobmVzdGVkUXVlc3Rpb25QYXRoKSkge1xuICAgICAgICAgICAgICAgICAgICBkZWxldGVOb2RlQnlQYXRoKGNvbGxlY3Rpb25EYXRhT2JqZWN0LCBuZXN0ZWRRdWVzdGlvblBhdGgpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xufVxuICAgIH0pO1xufTtcblxuLypcbiAqIENvbnZlcnRzIGFuIG9iamVjdCB0byBhbiBhcnJheSBpZiBpdCBpc24ndCBhbHJlYWR5LCBmb3IgdXNlIHdoZW4gY29tYmluaW5nIHNob3cgd2hlbiBydWxlcy5cbiAqL1xuZXhwb3J0IGNvbnN0IHRvQXJyYXkgPSB2YWx1ZSA9PiBBcnJheS5pc0FycmF5KHZhbHVlKSA/IHZhbHVlIDogW3ZhbHVlXTsiXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFVBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUFpRCxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUVqRDs7QUFFQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ08sTUFBTUcsUUFBUSxHQUFHQSxDQUFDQyxHQUFHLEVBQUVDLEtBQUssRUFBRUMsUUFBUSxLQUFLO0VBQzlDLElBQUksQ0FBQ0EsUUFBUSxDQUFD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