UNPKG

molstar

Version:

A comprehensive macromolecular library.

59 lines (58 loc) 2.27 kB
/** * Copyright (c) 2025 mol* contributors, licensed under MIT, See LICENSE file for more info. * * @author David Sehnal <david.sehnal@gmail.com> */ import { OrderedSet } from '../../mol-data/int.js'; import { ShapeGroup } from '../../mol-model/shape.js'; import { StateObjectSelector, StateTree } from '../../mol-state/index.js'; /** * Queries all MolViewSpec references in the current state of the plugin. */ export function queryMVSRef(plugin, ref) { return plugin.state.data.selectQ(q => q.root.subtree().withTag(`mvs-ref:${ref}`)); } /** * Creates a mapping of all MolViewSpec references in the current state of the plugin. */ export function createMVSRefMap(plugin) { const tree = plugin.state.data.tree; const mapping = new Map(); StateTree.doPreOrder(tree, tree.root, { mapping, plugin }, (n, _, s) => { if (!n.tags) return; for (const tag of n.tags) { if (!tag.startsWith('mvs-ref:')) continue; const mvsRef = tag.substring(8); const selector = new StateObjectSelector(n.ref, s.plugin.state.data); if (s.mapping.has(mvsRef)) s.mapping.get(mvsRef).push(selector); else s.mapping.set(mvsRef, [selector]); } }); return mapping; } export function tryGetPrimitivesFromLoci(loci) { if (!ShapeGroup.isLoci(loci)) return undefined; const srcData = loci.shape.sourceData; if ((srcData === null || srcData === void 0 ? void 0 : srcData.kind) !== 'mvs-primitives') return undefined; const nodes = []; for (const group of loci.groups) { OrderedSet.forEach(group.ids, id => { const node = srcData.groupToNode.get(id); if (node) nodes.push(node); }); } return nodes.length > 0 ? nodes : undefined; } // Retrieves the MVS snapshot associated with the current snapshot of the plugin // This will only work if the current state was created from an MVS snapshot export function getCurrentMVSSnapshot(plugin) { var _a, _b; return (_b = (_a = plugin.managers.snapshot.current) === null || _a === void 0 ? void 0 : _a._transientData) === null || _b === void 0 ? void 0 : _b.sourceMvsSnapshot; }