aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/MainViewNotifs.tsx
blob: 05f89048573804acb5176e3edaf20fe70d330bb5 (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
import { action, computed, observable } from 'mobx';
import { observer } from 'mobx-react';
import "normalize.css";
import * as React from 'react';
import { Doc, DocListCast, Opt } from '../../fields/Doc';
import { emptyFunction } from '../../Utils';
import { SetupDrag } from '../util/DragManager';
import "./MainViewNotifs.scss";
import { CollectionDockingView } from './collections/CollectionDockingView';


@observer
export class MainViewNotifs extends React.Component {

    @observable static NotifsCol: Opt<Doc>;
    openNotifsCol = () => {
        if (MainViewNotifs.NotifsCol) {
            CollectionDockingView.AddRightSplit(MainViewNotifs.NotifsCol);
        }
    }
    render() {
        const length = MainViewNotifs.NotifsCol ? DocListCast(MainViewNotifs.NotifsCol.data).length : 0;
        const notifsRef = React.createRef<HTMLDivElement>();
        const dragNotifs = action(() => MainViewNotifs.NotifsCol!);
        return <div className="mainNotifs-container" ref={notifsRef}>
            <button className="mainNotifs-badge" style={length > 0 ? { "display": "initial" } : { "display": "none" }}
                onClick={this.openNotifsCol} onPointerDown={MainViewNotifs.NotifsCol ? SetupDrag(notifsRef, dragNotifs) : emptyFunction}>
                {length}
            </button>
        </div>;
    }
}