mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-16 00:01:20 +01:00
Collapsible editor groups
This commit is contained in:
parent
2a34424898
commit
18674f5edb
2 changed files with 129 additions and 30 deletions
|
@ -1,11 +1,9 @@
|
||||||
import React from 'react'
|
import React from 'react'
|
||||||
|
|
||||||
import Toolbar from 'rebass/dist/Toolbar'
|
|
||||||
import NavItem from 'rebass/dist/NavItem'
|
|
||||||
|
|
||||||
import SourceEditor from './SourceEditor'
|
import SourceEditor from './SourceEditor'
|
||||||
import FilterEditor from '../filter/FilterEditor'
|
import FilterEditor from '../filter/FilterEditor'
|
||||||
import PropertyGroup from '../fields/PropertyGroup'
|
import PropertyGroup from '../fields/PropertyGroup'
|
||||||
|
import LayerEditorGroup from './LayerEditorGroup'
|
||||||
|
|
||||||
import ScrollContainer from '../ScrollContainer'
|
import ScrollContainer from '../ScrollContainer'
|
||||||
|
|
||||||
|
@ -37,7 +35,30 @@ export default class LayerEditor extends React.Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props)
|
||||||
|
|
||||||
|
//TODO: Clean this up and refactor into function
|
||||||
|
const editorGroups = {}
|
||||||
|
layout[this.props.layer.type].groups.forEach(group => {
|
||||||
|
editorGroups[group.title] = true
|
||||||
|
})
|
||||||
|
editorGroups['Source'] = true
|
||||||
|
|
||||||
|
this.state = { editorGroups }
|
||||||
|
}
|
||||||
|
|
||||||
|
componentWillReceiveProps(nextProps) {
|
||||||
|
const additionalGroups = { ...this.state.editorGroups }
|
||||||
|
|
||||||
|
layout[nextProps.layer.type].groups.forEach(group => {
|
||||||
|
if(!(group.title in additionalGroups)) {
|
||||||
|
additionalGroups[group.title] = true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
this.setState({
|
||||||
|
editorGroups: additionalGroups
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
getChildContext () {
|
getChildContext () {
|
||||||
|
@ -71,28 +92,42 @@ export default class LayerEditor extends React.Component {
|
||||||
this.props.onLayerChanged(changedLayer)
|
this.props.onLayerChanged(changedLayer)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onGroupToggle(groupTitle, active) {
|
||||||
|
const changedActiveGroups = {
|
||||||
|
...this.state.editorGroups,
|
||||||
|
[groupTitle]: active,
|
||||||
|
}
|
||||||
|
this.setState({
|
||||||
|
editorGroups: changedActiveGroups
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
|
console.log('editor groups', this.state.editorGroups)
|
||||||
const layerType = this.props.layer.type
|
const layerType = this.props.layer.type
|
||||||
const groups = layout[layerType].groups
|
const groups = layout[layerType].groups
|
||||||
const propertyGroups = groups.map(group => {
|
const propertyGroups = groups.map(group => {
|
||||||
return <PropertyGroup
|
return <LayerEditorGroup
|
||||||
key={this.props.group}
|
key={group.title}
|
||||||
|
title={group.title}
|
||||||
|
isActive={this.state.editorGroups[group.title]}
|
||||||
|
onActiveToggle={this.onGroupToggle.bind(this, group.title)}
|
||||||
|
>
|
||||||
|
<PropertyGroup
|
||||||
layer={this.props.layer}
|
layer={this.props.layer}
|
||||||
groupFields={group.fields}
|
groupFields={group.fields}
|
||||||
onChange={this.onPropertyChange.bind(this)}
|
onChange={this.onPropertyChange.bind(this)}
|
||||||
/>
|
/>
|
||||||
|
</LayerEditorGroup>
|
||||||
})
|
})
|
||||||
|
|
||||||
return <div style={{
|
let dataGroup = null
|
||||||
padding: theme.scale[0],
|
if(this.props.layer.type !== 'background') {
|
||||||
}}>
|
dataGroup = <LayerEditorGroup
|
||||||
<Toolbar>
|
title="Source"
|
||||||
<NavItem style={{fontWeight: 400}}>
|
isActive={this.state.editorGroups['Source']}
|
||||||
{this.props.layer.id}
|
onActiveToggle={this.onGroupToggle.bind(this, 'Source')}
|
||||||
</NavItem>
|
>
|
||||||
</Toolbar>
|
|
||||||
{propertyGroups}
|
|
||||||
{this.props.layer.type !== 'background' && <div>
|
|
||||||
<FilterEditor
|
<FilterEditor
|
||||||
filter={this.props.layer.filter}
|
filter={this.props.layer.filter}
|
||||||
properties={this.props.vectorLayers[this.props.layer['source-layer']]}
|
properties={this.props.vectorLayers[this.props.layer['source-layer']]}
|
||||||
|
@ -105,7 +140,14 @@ export default class LayerEditor extends React.Component {
|
||||||
onSourceChange={console.log}
|
onSourceChange={console.log}
|
||||||
onSourceLayerChange={console.log}
|
onSourceLayerChange={console.log}
|
||||||
/>
|
/>
|
||||||
</div>}
|
</LayerEditorGroup>
|
||||||
|
}
|
||||||
|
|
||||||
|
return <div style={{
|
||||||
|
padding: theme.scale[0],
|
||||||
|
}}>
|
||||||
|
{propertyGroups}
|
||||||
|
{dataGroup}
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
57
src/components/layers/LayerEditorGroup.jsx
Normal file
57
src/components/layers/LayerEditorGroup.jsx
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
import React from 'react'
|
||||||
|
import colors from '../../config/colors'
|
||||||
|
import { margins, fontSizes } from '../../config/scales'
|
||||||
|
|
||||||
|
import CollapseOpenIcon from 'react-icons/lib/md/arrow-drop-down'
|
||||||
|
import CollapseCloseIcon from 'react-icons/lib/md/arrow-drop-up'
|
||||||
|
|
||||||
|
class Collapser extends React.Component {
|
||||||
|
static propTypes = {
|
||||||
|
isCollapsed: React.PropTypes.bool.isRequired,
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
const iconStyle = {
|
||||||
|
width: 20,
|
||||||
|
height: 20,
|
||||||
|
}
|
||||||
|
return this.props.isCollapsed ? <CollapseCloseIcon style={iconStyle}/> : <CollapseOpenIcon style={iconStyle} />
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default class LayerEditorGroup extends React.Component {
|
||||||
|
static propTypes = {
|
||||||
|
title: React.PropTypes.string.isRequired,
|
||||||
|
isActive: React.PropTypes.bool.isRequired,
|
||||||
|
children: React.PropTypes.element.isRequired,
|
||||||
|
onActiveToggle: React.PropTypes.func.isRequired
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return <div
|
||||||
|
onClick={e => this.props.onActiveToggle(!this.props.isActive)}
|
||||||
|
>
|
||||||
|
<div style={{
|
||||||
|
fontSize: fontSizes[4],
|
||||||
|
backgroundColor: colors.gray,
|
||||||
|
color: colors.lowgray,
|
||||||
|
padding: margins[1],
|
||||||
|
display: 'flex',
|
||||||
|
flexDirection: 'row',
|
||||||
|
lineHeight: '20px',
|
||||||
|
}}>
|
||||||
|
<span>{this.props.title}</span>
|
||||||
|
<span style={{flexGrow: 1}} />
|
||||||
|
<Collapser isCollapsed={this.props.isActive} />
|
||||||
|
</div>
|
||||||
|
<div style={{
|
||||||
|
display: this.props.isActive ? null : 'none',
|
||||||
|
border: 2,
|
||||||
|
borderStyle: 'solid',
|
||||||
|
borderColor: colors.gray,
|
||||||
|
}}>
|
||||||
|
{this.props.children}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue