Merge branch 'remove-turbo'

This commit is contained in:
DrMint 2023-09-28 15:01:49 +02:00
commit e8f3afe409
14 changed files with 96 additions and 181 deletions

BIN
bun.lockb

Binary file not shown.

View File

@ -12,15 +12,12 @@
}, },
"dependencies": { "dependencies": {
"@astrojs/node": "^6.0.0", "@astrojs/node": "^6.0.0",
"@hotwired/turbo": "^7.3.0",
"accept-language": "^3.0.18", "accept-language": "^3.0.18",
"astro": "^3.0.3", "astro": "^3.0.3",
"astro-icon": "next", "astro-icon": "next",
"hono": "^3.5.7", "hono": "^3.5.7",
"htmx.org": "^1.9.5",
"js-cookie": "^3.0.5", "js-cookie": "^3.0.5",
"node-cache": "^5.1.2", "node-cache": "^5.1.2",
"sanitize.css": "^13.0.0",
"tippy.js": "^6.3.7" "tippy.js": "^6.3.7"
}, },
"devDependencies": { "devDependencies": {

File diff suppressed because one or more lines are too long

View File

@ -1,8 +1,7 @@
--- ---
import Html from "pages/_components/Html.astro"; import Html from "pages/_components/Html.astro";
import Navbar from "./components/Navbar.astro"; import Navbar from "./components/Navbar.astro";
import { parseCookie } from "utils/astro"; import { CookieNames, parseCookie } from "utils/cookies";
import { CookieNames } from "utils/cookies";
import MenuPanel from "./components/MenuPanel.astro"; import MenuPanel from "./components/MenuPanel.astro";
interface Props { interface Props {

View File

@ -18,18 +18,18 @@ const { isReduced = false } = Astro.props;
/* ------------------------------------------- HTML ------------------------------------------- */ /* ------------------------------------------- HTML ------------------------------------------- */
} }
<a <a id="accords-logo" href={getLocalizedUrl("/", locale)}>
id="accords-logo"
data-turbo-confirm="Do you want to leave this page?"
href={getLocalizedUrl("/", locale)}
>
<Icon name="accords" /> <Icon name="accords" />
</a> </a>
<p id="title" class:list={{ hidden: isReduced }}>Accords Library</p> <p id="title" class:list={{ hidden: isReduced }}>Accords Library</p>
<div id="buttons" class:list={["when-js", { reduced: isReduced }]}> <div id="buttons" class:list={["when-js", { reduced: isReduced }]}>
<ReduceToggleButton icon={isReduced ? "material-symbols:chevron-right": "material-symbols:chevron-left"} /> <ReduceToggleButton
icon={isReduced
? "material-symbols:chevron-right"
: "material-symbols:chevron-left"}
/>
<ThemeToggleButton /> <ThemeToggleButton />
</div> </div>
@ -118,9 +118,11 @@ const { isReduced = false } = Astro.props;
</p> </p>
<div id="social-links"> <div id="social-links">
<Icon name="github-brands" /> <a href="https://github.com/accords-Library"
<Icon name="x-brands" /> ><Icon name="github-brands" /></a
<Icon name="discord-brands" /> >
<a href="https://twitter.com/AccordsLibrary"><Icon name="x-brands" /></a>
<a href="/discord"><Icon name="discord-brands" /></a>
</div> </div>
</div> </div>
@ -190,7 +192,7 @@ const { isReduced = false } = Astro.props;
place-items: center; place-items: center;
gap: 2rem; gap: 2rem;
& > svg { & > a > svg {
width: 40px; width: 40px;
height: 40px; height: 40px;
} }
@ -203,9 +205,6 @@ const { isReduced = false } = Astro.props;
<script> <script>
import tippy, { createSingleton } from "tippy.js"; import tippy, { createSingleton } from "tippy.js";
import { onLoad } from "utils/turbo";
onLoad(() => {
createSingleton( createSingleton(
tippy("#menu-panel > .when-reduced > [data-tippy-template]", { tippy("#menu-panel > .when-reduced > [data-tippy-template]", {
content: (reference) => { content: (reference) => {
@ -226,5 +225,4 @@ const { isReduced = false } = Astro.props;
inertia: true, inertia: true,
} }
); );
});
</script> </script>

View File

@ -70,9 +70,7 @@ const { title, showSubPanel } = Astro.props;
<script> <script>
import { Elementos } from "utils/Elementos"; import { Elementos } from "utils/Elementos";
import { observable } from "utils/micro-observables"; import { observable } from "utils/micro-observables";
import { onLoad } from "utils/turbo";
onLoad(() => {
const isMenuPanelOpened = observable(false); const isMenuPanelOpened = observable(false);
const menuPanel = new Elementos("#menu-panel"); const menuPanel = new Elementos("#menu-panel");
const menuPanelToggle = new Elementos("#toggle-menu-panel"); const menuPanelToggle = new Elementos("#toggle-menu-panel");
@ -93,5 +91,4 @@ const { title, showSubPanel } = Astro.props;
}); });
subPanel.setClass("opened", isSubPanelOpened); subPanel.setClass("opened", isSubPanelOpened);
subPanelToggle.setClass("on", isSubPanelOpened); subPanelToggle.setClass("on", isSubPanelOpened);
});
</script> </script>

View File

@ -24,9 +24,7 @@ const { icon } = Astro.props;
import { Elementos } from "utils/Elementos"; import { Elementos } from "utils/Elementos";
import { CookieNames } from "utils/cookies"; import { CookieNames } from "utils/cookies";
import { observableWithPersistence } from "utils/micro-observables"; import { observableWithPersistence } from "utils/micro-observables";
import { onLoad } from "utils/turbo";
onLoad(() => {
const toggleReducedButton = new Elementos("#reduce-toggle"); const toggleReducedButton = new Elementos("#reduce-toggle");
const menuPanel = new Elementos("#menu-panel"); const menuPanel = new Elementos("#menu-panel");
@ -37,9 +35,7 @@ const { icon } = Astro.props;
toggleReducedButton.onClick(() => { toggleReducedButton.onClick(() => {
isReduced.update((oldValue) => !oldValue); isReduced.update((oldValue) => !oldValue);
Turbo.cache.clear();
}); });
menuPanel.setClass("reduced", isReduced); menuPanel.setClass("reduced", isReduced);
});
</script> </script>

View File

@ -1,7 +1,6 @@
--- ---
import { Icon } from "astro-icon/components"; import { Icon } from "astro-icon/components";
import { parseCookie } from "utils/astro"; import { CookieNames, parseCookie } from "utils/cookies";
import { CookieNames } from "utils/cookies";
const themeColors = parseCookie<string>( const themeColors = parseCookie<string>(
Astro.cookies.get(CookieNames.THEME_COLOR), Astro.cookies.get(CookieNames.THEME_COLOR),
@ -50,9 +49,7 @@ const themeColors = parseCookie<string>(
import { Elementos } from "utils/Elementos"; import { Elementos } from "utils/Elementos";
import { CookieNames } from "utils/cookies"; import { CookieNames } from "utils/cookies";
import { observableWithPersistence } from "utils/micro-observables"; import { observableWithPersistence } from "utils/micro-observables";
import { onLoad } from "utils/turbo";
onLoad(() => {
const body = new Elementos("body"); const body = new Elementos("body");
const themeToggleButton = new Elementos("#theme-toggle"); const themeToggleButton = new Elementos("#theme-toggle");
@ -61,9 +58,7 @@ const themeColors = parseCookie<string>(
"theme-color-light" "theme-color-light"
); );
const isDarkMode = themeColor.select( const isDarkMode = themeColor.select((value) => value === "theme-color-dark");
(value) => value === "theme-color-dark"
);
themeToggleButton.onClick(() => { themeToggleButton.onClick(() => {
themeColor.update((oldValue) => themeColor.update((oldValue) =>
@ -71,17 +66,12 @@ const themeColors = parseCookie<string>(
? "theme-color-dark" ? "theme-color-dark"
: "theme-color-light" : "theme-color-light"
); );
Turbo.cache.clear();
}); });
themeToggleButton.setClass( themeToggleButton.setClass({ ifFalse: "light", ifTrue: "dark" }, isDarkMode);
{ ifFalse: "light", ifTrue: "dark" },
isDarkMode
);
body.setClass( body.setClass(
{ ifFalse: "theme-color-light", ifTrue: "theme-color-dark" }, { ifFalse: "theme-color-light", ifTrue: "theme-color-dark" },
isDarkMode isDarkMode
); );
});
</script> </script>

View File

@ -1,6 +1,5 @@
--- ---
import { parseCookie } from "utils/astro"; import { CookieNames, parseCookie } from "utils/cookies";
import { CookieNames } from "utils/cookies";
interface Props { interface Props {
title: string; title: string;
@ -22,7 +21,6 @@ const themeColors = parseCookie(
<meta charset="UTF-8" /> <meta charset="UTF-8" />
<meta name="viewport" content="width=device-width" /> <meta name="viewport" content="width=device-width" />
<title>{title}</title> <title>{title}</title>
<script is:inline src="/js/turbo.es2017-umd.js" async defer></script>
<link href="/css/sanitize.min.css" rel="stylesheet" /> <link href="/css/sanitize.min.css" rel="stylesheet" />
<link href="/css/tippy.css" rel="stylesheet" /> <link href="/css/tippy.css" rel="stylesheet" />
<link rel="icon" type="image/svg+xml" href="/favicon.svg" /> <link rel="icon" type="image/svg+xml" href="/favicon.svg" />
@ -297,7 +295,7 @@ const themeColors = parseCookie(
@font-face { @font-face {
font-family: "Vollkorn"; font-family: "Vollkorn";
src: url("/fonts/Vollkorn-Bold.woff2") format("woff2"); src: url("/fonts/Vollkorn-Bold.woff2") format("woff2");
font-weight: bold; font-weight: 700;
font-style: normal; font-style: normal;
font-display: swap; font-display: swap;
} }
@ -305,7 +303,7 @@ const themeColors = parseCookie(
@font-face { @font-face {
font-family: "Noto Sans"; font-family: "Noto Sans";
src: url("/fonts/NotoSans-Medium.woff2") format("woff2"); src: url("/fonts/NotoSans-Medium.woff2") format("woff2");
font-weight: medium; font-weight: 600;
font-style: normal; font-style: normal;
font-display: swap; font-display: swap;
} }
@ -313,7 +311,7 @@ const themeColors = parseCookie(
@font-face { @font-face {
font-family: "Noto Sans"; font-family: "Noto Sans";
src: url("/fonts/NotoSans-Bold.woff2") format("woff2"); src: url("/fonts/NotoSans-Bold.woff2") format("woff2");
font-weight: bold; font-weight: 700;
font-style: normal; font-style: normal;
font-display: swap; font-display: swap;
} }
@ -321,7 +319,7 @@ const themeColors = parseCookie(
@font-face { @font-face {
font-family: "Angelic Agrippa"; font-family: "Angelic Agrippa";
src: url("/fonts/AngelicAgrippa-Regular.woff2") format("woff2"); src: url("/fonts/AngelicAgrippa-Regular.woff2") format("woff2");
font-weight: normal; font-weight: 500;
font-style: normal; font-style: normal;
font-display: swap; font-display: swap;
} }
@ -449,37 +447,3 @@ const themeColors = parseCookie(
--font-angelic: "Angelic Agrippa", serif; --font-angelic: "Angelic Agrippa", serif;
} }
</style> </style>
{
/* -------------------------------------------- JS -------------------------------------------- */
}
<script>
import { Elementos } from "utils/Elementos";
import { observable } from "utils/micro-observables";
import { onRequestEnd, onRequestStart, onLoad } from "utils/turbo";
onLoad(() => {
const progressBar = new Elementos("#turbo-progress-bar");
const isLoading = observable(false);
const isCompleted = observable(false);
progressBar.setClass("loading", isLoading);
progressBar.setClass("completed", isCompleted);
let requestStartTime = 0;
onRequestStart(() => {
isLoading.set(true);
isCompleted.set(false);
requestStartTime = Date.now();
});
onRequestEnd(() => {
isLoading.set(false);
if (Date.now() - requestStartTime > 500) {
isCompleted.set(true);
}
});
});
</script>

View File

@ -1,7 +0,0 @@
// https://turbo.hotwired.dev/reference/drive
declare namespace Turbo {
const cache: {
clear: () => void;
};
const setProgressBarDelay: (delayInMs: number) => void;
}

View File

@ -1,8 +0,0 @@
import { type AstroCookies } from "astro";
type AstroCookie = ReturnType<AstroCookies["get"]>;
export const parseCookie = <T>(cookies: AstroCookie, defaultValue: T): T => {
const value: T | null = JSON.parse(cookies?.value ?? "null");
return value ?? defaultValue;
};

View File

@ -1,3 +1,12 @@
import { type AstroCookies } from "astro";
type AstroCookie = ReturnType<AstroCookies["get"]>;
export const parseCookie = <T>(cookies: AstroCookie, defaultValue: T): T => {
const value: T | null = JSON.parse(cookies?.value ?? "null");
return value ?? defaultValue;
};
export enum CookieNames { export enum CookieNames {
MENU_PANEL_REDUCED = "menuPanelReduced", MENU_PANEL_REDUCED = "menuPanelReduced",
THEME_COLOR = "themeColor", THEME_COLOR = "themeColor",

View File

@ -1,5 +0,0 @@
export const customEvents = {
mainPanel: {
reduce: { toggle: "mainPanel.reduce.toggle" },
},
};

View File

@ -1,14 +0,0 @@
export const onLoad = (callback: () => void) =>
document.documentElement.addEventListener("turbo:load", callback);
export const onRequestStart = (callback: () => void) =>
document.documentElement.addEventListener(
"turbo:before-fetch-request",
callback
);
export const onRequestEnd = (callback: () => void) =>
document.documentElement.addEventListener(
"turbo:render",
callback
);