maputnik/src/app.jsx

72 lines
1.4 KiB
React
Raw Normal View History

import React from 'react'
2016-09-08 19:47:29 +02:00
import { Drawer, Container, Block, Fixed } from 'rebass'
import {Map} from './map.jsx'
import {Toolbar} from './toolbar.jsx'
2016-09-08 19:47:29 +02:00
import { LayerEditor } from './layers.jsx'
import theme from './theme.js'
import layout from './layout.scss'
2015-06-15 15:21:19 +02:00
2016-09-08 21:42:18 +02:00
export class WorkspaceDrawer extends React.Component {
render() {
let editor = null
if(this.props.mapStyle) {
editor = <LayerEditor layers={this.props.mapStyle.layers}/>
}
2016-09-09 00:55:50 +02:00
return <div style={{
2016-09-08 21:42:18 +02:00
zIndex: 100,
position: "fixed",
height: "100%",
left: "60",
width: 300,
top: "0",
bottom: "0",
backgroundColor: theme.colors.gray}
} >
{editor}
2016-09-09 00:55:50 +02:00
</div>
2016-09-08 21:42:18 +02:00
}
}
2015-06-15 15:21:19 +02:00
export default class App extends React.Component {
2016-09-08 19:47:29 +02:00
static childContextTypes = {
rebass: React.PropTypes.object,
reactIconBase: React.PropTypes.object
}
constructor(props) {
super(props)
this.updateStyle = this.updateStyle.bind(this);
this.state = {
mapStyle: null
}
}
updateStyle(newStyle) {
this.setState({ mapStyle: newStyle })
}
2016-09-08 19:47:29 +02:00
getChildContext () {
return {
rebass: theme,
reactIconBase: {
size: 20,
}
}
}
2015-06-15 15:21:19 +02:00
render() {
console.log(this.state.mapStyle)
2016-09-09 11:29:18 +02:00
return <div style={{ fontFamily: theme.fontFamily, color: theme.color }}>
<Toolbar onStyleUpload={this.updateStyle} />
<WorkspaceDrawer mapStyle={this.state.mapStyle} />
<div className={layout.map}>
<Map mapStyle={this.state.mapStyle} />
</div>
</div>
2015-06-15 15:21:19 +02:00
}
2016-09-08 19:47:29 +02:00
}