model.ts 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /**
  2. * Copyright (c) 2019-2020 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  5. */
  6. import { LoadParams, ParseParams } from '../types';
  7. import { PluginContext } from 'molstar/lib/mol-plugin/context';
  8. import { PresetProps, RcsbPreset } from './preset';
  9. import { Asset } from 'molstar/lib/mol-util/assets';
  10. import { Mat4 } from 'molstar/lib/mol-math/linear-algebra';
  11. import { StateTransforms } from 'molstar/lib/mol-plugin-state/transforms';
  12. import { BuiltInTrajectoryFormat } from 'molstar/lib/mol-plugin-state/formats/trajectory';
  13. import {TrajectoryHierarchyPresetProvider} from 'molstar/lib/mol-plugin-state/builder/structure/hierarchy-preset';
  14. export class ModelLoader {
  15. async load<P>(load: LoadParams, props?: PresetProps, matrix?: Mat4, reprProvider?: TrajectoryHierarchyPresetProvider, params?: P) {
  16. const { fileOrUrl, format, isBinary } = load;
  17. const data = fileOrUrl instanceof File
  18. ? (await this.plugin.builders.data.readFile({ file: Asset.File(fileOrUrl), isBinary })).data
  19. : await this.plugin.builders.data.download({ url: fileOrUrl, isBinary });
  20. await this.handleTrajectory<P>(data, format, props, matrix, reprProvider, params);
  21. }
  22. async parse<P>(parse: ParseParams, props?: PresetProps & { dataLabel?: string }, matrix?: Mat4, reprProvider?: TrajectoryHierarchyPresetProvider, params?: P) {
  23. const { data, format } = parse;
  24. const _data = await this.plugin.builders.data.rawData({ data, label: props?.dataLabel });
  25. await this.handleTrajectory(_data, format, props, matrix, reprProvider, params);
  26. }
  27. private async handleTrajectory<P>(data: any, format: BuiltInTrajectoryFormat, props?: PresetProps, matrix?: Mat4, reprProvider?: TrajectoryHierarchyPresetProvider, params?: P) {
  28. const trajectory = await this.plugin.builders.structure.parseTrajectory(data, format);
  29. if(reprProvider){
  30. await this.plugin.builders.structure.hierarchy.applyPreset(trajectory, reprProvider, {...params});
  31. }else{
  32. const selector = await this.plugin.builders.structure.hierarchy.applyPreset(trajectory, RcsbPreset, {
  33. preset: props || { kind: 'standard', assemblyId: '' }
  34. });
  35. if (matrix && selector?.structureProperties) {
  36. const params = {
  37. transform: {
  38. name: 'matrix' as const,
  39. params: { data: matrix, transpose: false }
  40. }
  41. };
  42. const b = this.plugin.state.data.build().to(selector.structureProperties)
  43. .insert(StateTransforms.Model.TransformStructureConformation, params);
  44. await this.plugin.runTask(this.plugin.state.data.updateTree(b));
  45. }
  46. }
  47. }
  48. constructor(private plugin: PluginContext) {
  49. }
  50. }