mirror of
https://github.com/maputnik/editor.git
synced 2026-02-12 15:40:01 +00:00
This is a rough start on adding react-i18next. I'll be working on adding more translatable strings and translations in the coming days. I'm going to need to wrap class components in HOCs, so let me know if there's something I should be fixing before doing that. I'm thinking now to keep the exported class names exactly the same, and rename the existing classes by prefixing an `I` (for internal). For example: ``` export default class AppToolbar ... ``` becomes ``` class IAppToolbar ... const AppToolbar = withTranslation()(IAppToolbar); export default AppToolbar; ``` I'll be able to contribute Japanese strings (I've talked to a couple people on my team and they'll be happy to help as well), so that's the language I decided to go with in this PR. Closes #746 --------- Co-authored-by: Ko Nagase <nagase@georepublic.co.jp> Co-authored-by: Harel M <harel.mazor@gmail.com>
84 lines
2.5 KiB
TypeScript
84 lines
2.5 KiB
TypeScript
import React from 'react'
|
|
|
|
import { Trans, WithTranslation, withTranslation } from 'react-i18next';
|
|
import Modal from './Modal'
|
|
|
|
|
|
type ModalDebugInternalProps = {
|
|
isOpen: boolean
|
|
renderer: string
|
|
onChangeMaplibreGlDebug(key: string, checked: boolean): unknown
|
|
onChangeOpenlayersDebug(key: string, checked: boolean): unknown
|
|
onOpenToggle(value: boolean): unknown
|
|
maplibreGlDebugOptions?: object
|
|
openlayersDebugOptions?: object
|
|
mapView: {
|
|
zoom: number
|
|
center: {
|
|
lng: number
|
|
lat: number
|
|
}
|
|
}
|
|
} & WithTranslation;
|
|
|
|
|
|
class ModalDebugInternal extends React.Component<ModalDebugInternalProps> {
|
|
render() {
|
|
const {t, mapView} = this.props;
|
|
|
|
const osmZoom = Math.round(mapView.zoom)+1;
|
|
const osmLon = +(mapView.center.lng).toFixed(5);
|
|
const osmLat = +(mapView.center.lat).toFixed(5);
|
|
|
|
return <Modal
|
|
data-wd-key="modal:debug"
|
|
isOpen={this.props.isOpen}
|
|
onOpenToggle={this.props.onOpenToggle}
|
|
title={t('Debug')}
|
|
>
|
|
<section className="maputnik-modal-section maputnik-modal-shortcuts">
|
|
<h1>{t("Options")}</h1>
|
|
{this.props.renderer === 'mlgljs' &&
|
|
<ul>
|
|
{Object.entries(this.props.maplibreGlDebugOptions!).map(([key, val]) => {
|
|
return <li key={key}>
|
|
<label>
|
|
<input type="checkbox" checked={val} onChange={(e) => this.props.onChangeMaplibreGlDebug(key, e.target.checked)} /> {key}
|
|
</label>
|
|
</li>
|
|
})}
|
|
</ul>
|
|
}
|
|
{this.props.renderer === 'ol' &&
|
|
<ul>
|
|
{Object.entries(this.props.openlayersDebugOptions!).map(([key, val]) => {
|
|
return <li key={key}>
|
|
<label>
|
|
<input type="checkbox" checked={val} onChange={(e) => this.props.onChangeOpenlayersDebug(key, e.target.checked)} /> {key}
|
|
</label>
|
|
</li>
|
|
})}
|
|
</ul>
|
|
}
|
|
</section>
|
|
<section className="maputnik-modal-section">
|
|
<h1>Links</h1>
|
|
<p>
|
|
<Trans t={t}>
|
|
<a
|
|
target="_blank"
|
|
rel="noopener noreferrer"
|
|
href={`https://www.openstreetmap.org/#map=${osmZoom}/${osmLat}/${osmLon}`}
|
|
>
|
|
Open in OSM
|
|
</a> — Opens the current view on openstreetmap.org
|
|
</Trans>
|
|
</p>
|
|
</section>
|
|
</Modal>
|
|
}
|
|
}
|
|
|
|
const ModalDebug = withTranslation()(ModalDebugInternal);
|
|
export default ModalDebug;
|