matterviz 0.3.4 → 0.3.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (852) hide show
  1. package/.vscode/launch.json +13 -0
  2. package/.vscodeignore +7 -0
  3. package/dist/assets/STLExporter-BpTH3YHE.js +8 -0
  4. package/dist/assets/browser-DdDecX_W.js +1 -0
  5. package/dist/assets/export-qgn-H9y6.js +2 -0
  6. package/dist/assets/main-DiKYzti2.css +1 -0
  7. package/dist/assets/moyo_wasm_bg-0ocwg7xY.wasm +0 -0
  8. package/dist/extension.js +31293 -0
  9. package/dist/src/lib/FilePicker.svelte +360 -0
  10. package/dist/src/lib/MillerIndexInput.svelte +66 -0
  11. package/dist/src/lib/api/mp.ts +26 -0
  12. package/dist/src/lib/api/optimade.ts +204 -0
  13. package/dist/src/lib/app.css +247 -0
  14. package/dist/src/lib/brillouin/BrillouinZone.svelte +549 -0
  15. package/dist/src/lib/brillouin/BrillouinZoneControls.svelte +144 -0
  16. package/dist/src/lib/brillouin/BrillouinZoneExportPane.svelte +146 -0
  17. package/dist/src/lib/brillouin/BrillouinZoneInfoPane.svelte +146 -0
  18. package/dist/src/lib/brillouin/BrillouinZoneScene.svelte +476 -0
  19. package/dist/src/lib/brillouin/BrillouinZoneTooltip.svelte +92 -0
  20. package/dist/src/lib/brillouin/compute.ts +529 -0
  21. package/dist/src/lib/brillouin/index.ts +8 -0
  22. package/dist/src/lib/brillouin/types.ts +51 -0
  23. package/dist/src/lib/chempot-diagram/ChemPotDiagram.svelte +327 -0
  24. package/dist/src/lib/chempot-diagram/ChemPotDiagram2D.svelte +846 -0
  25. package/dist/src/lib/chempot-diagram/ChemPotDiagram3D.svelte +3193 -0
  26. package/dist/src/lib/chempot-diagram/async-compute.svelte.ts +94 -0
  27. package/dist/src/lib/chempot-diagram/chempot-worker.ts +11 -0
  28. package/dist/src/lib/chempot-diagram/color.ts +42 -0
  29. package/dist/src/lib/chempot-diagram/compute.ts +1014 -0
  30. package/dist/src/lib/chempot-diagram/index.ts +6 -0
  31. package/dist/src/lib/chempot-diagram/pointer.ts +56 -0
  32. package/dist/src/lib/chempot-diagram/temperature.ts +77 -0
  33. package/dist/src/lib/chempot-diagram/types.ts +130 -0
  34. package/dist/src/lib/colors/index.ts +249 -0
  35. package/dist/src/lib/composition/BarChart.svelte +297 -0
  36. package/dist/src/lib/composition/BubbleChart.svelte +218 -0
  37. package/dist/src/lib/composition/Composition.svelte +165 -0
  38. package/dist/src/lib/composition/Formula.svelte +268 -0
  39. package/dist/src/lib/composition/FormulaFilter.svelte +1257 -0
  40. package/dist/src/lib/composition/PieChart.svelte +323 -0
  41. package/dist/src/lib/composition/format.ts +155 -0
  42. package/dist/src/lib/composition/index.ts +37 -0
  43. package/dist/src/lib/composition/parse.ts +605 -0
  44. package/dist/src/lib/constants.ts +134 -0
  45. package/dist/src/lib/controls.ts +42 -0
  46. package/dist/src/lib/convex-hull/ConvexHull.svelte +157 -0
  47. package/dist/src/lib/convex-hull/ConvexHull2D.svelte +825 -0
  48. package/dist/src/lib/convex-hull/ConvexHull3D.svelte +1801 -0
  49. package/dist/src/lib/convex-hull/ConvexHull4D.svelte +1398 -0
  50. package/dist/src/lib/convex-hull/ConvexHullControls.svelte +535 -0
  51. package/dist/src/lib/convex-hull/ConvexHullInfoPane.svelte +125 -0
  52. package/dist/src/lib/convex-hull/ConvexHullStats.svelte +929 -0
  53. package/dist/src/lib/convex-hull/ConvexHullTooltip.svelte +131 -0
  54. package/dist/src/lib/convex-hull/GasPressureControls.svelte +247 -0
  55. package/dist/src/lib/convex-hull/StructurePopup.svelte +151 -0
  56. package/dist/src/lib/convex-hull/TemperatureSlider.svelte +140 -0
  57. package/dist/src/lib/convex-hull/barycentric-coords.ts +246 -0
  58. package/dist/src/lib/convex-hull/demo-temperature.ts +63 -0
  59. package/dist/src/lib/convex-hull/gas-thermodynamics.ts +405 -0
  60. package/dist/src/lib/convex-hull/helpers.ts +932 -0
  61. package/dist/src/lib/convex-hull/index.ts +202 -0
  62. package/dist/src/lib/convex-hull/thermodynamics.ts +2192 -0
  63. package/dist/src/lib/convex-hull/types.ts +267 -0
  64. package/dist/src/lib/coordination/CoordinationBarPlot.svelte +311 -0
  65. package/dist/src/lib/coordination/calc-coordination.ts +93 -0
  66. package/dist/src/lib/coordination/index.ts +9 -0
  67. package/dist/src/lib/effects.svelte.ts +48 -0
  68. package/dist/src/lib/element/BohrAtom.svelte +147 -0
  69. package/dist/src/lib/element/ElementHeading.svelte +26 -0
  70. package/dist/src/lib/element/ElementPhoto.svelte +57 -0
  71. package/dist/src/lib/element/ElementStats.svelte +80 -0
  72. package/dist/src/lib/element/ElementTile.svelte +484 -0
  73. package/dist/src/lib/element/data.json.gz.d.ts +4 -0
  74. package/dist/src/lib/element/data.ts +14 -0
  75. package/dist/src/lib/element/index.ts +8 -0
  76. package/dist/src/lib/element/types.ts +62 -0
  77. package/dist/src/lib/feedback/ClickFeedback.svelte +58 -0
  78. package/dist/src/lib/feedback/DragOverlay.svelte +42 -0
  79. package/dist/src/lib/feedback/index.ts +4 -0
  80. package/dist/src/lib/fermi-surface/FermiSlice.svelte +189 -0
  81. package/dist/src/lib/fermi-surface/FermiSurface.svelte +600 -0
  82. package/dist/src/lib/fermi-surface/FermiSurfaceControls.svelte +448 -0
  83. package/dist/src/lib/fermi-surface/FermiSurfaceScene.svelte +794 -0
  84. package/dist/src/lib/fermi-surface/FermiSurfaceTooltip.svelte +111 -0
  85. package/dist/src/lib/fermi-surface/compute.ts +728 -0
  86. package/dist/src/lib/fermi-surface/constants.ts +32 -0
  87. package/dist/src/lib/fermi-surface/export.ts +64 -0
  88. package/dist/src/lib/fermi-surface/index.ts +14 -0
  89. package/dist/src/lib/fermi-surface/marching-cubes.ts +3 -0
  90. package/dist/src/lib/fermi-surface/parse.ts +574 -0
  91. package/dist/src/lib/fermi-surface/symmetry.ts +56 -0
  92. package/dist/src/lib/fermi-surface/types.ts +159 -0
  93. package/dist/src/lib/heatmap-matrix/HeatmapMatrix.svelte +1545 -0
  94. package/dist/src/lib/heatmap-matrix/HeatmapMatrixControls.svelte +225 -0
  95. package/dist/src/lib/heatmap-matrix/index.ts +167 -0
  96. package/dist/src/lib/heatmap-matrix/shared.ts +7 -0
  97. package/dist/src/lib/icons.ts +650 -0
  98. package/dist/src/lib/index.ts +61 -0
  99. package/dist/src/lib/io/decompress.ts +92 -0
  100. package/dist/src/lib/io/export.ts +385 -0
  101. package/dist/src/lib/io/fetch.ts +46 -0
  102. package/dist/src/lib/io/file-drop.ts +51 -0
  103. package/dist/src/lib/io/index.ts +7 -0
  104. package/dist/src/lib/io/is-binary.ts +24 -0
  105. package/dist/src/lib/io/types.ts +8 -0
  106. package/dist/src/lib/io/url-drop.ts +141 -0
  107. package/dist/src/lib/isosurface/Isosurface.svelte +285 -0
  108. package/dist/src/lib/isosurface/IsosurfaceControls.svelte +277 -0
  109. package/dist/src/lib/isosurface/index.ts +7 -0
  110. package/dist/src/lib/isosurface/parse.ts +656 -0
  111. package/dist/src/lib/isosurface/slice.ts +175 -0
  112. package/dist/src/lib/isosurface/types.ts +309 -0
  113. package/dist/src/lib/labels.ts +320 -0
  114. package/dist/src/lib/layout/FullscreenToggle.svelte +50 -0
  115. package/dist/src/lib/layout/InfoCard.svelte +120 -0
  116. package/dist/src/lib/layout/InfoTag.svelte +185 -0
  117. package/dist/src/lib/layout/PropertyFilter.svelte +246 -0
  118. package/dist/src/lib/layout/SettingsSection.svelte +148 -0
  119. package/dist/src/lib/layout/SubpageGrid.svelte +82 -0
  120. package/dist/src/lib/layout/fullscreen.ts +65 -0
  121. package/dist/src/lib/layout/index.ts +11 -0
  122. package/dist/src/lib/layout/json-tree/JsonNode.svelte +548 -0
  123. package/dist/src/lib/layout/json-tree/JsonTree.svelte +1230 -0
  124. package/dist/src/lib/layout/json-tree/JsonValue.svelte +334 -0
  125. package/dist/src/lib/layout/json-tree/index.ts +3 -0
  126. package/dist/src/lib/layout/json-tree/types.ts +126 -0
  127. package/dist/src/lib/layout/json-tree/utils.ts +682 -0
  128. package/dist/src/lib/marching-cubes.ts +614 -0
  129. package/dist/src/lib/math.ts +1081 -0
  130. package/dist/src/lib/overlays/ContextMenu.svelte +162 -0
  131. package/dist/src/lib/overlays/CopyButton.svelte +45 -0
  132. package/dist/src/lib/overlays/DragControlTab.svelte +98 -0
  133. package/dist/src/lib/overlays/DraggablePane.svelte +487 -0
  134. package/dist/src/lib/overlays/InfoPaneCards.svelte +149 -0
  135. package/dist/src/lib/overlays/index.ts +3 -0
  136. package/dist/src/lib/periodic-table/PeriodicTable.svelte +469 -0
  137. package/dist/src/lib/periodic-table/PeriodicTableControls.svelte +557 -0
  138. package/dist/src/lib/periodic-table/PropertySelect.svelte +37 -0
  139. package/dist/src/lib/periodic-table/index.ts +12 -0
  140. package/dist/src/lib/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +1086 -0
  141. package/dist/src/lib/phase-diagram/PhaseDiagramControls.svelte +444 -0
  142. package/dist/src/lib/phase-diagram/PhaseDiagramEditorPane.svelte +126 -0
  143. package/dist/src/lib/phase-diagram/PhaseDiagramExportPane.svelte +184 -0
  144. package/dist/src/lib/phase-diagram/PhaseDiagramTooltip.svelte +391 -0
  145. package/dist/src/lib/phase-diagram/TdbInfoPanel.svelte +203 -0
  146. package/dist/src/lib/phase-diagram/build-diagram.ts +186 -0
  147. package/dist/src/lib/phase-diagram/colors.ts +58 -0
  148. package/dist/src/lib/phase-diagram/diagram-input.ts +40 -0
  149. package/dist/src/lib/phase-diagram/index.ts +13 -0
  150. package/dist/src/lib/phase-diagram/parse.ts +348 -0
  151. package/dist/src/lib/phase-diagram/svg-to-diagram.ts +1023 -0
  152. package/dist/src/lib/phase-diagram/types.ts +144 -0
  153. package/dist/src/lib/phase-diagram/utils.ts +775 -0
  154. package/dist/src/lib/plot/AxisLabel.svelte +51 -0
  155. package/dist/src/lib/plot/BarPlot.svelte +2113 -0
  156. package/dist/src/lib/plot/BarPlotControls.svelte +66 -0
  157. package/dist/src/lib/plot/BinnedScatterPlot.svelte +1114 -0
  158. package/dist/src/lib/plot/ColorBar.svelte +721 -0
  159. package/dist/src/lib/plot/ColorScaleSelect.svelte +54 -0
  160. package/dist/src/lib/plot/ElementScatter.svelte +63 -0
  161. package/dist/src/lib/plot/FillArea.svelte +223 -0
  162. package/dist/src/lib/plot/Histogram.svelte +1558 -0
  163. package/dist/src/lib/plot/HistogramControls.svelte +212 -0
  164. package/dist/src/lib/plot/InteractiveAxisLabel.svelte +96 -0
  165. package/dist/src/lib/plot/Line.svelte +84 -0
  166. package/dist/src/lib/plot/PlotAxis.svelte +169 -0
  167. package/dist/src/lib/plot/PlotControls.svelte +537 -0
  168. package/dist/src/lib/plot/PlotLegend.svelte +569 -0
  169. package/dist/src/lib/plot/PlotTooltip.svelte +67 -0
  170. package/dist/src/lib/plot/PortalSelect.svelte +253 -0
  171. package/dist/src/lib/plot/ReferenceLine3D.svelte +156 -0
  172. package/dist/src/lib/plot/ReferencePlane.svelte +175 -0
  173. package/dist/src/lib/plot/ScatterPlot.svelte +2778 -0
  174. package/dist/src/lib/plot/ScatterPlot3D.svelte +529 -0
  175. package/dist/src/lib/plot/ScatterPlot3DControls.svelte +437 -0
  176. package/dist/src/lib/plot/ScatterPlot3DScene.svelte +912 -0
  177. package/dist/src/lib/plot/ScatterPlotControls.svelte +306 -0
  178. package/dist/src/lib/plot/ScatterPoint.svelte +182 -0
  179. package/dist/src/lib/plot/SpacegroupBarPlot.svelte +293 -0
  180. package/dist/src/lib/plot/Surface3D.svelte +197 -0
  181. package/dist/src/lib/plot/ZeroLines.svelte +97 -0
  182. package/dist/src/lib/plot/ZoomRect.svelte +23 -0
  183. package/dist/src/lib/plot/adaptive-density.ts +316 -0
  184. package/dist/src/lib/plot/auto-place.ts +184 -0
  185. package/dist/src/lib/plot/axis-utils.ts +122 -0
  186. package/dist/src/lib/plot/binned-scatter-types.ts +83 -0
  187. package/dist/src/lib/plot/data-cleaning.ts +1069 -0
  188. package/dist/src/lib/plot/data-transform.ts +69 -0
  189. package/dist/src/lib/plot/defaults.ts +9 -0
  190. package/dist/src/lib/plot/fill-utils.ts +494 -0
  191. package/dist/src/lib/plot/hover-lock.svelte.ts +60 -0
  192. package/dist/src/lib/plot/index.ts +53 -0
  193. package/dist/src/lib/plot/interactions.ts +119 -0
  194. package/dist/src/lib/plot/layout.ts +425 -0
  195. package/dist/src/lib/plot/reference-line.ts +426 -0
  196. package/dist/src/lib/plot/scales.ts +654 -0
  197. package/dist/src/lib/plot/svg.ts +23 -0
  198. package/dist/src/lib/plot/types.ts +1144 -0
  199. package/dist/src/lib/plot/utils/label-placement.ts +541 -0
  200. package/dist/src/lib/plot/utils/series-visibility.ts +140 -0
  201. package/dist/src/lib/plot/utils.ts +11 -0
  202. package/dist/src/lib/rdf/RdfPlot.svelte +247 -0
  203. package/dist/src/lib/rdf/calc-rdf.ts +167 -0
  204. package/dist/src/lib/rdf/index.ts +27 -0
  205. package/dist/src/lib/sanitize.ts +126 -0
  206. package/dist/src/lib/settings.ts +1479 -0
  207. package/dist/src/lib/spectral/Bands.svelte +1040 -0
  208. package/dist/src/lib/spectral/BandsAndDos.svelte +134 -0
  209. package/dist/src/lib/spectral/BrillouinBandsDos.svelte +252 -0
  210. package/dist/src/lib/spectral/Dos.svelte +697 -0
  211. package/dist/src/lib/spectral/helpers.ts +1381 -0
  212. package/dist/src/lib/spectral/index.ts +8 -0
  213. package/dist/src/lib/spectral/types.ts +112 -0
  214. package/dist/src/lib/state.svelte.ts +64 -0
  215. package/dist/src/lib/structure/Arrow.svelte +72 -0
  216. package/dist/src/lib/structure/AtomLegend.svelte +815 -0
  217. package/dist/src/lib/structure/Bond.svelte +140 -0
  218. package/dist/src/lib/structure/CanvasTooltip.svelte +33 -0
  219. package/dist/src/lib/structure/CellSelect.svelte +349 -0
  220. package/dist/src/lib/structure/Cylinder.svelte +45 -0
  221. package/dist/src/lib/structure/Lattice.svelte +196 -0
  222. package/dist/src/lib/structure/Structure.svelte +2248 -0
  223. package/dist/src/lib/structure/StructureControls.svelte +1273 -0
  224. package/dist/src/lib/structure/StructureExportPane.svelte +252 -0
  225. package/dist/src/lib/structure/StructureInfoPane.svelte +737 -0
  226. package/dist/src/lib/structure/StructureScene.svelte +2255 -0
  227. package/dist/src/lib/structure/atom-properties.ts +316 -0
  228. package/dist/src/lib/structure/bond-order-perception.ts +447 -0
  229. package/dist/src/lib/structure/bonding.ts +944 -0
  230. package/dist/src/lib/structure/export.ts +861 -0
  231. package/dist/src/lib/structure/index.ts +291 -0
  232. package/dist/src/lib/structure/label-placement.ts +130 -0
  233. package/dist/src/lib/structure/measure.ts +45 -0
  234. package/dist/src/lib/structure/parse.ts +1705 -0
  235. package/dist/src/lib/structure/partial-occupancy.ts +183 -0
  236. package/dist/src/lib/structure/pbc.ts +164 -0
  237. package/dist/src/lib/structure/supercell.ts +226 -0
  238. package/dist/src/lib/structure/validation.ts +11 -0
  239. package/dist/src/lib/symmetry/SymmetryStats.svelte +226 -0
  240. package/dist/src/lib/symmetry/WyckoffTable.svelte +120 -0
  241. package/dist/src/lib/symmetry/cell-transform.ts +118 -0
  242. package/dist/src/lib/symmetry/index.ts +348 -0
  243. package/dist/src/lib/symmetry/spacegroups.ts +404 -0
  244. package/dist/src/lib/table/HeatmapTable.svelte +1833 -0
  245. package/dist/src/lib/table/ToggleMenu.svelte +385 -0
  246. package/dist/src/lib/table/index.ts +139 -0
  247. package/dist/src/lib/theme/ThemeControl.svelte +53 -0
  248. package/dist/src/lib/theme/index.ts +107 -0
  249. package/dist/src/lib/theme/themes.mjs +297 -0
  250. package/dist/src/lib/time.ts +71 -0
  251. package/dist/src/lib/tooltip/TooltipContent.svelte +58 -0
  252. package/dist/src/lib/tooltip/index.ts +2 -0
  253. package/dist/src/lib/tooltip/types.ts +13 -0
  254. package/dist/src/lib/trajectory/Trajectory.svelte +1545 -0
  255. package/dist/src/lib/trajectory/TrajectoryError.svelte +128 -0
  256. package/dist/src/lib/trajectory/TrajectoryExportPane.svelte +357 -0
  257. package/dist/src/lib/trajectory/TrajectoryInfoPane.svelte +313 -0
  258. package/dist/src/lib/trajectory/constants.ts +7 -0
  259. package/dist/src/lib/trajectory/extract.ts +196 -0
  260. package/dist/src/lib/trajectory/format-detect.ts +96 -0
  261. package/dist/src/lib/trajectory/frame-reader.ts +456 -0
  262. package/dist/src/lib/trajectory/helpers.ts +217 -0
  263. package/dist/src/lib/trajectory/index.ts +218 -0
  264. package/dist/src/lib/trajectory/parse/ase.ts +109 -0
  265. package/dist/src/lib/trajectory/parse/hdf5.ts +173 -0
  266. package/dist/src/lib/trajectory/parse/index.ts +411 -0
  267. package/dist/src/lib/trajectory/parse/lammps.ts +215 -0
  268. package/dist/src/lib/trajectory/parse/vasp.ts +102 -0
  269. package/dist/src/lib/trajectory/parse/xyz.ts +143 -0
  270. package/dist/src/lib/trajectory/plotting.ts +599 -0
  271. package/dist/src/lib/trajectory/types.ts +13 -0
  272. package/dist/src/lib/utils.ts +56 -0
  273. package/dist/src/lib/xrd/XrdPlot.svelte +615 -0
  274. package/dist/src/lib/xrd/broadening.ts +130 -0
  275. package/dist/src/lib/xrd/calc-xrd.ts +397 -0
  276. package/dist/src/lib/xrd/index.ts +38 -0
  277. package/dist/src/lib/xrd/parse.ts +858 -0
  278. package/dist/webview.js +29421 -0
  279. package/icon.png +0 -0
  280. package/license +1 -1
  281. package/matterviz-0.3.2.vsix +0 -0
  282. package/matterviz-0.3.4.vsix +0 -0
  283. package/matterviz-0.3.5.vsix +0 -0
  284. package/package.json +1461 -231
  285. package/readme.md +171 -98
  286. package/scripts/sync-config.ts +101 -0
  287. package/src/declarations.d.ts +2 -0
  288. package/src/extension.ts +972 -0
  289. package/src/node-io.ts +65 -0
  290. package/src/types.ts +17 -0
  291. package/src/webview/JsonBrowser.svelte +1079 -0
  292. package/src/webview/PlotPanel.svelte +346 -0
  293. package/src/webview/detect.ts +444 -0
  294. package/src/webview/main.ts +764 -0
  295. package/src/webview/plot-utils.ts +250 -0
  296. package/test-fixtures/all-viz-types.json.gz +0 -0
  297. package/test-fixtures/plot-demo-data.json.gz +0 -0
  298. package/tests/detect.test.ts +604 -0
  299. package/tests/extension.test.ts +2041 -0
  300. package/tests/node-io.test.ts +39 -0
  301. package/tests/plot-utils.test.ts +302 -0
  302. package/tests/vite-plugin-json-gz.test.ts +114 -0
  303. package/tests/vscode-mock.ts +18 -0
  304. package/tests/webview.test.ts +231 -0
  305. package/tsconfig.json +20 -0
  306. package/vite-plugin-json-gz.ts +29 -0
  307. package/vite.config.ts +34 -0
  308. package/vite.extension.config.ts +34 -0
  309. package/dist/EmptyState.svelte.d.ts +0 -9
  310. package/dist/FilePicker.svelte +0 -360
  311. package/dist/FilePicker.svelte.d.ts +0 -17
  312. package/dist/Icon.svelte.d.ts +0 -13
  313. package/dist/MillerIndexInput.svelte +0 -66
  314. package/dist/MillerIndexInput.svelte.d.ts +0 -7
  315. package/dist/api/mp.d.ts +0 -6
  316. package/dist/api/mp.js +0 -22
  317. package/dist/api/optimade.d.ts +0 -45
  318. package/dist/api/optimade.js +0 -135
  319. package/dist/app.css +0 -240
  320. package/dist/brillouin/BrillouinZone.svelte +0 -543
  321. package/dist/brillouin/BrillouinZone.svelte.d.ts +0 -83
  322. package/dist/brillouin/BrillouinZoneControls.svelte +0 -144
  323. package/dist/brillouin/BrillouinZoneControls.svelte.d.ts +0 -17
  324. package/dist/brillouin/BrillouinZoneExportPane.svelte +0 -148
  325. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +0 -15
  326. package/dist/brillouin/BrillouinZoneInfoPane.svelte +0 -146
  327. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +0 -13
  328. package/dist/brillouin/BrillouinZoneScene.svelte +0 -476
  329. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +0 -48
  330. package/dist/brillouin/BrillouinZoneTooltip.svelte +0 -92
  331. package/dist/brillouin/BrillouinZoneTooltip.svelte.d.ts +0 -8
  332. package/dist/brillouin/compute.d.ts +0 -17
  333. package/dist/brillouin/compute.js +0 -422
  334. package/dist/brillouin/index.d.ts +0 -8
  335. package/dist/brillouin/index.js +0 -8
  336. package/dist/brillouin/types.d.ts +0 -48
  337. package/dist/brillouin/types.js +0 -1
  338. package/dist/chempot-diagram/ChemPotDiagram.svelte +0 -327
  339. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +0 -13
  340. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +0 -847
  341. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +0 -16
  342. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +0 -3194
  343. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +0 -16
  344. package/dist/chempot-diagram/ChemPotScene3D.svelte.d.ts +0 -7
  345. package/dist/chempot-diagram/async-compute.svelte.d.ts +0 -3
  346. package/dist/chempot-diagram/async-compute.svelte.js +0 -77
  347. package/dist/chempot-diagram/chempot-worker.d.ts +0 -1
  348. package/dist/chempot-diagram/chempot-worker.js +0 -11
  349. package/dist/chempot-diagram/color.d.ts +0 -10
  350. package/dist/chempot-diagram/color.js +0 -32
  351. package/dist/chempot-diagram/compute.d.ts +0 -48
  352. package/dist/chempot-diagram/compute.js +0 -812
  353. package/dist/chempot-diagram/index.d.ts +0 -6
  354. package/dist/chempot-diagram/index.js +0 -6
  355. package/dist/chempot-diagram/pointer.d.ts +0 -16
  356. package/dist/chempot-diagram/pointer.js +0 -40
  357. package/dist/chempot-diagram/temperature.d.ts +0 -15
  358. package/dist/chempot-diagram/temperature.js +0 -36
  359. package/dist/chempot-diagram/types.d.ts +0 -86
  360. package/dist/chempot-diagram/types.js +0 -28
  361. package/dist/colors/index.d.ts +0 -47
  362. package/dist/colors/index.js +0 -203
  363. package/dist/composition/BarChart.svelte +0 -297
  364. package/dist/composition/BarChart.svelte.d.ts +0 -39
  365. package/dist/composition/BubbleChart.svelte +0 -218
  366. package/dist/composition/BubbleChart.svelte.d.ts +0 -28
  367. package/dist/composition/Composition.svelte +0 -164
  368. package/dist/composition/Composition.svelte.d.ts +0 -15
  369. package/dist/composition/Formula.svelte +0 -265
  370. package/dist/composition/Formula.svelte.d.ts +0 -19
  371. package/dist/composition/FormulaFilter.svelte +0 -1259
  372. package/dist/composition/FormulaFilter.svelte.d.ts +0 -51
  373. package/dist/composition/PieChart.svelte +0 -323
  374. package/dist/composition/PieChart.svelte.d.ts +0 -37
  375. package/dist/composition/format.d.ts +0 -15
  376. package/dist/composition/format.js +0 -109
  377. package/dist/composition/index.d.ts +0 -20
  378. package/dist/composition/index.js +0 -14
  379. package/dist/composition/parse.d.ts +0 -55
  380. package/dist/composition/parse.js +0 -459
  381. package/dist/constants.d.ts +0 -29
  382. package/dist/constants.js +0 -105
  383. package/dist/controls.d.ts +0 -14
  384. package/dist/controls.js +0 -30
  385. package/dist/convex-hull/ConvexHull.svelte +0 -157
  386. package/dist/convex-hull/ConvexHull.svelte.d.ts +0 -13
  387. package/dist/convex-hull/ConvexHull2D.svelte +0 -813
  388. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +0 -11
  389. package/dist/convex-hull/ConvexHull3D.svelte +0 -1788
  390. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +0 -8
  391. package/dist/convex-hull/ConvexHull4D.svelte +0 -1374
  392. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +0 -8
  393. package/dist/convex-hull/ConvexHullControls.svelte +0 -546
  394. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +0 -48
  395. package/dist/convex-hull/ConvexHullInfoPane.svelte +0 -115
  396. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +0 -18
  397. package/dist/convex-hull/ConvexHullStats.svelte +0 -905
  398. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +0 -15
  399. package/dist/convex-hull/ConvexHullTooltip.svelte +0 -131
  400. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +0 -33
  401. package/dist/convex-hull/GasPressureControls.svelte +0 -247
  402. package/dist/convex-hull/GasPressureControls.svelte.d.ts +0 -11
  403. package/dist/convex-hull/StructurePopup.svelte +0 -116
  404. package/dist/convex-hull/StructurePopup.svelte.d.ts +0 -18
  405. package/dist/convex-hull/TemperatureSlider.svelte +0 -137
  406. package/dist/convex-hull/TemperatureSlider.svelte.d.ts +0 -8
  407. package/dist/convex-hull/barycentric-coords.d.ts +0 -18
  408. package/dist/convex-hull/barycentric-coords.js +0 -182
  409. package/dist/convex-hull/demo-temperature.d.ts +0 -6
  410. package/dist/convex-hull/demo-temperature.js +0 -40
  411. package/dist/convex-hull/gas-thermodynamics.d.ts +0 -16
  412. package/dist/convex-hull/gas-thermodynamics.js +0 -316
  413. package/dist/convex-hull/helpers.d.ts +0 -103
  414. package/dist/convex-hull/helpers.js +0 -671
  415. package/dist/convex-hull/index.d.ts +0 -118
  416. package/dist/convex-hull/index.js +0 -57
  417. package/dist/convex-hull/thermodynamics.d.ts +0 -66
  418. package/dist/convex-hull/thermodynamics.js +0 -1752
  419. package/dist/convex-hull/types.d.ts +0 -162
  420. package/dist/convex-hull/types.js +0 -36
  421. package/dist/coordination/CoordinationBarPlot.svelte +0 -311
  422. package/dist/coordination/CoordinationBarPlot.svelte.d.ts +0 -30
  423. package/dist/coordination/calc-coordination.d.ts +0 -15
  424. package/dist/coordination/calc-coordination.js +0 -63
  425. package/dist/coordination/index.d.ts +0 -8
  426. package/dist/coordination/index.js +0 -7
  427. package/dist/element/BohrAtom.svelte +0 -149
  428. package/dist/element/BohrAtom.svelte.d.ts +0 -20
  429. package/dist/element/ElementHeading.svelte +0 -26
  430. package/dist/element/ElementHeading.svelte.d.ts +0 -8
  431. package/dist/element/ElementPhoto.svelte +0 -57
  432. package/dist/element/ElementPhoto.svelte.d.ts +0 -9
  433. package/dist/element/ElementStats.svelte +0 -80
  434. package/dist/element/ElementStats.svelte.d.ts +0 -8
  435. package/dist/element/ElementTile.svelte +0 -484
  436. package/dist/element/ElementTile.svelte.d.ts +0 -29
  437. package/dist/element/Nucleus.svelte.d.ts +0 -17
  438. package/dist/element/data.d.ts +0 -3
  439. package/dist/element/data.js +0 -2
  440. package/dist/element/data.json.gz.d.ts +0 -2
  441. package/dist/element/index.d.ts +0 -8
  442. package/dist/element/index.js +0 -8
  443. package/dist/element/types.d.ts +0 -57
  444. package/dist/element/types.js +0 -1
  445. package/dist/feedback/ClickFeedback.svelte +0 -58
  446. package/dist/feedback/ClickFeedback.svelte.d.ts +0 -12
  447. package/dist/feedback/DragOverlay.svelte +0 -42
  448. package/dist/feedback/DragOverlay.svelte.d.ts +0 -7
  449. package/dist/feedback/Spinner.svelte.d.ts +0 -7
  450. package/dist/feedback/StatusMessage.svelte.d.ts +0 -9
  451. package/dist/feedback/index.d.ts +0 -4
  452. package/dist/feedback/index.js +0 -4
  453. package/dist/fermi-surface/FermiSlice.svelte +0 -189
  454. package/dist/fermi-surface/FermiSlice.svelte.d.ts +0 -24
  455. package/dist/fermi-surface/FermiSurface.svelte +0 -597
  456. package/dist/fermi-surface/FermiSurface.svelte.d.ts +0 -83
  457. package/dist/fermi-surface/FermiSurfaceControls.svelte +0 -452
  458. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +0 -35
  459. package/dist/fermi-surface/FermiSurfaceScene.svelte +0 -792
  460. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +0 -50
  461. package/dist/fermi-surface/FermiSurfaceTooltip.svelte +0 -111
  462. package/dist/fermi-surface/FermiSurfaceTooltip.svelte.d.ts +0 -8
  463. package/dist/fermi-surface/compute.d.ts +0 -5
  464. package/dist/fermi-surface/compute.js +0 -538
  465. package/dist/fermi-surface/constants.d.ts +0 -9
  466. package/dist/fermi-surface/constants.js +0 -27
  467. package/dist/fermi-surface/export.d.ts +0 -5
  468. package/dist/fermi-surface/export.js +0 -63
  469. package/dist/fermi-surface/index.d.ts +0 -12
  470. package/dist/fermi-surface/index.js +0 -13
  471. package/dist/fermi-surface/marching-cubes.d.ts +0 -2
  472. package/dist/fermi-surface/marching-cubes.js +0 -2
  473. package/dist/fermi-surface/parse.d.ts +0 -2
  474. package/dist/fermi-surface/parse.js +0 -495
  475. package/dist/fermi-surface/symmetry.d.ts +0 -3
  476. package/dist/fermi-surface/symmetry.js +0 -46
  477. package/dist/fermi-surface/types.d.ts +0 -113
  478. package/dist/fermi-surface/types.js +0 -4
  479. package/dist/heatmap-matrix/HeatmapMatrix.svelte +0 -1527
  480. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +0 -110
  481. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +0 -225
  482. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +0 -30
  483. package/dist/heatmap-matrix/index.d.ts +0 -53
  484. package/dist/heatmap-matrix/index.js +0 -100
  485. package/dist/heatmap-matrix/shared.d.ts +0 -2
  486. package/dist/heatmap-matrix/shared.js +0 -4
  487. package/dist/icons.d.ts +0 -569
  488. package/dist/icons.js +0 -648
  489. package/dist/index.d.ts +0 -39
  490. package/dist/index.js +0 -39
  491. package/dist/io/decompress.d.ts +0 -10
  492. package/dist/io/decompress.js +0 -69
  493. package/dist/io/export.d.ts +0 -16
  494. package/dist/io/export.js +0 -312
  495. package/dist/io/fetch.d.ts +0 -5
  496. package/dist/io/fetch.js +0 -39
  497. package/dist/io/file-drop.d.ts +0 -7
  498. package/dist/io/file-drop.js +0 -43
  499. package/dist/io/index.d.ts +0 -7
  500. package/dist/io/index.js +0 -7
  501. package/dist/io/is-binary.d.ts +0 -1
  502. package/dist/io/is-binary.js +0 -5
  503. package/dist/io/types.d.ts +0 -8
  504. package/dist/io/types.js +0 -1
  505. package/dist/io/url-drop.d.ts +0 -2
  506. package/dist/io/url-drop.js +0 -117
  507. package/dist/isosurface/Isosurface.svelte +0 -285
  508. package/dist/isosurface/Isosurface.svelte.d.ts +0 -8
  509. package/dist/isosurface/IsosurfaceControls.svelte +0 -291
  510. package/dist/isosurface/IsosurfaceControls.svelte.d.ts +0 -9
  511. package/dist/isosurface/index.d.ts +0 -5
  512. package/dist/isosurface/index.js +0 -6
  513. package/dist/isosurface/parse.d.ts +0 -6
  514. package/dist/isosurface/parse.js +0 -553
  515. package/dist/isosurface/slice.d.ts +0 -11
  516. package/dist/isosurface/slice.js +0 -140
  517. package/dist/isosurface/types.d.ts +0 -56
  518. package/dist/isosurface/types.js +0 -227
  519. package/dist/labels.d.ts +0 -53
  520. package/dist/labels.js +0 -274
  521. package/dist/layout/FullscreenToggle.svelte +0 -50
  522. package/dist/layout/FullscreenToggle.svelte.d.ts +0 -7
  523. package/dist/layout/InfoCard.svelte +0 -120
  524. package/dist/layout/InfoCard.svelte.d.ts +0 -21
  525. package/dist/layout/InfoTag.svelte +0 -183
  526. package/dist/layout/InfoTag.svelte.d.ts +0 -19
  527. package/dist/layout/PropertyFilter.svelte +0 -244
  528. package/dist/layout/PropertyFilter.svelte.d.ts +0 -24
  529. package/dist/layout/SettingsSection.svelte +0 -148
  530. package/dist/layout/SettingsSection.svelte.d.ts +0 -17
  531. package/dist/layout/SubpageGrid.svelte +0 -82
  532. package/dist/layout/SubpageGrid.svelte.d.ts +0 -14
  533. package/dist/layout/fullscreen.d.ts +0 -9
  534. package/dist/layout/fullscreen.js +0 -53
  535. package/dist/layout/index.d.ts +0 -10
  536. package/dist/layout/index.js +0 -8
  537. package/dist/layout/json-tree/JsonNode.svelte +0 -547
  538. package/dist/layout/json-tree/JsonNode.svelte.d.ts +0 -11
  539. package/dist/layout/json-tree/JsonTree.svelte +0 -1222
  540. package/dist/layout/json-tree/JsonTree.svelte.d.ts +0 -6
  541. package/dist/layout/json-tree/JsonValue.svelte +0 -334
  542. package/dist/layout/json-tree/JsonValue.svelte.d.ts +0 -9
  543. package/dist/layout/json-tree/index.d.ts +0 -3
  544. package/dist/layout/json-tree/index.js +0 -3
  545. package/dist/layout/json-tree/types.d.ts +0 -73
  546. package/dist/layout/json-tree/types.js +0 -3
  547. package/dist/layout/json-tree/utils.d.ts +0 -29
  548. package/dist/layout/json-tree/utils.js +0 -648
  549. package/dist/marching-cubes.d.ts +0 -14
  550. package/dist/marching-cubes.js +0 -542
  551. package/dist/math.d.ts +0 -91
  552. package/dist/math.js +0 -896
  553. package/dist/overlays/ContextMenu.svelte +0 -162
  554. package/dist/overlays/ContextMenu.svelte.d.ts +0 -25
  555. package/dist/overlays/DraggablePane.svelte +0 -564
  556. package/dist/overlays/DraggablePane.svelte.d.ts +0 -36
  557. package/dist/overlays/index.d.ts +0 -2
  558. package/dist/overlays/index.js +0 -2
  559. package/dist/periodic-table/PeriodicTable.svelte +0 -469
  560. package/dist/periodic-table/PeriodicTable.svelte.d.ts +0 -55
  561. package/dist/periodic-table/PeriodicTableControls.svelte +0 -557
  562. package/dist/periodic-table/PeriodicTableControls.svelte.d.ts +0 -24
  563. package/dist/periodic-table/PropertySelect.svelte +0 -37
  564. package/dist/periodic-table/PropertySelect.svelte.d.ts +0 -13
  565. package/dist/periodic-table/TableInset.svelte.d.ts +0 -9
  566. package/dist/periodic-table/index.d.ts +0 -10
  567. package/dist/periodic-table/index.js +0 -4
  568. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +0 -1086
  569. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +0 -44
  570. package/dist/phase-diagram/PhaseDiagramControls.svelte +0 -451
  571. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +0 -30
  572. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +0 -126
  573. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +0 -15
  574. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +0 -192
  575. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +0 -19
  576. package/dist/phase-diagram/PhaseDiagramTooltip.svelte +0 -392
  577. package/dist/phase-diagram/PhaseDiagramTooltip.svelte.d.ts +0 -16
  578. package/dist/phase-diagram/TdbInfoPanel.svelte +0 -203
  579. package/dist/phase-diagram/TdbInfoPanel.svelte.d.ts +0 -12
  580. package/dist/phase-diagram/build-diagram.d.ts +0 -11
  581. package/dist/phase-diagram/build-diagram.js +0 -167
  582. package/dist/phase-diagram/colors.d.ts +0 -35
  583. package/dist/phase-diagram/colors.js +0 -51
  584. package/dist/phase-diagram/diagram-input.d.ts +0 -33
  585. package/dist/phase-diagram/diagram-input.js +0 -3
  586. package/dist/phase-diagram/index.d.ts +0 -13
  587. package/dist/phase-diagram/index.js +0 -13
  588. package/dist/phase-diagram/parse.d.ts +0 -55
  589. package/dist/phase-diagram/parse.js +0 -276
  590. package/dist/phase-diagram/svg-to-diagram.d.ts +0 -2
  591. package/dist/phase-diagram/svg-to-diagram.js +0 -869
  592. package/dist/phase-diagram/types.d.ts +0 -99
  593. package/dist/phase-diagram/types.js +0 -1
  594. package/dist/phase-diagram/utils.d.ts +0 -118
  595. package/dist/phase-diagram/utils.js +0 -606
  596. package/dist/plot/AxisLabel.svelte +0 -51
  597. package/dist/plot/AxisLabel.svelte.d.ts +0 -16
  598. package/dist/plot/BarPlot.svelte +0 -2256
  599. package/dist/plot/BarPlot.svelte.d.ts +0 -82
  600. package/dist/plot/BarPlotControls.svelte +0 -66
  601. package/dist/plot/BarPlotControls.svelte.d.ts +0 -18
  602. package/dist/plot/ColorBar.svelte +0 -719
  603. package/dist/plot/ColorBar.svelte.d.ts +0 -31
  604. package/dist/plot/ColorScaleSelect.svelte +0 -54
  605. package/dist/plot/ColorScaleSelect.svelte.d.ts +0 -15
  606. package/dist/plot/ElementScatter.svelte +0 -63
  607. package/dist/plot/ElementScatter.svelte.d.ts +0 -14
  608. package/dist/plot/FillArea.svelte +0 -226
  609. package/dist/plot/FillArea.svelte.d.ts +0 -20
  610. package/dist/plot/Histogram.svelte +0 -1654
  611. package/dist/plot/Histogram.svelte.d.ts +0 -50
  612. package/dist/plot/HistogramControls.svelte +0 -212
  613. package/dist/plot/HistogramControls.svelte.d.ts +0 -22
  614. package/dist/plot/InteractiveAxisLabel.svelte +0 -94
  615. package/dist/plot/InteractiveAxisLabel.svelte.d.ts +0 -14
  616. package/dist/plot/Line.svelte +0 -85
  617. package/dist/plot/Line.svelte.d.ts +0 -15
  618. package/dist/plot/PlotControls.svelte +0 -537
  619. package/dist/plot/PlotControls.svelte.d.ts +0 -4
  620. package/dist/plot/PlotLegend.svelte +0 -498
  621. package/dist/plot/PlotLegend.svelte.d.ts +0 -25
  622. package/dist/plot/PlotTooltip.svelte +0 -67
  623. package/dist/plot/PlotTooltip.svelte.d.ts +0 -17
  624. package/dist/plot/PortalSelect.svelte +0 -253
  625. package/dist/plot/PortalSelect.svelte.d.ts +0 -16
  626. package/dist/plot/ReferenceLine.svelte.d.ts +0 -20
  627. package/dist/plot/ReferenceLine3D.svelte +0 -154
  628. package/dist/plot/ReferenceLine3D.svelte.d.ts +0 -14
  629. package/dist/plot/ReferencePlane.svelte +0 -178
  630. package/dist/plot/ReferencePlane.svelte.d.ts +0 -14
  631. package/dist/plot/ScatterPlot.svelte +0 -2831
  632. package/dist/plot/ScatterPlot.svelte.d.ts +0 -92
  633. package/dist/plot/ScatterPlot3D.svelte +0 -499
  634. package/dist/plot/ScatterPlot3D.svelte.d.ts +0 -94
  635. package/dist/plot/ScatterPlot3DControls.svelte +0 -437
  636. package/dist/plot/ScatterPlot3DControls.svelte.d.ts +0 -20
  637. package/dist/plot/ScatterPlot3DScene.svelte +0 -912
  638. package/dist/plot/ScatterPlot3DScene.svelte.d.ts +0 -74
  639. package/dist/plot/ScatterPlotControls.svelte +0 -307
  640. package/dist/plot/ScatterPlotControls.svelte.d.ts +0 -17
  641. package/dist/plot/ScatterPoint.svelte +0 -185
  642. package/dist/plot/ScatterPoint.svelte.d.ts +0 -19
  643. package/dist/plot/SpacegroupBarPlot.svelte +0 -292
  644. package/dist/plot/SpacegroupBarPlot.svelte.d.ts +0 -9
  645. package/dist/plot/Surface3D.svelte +0 -200
  646. package/dist/plot/Surface3D.svelte.d.ts +0 -13
  647. package/dist/plot/ZeroLines.svelte +0 -96
  648. package/dist/plot/ZeroLines.svelte.d.ts +0 -32
  649. package/dist/plot/ZoomRect.svelte +0 -23
  650. package/dist/plot/ZoomRect.svelte.d.ts +0 -8
  651. package/dist/plot/axis-utils.d.ts +0 -19
  652. package/dist/plot/axis-utils.js +0 -80
  653. package/dist/plot/data-cleaning.d.ts +0 -37
  654. package/dist/plot/data-cleaning.js +0 -855
  655. package/dist/plot/data-transform.d.ts +0 -16
  656. package/dist/plot/data-transform.js +0 -45
  657. package/dist/plot/defaults.d.ts +0 -19
  658. package/dist/plot/defaults.js +0 -9
  659. package/dist/plot/fill-utils.d.ts +0 -51
  660. package/dist/plot/fill-utils.js +0 -337
  661. package/dist/plot/hover-lock.svelte.d.ts +0 -14
  662. package/dist/plot/hover-lock.svelte.js +0 -46
  663. package/dist/plot/index.d.ts +0 -43
  664. package/dist/plot/index.js +0 -37
  665. package/dist/plot/interactions.d.ts +0 -12
  666. package/dist/plot/interactions.js +0 -100
  667. package/dist/plot/layout.d.ts +0 -60
  668. package/dist/plot/layout.js +0 -230
  669. package/dist/plot/reference-line.d.ts +0 -60
  670. package/dist/plot/reference-line.js +0 -316
  671. package/dist/plot/scales.d.ts +0 -48
  672. package/dist/plot/scales.js +0 -484
  673. package/dist/plot/svg.d.ts +0 -1
  674. package/dist/plot/svg.js +0 -11
  675. package/dist/plot/types.d.ts +0 -863
  676. package/dist/plot/types.js +0 -103
  677. package/dist/plot/utils/label-placement.d.ts +0 -47
  678. package/dist/plot/utils/label-placement.js +0 -256
  679. package/dist/plot/utils/series-visibility.d.ts +0 -9
  680. package/dist/plot/utils/series-visibility.js +0 -67
  681. package/dist/plot/utils.d.ts +0 -1
  682. package/dist/plot/utils.js +0 -14
  683. package/dist/rdf/RdfPlot.svelte +0 -247
  684. package/dist/rdf/RdfPlot.svelte.d.ts +0 -27
  685. package/dist/rdf/calc-rdf.d.ts +0 -4
  686. package/dist/rdf/calc-rdf.js +0 -111
  687. package/dist/rdf/index.d.ts +0 -23
  688. package/dist/rdf/index.js +0 -2
  689. package/dist/sanitize.d.ts +0 -4
  690. package/dist/sanitize.js +0 -107
  691. package/dist/settings.d.ts +0 -253
  692. package/dist/settings.js +0 -1123
  693. package/dist/spectral/Bands.svelte +0 -1040
  694. package/dist/spectral/Bands.svelte.d.ts +0 -40
  695. package/dist/spectral/BandsAndDos.svelte +0 -128
  696. package/dist/spectral/BandsAndDos.svelte.d.ts +0 -18
  697. package/dist/spectral/BrillouinBandsDos.svelte +0 -248
  698. package/dist/spectral/BrillouinBandsDos.svelte.d.ts +0 -20
  699. package/dist/spectral/Dos.svelte +0 -697
  700. package/dist/spectral/Dos.svelte.d.ts +0 -29
  701. package/dist/spectral/helpers.d.ts +0 -117
  702. package/dist/spectral/helpers.js +0 -1023
  703. package/dist/spectral/index.d.ts +0 -6
  704. package/dist/spectral/index.js +0 -7
  705. package/dist/spectral/types.d.ts +0 -84
  706. package/dist/spectral/types.js +0 -2
  707. package/dist/state.svelte.d.ts +0 -25
  708. package/dist/state.svelte.js +0 -45
  709. package/dist/structure/Arrow.svelte +0 -72
  710. package/dist/structure/Arrow.svelte.d.ts +0 -15
  711. package/dist/structure/AtomLegend.svelte +0 -798
  712. package/dist/structure/AtomLegend.svelte.d.ts +0 -34
  713. package/dist/structure/Bond.svelte +0 -140
  714. package/dist/structure/Bond.svelte.d.ts +0 -9
  715. package/dist/structure/CanvasTooltip.svelte +0 -33
  716. package/dist/structure/CanvasTooltip.svelte.d.ts +0 -12
  717. package/dist/structure/CellSelect.svelte +0 -351
  718. package/dist/structure/CellSelect.svelte.d.ts +0 -13
  719. package/dist/structure/Cylinder.svelte +0 -45
  720. package/dist/structure/Cylinder.svelte.d.ts +0 -10
  721. package/dist/structure/Lattice.svelte +0 -196
  722. package/dist/structure/Lattice.svelte.d.ts +0 -17
  723. package/dist/structure/Structure.svelte +0 -1857
  724. package/dist/structure/Structure.svelte.d.ts +0 -83
  725. package/dist/structure/StructureControls.svelte +0 -1184
  726. package/dist/structure/StructureControls.svelte.d.ts +0 -31
  727. package/dist/structure/StructureExportPane.svelte +0 -251
  728. package/dist/structure/StructureExportPane.svelte.d.ts +0 -17
  729. package/dist/structure/StructureInfoPane.svelte +0 -434
  730. package/dist/structure/StructureInfoPane.svelte.d.ts +0 -18
  731. package/dist/structure/StructureScene.svelte +0 -1574
  732. package/dist/structure/StructureScene.svelte.d.ts +0 -104
  733. package/dist/structure/atom-properties.d.ts +0 -37
  734. package/dist/structure/atom-properties.js +0 -198
  735. package/dist/structure/bonding.d.ts +0 -33
  736. package/dist/structure/bonding.js +0 -304
  737. package/dist/structure/export.d.ts +0 -20
  738. package/dist/structure/export.js +0 -725
  739. package/dist/structure/ferrox-wasm-types.d.ts +0 -46
  740. package/dist/structure/ferrox-wasm-types.js +0 -18
  741. package/dist/structure/ferrox-wasm.d.ts +0 -94
  742. package/dist/structure/ferrox-wasm.js +0 -249
  743. package/dist/structure/index.d.ts +0 -110
  744. package/dist/structure/index.js +0 -168
  745. package/dist/structure/measure.d.ts +0 -6
  746. package/dist/structure/measure.js +0 -29
  747. package/dist/structure/parse.d.ts +0 -65
  748. package/dist/structure/parse.js +0 -1374
  749. package/dist/structure/partial-occupancy.d.ts +0 -25
  750. package/dist/structure/partial-occupancy.js +0 -99
  751. package/dist/structure/pbc.d.ts +0 -9
  752. package/dist/structure/pbc.js +0 -123
  753. package/dist/structure/supercell.d.ts +0 -8
  754. package/dist/structure/supercell.js +0 -137
  755. package/dist/structure/validation.d.ts +0 -2
  756. package/dist/structure/validation.js +0 -10
  757. package/dist/symmetry/SymmetryStats.svelte +0 -226
  758. package/dist/symmetry/SymmetryStats.svelte.d.ts +0 -21
  759. package/dist/symmetry/WyckoffTable.svelte +0 -113
  760. package/dist/symmetry/WyckoffTable.svelte.d.ts +0 -11
  761. package/dist/symmetry/cell-transform.d.ts +0 -12
  762. package/dist/symmetry/cell-transform.js +0 -77
  763. package/dist/symmetry/index.d.ts +0 -43
  764. package/dist/symmetry/index.js +0 -229
  765. package/dist/symmetry/spacegroups.d.ts +0 -9
  766. package/dist/symmetry/spacegroups.js +0 -394
  767. package/dist/table/HeatmapTable.svelte +0 -1854
  768. package/dist/table/HeatmapTable.svelte.d.ts +0 -49
  769. package/dist/table/ToggleMenu.svelte +0 -376
  770. package/dist/table/ToggleMenu.svelte.d.ts +0 -11
  771. package/dist/table/index.d.ts +0 -74
  772. package/dist/table/index.js +0 -38
  773. package/dist/theme/ThemeControl.svelte +0 -53
  774. package/dist/theme/ThemeControl.svelte.d.ts +0 -9
  775. package/dist/theme/index.d.ts +0 -29
  776. package/dist/theme/index.js +0 -79
  777. package/dist/theme/themes.mjs +0 -285
  778. package/dist/time.d.ts +0 -4
  779. package/dist/time.js +0 -70
  780. package/dist/tooltip/TooltipContent.svelte +0 -58
  781. package/dist/tooltip/TooltipContent.svelte.d.ts +0 -31
  782. package/dist/tooltip/index.d.ts +0 -2
  783. package/dist/tooltip/index.js +0 -2
  784. package/dist/tooltip/types.d.ts +0 -8
  785. package/dist/tooltip/types.js +0 -1
  786. package/dist/trajectory/Trajectory.svelte +0 -1517
  787. package/dist/trajectory/Trajectory.svelte.d.ts +0 -77
  788. package/dist/trajectory/TrajectoryError.svelte +0 -128
  789. package/dist/trajectory/TrajectoryError.svelte.d.ts +0 -13
  790. package/dist/trajectory/TrajectoryExportPane.svelte +0 -357
  791. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +0 -17
  792. package/dist/trajectory/TrajectoryInfoPane.svelte +0 -387
  793. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +0 -17
  794. package/dist/trajectory/constants.d.ts +0 -6
  795. package/dist/trajectory/constants.js +0 -7
  796. package/dist/trajectory/extract.d.ts +0 -5
  797. package/dist/trajectory/extract.js +0 -162
  798. package/dist/trajectory/format-detect.d.ts +0 -9
  799. package/dist/trajectory/format-detect.js +0 -76
  800. package/dist/trajectory/frame-reader.d.ts +0 -17
  801. package/dist/trajectory/frame-reader.js +0 -332
  802. package/dist/trajectory/helpers.d.ts +0 -14
  803. package/dist/trajectory/helpers.js +0 -172
  804. package/dist/trajectory/index.d.ts +0 -63
  805. package/dist/trajectory/index.js +0 -126
  806. package/dist/trajectory/parse/ase.d.ts +0 -2
  807. package/dist/trajectory/parse/ase.js +0 -77
  808. package/dist/trajectory/parse/hdf5.d.ts +0 -2
  809. package/dist/trajectory/parse/hdf5.js +0 -129
  810. package/dist/trajectory/parse/index.d.ts +0 -12
  811. package/dist/trajectory/parse/index.js +0 -299
  812. package/dist/trajectory/parse/lammps.d.ts +0 -5
  813. package/dist/trajectory/parse/lammps.js +0 -179
  814. package/dist/trajectory/parse/vasp.d.ts +0 -2
  815. package/dist/trajectory/parse/vasp.js +0 -68
  816. package/dist/trajectory/parse/xyz.d.ts +0 -2
  817. package/dist/trajectory/parse/xyz.js +0 -110
  818. package/dist/trajectory/plotting.d.ts +0 -28
  819. package/dist/trajectory/plotting.js +0 -423
  820. package/dist/trajectory/types.d.ts +0 -11
  821. package/dist/trajectory/types.js +0 -1
  822. package/dist/utils.d.ts +0 -5
  823. package/dist/utils.js +0 -36
  824. package/dist/xrd/XrdPlot.svelte +0 -615
  825. package/dist/xrd/XrdPlot.svelte.d.ts +0 -28
  826. package/dist/xrd/broadening.d.ts +0 -20
  827. package/dist/xrd/broadening.js +0 -97
  828. package/dist/xrd/calc-xrd.d.ts +0 -37
  829. package/dist/xrd/calc-xrd.js +0 -337
  830. package/dist/xrd/index.d.ts +0 -37
  831. package/dist/xrd/index.js +0 -4
  832. package/dist/xrd/parse.d.ts +0 -13
  833. package/dist/xrd/parse.js +0 -749
  834. /package/dist/{EmptyState.svelte → src/lib/EmptyState.svelte} +0 -0
  835. /package/dist/{Icon.svelte → src/lib/Icon.svelte} +0 -0
  836. /package/dist/{chempot-diagram → src/lib/chempot-diagram}/ChemPotScene3D.svelte +0 -0
  837. /package/dist/{colors → src/lib/colors}/alloy-colors.json +0 -0
  838. /package/dist/{colors → src/lib/colors}/dark-mode-colors.json +0 -0
  839. /package/dist/{colors → src/lib/colors}/jmol-colors.json +0 -0
  840. /package/dist/{colors → src/lib/colors}/muted-colors.json +0 -0
  841. /package/dist/{colors → src/lib/colors}/pastel-colors.json +0 -0
  842. /package/dist/{colors → src/lib/colors}/vesta-colors.json +0 -0
  843. /package/dist/{element → src/lib/element}/Nucleus.svelte +0 -0
  844. /package/dist/{element → src/lib/element}/data.json +0 -0
  845. /package/dist/{element → src/lib/element}/data.json.gz +0 -0
  846. /package/dist/{element → src/lib/element}/data.schema.json +0 -0
  847. /package/dist/{element-image-urls.json → src/lib/element-image-urls.json} +0 -0
  848. /package/dist/{feedback → src/lib/feedback}/Spinner.svelte +0 -0
  849. /package/dist/{feedback → src/lib/feedback}/StatusMessage.svelte +0 -0
  850. /package/dist/{periodic-table → src/lib/periodic-table}/TableInset.svelte +0 -0
  851. /package/dist/{plot → src/lib/plot}/ReferenceLine.svelte +0 -0
  852. /package/dist/{xrd → src/lib/xrd}/atomic_scattering_params.json +0 -0
