This commit is contained in:
Adam 2023-05-01 21:05:37 -04:00
parent 65cbee4ea2
commit 7e5f574d91
7 changed files with 587 additions and 586 deletions

View file

@ -7,7 +7,7 @@
}, },
"type": "module", "type": "module",
"devDependencies": { "devDependencies": {
"@types/node": "^18.16.2", "@types/node": "^18.16.3",
"esbuild": "^0.14.54", "esbuild": "^0.14.54",
"postcss": "^8.4.23", "postcss": "^8.4.23",
"solid-start-node": "^0.2.26", "solid-start-node": "^0.2.26",

1076
lightning/pnpm-lock.yaml generated

File diff suppressed because it is too large Load diff

View file

@ -1,9 +1,8 @@
import type { JSX } from "solid-js" import type { JSX } from "solid-js"
import type { Viewport } from "solid-map-gl"; import { Viewport } from "solid-map-gl";
import { mapRotate, setMapRotate } from "./map/BadassMap"; import { mapRotate, setMapRotate } from "./map/BadassMap";
import { viewport, setViewport } from "./map/BadassMap"; import { viewport, setViewport } from "./map/BadassMap";
import { unstable_clientOnly } from "solid-start";
const MapIconLayer = unstable_clientOnly(() => import('~/components/map/MapIconLayer.tsx'));
export function Toolbox() { export function Toolbox() {
return ( return (
@ -19,10 +18,6 @@ export function Toolbox() {
<button onClick={() => setMapRotate(!mapRotate())} > Toggle Rotate </button> <button onClick={() => setMapRotate(!mapRotate())} > Toggle Rotate </button>
</li> </li>
<li>
<button onClick={() => setMapIcons()} > Clear Icons </button>
</li>
<br /> <br />
<h3>Fly To:</h3> <h3>Fly To:</h3>
<hr /> <hr />

View file

@ -9,11 +9,12 @@ import { createEffect, createSignal, JSX } from 'solid-js';
import { unstable_clientOnly } from 'solid-start'; import { unstable_clientOnly } from 'solid-start';
const MapScatLayer = unstable_clientOnly(() => import('~/components/map/MapScatLayer')); const MapScatLayer = unstable_clientOnly(() => import('~/components/map/MapScatLayer'));
const MapArcLayer = unstable_clientOnly(() => import('~/components/map/MapArcLayer')); const MapArcLayer = unstable_clientOnly(() => import('~/components/map/MapArcLayer'));
const MapIconLayer = unstable_clientOnly(() => import('~/components/map/MapIconLayer.tsx')); const MapIconLayer = unstable_clientOnly(() => import('~/components/map/MapIconLayer'));
import 'maplibre-gl/dist/maplibre-gl.css'; import 'maplibre-gl/dist/maplibre-gl.css';
import StyleJson from '~/style/style.json'; import StyleJson from '~/style/style.json';
export const [mapIcons, setMapIcons] = createSignal([]);
export const [mapRotate, setMapRotate] = createSignal(false); export const [mapRotate, setMapRotate] = createSignal(false);
createEffect(() => console.log('Rotate:', mapRotate())); createEffect(() => console.log('Rotate:', mapRotate()));

View file

@ -1,21 +1,19 @@
import { IconLayer } from "@deck.gl/layers/typed"; import { IconLayer } from "@deck.gl/layers/typed";
import { MapboxLayer } from "@deck.gl/mapbox/typed"; import { MapboxLayer } from "@deck.gl/mapbox/typed";
import { Layer } from "solid-map-gl"; import { Layer } from "solid-map-gl";
import { createEffect, Show } from "solid-js";
import { createEffect, createSignal, JSX, Show } from "solid-js";
import { useStationsContext } from "../StationsContext"; import { useStationsContext } from "../StationsContext";
import { createMemo } from "solid-js";
const ICON_MAPPING = { import type { JSX } from "solid-js";
marker: { x: 0, y: 0, width: 128, height: 128, mask: true }
};
export const [mapIcons, setMapIcons] = createSignal([]);
export default function MapIconLayer(props: any) { export default function MapIconLayer(props: any) {
const ICON_MAPPING = {
marker: { x: 0, y: 0, width: 128, height: 128, mask: true }
};
const [stations] = useStationsContext(); const [stations] = useStationsContext();
const pls = createMemo(() => setMapIcons(stations())); createEffect(() => console.log("Watch me update but not trigger a render!", stations()));
return ( return (
<Show when={stations()}> <Show when={stations()}>
@ -23,7 +21,7 @@ export default function MapIconLayer(props: any) {
new MapboxLayer({ new MapboxLayer({
id: 'deckgl-iconlayer', id: 'deckgl-iconlayer',
type: IconLayer, type: IconLayer,
data: mapIcons(), data: stations(),
pickable: true, pickable: true,
iconAtlas: 'https://raw.githubusercontent.com/visgl/deck.gl-data/master/website/icon-atlas.png', iconAtlas: 'https://raw.githubusercontent.com/visgl/deck.gl-data/master/website/icon-atlas.png',
iconMapping: ICON_MAPPING, iconMapping: ICON_MAPPING,
@ -33,8 +31,8 @@ export default function MapIconLayer(props: any) {
getSize: d => 3, getSize: d => 3,
getColor: d => [d.Dist * 100, 140 - (d.Dist * 50), 0], getColor: d => [d.Dist * 100, 140 - (d.Dist * 50), 0],
parameters: { parameters: {
depthTest: false depthTest: false,
} },
} as any)} /> } as any)} />
</Show> </Show>
) as JSX.Element ) as JSX.Element

View file

@ -1,13 +0,0 @@
import { Marker, Popup } from 'solid-map-gl';
import type { NavigationOptions, GeolocateOptions, AttributionOptions, ScaleOptions, } from 'maplibre-gl';
import type { JSX } from 'solid-js';
export default function MapControls() {
return (
<>
</>
) as JSX.Element;
};

View file

@ -1,6 +1,7 @@
import { ScatterplotLayer } from '@deck.gl/layers/typed'; import { ScatterplotLayer } from '@deck.gl/layers/typed';
import { MapboxLayer } from '@deck.gl/mapbox/typed'; import { MapboxLayer } from '@deck.gl/mapbox/typed';
import { Layer } from 'solid-map-gl'; import { Layer } from 'solid-map-gl';
import { Show } from 'solid-js';
import type { JSX } from 'solid-js'; import type { JSX } from 'solid-js';
@ -13,23 +14,38 @@ type ScatData = {
export default function MapScatLayer(props: any) { export default function MapScatLayer(props: any) {
function onHover(info, event) {
// console.log('hover info:',info, 'hover event:', event);
};
function onClick(info, event) {
console.log('click info:', info, 'click event:', event);
};
return ( return (
<Layer customLayer={ <Show when={allStations()}>
new MapboxLayer({ <Layer customLayer={
id: 'deckgl-scatterplot', new MapboxLayer({
type: ScatterplotLayer, id: 'deckgl-scatterplot',
data: allStations(), type: ScatterplotLayer,
pickable: false, data: allStations(),
stroked: false, pickable: true,
lineWidthMaxPixels: 0, onHover: onHover,
radiusMinPixels: 1, onClick: onClick,
radiusMaxPixels: 50, highlightColor: [255, 255, 255, 1],
radiusUnits: 'meters', autoHighlight: true,
getRadius: 1, stroked: false,
radiusScale: 10, lineWidthMaxPixels: 0,
getPosition: (d: any) => d.coordinates, radiusMinPixels: 1,
antialiasing: false, radiusMaxPixels: 50,
getFillColor: [255, 140, 0], radiusUnits: 'meters',
} as any)} /> getRadius: 1,
radiusScale: 10,
getPosition: (d: any) => d.coordinates,
antialiasing: false,
getFillColor: [255, 140, 0],
} as any)} />
</Show>
) as JSX.Element; ) as JSX.Element;
}; };