blob: 969605be9e40ebdfc49d135f4eb7355c3995b18d (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
 | import React = require("react");
import { computed } from "mobx";
import { observer } from "mobx-react";
export interface TouchScrollableMenuProps {
    options: JSX.Element[];
    bounds: {
        right: number;
        left: number;
        bottom: number;
        top: number;
        width: number;
        height: number;
    };
    selectedIndex: number;
    x: number;
    y: number;
}
export interface TouchScrollableMenuItemProps {
    text: string;
    onClick: () => any;
}
@observer
export default class TouchScrollableMenu extends React.Component<TouchScrollableMenuProps> {
    @computed
    private get possibilities() { return this.props.options; }
    @computed
    private get selectedIndex() { return this.props.selectedIndex; }
    render() {
        return (
            <div className="inkToTextDoc-cont" style={{
                transform: `translate(${this.props.x}px, ${this.props.y}px)`,
                width: 300,
                height: this.possibilities.length * 25
            }}>
                <div className="inkToTextDoc-scroller" style={{ transform: `translate(0, ${-this.selectedIndex * 25}px)` }}>
                    {this.possibilities}
                </div>
                <div className="shadow" style={{ height: `calc(100% - 25px - ${this.selectedIndex * 25}px)` }}>
                </div>
            </div>
        );
    }
}
export class TouchScrollableMenuItem extends React.Component<TouchScrollableMenuItemProps>{
    render() {
        return (
            <div className="menuItem-cont" onClick={this.props.onClick}>
                {this.props.text}
            </div>
        );
    }
}
 |