@@ -0,0 +1,1273 @@
1
+ <script lang="ts">
2
+ import type { ColorSchemeName, D3InterpolateName } from '$lib/colors'
3
+ import { AXIS_COLORS, ELEMENT_COLOR_SCHEMES } from '$lib/colors'
4
+ import IsosurfaceControls from '$lib/isosurface/IsosurfaceControls.svelte'
5
+ import type { IsosurfaceSettings, VolumetricData } from '$lib/isosurface/types'
6
+ import { format_num } from '$lib/labels'
7
+ import { SettingsSection } from '$lib/layout'
8
+ import { to_degrees, to_radians } from '$lib/math'
9
+ import DraggablePane from '$lib/overlays/DraggablePane.svelte'
10
+ import { ColorScaleSelect } from '$lib/plot'
11
+ import type { VectorLayerConfig } from '$lib/settings'
12
+ import { DEFAULTS, SETTINGS_CONFIG, VECTOR_COLOR_MODES } from '$lib/settings'
13
+ import type { AnyStructure } from '$lib/structure'
14
+ import {
15
+ default_vector_configs,
16
+ get_structure_vector_keys,
17
+ Lattice,
18
+ StructureScene,
19
+ VECTOR_PALETTE,
20
+ } from '$lib/structure'
21
+ import type { AtomColorConfig } from '$lib/structure/atom-properties'
22
+ import { is_valid_supercell_input } from '$lib/structure/supercell'
23
+ import type { CellType } from '$lib/symmetry'
24
+ import type { MoyoDataset } from '@spglib/moyo-wasm'
25
+ import type { ComponentProps } from 'svelte'
26
+ import Select from 'svelte-multiselect'
27
+ import { tooltip } from 'svelte-multiselect/attachments'
28
+
29
+ let {
30
+ controls_open = $bindable(false),
31
+ scene_props = $bindable({}),
32
+ lattice_props = $bindable({
33
+ show_cell_vectors: DEFAULTS.structure.show_cell_vectors,
34
+ cell_edge_color: DEFAULTS.structure.cell_edge_color,
35
+ cell_edge_opacity: DEFAULTS.structure.cell_edge_opacity,
36
+ cell_surface_color: DEFAULTS.structure.cell_surface_color,
37
+ cell_surface_opacity: DEFAULTS.structure.cell_surface_opacity,
38
+ cell_edge_width: DEFAULTS.structure.cell_edge_width,
39
+ }),
40
+ show_image_atoms = $bindable(DEFAULTS.structure.show_image_atoms),
41
+ supercell_scaling = $bindable(`1x1x1`),
42
+ background_color = $bindable(),
43
+ background_opacity = $bindable(DEFAULTS.background_opacity),
44
+ color_scheme = $bindable(DEFAULTS.color_scheme),
45
+ atom_color_config = $bindable({
46
+ mode: DEFAULTS.structure.atom_color_mode,
47
+ scale: DEFAULTS.structure.atom_color_scale,
48
+ scale_type: DEFAULTS.structure.atom_color_scale_type,
49
+ }),
50
+ structure = undefined,
51
+ supercell_loading = $bindable(false),
52
+ sym_data = null,
53
+ cell_type = $bindable(`original`),
54
+ volumetric_data = $bindable<VolumetricData[]>(),
55
+ isosurface_settings = $bindable<IsosurfaceSettings>(),
56
+ active_volume_idx = $bindable(0),
57
+ pane_props = {},
58
+ toggle_props = {},
59
+ ...rest
60
+ }: Omit<ComponentProps<typeof DraggablePane>, `children`> & {
61
+ controls_open?: boolean // Control pane state
62
+ scene_props?: ComponentProps<typeof StructureScene>
63
+ lattice_props?: ComponentProps<typeof Lattice>
64
+ show_image_atoms?: boolean
65
+ supercell_scaling?: string
66
+ background_color?: string
67
+ background_opacity?: number
68
+ color_scheme?: string
69
+ atom_color_config?: Partial<AtomColorConfig>
70
+ structure?: AnyStructure
71
+ supercell_loading?: boolean
72
+ sym_data?: MoyoDataset | null
73
+ cell_type?: CellType // Cell type: original, conventional, or primitive
74
+ volumetric_data?: VolumetricData[] // Volumetric data volumes for isosurface controls
75
+ isosurface_settings?: IsosurfaceSettings // Isosurface rendering settings
76
+ active_volume_idx?: number // Active volume index
77
+ pane_props?: ComponentProps<typeof DraggablePane>[`pane_props`]
78
+ toggle_props?: ComponentProps<typeof DraggablePane>[`toggle_props`]
79
+ } = $props()
80
+
81
+ // Color scheme selection state
82
+ let color_scheme_selected = $state([color_scheme])
83
+ $effect(() => {
84
+ if (color_scheme_selected.length > 0) {
85
+ color_scheme = color_scheme_selected[0] as string
86
+ }
87
+ })
88
+
89
+ // Atom color config selection state
90
+ let color_scale_selected = $state<D3InterpolateName[]>([
91
+ atom_color_config.scale || DEFAULTS.structure.atom_color_scale,
92
+ ])
93
+
94
+ // Sync local selection to config
95
+ $effect(() => {
96
+ if (
97
+ color_scale_selected[0] && color_scale_selected[0] !== atom_color_config.scale
98
+ ) atom_color_config.scale = color_scale_selected[0]
99
+ })
100
+ // Sync config to local selection (for external updates)
101
+ $effect(() => {
102
+ if (
103
+ atom_color_config.scale && atom_color_config.scale !== color_scale_selected[0]
104
+ ) color_scale_selected = [atom_color_config.scale]
105
+ })
106
+ // Auto-set scale_type based on mode
107
+ $effect(() => {
108
+ if (atom_color_config.mode === `wyckoff`) {
109
+ atom_color_config.scale_type = `categorical`
110
+ } else if (atom_color_config.mode === `coordination`) {
111
+ atom_color_config.scale_type = `continuous`
112
+ }
113
+ })
114
+
115
+ const hex_color_pattern = /^#[0-9a-f]{3}([0-9a-f]{3})?$/i
116
+ const color_mix_pattern =
117
+ /^color-mix\(in srgb,\s*(#[0-9a-f]{3}(?:[0-9a-f]{3})?)\s+(\d+(?:\.\d+)?)%,\s*transparent\)$/i
118
+
119
+ const as_hex_color = (color: string | undefined, fallback: string): string =>
120
+ color?.match(hex_color_pattern)?.[0] ?? fallback
121
+
122
+ const parse_label_bg_color = (
123
+ color: string | undefined,
124
+ fallback_hex_color: string,
125
+ fallback_opacity: number,
126
+ ): { hex_color: string; opacity: number } => {
127
+ if (color === `transparent`) {
128
+ return { hex_color: fallback_hex_color, opacity: 0 }
129
+ }
130
+ const color_mix = color?.match(color_mix_pattern)
131
+ if (color_mix) {
132
+ const percentage = Math.max(0, Math.min(100, Number(color_mix[2])))
133
+ return {
134
+ hex_color: color_mix[1],
135
+ opacity: percentage / 100,
136
+ }
137
+ }
138
+ const hex_color = color?.match(hex_color_pattern)?.[0]
139
+ return hex_color === undefined
140
+ ? { hex_color: fallback_hex_color, opacity: fallback_opacity }
141
+ : { hex_color, opacity: 1 }
142
+ }
143
+
144
+ const default_site_label_color = as_hex_color(
145
+ DEFAULTS.structure.site_label_color,
146
+ `#111111`,
147
+ )
148
+ const default_site_label_bg = parse_label_bg_color(
149
+ DEFAULTS.structure.site_label_bg_color,
150
+ `#000000`,
151
+ 0,
152
+ )
153
+ const initial_site_label_bg = parse_label_bg_color(
154
+ scene_props.site_label_bg_color,
155
+ default_site_label_bg.hex_color,
156
+ default_site_label_bg.opacity,
157
+ )
158
+
159
+ // Atom label color management
160
+ let site_label_hex_color = $state(
161
+ as_hex_color(scene_props.site_label_color, default_site_label_color),
162
+ )
163
+ let site_label_bg_hex_color = $state(initial_site_label_bg.hex_color)
164
+ let site_label_background_opacity = $state(initial_site_label_bg.opacity)
165
+ let last_synced_site_label_color = scene_props.site_label_color
166
+ let last_synced_site_label_bg_color = scene_props.site_label_bg_color
167
+
168
+ $effect(() => {
169
+ const external_color_changed =
170
+ scene_props.site_label_color !== last_synced_site_label_color
171
+ const external_bg_changed =
172
+ scene_props.site_label_bg_color !== last_synced_site_label_bg_color
173
+
174
+ if (external_color_changed) {
175
+ site_label_hex_color = as_hex_color(
176
+ scene_props.site_label_color,
177
+ default_site_label_color,
178
+ )
179
+ }
180
+ if (external_bg_changed) {
181
+ const next_bg = parse_label_bg_color(
182
+ scene_props.site_label_bg_color,
183
+ default_site_label_bg.hex_color,
184
+ default_site_label_bg.opacity,
185
+ )
186
+ site_label_bg_hex_color = next_bg.hex_color
187
+ site_label_background_opacity = next_bg.opacity
188
+ }
189
+
190
+ if (!external_color_changed) scene_props.site_label_color = site_label_hex_color
191
+ if (!external_bg_changed) {
192
+ scene_props.site_label_bg_color =
193
+ `color-mix(in srgb, ${site_label_bg_hex_color} ${
194
+ format_num(site_label_background_opacity, `.1~%`)
195
+ }, transparent)`
196
+ }
197
+
198
+ last_synced_site_label_color = scene_props.site_label_color
199
+ last_synced_site_label_bg_color = scene_props.site_label_bg_color
200
+ })
201
+
202
+ // Ensure site_label_offset is always available
203
+ scene_props.site_label_offset ??= [...DEFAULTS.structure.site_label_offset]
204
+
205
+ // Collect available vector property keys from the structure
206
+ let available_vector_keys = $derived(
207
+ structure ? get_structure_vector_keys(structure) : [],
208
+ )
209
+ const is_key_visible = (key: string): boolean =>
210
+ scene_props.vector_configs?.[key]?.visible !== false
211
+
212
+ let any_vectors_visible = $derived(available_vector_keys.some(is_key_visible))
213
+
214
+ function update_vector_config(key: string, patch: Partial<VectorLayerConfig>) {
215
+ const configs = { ...scene_props.vector_configs }
216
+ configs[key] = {
217
+ ...(configs[key] ?? { visible: true, color: null, scale: null }),
218
+ ...patch,
219
+ }
220
+ scene_props.vector_configs = configs
221
+ }
222
+
223
+ // Detect if structure has lattice (can create supercells)
224
+ let has_lattice = $derived(
225
+ structure && `lattice` in structure && structure.lattice !== undefined,
226
+ )
227
+
228
+ // Validate supercell input
229
+ let supercell_input_valid = $derived(is_valid_supercell_input(supercell_scaling))
230
+
231
+ // Ensure rotation is always an array
232
+ $effect(() => {
233
+ scene_props.rotation ??= [...DEFAULTS.structure.rotation]
234
+ })
235
+
236
+ let rotation_degrees = $derived(
237
+ scene_props.rotation?.map((rad) => {
238
+ const deg = to_degrees(rad)
239
+ // Convert to [0, 360] range for UI display
240
+ return ((deg % 360) + 360) % 360
241
+ }) ?? [0, 0, 0],
242
+ )
243
+
244
+ function update_rotation(axis: `x` | `y` | `z`, degrees: number) {
245
+ scene_props.rotation ??= [0, 0, 0]
246
+ const axis_index = { x: 0, y: 1, z: 2 }[axis]
247
+ const clamped = Math.max(0, Math.min(360, degrees))
248
+ const norm = ((clamped % 360) + 360) % 360
249
+ scene_props.rotation[axis_index] = to_radians(norm)
250
+ // Trigger reactivity by creating new array
251
+ scene_props.rotation = [...scene_props.rotation]
252
+ }
253
+
254
+ // Helper function to get example set of colors from an element color scheme
255
+ function get_representative_colors(scheme_name: string): string[] {
256
+ const scheme = ELEMENT_COLOR_SCHEMES[scheme_name as ColorSchemeName]
257
+ if (!scheme) return []
258
+
259
+ // Get colors for common elements: H, C, N, O, Fe, Ca, Si, Al
260
+ const sample_elements = [`H`, `C`, `N`, `O`, `Fe`, `Ca`, `Si`, `Al`]
261
+ return sample_elements
262
+ .slice(0, 4) // Take first 4
263
+ .map((el) => scheme[el] || scheme.H || `#cccccc`)
264
+ .filter(Boolean)
265
+ }
266
+ </script>
267
+
268
+ <DraggablePane
269
+ bind:show={controls_open}
270
+ resizable="both"
271
+ pane_props={{
272
+ ...pane_props,
273
+ class: `controls-pane ${pane_props?.class ?? ``}`,
274
+ style: `--pane-max-height: 70vh; ${pane_props?.style ?? ``}`,
275
+ }}
276
+ toggle_props={{
277
+ title: controls_open ? `` : `Structure controls`,
278
+ ...toggle_props,
279
+ class: `structure-controls-toggle ${toggle_props?.class ?? ``}`,
280
+ }}
281
+ {...rest}
282
+ >
283
+ {#if volumetric_data?.length && isosurface_settings}
284
+ <IsosurfaceControls
285
+ bind:settings={isosurface_settings}
286
+ volumes={volumetric_data}
287
+ bind:active_volume_idx
288
+ />
289
+ {/if}
290
+
291
+ <SettingsSection
292
+ title="Visibility"
293
+ current_values={{
294
+ show_atoms: scene_props.show_atoms,
295
+ show_bonds: scene_props.show_bonds,
296
+ show_image_atoms,
297
+ show_site_labels: scene_props.show_site_labels,
298
+ show_site_indices: scene_props.show_site_indices,
299
+ vector_configs: scene_props.vector_configs,
300
+ show_cell_vectors: lattice_props.show_cell_vectors,
301
+ }}
302
+ on_reset={() => {
303
+ scene_props.show_atoms = DEFAULTS.structure.show_atoms
304
+ scene_props.show_bonds = DEFAULTS.structure.show_bonds
305
+ scene_props.show_site_labels = DEFAULTS.structure.show_site_labels
306
+ scene_props.show_site_indices = DEFAULTS.structure.show_site_indices
307
+ scene_props.vector_configs = default_vector_configs(available_vector_keys)
308
+ show_image_atoms = DEFAULTS.structure.show_image_atoms
309
+ lattice_props.show_cell_vectors = DEFAULTS.structure.show_cell_vectors
310
+ }}
311
+ style="display: flex; flex-direction: row; flex-wrap: wrap; gap: 12pt"
312
+ >
313
+ Show <label
314
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.show_atoms.description })}
315
+ style="gap: 6pt"
316
+ >
317
+ <input type="checkbox" bind:checked={scene_props.show_atoms} />
318
+ Atoms
319
+ </label>
320
+ <label
321
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.show_image_atoms.description })}
322
+ style="gap: 6pt"
323
+ >
324
+ <input type="checkbox" bind:checked={show_image_atoms} />
325
+ Image Atoms
326
+ </label>
327
+ <label
328
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.show_site_labels.description })}
329
+ style="gap: 6pt"
330
+ >
331
+ <input type="checkbox" bind:checked={scene_props.show_site_labels} />
332
+ Site Labels
333
+ </label>
334
+ <label
335
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.show_site_indices.description })}
336
+ style="gap: 6pt"
337
+ >
338
+ <input type="checkbox" bind:checked={scene_props.show_site_indices} />
339
+ Site Indices
340
+ </label>
341
+ {#if available_vector_keys.length > 0}
342
+ {#each available_vector_keys as key, idx (key)}
343
+ <label
344
+ {@attach tooltip({
345
+ content: `Toggle ${key} vectors`,
346
+ })}
347
+ style="gap: 4pt"
348
+ >
349
+ <input
350
+ type="checkbox"
351
+ checked={is_key_visible(key)}
352
+ onchange={() => update_vector_config(key, { visible: !is_key_visible(key) })}
353
+ />
354
+ <input
355
+ type="color"
356
+ aria-label={`${key} vector color`}
357
+ value={scene_props.vector_configs?.[key]?.color ??
358
+ VECTOR_PALETTE[idx % VECTOR_PALETTE.length]}
359
+ onchange={(evt) =>
360
+ update_vector_config(key, {
361
+ color: evt.currentTarget.value,
362
+ })}
363
+ style="width: 22px; height: 22px; padding: 0; border: none; cursor: pointer"
364
+ />
365
+ {key}
366
+ {#if scene_props.vector_configs?.[key]?.color != null}
367
+ <button
368
+ type="button"
369
+ aria-label={`Reset ${key} color to default`}
370
+ onclick={() => update_vector_config(key, { color: null })}
371
+ style="padding: 0 3pt; font-size: 0.8em; line-height: 1; cursor: pointer"
372
+ >
373
+ ×
374
+ </button>
375
+ {/if}
376
+ </label>
377
+ {/each}
378
+ {/if}
379
+ <label style="gap: 6pt">
380
+ <input type="checkbox" bind:checked={lattice_props.show_cell_vectors} />
381
+ Lattice Vectors
382
+ </label>
383
+ <label
384
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.show_bonds.description })}
385
+ style="gap: 6pt"
386
+ >
387
+ Bonds:
388
+ <select bind:value={scene_props.show_bonds}>
389
+ {#each Object.entries(SETTINGS_CONFIG.structure.show_bonds.enum ?? {}) as
390
+ [value, label]
391
+ (value)
392
+ }
393
+ <option {value}>{label}</option>
394
+ {/each}
395
+ </select>
396
+ </label>
397
+ </SettingsSection>
398
+
399
+ <SettingsSection
400
+ title="Camera"
401
+ current_values={{
402
+ camera_projection: scene_props.camera_projection,
403
+ auto_rotate: scene_props.auto_rotate,
404
+ rotate_speed: scene_props.rotate_speed,
405
+ zoom_speed: scene_props.zoom_speed,
406
+ pan_speed: scene_props.pan_speed,
407
+ zoom_to_cursor: scene_props.zoom_to_cursor,
408
+ rotation_damping: scene_props.rotation_damping,
409
+ rotation: scene_props.rotation,
410
+ }}
411
+ on_reset={() => {
412
+ scene_props.camera_projection = DEFAULTS.structure.camera_projection
413
+ scene_props.auto_rotate = DEFAULTS.structure.auto_rotate
414
+ scene_props.rotate_speed = DEFAULTS.structure.rotate_speed
415
+ scene_props.zoom_speed = DEFAULTS.structure.zoom_speed
416
+ scene_props.pan_speed = DEFAULTS.structure.pan_speed
417
+ scene_props.zoom_to_cursor = DEFAULTS.structure.zoom_to_cursor
418
+ scene_props.rotation_damping = DEFAULTS.structure.rotation_damping
419
+ scene_props.rotation = [...DEFAULTS.structure.rotation]
420
+ }}
421
+ >
422
+ <label>
423
+ <span
424
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.camera_projection.description })}
425
+ >
426
+ Projection
427
+ </span>
428
+ <select bind:value={scene_props.camera_projection}>
429
+ {#each Object.entries(
430
+ SETTINGS_CONFIG.structure.camera_projection.enum ?? {},
431
+ ) as
432
+ [value, label]
433
+ (value)
434
+ }
435
+ <option {value}>{label}</option>
436
+ {/each}
437
+ </select>
438
+ </label>
439
+ <label
440
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.auto_rotate.description })}
441
+ >
442
+ Auto-rotate speed
443
+ <input
444
+ type="number"
445
+ min={0}
446
+ max={2}
447
+ step={0.01}
448
+ bind:value={scene_props.auto_rotate}
449
+ />
450
+ <input
451
+ type="range"
452
+ min={0}
453
+ max={2}
454
+ step={0.01}
455
+ bind:value={scene_props.auto_rotate}
456
+ />
457
+ </label>
458
+ <label
459
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.rotate_speed.description })}
460
+ >
461
+ Rotate speed
462
+ <input
463
+ type="number"
464
+ min={0}
465
+ max={2}
466
+ step={0.05}
467
+ bind:value={scene_props.rotate_speed}
468
+ />
469
+ <input
470
+ type="range"
471
+ min={0}
472
+ max={2}
473
+ step={0.05}
474
+ bind:value={scene_props.rotate_speed}
475
+ />
476
+ </label>
477
+ <label
478
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.zoom_speed.description })}
479
+ >
480
+ Zoom speed
481
+ <input
482
+ type="number"
483
+ min={0.1}
484
+ max={0.8}
485
+ step={0.02}
486
+ bind:value={scene_props.zoom_speed}
487
+ />
488
+ <input
489
+ type="range"
490
+ min={0.1}
491
+ max={0.8}
492
+ step={0.02}
493
+ bind:value={scene_props.zoom_speed}
494
+ />
495
+ </label>
496
+ <label
497
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.pan_speed.description })}
498
+ >
499
+ Pan speed
500
+ <input
501
+ type="number"
502
+ min={0}
503
+ max={2}
504
+ step={0.01}
505
+ bind:value={scene_props.pan_speed}
506
+ />
507
+ <input
508
+ type="range"
509
+ min={0}
510
+ max={2}
511
+ step={0.01}
512
+ bind:value={scene_props.pan_speed}
513
+ />
514
+ </label>
515
+ <label
516
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.zoom_to_cursor.description })}
517
+ >
518
+ <input type="checkbox" bind:checked={scene_props.zoom_to_cursor} />
519
+ <span>Zoom to cursor</span>
520
+ </label>
521
+ <label
522
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.rotation_damping.description })}
523
+ >
524
+ Rotation damping
525
+ <input
526
+ type="number"
527
+ min={0.01}
528
+ max={0.3}
529
+ step={0.01}
530
+ bind:value={scene_props.rotation_damping}
531
+ />
532
+ <input
533
+ type="range"
534
+ min={0.01}
535
+ max={0.3}
536
+ step={0.01}
537
+ bind:value={scene_props.rotation_damping}
538
+ />
539
+ </label>
540
+
541
+ Axis Rotation
542
+ <div class="rotation-axes">
543
+ {#each AXIS_COLORS as [axis, color], idx (axis)}
544
+ <div>
545
+ <div
546
+ {@attach tooltip()}
547
+ title="{axis}-axis rotation in degrees"
548
+ style:color
549
+ >
550
+ <span>{axis.toUpperCase()} = </span>
551
+ <input
552
+ type="number"
553
+ min={0}
554
+ max={360}
555
+ step={1}
556
+ value={rotation_degrees[idx].toFixed(0)}
557
+ oninput={(event) =>
558
+ update_rotation(axis, Number(event.currentTarget.value))}
559
+ style:color
560
+ style="margin: 0"
561
+ />
562
+ °
563
+ </div>
564
+ <input
565
+ type="range"
566
+ min={0}
567
+ max={360}
568
+ step={1}
569
+ value={rotation_degrees[idx].toFixed(0)}
570
+ oninput={(event) => update_rotation(axis, Number(event.currentTarget.value))}
571
+ style:--thumb-color={color}
572
+ style="width: 100%"
573
+ />
574
+ </div>
575
+ {/each}
576
+ </div>
577
+ </SettingsSection>
578
+
579
+ <SettingsSection
580
+ title="Atoms"
581
+ current_values={{
582
+ atom_radius: scene_props.atom_radius,
583
+ same_size_atoms: scene_props.same_size_atoms,
584
+ color_scheme,
585
+ ...atom_color_config,
586
+ }}
587
+ on_reset={() => {
588
+ scene_props.atom_radius = DEFAULTS.structure.atom_radius
589
+ scene_props.same_size_atoms = DEFAULTS.structure.same_size_atoms
590
+ color_scheme = DEFAULTS.color_scheme
591
+ color_scheme_selected = [DEFAULTS.color_scheme]
592
+ atom_color_config.mode = DEFAULTS.structure.atom_color_mode
593
+ atom_color_config.scale = DEFAULTS.structure.atom_color_scale
594
+ atom_color_config.scale_type = DEFAULTS.structure.atom_color_scale_type
595
+ color_scale_selected = [DEFAULTS.structure.atom_color_scale]
596
+ }}
597
+ >
598
+ <label
599
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.atom_radius.description })}
600
+ >
601
+ Radius <small>(Å)</small>
602
+ <input
603
+ type="number"
604
+ min={0.2}
605
+ max={2}
606
+ step={0.05}
607
+ bind:value={scene_props.atom_radius}
608
+ />
609
+ <input
610
+ type="range"
611
+ min={0.2}
612
+ max={2}
613
+ step={0.05}
614
+ bind:value={scene_props.atom_radius}
615
+ />
616
+ </label>
617
+ <label
618
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.same_size_atoms.description })}
619
+ >
620
+ Same size atoms
621
+ <input type="checkbox" bind:checked={scene_props.same_size_atoms} />
622
+ </label>
623
+ <label
624
+ {@attach tooltip({ content: SETTINGS_CONFIG.color_scheme.description })}
625
+ >
626
+ Color scheme
627
+ <Select
628
+ options={Object.keys(ELEMENT_COLOR_SCHEMES)}
629
+ maxSelect={1}
630
+ minSelect={1}
631
+ bind:selected={color_scheme_selected}
632
+ liOptionStyle="padding: 3pt 6pt;"
633
+ liSelectedStyle="background-color: transparent;"
634
+ ulSelectedStyle="display: contents;"
635
+ inputStyle="flex: none; min-width: 0; width: 0; opacity: 0;"
636
+ style="flex: 1; min-width: 0; border: none; margin-left: 4pt"
637
+ aria-label="Color scheme"
638
+ >
639
+ {#snippet children({ option })}
640
+ {@const option_style =
641
+ `display: flex; align-items: center; gap: 6pt; justify-content: space-between;`}
642
+ <div style={option_style}>
643
+ {option}
644
+ <div style="display: flex; gap: 3pt">
645
+ {#each get_representative_colors(String(option)) as color (color)}
646
+ {@const color_style =
647
+ `width: 15px; height: 15px; border-radius: 2px; background: ${color};`}
648
+ <div style={color_style}></div>
649
+ {/each}
650
+ </div>
651
+ </div>
652
+ {/snippet}
653
+ </Select>
654
+ </label>
655
+ <label
656
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.atom_color_mode.description })}
657
+ >
658
+ Atom coloring
659
+ <select bind:value={atom_color_config.mode}>
660
+ {#each Object.entries(SETTINGS_CONFIG.structure.atom_color_mode.enum || {}) as
661
+ [value, label]
662
+ (value)
663
+ }
664
+ <option {value} disabled={!sym_data && value === `wyckoff`}>{label}</option>
665
+ {/each}
666
+ </select>
667
+ </label>
668
+ {#if atom_color_config.mode !== `element`}
669
+ <label
670
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.atom_color_scale.description })}
671
+ >
672
+ Color scale
673
+ <ColorScaleSelect
674
+ bind:value={atom_color_config.scale}
675
+ bind:selected={color_scale_selected}
676
+ colorbar={{
677
+ tick_labels: 0,
678
+ wrapper_style: `width: 100%;`,
679
+ }}
680
+ style="flex: 1; min-width: 0; border: none"
681
+ aria-label="Color scale"
682
+ />
683
+ </label>
684
+ {/if}
685
+ </SettingsSection>
686
+
687
+ {#if scene_props.show_site_labels || scene_props.show_site_indices}
688
+ <SettingsSection
689
+ title="Labels"
690
+ current_values={{
691
+ site_label_size: scene_props.site_label_size,
692
+ site_label_hex_color,
693
+ site_label_bg_hex_color,
694
+ site_label_background_opacity,
695
+ site_label_padding: scene_props.site_label_padding,
696
+ site_label_offset: scene_props.site_label_offset,
697
+ }}
698
+ on_reset={() => {
699
+ scene_props.site_label_size = DEFAULTS.structure.site_label_size
700
+ scene_props.site_label_padding = DEFAULTS.structure.site_label_padding
701
+ scene_props.site_label_offset = [...DEFAULTS.structure.site_label_offset]
702
+ site_label_hex_color = default_site_label_color
703
+ site_label_bg_hex_color = default_site_label_bg.hex_color
704
+ site_label_background_opacity = default_site_label_bg.opacity
705
+ }}
706
+ >
707
+ <div class="pane-row">
708
+ <label>
709
+ Color
710
+ <input
711
+ type="color"
712
+ aria-label="Site label color"
713
+ bind:value={site_label_hex_color}
714
+ />
715
+ </label>
716
+ <label>
717
+ Size
718
+ <input
719
+ type="range"
720
+ min="0.5"
721
+ max="2"
722
+ step="0.1"
723
+ bind:value={scene_props.site_label_size}
724
+ />
725
+ </label>
726
+ </div>
727
+ <div class="pane-row">
728
+ <label>
729
+ Background
730
+ <input
731
+ type="color"
732
+ aria-label="Site label background color"
733
+ bind:value={site_label_bg_hex_color}
734
+ />
735
+ </label>
736
+ <label>
737
+ Opacity
738
+ <input
739
+ type="number"
740
+ min="0"
741
+ max="1"
742
+ step="0.01"
743
+ aria-label="Site label background opacity"
744
+ bind:value={site_label_background_opacity}
745
+ />
746
+ <input
747
+ type="range"
748
+ min="0"
749
+ max="1"
750
+ step="0.01"
751
+ aria-label="Site label background opacity slider"
752
+ bind:value={site_label_background_opacity}
753
+ />
754
+ </label>
755
+ </div>
756
+ <div class="pane-row">
757
+ <label>
758
+ Padding
759
+ <input
760
+ type="number"
761
+ min="0"
762
+ max="10"
763
+ step="1"
764
+ bind:value={scene_props.site_label_padding}
765
+ />
766
+ <input
767
+ type="range"
768
+ min="0"
769
+ max="10"
770
+ step="1"
771
+ bind:value={scene_props.site_label_padding}
772
+ />
773
+ </label>
774
+ </div>
775
+ <div class="pane-row">
776
+ Offset
777
+ {#each [`X`, `Y`, `Z`] as axis, idx (axis)}
778
+ <label>
779
+ {axis}
780
+ <input
781
+ type="number"
782
+ min="-1"
783
+ max="1"
784
+ step="0.1"
785
+ bind:value={scene_props.site_label_offset![idx]}
786
+ />
787
+ </label>
788
+ {/each}
789
+ </div>
790
+ </SettingsSection>
791
+ {/if}
792
+
793
+ {#if available_vector_keys.length > 0 && any_vectors_visible}
794
+ <SettingsSection
795
+ title="Site Vectors"
796
+ current_values={{
797
+ vector_scale: scene_props.vector_scale,
798
+ vector_color: scene_props.vector_color,
799
+ vector_normalize: scene_props.vector_normalize,
800
+ vector_uniform_thickness: scene_props.vector_uniform_thickness,
801
+ vector_color_mode: scene_props.vector_color_mode,
802
+ vector_color_scale: scene_props.vector_color_scale,
803
+ vector_origin_gap: scene_props.vector_origin_gap,
804
+ }}
805
+ on_reset={() => {
806
+ scene_props.vector_scale = DEFAULTS.structure.vector_scale
807
+ scene_props.vector_color = DEFAULTS.structure.vector_color
808
+ scene_props.vector_color_mode = DEFAULTS.structure.vector_color_mode
809
+ scene_props.vector_color_scale = DEFAULTS.structure.vector_color_scale
810
+ scene_props.vector_normalize = DEFAULTS.structure.vector_normalize
811
+ scene_props.vector_uniform_thickness =
812
+ DEFAULTS.structure.vector_uniform_thickness
813
+ scene_props.vector_origin_gap = DEFAULTS.structure.vector_origin_gap
814
+ for (const key of available_vector_keys) {
815
+ update_vector_config(key, { scale: null })
816
+ }
817
+ }}
818
+ >
819
+ <label>
820
+ Global Scale
821
+ <input
822
+ type="number"
823
+ min={0.001}
824
+ max={5}
825
+ step={0.001}
826
+ bind:value={scene_props.vector_scale}
827
+ />
828
+ <input
829
+ type="range"
830
+ min={0.001}
831
+ max={5}
832
+ step={0.001}
833
+ bind:value={scene_props.vector_scale}
834
+ />
835
+ </label>
836
+ <label
837
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.vector_normalize.description })}
838
+ style="gap: 6pt"
839
+ >
840
+ <input type="checkbox" bind:checked={scene_props.vector_normalize} />
841
+ Normalize
842
+ </label>
843
+ <label
844
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.vector_uniform_thickness.description })}
845
+ style="gap: 6pt"
846
+ >
847
+ <input type="checkbox" bind:checked={scene_props.vector_uniform_thickness} />
848
+ Uniform Thickness
849
+ </label>
850
+ <label
851
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.vector_color_mode.description })}
852
+ >
853
+ Color Mode
854
+ <select bind:value={scene_props.vector_color_mode}>
855
+ {#each VECTOR_COLOR_MODES as mode (mode)}
856
+ <option value={mode}>{mode.replaceAll(`_`, ` `)}</option>
857
+ {/each}
858
+ </select>
859
+ </label>
860
+ {#if scene_props.vector_color_mode === `magnitude`}
861
+ <label>
862
+ Scale
863
+ <ColorScaleSelect
864
+ bind:value={scene_props.vector_color_scale}
865
+ style="max-width: 180px"
866
+ />
867
+ </label>
868
+ {/if}
869
+ {#if scene_props.vector_color_mode === `uniform`}
870
+ <label>
871
+ Color
872
+ <input type="color" bind:value={scene_props.vector_color} />
873
+ </label>
874
+ {/if}
875
+ {#if available_vector_keys.length > 1}
876
+ <label
877
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.vector_origin_gap.description })}
878
+ >
879
+ Origin Gap
880
+ <input
881
+ type="number"
882
+ min={0}
883
+ max={0.5}
884
+ step={0.02}
885
+ bind:value={scene_props.vector_origin_gap}
886
+ />
887
+ <input
888
+ type="range"
889
+ min={0}
890
+ max={0.5}
891
+ step={0.02}
892
+ bind:value={scene_props.vector_origin_gap}
893
+ />
894
+ </label>
895
+ {#each available_vector_keys as key (key)}
896
+ {#if is_key_visible(key)}
897
+ {@const on_scale = (
898
+ evt: Event & { currentTarget: HTMLInputElement },
899
+ ) => {
900
+ const parsed = parseFloat(evt.currentTarget.value)
901
+ update_vector_config(key, { scale: Number.isNaN(parsed) ? 1.0 : parsed })
902
+ }}
903
+ <label
904
+ {@attach tooltip({ content: `Scale multiplier for ${key} arrows (applied on top of global scale)` })}
905
+ >
906
+ {key} scale
907
+ <input
908
+ type="number"
909
+ min={0.1}
910
+ max={5}
911
+ step={0.1}
912
+ value={scene_props.vector_configs?.[key]?.scale ?? 1.0}
913
+ onchange={on_scale}
914
+ />
915
+ <input
916
+ type="range"
917
+ min={0.1}
918
+ max={5}
919
+ step={0.1}
920
+ value={scene_props.vector_configs?.[key]?.scale ?? 1.0}
921
+ oninput={on_scale}
922
+ />
923
+ </label>
924
+ {/if}
925
+ {/each}
926
+ {/if}
927
+ </SettingsSection>
928
+ {/if}
929
+
930
+ {#if has_lattice}
931
+ <SettingsSection
932
+ title="Cell"
933
+ current_values={{
934
+ cell_edge_color: lattice_props.cell_edge_color,
935
+ cell_edge_opacity: lattice_props.cell_edge_opacity,
936
+ cell_surface_color: lattice_props.cell_surface_color,
937
+ cell_surface_opacity: lattice_props.cell_surface_opacity,
938
+ supercell_scaling,
939
+ cell_type,
940
+ }}
941
+ on_reset={() => {
942
+ lattice_props.cell_edge_color = DEFAULTS.structure.cell_edge_color
943
+ lattice_props.cell_edge_opacity = DEFAULTS.structure.cell_edge_opacity
944
+ lattice_props.cell_surface_color = DEFAULTS.structure.cell_surface_color
945
+ lattice_props.cell_surface_opacity = DEFAULTS.structure.cell_surface_opacity
946
+ supercell_scaling = `1x1x1`
947
+ cell_type = `original`
948
+ }}
949
+ >
950
+ <label
951
+ {@attach tooltip({
952
+ content: sym_data
953
+ ? `Transform to conventional or primitive cell using crystallographic symmetry`
954
+ : `Symmetry analysis required. Wait for analysis to complete.`,
955
+ })}
956
+ >
957
+ <span>Cell Type</span>
958
+ <select bind:value={cell_type} disabled={!sym_data}>
959
+ <option value="original">Original</option>
960
+ <option value="conventional">Conventional</option>
961
+ <option value="primitive">Primitive</option>
962
+ </select>
963
+ </label>
964
+ <label>
965
+ <span
966
+ {@attach tooltip({ content: `Create supercells by repeating the unit cell. Examples: "2x2x2", "3x1x2", or "2"` })}
967
+ >
968
+ Supercell Scaling
969
+ </span>
970
+ <input
971
+ type="text"
972
+ bind:value={supercell_scaling}
973
+ placeholder="1x1x1"
974
+ style:border={supercell_input_valid ? undefined : `1px dashed red`}
975
+ style:opacity={supercell_loading ? 0.5 : 1}
976
+ disabled={supercell_loading}
977
+ inputmode="text"
978
+ autocomplete="off"
979
+ spellcheck="false"
980
+ pattern="^(\d+|\d+x\d+x\d+)$"
981
+ aria-invalid={!supercell_input_valid}
982
+ title={supercell_input_valid
983
+ ? `Valid supercell scaling: ${supercell_scaling}`
984
+ : `Invalid format. Use "2x2x2", "3x1x2", or "2"`}
985
+ />
986
+ </label>
987
+ {#if supercell_loading}
988
+ <div
989
+ style="display: flex; align-items: center; gap: 8px; font-size: 0.85em; color: var(--accent-color); margin-top: 4pt"
990
+ >
991
+ <span
992
+ class="spinner-icon"
993
+ style="display: inline-block; width: 12px; height: 12px; border: 2px solid currentColor; border-right-color: transparent; border-radius: 50%; animation: spin 0.8s linear infinite"
994
+ ></span>
995
+ <span>Generating supercell...</span>
996
+ </div>
997
+ {/if}
998
+
999
+ {#if !supercell_input_valid}
1000
+ <div
1001
+ data-testid="supercell-input-error"
1002
+ style="color: red; font-size: 0.8em; margin-top: 4pt"
1003
+ >
1004
+ Invalid format. Use patterns like "2x2x2", "3x1x2", or "2".
1005
+ </div>
1006
+ {/if}
1007
+
1008
+ {#each [
1009
+ {
1010
+ label: `Edge color`,
1011
+ color_prop: `cell_edge_color`,
1012
+ opacity_prop: `cell_edge_opacity`,
1013
+ step: 0.05,
1014
+ },
1015
+ {
1016
+ label: `Surface color`,
1017
+ color_prop: `cell_surface_color`,
1018
+ opacity_prop: `cell_surface_opacity`,
1019
+ step: 0.01,
1020
+ },
1021
+ ] as const as
1022
+ { label, color_prop, opacity_prop, step }
1023
+ (label)
1024
+ }
1025
+ <div class="pane-row">
1026
+ <label>
1027
+ {label}
1028
+ <input
1029
+ type="color"
1030
+ bind:value={lattice_props[color_prop]}
1031
+ />
1032
+ </label>
1033
+ <label>
1034
+ opacity
1035
+ <input
1036
+ type="number"
1037
+ min={0}
1038
+ max={1}
1039
+ {step}
1040
+ bind:value={lattice_props[opacity_prop]}
1041
+ />
1042
+ <input
1043
+ type="range"
1044
+ min={0}
1045
+ max={1}
1046
+ {step}
1047
+ bind:value={lattice_props[opacity_prop]}
1048
+ />
1049
+ </label>
1050
+ </div>
1051
+ {/each}
1052
+ </SettingsSection>
1053
+ {/if}
1054
+
1055
+ <SettingsSection
1056
+ title="Background"
1057
+ current_values={{
1058
+ background_color,
1059
+ background_opacity,
1060
+ }}
1061
+ on_reset={() => {
1062
+ background_color = undefined
1063
+ background_opacity = DEFAULTS.background_opacity
1064
+ }}
1065
+ >
1066
+ <div class="pane-row">
1067
+ <label>
1068
+ Color
1069
+ <!-- not using bind:value to not give a default value of #000000 to background_color, needs to stay undefined to not override --struct-bg theme color -->
1070
+ <input
1071
+ type="color"
1072
+ value={background_color}
1073
+ oninput={(event) => {
1074
+ background_color = event.currentTarget.value
1075
+ }}
1076
+ />
1077
+ </label>
1078
+ <label>
1079
+ Opacity
1080
+ <input
1081
+ type="number"
1082
+ min={0}
1083
+ max={1}
1084
+ step={0.02}
1085
+ bind:value={background_opacity}
1086
+ />
1087
+ <input type="range" min={0} max={1} step={0.02} bind:value={background_opacity} />
1088
+ </label>
1089
+ </div>
1090
+ </SettingsSection>
1091
+
1092
+ <SettingsSection
1093
+ title="Lighting"
1094
+ current_values={{
1095
+ directional_light: scene_props.directional_light,
1096
+ ambient_light: scene_props.ambient_light,
1097
+ }}
1098
+ on_reset={() => {
1099
+ scene_props.directional_light = DEFAULTS.structure.directional_light
1100
+ scene_props.ambient_light = DEFAULTS.structure.ambient_light
1101
+ }}
1102
+ >
1103
+ <label>
1104
+ <span title="Intensity of the directional light" {@attach tooltip()}>
1105
+ Directional light
1106
+ </span>
1107
+ <input
1108
+ type="number"
1109
+ min={0}
1110
+ max={4}
1111
+ step={0.01}
1112
+ bind:value={scene_props.directional_light}
1113
+ />
1114
+ <input
1115
+ type="range"
1116
+ min={0}
1117
+ max={4}
1118
+ step={0.01}
1119
+ bind:value={scene_props.directional_light}
1120
+ />
1121
+ </label>
1122
+ <label>
1123
+ <span title="Intensity of the ambient light" {@attach tooltip()}>
1124
+ Ambient light
1125
+ </span>
1126
+ <input
1127
+ type="number"
1128
+ min={0.5}
1129
+ max={3}
1130
+ step={0.05}
1131
+ bind:value={scene_props.ambient_light}
1132
+ />
1133
+ <input
1134
+ type="range"
1135
+ min={0.5}
1136
+ max={3}
1137
+ step={0.05}
1138
+ bind:value={scene_props.ambient_light}
1139
+ />
1140
+ </label>
1141
+ </SettingsSection>
1142
+
1143
+ {#if scene_props.show_bonds && scene_props.show_bonds !== `never`}
1144
+ <SettingsSection
1145
+ title="Bonds"
1146
+ current_values={{
1147
+ bonding_strategy: scene_props.bonding_strategy,
1148
+ auto_bond_order: scene_props.auto_bond_order,
1149
+ aromatic_display: scene_props.aromatic_display,
1150
+ bond_color: scene_props.bond_color,
1151
+ bond_thickness: scene_props.bond_thickness,
1152
+ }}
1153
+ on_reset={() => {
1154
+ scene_props.bonding_strategy = DEFAULTS.structure.bonding_strategy
1155
+ scene_props.auto_bond_order = DEFAULTS.structure.auto_bond_order
1156
+ scene_props.aromatic_display = DEFAULTS.structure.aromatic_display
1157
+ scene_props.bond_color = DEFAULTS.structure.bond_color
1158
+ scene_props.bond_thickness = DEFAULTS.structure.bond_thickness
1159
+ }}
1160
+ >
1161
+ <label>
1162
+ Strategy <select bind:value={scene_props.bonding_strategy}>
1163
+ {#each Object.entries(
1164
+ SETTINGS_CONFIG.structure.bonding_strategy.enum ?? {},
1165
+ ) as
1166
+ [value, label]
1167
+ (value)
1168
+ }
1169
+ <option {value}>{label}</option>
1170
+ {/each}
1171
+ </select>
1172
+ </label>
1173
+ <label
1174
+ style="gap: 6pt"
1175
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.auto_bond_order.description })}
1176
+ >
1177
+ <input type="checkbox" bind:checked={scene_props.auto_bond_order} />
1178
+ Auto bond order (perceive double/triple/aromatic)
1179
+ </label>
1180
+ {#if scene_props.auto_bond_order}
1181
+ <label
1182
+ {@attach tooltip({ content: SETTINGS_CONFIG.structure.aromatic_display.description })}
1183
+ >
1184
+ Aromatic display <select bind:value={scene_props.aromatic_display}>
1185
+ {#each Object.entries(
1186
+ SETTINGS_CONFIG.structure.aromatic_display.enum ?? {},
1187
+ ) as
1188
+ [value, label]
1189
+ (value)
1190
+ }
1191
+ <option {value}>{label}</option>
1192
+ {/each}
1193
+ </select>
1194
+ </label>
1195
+ {/if}
1196
+ <label>
1197
+ Color <input type="color" bind:value={scene_props.bond_color} />
1198
+ </label>
1199
+ <label>
1200
+ Thickness
1201
+ <input
1202
+ type="number"
1203
+ min={0.05}
1204
+ max={0.5}
1205
+ step={0.05}
1206
+ bind:value={scene_props.bond_thickness}
1207
+ />
1208
+ <input
1209
+ type="range"
1210
+ min={0.05}
1211
+ max={0.5}
1212
+ step={0.05}
1213
+ bind:value={scene_props.bond_thickness}
1214
+ />
1215
+ </label>
1216
+ </SettingsSection>
1217
+ {/if}
1218
+ </DraggablePane>
1219
+
1220
+ <style>
1221
+ .rotation-axes {
1222
+ display: flex;
1223
+ gap: 10pt;
1224
+ }
1225
+ .rotation-axes > div {
1226
+ display: grid;
1227
+ gap: 0.4em;
1228
+ place-items: center;
1229
+ }
1230
+ :global(.controls-pane) {
1231
+ font-size: 0.85em;
1232
+ }
1233
+
1234
+ :global(.controls-pane section) {
1235
+ display: flex;
1236
+ flex-direction: column;
1237
+ gap: 6pt;
1238
+ }
1239
+ :global(.controls-pane h4) {
1240
+ margin: 10pt 0 4pt !important;
1241
+ }
1242
+ :global(.controls-pane h4:first-of-type) {
1243
+ margin-top: 0 !important;
1244
+ }
1245
+ .pane-row {
1246
+ display: flex;
1247
+ gap: 12pt;
1248
+ justify-content: space-between;
1249
+ width: 100%;
1250
+ }
1251
+ label {
1252
+ display: flex;
1253
+ align-items: center;
1254
+ gap: 10pt;
1255
+ }
1256
+ input,
1257
+ select {
1258
+ font-size: inherit;
1259
+ font-family: inherit;
1260
+ }
1261
+ input[type='range'] {
1262
+ flex: 1;
1263
+ min-width: 40px;
1264
+ }
1265
+ @keyframes spin {
1266
+ from {
1267
+ transform: rotate(0deg);
1268
+ }
1269
+ to {
1270
+ transform: rotate(360deg);
1271
+ }
1272
+ }
1273
+ </style>