2016-12-16 16:52:16 +01:00
|
|
|
import React from 'react'
|
2017-11-06 16:32:04 +01:00
|
|
|
import PropTypes from 'prop-types'
|
2016-12-16 16:52:16 +01:00
|
|
|
|
2017-11-07 11:21:39 +01:00
|
|
|
import styleSpec from '@mapbox/mapbox-gl-style-spec/style-spec'
|
2016-12-21 14:36:09 +01:00
|
|
|
import InputBlock from '../inputs/InputBlock'
|
|
|
|
import StringInput from '../inputs/StringInput'
|
|
|
|
import SelectInput from '../inputs/SelectInput'
|
|
|
|
import Modal from './Modal'
|
2016-12-16 16:52:16 +01:00
|
|
|
|
|
|
|
class SettingsModal extends React.Component {
|
|
|
|
static propTypes = {
|
2017-11-06 16:32:04 +01:00
|
|
|
mapStyle: PropTypes.object.isRequired,
|
|
|
|
onStyleChanged: PropTypes.func.isRequired,
|
|
|
|
isOpen: PropTypes.bool.isRequired,
|
|
|
|
onOpenToggle: PropTypes.func.isRequired,
|
2016-12-16 16:52:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
}
|
|
|
|
|
2016-12-29 17:32:23 +01:00
|
|
|
changeStyleProperty(property, value) {
|
|
|
|
const changedStyle = {
|
|
|
|
...this.props.mapStyle,
|
|
|
|
[property]: value
|
|
|
|
}
|
2016-12-16 16:52:16 +01:00
|
|
|
this.props.onStyleChanged(changedStyle)
|
|
|
|
}
|
|
|
|
|
2016-12-29 17:32:23 +01:00
|
|
|
changeMetadataProperty(property, value) {
|
2016-12-22 18:08:42 +01:00
|
|
|
const changedStyle = {
|
|
|
|
...this.props.mapStyle,
|
|
|
|
metadata: {
|
|
|
|
...this.props.mapStyle.metadata,
|
2016-12-29 17:32:23 +01:00
|
|
|
[property]: value
|
2016-12-22 18:08:42 +01:00
|
|
|
}
|
|
|
|
}
|
2016-12-16 17:13:05 +01:00
|
|
|
this.props.onStyleChanged(changedStyle)
|
|
|
|
}
|
|
|
|
|
2016-12-16 16:52:16 +01:00
|
|
|
render() {
|
2016-12-28 21:50:47 +01:00
|
|
|
const metadata = this.props.mapStyle.metadata || {}
|
2016-12-21 16:50:34 +01:00
|
|
|
const inputProps = { }
|
2016-12-21 14:36:09 +01:00
|
|
|
return <Modal
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings"
|
2016-12-21 16:11:08 +01:00
|
|
|
isOpen={this.props.isOpen}
|
2016-12-22 16:35:31 +01:00
|
|
|
onOpenToggle={this.props.onOpenToggle}
|
2017-01-09 22:37:21 +01:00
|
|
|
title={'Style Settings'}
|
2016-12-21 14:36:09 +01:00
|
|
|
>
|
2017-01-13 15:31:28 +01:00
|
|
|
<div style={{minWidth: 350}}>
|
2017-04-10 14:29:57 +02:00
|
|
|
<InputBlock label={"Name"} doc={styleSpec.latest.$root.name.doc}>
|
2016-12-21 14:36:09 +01:00
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.name"
|
2016-12-20 16:08:49 +01:00
|
|
|
value={this.props.mapStyle.name}
|
2016-12-29 17:32:23 +01:00
|
|
|
onChange={this.changeStyleProperty.bind(this, "name")}
|
2016-12-16 16:52:16 +01:00
|
|
|
/>
|
2016-12-21 14:36:09 +01:00
|
|
|
</InputBlock>
|
2017-01-09 22:37:21 +01:00
|
|
|
<InputBlock label={"Owner"} doc={"Owner ID of the style. Used by Mapbox or future style APIs."}>
|
2016-12-21 14:36:09 +01:00
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.owner"
|
2016-12-20 16:08:49 +01:00
|
|
|
value={this.props.mapStyle.owner}
|
2016-12-29 17:32:23 +01:00
|
|
|
onChange={this.changeStyleProperty.bind(this, "owner")}
|
2016-12-16 16:52:16 +01:00
|
|
|
/>
|
2016-12-21 14:36:09 +01:00
|
|
|
</InputBlock>
|
2017-04-10 14:29:57 +02:00
|
|
|
<InputBlock label={"Sprite URL"} doc={styleSpec.latest.$root.sprite.doc}>
|
2016-12-21 14:36:09 +01:00
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.sprite"
|
2016-12-20 16:08:49 +01:00
|
|
|
value={this.props.mapStyle.sprite}
|
2016-12-29 17:32:23 +01:00
|
|
|
onChange={this.changeStyleProperty.bind(this, "sprite")}
|
2016-12-16 16:52:16 +01:00
|
|
|
/>
|
2016-12-21 14:36:09 +01:00
|
|
|
</InputBlock>
|
|
|
|
|
2017-04-10 14:29:57 +02:00
|
|
|
<InputBlock label={"Glyphs URL"} doc={styleSpec.latest.$root.glyphs.doc}>
|
2016-12-21 14:36:09 +01:00
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.glyphs"
|
2016-12-20 16:08:49 +01:00
|
|
|
value={this.props.mapStyle.glyphs}
|
2016-12-29 17:32:23 +01:00
|
|
|
onChange={this.changeStyleProperty.bind(this, "glyphs")}
|
2016-12-16 17:13:05 +01:00
|
|
|
/>
|
2016-12-21 14:36:09 +01:00
|
|
|
</InputBlock>
|
|
|
|
|
2017-01-13 15:31:28 +01:00
|
|
|
<InputBlock label={"Mapbox Access Token"} doc={"Public access token for Mapbox services."}>
|
2016-12-28 21:50:47 +01:00
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.maputnik:mapbox_access_token"
|
2017-01-13 15:31:28 +01:00
|
|
|
value={metadata['maputnik:mapbox_access_token']}
|
|
|
|
onChange={this.changeMetadataProperty.bind(this, "maputnik:mapbox_access_token")}
|
|
|
|
/>
|
|
|
|
</InputBlock>
|
|
|
|
|
|
|
|
<InputBlock label={"OpenMapTiles Access Token"} doc={"Public access token for the OpenMapTiles CDN."}>
|
|
|
|
<StringInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.maputnik:openmaptiles_access_token"
|
2017-01-13 15:31:28 +01:00
|
|
|
value={metadata['maputnik:openmaptiles_access_token']}
|
|
|
|
onChange={this.changeMetadataProperty.bind(this, "maputnik:openmaptiles_access_token")}
|
2016-12-28 21:50:47 +01:00
|
|
|
/>
|
|
|
|
</InputBlock>
|
2016-12-21 14:36:09 +01:00
|
|
|
|
2017-01-09 22:37:21 +01:00
|
|
|
<InputBlock label={"Style Renderer"} doc={"Choose the default Maputnik renderer for this style."}>
|
2016-12-21 14:36:09 +01:00
|
|
|
<SelectInput {...inputProps}
|
2018-01-05 18:45:55 +01:00
|
|
|
data-wd-key="modal-settings.maputnik:renderer"
|
2016-12-21 14:36:09 +01:00
|
|
|
options={[
|
|
|
|
['mbgljs', 'MapboxGL JS'],
|
2016-12-24 14:42:57 +01:00
|
|
|
['ol3', 'Open Layers 3'],
|
2016-12-21 14:36:09 +01:00
|
|
|
]}
|
2016-12-28 21:50:47 +01:00
|
|
|
value={metadata['maputnik:renderer'] || 'mbgljs'}
|
2016-12-29 17:32:23 +01:00
|
|
|
onChange={this.changeMetadataProperty.bind(this, 'maputnik:renderer')}
|
2016-12-16 17:13:05 +01:00
|
|
|
/>
|
2016-12-21 14:36:09 +01:00
|
|
|
</InputBlock>
|
2017-01-13 15:31:28 +01:00
|
|
|
</div>
|
2016-12-21 14:36:09 +01:00
|
|
|
</Modal>
|
2016-12-16 16:52:16 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SettingsModal
|