103 lines
5.6 KiB
TypeScript
103 lines
5.6 KiB
TypeScript
import { defineComponent, computed, ref, type Ref } from "vue";
|
|
import useHead from "@/useHead.ts";
|
|
import DJTooltip, { setupTooltip } from "@/DJTooltip.tsx";
|
|
import DJEmail from "@/DJEmail.tsx";
|
|
|
|
export default defineComponent({
|
|
name: "app-root",
|
|
setup() {
|
|
useHead({ title: "DJ Ledda's Homepage" });
|
|
|
|
const tooltipCarrier = ref<HTMLDivElement | null>(null);
|
|
setupTooltip({ carrier: tooltipCarrier });
|
|
|
|
const dude1Spinning = ref(false);
|
|
const dude2Spinning = ref(false);
|
|
|
|
function toggleDude(event: MouseEvent, dudeRef: Ref<boolean>) {
|
|
const dude = event.target as HTMLImageElement;
|
|
if (dudeRef.value) {
|
|
dude.addEventListener("animationiteration", function listener() {
|
|
dudeRef.value = false;
|
|
dude.removeEventListener("animationiteration", listener as EventListenerOrEventListenerObject);
|
|
});
|
|
} else {
|
|
dudeRef.value = true;
|
|
}
|
|
}
|
|
|
|
const shaking = computed(() => dude1Spinning.value || dude2Spinning.value);
|
|
|
|
return () => <>
|
|
<div ref={tooltipCarrier} class="tooltip-carrier" />
|
|
<div class="supercontainer">
|
|
<div class={{ shakeable: true, shakeMe: shaking.value }}>
|
|
<div class="title_name">
|
|
<DJTooltip tooltip="I wonder what he's listening to?">
|
|
<img src="/home/img/dj.gif" alt="dj legt krasse Mucke auf"
|
|
class={{ dude: true, spinMe: dude1Spinning.value }}
|
|
onClick={ (e) => toggleDude(e, dude1Spinning)} />
|
|
</DJTooltip>
|
|
<DJTooltip tooltip="Easily the coolest guy out there.">
|
|
<span>DJ Ledda</span>
|
|
</DJTooltip>
|
|
<DJTooltip tooltip="I once heard this guy played at revs.">
|
|
<img src="/home/img/dj.gif" alt="dj laying down some sick beats"
|
|
class={{ dude: true, spinMe: dude2Spinning.value }}
|
|
onClick={ (e) => toggleDude(e, dude2Spinning) } />
|
|
</DJTooltip>
|
|
</div>
|
|
<div class="main">
|
|
<div class="subject">
|
|
<div class="resourcelist">
|
|
<a href="https://drum-slayer.com">
|
|
<DJTooltip class="resource" tooltip="Small app for designing multitrack looped rhythms with local save and multiple files. Originally built using just vanilla TypeScript and CSS, now with Vue.">
|
|
Drum Slayer
|
|
</DJTooltip>
|
|
</a>
|
|
<a href="/somaesque">
|
|
<DJTooltip class="resource" tooltip="Puzzle solver app for puzzle cubes resembling the original Soma Cube puzzle. Save and edit your own puzzles! Built with Svelte, THREE.js and AssemblyScript.">
|
|
Somaesque
|
|
</DJTooltip>
|
|
</a>
|
|
<a href="/generative-energy">
|
|
<DJTooltip class="resource" tooltip="Thyroid calculator, German translations, and more...">
|
|
Generative Energy - Ray Peat Resources
|
|
</DJTooltip>
|
|
</a>
|
|
<a href="/home/muenchen-auf-englisch.html">
|
|
<DJTooltip class="resource" tooltip="
|
|
Authentic historically accurate translations of all of Munich's S-Bahn and U-Bahn
|
|
stations, as well as the main municipalities, into English. You live in Allach? It's
|
|
Axleigh now. Giesing? Nope! Kyesing! This is a WIP.
|
|
">
|
|
München auf Englisch - Munich in English
|
|
</DJTooltip>
|
|
</a>
|
|
<a href="/kadi/">
|
|
<DJTooltip class="resource" tooltip="Make an account and start saving paper and tracking your Yatzy stats with your
|
|
friends! Make your own rulesets, and more. Built with React, express.js, and
|
|
MongoDB. Currently inactive.">
|
|
K A D I: Online Yatzy Scoresheets
|
|
</DJTooltip>
|
|
</a>
|
|
<a href="https://git.djledda.net/Ledda">
|
|
<DJTooltip class="resource" tooltip="Check out what I'm coding!">
|
|
My git projects
|
|
</DJTooltip>
|
|
</a>
|
|
<DJEmail>
|
|
<DJTooltip class="resource" tooltip="You'll see my address when you click here.">
|
|
Click here to get in touch
|
|
</DJTooltip>
|
|
</DJEmail>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div id="tooltipCarrier"></div>
|
|
</div>
|
|
</div>
|
|
</>;
|
|
},
|
|
});
|