2016-12-21 11:24:32 +01:00
|
|
|
import React from 'react'
|
|
|
|
|
2016-12-22 11:52:21 +01:00
|
|
|
import Collapse from 'react-collapse'
|
2016-12-21 11:24:32 +01:00
|
|
|
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() {
|
2016-12-21 11:27:49 +01:00
|
|
|
return <div>
|
2017-01-10 21:28:30 +01:00
|
|
|
<div className="maputnik-layer-editor-group"
|
2016-12-21 11:27:49 +01:00
|
|
|
onClick={e => this.props.onActiveToggle(!this.props.isActive)}
|
|
|
|
>
|
2016-12-21 11:24:32 +01:00
|
|
|
<span>{this.props.title}</span>
|
|
|
|
<span style={{flexGrow: 1}} />
|
|
|
|
<Collapser isCollapsed={this.props.isActive} />
|
|
|
|
</div>
|
2016-12-22 12:06:04 +01:00
|
|
|
<Collapse isOpened={this.props.isActive}>
|
|
|
|
{this.props.children}
|
|
|
|
</Collapse>
|
2016-12-21 11:24:32 +01:00
|
|
|
</div>
|
|
|
|
}
|
|
|
|
}
|