matterviz 0.4.0 → 0.4.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 (326) hide show
  1. package/dist/brillouin/BrillouinZone.svelte +68 -145
  2. package/dist/brillouin/BrillouinZone.svelte.d.ts +5 -14
  3. package/dist/brillouin/BrillouinZoneExportPane.svelte +43 -96
  4. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +1 -1
  5. package/dist/brillouin/BrillouinZoneInfoPane.svelte +9 -32
  6. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +2 -3
  7. package/dist/brillouin/BrillouinZoneScene.svelte +49 -203
  8. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +3 -23
  9. package/dist/brillouin/ReciprocalVectors.svelte +39 -0
  10. package/dist/brillouin/ReciprocalVectors.svelte.d.ts +9 -0
  11. package/dist/brillouin/compute.d.ts +2 -0
  12. package/dist/brillouin/compute.js +80 -77
  13. package/dist/brillouin/geometry.d.ts +8 -0
  14. package/dist/brillouin/geometry.js +57 -0
  15. package/dist/brillouin/index.d.ts +2 -0
  16. package/dist/brillouin/index.js +2 -0
  17. package/dist/brillouin/types.d.ts +2 -2
  18. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +1 -1
  19. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +100 -191
  20. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +4 -1
  21. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +176 -464
  22. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +7 -1
  23. package/dist/chempot-diagram/color.d.ts +3 -6
  24. package/dist/chempot-diagram/color.js +5 -5
  25. package/dist/chempot-diagram/compute.d.ts +3 -3
  26. package/dist/chempot-diagram/compute.js +3 -1
  27. package/dist/chempot-diagram/controls-state.svelte.d.ts +10 -0
  28. package/dist/chempot-diagram/controls-state.svelte.js +42 -0
  29. package/dist/chempot-diagram/export.d.ts +47 -0
  30. package/dist/chempot-diagram/export.js +133 -0
  31. package/dist/chempot-diagram/index.d.ts +1 -0
  32. package/dist/chempot-diagram/index.js +1 -0
  33. package/dist/chempot-diagram/pointer.d.ts +0 -10
  34. package/dist/chempot-diagram/pointer.js +4 -4
  35. package/dist/chempot-diagram/types.d.ts +3 -3
  36. package/dist/colors/index.js +2 -2
  37. package/dist/composition/FormulaFilter.svelte +6 -5
  38. package/dist/composition/PieChart.svelte +5 -5
  39. package/dist/composition/chem-sys.js +3 -2
  40. package/dist/composition/format.js +3 -2
  41. package/dist/composition/parse.d.ts +0 -1
  42. package/dist/composition/parse.js +17 -19
  43. package/dist/controls.d.ts +1 -0
  44. package/dist/controls.js +0 -1
  45. package/dist/convex-hull/ConvexHull.svelte +8 -10
  46. package/dist/convex-hull/ConvexHull.svelte.d.ts +1 -4
  47. package/dist/convex-hull/ConvexHull2D.svelte +94 -175
  48. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +1 -1
  49. package/dist/convex-hull/ConvexHull3D.svelte +176 -680
  50. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +1 -1
  51. package/dist/convex-hull/ConvexHull4D.svelte +180 -680
  52. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +1 -1
  53. package/dist/convex-hull/ConvexHullChrome.svelte +268 -0
  54. package/dist/convex-hull/ConvexHullChrome.svelte.d.ts +30 -0
  55. package/dist/convex-hull/ConvexHullControls.svelte +88 -7
  56. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +7 -6
  57. package/dist/convex-hull/ConvexHullInfoPane.svelte +18 -5
  58. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +6 -5
  59. package/dist/convex-hull/ConvexHullStats.svelte +29 -168
  60. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +3 -1
  61. package/dist/convex-hull/ConvexHullTooltip.svelte +11 -2
  62. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +2 -1
  63. package/dist/convex-hull/barycentric-coords.d.ts +2 -4
  64. package/dist/convex-hull/barycentric-coords.js +6 -33
  65. package/dist/convex-hull/canvas-interactions.svelte.d.ts +79 -0
  66. package/dist/convex-hull/canvas-interactions.svelte.js +278 -0
  67. package/dist/convex-hull/helpers.d.ts +39 -7
  68. package/dist/convex-hull/helpers.js +154 -69
  69. package/dist/convex-hull/hull-state.svelte.d.ts +44 -0
  70. package/dist/convex-hull/hull-state.svelte.js +124 -0
  71. package/dist/convex-hull/index.d.ts +9 -7
  72. package/dist/convex-hull/index.js +7 -2
  73. package/dist/convex-hull/thermodynamics.js +91 -920
  74. package/dist/convex-hull/types.d.ts +12 -4
  75. package/dist/convex-hull/types.js +12 -0
  76. package/dist/coordination/CoordinationBarPlot.svelte +4 -11
  77. package/dist/element/BohrAtom.svelte +2 -1
  78. package/dist/element/ElementTile.svelte.d.ts +1 -1
  79. package/dist/element/index.d.ts +4 -0
  80. package/dist/element/index.js +18 -0
  81. package/dist/feedback/DragOverlay.svelte +3 -1
  82. package/dist/feedback/DragOverlay.svelte.d.ts +1 -0
  83. package/dist/feedback/StatusMessage.svelte +13 -3
  84. package/dist/fermi-surface/FermiSurface.svelte +67 -146
  85. package/dist/fermi-surface/FermiSurface.svelte.d.ts +5 -14
  86. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +1 -1
  87. package/dist/fermi-surface/FermiSurfaceScene.svelte +72 -224
  88. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +3 -23
  89. package/dist/fermi-surface/compute.js +11 -10
  90. package/dist/fermi-surface/export.js +4 -15
  91. package/dist/fermi-surface/index.d.ts +0 -1
  92. package/dist/fermi-surface/index.js +0 -1
  93. package/dist/fermi-surface/parse.d.ts +1 -1
  94. package/dist/fermi-surface/parse.js +64 -75
  95. package/dist/fermi-surface/types.d.ts +2 -2
  96. package/dist/heatmap-matrix/HeatmapMatrix.svelte +55 -40
  97. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +4 -3
  98. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +3 -2
  99. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +5 -5
  100. package/dist/heatmap-matrix/index.d.ts +3 -2
  101. package/dist/index.d.ts +1 -0
  102. package/dist/index.js +1 -0
  103. package/dist/io/ExportPane.svelte +166 -0
  104. package/dist/io/ExportPane.svelte.d.ts +17 -0
  105. package/dist/io/decompress.js +1 -2
  106. package/dist/io/export.d.ts +5 -1
  107. package/dist/io/export.js +32 -28
  108. package/dist/io/fetch.d.ts +2 -1
  109. package/dist/io/file-drop.d.ts +7 -0
  110. package/dist/io/file-drop.js +13 -0
  111. package/dist/io/index.d.ts +2 -0
  112. package/dist/io/index.js +10 -0
  113. package/dist/io/types.d.ts +13 -0
  114. package/dist/isosurface/parse.js +46 -44
  115. package/dist/labels.js +1 -1
  116. package/dist/layout/FullscreenButton.svelte +33 -0
  117. package/dist/layout/FullscreenButton.svelte.d.ts +10 -0
  118. package/dist/layout/FullscreenToggle.svelte +8 -14
  119. package/dist/layout/ViewerChrome.svelte +116 -0
  120. package/dist/layout/ViewerChrome.svelte.d.ts +17 -0
  121. package/dist/layout/fullscreen.d.ts +4 -0
  122. package/dist/layout/fullscreen.svelte.d.ts +8 -0
  123. package/dist/layout/fullscreen.svelte.js +37 -0
  124. package/dist/layout/index.d.ts +3 -0
  125. package/dist/layout/index.js +3 -0
  126. package/dist/math.d.ts +7 -3
  127. package/dist/math.js +18 -21
  128. package/dist/overlays/index.d.ts +4 -0
  129. package/dist/periodic-table/PeriodicTable.svelte +9 -8
  130. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +1 -1
  131. package/dist/phase-diagram/PhaseDiagramControls.svelte +3 -2
  132. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +4 -3
  133. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +2 -1
  134. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +2 -3
  135. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +47 -132
  136. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +3 -4
  137. package/dist/phase-diagram/colors.js +1 -1
  138. package/dist/phase-diagram/parse.d.ts +2 -1
  139. package/dist/plot/bar/BarPlot.svelte +79 -316
  140. package/dist/plot/bar/BarPlot.svelte.d.ts +7 -15
  141. package/dist/plot/bar/BarPlotControls.svelte.d.ts +1 -1
  142. package/dist/plot/bar/SpacegroupBarPlot.svelte +2 -1
  143. package/dist/plot/box/BoxPlot.svelte +76 -246
  144. package/dist/plot/box/BoxPlot.svelte.d.ts +4 -3
  145. package/dist/plot/box/BoxPlotControls.svelte.d.ts +1 -1
  146. package/dist/plot/box/Violin.svelte.d.ts +1 -1
  147. package/dist/plot/box/box-plot.d.ts +3 -2
  148. package/dist/plot/box/box-plot.js +5 -2
  149. package/dist/plot/box/kde.d.ts +2 -1
  150. package/dist/plot/box/kde.js +4 -4
  151. package/dist/plot/core/auto-place.d.ts +1 -1
  152. package/dist/plot/core/auto-place.js +4 -1
  153. package/dist/plot/core/components/ColorBar.svelte +5 -5
  154. package/dist/plot/core/components/ColorBar.svelte.d.ts +5 -4
  155. package/dist/plot/core/components/Line.svelte +3 -2
  156. package/dist/plot/core/components/Line.svelte.d.ts +3 -2
  157. package/dist/plot/core/components/PlotAxis.svelte +2 -1
  158. package/dist/plot/core/components/PlotAxis.svelte.d.ts +2 -1
  159. package/dist/plot/core/components/PlotControls.svelte.d.ts +1 -1
  160. package/dist/plot/core/components/ReferenceLine3D.svelte +2 -2
  161. package/dist/plot/core/components/ReferenceLine3D.svelte.d.ts +4 -4
  162. package/dist/plot/core/components/ReferencePlane.svelte +2 -2
  163. package/dist/plot/core/components/ReferencePlane.svelte.d.ts +4 -4
  164. package/dist/plot/core/data-cleaning.js +18 -18
  165. package/dist/plot/core/fill-utils.d.ts +4 -3
  166. package/dist/plot/core/fill-utils.js +6 -3
  167. package/dist/plot/core/interactions.d.ts +5 -1
  168. package/dist/plot/core/interactions.js +14 -0
  169. package/dist/plot/core/pan-zoom.svelte.d.ts +35 -0
  170. package/dist/plot/core/pan-zoom.svelte.js +221 -0
  171. package/dist/plot/core/placed-tween.svelte.d.ts +21 -0
  172. package/dist/plot/core/placed-tween.svelte.js +68 -0
  173. package/dist/plot/core/reference-line.d.ts +10 -10
  174. package/dist/plot/core/reference-line.js +6 -6
  175. package/dist/plot/core/scales.d.ts +17 -25
  176. package/dist/plot/core/scales.js +10 -8
  177. package/dist/plot/core/svg.d.ts +2 -1
  178. package/dist/plot/core/types.d.ts +18 -7
  179. package/dist/plot/core/utils/label-placement.d.ts +1 -1
  180. package/dist/plot/core/utils/label-placement.js +3 -3
  181. package/dist/plot/core/utils.d.ts +2 -1
  182. package/dist/plot/histogram/Histogram.svelte +77 -314
  183. package/dist/plot/histogram/HistogramControls.svelte.d.ts +1 -1
  184. package/dist/plot/sankey/Sankey.svelte +2 -5
  185. package/dist/plot/sankey/Sankey.svelte.d.ts +1 -1
  186. package/dist/plot/sankey/sankey.js +3 -1
  187. package/dist/plot/scatter/BinnedScatterPlot.svelte +3 -5
  188. package/dist/plot/scatter/BinnedScatterPlot.svelte.d.ts +4 -4
  189. package/dist/plot/scatter/ScatterPlot.svelte +160 -450
  190. package/dist/plot/scatter/ScatterPlot.svelte.d.ts +7 -15
  191. package/dist/plot/scatter/ScatterPlotControls.svelte.d.ts +1 -1
  192. package/dist/plot/scatter/binned-scatter-types.d.ts +4 -11
  193. package/dist/plot/scatter/index.d.ts +1 -1
  194. package/dist/plot/scatter-3d/ScatterPlot3D.svelte +15 -26
  195. package/dist/plot/scatter-3d/ScatterPlot3D.svelte.d.ts +6 -14
  196. package/dist/plot/scatter-3d/ScatterPlot3DControls.svelte +9 -10
  197. package/dist/plot/scatter-3d/ScatterPlot3DControls.svelte.d.ts +5 -5
  198. package/dist/plot/scatter-3d/ScatterPlot3DScene.svelte +122 -121
  199. package/dist/plot/scatter-3d/ScatterPlot3DScene.svelte.d.ts +5 -14
  200. package/dist/plot/scatter-3d/Surface3D.svelte +6 -5
  201. package/dist/plot/scatter-3d/Surface3D.svelte.d.ts +4 -3
  202. package/dist/plot/sunburst/Sunburst.svelte +16 -20
  203. package/dist/plot/sunburst/Sunburst.svelte.d.ts +4 -3
  204. package/dist/plot/sunburst/SunburstControls.svelte.d.ts +1 -1
  205. package/dist/plot/sunburst/sunburst.js +4 -1
  206. package/dist/rdf/RdfPlot.svelte.d.ts +1 -1
  207. package/dist/sanitize.js +13 -2
  208. package/dist/scene/SceneCamera.svelte +62 -0
  209. package/dist/scene/SceneCamera.svelte.d.ts +19 -0
  210. package/dist/scene/bind-renderer.svelte.d.ts +2 -0
  211. package/dist/scene/bind-renderer.svelte.js +14 -0
  212. package/dist/scene/index.d.ts +4 -0
  213. package/dist/scene/index.js +5 -0
  214. package/dist/scene/props.js +52 -0
  215. package/dist/scene/types.d.ts +26 -0
  216. package/dist/scene/types.js +1 -0
  217. package/dist/settings.d.ts +14 -2
  218. package/dist/settings.js +59 -1
  219. package/dist/spectral/Bands.svelte +8 -7
  220. package/dist/spectral/Bands.svelte.d.ts +3 -2
  221. package/dist/spectral/BandsAndDos.svelte +22 -24
  222. package/dist/spectral/BrillouinBandsDos.svelte +3 -3
  223. package/dist/spectral/Dos.svelte +5 -4
  224. package/dist/spectral/Dos.svelte.d.ts +2 -1
  225. package/dist/spectral/helpers.d.ts +6 -6
  226. package/dist/spectral/helpers.js +43 -37
  227. package/dist/state.svelte.d.ts +0 -7
  228. package/dist/state.svelte.js +0 -6
  229. package/dist/structure/Arrow.svelte +2 -4
  230. package/dist/structure/AtomLegend.svelte.d.ts +1 -1
  231. package/dist/structure/CanvasTooltip.svelte +1 -0
  232. package/dist/structure/CellSelect.svelte +11 -3
  233. package/dist/structure/CellSelect.svelte.d.ts +2 -1
  234. package/dist/structure/Lattice.svelte +2 -2
  235. package/dist/structure/Structure.svelte +291 -355
  236. package/dist/structure/Structure.svelte.d.ts +5 -15
  237. package/dist/structure/StructureControls.svelte +217 -2
  238. package/dist/structure/StructureControls.svelte.d.ts +5 -3
  239. package/dist/structure/StructureExportPane.svelte +54 -156
  240. package/dist/structure/StructureExportPane.svelte.d.ts +4 -5
  241. package/dist/structure/StructureInfoPane.svelte +5 -3
  242. package/dist/structure/StructureInfoPane.svelte.d.ts +5 -5
  243. package/dist/structure/StructureScene.svelte +365 -198
  244. package/dist/structure/StructureScene.svelte.d.ts +22 -20
  245. package/dist/structure/{label-placement.d.ts → atom-label-placement.d.ts} +3 -3
  246. package/dist/structure/{label-placement.js → atom-label-placement.js} +12 -2
  247. package/dist/structure/atom-properties.d.ts +1 -1
  248. package/dist/structure/atom-properties.js +11 -16
  249. package/dist/structure/bond-order-perception.js +2 -4
  250. package/dist/structure/bonding.d.ts +3 -0
  251. package/dist/structure/bonding.js +91 -48
  252. package/dist/structure/export.d.ts +24 -4
  253. package/dist/structure/export.js +64 -122
  254. package/dist/structure/index.d.ts +2 -0
  255. package/dist/structure/index.js +2 -0
  256. package/dist/structure/parse.d.ts +3 -2
  257. package/dist/structure/parse.js +333 -370
  258. package/dist/structure/partial-occupancy.d.ts +0 -1
  259. package/dist/structure/partial-occupancy.js +1 -1
  260. package/dist/structure/pbc.d.ts +1 -1
  261. package/dist/structure/pbc.js +186 -13
  262. package/dist/structure/polyhedra.d.ts +41 -0
  263. package/dist/structure/polyhedra.js +602 -0
  264. package/dist/structure/site.d.ts +4 -0
  265. package/dist/structure/site.js +1 -0
  266. package/dist/structure/supercell.js +3 -2
  267. package/dist/structure/validation.js +5 -6
  268. package/dist/symmetry/SymmetryElementControls.svelte +69 -0
  269. package/dist/symmetry/SymmetryElementControls.svelte.d.ts +9 -0
  270. package/dist/symmetry/SymmetryElements.svelte +354 -0
  271. package/dist/symmetry/SymmetryElements.svelte.d.ts +24 -0
  272. package/dist/symmetry/SymmetryStats.svelte +111 -6
  273. package/dist/symmetry/WyckoffTable.svelte +68 -7
  274. package/dist/symmetry/WyckoffTable.svelte.d.ts +3 -0
  275. package/dist/symmetry/cell-transform.js +7 -14
  276. package/dist/symmetry/index.d.ts +14 -4
  277. package/dist/symmetry/index.js +301 -80
  278. package/dist/symmetry/spacegroups.d.ts +5 -1
  279. package/dist/symmetry/spacegroups.js +15 -1
  280. package/dist/symmetry/symmetry-elements.d.ts +33 -0
  281. package/dist/symmetry/symmetry-elements.js +521 -0
  282. package/dist/symmetry/wyckoff-db.d.ts +9 -0
  283. package/dist/symmetry/wyckoff-db.js +87 -0
  284. package/dist/table/HeatmapTable.svelte +4 -15
  285. package/dist/table/HeatmapTable.svelte.d.ts +1 -1
  286. package/dist/trajectory/Trajectory.svelte +58 -61
  287. package/dist/trajectory/Trajectory.svelte.d.ts +10 -22
  288. package/dist/trajectory/TrajectoryExportPane.svelte +15 -24
  289. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +4 -5
  290. package/dist/trajectory/TrajectoryInfoPane.svelte +3 -2
  291. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +3 -2
  292. package/dist/trajectory/constants.js +6 -2
  293. package/dist/trajectory/extract.js +17 -37
  294. package/dist/trajectory/format-detect.d.ts +0 -1
  295. package/dist/trajectory/format-detect.js +3 -9
  296. package/dist/trajectory/frame-reader.d.ts +0 -1
  297. package/dist/trajectory/frame-reader.js +62 -128
  298. package/dist/trajectory/helpers.d.ts +10 -2
  299. package/dist/trajectory/helpers.js +56 -36
  300. package/dist/trajectory/parse/ase.d.ts +9 -1
  301. package/dist/trajectory/parse/ase.js +47 -32
  302. package/dist/trajectory/parse/diagnostics.d.ts +3 -0
  303. package/dist/trajectory/parse/diagnostics.js +14 -0
  304. package/dist/trajectory/parse/index.d.ts +1 -1
  305. package/dist/trajectory/parse/index.js +54 -102
  306. package/dist/trajectory/parse/lammps.d.ts +0 -2
  307. package/dist/trajectory/parse/lammps.js +8 -6
  308. package/dist/trajectory/parse/pymatgen.d.ts +2 -0
  309. package/dist/trajectory/parse/pymatgen.js +74 -0
  310. package/dist/trajectory/parse/vasp.js +4 -3
  311. package/dist/trajectory/parse/xyz.d.ts +9 -21
  312. package/dist/trajectory/parse/xyz.js +28 -33
  313. package/dist/trajectory/plotting.d.ts +0 -1
  314. package/dist/trajectory/plotting.js +3 -100
  315. package/dist/utils.d.ts +1 -0
  316. package/dist/utils.js +1 -1
  317. package/dist/xrd/XrdPlot.svelte +14 -29
  318. package/dist/xrd/broadening.d.ts +2 -1
  319. package/dist/xrd/calc-xrd.js +6 -11
  320. package/dist/xrd/index.d.ts +2 -2
  321. package/package.json +29 -16
  322. package/dist/element/data.json +0 -11864
  323. package/dist/fermi-surface/marching-cubes.d.ts +0 -2
  324. package/dist/fermi-surface/marching-cubes.js +0 -2
  325. package/dist/plot/core/hover-lock.svelte.d.ts +0 -14
  326. package/dist/plot/core/hover-lock.svelte.js +0 -45
