maps.chandlerswift.com/main.js

52 lines
1.4 KiB
JavaScript

import './style.css';
import {Map, View} from 'ol';
import {fromLonLat} from 'ol/proj.js';
import layerCategories from './layers/index.js';
const map = new Map({
target: 'map',
layers: [],
view: new View({
center: fromLonLat([-93.24151, 44.80376]),
zoom: 10,
})
});
// Basic reactivity binding: like vue.js, just worse :)
//
// This implements some basic reactivity so that I can add and remove layers.
// Nothing too fancy, at this point. Eventually, I'll likely pull in proper Vue,
// as I aim for more complex interactions, like layer ordering, color selection,
// custom layer imports, and more.
for (let category of layerCategories) {
const catDiv = document.createElement("div");
catDiv.innerHTML = `
<h3>${category.name}</h3>
<ul></ul>
`;
for (let layer of category.layers) {
const li = document.createElement("li");
li.innerHTML = `
<input type="checkbox" ${layer.enabled ? "checked" : ""}> ${layer.name}
`;
li.querySelector("input").addEventListener("change", function(e){
if (e.target.checked) {
map.getLayers().push(layer.layer);
} else {
map.getLayers().remove(layer.layer);
}
});
catDiv.querySelector("ul").appendChild(li);
}
document.querySelector("aside").appendChild(catDiv);
}
for (let category of layerCategories) {
for (let layer of category.layers) {
if (layer.enabled) {
map.addLayer(layer.layer);
}
}
}