Zipcode-Finder/script.js
2023-02-06 12:17:43 +01:00

49 lines
1.1 KiB
JavaScript

var mouseX, mouseY;
denmark.onmousemove = event => {
zip.style.display = "none";
var rect = denmark.getBoundingClientRect();
mouseX = event.x - rect.left;
mouseY = event.y - rect.top;
var coordX = mouseX * 0.00875 + 6;
var coordY = Math.abs(mouseY * 0.0052 - 58);
coords.innerHTML = `${coordX}<br>${coordY}`;
var oldMouseX = mouseX, oldMouseY = mouseY;
setTimeout(() => {
if (!mouseX || !mouseY || oldMouseX != mouseX || oldMouseY != mouseY) return;
var xhr = new XMLHttpRequest;
xhr.onload = () => {
if (xhr.status === 200)
eval(xhr.responseText);
else
onZipError();
}
xhr.open("GET", `https://api.dataforsyningen.dk/postnumre/reverse?x=${coordX}&y=${coordY}&callback=onZipFound`);
xhr.send();
}, 200);
};
denmark.onmouseleave = () => {
mouseX = mouseY = null;
};
function onZipFound(data) {
zip.innerHTML = `${data.nr} <b>${data.navn}</b>`;
zip.style.left = (mouseX+3) + "px";
zip.style.top = (mouseY+3) + "px";
zip.style.display = "block";
}
function onZipError() {
zip.innerHTML = "Postnummer ikke fundet";
zip.style.left = (mouseX+3) + "px";
zip.style.top = (mouseY+3) + "px";
zip.style.display = "block";
}