aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/DashboardView.tsx
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>
      }
}