molstar 3.3.0 → 3.5.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 (905) hide show
  1. package/LICENSE +20 -20
  2. package/README.md +202 -194
  3. package/build/viewer/embedded.html +43 -43
  4. package/build/viewer/index.html +106 -106
  5. package/build/viewer/molstar.js +1 -1
  6. package/lib/apps/docking-viewer/index.html +36 -36
  7. package/lib/apps/docking-viewer/viewport.js +1 -1
  8. package/lib/apps/viewer/app.d.ts +7 -6
  9. package/lib/apps/viewer/app.js +2 -0
  10. package/lib/apps/viewer/embedded.html +43 -43
  11. package/lib/apps/viewer/index.html +106 -106
  12. package/lib/cli/chem-comp-dict/create-saccharides.d.ts +7 -0
  13. package/lib/cli/chem-comp-dict/create-saccharides.js +67 -0
  14. package/lib/cli/cif2bcif/converter.js +1 -1
  15. package/lib/cli/cif2bcif/index.js +4 -4
  16. package/lib/commonjs/apps/docking-viewer/index.js +12 -12
  17. package/lib/commonjs/apps/docking-viewer/viewport.js +33 -33
  18. package/lib/commonjs/apps/viewer/app.d.ts +7 -6
  19. package/lib/commonjs/apps/viewer/app.js +24 -22
  20. package/lib/commonjs/apps/viewer/index.js +1 -1
  21. package/lib/commonjs/cli/chem-comp-dict/create-ions.js +6 -6
  22. package/lib/commonjs/cli/chem-comp-dict/create-saccharides.d.ts +7 -0
  23. package/lib/commonjs/cli/chem-comp-dict/create-saccharides.js +69 -0
  24. package/lib/commonjs/cli/chem-comp-dict/create-table.js +8 -8
  25. package/lib/commonjs/cli/chem-comp-dict/util.js +17 -17
  26. package/lib/commonjs/cli/cif2bcif/converter.js +9 -9
  27. package/lib/commonjs/cli/cif2bcif/index.js +12 -12
  28. package/lib/commonjs/cli/cifschema/index.js +27 -27
  29. package/lib/commonjs/cli/cifschema/util/cif-dic.js +1 -1
  30. package/lib/commonjs/cli/lipid-params/index.js +9 -9
  31. package/lib/commonjs/cli/state-docs/index.js +2 -2
  32. package/lib/commonjs/cli/structure-info/helpers.js +11 -11
  33. package/lib/commonjs/cli/structure-info/model.js +15 -15
  34. package/lib/commonjs/cli/structure-info/volume.js +9 -9
  35. package/lib/commonjs/examples/alpha-orbitals/controls.js +3 -3
  36. package/lib/commonjs/examples/alpha-orbitals/index.js +11 -11
  37. package/lib/commonjs/examples/basic-wrapper/controls.js +2 -2
  38. package/lib/commonjs/examples/basic-wrapper/index.js +22 -22
  39. package/lib/commonjs/examples/basic-wrapper/superposition.js +8 -8
  40. package/lib/commonjs/examples/domain-annotation-server/mapping.js +3 -3
  41. package/lib/commonjs/examples/domain-annotation-server/server.js +6 -6
  42. package/lib/commonjs/examples/domain-annotation-server/test.js +3 -3
  43. package/lib/commonjs/examples/lighting/index.js +6 -6
  44. package/lib/commonjs/examples/proteopedia-wrapper/annotation.js +2 -2
  45. package/lib/commonjs/examples/proteopedia-wrapper/helpers.js +4 -4
  46. package/lib/commonjs/examples/proteopedia-wrapper/index.js +26 -26
  47. package/lib/commonjs/examples/proteopedia-wrapper/ui/controls.js +2 -2
  48. package/lib/commonjs/examples/task.js +15 -15
  49. package/lib/commonjs/extensions/alpha-orbitals/collocation.js +2 -2
  50. package/lib/commonjs/extensions/alpha-orbitals/data-model.js +1 -1
  51. package/lib/commonjs/extensions/alpha-orbitals/density.js +2 -2
  52. package/lib/commonjs/extensions/alpha-orbitals/gpu/compute.js +2 -2
  53. package/lib/commonjs/extensions/alpha-orbitals/orbitals.js +2 -2
  54. package/lib/commonjs/extensions/alpha-orbitals/transforms.js +13 -13
  55. package/lib/commonjs/extensions/anvil/algorithm.js +13 -13
  56. package/lib/commonjs/extensions/anvil/behavior.js +14 -14
  57. package/lib/commonjs/extensions/anvil/prop.js +7 -7
  58. package/lib/commonjs/extensions/anvil/representation.js +5 -5
  59. package/lib/commonjs/extensions/cellpack/index.js +1 -1
  60. package/lib/commonjs/extensions/cellpack/model.js +26 -24
  61. package/lib/commonjs/extensions/cellpack/preset.js +6 -6
  62. package/lib/commonjs/extensions/cellpack/property.js +3 -3
  63. package/lib/commonjs/extensions/cellpack/representation.js +2 -2
  64. package/lib/commonjs/extensions/cellpack/state.js +13 -13
  65. package/lib/commonjs/extensions/cellpack/util.js +14 -14
  66. package/lib/commonjs/extensions/dnatco/confal-pyramids/behavior.js +7 -7
  67. package/lib/commonjs/extensions/dnatco/confal-pyramids/color.d.ts +397 -2
  68. package/lib/commonjs/extensions/dnatco/confal-pyramids/color.js +223 -131
  69. package/lib/commonjs/extensions/dnatco/confal-pyramids/property.js +6 -8
  70. package/lib/commonjs/extensions/dnatco/confal-pyramids/representation.js +2 -2
  71. package/lib/commonjs/extensions/dnatco/confal-pyramids/util.js +19 -20
  72. package/lib/commonjs/extensions/g3d/data.js +6 -6
  73. package/lib/commonjs/extensions/g3d/format.js +14 -14
  74. package/lib/commonjs/extensions/g3d/model.js +4 -4
  75. package/lib/commonjs/extensions/geo-export/controls.js +3 -3
  76. package/lib/commonjs/extensions/geo-export/glb-exporter.js +9 -9
  77. package/lib/commonjs/extensions/geo-export/index.js +1 -1
  78. package/lib/commonjs/extensions/geo-export/mesh-exporter.js +12 -12
  79. package/lib/commonjs/extensions/geo-export/obj-exporter.js +7 -7
  80. package/lib/commonjs/extensions/geo-export/stl-exporter.js +7 -7
  81. package/lib/commonjs/extensions/geo-export/ui.js +7 -7
  82. package/lib/commonjs/extensions/geo-export/usdz-exporter.js +9 -9
  83. package/lib/commonjs/extensions/model-archive/quality-assessment/behavior.js +9 -9
  84. package/lib/commonjs/extensions/model-archive/quality-assessment/color/plddt.js +4 -4
  85. package/lib/commonjs/extensions/model-archive/quality-assessment/color/qmean.js +4 -4
  86. package/lib/commonjs/extensions/model-archive/quality-assessment/prop.js +5 -5
  87. package/lib/commonjs/extensions/model-export/export.js +4 -4
  88. package/lib/commonjs/extensions/model-export/index.js +1 -1
  89. package/lib/commonjs/extensions/model-export/ui.js +5 -5
  90. package/lib/commonjs/extensions/mp4-export/controls.js +5 -5
  91. package/lib/commonjs/extensions/mp4-export/encoder.js +4 -4
  92. package/lib/commonjs/extensions/mp4-export/index.js +1 -1
  93. package/lib/commonjs/extensions/mp4-export/ui.js +5 -5
  94. package/lib/commonjs/extensions/pdbe/preferred-assembly.js +2 -2
  95. package/lib/commonjs/extensions/pdbe/struct-ref-domain.js +2 -2
  96. package/lib/commonjs/extensions/pdbe/structure-quality-report/behavior.js +1 -1
  97. package/lib/commonjs/extensions/pdbe/structure-quality-report/prop.js +8 -8
  98. package/lib/commonjs/extensions/rcsb/assembly-symmetry/behavior.js +17 -17
  99. package/lib/commonjs/extensions/rcsb/assembly-symmetry/color.js +2 -2
  100. package/lib/commonjs/extensions/rcsb/assembly-symmetry/prop.js +9 -9
  101. package/lib/commonjs/extensions/rcsb/assembly-symmetry/representation.js +6 -6
  102. package/lib/commonjs/extensions/rcsb/assembly-symmetry/ui.js +9 -9
  103. package/lib/commonjs/extensions/rcsb/validation-report/behavior.js +17 -17
  104. package/lib/commonjs/extensions/rcsb/validation-report/prop.js +15 -15
  105. package/lib/commonjs/extensions/rcsb/validation-report/representation.js +22 -5
  106. package/lib/commonjs/extensions/zenodo/index.d.ts +7 -0
  107. package/lib/commonjs/extensions/zenodo/index.js +35 -0
  108. package/lib/commonjs/extensions/zenodo/ui.d.ts +61 -0
  109. package/lib/commonjs/extensions/zenodo/ui.js +306 -0
  110. package/lib/commonjs/mol-canvas3d/camera/stereo.js +1 -1
  111. package/lib/commonjs/mol-canvas3d/camera/util.js +1 -1
  112. package/lib/commonjs/mol-canvas3d/camera.js +2 -1
  113. package/lib/commonjs/mol-canvas3d/canvas3d.js +14 -14
  114. package/lib/commonjs/mol-canvas3d/controls/trackball.js +1 -1
  115. package/lib/commonjs/mol-canvas3d/helper/bounding-sphere-helper.js +1 -1
  116. package/lib/commonjs/mol-canvas3d/helper/camera-helper.js +5 -5
  117. package/lib/commonjs/mol-canvas3d/helper/handle-helper.js +5 -5
  118. package/lib/commonjs/mol-canvas3d/helper/helper.js +1 -1
  119. package/lib/commonjs/mol-canvas3d/helper/interaction-events.js +2 -2
  120. package/lib/commonjs/mol-canvas3d/passes/draw.js +3 -3
  121. package/lib/commonjs/mol-canvas3d/passes/fxaa.js +3 -3
  122. package/lib/commonjs/mol-canvas3d/passes/image.js +1 -1
  123. package/lib/commonjs/mol-canvas3d/passes/marking.js +6 -6
  124. package/lib/commonjs/mol-canvas3d/passes/multi-sample.js +3 -3
  125. package/lib/commonjs/mol-canvas3d/passes/postprocessing.js +12 -12
  126. package/lib/commonjs/mol-canvas3d/passes/smaa.js +9 -9
  127. package/lib/commonjs/mol-canvas3d/passes/wboit.js +3 -3
  128. package/lib/commonjs/mol-canvas3d/util.js +2 -2
  129. package/lib/commonjs/mol-data/db/column.js +2 -2
  130. package/lib/commonjs/mol-data/db/table.js +1 -1
  131. package/lib/commonjs/mol-data/db.js +1 -1
  132. package/lib/commonjs/mol-data/generic.js +3 -3
  133. package/lib/commonjs/mol-data/index.js +4 -4
  134. package/lib/commonjs/mol-data/int/interval.js +1 -1
  135. package/lib/commonjs/mol-data/int/ordered-set.js +1 -1
  136. package/lib/commonjs/mol-data/int/segmentation.js +1 -1
  137. package/lib/commonjs/mol-data/int/sorted-array.js +1 -1
  138. package/lib/commonjs/mol-data/util.js +7 -7
  139. package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.d.ts +2 -2
  140. package/lib/commonjs/mol-geo/geometry/cylinders/cylinders.js +3 -3
  141. package/lib/commonjs/mol-geo/geometry/direct-volume/direct-volume.js +3 -3
  142. package/lib/commonjs/mol-geo/geometry/direct-volume/transfer-function.js +1 -1
  143. package/lib/commonjs/mol-geo/geometry/image/image.js +3 -3
  144. package/lib/commonjs/mol-geo/geometry/lines/lines.d.ts +0 -1
  145. package/lib/commonjs/mol-geo/geometry/lines/lines.js +3 -3
  146. package/lib/commonjs/mol-geo/geometry/mesh/color-smoothing.d.ts +1 -1
  147. package/lib/commonjs/mol-geo/geometry/mesh/color-smoothing.js +5 -3
  148. package/lib/commonjs/mol-geo/geometry/mesh/mesh.js +3 -3
  149. package/lib/commonjs/mol-geo/geometry/points/points.d.ts +1 -1
  150. package/lib/commonjs/mol-geo/geometry/points/points.js +3 -3
  151. package/lib/commonjs/mol-geo/geometry/size-data.js +1 -1
  152. package/lib/commonjs/mol-geo/geometry/spheres/spheres.js +3 -3
  153. package/lib/commonjs/mol-geo/geometry/text/font-atlas.js +1 -1
  154. package/lib/commonjs/mol-geo/geometry/text/text-builder.js +3 -2
  155. package/lib/commonjs/mol-geo/geometry/text/text.js +3 -3
  156. package/lib/commonjs/mol-geo/geometry/texture-mesh/color-smoothing.d.ts +1 -1
  157. package/lib/commonjs/mol-geo/geometry/texture-mesh/color-smoothing.js +10 -8
  158. package/lib/commonjs/mol-geo/geometry/texture-mesh/texture-mesh.js +3 -3
  159. package/lib/commonjs/mol-geo/primitive/circle.js +1 -1
  160. package/lib/commonjs/mol-geo/primitive/cylinder.js +1 -1
  161. package/lib/commonjs/mol-geo/primitive/polyhedron.js +1 -1
  162. package/lib/commonjs/mol-geo/primitive/prism.js +1 -1
  163. package/lib/commonjs/mol-geo/primitive/star.js +1 -1
  164. package/lib/commonjs/mol-geo/primitive/torus.js +1 -1
  165. package/lib/commonjs/mol-geo/util/marching-cubes/algorithm.js +9 -9
  166. package/lib/commonjs/mol-gl/compute/grid3d.js +5 -5
  167. package/lib/commonjs/mol-gl/compute/histogram-pyramid/reduction.js +3 -3
  168. package/lib/commonjs/mol-gl/compute/histogram-pyramid/sum.js +3 -3
  169. package/lib/commonjs/mol-gl/compute/marching-cubes/active-voxels.js +3 -3
  170. package/lib/commonjs/mol-gl/compute/marching-cubes/isosurface.js +3 -3
  171. package/lib/commonjs/mol-gl/compute/util.js +3 -3
  172. package/lib/commonjs/mol-gl/renderable/cylinders.js +3 -3
  173. package/lib/commonjs/mol-gl/renderable/direct-volume.js +3 -3
  174. package/lib/commonjs/mol-gl/renderable/image.js +3 -3
  175. package/lib/commonjs/mol-gl/renderable/lines.js +3 -3
  176. package/lib/commonjs/mol-gl/renderable/mesh.js +3 -3
  177. package/lib/commonjs/mol-gl/renderable/points.js +3 -3
  178. package/lib/commonjs/mol-gl/renderable/schema.js +1 -1
  179. package/lib/commonjs/mol-gl/renderable/spheres.js +3 -3
  180. package/lib/commonjs/mol-gl/renderable/text.js +3 -3
  181. package/lib/commonjs/mol-gl/renderable/texture-mesh.js +3 -3
  182. package/lib/commonjs/mol-gl/renderable/util.js +1 -1
  183. package/lib/commonjs/mol-gl/shader-code.js +2 -1
  184. package/lib/commonjs/mol-gl/webgl/buffer.js +4 -5
  185. package/lib/commonjs/mol-gl/webgl/context.d.ts +1 -1
  186. package/lib/commonjs/mol-gl/webgl/context.js +5 -5
  187. package/lib/commonjs/mol-gl/webgl/render-item.js +1 -1
  188. package/lib/commonjs/mol-gl/webgl/resources.js +2 -2
  189. package/lib/commonjs/mol-io/common/binary-cif/classifier.js +7 -6
  190. package/lib/commonjs/mol-io/common/binary-cif/decoder.js +4 -3
  191. package/lib/commonjs/mol-io/common/binary-cif.js +3 -3
  192. package/lib/commonjs/mol-io/common/io-buffer.d.ts +206 -0
  193. package/lib/commonjs/mol-io/common/io-buffer.js +408 -0
  194. package/lib/commonjs/mol-io/common/netcdf/reader.d.ts +78 -0
  195. package/lib/commonjs/mol-io/common/netcdf/reader.js +459 -0
  196. package/lib/commonjs/mol-io/common/typed-array.js +2 -2
  197. package/lib/commonjs/mol-io/reader/ccp4/parser.js +8 -8
  198. package/lib/commonjs/mol-io/reader/cif/binary/parser.js +3 -3
  199. package/lib/commonjs/mol-io/reader/cif/data-model.js +1 -1
  200. package/lib/commonjs/mol-io/reader/cif/schema/mmcif-extras.js +2 -2
  201. package/lib/commonjs/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
  202. package/lib/commonjs/mol-io/reader/cif/schema.js +2 -2
  203. package/lib/commonjs/mol-io/reader/cif/text/parser.js +7 -7
  204. package/lib/commonjs/mol-io/reader/cif.js +1 -1
  205. package/lib/commonjs/mol-io/reader/common/text/tokenizer.js +4 -4
  206. package/lib/commonjs/mol-io/reader/csv/data-model.js +1 -1
  207. package/lib/commonjs/mol-io/reader/csv/parser.js +7 -7
  208. package/lib/commonjs/mol-io/reader/cube/parser.js +2 -2
  209. package/lib/commonjs/mol-io/reader/dcd/parser.js +2 -2
  210. package/lib/commonjs/mol-io/reader/dsn6/parser.js +8 -8
  211. package/lib/commonjs/mol-io/reader/dx/parser.js +4 -4
  212. package/lib/commonjs/mol-io/reader/gro/parser.js +6 -6
  213. package/lib/commonjs/mol-io/reader/mol/parser.js +2 -2
  214. package/lib/commonjs/mol-io/reader/mol2/parser.js +8 -8
  215. package/lib/commonjs/mol-io/reader/nctraj/parser.d.ts +18 -0
  216. package/lib/commonjs/mol-io/reader/nctraj/parser.js +101 -0
  217. package/lib/commonjs/mol-io/reader/obj/parser.js +4 -4
  218. package/lib/commonjs/mol-io/reader/pdb/parser.js +2 -2
  219. package/lib/commonjs/mol-io/reader/ply/parser.js +4 -4
  220. package/lib/commonjs/mol-io/reader/prmtop/parser.d.ts +58 -0
  221. package/lib/commonjs/mol-io/reader/prmtop/parser.js +172 -0
  222. package/lib/commonjs/mol-io/reader/psf/parser.js +8 -8
  223. package/lib/commonjs/mol-io/reader/sdf/parser.js +2 -2
  224. package/lib/commonjs/mol-io/reader/top/parser.d.ts +37 -0
  225. package/lib/commonjs/mol-io/reader/top/parser.js +303 -0
  226. package/lib/commonjs/mol-io/reader/trr/parser.d.ts +22 -0
  227. package/lib/commonjs/mol-io/reader/trr/parser.js +146 -0
  228. package/lib/commonjs/mol-io/reader/xtc/parser.js +4 -4
  229. package/lib/commonjs/mol-io/reader/xyz/parser.js +2 -2
  230. package/lib/commonjs/mol-io/writer/cif/encoder.js +3 -2
  231. package/lib/commonjs/mol-io/writer/cif.js +1 -1
  232. package/lib/commonjs/mol-io/writer/ligand-encoder.js +1 -1
  233. package/lib/commonjs/mol-io/writer/mol/encoder.js +1 -1
  234. package/lib/commonjs/mol-io/writer/mol2/encoder.js +1 -1
  235. package/lib/commonjs/mol-math/geometry/boundary-helper.js +5 -5
  236. package/lib/commonjs/mol-math/geometry/common.d.ts +2 -1
  237. package/lib/commonjs/mol-math/geometry/common.js +1 -1
  238. package/lib/commonjs/mol-math/geometry/gaussian-density/cpu.d.ts +1 -1
  239. package/lib/commonjs/mol-math/geometry/gaussian-density/cpu.js +6 -6
  240. package/lib/commonjs/mol-math/geometry/gaussian-density/gpu.d.ts +1 -1
  241. package/lib/commonjs/mol-math/geometry/gaussian-density/gpu.js +8 -8
  242. package/lib/commonjs/mol-math/geometry/gaussian-density.d.ts +2 -2
  243. package/lib/commonjs/mol-math/geometry/gaussian-density.js +5 -5
  244. package/lib/commonjs/mol-math/geometry/molecular-surface.d.ts +2 -1
  245. package/lib/commonjs/mol-math/geometry/molecular-surface.js +10 -10
  246. package/lib/commonjs/mol-math/geometry/primitives/box3d.js +2 -1
  247. package/lib/commonjs/mol-math/geometry/primitives/sphere3d.js +13 -7
  248. package/lib/commonjs/mol-math/geometry.js +8 -8
  249. package/lib/commonjs/mol-math/graph/inter-unit-graph.js +1 -1
  250. package/lib/commonjs/mol-math/graph.js +1 -1
  251. package/lib/commonjs/mol-math/linear-algebra.js +2 -2
  252. package/lib/commonjs/mol-model/sequence/alignment/alignment.js +1 -1
  253. package/lib/commonjs/mol-model/sequence/sequence.js +2 -1
  254. package/lib/commonjs/mol-model/sequence.js +1 -1
  255. package/lib/commonjs/mol-model/shape.js +1 -1
  256. package/lib/commonjs/mol-model/structure/coordinates.js +1 -1
  257. package/lib/commonjs/mol-model/structure/export/categories/secondary-structure.js +2 -2
  258. package/lib/commonjs/mol-model/structure/model/model.js +3 -3
  259. package/lib/commonjs/mol-model/structure/model/properties/atomic.js +3 -3
  260. package/lib/commonjs/mol-model/structure/model/properties/coarse.js +2 -2
  261. package/lib/commonjs/mol-model/structure/model/types/saccharides.d.ts +8 -0
  262. package/lib/commonjs/mol-model/structure/model/types/saccharides.js +11 -0
  263. package/lib/commonjs/mol-model/structure/model.js +3 -3
  264. package/lib/commonjs/mol-model/structure/query/queries/generators.js +2 -2
  265. package/lib/commonjs/mol-model/structure/query/queries/modifiers.js +2 -2
  266. package/lib/commonjs/mol-model/structure/query.js +6 -6
  267. package/lib/commonjs/mol-model/structure/structure/carbohydrates/compute.js +1 -1
  268. package/lib/commonjs/mol-model/structure/structure/carbohydrates/constants.d.ts +1 -1
  269. package/lib/commonjs/mol-model/structure/structure/carbohydrates/constants.js +6 -9
  270. package/lib/commonjs/mol-model/structure/structure/element/element.js +5 -5
  271. package/lib/commonjs/mol-model/structure/structure/element.js +1 -1
  272. package/lib/commonjs/mol-model/structure/structure/structure.js +9 -6
  273. package/lib/commonjs/mol-model/structure/structure/symmetry.js +10 -10
  274. package/lib/commonjs/mol-model/structure/structure/unit/bonds/data.js +2 -2
  275. package/lib/commonjs/mol-model/structure/structure/unit/bonds/inter-compute.d.ts +1 -0
  276. package/lib/commonjs/mol-model/structure/structure/unit/bonds/inter-compute.js +6 -4
  277. package/lib/commonjs/mol-model/structure/structure/unit/bonds/intra-compute.js +1 -1
  278. package/lib/commonjs/mol-model/structure/structure/unit/bonds.js +3 -3
  279. package/lib/commonjs/mol-model/structure/structure/unit.js +5 -22
  280. package/lib/commonjs/mol-model/structure/structure/util/superposition.js +1 -1
  281. package/lib/commonjs/mol-model/structure/structure.js +2 -2
  282. package/lib/commonjs/mol-model/structure/topology.js +1 -1
  283. package/lib/commonjs/mol-model/structure.js +6 -6
  284. package/lib/commonjs/mol-model/volume.js +2 -2
  285. package/lib/commonjs/mol-model-formats/shape/ply.js +7 -7
  286. package/lib/commonjs/mol-model-formats/structure/basic/atomic.d.ts +1 -1
  287. package/lib/commonjs/mol-model-formats/structure/basic/atomic.js +2 -15
  288. package/lib/commonjs/mol-model-formats/structure/basic/coarse.js +3 -3
  289. package/lib/commonjs/mol-model-formats/structure/basic/entities.js +1 -1
  290. package/lib/commonjs/mol-model-formats/structure/basic/parser.d.ts +1 -1
  291. package/lib/commonjs/mol-model-formats/structure/basic/parser.js +10 -10
  292. package/lib/commonjs/mol-model-formats/structure/basic/schema.d.ts +2 -2
  293. package/lib/commonjs/mol-model-formats/structure/basic/schema.js +7 -2
  294. package/lib/commonjs/mol-model-formats/structure/basic/sort.js +2 -2
  295. package/lib/commonjs/mol-model-formats/structure/basic/util.d.ts +33 -2
  296. package/lib/commonjs/mol-model-formats/structure/basic/util.js +26 -2
  297. package/lib/commonjs/mol-model-formats/structure/cif-core.js +6 -6
  298. package/lib/commonjs/mol-model-formats/structure/common/component.js +5 -1
  299. package/lib/commonjs/mol-model-formats/structure/cube.js +5 -5
  300. package/lib/commonjs/mol-model-formats/structure/dcd.js +2 -2
  301. package/lib/commonjs/mol-model-formats/structure/gro.js +5 -3
  302. package/lib/commonjs/mol-model-formats/structure/mmcif.d.ts +1 -1
  303. package/lib/commonjs/mol-model-formats/structure/mmcif.js +4 -2
  304. package/lib/commonjs/mol-model-formats/structure/mol.js +5 -5
  305. package/lib/commonjs/mol-model-formats/structure/mol2.js +6 -6
  306. package/lib/commonjs/mol-model-formats/structure/nctraj.d.ts +9 -0
  307. package/lib/commonjs/mol-model-formats/structure/nctraj.js +60 -0
  308. package/lib/commonjs/mol-model-formats/structure/pdb/to-cif.js +2 -2
  309. package/lib/commonjs/mol-model-formats/structure/pdb.d.ts +1 -1
  310. package/lib/commonjs/mol-model-formats/structure/pdb.js +7 -5
  311. package/lib/commonjs/mol-model-formats/structure/prmtop.d.ts +16 -0
  312. package/lib/commonjs/mol-model-formats/structure/prmtop.js +147 -0
  313. package/lib/commonjs/mol-model-formats/structure/property/bonds/index-pair.js +1 -1
  314. package/lib/commonjs/mol-model-formats/structure/property/symmetry.js +11 -1
  315. package/lib/commonjs/mol-model-formats/structure/psf.js +5 -3
  316. package/lib/commonjs/mol-model-formats/structure/top.d.ts +16 -0
  317. package/lib/commonjs/mol-model-formats/structure/top.js +189 -0
  318. package/lib/commonjs/mol-model-formats/structure/trr.d.ts +9 -0
  319. package/lib/commonjs/mol-model-formats/structure/trr.js +46 -0
  320. package/lib/commonjs/mol-model-formats/structure/util.d.ts +2 -2
  321. package/lib/commonjs/mol-model-formats/structure/util.js +19 -20
  322. package/lib/commonjs/mol-model-formats/structure/xtc.js +2 -2
  323. package/lib/commonjs/mol-model-formats/structure/xyz.js +2 -2
  324. package/lib/commonjs/mol-model-formats/volume/ccp4.js +2 -2
  325. package/lib/commonjs/mol-model-formats/volume/cube.js +2 -2
  326. package/lib/commonjs/mol-model-formats/volume/density-server.js +2 -2
  327. package/lib/commonjs/mol-model-formats/volume/dsn6.js +2 -2
  328. package/lib/commonjs/mol-model-formats/volume/dx.js +2 -2
  329. package/lib/commonjs/mol-model-props/common/custom-element-property.js +2 -2
  330. package/lib/commonjs/mol-model-props/common/custom-model-property.js +5 -5
  331. package/lib/commonjs/mol-model-props/common/custom-property.js +1 -1
  332. package/lib/commonjs/mol-model-props/common/custom-structure-property.js +6 -6
  333. package/lib/commonjs/mol-model-props/computed/accessible-surface-area/shrake-rupley/area.js +2 -2
  334. package/lib/commonjs/mol-model-props/computed/accessible-surface-area/shrake-rupley.js +5 -5
  335. package/lib/commonjs/mol-model-props/computed/accessible-surface-area.js +4 -4
  336. package/lib/commonjs/mol-model-props/computed/chemistry/valence-model.js +3 -3
  337. package/lib/commonjs/mol-model-props/computed/helix-orientation.js +2 -2
  338. package/lib/commonjs/mol-model-props/computed/interactions/common.js +1 -1
  339. package/lib/commonjs/mol-model-props/computed/interactions/contacts.js +1 -1
  340. package/lib/commonjs/mol-model-props/computed/interactions/features.js +1 -1
  341. package/lib/commonjs/mol-model-props/computed/interactions/hydrogen-bonds.js +3 -3
  342. package/lib/commonjs/mol-model-props/computed/interactions/interactions.js +3 -3
  343. package/lib/commonjs/mol-model-props/computed/interactions.js +4 -4
  344. package/lib/commonjs/mol-model-props/computed/representations/interactions-inter-unit-cylinder.js +10 -4
  345. package/lib/commonjs/mol-model-props/computed/representations/interactions-intra-unit-cylinder.js +12 -7
  346. package/lib/commonjs/mol-model-props/computed/representations/interactions.js +1 -1
  347. package/lib/commonjs/mol-model-props/computed/secondary-structure/dssp.js +2 -2
  348. package/lib/commonjs/mol-model-props/computed/secondary-structure.js +7 -7
  349. package/lib/commonjs/mol-model-props/computed/valence-model.js +4 -4
  350. package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/property.js +2 -2
  351. package/lib/commonjs/mol-model-props/integrative/cross-link-restraint/representation.js +12 -3
  352. package/lib/commonjs/mol-model-props/sequence/sifts-mapping.js +2 -2
  353. package/lib/commonjs/mol-model-props/sequence/themes/sifts-mapping.js +3 -3
  354. package/lib/commonjs/mol-plugin/animation-loop.js +2 -2
  355. package/lib/commonjs/mol-plugin/behavior/behavior.js +5 -5
  356. package/lib/commonjs/mol-plugin/behavior/dynamic/camera.js +2 -2
  357. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/accessible-surface-area.js +1 -1
  358. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/interactions.js +1 -1
  359. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/secondary-structure.js +1 -1
  360. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/computed/valence-model.js +1 -1
  361. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/integrative/cross-link-restraint.js +1 -1
  362. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/sequence/sifts-mapping.js +1 -1
  363. package/lib/commonjs/mol-plugin/behavior/dynamic/custom-props/structure-info.js +2 -2
  364. package/lib/commonjs/mol-plugin/behavior/dynamic/representation.js +3 -3
  365. package/lib/commonjs/mol-plugin/behavior/dynamic/selection/structure-focus-representation.js +11 -11
  366. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/behavior.js +12 -12
  367. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +2 -3
  368. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/model.js +1 -1
  369. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/transformers.js +16 -16
  370. package/lib/commonjs/mol-plugin/behavior/dynamic/volume-streaming/util.js +10 -10
  371. package/lib/commonjs/mol-plugin/behavior/static/state.js +6 -6
  372. package/lib/commonjs/mol-plugin/behavior.js +8 -8
  373. package/lib/commonjs/mol-plugin/command.js +2 -2
  374. package/lib/commonjs/mol-plugin/context.d.ts +2 -1
  375. package/lib/commonjs/mol-plugin/context.js +9 -8
  376. package/lib/commonjs/mol-plugin/layout.js +2 -2
  377. package/lib/commonjs/mol-plugin/spec.js +1 -1
  378. package/lib/commonjs/mol-plugin/state.js +5 -5
  379. package/lib/commonjs/mol-plugin/util/task-manager.js +4 -4
  380. package/lib/commonjs/mol-plugin/util/toast.js +1 -1
  381. package/lib/commonjs/mol-plugin/util/viewport-screenshot.js +17 -17
  382. package/lib/commonjs/mol-plugin-state/actions/file.d.ts +1 -1
  383. package/lib/commonjs/mol-plugin-state/actions/file.js +94 -61
  384. package/lib/commonjs/mol-plugin-state/actions/structure.d.ts +11 -2
  385. package/lib/commonjs/mol-plugin-state/actions/structure.js +190 -20
  386. package/lib/commonjs/mol-plugin-state/actions/volume.js +5 -4
  387. package/lib/commonjs/mol-plugin-state/actions.js +3 -3
  388. package/lib/commonjs/mol-plugin-state/animation/built-in/assembly-unwind.js +2 -2
  389. package/lib/commonjs/mol-plugin-state/animation/built-in/camera-rock.js +3 -3
  390. package/lib/commonjs/mol-plugin-state/animation/built-in/camera-spin.js +3 -3
  391. package/lib/commonjs/mol-plugin-state/animation/built-in/explode-units.js +4 -4
  392. package/lib/commonjs/mol-plugin-state/animation/built-in/model-index.js +2 -2
  393. package/lib/commonjs/mol-plugin-state/animation/built-in/spin-structure.js +5 -5
  394. package/lib/commonjs/mol-plugin-state/animation/built-in/state-interpolation.js +2 -2
  395. package/lib/commonjs/mol-plugin-state/animation/built-in/state-snapshots.js +5 -5
  396. package/lib/commonjs/mol-plugin-state/builder/data.js +2 -2
  397. package/lib/commonjs/mol-plugin-state/builder/structure/hierarchy-preset.js +16 -16
  398. package/lib/commonjs/mol-plugin-state/builder/structure/representation-preset.js +28 -28
  399. package/lib/commonjs/mol-plugin-state/builder/structure/representation.js +2 -2
  400. package/lib/commonjs/mol-plugin-state/builder/structure.js +7 -7
  401. package/lib/commonjs/mol-plugin-state/component.js +1 -1
  402. package/lib/commonjs/mol-plugin-state/formats/{structure.d.ts → coordinates.d.ts} +34 -18
  403. package/lib/commonjs/mol-plugin-state/formats/coordinates.js +70 -0
  404. package/lib/commonjs/mol-plugin-state/formats/registry.d.ts +3 -3
  405. package/lib/commonjs/mol-plugin-state/formats/registry.js +13 -8
  406. package/lib/commonjs/mol-plugin-state/formats/shape.js +2 -2
  407. package/lib/commonjs/mol-plugin-state/formats/topology.d.ts +73 -0
  408. package/lib/commonjs/mol-plugin-state/formats/topology.js +87 -0
  409. package/lib/commonjs/mol-plugin-state/formats/trajectory.js +6 -6
  410. package/lib/commonjs/mol-plugin-state/formats/volume.js +21 -21
  411. package/lib/commonjs/mol-plugin-state/helpers/root-structure.js +15 -15
  412. package/lib/commonjs/mol-plugin-state/helpers/structure-clipping.js +7 -7
  413. package/lib/commonjs/mol-plugin-state/helpers/structure-component.js +2 -1
  414. package/lib/commonjs/mol-plugin-state/helpers/structure-overpaint.js +11 -11
  415. package/lib/commonjs/mol-plugin-state/helpers/structure-selection-query.js +3 -3
  416. package/lib/commonjs/mol-plugin-state/helpers/structure-substance.js +11 -11
  417. package/lib/commonjs/mol-plugin-state/helpers/structure-transparency.js +11 -11
  418. package/lib/commonjs/mol-plugin-state/manager/animation.js +17 -17
  419. package/lib/commonjs/mol-plugin-state/manager/camera.js +1 -1
  420. package/lib/commonjs/mol-plugin-state/manager/interactivity.js +6 -6
  421. package/lib/commonjs/mol-plugin-state/manager/snapshots.js +14 -14
  422. package/lib/commonjs/mol-plugin-state/manager/structure/component.js +26 -26
  423. package/lib/commonjs/mol-plugin-state/manager/structure/focus.js +2 -2
  424. package/lib/commonjs/mol-plugin-state/manager/structure/hierarchy-state.js +1 -1
  425. package/lib/commonjs/mol-plugin-state/manager/structure/hierarchy.js +8 -8
  426. package/lib/commonjs/mol-plugin-state/manager/structure/measurement.js +21 -21
  427. package/lib/commonjs/mol-plugin-state/manager/structure/selection.js +3 -3
  428. package/lib/commonjs/mol-plugin-state/manager/volume/hierarchy.js +1 -1
  429. package/lib/commonjs/mol-plugin-state/objects.d.ts +47 -1
  430. package/lib/commonjs/mol-plugin-state/objects.js +46 -30
  431. package/lib/commonjs/mol-plugin-state/transforms/data.d.ts +6 -0
  432. package/lib/commonjs/mol-plugin-state/transforms/data.js +93 -41
  433. package/lib/commonjs/mol-plugin-state/transforms/model.d.ts +14 -2
  434. package/lib/commonjs/mol-plugin-state/transforms/model.js +163 -54
  435. package/lib/commonjs/mol-plugin-state/transforms/representation.js +77 -77
  436. package/lib/commonjs/mol-plugin-state/transforms/shape.js +2 -2
  437. package/lib/commonjs/mol-plugin-state/transforms/volume.js +16 -16
  438. package/lib/commonjs/mol-plugin-state/transforms.js +6 -6
  439. package/lib/commonjs/mol-plugin-ui/base.js +5 -5
  440. package/lib/commonjs/mol-plugin-ui/context.js +1 -1
  441. package/lib/commonjs/mol-plugin-ui/controls/action-menu.js +14 -14
  442. package/lib/commonjs/mol-plugin-ui/controls/color.js +7 -7
  443. package/lib/commonjs/mol-plugin-ui/controls/common.js +16 -16
  444. package/lib/commonjs/mol-plugin-ui/controls/icons.js +70 -70
  445. package/lib/commonjs/mol-plugin-ui/controls/legend.js +7 -7
  446. package/lib/commonjs/mol-plugin-ui/controls/line-graph/line-graph-component.js +3 -3
  447. package/lib/commonjs/mol-plugin-ui/controls/line-graph/point-component.js +2 -2
  448. package/lib/commonjs/mol-plugin-ui/controls/parameters.js +94 -94
  449. package/lib/commonjs/mol-plugin-ui/controls/screenshot.js +5 -5
  450. package/lib/commonjs/mol-plugin-ui/controls/slider.js +16 -16
  451. package/lib/commonjs/mol-plugin-ui/controls.js +16 -16
  452. package/lib/commonjs/mol-plugin-ui/custom/volume.js +16 -16
  453. package/lib/commonjs/mol-plugin-ui/index.js +4 -4
  454. package/lib/commonjs/mol-plugin-ui/left-panel.d.ts +8 -1
  455. package/lib/commonjs/mol-plugin-ui/left-panel.js +40 -19
  456. package/lib/commonjs/mol-plugin-ui/plugin.js +17 -17
  457. package/lib/commonjs/mol-plugin-ui/sequence/chain.js +1 -1
  458. package/lib/commonjs/mol-plugin-ui/sequence/element.js +1 -1
  459. package/lib/commonjs/mol-plugin-ui/sequence/hetero.js +1 -1
  460. package/lib/commonjs/mol-plugin-ui/sequence/polymer.js +1 -1
  461. package/lib/commonjs/mol-plugin-ui/sequence/sequence.js +6 -6
  462. package/lib/commonjs/mol-plugin-ui/sequence.js +9 -9
  463. package/lib/commonjs/mol-plugin-ui/spec.js +1 -1
  464. package/lib/commonjs/mol-plugin-ui/state/actions.js +2 -2
  465. package/lib/commonjs/mol-plugin-ui/state/animation.js +2 -2
  466. package/lib/commonjs/mol-plugin-ui/state/apply-action.js +1 -1
  467. package/lib/commonjs/mol-plugin-ui/state/common.js +12 -12
  468. package/lib/commonjs/mol-plugin-ui/state/snapshots.js +29 -29
  469. package/lib/commonjs/mol-plugin-ui/state/tree.js +19 -19
  470. package/lib/commonjs/mol-plugin-ui/state/update-transform.js +3 -3
  471. package/lib/commonjs/mol-plugin-ui/structure/components.js +19 -19
  472. package/lib/commonjs/mol-plugin-ui/structure/focus.js +4 -4
  473. package/lib/commonjs/mol-plugin-ui/structure/generic.js +6 -6
  474. package/lib/commonjs/mol-plugin-ui/structure/measurements.js +13 -13
  475. package/lib/commonjs/mol-plugin-ui/structure/quick-styles.js +11 -11
  476. package/lib/commonjs/mol-plugin-ui/structure/selection.js +13 -13
  477. package/lib/commonjs/mol-plugin-ui/structure/source.js +12 -12
  478. package/lib/commonjs/mol-plugin-ui/structure/superposition.js +20 -20
  479. package/lib/commonjs/mol-plugin-ui/structure/volume.js +12 -12
  480. package/lib/commonjs/mol-plugin-ui/task.js +8 -8
  481. package/lib/commonjs/mol-plugin-ui/toast.js +6 -6
  482. package/lib/commonjs/mol-plugin-ui/viewport/canvas.js +5 -5
  483. package/lib/commonjs/mol-plugin-ui/viewport/help.js +14 -14
  484. package/lib/commonjs/mol-plugin-ui/viewport/screenshot.js +8 -8
  485. package/lib/commonjs/mol-plugin-ui/viewport/simple-settings.js +6 -6
  486. package/lib/commonjs/mol-plugin-ui/viewport.js +7 -7
  487. package/lib/commonjs/mol-repr/representation.js +4 -4
  488. package/lib/commonjs/mol-repr/shape/loci/angle.js +9 -9
  489. package/lib/commonjs/mol-repr/shape/loci/common.js +1 -1
  490. package/lib/commonjs/mol-repr/shape/loci/dihedral.js +14 -14
  491. package/lib/commonjs/mol-repr/shape/loci/distance.js +5 -5
  492. package/lib/commonjs/mol-repr/shape/loci/label.js +3 -3
  493. package/lib/commonjs/mol-repr/shape/loci/orientation.js +4 -4
  494. package/lib/commonjs/mol-repr/shape/loci/plane.js +2 -2
  495. package/lib/commonjs/mol-repr/shape/model/unitcell.js +2 -2
  496. package/lib/commonjs/mol-repr/shape/representation.js +2 -2
  497. package/lib/commonjs/mol-repr/structure/complex-representation.js +2 -2
  498. package/lib/commonjs/mol-repr/structure/complex-visual.js +12 -12
  499. package/lib/commonjs/mol-repr/structure/params.js +8 -8
  500. package/lib/commonjs/mol-repr/structure/registry.js +1 -1
  501. package/lib/commonjs/mol-repr/structure/representation/backbone.js +1 -1
  502. package/lib/commonjs/mol-repr/structure/representation/ball-and-stick.js +1 -1
  503. package/lib/commonjs/mol-repr/structure/representation/carbohydrate.js +1 -1
  504. package/lib/commonjs/mol-repr/structure/representation/cartoon.js +3 -3
  505. package/lib/commonjs/mol-repr/structure/representation/ellipsoid.js +1 -1
  506. package/lib/commonjs/mol-repr/structure/representation/gaussian-surface.js +1 -1
  507. package/lib/commonjs/mol-repr/structure/representation/gaussian-volume.js +1 -1
  508. package/lib/commonjs/mol-repr/structure/representation/label.js +1 -1
  509. package/lib/commonjs/mol-repr/structure/representation/line.js +1 -1
  510. package/lib/commonjs/mol-repr/structure/representation/molecular-surface.js +1 -1
  511. package/lib/commonjs/mol-repr/structure/representation/orientation.js +1 -1
  512. package/lib/commonjs/mol-repr/structure/representation/point.js +1 -1
  513. package/lib/commonjs/mol-repr/structure/representation/putty.js +1 -1
  514. package/lib/commonjs/mol-repr/structure/representation/spacefill.js +1 -1
  515. package/lib/commonjs/mol-repr/structure/representation.js +1 -1
  516. package/lib/commonjs/mol-repr/structure/units-representation.js +2 -2
  517. package/lib/commonjs/mol-repr/structure/units-visual.js +16 -16
  518. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +1 -1
  519. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-cylinder.js +21 -11
  520. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-line.d.ts +1 -1
  521. package/lib/commonjs/mol-repr/structure/visual/bond-inter-unit-line.js +11 -6
  522. package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-cylinder.js +17 -7
  523. package/lib/commonjs/mol-repr/structure/visual/bond-intra-unit-line.js +9 -4
  524. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-link-cylinder.js +11 -2
  525. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-symbol-mesh.js +1 -1
  526. package/lib/commonjs/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.js +11 -2
  527. package/lib/commonjs/mol-repr/structure/visual/element-cross.js +1 -1
  528. package/lib/commonjs/mol-repr/structure/visual/element-point.d.ts +1 -1
  529. package/lib/commonjs/mol-repr/structure/visual/element-point.js +23 -4
  530. package/lib/commonjs/mol-repr/structure/visual/element-sphere.js +1 -1
  531. package/lib/commonjs/mol-repr/structure/visual/ellipsoid-mesh.js +1 -1
  532. package/lib/commonjs/mol-repr/structure/visual/gaussian-density-volume.js +8 -9
  533. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +1 -1
  534. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-mesh.js +20 -20
  535. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +1 -1
  536. package/lib/commonjs/mol-repr/structure/visual/gaussian-surface-wireframe.js +7 -8
  537. package/lib/commonjs/mol-repr/structure/visual/label-text.js +1 -1
  538. package/lib/commonjs/mol-repr/structure/visual/molecular-surface-mesh.js +6 -6
  539. package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +1 -1
  540. package/lib/commonjs/mol-repr/structure/visual/molecular-surface-wireframe.js +7 -7
  541. package/lib/commonjs/mol-repr/structure/visual/nucleotide-block-mesh.js +1 -1
  542. package/lib/commonjs/mol-repr/structure/visual/nucleotide-ring-mesh.js +1 -1
  543. package/lib/commonjs/mol-repr/structure/visual/orientation-ellipsoid-mesh.js +1 -1
  544. package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-cylinder.js +1 -1
  545. package/lib/commonjs/mol-repr/structure/visual/polymer-backbone-sphere.js +1 -1
  546. package/lib/commonjs/mol-repr/structure/visual/polymer-direction-wedge.js +1 -1
  547. package/lib/commonjs/mol-repr/structure/visual/polymer-gap-cylinder.js +1 -1
  548. package/lib/commonjs/mol-repr/structure/visual/polymer-trace-mesh.js +1 -1
  549. package/lib/commonjs/mol-repr/structure/visual/polymer-tube-mesh.js +1 -1
  550. package/lib/commonjs/mol-repr/structure/visual/util/bond.js +2 -2
  551. package/lib/commonjs/mol-repr/structure/visual/util/common.d.ts +1 -3
  552. package/lib/commonjs/mol-repr/structure/visual/util/common.js +3 -28
  553. package/lib/commonjs/mol-repr/structure/visual/util/element.js +36 -2
  554. package/lib/commonjs/mol-repr/structure/visual/util/gaussian.js +13 -13
  555. package/lib/commonjs/mol-repr/structure/visual/util/link.d.ts +13 -3
  556. package/lib/commonjs/mol-repr/structure/visual/util/link.js +55 -6
  557. package/lib/commonjs/mol-repr/structure/visual/util/molecular-surface.js +5 -5
  558. package/lib/commonjs/mol-repr/structure/visual/util/polymer.js +4 -4
  559. package/lib/commonjs/mol-repr/util.js +1 -1
  560. package/lib/commonjs/mol-repr/volume/direct-volume.js +3 -3
  561. package/lib/commonjs/mol-repr/volume/isosurface.js +9 -9
  562. package/lib/commonjs/mol-repr/volume/registry.js +1 -1
  563. package/lib/commonjs/mol-repr/volume/representation.js +5 -5
  564. package/lib/commonjs/mol-repr/volume/slice.js +4 -4
  565. package/lib/commonjs/mol-script/language/builder.d.ts +1 -0
  566. package/lib/commonjs/mol-script/language/parser.js +7 -4
  567. package/lib/commonjs/mol-script/language/symbol-table/internal.js +1 -1
  568. package/lib/commonjs/mol-script/language/symbol-table/structure-query.js +1 -1
  569. package/lib/commonjs/mol-script/runtime/query/compiler.js +1 -1
  570. package/lib/commonjs/mol-script/script/mol-script/symbols.js +1 -1
  571. package/lib/commonjs/mol-state/action.js +1 -1
  572. package/lib/commonjs/mol-state/index.js +8 -8
  573. package/lib/commonjs/mol-state/state/builder.js +2 -2
  574. package/lib/commonjs/mol-state/state/selection.js +1 -1
  575. package/lib/commonjs/mol-state/state.js +21 -21
  576. package/lib/commonjs/mol-state/transform.js +4 -4
  577. package/lib/commonjs/mol-state/transformer.js +1 -1
  578. package/lib/commonjs/mol-task/execution/observable.js +5 -5
  579. package/lib/commonjs/mol-task/task.js +3 -3
  580. package/lib/commonjs/mol-task/util/chunked.js +2 -2
  581. package/lib/commonjs/mol-task/util/multistep.js +1 -1
  582. package/lib/commonjs/mol-task/util/scheduler.d.ts +2 -2
  583. package/lib/commonjs/mol-task/util/scheduler.js +8 -8
  584. package/lib/commonjs/mol-theme/color/atom-id.js +1 -1
  585. package/lib/commonjs/mol-theme/color/chain-id.js +1 -1
  586. package/lib/commonjs/mol-theme/color/element-index.js +1 -1
  587. package/lib/commonjs/mol-theme/color/entity-id.js +1 -1
  588. package/lib/commonjs/mol-theme/color/entity-source.js +2 -2
  589. package/lib/commonjs/mol-theme/color/hydrophobicity.js +2 -2
  590. package/lib/commonjs/mol-theme/color/model-index.js +1 -1
  591. package/lib/commonjs/mol-theme/color/operator-hkl.js +2 -2
  592. package/lib/commonjs/mol-theme/color/operator-name.js +1 -1
  593. package/lib/commonjs/mol-theme/color/polymer-id.js +2 -2
  594. package/lib/commonjs/mol-theme/color/polymer-index.js +2 -2
  595. package/lib/commonjs/mol-theme/color/unit-index.js +2 -2
  596. package/lib/commonjs/mol-theme/label.js +6 -6
  597. package/lib/commonjs/mol-theme/theme.js +3 -3
  598. package/lib/commonjs/mol-util/assets.js +7 -7
  599. package/lib/commonjs/mol-util/color/distinct.js +1 -1
  600. package/lib/commonjs/mol-util/color/palette.js +3 -3
  601. package/lib/commonjs/mol-util/color/scale.js +2 -2
  602. package/lib/commonjs/mol-util/data-source.js +14 -13
  603. package/lib/commonjs/mol-util/file-info.d.ts +1 -3
  604. package/lib/commonjs/mol-util/file-info.js +2 -10
  605. package/lib/commonjs/mol-util/graphql-client.js +4 -4
  606. package/lib/commonjs/mol-util/index.d.ts +1 -0
  607. package/lib/commonjs/mol-util/index.js +8 -2
  608. package/lib/commonjs/mol-util/input/input-observer.js +6 -6
  609. package/lib/commonjs/mol-util/make-dir.js +1 -1
  610. package/lib/commonjs/mol-util/material.js +2 -2
  611. package/lib/commonjs/mol-util/monadic-parser.js +2 -2
  612. package/lib/commonjs/mol-util/param-definition.js +7 -7
  613. package/lib/commonjs/mol-util/read.js +2 -2
  614. package/lib/commonjs/mol-util/retry-if.js +2 -2
  615. package/lib/commonjs/mol-util/string.js +1 -1
  616. package/lib/commonjs/mol-util/zip/deflate.js +4 -3
  617. package/lib/commonjs/mol-util/zip/inflate.js +2 -2
  618. package/lib/commonjs/mol-util/zip/zip.d.ts +7 -1
  619. package/lib/commonjs/mol-util/zip/zip.js +21 -16
  620. package/lib/commonjs/servers/common/file-handle.js +1 -1
  621. package/lib/commonjs/servers/common/swagger-ui/index.js +1 -1
  622. package/lib/commonjs/servers/model/config.d.ts +2 -2
  623. package/lib/commonjs/servers/model/config.js +5 -5
  624. package/lib/commonjs/servers/model/preprocess/converter.js +2 -2
  625. package/lib/commonjs/servers/model/preprocess/master.js +3 -3
  626. package/lib/commonjs/servers/model/preprocess/parallel.js +6 -6
  627. package/lib/commonjs/servers/model/preprocess/preprocess.js +4 -4
  628. package/lib/commonjs/servers/model/preprocess.js +1 -1
  629. package/lib/commonjs/servers/model/properties/providers/pdbe.js +8 -8
  630. package/lib/commonjs/servers/model/properties/providers/wwpdb.js +12 -12
  631. package/lib/commonjs/servers/model/property-provider.js +3 -3
  632. package/lib/commonjs/servers/model/query.js +1 -1
  633. package/lib/commonjs/servers/model/server/api-local.js +2 -2
  634. package/lib/commonjs/servers/model/server/api-schema.js +2 -2
  635. package/lib/commonjs/servers/model/server/api-web.js +5 -5
  636. package/lib/commonjs/servers/model/server/api.js +6 -6
  637. package/lib/commonjs/servers/model/server/query.js +15 -15
  638. package/lib/commonjs/servers/model/server/structure-wrapper.js +21 -21
  639. package/lib/commonjs/servers/model/server.js +2 -2
  640. package/lib/commonjs/servers/model/utils/fetch-props-pdbe.js +6 -6
  641. package/lib/commonjs/servers/model/utils/fetch-retry.js +3 -3
  642. package/lib/commonjs/servers/model/utils/writer.js +3 -3
  643. package/lib/commonjs/servers/plugin-state/config.js +1 -1
  644. package/lib/commonjs/servers/plugin-state/index.js +6 -6
  645. package/lib/commonjs/servers/volume/common/binary-schema.js +1 -1
  646. package/lib/commonjs/servers/volume/common/data-format.js +3 -3
  647. package/lib/commonjs/servers/volume/common/file.js +8 -8
  648. package/lib/commonjs/servers/volume/config.js +6 -6
  649. package/lib/commonjs/servers/volume/pack/format/ccp4.js +4 -4
  650. package/lib/commonjs/servers/volume/pack/format/dsn6.js +4 -4
  651. package/lib/commonjs/servers/volume/pack/format.js +3 -3
  652. package/lib/commonjs/servers/volume/pack/main.js +13 -13
  653. package/lib/commonjs/servers/volume/pack/sampling.js +13 -13
  654. package/lib/commonjs/servers/volume/pack/writer.js +2 -2
  655. package/lib/commonjs/servers/volume/pack.js +1 -1
  656. package/lib/commonjs/servers/volume/query.js +4 -4
  657. package/lib/commonjs/servers/volume/server/algebra/box.js +1 -1
  658. package/lib/commonjs/servers/volume/server/api.js +8 -8
  659. package/lib/commonjs/servers/volume/server/local-api.js +8 -8
  660. package/lib/commonjs/servers/volume/server/query/compose.js +8 -8
  661. package/lib/commonjs/servers/volume/server/query/execute.js +10 -10
  662. package/lib/commonjs/servers/volume/server/query/identify.js +2 -2
  663. package/lib/commonjs/servers/volume/server/web-api.js +7 -7
  664. package/lib/commonjs/servers/volume/server.js +2 -2
  665. package/lib/examples/alpha-orbitals/controls.js +2 -2
  666. package/lib/examples/alpha-orbitals/index.html +61 -61
  667. package/lib/examples/basic-wrapper/controls.js +1 -1
  668. package/lib/examples/basic-wrapper/index.html +137 -137
  669. package/lib/examples/lighting/index.html +88 -88
  670. package/lib/examples/proteopedia-wrapper/index.html +236 -236
  671. package/lib/examples/proteopedia-wrapper/ui/controls.js +1 -1
  672. package/lib/extensions/cellpack/model.js +4 -2
  673. package/lib/extensions/cellpack/state.js +2 -2
  674. package/lib/extensions/dnatco/confal-pyramids/color.d.ts +397 -2
  675. package/lib/extensions/dnatco/confal-pyramids/color.js +224 -132
  676. package/lib/extensions/dnatco/confal-pyramids/property.js +1 -3
  677. package/lib/extensions/dnatco/confal-pyramids/util.js +19 -20
  678. package/lib/extensions/geo-export/ui.js +2 -2
  679. package/lib/extensions/model-export/ui.js +2 -2
  680. package/lib/extensions/mp4-export/ui.js +2 -2
  681. package/lib/extensions/rcsb/assembly-symmetry/ui.js +3 -3
  682. package/lib/extensions/rcsb/validation-report/representation.js +19 -2
  683. package/lib/extensions/zenodo/index.d.ts +7 -0
  684. package/lib/extensions/zenodo/index.js +32 -0
  685. package/lib/extensions/zenodo/ui.d.ts +61 -0
  686. package/lib/extensions/zenodo/ui.js +303 -0
  687. package/lib/mol-canvas3d/camera.js +2 -1
  688. package/lib/mol-canvas3d/helper/camera-helper.js +1 -1
  689. package/lib/mol-canvas3d/helper/handle-helper.js +1 -1
  690. package/lib/mol-canvas3d/helper/interaction-events.js +1 -1
  691. package/lib/mol-geo/geometry/cylinders/cylinders.d.ts +2 -2
  692. package/lib/mol-geo/geometry/lines/lines.d.ts +0 -1
  693. package/lib/mol-geo/geometry/mesh/color-smoothing.d.ts +1 -1
  694. package/lib/mol-geo/geometry/mesh/color-smoothing.js +5 -3
  695. package/lib/mol-geo/geometry/points/points.d.ts +1 -1
  696. package/lib/mol-geo/geometry/text/text-builder.js +2 -1
  697. package/lib/mol-geo/geometry/texture-mesh/color-smoothing.d.ts +1 -1
  698. package/lib/mol-geo/geometry/texture-mesh/color-smoothing.js +6 -4
  699. package/lib/mol-gl/shader-code.js +2 -1
  700. package/lib/mol-gl/webgl/buffer.js +2 -3
  701. package/lib/mol-gl/webgl/context.d.ts +1 -1
  702. package/lib/mol-gl/webgl/context.js +2 -2
  703. package/lib/mol-io/common/binary-cif/classifier.js +3 -2
  704. package/lib/mol-io/common/binary-cif/decoder.js +4 -3
  705. package/lib/mol-io/common/io-buffer.d.ts +206 -0
  706. package/lib/mol-io/common/io-buffer.js +405 -0
  707. package/lib/mol-io/common/netcdf/reader.d.ts +78 -0
  708. package/lib/mol-io/common/netcdf/reader.js +456 -0
  709. package/lib/mol-io/reader/cif/schema/mmcif.d.ts +1 -1
  710. package/lib/mol-io/reader/nctraj/parser.d.ts +18 -0
  711. package/lib/mol-io/reader/nctraj/parser.js +97 -0
  712. package/lib/mol-io/reader/prmtop/parser.d.ts +58 -0
  713. package/lib/mol-io/reader/prmtop/parser.js +168 -0
  714. package/lib/mol-io/reader/top/parser.d.ts +37 -0
  715. package/lib/mol-io/reader/top/parser.js +299 -0
  716. package/lib/mol-io/reader/trr/parser.d.ts +22 -0
  717. package/lib/mol-io/reader/trr/parser.js +142 -0
  718. package/lib/mol-io/writer/cif/encoder.js +2 -1
  719. package/lib/mol-math/geometry/common.d.ts +2 -1
  720. package/lib/mol-math/geometry/common.js +1 -1
  721. package/lib/mol-math/geometry/gaussian-density/cpu.d.ts +1 -1
  722. package/lib/mol-math/geometry/gaussian-density/cpu.js +2 -2
  723. package/lib/mol-math/geometry/gaussian-density/gpu.d.ts +1 -1
  724. package/lib/mol-math/geometry/gaussian-density/gpu.js +7 -7
  725. package/lib/mol-math/geometry/gaussian-density.d.ts +2 -2
  726. package/lib/mol-math/geometry/gaussian-density.js +1 -1
  727. package/lib/mol-math/geometry/molecular-surface.d.ts +2 -1
  728. package/lib/mol-math/geometry/molecular-surface.js +2 -2
  729. package/lib/mol-math/geometry/primitives/box3d.js +2 -1
  730. package/lib/mol-math/geometry/primitives/sphere3d.js +12 -6
  731. package/lib/mol-model/sequence/sequence.js +2 -1
  732. package/lib/mol-model/structure/model/types/saccharides.d.ts +8 -0
  733. package/lib/mol-model/structure/model/types/saccharides.js +8 -0
  734. package/lib/mol-model/structure/structure/carbohydrates/constants.d.ts +1 -1
  735. package/lib/mol-model/structure/structure/carbohydrates/constants.js +6 -9
  736. package/lib/mol-model/structure/structure/structure.js +4 -1
  737. package/lib/mol-model/structure/structure/unit/bonds/inter-compute.d.ts +1 -0
  738. package/lib/mol-model/structure/structure/unit/bonds/inter-compute.js +4 -2
  739. package/lib/mol-model/structure/structure/unit.js +1 -18
  740. package/lib/mol-model-formats/structure/basic/atomic.d.ts +1 -1
  741. package/lib/mol-model-formats/structure/basic/atomic.js +1 -14
  742. package/lib/mol-model-formats/structure/basic/parser.d.ts +1 -1
  743. package/lib/mol-model-formats/structure/basic/parser.js +1 -1
  744. package/lib/mol-model-formats/structure/basic/schema.d.ts +2 -2
  745. package/lib/mol-model-formats/structure/basic/schema.js +7 -2
  746. package/lib/mol-model-formats/structure/basic/util.d.ts +33 -2
  747. package/lib/mol-model-formats/structure/basic/util.js +24 -1
  748. package/lib/mol-model-formats/structure/cif-core.js +4 -4
  749. package/lib/mol-model-formats/structure/common/component.js +5 -1
  750. package/lib/mol-model-formats/structure/cube.js +3 -3
  751. package/lib/mol-model-formats/structure/gro.js +3 -1
  752. package/lib/mol-model-formats/structure/mmcif.d.ts +1 -1
  753. package/lib/mol-model-formats/structure/mmcif.js +4 -2
  754. package/lib/mol-model-formats/structure/mol.js +3 -3
  755. package/lib/mol-model-formats/structure/mol2.js +4 -4
  756. package/lib/mol-model-formats/structure/nctraj.d.ts +9 -0
  757. package/lib/mol-model-formats/structure/nctraj.js +56 -0
  758. package/lib/mol-model-formats/structure/pdb.d.ts +1 -1
  759. package/lib/mol-model-formats/structure/pdb.js +5 -3
  760. package/lib/mol-model-formats/structure/prmtop.d.ts +16 -0
  761. package/lib/mol-model-formats/structure/prmtop.js +144 -0
  762. package/lib/mol-model-formats/structure/property/symmetry.js +11 -1
  763. package/lib/mol-model-formats/structure/psf.js +3 -1
  764. package/lib/mol-model-formats/structure/top.d.ts +16 -0
  765. package/lib/mol-model-formats/structure/top.js +186 -0
  766. package/lib/mol-model-formats/structure/trr.d.ts +9 -0
  767. package/lib/mol-model-formats/structure/trr.js +42 -0
  768. package/lib/mol-model-formats/structure/util.d.ts +2 -2
  769. package/lib/mol-model-formats/structure/util.js +19 -20
  770. package/lib/mol-model-formats/structure/xyz.js +2 -2
  771. package/lib/mol-model-props/computed/representations/interactions-inter-unit-cylinder.js +9 -3
  772. package/lib/mol-model-props/computed/representations/interactions-intra-unit-cylinder.js +10 -5
  773. package/lib/mol-model-props/integrative/cross-link-restraint/representation.js +10 -1
  774. package/lib/mol-plugin/behavior/dynamic/volume-streaming/model.d.ts +2 -3
  775. package/lib/mol-plugin/context.d.ts +2 -1
  776. package/lib/mol-plugin/context.js +4 -3
  777. package/lib/mol-plugin/spec.js +1 -1
  778. package/lib/mol-plugin/version.js +2 -2
  779. package/lib/mol-plugin-state/actions/file.d.ts +1 -1
  780. package/lib/mol-plugin-state/actions/file.js +88 -55
  781. package/lib/mol-plugin-state/actions/structure.d.ts +11 -2
  782. package/lib/mol-plugin-state/actions/structure.js +174 -4
  783. package/lib/mol-plugin-state/actions/volume.js +3 -2
  784. package/lib/mol-plugin-state/formats/{structure.d.ts → coordinates.d.ts} +34 -18
  785. package/lib/mol-plugin-state/formats/coordinates.js +67 -0
  786. package/lib/mol-plugin-state/formats/registry.d.ts +3 -3
  787. package/lib/mol-plugin-state/formats/registry.js +13 -8
  788. package/lib/mol-plugin-state/formats/topology.d.ts +73 -0
  789. package/lib/mol-plugin-state/formats/topology.js +84 -0
  790. package/lib/mol-plugin-state/helpers/root-structure.js +1 -1
  791. package/lib/mol-plugin-state/helpers/structure-component.js +2 -1
  792. package/lib/mol-plugin-state/manager/snapshots.js +4 -4
  793. package/lib/mol-plugin-state/objects.d.ts +47 -1
  794. package/lib/mol-plugin-state/objects.js +17 -1
  795. package/lib/mol-plugin-state/transforms/data.d.ts +6 -0
  796. package/lib/mol-plugin-state/transforms/data.js +61 -9
  797. package/lib/mol-plugin-state/transforms/model.d.ts +14 -2
  798. package/lib/mol-plugin-state/transforms/model.js +112 -3
  799. package/lib/mol-plugin-ui/base.js +1 -1
  800. package/lib/mol-plugin-ui/controls/action-menu.js +7 -7
  801. package/lib/mol-plugin-ui/controls/color.js +3 -3
  802. package/lib/mol-plugin-ui/controls/common.js +10 -10
  803. package/lib/mol-plugin-ui/controls/icons.js +70 -70
  804. package/lib/mol-plugin-ui/controls/legend.js +3 -3
  805. package/lib/mol-plugin-ui/controls/line-graph/line-graph-component.js +1 -1
  806. package/lib/mol-plugin-ui/controls/parameters.js +51 -51
  807. package/lib/mol-plugin-ui/controls/screenshot.js +2 -2
  808. package/lib/mol-plugin-ui/controls/slider.js +5 -5
  809. package/lib/mol-plugin-ui/controls.js +7 -7
  810. package/lib/mol-plugin-ui/custom/volume.js +4 -4
  811. package/lib/mol-plugin-ui/left-panel.d.ts +8 -1
  812. package/lib/mol-plugin-ui/left-panel.js +33 -12
  813. package/lib/mol-plugin-ui/plugin.js +10 -10
  814. package/lib/mol-plugin-ui/sequence/sequence.js +1 -1
  815. package/lib/mol-plugin-ui/sequence.js +5 -5
  816. package/lib/mol-plugin-ui/skin/base/base.scss +32 -32
  817. package/lib/mol-plugin-ui/skin/base/components/controls-base.scss +333 -333
  818. package/lib/mol-plugin-ui/skin/base/components/controls.scss +418 -418
  819. package/lib/mol-plugin-ui/skin/base/components/help.scss +27 -27
  820. package/lib/mol-plugin-ui/skin/base/components/line-graph.scss +67 -67
  821. package/lib/mol-plugin-ui/skin/base/components/log.scss +100 -100
  822. package/lib/mol-plugin-ui/skin/base/components/misc.scss +643 -643
  823. package/lib/mol-plugin-ui/skin/base/components/sequence.scss +125 -125
  824. package/lib/mol-plugin-ui/skin/base/components/slider.scss +165 -165
  825. package/lib/mol-plugin-ui/skin/base/components/tasks.scss +99 -99
  826. package/lib/mol-plugin-ui/skin/base/components/toast.scss +83 -83
  827. package/lib/mol-plugin-ui/skin/base/components/transformer.scss +163 -163
  828. package/lib/mol-plugin-ui/skin/base/components/viewport.scss +128 -128
  829. package/lib/mol-plugin-ui/skin/base/layout/common.scss +71 -71
  830. package/lib/mol-plugin-ui/skin/base/layout/controls-landscape.scss +89 -89
  831. package/lib/mol-plugin-ui/skin/base/layout/controls-outside.scss +98 -98
  832. package/lib/mol-plugin-ui/skin/base/layout/controls-portrait.scss +108 -108
  833. package/lib/mol-plugin-ui/skin/base/layout.scss +40 -40
  834. package/lib/mol-plugin-ui/skin/base/logo.scss +12 -12
  835. package/lib/mol-plugin-ui/skin/base/normalize.scss +209 -209
  836. package/lib/mol-plugin-ui/skin/base/ui.scss +40 -40
  837. package/lib/mol-plugin-ui/skin/base/variables.scss +85 -85
  838. package/lib/mol-plugin-ui/skin/blue.scss +1 -1
  839. package/lib/mol-plugin-ui/skin/colors/blue.scss +23 -23
  840. package/lib/mol-plugin-ui/skin/colors/dark.scss +23 -23
  841. package/lib/mol-plugin-ui/skin/colors/light.scss +29 -29
  842. package/lib/mol-plugin-ui/skin/dark.scss +1 -1
  843. package/lib/mol-plugin-ui/skin/light.scss +1 -1
  844. package/lib/mol-plugin-ui/state/actions.js +1 -1
  845. package/lib/mol-plugin-ui/state/animation.js +1 -1
  846. package/lib/mol-plugin-ui/state/common.js +7 -7
  847. package/lib/mol-plugin-ui/state/snapshots.js +9 -9
  848. package/lib/mol-plugin-ui/state/tree.js +14 -14
  849. package/lib/mol-plugin-ui/state/update-transform.js +1 -1
  850. package/lib/mol-plugin-ui/structure/components.js +10 -10
  851. package/lib/mol-plugin-ui/structure/focus.js +1 -1
  852. package/lib/mol-plugin-ui/structure/generic.js +4 -4
  853. package/lib/mol-plugin-ui/structure/measurements.js +8 -8
  854. package/lib/mol-plugin-ui/structure/quick-styles.js +2 -2
  855. package/lib/mol-plugin-ui/structure/selection.js +7 -7
  856. package/lib/mol-plugin-ui/structure/source.js +4 -4
  857. package/lib/mol-plugin-ui/structure/superposition.js +8 -8
  858. package/lib/mol-plugin-ui/structure/volume.js +4 -4
  859. package/lib/mol-plugin-ui/task.js +5 -5
  860. package/lib/mol-plugin-ui/toast.js +4 -4
  861. package/lib/mol-plugin-ui/viewport/canvas.js +3 -3
  862. package/lib/mol-plugin-ui/viewport/help.js +8 -8
  863. package/lib/mol-plugin-ui/viewport/screenshot.js +3 -3
  864. package/lib/mol-plugin-ui/viewport/simple-settings.js +1 -1
  865. package/lib/mol-plugin-ui/viewport.js +4 -4
  866. package/lib/mol-repr/structure/visual/bond-inter-unit-cylinder.d.ts +1 -1
  867. package/lib/mol-repr/structure/visual/bond-inter-unit-cylinder.js +20 -10
  868. package/lib/mol-repr/structure/visual/bond-inter-unit-line.d.ts +1 -1
  869. package/lib/mol-repr/structure/visual/bond-inter-unit-line.js +10 -5
  870. package/lib/mol-repr/structure/visual/bond-intra-unit-cylinder.js +16 -6
  871. package/lib/mol-repr/structure/visual/bond-intra-unit-line.js +8 -3
  872. package/lib/mol-repr/structure/visual/carbohydrate-link-cylinder.js +10 -1
  873. package/lib/mol-repr/structure/visual/carbohydrate-terminal-link-cylinder.js +10 -1
  874. package/lib/mol-repr/structure/visual/element-point.d.ts +1 -1
  875. package/lib/mol-repr/structure/visual/element-point.js +22 -3
  876. package/lib/mol-repr/structure/visual/gaussian-density-volume.js +2 -3
  877. package/lib/mol-repr/structure/visual/gaussian-surface-mesh.d.ts +1 -1
  878. package/lib/mol-repr/structure/visual/gaussian-surface-mesh.js +10 -10
  879. package/lib/mol-repr/structure/visual/gaussian-surface-wireframe.d.ts +1 -1
  880. package/lib/mol-repr/structure/visual/gaussian-surface-wireframe.js +4 -5
  881. package/lib/mol-repr/structure/visual/molecular-surface-mesh.js +4 -4
  882. package/lib/mol-repr/structure/visual/molecular-surface-wireframe.d.ts +1 -1
  883. package/lib/mol-repr/structure/visual/molecular-surface-wireframe.js +5 -5
  884. package/lib/mol-repr/structure/visual/util/common.d.ts +1 -3
  885. package/lib/mol-repr/structure/visual/util/common.js +1 -24
  886. package/lib/mol-repr/structure/visual/util/element.js +36 -2
  887. package/lib/mol-repr/structure/visual/util/link.d.ts +13 -3
  888. package/lib/mol-repr/structure/visual/util/link.js +55 -6
  889. package/lib/mol-script/language/builder.d.ts +1 -0
  890. package/lib/mol-script/language/parser.js +7 -4
  891. package/lib/mol-task/util/scheduler.d.ts +2 -2
  892. package/lib/mol-task/util/scheduler.js +7 -7
  893. package/lib/mol-theme/color/hydrophobicity.js +2 -2
  894. package/lib/mol-util/data-source.js +2 -1
  895. package/lib/mol-util/file-info.d.ts +1 -3
  896. package/lib/mol-util/file-info.js +2 -10
  897. package/lib/mol-util/index.d.ts +1 -0
  898. package/lib/mol-util/index.js +5 -0
  899. package/lib/mol-util/zip/deflate.js +2 -1
  900. package/lib/mol-util/zip/zip.d.ts +7 -1
  901. package/lib/mol-util/zip/zip.js +5 -1
  902. package/lib/servers/model/config.d.ts +2 -2
  903. package/package.json +160 -160
  904. package/lib/commonjs/mol-plugin-state/formats/structure.js +0 -64
  905. package/lib/mol-plugin-state/formats/structure.js +0 -61
