Skip to content
Snippets Groups Projects
Select Git revision
  • 2b78d2dfe0ea781d93dea77572a8fbc687a0295b
  • master default protected
  • rednatco-v2
  • rednatco
  • test
  • ntc-tube-uniform-color
  • ntc-tube-missing-atoms
  • restore-vertex-array-per-program
  • watlas2
  • dnatco_new
  • cleanup-old-nodejs
  • webmmb
  • fix_auth_seq_id
  • update_deps
  • ext_dev
  • ntc_balls
  • nci-2
  • plugin
  • bugfix-0.4.5
  • nci
  • servers
  • v0.5.0-dev.1
  • v0.4.5
  • v0.4.4
  • v0.4.3
  • v0.4.2
  • v0.4.1
  • v0.4.0
  • v0.3.12
  • v0.3.11
  • v0.3.10
  • v0.3.9
  • v0.3.8
  • v0.3.7
  • v0.3.6
  • v0.3.5
  • v0.3.4
  • v0.3.3
  • v0.3.2
  • v0.3.1
  • v0.3.0
41 results

assembly-symmetry.ts

Blame
  • user avatar
    Alexander Rose authored
    2b78d2df
    History
    assembly-symmetry.ts 3.36 KiB
    /**
     * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author Alexander Rose <alexander.rose@weirdbyte.de>
     */
    
    import { PluginBehavior } from 'mol-plugin/behavior';
    import { ParamDefinition as PD } from 'mol-util/param-definition'
    import { AssemblySymmetry } from 'mol-model-props/rcsb/assembly-symmetry';
    import { CustomPropertyRegistry } from 'mol-plugin/util/custom-prop-registry';
    import { AssemblySymmetryClusterColorThemeProvider } from 'mol-model-props/rcsb/themes/assembly-symmetry-cluster';
    import { AssemblySymmetryAxesRepresentationProvider } from 'mol-model-props/rcsb/representations/assembly-symmetry-axes';
    import { Loci, isDataLoci } from 'mol-model/loci';
    import { OrderedSet } from 'mol-data/int';
    import { Table } from 'mol-data/db';
    
    export const RCSBAssemblySymmetry = PluginBehavior.create<{ autoAttach: boolean }>({
        name: 'rcsb-assembly-symmetry-prop',
        display: { name: 'RCSB Assembly Symmetry', group: 'Custom Props' },
        ctor: class extends PluginBehavior.Handler<{ autoAttach: boolean }> {
            private attach = AssemblySymmetry.createAttachTask(this.ctx.fetch);
    
            private provider: CustomPropertyRegistry.Provider = {
                option: [AssemblySymmetry.Descriptor.name, 'RCSB Assembly Symmetry'],
                descriptor: AssemblySymmetry.Descriptor,
                defaultSelected: this.params.autoAttach,
                attachableTo: () => true,
                attach: this.attach
            }
    
            register(): void {
                this.ctx.customModelProperties.register(this.provider);
                this.ctx.lociLabels.addProvider(labelAssemblySymmetryAxes);
                this.ctx.structureRepresentation.themeCtx.colorThemeRegistry.add('rcsb-assembly-symmetry-cluster', AssemblySymmetryClusterColorThemeProvider)
                this.ctx.structureRepresentation.registry.add('rcsb-assembly-symmetry-axes', AssemblySymmetryAxesRepresentationProvider)
            }
    
            update(p: { autoAttach: boolean }) {
                let updated = this.params.autoAttach !== p.autoAttach
                this.params.autoAttach = p.autoAttach;
                this.provider.defaultSelected = p.autoAttach;
                return updated;
            }
    
            unregister() {
                this.ctx.customModelProperties.unregister(AssemblySymmetry.Descriptor.name);
                this.ctx.lociLabels.removeProvider(labelAssemblySymmetryAxes);
                this.ctx.structureRepresentation.themeCtx.colorThemeRegistry.remove('rcsb-assembly-symmetry-cluster')
                this.ctx.structureRepresentation.registry.remove('rcsb-assembly-symmetry-axes')
            }
        },
        params: () => ({
            autoAttach: PD.Boolean(false)
        })
    });
    
    function labelAssemblySymmetryAxes(loci: Loci): string | undefined {
        if (isDataLoci(loci) && AssemblySymmetry.is(loci.data) && loci.tag === 'axes') {
            const { rcsb_assembly_symmetry_axis: axis, rcsb_assembly_symmetry: sym } = loci.data.db
            const labels: string[] = []
            OrderedSet.forEach(loci.indices, v => {
                const symmetryId = axis.symmetry_id.value(v)
                const symmetry = Table.pickRow(sym, i => sym.id.value(i) === symmetryId)
                if (symmetry) {
                    labels.push(`Axis of order ${axis.order.value(v)} for ${symmetry.kind} ${symmetry.type.toLowerCase()} symmetry`)
                }
            })
            return labels.length ? labels.join(', ') : undefined
        }
        return undefined
    }