@jsonforms/core 3.0.0 → 3.1.0-alpha.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 (194) hide show
  1. package/lib/Helpers.d.ts +1 -1
  2. package/lib/actions/actions.d.ts +6 -5
  3. package/lib/generators/Generate.d.ts +1 -1
  4. package/lib/generators/schema.d.ts +1 -1
  5. package/lib/i18n/i18nTypes.d.ts +3 -2
  6. package/lib/i18n/i18nUtil.d.ts +2 -2
  7. package/lib/jsonforms-core.cjs.js +3 -3
  8. package/lib/jsonforms-core.cjs.js.map +1 -1
  9. package/lib/jsonforms-core.esm.js +2 -2
  10. package/lib/jsonforms-core.esm.js.map +1 -1
  11. package/lib/models/jsonSchema.d.ts +2 -2
  12. package/lib/models/uischema.d.ts +1 -1
  13. package/lib/reducers/cells.d.ts +2 -2
  14. package/lib/reducers/config.d.ts +1 -1
  15. package/lib/reducers/core.d.ts +3 -2
  16. package/lib/reducers/default-data.d.ts +1 -1
  17. package/lib/reducers/i18n.d.ts +1 -1
  18. package/lib/reducers/reducers.d.ts +4 -4
  19. package/lib/reducers/renderers.d.ts +2 -2
  20. package/lib/reducers/selectors.d.ts +6 -6
  21. package/lib/reducers/uischemas.d.ts +2 -2
  22. package/lib/store.d.ts +3 -3
  23. package/lib/testers/testers.d.ts +1 -1
  24. package/lib/util/cell.d.ts +3 -3
  25. package/lib/util/combinators.d.ts +1 -1
  26. package/lib/util/label.d.ts +1 -1
  27. package/lib/util/path.d.ts +6 -3
  28. package/lib/util/renderer.d.ts +5 -5
  29. package/lib/util/resolvers.d.ts +1 -1
  30. package/lib/util/runtime.d.ts +2 -2
  31. package/lib/util/util.d.ts +2 -2
  32. package/lib/util/validator.d.ts +1 -1
  33. package/package.json +7 -3
  34. package/src/Helpers.ts +1 -1
  35. package/src/actions/actions.ts +6 -5
  36. package/src/generators/Generate.ts +1 -1
  37. package/src/generators/schema.ts +1 -1
  38. package/src/i18n/i18nTypes.ts +3 -2
  39. package/src/i18n/i18nUtil.ts +2 -2
  40. package/src/models/jsonSchema.ts +2 -2
  41. package/src/models/uischema.ts +1 -1
  42. package/src/reducers/cells.ts +2 -2
  43. package/src/reducers/config.ts +1 -1
  44. package/src/reducers/core.ts +4 -3
  45. package/src/reducers/default-data.ts +1 -1
  46. package/src/reducers/i18n.ts +1 -1
  47. package/src/reducers/reducers.ts +4 -4
  48. package/src/reducers/renderers.ts +2 -2
  49. package/src/reducers/selectors.ts +6 -6
  50. package/src/reducers/uischemas.ts +2 -2
  51. package/src/store.ts +3 -3
  52. package/src/testers/testers.ts +2 -2
  53. package/src/util/cell.ts +3 -3
  54. package/src/util/combinators.ts +1 -1
  55. package/src/util/label.ts +1 -1
  56. package/src/util/path.ts +6 -3
  57. package/src/util/renderer.ts +5 -5
  58. package/src/util/resolvers.ts +2 -2
  59. package/src/util/runtime.ts +2 -2
  60. package/src/util/util.ts +2 -2
  61. package/src/util/validator.ts +1 -1
  62. package/.nycrc +0 -6
  63. package/docs/assets/css/main.css +0 -1
  64. package/docs/assets/images/icons.png +0 -0
  65. package/docs/assets/images/icons@2x.png +0 -0
  66. package/docs/assets/images/widgets.png +0 -0
  67. package/docs/assets/images/widgets@2x.png +0 -0
  68. package/docs/assets/js/main.js +0 -51
  69. package/docs/assets/js/search.json +0 -1
  70. package/docs/classes/gen.html +0 -406
  71. package/docs/enums/ruleeffect.html +0 -214
  72. package/docs/globals.html +0 -10568
  73. package/docs/index.html +0 -1297
  74. package/docs/interfaces/action.html +0 -166
  75. package/docs/interfaces/addcellrendereraction.html +0 -181
  76. package/docs/interfaces/addrendereraction.html +0 -181
  77. package/docs/interfaces/adduischemaaction.html +0 -181
  78. package/docs/interfaces/andcondition.html +0 -181
  79. package/docs/interfaces/anyaction.html +0 -189
  80. package/docs/interfaces/arraycontrolprops.html +0 -653
  81. package/docs/interfaces/arraylayoutprops.html +0 -648
  82. package/docs/interfaces/categorization.html +0 -281
  83. package/docs/interfaces/category.html +0 -279
  84. package/docs/interfaces/cellprops.html +0 -452
  85. package/docs/interfaces/combinatorrendererprops.html +0 -503
  86. package/docs/interfaces/combinatorsubschemarenderinfo.html +0 -181
  87. package/docs/interfaces/composablecondition.html +0 -193
  88. package/docs/interfaces/condition.html +0 -176
  89. package/docs/interfaces/controlelement.html +0 -280
  90. package/docs/interfaces/controlprops.html +0 -497
  91. package/docs/interfaces/controlstate.html +0 -184
  92. package/docs/interfaces/controlwithdetailprops.html +0 -501
  93. package/docs/interfaces/dispatchcellprops.html +0 -388
  94. package/docs/interfaces/dispatchcellstateprops.html +0 -408
  95. package/docs/interfaces/dispatchpropsofarraycontrol.html +0 -322
  96. package/docs/interfaces/dispatchpropsofcontrol.html +0 -204
  97. package/docs/interfaces/dispatchpropsofmultienumcontrol.html +0 -215
  98. package/docs/interfaces/enumcellprops.html +0 -467
  99. package/docs/interfaces/enumoption.html +0 -167
  100. package/docs/interfaces/formatted.html +0 -226
  101. package/docs/interfaces/grouplayout.html +0 -284
  102. package/docs/interfaces/horizontallayout.html +0 -234
  103. package/docs/interfaces/initaction.html +0 -209
  104. package/docs/interfaces/initactionoptions.html +0 -181
  105. package/docs/interfaces/internationalizable.html +0 -170
  106. package/docs/interfaces/jsonformscellrendererregistryentry.html +0 -167
  107. package/docs/interfaces/jsonformscore.html +0 -251
  108. package/docs/interfaces/jsonformsdefaultdataregistryentry.html +0 -167
  109. package/docs/interfaces/jsonformsextendedstate.html +0 -175
  110. package/docs/interfaces/jsonformsi18nstate.html +0 -181
  111. package/docs/interfaces/jsonformsprops.html +0 -321
  112. package/docs/interfaces/jsonformsrendererregistryentry.html +0 -167
  113. package/docs/interfaces/jsonformsstate.html +0 -170
  114. package/docs/interfaces/jsonformsstore.html +0 -376
  115. package/docs/interfaces/jsonformssubstates.html +0 -276
  116. package/docs/interfaces/jsonformsuischemaregistryentry.html +0 -167
  117. package/docs/interfaces/jsonschema4.html +0 -758
  118. package/docs/interfaces/jsonschema7.html +0 -884
  119. package/docs/interfaces/labelable.html +0 -184
  120. package/docs/interfaces/labeldescription.html +0 -184
  121. package/docs/interfaces/labeled.html +0 -182
  122. package/docs/interfaces/labelelement.html +0 -251
  123. package/docs/interfaces/labelprops.html +0 -339
  124. package/docs/interfaces/layout.html +0 -253
  125. package/docs/interfaces/layoutprops.html +0 -359
  126. package/docs/interfaces/leafcondition.html +0 -209
  127. package/docs/interfaces/orcondition.html +0 -181
  128. package/docs/interfaces/ownpropsofcell.html +0 -321
  129. package/docs/interfaces/ownpropsofcontrol.html +0 -305
  130. package/docs/interfaces/ownpropsofenum.html +0 -161
  131. package/docs/interfaces/ownpropsofenumcell.html +0 -335
  132. package/docs/interfaces/ownpropsofjsonformsrenderer.html +0 -296
  133. package/docs/interfaces/ownpropsoflabel.html +0 -286
  134. package/docs/interfaces/ownpropsoflayout.html +0 -305
  135. package/docs/interfaces/ownpropsofmasterlistitem.html +0 -289
  136. package/docs/interfaces/ownpropsofrenderer.html +0 -292
  137. package/docs/interfaces/referenceschemamap.html +0 -138
  138. package/docs/interfaces/registerdefaultdataaction.html +0 -181
  139. package/docs/interfaces/removecellrendereraction.html +0 -181
  140. package/docs/interfaces/removerendereraction.html +0 -181
  141. package/docs/interfaces/removeuischemaaction.html +0 -167
  142. package/docs/interfaces/rendererprops.html +0 -331
  143. package/docs/interfaces/rule.html +0 -185
  144. package/docs/interfaces/schemabasedcondition.html +0 -202
  145. package/docs/interfaces/scopable.html +0 -171
  146. package/docs/interfaces/scoped.html +0 -183
  147. package/docs/interfaces/setajvaction.html +0 -167
  148. package/docs/interfaces/setconfigaction.html +0 -167
  149. package/docs/interfaces/setlocaleaction.html +0 -167
  150. package/docs/interfaces/setschemaaction.html +0 -167
  151. package/docs/interfaces/settranslatoraction.html +0 -181
  152. package/docs/interfaces/setuischemaaction.html +0 -167
  153. package/docs/interfaces/setvalidationmodeaction.html +0 -167
  154. package/docs/interfaces/statepropsofarraycontrol.html +0 -474
  155. package/docs/interfaces/statepropsofarraylayout.html +0 -461
  156. package/docs/interfaces/statepropsofcell.html +0 -408
  157. package/docs/interfaces/statepropsofcombinator.html +0 -449
  158. package/docs/interfaces/statepropsofcontrol.html +0 -451
  159. package/docs/interfaces/statepropsofcontrolwithdetail.html +0 -463
  160. package/docs/interfaces/statepropsofenumcell.html +0 -422
  161. package/docs/interfaces/statepropsofjsonformsrenderer.html +0 -324
  162. package/docs/interfaces/statepropsoflabel.html +0 -343
  163. package/docs/interfaces/statepropsoflayout.html +0 -369
  164. package/docs/interfaces/statepropsofmasteritem.html +0 -309
  165. package/docs/interfaces/statepropsofrenderer.html +0 -331
  166. package/docs/interfaces/statepropsofscopedrenderer.html +0 -391
  167. package/docs/interfaces/store.html +0 -386
  168. package/docs/interfaces/testercontext.html +0 -184
  169. package/docs/interfaces/uischemaelement.html +0 -225
  170. package/docs/interfaces/unregisterdefaultdataaction.html +0 -167
  171. package/docs/interfaces/updateaction.html +0 -202
  172. package/docs/interfaces/updatecoreaction.html +0 -209
  173. package/docs/interfaces/updateerrorsaction.html +0 -167
  174. package/docs/interfaces/updatei18naction.html +0 -195
  175. package/docs/interfaces/verticallayout.html +0 -234
  176. package/docs/interfaces/withclassname.html +0 -153
  177. package/rollup.config.js +0 -44
  178. package/stats.html +0 -3279
  179. package/test/actions/actions.test.ts +0 -93
  180. package/test/generators/schema.test.ts +0 -224
  181. package/test/generators/uischema.test.ts +0 -576
  182. package/test/i18n/i18nUtil.test.ts +0 -88
  183. package/test/reducers/core.test.ts +0 -1682
  184. package/test/reducers/uischemas.test.ts +0 -173
  185. package/test/testers.test.ts +0 -948
  186. package/test/util/array.test.ts +0 -28
  187. package/test/util/cell.test.ts +0 -354
  188. package/test/util/derivetype.test.ts +0 -101
  189. package/test/util/label.test.ts +0 -364
  190. package/test/util/path.test.ts +0 -259
  191. package/test/util/renderer.test.ts +0 -1830
  192. package/test/util/resolvers.test.ts +0 -157
  193. package/test/util/runtime.test.ts +0 -779
  194. package/tsconfig.json +0 -13
