import React from 'react' import Immutable from 'immutable' import color from 'color' import GlSpec from 'mapbox-gl-style-spec/reference/latest.min.js' import NumberField from './number' import EnumField from './enum' import BooleanField from './boolean' import ColorField from './color' import StringField from './string' import inputStyle from './input.js' import theme from '../theme.js' function isZoomField(value) { return Immutable.Map.isMap(value) } const specFieldProps = { onChange: React.PropTypes.func.isRequired, fieldName: React.PropTypes.string.isRequired, fieldSpec: React.PropTypes.object.isRequired, } /** Supports displaying spec field for zoom function objects * https://www.mapbox.com/mapbox-gl-style-spec/#types-function-zoom-property */ class ZoomSpecField extends React.Component { static propTypes = { ...specFieldProps, value: React.PropTypes.oneOfType([ React.PropTypes.object, React.PropTypes.string, React.PropTypes.number, React.PropTypes.bool, ]), } render() { if(isZoomField(this.props.value)) { const zoomFields = this.props.value.get('stops').map(stop => { const zoomLevel = stop.get(0) const value = stop.get(1) return
Zoom Level {zoomLevel}
}).toSeq() return
{zoomFields}
} else { return } } } function labelFromFieldName(fieldName) { let label = fieldName.split('-').slice(1).join(' ') if(label.length > 0) { label = label.charAt(0).toUpperCase() + label.slice(1); } return label } /** Display any field from the Mapbox GL style spec and * choose the correct field component based on the @{fieldSpec} * to display @{value}. */ class SpecField extends React.Component { static propTypes = { ...specFieldProps, value: React.PropTypes.oneOfType([ React.PropTypes.string, React.PropTypes.number, ]), /** Override the style of the field */ style: React.PropTypes.object, } onValueChanged(property, value) { return this.props.onChange(property, value) } render() { const label = labelFromFieldName(this.props.fieldName) switch(this.props.fieldSpec.type) { case 'number': return ( ) case 'enum': return ( ) case 'string': return ( ) case 'color': return ( ) case 'boolean': return ( ) default: return null } } } export class PropertyGroup extends React.Component { static propTypes = { onChange: React.PropTypes.func.isRequired, properties: React.PropTypes.instanceOf(Immutable.Map).isRequired, layerType: React.PropTypes.oneOf(['fill', 'background', 'line', 'symbol']).isRequired, groupType: React.PropTypes.oneOf(['paint', 'layout']).isRequired, } render() { const layerTypeSpec = GlSpec[this.props.groupType + "_" + this.props.layerType] const specFields = Object.keys(layerTypeSpec).filter(propName => propName !== 'visibility').map(propName => { const fieldSpec = layerTypeSpec[propName] const propValue = this.props.properties.get(propName) return }) return
{specFields}
} }