maputnik/src/components/Toolbar.jsx

206 lines
6 KiB
React
Raw Normal View History

2016-12-20 11:44:22 +01:00
import React from 'react'
import FileReaderInput from 'react-file-reader-input'
2016-09-08 19:47:29 +02:00
2016-09-10 14:47:06 +02:00
import MdFileDownload from 'react-icons/lib/md/file-download'
import MdFileUpload from 'react-icons/lib/md/file-upload'
2016-12-28 16:23:33 +01:00
import OpenIcon from 'react-icons/lib/md/open-in-browser'
import SettingsIcon from 'react-icons/lib/md/settings'
import MdInfo from 'react-icons/lib/md/info'
2016-12-28 16:23:33 +01:00
import SourcesIcon from 'react-icons/lib/md/layers'
2016-09-10 14:47:06 +02:00
import MdSave from 'react-icons/lib/md/save'
2016-12-04 17:03:36 +01:00
import MdStyle from 'react-icons/lib/md/style'
2016-09-10 22:08:26 +02:00
import MdMap from 'react-icons/lib/md/map'
2016-12-04 17:03:36 +01:00
import MdInsertEmoticon from 'react-icons/lib/md/insert-emoticon'
import MdFontDownload from 'react-icons/lib/md/font-download'
2016-12-28 16:23:33 +01:00
import HelpIcon from 'react-icons/lib/md/help-outline'
import InspectionIcon from 'react-icons/lib/md/find-in-page'
import AddIcon from 'react-icons/lib/md/add-circle-outline'
2016-09-10 22:08:26 +02:00
import AddModal from './modals/AddModal'
2016-12-20 11:44:22 +01:00
import SettingsModal from './modals/SettingsModal'
2016-12-21 16:11:08 +01:00
import SourcesModal from './modals/SourcesModal'
2016-12-22 11:27:53 +01:00
import OpenModal from './modals/OpenModal'
2016-12-20 11:44:22 +01:00
import style from '../libs/style'
2016-12-21 15:08:04 +01:00
import colors from '../config/colors'
import { margins, fontSizes } from '../config/scales'
2016-09-08 19:47:29 +02:00
2016-12-21 15:08:04 +01:00
const IconText = props => <span style={{ paddingLeft: margins[0] }}>
2016-12-04 17:03:36 +01:00
{props.children}
2016-12-21 15:08:04 +01:00
</span>
2016-12-04 17:03:36 +01:00
2016-12-22 11:37:32 +01:00
const actionStyle = {
display: "inline-block",
2016-12-25 20:36:10 +01:00
padding: 10,
2016-12-22 11:37:32 +01:00
fontSize: fontSizes[4],
cursor: "pointer",
2016-12-22 14:18:07 +01:00
color: colors.white,
2016-12-22 11:37:32 +01:00
textDecoration: 'none',
}
const ToolbarLink = props => <a
href={props.href}
target={"blank"}
style={{
...actionStyle,
...props.style,
}}>
{props.children}
</a>
2016-12-22 14:18:07 +01:00
class ToolbarAction extends React.Component {
static propTypes = {
onClick: React.PropTypes.func.isRequired,
}
2016-12-21 14:46:51 +01:00
2016-12-22 14:18:07 +01:00
constructor(props) {
super(props)
this.state = { hover: false }
}
render() {
return <a
onClick={this.props.onClick}
onMouseOver={e => this.setState({hover: true})}
onMouseOut={e => this.setState({hover: false})}
style={{
...actionStyle,
...this.props.style,
backgroundColor: this.state.hover ? colors.gray : null,
}}>
{this.props.children}
</a>
}
}
2016-12-22 11:27:53 +01:00
2016-12-20 11:44:22 +01:00
export default class Toolbar extends React.Component {
2016-12-04 17:03:36 +01:00
static propTypes = {
2016-12-20 16:08:49 +01:00
mapStyle: React.PropTypes.object.isRequired,
2016-12-16 16:52:16 +01:00
onStyleChanged: React.PropTypes.func.isRequired,
2016-12-04 17:03:36 +01:00
// A new style has been uploaded
2016-12-22 16:51:18 +01:00
onStyleOpen: React.PropTypes.func.isRequired,
2016-12-04 17:03:36 +01:00
// Current style is requested for download
onStyleDownload: React.PropTypes.func.isRequired,
// A dict of source id's and the available source layers
sources: React.PropTypes.object.isRequired,
2016-12-16 16:52:16 +01:00
}
constructor(props) {
super(props)
this.state = {
2016-12-22 16:51:18 +01:00
isOpen: {
settings: false,
sources: false,
open: false,
add: false,
2016-12-22 16:51:18 +01:00
}
2016-12-16 16:52:16 +01:00
}
2016-12-04 17:03:36 +01:00
}
downloadButton() {
2016-12-22 16:37:53 +01:00
return <ToolbarAction onClick={this.props.onStyleDownload}>
2016-12-21 15:08:04 +01:00
<MdFileDownload />
<IconText>Download</IconText>
</ToolbarAction>
2016-12-04 17:03:36 +01:00
}
2016-09-10 14:56:59 +02:00
2016-12-24 14:46:57 +01:00
toggleInspectionMode() {
const metadata = this.props.mapStyle.metadata || {}
const currentRenderer = metadata['maputnik:renderer'] || 'mbgljs'
const changedRenderer = currentRenderer === 'inspection' ? 'mbgljs' : 'inspection'
const changedStyle = {
...this.props.mapStyle,
metadata: {
'maputnik:renderer': changedRenderer
}
}
this.props.onStyleChanged(changedStyle)
}
2016-12-22 16:51:18 +01:00
toggleModal(modalName) {
this.setState({
isOpen: {
...this.state.isOpen,
[modalName]: !this.state.isOpen[modalName]
}
})
2016-12-16 17:35:09 +01:00
}
2016-12-22 16:54:22 +01:00
render() {
return <div style={{
position: "fixed",
height: 40,
width: '100%',
zIndex: 100,
left: 0,
top: 0,
backgroundColor: colors.black
}}>
2016-12-22 16:51:18 +01:00
<SettingsModal
mapStyle={this.props.mapStyle}
onStyleChanged={this.props.onStyleChanged}
isOpen={this.state.isOpen.settings}
onOpenToggle={this.toggleModal.bind(this, 'settings')}
2016-12-22 16:54:22 +01:00
/>
2016-12-22 16:51:18 +01:00
<OpenModal
isOpen={this.state.isOpen.open}
onStyleOpen={this.props.onStyleOpen}
onOpenToggle={this.toggleModal.bind(this, 'open')}
2016-12-22 16:54:22 +01:00
/>
2016-12-22 16:51:18 +01:00
<SourcesModal
mapStyle={this.props.mapStyle}
onStyleChanged={this.props.onStyleChanged}
isOpen={this.state.isOpen.sources}
onOpenToggle={this.toggleModal.bind(this, 'sources')}
2016-12-22 16:54:22 +01:00
/>
<AddModal
mapStyle={this.props.mapStyle}
sources={this.props.sources}
isOpen={this.state.isOpen.add}
onOpenToggle={this.toggleModal.bind(this, 'add')}
2016-12-29 15:35:07 +01:00
onStyleChange={this.props.onStyleChanged}
/>
2016-12-22 16:37:53 +01:00
<ToolbarLink
href={"https://github.com/maputnik/editor"}
style={{
width: 180,
textAlign: 'left',
backgroundColor: colors.black,
padding: 5,
}}
>
2016-12-21 15:08:04 +01:00
<img src="https://github.com/maputnik/editor/raw/master/media/maputnik.png" alt="Maputnik" style={{width: 30, height: 30, paddingRight: 5, verticalAlign: 'middle'}}/>
<span style={{fontSize: 20, verticalAlign: 'middle' }}>Maputnik</span>
2016-12-22 16:37:53 +01:00
</ToolbarLink>
2016-12-22 16:51:18 +01:00
<ToolbarAction onClick={this.toggleModal.bind(this, 'open')}>
2016-12-28 16:23:33 +01:00
<OpenIcon />
2016-12-22 11:27:53 +01:00
<IconText>Open</IconText>
2016-12-21 15:08:04 +01:00
</ToolbarAction>
2016-12-04 17:03:36 +01:00
{this.downloadButton()}
2016-12-28 16:23:33 +01:00
<ToolbarAction onClick={this.toggleModal.bind(this, 'add')}>
<AddIcon />
<IconText>Add Layer</IconText>
</ToolbarAction>
2016-12-22 16:51:18 +01:00
<ToolbarAction onClick={this.toggleModal.bind(this, 'sources')}>
2016-12-28 16:23:33 +01:00
<SourcesIcon />
2016-12-21 16:11:08 +01:00
<IconText>Sources</IconText>
2016-12-21 15:08:04 +01:00
</ToolbarAction>
2016-12-22 16:51:18 +01:00
<ToolbarAction onClick={this.toggleModal.bind(this, 'settings')}>
2016-12-28 16:23:33 +01:00
<SettingsIcon />
2016-12-21 15:08:04 +01:00
<IconText>Style Settings</IconText>
</ToolbarAction>
2016-12-24 14:46:57 +01:00
<ToolbarAction onClick={this.toggleInspectionMode.bind(this)}>
2016-12-28 16:23:33 +01:00
<InspectionIcon />
2016-12-21 15:08:04 +01:00
<IconText>Inspect</IconText>
</ToolbarAction>
2016-12-22 11:37:32 +01:00
<ToolbarLink href={"https://github.com/maputnik/editor/wiki"}>
2016-12-28 16:23:33 +01:00
<HelpIcon />
2016-12-21 15:08:04 +01:00
<IconText>Help</IconText>
2016-12-22 11:37:32 +01:00
</ToolbarLink>
2016-12-04 17:03:36 +01:00
</div>
}
2016-09-08 19:47:29 +02:00
}