2023-07-03 00:20:36 -05:00
|
|
|
import './style.css';
|
|
|
|
import {Map, View} from 'ol';
|
2023-07-03 22:13:15 -05:00
|
|
|
import {fromLonLat, get} from 'ol/proj.js';
|
|
|
|
import {defaults as defaultControls} from 'ol/control.js';
|
|
|
|
|
|
|
|
import ToggleMenuControl from './ui/controls.js';
|
2023-07-03 00:20:36 -05:00
|
|
|
|
2023-07-03 19:26:02 -05:00
|
|
|
import layerCategories from './layers/index.js';
|
2023-07-03 15:27:18 -05:00
|
|
|
|
2023-07-03 00:20:36 -05:00
|
|
|
const map = new Map({
|
2023-07-03 22:13:15 -05:00
|
|
|
controls: defaultControls().extend([new ToggleMenuControl()]),
|
2023-07-03 00:20:36 -05:00
|
|
|
target: 'map',
|
2023-07-03 19:26:02 -05:00
|
|
|
layers: [],
|
2023-07-03 00:20:36 -05:00
|
|
|
view: new View({
|
2023-07-03 01:00:10 -05:00
|
|
|
center: fromLonLat([-93.24151, 44.80376]),
|
|
|
|
zoom: 10,
|
2023-07-03 00:20:36 -05:00
|
|
|
})
|
|
|
|
});
|
2023-07-03 15:27:18 -05:00
|
|
|
|
2023-07-03 19:26:02 -05:00
|
|
|
// 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 = `
|
2023-07-28 08:21:58 -05:00
|
|
|
<details ${category.layers.filter(l => l.enabled).length > 0 ? "open" : ""}>
|
2023-07-25 20:35:57 -05:00
|
|
|
<summary>${category.name}</summary>
|
2023-07-03 19:26:02 -05:00
|
|
|
<ul></ul>
|
2023-07-25 20:35:57 -05:00
|
|
|
</details>
|
2023-07-03 19:26:02 -05:00
|
|
|
`;
|
|
|
|
for (let layer of category.layers) {
|
|
|
|
const li = document.createElement("li");
|
|
|
|
li.innerHTML = `
|
2023-07-04 00:20:13 -05:00
|
|
|
<label><input type="checkbox" ${layer.enabled ? "checked" : ""}> ${layer.name}</label>
|
2023-07-03 19:26:02 -05:00
|
|
|
`;
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|