From 2978210a4d3e6893654f7ccdd09ea8cf9d876ee9 Mon Sep 17 00:00:00 2001 From: lukasmartinelli Date: Fri, 9 Sep 2016 19:14:55 +0200 Subject: [PATCH] Support visibility toggle --- src/layers.jsx | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/src/layers.jsx b/src/layers.jsx index 587f8ec..f7cfd86 100644 --- a/src/layers.jsx +++ b/src/layers.jsx @@ -2,7 +2,7 @@ import React from 'react' import randomColor from 'randomcolor' import { Block, ButtonCircle, Heading, Checkbox, Slider, Switch, Input, Panel, PanelHeader, Toolbar, NavItem, Tooltip, Container, Space} from 'rebass' import { Button, Text } from 'rebass' -import {MdArrowDropDown, MdArrowDropUp, MdAddToPhotos, MdDelete, MdVisibilityOff} from 'react-icons/lib/md'; +import {MdVisibility, MdArrowDropDown, MdArrowDropUp, MdAddToPhotos, MdDelete, MdVisibilityOff} from 'react-icons/lib/md'; import Collapse from 'react-collapse' import theme from './theme.js' import scrollbars from './scrollbars.scss' @@ -118,6 +118,16 @@ export class LayerPanel extends React.Component { this.setState({ layer }); } + onLayoutChanged(property, newValue) { + let layer = this.state.layer + layer.layout[property] = newValue; + this.props.styleManager.changeStyle({ + command: 'setLayoutProperty', + args: [layer.id, property, newValue] + }) + this.setState({ layer }); + } + toggleLayer() { this.setState({isOpened: !this.state.isOpened}) } @@ -141,7 +151,21 @@ export class LayerPanel extends React.Component { return } + toggleVisibility() { + console.log(this.state.layer) + if(this.state.layer.layout.visibility === 'none') { + this.onLayoutChanged('visibility', 'visible') + } else { + this.onLayoutChanged('visibility', 'none') + } + } + render() { + let visibleIcon = + if(this.state.layer.layout && this.state.layer.layout.visibility === 'none') { + visibleIcon = + } + return
- - + + {visibleIcon}