matterviz 0.3.6 → 0.4.0

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 (926) hide show
  1. package/dist/EmptyState.svelte.d.ts +9 -0
  2. package/dist/FilePicker.svelte +360 -0
  3. package/dist/FilePicker.svelte.d.ts +17 -0
  4. package/dist/Icon.svelte +44 -0
  5. package/dist/Icon.svelte.d.ts +13 -0
  6. package/dist/MillerIndexInput.svelte +66 -0
  7. package/dist/MillerIndexInput.svelte.d.ts +7 -0
  8. package/dist/api/mp.d.ts +6 -0
  9. package/dist/api/mp.js +22 -0
  10. package/dist/api/optimade.d.ts +45 -0
  11. package/dist/api/optimade.js +141 -0
  12. package/dist/app.css +244 -0
  13. package/dist/brillouin/BrillouinZone.svelte +554 -0
  14. package/dist/brillouin/BrillouinZone.svelte.d.ts +84 -0
  15. package/dist/brillouin/BrillouinZoneControls.svelte +144 -0
  16. package/dist/brillouin/BrillouinZoneControls.svelte.d.ts +17 -0
  17. package/dist/brillouin/BrillouinZoneExportPane.svelte +146 -0
  18. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +15 -0
  19. package/dist/brillouin/BrillouinZoneInfoPane.svelte +146 -0
  20. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +13 -0
  21. package/dist/brillouin/BrillouinZoneScene.svelte +522 -0
  22. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +49 -0
  23. package/dist/brillouin/BrillouinZoneTooltip.svelte +83 -0
  24. package/dist/brillouin/BrillouinZoneTooltip.svelte.d.ts +8 -0
  25. package/dist/brillouin/compute.d.ts +17 -0
  26. package/dist/brillouin/compute.js +422 -0
  27. package/dist/brillouin/index.d.ts +8 -0
  28. package/dist/brillouin/index.js +7 -0
  29. package/dist/brillouin/types.d.ts +43 -0
  30. package/dist/brillouin/types.js +1 -0
  31. package/dist/chempot-diagram/ChemPotDiagram.svelte +328 -0
  32. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +13 -0
  33. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +843 -0
  34. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +16 -0
  35. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +3191 -0
  36. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +16 -0
  37. package/dist/chempot-diagram/ChemPotScene3D.svelte.d.ts +7 -0
  38. package/dist/chempot-diagram/async-compute.svelte.d.ts +3 -0
  39. package/dist/chempot-diagram/async-compute.svelte.js +80 -0
  40. package/dist/chempot-diagram/chempot-worker.d.ts +1 -0
  41. package/dist/chempot-diagram/chempot-worker.js +12 -0
  42. package/dist/chempot-diagram/color.d.ts +10 -0
  43. package/dist/chempot-diagram/color.js +32 -0
  44. package/dist/chempot-diagram/compute.d.ts +48 -0
  45. package/dist/chempot-diagram/compute.js +804 -0
  46. package/dist/chempot-diagram/index.d.ts +6 -0
  47. package/dist/chempot-diagram/index.js +6 -0
  48. package/dist/chempot-diagram/pointer.d.ts +16 -0
  49. package/dist/chempot-diagram/pointer.js +40 -0
  50. package/dist/chempot-diagram/temperature.d.ts +15 -0
  51. package/dist/chempot-diagram/temperature.js +34 -0
  52. package/dist/chempot-diagram/types.d.ts +81 -0
  53. package/dist/chempot-diagram/types.js +28 -0
  54. package/dist/colors/index.d.ts +47 -0
  55. package/dist/colors/index.js +204 -0
  56. package/dist/composition/BarChart.svelte +297 -0
  57. package/dist/composition/BarChart.svelte.d.ts +39 -0
  58. package/dist/composition/BubbleChart.svelte +218 -0
  59. package/dist/composition/BubbleChart.svelte.d.ts +28 -0
  60. package/dist/composition/Composition.svelte +165 -0
  61. package/dist/composition/Composition.svelte.d.ts +15 -0
  62. package/dist/composition/Formula.svelte +268 -0
  63. package/dist/composition/Formula.svelte.d.ts +19 -0
  64. package/dist/composition/FormulaFilter.svelte +1263 -0
  65. package/dist/composition/FormulaFilter.svelte.d.ts +51 -0
  66. package/dist/composition/PieChart.svelte +324 -0
  67. package/dist/composition/PieChart.svelte.d.ts +37 -0
  68. package/dist/composition/chem-sys.d.ts +8 -0
  69. package/dist/composition/chem-sys.js +85 -0
  70. package/dist/composition/format.d.ts +15 -0
  71. package/dist/composition/format.js +111 -0
  72. package/dist/composition/index.d.ts +21 -0
  73. package/dist/composition/index.js +15 -0
  74. package/dist/composition/parse.d.ts +56 -0
  75. package/dist/composition/parse.js +486 -0
  76. package/dist/constants.d.ts +29 -0
  77. package/dist/constants.js +99 -0
  78. package/dist/controls.d.ts +14 -0
  79. package/dist/controls.js +30 -0
  80. package/dist/convex-hull/ConvexHull.svelte +157 -0
  81. package/dist/convex-hull/ConvexHull.svelte.d.ts +13 -0
  82. package/dist/convex-hull/ConvexHull2D.svelte +827 -0
  83. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +11 -0
  84. package/dist/convex-hull/ConvexHull3D.svelte +1801 -0
  85. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +8 -0
  86. package/dist/convex-hull/ConvexHull4D.svelte +1394 -0
  87. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +8 -0
  88. package/dist/convex-hull/ConvexHullControls.svelte +535 -0
  89. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +48 -0
  90. package/dist/convex-hull/ConvexHullInfoPane.svelte +125 -0
  91. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +20 -0
  92. package/dist/convex-hull/ConvexHullStats.svelte +929 -0
  93. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +17 -0
  94. package/dist/convex-hull/ConvexHullTooltip.svelte +131 -0
  95. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +33 -0
  96. package/dist/convex-hull/GasPressureControls.svelte +247 -0
  97. package/dist/convex-hull/GasPressureControls.svelte.d.ts +11 -0
  98. package/dist/convex-hull/StructurePopup.svelte +151 -0
  99. package/dist/convex-hull/StructurePopup.svelte.d.ts +18 -0
  100. package/dist/convex-hull/TemperatureSlider.svelte +140 -0
  101. package/dist/convex-hull/TemperatureSlider.svelte.d.ts +8 -0
  102. package/dist/convex-hull/barycentric-coords.d.ts +18 -0
  103. package/dist/convex-hull/barycentric-coords.js +182 -0
  104. package/dist/convex-hull/demo-temperature.d.ts +6 -0
  105. package/dist/convex-hull/demo-temperature.js +38 -0
  106. package/dist/convex-hull/gas-thermodynamics.d.ts +16 -0
  107. package/dist/convex-hull/gas-thermodynamics.js +306 -0
  108. package/dist/convex-hull/helpers.d.ts +117 -0
  109. package/dist/convex-hull/helpers.js +718 -0
  110. package/dist/convex-hull/index.d.ts +119 -0
  111. package/dist/convex-hull/index.js +58 -0
  112. package/dist/convex-hull/thermodynamics.d.ts +67 -0
  113. package/dist/convex-hull/thermodynamics.js +1757 -0
  114. package/dist/convex-hull/types.d.ts +162 -0
  115. package/dist/convex-hull/types.js +36 -0
  116. package/dist/coordination/CoordinationBarPlot.svelte +311 -0
  117. package/dist/coordination/CoordinationBarPlot.svelte.d.ts +30 -0
  118. package/dist/coordination/calc-coordination.d.ts +15 -0
  119. package/dist/coordination/calc-coordination.js +63 -0
  120. package/dist/coordination/index.d.ts +8 -0
  121. package/dist/coordination/index.js +7 -0
  122. package/dist/effects.svelte.d.ts +12 -0
  123. package/dist/effects.svelte.js +37 -0
  124. package/dist/element/BohrAtom.svelte.d.ts +20 -0
  125. package/dist/element/ElementHeading.svelte +26 -0
  126. package/dist/element/ElementHeading.svelte.d.ts +8 -0
  127. package/dist/element/ElementPhoto.svelte +57 -0
  128. package/dist/element/ElementPhoto.svelte.d.ts +9 -0
  129. package/dist/element/ElementStats.svelte +80 -0
  130. package/dist/element/ElementStats.svelte.d.ts +8 -0
  131. package/dist/element/ElementTile.svelte +484 -0
  132. package/dist/element/ElementTile.svelte.d.ts +29 -0
  133. package/dist/element/Nucleus.svelte.d.ts +17 -0
  134. package/dist/element/data.d.ts +2 -0
  135. package/dist/element/data.js +2 -0
  136. package/dist/element/index.d.ts +8 -0
  137. package/dist/element/index.js +7 -0
  138. package/dist/element/types.d.ts +57 -0
  139. package/dist/element/types.js +1 -0
  140. package/dist/feedback/ClickFeedback.svelte +58 -0
  141. package/dist/feedback/ClickFeedback.svelte.d.ts +12 -0
  142. package/dist/feedback/DragOverlay.svelte +42 -0
  143. package/dist/feedback/DragOverlay.svelte.d.ts +7 -0
  144. package/dist/feedback/Spinner.svelte.d.ts +7 -0
  145. package/dist/feedback/StatusMessage.svelte.d.ts +9 -0
  146. package/dist/feedback/index.d.ts +4 -0
  147. package/dist/feedback/index.js +4 -0
  148. package/dist/fermi-surface/FermiSlice.svelte +197 -0
  149. package/dist/fermi-surface/FermiSlice.svelte.d.ts +24 -0
  150. package/dist/fermi-surface/FermiSurface.svelte +606 -0
  151. package/dist/fermi-surface/FermiSurface.svelte.d.ts +83 -0
  152. package/dist/fermi-surface/FermiSurfaceControls.svelte +448 -0
  153. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +35 -0
  154. package/dist/fermi-surface/FermiSurfaceScene.svelte +797 -0
  155. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +50 -0
  156. package/dist/fermi-surface/FermiSurfaceTooltip.svelte +85 -0
  157. package/dist/fermi-surface/FermiSurfaceTooltip.svelte.d.ts +8 -0
  158. package/dist/fermi-surface/compute.d.ts +5 -0
  159. package/dist/fermi-surface/compute.js +538 -0
  160. package/dist/fermi-surface/constants.d.ts +9 -0
  161. package/dist/fermi-surface/constants.js +27 -0
  162. package/dist/fermi-surface/export.d.ts +5 -0
  163. package/dist/fermi-surface/export.js +51 -0
  164. package/dist/fermi-surface/index.d.ts +12 -0
  165. package/dist/fermi-surface/index.js +13 -0
  166. package/dist/fermi-surface/marching-cubes.d.ts +2 -0
  167. package/dist/fermi-surface/marching-cubes.js +2 -0
  168. package/dist/fermi-surface/parse.d.ts +2 -0
  169. package/dist/fermi-surface/parse.js +494 -0
  170. package/dist/fermi-surface/symmetry.d.ts +3 -0
  171. package/dist/fermi-surface/symmetry.js +46 -0
  172. package/dist/fermi-surface/types.d.ts +111 -0
  173. package/dist/fermi-surface/types.js +4 -0
  174. package/dist/heatmap-matrix/HeatmapMatrix.svelte +1547 -0
  175. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +110 -0
  176. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +225 -0
  177. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +30 -0
  178. package/dist/heatmap-matrix/index.d.ts +53 -0
  179. package/dist/heatmap-matrix/index.js +100 -0
  180. package/dist/heatmap-matrix/shared.d.ts +2 -0
  181. package/dist/heatmap-matrix/shared.js +4 -0
  182. package/dist/icons.d.ts +569 -0
  183. package/dist/icons.js +648 -0
  184. package/dist/index.d.ts +39 -0
  185. package/dist/index.js +39 -0
  186. package/dist/io/decompress.d.ts +11 -0
  187. package/dist/io/decompress.js +76 -0
  188. package/dist/io/export.d.ts +16 -0
  189. package/dist/io/export.js +338 -0
  190. package/dist/io/fetch.d.ts +5 -0
  191. package/dist/io/fetch.js +43 -0
  192. package/dist/io/file-drop.d.ts +7 -0
  193. package/dist/io/file-drop.js +42 -0
  194. package/dist/io/index.d.ts +7 -0
  195. package/dist/io/index.js +6 -0
  196. package/dist/io/is-binary.d.ts +1 -0
  197. package/dist/io/is-binary.js +20 -0
  198. package/dist/io/types.d.ts +8 -0
  199. package/dist/io/types.js +1 -0
  200. package/dist/io/url-drop.d.ts +2 -0
  201. package/dist/io/url-drop.js +154 -0
  202. package/dist/isosurface/Isosurface.svelte +285 -0
  203. package/dist/isosurface/Isosurface.svelte.d.ts +8 -0
  204. package/dist/isosurface/IsosurfaceControls.svelte +277 -0
  205. package/dist/isosurface/IsosurfaceControls.svelte.d.ts +9 -0
  206. package/dist/isosurface/index.d.ts +5 -0
  207. package/dist/isosurface/index.js +6 -0
  208. package/dist/isosurface/parse.d.ts +6 -0
  209. package/dist/isosurface/parse.js +552 -0
  210. package/dist/isosurface/slice.d.ts +11 -0
  211. package/dist/isosurface/slice.js +141 -0
  212. package/dist/isosurface/types.d.ts +56 -0
  213. package/dist/isosurface/types.js +227 -0
  214. package/dist/keyboard.d.ts +3 -0
  215. package/dist/keyboard.js +23 -0
  216. package/dist/labels.d.ts +53 -0
  217. package/dist/labels.js +278 -0
  218. package/dist/layout/FullscreenToggle.svelte +50 -0
  219. package/dist/layout/FullscreenToggle.svelte.d.ts +7 -0
  220. package/dist/layout/InfoCard.svelte +120 -0
  221. package/dist/layout/InfoCard.svelte.d.ts +21 -0
  222. package/dist/layout/InfoTag.svelte +185 -0
  223. package/dist/layout/InfoTag.svelte.d.ts +19 -0
  224. package/dist/layout/PropertyFilter.svelte +247 -0
  225. package/dist/layout/PropertyFilter.svelte.d.ts +24 -0
  226. package/dist/layout/SettingsSection.svelte +148 -0
  227. package/dist/layout/SettingsSection.svelte.d.ts +17 -0
  228. package/dist/layout/SubpageGrid.svelte +82 -0
  229. package/dist/layout/SubpageGrid.svelte.d.ts +14 -0
  230. package/dist/layout/fullscreen.d.ts +9 -0
  231. package/dist/layout/fullscreen.js +53 -0
  232. package/dist/layout/index.d.ts +10 -0
  233. package/dist/layout/index.js +8 -0
  234. package/dist/layout/json-tree/JsonNode.svelte +548 -0
  235. package/dist/layout/json-tree/JsonNode.svelte.d.ts +11 -0
  236. package/dist/layout/json-tree/JsonTree.svelte +1230 -0
  237. package/dist/layout/json-tree/JsonTree.svelte.d.ts +6 -0
  238. package/dist/layout/json-tree/JsonValue.svelte.d.ts +9 -0
  239. package/dist/layout/json-tree/index.d.ts +3 -0
  240. package/dist/layout/json-tree/index.js +3 -0
  241. package/dist/layout/json-tree/types.d.ts +74 -0
  242. package/dist/layout/json-tree/types.js +2 -0
  243. package/dist/layout/json-tree/utils.d.ts +29 -0
  244. package/dist/layout/json-tree/utils.js +642 -0
  245. package/dist/marching-cubes.d.ts +14 -0
  246. package/dist/marching-cubes.js +535 -0
  247. package/dist/math.d.ts +105 -0
  248. package/dist/math.js +920 -0
  249. package/dist/overlays/ContextMenu.svelte +162 -0
  250. package/dist/overlays/ContextMenu.svelte.d.ts +25 -0
  251. package/dist/overlays/CopyButton.svelte +45 -0
  252. package/dist/overlays/CopyButton.svelte.d.ts +8 -0
  253. package/dist/overlays/DragControlTab.svelte +98 -0
  254. package/dist/overlays/DragControlTab.svelte.d.ts +8 -0
  255. package/dist/overlays/DraggablePane.svelte +487 -0
  256. package/dist/overlays/DraggablePane.svelte.d.ts +36 -0
  257. package/dist/overlays/InfoPaneCards.svelte +149 -0
  258. package/dist/overlays/InfoPaneCards.svelte.d.ts +22 -0
  259. package/dist/overlays/index.d.ts +3 -0
  260. package/dist/overlays/index.js +3 -0
  261. package/dist/periodic-table/PeriodicTable.svelte +480 -0
  262. package/dist/periodic-table/PeriodicTable.svelte.d.ts +55 -0
  263. package/dist/periodic-table/PeriodicTableControls.svelte +557 -0
  264. package/dist/periodic-table/PeriodicTableControls.svelte.d.ts +24 -0
  265. package/dist/periodic-table/PropertySelect.svelte +38 -0
  266. package/dist/periodic-table/PropertySelect.svelte.d.ts +13 -0
  267. package/dist/periodic-table/TableInset.svelte.d.ts +9 -0
  268. package/dist/periodic-table/index.d.ts +10 -0
  269. package/dist/periodic-table/index.js +4 -0
  270. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +1092 -0
  271. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +44 -0
  272. package/dist/phase-diagram/PhaseDiagramControls.svelte +444 -0
  273. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +30 -0
  274. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +127 -0
  275. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +15 -0
  276. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +184 -0
  277. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +19 -0
  278. package/dist/phase-diagram/PhaseDiagramTooltip.svelte +391 -0
  279. package/dist/phase-diagram/PhaseDiagramTooltip.svelte.d.ts +16 -0
  280. package/dist/phase-diagram/TdbInfoPanel.svelte +203 -0
  281. package/dist/phase-diagram/TdbInfoPanel.svelte.d.ts +12 -0
  282. package/dist/phase-diagram/build-diagram.d.ts +11 -0
  283. package/dist/phase-diagram/build-diagram.js +160 -0
  284. package/dist/phase-diagram/colors.d.ts +35 -0
  285. package/dist/phase-diagram/colors.js +51 -0
  286. package/dist/phase-diagram/diagram-input.d.ts +29 -0
  287. package/dist/phase-diagram/diagram-input.js +3 -0
  288. package/dist/phase-diagram/index.d.ts +13 -0
  289. package/dist/phase-diagram/index.js +11 -0
  290. package/dist/phase-diagram/parse.d.ts +55 -0
  291. package/dist/phase-diagram/parse.js +273 -0
  292. package/dist/phase-diagram/svg-to-diagram.d.ts +2 -0
  293. package/dist/phase-diagram/svg-to-diagram.js +867 -0
  294. package/dist/phase-diagram/types.d.ts +93 -0
  295. package/dist/phase-diagram/types.js +1 -0
  296. package/dist/phase-diagram/utils.d.ts +118 -0
  297. package/dist/phase-diagram/utils.js +600 -0
  298. package/dist/plot/bar/BarPlot.svelte +1755 -0
  299. package/dist/plot/bar/BarPlot.svelte.d.ts +84 -0
  300. package/dist/plot/bar/BarPlotControls.svelte +67 -0
  301. package/dist/plot/bar/BarPlotControls.svelte.d.ts +18 -0
  302. package/dist/plot/bar/SpacegroupBarPlot.svelte +293 -0
  303. package/dist/plot/bar/SpacegroupBarPlot.svelte.d.ts +9 -0
  304. package/dist/plot/bar/data.d.ts +40 -0
  305. package/dist/plot/bar/data.js +154 -0
  306. package/dist/plot/bar/geometry.d.ts +39 -0
  307. package/dist/plot/bar/geometry.js +60 -0
  308. package/dist/plot/bar/index.d.ts +3 -0
  309. package/dist/plot/bar/index.js +3 -0
  310. package/dist/plot/box/BoxPlot.svelte +1462 -0
  311. package/dist/plot/box/BoxPlot.svelte.d.ts +94 -0
  312. package/dist/plot/box/BoxPlotControls.svelte +109 -0
  313. package/dist/plot/box/BoxPlotControls.svelte.d.ts +19 -0
  314. package/dist/plot/box/Violin.svelte +14 -0
  315. package/dist/plot/box/Violin.svelte.d.ts +70 -0
  316. package/dist/plot/box/box-plot.d.ts +55 -0
  317. package/dist/plot/box/box-plot.js +126 -0
  318. package/dist/plot/box/index.d.ts +5 -0
  319. package/dist/plot/box/index.js +5 -0
  320. package/dist/plot/box/kde.d.ts +16 -0
  321. package/dist/plot/box/kde.js +160 -0
  322. package/dist/plot/box/quantile.d.ts +3 -0
  323. package/dist/plot/box/quantile.js +53 -0
  324. package/dist/plot/core/auto-place.d.ts +43 -0
  325. package/dist/plot/core/auto-place.js +122 -0
  326. package/dist/plot/core/axis-utils.d.ts +46 -0
  327. package/dist/plot/core/axis-utils.js +110 -0
  328. package/dist/plot/core/components/AxisLabel.svelte +51 -0
  329. package/dist/plot/core/components/AxisLabel.svelte.d.ts +16 -0
  330. package/dist/plot/core/components/ColorBar.svelte +724 -0
  331. package/dist/plot/core/components/ColorBar.svelte.d.ts +31 -0
  332. package/dist/plot/core/components/ColorScaleSelect.svelte +55 -0
  333. package/dist/plot/core/components/ColorScaleSelect.svelte.d.ts +15 -0
  334. package/dist/plot/core/components/ControlPane.svelte +46 -0
  335. package/dist/plot/core/components/ControlPane.svelte.d.ts +13 -0
  336. package/dist/plot/core/components/FillArea.svelte +234 -0
  337. package/dist/plot/core/components/FillArea.svelte.d.ts +21 -0
  338. package/dist/plot/core/components/InteractiveAxisLabel.svelte +96 -0
  339. package/dist/plot/core/components/InteractiveAxisLabel.svelte.d.ts +14 -0
  340. package/dist/plot/core/components/Line.svelte +101 -0
  341. package/dist/plot/core/components/Line.svelte.d.ts +15 -0
  342. package/dist/plot/core/components/PlotAxis.svelte +171 -0
  343. package/dist/plot/core/components/PlotAxis.svelte.d.ts +25 -0
  344. package/dist/plot/core/components/PlotControls.svelte +525 -0
  345. package/dist/plot/core/components/PlotControls.svelte.d.ts +4 -0
  346. package/dist/plot/core/components/PlotLegend.svelte +580 -0
  347. package/dist/plot/core/components/PlotLegend.svelte.d.ts +30 -0
  348. package/dist/plot/core/components/PlotTooltip.svelte +83 -0
  349. package/dist/plot/core/components/PlotTooltip.svelte.d.ts +25 -0
  350. package/dist/plot/core/components/PortalSelect.svelte +257 -0
  351. package/dist/plot/core/components/PortalSelect.svelte.d.ts +16 -0
  352. package/dist/plot/core/components/ReferenceLine.svelte +204 -0
  353. package/dist/plot/core/components/ReferenceLine.svelte.d.ts +20 -0
  354. package/dist/plot/core/components/ReferenceLine3D.svelte +156 -0
  355. package/dist/plot/core/components/ReferenceLine3D.svelte.d.ts +14 -0
  356. package/dist/plot/core/components/ReferencePlane.svelte +175 -0
  357. package/dist/plot/core/components/ReferencePlane.svelte.d.ts +14 -0
  358. package/dist/plot/core/components/ZeroLines.svelte +97 -0
  359. package/dist/plot/core/components/ZeroLines.svelte.d.ts +33 -0
  360. package/dist/plot/core/components/ZoomRect.svelte +23 -0
  361. package/dist/plot/core/components/ZoomRect.svelte.d.ts +8 -0
  362. package/dist/plot/core/components/index.d.ts +17 -0
  363. package/dist/plot/core/components/index.js +17 -0
  364. package/dist/plot/core/data-cleaning.d.ts +107 -0
  365. package/dist/plot/core/data-cleaning.js +853 -0
  366. package/dist/plot/core/data-transform.d.ts +16 -0
  367. package/dist/plot/core/data-transform.js +45 -0
  368. package/dist/plot/core/fill-utils.d.ts +33 -0
  369. package/dist/plot/core/fill-utils.js +388 -0
  370. package/dist/plot/core/hover-lock.svelte.d.ts +14 -0
  371. package/dist/plot/core/hover-lock.svelte.js +45 -0
  372. package/dist/plot/core/index.d.ts +10 -0
  373. package/dist/plot/core/index.js +11 -0
  374. package/dist/plot/core/interactions.d.ts +35 -0
  375. package/dist/plot/core/interactions.js +195 -0
  376. package/dist/plot/core/layout.d.ts +79 -0
  377. package/dist/plot/core/layout.js +281 -0
  378. package/dist/plot/core/reference-line.d.ts +60 -0
  379. package/dist/plot/core/reference-line.js +301 -0
  380. package/dist/plot/core/scales.d.ts +48 -0
  381. package/dist/plot/core/scales.js +480 -0
  382. package/dist/plot/core/svg.d.ts +2 -0
  383. package/dist/plot/core/svg.js +41 -0
  384. package/dist/plot/core/types.d.ts +771 -0
  385. package/dist/plot/core/types.js +99 -0
  386. package/dist/plot/core/utils/label-placement.d.ts +68 -0
  387. package/dist/plot/core/utils/label-placement.js +326 -0
  388. package/dist/plot/core/utils/series-visibility.d.ts +26 -0
  389. package/dist/plot/core/utils/series-visibility.js +112 -0
  390. package/dist/plot/core/utils.d.ts +11 -0
  391. package/dist/plot/core/utils.js +27 -0
  392. package/dist/plot/histogram/Histogram.svelte +1418 -0
  393. package/dist/plot/histogram/Histogram.svelte.d.ts +50 -0
  394. package/dist/plot/histogram/HistogramControls.svelte +212 -0
  395. package/dist/plot/histogram/HistogramControls.svelte.d.ts +22 -0
  396. package/dist/plot/histogram/index.d.ts +2 -0
  397. package/dist/plot/histogram/index.js +2 -0
  398. package/dist/plot/index.d.ts +8 -0
  399. package/dist/plot/index.js +10 -0
  400. package/dist/plot/sankey/Sankey.svelte +700 -0
  401. package/dist/plot/sankey/Sankey.svelte.d.ts +74 -0
  402. package/dist/plot/sankey/SankeyControls.svelte +98 -0
  403. package/dist/plot/sankey/SankeyControls.svelte.d.ts +19 -0
  404. package/dist/plot/sankey/index.d.ts +4 -0
  405. package/dist/plot/sankey/index.js +3 -0
  406. package/dist/plot/sankey/sankey-types.d.ts +42 -0
  407. package/dist/plot/sankey/sankey-types.js +4 -0
  408. package/dist/plot/sankey/sankey.d.ts +52 -0
  409. package/dist/plot/sankey/sankey.js +187 -0
  410. package/dist/plot/scatter/BinnedScatterPlot.svelte +1116 -0
  411. package/dist/plot/scatter/BinnedScatterPlot.svelte.d.ts +66 -0
  412. package/dist/plot/scatter/ElementScatter.svelte +63 -0
  413. package/dist/plot/scatter/ElementScatter.svelte.d.ts +14 -0
  414. package/dist/plot/scatter/ScatterPlot.svelte +2357 -0
  415. package/dist/plot/scatter/ScatterPlot.svelte.d.ts +96 -0
  416. package/dist/plot/scatter/ScatterPlotControls.svelte +307 -0
  417. package/dist/plot/scatter/ScatterPlotControls.svelte.d.ts +17 -0
  418. package/dist/plot/scatter/ScatterPoint.svelte +182 -0
  419. package/dist/plot/scatter/ScatterPoint.svelte.d.ts +22 -0
  420. package/dist/plot/scatter/adaptive-density.d.ts +79 -0
  421. package/dist/plot/scatter/adaptive-density.js +217 -0
  422. package/dist/plot/scatter/binned-scatter-types.d.ts +59 -0
  423. package/dist/plot/scatter/binned-scatter-types.js +1 -0
  424. package/dist/plot/scatter/index.d.ts +7 -0
  425. package/dist/plot/scatter/index.js +5 -0
  426. package/dist/plot/scatter/scatter-data.d.ts +19 -0
  427. package/dist/plot/scatter/scatter-data.js +212 -0
  428. package/dist/plot/scatter-3d/ScatterPlot3D.svelte +531 -0
  429. package/dist/plot/scatter-3d/ScatterPlot3D.svelte.d.ts +95 -0
  430. package/dist/plot/scatter-3d/ScatterPlot3DControls.svelte +438 -0
  431. package/dist/plot/scatter-3d/ScatterPlot3DControls.svelte.d.ts +20 -0
  432. package/dist/plot/scatter-3d/ScatterPlot3DScene.svelte +912 -0
  433. package/dist/plot/scatter-3d/ScatterPlot3DScene.svelte.d.ts +74 -0
  434. package/dist/plot/scatter-3d/Surface3D.svelte +197 -0
  435. package/dist/plot/scatter-3d/Surface3D.svelte.d.ts +13 -0
  436. package/dist/plot/scatter-3d/index.d.ts +4 -0
  437. package/dist/plot/scatter-3d/index.js +4 -0
  438. package/dist/plot/sunburst/Sunburst.svelte +1045 -0
  439. package/dist/plot/sunburst/Sunburst.svelte.d.ts +96 -0
  440. package/dist/plot/sunburst/SunburstControls.svelte +200 -0
  441. package/dist/plot/sunburst/SunburstControls.svelte.d.ts +26 -0
  442. package/dist/plot/sunburst/index.d.ts +4 -0
  443. package/dist/plot/sunburst/index.js +4 -0
  444. package/dist/plot/sunburst/render.d.ts +34 -0
  445. package/dist/plot/sunburst/render.js +122 -0
  446. package/dist/plot/sunburst/sunburst.d.ts +62 -0
  447. package/dist/plot/sunburst/sunburst.js +266 -0
  448. package/dist/rdf/RdfPlot.svelte +248 -0
  449. package/dist/rdf/RdfPlot.svelte.d.ts +27 -0
  450. package/dist/rdf/calc-rdf.d.ts +4 -0
  451. package/dist/rdf/calc-rdf.js +98 -0
  452. package/dist/rdf/index.d.ts +23 -0
  453. package/dist/rdf/index.js +2 -0
  454. package/dist/sanitize.d.ts +6 -0
  455. package/dist/sanitize.js +116 -0
  456. package/dist/settings.d.ts +319 -0
  457. package/dist/settings.js +1394 -0
  458. package/dist/spectral/Bands.svelte +1050 -0
  459. package/dist/spectral/Bands.svelte.d.ts +39 -0
  460. package/dist/spectral/BandsAndDos.svelte +134 -0
  461. package/dist/spectral/BandsAndDos.svelte.d.ts +18 -0
  462. package/dist/spectral/BrillouinBandsDos.svelte +264 -0
  463. package/dist/spectral/BrillouinBandsDos.svelte.d.ts +20 -0
  464. package/dist/spectral/Dos.svelte +688 -0
  465. package/dist/spectral/Dos.svelte.d.ts +29 -0
  466. package/dist/spectral/helpers.d.ts +121 -0
  467. package/dist/spectral/helpers.js +1098 -0
  468. package/dist/spectral/index.d.ts +6 -0
  469. package/dist/spectral/index.js +6 -0
  470. package/dist/spectral/types.d.ts +84 -0
  471. package/dist/spectral/types.js +2 -0
  472. package/dist/state.svelte.d.ts +25 -0
  473. package/dist/state.svelte.js +45 -0
  474. package/dist/structure/Arrow.svelte +72 -0
  475. package/dist/structure/Arrow.svelte.d.ts +15 -0
  476. package/dist/structure/AtomLegend.svelte +814 -0
  477. package/dist/structure/AtomLegend.svelte.d.ts +35 -0
  478. package/dist/structure/Bond.svelte +140 -0
  479. package/dist/structure/Bond.svelte.d.ts +9 -0
  480. package/dist/structure/CanvasTooltip.svelte +33 -0
  481. package/dist/structure/CanvasTooltip.svelte.d.ts +12 -0
  482. package/dist/structure/CellSelect.svelte +348 -0
  483. package/dist/structure/CellSelect.svelte.d.ts +13 -0
  484. package/dist/structure/Cylinder.svelte +49 -0
  485. package/dist/structure/Cylinder.svelte.d.ts +13 -0
  486. package/dist/structure/Lattice.svelte +196 -0
  487. package/dist/structure/Lattice.svelte.d.ts +17 -0
  488. package/dist/structure/Structure.svelte +2254 -0
  489. package/dist/structure/Structure.svelte.d.ts +89 -0
  490. package/dist/structure/StructureControls.svelte +1273 -0
  491. package/dist/structure/StructureControls.svelte.d.ts +31 -0
  492. package/dist/structure/StructureExportPane.svelte +252 -0
  493. package/dist/structure/StructureExportPane.svelte.d.ts +17 -0
  494. package/dist/structure/StructureInfoPane.svelte +736 -0
  495. package/dist/structure/StructureInfoPane.svelte.d.ts +19 -0
  496. package/dist/structure/StructureScene.svelte +2256 -0
  497. package/dist/structure/StructureScene.svelte.d.ts +111 -0
  498. package/dist/structure/atom-properties.d.ts +37 -0
  499. package/dist/structure/atom-properties.js +200 -0
  500. package/dist/structure/bond-order-perception.d.ts +13 -0
  501. package/dist/structure/bond-order-perception.js +384 -0
  502. package/dist/structure/bonding.d.ts +69 -0
  503. package/dist/structure/bonding.js +724 -0
  504. package/dist/structure/export.d.ts +20 -0
  505. package/dist/structure/export.js +731 -0
  506. package/dist/structure/index.d.ts +124 -0
  507. package/dist/structure/index.js +167 -0
  508. package/dist/structure/label-placement.d.ts +14 -0
  509. package/dist/structure/label-placement.js +72 -0
  510. package/dist/structure/measure.d.ts +7 -0
  511. package/dist/structure/measure.js +30 -0
  512. package/dist/structure/parse.d.ts +66 -0
  513. package/dist/structure/parse.js +1410 -0
  514. package/dist/structure/partial-occupancy.d.ts +25 -0
  515. package/dist/structure/partial-occupancy.js +99 -0
  516. package/dist/structure/pbc.d.ts +9 -0
  517. package/dist/structure/pbc.js +127 -0
  518. package/dist/structure/supercell.d.ts +8 -0
  519. package/dist/structure/supercell.js +170 -0
  520. package/dist/structure/validation.d.ts +2 -0
  521. package/dist/structure/validation.js +10 -0
  522. package/dist/symmetry/SymmetryStats.svelte +226 -0
  523. package/dist/symmetry/SymmetryStats.svelte.d.ts +21 -0
  524. package/dist/symmetry/WyckoffTable.svelte +120 -0
  525. package/dist/symmetry/WyckoffTable.svelte.d.ts +11 -0
  526. package/dist/symmetry/cell-transform.d.ts +12 -0
  527. package/dist/symmetry/cell-transform.js +91 -0
  528. package/dist/symmetry/index.d.ts +43 -0
  529. package/dist/symmetry/index.js +226 -0
  530. package/dist/symmetry/spacegroups.d.ts +16 -0
  531. package/dist/symmetry/spacegroups.js +429 -0
  532. package/dist/table/HeatmapTable.svelte +1885 -0
  533. package/dist/table/HeatmapTable.svelte.d.ts +49 -0
  534. package/dist/table/ToggleMenu.svelte +385 -0
  535. package/dist/table/ToggleMenu.svelte.d.ts +11 -0
  536. package/dist/table/index.d.ts +72 -0
  537. package/dist/table/index.js +38 -0
  538. package/dist/theme/ThemeControl.svelte +53 -0
  539. package/dist/theme/ThemeControl.svelte.d.ts +9 -0
  540. package/dist/theme/index.d.ts +29 -0
  541. package/dist/theme/index.js +79 -0
  542. package/dist/time.d.ts +4 -0
  543. package/dist/time.js +70 -0
  544. package/dist/tooltip/KCoords.svelte +45 -0
  545. package/dist/tooltip/KCoords.svelte.d.ts +8 -0
  546. package/dist/tooltip/TooltipContent.svelte +58 -0
  547. package/dist/tooltip/TooltipContent.svelte.d.ts +31 -0
  548. package/dist/tooltip/index.d.ts +3 -0
  549. package/dist/tooltip/index.js +2 -0
  550. package/dist/tooltip/types.d.ts +8 -0
  551. package/dist/tooltip/types.js +1 -0
  552. package/dist/trajectory/Trajectory.svelte +1571 -0
  553. package/dist/trajectory/Trajectory.svelte.d.ts +78 -0
  554. package/dist/trajectory/TrajectoryError.svelte +128 -0
  555. package/dist/trajectory/TrajectoryError.svelte.d.ts +13 -0
  556. package/dist/trajectory/TrajectoryExportPane.svelte +358 -0
  557. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +17 -0
  558. package/dist/trajectory/TrajectoryInfoPane.svelte +314 -0
  559. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +17 -0
  560. package/dist/trajectory/constants.d.ts +6 -0
  561. package/dist/trajectory/constants.js +7 -0
  562. package/dist/trajectory/extract.d.ts +5 -0
  563. package/dist/trajectory/extract.js +162 -0
  564. package/dist/trajectory/format-detect.d.ts +10 -0
  565. package/dist/trajectory/format-detect.js +90 -0
  566. package/dist/trajectory/frame-reader.d.ts +17 -0
  567. package/dist/trajectory/frame-reader.js +299 -0
  568. package/dist/trajectory/helpers.d.ts +15 -0
  569. package/dist/trajectory/helpers.js +164 -0
  570. package/dist/trajectory/index.d.ts +63 -0
  571. package/dist/trajectory/index.js +126 -0
  572. package/dist/trajectory/parse/ase.d.ts +2 -0
  573. package/dist/trajectory/parse/ase.js +73 -0
  574. package/dist/trajectory/parse/hdf5.d.ts +2 -0
  575. package/dist/trajectory/parse/hdf5.js +127 -0
  576. package/dist/trajectory/parse/index.d.ts +12 -0
  577. package/dist/trajectory/parse/index.js +306 -0
  578. package/dist/trajectory/parse/lammps.d.ts +5 -0
  579. package/dist/trajectory/parse/lammps.js +179 -0
  580. package/dist/trajectory/parse/vasp.d.ts +2 -0
  581. package/dist/trajectory/parse/vasp.js +87 -0
  582. package/dist/trajectory/parse/xyz.d.ts +26 -0
  583. package/dist/trajectory/parse/xyz.js +123 -0
  584. package/dist/trajectory/plotting.d.ts +28 -0
  585. package/dist/trajectory/plotting.js +423 -0
  586. package/dist/trajectory/types.d.ts +11 -0
  587. package/dist/trajectory/types.js +1 -0
  588. package/dist/utils.d.ts +7 -0
  589. package/dist/utils.js +47 -0
  590. package/dist/xrd/XrdPlot.svelte +616 -0
  591. package/dist/xrd/XrdPlot.svelte.d.ts +28 -0
  592. package/dist/xrd/broadening.d.ts +20 -0
  593. package/dist/xrd/broadening.js +97 -0
  594. package/dist/xrd/calc-xrd.d.ts +37 -0
  595. package/dist/xrd/calc-xrd.js +339 -0
  596. package/dist/xrd/index.d.ts +37 -0
  597. package/dist/xrd/index.js +4 -0
  598. package/dist/xrd/parse.d.ts +13 -0
  599. package/dist/xrd/parse.js +749 -0
  600. package/license +1 -1
  601. package/package.json +237 -1458
  602. package/readme.md +98 -171
  603. package/.vscode/launch.json +0 -13
  604. package/.vscodeignore +0 -7
  605. package/dist/assets/STLExporter-BpTH3YHE.js +0 -8
  606. package/dist/assets/browser-DdDecX_W.js +0 -1
  607. package/dist/assets/export-qgn-H9y6.js +0 -2
  608. package/dist/assets/main-DiKYzti2.css +0 -1
  609. package/dist/assets/moyo_wasm_bg-0ocwg7xY.wasm +0 -0
  610. package/dist/extension.js +0 -31293
  611. package/dist/src/lib/FilePicker.svelte +0 -360
  612. package/dist/src/lib/Icon.svelte +0 -41
  613. package/dist/src/lib/MillerIndexInput.svelte +0 -66
  614. package/dist/src/lib/api/mp.ts +0 -26
  615. package/dist/src/lib/api/optimade.ts +0 -204
  616. package/dist/src/lib/app.css +0 -247
  617. package/dist/src/lib/brillouin/BrillouinZone.svelte +0 -549
  618. package/dist/src/lib/brillouin/BrillouinZoneControls.svelte +0 -144
  619. package/dist/src/lib/brillouin/BrillouinZoneExportPane.svelte +0 -146
  620. package/dist/src/lib/brillouin/BrillouinZoneInfoPane.svelte +0 -146
  621. package/dist/src/lib/brillouin/BrillouinZoneScene.svelte +0 -476
  622. package/dist/src/lib/brillouin/BrillouinZoneTooltip.svelte +0 -92
  623. package/dist/src/lib/brillouin/compute.ts +0 -529
  624. package/dist/src/lib/brillouin/index.ts +0 -8
  625. package/dist/src/lib/brillouin/types.ts +0 -51
  626. package/dist/src/lib/chempot-diagram/ChemPotDiagram.svelte +0 -327
  627. package/dist/src/lib/chempot-diagram/ChemPotDiagram2D.svelte +0 -846
  628. package/dist/src/lib/chempot-diagram/ChemPotDiagram3D.svelte +0 -3193
  629. package/dist/src/lib/chempot-diagram/async-compute.svelte.ts +0 -94
  630. package/dist/src/lib/chempot-diagram/chempot-worker.ts +0 -11
  631. package/dist/src/lib/chempot-diagram/color.ts +0 -42
  632. package/dist/src/lib/chempot-diagram/compute.ts +0 -1014
  633. package/dist/src/lib/chempot-diagram/index.ts +0 -6
  634. package/dist/src/lib/chempot-diagram/pointer.ts +0 -56
  635. package/dist/src/lib/chempot-diagram/temperature.ts +0 -77
  636. package/dist/src/lib/chempot-diagram/types.ts +0 -130
  637. package/dist/src/lib/colors/index.ts +0 -249
  638. package/dist/src/lib/composition/BarChart.svelte +0 -297
  639. package/dist/src/lib/composition/BubbleChart.svelte +0 -218
  640. package/dist/src/lib/composition/Composition.svelte +0 -165
  641. package/dist/src/lib/composition/Formula.svelte +0 -268
  642. package/dist/src/lib/composition/FormulaFilter.svelte +0 -1257
  643. package/dist/src/lib/composition/PieChart.svelte +0 -323
  644. package/dist/src/lib/composition/format.ts +0 -155
  645. package/dist/src/lib/composition/index.ts +0 -37
  646. package/dist/src/lib/composition/parse.ts +0 -605
  647. package/dist/src/lib/constants.ts +0 -134
  648. package/dist/src/lib/controls.ts +0 -42
  649. package/dist/src/lib/convex-hull/ConvexHull.svelte +0 -157
  650. package/dist/src/lib/convex-hull/ConvexHull2D.svelte +0 -825
  651. package/dist/src/lib/convex-hull/ConvexHull3D.svelte +0 -1801
  652. package/dist/src/lib/convex-hull/ConvexHull4D.svelte +0 -1398
  653. package/dist/src/lib/convex-hull/ConvexHullControls.svelte +0 -535
  654. package/dist/src/lib/convex-hull/ConvexHullInfoPane.svelte +0 -125
  655. package/dist/src/lib/convex-hull/ConvexHullStats.svelte +0 -929
  656. package/dist/src/lib/convex-hull/ConvexHullTooltip.svelte +0 -131
  657. package/dist/src/lib/convex-hull/GasPressureControls.svelte +0 -247
  658. package/dist/src/lib/convex-hull/StructurePopup.svelte +0 -151
  659. package/dist/src/lib/convex-hull/TemperatureSlider.svelte +0 -140
  660. package/dist/src/lib/convex-hull/barycentric-coords.ts +0 -246
  661. package/dist/src/lib/convex-hull/demo-temperature.ts +0 -63
  662. package/dist/src/lib/convex-hull/gas-thermodynamics.ts +0 -405
  663. package/dist/src/lib/convex-hull/helpers.ts +0 -932
  664. package/dist/src/lib/convex-hull/index.ts +0 -202
  665. package/dist/src/lib/convex-hull/thermodynamics.ts +0 -2192
  666. package/dist/src/lib/convex-hull/types.ts +0 -267
  667. package/dist/src/lib/coordination/CoordinationBarPlot.svelte +0 -311
  668. package/dist/src/lib/coordination/calc-coordination.ts +0 -93
  669. package/dist/src/lib/coordination/index.ts +0 -9
  670. package/dist/src/lib/effects.svelte.ts +0 -48
  671. package/dist/src/lib/element/ElementHeading.svelte +0 -26
  672. package/dist/src/lib/element/ElementPhoto.svelte +0 -57
  673. package/dist/src/lib/element/ElementStats.svelte +0 -80
  674. package/dist/src/lib/element/ElementTile.svelte +0 -484
  675. package/dist/src/lib/element/data.ts +0 -14
  676. package/dist/src/lib/element/index.ts +0 -8
  677. package/dist/src/lib/element/types.ts +0 -62
  678. package/dist/src/lib/feedback/ClickFeedback.svelte +0 -58
  679. package/dist/src/lib/feedback/DragOverlay.svelte +0 -42
  680. package/dist/src/lib/feedback/index.ts +0 -4
  681. package/dist/src/lib/fermi-surface/FermiSlice.svelte +0 -189
  682. package/dist/src/lib/fermi-surface/FermiSurface.svelte +0 -600
  683. package/dist/src/lib/fermi-surface/FermiSurfaceControls.svelte +0 -448
  684. package/dist/src/lib/fermi-surface/FermiSurfaceScene.svelte +0 -794
  685. package/dist/src/lib/fermi-surface/FermiSurfaceTooltip.svelte +0 -111
  686. package/dist/src/lib/fermi-surface/compute.ts +0 -728
  687. package/dist/src/lib/fermi-surface/constants.ts +0 -32
  688. package/dist/src/lib/fermi-surface/export.ts +0 -64
  689. package/dist/src/lib/fermi-surface/index.ts +0 -14
  690. package/dist/src/lib/fermi-surface/marching-cubes.ts +0 -3
  691. package/dist/src/lib/fermi-surface/parse.ts +0 -574
  692. package/dist/src/lib/fermi-surface/symmetry.ts +0 -56
  693. package/dist/src/lib/fermi-surface/types.ts +0 -159
  694. package/dist/src/lib/heatmap-matrix/HeatmapMatrix.svelte +0 -1545
  695. package/dist/src/lib/heatmap-matrix/HeatmapMatrixControls.svelte +0 -225
  696. package/dist/src/lib/heatmap-matrix/index.ts +0 -167
  697. package/dist/src/lib/heatmap-matrix/shared.ts +0 -7
  698. package/dist/src/lib/icons.ts +0 -650
  699. package/dist/src/lib/index.ts +0 -61
  700. package/dist/src/lib/io/decompress.ts +0 -92
  701. package/dist/src/lib/io/export.ts +0 -385
  702. package/dist/src/lib/io/fetch.ts +0 -46
  703. package/dist/src/lib/io/file-drop.ts +0 -51
  704. package/dist/src/lib/io/index.ts +0 -7
  705. package/dist/src/lib/io/is-binary.ts +0 -24
  706. package/dist/src/lib/io/types.ts +0 -8
  707. package/dist/src/lib/io/url-drop.ts +0 -141
  708. package/dist/src/lib/isosurface/Isosurface.svelte +0 -285
  709. package/dist/src/lib/isosurface/IsosurfaceControls.svelte +0 -277
  710. package/dist/src/lib/isosurface/index.ts +0 -7
  711. package/dist/src/lib/isosurface/parse.ts +0 -656
  712. package/dist/src/lib/isosurface/slice.ts +0 -175
  713. package/dist/src/lib/isosurface/types.ts +0 -309
  714. package/dist/src/lib/labels.ts +0 -320
  715. package/dist/src/lib/layout/FullscreenToggle.svelte +0 -50
  716. package/dist/src/lib/layout/InfoCard.svelte +0 -120
  717. package/dist/src/lib/layout/InfoTag.svelte +0 -185
  718. package/dist/src/lib/layout/PropertyFilter.svelte +0 -246
  719. package/dist/src/lib/layout/SettingsSection.svelte +0 -148
  720. package/dist/src/lib/layout/SubpageGrid.svelte +0 -82
  721. package/dist/src/lib/layout/fullscreen.ts +0 -65
  722. package/dist/src/lib/layout/index.ts +0 -11
  723. package/dist/src/lib/layout/json-tree/JsonNode.svelte +0 -548
  724. package/dist/src/lib/layout/json-tree/JsonTree.svelte +0 -1230
  725. package/dist/src/lib/layout/json-tree/index.ts +0 -3
  726. package/dist/src/lib/layout/json-tree/types.ts +0 -126
  727. package/dist/src/lib/layout/json-tree/utils.ts +0 -682
  728. package/dist/src/lib/marching-cubes.ts +0 -614
  729. package/dist/src/lib/math.ts +0 -1081
  730. package/dist/src/lib/overlays/ContextMenu.svelte +0 -162
  731. package/dist/src/lib/overlays/CopyButton.svelte +0 -45
  732. package/dist/src/lib/overlays/DragControlTab.svelte +0 -98
  733. package/dist/src/lib/overlays/DraggablePane.svelte +0 -487
  734. package/dist/src/lib/overlays/InfoPaneCards.svelte +0 -149
  735. package/dist/src/lib/overlays/index.ts +0 -3
  736. package/dist/src/lib/periodic-table/PeriodicTable.svelte +0 -469
  737. package/dist/src/lib/periodic-table/PeriodicTableControls.svelte +0 -557
  738. package/dist/src/lib/periodic-table/PropertySelect.svelte +0 -37
  739. package/dist/src/lib/periodic-table/index.ts +0 -12
  740. package/dist/src/lib/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +0 -1086
  741. package/dist/src/lib/phase-diagram/PhaseDiagramControls.svelte +0 -444
  742. package/dist/src/lib/phase-diagram/PhaseDiagramEditorPane.svelte +0 -126
  743. package/dist/src/lib/phase-diagram/PhaseDiagramExportPane.svelte +0 -184
  744. package/dist/src/lib/phase-diagram/PhaseDiagramTooltip.svelte +0 -391
  745. package/dist/src/lib/phase-diagram/TdbInfoPanel.svelte +0 -203
  746. package/dist/src/lib/phase-diagram/build-diagram.ts +0 -186
  747. package/dist/src/lib/phase-diagram/colors.ts +0 -58
  748. package/dist/src/lib/phase-diagram/diagram-input.ts +0 -40
  749. package/dist/src/lib/phase-diagram/index.ts +0 -13
  750. package/dist/src/lib/phase-diagram/parse.ts +0 -348
  751. package/dist/src/lib/phase-diagram/svg-to-diagram.ts +0 -1023
  752. package/dist/src/lib/phase-diagram/types.ts +0 -144
  753. package/dist/src/lib/phase-diagram/utils.ts +0 -775
  754. package/dist/src/lib/plot/AxisLabel.svelte +0 -51
  755. package/dist/src/lib/plot/BarPlot.svelte +0 -2113
  756. package/dist/src/lib/plot/BarPlotControls.svelte +0 -66
  757. package/dist/src/lib/plot/BinnedScatterPlot.svelte +0 -1114
  758. package/dist/src/lib/plot/ColorBar.svelte +0 -721
  759. package/dist/src/lib/plot/ColorScaleSelect.svelte +0 -54
  760. package/dist/src/lib/plot/ElementScatter.svelte +0 -63
  761. package/dist/src/lib/plot/FillArea.svelte +0 -223
  762. package/dist/src/lib/plot/Histogram.svelte +0 -1558
  763. package/dist/src/lib/plot/HistogramControls.svelte +0 -212
  764. package/dist/src/lib/plot/InteractiveAxisLabel.svelte +0 -96
  765. package/dist/src/lib/plot/Line.svelte +0 -84
  766. package/dist/src/lib/plot/PlotAxis.svelte +0 -169
  767. package/dist/src/lib/plot/PlotControls.svelte +0 -537
  768. package/dist/src/lib/plot/PlotLegend.svelte +0 -569
  769. package/dist/src/lib/plot/PlotTooltip.svelte +0 -67
  770. package/dist/src/lib/plot/PortalSelect.svelte +0 -253
  771. package/dist/src/lib/plot/ReferenceLine.svelte +0 -204
  772. package/dist/src/lib/plot/ReferenceLine3D.svelte +0 -156
  773. package/dist/src/lib/plot/ReferencePlane.svelte +0 -175
  774. package/dist/src/lib/plot/ScatterPlot.svelte +0 -2778
  775. package/dist/src/lib/plot/ScatterPlot3D.svelte +0 -529
  776. package/dist/src/lib/plot/ScatterPlot3DControls.svelte +0 -437
  777. package/dist/src/lib/plot/ScatterPlot3DScene.svelte +0 -912
  778. package/dist/src/lib/plot/ScatterPlotControls.svelte +0 -306
  779. package/dist/src/lib/plot/ScatterPoint.svelte +0 -182
  780. package/dist/src/lib/plot/SpacegroupBarPlot.svelte +0 -293
  781. package/dist/src/lib/plot/Surface3D.svelte +0 -197
  782. package/dist/src/lib/plot/ZeroLines.svelte +0 -97
  783. package/dist/src/lib/plot/ZoomRect.svelte +0 -23
  784. package/dist/src/lib/plot/adaptive-density.ts +0 -316
  785. package/dist/src/lib/plot/auto-place.ts +0 -184
  786. package/dist/src/lib/plot/axis-utils.ts +0 -122
  787. package/dist/src/lib/plot/binned-scatter-types.ts +0 -83
  788. package/dist/src/lib/plot/data-cleaning.ts +0 -1069
  789. package/dist/src/lib/plot/data-transform.ts +0 -69
  790. package/dist/src/lib/plot/defaults.ts +0 -9
  791. package/dist/src/lib/plot/fill-utils.ts +0 -494
  792. package/dist/src/lib/plot/hover-lock.svelte.ts +0 -60
  793. package/dist/src/lib/plot/index.ts +0 -53
  794. package/dist/src/lib/plot/interactions.ts +0 -119
  795. package/dist/src/lib/plot/layout.ts +0 -425
  796. package/dist/src/lib/plot/reference-line.ts +0 -426
  797. package/dist/src/lib/plot/scales.ts +0 -654
  798. package/dist/src/lib/plot/svg.ts +0 -23
  799. package/dist/src/lib/plot/types.ts +0 -1144
  800. package/dist/src/lib/plot/utils/label-placement.ts +0 -541
  801. package/dist/src/lib/plot/utils/series-visibility.ts +0 -140
  802. package/dist/src/lib/plot/utils.ts +0 -11
  803. package/dist/src/lib/rdf/RdfPlot.svelte +0 -247
  804. package/dist/src/lib/rdf/calc-rdf.ts +0 -167
  805. package/dist/src/lib/rdf/index.ts +0 -27
  806. package/dist/src/lib/sanitize.ts +0 -126
  807. package/dist/src/lib/settings.ts +0 -1479
  808. package/dist/src/lib/spectral/Bands.svelte +0 -1040
  809. package/dist/src/lib/spectral/BandsAndDos.svelte +0 -134
  810. package/dist/src/lib/spectral/BrillouinBandsDos.svelte +0 -252
  811. package/dist/src/lib/spectral/Dos.svelte +0 -697
  812. package/dist/src/lib/spectral/helpers.ts +0 -1381
  813. package/dist/src/lib/spectral/index.ts +0 -8
  814. package/dist/src/lib/spectral/types.ts +0 -112
  815. package/dist/src/lib/state.svelte.ts +0 -64
  816. package/dist/src/lib/structure/Arrow.svelte +0 -72
  817. package/dist/src/lib/structure/AtomLegend.svelte +0 -815
  818. package/dist/src/lib/structure/Bond.svelte +0 -140
  819. package/dist/src/lib/structure/CanvasTooltip.svelte +0 -33
  820. package/dist/src/lib/structure/CellSelect.svelte +0 -349
  821. package/dist/src/lib/structure/Cylinder.svelte +0 -45
  822. package/dist/src/lib/structure/Lattice.svelte +0 -196
  823. package/dist/src/lib/structure/Structure.svelte +0 -2248
  824. package/dist/src/lib/structure/StructureControls.svelte +0 -1273
  825. package/dist/src/lib/structure/StructureExportPane.svelte +0 -252
  826. package/dist/src/lib/structure/StructureInfoPane.svelte +0 -737
  827. package/dist/src/lib/structure/StructureScene.svelte +0 -2255
  828. package/dist/src/lib/structure/atom-properties.ts +0 -316
  829. package/dist/src/lib/structure/bond-order-perception.ts +0 -447
  830. package/dist/src/lib/structure/bonding.ts +0 -944
  831. package/dist/src/lib/structure/export.ts +0 -861
  832. package/dist/src/lib/structure/index.ts +0 -291
  833. package/dist/src/lib/structure/label-placement.ts +0 -130
  834. package/dist/src/lib/structure/measure.ts +0 -45
  835. package/dist/src/lib/structure/parse.ts +0 -1705
  836. package/dist/src/lib/structure/partial-occupancy.ts +0 -183
  837. package/dist/src/lib/structure/pbc.ts +0 -164
  838. package/dist/src/lib/structure/supercell.ts +0 -226
  839. package/dist/src/lib/structure/validation.ts +0 -11
  840. package/dist/src/lib/symmetry/SymmetryStats.svelte +0 -226
  841. package/dist/src/lib/symmetry/WyckoffTable.svelte +0 -120
  842. package/dist/src/lib/symmetry/cell-transform.ts +0 -118
  843. package/dist/src/lib/symmetry/index.ts +0 -348
  844. package/dist/src/lib/symmetry/spacegroups.ts +0 -404
  845. package/dist/src/lib/table/HeatmapTable.svelte +0 -1833
  846. package/dist/src/lib/table/ToggleMenu.svelte +0 -385
  847. package/dist/src/lib/table/index.ts +0 -139
  848. package/dist/src/lib/theme/ThemeControl.svelte +0 -53
  849. package/dist/src/lib/theme/index.ts +0 -107
  850. package/dist/src/lib/time.ts +0 -71
  851. package/dist/src/lib/tooltip/TooltipContent.svelte +0 -58
  852. package/dist/src/lib/tooltip/index.ts +0 -2
  853. package/dist/src/lib/tooltip/types.ts +0 -13
  854. package/dist/src/lib/trajectory/Trajectory.svelte +0 -1545
  855. package/dist/src/lib/trajectory/TrajectoryError.svelte +0 -128
  856. package/dist/src/lib/trajectory/TrajectoryExportPane.svelte +0 -357
  857. package/dist/src/lib/trajectory/TrajectoryInfoPane.svelte +0 -313
  858. package/dist/src/lib/trajectory/constants.ts +0 -7
  859. package/dist/src/lib/trajectory/extract.ts +0 -196
  860. package/dist/src/lib/trajectory/format-detect.ts +0 -96
  861. package/dist/src/lib/trajectory/frame-reader.ts +0 -456
  862. package/dist/src/lib/trajectory/helpers.ts +0 -217
  863. package/dist/src/lib/trajectory/index.ts +0 -218
  864. package/dist/src/lib/trajectory/parse/ase.ts +0 -109
  865. package/dist/src/lib/trajectory/parse/hdf5.ts +0 -173
  866. package/dist/src/lib/trajectory/parse/index.ts +0 -411
  867. package/dist/src/lib/trajectory/parse/lammps.ts +0 -215
  868. package/dist/src/lib/trajectory/parse/vasp.ts +0 -102
  869. package/dist/src/lib/trajectory/parse/xyz.ts +0 -143
  870. package/dist/src/lib/trajectory/plotting.ts +0 -599
  871. package/dist/src/lib/trajectory/types.ts +0 -13
  872. package/dist/src/lib/utils.ts +0 -56
  873. package/dist/src/lib/xrd/XrdPlot.svelte +0 -615
  874. package/dist/src/lib/xrd/broadening.ts +0 -130
  875. package/dist/src/lib/xrd/calc-xrd.ts +0 -397
  876. package/dist/src/lib/xrd/index.ts +0 -38
  877. package/dist/src/lib/xrd/parse.ts +0 -858
  878. package/dist/webview.js +0 -29421
  879. package/icon.png +0 -0
  880. package/matterviz-0.3.2.vsix +0 -0
  881. package/matterviz-0.3.4.vsix +0 -0
  882. package/matterviz-0.3.5.vsix +0 -0
  883. package/scripts/sync-config.ts +0 -101
  884. package/src/declarations.d.ts +0 -2
  885. package/src/extension.ts +0 -972
  886. package/src/node-io.ts +0 -65
  887. package/src/types.ts +0 -17
  888. package/src/webview/JsonBrowser.svelte +0 -1079
  889. package/src/webview/PlotPanel.svelte +0 -346
  890. package/src/webview/detect.ts +0 -444
  891. package/src/webview/main.ts +0 -764
  892. package/src/webview/plot-utils.ts +0 -250
  893. package/test-fixtures/all-viz-types.json.gz +0 -0
  894. package/test-fixtures/plot-demo-data.json.gz +0 -0
  895. package/tests/detect.test.ts +0 -604
  896. package/tests/extension.test.ts +0 -2041
  897. package/tests/node-io.test.ts +0 -39
  898. package/tests/plot-utils.test.ts +0 -302
  899. package/tests/vite-plugin-json-gz.test.ts +0 -114
  900. package/tests/vscode-mock.ts +0 -18
  901. package/tests/webview.test.ts +0 -231
  902. package/tsconfig.json +0 -20
  903. package/vite-plugin-json-gz.ts +0 -29
  904. package/vite.config.ts +0 -34
  905. package/vite.extension.config.ts +0 -34
  906. /package/dist/{src/lib/EmptyState.svelte → EmptyState.svelte} +0 -0
  907. /package/dist/{src/lib/chempot-diagram → chempot-diagram}/ChemPotScene3D.svelte +0 -0
  908. /package/dist/{src/lib/colors → colors}/alloy-colors.json +0 -0
  909. /package/dist/{src/lib/colors → colors}/dark-mode-colors.json +0 -0
  910. /package/dist/{src/lib/colors → colors}/jmol-colors.json +0 -0
  911. /package/dist/{src/lib/colors → colors}/muted-colors.json +0 -0
  912. /package/dist/{src/lib/colors → colors}/pastel-colors.json +0 -0
  913. /package/dist/{src/lib/colors → colors}/vesta-colors.json +0 -0
  914. /package/dist/{src/lib/element → element}/BohrAtom.svelte +0 -0
  915. /package/dist/{src/lib/element → element}/Nucleus.svelte +0 -0
  916. /package/dist/{src/lib/element → element}/data.json +0 -0
  917. /package/dist/{src/lib/element → element}/data.json.gz +0 -0
  918. /package/dist/{src/lib/element → element}/data.json.gz.d.ts +0 -0
  919. /package/dist/{src/lib/element → element}/data.schema.json +0 -0
  920. /package/dist/{src/lib/element-image-urls.json → element-image-urls.json} +0 -0
  921. /package/dist/{src/lib/feedback → feedback}/Spinner.svelte +0 -0
  922. /package/dist/{src/lib/feedback → feedback}/StatusMessage.svelte +0 -0
  923. /package/dist/{src/lib/layout → layout}/json-tree/JsonValue.svelte +0 -0
  924. /package/dist/{src/lib/periodic-table → periodic-table}/TableInset.svelte +0 -0
  925. /package/dist/{src/lib/theme → theme}/themes.mjs +0 -0
  926. /package/dist/{src/lib/xrd → xrd}/atomic_scattering_params.json +0 -0
