117 lines
2.6 KiB
HTML
117 lines
2.6 KiB
HTML
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta charset="utf-8">
|
||
|
<!-- meta name="color-scheme" content="dark light" /-->
|
||
|
<title>
|
||
|
Projects | Criminally Cute
|
||
|
</title>
|
||
|
<link rel="icon" type="image/png" href="/favicon.png">
|
||
|
<link rel="stylesheet" href="/css/site.css">
|
||
|
</head>
|
||
|
|
||
|
<body>
|
||
|
<header>
|
||
|
<nav>
|
||
|
<ul>
|
||
|
<li><a href="/">Home</a></li>
|
||
|
<li><a href="/about">About</a></li>
|
||
|
<li><a href="/blog">Blog</a></li>
|
||
|
<li><a href="/projects">Projects</a></li>
|
||
|
</ul>
|
||
|
</nav>
|
||
|
<div>
|
||
|
<h1>Projects</h1>
|
||
|
</div>
|
||
|
</header>
|
||
|
|
||
|
<main>
|
||
|
<article>
|
||
|
<div class="space-y-20">
|
||
|
<div class="flex flex-col space-y-20">
|
||
|
|
||
|
<div>
|
||
|
<h2 class="text-base">active</h2>
|
||
|
<div class="space-y-4">
|
||
|
<div>
|
||
|
|
||
|
<a href="https://some.site">test</a>
|
||
|
|
||
|
<p class="mt-0 text-sm">
|
||
|
Fleet bilge rat hang the jib Sail ho dead men tell no tales gibbet yardarm galleon. Bowsprit long boat cackle fruit draft chandler scurvy crimp black spot lugger Sea Legs.
|
||
|
|
||
|
</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
</div>
|
||
|
</div>
|
||
|
</article>
|
||
|
</main>
|
||
|
|
||
|
<footer>
|
||
|
<ul>
|
||
|
<li>some link</li>
|
||
|
<li>some link 2</li>
|
||
|
</ul>
|
||
|
<div>
|
||
|
<p>© 2024 Criminally Cute</p>
|
||
|
<p><a class="underline" href="/feed.xml">RSS</a></p>
|
||
|
</div>
|
||
|
</footer>
|
||
|
</body>
|
||
|
</html>
|
||
|
|
||
|
|
||
|
<script>
|
||
|
function log(message) {
|
||
|
if (true) {
|
||
|
console.log(`[web_dev_utils] ${message}`)
|
||
|
}
|
||
|
}
|
||
|
function connect() {
|
||
|
try {
|
||
|
window.socket = new WebSocket('ws://' + location.host + '/ws');
|
||
|
|
||
|
window.socket.onmessage = function(e) {
|
||
|
if (e.data === "reload") {
|
||
|
log("reloading!");
|
||
|
location.reload();
|
||
|
} else if (e.data === "subscribed") {
|
||
|
log("connected and subscribed!");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
window.socket.onopen = () => {
|
||
|
waitForConnection(() => {
|
||
|
log("sending 'subscribe' message");
|
||
|
window.socket.send("subscribe")
|
||
|
}
|
||
|
, 300);
|
||
|
};
|
||
|
|
||
|
window.socket.onclose = () => {
|
||
|
setTimeout(() => connect(), 500);
|
||
|
};
|
||
|
|
||
|
function waitForConnection(callback, interval) {
|
||
|
log("waiting for connection!")
|
||
|
if (window.socket.readyState === 1) {
|
||
|
callback();
|
||
|
} else {
|
||
|
log("setting a timeout")
|
||
|
setTimeout(() => waitForConnection(callback, interval), interval);
|
||
|
}
|
||
|
}
|
||
|
} catch (e) {
|
||
|
log(e);
|
||
|
setTimeout(() => connect(), 500);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
log("about to connect");
|
||
|
connect();
|
||
|
</script>
|
||
|
|