model.tsx 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. /**
  2. * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
  3. *
  4. * Adapted from LiteMol
  5. * Copyright (c) 2016 - now David Sehnal, licensed under Apache 2.0, See LICENSE file for more info.
  6. *
  7. * @author Alexander Rose <alexander.rose@weirdbyte.de>
  8. */
  9. import * as React from 'react'
  10. import { View } from '../view';
  11. import { Controller } from '../../controller/controller';
  12. import { ModelEntity } from 'mol-view/state/entity';
  13. import { StructureProps, ModelToStructure as ModelToStructureTransform } from 'mol-view/state/transform'
  14. import { StateContext } from 'mol-view/state/context';
  15. export class ModelToStructure extends View<Controller<any>, StructureProps, { transform: ModelToStructureTransform, entity: ModelEntity, ctx: StateContext }> {
  16. state = {
  17. assembly: ''
  18. }
  19. create(state?: Partial<StructureProps>) {
  20. const { transform, entity, ctx } = this.props
  21. console.log('create structure', transform, entity)
  22. const newState = { ...this.state, ...state }
  23. this.setState(newState)
  24. transform.apply(ctx, entity, newState)
  25. }
  26. render() {
  27. const { transform, entity } = this.props
  28. const assemblyOptions = entity.value[0].symmetry.assemblies.map((value, idx) => {
  29. return <option key={value.id} value={value.id}>{value.details}</option>
  30. })
  31. return <div className='molstar-transformer-wrapper'>
  32. <div className='molstar-panel molstar-control molstar-transformer molstar-panel-expanded'>
  33. <div className='molstar-panel-header'>
  34. <button
  35. className='molstar-btn molstar-btn-link molstar-panel-expander'
  36. onClick={() => this.create()}
  37. >
  38. <span>[{transform.kind}] {transform.inputKind} -> {transform.outputKind}</span>
  39. </button>
  40. </div>
  41. <div className='molstar-panel-body'>
  42. <div>
  43. <div className='molstar-control-row molstar-options-group'>
  44. <span>Details</span>
  45. <div>
  46. <select
  47. className='molstar-form-control'
  48. value={this.state.assembly}
  49. onChange={(e) => this.create({ assembly: e.target.value })}
  50. >
  51. {assemblyOptions}
  52. </select>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. </div>
  58. </div>;
  59. }
  60. }