molstar 3.3.1 → 3.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (777) hide show
  1. package/README.md +3 -0
  2. package/build/viewer/molstar.js +1 -1
  3. package/lib/apps/docking-viewer/viewport.js +1 -1
  4. package/lib/apps/viewer/app.d.ts +7 -6
  5. package/lib/apps/viewer/app.js +2 -0
  6. package/lib/cli/chem-comp-dict/create-saccharides.d.ts +7 -0
  7. package/lib/cli/chem-comp-dict/create-saccharides.js +67 -0
  8. package/lib/commonjs/apps/docking-viewer/index.js +12 -12
  9. package/lib/commonjs/apps/docking-viewer/viewport.js +33 -33
  10. package/lib/commonjs/apps/viewer/app.d.ts +7 -6
  11. package/lib/commonjs/apps/viewer/app.js +24 -22
  12. package/lib/commonjs/apps/viewer/index.js +1 -1
  13. package/lib/commonjs/cli/chem-comp-dict/create-ions.js +6 -6
  14. package/lib/commonjs/cli/chem-comp-dict/create-saccharides.d.ts +7 -0
  15. package/lib/commonjs/cli/chem-comp-dict/create-saccharides.js +69 -0
  16. package/lib/commonjs/cli/chem-comp-dict/create-table.js +8 -8
  17. package/lib/commonjs/cli/chem-comp-dict/util.js +17 -17
  18. package/lib/commonjs/cli/cif2bcif/converter.js +9 -9
  19. package/lib/commonjs/cli/cif2bcif/index.js +8 -8
  20. package/lib/commonjs/cli/cifschema/index.js +27 -27
  21. package/lib/commonjs/cli/cifschema/util/cif-dic.js +1 -1
  22. package/lib/commonjs/cli/lipid-params/index.js +9 -9
  23. package/lib/commonjs/cli/state-docs/index.js +2 -2
  24. package/lib/commonjs/cli/structure-info/helpers.js +11 -11
  25. package/lib/commonjs/cli/structure-info/model.js +15 -15
  26. package/lib/commonjs/cli/structure-info/volume.js +9 -9
  27. package/lib/commonjs/examples/alpha-orbitals/controls.js +3 -3
  28. package/lib/commonjs/examples/alpha-orbitals/index.js +11 -11
  29. package/lib/commonjs/examples/basic-wrapper/controls.js +2 -2
  30. package/lib/commonjs/examples/basic-wrapper/index.js +22 -22
  31. package/lib/commonjs/examples/basic-wrapper/superposition.js +8 -8
  32. package/lib/commonjs/examples/domain-annotation-server/mapping.js +3 -3
  33. package/lib/commonjs/examples/domain-annotation-server/server.js +6 -6
  34. package/lib/commonjs/examples/domain-annotation-server/test.js +3 -3
  35. package/lib/commonjs/examples/lighting/index.js +6 -6
  36. package/lib/commonjs/examples/proteopedia-wrapper/annotation.js +2 -2
  37. package/lib/commonjs/examples/proteopedia-wrapper/helpers.js +4 -4
  38. package/lib/commonjs/examples/proteopedia-wrapper/index.js +26 -26
  39. package/lib/commonjs/examples/proteopedia-wrapper/ui/controls.js +2 -2
  40. package/lib/commonjs/examples/task.js +15 -15
  41. package/lib/commonjs/extensions/alpha-orbitals/collocation.js +2 -2
  42. package/lib/commonjs/extensions/alpha-orbitals/data-model.js +1 -1
  43. package/lib/commonjs/extensions/alpha-orbitals/density.js +2 -2
  44. package/lib/commonjs/extensions/alpha-orbitals/gpu/compute.js +2 -2
  45. package/lib/commonjs/extensions/alpha-orbitals/orbitals.js +2 -2
  46. package/lib/commonjs/extensions/alpha-orbitals/transforms.js +13 -13
  47. package/lib/commonjs/extensions/anvil/algorithm.js +13 -13
  48. package/lib/commonjs/extensions/anvil/behavior.js +14 -14
  49. package/lib/commonjs/extensions/anvil/prop.js +7 -7
  50. package/lib/commonjs/extensions/anvil/representation.js +5 -5
  51. package/lib/commonjs/extensions/cellpack/index.js +1 -1
  52. package/lib/commonjs/extensions/cellpack/model.js +26 -24
  53. package/lib/commonjs/extensions/cellpack/preset.js +6 -6
  54. package/lib/commonjs/extensions/cellpack/property.js +3 -3
  55. package/lib/commonjs/extensions/cellpack/representation.js +2 -2
  56. package/lib/commonjs/extensions/cellpack/state.js +13 -13
  57. package/lib/commonjs/extensions/cellpack/util.js +14 -14
  58. package/lib/commonjs/extensions/dnatco/confal-pyramids/behavior.js +7 -7
  59. package/lib/commonjs/extensions/dnatco/confal-pyramids/property.js +5 -5
  60. package/lib/commonjs/extensions/dnatco/confal-pyramids/representation.js +2 -2
  61. package/lib/commonjs/extensions/dnatco/confal-pyramids/util.js +1 -1
  62. package/lib/commonjs/extensions/g3d/data.js +6 -6
  63. package/lib/commonjs/extensions/g3d/format.js +14 -14
  64. package/lib/commonjs/extensions/g3d/model.js +4 -4
  65. package/lib/commonjs/extensions/geo-export/controls.js +3 -3
  66. package/lib/commonjs/extensions/geo-export/glb-exporter.js +9 -9
  67. package/lib/commonjs/extensions/geo-export/index.js +1 -1
  68. package/lib/commonjs/extensions/geo-export/mesh-exporter.js +12 -12
  69. package/lib/commonjs/extensions/geo-export/obj-exporter.js +7 -7
  70. package/lib/commonjs/extensions/geo-export/stl-exporter.js +7 -7
  71. package/lib/commonjs/extensions/geo-export/ui.js +7 -7
  72. package/lib/commonjs/extensions/geo-export/usdz-exporter.js +9 -9
  73. package/lib/commonjs/extensions/model-archive/quality-assessment/behavior.js +9 -9
  74. package/lib/commonjs/extensions/model-archive/quality-assessment/color/plddt.js +4 -4
  75. package/lib/commonjs/extensions/model-archive/quality-assessment/color/qmean.js +4 -4
  76. package/lib/commonjs/extensions/model-archive/quality-assessment/prop.js +5 -5
  77. package/lib/commonjs/extensions/model-export/export.js +4 -4
  78. package/lib/commonjs/extensions/model-export/index.js +1 -1
  79. package/lib/commonjs/extensions/model-export/ui.js +5 -5
  80. package/lib/commonjs/extensions/mp4-export/controls.js +5 -5
  81. package/lib/commonjs/extensions/mp4-export/encoder.js +4 -4
  82. package/lib/commonjs/extensions/mp4-export/index.js +1 -1
  83. package/lib/commonjs/extensions/mp4-export/ui.js +5 -5
  84. package/lib/commonjs/extensions/pdbe/preferred-assembly.js +2 -2
  85. package/lib/commonjs/extensions/pdbe/struct-ref-domain.js +2 -2
  86. package/lib/commonjs/extensions/pdbe/structure-quality-report/behavior.js +1 -1
  87. package/lib/commonjs/extensions/pdbe/structure-quality-report/prop.js +8 -8
  88. package/lib/commonjs/extensions/rcsb/assembly-symmetry/behavior.js +17 -17
  89. package/lib/commonjs/extensions/rcsb/assembly-symmetry/color.js +2 -2
  90. package/lib/commonjs/extensions/rcsb/assembly-symmetry/prop.js +9 -9
  91. package/lib/commonjs/extensions/rcsb/assembly-symmetry/representation.js +6 -6
  92. package/lib/commonjs/extensions/rcsb/assembly-symmetry/ui.js +9 -9
  93. package/lib/commonjs/extensions/rcsb/validation-report/behavior.js +17 -17
  94. package/lib/commonjs/extensions/rcsb/validation-report/prop.js +15 -15
  95. package/lib/commonjs/extensions/rcsb/validation-report/representation.js +3 -3
  96. package/lib/commonjs/extensions/zenodo/index.d.ts +7 -0
  97. package/lib/commonjs/extensions/zenodo/index.js +35 -0
  98. package/lib/commonjs/extensions/zenodo/ui.d.ts +61 -0
  99. package/lib/commonjs/extensions/zenodo/ui.js +306 -0
  100. package/lib/commonjs/mol-canvas3d/camera/stereo.js +1 -1
  101. package/lib/commonjs/mol-canvas3d/camera/util.js +1 -1
  102. package/lib/commonjs/mol-canvas3d/camera.js +2 -1
  103. package/lib/commonjs/mol-canvas3d/canvas3d.js +14 -14
  104. package/lib/commonjs/mol-canvas3d/controls/trackball.js +1 -1
  105. package/lib/commonjs/mol-canvas3d/helper/bounding-sphere-helper.js +1 -1
  106. package/lib/commonjs/mol-canvas3d/helper/camera-helper.js +5 -5
  107. package/lib/commonjs/mol-canvas3d/helper/handle-helper.js +5 -5
  108. package/lib/commonjs/mol-canvas3d/helper/helper.js +1 -1
  109. package/lib/commonjs/mol-canvas3d/helper/interaction-events.js +2 -2
  110. package/lib/commonjs/mol-canvas3d/passes/draw.js +3 -3
  111. package/lib/commonjs/mol-canvas3d/passes/fxaa.js +3 -3
  112. package/lib/commonjs/mol-canvas3d/passes/image.js +1 -1
  113. package/lib/commonjs/mol-canvas3d/passes/marking.js +6 -6
  114. package/lib/commonjs/mol-canvas3d/passes/multi-sample.js +3 -3
  115. package/lib/commonjs/mol-canvas3d/passes/postprocessing.js +12 -12
  116. package/lib/commonjs/mol-canvas3d/passes/smaa.js +9 -9
  117. package/lib/commonjs/mol-canvas3d/passes/wboit.js +3 -3
  118. package/lib/commonjs/mol-canvas3d/util.js +2 -2
  119. package/lib/commonjs/mol-data/db/column.js +2 -2
  120. package/lib/commonjs/mol-data/db/table.js +1 -1
  121. package/lib/commonjs/mol-data/db.js +1 -1
  122. package/lib/commonjs/mol-data/generic.js +3 -3
  123. package/lib/commonjs/mol-data/index.js +4 -4
  124. package/lib/commonjs/mol-data/int/interval.js +1 -1
  125. package/lib/commonjs/mol-data/int/ordered-set.js +1 -1
  126. package/lib/commonjs/mol-data/int/segmentation.js +1 -1
  127. package/lib/commonjs/mol-data/int/sorted-array.js +1 -1
  128. package/lib/commonjs/mol-data/util.js +7 -7
  129. package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.js +3 -3
  130. package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.js +3 -3
  131. package/lib/commonjs/mol-geo/geometry/direct-volume/transfer-function.js +1 -1
  132. package/lib/commonjs/mol-geo/geometry/image/image.js +3 -3
  133. package/lib/commonjs/mol-geo/geometry/lines/lines.js +3 -3
  134. package/lib/commonjs/mol-geo/geometry/mesh/mesh.js +3 -3
  135. package/lib/commonjs/mol-geo/geometry/points/points.js +3 -3
  136. package/lib/commonjs/mol-geo/geometry/size-data.js +1 -1
  137. package/lib/commonjs/mol-geo/geometry/spheres/spheres.js +3 -3
  138. package/lib/commonjs/mol-geo/geometry/text/font-atlas.js +1 -1
  139. package/lib/commonjs/mol-geo/geometry/text/text-builder.js +3 -2
  140. package/lib/commonjs/mol-geo/geometry/text/text.js +3 -3
  141. package/lib/commonjs/mol-geo/geometry/texture-mesh/color-smoothing.js +4 -4
  142. package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.js +3 -3
  143. package/lib/commonjs/mol-geo/primitive/circle.js +1 -1
  144. package/lib/commonjs/mol-geo/primitive/cylinder.js +1 -1
  145. package/lib/commonjs/mol-geo/primitive/polyhedron.js +1 -1
  146. package/lib/commonjs/mol-geo/primitive/prism.js +1 -1
  147. package/lib/commonjs/mol-geo/primitive/star.js +1 -1
  148. package/lib/commonjs/mol-geo/primitive/torus.js +1 -1
  149. package/lib/commonjs/mol-geo/util/marching-cubes/algorithm.js +9 -9
  150. package/lib/commonjs/mol-gl/compute/grid3d.js +5 -5
  151. package/lib/commonjs/mol-gl/compute/histogram-pyramid/reduction.js +3 -3
  152. package/lib/commonjs/mol-gl/compute/histogram-pyramid/sum.js +3 -3
  153. package/lib/commonjs/mol-gl/compute/marching-cubes/active-voxels.js +3 -3
  154. package/lib/commonjs/mol-gl/compute/marching-cubes/isosurface.js +3 -3
  155. package/lib/commonjs/mol-gl/compute/util.js +3 -3
  156. package/lib/commonjs/mol-gl/renderable/cylinders.js +3 -3
  157. package/lib/commonjs/mol-gl/renderable/direct-volume.js +3 -3
  158. package/lib/commonjs/mol-gl/renderable/image.js +3 -3
  159. package/lib/commonjs/mol-gl/renderable/lines.js +3 -3
  160. package/lib/commonjs/mol-gl/renderable/mesh.js +3 -3
  161. package/lib/commonjs/mol-gl/renderable/points.js +3 -3
  162. package/lib/commonjs/mol-gl/renderable/schema.js +1 -1
  163. package/lib/commonjs/mol-gl/renderable/spheres.js +3 -3
  164. package/lib/commonjs/mol-gl/renderable/text.js +3 -3
  165. package/lib/commonjs/mol-gl/renderable/texture-mesh.js +3 -3
  166. package/lib/commonjs/mol-gl/renderable/util.js +1 -1
  167. package/lib/commonjs/mol-gl/shader-code.js +2 -1
  168. package/lib/commonjs/mol-gl/webgl/buffer.js +4 -5
  169. package/lib/commonjs/mol-gl/webgl/context.js +3 -3
  170. package/lib/commonjs/mol-gl/webgl/render-item.js +1 -1
  171. package/lib/commonjs/mol-gl/webgl/resources.js +2 -2
  172. package/lib/commonjs/mol-io/common/binary-cif/classifier.js +7 -6
  173. package/lib/commonjs/mol-io/common/binary-cif/decoder.js +4 -3
  174. package/lib/commonjs/mol-io/common/binary-cif.js +3 -3
  175. package/lib/commonjs/mol-io/common/io-buffer.d.ts +206 -0
  176. package/lib/commonjs/mol-io/common/io-buffer.js +408 -0
  177. package/lib/commonjs/mol-io/common/netcdf/reader.d.ts +78 -0
  178. package/lib/commonjs/mol-io/common/netcdf/reader.js +459 -0
  179. package/lib/commonjs/mol-io/common/typed-array.js +2 -2
  180. package/lib/commonjs/mol-io/reader/ccp4/parser.js +8 -8
  181. package/lib/commonjs/mol-io/reader/cif/binary/parser.js +3 -3
  182. package/lib/commonjs/mol-io/reader/cif/data-model.js +1 -1
  183. package/lib/commonjs/mol-io/reader/cif/schema/mmcif-extras.js +2 -2
  184. package/lib/commonjs/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
  185. package/lib/commonjs/mol-io/reader/cif/schema.js +2 -2
  186. package/lib/commonjs/mol-io/reader/cif/text/parser.js +7 -7
  187. package/lib/commonjs/mol-io/reader/cif.js +1 -1
  188. package/lib/commonjs/mol-io/reader/common/text/tokenizer.js +4 -4
  189. package/lib/commonjs/mol-io/reader/csv/data-model.js +1 -1
  190. package/lib/commonjs/mol-io/reader/csv/parser.js +7 -7
  191. package/lib/commonjs/mol-io/reader/cube/parser.js +2 -2
  192. package/lib/commonjs/mol-io/reader/dcd/parser.js +2 -2
  193. package/lib/commonjs/mol-io/reader/dsn6/parser.js +8 -8
  194. package/lib/commonjs/mol-io/reader/dx/parser.js +4 -4
  195. package/lib/commonjs/mol-io/reader/gro/parser.js +6 -6
  196. package/lib/commonjs/mol-io/reader/mol/parser.js +2 -2
  197. package/lib/commonjs/mol-io/reader/mol2/parser.js +8 -8
  198. package/lib/commonjs/mol-io/reader/nctraj/parser.d.ts +18 -0
  199. package/lib/commonjs/mol-io/reader/nctraj/parser.js +101 -0
  200. package/lib/commonjs/mol-io/reader/obj/parser.js +4 -4
  201. package/lib/commonjs/mol-io/reader/pdb/parser.js +2 -2
  202. package/lib/commonjs/mol-io/reader/ply/parser.js +4 -4
  203. package/lib/commonjs/mol-io/reader/prmtop/parser.d.ts +58 -0
  204. package/lib/commonjs/mol-io/reader/prmtop/parser.js +172 -0
  205. package/lib/commonjs/mol-io/reader/psf/parser.js +8 -8
  206. package/lib/commonjs/mol-io/reader/sdf/parser.js +2 -2
  207. package/lib/commonjs/mol-io/reader/top/parser.d.ts +37 -0
  208. package/lib/commonjs/mol-io/reader/top/parser.js +303 -0
  209. package/lib/commonjs/mol-io/reader/trr/parser.d.ts +22 -0
  210. package/lib/commonjs/mol-io/reader/trr/parser.js +146 -0
  211. package/lib/commonjs/mol-io/reader/xtc/parser.js +4 -4
  212. package/lib/commonjs/mol-io/reader/xyz/parser.js +2 -2
  213. package/lib/commonjs/mol-io/writer/cif/encoder.js +3 -2
  214. package/lib/commonjs/mol-io/writer/cif.js +1 -1
  215. package/lib/commonjs/mol-io/writer/ligand-encoder.js +1 -1
  216. package/lib/commonjs/mol-io/writer/mol/encoder.js +1 -1
  217. package/lib/commonjs/mol-io/writer/mol2/encoder.js +1 -1
  218. package/lib/commonjs/mol-math/geometry/boundary-helper.js +5 -5
  219. package/lib/commonjs/mol-math/geometry/gaussian-density/cpu.js +4 -4
  220. package/lib/commonjs/mol-math/geometry/gaussian-density/gpu.js +1 -1
  221. package/lib/commonjs/mol-math/geometry/gaussian-density.js +4 -4
  222. package/lib/commonjs/mol-math/geometry/molecular-surface.js +8 -8
  223. package/lib/commonjs/mol-math/geometry/primitives/sphere3d.js +1 -1
  224. package/lib/commonjs/mol-math/geometry.js +8 -8
  225. package/lib/commonjs/mol-math/graph/inter-unit-graph.js +1 -1
  226. package/lib/commonjs/mol-math/graph.js +1 -1
  227. package/lib/commonjs/mol-math/linear-algebra.js +2 -2
  228. package/lib/commonjs/mol-model/sequence/alignment/alignment.js +1 -1
  229. package/lib/commonjs/mol-model/sequence/sequence.js +2 -1
  230. package/lib/commonjs/mol-model/sequence.js +1 -1
  231. package/lib/commonjs/mol-model/shape.js +1 -1
  232. package/lib/commonjs/mol-model/structure/coordinates.js +1 -1
  233. package/lib/commonjs/mol-model/structure/export/categories/secondary-structure.js +2 -2
  234. package/lib/commonjs/mol-model/structure/model/model.js +3 -3
  235. package/lib/commonjs/mol-model/structure/model/properties/atomic.js +3 -3
  236. package/lib/commonjs/mol-model/structure/model/properties/coarse.js +2 -2
  237. package/lib/commonjs/mol-model/structure/model/types/saccharides.d.ts +8 -0
  238. package/lib/commonjs/mol-model/structure/model/types/saccharides.js +11 -0
  239. package/lib/commonjs/mol-model/structure/model.js +3 -3
  240. package/lib/commonjs/mol-model/structure/query/queries/generators.js +2 -2
  241. package/lib/commonjs/mol-model/structure/query/queries/modifiers.js +2 -2
  242. package/lib/commonjs/mol-model/structure/query.js +6 -6
  243. package/lib/commonjs/mol-model/structure/structure/carbohydrates/compute.js +1 -1
  244. package/lib/commonjs/mol-model/structure/structure/carbohydrates/constants.d.ts +1 -1
  245. package/lib/commonjs/mol-model/structure/structure/carbohydrates/constants.js +6 -9
  246. package/lib/commonjs/mol-model/structure/structure/element/element.js +5 -5
  247. package/lib/commonjs/mol-model/structure/structure/element.js +1 -1
  248. package/lib/commonjs/mol-model/structure/structure/structure.js +5 -5
  249. package/lib/commonjs/mol-model/structure/structure/symmetry.js +10 -10
  250. package/lib/commonjs/mol-model/structure/structure/unit/bonds/data.js +2 -2
  251. package/lib/commonjs/mol-model/structure/structure/unit/bonds/inter-compute.js +3 -3
  252. package/lib/commonjs/mol-model/structure/structure/unit/bonds/intra-compute.js +1 -1
  253. package/lib/commonjs/mol-model/structure/structure/unit/bonds.js +3 -3
  254. package/lib/commonjs/mol-model/structure/structure/unit.js +4 -4
  255. package/lib/commonjs/mol-model/structure/structure/util/superposition.js +1 -1
  256. package/lib/commonjs/mol-model/structure/structure.js +2 -2
  257. package/lib/commonjs/mol-model/structure/topology.js +1 -1
  258. package/lib/commonjs/mol-model/structure.js +6 -6
  259. package/lib/commonjs/mol-model/volume.js +2 -2
  260. package/lib/commonjs/mol-model-formats/shape/ply.js +7 -7
  261. package/lib/commonjs/mol-model-formats/structure/basic/atomic.d.ts +1 -1
  262. package/lib/commonjs/mol-model-formats/structure/basic/atomic.js +2 -15
  263. package/lib/commonjs/mol-model-formats/structure/basic/coarse.js +3 -3
  264. package/lib/commonjs/mol-model-formats/structure/basic/entities.js +1 -1
  265. package/lib/commonjs/mol-model-formats/structure/basic/parser.d.ts +1 -1
  266. package/lib/commonjs/mol-model-formats/structure/basic/parser.js +10 -10
  267. package/lib/commonjs/mol-model-formats/structure/basic/schema.d.ts +2 -2
  268. package/lib/commonjs/mol-model-formats/structure/basic/schema.js +7 -2
  269. package/lib/commonjs/mol-model-formats/structure/basic/sort.js +2 -2
  270. package/lib/commonjs/mol-model-formats/structure/basic/util.d.ts +33 -2
  271. package/lib/commonjs/mol-model-formats/structure/basic/util.js +26 -2
  272. package/lib/commonjs/mol-model-formats/structure/cif-core.js +6 -6
  273. package/lib/commonjs/mol-model-formats/structure/common/component.js +5 -1
  274. package/lib/commonjs/mol-model-formats/structure/cube.js +5 -5
  275. package/lib/commonjs/mol-model-formats/structure/dcd.js +2 -2
  276. package/lib/commonjs/mol-model-formats/structure/gro.js +5 -3
  277. package/lib/commonjs/mol-model-formats/structure/mmcif.d.ts +1 -1
  278. package/lib/commonjs/mol-model-formats/structure/mmcif.js +4 -2
  279. package/lib/commonjs/mol-model-formats/structure/mol.js +5 -5
  280. package/lib/commonjs/mol-model-formats/structure/mol2.js +6 -6
  281. package/lib/commonjs/mol-model-formats/structure/nctraj.d.ts +9 -0
  282. package/lib/commonjs/mol-model-formats/structure/nctraj.js +60 -0
  283. package/lib/commonjs/mol-model-formats/structure/pdb/to-cif.js +2 -2
  284. package/lib/commonjs/mol-model-formats/structure/pdb.d.ts +1 -1
  285. package/lib/commonjs/mol-model-formats/structure/pdb.js +7 -5
  286. package/lib/commonjs/mol-model-formats/structure/prmtop.d.ts +16 -0
  287. package/lib/commonjs/mol-model-formats/structure/prmtop.js +147 -0
  288. package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.js +1 -1
  289. package/lib/commonjs/mol-model-formats/structure/property/symmetry.js +11 -1
  290. package/lib/commonjs/mol-model-formats/structure/psf.js +5 -3
  291. package/lib/commonjs/mol-model-formats/structure/top.d.ts +16 -0
  292. package/lib/commonjs/mol-model-formats/structure/top.js +189 -0
  293. package/lib/commonjs/mol-model-formats/structure/trr.d.ts +9 -0
  294. package/lib/commonjs/mol-model-formats/structure/trr.js +46 -0
  295. package/lib/commonjs/mol-model-formats/structure/util.d.ts +2 -2
  296. package/lib/commonjs/mol-model-formats/structure/util.js +19 -20
  297. package/lib/commonjs/mol-model-formats/structure/xtc.js +2 -2
  298. package/lib/commonjs/mol-model-formats/structure/xyz.js +2 -2
  299. package/lib/commonjs/mol-model-formats/volume/ccp4.js +2 -2
  300. package/lib/commonjs/mol-model-formats/volume/cube.js +2 -2
  301. package/lib/commonjs/mol-model-formats/volume/density-server.js +2 -2
  302. package/lib/commonjs/mol-model-formats/volume/dsn6.js +2 -2
  303. package/lib/commonjs/mol-model-formats/volume/dx.js +2 -2
  304. package/lib/commonjs/mol-model-props/common/custom-element-property.js +2 -2
  305. package/lib/commonjs/mol-model-props/common/custom-model-property.js +5 -5
  306. package/lib/commonjs/mol-model-props/common/custom-property.js +1 -1
  307. package/lib/commonjs/mol-model-props/common/custom-structure-property.js +6 -6
  308. package/lib/commonjs/mol-model-props/computed/accessible-surface-area/shrake-rupley/area.js +2 -2
  309. package/lib/commonjs/mol-model-props/computed/accessible-surface-area/shrake-rupley.js +5 -5
  310. package/lib/commonjs/mol-model-props/computed/accessible-surface-area.js +4 -4
  311. package/lib/commonjs/mol-model-props/computed/chemistry/valence-model.js +3 -3
  312. package/lib/commonjs/mol-model-props/computed/helix-orientation.js +2 -2
  313. package/lib/commonjs/mol-model-props/computed/interactions/common.js +1 -1
  314. package/lib/commonjs/mol-model-props/computed/interactions/contacts.js +1 -1
  315. package/lib/commonjs/mol-model-props/computed/interactions/features.js +1 -1
  316. package/lib/commonjs/mol-model-props/computed/interactions/hydrogen-bonds.js +3 -3
  317. package/lib/commonjs/mol-model-props/computed/interactions/interactions.js +3 -3
  318. package/lib/commonjs/mol-model-props/computed/interactions.js +4 -4
  319. package/lib/commonjs/mol-model-props/computed/representations/interactions-inter-unit-cylinder.js +1 -1
  320. package/lib/commonjs/mol-model-props/computed/representations/interactions-intra-unit-cylinder.js +3 -3
  321. package/lib/commonjs/mol-model-props/computed/representations/interactions.js +1 -1
  322. package/lib/commonjs/mol-model-props/computed/secondary-structure/dssp.js +2 -2
  323. package/lib/commonjs/mol-model-props/computed/secondary-structure.js +7 -7
  324. package/lib/commonjs/mol-model-props/computed/valence-model.js +4 -4
  325. package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/property.js +2 -2
  326. package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/representation.js +2 -2
  327. package/lib/commonjs/mol-model-props/sequence/sifts-mapping.js +2 -2
  328. package/lib/commonjs/mol-model-props/sequence/themes/sifts-mapping.js +3 -3
  329. package/lib/commonjs/mol-plugin/animation-loop.js +2 -2
  330. package/lib/commonjs/mol-plugin/behavior/behavior.js +5 -5
  331. package/lib/commonjs/mol-plugin/behavior/dynamic/camera.js +2 -2
  332. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/accessible-surface-area.js +1 -1
  333. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/interactions.js +1 -1
  334. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/secondary-structure.js +1 -1
  335. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/valence-model.js +1 -1
  336. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/integrative/cross-link-restraint.js +1 -1
  337. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/sequence/sifts-mapping.js +1 -1
  338. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/structure-info.js +2 -2
  339. package/lib/commonjs/mol-plugin/behavior/dynamic/representation.js +3 -3
  340. package/lib/commonjs/mol-plugin/behavior/dynamic/selection/structure-focus-representation.js +11 -11
  341. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/behavior.js +12 -12
  342. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/model.js +1 -1
  343. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/transformers.js +16 -16
  344. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/util.js +10 -10
  345. package/lib/commonjs/mol-plugin/behavior/static/state.js +6 -6
  346. package/lib/commonjs/mol-plugin/behavior.js +8 -8
  347. package/lib/commonjs/mol-plugin/command.js +2 -2
  348. package/lib/commonjs/mol-plugin/context.d.ts +2 -1
  349. package/lib/commonjs/mol-plugin/context.js +9 -8
  350. package/lib/commonjs/mol-plugin/layout.js +2 -2
  351. package/lib/commonjs/mol-plugin/spec.js +1 -1
  352. package/lib/commonjs/mol-plugin/state.js +5 -5
  353. package/lib/commonjs/mol-plugin/util/task-manager.js +4 -4
  354. package/lib/commonjs/mol-plugin/util/toast.js +1 -1
  355. package/lib/commonjs/mol-plugin/util/viewport-screenshot.js +17 -17
  356. package/lib/commonjs/mol-plugin-state/actions/file.d.ts +1 -1
  357. package/lib/commonjs/mol-plugin-state/actions/file.js +94 -61
  358. package/lib/commonjs/mol-plugin-state/actions/structure.d.ts +11 -2
  359. package/lib/commonjs/mol-plugin-state/actions/structure.js +190 -20
  360. package/lib/commonjs/mol-plugin-state/actions/volume.js +5 -4
  361. package/lib/commonjs/mol-plugin-state/actions.js +3 -3
  362. package/lib/commonjs/mol-plugin-state/animation/built-in/assembly-unwind.js +2 -2
  363. package/lib/commonjs/mol-plugin-state/animation/built-in/camera-rock.js +3 -3
  364. package/lib/commonjs/mol-plugin-state/animation/built-in/camera-spin.js +3 -3
  365. package/lib/commonjs/mol-plugin-state/animation/built-in/explode-units.js +4 -4
  366. package/lib/commonjs/mol-plugin-state/animation/built-in/model-index.js +2 -2
  367. package/lib/commonjs/mol-plugin-state/animation/built-in/spin-structure.js +5 -5
  368. package/lib/commonjs/mol-plugin-state/animation/built-in/state-interpolation.js +2 -2
  369. package/lib/commonjs/mol-plugin-state/animation/built-in/state-snapshots.js +5 -5
  370. package/lib/commonjs/mol-plugin-state/builder/data.js +2 -2
  371. package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy-preset.js +16 -16
  372. package/lib/commonjs/mol-plugin-state/builder/structure/representation-preset.js +28 -28
  373. package/lib/commonjs/mol-plugin-state/builder/structure/representation.js +2 -2
  374. package/lib/commonjs/mol-plugin-state/builder/structure.js +7 -7
  375. package/lib/commonjs/mol-plugin-state/component.js +1 -1
  376. package/lib/commonjs/mol-plugin-state/formats/{structure.d.ts → coordinates.d.ts} +34 -18
  377. package/lib/commonjs/mol-plugin-state/formats/coordinates.js +70 -0
  378. package/lib/commonjs/mol-plugin-state/formats/registry.d.ts +3 -3
  379. package/lib/commonjs/mol-plugin-state/formats/registry.js +13 -8
  380. package/lib/commonjs/mol-plugin-state/formats/shape.js +2 -2
  381. package/lib/commonjs/mol-plugin-state/formats/topology.d.ts +73 -0
  382. package/lib/commonjs/mol-plugin-state/formats/topology.js +87 -0
  383. package/lib/commonjs/mol-plugin-state/formats/trajectory.js +6 -6
  384. package/lib/commonjs/mol-plugin-state/formats/volume.js +21 -21
  385. package/lib/commonjs/mol-plugin-state/helpers/root-structure.js +14 -14
  386. package/lib/commonjs/mol-plugin-state/helpers/structure-clipping.js +7 -7
  387. package/lib/commonjs/mol-plugin-state/helpers/structure-component.js +2 -1
  388. package/lib/commonjs/mol-plugin-state/helpers/structure-overpaint.js +11 -11
  389. package/lib/commonjs/mol-plugin-state/helpers/structure-selection-query.js +3 -3
  390. package/lib/commonjs/mol-plugin-state/helpers/structure-substance.js +11 -11
  391. package/lib/commonjs/mol-plugin-state/helpers/structure-transparency.js +11 -11
  392. package/lib/commonjs/mol-plugin-state/manager/animation.js +17 -17
  393. package/lib/commonjs/mol-plugin-state/manager/camera.js +1 -1
  394. package/lib/commonjs/mol-plugin-state/manager/interactivity.js +6 -6
  395. package/lib/commonjs/mol-plugin-state/manager/snapshots.js +14 -14
  396. package/lib/commonjs/mol-plugin-state/manager/structure/component.js +26 -26
  397. package/lib/commonjs/mol-plugin-state/manager/structure/focus.js +2 -2
  398. package/lib/commonjs/mol-plugin-state/manager/structure/hierarchy-state.js +1 -1
  399. package/lib/commonjs/mol-plugin-state/manager/structure/hierarchy.js +8 -8
  400. package/lib/commonjs/mol-plugin-state/manager/structure/measurement.js +21 -21
  401. package/lib/commonjs/mol-plugin-state/manager/structure/selection.js +3 -3
  402. package/lib/commonjs/mol-plugin-state/manager/volume/hierarchy.js +1 -1
  403. package/lib/commonjs/mol-plugin-state/objects.d.ts +47 -1
  404. package/lib/commonjs/mol-plugin-state/objects.js +46 -30
  405. package/lib/commonjs/mol-plugin-state/transforms/data.d.ts +6 -0
  406. package/lib/commonjs/mol-plugin-state/transforms/data.js +93 -41
  407. package/lib/commonjs/mol-plugin-state/transforms/model.d.ts +14 -2
  408. package/lib/commonjs/mol-plugin-state/transforms/model.js +163 -54
  409. package/lib/commonjs/mol-plugin-state/transforms/representation.js +77 -77
  410. package/lib/commonjs/mol-plugin-state/transforms/shape.js +2 -2
  411. package/lib/commonjs/mol-plugin-state/transforms/volume.js +16 -16
  412. package/lib/commonjs/mol-plugin-state/transforms.js +6 -6
  413. package/lib/commonjs/mol-plugin-ui/base.js +5 -5
  414. package/lib/commonjs/mol-plugin-ui/context.js +1 -1
  415. package/lib/commonjs/mol-plugin-ui/controls/action-menu.js +14 -14
  416. package/lib/commonjs/mol-plugin-ui/controls/color.js +7 -7
  417. package/lib/commonjs/mol-plugin-ui/controls/common.js +16 -16
  418. package/lib/commonjs/mol-plugin-ui/controls/icons.js +70 -70
  419. package/lib/commonjs/mol-plugin-ui/controls/legend.js +7 -7
  420. package/lib/commonjs/mol-plugin-ui/controls/line-graph/line-graph-component.js +3 -3
  421. package/lib/commonjs/mol-plugin-ui/controls/line-graph/point-component.js +2 -2
  422. package/lib/commonjs/mol-plugin-ui/controls/parameters.js +94 -94
  423. package/lib/commonjs/mol-plugin-ui/controls/screenshot.js +5 -5
  424. package/lib/commonjs/mol-plugin-ui/controls/slider.js +16 -16
  425. package/lib/commonjs/mol-plugin-ui/controls.js +16 -16
  426. package/lib/commonjs/mol-plugin-ui/custom/volume.js +16 -16
  427. package/lib/commonjs/mol-plugin-ui/index.js +4 -4
  428. package/lib/commonjs/mol-plugin-ui/left-panel.d.ts +8 -1
  429. package/lib/commonjs/mol-plugin-ui/left-panel.js +40 -19
  430. package/lib/commonjs/mol-plugin-ui/plugin.js +17 -17
  431. package/lib/commonjs/mol-plugin-ui/sequence/chain.js +1 -1
  432. package/lib/commonjs/mol-plugin-ui/sequence/element.js +1 -1
  433. package/lib/commonjs/mol-plugin-ui/sequence/hetero.js +1 -1
  434. package/lib/commonjs/mol-plugin-ui/sequence/polymer.js +1 -1
  435. package/lib/commonjs/mol-plugin-ui/sequence/sequence.js +6 -6
  436. package/lib/commonjs/mol-plugin-ui/sequence.js +9 -9
  437. package/lib/commonjs/mol-plugin-ui/spec.js +1 -1
  438. package/lib/commonjs/mol-plugin-ui/state/actions.js +2 -2
  439. package/lib/commonjs/mol-plugin-ui/state/animation.js +2 -2
  440. package/lib/commonjs/mol-plugin-ui/state/apply-action.js +1 -1
  441. package/lib/commonjs/mol-plugin-ui/state/common.js +12 -12
  442. package/lib/commonjs/mol-plugin-ui/state/snapshots.js +29 -29
  443. package/lib/commonjs/mol-plugin-ui/state/tree.js +19 -19
  444. package/lib/commonjs/mol-plugin-ui/state/update-transform.js +3 -3
  445. package/lib/commonjs/mol-plugin-ui/structure/components.js +19 -19
  446. package/lib/commonjs/mol-plugin-ui/structure/focus.js +4 -4
  447. package/lib/commonjs/mol-plugin-ui/structure/generic.js +6 -6
  448. package/lib/commonjs/mol-plugin-ui/structure/measurements.js +13 -13
  449. package/lib/commonjs/mol-plugin-ui/structure/quick-styles.js +11 -11
  450. package/lib/commonjs/mol-plugin-ui/structure/selection.js +13 -13
  451. package/lib/commonjs/mol-plugin-ui/structure/source.js +12 -12
  452. package/lib/commonjs/mol-plugin-ui/structure/superposition.js +20 -20
  453. package/lib/commonjs/mol-plugin-ui/structure/volume.js +12 -12
  454. package/lib/commonjs/mol-plugin-ui/task.js +8 -8
  455. package/lib/commonjs/mol-plugin-ui/toast.js +6 -6
  456. package/lib/commonjs/mol-plugin-ui/viewport/canvas.js +5 -5
  457. package/lib/commonjs/mol-plugin-ui/viewport/help.js +14 -14
  458. package/lib/commonjs/mol-plugin-ui/viewport/screenshot.js +8 -8
  459. package/lib/commonjs/mol-plugin-ui/viewport/simple-settings.js +6 -6
  460. package/lib/commonjs/mol-plugin-ui/viewport.js +7 -7
  461. package/lib/commonjs/mol-repr/representation.js +4 -4
  462. package/lib/commonjs/mol-repr/shape/loci/angle.js +9 -9
  463. package/lib/commonjs/mol-repr/shape/loci/common.js +1 -1
  464. package/lib/commonjs/mol-repr/shape/loci/dihedral.js +14 -14
  465. package/lib/commonjs/mol-repr/shape/loci/distance.js +5 -5
  466. package/lib/commonjs/mol-repr/shape/loci/label.js +3 -3
  467. package/lib/commonjs/mol-repr/shape/loci/orientation.js +4 -4
  468. package/lib/commonjs/mol-repr/shape/loci/plane.js +2 -2
  469. package/lib/commonjs/mol-repr/shape/model/unitcell.js +2 -2
  470. package/lib/commonjs/mol-repr/shape/representation.js +2 -2
  471. package/lib/commonjs/mol-repr/structure/complex-representation.js +2 -2
  472. package/lib/commonjs/mol-repr/structure/complex-visual.js +12 -12
  473. package/lib/commonjs/mol-repr/structure/params.js +8 -8
  474. package/lib/commonjs/mol-repr/structure/registry.js +1 -1
  475. package/lib/commonjs/mol-repr/structure/representation/backbone.js +1 -1
  476. package/lib/commonjs/mol-repr/structure/representation/ball-and-stick.js +1 -1
  477. package/lib/commonjs/mol-repr/structure/representation/carbohydrate.js +1 -1
  478. package/lib/commonjs/mol-repr/structure/representation/cartoon.js +3 -3
  479. package/lib/commonjs/mol-repr/structure/representation/ellipsoid.js +1 -1
  480. package/lib/commonjs/mol-repr/structure/representation/gaussian-surface.js +1 -1
  481. package/lib/commonjs/mol-repr/structure/representation/gaussian-volume.js +1 -1
  482. package/lib/commonjs/mol-repr/structure/representation/label.js +1 -1
  483. package/lib/commonjs/mol-repr/structure/representation/line.js +1 -1
  484. package/lib/commonjs/mol-repr/structure/representation/molecular-surface.js +1 -1
  485. package/lib/commonjs/mol-repr/structure/representation/orientation.js +1 -1
  486. package/lib/commonjs/mol-repr/structure/representation/point.js +1 -1
  487. package/lib/commonjs/mol-repr/structure/representation/putty.js +1 -1
  488. package/lib/commonjs/mol-repr/structure/representation/spacefill.js +1 -1
  489. package/lib/commonjs/mol-repr/structure/representation.js +1 -1
  490. package/lib/commonjs/mol-repr/structure/units-representation.js +2 -2
  491. package/lib/commonjs/mol-repr/structure/units-visual.js +16 -16
  492. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-cylinder.js +1 -1
  493. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-line.js +1 -1
  494. package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-cylinder.js +1 -1
  495. package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-line.js +1 -1
  496. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-link-cylinder.js +1 -1
  497. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-symbol-mesh.js +1 -1
  498. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.js +1 -1
  499. package/lib/commonjs/mol-repr/structure/visual/element-cross.js +1 -1
  500. package/lib/commonjs/mol-repr/structure/visual/element-point.js +1 -1
  501. package/lib/commonjs/mol-repr/structure/visual/element-sphere.js +1 -1
  502. package/lib/commonjs/mol-repr/structure/visual/ellipsoid-mesh.js +1 -1
  503. package/lib/commonjs/mol-repr/structure/visual/gaussian-density-volume.js +6 -6
  504. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.js +11 -11
  505. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.js +3 -3
  506. package/lib/commonjs/mol-repr/structure/visual/label-text.js +1 -1
  507. package/lib/commonjs/mol-repr/structure/visual/molecular-surface-mesh.js +3 -3
  508. package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.js +3 -3
  509. package/lib/commonjs/mol-repr/structure/visual/nucleotide-block-mesh.js +1 -1
  510. package/lib/commonjs/mol-repr/structure/visual/nucleotide-ring-mesh.js +1 -1
  511. package/lib/commonjs/mol-repr/structure/visual/orientation-ellipsoid-mesh.js +1 -1
  512. package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-cylinder.js +1 -1
  513. package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-sphere.js +1 -1
  514. package/lib/commonjs/mol-repr/structure/visual/polymer-direction-wedge.js +1 -1
  515. package/lib/commonjs/mol-repr/structure/visual/polymer-gap-cylinder.js +1 -1
  516. package/lib/commonjs/mol-repr/structure/visual/polymer-trace-mesh.js +1 -1
  517. package/lib/commonjs/mol-repr/structure/visual/polymer-tube-mesh.js +1 -1
  518. package/lib/commonjs/mol-repr/structure/visual/util/bond.js +2 -2
  519. package/lib/commonjs/mol-repr/structure/visual/util/common.js +1 -1
  520. package/lib/commonjs/mol-repr/structure/visual/util/gaussian.js +13 -13
  521. package/lib/commonjs/mol-repr/structure/visual/util/molecular-surface.js +5 -5
  522. package/lib/commonjs/mol-repr/structure/visual/util/polymer.js +4 -4
  523. package/lib/commonjs/mol-repr/util.js +1 -1
  524. package/lib/commonjs/mol-repr/volume/direct-volume.js +3 -3
  525. package/lib/commonjs/mol-repr/volume/isosurface.js +9 -9
  526. package/lib/commonjs/mol-repr/volume/registry.js +1 -1
  527. package/lib/commonjs/mol-repr/volume/representation.js +5 -5
  528. package/lib/commonjs/mol-repr/volume/slice.js +4 -4
  529. package/lib/commonjs/mol-script/language/parser.js +7 -4
  530. package/lib/commonjs/mol-script/language/symbol-table/internal.js +1 -1
  531. package/lib/commonjs/mol-script/language/symbol-table/structure-query.js +1 -1
  532. package/lib/commonjs/mol-script/runtime/query/compiler.js +1 -1
  533. package/lib/commonjs/mol-script/script/mol-script/symbols.js +1 -1
  534. package/lib/commonjs/mol-state/action.js +1 -1
  535. package/lib/commonjs/mol-state/index.js +8 -8
  536. package/lib/commonjs/mol-state/state/builder.js +2 -2
  537. package/lib/commonjs/mol-state/state/selection.js +1 -1
  538. package/lib/commonjs/mol-state/state.js +21 -21
  539. package/lib/commonjs/mol-state/transform.js +4 -4
  540. package/lib/commonjs/mol-state/transformer.js +1 -1
  541. package/lib/commonjs/mol-task/execution/observable.js +5 -5
  542. package/lib/commonjs/mol-task/task.js +3 -3
  543. package/lib/commonjs/mol-task/util/chunked.js +2 -2
  544. package/lib/commonjs/mol-task/util/multistep.js +1 -1
  545. package/lib/commonjs/mol-task/util/scheduler.d.ts +2 -2
  546. package/lib/commonjs/mol-task/util/scheduler.js +8 -8
  547. package/lib/commonjs/mol-theme/color/atom-id.js +1 -1
  548. package/lib/commonjs/mol-theme/color/chain-id.js +1 -1
  549. package/lib/commonjs/mol-theme/color/element-index.js +1 -1
  550. package/lib/commonjs/mol-theme/color/entity-id.js +1 -1
  551. package/lib/commonjs/mol-theme/color/entity-source.js +2 -2
  552. package/lib/commonjs/mol-theme/color/hydrophobicity.js +2 -2
  553. package/lib/commonjs/mol-theme/color/model-index.js +1 -1
  554. package/lib/commonjs/mol-theme/color/operator-hkl.js +2 -2
  555. package/lib/commonjs/mol-theme/color/operator-name.js +1 -1
  556. package/lib/commonjs/mol-theme/color/polymer-id.js +2 -2
  557. package/lib/commonjs/mol-theme/color/polymer-index.js +2 -2
  558. package/lib/commonjs/mol-theme/color/unit-index.js +2 -2
  559. package/lib/commonjs/mol-theme/label.js +6 -6
  560. package/lib/commonjs/mol-theme/theme.js +3 -3
  561. package/lib/commonjs/mol-util/assets.js +7 -7
  562. package/lib/commonjs/mol-util/color/distinct.js +1 -1
  563. package/lib/commonjs/mol-util/color/palette.js +3 -3
  564. package/lib/commonjs/mol-util/color/scale.js +2 -2
  565. package/lib/commonjs/mol-util/data-source.js +14 -13
  566. package/lib/commonjs/mol-util/file-info.d.ts +1 -3
  567. package/lib/commonjs/mol-util/file-info.js +2 -10
  568. package/lib/commonjs/mol-util/graphql-client.js +4 -4
  569. package/lib/commonjs/mol-util/index.d.ts +1 -0
  570. package/lib/commonjs/mol-util/index.js +8 -2
  571. package/lib/commonjs/mol-util/input/input-observer.js +6 -6
  572. package/lib/commonjs/mol-util/make-dir.js +1 -1
  573. package/lib/commonjs/mol-util/material.js +2 -2
  574. package/lib/commonjs/mol-util/monadic-parser.js +2 -2
  575. package/lib/commonjs/mol-util/param-definition.js +7 -7
  576. package/lib/commonjs/mol-util/read.js +2 -2
  577. package/lib/commonjs/mol-util/retry-if.js +2 -2
  578. package/lib/commonjs/mol-util/string.js +1 -1
  579. package/lib/commonjs/mol-util/zip/deflate.js +4 -3
  580. package/lib/commonjs/mol-util/zip/inflate.js +2 -2
  581. package/lib/commonjs/mol-util/zip/zip.d.ts +7 -1
  582. package/lib/commonjs/mol-util/zip/zip.js +21 -16
  583. package/lib/commonjs/servers/common/file-handle.js +1 -1
  584. package/lib/commonjs/servers/common/swagger-ui/index.js +1 -1
  585. package/lib/commonjs/servers/model/config.d.ts +2 -2
  586. package/lib/commonjs/servers/model/config.js +5 -5
  587. package/lib/commonjs/servers/model/preprocess/converter.js +2 -2
  588. package/lib/commonjs/servers/model/preprocess/master.js +3 -3
  589. package/lib/commonjs/servers/model/preprocess/parallel.js +6 -6
  590. package/lib/commonjs/servers/model/preprocess/preprocess.js +4 -4
  591. package/lib/commonjs/servers/model/preprocess.js +1 -1
  592. package/lib/commonjs/servers/model/properties/providers/pdbe.js +8 -8
  593. package/lib/commonjs/servers/model/properties/providers/wwpdb.js +12 -12
  594. package/lib/commonjs/servers/model/property-provider.js +3 -3
  595. package/lib/commonjs/servers/model/query.js +1 -1
  596. package/lib/commonjs/servers/model/server/api-local.js +2 -2
  597. package/lib/commonjs/servers/model/server/api-schema.js +2 -2
  598. package/lib/commonjs/servers/model/server/api-web.js +5 -5
  599. package/lib/commonjs/servers/model/server/api.js +6 -6
  600. package/lib/commonjs/servers/model/server/query.js +15 -15
  601. package/lib/commonjs/servers/model/server/structure-wrapper.js +21 -21
  602. package/lib/commonjs/servers/model/server.js +2 -2
  603. package/lib/commonjs/servers/model/utils/fetch-props-pdbe.js +6 -6
  604. package/lib/commonjs/servers/model/utils/fetch-retry.js +3 -3
  605. package/lib/commonjs/servers/model/utils/writer.js +3 -3
  606. package/lib/commonjs/servers/plugin-state/config.js +1 -1
  607. package/lib/commonjs/servers/plugin-state/index.js +6 -6
  608. package/lib/commonjs/servers/volume/common/binary-schema.js +1 -1
  609. package/lib/commonjs/servers/volume/common/data-format.js +3 -3
  610. package/lib/commonjs/servers/volume/common/file.js +8 -8
  611. package/lib/commonjs/servers/volume/config.js +6 -6
  612. package/lib/commonjs/servers/volume/pack/format/ccp4.js +4 -4
  613. package/lib/commonjs/servers/volume/pack/format/dsn6.js +4 -4
  614. package/lib/commonjs/servers/volume/pack/format.js +3 -3
  615. package/lib/commonjs/servers/volume/pack/main.js +13 -13
  616. package/lib/commonjs/servers/volume/pack/sampling.js +13 -13
  617. package/lib/commonjs/servers/volume/pack/writer.js +2 -2
  618. package/lib/commonjs/servers/volume/pack.js +1 -1
  619. package/lib/commonjs/servers/volume/query.js +4 -4
  620. package/lib/commonjs/servers/volume/server/algebra/box.js +1 -1
  621. package/lib/commonjs/servers/volume/server/api.js +8 -8
  622. package/lib/commonjs/servers/volume/server/local-api.js +8 -8
  623. package/lib/commonjs/servers/volume/server/query/compose.js +8 -8
  624. package/lib/commonjs/servers/volume/server/query/execute.js +10 -10
  625. package/lib/commonjs/servers/volume/server/query/identify.js +2 -2
  626. package/lib/commonjs/servers/volume/server/web-api.js +7 -7
  627. package/lib/commonjs/servers/volume/server.js +2 -2
  628. package/lib/examples/alpha-orbitals/controls.js +2 -2
  629. package/lib/examples/basic-wrapper/controls.js +1 -1
  630. package/lib/examples/proteopedia-wrapper/ui/controls.js +1 -1
  631. package/lib/extensions/cellpack/model.js +4 -2
  632. package/lib/extensions/cellpack/state.js +2 -2
  633. package/lib/extensions/geo-export/ui.js +2 -2
  634. package/lib/extensions/model-export/ui.js +2 -2
  635. package/lib/extensions/mp4-export/ui.js +2 -2
  636. package/lib/extensions/rcsb/assembly-symmetry/ui.js +3 -3
  637. package/lib/extensions/zenodo/index.d.ts +7 -0
  638. package/lib/extensions/zenodo/index.js +32 -0
  639. package/lib/extensions/zenodo/ui.d.ts +61 -0
  640. package/lib/extensions/zenodo/ui.js +303 -0
  641. package/lib/mol-canvas3d/camera.js +2 -1
  642. package/lib/mol-canvas3d/helper/camera-helper.js +1 -1
  643. package/lib/mol-canvas3d/helper/handle-helper.js +1 -1
  644. package/lib/mol-canvas3d/helper/interaction-events.js +1 -1
  645. package/lib/mol-geo/geometry/text/text-builder.js +2 -1
  646. package/lib/mol-gl/shader-code.js +2 -1
  647. package/lib/mol-gl/webgl/buffer.js +2 -3
  648. package/lib/mol-io/common/binary-cif/classifier.js +3 -2
  649. package/lib/mol-io/common/binary-cif/decoder.js +4 -3
  650. package/lib/mol-io/common/io-buffer.d.ts +206 -0
  651. package/lib/mol-io/common/io-buffer.js +405 -0
  652. package/lib/mol-io/common/netcdf/reader.d.ts +78 -0
  653. package/lib/mol-io/common/netcdf/reader.js +456 -0
  654. package/lib/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
  655. package/lib/mol-io/reader/nctraj/parser.d.ts +18 -0
  656. package/lib/mol-io/reader/nctraj/parser.js +97 -0
  657. package/lib/mol-io/reader/prmtop/parser.d.ts +58 -0
  658. package/lib/mol-io/reader/prmtop/parser.js +168 -0
  659. package/lib/mol-io/reader/top/parser.d.ts +37 -0
  660. package/lib/mol-io/reader/top/parser.js +299 -0
  661. package/lib/mol-io/reader/trr/parser.d.ts +22 -0
  662. package/lib/mol-io/reader/trr/parser.js +142 -0
  663. package/lib/mol-io/writer/cif/encoder.js +2 -1
  664. package/lib/mol-model/sequence/sequence.js +2 -1
  665. package/lib/mol-model/structure/model/types/saccharides.d.ts +8 -0
  666. package/lib/mol-model/structure/model/types/saccharides.js +8 -0
  667. package/lib/mol-model/structure/structure/carbohydrates/constants.d.ts +1 -1
  668. package/lib/mol-model/structure/structure/carbohydrates/constants.js +6 -9
  669. package/lib/mol-model-formats/structure/basic/atomic.d.ts +1 -1
  670. package/lib/mol-model-formats/structure/basic/atomic.js +1 -14
  671. package/lib/mol-model-formats/structure/basic/parser.d.ts +1 -1
  672. package/lib/mol-model-formats/structure/basic/parser.js +1 -1
  673. package/lib/mol-model-formats/structure/basic/schema.d.ts +2 -2
  674. package/lib/mol-model-formats/structure/basic/schema.js +7 -2
  675. package/lib/mol-model-formats/structure/basic/util.d.ts +33 -2
  676. package/lib/mol-model-formats/structure/basic/util.js +24 -1
  677. package/lib/mol-model-formats/structure/cif-core.js +4 -4
  678. package/lib/mol-model-formats/structure/common/component.js +5 -1
  679. package/lib/mol-model-formats/structure/cube.js +3 -3
  680. package/lib/mol-model-formats/structure/gro.js +3 -1
  681. package/lib/mol-model-formats/structure/mmcif.d.ts +1 -1
  682. package/lib/mol-model-formats/structure/mmcif.js +4 -2
  683. package/lib/mol-model-formats/structure/mol.js +3 -3
  684. package/lib/mol-model-formats/structure/mol2.js +4 -4
  685. package/lib/mol-model-formats/structure/nctraj.d.ts +9 -0
  686. package/lib/mol-model-formats/structure/nctraj.js +56 -0
  687. package/lib/mol-model-formats/structure/pdb.d.ts +1 -1
  688. package/lib/mol-model-formats/structure/pdb.js +5 -3
  689. package/lib/mol-model-formats/structure/prmtop.d.ts +16 -0
  690. package/lib/mol-model-formats/structure/prmtop.js +144 -0
  691. package/lib/mol-model-formats/structure/property/symmetry.js +11 -1
  692. package/lib/mol-model-formats/structure/psf.js +3 -1
  693. package/lib/mol-model-formats/structure/top.d.ts +16 -0
  694. package/lib/mol-model-formats/structure/top.js +186 -0
  695. package/lib/mol-model-formats/structure/trr.d.ts +9 -0
  696. package/lib/mol-model-formats/structure/trr.js +42 -0
  697. package/lib/mol-model-formats/structure/util.d.ts +2 -2
  698. package/lib/mol-model-formats/structure/util.js +19 -20
  699. package/lib/mol-model-formats/structure/xyz.js +2 -2
  700. package/lib/mol-plugin/context.d.ts +2 -1
  701. package/lib/mol-plugin/context.js +4 -3
  702. package/lib/mol-plugin/spec.js +1 -1
  703. package/lib/mol-plugin/version.js +2 -2
  704. package/lib/mol-plugin-state/actions/file.d.ts +1 -1
  705. package/lib/mol-plugin-state/actions/file.js +88 -55
  706. package/lib/mol-plugin-state/actions/structure.d.ts +11 -2
  707. package/lib/mol-plugin-state/actions/structure.js +174 -4
  708. package/lib/mol-plugin-state/actions/volume.js +3 -2
  709. package/lib/mol-plugin-state/formats/{structure.d.ts → coordinates.d.ts} +34 -18
  710. package/lib/mol-plugin-state/formats/coordinates.js +67 -0
  711. package/lib/mol-plugin-state/formats/registry.d.ts +3 -3
  712. package/lib/mol-plugin-state/formats/registry.js +13 -8
  713. package/lib/mol-plugin-state/formats/topology.d.ts +73 -0
  714. package/lib/mol-plugin-state/formats/topology.js +84 -0
  715. package/lib/mol-plugin-state/helpers/structure-component.js +2 -1
  716. package/lib/mol-plugin-state/manager/snapshots.js +4 -4
  717. package/lib/mol-plugin-state/objects.d.ts +47 -1
  718. package/lib/mol-plugin-state/objects.js +17 -1
  719. package/lib/mol-plugin-state/transforms/data.d.ts +6 -0
  720. package/lib/mol-plugin-state/transforms/data.js +61 -9
  721. package/lib/mol-plugin-state/transforms/model.d.ts +14 -2
  722. package/lib/mol-plugin-state/transforms/model.js +112 -3
  723. package/lib/mol-plugin-ui/base.js +1 -1
  724. package/lib/mol-plugin-ui/controls/action-menu.js +7 -7
  725. package/lib/mol-plugin-ui/controls/color.js +3 -3
  726. package/lib/mol-plugin-ui/controls/common.js +10 -10
  727. package/lib/mol-plugin-ui/controls/icons.js +70 -70
  728. package/lib/mol-plugin-ui/controls/legend.js +3 -3
  729. package/lib/mol-plugin-ui/controls/line-graph/line-graph-component.js +1 -1
  730. package/lib/mol-plugin-ui/controls/parameters.js +51 -51
  731. package/lib/mol-plugin-ui/controls/screenshot.js +2 -2
  732. package/lib/mol-plugin-ui/controls/slider.js +5 -5
  733. package/lib/mol-plugin-ui/controls.js +7 -7
  734. package/lib/mol-plugin-ui/custom/volume.js +4 -4
  735. package/lib/mol-plugin-ui/left-panel.d.ts +8 -1
  736. package/lib/mol-plugin-ui/left-panel.js +33 -12
  737. package/lib/mol-plugin-ui/plugin.js +10 -10
  738. package/lib/mol-plugin-ui/sequence/sequence.js +1 -1
  739. package/lib/mol-plugin-ui/sequence.js +5 -5
  740. package/lib/mol-plugin-ui/state/actions.js +1 -1
  741. package/lib/mol-plugin-ui/state/animation.js +1 -1
  742. package/lib/mol-plugin-ui/state/common.js +7 -7
  743. package/lib/mol-plugin-ui/state/snapshots.js +9 -9
  744. package/lib/mol-plugin-ui/state/tree.js +14 -14
  745. package/lib/mol-plugin-ui/state/update-transform.js +1 -1
  746. package/lib/mol-plugin-ui/structure/components.js +10 -10
  747. package/lib/mol-plugin-ui/structure/focus.js +1 -1
  748. package/lib/mol-plugin-ui/structure/generic.js +4 -4
  749. package/lib/mol-plugin-ui/structure/measurements.js +8 -8
  750. package/lib/mol-plugin-ui/structure/quick-styles.js +2 -2
  751. package/lib/mol-plugin-ui/structure/selection.js +7 -7
  752. package/lib/mol-plugin-ui/structure/source.js +4 -4
  753. package/lib/mol-plugin-ui/structure/superposition.js +8 -8
  754. package/lib/mol-plugin-ui/structure/volume.js +4 -4
  755. package/lib/mol-plugin-ui/task.js +5 -5
  756. package/lib/mol-plugin-ui/toast.js +4 -4
  757. package/lib/mol-plugin-ui/viewport/canvas.js +3 -3
  758. package/lib/mol-plugin-ui/viewport/help.js +8 -8
  759. package/lib/mol-plugin-ui/viewport/screenshot.js +3 -3
  760. package/lib/mol-plugin-ui/viewport/simple-settings.js +1 -1
  761. package/lib/mol-plugin-ui/viewport.js +4 -4
  762. package/lib/mol-script/language/parser.js +7 -4
  763. package/lib/mol-task/util/scheduler.d.ts +2 -2
  764. package/lib/mol-task/util/scheduler.js +7 -7
  765. package/lib/mol-theme/color/hydrophobicity.js +2 -2
  766. package/lib/mol-util/data-source.js +2 -1
  767. package/lib/mol-util/file-info.d.ts +1 -3
  768. package/lib/mol-util/file-info.js +2 -10
  769. package/lib/mol-util/index.d.ts +1 -0
  770. package/lib/mol-util/index.js +5 -0
  771. package/lib/mol-util/zip/deflate.js +2 -1
  772. package/lib/mol-util/zip/zip.d.ts +7 -1
  773. package/lib/mol-util/zip/zip.js +5 -1
  774. package/lib/servers/model/config.d.ts +2 -2
  775. package/package.json +16 -16
  776. package/lib/commonjs/mol-plugin-state/formats/structure.js +0 -64
  777. package/lib/mol-plugin-state/formats/structure.js +0 -61
