@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.
Files changed (277) hide show
  1. package/dist/components/CheckYourAnswers/Answer.js +18 -7
  2. package/dist/components/CheckYourAnswers/Answer.test.js +137 -0
  3. package/dist/components/CheckYourAnswers/CheckYourAnswers.js +70 -46
  4. package/dist/components/CheckYourAnswers/CheckYourAnswers.stories.mdx +410 -0
  5. package/dist/components/CheckYourAnswers/CheckYourAnswers.test.js +551 -0
  6. package/dist/components/CollectionPage/CollectionPage.js +15 -10
  7. package/dist/components/CollectionPage/CollectionPage.test.js +382 -0
  8. package/dist/components/FormComponent/Collection.js +91 -48
  9. package/dist/components/FormComponent/Collection.scss +2 -1
  10. package/dist/components/FormComponent/Collection.test.js +807 -0
  11. package/dist/components/FormComponent/Container.js +35 -16
  12. package/dist/components/FormComponent/Container.test.js +370 -0
  13. package/dist/components/FormComponent/FormComponent.js +39 -13
  14. package/dist/components/FormComponent/FormComponent.stories.mdx +184 -0
  15. package/dist/components/FormComponent/FormComponent.test.js +226 -0
  16. package/dist/components/FormComponent/helpers/addLabel.js +5 -4
  17. package/dist/components/FormComponent/helpers/getComponentFieldSet.js +16 -0
  18. package/dist/components/FormComponent/helpers/getComponentFieldSet.test.js +29 -0
  19. package/dist/components/FormComponent/helpers/index.js +8 -1
  20. package/dist/components/FormPage/FormPage.js +69 -30
  21. package/dist/components/FormPage/FormPage.stories.mdx +155 -0
  22. package/dist/components/FormPage/FormPage.test.js +330 -0
  23. package/dist/components/FormRenderer/FormRenderer.js +142 -228
  24. package/dist/components/FormRenderer/FormRenderer.stories.mdx +183 -0
  25. package/dist/components/FormRenderer/FormRenderer.test.js +968 -0
  26. package/dist/components/FormRenderer/handlers/index.js +1 -2
  27. package/dist/components/FormRenderer/handlers/navigate.js +3 -1
  28. package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.js +35 -14
  29. package/dist/components/FormRenderer/helpers/cleanHiddenNestedData.test.js +88 -5
  30. package/dist/components/FormRenderer/helpers/getCYA.js +11 -2
  31. package/dist/components/FormRenderer/helpers/getNextPageId.js +13 -7
  32. package/dist/components/FormRenderer/helpers/getRelevantPages.js +10 -2
  33. package/dist/components/FormRenderer/helpers/getRelevantPages.test.js +1 -1
  34. package/dist/components/FormRenderer/helpers/getSubmissionStatus.js +2 -2
  35. package/dist/components/FormRenderer/helpers/getSubmissionStatus.test.js +6 -2
  36. package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.js +171 -51
  37. package/dist/components/FormRenderer/helpers/getUpdatedSectionStates.test.js +307 -24
  38. package/dist/components/FormRenderer/helpers/index.js +1 -2
  39. package/dist/components/FormRenderer/onCYAAction.js +108 -0
  40. package/dist/components/FormRenderer/onCYAAction.test.js +583 -0
  41. package/dist/components/FormRenderer/onPageAction.js +145 -0
  42. package/dist/components/FormRenderer/onPageAction.test.js +678 -0
  43. package/dist/components/FormRenderer/onTaskAction.js +48 -0
  44. package/dist/components/FormRenderer/onTaskAction.test.js +217 -0
  45. package/dist/components/PageActions/ActionButton.js +0 -3
  46. package/dist/components/PageActions/ActionButton.test.js +93 -0
  47. package/dist/components/PageActions/PageActions.js +2 -2
  48. package/dist/components/PageActions/PageActions.stories.mdx +74 -0
  49. package/dist/components/PageActions/PageActions.test.js +132 -0
  50. package/dist/components/SummaryList/GroupAction.js +2 -2
  51. package/dist/components/SummaryList/GroupAction.test.js +80 -0
  52. package/dist/components/SummaryList/RowAction.js +2 -2
  53. package/dist/components/SummaryList/RowAction.test.js +80 -0
  54. package/dist/components/SummaryList/SummaryList.js +29 -12
  55. package/dist/components/SummaryList/SummaryList.scss +19 -0
  56. package/dist/components/SummaryList/SummaryList.stories.mdx +90 -0
  57. package/dist/components/SummaryList/SummaryList.test.js +400 -0
  58. package/dist/components/SummaryList/SummaryListHeadingRow.js +30 -0
  59. package/dist/components/SummaryList/SummaryListRow.js +5 -2
  60. package/dist/components/SummaryList/helpers/getGroupActionAttributes.js +2 -1
  61. package/dist/components/SummaryList/helpers/getRowActionAttributes.js +2 -1
  62. package/dist/components/TaskList/Task.js +3 -3
  63. package/dist/components/TaskList/Task.test.js +167 -0
  64. package/dist/components/TaskList/TaskList.js +73 -22
  65. package/dist/components/TaskList/TaskList.stories.mdx +164 -0
  66. package/dist/components/TaskList/TaskList.test.js +389 -0
  67. package/dist/components/TaskList/TaskState.js +2 -2
  68. package/dist/components/TaskList/TaskState.test.js +86 -0
  69. package/dist/components/index.js +14 -0
  70. package/dist/context/HooksContext/HooksContext.js +72 -8
  71. package/dist/context/HooksContext/HooksContext.test.js +44 -0
  72. package/dist/context/ValidationContext/ValidationContext.js +38 -28
  73. package/dist/context/ValidationContext/ValidationContext.test.js +84 -0
  74. package/dist/hooks/useAxios.js +10 -12
  75. package/dist/hooks/useGetRequest.js +48 -49
  76. package/dist/hooks/useRefData.js +7 -4
  77. package/dist/index.js +34 -1
  78. package/dist/json/addressDetails.json +149 -0
  79. package/dist/json/areYouACivilServant.json +7 -0
  80. package/dist/json/firstForm.json +94 -0
  81. package/dist/json/grade.json +108 -0
  82. package/dist/json/group.data.json +21 -0
  83. package/dist/json/group.json +402 -0
  84. package/dist/json/groupOfRow.json +137 -0
  85. package/dist/json/groupOfRowData.json +15 -0
  86. package/dist/json/port.json +346 -0
  87. package/dist/json/saveAndContinue.json +98 -0
  88. package/dist/json/sublocation.json +859 -0
  89. package/dist/json/taskList.json +265 -0
  90. package/dist/json/team.json +17351 -0
  91. package/dist/json/terminal.json +81 -0
  92. package/dist/json/userProfile.data.json +21 -0
  93. package/dist/json/userProfile.json +276 -0
  94. package/dist/models/ComponentTypes.js +8 -0
  95. package/dist/models/PageAction.js +4 -1
  96. package/dist/models/TaskStates.js +10 -2
  97. package/dist/models/index.js +16 -1
  98. package/dist/setupTests.js +46 -0
  99. package/dist/utils/CheckYourAnswers/getCYAAction.js +5 -5
  100. package/dist/utils/CheckYourAnswers/getCYAAction.test.js +121 -0
  101. package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.js +6 -2
  102. package/dist/utils/CheckYourAnswers/getCYACollectionChangeAction.test.js +71 -0
  103. package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.js +6 -2
  104. package/dist/utils/CheckYourAnswers/getCYACollectionDeleteAction.test.js +55 -0
  105. package/dist/utils/CheckYourAnswers/getCYARow.js +14 -11
  106. package/dist/utils/CheckYourAnswers/getCYARow.test.js +291 -0
  107. package/dist/utils/CheckYourAnswers/getCYARowForGroup.js +4 -1
  108. package/dist/utils/CheckYourAnswers/getCYARowForGroup.test.js +70 -0
  109. package/dist/utils/CheckYourAnswers/getCYARowsForCollection.js +15 -10
  110. package/dist/utils/CheckYourAnswers/getCYARowsForCollection.test.js +288 -0
  111. package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.js +94 -36
  112. package/dist/utils/CheckYourAnswers/getCYARowsForCollectionPage.test.js +414 -0
  113. package/dist/utils/CheckYourAnswers/getCYARowsForContainer.js +21 -7
  114. package/dist/utils/CheckYourAnswers/getCYARowsForContainer.test.js +486 -0
  115. package/dist/utils/CheckYourAnswers/getCYARowsForPage.js +11 -3
  116. package/dist/utils/CheckYourAnswers/getCYARowsForPage.test.js +346 -0
  117. package/dist/utils/CheckYourAnswers/showComponentCYA.js +19 -3
  118. package/dist/utils/CheckYourAnswers/showComponentCYA.test.js +143 -0
  119. package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.js +5 -1
  120. package/dist/utils/CollectionPage/duplicateCollectionPageActiveEntry.test.js +40 -0
  121. package/dist/utils/CollectionPage/getCollectionPageActiveIndex.test.js +53 -0
  122. package/dist/utils/CollectionPage/mergeCollectionPages.js +25 -17
  123. package/dist/utils/CollectionPage/mergeCollectionPages.test.js +130 -0
  124. package/dist/utils/Component/addShowWhen.js +44 -0
  125. package/dist/utils/Component/addShowWhen.test.js +216 -0
  126. package/dist/utils/Component/applyToComponentTree.js +71 -0
  127. package/dist/utils/Component/applyToComponentTree.test.js +127 -0
  128. package/dist/utils/Component/cleanAttributes.js +8 -2
  129. package/dist/utils/Component/cleanAttributes.test.js +68 -0
  130. package/dist/utils/Component/elevateNestedComponents.js +4 -1
  131. package/dist/utils/Component/elevateNestedComponents.test.js +122 -0
  132. package/dist/utils/Component/getComponent.js +80 -11
  133. package/dist/utils/Component/getComponentTests/getComponent.autocomplete.test.js +4 -4
  134. package/dist/utils/Component/getComponentTests/getComponent.calculation.test.js +25 -24
  135. package/dist/utils/Component/getComponentTests/getComponent.checkboxes.test.js +66 -5
  136. package/dist/utils/Component/getComponentTests/getComponent.date.test.js +2 -2
  137. package/dist/utils/Component/getComponentTests/getComponent.details.test.js +9 -7
  138. package/dist/utils/Component/getComponentTests/getComponent.email.test.js +3 -3
  139. package/dist/utils/Component/getComponentTests/getComponent.file.test.js +3 -3
  140. package/dist/utils/Component/getComponentTests/getComponent.list.test.js +44 -0
  141. package/dist/utils/Component/getComponentTests/{getComponent.textarea.test.js → getComponent.multifile.test.js} +29 -21
  142. package/dist/utils/Component/getComponentTests/getComponent.nested.test.js +159 -83
  143. package/dist/utils/Component/getComponentTests/getComponent.paragraph.test.js +43 -0
  144. package/dist/utils/Component/getComponentTests/getComponent.phoneNumber.test.js +3 -3
  145. package/dist/utils/Component/getComponentTests/getComponent.radios.test.js +55 -5
  146. package/dist/utils/Component/getComponentTests/getComponent.select.test.js +3 -9
  147. package/dist/utils/Component/getComponentTests/getComponent.text.test.js +3 -3
  148. package/dist/utils/Component/getComponentTests/getComponent.textArea.test.js +109 -0
  149. package/dist/utils/Component/getComponentTests/getComponent.time.test.js +7 -7
  150. package/dist/utils/Component/getDefaultValue.js +4 -1
  151. package/dist/utils/Component/getDefaultValue.test.js +50 -0
  152. package/dist/utils/Component/index.js +2 -0
  153. package/dist/utils/Component/isEditable.js +2 -2
  154. package/dist/utils/Component/isEditable.test.js +43 -0
  155. package/dist/utils/Component/optionIsSelected.js +22 -0
  156. package/dist/utils/Component/optionIsSelected.test.js +42 -0
  157. package/dist/utils/Component/setupContainerComponentsPath.js +40 -0
  158. package/dist/utils/Component/setupContainerComponentsPath.test.js +78 -0
  159. package/dist/utils/Component/showComponent.test.js +156 -0
  160. package/dist/utils/Component/wrapInFormGroup.js +1 -1
  161. package/dist/utils/Condition/meetsAllConditions.js +1 -1
  162. package/dist/utils/Condition/meetsAllConditions.test.js +61 -0
  163. package/dist/utils/Condition/meetsCondition.js +74 -4
  164. package/dist/utils/Condition/meetsCondition.test.js +763 -0
  165. package/dist/utils/Condition/meetsOneCondition.js +1 -1
  166. package/dist/utils/Condition/meetsOneCondition.test.js +100 -0
  167. package/dist/utils/Condition/setupConditions.js +6 -3
  168. package/dist/utils/Condition/setupConditions.test.js +33 -0
  169. package/dist/utils/Container/getEditableComponents.test.js +135 -0
  170. package/dist/utils/Container/setupNesting.js +21 -2
  171. package/dist/utils/Container/setupNesting.test.js +145 -0
  172. package/dist/utils/Container/showContainer.test.js +178 -0
  173. package/dist/utils/Data/applyFormula.js +20 -11
  174. package/dist/utils/Data/applyFormula.test.js +263 -0
  175. package/dist/utils/Data/getAutocompleteSource.js +6 -2
  176. package/dist/utils/Data/getAutocompleteSource.test.js +352 -0
  177. package/dist/utils/Data/getDataPath.test.js +48 -0
  178. package/dist/utils/Data/getOptions.js +17 -3
  179. package/dist/utils/Data/getOptions.test.js +140 -0
  180. package/dist/utils/Data/getSourceData.js +2 -2
  181. package/dist/utils/Data/getSourceData.test.js +153 -0
  182. package/dist/utils/Data/refDataToOptions.js +4 -1
  183. package/dist/utils/Data/refDataToOptions.test.js +196 -0
  184. package/dist/utils/Data/setDataItem.test.js +110 -0
  185. package/dist/utils/Data/setupFormData.js +39 -16
  186. package/dist/utils/Data/setupFormData.test.js +410 -0
  187. package/dist/utils/Data/setupRefDataUrlForComponent.js +4 -1
  188. package/dist/utils/Data/setupRefDataUrlForComponent.test.js +131 -0
  189. package/dist/utils/FormPage/applyConditionalProperties.js +35 -0
  190. package/dist/utils/FormPage/applyConditionalProperties.test.js +61 -0
  191. package/dist/utils/FormPage/getFormPage.js +5 -2
  192. package/dist/utils/FormPage/getFormPage.test.js +206 -0
  193. package/dist/utils/FormPage/getFormPages.js +4 -1
  194. package/dist/utils/FormPage/getFormPages.test.js +97 -0
  195. package/dist/utils/FormPage/getPageActions.js +8 -4
  196. package/dist/utils/FormPage/getPageActions.test.js +114 -0
  197. package/dist/utils/FormPage/getParagraphFromText.test.js +27 -0
  198. package/dist/utils/FormPage/index.js +2 -0
  199. package/dist/utils/FormPage/showFormPage.js +2 -2
  200. package/dist/utils/FormPage/showFormPage.test.js +180 -0
  201. package/dist/utils/FormPage/showFormPageCYA.js +1 -0
  202. package/dist/utils/FormPage/showFormPageCYA.test.js +28 -0
  203. package/dist/utils/FormPage/useComponent.js +29 -14
  204. package/dist/utils/FormPage/useComponent.test.js +167 -0
  205. package/dist/utils/Format/formatData.test.js +45 -0
  206. package/dist/utils/Format/formatDataForComponent.js +2 -1
  207. package/dist/utils/Format/formatDataForComponent.test.js +142 -0
  208. package/dist/utils/Format/formatDataForForm.js +4 -1
  209. package/dist/utils/Format/formatDataForForm.test.js +81 -0
  210. package/dist/utils/Format/formatDataForPage.test.js +99 -0
  211. package/dist/utils/Hub/getFormHub.test.js +105 -0
  212. package/dist/utils/Meta/documents/getDocuments.test.js +4 -1
  213. package/dist/utils/Meta/documents/index.js +2 -2
  214. package/dist/utils/Meta/documents/setDocumentsForField.js +31 -0
  215. package/dist/utils/Meta/documents/setDocumentsForField.test.js +59 -0
  216. package/dist/utils/Operate/checkValueIsTruthy.test.js +42 -0
  217. package/dist/utils/Operate/getFirstOf.js +31 -0
  218. package/dist/utils/Operate/getFirstOf.test.js +86 -0
  219. package/dist/utils/Operate/getIndexOfMatchingValueIn.test.js +163 -0
  220. package/dist/utils/Operate/persistValueInFormData.js +2 -1
  221. package/dist/utils/Operate/persistValueInFormData.test.js +115 -0
  222. package/dist/utils/Operate/runPageOperations.js +3 -1
  223. package/dist/utils/Operate/runPageOperations.test.js +105 -0
  224. package/dist/utils/Operate/setValueInFormData.test.js +44 -0
  225. package/dist/utils/Operate/shouldRun.js +16 -13
  226. package/dist/utils/Operate/shouldRun.test.js +66 -0
  227. package/dist/utils/Validate/additional/conditionallyRequired.js +24 -0
  228. package/dist/utils/Validate/additional/conditionallyRequired.test.js +73 -0
  229. package/dist/utils/Validate/additional/index.js +13 -4
  230. package/dist/utils/Validate/additional/mustBeAfter.js +8 -6
  231. package/dist/utils/Validate/additional/mustBeAfter.test.js +15 -1
  232. package/dist/utils/Validate/additional/mustBeBefore.js +9 -5
  233. package/dist/utils/Validate/additional/mustBeBefore.test.js +14 -0
  234. package/dist/utils/Validate/additional/mustBeEarlierDateTime.js +1 -1
  235. package/dist/utils/Validate/additional/mustBeEarlierDateTime.test.js +6 -3
  236. package/dist/utils/Validate/additional/mustBeGreaterThan.js +22 -0
  237. package/dist/utils/Validate/additional/mustBeGreaterThan.test.js +56 -0
  238. package/dist/utils/Validate/additional/mustBeInTheFuture.js +1 -1
  239. package/dist/utils/Validate/additional/mustBeInThePast.js +5 -5
  240. package/dist/utils/Validate/additional/mustBeLessThan.js +7 -6
  241. package/dist/utils/Validate/additional/mustBeLessThan.test.js +11 -1
  242. package/dist/utils/Validate/additional/mustBeNumbersOnly.js +9 -5
  243. package/dist/utils/Validate/additional/mustBeNumbersOnly.test.js +10 -2
  244. package/dist/utils/Validate/additional/mustEnterAtLeastOne.js +1 -0
  245. package/dist/utils/Validate/additional/mustEnterAtLeastOne.test.js +4 -1
  246. package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.js +19 -0
  247. package/dist/utils/Validate/additional/mustHaveLessThanDecimalPlaces.test.js +36 -0
  248. package/dist/utils/Validate/additional/mustSelectOnlyOne.js +29 -0
  249. package/dist/utils/Validate/additional/mustSelectOnlyOne.test.js +52 -0
  250. package/dist/utils/Validate/additional/utils.js +18 -18
  251. package/dist/utils/Validate/index.js +6 -0
  252. package/dist/utils/Validate/validateCollection.js +20 -5
  253. package/dist/utils/Validate/validateCollection.test.js +125 -0
  254. package/dist/utils/Validate/validateComponent.js +36 -20
  255. package/dist/utils/Validate/validateComponent.test.js +365 -0
  256. package/dist/utils/Validate/validateContainer.js +9 -3
  257. package/dist/utils/Validate/validateContainer.test.js +75 -0
  258. package/dist/utils/Validate/validateDate.js +4 -3
  259. package/dist/utils/Validate/validateDate.test.js +114 -0
  260. package/dist/utils/Validate/validateEmail.js +14 -1
  261. package/dist/utils/Validate/validateEmail.test.js +74 -0
  262. package/dist/utils/Validate/validateMultifile.js +32 -0
  263. package/dist/utils/Validate/validateMultifile.test.js +47 -0
  264. package/dist/utils/Validate/validatePage.js +12 -6
  265. package/dist/utils/Validate/validatePage.test.js +472 -0
  266. package/dist/utils/Validate/validateRegex.js +2 -5
  267. package/dist/utils/Validate/validateRegex.test.js +42 -0
  268. package/dist/utils/Validate/validateRequired.js +2 -4
  269. package/dist/utils/Validate/validateRequired.test.js +63 -0
  270. package/dist/utils/Validate/validateTextArea.js +37 -0
  271. package/dist/utils/Validate/validateTextArea.test.js +42 -0
  272. package/dist/utils/Validate/validateTime.js +2 -2
  273. package/dist/utils/Validate/validateTime.test.js +59 -0
  274. package/dist/utils/index.js +4 -1
  275. package/package.json +35 -50
  276. package/dist/utils/Meta/documents/setDocumentForField.js +0 -29
  277. 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.any,
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;
@@ -18,7 +18,8 @@ var getGroupActionAttributes = function getGroupActionAttributes(groupRow) {
18
18
  },
19
19
  tabIndex: '0'
20
20
  };
21
- } else if (groupRow.action.page) {
21
+ }
22
+ if (groupRow.action.page) {
22
23
  return {
23
24
  href: "/".concat(groupRow.action.page)
24
25
  };
@@ -18,7 +18,8 @@ var getRowActionAttributes = function getRowActionAttributes(row) {
18
18
  },
19
19
  tabIndex: '0'
20
20
  };
21
- } else if (row.action.page) {
21
+ }
22
+ if (row.action.page) {
22
23
  return {
23
24
  href: "/".concat(row.action.page)
24
25
  };
@@ -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++) { arr2[i] = arr[i]; } return arr2; }
20
- function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
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.array.isRequired,
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
+ });