@@ -1,4 +1,5 @@
1
1
  import type { PhaseData } from '../convex-hull/types';
2
+ import { type FullscreenToggleProp } from '../layout';
2
3
  import type { ChemPotDiagramConfig, ChemPotHoverInfo } from './types';
3
4
  type $$ComponentProps = {
4
5
  entries: PhaseData[];
@@ -10,7 +11,12 @@ type $$ComponentProps = {
10
11
  max_interpolation_gap?: number;
11
12
  hover_info?: ChemPotHoverInfo | null;
12
13
  render_local_tooltip?: boolean;
14
+ wrapper?: HTMLDivElement;
15
+ fullscreen?: boolean;
16
+ fullscreen_toggle?: FullscreenToggleProp;
17
+ controls_open?: boolean;
18
+ export_pane_open?: boolean;
13
19
  };
14
- declare const ChemPotDiagram3D: import("svelte").Component<$$ComponentProps, {}, "temperature" | "height" | "width" | "hover_info">;
20
+ declare const ChemPotDiagram3D: import("svelte").Component<$$ComponentProps, {}, "height" | "width" | "temperature" | "fullscreen" | "wrapper" | "controls_open" | "export_pane_open" | "hover_info">;
15
21
  type ChemPotDiagram3D = ReturnType<typeof ChemPotDiagram3D>;
16
22
  export default ChemPotDiagram3D;
@@ -1,10 +1,7 @@
1
1
  import { type D3InterpolateName } from '../colors';
2
- /** Resolve D3 interpolator with optional reverse for chempot color scales. */
3
- export declare function get_chempot_interpolator(name: D3InterpolateName, reverse: boolean): (t: number) => string;
4
- /** Build sequential color scale from values and D3 interpolator name. */
2
+ import type { Vec2 } from '../math';
5
3
  export declare function make_chempot_color_scale(values: number[], interpolator_name: D3InterpolateName, reverse: boolean): ((val: number) => string) | null;
6
- /** Resolve color bar props for chempot diagrams (interpolator + domain). */
7
4
  export declare function get_chempot_color_bar_config(color_scale: D3InterpolateName, reverse: boolean): {
8
- color_scale_fn: (t: number) => string;
9
- color_scale_domain: [number, number];
5
+ color_scale_fn: (frac: number) => string;
6
+ color_scale_domain: Vec2;
10
7
  };
@@ -1,11 +1,11 @@
1
1
  import { get_d3_interpolator } from '../colors';
2
2
  import { scaleSequential } from 'd3-scale';
3
- /** Resolve D3 interpolator with optional reverse for chempot color scales. */
4
- export function get_chempot_interpolator(name, reverse) {
3
+ // Resolve D3 interpolator with optional reverse for chempot color scales.
4
+ function get_chempot_interpolator(name, reverse) {
5
5
  const raw = get_d3_interpolator(name);
6
- return reverse ? (t) => raw(1 - t) : raw;
6
+ return reverse ? (frac) => raw(1 - frac) : raw;
7
7
  }
8
- /** Build sequential color scale from values and D3 interpolator name. */
8
+ // Build sequential color scale from values and D3 interpolator name.
9
9
  export function make_chempot_color_scale(values, interpolator_name, reverse) {
10
10
  const finite_values = values.filter(Number.isFinite);
11
11
  if (finite_values.length === 0)
@@ -23,7 +23,7 @@ export function make_chempot_color_scale(values, interpolator_name, reverse) {
23
23
  max_value,
24
24
  ]);
25
25
  }
26
- /** Resolve color bar props for chempot diagrams (interpolator + domain). */
26
+ // Resolve color bar props for chempot diagrams (interpolator + domain).
27
27
  export function get_chempot_color_bar_config(color_scale, reverse) {
28
28
  return {
29
29
  color_scale_fn: get_chempot_interpolator(color_scale, reverse),
@@ -1,4 +1,5 @@
1
1
  import type { PhaseData } from '../convex-hull/types';
2
+ import type { Vec2 } from '../math';
2
3
  import { type ChemPotDiagramConfig, type ChemPotDiagramData } from './types';
3
4
  export declare function get_energy_per_atom(entry: PhaseData): number;
4
5
  export declare function formula_key_from_composition(composition: Record<string, number>): string;
@@ -6,14 +7,13 @@ export declare function get_min_entries_and_el_refs(entries: PhaseData[]): {
6
7
  min_entries: PhaseData[];
7
8
  el_refs: Record<string, PhaseData>;
8
9
  };
9
- export declare function compute_form_energy_per_atom(entry: PhaseData, el_refs: Record<string, PhaseData>): number;
10
10
  export declare function best_form_energy_for_formula(entries: PhaseData[], formula: string, el_refs: Record<string, PhaseData>): number | undefined;
11
11
  export declare const renormalize_entries: (entries: PhaseData[], el_refs: Record<string, PhaseData>, elements: string[]) => PhaseData[];
12
12
  export declare function build_hyperplanes(min_entries: PhaseData[], el_refs: Record<string, PhaseData>, elements: string[]): {
13
13
  hyperplanes: number[][];
14
14
  hyperplane_entries: PhaseData[];
15
15
  };
16
- export declare function build_border_hyperplanes(lims: [number, number][]): number[][];
16
+ export declare function build_border_hyperplanes(lims: Vec2[]): number[][];
17
17
  export declare function compute_domains(hyperplanes: number[][], border_hyperplanes: number[][], hyperplane_entries: PhaseData[], dim: number): Record<string, number[][]>;
18
18
  export declare function apply_element_padding(domains: Record<string, number[][]>, elem_indices: number[], padding: number, default_min_limit: number): number[];
19
19
  export declare function pad_domain_points(pts: number[][], elem_indices: number[], new_lims: number[], default_min_limit: number, padding: number): number[][];
@@ -26,7 +26,7 @@ export declare function simple_pca(data: number[][], k?: number): {
26
26
  scores: number[][];
27
27
  eigenvectors: number[][];
28
28
  };
29
- export declare function orthonormal_2d(line_pts: number[][]): [number, number];
29
+ export declare function orthonormal_2d(line_pts: number[][]): Vec2;
30
30
  export declare function dedup_points(pts: number[][], tol?: number): {
31
31
  unique: number[][];
32
32
  orig_indices: number[];
@@ -84,7 +84,9 @@ export function get_min_entries_and_el_refs(entries) {
84
84
  return { min_entries, el_refs };
85
85
  }
86
86
  // Compute formation energy per atom against elemental references.
87
- export function compute_form_energy_per_atom(entry, el_refs) {
87
+ // NOTE: diverges from convex-hull's compute_e_form_per_atom (which returns null on
88
+ // missing refs); kept module-private so the divergent variant can't leak into public API.
89
+ function compute_form_energy_per_atom(entry, el_refs) {
88
90
  const atom_count = count_atoms_in_composition(entry.composition);
89
91
  const energy_per_atom = get_energy_per_atom(entry);
90
92
  let ref_energy = 0;
@@ -0,0 +1,10 @@
1
+ import { type ChemPotDiagramConfig } from './types';
2
+ export declare function create_chempot_overrides<Key extends keyof ChemPotDiagramConfig>(config: () => ChemPotDiagramConfig, keys: readonly Key[], custom_defaults?: {
3
+ [P in Key]?: NonNullable<ChemPotDiagramConfig[P]>;
4
+ }): {
5
+ resolve: <P extends Key>(key: P) => NonNullable<ChemPotDiagramConfig[P]>;
6
+ set: <P extends Key>(key: P, value: NonNullable<ChemPotDiagramConfig[P]>) => void;
7
+ reset: () => void;
8
+ };
9
+ export declare const CHEMPOT_COLOR_MODE_OPTIONS: readonly [readonly ["none", "None"], readonly ["energy", "Energy/atom"], readonly ["formation_energy", "Formation energy"], readonly ["arity", "Element count"], readonly ["entries", "Entry count"]];
10
+ export declare const CHEMPOT_COLOR_SCALE_OPTIONS: readonly [readonly ["interpolateViridis", "Viridis"], readonly ["interpolatePlasma", "Plasma"], readonly ["interpolateInferno", "Inferno"], readonly ["interpolateMagma", "Magma"], readonly ["interpolateCividis", "Cividis"], readonly ["interpolateTurbo", "Turbo"], readonly ["interpolateRdYlBu", "RdYlBu"], readonly ["interpolateSpectral", "Spectral"]];
@@ -0,0 +1,42 @@
1
+ // Override state + shared <option> lists for the ChemPotDiagram2D/3D control panes
2
+ import { CHEMPOT_DEFAULTS } from './types';
3
+ // Per-key user overrides with `override ?? config ?? default` resolution; `reset()`
4
+ // clears all overrides (the panes' "Reset defaults" buttons). Defaults come from
5
+ // CHEMPOT_DEFAULTS unless overridden via custom_defaults; keys without either throw upfront.
6
+ export function create_chempot_overrides(config, keys, custom_defaults = {}) {
7
+ const defaults = Object.fromEntries(keys.map((key) => {
8
+ const fallback = custom_defaults[key] ?? CHEMPOT_DEFAULTS[key];
9
+ if (fallback === undefined) {
10
+ throw new Error(`create_chempot_overrides: key '${key}' is missing from both custom_defaults and CHEMPOT_DEFAULTS`);
11
+ }
12
+ return [key, fallback];
13
+ }));
14
+ let overrides = $state({});
15
+ return {
16
+ resolve: (key) => (overrides[key] ?? config()[key] ?? defaults[key]),
17
+ set: (key, value) => {
18
+ overrides[key] = value;
19
+ },
20
+ reset: () => {
21
+ overrides = {};
22
+ },
23
+ };
24
+ }
25
+ // [value, label] pairs for the color-mode and color-scale <select>s in both panes
26
+ export const CHEMPOT_COLOR_MODE_OPTIONS = [
27
+ [`none`, `None`],
28
+ [`energy`, `Energy/atom`],
29
+ [`formation_energy`, `Formation energy`],
30
+ [`arity`, `Element count`],
31
+ [`entries`, `Entry count`],
32
+ ];
33
+ export const CHEMPOT_COLOR_SCALE_OPTIONS = [
34
+ [`interpolateViridis`, `Viridis`],
35
+ [`interpolatePlasma`, `Plasma`],
36
+ [`interpolateInferno`, `Inferno`],
37
+ [`interpolateMagma`, `Magma`],
38
+ [`interpolateCividis`, `Cividis`],
39
+ [`interpolateTurbo`, `Turbo`],
40
+ [`interpolateRdYlBu`, `RdYlBu`],
41
+ [`interpolateSpectral`, `Spectral`],
42
+ ];
@@ -0,0 +1,47 @@
1
+ import * as THREE from 'three';
2
+ export declare const get_json_string: (payload: unknown) => string;
3
+ export declare const export_json_file: (payload: unknown, basename: string) => void;
4
+ interface XYZ {
5
+ x: number;
6
+ y: number;
7
+ z: number;
8
+ }
9
+ export declare function get_view_settings(opts: {
10
+ elements: string[];
11
+ camera_projection: string;
12
+ auto_rotate: number;
13
+ color_mode: string;
14
+ color_scale: string;
15
+ reverse_color_scale: boolean;
16
+ camera_position?: XYZ | null;
17
+ camera_target?: XYZ | null;
18
+ }): Record<string, unknown>;
19
+ export declare const export_view_json_file: (view_settings: Record<string, unknown>, basename: string) => void;
20
+ export interface OverlayTextItem {
21
+ x: number;
22
+ y: number;
23
+ text: string;
24
+ font: string;
25
+ font_size: string;
26
+ font_family: string;
27
+ font_weight: string;
28
+ color: string;
29
+ }
30
+ export declare function get_overlay_text_items(wrapper: HTMLElement, canvas_rect: DOMRect): OverlayTextItem[];
31
+ export declare function export_png_file(wrapper: HTMLElement | undefined, basename: string, png_dpi: number): void;
32
+ export declare function export_svg_file(wrapper: HTMLElement | undefined, basename: string, view_settings: Record<string, unknown>): void;
33
+ export interface ChemPotGlbParts {
34
+ hull_geometry?: THREE.BufferGeometry | null;
35
+ hull_opacity?: number;
36
+ edge_geometry: THREE.BufferGeometry;
37
+ formula_meshes?: {
38
+ geometry: THREE.BufferGeometry;
39
+ color: string;
40
+ }[];
41
+ formula_edges?: {
42
+ geometry: THREE.BufferGeometry;
43
+ color: string;
44
+ }[];
45
+ }
46
+ export declare function export_glb_file(parts: ChemPotGlbParts, basename: string): void;
47
+ export {};
@@ -0,0 +1,133 @@
1
+ // Export helpers for chemical potential diagrams (shared between 2D and 3D views).
2
+ import { dpi_to_scale } from '../io/export';
3
+ import { download } from '../io/fetch';
4
+ import * as THREE from 'three';
5
+ import { GLTFExporter } from 'three/examples/jsm/exporters/GLTFExporter.js';
6
+ export const get_json_string = (payload) => JSON.stringify(payload, null, 2);
7
+ const download_json = (payload, filename) => download(get_json_string(payload), filename, `application/json`);
8
+ export const export_json_file = (payload, basename) => download_json(payload, `${basename}.json`);
9
+ const xyz_tuple = (point) => point ? [point.x, point.y, point.z] : null;
10
+ const get_gl_canvas = (wrapper) => {
11
+ const canvas = wrapper?.querySelector(`canvas`);
12
+ return canvas instanceof HTMLCanvasElement ? canvas : null;
13
+ };
14
+ // Serializable snapshot of the current 3D view (embedded in SVG/JSON exports)
15
+ export function get_view_settings(opts) {
16
+ const { camera_position, camera_target, ...settings } = opts;
17
+ return {
18
+ ...settings,
19
+ camera_position: xyz_tuple(camera_position),
20
+ camera_target: xyz_tuple(camera_target),
21
+ };
22
+ }
23
+ export const export_view_json_file = (view_settings, basename) => download_json(view_settings, `${basename}-view.json`);
24
+ // Collect HTML overlay text (tick/axis/domain labels) positioned relative to the canvas
25
+ export function get_overlay_text_items(wrapper, canvas_rect) {
26
+ const text_items = [];
27
+ for (const element of wrapper.querySelectorAll(`.tick-label, .axis-label, .domain-label`)) {
28
+ const html_element = element;
29
+ const style = getComputedStyle(html_element);
30
+ if (style.display === `none` || style.visibility === `hidden`)
31
+ continue;
32
+ const element_rect = html_element.getBoundingClientRect();
33
+ text_items.push({
34
+ x: element_rect.left + element_rect.width / 2 - canvas_rect.left,
35
+ y: element_rect.top + element_rect.height / 2 - canvas_rect.top,
36
+ text: html_element.textContent ?? ``,
37
+ font: style.font || `${style.fontSize} ${style.fontFamily}`,
38
+ font_size: style.fontSize || `11px`,
39
+ font_family: style.fontFamily || `sans-serif`,
40
+ font_weight: style.fontWeight || `400`,
41
+ color: style.color || `#333`,
42
+ });
43
+ }
44
+ return text_items;
45
+ }
46
+ // Composite the WebGL canvas + HTML overlay labels into a single PNG download
47
+ export function export_png_file(wrapper, basename, png_dpi) {
48
+ const gl_canvas = get_gl_canvas(wrapper);
49
+ if (!gl_canvas || !wrapper)
50
+ return;
51
+ const rect = gl_canvas.getBoundingClientRect();
52
+ // A degenerate rect means the canvas is hidden/unrendered: nothing to capture
53
+ if (!(rect.width > 0) || !(rect.height > 0)) {
54
+ console.error(`Cannot export PNG: canvas has zero size (width=${rect.width}, height=${rect.height})`);
55
+ return;
56
+ }
57
+ const scale = dpi_to_scale(png_dpi);
58
+ const out = document.createElement(`canvas`);
59
+ // Floor at 1px so tiny rect x min-DPI rounding can't yield an invalid 0x0 canvas
60
+ out.width = Math.max(1, Math.round(rect.width * scale));
61
+ out.height = Math.max(1, Math.round(rect.height * scale));
62
+ const ctx = out.getContext(`2d`);
63
+ if (!ctx)
64
+ return;
65
+ ctx.scale(scale, scale);
66
+ ctx.drawImage(gl_canvas, 0, 0, rect.width, rect.height);
67
+ for (const text_item of get_overlay_text_items(wrapper, rect)) {
68
+ ctx.font = text_item.font;
69
+ ctx.fillStyle = text_item.color;
70
+ ctx.textAlign = `center`;
71
+ ctx.textBaseline = `middle`;
72
+ ctx.fillText(text_item.text, text_item.x, text_item.y);
73
+ }
74
+ out.toBlob((blob) => {
75
+ if (!blob)
76
+ return;
77
+ download(blob, `${basename}.png`, `image/png`);
78
+ }, `image/png`);
79
+ }
80
+ const xml_escape = (text) => text
81
+ .replaceAll(`&`, `&amp;`)
82
+ .replaceAll(`<`, `&lt;`)
83
+ .replaceAll(`>`, `&gt;`)
84
+ .replaceAll(`"`, `&quot;`)
85
+ .replaceAll(`'`, `&#39;`);
86
+ // SVG snapshot: rasterized canvas as embedded image + overlay labels as real text nodes
87
+ export function export_svg_file(wrapper, basename, view_settings) {
88
+ const gl_canvas = get_gl_canvas(wrapper);
89
+ if (!gl_canvas || !wrapper)
90
+ return;
91
+ const canvas_rect = gl_canvas.getBoundingClientRect();
92
+ if (canvas_rect.width === 0 || canvas_rect.height === 0)
93
+ return;
94
+ const png_data_url = gl_canvas.toDataURL(`image/png`);
95
+ const text_nodes = get_overlay_text_items(wrapper, canvas_rect).map((text_item) => `<text x="${text_item.x.toFixed(2)}" y="${text_item.y.toFixed(2)}" text-anchor="middle" dominant-baseline="central" fill="${xml_escape(text_item.color)}" font-size="${xml_escape(text_item.font_size)}" font-family="${xml_escape(text_item.font_family)}" font-weight="${xml_escape(text_item.font_weight)}">${xml_escape(text_item.text)}</text>`);
96
+ const metadata = xml_escape(JSON.stringify(view_settings));
97
+ const svg = [
98
+ `<?xml version="1.0" encoding="UTF-8"?>`,
99
+ `<svg xmlns="http://www.w3.org/2000/svg" width="${canvas_rect.width}" height="${canvas_rect.height}" viewBox="0 0 ${canvas_rect.width} ${canvas_rect.height}">`,
100
+ `<metadata>${metadata}</metadata>`,
101
+ `<image href="${png_data_url}" x="0" y="0" width="${canvas_rect.width}" height="${canvas_rect.height}" />`,
102
+ ...text_nodes,
103
+ `</svg>`,
104
+ ].join(``);
105
+ download(svg, `${basename}.svg`, `image/svg+xml`);
106
+ }
107
+ // Rebuild the scene from its geometries and export as binary GLTF
108
+ export function export_glb_file(parts, basename) {
109
+ const { hull_geometry, hull_opacity = 0.25, edge_geometry, formula_meshes = [], formula_edges = [], } = parts;
110
+ const gltf_exporter = new GLTFExporter();
111
+ const export_root = new THREE.Group();
112
+ const add_mesh = (geometry, material) => {
113
+ const opts = { transparent: true, side: THREE.DoubleSide, ...material };
114
+ export_root.add(new THREE.Mesh(geometry.clone(), new THREE.MeshBasicMaterial(opts)));
115
+ };
116
+ const add_lines = (geometry, color) => {
117
+ export_root.add(new THREE.LineSegments(geometry.clone(), new THREE.LineBasicMaterial({ color })));
118
+ };
119
+ if (hull_geometry)
120
+ add_mesh(hull_geometry, { vertexColors: true, opacity: hull_opacity });
121
+ add_lines(edge_geometry, 0x333333);
122
+ for (const { geometry, color } of formula_meshes) {
123
+ add_mesh(geometry, { color: new THREE.Color(color), opacity: 0.13 });
124
+ }
125
+ for (const { geometry, color } of formula_edges) {
126
+ add_lines(geometry, new THREE.Color(color));
127
+ }
128
+ gltf_exporter.parse(export_root, (result) => {
129
+ if (!(result instanceof ArrayBuffer))
130
+ return;
131
+ download(result, `${basename}.glb`, `model/gltf-binary`);
132
+ }, (err) => console.error(`Failed to export GLB:`, err), { binary: true, onlyVisible: false });
133
+ }
@@ -3,4 +3,5 @@ export { default as ChemPotDiagram2D } from './ChemPotDiagram2D.svelte';
3
3
  export { default as ChemPotDiagram3D } from './ChemPotDiagram3D.svelte';
4
4
  export { compute_chempot_async } from './async-compute.svelte';
5
5
  export { compute_chempot_diagram, get_ternary_combinations } from './compute';
6
+ export * from './export';
6
7
  export * from './types';
@@ -3,4 +3,5 @@ export { default as ChemPotDiagram2D } from './ChemPotDiagram2D.svelte';
3
3
  export { default as ChemPotDiagram3D } from './ChemPotDiagram3D.svelte';
4
4
  export { compute_chempot_async } from './async-compute.svelte';
5
5
  export { compute_chempot_diagram, get_ternary_combinations } from './compute';
6
+ export * from './export';
6
7
  export * from './types';
@@ -1,13 +1,3 @@
1
- export declare function get_pointer_coords(raw_event: unknown): {
2
- clientX: number;
3
- clientY: number;
4
- } | null;
5
- /** Convert pointer event to container-relative coords for tooltip placement. */
6
- export declare function get_hover_pointer(raw_event: unknown, container_rect: DOMRect | null | undefined): {
7
- x: number;
8
- y: number;
9
- } | null;
10
- /** Add hover pointer to an info object for tooltip placement. */
11
1
  export declare function with_hover_pointer<T extends {
12
2
  pointer?: {
13
3
  x: number;
@@ -2,7 +2,7 @@
2
2
  // Handles DOM events and Threlte/Three.js event wrappers (nativeEvent, srcEvent).
3
3
  const is_pointer_like_event = (event_val) => (typeof PointerEvent !== `undefined` && event_val instanceof PointerEvent) ||
4
4
  (typeof MouseEvent !== `undefined` && event_val instanceof MouseEvent);
5
- export function get_pointer_coords(raw_event) {
5
+ function get_pointer_coords(raw_event) {
6
6
  if (is_pointer_like_event(raw_event)) {
7
7
  return raw_event;
8
8
  }
@@ -22,8 +22,8 @@ export function get_pointer_coords(raw_event) {
22
22
  }
23
23
  return null;
24
24
  }
25
- /** Convert pointer event to container-relative coords for tooltip placement. */
26
- export function get_hover_pointer(raw_event, container_rect) {
25
+ // Convert pointer event to container-relative coords for tooltip placement.
26
+ function get_hover_pointer(raw_event, container_rect) {
27
27
  const pointer_event = get_pointer_coords(raw_event);
28
28
  if (!pointer_event)
29
29
  return null;
@@ -33,7 +33,7 @@ export function get_hover_pointer(raw_event, container_rect) {
33
33
  const y = pointer_event.clientY - offset_y + 4;
34
34
  return { x, y };
35
35
  }
36
- /** Add hover pointer to an info object for tooltip placement. */
36
+ // Add hover pointer to an info object for tooltip placement.
37
37
  export function with_hover_pointer(info, raw_event, container_rect) {
38
38
  const pointer = get_hover_pointer(raw_event, container_rect);
39
39
  return { ...info, pointer: pointer ?? undefined };
@@ -1,7 +1,7 @@
1
1
  import type { D3InterpolateName } from '../colors';
2
2
  import type { PhaseData } from '../convex-hull/types';
3
- import type { Point2D } from '../math';
4
- export type ChemPotLimits = Partial<Record<string, [number, number]>>;
3
+ import type { Point2D, Vec2 } from '../math';
4
+ export type ChemPotLimits = Partial<Record<string, Vec2>>;
5
5
  export type ChemPotColorMode = `none` | `energy` | `formation_energy` | `arity` | `entries`;
6
6
  export type ChemPotProjectionMode = `single` | `grid`;
7
7
  export interface ChemPotDiagramConfig {
@@ -31,7 +31,7 @@ export interface ChemPotDiagramData {
31
31
  min_entries: PhaseData[];
32
32
  hyperplanes: number[][];
33
33
  hyperplane_entries: PhaseData[];
34
- lims: [number, number][];
34
+ lims: Vec2[];
35
35
  }
36
36
  export interface ChemPotHoverInfoBase {
37
37
  formula: string;
@@ -79,8 +79,8 @@ export const PLOT_COLORS = [
79
79
  ];
80
80
  // calculate human-perceived brightness from RGB color
81
81
  export function luminance(clr) {
82
- const { r, g, b } = rgb(clr);
83
- return (0.299 * r + 0.587 * g + 0.114 * b) / 255; // https://stackoverflow.com/a/596243
82
+ const { r: red, g: green, b: blue } = rgb(clr);
83
+ return (0.299 * red + 0.587 * green + 0.114 * blue) / 255; // https://stackoverflow.com/a/596243
84
84
  }
85
85
  // get background color of passed DOM node, or recurse up the DOM tree if current node is transparent
86
86
  export function get_bg_color(elem, bg_color = null) {
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import Icon from '../Icon.svelte'
3
3
  import { get_alphabetical_formula } from './format'
4
- import { ELEM_SYMBOLS } from '../labels'
4
+ import { is_elem_symbol, type ElementSymbol } from '../element'
5
5
  import { tooltip } from 'svelte-multiselect/attachments'
6
6
  import type { HTMLAttributes } from 'svelte/elements'
7
7
  import type { FormulaSearchMode } from './index'
@@ -356,8 +356,10 @@
356
356
  try {
357
357
  const tokens = parse_formula_with_wildcards(sanitized_input)
358
358
  const explicit = tokens
359
- .filter((token) => token.element !== null)
360
- .map((token) => ({ element: token.element as string, count: token.count }))
359
+ .filter((token): token is { element: ElementSymbol; count: number } =>
360
+ token.element !== null
361
+ )
362
+ .map((token) => ({ element: token.element, count: token.count }))
361
363
  const wildcard_tokens = tokens.filter((token) => token.element === null)
362
364
 
363
365
  // Merge explicit element counts before sorting.
@@ -425,8 +427,7 @@
425
427
  const [element_part, constraint] = without_operator.split(`:`)
426
428
  const element = element_part.trim()
427
429
  const is_wildcard = element === `*`
428
- const is_valid_element = is_wildcard ||
429
- ELEM_SYMBOLS.includes(element as (typeof ELEM_SYMBOLS)[number])
430
+ const is_valid_element = is_wildcard || is_elem_symbol(element)
430
431
  const normalized_constraint = constraint?.trim() || null
431
432
  const is_valid = is_valid_element && (normalized_constraint === null ||
432
433
  is_valid_constraint(normalized_constraint))
@@ -75,12 +75,12 @@
75
75
 
76
76
  // Single element: full circle with no radial stroke line, label at center
77
77
  if (fraction === 1) {
78
- const r = outer_radius
78
+ const radius = outer_radius
79
79
  const ir = inner_radius_adjusted
80
80
  // Two semicircular arcs to form a full circle (avoids SVG 360° arc bug)
81
- const outer_arc = `M ${center} ${center - r} A ${r} ${r} 0 1 1 ${center} ${
82
- center + r
83
- } A ${r} ${r} 0 1 1 ${center} ${center - r} Z`
81
+ const outer_arc = `M ${center} ${center - radius} A ${radius} ${radius} 0 1 1 ${center} ${
82
+ center + radius
83
+ } A ${radius} ${radius} 0 1 1 ${center} ${center - radius} Z`
84
84
  const path = ir > 0
85
85
  ? `${outer_arc} M ${center} ${
86
86
  center - ir
@@ -101,7 +101,7 @@
101
101
  label_x: center,
102
102
  label_y: center,
103
103
  is_outside_slice: false,
104
- font_scale: get_chart_font_scale(2.6, label_text, r * 2),
104
+ font_scale: get_chart_font_scale(2.6, label_text, radius * 2),
105
105
  text_color: pick_contrast_color({ bg_color: color }),
106
106
  }
107
107
  }
@@ -1,6 +1,7 @@
1
1
  // Build arity -> chemical-system hierarchy data for the Sunburst component
2
2
  // (counterpart to pymatviz's chem_sys_sunburst).
3
- import { is_valid_element, parse_formula } from './parse';
3
+ import { is_elem_symbol } from '../element';
4
+ import { parse_formula } from './parse';
4
5
  const ARITY_NAMES = [
5
6
  ``,
6
7
  `unary`,
@@ -29,7 +30,7 @@ export function chem_sys_sunburst_data(entries) {
29
30
  let elements;
30
31
  if (entry.includes(`-`)) {
31
32
  elements = entry.split(`-`).map((el) => el.trim());
32
- if (!elements.every(is_valid_element))
33
+ if (!elements.every(is_elem_symbol))
33
34
  return null;
34
35
  }
35
36
  else {
@@ -1,5 +1,6 @@
1
1
  import { format_num } from '../labels';
2
- import { ELEMENT_ELECTRONEGATIVITY_MAP, is_valid_element, parse_composition } from './parse';
2
+ import { is_elem_symbol } from '../element';
3
+ import { ELEMENT_ELECTRONEGATIVITY_MAP, parse_composition } from './parse';
3
4
  // Extract composition from structure object
4
5
  const structure_to_composition = (structure) => {
5
6
  if (!structure.sites || !Array.isArray(structure.sites)) {
@@ -20,7 +21,7 @@ const structure_to_composition = (structure) => {
20
21
  const is_structure_like = (input) => `sites` in input || `lattice` in input;
21
22
  // Format composition into chemical formula string
22
23
  export const format_composition_formula = (composition, sort_fn, plain_text = false, delim = ` `, amount_format = `.3~s`) => {
23
- const symbols = Object.keys(composition).filter(is_valid_element);
24
+ const symbols = Object.keys(composition).filter(is_elem_symbol);
24
25
  return sort_fn(symbols)
25
26
  .filter((el) => composition[el] && composition[el] > 0)
26
27
  .map((el) => {
@@ -6,7 +6,6 @@ export declare const ATOMIC_WEIGHTS: Map<"S" | "K" | "B" | "H" | "He" | "Li" | "
6
6
  export declare const ELEMENT_ELECTRONEGATIVITY_MAP: Map<"S" | "K" | "B" | "H" | "He" | "Li" | "Be" | "C" | "N" | "O" | "F" | "Ne" | "Na" | "Mg" | "Al" | "Si" | "P" | "Cl" | "Ar" | "Ca" | "Sc" | "Ti" | "V" | "Cr" | "Mn" | "Fe" | "Co" | "Ni" | "Cu" | "Zn" | "Ga" | "Ge" | "As" | "Se" | "Br" | "Kr" | "Rb" | "Sr" | "Y" | "Zr" | "Nb" | "Mo" | "Tc" | "Ru" | "Rh" | "Pd" | "Ag" | "Cd" | "In" | "Sn" | "Sb" | "Te" | "I" | "Xe" | "Cs" | "Ba" | "La" | "Ce" | "Pr" | "Nd" | "Pm" | "Sm" | "Eu" | "Gd" | "Tb" | "Dy" | "Ho" | "Er" | "Tm" | "Yb" | "Lu" | "Hf" | "Ta" | "W" | "Re" | "Os" | "Ir" | "Pt" | "Au" | "Hg" | "Tl" | "Pb" | "Bi" | "Po" | "At" | "Rn" | "Fr" | "Ra" | "Ac" | "Th" | "Pa" | "U" | "Np" | "Pu" | "Am" | "Cm" | "Bk" | "Cf" | "Es" | "Fm" | "Md" | "No" | "Lr" | "Rf" | "Db" | "Sg" | "Bh" | "Hs" | "Mt" | "Ds" | "Rg" | "Cn" | "Nh" | "Fl" | "Mc" | "Lv" | "Ts" | "Og", number>;
7
7
  export declare const ELEM_NAME_TO_SYMBOL: Record<string, ElementSymbol>;
8
8
  export declare const ELEM_SYMBOL_TO_NAME: Partial<Record<ElementSymbol, string>>;
9
- export declare const is_valid_element: (sym: string) => sym is ElementSymbol;
10
9
  export declare const atomic_num_to_symbols: (atomic_composition: Record<number, number>) => CompositionType;
11
10
  export declare const atomic_symbol_to_num: (symbol_composition: CompositionType) => Record<number, number>;
12
11
  export declare const parse_formula: (formula: string) => CompositionType;