@ukhomeoffice/cop-react-form-renderer 7.3.2-alpha.5 → 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 +81 -170
- 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,158 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _getIndexOfMatchingValueIn = _interopRequireDefault(require("./getIndexOfMatchingValueIn"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('Utils.Operate.getIndexOfPriorMatchingValueIn', () => {
|
|
6
|
-
const DATA = {
|
|
7
|
-
arrayOfValues: ['abc', 'bcd', 'cde', 'def', {
|
|
8
|
-
root: {
|
|
9
|
-
branch: 'leaf'
|
|
10
|
-
}
|
|
11
|
-
}],
|
|
12
|
-
cutoffIndex: 1,
|
|
13
|
-
ignoreIndex: 2,
|
|
14
|
-
valueToSearchFor: 'cde',
|
|
15
|
-
targetName: 'arrayOfValues',
|
|
16
|
-
fieldName: 'valueToSearchFor',
|
|
17
|
-
cutoffName: 'cutoffIndex',
|
|
18
|
-
ignoreName: 'ignoreIndex'
|
|
19
|
-
};
|
|
20
|
-
it('Should return the index of a matching value if one exists', () => {
|
|
21
|
-
const CONFIG = {
|
|
22
|
-
target: 'arrayOfValues',
|
|
23
|
-
value: 'cde'
|
|
24
|
-
};
|
|
25
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
26
|
-
expect(result).toEqual('2');
|
|
27
|
-
});
|
|
28
|
-
it('Should handle getting value from given field', () => {
|
|
29
|
-
const CONFIG = {
|
|
30
|
-
target: 'arrayOfValues',
|
|
31
|
-
field: 'valueToSearchFor'
|
|
32
|
-
};
|
|
33
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
34
|
-
expect(result).toEqual('2');
|
|
35
|
-
});
|
|
36
|
-
it('Should handle interpolated string for field', () => {
|
|
37
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
38
|
-
const CONFIG = {
|
|
39
|
-
target: 'arrayOfValues',
|
|
40
|
-
field: '${fieldName}'
|
|
41
|
-
};
|
|
42
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
43
|
-
expect(result).toEqual('2');
|
|
44
|
-
});
|
|
45
|
-
it('Should handle interpolated string for key', () => {
|
|
46
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
47
|
-
const CONFIG = {
|
|
48
|
-
target: 'arrayOfValues',
|
|
49
|
-
key: 'root.branch',
|
|
50
|
-
value: 'leaf'
|
|
51
|
-
};
|
|
52
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
53
|
-
expect(result).toEqual('4');
|
|
54
|
-
});
|
|
55
|
-
it('Should handle a cutoff value being specified', () => {
|
|
56
|
-
const CONFIG = {
|
|
57
|
-
target: 'arrayOfValues',
|
|
58
|
-
value: 'cde',
|
|
59
|
-
cutoff: {
|
|
60
|
-
value: 1
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
64
|
-
expect(result).toEqual(null); // Cutoff occurs before matching value is reached.
|
|
65
|
-
});
|
|
66
|
-
it('Should handle a cutoff field being specified', () => {
|
|
67
|
-
const CONFIG = {
|
|
68
|
-
target: 'arrayOfValues',
|
|
69
|
-
value: 'cde',
|
|
70
|
-
cutoff: {
|
|
71
|
-
field: 'cutoffIndex'
|
|
72
|
-
}
|
|
73
|
-
};
|
|
74
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
75
|
-
expect(result).toEqual(null); // Cutoff occurs before matching value is reached.
|
|
76
|
-
});
|
|
77
|
-
it('Should handle interpolated string for cutoff.field', () => {
|
|
78
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
79
|
-
const CONFIG = {
|
|
80
|
-
target: 'arrayOfValues',
|
|
81
|
-
value: 'cde',
|
|
82
|
-
cutoff: {
|
|
83
|
-
field: '${cutoffName}'
|
|
84
|
-
}
|
|
85
|
-
};
|
|
86
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
87
|
-
expect(result).toEqual(null); // Cutoff occurs before matching value is reached.
|
|
88
|
-
});
|
|
89
|
-
it('Should handle an ignore value being specified', () => {
|
|
90
|
-
const CONFIG = {
|
|
91
|
-
target: 'arrayOfValues',
|
|
92
|
-
value: 'cde',
|
|
93
|
-
ignore: {
|
|
94
|
-
value: 2
|
|
95
|
-
}
|
|
96
|
-
};
|
|
97
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
98
|
-
expect(result).toEqual(null); // Should ignore the matching value.
|
|
99
|
-
});
|
|
100
|
-
it('Should handle an ignore field being specified', () => {
|
|
101
|
-
const CONFIG = {
|
|
102
|
-
target: 'arrayOfValues',
|
|
103
|
-
value: 'cde',
|
|
104
|
-
ignore: {
|
|
105
|
-
field: 'ignoreIndex'
|
|
106
|
-
}
|
|
107
|
-
};
|
|
108
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
109
|
-
expect(result).toEqual(null); // Should ignore the matching value.
|
|
110
|
-
});
|
|
111
|
-
it('Should handle interpolated string for ignore.field', () => {
|
|
112
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
113
|
-
const CONFIG = {
|
|
114
|
-
target: 'arrayOfValues',
|
|
115
|
-
value: 'cde',
|
|
116
|
-
ignore: {
|
|
117
|
-
field: '${ignoreName}'
|
|
118
|
-
}
|
|
119
|
-
};
|
|
120
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
121
|
-
expect(result).toEqual(null); // Should ignore the matching value.
|
|
122
|
-
});
|
|
123
|
-
it('Should handle interpolated string for target', () => {
|
|
124
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
125
|
-
const CONFIG = {
|
|
126
|
-
target: '${targetName}',
|
|
127
|
-
value: 'cde'
|
|
128
|
-
};
|
|
129
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
130
|
-
expect(result).toEqual('2');
|
|
131
|
-
});
|
|
132
|
-
it('Should return null when the target does not exist', () => {
|
|
133
|
-
const CONFIG = {
|
|
134
|
-
target: 'notARealTarget',
|
|
135
|
-
value: 'cde'
|
|
136
|
-
};
|
|
137
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
138
|
-
expect(result).toEqual(null);
|
|
139
|
-
});
|
|
140
|
-
it('Should return null when config is missing fields', () => {
|
|
141
|
-
const CONFIG = {};
|
|
142
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, DATA);
|
|
143
|
-
expect(result).toEqual(null);
|
|
144
|
-
});
|
|
145
|
-
it('Should return null when config is invalid', () => {
|
|
146
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(null, DATA);
|
|
147
|
-
expect(result).toEqual(null);
|
|
148
|
-
});
|
|
149
|
-
it('Should return null when data is invalid', () => {
|
|
150
|
-
const CONFIG = {
|
|
151
|
-
target: 'arrayOfValues',
|
|
152
|
-
value: 'cde'
|
|
153
|
-
};
|
|
154
|
-
const result = (0, _getIndexOfMatchingValueIn.default)(CONFIG, null);
|
|
155
|
-
expect(result).toEqual(null);
|
|
156
|
-
});
|
|
157
|
-
});
|
|
158
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbiIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJEQVRBIiwiYXJyYXlPZlZhbHVlcyIsInJvb3QiLCJicmFuY2giLCJjdXRvZmZJbmRleCIsImlnbm9yZUluZGV4IiwidmFsdWVUb1NlYXJjaEZvciIsInRhcmdldE5hbWUiLCJmaWVsZE5hbWUiLCJjdXRvZmZOYW1lIiwiaWdub3JlTmFtZSIsIml0IiwiQ09ORklHIiwidGFyZ2V0IiwidmFsdWUiLCJyZXN1bHQiLCJnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluIiwiZXhwZWN0IiwidG9FcXVhbCIsImZpZWxkIiwia2V5IiwiY3V0b2ZmIiwiaWdub3JlIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL09wZXJhdGUvZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbi50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluIGZyb20gJy4vZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbic7XG5cbmRlc2NyaWJlKCdVdGlscy5PcGVyYXRlLmdldEluZGV4T2ZQcmlvck1hdGNoaW5nVmFsdWVJbicsICgpID0+IHtcbiAgY29uc3QgREFUQSA9IHsgXG4gICAgYXJyYXlPZlZhbHVlczogW1xuICAgICAgJ2FiYycsXG4gICAgICAnYmNkJyxcbiAgICAgICdjZGUnLFxuICAgICAgJ2RlZicsXG4gICAgICB7XG4gICAgICAgIHJvb3Q6IHtcbiAgICAgICAgICBicmFuY2g6ICdsZWFmJ1xuICAgICAgICB9XG4gICAgICB9ICAgICAgICBcbiAgICBdLFxuICAgIGN1dG9mZkluZGV4OiAxLFxuICAgIGlnbm9yZUluZGV4OiAyLFxuICAgIHZhbHVlVG9TZWFyY2hGb3I6ICdjZGUnLFxuICAgIHRhcmdldE5hbWU6ICdhcnJheU9mVmFsdWVzJyxcbiAgICBmaWVsZE5hbWU6ICd2YWx1ZVRvU2VhcmNoRm9yJyxcbiAgICBjdXRvZmZOYW1lOiAnY3V0b2ZmSW5kZXgnLFxuICAgIGlnbm9yZU5hbWU6ICdpZ25vcmVJbmRleCdcbiAgfTtcblxuICBpdCgnU2hvdWxkIHJldHVybiB0aGUgaW5kZXggb2YgYSBtYXRjaGluZyB2YWx1ZSBpZiBvbmUgZXhpc3RzJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnYXJyYXlPZlZhbHVlcycsIHZhbHVlOiAnY2RlJyB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IGdldEluZGV4T2ZNYXRjaGluZ1ZhbHVlSW4oQ09ORklHLCBEQVRBKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKCcyJyk7XG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgaGFuZGxlIGdldHRpbmcgdmFsdWUgZnJvbSBnaXZlbiBmaWVsZCcsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IHRhcmdldDogJ2FycmF5T2ZWYWx1ZXMnLCBmaWVsZDogJ3ZhbHVlVG9TZWFyY2hGb3InIH07XG4gICAgY29uc3QgcmVzdWx0ID0gZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbihDT05GSUcsIERBVEEpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwoJzInKTtcbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCBoYW5kbGUgaW50ZXJwb2xhdGVkIHN0cmluZyBmb3IgZmllbGQnLCAoKSA9PiB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXRlbXBsYXRlLWN1cmx5LWluLXN0cmluZ1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnYXJyYXlPZlZhbHVlcycsIGZpZWxkOiAnJHtmaWVsZE5hbWV9JyB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IGdldEluZGV4T2ZNYXRjaGluZ1ZhbHVlSW4oQ09ORklHLCBEQVRBKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKCcyJyk7XG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgaGFuZGxlIGludGVycG9sYXRlZCBzdHJpbmcgZm9yIGtleScsICgpID0+IHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdGVtcGxhdGUtY3VybHktaW4tc3RyaW5nXG4gICAgY29uc3QgQ09ORklHID0geyB0YXJnZXQ6ICdhcnJheU9mVmFsdWVzJywga2V5OiAncm9vdC5icmFuY2gnLCB2YWx1ZTogJ2xlYWYnIH07XG4gICAgY29uc3QgcmVzdWx0ID0gZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbihDT05GSUcsIERBVEEpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwoJzQnKTtcbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCBoYW5kbGUgYSBjdXRvZmYgdmFsdWUgYmVpbmcgc3BlY2lmaWVkJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnYXJyYXlPZlZhbHVlcycsIHZhbHVlOiAnY2RlJywgY3V0b2ZmOiB7IHZhbHVlOiAxIH0gfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTsgLy8gQ3V0b2ZmIG9jY3VycyBiZWZvcmUgbWF0Y2hpbmcgdmFsdWUgaXMgcmVhY2hlZC5cbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCBoYW5kbGUgYSBjdXRvZmYgZmllbGQgYmVpbmcgc3BlY2lmaWVkJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnYXJyYXlPZlZhbHVlcycsIHZhbHVlOiAnY2RlJywgY3V0b2ZmOiB7IGZpZWxkOiAnY3V0b2ZmSW5kZXgnIH0gfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTsgLy8gQ3V0b2ZmIG9jY3VycyBiZWZvcmUgbWF0Y2hpbmcgdmFsdWUgaXMgcmVhY2hlZC5cbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCBoYW5kbGUgaW50ZXJwb2xhdGVkIHN0cmluZyBmb3IgY3V0b2ZmLmZpZWxkJywgKCkgPT4ge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby10ZW1wbGF0ZS1jdXJseS1pbi1zdHJpbmdcbiAgICBjb25zdCBDT05GSUcgPSB7IHRhcmdldDogJ2FycmF5T2ZWYWx1ZXMnLCB2YWx1ZTogJ2NkZScsIGN1dG9mZjogeyBmaWVsZDogJyR7Y3V0b2ZmTmFtZX0nIH0gfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTsgLy8gQ3V0b2ZmIG9jY3VycyBiZWZvcmUgbWF0Y2hpbmcgdmFsdWUgaXMgcmVhY2hlZC5cbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCBoYW5kbGUgYW4gaWdub3JlIHZhbHVlIGJlaW5nIHNwZWNpZmllZCcsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IHRhcmdldDogJ2FycmF5T2ZWYWx1ZXMnLCB2YWx1ZTogJ2NkZScsIGlnbm9yZTogeyB2YWx1ZTogMiB9IH07XG4gICAgY29uc3QgcmVzdWx0ID0gZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbihDT05GSUcsIERBVEEpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwobnVsbCk7IC8vIFNob3VsZCBpZ25vcmUgdGhlIG1hdGNoaW5nIHZhbHVlLlxuICB9KTtcblxuICBpdCgnU2hvdWxkIGhhbmRsZSBhbiBpZ25vcmUgZmllbGQgYmVpbmcgc3BlY2lmaWVkJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnYXJyYXlPZlZhbHVlcycsIHZhbHVlOiAnY2RlJywgaWdub3JlOiB7IGZpZWxkOiAnaWdub3JlSW5kZXgnIH0gfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTsgLy8gU2hvdWxkIGlnbm9yZSB0aGUgbWF0Y2hpbmcgdmFsdWUuXG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgaGFuZGxlIGludGVycG9sYXRlZCBzdHJpbmcgZm9yIGlnbm9yZS5maWVsZCcsICgpID0+IHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tdGVtcGxhdGUtY3VybHktaW4tc3RyaW5nXG4gICAgY29uc3QgQ09ORklHID0geyB0YXJnZXQ6ICdhcnJheU9mVmFsdWVzJywgdmFsdWU6ICdjZGUnLCBpZ25vcmU6IHsgZmllbGQ6ICcke2lnbm9yZU5hbWV9JyB9IH07XG4gICAgY29uc3QgcmVzdWx0ID0gZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbihDT05GSUcsIERBVEEpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwobnVsbCk7IC8vIFNob3VsZCBpZ25vcmUgdGhlIG1hdGNoaW5nIHZhbHVlLlxuICB9KTtcblxuICBpdCgnU2hvdWxkIGhhbmRsZSBpbnRlcnBvbGF0ZWQgc3RyaW5nIGZvciB0YXJnZXQnLCAoKSA9PiB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXRlbXBsYXRlLWN1cmx5LWluLXN0cmluZ1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnJHt0YXJnZXROYW1lfScsIHZhbHVlOiAnY2RlJyB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IGdldEluZGV4T2ZNYXRjaGluZ1ZhbHVlSW4oQ09ORklHLCBEQVRBKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKCcyJyk7XG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgcmV0dXJuIG51bGwgd2hlbiB0aGUgdGFyZ2V0IGRvZXMgbm90IGV4aXN0JywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgdGFyZ2V0OiAnbm90QVJlYWxUYXJnZXQnLCB2YWx1ZTogJ2NkZScgfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTtcbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCByZXR1cm4gbnVsbCB3aGVuIGNvbmZpZyBpcyBtaXNzaW5nIGZpZWxkcycsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7fTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTtcbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCByZXR1cm4gbnVsbCB3aGVuIGNvbmZpZyBpcyBpbnZhbGlkJywgKCkgPT4ge1xuICAgIGNvbnN0IHJlc3VsdCA9IGdldEluZGV4T2ZNYXRjaGluZ1ZhbHVlSW4obnVsbCwgREFUQSk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTtcbiAgfSk7XG5cbiAgaXQoJ1Nob3VsZCByZXR1cm4gbnVsbCB3aGVuIGRhdGEgaXMgaW52YWxpZCcsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IHRhcmdldDogJ2FycmF5T2ZWYWx1ZXMnLCB2YWx1ZTogJ2NkZScgfTtcbiAgICBjb25zdCByZXN1bHQgPSBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluKENPTkZJRywgbnVsbCk7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChudWxsKTtcbiAgfSk7XG5cbn0pO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLElBQUFBLDBCQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBb0UsU0FBQUQsdUJBQUFFLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFFcEVHLFFBQVEsQ0FBQyw4Q0FBOEMsRUFBRSxNQUFNO0VBQzdELE1BQU1DLElBQUksR0FBRztJQUNYQyxhQUFhLEVBQUUsQ0FD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
|
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
8
|
-
var _getCollectionPageActiveIndex = _interopRequireDefault(require("../CollectionPage/getCollectionPageActiveIndex"));
|
|
9
|
-
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
10
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
|
-
// Global imports.
|
|
12
|
-
|
|
13
|
-
// Local imports.
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Finds a field within data and returns its length
|
|
17
|
-
* @param {object} config The config of the operation.
|
|
18
|
-
* @param {string} config.target The path to the target field. If the path
|
|
19
|
-
* goes through a collection this can be specified as 'collectionName[]'
|
|
20
|
-
* and this function will use the active entry within that collection.
|
|
21
|
-
* @param {object} data A page's formData.
|
|
22
|
-
* @returns The length of a field if found or 0
|
|
23
|
-
*/
|
|
24
|
-
const getLength = (config, data) => {
|
|
25
|
-
if (!config || !data) {
|
|
26
|
-
return null;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
// Replace any instances of 'collectionName[]' with 'collectionName[activeIndex]'
|
|
30
|
-
const pathParts = config.target.split('.');
|
|
31
|
-
let updatedPath = '';
|
|
32
|
-
pathParts.forEach(part => {
|
|
33
|
-
if (updatedPath !== '') {
|
|
34
|
-
updatedPath += '.';
|
|
35
|
-
}
|
|
36
|
-
if (part.slice(-2) === '[]') {
|
|
37
|
-
const collectionName = part.slice(0, -2);
|
|
38
|
-
const activeIndex = (0, _getCollectionPageActiveIndex.default)(collectionName, data);
|
|
39
|
-
updatedPath += "".concat(collectionName, "[").concat(activeIndex, "]");
|
|
40
|
-
} else {
|
|
41
|
-
updatedPath += part;
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
// Get the field and return its length
|
|
46
|
-
const targetPath = _copReactComponents.Utils.interpolateString(updatedPath, data);
|
|
47
|
-
const target = (0, _getSourceData.default)(data, targetPath);
|
|
48
|
-
return (target === null || target === void 0 ? void 0 : target.length) || 0;
|
|
49
|
-
};
|
|
50
|
-
var _default = exports.default = getLength;
|
|
51
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY29wUmVhY3RDb21wb25lbnRzIiwicmVxdWlyZSIsIl9nZXRDb2xsZWN0aW9uUGFnZUFjdGl2ZUluZGV4IiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsIl9nZXRTb3VyY2VEYXRhIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZ2V0TGVuZ3RoIiwiY29uZmlnIiwiZGF0YSIsInBhdGhQYXJ0cyIsInRhcmdldCIsInNwbGl0IiwidXBkYXRlZFBhdGgiLCJmb3JFYWNoIiwicGFydCIsInNsaWNlIiwiY29sbGVjdGlvbk5hbWUiLCJhY3RpdmVJbmRleCIsImdldENvbGxlY3Rpb25QYWdlQWN0aXZlSW5kZXgiLCJjb25jYXQiLCJ0YXJnZXRQYXRoIiwiVXRpbHMiLCJpbnRlcnBvbGF0ZVN0cmluZyIsImdldFNvdXJjZURhdGEiLCJsZW5ndGgiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvT3BlcmF0ZS9nZXRMZW5ndGguanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gR2xvYmFsIGltcG9ydHMuXG5pbXBvcnQgeyBVdGlscyB9IGZyb20gJ0B1a2hvbWVvZmZpY2UvY29wLXJlYWN0LWNvbXBvbmVudHMnO1xuXG4vLyBMb2NhbCBpbXBvcnRzLlxuaW1wb3J0IGdldENvbGxlY3Rpb25QYWdlQWN0aXZlSW5kZXggZnJvbSAnLi4vQ29sbGVjdGlvblBhZ2UvZ2V0Q29sbGVjdGlvblBhZ2VBY3RpdmVJbmRleCc7XG5pbXBvcnQgZ2V0U291cmNlRGF0YSBmcm9tICcuLi9EYXRhL2dldFNvdXJjZURhdGEnO1xuXG4vKipcbiAqIEZpbmRzIGEgZmllbGQgd2l0aGluIGRhdGEgYW5kIHJldHVybnMgaXRzIGxlbmd0aFxuICogQHBhcmFtIHtvYmplY3R9IGNvbmZpZyBUaGUgY29uZmlnIG9mIHRoZSBvcGVyYXRpb24uXG4gKiBAcGFyYW0ge3N0cmluZ30gY29uZmlnLnRhcmdldCBUaGUgcGF0aCB0byB0aGUgdGFyZ2V0IGZpZWxkLiBJZiB0aGUgcGF0aFxuICogZ29lcyB0aHJvdWdoIGEgY29sbGVjdGlvbiB0aGlzIGNhbiBiZSBzcGVjaWZpZWQgYXMgJ2NvbGxlY3Rpb25OYW1lW10nXG4gKiBhbmQgdGhpcyBmdW5jdGlvbiB3aWxsIHVzZSB0aGUgYWN0aXZlIGVudHJ5IHdpdGhpbiB0aGF0IGNvbGxlY3Rpb24uXG4gKiBAcGFyYW0ge29iamVjdH0gZGF0YSBBIHBhZ2UncyBmb3JtRGF0YS5cbiAqIEByZXR1cm5zIFRoZSBsZW5ndGggb2YgYSBmaWVsZCBpZiBmb3VuZCBvciAwXG4gKi9cbmNvbnN0IGdldExlbmd0aCA9IChjb25maWcsIGRhdGEpID0+IHtcbiAgaWYgKCFjb25maWcgfHwgIWRhdGEpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIC8vIFJlcGxhY2UgYW55IGluc3RhbmNlcyBvZiAnY29sbGVjdGlvbk5hbWVbXScgd2l0aCAnY29sbGVjdGlvbk5hbWVbYWN0aXZlSW5kZXhdJ1xuICBjb25zdCBwYXRoUGFydHMgPSBjb25maWcudGFyZ2V0LnNwbGl0KCcuJyk7XG4gIGxldCB1cGRhdGVkUGF0aCA9ICcnO1xuICBwYXRoUGFydHMuZm9yRWFjaCgocGFydCkgPT4ge1xuICAgIGlmICh1cGRhdGVkUGF0aCAhPT0gJycpIHtcbiAgICAgIHVwZGF0ZWRQYXRoICs9ICcuJztcbiAgICB9XG4gICAgaWYgKHBhcnQuc2xpY2UoLTIpID09PSAnW10nKSB7XG4gICAgICBjb25zdCBjb2xsZWN0aW9uTmFtZSA9IHBhcnQuc2xpY2UoMCwgLTIpO1xuICAgICAgY29uc3QgYWN0aXZlSW5kZXggPSBnZXRDb2xsZWN0aW9uUGFnZUFjdGl2ZUluZGV4KGNvbGxlY3Rpb25OYW1lLCBkYXRhKTtcbiAgICAgIHVwZGF0ZWRQYXRoICs9IGAke2NvbGxlY3Rpb25OYW1lfVske2FjdGl2ZUluZGV4fV1gO1xuICAgIH0gZWxzZSB7XG4gICAgICB1cGRhdGVkUGF0aCArPSBwYXJ0O1xuICAgIH1cbiAgfSk7XG5cbiAgLy8gR2V0IHRoZSBmaWVsZCBhbmQgcmV0dXJuIGl0cyBsZW5ndGhcbiAgY29uc3QgdGFyZ2V0UGF0aCA9IFV0aWxzLmludGVycG9sYXRlU3RyaW5nKHVwZGF0ZWRQYXRoLCBkYXRhKTtcbiAgY29uc3QgdGFyZ2V0ID0gZ2V0U291cmNlRGF0YShkYXRhLCB0YXJnZXRQYXRoKTtcbiAgcmV0dXJuIHRhcmdldD8ubGVuZ3RoIHx8IDA7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBnZXRMZW5ndGg7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLElBQUFBLG1CQUFBLEdBQUFDLE9BQUE7QUFHQSxJQUFBQyw2QkFBQSxHQUFBQyxzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsY0FBQSxHQUFBRCxzQkFBQSxDQUFBRixPQUFBO0FBQWtELFNBQUFFLHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBTGxEOztBQUdBOztBQUlBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1HLFNBQVMsR0FBR0EsQ0FBQ0MsTUFBTSxFQUFFQyxJQUFJLEtBQUs7RUFDbEMsSUFBSSxDQUFDRCxNQUFNLElBQUksQ0FBQ0MsSUFBSSxFQUFFO0lBQ3BCLE9BQU8sSUFBSTtFQUNiOztFQUVBO0VBQ0EsTUFBTUMsU0FBUyxHQUFHRixNQUFNLENBQUNHLE1BQU0sQ0FBQ0MsS0FBSyxDQUFDLEdBQUcsQ0FBQztFQUMxQyxJQUFJQyxXQUFXLEdBQUcsRUFBRTtFQUNwQkgsU0FBUyxDQUFDSSxPQUFPLENBQUVDLElBQUksSUFBSztJQUMxQixJQUFJRixXQUFXLEtBQUssRUFBRSxFQUFFO01BQ3RCQSxXQUFXLElBQUksR0FBRztJQUNwQjtJQUNBLElBQUlFLElBQUksQ0FBQ0MsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssSUFBSSxFQUFFO01BQzNCLE1BQU1DLGNBQWMsR0FBR0YsSUFBSSxDQUFDQyxLQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO01BQ3hDLE1BQU1FLFdBQVcsR0FBRyxJQUFBQyxxQ0FBNEIsRUFBQ0YsY0FBYyxFQUFFUixJQUFJLENBQUM7TUFDdEVJLFdBQVcsT0FBQU8sTUFBQSxDQUFPSCxjQUFjLE9BQUFHLE1BQUEsQ0FBSUYsV0FBVyxNQUFHO0lBQ3BELENBQUMsTUFBTTtNQUNMTCxXQUFXLElBQUlFLElBQUk7SUFDckI7RUFDRixDQUFDLENBQUM7O0VBRUY7RUFDQSxNQUFNTSxVQUFVLEdBQUdDLHlCQUFLLENBQUNDLGlCQUFpQixDQUFDVixXQUFXLEVBQUVKLElBQUksQ0FBQztFQUM3RCxNQUFNRSxNQUFNLEdBQUcsSUFBQWEsc0JBQWEsRUFBQ2YsSUFBSSxFQUFFWSxVQUFVLENBQUM7RUFDOUMsT0FBTyxDQUFBVixNQUFNLGFBQU5BLE1BQU0sdUJBQU5BLE1BQU0sQ0FBRWMsTUFBTSxLQUFJLENBQUM7QUFDNUIsQ0FBQztBQUFDLElBQUFDLFFBQUEsR0FBQUMsT0FBQSxDQUFBckIsT0FBQSxHQUVhQyxTQUFTIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,90 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _getLength = _interopRequireDefault(require("./getLength"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('Utils.Operate.getLength', () => {
|
|
6
|
-
it('returns null if config is not defined', () => {
|
|
7
|
-
expect((0, _getLength.default)(null, {})).toEqual(null);
|
|
8
|
-
});
|
|
9
|
-
it('returns null if data is not defined', () => {
|
|
10
|
-
expect((0, _getLength.default)({}, null)).toEqual(null);
|
|
11
|
-
});
|
|
12
|
-
it('returns the length of a top level string', () => {
|
|
13
|
-
const CONFIG = {
|
|
14
|
-
target: 'alpha'
|
|
15
|
-
};
|
|
16
|
-
const DATA = {
|
|
17
|
-
alpha: 'abcdef'
|
|
18
|
-
};
|
|
19
|
-
expect((0, _getLength.default)(CONFIG, DATA)).toEqual(6);
|
|
20
|
-
});
|
|
21
|
-
it('returns the length of a top level array', () => {
|
|
22
|
-
const CONFIG = {
|
|
23
|
-
target: 'alpha'
|
|
24
|
-
};
|
|
25
|
-
const DATA = {
|
|
26
|
-
alpha: [{
|
|
27
|
-
test: 'test'
|
|
28
|
-
}, {
|
|
29
|
-
test: 'test'
|
|
30
|
-
}, {
|
|
31
|
-
test: 'test'
|
|
32
|
-
}, {
|
|
33
|
-
test: 'test'
|
|
34
|
-
}]
|
|
35
|
-
};
|
|
36
|
-
expect((0, _getLength.default)(CONFIG, DATA)).toEqual(4);
|
|
37
|
-
});
|
|
38
|
-
it('returns 0 if the field cannot be found', () => {
|
|
39
|
-
const CONFIG = {
|
|
40
|
-
target: 'alpha'
|
|
41
|
-
};
|
|
42
|
-
const DATA = {
|
|
43
|
-
beta: [{
|
|
44
|
-
test: 'test'
|
|
45
|
-
}, {
|
|
46
|
-
test: 'test'
|
|
47
|
-
}, {
|
|
48
|
-
test: 'test'
|
|
49
|
-
}, {
|
|
50
|
-
test: 'test'
|
|
51
|
-
}]
|
|
52
|
-
};
|
|
53
|
-
expect((0, _getLength.default)(CONFIG, DATA)).toEqual(0);
|
|
54
|
-
});
|
|
55
|
-
it('returns the length of a field not on the top level', () => {
|
|
56
|
-
const CONFIG = {
|
|
57
|
-
target: 'alpha.beta'
|
|
58
|
-
};
|
|
59
|
-
const DATA = {
|
|
60
|
-
alphaActiveId: 3,
|
|
61
|
-
alpha: {
|
|
62
|
-
beta: 'qwerty'
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
expect((0, _getLength.default)(CONFIG, DATA)).toEqual(6);
|
|
66
|
-
});
|
|
67
|
-
it('returns the length of an array nested under an array', () => {
|
|
68
|
-
const CONFIG = {
|
|
69
|
-
target: 'alpha[].beta'
|
|
70
|
-
};
|
|
71
|
-
const DATA = {
|
|
72
|
-
alphaActiveId: 3,
|
|
73
|
-
alpha: [{
|
|
74
|
-
id: 1,
|
|
75
|
-
beta: ['test']
|
|
76
|
-
}, {
|
|
77
|
-
id: 2,
|
|
78
|
-
beta: ['test', 'test']
|
|
79
|
-
}, {
|
|
80
|
-
id: 3,
|
|
81
|
-
beta: ['test', 'test', 'test']
|
|
82
|
-
}, {
|
|
83
|
-
id: 4,
|
|
84
|
-
beta: ['test', 'test', 'test', 'test']
|
|
85
|
-
}]
|
|
86
|
-
};
|
|
87
|
-
expect((0, _getLength.default)(CONFIG, DATA)).toEqual(3);
|
|
88
|
-
});
|
|
89
|
-
});
|
|
90
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZ2V0TGVuZ3RoIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJkZXNjcmliZSIsIml0IiwiZXhwZWN0IiwiZ2V0TGVuZ3RoIiwidG9FcXVhbCIsIkNPTkZJRyIsInRhcmdldCIsIkRBVEEiLCJhbHBoYSIsInRlc3QiLCJiZXRhIiwiYWxwaGFBY3RpdmVJZCIsImlkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL09wZXJhdGUvZ2V0TGVuZ3RoLnRlc3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGdldExlbmd0aCBmcm9tICcuL2dldExlbmd0aCc7XG5cbmRlc2NyaWJlKCdVdGlscy5PcGVyYXRlLmdldExlbmd0aCcsICgpID0+IHtcblxuICBpdCgncmV0dXJucyBudWxsIGlmIGNvbmZpZyBpcyBub3QgZGVmaW5lZCcsICgpID0+IHtcbiAgICBleHBlY3QoZ2V0TGVuZ3RoKG51bGwsIHt9KSkudG9FcXVhbChudWxsKTtcbiAgfSk7XG5cbiAgaXQoJ3JldHVybnMgbnVsbCBpZiBkYXRhIGlzIG5vdCBkZWZpbmVkJywgKCkgPT4ge1xuICAgIGV4cGVjdChnZXRMZW5ndGgoe30sIG51bGwpKS50b0VxdWFsKG51bGwpO1xuICB9KTtcblxuICBpdCgncmV0dXJucyB0aGUgbGVuZ3RoIG9mIGEgdG9wIGxldmVsIHN0cmluZycsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7XG4gICAgICB0YXJnZXQ6ICdhbHBoYScsXG4gICAgfTtcbiAgICBjb25zdCBEQVRBID0ge1xuICAgICAgYWxwaGE6ICdhYmNkZWYnLFxuICAgIH07XG4gICAgZXhwZWN0KGdldExlbmd0aChDT05GSUcsIERBVEEpKS50b0VxdWFsKDYpO1xuICB9KTtcblxuICBpdCgncmV0dXJucyB0aGUgbGVuZ3RoIG9mIGEgdG9wIGxldmVsIGFycmF5JywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHtcbiAgICAgIHRhcmdldDogJ2FscGhhJyxcbiAgICB9O1xuICAgIGNvbnN0IERBVEEgPSB7XG4gICAgICBhbHBoYTogW1xuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogJ3Rlc3QnLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogJ3Rlc3QnLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogJ3Rlc3QnLFxuICAgICAgICB9LFxuICAgICAgICB7XG4gICAgICAgICAgdGVzdDogJ3Rlc3QnLFxuICAgICAgICB9LFxuICAgICAgXSxcbiAgICB9O1xuICAgIGV4cGVjdChnZXRMZW5ndGgoQ09ORklHLCBEQVRBKSkudG9FcXVhbCg0KTtcbiAgfSk7XG5cbiAgaXQoJ3JldHVybnMgMCBpZiB0aGUgZmllbGQgY2Fubm90IGJlIGZvdW5kJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHtcbiAgICAgICAgdGFyZ2V0OiAnYWxwaGEnLFxuICAgICAgfTtcbiAgICAgIGNvbnN0IERBVEEgPSB7XG4gICAgICAgIGJldGE6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0ZXN0OiAndGVzdCcsXG4gICAgICAgICAgfSxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0ZXN0OiAndGVzdCcsXG4gICAgICAgICAgfSxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0ZXN0OiAndGVzdCcsXG4gICAgICAgICAgfSxcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0ZXN0OiAndGVzdCcsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH07XG4gICAgICBleHBlY3QoZ2V0TGVuZ3RoKENPTkZJRywgREFUQSkpLnRvRXF1YWwoMCk7XG4gIH0pO1xuXG4gIGl0KCdyZXR1cm5zIHRoZSBsZW5ndGggb2YgYSBmaWVsZCBub3Qgb24gdGhlIHRvcCBsZXZlbCcsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7XG4gICAgICAgIHRhcmdldDogJ2FscGhhLmJldGEnLFxuICAgICAgfTtcbiAgICAgIGNvbnN0IERBVEEgPSB7XG4gICAgICAgIGFscGhhQWN0aXZlSWQ6IDMsXG4gICAgICAgIGFscGhhOiB7XG4gICAgICAgICAgICBiZXRhOiAncXdlcnR5J1xuICAgICAgICB9LFxuICAgICAgfTtcbiAgICAgIGV4cGVjdChnZXRMZW5ndGgoQ09ORklHLCBEQVRBKSkudG9FcXVhbCg2KTtcbiAgfSk7XG5cbiAgaXQoJ3JldHVybnMgdGhlIGxlbmd0aCBvZiBhbiBhcnJheSBuZXN0ZWQgdW5kZXIgYW4gYXJyYXknLCAoKSA9PiB7XG4gICAgY29uc3QgQ09ORklHID0ge1xuICAgICAgICB0YXJnZXQ6ICdhbHBoYVtdLmJldGEnLFxuICAgICAgfTtcbiAgICAgIGNvbnN0IERBVEEgPSB7XG4gICAgICAgIGFscGhhQWN0aXZlSWQ6IDMsXG4gICAgICAgIGFscGhhOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgaWQ6IDEsXG4gICAgICAgICAgICBiZXRhOiBbJ3Rlc3QnXSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIGlkOiAyLFxuICAgICAgICAgICAgYmV0YTogWyd0ZXN0JywgJ3Rlc3QnXSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIGlkOiAzLFxuICAgICAgICAgICAgYmV0YTogWyd0ZXN0JywgJ3Rlc3QnLCAndGVzdCddLFxuICAgICAgICAgIH0sXG4gICAgICAgICAge1xuICAgICAgICAgICAgaWQ6IDQsXG4gICAgICAgICAgICBiZXRhOiBbJ3Rlc3QnLCAndGVzdCcsICd0ZXN0JywgJ3Rlc3QnXSxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgfTtcbiAgICAgIGV4cGVjdChnZXRMZW5ndGgoQ09ORklHLCBEQVRBKSkudG9FcXVhbCgzKTtcbiAgfSk7XG5cbn0pOyJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxVQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBb0MsU0FB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
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _runPageOperations = _interopRequireDefault(require("./runPageOperations"));
|
|
8
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
-
const Operate = {
|
|
10
|
-
runPageOperations: _runPageOperations.default
|
|
11
|
-
};
|
|
12
|
-
var _default = exports.default = Operate;
|
|
13
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcnVuUGFnZU9wZXJhdGlvbnMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIk9wZXJhdGUiLCJydW5QYWdlT3BlcmF0aW9ucyIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9PcGVyYXRlL2luZGV4LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBydW5QYWdlT3BlcmF0aW9ucyBmcm9tICcuL3J1blBhZ2VPcGVyYXRpb25zJztcblxuY29uc3QgT3BlcmF0ZSA9IHtcbiAgcnVuUGFnZU9wZXJhdGlvbnMsXG59O1xuXG5leHBvcnQgZGVmYXVsdCBPcGVyYXRlO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQSxJQUFBQSxrQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQW9ELFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRXBELE1BQU1HLE9BQU8sR0FBRztFQUNkQyxpQkFBaUIsRUFBakJBO0FBQ0YsQ0FBQztBQUFDLElBQUFDLFFBQUEsR0FBQUMsT0FBQSxDQUFBSixPQUFBLEdBRWFDLE9BQU8iLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
8
|
-
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
9
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
|
-
// Global imports.
|
|
11
|
-
|
|
12
|
-
// Local imports.
|
|
13
|
-
|
|
14
|
-
/**
|
|
15
|
-
* Simple operation to call the page's onChange handler with a specific value
|
|
16
|
-
* and name. Supports getting a value from an interpolated field string.
|
|
17
|
-
* @param {object} config The operation config.
|
|
18
|
-
* @param {object} data The page's formData.
|
|
19
|
-
* @param {function} onChange The page's onChange handler.
|
|
20
|
-
*/
|
|
21
|
-
const persistValueInFormData = (config, data, onChange) => {
|
|
22
|
-
let value;
|
|
23
|
-
if (config !== null && config !== void 0 && config.field) {
|
|
24
|
-
const fieldPath = _copReactComponents.Utils.interpolateString(config.field, data);
|
|
25
|
-
value = (0, _getSourceData.default)(data, fieldPath);
|
|
26
|
-
} else {
|
|
27
|
-
value = config === null || config === void 0 ? void 0 : config.value;
|
|
28
|
-
}
|
|
29
|
-
/* eslint-disable object-shorthand */
|
|
30
|
-
if (value != null && config.name && data[config.name] !== value) {
|
|
31
|
-
onChange({
|
|
32
|
-
target: {
|
|
33
|
-
name: config.name,
|
|
34
|
-
value: value
|
|
35
|
-
}
|
|
36
|
-
});
|
|
37
|
-
}
|
|
38
|
-
};
|
|
39
|
-
var _default = exports.default = persistValueInFormData;
|
|
40
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY29wUmVhY3RDb21wb25lbnRzIiwicmVxdWlyZSIsIl9nZXRTb3VyY2VEYXRhIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsInBlcnNpc3RWYWx1ZUluRm9ybURhdGEiLCJjb25maWciLCJkYXRhIiwib25DaGFuZ2UiLCJ2YWx1ZSIsImZpZWxkIiwiZmllbGRQYXRoIiwiVXRpbHMiLCJpbnRlcnBvbGF0ZVN0cmluZyIsImdldFNvdXJjZURhdGEiLCJuYW1lIiwidGFyZ2V0IiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL09wZXJhdGUvcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YS5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBHbG9iYWwgaW1wb3J0cy5cbmltcG9ydCB7IFV0aWxzIH0gZnJvbSAnQHVraG9tZW9mZmljZS9jb3AtcmVhY3QtY29tcG9uZW50cyc7XG5cbi8vIExvY2FsIGltcG9ydHMuXG5pbXBvcnQgZ2V0U291cmNlRGF0YSBmcm9tICcuLi9EYXRhL2dldFNvdXJjZURhdGEnO1xuXG4vKipcbiAqIFNpbXBsZSBvcGVyYXRpb24gdG8gY2FsbCB0aGUgcGFnZSdzIG9uQ2hhbmdlIGhhbmRsZXIgd2l0aCBhIHNwZWNpZmljIHZhbHVlXG4gKiBhbmQgbmFtZS4gU3VwcG9ydHMgZ2V0dGluZyBhIHZhbHVlIGZyb20gYW4gaW50ZXJwb2xhdGVkIGZpZWxkIHN0cmluZy5cbiAqIEBwYXJhbSB7b2JqZWN0fSBjb25maWcgVGhlIG9wZXJhdGlvbiBjb25maWcuXG4gKiBAcGFyYW0ge29iamVjdH0gZGF0YSBUaGUgcGFnZSdzIGZvcm1EYXRhLlxuICogQHBhcmFtIHtmdW5jdGlvbn0gb25DaGFuZ2UgVGhlIHBhZ2UncyBvbkNoYW5nZSBoYW5kbGVyLlxuICovXG5jb25zdCBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhID0gKGNvbmZpZywgZGF0YSwgb25DaGFuZ2UpID0+IHtcbiAgbGV0IHZhbHVlO1xuICBpZiAoY29uZmlnPy5maWVsZCkge1xuICAgIGNvbnN0IGZpZWxkUGF0aCA9IFV0aWxzLmludGVycG9sYXRlU3RyaW5nKGNvbmZpZy5maWVsZCwgZGF0YSk7XG4gICAgdmFsdWUgPSBnZXRTb3VyY2VEYXRhKGRhdGEsIGZpZWxkUGF0aCk7XG4gIH0gZWxzZSB7XG4gICAgdmFsdWUgPSBjb25maWc/LnZhbHVlO1xuICB9XG4gIC8qIGVzbGludC1kaXNhYmxlIG9iamVjdC1zaG9ydGhhbmQgKi9cbiAgaWYgKHZhbHVlICE9IG51bGwgJiYgY29uZmlnLm5hbWUgJiYgZGF0YVtjb25maWcubmFtZV0gIT09IHZhbHVlKSB7XG4gICAgb25DaGFuZ2UoeyB0YXJnZXQ6IHsgbmFtZTogY29uZmlnLm5hbWUsIHZhbHVlOiB2YWx1ZSB9fSk7XG4gIH1cbn07XG5cbmV4cG9ydCBkZWZhdWx0IHBlcnNpc3RWYWx1ZUluRm9ybURhdGE7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLElBQUFBLG1CQUFBLEdBQUFDLE9BQUE7QUFHQSxJQUFBQyxjQUFBLEdBQUFDLHNCQUFBLENBQUFGLE9BQUE7QUFBa0QsU0FBQUUsdUJBQUFDLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFKbEQ7O0FBR0E7O0FBR0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNRyxzQkFBc0IsR0FBR0EsQ0FBQ0MsTUFBTSxFQUFFQyxJQUFJLEVBQUVDLFFBQVEsS0FBSztFQUN6RCxJQUFJQyxLQUFLO0VBQ1QsSUFBSUgsTUFBTSxhQUFOQSxNQUFNLGVBQU5BLE1BQU0sQ0FBRUksS0FBSyxFQUFFO0lBQ2pCLE1BQU1DLFNBQVMsR0FBR0MseUJBQUssQ0FBQ0MsaUJBQWlCLENBQUNQLE1BQU0sQ0FBQ0ksS0FBSyxFQUFFSCxJQUFJLENBQUM7SUFDN0RFLEtBQUssR0FBRyxJQUFBSyxzQkFBYSxFQUFDUCxJQUFJLEVBQUVJLFNBQVMsQ0FBQztFQUN4QyxDQUFDLE1BQU07SUFDTEYsS0FBSyxHQUFHSCxNQUFNLGFBQU5BLE1BQU0sdUJBQU5BLE1BQU0sQ0FBRUcsS0FBSztFQUN2QjtFQUNBO0VBQ0EsSUFBSUEsS0FBSyxJQUFJLElBQUksSUFBSUgsTUFBTSxDQUFDUyxJQUFJLElBQUlSLElBQUksQ0FBQ0QsTUFBTSxDQUFDUyxJQUFJLENBQUMsS0FBS04sS0FBSyxFQUFFO0lBQy9ERCxRQUFRLENBQUM7TUFBRVEsTUFBTSxFQUFFO1FBQUVELElBQUksRUFBRVQsTUFBTSxDQUFDUyxJQUFJO1FBQUVOLEtBQUssRUFBRUE7TUFBTTtJQUFDLENBQUMsQ0FBQztFQUMxRDtBQUNGLENBQUM7QUFBQyxJQUFBUSxRQUFBLEdBQUFDLE9BQUEsQ0FBQWQsT0FBQSxHQUVhQyxzQkFBc0IiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _persistValueInFormData = _interopRequireDefault(require("./persistValueInFormData"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('Utils.Operate.persistValueInFormData', () => {
|
|
6
|
-
let DATA = {
|
|
7
|
-
alpha: 'abc',
|
|
8
|
-
beta: 'charlie',
|
|
9
|
-
charlie: '123'
|
|
10
|
-
};
|
|
11
|
-
let ON_CHANGE_COUNT = 0;
|
|
12
|
-
const ON_CHANGE = _ref => {
|
|
13
|
-
let {
|
|
14
|
-
target
|
|
15
|
-
} = _ref;
|
|
16
|
-
DATA[target.name] = target.value;
|
|
17
|
-
ON_CHANGE_COUNT += 1;
|
|
18
|
-
};
|
|
19
|
-
beforeEach(() => {
|
|
20
|
-
DATA = {
|
|
21
|
-
alpha: 'abc',
|
|
22
|
-
beta: 'charlie',
|
|
23
|
-
charlie: '123'
|
|
24
|
-
};
|
|
25
|
-
ON_CHANGE_COUNT = 0;
|
|
26
|
-
});
|
|
27
|
-
it('Should trigger a change correctly', () => {
|
|
28
|
-
const CONFIG = {
|
|
29
|
-
name: 'alpha',
|
|
30
|
-
value: 'bcd'
|
|
31
|
-
};
|
|
32
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
33
|
-
expect(DATA).toEqual({
|
|
34
|
-
alpha: 'bcd',
|
|
35
|
-
beta: 'charlie',
|
|
36
|
-
charlie: '123'
|
|
37
|
-
});
|
|
38
|
-
expect(ON_CHANGE_COUNT).toEqual(1);
|
|
39
|
-
});
|
|
40
|
-
it('Should trigger a change correctly with boolean false', () => {
|
|
41
|
-
const CONFIG = {
|
|
42
|
-
name: 'alpha',
|
|
43
|
-
value: false
|
|
44
|
-
};
|
|
45
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
46
|
-
expect(DATA).toEqual({
|
|
47
|
-
alpha: false,
|
|
48
|
-
beta: 'charlie',
|
|
49
|
-
charlie: '123'
|
|
50
|
-
});
|
|
51
|
-
expect(ON_CHANGE_COUNT).toEqual(1);
|
|
52
|
-
});
|
|
53
|
-
it('Should not call onChange when value is unchanged', () => {
|
|
54
|
-
const CONFIG = {
|
|
55
|
-
name: 'alpha',
|
|
56
|
-
value: 'abc'
|
|
57
|
-
};
|
|
58
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
59
|
-
expect(DATA).toEqual({
|
|
60
|
-
alpha: 'abc',
|
|
61
|
-
beta: 'charlie',
|
|
62
|
-
charlie: '123'
|
|
63
|
-
});
|
|
64
|
-
expect(ON_CHANGE_COUNT).toEqual(0);
|
|
65
|
-
});
|
|
66
|
-
it('Should not call onChange if no value or field is given', () => {
|
|
67
|
-
const CONFIG = {
|
|
68
|
-
name: 'alpha'
|
|
69
|
-
};
|
|
70
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
71
|
-
expect(DATA).toEqual({
|
|
72
|
-
alpha: 'abc',
|
|
73
|
-
beta: 'charlie',
|
|
74
|
-
charlie: '123'
|
|
75
|
-
});
|
|
76
|
-
expect(ON_CHANGE_COUNT).toEqual(0);
|
|
77
|
-
});
|
|
78
|
-
it('Should not call onChange if no name is given', () => {
|
|
79
|
-
const CONFIG = {
|
|
80
|
-
field: 'charlie'
|
|
81
|
-
};
|
|
82
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
83
|
-
expect(DATA).toEqual({
|
|
84
|
-
alpha: 'abc',
|
|
85
|
-
beta: 'charlie',
|
|
86
|
-
charlie: '123'
|
|
87
|
-
});
|
|
88
|
-
expect(ON_CHANGE_COUNT).toEqual(0);
|
|
89
|
-
});
|
|
90
|
-
it('Should not call onChange if field cannot be found', () => {
|
|
91
|
-
const CONFIG = {
|
|
92
|
-
name: 'alpha',
|
|
93
|
-
field: 'delta'
|
|
94
|
-
};
|
|
95
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
96
|
-
expect(DATA).toEqual({
|
|
97
|
-
alpha: 'abc',
|
|
98
|
-
beta: 'charlie',
|
|
99
|
-
charlie: '123'
|
|
100
|
-
});
|
|
101
|
-
expect(ON_CHANGE_COUNT).toEqual(0);
|
|
102
|
-
});
|
|
103
|
-
it('Should correctly interpolate a field value', () => {
|
|
104
|
-
// eslint-disable-next-line no-template-curly-in-string
|
|
105
|
-
const CONFIG = {
|
|
106
|
-
name: 'alpha',
|
|
107
|
-
field: '${beta}'
|
|
108
|
-
};
|
|
109
|
-
(0, _persistValueInFormData.default)(CONFIG, DATA, ON_CHANGE);
|
|
110
|
-
expect(DATA).toEqual({
|
|
111
|
-
alpha: '123',
|
|
112
|
-
beta: 'charlie',
|
|
113
|
-
charlie: '123'
|
|
114
|
-
});
|
|
115
|
-
expect(ON_CHANGE_COUNT).toEqual(1);
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJEQVRBIiwiYWxwaGEiLCJiZXRhIiwiY2hhcmxpZSIsIk9OX0NIQU5HRV9DT1VOVCIsIk9OX0NIQU5HRSIsIl9yZWYiLCJ0YXJnZXQiLCJuYW1lIiwidmFsdWUiLCJiZWZvcmVFYWNoIiwiaXQiLCJDT05GSUciLCJwZXJzaXN0VmFsdWVJbkZvcm1EYXRhIiwiZXhwZWN0IiwidG9FcXVhbCIsImZpZWxkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL09wZXJhdGUvcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YS50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhIGZyb20gJy4vcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YSc7XG5cbmRlc2NyaWJlKCdVdGlscy5PcGVyYXRlLnBlcnNpc3RWYWx1ZUluRm9ybURhdGEnLCAoKSA9PiB7XG4gIGxldCBEQVRBID0geyBhbHBoYTogJ2FiYycsIGJldGE6ICdjaGFybGllJywgY2hhcmxpZTogJzEyMycgfTtcbiAgbGV0IE9OX0NIQU5HRV9DT1VOVCA9IDA7XG5cbiAgY29uc3QgT05fQ0hBTkdFID0gKHsgdGFyZ2V0IH0pID0+IHtcbiAgICBEQVRBW3RhcmdldC5uYW1lXSA9IHRhcmdldC52YWx1ZTtcbiAgICBPTl9DSEFOR0VfQ09VTlQgKz0gMTtcbiAgfTtcblxuICBiZWZvcmVFYWNoKCgpID0+IHtcbiAgICBEQVRBID0geyBhbHBoYTogJ2FiYycsIGJldGE6ICdjaGFybGllJywgY2hhcmxpZTogJzEyMycgfTtcbiAgICBPTl9DSEFOR0VfQ09VTlQgPSAwO1xuICB9KTtcblxuXG4gIGl0KCdTaG91bGQgdHJpZ2dlciBhIGNoYW5nZSBjb3JyZWN0bHknLCAoKSA9PiB7XG4gICAgY29uc3QgQ09ORklHID0geyBuYW1lOiAnYWxwaGEnLCB2YWx1ZTogJ2JjZCcgfTtcbiAgICBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhKENPTkZJRywgREFUQSwgT05fQ0hBTkdFKTtcbiAgICBleHBlY3QoREFUQSkudG9FcXVhbCh7IGFscGhhOiAnYmNkJywgYmV0YTogJ2NoYXJsaWUnLCBjaGFybGllOiAnMTIzJyB9KTtcbiAgICBleHBlY3QoT05fQ0hBTkdFX0NPVU5UKS50b0VxdWFsKDEpO1xuICB9KTtcblxuICBpdCgnU2hvdWxkIHRyaWdnZXIgYSBjaGFuZ2UgY29ycmVjdGx5IHdpdGggYm9vbGVhbiBmYWxzZScsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IG5hbWU6ICdhbHBoYScsIHZhbHVlOiBmYWxzZSB9O1xuICAgIHBlcnNpc3RWYWx1ZUluRm9ybURhdGEoQ09ORklHLCBEQVRBLCBPTl9DSEFOR0UpO1xuICAgIGV4cGVjdChEQVRBKS50b0VxdWFsKHsgYWxwaGE6IGZhbHNlLCBiZXRhOiAnY2hhcmxpZScsIGNoYXJsaWU6ICcxMjMnIH0pO1xuICAgIGV4cGVjdChPTl9DSEFOR0VfQ09VTlQpLnRvRXF1YWwoMSk7XG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgbm90IGNhbGwgb25DaGFuZ2Ugd2hlbiB2YWx1ZSBpcyB1bmNoYW5nZWQnLCAoKSA9PiB7XG4gICAgY29uc3QgQ09ORklHID0geyBuYW1lOiAnYWxwaGEnLCB2YWx1ZTogJ2FiYycgfTtcbiAgICBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhKENPTkZJRywgREFUQSwgT05fQ0hBTkdFKTtcbiAgICBleHBlY3QoREFUQSkudG9FcXVhbCh7IGFscGhhOiAnYWJjJywgYmV0YTogJ2NoYXJsaWUnLCBjaGFybGllOiAnMTIzJyB9KTtcbiAgICBleHBlY3QoT05fQ0hBTkdFX0NPVU5UKS50b0VxdWFsKDApO1xuICB9KTtcblxuICBpdCgnU2hvdWxkIG5vdCBjYWxsIG9uQ2hhbmdlIGlmIG5vIHZhbHVlIG9yIGZpZWxkIGlzIGdpdmVuJywgKCkgPT4ge1xuICAgIGNvbnN0IENPTkZJRyA9IHsgbmFtZTogJ2FscGhhJyB9O1xuICAgIHBlcnNpc3RWYWx1ZUluRm9ybURhdGEoQ09ORklHLCBEQVRBLCBPTl9DSEFOR0UpO1xuICAgIGV4cGVjdChEQVRBKS50b0VxdWFsKHsgYWxwaGE6ICdhYmMnLCBiZXRhOiAnY2hhcmxpZScsIGNoYXJsaWU6ICcxMjMnIH0pO1xuICAgIGV4cGVjdChPTl9DSEFOR0VfQ09VTlQpLnRvRXF1YWwoMCk7XG4gIH0pO1xuXG4gIGl0KCdTaG91bGQgbm90IGNhbGwgb25DaGFuZ2UgaWYgbm8gbmFtZSBpcyBnaXZlbicsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IGZpZWxkOiAnY2hhcmxpZScgfTtcbiAgICBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhKENPTkZJRywgREFUQSwgT05fQ0hBTkdFKTtcbiAgICBleHBlY3QoREFUQSkudG9FcXVhbCh7IGFscGhhOiAnYWJjJywgYmV0YTogJ2NoYXJsaWUnLCBjaGFybGllOiAnMTIzJyB9KTtcbiAgICBleHBlY3QoT05fQ0hBTkdFX0NPVU5UKS50b0VxdWFsKDApO1xuICB9KTtcblxuICBpdCgnU2hvdWxkIG5vdCBjYWxsIG9uQ2hhbmdlIGlmIGZpZWxkIGNhbm5vdCBiZSBmb3VuZCcsICgpID0+IHtcbiAgICBjb25zdCBDT05GSUcgPSB7IG5hbWU6ICdhbHBoYScsIGZpZWxkOiAnZGVsdGEnIH07XG4gICAgcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YShDT05GSUcsIERBVEEsIE9OX0NIQU5HRSk7XG4gICAgZXhwZWN0KERBVEEpLnRvRXF1YWwoeyBhbHBoYTogJ2FiYycsIGJldGE6ICdjaGFybGllJywgY2hhcmxpZTogJzEyMycgfSk7XG4gICAgZXhwZWN0KE9OX0NIQU5HRV9DT1VOVCkudG9FcXVhbCgwKTtcbiAgfSk7XG5cblxuICBpdCgnU2hvdWxkIGNvcnJlY3RseSBpbnRlcnBvbGF0ZSBhIGZpZWxkIHZhbHVlJywgKCkgPT4ge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBuby10ZW1wbGF0ZS1jdXJseS1pbi1zdHJpbmdcbiAgICBjb25zdCBDT05GSUcgPSB7IG5hbWU6ICdhbHBoYScsIGZpZWxkOiAnJHtiZXRhfScgfTtcbiAgICBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhKENPTkZJRywgREFUQSwgT05fQ0hBTkdFKTtcbiAgICBleHBlY3QoREFUQSkudG9FcXVhbCh7IGFscGhhOiAnMTIzJywgYmV0YTogJ2NoYXJsaWUnLCBjaGFybGllOiAnMTIzJyB9KTtcbiAgICBleHBlY3QoT05fQ0hBTkdFX0NPVU5UKS50b0VxdWFsKDEpO1xuICB9KTtcblxufSk7XG4iXSwibWFwcGluZ3MiOiI7O0FBQUEsSUFBQUEsdUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUE4RCxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUU5REcsUUFBUSxDQUFDLHNDQUFzQyxFQUFFLE1BQU07RUFDckQsSUFBSUMsSUFBSSxHQUFHO0lBQUVDLEtBQUssRUFBRSxLQUFLO0lBQUVDLElBQUksRUFBRSxTQUFTO0lBQUVDLE9BQU8sRUFBRTtFQUFNLENBQUM7RUFDNUQsSUFBSUMsZUFBZSxHQUFHLENBQUM7RUFFdkIsTUFBTUMsU0FBUyxHQUFHQyxJQUFBLElBQWdCO0lBQUEsSUFBZjtNQUFFQztJQUFPLENBQUMsR0FBQUQsSUFBQTtJQUMzQk4sSUFBSSxDQUFDTyxNQUFNLENBQUNDLElBQUksQ0FBQyxHQUFHRCxNQUFNLENBQUNFLEtBQUs7SUFDaENMLGVBQWUsSUFBSSxDQUFDO0VBQ3RCLENBQUM7RUFFRE0sVUFBVSxDQUFDLE1BQU07SUFDZlYsSUFBSSxHQUFHO01BQUVDLEtBQUssRUFBRSxLQUFLO01BQUVDLElBQUksRUFBRSxTQUFTO01BQUVDLE9BQU8sRUFBRTtJQUFNLENBQUM7SUFDeERDLGVBQWUsR0FBRyxDQUFDO0VBQ3JCLENBQUMsQ0FBQztFQUdGTyxFQUFFLENBQUMsbUNBQW1DLEVBQUUsTUFBTTtJQUM1QyxNQUFNQyxNQUFNLEdBQUc7TUFBRUosSUFBSSxFQUFFLE9BQU87TUFBRUMsS0FBSyxFQUFFO0lBQU0sQ0FBQztJQUM5QyxJQUFBSSwrQkFBc0IsRUFBQ0QsTUFBTSxFQUFFWixJQUFJLEVBQUVLLFNBQVMsQ0FBQztJQUMvQ1MsTUFBTSxDQUFDZCxJQUFJLENBQUMsQ0FBQ2UsT0FBTyxDQUFDO01BQUVkLEtBQUssRUFBRSxLQUFLO01BQUVDLElBQUksRUFBRSxTQUFTO01BQUVDLE9BQU8sRUFBRTtJQUFNLENBQUMsQ0FBQztJQUN2RVcsTUFBTSxDQUFDVixlQUFlLENBQUMsQ0FBQ1csT0FBTyxDQUFDLENBQUMsQ0FBQztFQUNwQyxDQUFDLENBQUM7RUFFRkosRUFBRSxDQUFDLHNEQUFzRCxFQUFFLE1BQU07SUFDL0QsTUFBTUMsTUFBTSxHQUFHO01BQUVKLElBQUksRUFBRSxPQUFPO01BQUVDLEtBQUssRUFBRTtJQUFNLENBQUM7SUFDOUMsSUFBQUksK0JBQXNCLEVBQUNELE1BQU0sRUFBRVosSUFBSSxFQUFFSyxTQUFTLENBQUM7SUFDL0NTLE1BQU0sQ0FBQ2QsSUFBSSxDQUFDLENBQUNlLE9BQU8sQ0FBQztNQUFFZCxLQUFLLEVBQUUsS0FBSztNQUFFQyxJQUFJLEVBQUUsU0FBUztNQUFFQyxPQUFPLEVBQUU7SUFBTSxDQUFDLENBQUM7SUFDdkVXLE1BQU0sQ0FBQ1YsZUFBZSxDQUFDLENBQUNXLE9BQU8sQ0FBQyxDQUFDLENBQUM7RUFDcEMsQ0FBQyxDQUFDO0VBRUZKLEVBQUUsQ0FBQyxrREFBa0QsRUFBRSxNQUFNO0lBQzNELE1BQU1DLE1BQU0sR0FBRztNQUFFSixJQUFJLEVBQUUsT0FBTztNQUFFQyxLQUFLLEVBQUU7SUFBTSxDQUFDO0lBQzlDLElBQUFJLCtCQUFzQixFQUFDRCxNQUFNLEVBQUVaLElBQUksRUFBRUssU0FBUyxDQUFDO0lBQy9DUyxNQUFNLENBQUNkLElBQUksQ0FBQyxDQUFDZSxPQUFPLENBQUM7TUFBRWQsS0FBSyxFQUFFLEtBQUs7TUFBRUMsSUFBSSxFQUFFLFNBQVM7TUFBRUMsT0FBTyxFQUFFO0lBQU0sQ0FBQyxDQUFDO0lBQ3ZFVyxNQUFNLENBQUNWLGVBQWUsQ0FBQyxDQUFDVyxPQUFPLENBQUMsQ0FBQyxDQUFDO0VBQ3BDLENBQUMsQ0FBQztFQUVGSixFQUFFLENBQUMsd0RBQXdELEVBQUUsTUFBTTtJQUNqRSxNQUFNQyxNQUFNLEdBQUc7TUFBRUosSUFBSSxFQUFFO0lBQVEsQ0FBQztJQUNoQyxJQUFBSywrQkFBc0IsRUFBQ0QsTUFBTSxFQUFFWixJQUFJLEVBQUVLLFNBQVMsQ0FBQztJQUMvQ1MsTUFBTSxDQUFDZCxJQUFJLENBQUMsQ0FBQ2UsT0FBTyxDQUFDO01BQUVkLEtBQUssRUFBRSxLQUFLO01BQUVDLElBQUksRUFBRSxTQUFTO01BQUVDLE9BQU8sRUFBRTtJQUFNLENBQUMsQ0FBQztJQUN2RVcsTUFBTSxDQUFDVixlQUFlLENBQUMsQ0FBQ1csT0FBTyxDQUFDLENBQUMsQ0FBQztFQUNwQyxDQUFDLENBQUM7RUFFRkosRUFBRSxDQUFDLDhDQUE4QyxFQUFFLE1BQU07SUFDdkQsTUFBTUMsTUFBTSxHQUFHO01BQUVJLEtBQUssRUFBRTtJQUFVLENBQUM7SUFDbkMsSUFBQUgsK0JBQXNCLEVBQUNELE1BQU0sRUFBRVosSUFBSSxFQUFFSyxTQUFTLENBQUM7SUFDL0NTLE1BQU0sQ0FBQ2QsSUFBSSxDQUFDLENBQUNlLE9BQU8sQ0FBQztNQUFFZCxLQUFLLEVBQUUsS0FBSztNQUFFQyxJQUFJLEVBQUUsU0FBUztNQUFFQyxPQUFPLEVBQUU7SUFBTSxDQUFDLENBQUM7SUFDdkVXLE1BQU0sQ0FBQ1YsZUFBZSxDQUFDLENBQUNXLE9BQU8sQ0FBQyxDQUFDLENBQUM7RUFDcEMsQ0FBQyxDQUFDO0VBRUZKLEVBQUUsQ0FBQyxtREFBbUQsRUFBRSxNQUFNO0lBQzVELE1BQU1DLE1BQU0sR0FBRztNQUFFSixJQUFJLEVBQUUsT0FBTztNQUFFUSxLQUFLLEVBQUU7SUFBUSxDQUFDO0lBQ2hELElBQUFILCtCQUFzQixFQUFDRCxNQUFNLEVBQUVaLElBQUksRUFBRUssU0FBUyxDQUFDO0lBQy9DUyxNQUFNLENBQUNkLElBQUksQ0FBQyxDQUFDZSxPQUFPLENBQUM7TUFBRWQsS0FBSyxFQUFFLEtBQUs7TUFBRUMsSUFBSSxFQUFFLFNBQVM7TUFBRUMsT0FBTyxFQUFFO0lBQU0sQ0FBQyxDQUFDO0lBQ3ZFVyxNQUFNLENBQUNWLGVBQWUsQ0FBQyxDQUFDVyxPQUFPLENBQUMsQ0FBQyxDQUFDO0VBQ3BDLENBQUMsQ0FBQztFQUdGSixFQUFFLENBQUMsNENBQTRDLEVBQUUsTUFBTTtJQUNyRDtJQUNBLE1BQU1DLE1BQU0sR0FBRztNQUFFSixJQUFJLEVBQUUsT0FBTztNQUFFUSxLQUFLLEVBQUU7SUFBVSxDQUFDO0lBQ2xELElBQUFILCtCQUFzQixFQUFDRCxNQUFNLEVBQUVaLElBQUksRUFBRUssU0FBUyxDQUFDO0lBQy9DUyxNQUFNLENBQUNkLElBQUksQ0FBQyxDQUFDZSxPQUFPLENBQUM7TUFBRWQsS0FBSyxFQUFFLEtBQUs7TUFBRUMsSUFBSSxFQUFFLFNBQVM7TUFBRUMsT0FBTyxFQUFFO0lBQU0sQ0FBQyxDQUFDO0lBQ3ZFVyxNQUFNLENBQUNWLGVBQWUsQ0FBQyxDQUFDVyxPQUFPLENBQUMsQ0FBQyxDQUFDO0VBQ3BDLENBQUMsQ0FBQztBQUVKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
8
|
-
var _checkValueIsTruthy = _interopRequireDefault(require("./checkValueIsTruthy"));
|
|
9
|
-
var _getIndexOfMatchingValueIn = _interopRequireDefault(require("./getIndexOfMatchingValueIn"));
|
|
10
|
-
var _persistValueInFormData = _interopRequireDefault(require("./persistValueInFormData"));
|
|
11
|
-
var _setValueInFormData = _interopRequireDefault(require("./setValueInFormData"));
|
|
12
|
-
var _deleteValueInFormData = _interopRequireDefault(require("./deleteValueInFormData"));
|
|
13
|
-
var _shouldRun = _interopRequireDefault(require("./shouldRun"));
|
|
14
|
-
var _setDataItem = _interopRequireDefault(require("../Data/setDataItem"));
|
|
15
|
-
var _getFirstOf = _interopRequireDefault(require("./getFirstOf"));
|
|
16
|
-
var _getLength = _interopRequireDefault(require("./getLength"));
|
|
17
|
-
var _doesContainValue = _interopRequireDefault(require("./doesContainValue"));
|
|
18
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
19
|
-
// Global imports.
|
|
20
|
-
|
|
21
|
-
// Local imports.
|
|
22
|
-
|
|
23
|
-
const functions = {
|
|
24
|
-
checkValueIsTruthy: _checkValueIsTruthy.default,
|
|
25
|
-
getIndexOfMatchingValueIn: _getIndexOfMatchingValueIn.default,
|
|
26
|
-
doesContainValue: _doesContainValue.default,
|
|
27
|
-
persistValueInFormData: _persistValueInFormData.default,
|
|
28
|
-
setValueInFormData: _setValueInFormData.default,
|
|
29
|
-
deleteValueInFormData: _deleteValueInFormData.default,
|
|
30
|
-
getLength: _getLength.default,
|
|
31
|
-
getFirstOf: _getFirstOf.default
|
|
32
|
-
};
|
|
33
|
-
const doOperation = (config, data, onChange) => {
|
|
34
|
-
const fn = functions[config.function];
|
|
35
|
-
if (typeof fn === 'function') {
|
|
36
|
-
return fn(config, data, onChange);
|
|
37
|
-
}
|
|
38
|
-
return undefined;
|
|
39
|
-
};
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Run operations, specified in a page's config, on formData.
|
|
43
|
-
*
|
|
44
|
-
* The result of an operation will be placed in data according
|
|
45
|
-
* to the operations 'output' string. This string is a dot
|
|
46
|
-
* separated fieldId. If any part of the output doesn't exist,
|
|
47
|
-
* then it is created.
|
|
48
|
-
*
|
|
49
|
-
* The page's onChange handler is passed in here in case any
|
|
50
|
-
* operation needs to persist its value within formData. Normally
|
|
51
|
-
* any operation result only lasts until the page is re-rendered.
|
|
52
|
-
*
|
|
53
|
-
* @param {object} config The config for the page.
|
|
54
|
-
* @param {object} data The page's formData.
|
|
55
|
-
* @param {function} onChange The page's onChange handler.
|
|
56
|
-
* @returns data with the results of any operations included.
|
|
57
|
-
*/
|
|
58
|
-
const runPageOperations = (config, data, onChange) => {
|
|
59
|
-
if (config !== null && config !== void 0 && config.operations && data) {
|
|
60
|
-
config.operations.forEach(op => {
|
|
61
|
-
if ((0, _shouldRun.default)(op.run_when, data)) {
|
|
62
|
-
const result = doOperation(op, data, onChange);
|
|
63
|
-
if (op.output) {
|
|
64
|
-
// Remove array indexers and replace them with dot separators. This ensures that outputPath will
|
|
65
|
-
// work with setDataItem.
|
|
66
|
-
const outputPath = _copReactComponents.Utils.interpolateString(op.output, data).replace('[', '.').replace(']', '');
|
|
67
|
-
(0, _setDataItem.default)(data, outputPath, result);
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
return data;
|
|
73
|
-
};
|
|
74
|
-
var _default = exports.default = runPageOperations;
|
|
75
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY29wUmVhY3RDb21wb25lbnRzIiwicmVxdWlyZSIsIl9jaGVja1ZhbHVlSXNUcnV0aHkiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwiX2dldEluZGV4T2ZNYXRjaGluZ1ZhbHVlSW4iLCJfcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YSIsIl9zZXRWYWx1ZUluRm9ybURhdGEiLCJfZGVsZXRlVmFsdWVJbkZvcm1EYXRhIiwiX3Nob3VsZFJ1biIsIl9zZXREYXRhSXRlbSIsIl9nZXRGaXJzdE9mIiwiX2dldExlbmd0aCIsIl9kb2VzQ29udGFpblZhbHVlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZnVuY3Rpb25zIiwiY2hlY2tWYWx1ZUlzVHJ1dGh5IiwiZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbiIsImRvZXNDb250YWluVmFsdWUiLCJwZXJzaXN0VmFsdWVJbkZvcm1EYXRhIiwic2V0VmFsdWVJbkZvcm1EYXRhIiwiZGVsZXRlVmFsdWVJbkZvcm1EYXRhIiwiZ2V0TGVuZ3RoIiwiZ2V0Rmlyc3RPZiIsImRvT3BlcmF0aW9uIiwiY29uZmlnIiwiZGF0YSIsIm9uQ2hhbmdlIiwiZm4iLCJmdW5jdGlvbiIsInVuZGVmaW5lZCIsInJ1blBhZ2VPcGVyYXRpb25zIiwib3BlcmF0aW9ucyIsImZvckVhY2giLCJvcCIsInNob3VsZFJ1biIsInJ1bl93aGVuIiwicmVzdWx0Iiwib3V0cHV0Iiwib3V0cHV0UGF0aCIsIlV0aWxzIiwiaW50ZXJwb2xhdGVTdHJpbmciLCJyZXBsYWNlIiwic2V0RGF0YUl0ZW0iLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvT3BlcmF0ZS9ydW5QYWdlT3BlcmF0aW9ucy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBHbG9iYWwgaW1wb3J0cy5cbmltcG9ydCB7IFV0aWxzIH0gZnJvbSAnQHVraG9tZW9mZmljZS9jb3AtcmVhY3QtY29tcG9uZW50cyc7XG5cbi8vIExvY2FsIGltcG9ydHMuXG5pbXBvcnQgY2hlY2tWYWx1ZUlzVHJ1dGh5IGZyb20gJy4vY2hlY2tWYWx1ZUlzVHJ1dGh5JztcbmltcG9ydCBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluIGZyb20gJy4vZ2V0SW5kZXhPZk1hdGNoaW5nVmFsdWVJbic7XG5pbXBvcnQgcGVyc2lzdFZhbHVlSW5Gb3JtRGF0YSBmcm9tICcuL3BlcnNpc3RWYWx1ZUluRm9ybURhdGEnO1xuaW1wb3J0IHNldFZhbHVlSW5Gb3JtRGF0YSBmcm9tICcuL3NldFZhbHVlSW5Gb3JtRGF0YSc7XG5pbXBvcnQgZGVsZXRlVmFsdWVJbkZvcm1EYXRhIGZyb20gJy4vZGVsZXRlVmFsdWVJbkZvcm1EYXRhJztcbmltcG9ydCBzaG91bGRSdW4gZnJvbSAnLi9zaG91bGRSdW4nO1xuaW1wb3J0IHNldERhdGFJdGVtIGZyb20gJy4uL0RhdGEvc2V0RGF0YUl0ZW0nO1xuaW1wb3J0IGdldEZpcnN0T2YgZnJvbSAnLi9nZXRGaXJzdE9mJztcbmltcG9ydCBnZXRMZW5ndGggZnJvbSAnLi9nZXRMZW5ndGgnO1xuaW1wb3J0IGRvZXNDb250YWluVmFsdWUgZnJvbSAnLi9kb2VzQ29udGFpblZhbHVlJztcblxuY29uc3QgZnVuY3Rpb25zID0geyBcbiAgY2hlY2tWYWx1ZUlzVHJ1dGh5LFxuICBnZXRJbmRleE9mTWF0Y2hpbmdWYWx1ZUluLFxuICBkb2VzQ29udGFpblZhbHVlLFxuICBwZXJzaXN0VmFsdWVJbkZvcm1EYXRhLFxuICBzZXRWYWx1ZUluRm9ybURhdGEsXG4gIGRlbGV0ZVZhbHVlSW5Gb3JtRGF0YSxcbiAgZ2V0TGVuZ3RoLFxuICBnZXRGaXJzdE9mXG59O1xuXG5jb25zdCBkb09wZXJhdGlvbiA9IChjb25maWcsIGRhdGEsIG9uQ2hhbmdlKSA9PiB7XG4gIGNvbnN0IGZuID0gZnVuY3Rpb25zW2NvbmZpZy5mdW5jdGlvbl07XG4gIGlmICh0eXBlb2YgZm4gPT09ICdmdW5jdGlvbicpIHtcbiAgICByZXR1cm4gZm4oY29uZmlnLCBkYXRhLCBvbkNoYW5nZSk7XG4gIH1cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG5cbi8qKlxuICogUnVuIG9wZXJhdGlvbnMsIHNwZWNpZmllZCBpbiBhIHBhZ2UncyBjb25maWcsIG9uIGZvcm1EYXRhLlxuICogXG4gKiBUaGUgcmVzdWx0IG9mIGFuIG9wZXJhdGlvbiB3aWxsIGJlIHBsYWNlZCBpbiBkYXRhIGFjY29yZGluZ1xuICogdG8gdGhlIG9wZXJhdGlvbnMgJ291dHB1dCcgc3RyaW5nLiBUaGlzIHN0cmluZyBpcyBhIGRvdFxuICogc2VwYXJhdGVkIGZpZWxkSWQuIElmIGFueSBwYXJ0IG9mIHRoZSBvdXRwdXQgZG9lc24ndCBleGlzdCxcbiAqIHRoZW4gaXQgaXMgY3JlYXRlZC5cbiAqIFxuICogVGhlIHBhZ2UncyBvbkNoYW5nZSBoYW5kbGVyIGlzIHBhc3NlZCBpbiBoZXJlIGluIGNhc2UgYW55XG4gKiBvcGVyYXRpb24gbmVlZHMgdG8gcGVyc2lzdCBpdHMgdmFsdWUgd2l0aGluIGZvcm1EYXRhLiBOb3JtYWxseVxuICogYW55IG9wZXJhdGlvbiByZXN1bHQgb25seSBsYXN0cyB1bnRpbCB0aGUgcGFnZSBpcyByZS1yZW5kZXJlZC5cbiAqIFxuICogQHBhcmFtIHtvYmplY3R9IGNvbmZpZyBUaGUgY29uZmlnIGZvciB0aGUgcGFnZS5cbiAqIEBwYXJhbSB7b2JqZWN0fSBkYXRhIFRoZSBwYWdlJ3MgZm9ybURhdGEuXG4gKiBAcGFyYW0ge2Z1bmN0aW9ufSBvbkNoYW5nZSBUaGUgcGFnZSdzIG9uQ2hhbmdlIGhhbmRsZXIuXG4gKiBAcmV0dXJucyBkYXRhIHdpdGggdGhlIHJlc3VsdHMgb2YgYW55IG9wZXJhdGlvbnMgaW5jbHVkZWQuXG4gKi9cbmNvbnN0IHJ1blBhZ2VPcGVyYXRpb25zID0gKGNvbmZpZywgZGF0YSwgb25DaGFuZ2UpID0+IHtcbiAgaWYgKGNvbmZpZz8ub3BlcmF0aW9ucyAmJiBkYXRhKSB7XG4gICAgY29uZmlnLm9wZXJhdGlvbnMuZm9yRWFjaCgob3ApID0+IHtcbiAgICAgIGlmIChzaG91bGRSdW4ob3AucnVuX3doZW4sIGRhdGEpKSB7XG4gICAgICAgIGNvbnN0IHJlc3VsdCA9IGRvT3BlcmF0aW9uKG9wLCBkYXRhLCBvbkNoYW5nZSk7IFxuICAgICAgICBpZiAob3Aub3V0cHV0KSB7XG4gICAgICAgICAgLy8gUmVtb3ZlIGFycmF5IGluZGV4ZXJzIGFuZCByZXBsYWNlIHRoZW0gd2l0aCBkb3Qgc2VwYXJhdG9ycy4gVGhpcyBlbnN1cmVzIHRoYXQgb3V0cHV0UGF0aCB3aWxsXG4gICAgICAgICAgLy8gd29yayB3aXRoIHNldERhdGFJdGVtLlxuICAgICAgICAgIGNvbnN0IG91dHB1dFBhdGggPSBVdGlscy5pbnRlcnBvbGF0ZVN0cmluZyhvcC5vdXRwdXQsIGRhdGEpLnJlcGxhY2UoJ1snLCAnLicpLnJlcGxhY2UoJ10nLCAnJyk7XG4gICAgICAgICAgc2V0RGF0YUl0ZW0oZGF0YSwgb3V0cHV0UGF0aCwgcmVzdWx0KTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pO1xuICB9XG4gIHJldHVybiBkYXRhO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgcnVuUGFnZU9wZXJhdGlvbnM7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLElBQUFBLG1CQUFBLEdBQUFDLE9BQUE7QUFHQSxJQUFBQyxtQkFBQSxHQUFBQyxzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQUcsMEJBQUEsR0FBQUQsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFJLHVCQUFBLEdBQUFGLHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBSyxtQkFBQSxHQUFBSCxzQkFBQSxDQUFBRixPQUFBO0FBQ0EsSUFBQU0sc0JBQUEsR0FBQUosc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFPLFVBQUEsR0FBQUwsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFRLFlBQUEsR0FBQU4sc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFTLFdBQUEsR0FBQVAsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFVLFVBQUEsR0FBQVIsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFXLGlCQUFBLEdBQUFULHNCQUFBLENBQUFGLE9BQUE7QUFBa0QsU0FBQUUsdUJBQUFVLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFibEQ7O0FBR0E7O0FBWUEsTUFBTUcsU0FBUyxHQUFHO0VBQ2hCQyxrQkFBa0IsRUFBbEJBLDJCQUFrQjtFQUNsQkMseUJBQXlCLEVBQXpCQSxrQ0FBeUI7RUFDekJDLGdCQUFnQixFQUFoQkEseUJBQWdCO0VBQ2hCQyxzQkFBc0IsRUFBdEJBLCtCQUFzQjtFQUN0QkMsa0JBQWtCLEVBQWxCQSwyQkFBa0I7RUFDbEJDLHFCQUFxQixFQUFyQkEsOEJBQXFCO0VBQ3JCQyxTQUFTLEVBQVRBLGtCQUFTO0VBQ1RDLFVBQVUsRUFBVkE7QUFDRixDQUFDO0FBRUQsTUFBTUMsV0FBVyxHQUFHQSxDQUFDQyxNQUFNLEVBQUVDLElBQUksRUFBRUMsUUFBUSxLQUFLO0VBQzlDLE1BQU1DLEVBQUUsR0FBR2IsU0FBUyxDQUFDVSxNQUFNLENBQUNJLFFBQVEsQ0FBQztFQUNyQyxJQUFJLE9BQU9ELEVBQUUsS0FBSyxVQUFVLEVBQUU7SUFDNUIsT0FBT0EsRUFBRSxDQUFDSCxNQUFNLEVBQUVDLElBQUksRUFBRUMsUUFBUSxDQUFDO0VBQ25DO0VBQ0EsT0FBT0csU0FBUztBQUNsQixDQUFDOztBQUVEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNQyxpQkFBaUIsR0FBR0EsQ0FBQ04sTUFBTSxFQUFFQyxJQUFJLEVBQUVDLFFBQVEsS0FBSztFQUNwRCxJQUFJRixNQUFNLGFBQU5BLE1BQU0sZUFBTkEsTUFBTSxDQUFFTyxVQUFVLElBQUlOLElBQUksRUFBRTtJQUM5QkQsTUFBTSxDQUFDTyxVQUFVLENBQUNDLE9BQU8sQ0FBRUMsRUFBRSxJQUFLO01BQ2hDLElBQUksSUFBQUMsa0JBQVMsRUFBQ0QsRUFBRSxDQUFDRSxRQUFRLEVBQUVWLElBQUksQ0FBQyxFQUFFO1FBQ2hDLE1BQU1XLE1BQU0sR0FBR2IsV0FBVyxDQUFDVSxFQUFFLEVBQUVSLElBQUksRUFBRUMsUUFBUSxDQUFDO1FBQzlDLElBQUlPLEVBQUUsQ0FBQ0ksTUFBTSxFQUFFO1VBQ2I7VUFDQTtVQUNBLE1BQU1DLFVBQVUsR0FBR0MseUJBQUssQ0FBQ0MsaUJBQWlCLENBQUNQLEVBQUUsQ0FBQ0ksTUFBTSxFQUFFWixJQUFJLENBQUMsQ0FBQ2dCLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLENBQUNBLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDO1VBQzlGLElBQUFDLG9CQUFXLEVBQUNqQixJQUFJLEVBQUVhLFVBQVUsRUFBRUYsTUFBTSxDQUFDO1FBQ3ZDO01BQ0Y7SUFDRixDQUFDLENBQUM7RUFDSjtFQUNBLE9BQU9YLElBQUk7QUFDYixDQUFDO0FBQUMsSUFBQWtCLFFBQUEsR0FBQUMsT0FBQSxDQUFBL0IsT0FBQSxHQUVhaUIsaUJBQWlCIiwiaWdub3JlTGlzdCI6W119
|