@beinformed/ui 1.12.0 → 1.13.1

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 (305) hide show
  1. package/CHANGELOG.md +32 -2
  2. package/esm/builder/mergeLayoutHintConfigurations.js +3 -3
  3. package/esm/builder/mergeLayoutHintConfigurations.js.map +1 -1
  4. package/esm/exceptions/ConfigurationException.js +2 -1
  5. package/esm/exceptions/ConfigurationException.js.map +1 -1
  6. package/esm/exceptions/FetchException.js +4 -3
  7. package/esm/exceptions/FetchException.js.map +1 -1
  8. package/esm/exceptions/IllegalArgumentException.js +2 -1
  9. package/esm/exceptions/IllegalArgumentException.js.map +1 -1
  10. package/esm/exceptions/IllegalReturnException.js +2 -1
  11. package/esm/exceptions/IllegalReturnException.js.map +1 -1
  12. package/esm/exceptions/IllegalStateException.js +2 -1
  13. package/esm/exceptions/IllegalStateException.js.map +1 -1
  14. package/esm/exceptions/JsonParseException.js +2 -1
  15. package/esm/exceptions/JsonParseException.js.map +1 -1
  16. package/esm/exceptions/MissingPropertyException.js +2 -1
  17. package/esm/exceptions/MissingPropertyException.js.map +1 -1
  18. package/esm/exceptions/NetworkException.js +2 -1
  19. package/esm/exceptions/NetworkException.js.map +1 -1
  20. package/esm/exceptions/NotAllowedUriException.js +2 -1
  21. package/esm/exceptions/NotAllowedUriException.js.map +1 -1
  22. package/esm/exceptions/NotFoundException.js +2 -1
  23. package/esm/exceptions/NotFoundException.js.map +1 -1
  24. package/esm/exceptions/ServerRequestException.js +2 -1
  25. package/esm/exceptions/ServerRequestException.js.map +1 -1
  26. package/esm/exceptions/ThemePropertyException.js +2 -1
  27. package/esm/exceptions/ThemePropertyException.js.map +1 -1
  28. package/esm/exceptions/TimeoutException.js +2 -1
  29. package/esm/exceptions/TimeoutException.js.map +1 -1
  30. package/esm/exceptions/UnauthorizedException.js +2 -1
  31. package/esm/exceptions/UnauthorizedException.js.map +1 -1
  32. package/esm/exceptions/UnsupportedOperationException.js +2 -1
  33. package/esm/exceptions/UnsupportedOperationException.js.map +1 -1
  34. package/esm/hooks/useContent.js +2 -2
  35. package/esm/hooks/useContent.js.map +1 -1
  36. package/esm/hooks/useDeepCompareEffect.js +2 -1
  37. package/esm/hooks/useDeepCompareEffect.js.map +1 -1
  38. package/esm/hooks/useForm.js.map +1 -1
  39. package/esm/hooks/useModal.js +2 -2
  40. package/esm/hooks/useModal.js.map +1 -1
  41. package/esm/hooks/useModularUI.js +0 -1
  42. package/esm/hooks/useModularUI.js.map +1 -1
  43. package/esm/hooks/useProgressIndicator.js +2 -2
  44. package/esm/i18n/Locale.js +11 -4
  45. package/esm/i18n/Locale.js.map +1 -1
  46. package/esm/i18n/Locales.js +2 -2
  47. package/esm/i18n/Message.js +2 -2
  48. package/esm/i18n/languages.js +2 -1
  49. package/esm/i18n/languages.js.map +1 -1
  50. package/esm/models/attributes/AttributeCollection.js +2 -2
  51. package/esm/models/attributes/AttributeContent.js +58 -30
  52. package/esm/models/attributes/AttributeContent.js.map +1 -1
  53. package/esm/models/attributes/AttributeDataHelper.js +3 -3
  54. package/esm/models/attributes/AttributeDataHelper.js.map +1 -1
  55. package/esm/models/attributes/BooleanAttributeModel.js +2 -2
  56. package/esm/models/attributes/ChoiceAttributeModel.js +2 -2
  57. package/esm/models/attributes/ChoiceAttributeOptionCollection.js +2 -2
  58. package/esm/models/attributes/CompositeAttributeChildCollection.js +2 -2
  59. package/esm/models/attributes/HelptextAttributeModel.js +24 -9
  60. package/esm/models/attributes/HelptextAttributeModel.js.map +1 -1
  61. package/esm/models/attributes/_createAttribute.js +2 -2
  62. package/esm/models/base/ResourceModel.js +2 -2
  63. package/esm/models/caseview/CaseViewModel.js +4 -5
  64. package/esm/models/caseview/CaseViewModel.js.map +1 -1
  65. package/esm/models/concepts/ConceptDetailModel.js +2 -2
  66. package/esm/models/concepts/SourceReferenceModel.js +2 -2
  67. package/esm/models/content/ContentTOCModel.js +2 -2
  68. package/esm/models/filters/AssignmentFilterModel.js +2 -2
  69. package/esm/models/filters/BaseFilterModel.js +2 -2
  70. package/esm/models/filters/ConceptIndexFilterModel.js +2 -1
  71. package/esm/models/filters/ConceptIndexFilterModel.js.map +1 -1
  72. package/esm/models/filters/FilterCollection.js +2 -2
  73. package/esm/models/filters/FilterModel.js +2 -1
  74. package/esm/models/filters/FilterModel.js.map +1 -1
  75. package/esm/models/form/FormModel.js +28 -4
  76. package/esm/models/form/FormModel.js.map +1 -1
  77. package/esm/models/form/FormObjectModel.js +5 -7
  78. package/esm/models/form/FormObjectModel.js.map +1 -1
  79. package/esm/models/grouping/GroupingModel.js +2 -2
  80. package/esm/models/links/normalizeLinkJSON.js +2 -2
  81. package/esm/models/list/ListDetailModel.js +4 -6
  82. package/esm/models/list/ListDetailModel.js.map +1 -1
  83. package/esm/models/list/ListItemCollection.js +38 -0
  84. package/esm/models/list/ListItemCollection.js.map +1 -1
  85. package/esm/models/list/ListItemModel.js +14 -2
  86. package/esm/models/list/ListItemModel.js.map +1 -1
  87. package/esm/models/list/ListModel.js +19 -74
  88. package/esm/models/list/ListModel.js.map +1 -1
  89. package/esm/models/lookup/LookupOptionCollection.js +2 -2
  90. package/esm/models/panels/GroupingPanelModel.js +2 -4
  91. package/esm/models/panels/GroupingPanelModel.js.map +1 -1
  92. package/esm/modularui/ModularUIError.js +2 -1
  93. package/esm/modularui/ModularUIError.js.map +1 -1
  94. package/esm/modularui/ModularUIRequest.js +71 -49
  95. package/esm/modularui/ModularUIRequest.js.map +1 -1
  96. package/esm/react-server/serverUtil.js +2 -2
  97. package/esm/react-theme/createTheme.js +2 -2
  98. package/esm/redux/_i18n/reducer.js +2 -2
  99. package/esm/redux/_modularui/actions.js +2 -2
  100. package/esm/redux/_modularui/connector.js +2 -2
  101. package/esm/redux/_modularui/reducer.js +2 -2
  102. package/esm/redux/_modularui/selectors.js +2 -2
  103. package/esm/redux/reducers/AuthReducer.js +2 -2
  104. package/esm/redux/reducers/ModalsReducer.js +2 -2
  105. package/esm/redux/reducers/NotificationReducer.js +2 -2
  106. package/esm/redux/reducers/PreferencesReducer.js +2 -2
  107. package/esm/redux/reducers/ProgressIndicatorReducer.js +2 -2
  108. package/esm/redux/store/configureStore.js +2 -2
  109. package/esm/utils/browser/Cookies.js +18 -32
  110. package/esm/utils/browser/Cookies.js.map +1 -1
  111. package/esm/utils/fetch/xhr.js +4 -3
  112. package/esm/utils/fetch/xhr.js.map +1 -1
  113. package/lib/builder/mergeLayoutHintConfigurations.js +3 -3
  114. package/lib/builder/mergeLayoutHintConfigurations.js.flow +3 -3
  115. package/lib/builder/mergeLayoutHintConfigurations.js.map +1 -1
  116. package/lib/exceptions/ConfigurationException.js +3 -1
  117. package/lib/exceptions/ConfigurationException.js.map +1 -1
  118. package/lib/exceptions/FetchException.js +5 -3
  119. package/lib/exceptions/FetchException.js.map +1 -1
  120. package/lib/exceptions/IllegalArgumentException.js +3 -1
  121. package/lib/exceptions/IllegalArgumentException.js.map +1 -1
  122. package/lib/exceptions/IllegalReturnException.js +3 -1
  123. package/lib/exceptions/IllegalReturnException.js.map +1 -1
  124. package/lib/exceptions/IllegalStateException.js +3 -1
  125. package/lib/exceptions/IllegalStateException.js.map +1 -1
  126. package/lib/exceptions/JsonParseException.js +3 -1
  127. package/lib/exceptions/JsonParseException.js.map +1 -1
  128. package/lib/exceptions/MissingPropertyException.js +3 -1
  129. package/lib/exceptions/MissingPropertyException.js.map +1 -1
  130. package/lib/exceptions/NetworkException.js +3 -1
  131. package/lib/exceptions/NetworkException.js.map +1 -1
  132. package/lib/exceptions/NotAllowedUriException.js +3 -1
  133. package/lib/exceptions/NotAllowedUriException.js.map +1 -1
  134. package/lib/exceptions/NotFoundException.js +3 -1
  135. package/lib/exceptions/NotFoundException.js.map +1 -1
  136. package/lib/exceptions/ServerRequestException.js +3 -1
  137. package/lib/exceptions/ServerRequestException.js.map +1 -1
  138. package/lib/exceptions/ThemePropertyException.js +3 -1
  139. package/lib/exceptions/ThemePropertyException.js.map +1 -1
  140. package/lib/exceptions/TimeoutException.js +3 -1
  141. package/lib/exceptions/TimeoutException.js.map +1 -1
  142. package/lib/exceptions/UnauthorizedException.js +3 -1
  143. package/lib/exceptions/UnauthorizedException.js.map +1 -1
  144. package/lib/exceptions/UnsupportedOperationException.js +3 -1
  145. package/lib/exceptions/UnsupportedOperationException.js.map +1 -1
  146. package/lib/hooks/useContent.js +2 -2
  147. package/lib/hooks/useContent.js.flow +2 -2
  148. package/lib/hooks/useContent.js.map +1 -1
  149. package/lib/hooks/useDeepCompareEffect.js +2 -1
  150. package/lib/hooks/useDeepCompareEffect.js.flow +1 -1
  151. package/lib/hooks/useDeepCompareEffect.js.map +1 -1
  152. package/lib/hooks/useForm.js.flow +1 -2
  153. package/lib/hooks/useForm.js.map +1 -1
  154. package/lib/hooks/useModal.js +2 -2
  155. package/lib/hooks/useModal.js.flow +1 -1
  156. package/lib/hooks/useModal.js.map +1 -1
  157. package/lib/hooks/useModularUI.js +0 -1
  158. package/lib/hooks/useModularUI.js.flow +0 -2
  159. package/lib/hooks/useModularUI.js.map +1 -1
  160. package/lib/hooks/useProgressIndicator.js +2 -2
  161. package/lib/i18n/Locale.js +11 -5
  162. package/lib/i18n/Locale.js.flow +7 -0
  163. package/lib/i18n/Locale.js.map +1 -1
  164. package/lib/i18n/Locales.js +2 -2
  165. package/lib/i18n/Message.js +2 -2
  166. package/lib/i18n/__tests__/Locale.spec.js.flow +14 -0
  167. package/lib/i18n/languages.js +2 -1
  168. package/lib/i18n/languages.js.flow +1 -0
  169. package/lib/i18n/languages.js.map +1 -1
  170. package/lib/i18n/types.js.flow +1 -0
  171. package/lib/models/attributes/AttributeCollection.js +2 -2
  172. package/lib/models/attributes/AttributeContent.js +59 -31
  173. package/lib/models/attributes/AttributeContent.js.flow +63 -16
  174. package/lib/models/attributes/AttributeContent.js.map +1 -1
  175. package/lib/models/attributes/AttributeDataHelper.js +3 -3
  176. package/lib/models/attributes/AttributeDataHelper.js.flow +1 -0
  177. package/lib/models/attributes/AttributeDataHelper.js.map +1 -1
  178. package/lib/models/attributes/BooleanAttributeModel.js +2 -2
  179. package/lib/models/attributes/ChoiceAttributeModel.js +2 -2
  180. package/lib/models/attributes/ChoiceAttributeOptionCollection.js +2 -2
  181. package/lib/models/attributes/CompositeAttributeChildCollection.js +2 -2
  182. package/lib/models/attributes/HelptextAttributeModel.js +24 -9
  183. package/lib/models/attributes/HelptextAttributeModel.js.flow +18 -5
  184. package/lib/models/attributes/HelptextAttributeModel.js.map +1 -1
  185. package/lib/models/attributes/__tests__/AttributeCollection.spec.js.flow +4 -4
  186. package/lib/models/attributes/__tests__/AttributeContent.spec.js.flow +13 -19
  187. package/lib/models/attributes/__tests__/HelptextAttributeModel.spec.js.flow +18 -10
  188. package/lib/models/attributes/_createAttribute.js +2 -2
  189. package/lib/models/base/ResourceModel.js +2 -2
  190. package/lib/models/caseview/CaseViewModel.js +5 -5
  191. package/lib/models/caseview/CaseViewModel.js.flow +5 -3
  192. package/lib/models/caseview/CaseViewModel.js.map +1 -1
  193. package/lib/models/caseview/__tests__/CaseViewModel.spec.js.flow +43 -4
  194. package/lib/models/concepts/ConceptDetailModel.js +2 -2
  195. package/lib/models/concepts/SourceReferenceModel.js +2 -2
  196. package/lib/models/content/ContentTOCModel.js +2 -2
  197. package/lib/models/filters/AssignmentFilterModel.js +2 -2
  198. package/lib/models/filters/BaseFilterModel.js +2 -2
  199. package/lib/models/filters/ConceptIndexFilterModel.js +3 -1
  200. package/lib/models/filters/ConceptIndexFilterModel.js.map +1 -1
  201. package/lib/models/filters/FilterCollection.js +2 -2
  202. package/lib/models/filters/FilterModel.js +3 -1
  203. package/lib/models/filters/FilterModel.js.map +1 -1
  204. package/lib/models/form/FormModel.js +28 -4
  205. package/lib/models/form/FormModel.js.flow +18 -1
  206. package/lib/models/form/FormModel.js.map +1 -1
  207. package/lib/models/form/FormObjectModel.js +5 -7
  208. package/lib/models/form/FormObjectModel.js.flow +2 -4
  209. package/lib/models/form/FormObjectModel.js.map +1 -1
  210. package/lib/models/form/__tests__/FormModel.getters.spec.js.flow +15 -0
  211. package/lib/models/form/__tests__/FormObjectModel.spec.js.flow +29 -3
  212. package/lib/models/grouping/GroupingModel.js +2 -2
  213. package/lib/models/links/normalizeLinkJSON.js +2 -2
  214. package/lib/models/list/ListDetailModel.js +4 -6
  215. package/lib/models/list/ListDetailModel.js.flow +2 -2
  216. package/lib/models/list/ListDetailModel.js.map +1 -1
  217. package/lib/models/list/ListItemCollection.js +40 -0
  218. package/lib/models/list/ListItemCollection.js.flow +38 -1
  219. package/lib/models/list/ListItemCollection.js.map +1 -1
  220. package/lib/models/list/ListItemModel.js +14 -2
  221. package/lib/models/list/ListItemModel.js.flow +15 -0
  222. package/lib/models/list/ListItemModel.js.map +1 -1
  223. package/lib/models/list/ListModel.js +18 -75
  224. package/lib/models/list/ListModel.js.flow +3 -47
  225. package/lib/models/list/ListModel.js.map +1 -1
  226. package/lib/models/list/__tests__/ListDetailModel.spec.js.flow +5 -3
  227. package/lib/models/list/__tests__/ListItemCollection.spec.js.flow +22 -0
  228. package/lib/models/list/__tests__/ListModel.spec.js.flow +5 -5
  229. package/lib/models/lookup/LookupOptionCollection.js +2 -2
  230. package/lib/models/panels/GroupingPanelModel.js +2 -4
  231. package/lib/models/panels/GroupingPanelModel.js.flow +2 -2
  232. package/lib/models/panels/GroupingPanelModel.js.map +1 -1
  233. package/lib/models/panels/__tests__/GroupingPanelModel.spec.js.flow +43 -24
  234. package/lib/models/process/__tests__/ProcessStatusSettingsModel.spec.js.flow +11 -0
  235. package/lib/models/types.js.flow +3 -3
  236. package/lib/modularui/ModularUIError.js +3 -1
  237. package/lib/modularui/ModularUIError.js.map +1 -1
  238. package/lib/modularui/ModularUIRequest.js +69 -49
  239. package/lib/modularui/ModularUIRequest.js.flow +38 -22
  240. package/lib/modularui/ModularUIRequest.js.map +1 -1
  241. package/lib/react-server/serverUtil.js +2 -2
  242. package/lib/react-theme/createTheme.js +2 -2
  243. package/lib/redux/_i18n/reducer.js +2 -2
  244. package/lib/redux/_modularui/actions.js +2 -2
  245. package/lib/redux/_modularui/connector.js +2 -2
  246. package/lib/redux/_modularui/reducer.js +2 -2
  247. package/lib/redux/_modularui/selectors.js +2 -2
  248. package/lib/redux/reducers/AuthReducer.js +2 -2
  249. package/lib/redux/reducers/ModalsReducer.js +2 -2
  250. package/lib/redux/reducers/NotificationReducer.js +2 -2
  251. package/lib/redux/reducers/PreferencesReducer.js +2 -2
  252. package/lib/redux/reducers/ProgressIndicatorReducer.js +2 -2
  253. package/lib/redux/store/configureStore.js +2 -2
  254. package/lib/utils/browser/Cookies.js +18 -31
  255. package/lib/utils/browser/Cookies.js.flow +22 -28
  256. package/lib/utils/browser/Cookies.js.map +1 -1
  257. package/lib/utils/browser/__tests__/Cookies.spec.js.flow +51 -0
  258. package/lib/utils/fetch/xhr.js +4 -3
  259. package/lib/utils/fetch/xhr.js.flow +3 -1
  260. package/lib/utils/fetch/xhr.js.map +1 -1
  261. package/package.json +36 -34
  262. package/src/builder/mergeLayoutHintConfigurations.js +3 -3
  263. package/src/hooks/useContent.js +2 -2
  264. package/src/hooks/useDeepCompareEffect.js +1 -1
  265. package/src/hooks/useForm.js +1 -2
  266. package/src/hooks/useModal.js +1 -1
  267. package/src/hooks/useModularUI.js +0 -2
  268. package/src/i18n/Locale.js +7 -0
  269. package/src/i18n/__tests__/Locale.spec.js +14 -0
  270. package/src/i18n/languages.js +1 -0
  271. package/src/i18n/types.js +1 -0
  272. package/src/models/attributes/AttributeContent.js +63 -16
  273. package/src/models/attributes/AttributeDataHelper.js +1 -0
  274. package/src/models/attributes/HelptextAttributeModel.js +18 -5
  275. package/src/models/attributes/__mock__/_FormCollectionContribution.json +9 -0
  276. package/src/models/attributes/__mock__/_FormCollectionData.json +12 -3
  277. package/src/models/attributes/__tests__/AttributeCollection.spec.js +4 -4
  278. package/src/models/attributes/__tests__/AttributeContent.spec.js +13 -19
  279. package/src/models/attributes/__tests__/HelptextAttributeModel.spec.js +18 -10
  280. package/src/models/caseview/CaseViewModel.js +5 -3
  281. package/src/models/caseview/__tests__/CaseViewModel.spec.js +43 -4
  282. package/src/models/caseview/__tests__/caseview.json +14 -3
  283. package/src/models/caseview/__tests__/caseviewContributions.json +48 -77
  284. package/src/models/caseview/__tests__/caseview_local_taskgroup.json +57 -0
  285. package/src/models/form/FormModel.js +18 -1
  286. package/src/models/form/FormObjectModel.js +2 -4
  287. package/src/models/form/__tests__/FormModel.getters.spec.js +15 -0
  288. package/src/models/form/__tests__/FormObjectModel.spec.js +29 -3
  289. package/src/models/list/ListDetailModel.js +2 -2
  290. package/src/models/list/ListItemCollection.js +38 -1
  291. package/src/models/list/ListItemModel.js +15 -0
  292. package/src/models/list/ListModel.js +3 -47
  293. package/src/models/list/__tests__/ListDetailModel.spec.js +5 -3
  294. package/src/models/list/__tests__/ListItemCollection.spec.js +22 -0
  295. package/src/models/list/__tests__/ListModel.spec.js +5 -5
  296. package/src/models/panels/GroupingPanelModel.js +2 -2
  297. package/src/models/panels/__tests__/GroupingPanelModel.spec.js +43 -24
  298. package/src/models/panels/__tests__/groupingPanel.json +20 -1
  299. package/src/models/panels/__tests__/groupingPanelContributions.json +14 -1
  300. package/src/models/process/__tests__/ProcessStatusSettingsModel.spec.js +11 -0
  301. package/src/models/types.js +3 -3
  302. package/src/modularui/ModularUIRequest.js +38 -22
  303. package/src/utils/browser/Cookies.js +22 -28
  304. package/src/utils/browser/__tests__/Cookies.spec.js +51 -0
  305. package/src/utils/fetch/xhr.js +3 -1
