mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-14 20:23:27 +01:00
Separate work space drawer
This commit is contained in:
parent
3cc989e70f
commit
622286f294
3 changed files with 66 additions and 32 deletions
52
src/app.jsx
52
src/app.jsx
|
@ -4,39 +4,13 @@ import {saveAs} from 'file-saver'
|
||||||
import { Drawer, Container, Block, Fixed } from 'rebass'
|
import { Drawer, Container, Block, Fixed } from 'rebass'
|
||||||
import {Map} from './map.jsx'
|
import {Map} from './map.jsx'
|
||||||
import {Toolbar} from './toolbar.jsx'
|
import {Toolbar} from './toolbar.jsx'
|
||||||
import { LayerEditor } from './layers.jsx'
|
|
||||||
import { StyleManager } from './style.js'
|
import { StyleManager } from './style.js'
|
||||||
|
import { WorkspaceDrawer } from './workspace.jsx'
|
||||||
|
|
||||||
import theme from './theme.js'
|
import theme from './theme.js'
|
||||||
import layout from './layout.scss'
|
import layout from './layout.scss'
|
||||||
import 'react-virtualized/styles.css'
|
import 'react-virtualized/styles.css'
|
||||||
|
|
||||||
export class WorkspaceDrawer extends React.Component {
|
|
||||||
static propTypes = {
|
|
||||||
styleManager: React.PropTypes.object.isRequired
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
let editor = null
|
|
||||||
if(this.props.styleManager.mapStyle) {
|
|
||||||
editor = <LayerEditor styleManager={this.props.styleManager}/>
|
|
||||||
}
|
|
||||||
|
|
||||||
return <div style={{
|
|
||||||
zIndex: 100,
|
|
||||||
position: "fixed",
|
|
||||||
left: 60,
|
|
||||||
width: 300,
|
|
||||||
top: 0,
|
|
||||||
bottom: 0,
|
|
||||||
overflow: "hidden",
|
|
||||||
backgroundColor: theme.colors.gray}
|
|
||||||
}>
|
|
||||||
{editor}
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export default class App extends React.Component {
|
export default class App extends React.Component {
|
||||||
static childContextTypes = {
|
static childContextTypes = {
|
||||||
rebass: React.PropTypes.object,
|
rebass: React.PropTypes.object,
|
||||||
|
@ -47,6 +21,7 @@ export default class App extends React.Component {
|
||||||
super(props)
|
super(props)
|
||||||
this.state = {
|
this.state = {
|
||||||
styleManager: new StyleManager(),
|
styleManager: new StyleManager(),
|
||||||
|
workContext: "layers",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +35,19 @@ export default class App extends React.Component {
|
||||||
this.setState({ styleManager: new StyleManager(newStyle) })
|
this.setState({ styleManager: new StyleManager(newStyle) })
|
||||||
}
|
}
|
||||||
|
|
||||||
getChildContext () {
|
onOpenSettings() {
|
||||||
|
this.setState({
|
||||||
|
workContext: "settings",
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
onOpenLayers() {
|
||||||
|
this.setState({
|
||||||
|
workContext: "layers",
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
getChildContext() {
|
||||||
return {
|
return {
|
||||||
rebass: theme,
|
rebass: theme,
|
||||||
reactIconBase: {
|
reactIconBase: {
|
||||||
|
@ -71,8 +58,13 @@ export default class App extends React.Component {
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return <div style={{ fontFamily: theme.fontFamily, color: theme.color }}>
|
return <div style={{ fontFamily: theme.fontFamily, color: theme.color }}>
|
||||||
<Toolbar onStyleUpload={this.onStyleUpload.bind(this)} onStyleDownload={this.onStyleDownload.bind(this)} />
|
<Toolbar
|
||||||
<WorkspaceDrawer styleManager={this.state.styleManager}/>
|
onStyleUpload={this.onStyleUpload.bind(this)}
|
||||||
|
onStyleDownload={this.onStyleDownload.bind(this)}
|
||||||
|
onOpenSettings={this.onOpenSettings.bind(this)}
|
||||||
|
onOpenLayers={this.onOpenLayers.bind(this)}
|
||||||
|
/>
|
||||||
|
<WorkspaceDrawer workContext={this.state.workContext} styleManager={this.state.styleManager}/>
|
||||||
<div className={layout.map}>
|
<div className={layout.map}>
|
||||||
<Map styleManager={this.state.styleManager} />
|
<Map styleManager={this.state.styleManager} />
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -10,7 +10,9 @@ import theme from './theme.js';
|
||||||
export class Toolbar extends React.Component {
|
export class Toolbar extends React.Component {
|
||||||
static propTypes = {
|
static propTypes = {
|
||||||
onStyleUpload: React.PropTypes.func.isRequired,
|
onStyleUpload: React.PropTypes.func.isRequired,
|
||||||
onStyleDownload: React.PropTypes.func.isRequired
|
onStyleDownload: React.PropTypes.func.isRequired,
|
||||||
|
onOpenSettings: React.PropTypes.func,
|
||||||
|
onOpenLayers: React.PropTypes.func,
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
|
@ -68,9 +70,16 @@ export class Toolbar extends React.Component {
|
||||||
</Block>
|
</Block>
|
||||||
{downloadButton}
|
{downloadButton}
|
||||||
<Block>
|
<Block>
|
||||||
<Button big={true}>
|
<Button big={true} onClick={this.props.onOpenLayers}>
|
||||||
<Tooltip inverted rounded title="Layers">
|
<Tooltip inverted rounded title="Layers">
|
||||||
<MdLayers />
|
<MdLayers />
|
||||||
|
</Tooltip>
|
||||||
|
</Button>
|
||||||
|
</Block>
|
||||||
|
<Block>
|
||||||
|
<Button big={true} onClick={this.props.onOpenSettings}>
|
||||||
|
<Tooltip inverted rounded title="Settings">
|
||||||
|
<MdSettings />
|
||||||
</Tooltip>
|
</Tooltip>
|
||||||
</Button>
|
</Button>
|
||||||
</Block>
|
</Block>
|
||||||
|
|
33
src/workspace.jsx
Normal file
33
src/workspace.jsx
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
import React from 'react'
|
||||||
|
import { LayerEditor } from './layers.jsx'
|
||||||
|
import theme from './theme.js'
|
||||||
|
|
||||||
|
/** The workspace drawer contains the editor components depending on the context
|
||||||
|
* chosen in the toolbar. */
|
||||||
|
export class WorkspaceDrawer extends React.Component {
|
||||||
|
static propTypes = {
|
||||||
|
workContext: React.PropTypes.oneOf(['layers', 'settings']).isRequired,
|
||||||
|
styleManager: React.PropTypes.object.isRequired
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
let workspaceContent = null
|
||||||
|
|
||||||
|
if(this.props.workContext === "layers" && this.props.styleManager.mapStyle) {
|
||||||
|
workspaceContent = <LayerEditor styleManager={this.props.styleManager}/>
|
||||||
|
}
|
||||||
|
|
||||||
|
return <div style={{
|
||||||
|
zIndex: 100,
|
||||||
|
position: "fixed",
|
||||||
|
left: 60,
|
||||||
|
width: 300,
|
||||||
|
top: 0,
|
||||||
|
bottom: 0,
|
||||||
|
overflow: "hidden",
|
||||||
|
backgroundColor: theme.colors.gray}
|
||||||
|
}>
|
||||||
|
{workspaceContent}
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue