@genome-spy/core 0.64.0 → 0.66.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 (285) hide show
  1. package/dist/bundle/{index-CCJIjehY.js → AbortablePromiseCache-CcuMrnn7.js} +22 -91
  2. package/dist/bundle/browser-BRemItdO.js +138 -0
  3. package/dist/bundle/index-BatuyGAI.js +271 -0
  4. package/dist/bundle/index-ByuE8dvu.js +332 -0
  5. package/dist/bundle/index-Cq3QFUxX.js +1781 -0
  6. package/dist/bundle/{index-C08YCM2T.js → index-D-w7Mmt9.js} +246 -126
  7. package/dist/bundle/index-D28m8tSW.js +1607 -0
  8. package/dist/bundle/index-D74H8TTz.js +508 -0
  9. package/dist/bundle/index-DbJ0oeYM.js +631 -0
  10. package/dist/bundle/index.es.js +15034 -13842
  11. package/dist/bundle/index.js +223 -237
  12. package/dist/bundle/inflate-GtwLkvSP.js +1048 -0
  13. package/dist/bundle/unzip-NywezaRR.js +1492 -0
  14. package/dist/schema.json +22 -4
  15. package/dist/src/config/scaleDefaults.d.ts +8 -0
  16. package/dist/src/config/scaleDefaults.d.ts.map +1 -0
  17. package/dist/src/config/scaleDefaults.js +45 -0
  18. package/dist/src/data/collector.d.ts +7 -2
  19. package/dist/src/data/collector.d.ts.map +1 -1
  20. package/dist/src/data/collector.js +13 -2
  21. package/dist/src/data/dataFlow.d.ts +20 -42
  22. package/dist/src/data/dataFlow.d.ts.map +1 -1
  23. package/dist/src/data/dataFlow.js +57 -80
  24. package/dist/src/data/flowHandle.d.ts +15 -0
  25. package/dist/src/data/flowHandle.d.ts.map +1 -0
  26. package/dist/src/data/flowHandle.js +13 -0
  27. package/dist/src/data/flowInit.d.ts +85 -0
  28. package/dist/src/data/flowInit.d.ts.map +1 -0
  29. package/dist/src/data/flowInit.js +238 -0
  30. package/dist/src/data/flowInit.test.d.ts +2 -0
  31. package/dist/src/data/flowInit.test.d.ts.map +1 -0
  32. package/dist/src/data/flowOptimizer.d.ts +6 -4
  33. package/dist/src/data/flowOptimizer.d.ts.map +1 -1
  34. package/dist/src/data/flowOptimizer.js +29 -14
  35. package/dist/src/data/sources/lazy/axisTickSource.js +1 -1
  36. package/dist/src/data/sources/lazy/bamSource.js +1 -1
  37. package/dist/src/data/sources/lazy/bigBedSource.js +1 -1
  38. package/dist/src/data/sources/lazy/bigWigSource.js +1 -1
  39. package/dist/src/data/sources/lazy/gff3Source.d.ts +2 -6
  40. package/dist/src/data/sources/lazy/gff3Source.d.ts.map +1 -1
  41. package/dist/src/data/sources/lazy/gff3Source.js +4 -8
  42. package/dist/src/data/sources/lazy/indexedFastaSource.d.ts.map +1 -1
  43. package/dist/src/data/sources/lazy/indexedFastaSource.js +17 -17
  44. package/dist/src/data/sources/lazy/singleAxisLazySource.d.ts +1 -1
  45. package/dist/src/data/sources/lazy/singleAxisLazySource.d.ts.map +1 -1
  46. package/dist/src/data/sources/lazy/singleAxisLazySource.js +10 -3
  47. package/dist/src/data/sources/lazy/singleAxisWindowedSource.d.ts.map +1 -1
  48. package/dist/src/data/sources/lazy/singleAxisWindowedSource.js +5 -1
  49. package/dist/src/data/sources/lazy/tabixSource.js +1 -1
  50. package/dist/src/data/transforms/filterScoredLabels.d.ts +1 -1
  51. package/dist/src/data/transforms/filterScoredLabels.d.ts.map +1 -1
  52. package/dist/src/data/transforms/filterScoredLabels.js +1 -1
  53. package/dist/src/data/transforms/linearizeGenomicCoordinate.d.ts.map +1 -1
  54. package/dist/src/data/transforms/linearizeGenomicCoordinate.js +2 -1
  55. package/dist/src/encoder/encoder.d.ts +1 -1
  56. package/dist/src/encoder/encoder.d.ts.map +1 -1
  57. package/dist/src/encoder/encoder.js +1 -1
  58. package/dist/src/genome/scaleLocus.d.ts +39 -0
  59. package/dist/src/genome/scaleLocus.d.ts.map +1 -1
  60. package/dist/src/genome/scaleLocus.js +76 -0
  61. package/dist/src/genomeSpy/canvasExport.d.ts +19 -0
  62. package/dist/src/genomeSpy/canvasExport.d.ts.map +1 -0
  63. package/dist/src/genomeSpy/canvasExport.js +66 -0
  64. package/dist/src/genomeSpy/containerUi.d.ts +17 -0
  65. package/dist/src/genomeSpy/containerUi.d.ts.map +1 -0
  66. package/dist/src/genomeSpy/containerUi.js +78 -0
  67. package/dist/src/genomeSpy/eventListenerRegistry.d.ts +19 -0
  68. package/dist/src/genomeSpy/eventListenerRegistry.d.ts.map +1 -0
  69. package/dist/src/genomeSpy/eventListenerRegistry.js +38 -0
  70. package/dist/src/genomeSpy/inputBindingManager.d.ts +14 -0
  71. package/dist/src/genomeSpy/inputBindingManager.d.ts.map +1 -0
  72. package/dist/src/genomeSpy/inputBindingManager.js +63 -0
  73. package/dist/src/genomeSpy/interactionController.d.ts +40 -0
  74. package/dist/src/genomeSpy/interactionController.d.ts.map +1 -0
  75. package/dist/src/genomeSpy/interactionController.js +371 -0
  76. package/dist/src/genomeSpy/keyboardListenerManager.d.ts +10 -0
  77. package/dist/src/genomeSpy/keyboardListenerManager.d.ts.map +1 -0
  78. package/dist/src/genomeSpy/keyboardListenerManager.js +31 -0
  79. package/dist/src/genomeSpy/loadingIndicatorManager.d.ts +15 -0
  80. package/dist/src/genomeSpy/loadingIndicatorManager.d.ts.map +1 -0
  81. package/dist/src/genomeSpy/loadingIndicatorManager.js +92 -0
  82. package/dist/src/genomeSpy/renderCoordinator.d.ts +22 -0
  83. package/dist/src/genomeSpy/renderCoordinator.d.ts.map +1 -0
  84. package/dist/src/genomeSpy/renderCoordinator.js +118 -0
  85. package/dist/src/genomeSpy/viewContextFactory.d.ts +18 -0
  86. package/dist/src/genomeSpy/viewContextFactory.d.ts.map +1 -0
  87. package/dist/src/genomeSpy/viewContextFactory.js +79 -0
  88. package/dist/src/genomeSpy/viewDataInit.d.ts +12 -0
  89. package/dist/src/genomeSpy/viewDataInit.d.ts.map +1 -0
  90. package/dist/src/genomeSpy/viewDataInit.js +41 -0
  91. package/dist/src/genomeSpy/viewHierarchyConfig.d.ts +14 -0
  92. package/dist/src/genomeSpy/viewHierarchyConfig.d.ts.map +1 -0
  93. package/dist/src/genomeSpy/viewHierarchyConfig.js +24 -0
  94. package/dist/src/genomeSpy/viewHighlight.d.ts +5 -0
  95. package/dist/src/genomeSpy/viewHighlight.d.ts.map +1 -0
  96. package/dist/src/genomeSpy/viewHighlight.js +30 -0
  97. package/dist/src/genomeSpy.d.ts +17 -72
  98. package/dist/src/genomeSpy.d.ts.map +1 -1
  99. package/dist/src/genomeSpy.js +180 -789
  100. package/dist/src/gl/glslScaleGenerator.d.ts +1 -1
  101. package/dist/src/gl/webGLHelper.d.ts +2 -2
  102. package/dist/src/gl/webGLHelper.d.ts.map +1 -1
  103. package/dist/src/gl/webGLHelper.js +4 -4
  104. package/dist/src/index.d.ts.map +1 -1
  105. package/dist/src/index.js +2 -12
  106. package/dist/src/marks/mark.d.ts +1 -0
  107. package/dist/src/marks/mark.d.ts.map +1 -1
  108. package/dist/src/marks/mark.js +26 -3
  109. package/dist/src/{view → scales}/axisResolution.d.ts +12 -14
  110. package/dist/src/scales/axisResolution.d.ts.map +1 -0
  111. package/dist/src/{view → scales}/axisResolution.js +38 -12
  112. package/dist/src/scales/axisResolution.test.d.ts.map +1 -0
  113. package/dist/src/scales/scaleDomainAggregator.d.ts +57 -0
  114. package/dist/src/scales/scaleDomainAggregator.d.ts.map +1 -0
  115. package/dist/src/scales/scaleDomainAggregator.js +162 -0
  116. package/dist/src/scales/scaleDomainAggregator.test.d.ts +2 -0
  117. package/dist/src/scales/scaleDomainAggregator.test.d.ts.map +1 -0
  118. package/dist/src/scales/scaleInstanceManager.d.ts +40 -0
  119. package/dist/src/scales/scaleInstanceManager.d.ts.map +1 -0
  120. package/dist/src/scales/scaleInstanceManager.js +313 -0
  121. package/dist/src/scales/scaleInstanceManager.test.d.ts +2 -0
  122. package/dist/src/scales/scaleInstanceManager.test.d.ts.map +1 -0
  123. package/dist/src/scales/scaleInteractionController.d.ts +73 -0
  124. package/dist/src/scales/scaleInteractionController.d.ts.map +1 -0
  125. package/dist/src/scales/scaleInteractionController.js +336 -0
  126. package/dist/src/scales/scaleInteractionController.test.d.ts +2 -0
  127. package/dist/src/scales/scaleInteractionController.test.d.ts.map +1 -0
  128. package/dist/src/scales/scalePropsResolver.d.ts +23 -0
  129. package/dist/src/scales/scalePropsResolver.d.ts.map +1 -0
  130. package/dist/src/scales/scalePropsResolver.js +74 -0
  131. package/dist/src/{view → scales}/scaleResolution.d.ts +53 -31
  132. package/dist/src/scales/scaleResolution.d.ts.map +1 -0
  133. package/dist/src/scales/scaleResolution.js +658 -0
  134. package/dist/src/scales/scaleResolution.test.d.ts.map +1 -0
  135. package/dist/src/scales/scaleResolutionConstants.d.ts +6 -0
  136. package/dist/src/scales/scaleResolutionConstants.d.ts.map +1 -0
  137. package/dist/src/scales/scaleResolutionConstants.js +5 -0
  138. package/dist/src/scales/scaleRules.d.ts +16 -0
  139. package/dist/src/scales/scaleRules.d.ts.map +1 -0
  140. package/dist/src/scales/scaleRules.js +103 -0
  141. package/dist/src/scales/scaleRules.test.d.ts +2 -0
  142. package/dist/src/scales/scaleRules.test.d.ts.map +1 -0
  143. package/dist/src/spec/channel.d.ts +13 -18
  144. package/dist/src/spec/sampleView.d.ts +3 -2
  145. package/dist/src/spec/scale.d.ts +6 -0
  146. package/dist/src/types/embedApi.d.ts +5 -0
  147. package/dist/src/types/scaleResolutionApi.d.ts +1 -1
  148. package/dist/src/types/viewContext.d.ts +1 -1
  149. package/dist/src/view/concatView.d.ts +18 -0
  150. package/dist/src/view/concatView.d.ts.map +1 -1
  151. package/dist/src/view/concatView.js +73 -0
  152. package/dist/src/view/concatView.test.d.ts +2 -0
  153. package/dist/src/view/concatView.test.d.ts.map +1 -0
  154. package/dist/src/view/containerMutationHelper.d.ts +74 -0
  155. package/dist/src/view/containerMutationHelper.d.ts.map +1 -0
  156. package/dist/src/view/containerMutationHelper.js +114 -0
  157. package/dist/src/view/containerView.d.ts +0 -7
  158. package/dist/src/view/containerView.d.ts.map +1 -1
  159. package/dist/src/view/containerView.js +0 -10
  160. package/dist/src/view/facetView.d.ts.map +1 -1
  161. package/dist/src/view/facetView.js +0 -14
  162. package/dist/src/view/flowBuilder.d.ts +2 -2
  163. package/dist/src/view/flowBuilder.d.ts.map +1 -1
  164. package/dist/src/view/flowBuilder.js +21 -4
  165. package/dist/src/view/gridView/gridChild.d.ts +11 -0
  166. package/dist/src/view/gridView/gridChild.d.ts.map +1 -1
  167. package/dist/src/view/gridView/gridChild.js +32 -6
  168. package/dist/src/view/gridView/gridView.d.ts +39 -1
  169. package/dist/src/view/gridView/gridView.d.ts.map +1 -1
  170. package/dist/src/view/gridView/gridView.js +113 -42
  171. package/dist/src/view/gridView/gridView.test.d.ts +2 -0
  172. package/dist/src/view/gridView/gridView.test.d.ts.map +1 -0
  173. package/dist/src/view/gridView/scrollbar.d.ts +39 -8
  174. package/dist/src/view/gridView/scrollbar.d.ts.map +1 -1
  175. package/dist/src/view/gridView/scrollbar.js +184 -69
  176. package/dist/src/view/gridView/selectionRect.d.ts +8 -4
  177. package/dist/src/view/gridView/selectionRect.d.ts.map +1 -1
  178. package/dist/src/view/gridView/selectionRect.js +28 -3
  179. package/dist/src/view/gridView/selectionRect.test.d.ts +2 -0
  180. package/dist/src/view/gridView/selectionRect.test.d.ts.map +1 -0
  181. package/dist/src/view/layerView.d.ts +14 -0
  182. package/dist/src/view/layerView.d.ts.map +1 -1
  183. package/dist/src/view/layerView.js +66 -0
  184. package/dist/src/view/layerView.test.d.ts +2 -0
  185. package/dist/src/view/layerView.test.d.ts.map +1 -0
  186. package/dist/src/view/paramMediator.d.ts +2 -1
  187. package/dist/src/view/paramMediator.d.ts.map +1 -1
  188. package/dist/src/view/paramMediator.js +13 -1
  189. package/dist/src/view/testUtils.d.ts.map +1 -1
  190. package/dist/src/view/testUtils.js +18 -5
  191. package/dist/src/view/unitView.d.ts.map +1 -1
  192. package/dist/src/view/unitView.js +52 -12
  193. package/dist/src/view/view.d.ts +23 -7
  194. package/dist/src/view/view.d.ts.map +1 -1
  195. package/dist/src/view/view.js +61 -5
  196. package/dist/src/view/viewDispose.test.d.ts +2 -0
  197. package/dist/src/view/viewDispose.test.d.ts.map +1 -0
  198. package/dist/src/view/viewUtils.d.ts +4 -4
  199. package/dist/src/view/viewUtils.d.ts.map +1 -1
  200. package/dist/src/view/viewUtils.js +19 -15
  201. package/dist/src/view/viewUtils.test.d.ts +2 -0
  202. package/dist/src/view/viewUtils.test.d.ts.map +1 -0
  203. package/package.json +10 -10
  204. package/dist/bundle/__vite-browser-external-C--ziKoh.js +0 -8
  205. package/dist/bundle/_commonjsHelpers-DjF3Plf2.js +0 -26
  206. package/dist/bundle/index-5ajWdKly.js +0 -1319
  207. package/dist/bundle/index-B03-Om4z.js +0 -274
  208. package/dist/bundle/index-BftNdA0O.js +0 -27
  209. package/dist/bundle/index-Bg7C4Xat.js +0 -2750
  210. package/dist/bundle/index-C3QR8Lv6.js +0 -2131
  211. package/dist/bundle/index-DTcHjAHp.js +0 -505
  212. package/dist/bundle/index-DnIkxb0L.js +0 -1025
  213. package/dist/bundle/index-Ww3TAo6_.js +0 -71
  214. package/dist/bundle/index-g8iXgW0W.js +0 -651
  215. package/dist/bundle/long-B-FASCSo.js +0 -2387
  216. package/dist/bundle/remoteFile-BuaqFGWk.js +0 -94
  217. package/dist/src/data/collector.test.js +0 -138
  218. package/dist/src/data/dataFlow.test.js +0 -5
  219. package/dist/src/data/flow.test.js +0 -81
  220. package/dist/src/data/flowNode.test.js +0 -50
  221. package/dist/src/data/flowOptimizer.test.js +0 -204
  222. package/dist/src/data/formats/fasta.test.js +0 -27
  223. package/dist/src/data/sources/inlineSource.test.js +0 -63
  224. package/dist/src/data/sources/sequenceSource.test.js +0 -81
  225. package/dist/src/data/transforms/aggregate.test.js +0 -134
  226. package/dist/src/data/transforms/clone.test.js +0 -11
  227. package/dist/src/data/transforms/coverage.test.js +0 -238
  228. package/dist/src/data/transforms/filter.test.js +0 -20
  229. package/dist/src/data/transforms/flatten.test.js +0 -96
  230. package/dist/src/data/transforms/flattenDelimited.test.js +0 -90
  231. package/dist/src/data/transforms/flattenSequence.test.js +0 -34
  232. package/dist/src/data/transforms/formula.test.js +0 -25
  233. package/dist/src/data/transforms/identifier.test.js +0 -92
  234. package/dist/src/data/transforms/pileup.test.js +0 -70
  235. package/dist/src/data/transforms/project.test.js +0 -32
  236. package/dist/src/data/transforms/regexExtract.test.js +0 -70
  237. package/dist/src/data/transforms/regexFold.test.js +0 -201
  238. package/dist/src/data/transforms/sample.test.js +0 -38
  239. package/dist/src/data/transforms/stack.test.js +0 -91
  240. package/dist/src/encoder/accessor.test.js +0 -162
  241. package/dist/src/encoder/encoder.test.js +0 -105
  242. package/dist/src/genome/genome.test.js +0 -268
  243. package/dist/src/genome/genomes.test.js +0 -8
  244. package/dist/src/genome/scaleIndex.test.js +0 -78
  245. package/dist/src/genome/scaleLocus.test.js +0 -4
  246. package/dist/src/scale/scale.test.js +0 -326
  247. package/dist/src/scale/ticks.test.js +0 -46
  248. package/dist/src/selection/selection.test.js +0 -14
  249. package/dist/src/utils/addBaseUrl.test.js +0 -30
  250. package/dist/src/utils/binnedIndex.test.js +0 -201
  251. package/dist/src/utils/cloner.test.js +0 -35
  252. package/dist/src/utils/coalesce.test.js +0 -16
  253. package/dist/src/utils/concatIterables.test.js +0 -8
  254. package/dist/src/utils/domainArray.test.js +0 -130
  255. package/dist/src/utils/indexer.test.js +0 -49
  256. package/dist/src/utils/interactionEvent.test.js +0 -35
  257. package/dist/src/utils/iterateNestedMaps.test.js +0 -33
  258. package/dist/src/utils/kWayMerge.test.js +0 -30
  259. package/dist/src/utils/mergeObjects.test.js +0 -42
  260. package/dist/src/utils/numberExtractor.test.js +0 -6
  261. package/dist/src/utils/propertyCacher.test.js +0 -89
  262. package/dist/src/utils/propertyCoalescer.test.js +0 -25
  263. package/dist/src/utils/radixSort.test.js +0 -51
  264. package/dist/src/utils/reservationMap.test.js +0 -20
  265. package/dist/src/utils/ringBuffer.test.js +0 -39
  266. package/dist/src/utils/topK.test.js +0 -54
  267. package/dist/src/utils/trees.test.js +0 -135
  268. package/dist/src/utils/url.test.js +0 -28
  269. package/dist/src/utils/variableTools.test.js +0 -13
  270. package/dist/src/view/axisResolution.d.ts.map +0 -1
  271. package/dist/src/view/axisResolution.test.d.ts.map +0 -1
  272. package/dist/src/view/axisResolution.test.js +0 -206
  273. package/dist/src/view/flowBuilder.test.js +0 -125
  274. package/dist/src/view/layout/flexLayout.test.js +0 -323
  275. package/dist/src/view/layout/grid.test.js +0 -71
  276. package/dist/src/view/layout/rectangle.test.js +0 -192
  277. package/dist/src/view/paramMediator.test.js +0 -260
  278. package/dist/src/view/scaleResolution.d.ts.map +0 -1
  279. package/dist/src/view/scaleResolution.js +0 -1049
  280. package/dist/src/view/scaleResolution.test.d.ts.map +0 -1
  281. package/dist/src/view/scaleResolution.test.js +0 -645
  282. package/dist/src/view/view.test.js +0 -245
  283. package/dist/src/view/viewFactory.test.js +0 -25
  284. /package/dist/src/{view → scales}/axisResolution.test.d.ts +0 -0
  285. /package/dist/src/{view → scales}/scaleResolution.test.d.ts +0 -0
