maputnik/src/layers/list.jsx

82 lines
1.8 KiB
React
Raw Normal View History

2016-09-10 14:10:25 +02:00
import React from 'react'
import Immutable from 'immutable'
import { Heading, Toolbar, NavItem, Space} from 'rebass'
import { LayerEditor } from './editor.jsx'
import scrollbars from '../scrollbars.scss'
// List of collapsible layer editors
export class LayerList extends React.Component {
static propTypes = {
layers: React.PropTypes.instanceOf(Immutable.List),
2016-09-10 15:15:17 +02:00
onLayersChanged: React.PropTypes.func.isRequired
}
2016-09-10 14:10:25 +02:00
constructor(props) {
super(props)
}
onLayerDestroyed(deletedLayer) {
//TODO: That's just horrible...
2016-09-10 16:56:52 +02:00
// Can we use a immutable ordered map to look up and guarantee order
// at the same time?
2016-09-10 14:10:25 +02:00
let deleteIdx = -1
2016-09-10 16:56:52 +02:00
for (let entry of this.props.layers.entries()) {
let [i, layer] = entry
if(layer.get('id') == deletedLayer.get('id')) {
2016-09-10 14:10:25 +02:00
deleteIdx = i
break
}
}
2016-09-10 16:56:52 +02:00
this.props.onLayersChanged(this.props.layers.delete(deleteIdx))
2016-09-10 14:10:25 +02:00
}
onLayerChanged(changedLayer) {
//TODO: That's just horrible...
let changeIdx = -1
for (let entry of this.props.layers.entries()) {
let [i, layer] = entry
if(layer.get('id') == changedLayer.get('id')) {
changeIdx = i
break
}
}
const changedLayers = this.props.layers.set(changeIdx, changedLayer)
this.props.onLayersChanged(changedLayers)
}
render() {
var layerPanels = []
for(let layer of this.props.layers) {
layerPanels.push(<LayerEditor
key={layer.get('id')}
layer={layer}
onLayerDestroyed={this.onLayerDestroyed.bind(this)}
onLayerChanged={this.onLayerChanged.bind(this)}
/>)
}
return <div>
<Toolbar style={{marginRight: 20}}>
<NavItem>
<Heading>Layers</Heading>
</NavItem>
<Space auto x={1} />
</Toolbar>
<div className={scrollbars.darkScrollbar} style={{
overflowY: "scroll",
bottom:0,
left:0,
right:0,
top:40,
position: "absolute",
}}>
{layerPanels}
</div>
</div>
}
}