diff options
Diffstat (limited to 'main.js')
-rw-r--r-- | main.js | 80 |
1 files changed, 76 insertions, 4 deletions
@@ -1320,6 +1320,70 @@ const layers = { }); }), }, + + /* Documentation at + * https://www.smhi.se/polopoly_fs/1.34541!/dammprod%202013_3%2C%20beskrivning%2C%20SVAR2012_2.pdf + * */ + smhi_dam: { + popoverTitle: 'Damm', + popover: [ + ['Dammenhetens namn', 'dnamn'], + ['Dammanläggningens namn', 'namn'], + ['Länsnr', 'lst_objid', { classes: ['feature-objid'] }], + ['Status', 'status', { fn: (v) => v === 0 ? '' : v === 1 ? 'Befintlig damm' : v === 2 ? 'Fd. damm' : v }], + ['Regleringstyp', 'regl_typ', { fn: (v) => v === 0 ? '' : v }], + ['Byggår', 'byggar', { fn: (v) => v === 0 ? '' : v }], + ['Dammhöjd', 'dammhojd', { unit: 'm', fn: (v) => v === 0 ? '' : v }], + ['Krönlängd', 'kron', { unit: 'm', fn: (v) => v === 0 ? '' : v }], + ['Fiskväg', 'fiskvag', { fn: (v) => + v === 0 ? '' : + v === 1 ? 'Bassängtrappa' : + v === 2 ? 'Denilränna' : + v === 3 ? 'Slitsränna' : + v === 4 ? 'Omlöp' : + v === 5 ? 'Inlöp' : + v === 6 ? 'Ålledare' : + v === 7 ? 'Smoltränna' : + v === 8 ? 'Okänd typ' : + v === 9 ? 'Ingen' : + v === 10 ? 'Annan' : + v }], + ['Huvudavrinningsområdesnummer', 'haro', { classes: ['feature-objid'] } ], + ['Vattendistrikt', 'RBD', { classes: ['feature-objid'] } ], + ['Verksamhet', 'verksmht', { fn: (v) => + v === 0 ? '' : + v === 1 ? 'Kraftproduktion' : + v === 2 ? 'Industri' : + v === 3 ? 'Sjöfart' : + v === 4 ? 'Invallning' : + v === 5 ? 'Vattenförsörjning' : + v === 6 ? 'Spegeldamm' : + v === 7 ? 'Historisk' : + v === 8 ? 'Övrigt' : + v }], + ['Högsta dämningsgräns', 'dg', { unit: 'm', fn: (v) => v === 0 ? '' : v }], + ['Lägsta sänkningsgräns', 'sg', { unit: 'm', fn: (v) => v === 0 ? '' : v }], + ['Magasinsyta', 'my', { unit: 'km²', fn: (v) => v === 0 ? '' : v }], + ['Reglerbar volym', 'my', { unit: 'Mm³', fn: (v) => v === 0 ? '' : v }], + ['Kommentar', 'kommentar'], + ['Damm-ID', 'dammid', { classes: ['feature-objid'] }], + ], + style: [2, 3, 4, 4, 4, 6, 8, 8, 8, 10, 16, 32].map(function(width) { + return new Style({ + zIndex: 59, + image: new CircleStyle({ + radius: width, + fill: new Fill({ + color: 'rgb(219, 30, 42)', + }), + stroke: new Stroke({ + width: Math.log2(width) * 2/5, + color: 'rgb(128, 17, 25)', + }), + }), + }); + }), + }, }; const layerHierarchy = [ @@ -1341,6 +1405,10 @@ const layerHierarchy = [ ], }, { + text: 'Dammar', + layer: 'smhi_dam', + }, + { text: 'Mineralrättigheter', children: [ { @@ -1729,11 +1797,15 @@ map.addLayer(vectorLayer2); const text0 = document.createTextNode(x.text); label0.appendChild(text0); - const body = document.createElement('div'); - collapse.appendChild(body); - body.classList.add('accordion-body'); + if (x.children === undefined || x.children.length === 0) { + item.replaceChild(span0, header); + } else { + const body = document.createElement('div'); + collapse.appendChild(body); + body.classList.add('accordion-body'); - addAccordionGroup(body, x.children); + addAccordionGroup(body, x.children); + } input0.onclick = function(event) { return onClickFunction(x._layers, event); |