mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-07 13:45:26 +01:00
bd9076c4ff
This is to make the following options accessible to keyboard users - reorder layers - duplicate layer - delete layer - hide/show layer
126 lines
3.4 KiB
JavaScript
126 lines
3.4 KiB
JavaScript
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import Color from 'color'
|
|
import classnames from 'classnames'
|
|
|
|
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'
|
|
|
|
@SortableHandle
|
|
class LayerTypeDragHandle extends React.Component {
|
|
static propTypes = LayerIcon.propTypes
|
|
|
|
render() {
|
|
return <LayerIcon
|
|
{...this.props}
|
|
style={{
|
|
cursor: 'move',
|
|
width: 14,
|
|
height: 14,
|
|
paddingRight: 3,
|
|
}}
|
|
/>
|
|
}
|
|
}
|
|
|
|
class IconAction extends React.Component {
|
|
static propTypes = {
|
|
action: PropTypes.string.isRequired,
|
|
onClick: PropTypes.func.isRequired,
|
|
wdKey: PropTypes.string
|
|
}
|
|
|
|
renderIcon() {
|
|
switch(this.props.action) {
|
|
case 'duplicate': return <CopyIcon />
|
|
case 'show': return <VisibilityIcon />
|
|
case 'hide': return <VisibilityOffIcon />
|
|
case 'delete': return <DeleteIcon />
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return <button
|
|
tabIndex="-1"
|
|
title={this.props.action}
|
|
className="maputnik-layer-list-icon-action"
|
|
data-wd-key={this.props.wdKey}
|
|
onClick={this.props.onClick}
|
|
>
|
|
{this.renderIcon()}
|
|
</button>
|
|
}
|
|
}
|
|
|
|
@SortableElement
|
|
class LayerListItem extends React.Component {
|
|
static propTypes = {
|
|
layerId: PropTypes.string.isRequired,
|
|
layerType: PropTypes.string.isRequired,
|
|
isSelected: PropTypes.bool,
|
|
visibility: PropTypes.string,
|
|
className: PropTypes.string,
|
|
|
|
onLayerSelect: PropTypes.func.isRequired,
|
|
onLayerCopy: PropTypes.func,
|
|
onLayerDestroy: PropTypes.func,
|
|
onLayerVisibilityToggle: PropTypes.func,
|
|
}
|
|
|
|
static defaultProps = {
|
|
isSelected: false,
|
|
visibility: 'visible',
|
|
onLayerCopy: () => {},
|
|
onLayerDestroy: () => {},
|
|
onLayerVisibilityToggle: () => {},
|
|
}
|
|
|
|
static childContextTypes = {
|
|
reactIconBase: PropTypes.object
|
|
}
|
|
|
|
getChildContext() {
|
|
return {
|
|
reactIconBase: { size: 14 }
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return <li
|
|
key={this.props.layerId}
|
|
onClick={e => this.props.onLayerSelect(this.props.layerId)}
|
|
data-wd-key={"layer-list-item:"+this.props.layerId}
|
|
className={classnames({
|
|
"maputnik-layer-list-item": true,
|
|
"maputnik-layer-list-item-selected": this.props.isSelected,
|
|
[this.props.className]: true,
|
|
})}>
|
|
<LayerTypeDragHandle type={this.props.layerType} />
|
|
<span className="maputnik-layer-list-item-id">{this.props.layerId}</span>
|
|
<span style={{flexGrow: 1}} />
|
|
<IconAction
|
|
wdKey={"layer-list-item:"+this.props.layerId+":delete"}
|
|
action={'delete'}
|
|
onClick={e => this.props.onLayerDestroy(this.props.layerId)}
|
|
/>
|
|
<IconAction
|
|
wdKey={"layer-list-item:"+this.props.layerId+":copy"}
|
|
action={'duplicate'}
|
|
onClick={e => this.props.onLayerCopy(this.props.layerId)}
|
|
/>
|
|
<IconAction
|
|
wdKey={"layer-list-item:"+this.props.layerId+":toggle-visibility"}
|
|
action={this.props.visibility === 'visible' ? 'hide' : 'show'}
|
|
onClick={e => this.props.onLayerVisibilityToggle(this.props.layerId)}
|
|
/>
|
|
</li>
|
|
}
|
|
}
|
|
|
|
export default LayerListItem;
|