Initial commit
This commit is contained in:
commit
1be6713c91
BIN
denmark-map.jpg
Normal file
BIN
denmark-map.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 134 KiB |
15
index.html
Normal file
15
index.html
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>noob</title>
|
||||||
|
<link rel="stylesheet" href="style.css">
|
||||||
|
<script src="script.js" defer></script>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<main>
|
||||||
|
<img id="denmark" src="denmark-map.jpg">
|
||||||
|
<p id="coords"></p>
|
||||||
|
<div id="zip"></div>
|
||||||
|
</main>
|
||||||
|
</body>
|
||||||
|
</html>
|
48
script.js
Normal file
48
script.js
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
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";
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user