Files
sukaato-site/lib/sukaato_web/controllers/page_html/twofact.html.heex
2025-09-03 13:12:13 -04:00

90 lines
4.6 KiB
Plaintext

<!DOCTYPE html>
<% rel_proj_root = "../../../.." %>
<html lang={@config["site"]["lang"]}>
<.html_head site_name={@config["site"]["name"]} site_author={@config["site"]["author"]} site_desc={@config["site"]["desc"]} />
<script id="MathJax-script" async src="https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js"></script>
<!-- <audio id="loaded" class="notifier" src={~p"/audio/page_load.mp3"}></audio> -->
<body id="default_body">
<noscript>
<div id="noscript_panel" class="panel">
<!-- @TODO change below button button to anchor elements for ALL HEEx pages -->
<a id="monologin_noscript" class="loginbutt">Log in</a>
<a id="monoregistration_noscript" class="registbutt">Register</a>
</div>
</noscript>
<template id="panel">
<!-- @TODO change below button button to anchor elements for ALL HEEx pages -->
<a id="monologin" class="loginbutt">Log in</a>
<a id="monoregistration" class="registbutt">Register</a>
</template>
<div id="banner">
<% # @TODO verify the below works %>
<%= raw File.read!(Path.expand("#{rel_proj_root}/priv/static/images/main.svg", __DIR__)) %>
<span class="frontmatter"><a id="home" href={~p"/"}><h1 id="site_title" class="title"><%= @config["site"]["name"] %></h1></a></span>
<nav id="site_nav">
<.navify page_links={@pages} />
</nav>
</div>
<div id="doc">
<main id="content" class="page_content">
<!-- @TODO write a small explanation of site--take inspiration from neocities -->
<%= if @attempted do %>
<span><p>No traces of daimonic possession detected via clairvoyance. Try again?</p></span>
<% else %>
<span><p>By clairvoyance the cult shall detect if you've been properly daimonically possessed!</p></span>
<% end %>
<img />
<form method="post" autocomplete="on">
<input type="hidden" name="_csrf_token" value={Phoenix.Controller.get_csrf_token()} />
<%= if @totp do %>
<label for="totp">Enter TOTP Code</label><br>
<input type="text" id="totp" name="code" maxlength="6"><br>
<% end %>
<%= if @fido do %>
<label for="fido"></label><br>
<input type="text" id="fido" name="chall_resp"><br>
<!-- <input type="hidden" name="chall" value=""> -->
<% end %>
<input type="submit" class="acct_manager" value="Verify">
</form>
</main>
</div>
<div id="extra">
</div>
<.html_foot />
</body>
<script type="module">
// import { NotificationSounds } from "<%= ~p"/js/notifiers.js" %>";
import { Point, Line } from "<%= ~p"/js/space.js" %>";
import { Hitbox, Tracker, spatialTriggerY } from "<%= ~p"/js/triggers.js" %>";
import { reportPriority } from "<%= ~p"/js/err.js" %>";
reportPriority();
let sandbox = new Hitbox(document.body)
let sandbox_rect = sandbox.matter.getBoundingClientRect()
sandbox.y = sandbox_rect.y
let ceiling = new Point(0, Math.round(sandbox.y), 0)
let floor = new Point(0, Math.round(ceiling.y * (60 / sandbox.y)), 0)
let constraint = new Line(ceiling, floor)
window.addEventListener("resize", (e) => {
let sandbox_prev_y = sandbox.y
let sandbox_rect = sandbox.matter.getBoundingClientRect()
sandbox.y = sandbox_rect.y
ceiling.y = Math.round(sandbox.y)
floor.y = Math.round((ceiling.y * (60 / sandbox_prev_y)) + ((ceiling.y * (60 / sandbox_prev_y)) * (sandbox.y / sandbox_prev_y)))
constraint.point1 = ceiling
constraint.point2 = floor
constraint.reset()
console.log("Floor has changed to value %d", floor.y)
console.log(Math.round(ceiling.y * (sandbox.y / sandbox_prev_y)))
console.info("Logging \"top\" of %o on window resize as: %d", sandbox.matter, sandbox.y)
})
sandbox.matter.addEventListener("mousemove", (e) => {
let panel = document.getElementById("panel")
let tracker = new Tracker(e, panel)
tracker.y = tracker.event.clientY
// let yFloor = Math.round(panel.getBoundingClientRect().height)
spatialTriggerY(tracker, constraint, sandbox)
})
</script>
</html>