@platforma-sdk/model 1.53.10 → 1.53.13

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 (288) hide show
  1. package/dist/annotations/converter.cjs +11 -11
  2. package/dist/annotations/converter.cjs.map +1 -1
  3. package/dist/annotations/converter.d.ts +1 -1
  4. package/dist/annotations/converter.d.ts.map +1 -1
  5. package/dist/annotations/converter.js +11 -11
  6. package/dist/annotations/converter.js.map +1 -1
  7. package/dist/annotations/index.d.ts +2 -2
  8. package/dist/annotations/types.d.ts +4 -4
  9. package/dist/bconfig/index.d.ts +5 -5
  10. package/dist/bconfig/lambdas.d.ts +7 -7
  11. package/dist/bconfig/lambdas.d.ts.map +1 -1
  12. package/dist/bconfig/normalization.cjs.map +1 -1
  13. package/dist/bconfig/normalization.d.ts +3 -3
  14. package/dist/bconfig/normalization.js.map +1 -1
  15. package/dist/bconfig/types.cjs.map +1 -1
  16. package/dist/bconfig/types.d.ts +2 -2
  17. package/dist/bconfig/types.d.ts.map +1 -1
  18. package/dist/bconfig/types.js.map +1 -1
  19. package/dist/bconfig/util.d.ts +4 -4
  20. package/dist/bconfig/v3.d.ts +3 -3
  21. package/dist/block_api_v1.d.ts +2 -2
  22. package/dist/block_api_v1.d.ts.map +1 -1
  23. package/dist/block_api_v2.d.ts +2 -2
  24. package/dist/block_api_v2.d.ts.map +1 -1
  25. package/dist/block_api_v3.d.ts +3 -3
  26. package/dist/block_migrations.cjs +10 -10
  27. package/dist/block_migrations.cjs.map +1 -1
  28. package/dist/block_migrations.d.ts.map +1 -1
  29. package/dist/block_migrations.js +10 -10
  30. package/dist/block_migrations.js.map +1 -1
  31. package/dist/block_model.cjs +11 -11
  32. package/dist/block_model.cjs.map +1 -1
  33. package/dist/block_model.d.ts +8 -8
  34. package/dist/block_model.d.ts.map +1 -1
  35. package/dist/block_model.js +11 -11
  36. package/dist/block_model.js.map +1 -1
  37. package/dist/block_state_patch.d.ts +2 -2
  38. package/dist/block_state_util.cjs +1 -1
  39. package/dist/block_state_util.cjs.map +1 -1
  40. package/dist/block_state_util.d.ts +3 -3
  41. package/dist/block_state_util.js +1 -1
  42. package/dist/block_state_util.js.map +1 -1
  43. package/dist/block_storage.cjs +10 -10
  44. package/dist/block_storage.cjs.map +1 -1
  45. package/dist/block_storage.d.ts +2 -2
  46. package/dist/block_storage.d.ts.map +1 -1
  47. package/dist/block_storage.js +10 -10
  48. package/dist/block_storage.js.map +1 -1
  49. package/dist/block_storage_vm.cjs +22 -22
  50. package/dist/block_storage_vm.cjs.map +1 -1
  51. package/dist/block_storage_vm.d.ts +1 -1
  52. package/dist/block_storage_vm.d.ts.map +1 -1
  53. package/dist/block_storage_vm.js +22 -22
  54. package/dist/block_storage_vm.js.map +1 -1
  55. package/dist/builder.cjs +32 -23
  56. package/dist/builder.cjs.map +1 -1
  57. package/dist/builder.d.ts +7 -7
  58. package/dist/builder.d.ts.map +1 -1
  59. package/dist/builder.js +32 -23
  60. package/dist/builder.js.map +1 -1
  61. package/dist/components/PFrameForGraphs.cjs +7 -6
  62. package/dist/components/PFrameForGraphs.cjs.map +1 -1
  63. package/dist/components/PFrameForGraphs.d.ts +4 -4
  64. package/dist/components/PFrameForGraphs.d.ts.map +1 -1
  65. package/dist/components/PFrameForGraphs.js +7 -6
  66. package/dist/components/PFrameForGraphs.js.map +1 -1
  67. package/dist/components/PlAnnotations/filter.d.ts +14 -14
  68. package/dist/components/PlAnnotations/filter.d.ts.map +1 -1
  69. package/dist/components/PlAnnotations/filters_ui.cjs +46 -46
  70. package/dist/components/PlAnnotations/filters_ui.cjs.map +1 -1
  71. package/dist/components/PlAnnotations/filters_ui.d.ts +10 -34
  72. package/dist/components/PlAnnotations/filters_ui.d.ts.map +1 -1
  73. package/dist/components/PlAnnotations/filters_ui.js +46 -46
  74. package/dist/components/PlAnnotations/filters_ui.js.map +1 -1
  75. package/dist/components/PlAnnotations/index.d.ts +2 -2
  76. package/dist/components/PlAnnotations/types.d.ts +2 -2
  77. package/dist/components/PlDataTable.cjs +19 -20
  78. package/dist/components/PlDataTable.cjs.map +1 -1
  79. package/dist/components/PlDataTable.d.ts +27 -27
  80. package/dist/components/PlDataTable.d.ts.map +1 -1
  81. package/dist/components/PlDataTable.js +19 -20
  82. package/dist/components/PlDataTable.js.map +1 -1
  83. package/dist/components/PlMultiSequenceAlignment.cjs +2 -2
  84. package/dist/components/PlMultiSequenceAlignment.cjs.map +1 -1
  85. package/dist/components/PlMultiSequenceAlignment.d.ts +6 -6
  86. package/dist/components/PlMultiSequenceAlignment.d.ts.map +1 -1
  87. package/dist/components/PlMultiSequenceAlignment.js +2 -2
  88. package/dist/components/PlMultiSequenceAlignment.js.map +1 -1
  89. package/dist/components/PlSelectionModel.cjs.map +1 -1
  90. package/dist/components/PlSelectionModel.d.ts +1 -1
  91. package/dist/components/PlSelectionModel.js.map +1 -1
  92. package/dist/components/index.d.ts +5 -5
  93. package/dist/config/actions.cjs +39 -39
  94. package/dist/config/actions.cjs.map +1 -1
  95. package/dist/config/actions.d.ts +9 -9
  96. package/dist/config/actions.d.ts.map +1 -1
  97. package/dist/config/actions.js +39 -39
  98. package/dist/config/actions.js.map +1 -1
  99. package/dist/config/actions_kinds.d.ts +30 -30
  100. package/dist/config/actions_kinds.d.ts.map +1 -1
  101. package/dist/config/index.d.ts +6 -6
  102. package/dist/config/model.d.ts +28 -28
  103. package/dist/config/model_meta.d.ts +1 -1
  104. package/dist/config/type_engine.d.ts +3 -3
  105. package/dist/config/type_util.d.ts +2 -2
  106. package/dist/env_value.cjs +1 -1
  107. package/dist/env_value.cjs.map +1 -1
  108. package/dist/env_value.js +1 -1
  109. package/dist/env_value.js.map +1 -1
  110. package/dist/filters/converter.cjs +36 -32
  111. package/dist/filters/converter.cjs.map +1 -1
  112. package/dist/filters/converter.d.ts +2 -2
  113. package/dist/filters/converter.d.ts.map +1 -1
  114. package/dist/filters/converter.js +36 -32
  115. package/dist/filters/converter.js.map +1 -1
  116. package/dist/filters/index.d.ts +2 -2
  117. package/dist/filters/types.d.ts +33 -33
  118. package/dist/filters/types.d.ts.map +1 -1
  119. package/dist/index.d.ts +24 -24
  120. package/dist/internal.cjs +7 -7
  121. package/dist/internal.cjs.map +1 -1
  122. package/dist/internal.d.ts +4 -4
  123. package/dist/internal.d.ts.map +1 -1
  124. package/dist/internal.js +7 -7
  125. package/dist/internal.js.map +1 -1
  126. package/dist/package.json.cjs +1 -1
  127. package/dist/package.json.js +1 -1
  128. package/dist/pframe.cjs +1 -1
  129. package/dist/pframe.cjs.map +1 -1
  130. package/dist/pframe.d.ts +1 -1
  131. package/dist/pframe.js +1 -1
  132. package/dist/pframe.js.map +1 -1
  133. package/dist/pframe_utils/columns.cjs +23 -15
  134. package/dist/pframe_utils/columns.cjs.map +1 -1
  135. package/dist/pframe_utils/columns.d.ts +3 -3
  136. package/dist/pframe_utils/columns.d.ts.map +1 -1
  137. package/dist/pframe_utils/columns.js +23 -15
  138. package/dist/pframe_utils/columns.js.map +1 -1
  139. package/dist/pframe_utils/index.cjs +25 -25
  140. package/dist/pframe_utils/index.cjs.map +1 -1
  141. package/dist/pframe_utils/index.d.ts +3 -3
  142. package/dist/pframe_utils/index.d.ts.map +1 -1
  143. package/dist/pframe_utils/index.js +25 -25
  144. package/dist/pframe_utils/index.js.map +1 -1
  145. package/dist/platforma.d.ts +7 -7
  146. package/dist/platforma.d.ts.map +1 -1
  147. package/dist/raw_globals.cjs +4 -1
  148. package/dist/raw_globals.cjs.map +1 -1
  149. package/dist/raw_globals.d.ts +2 -2
  150. package/dist/raw_globals.d.ts.map +1 -1
  151. package/dist/raw_globals.js +4 -1
  152. package/dist/raw_globals.js.map +1 -1
  153. package/dist/ref_util.cjs +4 -4
  154. package/dist/ref_util.cjs.map +1 -1
  155. package/dist/ref_util.d.ts +1 -1
  156. package/dist/ref_util.js +4 -4
  157. package/dist/ref_util.js.map +1 -1
  158. package/dist/render/accessor.cjs +24 -24
  159. package/dist/render/accessor.cjs.map +1 -1
  160. package/dist/render/accessor.d.ts +10 -10
  161. package/dist/render/accessor.d.ts.map +1 -1
  162. package/dist/render/accessor.js +24 -24
  163. package/dist/render/accessor.js.map +1 -1
  164. package/dist/render/api.cjs +23 -23
  165. package/dist/render/api.cjs.map +1 -1
  166. package/dist/render/api.d.ts +11 -11
  167. package/dist/render/api.d.ts.map +1 -1
  168. package/dist/render/api.js +23 -23
  169. package/dist/render/api.js.map +1 -1
  170. package/dist/render/future.cjs.map +1 -1
  171. package/dist/render/future.d.ts +1 -1
  172. package/dist/render/future.js.map +1 -1
  173. package/dist/render/index.d.ts +6 -6
  174. package/dist/render/internal.cjs +4 -4
  175. package/dist/render/internal.cjs.map +1 -1
  176. package/dist/render/internal.d.ts +7 -7
  177. package/dist/render/internal.d.ts.map +1 -1
  178. package/dist/render/internal.js +4 -4
  179. package/dist/render/internal.js.map +1 -1
  180. package/dist/render/traversal_ops.d.ts +1 -1
  181. package/dist/render/util/axis_filtering.cjs +48 -44
  182. package/dist/render/util/axis_filtering.cjs.map +1 -1
  183. package/dist/render/util/axis_filtering.d.ts +2 -2
  184. package/dist/render/util/axis_filtering.js +48 -44
  185. package/dist/render/util/axis_filtering.js.map +1 -1
  186. package/dist/render/util/column_collection.cjs +42 -35
  187. package/dist/render/util/column_collection.cjs.map +1 -1
  188. package/dist/render/util/column_collection.d.ts +4 -4
  189. package/dist/render/util/column_collection.d.ts.map +1 -1
  190. package/dist/render/util/column_collection.js +42 -35
  191. package/dist/render/util/column_collection.js.map +1 -1
  192. package/dist/render/util/index.d.ts +4 -4
  193. package/dist/render/util/label.cjs +15 -21
  194. package/dist/render/util/label.cjs.map +1 -1
  195. package/dist/render/util/label.d.ts +2 -2
  196. package/dist/render/util/label.d.ts.map +1 -1
  197. package/dist/render/util/label.js +15 -21
  198. package/dist/render/util/label.js.map +1 -1
  199. package/dist/render/util/pcolumn_data.cjs +56 -54
  200. package/dist/render/util/pcolumn_data.cjs.map +1 -1
  201. package/dist/render/util/pcolumn_data.d.ts +5 -5
  202. package/dist/render/util/pcolumn_data.d.ts.map +1 -1
  203. package/dist/render/util/pcolumn_data.js +56 -54
  204. package/dist/render/util/pcolumn_data.js.map +1 -1
  205. package/dist/render/util/pframe_upgraders.cjs +6 -6
  206. package/dist/render/util/pframe_upgraders.cjs.map +1 -1
  207. package/dist/render/util/pframe_upgraders.d.ts +1 -1
  208. package/dist/render/util/pframe_upgraders.d.ts.map +1 -1
  209. package/dist/render/util/pframe_upgraders.js +6 -6
  210. package/dist/render/util/pframe_upgraders.js.map +1 -1
  211. package/dist/render/util/split_selectors.d.ts +1 -1
  212. package/dist/render/util/split_selectors.d.ts.map +1 -1
  213. package/dist/sdk_info.cjs.map +1 -1
  214. package/dist/sdk_info.js.map +1 -1
  215. package/dist/version.cjs.map +1 -1
  216. package/dist/version.js.map +1 -1
  217. package/package.json +23 -21
  218. package/src/annotations/converter.test.ts +98 -101
  219. package/src/annotations/converter.ts +21 -17
  220. package/src/annotations/index.ts +2 -2
  221. package/src/annotations/types.ts +4 -4
  222. package/src/bconfig/index.ts +5 -5
  223. package/src/bconfig/lambdas.ts +10 -12
  224. package/src/bconfig/normalization.ts +5 -5
  225. package/src/bconfig/types.ts +3 -5
  226. package/src/bconfig/util.ts +3 -3
  227. package/src/bconfig/v3.ts +3 -3
  228. package/src/block_api_v1.ts +7 -3
  229. package/src/block_api_v2.ts +7 -3
  230. package/src/block_api_v3.ts +3 -3
  231. package/src/block_migrations.test.ts +66 -67
  232. package/src/block_migrations.ts +16 -16
  233. package/src/block_model.ts +76 -140
  234. package/src/block_state_patch.ts +2 -2
  235. package/src/block_state_util.ts +4 -4
  236. package/src/block_storage.test.ts +106 -99
  237. package/src/block_storage.ts +22 -25
  238. package/src/block_storage_vm.ts +41 -35
  239. package/src/builder.ts +107 -95
  240. package/src/components/PFrameForGraphs.test.ts +261 -255
  241. package/src/components/PFrameForGraphs.ts +35 -22
  242. package/src/components/PlAnnotations/filter.ts +21 -15
  243. package/src/components/PlAnnotations/filters_ui.test.ts +230 -73
  244. package/src/components/PlAnnotations/filters_ui.ts +138 -105
  245. package/src/components/PlAnnotations/index.ts +2 -2
  246. package/src/components/PlAnnotations/types.ts +2 -2
  247. package/src/components/PlDataTable.ts +177 -164
  248. package/src/components/PlMultiSequenceAlignment.ts +11 -18
  249. package/src/components/PlSelectionModel.ts +1 -1
  250. package/src/components/index.ts +5 -5
  251. package/src/config/actions.ts +64 -59
  252. package/src/config/actions_kinds.ts +38 -34
  253. package/src/config/index.ts +6 -6
  254. package/src/config/model.ts +28 -28
  255. package/src/config/model_meta.ts +1 -1
  256. package/src/config/type_engine.ts +3 -3
  257. package/src/config/type_util.ts +2 -2
  258. package/src/env_value.ts +2 -2
  259. package/src/filters/converter.test.ts +185 -144
  260. package/src/filters/converter.ts +47 -35
  261. package/src/filters/index.ts +2 -2
  262. package/src/filters/types.ts +44 -39
  263. package/src/global.d.ts +1 -1
  264. package/src/index.ts +24 -24
  265. package/src/internal.ts +27 -17
  266. package/src/pframe.ts +3 -3
  267. package/src/pframe_utils/columns.ts +81 -31
  268. package/src/pframe_utils/index.ts +65 -43
  269. package/src/platforma.ts +44 -21
  270. package/src/raw_globals.ts +13 -7
  271. package/src/ref_util.ts +6 -6
  272. package/src/render/accessor.ts +43 -44
  273. package/src/render/api.ts +102 -78
  274. package/src/render/future.ts +2 -2
  275. package/src/render/index.ts +6 -6
  276. package/src/render/internal.ts +11 -12
  277. package/src/render/traversal_ops.ts +1 -1
  278. package/src/render/util/axis_filtering.ts +67 -52
  279. package/src/render/util/column_collection.ts +171 -91
  280. package/src/render/util/index.ts +4 -4
  281. package/src/render/util/label.test.ts +139 -139
  282. package/src/render/util/label.ts +42 -33
  283. package/src/render/util/pcolumn_data.ts +111 -75
  284. package/src/render/util/pframe_upgraders.ts +24 -13
  285. package/src/render/util/split_selectors.ts +6 -1
  286. package/src/sdk_info.ts +1 -1
  287. package/src/typing.test.ts +56 -56
  288. package/src/version.ts +1 -1
