Skip to content
Snippets Groups Projects
camera.tsx 2.71 KiB
Newer Older
David Sehnal's avatar
David Sehnal committed
/**
 * Copyright (c) 2018 mol* contributors, licensed under MIT, See LICENSE file for more info.
 *
 * @author David Sehnal <david.sehnal@gmail.com>
 */

import { PluginCommands } from 'mol-plugin/command';
import * as React from 'react';
import { PluginUIComponent } from './base';
David Sehnal's avatar
David Sehnal committed
import { ParamDefinition as PD } from 'mol-util/param-definition';
import { ParameterControls } from './controls/parameters';
export class CameraSnapshots extends PluginUIComponent<{ }, { }> {
David Sehnal's avatar
David Sehnal committed
    render() {
        return <div>
David Sehnal's avatar
David Sehnal committed
            <div className='msp-section-header'>Camera Snapshots</div>
David Sehnal's avatar
David Sehnal committed
            <CameraSnapshotControls />
            <CameraSnapshotList />
        </div>;
    }
}

class CameraSnapshotControls extends PluginUIComponent<{ }, { name: string, description: string }> {
David Sehnal's avatar
David Sehnal committed
    static Params = {
        name: PD.Text(),
        description: PD.Text()
    }
    state = PD.getDefaultValues(CameraSnapshotControls.Params);
David Sehnal's avatar
David Sehnal committed

    add = () => {
        PluginCommands.Camera.Snapshots.Add.dispatch(this.plugin, this.state);
        this.setState({ name: '', description: '' })
    }

    clear = () => {
        PluginCommands.Camera.Snapshots.Clear.dispatch(this.plugin, {});
    }

    render() {
        return <div>
David Sehnal's avatar
David Sehnal committed
            <ParameterControls params={CameraSnapshotControls.Params} values={this.state} onEnter={this.add} onChange={p => this.setState({ [p.name]: p.value } as any)}  />

            <div className='msp-btn-row-group'>
                <button className='msp-btn msp-btn-block msp-form-control' onClick={this.add}>Add</button>
                <button className='msp-btn msp-btn-block msp-form-control' onClick={this.clear}>Clear</button>
            </div>
class CameraSnapshotList extends PluginUIComponent<{ }, { }> {
David Sehnal's avatar
David Sehnal committed
    componentDidMount() {
        this.subscribe(this.plugin.events.state.cameraSnapshots.changed, () => this.forceUpdate());
    }

    apply(id: string) {
        return () => PluginCommands.Camera.Snapshots.Apply.dispatch(this.plugin, { id });
    }

    remove(id: string) {
        return () => {
            PluginCommands.Camera.Snapshots.Remove.dispatch(this.plugin, { id });
        }
    }

    render() {
David Sehnal's avatar
David Sehnal committed
        return <ul style={{ listStyle: 'none' }} className='msp-state-list'>
David Sehnal's avatar
David Sehnal committed
            {this.plugin.state.cameraSnapshots.entries.valueSeq().map(e =><li key={e!.id}>
David Sehnal's avatar
David Sehnal committed
                <button className='msp-btn msp-btn-block msp-form-control' onClick={this.apply(e!.id)}>{e!.name || e!.timestamp} <small>{e!.description}</small></button>
David Sehnal's avatar
David Sehnal committed
                <button onClick={this.remove(e!.id)} className='msp-btn msp-btn-link msp-state-list-remove-button'>
David Sehnal's avatar
David Sehnal committed
                    <span className='msp-icon msp-icon-remove' />
                </button>
David Sehnal's avatar
David Sehnal committed
            </li>)}
        </ul>;
    }
}