@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,128 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _mustBeEarlierDateTime = _interopRequireDefault(require("./mustBeEarlierDateTime"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
6
|
-
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
7
|
-
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
8
|
-
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
9
|
-
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
10
|
-
describe('utils.Validate.additional.mustBeEarlierDateTime', () => {
|
|
11
|
-
const DATA = {
|
|
12
|
-
testContainer: {
|
|
13
|
-
testDate: '01-01-2000',
|
|
14
|
-
testTime: '00:00'
|
|
15
|
-
}
|
|
16
|
-
};
|
|
17
|
-
const CONFIG = {
|
|
18
|
-
function: 'mustBeEarlierDateTime',
|
|
19
|
-
date: 'testDate',
|
|
20
|
-
time: 'testTime',
|
|
21
|
-
message: 'Date and time must be in the past'
|
|
22
|
-
};
|
|
23
|
-
const CONTAINER = {
|
|
24
|
-
fieldId: 'testContainer',
|
|
25
|
-
type: 'container',
|
|
26
|
-
components: [{
|
|
27
|
-
fieldId: 'testDate',
|
|
28
|
-
type: 'date',
|
|
29
|
-
required: true
|
|
30
|
-
}, {
|
|
31
|
-
fieldId: 'testTime',
|
|
32
|
-
type: 'time',
|
|
33
|
-
required: true
|
|
34
|
-
}]
|
|
35
|
-
};
|
|
36
|
-
test('should return false if the date component is missing', () => {
|
|
37
|
-
const EDITED_CONFIG = _objectSpread(_objectSpread({}, CONFIG), {}, {
|
|
38
|
-
date: 'notARealComponent'
|
|
39
|
-
});
|
|
40
|
-
const result = (0, _mustBeEarlierDateTime.default)(DATA, EDITED_CONFIG, CONTAINER);
|
|
41
|
-
expect(result).toEqual(false);
|
|
42
|
-
});
|
|
43
|
-
test('should return false if the time component is missing', () => {
|
|
44
|
-
const EDITED_CONFIG = _objectSpread(_objectSpread({}, CONFIG), {}, {
|
|
45
|
-
time: 'notARealComponent'
|
|
46
|
-
});
|
|
47
|
-
const result = (0, _mustBeEarlierDateTime.default)(DATA, EDITED_CONFIG, CONTAINER);
|
|
48
|
-
expect(result).toEqual(false);
|
|
49
|
-
});
|
|
50
|
-
test('should return false if data is null', () => {
|
|
51
|
-
const result = (0, _mustBeEarlierDateTime.default)(null, CONFIG, CONTAINER);
|
|
52
|
-
expect(result).toEqual(false);
|
|
53
|
-
});
|
|
54
|
-
test('should return true if date value is missing', () => {
|
|
55
|
-
const EDITED_DATA = {
|
|
56
|
-
testContainer: {
|
|
57
|
-
testTime: '00:00'
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
const result = (0, _mustBeEarlierDateTime.default)(EDITED_DATA, CONFIG, CONTAINER);
|
|
61
|
-
expect(result).toEqual(true);
|
|
62
|
-
});
|
|
63
|
-
test('should return true if time value is missing', () => {
|
|
64
|
-
const EDITED_DATA = {
|
|
65
|
-
testContainer: {
|
|
66
|
-
testDate: '01-01-2000'
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
const result = (0, _mustBeEarlierDateTime.default)(EDITED_DATA, CONFIG, CONTAINER);
|
|
70
|
-
expect(result).toEqual(true);
|
|
71
|
-
});
|
|
72
|
-
test('should return true if time value is missing and optional', () => {
|
|
73
|
-
const EDITED_DATA = {
|
|
74
|
-
testContainer: {
|
|
75
|
-
testDate: '01-01-2000'
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
const EDITED_CONTAINER = {
|
|
79
|
-
fieldId: 'testContainer',
|
|
80
|
-
type: 'container',
|
|
81
|
-
components: [{
|
|
82
|
-
fieldId: 'testDate',
|
|
83
|
-
type: 'date',
|
|
84
|
-
required: true
|
|
85
|
-
}, {
|
|
86
|
-
fieldId: 'testTime',
|
|
87
|
-
type: 'time'
|
|
88
|
-
}]
|
|
89
|
-
};
|
|
90
|
-
const result = (0, _mustBeEarlierDateTime.default)(EDITED_DATA, CONFIG, EDITED_CONTAINER);
|
|
91
|
-
expect(result).toEqual(true);
|
|
92
|
-
});
|
|
93
|
-
test('should return true if date has errors', () => {
|
|
94
|
-
const EDITED_DATA = {
|
|
95
|
-
testContainer: {
|
|
96
|
-
testDate: '011-011-200000',
|
|
97
|
-
testTime: '00:00'
|
|
98
|
-
}
|
|
99
|
-
};
|
|
100
|
-
const result = (0, _mustBeEarlierDateTime.default)(EDITED_DATA, CONFIG, CONTAINER);
|
|
101
|
-
expect(result).toEqual(true);
|
|
102
|
-
});
|
|
103
|
-
test('should return true if time has errors', () => {
|
|
104
|
-
const EDITED_DATA = {
|
|
105
|
-
testContainer: {
|
|
106
|
-
testDate: '01-01-2000',
|
|
107
|
-
testTime: '45:78'
|
|
108
|
-
}
|
|
109
|
-
};
|
|
110
|
-
const result = (0, _mustBeEarlierDateTime.default)(EDITED_DATA, CONFIG, CONTAINER);
|
|
111
|
-
expect(result).toEqual(true);
|
|
112
|
-
});
|
|
113
|
-
test('should return true if date & time are in the past', () => {
|
|
114
|
-
const result = (0, _mustBeEarlierDateTime.default)(DATA, CONFIG, CONTAINER);
|
|
115
|
-
expect(result).toEqual(true);
|
|
116
|
-
});
|
|
117
|
-
test('should return false if date & time are not in the past', () => {
|
|
118
|
-
const futureDATA = {
|
|
119
|
-
testContainer: {
|
|
120
|
-
testDate: '01-01-5000',
|
|
121
|
-
testTime: '00:00'
|
|
122
|
-
}
|
|
123
|
-
};
|
|
124
|
-
const result = (0, _mustBeEarlierDateTime.default)(futureDATA, CONFIG, CONTAINER);
|
|
125
|
-
expect(result).toEqual(false);
|
|
126
|
-
});
|
|
127
|
-
});
|
|
128
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXVzdEJlRWFybGllckRhdGVUaW1lIiwiX2ludGVyb3BSZXF1aXJlRGVmYXVsdCIsInJlcXVpcmUiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJvd25LZXlzIiwiciIsInQiLCJPYmplY3QiLCJrZXlzIiwiZ2V0T3duUHJvcGVydHlTeW1ib2xzIiwibyIsImZpbHRlciIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsImVudW1lcmFibGUiLCJwdXNoIiwiYXBwbHkiLCJfb2JqZWN0U3ByZWFkIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwiZm9yRWFjaCIsIl9kZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvcnMiLCJkZWZpbmVQcm9wZXJ0aWVzIiwiZGVmaW5lUHJvcGVydHkiLCJfdG9Qcm9wZXJ0eUtleSIsInZhbHVlIiwiY29uZmlndXJhYmxlIiwid3JpdGFibGUiLCJpIiwiX3RvUHJpbWl0aXZlIiwiU3ltYm9sIiwidG9QcmltaXRpdmUiLCJjYWxsIiwiVHlwZUVycm9yIiwiU3RyaW5nIiwiTnVtYmVyIiwiZGVzY3JpYmUiLCJEQVRBIiwidGVzdENvbnRhaW5lciIsInRlc3REYXRlIiwidGVzdFRpbWUiLCJDT05GSUciLCJmdW5jdGlvbiIsImRhdGUiLCJ0aW1lIiwibWVzc2FnZSIsIkNPTlRBSU5FUiIsImZpZWxkSWQiLCJ0eXBlIiwiY29tcG9uZW50cyIsInJlcXVpcmVkIiwidGVzdCIsIkVESVRFRF9DT05GSUciLCJyZXN1bHQiLCJtdXN0QmVFYXJsaWVyRGF0ZVRpbWUiLCJleHBlY3QiLCJ0b0VxdWFsIiwiRURJVEVEX0RBVEEiLCJFRElURURfQ09OVEFJTkVSIiwiZnV0dXJlREFUQSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS9hZGRpdGlvbmFsL211c3RCZUVhcmxpZXJEYXRlVGltZS50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBtdXN0QmVFYXJsaWVyRGF0ZVRpbWUgZnJvbSAnLi9tdXN0QmVFYXJsaWVyRGF0ZVRpbWUnO1xuXG5kZXNjcmliZSgndXRpbHMuVmFsaWRhdGUuYWRkaXRpb25hbC5tdXN0QmVFYXJsaWVyRGF0ZVRpbWUnLCAoKSA9PiB7XG4gIGNvbnN0IERBVEEgPSB7XG4gICAgdGVzdENvbnRhaW5lcjoge1xuICAgICAgdGVzdERhdGU6ICcwMS0wMS0yMDAwJyxcbiAgICAgIHRlc3RUaW1lOiAnMDA6MDAnXG4gICAgfVxuICB9O1xuICBjb25zdCBDT05GSUcgPSB7XG4gICAgZnVuY3Rpb246ICdtdXN0QmVFYXJsaWVyRGF0ZVRpbWUnLFxuICAgIGRhdGU6ICd0ZXN0RGF0ZScsXG4gICAgdGltZTogJ3Rlc3RUaW1lJyxcbiAgICBtZXNzYWdlOiAnRGF0ZSBhbmQgdGltZSBtdXN0IGJlIGluIHRoZSBwYXN0J1xuICB9O1xuICBjb25zdCBDT05UQUlORVIgPSB7XG4gICAgZmllbGRJZDogJ3Rlc3RDb250YWluZXInLFxuICAgIHR5cGU6ICdjb250YWluZXInLFxuICAgIGNvbXBvbmVudHM6IFtcbiAgICAgIHtcbiAgICAgICAgZmllbGRJZDogJ3Rlc3REYXRlJyxcbiAgICAgICAgdHlwZTogJ2RhdGUnLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgfSxcbiAgICAgIHtcbiAgICAgICAgZmllbGRJZDogJ3Rlc3RUaW1lJyxcbiAgICAgICAgdHlwZTogJ3RpbWUnLFxuICAgICAgICByZXF1aXJlZDogdHJ1ZVxuICAgICAgfVxuICAgIF0sXG4gIH07XG5cbiAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBpZiB0aGUgZGF0ZSBjb21wb25lbnQgaXMgbWlzc2luZycsICgpID0+IHtcbiAgICBjb25zdCBFRElURURfQ09ORklHID0geyAuLi5DT05GSUcsIGRhdGU6ICdub3RBUmVhbENvbXBvbmVudCcgfTtcbiAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVFYXJsaWVyRGF0ZVRpbWUoREFUQSwgRURJVEVEX0NPTkZJRywgQ09OVEFJTkVSKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKGZhbHNlKTtcbiAgfSk7XG5cbiAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBpZiB0aGUgdGltZSBjb21wb25lbnQgaXMgbWlzc2luZycsICgpID0+IHtcbiAgICBjb25zdCBFRElURURfQ09ORklHID0geyAuLi5DT05GSUcsIHRpbWU6ICdub3RBUmVhbENvbXBvbmVudCcgfTtcbiAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVFYXJsaWVyRGF0ZVRpbWUoREFUQSwgRURJVEVEX0NPTkZJRywgQ09OVEFJTkVSKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKGZhbHNlKTtcbiAgfSk7XG5cbiAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBpZiBkYXRhIGlzIG51bGwnLCAoKSA9PiB7XG4gICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlRWFybGllckRhdGVUaW1lKG51bGwsIENPTkZJRywgQ09OVEFJTkVSKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKGZhbHNlKTtcbiAgfSk7XG5cbiAgdGVzdCgnc2hvdWxkIHJldHVybiB0cnVlIGlmIGRhdGUgdmFsdWUgaXMgbWlzc2luZycsICgpID0+IHtcbiAgICBjb25zdCBFRElURURfREFUQSA9IHtcbiAgICAgIHRlc3RDb250YWluZXI6IHtcbiAgICAgICAgdGVzdFRpbWU6ICcwMDowMCdcbiAgICAgIH1cbiAgICB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUVhcmxpZXJEYXRlVGltZShFRElURURfREFUQSwgQ09ORklHLCBDT05UQUlORVIpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gIH0pO1xuXG4gIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBpZiB0aW1lIHZhbHVlIGlzIG1pc3NpbmcnLCAoKSA9PiB7XG4gICAgY29uc3QgRURJVEVEX0RBVEEgPSB7XG4gICAgICB0ZXN0Q29udGFpbmVyOiB7XG4gICAgICAgIHRlc3REYXRlOiAnMDEtMDEtMjAwMCcsXG4gICAgICB9XG4gICAgfTtcbiAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVFYXJsaWVyRGF0ZVRpbWUoRURJVEVEX0RBVEEsIENPTkZJRywgQ09OVEFJTkVSKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICB9KTtcblxuICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgaWYgdGltZSB2YWx1ZSBpcyBtaXNzaW5nIGFuZCBvcHRpb25hbCcsICgpID0+IHtcbiAgICBjb25zdCBFRElURURfREFUQSA9IHtcbiAgICAgIHRlc3RDb250YWluZXI6IHtcbiAgICAgICAgdGVzdERhdGU6ICcwMS0wMS0yMDAwJyxcbiAgICAgIH1cbiAgICB9O1xuICAgIGNvbnN0IEVESVRFRF9DT05UQUlORVIgPSB7XG4gICAgICBmaWVsZElkOiAndGVzdENvbnRhaW5lcicsXG4gICAgICB0eXBlOiAnY29udGFpbmVyJyxcbiAgICAgIGNvbXBvbmVudHM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGZpZWxkSWQ6ICd0ZXN0RGF0ZScsXG4gICAgICAgICAgdHlwZTogJ2RhdGUnLFxuICAgICAgICAgIHJlcXVpcmVkOiB0cnVlXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICBmaWVsZElkOiAndGVzdFRpbWUnLFxuICAgICAgICAgIHR5cGU6ICd0aW1lJ1xuICAgICAgICB9XG4gICAgICBdLFxuICAgIH07XG4gICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlRWFybGllckRhdGVUaW1lKEVESVRFRF9EQVRBLCBDT05GSUcsIEVESVRFRF9DT05UQUlORVIpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gIH0pO1xuXG4gIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBpZiBkYXRlIGhhcyBlcnJvcnMnLCAoKSA9PiB7XG4gICAgY29uc3QgRURJVEVEX0RBVEEgPSB7XG4gICAgICB0ZXN0Q29udGFpbmVyOiB7XG4gICAgICAgIHRlc3REYXRlOiAnMDExLTAxMS0yMDAwMDAnLFxuICAgICAgICB0ZXN0VGltZTogJzAwOjAwJ1xuICAgICAgfVxuICAgIH07XG4gICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlRWFybGllckRhdGVUaW1lKEVESVRFRF9EQVRBLCBDT05GSUcsIENPTlRBSU5FUik7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgfSk7XG5cbiAgdGVzdCgnc2hvdWxkIHJldHVybiB0cnVlIGlmIHRpbWUgaGFzIGVycm9ycycsICgpID0+IHtcbiAgICBjb25zdCBFRElURURfREFUQSA9IHtcbiAgICAgIHRlc3RDb250YWluZXI6IHtcbiAgICAgICAgdGVzdERhdGU6ICcwMS0wMS0yMDAwJyxcbiAgICAgICAgdGVzdFRpbWU6ICc0NTo3OCdcbiAgICAgIH1cbiAgICB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUVhcmxpZXJEYXRlVGltZShFRElURURfREFUQSwgQ09ORklHLCBDT05UQUlORVIpO1xuICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gIH0pO1xuXG4gIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBpZiBkYXRlICYgdGltZSBhcmUgaW4gdGhlIHBhc3QnLCAoKSA9PiB7XG4gICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlRWFybGllckRhdGVUaW1lKERBVEEsIENPTkZJRywgQ09OVEFJTkVSKTtcbiAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICB9KTtcblxuICB0ZXN0KCdzaG91bGQgcmV0dXJuIGZhbHNlIGlmIGRhdGUgJiB0aW1lIGFyZSBub3QgaW4gdGhlIHBhc3QnLCAoKSA9PiB7XG4gICAgY29uc3QgZnV0dXJlREFUQSA9IHtcbiAgICAgIHRlc3RDb250YWluZXI6IHtcbiAgICAgICAgdGVzdERhdGU6ICcwMS0wMS01MDAwJyxcbiAgICAgICAgdGVzdFRpbWU6ICcwMDowMCdcbiAgICAgIH1cbiAgICB9O1xuICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUVhcmxpZXJEYXRlVGltZShmdXR1cmVEQVRBLCBDT05GSUcsIENPTlRBSU5FUik7XG4gICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChmYWxzZSk7XG4gIH0pO1xuXG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxzQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQTRELFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBQUEsU0FBQUcsUUFBQUgsQ0FBQSxFQUFBSSxDQUFBLFFBQUFDLENBQUEsR0FBQUMsTUFBQSxDQUFBQyxJQUFBLENBQUFQLENBQUEsT0FBQU0sTUFBQSxDQUFBRSxxQkFBQSxRQUFBQyxDQUFBLEdBQUFILE1BQUEsQ0FBQUUscUJBQUEsQ0FBQVIsQ0FBQSxHQUFBSSxDQUFBLEtBQUFLLENBQUEsR0FBQUEsQ0FBQSxDQUFBQyxNQUFBLFdBQUFOLENBQUEsV0FBQUUsTUFBQSxDQUFBSyx3QkFBQSxDQUFBWCxDQUFBLEVBQUFJLENBQUEsRUFBQVEsVUFBQSxPQUFBUCxDQUFBLENBQUFRLElBQUEsQ0FBQUMsS0FBQSxDQUFBVCxDQUFBLEVBQUFJLENBQUEsWUFBQUosQ0FBQTtBQUFBLFNBQUFVLGNBQUFmLENBQUEsYUFBQUksQ0FBQSxNQUFBQSxDQUFBLEdBQUFZLFNBQUEsQ0FBQUMsTUFBQSxFQUFBYixDQUFBLFVBQUFDLENBQUEsV0FBQVcsU0FBQSxDQUFBWixDQUFBLElBQUFZLFNBQUEsQ0FBQVosQ0FBQSxRQUFBQSxDQUFBLE9BQUFELE9BQUEsQ0FBQUcsTUFBQSxDQUFBRCxDQUFBLE9BQUFhLE9BQUEsV0FBQWQsQ0FBQSxJQUFBZSxlQUFBLENBQUFuQixDQUFBLEVBQUFJLENBQUEsRUFBQUMsQ0FBQSxDQUFBRCxDQUFBLFNBQUFFLE1BQUEsQ0FBQWMseUJBQUEsR0FBQWQsTUFBQSxDQUFBZSxnQkFBQSxDQUFBckIsQ0FBQSxFQUFBTSxNQUFBLENBQUFjLHlCQUFBLENBQUFmLENBQUEsS0FBQUYsT0FBQSxDQUFBRyxN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
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* @param {*} value - the value to check.
|
|
9
|
-
* @param {number} config.value - the value must be greater than config.value.
|
|
10
|
-
* @returns true if value is greater than config.value, false if not.
|
|
11
|
-
*/
|
|
12
|
-
const mustBeGreaterThan = (value, config) => {
|
|
13
|
-
if (!value) {
|
|
14
|
-
// null, undefined and empty strings should be picked up by the required flag
|
|
15
|
-
// and not considered here as they would be valid for optional fields.
|
|
16
|
-
return true;
|
|
17
|
-
}
|
|
18
|
-
const finalValue = typeof value === 'string' ? value.replace(/,/g, '') : value;
|
|
19
|
-
return parseFloat(finalValue) > config.value;
|
|
20
|
-
};
|
|
21
|
-
var _default = exports.default = mustBeGreaterThan;
|
|
22
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtdXN0QmVHcmVhdGVyVGhhbiIsInZhbHVlIiwiY29uZmlnIiwiZmluYWxWYWx1ZSIsInJlcGxhY2UiLCJwYXJzZUZsb2F0IiwiX2RlZmF1bHQiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS9hZGRpdGlvbmFsL211c3RCZUdyZWF0ZXJUaGFuLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHBhcmFtIHsqfSB2YWx1ZSAtIHRoZSB2YWx1ZSB0byBjaGVjay5cbiAqIEBwYXJhbSB7bnVtYmVyfSBjb25maWcudmFsdWUgLSB0aGUgdmFsdWUgbXVzdCBiZSBncmVhdGVyIHRoYW4gY29uZmlnLnZhbHVlLiBcbiAqIEByZXR1cm5zIHRydWUgaWYgdmFsdWUgaXMgZ3JlYXRlciB0aGFuIGNvbmZpZy52YWx1ZSwgZmFsc2UgaWYgbm90LlxuICovXG5jb25zdCBtdXN0QmVHcmVhdGVyVGhhbiA9ICh2YWx1ZSwgY29uZmlnKSA9PiB7XG4gIGlmICghdmFsdWUpIHtcbiAgICAvLyBudWxsLCB1bmRlZmluZWQgYW5kIGVtcHR5IHN0cmluZ3Mgc2hvdWxkIGJlIHBpY2tlZCB1cCBieSB0aGUgcmVxdWlyZWQgZmxhZ1xuICAgIC8vIGFuZCBub3QgY29uc2lkZXJlZCBoZXJlIGFzIHRoZXkgd291bGQgYmUgdmFsaWQgZm9yIG9wdGlvbmFsIGZpZWxkcy5cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICBjb25zdCBmaW5hbFZhbHVlID0gdHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJyA/XG4gICAgdmFsdWUucmVwbGFjZSgvLC9nLCAnJykgOlxuICAgIHZhbHVlO1xuICByZXR1cm4gKHBhcnNlRmxvYXQoZmluYWxWYWx1ZSkgPiBjb25maWcudmFsdWUpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgbXVzdEJlR3JlYXRlclRoYW47XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNQSxpQkFBaUIsR0FBR0EsQ0FBQ0MsS0FBSyxFQUFFQyxNQUFNLEtBQUs7RUFDM0MsSUFBSSxDQUFDRCxLQUFLLEVBQUU7SUFDVjtJQUNBO0lBQ0EsT0FBTyxJQUFJO0VBQ2I7RUFDQSxNQUFNRSxVQUFVLEdBQUcsT0FBT0YsS0FBSyxLQUFLLFFBQVEsR0FDMUNBLEtBQUssQ0FBQ0csT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsR0FDdkJILEtBQUs7RUFDUCxPQUFRSSxVQUFVLENBQUNGLFVBQVUsQ0FBQyxHQUFHRCxNQUFNLENBQUNELEtBQUs7QUFDL0MsQ0FBQztBQUFDLElBQUFLLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFSLGlCQUFpQiIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _mustBeGreaterThan = _interopRequireDefault(require("./mustBeGreaterThan"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('utils', () => {
|
|
6
|
-
describe('Validate', () => {
|
|
7
|
-
describe('additional', () => {
|
|
8
|
-
describe('mustBeGreaterThan', () => {
|
|
9
|
-
test('should return true given a number greater than 10', () => {
|
|
10
|
-
const result = (0, _mustBeGreaterThan.default)('11', {
|
|
11
|
-
value: 10
|
|
12
|
-
});
|
|
13
|
-
expect(result).toEqual(true);
|
|
14
|
-
});
|
|
15
|
-
test('should return false if provided value less than or equal to 10', () => {
|
|
16
|
-
const result1 = (0, _mustBeGreaterThan.default)('9', {
|
|
17
|
-
value: 10
|
|
18
|
-
});
|
|
19
|
-
expect(result1).toBeFalsy();
|
|
20
|
-
const result2 = (0, _mustBeGreaterThan.default)('10', {
|
|
21
|
-
value: 10
|
|
22
|
-
});
|
|
23
|
-
expect(result2).toBeFalsy();
|
|
24
|
-
});
|
|
25
|
-
test('should correctly handle numbers with commas in', () => {
|
|
26
|
-
const result1 = (0, _mustBeGreaterThan.default)('999,999,999.99', {
|
|
27
|
-
value: 1000000000
|
|
28
|
-
});
|
|
29
|
-
expect(result1).toEqual(false);
|
|
30
|
-
const result2 = (0, _mustBeGreaterThan.default)('1,000,000,123', {
|
|
31
|
-
value: 1000000000
|
|
32
|
-
});
|
|
33
|
-
expect(result2).toEqual(true);
|
|
34
|
-
});
|
|
35
|
-
test('should return true when string is undefined', () => {
|
|
36
|
-
const result = (0, _mustBeGreaterThan.default)(undefined, {
|
|
37
|
-
value: 10
|
|
38
|
-
});
|
|
39
|
-
expect(result).toEqual(true);
|
|
40
|
-
});
|
|
41
|
-
test('should return true when string is empty', () => {
|
|
42
|
-
const result = (0, _mustBeGreaterThan.default)('', {
|
|
43
|
-
value: 10
|
|
44
|
-
});
|
|
45
|
-
expect(result).toEqual(true);
|
|
46
|
-
});
|
|
47
|
-
test('should return true when string is null', () => {
|
|
48
|
-
const result = (0, _mustBeGreaterThan.default)(null, {
|
|
49
|
-
value: 10
|
|
50
|
-
});
|
|
51
|
-
expect(result).toEqual(true);
|
|
52
|
-
});
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXVzdEJlR3JlYXRlclRoYW4iLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsImRlc2NyaWJlIiwidGVzdCIsInJlc3VsdCIsIm11c3RCZUdyZWF0ZXJUaGFuIiwidmFsdWUiLCJleHBlY3QiLCJ0b0VxdWFsIiwicmVzdWx0MSIsInRvQmVGYWxzeSIsInJlc3VsdDIiLCJ1bmRlZmluZWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvYWRkaXRpb25hbC9tdXN0QmVHcmVhdGVyVGhhbi50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBtdXN0QmVHcmVhdGVyVGhhbiBmcm9tICcuL211c3RCZUdyZWF0ZXJUaGFuJztcblxuZGVzY3JpYmUoJ3V0aWxzJywgKCkgPT4ge1xuICBkZXNjcmliZSgnVmFsaWRhdGUnLCAoKSA9PiB7XG4gICAgZGVzY3JpYmUoJ2FkZGl0aW9uYWwnLCAoKSA9PiB7XG4gICAgICBkZXNjcmliZSgnbXVzdEJlR3JlYXRlclRoYW4nLCAoKSA9PiB7XG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBnaXZlbiBhIG51bWJlciBncmVhdGVyIHRoYW4gMTAnLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlR3JlYXRlclRoYW4oJzExJywge3ZhbHVlOiAxMH0pO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gZmFsc2UgaWYgcHJvdmlkZWQgdmFsdWUgbGVzcyB0aGFuIG9yIGVxdWFsIHRvIDEwJywgKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHJlc3VsdDEgPSBtdXN0QmVHcmVhdGVyVGhhbignOScsIHt2YWx1ZTogMTB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0MSkudG9CZUZhbHN5KCk7XG4gICAgICAgICAgY29uc3QgcmVzdWx0MiA9IG11c3RCZUdyZWF0ZXJUaGFuKCcxMCcsIHt2YWx1ZTogMTB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0MikudG9CZUZhbHN5KCk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCBjb3JyZWN0bHkgaGFuZGxlIG51bWJlcnMgd2l0aCBjb21tYXMgaW4nLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0MSA9IG11c3RCZUdyZWF0ZXJUaGFuKCc5OTksOTk5LDk5OS45OScsIHt2YWx1ZTogMTAwMDAwMDAwMH0pO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQxKS50b0VxdWFsKGZhbHNlKTtcbiAgICAgICAgICBjb25zdCByZXN1bHQyID0gbXVzdEJlR3JlYXRlclRoYW4oJzEsMDAwLDAwMCwxMjMnLCB7dmFsdWU6IDEwMDAwMDAwMDB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0MikudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiB0cnVlIHdoZW4gc3RyaW5nIGlzIHVuZGVmaW5lZCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVHcmVhdGVyVGhhbih1bmRlZmluZWQsIHt2YWx1ZTogMTB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgd2hlbiBzdHJpbmcgaXMgZW1wdHknLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlR3JlYXRlclRoYW4oJycsIHt2YWx1ZTogMTB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgd2hlbiBzdHJpbmcgaXMgbnVsbCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVHcmVhdGVyVGhhbihudWxsLCB7dmFsdWU6IDEwfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxrQkFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQW9ELFNBQUFELHVCQUFBRSxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRXBERyxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU07RUFDdEJBLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTTtJQUN6QkEsUUFBUSxDQUFDLFlBQVksRUFBRSxNQUFNO01BQzNCQSxRQUFRLENBQUMsbUJBQW1CLEVBQUUsTUFBTTtRQUNsQ0MsSUFBSSxDQUFDLG1EQUFtRCxFQUFFLE1BQU07VUFDOUQsTUFBTUMsTUFBTSxHQUFHLElBQUFDLDBCQUFpQixFQUFDLElBQUksRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBRSxDQUFDLENBQUM7VUFDbkRDLE1BQU0sQ0FBQ0gsTUFBTSxDQUFDLENBQUNJLE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDOUIsQ0FBQyxDQUFDO1FBRUZMLElBQUksQ0FBQyxnRUFBZ0UsRUFBRSxNQUFNO1VBQzNFLE1BQU1NLE9BQU8sR0FBRyxJQUFBSiwwQkFBaUIsRUFBQyxHQUFHLEVBQUU7WUFBQ0MsS0FBSyxFQUFFO1VBQUUsQ0FBQyxDQUFDO1VBQ25EQyxNQUFNLENBQUNFLE9BQU8sQ0FBQyxDQUFDQyxTQUFTLENBQUMsQ0FBQztVQUMzQixNQUFNQyxPQUFPLEdBQUcsSUFBQU4sMEJBQWlCLEVBQUMsSUFBSSxFQUFFO1lBQUNDLEtBQUssRUFBRTtVQUFFLENBQUMsQ0FBQztVQUNwREMsTUFBTSxDQUFDSSxPQUFPLENBQUMsQ0FBQ0QsU0FBUyxDQUFDLENBQUM7UUFDN0IsQ0FBQyxDQUFDO1FBRUZQLElBQUksQ0FBQyxnREFBZ0QsRUFBRSxNQUFNO1VBQzNELE1BQU1NLE9BQU8sR0FBRyxJQUFBSiwwQkFBaUIsRUFBQyxnQkFBZ0IsRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBVSxDQUFDLENBQUM7VUFDeEVDLE1BQU0sQ0FBQ0UsT0FBTyxDQUFDLENBQUNELE9BQU8sQ0FBQyxLQUFLLENBQUM7VUFDOUIsTUFBTUcsT0FBTyxHQUFHLElBQUFOLDBCQUFpQixFQUFDLGVBQWUsRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBVSxDQUFDLENBQUM7VUFDdkVDLE1BQU0sQ0FBQ0ksT0FBTyxDQUFDLENBQUNILE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDL0IsQ0FBQyxDQUFDO1FBRUZMLElBQUksQ0FBQyw2Q0FBNkMsRUFBRSxNQUFNO1VBQ3hELE1BQU1DLE1BQU0sR0FBRyxJQUFBQywwQkFBaUIsRUFBQ08sU0FBUyxFQUFFO1lBQUNOLEtBQUssRUFBRTtVQUFFLENBQUMsQ0FBQztVQUN4REMsTUFBTSxDQUFDSCxNQUFNLENBQUMsQ0FBQ0ksT0FBTyxDQUFDLElBQUksQ0FBQztRQUM5QixDQUFDLENBQUM7UUFFRkwsSUFBSSxDQUFDLHlDQUF5QyxFQUFFLE1BQU07VUFDcEQsTUFBTUMsTUFBTSxHQUFHLElBQUFDLDBCQUFpQixFQUFDLEVBQUUsRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBRSxDQUFDLENBQUM7VUFDakRDLE1BQU0sQ0FBQ0gsTUFBTSxDQUFDLENBQUNJLE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDOUIsQ0FBQyxDQUFDO1FBRUZMLElBQUksQ0FBQyx3Q0FBd0MsRUFBRSxNQUFNO1VBQ25ELE1BQU1DLE1BQU0sR0FBRyxJQUFBQywwQkFBaUIsRUFBQyxJQUFJLEVBQUU7WUFBQ0MsS0FBSyxFQUFFO1VBQUUsQ0FBQyxDQUFDO1VBQ25EQyxNQUFNLENBQUNILE1BQU0sQ0FBQyxDQUFDSSxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQzlCLENBQUMsQ0FBQztNQUNKLENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQztFQUNKLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
8
|
-
var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
|
|
9
|
-
var _isToday = _interopRequireDefault(require("dayjs/plugin/isToday"));
|
|
10
|
-
var _utils = require("./utils");
|
|
11
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
|
-
// Global Imports
|
|
13
|
-
|
|
14
|
-
// Local imports
|
|
15
|
-
|
|
16
|
-
_dayjs.default.extend(_customParseFormat.default);
|
|
17
|
-
_dayjs.default.extend(_isToday.default);
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Function returns true if the date parameter is a date after today, else returns false
|
|
21
|
-
* @param {string} date - date string e.g. '03-12-2021'
|
|
22
|
-
* @param {boolean} config.todayAllowed - true if today should be a valid date
|
|
23
|
-
* @returns true if date is after current date
|
|
24
|
-
*/
|
|
25
|
-
const mustBeInTheFuture = (date, config) => {
|
|
26
|
-
const afterToday = (0, _dayjs.default)((0, _utils.formatString)(date), _utils.DATE_FORMAT).isAfter((0, _dayjs.default)());
|
|
27
|
-
if (afterToday) {
|
|
28
|
-
return true;
|
|
29
|
-
}
|
|
30
|
-
return !!(config !== null && config !== void 0 && config.todayAllowed) && (0, _dayjs.default)((0, _utils.formatString)(date), _utils.DATE_FORMAT).isToday();
|
|
31
|
-
};
|
|
32
|
-
var _default = exports.default = mustBeInTheFuture;
|
|
33
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF5anMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9jdXN0b21QYXJzZUZvcm1hdCIsIl9pc1RvZGF5IiwiX3V0aWxzIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGF5anMiLCJleHRlbmQiLCJjdXN0b21QYXJzZUZvcm1hdCIsImlzVG9kYXkiLCJtdXN0QmVJblRoZUZ1dHVyZSIsImRhdGUiLCJjb25maWciLCJhZnRlclRvZGF5IiwiZm9ybWF0U3RyaW5nIiwiREFURV9GT1JNQVQiLCJpc0FmdGVyIiwidG9kYXlBbGxvd2VkIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3V0aWxzL1ZhbGlkYXRlL2FkZGl0aW9uYWwvbXVzdEJlSW5UaGVGdXR1cmUuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gR2xvYmFsIEltcG9ydHNcbmltcG9ydCBkYXlqcyBmcm9tICdkYXlqcyc7XG5pbXBvcnQgY3VzdG9tUGFyc2VGb3JtYXQgZnJvbSAnZGF5anMvcGx1Z2luL2N1c3RvbVBhcnNlRm9ybWF0JztcbmltcG9ydCBpc1RvZGF5IGZyb20gJ2RheWpzL3BsdWdpbi9pc1RvZGF5JztcblxuLy8gTG9jYWwgaW1wb3J0c1xuaW1wb3J0IHsgREFURV9GT1JNQVQsIGZvcm1hdFN0cmluZyB9IGZyb20gJy4vdXRpbHMnO1xuXG5kYXlqcy5leHRlbmQoY3VzdG9tUGFyc2VGb3JtYXQpO1xuZGF5anMuZXh0ZW5kKGlzVG9kYXkpO1xuXG4vKipcbiAqIEZ1bmN0aW9uIHJldHVybnMgdHJ1ZSBpZiB0aGUgZGF0ZSBwYXJhbWV0ZXIgaXMgYSBkYXRlIGFmdGVyIHRvZGF5LCBlbHNlIHJldHVybnMgZmFsc2VcbiAqIEBwYXJhbSB7c3RyaW5nfSBkYXRlIC0gZGF0ZSBzdHJpbmcgZS5nLiAnMDMtMTItMjAyMSdcbiAqIEBwYXJhbSB7Ym9vbGVhbn0gY29uZmlnLnRvZGF5QWxsb3dlZCAtIHRydWUgaWYgdG9kYXkgc2hvdWxkIGJlIGEgdmFsaWQgZGF0ZVxuICogQHJldHVybnMgdHJ1ZSBpZiBkYXRlIGlzIGFmdGVyIGN1cnJlbnQgZGF0ZVxuICovXG5jb25zdCBtdXN0QmVJblRoZUZ1dHVyZSA9IChkYXRlLCBjb25maWcpID0+IHtcbiAgY29uc3QgYWZ0ZXJUb2RheSA9IGRheWpzKGZvcm1hdFN0cmluZyhkYXRlKSwgREFURV9GT1JNQVQpLmlzQWZ0ZXIoZGF5anMoKSk7XG4gIGlmIChhZnRlclRvZGF5KSB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cbiAgcmV0dXJuICEhY29uZmlnPy50b2RheUFsbG93ZWQgJiYgZGF5anMoZm9ybWF0U3RyaW5nKGRhdGUpLCBEQVRFX0ZPUk1BVCkuaXNUb2RheSgpO1xufTtcblxuZXhwb3J0IGRlZmF1bHQgbXVzdEJlSW5UaGVGdXR1cmU7XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUNBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLGtCQUFBLEdBQUFGLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBRSxRQUFBLEdBQUFILHNCQUFBLENBQUFDLE9BQUE7QUFHQSxJQUFBRyxNQUFBLEdBQUFILE9BQUE7QUFBb0QsU0FBQUQsdUJBQUFLLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFOcEQ7O0FBS0E7O0FBR0FHLGNBQUssQ0FBQ0MsTUFBTSxDQUFDQywwQkFBaUIsQ0FBQztBQUMvQkYsY0FBSyxDQUFDQyxNQUFNLENBQUNFLGdCQUFPLENBQUM7O0FBRXJCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1DLGlCQUFpQixHQUFHQSxDQUFDQyxJQUFJLEVBQUVDLE1BQU0sS0FBSztFQUMxQyxNQUFNQyxVQUFVLEdBQUcsSUFBQVAsY0FBSyxFQUFDLElBQUFRLG1CQUFZLEVBQUNILElBQUksQ0FBQyxFQUFFSSxrQkFBVyxDQUFDLENBQUNDLE9BQU8sQ0FBQyxJQUFBVixjQUFLLEVBQUMsQ0FBQyxDQUFDO0VBQzFFLElBQUlPLFVBQVUsRUFBRTtJQUNkLE9BQU8sSUFBSTtFQUNiO0VBQ0EsT0FBTyxDQUFDLEVBQUNELE1BQU0sYUFBTkEsTUFBTSxlQUFOQSxNQUFNLENBQUVLLFlBQVksS0FBSSxJQUFBWCxjQUFLLEVBQUMsSUFBQVEsbUJBQVksRUFBQ0gsSUFBSSxDQUFDLEVBQUVJLGtCQUFXLENBQUMsQ0FBQ04sT0FBTyxDQUFDLENBQUM7QUFDbkYsQ0FBQztBQUFDLElBQUFTLFFBQUEsR0FBQUMsT0FBQSxDQUFBZCxPQUFBLEdBRWFLLGlCQUFpQiIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
4
|
-
var _mustBeInTheFuture = _interopRequireDefault(require("./mustBeInTheFuture"));
|
|
5
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
6
|
-
describe('utils', () => {
|
|
7
|
-
describe('Validate', () => {
|
|
8
|
-
describe('additional', () => {
|
|
9
|
-
describe('mustBeInTheFuture', () => {
|
|
10
|
-
test('should return false given a date in the past', () => {
|
|
11
|
-
const result = (0, _mustBeInTheFuture.default)((0, _dayjs.default)().subtract(1, 'day').format('DD-MM-YYYY'));
|
|
12
|
-
expect(result).toEqual(false);
|
|
13
|
-
});
|
|
14
|
-
test('should return true given a date in the future', () => {
|
|
15
|
-
const result = (0, _mustBeInTheFuture.default)((0, _dayjs.default)().add(1, 'day').format('DD-MM-YYYY'));
|
|
16
|
-
expect(result).toEqual(true);
|
|
17
|
-
});
|
|
18
|
-
test('should return false given todays date', () => {
|
|
19
|
-
const result = (0, _mustBeInTheFuture.default)((0, _dayjs.default)().format('DD-MM-YYYY'));
|
|
20
|
-
expect(result).toEqual(false);
|
|
21
|
-
});
|
|
22
|
-
test('should return true given todays date if todayAllowed is true', () => {
|
|
23
|
-
const result = (0, _mustBeInTheFuture.default)((0, _dayjs.default)().format('DD-MM-YYYY'), {
|
|
24
|
-
todayAllowed: true
|
|
25
|
-
});
|
|
26
|
-
expect(result).toEqual(true);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF5anMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9tdXN0QmVJblRoZUZ1dHVyZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsImRlc2NyaWJlIiwidGVzdCIsInJlc3VsdCIsIm11c3RCZUluVGhlRnV0dXJlIiwiZGF5anMiLCJzdWJ0cmFjdCIsImZvcm1hdCIsImV4cGVjdCIsInRvRXF1YWwiLCJhZGQiLCJ0b2RheUFsbG93ZWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvYWRkaXRpb25hbC9tdXN0QmVJblRoZUZ1dHVyZS50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkYXlqcyBmcm9tICdkYXlqcyc7XG5pbXBvcnQgbXVzdEJlSW5UaGVGdXR1cmUgZnJvbSAnLi9tdXN0QmVJblRoZUZ1dHVyZSc7XG5cbmRlc2NyaWJlKCd1dGlscycsICgpID0+IHtcbiAgZGVzY3JpYmUoJ1ZhbGlkYXRlJywgKCkgPT4ge1xuICAgIGRlc2NyaWJlKCdhZGRpdGlvbmFsJywgKCkgPT4ge1xuICAgICAgZGVzY3JpYmUoJ211c3RCZUluVGhlRnV0dXJlJywgKCkgPT4ge1xuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGZhbHNlIGdpdmVuIGEgZGF0ZSBpbiB0aGUgcGFzdCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZUZ1dHVyZShkYXlqcygpLnN1YnRyYWN0KDEsICdkYXknKS5mb3JtYXQoJ0RELU1NLVlZWVknKSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChmYWxzZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBnaXZlbiBhIGRhdGUgaW4gdGhlIGZ1dHVyZScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZUZ1dHVyZShkYXlqcygpLmFkZCgxLCAnZGF5JykuZm9ybWF0KCdERC1NTS1ZWVlZJykpO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gZmFsc2UgZ2l2ZW4gdG9kYXlzIGRhdGUnLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlSW5UaGVGdXR1cmUoZGF5anMoKS5mb3JtYXQoJ0RELU1NLVlZWVknKSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChmYWxzZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBnaXZlbiB0b2RheXMgZGF0ZSBpZiB0b2RheUFsbG93ZWQgaXMgdHJ1ZScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZUZ1dHVyZShkYXlqcygpLmZvcm1hdCgnREQtTU0tWVlZWScpLCB7IHRvZGF5QWxsb3dlZDogdHJ1ZSB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcbiAgICAgIH0pO1xuICAgIH0pO1xuICB9KTtcbn0pO1xuIl0sIm1hcHBpbmdzIjoiOztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLGtCQUFBLEdBQUFGLHNCQUFBLENBQUFDLE9BQUE7QUFBb0QsU0FBQUQsdUJBQUFHLENBQUEsV0FBQUEsQ0FBQSxJQUFBQSxDQUFBLENBQUFDLFVBQUEsR0FBQUQsQ0FBQSxLQUFBRSxPQUFBLEVBQUFGLENBQUE7QUFFcERHLFFBQVEsQ0FBQyxPQUFPLEVBQUUsTUFBTTtFQUN0QkEsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNO0lBQ3pCQSxRQUFRLENBQUMsWUFBWSxFQUFFLE1BQU07TUFDM0JBLFFBQVEsQ0FBQyxtQkFBbUIsRUFBRSxNQUFNO1FBQ2xDQyxJQUFJLENBQUMsOENBQThDLEVBQUUsTUFBTTtVQUN6RCxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsMEJBQWlCLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0MsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQ0MsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1VBQ2pGQyxNQUFNLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxPQUFPLENBQUMsS0FBSyxDQUFDO1FBQy9CLENBQUMsQ0FBQztRQUVGUCxJQUFJLENBQUMsK0NBQStDLEVBQUUsTUFBTTtVQUMxRCxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsMEJBQWlCLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0ssR0FBRyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQ0gsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1VBQzVFQyxNQUFNLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQzlCLENBQUMsQ0FBQztRQUVGUCxJQUFJLENBQUMsdUNBQXVDLEVBQUUsTUFBTTtVQUNsRCxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsMEJBQWlCLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0UsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1VBQzlEQyxNQUFNLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxPQUFPLENBQUMsS0FBSyxDQUFDO1FBQy9CLENBQUMsQ0FBQztRQUVGUCxJQUFJLENBQUMsOERBQThELEVBQUUsTUFBTTtVQUN6RSxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsMEJBQWlCLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0UsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFFO1lBQUVJLFlBQVksRUFBRTtVQUFLLENBQUMsQ0FBQztVQUN0RkgsTUFBTSxDQUFDTCxNQUFNLENBQUMsQ0FBQ00sT0FBTyxDQUFDLElBQUksQ0FBQztRQUM5QixDQUFDLENBQUM7TUFDSixDQUFDLENBQUM7SUFDSixDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
8
|
-
var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
|
|
9
|
-
var _isToday = _interopRequireDefault(require("dayjs/plugin/isToday"));
|
|
10
|
-
var _utils = require("./utils");
|
|
11
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
|
-
// Global imports
|
|
13
|
-
|
|
14
|
-
// Local imports
|
|
15
|
-
|
|
16
|
-
_dayjs.default.extend(_customParseFormat.default);
|
|
17
|
-
_dayjs.default.extend(_isToday.default);
|
|
18
|
-
|
|
19
|
-
/**
|
|
20
|
-
* Function returns true if the date parameter is a date before today, else returns false
|
|
21
|
-
* dayjs counts today as before today so also cover same day inputs
|
|
22
|
-
* @param {string} date - date string e.g. '03-12-2021'
|
|
23
|
-
* @param {boolean} config.todayAllowed - true if today should be a valid date
|
|
24
|
-
* @returns true if date is before current date
|
|
25
|
-
*/
|
|
26
|
-
const mustBeInThePast = (date, config) => {
|
|
27
|
-
const beforeToday = (0, _dayjs.default)((0, _utils.formatString)(date), _utils.DATE_FORMAT).isBefore((0, _dayjs.default)());
|
|
28
|
-
const dateIsToday = (0, _dayjs.default)((0, _utils.formatString)(date), _utils.DATE_FORMAT).isToday();
|
|
29
|
-
// dayjs classifies the current day as in the past so exclude it here
|
|
30
|
-
if (beforeToday && !dateIsToday) {
|
|
31
|
-
return true;
|
|
32
|
-
}
|
|
33
|
-
return dateIsToday && !!(config !== null && config !== void 0 && config.todayAllowed);
|
|
34
|
-
};
|
|
35
|
-
var _default = exports.default = mustBeInThePast;
|
|
36
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF5anMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9jdXN0b21QYXJzZUZvcm1hdCIsIl9pc1RvZGF5IiwiX3V0aWxzIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGF5anMiLCJleHRlbmQiLCJjdXN0b21QYXJzZUZvcm1hdCIsImlzVG9kYXkiLCJtdXN0QmVJblRoZVBhc3QiLCJkYXRlIiwiY29uZmlnIiwiYmVmb3JlVG9kYXkiLCJmb3JtYXRTdHJpbmciLCJEQVRFX0ZPUk1BVCIsImlzQmVmb3JlIiwiZGF0ZUlzVG9kYXkiLCJ0b2RheUFsbG93ZWQiLCJfZGVmYXVsdCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvYWRkaXRpb25hbC9tdXN0QmVJblRoZVBhc3QuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gR2xvYmFsIGltcG9ydHNcbmltcG9ydCBkYXlqcyBmcm9tICdkYXlqcyc7XG5pbXBvcnQgY3VzdG9tUGFyc2VGb3JtYXQgZnJvbSAnZGF5anMvcGx1Z2luL2N1c3RvbVBhcnNlRm9ybWF0JztcbmltcG9ydCBpc1RvZGF5IGZyb20gJ2RheWpzL3BsdWdpbi9pc1RvZGF5JztcblxuXG4vLyBMb2NhbCBpbXBvcnRzXG5pbXBvcnQgeyBEQVRFX0ZPUk1BVCwgZm9ybWF0U3RyaW5nIH0gZnJvbSAnLi91dGlscyc7XG5cbmRheWpzLmV4dGVuZChjdXN0b21QYXJzZUZvcm1hdCk7XG5kYXlqcy5leHRlbmQoaXNUb2RheSk7XG5cbi8qKlxuICogRnVuY3Rpb24gcmV0dXJucyB0cnVlIGlmIHRoZSBkYXRlIHBhcmFtZXRlciBpcyBhIGRhdGUgYmVmb3JlIHRvZGF5LCBlbHNlIHJldHVybnMgZmFsc2VcbiAqIGRheWpzIGNvdW50cyB0b2RheSBhcyBiZWZvcmUgdG9kYXkgc28gYWxzbyBjb3ZlciBzYW1lIGRheSBpbnB1dHNcbiAqIEBwYXJhbSB7c3RyaW5nfSBkYXRlIC0gZGF0ZSBzdHJpbmcgZS5nLiAnMDMtMTItMjAyMSdcbiAqIEBwYXJhbSB7Ym9vbGVhbn0gY29uZmlnLnRvZGF5QWxsb3dlZCAtIHRydWUgaWYgdG9kYXkgc2hvdWxkIGJlIGEgdmFsaWQgZGF0ZVxuICogQHJldHVybnMgdHJ1ZSBpZiBkYXRlIGlzIGJlZm9yZSBjdXJyZW50IGRhdGVcbiAqL1xuY29uc3QgbXVzdEJlSW5UaGVQYXN0ID0gKGRhdGUsIGNvbmZpZykgPT4ge1xuICBjb25zdCBiZWZvcmVUb2RheSA9IGRheWpzKGZvcm1hdFN0cmluZyhkYXRlKSwgREFURV9GT1JNQVQpLmlzQmVmb3JlKGRheWpzKCkpO1xuICBjb25zdCBkYXRlSXNUb2RheSA9IGRheWpzKGZvcm1hdFN0cmluZyhkYXRlKSwgREFURV9GT1JNQVQpLmlzVG9kYXkoKTtcbiAgLy8gZGF5anMgY2xhc3NpZmllcyB0aGUgY3VycmVudCBkYXkgYXMgaW4gdGhlIHBhc3Qgc28gZXhjbHVkZSBpdCBoZXJlXG4gIGlmIChiZWZvcmVUb2RheSAmJiAhZGF0ZUlzVG9kYXkpIHtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICByZXR1cm4gZGF0ZUlzVG9kYXkgJiYgISFjb25maWc/LnRvZGF5QWxsb3dlZDtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IG11c3RCZUluVGhlUGFzdDtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsa0JBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFFLFFBQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUlBLElBQUFHLE1BQUEsR0FBQUgsT0FBQTtBQUFvRCxTQUFBRCx1QkFBQUssQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQVBwRDs7QUFNQTs7QUFHQUcsY0FBSyxDQUFDQyxNQUFNLENBQUNDLDBCQUFpQixDQUFDO0FBQy9CRixjQUFLLENBQUNDLE1BQU0sQ0FBQ0UsZ0JBQU8sQ0FBQzs7QUFFckI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxNQUFNQyxlQUFlLEdBQUdBLENBQUNDLElBQUksRUFBRUMsTUFBTSxLQUFLO0VBQ3hDLE1BQU1DLFdBQVcsR0FBRyxJQUFBUCxjQUFLLEVBQUMsSUFBQVEsbUJBQVksRUFBQ0gsSUFBSSxDQUFDLEVBQUVJLGtCQUFXLENBQUMsQ0FBQ0MsUUFBUSxDQUFDLElBQUFWLGNBQUssRUFBQyxDQUFDLENBQUM7RUFDNUUsTUFBTVcsV0FBVyxHQUFHLElBQUFYLGNBQUssRUFBQyxJQUFBUSxtQkFBWSxFQUFDSCxJQUFJLENBQUMsRUFBRUksa0JBQVcsQ0FBQyxDQUFDTixPQUFPLENBQUMsQ0FBQztFQUNwRTtFQUNBLElBQUlJLFdBQVcsSUFBSSxDQUFDSSxXQUFXLEVBQUU7SUFDL0IsT0FBTyxJQUFJO0VBQ2I7RUFDQSxPQUFPQSxXQUFXLElBQUksQ0FBQyxFQUFDTCxNQUFNLGFBQU5BLE1BQU0sZUFBTkEsTUFBTSxDQUFFTSxZQUFZO0FBQzlDLENBQUM7QUFBQyxJQUFBQyxRQUFBLEdBQUFDLE9BQUEsQ0FBQWYsT0FBQSxHQUVhSyxlQUFlIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
4
|
-
var _mustBeInThePast = _interopRequireDefault(require("./mustBeInThePast"));
|
|
5
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
6
|
-
describe('utils', () => {
|
|
7
|
-
describe('Validate', () => {
|
|
8
|
-
describe('additional', () => {
|
|
9
|
-
describe('mustBeInThePast', () => {
|
|
10
|
-
test('should return true given a date in the past', () => {
|
|
11
|
-
const result = (0, _mustBeInThePast.default)((0, _dayjs.default)().subtract(1, 'day').format('DD-MM-YYYY'));
|
|
12
|
-
expect(result).toEqual(true);
|
|
13
|
-
});
|
|
14
|
-
test('should return false given a date in the future', () => {
|
|
15
|
-
const result = (0, _mustBeInThePast.default)((0, _dayjs.default)().add(1, 'day').format('DD-MM-YYYY'));
|
|
16
|
-
expect(result).toEqual(false);
|
|
17
|
-
});
|
|
18
|
-
test('should return false given todays date', () => {
|
|
19
|
-
const result = (0, _mustBeInThePast.default)((0, _dayjs.default)().format('DD-MM-YYYY'));
|
|
20
|
-
expect(result).toEqual(false);
|
|
21
|
-
});
|
|
22
|
-
test('should return true given todays date if todayAllowed is true', () => {
|
|
23
|
-
const result = (0, _mustBeInThePast.default)((0, _dayjs.default)().format('DD-MM-YYYY'), {
|
|
24
|
-
todayAllowed: true
|
|
25
|
-
});
|
|
26
|
-
expect(result).toEqual(true);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
29
|
-
});
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGF5anMiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9tdXN0QmVJblRoZVBhc3QiLCJlIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJkZXNjcmliZSIsInRlc3QiLCJyZXN1bHQiLCJtdXN0QmVJblRoZVBhc3QiLCJkYXlqcyIsInN1YnRyYWN0IiwiZm9ybWF0IiwiZXhwZWN0IiwidG9FcXVhbCIsImFkZCIsInRvZGF5QWxsb3dlZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS9hZGRpdGlvbmFsL211c3RCZUluVGhlUGFzdC50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBkYXlqcyBmcm9tICdkYXlqcyc7XG5pbXBvcnQgbXVzdEJlSW5UaGVQYXN0IGZyb20gJy4vbXVzdEJlSW5UaGVQYXN0JztcblxuZGVzY3JpYmUoJ3V0aWxzJywgKCkgPT4ge1xuICBkZXNjcmliZSgnVmFsaWRhdGUnLCAoKSA9PiB7XG4gICAgZGVzY3JpYmUoJ2FkZGl0aW9uYWwnLCAoKSA9PiB7XG4gICAgICBkZXNjcmliZSgnbXVzdEJlSW5UaGVQYXN0JywgKCkgPT4ge1xuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgZ2l2ZW4gYSBkYXRlIGluIHRoZSBwYXN0JywgKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUluVGhlUGFzdChkYXlqcygpLnN1YnRyYWN0KDEsICdkYXknKS5mb3JtYXQoJ0RELU1NLVlZWVknKSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBnaXZlbiBhIGRhdGUgaW4gdGhlIGZ1dHVyZScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZVBhc3QoZGF5anMoKS5hZGQoMSwgJ2RheScpLmZvcm1hdCgnREQtTU0tWVlZWScpKTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKGZhbHNlKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBnaXZlbiB0b2RheXMgZGF0ZScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZVBhc3QoZGF5anMoKS5mb3JtYXQoJ0RELU1NLVlZWVknKSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChmYWxzZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBnaXZlbiB0b2RheXMgZGF0ZSBpZiB0b2RheUFsbG93ZWQgaXMgdHJ1ZScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVJblRoZVBhc3QoZGF5anMoKS5mb3JtYXQoJ0RELU1NLVlZWVknKSwgeyB0b2RheUFsbG93ZWQ6IHRydWUgfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfSk7XG59KTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxnQkFBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQWdELFNBQUFELHVCQUFBRyxDQUFBLFdBQUFBLENBQUEsSUFBQUEsQ0FBQSxDQUFBQyxVQUFBLEdBQUFELENBQUEsS0FBQUUsT0FBQSxFQUFBRixDQUFBO0FBRWhERyxRQUFRLENBQUMsT0FBTyxFQUFFLE1BQU07RUFDdEJBLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTTtJQUN6QkEsUUFBUSxDQUFDLFlBQVksRUFBRSxNQUFNO01BQzNCQSxRQUFRLENBQUMsaUJBQWlCLEVBQUUsTUFBTTtRQUNoQ0MsSUFBSSxDQUFDLDZDQUE2QyxFQUFFLE1BQU07VUFDeEQsTUFBTUMsTUFBTSxHQUFHLElBQUFDLHdCQUFlLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0MsUUFBUSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQ0MsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO1VBQy9FQyxNQUFNLENBQUNMLE1BQU0sQ0FBQyxDQUFDTSxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQzlCLENBQUMsQ0FBQztRQUVGUCxJQUFJLENBQUMsZ0RBQWdELEVBQUUsTUFBTTtVQUMzRCxNQUFNQyxNQUFNLEdBQUcsSUFBQUMsd0JBQWUsRUFBQyxJQUFBQyxjQUFLLEVBQUMsQ0FBQyxDQUFDSyxHQUFHLENBQUMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDSCxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7VUFDMUVDLE1BQU0sQ0FBQ0wsTUFBTSxDQUFDLENBQUNNLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDL0IsQ0FBQyxDQUFDO1FBRUZQLElBQUksQ0FBQyx1Q0FBdUMsRUFBRSxNQUFNO1VBQ2xELE1BQU1DLE1BQU0sR0FBRyxJQUFBQyx3QkFBZSxFQUFDLElBQUFDLGNBQUssRUFBQyxDQUFDLENBQUNFLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztVQUM1REMsTUFBTSxDQUFDTCxNQUFNLENBQUMsQ0FBQ00sT0FBTyxDQUFDLEtBQUssQ0FBQztRQUMvQixDQUFDLENBQUM7UUFFRlAsSUFBSSxDQUFDLDhEQUE4RCxFQUFFLE1BQU07VUFDekUsTUFBTUMsTUFBTSxHQUFHLElBQUFDLHdCQUFlLEVBQUMsSUFBQUMsY0FBSyxFQUFDLENBQUMsQ0FBQ0UsTUFBTSxDQUFDLFlBQVksQ0FBQyxFQUFFO1lBQUVJLFlBQVksRUFBRTtVQUFLLENBQUMsQ0FBQztVQUNwRkgsTUFBTSxDQUFDTCxNQUFNLENBQUMsQ0FBQ00sT0FBTyxDQUFDLElBQUksQ0FBQztRQUM5QixDQUFDLENBQUM7TUFDSixDQUFDLENBQUM7SUFDSixDQUFDLENBQUM7RUFDSixDQUFDLENBQUM7QUFDSixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* @param {*} value - the value to check.
|
|
9
|
-
* @param {number} config.value - the value must be equal or less than config.value.
|
|
10
|
-
* @returns true if value is equal to or less then config.value, false if not.
|
|
11
|
-
*/
|
|
12
|
-
const mustBeLessThan = (value, config) => {
|
|
13
|
-
if (!value) {
|
|
14
|
-
// null, undefined and empty strings should be picked up by the required flag
|
|
15
|
-
// and not considered here as they would be valid for optional fields.
|
|
16
|
-
return true;
|
|
17
|
-
}
|
|
18
|
-
const finalValue = typeof value === 'string' ? value.replace(/,/g, '') : value;
|
|
19
|
-
return parseFloat(finalValue) < config.value;
|
|
20
|
-
};
|
|
21
|
-
var _default = exports.default = mustBeLessThan;
|
|
22
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtdXN0QmVMZXNzVGhhbiIsInZhbHVlIiwiY29uZmlnIiwiZmluYWxWYWx1ZSIsInJlcGxhY2UiLCJwYXJzZUZsb2F0IiwiX2RlZmF1bHQiLCJleHBvcnRzIiwiZGVmYXVsdCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS9hZGRpdGlvbmFsL211c3RCZUxlc3NUaGFuLmpzIl0sInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHBhcmFtIHsqfSB2YWx1ZSAtIHRoZSB2YWx1ZSB0byBjaGVjay5cbiAqIEBwYXJhbSB7bnVtYmVyfSBjb25maWcudmFsdWUgLSB0aGUgdmFsdWUgbXVzdCBiZSBlcXVhbCBvciBsZXNzIHRoYW4gY29uZmlnLnZhbHVlLiBcbiAqIEByZXR1cm5zIHRydWUgaWYgdmFsdWUgaXMgZXF1YWwgdG8gb3IgbGVzcyB0aGVuIGNvbmZpZy52YWx1ZSwgZmFsc2UgaWYgbm90LlxuICovXG5jb25zdCBtdXN0QmVMZXNzVGhhbiA9ICh2YWx1ZSwgY29uZmlnKSA9PiB7XG4gIGlmICghdmFsdWUpIHtcbiAgICAvLyBudWxsLCB1bmRlZmluZWQgYW5kIGVtcHR5IHN0cmluZ3Mgc2hvdWxkIGJlIHBpY2tlZCB1cCBieSB0aGUgcmVxdWlyZWQgZmxhZ1xuICAgIC8vIGFuZCBub3QgY29uc2lkZXJlZCBoZXJlIGFzIHRoZXkgd291bGQgYmUgdmFsaWQgZm9yIG9wdGlvbmFsIGZpZWxkcy5cbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuICBjb25zdCBmaW5hbFZhbHVlID0gdHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJyA/XG4gICAgdmFsdWUucmVwbGFjZSgvLC9nLCAnJykgOlxuICAgIHZhbHVlO1xuICByZXR1cm4gKHBhcnNlRmxvYXQoZmluYWxWYWx1ZSkgPCBjb25maWcudmFsdWUpO1xufTtcbiAgXG5leHBvcnQgZGVmYXVsdCBtdXN0QmVMZXNzVGhhbjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1BLGNBQWMsR0FBR0EsQ0FBQ0MsS0FBSyxFQUFFQyxNQUFNLEtBQUs7RUFDeEMsSUFBSSxDQUFDRCxLQUFLLEVBQUU7SUFDVjtJQUNBO0lBQ0EsT0FBTyxJQUFJO0VBQ2I7RUFDQSxNQUFNRSxVQUFVLEdBQUcsT0FBT0YsS0FBSyxLQUFLLFFBQVEsR0FDMUNBLEtBQUssQ0FBQ0csT0FBTyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsR0FDdkJILEtBQUs7RUFDUCxPQUFRSSxVQUFVLENBQUNGLFVBQVUsQ0FBQyxHQUFHRCxNQUFNLENBQUNELEtBQUs7QUFDL0MsQ0FBQztBQUFDLElBQUFLLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFSLGNBQWMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _mustBeLessThan = _interopRequireDefault(require("./mustBeLessThan"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('utils', () => {
|
|
6
|
-
describe('Validate', () => {
|
|
7
|
-
describe('additional', () => {
|
|
8
|
-
describe('mustBeLessThan', () => {
|
|
9
|
-
test('should return true given a number equal to or less than 1000000000', () => {
|
|
10
|
-
const result = (0, _mustBeLessThan.default)(999999999.999, {
|
|
11
|
-
value: 1000000000
|
|
12
|
-
});
|
|
13
|
-
expect(result).toEqual(true);
|
|
14
|
-
});
|
|
15
|
-
test('should return false if provided value greater than 1000000000', () => {
|
|
16
|
-
const result = (0, _mustBeLessThan.default)('1000000000.9', {
|
|
17
|
-
value: 1000000000
|
|
18
|
-
});
|
|
19
|
-
expect(result).toBeFalsy();
|
|
20
|
-
});
|
|
21
|
-
test('should correctly handle numbers with commas in', () => {
|
|
22
|
-
const result1 = (0, _mustBeLessThan.default)('999,999,999.99', {
|
|
23
|
-
value: 1000000000
|
|
24
|
-
});
|
|
25
|
-
expect(result1).toEqual(true);
|
|
26
|
-
const result2 = (0, _mustBeLessThan.default)('1,000,000,123', {
|
|
27
|
-
value: 1000000000
|
|
28
|
-
});
|
|
29
|
-
expect(result2).toEqual(false);
|
|
30
|
-
});
|
|
31
|
-
test('should return true when string is undefined', () => {
|
|
32
|
-
const result = (0, _mustBeLessThan.default)(undefined, {
|
|
33
|
-
value: 3
|
|
34
|
-
});
|
|
35
|
-
expect(result).toEqual(true);
|
|
36
|
-
});
|
|
37
|
-
test('should return true when string is empty', () => {
|
|
38
|
-
const result = (0, _mustBeLessThan.default)('', {
|
|
39
|
-
value: 3
|
|
40
|
-
});
|
|
41
|
-
expect(result).toEqual(true);
|
|
42
|
-
});
|
|
43
|
-
test('should return true when string is null', () => {
|
|
44
|
-
const result = (0, _mustBeLessThan.default)(null, {
|
|
45
|
-
value: 3
|
|
46
|
-
});
|
|
47
|
-
expect(result).toEqual(true);
|
|
48
|
-
});
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
});
|
|
52
|
-
});
|
|
53
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXVzdEJlTGVzc1RoYW4iLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsImUiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsImRlc2NyaWJlIiwidGVzdCIsInJlc3VsdCIsIm11c3RCZUxlc3NUaGFuIiwidmFsdWUiLCJleHBlY3QiLCJ0b0VxdWFsIiwidG9CZUZhbHN5IiwicmVzdWx0MSIsInJlc3VsdDIiLCJ1bmRlZmluZWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdXRpbHMvVmFsaWRhdGUvYWRkaXRpb25hbC9tdXN0QmVMZXNzVGhhbi50ZXN0LmpzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBtdXN0QmVMZXNzVGhhbiBmcm9tICcuL211c3RCZUxlc3NUaGFuJztcblxuZGVzY3JpYmUoJ3V0aWxzJywgKCkgPT4ge1xuICBkZXNjcmliZSgnVmFsaWRhdGUnLCAoKSA9PiB7XG4gICAgZGVzY3JpYmUoJ2FkZGl0aW9uYWwnLCAoKSA9PiB7XG4gICAgICBkZXNjcmliZSgnbXVzdEJlTGVzc1RoYW4nLCAoKSA9PiB7XG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSBnaXZlbiBhIG51bWJlciBlcXVhbCB0byBvciBsZXNzIHRoYW4gMTAwMDAwMDAwMCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMZXNzVGhhbig5OTk5OTk5OTkuOTk5LCB7dmFsdWU6IDEwMDAwMDAwMDB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGZhbHNlIGlmIHByb3ZpZGVkIHZhbHVlIGdyZWF0ZXIgdGhhbiAxMDAwMDAwMDAwJywgKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUxlc3NUaGFuKCcxMDAwMDAwMDAwLjknLCB7dmFsdWU6IDEwMDAwMDAwMDB9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0JlRmFsc3koKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIGNvcnJlY3RseSBoYW5kbGUgbnVtYmVycyB3aXRoIGNvbW1hcyBpbicsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQxID0gbXVzdEJlTGVzc1RoYW4oJzk5OSw5OTksOTk5Ljk5Jywge3ZhbHVlOiAxMDAwMDAwMDAwfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdDEpLnRvRXF1YWwodHJ1ZSk7XG4gICAgICAgICAgY29uc3QgcmVzdWx0MiA9IG11c3RCZUxlc3NUaGFuKCcxLDAwMCwwMDAsMTIzJywge3ZhbHVlOiAxMDAwMDAwMDAwfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdDIpLnRvRXF1YWwoZmFsc2UpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgd2hlbiBzdHJpbmcgaXMgdW5kZWZpbmVkJywgKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUxlc3NUaGFuKHVuZGVmaW5lZCwge3ZhbHVlOiAzfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiB0cnVlIHdoZW4gc3RyaW5nIGlzIGVtcHR5JywgKCkgPT4ge1xuICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IG11c3RCZUxlc3NUaGFuKCcnLCB7dmFsdWU6IDN9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgd2hlbiBzdHJpbmcgaXMgbnVsbCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMZXNzVGhhbihudWxsLCB7dmFsdWU6IDN9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0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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
|
-
/**
|
|
8
|
-
* Function returns true if the string parameter is longer than a given length, false
|
|
9
|
-
* if it is not.
|
|
10
|
-
* @param {string} string - the string to check the length of.
|
|
11
|
-
* @param {number} config.value - the length that string.length must be greater than.
|
|
12
|
-
* @returns true if string.length is greater than config.value, false if not.
|
|
13
|
-
*/
|
|
14
|
-
const mustBeLongerThan = (string, config) => {
|
|
15
|
-
if (!string) {
|
|
16
|
-
// null, undefined and empty strings should be picked up by the required flag
|
|
17
|
-
// and not considered here as they would be valid for optional fields.
|
|
18
|
-
return true;
|
|
19
|
-
}
|
|
20
|
-
return string.length > config.value;
|
|
21
|
-
};
|
|
22
|
-
var _default = exports.default = mustBeLongerThan;
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtdXN0QmVMb25nZXJUaGFuIiwic3RyaW5nIiwiY29uZmlnIiwibGVuZ3RoIiwidmFsdWUiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3V0aWxzL1ZhbGlkYXRlL2FkZGl0aW9uYWwvbXVzdEJlTG9uZ2VyVGhhbi5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEZ1bmN0aW9uIHJldHVybnMgdHJ1ZSBpZiB0aGUgc3RyaW5nIHBhcmFtZXRlciBpcyBsb25nZXIgdGhhbiBhIGdpdmVuIGxlbmd0aCwgZmFsc2VcbiAqIGlmIGl0IGlzIG5vdC5cbiAqIEBwYXJhbSB7c3RyaW5nfSBzdHJpbmcgLSB0aGUgc3RyaW5nIHRvIGNoZWNrIHRoZSBsZW5ndGggb2YuXG4gKiBAcGFyYW0ge251bWJlcn0gY29uZmlnLnZhbHVlIC0gdGhlIGxlbmd0aCB0aGF0IHN0cmluZy5sZW5ndGggbXVzdCBiZSBncmVhdGVyIHRoYW4uIFxuICogQHJldHVybnMgdHJ1ZSBpZiBzdHJpbmcubGVuZ3RoIGlzIGdyZWF0ZXIgdGhhbiBjb25maWcudmFsdWUsIGZhbHNlIGlmIG5vdC5cbiAqL1xuY29uc3QgbXVzdEJlTG9uZ2VyVGhhbiA9IChzdHJpbmcsIGNvbmZpZykgPT4ge1xuICBpZiAoIXN0cmluZykge1xuICAgIC8vIG51bGwsIHVuZGVmaW5lZCBhbmQgZW1wdHkgc3RyaW5ncyBzaG91bGQgYmUgcGlja2VkIHVwIGJ5IHRoZSByZXF1aXJlZCBmbGFnXG4gICAgLy8gYW5kIG5vdCBjb25zaWRlcmVkIGhlcmUgYXMgdGhleSB3b3VsZCBiZSB2YWxpZCBmb3Igb3B0aW9uYWwgZmllbGRzLlxuICAgIHJldHVybiB0cnVlO1xuICB9XG4gIHJldHVybiAoc3RyaW5nLmxlbmd0aCA+IGNvbmZpZy52YWx1ZSk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBtdXN0QmVMb25nZXJUaGFuO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLE1BQU1BLGdCQUFnQixHQUFHQSxDQUFDQyxNQUFNLEVBQUVDLE1BQU0sS0FBSztFQUMzQyxJQUFJLENBQUNELE1BQU0sRUFBRTtJQUNYO0lBQ0E7SUFDQSxPQUFPLElBQUk7RUFDYjtFQUNBLE9BQVFBLE1BQU0sQ0FBQ0UsTUFBTSxHQUFHRCxNQUFNLENBQUNFLEtBQUs7QUFDdEMsQ0FBQztBQUFDLElBQUFDLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFQLGdCQUFnQiIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _mustBeLongerThan = _interopRequireDefault(require("./mustBeLongerThan"));
|
|
4
|
-
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
5
|
-
describe('utils', () => {
|
|
6
|
-
describe('Validate', () => {
|
|
7
|
-
describe('additional', () => {
|
|
8
|
-
describe('mustBeLongerThan', () => {
|
|
9
|
-
test('should return true given a string longer than the given length', () => {
|
|
10
|
-
const result = (0, _mustBeLongerThan.default)('test', {
|
|
11
|
-
value: 3
|
|
12
|
-
});
|
|
13
|
-
expect(result).toEqual(true);
|
|
14
|
-
});
|
|
15
|
-
test('should return false given a string shorter than the given length', () => {
|
|
16
|
-
const result = (0, _mustBeLongerThan.default)('to', {
|
|
17
|
-
value: 3
|
|
18
|
-
});
|
|
19
|
-
expect(result).toEqual(false);
|
|
20
|
-
});
|
|
21
|
-
test('should return false given a string equal to the given length', () => {
|
|
22
|
-
const result = (0, _mustBeLongerThan.default)('dog', {
|
|
23
|
-
value: 3
|
|
24
|
-
});
|
|
25
|
-
expect(result).toEqual(false);
|
|
26
|
-
});
|
|
27
|
-
test('should return true when string is undefined', () => {
|
|
28
|
-
const result = (0, _mustBeLongerThan.default)(undefined, {
|
|
29
|
-
value: 3
|
|
30
|
-
});
|
|
31
|
-
expect(result).toEqual(true);
|
|
32
|
-
});
|
|
33
|
-
test('should return true when string is empty', () => {
|
|
34
|
-
const result = (0, _mustBeLongerThan.default)('', {
|
|
35
|
-
value: 3
|
|
36
|
-
});
|
|
37
|
-
expect(result).toEqual(true);
|
|
38
|
-
});
|
|
39
|
-
test('should return true when string is null', () => {
|
|
40
|
-
const result = (0, _mustBeLongerThan.default)(null, {
|
|
41
|
-
value: 3
|
|
42
|
-
});
|
|
43
|
-
expect(result).toEqual(true);
|
|
44
|
-
});
|
|
45
|
-
});
|
|
46
|
-
});
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfbXVzdEJlTG9uZ2VyVGhhbiIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiZSIsIl9fZXNNb2R1bGUiLCJkZWZhdWx0IiwiZGVzY3JpYmUiLCJ0ZXN0IiwicmVzdWx0IiwibXVzdEJlTG9uZ2VyVGhhbiIsInZhbHVlIiwiZXhwZWN0IiwidG9FcXVhbCIsInVuZGVmaW5lZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy91dGlscy9WYWxpZGF0ZS9hZGRpdGlvbmFsL211c3RCZUxvbmdlclRoYW4udGVzdC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgbXVzdEJlTG9uZ2VyVGhhbiBmcm9tICcuL211c3RCZUxvbmdlclRoYW4nO1xuXG5kZXNjcmliZSgndXRpbHMnLCAoKSA9PiB7XG4gIGRlc2NyaWJlKCdWYWxpZGF0ZScsICgpID0+IHtcbiAgICBkZXNjcmliZSgnYWRkaXRpb25hbCcsICgpID0+IHtcbiAgICAgIGRlc2NyaWJlKCdtdXN0QmVMb25nZXJUaGFuJywgKCkgPT4ge1xuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgZ2l2ZW4gYSBzdHJpbmcgbG9uZ2VyIHRoYW4gdGhlIGdpdmVuIGxlbmd0aCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMb25nZXJUaGFuKCd0ZXN0Jywge3ZhbHVlOiAzfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbCh0cnVlKTtcbiAgICAgICAgfSk7XG5cbiAgICAgICAgdGVzdCgnc2hvdWxkIHJldHVybiBmYWxzZSBnaXZlbiBhIHN0cmluZyBzaG9ydGVyIHRoYW4gdGhlIGdpdmVuIGxlbmd0aCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMb25nZXJUaGFuKCd0bycsIHt2YWx1ZTogM30pO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwoZmFsc2UpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIGZhbHNlIGdpdmVuIGEgc3RyaW5nIGVxdWFsIHRvIHRoZSBnaXZlbiBsZW5ndGgnLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlTG9uZ2VyVGhhbignZG9nJywge3ZhbHVlOiAzfSk7XG4gICAgICAgICAgZXhwZWN0KHJlc3VsdCkudG9FcXVhbChmYWxzZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSB3aGVuIHN0cmluZyBpcyB1bmRlZmluZWQnLCAoKSA9PiB7XG4gICAgICAgICAgY29uc3QgcmVzdWx0ID0gbXVzdEJlTG9uZ2VyVGhhbih1bmRlZmluZWQsIHt2YWx1ZTogM30pO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRlc3QoJ3Nob3VsZCByZXR1cm4gdHJ1ZSB3aGVuIHN0cmluZyBpcyBlbXB0eScsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMb25nZXJUaGFuKCcnLCB7dmFsdWU6IDN9KTtcbiAgICAgICAgICBleHBlY3QocmVzdWx0KS50b0VxdWFsKHRydWUpO1xuICAgICAgICB9KTtcblxuICAgICAgICB0ZXN0KCdzaG91bGQgcmV0dXJuIHRydWUgd2hlbiBzdHJpbmcgaXMgbnVsbCcsICgpID0+IHtcbiAgICAgICAgICBjb25zdCByZXN1bHQgPSBtdXN0QmVMb25nZXJUaGFuKG51bGwsIHt2YWx1ZTogM30pO1xuICAgICAgICAgIGV4cGVjdChyZXN1bHQpLnRvRXF1YWwodHJ1ZSk7XG4gICAgICAgIH0pO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXSwibWFwcGluZ3MiOiI7O0FBQUEsSUFBQUEsaUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUFrRCxTQUFBRCx1QkFBQUUsQ0FBQSxXQUFBQSxDQUFBLElBQUFBLENBQUEsQ0FBQUMsVUFBQSxHQUFBRCxDQUFBLEtBQUFFLE9BQUEsRUFBQUYsQ0FBQTtBQUVsREcsUUFBUSxDQUFDLE9BQU8sRUFBRSxNQUFNO0VBQ3RCQSxRQUFRLENBQUMsVUFBVSxFQUFFLE1BQU07SUFDekJBLFFBQVEsQ0FBQyxZQUFZLEVBQUUsTUFBTTtNQUMzQkEsUUFBUSxDQUFDLGtCQUFrQixFQUFFLE1BQU07UUFDakNDLElBQUksQ0FBQyxnRUFBZ0UsRUFBRSxNQUFNO1VBQzNFLE1BQU1DLE1BQU0sR0FBRyxJQUFBQyx5QkFBZ0IsRUFBQyxNQUFNLEVBQUU7WUFBQ0MsS0FBSyxFQUFFO1VBQUMsQ0FBQyxDQUFDO1VBQ25EQyxNQUFNLENBQUNILE1BQU0sQ0FBQyxDQUFDSSxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQzlCLENBQUMsQ0FBQztRQUVGTCxJQUFJLENBQUMsa0VBQWtFLEVBQUUsTUFBTTtVQUM3RSxNQUFNQyxNQUFNLEdBQUcsSUFBQUMseUJBQWdCLEVBQUMsSUFBSSxFQUFFO1lBQUNDLEtBQUssRUFBRTtVQUFDLENBQUMsQ0FBQztVQUNqREMsTUFBTSxDQUFDSCxNQUFNLENBQUMsQ0FBQ0ksT0FBTyxDQUFDLEtBQUssQ0FBQztRQUMvQixDQUFDLENBQUM7UUFFRkwsSUFBSSxDQUFDLDhEQUE4RCxFQUFFLE1BQU07VUFDekUsTUFBTUMsTUFBTSxHQUFHLElBQUFDLHlCQUFnQixFQUFDLEtBQUssRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBQyxDQUFDLENBQUM7VUFDbERDLE1BQU0sQ0FBQ0gsTUFBTSxDQUFDLENBQUNJLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDL0IsQ0FBQyxDQUFDO1FBRUZMLElBQUksQ0FBQyw2Q0FBNkMsRUFBRSxNQUFNO1VBQ3hELE1BQU1DLE1BQU0sR0FBRyxJQUFBQyx5QkFBZ0IsRUFBQ0ksU0FBUyxFQUFFO1lBQUNILEtBQUssRUFBRTtVQUFDLENBQUMsQ0FBQztVQUN0REMsTUFBTSxDQUFDSCxNQUFNLENBQUMsQ0FBQ0ksT0FBTyxDQUFDLElBQUksQ0FBQztRQUM5QixDQUFDLENBQUM7UUFFRkwsSUFBSSxDQUFDLHlDQUF5QyxFQUFFLE1BQU07VUFDcEQsTUFBTUMsTUFBTSxHQUFHLElBQUFDLHlCQUFnQixFQUFDLEVBQUUsRUFBRTtZQUFDQyxLQUFLLEVBQUU7VUFBQyxDQUFDLENBQUM7VUFDL0NDLE1BQU0sQ0FBQ0gsTUFBTSxDQUFDLENBQUNJLE9BQU8sQ0FBQyxJQUFJLENBQUM7UUFDOUIsQ0FBQyxDQUFDO1FBRUZMLElBQUksQ0FBQyx3Q0FBd0MsRUFBRSxNQUFNO1VBQ25ELE1BQU1DLE1BQU0sR0FBRyxJQUFBQyx5QkFBZ0IsRUFBQyxJQUFJLEVBQUU7WUFBQ0MsS0FBSyxFQUFFO1VBQUMsQ0FBQyxDQUFDO1VBQ2pEQyxNQUFNLENBQUNILE1BQU0sQ0FBQyxDQUFDSSxPQUFPLENBQUMsSUFBSSxDQUFDO1FBQzlCLENBQUMsQ0FBQztNQUNKLENBQUMsQ0FBQztJQUNKLENBQUMsQ0FBQztFQUNKLENBQUMsQ0FBQztBQUNKLENBQUMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
/**
|
|
8
|
-
* Checks if a string contains only numberical characters.
|
|
9
|
-
* An optional flag in config can be used to allow commas.
|
|
10
|
-
* @param {*} value The value to check for only numerical characters.
|
|
11
|
-
* @param {object} config The config of the validation check.
|
|
12
|
-
* @returns true if value passes the regex, false if not.
|
|
13
|
-
*/
|
|
14
|
-
const mustBeNumbersOnly = (value, config) => {
|
|
15
|
-
if (!value) {
|
|
16
|
-
// null, undefined and empty numbers should be picked up by the required flag
|
|
17
|
-
// and not considered here as they would be valid for optional fields.
|
|
18
|
-
return true;
|
|
19
|
-
}
|
|
20
|
-
const regex = config !== null && config !== void 0 && config.allowCommas ? /^[0-9,]*\.?[0-9]*$/ : /^[0-9]*\.?[0-9]*$/;
|
|
21
|
-
return regex.test(value);
|
|
22
|
-
};
|
|
23
|
-
var _default = exports.default = mustBeNumbersOnly;
|
|
24
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtdXN0QmVOdW1iZXJzT25seSIsInZhbHVlIiwiY29uZmlnIiwicmVnZXgiLCJhbGxvd0NvbW1hcyIsInRlc3QiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJkZWZhdWx0Il0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3V0aWxzL1ZhbGlkYXRlL2FkZGl0aW9uYWwvbXVzdEJlTnVtYmVyc09ubHkuanMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBDaGVja3MgaWYgYSBzdHJpbmcgY29udGFpbnMgb25seSBudW1iZXJpY2FsIGNoYXJhY3RlcnMuXG4gKiBBbiBvcHRpb25hbCBmbGFnIGluIGNvbmZpZyBjYW4gYmUgdXNlZCB0byBhbGxvdyBjb21tYXMuXG4gKiBAcGFyYW0geyp9IHZhbHVlIFRoZSB2YWx1ZSB0byBjaGVjayBmb3Igb25seSBudW1lcmljYWwgY2hhcmFjdGVycy5cbiAqIEBwYXJhbSB7b2JqZWN0fSBjb25maWcgVGhlIGNvbmZpZyBvZiB0aGUgdmFsaWRhdGlvbiBjaGVjay5cbiAqIEByZXR1cm5zIHRydWUgaWYgdmFsdWUgcGFzc2VzIHRoZSByZWdleCwgZmFsc2UgaWYgbm90LlxuICovXG4gY29uc3QgbXVzdEJlTnVtYmVyc09ubHkgPSAodmFsdWUsIGNvbmZpZykgPT4ge1xuICAgIGlmICghdmFsdWUpIHtcbiAgICAgIC8vIG51bGwsIHVuZGVmaW5lZCBhbmQgZW1wdHkgbnVtYmVycyBzaG91bGQgYmUgcGlja2VkIHVwIGJ5IHRoZSByZXF1aXJlZCBmbGFnXG4gICAgICAvLyBhbmQgbm90IGNvbnNpZGVyZWQgaGVyZSBhcyB0aGV5IHdvdWxkIGJlIHZhbGlkIGZvciBvcHRpb25hbCBmaWVsZHMuXG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgY29uc3QgcmVnZXggPSBjb25maWc/LmFsbG93Q29tbWFzID9cbiAgICAgIC9eWzAtOSxdKlxcLj9bMC05XSokLyA6XG4gICAgICAvXlswLTldKlxcLj9bMC05XSokLztcbiAgICByZXR1cm4gcmVnZXgudGVzdCh2YWx1ZSk7XG4gIH07XG4gIFxuICBleHBvcnQgZGVmYXVsdCBtdXN0QmVOdW1iZXJzT25seTtcbiAgIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNDLE1BQU1BLGlCQUFpQixHQUFHQSxDQUFDQyxLQUFLLEVBQUVDLE1BQU0sS0FBSztFQUMxQyxJQUFJLENBQUNELEtBQUssRUFBRTtJQUNWO0lBQ0E7SUFDQSxPQUFPLElBQUk7RUFDYjtFQUNBLE1BQU1FLEtBQUssR0FBR0QsTUFBTSxhQUFOQSxNQUFNLGVBQU5BLE1BQU0sQ0FBRUUsV0FBVyxHQUMvQixvQkFBb0IsR0FDcEIsbUJBQW1CO0VBQ3JCLE9BQU9ELEtBQUssQ0FBQ0UsSUFBSSxDQUFDSixLQUFLLENBQUM7QUFDMUIsQ0FBQztBQUFDLElBQUFLLFFBQUEsR0FBQUMsT0FBQSxDQUFBQyxPQUFBLEdBRWFSLGlCQUFpQiIsImlnbm9yZUxpc3QiOltdfQ==
|