meh
This commit is contained in:
parent
65cbee4ea2
commit
7e5f574d91
7 changed files with 587 additions and 586 deletions
|
@ -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
1076
lightning/pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load diff
|
@ -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 />
|
||||||
|
|
|
@ -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()));
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
|
||||||
};
|
|
|
@ -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,13 +14,27 @@ 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 (
|
||||||
|
<Show when={allStations()}>
|
||||||
<Layer customLayer={
|
<Layer customLayer={
|
||||||
new MapboxLayer({
|
new MapboxLayer({
|
||||||
id: 'deckgl-scatterplot',
|
id: 'deckgl-scatterplot',
|
||||||
type: ScatterplotLayer,
|
type: ScatterplotLayer,
|
||||||
data: allStations(),
|
data: allStations(),
|
||||||
pickable: false,
|
pickable: true,
|
||||||
|
onHover: onHover,
|
||||||
|
onClick: onClick,
|
||||||
|
highlightColor: [255, 255, 255, 1],
|
||||||
|
autoHighlight: true,
|
||||||
stroked: false,
|
stroked: false,
|
||||||
lineWidthMaxPixels: 0,
|
lineWidthMaxPixels: 0,
|
||||||
radiusMinPixels: 1,
|
radiusMinPixels: 1,
|
||||||
|
@ -31,5 +46,6 @@ export default function MapScatLayer(props: any) {
|
||||||
antialiasing: false,
|
antialiasing: false,
|
||||||
getFillColor: [255, 140, 0],
|
getFillColor: [255, 140, 0],
|
||||||
} as any)} />
|
} as any)} />
|
||||||
|
</Show>
|
||||||
) as JSX.Element;
|
) as JSX.Element;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Add table
Reference in a new issue