@@ -2,13 +2,14 @@ import GroupingPanelModel from "../GroupingPanelModel";
2
2
 
3
3
  import panelJson from "./groupingPanel.json";
4
4
  import panelContributionsJson from "./groupingPanelContributions.json";
5
- import CaseViewModel from "../../caseview/CaseViewModel";
6
5
 
7
6
  describe("groupingPanelModel", () => {
8
7
  it("should be able to create an empty GroupingPanelModel object", () => {
9
8
  const groupingPanel = new GroupingPanelModel();
10
9
 
11
10
  expect(groupingPanel).toBeInstanceOf(GroupingPanelModel);
11
+ expect(groupingPanel.type).toBe("GroupingPanel");
12
+ expect(groupingPanel.introtext).toBe("");
12
13
 
13
14
  expect(
14
15
  GroupingPanelModel.isApplicableModel({
@@ -51,10 +52,24 @@ describe("groupingPanelModel", () => {
51
52
  expect(groupingPanel.panelLinks).toHaveLength(1);
52
53
 
53
54
  expect(groupingPanel.hasIntroText()).toBe(true);
55
+
56
+ expect(groupingPanel.getInitialChildModelLinks()).toHaveLength(4);
57
+ });
58
+
59
+ it("can handle local taskgroups", () => {
60
+ const groupingPanel = new GroupingPanelModel({
61
+ key: "AskingQuestions",
62
+ data: panelJson,
63
+ contributions: panelContributionsJson,
64
+ });
65
+
66
+ expect(groupingPanel.hasTaskGroups()).toBe(true);
67
+ expect(groupingPanel.hasTasks()).toBe(true);
68
+ expect(groupingPanel.taskGroupCollection).toHaveLength(1);
54
69
  });
55
70
 
56
71
  it("should be able to handle different kind of introtext", () => {
57
- const groupingPanelOldStructure = new CaseViewModel({
72
+ const groupingPanelOldStructure = new GroupingPanelModel({
58
73
  key: "Book",
59
74
  data: panelJson,
60
75
  contributions: panelContributionsJson,
@@ -64,10 +79,10 @@ describe("groupingPanelModel", () => {
64
79
  "<p>This is introtext</p>"
65
80
  );
66
81
 
67
- const groupingPanelFromDataPlain = new CaseViewModel({
82
+ const groupingPanelFromDataPlain = new GroupingPanelModel({
68
83
  key: "Book",
69
84
  data: {
70
- _text: "<p>This is introtext</p>",
85
+ _content: { text: { message: "<p>This is introtext</p>" } },
71
86
  ...panelJson,
72
87
  },
73
88
  contributions: panelContributionsJson,
@@ -77,12 +92,14 @@ describe("groupingPanelModel", () => {
77
92
  "<p>This is introtext</p>"
78
93
  );
79
94
 
80
- const groupingPanelFromDataApplicationMessage = new CaseViewModel({
95
+ const groupingPanelFromDataApplicationMessage = new GroupingPanelModel({
81
96
  key: "Book",
82
97
  data: {
83
98
  ...panelJson,
84
- _text: {
85
- message: "<p>This is introtext</p>",
99
+ _content: {
100
+ text: {
101
+ message: "<p>This is introtext</p>",
102
+ },
86
103
  },
87
104
  },
88
105
  contributions: panelContributionsJson,
@@ -92,29 +109,31 @@ describe("groupingPanelModel", () => {
92
109
  "<p>This is introtext</p>"
93
110
  );
94
111
 
95
- const groupingPanelFromNewContributionsRawTextMessage = new CaseViewModel({
96
- key: "Book",
97
- data: panelJson,
98
- contributions: {
99
- ...panelContributionsJson,
100
- text: {
101
- message: "<p>This is introtext</p>",
112
+ const groupingPanelFromNewContributionsRawTextMessage =
113
+ new GroupingPanelModel({
114
+ key: "Book",
115
+ data: panelJson,
116
+ contributions: {
117
+ ...panelContributionsJson,
118
+ text: {
119
+ message: "<p>This is introtext</p>",
120
+ },
102
121
  },
103
- },
104
- });
122
+ });
105
123
 
106
124
  expect(groupingPanelFromNewContributionsRawTextMessage.introtext).toBe(
107
125
  "<p>This is introtext</p>"
108
126
  );
109
127
 
110
- const groupingPanelFromNewContributionsSimpleMessage = new CaseViewModel({
111
- key: "Book",
112
- data: panelJson,
113
- contributions: {
114
- ...panelContributionsJson,
115
- text: "<p>This is introtext</p>",
116
- },
117
- });
128
+ const groupingPanelFromNewContributionsSimpleMessage =
129
+ new GroupingPanelModel({
130
+ key: "Book",
131
+ data: panelJson,
132
+ contributions: {
133
+ ...panelContributionsJson,
134
+ text: "<p>This is introtext</p>",
135
+ },
136
+ });
118
137
 
119
138
  expect(groupingPanelFromNewContributionsSimpleMessage.introtext).toBe(
120
139
  "<p>This is introtext</p>"
@@ -1,4 +1,5 @@
1
1
  import ProcessStatusSettingsModel from "../ProcessStatusSettingsModel";
2
+ import { DateUtil } from "../../../utils";
2
3
 
3
4
  describe("processStatusSettingsModel", () => {
4
5
  it("should be able to create an empty ProcessStatusSettingsModel object", () => {
@@ -37,5 +38,15 @@ describe("processStatusSettingsModel", () => {
37
38
  expect(processStatus.isApplicable).toBeTruthy();
38
39
  expect(processStatus.isCompleted).toBeFalsy();
39
40
  expect(processStatus.isNeeded).toBeTruthy();
41
+
42
+ expect(processStatus.state).toBeNull();
43
+ expect(processStatus.canComplete).toBeNull();
44
+
45
+ expect(processStatus.referenceDate).toBe(DateUtil.now());
46
+
47
+ expect(processStatus.links).toHaveLength(1);
48
+ expect(processStatus.conceptLink.href.path).toBe(
49
+ "/concepts/Research grant/Business design/Constraints/Eligible for research grant.bixml/EligibleResearchGrant"
50
+ );
40
51
  });
41
52
  });
@@ -215,21 +215,21 @@ export type ContentElement = {
215
215
  },
216
216
  };
217
217
 
218
- type PropertyElementMapped = {
218
+ export type PropertyElementMapped = {
219
219
  propertyElement: {
220
220
  label: string,
221
221
  layouthint: LayoutHintCollection,
222
222
  properties: Array<PropertyData>,
223
223
  },
224
224
  };
225
- type TextFragmentElementMapped = {
225
+ export type TextFragmentElementMapped = {
226
226
  textFragmentElement: {
227
227
  label: string,
228
228
  layouthint: LayoutHintCollection,
229
229
  textfragments: Array<TextFragmentData>,
230
230
  },
231
231
  };
232
- type ContentElementMapped = {
232
+ export type ContentElementMapped = {
233
233
  contentElement: {
234
234
  label: string,
235
235
  layouthint: LayoutHintCollection,
@@ -9,6 +9,8 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports.default = void 0;
11
11
 
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/createClass"));
13
+
12
14
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck"));
13
15
 
14
16
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/assertThisInitialized"));
@@ -55,7 +57,7 @@ var ModularUIError = /*#__PURE__*/function (_Error) {
55
57
  return _this;
56
58
  }
57
59
 
58
- return ModularUIError;
60
+ return (0, _createClass2.default)(ModularUIError);
59
61
  }( /*#__PURE__*/(0, _wrapNativeSuper2.default)(Error));
60
62
 
61
63
  var _default = ModularUIError;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/modularui/ModularUIError.js"],"names":["ModularUIError","message","response","resource","Error","captureStackTrace"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;AACA;IACMA,c;;;;;AAIJ;AACF;AACE,0BAAYC,OAAZ,EAA6BC,QAA7B,EAA+CC,QAA/C,EAAiE;AAAA;;AAAA;AAC/D,8BAAMF,OAAN;AAD+D;AAAA;AAG/D,UAAKC,QAAL,GAAgBA,QAAhB;AACA,UAAKC,QAAL,GAAgBA,QAAhB,CAJ+D,CAM/D;AACA;AACA;;AACA,QAAIC,KAAK,CAACC,iBAAV,EAA6B;AAC3BD,MAAAA,KAAK,CAACC,iBAAN,8CAA8BL,cAA9B;AACD;;AAX8D;AAYhE;;;+CAlB0BI,K;;eAqBdJ,c","sourcesContent":["// @flow\n/**\n */\nclass ModularUIError extends Error {\n response: Object;\n resource: string;\n\n /**\n */\n constructor(message: string, response: Object, resource: string) {\n super(message);\n\n this.response = response;\n this.resource = resource;\n\n // Without passing ModularUIError to captureStackTrace, the ModularUIError\n // frame would show up in the .stack property. By passing\n // the constructor, we omit that frame, and retain all frames below it.\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, ModularUIError);\n }\n }\n}\n\nexport default ModularUIError;\n"],"file":"ModularUIError.js"}
1
+ {"version":3,"sources":["../../src/modularui/ModularUIError.js"],"names":["ModularUIError","message","response","resource","Error","captureStackTrace"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;AACA;IACMA,c;;;;;AAIJ;AACF;AACE,0BAAYC,OAAZ,EAA6BC,QAA7B,EAA+CC,QAA/C,EAAiE;AAAA;;AAAA;AAC/D,8BAAMF,OAAN;AAD+D;AAAA;AAG/D,UAAKC,QAAL,GAAgBA,QAAhB;AACA,UAAKC,QAAL,GAAgBA,QAAhB,CAJ+D,CAM/D;AACA;AACA;;AACA,QAAIC,KAAK,CAACC,iBAAV,EAA6B;AAC3BD,MAAAA,KAAK,CAACC,iBAAN,8CAA8BL,cAA9B;AACD;;AAX8D;AAYhE;;;+CAlB0BI,K;;eAqBdJ,c","sourcesContent":["// @flow\n/**\n */\nclass ModularUIError extends Error {\n response: Object;\n resource: string;\n\n /**\n */\n constructor(message: string, response: Object, resource: string) {\n super(message);\n\n this.response = response;\n this.resource = resource;\n\n // Without passing ModularUIError to captureStackTrace, the ModularUIError\n // frame would show up in the .stack property. By passing\n // the constructor, we omit that frame, and retain all frames below it.\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, ModularUIError);\n }\n }\n}\n\nexport default ModularUIError;\n"],"file":"ModularUIError.js"}
@@ -87,9 +87,9 @@ function _unsupportedIterableToArray(o, minLen) { var _context9; if (!o) return;
87
87
 
88
88
  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; }
89
89
 
90
- function ownKeys(object, enumerableOnly) { var keys = _Object$keys10(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); if (enumerableOnly) { symbols = _filterInstanceProperty2(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
90
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys10(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty2(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
91
91
 
92
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors) { Object.defineProperties(target, _Object$getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } } return target; }
92
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? Object.defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
93
93
 
94
94
  /**
95
95
  * Helper for fetching data and contributions from the Be Informed modular ui
@@ -540,6 +540,35 @@ var ModularUIRequest = /*#__PURE__*/function () {
540
540
 
541
541
  return _promise.default.resolve();
542
542
  }
543
+ /**
544
+ * Retrieve an object of key: link
545
+ */
546
+
547
+ }, {
548
+ key: "dataLinksPerName",
549
+ value: function dataLinksPerName(dataLinks) {
550
+ if (Array.isArray(dataLinks)) {
551
+ var links = {};
552
+
553
+ var _iterator2 = _createForOfIteratorHelper(dataLinks),
554
+ _step2;
555
+
556
+ try {
557
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
558
+ var dataLink = _step2.value;
559
+ links[dataLink.name] = dataLink;
560
+ }
561
+ } catch (err) {
562
+ _iterator2.e(err);
563
+ } finally {
564
+ _iterator2.f();
565
+ }
566
+
567
+ return links;
568
+ }
569
+
570
+ return dataLinks;
571
+ }
543
572
  /**
544
573
  * Check if links are empty and hide them when hide-when-empty hint exists
545
574
  */
@@ -547,53 +576,44 @@ var ModularUIRequest = /*#__PURE__*/function () {
547
576
  }, {
548
577
  key: "processLinks",
549
578
  value: function processLinks(dataLinks, contributionLinks) {
550
- var _this4 = this;
579
+ var linksPerName = this.dataLinksPerName(dataLinks);
580
+ var hideWhenEmptyLinks = (0, _filter.default)(contributionLinks).call(contributionLinks, function (contributionLink) {
581
+ var _contributionLink$lay;
551
582
 
583
+ return (_contributionLink$lay = contributionLink.layouthint) === null || _contributionLink$lay === void 0 ? void 0 : (0, _includes.default)(_contributionLink$lay).call(_contributionLink$lay, _LayoutHints.HIDE_WHEN_EMPTY);
584
+ });
552
585
  var isHiddenListChecks = [];
553
586
 
554
- var _iterator2 = _createForOfIteratorHelper(contributionLinks),
555
- _step2;
587
+ var _iterator3 = _createForOfIteratorHelper(hideWhenEmptyLinks),
588
+ _step3;
556
589
 
557
590
  try {
558
- var _loop2 = function _loop2() {
559
- var _contributionLink$lay;
560
-
561
- var contributionLink = _step2.value;
562
-
563
- if ((_contributionLink$lay = contributionLink.layouthint) !== null && _contributionLink$lay !== void 0 && (0, _includes.default)(_contributionLink$lay).call(_contributionLink$lay, _LayoutHints.HIDE_WHEN_EMPTY)) {
564
- var dataLink = Array.isArray(dataLinks) ? (0, _find.default)(dataLinks).call(dataLinks, function (link) {
565
- return link.name === contributionLink.name;
566
- }) : dataLinks[contributionLink.name];
591
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
592
+ var contributionLink = _step3.value;
593
+ var dataLink = linksPerName[contributionLink.name];
567
594
 
568
- if (dataLink !== null && dataLink !== void 0 && dataLink.href) {
569
- isHiddenListChecks.push(_this4.isHiddenList(contributionLink.name, dataLink.href));
570
- }
595
+ if (dataLink !== null && dataLink !== void 0 && dataLink.href) {
596
+ isHiddenListChecks.push(this.isHiddenList(contributionLink.name, dataLink.href));
571
597
  }
572
- };
573
-
574
- for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
575
- _loop2();
576
598
  }
577
599
  } catch (err) {
578
- _iterator2.e(err);
600
+ _iterator3.e(err);
579
601
  } finally {
580
- _iterator2.f();
602
+ _iterator3.f();
581
603
  }
582
604
 
583
605
  return _promise.default.all(isHiddenListChecks).then(function (hiddenLinks) {
584
- var newDataLinks;
585
-
586
606
  if (Array.isArray(dataLinks)) {
587
- newDataLinks = (0, _filter.default)(dataLinks).call(dataLinks, function (dataLink) {
607
+ return (0, _filter.default)(dataLinks).call(dataLinks, function (dataLink) {
588
608
  return !(0, _includes.default)(hiddenLinks).call(hiddenLinks, dataLink.name);
589
609
  });
590
- } else {
591
- newDataLinks = {};
610
+ }
592
611
 
593
- for (var dataLinkKey in dataLinks) {
594
- if (!(0, _includes.default)(hiddenLinks).call(hiddenLinks, dataLinkKey)) {
595
- newDataLinks[dataLinkKey] = dataLinks[dataLinkKey];
596
- }
612
+ var newDataLinks = {};
613
+
614
+ for (var dataLinkKey in dataLinks) {
615
+ if (!(0, _includes.default)(hiddenLinks).call(hiddenLinks, dataLinkKey)) {
616
+ newDataLinks[dataLinkKey] = dataLinks[dataLinkKey];
597
617
  }
598
618
  }
599
619
 
@@ -703,31 +723,31 @@ var ModularUIRequest = /*#__PURE__*/function () {
703
723
  }, {
704
724
  key: "fetch",
705
725
  value: function fetch() {
706
- var _this5 = this;
726
+ var _this4 = this;
707
727
 
708
728
  return this.fetchDataService().then(function (data) {
709
729
  if (data == null) {
710
- throw new Error("No data received for ".concat(_this5.href.toString()));
730
+ throw new Error("No data received for ".concat(_this4.href.toString()));
711
731
  }
712
732
 
713
- _this5.processDataService(data);
733
+ _this4.processDataService(data);
714
734
 
715
- return _this5.fetchContributionsService();
735
+ return _this4.fetchContributionsService();
716
736
  }).then(function (contributionsData) {
717
737
  if (contributionsData == null) {
718
- throw new Error("No contributions data received for ".concat(_this5.contributionsHref));
738
+ throw new Error("No contributions data received for ".concat(_this4.contributionsHref));
719
739
  }
720
740
 
721
- _this5.processContributionsService(contributionsData);
741
+ _this4.processContributionsService(contributionsData);
722
742
 
723
- return _this5.processAsyncLayoutHints();
743
+ return _this4.processAsyncLayoutHints();
724
744
  }).then(function () {
725
- return _promise.default.resolve(_this5.createModel());
745
+ return _promise.default.resolve(_this4.createModel());
726
746
  }).then(function (model) {
727
- return _this5.loadDynamicValidations(model);
747
+ return _this4.loadDynamicValidations(model);
728
748
  }).then(function (model) {
729
- if (_this5.withChildModels) {
730
- return _this5.fetchChildModels(model);
749
+ if (_this4.withChildModels) {
750
+ return _this4.fetchChildModels(model);
731
751
  }
732
752
 
733
753
  return _promise.default.resolve(model);
@@ -750,12 +770,12 @@ var ModularUIRequest = /*#__PURE__*/function () {
750
770
  }, {
751
771
  key: "fetchChildModels",
752
772
  value: function fetchChildModels(model) {
753
- var _this6 = this;
773
+ var _this5 = this;
754
774
 
755
775
  var childModelLinks = model.getInitialChildModelLinks();
756
776
  var childModelRequests = (0, _map.default)(childModelLinks).call(childModelLinks, function (childModelLink) {
757
777
  var request = new ModularUIRequest(childModelLink.href, {
758
- locale: _this6.locale
778
+ locale: _this5.locale
759
779
  });
760
780
 
761
781
  if (childModelLink.targetModel) {
@@ -791,11 +811,11 @@ var ModularUIRequest = /*#__PURE__*/function () {
791
811
  }, {
792
812
  key: "fetchContent",
793
813
  value: function fetchContent(withChildSections) {
794
- var _this7 = this;
814
+ var _this6 = this;
795
815
 
796
816
  return this.fetchFromCache().then(function (model) {
797
817
  if (withChildSections && model instanceof _ContentModel.default && model.childSectionLinks.length > 0) {
798
- return _this7.fetchContentChildSections(model);
818
+ return _this6.fetchContentChildSections(model);
799
819
  }
800
820
 
801
821
  return _promise.default.resolve(model);
@@ -809,13 +829,13 @@ var ModularUIRequest = /*#__PURE__*/function () {
809
829
  key: "fetchContentChildSections",
810
830
  value: function fetchContentChildSections(contentModel) {
811
831
  var _context8,
812
- _this8 = this;
832
+ _this7 = this;
813
833
 
814
834
  var newContentModel = contentModel.clone();
815
835
  return _promise.default.all((0, _map.default)(_context8 = contentModel.childSectionLinks).call(_context8, function (childSectionLink) {
816
836
  var contentHrefWithEntryDate = childSectionLink.selfhref.addParameter(_Constants.TIMEVERSION_FILTER_NAME, contentModel.entryDate);
817
837
  var request = new ModularUIRequest(contentHrefWithEntryDate, {
818
- locale: _this8.locale
838
+ locale: _this7.locale
819
839
  });
820
840
  return request.fetchContent(true);
821
841
  })).then(function (sectionModels) {
@@ -386,6 +386,20 @@ class ModularUIRequest {
386
386
  return Promise.resolve();
387
387
  }
388
388
 
389
+ /**
390
+ * Retrieve an object of key: link
391
+ */
392
+ dataLinksPerName(dataLinks: any): { [linkName: string]: any } {
393
+ if (Array.isArray(dataLinks)) {
394
+ const links = {};
395
+ for (const dataLink of dataLinks) {
396
+ links[dataLink.name] = dataLink;
397
+ }
398
+ return links;
399
+ }
400
+ return dataLinks;
401
+ }
402
+
389
403
  /**
390
404
  * Check if links are empty and hide them when hide-when-empty hint exists
391
405
  */
@@ -393,42 +407,44 @@ class ModularUIRequest {
393
407
  dataLinks: any,
394
408
  contributionLinks: any
395
409
  ): Promise<Object | Array<Object>> {
410
+ const linksPerName = this.dataLinksPerName(dataLinks);
411
+ const hideWhenEmptyLinks = contributionLinks.filter((contributionLink) =>
412
+ contributionLink.layouthint?.includes(HIDE_WHEN_EMPTY)
413
+ );
414
+
396
415
  const isHiddenListChecks = [];
397
- for (const contributionLink of contributionLinks) {
398
- if (contributionLink.layouthint?.includes(HIDE_WHEN_EMPTY)) {
399
- const dataLink = Array.isArray(dataLinks)
400
- ? dataLinks.find((link) => link.name === contributionLink.name)
401
- : dataLinks[contributionLink.name];
402
-
403
- if (dataLink?.href) {
404
- isHiddenListChecks.push(
405
- this.isHiddenList(contributionLink.name, dataLink.href)
406
- );
407
- }
416
+
417
+ for (const contributionLink of hideWhenEmptyLinks) {
418
+ const dataLink = linksPerName[contributionLink.name];
419
+ if (dataLink?.href) {
420
+ isHiddenListChecks.push(
421
+ this.isHiddenList(contributionLink.name, dataLink.href)
422
+ );
408
423
  }
409
424
  }
410
425
 
411
- return Promise.all(isHiddenListChecks).then((hiddenLinks) => {
412
- let newDataLinks;
413
- if (Array.isArray(dataLinks)) {
414
- newDataLinks = dataLinks.filter(
415
- (dataLink) => !hiddenLinks.includes(dataLink.name)
416
- );
417
- } else {
418
- newDataLinks = {};
426
+ return Promise.all(isHiddenListChecks).then(
427
+ (hiddenLinks: Array<string>) => {
428
+ if (Array.isArray(dataLinks)) {
429
+ return dataLinks.filter(
430
+ (dataLink) => !hiddenLinks.includes(dataLink.name)
431
+ );
432
+ }
433
+
434
+ const newDataLinks = {};
419
435
  for (const dataLinkKey in dataLinks) {
420
436
  if (!hiddenLinks.includes(dataLinkKey)) {
421
437
  newDataLinks[dataLinkKey] = dataLinks[dataLinkKey];
422
438
  }
423
439
  }
440
+ return newDataLinks;
424
441
  }
425
- return newDataLinks;
426
- });
442
+ );
427
443
  }
428
444
 
429
445
  /**
430
446
  */
431
- isHiddenList(name: string, href: string): Promise<?string> {
447
+ isHiddenList(name: string, href: string): Promise<string> {
432
448
  return universalFetch({
433
449
  ...this.options,
434
450
  url: `${BASE}${href}`,