import React from 'react' import PropTypes from 'prop-types' import Button from '../Button' import InputBlock from '../inputs/InputBlock' import StringInput from '../inputs/StringInput' import SelectInput from '../inputs/SelectInput' import Modal from './Modal' import LayerTypeBlock from '../layers/LayerTypeBlock' import LayerIdBlock from '../layers/LayerIdBlock' import LayerSourceBlock from '../layers/LayerSourceBlock' import LayerSourceLayerBlock from '../layers/LayerSourceLayerBlock' class AddModal extends React.Component { static propTypes = { layers: PropTypes.array.isRequired, onLayersChange: PropTypes.func.isRequired, isOpen: PropTypes.bool.isRequired, onOpenToggle: PropTypes.func.isRequired, // A dict of source id's and the available source layers sources: PropTypes.object.isRequired, } addLayer() { const changedLayers = this.props.layers.slice(0) const layer = { id: this.state.id, type: this.state.type, } if(this.state.type !== 'background') { layer.source = this.state.source if(this.state.type !== 'raster' && this.state['source-layer']) { layer['source-layer'] = this.state['source-layer'] } } changedLayers.push(layer) this.props.onLayersChange(changedLayers) this.props.onOpenToggle(false) } constructor(props) { super(props) this.state = { type: 'fill', id: '', } if(props.sources.length > 0) { this.state.source = Object.keys(this.props.sources)[0] this.state['source-layer'] = this.props.sources[this.state.source][0] } } componentWillReceiveProps(nextProps) { const sourceIds = Object.keys(nextProps.sources) if(!this.state.source && sourceIds.length > 0) { this.setState({ source: sourceIds[0], 'source-layer': this.state['source-layer'] || (nextProps.sources[sourceIds[0]] || [])[0] }) } } render() { return
this.setState({ id: v })} /> this.setState({ type: v })} /> {this.state.type !== 'background' && this.setState({ source: v })} /> } {this.state.type !== 'background' && this.state.type !== 'raster' && this.setState({ 'source-layer': v })} /> }
} } export default AddModal