@@ -1,779 +0,0 @@
1
- /*
2
- The MIT License
3
-
4
- Copyright (c) 2017-2019 EclipseSource Munich
5
- https://github.com/eclipsesource/jsonforms
6
-
7
- Permission is hereby granted, free of charge, to any person obtaining a copy
8
- of this software and associated documentation files (the "Software"), to deal
9
- in the Software without restriction, including without limitation the rights
10
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
- copies of the Software, and to permit persons to whom the Software is
12
- furnished to do so, subject to the following conditions:
13
-
14
- The above copyright notice and this permission notice shall be included in
15
- all copies or substantial portions of the Software.
16
-
17
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23
- THE SOFTWARE.
24
- */
25
- import test from 'ava';
26
- import {
27
- AndCondition,
28
- ControlElement,
29
- createAjv,
30
- isInherentlyEnabled,
31
- JsonFormsCore,
32
- LeafCondition,
33
- OrCondition,
34
- RuleEffect,
35
- SchemaBasedCondition
36
- } from '../../src';
37
- import { evalEnablement, evalVisibility } from '../../src/util/runtime';
38
-
39
- test('evalVisibility show valid case', t => {
40
- const leafCondition: LeafCondition = {
41
- type: 'LEAF',
42
- scope: '#/properties/ruleValue',
43
- expectedValue: 'bar'
44
- };
45
- const uischema: ControlElement = {
46
- type: 'Control',
47
- scope: '#/properties/value',
48
- rule: {
49
- effect: RuleEffect.SHOW,
50
- condition: leafCondition
51
- }
52
- };
53
- const data = {
54
- value: 'foo',
55
- ruleValue: 'bar'
56
- };
57
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
58
- });
59
-
60
- test('evalVisibility show valid case based on AndCondition', t => {
61
- const leafCondition1: LeafCondition = {
62
- type: 'LEAF',
63
- scope: '#/properties/ruleValue1',
64
- expectedValue: 'bar'
65
- };
66
- const leafCondition2: LeafCondition = {
67
- type: 'LEAF',
68
- scope: '#/properties/ruleValue2',
69
- expectedValue: 'foo'
70
- };
71
- const condition: AndCondition = {
72
- type: 'AND',
73
- conditions: [leafCondition1, leafCondition2]
74
- };
75
- const uischema: ControlElement = {
76
- type: 'Control',
77
- scope: '#/properties/value',
78
- rule: {
79
- effect: RuleEffect.SHOW,
80
- condition: condition
81
- }
82
- };
83
- const data = {
84
- value: 'hello',
85
- ruleValue1: 'bar',
86
- ruleValue2: 'foo'
87
- };
88
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
89
- });
90
-
91
- test('evalVisibility show invalid case based on AndCondition', t => {
92
- const leafCondition1: LeafCondition = {
93
- type: 'LEAF',
94
- scope: '#/properties/ruleValue1',
95
- expectedValue: 'bar'
96
- };
97
- const leafCondition2: LeafCondition = {
98
- type: 'LEAF',
99
- scope: '#/properties/ruleValue2',
100
- expectedValue: 'bar'
101
- };
102
- const condition: AndCondition = {
103
- type: 'AND',
104
- conditions: [leafCondition1, leafCondition2]
105
- };
106
- const uischema: ControlElement = {
107
- type: 'Control',
108
- scope: '#/properties/value',
109
- rule: {
110
- effect: RuleEffect.SHOW,
111
- condition: condition
112
- }
113
- };
114
- const data = {
115
- value: 'hello',
116
- ruleValue1: 'bar',
117
- ruleValue2: 'foo'
118
- };
119
- t.is(evalVisibility(uischema, data, undefined, createAjv()), false);
120
- });
121
-
122
- test('evalVisibility show valid case based on OrCondition', t => {
123
- const leafCondition1: LeafCondition = {
124
- type: 'LEAF',
125
- scope: '#/properties/ruleValue1',
126
- expectedValue: 'bar'
127
- };
128
- const leafCondition2: LeafCondition = {
129
- type: 'LEAF',
130
- scope: '#/properties/ruleValue2',
131
- expectedValue: 'foo'
132
- };
133
- const condition: OrCondition = {
134
- type: 'OR',
135
- conditions: [leafCondition1, leafCondition2]
136
- };
137
- const uischema: ControlElement = {
138
- type: 'Control',
139
- scope: '#/properties/value',
140
- rule: {
141
- effect: RuleEffect.SHOW,
142
- condition: condition
143
- }
144
- };
145
- const data = {
146
- value: 'hello',
147
- ruleValue1: 'bar1',
148
- ruleValue2: 'foo'
149
- };
150
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
151
- });
152
-
153
- test('evalVisibility show invalid case based on OrCondition', t => {
154
- const leafCondition1: LeafCondition = {
155
- type: 'LEAF',
156
- scope: '#/properties/ruleValue1',
157
- expectedValue: 'foo'
158
- };
159
- const leafCondition2: LeafCondition = {
160
- type: 'LEAF',
161
- scope: '#/properties/ruleValue2',
162
- expectedValue: 'bar'
163
- };
164
- const condition: OrCondition = {
165
- type: 'OR',
166
- conditions: [leafCondition1, leafCondition2]
167
- };
168
- const uischema: ControlElement = {
169
- type: 'Control',
170
- scope: '#/properties/value',
171
- rule: {
172
- effect: RuleEffect.SHOW,
173
- condition: condition
174
- }
175
- };
176
- const data = {
177
- value: 'hello',
178
- ruleValue1: 'bar',
179
- ruleValue2: 'foo'
180
- };
181
- t.is(evalVisibility(uischema, data, undefined, createAjv()), false);
182
- });
183
-
184
- test('evalVisibility show valid case based on schema condition', t => {
185
- const condition: SchemaBasedCondition = {
186
- scope: '#/properties/ruleValue',
187
- schema: {
188
- const: 'bar'
189
- }
190
- };
191
- const uischema: ControlElement = {
192
- type: 'Control',
193
- scope: '#/properties/value',
194
- rule: {
195
- effect: RuleEffect.SHOW,
196
- condition
197
- }
198
- };
199
- const data = {
200
- value: 'foo',
201
- ruleValue: 'bar'
202
- };
203
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
204
- });
205
-
206
- test('evalVisibility show valid case based on schema condition and enum', t => {
207
- const condition: SchemaBasedCondition = {
208
- scope: '#/properties/ruleValue',
209
- schema: {
210
- enum: ['bar', 'baz']
211
- }
212
- };
213
- const uischema: ControlElement = {
214
- type: 'Control',
215
- scope: '#/properties/value',
216
- rule: {
217
- effect: RuleEffect.SHOW,
218
- condition
219
- }
220
- };
221
- const data = {
222
- value: 'foo',
223
- ruleValue: 'bar'
224
- };
225
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
226
- t.is(
227
- evalVisibility(
228
- uischema,
229
- { ...data, ruleValue: 'baz' },
230
- undefined,
231
- createAjv()
232
- ),
233
- true
234
- );
235
- t.is(
236
- evalVisibility(
237
- uischema,
238
- { ...data, ruleValue: 'foo' },
239
- undefined,
240
- createAjv()
241
- ),
242
- false
243
- );
244
- });
245
-
246
- test('evalVisibility show invalid case', t => {
247
- const leafCondition: LeafCondition = {
248
- type: 'LEAF',
249
- scope: '#/properties/ruleValue',
250
- expectedValue: 'bar'
251
- };
252
- const uischema: ControlElement = {
253
- type: 'Control',
254
- scope: '#/properties/value',
255
- rule: {
256
- effect: RuleEffect.SHOW,
257
- condition: leafCondition
258
- }
259
- };
260
- const data = {
261
- value: 'foo',
262
- ruleValue: 'foobar'
263
- };
264
- t.deepEqual(evalVisibility(uischema, data, undefined, createAjv()), false);
265
- });
266
- test('evalVisibility hide valid case', t => {
267
- const leafCondition: LeafCondition = {
268
- type: 'LEAF',
269
- scope: '#/properties/ruleValue',
270
- expectedValue: 'bar'
271
- };
272
- const uischema: ControlElement = {
273
- type: 'Control',
274
- scope: '#/properties/value',
275
- rule: {
276
- effect: RuleEffect.HIDE,
277
- condition: leafCondition
278
- }
279
- };
280
- const data = {
281
- value: 'foo',
282
- ruleValue: 'bar'
283
- };
284
- t.is(evalVisibility(uischema, data, undefined, createAjv()), false);
285
- });
286
-
287
- test('evalVisibility hide invalid case', t => {
288
- const leafCondition: LeafCondition = {
289
- type: 'LEAF',
290
- scope: '#/properties/ruleValue',
291
- expectedValue: 'bar'
292
- };
293
- const uischema: ControlElement = {
294
- type: 'Control',
295
- scope: '#/properties/value',
296
- rule: {
297
- effect: RuleEffect.HIDE,
298
- condition: leafCondition
299
- }
300
- };
301
- const data = {
302
- value: 'foo',
303
- ruleValue: 'foobar'
304
- };
305
- t.is(evalVisibility(uischema, data, undefined, createAjv()), true);
306
- });
307
-
308
- test('evalEnablement enable valid case', t => {
309
- const leafCondition: LeafCondition = {
310
- type: 'LEAF',
311
- scope: '#/properties/ruleValue',
312
- expectedValue: 'bar'
313
- };
314
- const uischema: ControlElement = {
315
- type: 'Control',
316
- scope: '#/properties/value',
317
- rule: {
318
- effect: RuleEffect.ENABLE,
319
- condition: leafCondition
320
- }
321
- };
322
- const data = {
323
- value: 'foo',
324
- ruleValue: 'bar'
325
- };
326
- t.is(evalEnablement(uischema, data, undefined, createAjv()), true);
327
- });
328
-
329
- test('evalEnablement show valid case based on AndCondition', t => {
330
- const leafCondition1: LeafCondition = {
331
- type: 'LEAF',
332
- scope: '#/properties/ruleValue1',
333
- expectedValue: 'bar'
334
- };
335
- const leafCondition2: LeafCondition = {
336
- type: 'LEAF',
337
- scope: '#/properties/ruleValue2',
338
- expectedValue: 'foo'
339
- };
340
- const condition: AndCondition = {
341
- type: 'AND',
342
- conditions: [leafCondition1, leafCondition2]
343
- };
344
- const uischema: ControlElement = {
345
- type: 'Control',
346
- scope: '#/properties/value',
347
- rule: {
348
- effect: RuleEffect.ENABLE,
349
- condition: condition
350
- }
351
- };
352
- const data = {
353
- value: 'hello',
354
- ruleValue1: 'bar',
355
- ruleValue2: 'foo'
356
- };
357
- t.is(evalEnablement(uischema, data, undefined, createAjv()), true);
358
- });
359
-
360
- test('evalEnablement show invalid case based on AndCondition', t => {
361
- const leafCondition1: LeafCondition = {
362
- type: 'LEAF',
363
- scope: '#/properties/ruleValue1',
364
- expectedValue: 'bar'
365
- };
366
- const leafCondition2: LeafCondition = {
367
- type: 'LEAF',
368
- scope: '#/properties/ruleValue2',
369
- expectedValue: 'bar'
370
- };
371
- const condition: AndCondition = {
372
- type: 'AND',
373
- conditions: [leafCondition1, leafCondition2]
374
- };
375
- const uischema: ControlElement = {
376
- type: 'Control',
377
- scope: '#/properties/value',
378
- rule: {
379
- effect: RuleEffect.ENABLE,
380
- condition: condition
381
- }
382
- };
383
- const data = {
384
- value: 'hello',
385
- ruleValue1: 'bar',
386
- ruleValue2: 'foo'
387
- };
388
- t.is(evalEnablement(uischema, data, undefined, createAjv()), false);
389
- });
390
-
391
- test('evalEnablement show valid case based on OrCondition', t => {
392
- const leafCondition1: LeafCondition = {
393
- type: 'LEAF',
394
- scope: '#/properties/ruleValue1',
395
- expectedValue: 'bar'
396
- };
397
- const leafCondition2: LeafCondition = {
398
- type: 'LEAF',
399
- scope: '#/properties/ruleValue2',
400
- expectedValue: 'foo'
401
- };
402
- const condition: OrCondition = {
403
- type: 'OR',
404
- conditions: [leafCondition1, leafCondition2]
405
- };
406
- const uischema: ControlElement = {
407
- type: 'Control',
408
- scope: '#/properties/value',
409
- rule: {
410
- effect: RuleEffect.ENABLE,
411
- condition: condition
412
- }
413
- };
414
- const data = {
415
- value: 'hello',
416
- ruleValue1: 'bar1',
417
- ruleValue2: 'foo'
418
- };
419
- t.is(evalEnablement(uischema, data, undefined, createAjv()), true);
420
- });
421
-
422
- test('evalEnablement show invalid case based on OrCondition', t => {
423
- const leafCondition1: LeafCondition = {
424
- type: 'LEAF',
425
- scope: '#/properties/ruleValue1',
426
- expectedValue: 'foo'
427
- };
428
- const leafCondition2: LeafCondition = {
429
- type: 'LEAF',
430
- scope: '#/properties/ruleValue2',
431
- expectedValue: 'bar'
432
- };
433
- const condition: OrCondition = {
434
- type: 'OR',
435
- conditions: [leafCondition1, leafCondition2]
436
- };
437
- const uischema: ControlElement = {
438
- type: 'Control',
439
- scope: '#/properties/value',
440
- rule: {
441
- effect: RuleEffect.ENABLE,
442
- condition: condition
443
- }
444
- };
445
- const data = {
446
- value: 'hello',
447
- ruleValue1: 'bar',
448
- ruleValue2: 'foo'
449
- };
450
- t.is(evalEnablement(uischema, data, undefined, createAjv()), false);
451
- });
452
-
453
- test('evalEnablement enable invalid case', t => {
454
- const leafCondition: LeafCondition = {
455
- type: 'LEAF',
456
- scope: '#/properties/ruleValue',
457
- expectedValue: 'bar'
458
- };
459
- const uischema: ControlElement = {
460
- type: 'Control',
461
- scope: '#/properties/value',
462
- rule: {
463
- effect: RuleEffect.ENABLE,
464
- condition: leafCondition
465
- }
466
- };
467
- const data = {
468
- value: 'foo',
469
- ruleValue: 'foobar'
470
- };
471
- t.is(evalEnablement(uischema, data, undefined, createAjv()), false);
472
- });
473
- test('evalEnablement disable valid case', t => {
474
- const leafCondition: LeafCondition = {
475
- type: 'LEAF',
476
- scope: '#/properties/ruleValue',
477
- expectedValue: 'bar'
478
- };
479
- const uischema: ControlElement = {
480
- type: 'Control',
481
- scope: '#/properties/value',
482
- rule: {
483
- effect: RuleEffect.DISABLE,
484
- condition: leafCondition
485
- }
486
- };
487
- const data = {
488
- value: 'foo',
489
- ruleValue: 'bar'
490
- };
491
- t.is(evalEnablement(uischema, data, undefined, createAjv()), false);
492
- });
493
-
494
- test('evalEnablement disable invalid case', t => {
495
- const leafCondition: LeafCondition = {
496
- type: 'LEAF',
497
- scope: '#/properties/ruleValue',
498
- expectedValue: 'bar'
499
- };
500
- const uischema: ControlElement = {
501
- type: 'Control',
502
- scope: '#/properties/value',
503
- rule: {
504
- effect: RuleEffect.DISABLE,
505
- condition: leafCondition
506
- }
507
- };
508
- const data = {
509
- value: 'foo',
510
- ruleValue: 'foobar'
511
- };
512
- t.is(evalEnablement(uischema, data, undefined, createAjv()), true);
513
- });
514
-
515
- test('evalEnablement disable invalid case based on schema condition', t => {
516
- const condition: SchemaBasedCondition = {
517
- scope: '#/properties/ruleValue',
518
- schema: {
519
- enum: ['bar', 'baz']
520
- }
521
- };
522
- const uischema: ControlElement = {
523
- type: 'Control',
524
- scope: '#/properties/value',
525
- rule: {
526
- effect: RuleEffect.DISABLE,
527
- condition
528
- }
529
- };
530
- const data = {
531
- value: 'foo',
532
- ruleValue: 'bar'
533
- };
534
- t.is(evalEnablement(uischema, data, undefined, createAjv()), false);
535
- t.is(
536
- evalEnablement(
537
- uischema,
538
- { ...data, ruleValue: 'baz' },
539
- undefined,
540
- createAjv()
541
- ),
542
- false
543
- );
544
- t.is(
545
- evalEnablement(
546
- uischema,
547
- { ...data, ruleValue: 'foo' },
548
- undefined,
549
- createAjv()
550
- ),
551
- true
552
- );
553
- });
554
-
555
- test('isInherentlyEnabled disabled globally', t => {
556
- t.false(
557
- isInherentlyEnabled(
558
- { jsonforms: { readonly: true } },
559
- null,
560
- null,
561
- null,
562
- null,
563
- null
564
- )
565
- );
566
- });
567
-
568
- test('isInherentlyEnabled disabled by ownProps', t => {
569
- t.false(
570
- isInherentlyEnabled(null, { enabled: false }, null, null, null, null)
571
- );
572
- });
573
-
574
- test('isInherentlyEnabled enabled by ownProps', t => {
575
- t.true(isInherentlyEnabled(null, { enabled: true }, null, null, null, null));
576
- });
577
-
578
- test('isInherentlyEnabled disabled by uischema', t => {
579
- t.false(
580
- isInherentlyEnabled(
581
- null,
582
- null,
583
- ({ options: { readonly: true } } as unknown) as ControlElement,
584
- null,
585
- null,
586
- null
587
- )
588
- );
589
- });
590
-
591
- test('isInherentlyEnabled disabled by uischema over ownProps', t => {
592
- t.false(
593
- isInherentlyEnabled(
594
- null,
595
- { enabled: true },
596
- ({ options: { readonly: true } } as unknown) as ControlElement,
597
- null,
598
- null,
599
- null
600
- )
601
- );
602
- });
603
-
604
- test('isInherentlyEnabled enabled by uischema over schema', t => {
605
- t.true(
606
- isInherentlyEnabled(
607
- null,
608
- null,
609
- ({ options: { readonly: false } } as unknown) as ControlElement,
610
- { readOnly: true },
611
- null,
612
- null
613
- )
614
- );
615
- });
616
-
617
- test('isInherentlyEnabled disabled by ownProps over schema enablement', t => {
618
- t.false(
619
- isInherentlyEnabled(
620
- null,
621
- { enabled: false},
622
- null,
623
- { readOnly: false },
624
- null,
625
- null
626
- )
627
- );
628
- });
629
-
630
- test('isInherentlyEnabled disabled by uischema over schema', t => {
631
- t.false(
632
- isInherentlyEnabled(
633
- null,
634
- null,
635
- ({ options: { readonly: true } } as unknown) as ControlElement,
636
- { readOnly: false },
637
- null,
638
- null
639
- )
640
- );
641
- });
642
-
643
- test('isInherentlyEnabled disabled by schema', t => {
644
- t.false(
645
- isInherentlyEnabled(null, null, null, { readOnly: true }, null, null)
646
- );
647
- });
648
-
649
- test('isInherentlyEnabled disabled by schema over ownProps', t => {
650
- t.false(
651
- isInherentlyEnabled(
652
- null,
653
- { enabled: true },
654
- null,
655
- { readOnly: true },
656
- null,
657
- null
658
- )
659
- );
660
- });
661
-
662
- test('isInherentlyEnabled disabled by rule', t => {
663
- const leafCondition: SchemaBasedCondition = {
664
- scope: '#/properties/ruleValue',
665
- schema: { type: 'string', pattern: 'bar' }
666
- };
667
- const uischema: ControlElement = {
668
- type: 'Control',
669
- scope: '#/properties/value',
670
- rule: {
671
- effect: RuleEffect.DISABLE,
672
- condition: leafCondition
673
- }
674
- };
675
- const data = {
676
- value: 'foo',
677
- ruleValue: 'bar'
678
- };
679
-
680
- t.false(
681
- isInherentlyEnabled(
682
- { jsonforms: { core: { ajv: createAjv() } as JsonFormsCore } },
683
- null,
684
- uischema,
685
- null,
686
- data,
687
- null
688
- )
689
- );
690
- });
691
-
692
- test('isInherentlyEnabled disabled by global over rule ', t => {
693
- const leafCondition: SchemaBasedCondition = {
694
- scope: '#/properties/ruleValue',
695
- schema: { type: 'string', pattern: 'bar' }
696
- };
697
- const uischema: ControlElement = {
698
- type: 'Control',
699
- scope: '#/properties/value',
700
- rule: {
701
- effect: RuleEffect.ENABLE,
702
- condition: leafCondition
703
- }
704
- };
705
- const data = {
706
- value: 'foo',
707
- ruleValue: 'bar'
708
- };
709
-
710
- t.false(
711
- isInherentlyEnabled(
712
- {
713
- jsonforms: {
714
- readonly: true,
715
- core: { ajv: createAjv() } as JsonFormsCore
716
- }
717
- },
718
- null,
719
- uischema,
720
- null,
721
- data,
722
- null
723
- )
724
- );
725
- });
726
-
727
- test('isInherentlyEnabled disabled by config', t => {
728
- t.false(
729
- isInherentlyEnabled(null, null, null, null, null, { readonly: true })
730
- );
731
- });
732
-
733
- test('isInherentlyEnabled enabled by config over ownProps', t => {
734
- t.true(
735
- isInherentlyEnabled(null, { enabled: false }, null, null, null, {
736
- readonly: false
737
- })
738
- );
739
- });
740
-
741
- test('isInherentlyEnabled enabled by uischema over config', t => {
742
- t.true(
743
- isInherentlyEnabled(
744
- null,
745
- null,
746
- ({ options: { readonly: false } } as unknown) as ControlElement,
747
- null,
748
- null,
749
- { readonly: true }
750
- )
751
- );
752
- });
753
-
754
- test('isInherentlyEnabled prefer readonly over readOnly', t => {
755
- t.true(
756
- isInherentlyEnabled(
757
- null,
758
- null,
759
- ({ options: { readonly: false, readOnly: true } } as unknown) as ControlElement,
760
- null,
761
- null,
762
- null
763
- )
764
- );
765
- t.false(
766
- isInherentlyEnabled(
767
- null,
768
- null,
769
- ({ options: { readonly: true, readOnly: false } } as unknown) as ControlElement,
770
- null,
771
- null,
772
- null
773
- )
774
- );
775
- });
776
-
777
- test('isInherentlyEnabled enabled', t => {
778
- t.true(isInherentlyEnabled(null, null, null, null, null, null));
779
- });