Skip to content
Snippets Groups Projects
Select Git revision
  • 166edc61d923f5c68cbfbb798721859bc7593a03
  • master default protected
  • rednatco-v2
  • base-pairs-ladder
  • 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
  • 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

index.ts

Blame
  • index.ts 1.47 KiB
    /**
     * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
     *
     * @author Alexander Rose <alexander.rose@weirdbyte.de>
     */
    
    import CIF from 'mol-io/reader/cif'
    import { Run, Progress } from 'mol-task'
    import { Model } from 'mol-model/structure'
    
    export function log(progress: Progress) {
        const p = progress.root.progress
        console.log(`${p.message} ${(p.current/p.max*100).toFixed(2)}%`)
    }
    
    export async function parseCif(data: string|Uint8Array) {
        const comp = CIF.parse(data)
        const parsed = await Run(comp, log, 100);
        if (parsed.isError) throw parsed;
        return parsed
    }
    
    export async function getModelFromPdbId(pdbid: string) {
        const data = await fetch(`https://files.rcsb.org/download/${pdbid}.cif`)
        const parsed = await parseCif(await data.text())
        return Model.create({ kind: 'mmCIF', data: CIF.schema.mmCIF(parsed.result.blocks[0]) })
    }
    
    const readFileAsText = (file: File) => {
        const fileReader = new FileReader()
        return new Promise<string>((resolve, reject) => {
            fileReader.onerror = () => {
                fileReader.abort()
                reject(new DOMException('Error parsing input file.'))
            }
            fileReader.onload = () => resolve(fileReader.result)
            fileReader.readAsText(file)
        })
    }
    
    export async function getModelFromFile(file: File) {
        const parsed = await parseCif(await readFileAsText(file))
        return Model.create({ kind: 'mmCIF', data: CIF.schema.mmCIF(parsed.result.blocks[0]) })
    }