@beinformed/ui 1.12.1 → 1.13.2

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 (281) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/esm/builder/mergeLayoutHintConfigurations.js +3 -3
  3. package/esm/builder/mergeLayoutHintConfigurations.js.map +1 -1
  4. package/esm/constants/Settings.js +2 -1
  5. package/esm/constants/Settings.js.map +1 -1
  6. package/esm/exceptions/ConfigurationException.js +2 -1
  7. package/esm/exceptions/ConfigurationException.js.map +1 -1
  8. package/esm/exceptions/FetchException.js +4 -3
  9. package/esm/exceptions/FetchException.js.map +1 -1
  10. package/esm/exceptions/IllegalArgumentException.js +2 -1
  11. package/esm/exceptions/IllegalArgumentException.js.map +1 -1
  12. package/esm/exceptions/IllegalReturnException.js +2 -1
  13. package/esm/exceptions/IllegalReturnException.js.map +1 -1
  14. package/esm/exceptions/IllegalStateException.js +2 -1
  15. package/esm/exceptions/IllegalStateException.js.map +1 -1
  16. package/esm/exceptions/JsonParseException.js +2 -1
  17. package/esm/exceptions/JsonParseException.js.map +1 -1
  18. package/esm/exceptions/MissingPropertyException.js +2 -1
  19. package/esm/exceptions/MissingPropertyException.js.map +1 -1
  20. package/esm/exceptions/NetworkException.js +2 -1
  21. package/esm/exceptions/NetworkException.js.map +1 -1
  22. package/esm/exceptions/NotAllowedUriException.js +2 -1
  23. package/esm/exceptions/NotAllowedUriException.js.map +1 -1
  24. package/esm/exceptions/NotFoundException.js +2 -1
  25. package/esm/exceptions/NotFoundException.js.map +1 -1
  26. package/esm/exceptions/ServerRequestException.js +2 -1
  27. package/esm/exceptions/ServerRequestException.js.map +1 -1
  28. package/esm/exceptions/ThemePropertyException.js +2 -1
  29. package/esm/exceptions/ThemePropertyException.js.map +1 -1
  30. package/esm/exceptions/TimeoutException.js +2 -1
  31. package/esm/exceptions/TimeoutException.js.map +1 -1
  32. package/esm/exceptions/UnauthorizedException.js +2 -1
  33. package/esm/exceptions/UnauthorizedException.js.map +1 -1
  34. package/esm/exceptions/UnsupportedOperationException.js +2 -1
  35. package/esm/exceptions/UnsupportedOperationException.js.map +1 -1
  36. package/esm/hooks/useContent.js +2 -2
  37. package/esm/hooks/useContent.js.map +1 -1
  38. package/esm/hooks/useDeepCompareEffect.js +2 -1
  39. package/esm/hooks/useDeepCompareEffect.js.map +1 -1
  40. package/esm/hooks/useForm.js.map +1 -1
  41. package/esm/hooks/useModal.js +2 -2
  42. package/esm/hooks/useModal.js.map +1 -1
  43. package/esm/hooks/useModularUI.js +0 -1
  44. package/esm/hooks/useModularUI.js.map +1 -1
  45. package/esm/hooks/useProgressIndicator.js +2 -2
  46. package/esm/i18n/Locale.js +11 -4
  47. package/esm/i18n/Locale.js.map +1 -1
  48. package/esm/i18n/Locales.js +2 -2
  49. package/esm/i18n/Message.js +2 -2
  50. package/esm/i18n/languages.js +2 -1
  51. package/esm/i18n/languages.js.map +1 -1
  52. package/esm/models/attributes/AttributeCollection.js +2 -2
  53. package/esm/models/attributes/AttributeContent.js +58 -30
  54. package/esm/models/attributes/AttributeContent.js.map +1 -1
  55. package/esm/models/attributes/AttributeDataHelper.js +2 -2
  56. package/esm/models/attributes/BooleanAttributeModel.js +2 -2
  57. package/esm/models/attributes/ChoiceAttributeModel.js +2 -2
  58. package/esm/models/attributes/ChoiceAttributeOptionCollection.js +2 -2
  59. package/esm/models/attributes/CompositeAttributeChildCollection.js +2 -2
  60. package/esm/models/attributes/_createAttribute.js +2 -2
  61. package/esm/models/base/ResourceModel.js +2 -2
  62. package/esm/models/caseview/CaseViewModel.js +2 -1
  63. package/esm/models/caseview/CaseViewModel.js.map +1 -1
  64. package/esm/models/concepts/ConceptDetailModel.js +2 -2
  65. package/esm/models/concepts/SourceReferenceModel.js +2 -2
  66. package/esm/models/content/ContentTOCModel.js +2 -2
  67. package/esm/models/filters/AssignmentFilterModel.js +2 -2
  68. package/esm/models/filters/BaseFilterModel.js +2 -2
  69. package/esm/models/filters/ConceptIndexFilterModel.js +2 -1
  70. package/esm/models/filters/ConceptIndexFilterModel.js.map +1 -1
  71. package/esm/models/filters/FilterCollection.js +2 -2
  72. package/esm/models/filters/FilterModel.js +2 -1
  73. package/esm/models/filters/FilterModel.js.map +1 -1
  74. package/esm/models/form/FormModel.js +28 -4
  75. package/esm/models/form/FormModel.js.map +1 -1
  76. package/esm/models/form/FormObjectModel.js +2 -2
  77. package/esm/models/grouping/GroupingModel.js +2 -2
  78. package/esm/models/links/normalizeLinkJSON.js +2 -2
  79. package/esm/models/list/ListDetailModel.js +2 -2
  80. package/esm/models/list/ListItemCollection.js +38 -0
  81. package/esm/models/list/ListItemCollection.js.map +1 -1
  82. package/esm/models/list/ListItemModel.js +14 -2
  83. package/esm/models/list/ListItemModel.js.map +1 -1
  84. package/esm/models/list/ListModel.js +17 -70
  85. package/esm/models/list/ListModel.js.map +1 -1
  86. package/esm/models/lookup/LookupOptionCollection.js +2 -2
  87. package/esm/modularui/ModularUIError.js +2 -1
  88. package/esm/modularui/ModularUIError.js.map +1 -1
  89. package/esm/modularui/ModularUIRequest.js +71 -49
  90. package/esm/modularui/ModularUIRequest.js.map +1 -1
  91. package/esm/react-server/serverUtil.js +2 -2
  92. package/esm/react-theme/createTheme.js +2 -2
  93. package/esm/redux/_i18n/reducer.js +2 -2
  94. package/esm/redux/_modularui/actions.js +2 -2
  95. package/esm/redux/_modularui/connector.js +2 -2
  96. package/esm/redux/_modularui/reducer.js +2 -2
  97. package/esm/redux/_modularui/selectors.js +2 -2
  98. package/esm/redux/reducers/AuthReducer.js +2 -2
  99. package/esm/redux/reducers/ModalsReducer.js +2 -2
  100. package/esm/redux/reducers/NotificationReducer.js +2 -2
  101. package/esm/redux/reducers/PreferencesReducer.js +2 -2
  102. package/esm/redux/reducers/ProgressIndicatorReducer.js +2 -2
  103. package/esm/redux/store/configureStore.js +2 -2
  104. package/esm/utils/browser/Cookies.js +18 -32
  105. package/esm/utils/browser/Cookies.js.map +1 -1
  106. package/esm/utils/fetch/xhr.js +6 -4
  107. package/esm/utils/fetch/xhr.js.map +1 -1
  108. package/lib/builder/mergeLayoutHintConfigurations.js +3 -3
  109. package/lib/builder/mergeLayoutHintConfigurations.js.flow +3 -3
  110. package/lib/builder/mergeLayoutHintConfigurations.js.map +1 -1
  111. package/lib/constants/Settings.js +2 -1
  112. package/lib/constants/Settings.js.flow +2 -0
  113. package/lib/constants/Settings.js.map +1 -1
  114. package/lib/exceptions/ConfigurationException.js +3 -1
  115. package/lib/exceptions/ConfigurationException.js.map +1 -1
  116. package/lib/exceptions/FetchException.js +5 -3
  117. package/lib/exceptions/FetchException.js.map +1 -1
  118. package/lib/exceptions/IllegalArgumentException.js +3 -1
  119. package/lib/exceptions/IllegalArgumentException.js.map +1 -1
  120. package/lib/exceptions/IllegalReturnException.js +3 -1
  121. package/lib/exceptions/IllegalReturnException.js.map +1 -1
  122. package/lib/exceptions/IllegalStateException.js +3 -1
  123. package/lib/exceptions/IllegalStateException.js.map +1 -1
  124. package/lib/exceptions/JsonParseException.js +3 -1
  125. package/lib/exceptions/JsonParseException.js.map +1 -1
  126. package/lib/exceptions/MissingPropertyException.js +3 -1
  127. package/lib/exceptions/MissingPropertyException.js.map +1 -1
  128. package/lib/exceptions/NetworkException.js +3 -1
  129. package/lib/exceptions/NetworkException.js.map +1 -1
  130. package/lib/exceptions/NotAllowedUriException.js +3 -1
  131. package/lib/exceptions/NotAllowedUriException.js.map +1 -1
  132. package/lib/exceptions/NotFoundException.js +3 -1
  133. package/lib/exceptions/NotFoundException.js.map +1 -1
  134. package/lib/exceptions/ServerRequestException.js +3 -1
  135. package/lib/exceptions/ServerRequestException.js.map +1 -1
  136. package/lib/exceptions/ThemePropertyException.js +3 -1
  137. package/lib/exceptions/ThemePropertyException.js.map +1 -1
  138. package/lib/exceptions/TimeoutException.js +3 -1
  139. package/lib/exceptions/TimeoutException.js.map +1 -1
  140. package/lib/exceptions/UnauthorizedException.js +3 -1
  141. package/lib/exceptions/UnauthorizedException.js.map +1 -1
  142. package/lib/exceptions/UnsupportedOperationException.js +3 -1
  143. package/lib/exceptions/UnsupportedOperationException.js.map +1 -1
  144. package/lib/hooks/useContent.js +2 -2
  145. package/lib/hooks/useContent.js.flow +2 -2
  146. package/lib/hooks/useContent.js.map +1 -1
  147. package/lib/hooks/useDeepCompareEffect.js +2 -1
  148. package/lib/hooks/useDeepCompareEffect.js.flow +1 -1
  149. package/lib/hooks/useDeepCompareEffect.js.map +1 -1
  150. package/lib/hooks/useForm.js.flow +1 -2
  151. package/lib/hooks/useForm.js.map +1 -1
  152. package/lib/hooks/useModal.js +2 -2
  153. package/lib/hooks/useModal.js.flow +1 -1
  154. package/lib/hooks/useModal.js.map +1 -1
  155. package/lib/hooks/useModularUI.js +0 -1
  156. package/lib/hooks/useModularUI.js.flow +0 -2
  157. package/lib/hooks/useModularUI.js.map +1 -1
  158. package/lib/hooks/useProgressIndicator.js +2 -2
  159. package/lib/i18n/Locale.js +11 -5
  160. package/lib/i18n/Locale.js.flow +7 -0
  161. package/lib/i18n/Locale.js.map +1 -1
  162. package/lib/i18n/Locales.js +2 -2
  163. package/lib/i18n/Message.js +2 -2
  164. package/lib/i18n/__tests__/Locale.spec.js.flow +14 -0
  165. package/lib/i18n/languages.js +2 -1
  166. package/lib/i18n/languages.js.flow +1 -0
  167. package/lib/i18n/languages.js.map +1 -1
  168. package/lib/i18n/types.js.flow +1 -0
  169. package/lib/models/attributes/AttributeCollection.js +2 -2
  170. package/lib/models/attributes/AttributeContent.js +59 -31
  171. package/lib/models/attributes/AttributeContent.js.flow +63 -16
  172. package/lib/models/attributes/AttributeContent.js.map +1 -1
  173. package/lib/models/attributes/AttributeDataHelper.js +2 -2
  174. package/lib/models/attributes/BooleanAttributeModel.js +2 -2
  175. package/lib/models/attributes/ChoiceAttributeModel.js +2 -2
  176. package/lib/models/attributes/ChoiceAttributeOptionCollection.js +2 -2
  177. package/lib/models/attributes/CompositeAttributeChildCollection.js +2 -2
  178. package/lib/models/attributes/__tests__/AttributeContent.spec.js.flow +13 -19
  179. package/lib/models/attributes/__tests__/StringAttributeModel.spec.js.flow +1 -1
  180. package/lib/models/attributes/_createAttribute.js +2 -2
  181. package/lib/models/base/ResourceModel.js +2 -2
  182. package/lib/models/base/__tests__/BaseModel.spec.js.flow +5 -5
  183. package/lib/models/caseview/CaseViewModel.js +3 -1
  184. package/lib/models/caseview/CaseViewModel.js.flow +3 -1
  185. package/lib/models/caseview/CaseViewModel.js.map +1 -1
  186. package/lib/models/caseview/__tests__/CaseViewModel.spec.js.flow +38 -1
  187. package/lib/models/concepts/ConceptDetailModel.js +2 -2
  188. package/lib/models/concepts/SourceReferenceModel.js +2 -2
  189. package/lib/models/content/ContentTOCModel.js +2 -2
  190. package/lib/models/filters/AssignmentFilterModel.js +2 -2
  191. package/lib/models/filters/BaseFilterModel.js +2 -2
  192. package/lib/models/filters/ConceptIndexFilterModel.js +3 -1
  193. package/lib/models/filters/ConceptIndexFilterModel.js.map +1 -1
  194. package/lib/models/filters/FilterCollection.js +2 -2
  195. package/lib/models/filters/FilterModel.js +3 -1
  196. package/lib/models/filters/FilterModel.js.map +1 -1
  197. package/lib/models/form/FormModel.js +28 -4
  198. package/lib/models/form/FormModel.js.flow +18 -1
  199. package/lib/models/form/FormModel.js.map +1 -1
  200. package/lib/models/form/FormObjectModel.js +2 -2
  201. package/lib/models/form/__tests__/FormModel.getters.spec.js.flow +15 -0
  202. package/lib/models/grouping/GroupingModel.js +2 -2
  203. package/lib/models/links/normalizeLinkJSON.js +2 -2
  204. package/lib/models/list/ListDetailModel.js +2 -2
  205. package/lib/models/list/ListItemCollection.js +40 -0
  206. package/lib/models/list/ListItemCollection.js.flow +38 -1
  207. package/lib/models/list/ListItemCollection.js.map +1 -1
  208. package/lib/models/list/ListItemModel.js +14 -2
  209. package/lib/models/list/ListItemModel.js.flow +15 -0
  210. package/lib/models/list/ListItemModel.js.map +1 -1
  211. package/lib/models/list/ListModel.js +16 -71
  212. package/lib/models/list/ListModel.js.flow +1 -45
  213. package/lib/models/list/ListModel.js.map +1 -1
  214. package/lib/models/list/__tests__/ListItemCollection.spec.js.flow +22 -0
  215. package/lib/models/list/__tests__/ListModel.spec.js.flow +0 -2
  216. package/lib/models/lookup/LookupOptionCollection.js +2 -2
  217. package/lib/models/panels/__tests__/GroupingPanelModel.spec.js.flow +38 -21
  218. package/lib/models/process/__tests__/ProcessStatusSettingsModel.spec.js.flow +11 -0
  219. package/lib/models/types.js.flow +3 -3
  220. package/lib/modularui/ModularUIError.js +3 -1
  221. package/lib/modularui/ModularUIError.js.map +1 -1
  222. package/lib/modularui/ModularUIRequest.js +69 -49
  223. package/lib/modularui/ModularUIRequest.js.flow +38 -22
  224. package/lib/modularui/ModularUIRequest.js.map +1 -1
  225. package/lib/react-server/serverUtil.js +2 -2
  226. package/lib/react-theme/createTheme.js +2 -2
  227. package/lib/redux/_i18n/reducer.js +2 -2
  228. package/lib/redux/_modularui/actions.js +2 -2
  229. package/lib/redux/_modularui/connector.js +2 -2
  230. package/lib/redux/_modularui/reducer.js +2 -2
  231. package/lib/redux/_modularui/selectors.js +2 -2
  232. package/lib/redux/reducers/AuthReducer.js +2 -2
  233. package/lib/redux/reducers/ModalsReducer.js +2 -2
  234. package/lib/redux/reducers/NotificationReducer.js +2 -2
  235. package/lib/redux/reducers/PreferencesReducer.js +2 -2
  236. package/lib/redux/reducers/ProgressIndicatorReducer.js +2 -2
  237. package/lib/redux/store/configureStore.js +2 -2
  238. package/lib/utils/browser/Cookies.js +18 -31
  239. package/lib/utils/browser/Cookies.js.flow +22 -28
  240. package/lib/utils/browser/Cookies.js.map +1 -1
  241. package/lib/utils/browser/__tests__/Cookies.spec.js.flow +51 -0
  242. package/lib/utils/fetch/xhr.js +7 -4
  243. package/lib/utils/fetch/xhr.js.flow +6 -2
  244. package/lib/utils/fetch/xhr.js.map +1 -1
  245. package/package.json +36 -34
  246. package/src/builder/mergeLayoutHintConfigurations.js +3 -3
  247. package/src/constants/Settings.js +2 -0
  248. package/src/hooks/useContent.js +2 -2
  249. package/src/hooks/useDeepCompareEffect.js +1 -1
  250. package/src/hooks/useForm.js +1 -2
  251. package/src/hooks/useModal.js +1 -1
  252. package/src/hooks/useModularUI.js +0 -2
  253. package/src/i18n/Locale.js +7 -0
  254. package/src/i18n/__tests__/Locale.spec.js +14 -0
  255. package/src/i18n/languages.js +1 -0
  256. package/src/i18n/types.js +1 -0
  257. package/src/models/attributes/AttributeContent.js +63 -16
  258. package/src/models/attributes/__tests__/AttributeContent.spec.js +13 -19
  259. package/src/models/attributes/__tests__/StringAttributeModel.spec.js +1 -1
  260. package/src/models/base/__tests__/BaseModel.spec.js +5 -5
  261. package/src/models/caseview/CaseViewModel.js +3 -1
  262. package/src/models/caseview/__tests__/CaseViewModel.spec.js +38 -1
  263. package/src/models/caseview/__tests__/caseview.json +14 -3
  264. package/src/models/caseview/__tests__/caseviewContributions.json +48 -77
  265. package/src/models/caseview/__tests__/caseview_local_taskgroup.json +57 -0
  266. package/src/models/form/FormModel.js +18 -1
  267. package/src/models/form/__tests__/FormModel.getters.spec.js +15 -0
  268. package/src/models/list/ListItemCollection.js +38 -1
  269. package/src/models/list/ListItemModel.js +15 -0
  270. package/src/models/list/ListModel.js +1 -45
  271. package/src/models/list/__tests__/ListItemCollection.spec.js +22 -0
  272. package/src/models/list/__tests__/ListModel.spec.js +0 -2
  273. package/src/models/panels/__tests__/GroupingPanelModel.spec.js +38 -21
  274. package/src/models/panels/__tests__/groupingPanel.json +20 -1
  275. package/src/models/panels/__tests__/groupingPanelContributions.json +14 -1
  276. package/src/models/process/__tests__/ProcessStatusSettingsModel.spec.js +11 -0
  277. package/src/models/types.js +3 -3
  278. package/src/modularui/ModularUIRequest.js +38 -22
  279. package/src/utils/browser/Cookies.js +22 -28
  280. package/src/utils/browser/__tests__/Cookies.spec.js +51 -0
  281. package/src/utils/fetch/xhr.js +6 -2