@@ -0,0 +1,146 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) 2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
+ *
5
+ * Adapted from NGL.
6
+ *
7
+ * @author Alexander Rose <alexander.rose@weirdbyte.de>
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.parseTrr = void 0;
11
+ var tslib_1 = require("tslib");
12
+ var mol_task_1 = require("../../../mol-task");
13
+ var result_1 = require("../result");
14
+ function parseInternal(data) {
15
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
16
+ 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;
17
+ return tslib_1.__generator(this, function (_a) {
18
+ dv = new DataView(data.buffer);
19
+ f = {
20
+ frames: [],
21
+ boxes: [],
22
+ times: [],
23
+ timeOffset: 0,
24
+ deltaTime: 0
25
+ };
26
+ coordinates = f.frames;
27
+ boxes = f.boxes;
28
+ times = f.times;
29
+ offset = 0;
30
+ while (true) {
31
+ // const magicnum = dv.getInt32(offset)
32
+ // const i1 = dv.getFloat32(offset + 4)
33
+ offset += 8;
34
+ versionSize = dv.getInt32(offset);
35
+ offset += 4;
36
+ offset += versionSize;
37
+ boxSize = dv.getInt32(offset + 8);
38
+ virSize = dv.getInt32(offset + 12);
39
+ presSize = dv.getInt32(offset + 16);
40
+ coordSize = dv.getInt32(offset + 28);
41
+ velocitySize = dv.getInt32(offset + 32);
42
+ forceSize = dv.getInt32(offset + 36);
43
+ natoms = dv.getInt32(offset + 40);
44
+ // const step = dv.getInt32(offset + 44)
45
+ // const nre = dv.getInt32(offset + 48)
46
+ offset += 52;
47
+ floatSize = boxSize / 9;
48
+ natoms3 = natoms * 3;
49
+ // let lambda
50
+ if (floatSize === 8) {
51
+ times.push(dv.getFloat64(offset));
52
+ // lambda = dv.getFloat64(offset + 8)
53
+ }
54
+ else {
55
+ times.push(dv.getFloat32(offset));
56
+ // lambda = dv.getFloat32(offset + 4)
57
+ }
58
+ offset += 2 * floatSize;
59
+ if (boxSize) {
60
+ box = new Float32Array(9);
61
+ if (floatSize === 8) {
62
+ for (i = 0; i < 9; ++i) {
63
+ box[i] = dv.getFloat64(offset) * 10;
64
+ offset += 8;
65
+ }
66
+ }
67
+ else {
68
+ for (i = 0; i < 9; ++i) {
69
+ box[i] = dv.getFloat32(offset) * 10;
70
+ offset += 4;
71
+ }
72
+ }
73
+ boxes.push(box);
74
+ }
75
+ // ignore, unused
76
+ offset += virSize;
77
+ // ignore, unused
78
+ offset += presSize;
79
+ if (coordSize) {
80
+ x = new Float32Array(natoms);
81
+ y = new Float32Array(natoms);
82
+ z = new Float32Array(natoms);
83
+ if (floatSize === 8) {
84
+ for (i = 0; i < natoms; ++i) {
85
+ x[i] = dv.getFloat64(offset) * 10;
86
+ y[i] = dv.getFloat64(offset + 8) * 10;
87
+ z[i] = dv.getFloat64(offset + 16) * 10;
88
+ offset += 24;
89
+ }
90
+ }
91
+ else {
92
+ tmp = new Uint32Array(data.buffer, offset, natoms3);
93
+ for (i = 0; i < natoms3; ++i) {
94
+ value = tmp[i];
95
+ tmp[i] = (((value & 0xFF) << 24) | ((value & 0xFF00) << 8) |
96
+ ((value >> 8) & 0xFF00) | ((value >> 24) & 0xFF));
97
+ }
98
+ frameCoords = new Float32Array(data.buffer, offset, natoms3);
99
+ for (i = 0; i < natoms; ++i) {
100
+ x[i] = frameCoords[i * 3] * 10;
101
+ y[i] = frameCoords[i * 3 + 1] * 10;
102
+ z[i] = frameCoords[i * 3 + 2] * 10;
103
+ offset += 12;
104
+ }
105
+ }
106
+ coordinates.push({ count: natoms, x: x, y: y, z: z });
107
+ }
108
+ // ignore, unused
109
+ offset += velocitySize;
110
+ // ignore, unused
111
+ offset += forceSize;
112
+ if (offset >= data.byteLength)
113
+ break;
114
+ }
115
+ if (times.length >= 1) {
116
+ f.timeOffset = times[0];
117
+ }
118
+ if (times.length >= 2) {
119
+ f.deltaTime = times[1] - times[0];
120
+ }
121
+ return [2 /*return*/, f];
122
+ });
123
+ });
124
+ }
125
+ function parseTrr(data) {
126
+ var _this = this;
127
+ return mol_task_1.Task.create('Parse TRR', function (ctx) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
128
+ var file, e_1;
129
+ return tslib_1.__generator(this, function (_a) {
130
+ switch (_a.label) {
131
+ case 0:
132
+ _a.trys.push([0, 2, , 3]);
133
+ ctx.update({ canAbort: true, message: 'Parsing trajectory...' });
134
+ return [4 /*yield*/, parseInternal(data)];
135
+ case 1:
136
+ file = _a.sent();
137
+ return [2 /*return*/, result_1.ReaderResult.success(file)];
138
+ case 2:
139
+ e_1 = _a.sent();
140
+ return [2 /*return*/, result_1.ReaderResult.error('' + e_1)];
141
+ case 3: return [2 /*return*/];
142
+ }
143
+ });
144
+ }); });
145
+ }
146
+ exports.parseTrr = parseTrr;
@@ -141,9 +141,9 @@ function undefinedError() {
141
141
  throw new Error('(xdrfile error) Undefined error.');
142
142
  }
