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,144 @@
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 { Column, Table } from '../../mol-data/db';
8
+ import { getMoleculeType } from '../../mol-model/structure/model/types';
9
+ import { Topology } from '../../mol-model/structure/topology/topology';
10
+ import { Task } from '../../mol-task';
11
+ import { BasicSchema, createBasic } from './basic/schema';
12
+ import { ComponentBuilder } from './common/component';
13
+ import { EntityBuilder } from './common/entity';
14
+ import { getChainId } from './common/util';
15
+ import { guessElementSymbolString } from './util';
16
+ function getBasic(prmtop) {
17
+ var pointers = prmtop.pointers, residuePointer = prmtop.residuePointer, residueLabel = prmtop.residueLabel, atomName = prmtop.atomName;
18
+ var atomCount = pointers.NATOM;
19
+ var residueCount = pointers.NRES;
20
+ //
21
+ var residueIds = new Uint32Array(atomCount);
22
+ var residueNames = [];
23
+ var addResidue = function (i, from, to) {
24
+ var rn = residueLabel.value(i);
25
+ for (var j = from, jl = to; j < jl; ++j) {
26
+ residueIds[j] = i + 1;
27
+ residueNames[j] = rn;
28
+ }
29
+ };
30
+ for (var i = 0, il = residueCount - 1; i < il; ++i) {
31
+ addResidue(i, residuePointer.value(i) - 1, residuePointer.value(i + 1) - 1);
32
+ }
33
+ addResidue(residueCount - 1, residuePointer.value(residueCount - 1) - 1, atomCount);
34
+ var residueId = Column.ofIntArray(residueIds);
35
+ var residueName = Column.ofStringArray(residueNames);
36
+ //
37
+ var entityIds = new Array(atomCount);
38
+ var asymIds = new Array(atomCount);
39
+ var seqIds = new Uint32Array(atomCount);
40
+ var ids = new Uint32Array(atomCount);
41
+ var entityBuilder = new EntityBuilder();
42
+ var componentBuilder = new ComponentBuilder(residueId, atomName);
43
+ var currentEntityId = '';
44
+ var currentAsymIndex = 0;
45
+ var currentAsymId = '';
46
+ var currentSeqId = 0;
47
+ var prevMoleculeType = 0 /* Unknown */;
48
+ var prevResidueNumber = -1;
49
+ for (var i = 0, il = atomCount; i < il; ++i) {
50
+ var residueNumber = residueId.value(i);
51
+ if (residueNumber !== prevResidueNumber) {
52
+ var compId = residueName.value(i);
53
+ var moleculeType = getMoleculeType(componentBuilder.add(compId, i).type, compId);
54
+ if (moleculeType !== prevMoleculeType) {
55
+ currentAsymId = getChainId(currentAsymIndex);
56
+ currentAsymIndex += 1;
57
+ currentSeqId = 0;
58
+ }
59
+ currentEntityId = entityBuilder.getEntityId(compId, moleculeType, currentAsymId);
60
+ currentSeqId += 1;
61
+ prevResidueNumber = residueNumber;
62
+ prevMoleculeType = moleculeType;
63
+ }
64
+ entityIds[i] = currentEntityId;
65
+ asymIds[i] = currentAsymId;
66
+ seqIds[i] = currentSeqId;
67
+ ids[i] = i;
68
+ }
69
+ var id = Column.ofIntArray(ids);
70
+ var asym_id = Column.ofStringArray(asymIds);
71
+ //
72
+ var type_symbol = new Array(atomCount);
73
+ for (var i = 0; i < atomCount; ++i) {
74
+ type_symbol[i] = guessElementSymbolString(atomName.value(i), residueName.value(i));
75
+ }
76
+ var atom_site = Table.ofPartialColumns(BasicSchema.atom_site, {
77
+ auth_asym_id: asym_id,
78
+ auth_atom_id: Column.asArrayColumn(atomName),
79
+ auth_comp_id: residueName,
80
+ auth_seq_id: residueId,
81
+ id: Column.asArrayColumn(id),
82
+ label_asym_id: asym_id,
83
+ label_atom_id: Column.asArrayColumn(atomName),
84
+ label_comp_id: residueName,
85
+ label_seq_id: Column.ofIntArray(seqIds),
86
+ label_entity_id: Column.ofStringArray(entityIds),
87
+ occupancy: Column.ofConst(1, atomCount, Column.Schema.float),
88
+ type_symbol: Column.ofStringArray(type_symbol),
89
+ pdbx_PDB_model_num: Column.ofConst(1, atomCount, Column.Schema.int),
90
+ }, atomCount);
91
+ var basic = createBasic({
92
+ entity: entityBuilder.getEntityTable(),
93
+ chem_comp: componentBuilder.getChemCompTable(),
94
+ atom_site: atom_site
95
+ });
96
+ return basic;
97
+ }
98
+ //
99
+ export { PrmtopFormat };
100
+ var PrmtopFormat;
101
+ (function (PrmtopFormat) {
102
+ function is(x) {
103
+ return (x === null || x === void 0 ? void 0 : x.kind) === 'prmtop';
104
+ }
105
+ PrmtopFormat.is = is;
106
+ function fromPrmtop(prmtop) {
107
+ return { kind: 'prmtop', name: prmtop.title.join(' ') || 'PRMTOP', data: prmtop };
108
+ }
109
+ PrmtopFormat.fromPrmtop = fromPrmtop;
110
+ })(PrmtopFormat || (PrmtopFormat = {}));
111
+ export function topologyFromPrmtop(prmtop) {
112
+ var _this = this;
113
+ return Task.create('Parse PRMTOP', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
114
+ var format, basic, _a, NBONH, NBONA, bondsIncHydrogen, bondsWithoutHydrogen, bondCount, bonds;
115
+ return __generator(this, function (_b) {
116
+ format = PrmtopFormat.fromPrmtop(prmtop);
117
+ basic = getBasic(prmtop);
118
+ _a = prmtop.pointers, NBONH = _a.NBONH, NBONA = _a.NBONA, bondsIncHydrogen = prmtop.bondsIncHydrogen, bondsWithoutHydrogen = prmtop.bondsWithoutHydrogen;
119
+ bondCount = NBONH + NBONA;
120
+ bonds = {
121
+ indexA: Column.ofLambda({
122
+ value: function (row) {
123
+ return row < NBONH
124
+ ? bondsIncHydrogen.value(row * 3) / 3
125
+ : bondsWithoutHydrogen.value((row - NBONH) * 3) / 3;
126
+ },
127
+ rowCount: bondCount,
128
+ schema: Column.Schema.int,
129
+ }),
130
+ indexB: Column.ofLambda({
131
+ value: function (row) {
132
+ return row < NBONH
133
+ ? bondsIncHydrogen.value(row * 3 + 1) / 3
134
+ : bondsWithoutHydrogen.value((row - NBONH) * 3 + 1) / 3;
135
+ },
136
+ rowCount: bondCount,
137
+ schema: Column.Schema.int,
138
+ }),
139
+ order: Column.ofConst(1, bondCount, Column.Schema.int)
140
+ };
141
+ return [2 /*return*/, Topology.create(prmtop.title.join(' ') || 'PRMTOP', basic, bonds, format)];
142
+ });
143
+ }); });
144
+ }
@@ -48,8 +48,18 @@ function getSpacegroupNameOrNumber(symmetry) {
48
48
  function getSpacegroup(symmetry, cell) {
49
49
  if (symmetry._rowCount === 0 || cell._rowCount === 0)
50
50
  return Spacegroup.ZeroP1;
51
+ var a = cell.length_a.value(0);
52
+ var b = cell.length_b.value(0);
53
+ var c = cell.length_c.value(0);
54
+ if (a === 0 || b === 0 || c === 0)
55
+ return Spacegroup.ZeroP1;
56
+ var alpha = cell.angle_alpha.value(0);
57
+ var beta = cell.angle_beta.value(0);
58
+ var gamma = cell.angle_gamma.value(0);
59
+ if (alpha === 0 || beta === 0 || gamma === 0)
60
+ return Spacegroup.ZeroP1;
51
61
  var nameOrNumber = getSpacegroupNameOrNumber(symmetry);
52
- var spaceCell = SpacegroupCell.create(nameOrNumber, Vec3.create(cell.length_a.value(0), cell.length_b.value(0), cell.length_c.value(0)), Vec3.scale(Vec3.zero(), Vec3.create(cell.angle_alpha.value(0), cell.angle_beta.value(0), cell.angle_gamma.value(0)), Math.PI / 180));
62
+ var spaceCell = SpacegroupCell.create(nameOrNumber, Vec3.create(a, b, c), Vec3.scale(Vec3(), Vec3.create(alpha, beta, gamma), Math.PI / 180));
53
63
  return Spacegroup.create(spaceCell);
54
64
  }
55
65
  function getNcsOperators(struct_ncs_oper) {
@@ -18,6 +18,7 @@ function getBasic(atoms) {
18
18
  var asymIds = new Array(atoms.count);
19
19
  var seqIds = new Uint32Array(atoms.count);
20
20
  var ids = new Uint32Array(atoms.count);
21
+ var typeSymbol = new Array(atoms.count);
21
22
  var entityBuilder = new EntityBuilder();
22
23
  var componentBuilder = new ComponentBuilder(atoms.residueId, atoms.atomName);
23
24
  var currentEntityId = '';
@@ -57,6 +58,7 @@ function getBasic(atoms) {
57
58
  asymIds[i] = currentAsymId;
58
59
  seqIds[i] = currentSeqId;
59
60
  ids[i] = i;
61
+ typeSymbol[i] = guessElementSymbolString(atoms.atomName.value(i), atoms.residueName.value(i));
60
62
  }
61
63
  var atom_site = Table.ofPartialColumns(BasicSchema.atom_site, {
62
64
  auth_asym_id: atoms.segmentName,
@@ -70,7 +72,7 @@ function getBasic(atoms) {
70
72
  label_seq_id: Column.ofIntArray(seqIds),
71
73
  label_entity_id: Column.ofStringArray(entityIds),
72
74
  occupancy: Column.ofConst(1, atoms.count, Column.Schema.float),
73
- type_symbol: Column.ofStringArray(Column.mapToArray(atoms.atomName, function (s) { return guessElementSymbolString(s); })),
75
+ type_symbol: Column.ofStringArray(typeSymbol),
74
76
  pdbx_PDB_model_num: Column.ofConst(1, atoms.count, Column.Schema.int),
75
77
  }, atoms.count);
76
78
  return createBasic({
@@ -0,0 +1,16 @@
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 { TopFile } from '../../mol-io/reader/top/parser';
7
+ import { Topology } from '../../mol-model/structure/topology/topology';
8
+ import { Task } from '../../mol-task';
9
+ import { ModelFormat } from '../format';
10
+ export { TopFormat };
11
+ declare type TopFormat = ModelFormat<TopFile>;
12
+ declare namespace TopFormat {
13
+ function is(x?: ModelFormat): x is TopFormat;
14
+ function fromTop(top: TopFile): TopFormat;
15
+ }
16
+ export declare function topologyFromTop(top: TopFile): Task<Topology>;
@@ -0,0 +1,186 @@
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 { Column, Table } from '../../mol-data/db';
8
+ import { getMoleculeType } from '../../mol-model/structure/model/types';
9
+ import { Topology } from '../../mol-model/structure/topology/topology';
10
+ import { Task } from '../../mol-task';
11
+ import { BasicSchema, createBasic } from './basic/schema';
12
+ import { ComponentBuilder } from './common/component';
13
+ import { EntityBuilder } from './common/entity';
14
+ import { getChainId } from './common/util';
15
+ import { guessElementSymbolString } from './util';
16
+ function getBasic(top) {
17
+ var molecules = top.molecules, compounds = top.compounds;
18
+ var singleResidue = {};
19
+ var atomCount = 0;
20
+ for (var i = 0, il = molecules._rowCount; i < il; ++i) {
21
+ var mol = molecules.compound.value(i);
22
+ var count = molecules.molCount.value(i);
23
+ var atoms = compounds[mol].atoms;
24
+ Column.asArrayColumn(atoms.atom);
25
+ Column.asArrayColumn(atoms.resnr);
26
+ Column.asArrayColumn(atoms.residu);
27
+ atomCount += count * atoms._rowCount;
28
+ var prevResnr = atoms.resnr.value(0);
29
+ singleResidue[mol] = true;
30
+ for (var j = 1, jl = atoms._rowCount; j < jl; ++j) {
31
+ var resnr = atoms.resnr.value(j);
32
+ if (resnr !== prevResnr) {
33
+ singleResidue[mol] = false;
34
+ break;
35
+ }
36
+ prevResnr = resnr;
37
+ }
38
+ }
39
+ //
40
+ var atomNames = new Array(atomCount);
41
+ var residueIds = new Uint32Array(atomCount);
42
+ var residueNames = new Array(atomCount);
43
+ var k = 0;
44
+ for (var i = 0, il = molecules._rowCount; i < il; ++i) {
45
+ var mol = molecules.compound.value(i);
46
+ var count = molecules.molCount.value(i);
47
+ var atoms = compounds[mol].atoms;
48
+ var isSingleResidue = singleResidue[mol];
49
+ for (var j = 0; j < count; ++j) {
50
+ for (var l = 0, ll = atoms._rowCount; l < ll; ++l) {
51
+ atomNames[k] = atoms.atom.value(l);
52
+ residueIds[k] = atoms.resnr.value(l);
53
+ residueNames[k] = atoms.residu.value(l);
54
+ if (isSingleResidue)
55
+ residueIds[k] += j;
56
+ k += 1;
57
+ }
58
+ }
59
+ }
60
+ var atomName = Column.ofStringArray(atomNames);
61
+ var residueId = Column.ofIntArray(residueIds);
62
+ var residueName = Column.ofStringArray(residueNames);
63
+ //
64
+ var entityIds = new Array(atomCount);
65
+ var asymIds = new Array(atomCount);
66
+ var seqIds = new Uint32Array(atomCount);
67
+ var ids = new Uint32Array(atomCount);
68
+ var entityBuilder = new EntityBuilder();
69
+ var componentBuilder = new ComponentBuilder(residueId, atomName);
70
+ var currentEntityId = '';
71
+ var currentAsymIndex = 0;
72
+ var currentAsymId = '';
73
+ var currentSeqId = 0;
74
+ var prevMoleculeType = 0 /* Unknown */;
75
+ var prevResidueNumber = -1;
76
+ for (var i = 0, il = atomCount; i < il; ++i) {
77
+ var residueNumber = residueId.value(i);
78
+ if (residueNumber !== prevResidueNumber) {
79
+ var compId = residueName.value(i);
80
+ var moleculeType = getMoleculeType(componentBuilder.add(compId, i).type, compId);
81
+ if (moleculeType !== prevMoleculeType) {
82
+ currentAsymId = getChainId(currentAsymIndex);
83
+ currentAsymIndex += 1;
84
+ currentSeqId = 0;
85
+ }
86
+ currentEntityId = entityBuilder.getEntityId(compId, moleculeType, currentAsymId);
87
+ currentSeqId += 1;
88
+ prevResidueNumber = residueNumber;
89
+ prevMoleculeType = moleculeType;
90
+ }
91
+ entityIds[i] = currentEntityId;
92
+ asymIds[i] = currentAsymId;
93
+ seqIds[i] = currentSeqId;
94
+ ids[i] = i;
95
+ }
96
+ var id = Column.ofIntArray(ids);
97
+ var asym_id = Column.ofStringArray(asymIds);
98
+ //
99
+ var type_symbol = new Array(atomCount);
100
+ for (var i = 0; i < atomCount; ++i) {
101
+ type_symbol[i] = guessElementSymbolString(atomName.value(i), residueName.value(i));
102
+ }
103
+ var atom_site = Table.ofPartialColumns(BasicSchema.atom_site, {
104
+ auth_asym_id: asym_id,
105
+ auth_atom_id: Column.asArrayColumn(atomName),
106
+ auth_comp_id: residueName,
107
+ auth_seq_id: residueId,
108
+ id: Column.asArrayColumn(id),
109
+ label_asym_id: asym_id,
110
+ label_atom_id: Column.asArrayColumn(atomName),
111
+ label_comp_id: residueName,
112
+ label_seq_id: Column.ofIntArray(seqIds),
113
+ label_entity_id: Column.ofStringArray(entityIds),
114
+ occupancy: Column.ofConst(1, atomCount, Column.Schema.float),
115
+ type_symbol: Column.ofStringArray(type_symbol),
116
+ pdbx_PDB_model_num: Column.ofConst(1, atomCount, Column.Schema.int),
117
+ }, atomCount);
118
+ var basic = createBasic({
119
+ entity: entityBuilder.getEntityTable(),
120
+ chem_comp: componentBuilder.getChemCompTable(),
121
+ atom_site: atom_site
122
+ });
123
+ return basic;
124
+ }
125
+ function getBonds(top) {
126
+ var molecules = top.molecules, compounds = top.compounds;
127
+ var indexA = [];
128
+ var indexB = [];
129
+ var atomOffset = 0;
130
+ for (var i = 0, il = molecules._rowCount; i < il; ++i) {
131
+ var mol = molecules.compound.value(i);
132
+ var count = molecules.molCount.value(i);
133
+ var _a = compounds[mol], atoms = _a.atoms, bonds = _a.bonds;
134
+ if (bonds) {
135
+ for (var j = 0; j < count; ++j) {
136
+ for (var l = 0, ll = bonds._rowCount; l < ll; ++l) {
137
+ indexA.push(bonds.ai.value(l) - 1 + atomOffset);
138
+ indexB.push(bonds.aj.value(l) - 1 + atomOffset);
139
+ }
140
+ atomOffset += atoms._rowCount;
141
+ }
142
+ }
143
+ else if (mol === 'TIP3') {
144
+ for (var j = 0; j < count; ++j) {
145
+ indexA.push(0 + atomOffset);
146
+ indexB.push(1 + atomOffset);
147
+ indexA.push(0 + atomOffset);
148
+ indexB.push(2 + atomOffset);
149
+ atomOffset += atoms._rowCount;
150
+ }
151
+ }
152
+ else {
153
+ atomOffset += count * atoms._rowCount;
154
+ }
155
+ }
156
+ return {
157
+ indexA: Column.ofIntArray(indexA),
158
+ indexB: Column.ofIntArray(indexB),
159
+ order: Column.ofConst(1, indexA.length, Column.Schema.int)
160
+ };
161
+ }
162
+ //
163
+ export { TopFormat };
164
+ var TopFormat;
165
+ (function (TopFormat) {
166
+ function is(x) {
167
+ return (x === null || x === void 0 ? void 0 : x.kind) === 'top';
168
+ }
169
+ TopFormat.is = is;
170
+ function fromTop(top) {
171
+ return { kind: 'top', name: top.system || 'TOP', data: top };
172
+ }
173
+ TopFormat.fromTop = fromTop;
174
+ })(TopFormat || (TopFormat = {}));
175
+ export function topologyFromTop(top) {
176
+ var _this = this;
177
+ return Task.create('Parse TOP', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
178
+ var format, basic, bonds;
179
+ return __generator(this, function (_a) {
180
+ format = TopFormat.fromTop(top);
181
+ basic = getBasic(top);
182
+ bonds = getBonds(top);
183
+ return [2 /*return*/, Topology.create(top.system || 'TOP', basic, bonds, format)];
184
+ });
185
+ }); });
186
+ }
@@ -0,0 +1,9 @@
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 { TrrFile } from '../../mol-io/reader/trr/parser';
8
+ import { Coordinates } from '../../mol-model/structure/coordinates';
9
+ export declare function coordinatesFromTrr(file: TrrFile): Task<Coordinates>;
@@ -0,0 +1,42 @@
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 { Coordinates, Time } from '../../mol-model/structure/coordinates';
9
+ import { Cell } from '../../mol-math/geometry/spacegroup/cell';
10
+ import { Vec3 } from '../../mol-math/linear-algebra';
11
+ export function coordinatesFromTrr(file) {
12
+ var _this = this;
13
+ return Task.create('Parse TRR', function (ctx) { return __awaiter(_this, void 0, void 0, function () {
14
+ var deltaTime, offsetTime, frames, i, il, box, x, y, z;
15
+ return __generator(this, function (_a) {
16
+ switch (_a.label) {
17
+ case 0: return [4 /*yield*/, ctx.update('Converting to coordinates')];
18
+ case 1:
19
+ _a.sent();
20
+ deltaTime = Time(file.deltaTime, 'step');
21
+ offsetTime = Time(file.timeOffset, deltaTime.unit);
22
+ frames = [];
23
+ for (i = 0, il = file.frames.length; i < il; ++i) {
24
+ box = file.boxes[i];
25
+ x = Vec3.fromArray(Vec3(), box, 0);
26
+ y = Vec3.fromArray(Vec3(), box, 3);
27
+ z = Vec3.fromArray(Vec3(), box, 6);
28
+ frames.push({
29
+ elementCount: file.frames[i].count,
30
+ cell: Cell.fromBasis(x, y, z),
31
+ x: file.frames[i].x,
32
+ y: file.frames[i].y,
33
+ z: file.frames[i].z,
34
+ xyzOrdering: { isIdentity: true },
35
+ time: Time(offsetTime.value + deltaTime.value * i, deltaTime.unit)
36
+ });
37
+ }
38
+ return [2 /*return*/, Coordinates.create(frames, deltaTime, offsetTime)];
39
+ }
40
+ });
41
+ }); });
42
+ }
@@ -1,8 +1,8 @@
1
1
  /**
2
- * Copyright (c) 2019-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2019-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
3
  *
4
4
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
5
  */
6
6
  import { Tokens } from '../../mol-io/reader/common/text/tokenizer';
7
7
  export declare function guessElementSymbolTokens(tokens: Tokens, str: string, start: number, end: number): void;
8
- export declare function guessElementSymbolString(str: string): string;
8
+ export declare function guessElementSymbolString(atomId: string, compId: string): string;
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2019-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2019-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
3
  *
4
4
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
5
  */
@@ -40,34 +40,33 @@ export function guessElementSymbolTokens(tokens, str, start, end) {
40
40
  return TokenBuilder.add(tokens, s, s + 1);
41
41
  TokenBuilder.add(tokens, s, s); // no reasonable guess, add empty token
42
42
  }
43
+ var TwoCharElementNames = new Set(['NA', 'CL', 'FE', 'SI', 'BR', 'AS']);
44
+ var OneCharElementNames = new Set(['C', 'H', 'N', 'O', 'P', 'S']);
43
45
  var reTrimSpacesAndNumbers = /^[\s\d]+|[\s\d]+$/g;
44
- export function guessElementSymbolString(str) {
46
+ export function guessElementSymbolString(atomId, compId) {
45
47
  // trim spaces and numbers, convert to upper case
46
- str = str.replace(reTrimSpacesAndNumbers, '').toUpperCase();
47
- var l = str.length;
48
+ atomId = atomId.replace(reTrimSpacesAndNumbers, '').toUpperCase();
49
+ var l = atomId.length;
48
50
  if (l === 0)
49
- return str; // empty
51
+ return atomId; // empty
50
52
  if (l === 1)
51
- return str; // one char
52
- if (l === 2) { // two chars
53
- if (str === 'NA' || str === 'CL' || str === 'FE' || str === 'SI' ||
54
- str === 'BR' || str === 'AS')
55
- return str;
56
- }
57
- if (l === 3) { // three chars
58
- if (str === 'SOD')
53
+ return atomId; // one char
54
+ if (TwoCharElementNames.has(atomId))
55
+ return atomId; // two chars
56
+ // check for Charmm ion names where component and atom id are the same
57
+ if (l === 3 && compId === atomId) {
58
+ if (atomId === 'SOD')
59
59
  return 'NA';
60
- if (str === 'POT')
60
+ if (atomId === 'POT')
61
61
  return 'K';
62
- if (str === 'CES')
62
+ if (atomId === 'CES')
63
63
  return 'CS';
64
- if (str === 'CAL')
64
+ if (atomId === 'CAL')
65
65
  return 'CA';
66
- if (str === 'CLA')
66
+ if (atomId === 'CLA')
67
67
  return 'CL';
68
68
  }
69
- var c = str[0];
70
- if (c === 'C' || c === 'H' || c === 'N' || c === 'O' || c === 'P' || c === 'S')
71
- return c;
69
+ if (OneCharElementNames.has(atomId[0]))
70
+ return atomId[0];
72
71
  return ''; // no reasonable guess, return empty string
73
72
  }
@@ -63,12 +63,12 @@ function getModels(mol, ctx) {
63
63
  var componentBuilder = new ComponentBuilder(seq_id, type_symbol);
64
64
  componentBuilder.setNames([['MOL', 'Unknown Molecule']]);
65
65
  componentBuilder.add('MOL', 0);
66
- var basics = createBasic({
66
+ var basic = createBasic({
67
67
  entity: entityBuilder.getEntityTable(),
68
68
  chem_comp: componentBuilder.getChemCompTable(),
69
69
  atom_site: atom_site
70
70
  });
71
- return createModels(basics, XyzFormat.create(mol), ctx);
71
+ return createModels(basic, XyzFormat.create(mol), ctx);
72
72
  }
73
73
  //
74
74
  export { XyzFormat };
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2018-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
3
  *
4
4
  * @author David Sehnal <david.sehnal@gmail.com>
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
@@ -143,6 +143,7 @@ export declare class PluginContext {
143
143
  readonly customModelProperties: CustomProperty.Registry<Model>;
144
144
  readonly customStructureProperties: CustomProperty.Registry<Structure>;
145
145
  readonly customStructureControls: Map<string, new () => any>;
146
+ readonly customImportControls: Map<string, new () => any>;
146
147
  readonly genericRepresentationControls: Map<string, (selection: StructureHierarchyManager['selection']) => [StructureHierarchyRef[], string]>;
147
148
  /**
148
149
  * Used to store application specific custom state which is then available
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2018-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
3
  *
4
4
  * @author David Sehnal <david.sehnal@gmail.com>
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
@@ -156,6 +156,7 @@ var PluginContext = /** @class */ (function () {
156
156
  this.customModelProperties = new CustomProperty.Registry();
157
157
  this.customStructureProperties = new CustomProperty.Registry();
158
158
  this.customStructureControls = new Map();
159
+ this.customImportControls = new Map();
159
160
  this.genericRepresentationControls = new Map();
160
161
  /**
161
162
  * Used to store application specific custom state which is then available
@@ -291,8 +292,8 @@ var PluginContext = /** @class */ (function () {
291
292
  this.state.dispose();
292
293
  this.managers.task.dispose();
293
294
  this.helpers.substructureParent.dispose();
294
- objectForEach(this.managers, function (m) { var _a, _b; return (_b = (_a = m) === null || _a === void 0 ? void 0 : _a.dispose) === null || _b === void 0 ? void 0 : _b.call(_a); });
295
- objectForEach(this.managers.structure, function (m) { var _a, _b; return (_b = (_a = m) === null || _a === void 0 ? void 0 : _a.dispose) === null || _b === void 0 ? void 0 : _b.call(_a); });
295
+ objectForEach(this.managers, function (m) { var _a; return (_a = m === null || m === void 0 ? void 0 : m.dispose) === null || _a === void 0 ? void 0 : _a.call(m); });
296
+ objectForEach(this.managers.structure, function (m) { var _a; return (_a = m === null || m === void 0 ? void 0 : m.dispose) === null || _a === void 0 ? void 0 : _a.call(m); });
296
297
  this.disposed = true;
297
298
  };
298
299
  PluginContext.prototype.initBehaviorEvents = function () {
@@ -33,10 +33,10 @@ var PluginSpec;
33
33
  export var DefaultPluginSpec = function () { return ({
34
34
  actions: [
35
35
  PluginSpec.Action(StateActions.Structure.DownloadStructure),
36
- PluginSpec.Action(StateActions.Structure.AddTrajectory),
37
36
  PluginSpec.Action(StateActions.Volume.DownloadDensity),
38
37
  PluginSpec.Action(StateActions.DataFormat.DownloadFile),
39
38
  PluginSpec.Action(StateActions.DataFormat.OpenFiles),
39
+ PluginSpec.Action(StateActions.Structure.LoadTrajectory),
40
40
  PluginSpec.Action(StateActions.Structure.EnableModelCustomProps),
41
41
  PluginSpec.Action(StateActions.Structure.EnableStructureCustomProps),
42
42
  // Volume streaming
@@ -1,2 +1,2 @@
1
- export var PLUGIN_VERSION = '3.3.1';
2
- export var PLUGIN_VERSION_DATE = new Date(typeof __MOLSTAR_DEBUG_TIMESTAMP__ !== 'undefined' ? __MOLSTAR_DEBUG_TIMESTAMP__ : 1646016251962);
1
+ export var PLUGIN_VERSION = '3.4.0';
2
+ export var PLUGIN_VERSION_DATE = new Date(typeof __MOLSTAR_DEBUG_TIMESTAMP__ !== 'undefined' ? __MOLSTAR_DEBUG_TIMESTAMP__ : 1647202245473);
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2019-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2019-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
3
  *
4
4
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
5
5
  */