@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.
- package/README.md +106 -32
- package/dist/components/CheckYourAnswers/Answer.d.ts +10 -0
- package/dist/components/CheckYourAnswers/CheckYourAnswers.d.ts +35 -0
- package/dist/components/CheckYourAnswers/index.d.ts +2 -0
- package/dist/components/CollectionPage/CollectionPage.d.ts +24 -0
- package/dist/components/CollectionPage/index.d.ts +1 -0
- package/dist/components/CollectionSummary/BannerStrip.d.ts +9 -0
- package/dist/components/CollectionSummary/CollectionSummary.d.ts +53 -0
- package/dist/components/CollectionSummary/Confirmation.d.ts +15 -0
- package/dist/components/CollectionSummary/RenderListView.d.ts +42 -0
- package/dist/components/CollectionSummary/SummaryCard.d.ts +62 -0
- package/dist/components/CollectionSummary/SummaryCardButtons.d.ts +21 -0
- package/dist/components/CollectionSummary/SummaryCardDetails.d.ts +14 -0
- package/dist/components/CollectionSummary/SummaryCardValidationContext.d.ts +9 -0
- package/dist/components/CollectionSummary/index.d.ts +2 -0
- package/dist/components/FormComponent/Collection.d.ts +39 -0
- package/dist/components/FormComponent/Container.d.ts +26 -0
- package/dist/components/FormComponent/FormComponent.d.ts +39 -0
- package/dist/components/FormComponent/helpers/addLabel.d.ts +7 -0
- package/dist/components/FormComponent/helpers/getComponentDisabled.d.ts +2 -0
- package/dist/components/FormComponent/helpers/getComponentError.d.ts +4 -0
- package/dist/components/FormComponent/helpers/getComponentFieldSet.d.ts +2 -0
- package/dist/components/FormComponent/helpers/index.d.ts +5 -0
- package/dist/components/FormComponent/index.d.ts +2 -0
- package/dist/components/FormPage/FormPage.d.ts +36 -0
- package/dist/components/FormPage/index.d.ts +2 -0
- package/dist/components/FormRenderer/FormRenderer.d.ts +39 -0
- package/dist/components/FormRenderer/handlers/cyaAction.d.ts +9 -0
- package/dist/components/FormRenderer/handlers/getPageId.d.ts +8 -0
- package/dist/components/FormRenderer/handlers/index.d.ts +6 -0
- package/dist/components/FormRenderer/handlers/navigate.d.ts +10 -0
- package/dist/components/FormRenderer/handlers/submissionError.d.ts +7 -0
- package/dist/components/FormRenderer/helpers/canActionProceed.d.ts +12 -0
- package/dist/components/FormRenderer/helpers/canCYASubmit.d.ts +10 -0
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.d.ts +51 -0
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.d.ts +179 -0
- package/dist/components/FormRenderer/helpers/getCYA.d.ts +20 -0
- package/dist/components/FormRenderer/helpers/getFormState.d.ts +25 -0
- package/dist/components/FormRenderer/helpers/getNextPageId.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getPage.d.ts +9 -0
- package/dist/components/FormRenderer/helpers/getRelevantPages.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.d.ts +10 -0
- package/dist/components/FormRenderer/helpers/index.d.ts +29 -0
- package/dist/components/FormRenderer/index.d.ts +2 -0
- package/dist/components/FormRenderer/onCYAAction.d.ts +6 -0
- package/dist/components/FormRenderer/onPageAction.d.ts +2 -0
- package/dist/components/FormRenderer/onTaskAction.d.ts +2 -0
- package/dist/components/PageActions/ActionButton.d.ts +7 -0
- package/dist/components/PageActions/PageActions.d.ts +7 -0
- package/dist/components/PageActions/index.d.ts +2 -0
- package/dist/components/SummaryList/GroupAction.d.ts +12 -0
- package/dist/components/SummaryList/RowAction.d.ts +12 -0
- package/dist/components/SummaryList/SummaryList.d.ts +28 -0
- package/dist/components/SummaryList/SummaryList.stories.d.ts +10 -0
- package/dist/components/SummaryList/SummaryListHeadingRow.d.ts +7 -0
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.d.ts +16 -0
- package/dist/components/SummaryList/SummaryListRow.d.ts +19 -0
- package/dist/components/SummaryList/SummaryListTitleRow.d.ts +7 -0
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.d.ts +17 -0
- package/dist/components/SummaryList/helpers/getRowActionAttributes.d.ts +17 -0
- package/dist/components/SummaryList/helpers/index.d.ts +2 -0
- package/dist/components/SummaryList/index.d.ts +2 -0
- package/dist/components/TaskList/Task.d.ts +12 -0
- package/dist/components/TaskList/TaskList.d.ts +40 -0
- package/dist/components/TaskList/TaskState.d.ts +6 -0
- package/dist/components/TaskList/index.d.ts +2 -0
- package/dist/components/index.d.ts +8 -0
- package/dist/context/HooksContext/HooksContext.d.ts +23 -0
- package/dist/context/HooksContext/index.d.ts +3 -0
- package/dist/context/ValidationContext/ValidationContext.d.ts +7 -0
- package/dist/context/ValidationContext/index.d.ts +3 -0
- package/dist/context/index.d.ts +3 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/useAxios.d.ts +2 -0
- package/dist/hooks/useGetRequest.d.ts +12 -0
- package/dist/hooks/useHooks.d.ts +2 -0
- package/dist/hooks/useRefData.d.ts +7 -0
- package/dist/hooks/useValidation.d.ts +2 -0
- package/dist/index.cjs +5 -0
- package/dist/index.css +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +6124 -81
- package/dist/models/CollectionLabels.d.ts +7 -0
- package/dist/models/ComponentTypes.d.ts +27 -0
- package/dist/models/EventTypes.d.ts +6 -0
- package/dist/models/FormPages.d.ts +6 -0
- package/dist/models/FormTypes.d.ts +10 -0
- package/dist/models/HubFormats.d.ts +5 -0
- package/dist/models/PageAction.d.ts +89 -0
- package/dist/models/TaskStates.d.ts +39 -0
- package/dist/models/index.d.ts +143 -0
- package/dist/setupTests.d.ts +14 -0
- package/dist/utils/CheckYourAnswers/getCYAAction.d.ts +20 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.d.ts +22 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.d.ts +22 -0
- package/dist/utils/CheckYourAnswers/getCYARow.d.ts +26 -0
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.d.ts +17 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.d.ts +2 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.d.ts +23 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.d.ts +2 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.d.ts +11 -0
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.d.ts +3 -0
- package/dist/utils/CheckYourAnswers/index.d.ts +5 -0
- package/dist/utils/CheckYourAnswers/showComponentCYA.d.ts +11 -0
- package/dist/utils/CollectionPage/addCollectionPageEntry.d.ts +12 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.d.ts +13 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.d.ts +13 -0
- package/dist/utils/CollectionPage/getCollectionPageActiveId.d.ts +14 -0
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.d.ts +15 -0
- package/dist/utils/CollectionPage/getCollectionPageData.d.ts +15 -0
- package/dist/utils/CollectionPage/getErrorsForCollection.d.ts +2 -0
- package/dist/utils/CollectionPage/getQuickEditPage.d.ts +40 -0
- package/dist/utils/CollectionPage/index.d.ts +13 -0
- package/dist/utils/CollectionPage/mergeCollectionPages.d.ts +13 -0
- package/dist/utils/CollectionPage/removeCollectionPageEntry.d.ts +11 -0
- package/dist/utils/CollectionPage/setCollectionPageData.d.ts +16 -0
- package/dist/utils/Component/addShowWhen.d.ts +13 -0
- package/dist/utils/Component/applyToComponentTree.d.ts +15 -0
- package/dist/utils/Component/cleanAttributes.d.ts +14 -0
- package/dist/utils/Component/elevateNestedComponents.d.ts +28 -0
- package/dist/utils/Component/getDefaultValue.d.ts +2 -0
- package/dist/utils/Component/getDefaultValueFromConfig.d.ts +2 -0
- package/dist/utils/Component/index.d.ts +12 -0
- package/dist/utils/Component/isEditable.d.ts +3 -0
- package/dist/utils/Component/optionIsSelected.d.ts +10 -0
- package/dist/utils/Component/setupContainerComponentsPath.d.ts +2 -0
- package/dist/utils/Component/showComponent.d.ts +2 -0
- package/dist/utils/Condition/index.d.ts +6 -0
- package/dist/utils/Condition/meetsAllConditions.d.ts +8 -0
- package/dist/utils/Condition/meetsCondition.d.ts +14 -0
- package/dist/utils/Condition/meetsOneCondition.d.ts +8 -0
- package/dist/utils/Condition/setupConditions.d.ts +2 -0
- package/dist/utils/Container/getEditableComponents.d.ts +7 -0
- package/dist/utils/Container/index.d.ts +6 -0
- package/dist/utils/Container/setupNesting.d.ts +2 -0
- package/dist/utils/Container/showContainer.d.ts +8 -0
- package/dist/utils/Data/applyFormula.d.ts +2 -0
- package/dist/utils/Data/deleteValues.d.ts +8 -0
- package/dist/utils/Data/getAutocompleteSource.d.ts +2 -0
- package/dist/utils/Data/getDataPath.d.ts +21 -0
- package/dist/utils/Data/getOptions.d.ts +2 -0
- package/dist/utils/Data/getSourceData.d.ts +17 -0
- package/dist/utils/Data/index.d.ts +15 -0
- package/dist/utils/Data/nestInRefdataOptions.d.ts +10 -0
- package/dist/utils/Data/refDataToOptions.d.ts +8 -0
- package/dist/utils/Data/setDataItem.d.ts +2 -0
- package/dist/utils/Data/setupFormData.d.ts +15 -0
- package/dist/utils/Data/setupRefDataUrlForComponent.d.ts +2 -0
- package/dist/utils/FormPage/applyConditionalProperties.d.ts +8 -0
- package/dist/utils/FormPage/getConditionalText.d.ts +23 -0
- package/dist/utils/FormPage/getFormPage.d.ts +9 -0
- package/dist/utils/FormPage/getFormPages.d.ts +9 -0
- package/dist/utils/FormPage/getPageActions.d.ts +13 -0
- package/dist/utils/FormPage/getParagraphFromText.d.ts +11 -0
- package/dist/utils/FormPage/index.d.ts +10 -0
- package/dist/utils/FormPage/showFormPage.d.ts +8 -0
- package/dist/utils/FormPage/showFormPageCYA.d.ts +8 -0
- package/dist/utils/FormPage/useComponent.d.ts +9 -0
- package/dist/utils/Format/formatData.d.ts +8 -0
- package/dist/utils/Format/formatDataForComponent.d.ts +15 -0
- package/dist/utils/Format/formatDataForForm.d.ts +8 -0
- package/dist/utils/Format/formatDataForPage.d.ts +15 -0
- package/dist/utils/Format/index.d.ts +7 -0
- package/dist/utils/Hub/getFormHub.d.ts +15 -0
- package/dist/utils/Hub/index.d.ts +4 -0
- package/dist/utils/Meta/constants.d.ts +2 -0
- package/dist/utils/Meta/documents/getDocuments.d.ts +2 -0
- package/dist/utils/Meta/documents/index.d.ts +6 -0
- package/dist/utils/Meta/documents/setDocumentsForField.d.ts +2 -0
- package/dist/utils/Meta/index.d.ts +9 -0
- package/dist/utils/Operate/checkValueIsTruthy.d.ts +9 -0
- package/dist/utils/Operate/deleteValueInFormData.d.ts +8 -0
- package/dist/utils/Operate/doesContainValue.d.ts +11 -0
- package/dist/utils/Operate/getFirstOf.d.ts +2 -0
- package/dist/utils/Operate/getIndexOfMatchingValueIn.d.ts +11 -0
- package/dist/utils/Operate/getLength.d.ts +11 -0
- package/dist/utils/Operate/index.d.ts +4 -0
- package/dist/utils/Operate/persistValueInFormData.d.ts +9 -0
- package/dist/utils/Operate/runPageOperations.d.ts +19 -0
- package/dist/utils/Operate/setValueInFormData.d.ts +2 -0
- package/dist/utils/Operate/shouldRun.d.ts +9 -0
- package/dist/utils/Validate/additional/conditionallyPermittedChange.d.ts +14 -0
- package/dist/utils/Validate/additional/conditionallyRequired.d.ts +11 -0
- package/dist/utils/Validate/additional/index.d.ts +2 -0
- package/dist/utils/Validate/additional/mustBeAfter.d.ts +14 -0
- package/dist/utils/Validate/additional/mustBeBefore.d.ts +14 -0
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.d.ts +15 -0
- package/dist/utils/Validate/additional/mustBeGreaterThan.d.ts +7 -0
- package/dist/utils/Validate/additional/mustBeInTheFuture.d.ts +8 -0
- package/dist/utils/Validate/additional/mustBeInThePast.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeLessThan.d.ts +7 -0
- package/dist/utils/Validate/additional/mustBeLongerThan.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeNumbersOnly.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeOneOf.d.ts +8 -0
- package/dist/utils/Validate/additional/mustBeShorterThan.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.d.ts +10 -0
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.d.ts +9 -0
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.d.ts +7 -0
- package/dist/utils/Validate/additional/mustNotContainSql.d.ts +2 -0
- package/dist/utils/Validate/additional/mustSelectOnlyOne.d.ts +8 -0
- package/dist/utils/Validate/additional/utils.d.ts +4 -0
- package/dist/utils/Validate/index.d.ts +42 -0
- package/dist/utils/Validate/validateCollection.d.ts +9 -0
- package/dist/utils/Validate/validateComponent.d.ts +16 -0
- package/dist/utils/Validate/validateContainer.d.ts +12 -0
- package/dist/utils/Validate/validateDate.d.ts +29 -0
- package/dist/utils/Validate/validateEmail.d.ts +13 -0
- package/dist/utils/Validate/validateMultifile.d.ts +3 -0
- package/dist/utils/Validate/validateOnPageLoad.d.ts +1 -0
- package/dist/utils/Validate/validatePage.d.ts +8 -0
- package/dist/utils/Validate/validateRegex.d.ts +13 -0
- package/dist/utils/Validate/validateRequired.d.ts +9 -0
- package/dist/utils/Validate/validateTextArea.d.ts +13 -0
- package/dist/utils/Validate/validateTime.d.ts +20 -0
- package/dist/utils/canOverrideFieldRequired.d.ts +9 -0
- package/dist/utils/index.d.ts +140 -0
- package/package.json +80 -167
- package/LICENCE.md +0 -21
- package/dist/components/CheckYourAnswers/Answer.js +0 -59
- package/dist/components/CheckYourAnswers/Answer.test.js +0 -142
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +0 -252
- package/dist/components/CheckYourAnswers/CheckYourAnswers.scss +0 -43
- package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +0 -409
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +0 -603
- package/dist/components/CheckYourAnswers/index.js +0 -10
- package/dist/components/CollectionPage/CollectionPage.js +0 -178
- package/dist/components/CollectionPage/CollectionPage.test.js +0 -507
- package/dist/components/CollectionPage/index.js +0 -10
- package/dist/components/CollectionSummary/BannerStrip.js +0 -65
- package/dist/components/CollectionSummary/BannerStrip.scss +0 -60
- package/dist/components/CollectionSummary/BannerStrip.test.js +0 -167
- package/dist/components/CollectionSummary/CollectionSummary.js +0 -362
- package/dist/components/CollectionSummary/CollectionSummary.scss +0 -26
- package/dist/components/CollectionSummary/CollectionSummary.test.js +0 -368
- package/dist/components/CollectionSummary/Confirmation.js +0 -65
- package/dist/components/CollectionSummary/Confirmation.scss +0 -26
- package/dist/components/CollectionSummary/Confirmation.test.js +0 -109
- package/dist/components/CollectionSummary/RenderListView.js +0 -162
- package/dist/components/CollectionSummary/RenderListView.scss +0 -295
- package/dist/components/CollectionSummary/RenderListView.test.js +0 -303
- package/dist/components/CollectionSummary/SummaryCard.js +0 -277
- package/dist/components/CollectionSummary/SummaryCard.scss +0 -114
- package/dist/components/CollectionSummary/SummaryCard.test.js +0 -1442
- package/dist/components/CollectionSummary/SummaryCardButtons.js +0 -76
- package/dist/components/CollectionSummary/SummaryCardButtons.test.js +0 -87
- package/dist/components/CollectionSummary/SummaryCardDetails.js +0 -206
- package/dist/components/CollectionSummary/SummaryCardDetails.scss +0 -216
- package/dist/components/CollectionSummary/SummaryCardDetails.test.js +0 -654
- package/dist/components/CollectionSummary/SummaryCardValidationContext.js +0 -79
- package/dist/components/CollectionSummary/SummaryCardValidationContext.test.js +0 -104
- package/dist/components/CollectionSummary/index.js +0 -10
- package/dist/components/FormComponent/Collection.js +0 -234
- package/dist/components/FormComponent/Collection.scss +0 -24
- package/dist/components/FormComponent/Collection.test.js +0 -934
- package/dist/components/FormComponent/Container.js +0 -130
- package/dist/components/FormComponent/Container.scss +0 -15
- package/dist/components/FormComponent/Container.test.js +0 -456
- package/dist/components/FormComponent/FormComponent.js +0 -238
- package/dist/components/FormComponent/FormComponent.stories.mdx +0 -186
- package/dist/components/FormComponent/FormComponent.test.js +0 -436
- package/dist/components/FormComponent/helpers/addLabel.js +0 -25
- package/dist/components/FormComponent/helpers/getComponentDisabled.js +0 -15
- package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +0 -27
- package/dist/components/FormComponent/helpers/getComponentError.js +0 -23
- package/dist/components/FormComponent/helpers/getComponentError.test.js +0 -51
- package/dist/components/FormComponent/helpers/getComponentFieldSet.js +0 -11
- package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +0 -30
- package/dist/components/FormComponent/helpers/index.js +0 -35
- package/dist/components/FormComponent/index.js +0 -10
- package/dist/components/FormPage/FormPage.js +0 -212
- package/dist/components/FormPage/FormPage.scss +0 -7
- package/dist/components/FormPage/FormPage.stories.mdx +0 -157
- package/dist/components/FormPage/FormPage.test.js +0 -454
- package/dist/components/FormPage/index.js +0 -10
- package/dist/components/FormRenderer/FormRenderer.js +0 -426
- package/dist/components/FormRenderer/FormRenderer.scss +0 -5
- package/dist/components/FormRenderer/FormRenderer.stories.mdx +0 -178
- package/dist/components/FormRenderer/FormRenderer.test.js +0 -799
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/cop-reassign-task-to-rcc.json +0 -446
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-containerised.json +0 -120
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested-block.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-refdata.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-target-component-nested.json +0 -99
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-show-whens-page-hidden.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-airpax.json +0 -26408
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-mandec.json +0 -9405
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component-dependent-on-external-data.json +0 -158
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component.json +0 -86
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-collection.json +0 -173
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-hidden-collection.json +0 -202
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-show-when-in-component-and-page.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions-visible-elsewhere.json +0 -118
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions.json +0 -112
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component.json +0 -58
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-containerised-component.json +0 -97
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-collection-component.json +0 -83
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-component.json +0 -55
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-entire-collection.json +0 -114
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component-leaf-hidden.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-options.json +0 -99
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-collection.json +0 -128
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-component-used-elsewhere.json +0 -109
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-same-component-reused.json +0 -62
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page.json +0 -96
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option-visible-elsewhere.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option.json +0 -112
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-component.json +0 -26003
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-radio-component.json +0 -201
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-same-component-reused-one-shown.json +0 -75
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-variance-breach.json +0 -4272
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-carrier.json +0 -407
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-change-what-happened-before.json +0 -300
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-remove-photos-before.json +0 -384
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-business-interests-before.json +0 -140
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-criminality-before.json +0 -186
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-unspent-convictions-before.json +0 -143
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-variance-breach-with-upload-files.json +0 -1264
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-containerised.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested-block.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-refdata.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-target-component-nested.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-show-whens-page-hidden.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component-dependent-on-external-data.json +0 -26
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-collection.json +0 -25
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-hidden-collection.json +0 -26
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-show-when-in-component-and-page.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions-visible-elsewhere.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-containerised-component.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-collection-component.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-component.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-entire-collection.json +0 -20
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component-leaf-hidden.json +0 -14
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component.json +0 -14
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-options.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-collection.json +0 -18
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-component-used-elsewhere.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-same-component-reused.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option-visible-elsewhere.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-component.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-radio-component.json +0 -45
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-same-component-reused-one-shown.json +0 -8
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/reassign-to-rcc.json +0 -72
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-change-what-happened-after.json +0 -280
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-remove-photos-after.json +0 -355
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-base-file.json +0 -80
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-business-interests-after.json +0 -122
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-criminality-after.json +0 -86
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-unspent-convictions-after.json +0 -127
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-containerised-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-block-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-refdata-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-target-component-nested-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-show-whens-page-hidden-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-dependent-on-external-data-removed.json +0 -23
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-collection-removed.json +0 -21
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-hidden-collection-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-show-when-in-component-and-page-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-visible-elsewhere-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-containerised-component-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-collection-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-entire-collection-removed.json +0 -3
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-leaf-hidden-removed.json +0 -13
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-options-removed.json +0 -8
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-collection-removed.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-component-used-elsewhere-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-same-component-reused-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-visible-elsewhere-removed.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-component.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-radio-component-removed.json +0 -45
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-same-component-reused-one-shown-removed.json +0 -7
- package/dist/components/FormRenderer/handlers/cyaAction.js +0 -23
- package/dist/components/FormRenderer/handlers/getPageId.js +0 -15
- package/dist/components/FormRenderer/handlers/getPageId.test.js +0 -35
- package/dist/components/FormRenderer/handlers/handlers.test.js +0 -81
- package/dist/components/FormRenderer/handlers/index.js +0 -17
- package/dist/components/FormRenderer/handlers/navigate.js +0 -25
- package/dist/components/FormRenderer/handlers/submissionError.js +0 -18
- package/dist/components/FormRenderer/helpers/canActionProceed.js +0 -27
- package/dist/components/FormRenderer/helpers/canActionProceed.test.js +0 -84
- package/dist/components/FormRenderer/helpers/canCYASubmit.js +0 -17
- package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +0 -75
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +0 -63
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +0 -191
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.js +0 -338
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.test.js +0 -434
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.js +0 -399
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.test.js +0 -559
- package/dist/components/FormRenderer/helpers/getCYA.js +0 -42
- package/dist/components/FormRenderer/helpers/getCYA.test.js +0 -46
- package/dist/components/FormRenderer/helpers/getFormState.js +0 -25
- package/dist/components/FormRenderer/helpers/getFormState.test.js +0 -60
- package/dist/components/FormRenderer/helpers/getNextPageId.js +0 -76
- package/dist/components/FormRenderer/helpers/getNextPageId.test.js +0 -292
- package/dist/components/FormRenderer/helpers/getPage.js +0 -27
- package/dist/components/FormRenderer/helpers/getPage.test.js +0 -45
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +0 -27
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +0 -70
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +0 -65
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +0 -309
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +0 -201
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +0 -473
- package/dist/components/FormRenderer/helpers/index.js +0 -33
- package/dist/components/FormRenderer/index.js +0 -10
- package/dist/components/FormRenderer/onCYAAction.js +0 -150
- package/dist/components/FormRenderer/onCYAAction.test.js +0 -741
- package/dist/components/FormRenderer/onPageAction.js +0 -227
- package/dist/components/FormRenderer/onPageAction.test.js +0 -960
- package/dist/components/FormRenderer/onTaskAction.js +0 -47
- package/dist/components/FormRenderer/onTaskAction.test.js +0 -247
- package/dist/components/PageActions/ActionButton.js +0 -48
- package/dist/components/PageActions/ActionButton.test.js +0 -73
- package/dist/components/PageActions/PageActions.js +0 -37
- package/dist/components/PageActions/PageActions.stories.mdx +0 -74
- package/dist/components/PageActions/PageActions.test.js +0 -106
- package/dist/components/PageActions/index.js +0 -10
- package/dist/components/SummaryList/GroupAction.js +0 -50
- package/dist/components/SummaryList/GroupAction.test.js +0 -86
- package/dist/components/SummaryList/RowAction.js +0 -48
- package/dist/components/SummaryList/RowAction.test.js +0 -86
- package/dist/components/SummaryList/SummaryList.js +0 -128
- package/dist/components/SummaryList/SummaryList.scss +0 -79
- package/dist/components/SummaryList/SummaryList.stories.mdx +0 -84
- package/dist/components/SummaryList/SummaryList.test.js +0 -504
- package/dist/components/SummaryList/SummaryListHeadingRow.js +0 -39
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.js +0 -65
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.scss +0 -38
- package/dist/components/SummaryList/SummaryListRow.js +0 -58
- package/dist/components/SummaryList/SummaryListTitleRow.js +0 -32
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +0 -29
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +0 -72
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +0 -29
- package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +0 -72
- package/dist/components/SummaryList/helpers/index.js +0 -14
- package/dist/components/SummaryList/index.js +0 -10
- package/dist/components/TaskList/Task.js +0 -62
- package/dist/components/TaskList/Task.test.js +0 -176
- package/dist/components/TaskList/TaskList.js +0 -175
- package/dist/components/TaskList/TaskList.scss +0 -123
- package/dist/components/TaskList/TaskList.stories.mdx +0 -164
- package/dist/components/TaskList/TaskList.test.js +0 -535
- package/dist/components/TaskList/TaskState.js +0 -37
- package/dist/components/TaskList/TaskState.test.js +0 -95
- package/dist/components/TaskList/index.js +0 -10
- package/dist/components/index.js +0 -56
- package/dist/context/HooksContext/HooksContext.js +0 -122
- package/dist/context/HooksContext/HooksContext.test.js +0 -45
- package/dist/context/HooksContext/index.js +0 -16
- package/dist/context/ValidationContext/ValidationContext.js +0 -98
- package/dist/context/ValidationContext/ValidationContext.test.js +0 -107
- package/dist/context/ValidationContext/index.js +0 -16
- package/dist/context/index.js +0 -21
- package/dist/hooks/index.js +0 -55
- package/dist/hooks/useAxios.js +0 -36
- package/dist/hooks/useGetRequest.js +0 -89
- package/dist/hooks/useHooks.js +0 -15
- package/dist/hooks/useRefData.js +0 -62
- package/dist/hooks/useValidation.js +0 -15
- package/dist/json/actions.json +0 -17
- package/dist/json/actionsNoSave.json +0 -17
- package/dist/json/addressDetails.json +0 -149
- package/dist/json/areYouACivilServant.json +0 -7
- package/dist/json/firstForm.json +0 -94
- package/dist/json/grade.json +0 -108
- package/dist/json/group.data.json +0 -21
- package/dist/json/group.json +0 -402
- package/dist/json/groupOfRow.json +0 -137
- package/dist/json/groupOfRowData.json +0 -15
- package/dist/json/port.json +0 -346
- package/dist/json/saveAndContinue.json +0 -98
- package/dist/json/sublocation.json +0 -859
- package/dist/json/taskList.json +0 -265
- package/dist/json/team.json +0 -17351
- package/dist/json/terminal.json +0 -81
- package/dist/json/userProfile.data.json +0 -21
- package/dist/json/userProfile.json +0 -276
- package/dist/models/CollectionLabels.js +0 -15
- package/dist/models/ComponentTypes.js +0 -58
- package/dist/models/EventTypes.js +0 -16
- package/dist/models/FormPages.js +0 -16
- package/dist/models/FormTypes.js +0 -24
- package/dist/models/HubFormats.js +0 -14
- package/dist/models/PageAction.js +0 -65
- package/dist/models/TaskStates.js +0 -46
- package/dist/models/index.js +0 -77
- package/dist/setupTests.js +0 -54
- package/dist/utils/CheckYourAnswers/getCYAAction.js +0 -44
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +0 -120
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +0 -57
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +0 -162
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +0 -66
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +0 -198
- package/dist/utils/CheckYourAnswers/getCYARow.js +0 -58
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +0 -373
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +0 -69
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +0 -70
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +0 -71
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +0 -285
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +0 -237
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +0 -844
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +0 -45
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +0 -535
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +0 -72
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +0 -343
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.js +0 -42
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.test.js +0 -56
- package/dist/utils/CheckYourAnswers/index.js +0 -15
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +0 -53
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +0 -149
- package/dist/utils/CollectionPage/addCollectionPageEntry.js +0 -23
- package/dist/utils/CollectionPage/addCollectionPageEntry.test.js +0 -17
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +0 -26
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +0 -70
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +0 -51
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +0 -125
- package/dist/utils/CollectionPage/getCollectionPageActiveId.js +0 -24
- package/dist/utils/CollectionPage/getCollectionPageActiveId.test.js +0 -26
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +0 -44
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +0 -88
- package/dist/utils/CollectionPage/getCollectionPageData.js +0 -53
- package/dist/utils/CollectionPage/getCollectionPageData.test.js +0 -103
- package/dist/utils/CollectionPage/getErrorsForCollection.js +0 -55
- package/dist/utils/CollectionPage/getErrorsForCollection.test.js +0 -154
- package/dist/utils/CollectionPage/getQuickEditPage.js +0 -122
- package/dist/utils/CollectionPage/getQuickEditPage.test.js +0 -143
- package/dist/utils/CollectionPage/index.js +0 -33
- package/dist/utils/CollectionPage/mergeCollectionPages.js +0 -128
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +0 -198
- package/dist/utils/CollectionPage/removeCollectionPageEntry.js +0 -36
- package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +0 -62
- package/dist/utils/CollectionPage/setCollectionPageData.js +0 -60
- package/dist/utils/CollectionPage/setCollectionPageData.test.js +0 -182
- package/dist/utils/Component/addShowWhen.js +0 -43
- package/dist/utils/Component/addShowWhen.test.js +0 -217
- package/dist/utils/Component/applyToComponentTree.js +0 -68
- package/dist/utils/Component/applyToComponentTree.test.js +0 -125
- package/dist/utils/Component/cleanAttributes.js +0 -42
- package/dist/utils/Component/cleanAttributes.test.js +0 -67
- package/dist/utils/Component/elevateNestedComponents.js +0 -58
- package/dist/utils/Component/elevateNestedComponents.test.js +0 -305
- package/dist/utils/Component/getComponent.js +0 -305
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +0 -73
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +0 -251
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +0 -156
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +0 -104
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +0 -56
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +0 -31
- package/dist/utils/Component/getComponentTests/getComponent.html.test.js +0 -42
- package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +0 -29
- package/dist/utils/Component/getComponentTests/getComponent.list.test.js +0 -47
- package/dist/utils/Component/getComponentTests/getComponent.multifile.test.js +0 -66
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +0 -211
- package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +0 -46
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +0 -221
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +0 -62
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +0 -104
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +0 -80
- package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +0 -14
- package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +0 -29
- package/dist/utils/Component/getDefaultValue.js +0 -22
- package/dist/utils/Component/getDefaultValue.test.js +0 -62
- package/dist/utils/Component/getDefaultValueFromConfig.js +0 -106
- package/dist/utils/Component/getDefaultValueFromConfig.test.js +0 -141
- package/dist/utils/Component/index.js +0 -29
- package/dist/utils/Component/isEditable.js +0 -13
- package/dist/utils/Component/isEditable.test.js +0 -42
- package/dist/utils/Component/optionIsSelected.js +0 -25
- package/dist/utils/Component/optionIsSelected.test.js +0 -69
- package/dist/utils/Component/setupContainerComponentsPath.js +0 -35
- package/dist/utils/Component/setupContainerComponentsPath.test.js +0 -79
- package/dist/utils/Component/showComponent.js +0 -25
- package/dist/utils/Component/showComponent.test.js +0 -157
- package/dist/utils/Component/wrapInFormGroup.js +0 -26
- package/dist/utils/Condition/index.js +0 -17
- package/dist/utils/Condition/meetsAllConditions.js +0 -44
- package/dist/utils/Condition/meetsAllConditions.test.js +0 -109
- package/dist/utils/Condition/meetsCondition.js +0 -165
- package/dist/utils/Condition/meetsCondition.test.js +0 -899
- package/dist/utils/Condition/meetsOneCondition.js +0 -32
- package/dist/utils/Condition/meetsOneCondition.test.js +0 -101
- package/dist/utils/Condition/setupConditions.js +0 -36
- package/dist/utils/Condition/setupConditions.test.js +0 -34
- package/dist/utils/Container/getEditableComponents.js +0 -29
- package/dist/utils/Container/getEditableComponents.test.js +0 -134
- package/dist/utils/Container/index.js +0 -17
- package/dist/utils/Container/setupNesting.js +0 -53
- package/dist/utils/Container/setupNesting.test.js +0 -143
- package/dist/utils/Container/showContainer.js +0 -52
- package/dist/utils/Container/showContainer.test.js +0 -179
- package/dist/utils/Data/applyFormula.js +0 -90
- package/dist/utils/Data/applyFormula.test.js +0 -264
- package/dist/utils/Data/deleteValues.js +0 -19
- package/dist/utils/Data/deleteValues.test.js +0 -58
- package/dist/utils/Data/getAutocompleteSource.js +0 -87
- package/dist/utils/Data/getAutocompleteSource.test.js +0 -335
- package/dist/utils/Data/getDataPath.js +0 -66
- package/dist/utils/Data/getDataPath.test.js +0 -49
- package/dist/utils/Data/getOptions.js +0 -86
- package/dist/utils/Data/getOptions.test.js +0 -279
- package/dist/utils/Data/getSourceData.js +0 -44
- package/dist/utils/Data/getSourceData.test.js +0 -158
- package/dist/utils/Data/index.js +0 -35
- package/dist/utils/Data/nestInRefdataOptions.js +0 -47
- package/dist/utils/Data/nestInRefdataOptions.test.js +0 -237
- package/dist/utils/Data/refDataToOptions.js +0 -44
- package/dist/utils/Data/refDataToOptions.test.js +0 -197
- package/dist/utils/Data/setDataItem.js +0 -26
- package/dist/utils/Data/setDataItem.test.js +0 -136
- package/dist/utils/Data/setupFormData.js +0 -49
- package/dist/utils/Data/setupFormData.test.js +0 -215
- package/dist/utils/Data/setupRefDataUrlForComponent.js +0 -44
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +0 -150
- package/dist/utils/FormPage/applyConditionalProperties.js +0 -34
- package/dist/utils/FormPage/applyConditionalProperties.test.js +0 -61
- package/dist/utils/FormPage/getConditionalText.js +0 -55
- package/dist/utils/FormPage/getConditionalText.test.js +0 -163
- package/dist/utils/FormPage/getFormPage.js +0 -54
- package/dist/utils/FormPage/getFormPage.test.js +0 -206
- package/dist/utils/FormPage/getFormPages.js +0 -30
- package/dist/utils/FormPage/getFormPages.test.js +0 -97
- package/dist/utils/FormPage/getPageActions.js +0 -58
- package/dist/utils/FormPage/getPageActions.test.js +0 -115
- package/dist/utils/FormPage/getParagraphFromText.js +0 -21
- package/dist/utils/FormPage/getParagraphFromText.test.js +0 -28
- package/dist/utils/FormPage/index.js +0 -24
- package/dist/utils/FormPage/showFormPage.js +0 -52
- package/dist/utils/FormPage/showFormPage.test.js +0 -181
- package/dist/utils/FormPage/showFormPageCYA.js +0 -23
- package/dist/utils/FormPage/showFormPageCYA.test.js +0 -29
- package/dist/utils/FormPage/useComponent.js +0 -83
- package/dist/utils/FormPage/useComponent.test.js +0 -216
- package/dist/utils/Format/formatData.js +0 -27
- package/dist/utils/Format/formatData.test.js +0 -46
- package/dist/utils/Format/formatDataForComponent.js +0 -35
- package/dist/utils/Format/formatDataForComponent.test.js +0 -114
- package/dist/utils/Format/formatDataForForm.js +0 -27
- package/dist/utils/Format/formatDataForForm.test.js +0 -79
- package/dist/utils/Format/formatDataForPage.js +0 -31
- package/dist/utils/Format/formatDataForPage.test.js +0 -94
- package/dist/utils/Format/index.js +0 -21
- package/dist/utils/Hub/getFormHub.js +0 -40
- package/dist/utils/Hub/getFormHub.test.js +0 -105
- package/dist/utils/Hub/index.js +0 -15
- package/dist/utils/Meta/constants.js +0 -9
- package/dist/utils/Meta/documents/getDocuments.js +0 -15
- package/dist/utils/Meta/documents/getDocuments.test.js +0 -46
- package/dist/utils/Meta/documents/index.js +0 -19
- package/dist/utils/Meta/documents/setDocumentsForField.js +0 -30
- package/dist/utils/Meta/documents/setDocumentsForField.test.js +0 -97
- package/dist/utils/Meta/index.js +0 -17
- package/dist/utils/Operate/checkValueIsTruthy.js +0 -29
- package/dist/utils/Operate/checkValueIsTruthy.test.js +0 -43
- package/dist/utils/Operate/deleteValueInFormData.js +0 -27
- package/dist/utils/Operate/deleteValueInFormData.test.js +0 -61
- package/dist/utils/Operate/doesContainValue.js +0 -35
- package/dist/utils/Operate/doesContainValue.test.js +0 -76
- package/dist/utils/Operate/getFirstOf.js +0 -31
- package/dist/utils/Operate/getFirstOf.test.js +0 -87
- package/dist/utils/Operate/getIndexOfMatchingValueIn.js +0 -68
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +0 -158
- package/dist/utils/Operate/getLength.js +0 -51
- package/dist/utils/Operate/getLength.test.js +0 -90
- package/dist/utils/Operate/index.js +0 -13
- package/dist/utils/Operate/persistValueInFormData.js +0 -40
- package/dist/utils/Operate/persistValueInFormData.test.js +0 -118
- package/dist/utils/Operate/runPageOperations.js +0 -75
- package/dist/utils/Operate/runPageOperations.test.js +0 -105
- package/dist/utils/Operate/setValueInFormData.js +0 -22
- package/dist/utils/Operate/setValueInFormData.test.js +0 -45
- package/dist/utils/Operate/shouldRun.js +0 -57
- package/dist/utils/Operate/shouldRun.test.js +0 -65
- package/dist/utils/Validate/additional/conditionallyPermittedChange.js +0 -26
- package/dist/utils/Validate/additional/conditionallyPermittedChange.test.js +0 -34
- package/dist/utils/Validate/additional/conditionallyRequired.js +0 -24
- package/dist/utils/Validate/additional/conditionallyRequired.test.js +0 -74
- package/dist/utils/Validate/additional/index.js +0 -74
- package/dist/utils/Validate/additional/index.test.js +0 -130
- package/dist/utils/Validate/additional/mustBeAfter.js +0 -34
- package/dist/utils/Validate/additional/mustBeAfter.test.js +0 -109
- package/dist/utils/Validate/additional/mustBeBefore.js +0 -34
- package/dist/utils/Validate/additional/mustBeBefore.test.js +0 -77
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +0 -57
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +0 -128
- package/dist/utils/Validate/additional/mustBeGreaterThan.js +0 -22
- package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +0 -57
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +0 -33
- package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +0 -32
- package/dist/utils/Validate/additional/mustBeInThePast.js +0 -36
- package/dist/utils/Validate/additional/mustBeInThePast.test.js +0 -32
- package/dist/utils/Validate/additional/mustBeLessThan.js +0 -22
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +0 -53
- package/dist/utils/Validate/additional/mustBeLongerThan.js +0 -23
- package/dist/utils/Validate/additional/mustBeLongerThan.test.js +0 -49
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +0 -24
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +0 -45
- package/dist/utils/Validate/additional/mustBeOneOf.js +0 -22
- package/dist/utils/Validate/additional/mustBeOneOf.test.js +0 -37
- package/dist/utils/Validate/additional/mustBeShorterThan.js +0 -23
- package/dist/utils/Validate/additional/mustBeShorterThan.test.js +0 -49
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.js +0 -40
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.test.js +0 -163
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +0 -26
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +0 -37
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +0 -19
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +0 -37
- package/dist/utils/Validate/additional/mustNotContainSql.js +0 -19
- package/dist/utils/Validate/additional/mustNotContainSql.test.js +0 -33
- package/dist/utils/Validate/additional/mustSelectOnlyOne.js +0 -29
- package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +0 -55
- package/dist/utils/Validate/additional/utils.js +0 -35
- package/dist/utils/Validate/index.js +0 -33
- package/dist/utils/Validate/validateCollection.js +0 -50
- package/dist/utils/Validate/validateCollection.test.js +0 -134
- package/dist/utils/Validate/validateComponent.js +0 -126
- package/dist/utils/Validate/validateComponent.test.js +0 -435
- package/dist/utils/Validate/validateContainer.js +0 -52
- package/dist/utils/Validate/validateContainer.test.js +0 -115
- package/dist/utils/Validate/validateDate.js +0 -112
- package/dist/utils/Validate/validateDate.test.js +0 -133
- package/dist/utils/Validate/validateEmail.js +0 -45
- package/dist/utils/Validate/validateEmail.test.js +0 -78
- package/dist/utils/Validate/validateMultifile.js +0 -29
- package/dist/utils/Validate/validateMultifile.test.js +0 -46
- package/dist/utils/Validate/validateOnPageLoad.js +0 -24
- package/dist/utils/Validate/validateOnPageLoad.test.js +0 -89
- package/dist/utils/Validate/validatePage.js +0 -56
- package/dist/utils/Validate/validatePage.test.js +0 -795
- package/dist/utils/Validate/validateRegex.js +0 -41
- package/dist/utils/Validate/validateRegex.test.js +0 -43
- package/dist/utils/Validate/validateRequired.js +0 -37
- package/dist/utils/Validate/validateRequired.test.js +0 -64
- package/dist/utils/Validate/validateTextArea.js +0 -36
- package/dist/utils/Validate/validateTextArea.test.js +0 -71
- package/dist/utils/Validate/validateTime.js +0 -76
- package/dist/utils/Validate/validateTime.test.js +0 -116
- package/dist/utils/canOverrideFieldRequired.js +0 -23
- package/dist/utils/index.js +0 -42
|
@@ -1,227 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _models = require("../../models");
|
|
8
|
-
var _utils = _interopRequireDefault(require("../../utils"));
|
|
9
|
-
var _setCollectionPageData = _interopRequireDefault(require("../../utils/CollectionPage/setCollectionPageData"));
|
|
10
|
-
var _handlers = _interopRequireDefault(require("./handlers"));
|
|
11
|
-
var _helpers = _interopRequireDefault(require("./helpers"));
|
|
12
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
13
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
14
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
15
|
-
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
16
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
17
|
-
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
18
|
-
// Handle actions from pages.
|
|
19
|
-
// (patch captures payload-ready field name and value,
|
|
20
|
-
// patchLabel captures non-ID values
|
|
21
|
-
// for display purposes after submission.)
|
|
22
|
-
const onPageAction = (action, patch, patchLabel, hooks, data, formState, validate, onPageChange, type, cleanseHiddenData, pages, components, pageId, setPagePoint, currentTask, setData, hubDetails, setSubmitted, addErrors, submitting, setSubmitting, existingErrors) => {
|
|
23
|
-
// Save a copy of data in case submit errors and we need to revert
|
|
24
|
-
const preSubmitData = _objectSpread({}, data);
|
|
25
|
-
const form = formState;
|
|
26
|
-
const update = hooks.onAction(form.page.formData, patch, data, action.customAction);
|
|
27
|
-
form.page.formData = update.formData;
|
|
28
|
-
let _patch = update.patch;
|
|
29
|
-
|
|
30
|
-
// Re-apply the patch to the page's formData.
|
|
31
|
-
// This should normally have no effect but will prevent issues
|
|
32
|
-
// with validation if formData happens to have been wiped.
|
|
33
|
-
form.page.formData = _objectSpread(_objectSpread({}, form.page.formData), _patch);
|
|
34
|
-
|
|
35
|
-
// Exposes form data to consuming application.
|
|
36
|
-
if (action.type === _models.PageAction.TYPES.CANCEL) {
|
|
37
|
-
hooks.onCancel(form.page.formData);
|
|
38
|
-
setSubmitting(false);
|
|
39
|
-
return;
|
|
40
|
-
}
|
|
41
|
-
;
|
|
42
|
-
|
|
43
|
-
// Check to see whether the action is able to proceed, which in
|
|
44
|
-
// in the case of a submission will validate the fields in the page.
|
|
45
|
-
if (_helpers.default.canActionProceed(action, form.page, validate.page, existingErrors) && (!submitting || action.ignoreSubmittingFlag)) {
|
|
46
|
-
_patch = _helpers.default.cleanHiddenNestedData(_patch, form.page);
|
|
47
|
-
setSubmitting(true);
|
|
48
|
-
if (action.addToFormData) {
|
|
49
|
-
const operations = Array.isArray(action.addToFormData) ? action.addToFormData : [action.addToFormData];
|
|
50
|
-
operations.forEach(op => {
|
|
51
|
-
if (op.isCollection) {
|
|
52
|
-
(0, _setCollectionPageData.default)(op.field, op.value, formState.page.formData);
|
|
53
|
-
} else {
|
|
54
|
-
_utils.default.Data.setDataItem(formState.page.formData, op.field, op.value);
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
form.page.formData[action.addToFormData.field] = action.addToFormData.value;
|
|
58
|
-
}
|
|
59
|
-
if (action.type === _models.PageAction.TYPES.NAVIGATE) {
|
|
60
|
-
_handlers.default.navigate(action, pageId, onPageChange);
|
|
61
|
-
setSubmitting(false);
|
|
62
|
-
} else {
|
|
63
|
-
let pageUpdate = next => onPageChange(_helpers.default.getNextPageId(type, pages, pageId, action, next));
|
|
64
|
-
let collectionName;
|
|
65
|
-
let addAnotherName;
|
|
66
|
-
if (action.collection) {
|
|
67
|
-
collectionName = action.collection;
|
|
68
|
-
const collectionNameCapitalised = collectionName.charAt(0).toUpperCase() + collectionName.slice(1);
|
|
69
|
-
addAnotherName = "addAnother".concat(collectionNameCapitalised).slice(0, -1);
|
|
70
|
-
}
|
|
71
|
-
let collectionArray;
|
|
72
|
-
let index;
|
|
73
|
-
if (collectionName) {
|
|
74
|
-
collectionArray = form.page.formData[collectionName];
|
|
75
|
-
if (collectionArray && collectionArray.length > 0 && form.page.formData["".concat(collectionName, "ActiveId")]) {
|
|
76
|
-
index = collectionArray.findIndex(obj => obj.id === form.page.formData["".concat(collectionName, "ActiveId")]);
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
/* eslint-disable no-case-declarations */
|
|
81
|
-
switch (action.type) {
|
|
82
|
-
case _models.PageAction.TYPES.SUBMIT:
|
|
83
|
-
setPagePoint('submit');
|
|
84
|
-
break;
|
|
85
|
-
case _models.PageAction.TYPES.SAVE_AND_NAVIGATE:
|
|
86
|
-
const state = _objectSpread({}, currentTask);
|
|
87
|
-
// If resetActiveId is true then point active ID to first entry in collection
|
|
88
|
-
if (collectionArray && collectionArray.length > 0 && action.resetActiveId) {
|
|
89
|
-
form.page.formData["".concat(collectionName, "ActiveId")] = collectionArray[0].id;
|
|
90
|
-
}
|
|
91
|
-
// If resetActiveId is false
|
|
92
|
-
if (collectionArray && collectionArray.length > 0 && !action.resetActiveId) {
|
|
93
|
-
// Set addAnother field to yes if not reached last entry in collection
|
|
94
|
-
if (index !== undefined && index + 1 < form.page.formData[collectionName].length) {
|
|
95
|
-
form.page.formData[addAnotherName] = 'Yes';
|
|
96
|
-
}
|
|
97
|
-
// Set addAnother field to no if reached last entry
|
|
98
|
-
if (index !== undefined && index + 1 === form.page.formData[collectionName].length && form.page.formData[addAnotherName]) {
|
|
99
|
-
form.page.formData[addAnotherName] = 'No';
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
pageUpdate = () => _handlers.default.navigate(action, pageId, onPageChange, state);
|
|
103
|
-
break;
|
|
104
|
-
case _models.PageAction.TYPES.COLLECTION_ADD:
|
|
105
|
-
// Only add entry if the index is undefined,
|
|
106
|
-
// the array is empty
|
|
107
|
-
// or the active ID is the last one in the collection,
|
|
108
|
-
// otherwise move to next entry.
|
|
109
|
-
if (index === undefined || collectionArray.length === 0 || index + 1 === form.page.formData[collectionName].length) {
|
|
110
|
-
_utils.default.CollectionPage.addEntry(action.collection, form.page.formData);
|
|
111
|
-
} else {
|
|
112
|
-
form.page.formData["".concat(action.collection, "ActiveId")] = collectionArray[index + 1].id;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
// We need to delete the collection entry fields from formData as it will be holding previous values.
|
|
116
|
-
if (form.page.formData["".concat(action.collection)] && form.page.formData["".concat(action.collection)].length > 0) {
|
|
117
|
-
const lastIndex = form.page.formData["".concat(action.collection)].length - 1;
|
|
118
|
-
const fieldsToDelete = Object.keys(form.page.formData["".concat(action.collection)][lastIndex]).filter(k => k in form.page.formData && k !== 'id');
|
|
119
|
-
fieldsToDelete.forEach(i => delete form.page.formData[i]);
|
|
120
|
-
}
|
|
121
|
-
pageUpdate = () => _handlers.default.navigate(action, pageId, onPageChange);
|
|
122
|
-
break;
|
|
123
|
-
case _models.PageAction.TYPES.COLLECTION_DUPLICATE:
|
|
124
|
-
if (_utils.default.CollectionPage.duplicateActiveEntry(action.collection, formState.page.formData)) {
|
|
125
|
-
pageUpdate = () => _handlers.default.navigate(action, pageId, onPageChange);
|
|
126
|
-
}
|
|
127
|
-
;
|
|
128
|
-
break;
|
|
129
|
-
case _models.PageAction.TYPES.COLLECTION_REMOVE:
|
|
130
|
-
const activeId = action.targetId || form.page.formData["".concat(action.collection.split('.').pop(), "ActiveId")];
|
|
131
|
-
const removedEntry = _utils.default.CollectionPage.removeEntry(action.collection, formState.page.formData, activeId);
|
|
132
|
-
if (action.recordRemoval) {
|
|
133
|
-
form.page.formData["".concat(action.collection.split('.').pop(), "LastRemoved")] = _objectSpread({}, removedEntry);
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
// The formData needs to be tidied up after removing the collection entry:
|
|
137
|
-
|
|
138
|
-
// 1. Retrieve the formData ID as it will be overwritten by a field with the same name in the collection entry.
|
|
139
|
-
const formDataId = form.page.formData.id;
|
|
140
|
-
|
|
141
|
-
// 2. Build the list of field names to delete and delete them from formData.
|
|
142
|
-
if (removedEntry !== null) {
|
|
143
|
-
const removedEntryFieldsToDelete = Object.keys(removedEntry).filter(k => k in form.page.formData);
|
|
144
|
-
removedEntryFieldsToDelete.forEach(i => delete form.page.formData[i]);
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
// 3. Assign the fields in the last collection entry to formData.
|
|
148
|
-
Object.assign(form.page.formData, collectionArray[collectionArray.length - 1]);
|
|
149
|
-
|
|
150
|
-
// 4. Assign the formData ID back to the formData.
|
|
151
|
-
form.page.formData.id = formDataId;
|
|
152
|
-
|
|
153
|
-
// 5. If the collection array has entries set the correct ActiveId
|
|
154
|
-
// otherwise delete it as well as the collection array.
|
|
155
|
-
if (collectionArray.length > 0) {
|
|
156
|
-
form.page.formData["".concat(action.collection, "ActiveId")] = collectionArray[collectionArray.length - 1].id;
|
|
157
|
-
} else {
|
|
158
|
-
delete form.page.formData["".concat(action.collection, "ActiveId")];
|
|
159
|
-
delete form.page.formData[action.collection];
|
|
160
|
-
}
|
|
161
|
-
pageUpdate = () => _handlers.default.navigate(action, pageId, onPageChange);
|
|
162
|
-
break;
|
|
163
|
-
default:
|
|
164
|
-
break;
|
|
165
|
-
}
|
|
166
|
-
;
|
|
167
|
-
|
|
168
|
-
// If a value has been deleted from formData,
|
|
169
|
-
// also delete it from data before doing object spread,
|
|
170
|
-
// or else it will reappear in submissionData.
|
|
171
|
-
_utils.default.Data.deleteValues(data, formState.page.formData);
|
|
172
|
-
|
|
173
|
-
// Save draft or submit.
|
|
174
|
-
const submissionData = _utils.default.Format.form({
|
|
175
|
-
pages,
|
|
176
|
-
components
|
|
177
|
-
}, _objectSpread(_objectSpread(_objectSpread({}, data), patch), formState.page.formData), _models.EventTypes.SUBMIT);
|
|
178
|
-
submissionData.formStatus = _helpers.default.getSubmissionStatus(type, pages, pageId, action, submissionData, currentTask, true, hubDetails === null || hubDetails === void 0 ? void 0 : hubDetails.sections);
|
|
179
|
-
if (_patch) {
|
|
180
|
-
setData(submissionData);
|
|
181
|
-
}
|
|
182
|
-
;
|
|
183
|
-
const formPagesAndComponents = {
|
|
184
|
-
pages,
|
|
185
|
-
components
|
|
186
|
-
};
|
|
187
|
-
if (action.type === _models.PageAction.TYPES.SUBMIT) {
|
|
188
|
-
_helpers.default.clearOutUncompletedRoutes(cleanseHiddenData, formPagesAndComponents, submissionData);
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
// In case of hub-and-spoke if patchLabel has changed then
|
|
192
|
-
// save name and value to variables for call to onSubmit hook
|
|
193
|
-
let changedFieldName;
|
|
194
|
-
let changedFieldValue;
|
|
195
|
-
if (type === _models.FormTypes.HUB && Object.keys(patchLabel).length > 0) {
|
|
196
|
-
/* eslint-disable prefer-destructuring */
|
|
197
|
-
changedFieldName = Object.keys(patchLabel)[0];
|
|
198
|
-
changedFieldValue = Object.values(patchLabel)[0];
|
|
199
|
-
/* eslint-enable prefer-destructuring */
|
|
200
|
-
}
|
|
201
|
-
;
|
|
202
|
-
|
|
203
|
-
// Now submit the data to the backend...
|
|
204
|
-
hooks.onSubmit(action.type, submissionData, response => {
|
|
205
|
-
// The backend response may well contain data we need so apply it...
|
|
206
|
-
// ... but this needs to happen in a useEffect, not right away.
|
|
207
|
-
const sData = _objectSpread(_objectSpread({}, submissionData), response);
|
|
208
|
-
setSubmitted({
|
|
209
|
-
data: sData
|
|
210
|
-
});
|
|
211
|
-
pageUpdate(sData);
|
|
212
|
-
setSubmitting(false);
|
|
213
|
-
}, function (errors) {
|
|
214
|
-
let wipeData = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
|
|
215
|
-
_handlers.default.submissionError(errors, addErrors);
|
|
216
|
-
if (wipeData) {
|
|
217
|
-
setData(_objectSpread({}, preSubmitData));
|
|
218
|
-
}
|
|
219
|
-
setSubmitting(false);
|
|
220
|
-
}, changedFieldName, changedFieldValue, pageId);
|
|
221
|
-
}
|
|
222
|
-
;
|
|
223
|
-
}
|
|
224
|
-
;
|
|
225
|
-
};
|
|
226
|
-
var _default = exports.default = onPageAction;
|
|
227
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbW9kZWxzIiwicmVxdWlyZSIsIl91dGlscyIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJfc2V0Q29sbGVjdGlvblBhZ2VEYXRhIiwiX2hhbmRsZXJzIiwiX2hlbHBlcnMiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJvd25LZXlzIiwiciIsInQiLCJPYmplY3QiLCJrZXlzIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwibyIsImZpbHRlciIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImVudW1lcmFibGUiLCJwdXNoIiwiYXBwbHkiLCJfb2JqZWN0U3ByZWFkIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwiZm9yRWFjaCIsIl9kZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvcnMiLCJkZWZpbmVQcm9wZXJ0aWVzIiwiZGVmaW5lUHJvcGVydHkiLCJfdG9Qcm9wZXJ0eUtleSIsInZhbHVlIiwiY29uZmlndXJhYmxlIiwid3JpdGFibGUiLCJpIiwiX3RvUHJpbWl0aXZlIiwiU3ltYm9sIiwidG9QcmltaXRpdmUiLCJjYWxsIiwiVHlwZUVycm9yIiwiU3RyaW5nIiwiTnVtYmVyIiwib25QYWdlQWN0aW9uIiwiYWN0aW9uIiwicGF0Y2giLCJwYXRjaExhYmVsIiwiaG9va3MiLCJkYXRhIiwiZm9ybVN0YXRlIiwidmFsaWRhdGUiLCJvblBhZ2VDaGFuZ2UiLCJ0eXBlIiwiY2xlYW5zZUhpZGRlbkRhdGEiLCJwYWdlcyIsImNvbXBvbmVudHMiLCJwYWdlSWQiLCJzZXRQYWdlUG9pbnQiLCJjdXJyZW50VGFzayIsInNldERhdGEiLCJodWJEZXRhaWxzIiwic2V0U3VibWl0dGVkIiwiYWRkRXJyb3JzIiwic3VibWl0dGluZyIsInNldFN1Ym1pdHRpbmciLCJleGlzdGluZ0Vycm9ycyIsInByZVN1Ym1pdERhdGEiLCJmb3JtIiwidXBkYXRlIiwib25BY3Rpb24iLCJwYWdlIiwiZm9ybURhdGEiLCJjdXN0b21BY3Rpb24iLCJfcGF0Y2giLCJQYWdlQWN0aW9uIiwiVFlQRVMiLCJDQU5DRUwiLCJvbkNhbmNlbCIsImhlbHBlcnMiLCJjYW5BY3Rpb25Qcm9jZWVkIiwiaWdub3JlU3VibWl0dGluZ0ZsYWciLCJjbGVhbkhpZGRlbk5lc3RlZERhdGEiLCJhZGRUb0Zvcm1EYXRhIiwib3BlcmF0aW9ucyIsIkFycmF5IiwiaXNBcnJheSIsIm9wIiwiaXNDb2xsZWN0aW9uIiwic2V0Q29sbGVjdGlvblBhZ2VEYXRhIiwiZmllbGQiLCJVdGlscyIsIkRhdGEiLCJzZXREYXRhSXRlbSIsIk5BVklHQVRFIiwiaGFuZGxlcnMiLCJuYXZpZ2F0ZSIsInBhZ2VVcGRhdGUiLCJuZXh0IiwiZ2V0TmV4dFBhZ2VJZCIsImNvbGxlY3Rpb25OYW1lIiwiYWRkQW5vdGhlck5hbWUiLCJjb2xsZWN0aW9uIiwiY29sbGVjdGlvbk5hbWVDYXBpdGFsaXNlZCIsImNoYXJBdCIsInRvVXBwZXJDYXNlIiwic2xpY2UiLCJjb25jYXQiLCJjb2xsZWN0aW9uQXJyYXkiLCJpbmRleCIsImZpbmRJbmRleCIsIm9iaiIsImlkIiwiU1VCTUlUIiwiU0FWRV9BTkRfTkFWSUdBVEUiLCJzdGF0ZSIsInJlc2V0QWN0aXZlSWQiLCJ1bmRlZmluZWQiLCJDT0xMRUNUSU9OX0FERCIsIkNvbGxlY3Rpb25QYWdlIiwiYWRkRW50cnkiLCJsYXN0SW5kZXgiLCJmaWVsZHNUb0RlbGV0ZSIsImsiLCJDT0xMRUNUSU9OX0RVUExJQ0FURSIsImR1cGxpY2F0ZUFjdGl2ZUVudHJ5IiwiQ09MTEVDVElPTl9SRU1PVkUiLCJhY3RpdmVJZCIsInRhcmdldElkIiwic3BsaXQiLCJwb3AiLCJyZW1vdmVkRW50cnkiLCJyZW1vdmVFbnRyeSIsInJlY29yZFJlbW92YWwiLCJmb3JtRGF0YUlkIiwicmVtb3ZlZEVudHJ5RmllbGRzVG9EZWxldGUiLCJhc3NpZ24iLCJkZWxldGVWYWx1ZXMiLCJzdWJtaXNzaW9uRGF0YSIsIkZvcm1hdCIsIkV2ZW50VHlwZXMiLCJmb3JtU3RhdHVzIiwiZ2V0U3VibWlzc2lvblN0YXR1cyIsInNlY3Rpb25zIiwiZm9ybVBhZ2VzQW5kQ29tcG9uZW50cyIsImNsZWFyT3V0VW5jb21wbGV0ZWRSb3V0ZXMiLCJjaGFuZ2VkRmllbGROYW1lIiwiY2hhbmdlZEZpZWxkVmFsdWUiLCJGb3JtVHlwZXMiLCJIVUIiLCJ2YWx1ZXMiLCJvblN1Ym1pdCIsInJlc3BvbnNlIiwic0RhdGEiLCJlcnJvcnMiLCJ3aXBlRGF0YSIsInN1Ym1pc3Npb25FcnJvciIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0Zvcm1SZW5kZXJlci9vblBhZ2VBY3Rpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnRUeXBlcywgRm9ybVR5cGVzLCBQYWdlQWN0aW9uIH0gZnJvbSBcIi4uLy4uL21vZGVsc1wiO1xuaW1wb3J0IFV0aWxzIGZyb20gXCIuLi8uLi91dGlsc1wiO1xuaW1wb3J0IHNldENvbGxlY3Rpb25QYWdlRGF0YSBmcm9tIFwiLi4vLi4vdXRpbHMvQ29sbGVjdGlvblBhZ2Uvc2V0Q29sbGVjdGlvblBhZ2VEYXRhXCI7XG5pbXBvcnQgaGFuZGxlcnMgZnJvbSBcIi4vaGFuZGxlcnNcIjtcbmltcG9ydCBoZWxwZXJzIGZyb20gXCIuL2hlbHBlcnNcIjtcblxuLy8gSGFuZGxlIGFjdGlvbnMgZnJvbSBwYWdlcy5cbi8vIChwYXRjaCBjYXB0dXJlcyBwYXlsb2FkLXJlYWR5IGZpZWxkIG5hbWUgYW5kIHZhbHVlLCBcbi8vIHBhdGNoTGFiZWwgY2FwdHVyZXMgbm9uLUlEIHZhbHVlcyBcbi8vIGZvciBkaXNwbGF5IHB1cnBvc2VzIGFmdGVyIHN1Ym1pc3Npb24uKVxuY29uc3Qgb25QYWdlQWN0aW9uID0gKFxuICBhY3Rpb24sXG4gIHBhdGNoLFxuICBwYXRjaExhYmVsLFxuICBob29rcyxcbiAgZGF0YSxcbiAgZm9ybVN0YXRlLFxuICB2YWxpZGF0ZSxcbiAgb25QYWdlQ2hhbmdlLFxuICB0eXBlLFxuICBjbGVhbnNlSGlkZGVuRGF0YSxcbiAgcGFnZXMsXG4gIGNvbXBvbmVudHMsXG4gIHBhZ2VJZCxcbiAgc2V0UGFnZVBvaW50LFxuICBjdXJyZW50VGFzayxcbiAgc2V0RGF0YSxcbiAgaHViRGV0YWlscyxcbiAgc2V0U3VibWl0dGVkLFxuICBhZGRFcnJvcnMsXG4gIHN1Ym1pdHRpbmcsXG4gIHNldFN1Ym1pdHRpbmcsXG4gIGV4aXN0aW5nRXJyb3JzXG4pID0+IHtcbiAgLy8gU2F2ZSBhIGNvcHkgb2YgZGF0YSBpbiBjYXNlIHN1Ym1pdCBlcnJvcnMgYW5kIHdlIG5lZWQgdG8gcmV2ZXJ0XG4gIGNvbnN0IHByZVN1Ym1pdERhdGEgPSB7IC4uLmRhdGEgfTtcblxuICBjb25zdCBmb3JtID0gZm9ybVN0YXRlO1xuICBjb25zdCB1cGRhdGUgPSBob29rcy5vbkFjdGlvbihmb3JtLnBhZ2UuZm9ybURhdGEsIHBhdGNoLCBkYXRhLCBhY3Rpb24uY3VzdG9tQWN0aW9uKTtcbiAgZm9ybS5wYWdlLmZvcm1EYXRhID0gdXBkYXRlLmZvcm1EYXRhO1xuICBsZXQgX3BhdGNoID0gdXBkYXRlLnBhdGNoO1xuXG4gIC8vIFJlLWFwcGx5IHRoZSBwYXRjaCB0byB0aGUgcGFnZSdzIGZvcm1EYXRhLlxuICAvLyBUaGlzIHNob3VsZCBub3JtYWxseSBoYXZlIG5vIGVmZmVjdCBidXQgd2lsbCBwcmV2ZW50IGlzc3VlcyBcbiAgLy8gd2l0aCB2YWxpZGF0aW9uIGlmIGZvcm1EYXRhIGhhcHBlbnMgdG8gaGF2ZSBiZWVuIHdpcGVkLlxuICBmb3JtLnBhZ2UuZm9ybURhdGEgPSB7IC4uLmZvcm0ucGFnZS5mb3JtRGF0YSwgLi4uX3BhdGNoIH07XG5cbiAgLy8gRXhwb3NlcyBmb3JtIGRhdGEgdG8gY29uc3VtaW5nIGFwcGxpY2F0aW9uLlxuICBpZiAoYWN0aW9uLnR5cGUgPT09IFBhZ2VBY3Rpb24uVFlQRVMuQ0FOQ0VMKSB7XG4gICAgaG9va3Mub25DYW5jZWwoZm9ybS5wYWdlLmZvcm1EYXRhKTtcbiAgICBzZXRTdWJtaXR0aW5nKGZhbHNlKTtcbiAgICByZXR1cm47XG4gIH07XG5cbiAgLy8gQ2hlY2sgdG8gc2VlIHdoZXRoZXIgdGhlIGFjdGlvbiBpcyBhYmxlIHRvIHByb2NlZWQsIHdoaWNoIGluXG4gIC8vIGluIHRoZSBjYXNlIG9mIGEgc3VibWlzc2lvbiB3aWxsIHZhbGlkYXRlIHRoZSBmaWVsZHMgaW4gdGhlIHBhZ2UuXG4gIGlmIChoZWxwZXJzLmNhbkFjdGlvblByb2NlZWQoYWN0aW9uLCBmb3JtLnBhZ2UsIHZhbGlkYXRlLnBhZ2UsIGV4aXN0aW5nRXJyb3JzKSAmJiAoIXN1Ym1pdHRpbmcgfHwgYWN0aW9uLmlnbm9yZVN1Ym1pdHRpbmdGbGFnKSkge1xuICAgIF9wYXRjaCA9IGhlbHBlcnMuY2xlYW5IaWRkZW5OZXN0ZWREYXRhKF9wYXRjaCwgZm9ybS5wYWdlKTtcbiAgICBzZXRTdWJtaXR0aW5nKHRydWUpO1xuICAgIGlmIChhY3Rpb24uYWRkVG9Gb3JtRGF0YSkge1xuICAgICAgY29uc3Qgb3BlcmF0aW9ucyA9IEFycmF5LmlzQXJyYXkoYWN0aW9uLmFkZFRvRm9ybURhdGEpID8gYWN0aW9uLmFkZFRvRm9ybURhdGEgOiBbYWN0aW9uLmFkZFRvRm9ybURhdGFdO1xuICAgICAgb3BlcmF0aW9ucy5mb3JFYWNoKG9wID0+IHtcbiAgICAgICAgaWYgKG9wLmlzQ29sbGVjdGlvbikge1xuICAgICAgICAgIHNldENvbGxlY3Rpb25QYWdlRGF0YShvcC5maWVsZCwgb3AudmFsdWUsIGZvcm1TdGF0ZS5wYWdlLmZvcm1EYXRhKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICBVdGlscy5EYXRhLnNldERhdGFJdGVtKGZvcm1TdGF0ZS5wYWdlLmZvcm1EYXRhLCBvcC5maWVsZCwgb3AudmFsdWUpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICAgIGZvcm0ucGFnZS5mb3JtRGF0YVthY3Rpb24uYWRkVG9Gb3JtRGF0YS5maWVsZF0gPSBhY3Rpb24uYWRkVG9Gb3JtRGF0YS52YWx1ZTtcbiAgICB9XG4gICAgaWYgKGFjdGlvbi50eXBlID09PSBQYWdlQWN0aW9uLlRZUEVTLk5BVklHQVRFKSB7XG4gICAgICBoYW5kbGVycy5uYXZpZ2F0ZShhY3Rpb24sIHBhZ2VJZCwgb25QYWdlQ2hhbmdlKTtcbiAgICAgIHNldFN1Ym1pdHRpbmcoZmFsc2UpO1xuICAgIH0gZWxzZSB7XG4gICAgICBsZXQgcGFnZVVwZGF0ZSA9IChuZXh0KSA9PiBvblBhZ2VDaGFuZ2UoaGVscGVycy5nZXROZXh0UGFnZUlkKHR5cGUsIHBhZ2VzLCBwYWdlSWQsIGFjdGlvbiwgbmV4dCkpO1xuICAgICAgbGV0IGNvbGxlY3Rpb25OYW1lO1xuICAgICAgbGV0IGFkZEFub3RoZXJOYW1lO1xuICAgICAgaWYgKGFjdGlvbi5jb2xsZWN0aW9uKSB7XG4gICAgICAgIGNvbGxlY3Rpb25OYW1lID0gYWN0aW9uLmNvbGxlY3Rpb247XG4gICAgICAgIGNvbnN0IGNvbGxlY3Rpb25OYW1lQ2FwaXRhbGlzZWQgPSBjb2xsZWN0aW9uTmFtZS5jaGFyQXQoMCkudG9VcHBlckNhc2UoKSArIGNvbGxlY3Rpb25OYW1lLnNsaWNlKDEpXG4gICAgICAgIGFkZEFub3RoZXJOYW1lID0gYGFkZEFub3RoZXIke2NvbGxlY3Rpb25OYW1lQ2FwaXRhbGlzZWR9YC5zbGljZSgwLCAtMSk7XG4gICAgICB9XG4gICAgICBsZXQgY29sbGVjdGlvbkFycmF5O1xuICAgICAgbGV0IGluZGV4O1xuICAgICAgaWYgKGNvbGxlY3Rpb25OYW1lKSB7XG4gICAgICAgIGNvbGxlY3Rpb25BcnJheSA9IGZvcm0ucGFnZS5mb3JtRGF0YVtjb2xsZWN0aW9uTmFtZV07XG4gICAgICAgIGlmIChjb2xsZWN0aW9uQXJyYXkgJiYgY29sbGVjdGlvbkFycmF5Lmxlbmd0aCA+IDAgJiYgZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2NvbGxlY3Rpb25OYW1lfUFjdGl2ZUlkYF0pIHtcbiAgICAgICAgICBpbmRleCA9IGNvbGxlY3Rpb25BcnJheS5maW5kSW5kZXgob2JqID0+IG9iai5pZCA9PT0gZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2NvbGxlY3Rpb25OYW1lfUFjdGl2ZUlkYF0pO1xuICAgICAgICB9XG4gICAgICB9XG5cbiAgICAgIC8qIGVzbGludC1kaXNhYmxlIG5vLWNhc2UtZGVjbGFyYXRpb25zICovXG4gICAgICBzd2l0Y2ggKGFjdGlvbi50eXBlKSB7XG4gICAgICAgIGNhc2UgUGFnZUFjdGlvbi5UWVBFUy5TVUJNSVQ6XG4gICAgICAgICAgc2V0UGFnZVBvaW50KCdzdWJtaXQnKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBQYWdlQWN0aW9uLlRZUEVTLlNBVkVfQU5EX05BVklHQVRFOlxuICAgICAgICAgIGNvbnN0IHN0YXRlID0geyAuLi5jdXJyZW50VGFzayB9O1xuICAgICAgICAgIC8vIElmIHJlc2V0QWN0aXZlSWQgaXMgdHJ1ZSB0aGVuIHBvaW50IGFjdGl2ZSBJRCB0byBmaXJzdCBlbnRyeSBpbiBjb2xsZWN0aW9uXG4gICAgICAgICAgaWYgKGNvbGxlY3Rpb25BcnJheSAmJiBjb2xsZWN0aW9uQXJyYXkubGVuZ3RoID4gMCAmJiBhY3Rpb24ucmVzZXRBY3RpdmVJZCkge1xuICAgICAgICAgICAgZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2NvbGxlY3Rpb25OYW1lfUFjdGl2ZUlkYF0gPSBjb2xsZWN0aW9uQXJyYXlbMF0uaWQ7XG4gICAgICAgICAgfVxuICAgICAgICAgIC8vIElmIHJlc2V0QWN0aXZlSWQgaXMgZmFsc2VcbiAgICAgICAgICBpZiAoY29sbGVjdGlvbkFycmF5ICYmIGNvbGxlY3Rpb25BcnJheS5sZW5ndGggPiAwICYmICFhY3Rpb24ucmVzZXRBY3RpdmVJZCkge1xuICAgICAgICAgICAgLy8gU2V0IGFkZEFub3RoZXIgZmllbGQgdG8geWVzIGlmIG5vdCByZWFjaGVkIGxhc3QgZW50cnkgaW4gY29sbGVjdGlvblxuICAgICAgICAgICAgaWYgKGluZGV4ICE9PSB1bmRlZmluZWQgJiYgaW5kZXggKyAxIDwgZm9ybS5wYWdlLmZvcm1EYXRhW2NvbGxlY3Rpb25OYW1lXS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgZm9ybS5wYWdlLmZvcm1EYXRhW2FkZEFub3RoZXJOYW1lXSA9ICdZZXMnO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgLy8gU2V0IGFkZEFub3RoZXIgZmllbGQgdG8gbm8gaWYgcmVhY2hlZCBsYXN0IGVudHJ5XG4gICAgICAgICAgICBpZiAoaW5kZXggIT09IHVuZGVmaW5lZCAmJiBpbmRleCArIDEgPT09IGZvcm0ucGFnZS5mb3JtRGF0YVtjb2xsZWN0aW9uTmFtZV0ubGVuZ3RoICYmIGZvcm0ucGFnZS5mb3JtRGF0YVthZGRBbm90aGVyTmFtZV0pIHtcbiAgICAgICAgICAgICAgZm9ybS5wYWdlLmZvcm1EYXRhW2FkZEFub3RoZXJOYW1lXSA9ICdObyc7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgcGFnZVVwZGF0ZSA9ICgpID0+IGhhbmRsZXJzLm5hdmlnYXRlKGFjdGlvbiwgcGFnZUlkLCBvblBhZ2VDaGFuZ2UsIHN0YXRlKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSBQYWdlQWN0aW9uLlRZUEVTLkNPTExFQ1RJT05fQUREOlxuICAgICAgICAgIC8vIE9ubHkgYWRkIGVudHJ5IGlmIHRoZSBpbmRleCBpcyB1bmRlZmluZWQsXG4gICAgICAgICAgLy8gdGhlIGFycmF5IGlzIGVtcHR5XG4gICAgICAgICAgLy8gb3IgdGhlIGFjdGl2ZSBJRCBpcyB0aGUgbGFzdCBvbmUgaW4gdGhlIGNvbGxlY3Rpb24sXG4gICAgICAgICAgLy8gb3RoZXJ3aXNlIG1vdmUgdG8gbmV4dCBlbnRyeS5cbiAgICAgICAgICBpZiAoaW5kZXggPT09IHVuZGVmaW5lZCB8fCAoY29sbGVjdGlvbkFycmF5Lmxlbmd0aCA9PT0gMCkgfHwgaW5kZXggKyAxID09PSBmb3JtLnBhZ2UuZm9ybURhdGFbY29sbGVjdGlvbk5hbWVdLmxlbmd0aCkge1xuICAgICAgICAgICAgVXRpbHMuQ29sbGVjdGlvblBhZ2UuYWRkRW50cnkoYWN0aW9uLmNvbGxlY3Rpb24sIGZvcm0ucGFnZS5mb3JtRGF0YSk7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGZvcm0ucGFnZS5mb3JtRGF0YVtgJHthY3Rpb24uY29sbGVjdGlvbn1BY3RpdmVJZGBdID0gY29sbGVjdGlvbkFycmF5W2luZGV4ICsgMV0uaWQ7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gV2UgbmVlZCB0byBkZWxldGUgdGhlIGNvbGxlY3Rpb24gZW50cnkgZmllbGRzIGZyb20gZm9ybURhdGEgYXMgaXQgd2lsbCBiZSBob2xkaW5nIHByZXZpb3VzIHZhbHVlcy5cbiAgICAgICAgICBpZiAoZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2FjdGlvbi5jb2xsZWN0aW9ufWBdICYmIGZvcm0ucGFnZS5mb3JtRGF0YVtgJHthY3Rpb24uY29sbGVjdGlvbn1gXS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBjb25zdCBsYXN0SW5kZXggPSBmb3JtLnBhZ2UuZm9ybURhdGFbYCR7YWN0aW9uLmNvbGxlY3Rpb259YF0ubGVuZ3RoIC0gMTtcbiAgICAgICAgICAgIGNvbnN0IGZpZWxkc1RvRGVsZXRlID0gT2JqZWN0LmtleXMoZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2FjdGlvbi5jb2xsZWN0aW9ufWBdW2xhc3RJbmRleF0pXG4gICAgICAgICAgICAgIC5maWx0ZXIoayA9PiBrIGluIGZvcm0ucGFnZS5mb3JtRGF0YSAmJiBrICE9PSAnaWQnKTtcbiAgICAgICAgICAgIGZpZWxkc1RvRGVsZXRlLmZvckVhY2goaSA9PiBkZWxldGUgZm9ybS5wYWdlLmZvcm1EYXRhW2ldKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICBwYWdlVXBkYXRlID0gKCkgPT4gaGFuZGxlcnMubmF2aWdhdGUoYWN0aW9uLCBwYWdlSWQsIG9uUGFnZUNoYW5nZSk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgUGFnZUFjdGlvbi5UWVBFUy5DT0xMRUNUSU9OX0RVUExJQ0FURTpcbiAgICAgICAgICBpZiAoVXRpbHMuQ29sbGVjdGlvblBhZ2UuZHVwbGljYXRlQWN0aXZlRW50cnkoYWN0aW9uLmNvbGxlY3Rpb24sIGZvcm1TdGF0ZS5wYWdlLmZvcm1EYXRhKSkge1xuICAgICAgICAgICAgcGFnZVVwZGF0ZSA9ICgpID0+IGhhbmRsZXJzLm5hdmlnYXRlKGFjdGlvbiwgcGFnZUlkLCBvblBhZ2VDaGFuZ2UpO1xuICAgICAgICAgIH07XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgUGFnZUFjdGlvbi5UWVBFUy5DT0xMRUNUSU9OX1JFTU9WRTpcbiAgICAgICAgICBjb25zdCBhY3RpdmVJZCA9IGFjdGlvbi50YXJnZXRJZCB8fCBmb3JtLnBhZ2UuZm9ybURhdGFbYCR7YWN0aW9uLmNvbGxlY3Rpb24uc3BsaXQoJy4nKS5wb3AoKX1BY3RpdmVJZGBdO1xuICAgICAgICAgIGNvbnN0IHJlbW92ZWRFbnRyeSA9IFV0aWxzLkNvbGxlY3Rpb25QYWdlLnJlbW92ZUVudHJ5KGFjdGlvbi5jb2xsZWN0aW9uLCBmb3JtU3RhdGUucGFnZS5mb3JtRGF0YSwgYWN0aXZlSWQpO1xuICAgICAgICAgIGlmIChhY3Rpb24ucmVjb3JkUmVtb3ZhbCkge1xuICAgICAgICAgICAgZm9ybS5wYWdlLmZvcm1EYXRhW2Ake2FjdGlvbi5jb2xsZWN0aW9uLnNwbGl0KCcuJykucG9wKCl9TGFzdFJlbW92ZWRgXSA9IHsgLi4ucmVtb3ZlZEVudHJ5IH07XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgLy8gVGhlIGZvcm1EYXRhIG5lZWRzIHRvIGJlIHRpZGllZCB1cCBhZnRlciByZW1vdmluZyB0aGUgY29sbGVjdGlvbiBlbnRyeTpcblxuICAgICAgICAgIC8vIDEuIFJldHJpZXZlIHRoZSBmb3JtRGF0YSBJRCBhcyBpdCB3aWxsIGJlIG92ZXJ3cml0dGVuIGJ5IGEgZmllbGQgd2l0aCB0aGUgc2FtZSBuYW1lIGluIHRoZSBjb2xsZWN0aW9uIGVudHJ5LlxuICAgICAgICAgIGNvbnN0IGZvcm1EYXRhSWQgPSBmb3JtLnBhZ2UuZm9ybURhdGEuaWQ7XG5cbiAgICAgICAgICAvLyAyLiBCdWlsZCB0aGUgbGlzdCBvZiBmaWVsZCBuYW1lcyB0byBkZWxldGUgYW5kIGRlbGV0ZSB0aGVtIGZyb20gZm9ybURhdGEuXG4gICAgICAgICAgaWYgKHJlbW92ZWRFbnRyeSAhPT0gbnVsbCkge1xuICAgICAgICAgICAgY29uc3QgcmVtb3ZlZEVudHJ5RmllbGRzVG9EZWxldGUgPSBPYmplY3Qua2V5cyhyZW1vdmVkRW50cnkpLmZpbHRlcihrID0+IGsgaW4gZm9ybS5wYWdlLmZvcm1EYXRhKTtcbiAgICAgICAgICAgIHJlbW92ZWRFbnRyeUZpZWxkc1RvRGVsZXRlLmZvckVhY2goaSA9PiBkZWxldGUgZm9ybS5wYWdlLmZvcm1EYXRhW2ldKTtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICAvLyAzLiBBc3NpZ24gdGhlIGZpZWxkcyBpbiB0aGUgbGFzdCBjb2xsZWN0aW9uIGVudHJ5IHRvIGZvcm1EYXRhLlxuICAgICAgICAgIE9iamVjdC5hc3NpZ24oZm9ybS5wYWdlLmZvcm1EYXRhLCBjb2xsZWN0aW9uQXJyYXlbY29sbGVjdGlvbkFycmF5Lmxlbmd0aCAtIDFdKTtcblxuICAgICAgICAgIC8vIDQuIEFzc2lnbiB0aGUgZm9ybURhdGEgSUQgYmFjayB0byB0aGUgZm9ybURhdGEuXG4gICAgICAgICAgZm9ybS5wYWdlLmZvcm1EYXRhLmlkID0gZm9ybURhdGFJZDtcblxuICAgICAgICAgIC8vIDUuIElmIHRoZSBjb2xsZWN0aW9uIGFycmF5IGhhcyBlbnRyaWVzIHNldCB0aGUgY29ycmVjdCBBY3RpdmVJZCBcbiAgICAgICAgICAvLyBvdGhlcndpc2UgZGVsZXRlIGl0IGFzIHdlbGwgYXMgdGhlIGNvbGxlY3Rpb24gYXJyYXkuXG4gICAgICAgICAgaWYgKGNvbGxlY3Rpb25BcnJheS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICBmb3JtLnBhZ2UuZm9ybURhdGFbYCR7YWN0aW9uLmNvbGxlY3Rpb259QWN0aXZlSWRgXSA9IGNvbGxlY3Rpb25BcnJheVtjb2xsZWN0aW9uQXJyYXkubGVuZ3RoIC0gMV0uaWQ7XG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGRlbGV0ZSBmb3JtLnBhZ2UuZm9ybURhdGFbYCR7YWN0aW9uLmNvbGxlY3Rpb259QWN0aXZlSWRgXTtcbiAgICAgICAgICAgIGRlbGV0ZSBmb3JtLnBhZ2UuZm9ybURhdGFbYWN0aW9uLmNvbGxlY3Rpb25dO1xuICAgICAgICAgIH1cblxuICAgICAgICAgIHBhZ2VVcGRhdGUgPSAoKSA9PiBoYW5kbGVycy5uYXZpZ2F0ZShhY3Rpb24sIHBhZ2VJZCwgb25QYWdlQ2hhbmdlKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgZGVmYXVsdDpcbiAgICAgICAgICBicmVhaztcbiAgICAgIH07XG5cbiAgICAgIC8vIElmIGEgdmFsdWUgaGFzIGJlZW4gZGVsZXRlZCBmcm9tIGZvcm1EYXRhLFxuICAgICAgLy8gYWxzbyBkZWxldGUgaXQgZnJvbSBkYXRhIGJlZm9yZSBkb2luZyBvYmplY3Qgc3ByZWFkLFxuICAgICAgLy8gb3IgZWxzZSBpdCB3aWxsIHJlYXBwZWFyIGluIHN1Ym1pc3Npb25EYXRhLlxuICAgICAgVXRpbHMuRGF0YS5kZWxldGVWYWx1ZXMoZGF0YSwgZm9ybVN0YXRlLnBhZ2UuZm9ybURhdGEpO1xuXG4gICAgICAvLyBTYXZlIGRyYWZ0IG9yIHN1Ym1pdC5cbiAgICAgIGNvbnN0IHN1Ym1pc3Npb25EYXRhID0gVXRpbHMuRm9ybWF0LmZvcm0oeyBwYWdlcywgY29tcG9uZW50cyB9LCB7IC4uLmRhdGEsIC4uLnBhdGNoLCAuLi5mb3JtU3RhdGUucGFnZS5mb3JtRGF0YSB9LCBFdmVudFR5cGVzLlNVQk1JVCk7XG4gICAgICBzdWJtaXNzaW9uRGF0YS5mb3JtU3RhdHVzID0gaGVscGVycy5nZXRTdWJtaXNzaW9uU3RhdHVzKHR5cGUsIHBhZ2VzLCBwYWdlSWQsIGFjdGlvbiwgc3VibWlzc2lvbkRhdGEsIGN1cnJlbnRUYXNrLCB0cnVlLCBodWJEZXRhaWxzPy5zZWN0aW9ucyk7XG4gICAgICBpZiAoX3BhdGNoKSB7XG4gICAgICAgIHNldERhdGEoc3VibWlzc2lvbkRhdGEpO1xuICAgICAgfTtcblxuICAgICAgY29uc3QgZm9ybVBhZ2VzQW5kQ29tcG9uZW50cyA9IHsgcGFnZXMsIGNvbXBvbmVudHMgfTtcbiAgICAgIGlmIChhY3Rpb24udHlwZSA9PT0gUGFnZUFjdGlvbi5UWVBFUy5TVUJNSVQpIHtcbiAgICAgICAgaGVscGVycy5jbGVhck91dFVuY29tcGxldGVkUm91dGVzKGNsZWFuc2VIaWRkZW5EYXRhLCBmb3JtUGFnZXNBbmRDb21wb25lbnRzLCBzdWJtaXNzaW9uRGF0YSk7XG4gICAgICB9XG5cbiAgICAgIC8vIEluIGNhc2Ugb2YgaHViLWFuZC1zcG9rZSBpZiBwYXRjaExhYmVsIGhhcyBjaGFuZ2VkIHRoZW4gXG4gICAgICAvLyBzYXZlIG5hbWUgYW5kIHZhbHVlIHRvIHZhcmlhYmxlcyBmb3IgY2FsbCB0byBvblN1Ym1pdCBob29rXG4gICAgICBsZXQgY2hhbmdlZEZpZWxkTmFtZTtcbiAgICAgIGxldCBjaGFuZ2VkRmllbGRWYWx1ZTtcbiAgICAgIGlmICh0eXBlID09PSBGb3JtVHlwZXMuSFVCICYmIE9iamVjdC5rZXlzKHBhdGNoTGFiZWwpLmxlbmd0aCA+IDApIHtcbiAgICAgICAgLyogZXNsaW50LWRpc2FibGUgcHJlZmVyLWRlc3RydWN0dXJpbmcgKi9cbiAgICAgICAgY2hhbmdlZEZpZWxkTmFtZSA9IE9iamVjdC5rZXlzKHBhdGNoTGFiZWwpWzBdO1xuICAgICAgICBjaGFuZ2VkRmllbGRWYWx1ZSA9IE9iamVjdC52YWx1ZXMocGF0Y2hMYWJlbClbMF07XG4gICAgICAgIC8qIGVzbGludC1lbmFibGUgcHJlZmVyLWRlc3RydWN0dXJpbmcgKi9cbiAgICAgIH07XG5cbiAgICAgIC8vIE5vdyBzdWJtaXQgdGhlIGRhdGEgdG8gdGhlIGJhY2tlbmQuLi5cbiAgICAgIGhvb2tzLm9uU3VibWl0KGFjdGlvbi50eXBlLCBzdWJtaXNzaW9uRGF0YSwgKHJlc3BvbnNlKSA9PiB7XG4gICAgICAgIC8vIFRoZSBiYWNrZW5kIHJlc3BvbnNlIG1heSB3ZWxsIGNvbnRhaW4gZGF0YSB3ZSBuZWVkIHNvIGFwcGx5IGl0Li4uXG4gICAgICAgIC8vIC4uLiBidXQgdGhpcyBuZWVkcyB0byBoYXBwZW4gaW4gYSB1c2VFZmZlY3QsIG5vdCByaWdodCBhd2F5LlxuICAgICAgICBjb25zdCBzRGF0YSA9IHsgLi4uc3VibWlzc2lvbkRhdGEsIC4uLnJlc3BvbnNlIH07XG4gICAgICAgIHNldFN1Ym1pdHRlZCh7IGRhdGE6IHNEYXRhIH0pO1xuICAgICAgICBwYWdlVXBkYXRlKHNEYXRhKTtcbiAgICAgICAgc2V0U3VibWl0dGluZyhmYWxzZSk7XG4gICAgICB9LCAoZXJyb3JzLCB3aXBlRGF0YSA9IHRydWUpID0+IHtcbiAgICAgICAgaGFuZGxlcnMuc3VibWlzc2lvbkVycm9yKGVycm9ycywgYWRkRXJyb3JzKTtcbiAgICAgICAgaWYgKHdpcGVEYXRhKSB7XG4gICAgICAgICAgc2V0RGF0YSh7IC4uLnByZVN1Ym1pdERhdGEgfSk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0U3VibWl0dGluZyhmYWxzZSk7XG4gICAgICB9LCBjaGFuZ2VkRmllbGROYW1lLCBjaGFuZ2VkRmllbGRWYWx1ZSwgcGFnZUlkKTtcbiAgICB9O1xuICB9O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgb25QYWdlQWN0aW9uO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxPQUFBLEdBQUFDLE9BQUE7QUFDQSxJQUFBQyxNQUFBLEdBQUFDLHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBRyxzQkFBQSxHQUFBRCxzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUksU0FBQSxHQUFBRixzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUssUUFBQSxHQUFBSCxzQkFBQSxDQUFBRixPQUFBO0FBQWdDLFNBQUFFLHVCQUFBSSxDQUFBLFdBQUFBLENBQUEs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
|