@ukhomeoffice/cop-react-form-renderer 6.7.0-alpha → 6.11.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/dist/components/CheckYourAnswers/Answer.js +22 -16
- package/dist/components/CheckYourAnswers/Answer.test.js +180 -92
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +137 -103
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +861 -463
- package/dist/components/CollectionPage/CollectionPage.js +63 -73
- package/dist/components/CollectionPage/CollectionPage.test.js +366 -316
- package/dist/components/CollectionSummary/BannerStrip.js +13 -13
- package/dist/components/CollectionSummary/BannerStrip.test.js +76 -80
- package/dist/components/CollectionSummary/CollectionSummary.js +126 -99
- package/dist/components/CollectionSummary/CollectionSummary.test.js +188 -152
- package/dist/components/CollectionSummary/Confirmation.js +12 -14
- package/dist/components/CollectionSummary/Confirmation.test.js +63 -68
- package/dist/components/CollectionSummary/RenderListView.js +52 -46
- package/dist/components/CollectionSummary/RenderListView.scss +1 -1
- package/dist/components/CollectionSummary/RenderListView.test.js +77 -78
- package/dist/components/CollectionSummary/SummaryCard.js +152 -110
- package/dist/components/CollectionSummary/SummaryCard.test.js +1018 -929
- package/dist/components/CollectionSummary/SummaryCardDetails.js +137 -94
- package/dist/components/CollectionSummary/SummaryCardDetails.scss +13 -4
- package/dist/components/CollectionSummary/SummaryCardDetails.test.js +331 -128
- package/dist/components/CollectionSummary/SummaryCardValidationContext.js +35 -30
- package/dist/components/CollectionSummary/SummaryCardValidationContext.test.js +74 -62
- package/dist/components/FormComponent/Collection.js +108 -74
- package/dist/components/FormComponent/Collection.test.js +1081 -909
- package/dist/components/FormComponent/Container.js +39 -40
- package/dist/components/FormComponent/Container.test.js +412 -312
- package/dist/components/FormComponent/FormComponent.js +72 -69
- package/dist/components/FormComponent/FormComponent.test.js +414 -353
- package/dist/components/FormComponent/helpers/addLabel.js +7 -4
- package/dist/components/FormComponent/helpers/getComponentDisabled.js +1 -1
- package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +7 -7
- package/dist/components/FormComponent/helpers/getComponentError.js +5 -3
- package/dist/components/FormComponent/helpers/getComponentError.test.js +14 -14
- package/dist/components/FormComponent/helpers/getComponentFieldSet.js +4 -3
- package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +6 -6
- package/dist/components/FormComponent/helpers/index.js +4 -4
- package/dist/components/FormPage/FormPage.js +80 -65
- package/dist/components/FormPage/FormPage.test.js +163 -127
- package/dist/components/FormRenderer/FormRenderer.js +180 -143
- package/dist/components/FormRenderer/FormRenderer.test.js +1115 -730
- package/dist/components/FormRenderer/handlers/cyaAction.js +2 -2
- package/dist/components/FormRenderer/handlers/getPageId.js +3 -1
- package/dist/components/FormRenderer/handlers/getPageId.test.js +14 -14
- package/dist/components/FormRenderer/handlers/handlers.test.js +32 -32
- package/dist/components/FormRenderer/handlers/index.js +1 -1
- package/dist/components/FormRenderer/handlers/navigate.js +3 -3
- 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 +15 -15
- package/dist/components/FormRenderer/helpers/canCYASubmit.js +3 -1
- package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +20 -16
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +22 -17
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +16 -16
- package/dist/components/FormRenderer/helpers/getCYA.js +5 -3
- package/dist/components/FormRenderer/helpers/getCYA.test.js +11 -11
- package/dist/components/FormRenderer/helpers/getFormState.js +7 -5
- package/dist/components/FormRenderer/helpers/getFormState.test.js +10 -10
- package/dist/components/FormRenderer/helpers/getNextPageId.js +24 -13
- package/dist/components/FormRenderer/helpers/getNextPageId.test.js +67 -67
- package/dist/components/FormRenderer/helpers/getPage.js +4 -2
- package/dist/components/FormRenderer/helpers/getPage.test.js +11 -11
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +9 -7
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +14 -14
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +5 -5
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +97 -103
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +60 -62
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +78 -71
- package/dist/components/FormRenderer/helpers/index.js +1 -1
- package/dist/components/FormRenderer/onCYAAction.js +51 -59
- package/dist/components/FormRenderer/onCYAAction.test.js +152 -164
- package/dist/components/FormRenderer/onPageAction.js +39 -43
- package/dist/components/FormRenderer/onPageAction.test.js +208 -223
- package/dist/components/FormRenderer/onTaskAction.js +13 -9
- package/dist/components/FormRenderer/onTaskAction.test.js +88 -93
- package/dist/components/PageActions/ActionButton.js +15 -12
- package/dist/components/PageActions/ActionButton.test.js +78 -56
- package/dist/components/PageActions/PageActions.js +10 -10
- package/dist/components/PageActions/PageActions.test.js +115 -86
- package/dist/components/SummaryList/GroupAction.js +17 -9
- package/dist/components/SummaryList/GroupAction.test.js +33 -37
- package/dist/components/SummaryList/RowAction.js +16 -11
- package/dist/components/SummaryList/RowAction.test.js +33 -37
- package/dist/components/SummaryList/SummaryList.js +34 -21
- package/dist/components/SummaryList/SummaryList.scss +15 -0
- package/dist/components/SummaryList/SummaryList.test.js +226 -143
- package/dist/components/SummaryList/SummaryListHeadingRow.js +4 -6
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.js +53 -0
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.scss +38 -0
- package/dist/components/SummaryList/SummaryListRow.js +4 -6
- package/dist/components/SummaryList/SummaryListTitleRow.js +3 -5
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +5 -3
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +22 -22
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +5 -3
- package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +22 -22
- package/dist/components/SummaryList/helpers/index.js +1 -1
- package/dist/components/TaskList/Task.js +29 -19
- package/dist/components/TaskList/Task.test.js +76 -83
- package/dist/components/TaskList/TaskList.js +92 -49
- package/dist/components/TaskList/TaskList.scss +24 -0
- package/dist/components/TaskList/TaskList.test.js +255 -113
- package/dist/components/TaskList/TaskState.js +5 -7
- package/dist/components/TaskList/TaskState.test.js +45 -52
- package/dist/components/index.js +7 -7
- package/dist/context/HooksContext/HooksContext.js +80 -57
- package/dist/context/HooksContext/HooksContext.test.js +35 -26
- package/dist/context/HooksContext/index.js +4 -3
- package/dist/context/ValidationContext/ValidationContext.js +94 -43
- package/dist/context/ValidationContext/ValidationContext.test.js +68 -56
- package/dist/context/ValidationContext/index.js +4 -3
- package/dist/context/index.js +2 -2
- package/dist/hooks/index.js +10 -9
- package/dist/hooks/useAxios.js +40 -14
- package/dist/hooks/useGetRequest.js +97 -61
- package/dist/hooks/useHooks.js +3 -1
- package/dist/hooks/useRefData.js +39 -26
- package/dist/hooks/useValidation.js +3 -1
- package/dist/index.js +14 -13
- 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 +38 -44
- package/dist/models/TaskStates.js +28 -29
- package/dist/models/index.js +9 -9
- package/dist/setupTests.js +31 -30
- package/dist/utils/CheckYourAnswers/getCYAAction.js +5 -5
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +54 -52
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +25 -15
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +35 -33
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +31 -17
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +44 -42
- package/dist/utils/CheckYourAnswers/getCYARow.js +6 -6
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +86 -86
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +24 -18
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +16 -15
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +36 -33
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +61 -58
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +108 -87
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +281 -162
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +20 -25
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +97 -103
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +18 -13
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +76 -70
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.js +42 -0
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.test.js +56 -0
- package/dist/utils/CheckYourAnswers/index.js +1 -1
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +4 -4
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +25 -25
- package/dist/utils/CollectionPage/addCollectionPageEntry.js +2 -2
- package/dist/utils/CollectionPage/addCollectionPageEntry.test.js +5 -5
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +2 -2
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +18 -17
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +22 -12
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +38 -47
- package/dist/utils/CollectionPage/getCollectionPageActiveId.js +2 -2
- package/dist/utils/CollectionPage/getCollectionPageActiveId.test.js +10 -10
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +11 -7
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +22 -22
- package/dist/utils/CollectionPage/getCollectionPageData.js +12 -8
- package/dist/utils/CollectionPage/getCollectionPageData.test.js +19 -19
- package/dist/utils/CollectionPage/getErrorsForCollection.js +24 -24
- package/dist/utils/CollectionPage/getErrorsForCollection.test.js +22 -20
- package/dist/utils/CollectionPage/getQuickEditPage.js +31 -35
- package/dist/utils/CollectionPage/getQuickEditPage.test.js +27 -15
- package/dist/utils/CollectionPage/index.js +1 -1
- package/dist/utils/CollectionPage/mergeCollectionPages.js +43 -31
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +26 -26
- package/dist/utils/CollectionPage/removeCollectionPageEntry.js +6 -4
- package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +10 -10
- package/dist/utils/CollectionPage/setCollectionPageData.js +16 -10
- package/dist/utils/CollectionPage/setCollectionPageData.test.js +24 -24
- package/dist/utils/Component/addShowWhen.js +8 -4
- package/dist/utils/Component/addShowWhen.test.js +37 -37
- package/dist/utils/Component/applyToComponentTree.js +18 -18
- package/dist/utils/Component/applyToComponentTree.test.js +32 -27
- package/dist/utils/Component/cleanAttributes.js +13 -10
- package/dist/utils/Component/cleanAttributes.test.js +18 -17
- package/dist/utils/Component/elevateNestedComponents.js +7 -6
- package/dist/utils/Component/elevateNestedComponents.test.js +68 -30
- package/dist/utils/Component/getComponent.js +94 -88
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +17 -18
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +59 -46
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +48 -39
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +33 -23
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +18 -20
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +22 -17
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +25 -20
- package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +9 -10
- package/dist/utils/Component/getComponentTests/getComponent.html.test.js +15 -17
- package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +8 -9
- package/dist/utils/Component/getComponentTests/getComponent.list.test.js +15 -17
- package/dist/utils/Component/getComponentTests/getComponent.multifile.test.js +26 -22
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +175 -155
- package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +15 -17
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +22 -17
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +72 -57
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +22 -17
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +22 -17
- package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +38 -31
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +29 -20
- package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +2 -2
- package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +8 -9
- package/dist/utils/Component/getDefaultValue.js +8 -6
- package/dist/utils/Component/getDefaultValue.test.js +12 -12
- package/dist/utils/Component/getDefaultValueFromConfig.js +21 -22
- package/dist/utils/Component/getDefaultValueFromConfig.test.js +31 -31
- package/dist/utils/Component/index.js +1 -1
- package/dist/utils/Component/isEditable.js +4 -2
- package/dist/utils/Component/isEditable.test.js +15 -14
- package/dist/utils/Component/optionIsSelected.js +6 -1
- package/dist/utils/Component/optionIsSelected.test.js +35 -9
- package/dist/utils/Component/setupContainerComponentsPath.js +29 -27
- package/dist/utils/Component/setupContainerComponentsPath.test.js +11 -11
- package/dist/utils/Component/showComponent.js +1 -1
- package/dist/utils/Component/showComponent.test.js +28 -28
- package/dist/utils/Component/wrapInFormGroup.js +2 -2
- package/dist/utils/Condition/index.js +1 -1
- package/dist/utils/Condition/meetsAllConditions.js +8 -8
- package/dist/utils/Condition/meetsAllConditions.test.js +20 -20
- package/dist/utils/Condition/meetsCondition.js +25 -16
- package/dist/utils/Condition/meetsCondition.test.js +402 -402
- package/dist/utils/Condition/meetsOneCondition.js +5 -5
- package/dist/utils/Condition/meetsOneCondition.test.js +16 -16
- package/dist/utils/Condition/setupConditions.js +18 -13
- package/dist/utils/Condition/setupConditions.test.js +7 -7
- package/dist/utils/Container/getEditableComponents.js +5 -3
- package/dist/utils/Container/getEditableComponents.test.js +45 -43
- package/dist/utils/Container/index.js +1 -1
- package/dist/utils/Container/setupNesting.js +20 -16
- package/dist/utils/Container/setupNesting.test.js +30 -27
- package/dist/utils/Container/showContainer.js +7 -3
- package/dist/utils/Container/showContainer.test.js +30 -30
- package/dist/utils/Data/applyFormula.js +48 -38
- package/dist/utils/Data/applyFormula.test.js +20 -20
- package/dist/utils/Data/getAutocompleteSource.js +26 -18
- package/dist/utils/Data/getAutocompleteSource.test.js +86 -80
- package/dist/utils/Data/getDataPath.js +28 -18
- package/dist/utils/Data/getDataPath.test.js +12 -12
- package/dist/utils/Data/getOptions.js +30 -24
- package/dist/utils/Data/getOptions.test.js +27 -27
- package/dist/utils/Data/getSourceData.js +19 -6
- package/dist/utils/Data/getSourceData.test.js +80 -84
- package/dist/utils/Data/index.js +1 -1
- package/dist/utils/Data/nestInRefdataOptions.js +16 -9
- package/dist/utils/Data/nestInRefdataOptions.test.js +16 -16
- package/dist/utils/Data/refDataToOptions.js +13 -10
- package/dist/utils/Data/refDataToOptions.test.js +19 -19
- package/dist/utils/Data/setDataItem.js +8 -7
- package/dist/utils/Data/setDataItem.test.js +37 -37
- package/dist/utils/Data/setupFormData.js +21 -13
- package/dist/utils/Data/setupFormData.test.js +50 -51
- package/dist/utils/Data/setupRefDataUrlForComponent.js +26 -20
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +24 -24
- package/dist/utils/FormPage/applyConditionalProperties.js +9 -5
- package/dist/utils/FormPage/applyConditionalProperties.test.js +18 -15
- package/dist/utils/FormPage/getConditionalText.js +3 -3
- package/dist/utils/FormPage/getConditionalText.test.js +29 -29
- package/dist/utils/FormPage/getFormPage.js +16 -15
- package/dist/utils/FormPage/getFormPage.test.js +46 -47
- package/dist/utils/FormPage/getFormPages.js +12 -7
- package/dist/utils/FormPage/getFormPages.test.js +23 -20
- package/dist/utils/FormPage/getPageActions.js +15 -9
- package/dist/utils/FormPage/getPageActions.test.js +32 -32
- package/dist/utils/FormPage/getParagraphFromText.js +7 -5
- package/dist/utils/FormPage/getParagraphFromText.test.js +6 -6
- package/dist/utils/FormPage/index.js +4 -2
- package/dist/utils/FormPage/showFormPage.js +7 -3
- package/dist/utils/FormPage/showFormPage.test.js +32 -32
- package/dist/utils/FormPage/showFormPageCYA.js +1 -1
- package/dist/utils/FormPage/showFormPageCYA.test.js +8 -8
- package/dist/utils/FormPage/useComponent.js +28 -21
- package/dist/utils/FormPage/useComponent.test.js +79 -77
- package/dist/utils/Format/formatData.js +1 -1
- package/dist/utils/Format/formatData.test.js +18 -18
- package/dist/utils/Format/formatDataForComponent.js +6 -5
- package/dist/utils/Format/formatDataForComponent.test.js +78 -50
- package/dist/utils/Format/formatDataForForm.js +8 -6
- package/dist/utils/Format/formatDataForForm.test.js +16 -13
- package/dist/utils/Format/formatDataForPage.js +5 -4
- package/dist/utils/Format/formatDataForPage.test.js +25 -20
- package/dist/utils/Format/index.js +1 -1
- package/dist/utils/Hub/getFormHub.js +1 -1
- package/dist/utils/Hub/getFormHub.test.js +31 -28
- package/dist/utils/Hub/index.js +1 -1
- 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 +16 -24
- package/dist/utils/Meta/documents/index.js +1 -1
- package/dist/utils/Meta/documents/setDocumentsForField.js +16 -14
- package/dist/utils/Meta/documents/setDocumentsForField.test.js +34 -68
- package/dist/utils/Meta/index.js +1 -1
- package/dist/utils/Operate/checkValueIsTruthy.js +2 -2
- package/dist/utils/Operate/checkValueIsTruthy.test.js +16 -16
- package/dist/utils/Operate/getFirstOf.js +5 -5
- package/dist/utils/Operate/getFirstOf.test.js +31 -31
- package/dist/utils/Operate/getIndexOfMatchingValueIn.js +10 -10
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +52 -46
- package/dist/utils/Operate/getLength.js +50 -0
- package/dist/utils/Operate/getLength.test.js +89 -0
- package/dist/utils/Operate/index.js +1 -1
- package/dist/utils/Operate/persistValueInFormData.js +3 -3
- package/dist/utils/Operate/persistValueInFormData.test.js +20 -22
- package/dist/utils/Operate/runPageOperations.js +9 -7
- package/dist/utils/Operate/runPageOperations.test.js +36 -35
- package/dist/utils/Operate/setValueInFormData.js +2 -2
- package/dist/utils/Operate/setValueInFormData.test.js +16 -16
- package/dist/utils/Operate/shouldRun.js +6 -6
- package/dist/utils/Operate/shouldRun.test.js +27 -21
- package/dist/utils/Validate/additional/conditionallyRequired.js +4 -4
- package/dist/utils/Validate/additional/conditionallyRequired.test.js +18 -18
- package/dist/utils/Validate/additional/index.js +6 -6
- package/dist/utils/Validate/additional/index.test.js +12 -12
- package/dist/utils/Validate/additional/mustBeAfter.js +2 -2
- package/dist/utils/Validate/additional/mustBeAfter.test.js +40 -40
- package/dist/utils/Validate/additional/mustBeBefore.js +2 -2
- package/dist/utils/Validate/additional/mustBeBefore.test.js +28 -28
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +11 -7
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +41 -37
- package/dist/utils/Validate/additional/mustBeGreaterThan.js +2 -2
- package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +18 -18
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +2 -2
- package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +12 -12
- package/dist/utils/Validate/additional/mustBeInThePast.js +3 -3
- package/dist/utils/Validate/additional/mustBeInThePast.test.js +12 -12
- package/dist/utils/Validate/additional/mustBeLessThan.js +2 -2
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +17 -17
- package/dist/utils/Validate/additional/mustBeLongerThan.js +1 -1
- package/dist/utils/Validate/additional/mustBeLongerThan.test.js +16 -16
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +2 -2
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +20 -20
- package/dist/utils/Validate/additional/mustBeShorterThan.js +1 -1
- package/dist/utils/Validate/additional/mustBeShorterThan.test.js +16 -16
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.js +4 -4
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.test.js +39 -35
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +2 -2
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +16 -14
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +1 -1
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +12 -12
- package/dist/utils/Validate/additional/mustNotContainSql.js +4 -3
- package/dist/utils/Validate/additional/mustNotContainSql.test.js +14 -14
- package/dist/utils/Validate/additional/mustSelectOnlyOne.js +2 -2
- package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +26 -28
- package/dist/utils/Validate/additional/utils.js +22 -9
- package/dist/utils/Validate/index.js +1 -1
- package/dist/utils/Validate/validateCollection.js +25 -19
- package/dist/utils/Validate/validateCollection.test.js +66 -74
- package/dist/utils/Validate/validateComponent.js +21 -18
- package/dist/utils/Validate/validateComponent.test.js +176 -166
- package/dist/utils/Validate/validateContainer.js +20 -15
- package/dist/utils/Validate/validateContainer.test.js +52 -58
- package/dist/utils/Validate/validateDate.js +21 -15
- package/dist/utils/Validate/validateDate.test.js +32 -31
- package/dist/utils/Validate/validateEmail.js +8 -6
- package/dist/utils/Validate/validateEmail.test.js +25 -25
- package/dist/utils/Validate/validateMultifile.js +7 -5
- package/dist/utils/Validate/validateMultifile.test.js +18 -17
- package/dist/utils/Validate/validatePage.js +22 -19
- package/dist/utils/Validate/validatePage.test.js +203 -215
- package/dist/utils/Validate/validateRegex.js +5 -3
- package/dist/utils/Validate/validateRegex.test.js +14 -14
- package/dist/utils/Validate/validateRequired.js +6 -4
- package/dist/utils/Validate/validateRequired.test.js +18 -18
- package/dist/utils/Validate/validateTextArea.js +6 -4
- package/dist/utils/Validate/validateTextArea.test.js +20 -20
- package/dist/utils/Validate/validateTime.js +26 -11
- package/dist/utils/Validate/validateTime.test.js +62 -16
- package/dist/utils/index.js +9 -7
- package/package.json +2 -2
- package/dist/utils/CheckYourAnswers/getComponentRowForCYA.js +0 -37
- package/dist/utils/CheckYourAnswers/getComponentRowForCYA.test.js +0 -41
|
@@ -13,8 +13,8 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
13
13
|
* @param {string} currentPageId The current pageId.
|
|
14
14
|
* @param {Function} onChange The handler to call if the pageId is different to the currentPageId.
|
|
15
15
|
*/
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
var cyaAction = function cyaAction(page, currentPageId, onChange) {
|
|
17
|
+
var pageId = (0, _getPageId.default)(page.action, page.pageId);
|
|
18
18
|
if (pageId !== currentPageId) {
|
|
19
19
|
onChange(pageId);
|
|
20
20
|
}
|
|
@@ -10,5 +10,7 @@ exports.default = void 0;
|
|
|
10
10
|
* @param {string} pageId The id of the page on which the action was invoked.
|
|
11
11
|
* @returns A page id.
|
|
12
12
|
*/
|
|
13
|
-
|
|
13
|
+
var getPageId = function getPageId(action, pageId) {
|
|
14
|
+
return (action === null || action === void 0 ? void 0 : action.page) || pageId;
|
|
15
|
+
};
|
|
14
16
|
var _default = exports.default = getPageId;
|
|
@@ -4,26 +4,26 @@ var _getPageId = _interopRequireDefault(require("./getPageId"));
|
|
|
4
4
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
5
5
|
// Local imports
|
|
6
6
|
|
|
7
|
-
describe('components', ()
|
|
8
|
-
describe('FormRenderer', ()
|
|
9
|
-
describe('handlers', ()
|
|
10
|
-
describe('getPageId', ()
|
|
11
|
-
it('should return the pageId when the action is null', ()
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
describe('components', function () {
|
|
8
|
+
describe('FormRenderer', function () {
|
|
9
|
+
describe('handlers', function () {
|
|
10
|
+
describe('getPageId', function () {
|
|
11
|
+
it('should return the pageId when the action is null', function () {
|
|
12
|
+
var PAGE_ID = 'alpha';
|
|
13
|
+
var ACTION = null;
|
|
14
14
|
expect((0, _getPageId.default)(ACTION, PAGE_ID)).toEqual(PAGE_ID);
|
|
15
15
|
});
|
|
16
|
-
it('should return the pageId when the action contains no page', ()
|
|
17
|
-
|
|
18
|
-
|
|
16
|
+
it('should return the pageId when the action contains no page', function () {
|
|
17
|
+
var PAGE_ID = 'alpha';
|
|
18
|
+
var ACTION = {
|
|
19
19
|
id: 'bravo'
|
|
20
20
|
};
|
|
21
21
|
expect((0, _getPageId.default)(ACTION, PAGE_ID)).toEqual(PAGE_ID);
|
|
22
22
|
});
|
|
23
|
-
it('should return the page when provided', ()
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
23
|
+
it('should return the page when provided', function () {
|
|
24
|
+
var NAVIGATE_TO = 'delta';
|
|
25
|
+
var PAGE_ID = 'alpha';
|
|
26
|
+
var ACTION = {
|
|
27
27
|
page: NAVIGATE_TO
|
|
28
28
|
};
|
|
29
29
|
expect((0, _getPageId.default)(ACTION, PAGE_ID)).toEqual(NAVIGATE_TO);
|
|
@@ -4,30 +4,30 @@ var _ = _interopRequireDefault(require("."));
|
|
|
4
4
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
5
5
|
// Local imports
|
|
6
6
|
|
|
7
|
-
describe('components', ()
|
|
8
|
-
describe('FormRenderer', ()
|
|
9
|
-
describe('handlers', ()
|
|
10
|
-
describe('cyaAction', ()
|
|
11
|
-
it('should not call the onChange method when the page is unchanged', ()
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
describe('components', function () {
|
|
8
|
+
describe('FormRenderer', function () {
|
|
9
|
+
describe('handlers', function () {
|
|
10
|
+
describe('cyaAction', function () {
|
|
11
|
+
it('should not call the onChange method when the page is unchanged', function () {
|
|
12
|
+
var CURRENT_PAGE_ID = 'alpha';
|
|
13
|
+
var PAGE = {
|
|
14
14
|
pageId: CURRENT_PAGE_ID
|
|
15
15
|
};
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
var ON_CHANGE_CALLS = [];
|
|
17
|
+
var ON_CHANGE = function ON_CHANGE(pageId) {
|
|
18
18
|
ON_CHANGE_CALLS.push(pageId);
|
|
19
19
|
};
|
|
20
20
|
_.default.cyaAction(PAGE, CURRENT_PAGE_ID, ON_CHANGE);
|
|
21
21
|
expect(ON_CHANGE_CALLS.length).toEqual(0);
|
|
22
22
|
});
|
|
23
|
-
it('should call the onChange method when the page has changed', ()
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
23
|
+
it('should call the onChange method when the page has changed', function () {
|
|
24
|
+
var CURRENT_PAGE_ID = 'alpha';
|
|
25
|
+
var NEW_PAGE_ID = 'bravo';
|
|
26
|
+
var PAGE = {
|
|
27
27
|
pageId: NEW_PAGE_ID
|
|
28
28
|
};
|
|
29
|
-
|
|
30
|
-
|
|
29
|
+
var ON_CHANGE_CALLS = [];
|
|
30
|
+
var ON_CHANGE = function ON_CHANGE(pageId) {
|
|
31
31
|
ON_CHANGE_CALLS.push(pageId);
|
|
32
32
|
};
|
|
33
33
|
_.default.cyaAction(PAGE, CURRENT_PAGE_ID, ON_CHANGE);
|
|
@@ -35,27 +35,27 @@ describe('components', () => {
|
|
|
35
35
|
expect(ON_CHANGE_CALLS[0]).toEqual(NEW_PAGE_ID);
|
|
36
36
|
});
|
|
37
37
|
});
|
|
38
|
-
describe('navigate', ()
|
|
39
|
-
it('should not call the onNavigate method when the page is unchanged', ()
|
|
40
|
-
|
|
41
|
-
|
|
38
|
+
describe('navigate', function () {
|
|
39
|
+
it('should not call the onNavigate method when the page is unchanged', function () {
|
|
40
|
+
var CURRENT_PAGE_ID = 'alpha';
|
|
41
|
+
var ACTION = {
|
|
42
42
|
page: CURRENT_PAGE_ID
|
|
43
43
|
};
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
var ON_NAVIGATE_CALLS = [];
|
|
45
|
+
var ON_NAVIGATE = function ON_NAVIGATE(pageId) {
|
|
46
46
|
ON_NAVIGATE_CALLS.push(pageId);
|
|
47
47
|
};
|
|
48
48
|
_.default.navigate(ACTION, CURRENT_PAGE_ID, ON_NAVIGATE);
|
|
49
49
|
expect(ON_NAVIGATE_CALLS.length).toEqual(0);
|
|
50
50
|
});
|
|
51
|
-
it('should call the onNavigate method when the page has changed', ()
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
51
|
+
it('should call the onNavigate method when the page has changed', function () {
|
|
52
|
+
var CURRENT_PAGE_ID = 'alpha';
|
|
53
|
+
var NEW_PAGE_ID = 'bravo';
|
|
54
|
+
var ACTION = {
|
|
55
55
|
page: NEW_PAGE_ID
|
|
56
56
|
};
|
|
57
|
-
|
|
58
|
-
|
|
57
|
+
var ON_NAVIGATE_CALLS = [];
|
|
58
|
+
var ON_NAVIGATE = function ON_NAVIGATE(pageId) {
|
|
59
59
|
ON_NAVIGATE_CALLS.push(pageId);
|
|
60
60
|
};
|
|
61
61
|
_.default.navigate(ACTION, CURRENT_PAGE_ID, ON_NAVIGATE);
|
|
@@ -63,13 +63,13 @@ describe('components', () => {
|
|
|
63
63
|
expect(ON_NAVIGATE_CALLS[0]).toEqual(NEW_PAGE_ID);
|
|
64
64
|
});
|
|
65
65
|
});
|
|
66
|
-
describe('submissionError', ()
|
|
67
|
-
it('should call the onError method with the same errors', ()
|
|
68
|
-
|
|
69
|
-
|
|
66
|
+
describe('submissionError', function () {
|
|
67
|
+
it('should call the onError method with the same errors', function () {
|
|
68
|
+
var ON_ERROR_CALLS = [];
|
|
69
|
+
var ON_ERROR = function ON_ERROR(errors) {
|
|
70
70
|
ON_ERROR_CALLS.push(errors);
|
|
71
71
|
};
|
|
72
|
-
|
|
72
|
+
var ERRORS = ['alpha', 'bravo', 'charlie'];
|
|
73
73
|
_.default.submissionError(ERRORS, ON_ERROR);
|
|
74
74
|
expect(ON_ERROR_CALLS.length).toEqual(1);
|
|
75
75
|
expect(ON_ERROR_CALLS[0]).toEqual(ERRORS);
|
|
@@ -8,7 +8,7 @@ var _cyaAction = _interopRequireDefault(require("./cyaAction"));
|
|
|
8
8
|
var _navigate = _interopRequireDefault(require("./navigate"));
|
|
9
9
|
var _submissionError = _interopRequireDefault(require("./submissionError"));
|
|
10
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
-
|
|
11
|
+
var handlers = {
|
|
12
12
|
cyaAction: _cyaAction.default,
|
|
13
13
|
navigate: _navigate.default,
|
|
14
14
|
submissionError: _submissionError.default
|
|
@@ -14,9 +14,9 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
14
14
|
* @param {Function} onNavigate The handler to call if the pageId is different to the currentPageId.
|
|
15
15
|
* @param {object|undefined} state State to pass to the handler on change
|
|
16
16
|
*/
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
17
|
+
var navigate = function navigate(action, currentPageId, onNavigate) {
|
|
18
|
+
var state = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : undefined;
|
|
19
|
+
var pageId = (0, _getPageId.default)(action, currentPageId);
|
|
20
20
|
if (pageId !== currentPageId) {
|
|
21
21
|
onNavigate(pageId, state);
|
|
22
22
|
}
|
|
@@ -9,7 +9,7 @@ exports.default = void 0;
|
|
|
9
9
|
* @param {Array} errors The errors returned by the backend when submitting.
|
|
10
10
|
* @param {Function} onError The handler to call with the formatted errors.
|
|
11
11
|
*/
|
|
12
|
-
|
|
12
|
+
var submissionError = function submissionError(errors, onError) {
|
|
13
13
|
// For now, simply pass them straight through as we don't yet know
|
|
14
14
|
// what the errors will look like.
|
|
15
15
|
onError(errors);
|
|
@@ -14,7 +14,7 @@ exports.default = void 0;
|
|
|
14
14
|
* @param {Array} errors An array of existing errors.
|
|
15
15
|
* @returns A boolean where `true` means the action can proceed and `false` means it cannot.
|
|
16
16
|
*/
|
|
17
|
-
|
|
17
|
+
var canActionProceed = function canActionProceed(action, page, pageValidator, errors) {
|
|
18
18
|
if (action.validate) {
|
|
19
19
|
if (action.checkPreexistingErrors && errors.length !== 0) {
|
|
20
20
|
return false;
|
|
@@ -5,18 +5,18 @@ var _canActionProceed = _interopRequireDefault(require("./canActionProceed"));
|
|
|
5
5
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
6
6
|
// Local imports
|
|
7
7
|
|
|
8
|
-
describe('components.FormRenderer.helpers.canActionProceed', ()
|
|
9
|
-
it('should return true when the action does not require validation', ()
|
|
10
|
-
|
|
8
|
+
describe('components.FormRenderer.helpers.canActionProceed', function () {
|
|
9
|
+
it('should return true when the action does not require validation', function () {
|
|
10
|
+
var ACTION = {
|
|
11
11
|
validate: false
|
|
12
12
|
};
|
|
13
13
|
expect((0, _canActionProceed.default)(ACTION, {}, _Validate.default.page)).toBeTruthy();
|
|
14
14
|
});
|
|
15
|
-
it('should return true when the page is valid', ()
|
|
16
|
-
|
|
15
|
+
it('should return true when the page is valid', function () {
|
|
16
|
+
var ACTION = {
|
|
17
17
|
validate: true
|
|
18
18
|
};
|
|
19
|
-
|
|
19
|
+
var PAGE = {
|
|
20
20
|
components: [{
|
|
21
21
|
id: 'a',
|
|
22
22
|
fieldId: 'a',
|
|
@@ -29,11 +29,11 @@ describe('components.FormRenderer.helpers.canActionProceed', () => {
|
|
|
29
29
|
};
|
|
30
30
|
expect((0, _canActionProceed.default)(ACTION, PAGE, _Validate.default.page, [])).toBeTruthy();
|
|
31
31
|
});
|
|
32
|
-
it('should return false when the page is invalid', ()
|
|
33
|
-
|
|
32
|
+
it('should return false when the page is invalid', function () {
|
|
33
|
+
var ACTION = {
|
|
34
34
|
validate: true
|
|
35
35
|
};
|
|
36
|
-
|
|
36
|
+
var PAGE = {
|
|
37
37
|
components: [{
|
|
38
38
|
id: 'a',
|
|
39
39
|
fieldId: 'a',
|
|
@@ -44,12 +44,12 @@ describe('components.FormRenderer.helpers.canActionProceed', () => {
|
|
|
44
44
|
};
|
|
45
45
|
expect((0, _canActionProceed.default)(ACTION, PAGE, _Validate.default.page, [])).toBeFalsy();
|
|
46
46
|
});
|
|
47
|
-
it('should return false when the action has checkPreexistingErrors and errors is not empty', ()
|
|
48
|
-
|
|
47
|
+
it('should return false when the action has checkPreexistingErrors and errors is not empty', function () {
|
|
48
|
+
var ACTION = {
|
|
49
49
|
validate: true,
|
|
50
50
|
checkPreexistingErrors: true
|
|
51
51
|
};
|
|
52
|
-
|
|
52
|
+
var PAGE = {
|
|
53
53
|
components: [{
|
|
54
54
|
id: 'a',
|
|
55
55
|
fieldId: 'a',
|
|
@@ -62,12 +62,12 @@ describe('components.FormRenderer.helpers.canActionProceed', () => {
|
|
|
62
62
|
};
|
|
63
63
|
expect((0, _canActionProceed.default)(ACTION, PAGE, _Validate.default.page, ['anError'])).toBeFalsy();
|
|
64
64
|
});
|
|
65
|
-
it('should return true when the action has checkPreexistingErrors and errors is empty', ()
|
|
66
|
-
|
|
65
|
+
it('should return true when the action has checkPreexistingErrors and errors is empty', function () {
|
|
66
|
+
var ACTION = {
|
|
67
67
|
validate: true,
|
|
68
68
|
checkPreexistingErrors: true
|
|
69
69
|
};
|
|
70
|
-
|
|
70
|
+
var PAGE = {
|
|
71
71
|
components: [{
|
|
72
72
|
id: 'a',
|
|
73
73
|
fieldId: 'a',
|
|
@@ -12,5 +12,7 @@ exports.default = void 0;
|
|
|
12
12
|
* @param {Function} pagesValidator A function to validate the page.
|
|
13
13
|
* @returns A boolean where `true` means the CYA can submit and `false` means it cannot.
|
|
14
14
|
*/
|
|
15
|
-
|
|
15
|
+
var canCYASubmit = function canCYASubmit(pages, pagesValidator) {
|
|
16
|
+
return pagesValidator(pages).length === 0;
|
|
17
|
+
};
|
|
16
18
|
var _default = exports.default = canCYASubmit;
|
|
@@ -5,28 +5,32 @@ var _canCYASubmit = _interopRequireDefault(require("./canCYASubmit"));
|
|
|
5
5
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
6
6
|
// Local imports
|
|
7
7
|
|
|
8
|
-
describe('components.FormRenderer.helpers.canCYASubmit', ()
|
|
9
|
-
|
|
8
|
+
describe('components.FormRenderer.helpers.canCYASubmit', function () {
|
|
9
|
+
var ALPHA = {
|
|
10
10
|
id: 'a',
|
|
11
11
|
fieldId: 'a',
|
|
12
12
|
label: 'Alpha',
|
|
13
13
|
required: true
|
|
14
14
|
};
|
|
15
|
-
|
|
15
|
+
var CHARLIE = {
|
|
16
16
|
id: 'c',
|
|
17
17
|
fieldId: 'c',
|
|
18
18
|
label: 'Charlie',
|
|
19
19
|
required: true
|
|
20
20
|
};
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
21
|
+
var validatePages = function validatePages(pages) {
|
|
22
|
+
return pages.flatMap(function (page) {
|
|
23
|
+
return _Validate.default.page(page);
|
|
24
|
+
});
|
|
25
|
+
};
|
|
26
|
+
it('should return true when all pages are valid', function () {
|
|
27
|
+
var PAGE_1 = {
|
|
24
28
|
components: [ALPHA],
|
|
25
29
|
formData: {
|
|
26
30
|
a: 'Bravo'
|
|
27
31
|
}
|
|
28
32
|
};
|
|
29
|
-
|
|
33
|
+
var PAGE_2 = {
|
|
30
34
|
components: [CHARLIE],
|
|
31
35
|
formData: {
|
|
32
36
|
c: 'Delta'
|
|
@@ -34,12 +38,12 @@ describe('components.FormRenderer.helpers.canCYASubmit', () => {
|
|
|
34
38
|
};
|
|
35
39
|
expect((0, _canCYASubmit.default)([PAGE_1, PAGE_2], validatePages)).toBeTruthy();
|
|
36
40
|
});
|
|
37
|
-
it('should return false when the first page is invalid', ()
|
|
38
|
-
|
|
41
|
+
it('should return false when the first page is invalid', function () {
|
|
42
|
+
var PAGE_1 = {
|
|
39
43
|
components: [ALPHA],
|
|
40
44
|
formData: {}
|
|
41
45
|
};
|
|
42
|
-
|
|
46
|
+
var PAGE_2 = {
|
|
43
47
|
components: [CHARLIE],
|
|
44
48
|
formData: {
|
|
45
49
|
c: 'Delta'
|
|
@@ -47,25 +51,25 @@ describe('components.FormRenderer.helpers.canCYASubmit', () => {
|
|
|
47
51
|
};
|
|
48
52
|
expect((0, _canCYASubmit.default)([PAGE_1, PAGE_2], validatePages)).toBeFalsy();
|
|
49
53
|
});
|
|
50
|
-
it('should return false when the second page is invalid', ()
|
|
51
|
-
|
|
54
|
+
it('should return false when the second page is invalid', function () {
|
|
55
|
+
var PAGE_1 = {
|
|
52
56
|
components: [ALPHA],
|
|
53
57
|
formData: {
|
|
54
58
|
a: 'Bravo'
|
|
55
59
|
}
|
|
56
60
|
};
|
|
57
|
-
|
|
61
|
+
var PAGE_2 = {
|
|
58
62
|
components: [CHARLIE],
|
|
59
63
|
formData: {}
|
|
60
64
|
};
|
|
61
65
|
expect((0, _canCYASubmit.default)([PAGE_1, PAGE_2], validatePages)).toBeFalsy();
|
|
62
66
|
});
|
|
63
|
-
it('should return false when the both pages are invalid', ()
|
|
64
|
-
|
|
67
|
+
it('should return false when the both pages are invalid', function () {
|
|
68
|
+
var PAGE_1 = {
|
|
65
69
|
components: [ALPHA],
|
|
66
70
|
formData: {}
|
|
67
71
|
};
|
|
68
|
-
|
|
72
|
+
var PAGE_2 = {
|
|
69
73
|
components: [CHARLIE],
|
|
70
74
|
formData: {}
|
|
71
75
|
};
|
|
@@ -6,15 +6,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.default = void 0;
|
|
7
7
|
var _optionIsSelected = _interopRequireDefault(require("../../../utils/Component/optionIsSelected"));
|
|
8
8
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
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 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; }
|
|
11
|
+
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; }
|
|
12
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
13
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
14
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } // Local imports
|
|
15
|
+
var parentComponents = ['radios', 'checkboxes'];
|
|
12
16
|
function getIdsToDelete(component, selectedValue) {
|
|
13
17
|
var _component$data;
|
|
14
|
-
|
|
15
|
-
component === null || component === void 0 || (_component$data = component.data) === null || _component$data === void 0 || (_component$data = _component$data.options) === null || _component$data === void 0 || _component$data.forEach(option
|
|
18
|
+
var idsToDelete = [];
|
|
19
|
+
component === null || component === void 0 || (_component$data = component.data) === null || _component$data === void 0 || (_component$data = _component$data.options) === null || _component$data === void 0 || _component$data.forEach(function (option) {
|
|
16
20
|
if (!(0, _optionIsSelected.default)(selectedValue, option) && option.nested) {
|
|
17
|
-
option.nested.forEach(nested
|
|
21
|
+
option.nested.forEach(function (nested) {
|
|
18
22
|
idsToDelete.push(nested.id);
|
|
19
23
|
});
|
|
20
24
|
}
|
|
@@ -22,25 +26,26 @@ function getIdsToDelete(component, selectedValue) {
|
|
|
22
26
|
return idsToDelete;
|
|
23
27
|
}
|
|
24
28
|
;
|
|
25
|
-
|
|
26
|
-
page.components.forEach(component
|
|
29
|
+
var cleanHiddenNestedData = function cleanHiddenNestedData(patch, page) {
|
|
30
|
+
page.components.forEach(function (component) {
|
|
27
31
|
if (!parentComponents.includes(component.type)) {
|
|
28
32
|
return;
|
|
29
33
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
idsToDelete.forEach(id
|
|
34
|
+
var _patch = patch;
|
|
35
|
+
var idsToDelete = getIdsToDelete(component, _patch[component.id]);
|
|
36
|
+
idsToDelete.forEach(function (id) {
|
|
33
37
|
delete _patch[id];
|
|
34
38
|
});
|
|
35
39
|
});
|
|
36
40
|
if (page.collection && patch[page.collection.name]) {
|
|
37
41
|
var _page$formData;
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
_patch[page.collection.name] = _patch[page.collection.name].map(
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
42
|
+
var activeId = patch["".concat(page.collection.name, "ActiveId")] || ((_page$formData = page.formData) === null || _page$formData === void 0 ? void 0 : _page$formData["".concat(page.collection.name, "ActiveId")]);
|
|
43
|
+
var _patch = patch;
|
|
44
|
+
_patch[page.collection.name] = _patch[page.collection.name].map(function (entry) {
|
|
45
|
+
return entry.id === activeId ? cleanHiddenNestedData(entry, _objectSpread(_objectSpread({}, page), {}, {
|
|
46
|
+
collection: undefined
|
|
47
|
+
})) : entry;
|
|
48
|
+
});
|
|
44
49
|
}
|
|
45
50
|
;
|
|
46
51
|
return patch;
|
|
@@ -4,17 +4,17 @@ var _cleanHiddenNestedData = _interopRequireDefault(require("./cleanHiddenNested
|
|
|
4
4
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
5
5
|
// Local imports
|
|
6
6
|
|
|
7
|
-
describe('components', ()
|
|
8
|
-
describe('FormRenderer', ()
|
|
9
|
-
describe('helpers', ()
|
|
10
|
-
describe('cleanHiddenNestedData', ()
|
|
11
|
-
it('should remove data corresponding to hidden nested components in radios', ()
|
|
12
|
-
|
|
7
|
+
describe('components', function () {
|
|
8
|
+
describe('FormRenderer', function () {
|
|
9
|
+
describe('helpers', function () {
|
|
10
|
+
describe('cleanHiddenNestedData', function () {
|
|
11
|
+
it('should remove data corresponding to hidden nested components in radios', function () {
|
|
12
|
+
var patchRadios = {
|
|
13
13
|
parent: 'option2',
|
|
14
14
|
nested1: 'should not be included',
|
|
15
15
|
nested2: 'should be included'
|
|
16
16
|
};
|
|
17
|
-
|
|
17
|
+
var pageRadios = {
|
|
18
18
|
id: 'page',
|
|
19
19
|
name: 'page',
|
|
20
20
|
title: 'Page',
|
|
@@ -39,17 +39,17 @@ describe('components', () => {
|
|
|
39
39
|
}
|
|
40
40
|
}]
|
|
41
41
|
};
|
|
42
|
-
|
|
42
|
+
var updatedPatchRadios = (0, _cleanHiddenNestedData.default)(patchRadios, pageRadios);
|
|
43
43
|
expect(updatedPatchRadios.nested1).toBeFalsy();
|
|
44
44
|
expect(updatedPatchRadios.nested2).toBeTruthy();
|
|
45
45
|
});
|
|
46
|
-
it('should remove data corresponding to hidden nested components in checkboxes', ()
|
|
47
|
-
|
|
46
|
+
it('should remove data corresponding to hidden nested components in checkboxes', function () {
|
|
47
|
+
var patchCheckboxes = {
|
|
48
48
|
parent: ['option2'],
|
|
49
49
|
nested1: 'should not be included',
|
|
50
50
|
nested2: 'should be included'
|
|
51
51
|
};
|
|
52
|
-
|
|
52
|
+
var pageCheckboxes = {
|
|
53
53
|
id: 'page',
|
|
54
54
|
name: 'page',
|
|
55
55
|
title: 'Page',
|
|
@@ -74,12 +74,12 @@ describe('components', () => {
|
|
|
74
74
|
}
|
|
75
75
|
}]
|
|
76
76
|
};
|
|
77
|
-
|
|
77
|
+
var updatedPatchCheckboxes = (0, _cleanHiddenNestedData.default)(patchCheckboxes, pageCheckboxes);
|
|
78
78
|
expect(updatedPatchCheckboxes.nested1).toBeFalsy();
|
|
79
79
|
expect(updatedPatchCheckboxes.nested2).toBeTruthy();
|
|
80
80
|
});
|
|
81
|
-
it('remove data corresponding to hidden nested components within the active collection entry', ()
|
|
82
|
-
|
|
81
|
+
it('remove data corresponding to hidden nested components within the active collection entry', function () {
|
|
82
|
+
var patch = {
|
|
83
83
|
collectionNameActiveId: '456',
|
|
84
84
|
collectionName: [{
|
|
85
85
|
id: '123',
|
|
@@ -93,7 +93,7 @@ describe('components', () => {
|
|
|
93
93
|
nested2: 'should be included'
|
|
94
94
|
}]
|
|
95
95
|
};
|
|
96
|
-
|
|
96
|
+
var page = {
|
|
97
97
|
id: 'page',
|
|
98
98
|
name: 'page',
|
|
99
99
|
title: 'Page',
|
|
@@ -120,7 +120,7 @@ describe('components', () => {
|
|
|
120
120
|
}
|
|
121
121
|
}]
|
|
122
122
|
};
|
|
123
|
-
|
|
123
|
+
var updatedPatch = (0, _cleanHiddenNestedData.default)(patch, page);
|
|
124
124
|
expect(updatedPatch.collectionName[0].nested1).toBeTruthy();
|
|
125
125
|
expect(updatedPatch.collectionName[0].nested2).toBeTruthy();
|
|
126
126
|
expect(updatedPatch.collectionName[1].nested1).toBeFalsy();
|
|
@@ -15,7 +15,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
15
15
|
* @param {object} hub The hub, if there is one.
|
|
16
16
|
* @returns A configuration object for the Check your answers screen.
|
|
17
17
|
*/
|
|
18
|
-
|
|
18
|
+
var getCYA = function getCYA(pageId, pages, hub) {
|
|
19
19
|
if (pageId === _models.FormPages.HUB && hub === _models.HubFormats.CYA) {
|
|
20
20
|
return {
|
|
21
21
|
title: ''
|
|
@@ -26,9 +26,11 @@ const getCYA = (pageId, pages, hub) => {
|
|
|
26
26
|
return {};
|
|
27
27
|
}
|
|
28
28
|
;
|
|
29
|
-
|
|
29
|
+
var currentPage = pages === null || pages === void 0 ? void 0 : pages.find(function (p) {
|
|
30
|
+
return p.id === pageId;
|
|
31
|
+
});
|
|
30
32
|
if ((currentPage === null || currentPage === void 0 ? void 0 : currentPage.type) === _models.FormPages.PARTIAL_CYA) {
|
|
31
|
-
|
|
33
|
+
var pageWithConditionals = _utils.default.FormPage.applyConditionalProperties(currentPage);
|
|
32
34
|
return {
|
|
33
35
|
title: pageWithConditionals.title,
|
|
34
36
|
hideChangeActions: pageWithConditionals.hideChangeActions,
|
|
@@ -5,32 +5,32 @@ var _getCYA = _interopRequireDefault(require("./getCYA"));
|
|
|
5
5
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
6
6
|
// Local imports
|
|
7
7
|
|
|
8
|
-
describe('components', ()
|
|
9
|
-
describe('FormRenderer', ()
|
|
10
|
-
describe('helpers', ()
|
|
11
|
-
|
|
8
|
+
describe('components', function () {
|
|
9
|
+
describe('FormRenderer', function () {
|
|
10
|
+
describe('helpers', function () {
|
|
11
|
+
var HUB = {
|
|
12
12
|
id: _models.FormPages.HUB,
|
|
13
13
|
components: []
|
|
14
14
|
};
|
|
15
|
-
describe('getCYA', ()
|
|
16
|
-
it('should give an empty object if the pageId is "CYA"', ()
|
|
15
|
+
describe('getCYA', function () {
|
|
16
|
+
it('should give an empty object if the pageId is "CYA"', function () {
|
|
17
17
|
expect((0, _getCYA.default)(_models.FormPages.CYA)).toEqual({});
|
|
18
18
|
});
|
|
19
|
-
it('should give an object with a blank title if the pageId is "hub" and the hub is the CYA', ()
|
|
19
|
+
it('should give an object with a blank title if the pageId is "hub" and the hub is the CYA', function () {
|
|
20
20
|
expect((0, _getCYA.default)(_models.FormPages.HUB, [], _models.HubFormats.CYA)).toEqual({
|
|
21
21
|
title: ''
|
|
22
22
|
});
|
|
23
23
|
});
|
|
24
|
-
it('should give undefined if pageId is "hub" and the hub is NOT the CYA', ()
|
|
24
|
+
it('should give undefined if pageId is "hub" and the hub is NOT the CYA', function () {
|
|
25
25
|
expect((0, _getCYA.default)(_models.FormPages.HUB, [], HUB)).toBeUndefined();
|
|
26
26
|
});
|
|
27
|
-
it('should give undefined if pageId is NOT "hub" and the hub is NOT the CYA', ()
|
|
27
|
+
it('should give undefined if pageId is NOT "hub" and the hub is NOT the CYA', function () {
|
|
28
28
|
expect((0, _getCYA.default)(_models.FormPages.HUB, [], HUB)).toBeUndefined();
|
|
29
29
|
});
|
|
30
|
-
it('should give undefined if pageId is NOT "hub" and the hub is the CYA', ()
|
|
30
|
+
it('should give undefined if pageId is NOT "hub" and the hub is the CYA', function () {
|
|
31
31
|
expect((0, _getCYA.default)('bob', [], _models.HubFormats.CYA)).toBeUndefined();
|
|
32
32
|
});
|
|
33
|
-
it('should return an object with a title if the current page has type partial-cya', ()
|
|
33
|
+
it('should return an object with a title if the current page has type partial-cya', function () {
|
|
34
34
|
expect((0, _getCYA.default)('pageId', [{
|
|
35
35
|
id: 'pageId',
|
|
36
36
|
type: 'partial-cya',
|
|
@@ -16,9 +16,11 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
16
16
|
* @param {object} hub The hub, if there is one.
|
|
17
17
|
* @returns The current state of the form.
|
|
18
18
|
*/
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
19
|
+
var getFormState = function getFormState(pageId, pages, hub) {
|
|
20
|
+
return {
|
|
21
|
+
pageId: pageId,
|
|
22
|
+
cya: (0, _getCYA.default)(pageId, pages, hub),
|
|
23
|
+
page: (0, _getPage.default)(pageId, pages, hub)
|
|
24
|
+
};
|
|
25
|
+
};
|
|
24
26
|
var _default = exports.default = getFormState;
|