diff --git a/src/components/map/MapboxGlMap.jsx b/src/components/map/MapboxGlMap.jsx index d0e3850..ca3ef47 100644 --- a/src/components/map/MapboxGlMap.jsx +++ b/src/components/map/MapboxGlMap.jsx @@ -14,6 +14,9 @@ import 'mapbox-gl/dist/mapbox-gl.css' import '../../mapboxgl.css' import '../../libs/mapbox-rtl' + +const IS_SUPPORTED = MapboxGl.supported(); + function renderPropertyPopup(features) { var mountNode = document.createElement('div'); ReactDOM.render(, mountNode) @@ -81,6 +84,8 @@ export default class MapboxGlMap extends React.Component { } UNSAFE_componentWillReceiveProps(nextProps) { + if(!IS_SUPPORTED) return; + if(!this.state.map) return const metadata = nextProps.mapStyle.metadata || {} MapboxGl.accessToken = metadata['maputnik:mapbox_access_token'] || tokens.mapbox @@ -93,6 +98,8 @@ export default class MapboxGlMap extends React.Component { } componentDidUpdate(prevProps) { + if(!IS_SUPPORTED) return; + const map = this.state.map; if(this.props.inspectModeEnabled !== prevProps.inspectModeEnabled) { @@ -107,6 +114,8 @@ export default class MapboxGlMap extends React.Component { } componentDidMount() { + if(!IS_SUPPORTED) return; + const mapOpts = { ...this.props.options, container: this.container, @@ -163,9 +172,20 @@ export default class MapboxGlMap extends React.Component { } render() { - return
this.container = x} - >
+ if(IS_SUPPORTED) { + return
this.container = x} + >
+ } + else { + return
+
+ Error: Cannot load MapboxGL, WebGL is either unsupported or disabled +
+
+ } } } diff --git a/src/styles/_components.scss b/src/styles/_components.scss index e257211..302ec52 100644 --- a/src/styles/_components.scss +++ b/src/styles/_components.scss @@ -1,5 +1,6 @@ // MAP .maputnik-map { + display: flex; position: fixed !important; top: $toolbar-height + $toolbar-offset; right: 0; @@ -10,6 +11,16 @@ - 200px /* layer list */ - 350px /* layer editor */ ); + + &--error { + align-items: center; + justify-content: center; + } + + &__error-message { + margin: 16px; + text-align: center; + } } // DOC LABEL