matterviz 0.3.5 → 0.3.6

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 (855) hide show
  1. package/.vscode/launch.json +13 -0
  2. package/.vscodeignore +7 -0
  3. package/dist/assets/STLExporter-BpTH3YHE.js +8 -0
  4. package/dist/assets/browser-DdDecX_W.js +1 -0
  5. package/dist/assets/export-qgn-H9y6.js +2 -0
  6. package/dist/assets/main-DiKYzti2.css +1 -0
  7. package/dist/assets/moyo_wasm_bg-0ocwg7xY.wasm +0 -0
  8. package/dist/extension.js +31293 -0
  9. package/dist/src/lib/FilePicker.svelte +360 -0
  10. package/dist/src/lib/MillerIndexInput.svelte +66 -0
  11. package/dist/src/lib/api/mp.ts +26 -0
  12. package/dist/src/lib/api/optimade.ts +204 -0
  13. package/dist/src/lib/brillouin/BrillouinZone.svelte +549 -0
  14. package/dist/src/lib/brillouin/BrillouinZoneControls.svelte +144 -0
  15. package/dist/src/lib/brillouin/BrillouinZoneExportPane.svelte +146 -0
  16. package/dist/src/lib/brillouin/BrillouinZoneInfoPane.svelte +146 -0
  17. package/dist/src/lib/brillouin/BrillouinZoneScene.svelte +476 -0
  18. package/dist/src/lib/brillouin/BrillouinZoneTooltip.svelte +92 -0
  19. package/dist/src/lib/brillouin/compute.ts +529 -0
  20. package/dist/src/lib/brillouin/index.ts +8 -0
  21. package/dist/src/lib/brillouin/types.ts +51 -0
  22. package/dist/src/lib/chempot-diagram/ChemPotDiagram.svelte +327 -0
  23. package/dist/src/lib/chempot-diagram/ChemPotDiagram2D.svelte +846 -0
  24. package/dist/src/lib/chempot-diagram/ChemPotDiagram3D.svelte +3193 -0
  25. package/dist/src/lib/chempot-diagram/async-compute.svelte.ts +94 -0
  26. package/dist/src/lib/chempot-diagram/chempot-worker.ts +11 -0
  27. package/dist/src/lib/chempot-diagram/color.ts +42 -0
  28. package/dist/src/lib/chempot-diagram/compute.ts +1014 -0
  29. package/dist/src/lib/chempot-diagram/index.ts +6 -0
  30. package/dist/src/lib/chempot-diagram/pointer.ts +56 -0
  31. package/dist/src/lib/chempot-diagram/temperature.ts +77 -0
  32. package/dist/src/lib/chempot-diagram/types.ts +130 -0
  33. package/dist/src/lib/colors/index.ts +249 -0
  34. package/dist/src/lib/composition/BarChart.svelte +297 -0
  35. package/dist/src/lib/composition/BubbleChart.svelte +218 -0
  36. package/dist/src/lib/composition/Composition.svelte +165 -0
  37. package/dist/src/lib/composition/Formula.svelte +268 -0
  38. package/dist/src/lib/composition/FormulaFilter.svelte +1257 -0
  39. package/dist/src/lib/composition/PieChart.svelte +323 -0
  40. package/dist/src/lib/composition/format.ts +155 -0
  41. package/dist/src/lib/composition/index.ts +37 -0
  42. package/dist/src/lib/composition/parse.ts +605 -0
  43. package/dist/src/lib/constants.ts +134 -0
  44. package/dist/src/lib/controls.ts +42 -0
  45. package/dist/src/lib/convex-hull/ConvexHull.svelte +157 -0
  46. package/dist/src/lib/convex-hull/ConvexHull2D.svelte +825 -0
  47. package/dist/src/lib/convex-hull/ConvexHull3D.svelte +1801 -0
  48. package/dist/src/lib/convex-hull/ConvexHull4D.svelte +1398 -0
  49. package/dist/src/lib/convex-hull/ConvexHullControls.svelte +535 -0
  50. package/dist/src/lib/convex-hull/ConvexHullInfoPane.svelte +125 -0
  51. package/dist/src/lib/convex-hull/ConvexHullStats.svelte +929 -0
  52. package/dist/src/lib/convex-hull/ConvexHullTooltip.svelte +131 -0
  53. package/dist/src/lib/convex-hull/GasPressureControls.svelte +247 -0
  54. package/dist/src/lib/convex-hull/StructurePopup.svelte +151 -0
  55. package/dist/src/lib/convex-hull/TemperatureSlider.svelte +140 -0
  56. package/dist/src/lib/convex-hull/barycentric-coords.ts +246 -0
  57. package/dist/src/lib/convex-hull/demo-temperature.ts +63 -0
  58. package/dist/src/lib/convex-hull/gas-thermodynamics.ts +405 -0
  59. package/dist/src/lib/convex-hull/helpers.ts +932 -0
  60. package/dist/src/lib/convex-hull/index.ts +202 -0
  61. package/dist/src/lib/convex-hull/thermodynamics.ts +2192 -0
  62. package/dist/src/lib/convex-hull/types.ts +267 -0
  63. package/dist/src/lib/coordination/CoordinationBarPlot.svelte +311 -0
  64. package/dist/src/lib/coordination/calc-coordination.ts +93 -0
  65. package/dist/src/lib/coordination/index.ts +9 -0
  66. package/dist/src/lib/effects.svelte.ts +48 -0
  67. package/dist/src/lib/element/BohrAtom.svelte +147 -0
  68. package/dist/src/lib/element/ElementHeading.svelte +26 -0
  69. package/dist/src/lib/element/ElementPhoto.svelte +57 -0
  70. package/dist/src/lib/element/ElementStats.svelte +80 -0
  71. package/dist/src/lib/element/ElementTile.svelte +484 -0
  72. package/dist/src/lib/element/data.json.gz.d.ts +4 -0
  73. package/dist/src/lib/element/data.ts +14 -0
  74. package/dist/src/lib/element/index.ts +8 -0
  75. package/dist/src/lib/element/types.ts +62 -0
  76. package/dist/src/lib/feedback/ClickFeedback.svelte +58 -0
  77. package/dist/src/lib/feedback/DragOverlay.svelte +42 -0
  78. package/dist/src/lib/feedback/index.ts +4 -0
  79. package/dist/src/lib/fermi-surface/FermiSlice.svelte +189 -0
  80. package/dist/src/lib/fermi-surface/FermiSurface.svelte +600 -0
  81. package/dist/src/lib/fermi-surface/FermiSurfaceControls.svelte +448 -0
  82. package/dist/src/lib/fermi-surface/FermiSurfaceScene.svelte +794 -0
  83. package/dist/src/lib/fermi-surface/FermiSurfaceTooltip.svelte +111 -0
  84. package/dist/src/lib/fermi-surface/compute.ts +728 -0
  85. package/dist/src/lib/fermi-surface/constants.ts +32 -0
  86. package/dist/src/lib/fermi-surface/export.ts +64 -0
  87. package/dist/src/lib/fermi-surface/index.ts +14 -0
  88. package/dist/src/lib/fermi-surface/marching-cubes.ts +3 -0
  89. package/dist/src/lib/fermi-surface/parse.ts +574 -0
  90. package/dist/src/lib/fermi-surface/symmetry.ts +56 -0
  91. package/dist/src/lib/fermi-surface/types.ts +159 -0
  92. package/dist/src/lib/heatmap-matrix/HeatmapMatrix.svelte +1545 -0
  93. package/dist/src/lib/heatmap-matrix/HeatmapMatrixControls.svelte +225 -0
  94. package/dist/src/lib/heatmap-matrix/index.ts +167 -0
  95. package/dist/src/lib/heatmap-matrix/shared.ts +7 -0
  96. package/dist/src/lib/icons.ts +650 -0
  97. package/dist/src/lib/index.ts +61 -0
  98. package/dist/src/lib/io/decompress.ts +92 -0
  99. package/dist/src/lib/io/export.ts +385 -0
  100. package/dist/src/lib/io/fetch.ts +46 -0
  101. package/dist/src/lib/io/file-drop.ts +51 -0
  102. package/dist/src/lib/io/index.ts +7 -0
  103. package/dist/src/lib/io/is-binary.ts +24 -0
  104. package/dist/src/lib/io/types.ts +8 -0
  105. package/dist/src/lib/io/url-drop.ts +141 -0
  106. package/dist/src/lib/isosurface/Isosurface.svelte +285 -0
  107. package/dist/src/lib/isosurface/IsosurfaceControls.svelte +277 -0
  108. package/dist/src/lib/isosurface/index.ts +7 -0
  109. package/dist/src/lib/isosurface/parse.ts +656 -0
  110. package/dist/src/lib/isosurface/slice.ts +175 -0
  111. package/dist/src/lib/isosurface/types.ts +309 -0
  112. package/dist/src/lib/labels.ts +320 -0
  113. package/dist/src/lib/layout/FullscreenToggle.svelte +50 -0
  114. package/dist/src/lib/layout/InfoCard.svelte +120 -0
  115. package/dist/src/lib/layout/InfoTag.svelte +185 -0
  116. package/dist/src/lib/layout/PropertyFilter.svelte +246 -0
  117. package/dist/src/lib/layout/SettingsSection.svelte +148 -0
  118. package/dist/src/lib/layout/SubpageGrid.svelte +82 -0
  119. package/dist/src/lib/layout/fullscreen.ts +65 -0
  120. package/dist/src/lib/layout/index.ts +11 -0
  121. package/dist/src/lib/layout/json-tree/JsonNode.svelte +548 -0
  122. package/dist/src/lib/layout/json-tree/JsonTree.svelte +1230 -0
  123. package/dist/src/lib/layout/json-tree/JsonValue.svelte +334 -0
  124. package/dist/src/lib/layout/json-tree/index.ts +3 -0
  125. package/dist/src/lib/layout/json-tree/types.ts +126 -0
  126. package/dist/src/lib/layout/json-tree/utils.ts +682 -0
  127. package/dist/src/lib/marching-cubes.ts +614 -0
  128. package/dist/src/lib/math.ts +1081 -0
  129. package/dist/src/lib/overlays/ContextMenu.svelte +162 -0
  130. package/dist/src/lib/overlays/CopyButton.svelte +45 -0
  131. package/dist/src/lib/overlays/DragControlTab.svelte +98 -0
  132. package/dist/src/lib/overlays/DraggablePane.svelte +487 -0
  133. package/dist/src/lib/overlays/InfoPaneCards.svelte +149 -0
  134. package/dist/src/lib/overlays/index.ts +3 -0
  135. package/dist/src/lib/periodic-table/PeriodicTable.svelte +469 -0
  136. package/dist/src/lib/periodic-table/PeriodicTableControls.svelte +557 -0
  137. package/dist/src/lib/periodic-table/PropertySelect.svelte +37 -0
  138. package/dist/src/lib/periodic-table/index.ts +12 -0
  139. package/dist/src/lib/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +1086 -0
  140. package/dist/src/lib/phase-diagram/PhaseDiagramControls.svelte +444 -0
  141. package/dist/src/lib/phase-diagram/PhaseDiagramEditorPane.svelte +126 -0
  142. package/dist/src/lib/phase-diagram/PhaseDiagramExportPane.svelte +184 -0
  143. package/dist/src/lib/phase-diagram/PhaseDiagramTooltip.svelte +391 -0
  144. package/dist/src/lib/phase-diagram/TdbInfoPanel.svelte +203 -0
  145. package/dist/src/lib/phase-diagram/build-diagram.ts +186 -0
  146. package/dist/src/lib/phase-diagram/colors.ts +58 -0
  147. package/dist/src/lib/phase-diagram/diagram-input.ts +40 -0
  148. package/dist/src/lib/phase-diagram/index.ts +13 -0
  149. package/dist/src/lib/phase-diagram/parse.ts +348 -0
  150. package/dist/src/lib/phase-diagram/svg-to-diagram.ts +1023 -0
  151. package/dist/src/lib/phase-diagram/types.ts +144 -0
  152. package/dist/src/lib/phase-diagram/utils.ts +775 -0
  153. package/dist/src/lib/plot/AxisLabel.svelte +51 -0
  154. package/dist/src/lib/plot/BarPlot.svelte +2113 -0
  155. package/dist/src/lib/plot/BarPlotControls.svelte +66 -0
  156. package/dist/src/lib/plot/BinnedScatterPlot.svelte +1114 -0
  157. package/dist/src/lib/plot/ColorBar.svelte +721 -0
  158. package/dist/src/lib/plot/ColorScaleSelect.svelte +54 -0
  159. package/dist/src/lib/plot/ElementScatter.svelte +63 -0
  160. package/dist/src/lib/plot/FillArea.svelte +223 -0
  161. package/dist/src/lib/plot/Histogram.svelte +1558 -0
  162. package/dist/src/lib/plot/HistogramControls.svelte +212 -0
  163. package/dist/src/lib/plot/InteractiveAxisLabel.svelte +96 -0
  164. package/dist/src/lib/plot/Line.svelte +84 -0
  165. package/dist/src/lib/plot/PlotAxis.svelte +169 -0
  166. package/dist/src/lib/plot/PlotControls.svelte +537 -0
  167. package/dist/src/lib/plot/PlotLegend.svelte +569 -0
  168. package/dist/src/lib/plot/PlotTooltip.svelte +67 -0
  169. package/dist/src/lib/plot/PortalSelect.svelte +253 -0
  170. package/dist/src/lib/plot/ReferenceLine3D.svelte +156 -0
  171. package/dist/src/lib/plot/ReferencePlane.svelte +175 -0
  172. package/dist/src/lib/plot/ScatterPlot.svelte +2778 -0
  173. package/dist/src/lib/plot/ScatterPlot3D.svelte +529 -0
  174. package/dist/src/lib/plot/ScatterPlot3DControls.svelte +437 -0
  175. package/dist/src/lib/plot/ScatterPlot3DScene.svelte +912 -0
  176. package/dist/src/lib/plot/ScatterPlotControls.svelte +306 -0
  177. package/dist/src/lib/plot/ScatterPoint.svelte +182 -0
  178. package/dist/src/lib/plot/SpacegroupBarPlot.svelte +293 -0
  179. package/dist/src/lib/plot/Surface3D.svelte +197 -0
  180. package/dist/src/lib/plot/ZeroLines.svelte +97 -0
  181. package/dist/src/lib/plot/ZoomRect.svelte +23 -0
  182. package/dist/src/lib/plot/adaptive-density.ts +316 -0
  183. package/dist/src/lib/plot/auto-place.ts +184 -0
  184. package/dist/src/lib/plot/axis-utils.ts +122 -0
  185. package/dist/src/lib/plot/binned-scatter-types.ts +83 -0
  186. package/dist/src/lib/plot/data-cleaning.ts +1069 -0
  187. package/dist/src/lib/plot/data-transform.ts +69 -0
  188. package/dist/src/lib/plot/defaults.ts +9 -0
  189. package/dist/src/lib/plot/fill-utils.ts +494 -0
  190. package/dist/src/lib/plot/hover-lock.svelte.ts +60 -0
  191. package/dist/src/lib/plot/index.ts +53 -0
  192. package/dist/src/lib/plot/interactions.ts +119 -0
  193. package/dist/src/lib/plot/layout.ts +425 -0
  194. package/dist/src/lib/plot/reference-line.ts +426 -0
  195. package/dist/src/lib/plot/scales.ts +654 -0
  196. package/dist/src/lib/plot/svg.ts +23 -0
  197. package/dist/src/lib/plot/types.ts +1144 -0
  198. package/dist/src/lib/plot/utils/label-placement.ts +541 -0
  199. package/dist/src/lib/plot/utils/series-visibility.ts +140 -0
  200. package/dist/src/lib/plot/utils.ts +11 -0
  201. package/dist/src/lib/rdf/RdfPlot.svelte +247 -0
  202. package/dist/src/lib/rdf/calc-rdf.ts +167 -0
  203. package/dist/src/lib/rdf/index.ts +27 -0
  204. package/dist/src/lib/sanitize.ts +126 -0
  205. package/dist/src/lib/settings.ts +1479 -0
  206. package/dist/src/lib/spectral/Bands.svelte +1040 -0
  207. package/dist/src/lib/spectral/BandsAndDos.svelte +134 -0
  208. package/dist/src/lib/spectral/BrillouinBandsDos.svelte +252 -0
  209. package/dist/src/lib/spectral/Dos.svelte +697 -0
  210. package/dist/src/lib/spectral/helpers.ts +1381 -0
  211. package/dist/src/lib/spectral/index.ts +8 -0
  212. package/dist/src/lib/spectral/types.ts +112 -0
  213. package/dist/src/lib/state.svelte.ts +64 -0
  214. package/dist/src/lib/structure/Arrow.svelte +72 -0
  215. package/dist/src/lib/structure/AtomLegend.svelte +815 -0
  216. package/dist/src/lib/structure/Bond.svelte +140 -0
  217. package/dist/src/lib/structure/CanvasTooltip.svelte +33 -0
  218. package/dist/src/lib/structure/CellSelect.svelte +349 -0
  219. package/dist/src/lib/structure/Cylinder.svelte +45 -0
  220. package/dist/src/lib/structure/Lattice.svelte +196 -0
  221. package/dist/src/lib/structure/Structure.svelte +2248 -0
  222. package/dist/src/lib/structure/StructureControls.svelte +1273 -0
  223. package/dist/src/lib/structure/StructureExportPane.svelte +252 -0
  224. package/dist/src/lib/structure/StructureInfoPane.svelte +737 -0
  225. package/dist/src/lib/structure/StructureScene.svelte +2255 -0
  226. package/dist/src/lib/structure/atom-properties.ts +316 -0
  227. package/dist/src/lib/structure/bond-order-perception.ts +447 -0
  228. package/dist/src/lib/structure/bonding.ts +944 -0
  229. package/dist/src/lib/structure/export.ts +861 -0
  230. package/dist/src/lib/structure/index.ts +291 -0
  231. package/dist/src/lib/structure/label-placement.ts +130 -0
  232. package/dist/src/lib/structure/measure.ts +45 -0
  233. package/dist/src/lib/structure/parse.ts +1705 -0
  234. package/dist/src/lib/structure/partial-occupancy.ts +183 -0
  235. package/dist/src/lib/structure/pbc.ts +164 -0
  236. package/dist/src/lib/structure/supercell.ts +226 -0
  237. package/dist/src/lib/structure/validation.ts +11 -0
  238. package/dist/src/lib/symmetry/SymmetryStats.svelte +226 -0
  239. package/dist/src/lib/symmetry/WyckoffTable.svelte +120 -0
  240. package/dist/src/lib/symmetry/cell-transform.ts +118 -0
  241. package/dist/src/lib/symmetry/index.ts +348 -0
  242. package/dist/src/lib/symmetry/spacegroups.ts +404 -0
  243. package/dist/src/lib/table/HeatmapTable.svelte +1833 -0
  244. package/dist/src/lib/table/ToggleMenu.svelte +385 -0
  245. package/dist/src/lib/table/index.ts +139 -0
  246. package/dist/src/lib/theme/ThemeControl.svelte +53 -0
  247. package/dist/src/lib/theme/index.ts +107 -0
  248. package/dist/src/lib/theme/themes.mjs +297 -0
  249. package/dist/src/lib/time.ts +71 -0
  250. package/dist/src/lib/tooltip/TooltipContent.svelte +58 -0
  251. package/dist/src/lib/tooltip/index.ts +2 -0
  252. package/dist/src/lib/tooltip/types.ts +13 -0
  253. package/dist/src/lib/trajectory/Trajectory.svelte +1545 -0
  254. package/dist/src/lib/trajectory/TrajectoryError.svelte +128 -0
  255. package/dist/src/lib/trajectory/TrajectoryExportPane.svelte +357 -0
  256. package/dist/src/lib/trajectory/TrajectoryInfoPane.svelte +313 -0
  257. package/dist/src/lib/trajectory/constants.ts +7 -0
  258. package/dist/src/lib/trajectory/extract.ts +196 -0
  259. package/dist/src/lib/trajectory/format-detect.ts +96 -0
  260. package/dist/src/lib/trajectory/frame-reader.ts +456 -0
  261. package/dist/src/lib/trajectory/helpers.ts +217 -0
  262. package/dist/src/lib/trajectory/index.ts +218 -0
  263. package/dist/src/lib/trajectory/parse/ase.ts +109 -0
  264. package/dist/src/lib/trajectory/parse/hdf5.ts +173 -0
  265. package/dist/src/lib/trajectory/parse/index.ts +411 -0
  266. package/dist/src/lib/trajectory/parse/lammps.ts +215 -0
  267. package/dist/src/lib/trajectory/parse/vasp.ts +102 -0
  268. package/dist/src/lib/trajectory/parse/xyz.ts +143 -0
  269. package/dist/src/lib/trajectory/plotting.ts +599 -0
  270. package/dist/src/lib/trajectory/types.ts +13 -0
  271. package/dist/src/lib/utils.ts +56 -0
  272. package/dist/src/lib/xrd/XrdPlot.svelte +615 -0
  273. package/dist/src/lib/xrd/broadening.ts +130 -0
  274. package/dist/src/lib/xrd/calc-xrd.ts +397 -0
  275. package/dist/src/lib/xrd/index.ts +38 -0
  276. package/dist/src/lib/xrd/parse.ts +858 -0
  277. package/dist/webview.js +29421 -0
  278. package/icon.png +0 -0
  279. package/license +1 -1
  280. package/matterviz-0.3.2.vsix +0 -0
  281. package/matterviz-0.3.4.vsix +0 -0
  282. package/matterviz-0.3.5.vsix +0 -0
  283. package/package.json +1460 -215
  284. package/readme.md +171 -98
  285. package/scripts/sync-config.ts +101 -0
  286. package/src/declarations.d.ts +2 -0
  287. package/src/extension.ts +972 -0
  288. package/src/node-io.ts +65 -0
  289. package/src/types.ts +17 -0
  290. package/src/webview/JsonBrowser.svelte +1079 -0
  291. package/src/webview/PlotPanel.svelte +346 -0
  292. package/src/webview/detect.ts +444 -0
  293. package/src/webview/main.ts +764 -0
  294. package/src/webview/plot-utils.ts +250 -0
  295. package/test-fixtures/all-viz-types.json.gz +0 -0
  296. package/test-fixtures/plot-demo-data.json.gz +0 -0
  297. package/tests/detect.test.ts +604 -0
  298. package/tests/extension.test.ts +2041 -0
  299. package/tests/node-io.test.ts +39 -0
  300. package/tests/plot-utils.test.ts +302 -0
  301. package/tests/vite-plugin-json-gz.test.ts +114 -0
  302. package/tests/vscode-mock.ts +18 -0
  303. package/tests/webview.test.ts +231 -0
  304. package/tsconfig.json +20 -0
  305. package/vite-plugin-json-gz.ts +29 -0
  306. package/vite.config.ts +34 -0
  307. package/vite.extension.config.ts +34 -0
  308. package/dist/EmptyState.svelte.d.ts +0 -9
  309. package/dist/FilePicker.svelte +0 -360
  310. package/dist/FilePicker.svelte.d.ts +0 -17
  311. package/dist/Icon.svelte.d.ts +0 -13
  312. package/dist/MillerIndexInput.svelte +0 -66
  313. package/dist/MillerIndexInput.svelte.d.ts +0 -7
  314. package/dist/api/mp.d.ts +0 -6
  315. package/dist/api/mp.js +0 -22
  316. package/dist/api/optimade.d.ts +0 -45
  317. package/dist/api/optimade.js +0 -135
  318. package/dist/brillouin/BrillouinZone.svelte +0 -546
  319. package/dist/brillouin/BrillouinZone.svelte.d.ts +0 -83
  320. package/dist/brillouin/BrillouinZoneControls.svelte +0 -144
  321. package/dist/brillouin/BrillouinZoneControls.svelte.d.ts +0 -17
  322. package/dist/brillouin/BrillouinZoneExportPane.svelte +0 -148
  323. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +0 -15
  324. package/dist/brillouin/BrillouinZoneInfoPane.svelte +0 -146
  325. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +0 -13
  326. package/dist/brillouin/BrillouinZoneScene.svelte +0 -476
  327. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +0 -48
  328. package/dist/brillouin/BrillouinZoneTooltip.svelte +0 -92
  329. package/dist/brillouin/BrillouinZoneTooltip.svelte.d.ts +0 -8
  330. package/dist/brillouin/compute.d.ts +0 -17
  331. package/dist/brillouin/compute.js +0 -426
  332. package/dist/brillouin/index.d.ts +0 -8
  333. package/dist/brillouin/index.js +0 -8
  334. package/dist/brillouin/types.d.ts +0 -48
  335. package/dist/brillouin/types.js +0 -1
  336. package/dist/chempot-diagram/ChemPotDiagram.svelte +0 -327
  337. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +0 -13
  338. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +0 -847
  339. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +0 -16
  340. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +0 -3194
  341. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +0 -16
  342. package/dist/chempot-diagram/ChemPotScene3D.svelte.d.ts +0 -7
  343. package/dist/chempot-diagram/async-compute.svelte.d.ts +0 -3
  344. package/dist/chempot-diagram/async-compute.svelte.js +0 -78
  345. package/dist/chempot-diagram/chempot-worker.d.ts +0 -1
  346. package/dist/chempot-diagram/chempot-worker.js +0 -11
  347. package/dist/chempot-diagram/color.d.ts +0 -10
  348. package/dist/chempot-diagram/color.js +0 -32
  349. package/dist/chempot-diagram/compute.d.ts +0 -48
  350. package/dist/chempot-diagram/compute.js +0 -812
  351. package/dist/chempot-diagram/index.d.ts +0 -6
  352. package/dist/chempot-diagram/index.js +0 -6
  353. package/dist/chempot-diagram/pointer.d.ts +0 -16
  354. package/dist/chempot-diagram/pointer.js +0 -40
  355. package/dist/chempot-diagram/temperature.d.ts +0 -15
  356. package/dist/chempot-diagram/temperature.js +0 -36
  357. package/dist/chempot-diagram/types.d.ts +0 -86
  358. package/dist/chempot-diagram/types.js +0 -28
  359. package/dist/colors/index.d.ts +0 -47
  360. package/dist/colors/index.js +0 -203
  361. package/dist/composition/BarChart.svelte +0 -297
  362. package/dist/composition/BarChart.svelte.d.ts +0 -39
  363. package/dist/composition/BubbleChart.svelte +0 -218
  364. package/dist/composition/BubbleChart.svelte.d.ts +0 -28
  365. package/dist/composition/Composition.svelte +0 -164
  366. package/dist/composition/Composition.svelte.d.ts +0 -15
  367. package/dist/composition/Formula.svelte +0 -265
  368. package/dist/composition/Formula.svelte.d.ts +0 -19
  369. package/dist/composition/FormulaFilter.svelte +0 -1259
  370. package/dist/composition/FormulaFilter.svelte.d.ts +0 -51
  371. package/dist/composition/PieChart.svelte +0 -323
  372. package/dist/composition/PieChart.svelte.d.ts +0 -37
  373. package/dist/composition/format.d.ts +0 -15
  374. package/dist/composition/format.js +0 -109
  375. package/dist/composition/index.d.ts +0 -20
  376. package/dist/composition/index.js +0 -14
  377. package/dist/composition/parse.d.ts +0 -55
  378. package/dist/composition/parse.js +0 -459
  379. package/dist/constants.d.ts +0 -29
  380. package/dist/constants.js +0 -99
  381. package/dist/controls.d.ts +0 -14
  382. package/dist/controls.js +0 -30
  383. package/dist/convex-hull/ConvexHull.svelte +0 -157
  384. package/dist/convex-hull/ConvexHull.svelte.d.ts +0 -13
  385. package/dist/convex-hull/ConvexHull2D.svelte +0 -814
  386. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +0 -11
  387. package/dist/convex-hull/ConvexHull3D.svelte +0 -1790
  388. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +0 -8
  389. package/dist/convex-hull/ConvexHull4D.svelte +0 -1386
  390. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +0 -8
  391. package/dist/convex-hull/ConvexHullControls.svelte +0 -546
  392. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +0 -48
  393. package/dist/convex-hull/ConvexHullInfoPane.svelte +0 -122
  394. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +0 -18
  395. package/dist/convex-hull/ConvexHullStats.svelte +0 -922
  396. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +0 -15
  397. package/dist/convex-hull/ConvexHullTooltip.svelte +0 -131
  398. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +0 -33
  399. package/dist/convex-hull/GasPressureControls.svelte +0 -247
  400. package/dist/convex-hull/GasPressureControls.svelte.d.ts +0 -11
  401. package/dist/convex-hull/StructurePopup.svelte +0 -116
  402. package/dist/convex-hull/StructurePopup.svelte.d.ts +0 -18
  403. package/dist/convex-hull/TemperatureSlider.svelte +0 -137
  404. package/dist/convex-hull/TemperatureSlider.svelte.d.ts +0 -8
  405. package/dist/convex-hull/barycentric-coords.d.ts +0 -18
  406. package/dist/convex-hull/barycentric-coords.js +0 -182
  407. package/dist/convex-hull/demo-temperature.d.ts +0 -6
  408. package/dist/convex-hull/demo-temperature.js +0 -40
  409. package/dist/convex-hull/gas-thermodynamics.d.ts +0 -16
  410. package/dist/convex-hull/gas-thermodynamics.js +0 -316
  411. package/dist/convex-hull/helpers.d.ts +0 -103
  412. package/dist/convex-hull/helpers.js +0 -689
  413. package/dist/convex-hull/index.d.ts +0 -118
  414. package/dist/convex-hull/index.js +0 -57
  415. package/dist/convex-hull/thermodynamics.d.ts +0 -66
  416. package/dist/convex-hull/thermodynamics.js +0 -1752
  417. package/dist/convex-hull/types.d.ts +0 -162
  418. package/dist/convex-hull/types.js +0 -36
  419. package/dist/coordination/CoordinationBarPlot.svelte +0 -311
  420. package/dist/coordination/CoordinationBarPlot.svelte.d.ts +0 -30
  421. package/dist/coordination/calc-coordination.d.ts +0 -15
  422. package/dist/coordination/calc-coordination.js +0 -63
  423. package/dist/coordination/index.d.ts +0 -8
  424. package/dist/coordination/index.js +0 -7
  425. package/dist/element/BohrAtom.svelte +0 -147
  426. package/dist/element/BohrAtom.svelte.d.ts +0 -20
  427. package/dist/element/ElementHeading.svelte +0 -26
  428. package/dist/element/ElementHeading.svelte.d.ts +0 -8
  429. package/dist/element/ElementPhoto.svelte +0 -57
  430. package/dist/element/ElementPhoto.svelte.d.ts +0 -9
  431. package/dist/element/ElementStats.svelte +0 -80
  432. package/dist/element/ElementStats.svelte.d.ts +0 -8
  433. package/dist/element/ElementTile.svelte +0 -484
  434. package/dist/element/ElementTile.svelte.d.ts +0 -29
  435. package/dist/element/Nucleus.svelte.d.ts +0 -17
  436. package/dist/element/data.d.ts +0 -2
  437. package/dist/element/data.js +0 -2
  438. package/dist/element/data.json.gz.d.ts +0 -2
  439. package/dist/element/index.d.ts +0 -8
  440. package/dist/element/index.js +0 -8
  441. package/dist/element/types.d.ts +0 -57
  442. package/dist/element/types.js +0 -1
  443. package/dist/feedback/ClickFeedback.svelte +0 -58
  444. package/dist/feedback/ClickFeedback.svelte.d.ts +0 -12
  445. package/dist/feedback/DragOverlay.svelte +0 -42
  446. package/dist/feedback/DragOverlay.svelte.d.ts +0 -7
  447. package/dist/feedback/Spinner.svelte.d.ts +0 -7
  448. package/dist/feedback/StatusMessage.svelte.d.ts +0 -9
  449. package/dist/feedback/index.d.ts +0 -4
  450. package/dist/feedback/index.js +0 -4
  451. package/dist/fermi-surface/FermiSlice.svelte +0 -189
  452. package/dist/fermi-surface/FermiSlice.svelte.d.ts +0 -24
  453. package/dist/fermi-surface/FermiSurface.svelte +0 -600
  454. package/dist/fermi-surface/FermiSurface.svelte.d.ts +0 -83
  455. package/dist/fermi-surface/FermiSurfaceControls.svelte +0 -452
  456. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +0 -35
  457. package/dist/fermi-surface/FermiSurfaceScene.svelte +0 -792
  458. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +0 -50
  459. package/dist/fermi-surface/FermiSurfaceTooltip.svelte +0 -111
  460. package/dist/fermi-surface/FermiSurfaceTooltip.svelte.d.ts +0 -8
  461. package/dist/fermi-surface/compute.d.ts +0 -5
  462. package/dist/fermi-surface/compute.js +0 -538
  463. package/dist/fermi-surface/constants.d.ts +0 -9
  464. package/dist/fermi-surface/constants.js +0 -27
  465. package/dist/fermi-surface/export.d.ts +0 -5
  466. package/dist/fermi-surface/export.js +0 -63
  467. package/dist/fermi-surface/index.d.ts +0 -12
  468. package/dist/fermi-surface/index.js +0 -13
  469. package/dist/fermi-surface/marching-cubes.d.ts +0 -2
  470. package/dist/fermi-surface/marching-cubes.js +0 -2
  471. package/dist/fermi-surface/parse.d.ts +0 -2
  472. package/dist/fermi-surface/parse.js +0 -495
  473. package/dist/fermi-surface/symmetry.d.ts +0 -3
  474. package/dist/fermi-surface/symmetry.js +0 -46
  475. package/dist/fermi-surface/types.d.ts +0 -113
  476. package/dist/fermi-surface/types.js +0 -4
  477. package/dist/heatmap-matrix/HeatmapMatrix.svelte +0 -1527
  478. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +0 -110
  479. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +0 -225
  480. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +0 -30
  481. package/dist/heatmap-matrix/index.d.ts +0 -53
  482. package/dist/heatmap-matrix/index.js +0 -100
  483. package/dist/heatmap-matrix/shared.d.ts +0 -2
  484. package/dist/heatmap-matrix/shared.js +0 -4
  485. package/dist/icons.d.ts +0 -569
  486. package/dist/icons.js +0 -648
  487. package/dist/index.d.ts +0 -39
  488. package/dist/index.js +0 -39
  489. package/dist/io/decompress.d.ts +0 -10
  490. package/dist/io/decompress.js +0 -74
  491. package/dist/io/export.d.ts +0 -16
  492. package/dist/io/export.js +0 -316
  493. package/dist/io/fetch.d.ts +0 -5
  494. package/dist/io/fetch.js +0 -39
  495. package/dist/io/file-drop.d.ts +0 -7
  496. package/dist/io/file-drop.js +0 -43
  497. package/dist/io/index.d.ts +0 -7
  498. package/dist/io/index.js +0 -7
  499. package/dist/io/is-binary.d.ts +0 -1
  500. package/dist/io/is-binary.js +0 -20
  501. package/dist/io/types.d.ts +0 -8
  502. package/dist/io/types.js +0 -1
  503. package/dist/io/url-drop.d.ts +0 -2
  504. package/dist/io/url-drop.js +0 -117
  505. package/dist/isosurface/Isosurface.svelte +0 -285
  506. package/dist/isosurface/Isosurface.svelte.d.ts +0 -8
  507. package/dist/isosurface/IsosurfaceControls.svelte +0 -291
  508. package/dist/isosurface/IsosurfaceControls.svelte.d.ts +0 -9
  509. package/dist/isosurface/index.d.ts +0 -5
  510. package/dist/isosurface/index.js +0 -6
  511. package/dist/isosurface/parse.d.ts +0 -6
  512. package/dist/isosurface/parse.js +0 -553
  513. package/dist/isosurface/slice.d.ts +0 -11
  514. package/dist/isosurface/slice.js +0 -140
  515. package/dist/isosurface/types.d.ts +0 -56
  516. package/dist/isosurface/types.js +0 -227
  517. package/dist/labels.d.ts +0 -53
  518. package/dist/labels.js +0 -274
  519. package/dist/layout/FullscreenToggle.svelte +0 -50
  520. package/dist/layout/FullscreenToggle.svelte.d.ts +0 -7
  521. package/dist/layout/InfoCard.svelte +0 -120
  522. package/dist/layout/InfoCard.svelte.d.ts +0 -21
  523. package/dist/layout/InfoTag.svelte +0 -183
  524. package/dist/layout/InfoTag.svelte.d.ts +0 -19
  525. package/dist/layout/PropertyFilter.svelte +0 -244
  526. package/dist/layout/PropertyFilter.svelte.d.ts +0 -24
  527. package/dist/layout/SettingsSection.svelte +0 -148
  528. package/dist/layout/SettingsSection.svelte.d.ts +0 -17
  529. package/dist/layout/SubpageGrid.svelte +0 -82
  530. package/dist/layout/SubpageGrid.svelte.d.ts +0 -14
  531. package/dist/layout/fullscreen.d.ts +0 -9
  532. package/dist/layout/fullscreen.js +0 -53
  533. package/dist/layout/index.d.ts +0 -10
  534. package/dist/layout/index.js +0 -8
  535. package/dist/layout/json-tree/JsonNode.svelte +0 -548
  536. package/dist/layout/json-tree/JsonNode.svelte.d.ts +0 -11
  537. package/dist/layout/json-tree/JsonTree.svelte +0 -1222
  538. package/dist/layout/json-tree/JsonTree.svelte.d.ts +0 -6
  539. package/dist/layout/json-tree/JsonValue.svelte +0 -334
  540. package/dist/layout/json-tree/JsonValue.svelte.d.ts +0 -9
  541. package/dist/layout/json-tree/index.d.ts +0 -3
  542. package/dist/layout/json-tree/index.js +0 -3
  543. package/dist/layout/json-tree/types.d.ts +0 -73
  544. package/dist/layout/json-tree/types.js +0 -3
  545. package/dist/layout/json-tree/utils.d.ts +0 -29
  546. package/dist/layout/json-tree/utils.js +0 -649
  547. package/dist/marching-cubes.d.ts +0 -14
  548. package/dist/marching-cubes.js +0 -542
  549. package/dist/math.d.ts +0 -91
  550. package/dist/math.js +0 -896
  551. package/dist/overlays/ContextMenu.svelte +0 -162
  552. package/dist/overlays/ContextMenu.svelte.d.ts +0 -25
  553. package/dist/overlays/CopyButton.svelte +0 -45
  554. package/dist/overlays/CopyButton.svelte.d.ts +0 -8
  555. package/dist/overlays/DraggablePane.svelte +0 -564
  556. package/dist/overlays/DraggablePane.svelte.d.ts +0 -36
  557. package/dist/overlays/InfoPaneCards.svelte +0 -149
  558. package/dist/overlays/InfoPaneCards.svelte.d.ts +0 -22
  559. package/dist/overlays/index.d.ts +0 -2
  560. package/dist/overlays/index.js +0 -2
  561. package/dist/periodic-table/PeriodicTable.svelte +0 -469
  562. package/dist/periodic-table/PeriodicTable.svelte.d.ts +0 -55
  563. package/dist/periodic-table/PeriodicTableControls.svelte +0 -557
  564. package/dist/periodic-table/PeriodicTableControls.svelte.d.ts +0 -24
  565. package/dist/periodic-table/PropertySelect.svelte +0 -37
  566. package/dist/periodic-table/PropertySelect.svelte.d.ts +0 -13
  567. package/dist/periodic-table/TableInset.svelte.d.ts +0 -9
  568. package/dist/periodic-table/index.d.ts +0 -10
  569. package/dist/periodic-table/index.js +0 -4
  570. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +0 -1084
  571. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +0 -44
  572. package/dist/phase-diagram/PhaseDiagramControls.svelte +0 -449
  573. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +0 -30
  574. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +0 -126
  575. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +0 -15
  576. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +0 -192
  577. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +0 -19
  578. package/dist/phase-diagram/PhaseDiagramTooltip.svelte +0 -392
  579. package/dist/phase-diagram/PhaseDiagramTooltip.svelte.d.ts +0 -16
  580. package/dist/phase-diagram/TdbInfoPanel.svelte +0 -203
  581. package/dist/phase-diagram/TdbInfoPanel.svelte.d.ts +0 -12
  582. package/dist/phase-diagram/build-diagram.d.ts +0 -11
  583. package/dist/phase-diagram/build-diagram.js +0 -167
  584. package/dist/phase-diagram/colors.d.ts +0 -35
  585. package/dist/phase-diagram/colors.js +0 -51
  586. package/dist/phase-diagram/diagram-input.d.ts +0 -33
  587. package/dist/phase-diagram/diagram-input.js +0 -3
  588. package/dist/phase-diagram/index.d.ts +0 -13
  589. package/dist/phase-diagram/index.js +0 -13
  590. package/dist/phase-diagram/parse.d.ts +0 -55
  591. package/dist/phase-diagram/parse.js +0 -276
  592. package/dist/phase-diagram/svg-to-diagram.d.ts +0 -2
  593. package/dist/phase-diagram/svg-to-diagram.js +0 -867
  594. package/dist/phase-diagram/types.d.ts +0 -99
  595. package/dist/phase-diagram/types.js +0 -1
  596. package/dist/phase-diagram/utils.d.ts +0 -118
  597. package/dist/phase-diagram/utils.js +0 -606
  598. package/dist/plot/AxisLabel.svelte +0 -51
  599. package/dist/plot/AxisLabel.svelte.d.ts +0 -16
  600. package/dist/plot/BarPlot.svelte +0 -2265
  601. package/dist/plot/BarPlot.svelte.d.ts +0 -83
  602. package/dist/plot/BarPlotControls.svelte +0 -66
  603. package/dist/plot/BarPlotControls.svelte.d.ts +0 -18
  604. package/dist/plot/ColorBar.svelte +0 -719
  605. package/dist/plot/ColorBar.svelte.d.ts +0 -31
  606. package/dist/plot/ColorScaleSelect.svelte +0 -54
  607. package/dist/plot/ColorScaleSelect.svelte.d.ts +0 -15
  608. package/dist/plot/ElementScatter.svelte +0 -63
  609. package/dist/plot/ElementScatter.svelte.d.ts +0 -14
  610. package/dist/plot/FillArea.svelte +0 -225
  611. package/dist/plot/FillArea.svelte.d.ts +0 -21
  612. package/dist/plot/Histogram.svelte +0 -1672
  613. package/dist/plot/Histogram.svelte.d.ts +0 -50
  614. package/dist/plot/HistogramControls.svelte +0 -212
  615. package/dist/plot/HistogramControls.svelte.d.ts +0 -22
  616. package/dist/plot/InteractiveAxisLabel.svelte +0 -94
  617. package/dist/plot/InteractiveAxisLabel.svelte.d.ts +0 -14
  618. package/dist/plot/Line.svelte +0 -84
  619. package/dist/plot/Line.svelte.d.ts +0 -15
  620. package/dist/plot/PlotControls.svelte +0 -537
  621. package/dist/plot/PlotControls.svelte.d.ts +0 -4
  622. package/dist/plot/PlotLegend.svelte +0 -569
  623. package/dist/plot/PlotLegend.svelte.d.ts +0 -29
  624. package/dist/plot/PlotTooltip.svelte +0 -67
  625. package/dist/plot/PlotTooltip.svelte.d.ts +0 -17
  626. package/dist/plot/PortalSelect.svelte +0 -253
  627. package/dist/plot/PortalSelect.svelte.d.ts +0 -16
  628. package/dist/plot/ReferenceLine.svelte.d.ts +0 -20
  629. package/dist/plot/ReferenceLine3D.svelte +0 -154
  630. package/dist/plot/ReferenceLine3D.svelte.d.ts +0 -14
  631. package/dist/plot/ReferencePlane.svelte +0 -178
  632. package/dist/plot/ReferencePlane.svelte.d.ts +0 -14
  633. package/dist/plot/ScatterPlot.svelte +0 -2845
  634. package/dist/plot/ScatterPlot.svelte.d.ts +0 -93
  635. package/dist/plot/ScatterPlot3D.svelte +0 -502
  636. package/dist/plot/ScatterPlot3D.svelte.d.ts +0 -94
  637. package/dist/plot/ScatterPlot3DControls.svelte +0 -437
  638. package/dist/plot/ScatterPlot3DControls.svelte.d.ts +0 -20
  639. package/dist/plot/ScatterPlot3DScene.svelte +0 -912
  640. package/dist/plot/ScatterPlot3DScene.svelte.d.ts +0 -74
  641. package/dist/plot/ScatterPlotControls.svelte +0 -307
  642. package/dist/plot/ScatterPlotControls.svelte.d.ts +0 -17
  643. package/dist/plot/ScatterPoint.svelte +0 -191
  644. package/dist/plot/ScatterPoint.svelte.d.ts +0 -21
  645. package/dist/plot/SpacegroupBarPlot.svelte +0 -293
  646. package/dist/plot/SpacegroupBarPlot.svelte.d.ts +0 -9
  647. package/dist/plot/Surface3D.svelte +0 -200
  648. package/dist/plot/Surface3D.svelte.d.ts +0 -13
  649. package/dist/plot/ZeroLines.svelte +0 -96
  650. package/dist/plot/ZeroLines.svelte.d.ts +0 -32
  651. package/dist/plot/ZoomRect.svelte +0 -23
  652. package/dist/plot/ZoomRect.svelte.d.ts +0 -8
  653. package/dist/plot/axis-utils.d.ts +0 -19
  654. package/dist/plot/axis-utils.js +0 -80
  655. package/dist/plot/data-cleaning.d.ts +0 -37
  656. package/dist/plot/data-cleaning.js +0 -855
  657. package/dist/plot/data-transform.d.ts +0 -16
  658. package/dist/plot/data-transform.js +0 -45
  659. package/dist/plot/defaults.d.ts +0 -19
  660. package/dist/plot/defaults.js +0 -9
  661. package/dist/plot/fill-utils.d.ts +0 -51
  662. package/dist/plot/fill-utils.js +0 -337
  663. package/dist/plot/hover-lock.svelte.d.ts +0 -14
  664. package/dist/plot/hover-lock.svelte.js +0 -46
  665. package/dist/plot/index.d.ts +0 -37
  666. package/dist/plot/index.js +0 -37
  667. package/dist/plot/interactions.d.ts +0 -12
  668. package/dist/plot/interactions.js +0 -100
  669. package/dist/plot/layout.d.ts +0 -60
  670. package/dist/plot/layout.js +0 -230
  671. package/dist/plot/reference-line.d.ts +0 -60
  672. package/dist/plot/reference-line.js +0 -316
  673. package/dist/plot/scales.d.ts +0 -48
  674. package/dist/plot/scales.js +0 -484
  675. package/dist/plot/svg.d.ts +0 -1
  676. package/dist/plot/svg.js +0 -11
  677. package/dist/plot/types.d.ts +0 -859
  678. package/dist/plot/types.js +0 -103
  679. package/dist/plot/utils/label-placement.d.ts +0 -47
  680. package/dist/plot/utils/label-placement.js +0 -256
  681. package/dist/plot/utils/series-visibility.d.ts +0 -9
  682. package/dist/plot/utils/series-visibility.js +0 -67
  683. package/dist/plot/utils.d.ts +0 -1
  684. package/dist/plot/utils.js +0 -14
  685. package/dist/rdf/RdfPlot.svelte +0 -247
  686. package/dist/rdf/RdfPlot.svelte.d.ts +0 -27
  687. package/dist/rdf/calc-rdf.d.ts +0 -4
  688. package/dist/rdf/calc-rdf.js +0 -111
  689. package/dist/rdf/index.d.ts +0 -23
  690. package/dist/rdf/index.js +0 -2
  691. package/dist/sanitize.d.ts +0 -4
  692. package/dist/sanitize.js +0 -114
  693. package/dist/settings.d.ts +0 -255
  694. package/dist/settings.js +0 -1132
  695. package/dist/spectral/Bands.svelte +0 -1040
  696. package/dist/spectral/Bands.svelte.d.ts +0 -40
  697. package/dist/spectral/BandsAndDos.svelte +0 -128
  698. package/dist/spectral/BandsAndDos.svelte.d.ts +0 -18
  699. package/dist/spectral/BrillouinBandsDos.svelte +0 -248
  700. package/dist/spectral/BrillouinBandsDos.svelte.d.ts +0 -20
  701. package/dist/spectral/Dos.svelte +0 -697
  702. package/dist/spectral/Dos.svelte.d.ts +0 -29
  703. package/dist/spectral/helpers.d.ts +0 -117
  704. package/dist/spectral/helpers.js +0 -1023
  705. package/dist/spectral/index.d.ts +0 -6
  706. package/dist/spectral/index.js +0 -7
  707. package/dist/spectral/types.d.ts +0 -84
  708. package/dist/spectral/types.js +0 -2
  709. package/dist/state.svelte.d.ts +0 -25
  710. package/dist/state.svelte.js +0 -45
  711. package/dist/structure/Arrow.svelte +0 -72
  712. package/dist/structure/Arrow.svelte.d.ts +0 -15
  713. package/dist/structure/AtomLegend.svelte +0 -798
  714. package/dist/structure/AtomLegend.svelte.d.ts +0 -34
  715. package/dist/structure/Bond.svelte +0 -140
  716. package/dist/structure/Bond.svelte.d.ts +0 -9
  717. package/dist/structure/CanvasTooltip.svelte +0 -33
  718. package/dist/structure/CanvasTooltip.svelte.d.ts +0 -12
  719. package/dist/structure/CellSelect.svelte +0 -351
  720. package/dist/structure/CellSelect.svelte.d.ts +0 -13
  721. package/dist/structure/Cylinder.svelte +0 -45
  722. package/dist/structure/Cylinder.svelte.d.ts +0 -10
  723. package/dist/structure/Lattice.svelte +0 -196
  724. package/dist/structure/Lattice.svelte.d.ts +0 -17
  725. package/dist/structure/Structure.svelte +0 -1999
  726. package/dist/structure/Structure.svelte.d.ts +0 -87
  727. package/dist/structure/StructureControls.svelte +0 -1298
  728. package/dist/structure/StructureControls.svelte.d.ts +0 -31
  729. package/dist/structure/StructureExportPane.svelte +0 -251
  730. package/dist/structure/StructureExportPane.svelte.d.ts +0 -17
  731. package/dist/structure/StructureInfoPane.svelte +0 -735
  732. package/dist/structure/StructureInfoPane.svelte.d.ts +0 -19
  733. package/dist/structure/StructureScene.svelte +0 -1905
  734. package/dist/structure/StructureScene.svelte.d.ts +0 -108
  735. package/dist/structure/atom-properties.d.ts +0 -37
  736. package/dist/structure/atom-properties.js +0 -200
  737. package/dist/structure/bond-order-perception.d.ts +0 -13
  738. package/dist/structure/bond-order-perception.js +0 -367
  739. package/dist/structure/bonding.d.ts +0 -42
  740. package/dist/structure/bonding.js +0 -525
  741. package/dist/structure/export.d.ts +0 -20
  742. package/dist/structure/export.js +0 -727
  743. package/dist/structure/index.d.ts +0 -125
  744. package/dist/structure/index.js +0 -171
  745. package/dist/structure/label-placement.d.ts +0 -14
  746. package/dist/structure/label-placement.js +0 -72
  747. package/dist/structure/measure.d.ts +0 -6
  748. package/dist/structure/measure.js +0 -29
  749. package/dist/structure/parse.d.ts +0 -66
  750. package/dist/structure/parse.js +0 -1363
  751. package/dist/structure/partial-occupancy.d.ts +0 -25
  752. package/dist/structure/partial-occupancy.js +0 -99
  753. package/dist/structure/pbc.d.ts +0 -9
  754. package/dist/structure/pbc.js +0 -123
  755. package/dist/structure/supercell.d.ts +0 -8
  756. package/dist/structure/supercell.js +0 -170
  757. package/dist/structure/validation.d.ts +0 -2
  758. package/dist/structure/validation.js +0 -10
  759. package/dist/symmetry/SymmetryStats.svelte +0 -226
  760. package/dist/symmetry/SymmetryStats.svelte.d.ts +0 -21
  761. package/dist/symmetry/WyckoffTable.svelte +0 -113
  762. package/dist/symmetry/WyckoffTable.svelte.d.ts +0 -11
  763. package/dist/symmetry/cell-transform.d.ts +0 -12
  764. package/dist/symmetry/cell-transform.js +0 -91
  765. package/dist/symmetry/index.d.ts +0 -43
  766. package/dist/symmetry/index.js +0 -229
  767. package/dist/symmetry/spacegroups.d.ts +0 -9
  768. package/dist/symmetry/spacegroups.js +0 -394
  769. package/dist/table/HeatmapTable.svelte +0 -1854
  770. package/dist/table/HeatmapTable.svelte.d.ts +0 -49
  771. package/dist/table/ToggleMenu.svelte +0 -376
  772. package/dist/table/ToggleMenu.svelte.d.ts +0 -11
  773. package/dist/table/index.d.ts +0 -74
  774. package/dist/table/index.js +0 -38
  775. package/dist/theme/ThemeControl.svelte +0 -53
  776. package/dist/theme/ThemeControl.svelte.d.ts +0 -9
  777. package/dist/theme/index.d.ts +0 -29
  778. package/dist/theme/index.js +0 -79
  779. package/dist/theme/themes.mjs +0 -285
  780. package/dist/time.d.ts +0 -4
  781. package/dist/time.js +0 -70
  782. package/dist/tooltip/TooltipContent.svelte +0 -58
  783. package/dist/tooltip/TooltipContent.svelte.d.ts +0 -31
  784. package/dist/tooltip/index.d.ts +0 -2
  785. package/dist/tooltip/index.js +0 -2
  786. package/dist/tooltip/types.d.ts +0 -8
  787. package/dist/tooltip/types.js +0 -1
  788. package/dist/trajectory/Trajectory.svelte +0 -1517
  789. package/dist/trajectory/Trajectory.svelte.d.ts +0 -77
  790. package/dist/trajectory/TrajectoryError.svelte +0 -128
  791. package/dist/trajectory/TrajectoryError.svelte.d.ts +0 -13
  792. package/dist/trajectory/TrajectoryExportPane.svelte +0 -357
  793. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +0 -17
  794. package/dist/trajectory/TrajectoryInfoPane.svelte +0 -313
  795. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +0 -17
  796. package/dist/trajectory/constants.d.ts +0 -6
  797. package/dist/trajectory/constants.js +0 -7
  798. package/dist/trajectory/extract.d.ts +0 -5
  799. package/dist/trajectory/extract.js +0 -162
  800. package/dist/trajectory/format-detect.d.ts +0 -9
  801. package/dist/trajectory/format-detect.js +0 -76
  802. package/dist/trajectory/frame-reader.d.ts +0 -17
  803. package/dist/trajectory/frame-reader.js +0 -332
  804. package/dist/trajectory/helpers.d.ts +0 -14
  805. package/dist/trajectory/helpers.js +0 -172
  806. package/dist/trajectory/index.d.ts +0 -63
  807. package/dist/trajectory/index.js +0 -126
  808. package/dist/trajectory/parse/ase.d.ts +0 -2
  809. package/dist/trajectory/parse/ase.js +0 -73
  810. package/dist/trajectory/parse/hdf5.d.ts +0 -2
  811. package/dist/trajectory/parse/hdf5.js +0 -127
  812. package/dist/trajectory/parse/index.d.ts +0 -12
  813. package/dist/trajectory/parse/index.js +0 -299
  814. package/dist/trajectory/parse/lammps.d.ts +0 -5
  815. package/dist/trajectory/parse/lammps.js +0 -179
  816. package/dist/trajectory/parse/vasp.d.ts +0 -2
  817. package/dist/trajectory/parse/vasp.js +0 -68
  818. package/dist/trajectory/parse/xyz.d.ts +0 -2
  819. package/dist/trajectory/parse/xyz.js +0 -110
  820. package/dist/trajectory/plotting.d.ts +0 -28
  821. package/dist/trajectory/plotting.js +0 -423
  822. package/dist/trajectory/types.d.ts +0 -11
  823. package/dist/trajectory/types.js +0 -1
  824. package/dist/utils.d.ts +0 -5
  825. package/dist/utils.js +0 -36
  826. package/dist/xrd/XrdPlot.svelte +0 -615
  827. package/dist/xrd/XrdPlot.svelte.d.ts +0 -28
  828. package/dist/xrd/broadening.d.ts +0 -20
  829. package/dist/xrd/broadening.js +0 -97
  830. package/dist/xrd/calc-xrd.d.ts +0 -37
  831. package/dist/xrd/calc-xrd.js +0 -337
  832. package/dist/xrd/index.d.ts +0 -37
  833. package/dist/xrd/index.js +0 -4
  834. package/dist/xrd/parse.d.ts +0 -13
  835. package/dist/xrd/parse.js +0 -749
  836. /package/dist/{EmptyState.svelte → src/lib/EmptyState.svelte} +0 -0
  837. /package/dist/{Icon.svelte → src/lib/Icon.svelte} +0 -0
  838. /package/dist/{app.css → src/lib/app.css} +0 -0
  839. /package/dist/{chempot-diagram → src/lib/chempot-diagram}/ChemPotScene3D.svelte +0 -0
  840. /package/dist/{colors → src/lib/colors}/alloy-colors.json +0 -0
  841. /package/dist/{colors → src/lib/colors}/dark-mode-colors.json +0 -0
  842. /package/dist/{colors → src/lib/colors}/jmol-colors.json +0 -0
  843. /package/dist/{colors → src/lib/colors}/muted-colors.json +0 -0
  844. /package/dist/{colors → src/lib/colors}/pastel-colors.json +0 -0
  845. /package/dist/{colors → src/lib/colors}/vesta-colors.json +0 -0
  846. /package/dist/{element → src/lib/element}/Nucleus.svelte +0 -0
  847. /package/dist/{element → src/lib/element}/data.json +0 -0
  848. /package/dist/{element → src/lib/element}/data.json.gz +0 -0
  849. /package/dist/{element → src/lib/element}/data.schema.json +0 -0
  850. /package/dist/{element-image-urls.json → src/lib/element-image-urls.json} +0 -0
  851. /package/dist/{feedback → src/lib/feedback}/Spinner.svelte +0 -0
  852. /package/dist/{feedback → src/lib/feedback}/StatusMessage.svelte +0 -0
  853. /package/dist/{periodic-table → src/lib/periodic-table}/TableInset.svelte +0 -0
  854. /package/dist/{plot → src/lib/plot}/ReferenceLine.svelte +0 -0
  855. /package/dist/{xrd → src/lib/xrd}/atomic_scattering_params.json +0 -0
