sandbox/solid/src/components/map/Map.tsx

90 lines
2.3 KiB
TypeScript
Raw Normal View History

2022-11-25 15:13:05 +00:00
import { Component, createEffect, createSignal, onMount } from 'solid-js';
import {
useParams,
useNavigate,
useRouteData,
useBeforeLeave,
} from '@solidjs/router';
2022-11-24 20:31:39 +00:00
import OlMap from 'ol/Map';
import View from 'ol/View';
import TileLayer from 'ol/layer/Tile';
import VectorLayer from 'ol/layer/Vector';
import VectorSource from 'ol/source/Vector';
import Feature from 'ol/Feature';
import Attribution from 'ol/control/Attribution';
import Rotate from 'ol/control/Rotate';
import ScaleLine from 'ol/control/ScaleLine';
import Control from 'ol/control/Control';
import OSM from 'ol/source/OSM';
import { useGeographic as olUseGeographic } from 'ol/proj';
import 'ol/ol.css';
import './Map.css';
const Map: Component = () => {
const [getMap, setMap] = createSignal<OlMap | null>(null);
const params = useParams();
2022-11-25 15:13:05 +00:00
const [state, setState] = createSignal(params);
createEffect(() => {
setState(params);
const map = getMap();
const view = map?.getView();
view?.setCenter([+state().lon, +state().lat]);
view?.setRotation(+state().rotation);
view?.setZoom(+state().zoom);
});
const navigate = useNavigate();
2022-11-24 20:31:39 +00:00
let target: HTMLDivElement;
2022-11-25 15:13:05 +00:00
console.log({ caller: 'Map', center: params.center });
2022-11-24 20:31:39 +00:00
onMount(() => {
olUseGeographic();
const changeListener = (event: any) => {
const map = getMap();
const view = map?.getView();
const center = view?.getCenter();
if (center) {
navigate(
`/map/${center[0]}/${
center[1]
}/${view?.getZoom()}/${view?.getRotation()}`
);
}
console.log({
caller: 'Map / changeListener',
event,
params,
map,
});
};
2022-11-24 20:31:39 +00:00
const olMap = new OlMap({
view: new View({
2022-11-25 15:13:05 +00:00
center: [+state().lon, +state().lat],
zoom: +state().zoom,
rotation: +state().rotation,
2022-11-24 20:31:39 +00:00
}),
layers: [
new TileLayer({
source: new OSM(),
}),
//new VectorLayer({ source: newSource }),
],
target: target,
// controls,
});
olMap.on(['moveend'], changeListener);
2022-11-24 20:31:39 +00:00
setMap(olMap);
});
2022-11-25 15:13:05 +00:00
useBeforeLeave((event) => {
console.log({ caller: 'Map / useBeforeLeave', event });
});
2022-11-24 20:31:39 +00:00
// @ts-ignore
return <div class='ol-map' ref={target} />;
};
export default Map;