diff options
Diffstat (limited to 'src/client/views/LightboxView.tsx')
| -rw-r--r-- | src/client/views/LightboxView.tsx | 105 | 
1 files changed, 105 insertions, 0 deletions
| diff --git a/src/client/views/LightboxView.tsx b/src/client/views/LightboxView.tsx new file mode 100644 index 000000000..4e9491ec6 --- /dev/null +++ b/src/client/views/LightboxView.tsx @@ -0,0 +1,105 @@ +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; +import { action, observable, computed } from 'mobx'; +import { observer } from 'mobx-react'; +import "normalize.css"; +import * as React from 'react'; +import { Doc, Opt } from '../../fields/Doc'; +import { emptyFunction, emptyPath, returnEmptyDoclist, returnEmptyFilter, returnFalse, returnTrue } from '../../Utils'; +import { Transform } from '../util/Transform'; +import "./LightboxView.scss"; +import { DocumentView } from './nodes/DocumentView'; +import { DefaultStyleProvider } from './StyleProvider'; + +interface LightboxViewProps { +    PanelWidth: number; +    PanelHeight: number; +    maxBorder: number[]; +} + +@observer +export class LightboxView extends React.Component<LightboxViewProps> { +    @observable public static LightboxDoc: Opt<Doc>; +    public static IsLightboxDocView(path: DocumentView[]) { return path.includes(LightboxView.LightboxDocView.current!); } +    public static LightboxHistory: (Opt<Doc>)[] = []; +    public static LightboxFuture: (Opt<Doc>)[] = []; +    public static LightboxDocView = React.createRef<DocumentView>(); +    @computed get leftBorder() { return Math.min(this.props.PanelWidth / 4, this.props.maxBorder[0]); } +    @computed get topBorder() { return Math.min(this.props.PanelHeight / 4, this.props.maxBorder[1]); } +    lightboxWidth = () => this.props.PanelWidth - this.leftBorder * 2; +    lightboxHeight = () => this.props.PanelHeight - this.topBorder * 2; +    lightboxScreenToLocal = () => new Transform(-this.leftBorder, -this.topBorder, 1); +    navBtn = (left: Opt<number>, icon: string, display: () => string, click: (e: React.MouseEvent) => void) => { +        return <div className="lightboxView-navBtn-frame" style={{ +            display: display(), +            left, +            width: Math.min(this.props.PanelWidth / 4, this.props.maxBorder[0]) +        }}> +            <div className="lightboxView-navBtn" style={{ top: this.props.PanelHeight / 2 - 12.50 }} +                onClick={click}> +                <FontAwesomeIcon icon={icon as any} size="3x" /> +            </div> +        </div>; +    } + +    render() { +        if (LightboxView.LightboxHistory.lastElement() !== LightboxView.LightboxDoc) LightboxView.LightboxHistory.push(LightboxView.LightboxDoc); +        let downx = 0, downy = 0; +        return !LightboxView.LightboxDoc ? (null) : +            <div className="lightboxView-frame" +                onPointerDown={e => { downx = e.clientX; downy = e.clientY; }} +                onClick={action(e => { +                    if (Math.abs(downx - e.clientX) < 4 && Math.abs(downy - e.clientY) < 4) { +                        LightboxView.LightboxHistory = []; +                        LightboxView.LightboxFuture = []; +                        LightboxView.LightboxDoc = undefined; +                    } +                })}  > +                <div className="lightboxView-contents" style={{ +                    left: this.leftBorder, +                    top: this.topBorder, +                    width: this.lightboxWidth(), +                    height: this.lightboxHeight() +                }}> +                    <DocumentView ref={LightboxView.LightboxDocView} +                        Document={LightboxView.LightboxDoc} +                        DataDoc={undefined} +                        addDocument={undefined} +                        addDocTab={returnFalse} +                        pinToPres={emptyFunction} +                        rootSelected={returnTrue} +                        docViewPath={returnEmptyDoclist} +                        removeDocument={undefined} +                        styleProvider={DefaultStyleProvider} +                        layerProvider={returnTrue} +                        ScreenToLocalTransform={this.lightboxScreenToLocal} +                        PanelWidth={this.lightboxWidth} +                        PanelHeight={this.lightboxHeight} +                        focus={emptyFunction} +                        parentActive={returnTrue} +                        whenActiveChanged={emptyFunction} +                        bringToFront={emptyFunction} +                        docFilters={returnEmptyFilter} +                        docRangeFilters={returnEmptyFilter} +                        searchFilterDocs={returnEmptyDoclist} +                        ContainingCollectionView={undefined} +                        ContainingCollectionDoc={undefined} +                        renderDepth={0} /> +                </div> +                {this.navBtn(undefined, "chevron-left", +                    () => LightboxView.LightboxDoc && LightboxView.LightboxHistory.length ? "" : "none", +                    action(e => { +                        e.stopPropagation(); +                        const popped = LightboxView.LightboxHistory.pop(); +                        if (LightboxView.LightboxHistory.lastElement() !== LightboxView.LightboxFuture.lastElement()) LightboxView.LightboxFuture.push(popped); +                        LightboxView.LightboxDoc = LightboxView.LightboxHistory.lastElement(); +                    }))} +                {this.navBtn(this.props.PanelWidth - Math.min(this.props.PanelWidth / 4, this.props.maxBorder[0]), "chevron-right", +                    () => LightboxView.LightboxDoc && LightboxView.LightboxFuture.length ? "" : "none", +                    action(e => { +                        e.stopPropagation(); +                        LightboxView.LightboxDoc = LightboxView.LightboxFuture.pop(); +                    }))} + +            </div>; +    } +}
\ No newline at end of file | 