@@ -1,326 +0,0 @@
1
- // @ts-nocheck
2
-
3
- import { expect, test } from "vitest";
4
- /*!
5
- * Adapted from vega-encode:
6
- * https://github.com/vega/vega/blob/master/packages/vega-encode/test/scale-test.js
7
- *
8
- * Copyright (c) 2015-2018, University of Washington Interactive Data Lab
9
- * All rights reserved.
10
- *
11
- * BSD-3-Clause License: https://github.com/vega/vega-lite/blob/master/LICENSE
12
- */
13
-
14
- /* eslint-disable */
15
-
16
- import * as util from "vega-util";
17
- import * as vs from "vega-scale";
18
- import createScale from "./scale.js";
19
-
20
- // Suppress warnings by default
21
- const scale = (params, logger) =>
22
- createScale(params, logger || { warn: () => {} });
23
-
24
- test("Scale respects domain configuration", function () {
25
- var s,
26
- params = {
27
- type: "linear",
28
- domain: [1, 9.5],
29
- };
30
-
31
- // test zero inclusion
32
- s = scale(params);
33
- expect(s.domain()).toEqual([0, 9.5]);
34
- s = scale(util.extend({ zero: true }, params));
35
- expect(s.domain()).toEqual([0, 9.5]);
36
- s = scale(util.extend({ zero: false }, params));
37
- expect(s.domain()).toEqual([1, 9.5]);
38
-
39
- // test nice domain
40
- s = scale(util.extend({ nice: true }, params));
41
- expect(s.domain()).toEqual([0, 10]);
42
-
43
- // test domain min/max
44
- s = scale(util.extend({ domainMin: -1, domainMax: 10 }, params));
45
- expect(s.domain()).toEqual([-1, 10]);
46
-
47
- // domain min overrides zero
48
- s = scale(
49
- util.extend({ zero: true, domainMin: 0.5, domainMax: 10 }, params)
50
- );
51
- expect(s.domain()).toEqual([0.5, 10]);
52
-
53
- // test domain mid
54
- s = scale(util.extend({ domainMid: 5 }, params));
55
- expect(s.domain()).toEqual([0, 5, 9.5]);
56
-
57
- // test domain raw
58
- s = scale(util.extend({ domainRaw: [2, 11] }, params));
59
- expect(s.domain()).toEqual([2, 11]);
60
- });
61
-
62
- test("Scale respects domain padding", function () {
63
- var d;
64
-
65
- // test linear scale padding
66
- d = scale({
67
- type: "linear",
68
- domain: [5, 95],
69
- range: [0, 100],
70
- padding: 5,
71
- zero: false,
72
- }).domain();
73
- expect(d).toEqual([0, 100]);
74
-
75
- // test log scale padding
76
- d = scale({
77
- type: "log",
78
- domain: [1, 10],
79
- range: [0, 60],
80
- padding: 20,
81
- zero: false,
82
- }).domain();
83
- expect(Math.abs(d[0] - 0.1) < 1e-8).toBeTruthy();
84
- expect(Math.abs(d[1] - 100) < 1e-8).toBeTruthy();
85
-
86
- // test sqrt scale padding
87
- d = scale({
88
- type: "sqrt",
89
- domain: [2 * 2, 3 * 3],
90
- range: [0, 60],
91
- padding: 20,
92
- zero: false,
93
- }).domain();
94
- expect(Math.abs(d[0] - 1 * 1) < 1e-8).toBeTruthy();
95
- expect(Math.abs(d[1] - 4 * 4) < 1e-8).toBeTruthy();
96
-
97
- // test power scale padding
98
- d = scale({
99
- type: "pow",
100
- exponent: 1 / 3,
101
- domain: [2 * 2 * 2, 3 * 3 * 3],
102
- range: [0, 60],
103
- padding: 20,
104
- zero: false,
105
- }).domain();
106
- expect(Math.abs(d[0] - 1 * 1 * 1) < 1e-8).toBeTruthy();
107
- expect(Math.abs(d[1] - 4 * 4 * 4) < 1e-8).toBeTruthy();
108
- });
109
-
110
- test("Ordinal scale respects domainImplicit", function () {
111
- var s,
112
- params = {
113
- type: "ordinal",
114
- domain: [],
115
- range: ["a", "b", "c"],
116
- };
117
-
118
- s = scale(params);
119
- expect(s("foo")).toBe(undefined);
120
- expect(s("bar")).toBe(undefined);
121
- expect(s("foo")).toBe(undefined);
122
-
123
- s = scale(util.extend({ domainImplicit: false }, params));
124
- expect(s("foo")).toBe(undefined);
125
- expect(s("bar")).toBe(undefined);
126
- expect(s("foo")).toBe(undefined);
127
-
128
- s = scale(util.extend({ domainImplicit: true }, params));
129
- expect(s("foo")).toBe("a");
130
- expect(s("bar")).toBe("b");
131
- expect(s("foo")).toBe("a");
132
- });
133
-
134
- test("Scale respects range configuration", function () {
135
- var s,
136
- params = {
137
- type: "linear",
138
- domain: [0, 10],
139
- range: [0, 10],
140
- };
141
-
142
- // round
143
- s = scale(params);
144
- expect(s(0.5)).toBe(0.5);
145
- s = scale(util.extend({ round: true }, params));
146
- expect(s(0.5)).toBe(1);
147
-
148
- // reverse
149
- s = scale(util.extend({ reverse: true }, params));
150
- expect(s.range()).toEqual([10, 0]);
151
-
152
- // rangeStep
153
- params = {
154
- type: "band",
155
- domain: ["a", "b", "c"],
156
- rangeStep: 20,
157
- padding: 0,
158
- };
159
- s = scale(params);
160
- expect(s.range()).toEqual([0, 60]);
161
- expect(s.bandwidth()).toBe(20);
162
-
163
- s = expect(function () {
164
- scale(util.extend({}, params, { type: "linear" }));
165
- }).toThrow();
166
- });
167
-
168
- test("Scale respects range color schemes", function () {
169
- var s, u, v;
170
-
171
- // performs scheme lookup
172
- s = scale({ type: "ordinal", scheme: "category10" });
173
- expect(s.range().length).toBe(10);
174
-
175
- // throws on invalid scheme
176
- expect(function () {
177
- scale({ type: "ordinal", scheme: "foobarbaz" });
178
- }).toThrow();
179
- expect(function () {
180
- scale({ type: "sequential", scheme: "foobarbaz" });
181
- }).toThrow();
182
-
183
- // handles interpolating schemes and extents
184
- s = scale({ type: "sequential", scheme: "viridis" });
185
- u = s.interpolator();
186
- expect(typeof u).toBe("function");
187
-
188
- s = scale({
189
- type: "sequential",
190
- scheme: "viridis",
191
- schemeExtent: [0.2, 0.9],
192
- });
193
- v = s.interpolator();
194
- expect(typeof v).toBe("function");
195
- expect(v(0)).toBe(u(0.2));
196
- expect(v(1)).toBe(u(0.9));
197
-
198
- s = scale({
199
- type: "sequential",
200
- scheme: "viridis",
201
- schemeExtent: [0.2, 0.9],
202
- reverse: true,
203
- });
204
- v = s.interpolator();
205
- expect(typeof v).toBe("function");
206
- expect(v(0)).toBe(u(0.9));
207
- expect(v(1)).toBe(u(0.2));
208
-
209
- // generate interpolator as needed
210
- s = scale({ type: "sequential", range: ["#000", "#f00"] });
211
- v = s.interpolator();
212
- expect(typeof v).toBe("function");
213
- expect(v(0)).toBe("rgb(0, 0, 0)");
214
- expect(v(1)).toBe("rgb(255, 0, 0)");
215
-
216
- // quantize to provided scheme count
217
- s = scale({ type: "quantize", scheme: "viridis", schemeCount: 3 });
218
- v = s.range();
219
- expect(v.length).toBe(3);
220
- expect(v[0]).toBe(u(1 / 4));
221
- expect(v[1]).toBe(u(2 / 4));
222
- expect(v[2]).toBe(u(3 / 4));
223
- });
224
-
225
- test("Scale warns for zero in log domain", function () {
226
- function logScale(domain) {
227
- const logger = {
228
- count: 0,
229
- warn: function (msg) {
230
- this.count++;
231
- },
232
- };
233
-
234
- return function () {
235
- scale({ type: "log", domain: domain }, logger);
236
- if (logger.count) {
237
- throw new Error();
238
- }
239
- };
240
- }
241
-
242
- expect(logScale([0, 1])).toThrow();
243
- expect(logScale([-1, 0])).toThrow();
244
- expect(logScale([-1, 1])).toThrow();
245
- expect(logScale([1, 0, 2])).toThrow();
246
- expect(logScale([1, 2])).not.toThrow();
247
- expect(logScale([-2, -1])).not.toThrow();
248
- });
249
-
250
- test("Scale infers scale key from type, domain, and range", function () {
251
- function key(params) {
252
- return scale(params).type;
253
- }
254
-
255
- // numeric domain scales should adapt
256
- [vs.Linear, vs.Log, vs.Pow, vs.Sqrt, vs.Symlog].forEach(function (st) {
257
- expect(key({ type: st, domain: [0, 1], range: [0, 1] })).toBe(st);
258
- expect(key({ type: st, domain: [0, 1], range: [true, false] })).toBe(
259
- st
260
- );
261
-
262
- // direct color range specification
263
- expect(key({ type: st, domain: [0, 1], range: ["blue", "red"] })).toBe(
264
- `${vs.Sequential}-${st}`
265
- );
266
- expect(
267
- key({ type: st, domain: [0, 1, 2], range: ["blue", "red"] })
268
- ).toBe(`${vs.Diverging}-${st}`);
269
- expect(
270
- key({ type: st, domain: [0, 1, 2, 3], range: ["blue", "red"] })
271
- ).toBe(st);
272
-
273
- // color scheme range specification
274
- expect(key({ type: st, domain: [0, 1], scheme: "blues" })).toBe(
275
- `${vs.Sequential}-${st}`
276
- );
277
- expect(key({ type: st, domain: [0, 1, 2], scheme: "blues" })).toBe(
278
- `${vs.Diverging}-${st}`
279
- );
280
- expect(key({ type: st, domain: [0, 1, 2, 3], scheme: "blues" })).toBe(
281
- st
282
- );
283
- });
284
-
285
- // temporal domain scales should not adapt
286
- [vs.Time, vs.UTC].forEach(function (st) {
287
- const t0 = new Date(2010, 0, 1),
288
- t1 = new Date(2011, 0, 1),
289
- t2 = new Date(2012, 0, 1),
290
- t3 = new Date(2013, 0, 1);
291
-
292
- expect(key({ type: st, domain: [t0, t1], range: [0, 1] })).toBe(st);
293
- expect(key({ type: st, domain: [t0, t1], range: [true, false] })).toBe(
294
- st
295
- );
296
-
297
- // direct color range specification
298
- expect(
299
- key({ type: st, domain: [t0, t1], range: ["blue", "red"] })
300
- ).toBe(st);
301
- expect(
302
- key({ type: st, domain: [t0, t1, t2], range: ["blue", "red"] })
303
- ).toBe(st);
304
- expect(
305
- key({ type: st, domain: [t0, t1, t2, t3], range: ["blue", "red"] })
306
- ).toBe(st);
307
-
308
- // color scheme range specification
309
- expect(key({ type: st, domain: [t0, t1], scheme: "blues" })).toBe(st);
310
- expect(key({ type: st, domain: [t0, t1, t2], scheme: "blues" })).toBe(
311
- st
312
- );
313
- expect(
314
- key({ type: st, domain: [t0, t1, t2, t3], scheme: "blues" })
315
- ).toBe(st);
316
- });
317
-
318
- // sequential should work for backwards compatibility
319
- const st = vs.Sequential;
320
- expect(key({ type: st, domain: [0, 1], range: ["blue", "red"] })).toBe(
321
- `${st}-${vs.Linear}`
322
- );
323
- expect(key({ type: st, domain: [0, 1], scheme: "blues" })).toBe(
324
- `${st}-${vs.Linear}`
325
- );
326
- });
@@ -1,46 +0,0 @@
1
- import { expect, test } from "vitest";
2
- /*!
3
- * Adapted from vega-encode:
4
- * https://github.com/vega/vega/blob/master/packages/vega-encode/test/scale-test.js
5
- *
6
- * Copyright (c) 2015-2018, University of Washington Interactive Data Lab
7
- * All rights reserved.
8
- *
9
- * BSD-3-Clause License: https://github.com/vega/vega-lite/blob/master/LICENSE
10
- */
11
-
12
- /* eslint-disable */
13
-
14
- import { validTicks } from "./ticks.js";
15
-
16
- test("validTicks uses count correctly", function () {
17
- var data = [0, 1, 2, 3, 4, 5, 6, 7];
18
-
19
- /**
20
- *
21
- * @param {T} x
22
- * @returns {T}
23
- * @template T
24
- */
25
- var identity = function (x) {
26
- return x;
27
- };
28
- identity.range = function () {
29
- return [0, 10];
30
- };
31
-
32
- var t1 = validTicks(identity, data, 5);
33
- expect(t1).toEqual([0, 2, 4, 6]);
34
-
35
- // don't change ticks if count is large
36
- var t2 = validTicks(identity, data, 100);
37
- expect(t2).toEqual(data);
38
-
39
- // special case for low number of ticks
40
- var t3 = validTicks(identity, data, 3);
41
- expect(t3).toEqual([0, 7]);
42
-
43
- // single tick should pass through
44
- var t5 = validTicks(identity, [1], 5);
45
- expect(t5).toEqual([1]);
46
- });
@@ -1,14 +0,0 @@
1
- import { describe, it, expect } from "vitest";
2
- import { asEventConfig } from "./selection.js";
3
-
4
- describe("asEventSpec", () => {
5
- it("parses a simple string event type", () => {
6
- const res = asEventConfig("click");
7
- expect(res).toEqual({ type: "click" });
8
- });
9
-
10
- it("parses a string event type with bracket filter", () => {
11
- const res = asEventConfig("click[event.shiftKey]");
12
- expect(res).toEqual({ type: "click", filter: "event.shiftKey" });
13
- });
14
- });
@@ -1,30 +0,0 @@
1
- import { expect, test } from "vitest";
2
- import addBaseUrl, { endWithSlash } from "./addBaseUrl.js";
3
-
4
- test("addBaseUrl adds baseUrl when needed", () => {
5
- expect(addBaseUrl("foo.html", "https://site.com/")).toEqual(
6
- "https://site.com/foo.html"
7
- );
8
- expect(addBaseUrl("foo.html", "https://site.com")).toEqual(
9
- "https://site.com/foo.html"
10
- );
11
- expect(addBaseUrl("bar/foo.html", "https://site.com/")).toEqual(
12
- "https://site.com/bar/foo.html"
13
- );
14
- expect(addBaseUrl("../foo.html", "https://site.com/bar/")).toEqual(
15
- "https://site.com/bar/../foo.html"
16
- );
17
- });
18
-
19
- test("addBaseUrl doesn't add baseUrl when not needed", () => {
20
- expect(addBaseUrl("/foo.html", "https://site.com/")).toEqual("/foo.html");
21
- expect(addBaseUrl("foo.html", undefined)).toEqual("foo.html");
22
- });
23
-
24
- test("endWithSlash adds slash when needed", () => {
25
- expect(endWithSlash(null)).toBeNull();
26
- expect(endWithSlash("https://site.com")).toEqual("https://site.com/");
27
- expect(endWithSlash("https://site.com/")).toEqual("https://site.com/");
28
- expect(() => endWithSlash("https://site.com/foo?bar")).toThrow();
29
- expect(() => endWithSlash("https://site.com/foo#bar")).toThrow();
30
- });
@@ -1,201 +0,0 @@
1
- import { describe, expect, test } from "vitest";
2
- import { createBinningRangeIndexer } from "./binnedIndex.js";
3
-
4
- describe("Binning Indexer", () => {
5
- test("Single point is binned correctly", () => {
6
- const items = [25];
7
- const indexer = createBinningRangeIndexer(10, [0, 100], (x) => x);
8
-
9
- // Each item uses two vertices
10
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
11
-
12
- const index = indexer.getIndex();
13
-
14
- expect(index(1, 4)).toEqual([0, 0]);
15
- expect(index(23, 27)).toEqual([0, 2]);
16
- expect(index(13, 37)).toEqual([0, 2]);
17
- // TODO: MAX_INT could be replaced with the actual maximum vertex number
18
- expect(index(40, 42)).toEqual([2147483647, 2147483647]);
19
- });
20
-
21
- test("Multiple points are binned correctly", () => {
22
- const items = [0, 1, 4, 10, 35, 35, 36, 80];
23
- const indexer = createBinningRangeIndexer(10, [0, 100], (x) => x);
24
-
25
- // Each item uses two vertices
26
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
27
-
28
- const index = indexer.getIndex();
29
-
30
- expect(index(0, 0)).toEqual([0, 6]);
31
- expect(index(0, 1)).toEqual([0, 6]);
32
- expect(index(1, 2)).toEqual([0, 6]);
33
- expect(index(1, 15)).toEqual([0, 8]);
34
- expect(index(3, 6)).toEqual([0, 6]);
35
- expect(index(10, 15)).toEqual([6, 8]);
36
- expect(index(11, 38)).toEqual([6, 14]);
37
- expect(index(11, 45)).toEqual([6, 14]);
38
- expect(index(34, 36)).toEqual([8, 14]);
39
- expect(index(35.5, 36.5)).toEqual([8, 14]);
40
- expect(index(40, 50)).toEqual([14, 14]);
41
- expect(index(40, 85)).toEqual([14, 16]);
42
- expect(index(90, 100)).toEqual([16, 16]);
43
-
44
- expect(index(0, 100)).toEqual([0, 16]);
45
- expect(index(-1, 100)).toEqual([0, 16]);
46
- expect(index(0, 101)).toEqual([0, 16]);
47
- });
48
-
49
- test("Non-overlapping ranges are binned correctly", () => {
50
- const items = [
51
- [0, 5],
52
- [25, 48],
53
- [50, 55],
54
- [64, 67],
55
- [72, 75],
56
- [75, 78],
57
- [86, 90],
58
- [90, 93],
59
- ];
60
- const indexer = createBinningRangeIndexer(
61
- 10,
62
- [0, 100],
63
- (x) => x[0],
64
- (x) => x[1]
65
- );
66
-
67
- // Each item uses two vertices
68
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
69
-
70
- const index = indexer.getIndex();
71
-
72
- expect(index(0, 1)).toEqual([0, 2]);
73
- expect(index(3, 40)).toEqual([0, 4]);
74
- expect(index(6, 40)).toEqual([0, 4]);
75
- expect(index(15, 30)).toEqual([2, 4]);
76
- expect(index(50, 57)).toEqual([4, 6]);
77
- expect(index(62, 69)).toEqual([6, 8]);
78
- expect(index(69, 71)).toEqual([6, 12]);
79
- expect(index(69, 79)).toEqual([6, 12]);
80
-
81
- expect(index(80, 90)).toEqual([12, 14]);
82
- expect(index(90, 100)).toEqual([14, 16]);
83
-
84
- expect(index(0, 99)).toEqual([0, 16]);
85
- expect(index(0, 100)).toEqual([0, 16]);
86
- });
87
-
88
- test("Overlapping ranges with the same start coordinate are binned correctly", () => {
89
- const items = [
90
- // Increasing lengths
91
- [0, 5],
92
- [0, 64],
93
- [0, 80],
94
- // Decreasing lengths
95
- [100, 191],
96
- [100, 167],
97
- [100, 123],
98
- ];
99
- const indexer = createBinningRangeIndexer(
100
- 100,
101
- [0, 1000],
102
- (x) => x[0],
103
- (x) => x[1]
104
- );
105
-
106
- // Each item uses two vertices
107
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
108
-
109
- const index = indexer.getIndex();
110
-
111
- expect(index(0, 1)).toEqual([0, 6]);
112
- expect(index(3, 40)).toEqual([0, 6]);
113
- expect(index(0, 100)).toEqual([0, 6]);
114
- expect(index(77, 78)).toEqual([4, 6]);
115
-
116
- expect(index(90, 205)).toEqual([6, 12]);
117
- expect(index(111, 115)).toEqual([6, 12]);
118
- // Not optimal. Should be [6, 8], but [6, 12] is not wrong
119
- expect(index(180, 190)).toEqual([6, 12]);
120
- });
121
-
122
- test("Overlapping ranges are binned correctly", () => {
123
- const items = [
124
- [10, 30],
125
- [25, 50],
126
-
127
- [102, 129],
128
- [112, 139],
129
- [121, 149],
130
- ];
131
- const indexer = createBinningRangeIndexer(
132
- 100,
133
- [0, 1000],
134
- (x) => x[0],
135
- (x) => x[1]
136
- );
137
-
138
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
139
-
140
- const index = indexer.getIndex();
141
-
142
- // TODO: More tests
143
-
144
- expect(index(0, 5)).toEqual([0, 0]);
145
- expect(index(0, 15)).toEqual([0, 2]);
146
- expect(index(27, 40)).toEqual([0, 4]);
147
- expect(index(40, 50)).toEqual([2, 4]);
148
- expect(index(40, 80)).toEqual([2, 4]);
149
- expect(index(10, 29)).toEqual([0, 4]);
150
-
151
- expect(index(90, 160)).toEqual([4, 10]);
152
- expect(index(115, 116)).toEqual([4, 8]);
153
- expect(index(135, 145)).toEqual([6, 10]);
154
- });
155
-
156
- test("Unordered ranges disable the index", () => {
157
- const items = [
158
- [10, 30],
159
- [25, 50],
160
-
161
- [112, 139],
162
- [102, 129], // <- Unordered!
163
- [121, 149],
164
- ];
165
- const indexer = createBinningRangeIndexer(
166
- 100,
167
- [0, 1000],
168
- (x) => x[0],
169
- (x) => x[1]
170
- );
171
-
172
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
173
-
174
- const index = indexer.getIndex();
175
-
176
- expect(index).toBeUndefined();
177
- });
178
-
179
- test("Inverted ranges disable the index", () => {
180
- const items = [
181
- [10, 30],
182
- [25, 50],
183
-
184
- [102, 129],
185
- [139, 112], // <- Inverted!
186
- [121, 149],
187
- ];
188
- const indexer = createBinningRangeIndexer(
189
- 100,
190
- [0, 1000],
191
- (x) => x[0],
192
- (x) => x[1]
193
- );
194
-
195
- items.forEach((x, i) => indexer(x, i * 2, (i + 1) * 2));
196
-
197
- const index = indexer.getIndex();
198
-
199
- expect(index).toBeUndefined();
200
- });
201
- });
@@ -1,35 +0,0 @@
1
- import { expect, test } from "vitest";
2
- import createCloner, { getAllProperties } from "./cloner.js";
3
-
4
- const template = {
5
- 1: "iddqd",
6
- a: 1,
7
- c: "xyzzy",
8
- b: "idclip",
9
- };
10
-
11
- test("Cloner clones object properly", () => {
12
- const makeClone = createCloner(template);
13
-
14
- expect(makeClone(template)).toEqual(template);
15
- expect(makeClone(template)).not.toBe(template);
16
-
17
- const another = {
18
- 1: "hello",
19
- a: 2,
20
- c: "idkfa",
21
- b: "idclip",
22
- };
23
-
24
- expect(makeClone(another)).toEqual(another);
25
- expect(makeClone(another)).not.toBe(another);
26
- });
27
-
28
- test("getAllProperties", () => {
29
- expect(getAllProperties(template)).toEqual(["1", "a", "c", "b"]);
30
-
31
- const obj = Object.create(template);
32
- obj.d = 42;
33
-
34
- expect(getAllProperties(obj)).toEqual(["d", "1", "a", "c", "b"]);
35
- });
@@ -1,16 +0,0 @@
1
- import { expect, test } from "vitest";
2
- import coalesce from "./coalesce.js";
3
-
4
- test("Coalesce returns first defined value", () => {
5
- expect(coalesce(0, 1, 2, 3)).toEqual(0);
6
- expect(coalesce(undefined, 1, 2, 3)).toEqual(1);
7
- expect(coalesce(undefined, undefined, 2, 3)).toEqual(2);
8
- });
9
-
10
- test("Coalesce returns undefined if input is all-undefined", () => {
11
- expect(coalesce(undefined, undefined)).toBeUndefined();
12
- });
13
-
14
- test("Coalesce returns undefined on empty input", () => {
15
- expect(coalesce()).toBeUndefined();
16
- });
@@ -1,8 +0,0 @@
1
- import { expect, test } from "vitest";
2
- import concatIterables from "./concatIterables.js";
3
-
4
- test("ConcatIterables yields all elements in the correct order", () => {
5
- expect([...concatIterables([1, 2], [3, 4], [5, 6, 7], [-1000])]).toEqual([
6
- 1, 2, 3, 4, 5, 6, 7, -1000,
7
- ]);
8
- });