@@ -1,932 +0,0 @@
1
- import { type D3InterpolateName, get_d3_interpolator } from '$lib/colors'
2
- import { ELEM_SYMBOL_TO_NAME } from '$lib/composition'
3
- import type { EnergyModeInfo } from '$lib/convex-hull'
4
- import type { ElementSymbol } from '$lib/element'
5
- import { format_fractional, format_num, symbol_map } from '$lib/labels'
6
- import { scaleSequential } from 'd3-scale'
7
- import { symbol } from 'd3-shape'
8
- import {
9
- analyze_gas_data as _analyze_gas_data,
10
- apply_gas_corrections as _apply_gas_corrections,
11
- } from './gas-thermodynamics'
12
- import type {
13
- ConvexHullConfig,
14
- GasAnalysis,
15
- GasThermodynamicsConfig,
16
- HighlightStyle,
17
- MarkerSymbol,
18
- PhaseData,
19
- } from './types'
20
- import { DEFAULT_GAS_TEMP } from './types'
21
- export { DEFAULT_GAS_TEMP }
22
-
23
- // Tolerance for classifying a phase as on the convex hull (eV/atom)
24
- export const HULL_STABILITY_TOL = 1e-6
25
-
26
- // Clamp raw hull distance and compute stability for a single entry.
27
- // Excluded entries keep their raw (possibly negative) distance and are never stable.
28
- export function compute_hull_stability(
29
- raw_distance: number,
30
- exclude_from_hull?: boolean,
31
- tol: number = HULL_STABILITY_TOL,
32
- ): { e_above_hull: number; is_stable: boolean } {
33
- if (exclude_from_hull) return { e_above_hull: raw_distance, is_stable: false }
34
- const e_above_hull = Math.abs(raw_distance) < tol ? 0 : Math.max(0, raw_distance)
35
- return { e_above_hull, is_stable: e_above_hull <= tol }
36
- }
37
-
38
- type StabilityEntry = { is_stable?: boolean; e_above_hull?: number }
39
-
40
- export const entry_is_stable = (
41
- entry: StabilityEntry,
42
- tol: number = HULL_STABILITY_TOL,
43
- ): boolean =>
44
- entry.is_stable === true ||
45
- (entry.is_stable !== false && Math.abs(entry.e_above_hull ?? Infinity) <= tol)
46
-
47
- // Check if entry is on the convex hull (stable or e_above_hull ≈ 0)
48
- export const is_on_hull = (entry: PhaseData, tol: number = HULL_STABILITY_TOL): boolean =>
49
- !entry.exclude_from_hull && entry_is_stable(entry, tol)
50
-
51
- export const get_arity = (entry: PhaseData): number =>
52
- Object.values(entry.composition).filter((count) => count > 0).length
53
-
54
- export const is_unary_entry = (entry: PhaseData) => get_arity(entry) === 1
55
-
56
- export const entry_is_unstable = (entry: StabilityEntry): boolean => !entry_is_stable(entry)
57
-
58
- export const entry_is_visible = (
59
- entry: StabilityEntry,
60
- show_stable: boolean,
61
- show_unstable: boolean,
62
- ): boolean => (entry_is_stable(entry) ? show_stable : show_unstable)
63
-
64
- export const visible_entries = <Entry extends StabilityEntry>(
65
- entries: readonly Entry[],
66
- show_stable: boolean,
67
- show_unstable: boolean,
68
- ): Entry[] => entries.filter((entry) => entry_is_visible(entry, show_stable, show_unstable))
69
-
70
- // Energy color scale factory (shared)
71
- export function get_energy_color_scale(
72
- color_mode: `stability` | `energy`,
73
- color_scale: D3InterpolateName,
74
- plot_entries: { e_above_hull?: number }[],
75
- ): ((value: number) => string) | null {
76
- if (color_mode !== `energy` || plot_entries.length === 0) return null
77
- let lo = Number.POSITIVE_INFINITY
78
- let hi_raw = 0.1
79
- for (const entry of plot_entries) {
80
- const val = entry.e_above_hull
81
- if (typeof val !== `number` || !Number.isFinite(val)) continue
82
- lo = Math.min(lo, val)
83
- hi_raw = Math.max(hi_raw, val)
84
- }
85
- if (!Number.isFinite(lo)) return null
86
- const hi = Math.max(hi_raw, lo + 1e-6)
87
- const interpolator = get_d3_interpolator(color_scale)
88
- return scaleSequential(interpolator).domain([lo, hi])
89
- }
90
-
91
- // Point color resolver (shared)
92
- export function get_point_color_for_entry(
93
- entry: { is_stable?: boolean; e_above_hull?: number },
94
- color_mode: `stability` | `energy`,
95
- colors: ConvexHullConfig[`colors`] | undefined,
96
- energy_scale: ((value: number) => string) | null,
97
- ): string {
98
- const is_stable = entry_is_stable(entry)
99
- if (color_mode === `stability`) {
100
- return is_stable ? colors?.stable || `#0072B2` : colors?.unstable || `#E69F00`
101
- }
102
- return energy_scale && typeof entry.e_above_hull === `number`
103
- ? energy_scale(entry.e_above_hull)
104
- : `#666`
105
- }
106
-
107
- // Robust drag-and-drop JSON parsing for convex hull entries
108
- export async function parse_hull_entries_from_drop(
109
- event: DragEvent,
110
- ): Promise<PhaseData[] | null> {
111
- event.preventDefault()
112
- const file = event.dataTransfer?.files?.[0]
113
- if (!file?.name.endsWith(`.json`)) return null
114
- try {
115
- const data = JSON.parse(await file.text()) as PhaseData[]
116
- if (!Array.isArray(data) || data.length === 0) return null
117
- if (!data[0].composition || typeof data[0].energy !== `number`) return null
118
- return data
119
- } catch (error) {
120
- console.error(`Error parsing dropped file:`, error)
121
- return null
122
- }
123
- }
124
-
125
- // Compute a consistent max energy threshold for controls (shared)
126
- export function calc_max_hull_dist_in_data(processed_entries: PhaseData[]): number {
127
- if (processed_entries.length === 0) return 0.5
128
- let max_hull_dist = 0
129
- for (const entry of processed_entries) {
130
- const val = entry.e_above_hull
131
- if (typeof val === `number` && Number.isFinite(val)) {
132
- max_hull_dist = Math.max(max_hull_dist, val)
133
- }
134
- }
135
- const max_val = max_hull_dist + 0.001
136
- return Math.max(0.1, max_val)
137
- }
138
-
139
- // Smart threshold for showing unstable entries based on entry count.
140
- // Few entries (≤25): show all. Many entries (≥100): use static default. Between: interpolate.
141
- export function compute_auto_hull_dist_threshold(
142
- n_entries: number,
143
- max_hull_dist_in_data: number,
144
- static_default: number,
145
- ): number {
146
- const [LOW, HIGH] = [25, 100]
147
- if (n_entries <= LOW) return max_hull_dist_in_data
148
- if (n_entries >= HIGH) return static_default
149
- const t = (n_entries - LOW) / (HIGH - LOW)
150
- return max_hull_dist_in_data * (1 - t) + static_default * t
151
- }
152
-
153
- export function auto_threshold_reset(default_threshold: number) {
154
- let source: unknown
155
- let auto_threshold = default_threshold
156
- let initialized = false
157
- return (next_source: unknown, current_threshold: number, next_auto_threshold: number) => {
158
- if (initialized && next_source === source) return undefined
159
- const user_changed = initialized && Math.abs(current_threshold - auto_threshold) > 0.001
160
- source = next_source
161
- auto_threshold = next_auto_threshold
162
- initialized = true
163
- return user_changed ? undefined : next_auto_threshold
164
- }
165
- }
166
-
167
- export function current_entry<Entry extends { entry_id?: string }>(
168
- entry: Entry | null | undefined,
169
- entries: readonly Entry[],
170
- ): Entry | null {
171
- if (!entry) return null
172
- if (entry.entry_id) {
173
- return entries.find((candidate) => candidate.entry_id === entry.entry_id) ?? null
174
- }
175
- return entries.includes(entry) ? entry : null
176
- }
177
-
178
- // Build a tooltip text for any phase entry (shared)
179
- export function build_entry_tooltip_text(entry: PhaseData): string {
180
- const is_element = is_unary_entry(entry)
181
- const elem_symbol = is_element ? Object.keys(entry.composition)[0] : ``
182
-
183
- const elem_name = is_element ? (ELEM_SYMBOL_TO_NAME[elem_symbol as ElementSymbol] ?? ``) : ``
184
-
185
- let text = is_element
186
- ? `${elem_symbol}${elem_name ? ` (${elem_name})` : ``}\n`
187
- : `${entry.name || entry.reduced_formula || ``}\n`
188
-
189
- if (!is_element) {
190
- const total = Object.values(entry.composition).reduce((sum, amt) => sum + amt, 0)
191
- if (total > 0) {
192
- const fractions = Object.entries(entry.composition)
193
- .filter(([, amt]) => amt > 0)
194
- .map(([el, amt]) => `${el}: ${format_fractional(amt / total)}`)
195
- if (fractions.length > 1) {
196
- text += `Composition: ${fractions.join(`, `)}\n`
197
- }
198
- }
199
- }
200
-
201
- if (entry.e_above_hull !== undefined) {
202
- const e_hull_str = format_num(entry.e_above_hull, `.3~`)
203
- text += `E<sub>above hull</sub>: ${e_hull_str} eV/atom\n`
204
- }
205
- // Fallback to energy_per_atom if e_form_per_atom is absent
206
- const e_form_display = entry.e_form_per_atom ?? entry.energy_per_atom
207
- if (e_form_display !== undefined) {
208
- const e_form_str = format_num(e_form_display, `.3~`)
209
- text += `E<sub>form</sub>: ${e_form_str} eV/atom`
210
- }
211
- if (entry.entry_id) text += `\nID: ${entry.entry_id}`
212
- return text
213
- }
214
-
215
- // Generic mouse hit-testing for projected 3D points (shared)
216
- export function find_hull_entry_at_mouse<
217
- T extends {
218
- x: number
219
- y: number
220
- z: number
221
- size?: number
222
- is_stable?: boolean
223
- e_above_hull?: number
224
- },
225
- >(
226
- canvas: HTMLCanvasElement | undefined,
227
- event: MouseEvent,
228
- plot_entries: T[],
229
- project_point: (x: number, y: number, z: number) => { x: number; y: number },
230
- ): T | null {
231
- if (!canvas) return null
232
- const rect = canvas.getBoundingClientRect()
233
- const mouse_x = event.clientX - rect.left
234
- const mouse_y = event.clientY - rect.top
235
- const container_scale = Math.min(canvas.clientWidth || 600, canvas.clientHeight || 600) / 600
236
- for (const entry of plot_entries) {
237
- const projected = project_point(entry.x, entry.y, entry.z)
238
- const distance = Math.hypot(mouse_x - projected.x, mouse_y - projected.y)
239
- const base = entry.size ?? (entry_is_stable(entry) ? 6 : 4)
240
- if (distance < base * container_scale + 5) return entry
241
- }
242
- return null
243
- }
244
-
245
- // Calculate which side of the viewport has more space for modal placement
246
- export function calculate_modal_side(wrapper: HTMLDivElement | undefined): boolean {
247
- if (!wrapper) return true
248
- const rect = wrapper.getBoundingClientRect()
249
- const viewport_width = globalThis.innerWidth
250
- const space_on_right = viewport_width - rect.right
251
- const space_on_left = rect.left
252
- return space_on_right >= space_on_left
253
- }
254
-
255
- // Compute energy source mode information for convex hull entries. Returns energy mode information including capability flags and resolved mode.
256
- // This determines whether we can use precomputed energies or need to compute on-the-fly.
257
- export function compute_energy_mode_info(
258
- entries: PhaseData[], // Array of phase entries to analyze
259
- find_lowest_energy_unary_refs_fn: (entries: PhaseData[]) => Record<string, PhaseData>, // Function to find unary references
260
- energy_source_mode: `precomputed` | `on-the-fly`, // User-specified energy source mode preference
261
- ): EnergyModeInfo {
262
- const has_precomputed_e_form =
263
- entries.length > 0 && entries.every((entry) => typeof entry.e_form_per_atom === `number`)
264
- const has_precomputed_hull =
265
- entries.length > 0 && entries.every((entry) => typeof entry.e_above_hull === `number`)
266
-
267
- const unary_refs = find_lowest_energy_unary_refs_fn(entries)
268
-
269
- const elements_in_entries = new Set<string>()
270
- for (const entry of entries) {
271
- for (const el of Object.keys(entry.composition)) elements_in_entries.add(el)
272
- }
273
- let can_compute_e_form = true
274
- for (const el of elements_in_entries) {
275
- if (!unary_refs[el]) {
276
- can_compute_e_form = false
277
- break
278
- }
279
- }
280
- const can_compute_hull = can_compute_e_form
281
-
282
- // Resolve mode to avoid inconsistent states:
283
- // - If full precomputed available, honor user toggle
284
- // - Else if we can compute both, use on-the-fly automatically
285
- // - Else fall back to precomputed (best-effort)
286
- const energy_mode =
287
- has_precomputed_e_form && has_precomputed_hull
288
- ? energy_source_mode
289
- : can_compute_e_form && can_compute_hull
290
- ? `on-the-fly`
291
- : `precomputed`
292
-
293
- return {
294
- has_precomputed_e_form,
295
- has_precomputed_hull,
296
- can_compute_e_form,
297
- can_compute_hull,
298
- energy_mode,
299
- unary_refs,
300
- }
301
- }
302
-
303
- // Compute effective entries with formation energies based on the energy mode.
304
- // Returns entries with formation energies populated (either precomputed or on-the-fly)
305
- export function get_effective_entries(
306
- entries: PhaseData[], // Original phase entries
307
- energy_mode: `precomputed` | `on-the-fly`, // Energy source mode (precomputed or on-the-fly)
308
- unary_refs: Record<string, PhaseData>, // Unary reference entries for energy computation
309
- compute_e_form_fn: (
310
- entry: PhaseData,
311
- unary_refs: Record<string, PhaseData>,
312
- ) => number | null, // Function to compute formation energy per atom
313
- ): PhaseData[] {
314
- if (energy_mode === `precomputed`) return entries
315
-
316
- return entries.map((entry) => {
317
- const e_form = compute_e_form_fn(entry, unary_refs)
318
- if (e_form === null) return entry
319
- return { ...entry, e_form_per_atom: e_form }
320
- })
321
- }
322
-
323
- // Copy text to clipboard with visual feedback
324
- export async function copy_entry_to_clipboard(
325
- entry: PhaseData,
326
- position: { x: number; y: number },
327
- on_feedback: (visible: boolean, pos: { x: number; y: number }) => void,
328
- ): Promise<void> {
329
- const text = build_entry_tooltip_text(entry)
330
- await navigator.clipboard.writeText(text)
331
- on_feedback(true, position)
332
- setTimeout(() => on_feedback(false, position), 1500)
333
- }
334
-
335
- export const DEFAULT_HIGHLIGHT_STYLE: Required<HighlightStyle> = {
336
- effect: `pulse`,
337
- color: `#ff4444`, // Bright red for visibility
338
- size_multiplier: 1.8, // Moderate base size
339
- opacity: 0.85, // High visibility
340
- pulse_speed: 3, // Smooth pulsing
341
- }
342
-
343
- export const merge_highlight_style = (
344
- custom_style: HighlightStyle | undefined,
345
- ): Required<HighlightStyle> => ({
346
- ...DEFAULT_HIGHLIGHT_STYLE,
347
- ...custom_style,
348
- })
349
-
350
- // Check if entry matches any item in highlighted_list (by structure_id or entry_id)
351
- export function is_entry_highlighted<T extends { entry_id?: string; structure_id?: string }>(
352
- entry: T,
353
- highlighted_list: (string | T)[],
354
- ): boolean {
355
- if (!highlighted_list.length) return false
356
- const { entry_id, structure_id } = entry
357
- if (!entry_id && !structure_id) return false
358
-
359
- return highlighted_list.some((item) => {
360
- if (typeof item === `string`) {
361
- return item === entry_id || item === structure_id
362
- }
363
- // Object: match by structure_id if present, else fall back to entry_id
364
- return item?.structure_id
365
- ? structure_id === item.structure_id
366
- : item?.entry_id === entry_id
367
- })
368
- }
369
-
370
- // Calculate fractional composition (normalized composition) for an entry
371
- export function get_fractional_composition(
372
- composition: Record<string, number>,
373
- ): Record<string, number> {
374
- const total = Object.values(composition).reduce((sum, amt) => sum + amt, 0)
375
- if (total <= 0) return {} // Return empty object if total is zero or negative (invalid composition)
376
- const fractional: Record<string, number> = {}
377
- for (const [elem, amt] of Object.entries(composition)) {
378
- // Only include positive amounts in fractional composition
379
- if (amt > 0) fractional[elem] = amt / total
380
- }
381
- return fractional
382
- }
383
-
384
- export interface PolymorphStats {
385
- total: number
386
- higher: number
387
- lower: number
388
- equal: number
389
- }
390
-
391
- // Energy metric types for consistent polymorph comparison
392
- type EnergyMetric = `e_form_per_atom` | `energy_per_atom` | `e_above_hull` | null
393
-
394
- // Check if value is a finite number
395
- const is_finite = (val: unknown): val is number =>
396
- typeof val === `number` && Number.isFinite(val)
397
-
398
- // Compute energy_per_atom from total energy and composition
399
- function compute_energy_per_atom(entry: PhaseData): number | null {
400
- if (!is_finite(entry.energy)) return null
401
- const total_atoms = Object.values(entry.composition).reduce((sum, amt) => sum + amt, 0)
402
- return total_atoms > 0 ? entry.energy / total_atoms : null
403
- }
404
-
405
- // Get energy value for an entry using a specific metric
406
- // NOTE: We prioritize absolute energies (e_form_per_atom, energy_per_atom) over e_above_hull
407
- // because polymorphs of the same composition on the hull all have e_above_hull=0
408
- function get_entry_energy_by_metric(entry: PhaseData, metric: EnergyMetric): number | null {
409
- if (metric === `e_form_per_atom` && is_finite(entry.e_form_per_atom)) {
410
- return entry.e_form_per_atom
411
- }
412
- if (metric === `energy_per_atom`) {
413
- return is_finite(entry.energy_per_atom)
414
- ? entry.energy_per_atom
415
- : compute_energy_per_atom(entry)
416
- }
417
- if (metric === `e_above_hull` && is_finite(entry.e_above_hull)) {
418
- return entry.e_above_hull
419
- }
420
- return null
421
- }
422
-
423
- function get_label_representative_energy(entry: PhaseData): number {
424
- if (is_finite(entry.e_form_per_atom)) return entry.e_form_per_atom
425
- if (is_finite(entry.energy_per_atom)) return entry.energy_per_atom
426
- const energy_per_atom = compute_energy_per_atom(entry)
427
- if (energy_per_atom !== null) return energy_per_atom
428
- if (is_finite(entry.energy)) return entry.energy
429
- if (is_finite(entry.e_above_hull)) return entry.e_above_hull
430
- return Number.POSITIVE_INFINITY
431
- }
432
-
433
- function get_fractional_composition_key(composition: Record<string, number>): string {
434
- return Object.entries(get_fractional_composition(composition))
435
- .sort(([elem_a], [elem_b]) => elem_a.localeCompare(elem_b))
436
- .map(([elem, frac]) => `${elem}:${frac.toFixed(6)}`)
437
- .join(`|`)
438
- }
439
-
440
- // Pick one label target per normalized composition. Multiple polymorphs, supercell
441
- // formulas, or same-composition entries often project to the same screen position.
442
- export function get_composition_label_entries<T extends PhaseData>(entries: Iterable<T>): T[] {
443
- const label_entry_by_composition = new Map<string, T>()
444
-
445
- for (const entry of entries) {
446
- const comp_key = get_fractional_composition_key(entry.composition)
447
- if (!comp_key) continue
448
-
449
- const existing = label_entry_by_composition.get(comp_key)
450
- if (
451
- !existing ||
452
- get_label_representative_energy(entry) < get_label_representative_energy(existing)
453
- ) {
454
- label_entry_by_composition.set(comp_key, entry)
455
- }
456
- }
457
-
458
- return Array.from(label_entry_by_composition.values())
459
- }
460
-
461
- // Determine which energy metric to use for a composition group
462
- // Returns the first metric that ALL entries in the group can provide
463
- function select_group_energy_metric(polymorphs: PhaseData[]): EnergyMetric {
464
- // Try e_form_per_atom first (best for comparing polymorphs)
465
- if (polymorphs.every((entry) => is_finite(entry.e_form_per_atom))) {
466
- return `e_form_per_atom`
467
- }
468
- // Try energy_per_atom (either direct field or computed from total energy)
469
- if (
470
- polymorphs.every(
471
- (entry) => is_finite(entry.energy_per_atom) || compute_energy_per_atom(entry) !== null,
472
- )
473
- )
474
- return `energy_per_atom`
475
- // Last resort: e_above_hull (will fail to differentiate stable polymorphs with e_above_hull=0)
476
- if (polymorphs.every((entry) => is_finite(entry.e_above_hull))) {
477
- return `e_above_hull`
478
- }
479
-
480
- return null // No valid metric available for this group
481
- }
482
-
483
- // Pre-compute polymorph statistics for all entries at once (O(n²) but done once)
484
- // Returns a Map keyed by entry_id for O(1) lookups during hover
485
- export function compute_all_polymorph_stats(
486
- all_entries: PhaseData[],
487
- ): Map<string, PolymorphStats> {
488
- const stats_map = new Map<string, PolymorphStats>()
489
- const zero_stats = { total: 0, higher: 0, lower: 0, equal: 0 }
490
-
491
- // Group entries by fractional composition (normalized stoichiometry)
492
- const composition_groups = new Map<string, PhaseData[]>()
493
- for (const entry of all_entries) {
494
- const comp_key = get_fractional_composition_key(entry.composition)
495
- const group = composition_groups.get(comp_key) ?? []
496
- if (group.length === 0) composition_groups.set(comp_key, group)
497
- group.push(entry)
498
- }
499
-
500
- // Calculate stats for each polymorph group
501
- for (const polymorphs of composition_groups.values()) {
502
- // Select one consistent metric for the entire composition group
503
- const group_metric = select_group_energy_metric(polymorphs)
504
-
505
- // If no valid metric available, set all entries in group to zero stats
506
- if (group_metric === null) {
507
- for (const entry of polymorphs) {
508
- if (entry.entry_id) stats_map.set(entry.entry_id, zero_stats)
509
- }
510
- continue
511
- }
512
-
513
- // Compare entries using the consistent group metric
514
- for (const entry of polymorphs) {
515
- if (!entry.entry_id) continue
516
-
517
- const entry_energy = get_entry_energy_by_metric(entry, group_metric)
518
- if (entry_energy === null) {
519
- stats_map.set(entry.entry_id, zero_stats)
520
- continue
521
- }
522
-
523
- let [total, higher, lower, equal] = [0, 0, 0, 0]
524
- for (const other of polymorphs) {
525
- if (other === entry || other.entry_id === entry.entry_id) continue
526
-
527
- const other_energy = get_entry_energy_by_metric(other, group_metric)
528
- if (other_energy === null) continue
529
-
530
- total++
531
- if (other_energy > entry_energy) higher++
532
- else if (other_energy < entry_energy) lower++
533
- else equal++
534
- }
535
-
536
- stats_map.set(entry.entry_id, { total, higher, lower, equal })
537
- }
538
- }
539
-
540
- return stats_map
541
- }
542
-
543
- function apply_alpha_to_color(color: string, alpha: number): string {
544
- // Handle existing rgba format
545
- if (color.includes(`rgba`)) return color.replace(/[\d.]+\)$/, `${alpha})`)
546
-
547
- if (color.includes(`rgb(`)) {
548
- // Convert rgb to rgba
549
- return color.replace(/rgb\(/, `rgba(`).replace(/\)$/, `, ${alpha})`)
550
- }
551
-
552
- const hex_match = /^#?([0-9a-fA-F]{3}|[0-9a-fA-F]{6})$/.exec(color) // Convert hex to rgba
553
- if (hex_match) {
554
- let hex = hex_match[1]
555
- // Expand short form (e.g. "03F") to full form (e.g. "0033FF")
556
- if (hex.length === 3)
557
- hex = hex
558
- .split(``)
559
- .map((char) => char + char)
560
- .join(``)
561
-
562
- const red = parseInt(hex.slice(0, 2), 16)
563
- const green = parseInt(hex.slice(2, 4), 16)
564
- const blue = parseInt(hex.slice(4, 6), 16)
565
- return `rgba(${red}, ${green}, ${blue}, ${alpha})`
566
- }
567
-
568
- return color // Return unchanged if format not recognized
569
- }
570
-
571
- export function draw_highlight_effect(
572
- ctx: CanvasRenderingContext2D,
573
- projected: { x: number; y: number },
574
- size: number,
575
- container_scale: number,
576
- pulse_time: number,
577
- style: Required<HighlightStyle>,
578
- ): void {
579
- const { effect, color: hl_color, size_multiplier, opacity, pulse_speed } = style
580
-
581
- if (effect === `pulse`) {
582
- // Smooth pulsating effect with moderate size and opacity changes
583
- const pulse_val = 0.5 + 0.5 * Math.sin(pulse_time * pulse_speed)
584
- const hl_size = size * (size_multiplier + 0.5 * pulse_val)
585
- const hl_opacity = opacity * (0.5 + 0.5 * pulse_val)
586
-
587
- // Draw pulsating ring
588
- ctx.lineWidth = (1.5 + pulse_val) * container_scale
589
- ctx.beginPath()
590
- ctx.arc(projected.x, projected.y, hl_size, 0, 2 * Math.PI)
591
- ctx.fillStyle = apply_alpha_to_color(hl_color, hl_opacity * 0.3)
592
- ctx.strokeStyle = apply_alpha_to_color(hl_color, hl_opacity)
593
- ctx.fill()
594
- ctx.stroke()
595
- } else if (effect === `glow`) {
596
- // Soft glow effect with layered circles for depth
597
- const hl_size = size * size_multiplier
598
-
599
- // Outer soft glow
600
- ctx.beginPath()
601
- ctx.arc(projected.x, projected.y, hl_size * 1.3, 0, 2 * Math.PI)
602
- ctx.fillStyle = apply_alpha_to_color(hl_color, opacity * 0.15)
603
- ctx.fill()
604
-
605
- // Inner glow with stroke
606
- ctx.lineWidth = 1.5 * container_scale
607
- ctx.beginPath()
608
- ctx.arc(projected.x, projected.y, hl_size, 0, 2 * Math.PI)
609
- ctx.fillStyle = apply_alpha_to_color(hl_color, opacity * 0.4)
610
- ctx.strokeStyle = apply_alpha_to_color(hl_color, opacity * 0.8)
611
- ctx.fill()
612
- ctx.stroke()
613
- } else if (effect === `size`) {
614
- // Simple size highlight with stroke
615
- const hl_size = size * size_multiplier
616
- ctx.lineWidth = 2 * container_scale
617
- ctx.beginPath()
618
- ctx.arc(projected.x, projected.y, hl_size, 0, 2 * Math.PI)
619
- ctx.strokeStyle = hl_color
620
- ctx.stroke()
621
- }
622
- // effect === `color` is handled in the main drawing code
623
- }
624
-
625
- // Draw selection highlight for currently selected entry (with pulsing animation)
626
- export function draw_selection_highlight(
627
- ctx: CanvasRenderingContext2D,
628
- projected: { x: number; y: number },
629
- base_size: number,
630
- container_scale: number,
631
- pulse_time: number,
632
- pulse_opacity: number,
633
- ): void {
634
- const highlight_size = base_size * (1.8 + 0.3 * Math.sin(pulse_time * 4))
635
- ctx.fillStyle = apply_alpha_to_color(`rgba(102, 240, 255, 1)`, pulse_opacity * 0.6)
636
- ctx.strokeStyle = apply_alpha_to_color(`rgba(102, 240, 255, 1)`, pulse_opacity)
637
- ctx.lineWidth = 2 * container_scale
638
- ctx.beginPath()
639
- ctx.arc(projected.x, projected.y, highlight_size, 0, 2 * Math.PI)
640
- ctx.fill()
641
- ctx.stroke()
642
- }
643
-
644
- // Get text color for canvas rendering. Canvas 2D context doesn't understand CSS functions
645
- // like light-dark() or var(), so we fall back to appropriate colors based on dark mode.
646
- export function get_canvas_text_color(
647
- dark_mode: boolean,
648
- element?: HTMLElement | null,
649
- ): string {
650
- const fallback = dark_mode ? `#ffffff` : `#212121`
651
- if (typeof document === `undefined`) return fallback
652
- const css_value = getComputedStyle(element ?? document.documentElement)
653
- .getPropertyValue(`--text-color`)
654
- ?.trim()
655
- // Check for unsupported CSS functions that canvas can't render
656
- return css_value && !/light-dark|var\(/i.test(css_value) ? css_value : fallback
657
- }
658
-
659
- // Create a Path2D for a marker symbol. Uses d3-shape for consistent rendering with ScatterPlot.
660
- export function create_marker_path(size: number, marker: MarkerSymbol = `circle`): Path2D {
661
- const safe_size = Number.isFinite(size) ? size : 0
662
- const rounded_size = Math.max(0, Number(safe_size.toFixed(3)))
663
-
664
- // Capitalize first letter to get D3 symbol name (e.g. 'circle' -> 'Circle')
665
- const d3_name = marker.charAt(0).toUpperCase() + marker.slice(1)
666
- const symbol_type = symbol_map[d3_name as keyof typeof symbol_map]
667
- const symbol_area = Math.PI * rounded_size * rounded_size
668
- const path_data = symbol_type ? symbol().type(symbol_type).size(symbol_area)() : null
669
- const path = new Path2D(path_data ?? undefined)
670
-
671
- if (!path_data) {
672
- path.arc(0, 0, rounded_size, 0, 2 * Math.PI)
673
- }
674
-
675
- return path
676
- }
677
-
678
- // Temperature-dependent free energy helpers (use integer K values for exact matching)
679
-
680
- // Result of analyzing entries for temperature-dependent data
681
- export interface TemperatureAnalysis {
682
- has_temp_data: boolean
683
- available_temperatures: number[] // sorted unique T values (union across all entries)
684
- }
685
-
686
- // Analyze entries for temperature-dependent free energy data.
687
- // Returns available temperatures (union of all T values across entries) if any entries have temp data.
688
- export function analyze_temperature_data(entries: PhaseData[]): TemperatureAnalysis {
689
- const unique_temperatures = new Set<number>()
690
- for (const entry of entries) {
691
- if (!entry_has_temp_data(entry)) continue
692
- for (const temperature of entry.temperatures ?? []) unique_temperatures.add(temperature)
693
- }
694
- const available_temperatures = [...unique_temperatures].sort((a, b) => a - b)
695
- return {
696
- has_temp_data: available_temperatures.length > 0,
697
- available_temperatures,
698
- }
699
- }
700
-
701
- // Check if an entry has valid temperature-dependent data (matching array lengths, non-empty)
702
- function entry_has_temp_data(entry: PhaseData): boolean {
703
- const { temperatures, free_energies } = entry
704
- return Boolean(
705
- temperatures?.length &&
706
- free_energies?.length &&
707
- temperatures.length === free_energies.length,
708
- )
709
- }
710
-
711
- // Check if entry has data at exact temperature T
712
- export const entry_has_temperature = (entry: PhaseData, T: number): boolean =>
713
- entry_has_temp_data(entry) && (entry.temperatures?.includes(T) ?? false)
714
-
715
- // Get energy at temperature T (throws if T not found - validate with entry_has_temperature first)
716
- export function get_energy_at_temperature(entry: PhaseData, T: number): number {
717
- const temps = entry.temperatures ?? []
718
- const energies = entry.free_energies ?? []
719
- const idx = temps.indexOf(T)
720
- if (idx === -1) {
721
- throw new Error(`Temperature ${T}K not found in entry temperatures`)
722
- }
723
- return energies[idx]
724
- }
725
-
726
- // Find bracketing temperatures for interpolation (T_low < T < T_high)
727
- // Returns null if T is outside the range or no valid bracket exists
728
- function find_bracket_temperatures(
729
- entry: PhaseData,
730
- T: number,
731
- ): { T_low: number; T_high: number; E_low: number; E_high: number } | null {
732
- const temps = entry.temperatures ?? []
733
- const energies = entry.free_energies ?? []
734
- if (temps.length < 2) return null
735
-
736
- // Find the largest T_low < T and smallest T_high > T
737
- let T_low = -Infinity
738
- let T_high = Infinity
739
- let E_low = 0
740
- let E_high = 0
741
-
742
- // Must scan all temperatures to find the tightest bracket (arrays may be unsorted)
743
- for (const [idx, temp] of temps.entries()) {
744
- if (temp < T && temp > T_low) {
745
- T_low = temp
746
- E_low = energies[idx]
747
- } else if (temp > T && temp < T_high) {
748
- T_high = temp
749
- E_high = energies[idx]
750
- }
751
- }
752
-
753
- // Must have valid brackets on both sides
754
- if (!isFinite(T_low) || !isFinite(T_high)) return null
755
- return { T_low, T_high, E_low, E_high }
756
- }
757
-
758
- // Check if we can interpolate energy at temperature T
759
- // Requires temperatures both above and below T within max_gap
760
- export function can_interpolate_at_temperature(
761
- entry: PhaseData,
762
- T: number,
763
- max_gap: number,
764
- ): boolean {
765
- const bracket = find_bracket_temperatures(entry, T)
766
- if (!bracket) return false
767
- return bracket.T_high - bracket.T_low <= max_gap
768
- }
769
-
770
- // Linearly interpolate energy at temperature T
771
- // Returns null if interpolation is not possible
772
- export function interpolate_energy_at_temperature(
773
- entry: PhaseData,
774
- T: number,
775
- max_gap: number,
776
- ): number | null {
777
- const bracket = find_bracket_temperatures(entry, T)
778
- if (!bracket) return null
779
- if (bracket.T_high - bracket.T_low > max_gap) return null
780
-
781
- // Linear interpolation: E(T) = E_low + (E_high - E_low) * (T - T_low) / (T_high - T_low)
782
- const fraction = (T - bracket.T_low) / (bracket.T_high - bracket.T_low)
783
- return bracket.E_low + (bracket.E_high - bracket.E_low) * fraction
784
- }
785
-
786
- // Options for temperature filtering
787
- export interface TemperatureFilterOptions {
788
- // Enable linear interpolation for missing temperatures (default: true)
789
- interpolate?: boolean
790
- // Maximum temperature gap (in Kelvin) allowed for interpolation (default: 500K)
791
- max_interpolation_gap?: number
792
- }
793
-
794
- const DEFAULT_TEMP_FILTER_OPTIONS: Required<TemperatureFilterOptions> = {
795
- interpolate: true,
796
- max_interpolation_gap: 500,
797
- }
798
-
799
- // Filter entries for temperature T, replacing energy with G(T) where available.
800
- // - Entries WITH temp data at T: use G(T) as energy
801
- // - Entries WITHOUT any temp data: keep with static energy (e.g., pure element refs)
802
- // - Entries WITH temp data but MISSING T: interpolate if enabled and possible, else excluded
803
- export function filter_entries_at_temperature(
804
- entries: PhaseData[],
805
- T: number,
806
- options: TemperatureFilterOptions = {},
807
- ): PhaseData[] {
808
- const { interpolate, max_interpolation_gap } = {
809
- ...DEFAULT_TEMP_FILTER_OPTIONS,
810
- ...options,
811
- }
812
-
813
- return entries.flatMap((entry) => {
814
- // No temp data - keep with static energy
815
- if (!entry_has_temp_data(entry)) return [entry]
816
-
817
- // Exact temperature match - use G(T)
818
- // Set both energy and energy_per_atom so downstream formation energy
819
- // calculations use the temperature-dependent value (not stale 0K energy_per_atom)
820
- if (entry_has_temperature(entry, T)) {
821
- // free_energies stores per-atom values (E_0K/atom + F_vib/atom),
822
- // so energy is already per-atom — set both fields to the same value
823
- const energy = get_energy_at_temperature(entry, T)
824
- return [{ ...entry, energy, energy_per_atom: energy }]
825
- }
826
-
827
- // Try interpolation if enabled
828
- if (interpolate) {
829
- const energy = interpolate_energy_at_temperature(entry, T, max_interpolation_gap)
830
- if (energy !== null) {
831
- // interpolated energy is also per-atom (interpolated from per-atom free_energies)
832
- return [{ ...entry, energy, energy_per_atom: energy }]
833
- }
834
- }
835
-
836
- // Exclude entry (has temp data but can't get energy at T)
837
- return []
838
- })
839
- }
840
-
841
- // Gas-dependent chemical potential helpers
842
-
843
- // Analyze entries for gas-dependent elements (safe wrapper with optional config)
844
- // Returns information about which gases are relevant for the chemical system.
845
- export function safe_analyze_gas_data(
846
- entries: PhaseData[],
847
- config?: GasThermodynamicsConfig,
848
- ): GasAnalysis {
849
- if (!config?.enabled_gases?.length) {
850
- return {
851
- has_gas_dependent_elements: false,
852
- gas_elements: [],
853
- relevant_gases: [],
854
- }
855
- }
856
- return _analyze_gas_data(entries, config)
857
- }
858
-
859
- // Apply gas chemical potential corrections to entries (safe wrapper with optional config)
860
- // This adjusts formation energies based on gas atmosphere conditions (T, P).
861
- // Should be applied after temperature filtering.
862
- export function safe_apply_gas_corrections(
863
- entries: PhaseData[],
864
- config: GasThermodynamicsConfig | undefined,
865
- T: number,
866
- ): PhaseData[] {
867
- if (!config?.enabled_gases?.length) return entries
868
- return _apply_gas_corrections(entries, config, T)
869
- }
870
-
871
- // Get gas-corrected entries in one call (consolidates analysis + correction)
872
- // Merges gas_pressures with config.pressures and applies corrections if the
873
- // chemical system contains gas-dependent elements. Returns original entries
874
- // if no gas config or no relevant gases.
875
- export function get_gas_corrected_entries(
876
- entries: PhaseData[],
877
- gas_config: GasThermodynamicsConfig | undefined,
878
- gas_pressures: Partial<Record<string, number>>,
879
- temperature: number,
880
- ): {
881
- entries: PhaseData[]
882
- analysis: GasAnalysis
883
- merged_config: GasThermodynamicsConfig | undefined
884
- } {
885
- if (!gas_config?.enabled_gases?.length) {
886
- return {
887
- entries,
888
- analysis: {
889
- has_gas_dependent_elements: false,
890
- gas_elements: [],
891
- relevant_gases: [],
892
- },
893
- merged_config: undefined,
894
- }
895
- }
896
-
897
- const merged_config: GasThermodynamicsConfig = {
898
- ...gas_config,
899
- pressures: { ...gas_config.pressures, ...gas_pressures },
900
- }
901
- const analysis = _analyze_gas_data(entries, merged_config)
902
-
903
- if (!analysis.has_gas_dependent_elements) {
904
- return { entries, analysis, merged_config }
905
- }
906
-
907
- return {
908
- entries: _apply_gas_corrections(entries, merged_config, temperature),
909
- analysis,
910
- merged_config,
911
- }
912
- }
913
-
914
- // Derive a display label for a convex hull entry, falling back to composition
915
- // when reduced_formula and name are both missing.
916
- export function get_entry_label(
917
- entry: { reduced_formula?: string; name?: string; composition: Record<string, number> },
918
- elements?: ElementSymbol[],
919
- ): string {
920
- if (entry.reduced_formula) return entry.reduced_formula
921
- if (entry.name) return entry.name
922
- let pairs = Object.entries(entry.composition).filter(([, amt]) => amt > 0)
923
- if (elements) {
924
- pairs = pairs.sort(
925
- ([el1], [el2]) =>
926
- elements.indexOf(el1 as ElementSymbol) - elements.indexOf(el2 as ElementSymbol),
927
- )
928
- }
929
- return pairs
930
- .map(([el, amt]) => (Math.abs(amt - 1) < 1e-6 ? el : `${el}${format_num(amt, `.2~`)}`))
931
- .join(``)
932
- }