@ukhomeoffice/cop-react-form-renderer 5.0.0-alpha → 5.0.0
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 +18 -7
- package/dist/components/CheckYourAnswers/Answer.test.js +137 -0
- package/dist/components/CheckYourAnswers/CheckYourAnswers.js +70 -46
- package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +410 -0
- package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +551 -0
- package/dist/components/CollectionPage/CollectionPage.js +15 -10
- package/dist/components/CollectionPage/CollectionPage.test.js +382 -0
- package/dist/components/FormComponent/Collection.js +91 -48
- package/dist/components/FormComponent/Collection.scss +2 -1
- package/dist/components/FormComponent/Collection.test.js +807 -0
- package/dist/components/FormComponent/Container.js +35 -16
- package/dist/components/FormComponent/Container.test.js +370 -0
- package/dist/components/FormComponent/FormComponent.js +39 -13
- package/dist/components/FormComponent/FormComponent.stories.mdx +184 -0
- package/dist/components/FormComponent/FormComponent.test.js +226 -0
- package/dist/components/FormComponent/helpers/addLabel.js +5 -4
- package/dist/components/FormComponent/helpers/getComponentFieldSet.js +16 -0
- package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +29 -0
- package/dist/components/FormComponent/helpers/index.js +8 -1
- package/dist/components/FormPage/FormPage.js +69 -30
- package/dist/components/FormPage/FormPage.stories.mdx +155 -0
- package/dist/components/FormPage/FormPage.test.js +330 -0
- package/dist/components/FormRenderer/FormRenderer.js +142 -228
- package/dist/components/FormRenderer/FormRenderer.stories.mdx +183 -0
- package/dist/components/FormRenderer/FormRenderer.test.js +968 -0
- package/dist/components/FormRenderer/handlers/index.js +1 -2
- package/dist/components/FormRenderer/handlers/navigate.js +3 -1
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +35 -14
- package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +88 -5
- package/dist/components/FormRenderer/helpers/getCYA.js +11 -2
- package/dist/components/FormRenderer/helpers/getNextPageId.js +13 -7
- package/dist/components/FormRenderer/helpers/getRelevantPages.js +10 -2
- package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +1 -1
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +2 -2
- package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +6 -2
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +171 -51
- package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +307 -24
- package/dist/components/FormRenderer/helpers/index.js +1 -2
- package/dist/components/FormRenderer/onCYAAction.js +108 -0
- package/dist/components/FormRenderer/onCYAAction.test.js +583 -0
- package/dist/components/FormRenderer/onPageAction.js +145 -0
- package/dist/components/FormRenderer/onPageAction.test.js +678 -0
- package/dist/components/FormRenderer/onTaskAction.js +48 -0
- package/dist/components/FormRenderer/onTaskAction.test.js +217 -0
- package/dist/components/PageActions/ActionButton.js +0 -3
- package/dist/components/PageActions/ActionButton.test.js +93 -0
- package/dist/components/PageActions/PageActions.js +2 -2
- package/dist/components/PageActions/PageActions.stories.mdx +74 -0
- package/dist/components/PageActions/PageActions.test.js +132 -0
- package/dist/components/SummaryList/GroupAction.js +2 -2
- package/dist/components/SummaryList/GroupAction.test.js +80 -0
- package/dist/components/SummaryList/RowAction.js +2 -2
- package/dist/components/SummaryList/RowAction.test.js +80 -0
- package/dist/components/SummaryList/SummaryList.js +29 -12
- package/dist/components/SummaryList/SummaryList.scss +19 -0
- package/dist/components/SummaryList/SummaryList.stories.mdx +90 -0
- package/dist/components/SummaryList/SummaryList.test.js +400 -0
- package/dist/components/SummaryList/SummaryListHeadingRow.js +30 -0
- package/dist/components/SummaryList/SummaryListRow.js +5 -2
- package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +2 -1
- package/dist/components/SummaryList/helpers/getRowActionAttributes.js +2 -1
- package/dist/components/TaskList/Task.js +3 -3
- package/dist/components/TaskList/Task.test.js +167 -0
- package/dist/components/TaskList/TaskList.js +73 -22
- package/dist/components/TaskList/TaskList.stories.mdx +164 -0
- package/dist/components/TaskList/TaskList.test.js +389 -0
- package/dist/components/TaskList/TaskState.js +2 -2
- package/dist/components/TaskList/TaskState.test.js +86 -0
- package/dist/components/index.js +14 -0
- package/dist/context/HooksContext/HooksContext.js +72 -8
- package/dist/context/HooksContext/HooksContext.test.js +44 -0
- package/dist/context/ValidationContext/ValidationContext.js +38 -28
- package/dist/context/ValidationContext/ValidationContext.test.js +84 -0
- package/dist/hooks/useAxios.js +10 -12
- package/dist/hooks/useGetRequest.js +48 -49
- package/dist/hooks/useRefData.js +7 -4
- package/dist/index.js +34 -1
- package/dist/json/addressDetails.json +149 -0
- package/dist/json/areYouACivilServant.json +7 -0
- package/dist/json/firstForm.json +94 -0
- package/dist/json/grade.json +108 -0
- package/dist/json/group.data.json +21 -0
- package/dist/json/group.json +402 -0
- package/dist/json/groupOfRow.json +137 -0
- package/dist/json/groupOfRowData.json +15 -0
- package/dist/json/port.json +346 -0
- package/dist/json/saveAndContinue.json +98 -0
- package/dist/json/sublocation.json +859 -0
- package/dist/json/taskList.json +265 -0
- package/dist/json/team.json +17351 -0
- package/dist/json/terminal.json +81 -0
- package/dist/json/userProfile.data.json +21 -0
- package/dist/json/userProfile.json +276 -0
- package/dist/models/ComponentTypes.js +8 -0
- package/dist/models/PageAction.js +4 -1
- package/dist/models/TaskStates.js +10 -2
- package/dist/models/index.js +16 -1
- package/dist/setupTests.js +46 -0
- package/dist/utils/CheckYourAnswers/getCYAAction.js +5 -5
- package/dist/utils/CheckYourAnswers/getCYAAction.test.js +121 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +6 -2
- package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +71 -0
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +6 -2
- package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +55 -0
- package/dist/utils/CheckYourAnswers/getCYARow.js +14 -11
- package/dist/utils/CheckYourAnswers/getCYARow.test.js +291 -0
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +4 -1
- package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +70 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +15 -10
- package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +288 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +94 -36
- package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +414 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +21 -7
- package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +486 -0
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +11 -3
- package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +346 -0
- package/dist/utils/CheckYourAnswers/showComponentCYA.js +19 -3
- package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +143 -0
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +5 -1
- package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +40 -0
- package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +53 -0
- package/dist/utils/CollectionPage/mergeCollectionPages.js +25 -17
- package/dist/utils/CollectionPage/mergeCollectionPages.test.js +130 -0
- package/dist/utils/Component/addShowWhen.js +44 -0
- package/dist/utils/Component/addShowWhen.test.js +216 -0
- package/dist/utils/Component/applyToComponentTree.js +71 -0
- package/dist/utils/Component/applyToComponentTree.test.js +127 -0
- package/dist/utils/Component/cleanAttributes.js +8 -2
- package/dist/utils/Component/cleanAttributes.test.js +68 -0
- package/dist/utils/Component/elevateNestedComponents.js +4 -1
- package/dist/utils/Component/elevateNestedComponents.test.js +122 -0
- package/dist/utils/Component/getComponent.js +80 -11
- package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +4 -4
- package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +25 -24
- package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +66 -5
- package/dist/utils/Component/getComponentTests/getComponent.date.test.js +2 -2
- package/dist/utils/Component/getComponentTests/getComponent.details.test.js +9 -7
- package/dist/utils/Component/getComponentTests/getComponent.email.test.js +3 -3
- package/dist/utils/Component/getComponentTests/getComponent.file.test.js +3 -3
- package/dist/utils/Component/getComponentTests/getComponent.list.test.js +44 -0
- package/dist/utils/Component/getComponentTests/{getComponent.textarea.test.js → getComponent.multifile.test.js} +29 -21
- package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +159 -83
- package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +43 -0
- package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +3 -3
- package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +55 -5
- package/dist/utils/Component/getComponentTests/getComponent.select.test.js +3 -9
- package/dist/utils/Component/getComponentTests/getComponent.text.test.js +3 -3
- package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +109 -0
- package/dist/utils/Component/getComponentTests/getComponent.time.test.js +7 -7
- package/dist/utils/Component/getDefaultValue.js +4 -1
- package/dist/utils/Component/getDefaultValue.test.js +50 -0
- package/dist/utils/Component/index.js +2 -0
- package/dist/utils/Component/isEditable.js +2 -2
- package/dist/utils/Component/isEditable.test.js +43 -0
- package/dist/utils/Component/optionIsSelected.js +22 -0
- package/dist/utils/Component/optionIsSelected.test.js +42 -0
- package/dist/utils/Component/setupContainerComponentsPath.js +40 -0
- package/dist/utils/Component/setupContainerComponentsPath.test.js +78 -0
- package/dist/utils/Component/showComponent.test.js +156 -0
- package/dist/utils/Component/wrapInFormGroup.js +1 -1
- package/dist/utils/Condition/meetsAllConditions.js +1 -1
- package/dist/utils/Condition/meetsAllConditions.test.js +61 -0
- package/dist/utils/Condition/meetsCondition.js +74 -4
- package/dist/utils/Condition/meetsCondition.test.js +763 -0
- package/dist/utils/Condition/meetsOneCondition.js +1 -1
- package/dist/utils/Condition/meetsOneCondition.test.js +100 -0
- package/dist/utils/Condition/setupConditions.js +6 -3
- package/dist/utils/Condition/setupConditions.test.js +33 -0
- package/dist/utils/Container/getEditableComponents.test.js +135 -0
- package/dist/utils/Container/setupNesting.js +21 -2
- package/dist/utils/Container/setupNesting.test.js +145 -0
- package/dist/utils/Container/showContainer.test.js +178 -0
- package/dist/utils/Data/applyFormula.js +20 -11
- package/dist/utils/Data/applyFormula.test.js +263 -0
- package/dist/utils/Data/getAutocompleteSource.js +6 -2
- package/dist/utils/Data/getAutocompleteSource.test.js +352 -0
- package/dist/utils/Data/getDataPath.test.js +48 -0
- package/dist/utils/Data/getOptions.js +17 -3
- package/dist/utils/Data/getOptions.test.js +140 -0
- package/dist/utils/Data/getSourceData.js +2 -2
- package/dist/utils/Data/getSourceData.test.js +153 -0
- package/dist/utils/Data/refDataToOptions.js +4 -1
- package/dist/utils/Data/refDataToOptions.test.js +196 -0
- package/dist/utils/Data/setDataItem.test.js +110 -0
- package/dist/utils/Data/setupFormData.js +39 -16
- package/dist/utils/Data/setupFormData.test.js +410 -0
- package/dist/utils/Data/setupRefDataUrlForComponent.js +4 -1
- package/dist/utils/Data/setupRefDataUrlForComponent.test.js +131 -0
- package/dist/utils/FormPage/applyConditionalProperties.js +35 -0
- package/dist/utils/FormPage/applyConditionalProperties.test.js +61 -0
- package/dist/utils/FormPage/getFormPage.js +5 -2
- package/dist/utils/FormPage/getFormPage.test.js +206 -0
- package/dist/utils/FormPage/getFormPages.js +4 -1
- package/dist/utils/FormPage/getFormPages.test.js +97 -0
- package/dist/utils/FormPage/getPageActions.js +8 -4
- package/dist/utils/FormPage/getPageActions.test.js +114 -0
- package/dist/utils/FormPage/getParagraphFromText.test.js +27 -0
- package/dist/utils/FormPage/index.js +2 -0
- package/dist/utils/FormPage/showFormPage.js +2 -2
- package/dist/utils/FormPage/showFormPage.test.js +180 -0
- package/dist/utils/FormPage/showFormPageCYA.js +1 -0
- package/dist/utils/FormPage/showFormPageCYA.test.js +28 -0
- package/dist/utils/FormPage/useComponent.js +29 -14
- package/dist/utils/FormPage/useComponent.test.js +167 -0
- package/dist/utils/Format/formatData.test.js +45 -0
- package/dist/utils/Format/formatDataForComponent.js +2 -1
- package/dist/utils/Format/formatDataForComponent.test.js +142 -0
- package/dist/utils/Format/formatDataForForm.js +4 -1
- package/dist/utils/Format/formatDataForForm.test.js +81 -0
- package/dist/utils/Format/formatDataForPage.test.js +99 -0
- package/dist/utils/Hub/getFormHub.test.js +105 -0
- package/dist/utils/Meta/documents/getDocuments.test.js +4 -1
- package/dist/utils/Meta/documents/index.js +2 -2
- package/dist/utils/Meta/documents/setDocumentsForField.js +31 -0
- package/dist/utils/Meta/documents/setDocumentsForField.test.js +59 -0
- package/dist/utils/Operate/checkValueIsTruthy.test.js +42 -0
- package/dist/utils/Operate/getFirstOf.js +31 -0
- package/dist/utils/Operate/getFirstOf.test.js +86 -0
- package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +163 -0
- package/dist/utils/Operate/persistValueInFormData.js +2 -1
- package/dist/utils/Operate/persistValueInFormData.test.js +115 -0
- package/dist/utils/Operate/runPageOperations.js +3 -1
- package/dist/utils/Operate/runPageOperations.test.js +105 -0
- package/dist/utils/Operate/setValueInFormData.test.js +44 -0
- package/dist/utils/Operate/shouldRun.js +16 -13
- package/dist/utils/Operate/shouldRun.test.js +66 -0
- package/dist/utils/Validate/additional/conditionallyRequired.js +24 -0
- package/dist/utils/Validate/additional/conditionallyRequired.test.js +73 -0
- package/dist/utils/Validate/additional/index.js +13 -4
- package/dist/utils/Validate/additional/mustBeAfter.js +8 -6
- package/dist/utils/Validate/additional/mustBeAfter.test.js +15 -1
- package/dist/utils/Validate/additional/mustBeBefore.js +9 -5
- package/dist/utils/Validate/additional/mustBeBefore.test.js +14 -0
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +1 -1
- package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +6 -3
- package/dist/utils/Validate/additional/mustBeGreaterThan.js +22 -0
- package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +56 -0
- package/dist/utils/Validate/additional/mustBeInTheFuture.js +1 -1
- package/dist/utils/Validate/additional/mustBeInThePast.js +5 -5
- package/dist/utils/Validate/additional/mustBeLessThan.js +7 -6
- package/dist/utils/Validate/additional/mustBeLessThan.test.js +11 -1
- package/dist/utils/Validate/additional/mustBeNumbersOnly.js +9 -5
- package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +10 -2
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +1 -0
- package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +4 -1
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +19 -0
- package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +36 -0
- package/dist/utils/Validate/additional/mustSelectOnlyOne.js +29 -0
- package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +52 -0
- package/dist/utils/Validate/additional/utils.js +18 -18
- package/dist/utils/Validate/index.js +6 -0
- package/dist/utils/Validate/validateCollection.js +20 -5
- package/dist/utils/Validate/validateCollection.test.js +125 -0
- package/dist/utils/Validate/validateComponent.js +36 -20
- package/dist/utils/Validate/validateComponent.test.js +365 -0
- package/dist/utils/Validate/validateContainer.js +9 -3
- package/dist/utils/Validate/validateContainer.test.js +75 -0
- package/dist/utils/Validate/validateDate.js +4 -3
- package/dist/utils/Validate/validateDate.test.js +114 -0
- package/dist/utils/Validate/validateEmail.js +14 -1
- package/dist/utils/Validate/validateEmail.test.js +74 -0
- package/dist/utils/Validate/validateMultifile.js +32 -0
- package/dist/utils/Validate/validateMultifile.test.js +47 -0
- package/dist/utils/Validate/validatePage.js +12 -6
- package/dist/utils/Validate/validatePage.test.js +472 -0
- package/dist/utils/Validate/validateRegex.js +2 -5
- package/dist/utils/Validate/validateRegex.test.js +42 -0
- package/dist/utils/Validate/validateRequired.js +2 -4
- package/dist/utils/Validate/validateRequired.test.js +63 -0
- package/dist/utils/Validate/validateTextArea.js +37 -0
- package/dist/utils/Validate/validateTextArea.test.js +42 -0
- package/dist/utils/Validate/validateTime.js +2 -2
- package/dist/utils/Validate/validateTime.test.js +59 -0
- package/dist/utils/index.js +4 -1
- package/package.json +35 -50
- package/dist/utils/Meta/documents/setDocumentForField.js +0 -29
- package/dist/utils/Meta/documents/setDocumentForField.test.js +0 -49
|
@@ -0,0 +1,400 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
+
var _react = require("@testing-library/react");
|
|
5
|
+
var _react2 = _interopRequireDefault(require("react"));
|
|
6
|
+
var _SummaryList = _interopRequireWildcard(require("./SummaryList"));
|
|
7
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
8
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
9
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
10
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
11
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
12
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
13
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
14
|
+
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
15
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
16
|
+
describe('components', function () {
|
|
17
|
+
describe('SummaryList', function () {
|
|
18
|
+
var checkSummaryList = function checkSummaryList(container, id) {
|
|
19
|
+
var summaryList = (0, _react.getByTestId)(container, id);
|
|
20
|
+
expect(summaryList.tagName).toEqual('DL');
|
|
21
|
+
expect(summaryList.classList).toContain(_SummaryList.DEFAULT_CLASS);
|
|
22
|
+
return summaryList;
|
|
23
|
+
};
|
|
24
|
+
var checkTitleRow = function checkTitleRow(summaryList, index) {
|
|
25
|
+
var row = summaryList.childNodes[index];
|
|
26
|
+
expect(row.tagName).toEqual('DIV');
|
|
27
|
+
expect(row.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__row"));
|
|
28
|
+
expect(row.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__title"));
|
|
29
|
+
var _row$childNodes = _slicedToArray(row.childNodes, 1),
|
|
30
|
+
heading = _row$childNodes[0];
|
|
31
|
+
expect(heading.tagName).toEqual('H3');
|
|
32
|
+
expect(heading.classList).toContain('govuk-heading-s');
|
|
33
|
+
return heading;
|
|
34
|
+
};
|
|
35
|
+
var checkActionRow = function checkActionRow(summaryList, index) {
|
|
36
|
+
var row = summaryList.childNodes[index];
|
|
37
|
+
expect(row.tagName).toEqual('DIV');
|
|
38
|
+
expect(row.childNodes.length).toEqual(1);
|
|
39
|
+
var link = row.childNodes[0];
|
|
40
|
+
return link;
|
|
41
|
+
};
|
|
42
|
+
var checkRow = function checkRow(summaryList, index) {
|
|
43
|
+
var row = summaryList.childNodes[index];
|
|
44
|
+
expect(row.tagName).toEqual('DIV');
|
|
45
|
+
expect(row.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__row"));
|
|
46
|
+
var _row$childNodes2 = _slicedToArray(row.childNodes, 3),
|
|
47
|
+
key = _row$childNodes2[0],
|
|
48
|
+
value = _row$childNodes2[1],
|
|
49
|
+
actions = _row$childNodes2[2];
|
|
50
|
+
expect(key.tagName).toEqual('DT');
|
|
51
|
+
expect(key.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__key"));
|
|
52
|
+
expect(value.tagName).toEqual('DD');
|
|
53
|
+
expect(value.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__value"));
|
|
54
|
+
expect(actions.tagName).toEqual('DD');
|
|
55
|
+
expect(actions.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__actions"));
|
|
56
|
+
return [key, value, actions];
|
|
57
|
+
};
|
|
58
|
+
var checkRowNoChangeActions = function checkRowNoChangeActions(summaryList, index) {
|
|
59
|
+
var row = summaryList.childNodes[index];
|
|
60
|
+
expect(row.tagName).toEqual('DIV');
|
|
61
|
+
expect(row.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__row"));
|
|
62
|
+
var _row$childNodes3 = _slicedToArray(row.childNodes, 2),
|
|
63
|
+
key = _row$childNodes3[0],
|
|
64
|
+
value = _row$childNodes3[1];
|
|
65
|
+
expect(key.tagName).toEqual('DT');
|
|
66
|
+
expect(key.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__key"));
|
|
67
|
+
expect(value.tagName).toEqual('DD');
|
|
68
|
+
expect(value.classList).toContain("".concat(_SummaryList.DEFAULT_CLASS, "__value"));
|
|
69
|
+
expect(row.childNodes.length).toEqual(2);
|
|
70
|
+
return [key, value];
|
|
71
|
+
};
|
|
72
|
+
it('should handle an empty rows array', function () {
|
|
73
|
+
var ID = 'test-id';
|
|
74
|
+
var ROWS = [];
|
|
75
|
+
var _render = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
76
|
+
"data-testid": ID,
|
|
77
|
+
rows: ROWS
|
|
78
|
+
})),
|
|
79
|
+
container = _render.container;
|
|
80
|
+
var summaryList = checkSummaryList(container, ID);
|
|
81
|
+
expect(summaryList.childNodes.length).toEqual(0);
|
|
82
|
+
});
|
|
83
|
+
it('should handle rows with no actions and string values', function () {
|
|
84
|
+
var ID = 'test-id';
|
|
85
|
+
var ROWS = [{
|
|
86
|
+
key: 'a',
|
|
87
|
+
pageId: 'p1',
|
|
88
|
+
fieldId: 'a',
|
|
89
|
+
value: 'Alpha value'
|
|
90
|
+
}, {
|
|
91
|
+
key: 'b',
|
|
92
|
+
pageId: 'p2',
|
|
93
|
+
fieldId: 'b',
|
|
94
|
+
value: 'Bravo value'
|
|
95
|
+
}];
|
|
96
|
+
var _render2 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
97
|
+
"data-testid": ID,
|
|
98
|
+
rows: ROWS,
|
|
99
|
+
noGroupAction: true
|
|
100
|
+
})),
|
|
101
|
+
container = _render2.container;
|
|
102
|
+
var summaryList = checkSummaryList(container, ID);
|
|
103
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
104
|
+
ROWS.forEach(function (row, index) {
|
|
105
|
+
var _checkRow = checkRow(summaryList, index),
|
|
106
|
+
_checkRow2 = _slicedToArray(_checkRow, 3),
|
|
107
|
+
key = _checkRow2[0],
|
|
108
|
+
value = _checkRow2[1],
|
|
109
|
+
actions = _checkRow2[2];
|
|
110
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
111
|
+
expect(value.textContent).toEqual(row.value);
|
|
112
|
+
expect(actions.childNodes.length).toEqual(0);
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
it('should handle title rows', function () {
|
|
116
|
+
var ID = 'test-id';
|
|
117
|
+
var ROWS = [{
|
|
118
|
+
key: 'Title',
|
|
119
|
+
pageId: 'p1',
|
|
120
|
+
fieldId: 'a',
|
|
121
|
+
type: 'title'
|
|
122
|
+
}, {
|
|
123
|
+
key: 'b',
|
|
124
|
+
pageId: 'p1',
|
|
125
|
+
fieldId: 'b',
|
|
126
|
+
value: 'Alpha value'
|
|
127
|
+
}, {
|
|
128
|
+
key: 'c',
|
|
129
|
+
pageId: 'p2',
|
|
130
|
+
fieldId: 'c',
|
|
131
|
+
value: 'Bravo value'
|
|
132
|
+
}];
|
|
133
|
+
var _render3 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
134
|
+
"data-testid": ID,
|
|
135
|
+
rows: ROWS
|
|
136
|
+
})),
|
|
137
|
+
container = _render3.container;
|
|
138
|
+
var summaryList = checkSummaryList(container, ID);
|
|
139
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
140
|
+
var assessTitleRow = function assessTitleRow(row, index) {
|
|
141
|
+
var heading = checkTitleRow(summaryList, index);
|
|
142
|
+
expect(heading.textContent).toEqual(row.key);
|
|
143
|
+
};
|
|
144
|
+
var assessRow = function assessRow(row, index) {
|
|
145
|
+
var _checkRow3 = checkRow(summaryList, index),
|
|
146
|
+
_checkRow4 = _slicedToArray(_checkRow3, 3),
|
|
147
|
+
key = _checkRow4[0],
|
|
148
|
+
value = _checkRow4[1],
|
|
149
|
+
actions = _checkRow4[2];
|
|
150
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
151
|
+
expect(value.textContent).toEqual(row.value);
|
|
152
|
+
expect(actions.childNodes.length).toEqual(0);
|
|
153
|
+
};
|
|
154
|
+
ROWS.forEach(function (row, index) {
|
|
155
|
+
if (row.type === 'title') {
|
|
156
|
+
assessTitleRow(row, index);
|
|
157
|
+
} else {
|
|
158
|
+
assessRow(row, index);
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
it('should handle action rows', function () {
|
|
163
|
+
var ID = 'test-id';
|
|
164
|
+
var ROWS = [{
|
|
165
|
+
key: 'a',
|
|
166
|
+
pageId: 'p1',
|
|
167
|
+
fieldId: 'a',
|
|
168
|
+
type: 'action',
|
|
169
|
+
action: {
|
|
170
|
+
label: 'Do action'
|
|
171
|
+
}
|
|
172
|
+
}, {
|
|
173
|
+
key: 'b',
|
|
174
|
+
pageId: 'p2',
|
|
175
|
+
fieldId: 'b',
|
|
176
|
+
type: 'action',
|
|
177
|
+
action: {
|
|
178
|
+
label: 'Do action'
|
|
179
|
+
}
|
|
180
|
+
}, {
|
|
181
|
+
key: 'c',
|
|
182
|
+
pageId: 'p3',
|
|
183
|
+
fieldId: 'c',
|
|
184
|
+
type: 'action',
|
|
185
|
+
action: {
|
|
186
|
+
label: 'Do action'
|
|
187
|
+
}
|
|
188
|
+
}];
|
|
189
|
+
var _render4 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
190
|
+
"data-testid": ID,
|
|
191
|
+
rows: ROWS
|
|
192
|
+
})),
|
|
193
|
+
container = _render4.container;
|
|
194
|
+
var summaryList = checkSummaryList(container, ID);
|
|
195
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
196
|
+
var assessActionRow = function assessActionRow(row, index) {
|
|
197
|
+
var link = checkActionRow(summaryList, index);
|
|
198
|
+
expect(link.textContent).toEqual(row.action.label);
|
|
199
|
+
};
|
|
200
|
+
ROWS.forEach(function (row, index) {
|
|
201
|
+
assessActionRow(row, index);
|
|
202
|
+
});
|
|
203
|
+
});
|
|
204
|
+
it('should hide actions rows if flag is given', function () {
|
|
205
|
+
var ID = 'test-id';
|
|
206
|
+
var ROWS = [{
|
|
207
|
+
key: 'a',
|
|
208
|
+
pageId: 'p1',
|
|
209
|
+
fieldId: 'a',
|
|
210
|
+
type: 'action',
|
|
211
|
+
action: {
|
|
212
|
+
label: 'Do action'
|
|
213
|
+
}
|
|
214
|
+
}, {
|
|
215
|
+
key: 'b',
|
|
216
|
+
pageId: 'p2',
|
|
217
|
+
fieldId: 'b',
|
|
218
|
+
type: 'action',
|
|
219
|
+
action: {
|
|
220
|
+
label: 'Do action'
|
|
221
|
+
}
|
|
222
|
+
}, {
|
|
223
|
+
key: 'c',
|
|
224
|
+
pageId: 'p3',
|
|
225
|
+
fieldId: 'c',
|
|
226
|
+
type: 'action',
|
|
227
|
+
action: {
|
|
228
|
+
label: 'Do action'
|
|
229
|
+
}
|
|
230
|
+
}];
|
|
231
|
+
var _render5 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
232
|
+
"data-testid": ID,
|
|
233
|
+
rows: ROWS,
|
|
234
|
+
noChangeAction: true
|
|
235
|
+
})),
|
|
236
|
+
container = _render5.container;
|
|
237
|
+
var summaryList = checkSummaryList(container, ID);
|
|
238
|
+
expect(summaryList.childNodes.length).toEqual(0);
|
|
239
|
+
});
|
|
240
|
+
it('should handle rows with no actions and component values', function () {
|
|
241
|
+
var ID = 'test-id';
|
|
242
|
+
var VALUES = ['Alpha component value', 'Bravo component value'];
|
|
243
|
+
var ROWS = [{
|
|
244
|
+
key: 'a',
|
|
245
|
+
pageId: 'p1',
|
|
246
|
+
fieldId: 'a',
|
|
247
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[0])
|
|
248
|
+
}, {
|
|
249
|
+
key: 'b',
|
|
250
|
+
pageId: 'p2',
|
|
251
|
+
fieldId: 'b',
|
|
252
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[1])
|
|
253
|
+
}];
|
|
254
|
+
var _render6 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
255
|
+
"data-testid": ID,
|
|
256
|
+
rows: ROWS
|
|
257
|
+
})),
|
|
258
|
+
container = _render6.container;
|
|
259
|
+
var summaryList = checkSummaryList(container, ID);
|
|
260
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
261
|
+
ROWS.forEach(function (row, index) {
|
|
262
|
+
var _checkRow5 = checkRow(summaryList, index),
|
|
263
|
+
_checkRow6 = _slicedToArray(_checkRow5, 3),
|
|
264
|
+
key = _checkRow6[0],
|
|
265
|
+
value = _checkRow6[1],
|
|
266
|
+
actions = _checkRow6[2];
|
|
267
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
268
|
+
expect(value.childNodes.length).toEqual(1);
|
|
269
|
+
var valueDiv = value.childNodes[0];
|
|
270
|
+
expect(valueDiv.tagName).toEqual('DIV');
|
|
271
|
+
expect(valueDiv.textContent).toEqual(VALUES[index]);
|
|
272
|
+
expect(actions.childNodes.length).toEqual(0);
|
|
273
|
+
});
|
|
274
|
+
});
|
|
275
|
+
it('should handle rows with actions', function () {
|
|
276
|
+
var ID = 'test-id';
|
|
277
|
+
var ON_ACTION_CALLS = [];
|
|
278
|
+
var ON_ACTION = function ON_ACTION(row) {
|
|
279
|
+
ON_ACTION_CALLS.push(row);
|
|
280
|
+
};
|
|
281
|
+
var ROWS = [{
|
|
282
|
+
key: 'a',
|
|
283
|
+
pageId: 'p1',
|
|
284
|
+
fieldId: 'a',
|
|
285
|
+
value: 'Alpha value',
|
|
286
|
+
action: {
|
|
287
|
+
label: 'Change A',
|
|
288
|
+
onAction: ON_ACTION
|
|
289
|
+
}
|
|
290
|
+
}, {
|
|
291
|
+
key: 'b',
|
|
292
|
+
pageId: 'p2',
|
|
293
|
+
fieldId: 'b',
|
|
294
|
+
value: 'Bravo value',
|
|
295
|
+
action: {
|
|
296
|
+
label: 'Change B',
|
|
297
|
+
onAction: ON_ACTION
|
|
298
|
+
}
|
|
299
|
+
}];
|
|
300
|
+
var _render7 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
301
|
+
"data-testid": ID,
|
|
302
|
+
rows: ROWS
|
|
303
|
+
})),
|
|
304
|
+
container = _render7.container;
|
|
305
|
+
var summaryList = checkSummaryList(container, ID);
|
|
306
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
307
|
+
ROWS.forEach(function (row, index) {
|
|
308
|
+
var _checkRow7 = checkRow(summaryList, index),
|
|
309
|
+
_checkRow8 = _slicedToArray(_checkRow7, 3),
|
|
310
|
+
key = _checkRow8[0],
|
|
311
|
+
value = _checkRow8[1],
|
|
312
|
+
actions = _checkRow8[2];
|
|
313
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
314
|
+
expect(value.textContent).toEqual(row.value);
|
|
315
|
+
var a = actions.childNodes[0];
|
|
316
|
+
expect(a.textContent).toEqual(row.action.label);
|
|
317
|
+
_react.fireEvent.click(a, {});
|
|
318
|
+
expect(ON_ACTION_CALLS.length).toEqual(index + 1);
|
|
319
|
+
expect(ON_ACTION_CALLS[index]).toEqual(row);
|
|
320
|
+
});
|
|
321
|
+
});
|
|
322
|
+
it('should handle rows with component values and actions set to hidden', function () {
|
|
323
|
+
var ID = 'test-id';
|
|
324
|
+
var VALUES = ['Alpha component value', 'Bravo component value'];
|
|
325
|
+
var ROWS = [{
|
|
326
|
+
key: 'a',
|
|
327
|
+
pageId: 'p1',
|
|
328
|
+
fieldId: 'a',
|
|
329
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[0])
|
|
330
|
+
}, {
|
|
331
|
+
key: 'b',
|
|
332
|
+
pageId: 'p2',
|
|
333
|
+
fieldId: 'b',
|
|
334
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[1])
|
|
335
|
+
}];
|
|
336
|
+
var _render8 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
337
|
+
"data-testid": ID,
|
|
338
|
+
rows: ROWS,
|
|
339
|
+
noChangeAction: true
|
|
340
|
+
})),
|
|
341
|
+
container = _render8.container;
|
|
342
|
+
var summaryList = checkSummaryList(container, ID);
|
|
343
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length);
|
|
344
|
+
ROWS.forEach(function (row, index) {
|
|
345
|
+
var _checkRowNoChangeActi = checkRowNoChangeActions(summaryList, index),
|
|
346
|
+
_checkRowNoChangeActi2 = _slicedToArray(_checkRowNoChangeActi, 2),
|
|
347
|
+
key = _checkRowNoChangeActi2[0],
|
|
348
|
+
value = _checkRowNoChangeActi2[1];
|
|
349
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
350
|
+
expect(value.childNodes.length).toEqual(1);
|
|
351
|
+
var valueDiv = value.childNodes[0];
|
|
352
|
+
expect(valueDiv.tagName).toEqual('DIV');
|
|
353
|
+
expect(valueDiv.textContent).toEqual(VALUES[index]);
|
|
354
|
+
});
|
|
355
|
+
});
|
|
356
|
+
it('should render groups of rows correctly', function () {
|
|
357
|
+
var ID = 'test-id';
|
|
358
|
+
var VALUES = ['Alpha component value', 'Bravo component value', 'Charlie component value'];
|
|
359
|
+
var ISGROUP = true;
|
|
360
|
+
var ROWS = [{
|
|
361
|
+
key: 'a',
|
|
362
|
+
pageId: 'p1',
|
|
363
|
+
fieldId: 'a',
|
|
364
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[0]),
|
|
365
|
+
action: {
|
|
366
|
+
label: 'action'
|
|
367
|
+
}
|
|
368
|
+
}, {
|
|
369
|
+
key: 'b',
|
|
370
|
+
pageId: 'p1',
|
|
371
|
+
fieldId: 'b',
|
|
372
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[1])
|
|
373
|
+
}, {
|
|
374
|
+
key: 'c',
|
|
375
|
+
pageId: 'p1',
|
|
376
|
+
fieldId: 'c',
|
|
377
|
+
value: /*#__PURE__*/_react2.default.createElement("div", null, VALUES[2])
|
|
378
|
+
}];
|
|
379
|
+
var _render9 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_SummaryList.default, {
|
|
380
|
+
"data-testid": ID,
|
|
381
|
+
rows: ROWS,
|
|
382
|
+
isGroup: ISGROUP
|
|
383
|
+
})),
|
|
384
|
+
container = _render9.container;
|
|
385
|
+
var summaryList = checkSummaryList(container, ID);
|
|
386
|
+
expect(summaryList.childNodes.length).toEqual(ROWS.length + 1);
|
|
387
|
+
ROWS.forEach(function (row, index) {
|
|
388
|
+
var _checkRow9 = checkRow(summaryList, index),
|
|
389
|
+
_checkRow10 = _slicedToArray(_checkRow9, 2),
|
|
390
|
+
key = _checkRow10[0],
|
|
391
|
+
value = _checkRow10[1];
|
|
392
|
+
expect(key.textContent).toEqual("".concat(row.key, " (optional)"));
|
|
393
|
+
expect(value.childNodes.length).toEqual(1);
|
|
394
|
+
var valueDiv = value.childNodes[0];
|
|
395
|
+
expect(valueDiv.tagName).toEqual('DIV');
|
|
396
|
+
expect(valueDiv.textContent).toEqual(VALUES[index]);
|
|
397
|
+
});
|
|
398
|
+
});
|
|
399
|
+
});
|
|
400
|
+
});
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
var _copReactComponents = require("@ukhomeoffice/cop-react-components");
|
|
8
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
9
|
+
var _react = _interopRequireDefault(require("react"));
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
+
// Global imports
|
|
12
|
+
|
|
13
|
+
var SummaryListHeadingRow = function SummaryListHeadingRow(_ref) {
|
|
14
|
+
var title = _ref.title,
|
|
15
|
+
size = _ref.size,
|
|
16
|
+
classes = _ref.classes;
|
|
17
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
18
|
+
className: "".concat(classes('heading'))
|
|
19
|
+
}, size === 's' && /*#__PURE__*/_react.default.createElement(_copReactComponents.SmallHeading, null, title), size === 'm' && /*#__PURE__*/_react.default.createElement(_copReactComponents.MediumHeading, null, title));
|
|
20
|
+
};
|
|
21
|
+
SummaryListHeadingRow.propTypes = {
|
|
22
|
+
classes: _propTypes.default.func.isRequired,
|
|
23
|
+
size: _propTypes.default.string,
|
|
24
|
+
title: _propTypes.default.string.isRequired
|
|
25
|
+
};
|
|
26
|
+
SummaryListHeadingRow.defaultProps = {
|
|
27
|
+
size: 'm'
|
|
28
|
+
};
|
|
29
|
+
var _default = SummaryListHeadingRow;
|
|
30
|
+
exports.default = _default;
|
|
@@ -29,10 +29,11 @@ var SummaryListRow = function SummaryListRow(_ref) {
|
|
|
29
29
|
})));
|
|
30
30
|
};
|
|
31
31
|
SummaryListRow.propTypes = {
|
|
32
|
+
classes: _propTypes.default.func.isRequired,
|
|
32
33
|
row: _propTypes.default.shape({
|
|
33
34
|
key: _propTypes.default.string.isRequired,
|
|
34
35
|
required: _propTypes.default.bool,
|
|
35
|
-
value: _propTypes.default.
|
|
36
|
+
value: _propTypes.default.node,
|
|
36
37
|
action: _propTypes.default.shape({
|
|
37
38
|
page: _propTypes.default.string,
|
|
38
39
|
label: _propTypes.default.string,
|
|
@@ -40,8 +41,10 @@ SummaryListRow.propTypes = {
|
|
|
40
41
|
onAction: _propTypes.default.func
|
|
41
42
|
})
|
|
42
43
|
}).isRequired,
|
|
43
|
-
classes: _propTypes.default.func.isRequired,
|
|
44
44
|
showAction: _propTypes.default.bool
|
|
45
45
|
};
|
|
46
|
+
SummaryListRow.defaultProps = {
|
|
47
|
+
showAction: false
|
|
48
|
+
};
|
|
46
49
|
var _default = SummaryListRow;
|
|
47
50
|
exports.default = _default;
|
|
@@ -16,8 +16,8 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
16
16
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
17
17
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
18
18
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
19
|
-
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++)
|
|
20
|
-
function _iterableToArrayLimit(arr, i) { var _i =
|
|
19
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
20
|
+
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
21
21
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
22
22
|
var DEFAULT_CLASS = 'hods-task-list';
|
|
23
23
|
exports.DEFAULT_CLASS = DEFAULT_CLASS;
|
|
@@ -59,7 +59,7 @@ var Task = function Task(_ref) {
|
|
|
59
59
|
Task.propTypes = {
|
|
60
60
|
task: _propTypes.default.shape({
|
|
61
61
|
name: _propTypes.default.string.isRequired,
|
|
62
|
-
pages: _propTypes.default.
|
|
62
|
+
pages: _propTypes.default.arrayOf(_propTypes.default.string).isRequired,
|
|
63
63
|
state: _propTypes.default.string,
|
|
64
64
|
displayName: _propTypes.default.string
|
|
65
65
|
}).isRequired,
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _react = require("@testing-library/react");
|
|
4
|
+
var _react2 = _interopRequireDefault(require("react"));
|
|
5
|
+
var _models = require("../../models");
|
|
6
|
+
var _Task = _interopRequireDefault(require("./Task"));
|
|
7
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
8
|
+
// Global imports
|
|
9
|
+
|
|
10
|
+
// Local imports
|
|
11
|
+
|
|
12
|
+
describe('components', function () {
|
|
13
|
+
describe('TaskList.Task', function () {
|
|
14
|
+
it('should render a task', function () {
|
|
15
|
+
var STATE = _models.TaskStates.TYPES.COMPLETE;
|
|
16
|
+
var TASK = {
|
|
17
|
+
name: 'taskName',
|
|
18
|
+
pages: ['pageName'],
|
|
19
|
+
state: STATE
|
|
20
|
+
};
|
|
21
|
+
var ON_CLICK = function ON_CLICK() {};
|
|
22
|
+
var _render = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
23
|
+
task: TASK,
|
|
24
|
+
onClick: ON_CLICK
|
|
25
|
+
})),
|
|
26
|
+
container = _render.container;
|
|
27
|
+
expect(container.childNodes.length).toEqual(1);
|
|
28
|
+
expect(container.childNodes[0].classList).toContain('hods-task-list__item');
|
|
29
|
+
var span = container.childNodes[0].childNodes[0];
|
|
30
|
+
var state = container.childNodes[0].childNodes[1];
|
|
31
|
+
expect(span.classList).toContain('hods-task-list__task-name');
|
|
32
|
+
expect(span.textContent).toEqual(TASK.name);
|
|
33
|
+
expect(state.textContent).toEqual('Completed');
|
|
34
|
+
});
|
|
35
|
+
it('should render a task with a displayName', function () {
|
|
36
|
+
var STATE = _models.TaskStates.TYPES.COMPLETE;
|
|
37
|
+
var TASK = {
|
|
38
|
+
name: 'taskName',
|
|
39
|
+
displayName: 'Alpha Bravo',
|
|
40
|
+
pages: ['pageName'],
|
|
41
|
+
state: STATE
|
|
42
|
+
};
|
|
43
|
+
var ON_CLICK = function ON_CLICK() {};
|
|
44
|
+
var _render2 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
45
|
+
task: TASK,
|
|
46
|
+
onClick: ON_CLICK
|
|
47
|
+
})),
|
|
48
|
+
container = _render2.container;
|
|
49
|
+
expect(container.childNodes.length).toEqual(1);
|
|
50
|
+
expect(container.childNodes[0].classList).toContain('hods-task-list__item');
|
|
51
|
+
var span = container.childNodes[0].childNodes[0];
|
|
52
|
+
var state = container.childNodes[0].childNodes[1];
|
|
53
|
+
expect(span.classList).toContain('hods-task-list__task-name');
|
|
54
|
+
expect(span.textContent).toEqual(TASK.displayName);
|
|
55
|
+
expect(state.textContent).toEqual('Completed');
|
|
56
|
+
});
|
|
57
|
+
it('should render a task with inactive link if state is cannotStartYet', function () {
|
|
58
|
+
var STATE = _models.TaskStates.TYPES.CANNOT_START_YET;
|
|
59
|
+
var TASK = {
|
|
60
|
+
name: 'taskName',
|
|
61
|
+
pages: ['pageName'],
|
|
62
|
+
state: STATE
|
|
63
|
+
};
|
|
64
|
+
var ON_CLICK = function ON_CLICK() {};
|
|
65
|
+
var _render3 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
66
|
+
task: TASK,
|
|
67
|
+
onClick: ON_CLICK
|
|
68
|
+
})),
|
|
69
|
+
container = _render3.container;
|
|
70
|
+
var span = container.childNodes[0].childNodes[0];
|
|
71
|
+
expect(span.childNodes[0].tagName).toEqual(undefined);
|
|
72
|
+
expect(span.textContent).toEqual(TASK.name);
|
|
73
|
+
});
|
|
74
|
+
it('should render a task with a link if state is not cannotStartYet', function () {
|
|
75
|
+
var STATE = _models.TaskStates.TYPES.IN_PROGRESS;
|
|
76
|
+
var TASK = {
|
|
77
|
+
name: 'taskName',
|
|
78
|
+
pages: ['pageName'],
|
|
79
|
+
state: STATE
|
|
80
|
+
};
|
|
81
|
+
var ON_CLICK = function ON_CLICK() {};
|
|
82
|
+
var _render4 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
83
|
+
task: TASK,
|
|
84
|
+
onClick: ON_CLICK
|
|
85
|
+
})),
|
|
86
|
+
container = _render4.container;
|
|
87
|
+
var span = container.childNodes[0].childNodes[0];
|
|
88
|
+
expect(span.childNodes.length).toEqual(1);
|
|
89
|
+
expect(span.childNodes[0].tagName).toEqual('A');
|
|
90
|
+
expect(span.textContent).toEqual(TASK.name);
|
|
91
|
+
});
|
|
92
|
+
it('should render the displayName of a task with a link if state is not cannotStartYet', function () {
|
|
93
|
+
var STATE = _models.TaskStates.TYPES.IN_PROGRESS;
|
|
94
|
+
var TASK = {
|
|
95
|
+
name: 'taskName',
|
|
96
|
+
displayName: 'Charlie Delta',
|
|
97
|
+
pages: ['pageName'],
|
|
98
|
+
state: STATE
|
|
99
|
+
};
|
|
100
|
+
var ON_CLICK = function ON_CLICK() {};
|
|
101
|
+
var _render5 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
102
|
+
task: TASK,
|
|
103
|
+
onClick: ON_CLICK
|
|
104
|
+
})),
|
|
105
|
+
container = _render5.container;
|
|
106
|
+
var span = container.childNodes[0].childNodes[0];
|
|
107
|
+
expect(span.childNodes.length).toEqual(1);
|
|
108
|
+
expect(span.childNodes[0].tagName).toEqual('A');
|
|
109
|
+
expect(span.textContent).toEqual(TASK.displayName);
|
|
110
|
+
});
|
|
111
|
+
it('should call the given onClick function when the link is clicked', function () {
|
|
112
|
+
var STATE = _models.TaskStates.TYPES.IN_PROGRESS;
|
|
113
|
+
var TASK = {
|
|
114
|
+
name: 'taskName',
|
|
115
|
+
pages: ['pageName'],
|
|
116
|
+
state: STATE
|
|
117
|
+
};
|
|
118
|
+
var ON_CLICK_CALLS = [];
|
|
119
|
+
var ON_CLICK = function ON_CLICK(value) {
|
|
120
|
+
ON_CLICK_CALLS.push(value);
|
|
121
|
+
};
|
|
122
|
+
var _render6 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
123
|
+
task: TASK,
|
|
124
|
+
onClick: ON_CLICK
|
|
125
|
+
})),
|
|
126
|
+
container = _render6.container;
|
|
127
|
+
var link = container.childNodes[0].childNodes[0].childNodes[0];
|
|
128
|
+
_react.fireEvent.click(link);
|
|
129
|
+
expect(ON_CLICK_CALLS.length).toEqual(1);
|
|
130
|
+
expect(ON_CLICK_CALLS[0]).toEqual({
|
|
131
|
+
pages: ['pageName'],
|
|
132
|
+
name: "taskName",
|
|
133
|
+
state: STATE
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
it('should call the given onClick function when the enter key is pressed on the link', function () {
|
|
137
|
+
var STATE = _models.TaskStates.TYPES.IN_PROGRESS;
|
|
138
|
+
var TASK = {
|
|
139
|
+
name: 'taskName',
|
|
140
|
+
pages: ['pageName'],
|
|
141
|
+
state: STATE
|
|
142
|
+
};
|
|
143
|
+
var ON_CLICK_CALLS = [];
|
|
144
|
+
var ON_CLICK = function ON_CLICK(value) {
|
|
145
|
+
ON_CLICK_CALLS.push(value);
|
|
146
|
+
};
|
|
147
|
+
var _render7 = (0, _react.render)( /*#__PURE__*/_react2.default.createElement(_Task.default, {
|
|
148
|
+
task: TASK,
|
|
149
|
+
onClick: ON_CLICK
|
|
150
|
+
})),
|
|
151
|
+
container = _render7.container;
|
|
152
|
+
var link = container.childNodes[0].childNodes[0].childNodes[0];
|
|
153
|
+
// The keyPress event needs charCode: 13 or it fails; bug with the library.
|
|
154
|
+
_react.fireEvent.keyPress(link, {
|
|
155
|
+
key: 'Enter',
|
|
156
|
+
code: 13,
|
|
157
|
+
charCode: 13
|
|
158
|
+
});
|
|
159
|
+
expect(ON_CLICK_CALLS.length).toEqual(1);
|
|
160
|
+
expect(ON_CLICK_CALLS[0]).toEqual({
|
|
161
|
+
pages: ['pageName'],
|
|
162
|
+
name: "taskName",
|
|
163
|
+
state: STATE
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
});
|