matterviz 0.3.6 → 0.3.7

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 (863) 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.d.ts +13 -0
  5. package/dist/MillerIndexInput.svelte +66 -0
  6. package/dist/MillerIndexInput.svelte.d.ts +7 -0
  7. package/dist/api/mp.d.ts +6 -0
  8. package/dist/api/mp.js +22 -0
  9. package/dist/api/optimade.d.ts +45 -0
  10. package/dist/api/optimade.js +135 -0
  11. package/dist/brillouin/BrillouinZone.svelte +549 -0
  12. package/dist/brillouin/BrillouinZone.svelte.d.ts +83 -0
  13. package/dist/brillouin/BrillouinZoneControls.svelte +144 -0
  14. package/dist/brillouin/BrillouinZoneControls.svelte.d.ts +17 -0
  15. package/dist/brillouin/BrillouinZoneExportPane.svelte +146 -0
  16. package/dist/brillouin/BrillouinZoneExportPane.svelte.d.ts +15 -0
  17. package/dist/brillouin/BrillouinZoneInfoPane.svelte +146 -0
  18. package/dist/brillouin/BrillouinZoneInfoPane.svelte.d.ts +13 -0
  19. package/dist/brillouin/BrillouinZoneScene.svelte +476 -0
  20. package/dist/brillouin/BrillouinZoneScene.svelte.d.ts +48 -0
  21. package/dist/brillouin/BrillouinZoneTooltip.svelte +92 -0
  22. package/dist/brillouin/BrillouinZoneTooltip.svelte.d.ts +8 -0
  23. package/dist/brillouin/compute.d.ts +17 -0
  24. package/dist/brillouin/compute.js +426 -0
  25. package/dist/brillouin/index.d.ts +8 -0
  26. package/dist/brillouin/index.js +7 -0
  27. package/dist/brillouin/types.d.ts +43 -0
  28. package/dist/brillouin/types.js +1 -0
  29. package/dist/chempot-diagram/ChemPotDiagram.svelte +327 -0
  30. package/dist/chempot-diagram/ChemPotDiagram.svelte.d.ts +13 -0
  31. package/dist/chempot-diagram/ChemPotDiagram2D.svelte +846 -0
  32. package/dist/chempot-diagram/ChemPotDiagram2D.svelte.d.ts +16 -0
  33. package/dist/chempot-diagram/ChemPotDiagram3D.svelte +3193 -0
  34. package/dist/chempot-diagram/ChemPotDiagram3D.svelte.d.ts +16 -0
  35. package/dist/chempot-diagram/ChemPotScene3D.svelte.d.ts +7 -0
  36. package/dist/chempot-diagram/async-compute.svelte.d.ts +3 -0
  37. package/dist/chempot-diagram/async-compute.svelte.js +78 -0
  38. package/dist/chempot-diagram/chempot-worker.d.ts +1 -0
  39. package/dist/chempot-diagram/chempot-worker.js +11 -0
  40. package/dist/chempot-diagram/color.d.ts +10 -0
  41. package/dist/chempot-diagram/color.js +32 -0
  42. package/dist/chempot-diagram/compute.d.ts +48 -0
  43. package/dist/chempot-diagram/compute.js +806 -0
  44. package/dist/chempot-diagram/index.d.ts +6 -0
  45. package/dist/chempot-diagram/index.js +6 -0
  46. package/dist/chempot-diagram/pointer.d.ts +16 -0
  47. package/dist/chempot-diagram/pointer.js +40 -0
  48. package/dist/chempot-diagram/temperature.d.ts +15 -0
  49. package/dist/chempot-diagram/temperature.js +34 -0
  50. package/dist/chempot-diagram/types.d.ts +81 -0
  51. package/dist/chempot-diagram/types.js +28 -0
  52. package/dist/colors/index.d.ts +47 -0
  53. package/dist/colors/index.js +203 -0
  54. package/dist/composition/BarChart.svelte +297 -0
  55. package/dist/composition/BarChart.svelte.d.ts +39 -0
  56. package/dist/composition/BubbleChart.svelte +218 -0
  57. package/dist/composition/BubbleChart.svelte.d.ts +28 -0
  58. package/dist/composition/Composition.svelte +165 -0
  59. package/dist/composition/Composition.svelte.d.ts +15 -0
  60. package/dist/composition/Formula.svelte +268 -0
  61. package/dist/composition/Formula.svelte.d.ts +19 -0
  62. package/dist/composition/FormulaFilter.svelte +1257 -0
  63. package/dist/composition/FormulaFilter.svelte.d.ts +51 -0
  64. package/dist/composition/PieChart.svelte +323 -0
  65. package/dist/composition/PieChart.svelte.d.ts +37 -0
  66. package/dist/composition/format.d.ts +15 -0
  67. package/dist/composition/format.js +109 -0
  68. package/dist/composition/index.d.ts +20 -0
  69. package/dist/composition/index.js +14 -0
  70. package/dist/composition/parse.d.ts +56 -0
  71. package/dist/composition/parse.js +474 -0
  72. package/dist/constants.d.ts +29 -0
  73. package/dist/constants.js +99 -0
  74. package/dist/controls.d.ts +14 -0
  75. package/dist/controls.js +30 -0
  76. package/dist/convex-hull/ConvexHull.svelte +157 -0
  77. package/dist/convex-hull/ConvexHull.svelte.d.ts +13 -0
  78. package/dist/convex-hull/ConvexHull2D.svelte +825 -0
  79. package/dist/convex-hull/ConvexHull2D.svelte.d.ts +11 -0
  80. package/dist/convex-hull/ConvexHull3D.svelte +1801 -0
  81. package/dist/convex-hull/ConvexHull3D.svelte.d.ts +8 -0
  82. package/dist/convex-hull/ConvexHull4D.svelte +1398 -0
  83. package/dist/convex-hull/ConvexHull4D.svelte.d.ts +8 -0
  84. package/dist/convex-hull/ConvexHullControls.svelte +535 -0
  85. package/dist/convex-hull/ConvexHullControls.svelte.d.ts +48 -0
  86. package/dist/convex-hull/ConvexHullInfoPane.svelte +125 -0
  87. package/dist/convex-hull/ConvexHullInfoPane.svelte.d.ts +20 -0
  88. package/dist/convex-hull/ConvexHullStats.svelte +929 -0
  89. package/dist/convex-hull/ConvexHullStats.svelte.d.ts +17 -0
  90. package/dist/convex-hull/ConvexHullTooltip.svelte +131 -0
  91. package/dist/convex-hull/ConvexHullTooltip.svelte.d.ts +33 -0
  92. package/dist/convex-hull/GasPressureControls.svelte +247 -0
  93. package/dist/convex-hull/GasPressureControls.svelte.d.ts +11 -0
  94. package/dist/convex-hull/StructurePopup.svelte +151 -0
  95. package/dist/convex-hull/StructurePopup.svelte.d.ts +18 -0
  96. package/dist/convex-hull/TemperatureSlider.svelte.d.ts +8 -0
  97. package/dist/convex-hull/barycentric-coords.d.ts +18 -0
  98. package/dist/convex-hull/barycentric-coords.js +182 -0
  99. package/dist/convex-hull/demo-temperature.d.ts +6 -0
  100. package/dist/convex-hull/demo-temperature.js +40 -0
  101. package/dist/convex-hull/gas-thermodynamics.d.ts +16 -0
  102. package/dist/convex-hull/gas-thermodynamics.js +314 -0
  103. package/dist/convex-hull/helpers.d.ts +114 -0
  104. package/dist/convex-hull/helpers.js +710 -0
  105. package/dist/convex-hull/index.d.ts +119 -0
  106. package/dist/convex-hull/index.js +58 -0
  107. package/dist/convex-hull/thermodynamics.d.ts +67 -0
  108. package/dist/convex-hull/thermodynamics.js +1752 -0
  109. package/dist/convex-hull/types.d.ts +162 -0
  110. package/dist/convex-hull/types.js +36 -0
  111. package/dist/coordination/CoordinationBarPlot.svelte +311 -0
  112. package/dist/coordination/CoordinationBarPlot.svelte.d.ts +30 -0
  113. package/dist/coordination/calc-coordination.d.ts +15 -0
  114. package/dist/coordination/calc-coordination.js +63 -0
  115. package/dist/coordination/index.d.ts +8 -0
  116. package/dist/coordination/index.js +7 -0
  117. package/dist/effects.svelte.d.ts +12 -0
  118. package/dist/effects.svelte.js +37 -0
  119. package/dist/element/BohrAtom.svelte.d.ts +20 -0
  120. package/dist/element/ElementHeading.svelte +26 -0
  121. package/dist/element/ElementHeading.svelte.d.ts +8 -0
  122. package/dist/element/ElementPhoto.svelte +57 -0
  123. package/dist/element/ElementPhoto.svelte.d.ts +9 -0
  124. package/dist/element/ElementStats.svelte +80 -0
  125. package/dist/element/ElementStats.svelte.d.ts +8 -0
  126. package/dist/element/ElementTile.svelte +484 -0
  127. package/dist/element/ElementTile.svelte.d.ts +29 -0
  128. package/dist/element/Nucleus.svelte.d.ts +17 -0
  129. package/dist/element/data.d.ts +2 -0
  130. package/dist/element/data.js +2 -0
  131. package/dist/element/index.d.ts +8 -0
  132. package/dist/element/index.js +7 -0
  133. package/dist/element/types.d.ts +57 -0
  134. package/dist/element/types.js +1 -0
  135. package/dist/feedback/ClickFeedback.svelte +58 -0
  136. package/dist/feedback/ClickFeedback.svelte.d.ts +12 -0
  137. package/dist/feedback/DragOverlay.svelte +42 -0
  138. package/dist/feedback/DragOverlay.svelte.d.ts +7 -0
  139. package/dist/feedback/Spinner.svelte.d.ts +7 -0
  140. package/dist/feedback/StatusMessage.svelte.d.ts +9 -0
  141. package/dist/feedback/index.d.ts +4 -0
  142. package/dist/feedback/index.js +4 -0
  143. package/dist/fermi-surface/FermiSlice.svelte +189 -0
  144. package/dist/fermi-surface/FermiSlice.svelte.d.ts +24 -0
  145. package/dist/fermi-surface/FermiSurface.svelte +600 -0
  146. package/dist/fermi-surface/FermiSurface.svelte.d.ts +83 -0
  147. package/dist/fermi-surface/FermiSurfaceControls.svelte +448 -0
  148. package/dist/fermi-surface/FermiSurfaceControls.svelte.d.ts +35 -0
  149. package/dist/fermi-surface/FermiSurfaceScene.svelte +794 -0
  150. package/dist/fermi-surface/FermiSurfaceScene.svelte.d.ts +50 -0
  151. package/dist/fermi-surface/FermiSurfaceTooltip.svelte +111 -0
  152. package/dist/fermi-surface/FermiSurfaceTooltip.svelte.d.ts +8 -0
  153. package/dist/fermi-surface/compute.d.ts +5 -0
  154. package/dist/fermi-surface/compute.js +538 -0
  155. package/dist/fermi-surface/constants.d.ts +9 -0
  156. package/dist/fermi-surface/constants.js +27 -0
  157. package/dist/fermi-surface/export.d.ts +5 -0
  158. package/dist/fermi-surface/export.js +50 -0
  159. package/dist/fermi-surface/index.d.ts +12 -0
  160. package/dist/fermi-surface/index.js +13 -0
  161. package/dist/fermi-surface/marching-cubes.d.ts +2 -0
  162. package/dist/fermi-surface/marching-cubes.js +2 -0
  163. package/dist/fermi-surface/parse.d.ts +2 -0
  164. package/dist/fermi-surface/parse.js +491 -0
  165. package/dist/fermi-surface/symmetry.d.ts +3 -0
  166. package/dist/fermi-surface/symmetry.js +46 -0
  167. package/dist/fermi-surface/types.d.ts +110 -0
  168. package/dist/fermi-surface/types.js +4 -0
  169. package/dist/heatmap-matrix/HeatmapMatrix.svelte +1545 -0
  170. package/dist/heatmap-matrix/HeatmapMatrix.svelte.d.ts +110 -0
  171. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte +225 -0
  172. package/dist/heatmap-matrix/HeatmapMatrixControls.svelte.d.ts +30 -0
  173. package/dist/heatmap-matrix/index.d.ts +53 -0
  174. package/dist/heatmap-matrix/index.js +100 -0
  175. package/dist/heatmap-matrix/shared.d.ts +2 -0
  176. package/dist/heatmap-matrix/shared.js +4 -0
  177. package/dist/icons.d.ts +569 -0
  178. package/dist/icons.js +648 -0
  179. package/dist/index.d.ts +39 -0
  180. package/dist/index.js +39 -0
  181. package/dist/io/decompress.d.ts +11 -0
  182. package/dist/io/decompress.js +74 -0
  183. package/dist/io/export.d.ts +16 -0
  184. package/dist/io/export.js +316 -0
  185. package/dist/io/fetch.d.ts +5 -0
  186. package/dist/io/fetch.js +39 -0
  187. package/dist/io/file-drop.d.ts +7 -0
  188. package/dist/io/file-drop.js +43 -0
  189. package/dist/io/index.d.ts +7 -0
  190. package/dist/io/index.js +6 -0
  191. package/dist/io/is-binary.d.ts +1 -0
  192. package/dist/io/is-binary.js +20 -0
  193. package/dist/io/types.d.ts +8 -0
  194. package/dist/io/types.js +1 -0
  195. package/dist/io/url-drop.d.ts +2 -0
  196. package/dist/io/url-drop.js +123 -0
  197. package/dist/isosurface/Isosurface.svelte +285 -0
  198. package/dist/isosurface/Isosurface.svelte.d.ts +8 -0
  199. package/dist/isosurface/IsosurfaceControls.svelte +277 -0
  200. package/dist/isosurface/IsosurfaceControls.svelte.d.ts +9 -0
  201. package/dist/isosurface/index.d.ts +5 -0
  202. package/dist/isosurface/index.js +6 -0
  203. package/dist/isosurface/parse.d.ts +6 -0
  204. package/dist/isosurface/parse.js +553 -0
  205. package/dist/isosurface/slice.d.ts +11 -0
  206. package/dist/isosurface/slice.js +140 -0
  207. package/dist/isosurface/types.d.ts +56 -0
  208. package/dist/isosurface/types.js +227 -0
  209. package/dist/labels.d.ts +53 -0
  210. package/dist/labels.js +277 -0
  211. package/dist/layout/FullscreenToggle.svelte +50 -0
  212. package/dist/layout/FullscreenToggle.svelte.d.ts +7 -0
  213. package/dist/layout/InfoCard.svelte +120 -0
  214. package/dist/layout/InfoCard.svelte.d.ts +21 -0
  215. package/dist/layout/InfoTag.svelte +185 -0
  216. package/dist/layout/InfoTag.svelte.d.ts +19 -0
  217. package/dist/layout/PropertyFilter.svelte +246 -0
  218. package/dist/layout/PropertyFilter.svelte.d.ts +24 -0
  219. package/dist/layout/SettingsSection.svelte +148 -0
  220. package/dist/layout/SettingsSection.svelte.d.ts +17 -0
  221. package/dist/layout/SubpageGrid.svelte +82 -0
  222. package/dist/layout/SubpageGrid.svelte.d.ts +14 -0
  223. package/dist/layout/fullscreen.d.ts +9 -0
  224. package/dist/layout/fullscreen.js +53 -0
  225. package/dist/layout/index.d.ts +10 -0
  226. package/dist/layout/index.js +8 -0
  227. package/dist/layout/json-tree/JsonNode.svelte +548 -0
  228. package/dist/layout/json-tree/JsonNode.svelte.d.ts +11 -0
  229. package/dist/layout/json-tree/JsonTree.svelte +1230 -0
  230. package/dist/layout/json-tree/JsonTree.svelte.d.ts +6 -0
  231. package/dist/layout/json-tree/JsonValue.svelte.d.ts +9 -0
  232. package/dist/layout/json-tree/index.d.ts +3 -0
  233. package/dist/layout/json-tree/index.js +3 -0
  234. package/dist/layout/json-tree/types.d.ts +74 -0
  235. package/dist/layout/json-tree/types.js +2 -0
  236. package/dist/layout/json-tree/utils.d.ts +29 -0
  237. package/dist/layout/json-tree/utils.js +641 -0
  238. package/dist/marching-cubes.d.ts +14 -0
  239. package/dist/marching-cubes.js +540 -0
  240. package/dist/math.d.ts +101 -0
  241. package/dist/math.js +905 -0
  242. package/dist/overlays/ContextMenu.svelte +162 -0
  243. package/dist/overlays/ContextMenu.svelte.d.ts +25 -0
  244. package/dist/overlays/CopyButton.svelte +45 -0
  245. package/dist/overlays/CopyButton.svelte.d.ts +8 -0
  246. package/dist/overlays/DragControlTab.svelte +98 -0
  247. package/dist/overlays/DragControlTab.svelte.d.ts +8 -0
  248. package/dist/overlays/DraggablePane.svelte +487 -0
  249. package/dist/overlays/DraggablePane.svelte.d.ts +36 -0
  250. package/dist/overlays/InfoPaneCards.svelte +149 -0
  251. package/dist/overlays/InfoPaneCards.svelte.d.ts +22 -0
  252. package/dist/overlays/index.d.ts +3 -0
  253. package/dist/overlays/index.js +3 -0
  254. package/dist/periodic-table/PeriodicTable.svelte +469 -0
  255. package/dist/periodic-table/PeriodicTable.svelte.d.ts +55 -0
  256. package/dist/periodic-table/PeriodicTableControls.svelte +557 -0
  257. package/dist/periodic-table/PeriodicTableControls.svelte.d.ts +24 -0
  258. package/dist/periodic-table/PropertySelect.svelte +37 -0
  259. package/dist/periodic-table/PropertySelect.svelte.d.ts +13 -0
  260. package/dist/periodic-table/TableInset.svelte.d.ts +9 -0
  261. package/dist/periodic-table/index.d.ts +10 -0
  262. package/dist/periodic-table/index.js +4 -0
  263. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +1086 -0
  264. package/dist/phase-diagram/IsobaricBinaryPhaseDiagram.svelte.d.ts +44 -0
  265. package/dist/phase-diagram/PhaseDiagramControls.svelte +444 -0
  266. package/dist/phase-diagram/PhaseDiagramControls.svelte.d.ts +30 -0
  267. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte +126 -0
  268. package/dist/phase-diagram/PhaseDiagramEditorPane.svelte.d.ts +15 -0
  269. package/dist/phase-diagram/PhaseDiagramExportPane.svelte +184 -0
  270. package/dist/phase-diagram/PhaseDiagramExportPane.svelte.d.ts +19 -0
  271. package/dist/phase-diagram/PhaseDiagramTooltip.svelte +391 -0
  272. package/dist/phase-diagram/PhaseDiagramTooltip.svelte.d.ts +16 -0
  273. package/dist/phase-diagram/TdbInfoPanel.svelte +203 -0
  274. package/dist/phase-diagram/TdbInfoPanel.svelte.d.ts +12 -0
  275. package/dist/phase-diagram/build-diagram.d.ts +11 -0
  276. package/dist/phase-diagram/build-diagram.js +160 -0
  277. package/dist/phase-diagram/colors.d.ts +35 -0
  278. package/dist/phase-diagram/colors.js +51 -0
  279. package/dist/phase-diagram/diagram-input.d.ts +29 -0
  280. package/dist/phase-diagram/diagram-input.js +3 -0
  281. package/dist/phase-diagram/index.d.ts +13 -0
  282. package/dist/phase-diagram/index.js +11 -0
  283. package/dist/phase-diagram/parse.d.ts +55 -0
  284. package/dist/phase-diagram/parse.js +272 -0
  285. package/dist/phase-diagram/svg-to-diagram.d.ts +2 -0
  286. package/dist/phase-diagram/svg-to-diagram.js +867 -0
  287. package/dist/phase-diagram/types.d.ts +93 -0
  288. package/dist/phase-diagram/types.js +1 -0
  289. package/dist/phase-diagram/utils.d.ts +118 -0
  290. package/dist/phase-diagram/utils.js +604 -0
  291. package/dist/plot/AxisLabel.svelte +51 -0
  292. package/dist/plot/AxisLabel.svelte.d.ts +16 -0
  293. package/dist/plot/BarPlot.svelte +2113 -0
  294. package/dist/plot/BarPlot.svelte.d.ts +84 -0
  295. package/dist/plot/BarPlotControls.svelte +66 -0
  296. package/dist/plot/BarPlotControls.svelte.d.ts +18 -0
  297. package/dist/plot/BinnedScatterPlot.svelte +1114 -0
  298. package/dist/plot/BinnedScatterPlot.svelte.d.ts +66 -0
  299. package/dist/plot/ColorBar.svelte +721 -0
  300. package/dist/plot/ColorBar.svelte.d.ts +31 -0
  301. package/dist/plot/ColorScaleSelect.svelte +54 -0
  302. package/dist/plot/ColorScaleSelect.svelte.d.ts +15 -0
  303. package/dist/plot/ElementScatter.svelte +63 -0
  304. package/dist/plot/ElementScatter.svelte.d.ts +14 -0
  305. package/dist/plot/FillArea.svelte.d.ts +21 -0
  306. package/dist/plot/Histogram.svelte +1558 -0
  307. package/dist/plot/Histogram.svelte.d.ts +50 -0
  308. package/dist/plot/HistogramControls.svelte +212 -0
  309. package/dist/plot/HistogramControls.svelte.d.ts +22 -0
  310. package/dist/plot/InteractiveAxisLabel.svelte +96 -0
  311. package/dist/plot/InteractiveAxisLabel.svelte.d.ts +14 -0
  312. package/dist/plot/Line.svelte +84 -0
  313. package/dist/plot/Line.svelte.d.ts +15 -0
  314. package/dist/plot/PlotAxis.svelte +169 -0
  315. package/dist/plot/PlotAxis.svelte.d.ts +24 -0
  316. package/dist/plot/PlotControls.svelte +537 -0
  317. package/dist/plot/PlotControls.svelte.d.ts +4 -0
  318. package/dist/plot/PlotLegend.svelte +569 -0
  319. package/dist/plot/PlotLegend.svelte.d.ts +29 -0
  320. package/dist/plot/PlotTooltip.svelte +67 -0
  321. package/dist/plot/PlotTooltip.svelte.d.ts +17 -0
  322. package/dist/plot/PortalSelect.svelte +253 -0
  323. package/dist/plot/PortalSelect.svelte.d.ts +16 -0
  324. package/dist/plot/ReferenceLine.svelte.d.ts +20 -0
  325. package/dist/plot/ReferenceLine3D.svelte +156 -0
  326. package/dist/plot/ReferenceLine3D.svelte.d.ts +14 -0
  327. package/dist/plot/ReferencePlane.svelte +175 -0
  328. package/dist/plot/ReferencePlane.svelte.d.ts +14 -0
  329. package/dist/plot/ScatterPlot.svelte +2778 -0
  330. package/dist/plot/ScatterPlot.svelte.d.ts +96 -0
  331. package/dist/plot/ScatterPlot3D.svelte +529 -0
  332. package/dist/plot/ScatterPlot3D.svelte.d.ts +95 -0
  333. package/dist/plot/ScatterPlot3DControls.svelte +437 -0
  334. package/dist/plot/ScatterPlot3DControls.svelte.d.ts +20 -0
  335. package/dist/plot/ScatterPlot3DScene.svelte +912 -0
  336. package/dist/plot/ScatterPlot3DScene.svelte.d.ts +74 -0
  337. package/dist/plot/ScatterPlotControls.svelte +306 -0
  338. package/dist/plot/ScatterPlotControls.svelte.d.ts +17 -0
  339. package/dist/plot/ScatterPoint.svelte +182 -0
  340. package/dist/plot/ScatterPoint.svelte.d.ts +22 -0
  341. package/dist/plot/SpacegroupBarPlot.svelte +293 -0
  342. package/dist/plot/SpacegroupBarPlot.svelte.d.ts +9 -0
  343. package/dist/plot/Surface3D.svelte +197 -0
  344. package/dist/plot/Surface3D.svelte.d.ts +13 -0
  345. package/dist/plot/ZeroLines.svelte +97 -0
  346. package/dist/plot/ZeroLines.svelte.d.ts +33 -0
  347. package/dist/plot/ZoomRect.svelte +23 -0
  348. package/dist/plot/ZoomRect.svelte.d.ts +8 -0
  349. package/dist/plot/adaptive-density.d.ts +69 -0
  350. package/dist/plot/adaptive-density.js +191 -0
  351. package/dist/plot/auto-place.d.ts +43 -0
  352. package/dist/plot/auto-place.js +122 -0
  353. package/dist/plot/axis-utils.d.ts +19 -0
  354. package/dist/plot/axis-utils.js +78 -0
  355. package/dist/plot/binned-scatter-types.d.ts +59 -0
  356. package/dist/plot/binned-scatter-types.js +1 -0
  357. package/dist/plot/data-cleaning.d.ts +37 -0
  358. package/dist/plot/data-cleaning.js +855 -0
  359. package/dist/plot/data-transform.d.ts +16 -0
  360. package/dist/plot/data-transform.js +45 -0
  361. package/dist/plot/defaults.d.ts +19 -0
  362. package/dist/plot/defaults.js +9 -0
  363. package/dist/plot/fill-utils.d.ts +46 -0
  364. package/dist/plot/fill-utils.js +322 -0
  365. package/dist/plot/hover-lock.svelte.d.ts +14 -0
  366. package/dist/plot/hover-lock.svelte.js +46 -0
  367. package/dist/plot/index.d.ts +41 -0
  368. package/dist/plot/index.js +39 -0
  369. package/dist/plot/interactions.d.ts +12 -0
  370. package/dist/plot/interactions.js +101 -0
  371. package/dist/plot/layout.d.ts +78 -0
  372. package/dist/plot/layout.js +273 -0
  373. package/dist/plot/reference-line.d.ts +60 -0
  374. package/dist/plot/reference-line.js +314 -0
  375. package/dist/plot/scales.d.ts +48 -0
  376. package/dist/plot/scales.js +481 -0
  377. package/dist/plot/svg.d.ts +1 -0
  378. package/dist/plot/svg.js +11 -0
  379. package/dist/plot/types.d.ts +831 -0
  380. package/dist/plot/types.js +99 -0
  381. package/dist/plot/utils/label-placement.d.ts +68 -0
  382. package/dist/plot/utils/label-placement.js +326 -0
  383. package/dist/plot/utils/series-visibility.d.ts +15 -0
  384. package/dist/plot/utils/series-visibility.js +85 -0
  385. package/dist/plot/utils.d.ts +1 -0
  386. package/dist/plot/utils.js +14 -0
  387. package/dist/rdf/RdfPlot.svelte +247 -0
  388. package/dist/rdf/RdfPlot.svelte.d.ts +27 -0
  389. package/dist/rdf/calc-rdf.d.ts +4 -0
  390. package/dist/rdf/calc-rdf.js +111 -0
  391. package/dist/rdf/index.d.ts +23 -0
  392. package/dist/rdf/index.js +2 -0
  393. package/dist/sanitize.d.ts +6 -0
  394. package/dist/sanitize.js +116 -0
  395. package/dist/settings.d.ts +255 -0
  396. package/dist/settings.js +1132 -0
  397. package/dist/spectral/Bands.svelte +1040 -0
  398. package/dist/spectral/Bands.svelte.d.ts +40 -0
  399. package/dist/spectral/BandsAndDos.svelte +134 -0
  400. package/dist/spectral/BandsAndDos.svelte.d.ts +18 -0
  401. package/dist/spectral/BrillouinBandsDos.svelte +252 -0
  402. package/dist/spectral/BrillouinBandsDos.svelte.d.ts +20 -0
  403. package/dist/spectral/Dos.svelte +697 -0
  404. package/dist/spectral/Dos.svelte.d.ts +29 -0
  405. package/dist/spectral/helpers.d.ts +119 -0
  406. package/dist/spectral/helpers.js +1032 -0
  407. package/dist/spectral/index.d.ts +6 -0
  408. package/dist/spectral/index.js +6 -0
  409. package/dist/spectral/types.d.ts +84 -0
  410. package/dist/spectral/types.js +2 -0
  411. package/dist/state.svelte.d.ts +25 -0
  412. package/dist/state.svelte.js +45 -0
  413. package/dist/structure/Arrow.svelte +72 -0
  414. package/dist/structure/Arrow.svelte.d.ts +15 -0
  415. package/dist/structure/AtomLegend.svelte +815 -0
  416. package/dist/structure/AtomLegend.svelte.d.ts +35 -0
  417. package/dist/structure/Bond.svelte +140 -0
  418. package/dist/structure/Bond.svelte.d.ts +9 -0
  419. package/dist/structure/CanvasTooltip.svelte +33 -0
  420. package/dist/structure/CanvasTooltip.svelte.d.ts +12 -0
  421. package/dist/structure/CellSelect.svelte +349 -0
  422. package/dist/structure/CellSelect.svelte.d.ts +13 -0
  423. package/dist/structure/Cylinder.svelte +45 -0
  424. package/dist/structure/Cylinder.svelte.d.ts +10 -0
  425. package/dist/structure/Lattice.svelte +196 -0
  426. package/dist/structure/Lattice.svelte.d.ts +17 -0
  427. package/dist/structure/Structure.svelte +2248 -0
  428. package/dist/structure/Structure.svelte.d.ts +89 -0
  429. package/dist/structure/StructureControls.svelte +1273 -0
  430. package/dist/structure/StructureControls.svelte.d.ts +31 -0
  431. package/dist/structure/StructureExportPane.svelte +252 -0
  432. package/dist/structure/StructureExportPane.svelte.d.ts +17 -0
  433. package/dist/structure/StructureInfoPane.svelte +737 -0
  434. package/dist/structure/StructureInfoPane.svelte.d.ts +19 -0
  435. package/dist/structure/StructureScene.svelte +2255 -0
  436. package/dist/structure/StructureScene.svelte.d.ts +111 -0
  437. package/dist/structure/atom-properties.d.ts +37 -0
  438. package/dist/structure/atom-properties.js +200 -0
  439. package/dist/structure/bond-order-perception.d.ts +13 -0
  440. package/dist/structure/bond-order-perception.js +384 -0
  441. package/dist/structure/bonding.d.ts +68 -0
  442. package/dist/structure/bonding.js +696 -0
  443. package/dist/structure/export.d.ts +20 -0
  444. package/dist/structure/export.js +727 -0
  445. package/dist/structure/index.d.ts +126 -0
  446. package/dist/structure/index.js +169 -0
  447. package/dist/structure/label-placement.d.ts +14 -0
  448. package/dist/structure/label-placement.js +72 -0
  449. package/dist/structure/measure.d.ts +6 -0
  450. package/dist/structure/measure.js +29 -0
  451. package/dist/structure/parse.d.ts +66 -0
  452. package/dist/structure/parse.js +1392 -0
  453. package/dist/structure/partial-occupancy.d.ts +25 -0
  454. package/dist/structure/partial-occupancy.js +99 -0
  455. package/dist/structure/pbc.d.ts +9 -0
  456. package/dist/structure/pbc.js +123 -0
  457. package/dist/structure/supercell.d.ts +8 -0
  458. package/dist/structure/supercell.js +170 -0
  459. package/dist/structure/validation.d.ts +2 -0
  460. package/dist/structure/validation.js +10 -0
  461. package/dist/symmetry/SymmetryStats.svelte +226 -0
  462. package/dist/symmetry/SymmetryStats.svelte.d.ts +21 -0
  463. package/dist/symmetry/WyckoffTable.svelte +120 -0
  464. package/dist/symmetry/WyckoffTable.svelte.d.ts +11 -0
  465. package/dist/symmetry/cell-transform.d.ts +12 -0
  466. package/dist/symmetry/cell-transform.js +91 -0
  467. package/dist/symmetry/index.d.ts +43 -0
  468. package/dist/symmetry/index.js +228 -0
  469. package/dist/symmetry/spacegroups.d.ts +9 -0
  470. package/dist/symmetry/spacegroups.js +394 -0
  471. package/dist/table/HeatmapTable.svelte +1833 -0
  472. package/dist/table/HeatmapTable.svelte.d.ts +49 -0
  473. package/dist/table/ToggleMenu.svelte +385 -0
  474. package/dist/table/ToggleMenu.svelte.d.ts +11 -0
  475. package/dist/table/index.d.ts +74 -0
  476. package/dist/table/index.js +38 -0
  477. package/dist/theme/ThemeControl.svelte +53 -0
  478. package/dist/theme/ThemeControl.svelte.d.ts +9 -0
  479. package/dist/theme/index.d.ts +29 -0
  480. package/dist/theme/index.js +79 -0
  481. package/dist/time.d.ts +4 -0
  482. package/dist/time.js +70 -0
  483. package/dist/tooltip/TooltipContent.svelte +58 -0
  484. package/dist/tooltip/TooltipContent.svelte.d.ts +31 -0
  485. package/dist/tooltip/index.d.ts +2 -0
  486. package/dist/tooltip/index.js +1 -0
  487. package/dist/tooltip/types.d.ts +8 -0
  488. package/dist/tooltip/types.js +1 -0
  489. package/dist/trajectory/Trajectory.svelte +1545 -0
  490. package/dist/trajectory/Trajectory.svelte.d.ts +77 -0
  491. package/dist/trajectory/TrajectoryError.svelte +128 -0
  492. package/dist/trajectory/TrajectoryError.svelte.d.ts +13 -0
  493. package/dist/trajectory/TrajectoryExportPane.svelte +357 -0
  494. package/dist/trajectory/TrajectoryExportPane.svelte.d.ts +17 -0
  495. package/dist/trajectory/TrajectoryInfoPane.svelte +313 -0
  496. package/dist/trajectory/TrajectoryInfoPane.svelte.d.ts +17 -0
  497. package/dist/trajectory/constants.d.ts +6 -0
  498. package/dist/trajectory/constants.js +7 -0
  499. package/dist/trajectory/extract.d.ts +5 -0
  500. package/dist/trajectory/extract.js +162 -0
  501. package/dist/trajectory/format-detect.d.ts +9 -0
  502. package/dist/trajectory/format-detect.js +76 -0
  503. package/dist/trajectory/frame-reader.d.ts +17 -0
  504. package/dist/trajectory/frame-reader.js +332 -0
  505. package/dist/trajectory/helpers.d.ts +15 -0
  506. package/dist/trajectory/helpers.js +164 -0
  507. package/dist/trajectory/index.d.ts +63 -0
  508. package/dist/trajectory/index.js +126 -0
  509. package/dist/trajectory/parse/ase.d.ts +2 -0
  510. package/dist/trajectory/parse/ase.js +73 -0
  511. package/dist/trajectory/parse/hdf5.d.ts +2 -0
  512. package/dist/trajectory/parse/hdf5.js +127 -0
  513. package/dist/trajectory/parse/index.d.ts +12 -0
  514. package/dist/trajectory/parse/index.js +298 -0
  515. package/dist/trajectory/parse/lammps.d.ts +5 -0
  516. package/dist/trajectory/parse/lammps.js +179 -0
  517. package/dist/trajectory/parse/vasp.d.ts +2 -0
  518. package/dist/trajectory/parse/vasp.js +68 -0
  519. package/dist/trajectory/parse/xyz.d.ts +2 -0
  520. package/dist/trajectory/parse/xyz.js +110 -0
  521. package/dist/trajectory/plotting.d.ts +28 -0
  522. package/dist/trajectory/plotting.js +423 -0
  523. package/dist/trajectory/types.d.ts +11 -0
  524. package/dist/trajectory/types.js +1 -0
  525. package/dist/utils.d.ts +6 -0
  526. package/dist/utils.js +45 -0
  527. package/dist/xrd/XrdPlot.svelte +615 -0
  528. package/dist/xrd/XrdPlot.svelte.d.ts +28 -0
  529. package/dist/xrd/broadening.d.ts +20 -0
  530. package/dist/xrd/broadening.js +97 -0
  531. package/dist/xrd/calc-xrd.d.ts +37 -0
  532. package/dist/xrd/calc-xrd.js +336 -0
  533. package/dist/xrd/index.d.ts +37 -0
  534. package/dist/xrd/index.js +4 -0
  535. package/dist/xrd/parse.d.ts +13 -0
  536. package/dist/xrd/parse.js +749 -0
  537. package/license +1 -1
  538. package/package.json +232 -1457
  539. package/readme.md +98 -171
  540. package/.vscode/launch.json +0 -13
  541. package/.vscodeignore +0 -7
  542. package/dist/assets/STLExporter-BpTH3YHE.js +0 -8
  543. package/dist/assets/browser-DdDecX_W.js +0 -1
  544. package/dist/assets/export-qgn-H9y6.js +0 -2
  545. package/dist/assets/main-DiKYzti2.css +0 -1
  546. package/dist/assets/moyo_wasm_bg-0ocwg7xY.wasm +0 -0
  547. package/dist/extension.js +0 -31293
  548. package/dist/src/lib/FilePicker.svelte +0 -360
  549. package/dist/src/lib/MillerIndexInput.svelte +0 -66
  550. package/dist/src/lib/api/mp.ts +0 -26
  551. package/dist/src/lib/api/optimade.ts +0 -204
  552. package/dist/src/lib/brillouin/BrillouinZone.svelte +0 -549
  553. package/dist/src/lib/brillouin/BrillouinZoneControls.svelte +0 -144
  554. package/dist/src/lib/brillouin/BrillouinZoneExportPane.svelte +0 -146
  555. package/dist/src/lib/brillouin/BrillouinZoneInfoPane.svelte +0 -146
  556. package/dist/src/lib/brillouin/BrillouinZoneScene.svelte +0 -476
  557. package/dist/src/lib/brillouin/BrillouinZoneTooltip.svelte +0 -92
  558. package/dist/src/lib/brillouin/compute.ts +0 -529
  559. package/dist/src/lib/brillouin/index.ts +0 -8
  560. package/dist/src/lib/brillouin/types.ts +0 -51
  561. package/dist/src/lib/chempot-diagram/ChemPotDiagram.svelte +0 -327
  562. package/dist/src/lib/chempot-diagram/ChemPotDiagram2D.svelte +0 -846
  563. package/dist/src/lib/chempot-diagram/ChemPotDiagram3D.svelte +0 -3193
  564. package/dist/src/lib/chempot-diagram/async-compute.svelte.ts +0 -94
  565. package/dist/src/lib/chempot-diagram/chempot-worker.ts +0 -11
  566. package/dist/src/lib/chempot-diagram/color.ts +0 -42
  567. package/dist/src/lib/chempot-diagram/compute.ts +0 -1014
  568. package/dist/src/lib/chempot-diagram/index.ts +0 -6
  569. package/dist/src/lib/chempot-diagram/pointer.ts +0 -56
  570. package/dist/src/lib/chempot-diagram/temperature.ts +0 -77
  571. package/dist/src/lib/chempot-diagram/types.ts +0 -130
  572. package/dist/src/lib/colors/index.ts +0 -249
  573. package/dist/src/lib/composition/BarChart.svelte +0 -297
  574. package/dist/src/lib/composition/BubbleChart.svelte +0 -218
  575. package/dist/src/lib/composition/Composition.svelte +0 -165
  576. package/dist/src/lib/composition/Formula.svelte +0 -268
  577. package/dist/src/lib/composition/FormulaFilter.svelte +0 -1257
  578. package/dist/src/lib/composition/PieChart.svelte +0 -323
  579. package/dist/src/lib/composition/format.ts +0 -155
  580. package/dist/src/lib/composition/index.ts +0 -37
  581. package/dist/src/lib/composition/parse.ts +0 -605
  582. package/dist/src/lib/constants.ts +0 -134
  583. package/dist/src/lib/controls.ts +0 -42
  584. package/dist/src/lib/convex-hull/ConvexHull.svelte +0 -157
  585. package/dist/src/lib/convex-hull/ConvexHull2D.svelte +0 -825
  586. package/dist/src/lib/convex-hull/ConvexHull3D.svelte +0 -1801
  587. package/dist/src/lib/convex-hull/ConvexHull4D.svelte +0 -1398
  588. package/dist/src/lib/convex-hull/ConvexHullControls.svelte +0 -535
  589. package/dist/src/lib/convex-hull/ConvexHullInfoPane.svelte +0 -125
  590. package/dist/src/lib/convex-hull/ConvexHullStats.svelte +0 -929
  591. package/dist/src/lib/convex-hull/ConvexHullTooltip.svelte +0 -131
  592. package/dist/src/lib/convex-hull/GasPressureControls.svelte +0 -247
  593. package/dist/src/lib/convex-hull/StructurePopup.svelte +0 -151
  594. package/dist/src/lib/convex-hull/barycentric-coords.ts +0 -246
  595. package/dist/src/lib/convex-hull/demo-temperature.ts +0 -63
  596. package/dist/src/lib/convex-hull/gas-thermodynamics.ts +0 -405
  597. package/dist/src/lib/convex-hull/helpers.ts +0 -932
  598. package/dist/src/lib/convex-hull/index.ts +0 -202
  599. package/dist/src/lib/convex-hull/thermodynamics.ts +0 -2192
  600. package/dist/src/lib/convex-hull/types.ts +0 -267
  601. package/dist/src/lib/coordination/CoordinationBarPlot.svelte +0 -311
  602. package/dist/src/lib/coordination/calc-coordination.ts +0 -93
  603. package/dist/src/lib/coordination/index.ts +0 -9
  604. package/dist/src/lib/effects.svelte.ts +0 -48
  605. package/dist/src/lib/element/ElementHeading.svelte +0 -26
  606. package/dist/src/lib/element/ElementPhoto.svelte +0 -57
  607. package/dist/src/lib/element/ElementStats.svelte +0 -80
  608. package/dist/src/lib/element/ElementTile.svelte +0 -484
  609. package/dist/src/lib/element/data.ts +0 -14
  610. package/dist/src/lib/element/index.ts +0 -8
  611. package/dist/src/lib/element/types.ts +0 -62
  612. package/dist/src/lib/feedback/ClickFeedback.svelte +0 -58
  613. package/dist/src/lib/feedback/DragOverlay.svelte +0 -42
  614. package/dist/src/lib/feedback/index.ts +0 -4
  615. package/dist/src/lib/fermi-surface/FermiSlice.svelte +0 -189
  616. package/dist/src/lib/fermi-surface/FermiSurface.svelte +0 -600
  617. package/dist/src/lib/fermi-surface/FermiSurfaceControls.svelte +0 -448
  618. package/dist/src/lib/fermi-surface/FermiSurfaceScene.svelte +0 -794
  619. package/dist/src/lib/fermi-surface/FermiSurfaceTooltip.svelte +0 -111
  620. package/dist/src/lib/fermi-surface/compute.ts +0 -728
  621. package/dist/src/lib/fermi-surface/constants.ts +0 -32
  622. package/dist/src/lib/fermi-surface/export.ts +0 -64
  623. package/dist/src/lib/fermi-surface/index.ts +0 -14
  624. package/dist/src/lib/fermi-surface/marching-cubes.ts +0 -3
  625. package/dist/src/lib/fermi-surface/parse.ts +0 -574
  626. package/dist/src/lib/fermi-surface/symmetry.ts +0 -56
  627. package/dist/src/lib/fermi-surface/types.ts +0 -159
  628. package/dist/src/lib/heatmap-matrix/HeatmapMatrix.svelte +0 -1545
  629. package/dist/src/lib/heatmap-matrix/HeatmapMatrixControls.svelte +0 -225
  630. package/dist/src/lib/heatmap-matrix/index.ts +0 -167
  631. package/dist/src/lib/heatmap-matrix/shared.ts +0 -7
  632. package/dist/src/lib/icons.ts +0 -650
  633. package/dist/src/lib/index.ts +0 -61
  634. package/dist/src/lib/io/decompress.ts +0 -92
  635. package/dist/src/lib/io/export.ts +0 -385
  636. package/dist/src/lib/io/fetch.ts +0 -46
  637. package/dist/src/lib/io/file-drop.ts +0 -51
  638. package/dist/src/lib/io/index.ts +0 -7
  639. package/dist/src/lib/io/is-binary.ts +0 -24
  640. package/dist/src/lib/io/types.ts +0 -8
  641. package/dist/src/lib/io/url-drop.ts +0 -141
  642. package/dist/src/lib/isosurface/Isosurface.svelte +0 -285
  643. package/dist/src/lib/isosurface/IsosurfaceControls.svelte +0 -277
  644. package/dist/src/lib/isosurface/index.ts +0 -7
  645. package/dist/src/lib/isosurface/parse.ts +0 -656
  646. package/dist/src/lib/isosurface/slice.ts +0 -175
  647. package/dist/src/lib/isosurface/types.ts +0 -309
  648. package/dist/src/lib/labels.ts +0 -320
  649. package/dist/src/lib/layout/FullscreenToggle.svelte +0 -50
  650. package/dist/src/lib/layout/InfoCard.svelte +0 -120
  651. package/dist/src/lib/layout/InfoTag.svelte +0 -185
  652. package/dist/src/lib/layout/PropertyFilter.svelte +0 -246
  653. package/dist/src/lib/layout/SettingsSection.svelte +0 -148
  654. package/dist/src/lib/layout/SubpageGrid.svelte +0 -82
  655. package/dist/src/lib/layout/fullscreen.ts +0 -65
  656. package/dist/src/lib/layout/index.ts +0 -11
  657. package/dist/src/lib/layout/json-tree/JsonNode.svelte +0 -548
  658. package/dist/src/lib/layout/json-tree/JsonTree.svelte +0 -1230
  659. package/dist/src/lib/layout/json-tree/index.ts +0 -3
  660. package/dist/src/lib/layout/json-tree/types.ts +0 -126
  661. package/dist/src/lib/layout/json-tree/utils.ts +0 -682
  662. package/dist/src/lib/marching-cubes.ts +0 -614
  663. package/dist/src/lib/math.ts +0 -1081
  664. package/dist/src/lib/overlays/ContextMenu.svelte +0 -162
  665. package/dist/src/lib/overlays/CopyButton.svelte +0 -45
  666. package/dist/src/lib/overlays/DragControlTab.svelte +0 -98
  667. package/dist/src/lib/overlays/DraggablePane.svelte +0 -487
  668. package/dist/src/lib/overlays/InfoPaneCards.svelte +0 -149
  669. package/dist/src/lib/overlays/index.ts +0 -3
  670. package/dist/src/lib/periodic-table/PeriodicTable.svelte +0 -469
  671. package/dist/src/lib/periodic-table/PeriodicTableControls.svelte +0 -557
  672. package/dist/src/lib/periodic-table/PropertySelect.svelte +0 -37
  673. package/dist/src/lib/periodic-table/index.ts +0 -12
  674. package/dist/src/lib/phase-diagram/IsobaricBinaryPhaseDiagram.svelte +0 -1086
  675. package/dist/src/lib/phase-diagram/PhaseDiagramControls.svelte +0 -444
  676. package/dist/src/lib/phase-diagram/PhaseDiagramEditorPane.svelte +0 -126
  677. package/dist/src/lib/phase-diagram/PhaseDiagramExportPane.svelte +0 -184
  678. package/dist/src/lib/phase-diagram/PhaseDiagramTooltip.svelte +0 -391
  679. package/dist/src/lib/phase-diagram/TdbInfoPanel.svelte +0 -203
  680. package/dist/src/lib/phase-diagram/build-diagram.ts +0 -186
  681. package/dist/src/lib/phase-diagram/colors.ts +0 -58
  682. package/dist/src/lib/phase-diagram/diagram-input.ts +0 -40
  683. package/dist/src/lib/phase-diagram/index.ts +0 -13
  684. package/dist/src/lib/phase-diagram/parse.ts +0 -348
  685. package/dist/src/lib/phase-diagram/svg-to-diagram.ts +0 -1023
  686. package/dist/src/lib/phase-diagram/types.ts +0 -144
  687. package/dist/src/lib/phase-diagram/utils.ts +0 -775
  688. package/dist/src/lib/plot/AxisLabel.svelte +0 -51
  689. package/dist/src/lib/plot/BarPlot.svelte +0 -2113
  690. package/dist/src/lib/plot/BarPlotControls.svelte +0 -66
  691. package/dist/src/lib/plot/BinnedScatterPlot.svelte +0 -1114
  692. package/dist/src/lib/plot/ColorBar.svelte +0 -721
  693. package/dist/src/lib/plot/ColorScaleSelect.svelte +0 -54
  694. package/dist/src/lib/plot/ElementScatter.svelte +0 -63
  695. package/dist/src/lib/plot/Histogram.svelte +0 -1558
  696. package/dist/src/lib/plot/HistogramControls.svelte +0 -212
  697. package/dist/src/lib/plot/InteractiveAxisLabel.svelte +0 -96
  698. package/dist/src/lib/plot/Line.svelte +0 -84
  699. package/dist/src/lib/plot/PlotAxis.svelte +0 -169
  700. package/dist/src/lib/plot/PlotControls.svelte +0 -537
  701. package/dist/src/lib/plot/PlotLegend.svelte +0 -569
  702. package/dist/src/lib/plot/PlotTooltip.svelte +0 -67
  703. package/dist/src/lib/plot/PortalSelect.svelte +0 -253
  704. package/dist/src/lib/plot/ReferenceLine3D.svelte +0 -156
  705. package/dist/src/lib/plot/ReferencePlane.svelte +0 -175
  706. package/dist/src/lib/plot/ScatterPlot.svelte +0 -2778
  707. package/dist/src/lib/plot/ScatterPlot3D.svelte +0 -529
  708. package/dist/src/lib/plot/ScatterPlot3DControls.svelte +0 -437
  709. package/dist/src/lib/plot/ScatterPlot3DScene.svelte +0 -912
  710. package/dist/src/lib/plot/ScatterPlotControls.svelte +0 -306
  711. package/dist/src/lib/plot/ScatterPoint.svelte +0 -182
  712. package/dist/src/lib/plot/SpacegroupBarPlot.svelte +0 -293
  713. package/dist/src/lib/plot/Surface3D.svelte +0 -197
  714. package/dist/src/lib/plot/ZeroLines.svelte +0 -97
  715. package/dist/src/lib/plot/ZoomRect.svelte +0 -23
  716. package/dist/src/lib/plot/adaptive-density.ts +0 -316
  717. package/dist/src/lib/plot/auto-place.ts +0 -184
  718. package/dist/src/lib/plot/axis-utils.ts +0 -122
  719. package/dist/src/lib/plot/binned-scatter-types.ts +0 -83
  720. package/dist/src/lib/plot/data-cleaning.ts +0 -1069
  721. package/dist/src/lib/plot/data-transform.ts +0 -69
  722. package/dist/src/lib/plot/defaults.ts +0 -9
  723. package/dist/src/lib/plot/fill-utils.ts +0 -494
  724. package/dist/src/lib/plot/hover-lock.svelte.ts +0 -60
  725. package/dist/src/lib/plot/index.ts +0 -53
  726. package/dist/src/lib/plot/interactions.ts +0 -119
  727. package/dist/src/lib/plot/layout.ts +0 -425
  728. package/dist/src/lib/plot/reference-line.ts +0 -426
  729. package/dist/src/lib/plot/scales.ts +0 -654
  730. package/dist/src/lib/plot/svg.ts +0 -23
  731. package/dist/src/lib/plot/types.ts +0 -1144
  732. package/dist/src/lib/plot/utils/label-placement.ts +0 -541
  733. package/dist/src/lib/plot/utils/series-visibility.ts +0 -140
  734. package/dist/src/lib/plot/utils.ts +0 -11
  735. package/dist/src/lib/rdf/RdfPlot.svelte +0 -247
  736. package/dist/src/lib/rdf/calc-rdf.ts +0 -167
  737. package/dist/src/lib/rdf/index.ts +0 -27
  738. package/dist/src/lib/sanitize.ts +0 -126
  739. package/dist/src/lib/settings.ts +0 -1479
  740. package/dist/src/lib/spectral/Bands.svelte +0 -1040
  741. package/dist/src/lib/spectral/BandsAndDos.svelte +0 -134
  742. package/dist/src/lib/spectral/BrillouinBandsDos.svelte +0 -252
  743. package/dist/src/lib/spectral/Dos.svelte +0 -697
  744. package/dist/src/lib/spectral/helpers.ts +0 -1381
  745. package/dist/src/lib/spectral/index.ts +0 -8
  746. package/dist/src/lib/spectral/types.ts +0 -112
  747. package/dist/src/lib/state.svelte.ts +0 -64
  748. package/dist/src/lib/structure/Arrow.svelte +0 -72
  749. package/dist/src/lib/structure/AtomLegend.svelte +0 -815
  750. package/dist/src/lib/structure/Bond.svelte +0 -140
  751. package/dist/src/lib/structure/CanvasTooltip.svelte +0 -33
  752. package/dist/src/lib/structure/CellSelect.svelte +0 -349
  753. package/dist/src/lib/structure/Cylinder.svelte +0 -45
  754. package/dist/src/lib/structure/Lattice.svelte +0 -196
  755. package/dist/src/lib/structure/Structure.svelte +0 -2248
  756. package/dist/src/lib/structure/StructureControls.svelte +0 -1273
  757. package/dist/src/lib/structure/StructureExportPane.svelte +0 -252
  758. package/dist/src/lib/structure/StructureInfoPane.svelte +0 -737
  759. package/dist/src/lib/structure/StructureScene.svelte +0 -2255
  760. package/dist/src/lib/structure/atom-properties.ts +0 -316
  761. package/dist/src/lib/structure/bond-order-perception.ts +0 -447
  762. package/dist/src/lib/structure/bonding.ts +0 -944
  763. package/dist/src/lib/structure/export.ts +0 -861
  764. package/dist/src/lib/structure/index.ts +0 -291
  765. package/dist/src/lib/structure/label-placement.ts +0 -130
  766. package/dist/src/lib/structure/measure.ts +0 -45
  767. package/dist/src/lib/structure/parse.ts +0 -1705
  768. package/dist/src/lib/structure/partial-occupancy.ts +0 -183
  769. package/dist/src/lib/structure/pbc.ts +0 -164
  770. package/dist/src/lib/structure/supercell.ts +0 -226
  771. package/dist/src/lib/structure/validation.ts +0 -11
  772. package/dist/src/lib/symmetry/SymmetryStats.svelte +0 -226
  773. package/dist/src/lib/symmetry/WyckoffTable.svelte +0 -120
  774. package/dist/src/lib/symmetry/cell-transform.ts +0 -118
  775. package/dist/src/lib/symmetry/index.ts +0 -348
  776. package/dist/src/lib/symmetry/spacegroups.ts +0 -404
  777. package/dist/src/lib/table/HeatmapTable.svelte +0 -1833
  778. package/dist/src/lib/table/ToggleMenu.svelte +0 -385
  779. package/dist/src/lib/table/index.ts +0 -139
  780. package/dist/src/lib/theme/ThemeControl.svelte +0 -53
  781. package/dist/src/lib/theme/index.ts +0 -107
  782. package/dist/src/lib/time.ts +0 -71
  783. package/dist/src/lib/tooltip/TooltipContent.svelte +0 -58
  784. package/dist/src/lib/tooltip/index.ts +0 -2
  785. package/dist/src/lib/tooltip/types.ts +0 -13
  786. package/dist/src/lib/trajectory/Trajectory.svelte +0 -1545
  787. package/dist/src/lib/trajectory/TrajectoryError.svelte +0 -128
  788. package/dist/src/lib/trajectory/TrajectoryExportPane.svelte +0 -357
  789. package/dist/src/lib/trajectory/TrajectoryInfoPane.svelte +0 -313
  790. package/dist/src/lib/trajectory/constants.ts +0 -7
  791. package/dist/src/lib/trajectory/extract.ts +0 -196
  792. package/dist/src/lib/trajectory/format-detect.ts +0 -96
  793. package/dist/src/lib/trajectory/frame-reader.ts +0 -456
  794. package/dist/src/lib/trajectory/helpers.ts +0 -217
  795. package/dist/src/lib/trajectory/index.ts +0 -218
  796. package/dist/src/lib/trajectory/parse/ase.ts +0 -109
  797. package/dist/src/lib/trajectory/parse/hdf5.ts +0 -173
  798. package/dist/src/lib/trajectory/parse/index.ts +0 -411
  799. package/dist/src/lib/trajectory/parse/lammps.ts +0 -215
  800. package/dist/src/lib/trajectory/parse/vasp.ts +0 -102
  801. package/dist/src/lib/trajectory/parse/xyz.ts +0 -143
  802. package/dist/src/lib/trajectory/plotting.ts +0 -599
  803. package/dist/src/lib/trajectory/types.ts +0 -13
  804. package/dist/src/lib/utils.ts +0 -56
  805. package/dist/src/lib/xrd/XrdPlot.svelte +0 -615
  806. package/dist/src/lib/xrd/broadening.ts +0 -130
  807. package/dist/src/lib/xrd/calc-xrd.ts +0 -397
  808. package/dist/src/lib/xrd/index.ts +0 -38
  809. package/dist/src/lib/xrd/parse.ts +0 -858
  810. package/dist/webview.js +0 -29421
  811. package/icon.png +0 -0
  812. package/matterviz-0.3.2.vsix +0 -0
  813. package/matterviz-0.3.4.vsix +0 -0
  814. package/matterviz-0.3.5.vsix +0 -0
  815. package/scripts/sync-config.ts +0 -101
  816. package/src/declarations.d.ts +0 -2
  817. package/src/extension.ts +0 -972
  818. package/src/node-io.ts +0 -65
  819. package/src/types.ts +0 -17
  820. package/src/webview/JsonBrowser.svelte +0 -1079
  821. package/src/webview/PlotPanel.svelte +0 -346
  822. package/src/webview/detect.ts +0 -444
  823. package/src/webview/main.ts +0 -764
  824. package/src/webview/plot-utils.ts +0 -250
  825. package/test-fixtures/all-viz-types.json.gz +0 -0
  826. package/test-fixtures/plot-demo-data.json.gz +0 -0
  827. package/tests/detect.test.ts +0 -604
  828. package/tests/extension.test.ts +0 -2041
  829. package/tests/node-io.test.ts +0 -39
  830. package/tests/plot-utils.test.ts +0 -302
  831. package/tests/vite-plugin-json-gz.test.ts +0 -114
  832. package/tests/vscode-mock.ts +0 -18
  833. package/tests/webview.test.ts +0 -231
  834. package/tsconfig.json +0 -20
  835. package/vite-plugin-json-gz.ts +0 -29
  836. package/vite.config.ts +0 -34
  837. package/vite.extension.config.ts +0 -34
  838. /package/dist/{src/lib/EmptyState.svelte → EmptyState.svelte} +0 -0
  839. /package/dist/{src/lib/Icon.svelte → Icon.svelte} +0 -0
  840. /package/dist/{src/lib/app.css → app.css} +0 -0
  841. /package/dist/{src/lib/chempot-diagram → chempot-diagram}/ChemPotScene3D.svelte +0 -0
  842. /package/dist/{src/lib/colors → colors}/alloy-colors.json +0 -0
  843. /package/dist/{src/lib/colors → colors}/dark-mode-colors.json +0 -0
  844. /package/dist/{src/lib/colors → colors}/jmol-colors.json +0 -0
  845. /package/dist/{src/lib/colors → colors}/muted-colors.json +0 -0
  846. /package/dist/{src/lib/colors → colors}/pastel-colors.json +0 -0
  847. /package/dist/{src/lib/colors → colors}/vesta-colors.json +0 -0
  848. /package/dist/{src/lib/convex-hull → convex-hull}/TemperatureSlider.svelte +0 -0
  849. /package/dist/{src/lib/element → element}/BohrAtom.svelte +0 -0
  850. /package/dist/{src/lib/element → element}/Nucleus.svelte +0 -0
  851. /package/dist/{src/lib/element → element}/data.json +0 -0
  852. /package/dist/{src/lib/element → element}/data.json.gz +0 -0
  853. /package/dist/{src/lib/element → element}/data.json.gz.d.ts +0 -0
  854. /package/dist/{src/lib/element → element}/data.schema.json +0 -0
  855. /package/dist/{src/lib/element-image-urls.json → element-image-urls.json} +0 -0
  856. /package/dist/{src/lib/feedback → feedback}/Spinner.svelte +0 -0
  857. /package/dist/{src/lib/feedback → feedback}/StatusMessage.svelte +0 -0
  858. /package/dist/{src/lib/layout → layout}/json-tree/JsonValue.svelte +0 -0
  859. /package/dist/{src/lib/periodic-table → periodic-table}/TableInset.svelte +0 -0
  860. /package/dist/{src/lib/plot → plot}/FillArea.svelte +0 -0
  861. /package/dist/{src/lib/plot → plot}/ReferenceLine.svelte +0 -0
  862. /package/dist/{src/lib/theme → theme}/themes.mjs +0 -0
  863. /package/dist/{src/lib/xrd → xrd}/atomic_scattering_params.json +0 -0
