2023-04-15 07:59:50 -04:00
|
|
|
import { createSignal, Show } from 'solid-js';
|
2023-04-15 01:21:33 -04:00
|
|
|
import * as maplibre from 'maplibre-gl';
|
2023-04-16 08:18:32 -04:00
|
|
|
import MapGL, { Viewport, Camera, Layer, Popup, Marker } from 'solid-map-gl';
|
|
|
|
import { MapboxLayer } from '@deck.gl/mapbox/typed';
|
|
|
|
import { ArcLayer, ScatterplotLayer } from '@deck.gl/layers/typed';
|
2023-04-16 06:28:07 -04:00
|
|
|
|
|
|
|
import MapControls from './MapControls';
|
2023-04-16 19:07:30 -04:00
|
|
|
import MapScatLayer from './MapScatLayer';
|
|
|
|
import MapArcLayer from './MapArcLayer';
|
2023-04-15 07:59:50 -04:00
|
|
|
|
|
|
|
import type { JSX } from 'solid-js';
|
|
|
|
import type { MapOptions } from 'maplibre-gl';
|
|
|
|
|
2023-04-15 01:21:33 -04:00
|
|
|
import 'maplibre-gl/dist/maplibre-gl.css';
|
|
|
|
|
2023-04-15 22:01:38 -04:00
|
|
|
|
2023-04-15 07:59:50 -04:00
|
|
|
function BadassMap(): JSX.Element {
|
2023-04-16 04:49:13 -04:00
|
|
|
const FANEUIL_HALL: number[] = [-71.05625, 42.36]
|
|
|
|
const GD_TAVERN: number[] = [-71.056922, 42.360919]
|
2023-04-16 19:07:30 -04:00
|
|
|
const BBC: number[] = [-71.103, 42.3145]
|
|
|
|
const GARDEN: number[] = [-71.062228, 42.366303]
|
|
|
|
const PR_HOUSE: number[] = [-71.053678, 42.363722]
|
2023-04-16 04:49:13 -04:00
|
|
|
|
2023-04-15 22:05:53 -04:00
|
|
|
const TILES_URL: string = 'https://api.maptiler.com/maps/024da34e-fa66-4cb3-8f5f-0466b51e972e/style.json?key=Ukl2QNcQUCPAwuelQOvM'
|
2023-04-15 07:59:50 -04:00
|
|
|
const options: MapOptions = {
|
2023-04-15 22:01:38 -04:00
|
|
|
container: 'solid-map-gl will override me',
|
|
|
|
style: TILES_URL,
|
2023-04-15 07:59:50 -04:00
|
|
|
maxPitch: 85,
|
|
|
|
antialias: true,
|
2023-04-16 04:49:13 -04:00
|
|
|
};
|
2023-04-15 22:01:38 -04:00
|
|
|
const INITIAL_VIEW_STATE: Viewport = {
|
2023-04-16 04:49:13 -04:00
|
|
|
center: FANEUIL_HALL,
|
2023-04-15 01:21:33 -04:00
|
|
|
zoom: 15.5,
|
|
|
|
bearing: 160,
|
|
|
|
pitch: 60,
|
2023-04-16 04:49:13 -04:00
|
|
|
};
|
2023-04-15 22:01:38 -04:00
|
|
|
const [viewport, setViewport] = createSignal<Viewport>(INITIAL_VIEW_STATE);
|
2023-04-16 04:49:13 -04:00
|
|
|
const [rotate, setRotate] = createSignal<boolean>(true);
|
|
|
|
const toggleRotate = () => setRotate<boolean>(!rotate());
|
2023-04-15 07:59:50 -04:00
|
|
|
|
2023-04-16 19:07:30 -04:00
|
|
|
const ARC_DATA = [
|
|
|
|
{ source: FANEUIL_HALL, target: GD_TAVERN },
|
|
|
|
{ source: FANEUIL_HALL, target: BBC },
|
|
|
|
{ source: FANEUIL_HALL, target: GARDEN },
|
|
|
|
{ source: FANEUIL_HALL, target: PR_HOUSE },
|
|
|
|
];
|
|
|
|
|
2023-04-16 08:18:32 -04:00
|
|
|
const arcLayer = new MapboxLayer({
|
2023-04-16 06:28:07 -04:00
|
|
|
id: 'deckgl-arc',
|
|
|
|
type: ArcLayer,
|
2023-04-16 19:07:30 -04:00
|
|
|
data: ARC_DATA,
|
2023-04-16 06:28:07 -04:00
|
|
|
getSourcePosition: (d: any) => d.source,
|
|
|
|
getTargetPosition: (d: any) => d.target,
|
2023-04-16 19:07:30 -04:00
|
|
|
getSourceColor: [200, 0, 0],
|
|
|
|
getTargetColor: [0, 230, 0],
|
|
|
|
getWidth: 6,
|
2023-04-16 06:28:07 -04:00
|
|
|
});
|
2023-04-15 05:34:42 -04:00
|
|
|
|
2023-04-16 19:07:30 -04:00
|
|
|
const SCATTER_DATA = [
|
|
|
|
{ coordinates: FANEUIL_HALL },
|
|
|
|
{ coordinates: GD_TAVERN },
|
|
|
|
{ coordinates: BBC },
|
|
|
|
{ coordinates: GARDEN },
|
|
|
|
{ coordinates: PR_HOUSE },
|
|
|
|
];
|
|
|
|
|
2023-04-16 08:18:32 -04:00
|
|
|
const scatterplotLayer = new MapboxLayer({
|
|
|
|
id: 'deckgl-scatterplot',
|
|
|
|
type: ScatterplotLayer,
|
2023-04-16 19:07:30 -04:00
|
|
|
data: SCATTER_DATA,
|
2023-04-16 08:18:32 -04:00
|
|
|
getPosition: (d: any) => d.coordinates,
|
|
|
|
getRadius: 30,
|
|
|
|
getFillColor: [255, 140, 0],
|
|
|
|
getLineColor: [0, 0, 0,]
|
|
|
|
});
|
|
|
|
|
2023-04-15 01:21:33 -04:00
|
|
|
return (
|
|
|
|
<MapGL
|
|
|
|
mapLib={maplibre}
|
2023-04-15 07:59:50 -04:00
|
|
|
options={options}
|
2023-04-15 01:21:33 -04:00
|
|
|
viewport={viewport()}
|
|
|
|
onViewportChange={(evt: Viewport) => setViewport(evt)}
|
|
|
|
>
|
2023-04-16 08:18:32 -04:00
|
|
|
<Layer customLayer={arcLayer} />
|
|
|
|
<Layer customLayer={scatterplotLayer} />
|
|
|
|
|
|
|
|
<Marker
|
|
|
|
lngLat={FANEUIL_HALL}
|
|
|
|
options={{ color: '#900' }}
|
2023-04-16 04:49:13 -04:00
|
|
|
>
|
2023-04-16 08:18:32 -04:00
|
|
|
hi
|
|
|
|
</Marker>
|
|
|
|
|
2023-04-16 19:07:30 -04:00
|
|
|
<Camera
|
|
|
|
rotateViewport={rotate()}
|
|
|
|
reverse={true}
|
|
|
|
/>
|
|
|
|
<Show
|
|
|
|
when={rotate()}
|
|
|
|
fallback={<button onClick={toggleRotate}> Rotation On </button>}
|
|
|
|
>
|
|
|
|
<button onClick={toggleRotate}> Rotation Off </button>
|
|
|
|
</Show>
|
|
|
|
<MapControls />
|
2023-04-16 04:49:13 -04:00
|
|
|
</MapGL >
|
2023-04-15 01:21:33 -04:00
|
|
|
);
|
|
|
|
};
|
2023-04-15 07:59:50 -04:00
|
|
|
|
|
|
|
export default BadassMap;
|