import React from 'react' import Color from 'color' import CopyIcon from 'react-icons/lib/md/content-copy' import VisibilityIcon from 'react-icons/lib/md/visibility' import VisibilityOffIcon from 'react-icons/lib/md/visibility-off' import DeleteIcon from 'react-icons/lib/md/delete' import LayerIcon from '../icons/LayerIcon' import LayerEditor from './LayerEditor' import {SortableElement, SortableHandle} from 'react-sortable-hoc' import colors from '../../config/colors.js' import { fontSizes, margins } from '../../config/scales.js' @SortableHandle class LayerTypeDragHandle extends React.Component { static propTypes = LayerIcon.propTypes render() { return } } class IconAction extends React.Component { static propTypes = { action: React.PropTypes.string.isRequired, active: React.PropTypes.bool, onClick: React.PropTypes.func.isRequired, } constructor(props) { super(props) this.state = { hover: false } } renderIcon() { const iconStyle = { fill: colors.black } if(this.props.active) { iconStyle.fill = colors.midgray } if(this.state.hover) { iconStyle.fill = colors.lowgray } switch(this.props.action) { case 'copy': return case 'show': return case 'hide': return case 'delete': return default: return null } } render() { return this.setState({hover: true})} onMouseOut={e => this.setState({hover: false})} > {this.renderIcon()} } } @SortableElement class LayerListItem extends React.Component { static propTypes = { layerId: React.PropTypes.string.isRequired, layerType: React.PropTypes.string.isRequired, isSelected: React.PropTypes.bool, visibility: React.PropTypes.string, onLayerSelect: React.PropTypes.func.isRequired, onLayerCopy: React.PropTypes.func, onLayerDestroy: React.PropTypes.func, onLayerVisibilityToggle: React.PropTypes.func, } static defaultProps = { isSelected: false, visibility: 'visible', onLayerCopy: () => {}, onLayerDestroy: () => {}, onLayerVisibilityToggle: () => {}, } static childContextTypes = { reactIconBase: React.PropTypes.object } constructor(props) { super(props) this.state = { hover: false } } getChildContext() { return { reactIconBase: { size: fontSizes[4] } } } render() { const itemStyle = { backgroundColor: colors.black, } if(this.state.hover) { itemStyle.backgroundColor = Color(colors.black).lighten(0.10).string() } if(this.props.isSelected) { itemStyle.backgroundColor = Color(colors.black).lighten(0.15).string() } const iconProps = { active: this.state.hover || this.props.isSelected } return
  • this.props.onLayerSelect(this.props.layerId)} onMouseOver={e => this.setState({hover: true})} onMouseOut={e => this.setState({hover: false})} className="maputnik-layer-list-item" > {this.props.layerId} this.props.onLayerDestroy(this.props.layerId)} /> this.props.onLayerCopy(this.props.layerId)} /> this.props.onLayerVisibilityToggle(this.props.layerId)} />
  • } } export default LayerListItem;