@@ -598,6 +598,12 @@ class FormModel extends ResourceModel {
598
598
  return this._redirectLocation || this.successRedirect;
599
599
  }
600
600
 
601
+ /**
602
+ */
603
+ getSuccessData(): Object {
604
+ return this.data.success?.data;
605
+ }
606
+
601
607
  /**
602
608
  * Href handling
603
609
  */
@@ -664,15 +670,26 @@ class FormModel extends ResourceModel {
664
670
  * Handle form tokens to indicate concurrent form use
665
671
  */
666
672
  get tokens(): Array<string> {
667
- return this._tokens ?? this.data.tokens ?? [];
673
+ if (!this._tokens) {
674
+ this._tokens = this.data.tokens ?? [];
675
+ }
676
+ return this._tokens;
668
677
  }
669
678
 
670
679
  /**
680
+ * Replaces all tokens with the given collection of tokens
671
681
  */
672
682
  set tokens(tokens: Array<string>) {
673
683
  this._tokens = tokens;
674
684
  }
675
685
 
686
+ /**
687
+ * Removes all tokens from the form
688
+ */
689
+ removeTokens() {
690
+ this._tokens = [];
691
+ }
692
+
676
693
  /**
677
694
  * Keep track of changed form
678
695
  */
@@ -73,6 +73,21 @@ describe("formModel getters", () => {
73
73
 
74
74
  form.tokens = ["Token"];
75
75
  expect(form.tokens).toHaveLength(1);
76
+
77
+ const formJSON = {
78
+ formresponse: {
79
+ tokens: ["form-token"],
80
+ },
81
+ };
82
+
83
+ const formData = ModularUIResponse.create({
84
+ data: formJSON,
85
+ contributions: FormContributionsJSON,
86
+ });
87
+ const formWithToken = new FormModel(formData);
88
+ expect(formWithToken.tokens).toStrictEqual(["form-token"]);
89
+ formWithToken.removeTokens();
90
+ expect(formWithToken.tokens).toHaveLength(0);
76
91
  });
77
92
 
78
93
  it("can handle last modification", () => {
@@ -1,13 +1,50 @@
1
1
  // @flow
2
2
  import BaseCollection from "../base/BaseCollection";
3
3
  import ActionCollection from "../actions/ActionCollection";
4
+ import ListItemModel from "../list/ListItemModel";
4
5
 
5
- import type ListItemModel from "../list/ListItemModel";
6
+ import ConfigurationException from "../../exceptions/ConfigurationException";
7
+
8
+ import type ListModel from "../list/ListModel";
6
9
 
7
10
  /**
8
11
  * Collection of list items
9
12
  */
10
13
  class ListItemCollection extends BaseCollection<ListItemModel> {
14
+ /**
15
+ * Create a list item collection from the given list
16
+ */
17
+ static createFromList(list: ListModel): ListItemCollection {
18
+ const _embedded = list.getData("_embedded");
19
+ if (_embedded != null) {
20
+ if (Array.isArray(_embedded)) {
21
+ throw new ConfigurationException(
22
+ `One record panel with multiple tables is not supported, place all types in one panel for the panel with key ${list.key}`
23
+ );
24
+ }
25
+
26
+ const dynamicschema = list.getData("dynamicschema");
27
+
28
+ const collection = _embedded.results.map((resultItem) => {
29
+ const [key] = Object.keys(resultItem);
30
+ const listitemData = resultItem[key];
31
+ listitemData.dynamicschema = dynamicschema;
32
+
33
+ const listitemContributions = list.contributions.results[key];
34
+
35
+ return ListItemModel.createFromListResult(
36
+ key,
37
+ listitemData,
38
+ listitemContributions
39
+ );
40
+ });
41
+
42
+ return new ListItemCollection(collection);
43
+ }
44
+
45
+ return new ListItemCollection();
46
+ }
47
+
11
48
  /**
12
49
  */
13
50
  get additionalDetailRoutePath(): string {
@@ -14,6 +14,21 @@ import type LinkCollection from "../links/LinkCollection";
14
14
  * List Item
15
15
  */
16
16
  export default class ListItemModel extends DetailModel {
17
+ /**
18
+ */
19
+ static createFromListResult(
20
+ key: string,
21
+ data: Object,
22
+ contributions: Object
23
+ ): ListItemModel {
24
+ const listitemInput = new ModularUIResponse();
25
+ listitemInput.key = key;
26
+ listitemInput.data = data;
27
+ listitemInput.contributions = contributions;
28
+
29
+ return new ListItemModel(listitemInput);
30
+ }
31
+
17
32
  /**
18
33
  */
19
34
  static createFromChoiceAttributeOption(
@@ -1,6 +1,4 @@
1
1
  // @flow
2
- import { ConfigurationException } from "../../exceptions";
3
-
4
2
  import ModularUIResponse from "../../modularui/ModularUIResponse";
5
3
 
6
4
  import ListItemCollection from "../list/ListItemCollection";
@@ -113,54 +111,12 @@ export default class ListModel extends ResourceModel {
113
111
  return "";
114
112
  }
115
113
 
116
- /**
117
- * Create a listitem collection from the data and contributions of a list
118
- */
119
- createListItemCollection(): ListItemCollection {
120
- const listitemCollection = new ListItemCollection();
121
-
122
- const _embedded = this.getData("_embedded");
123
- if (_embedded !== null) {
124
- if (Array.isArray(_embedded)) {
125
- throw new ConfigurationException(
126
- `One record panel with multiple tables is not supported, place all types in one panel for the panel with key ${this.key}`
127
- );
128
- }
129
-
130
- listitemCollection.collection = _embedded.results.map((result) =>
131
- this.createListItem(result)
132
- );
133
- }
134
-
135
- return listitemCollection;
136
- }
137
-
138
- /**
139
- * Create a ListItem
140
- */
141
- createListItem(resultItem: Object): ListItemModel {
142
- const [key] = Object.keys(resultItem);
143
- const listitemData = resultItem[key];
144
- const listitemContributions = this.contributions.results[key];
145
-
146
- if (this.data.dynamicschema) {
147
- listitemData.dynamicschema = this.data.dynamicschema;
148
- }
149
-
150
- const listitemModelInput = new ModularUIResponse();
151
- listitemModelInput.key = key;
152
- listitemModelInput.data = listitemData;
153
- listitemModelInput.contributions = listitemContributions;
154
-
155
- return new ListItemModel(listitemModelInput);
156
- }
157
-
158
114
  /**
159
115
  * Getting the results
160
116
  */
161
117
  get listItemCollection(): ListItemCollection {
162
118
  if (!this._listItemCollection) {
163
- this._listItemCollection = this.createListItemCollection();
119
+ this._listItemCollection = ListItemCollection.createFromList(this);
164
120
  }
165
121
 
166
122
  return this._listItemCollection;
@@ -0,0 +1,22 @@
1
+ import ListItemCollection from "../ListItemCollection";
2
+
3
+ import caselist from "../__mock__/caselist";
4
+
5
+ describe("listItemCollection spec", () => {
6
+ it("should be able to create an empty collection", () => {
7
+ const collection = new ListItemCollection();
8
+
9
+ expect(collection).toBeInstanceOf(ListItemCollection);
10
+ expect(collection.additionalDetailRoutePath).toBe("__NON_EXISTING_ROUTE__");
11
+ });
12
+
13
+ it("can create a ListItemCollection from list items", () => {
14
+ const collection = ListItemCollection.createFromList(caselist);
15
+ expect(collection).toBeInstanceOf(ListItemCollection);
16
+
17
+ expect(collection.additionalDetailRoutePath).toBe(
18
+ "(/books/books/34/contributors|/books/books/34/publishedbypublishinghouse|/books/books/35/contributors|/books/books/35/publishedbypublishinghouse|/books/books/36/contributors|/books/books/36/publishedbypublishinghouse|/books/books/37/contributors|/books/books/37/publishedbypublishinghouse|/books/books/38/contributors|/books/books/38/publishedbypublishinghouse|/books/books/39/contributors|/books/books/39/publishedbypublishinghouse|/books/books/42/contributors|/books/books/42/publishedbypublishinghouse|/books/books/45/contributors|/books/books/45/publishedbypublishinghouse|/books/books/46/contributors|/books/books/46/publishedbypublishinghouse|/books/books/47/contributors|/books/books/47/publishedbypublishinghouse)"
19
+ );
20
+ expect(collection.actionCollection).toHaveLength(42);
21
+ });
22
+ });
@@ -24,8 +24,6 @@ describe("listModel spec", () => {
24
24
  expect(list.headers).toHaveLength(0);
25
25
 
26
26
  expect(list.introtext).toBe("");
27
-
28
- expect(typeof list.createListItem).toBe("function");
29
27
  });
30
28
 
31
29
  it("should be able to create a list from a typical modular ui response", () => {
@@ -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,7 +79,7 @@ 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
85
  _content: { text: { message: "<p>This is introtext</p>" } },
@@ -77,7 +92,7 @@ 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,
@@ -94,29 +109,31 @@ describe("groupingPanelModel", () => {
94
109
  "<p>This is introtext</p>"
95
110
  );
96
111
 
97
- const groupingPanelFromNewContributionsRawTextMessage = new CaseViewModel({
98
- key: "Book",
99
- data: panelJson,
100
- contributions: {
101
- ...panelContributionsJson,
102
- text: {
103
- 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
+ },
104
121
  },
105
- },
106
- });
122
+ });
107
123
 
108
124
  expect(groupingPanelFromNewContributionsRawTextMessage.introtext).toBe(
109
125
  "<p>This is introtext</p>"
110
126
  );
111
127
 
112
- const groupingPanelFromNewContributionsSimpleMessage = new CaseViewModel({
113
- key: "Book",
114
- data: panelJson,
115
- contributions: {
116
- ...panelContributionsJson,
117
- text: "<p>This is introtext</p>",
118
- },
119
- });
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
+ });
120
137
 
121
138
  expect(groupingPanelFromNewContributionsSimpleMessage.introtext).toBe(
122
139
  "<p>This is introtext</p>"
@@ -26,5 +26,24 @@
26
26
  "name": "TextFragments"
27
27
  }
28
28
  ]
29
- }
29
+ },
30
+ "taskgroups": [
31
+ {
32
+ "name": "taskgroup",
33
+ "actions": [
34
+ {
35
+ "name": "delivery",
36
+ "method": "POST",
37
+ "href": "/books/book/24/activities/delivery",
38
+ "fields": [
39
+ {
40
+ "name": "PrintAssignmentID",
41
+ "type": "number",
42
+ "value": null
43
+ }
44
+ ]
45
+ }
46
+ ]
47
+ }
48
+ ]
30
49
  }
@@ -42,5 +42,18 @@
42
42
  "resourcetype": "TaskGroup"
43
43
  }
44
44
  ]
