@ukhomeoffice/cop-react-form-renderer 4.18.0 → 5.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/dist/components/CheckYourAnswers/Answer.js +1 -14
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +19 -57
- package/dist/components/CheckYourAnswers/index.js +0 -3
- package/dist/components/CollectionPage/CollectionPage.js +8 -38
- package/dist/components/CollectionPage/index.js +0 -3
- package/dist/components/FormComponent/Collection.js +13 -54
- package/dist/components/FormComponent/Container.js +6 -30
- package/dist/components/FormComponent/FormComponent.js +14 -57
- package/dist/components/FormComponent/helpers/addLabel.js +4 -7
- package/dist/components/FormComponent/helpers/getComponentDisabled.js +0 -4
- package/dist/components/FormComponent/helpers/getComponentDisabled.test.js +0 -2
- package/dist/components/FormComponent/helpers/getComponentError.js +0 -6
- package/dist/components/FormComponent/helpers/getComponentError.test.js +0 -2
- package/dist/components/FormComponent/helpers/index.js +0 -4
- package/dist/components/FormComponent/index.js +0 -3
- package/dist/components/FormPage/FormPage.js +14 -45
- package/dist/components/FormPage/index.js +0 -3
- package/dist/components/FormRenderer/FormRenderer.js +106 -189
- package/dist/components/FormRenderer/handlers/cyaAction.js +0 -5
- package/dist/components/FormRenderer/handlers/getPageId.js +0 -2
- package/dist/components/FormRenderer/handlers/getPageId.test.js +1 -2
- package/dist/components/FormRenderer/handlers/handlers.test.js +1 -18
- package/dist/components/FormRenderer/handlers/index.js +0 -5
- package/dist/components/FormRenderer/handlers/navigate.js +0 -5
- package/dist/components/FormRenderer/handlers/submissionError.js +0 -2
- package/dist/components/FormRenderer/helpers/canActionProceed.js +0 -3
- package/dist/components/FormRenderer/helpers/canActionProceed.test.js +1 -3
- package/dist/components/FormRenderer/helpers/canCYASubmit.js +0 -2
- package/dist/components/FormRenderer/helpers/canCYASubmit.test.js +1 -5
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +0 -5
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +1 -2
- package/dist/components/FormRenderer/helpers/getCYA.js +0 -6
- package/dist/components/FormRenderer/helpers/getCYA.test.js +1 -3
- package/dist/components/FormRenderer/helpers/getFormState.js +0 -5
- package/dist/components/FormRenderer/helpers/getFormState.test.js +1 -3
- package/dist/components/FormRenderer/helpers/getNextPageId.js +0 -25
- package/dist/components/FormRenderer/helpers/getNextPageId.test.js +1 -4
- package/dist/components/FormRenderer/helpers/getPage.js +0 -5
- package/dist/components/FormRenderer/helpers/getPage.test.js +1 -3
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +0 -6
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +1 -3
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +0 -10
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +0 -6
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +6 -20
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +3 -8
- package/dist/components/FormRenderer/helpers/index.js +1 -11
- package/dist/components/FormRenderer/index.js +0 -3
- package/dist/components/PageActions/ActionButton.js +2 -17
- package/dist/components/PageActions/PageActions.js +3 -10
- package/dist/components/PageActions/index.js +0 -3
- package/dist/components/SummaryList/GroupAction.js +3 -24
- package/dist/components/SummaryList/RowAction.js +3 -23
- package/dist/components/SummaryList/SummaryList.js +6 -28
- package/dist/components/SummaryList/SummaryListRow.js +4 -8
- package/dist/components/SummaryList/SummaryListTitleRow.js +2 -7
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +0 -3
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.test.js +0 -6
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +0 -3
- package/dist/components/SummaryList/helpers/getRowActionAttributes.test.js +0 -6
- package/dist/components/SummaryList/helpers/index.js +0 -2
- package/dist/components/SummaryList/index.js +0 -3
- package/dist/components/TaskList/Task.js +7 -29
- package/dist/components/TaskList/TaskList.js +12 -33
- package/dist/components/TaskList/TaskState.js +2 -10
- package/dist/components/TaskList/index.js +0 -3
- package/dist/components/index.js +0 -6
- package/dist/context/HooksContext/HooksContext.js +14 -34
- package/dist/context/HooksContext/index.js +0 -5
- package/dist/context/ValidationContext/ValidationContext.js +8 -34
- package/dist/context/ValidationContext/index.js +0 -5
- package/dist/context/index.js +0 -3
- package/dist/hooks/index.js +0 -9
- package/dist/hooks/useAxios.js +8 -25
- package/dist/hooks/useGetRequest.js +13 -47
- package/dist/hooks/useHooks.js +2 -4
- package/dist/hooks/useRefData.js +8 -37
- package/dist/hooks/useValidation.js +2 -4
- package/dist/index.js +0 -6
- package/dist/models/PageAction.js +0 -3
- package/dist/models/TaskStates.js +0 -3
- package/dist/models/index.js +0 -9
- package/dist/utils/CheckYourAnswers/getCYAAction.js +1 -9
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +0 -10
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +0 -8
- package/dist/utils/CheckYourAnswers/getCYARow.js +1 -10
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +2 -20
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +0 -18
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +0 -20
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +0 -13
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +2 -22
- package/dist/utils/CheckYourAnswers/index.js +1 -3
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +2 -11
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +0 -11
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.js +0 -6
- package/dist/utils/CollectionPage/index.js +1 -5
- package/dist/utils/CollectionPage/mergeCollectionPages.js +1 -12
- package/dist/utils/Component/cleanAttributes.js +1 -8
- package/dist/utils/Component/elevateNestedComponents.js +0 -3
- package/dist/utils/Component/getComponent.js +4 -68
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +6 -10
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +10 -28
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +6 -33
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +10 -27
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +4 -10
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +4 -21
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +4 -22
- package/dist/utils/Component/getComponentTests/getComponent.heading.test.js +3 -7
- package/dist/utils/Component/getComponentTests/getComponent.html.test.js +4 -10
- package/dist/utils/Component/getComponentTests/getComponent.insetText.test.js +3 -7
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +6 -15
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +4 -21
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +6 -33
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +4 -21
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +4 -21
- package/dist/utils/Component/getComponentTests/getComponent.textarea.test.js +4 -21
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +10 -29
- package/dist/utils/Component/getComponentTests/getComponent.unknown.test.js +1 -2
- package/dist/utils/Component/getComponentTests/getComponent.warningText.test.js +3 -7
- package/dist/utils/Component/getDefaultValue.js +0 -7
- package/dist/utils/Component/index.js +0 -9
- package/dist/utils/Component/isEditable.js +1 -4
- package/dist/utils/Component/showComponent.js +1 -8
- package/dist/utils/Component/wrapInFormGroup.js +0 -7
- package/dist/utils/Condition/index.js +0 -5
- package/dist/utils/Condition/meetsAllConditions.js +0 -9
- package/dist/utils/Condition/meetsCondition.js +7 -19
- package/dist/utils/Condition/meetsOneCondition.js +1 -9
- package/dist/utils/Condition/setupConditions.js +0 -12
- package/dist/utils/Container/getEditableComponents.js +0 -7
- package/dist/utils/Container/index.js +0 -5
- package/dist/utils/Container/setupNesting.js +0 -11
- package/dist/utils/Container/showContainer.js +9 -18
- package/dist/utils/Data/applyFormula.js +2 -28
- package/dist/utils/Data/getAutocompleteSource.js +1 -4
- package/dist/utils/Data/getDataPath.js +3 -17
- package/dist/utils/Data/getOptions.js +0 -9
- package/dist/utils/Data/getSourceData.js +4 -19
- package/dist/utils/Data/index.js +1 -11
- package/dist/utils/Data/refDataToOptions.js +1 -12
- package/dist/utils/Data/setDataItem.js +0 -5
- package/dist/utils/Data/setupFormData.js +2 -20
- package/dist/utils/Data/setupRefDataUrlForComponent.js +0 -14
- package/dist/utils/FormPage/getFormPage.js +0 -15
- package/dist/utils/FormPage/getFormPages.js +0 -8
- package/dist/utils/FormPage/getPageActions.js +3 -18
- package/dist/utils/FormPage/getParagraphFromText.js +0 -3
- package/dist/utils/FormPage/index.js +0 -6
- package/dist/utils/FormPage/showFormPage.js +9 -18
- package/dist/utils/FormPage/showFormPageCYA.js +0 -5
- package/dist/utils/FormPage/useComponent.js +3 -18
- package/dist/utils/Format/formatData.js +0 -5
- package/dist/utils/Format/formatDataForComponent.js +1 -6
- package/dist/utils/Format/formatDataForForm.js +0 -8
- package/dist/utils/Format/formatDataForPage.js +1 -5
- package/dist/utils/Format/index.js +1 -6
- package/dist/utils/Hub/getFormHub.js +0 -8
- package/dist/utils/Hub/index.js +1 -3
- package/dist/utils/Meta/documents/getDocuments.js +1 -4
- package/dist/utils/Meta/documents/getDocuments.test.js +0 -9
- package/dist/utils/Meta/documents/index.js +1 -5
- package/dist/utils/Meta/documents/setDocumentForField.js +0 -11
- package/dist/utils/Meta/documents/setDocumentForField.test.js +0 -11
- package/dist/utils/Meta/index.js +2 -6
- package/dist/utils/Operate/checkValueIsTruthy.js +1 -7
- package/dist/utils/Operate/getIndexOfMatchingValueIn.js +7 -21
- package/dist/utils/Operate/index.js +0 -3
- package/dist/utils/Operate/persistValueInFormData.js +1 -8
- package/dist/utils/Operate/runPageOperations.js +3 -18
- package/dist/utils/Operate/setValueInFormData.js +2 -7
- package/dist/utils/Operate/shouldRun.js +1 -14
- package/dist/utils/Validate/additional/index.js +1 -18
- package/dist/utils/Validate/additional/index.test.js +0 -6
- package/dist/utils/Validate/additional/mustBeAfter.js +3 -8
- package/dist/utils/Validate/additional/mustBeAfter.test.js +0 -4
- package/dist/utils/Validate/additional/mustBeBefore.js +3 -8
- package/dist/utils/Validate/additional/mustBeBefore.test.js +0 -4
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +5 -16
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +0 -7
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +3 -12
- package/dist/utils/Validate/additional/mustBeInTheFuture.test.js +0 -3
- package/dist/utils/Validate/additional/mustBeInThePast.js +5 -13
- package/dist/utils/Validate/additional/mustBeInThePast.test.js +0 -3
- package/dist/utils/Validate/additional/mustBeLessThan.js +0 -3
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +0 -2
- package/dist/utils/Validate/additional/mustBeLongerThan.js +0 -3
- package/dist/utils/Validate/additional/mustBeLongerThan.test.js +0 -2
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +0 -4
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +0 -2
- package/dist/utils/Validate/additional/mustBeShorterThan.js +0 -3
- package/dist/utils/Validate/additional/mustBeShorterThan.test.js +0 -2
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +0 -5
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +0 -4
- package/dist/utils/Validate/additional/utils.js +8 -24
- package/dist/utils/Validate/index.js +1 -9
- package/dist/utils/Validate/validateCollection.js +0 -9
- package/dist/utils/Validate/validateComponent.js +2 -35
- package/dist/utils/Validate/validateContainer.js +0 -13
- package/dist/utils/Validate/validateDate.js +4 -36
- package/dist/utils/Validate/validateEmail.js +1 -7
- package/dist/utils/Validate/validatePage.js +0 -15
- package/dist/utils/Validate/validateRegex.js +0 -10
- package/dist/utils/Validate/validateRequired.js +0 -8
- package/dist/utils/Validate/validateTime.js +3 -20
- package/dist/utils/index.js +0 -19
- package/package.json +50 -34
- package/dist/components/CheckYourAnswers/Answer.test.js +0 -95
- package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +0 -410
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +0 -680
- package/dist/components/CollectionPage/CollectionPage.test.js +0 -428
- package/dist/components/FormComponent/Collection.test.js +0 -381
- package/dist/components/FormComponent/Container.test.js +0 -423
- package/dist/components/FormComponent/FormComponent.stories.mdx +0 -184
- package/dist/components/FormComponent/FormComponent.test.js +0 -264
- package/dist/components/FormPage/FormPage.stories.mdx +0 -131
- package/dist/components/FormPage/FormPage.test.js +0 -368
- package/dist/components/FormRenderer/FormRenderer.stories.mdx +0 -183
- package/dist/components/FormRenderer/FormRenderer.test.js +0 -1006
- package/dist/components/PageActions/ActionButton.test.js +0 -116
- package/dist/components/PageActions/PageActions.stories.mdx +0 -74
- package/dist/components/PageActions/PageActions.test.js +0 -157
- package/dist/components/SummaryList/GroupAction.test.js +0 -94
- package/dist/components/SummaryList/RowAction.test.js +0 -94
- package/dist/components/SummaryList/SummaryList.stories.mdx +0 -90
- package/dist/components/SummaryList/SummaryList.test.js +0 -361
- package/dist/components/TaskList/Task.test.js +0 -194
- package/dist/components/TaskList/TaskList.stories.mdx +0 -164
- package/dist/components/TaskList/TaskList.test.js +0 -334
- package/dist/components/TaskList/TaskState.test.js +0 -104
- package/dist/context/HooksContext/HooksContext.test.js +0 -60
- package/dist/context/ValidationContext/ValidationContext.test.js +0 -98
- 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/setupTests.js +0 -59
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +0 -139
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +0 -76
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +0 -59
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +0 -256
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +0 -77
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +0 -199
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +0 -170
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +0 -323
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +0 -281
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +0 -64
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +0 -41
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +0 -54
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +0 -131
- package/dist/utils/Component/cleanAttributes.test.js +0 -69
- package/dist/utils/Component/elevateNestedComponents.test.js +0 -92
- package/dist/utils/Component/getDefaultValue.test.js +0 -53
- package/dist/utils/Component/isEditable.test.js +0 -42
- package/dist/utils/Component/showComponent.test.js +0 -157
- package/dist/utils/Condition/meetsAllConditions.test.js +0 -62
- package/dist/utils/Condition/meetsCondition.test.js +0 -391
- package/dist/utils/Condition/meetsOneCondition.test.js +0 -101
- package/dist/utils/Condition/setupConditions.test.js +0 -35
- package/dist/utils/Container/getEditableComponents.test.js +0 -146
- package/dist/utils/Container/setupNesting.test.js +0 -92
- package/dist/utils/Container/showContainer.test.js +0 -179
- package/dist/utils/Data/applyFormula.test.js +0 -264
- package/dist/utils/Data/getAutocompleteSource.test.js +0 -146
- package/dist/utils/Data/getDataPath.test.js +0 -52
- package/dist/utils/Data/getOptions.test.js +0 -71
- package/dist/utils/Data/getSourceData.test.js +0 -141
- package/dist/utils/Data/refDataToOptions.test.js +0 -197
- package/dist/utils/Data/setDataItem.test.js +0 -112
- package/dist/utils/Data/setupFormData.test.js +0 -276
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +0 -133
- package/dist/utils/FormPage/getFormPage.test.js +0 -205
- package/dist/utils/FormPage/getFormPages.test.js +0 -98
- package/dist/utils/FormPage/getPageActions.test.js +0 -89
- package/dist/utils/FormPage/getParagraphFromText.test.js +0 -29
- package/dist/utils/FormPage/showFormPage.test.js +0 -182
- package/dist/utils/FormPage/showFormPageCYA.test.js +0 -30
- package/dist/utils/FormPage/useComponent.test.js +0 -169
- package/dist/utils/Format/formatData.test.js +0 -46
- package/dist/utils/Format/formatDataForComponent.test.js +0 -161
- package/dist/utils/Format/formatDataForForm.test.js +0 -78
- package/dist/utils/Format/formatDataForPage.test.js +0 -96
- package/dist/utils/Hub/getFormHub.test.js +0 -107
- package/dist/utils/Operate/checkValueIsTruthy.test.js +0 -44
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +0 -159
- package/dist/utils/Operate/persistValueInFormData.test.js +0 -106
- package/dist/utils/Operate/runPageOperations.test.js +0 -107
- package/dist/utils/Operate/setValueInFormData.test.js +0 -46
- package/dist/utils/Operate/shouldRun.test.js +0 -69
- package/dist/utils/Validate/validateCollection.test.js +0 -74
- package/dist/utils/Validate/validateComponent.test.js +0 -267
- package/dist/utils/Validate/validateContainer.test.js +0 -81
- package/dist/utils/Validate/validateDate.test.js +0 -118
- package/dist/utils/Validate/validateEmail.test.js +0 -57
- package/dist/utils/Validate/validatePage.test.js +0 -383
- package/dist/utils/Validate/validateRegex.test.js +0 -41
- package/dist/utils/Validate/validateRequired.test.js +0 -62
- package/dist/utils/Validate/validateTime.test.js +0 -61
|
@@ -4,13 +4,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _models = require("../../models");
|
|
9
|
-
|
|
10
8
|
var _FormPage = _interopRequireDefault(require("../FormPage"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Local imports
|
|
15
11
|
|
|
16
12
|
/**
|
|
@@ -31,18 +27,14 @@ var getFormHub = function getFormHub(type, hub, components, formData) {
|
|
|
31
27
|
if (hub.format === _models.HubFormats.CYA) {
|
|
32
28
|
return _models.HubFormats.CYA;
|
|
33
29
|
}
|
|
34
|
-
|
|
35
30
|
if (hub.components) {
|
|
36
31
|
return _FormPage.default.get(hub, components, formData);
|
|
37
32
|
}
|
|
38
33
|
}
|
|
39
|
-
|
|
40
34
|
if (type === _models.FormTypes.TASK || type === _models.FormTypes.FORM_WITH_TASK) {
|
|
41
35
|
return _models.HubFormats.TASK;
|
|
42
36
|
}
|
|
43
|
-
|
|
44
37
|
return undefined;
|
|
45
38
|
};
|
|
46
|
-
|
|
47
39
|
var _default = getFormHub;
|
|
48
40
|
exports.default = _default;
|
package/dist/utils/Hub/index.js
CHANGED
|
@@ -4,12 +4,10 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _getFormHub = _interopRequireDefault(require("./getFormHub"));
|
|
9
|
-
|
|
10
8
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
-
|
|
12
9
|
// Local imports
|
|
10
|
+
|
|
13
11
|
var Hub = {
|
|
14
12
|
get: _getFormHub.default
|
|
15
13
|
};
|
|
@@ -4,15 +4,12 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _constants = require("../constants");
|
|
9
|
-
|
|
10
8
|
// Local imports
|
|
9
|
+
|
|
11
10
|
var getDocuments = function getDocuments(formData) {
|
|
12
11
|
var _formData$META_PROPER;
|
|
13
|
-
|
|
14
12
|
return (formData === null || formData === void 0 ? void 0 : (_formData$META_PROPER = formData[_constants.META_PROPERTY]) === null || _formData$META_PROPER === void 0 ? void 0 : _formData$META_PROPER[_constants.META_DOCUMENTS_PROPERTY]) || [];
|
|
15
13
|
};
|
|
16
|
-
|
|
17
14
|
var _default = getDocuments;
|
|
18
15
|
exports.default = _default;
|
|
@@ -1,13 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _constants = require("../constants");
|
|
4
|
-
|
|
5
4
|
var _getDocuments = _interopRequireDefault(require("./getDocuments"));
|
|
6
|
-
|
|
7
5
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
8
|
-
|
|
9
6
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
10
|
-
|
|
11
7
|
describe('Utils.Meta.documents.get', function () {
|
|
12
8
|
it('should return an empty array if formData is null', function () {
|
|
13
9
|
expect((0, _getDocuments.default)(null)).toEqual([]);
|
|
@@ -17,17 +13,14 @@ describe('Utils.Meta.documents.get', function () {
|
|
|
17
13
|
});
|
|
18
14
|
it('should return an empty array if the meta property is undefined', function () {
|
|
19
15
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, undefined);
|
|
20
|
-
|
|
21
16
|
expect((0, _getDocuments.default)(FORM_DATA)).toEqual([]);
|
|
22
17
|
});
|
|
23
18
|
it('should return an empty array if the meta property contains no documents property', function () {
|
|
24
19
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, {});
|
|
25
|
-
|
|
26
20
|
expect((0, _getDocuments.default)(FORM_DATA)).toEqual([]);
|
|
27
21
|
});
|
|
28
22
|
it('should return an empty array if the meta.documents property is undefined', function () {
|
|
29
23
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, undefined));
|
|
30
|
-
|
|
31
24
|
expect((0, _getDocuments.default)(FORM_DATA)).toEqual([]);
|
|
32
25
|
});
|
|
33
26
|
it('should return the meta.documents property if it exists', function () {
|
|
@@ -35,9 +28,7 @@ describe('Utils.Meta.documents.get', function () {
|
|
|
35
28
|
field: 'alpha',
|
|
36
29
|
url: 'http://alpha-bravo.com/files/charlie'
|
|
37
30
|
}];
|
|
38
|
-
|
|
39
31
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, DOCUMENTS));
|
|
40
|
-
|
|
41
32
|
expect((0, _getDocuments.default)(FORM_DATA)).toEqual(DOCUMENTS);
|
|
42
33
|
});
|
|
43
34
|
});
|
|
@@ -4,16 +4,12 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _constants = require("../constants");
|
|
9
|
-
|
|
10
8
|
var _setDocumentForField = _interopRequireDefault(require("./setDocumentForField"));
|
|
11
|
-
|
|
12
9
|
var _getDocuments = _interopRequireDefault(require("./getDocuments"));
|
|
13
|
-
|
|
14
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
-
|
|
16
11
|
// Local imports
|
|
12
|
+
|
|
17
13
|
var documents = {
|
|
18
14
|
setForField: _setDocumentForField.default,
|
|
19
15
|
get: _getDocuments.default,
|
|
@@ -4,37 +4,26 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _constants = require("../constants");
|
|
9
|
-
|
|
10
8
|
var _getDocuments = _interopRequireDefault(require("./getDocuments"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
15
|
-
|
|
16
11
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
17
|
-
|
|
18
12
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
19
|
-
|
|
20
13
|
var setDocumentForField = function setDocumentForField(document, formData, field, allowMultiple) {
|
|
21
14
|
var documents = (0, _getDocuments.default)(formData);
|
|
22
|
-
|
|
23
15
|
if (!allowMultiple) {
|
|
24
16
|
documents = documents.filter(function (d) {
|
|
25
17
|
return d.field !== field;
|
|
26
18
|
});
|
|
27
19
|
}
|
|
28
|
-
|
|
29
20
|
if (document) {
|
|
30
21
|
documents.push(_objectSpread(_objectSpread({}, document), {}, {
|
|
31
22
|
field: field
|
|
32
23
|
}));
|
|
33
24
|
}
|
|
34
|
-
|
|
35
25
|
var existing = formData ? formData[_constants.META_PROPERTY] : undefined;
|
|
36
26
|
return _objectSpread(_objectSpread({}, existing), {}, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, documents));
|
|
37
27
|
};
|
|
38
|
-
|
|
39
28
|
var _default = setDocumentForField;
|
|
40
29
|
exports.default = _default;
|
|
@@ -1,13 +1,9 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _constants = require("../constants");
|
|
4
|
-
|
|
5
4
|
var _setDocumentForField = _interopRequireDefault(require("./setDocumentForField"));
|
|
6
|
-
|
|
7
5
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
8
|
-
|
|
9
6
|
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
10
|
-
|
|
11
7
|
describe('Utils.Meta.documents.add', function () {
|
|
12
8
|
var ALPHA_DOCUMENT = {
|
|
13
9
|
field: 'alpha',
|
|
@@ -22,7 +18,6 @@ describe('Utils.Meta.documents.add', function () {
|
|
|
22
18
|
});
|
|
23
19
|
it('should add a new document to the array', function () {
|
|
24
20
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
25
|
-
|
|
26
21
|
expect((0, _setDocumentForField.default)(BRAVO_DOCUMENT, FORM_DATA, BRAVO_DOCUMENT.field)).toEqual(_defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT, BRAVO_DOCUMENT]));
|
|
27
22
|
});
|
|
28
23
|
it('should replace an existing document with the same field', function () {
|
|
@@ -31,9 +26,7 @@ describe('Utils.Meta.documents.add', function () {
|
|
|
31
26
|
field: ALPHA_DOCUMENT.field,
|
|
32
27
|
url: NEW_URL
|
|
33
28
|
};
|
|
34
|
-
|
|
35
29
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
36
|
-
|
|
37
30
|
expect((0, _setDocumentForField.default)(NEW_ALPHA, FORM_DATA, NEW_ALPHA.field)).toEqual(_defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [NEW_ALPHA]));
|
|
38
31
|
});
|
|
39
32
|
it('should add a document with the same field if allowMultiple is true', function () {
|
|
@@ -42,19 +35,15 @@ describe('Utils.Meta.documents.add', function () {
|
|
|
42
35
|
field: ALPHA_DOCUMENT.field,
|
|
43
36
|
url: NEW_URL
|
|
44
37
|
};
|
|
45
|
-
|
|
46
38
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
47
|
-
|
|
48
39
|
expect((0, _setDocumentForField.default)(NEW_ALPHA, FORM_DATA, NEW_ALPHA.field, true)).toEqual(_defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT, NEW_ALPHA]));
|
|
49
40
|
});
|
|
50
41
|
it('should handle a null document being passed where a document with that field already exists', function () {
|
|
51
42
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
52
|
-
|
|
53
43
|
expect((0, _setDocumentForField.default)(null, FORM_DATA, ALPHA_DOCUMENT.field)).toEqual(_defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, []));
|
|
54
44
|
});
|
|
55
45
|
it('should handle a null document being passed where a document with that field does not already exist', function () {
|
|
56
46
|
var FORM_DATA = _defineProperty({}, _constants.META_PROPERTY, _defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
57
|
-
|
|
58
47
|
expect((0, _setDocumentForField.default)(null, FORM_DATA, BRAVO_DOCUMENT.field)).toEqual(_defineProperty({}, _constants.META_DOCUMENTS_PROPERTY, [ALPHA_DOCUMENT]));
|
|
59
48
|
});
|
|
60
49
|
});
|
package/dist/utils/Meta/index.js
CHANGED
|
@@ -3,19 +3,15 @@
|
|
|
3
3
|
Object.defineProperty(exports, "__esModule", {
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
|
-
exports.default =
|
|
7
|
-
|
|
6
|
+
exports.default = void 0;
|
|
8
7
|
var _constants = require("./constants");
|
|
9
|
-
|
|
10
8
|
var _documents = _interopRequireDefault(require("./documents"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Local imports
|
|
11
|
+
|
|
15
12
|
var Meta = {
|
|
16
13
|
documents: _documents.default,
|
|
17
14
|
name: _constants.META_PROPERTY
|
|
18
15
|
};
|
|
19
|
-
exports.Meta = Meta;
|
|
20
16
|
var _default = Meta;
|
|
21
17
|
exports.default = _default;
|
|
@@ -4,14 +4,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Global imports.
|
|
11
|
+
|
|
15
12
|
// Local imports.
|
|
16
13
|
|
|
17
14
|
/**
|
|
@@ -24,12 +21,9 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
24
21
|
var checkValueIsTruthy = function checkValueIsTruthy(config, data) {
|
|
25
22
|
if (config !== null && config !== void 0 && config.field) {
|
|
26
23
|
var fieldPath = _copReactComponents.Utils.interpolateString(config.field, data);
|
|
27
|
-
|
|
28
24
|
return !!(0, _getSourceData.default)(data, fieldPath);
|
|
29
25
|
}
|
|
30
|
-
|
|
31
26
|
return false;
|
|
32
27
|
};
|
|
33
|
-
|
|
34
28
|
var _default = checkValueIsTruthy;
|
|
35
29
|
exports.default = _default;
|
|
@@ -4,24 +4,21 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Global imports.
|
|
11
|
+
|
|
15
12
|
// Local imports.
|
|
13
|
+
|
|
16
14
|
var getValueOrField = function getValueOrField(config, data) {
|
|
17
15
|
if (config !== null && config !== void 0 && config.value) {
|
|
18
16
|
return config.value;
|
|
19
17
|
}
|
|
20
|
-
|
|
21
18
|
var path = _copReactComponents.Utils.interpolateString(config === null || config === void 0 ? void 0 : config.field, data);
|
|
22
|
-
|
|
23
19
|
return (0, _getSourceData.default)(data, path);
|
|
24
20
|
};
|
|
21
|
+
|
|
25
22
|
/**
|
|
26
23
|
* Searches for a value in an array in data that matches a value given
|
|
27
24
|
* in config. A cutoff index can be provided in config if the search
|
|
@@ -31,52 +28,41 @@ var getValueOrField = function getValueOrField(config, data) {
|
|
|
31
28
|
* @param {object} data A page's formData.
|
|
32
29
|
* @returns The index of the matching value if one exists, or null.
|
|
33
30
|
*/
|
|
34
|
-
|
|
35
|
-
|
|
36
31
|
var getIndexOfMatchingValueIn = function getIndexOfMatchingValueIn(config, data) {
|
|
37
32
|
if (!config || !data) {
|
|
38
33
|
return null;
|
|
39
34
|
}
|
|
40
|
-
|
|
41
35
|
var targetPath = _copReactComponents.Utils.interpolateString(config.target, data);
|
|
42
|
-
|
|
43
36
|
var target = (0, _getSourceData.default)(data, targetPath);
|
|
44
37
|
var value = getValueOrField(config, data);
|
|
45
38
|
var cutoff = getValueOrField(config.cutoff, data);
|
|
46
39
|
var ignore = getValueOrField(config.ignore, data);
|
|
47
40
|
var result = null;
|
|
48
|
-
|
|
49
41
|
if (target && value && Array.isArray(target)) {
|
|
50
42
|
target.every(function (entry, index) {
|
|
51
43
|
if (index === cutoff) {
|
|
52
44
|
return false;
|
|
53
45
|
}
|
|
54
|
-
|
|
55
46
|
if (index === ignore) {
|
|
56
47
|
return true;
|
|
57
|
-
}
|
|
48
|
+
}
|
|
49
|
+
// Here we're simply checking if value matches the entry itself. This
|
|
58
50
|
// will be enough of a check for arrays of simple values.
|
|
59
|
-
|
|
60
|
-
|
|
61
51
|
if (entry === value) {
|
|
62
52
|
result = index;
|
|
63
53
|
return false;
|
|
64
|
-
}
|
|
54
|
+
}
|
|
55
|
+
// If the last check failed and there is a config.key defined, then
|
|
65
56
|
// we're most likely checking an array of objects and should use the
|
|
66
57
|
// key to index in and find a matching value.
|
|
67
|
-
|
|
68
|
-
|
|
69
58
|
if (config.key && (0, _getSourceData.default)(entry, config.key) === value) {
|
|
70
59
|
result = index;
|
|
71
60
|
return false;
|
|
72
61
|
}
|
|
73
|
-
|
|
74
62
|
return true;
|
|
75
63
|
});
|
|
76
64
|
}
|
|
77
|
-
|
|
78
65
|
return typeof result === 'number' ? result.toString() : result;
|
|
79
66
|
};
|
|
80
|
-
|
|
81
67
|
var _default = getIndexOfMatchingValueIn;
|
|
82
68
|
exports.default = _default;
|
|
@@ -4,11 +4,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _runPageOperations = _interopRequireDefault(require("./runPageOperations"));
|
|
9
|
-
|
|
10
8
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
-
|
|
12
9
|
var Operate = {
|
|
13
10
|
runPageOperations: _runPageOperations.default
|
|
14
11
|
};
|
|
@@ -4,14 +4,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Global imports.
|
|
11
|
+
|
|
15
12
|
// Local imports.
|
|
16
13
|
|
|
17
14
|
/**
|
|
@@ -23,15 +20,12 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
23
20
|
*/
|
|
24
21
|
var persistValueInFormData = function persistValueInFormData(config, data, onChange) {
|
|
25
22
|
var value;
|
|
26
|
-
|
|
27
23
|
if (config !== null && config !== void 0 && config.field) {
|
|
28
24
|
var fieldPath = _copReactComponents.Utils.interpolateString(config.field, data);
|
|
29
|
-
|
|
30
25
|
value = (0, _getSourceData.default)(data, fieldPath);
|
|
31
26
|
} else {
|
|
32
27
|
value = config === null || config === void 0 ? void 0 : config.value;
|
|
33
28
|
}
|
|
34
|
-
|
|
35
29
|
if (value && config.name && data[config.name] !== value) {
|
|
36
30
|
onChange({
|
|
37
31
|
target: {
|
|
@@ -41,6 +35,5 @@ var persistValueInFormData = function persistValueInFormData(config, data, onCha
|
|
|
41
35
|
});
|
|
42
36
|
}
|
|
43
37
|
};
|
|
44
|
-
|
|
45
38
|
var _default = persistValueInFormData;
|
|
46
39
|
exports.default = _default;
|
|
@@ -4,41 +4,32 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _checkValueIsTruthy = _interopRequireDefault(require("./checkValueIsTruthy"));
|
|
11
|
-
|
|
12
9
|
var _getIndexOfMatchingValueIn = _interopRequireDefault(require("./getIndexOfMatchingValueIn"));
|
|
13
|
-
|
|
14
10
|
var _persistValueInFormData = _interopRequireDefault(require("./persistValueInFormData"));
|
|
15
|
-
|
|
16
11
|
var _setValueInFormData = _interopRequireDefault(require("./setValueInFormData"));
|
|
17
|
-
|
|
18
12
|
var _shouldRun = _interopRequireDefault(require("./shouldRun"));
|
|
19
|
-
|
|
20
13
|
var _setDataItem = _interopRequireDefault(require("../Data/setDataItem"));
|
|
21
|
-
|
|
22
14
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
|
-
|
|
24
15
|
// Global imports.
|
|
16
|
+
|
|
25
17
|
// Local imports.
|
|
18
|
+
|
|
26
19
|
var functions = {
|
|
27
20
|
checkValueIsTruthy: _checkValueIsTruthy.default,
|
|
28
21
|
getIndexOfMatchingValueIn: _getIndexOfMatchingValueIn.default,
|
|
29
22
|
persistValueInFormData: _persistValueInFormData.default,
|
|
30
23
|
setValueInFormData: _setValueInFormData.default
|
|
31
24
|
};
|
|
32
|
-
|
|
33
25
|
var doOperation = function doOperation(config, data, onChange) {
|
|
34
26
|
var fn = functions[config.function];
|
|
35
|
-
|
|
36
27
|
if (typeof fn === 'function') {
|
|
37
28
|
return fn(config, data, onChange);
|
|
38
29
|
}
|
|
39
|
-
|
|
40
30
|
return undefined;
|
|
41
31
|
};
|
|
32
|
+
|
|
42
33
|
/**
|
|
43
34
|
* Run operations, specified in a page's config, on formData.
|
|
44
35
|
*
|
|
@@ -56,27 +47,21 @@ var doOperation = function doOperation(config, data, onChange) {
|
|
|
56
47
|
* @param {function} onChange The page's onChange handler.
|
|
57
48
|
* @returns data with the results of any operations included.
|
|
58
49
|
*/
|
|
59
|
-
|
|
60
|
-
|
|
61
50
|
var runPageOperations = function runPageOperations(config, data, onChange) {
|
|
62
51
|
if (config !== null && config !== void 0 && config.operations && data) {
|
|
63
52
|
config.operations.forEach(function (op) {
|
|
64
53
|
if ((0, _shouldRun.default)(op.run_when, data)) {
|
|
65
54
|
var result = doOperation(op, data, onChange);
|
|
66
|
-
|
|
67
55
|
if (op.output) {
|
|
68
56
|
// Remove array indexers and replace them with dot separators. This ensures that outputPath will
|
|
69
57
|
// work with setDataItem.
|
|
70
58
|
var outputPath = _copReactComponents.Utils.interpolateString(op.output, data).replace('[', '.').replace(']', '');
|
|
71
|
-
|
|
72
59
|
(0, _setDataItem.default)(data, outputPath, result);
|
|
73
60
|
}
|
|
74
61
|
}
|
|
75
62
|
});
|
|
76
63
|
}
|
|
77
|
-
|
|
78
64
|
return data;
|
|
79
65
|
};
|
|
80
|
-
|
|
81
66
|
var _default = runPageOperations;
|
|
82
67
|
exports.default = _default;
|
|
@@ -4,24 +4,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Global imports.
|
|
11
|
+
|
|
15
12
|
// Local imports.
|
|
13
|
+
|
|
16
14
|
var setValueInFormData = function setValueInFormData(config, data) {
|
|
17
15
|
if (config !== null && config !== void 0 && config.field) {
|
|
18
16
|
var fieldPath = _copReactComponents.Utils.interpolateString(config.field, data);
|
|
19
|
-
|
|
20
17
|
return (0, _getSourceData.default)(data, fieldPath) || null;
|
|
21
18
|
}
|
|
22
|
-
|
|
23
19
|
return (config === null || config === void 0 ? void 0 : config.value) || null;
|
|
24
20
|
};
|
|
25
|
-
|
|
26
21
|
var _default = setValueInFormData;
|
|
27
22
|
exports.default = _default;
|
|
@@ -4,14 +4,11 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
9
|
-
|
|
10
8
|
var _getSourceData = _interopRequireDefault(require("../Data/getSourceData"));
|
|
11
|
-
|
|
12
9
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
13
|
-
|
|
14
10
|
// Global imports.
|
|
11
|
+
|
|
15
12
|
// Local imports.
|
|
16
13
|
|
|
17
14
|
/**
|
|
@@ -24,44 +21,34 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
24
21
|
var shouldRun = function shouldRun(config, data) {
|
|
25
22
|
if (config !== null && config !== void 0 && config.condition) {
|
|
26
23
|
var fieldPath = _copReactComponents.Utils.interpolateString(config.field, data);
|
|
27
|
-
|
|
28
24
|
var fieldValue = (0, _getSourceData.default)(data, fieldPath);
|
|
29
|
-
|
|
30
25
|
switch (config.condition) {
|
|
31
26
|
// Only run the operation if a given field's value has changed.
|
|
32
27
|
case 'changes':
|
|
33
28
|
var lastPath = "".concat(fieldPath, "LastValue");
|
|
34
29
|
var lastValue = config[lastPath] || null;
|
|
35
|
-
|
|
36
30
|
if (lastValue === null) {
|
|
37
31
|
// If there isn't a last value then we assume
|
|
38
32
|
// that this is the first render.
|
|
39
33
|
config[lastPath] = fieldValue;
|
|
40
34
|
return false;
|
|
41
35
|
}
|
|
42
|
-
|
|
43
36
|
if (fieldValue !== lastValue) {
|
|
44
37
|
config[lastPath] = fieldValue;
|
|
45
38
|
return true;
|
|
46
39
|
}
|
|
47
|
-
|
|
48
40
|
return false;
|
|
49
41
|
// Only run the operation if a given field's value is truthy.
|
|
50
|
-
|
|
51
42
|
case 'isTruthy':
|
|
52
43
|
return !!fieldValue;
|
|
53
44
|
// Only run the operation if a given field's value is falsy.
|
|
54
|
-
|
|
55
45
|
case 'isFalsy':
|
|
56
46
|
return !fieldValue;
|
|
57
|
-
|
|
58
47
|
default:
|
|
59
48
|
return false;
|
|
60
49
|
}
|
|
61
50
|
}
|
|
62
|
-
|
|
63
51
|
return true;
|
|
64
52
|
};
|
|
65
|
-
|
|
66
53
|
var _default = shouldRun;
|
|
67
54
|
exports.default = _default;
|
|
@@ -4,30 +4,19 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
|
|
8
7
|
var _mustBeAfter = _interopRequireDefault(require("./mustBeAfter"));
|
|
9
|
-
|
|
10
8
|
var _mustBeBefore = _interopRequireDefault(require("./mustBeBefore"));
|
|
11
|
-
|
|
12
9
|
var _mustBeEarlierDateTime = _interopRequireDefault(require("./mustBeEarlierDateTime"));
|
|
13
|
-
|
|
14
10
|
var _mustBeInThePast = _interopRequireDefault(require("./mustBeInThePast"));
|
|
15
|
-
|
|
16
11
|
var _mustBeInTheFuture = _interopRequireDefault(require("./mustBeInTheFuture"));
|
|
17
|
-
|
|
18
12
|
var _mustBeLongerThan = _interopRequireDefault(require("./mustBeLongerThan"));
|
|
19
|
-
|
|
20
13
|
var _mustBeShorterThan = _interopRequireDefault(require("./mustBeShorterThan"));
|
|
21
|
-
|
|
22
14
|
var _mustEnterAtLeastOne = _interopRequireDefault(require("./mustEnterAtLeastOne"));
|
|
23
|
-
|
|
24
15
|
var _mustBeNumbersOnly = _interopRequireDefault(require("./mustBeNumbersOnly"));
|
|
25
|
-
|
|
26
16
|
var _mustBeLessThan = _interopRequireDefault(require("./mustBeLessThan"));
|
|
27
|
-
|
|
28
17
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
29
|
-
|
|
30
18
|
// Local imports
|
|
19
|
+
|
|
31
20
|
var functions = {
|
|
32
21
|
mustBeAfter: _mustBeAfter.default,
|
|
33
22
|
mustBeBefore: _mustBeBefore.default,
|
|
@@ -40,17 +29,13 @@ var functions = {
|
|
|
40
29
|
mustBeNumbersOnly: _mustBeNumbersOnly.default,
|
|
41
30
|
mustBeLessThan: _mustBeLessThan.default
|
|
42
31
|
};
|
|
43
|
-
|
|
44
32
|
var additionalValidation = function additionalValidation(value, config, component) {
|
|
45
33
|
var fn = functions[config.function];
|
|
46
|
-
|
|
47
34
|
if (typeof fn === 'function') {
|
|
48
35
|
return fn(value, config, component) ? undefined : config.message;
|
|
49
36
|
}
|
|
50
|
-
|
|
51
37
|
return undefined;
|
|
52
38
|
};
|
|
53
|
-
|
|
54
39
|
var runAdditionalComponentValidation = function runAdditionalComponentValidation(component, value) {
|
|
55
40
|
// We only care when we have a value - if we don't have one but want one, set `required: true`.
|
|
56
41
|
if (!!value) {
|
|
@@ -65,9 +50,7 @@ var runAdditionalComponentValidation = function runAdditionalComponentValidation
|
|
|
65
50
|
return error;
|
|
66
51
|
}
|
|
67
52
|
}
|
|
68
|
-
|
|
69
53
|
return undefined;
|
|
70
54
|
};
|
|
71
|
-
|
|
72
55
|
var _default = runAdditionalComponentValidation;
|
|
73
56
|
exports.default = _default;
|
|
@@ -1,17 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
3
|
var _dayjs = _interopRequireDefault(require("dayjs"));
|
|
4
|
-
|
|
5
4
|
var _customParseFormat = _interopRequireDefault(require("dayjs/plugin/customParseFormat"));
|
|
6
|
-
|
|
7
5
|
var _utils = require("./utils");
|
|
8
|
-
|
|
9
6
|
var _index = _interopRequireDefault(require("./index"));
|
|
10
|
-
|
|
11
7
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
12
|
-
|
|
13
8
|
_dayjs.default.extend(_customParseFormat.default);
|
|
14
|
-
|
|
15
9
|
describe('utils', function () {
|
|
16
10
|
describe('Validate', function () {
|
|
17
11
|
describe('additional', function () {
|