blob: 5fd9b550d81d29114a94d499584ef27ba0959c00 (
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
|
import { observable } from "mobx";
import { observer } from "mobx-react";
import * as React from 'react';
import { Doc, DocListCast } from "../../fields/Doc";
import { Id } from "../../fields/FieldSymbols";
import { Cast, ImageCast, StrCast } from "../../fields/Types";
import { CurrentUserUtils } from "../util/CurrentUserUtils";
import { UndoManager } from "../util/UndoManager";
import "./DashboardView.scss"
@observer
export class DashboardView extends React.Component {
//TODO: delete dashboard, share dashboard, etc.
newDashboard = async () => {
const batch = UndoManager.StartBatch("new dash");
await CurrentUserUtils.createNewDashboard(Doc.UserDoc());
batch.end();
}
clickDashboard = async (e: React.MouseEvent, dashboard: Doc) => {
if (e.detail === 2) {
Doc.UserDoc().activeDashboard = dashboard
}
}
render() {
const myDashboards = DocListCast(CurrentUserUtils.MyDashboards.data);
return <div className="dashboard-view">
<div className="left-menu">
<div onClick={this.newDashboard}>New</div>
<div>All Dashboards</div>
</div>
<div className="all-dashboards">
{myDashboards.map((dashboard) =>
<div className="dashboard-container" key={dashboard[Id]} onClick={(e) => { this.clickDashboard(e, dashboard) }}>
<img src="https://media.istockphoto.com/photos/hot-air-balloons-flying-over-the-botan-canyon-in-turkey-picture-id1297349747?b=1&k=20&m=1297349747&s=170667a&w=0&h=oH31fJty_4xWl_JQ4OIQWZKP8C6ji9Mz7L4XmEnbqRU="></img>
<div className="title"> {StrCast(dashboard.title)} </div>
</div>
)}
{myDashboards.map((dashboard) => {
console.log(dashboard.thumb)
})}
</div>
</div>
}
}
|