diff --git a/lightning/src/components/BadassMap.tsx b/lightning/src/components/BadassMap.tsx index 11e3250..9c08589 100644 --- a/lightning/src/components/BadassMap.tsx +++ b/lightning/src/components/BadassMap.tsx @@ -3,31 +3,29 @@ import * as maplibre from 'maplibre-gl'; import MapControls from './MapControls'; import type { JSX } from 'solid-js'; -import type { MapOptions } from 'maplibre-gl'; + +// deck.gl +import { unstable_clientOnly } from 'solid-start'; +const MapScatLayer = unstable_clientOnly( () => import('~/components/MapScatLayer')); +const MapArcLayer = unstable_clientOnly(() => import('~/components/MapArcLayer')); import { arcData, scatData, viewport, setViewport } from '~/root'; import 'maplibre-gl/dist/maplibre-gl.css'; import StyleJson from '~/style/style.json'; -// deck.gl -import { unstable_clientOnly } from 'solid-start'; -const MapScatLayer = unstable_clientOnly(() => import('~/components/MapScatLayer')); -const MapArcLayer = unstable_clientOnly(() => import('~/components/MapArcLayer')); - -const options: MapOptions = { - container: 'solid-map-gl will override me', - style: StyleJson, - maxPitch: 85, - antialias: true, - renderWorldCopies: false, -}; export default function BadassMap() { return ( <> setViewport(evt)} transitionType="flyTo" diff --git a/lightning/src/components/MapArcLayer.tsx b/lightning/src/components/MapArcLayer.tsx index a585408..4518a69 100644 --- a/lightning/src/components/MapArcLayer.tsx +++ b/lightning/src/components/MapArcLayer.tsx @@ -4,22 +4,19 @@ import { Layer } from 'solid-map-gl'; import type { JSX } from 'solid-js'; -function MapArcLayer(props: any) { - const arcLayer = new MapboxLayer({ - id: 'deckgl-arc', - type: ArcLayer, - data: props.data, - getSourcePosition: (d: any) => d.source, - getTargetPosition: (d: any) => d.target, - getSourceColor: [200, 0, 0], - getTargetColor: [0, 230, 0], - getWidth: 6, - }); +export default function MapArcLayer(props: any) { + return ( - <> - - + d.source, + getTargetPosition: (d: any) => d.target, + getSourceColor: [200, 0, 0], + getTargetColor: [0, 230, 0], + getWidth: 6, + } as any)} /> ) as JSX.Element; }; - -export default MapArcLayer; diff --git a/lightning/src/components/MapControls.tsx b/lightning/src/components/MapControls.tsx index bdb43a1..0dcc55d 100644 --- a/lightning/src/components/MapControls.tsx +++ b/lightning/src/components/MapControls.tsx @@ -1,63 +1,63 @@ import { Control } from 'solid-map-gl'; + +import type { JSX } from 'solid-js'; import type { NavigationOptions, GeolocateOptions, - ScaleOptions, AttributionOptions, + ScaleOptions, } from 'maplibre-gl'; -import type { JSX } from 'solid-js'; -function MapControls() { - const NAV_OPTIONS: NavigationOptions = { - showCompass: true, - showZoom: true, - visualizePitch: true, - }; - const GEO_OPTIONS: GeolocateOptions = { - positionOptions: { - enableHighAccuracy: false, - timeout: 6000, - maximumAge: 0, - }, - fitBoundsOptions: { maxZoom: 15 }, - trackUserLocation: false, - showAccuracyCircle: false, - showUserLocation: true, - }; - const ATTRIB_OPTIONS: AttributionOptions = { - compact: false, - customAttribution: 'OpenStreetMap', - }; - const SCALE_OPTIONS: ScaleOptions = { - maxWidth: 100, - unit: 'imperial', - }; +export default function MapControls() { + return ( <> + + + + + ) as JSX.Element; }; - -export default MapControls; - diff --git a/lightning/src/components/MapScatLayer.tsx b/lightning/src/components/MapScatLayer.tsx index 2f2eceb..1e6c643 100644 --- a/lightning/src/components/MapScatLayer.tsx +++ b/lightning/src/components/MapScatLayer.tsx @@ -4,21 +4,19 @@ import { Layer } from 'solid-map-gl'; import type { JSX } from 'solid-js'; -function MapScatLayer(props: any) { - const scatterplotLayer = new MapboxLayer({ - id: 'deckgl-scatterplot', - type: ScatterplotLayer, - data: props.data, - getPosition: (d: any) => d.coordinates, - getRadius: 30, - getFillColor: [255, 140, 0], - getLineColor: [0, 0, 0,] - }); + +export default function MapScatLayer(props: any) { + return ( - <> - - + d.coordinates, + getRadius: 30, + getFillColor: [255, 140, 0], + getLineColor: [0, 0, 0,], + } as any)} /> ) as JSX.Element; }; - -export default MapScatLayer; diff --git a/lightning/src/components/MapScenegraphLayer.tsx b/lightning/src/components/MapScenegraphLayer.tsx index 60b7396..1d80a50 100644 --- a/lightning/src/components/MapScenegraphLayer.tsx +++ b/lightning/src/components/MapScenegraphLayer.tsx @@ -4,28 +4,22 @@ import { Layer } from 'solid-map-gl'; import type { JSX } from 'solid-js'; -function MapScenegraphLayer(props: any) { - - const scenegraphLayer = new MapboxLayer({ - id: 'deckgl-scenegraph', - type: ScenegraphLayer, - data: props.data, - pickable: true, - scenegraph: 'https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/BoxAnimated/glTF-Binary/BoxAnimated.glb', - getPosition: d => d.coordinates, - getOrientation: d => [0, Math.random() * 180, 90], - _animations: { - '*': { speed: 5 } - }, - sizeScale: 500, - _lighting: 'pbr' - }); +export default function MapScenegraphLayer(props: any) { return ( - <> - - + d.coordinates, + getOrientation: d => [0, Math.random() * 180, 90], + _animations: { + '*': { speed: 5 } + }, + sizeScale: 500, + _lighting: 'pbr', + } as any)} /> ) as JSX.Element; }; - -export default MapScenegraphLayer; diff --git a/lightning/src/components/Toolbox.tsx b/lightning/src/components/Toolbox.tsx new file mode 100644 index 0000000..2eb617d --- /dev/null +++ b/lightning/src/components/Toolbox.tsx @@ -0,0 +1,29 @@ +import type { JSX } from "solid-js" +import type { Viewport } from "solid-map-gl"; + +import { setViewport } from '~/root'; + + +export function Toolbox() { + + return ( +
    +

    Toolbox

    + +
  • + +
  • + +
