import React from 'react' import Immutable from 'immutable' import Heading from 'rebass/dist/Heading' import Toolbar from 'rebass/dist/Toolbar' import NavItem from 'rebass/dist/NavItem' import Space from 'rebass/dist/Space' import { LayerEditor } from './editor.jsx' import LayerListItem from './listitem.jsx' import scrollbars from '../scrollbars.scss' import PureRenderMixin from 'react-addons-pure-render-mixin'; import theme from '../theme.js' // List of collapsible layer editors export class LayerList extends React.Component { static propTypes = { layers: React.PropTypes.instanceOf(Immutable.OrderedMap), onLayersChanged: React.PropTypes.func.isRequired, onLayerSelected: React.PropTypes.func, } static defaultProps = { onLayerSelected: () => {}, } constructor(props) { super(props) this.shouldComponentUpdate = PureRenderMixin.shouldComponentUpdate.bind(this); } onLayerDestroyed(deletedLayer) { const remainingLayers = this.props.layers.delete(deletedLayer.get('id')) this.props.onLayersChanged(remainingLayers) } onLayerChanged(layer) { const changedLayers = this.props.layers.set(layer.get('id'), layer) this.props.onLayersChanged(changedLayers) } render() { const layerPanels = this.props.layers.map(layer => { const layerId = layer.get('id') return }).toIndexedSeq() return
{layerPanels}
} }