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), onLayersChanged: React.PropTypes.func.isRequired } constructor(props) { super(props) } onLayerDestroyed(deletedLayer) { //TODO: That's just horrible... // Can we use a immutable ordered map to look up and guarantee order // at the same time? let deleteIdx = -1 for (let entry of this.props.layers.entries()) { let [i, layer] = entry if(layer.get('id') == deletedLayer.get('id')) { deleteIdx = i break } } this.props.onLayersChanged(this.props.layers.delete(deleteIdx)) } 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() } return
Layers
{layerPanels}
} }