+ ) as JSX.Element; +}; diff --git a/lightning/src/root.tsx b/lightning/src/root.tsx index 9b15f91..f6f6b3b 100644 --- a/lightning/src/root.tsx +++ b/lightning/src/root.tsx @@ -1,5 +1,5 @@ // @refresh reload -import { Suspense, createSignal } from "solid-js"; +import { Suspense, createSignal, createEffect } from "solid-js"; import { A, Body, ErrorBoundary, FileRoutes, Head, Html, Meta, Routes, Scripts, Title } from "solid-start"; import "./root.css"; import BadassMap from './components/BadassMap'; @@ -15,49 +15,27 @@ const TEST = { PRH: { LngLatLike: { lng: -71.053678, lat: 42.363722 }, coords: [-71.053678, 42.363722], }, NSE: { LngLatLike: { lng: -74.0112660425065, lat: 40.70689167578798 }, coords: [-74.0112660425065, 40.70689167578798], }, }; -const ARC_DATA = [ - { source: TEST.FAN.coords, target: TEST.GDT.coords }, - { source: TEST.FAN.coords, target: TEST.BBC.coords }, - { source: TEST.FAN.coords, target: TEST.GAR.coords }, - { source: TEST.FAN.coords, target: TEST.PRH.coords }, -]; -const SCAT_DATA = [ + +export const [scatData, setScatData] = createSignal([ { coordinates: TEST.FAN.coords }, { coordinates: TEST.GDT.coords }, { coordinates: TEST.BBC.coords }, { coordinates: TEST.GAR.coords }, { coordinates: TEST.PRH.coords }, { coordinates: TEST.NSE.coords }, -]; -const USER_LOC = TEST.FAN.LngLatLike; -const INITIAL_VIEWPORT: Viewport = { - center: USER_LOC, - zoom: 15.5, - bearing: 10, - pitch: 60, -}; -export const BOS: Viewport = { - center: TEST.FAN.coords, - zoom: 15.5, - bearing: 160, - pitch: 60, -}; -export const NYC: Viewport = { - center: TEST.NSE.coords, - zoom: 15.5, - bearing: 10, - pitch: 60, -}; -export const [scatData, setScatData] = createSignal(SCAT_DATA); -export const [arcData, setArcData] = createSignal(ARC_DATA); -export const [viewport, setViewport] = createSignal(INITIAL_VIEWPORT); -export const [rotate, setRotate] = createSignal(false); -export const toggleRotate = () => setRotate(!rotate()); +]); -export function flyTo(viewUpdate: Viewport) { - setRotate(false) - setViewport(viewUpdate); -}; +export const [arcData, setArcData] = createSignal([ + { source: TEST.FAN.coords, target: TEST.GDT.coords }, + { source: TEST.FAN.coords, target: TEST.BBC.coords }, + { source: TEST.FAN.coords, target: TEST.GAR.coords }, + { source: TEST.FAN.coords, target: TEST.PRH.coords }, +]); + +export const [USER_LOC] = createSignal(TEST.FAN.LngLatLike); + +export const [viewport, setViewport] = createSignal(); +createEffect(() => console.log(viewport())); export default function Root() { return ( diff --git a/lightning/src/routes/about.tsx b/lightning/src/routes/about.tsx index 97dedb9..04d5abc 100644 --- a/lightning/src/routes/about.tsx +++ b/lightning/src/routes/about.tsx @@ -2,7 +2,9 @@ import { Title } from 'solid-start'; import type { JSX } from 'solid-js'; + export default function Home() { + return (
About Lightning @@ -57,4 +59,4 @@ export default function Home() {

) as JSX.Element; -} +}; diff --git a/lightning/src/routes/index.tsx b/lightning/src/routes/index.tsx index dab9f66..c737baf 100644 --- a/lightning/src/routes/index.tsx +++ b/lightning/src/routes/index.tsx @@ -2,16 +2,11 @@ import { Title } from 'solid-start'; import type { JSX } from 'solid-js'; -import { viewport, flyTo, BOS, NYC } from '~/root'; export default function Home() { return (
Ride the Lightning -
  • Toolbox
  • -
  • -
  • -
) as JSX.Element; };