@@ -0,0 +1,1114 @@
1
+ <script module lang="ts">
2
+ let next_clip_id = 0
3
+ </script>
4
+
5
+ <script
6
+ lang="ts"
7
+ generics="Metadata extends Record<string, unknown> = Record<string, unknown>, PointData extends Record<string, unknown> = Record<string, unknown>"
8
+ >
9
+ import Icon from '$lib/Icon.svelte'
10
+ import { format_value } from '$lib/labels'
11
+ import { FullscreenToggle, set_fullscreen_bg } from '$lib/layout'
12
+ import type { Point2D, Vec2 } from '$lib/math'
13
+ import { create_pulse_animation } from '$lib/effects.svelte'
14
+ import ColorBar from '$lib/plot/ColorBar.svelte'
15
+ import PlotAxis from '$lib/plot/PlotAxis.svelte'
16
+ import PlotTooltip from '$lib/plot/PlotTooltip.svelte'
17
+ import ZoomRect from '$lib/plot/ZoomRect.svelte'
18
+ import { compute_element_placement, filter_padding } from '$lib/plot/layout'
19
+ import type { Sides } from '$lib/plot/layout'
20
+ import {
21
+ build_pick_index,
22
+ bin_points,
23
+ density_bin_at_point,
24
+ first_point_in_bin,
25
+ get_metadata_at,
26
+ pick_from_index,
27
+ range_bounds,
28
+ series_extents,
29
+ should_render_points,
30
+ type DensityBin,
31
+ type DenseInternalPoint,
32
+ type DensePointSeries,
33
+ } from '$lib/plot/adaptive-density'
34
+ import { create_color_scale, create_scale, create_size_scale, generate_ticks } from '$lib/plot/scales'
35
+ import type { AxisConfig, DataSeries, InternalPoint, ScatterHandlerProps } from '$lib/plot/types'
36
+ import {
37
+ compute_label_positions,
38
+ estimate_label_size,
39
+ label_leader_segment,
40
+ type LabelSize,
41
+ } from '$lib/plot/utils/label-placement'
42
+ import type { ComponentProps, Snippet } from 'svelte'
43
+ import { onMount, tick } from 'svelte'
44
+ import type { HTMLAttributes } from 'svelte/elements'
45
+ import { SvelteMap, SvelteSet } from 'svelte/reactivity'
46
+ import type {
47
+ BinnedColorScaleConfig,
48
+ BinnedDensityConfig,
49
+ BinnedOverlaysConfig,
50
+ BinnedPointDataFn,
51
+ BinnedPointLabelsConfig,
52
+ BinnedPointPayload,
53
+ BinnedPointTooltipPayload,
54
+ BinnedSizeScaleConfig,
55
+ } from './binned-scatter-types'
56
+
57
+ type RenderMode = `density` | `points`
58
+ type DensePointEvent = {
59
+ point: DenseInternalPoint<Metadata>
60
+ event: MouseEvent
61
+ color?: string
62
+ point_data?: PointData
63
+ }
64
+ type DensityZoomEvent = {
65
+ bin: DensityBin
66
+ event: MouseEvent
67
+ }
68
+ type OverlayContext = { height: number; width: number; fullscreen: boolean }
69
+ const default_color_bar_size = { width: 220, height: 10 }
70
+ const default_density_auto_point_mode = { max_points: 25_000, max_points_per_px: 0.12 }
71
+ const default_density_color_bar: ComponentProps<typeof ColorBar> = { title: `Density` }
72
+ const default_density_color_scale = {
73
+ type: `linear`,
74
+ scheme: `interpolateViridis`,
75
+ } satisfies Exclude<BinnedColorScaleConfig, string>
76
+ const default_pad = { l: 64, r: 24, t: 24, b: 56 }
77
+ const default_point_radius_range: [number, number] = [4, 12]
78
+ const default_pick_radius = default_point_radius_range[1]
79
+ const default_size_scale = {
80
+ type: `linear`,
81
+ radius_range: default_point_radius_range,
82
+ pick_radius: default_pick_radius,
83
+ } satisfies BinnedSizeScaleConfig
84
+ const max_placement_bins = 500
85
+ const default_point_color = `#4dabf7`
86
+
87
+ let {
88
+ series,
89
+ x_axis = {},
90
+ y_axis = {},
91
+ size_scale = default_size_scale,
92
+ density: density_config = {},
93
+ overlays: overlays_config = {},
94
+ padding: padding_config = {},
95
+ tooltip,
96
+ point_data,
97
+ point_labels = {},
98
+ selected_point_id = null,
99
+ on_point_click,
100
+ on_density_zoom,
101
+ render_mode = $bindable<RenderMode>(`density`),
102
+ wrapper = $bindable(),
103
+ fullscreen = $bindable(false),
104
+ fullscreen_toggle = true,
105
+ children,
106
+ header_controls,
107
+ ...rest
108
+ }: Omit<HTMLAttributes<HTMLDivElement>, `children`> & {
109
+ series: DensePointSeries<Metadata>[]
110
+ x_axis?: AxisConfig
111
+ y_axis?: AxisConfig
112
+ size_scale?: BinnedSizeScaleConfig
113
+ density?: BinnedDensityConfig
114
+ overlays?: BinnedOverlaysConfig
115
+ padding?: Sides
116
+ tooltip?: Snippet<[BinnedPointTooltipPayload<Metadata, PointData>]>
117
+ point_data?: BinnedPointDataFn<Metadata, PointData>
118
+ point_labels?: BinnedPointLabelsConfig<Metadata, PointData>
119
+ selected_point_id?: string | number | null
120
+ on_point_click?: (payload: ScatterHandlerProps<Metadata> & DensePointEvent) => void
121
+ on_density_zoom?: (payload: DensityZoomEvent) => void
122
+ render_mode?: RenderMode
123
+ wrapper?: HTMLDivElement
124
+ fullscreen?: boolean
125
+ fullscreen_toggle?: boolean
126
+ children?: Snippet<[OverlayContext]>
127
+ header_controls?: Snippet<[OverlayContext]>
128
+ } = $props()
129
+
130
+ let canvas = $state<HTMLCanvasElement>()
131
+ let width = $state(0)
132
+ let height = $state(0)
133
+ let x_range = $state<Vec2>([0, 1])
134
+ let y_range = $state<Vec2>([0, 1])
135
+ let has_user_range = $state(false)
136
+ let drag_start = $state<Point2D | null>(null)
137
+ let drag_current = $state<Point2D | null>(null)
138
+ let suppress_next_click = false
139
+ let hovered_bin = $state<DensityBin | null>(null)
140
+ let hovered_point = $state<DenseInternalPoint<Metadata> | null>(null)
141
+ let tooltip_pos = $state<Point2D>({ x: 0, y: 0 })
142
+ let colorbar_element = $state<HTMLDivElement>()
143
+ let label_measure_root = $state<HTMLDivElement>()
144
+ let label_sizes = new SvelteMap<string, LabelSize>()
145
+ const clip_path_id = `binned-scatter-plot-area-${next_clip_id++}`
146
+
147
+ let pad = $derived(filter_padding(padding_config, default_pad))
148
+ let density_settings = $derived({
149
+ bin_px: density_config.bin_px ?? 2.8,
150
+ color_scale: density_config.color_scale ?? default_density_color_scale,
151
+ color_bar: density_config.color_bar === undefined ? default_density_color_bar : density_config.color_bar,
152
+ auto_point_mode: density_config.auto_point_mode === undefined
153
+ ? default_density_auto_point_mode
154
+ : density_config.auto_point_mode,
155
+ bin_click: density_config.bin_click ?? `zoom`,
156
+ })
157
+ let ref_lines = $derived(overlays_config.ref_lines ?? [])
158
+ let point_labels_settings = $derived({
159
+ font_size: point_labels.font_size ?? `11px`,
160
+ max_count: point_labels.max_count ?? 50,
161
+ gap_px: point_labels.gap_px ?? 3,
162
+ placement: point_labels.placement ?? {},
163
+ leaders: {
164
+ min_length_px: point_labels.leaders?.min_length_px ?? 6,
165
+ },
166
+ render: point_labels.render,
167
+ measure_text: point_labels.measure_text,
168
+ })
169
+
170
+ $effect(() => {
171
+ set_fullscreen_bg(wrapper, fullscreen, `--binned-scatter-fullscreen-bg`)
172
+ })
173
+
174
+ const selected_pulse = create_pulse_animation(
175
+ () => selected_point_id != null && render_mode === `points`,
176
+ { step: 0.035 },
177
+ )
178
+
179
+ const needs_data_range = (range: AxisConfig[`range`] | undefined): boolean =>
180
+ range?.[0] == null || range?.[1] == null
181
+
182
+ let needs_auto_range = $derived(
183
+ needs_data_range(x_axis.range) || needs_data_range(y_axis.range),
184
+ )
185
+ let auto_ranges = $derived(
186
+ needs_auto_range ? series_extents(series) : { x: [0, 1] as Vec2, y: [0, 1] as Vec2 },
187
+ )
188
+ let x_scale_type = $derived(x_axis.scale_type ?? `linear`)
189
+ let y_scale_type = $derived(y_axis.scale_type ?? `linear`)
190
+ let has_plot_size = $derived(width > 0 && height > 0)
191
+
192
+ const axis_range = (axis: AxisConfig, fallback: Vec2): Vec2 => [
193
+ axis.range?.[0] ?? fallback[0],
194
+ axis.range?.[1] ?? fallback[1],
195
+ ]
196
+ const same_range = (a: Vec2, b: Vec2): boolean => a[0] === b[0] && a[1] === b[1]
197
+
198
+ function set_auto_range() {
199
+ const next_x_range = axis_range(x_axis, auto_ranges.x)
200
+ const next_y_range = axis_range(y_axis, auto_ranges.y)
201
+ if (!same_range(x_range, next_x_range)) x_range = next_x_range
202
+ if (!same_range(y_range, next_y_range)) y_range = next_y_range
203
+ }
204
+
205
+ $effect(() => {
206
+ if (has_user_range) return
207
+ set_auto_range()
208
+ })
209
+
210
+ let plot_width = $derived(Math.max(1, width - pad.l - pad.r))
211
+ let plot_height = $derived(Math.max(1, height - pad.t - pad.b))
212
+ let plot_rect = $derived({
213
+ x: pad.l,
214
+ y: pad.t,
215
+ width: plot_width,
216
+ height: plot_height,
217
+ })
218
+ let x_scale_fn = $derived(create_scale(x_scale_type, x_range, [
219
+ pad.l,
220
+ width - pad.r,
221
+ ]))
222
+ let y_scale_fn = $derived(create_scale(y_scale_type, y_range, [
223
+ height - pad.b,
224
+ pad.t,
225
+ ]))
226
+ let x_ticks = $derived(
227
+ generate_ticks(x_range, x_scale_type, x_axis.ticks, x_scale_fn, {
228
+ default_count: 7,
229
+ }),
230
+ )
231
+ let y_ticks = $derived(
232
+ generate_ticks(y_range, y_scale_type, y_axis.ticks, y_scale_fn, {
233
+ default_count: 6,
234
+ }),
235
+ )
236
+ let density_bins = $derived({
237
+ x: Math.max(8, Math.ceil(plot_width / density_settings.bin_px)),
238
+ y: Math.max(8, Math.ceil(plot_height / density_settings.bin_px)),
239
+ })
240
+ let density_result = $derived(
241
+ bin_points(has_plot_size ? series : [], x_range, y_range, density_bins.x, density_bins.y),
242
+ )
243
+ let auto_color_range = $derived<Vec2>([1, Math.max(1, density_result.max_count)])
244
+ let color_scale_fn = $derived(create_color_scale(density_settings.color_scale, auto_color_range))
245
+ let hovered_bin_color = $derived(hovered_bin ? color_scale_fn(hovered_bin.count) : undefined)
246
+ let color_scale_type = $derived(
247
+ typeof density_settings.color_scale === `string` ? undefined : density_settings.color_scale.type,
248
+ )
249
+ let color_bar_props = $derived.by((): ComponentProps<typeof ColorBar> | null => {
250
+ const color_bar = density_settings.color_bar
251
+ if (!color_bar) return null
252
+ return {
253
+ ...color_bar,
254
+ scale_type: color_bar.scale_type ?? color_scale_type,
255
+ title: `${color_bar.title ?? `Density`} (${density_result.visible_count.toLocaleString()} points)`,
256
+ tick_format: color_bar.tick_format ?? `.2~s`,
257
+ tick_labels: color_bar.tick_labels ?? 4,
258
+ tick_side: color_bar.tick_side ?? `primary`,
259
+ bar_style: color_bar.bar_style ??
260
+ `width: ${default_color_bar_size.width}px; height: ${default_color_bar_size.height}px; ${color_bar.style ?? ``}`,
261
+ }
262
+ })
263
+ let density_placement_points = $derived.by(() => {
264
+ const points: Point2D[] = []
265
+ const bin_w = plot_width / density_result.x_bins
266
+ const bin_h = plot_height / density_result.y_bins
267
+ let occupied_count = 0
268
+ for (let idx = 0; idx < density_result.counts.length; idx++) {
269
+ if (density_result.counts[idx]) occupied_count++
270
+ }
271
+ const stride = Math.max(1, Math.ceil(occupied_count / max_placement_bins))
272
+ let occupied_idx = 0
273
+ for (let idx = 0; idx < density_result.counts.length; idx++) {
274
+ if (!density_result.counts[idx]) continue
275
+ if (occupied_idx++ % stride) continue
276
+ const x_bin = idx % density_result.x_bins
277
+ const y_bin = Math.floor(idx / density_result.x_bins)
278
+ points.push({
279
+ x: pad.l + (x_bin + 0.5) * bin_w,
280
+ y: pad.t + (density_result.y_bins - y_bin - 0.5) * bin_h,
281
+ })
282
+ }
283
+ return points
284
+ })
285
+ let color_bar_placement = $derived.by(() => {
286
+ if (
287
+ !color_bar_props ||
288
+ render_mode !== `density` ||
289
+ density_result.max_count <= 0 ||
290
+ !width ||
291
+ !height
292
+ ) {
293
+ return null
294
+ }
295
+
296
+ const is_vertical = color_bar_props?.orientation === `vertical`
297
+ // Fallback sizes (incl. room for tick labels) used before the colorbar first
298
+ // renders; compute_element_placement measures the real footprint once laid out
299
+ const fallback_size = is_vertical
300
+ ? { width: 56, height: 120 }
301
+ : { width: default_color_bar_size.width, height: 50 }
302
+
303
+ return compute_element_placement({
304
+ plot_bounds: plot_rect,
305
+ element: colorbar_element,
306
+ element_size: fallback_size,
307
+ // Small gap from the corner; the full-footprint measurement reserves the tick
308
+ // labels, so this alone keeps the colorbar off the axes
309
+ axis_clearance: 12,
310
+ points: density_placement_points,
311
+ grid_resolution: 12,
312
+ })
313
+ })
314
+
315
+ let auto_render_mode = $derived.by((): RenderMode => {
316
+ const auto_point_mode = density_settings.auto_point_mode
317
+ if (auto_point_mode === false) return render_mode
318
+ return should_render_points(
319
+ density_result.visible_count,
320
+ plot_width * plot_height,
321
+ auto_point_mode.max_points ?? default_density_auto_point_mode.max_points,
322
+ auto_point_mode.max_points_per_px ?? default_density_auto_point_mode.max_points_per_px,
323
+ )
324
+ ? `points`
325
+ : `density`
326
+ })
327
+ let all_size_values = $derived.by(() => {
328
+ const values: number[] = []
329
+ for (const srs of series) {
330
+ if (!srs.size_values) continue
331
+ for (let idx = 0; idx < srs.size_values.length; idx++) {
332
+ const size_value = srs.size_values[idx]
333
+ if (size_value == null || !Number.isFinite(size_value)) continue
334
+ values.push(size_value)
335
+ }
336
+ }
337
+ return values
338
+ })
339
+ let size_scale_fn = $derived(create_size_scale(size_scale, all_size_values))
340
+ let min_point_radius = $derived(size_scale.radius_range?.[0] ?? default_point_radius_range[0])
341
+ let max_point_radius = $derived(size_scale.radius_range?.[1] ?? default_point_radius_range[1])
342
+ let pick_radius_px = $derived(
343
+ size_scale.pick_radius === `auto`
344
+ ? max_point_radius
345
+ : size_scale.pick_radius ?? default_pick_radius,
346
+ )
347
+
348
+ $effect(() => {
349
+ if (!has_plot_size) return
350
+ if (density_settings.auto_point_mode !== false) render_mode = auto_render_mode
351
+ })
352
+ let pick_index = $derived(
353
+ render_mode === `points`
354
+ ? build_pick_index(series, {
355
+ x_range,
356
+ y_range,
357
+ x_scale: x_scale_fn,
358
+ y_scale: y_scale_fn,
359
+ radius_px: pick_radius_px,
360
+ })
361
+ : null,
362
+ )
363
+ let actual_label_placement_config = $derived({
364
+ sa_iterations: 2000,
365
+ max_labels: 300,
366
+ leader_line_threshold: 15,
367
+ candidate_gap: 0,
368
+ ...point_labels_settings.placement,
369
+ })
370
+
371
+ const reset_view = () => {
372
+ has_user_range = false
373
+ set_auto_range()
374
+ }
375
+
376
+ function point_radius_for_value(size_value: number | null | undefined): number {
377
+ if (size_value == null || !Number.isFinite(size_value)) {
378
+ return min_point_radius
379
+ }
380
+ return size_scale_fn(size_value)
381
+ }
382
+
383
+ function resize_canvas() {
384
+ if (!canvas) return
385
+ const dpr = globalThis.devicePixelRatio || 1
386
+ canvas.width = Math.max(1, Math.round(width * dpr))
387
+ canvas.height = Math.max(1, Math.round(height * dpr))
388
+ canvas.style.width = `${width}px`
389
+ canvas.style.height = `${height}px`
390
+ }
391
+
392
+ function draw_density(ctx: CanvasRenderingContext2D) {
393
+ const bin_w = plot_width / density_result.x_bins
394
+ const bin_h = plot_height / density_result.y_bins
395
+ const style_cache = new Map<number, { fill: string; alpha: number }>()
396
+ for (let y_bin = 0; y_bin < density_result.y_bins; y_bin++) {
397
+ for (let x_bin = 0; x_bin < density_result.x_bins; x_bin++) {
398
+ const count = density_result.counts[y_bin * density_result.x_bins + x_bin]
399
+ if (!count) continue
400
+ let style = style_cache.get(count)
401
+ if (!style) {
402
+ style = {
403
+ fill: color_scale_fn(count),
404
+ alpha: Math.min(0.95, 0.2 + Math.log1p(count) / Math.log1p(density_result.max_count)),
405
+ }
406
+ style_cache.set(count, style)
407
+ }
408
+ ctx.fillStyle = style.fill
409
+ ctx.globalAlpha = style.alpha
410
+ ctx.fillRect(
411
+ pad.l + x_bin * bin_w,
412
+ pad.t + (density_result.y_bins - y_bin - 1) * bin_h,
413
+ Math.ceil(bin_w) + 0.5,
414
+ Math.ceil(bin_h) + 0.5,
415
+ )
416
+ }
417
+ }
418
+ ctx.globalAlpha = 1
419
+ }
420
+
421
+ function draw_points(ctx: CanvasRenderingContext2D) {
422
+ const [x_min, x_max] = range_bounds(x_range)
423
+ const [y_min, y_max] = range_bounds(y_range)
424
+ const pulse = selected_pulse.unit
425
+ for (const [series_idx, srs] of series.entries()) {
426
+ ctx.fillStyle = srs.color ?? default_point_color
427
+ const n_points = Math.min(srs.x.length, srs.y.length)
428
+ for (let point_idx = 0; point_idx < n_points; point_idx++) {
429
+ const x = srs.x[point_idx]
430
+ const y = srs.y[point_idx]
431
+ if (!Number.isFinite(x) || !Number.isFinite(y)) continue
432
+ if (x < x_min || x > x_max || y < y_min || y > y_max) continue
433
+ const cx = x_scale_fn(x)
434
+ const cy = y_scale_fn(y)
435
+ const point_id = srs.point_ids?.[point_idx]
436
+ const is_selected = selected_point_id != null && point_id === selected_point_id
437
+ const radius = point_radius_for_value(srs.size_values?.[point_idx])
438
+ const is_hovered =
439
+ hovered_point?.series_idx === series_idx && hovered_point?.point_idx === point_idx
440
+ ctx.globalAlpha = is_selected || is_hovered ? 1 : 0.65
441
+ ctx.beginPath()
442
+ ctx.arc(cx, cy, radius * (is_selected ? 1.08 + 0.08 * pulse : 1), 0, 2 * Math.PI)
443
+ ctx.fill()
444
+ if (is_selected) {
445
+ ctx.globalAlpha = 0.35 + 0.25 * pulse
446
+ ctx.strokeStyle = srs.color ?? default_point_color
447
+ ctx.lineWidth = 1.5 + pulse
448
+ ctx.beginPath()
449
+ ctx.arc(cx, cy, radius * (1.45 + 0.25 * pulse), 0, 2 * Math.PI)
450
+ ctx.stroke()
451
+ }
452
+ }
453
+ }
454
+ ctx.globalAlpha = 1
455
+ }
456
+
457
+ $effect(() => {
458
+ if (!canvas || width <= 0 || height <= 0) return
459
+ resize_canvas()
460
+ const ctx = canvas.getContext(`2d`)
461
+ if (!ctx) return
462
+ const dpr = globalThis.devicePixelRatio || 1
463
+ ctx.setTransform(dpr, 0, 0, dpr, 0, 0)
464
+ ctx.clearRect(0, 0, width, height)
465
+ ctx.save()
466
+ ctx.beginPath()
467
+ ctx.rect(pad.l, pad.t, plot_width, plot_height)
468
+ ctx.clip()
469
+ if (render_mode === `points`) draw_points(ctx)
470
+ else draw_density(ctx)
471
+ ctx.restore()
472
+ })
473
+
474
+ function pointer_coords(event: PointerEvent | MouseEvent): Point2D | null {
475
+ if (!wrapper) return null
476
+ const rect = wrapper.getBoundingClientRect()
477
+ return { x: event.clientX - rect.left, y: event.clientY - rect.top }
478
+ }
479
+
480
+ function pick_at(coords: Point2D | null): DenseInternalPoint<Metadata> | null {
481
+ if (!coords || !pick_index) return null
482
+ return pick_from_index(pick_index, coords)
483
+ }
484
+
485
+ function clear_hover() {
486
+ hovered_bin = null
487
+ hovered_point = null
488
+ }
489
+
490
+ function handler_props(
491
+ point: DenseInternalPoint<Metadata>,
492
+ ): ScatterHandlerProps<Metadata> {
493
+ return {
494
+ x: point.x,
495
+ y: point.y,
496
+ cx: point.cx,
497
+ cy: point.cy,
498
+ metadata: point.metadata,
499
+ label: series[point.series_idx]?.label ?? null,
500
+ series_idx: point.series_idx,
501
+ x_axis,
502
+ y_axis,
503
+ x_formatted: format_value(point.x, x_axis.format ?? `.3~g`),
504
+ y_formatted: format_value(point.y, y_axis.format ?? `.3~g`),
505
+ }
506
+ }
507
+
508
+ function point_color(point: DenseInternalPoint<Metadata>): string {
509
+ return series[point.series_idx]?.color ?? default_point_color
510
+ }
511
+
512
+ function point_label_key(point: DenseInternalPoint<Metadata>): string {
513
+ return `${point.series_idx}-${point.point_idx}`
514
+ }
515
+
516
+ function make_point(series_idx: number, point_idx: number): DenseInternalPoint<Metadata> {
517
+ const srs = series[series_idx]
518
+ const x = srs.x[point_idx]
519
+ const y = srs.y[point_idx]
520
+ return {
521
+ x,
522
+ y,
523
+ cx: x_scale_fn(x),
524
+ cy: y_scale_fn(y),
525
+ series_idx,
526
+ point_idx,
527
+ metadata: get_metadata_at(srs.metadata, point_idx),
528
+ point_id: srs.point_ids?.[point_idx],
529
+ size_value: srs.size_values?.[point_idx],
530
+ }
531
+ }
532
+
533
+ function fallback_label_text(point: DenseInternalPoint<Metadata>): string {
534
+ return String(point.point_id ?? point_label_key(point))
535
+ }
536
+
537
+ function point_payload(
538
+ point: DenseInternalPoint<Metadata>,
539
+ color = point_color(point),
540
+ ): BinnedPointPayload<Metadata, PointData> {
541
+ const base_payload = { ...handler_props(point), point, color }
542
+ return { ...base_payload, point_data: point_data?.(base_payload) ?? undefined }
543
+ }
544
+
545
+ function label_measure_text(payload: BinnedPointPayload<Metadata, PointData>): string {
546
+ return point_labels_settings.measure_text?.(payload) ?? fallback_label_text(payload.point)
547
+ }
548
+
549
+ function label_size_for_payload(
550
+ payload: BinnedPointPayload<Metadata, PointData>,
551
+ ): LabelSize {
552
+ return label_sizes.get(point_label_key(payload.point)) ??
553
+ estimate_label_size(label_measure_text(payload), point_labels_settings.font_size)
554
+ }
555
+
556
+ let point_label_payloads = $derived.by(() => {
557
+ if (!point_labels_settings.render || render_mode !== `points`) return []
558
+
559
+ const [x_min, x_max] = range_bounds(x_range)
560
+ const [y_min, y_max] = range_bounds(y_range)
561
+ const payloads: BinnedPointPayload<Metadata, PointData>[] = []
562
+ for (let series_idx = 0; series_idx < series.length; series_idx++) {
563
+ const srs = series[series_idx]
564
+ const n_points = Math.min(srs.x.length, srs.y.length)
565
+ for (let point_idx = 0; point_idx < n_points; point_idx++) {
566
+ const x = srs.x[point_idx]
567
+ const y = srs.y[point_idx]
568
+ if (
569
+ !Number.isFinite(x) ||
570
+ !Number.isFinite(y) ||
571
+ x < x_min ||
572
+ x > x_max ||
573
+ y < y_min ||
574
+ y > y_max
575
+ ) continue
576
+ payloads.push(point_payload(make_point(series_idx, point_idx)))
577
+ if (payloads.length > point_labels_settings.max_count) return []
578
+ }
579
+ }
580
+ return payloads
581
+ })
582
+
583
+ let point_label_positions = $derived.by(() => {
584
+ if (!point_label_payloads.length) return {}
585
+
586
+ const filtered_data: InternalPoint<Metadata>[] = point_label_payloads.map(
587
+ (payload) => ({
588
+ ...payload.point,
589
+ point_label: {
590
+ text: label_measure_text(payload),
591
+ auto_placement: true,
592
+ font_size: point_labels_settings.font_size,
593
+ size: label_sizes.get(point_label_key(payload.point)),
594
+ },
595
+ point_style: {
596
+ radius: point_radius_for_value(payload.point.size_value) + point_labels_settings.gap_px,
597
+ },
598
+ }),
599
+ )
600
+ const label_series: DataSeries<Metadata>[] = [{ x: [], y: [], filtered_data }]
601
+
602
+ return compute_label_positions(
603
+ label_series,
604
+ actual_label_placement_config,
605
+ { x_scale_fn, y_scale_fn, y2_scale_fn: y_scale_fn, x_axis },
606
+ { width, height, pad },
607
+ )
608
+ })
609
+
610
+ async function measure_point_labels() {
611
+ await tick()
612
+ if (!label_measure_root) return
613
+
614
+ const active_keys = new SvelteSet<string>()
615
+ const measured_elements = label_measure_root.querySelectorAll<HTMLElement>(`[data-label-key]`)
616
+ for (const element of measured_elements) {
617
+ const label_key = element.dataset.labelKey
618
+ if (!label_key) continue
619
+ const { width: label_width, height: label_height } = element.getBoundingClientRect()
620
+ if (label_width <= 0 || label_height <= 0) continue
621
+ active_keys.add(label_key)
622
+ const current_size = label_sizes.get(label_key)
623
+ if (current_size?.width === label_width && current_size.height === label_height) continue
624
+ label_sizes.set(label_key, { width: label_width, height: label_height })
625
+ }
626
+
627
+ for (const label_key of label_sizes.keys()) {
628
+ if (!active_keys.has(label_key)) label_sizes.delete(label_key)
629
+ }
630
+ }
631
+
632
+ $effect(() => {
633
+ if (!label_measure_root || !point_label_payloads.length) return
634
+ void measure_point_labels()
635
+ })
636
+
637
+ function label_leader_line(
638
+ payload: BinnedPointPayload<Metadata, PointData>,
639
+ label_position: Point2D,
640
+ ): { x1: number; y1: number; x2: number; y2: number } | null {
641
+ const displacement = Math.hypot(label_position.x - payload.cx, label_position.y - payload.cy)
642
+ if (displacement <= (actual_label_placement_config.leader_line_threshold ?? 15)) {
643
+ return null
644
+ }
645
+ return label_leader_segment({
646
+ point: { x: payload.cx, y: payload.cy },
647
+ point_radius: point_radius_for_value(payload.point.size_value),
648
+ label_center: label_position,
649
+ label_size: label_size_for_payload(payload),
650
+ min_length: point_labels_settings.leaders.min_length_px,
651
+ })
652
+ }
653
+
654
+ function point_tooltip_props(
655
+ point: DenseInternalPoint<Metadata>,
656
+ ): BinnedPointTooltipPayload<Metadata, PointData> {
657
+ return point_payload(point)
658
+ }
659
+
660
+ function on_pointer_move(event: PointerEvent) {
661
+ const coords = pointer_coords(event)
662
+ if (coords) tooltip_pos = { x: coords.x + 12, y: coords.y + 8 }
663
+
664
+ if (!coords) {
665
+ clear_hover()
666
+ return
667
+ }
668
+
669
+ if (render_mode === `density`) {
670
+ hovered_point = null
671
+ const bin = density_bin_at_point(density_result, coords, plot_rect, x_range, y_range)
672
+ if (
673
+ hovered_bin?.x_bin !== bin?.x_bin ||
674
+ hovered_bin?.y_bin !== bin?.y_bin ||
675
+ hovered_bin?.count !== bin?.count
676
+ ) hovered_bin = bin
677
+ return
678
+ }
679
+
680
+ hovered_bin = null
681
+ const point = pick_at(coords)
682
+ if (
683
+ hovered_point?.series_idx !== point?.series_idx ||
684
+ hovered_point?.point_idx !== point?.point_idx
685
+ ) hovered_point = point
686
+ }
687
+
688
+ function emit_point_click(
689
+ point: DenseInternalPoint<Metadata>,
690
+ event: MouseEvent,
691
+ color = series[point.series_idx]?.color,
692
+ ) {
693
+ on_point_click?.({
694
+ ...point_payload(point, color),
695
+ event,
696
+ })
697
+ }
698
+
699
+ function zoom_to_bin(bin: DensityBin, event: MouseEvent) {
700
+ x_range = bin.x_range
701
+ y_range = bin.y_range
702
+ has_user_range = true
703
+ hovered_bin = null
704
+ on_density_zoom?.({ bin, event })
705
+ }
706
+
707
+ function on_click(event: MouseEvent) {
708
+ if (suppress_next_click) {
709
+ suppress_next_click = false
710
+ return
711
+ }
712
+
713
+ const coords = pointer_coords(event)
714
+ if (!coords) return
715
+
716
+ if (render_mode === `density`) {
717
+ const bin = density_bin_at_point(density_result, coords, plot_rect, x_range, y_range)
718
+ if (!bin) return
719
+ if (density_settings.bin_click === `none`) return
720
+ if (bin.count > 1 && density_settings.bin_click === `zoom`) {
721
+ zoom_to_bin(bin, event)
722
+ return
723
+ }
724
+ if (bin.count > 1 && density_settings.bin_click !== `point`) return
725
+
726
+ const point = first_point_in_bin(
727
+ series,
728
+ density_result,
729
+ bin,
730
+ x_scale_fn,
731
+ y_scale_fn,
732
+ )
733
+ if (point) emit_point_click(point, event, color_scale_fn(bin.count))
734
+ return
735
+ }
736
+
737
+ const point = pick_at(coords)
738
+ if (!point) return
739
+ emit_point_click(point, event)
740
+ }
741
+
742
+ function on_pointer_down(event: PointerEvent) {
743
+ if (event.button !== 0) return
744
+ const coords = pointer_coords(event)
745
+ if (!coords) return
746
+ drag_start = coords
747
+ drag_current = coords
748
+ if (event.currentTarget instanceof HTMLElement) {
749
+ event.currentTarget.setPointerCapture?.(event.pointerId)
750
+ }
751
+ }
752
+
753
+ function on_pointer_drag(event: PointerEvent) {
754
+ if (!drag_start) {
755
+ on_pointer_move(event)
756
+ return
757
+ }
758
+ const coords = pointer_coords(event)
759
+ if (coords) drag_current = coords
760
+ }
761
+
762
+ function on_pointer_up(event: PointerEvent) {
763
+ const start = drag_start
764
+ const end = drag_current
765
+ drag_start = null
766
+ drag_current = null
767
+
768
+ if (start && end && Math.abs(end.x - start.x) > 5 && Math.abs(end.y - start.y) > 5) {
769
+ const x0 = x_scale_fn.invert(start.x)
770
+ const x1 = x_scale_fn.invert(end.x)
771
+ const y0 = y_scale_fn.invert(start.y)
772
+ const y1 = y_scale_fn.invert(end.y)
773
+ x_range = [Math.min(x0, x1), Math.max(x0, x1)]
774
+ y_range = [Math.min(y0, y1), Math.max(y0, y1)]
775
+ has_user_range = true
776
+ suppress_next_click = true
777
+ }
778
+
779
+ if (event.currentTarget instanceof HTMLElement) {
780
+ event.currentTarget.releasePointerCapture?.(event.pointerId)
781
+ }
782
+ }
783
+
784
+ onMount(() => {
785
+ if (!wrapper) return
786
+ const observer = new ResizeObserver(([entry]) => {
787
+ width = Math.round(entry.contentRect.width)
788
+ height = Math.round(entry.contentRect.height)
789
+ })
790
+ observer.observe(wrapper)
791
+ return () => observer.disconnect()
792
+ })
793
+ </script>
794
+
795
+ <svelte:window
796
+ onkeydown={(event) => {
797
+ if (event.key === `Escape` && fullscreen) {
798
+ event.preventDefault()
799
+ fullscreen = false
800
+ }
801
+ }}
802
+ />
803
+
804
+ <div
805
+ {...rest}
806
+ bind:this={wrapper}
807
+ class="binned-scatter {rest.class ?? ``}"
808
+ class:fullscreen
809
+ data-render-mode={render_mode}
810
+ style:--binned-scatter-label-font-size={point_labels_settings.font_size}
811
+ onpointermove={on_pointer_drag}
812
+ onpointerdown={on_pointer_down}
813
+ onpointerup={on_pointer_up}
814
+ onmouseleave={clear_hover}
815
+ onclick={on_click}
816
+ ondblclick={reset_view}
817
+ >
818
+ {#if width && height}
819
+ <!-- svelte-ignore a11y_click_events_have_key_events -->
820
+ <!-- svelte-ignore a11y_no_static_element_interactions -->
821
+ <div
822
+ class="header-controls"
823
+ onpointerdown={(event) => event.stopPropagation()}
824
+ onclick={(event) => event.stopPropagation()}
825
+ ondblclick={(event) => event.stopPropagation()}
826
+ >
827
+ {@render header_controls?.({ height, width, fullscreen })}
828
+ {#if has_user_range}
829
+ <button
830
+ type="button"
831
+ class="reset-view"
832
+ aria-label="Reset view"
833
+ title="Reset view"
834
+ onclick={reset_view}
835
+ >
836
+ <Icon icon="Reset" width="18" height="18" />
837
+ </button>
838
+ {/if}
839
+ {#if fullscreen_toggle}
840
+ <FullscreenToggle bind:fullscreen />
841
+ {/if}
842
+ </div>
843
+ {/if}
844
+
845
+ <canvas bind:this={canvas}></canvas>
846
+
847
+ <svg width={width} height={height} aria-hidden="true">
848
+ <defs>
849
+ <clipPath id={clip_path_id}>
850
+ <rect x={pad.l} y={pad.t} width={plot_width} height={plot_height} />
851
+ </clipPath>
852
+ </defs>
853
+
854
+ <g class="reference-lines" clip-path="url(#{clip_path_id})">
855
+ {#each ref_lines as line}
856
+ <line
857
+ x1={x_scale_fn(line.x1)}
858
+ x2={x_scale_fn(line.x2)}
859
+ y1={y_scale_fn(line.y1)}
860
+ y2={y_scale_fn(line.y2)}
861
+ stroke={line.color ?? `currentColor`}
862
+ stroke-width={line.width ?? 1.5}
863
+ stroke-dasharray={line.dash ?? `5 4`}
864
+ />
865
+ {/each}
866
+ </g>
867
+ <PlotAxis
868
+ side="x"
869
+ ticks={x_ticks}
870
+ place={(tick) => x_scale_fn(tick)}
871
+ axis={x_axis}
872
+ {pad}
873
+ {width}
874
+ {height}
875
+ show_grid
876
+ tick_label={(tick) => format_value(tick, x_axis.format ?? `.2~g`)}
877
+ label_x={pad.l + plot_width / 2}
878
+ label_y={height - 12}
879
+ />
880
+ <PlotAxis
881
+ side="y"
882
+ ticks={y_ticks}
883
+ place={(tick) => y_scale_fn(tick)}
884
+ axis={y_axis}
885
+ {pad}
886
+ {width}
887
+ {height}
888
+ show_grid
889
+ tick_label={(tick) => format_value(tick, y_axis.format ?? `.2~g`)}
890
+ label_x={22}
891
+ label_y={pad.t + plot_height / 2}
892
+ />
893
+
894
+ <ZoomRect start={drag_start} current={drag_current} />
895
+
896
+ {#if point_label_payloads.length}
897
+ <g class="point-label-leaders" clip-path="url(#{clip_path_id})">
898
+ {#each point_label_payloads as payload (point_label_key(payload.point))}
899
+ {@const label_position = point_label_positions[point_label_key(payload.point)]}
900
+ {@const leader_line = label_position ? label_leader_line(payload, label_position) : null}
901
+ {#if leader_line}
902
+ <line
903
+ x1={leader_line.x1}
904
+ y1={leader_line.y1}
905
+ x2={leader_line.x2}
906
+ y2={leader_line.y2}
907
+ />
908
+ {/if}
909
+ {/each}
910
+ </g>
911
+ {/if}
912
+ </svg>
913
+
914
+ {#if point_labels_settings.render && point_label_payloads.length}
915
+ <div bind:this={label_measure_root} class="point-label-measurements" aria-hidden="true">
916
+ {#each point_label_payloads as payload (point_label_key(payload.point))}
917
+ <div
918
+ class="point-label point-label-measure"
919
+ data-label-key={point_label_key(payload.point)}
920
+ >
921
+ {@render point_labels_settings.render(payload)}
922
+ </div>
923
+ {/each}
924
+ </div>
925
+ {/if}
926
+
927
+ {#if point_labels_settings.render && point_label_payloads.length}
928
+ <div class="point-labels">
929
+ {#each point_label_payloads as payload (point_label_key(payload.point))}
930
+ {@const label_position = point_label_positions[point_label_key(payload.point)]}
931
+ {#if label_position}
932
+ <div
933
+ class="point-label"
934
+ style:left={`${label_position.x}px`}
935
+ style:top={`${label_position.y}px`}
936
+ >
937
+ {@render point_labels_settings.render(payload)}
938
+ </div>
939
+ {/if}
940
+ {/each}
941
+ </div>
942
+ {/if}
943
+
944
+ {#if color_bar_props && render_mode === `density` && density_result.max_count > 0 && color_bar_placement}
945
+ <div
946
+ bind:this={colorbar_element}
947
+ class="color-bar"
948
+ style:left={`${color_bar_placement.x}px`}
949
+ style:top={`${color_bar_placement.y}px`}
950
+ >
951
+ <ColorBar
952
+ {...color_bar_props}
953
+ color_scale_fn={color_scale_fn}
954
+ color_scale_domain={auto_color_range}
955
+ range={auto_color_range}
956
+ />
957
+ </div>
958
+ {/if}
959
+
960
+ {#if hovered_bin}
961
+ <PlotTooltip
962
+ x={tooltip_pos.x}
963
+ y={tooltip_pos.y}
964
+ offset={{ x: 0, y: 0 }}
965
+ bg_color={hovered_bin_color}
966
+ >
967
+ {hovered_bin.count.toLocaleString()} samples<br>
968
+ x: {format_value(hovered_bin.x_range[0], x_axis.format ?? `.3~g`)}
969
+ - {format_value(hovered_bin.x_range[1], x_axis.format ?? `.3~g`)}<br>
970
+ y: {format_value(hovered_bin.y_range[0], y_axis.format ?? `.3~g`)}
971
+ - {format_value(hovered_bin.y_range[1], y_axis.format ?? `.3~g`)}
972
+ </PlotTooltip>
973
+ {:else if hovered_point}
974
+ {@const props = point_tooltip_props(hovered_point)}
975
+ <PlotTooltip x={tooltip_pos.x} y={tooltip_pos.y} offset={{ x: 0, y: 0 }}>
976
+ {#if tooltip}
977
+ {@render tooltip(props)}
978
+ {:else}
979
+ {x_axis.label ?? `x`}: {props.x_formatted}<br>
980
+ {y_axis.label ?? `y`}: {props.y_formatted}
981
+ {/if}
982
+ </PlotTooltip>
983
+ {/if}
984
+
985
+ {@render children?.({ height, width, fullscreen })}
986
+ </div>
987
+
988
+ <style>
989
+ .binned-scatter {
990
+ position: relative;
991
+ min-height: 300px;
992
+ color: var(--text-color, CanvasText);
993
+ touch-action: none;
994
+ user-select: none;
995
+ }
996
+ .binned-scatter :global(.axis-label) {
997
+ color: currentColor;
998
+ font-size: 13px;
999
+ font-weight: 600;
1000
+ height: 100%;
1001
+ line-height: 24px;
1002
+ text-align: center;
1003
+ white-space: nowrap;
1004
+ width: 100%;
1005
+ }
1006
+ .binned-scatter.fullscreen {
1007
+ background: var(
1008
+ --binned-scatter-fullscreen-bg,
1009
+ var(--binned-scatter-bg, var(--plot-bg, Canvas))
1010
+ );
1011
+ border-radius: 0;
1012
+ box-sizing: border-box;
1013
+ height: 100vh !important;
1014
+ left: 0;
1015
+ margin: 0;
1016
+ max-height: none !important;
1017
+ overflow: hidden;
1018
+ padding-top: var(--plot-fullscreen-padding-top, 2em);
1019
+ position: fixed;
1020
+ top: 0;
1021
+ width: 100vw !important;
1022
+ z-index: var(--scatter-fullscreen-z-index, var(--z-index-overlay-nav, 100000001));
1023
+ }
1024
+ .header-controls {
1025
+ align-items: center;
1026
+ display: flex;
1027
+ gap: 8px;
1028
+ opacity: 0;
1029
+ position: absolute;
1030
+ right: var(--fullscreen-btn-right, 4px);
1031
+ top: var(--ctrl-btn-top, 5pt);
1032
+ transition: opacity 0.2s, background-color 0.2s;
1033
+ z-index: var(--fullscreen-btn-z-index, 10);
1034
+ }
1035
+ .header-controls :global(.fullscreen-toggle) {
1036
+ opacity: 1;
1037
+ position: static;
1038
+ }
1039
+ .reset-view {
1040
+ align-items: center;
1041
+ background-color: transparent;
1042
+ border-radius: var(--fullscreen-btn-border-radius, var(--border-radius, 3pt));
1043
+ cursor: pointer;
1044
+ display: flex;
1045
+ justify-content: center;
1046
+ padding: var(--fullscreen-btn-padding, 2pt);
1047
+ }
1048
+ .reset-view:hover,
1049
+ .reset-view:focus {
1050
+ background-color: color-mix(in srgb, currentColor 8%, transparent);
1051
+ }
1052
+ .binned-scatter:hover .header-controls,
1053
+ .binned-scatter .header-controls:focus-within {
1054
+ opacity: 1;
1055
+ }
1056
+ canvas,
1057
+ svg {
1058
+ inset: 0;
1059
+ position: absolute;
1060
+ }
1061
+ canvas {
1062
+ background: transparent;
1063
+ }
1064
+ svg {
1065
+ overflow: visible;
1066
+ pointer-events: none;
1067
+ }
1068
+ .reference-lines line {
1069
+ opacity: 0.75;
1070
+ }
1071
+ .point-label-leaders line {
1072
+ stroke: var(--binned-scatter-label-leader-color, color-mix(in srgb, currentColor 60%, transparent));
1073
+ stroke-dasharray: var(--binned-scatter-label-leader-dash, 2 2);
1074
+ stroke-width: var(--binned-scatter-label-leader-width, 0.8);
1075
+ }
1076
+ .point-labels {
1077
+ inset: 0;
1078
+ pointer-events: none;
1079
+ position: absolute;
1080
+ z-index: 1;
1081
+ }
1082
+ .point-label-measurements {
1083
+ contain: layout style;
1084
+ inset: 0;
1085
+ pointer-events: none;
1086
+ position: absolute;
1087
+ visibility: hidden;
1088
+ z-index: -1;
1089
+ }
1090
+ .point-label {
1091
+ background: var(--binned-scatter-label-bg, color-mix(in srgb, Canvas 84%, transparent));
1092
+ border: 0 !important;
1093
+ border-radius: var(--binned-scatter-label-radius, 3px);
1094
+ box-shadow: none;
1095
+ color: var(--binned-scatter-label-color, currentColor);
1096
+ font-size: var(--binned-scatter-label-font-size, 11px);
1097
+ line-height: 1.2;
1098
+ outline: 0;
1099
+ padding: var(--binned-scatter-label-padding, 1px 3px);
1100
+ position: absolute;
1101
+ text-align: center;
1102
+ transform: translate(-50%, -50%);
1103
+ white-space: nowrap;
1104
+ }
1105
+ .point-label-measure {
1106
+ left: 0;
1107
+ top: 0;
1108
+ transform: none;
1109
+ }
1110
+ .color-bar {
1111
+ pointer-events: auto;
1112
+ position: absolute;
1113
+ }
1114
+ </style>