summaryrefslogtreecommitdiff
path: root/client/components/App.jsx
blob: f7122b22c2e4d6aea01be35edd135a04b6cbf90a (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
import { h, Component } from 'preact'
import { isMobile } from '../vendor/util'
// import db from '../db'
import { Link, withRouter } from 'react-router-dom'

import Header from './Header.jsx'
import Folders from './Folders/Folders.jsx'
import Folder from './Folder/Folder.jsx'

import client from '../client'

class App extends Component {
  constructor(props) {
    super()
    this.state = {
      folders: null,
      openFolders: [],
    }
    client.folder.index().then( folders => this.setState({ folders }) )
  }
  openFolder(folder) {
    if (this.state.openFolders.indexOf(folder) === -1) {
      this.setState({ openFolders: this.state.openFolders.concat([folder]) })
    }
  }
  render() {
    const openFolders = this.state.openFolders.map((folder) => {
      return (
        <Folder folder={folder} />
      )
    })
    return (
      <div>
        <Header />
        <Folders folders={this.state.folders} openFolder={(folder) => this.openFolder(folder)} />
        {openFolders}
      </div>
    )
  }
}

export default withRouter(App)