45
- }
45
+ },
46
+ "taskgroups": [
47
+ {
48
+ "name": "taskgroup",
49
+ "label": "taskgroup",
50
+ "actions": [
51
+ {
52
+ "name": "delivery",
53
+ "label": "delivery",
54
+ "type": "form"
55
+ }
56
+ ]
57
+ }
58
+ ]
46
59
  }
@@ -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,
@@ -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}`,
@@ -1,4 +1,6 @@
1
1
  // @flow
2
+ import Cookies from "js-cookie";
3
+
2
4
  import { BASE } from "../../constants/Constants";
3
5
 
4
6
  type CookieOptions = {
@@ -7,18 +9,17 @@ type CookieOptions = {
7
9
  secure?: boolean,
8
10
  };
9
11
 
12
+ type CookieAttributes = {
13
+ path: string,
14
+ expires?: number,
15
+ sameSite?: string,
16
+ secure?: boolean,
17
+ };
18
+
10
19
  /**
11
20
  */
12
21
  const getCookie = (name: string): null | string => {
13
- if (typeof document !== "undefined") {
14
- const value = `;${document.cookie}`;
15
- const parts = value.split(`; ${name}=`);
16
- if (parts.length === 2) {
17
- return parts.pop().split(";").shift();
18
- }
19
- }
20
-
21
- return null;
22
+ return Cookies.get(name);
22
23
  };
23
24
 
24
25
  /**
@@ -28,31 +29,24 @@ const setCookie = (
28
29
  value: any,
29
30
  { days, sameSite = "Strict", secure }: CookieOptions = {}
30
31
  ) => {
31
- if (typeof document !== "undefined") {
32
- const valuePart = `${name}=${value || ""}`;
33
-
34
- let expires = "";
35
- if (days) {
36
- const date = new Date();
37
- date.setTime(date.getTime() + days * 24 * 60 * 60 * 1000);
38
- expires = `; expires=${date.toUTCString()}`;
39
- }
40
- let sameSitePart = "";
41
- if (sameSite) {
42
- sameSitePart = `; SameSite=${sameSite}`;
43
- }
44
- const securePart = secure ? "Secure" : "";
45
-
46
- document.cookie = `${valuePart}${expires}${sameSitePart}${securePart}; path=${BASE}`;
32
+ const attributes: CookieAttributes = { path: BASE };
33
+ if (days) {
34
+ attributes.expires = days;
35
+ }
36
+ if (sameSite) {
37
+ attributes.sameSite = sameSite;
38
+ }
39
+ if (secure) {
40
+ attributes.secure = secure;
47
41
  }
42
+
43
+ Cookies.set(name, value, attributes);
48
44
  };
49
45
 
50
46
  /**
51
47
  */
52
48
  const clearCookie = (name: string) => {
53
- if (typeof document !== "undefined") {
54
- document.cookie = `${name}=; Max-Age=-99999999;`;
55
- }
49
+ Cookies.remove(name, { path: BASE });
56
50
  };
57
51
 
58
52
  export { getCookie, setCookie, clearCookie };
@@ -0,0 +1,51 @@
1
+ import { getCookie, setCookie, clearCookie } from "../Cookies";
2
+
3
+ describe("cookies util", () => {
4
+ beforeEach(() => {
5
+ Object.defineProperty(
6
+ window.document,
7
+ "cookie",
8
+ (function (cookies) {
9
+ return {
10
+ get: function _get() {
11
+ const output = [];
12
+ for (const cookieName in cookies) {
13
+ output.push(cookieName + "=" + cookies[cookieName]);
14
+ }
15
+ return output.join("; ");
16
+ },
17
+ set: function _set(s) {
18
+ const indexOfSeparator = s.indexOf("=");
19
+ const key = s.substr(0, indexOfSeparator);
20
+ const value = s.substring(indexOfSeparator + 1);
21
+ const valueWithoutAttributes = value.substr(0, value.indexOf(";"));
22
+
23
+ if (valueWithoutAttributes === "") {
24
+ delete cookies[key];
25
+ } else {
26
+ cookies[key] = value;
27
+ }
28
+ return key + "=" + value;
29
+ },
30
+ reset: function _reset() {
31
+ cookies = {};
32
+ },
33
+ configurable: true,
34
+ };
35
+ })({})
36
+ );
37
+ });
38
+
39
+ it("should be able retrieve cookies by name", () => {
40
+ setCookie("newCookie", "test");
41
+ expect(getCookie("newCookie")).toBe("test");
42
+
43
+ setCookie("newCookie2", "test2");
44
+ expect(getCookie("newCookie")).toBe("test");
45
+ expect(getCookie("newCookie2")).toBe("test2");
46
+
47
+ clearCookie("newCookie2");
48
+ expect(getCookie("newCookie")).toBe("test");
49
+ expect(getCookie("newCookie2")).toBeUndefined();
50
+ });
51
+ });