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>;
}
}
|