143
143
  function parseInternal(ctx, data) {
144
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
144
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
145
145
  var dv, f, coordinates, boxes, times, minMaxInt, sizeint, bitsizeint, sizesmall, thiscoord, prevcoord, offset, buf, frameCoords, natoms, box, i, i, lfp, lsize, precision, bitsize, smallidx, tmpIdx, smaller, smallnum, adz, invPrecision, run_1, i, flag, isSmaller, k, tmpSwap, c;
146
- return (0, tslib_1.__generator)(this, function (_a) {
146
+ return tslib_1.__generator(this, function (_a) {
147
147
  switch (_a.label) {
148
148
  case 0:
149
149
  dv = new DataView(data.buffer, data.byteOffset);
@@ -354,9 +354,9 @@ function parseInternal(ctx, data) {
354
354
  }
355
355
  function parseXtc(data) {
356
356
  var _this = this;
357
- return mol_task_1.Task.create('Parse XTC', function (ctx) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
357
+ return mol_task_1.Task.create('Parse XTC', function (ctx) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
358
358
  var file, e_1;
359
- return (0, tslib_1.__generator)(this, function (_a) {
359
+ return tslib_1.__generator(this, function (_a) {
360
360
  switch (_a.label) {
361
361
  case 0:
362
362
  _a.trys.push([0, 2, , 3]);
@@ -51,8 +51,8 @@ function parseInternal(data) {
51
51
  }
52
52
  function parseXyz(data) {
53
53
  var _this = this;
54
- return mol_task_1.Task.create('Parse Mol', function () { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
55
- return (0, tslib_1.__generator)(this, function (_a) {
54
+ return mol_task_1.Task.create('Parse Mol', function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
55
+ return tslib_1.__generator(this, function (_a) {
56
56
  return [2 /*return*/, parseInternal(data)];
57
57
  });
58
58
  }); });
@@ -10,6 +10,7 @@ exports.Encoder = exports.Category = exports.Field = void 0;
10
10
  var tslib_1 = require("tslib");
11
11
  var iterator_1 = require("../../../mol-data/iterator");
12
12
  var binary_cif_1 = require("../../common/binary-cif");
13
+ var type_helpers_1 = require("../../../mol-util/type-helpers");
13
14
  var Field;
14
15
  (function (Field) {
15
16
  function str(name, value, params) {
@@ -199,7 +200,7 @@ function columnTensorValue(k) {
199
200
  }
200
201
  return function (i, d) {
201
202
  var _a;
202
- return (_a = d[k].schema.space).get.apply(_a, (0, tslib_1.__spreadArray)([d[k].value(i)], coords, false));
203
+ return (_a = d[k].schema.space).get.apply(_a, tslib_1.__spreadArray([d[k].value(i)], coords, false));
203
204
  };
204
205
  }
205
206
  function columnValueKind(k) {
@@ -262,7 +263,7 @@ function cifFieldsFromTableSchema(schema) {
262
263
  fields.push.apply(fields, getTensorDefinitions(k, t.space));
263
264
  }
264
265
  else {
265
- throw new Error("Unknown valueType ".concat(t.valueType));
266
+ (0, type_helpers_1.assertUnreachable)(t.valueType);
266
267
  }
267
268
  }
268
269
  return fields;
@@ -10,7 +10,7 @@ exports.CifWriter = void 0;
10
10
  var tslib_1 = require("tslib");
11
11
  var text_1 = require("./cif/encoder/text");
12
12
  var binary_1 = require("./cif/encoder/binary");
13
- var _Encoder = (0, tslib_1.__importStar)(require("./cif/encoder"));
13
+ var _Encoder = tslib_1.__importStar(require("./cif/encoder"));
14
14
  var binary_cif_1 = require("../common/binary-cif");
15
15
  var CifWriter;
16
16
  (function (CifWriter) {
@@ -9,7 +9,7 @@ exports.LigandEncoder = void 0;
9
9
  var tslib_1 = require("tslib");
10
10
  var mol_util_1 = require("../../mol-util");
11
11
  function Atom(partial) {
12
- return (0, tslib_1.__assign)({}, partial);
12
+ return tslib_1.__assign({}, partial);
13
13
  }
14
14
  var LigandEncoder = /** @class */ (function () {
15
15
  function LigandEncoder(encoder, metaInformation, hydrogens) {
@@ -13,7 +13,7 @@ var ligand_encoder_1 = require("../ligand-encoder");
13
13
  // specification: http://c4.cabrillo.edu/404/ctfile.pdf
14
14
  // SDF wraps MOL and allows for multiple molecules per file as well as additional properties
15
15
  var MolEncoder = /** @class */ (function (_super) {
16
- (0, tslib_1.__extends)(MolEncoder, _super);
16
+ tslib_1.__extends(MolEncoder, _super);
17
17
  function MolEncoder(encoder, metaInformation, hydrogens, terminator) {
18
18
  if (terminator === void 0) { terminator = ''; }
19
19
  var _this = _super.call(this, encoder, metaInformation, hydrogens) || this;
@@ -16,7 +16,7 @@ var types_1 = require("../../../mol-model/structure/model/types");
16
16
  var NON_METAL_ATOMS = 'H D B C N O F Si P S Cl As Se Br Te I At He Ne Ar Kr Xe Rn'.split(' ');
17
17
  // specification: http://chemyang.ccnu.edu.cn/ccb/server/AIMMS/mol2.pdf
18
18
  var Mol2Encoder = /** @class */ (function (_super) {
19
- (0, tslib_1.__extends)(Mol2Encoder, _super);
19
+ tslib_1.__extends(Mol2Encoder, _super);
20
20
  function Mol2Encoder(encoder, metaInformation, hydrogens) {
21
21
  var _this = _super.call(this, encoder, metaInformation, hydrogens) || this;
22
22
  _this.out = mol_util_1.StringBuilder.create();
@@ -88,7 +88,7 @@ var BoundaryHelper = /** @class */ (function () {
88
88
  this.centroidHelper.radiusSphereStep(center, radius);
89
89
  };
90
90
  BoundaryHelper.prototype.getSphere = function (sphere) {
91
- return geometry_1.Sphere3D.setExtrema(this.centroidHelper.getSphere(sphere), (0, tslib_1.__spreadArray)([], this.extrema, true));
91
+ return geometry_1.Sphere3D.setExtrema(this.centroidHelper.getSphere(sphere), tslib_1.__spreadArray([], this.extrema, true));
92
92
  };
93
93
  BoundaryHelper.prototype.getBox = function (box) {
94
94
  return box3d_1.Box3D.fromVec3Array(box || (0, box3d_1.Box3D)(), this.extrema);
@@ -109,16 +109,16 @@ function getEposDir(quality) {
109
109
  var dir;
110
110
  switch (quality) {
111
111
  case '6':
112
- dir = (0, tslib_1.__spreadArray)([], Type001, true);
112
+ dir = tslib_1.__spreadArray([], Type001, true);
113
113
  break;
114
114
  case '14':
115
- dir = (0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)([], Type001, true), Type111, true);
115
+ dir = tslib_1.__spreadArray(tslib_1.__spreadArray([], Type001, true), Type111, true);
116
116
  break;
117
117
  case '26':
118
- dir = (0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)([], Type001, true), Type111, true), Type011, true);
118
+ dir = tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray([], Type001, true), Type111, true), Type011, true);
119
119
  break;
120
120
  case '98':
121
- dir = (0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)([], Type001, true), Type111, true), Type011, true), Type012, true), Type112, true), Type122, true);
121
+ dir = tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray([], Type001, true), Type111, true), Type011, true), Type012, true), Type112, true), Type122, true);
122
122
  break;
123
123
  }
124
124
  return dir.map(function (a) {
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2018-2019 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>
@@ -24,6 +24,7 @@ export declare type DensityData = {
24
24
  field: Tensor;
25
25
  idField: Tensor;
26
26
  resolution: number;
27
+ maxRadius: number;
27
28
  };
28
29
  export declare type DensityTextureData = {
29
30
  transform: Mat4;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Copyright (c) 2018-2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
4
  *
5
5
  * @author David Sehnal <david.sehnal@gmail.com>
6
6
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2018-2020 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 Alexander Rose <alexander.rose@weirdbyte.de>
5
5
  */
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Copyright (c) 2018-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
4
  *
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
6
6
  */
@@ -12,7 +12,7 @@ var linear_algebra_1 = require("../../linear-algebra");
12
12
  var int_1 = require("../../../mol-data/int");
13
13
  var approx_1 = require("../../approx");
14
14
  function GaussianDensityCPU(ctx, position, box, radius, props) {
15
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
15
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
16
16
  function accumulateRange(begI, endI) {
17
17
  for (var i = begI; i < endI; ++i) {
18
18
  var j = int_1.OrderedSet.getAt(indices, i);
@@ -63,9 +63,9 @@ function GaussianDensityCPU(ctx, position, box, radius, props) {
63
63
  }
64
64
  }
65
65
  function accumulate() {
66
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
66
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
67
67
  var i;
68
- return (0, tslib_1.__generator)(this, function (_a) {
68
+ return tslib_1.__generator(this, function (_a) {
69
69
  switch (_a.label) {
70
70
  case 0:
71
71
  i = 0;
@@ -87,7 +87,7 @@ function GaussianDensityCPU(ctx, position, box, radius, props) {
87
87
  });
88
88
  }
89
89
  var resolution, radiusOffset, smoothness, scaleFactor, indices, x, y, z, id, n, radii, maxRadius, i, r, pad, expandedBox, min, scaledBox, dim, space, data, field, idData, idField, dimX, dimY, dimZ, iu, iv, iuv, gridx, gridy, gridz, densData, alpha, updateChunk, transform;
90
- return (0, tslib_1.__generator)(this, function (_a) {
90
+ return tslib_1.__generator(this, function (_a) {
91
91
  switch (_a.label) {
92
92
  case 0:
93
93
  resolution = props.resolution, radiusOffset = props.radiusOffset, smoothness = props.smoothness;
@@ -130,7 +130,7 @@ function GaussianDensityCPU(ctx, position, box, radius, props) {
130
130
  transform = linear_algebra_1.Mat4.identity();
131
131
  linear_algebra_1.Mat4.fromScaling(transform, linear_algebra_1.Vec3.create(resolution, resolution, resolution));
132
132
  linear_algebra_1.Mat4.setTranslation(transform, expandedBox.min);
133
- return [2 /*return*/, { field: field, idField: idField, transform: transform, radiusFactor: 1, resolution: resolution }];
133
+ return [2 /*return*/, { field: field, idField: idField, transform: transform, radiusFactor: 1, resolution: resolution, maxRadius: maxRadius }];
134
134
  }
135
135
  });
136
136
  });
@@ -1,5 +1,5 @@
1
1
  /**
2
- * Copyright (c) 2017-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
2
+ * Copyright (c) 2017-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
  * @author Michael Krone <michael.krone@uni-tuebingen.de>
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Copyright (c) 2017-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ * Copyright (c) 2017-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
4
  *
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
6
6
  * @author Michael Krone <michael.krone@uni-tuebingen.de>
@@ -59,11 +59,11 @@ function GaussianDensityGPU(position, box, radius, props, webgl) {
59
59
  // it's faster than texture3d
60
60
  // console.time('GaussianDensityTexture2d')
61
61
  var tmpTexture = getTexture('tmp', webgl, 'image-uint8', 'rgba', 'ubyte', 'linear');
62
- var _a = calcGaussianDensityTexture2d(webgl, position, box, radius, false, props, tmpTexture), scale = _a.scale, bbox = _a.bbox, texture = _a.texture, gridDim = _a.gridDim, gridTexDim = _a.gridTexDim, radiusFactor = _a.radiusFactor, resolution = _a.resolution;
62
+ var _a = calcGaussianDensityTexture2d(webgl, position, box, radius, false, props, tmpTexture), scale = _a.scale, bbox = _a.bbox, texture = _a.texture, gridDim = _a.gridDim, gridTexDim = _a.gridTexDim, radiusFactor = _a.radiusFactor, resolution = _a.resolution, maxRadius = _a.maxRadius;
63
63
  // webgl.waitForGpuCommandsCompleteSync()
64
64
  // console.timeEnd('GaussianDensityTexture2d')
65
65
  var _b = fieldFromTexture2d(webgl, texture, gridDim, gridTexDim), field = _b.field, idField = _b.idField;
66
- return { field: field, idField: idField, transform: getTransform(scale, bbox), radiusFactor: radiusFactor, resolution: resolution };
66
+ return { field: field, idField: idField, transform: getTransform(scale, bbox), radiusFactor: radiusFactor, resolution: resolution, maxRadius: maxRadius };
67
67
  }
68
68
  exports.GaussianDensityGPU = GaussianDensityGPU;
69
69
  function GaussianDensityTexture(webgl, position, box, radius, props, oldTexture) {
@@ -81,8 +81,8 @@ function GaussianDensityTexture3d(webgl, position, box, radius, props, oldTextur
81
81
  }
82
82
  exports.GaussianDensityTexture3d = GaussianDensityTexture3d;
83
83
  function finalizeGaussianDensityTexture(_a) {
84
- var texture = _a.texture, scale = _a.scale, bbox = _a.bbox, gridDim = _a.gridDim, gridTexDim = _a.gridTexDim, gridTexScale = _a.gridTexScale, radiusFactor = _a.radiusFactor, resolution = _a.resolution;
85
- return { transform: getTransform(scale, bbox), texture: texture, bbox: bbox, gridDim: gridDim, gridTexDim: gridTexDim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution };
84
+ var texture = _a.texture, scale = _a.scale, bbox = _a.bbox, gridDim = _a.gridDim, gridTexDim = _a.gridTexDim, gridTexScale = _a.gridTexScale, radiusFactor = _a.radiusFactor, resolution = _a.resolution, maxRadius = _a.maxRadius;
85
+ return { transform: getTransform(scale, bbox), texture: texture, bbox: bbox, gridDim: gridDim, gridTexDim: gridTexDim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution, maxRadius: maxRadius };
86
86
  }
87
87
  function getTransform(scale, bbox) {
88
88
  var transform = linear_algebra_1.Mat4.identity();
@@ -158,7 +158,7 @@ function calcGaussianDensityTexture2d(webgl, position, box, radius, powerOfTwo,
158
158
  render(texture, false);
159
159
  }
160
160
  // printTexture(webgl, minDistTex, 0.75);
161
- return { texture: texture, scale: scale, bbox: expandedBox, gridDim: dim, gridTexDim: gridTexDim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution };
161
+ return { texture: texture, scale: scale, bbox: expandedBox, gridDim: dim, gridTexDim: gridTexDim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution, maxRadius: maxRadius };
162
162
  }
163
163
  function calcGaussianDensityTexture3d(webgl, position, box, radius, props, texture) {
164
164
  // console.log('3d');
@@ -202,7 +202,7 @@ function calcGaussianDensityTexture3d(webgl, position, box, radius, props, textu
202
202
  render(minDistTex, true);
203
203
  setupGroupIdRendering(webgl, renderable);
204
204
  render(texture, false);
205
- return { texture: texture, scale: scale, bbox: expandedBox, gridDim: dim, gridTexDim: dim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution };
205
+ return { texture: texture, scale: scale, bbox: expandedBox, gridDim: dim, gridTexDim: dim, gridTexScale: gridTexScale, radiusFactor: radiusFactor, resolution: resolution, maxRadius: maxRadius };
206
206
  }
207
207
  //
208
208
  function prepareGaussianDensityData(position, box, radius, props) {
@@ -287,7 +287,7 @@ function createGaussianDensityRenderable(webgl, drawCount, positions, radii, gro
287
287
  dGridTexType: mol_util_1.ValueCell.create(minDistanceTexture.getDepth() > 0 ? '3d' : '2d'),
288
288
  dCalcType: mol_util_1.ValueCell.create('density'),
289
289
  };
290
- var schema = (0, tslib_1.__assign)({}, GaussianDensitySchema);
290
+ var schema = tslib_1.__assign({}, GaussianDensitySchema);
291
291
  var shaderCode = (0, shader_code_1.ShaderCode)(GaussianDensityName, gaussian_density_vert_1.gaussianDensity_vert, gaussian_density_frag_1.gaussianDensity_frag);
292
292
  var renderItem = (0, render_item_1.createComputeRenderItem)(webgl, 'points', shaderCode, schema, values);
293
293
  return (0, renderable_1.createComputeRenderable)(renderItem, values);
@@ -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 Alexander Rose <alexander.rose@weirdbyte.de>
5
5
  */
@@ -16,11 +16,11 @@ export declare const DefaultGaussianDensityProps: {
16
16
  export declare type GaussianDensityProps = typeof DefaultGaussianDensityProps;
17
17
  export declare type GaussianDensityData = {
18
18
  radiusFactor: number;
19
- resolution: number;
20
19
  } & DensityData;
21
20
  export declare type GaussianDensityTextureData = {
22
21
  radiusFactor: number;
23
22
  resolution: number;
23
+ maxRadius: number;
24
24
  } & DensityTextureData;
25
25
  export declare function computeGaussianDensity(position: PositionData, box: Box3D, radius: (index: number) => number, props: GaussianDensityProps): Task<GaussianDensityData>;
26
26
  export declare function computeGaussianDensityTexture(position: PositionData, box: Box3D, radius: (index: number) => number, props: GaussianDensityProps, webgl: WebGLContext, texture?: Texture): Task<GaussianDensityTextureData>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Copyright (c) 2018-2021 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ * Copyright (c) 2018-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
4
  *
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
6
6
  */
@@ -17,8 +17,8 @@ exports.DefaultGaussianDensityProps = {
17
17
  };
18
18
  function computeGaussianDensity(position, box, radius, props) {
19
19
  var _this = this;
20
- return task_1.Task.create('Gaussian Density', function (ctx) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
21
- return (0, tslib_1.__generator)(this, function (_a) {
20
+ return task_1.Task.create('Gaussian Density', function (ctx) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
21
+ return tslib_1.__generator(this, function (_a) {
22
22
  switch (_a.label) {
23
23
  case 0: return [4 /*yield*/, (0, cpu_1.GaussianDensityCPU)(ctx, position, box, radius, props)];
24
24
  case 1: return [2 /*return*/, _a.sent()];
@@ -41,8 +41,8 @@ function computeGaussianDensityTexture3d(position, box, radius, props, webgl, te
41
41
  exports.computeGaussianDensityTexture3d = computeGaussianDensityTexture3d;
42
42
  function _computeGaussianDensityTexture(type, position, box, radius, props, webgl, texture) {
43
43
  var _this = this;
44
- return task_1.Task.create('Gaussian Density', function (ctx) { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
45
- return (0, tslib_1.__generator)(this, function (_a) {
44
+ return task_1.Task.create('Gaussian Density', function (ctx) { return tslib_1.__awaiter(_this, void 0, void 0, function () {
45
+ return tslib_1.__generator(this, function (_a) {
46
46
  return [2 /*return*/, type === '2d' ?
47
47
  (0, gpu_1.GaussianDensityTexture2d)(webgl, position, box, radius, false, props, texture) :
48
48
  (0, gpu_1.GaussianDensityTexture3d)(webgl, position, box, radius, props, texture)];
@@ -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 Fred Ludlow <fred.ludlow@gmail.com>
5
5
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
@@ -29,4 +29,5 @@ export declare function calcMolecularSurface(ctx: RuntimeContext, position: Requ
29
29
  idField: Tensor;
30
30
  transform: Mat4;
31
31
  resolution: number;
32
+ maxRadius: number;
32
33
  }>;
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  /**
3
- * Copyright (c) 2019-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
3
+ * Copyright (c) 2019-2022 mol* contributors, licensed under MIT, See LICENSE file for more info.
4
4
  *
5
5
  * @author Fred Ludlow <fred.ludlow@gmail.com>
6
6
  * @author Alexander Rose <alexander.rose@weirdbyte.de>
@@ -44,12 +44,12 @@ function getAngleTables(probePositions) {
44
44
  //
45
45
  exports.MolecularSurfaceCalculationParams = {
46
46
  probeRadius: param_definition_1.ParamDefinition.Numeric(1.4, { min: 0, max: 10, step: 0.1 }, { description: 'Radius of the probe tracing the molecular surface.' }),
47
- resolution: param_definition_1.ParamDefinition.Numeric(0.5, { min: 0.01, max: 20, step: 0.01 }, (0, tslib_1.__assign)({ description: 'Grid resolution/cell spacing.' }, base_1.BaseGeometry.CustomQualityParamInfo)),
48
- probePositions: param_definition_1.ParamDefinition.Numeric(36, { min: 12, max: 90, step: 1 }, (0, tslib_1.__assign)({ description: 'Number of positions tested for probe target intersection.' }, base_1.BaseGeometry.CustomQualityParamInfo)),
47
+ resolution: param_definition_1.ParamDefinition.Numeric(0.5, { min: 0.01, max: 20, step: 0.01 }, tslib_1.__assign({ description: 'Grid resolution/cell spacing.' }, base_1.BaseGeometry.CustomQualityParamInfo)),
48
+ probePositions: param_definition_1.ParamDefinition.Numeric(36, { min: 12, max: 90, step: 1 }, tslib_1.__assign({ description: 'Number of positions tested for probe target intersection.' }, base_1.BaseGeometry.CustomQualityParamInfo)),
49
49
  };
50
50
  exports.DefaultMolecularSurfaceCalculationProps = param_definition_1.ParamDefinition.getDefaultValues(exports.MolecularSurfaceCalculationParams);
51
51
  function calcMolecularSurface(ctx, position, boundary, maxRadius, box, props) {
52
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
52
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
53
53
  /**
54
54
  * Is the point at x,y,z obscured by any of the atoms specifeid by indices in neighbours.
55
55
  * Ignore indices a and b (these are the relevant atoms in projectPoints/Torii)
@@ -157,9 +157,9 @@ function calcMolecularSurface(ctx, position, boundary, maxRadius, box, props) {
157
157
  }
158
158
  }
159
159
  function projectPoints() {
160
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
160
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
161
161
  var i;
162
- return (0, tslib_1.__generator)(this, function (_a) {
162
+ return tslib_1.__generator(this, function (_a) {
163
163
  switch (_a.label) {
164
164
  case 0:
165
165
  i = 0;
@@ -267,9 +267,9 @@ function calcMolecularSurface(ctx, position, boundary, maxRadius, box, props) {
267
267
  }
268
268
  }
269
269
  function projectTorii() {
270
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
270
+ return tslib_1.__awaiter(this, void 0, void 0, function () {
271
271
  var i;
272
- return (0, tslib_1.__generator)(this, function (_a) {
272
+ return tslib_1.__generator(this, function (_a) {
273
273
  switch (_a.label) {
274
274
  case 0:
275
275
  i = 0;
@@ -291,7 +291,7 @@ function calcMolecularSurface(ctx, position, boundary, maxRadius, box, props) {
291
291
  });
292
292
  }
293
293
  var lastClip, atob, mid, n1, n2, resolution, probeRadius, probePositions, scaleFactor, ngTorus, cellSize, lookup3d, neighbours, indices, px, py, pz, id, radius, n, pad, expandedBox, _a, minX, minY, minZ, scaledBox, dim, dimX, dimY, dimZ, iu, iv, iuv, _b, cosTable, sinTable, space, data, idData, gridx, gridy, gridz, updateChunk, field, idField, transform;
294
- return (0, tslib_1.__generator)(this, function (_c) {
294
+ return tslib_1.__generator(this, function (_c) {
295
295
  switch (_c.label) {
296
296
  case 0:
297
297
  lastClip = -1;
@@ -348,7 +348,7 @@ function calcMolecularSurface(ctx, position, boundary, maxRadius, box, props) {
348
348
  mat4_1.Mat4.fromScaling(transform, linear_algebra_1.Vec3.create(resolution, resolution, resolution));
349
349
  mat4_1.Mat4.setTranslation(transform, expandedBox.min);
350
350
  // console.log({ field, idField, transform, updateChunk })
351
- return [2 /*return*/, { field: field, idField: idField, transform: transform, resolution: resolution }];
351
+ return [2 /*return*/, { field: field, idField: idField, transform: transform, resolution: resolution, maxRadius: maxRadius }];
352
352
  }
353
353
  });
354
354
  });
@@ -31,8 +31,9 @@ exports.Box3D = Box3D;
31
31
  Box3D.clone = clone;
32
32
  /** Get box from sphere, uses extrema if available */
33
33
  function fromSphere3D(out, sphere) {
34
- if (sphere3d_1.Sphere3D.hasExtrema(sphere))
34
+ if (sphere3d_1.Sphere3D.hasExtrema(sphere) && sphere.extrema.length >= 14) { // 14 extrema with coarse boundary helper
35
35
  return fromVec3Array(out, sphere.extrema);
36
+ }
36
37
  var r = linear_algebra_1.Vec3.create(sphere.radius, sphere.radius, sphere.radius);
37
38
  linear_algebra_1.Vec3.sub(out.min, sphere.center, r);
38
39
  linear_algebra_1.Vec3.add(out.max, sphere.center, r);
@@ -183,7 +183,7 @@ exports.Sphere3D = Sphere3D;
183
183
  linear_algebra_1.Vec3.copy(out.center, sphere.center);
184
184
  out.radius = Math.max(sphere.radius, linear_algebra_1.Vec3.distance(sphere.center, by.center) + by.radius);
185
185
  if (hasExtrema(sphere) && hasExtrema(by)) {
186
- setExtrema(out, (0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)([], sphere.extrema.map(function (e) { return linear_algebra_1.Vec3.clone(e); }), true), by.extrema.map(function (e) { return linear_algebra_1.Vec3.clone(e); }), true));
186
+ setExtrema(out, tslib_1.__spreadArray(tslib_1.__spreadArray([], sphere.extrema.map(function (e) { return linear_algebra_1.Vec3.clone(e); }), true), by.extrema.map(function (e) { return linear_algebra_1.Vec3.clone(e); }), true));
187
187
  }
188
188
  return out;
189
189
  }
@@ -206,15 +206,21 @@ exports.Sphere3D = Sphere3D;
206
206
  var axes_1 = principal_axes_1.PrincipalAxes.calculateMomentsAxes(positions);
207
207
  axes3d_1.Axes3D.scale(axes_1, axes3d_1.Axes3D.normalize(axes_1, axes_1), delta);
208
208
  setExtrema(out, sphere.extrema.map(function (e) {
209
- linear_algebra_1.Vec3.sub(tmpDir, e, sphere.center);
210
- var out = linear_algebra_1.Vec3.clone(e);
209
+ linear_algebra_1.Vec3.normalize(tmpDir, linear_algebra_1.Vec3.sub(tmpDir, e, sphere.center));
210
+ var o = linear_algebra_1.Vec3.clone(e);
211
211
  var sA = linear_algebra_1.Vec3.dot(tmpDir, axes_1.dirA) < 0 ? -1 : 1;
212
- linear_algebra_1.Vec3.scaleAndAdd(out, out, axes_1.dirA, sA);
212
+ linear_algebra_1.Vec3.scaleAndAdd(o, o, axes_1.dirA, sA);
213
213
  var sB = linear_algebra_1.Vec3.dot(tmpDir, axes_1.dirB) < 0 ? -1 : 1;
214
- linear_algebra_1.Vec3.scaleAndAdd(out, out, axes_1.dirB, sB);
214
+ linear_algebra_1.Vec3.scaleAndAdd(o, o, axes_1.dirB, sB);
215
215
  var sC = linear_algebra_1.Vec3.dot(tmpDir, axes_1.dirC) < 0 ? -1 : 1;
216
- linear_algebra_1.Vec3.scaleAndAdd(out, out, axes_1.dirC, sC);
217
- return out;
216
+ linear_algebra_1.Vec3.scaleAndAdd(o, o, axes_1.dirC, sC);
217
+ if (linear_algebra_1.Vec3.distance(out.center, o) > out.radius) {
218
+ if (sphere.extrema.length >= 14) { // 14 extrema with coarse boundary helper
219
+ linear_algebra_1.Vec3.normalize(tmpDir, linear_algebra_1.Vec3.sub(tmpDir, o, sphere.center));
220
+ }
221
+ linear_algebra_1.Vec3.scaleAndAdd(o, out.center, tmpDir, out.radius);
222
+ }
223
+ return o;
218
224
  }));
219
225
  }
220
226
  return out;
@@ -7,11 +7,11 @@
7
7
  */
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
9
  var tslib_1 = require("tslib");
10
- (0, tslib_1.__exportStar)(require("./geometry/common"), exports);
11
- (0, tslib_1.__exportStar)(require("./geometry/symmetry-operator"), exports);
12
- (0, tslib_1.__exportStar)(require("./geometry/spacegroup/construction"), exports);
13
- (0, tslib_1.__exportStar)(require("./geometry/lookup3d/common"), exports);
14
- (0, tslib_1.__exportStar)(require("./geometry/lookup3d/grid"), exports);
15
- (0, tslib_1.__exportStar)(require("./geometry/primitives/box3d"), exports);
16
- (0, tslib_1.__exportStar)(require("./geometry/primitives/sphere3d"), exports);
17
- (0, tslib_1.__exportStar)(require("./geometry/primitives/axes3d"), exports);
10
+ tslib_1.__exportStar(require("./geometry/common"), exports);
11
+ tslib_1.__exportStar(require("./geometry/symmetry-operator"), exports);
12
+ tslib_1.__exportStar(require("./geometry/spacegroup/construction"), exports);
13
+ tslib_1.__exportStar(require("./geometry/lookup3d/common"), exports);
14
+ tslib_1.__exportStar(require("./geometry/lookup3d/grid"), exports);
15
+ tslib_1.__exportStar(require("./geometry/primitives/box3d"), exports);
16
+ tslib_1.__exportStar(require("./geometry/primitives/sphere3d"), exports);
17
+ tslib_1.__exportStar(require("./geometry/primitives/axes3d"), exports);