@@ -1,1257 +0,0 @@
1
- <script lang="ts">
2
- import Icon from '$lib/Icon.svelte'
3
- import { get_alphabetical_formula } from '$lib/composition/format'
4
- import { ELEM_SYMBOLS } from '$lib/labels'
5
- import { tooltip } from 'svelte-multiselect/attachments'
6
- import type { HTMLAttributes } from 'svelte/elements'
7
- import type { FormulaSearchMode } from './index'
8
- import {
9
- extract_formula_elements,
10
- has_wildcards,
11
- normalize_element_symbols,
12
- parse_formula,
13
- parse_formula_with_wildcards,
14
- } from './parse'
15
-
16
- type SearchExampleCategory = {
17
- label: string
18
- description: string
19
- examples: string[]
20
- }
21
-
22
- export type FormulaFilterToken = {
23
- raw: string
24
- element: string
25
- operator: `include` | `exclude`
26
- constraint: string | null
27
- is_wildcard: boolean
28
- is_valid: boolean
29
- }
30
-
31
- export type FormulaFilterParseResult = {
32
- value: string
33
- normalized_value: string
34
- search_mode: FormulaSearchMode
35
- tokens: FormulaFilterToken[]
36
- has_wildcards: boolean
37
- is_valid: boolean
38
- error_message: string | null
39
- }
40
-
41
- export type FormulaFilterValidation = {
42
- state: `valid` | `warning` | `invalid`
43
- message: string | null
44
- }
45
-
46
- const DEFAULT_SEARCH_EXAMPLES: SearchExampleCategory[] = [
47
- {
48
- label: `Has elements`,
49
- description:
50
- `Materials containing these elements. Operators/ranges: +Li,-O,Fe:1-2. Use * for any element.`,
51
- examples: [`Li,Fe`, `+Li,-O`, `Li,*,*`],
52
- },
53
- {
54
- label: `Chemical system`,
55
- description:
56
- `Materials with only these elements (no others). Wildcards/ranges supported.`,
57
- examples: [`Li-Fe-O`, `Li-Fe-*-*`, `*-*-O`],
58
- },
59
- {
60
- label: `Exact formula`,
61
- description:
62
- `Materials with this exact stoichiometry. Unicode paste, wildcards, and canonicalization supported.`,
63
- examples: [`LiFePO4`, `LiFe*2*`, `*2O3`],
64
- },
65
- ]
66
-
67
- const SUBSCRIPT_TO_ASCII: Record<string, string> = {
68
- [`\u2080`]: `0`,
69
- [`\u2081`]: `1`,
70
- [`\u2082`]: `2`,
71
- [`\u2083`]: `3`,
72
- [`\u2084`]: `4`,
73
- [`\u2085`]: `5`,
74
- [`\u2086`]: `6`,
75
- [`\u2087`]: `7`,
76
- [`\u2088`]: `8`,
77
- [`\u2089`]: `9`,
78
- }
79
-
80
- const SUPERSCRIPT_TO_ASCII: Record<string, string> = {
81
- [`\u2070`]: `0`,
82
- [`\u00B9`]: `1`,
83
- [`\u00B2`]: `2`,
84
- [`\u00B3`]: `3`,
85
- [`\u2074`]: `4`,
86
- [`\u2075`]: `5`,
87
- [`\u2076`]: `6`,
88
- [`\u2077`]: `7`,
89
- [`\u2078`]: `8`,
90
- [`\u2079`]: `9`,
91
- [`\u207A`]: `+`,
92
- [`\u207B`]: `-`,
93
- }
94
-
95
- let {
96
- value = $bindable(``),
97
- search_mode = $bindable(`elements`),
98
- input_element = $bindable(null),
99
- show_clear_button = true,
100
- show_examples = true,
101
- show_mode_lock = true,
102
- show_chip_editor = true,
103
- normalize_exact = true,
104
- examples = DEFAULT_SEARCH_EXAMPLES,
105
- disabled = false,
106
- mode_locked = $bindable(false),
107
- max_history = 5, // Max recent inputs to remember; 0 disables history dropdown
108
- history_key = `formula-filter-history`, // localStorage key for persisting history
109
- validate,
110
- onparse,
111
- on_validation,
112
- onchange,
113
- onclear,
114
- ...rest
115
- }: {
116
- value: string // Current filter value (normalized on blur/enter)
117
- search_mode?: FormulaSearchMode // Inferred search mode based on input format
118
- input_element?: HTMLInputElement | null // Reference to the input element for programmatic focus
119
- show_clear_button?: boolean // Show clear button when value is non-empty
120
- show_examples?: boolean // Show the help button and examples dropdown
121
- show_mode_lock?: boolean // Show mode lock toggle button
122
- show_chip_editor?: boolean // Show token chip editor for tokenized modes
123
- normalize_exact?: boolean // Canonicalize exact formulas on submit
124
- examples?: SearchExampleCategory[] // Override built-in search example categories
125
- disabled?: boolean // Disable all inputs
126
- mode_locked?: boolean // Prevent auto mode inference and mode cycling
127
- max_history?: number // Max recent inputs to remember; 0 disables history dropdown
128
- history_key?: string // localStorage key for persisting history
129
- validate?: (
130
- value: string,
131
- search_mode: FormulaSearchMode,
132
- parsed: FormulaFilterParseResult,
133
- ) => FormulaFilterValidation | null
134
- onparse?: (parsed: FormulaFilterParseResult) => void
135
- on_validation?: (validation: FormulaFilterValidation) => void
136
- onchange?: (value: string, search_mode: FormulaSearchMode) => void // Callback when value changes
137
- onclear?: () => void // Callback when clear button is clicked
138
- } & HTMLAttributes<HTMLDivElement> = $props()
139
-
140
- let input_value = $state(value)
141
- let examples_open = $state(false)
142
- let history_open = $state(false)
143
- let wrapper: HTMLDivElement | null = $state(null)
144
- let examples_wrapper: HTMLDivElement | null = $state(null)
145
- let focused_item_idx = $state(-1)
146
- let focused_history_idx = $state(-1)
147
- let anchor_left = $state(false)
148
- let history_query = $state(``)
149
- let validation = $state<FormulaFilterValidation>({ state: `valid`, message: null })
150
-
151
- // Flatten examples for keyboard navigation
152
- let all_examples = $derived(examples.flatMap((cat) => cat.examples))
153
-
154
- // === History Management ===
155
- const has_storage = typeof localStorage !== `undefined`
156
- const history_pins_key = $derived(`${history_key}-pins`)
157
-
158
- function load_history(): string[] {
159
- if (max_history <= 0 || !has_storage) return []
160
- try {
161
- const raw = localStorage.getItem(history_key)
162
- if (!raw) return []
163
- const parsed: unknown = JSON.parse(raw)
164
- if (!Array.isArray(parsed)) return []
165
- return parsed.filter((item): item is string => typeof item === `string`).slice(
166
- 0,
167
- max_history,
168
- )
169
- } catch {
170
- return []
171
- }
172
- }
173
-
174
- function save_history(entries: string[]): void {
175
- if (max_history <= 0 || !has_storage) return
176
- try {
177
- localStorage.setItem(history_key, JSON.stringify(entries.slice(0, max_history)))
178
- } catch {
179
- // localStorage may be unavailable (e.g. private browsing)
180
- }
181
- }
182
-
183
- function load_pinned(): string[] {
184
- if (max_history <= 0 || !has_storage) return []
185
- try {
186
- const raw = localStorage.getItem(history_pins_key)
187
- if (!raw) return []
188
- const parsed: unknown = JSON.parse(raw)
189
- if (!Array.isArray(parsed)) return []
190
- return parsed.filter((item): item is string => typeof item === `string`)
191
- } catch {
192
- return []
193
- }
194
- }
195
-
196
- function save_pinned(entries: string[]): void {
197
- if (max_history <= 0 || !has_storage) return
198
- try {
199
- localStorage.setItem(history_pins_key, JSON.stringify(entries))
200
- } catch {
201
- // localStorage may be unavailable
202
- }
203
- }
204
-
205
- let history = $state<string[]>(load_history())
206
- let pinned_history = $state<string[]>(load_pinned())
207
-
208
- function add_to_history(entry: string): void {
209
- if (max_history <= 0 || !entry.trim()) return
210
- // Remove duplicate if present, then prepend
211
- const filtered = history.filter((item) => item !== entry)
212
- history = [entry, ...filtered].slice(0, max_history)
213
- // Keep pin state for retained entries only
214
- pinned_history = pinned_history.filter((item) => history.includes(item))
215
- save_history(history)
216
- save_pinned(pinned_history)
217
- }
218
-
219
- function remove_from_history(entry: string): void {
220
- history = history.filter((item) => item !== entry)
221
- pinned_history = pinned_history.filter((item) => item !== entry)
222
- save_history(history)
223
- save_pinned(pinned_history)
224
- // Clamp focused index to prevent out-of-bounds access on Enter
225
- if (history.length === 0) history_open = false
226
- else if (focused_history_idx >= visible_history.length) {
227
- focused_history_idx = visible_history.length - 1
228
- }
229
- }
230
-
231
- function toggle_pin_history(entry: string): void {
232
- pinned_history = pinned_history.includes(entry)
233
- ? pinned_history.filter((item) => item !== entry)
234
- : [entry, ...pinned_history.filter((item) => item !== entry)]
235
- save_pinned(pinned_history)
236
- }
237
-
238
- function clear_history(): void {
239
- history = []
240
- pinned_history = []
241
- save_history(history)
242
- save_pinned(pinned_history)
243
- close_history()
244
- }
245
-
246
- const is_pinned = (entry: string): boolean => pinned_history.includes(entry)
247
-
248
- // Filtered history: exclude current value to avoid redundant suggestion
249
- let visible_history = $derived.by(() => {
250
- const filtered = history
251
- .filter((item) => item !== value)
252
- .filter((item) =>
253
- item.toLowerCase().includes(history_query.toLowerCase().trim())
254
- )
255
- const pinned = filtered.filter((item) => pinned_history.includes(item))
256
- const unpinned = filtered.filter((item) => !pinned_history.includes(item))
257
- return [...pinned, ...unpinned]
258
- })
259
-
260
- function close_history(): void {
261
- history_open = false
262
- history_query = ``
263
- focused_history_idx = -1
264
- }
265
-
266
- function open_history(): void {
267
- if (max_history <= 0 || visible_history.length === 0 || examples_open) return
268
- history_open = true
269
- history_query = ``
270
- focused_history_idx = -1
271
- }
272
-
273
- function handle_document_click(event: MouseEvent): void {
274
- if (!wrapper || (!examples_open && !history_open)) return
275
- const target = event.target
276
- if (!(target instanceof Node)) return
277
- if (!wrapper.contains(target)) {
278
- if (examples_open) close_examples()
279
- if (history_open) close_history()
280
- }
281
- }
282
-
283
- function close_examples(restore_focus = true): void {
284
- examples_open = false
285
- focused_item_idx = -1
286
- if (restore_focus) input_element?.focus({ preventScroll: true })
287
- }
288
-
289
- // Track last synced value to detect external changes (e.g. from URL params)
290
- // and re-infer mode accordingly. Without this, mode would only be set on first render.
291
- let last_synced = $state<string | null>(null)
292
- $effect(() => {
293
- if (value !== last_synced) {
294
- last_synced = value
295
- input_value = value
296
- if (value && !mode_locked) {
297
- const inferred = infer_mode(value)
298
- if (inferred !== search_mode) search_mode = inferred
299
- }
300
- run_validation(value, search_mode)
301
- }
302
- })
303
-
304
- // Detect if dropdown would exit viewport on the right and adjust anchor
305
- $effect(() => {
306
- if (!examples_open || !examples_wrapper) return
307
- requestAnimationFrame(() => {
308
- const dropdown = examples_wrapper?.querySelector(`.examples-dropdown`) as
309
- | HTMLElement
310
- | null
311
- if (!dropdown) return
312
- const rect = dropdown.getBoundingClientRect()
313
- if (rect.right > window.innerWidth && !anchor_left) anchor_left = true
314
- })
315
- })
316
-
317
- // Infer search mode from input format
318
- function infer_mode(input: string): FormulaSearchMode {
319
- const trimmed = input.trim()
320
- if (!trimmed) return `elements`
321
- if (/^[+\-!]\s*\w/.test(trimmed)) return `elements`
322
- if (trimmed.includes(`+`) || trimmed.includes(`!`)) return `elements`
323
- if (trimmed.includes(`:`)) return trimmed.includes(`-`) ? `chemsys` : `elements`
324
- if (trimmed.includes(`,`)) return `elements` // Li,Fe,O → has elements
325
- if (trimmed.includes(`-`)) return `chemsys` // Li-Fe-O → chemical system
326
- return `exact` // LiFePO4 → exact formula
327
- }
328
-
329
- // Cycle through modes: elements → chemsys → exact → elements
330
- const MODE_CYCLE: FormulaSearchMode[] = [`elements`, `chemsys`, `exact`]
331
-
332
- function normalize_unicode_formula(input: string): string {
333
- let normalized = input
334
- for (const [subscript, ascii] of Object.entries(SUBSCRIPT_TO_ASCII)) {
335
- normalized = normalized.replaceAll(subscript, ascii)
336
- }
337
- for (const [superscript, ascii] of Object.entries(SUPERSCRIPT_TO_ASCII)) {
338
- normalized = normalized.replaceAll(superscript, ascii)
339
- }
340
- return normalized
341
- .replaceAll(`·`, ``)
342
- .replaceAll(`⋅`, ``)
343
- .replaceAll(`−`, `-`)
344
- .replace(/\s+/g, ``)
345
- }
346
-
347
- function normalize_exact_formula(input: string): string {
348
- const sanitized_input = normalize_unicode_formula(input.trim())
349
- if (!sanitize_exact_formula(sanitized_input).is_valid) return sanitized_input
350
-
351
- if (!has_wildcards(sanitized_input)) {
352
- const canonical = get_alphabetical_formula(sanitized_input, true, ``)
353
- return canonical || sanitized_input
354
- }
355
-
356
- try {
357
- const tokens = parse_formula_with_wildcards(sanitized_input)
358
- const explicit = tokens
359
- .filter((token) => token.element !== null)
360
- .map((token) => ({ element: token.element as string, count: token.count }))
361
- const wildcard_tokens = tokens.filter((token) => token.element === null)
362
-
363
- // Merge explicit element counts before sorting.
364
- const merged_explicit: Array<{ element: string; count: number }> = []
365
- for (const token of explicit) {
366
- const existing = merged_explicit.find((item) =>
367
- item.element === token.element
368
- )
369
- if (existing) existing.count += token.count
370
- else merged_explicit.push(token)
371
- }
372
- const sorted_explicit = merged_explicit.sort((elem_a, elem_b) =>
373
- elem_a.element.localeCompare(elem_b.element)
374
- )
375
- const wildcard_str = wildcard_tokens.map((token) =>
376
- token.count > 1 ? `*${token.count}` : `*`
377
- ).join(``)
378
- const explicit_str = sorted_explicit.map((token) =>
379
- token.count > 1 ? `${token.element}${token.count}` : token.element
380
- ).join(``)
381
- return `${explicit_str}${wildcard_str}`
382
- } catch {
383
- return sanitized_input
384
- }
385
- }
386
-
387
- function is_valid_constraint(constraint: string): boolean {
388
- if (!constraint) return true
389
- return /^\d+$/.test(constraint) || /^\d+-\d+$/.test(constraint) ||
390
- /^(>=|<=|>|<)\d+$/.test(constraint)
391
- }
392
-
393
- function strip_operator_prefix(
394
- token: string,
395
- ): { operator: FormulaFilterToken[`operator`]; value: string } {
396
- const operator = token.startsWith(`-`) || token.startsWith(`!`)
397
- ? `exclude`
398
- : `include`
399
- const stripped_value =
400
- token.startsWith(`+`) || token.startsWith(`-`) || token.startsWith(`!`)
401
- ? token.slice(1)
402
- : token
403
- return { operator, value: stripped_value }
404
- }
405
-
406
- function serialize_token(
407
- token: Pick<FormulaFilterToken, `operator` | `element` | `constraint`>,
408
- ): string {
409
- const prefix = token.operator === `exclude` ? `-` : ``
410
- const suffix = token.constraint ? `:${token.constraint}` : ``
411
- return `${prefix}${token.element}${suffix}`
412
- }
413
-
414
- function token_chip_label(
415
- token: Pick<FormulaFilterToken, `operator` | `element` | `constraint`>,
416
- ): string {
417
- const prefix = token.operator === `exclude` ? `-` : `+`
418
- const suffix = token.constraint ? `:${token.constraint}` : ``
419
- return `${prefix}${token.element}${suffix}`
420
- }
421
-
422
- function parse_token(raw_token: string): FormulaFilterToken {
423
- const token = raw_token.trim()
424
- const { operator, value: without_operator } = strip_operator_prefix(token)
425
- const [element_part, constraint] = without_operator.split(`:`)
426
- const element = element_part.trim()
427
- const is_wildcard = element === `*`
428
- const is_valid_element = is_wildcard ||
429
- ELEM_SYMBOLS.includes(element as (typeof ELEM_SYMBOLS)[number])
430
- const normalized_constraint = constraint?.trim() || null
431
- const is_valid = is_valid_element && (normalized_constraint === null ||
432
- is_valid_constraint(normalized_constraint))
433
-
434
- return {
435
- raw: raw_token,
436
- element,
437
- operator,
438
- constraint: normalized_constraint,
439
- is_wildcard,
440
- is_valid,
441
- }
442
- }
443
-
444
- function tokenize_query(
445
- input: string,
446
- mode: FormulaSearchMode,
447
- ): FormulaFilterToken[] {
448
- const trimmed = input.trim()
449
- if (!trimmed) return []
450
- if (mode === `exact`) {
451
- return [{
452
- raw: trimmed,
453
- element: trimmed,
454
- operator: `include`,
455
- constraint: null,
456
- is_wildcard: has_wildcards(trimmed),
457
- is_valid: sanitize_exact_formula(trimmed).is_valid,
458
- }]
459
- }
460
- const normalized = mode === `chemsys` ? trimmed.replaceAll(`,`, `-`) : trimmed
461
- const tokens = mode === `chemsys`
462
- // Keep range constraints like Fe:1-2 intact while splitting token separators.
463
- ? normalized.split(/-(?!\d)/)
464
- : normalized.split(`,`)
465
- return tokens
466
- .map((token) => token.trim())
467
- .filter(Boolean)
468
- .map(parse_token)
469
- }
470
-
471
- function sanitize_exact_formula(
472
- input: string,
473
- ): { is_valid: boolean; error_message: string | null } {
474
- const trimmed = input.trim()
475
- if (!trimmed) return { is_valid: true, error_message: null }
476
- try {
477
- if (has_wildcards(trimmed)) {
478
- parse_formula_with_wildcards(trimmed)
479
- } else {
480
- parse_formula(trimmed)
481
- }
482
- return { is_valid: true, error_message: null }
483
- } catch (error) {
484
- const message = error instanceof Error ? error.message : `Invalid exact formula`
485
- return { is_valid: false, error_message: message }
486
- }
487
- }
488
-
489
- function normalize_tokenized_input(input: string, mode: FormulaSearchMode): string {
490
- const separator = mode === `chemsys` ? `-` : `,`
491
- const parsed_tokens = tokenize_query(input, mode)
492
- if (parsed_tokens.length === 0) return ``
493
-
494
- const normalized_tokens = parsed_tokens
495
- .filter((token) => token.is_valid)
496
- .map((token) => ({
497
- ...token,
498
- element: token.is_wildcard
499
- ? `*`
500
- : normalize_element_symbols(token.element).at(0) || token.element,
501
- }))
502
- .sort((token_a, token_b) => {
503
- if (token_a.operator !== token_b.operator) {
504
- return token_a.operator === `include` ? -1 : 1
505
- }
506
- if (token_a.is_wildcard !== token_b.is_wildcard) {
507
- return token_a.is_wildcard ? 1 : -1
508
- }
509
- return token_a.element.localeCompare(token_b.element)
510
- })
511
-
512
- return normalized_tokens
513
- .map(serialize_token)
514
- .join(separator)
515
- }
516
-
517
- function parse_query(
518
- normalized_value: string,
519
- mode: FormulaSearchMode,
520
- ): FormulaFilterParseResult {
521
- const tokens = tokenize_query(normalized_value, mode)
522
- const first_invalid_token = tokens.find((token) => !token.is_valid)
523
- const exact_validation = mode === `exact`
524
- ? sanitize_exact_formula(normalized_value)
525
- : {
526
- is_valid: !first_invalid_token,
527
- error_message: first_invalid_token
528
- ? `Invalid token: ${first_invalid_token.raw}`
529
- : null,
530
- }
531
- return {
532
- value: normalized_value,
533
- normalized_value,
534
- search_mode: mode,
535
- tokens,
536
- has_wildcards: tokens.some((token) => token.is_wildcard),
537
- is_valid: exact_validation.is_valid,
538
- error_message: exact_validation.error_message,
539
- }
540
- }
541
-
542
- function run_validation(next_value: string, next_mode: FormulaSearchMode): void {
543
- const parsed = parse_query(next_value, next_mode)
544
- onparse?.(parsed)
545
-
546
- const default_validation: FormulaFilterValidation = parsed.is_valid
547
- ? { state: `valid`, message: null }
548
- : { state: `invalid`, message: parsed.error_message ?? `Invalid filter query` }
549
- const custom_validation = validate?.(next_value, next_mode, parsed)
550
- validation = custom_validation ?? default_validation
551
- on_validation?.(validation)
552
- }
553
-
554
- // Extract elements from any input format (formula, comma-separated, dash-separated)
555
- // Always returns elements in alphabetical order for consistency, preserving wildcards (*)
556
- function extract_elements(input: string): string[] {
557
- const trimmed = input.trim()
558
- if (!trimmed) return []
559
- // If contains commas or dashes, split by those and sort alphabetically
560
- if (trimmed.includes(`,`) || trimmed.includes(`-`)) {
561
- const parts = trimmed.split(/[-,]/).map((str) => str.trim()).filter(Boolean)
562
- // Separate wildcards from regular elements
563
- const wildcards = parts.filter((part) => part === `*`)
564
- const regular_parts = parts.filter((part) => part !== `*`)
565
- // Filter valid elements and sort alphabetically, then append wildcards
566
- const valid_elements = normalize_element_symbols(regular_parts.join(`,`)).sort()
567
- return [...valid_elements, ...wildcards]
568
- }
569
- // Otherwise parse as formula (already returns sorted by default)
570
- // For formulas with wildcards, we can't parse them normally
571
- if (has_wildcards(trimmed)) { // Use shared utility and extract unique elements
572
- const tokens = parse_formula_with_wildcards(trimmed)
573
- const unique_elements: string[] = []
574
- for (const token of tokens) {
575
- if (token.element !== null && !unique_elements.includes(token.element)) {
576
- unique_elements.push(token.element)
577
- }
578
- }
579
- const elements = unique_elements.sort()
580
- const wildcards = tokens.filter((token) => token.element === null).map(() =>
581
- `*`
582
- )
583
- return [...elements, ...wildcards]
584
- }
585
- try {
586
- return extract_formula_elements(trimmed, { sorted: true })
587
- } catch {
588
- return []
589
- }
590
- }
591
-
592
- // Format elements for the given mode
593
- function format_for_mode(elements: string[], mode: FormulaSearchMode): string {
594
- if (elements.length === 0) return ``
595
- if (mode === `elements`) return elements.join(`,`)
596
- if (mode === `chemsys`) return elements.join(`-`)
597
- // For exact mode, just join without separator (user will need to add counts)
598
- return elements.join(``)
599
- }
600
-
601
- function cycle_mode(): void {
602
- if (mode_locked) return
603
- const current_idx = MODE_CYCLE.indexOf(search_mode)
604
- const next_idx = (current_idx + 1) % MODE_CYCLE.length
605
- const next_mode = MODE_CYCLE[next_idx]
606
-
607
- // Extract elements from current value and reformat for new mode
608
- const elements = extract_elements(value)
609
- const reformatted = format_for_mode(elements, next_mode)
610
-
611
- search_mode = next_mode
612
- last_synced = value = input_value = reformatted // update last_synced to prevent effect re-inference
613
- run_validation(reformatted, next_mode)
614
- onchange?.(reformatted, next_mode)
615
- }
616
-
617
- function set_value(new_value: string, forced_mode?: FormulaSearchMode): void {
618
- const mode = forced_mode ?? (mode_locked ? search_mode : infer_mode(new_value))
619
- last_synced = value = input_value = new_value // update last_synced to prevent effect re-inference
620
- search_mode = mode
621
- if (new_value.trim()) add_to_history(new_value)
622
- close_history()
623
- run_validation(value, mode)
624
- onchange?.(value, mode)
625
- }
626
-
627
- function sync_value(): void {
628
- const trimmed = normalize_unicode_formula(input_value).trim()
629
- if (!trimmed) return set_value(``)
630
-
631
- const mode = mode_locked ? search_mode : infer_mode(trimmed)
632
- if (mode === `exact`) {
633
- const exact_value = normalize_exact ? normalize_exact_formula(trimmed) : trimmed
634
- return set_value(exact_value, mode)
635
- }
636
-
637
- const parsed = parse_query(trimmed, mode)
638
- if (!parsed.is_valid) {
639
- // Preserve user input on invalid tokens instead of silently dropping them.
640
- input_value = trimmed
641
- run_validation(trimmed, mode)
642
- return
643
- }
644
-
645
- const normalized = normalize_tokenized_input(trimmed, mode)
646
- set_value(normalized, mode)
647
- }
648
-
649
- function onkeydown(event: KeyboardEvent): void {
650
- if (event.key === `Enter`) {
651
- event.preventDefault()
652
- if (history_open && focused_history_idx >= 0) {
653
- set_value(visible_history[focused_history_idx])
654
- } else {
655
- sync_value()
656
- }
657
- } else if (event.key === `Escape`) {
658
- if (history_open) close_history()
659
- else if (examples_open) examples_open = false
660
- else if (input_value) clear_filter()
661
- } else if (history_open && visible_history.length > 0) {
662
- const len = visible_history.length
663
- if (event.key === `ArrowDown`) {
664
- event.preventDefault()
665
- focused_history_idx = (focused_history_idx + 1) % len
666
- } else if (event.key === `ArrowUp`) {
667
- event.preventDefault()
668
- focused_history_idx = focused_history_idx <= 0
669
- ? len - 1
670
- : focused_history_idx - 1
671
- }
672
- }
673
- }
674
-
675
- function oninput(): void {
676
- if (history_open) {
677
- history_query = input_value
678
- focused_history_idx = visible_history.length > 0 ? 0 : -1
679
- }
680
- const mode = mode_locked ? search_mode : infer_mode(input_value)
681
- run_validation(input_value, mode)
682
- }
683
-
684
- function clear_filter(): void {
685
- onclear?.()
686
- set_value(``)
687
- }
688
-
689
- function apply_example(example: string): void {
690
- set_value(example, mode_locked ? search_mode : infer_mode(example))
691
- close_examples()
692
- }
693
-
694
- function toggle_examples(event: MouseEvent): void {
695
- event.stopPropagation()
696
- close_history()
697
- examples_open = !examples_open
698
- focused_item_idx = examples_open ? 0 : -1
699
- if (examples_open) anchor_left = false
700
- }
701
-
702
- function handle_menu_keydown(event: KeyboardEvent): void {
703
- const len = all_examples.length
704
- if (!len) return
705
- const is_button_activation = (event.key === `Enter` || event.key === ` `) &&
706
- event.target instanceof HTMLButtonElement
707
- if (is_button_activation) return
708
-
709
- const key_actions: Record<string, () => void> = {
710
- ArrowDown: () => (focused_item_idx = (focused_item_idx + 1) % len),
711
- ArrowUp: () => (focused_item_idx = (focused_item_idx - 1 + len) % len),
712
- Home: () => (focused_item_idx = 0),
713
- End: () => (focused_item_idx = len - 1),
714
- Escape: close_examples,
715
- }
716
-
717
- if (event.key in key_actions) {
718
- event.preventDefault()
719
- key_actions[event.key]()
720
- }
721
- }
722
-
723
- function toggle_mode_lock(): void {
724
- mode_locked = !mode_locked
725
- }
726
-
727
- function remove_token(token_idx: number): void {
728
- if (search_mode === `exact`) return
729
- const separator = search_mode === `chemsys` ? `-` : `,`
730
- const tokens = tokenize_query(input_value, search_mode)
731
- .filter((_, idx) => idx !== token_idx)
732
- const next_value = tokens.map(serialize_token).join(separator)
733
- input_value = next_value
734
- set_value(next_value, search_mode)
735
- }
736
-
737
- // Focus the active menu item when index changes
738
- $effect(() => {
739
- if (!examples_open || focused_item_idx < 0) return
740
- const items = wrapper?.querySelectorAll<HTMLButtonElement>(`[data-example-item]`)
741
- items?.[focused_item_idx]?.focus({ preventScroll: true })
742
- })
743
-
744
- let placeholder = $derived(
745
- search_mode === `chemsys`
746
- ? `Li-Fe-O or Li-*-*`
747
- : search_mode === `exact`
748
- ? `LiFePO4 or LiFe*2*`
749
- : `Li,Fe,O or Li,*,*`,
750
- )
751
-
752
- const MODE_LABELS: Record<FormulaSearchMode, string> = {
753
- elements: `has elements`,
754
- chemsys: `chemical system`,
755
- exact: `exact formula`,
756
- }
757
-
758
- let mode_hint = $derived(MODE_LABELS[search_mode])
759
- let parsed_tokens = $derived(tokenize_query(input_value, search_mode))
760
- let show_chip_row = $derived(
761
- show_chip_editor && search_mode !== `exact` && parsed_tokens.length > 0,
762
- )
763
- // Preview of next mode cycle step for tooltip
764
- let next_mode = $derived.by(() => {
765
- const next = MODE_CYCLE[(MODE_CYCLE.indexOf(search_mode) + 1) % MODE_CYCLE.length]
766
- const mode = MODE_LABELS[next]
767
- const next_value = format_for_mode(extract_elements(value), next)
768
- return { mode, value: next_value }
769
- })
770
- </script>
771
-
772
- <svelte:document onclick={handle_document_click} />
773
-
774
- <div
775
- class="formula-filter"
776
- bind:this={wrapper}
777
- class:disabled
778
- class:invalid={validation.state === `invalid`}
779
- class:warning={validation.state === `warning`}
780
- {...rest}
781
- >
782
- <input
783
- bind:this={input_element}
784
- bind:value={input_value}
785
- onblur={() => {
786
- // mousedown preventDefault on history items prevents blur, so this only
787
- // fires when focus genuinely leaves (tab out, click outside, etc.)
788
- // sync_value → set_value → close_history, so no separate close needed
789
- sync_value()
790
- }}
791
- onfocus={open_history}
792
- {oninput}
793
- onpaste={() => {
794
- requestAnimationFrame(() => {
795
- input_value = normalize_unicode_formula(input_value)
796
- oninput()
797
- })
798
- }}
799
- {onkeydown}
800
- {placeholder}
801
- {disabled}
802
- aria-label="Formula filter"
803
- />
804
- {#if history_open && visible_history.length > 0}
805
- <div class="history-dropdown" role="listbox" aria-label="Recent searches">
806
- <div class="history-header-row">
807
- <span class="history-header">Recent</span>
808
- <button
809
- type="button"
810
- class="history-clear-all"
811
- title="Clear history"
812
- aria-label="Clear all history"
813
- onmousedown={(event) => {
814
- event.preventDefault()
815
- clear_history()
816
- }}
817
- >
818
- Clear
819
- </button>
820
- </div>
821
- {#each visible_history as entry, idx (entry)}
822
- <div class="history-item" class:focused={idx === focused_history_idx}>
823
- <button
824
- type="button"
825
- class="history-value"
826
- role="option"
827
- aria-selected={idx === focused_history_idx}
828
- onmousedown={(event) => {
829
- event.preventDefault()
830
- set_value(entry)
831
- }}
832
- >
833
- {entry}
834
- </button>
835
- <button
836
- type="button"
837
- class="history-pin"
838
- title={is_pinned(entry) ? `Unpin entry` : `Pin entry`}
839
- aria-label={is_pinned(entry) ? `Unpin ${entry}` : `Pin ${entry}`}
840
- onmousedown={(event) => {
841
- event.preventDefault()
842
- toggle_pin_history(entry)
843
- }}
844
- >
845
- <Icon
846
- icon={is_pinned(entry) ? `Star` : `Circle`}
847
- style="width: 0.8em; height: 0.8em"
848
- />
849
- </button>
850
- <button
851
- type="button"
852
- class="history-remove"
853
- title="Remove from history"
854
- aria-label="Remove {entry} from history"
855
- onmousedown={(event) => {
856
- event.preventDefault()
857
- remove_from_history(entry)
858
- }}
859
- >
860
- <Icon icon="Close" style="width: 0.7em; height: 0.7em" />
861
- </button>
862
- </div>
863
- {/each}
864
- </div>
865
- {/if}
866
- {#if input_value}
867
- <button
868
- type="button"
869
- class="mode-hint clickable"
870
- class:locked={mode_locked}
871
- onclick={cycle_mode}
872
- title={mode_locked
873
- ? `Mode is locked`
874
- : `Click to switch to '${next_mode.mode}' → ${next_mode.value}`}
875
- {@attach tooltip()}
876
- aria-label="Change search mode"
877
- >
878
- {mode_hint}
879
- </button>
880
- {/if}
881
- {#if show_mode_lock && !disabled}
882
- <button
883
- type="button"
884
- class="icon-btn lock-btn"
885
- class:active={mode_locked}
886
- onclick={toggle_mode_lock}
887
- title={mode_locked ? `Unlock mode inference` : `Lock current mode`}
888
- {@attach tooltip()}
889
- aria-label={mode_locked ? `Unlock mode` : `Lock mode`}
890
- >
891
- <Icon icon={mode_locked ? `Lock` : `Unlock`} style="width: 1em; height: 1em" />
892
- </button>
893
- {/if}
894
- {#if show_clear_button && value && !disabled}
895
- <button
896
- type="button"
897
- class="icon-btn clear-btn"
898
- onclick={clear_filter}
899
- title="Clear (Escape)"
900
- {@attach tooltip()}
901
- aria-label="Clear filter"
902
- >
903
- <Icon icon="Close" style="width: 1em; height: 1em" />
904
- </button>
905
- {/if}
906
- {#if show_examples && !disabled}
907
- <div class="examples-wrapper" bind:this={examples_wrapper}>
908
- <button
909
- type="button"
910
- class="icon-btn help-btn"
911
- class:active={examples_open}
912
- onclick={toggle_examples}
913
- title="Show search examples"
914
- aria-label="Show search examples"
915
- aria-expanded={examples_open}
916
- aria-haspopup="menu"
917
- >
918
- <Icon icon="Info" style="width: 1.1em; height: 1.1em" />
919
- </button>
920
- {#if examples_open}
921
- <div
922
- class="examples-dropdown"
923
- class:anchor-left={anchor_left}
924
- role="menu"
925
- tabindex="-1"
926
- onkeydown={handle_menu_keydown}
927
- >
928
- {#each examples as category (category.label)}
929
- <div class="example-category">
930
- <div class="category-label">{category.label}:</div>
931
- <div class="example-tags">
932
- {#each category.examples as example (example)}
933
- <button
934
- type="button"
935
- class="example-tag"
936
- data-example-item
937
- onclick={() => apply_example(example)}
938
- title={category.description}
939
- role="menuitem"
940
- tabindex="-1"
941
- >
942
- {example}
943
- </button>
944
- {/each}
945
- </div>
946
- </div>
947
- {/each}
948
- </div>
949
- {/if}
950
- </div>
951
- {/if}
952
- </div>
953
- {#if show_chip_row}
954
- <div class="token-chip-row">
955
- {#each parsed_tokens as
956
- token,
957
- idx
958
- (`${token.operator}:${token.element}:${token.constraint ?? ``}:${idx}`)
959
- }
960
- <button
961
- type="button"
962
- class="token-chip"
963
- class:exclude={token.operator === `exclude`}
964
- class:invalid={!token.is_valid}
965
- onclick={() => remove_token(idx)}
966
- title="Click to remove token"
967
- aria-label="Remove token {token.raw}"
968
- >
969
- {token_chip_label(token)}
970
- </button>
971
- {/each}
972
- </div>
973
- {/if}
974
- {#if validation.message}
975
- <div class="validation-message" class:invalid={validation.state === `invalid`}>
976
- {validation.message}
977
- </div>
978
- {/if}
979
-
980
- <style>
981
- .formula-filter {
982
- position: relative;
983
- display: flex;
984
- align-items: center;
985
- gap: var(--formula-filter-gap, 1pt);
986
- padding: var(--formula-filter-padding, 4pt 8pt);
987
- border-radius: var(--formula-filter-border-radius, var(--border-radius, 3pt));
988
- background: var(--formula-filter-bg, rgba(128, 128, 128, 0.05));
989
- transition: background 0.15s;
990
- &.invalid {
991
- outline: 1px solid rgba(239, 68, 68, 0.65);
992
- background: rgba(239, 68, 68, 0.08);
993
- }
994
- &.warning {
995
- outline: 1px solid rgba(245, 158, 11, 0.6);
996
- background: rgba(245, 158, 11, 0.08);
997
- }
998
- &:focus-within {
999
- background: rgba(77, 182, 255, 0.08);
1000
- }
1001
- &.disabled {
1002
- opacity: 0.5;
1003
- pointer-events: none;
1004
- }
1005
- }
1006
- input {
1007
- flex: 1;
1008
- min-width: 0;
1009
- border: none;
1010
- background: transparent;
1011
- color: inherit;
1012
- padding: 2pt 0;
1013
- outline: none;
1014
- font-family: var(--mono-font, monospace);
1015
- &::placeholder {
1016
- opacity: 0.4;
1017
- }
1018
- }
1019
- .mode-hint {
1020
- opacity: 0.5;
1021
- white-space: nowrap;
1022
- &.clickable {
1023
- display: inline-flex;
1024
- align-items: center;
1025
- gap: 2pt;
1026
- background: rgba(77, 182, 255, 0.1);
1027
- border: 1px solid rgba(77, 182, 255, 0.25);
1028
- border-radius: 4px;
1029
- padding: 1pt 5pt;
1030
- cursor: pointer;
1031
- color: var(--highlight, #4db6ff);
1032
- opacity: 0.8;
1033
- transition: opacity 0.15s, background 0.15s;
1034
- &:hover {
1035
- opacity: 1;
1036
- background: rgba(77, 182, 255, 0.2);
1037
- border-color: rgba(77, 182, 255, 0.4);
1038
- }
1039
- &.locked {
1040
- cursor: not-allowed;
1041
- opacity: 0.5;
1042
- }
1043
- }
1044
- }
1045
- .icon-btn {
1046
- display: flex;
1047
- align-items: center;
1048
- justify-content: center;
1049
- background: none;
1050
- border: none;
1051
- cursor: pointer;
1052
- padding: 3pt;
1053
- border-radius: 50%;
1054
- color: inherit;
1055
- opacity: 0.4;
1056
- &:hover {
1057
- opacity: 1;
1058
- background: rgba(128, 128, 128, 0.15);
1059
- }
1060
- &.active {
1061
- opacity: 1;
1062
- color: var(--highlight, #4db6ff);
1063
- }
1064
- }
1065
- .history-dropdown {
1066
- position: absolute;
1067
- top: calc(100% + 2pt);
1068
- left: 0;
1069
- right: 0;
1070
- z-index: 101;
1071
- background: var(--dropdown-bg, var(--surface-bg, #fff));
1072
- border: 1px solid var(--dropdown-border, rgba(128, 128, 128, 0.2));
1073
- border-radius: 8px;
1074
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
1075
- padding: 4pt 0;
1076
- display: flex;
1077
- flex-direction: column;
1078
- }
1079
- .history-header {
1080
- font-size: 0.7em;
1081
- font-weight: 600;
1082
- opacity: 0.45;
1083
- padding: 2pt 10pt 4pt;
1084
- text-transform: uppercase;
1085
- letter-spacing: 0.5px;
1086
- }
1087
- .history-header-row {
1088
- display: flex;
1089
- align-items: center;
1090
- justify-content: space-between;
1091
- gap: 6pt;
1092
- padding-right: 6pt;
1093
- }
1094
- .history-clear-all {
1095
- border: none;
1096
- background: transparent;
1097
- cursor: pointer;
1098
- font-size: 0.75em;
1099
- opacity: 0.6;
1100
- &:hover {
1101
- opacity: 1;
1102
- }
1103
- }
1104
- .history-item {
1105
- display: flex;
1106
- align-items: center;
1107
- padding: 0 4pt 0 0;
1108
- &:is(.focused, :hover) {
1109
- background: rgba(77, 182, 255, 0.08);
1110
- }
1111
- }
1112
- .history-value {
1113
- flex: 1;
1114
- text-align: left;
1115
- background: none;
1116
- border: none;
1117
- cursor: pointer;
1118
- padding: 4pt 10pt;
1119
- font-family: var(--mono-font, monospace);
1120
- font-size: 0.88em;
1121
- color: inherit;
1122
- }
1123
- .history-remove {
1124
- min-width: 24px;
1125
- min-height: 24px;
1126
- display: flex;
1127
- align-items: center;
1128
- justify-content: center;
1129
- background: none;
1130
- border: none;
1131
- cursor: pointer;
1132
- padding: 3pt;
1133
- border-radius: 50%;
1134
- opacity: 0.3;
1135
- color: inherit;
1136
- &:hover {
1137
- opacity: 0.8;
1138
- background: rgba(128, 128, 128, 0.15);
1139
- }
1140
- }
1141
- .history-pin {
1142
- display: flex;
1143
- align-items: center;
1144
- justify-content: center;
1145
- background: none;
1146
- border: none;
1147
- cursor: pointer;
1148
- padding: 3pt;
1149
- border-radius: 50%;
1150
- opacity: 0.3;
1151
- color: inherit;
1152
- &:hover {
1153
- opacity: 0.8;
1154
- background: rgba(128, 128, 128, 0.15);
1155
- }
1156
- }
1157
- .examples-wrapper {
1158
- position: relative;
1159
- }
1160
- .examples-dropdown {
1161
- position: absolute;
1162
- top: calc(100% + 4pt);
1163
- right: 0;
1164
- z-index: 100;
1165
- width: max-content;
1166
- background: var(--dropdown-bg, var(--surface-bg, #fff));
1167
- border: 1px solid var(--dropdown-border, rgba(128, 128, 128, 0.2));
1168
- border-radius: 8px;
1169
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
1170
- padding: 8pt;
1171
- box-sizing: border-box;
1172
- display: flex;
1173
- flex-direction: column;
1174
- gap: 6pt;
1175
- &.anchor-left {
1176
- right: auto;
1177
- left: 0;
1178
- }
1179
- }
1180
- .example-category {
1181
- display: flex;
1182
- align-items: center;
1183
- gap: 6pt;
1184
- flex-wrap: wrap;
1185
- }
1186
- .category-label {
1187
- font-size: 0.75em;
1188
- font-weight: 600;
1189
- opacity: 0.6;
1190
- min-width: 115px;
1191
- }
1192
- .example-tags {
1193
- display: flex;
1194
- gap: 4pt;
1195
- flex-wrap: wrap;
1196
- }
1197
- .example-tag {
1198
- background: rgba(77, 182, 255, 0.1);
1199
- border: 1px solid rgba(77, 182, 255, 0.3);
1200
- border-radius: 4px;
1201
- padding: 3pt 7pt;
1202
- font-size: 0.82em;
1203
- font-family: var(--mono-font, monospace);
1204
- color: var(--highlight, #4db6ff);
1205
- cursor: pointer;
1206
- &:hover {
1207
- background: rgba(77, 182, 255, 0.2);
1208
- border-color: rgba(77, 182, 255, 0.5);
1209
- }
1210
- }
1211
- .token-chip-row {
1212
- margin-top: 4pt;
1213
- display: flex;
1214
- flex-wrap: wrap;
1215
- gap: 4pt;
1216
- }
1217
- .token-chip {
1218
- border: 1px solid rgba(77, 182, 255, 0.35);
1219
- background: rgba(77, 182, 255, 0.12);
1220
- border-radius: 4px;
1221
- font-family: var(--mono-font, monospace);
1222
- font-size: 0.78em;
1223
- padding: 2pt 6pt;
1224
- cursor: pointer;
1225
- color: inherit;
1226
- &.exclude {
1227
- border-color: rgba(239, 68, 68, 0.35);
1228
- background: rgba(239, 68, 68, 0.12);
1229
- }
1230
- &.invalid {
1231
- border-color: rgba(239, 68, 68, 0.65);
1232
- }
1233
- }
1234
- .validation-message {
1235
- margin-top: 4pt;
1236
- font-size: 0.74em;
1237
- opacity: 0.75;
1238
- &.invalid {
1239
- color: rgb(239, 68, 68);
1240
- opacity: 0.95;
1241
- }
1242
- }
1243
- @media (max-width: 700px) {
1244
- .icon-btn {
1245
- min-width: 28px;
1246
- min-height: 28px;
1247
- padding: 5pt;
1248
- }
1249
- :is(.history-remove, .history-pin) {
1250
- min-width: 28px;
1251
- min-height: 28px;
1252
- }
1253
- .history-value {
1254
- padding: 6pt 10pt;
1255
- }
1256
- }
1257
- </style>