@ukhomeoffice/cop-react-form-renderer 6.13.2 → 6.14.1
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 +8 -0
- package/dist/components/CheckYourAnswers/Answer.js +12 -11
- package/dist/components/CheckYourAnswers/Answer.test.js +132 -181
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +98 -133
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +544 -939
- package/dist/components/CheckYourAnswers/index.js +1 -1
- package/dist/components/CollectionPage/CollectionPage.js +62 -60
- package/dist/components/CollectionPage/CollectionPage.test.js +315 -365
- package/dist/components/CollectionPage/index.js +1 -1
- package/dist/components/CollectionSummary/BannerStrip.js +14 -14
- package/dist/components/CollectionSummary/BannerStrip.test.js +79 -74
- package/dist/components/CollectionSummary/CollectionSummary.js +81 -99
- package/dist/components/CollectionSummary/CollectionSummary.test.js +182 -166
- package/dist/components/CollectionSummary/Confirmation.js +15 -13
- package/dist/components/CollectionSummary/Confirmation.test.js +68 -63
- package/dist/components/CollectionSummary/RenderListView.js +47 -48
- package/dist/components/CollectionSummary/RenderListView.scss +4 -0
- package/dist/components/CollectionSummary/RenderListView.test.js +133 -98
- package/dist/components/CollectionSummary/SummaryCard.js +110 -148
- package/dist/components/CollectionSummary/SummaryCard.test.js +961 -993
- package/dist/components/CollectionSummary/SummaryCardButtons.js +71 -0
- package/dist/components/CollectionSummary/SummaryCardButtons.test.js +85 -0
- package/dist/components/CollectionSummary/SummaryCardDetails.js +59 -76
- package/dist/components/CollectionSummary/SummaryCardDetails.test.js +170 -180
- package/dist/components/CollectionSummary/SummaryCardValidationContext.js +31 -36
- package/dist/components/CollectionSummary/SummaryCardValidationContext.test.js +63 -75
- package/dist/components/CollectionSummary/index.js +1 -1
- package/dist/components/FormComponent/Collection.js +67 -102
- package/dist/components/FormComponent/Collection.test.js +907 -1080
- package/dist/components/FormComponent/Container.js +35 -29
- package/dist/components/FormComponent/Container.test.js +378 -409
- package/dist/components/FormComponent/FormComponent.js +59 -63
- package/dist/components/FormComponent/FormComponent.test.js +354 -415
- package/dist/components/FormComponent/helpers/addLabel.js +4 -7
- package/dist/components/FormComponent/helpers/getComponentDisabled.js +1 -1
- package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +8 -8
- package/dist/components/FormComponent/helpers/getComponentError.js +3 -5
- package/dist/components/FormComponent/helpers/getComponentError.test.js +15 -15
- package/dist/components/FormComponent/helpers/getComponentFieldSet.js +3 -4
- package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +7 -7
- package/dist/components/FormComponent/helpers/index.js +5 -5
- package/dist/components/FormComponent/index.js +1 -1
- package/dist/components/FormPage/FormPage.js +99 -88
- package/dist/components/FormPage/FormPage.test.js +173 -164
- package/dist/components/FormPage/index.js +1 -1
- package/dist/components/FormRenderer/FormRenderer.js +138 -174
- package/dist/components/FormRenderer/FormRenderer.test.js +732 -1114
- package/dist/components/FormRenderer/handlers/cyaAction.js +3 -3
- package/dist/components/FormRenderer/handlers/getPageId.js +1 -3
- package/dist/components/FormRenderer/handlers/getPageId.test.js +15 -15
- package/dist/components/FormRenderer/handlers/handlers.test.js +33 -33
- package/dist/components/FormRenderer/handlers/index.js +2 -2
- package/dist/components/FormRenderer/handlers/navigate.js +4 -4
- package/dist/components/FormRenderer/handlers/submissionError.js +1 -1
- package/dist/components/FormRenderer/helpers/canActionProceed.js +1 -1
- package/dist/components/FormRenderer/helpers/canActionProceed.test.js +16 -16
- package/dist/components/FormRenderer/helpers/canCYASubmit.js +1 -3
- package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +17 -21
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +22 -25
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +21 -21
- package/dist/components/FormRenderer/helpers/getCYA.js +4 -6
- package/dist/components/FormRenderer/helpers/getCYA.test.js +12 -12
- package/dist/components/FormRenderer/helpers/getFormState.js +6 -8
- package/dist/components/FormRenderer/helpers/getFormState.test.js +11 -11
- package/dist/components/FormRenderer/helpers/getNextPageId.js +14 -25
- package/dist/components/FormRenderer/helpers/getNextPageId.test.js +68 -68
- package/dist/components/FormRenderer/helpers/getPage.js +2 -4
- package/dist/components/FormRenderer/helpers/getPage.test.js +12 -12
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +7 -9
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +15 -15
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +6 -6
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +104 -98
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +44 -51
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +68 -74
- package/dist/components/FormRenderer/helpers/index.js +2 -2
- package/dist/components/FormRenderer/index.js +1 -1
- package/dist/components/FormRenderer/onCYAAction.js +43 -44
- package/dist/components/FormRenderer/onCYAAction.test.js +126 -133
- package/dist/components/FormRenderer/onPageAction.js +26 -35
- package/dist/components/FormRenderer/onPageAction.test.js +177 -186
- package/dist/components/FormRenderer/onTaskAction.js +11 -12
- package/dist/components/FormRenderer/onTaskAction.test.js +63 -68
- package/dist/components/PageActions/ActionButton.js +14 -14
- package/dist/components/PageActions/ActionButton.test.js +57 -79
- package/dist/components/PageActions/PageActions.js +11 -11
- package/dist/components/PageActions/PageActions.test.js +87 -116
- package/dist/components/PageActions/index.js +1 -1
- package/dist/components/SummaryList/GroupAction.js +10 -18
- package/dist/components/SummaryList/GroupAction.test.js +38 -34
- package/dist/components/SummaryList/RowAction.js +12 -17
- package/dist/components/SummaryList/RowAction.test.js +38 -34
- package/dist/components/SummaryList/SummaryList.js +23 -25
- package/dist/components/SummaryList/SummaryList.test.js +162 -189
- package/dist/components/SummaryList/SummaryListHeadingRow.js +7 -5
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.js +7 -5
- package/dist/components/SummaryList/SummaryListRow.js +7 -5
- package/dist/components/SummaryList/SummaryListTitleRow.js +6 -4
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +3 -5
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +23 -23
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +3 -5
- package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +23 -23
- package/dist/components/SummaryList/helpers/index.js +2 -2
- package/dist/components/SummaryList/index.js +1 -1
- package/dist/components/TaskList/Task.js +20 -30
- package/dist/components/TaskList/Task.test.js +84 -77
- package/dist/components/TaskList/TaskList.js +56 -79
- package/dist/components/TaskList/TaskList.test.js +149 -149
- package/dist/components/TaskList/TaskState.js +8 -6
- package/dist/components/TaskList/TaskState.test.js +53 -46
- package/dist/components/TaskList/index.js +1 -1
- package/dist/components/index.js +8 -8
- package/dist/context/HooksContext/HooksContext.js +56 -79
- package/dist/context/HooksContext/HooksContext.test.js +27 -36
- package/dist/context/HooksContext/index.js +3 -4
- package/dist/context/ValidationContext/ValidationContext.js +44 -95
- package/dist/context/ValidationContext/ValidationContext.test.js +57 -69
- package/dist/context/ValidationContext/index.js +3 -4
- package/dist/context/index.js +3 -3
- package/dist/hooks/index.js +10 -11
- package/dist/hooks/useAxios.js +15 -41
- package/dist/hooks/useGetRequest.js +62 -98
- package/dist/hooks/useHooks.js +1 -3
- package/dist/hooks/useRefData.js +25 -37
- package/dist/hooks/useValidation.js +1 -3
- package/dist/index.js +14 -15
- package/dist/models/CollectionLabels.js +1 -1
- package/dist/models/ComponentTypes.js +25 -25
- package/dist/models/EventTypes.js +4 -4
- package/dist/models/FormPages.js +4 -4
- package/dist/models/FormTypes.js +8 -8
- package/dist/models/HubFormats.js +3 -3
- package/dist/models/PageAction.js +44 -38
- package/dist/models/TaskStates.js +29 -28
- package/dist/models/index.js +10 -10
- package/dist/setupTests.js +30 -31
- package/dist/utils/CheckYourAnswers/getCYAAction.js +5 -5
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +53 -55
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +12 -21
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +32 -33
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +15 -28
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +41 -42
- package/dist/utils/CheckYourAnswers/getCYARow.js +7 -7
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +87 -87
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +19 -21
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +16 -17
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +27 -34
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +48 -52
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +79 -93
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +110 -115
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +11 -14
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +146 -98
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +14 -19
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +69 -73
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.js +7 -8
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.test.js +15 -16
- package/dist/utils/CheckYourAnswers/index.js +2 -2
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +5 -5
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +26 -26
- package/dist/utils/CollectionPage/addCollectionPageEntry.js +2 -2
- package/dist/utils/CollectionPage/addCollectionPageEntry.test.js +6 -6
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +3 -3
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +18 -19
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +13 -20
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +48 -39
- package/dist/utils/CollectionPage/getCollectionPageActiveId.js +2 -2
- package/dist/utils/CollectionPage/getCollectionPageActiveId.test.js +11 -11
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +7 -11
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +23 -23
- package/dist/utils/CollectionPage/getCollectionPageData.js +8 -12
- package/dist/utils/CollectionPage/getCollectionPageData.test.js +20 -20
- package/dist/utils/CollectionPage/getErrorsForCollection.js +20 -21
- package/dist/utils/CollectionPage/getErrorsForCollection.test.js +21 -23
- package/dist/utils/CollectionPage/getQuickEditPage.js +22 -23
- package/dist/utils/CollectionPage/getQuickEditPage.test.js +17 -18
- package/dist/utils/CollectionPage/index.js +2 -2
- package/dist/utils/CollectionPage/mergeCollectionPages.js +26 -35
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +18 -18
- package/dist/utils/CollectionPage/removeCollectionPageEntry.js +5 -7
- package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +11 -11
- package/dist/utils/CollectionPage/setCollectionPageData.js +10 -16
- package/dist/utils/CollectionPage/setCollectionPageData.test.js +25 -25
- package/dist/utils/Component/addShowWhen.js +5 -6
- package/dist/utils/Component/addShowWhen.test.js +38 -38
- package/dist/utils/Component/applyToComponentTree.js +12 -15
- package/dist/utils/Component/applyToComponentTree.test.js +28 -31
- package/dist/utils/Component/cleanAttributes.js +12 -11
- package/dist/utils/Component/cleanAttributes.test.js +17 -18
- package/dist/utils/Component/elevateNestedComponents.js +6 -6
- package/dist/utils/Component/elevateNestedComponents.test.js +34 -34
- package/dist/utils/Component/getComponent.js +81 -83
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +19 -18
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +41 -58
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +40 -49
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +24 -34
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +21 -19
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +18 -23
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +21 -26
- package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +11 -10
- package/dist/utils/Component/getComponentTests/getComponent.html.test.js +18 -16
- package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +10 -9
- package/dist/utils/Component/getComponentTests/getComponent.list.test.js +18 -16
- package/dist/utils/Component/getComponentTests/getComponent.multifile.test.js +23 -27
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +201 -174
- package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +18 -16
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +18 -23
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +58 -73
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +18 -23
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +18 -23
- package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +32 -39
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +21 -30
- package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +3 -3
- package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +10 -9
- package/dist/utils/Component/getDefaultValue.js +7 -9
- package/dist/utils/Component/getDefaultValue.test.js +13 -13
- package/dist/utils/Component/getDefaultValueFromConfig.js +16 -20
- package/dist/utils/Component/getDefaultValueFromConfig.test.js +32 -32
- package/dist/utils/Component/index.js +2 -2
- package/dist/utils/Component/isEditable.js +2 -4
- package/dist/utils/Component/isEditable.test.js +14 -15
- package/dist/utils/Component/optionIsSelected.js +2 -4
- package/dist/utils/Component/optionIsSelected.test.js +12 -12
- package/dist/utils/Component/setupContainerComponentsPath.js +23 -28
- package/dist/utils/Component/setupContainerComponentsPath.test.js +12 -12
- package/dist/utils/Component/showComponent.js +2 -2
- package/dist/utils/Component/showComponent.test.js +29 -29
- package/dist/utils/Component/wrapInFormGroup.js +4 -4
- package/dist/utils/Condition/index.js +2 -2
- package/dist/utils/Condition/meetsAllConditions.js +9 -9
- package/dist/utils/Condition/meetsAllConditions.test.js +21 -21
- package/dist/utils/Condition/meetsCondition.js +17 -26
- package/dist/utils/Condition/meetsCondition.test.js +403 -403
- package/dist/utils/Condition/meetsOneCondition.js +6 -6
- package/dist/utils/Condition/meetsOneCondition.test.js +17 -17
- package/dist/utils/Condition/setupConditions.js +12 -15
- package/dist/utils/Condition/setupConditions.test.js +8 -8
- package/dist/utils/Container/getEditableComponents.js +4 -6
- package/dist/utils/Container/getEditableComponents.test.js +44 -46
- package/dist/utils/Container/index.js +2 -2
- package/dist/utils/Container/setupNesting.js +14 -15
- package/dist/utils/Container/setupNesting.test.js +20 -23
- package/dist/utils/Container/showContainer.js +4 -8
- package/dist/utils/Container/showContainer.test.js +31 -31
- package/dist/utils/Data/applyFormula.js +30 -44
- package/dist/utils/Data/applyFormula.test.js +21 -21
- package/dist/utils/Data/deleteValues.js +4 -8
- package/dist/utils/Data/deleteValues.test.js +11 -11
- package/dist/utils/Data/getAutocompleteSource.js +19 -27
- package/dist/utils/Data/getAutocompleteSource.test.js +76 -81
- package/dist/utils/Data/getDataPath.js +18 -28
- package/dist/utils/Data/getDataPath.test.js +13 -13
- package/dist/utils/Data/getOptions.js +57 -30
- package/dist/utils/Data/getOptions.test.js +75 -28
- package/dist/utils/Data/getSourceData.js +6 -19
- package/dist/utils/Data/getSourceData.test.js +85 -81
- package/dist/utils/Data/index.js +2 -2
- package/dist/utils/Data/nestInRefdataOptions.js +9 -12
- package/dist/utils/Data/nestInRefdataOptions.test.js +17 -17
- package/dist/utils/Data/refDataToOptions.js +9 -10
- package/dist/utils/Data/refDataToOptions.test.js +20 -20
- package/dist/utils/Data/setDataItem.js +7 -8
- package/dist/utils/Data/setDataItem.test.js +38 -38
- package/dist/utils/Data/setupFormData.js +13 -20
- package/dist/utils/Data/setupFormData.test.js +48 -47
- package/dist/utils/Data/setupRefDataUrlForComponent.js +11 -20
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +25 -25
- package/dist/utils/FormPage/applyConditionalProperties.js +7 -8
- package/dist/utils/FormPage/applyConditionalProperties.test.js +14 -15
- package/dist/utils/FormPage/getConditionalText.js +4 -4
- package/dist/utils/FormPage/getConditionalText.test.js +30 -30
- package/dist/utils/FormPage/getFormPage.js +16 -12
- package/dist/utils/FormPage/getFormPage.test.js +23 -24
- package/dist/utils/FormPage/getFormPages.js +8 -11
- package/dist/utils/FormPage/getFormPages.test.js +15 -16
- package/dist/utils/FormPage/getPageActions.js +10 -13
- package/dist/utils/FormPage/getPageActions.test.js +33 -33
- package/dist/utils/FormPage/getParagraphFromText.js +5 -7
- package/dist/utils/FormPage/getParagraphFromText.test.js +7 -7
- package/dist/utils/FormPage/index.js +3 -5
- package/dist/utils/FormPage/showFormPage.js +4 -8
- package/dist/utils/FormPage/showFormPage.test.js +33 -33
- package/dist/utils/FormPage/showFormPageCYA.js +2 -2
- package/dist/utils/FormPage/showFormPageCYA.test.js +9 -9
- package/dist/utils/FormPage/useComponent.js +25 -22
- package/dist/utils/FormPage/useComponent.test.js +79 -44
- package/dist/utils/Format/formatData.js +1 -1
- package/dist/utils/Format/formatData.test.js +19 -19
- package/dist/utils/Format/formatDataForComponent.js +6 -7
- package/dist/utils/Format/formatDataForComponent.test.js +50 -78
- package/dist/utils/Format/formatDataForForm.js +5 -6
- package/dist/utils/Format/formatDataForForm.test.js +14 -17
- package/dist/utils/Format/formatDataForPage.js +4 -5
- package/dist/utils/Format/formatDataForPage.test.js +20 -25
- package/dist/utils/Format/index.js +2 -2
- package/dist/utils/Hub/getFormHub.js +2 -2
- package/dist/utils/Hub/getFormHub.test.js +23 -24
- package/dist/utils/Hub/index.js +2 -2
- package/dist/utils/Meta/constants.js +2 -2
- package/dist/utils/Meta/documents/getDocuments.js +1 -1
- package/dist/utils/Meta/documents/getDocuments.test.js +25 -17
- package/dist/utils/Meta/documents/index.js +2 -2
- package/dist/utils/Meta/documents/setDocumentsForField.js +12 -13
- package/dist/utils/Meta/documents/setDocumentsForField.test.js +70 -33
- package/dist/utils/Meta/index.js +2 -2
- package/dist/utils/Operate/checkValueIsTruthy.js +3 -3
- package/dist/utils/Operate/checkValueIsTruthy.test.js +17 -17
- package/dist/utils/Operate/deleteValueInFormData.js +2 -2
- package/dist/utils/Operate/deleteValueInFormData.test.js +15 -15
- package/dist/utils/Operate/getFirstOf.js +6 -6
- package/dist/utils/Operate/getFirstOf.test.js +32 -32
- package/dist/utils/Operate/getIndexOfMatchingValueIn.js +11 -11
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +47 -53
- package/dist/utils/Operate/getLength.js +9 -9
- package/dist/utils/Operate/getLength.test.js +19 -19
- package/dist/utils/Operate/index.js +2 -2
- package/dist/utils/Operate/persistValueInFormData.js +4 -4
- package/dist/utils/Operate/persistValueInFormData.test.js +23 -21
- package/dist/utils/Operate/runPageOperations.js +8 -8
- package/dist/utils/Operate/runPageOperations.test.js +24 -25
- package/dist/utils/Operate/setValueInFormData.js +3 -3
- package/dist/utils/Operate/setValueInFormData.test.js +17 -17
- package/dist/utils/Operate/shouldRun.js +7 -7
- package/dist/utils/Operate/shouldRun.test.js +22 -24
- package/dist/utils/Validate/additional/conditionallyPermittedChange.js +1 -1
- package/dist/utils/Validate/additional/conditionallyPermittedChange.test.js +15 -15
- package/dist/utils/Validate/additional/conditionallyRequired.js +4 -4
- package/dist/utils/Validate/additional/conditionallyRequired.test.js +19 -19
- package/dist/utils/Validate/additional/index.js +8 -8
- package/dist/utils/Validate/additional/index.test.js +22 -22
- package/dist/utils/Validate/additional/mustBeAfter.js +3 -3
- package/dist/utils/Validate/additional/mustBeAfter.test.js +41 -41
- package/dist/utils/Validate/additional/mustBeBefore.js +3 -3
- package/dist/utils/Validate/additional/mustBeBefore.test.js +29 -29
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +8 -12
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +37 -38
- package/dist/utils/Validate/additional/mustBeGreaterThan.js +2 -2
- package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +19 -19
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +3 -3
- package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +13 -13
- package/dist/utils/Validate/additional/mustBeInThePast.js +4 -4
- package/dist/utils/Validate/additional/mustBeInThePast.test.js +13 -13
- package/dist/utils/Validate/additional/mustBeLessThan.js +2 -2
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +18 -18
- package/dist/utils/Validate/additional/mustBeLongerThan.js +1 -1
- package/dist/utils/Validate/additional/mustBeLongerThan.test.js +17 -17
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +2 -2
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +21 -21
- package/dist/utils/Validate/additional/mustBeOneOf.js +1 -1
- package/dist/utils/Validate/additional/mustBeOneOf.test.js +13 -13
- package/dist/utils/Validate/additional/mustBeShorterThan.js +1 -1
- package/dist/utils/Validate/additional/mustBeShorterThan.test.js +17 -17
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.js +5 -5
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.test.js +35 -36
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +2 -2
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +15 -17
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +1 -1
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +13 -13
- package/dist/utils/Validate/additional/mustNotContainSql.js +3 -4
- package/dist/utils/Validate/additional/mustNotContainSql.test.js +15 -15
- package/dist/utils/Validate/additional/mustSelectOnlyOne.js +2 -2
- package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +29 -27
- package/dist/utils/Validate/additional/utils.js +9 -22
- package/dist/utils/Validate/index.js +2 -2
- package/dist/utils/Validate/validateCollection.js +18 -23
- package/dist/utils/Validate/validateCollection.test.js +75 -67
- package/dist/utils/Validate/validateComponent.js +19 -19
- package/dist/utils/Validate/validateComponent.test.js +179 -154
- package/dist/utils/Validate/validateContainer.js +14 -17
- package/dist/utils/Validate/validateContainer.test.js +59 -53
- package/dist/utils/Validate/validateDate.js +16 -22
- package/dist/utils/Validate/validateDate.test.js +31 -32
- package/dist/utils/Validate/validateEmail.js +8 -9
- package/dist/utils/Validate/validateEmail.test.js +29 -26
- package/dist/utils/Validate/validateMultifile.js +5 -7
- package/dist/utils/Validate/validateMultifile.test.js +17 -18
- package/dist/utils/Validate/validatePage.js +13 -18
- package/dist/utils/Validate/validatePage.test.js +198 -195
- package/dist/utils/Validate/validateRegex.js +3 -5
- package/dist/utils/Validate/validateRegex.test.js +15 -15
- package/dist/utils/Validate/validateRequired.js +4 -6
- package/dist/utils/Validate/validateRequired.test.js +19 -19
- package/dist/utils/Validate/validateTextArea.js +4 -6
- package/dist/utils/Validate/validateTextArea.test.js +21 -21
- package/dist/utils/Validate/validateTime.js +12 -19
- package/dist/utils/Validate/validateTime.test.js +27 -27
- package/dist/utils/index.js +5 -6
- package/package.json +5 -5
|
@@ -2,30 +2,28 @@
|
|
|
2
2
|
|
|
3
3
|
var _setupTests = require("../../setupTests");
|
|
4
4
|
var _getCYARow = _interopRequireDefault(require("./getCYARow"));
|
|
5
|
-
function _interopRequireDefault(
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
describe('
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
it('should get an appropriate row for a readonly text component', function () {
|
|
14
|
-
var PAGE = {
|
|
5
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
6
|
+
// Local imports
|
|
7
|
+
|
|
8
|
+
describe('utils', () => {
|
|
9
|
+
describe('CheckYourAnswers', () => {
|
|
10
|
+
describe('getCYARow', () => {
|
|
11
|
+
it('should get an appropriate row for a readonly text component', () => {
|
|
12
|
+
const PAGE = {
|
|
15
13
|
id: 'page',
|
|
16
14
|
formData: {
|
|
17
15
|
a: 'Bravo'
|
|
18
16
|
}
|
|
19
17
|
};
|
|
20
|
-
|
|
18
|
+
const COMPONENT = {
|
|
21
19
|
type: 'text',
|
|
22
20
|
readonly: true,
|
|
23
21
|
id: 'a',
|
|
24
22
|
fieldId: 'a',
|
|
25
23
|
label: 'Alpha'
|
|
26
24
|
};
|
|
27
|
-
|
|
28
|
-
|
|
25
|
+
const ON_ACTION = () => {};
|
|
26
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
29
27
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
30
28
|
pageId: PAGE.id,
|
|
31
29
|
fieldId: COMPONENT.fieldId,
|
|
@@ -35,19 +33,19 @@ describe('utils', function () {
|
|
|
35
33
|
action: null
|
|
36
34
|
});
|
|
37
35
|
});
|
|
38
|
-
it('should get an appropriate row for a readonly text component with no value',
|
|
39
|
-
|
|
36
|
+
it('should get an appropriate row for a readonly text component with no value', () => {
|
|
37
|
+
const PAGE = {
|
|
40
38
|
id: 'page',
|
|
41
39
|
formData: {}
|
|
42
40
|
};
|
|
43
|
-
|
|
41
|
+
const COMPONENT = {
|
|
44
42
|
type: 'text',
|
|
45
43
|
readonly: true,
|
|
46
44
|
id: 'a',
|
|
47
45
|
fieldId: 'a',
|
|
48
46
|
label: 'Alpha'
|
|
49
47
|
};
|
|
50
|
-
|
|
48
|
+
const ON_ACTION = () => {};
|
|
51
49
|
expect((0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION)).toEqual({
|
|
52
50
|
pageId: PAGE.id,
|
|
53
51
|
id: COMPONENT.id,
|
|
@@ -58,21 +56,21 @@ describe('utils', function () {
|
|
|
58
56
|
action: null
|
|
59
57
|
});
|
|
60
58
|
});
|
|
61
|
-
it('should get an appropriate row for a readonly non-editable component',
|
|
62
|
-
|
|
59
|
+
it('should get an appropriate row for a readonly non-editable component', () => {
|
|
60
|
+
const PAGE = {
|
|
63
61
|
id: 'page',
|
|
64
62
|
formData: {
|
|
65
63
|
a: 'BLAH'
|
|
66
64
|
}
|
|
67
65
|
};
|
|
68
|
-
|
|
66
|
+
const COMPONENT = {
|
|
69
67
|
type: 'blah',
|
|
70
68
|
readonly: true,
|
|
71
69
|
id: 'a',
|
|
72
70
|
fieldId: 'a',
|
|
73
71
|
label: 'Alpha'
|
|
74
72
|
};
|
|
75
|
-
|
|
73
|
+
const ON_ACTION = () => {};
|
|
76
74
|
expect((0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION)).toEqual({
|
|
77
75
|
pageId: PAGE.id,
|
|
78
76
|
id: COMPONENT.id,
|
|
@@ -82,22 +80,22 @@ describe('utils', function () {
|
|
|
82
80
|
action: null
|
|
83
81
|
});
|
|
84
82
|
});
|
|
85
|
-
it('should use the cya_label where there is no label',
|
|
86
|
-
|
|
83
|
+
it('should use the cya_label where there is no label', () => {
|
|
84
|
+
const PAGE = {
|
|
87
85
|
id: 'page',
|
|
88
86
|
formData: {
|
|
89
87
|
a: 'Bravo'
|
|
90
88
|
}
|
|
91
89
|
};
|
|
92
|
-
|
|
90
|
+
const COMPONENT = {
|
|
93
91
|
type: 'text',
|
|
94
92
|
readonly: true,
|
|
95
93
|
id: 'a',
|
|
96
94
|
fieldId: 'a',
|
|
97
95
|
cya_label: 'CYA Alpha'
|
|
98
96
|
};
|
|
99
|
-
|
|
100
|
-
|
|
97
|
+
const ON_ACTION = () => {};
|
|
98
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
101
99
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
102
100
|
pageId: PAGE.id,
|
|
103
101
|
fieldId: COMPONENT.fieldId,
|
|
@@ -107,22 +105,22 @@ describe('utils', function () {
|
|
|
107
105
|
value: 'Bravo'
|
|
108
106
|
});
|
|
109
107
|
});
|
|
110
|
-
it('should get an appropriate row for an editable text component',
|
|
111
|
-
|
|
108
|
+
it('should get an appropriate row for an editable text component', () => {
|
|
109
|
+
const PAGE = {
|
|
112
110
|
id: 'page',
|
|
113
111
|
formData: {
|
|
114
112
|
a: 'Bravo'
|
|
115
113
|
},
|
|
116
114
|
cya_link: {}
|
|
117
115
|
};
|
|
118
|
-
|
|
116
|
+
const COMPONENT = {
|
|
119
117
|
type: 'text',
|
|
120
118
|
id: 'a',
|
|
121
119
|
fieldId: 'a',
|
|
122
120
|
label: 'Alpha'
|
|
123
121
|
};
|
|
124
|
-
|
|
125
|
-
|
|
122
|
+
const ON_ACTION = () => {};
|
|
123
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
126
124
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
127
125
|
pageId: PAGE.id,
|
|
128
126
|
fieldId: COMPONENT.fieldId,
|
|
@@ -134,18 +132,19 @@ describe('utils', function () {
|
|
|
134
132
|
onAction: ON_ACTION
|
|
135
133
|
});
|
|
136
134
|
});
|
|
137
|
-
it('should update any nested components in radios with corresponding values from the stored formdata',
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
135
|
+
it('should update any nested components in radios with corresponding values from the stored formdata', () => {
|
|
136
|
+
const SELECTED_VALUE = 'selectedValue';
|
|
137
|
+
const NESTED_ID = 'nestedId';
|
|
138
|
+
const NESTED_VALUE = 'nestedValue';
|
|
139
|
+
const PAGE = {
|
|
142
140
|
id: 'page',
|
|
143
|
-
formData:
|
|
144
|
-
a: SELECTED_VALUE
|
|
145
|
-
|
|
141
|
+
formData: {
|
|
142
|
+
a: SELECTED_VALUE,
|
|
143
|
+
[NESTED_ID]: NESTED_VALUE
|
|
144
|
+
},
|
|
146
145
|
cya_link: {}
|
|
147
146
|
};
|
|
148
|
-
|
|
147
|
+
const COMPONENT = {
|
|
149
148
|
type: 'radios',
|
|
150
149
|
id: 'a',
|
|
151
150
|
fieldId: 'a',
|
|
@@ -158,17 +157,17 @@ describe('utils', function () {
|
|
|
158
157
|
}]
|
|
159
158
|
}
|
|
160
159
|
};
|
|
161
|
-
|
|
160
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, () => {});
|
|
162
161
|
expect(ROW.component.data.options[0].nested[0].value).toEqual(NESTED_VALUE);
|
|
163
162
|
});
|
|
164
|
-
it('should handle an undefined formData when attempting to set nested values in radios',
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
163
|
+
it('should handle an undefined formData when attempting to set nested values in radios', () => {
|
|
164
|
+
const SELECTED_VALUE = 'selectedValue';
|
|
165
|
+
const NESTED_ID = 'nestedId';
|
|
166
|
+
const PAGE = {
|
|
168
167
|
id: 'page',
|
|
169
168
|
cya_link: {}
|
|
170
169
|
};
|
|
171
|
-
|
|
170
|
+
const COMPONENT = {
|
|
172
171
|
type: 'radios',
|
|
173
172
|
id: 'a',
|
|
174
173
|
fieldId: 'a',
|
|
@@ -181,21 +180,22 @@ describe('utils', function () {
|
|
|
181
180
|
}]
|
|
182
181
|
}
|
|
183
182
|
};
|
|
184
|
-
|
|
183
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, () => {});
|
|
185
184
|
expect(ROW.component.data.options[0].nested[0].value).toBeUndefined();
|
|
186
185
|
});
|
|
187
|
-
it('should update any nested components in checkboxes with corresponding values from the stored formdata',
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
186
|
+
it('should update any nested components in checkboxes with corresponding values from the stored formdata', () => {
|
|
187
|
+
const SELECTED_VALUE = 'selectedValue';
|
|
188
|
+
const NESTED_ID = 'nestedId';
|
|
189
|
+
const NESTED_VALUE = 'nestedValue';
|
|
190
|
+
const PAGE = {
|
|
192
191
|
id: 'page',
|
|
193
|
-
formData:
|
|
194
|
-
a: [SELECTED_VALUE]
|
|
195
|
-
|
|
192
|
+
formData: {
|
|
193
|
+
a: [SELECTED_VALUE],
|
|
194
|
+
[NESTED_ID]: NESTED_VALUE
|
|
195
|
+
},
|
|
196
196
|
cya_link: {}
|
|
197
197
|
};
|
|
198
|
-
|
|
198
|
+
const COMPONENT = {
|
|
199
199
|
type: 'checkboxes',
|
|
200
200
|
id: 'a',
|
|
201
201
|
fieldId: 'a',
|
|
@@ -208,17 +208,17 @@ describe('utils', function () {
|
|
|
208
208
|
}]
|
|
209
209
|
}
|
|
210
210
|
};
|
|
211
|
-
|
|
211
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, () => {});
|
|
212
212
|
expect(ROW.component.data.options[0].nested[0].value).toEqual(NESTED_VALUE);
|
|
213
213
|
});
|
|
214
|
-
it('should handle an undefined formData when attempting to set nested values in checkboxes',
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
214
|
+
it('should handle an undefined formData when attempting to set nested values in checkboxes', () => {
|
|
215
|
+
const SELECTED_VALUE = 'selectedValue';
|
|
216
|
+
const NESTED_ID = 'nestedId';
|
|
217
|
+
const PAGE = {
|
|
218
218
|
id: 'page',
|
|
219
219
|
cya_link: {}
|
|
220
220
|
};
|
|
221
|
-
|
|
221
|
+
const COMPONENT = {
|
|
222
222
|
type: 'checkboxes',
|
|
223
223
|
id: 'a',
|
|
224
224
|
fieldId: 'a',
|
|
@@ -231,25 +231,25 @@ describe('utils', function () {
|
|
|
231
231
|
}]
|
|
232
232
|
}
|
|
233
233
|
};
|
|
234
|
-
|
|
234
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, () => {});
|
|
235
235
|
expect(ROW.component.data.options[0].nested[0].value).toBeUndefined();
|
|
236
236
|
});
|
|
237
|
-
it('should get an appropriate row for a readonly text component with no value and interpolated label',
|
|
238
|
-
|
|
237
|
+
it('should get an appropriate row for a readonly text component with no value and interpolated label', () => {
|
|
238
|
+
const PAGE = {
|
|
239
239
|
id: 'page',
|
|
240
240
|
formData: {
|
|
241
241
|
text: 'Smith'
|
|
242
242
|
}
|
|
243
243
|
};
|
|
244
244
|
// eslint-disable-next-line no-template-curly-in-string
|
|
245
|
-
|
|
245
|
+
const COMPONENT = {
|
|
246
246
|
type: 'text',
|
|
247
247
|
readonly: true,
|
|
248
248
|
id: 'a',
|
|
249
249
|
fieldId: 'a',
|
|
250
250
|
label: 'Alpha ${text}'
|
|
251
251
|
};
|
|
252
|
-
|
|
252
|
+
const ON_ACTION = () => {};
|
|
253
253
|
expect((0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION)).toEqual({
|
|
254
254
|
pageId: PAGE.id,
|
|
255
255
|
id: COMPONENT.id,
|
|
@@ -260,23 +260,23 @@ describe('utils', function () {
|
|
|
260
260
|
action: null
|
|
261
261
|
});
|
|
262
262
|
});
|
|
263
|
-
it('should use the interolated cya_label where there is no label',
|
|
264
|
-
|
|
263
|
+
it('should use the interolated cya_label where there is no label', () => {
|
|
264
|
+
const PAGE = {
|
|
265
265
|
id: 'page',
|
|
266
266
|
formData: {
|
|
267
267
|
a: 'Bravo'
|
|
268
268
|
}
|
|
269
269
|
};
|
|
270
270
|
// eslint-disable-next-line no-template-curly-in-string
|
|
271
|
-
|
|
271
|
+
const COMPONENT = {
|
|
272
272
|
type: 'text',
|
|
273
273
|
readonly: true,
|
|
274
274
|
id: 'a',
|
|
275
275
|
fieldId: 'a',
|
|
276
276
|
cya_label: 'CYA Alpha ${a}'
|
|
277
277
|
};
|
|
278
|
-
|
|
279
|
-
|
|
278
|
+
const ON_ACTION = () => {};
|
|
279
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
280
280
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
281
281
|
pageId: PAGE.id,
|
|
282
282
|
fieldId: COMPONENT.fieldId,
|
|
@@ -286,14 +286,14 @@ describe('utils', function () {
|
|
|
286
286
|
value: 'Bravo'
|
|
287
287
|
});
|
|
288
288
|
});
|
|
289
|
-
it('should use the cya_label where there is a label',
|
|
290
|
-
|
|
289
|
+
it('should use the cya_label where there is a label', () => {
|
|
290
|
+
const PAGE = {
|
|
291
291
|
id: 'page',
|
|
292
292
|
formData: {
|
|
293
293
|
a: 'Bravo'
|
|
294
294
|
}
|
|
295
295
|
};
|
|
296
|
-
|
|
296
|
+
const COMPONENT = {
|
|
297
297
|
type: 'text',
|
|
298
298
|
readonly: true,
|
|
299
299
|
id: 'a',
|
|
@@ -301,8 +301,8 @@ describe('utils', function () {
|
|
|
301
301
|
cya_label: 'CYA Alpha',
|
|
302
302
|
label: 'Alpha'
|
|
303
303
|
};
|
|
304
|
-
|
|
305
|
-
|
|
304
|
+
const ON_ACTION = () => {};
|
|
305
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
306
306
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
307
307
|
pageId: PAGE.id,
|
|
308
308
|
fieldId: COMPONENT.fieldId,
|
|
@@ -312,22 +312,22 @@ describe('utils', function () {
|
|
|
312
312
|
value: 'Bravo'
|
|
313
313
|
});
|
|
314
314
|
});
|
|
315
|
-
it('should use the label where there is no cya_label',
|
|
316
|
-
|
|
315
|
+
it('should use the label where there is no cya_label', () => {
|
|
316
|
+
const PAGE = {
|
|
317
317
|
id: 'page',
|
|
318
318
|
formData: {
|
|
319
319
|
a: 'Bravo'
|
|
320
320
|
}
|
|
321
321
|
};
|
|
322
|
-
|
|
322
|
+
const COMPONENT = {
|
|
323
323
|
type: 'text',
|
|
324
324
|
readonly: true,
|
|
325
325
|
id: 'a',
|
|
326
326
|
fieldId: 'a',
|
|
327
327
|
label: 'Alpha'
|
|
328
328
|
};
|
|
329
|
-
|
|
330
|
-
|
|
329
|
+
const ON_ACTION = () => {};
|
|
330
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
331
331
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
332
332
|
pageId: PAGE.id,
|
|
333
333
|
fieldId: COMPONENT.fieldId,
|
|
@@ -337,8 +337,8 @@ describe('utils', function () {
|
|
|
337
337
|
value: 'Bravo'
|
|
338
338
|
});
|
|
339
339
|
});
|
|
340
|
-
it('should not produce an action when the page is configured to have a single change link',
|
|
341
|
-
|
|
340
|
+
it('should not produce an action when the page is configured to have a single change link', () => {
|
|
341
|
+
const PAGE = {
|
|
342
342
|
id: 'page',
|
|
343
343
|
formData: {
|
|
344
344
|
a: 'Bravo'
|
|
@@ -349,15 +349,15 @@ describe('utils', function () {
|
|
|
349
349
|
singleChangeLink: true
|
|
350
350
|
}
|
|
351
351
|
};
|
|
352
|
-
|
|
352
|
+
const COMPONENT = {
|
|
353
353
|
type: 'text',
|
|
354
354
|
readonly: true,
|
|
355
355
|
id: 'a',
|
|
356
356
|
fieldId: 'a',
|
|
357
357
|
label: 'Alpha'
|
|
358
358
|
};
|
|
359
|
-
|
|
360
|
-
|
|
359
|
+
const ON_ACTION = () => {};
|
|
360
|
+
const ROW = (0, _getCYARow.default)(PAGE, COMPONENT, ON_ACTION);
|
|
361
361
|
(0, _setupTests.expectObjectLike)(ROW, {
|
|
362
362
|
pageId: PAGE.id,
|
|
363
363
|
fieldId: COMPONENT.fieldId,
|
|
@@ -7,14 +7,13 @@ exports.default = void 0;
|
|
|
7
7
|
var _react = _interopRequireDefault(require("react"));
|
|
8
8
|
var _FormComponent = _interopRequireDefault(require("../../components/FormComponent"));
|
|
9
9
|
var _getCYAAction = _interopRequireDefault(require("./getCYAAction"));
|
|
10
|
-
function _interopRequireDefault(
|
|
11
|
-
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
10
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
11
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
13
12
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
14
|
-
function _defineProperty(
|
|
15
|
-
function _toPropertyKey(
|
|
16
|
-
function _toPrimitive(
|
|
17
|
-
|
|
13
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
14
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
15
|
+
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
16
|
+
const getRowValue = row => {
|
|
18
17
|
if (!row.value) {
|
|
19
18
|
return null;
|
|
20
19
|
}
|
|
@@ -31,36 +30,35 @@ var getRowValue = function getRowValue(row) {
|
|
|
31
30
|
value: row.value
|
|
32
31
|
}));
|
|
33
32
|
};
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
return r.id === componentId;
|
|
39
|
-
});
|
|
33
|
+
const getGroupValue = (group, rows) => {
|
|
34
|
+
let firstComponentIndex = -1;
|
|
35
|
+
const value = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, group.components.map(componentId => {
|
|
36
|
+
const rowIndex = rows.findIndex(r => r.id === componentId);
|
|
40
37
|
if (firstComponentIndex < 0) {
|
|
41
38
|
firstComponentIndex = rowIndex;
|
|
42
39
|
}
|
|
43
40
|
return rowIndex > -1 ? getRowValue(rows[rowIndex]) : null;
|
|
44
41
|
}));
|
|
45
42
|
return {
|
|
46
|
-
value
|
|
47
|
-
firstComponentIndex
|
|
43
|
+
value,
|
|
44
|
+
firstComponentIndex
|
|
48
45
|
};
|
|
49
46
|
};
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
value
|
|
53
|
-
firstComponentIndex
|
|
54
|
-
|
|
47
|
+
const getCYARowForGroup = (page, group, rows, onAction) => {
|
|
48
|
+
const {
|
|
49
|
+
value,
|
|
50
|
+
firstComponentIndex
|
|
51
|
+
} = getGroupValue(group, rows);
|
|
52
|
+
const row = {
|
|
55
53
|
pageId: page.id,
|
|
56
54
|
fieldId: group.id,
|
|
57
55
|
key: group.label,
|
|
58
56
|
required: group.required,
|
|
59
|
-
value
|
|
57
|
+
value,
|
|
60
58
|
action: (0, _getCYAAction.default)(false, page, onAction)
|
|
61
59
|
};
|
|
62
60
|
return {
|
|
63
|
-
row
|
|
61
|
+
row,
|
|
64
62
|
insertAt: firstComponentIndex
|
|
65
63
|
};
|
|
66
64
|
};
|
|
@@ -3,38 +3,38 @@
|
|
|
3
3
|
var _setupTests = require("../../setupTests");
|
|
4
4
|
var _getCYARowForGroup = _interopRequireDefault(require("./getCYARowForGroup"));
|
|
5
5
|
var _getCYARow = _interopRequireDefault(require("./getCYARow"));
|
|
6
|
-
function _interopRequireDefault(
|
|
6
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
7
7
|
// Local imports
|
|
8
8
|
|
|
9
|
-
describe('utils',
|
|
10
|
-
describe('CheckYourAnswers',
|
|
11
|
-
describe('getCYARowsForGroup',
|
|
12
|
-
it('should check address values block',
|
|
13
|
-
|
|
9
|
+
describe('utils', () => {
|
|
10
|
+
describe('CheckYourAnswers', () => {
|
|
11
|
+
describe('getCYARowsForGroup', () => {
|
|
12
|
+
it('should check address values block', () => {
|
|
13
|
+
const COMPONENT_ADDRESS = {
|
|
14
14
|
id: 'firstLineOfTheAddress',
|
|
15
15
|
fieldId: 'firstLineOfTheAddress',
|
|
16
16
|
label: 'address',
|
|
17
17
|
type: 'text'
|
|
18
18
|
};
|
|
19
|
-
|
|
19
|
+
const COMPONENT_TOWN = {
|
|
20
20
|
id: 'town',
|
|
21
21
|
fieldId: 'town',
|
|
22
22
|
label: 'Town',
|
|
23
23
|
type: 'text'
|
|
24
24
|
};
|
|
25
|
-
|
|
25
|
+
const COMPONENT_CITY = {
|
|
26
26
|
id: 'city',
|
|
27
27
|
fieldId: 'city',
|
|
28
28
|
label: 'City',
|
|
29
29
|
type: 'text'
|
|
30
30
|
};
|
|
31
|
-
|
|
31
|
+
const COMPONENT_POSTCODE = {
|
|
32
32
|
id: 'postCode',
|
|
33
33
|
fieldId: 'postCode',
|
|
34
34
|
label: 'postCode',
|
|
35
35
|
type: 'text'
|
|
36
36
|
};
|
|
37
|
-
|
|
37
|
+
const PAGE = {
|
|
38
38
|
components: [COMPONENT_ADDRESS, COMPONENT_TOWN, COMPONENT_CITY, COMPONENT_POSTCODE],
|
|
39
39
|
id: 'addressDetails',
|
|
40
40
|
fieldId: 'UK address',
|
|
@@ -52,14 +52,13 @@ describe('utils', function () {
|
|
|
52
52
|
postCode: 'SW1A 2AA'
|
|
53
53
|
}
|
|
54
54
|
};
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
container = _renderWithValidation.container;
|
|
55
|
+
const ON_ACTION = () => {};
|
|
56
|
+
const rows = PAGE.components.map(component => (0, _getCYARow.default)(PAGE, component, ON_ACTION));
|
|
57
|
+
const {
|
|
58
|
+
container
|
|
59
|
+
} = (0, _setupTests.renderWithValidation)((0, _getCYARowForGroup.default)(PAGE, PAGE.groups[0], rows, ON_ACTION).row.value);
|
|
61
60
|
expect(container.childNodes.length).toEqual(4);
|
|
62
|
-
|
|
61
|
+
const addressValues = container.childNodes;
|
|
63
62
|
expect(addressValues[0].childNodes[0].textContent).toEqual('10 Downing Street');
|
|
64
63
|
expect(addressValues[1].childNodes[0].textContent).toEqual('City of Westminster');
|
|
65
64
|
expect(addressValues[2].childNodes[0].textContent).toEqual('London');
|
|
@@ -10,15 +10,14 @@ var _getCYAAction = _interopRequireDefault(require("./getCYAAction"));
|
|
|
10
10
|
var _getCYARowsForContainer = _interopRequireDefault(require("./getCYARowsForContainer"));
|
|
11
11
|
var _setupContainerComponentsPath = _interopRequireDefault(require("../Component/setupContainerComponentsPath"));
|
|
12
12
|
var _showComponentCYA = _interopRequireDefault(require("./showComponentCYA"));
|
|
13
|
-
function _interopRequireDefault(
|
|
14
|
-
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
13
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
15
14
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
16
15
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
17
|
-
function _defineProperty(
|
|
18
|
-
function _toPropertyKey(
|
|
19
|
-
function _toPrimitive(
|
|
16
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
17
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
18
|
+
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } // Global imports
|
|
20
19
|
// Local imports
|
|
21
|
-
|
|
20
|
+
const getEntryToCollectionRow = (page, onAction) => {
|
|
22
21
|
var _page$components$0$la;
|
|
23
22
|
return [{
|
|
24
23
|
pageId: page.id,
|
|
@@ -27,28 +26,24 @@ var getEntryToCollectionRow = function getEntryToCollectionRow(page, onAction) {
|
|
|
27
26
|
action: (0, _getCYAAction.default)(false, page, onAction)
|
|
28
27
|
}];
|
|
29
28
|
};
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
};
|
|
46
|
-
};
|
|
47
|
-
var getTitleRowForItem = function getTitleRowForItem(collection, item, pageId, labelCount, fullPath) {
|
|
48
|
-
var labels = _objectSpread(_objectSpread({}, _models.CollectionLabels), collection.labels);
|
|
29
|
+
const getContainerForItem = (collection, item, labelCount, fullPath) => ({
|
|
30
|
+
id: item.id,
|
|
31
|
+
fieldId: item.id,
|
|
32
|
+
type: _models.ComponentTypes.CONTAINER,
|
|
33
|
+
required: collection.required,
|
|
34
|
+
full_path: fullPath,
|
|
35
|
+
components: collection.item.map(component => _objectSpread(_objectSpread({}, component), {}, {
|
|
36
|
+
label: _copReactComponents.Utils.interpolateString(component.label, _objectSpread(_objectSpread({}, item), {}, {
|
|
37
|
+
index: labelCount
|
|
38
|
+
})),
|
|
39
|
+
full_path: "".concat(fullPath, ".").concat(component.fieldId)
|
|
40
|
+
}))
|
|
41
|
+
});
|
|
42
|
+
const getTitleRowForItem = (collection, item, pageId, labelCount, fullPath) => {
|
|
43
|
+
const labels = _objectSpread(_objectSpread({}, _models.CollectionLabels), collection.labels);
|
|
49
44
|
if (labels.item) {
|
|
50
45
|
return {
|
|
51
|
-
pageId
|
|
46
|
+
pageId,
|
|
52
47
|
fieldId: collection.fieldId,
|
|
53
48
|
full_path: fullPath,
|
|
54
49
|
key: _copReactComponents.Utils.interpolateString(labels.item, _objectSpread(_objectSpread({}, item), {}, {
|
|
@@ -60,17 +55,15 @@ var getTitleRowForItem = function getTitleRowForItem(collection, item, pageId, l
|
|
|
60
55
|
}
|
|
61
56
|
return null;
|
|
62
57
|
};
|
|
63
|
-
|
|
58
|
+
const getCYARowsForCollection = (page, collection, items, onAction, fnOverride) => {
|
|
64
59
|
if (Array.isArray(items) && items.length && (0, _showComponentCYA.default)(collection, page.formData)) {
|
|
65
|
-
return items.flatMap(
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
60
|
+
return items.flatMap((item, index) => {
|
|
61
|
+
const labelCount = (collection.countOffset || 0) + index + 1;
|
|
62
|
+
const fullPath = "".concat(collection.full_path || collection.fieldId, "[").concat(index, "]");
|
|
63
|
+
let container = getContainerForItem(collection, item, labelCount, fullPath);
|
|
69
64
|
container = (0, _setupContainerComponentsPath.default)(container);
|
|
70
65
|
return [getTitleRowForItem(collection, item, page.id, labelCount, fullPath)].concat((0, _getCYARowsForContainer.default)(page, container, item, onAction, fnOverride));
|
|
71
|
-
}).filter(
|
|
72
|
-
return !!r;
|
|
73
|
-
});
|
|
66
|
+
}).filter(r => !!r);
|
|
74
67
|
}
|
|
75
68
|
return getEntryToCollectionRow(page, onAction);
|
|
76
69
|
};
|