maps/lightning/src/components/BadassMap.tsx

53 lines
1.6 KiB
TypeScript
Raw Normal View History

2023-04-15 01:21:33 -04:00
import { Component, createSignal } from 'solid-js';
import MapGL, { Viewport, Control, Light, Camera } from 'solid-map-gl';
import * as maplibre from 'maplibre-gl';
import 'maplibre-gl/dist/maplibre-gl.css';
export default function BadassMap() {
const [viewport, setViewport] = createSignal({
center: [-71.05625, 42.36],
zoom: 15.5,
bearing: 160,
pitch: 60,
maxPitch: 85,
antialias: true,
} as Viewport);
2023-04-15 06:35:25 -04:00
const [rotate, setRotate] = createSignal(true)
const [rotateReverse, setRotateReverse] = createSignal(true)
2023-04-15 05:34:42 -04:00
2023-04-15 01:21:33 -04:00
return (
<MapGL
mapLib={maplibre}
options={{
style: 'https://api.maptiler.com/maps/024da34e-fa66-4cb3-8f5f-0466b51e972e/style.json?key=Ukl2QNcQUCPAwuelQOvM'
}}
viewport={viewport()}
onViewportChange={(evt: Viewport) => setViewport(evt)}
>
2023-04-15 06:35:25 -04:00
<button
onClick={ () => rotate() ? setRotate(false) : setRotate(true) }>
Toggle rotation
</button>
2023-04-15 01:21:33 -04:00
<Control type="fullscreen" position="top-right" />
<Control type="navigation" position="top-right" />
<Control type="geolocate" position="top-right" />
<Control type="scale" position="bottom-left" />
<Light style={{
anchor: 'viewport',
color: 'white',
intensity: 0.9,
}} />
<Camera
2023-04-15 05:34:42 -04:00
rotateViewport={rotate()}
2023-04-15 06:35:25 -04:00
reverse={rotateReverse()}
2023-04-15 01:21:33 -04:00
/>
</MapGL>
);
};