123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211 |
- /**
- * Copyright (c) 2018-2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
- *
- * @author David Sehnal <david.sehnal@gmail.com>
- * @author Alexander Rose <alexander.rose@weirdbyte.de>
- */
- import { VolumeIsoValue } from '../../../mol-model/volume';
- import { PluginContext } from '../../../mol-plugin/context';
- import { State, StateAction, StateBuilder, StateTransformer } from '../../../mol-state';
- import { Task } from '../../../mol-task';
- import { ColorNames } from '../../../mol-util/color/tables';
- import { FileInfo, getFileInfo } from '../../../mol-util/file-info';
- import { ParamDefinition as PD } from '../../../mol-util/param-definition';
- import { PluginStateObject } from '../objects';
- import { StateTransforms } from '../transforms';
- import { Download } from '../transforms/data';
- import { VolumeRepresentation3DHelpers } from '../transforms/representation';
- import { DataFormatProvider, guessCifVariant, DataFormatBuilderOptions } from './data-format';
- export const Ccp4Provider: DataFormatProvider<any> = {
- label: 'CCP4/MRC/BRIX',
- description: 'CCP4/MRC/BRIX',
- stringExtensions: [],
- binaryExtensions: ['ccp4', 'mrc', 'map'],
- isApplicable: (info: FileInfo, data: Uint8Array) => {
- return info.ext === 'ccp4' || info.ext === 'mrc' || info.ext === 'map'
- },
- getDefaultBuilder: (ctx: PluginContext, data: StateBuilder.To<PluginStateObject.Data.Binary>, options: DataFormatBuilderOptions, state: State) => {
- return Task.create('CCP4/MRC/BRIX default builder', async taskCtx => {
- let tree: StateBuilder.To<any> = data.apply(StateTransforms.Data.ParseCcp4)
- .apply(StateTransforms.Volume.VolumeFromCcp4)
- if (options.visuals) {
- tree = tree.apply(StateTransforms.Representation.VolumeRepresentation3D)
- }
- await state.updateTree(tree).runInContext(taskCtx)
- })
- }
- }
- export const Dsn6Provider: DataFormatProvider<any> = {
- label: 'DSN6/BRIX',
- description: 'DSN6/BRIX',
- stringExtensions: [],
- binaryExtensions: ['dsn6', 'brix'],
- isApplicable: (info: FileInfo, data: Uint8Array) => {
- return info.ext === 'dsn6' || info.ext === 'brix'
- },
- getDefaultBuilder: (ctx: PluginContext, data: StateBuilder.To<PluginStateObject.Data.Binary>, options: DataFormatBuilderOptions, state: State) => {
- return Task.create('DSN6/BRIX default builder', async taskCtx => {
- let tree: StateBuilder.To<any> = data.apply(StateTransforms.Data.ParseDsn6)
- .apply(StateTransforms.Volume.VolumeFromDsn6)
- if (options.visuals) {
- tree = tree.apply(StateTransforms.Representation.VolumeRepresentation3D)
- }
- await state.updateTree(tree).runInContext(taskCtx)
- })
- }
- }
- export const DscifProvider: DataFormatProvider<any> = {
- label: 'DensityServer CIF',
- description: 'DensityServer CIF',
- stringExtensions: ['cif'],
- binaryExtensions: ['bcif'],
- isApplicable: (info: FileInfo, data: Uint8Array | string) => {
- return guessCifVariant(info, data) === 'dscif' ? true : false
- },
- getDefaultBuilder: (ctx: PluginContext, data: StateBuilder.To<PluginStateObject.Data.Binary | PluginStateObject.Data.String>, options: DataFormatBuilderOptions, state: State) => {
- return Task.create('DensityServer CIF default builder', async taskCtx => {
- const cifBuilder = data.apply(StateTransforms.Data.ParseCif)
- const cifStateObject = await state.updateTree(cifBuilder).runInContext(taskCtx)
- const b = state.build().to(cifBuilder.ref);
- const blocks = cifStateObject.data.blocks.slice(1); // zero block contains query meta-data
- let tree: StateBuilder.To<any>
- if (blocks.length === 1) {
- tree = b
- .apply(StateTransforms.Volume.VolumeFromDensityServerCif, { blockHeader: blocks[0].header })
- if (options.visuals) {
- tree = tree.apply(StateTransforms.Representation.VolumeRepresentation3D, VolumeRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'isosurface', { isoValue: VolumeIsoValue.relative(1.5), alpha: 0.3 }, 'uniform', { value: ColorNames.teal }))
- }
- } else if (blocks.length === 2) {
- tree = b
- .apply(StateTransforms.Volume.VolumeFromDensityServerCif, { blockHeader: blocks[0].header })
- if (options.visuals) {
- tree = tree.apply(StateTransforms.Representation.VolumeRepresentation3D, VolumeRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'isosurface', { isoValue: VolumeIsoValue.relative(1.5), alpha: 0.3 }, 'uniform', { value: ColorNames.blue }))
- }
- const vol = tree.to(cifBuilder.ref)
- .apply(StateTransforms.Volume.VolumeFromDensityServerCif, { blockHeader: blocks[1].header })
- const posParams = VolumeRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'isosurface', { isoValue: VolumeIsoValue.relative(3), alpha: 0.3 }, 'uniform', { value: ColorNames.green })
- tree = vol.apply(StateTransforms.Representation.VolumeRepresentation3D, posParams)
- const negParams = VolumeRepresentation3DHelpers.getDefaultParamsStatic(ctx, 'isosurface', { isoValue: VolumeIsoValue.relative(-3), alpha: 0.3 }, 'uniform', { value: ColorNames.red })
- tree = tree.to(vol.ref).apply(StateTransforms.Representation.VolumeRepresentation3D, negParams)
- } else {
- throw new Error('unknown number of blocks')
- }
- await state.updateTree(tree).runInContext(taskCtx);
- })
- }
- }
- export { DownloadDensity };
- type DownloadDensity = typeof DownloadDensity
- const DownloadDensity = StateAction.build({
- from: PluginStateObject.Root,
- display: { name: 'Download Density', description: 'Load a density from the provided source and create its default visual.' },
- params: (a, ctx: PluginContext) => {
- const { options } = ctx.dataFormat.registry
- return {
- source: PD.MappedStatic('rcsb', {
- 'pdbe': PD.Group({
- id: PD.Text('1tqn', { label: 'Id' }),
- type: PD.Select('2fofc', [['2fofc', '2Fo-Fc'], ['fofc', 'Fo-Fc']]),
- }, { isFlat: true }),
- 'pdbe-emd-ds': PD.Group({
- id: PD.Text('emd-8004', { label: 'Id' }),
- detail: PD.Numeric(3, { min: 0, max: 10, step: 1 }, { label: 'Detail' }),
- }, { isFlat: true }),
- 'pdbe-xray-ds': PD.Group({
- id: PD.Text('1tqn', { label: 'Id' }),
- detail: PD.Numeric(3, { min: 0, max: 10, step: 1 }, { label: 'Detail' }),
- }, { isFlat: true }),
- 'rcsb': PD.Group({
- id: PD.Text('1tqn', { label: 'Id' }),
- type: PD.Select('2fofc', [['2fofc', '2Fo-Fc'], ['fofc', 'Fo-Fc']]),
- }, { isFlat: true }),
- 'url': PD.Group({
- url: PD.Text(''),
- isBinary: PD.Boolean(false),
- format: PD.Select('auto', options),
- }, { isFlat: true })
- }, {
- options: [
- ['pdbe', 'PDBe X-ray maps'],
- ['pdbe-emd-ds', 'PDBe EMD Density Server'],
- ['pdbe-xray-ds', 'PDBe X-ray Density Server'],
- ['rcsb', 'RCSB X-ray maps'],
- ['url', 'URL']
- ]
- })
- }
- }
- })(({ params, state }, ctx: PluginContext) => Task.create('Download Density', async taskCtx => {
- const src = params.source;
- let downloadParams: StateTransformer.Params<Download>;
- let provider: DataFormatProvider<any>
- switch (src.name) {
- case 'url':
- downloadParams = src.params;
- break;
- case 'pdbe':
- downloadParams = {
- url: src.params.type === '2fofc'
- ? `http://www.ebi.ac.uk/pdbe/coordinates/files/${src.params.id.toLowerCase()}.ccp4`
- : `http://www.ebi.ac.uk/pdbe/coordinates/files/${src.params.id.toLowerCase()}_diff.ccp4`,
- isBinary: true,
- label: `PDBe X-ray map: ${src.params.id}`
- };
- break;
- case 'pdbe-emd-ds':
- downloadParams = {
- url: `https://www.ebi.ac.uk/pdbe/densities/emd/${src.params.id.toLowerCase()}/cell?detail=${src.params.detail}`,
- isBinary: true,
- label: `PDBe EMD Density Server: ${src.params.id}`
- };
- break;
- case 'pdbe-xray-ds':
- downloadParams = {
- url: `https://www.ebi.ac.uk/pdbe/densities/x-ray/${src.params.id.toLowerCase()}/cell?detail=${src.params.detail}`,
- isBinary: true,
- label: `PDBe X-ray Density Server: ${src.params.id}`
- };
- break;
- case 'rcsb':
- downloadParams = {
- url: src.params.type === '2fofc'
- ? `https://edmaps.rcsb.org/maps/${src.params.id.toLowerCase()}_2fofc.dsn6`
- : `https://edmaps.rcsb.org/maps/${src.params.id.toLowerCase()}_fofc.dsn6`,
- isBinary: true,
- label: `RCSB X-ray map: ${src.params.id}`
- };
- break;
- default: throw new Error(`${(src as any).name} not supported.`);
- }
- const data = state.build().toRoot().apply(StateTransforms.Data.Download, downloadParams);
- const dataStateObject = await state.updateTree(data).runInContext(taskCtx);
- switch (src.name) {
- case 'url':
- downloadParams = src.params;
- provider = src.params.format === 'auto' ? ctx.dataFormat.registry.auto(getFileInfo(downloadParams.url), dataStateObject) : ctx.dataFormat.registry.get(src.params.format)
- break;
- case 'pdbe':
- provider = ctx.dataFormat.registry.get('ccp4')
- break;
- case 'pdbe-emd-ds':
- case 'pdbe-xray-ds':
- provider = ctx.dataFormat.registry.get('dscif')
- break;
- case 'rcsb':
- provider = ctx.dataFormat.registry.get('dsn6')
- break;
- default: throw new Error(`${(src as any).name} not supported.`);
- }
- const b = state.build().to(data.ref);
- await provider.getDefaultBuilder(ctx, b, { visuals: true }, state).runInContext(taskCtx)
- }));
|