@ukhomeoffice/cop-react-form-renderer 7.3.2 → 8.0.0-alpha
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +106 -32
- package/dist/components/CheckYourAnswers/Answer.d.ts +10 -0
- package/dist/components/CheckYourAnswers/CheckYourAnswers.d.ts +35 -0
- package/dist/components/CheckYourAnswers/index.d.ts +2 -0
- package/dist/components/CollectionPage/CollectionPage.d.ts +24 -0
- package/dist/components/CollectionPage/index.d.ts +1 -0
- package/dist/components/CollectionSummary/BannerStrip.d.ts +9 -0
- package/dist/components/CollectionSummary/CollectionSummary.d.ts +53 -0
- package/dist/components/CollectionSummary/Confirmation.d.ts +15 -0
- package/dist/components/CollectionSummary/RenderListView.d.ts +42 -0
- package/dist/components/CollectionSummary/SummaryCard.d.ts +62 -0
- package/dist/components/CollectionSummary/SummaryCardButtons.d.ts +21 -0
- package/dist/components/CollectionSummary/SummaryCardDetails.d.ts +14 -0
- package/dist/components/CollectionSummary/SummaryCardValidationContext.d.ts +9 -0
- package/dist/components/CollectionSummary/index.d.ts +2 -0
- package/dist/components/FormComponent/Collection.d.ts +39 -0
- package/dist/components/FormComponent/Container.d.ts +26 -0
- package/dist/components/FormComponent/FormComponent.d.ts +39 -0
- package/dist/components/FormComponent/helpers/addLabel.d.ts +7 -0
- package/dist/components/FormComponent/helpers/getComponentDisabled.d.ts +2 -0
- package/dist/components/FormComponent/helpers/getComponentError.d.ts +4 -0
- package/dist/components/FormComponent/helpers/getComponentFieldSet.d.ts +2 -0
- package/dist/components/FormComponent/helpers/index.d.ts +5 -0
- package/dist/components/FormComponent/index.d.ts +2 -0
- package/dist/components/FormPage/FormPage.d.ts +36 -0
- package/dist/components/FormPage/index.d.ts +2 -0
- package/dist/components/FormRenderer/FormRenderer.d.ts +39 -0
- package/dist/components/FormRenderer/handlers/cyaAction.d.ts +9 -0
- package/dist/components/FormRenderer/handlers/getPageId.d.ts +8 -0
- package/dist/components/FormRenderer/handlers/index.d.ts +6 -0
- package/dist/components/FormRenderer/handlers/navigate.d.ts +10 -0
- package/dist/components/FormRenderer/handlers/submissionError.d.ts +7 -0
- package/dist/components/FormRenderer/helpers/canActionProceed.d.ts +12 -0
- package/dist/components/FormRenderer/helpers/canCYASubmit.d.ts +10 -0
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.d.ts +51 -0
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.d.ts +179 -0
- package/dist/components/FormRenderer/helpers/getCYA.d.ts +20 -0
- package/dist/components/FormRenderer/helpers/getFormState.d.ts +25 -0
- package/dist/components/FormRenderer/helpers/getNextPageId.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getPage.d.ts +9 -0
- package/dist/components/FormRenderer/helpers/getRelevantPages.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.d.ts +2 -0
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.d.ts +10 -0
- package/dist/components/FormRenderer/helpers/index.d.ts +29 -0
- package/dist/components/FormRenderer/index.d.ts +2 -0
- package/dist/components/FormRenderer/onCYAAction.d.ts +6 -0
- package/dist/components/FormRenderer/onPageAction.d.ts +2 -0
- package/dist/components/FormRenderer/onTaskAction.d.ts +2 -0
- package/dist/components/PageActions/ActionButton.d.ts +7 -0
- package/dist/components/PageActions/PageActions.d.ts +7 -0
- package/dist/components/PageActions/index.d.ts +2 -0
- package/dist/components/SummaryList/GroupAction.d.ts +12 -0
- package/dist/components/SummaryList/RowAction.d.ts +12 -0
- package/dist/components/SummaryList/SummaryList.d.ts +28 -0
- package/dist/components/SummaryList/SummaryList.stories.d.ts +10 -0
- package/dist/components/SummaryList/SummaryListHeadingRow.d.ts +7 -0
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.d.ts +16 -0
- package/dist/components/SummaryList/SummaryListRow.d.ts +19 -0
- package/dist/components/SummaryList/SummaryListTitleRow.d.ts +7 -0
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.d.ts +17 -0
- package/dist/components/SummaryList/helpers/getRowActionAttributes.d.ts +17 -0
- package/dist/components/SummaryList/helpers/index.d.ts +2 -0
- package/dist/components/SummaryList/index.d.ts +2 -0
- package/dist/components/TaskList/Task.d.ts +12 -0
- package/dist/components/TaskList/TaskList.d.ts +40 -0
- package/dist/components/TaskList/TaskState.d.ts +6 -0
- package/dist/components/TaskList/index.d.ts +2 -0
- package/dist/components/index.d.ts +8 -0
- package/dist/context/HooksContext/HooksContext.d.ts +23 -0
- package/dist/context/HooksContext/index.d.ts +3 -0
- package/dist/context/ValidationContext/ValidationContext.d.ts +7 -0
- package/dist/context/ValidationContext/index.d.ts +3 -0
- package/dist/context/index.d.ts +3 -0
- package/dist/hooks/index.d.ts +6 -0
- package/dist/hooks/useAxios.d.ts +2 -0
- package/dist/hooks/useGetRequest.d.ts +12 -0
- package/dist/hooks/useHooks.d.ts +2 -0
- package/dist/hooks/useRefData.d.ts +7 -0
- package/dist/hooks/useValidation.d.ts +2 -0
- package/dist/index.cjs +5 -0
- package/dist/index.css +1 -0
- package/dist/index.d.ts +6 -0
- package/dist/index.js +6124 -81
- package/dist/models/CollectionLabels.d.ts +7 -0
- package/dist/models/ComponentTypes.d.ts +27 -0
- package/dist/models/EventTypes.d.ts +6 -0
- package/dist/models/FormPages.d.ts +6 -0
- package/dist/models/FormTypes.d.ts +10 -0
- package/dist/models/HubFormats.d.ts +5 -0
- package/dist/models/PageAction.d.ts +89 -0
- package/dist/models/TaskStates.d.ts +39 -0
- package/dist/models/index.d.ts +143 -0
- package/dist/setupTests.d.ts +14 -0
- package/dist/utils/CheckYourAnswers/getCYAAction.d.ts +20 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.d.ts +22 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.d.ts +22 -0
- package/dist/utils/CheckYourAnswers/getCYARow.d.ts +26 -0
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.d.ts +17 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.d.ts +2 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.d.ts +23 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.d.ts +2 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.d.ts +11 -0
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.d.ts +3 -0
- package/dist/utils/CheckYourAnswers/index.d.ts +5 -0
- package/dist/utils/CheckYourAnswers/showComponentCYA.d.ts +11 -0
- package/dist/utils/CollectionPage/addCollectionPageEntry.d.ts +12 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.d.ts +13 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.d.ts +13 -0
- package/dist/utils/CollectionPage/getCollectionPageActiveId.d.ts +14 -0
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.d.ts +15 -0
- package/dist/utils/CollectionPage/getCollectionPageData.d.ts +15 -0
- package/dist/utils/CollectionPage/getErrorsForCollection.d.ts +2 -0
- package/dist/utils/CollectionPage/getQuickEditPage.d.ts +40 -0
- package/dist/utils/CollectionPage/index.d.ts +13 -0
- package/dist/utils/CollectionPage/mergeCollectionPages.d.ts +13 -0
- package/dist/utils/CollectionPage/removeCollectionPageEntry.d.ts +11 -0
- package/dist/utils/CollectionPage/setCollectionPageData.d.ts +16 -0
- package/dist/utils/Component/addShowWhen.d.ts +13 -0
- package/dist/utils/Component/applyToComponentTree.d.ts +15 -0
- package/dist/utils/Component/cleanAttributes.d.ts +14 -0
- package/dist/utils/Component/elevateNestedComponents.d.ts +28 -0
- package/dist/utils/Component/getDefaultValue.d.ts +2 -0
- package/dist/utils/Component/getDefaultValueFromConfig.d.ts +2 -0
- package/dist/utils/Component/index.d.ts +12 -0
- package/dist/utils/Component/isEditable.d.ts +3 -0
- package/dist/utils/Component/optionIsSelected.d.ts +10 -0
- package/dist/utils/Component/setupContainerComponentsPath.d.ts +2 -0
- package/dist/utils/Component/showComponent.d.ts +2 -0
- package/dist/utils/Condition/index.d.ts +6 -0
- package/dist/utils/Condition/meetsAllConditions.d.ts +8 -0
- package/dist/utils/Condition/meetsCondition.d.ts +14 -0
- package/dist/utils/Condition/meetsOneCondition.d.ts +8 -0
- package/dist/utils/Condition/setupConditions.d.ts +2 -0
- package/dist/utils/Container/getEditableComponents.d.ts +7 -0
- package/dist/utils/Container/index.d.ts +6 -0
- package/dist/utils/Container/setupNesting.d.ts +2 -0
- package/dist/utils/Container/showContainer.d.ts +8 -0
- package/dist/utils/Data/applyFormula.d.ts +2 -0
- package/dist/utils/Data/deleteValues.d.ts +8 -0
- package/dist/utils/Data/getAutocompleteSource.d.ts +2 -0
- package/dist/utils/Data/getDataPath.d.ts +21 -0
- package/dist/utils/Data/getOptions.d.ts +2 -0
- package/dist/utils/Data/getSourceData.d.ts +17 -0
- package/dist/utils/Data/index.d.ts +15 -0
- package/dist/utils/Data/nestInRefdataOptions.d.ts +10 -0
- package/dist/utils/Data/refDataToOptions.d.ts +8 -0
- package/dist/utils/Data/setDataItem.d.ts +2 -0
- package/dist/utils/Data/setupFormData.d.ts +15 -0
- package/dist/utils/Data/setupRefDataUrlForComponent.d.ts +2 -0
- package/dist/utils/FormPage/applyConditionalProperties.d.ts +8 -0
- package/dist/utils/FormPage/getConditionalText.d.ts +23 -0
- package/dist/utils/FormPage/getFormPage.d.ts +9 -0
- package/dist/utils/FormPage/getFormPages.d.ts +9 -0
- package/dist/utils/FormPage/getPageActions.d.ts +13 -0
- package/dist/utils/FormPage/getParagraphFromText.d.ts +11 -0
- package/dist/utils/FormPage/index.d.ts +10 -0
- package/dist/utils/FormPage/showFormPage.d.ts +8 -0
- package/dist/utils/FormPage/showFormPageCYA.d.ts +8 -0
- package/dist/utils/FormPage/useComponent.d.ts +9 -0
- package/dist/utils/Format/formatData.d.ts +8 -0
- package/dist/utils/Format/formatDataForComponent.d.ts +15 -0
- package/dist/utils/Format/formatDataForForm.d.ts +8 -0
- package/dist/utils/Format/formatDataForPage.d.ts +15 -0
- package/dist/utils/Format/index.d.ts +7 -0
- package/dist/utils/Hub/getFormHub.d.ts +15 -0
- package/dist/utils/Hub/index.d.ts +4 -0
- package/dist/utils/Meta/constants.d.ts +2 -0
- package/dist/utils/Meta/documents/getDocuments.d.ts +2 -0
- package/dist/utils/Meta/documents/index.d.ts +6 -0
- package/dist/utils/Meta/documents/setDocumentsForField.d.ts +2 -0
- package/dist/utils/Meta/index.d.ts +9 -0
- package/dist/utils/Operate/checkValueIsTruthy.d.ts +9 -0
- package/dist/utils/Operate/deleteValueInFormData.d.ts +8 -0
- package/dist/utils/Operate/doesContainValue.d.ts +11 -0
- package/dist/utils/Operate/getFirstOf.d.ts +2 -0
- package/dist/utils/Operate/getIndexOfMatchingValueIn.d.ts +11 -0
- package/dist/utils/Operate/getLength.d.ts +11 -0
- package/dist/utils/Operate/index.d.ts +4 -0
- package/dist/utils/Operate/persistValueInFormData.d.ts +9 -0
- package/dist/utils/Operate/runPageOperations.d.ts +19 -0
- package/dist/utils/Operate/setValueInFormData.d.ts +2 -0
- package/dist/utils/Operate/shouldRun.d.ts +9 -0
- package/dist/utils/Validate/additional/conditionallyPermittedChange.d.ts +14 -0
- package/dist/utils/Validate/additional/conditionallyRequired.d.ts +11 -0
- package/dist/utils/Validate/additional/index.d.ts +2 -0
- package/dist/utils/Validate/additional/mustBeAfter.d.ts +14 -0
- package/dist/utils/Validate/additional/mustBeBefore.d.ts +14 -0
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.d.ts +15 -0
- package/dist/utils/Validate/additional/mustBeGreaterThan.d.ts +7 -0
- package/dist/utils/Validate/additional/mustBeInTheFuture.d.ts +8 -0
- package/dist/utils/Validate/additional/mustBeInThePast.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeLessThan.d.ts +7 -0
- package/dist/utils/Validate/additional/mustBeLongerThan.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeNumbersOnly.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeOneOf.d.ts +8 -0
- package/dist/utils/Validate/additional/mustBeShorterThan.d.ts +9 -0
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.d.ts +10 -0
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.d.ts +9 -0
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.d.ts +7 -0
- package/dist/utils/Validate/additional/mustNotContainSql.d.ts +2 -0
- package/dist/utils/Validate/additional/mustSelectOnlyOne.d.ts +8 -0
- package/dist/utils/Validate/additional/utils.d.ts +4 -0
- package/dist/utils/Validate/index.d.ts +42 -0
- package/dist/utils/Validate/validateCollection.d.ts +9 -0
- package/dist/utils/Validate/validateComponent.d.ts +16 -0
- package/dist/utils/Validate/validateContainer.d.ts +12 -0
- package/dist/utils/Validate/validateDate.d.ts +29 -0
- package/dist/utils/Validate/validateEmail.d.ts +13 -0
- package/dist/utils/Validate/validateMultifile.d.ts +3 -0
- package/dist/utils/Validate/validateOnPageLoad.d.ts +1 -0
- package/dist/utils/Validate/validatePage.d.ts +8 -0
- package/dist/utils/Validate/validateRegex.d.ts +13 -0
- package/dist/utils/Validate/validateRequired.d.ts +9 -0
- package/dist/utils/Validate/validateTextArea.d.ts +13 -0
- package/dist/utils/Validate/validateTime.d.ts +20 -0
- package/dist/utils/canOverrideFieldRequired.d.ts +9 -0
- package/dist/utils/index.d.ts +140 -0
- package/package.json +80 -167
- package/LICENCE.md +0 -21
- package/dist/components/CheckYourAnswers/Answer.js +0 -59
- package/dist/components/CheckYourAnswers/Answer.test.js +0 -142
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +0 -252
- package/dist/components/CheckYourAnswers/CheckYourAnswers.scss +0 -43
- package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +0 -409
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +0 -603
- package/dist/components/CheckYourAnswers/index.js +0 -10
- package/dist/components/CollectionPage/CollectionPage.js +0 -178
- package/dist/components/CollectionPage/CollectionPage.test.js +0 -507
- package/dist/components/CollectionPage/index.js +0 -10
- package/dist/components/CollectionSummary/BannerStrip.js +0 -65
- package/dist/components/CollectionSummary/BannerStrip.scss +0 -60
- package/dist/components/CollectionSummary/BannerStrip.test.js +0 -167
- package/dist/components/CollectionSummary/CollectionSummary.js +0 -362
- package/dist/components/CollectionSummary/CollectionSummary.scss +0 -26
- package/dist/components/CollectionSummary/CollectionSummary.test.js +0 -368
- package/dist/components/CollectionSummary/Confirmation.js +0 -65
- package/dist/components/CollectionSummary/Confirmation.scss +0 -26
- package/dist/components/CollectionSummary/Confirmation.test.js +0 -109
- package/dist/components/CollectionSummary/RenderListView.js +0 -162
- package/dist/components/CollectionSummary/RenderListView.scss +0 -295
- package/dist/components/CollectionSummary/RenderListView.test.js +0 -303
- package/dist/components/CollectionSummary/SummaryCard.js +0 -277
- package/dist/components/CollectionSummary/SummaryCard.scss +0 -114
- package/dist/components/CollectionSummary/SummaryCard.test.js +0 -1442
- package/dist/components/CollectionSummary/SummaryCardButtons.js +0 -76
- package/dist/components/CollectionSummary/SummaryCardButtons.test.js +0 -87
- package/dist/components/CollectionSummary/SummaryCardDetails.js +0 -206
- package/dist/components/CollectionSummary/SummaryCardDetails.scss +0 -216
- package/dist/components/CollectionSummary/SummaryCardDetails.test.js +0 -654
- package/dist/components/CollectionSummary/SummaryCardValidationContext.js +0 -79
- package/dist/components/CollectionSummary/SummaryCardValidationContext.test.js +0 -104
- package/dist/components/CollectionSummary/index.js +0 -10
- package/dist/components/FormComponent/Collection.js +0 -234
- package/dist/components/FormComponent/Collection.scss +0 -24
- package/dist/components/FormComponent/Collection.test.js +0 -934
- package/dist/components/FormComponent/Container.js +0 -130
- package/dist/components/FormComponent/Container.scss +0 -15
- package/dist/components/FormComponent/Container.test.js +0 -456
- package/dist/components/FormComponent/FormComponent.js +0 -238
- package/dist/components/FormComponent/FormComponent.stories.mdx +0 -186
- package/dist/components/FormComponent/FormComponent.test.js +0 -436
- package/dist/components/FormComponent/helpers/addLabel.js +0 -25
- package/dist/components/FormComponent/helpers/getComponentDisabled.js +0 -15
- package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +0 -27
- package/dist/components/FormComponent/helpers/getComponentError.js +0 -23
- package/dist/components/FormComponent/helpers/getComponentError.test.js +0 -51
- package/dist/components/FormComponent/helpers/getComponentFieldSet.js +0 -11
- package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +0 -30
- package/dist/components/FormComponent/helpers/index.js +0 -35
- package/dist/components/FormComponent/index.js +0 -10
- package/dist/components/FormPage/FormPage.js +0 -212
- package/dist/components/FormPage/FormPage.scss +0 -7
- package/dist/components/FormPage/FormPage.stories.mdx +0 -157
- package/dist/components/FormPage/FormPage.test.js +0 -454
- package/dist/components/FormPage/index.js +0 -10
- package/dist/components/FormRenderer/FormRenderer.js +0 -426
- package/dist/components/FormRenderer/FormRenderer.scss +0 -5
- package/dist/components/FormRenderer/FormRenderer.stories.mdx +0 -178
- package/dist/components/FormRenderer/FormRenderer.test.js +0 -799
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/cop-reassign-task-to-rcc.json +0 -446
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-containerised.json +0 -120
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested-block.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-dependent-component-nested.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-refdata.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens-target-component-nested.json +0 -99
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-component-show-whens.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-chained-show-whens-page-hidden.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-airpax.json +0 -26408
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-cop-mandec.json +0 -9405
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component-dependent-on-external-data.json +0 -158
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-collection-component.json +0 -86
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-collection.json +0 -173
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-referring-to-hidden-collection.json +0 -202
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-show-when-in-component-and-page.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions-visible-elsewhere.json +0 -118
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component-with-nested-questions.json +0 -112
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-component.json +0 -58
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-containerised-component.json +0 -97
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-collection-component.json +0 -83
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-embedded-component.json +0 -55
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-entire-collection.json +0 -114
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component-leaf-hidden.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-multilevel-containerised-component.json +0 -106
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-options.json +0 -99
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-collection.json +0 -128
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-component-used-elsewhere.json +0 -109
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page-same-component-reused.json +0 -62
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-hidden-page.json +0 -96
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option-visible-elsewhere.json +0 -113
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-nested-answers-hidden-by-option.json +0 -112
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-component.json +0 -26003
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-nested-radio-component.json +0 -201
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-page-same-component-reused-one-shown.json +0 -75
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/forms/form-variance-breach.json +0 -4272
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-carrier.json +0 -407
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-change-what-happened-before.json +0 -300
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-airpax-remove-photos-before.json +0 -384
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-business-interests-before.json +0 -140
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-criminality-before.json +0 -186
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-mandec-remove-unspent-convictions-before.json +0 -143
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/cop-variance-breach-with-upload-files.json +0 -1264
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-containerised.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested-block.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-dependent-component-nested.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-refdata.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens-target-component-nested.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-component-show-whens.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-chained-show-whens-page-hidden.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component-dependent-on-external-data.json +0 -26
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-collection-component.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-collection.json +0 -25
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-referring-to-hidden-collection.json +0 -26
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-show-when-in-component-and-page.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions-visible-elsewhere.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component-with-nested-questions.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-component.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-containerised-component.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-collection-component.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-embedded-component.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-entire-collection.json +0 -20
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component-leaf-hidden.json +0 -14
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-multilevel-containerised-component.json +0 -14
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-options.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-collection.json +0 -18
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-component-used-elsewhere.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page-same-component-reused.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-hidden-page.json +0 -9
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option-visible-elsewhere.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-nested-answers-hidden-by-option.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-component.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-nested-radio-component.json +0 -45
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/data-page-same-component-reused-one-shown.json +0 -8
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/input/reassign-to-rcc.json +0 -72
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-change-what-happened-after.json +0 -280
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-airpax-remove-photos-after.json +0 -355
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-base-file.json +0 -80
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-business-interests-after.json +0 -122
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-criminality-after.json +0 -86
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/cop-mandec-remove-unspent-convictions-after.json +0 -127
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-containerised-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-block-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-dependent-component-nested-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-refdata-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-removed.json +0 -7
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-component-show-whens-target-component-nested-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-chained-show-whens-page-hidden-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-dependent-on-external-data-removed.json +0 -23
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-collection-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-collection-removed.json +0 -21
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-referring-to-hidden-collection-removed.json +0 -6
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-show-when-in-component-and-page-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-component-with-nested-questions-visible-elsewhere-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-containerised-component-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-collection-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-embedded-component-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-entire-collection-removed.json +0 -3
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-leaf-hidden-removed.json +0 -13
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-multilevel-containerised-component-removed.json +0 -10
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-options-removed.json +0 -8
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-collection-removed.json +0 -15
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-component-used-elsewhere-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-removed.json +0 -4
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-hidden-page-same-component-reused-removed.json +0 -5
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-removed.json +0 -11
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-nested-answers-hidden-by-option-visible-elsewhere-removed.json +0 -12
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-component.json +0 -63
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-nested-radio-component-removed.json +0 -45
- package/dist/components/FormRenderer/clear-uncompleted-routes/test-data/output/data-page-same-component-reused-one-shown-removed.json +0 -7
- package/dist/components/FormRenderer/handlers/cyaAction.js +0 -23
- package/dist/components/FormRenderer/handlers/getPageId.js +0 -15
- package/dist/components/FormRenderer/handlers/getPageId.test.js +0 -35
- package/dist/components/FormRenderer/handlers/handlers.test.js +0 -81
- package/dist/components/FormRenderer/handlers/index.js +0 -17
- package/dist/components/FormRenderer/handlers/navigate.js +0 -25
- package/dist/components/FormRenderer/handlers/submissionError.js +0 -18
- package/dist/components/FormRenderer/helpers/canActionProceed.js +0 -27
- package/dist/components/FormRenderer/helpers/canActionProceed.test.js +0 -84
- package/dist/components/FormRenderer/helpers/canCYASubmit.js +0 -17
- package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +0 -75
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +0 -63
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +0 -191
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.js +0 -338
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutes.test.js +0 -434
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.js +0 -399
- package/dist/components/FormRenderer/helpers/clearOutUncompletedRoutesUtils.test.js +0 -559
- package/dist/components/FormRenderer/helpers/getCYA.js +0 -42
- package/dist/components/FormRenderer/helpers/getCYA.test.js +0 -46
- package/dist/components/FormRenderer/helpers/getFormState.js +0 -25
- package/dist/components/FormRenderer/helpers/getFormState.test.js +0 -60
- package/dist/components/FormRenderer/helpers/getNextPageId.js +0 -76
- package/dist/components/FormRenderer/helpers/getNextPageId.test.js +0 -292
- package/dist/components/FormRenderer/helpers/getPage.js +0 -27
- package/dist/components/FormRenderer/helpers/getPage.test.js +0 -45
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +0 -27
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +0 -70
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +0 -65
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +0 -309
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +0 -201
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +0 -473
- package/dist/components/FormRenderer/helpers/index.js +0 -33
- package/dist/components/FormRenderer/index.js +0 -10
- package/dist/components/FormRenderer/onCYAAction.js +0 -150
- package/dist/components/FormRenderer/onCYAAction.test.js +0 -741
- package/dist/components/FormRenderer/onPageAction.js +0 -227
- package/dist/components/FormRenderer/onPageAction.test.js +0 -960
- package/dist/components/FormRenderer/onTaskAction.js +0 -47
- package/dist/components/FormRenderer/onTaskAction.test.js +0 -247
- package/dist/components/PageActions/ActionButton.js +0 -48
- package/dist/components/PageActions/ActionButton.test.js +0 -73
- package/dist/components/PageActions/PageActions.js +0 -37
- package/dist/components/PageActions/PageActions.stories.mdx +0 -74
- package/dist/components/PageActions/PageActions.test.js +0 -106
- package/dist/components/PageActions/index.js +0 -10
- package/dist/components/SummaryList/GroupAction.js +0 -50
- package/dist/components/SummaryList/GroupAction.test.js +0 -86
- package/dist/components/SummaryList/RowAction.js +0 -48
- package/dist/components/SummaryList/RowAction.test.js +0 -86
- package/dist/components/SummaryList/SummaryList.js +0 -128
- package/dist/components/SummaryList/SummaryList.scss +0 -79
- package/dist/components/SummaryList/SummaryList.stories.mdx +0 -84
- package/dist/components/SummaryList/SummaryList.test.js +0 -504
- package/dist/components/SummaryList/SummaryListHeadingRow.js +0 -39
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.js +0 -65
- package/dist/components/SummaryList/SummaryListHeadingRowWithAction.scss +0 -38
- package/dist/components/SummaryList/SummaryListRow.js +0 -58
- package/dist/components/SummaryList/SummaryListTitleRow.js +0 -32
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +0 -29
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +0 -72
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +0 -29
- package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +0 -72
- package/dist/components/SummaryList/helpers/index.js +0 -14
- package/dist/components/SummaryList/index.js +0 -10
- package/dist/components/TaskList/Task.js +0 -62
- package/dist/components/TaskList/Task.test.js +0 -176
- package/dist/components/TaskList/TaskList.js +0 -175
- package/dist/components/TaskList/TaskList.scss +0 -123
- package/dist/components/TaskList/TaskList.stories.mdx +0 -164
- package/dist/components/TaskList/TaskList.test.js +0 -535
- package/dist/components/TaskList/TaskState.js +0 -37
- package/dist/components/TaskList/TaskState.test.js +0 -95
- package/dist/components/TaskList/index.js +0 -10
- package/dist/components/index.js +0 -56
- package/dist/context/HooksContext/HooksContext.js +0 -122
- package/dist/context/HooksContext/HooksContext.test.js +0 -45
- package/dist/context/HooksContext/index.js +0 -16
- package/dist/context/ValidationContext/ValidationContext.js +0 -98
- package/dist/context/ValidationContext/ValidationContext.test.js +0 -107
- package/dist/context/ValidationContext/index.js +0 -16
- package/dist/context/index.js +0 -21
- package/dist/hooks/index.js +0 -55
- package/dist/hooks/useAxios.js +0 -36
- package/dist/hooks/useGetRequest.js +0 -89
- package/dist/hooks/useHooks.js +0 -15
- package/dist/hooks/useRefData.js +0 -62
- package/dist/hooks/useValidation.js +0 -15
- package/dist/json/actions.json +0 -17
- package/dist/json/actionsNoSave.json +0 -17
- package/dist/json/addressDetails.json +0 -149
- package/dist/json/areYouACivilServant.json +0 -7
- package/dist/json/firstForm.json +0 -94
- package/dist/json/grade.json +0 -108
- package/dist/json/group.data.json +0 -21
- package/dist/json/group.json +0 -402
- package/dist/json/groupOfRow.json +0 -137
- package/dist/json/groupOfRowData.json +0 -15
- package/dist/json/port.json +0 -346
- package/dist/json/saveAndContinue.json +0 -98
- package/dist/json/sublocation.json +0 -859
- package/dist/json/taskList.json +0 -265
- package/dist/json/team.json +0 -17351
- package/dist/json/terminal.json +0 -81
- package/dist/json/userProfile.data.json +0 -21
- package/dist/json/userProfile.json +0 -276
- package/dist/models/CollectionLabels.js +0 -15
- package/dist/models/ComponentTypes.js +0 -58
- package/dist/models/EventTypes.js +0 -16
- package/dist/models/FormPages.js +0 -16
- package/dist/models/FormTypes.js +0 -24
- package/dist/models/HubFormats.js +0 -14
- package/dist/models/PageAction.js +0 -65
- package/dist/models/TaskStates.js +0 -46
- package/dist/models/index.js +0 -77
- package/dist/setupTests.js +0 -54
- package/dist/utils/CheckYourAnswers/getCYAAction.js +0 -44
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +0 -120
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +0 -57
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +0 -162
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +0 -66
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +0 -198
- package/dist/utils/CheckYourAnswers/getCYARow.js +0 -58
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +0 -373
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +0 -69
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +0 -70
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +0 -71
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +0 -285
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +0 -237
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +0 -844
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +0 -45
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +0 -535
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +0 -72
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +0 -343
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.js +0 -42
- package/dist/utils/CheckYourAnswers/getSummaryListRowForDetails.test.js +0 -56
- package/dist/utils/CheckYourAnswers/index.js +0 -15
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +0 -53
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +0 -149
- package/dist/utils/CollectionPage/addCollectionPageEntry.js +0 -23
- package/dist/utils/CollectionPage/addCollectionPageEntry.test.js +0 -17
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +0 -26
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +0 -70
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.js +0 -51
- package/dist/utils/CollectionPage/duplicateCollectionPageEntry.test.js +0 -125
- package/dist/utils/CollectionPage/getCollectionPageActiveId.js +0 -24
- package/dist/utils/CollectionPage/getCollectionPageActiveId.test.js +0 -26
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +0 -44
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +0 -88
- package/dist/utils/CollectionPage/getCollectionPageData.js +0 -53
- package/dist/utils/CollectionPage/getCollectionPageData.test.js +0 -103
- package/dist/utils/CollectionPage/getErrorsForCollection.js +0 -55
- package/dist/utils/CollectionPage/getErrorsForCollection.test.js +0 -154
- package/dist/utils/CollectionPage/getQuickEditPage.js +0 -122
- package/dist/utils/CollectionPage/getQuickEditPage.test.js +0 -143
- package/dist/utils/CollectionPage/index.js +0 -33
- package/dist/utils/CollectionPage/mergeCollectionPages.js +0 -128
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +0 -198
- package/dist/utils/CollectionPage/removeCollectionPageEntry.js +0 -36
- package/dist/utils/CollectionPage/removeCollectionPageEntry.test.js +0 -62
- package/dist/utils/CollectionPage/setCollectionPageData.js +0 -60
- package/dist/utils/CollectionPage/setCollectionPageData.test.js +0 -182
- package/dist/utils/Component/addShowWhen.js +0 -43
- package/dist/utils/Component/addShowWhen.test.js +0 -217
- package/dist/utils/Component/applyToComponentTree.js +0 -68
- package/dist/utils/Component/applyToComponentTree.test.js +0 -125
- package/dist/utils/Component/cleanAttributes.js +0 -42
- package/dist/utils/Component/cleanAttributes.test.js +0 -67
- package/dist/utils/Component/elevateNestedComponents.js +0 -58
- package/dist/utils/Component/elevateNestedComponents.test.js +0 -305
- package/dist/utils/Component/getComponent.js +0 -305
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +0 -73
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +0 -251
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +0 -156
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +0 -104
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +0 -56
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +0 -31
- package/dist/utils/Component/getComponentTests/getComponent.html.test.js +0 -42
- package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +0 -29
- package/dist/utils/Component/getComponentTests/getComponent.list.test.js +0 -47
- package/dist/utils/Component/getComponentTests/getComponent.multifile.test.js +0 -66
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +0 -211
- package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +0 -46
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +0 -221
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +0 -62
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +0 -60
- package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +0 -104
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +0 -80
- package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +0 -14
- package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +0 -29
- package/dist/utils/Component/getDefaultValue.js +0 -22
- package/dist/utils/Component/getDefaultValue.test.js +0 -62
- package/dist/utils/Component/getDefaultValueFromConfig.js +0 -106
- package/dist/utils/Component/getDefaultValueFromConfig.test.js +0 -141
- package/dist/utils/Component/index.js +0 -29
- package/dist/utils/Component/isEditable.js +0 -13
- package/dist/utils/Component/isEditable.test.js +0 -42
- package/dist/utils/Component/optionIsSelected.js +0 -25
- package/dist/utils/Component/optionIsSelected.test.js +0 -69
- package/dist/utils/Component/setupContainerComponentsPath.js +0 -35
- package/dist/utils/Component/setupContainerComponentsPath.test.js +0 -79
- package/dist/utils/Component/showComponent.js +0 -25
- package/dist/utils/Component/showComponent.test.js +0 -157
- package/dist/utils/Component/wrapInFormGroup.js +0 -26
- package/dist/utils/Condition/index.js +0 -17
- package/dist/utils/Condition/meetsAllConditions.js +0 -44
- package/dist/utils/Condition/meetsAllConditions.test.js +0 -109
- package/dist/utils/Condition/meetsCondition.js +0 -165
- package/dist/utils/Condition/meetsCondition.test.js +0 -899
- package/dist/utils/Condition/meetsOneCondition.js +0 -32
- package/dist/utils/Condition/meetsOneCondition.test.js +0 -101
- package/dist/utils/Condition/setupConditions.js +0 -36
- package/dist/utils/Condition/setupConditions.test.js +0 -34
- package/dist/utils/Container/getEditableComponents.js +0 -29
- package/dist/utils/Container/getEditableComponents.test.js +0 -134
- package/dist/utils/Container/index.js +0 -17
- package/dist/utils/Container/setupNesting.js +0 -53
- package/dist/utils/Container/setupNesting.test.js +0 -143
- package/dist/utils/Container/showContainer.js +0 -52
- package/dist/utils/Container/showContainer.test.js +0 -179
- package/dist/utils/Data/applyFormula.js +0 -90
- package/dist/utils/Data/applyFormula.test.js +0 -264
- package/dist/utils/Data/deleteValues.js +0 -19
- package/dist/utils/Data/deleteValues.test.js +0 -58
- package/dist/utils/Data/getAutocompleteSource.js +0 -87
- package/dist/utils/Data/getAutocompleteSource.test.js +0 -335
- package/dist/utils/Data/getDataPath.js +0 -66
- package/dist/utils/Data/getDataPath.test.js +0 -49
- package/dist/utils/Data/getOptions.js +0 -86
- package/dist/utils/Data/getOptions.test.js +0 -279
- package/dist/utils/Data/getSourceData.js +0 -44
- package/dist/utils/Data/getSourceData.test.js +0 -158
- package/dist/utils/Data/index.js +0 -35
- package/dist/utils/Data/nestInRefdataOptions.js +0 -47
- package/dist/utils/Data/nestInRefdataOptions.test.js +0 -237
- package/dist/utils/Data/refDataToOptions.js +0 -44
- package/dist/utils/Data/refDataToOptions.test.js +0 -197
- package/dist/utils/Data/setDataItem.js +0 -26
- package/dist/utils/Data/setDataItem.test.js +0 -136
- package/dist/utils/Data/setupFormData.js +0 -49
- package/dist/utils/Data/setupFormData.test.js +0 -215
- package/dist/utils/Data/setupRefDataUrlForComponent.js +0 -44
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +0 -150
- package/dist/utils/FormPage/applyConditionalProperties.js +0 -34
- package/dist/utils/FormPage/applyConditionalProperties.test.js +0 -61
- package/dist/utils/FormPage/getConditionalText.js +0 -55
- package/dist/utils/FormPage/getConditionalText.test.js +0 -163
- package/dist/utils/FormPage/getFormPage.js +0 -54
- package/dist/utils/FormPage/getFormPage.test.js +0 -206
- package/dist/utils/FormPage/getFormPages.js +0 -30
- package/dist/utils/FormPage/getFormPages.test.js +0 -97
- package/dist/utils/FormPage/getPageActions.js +0 -58
- package/dist/utils/FormPage/getPageActions.test.js +0 -115
- package/dist/utils/FormPage/getParagraphFromText.js +0 -21
- package/dist/utils/FormPage/getParagraphFromText.test.js +0 -28
- package/dist/utils/FormPage/index.js +0 -24
- package/dist/utils/FormPage/showFormPage.js +0 -52
- package/dist/utils/FormPage/showFormPage.test.js +0 -181
- package/dist/utils/FormPage/showFormPageCYA.js +0 -23
- package/dist/utils/FormPage/showFormPageCYA.test.js +0 -29
- package/dist/utils/FormPage/useComponent.js +0 -83
- package/dist/utils/FormPage/useComponent.test.js +0 -216
- package/dist/utils/Format/formatData.js +0 -27
- package/dist/utils/Format/formatData.test.js +0 -46
- package/dist/utils/Format/formatDataForComponent.js +0 -35
- package/dist/utils/Format/formatDataForComponent.test.js +0 -114
- package/dist/utils/Format/formatDataForForm.js +0 -27
- package/dist/utils/Format/formatDataForForm.test.js +0 -79
- package/dist/utils/Format/formatDataForPage.js +0 -31
- package/dist/utils/Format/formatDataForPage.test.js +0 -94
- package/dist/utils/Format/index.js +0 -21
- package/dist/utils/Hub/getFormHub.js +0 -40
- package/dist/utils/Hub/getFormHub.test.js +0 -105
- package/dist/utils/Hub/index.js +0 -15
- package/dist/utils/Meta/constants.js +0 -9
- package/dist/utils/Meta/documents/getDocuments.js +0 -15
- package/dist/utils/Meta/documents/getDocuments.test.js +0 -46
- package/dist/utils/Meta/documents/index.js +0 -19
- package/dist/utils/Meta/documents/setDocumentsForField.js +0 -30
- package/dist/utils/Meta/documents/setDocumentsForField.test.js +0 -97
- package/dist/utils/Meta/index.js +0 -17
- package/dist/utils/Operate/checkValueIsTruthy.js +0 -29
- package/dist/utils/Operate/checkValueIsTruthy.test.js +0 -43
- package/dist/utils/Operate/deleteValueInFormData.js +0 -27
- package/dist/utils/Operate/deleteValueInFormData.test.js +0 -61
- package/dist/utils/Operate/doesContainValue.js +0 -35
- package/dist/utils/Operate/doesContainValue.test.js +0 -76
- package/dist/utils/Operate/getFirstOf.js +0 -31
- package/dist/utils/Operate/getFirstOf.test.js +0 -87
- package/dist/utils/Operate/getIndexOfMatchingValueIn.js +0 -68
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +0 -158
- package/dist/utils/Operate/getLength.js +0 -51
- package/dist/utils/Operate/getLength.test.js +0 -90
- package/dist/utils/Operate/index.js +0 -13
- package/dist/utils/Operate/persistValueInFormData.js +0 -40
- package/dist/utils/Operate/persistValueInFormData.test.js +0 -118
- package/dist/utils/Operate/runPageOperations.js +0 -75
- package/dist/utils/Operate/runPageOperations.test.js +0 -105
- package/dist/utils/Operate/setValueInFormData.js +0 -22
- package/dist/utils/Operate/setValueInFormData.test.js +0 -45
- package/dist/utils/Operate/shouldRun.js +0 -57
- package/dist/utils/Operate/shouldRun.test.js +0 -65
- package/dist/utils/Validate/additional/conditionallyPermittedChange.js +0 -26
- package/dist/utils/Validate/additional/conditionallyPermittedChange.test.js +0 -34
- package/dist/utils/Validate/additional/conditionallyRequired.js +0 -24
- package/dist/utils/Validate/additional/conditionallyRequired.test.js +0 -74
- package/dist/utils/Validate/additional/index.js +0 -74
- package/dist/utils/Validate/additional/index.test.js +0 -130
- package/dist/utils/Validate/additional/mustBeAfter.js +0 -34
- package/dist/utils/Validate/additional/mustBeAfter.test.js +0 -109
- package/dist/utils/Validate/additional/mustBeBefore.js +0 -34
- package/dist/utils/Validate/additional/mustBeBefore.test.js +0 -77
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +0 -57
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +0 -128
- package/dist/utils/Validate/additional/mustBeGreaterThan.js +0 -22
- package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +0 -57
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +0 -33
- package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +0 -32
- package/dist/utils/Validate/additional/mustBeInThePast.js +0 -36
- package/dist/utils/Validate/additional/mustBeInThePast.test.js +0 -32
- package/dist/utils/Validate/additional/mustBeLessThan.js +0 -22
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +0 -53
- package/dist/utils/Validate/additional/mustBeLongerThan.js +0 -23
- package/dist/utils/Validate/additional/mustBeLongerThan.test.js +0 -49
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +0 -24
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +0 -45
- package/dist/utils/Validate/additional/mustBeOneOf.js +0 -22
- package/dist/utils/Validate/additional/mustBeOneOf.test.js +0 -37
- package/dist/utils/Validate/additional/mustBeShorterThan.js +0 -23
- package/dist/utils/Validate/additional/mustBeShorterThan.test.js +0 -49
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.js +0 -40
- package/dist/utils/Validate/additional/mustBeUniqueInCollection.test.js +0 -163
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +0 -26
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +0 -37
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +0 -19
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +0 -37
- package/dist/utils/Validate/additional/mustNotContainSql.js +0 -19
- package/dist/utils/Validate/additional/mustNotContainSql.test.js +0 -33
- package/dist/utils/Validate/additional/mustSelectOnlyOne.js +0 -29
- package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +0 -55
- package/dist/utils/Validate/additional/utils.js +0 -35
- package/dist/utils/Validate/index.js +0 -33
- package/dist/utils/Validate/validateCollection.js +0 -50
- package/dist/utils/Validate/validateCollection.test.js +0 -134
- package/dist/utils/Validate/validateComponent.js +0 -126
- package/dist/utils/Validate/validateComponent.test.js +0 -435
- package/dist/utils/Validate/validateContainer.js +0 -52
- package/dist/utils/Validate/validateContainer.test.js +0 -115
- package/dist/utils/Validate/validateDate.js +0 -112
- package/dist/utils/Validate/validateDate.test.js +0 -133
- package/dist/utils/Validate/validateEmail.js +0 -45
- package/dist/utils/Validate/validateEmail.test.js +0 -78
- package/dist/utils/Validate/validateMultifile.js +0 -29
- package/dist/utils/Validate/validateMultifile.test.js +0 -46
- package/dist/utils/Validate/validateOnPageLoad.js +0 -24
- package/dist/utils/Validate/validateOnPageLoad.test.js +0 -89
- package/dist/utils/Validate/validatePage.js +0 -56
- package/dist/utils/Validate/validatePage.test.js +0 -795
- package/dist/utils/Validate/validateRegex.js +0 -41
- package/dist/utils/Validate/validateRegex.test.js +0 -43
- package/dist/utils/Validate/validateRequired.js +0 -37
- package/dist/utils/Validate/validateRequired.test.js +0 -64
- package/dist/utils/Validate/validateTextArea.js +0 -36
- package/dist/utils/Validate/validateTextArea.test.js +0 -71
- package/dist/utils/Validate/validateTime.js +0 -76
- package/dist/utils/Validate/validateTime.test.js +0 -116
- package/dist/utils/canOverrideFieldRequired.js +0 -23
- package/dist/utils/index.js +0 -42
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* Validates an components value against a given regex pattern.
|
|
9
|
-
*
|
|
10
|
-
* An empty string for value is considered valid as not all components
|
|
11
|
-
* with pattern validation have to be required.
|
|
12
|
-
* @param {*} value The value to validate.
|
|
13
|
-
* @param {string} label The label to use in the default error message.
|
|
14
|
-
* @param {string} pattern The regex pattern to validate against.
|
|
15
|
-
* @param {array} customErrors The array of custom errors for the component.
|
|
16
|
-
* @returns An error if the value doesn't match the regex pattern.
|
|
17
|
-
*/
|
|
18
|
-
const validateRegex = (value, label, pattern, customErrors) => {
|
|
19
|
-
if (!value) {
|
|
20
|
-
return undefined;
|
|
21
|
-
}
|
|
22
|
-
if (typeof value === 'string') {
|
|
23
|
-
const regex = new RegExp(pattern);
|
|
24
|
-
if (regex.test(value)) {
|
|
25
|
-
return undefined;
|
|
26
|
-
}
|
|
27
|
-
if (Array.isArray(customErrors)) {
|
|
28
|
-
var _result$;
|
|
29
|
-
const result = customErrors.filter(error => error.type === 'pattern');
|
|
30
|
-
if (result !== null && result !== void 0 && (_result$ = result[0]) !== null && _result$ !== void 0 && _result$.message) {
|
|
31
|
-
return result[0].message;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
if (!label) {
|
|
36
|
-
return 'Component failed regex validation';
|
|
37
|
-
}
|
|
38
|
-
return "".concat(label, " failed regex validation");
|
|
39
|
-
};
|
|
40
|
-
var _default = exports.default = validateRegex;
|
|
41
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ2YWxpZGF0ZVJlZ2V4IiwidmFsdWUiLCJsYWJlbCIsInBhdHRlcm4iLCJjdXN0b21FcnJvcnMiLCJ1bmRlZmluZWQiLCJyZWdleCIsIlJlZ0V4cCIsInRlc3QiLCJBcnJheSIsImlzQXJyYXkiLCJfcmVzdWx0JCIsInJlc3VsdCIsImZpbHRlciIsImVycm9yIiwidHlwZSIsIm1lc3NhZ2UiLCJjb25jYXQiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL1ZhbGlkYXRlL3ZhbGlkYXRlUmVnZXguanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBWYWxpZGF0ZXMgYW4gY29tcG9uZW50cyB2YWx1ZSBhZ2FpbnN0IGEgZ2l2ZW4gcmVnZXggcGF0dGVybi5cbiAqIFxuICogQW4gZW1wdHkgc3RyaW5nIGZvciB2YWx1ZSBpcyBjb25zaWRlcmVkIHZhbGlkIGFzIG5vdCBhbGwgY29tcG9uZW50c1xuICogd2l0aCBwYXR0ZXJuIHZhbGlkYXRpb24gaGF2ZSB0byBiZSByZXF1aXJlZC4gXG4gKiBAcGFyYW0geyp9IHZhbHVlIFRoZSB2YWx1ZSB0byB2YWxpZGF0ZS5cbiAqIEBwYXJhbSB7c3RyaW5nfSBsYWJlbCBUaGUgbGFiZWwgdG8gdXNlIGluIHRoZSBkZWZhdWx0IGVycm9yIG1lc3NhZ2UuXG4gKiBAcGFyYW0ge3N0cmluZ30gcGF0dGVybiBUaGUgcmVnZXggcGF0dGVybiB0byB2YWxpZGF0ZSBhZ2FpbnN0LlxuICogQHBhcmFtIHthcnJheX0gY3VzdG9tRXJyb3JzIFRoZSBhcnJheSBvZiBjdXN0b20gZXJyb3JzIGZvciB0aGUgY29tcG9uZW50LlxuICogQHJldHVybnMgQW4gZXJyb3IgaWYgdGhlIHZhbHVlIGRvZXNuJ3QgbWF0Y2ggdGhlIHJlZ2V4IHBhdHRlcm4uXG4gKi9cbmNvbnN0IHZhbGlkYXRlUmVnZXggPSAodmFsdWUsIGxhYmVsLCBwYXR0ZXJuLCBjdXN0b21FcnJvcnMpID0+IHtcbiAgaWYgKCF2YWx1ZSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cbiAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICBjb25zdCByZWdleCA9IG5ldyBSZWdFeHAocGF0dGVybik7XG4gICAgaWYgKHJlZ2V4LnRlc3QodmFsdWUpKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgICBpZiAoQXJyYXkuaXNBcnJheShjdXN0b21FcnJvcnMpKSB7XG4gICAgICBjb25zdCByZXN1bHQgPSBjdXN0b21FcnJvcnMuZmlsdGVyKChlcnJvcikgPT4gZXJyb3IudHlwZSA9PT0gJ3BhdHRlcm4nKTtcbiAgICAgIGlmIChyZXN1bHQ/LlswXT8ubWVzc2FnZSkge1xuICAgICAgICByZXR1cm4gcmVzdWx0WzBdLm1lc3NhZ2U7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIGlmICghbGFiZWwpIHtcbiAgICByZXR1cm4gJ0NvbXBvbmVudCBmYWlsZWQgcmVnZXggdmFsaWRhdGlvbic7XG4gIH1cbiAgcmV0dXJuIGAke2xhYmVsfSBmYWlsZWQgcmVnZXggdmFsaWRhdGlvbmA7XG59O1xuXG5leHBvcnQgZGVmYXVsdCB2YWxpZGF0ZVJlZ2V4O1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsTUFBTUEsYUFBYSxHQUFHQSxDQUFDQyxLQUFLLEVBQUVDLEtBQUssRUFBRUMsT0FBTyxFQUFFQyxZQUFZLEtBQUs7RUFDN0QsSUFBSSxDQUFDSCxLQUFLLEVBQUU7SUFDVixPQUFPSSxTQUFTO0VBQ2xCO0VBQ0EsSUFBSSxPQUFPSixLQUFLLEtBQUssUUFBUSxFQUFFO0lBQzdCLE1BQU1LLEtBQUssR0FBRyxJQUFJQyxNQUFNLENBQUNKLE9BQU8sQ0FBQztJQUNqQyxJQUFJRyxLQUFLLENBQUNFLElBQUksQ0FBQ1AsS0FBSyxDQUFDLEVBQUU7TUFDckIsT0FBT0ksU0FBUztJQUNsQjtJQUNBLElBQUlJLEtBQUssQ0FBQ0MsT0FBTyxDQUFDTixZQUFZLENBQUMsRUFBRTtNQUFBLElBQUFPLFFBQUE7TUFDL0IsTUFBTUMsTUFBTSxHQUFHUixZQUFZLENBQUNTLE1BQU0sQ0FBRUMsS0FBSyxJQUFLQSxLQUFLLENBQUNDLElBQUksS0FBSyxTQUFTLENBQUM7TUFDdkUsSUFBSUgsTUFBTSxhQUFOQSxNQUFNLGdCQUFBRCxRQUFBLEdBQU5DLE1BQU0sQ0FBRyxDQUFDLENBQUMsY0FBQUQsUUFBQSxlQUFYQSxRQUFBLENBQWFLLE9BQU8sRUFBRTtRQUN4QixPQUFPSixNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUNJLE9BQU87TUFDMUI7SUFDRjtFQUNGO0VBQ0EsSUFBSSxDQUFDZCxLQUFLLEVBQUU7SUFDVixPQUFPLG1DQUFtQztFQUM1QztFQUNBLFVBQUFlLE1BQUEsQ0FBVWYsS0FBSztBQUNqQixDQUFDO0FBQUMsSUFBQWdCLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFwQixhQUFhIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _validateRegex = _interopRequireDefault(require("./validateRegex"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
// Local imports
|
|
6
|
-
|
|
7
|
-
describe('utils', () => {
|
|
8
|
-
describe('Validate', () => {
|
|
9
|
-
describe('regex', () => {
|
|
10
|
-
const GOOD_VALUE = 'hello';
|
|
11
|
-
const BAD_VALUE = 'h3llo';
|
|
12
|
-
const LABEL = 'Component';
|
|
13
|
-
const PATTERN = '^[a-z]*$';
|
|
14
|
-
const CUSTOM_ERRORS = [{
|
|
15
|
-
"type": "pattern",
|
|
16
|
-
"message": "Regex validation failed for ".concat(LABEL)
|
|
17
|
-
}];
|
|
18
|
-
const DEFAULT_ERROR = [{
|
|
19
|
-
"type": "pattern"
|
|
20
|
-
}];
|
|
21
|
-
|
|
22
|
-
// Valid values
|
|
23
|
-
it('should return no error when the value matches the regex pattern', () => {
|
|
24
|
-
expect((0, _validateRegex.default)(GOOD_VALUE, LABEL, PATTERN, CUSTOM_ERRORS)).toBeUndefined();
|
|
25
|
-
});
|
|
26
|
-
it('should return no error when the value is an empty string', () => {
|
|
27
|
-
expect((0, _validateRegex.default)('', LABEL, PATTERN, CUSTOM_ERRORS)).toBeUndefined();
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
// Invalid values
|
|
31
|
-
it('should return a custom error when the value does not match the regex pattern and one is specified', () => {
|
|
32
|
-
expect((0, _validateRegex.default)(BAD_VALUE, LABEL, PATTERN, CUSTOM_ERRORS)).toEqual(CUSTOM_ERRORS[0].message);
|
|
33
|
-
});
|
|
34
|
-
it('should return an error using label when the value does not match the regex pattern and a custom error is not specified', () => {
|
|
35
|
-
expect((0, _validateRegex.default)(BAD_VALUE, LABEL, PATTERN, DEFAULT_ERROR)).toEqual("".concat(LABEL, " failed regex validation"));
|
|
36
|
-
});
|
|
37
|
-
it('should return a default error when the value does not match the regex pattern and both a custom error and label are not specified', () => {
|
|
38
|
-
expect((0, _validateRegex.default)(BAD_VALUE, '', PATTERN, DEFAULT_ERROR)).toEqual('Component failed regex validation');
|
|
39
|
-
});
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdmFsaWRhdGVSZWdleCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJHT09EX1ZBTFVFIiwiQkFEX1ZBTFVFIiwiTEFCRUwiLCJQQVRURVJOIiwiQ1VTVE9NX0VSUk9SUyIsImNvbmNhdCIsIkRFRkFVTFRfRVJST1IiLCJpdCIsImV4cGVjdCIsInZhbGlkYXRlUmVnZXgiLCJ0b0JlVW5kZWZpbmVkIiwidG9FcXVhbCIsIm1lc3NhZ2UiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvdmFsaWRhdGVSZWdleC50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIExvY2FsIGltcG9ydHNcbmltcG9ydCB2YWxpZGF0ZVJlZ2V4IGZyb20gJy4vdmFsaWRhdGVSZWdleCc7XG5cbmRlc2NyaWJlKCd1dGlscycsICgpID0+IHtcblxuICBkZXNjcmliZSgnVmFsaWRhdGUnLCAoKSA9PiB7XG5cbiAgICBkZXNjcmliZSgncmVnZXgnLCAoKSA9PiB7XG4gICAgICBjb25zdCBHT09EX1ZBTFVFID0gJ2hlbGxvJztcbiAgICAgIGNvbnN0IEJBRF9WQUxVRSA9ICdoM2xsbyc7XG4gICAgICBjb25zdCBMQUJFTCA9ICdDb21wb25lbnQnO1xuICAgICAgY29uc3QgUEFUVEVSTiA9ICdeW2Etel0qJCc7XG4gICAgICBjb25zdCBDVVNUT01fRVJST1JTID0gW1xuICAgICAgICB7XG4gICAgICAgICAgXCJ0eXBlXCI6IFwicGF0dGVyblwiLFxuICAgICAgICAgIFwibWVzc2FnZVwiOiBgUmVnZXggdmFsaWRhdGlvbiBmYWlsZWQgZm9yICR7TEFCRUx9YCBcbiAgICAgICAgfVxuICAgICAgXTtcbiAgICAgIGNvbnN0IERFRkFVTFRfRVJST1IgPSBbXG4gICAgICAgIHtcbiAgICAgICAgICBcInR5cGVcIjogXCJwYXR0ZXJuXCJcbiAgICAgICAgfVxuICAgICAgXTtcblxuICAgICAgLy8gVmFsaWQgdmFsdWVzXG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBubyBlcnJvciB3aGVuIHRoZSB2YWx1ZSBtYXRjaGVzIHRoZSByZWdleCBwYXR0ZXJuJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZWdleChHT09EX1ZBTFVFLCBMQUJFTCwgUEFUVEVSTiwgQ1VTVE9NX0VSUk9SUykpLnRvQmVVbmRlZmluZWQoKTtcbiAgICAgIH0pO1xuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB0aGUgdmFsdWUgaXMgYW4gZW1wdHkgc3RyaW5nJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZWdleCgnJywgTEFCRUwsIFBBVFRFUk4sIENVU1RPTV9FUlJPUlMpKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcblxuICAgICAgLy8gSW52YWxpZCB2YWx1ZXNcbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIGEgY3VzdG9tIGVycm9yIHdoZW4gdGhlIHZhbHVlIGRvZXMgbm90IG1hdGNoIHRoZSByZWdleCBwYXR0ZXJuIGFuZCBvbmUgaXMgc3BlY2lmaWVkJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZWdleChCQURfVkFMVUUsIExBQkVMLCBQQVRURVJOLCBDVVNUT01fRVJST1JTKSkudG9FcXVhbChDVVNUT01fRVJST1JTWzBdLm1lc3NhZ2UpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciB1c2luZyBsYWJlbCB3aGVuIHRoZSB2YWx1ZSBkb2VzIG5vdCBtYXRjaCB0aGUgcmVnZXggcGF0dGVybiBhbmQgYSBjdXN0b20gZXJyb3IgaXMgbm90IHNwZWNpZmllZCcsICgpID0+IHtcbiAgICAgICAgZXhwZWN0KHZhbGlkYXRlUmVnZXgoQkFEX1ZBTFVFLCBMQUJFTCwgUEFUVEVSTiwgREVGQVVMVF9FUlJPUikpLnRvRXF1YWwoYCR7TEFCRUx9IGZhaWxlZCByZWdleCB2YWxpZGF0aW9uYCk7XG4gICAgICB9KTtcbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIGEgZGVmYXVsdCBlcnJvciB3aGVuIHRoZSB2YWx1ZSBkb2VzIG5vdCBtYXRjaCB0aGUgcmVnZXggcGF0dGVybiBhbmQgYm90aCBhIGN1c3RvbSBlcnJvciBhbmQgbGFiZWwgYXJlIG5vdCBzcGVjaWZpZWQnLCAoKSA9PiB7XG4gICAgICAgIGV4cGVjdCh2YWxpZGF0ZVJlZ2V4KEJBRF9WQUxVRSwgJycsIFBBVFRFUk4sIERFRkFVTFRfRVJST1IpKS50b0VxdWFsKCdDb21wb25lbnQgZmFpbGVkIHJlZ2V4IHZhbGlkYXRpb24nKTtcbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gIH0pO1xuXG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFDQSxJQUFBQSxjQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBNEMsU0FBQUQsdUJBQUFFLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFENUM7O0FBR0FHLFFBQVEsQ0FBQyxPQUFPLEVBQUUsTUFBTTtFQUV0QkEsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNO0lBRXpCQSxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU07TUFDdEIsTUFBTUMsVUFBVSxHQUFHLE9BQU87TUFDMUIsTUFBTUMsU0FBUyxHQUFHLE9BQU87TUFDekIsTUFBTUMsS0FBSyxHQUFHLFdBQVc7TUFDekIsTUFBTUMsT0FBTyxHQUFHLFVBQVU7TUFDMUIsTUFBTUMsYUFBYSxHQUFHLENBQ3BCO1FBQ0UsTUFBTSxFQUFFLFNBQVM7UUFDakIsU0FBUyxpQ0FBQUMsTUFBQSxDQUFpQ0gsS0FBSztNQUNqRCxDQUFDLENBQ0Y7TUFDRCxNQUFNSSxhQUFhLEdBQUcsQ0FDcEI7UUFDRSxNQUFNLEVBQUU7TUFDVixDQUFDLENBQ0Y7O01BRUQ7TUFDQUMsRUFBRSxDQUFDLGlFQUFpRSxFQUFFLE1BQU07UUFDMUVDLE1BQU0sQ0FBQyxJQUFBQyxzQkFBYSxFQUFDVCxVQUFVLEVBQUVFLEtBQUssRUFBRUMsT0FBTyxFQUFFQyxhQUFhLENBQUMsQ0FBQyxDQUFDTSxhQUFhLENBQUMsQ0FBQztNQUNsRixDQUFDLENBQUM7TUFDRkgsRUFBRSxDQUFDLDBEQUEwRCxFQUFFLE1BQU07UUFDbkVDLE1BQU0sQ0FBQyxJQUFBQyxzQkFBYSxFQUFDLEVBQUUsRUFBRVAsS0FBSyxFQUFFQyxPQUFPLEVBQUVDLGFBQWEsQ0FBQyxDQUFDLENBQUNNLGFBQWEsQ0FBQyxDQUFDO01BQzFFLENBQUMsQ0FBQzs7TUFFRjtNQUNBSCxFQUFFLENBQUMsbUdBQW1HLEVBQUUsTUFBTTtRQUM1R0MsTUFBTSxDQUFDLElBQUFDLHNCQUFhLEVBQUNSLFNBQVMsRUFBRUMsS0FBSyxFQUFFQyxPQUFPLEVBQUVDLGFBQWEsQ0FBQyxDQUFDLENBQUNPLE9BQU8sQ0FBQ1AsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDUSxPQUFPLENBQUM7TUFDbkcsQ0FBQyxDQUFDO01BQ0ZMLEVBQUUsQ0FBQyx3SEFBd0gsRUFBRSxNQUFNO1FBQ2pJQyxNQUFNLENBQUMsSUFBQUMsc0JBQWEsRUFBQ1IsU0FBUyxFQUFFQyxLQUFLLEVBQUVDLE9BQU8sRUFBRUcsYUFBYSxDQUFDLENBQUMsQ0FBQ0ssT0FBTyxJQUFBTixNQUFBLENBQUlILEtBQUssNkJBQTBCLENBQUM7TUFDN0csQ0FBQyxDQUFDO01BQ0ZLLEVBQUUsQ0FBQyxtSUFBbUksRUFBRSxNQUFNO1FBQzVJQyxNQUFNLENBQUMsSUFBQUMsc0JBQWEsRUFBQ1IsU0FBUyxFQUFFLEVBQUUsRUFBRUUsT0FBTyxFQUFFRyxhQUFhLENBQUMsQ0FBQyxDQUFDSyxPQUFPLENBQUMsbUNBQW1DLENBQUM7TUFDM0csQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDO0VBRUosQ0FBQyxDQUFDO0FBRUosQ0FBQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* Validates that a value is not nullish, which includes ensuring
|
|
9
|
-
* a string isn't just whitespace, an array is not empty, etc.
|
|
10
|
-
* @param {any} value The value to validate.
|
|
11
|
-
* @param {string} label The label to use in any error message.
|
|
12
|
-
* @returns An error if the value is nullish.
|
|
13
|
-
*/
|
|
14
|
-
const validateRequired = (value, label, customErrors) => {
|
|
15
|
-
let hasValue = false;
|
|
16
|
-
if (!!value || value === false || value === 0) {
|
|
17
|
-
hasValue = true;
|
|
18
|
-
if (typeof value === 'string') {
|
|
19
|
-
hasValue = value.trim().length > 0;
|
|
20
|
-
} else if (Array.isArray(value)) {
|
|
21
|
-
hasValue = value.length > 0;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
if (!hasValue) {
|
|
25
|
-
if (Array.isArray(customErrors)) {
|
|
26
|
-
const result = customErrors.filter(error => error.type === 'required');
|
|
27
|
-
if (result && result.length > 0 && result[0].message) {
|
|
28
|
-
return result[0].message;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
const name = label || 'Field';
|
|
32
|
-
return "".concat(name, " is required");
|
|
33
|
-
}
|
|
34
|
-
return undefined;
|
|
35
|
-
};
|
|
36
|
-
var _default = exports.default = validateRequired;
|
|
37
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ2YWxpZGF0ZVJlcXVpcmVkIiwidmFsdWUiLCJsYWJlbCIsImN1c3RvbUVycm9ycyIsImhhc1ZhbHVlIiwidHJpbSIsImxlbmd0aCIsIkFycmF5IiwiaXNBcnJheSIsInJlc3VsdCIsImZpbHRlciIsImVycm9yIiwidHlwZSIsIm1lc3NhZ2UiLCJuYW1lIiwiY29uY2F0IiwidW5kZWZpbmVkIiwiX2RlZmF1bHQiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS92YWxpZGF0ZVJlcXVpcmVkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVmFsaWRhdGVzIHRoYXQgYSB2YWx1ZSBpcyBub3QgbnVsbGlzaCwgd2hpY2ggaW5jbHVkZXMgZW5zdXJpbmdcbiAqIGEgc3RyaW5nIGlzbid0IGp1c3Qgd2hpdGVzcGFjZSwgYW4gYXJyYXkgaXMgbm90IGVtcHR5LCBldGMuXG4gKiBAcGFyYW0ge2FueX0gdmFsdWUgVGhlIHZhbHVlIHRvIHZhbGlkYXRlLlxuICogQHBhcmFtIHtzdHJpbmd9IGxhYmVsIFRoZSBsYWJlbCB0byB1c2UgaW4gYW55IGVycm9yIG1lc3NhZ2UuXG4gKiBAcmV0dXJucyBBbiBlcnJvciBpZiB0aGUgdmFsdWUgaXMgbnVsbGlzaC5cbiAqL1xuY29uc3QgdmFsaWRhdGVSZXF1aXJlZCA9ICh2YWx1ZSwgbGFiZWwsIGN1c3RvbUVycm9ycykgPT4ge1xuICBsZXQgaGFzVmFsdWUgPSBmYWxzZTtcbiAgaWYgKCEhdmFsdWUgfHwgdmFsdWUgPT09IGZhbHNlIHx8IHZhbHVlID09PSAwKSB7XG4gICAgaGFzVmFsdWUgPSB0cnVlO1xuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdzdHJpbmcnKSB7XG4gICAgICBoYXNWYWx1ZSA9IHZhbHVlLnRyaW0oKS5sZW5ndGggPiAwO1xuICAgIH0gZWxzZSBpZiAoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICAgIGhhc1ZhbHVlID0gdmFsdWUubGVuZ3RoID4gMDtcbiAgICB9XG4gIH1cbiAgaWYgKCFoYXNWYWx1ZSkge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGN1c3RvbUVycm9ycykpIHtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IGN1c3RvbUVycm9ycy5maWx0ZXIoKGVycm9yKSA9PiBlcnJvci50eXBlID09PSAncmVxdWlyZWQnKTtcbiAgICAgIGlmIChyZXN1bHQgJiYgcmVzdWx0Lmxlbmd0aCA+IDAgJiYgcmVzdWx0WzBdLm1lc3NhZ2UpIHtcbiAgICAgICAgcmV0dXJuIHJlc3VsdFswXS5tZXNzYWdlO1xuICAgICAgfVxuICAgIH1cbiAgICBjb25zdCBuYW1lID0gbGFiZWwgfHwgJ0ZpZWxkJztcbiAgICByZXR1cm4gYCR7bmFtZX0gaXMgcmVxdWlyZWRgO1xuICB9XG4gIHJldHVybiB1bmRlZmluZWQ7XG59O1xuXG5leHBvcnQgZGVmYXVsdCB2YWxpZGF0ZVJlcXVpcmVkO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1BLGdCQUFnQixHQUFHQSxDQUFDQyxLQUFLLEVBQUVDLEtBQUssRUFBRUMsWUFBWSxLQUFLO0VBQ3ZELElBQUlDLFFBQVEsR0FBRyxLQUFLO0VBQ3BCLElBQUksQ0FBQyxDQUFDSCxLQUFLLElBQUlBLEtBQUssS0FBSyxLQUFLLElBQUlBLEtBQUssS0FBSyxDQUFDLEVBQUU7SUFDN0NHLFFBQVEsR0FBRyxJQUFJO0lBQ2YsSUFBSSxPQUFPSCxLQUFLLEtBQUssUUFBUSxFQUFFO01BQzdCRyxRQUFRLEdBQUdILEtBQUssQ0FBQ0ksSUFBSSxDQUFDLENBQUMsQ0FBQ0MsTUFBTSxHQUFHLENBQUM7SUFDcEMsQ0FBQyxNQUFNLElBQUlDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDUCxLQUFLLENBQUMsRUFBRTtNQUMvQkcsUUFBUSxHQUFHSCxLQUFLLENBQUNLLE1BQU0sR0FBRyxDQUFDO0lBQzdCO0VBQ0Y7RUFDQSxJQUFJLENBQUNGLFFBQVEsRUFBRTtJQUNiLElBQUlHLEtBQUssQ0FBQ0MsT0FBTyxDQUFDTCxZQUFZLENBQUMsRUFBRTtNQUMvQixNQUFNTSxNQUFNLEdBQUdOLFlBQVksQ0FBQ08sTUFBTSxDQUFFQyxLQUFLLElBQUtBLEtBQUssQ0FBQ0MsSUFBSSxLQUFLLFVBQVUsQ0FBQztNQUN4RSxJQUFJSCxNQUFNLElBQUlBLE1BQU0sQ0FBQ0gsTUFBTSxHQUFHLENBQUMsSUFBSUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDSSxPQUFPLEVBQUU7UUFDcEQsT0FBT0osTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDSSxPQUFPO01BQzFCO0lBQ0Y7SUFDQSxNQUFNQyxJQUFJLEdBQUdaLEtBQUssSUFBSSxPQUFPO0lBQzdCLFVBQUFhLE1BQUEsQ0FBVUQsSUFBSTtFQUNoQjtFQUNBLE9BQU9FLFNBQVM7QUFDbEIsQ0FBQztBQUFDLElBQUFDLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFuQixnQkFBZ0IiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,64 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _validateRequired = _interopRequireDefault(require("./validateRequired"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
// Local imports
|
|
6
|
-
|
|
7
|
-
describe('utils', () => {
|
|
8
|
-
describe('Validate', () => {
|
|
9
|
-
describe('required', () => {
|
|
10
|
-
const LABEL = 'Component';
|
|
11
|
-
const ERROR = "".concat(LABEL, " is required");
|
|
12
|
-
|
|
13
|
-
// Valid values
|
|
14
|
-
it('should return no error when the value is set', () => {
|
|
15
|
-
expect((0, _validateRequired.default)('value', LABEL)).toBeUndefined();
|
|
16
|
-
});
|
|
17
|
-
it('should return no error when the value is an empty object', () => {
|
|
18
|
-
expect((0, _validateRequired.default)({}, LABEL)).toBeUndefined();
|
|
19
|
-
});
|
|
20
|
-
it('should return no error when the value is a non-empty array', () => {
|
|
21
|
-
expect((0, _validateRequired.default)(['bob'], LABEL)).toBeUndefined();
|
|
22
|
-
});
|
|
23
|
-
it('should return no error when the value is a boolean false', () => {
|
|
24
|
-
expect((0, _validateRequired.default)(false, LABEL)).toBeUndefined();
|
|
25
|
-
});
|
|
26
|
-
it('should return no error when the value is the number zero', () => {
|
|
27
|
-
expect((0, _validateRequired.default)(0, LABEL)).toBeUndefined();
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
// Invalid values
|
|
31
|
-
it('should return an error when the value is undefined', () => {
|
|
32
|
-
expect((0, _validateRequired.default)(undefined, LABEL)).toEqual(ERROR);
|
|
33
|
-
});
|
|
34
|
-
it('should return an error when the value is null', () => {
|
|
35
|
-
expect((0, _validateRequired.default)(null, LABEL)).toEqual(ERROR);
|
|
36
|
-
});
|
|
37
|
-
it('should return an error when the value is an empty string', () => {
|
|
38
|
-
expect((0, _validateRequired.default)('', LABEL)).toEqual(ERROR);
|
|
39
|
-
});
|
|
40
|
-
it('should return an error when the value is a string containing just spaces', () => {
|
|
41
|
-
expect((0, _validateRequired.default)(' ', LABEL)).toEqual(ERROR);
|
|
42
|
-
});
|
|
43
|
-
it('should return an error when the value is an empty array', () => {
|
|
44
|
-
expect((0, _validateRequired.default)([], LABEL)).toEqual(ERROR);
|
|
45
|
-
});
|
|
46
|
-
it('should use a default label when none is specified', () => {
|
|
47
|
-
expect((0, _validateRequired.default)(undefined, undefined)).toEqual('Field is required');
|
|
48
|
-
});
|
|
49
|
-
it('should use a custom error when one is provided', () => {
|
|
50
|
-
expect((0, _validateRequired.default)(undefined, undefined, [{
|
|
51
|
-
type: 'required',
|
|
52
|
-
message: 'custom error message'
|
|
53
|
-
}])).toEqual('custom error message');
|
|
54
|
-
});
|
|
55
|
-
it('should ignore a custom error when not of type required', () => {
|
|
56
|
-
expect((0, _validateRequired.default)(undefined, undefined, [{
|
|
57
|
-
type: 'genericError',
|
|
58
|
-
message: 'generic error message'
|
|
59
|
-
}])).toEqual('Field is required');
|
|
60
|
-
});
|
|
61
|
-
});
|
|
62
|
-
});
|
|
63
|
-
});
|
|
64
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdmFsaWRhdGVSZXF1aXJlZCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJMQUJFTCIsIkVSUk9SIiwiY29uY2F0IiwiaXQiLCJleHBlY3QiLCJ2YWxpZGF0ZVJlcXVpcmVkIiwidG9CZVVuZGVmaW5lZCIsInVuZGVmaW5lZCIsInRvRXF1YWwiLCJ0eXBlIiwibWVzc2FnZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS92YWxpZGF0ZVJlcXVpcmVkLnRlc3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gTG9jYWwgaW1wb3J0c1xuaW1wb3J0IHZhbGlkYXRlUmVxdWlyZWQgZnJvbSAnLi92YWxpZGF0ZVJlcXVpcmVkJztcblxuZGVzY3JpYmUoJ3V0aWxzJywgKCkgPT4ge1xuXG4gIGRlc2NyaWJlKCdWYWxpZGF0ZScsICgpID0+IHtcblxuICAgIGRlc2NyaWJlKCdyZXF1aXJlZCcsICgpID0+IHtcbiAgICAgIGNvbnN0IExBQkVMID0gJ0NvbXBvbmVudCc7XG4gICAgICBjb25zdCBFUlJPUiA9IGAke0xBQkVMfSBpcyByZXF1aXJlZGA7XG5cbiAgICAgIC8vIFZhbGlkIHZhbHVlc1xuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB0aGUgdmFsdWUgaXMgc2V0JywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCgndmFsdWUnLCBMQUJFTCkpLnRvQmVVbmRlZmluZWQoKTtcbiAgICAgIH0pO1xuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB0aGUgdmFsdWUgaXMgYW4gZW1wdHkgb2JqZWN0JywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCh7fSwgTEFCRUwpKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIG5vIGVycm9yIHdoZW4gdGhlIHZhbHVlIGlzIGEgbm9uLWVtcHR5IGFycmF5JywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZChbJ2JvYiddLCBMQUJFTCkpLnRvQmVVbmRlZmluZWQoKTtcbiAgICAgIH0pO1xuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB0aGUgdmFsdWUgaXMgYSBib29sZWFuIGZhbHNlJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZChmYWxzZSwgTEFCRUwpKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIG5vIGVycm9yIHdoZW4gdGhlIHZhbHVlIGlzIHRoZSBudW1iZXIgemVybycsICgpID0+IHtcbiAgICAgICAgZXhwZWN0KHZhbGlkYXRlUmVxdWlyZWQoMCwgTEFCRUwpKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcblxuICAgICAgLy8gSW52YWxpZCB2YWx1ZXNcbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIHdoZW4gdGhlIHZhbHVlIGlzIHVuZGVmaW5lZCcsICgpID0+IHtcbiAgICAgICAgZXhwZWN0KHZhbGlkYXRlUmVxdWlyZWQodW5kZWZpbmVkLCBMQUJFTCkpLnRvRXF1YWwoRVJST1IpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciB3aGVuIHRoZSB2YWx1ZSBpcyBudWxsJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZChudWxsLCBMQUJFTCkpLnRvRXF1YWwoRVJST1IpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciB3aGVuIHRoZSB2YWx1ZSBpcyBhbiBlbXB0eSBzdHJpbmcnLCAoKSA9PiB7XG4gICAgICAgIGV4cGVjdCh2YWxpZGF0ZVJlcXVpcmVkKCcnLCBMQUJFTCkpLnRvRXF1YWwoRVJST1IpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciB3aGVuIHRoZSB2YWx1ZSBpcyBhIHN0cmluZyBjb250YWluaW5nIGp1c3Qgc3BhY2VzJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCgnICAgICAnLCBMQUJFTCkpLnRvRXF1YWwoRVJST1IpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciB3aGVuIHRoZSB2YWx1ZSBpcyBhbiBlbXB0eSBhcnJheScsICgpID0+IHtcbiAgICAgICAgZXhwZWN0KHZhbGlkYXRlUmVxdWlyZWQoW10sIExBQkVMKSkudG9FcXVhbChFUlJPUik7XG4gICAgICB9KTtcbiAgICAgIGl0KCdzaG91bGQgdXNlIGEgZGVmYXVsdCBsYWJlbCB3aGVuIG5vbmUgaXMgc3BlY2lmaWVkJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCh1bmRlZmluZWQsIHVuZGVmaW5lZCkpLnRvRXF1YWwoJ0ZpZWxkIGlzIHJlcXVpcmVkJyk7XG4gICAgICB9KTtcbiAgICAgIGl0KCdzaG91bGQgdXNlIGEgY3VzdG9tIGVycm9yIHdoZW4gb25lIGlzIHByb3ZpZGVkJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCh1bmRlZmluZWQsIHVuZGVmaW5lZCwgW3t0eXBlOiAncmVxdWlyZWQnLCBtZXNzYWdlOiAnY3VzdG9tIGVycm9yIG1lc3NhZ2UnfV0pKS50b0VxdWFsKCdjdXN0b20gZXJyb3IgbWVzc2FnZScpO1xuICAgICAgfSk7XG4gICAgICBpdCgnc2hvdWxkIGlnbm9yZSBhIGN1c3RvbSBlcnJvciB3aGVuIG5vdCBvZiB0eXBlIHJlcXVpcmVkJywgKCkgPT4ge1xuICAgICAgICBleHBlY3QodmFsaWRhdGVSZXF1aXJlZCh1bmRlZmluZWQsIHVuZGVmaW5lZCwgW3t0eXBlOiAnZ2VuZXJpY0Vycm9yJywgbWVzc2FnZTogJ2dlbmVyaWMgZXJyb3IgbWVzc2FnZSd9XSkpLnRvRXF1YWwoJ0ZpZWxkIGlzIHJlcXVpcmVkJyk7XG4gICAgICB9KTtcblxuICAgIH0pO1xuXG4gIH0pO1xuXG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFDQSxJQUFBQSxpQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQWtELFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRGxEOztBQUdBRyxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU07RUFFdEJBLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTTtJQUV6QkEsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNO01BQ3pCLE1BQU1DLEtBQUssR0FBRyxXQUFXO01BQ3pCLE1BQU1DLEtBQUssTUFBQUMsTUFBQSxDQUFNRixLQUFLLGlCQUFjOztNQUVwQztNQUNBRyxFQUFFLENBQUMsOENBQThDLEVBQUUsTUFBTTtRQUN2REMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDLE9BQU8sRUFBRUwsS0FBSyxDQUFDLENBQUMsQ0FBQ00sYUFBYSxDQUFDLENBQUM7TUFDMUQsQ0FBQyxDQUFDO01BQ0ZILEVBQUUsQ0FBQywwREFBMEQsRUFBRSxNQUFNO1FBQ25FQyxNQUFNLENBQUMsSUFBQUMseUJBQWdCLEVBQUMsQ0FBQyxDQUFDLEVBQUVMLEtBQUssQ0FBQyxDQUFDLENBQUNNLGFBQWEsQ0FBQyxDQUFDO01BQ3JELENBQUMsQ0FBQztNQUNGSCxFQUFFLENBQUMsNERBQTRELEVBQUUsTUFBTTtRQUNyRUMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDLENBQUMsS0FBSyxDQUFDLEVBQUVMLEtBQUssQ0FBQyxDQUFDLENBQUNNLGFBQWEsQ0FBQyxDQUFDO01BQzFELENBQUMsQ0FBQztNQUNGSCxFQUFFLENBQUMsMERBQTBELEVBQUUsTUFBTTtRQUNuRUMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDLEtBQUssRUFBRUwsS0FBSyxDQUFDLENBQUMsQ0FBQ00sYUFBYSxDQUFDLENBQUM7TUFDeEQsQ0FBQyxDQUFDO01BQ0ZILEVBQUUsQ0FBQywwREFBMEQsRUFBRSxNQUFNO1FBQ25FQyxNQUFNLENBQUMsSUFBQUMseUJBQWdCLEVBQUMsQ0FBQyxFQUFFTCxLQUFLLENBQUMsQ0FBQyxDQUFDTSxhQUFhLENBQUMsQ0FBQztNQUNwRCxDQUFDLENBQUM7O01BRUY7TUFDQUgsRUFBRSxDQUFDLG9EQUFvRCxFQUFFLE1BQU07UUFDN0RDLE1BQU0sQ0FBQyxJQUFBQyx5QkFBZ0IsRUFBQ0UsU0FBUyxFQUFFUCxLQUFLLENBQUMsQ0FBQyxDQUFDUSxPQUFPLENBQUNQLEtBQUssQ0FBQztNQUMzRCxDQUFDLENBQUM7TUFDRkUsRUFBRSxDQUFDLCtDQUErQyxFQUFFLE1BQU07UUFDeERDLE1BQU0sQ0FBQyxJQUFBQyx5QkFBZ0IsRUFBQyxJQUFJLEVBQUVMLEtBQUssQ0FBQyxDQUFDLENBQUNRLE9BQU8sQ0FBQ1AsS0FBSyxDQUFDO01BQ3RELENBQUMsQ0FBQztNQUNGRSxFQUFFLENBQUMsMERBQTBELEVBQUUsTUFBTTtRQUNuRUMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDLEVBQUUsRUFBRUwsS0FBSyxDQUFDLENBQUMsQ0FBQ1EsT0FBTyxDQUFDUCxLQUFLLENBQUM7TUFDcEQsQ0FBQyxDQUFDO01BQ0ZFLEVBQUUsQ0FBQywwRUFBMEUsRUFBRSxNQUFNO1FBQ25GQyxNQUFNLENBQUMsSUFBQUMseUJBQWdCLEVBQUMsT0FBTyxFQUFFTCxLQUFLLENBQUMsQ0FBQyxDQUFDUSxPQUFPLENBQUNQLEtBQUssQ0FBQztNQUN6RCxDQUFDLENBQUM7TUFDRkUsRUFBRSxDQUFDLHlEQUF5RCxFQUFFLE1BQU07UUFDbEVDLE1BQU0sQ0FBQyxJQUFBQyx5QkFBZ0IsRUFBQyxFQUFFLEVBQUVMLEtBQUssQ0FBQyxDQUFDLENBQUNRLE9BQU8sQ0FBQ1AsS0FBSyxDQUFDO01BQ3BELENBQUMsQ0FBQztNQUNGRSxFQUFFLENBQUMsbURBQW1ELEVBQUUsTUFBTTtRQUM1REMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDRSxTQUFTLEVBQUVBLFNBQVMsQ0FBQyxDQUFDLENBQUNDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQztNQUM3RSxDQUFDLENBQUM7TUFDRkwsRUFBRSxDQUFDLGdEQUFnRCxFQUFFLE1BQU07UUFDekRDLE1BQU0sQ0FBQyxJQUFBQyx5QkFBZ0IsRUFBQ0UsU0FBUyxFQUFFQSxTQUFTLEVBQUUsQ0FBQztVQUFDRSxJQUFJLEVBQUUsVUFBVTtVQUFFQyxPQUFPLEVBQUU7UUFBc0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDRixPQUFPLENBQUMsc0JBQXNCLENBQUM7TUFDdkksQ0FBQyxDQUFDO01BQ0ZMLEVBQUUsQ0FBQyx3REFBd0QsRUFBRSxNQUFNO1FBQ2pFQyxNQUFNLENBQUMsSUFBQUMseUJBQWdCLEVBQUNFLFNBQVMsRUFBRUEsU0FBUyxFQUFFLENBQUM7VUFBQ0UsSUFBSSxFQUFFLGNBQWM7VUFBRUMsT0FBTyxFQUFFO1FBQXVCLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQ0YsT0FBTyxDQUFDLG1CQUFtQixDQUFDO01BQ3pJLENBQUMsQ0FBQztJQUVKLENBQUMsQ0FBQztFQUVKLENBQUMsQ0FBQztBQUVKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* Validates a text area when showCharacterCount property has been set.
|
|
9
|
-
*
|
|
10
|
-
* @param {string} label The label to use in any error message.
|
|
11
|
-
* @param {*} value The value to validate.
|
|
12
|
-
* @param {string} showCharacterCount The flag to enable character count validation.
|
|
13
|
-
* @param {array} customErrors An array of custom errors for the component.
|
|
14
|
-
* @param {boolean} required If the component is required.
|
|
15
|
-
* @param {number} maxLength The maximum allowable number of characters (by default, this is 1000 characters).
|
|
16
|
-
* @returns An error if the value exceeds the maximum allowable number of characters.
|
|
17
|
-
*/
|
|
18
|
-
const validateTextArea = function (label, value, showCharacterCount, customErrors, required) {
|
|
19
|
-
let maxLength = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 1000;
|
|
20
|
-
if (!showCharacterCount || !required && !value) {
|
|
21
|
-
return undefined;
|
|
22
|
-
}
|
|
23
|
-
const hasError = required && !value || value.length > maxLength;
|
|
24
|
-
if (hasError) {
|
|
25
|
-
if (Array.isArray(customErrors)) {
|
|
26
|
-
const result = customErrors.filter(error => error.type === 'length');
|
|
27
|
-
if (result && result.length > 0 && result[0].message) {
|
|
28
|
-
return result[0].message;
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
return "".concat(label, " must be ").concat(maxLength, " characters or less");
|
|
32
|
-
}
|
|
33
|
-
return undefined;
|
|
34
|
-
};
|
|
35
|
-
var _default = exports.default = validateTextArea;
|
|
36
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ2YWxpZGF0ZVRleHRBcmVhIiwibGFiZWwiLCJ2YWx1ZSIsInNob3dDaGFyYWN0ZXJDb3VudCIsImN1c3RvbUVycm9ycyIsInJlcXVpcmVkIiwibWF4TGVuZ3RoIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwidW5kZWZpbmVkIiwiaGFzRXJyb3IiLCJBcnJheSIsImlzQXJyYXkiLCJyZXN1bHQiLCJmaWx0ZXIiLCJlcnJvciIsInR5cGUiLCJtZXNzYWdlIiwiY29uY2F0IiwiX2RlZmF1bHQiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS92YWxpZGF0ZVRleHRBcmVhLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVmFsaWRhdGVzIGEgdGV4dCBhcmVhIHdoZW4gc2hvd0NoYXJhY3RlckNvdW50IHByb3BlcnR5IGhhcyBiZWVuIHNldC5cbiAqIFxuICogQHBhcmFtIHtzdHJpbmd9IGxhYmVsIFRoZSBsYWJlbCB0byB1c2UgaW4gYW55IGVycm9yIG1lc3NhZ2UuXG4gKiBAcGFyYW0geyp9IHZhbHVlIFRoZSB2YWx1ZSB0byB2YWxpZGF0ZS5cbiAqIEBwYXJhbSB7c3RyaW5nfSBzaG93Q2hhcmFjdGVyQ291bnQgVGhlIGZsYWcgdG8gZW5hYmxlIGNoYXJhY3RlciBjb3VudCB2YWxpZGF0aW9uLlxuICogQHBhcmFtIHthcnJheX0gY3VzdG9tRXJyb3JzIEFuIGFycmF5IG9mIGN1c3RvbSBlcnJvcnMgZm9yIHRoZSBjb21wb25lbnQuXG4gKiBAcGFyYW0ge2Jvb2xlYW59IHJlcXVpcmVkIElmIHRoZSBjb21wb25lbnQgaXMgcmVxdWlyZWQuXG4gKiBAcGFyYW0ge251bWJlcn0gbWF4TGVuZ3RoIFRoZSBtYXhpbXVtIGFsbG93YWJsZSBudW1iZXIgb2YgY2hhcmFjdGVycyAoYnkgZGVmYXVsdCwgdGhpcyBpcyAxMDAwIGNoYXJhY3RlcnMpLlxuICogQHJldHVybnMgQW4gZXJyb3IgaWYgdGhlIHZhbHVlIGV4Y2VlZHMgdGhlIG1heGltdW0gYWxsb3dhYmxlIG51bWJlciBvZiBjaGFyYWN0ZXJzLlxuICovXG5jb25zdCB2YWxpZGF0ZVRleHRBcmVhID0gKGxhYmVsLCB2YWx1ZSwgc2hvd0NoYXJhY3RlckNvdW50LCBjdXN0b21FcnJvcnMsIHJlcXVpcmVkLCBtYXhMZW5ndGggPSAxMDAwKSA9PiB7XG4gIGlmICghc2hvd0NoYXJhY3RlckNvdW50IHx8ICghcmVxdWlyZWQgJiYgIXZhbHVlKSkge1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBjb25zdCBoYXNFcnJvciA9IHJlcXVpcmVkICYmICF2YWx1ZSB8fCB2YWx1ZS5sZW5ndGggPiBtYXhMZW5ndGg7XG4gIGlmIChoYXNFcnJvcikge1xuICAgIGlmIChBcnJheS5pc0FycmF5KGN1c3RvbUVycm9ycykpIHtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IGN1c3RvbUVycm9ycy5maWx0ZXIoKGVycm9yKSA9PiBlcnJvci50eXBlID09PSAnbGVuZ3RoJyk7XG4gICAgICBpZiAocmVzdWx0ICYmIHJlc3VsdC5sZW5ndGggPiAwICYmIHJlc3VsdFswXS5tZXNzYWdlKSB7XG4gICAgICAgIHJldHVybiByZXN1bHRbMF0ubWVzc2FnZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGAke2xhYmVsfSBtdXN0IGJlICR7bWF4TGVuZ3RofSBjaGFyYWN0ZXJzIG9yIGxlc3NgO1xuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZDtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IHZhbGlkYXRlVGV4dEFyZWE7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNQSxnQkFBZ0IsR0FBRyxTQUFBQSxDQUFDQyxLQUFLLEVBQUVDLEtBQUssRUFBRUMsa0JBQWtCLEVBQUVDLFlBQVksRUFBRUMsUUFBUSxFQUF1QjtFQUFBLElBQXJCQyxTQUFTLEdBQUFDLFNBQUEsQ0FBQUMsTUFBQSxRQUFBRCxTQUFBLFFBQUFFLFNBQUEsR0FBQUYsU0FBQSxNQUFHLElBQUk7RUFDbEcsSUFBSSxDQUFDSixrQkFBa0IsSUFBSyxDQUFDRSxRQUFRLElBQUksQ0FBQ0gsS0FBTSxFQUFFO0lBQ2hELE9BQU9PLFNBQVM7RUFDbEI7RUFFQSxNQUFNQyxRQUFRLEdBQUdMLFFBQVEsSUFBSSxDQUFDSCxLQUFLLElBQUlBLEtBQUssQ0FBQ00sTUFBTSxHQUFHRixTQUFTO0VBQy9ELElBQUlJLFFBQVEsRUFBRTtJQUNaLElBQUlDLEtBQUssQ0FBQ0MsT0FBTyxDQUFDUixZQUFZLENBQUMsRUFBRTtNQUMvQixNQUFNUyxNQUFNLEdBQUdULFlBQVksQ0FBQ1UsTUFBTSxDQUFFQyxLQUFLLElBQUtBLEtBQUssQ0FBQ0MsSUFBSSxLQUFLLFFBQVEsQ0FBQztNQUN0RSxJQUFJSCxNQUFNLElBQUlBLE1BQU0sQ0FBQ0wsTUFBTSxHQUFHLENBQUMsSUFBSUssTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDSSxPQUFPLEVBQUU7UUFDcEQsT0FBT0osTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDSSxPQUFPO01BQzFCO0lBQ0Y7SUFDQSxVQUFBQyxNQUFBLENBQVVqQixLQUFLLGVBQUFpQixNQUFBLENBQVlaLFNBQVM7RUFDdEM7RUFFQSxPQUFPRyxTQUFTO0FBQ2xCLENBQUM7QUFBQyxJQUFBVSxRQUFBLEdBQUFDLE9BQUEsQ0FBQUMsT0FBQSxHQUVhckIsZ0JBQWdCIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _validateTextArea = _interopRequireDefault(require("./validateTextArea"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('utils', () => {
|
|
6
|
-
describe('Validate', () => {
|
|
7
|
-
describe('TextArea', () => {
|
|
8
|
-
const MAX_LENGTH = 10;
|
|
9
|
-
const LABEL = 'This is a custom label';
|
|
10
|
-
const CUSTOM_ERROR = "The value must be ".concat(MAX_LENGTH, " characters or less");
|
|
11
|
-
const ERROR_MSG = "".concat(LABEL, " must be ").concat(MAX_LENGTH, " characters or less");
|
|
12
|
-
const CUSTOM_ERRORS = [{
|
|
13
|
-
type: 'length',
|
|
14
|
-
message: CUSTOM_ERROR
|
|
15
|
-
}];
|
|
16
|
-
it('should return no error when the character count flag is disabled', () => {
|
|
17
|
-
const VALUE = 'ALPHA BRAVO';
|
|
18
|
-
expect((0, _validateTextArea.default)(LABEL, VALUE, false, CUSTOM_ERRORS, true, MAX_LENGTH)).toBeUndefined();
|
|
19
|
-
});
|
|
20
|
-
it('should return no error when value length has not exceeded the maximum allowable character length', () => {
|
|
21
|
-
const VALUE = 'ALPHA BRA';
|
|
22
|
-
expect((0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, true, MAX_LENGTH)).toBeUndefined();
|
|
23
|
-
});
|
|
24
|
-
it('should return no error when value length has not exceeded the default maximum allowable character length', () => {
|
|
25
|
-
const VALUE = 'ALPHA BRAVO';
|
|
26
|
-
expect((0, _validateTextArea.default)(LABEL, VALUE, true, undefined, true)).toBeUndefined();
|
|
27
|
-
});
|
|
28
|
-
it('should return an error when value length has exceeded the maximum allowable character length', () => {
|
|
29
|
-
const VALUE = 'ALPHA BRAVO';
|
|
30
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, undefined, true, MAX_LENGTH);
|
|
31
|
-
expect(error).toBeDefined();
|
|
32
|
-
expect(error).toEqual(ERROR_MSG);
|
|
33
|
-
});
|
|
34
|
-
it('should return a custom error when one is provided', () => {
|
|
35
|
-
const VALUE = 'ALPHA BRAVO CHARLIE';
|
|
36
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, true, MAX_LENGTH);
|
|
37
|
-
expect(error).toBeDefined();
|
|
38
|
-
expect(error).toEqual(CUSTOM_ERROR);
|
|
39
|
-
});
|
|
40
|
-
it('Should return a custom error when one is provided and the value is undefined', () => {
|
|
41
|
-
const VALUE = undefined;
|
|
42
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, true, MAX_LENGTH);
|
|
43
|
-
expect(error).toBeDefined();
|
|
44
|
-
expect(error).toEqual(CUSTOM_ERROR);
|
|
45
|
-
});
|
|
46
|
-
it('Should return undefined when the component is not required and value is undefined', () => {
|
|
47
|
-
const VALUE = undefined;
|
|
48
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, false, MAX_LENGTH);
|
|
49
|
-
expect(error).toBeUndefined();
|
|
50
|
-
});
|
|
51
|
-
it('Should return undefined when component required is undefined and value is undefined', () => {
|
|
52
|
-
const VALUE = undefined;
|
|
53
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, undefined, MAX_LENGTH);
|
|
54
|
-
expect(error).toBeUndefined();
|
|
55
|
-
});
|
|
56
|
-
it('Should return error when component required is false and value is over max length', () => {
|
|
57
|
-
const VALUE = 'ALPHA BRAVO CHARLIE';
|
|
58
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, false, MAX_LENGTH);
|
|
59
|
-
expect(error).toBeDefined();
|
|
60
|
-
expect(error).toEqual(CUSTOM_ERROR);
|
|
61
|
-
});
|
|
62
|
-
it('Should return error when component is required and value is undefined', () => {
|
|
63
|
-
const VALUE = undefined;
|
|
64
|
-
const error = (0, _validateTextArea.default)(LABEL, VALUE, true, CUSTOM_ERRORS, true, MAX_LENGTH);
|
|
65
|
-
expect(error).toBeDefined();
|
|
66
|
-
expect(error).toEqual(CUSTOM_ERROR);
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
});
|
|
70
|
-
});
|
|
71
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdmFsaWRhdGVUZXh0QXJlYSIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJNQVhfTEVOR1RIIiwiTEFCRUwiLCJDVVNUT01fRVJST1IiLCJjb25jYXQiLCJFUlJPUl9NU0ciLCJDVVNUT01fRVJST1JTIiwidHlwZSIsIm1lc3NhZ2UiLCJpdCIsIlZBTFVFIiwiZXhwZWN0IiwidmFsaWRhdGVUZXh0QXJlYSIsInRvQmVVbmRlZmluZWQiLCJ1bmRlZmluZWQiLCJlcnJvciIsInRvQmVEZWZpbmVkIiwidG9FcXVhbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS92YWxpZGF0ZVRleHRBcmVhLnRlc3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHZhbGlkYXRlVGV4dEFyZWEgZnJvbSAnLi92YWxpZGF0ZVRleHRBcmVhJztcblxuZGVzY3JpYmUoJ3V0aWxzJywgKCkgPT4ge1xuICBkZXNjcmliZSgnVmFsaWRhdGUnLCAoKSA9PiB7XG4gICAgZGVzY3JpYmUoJ1RleHRBcmVhJywgKCkgPT4ge1xuICAgICAgY29uc3QgTUFYX0xFTkdUSCA9IDEwO1xuICAgICAgY29uc3QgTEFCRUwgPSAnVGhpcyBpcyBhIGN1c3RvbSBsYWJlbCc7XG4gICAgICBjb25zdCBDVVNUT01fRVJST1IgPSBgVGhlIHZhbHVlIG11c3QgYmUgJHtNQVhfTEVOR1RIfSBjaGFyYWN0ZXJzIG9yIGxlc3NgO1xuICAgICAgY29uc3QgRVJST1JfTVNHID0gYCR7TEFCRUx9IG11c3QgYmUgJHtNQVhfTEVOR1RIfSBjaGFyYWN0ZXJzIG9yIGxlc3NgO1xuICAgICAgY29uc3QgQ1VTVE9NX0VSUk9SUyA9IFt7XG4gICAgICAgIHR5cGU6ICdsZW5ndGgnLFxuICAgICAgICBtZXNzYWdlOiBDVVNUT01fRVJST1IsXG4gICAgICB9XTtcblxuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB0aGUgY2hhcmFjdGVyIGNvdW50IGZsYWcgaXMgZGlzYWJsZWQnLCAoKSA9PiB7XG4gICAgICAgIGNvbnN0IFZBTFVFID0gJ0FMUEhBIEJSQVZPJztcbiAgICAgICAgZXhwZWN0KHZhbGlkYXRlVGV4dEFyZWEoTEFCRUwsIFZBTFVFLCBmYWxzZSwgQ1VTVE9NX0VSUk9SUywgdHJ1ZSwgTUFYX0xFTkdUSCkpLnRvQmVVbmRlZmluZWQoKTtcbiAgICAgIH0pO1xuXG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBubyBlcnJvciB3aGVuIHZhbHVlIGxlbmd0aCBoYXMgbm90IGV4Y2VlZGVkIHRoZSBtYXhpbXVtIGFsbG93YWJsZSBjaGFyYWN0ZXIgbGVuZ3RoJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBWQUxVRSA9ICdBTFBIQSBCUkEnO1xuICAgICAgICBleHBlY3QodmFsaWRhdGVUZXh0QXJlYShMQUJFTCwgVkFMVUUsIHRydWUsIENVU1RPTV9FUlJPUlMsIHRydWUsIE1BWF9MRU5HVEgpKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcblxuICAgICAgaXQoJ3Nob3VsZCByZXR1cm4gbm8gZXJyb3Igd2hlbiB2YWx1ZSBsZW5ndGggaGFzIG5vdCBleGNlZWRlZCB0aGUgZGVmYXVsdCBtYXhpbXVtIGFsbG93YWJsZSBjaGFyYWN0ZXIgbGVuZ3RoJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBWQUxVRSA9ICdBTFBIQSBCUkFWTyc7XG4gICAgICAgIGV4cGVjdCh2YWxpZGF0ZVRleHRBcmVhKExBQkVMLCBWQUxVRSwgdHJ1ZSwgdW5kZWZpbmVkLCB0cnVlKSkudG9CZVVuZGVmaW5lZCgpO1xuICAgICAgfSk7XG5cbiAgICAgIGl0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIHdoZW4gdmFsdWUgbGVuZ3RoIGhhcyBleGNlZWRlZCB0aGUgbWF4aW11bSBhbGxvd2FibGUgY2hhcmFjdGVyIGxlbmd0aCcsICgpID0+IHtcbiAgICAgICAgY29uc3QgVkFMVUUgPSAnQUxQSEEgQlJBVk8nO1xuICAgICAgICBjb25zdCBlcnJvciA9IHZhbGlkYXRlVGV4dEFyZWEoTEFCRUwsIFZBTFVFLCB0cnVlLCB1bmRlZmluZWQsIHRydWUsICBNQVhfTEVOR1RIKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0JlRGVmaW5lZCgpO1xuICAgICAgICBleHBlY3QoZXJyb3IpLnRvRXF1YWwoRVJST1JfTVNHKTtcbiAgICAgIH0pO1xuXG4gICAgICBpdCgnc2hvdWxkIHJldHVybiBhIGN1c3RvbSBlcnJvciB3aGVuIG9uZSBpcyBwcm92aWRlZCcsICgpID0+IHtcbiAgICAgICAgY29uc3QgVkFMVUUgPSAnQUxQSEEgQlJBVk8gQ0hBUkxJRSc7XG4gICAgICAgIGNvbnN0IGVycm9yID0gdmFsaWRhdGVUZXh0QXJlYShMQUJFTCwgVkFMVUUsIHRydWUsIENVU1RPTV9FUlJPUlMsIHRydWUsIE1BWF9MRU5HVEgpO1xuICAgICAgICBleHBlY3QoZXJyb3IpLnRvQmVEZWZpbmVkKCk7XG4gICAgICAgIGV4cGVjdChlcnJvcikudG9FcXVhbChDVVNUT01fRVJST1IpO1xuICAgICAgfSk7XG5cbiAgICAgIGl0KCdTaG91bGQgcmV0dXJuIGEgY3VzdG9tIGVycm9yIHdoZW4gb25lIGlzIHByb3ZpZGVkIGFuZCB0aGUgdmFsdWUgaXMgdW5kZWZpbmVkJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBWQUxVRSA9IHVuZGVmaW5lZDtcbiAgICAgICAgY29uc3QgZXJyb3IgPSB2YWxpZGF0ZVRleHRBcmVhKExBQkVMLCBWQUxVRSwgdHJ1ZSwgQ1VTVE9NX0VSUk9SUywgdHJ1ZSwgTUFYX0xFTkdUSCk7XG4gICAgICAgIGV4cGVjdChlcnJvcikudG9CZURlZmluZWQoKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0VxdWFsKENVU1RPTV9FUlJPUik7XG4gICAgICB9KTtcblxuICAgICAgaXQoJ1Nob3VsZCByZXR1cm4gdW5kZWZpbmVkIHdoZW4gdGhlIGNvbXBvbmVudCBpcyBub3QgcmVxdWlyZWQgYW5kIHZhbHVlIGlzIHVuZGVmaW5lZCcsICgpID0+IHtcbiAgICAgICAgY29uc3QgVkFMVUUgPSB1bmRlZmluZWQ7XG4gICAgICAgIGNvbnN0IGVycm9yID0gdmFsaWRhdGVUZXh0QXJlYShMQUJFTCwgVkFMVUUsIHRydWUsIENVU1RPTV9FUlJPUlMsIGZhbHNlLCBNQVhfTEVOR1RIKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcblxuICAgICAgaXQoJ1Nob3VsZCByZXR1cm4gdW5kZWZpbmVkIHdoZW4gY29tcG9uZW50IHJlcXVpcmVkIGlzIHVuZGVmaW5lZCBhbmQgdmFsdWUgaXMgdW5kZWZpbmVkJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBWQUxVRSA9IHVuZGVmaW5lZDtcbiAgICAgICAgY29uc3QgZXJyb3IgPSB2YWxpZGF0ZVRleHRBcmVhKExBQkVMLCBWQUxVRSwgdHJ1ZSwgQ1VTVE9NX0VSUk9SUywgdW5kZWZpbmVkLCBNQVhfTEVOR1RIKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0JlVW5kZWZpbmVkKCk7XG4gICAgICB9KTtcblxuICAgICAgaXQoJ1Nob3VsZCByZXR1cm4gZXJyb3Igd2hlbiBjb21wb25lbnQgcmVxdWlyZWQgaXMgZmFsc2UgYW5kIHZhbHVlIGlzIG92ZXIgbWF4IGxlbmd0aCcsICgpID0+IHtcbiAgICAgICAgY29uc3QgVkFMVUUgPSAnQUxQSEEgQlJBVk8gQ0hBUkxJRSc7XG4gICAgICAgIGNvbnN0IGVycm9yID0gdmFsaWRhdGVUZXh0QXJlYShMQUJFTCwgVkFMVUUsIHRydWUsIENVU1RPTV9FUlJPUlMsIGZhbHNlLCBNQVhfTEVOR1RIKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0JlRGVmaW5lZCgpO1xuICAgICAgICBleHBlY3QoZXJyb3IpLnRvRXF1YWwoQ1VTVE9NX0VSUk9SKTtcbiAgICAgIH0pO1xuXG4gICAgICBpdCgnU2hvdWxkIHJldHVybiBlcnJvciB3aGVuIGNvbXBvbmVudCBpcyByZXF1aXJlZCBhbmQgdmFsdWUgaXMgdW5kZWZpbmVkJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBWQUxVRSA9IHVuZGVmaW5lZDtcbiAgICAgICAgY29uc3QgZXJyb3IgPSB2YWxpZGF0ZVRleHRBcmVhKExBQkVMLCBWQUxVRSwgdHJ1ZSwgQ1VTVE9NX0VSUk9SUywgdHJ1ZSwgTUFYX0xFTkdUSCk7XG4gICAgICAgIGV4cGVjdChlcnJvcikudG9CZURlZmluZWQoKTtcbiAgICAgICAgZXhwZWN0KGVycm9yKS50b0VxdWFsKENVU1RPTV9FUlJPUik7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxpQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQWtELFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRWxERyxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU07RUFDdEJBLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTTtJQUN6QkEsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNO01BQ3pCLE1BQU1DLFVBQVUsR0FBRyxFQUFFO01BQ3JCLE1BQU1DLEtBQUssR0FBRyx3QkFBd0I7TUFDdEMsTUFBTUMsWUFBWSx3QkFBQUMsTUFBQSxDQUF3QkgsVUFBVSx3QkFBcUI7TUFDekUsTUFBTUksU0FBUyxNQUFBRCxNQUFBLENBQU1GLEtBQUssZUFBQUUsTUFBQSxDQUFZSCxVQUFVLHdCQUFxQjtNQUNyRSxNQUFNSyxhQUFhLEdBQUcsQ0FBQztRQUNyQkMsSUFBSSxFQUFFLFFBQVE7UUFDZEMsT0FBTyxFQUFFTDtNQUNYLENBQUMsQ0FBQztNQUVGTSxFQUFFLENBQUMsa0VBQWtFLEVBQUUsTUFBTTtRQUMzRSxNQUFNQyxLQUFLLEdBQUcsYUFBYTtRQUMzQkMsTUFBTSxDQUFDLElBQUFDLHlCQUFnQixFQUFDVixLQUFLLEVBQUVRLEtBQUssRUFBRSxLQUFLLEVBQUVK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
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _utils = require("./additional/utils");
|
|
8
|
-
// Local imports
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Checks if a time passed is a valid time.
|
|
12
|
-
* This will validate for missing components, invalid hour or minute components.
|
|
13
|
-
* EXAMPLE USE : const { message, propsInError } = validateTime('15:30')
|
|
14
|
-
*
|
|
15
|
-
* Note that an empty string is not considered invalid. You should use
|
|
16
|
-
* validateRequired (Validate.required) for that sort of validation.
|
|
17
|
-
*
|
|
18
|
-
* @param {string} time time as a string
|
|
19
|
-
* @returns an object with an error message and instructions for which parts of the time are in error
|
|
20
|
-
* or undefined for both if the time is valid
|
|
21
|
-
*/
|
|
22
|
-
const validateTime = time => {
|
|
23
|
-
if (!time) {
|
|
24
|
-
return {
|
|
25
|
-
message: undefined,
|
|
26
|
-
propsInError: undefined
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
const formattedDate = (0, _utils.formattedTime)(time);
|
|
30
|
-
const [hour, minute] = formattedDate.split(':');
|
|
31
|
-
const intHour = parseInt(hour, 10);
|
|
32
|
-
const intMinute = parseInt(minute, 10);
|
|
33
|
-
const badProps = [];
|
|
34
|
-
const messages = [];
|
|
35
|
-
const numericRegex = /^\d{0,2}:\d{0,2}$/;
|
|
36
|
-
if (!numericRegex.test(time)) {
|
|
37
|
-
badProps.push('invalid');
|
|
38
|
-
messages.push('Enter a valid time');
|
|
39
|
-
}
|
|
40
|
-
if (hour.length === 0) {
|
|
41
|
-
badProps.push('hour');
|
|
42
|
-
messages.push('Time must include a hour');
|
|
43
|
-
} else if (intHour > 23 || intHour < 0) {
|
|
44
|
-
badProps.push('hour');
|
|
45
|
-
messages.push('Hour must be between 0 and 23');
|
|
46
|
-
}
|
|
47
|
-
if (minute.length === 0) {
|
|
48
|
-
badProps.push('minute');
|
|
49
|
-
messages.push('Time must include a minute');
|
|
50
|
-
} else if (intMinute > 59 || intMinute < 0) {
|
|
51
|
-
badProps.push('minute');
|
|
52
|
-
messages.push('Minute must be between 0 and 59');
|
|
53
|
-
}
|
|
54
|
-
if (badProps.length > 0) {
|
|
55
|
-
const propsInError = {};
|
|
56
|
-
if (badProps.includes('hour')) {
|
|
57
|
-
propsInError.hour = true;
|
|
58
|
-
}
|
|
59
|
-
if (badProps.includes('minute')) {
|
|
60
|
-
propsInError.minute = true;
|
|
61
|
-
}
|
|
62
|
-
if (badProps.includes('invalid')) {
|
|
63
|
-
propsInError.invalid = true;
|
|
64
|
-
}
|
|
65
|
-
return {
|
|
66
|
-
message: badProps.length > 1 ? 'Enter a valid time' : messages[0],
|
|
67
|
-
propsInError
|
|
68
|
-
};
|
|
69
|
-
}
|
|
70
|
-
return {
|
|
71
|
-
message: undefined,
|
|
72
|
-
propsInError: undefined
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
var _default = exports.default = validateTime;
|
|
76
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdXRpbHMiLCJyZXF1aXJlIiwidmFsaWRhdGVUaW1lIiwidGltZSIsIm1lc3NhZ2UiLCJ1bmRlZmluZWQiLCJwcm9wc0luRXJyb3IiLCJmb3JtYXR0ZWREYXRlIiwiZm9ybWF0dGVkVGltZSIsImhvdXIiLCJtaW51dGUiLCJzcGxpdCIsImludEhvdXIiLCJwYXJzZUludCIsImludE1pbnV0ZSIsImJhZFByb3BzIiwibWVzc2FnZXMiLCJudW1lcmljUmVnZXgiLCJ0ZXN0IiwicHVzaCIsImxlbmd0aCIsImluY2x1ZGVzIiwiaW52YWxpZCIsIl9kZWZhdWx0IiwiZXhwb3J0cyIsImRlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvdmFsaWRhdGVUaW1lLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8vIExvY2FsIGltcG9ydHNcbmltcG9ydCB7IGZvcm1hdHRlZFRpbWUgfSBmcm9tICcuL2FkZGl0aW9uYWwvdXRpbHMnO1xuXG4vKipcbiAqIENoZWNrcyBpZiBhIHRpbWUgcGFzc2VkIGlzIGEgdmFsaWQgdGltZS5cbiAqIFRoaXMgd2lsbCB2YWxpZGF0ZSBmb3IgbWlzc2luZyBjb21wb25lbnRzLCBpbnZhbGlkIGhvdXIgb3IgbWludXRlIGNvbXBvbmVudHMuXG4gKiBFWEFNUExFIFVTRSA6IGNvbnN0IHsgbWVzc2FnZSwgcHJvcHNJbkVycm9yIH0gPSB2YWxpZGF0ZVRpbWUoJzE1OjMwJylcbiAqIFxuICogTm90ZSB0aGF0IGFuIGVtcHR5IHN0cmluZyBpcyBub3QgY29uc2lkZXJlZCBpbnZhbGlkLiBZb3Ugc2hvdWxkIHVzZVxuICogdmFsaWRhdGVSZXF1aXJlZCAoVmFsaWRhdGUucmVxdWlyZWQpIGZvciB0aGF0IHNvcnQgb2YgdmFsaWRhdGlvbi5cbiAqIFxuICogQHBhcmFtIHtzdHJpbmd9IHRpbWUgdGltZSBhcyBhIHN0cmluZ1xuICogQHJldHVybnMgYW4gb2JqZWN0IHdpdGggYW4gZXJyb3IgbWVzc2FnZSBhbmQgaW5zdHJ1Y3Rpb25zIGZvciB3aGljaCBwYXJ0cyBvZiB0aGUgdGltZSBhcmUgaW4gZXJyb3JcbiAqIG9yIHVuZGVmaW5lZCBmb3IgYm90aCBpZiB0aGUgdGltZSBpcyB2YWxpZFxuICovXG5jb25zdCB2YWxpZGF0ZVRpbWUgPSAodGltZSkgPT4ge1xuICBpZiAoIXRpbWUpIHtcbiAgICByZXR1cm4geyBtZXNzYWdlOiB1bmRlZmluZWQsIHByb3BzSW5FcnJvcjogdW5kZWZpbmVkIH07XG4gIH1cblxuICBjb25zdCBmb3JtYXR0ZWREYXRlID0gZm9ybWF0dGVkVGltZSh0aW1lKTtcbiAgY29uc3QgW2hvdXIsIG1pbnV0ZV0gPSBmb3JtYXR0ZWREYXRlLnNwbGl0KCc6Jyk7XG4gIGNvbnN0IGludEhvdXIgPSBwYXJzZUludChob3VyLCAxMCk7XG4gIGNvbnN0IGludE1pbnV0ZSA9IHBhcnNlSW50KG1pbnV0ZSwgMTApO1xuXG4gIGNvbnN0IGJhZFByb3BzID0gW107XG4gIGNvbnN0IG1lc3NhZ2VzID0gW107XG4gIGNvbnN0IG51bWVyaWNSZWdleCA9IC9eXFxkezAsMn06XFxkezAsMn0kLztcblxuICBpZiAoIW51bWVyaWNSZWdleC50ZXN0KHRpbWUpKSB7XG4gICAgYmFkUHJvcHMucHVzaCgnaW52YWxpZCcpO1xuICAgIG1lc3NhZ2VzLnB1c2goJ0VudGVyIGEgdmFsaWQgdGltZScpO1xuICB9XG5cbiAgaWYgKGhvdXIubGVuZ3RoID09PSAwKSB7XG4gICAgYmFkUHJvcHMucHVzaCggJ2hvdXInKTtcbiAgICBtZXNzYWdlcy5wdXNoKCAnVGltZSBtdXN0IGluY2x1ZGUgYSBob3VyJyk7XG4gIH0gZWxzZSBpZiAoaW50SG91ciA+IDIzIHx8IGludEhvdXIgPCAwKSB7XG4gICAgYmFkUHJvcHMucHVzaCggJ2hvdXInKVxuICAgIG1lc3NhZ2VzLnB1c2goICdIb3VyIG11c3QgYmUgYmV0d2VlbiAwIGFuZCAyMycpO1xuICB9XG5cbiAgaWYgKG1pbnV0ZS5sZW5ndGggPT09IDApIHtcbiAgICBiYWRQcm9wcy5wdXNoKCAnbWludXRlJyk7XG4gICAgbWVzc2FnZXMucHVzaCggICdUaW1lIG11c3QgaW5jbHVkZSBhIG1pbnV0ZScpO1xuICB9IGVsc2UgaWYgKGludE1pbnV0ZSA+IDU5IHx8IGludE1pbnV0ZSA8IDApIHtcbiAgICBiYWRQcm9wcy5wdXNoKCAnbWludXRlJyk7XG4gICAgbWVzc2FnZXMucHVzaCggJ01pbnV0ZSBtdXN0IGJlIGJldHdlZW4gMCBhbmQgNTknKTtcbiAgfVxuXG4gIGlmIChiYWRQcm9wcy5sZW5ndGggPiAwKSB7XG4gICAgY29uc3QgcHJvcHNJbkVycm9yID0ge307XG4gICAgaWYgKGJhZFByb3BzLmluY2x1ZGVzKCdob3VyJykpIHtcbiAgICAgIHByb3BzSW5FcnJvci5ob3VyID0gdHJ1ZTtcbiAgICB9XG4gICAgaWYgKGJhZFByb3BzLmluY2x1ZGVzKCdtaW51dGUnKSkge1xuICAgICAgcHJvcHNJbkVycm9yLm1pbnV0ZSA9IHRydWU7XG4gICAgfVxuICAgIGlmIChiYWRQcm9wcy5pbmNsdWRlcygnaW52YWxpZCcpKSB7XG4gICAgICBwcm9wc0luRXJyb3IuaW52YWxpZCA9IHRydWU7XG4gICAgfVxuICAgIHJldHVybiB7XG4gICAgICBtZXNzYWdlOiAoYmFkUHJvcHMubGVuZ3RoID4gMSkgPyAnRW50ZXIgYSB2YWxpZCB0aW1lJyA6IG1lc3NhZ2VzWzBdLFxuICAgICAgcHJvcHNJbkVycm9yXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHsgbWVzc2FnZTogdW5kZWZpbmVkLCBwcm9wc0luRXJyb3I6IHVuZGVmaW5lZCB9O1xufTtcblxuZXhwb3J0IGRlZmF1bHQgdmFsaWRhdGVUaW1lO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFDQSxJQUFBQSxNQUFBLEdBQUFDLE9BQUE7QUFEQTs7QUFHQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNQyxZQUFZLEdBQUlDLElBQUksSUFBSztFQUM3QixJQUFJLENBQUNB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
|
|
@@ -1,116 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _validateTime = _interopRequireDefault(require("./validateTime"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('utils', () => {
|
|
6
|
-
describe('Validate', () => {
|
|
7
|
-
describe('time', () => {
|
|
8
|
-
test('should return no error when the value is an empty string', () => {
|
|
9
|
-
expect((0, _validateTime.default)('')).toEqual({
|
|
10
|
-
message: undefined,
|
|
11
|
-
propsInError: undefined
|
|
12
|
-
});
|
|
13
|
-
});
|
|
14
|
-
test('should return undefined if a time string is valid', () => {
|
|
15
|
-
const output = (0, _validateTime.default)('14:30');
|
|
16
|
-
expect(output).toEqual({
|
|
17
|
-
message: undefined,
|
|
18
|
-
propsInError: undefined
|
|
19
|
-
});
|
|
20
|
-
});
|
|
21
|
-
test('should return an error if no hour is given', () => {
|
|
22
|
-
const output = (0, _validateTime.default)(':30');
|
|
23
|
-
expect(output).toEqual({
|
|
24
|
-
message: 'Time must include a hour',
|
|
25
|
-
propsInError: {
|
|
26
|
-
hour: true
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
test('should return an error if the hour is not between 0 and 23', () => {
|
|
31
|
-
const output = (0, _validateTime.default)('35:30');
|
|
32
|
-
expect(output).toEqual({
|
|
33
|
-
message: 'Hour must be between 0 and 23',
|
|
34
|
-
propsInError: {
|
|
35
|
-
hour: true
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
});
|
|
39
|
-
test('should return an error if no minute is given', () => {
|
|
40
|
-
const output = (0, _validateTime.default)('14:');
|
|
41
|
-
expect(output).toEqual({
|
|
42
|
-
message: 'Time must include a minute',
|
|
43
|
-
propsInError: {
|
|
44
|
-
minute: true
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
test('should return an error if the minute is not between 0 and 59', () => {
|
|
49
|
-
const output = (0, _validateTime.default)('14:75');
|
|
50
|
-
expect(output).toEqual({
|
|
51
|
-
message: 'Minute must be between 0 and 59',
|
|
52
|
-
propsInError: {
|
|
53
|
-
minute: true
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
test('should report multiple errors', () => {
|
|
58
|
-
const output = (0, _validateTime.default)('24:75');
|
|
59
|
-
expect(output).toEqual({
|
|
60
|
-
message: 'Enter a valid time',
|
|
61
|
-
propsInError: {
|
|
62
|
-
hour: true,
|
|
63
|
-
minute: true
|
|
64
|
-
}
|
|
65
|
-
});
|
|
66
|
-
});
|
|
67
|
-
test('should return an error if the time string contains non-numeric characters', () => {
|
|
68
|
-
const output = (0, _validateTime.default)('14:3A');
|
|
69
|
-
expect(output).toEqual({
|
|
70
|
-
message: 'Enter a valid time',
|
|
71
|
-
propsInError: {
|
|
72
|
-
invalid: true,
|
|
73
|
-
minute: true
|
|
74
|
-
}
|
|
75
|
-
});
|
|
76
|
-
});
|
|
77
|
-
test('should return an error if the time string contains more than two digits in hour', () => {
|
|
78
|
-
const output = (0, _validateTime.default)('144:30');
|
|
79
|
-
expect(output).toEqual({
|
|
80
|
-
message: 'Enter a valid time',
|
|
81
|
-
propsInError: {
|
|
82
|
-
invalid: true,
|
|
83
|
-
hour: true
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
});
|
|
87
|
-
test('should return an error if the time string contains more than two digits in minute', () => {
|
|
88
|
-
const output = (0, _validateTime.default)('14:309');
|
|
89
|
-
expect(output).toEqual({
|
|
90
|
-
message: 'Enter a valid time',
|
|
91
|
-
propsInError: {
|
|
92
|
-
invalid: true,
|
|
93
|
-
minute: true
|
|
94
|
-
}
|
|
95
|
-
});
|
|
96
|
-
});
|
|
97
|
-
test('should return an error if there is an additional colon in the time string', () => {
|
|
98
|
-
const output = (0, _validateTime.default)('14:30:');
|
|
99
|
-
expect(output).toEqual({
|
|
100
|
-
message: 'Enter a valid time',
|
|
101
|
-
propsInError: {
|
|
102
|
-
invalid: true
|
|
103
|
-
}
|
|
104
|
-
});
|
|
105
|
-
});
|
|
106
|
-
test('should return no error if there is a single digit for both hour and minute', () => {
|
|
107
|
-
const output = (0, _validateTime.default)('1:1');
|
|
108
|
-
expect(output).toEqual({
|
|
109
|
-
message: undefined,
|
|
110
|
-
propsInError: undefined
|
|
111
|
-
});
|
|
112
|
-
});
|
|
113
|
-
});
|
|
114
|
-
});
|
|
115
|
-
});
|
|
116
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfdmFsaWRhdGVUaW1lIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJkZXNjcmliZSIsInRlc3QiLCJleHBlY3QiLCJ2YWxpZGF0ZVRpbWUiLCJ0b0VxdWFsIiwibWVzc2FnZSIsInVuZGVmaW5lZCIsInByb3BzSW5FcnJvciIsIm91dHB1dCIsImhvdXIiLCJtaW51dGUiLCJpbnZhbGlkIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL1ZhbGlkYXRlL3ZhbGlkYXRlVGltZS50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB2YWxpZGF0ZVRpbWUgZnJvbSAnLi92YWxpZGF0ZVRpbWUnO1xuXG5kZXNjcmliZSgndXRpbHMnLCAoKSA9PiB7XG4gIGRlc2NyaWJlKCdWYWxpZGF0ZScsICgpID0+IHtcbiAgICBkZXNjcmliZSgndGltZScsICgpID0+IHtcblxuICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBubyBlcnJvciB3aGVuIHRoZSB2YWx1ZSBpcyBhbiBlbXB0eSBzdHJpbmcnLCAoKSA9PiB7XG4gICAgICAgIGV4cGVjdCh2YWxpZGF0ZVRpbWUoJycpKS50b0VxdWFsKHsgbWVzc2FnZTogdW5kZWZpbmVkLCBwcm9wc0luRXJyb3I6IHVuZGVmaW5lZCB9KTtcbiAgICAgIH0pO1xuXG4gICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHVuZGVmaW5lZCBpZiBhIHRpbWUgc3RyaW5nIGlzIHZhbGlkJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBvdXRwdXQgPSB2YWxpZGF0ZVRpbWUoJzE0OjMwJyk7XG4gICAgICAgIGV4cGVjdChvdXRwdXQpLnRvRXF1YWwoeyBtZXNzYWdlOiB1bmRlZmluZWQsIHByb3BzSW5FcnJvcjogdW5kZWZpbmVkIH0pO1xuICAgICAgfSk7XG5cbiAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gYW4gZXJyb3IgaWYgbm8gaG91ciBpcyBnaXZlbicsICgpID0+IHtcbiAgICAgICAgY29uc3Qgb3V0cHV0ID0gdmFsaWRhdGVUaW1lKCc6MzAnKTtcbiAgICAgICAgZXhwZWN0KG91dHB1dCkudG9FcXVhbCh7IG1lc3NhZ2U6ICdUaW1lIG11c3QgaW5jbHVkZSBhIGhvdXInLCBwcm9wc0luRXJyb3I6IHsgaG91cjogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG4gICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIGlmIHRoZSBob3VyIGlzIG5vdCBiZXR3ZWVuIDAgYW5kIDIzJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBvdXRwdXQgPSB2YWxpZGF0ZVRpbWUoJzM1OjMwJyk7XG4gICAgICAgIGV4cGVjdChvdXRwdXQpLnRvRXF1YWwoeyBtZXNzYWdlOiAnSG91ciBtdXN0IGJlIGJldHdlZW4gMCBhbmQgMjMnLCBwcm9wc0luRXJyb3I6IHsgaG91cjogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG5cbiAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gYW4gZXJyb3IgaWYgbm8gbWludXRlIGlzIGdpdmVuJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBvdXRwdXQgPSB2YWxpZGF0ZVRpbWUoJzE0OicpO1xuICAgICAgICBleHBlY3Qob3V0cHV0KS50b0VxdWFsKHsgbWVzc2FnZTogJ1RpbWUgbXVzdCBpbmNsdWRlIGEgbWludXRlJywgcHJvcHNJbkVycm9yOiB7IG1pbnV0ZTogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG4gICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIGlmIHRoZSBtaW51dGUgaXMgbm90IGJldHdlZW4gMCBhbmQgNTknLCAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IHZhbGlkYXRlVGltZSgnMTQ6NzUnKTtcbiAgICAgICAgZXhwZWN0KG91dHB1dCkudG9FcXVhbCh7IG1lc3NhZ2U6ICdNaW51dGUgbXVzdCBiZSBiZXR3ZWVuIDAgYW5kIDU5JywgcHJvcHNJbkVycm9yOiB7IG1pbnV0ZTogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG5cbiAgICAgIHRlc3QoJ3Nob3VsZCByZXBvcnQgbXVsdGlwbGUgZXJyb3JzJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBvdXRwdXQgPSB2YWxpZGF0ZVRpbWUoJzI0Ojc1Jyk7XG4gICAgICAgIGV4cGVjdChvdXRwdXQpLnRvRXF1YWwoeyBtZXNzYWdlOiAnRW50ZXIgYSB2YWxpZCB0aW1lJywgcHJvcHNJbkVycm9yOiB7IGhvdXI6IHRydWUsIG1pbnV0ZTogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG5cbiAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gYW4gZXJyb3IgaWYgdGhlIHRpbWUgc3RyaW5nIGNvbnRhaW5zIG5vbi1udW1lcmljIGNoYXJhY3RlcnMnLCAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IHZhbGlkYXRlVGltZSgnMTQ6M0EnKTtcbiAgICAgICAgZXhwZWN0KG91dHB1dCkudG9FcXVhbCh7IG1lc3NhZ2U6ICdFbnRlciBhIHZhbGlkIHRpbWUnLCBwcm9wc0luRXJyb3I6IHsgaW52YWxpZDogdHJ1ZSwgbWludXRlOiB0cnVlIH0gfSk7XG4gICAgICB9KTtcblxuICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBhbiBlcnJvciBpZiB0aGUgdGltZSBzdHJpbmcgY29udGFpbnMgbW9yZSB0aGFuIHR3byBkaWdpdHMgaW4gaG91cicsICgpID0+IHtcbiAgICAgICAgY29uc3Qgb3V0cHV0ID0gdmFsaWRhdGVUaW1lKCcxNDQ6MzAnKTtcbiAgICAgICAgZXhwZWN0KG91dHB1dCkudG9FcXVhbCh7IG1lc3NhZ2U6ICdFbnRlciBhIHZhbGlkIHRpbWUnLCBwcm9wc0luRXJyb3I6IHsgaW52YWxpZDogdHJ1ZSwgaG91cjogdHJ1ZSB9IH0pO1xuICAgICAgfSk7XG4gXG4gICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIGlmIHRoZSB0aW1lIHN0cmluZyBjb250YWlucyBtb3JlIHRoYW4gdHdvIGRpZ2l0cyBpbiBtaW51dGUnLCAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IHZhbGlkYXRlVGltZSgnMTQ6MzA5Jyk7XG4gICAgICAgIGV4cGVjdChvdXRwdXQpLnRvRXF1YWwoeyBtZXNzYWdlOiAnRW50ZXIgYSB2YWxpZCB0aW1lJywgcHJvcHNJbkVycm9yOiB7IGludmFsaWQ6IHRydWUsICBtaW51dGU6IHRydWUgfSB9KTtcbiAgICAgIH0pO1xuXG4gICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGFuIGVycm9yIGlmIHRoZXJlIGlzIGFuIGFkZGl0aW9uYWwgY29sb24gaW4gdGhlIHRpbWUgc3RyaW5nJywgKCkgPT4ge1xuICAgICAgICBjb25zdCBvdXRwdXQgPSB2YWxpZGF0ZVRpbWUoJzE0OjMwOicpO1xuICAgICAgICBleHBlY3Qob3V0cHV0KS50b0VxdWFsKHsgbWVzc2FnZTogJ0VudGVyIGEgdmFsaWQgdGltZScsIHByb3BzSW5FcnJvcjogeyBpbnZhbGlkOiB0cnVlIH0gfSk7XG4gICAgICB9KTtcblxuICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBubyBlcnJvciBpZiB0aGVyZSBpcyBhIHNpbmdsZSBkaWdpdCBmb3IgYm90aCBob3VyIGFuZCBtaW51dGUnLCAoKSA9PiB7XG4gICAgICAgIGNvbnN0IG91dHB1dCA9IHZhbGlkYXRlVGltZSgnMToxJyk7XG4gICAgICAgIGV4cGVjdChvdXRwdXQpLnRvRXF1YWwoeyBtZXNzYWdlOiB1bmRlZmluZWQsIHByb3BzSW5FcnJvcjogdW5kZWZpbmVkIH0pO1xuICAgICAgfSk7XG5cbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxhQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFBMEMsU0FBQUQsdUJBQUFFLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFFMUNHLFFBQVEsQ0FBQyxPQUFPLEVBQUUsTUFBTTtFQUN0QkEsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNO0lBQ3pC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
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _Condition = _interopRequireDefault(require("./Condition"));
|
|
8
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
-
/**
|
|
10
|
-
* Check to see if the field required status can be overridden.
|
|
11
|
-
* All conditions need to be met in order for the override to be permitted.
|
|
12
|
-
* @param {array} requiredOverrideConditions The conditions to evaluate.
|
|
13
|
-
* @param {object} data The form data to check.
|
|
14
|
-
* @returns true or false.
|
|
15
|
-
*/
|
|
16
|
-
const canOverrideFieldRequired = (requiredOverrideConditions, data) => {
|
|
17
|
-
if ((requiredOverrideConditions === null || requiredOverrideConditions === void 0 ? void 0 : requiredOverrideConditions.type) === "or") {
|
|
18
|
-
return _Condition.default.meetsOne(requiredOverrideConditions.conditions, data);
|
|
19
|
-
}
|
|
20
|
-
return _Condition.default.meetsAll(requiredOverrideConditions.conditions, data);
|
|
21
|
-
};
|
|
22
|
-
var _default = exports.default = canOverrideFieldRequired;
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfQ29uZGl0aW9uIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjYW5PdmVycmlkZUZpZWxkUmVxdWlyZWQiLCJyZXF1aXJlZE92ZXJyaWRlQ29uZGl0aW9ucyIsImRhdGEiLCJ0eXBlIiwiQ29uZGl0aW9uIiwibWVldHNPbmUiLCJjb25kaXRpb25zIiwibWVldHNBbGwiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvY2FuT3ZlcnJpZGVGaWVsZFJlcXVpcmVkLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBDb25kaXRpb24gZnJvbSAnLi9Db25kaXRpb24nO1xuXG4vKipcbiAqIENoZWNrIHRvIHNlZSBpZiB0aGUgZmllbGQgcmVxdWlyZWQgc3RhdHVzIGNhbiBiZSBvdmVycmlkZGVuLlxuICogQWxsIGNvbmRpdGlvbnMgbmVlZCB0byBiZSBtZXQgaW4gb3JkZXIgZm9yIHRoZSBvdmVycmlkZSB0byBiZSBwZXJtaXR0ZWQuXG4gKiBAcGFyYW0ge2FycmF5fSByZXF1aXJlZE92ZXJyaWRlQ29uZGl0aW9ucyBUaGUgY29uZGl0aW9ucyB0byBldmFsdWF0ZS5cbiAqIEBwYXJhbSB7b2JqZWN0fSBkYXRhIFRoZSBmb3JtIGRhdGEgdG8gY2hlY2suXG4gKiBAcmV0dXJucyB0cnVlIG9yIGZhbHNlLlxuICovXG5jb25zdCBjYW5PdmVycmlkZUZpZWxkUmVxdWlyZWQgPSAocmVxdWlyZWRPdmVycmlkZUNvbmRpdGlvbnMsIGRhdGEpID0+IHtcbiAgICBpZiAocmVxdWlyZWRPdmVycmlkZUNvbmRpdGlvbnM/LnR5cGUgPT09IFwib3JcIikge1xuICAgICAgICByZXR1cm4gQ29uZGl0aW9uLm1lZXRzT25lKHJlcXVpcmVkT3ZlcnJpZGVDb25kaXRpb25zLmNvbmRpdGlvbnMsIGRhdGEpXG4gICAgfVxuICAgIHJldHVybiBDb25kaXRpb24ubWVldHNBbGwocmVxdWlyZWRPdmVycmlkZUNvbmRpdGlvbnMuY29uZGl0aW9ucywgZGF0YSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBjYW5PdmVycmlkZUZpZWxkUmVxdWlyZWQ7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFVBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUFvQyxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUVwQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1HLHdCQUF3QixHQUFHQSxDQUFDQywwQkFBMEIsRUFBRUMsSUFBSSxLQUFLO0VBQ25FLElBQUksQ0FBQUQsMEJBQTBCLGFBQTFCQSwwQkFBMEIsdUJBQTFCQSwwQkFBMEIsQ0FBRUUsSUFBSSxNQUFLLElBQUksRUFBRTtJQUMzQyxPQUFPQyxrQkFBUyxDQUFDQyxRQUFRLENBQUNKLDBCQUEwQixDQUFDSyxVQUFVLEVBQUVKLElBQUksQ0FBQztFQUMxRTtFQUNBLE9BQU9FLGtCQUFTLENBQUNHLFFBQVEsQ0FBQ04sMEJBQTBCLENBQUNLLFVBQVUsRUFBRUosSUFBSSxDQUFDO0FBQzFFLENBQUM7QUFBQyxJQUFBTSxRQUFBLEdBQUFDLE9BQUEsQ0FBQVYsT0FBQSxHQUVhQyx3QkFBd0IiLCJpZ25vcmVMaXN0IjpbXX0=
|