mirror of
https://github.com/a-nyx/maputnik-with-pmtiles.git
synced 2025-01-15 23:01:18 +01:00
Hack on showing readonly filters
This commit is contained in:
parent
c4173aa458
commit
000a06f067
2 changed files with 67 additions and 0 deletions
62
src/filter/editor.jsx
Normal file
62
src/filter/editor.jsx
Normal file
|
@ -0,0 +1,62 @@
|
||||||
|
import React from 'react'
|
||||||
|
import Immutable from 'immutable'
|
||||||
|
import { PropertyGroup } from '../fields/spec'
|
||||||
|
import PureRenderMixin from 'react-addons-pure-render-mixin';
|
||||||
|
import inputStyle from '../fields/input.js'
|
||||||
|
import GlSpec from 'mapbox-gl-style-spec/reference/latest.min.js'
|
||||||
|
|
||||||
|
export default class FilterEditor extends React.Component {
|
||||||
|
static propTypes = {
|
||||||
|
filter: React.PropTypes.array.isRequired,
|
||||||
|
onFilterChanged: React.PropTypes.func.isRequired,
|
||||||
|
}
|
||||||
|
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.shouldComponentUpdate = PureRenderMixin.shouldComponentUpdate.bind(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
const op = this.props.filter[0]
|
||||||
|
const filters = this.props.filter.slice(1)
|
||||||
|
const filterElems = filters.map(f => {
|
||||||
|
const filterOp = f[0]
|
||||||
|
const prop = f[1]
|
||||||
|
const args = f.slice(2)
|
||||||
|
|
||||||
|
const availableFilterOperators = GlSpec.filter_operator.values
|
||||||
|
const filterOpOptions = availableFilterOperators.map(value => {
|
||||||
|
return <option value={value}>{value}</option>
|
||||||
|
})
|
||||||
|
|
||||||
|
return <div>
|
||||||
|
<select
|
||||||
|
style={{...inputStyle.select, width: '15%'}}
|
||||||
|
value={filterOp}
|
||||||
|
>
|
||||||
|
{filterOpOptions}
|
||||||
|
</select>
|
||||||
|
<input
|
||||||
|
style={{...inputStyle.input, width: '17%'}}
|
||||||
|
value={prop}
|
||||||
|
/>
|
||||||
|
<input
|
||||||
|
style={{...inputStyle.input, width: '55%'}}
|
||||||
|
value={args}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
})
|
||||||
|
|
||||||
|
return <div>
|
||||||
|
<select
|
||||||
|
style={{...inputStyle.select, width: '15%'}}
|
||||||
|
value={op}
|
||||||
|
>
|
||||||
|
<option value={"all"}>all</option>
|
||||||
|
<option value={"any"}>any</option>
|
||||||
|
</select>
|
||||||
|
<br/>
|
||||||
|
{filterElems}
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
}
|
|
@ -12,6 +12,7 @@ import LineLayer from './line.jsx'
|
||||||
import SymbolLayer from './symbol.jsx'
|
import SymbolLayer from './symbol.jsx'
|
||||||
import BackgroundLayer from './background.jsx'
|
import BackgroundLayer from './background.jsx'
|
||||||
import SourceEditor from './source.jsx'
|
import SourceEditor from './source.jsx'
|
||||||
|
import FilterEditor from '../filter/editor.jsx'
|
||||||
|
|
||||||
import MdVisibility from 'react-icons/lib/md/visibility'
|
import MdVisibility from 'react-icons/lib/md/visibility'
|
||||||
import MdVisibilityOff from 'react-icons/lib/md/visibility-off'
|
import MdVisibilityOff from 'react-icons/lib/md/visibility-off'
|
||||||
|
@ -147,6 +148,10 @@ export class LayerEditor extends React.Component {
|
||||||
<MdDelete />
|
<MdDelete />
|
||||||
</NavItem>
|
</NavItem>
|
||||||
</Toolbar>
|
</Toolbar>
|
||||||
|
<FilterEditor
|
||||||
|
filter={this.props.layer.get('filter').toJSON()}
|
||||||
|
onFilterChanged={console.log}
|
||||||
|
/>
|
||||||
{this.props.layer.get('type') !== 'background' && <SourceEditor
|
{this.props.layer.get('type') !== 'background' && <SourceEditor
|
||||||
source={this.props.layer.get('source')}
|
source={this.props.layer.get('source')}
|
||||||
sourceLayer={this.props.layer.get('source-layer')}
|
sourceLayer={this.props.layer.get('source-layer')}
|
||||||
|
|
Loading…
Reference in a new issue