@@ -1,273 +1,279 @@
1
- import { describe, expect, test } from 'vitest';
2
- import {enrichCompatible, getAvailableWithLinkersAxes} from './PFrameForGraphs';
1
+ import { describe, expect, test } from "vitest";
2
+ import { enrichCompatible, getAvailableWithLinkersAxes } from "./PFrameForGraphs";
3
3
  import {
4
- AxisId, CanonicalizedJson,
5
- canonicalizeJson, DataInfo,
6
- getAxisId,
7
- PColumn,
8
- PColumnSpec,
9
- PColumnValues,
10
- PObjectId,
11
- Annotation,
12
- AxisSpecNormalized,
13
- getNormalizedAxesList,
4
+ AxisId,
5
+ CanonicalizedJson,
6
+ canonicalizeJson,
7
+ DataInfo,
8
+ getAxisId,
9
+ PColumn,
10
+ PColumnSpec,
11
+ PColumnValues,
12
+ PObjectId,
13
+ Annotation,
14
+ AxisSpecNormalized,
15
+ getNormalizedAxesList,
14
16
  } from "@milaboratories/pl-model-common";
15
17
  import { TreeNodeAccessor } from "../render";
16
18
 
17
- function getAllAxesFromSpecs (specs:PColumnSpec[]):Map<CanonicalizedJson<AxisId>, AxisSpecNormalized> {
18
- const allAxes:Map<CanonicalizedJson<AxisId>, AxisSpecNormalized> = new Map();
19
- for (const spec of specs) {
20
- for (const id of getNormalizedAxesList(spec.axesSpec)) {
21
- const aid = getAxisId(id);
22
- allAxes.set(canonicalizeJson(aid), id);
23
- }
19
+ function getAllAxesFromSpecs(
20
+ specs: PColumnSpec[],
21
+ ): Map<CanonicalizedJson<AxisId>, AxisSpecNormalized> {
22
+ const allAxes: Map<CanonicalizedJson<AxisId>, AxisSpecNormalized> = new Map();
23
+ for (const spec of specs) {
24
+ for (const id of getNormalizedAxesList(spec.axesSpec)) {
25
+ const aid = getAxisId(id);
26
+ allAxes.set(canonicalizeJson(aid), id);
24
27
  }
25
- return allAxes
28
+ }
29
+ return allAxes;
26
30
  }
27
- describe('PFrameForGraph', () => {
28
- test('columns are compatible, no additional columns', () => {
29
- const columnSpec1: PColumnSpec = {
30
- kind: 'PColumn',
31
- name: 'column1',
32
- valueType: 'Int',
33
- axesSpec: [
34
- {type: 'String', name: 'axis1', domain: {}},
35
- {type: 'Int', name: 'axis2', domain: {}}
36
- ]
37
- }
38
- const columnSpec2: PColumnSpec = {
39
- kind: 'PColumn',
40
- name: 'column2',
41
- valueType: 'Int',
42
- axesSpec: [{type: 'String', name: 'axis1', domain: {}}]
43
- }
44
- const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [{
45
- id: 'id1' as PObjectId,
46
- spec: columnSpec1,
47
- data: []
48
- }, {
49
- id: 'id2' as PObjectId,
50
- spec: columnSpec2,
51
- data: []
52
- }
53
- ] as PColumn<PColumnValues>[]
54
- const allAxes = getAllAxesFromSpecs([columnSpec1, columnSpec2]);
31
+ describe("PFrameForGraph", () => {
32
+ test("columns are compatible, no additional columns", () => {
33
+ const columnSpec1: PColumnSpec = {
34
+ kind: "PColumn",
35
+ name: "column1",
36
+ valueType: "Int",
37
+ axesSpec: [
38
+ { type: "String", name: "axis1", domain: {} },
39
+ { type: "Int", name: "axis2", domain: {} },
40
+ ],
41
+ };
42
+ const columnSpec2: PColumnSpec = {
43
+ kind: "PColumn",
44
+ name: "column2",
45
+ valueType: "Int",
46
+ axesSpec: [{ type: "String", name: "axis1", domain: {} }],
47
+ };
48
+ const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
49
+ {
50
+ id: "id1" as PObjectId,
51
+ spec: columnSpec1,
52
+ data: [],
53
+ },
54
+ {
55
+ id: "id2" as PObjectId,
56
+ spec: columnSpec2,
57
+ data: [],
58
+ },
59
+ ] as PColumn<PColumnValues>[];
60
+ const allAxes = getAllAxesFromSpecs([columnSpec1, columnSpec2]);
55
61
 
56
- expect(enrichCompatible(allAxes, columns).length).toEqual(2);
57
- });
62
+ expect(enrichCompatible(allAxes, columns).length).toEqual(2);
63
+ });
58
64
 
59
- test('columns are not compatible, 1 additional column', () => {
60
- const columnSpec1: PColumnSpec = {
61
- kind: 'PColumn',
62
- name: 'column1',
63
- valueType: 'Int',
64
- axesSpec: [{type: 'String', name: 'axis1', domain: {key1: 'a'}}]
65
- }
66
- const columnSpec2: PColumnSpec = {
67
- kind: 'PColumn',
68
- name: 'column2',
69
- valueType: 'Int',
70
- axesSpec: [{type: 'String', name: 'axis1', domain: {}}]
71
- }
72
- const allAxes = getAllAxesFromSpecs([columnSpec1]);
73
- const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
74
- {id: 'id1' as PObjectId, spec: columnSpec1, data: []},
75
- {id: 'id2' as PObjectId, spec: columnSpec2, data: []}
76
- ] as PColumn<PColumnValues>[];
65
+ test("columns are not compatible, 1 additional column", () => {
66
+ const columnSpec1: PColumnSpec = {
67
+ kind: "PColumn",
68
+ name: "column1",
69
+ valueType: "Int",
70
+ axesSpec: [{ type: "String", name: "axis1", domain: { key1: "a" } }],
71
+ };
72
+ const columnSpec2: PColumnSpec = {
73
+ kind: "PColumn",
74
+ name: "column2",
75
+ valueType: "Int",
76
+ axesSpec: [{ type: "String", name: "axis1", domain: {} }],
77
+ };
78
+ const allAxes = getAllAxesFromSpecs([columnSpec1]);
79
+ const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
80
+ { id: "id1" as PObjectId, spec: columnSpec1, data: [] },
81
+ { id: "id2" as PObjectId, spec: columnSpec2, data: [] },
82
+ ] as PColumn<PColumnValues>[];
77
83
 
78
- const resultColumns = enrichCompatible(allAxes, columns);
79
- expect(resultColumns.length).toEqual(3);
80
- expect(resultColumns[2].id === columns[0].id).toEqual(false);
81
- expect(resultColumns[2].id === columns[1].id).toEqual(false);
82
- expect(resultColumns[2].spec).toEqual({
83
- kind: 'PColumn',
84
- name: 'column2',
85
- valueType: 'Int',
86
- axesSpec: [{type: 'String', name: 'axis1', domain: {key1: 'a'}, parentAxesSpec: []}],
87
- annotations: {[Annotation.Graph.IsVirtual]: 'true'}
88
- });
84
+ const resultColumns = enrichCompatible(allAxes, columns);
85
+ expect(resultColumns.length).toEqual(3);
86
+ expect(resultColumns[2].id === columns[0].id).toEqual(false);
87
+ expect(resultColumns[2].id === columns[1].id).toEqual(false);
88
+ expect(resultColumns[2].spec).toEqual({
89
+ kind: "PColumn",
90
+ name: "column2",
91
+ valueType: "Int",
92
+ axesSpec: [{ type: "String", name: "axis1", domain: { key1: "a" }, parentAxesSpec: [] }],
93
+ annotations: { [Annotation.Graph.IsVirtual]: "true" },
89
94
  });
90
- test('columns are not compatible, additional columns are impossible', () => {
91
- const columnSpec1: PColumnSpec = {
92
- kind: 'PColumn',
93
- name: 'column1',
94
- valueType: 'Int',
95
- axesSpec: [{type: 'String', name: 'axis1', domain: {key1: 'a'}}]
96
- }
97
- const columnSpec2: PColumnSpec = {
98
- kind: 'PColumn',
99
- name: 'column2',
100
- valueType: 'Int',
101
- axesSpec: [{type: 'String', name: 'axis1', domain: {key2: 'b'}}]
102
- }
103
- const allAxes = getAllAxesFromSpecs([columnSpec1]);
104
- const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
105
- {id: 'id1' as PObjectId, spec: columnSpec1, data: []},
106
- {id: 'id2' as PObjectId, spec: columnSpec2, data: []}
107
- ] as PColumn<PColumnValues>[]
95
+ });
96
+ test("columns are not compatible, additional columns are impossible", () => {
97
+ const columnSpec1: PColumnSpec = {
98
+ kind: "PColumn",
99
+ name: "column1",
100
+ valueType: "Int",
101
+ axesSpec: [{ type: "String", name: "axis1", domain: { key1: "a" } }],
102
+ };
103
+ const columnSpec2: PColumnSpec = {
104
+ kind: "PColumn",
105
+ name: "column2",
106
+ valueType: "Int",
107
+ axesSpec: [{ type: "String", name: "axis1", domain: { key2: "b" } }],
108
+ };
109
+ const allAxes = getAllAxesFromSpecs([columnSpec1]);
110
+ const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
111
+ { id: "id1" as PObjectId, spec: columnSpec1, data: [] },
112
+ { id: "id2" as PObjectId, spec: columnSpec2, data: [] },
113
+ ] as PColumn<PColumnValues>[];
108
114
 
109
- const resultColumns = enrichCompatible(allAxes, columns);
110
- expect(resultColumns.length).toEqual(2);
111
- });
112
- test('columns are not compatible, 2 additional columns', () => {
113
- const columnSpec1: PColumnSpec = {
114
- kind: 'PColumn',
115
- name: 'column1',
116
- valueType: 'Int',
117
- axesSpec: [
118
- {type: 'String', name: 'axis1', domain: {key1: 'a'}},
119
- {type: 'String', name: 'axis1', domain: {key1: 'b'}},
120
- ]
121
- }
122
- const columnSpec2: PColumnSpec = {
123
- kind: 'PColumn',
124
- name: 'column2',
125
- valueType: 'Int',
126
- axesSpec: [{type: 'String', name: 'axis1', domain: {}}]
127
- }
128
- const allAxes = getAllAxesFromSpecs([columnSpec1]);
129
- const columns: PColumn<TreeNodeAccessor | DataInfo<TreeNodeAccessor> | PColumnValues>[] = [
130
- {id: 'id1' as PObjectId, spec: columnSpec1, data: []},
131
- {id: 'id2' as PObjectId, spec: columnSpec2, data: []}
132
- ] as PColumn<PColumnValues>[]
115
+ const resultColumns = enrichCompatible(allAxes, columns);
116
+ expect(resultColumns.length).toEqual(2);
117
+ });
118
+ test("columns are not compatible, 2 additional columns", () => {
119
+ const columnSpec1: PColumnSpec = {
120
+ kind: "PColumn",
121
+ name: "column1",
122
+ valueType: "Int",
123
+ axesSpec: [
124
+ { type: "String", name: "axis1", domain: { key1: "a" } },
125
+ { type: "String", name: "axis1", domain: { key1: "b" } },
126
+ ],
127
+ };
128
+ const columnSpec2: PColumnSpec = {
129
+ kind: "PColumn",
130
+ name: "column2",
131
+ valueType: "Int",
132
+ axesSpec: [{ type: "String", name: "axis1", domain: {} }],
133
+ };
134
+ const allAxes = getAllAxesFromSpecs([columnSpec1]);
135
+ const columns: PColumn<TreeNodeAccessor | DataInfo<TreeNodeAccessor> | PColumnValues>[] = [
136
+ { id: "id1" as PObjectId, spec: columnSpec1, data: [] },
137
+ { id: "id2" as PObjectId, spec: columnSpec2, data: [] },
138
+ ] as PColumn<PColumnValues>[];
133
139
 
134
- const resultColumns = enrichCompatible(allAxes, columns);
135
- expect(resultColumns.length).toEqual(4);
136
- });
137
- test('columns are not compatible, 4 additional columns - by 2 axes', () => {
138
- const columnSpec1: PColumnSpec = {
139
- kind: 'PColumn',
140
- name: 'column1',
141
- valueType: 'Int',
142
- axesSpec: [
143
- {type: 'String', name: 'axis1', domain: {key1: 'a'}},
144
- {type: 'String', name: 'axis1', domain: {key1: 'b'}},
145
- {type: 'String', name: 'axis2', domain: {key1: 'a'}},
146
- {type: 'String', name: 'axis2', domain: {key1: 'b'}},
147
- ]
148
- }
149
- const columnSpec2: PColumnSpec = {
150
- kind: 'PColumn',
151
- name: 'column2',
152
- valueType: 'Int',
153
- axesSpec: [
154
- {type: 'String', name: 'axis1', domain: {}},
155
- {type: 'String', name: 'axis2', domain: {}}
156
- ]
157
- }
158
- const allAxes = getAllAxesFromSpecs([columnSpec1]);
159
- const columns: PColumn<TreeNodeAccessor | DataInfo<TreeNodeAccessor> | PColumnValues>[] = [
160
- {id: 'id1' as PObjectId, spec: columnSpec1, data: []},
161
- {id: 'id2' as PObjectId, spec: columnSpec2, data: []}
162
- ];
163
- const resultColumns = enrichCompatible(allAxes, columns);
164
- expect(resultColumns.length).toEqual(6);
165
- });
140
+ const resultColumns = enrichCompatible(allAxes, columns);
141
+ expect(resultColumns.length).toEqual(4);
142
+ });
143
+ test("columns are not compatible, 4 additional columns - by 2 axes", () => {
144
+ const columnSpec1: PColumnSpec = {
145
+ kind: "PColumn",
146
+ name: "column1",
147
+ valueType: "Int",
148
+ axesSpec: [
149
+ { type: "String", name: "axis1", domain: { key1: "a" } },
150
+ { type: "String", name: "axis1", domain: { key1: "b" } },
151
+ { type: "String", name: "axis2", domain: { key1: "a" } },
152
+ { type: "String", name: "axis2", domain: { key1: "b" } },
153
+ ],
154
+ };
155
+ const columnSpec2: PColumnSpec = {
156
+ kind: "PColumn",
157
+ name: "column2",
158
+ valueType: "Int",
159
+ axesSpec: [
160
+ { type: "String", name: "axis1", domain: {} },
161
+ { type: "String", name: "axis2", domain: {} },
162
+ ],
163
+ };
164
+ const allAxes = getAllAxesFromSpecs([columnSpec1]);
165
+ const columns: PColumn<TreeNodeAccessor | DataInfo<TreeNodeAccessor> | PColumnValues>[] = [
166
+ { id: "id1" as PObjectId, spec: columnSpec1, data: [] },
167
+ { id: "id2" as PObjectId, spec: columnSpec2, data: [] },
168
+ ];
169
+ const resultColumns = enrichCompatible(allAxes, columns);
170
+ expect(resultColumns.length).toEqual(6);
171
+ });
166
172
 
167
- test('Labels of added columns include added domains, but not include common domains', () => {
168
- const columnSpec1: PColumnSpec = {
169
- kind: 'PColumn',
170
- name: 'column1',
171
- valueType: 'Int',
172
- axesSpec: [
173
- {type: 'String', name: 'axis1', domain: {key0: 'commonDomain', key1: 'a', key2: 'c'}},
174
- {type: 'String', name: 'axis1', domain: {key0: 'commonDomain', key1: 'b', key2: 'c'}},
175
- ]
176
- }
177
- const columnSpec2: PColumnSpec = {
178
- kind: 'PColumn',
179
- name: 'column2',
180
- valueType: 'Int',
181
- annotations: {[Annotation.Label]: 'Label of column2'},
182
- axesSpec: [{type: 'String', name: 'axis1', domain: {key0: 'commonDomain'}}]
183
- }
184
- const allAxes = getAllAxesFromSpecs([columnSpec1]);
185
- const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
186
- {id: 'id1' as PObjectId, spec: columnSpec1, data: []},
187
- {id: 'id2' as PObjectId, spec: columnSpec2, data: []}
188
- ] as PColumn<PColumnValues>[]
173
+ test("Labels of added columns include added domains, but not include common domains", () => {
174
+ const columnSpec1: PColumnSpec = {
175
+ kind: "PColumn",
176
+ name: "column1",
177
+ valueType: "Int",
178
+ axesSpec: [
179
+ { type: "String", name: "axis1", domain: { key0: "commonDomain", key1: "a", key2: "c" } },
180
+ { type: "String", name: "axis1", domain: { key0: "commonDomain", key1: "b", key2: "c" } },
181
+ ],
182
+ };
183
+ const columnSpec2: PColumnSpec = {
184
+ kind: "PColumn",
185
+ name: "column2",
186
+ valueType: "Int",
187
+ annotations: { [Annotation.Label]: "Label of column2" },
188
+ axesSpec: [{ type: "String", name: "axis1", domain: { key0: "commonDomain" } }],
189
+ };
190
+ const allAxes = getAllAxesFromSpecs([columnSpec1]);
191
+ const columns: PColumn<TreeNodeAccessor | PColumnValues>[] = [
192
+ { id: "id1" as PObjectId, spec: columnSpec1, data: [] },
193
+ { id: "id2" as PObjectId, spec: columnSpec2, data: [] },
194
+ ] as PColumn<PColumnValues>[];
189
195
 
190
- const resultColumns = enrichCompatible(allAxes, columns);
191
- expect(resultColumns[2].spec.annotations?.[Annotation.Label]).toEqual('Label of column2 / a');
192
- expect(resultColumns[3].spec.annotations?.[Annotation.Label]).toEqual('Label of column2 / b');
193
- })
196
+ const resultColumns = enrichCompatible(allAxes, columns);
197
+ expect(resultColumns[2].spec.annotations?.[Annotation.Label]).toEqual("Label of column2 / a");
198
+ expect(resultColumns[3].spec.annotations?.[Annotation.Label]).toEqual("Label of column2 / b");
199
+ });
194
200
 
195
- test('Linker column adds available axis', () => {
196
- const columnSpec1: PColumnSpec = {
197
- kind: 'PColumn',
198
- name: 'column1',
199
- valueType: 'Int',
200
- axesSpec: [
201
- {type: 'String', name: 'axis1', domain: {key1: 'a'}},
202
- {type: 'String', name: 'axis2', domain: {key1: 'b'}},
203
- ]
204
- };
205
- const linkerColumn13: PColumnSpec = {
206
- kind: 'PColumn',
207
- name: 'linker13',
208
- valueType: 'String',
209
- annotations: {[Annotation.IsLinkerColumn]: 'true'},
210
- axesSpec: [
211
- {type: 'String', name: 'axis1'},
212
- {type: 'String', name: 'axis3'}
213
- ]
214
- }
201
+ test("Linker column adds available axis", () => {
202
+ const columnSpec1: PColumnSpec = {
203
+ kind: "PColumn",
204
+ name: "column1",
205
+ valueType: "Int",
206
+ axesSpec: [
207
+ { type: "String", name: "axis1", domain: { key1: "a" } },
208
+ { type: "String", name: "axis2", domain: { key1: "b" } },
209
+ ],
210
+ };
211
+ const linkerColumn13: PColumnSpec = {
212
+ kind: "PColumn",
213
+ name: "linker13",
214
+ valueType: "String",
215
+ annotations: { [Annotation.IsLinkerColumn]: "true" },
216
+ axesSpec: [
217
+ { type: "String", name: "axis1" },
218
+ { type: "String", name: "axis3" },
219
+ ],
220
+ };
215
221
 
216
- const linkerColumns = [{id: 'id5' as PObjectId, spec: linkerColumn13, data: []}];
217
- const availableAxes = getAvailableWithLinkersAxes(
218
- linkerColumns,
219
- getAllAxesFromSpecs([columnSpec1])
220
- );
221
- expect([...availableAxes.values()].map((id) => id.name)).toEqual(['axis3'])
222
- })
222
+ const linkerColumns = [{ id: "id5" as PObjectId, spec: linkerColumn13, data: [] }];
223
+ const availableAxes = getAvailableWithLinkersAxes(
224
+ linkerColumns,
225
+ getAllAxesFromSpecs([columnSpec1]),
226
+ );
227
+ expect([...availableAxes.values()].map((id) => id.name)).toEqual(["axis3"]);
228
+ });
223
229
 
224
- test('Linker columns add available axes by chains', () => {
225
- const columnSpec1: PColumnSpec = {
226
- kind: 'PColumn',
227
- name: 'column1',
228
- valueType: 'Int',
229
- axesSpec: [{type: 'String', name: 'axis1'}]
230
- };
231
- const linkerColumn12: PColumnSpec = {
232
- kind: 'PColumn',
233
- name: 'linker12',
234
- valueType: 'String',
235
- annotations: {[Annotation.IsLinkerColumn]: 'true'},
236
- axesSpec: [
237
- {type: 'String', name: 'axis1'},
238
- {type: 'String', name: 'axis2'}
239
- ]
240
- }
241
- const linkerColumn23: PColumnSpec = {
242
- kind: 'PColumn',
243
- name: 'linker23',
244
- valueType: 'String',
245
- annotations: {[Annotation.IsLinkerColumn]: 'true'},
246
- axesSpec: [
247
- {type: 'String', name: 'axis2'},
248
- {type: 'String', name: 'axis3'}
249
- ]
250
- }
251
- const linkerColumn34: PColumnSpec = {
252
- kind: 'PColumn',
253
- name: 'linker34',
254
- valueType: 'String',
255
- annotations: {[Annotation.IsLinkerColumn]: 'true'},
256
- axesSpec: [
257
- {type: 'String', name: 'axis3'},
258
- {type: 'String', name: 'axis4'}
259
- ]
260
- }
230
+ test("Linker columns add available axes by chains", () => {
231
+ const columnSpec1: PColumnSpec = {
232
+ kind: "PColumn",
233
+ name: "column1",
234
+ valueType: "Int",
235
+ axesSpec: [{ type: "String", name: "axis1" }],
236
+ };
237
+ const linkerColumn12: PColumnSpec = {
238
+ kind: "PColumn",
239
+ name: "linker12",
240
+ valueType: "String",
241
+ annotations: { [Annotation.IsLinkerColumn]: "true" },
242
+ axesSpec: [
243
+ { type: "String", name: "axis1" },
244
+ { type: "String", name: "axis2" },
245
+ ],
246
+ };
247
+ const linkerColumn23: PColumnSpec = {
248
+ kind: "PColumn",
249
+ name: "linker23",
250
+ valueType: "String",
251
+ annotations: { [Annotation.IsLinkerColumn]: "true" },
252
+ axesSpec: [
253
+ { type: "String", name: "axis2" },
254
+ { type: "String", name: "axis3" },
255
+ ],
256
+ };
257
+ const linkerColumn34: PColumnSpec = {
258
+ kind: "PColumn",
259
+ name: "linker34",
260
+ valueType: "String",
261
+ annotations: { [Annotation.IsLinkerColumn]: "true" },
262
+ axesSpec: [
263
+ { type: "String", name: "axis3" },
264
+ { type: "String", name: "axis4" },
265
+ ],
266
+ };
261
267
 
262
- const linkerColumns = [
263
- {id: 'id3' as PObjectId, spec: linkerColumn12, data: []},
264
- {id: 'id4' as PObjectId, spec: linkerColumn23, data: []},
265
- {id: 'id5' as PObjectId, spec: linkerColumn34, data: []},
266
- ];
267
- const availableAxes = getAvailableWithLinkersAxes(
268
- linkerColumns,
269
- getAllAxesFromSpecs([columnSpec1])
270
- );
271
- expect([...availableAxes.values()].map((id) => id.name)).toEqual(['axis2', 'axis3', 'axis4'])
272
- })
273
- })
268
+ const linkerColumns = [
269
+ { id: "id3" as PObjectId, spec: linkerColumn12, data: [] },
270
+ { id: "id4" as PObjectId, spec: linkerColumn23, data: [] },
271
+ { id: "id5" as PObjectId, spec: linkerColumn34, data: [] },
272
+ ];
273
+ const availableAxes = getAvailableWithLinkersAxes(
274
+ linkerColumns,
275
+ getAllAxesFromSpecs([columnSpec1]),
276
+ );
277
+ expect([...availableAxes.values()].map((id) => id.name)).toEqual(["axis2", "axis3", "axis4"]);
278
+ });
279
+ });