@@ -0,0 +1,168 @@
1
+ /**
2
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ *
4
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
+ */
6
+ import { __awaiter, __generator } from "tslib";
7
+ import { Task } from '../../../mol-task';
8
+ import { Tokenizer, TokenBuilder } from '../common/text/tokenizer';
9
+ import { ReaderResult as Result } from '../result';
10
+ import { TokenColumnProvider as TokenColumn } from '../common/text/column/token';
11
+ import { Column } from '../../../mol-data/db';
12
+ // http://ambermd.org/prmtop.pdf
13
+ // https://ambermd.org/FileFormats.php#topology
14
+ var Pointers = {
15
+ 'NATOM': '', 'NTYPES': '', 'NBONH': '', 'MBONA': '', 'NTHETH': '', 'MTHETA': '',
16
+ 'NPHIH': '', 'MPHIA': '', 'NHPARM': '', 'NPARM': '', 'NNB': '', 'NRES': '',
17
+ 'NBONA': '', 'NTHETA': '', 'NPHIA': '', 'NUMBND': '', 'NUMANG': '', 'NPTRA': '',
18
+ 'NATYP': '', 'NPHB': '', 'IFPERT': '', 'NBPER': '', 'NGPER': '', 'NDPER': '',
19
+ 'MBPER': '', 'MGPER': '', 'MDPER': '', 'IFBOX': '', 'NMXRS': '', 'IFCAP': '',
20
+ 'NUMEXTRA': '', 'NCOPY': '',
21
+ };
22
+ var PointersNames = Object.keys(Pointers);
23
+ var readLine = Tokenizer.readLine, markLine = Tokenizer.markLine, trim = Tokenizer.trim;
24
+ function State(tokenizer, runtimeCtx) {
25
+ return {
26
+ tokenizer: tokenizer,
27
+ runtimeCtx: runtimeCtx,
28
+ };
29
+ }
30
+ function handleTitle(state) {
31
+ var tokenizer = state.tokenizer;
32
+ var title = [];
33
+ while (tokenizer.tokenEnd < tokenizer.length) {
34
+ if (tokenizer.data[tokenizer.position] === '%')
35
+ break;
36
+ var line = readLine(tokenizer).trim();
37
+ if (line)
38
+ title.push(line);
39
+ }
40
+ return title;
41
+ }
42
+ function handlePointers(state) {
43
+ var tokenizer = state.tokenizer;
44
+ var pointers = Object.create(null);
45
+ PointersNames.forEach(function (name) { pointers[name] = 0; });
46
+ var curIdx = 0;
47
+ while (tokenizer.tokenEnd < tokenizer.length) {
48
+ if (tokenizer.data[tokenizer.position] === '%')
49
+ break;
50
+ var line = readLine(tokenizer);
51
+ var n = Math.min(curIdx + 10, 32);
52
+ for (var i = 0; curIdx < n; ++i, ++curIdx) {
53
+ pointers[PointersNames[curIdx]] = parseInt(line.substring(i * 8, i * 8 + 8).trim());
54
+ }
55
+ }
56
+ return pointers;
57
+ }
58
+ function handleTokens(state, count, countPerLine, itemSize) {
59
+ var tokenizer = state.tokenizer;
60
+ var tokens = TokenBuilder.create(tokenizer.data, count * 2);
61
+ var curIdx = 0;
62
+ while (tokenizer.tokenEnd < tokenizer.length) {
63
+ if (tokenizer.data[tokenizer.position] === '%')
64
+ break;
65
+ tokenizer.tokenStart = tokenizer.position;
66
+ var n = Math.min(curIdx + countPerLine, count);
67
+ for (var i = 0; curIdx < n; ++i, ++curIdx) {
68
+ var p = tokenizer.position;
69
+ trim(tokenizer, tokenizer.position, tokenizer.position + itemSize);
70
+ TokenBuilder.addUnchecked(tokens, tokenizer.tokenStart, tokenizer.tokenEnd);
71
+ tokenizer.position = p + itemSize;
72
+ }
73
+ markLine(tokenizer);
74
+ }
75
+ return tokens;
76
+ }
77
+ function parseInternal(data, ctx) {
78
+ return __awaiter(this, void 0, void 0, function () {
79
+ var t, state, result, prevPosition, line, flag, formatLine, tokens, tokens, tokens, tokens, tokens, tokens, tokens, tokens;
80
+ return __generator(this, function (_a) {
81
+ switch (_a.label) {
82
+ case 0:
83
+ t = Tokenizer(data);
84
+ state = State(t, ctx);
85
+ result = Object.create(null);
86
+ prevPosition = 0;
87
+ _a.label = 1;
88
+ case 1:
89
+ if (!(t.tokenEnd < t.length)) return [3 /*break*/, 4];
90
+ if (!(t.position - prevPosition > 100000 && ctx.shouldUpdate)) return [3 /*break*/, 3];
91
+ prevPosition = t.position;
92
+ return [4 /*yield*/, ctx.update({ current: t.position, max: t.length })];
93
+ case 2:
94
+ _a.sent();
95
+ _a.label = 3;
96
+ case 3:
97
+ line = readLine(state.tokenizer).trim();
98
+ if (line.startsWith('%VERSION')) {
99
+ result.version = line.substring(8).trim();
100
+ }
101
+ else if (line.startsWith('%FLAG')) {
102
+ flag = line.substring(5).trim();
103
+ formatLine = readLine(state.tokenizer).trim();
104
+ if (!formatLine.startsWith('%FORMAT'))
105
+ throw new Error('expected %FORMAT');
106
+ if (flag === 'TITLE') {
107
+ result.title = handleTitle(state);
108
+ }
109
+ else if (flag === 'POINTERS') {
110
+ result.pointers = handlePointers(state);
111
+ }
112
+ else if (flag === 'ATOM_NAME') {
113
+ tokens = handleTokens(state, result.pointers['NATOM'], 20, 4);
114
+ result.atomName = TokenColumn(tokens)(Column.Schema.str);
115
+ }
116
+ else if (flag === 'CHARGE') {
117
+ tokens = handleTokens(state, result.pointers['NATOM'], 5, 16);
118
+ result.charge = TokenColumn(tokens)(Column.Schema.float);
119
+ }
120
+ else if (flag === 'MASS') {
121
+ tokens = handleTokens(state, result.pointers['NATOM'], 5, 16);
122
+ result.mass = TokenColumn(tokens)(Column.Schema.float);
123
+ }
124
+ else if (flag === 'RESIDUE_LABEL') {
125
+ tokens = handleTokens(state, result.pointers['NRES'], 20, 4);
126
+ result.residueLabel = TokenColumn(tokens)(Column.Schema.str);
127
+ }
128
+ else if (flag === 'RESIDUE_POINTER') {
129
+ tokens = handleTokens(state, result.pointers['NRES'], 10, 8);
130
+ result.residuePointer = TokenColumn(tokens)(Column.Schema.int);
131
+ }
132
+ else if (flag === 'BONDS_INC_HYDROGEN') {
133
+ tokens = handleTokens(state, result.pointers['NBONH'] * 3, 10, 8);
134
+ result.bondsIncHydrogen = TokenColumn(tokens)(Column.Schema.int);
135
+ }
136
+ else if (flag === 'BONDS_WITHOUT_HYDROGEN') {
137
+ tokens = handleTokens(state, result.pointers['NBONA'] * 3, 10, 8);
138
+ result.bondsWithoutHydrogen = TokenColumn(tokens)(Column.Schema.int);
139
+ }
140
+ else if (flag === 'RADII') {
141
+ tokens = handleTokens(state, result.pointers['NATOM'], 5, 16);
142
+ result.radii = TokenColumn(tokens)(Column.Schema.float);
143
+ }
144
+ else {
145
+ while (t.tokenEnd < t.length) {
146
+ if (t.data[t.position] === '%')
147
+ break;
148
+ markLine(t);
149
+ }
150
+ }
151
+ }
152
+ return [3 /*break*/, 1];
153
+ case 4: return [2 /*return*/, Result.success(result)];
154
+ }
155
+ });
156
+ });
157
+ }
158
+ export function parsePrmtop(data) {
159
+ var _this = this;
160
+ return Task.create('Parse PRMTOP', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
161
+ return __generator(this, function (_a) {
162
+ switch (_a.label) {
163
+ case 0: return [4 /*yield*/, parseInternal(data, ctx)];
164
+ case 1: return [2 /*return*/, _a.sent()];
165
+ }
166
+ });
167
+ }); });
168
+ }
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ *
4
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
+ */
6
+ import { Task } from '../../../mol-task';
7
+ import { ReaderResult as Result } from '../result';
8
+ import { Column, Table } from '../../../mol-data/db';
9
+ declare const AtomsSchema: {
10
+ nr: Column.Schema.Int;
11
+ type: Column.Schema.Str;
12
+ resnr: Column.Schema.Int;
13
+ residu: Column.Schema.Str;
14
+ atom: Column.Schema.Str;
15
+ cgnr: Column.Schema.Int;
16
+ charge: Column.Schema.Float;
17
+ mass: Column.Schema.Float;
18
+ };
19
+ declare const BondsSchema: {
20
+ ai: Column.Schema.Int;
21
+ aj: Column.Schema.Int;
22
+ };
23
+ declare const MoleculesSchema: {
24
+ compound: Column.Schema.Str;
25
+ molCount: Column.Schema.Int;
26
+ };
27
+ declare type Compound = {
28
+ atoms: Table<typeof AtomsSchema>;
29
+ bonds?: Table<typeof BondsSchema>;
30
+ };
31
+ export interface TopFile {
32
+ readonly system: string;
33
+ readonly molecules: Table<typeof MoleculesSchema>;
34
+ readonly compounds: Record<string, Compound>;
35
+ }
36
+ export declare function parseTop(data: string): Task<Result<TopFile>>;
37
+ export {};
@@ -0,0 +1,299 @@
1
+ /**
2
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ *
4
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
+ */
6
+ import { __awaiter, __generator } from "tslib";
7
+ import { Task } from '../../../mol-task';
8
+ import { Tokenizer, TokenBuilder } from '../common/text/tokenizer';
9
+ import { ReaderResult as Result } from '../result';
10
+ import { TokenColumnProvider as TokenColumn } from '../common/text/column/token';
11
+ import { Column, Table } from '../../../mol-data/db';
12
+ // https://manual.gromacs.org/2021-current/reference-manual/file-formats.html#top
13
+ var AtomsSchema = {
14
+ nr: Column.Schema.Int(),
15
+ type: Column.Schema.Str(),
16
+ resnr: Column.Schema.Int(),
17
+ residu: Column.Schema.Str(),
18
+ atom: Column.Schema.Str(),
19
+ cgnr: Column.Schema.Int(),
20
+ charge: Column.Schema.Float(),
21
+ mass: Column.Schema.Float(),
22
+ };
23
+ var BondsSchema = {
24
+ ai: Column.Schema.Int(),
25
+ aj: Column.Schema.Int(),
26
+ };
27
+ var MoleculesSchema = {
28
+ compound: Column.Schema.Str(),
29
+ molCount: Column.Schema.Int(),
30
+ };
31
+ var readLine = Tokenizer.readLine, markLine = Tokenizer.markLine, skipWhitespace = Tokenizer.skipWhitespace, markStart = Tokenizer.markStart, eatValue = Tokenizer.eatValue, eatLine = Tokenizer.eatLine;
32
+ function State(tokenizer, runtimeCtx) {
33
+ return {
34
+ tokenizer: tokenizer,
35
+ runtimeCtx: runtimeCtx,
36
+ };
37
+ }
38
+ var reField = /\[ (.+) \]/;
39
+ var reWhitespace = /\s+/;
40
+ function handleMoleculetype(state) {
41
+ var tokenizer = state.tokenizer;
42
+ var molName = undefined;
43
+ while (tokenizer.tokenEnd < tokenizer.length) {
44
+ skipWhitespace(tokenizer);
45
+ var c = tokenizer.data[tokenizer.position];
46
+ if (c === '[')
47
+ break;
48
+ if (c === ';' || c === '*') {
49
+ markLine(tokenizer);
50
+ continue;
51
+ }
52
+ if (molName !== undefined)
53
+ throw new Error('more than one molName');
54
+ var line = readLine(tokenizer);
55
+ molName = line.split(reWhitespace)[0];
56
+ }
57
+ if (molName === undefined)
58
+ throw new Error('missing molName');
59
+ return molName;
60
+ }
61
+ function handleAtoms(state) {
62
+ var tokenizer = state.tokenizer;
63
+ var nr = TokenBuilder.create(tokenizer.data, 64);
64
+ var type = TokenBuilder.create(tokenizer.data, 64);
65
+ var resnr = TokenBuilder.create(tokenizer.data, 64);
66
+ var residu = TokenBuilder.create(tokenizer.data, 64);
67
+ var atom = TokenBuilder.create(tokenizer.data, 64);
68
+ var cgnr = TokenBuilder.create(tokenizer.data, 64);
69
+ var charge = TokenBuilder.create(tokenizer.data, 64);
70
+ var mass = TokenBuilder.create(tokenizer.data, 64);
71
+ while (tokenizer.tokenEnd < tokenizer.length) {
72
+ skipWhitespace(tokenizer);
73
+ var c = tokenizer.data[tokenizer.position];
74
+ if (c === '[')
75
+ break;
76
+ if (c === ';' || c === '*') {
77
+ markLine(tokenizer);
78
+ continue;
79
+ }
80
+ for (var j = 0; j < 8; ++j) {
81
+ skipWhitespace(tokenizer);
82
+ markStart(tokenizer);
83
+ eatValue(tokenizer);
84
+ switch (j) {
85
+ case 0:
86
+ TokenBuilder.add(nr, tokenizer.tokenStart, tokenizer.tokenEnd);
87
+ break;
88
+ case 1:
89
+ TokenBuilder.add(type, tokenizer.tokenStart, tokenizer.tokenEnd);
90
+ break;
91
+ case 2:
92
+ TokenBuilder.add(resnr, tokenizer.tokenStart, tokenizer.tokenEnd);
93
+ break;
94
+ case 3:
95
+ TokenBuilder.add(residu, tokenizer.tokenStart, tokenizer.tokenEnd);
96
+ break;
97
+ case 4:
98
+ TokenBuilder.add(atom, tokenizer.tokenStart, tokenizer.tokenEnd);
99
+ break;
100
+ case 5:
101
+ TokenBuilder.add(cgnr, tokenizer.tokenStart, tokenizer.tokenEnd);
102
+ break;
103
+ case 6:
104
+ TokenBuilder.add(charge, tokenizer.tokenStart, tokenizer.tokenEnd);
105
+ break;
106
+ case 7:
107
+ TokenBuilder.add(mass, tokenizer.tokenStart, tokenizer.tokenEnd);
108
+ break;
109
+ }
110
+ }
111
+ // ignore any extra columns
112
+ markLine(tokenizer);
113
+ }
114
+ return Table.ofColumns(AtomsSchema, {
115
+ nr: TokenColumn(nr)(Column.Schema.int),
116
+ type: TokenColumn(type)(Column.Schema.str),
117
+ resnr: TokenColumn(resnr)(Column.Schema.int),
118
+ residu: TokenColumn(residu)(Column.Schema.str),
119
+ atom: TokenColumn(atom)(Column.Schema.str),
120
+ cgnr: TokenColumn(cgnr)(Column.Schema.int),
121
+ charge: TokenColumn(charge)(Column.Schema.float),
122
+ mass: TokenColumn(mass)(Column.Schema.float),
123
+ });
124
+ }
125
+ function handleBonds(state) {
126
+ var tokenizer = state.tokenizer;
127
+ var ai = TokenBuilder.create(tokenizer.data, 64);
128
+ var aj = TokenBuilder.create(tokenizer.data, 64);
129
+ while (tokenizer.tokenEnd < tokenizer.length) {
130
+ skipWhitespace(tokenizer);
131
+ var c = tokenizer.data[tokenizer.position];
132
+ if (c === '[')
133
+ break;
134
+ if (c === ';' || c === '*') {
135
+ markLine(tokenizer);
136
+ continue;
137
+ }
138
+ for (var j = 0; j < 2; ++j) {
139
+ skipWhitespace(tokenizer);
140
+ markStart(tokenizer);
141
+ eatValue(tokenizer);
142
+ switch (j) {
143
+ case 0:
144
+ TokenBuilder.add(ai, tokenizer.tokenStart, tokenizer.tokenEnd);
145
+ break;
146
+ case 1:
147
+ TokenBuilder.add(aj, tokenizer.tokenStart, tokenizer.tokenEnd);
148
+ break;
149
+ }
150
+ }
151
+ // ignore any extra columns
152
+ markLine(tokenizer);
153
+ }
154
+ return Table.ofColumns(BondsSchema, {
155
+ ai: TokenColumn(ai)(Column.Schema.int),
156
+ aj: TokenColumn(aj)(Column.Schema.int),
157
+ });
158
+ }
159
+ function handleSystem(state) {
160
+ var tokenizer = state.tokenizer;
161
+ var system = undefined;
162
+ while (tokenizer.tokenEnd < tokenizer.length) {
163
+ skipWhitespace(tokenizer);
164
+ var c = tokenizer.data[tokenizer.position];
165
+ if (c === '[')
166
+ break;
167
+ if (c === ';' || c === '*') {
168
+ markLine(tokenizer);
169
+ continue;
170
+ }
171
+ if (system !== undefined)
172
+ throw new Error('more than one system');
173
+ system = readLine(tokenizer).trim();
174
+ }
175
+ if (system === undefined)
176
+ throw new Error('missing system');
177
+ return system;
178
+ }
179
+ function handleMolecules(state) {
180
+ var tokenizer = state.tokenizer;
181
+ var compound = TokenBuilder.create(tokenizer.data, 64);
182
+ var molCount = TokenBuilder.create(tokenizer.data, 64);
183
+ while (tokenizer.tokenEnd < tokenizer.length) {
184
+ skipWhitespace(tokenizer);
185
+ if (tokenizer.position >= tokenizer.length)
186
+ break;
187
+ var c = tokenizer.data[tokenizer.position];
188
+ if (c === '[')
189
+ break;
190
+ if (c === ';' || c === '*') {
191
+ markLine(tokenizer);
192
+ continue;
193
+ }
194
+ for (var j = 0; j < 2; ++j) {
195
+ skipWhitespace(tokenizer);
196
+ markStart(tokenizer);
197
+ eatValue(tokenizer);
198
+ switch (j) {
199
+ case 0:
200
+ TokenBuilder.add(compound, tokenizer.tokenStart, tokenizer.tokenEnd);
201
+ break;
202
+ case 1:
203
+ TokenBuilder.add(molCount, tokenizer.tokenStart, tokenizer.tokenEnd);
204
+ break;
205
+ }
206
+ }
207
+ // ignore any extra columns
208
+ eatLine(tokenizer);
209
+ markStart(tokenizer);
210
+ }
211
+ return Table.ofColumns(MoleculesSchema, {
212
+ compound: TokenColumn(compound)(Column.Schema.str),
213
+ molCount: TokenColumn(molCount)(Column.Schema.int),
214
+ });
215
+ }
216
+ function parseInternal(data, ctx) {
217
+ return __awaiter(this, void 0, void 0, function () {
218
+ function addMol() {
219
+ if (currentMolName && currentCompound.atoms) {
220
+ result.compounds[currentMolName] = currentCompound;
221
+ currentCompound = {};
222
+ currentMolName = '';
223
+ }
224
+ }
225
+ var t, state, result, prevPosition, currentCompound, currentMolName, line, fieldMatch, fieldName;
226
+ return __generator(this, function (_a) {
227
+ switch (_a.label) {
228
+ case 0:
229
+ t = Tokenizer(data);
230
+ state = State(t, ctx);
231
+ result = Object.create(null);
232
+ prevPosition = 0;
233
+ result.compounds = {};
234
+ currentCompound = {};
235
+ currentMolName = '';
236
+ _a.label = 1;
237
+ case 1:
238
+ if (!(t.tokenEnd < t.length)) return [3 /*break*/, 4];
239
+ if (!(t.position - prevPosition > 100000 && ctx.shouldUpdate)) return [3 /*break*/, 3];
240
+ prevPosition = t.position;
241
+ return [4 /*yield*/, ctx.update({ current: t.position, max: t.length })];
242
+ case 2:
243
+ _a.sent();
244
+ _a.label = 3;
245
+ case 3:
246
+ line = readLine(state.tokenizer).trim();
247
+ if (!line || line[0] === '*' || line[0] === ';') {
248
+ return [3 /*break*/, 1];
249
+ }
250
+ if (line.startsWith('#include')) {
251
+ throw new Error('#include statements not allowed');
252
+ }
253
+ if (line.startsWith('[')) {
254
+ fieldMatch = line.match(reField);
255
+ if (fieldMatch === null)
256
+ throw new Error('expected field name');
257
+ fieldName = fieldMatch[1];
258
+ if (fieldName === 'moleculetype') {
259
+ addMol();
260
+ currentMolName = handleMoleculetype(state);
261
+ }
262
+ else if (fieldName === 'atoms') {
263
+ currentCompound.atoms = handleAtoms(state);
264
+ }
265
+ else if (fieldName === 'bonds') {
266
+ currentCompound.bonds = handleBonds(state);
267
+ }
268
+ else if (fieldName === 'system') {
269
+ result.system = handleSystem(state);
270
+ }
271
+ else if (fieldName === 'molecules') {
272
+ addMol(); // add the last compound
273
+ result.molecules = handleMolecules(state);
274
+ }
275
+ else {
276
+ while (t.tokenEnd < t.length) {
277
+ if (t.data[t.position] === '[')
278
+ break;
279
+ markLine(t);
280
+ }
281
+ }
282
+ }
283
+ return [3 /*break*/, 1];
284
+ case 4: return [2 /*return*/, Result.success(result)];
285
+ }
286
+ });
287
+ });
288
+ }
289
+ export function parseTop(data) {
290
+ var _this = this;
291
+ return Task.create('Parse TOP', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
292
+ return __generator(this, function (_a) {
293
+ switch (_a.label) {
294
+ case 0: return [4 /*yield*/, parseInternal(data, ctx)];
295
+ case 1: return [2 /*return*/, _a.sent()];
296
+ }
297
+ });
298
+ }); });
299
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ *
4
+ * Adapted from NGL.
5
+ *
6
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
7
+ */
8
+ import { Task } from '../../../mol-task';
9
+ import { ReaderResult as Result } from '../result';
10
+ export interface TrrFile {
11
+ frames: {
12
+ count: number;
13
+ x: Float32Array;
14
+ y: Float32Array;
15
+ z: Float32Array;
16
+ }[];
17
+ boxes: number[][];
18
+ times: number[];
19
+ timeOffset: number;
20
+ deltaTime: number;
21
+ }
22
+ export declare function parseTrr(data: Uint8Array): Task<Result<TrrFile>>;
@@ -0,0 +1,142 @@
1
+ /**
2
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ *
4
+ * Adapted from NGL.
5
+ *
6
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
7
+ */
8
+ import { __awaiter, __generator } from "tslib";
9
+ import { Task } from '../../../mol-task';
10
+ import { ReaderResult as Result } from '../result';
11
+ function parseInternal(data) {
12
+ return __awaiter(this, void 0, void 0, function () {
13
+ var dv, f, coordinates, boxes, times, offset, versionSize, boxSize, virSize, presSize, coordSize, velocitySize, forceSize, natoms, floatSize, natoms3, box, i, i, x, y, z, i, tmp, i, value, frameCoords, i;
14
+ return __generator(this, function (_a) {
15
+ dv = new DataView(data.buffer);
16
+ f = {
17
+ frames: [],
18
+ boxes: [],
19
+ times: [],
20
+ timeOffset: 0,
21
+ deltaTime: 0
22
+ };
23
+ coordinates = f.frames;
24
+ boxes = f.boxes;
25
+ times = f.times;
26
+ offset = 0;
27
+ while (true) {
28
+ // const magicnum = dv.getInt32(offset)
29
+ // const i1 = dv.getFloat32(offset + 4)
30
+ offset += 8;
31
+ versionSize = dv.getInt32(offset);
32
+ offset += 4;
33
+ offset += versionSize;
34
+ boxSize = dv.getInt32(offset + 8);
35
+ virSize = dv.getInt32(offset + 12);
36
+ presSize = dv.getInt32(offset + 16);
37
+ coordSize = dv.getInt32(offset + 28);
38
+ velocitySize = dv.getInt32(offset + 32);
39
+ forceSize = dv.getInt32(offset + 36);
40
+ natoms = dv.getInt32(offset + 40);
41
+ // const step = dv.getInt32(offset + 44)
42
+ // const nre = dv.getInt32(offset + 48)
43
+ offset += 52;
44
+ floatSize = boxSize / 9;
45
+ natoms3 = natoms * 3;
46
+ // let lambda
47
+ if (floatSize === 8) {
48
+ times.push(dv.getFloat64(offset));
49
+ // lambda = dv.getFloat64(offset + 8)
50
+ }
51
+ else {
52
+ times.push(dv.getFloat32(offset));
53
+ // lambda = dv.getFloat32(offset + 4)
54
+ }
55
+ offset += 2 * floatSize;
56
+ if (boxSize) {
57
+ box = new Float32Array(9);
58
+ if (floatSize === 8) {
59
+ for (i = 0; i < 9; ++i) {
60
+ box[i] = dv.getFloat64(offset) * 10;
61
+ offset += 8;
62
+ }
63
+ }
64
+ else {
65
+ for (i = 0; i < 9; ++i) {
66
+ box[i] = dv.getFloat32(offset) * 10;
67
+ offset += 4;
68
+ }
69
+ }
70
+ boxes.push(box);
71
+ }
72
+ // ignore, unused
73
+ offset += virSize;
74
+ // ignore, unused
75
+ offset += presSize;
76
+ if (coordSize) {
77
+ x = new Float32Array(natoms);
78
+ y = new Float32Array(natoms);
79
+ z = new Float32Array(natoms);
80
+ if (floatSize === 8) {
81
+ for (i = 0; i < natoms; ++i) {
82
+ x[i] = dv.getFloat64(offset) * 10;
83
+ y[i] = dv.getFloat64(offset + 8) * 10;
84
+ z[i] = dv.getFloat64(offset + 16) * 10;
85
+ offset += 24;
86
+ }
87
+ }
88
+ else {
89
+ tmp = new Uint32Array(data.buffer, offset, natoms3);
90
+ for (i = 0; i < natoms3; ++i) {
91
+ value = tmp[i];
92
+ tmp[i] = (((value & 0xFF) << 24) | ((value & 0xFF00) << 8) |
93
+ ((value >> 8) & 0xFF00) | ((value >> 24) & 0xFF));
94
+ }
95
+ frameCoords = new Float32Array(data.buffer, offset, natoms3);
96
+ for (i = 0; i < natoms; ++i) {
97
+ x[i] = frameCoords[i * 3] * 10;
98
+ y[i] = frameCoords[i * 3 + 1] * 10;
99
+ z[i] = frameCoords[i * 3 + 2] * 10;
100
+ offset += 12;
101
+ }
102
+ }
103
+ coordinates.push({ count: natoms, x: x, y: y, z: z });
104
+ }
105
+ // ignore, unused
106
+ offset += velocitySize;
107
+ // ignore, unused
108
+ offset += forceSize;
109
+ if (offset >= data.byteLength)
110
+ break;
111
+ }
112
+ if (times.length >= 1) {
113
+ f.timeOffset = times[0];
114
+ }
115
+ if (times.length >= 2) {
116
+ f.deltaTime = times[1] - times[0];
117
+ }
118
+ return [2 /*return*/, f];
119
+ });
120
+ });
121
+ }
122
+ export function parseTrr(data) {
123
+ var _this = this;
124
+ return Task.create('Parse TRR', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
125
+ var file, e_1;
126
+ return __generator(this, function (_a) {
127
+ switch (_a.label) {
128
+ case 0:
129
+ _a.trys.push([0, 2, , 3]);
130
+ ctx.update({ canAbort: true, message: 'Parsing trajectory...' });
131
+ return [4 /*yield*/, parseInternal(data)];
132
+ case 1:
133
+ file = _a.sent();
134
+ return [2 /*return*/, Result.success(file)];
135
+ case 2:
136
+ e_1 = _a.sent();
137
+ return [2 /*return*/, Result.error('' + e_1)];
138
+ case 3: return [2 /*return*/];
139
+ }
140
+ });
141
+ }); });
142
+ }
@@ -7,6 +7,7 @@
7
7
  import { __spreadArray } from "tslib";
8
8
  import { Iterator } from '../../../mol-data/iterator';
9
9
  import { ArrayEncoding } from '../../common/binary-cif';
10
+ import { assertUnreachable } from '../../../mol-util/type-helpers';
10
11
  export var Field;
11
12
  (function (Field) {
12
13
  function str(name, value, params) {
@@ -259,7 +260,7 @@ function cifFieldsFromTableSchema(schema) {
259
260
  fields.push.apply(fields, getTensorDefinitions(k, t.space));
260
261
  }
261
262
  else {
262
- throw new Error("Unknown valueType ".concat(t.valueType));
263
+ assertUnreachable(t.valueType);
263
264
  }
264
265
  }
265
266
  return fields;