dev #6

Merged
nessi merged 6 commits from dev into main 2026-02-07 10:12:30 +00:00
2 changed files with 133 additions and 19 deletions
Showing only changes of commit 62439d2d28 - Show all commits

View File

@@ -14,7 +14,6 @@
rel="stylesheet" rel="stylesheet"
/> />
<!-- Fallback Background (IMMER sichtbar, kein Schwarz) -->
<style> <style>
html, html,
body { body {
@@ -39,7 +38,9 @@
rgba(30, 30, 30, 0.95), rgba(30, 30, 30, 0.95),
#000 #000
); );
transition: opacity 160ms ease; overflow: hidden;
opacity: 1;
transition: opacity 260ms ease;
} }
#app-splash.hide { #app-splash.hide {
@@ -47,12 +48,113 @@
pointer-events: none; pointer-events: none;
} }
#app-splash .title { /* gold animated lines */
#app-splash::before,
#app-splash::after {
content: "";
position: absolute;
inset: -40%;
background:
linear-gradient(
90deg,
transparent,
rgba(233, 216, 166, 0.18),
transparent
);
transform: rotate(12deg);
animation: goldSweep 1.6s linear infinite;
opacity: 0.55;
filter: blur(0.2px);
pointer-events: none;
}
#app-splash::after {
transform: rotate(-12deg);
animation-duration: 2.2s;
opacity: 0.35;
}
@keyframes goldSweep {
0% { transform: translateX(-25%) rotate(12deg); }
100% { transform: translateX(25%) rotate(12deg); }
}
/* glassy card */
.splash-card {
position: relative;
width: min(520px, 90vw);
border-radius: 22px;
padding: 18px 16px;
background: rgba(20, 20, 22, 0.55);
border: 1px solid rgba(233, 216, 166, 0.16);
box-shadow: 0 18px 70px rgba(0,0,0,0.55);
backdrop-filter: blur(10px);
-webkit-backdrop-filter: blur(10px);
text-align: center;
overflow: hidden;
}
.splash-card::before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(90deg, transparent, rgba(233,216,166,0.16), transparent);
opacity: 0.45;
pointer-events: none;
}
.splash-title {
position: relative;
font-family: "Cinzel Decorative", serif; font-family: "Cinzel Decorative", serif;
font-weight: 700; font-weight: 700;
letter-spacing: 0.08em; letter-spacing: 0.06em;
color: rgba(233, 216, 166, 0.85); color: rgba(245, 239, 220, 0.92);
font-size: 18px; font-size: 18px;
line-height: 1.25;
}
.splash-sub {
position: relative;
margin-top: 6px;
font-family: "IM Fell English", serif;
font-style: italic;
color: rgba(233, 216, 166, 0.78);
font-size: 13px;
}
/* Loader */
.loader {
position: relative;
margin: 14px auto 0;
width: 28px;
height: 28px;
border-radius: 999px;
border: 2px solid rgba(233, 216, 166, 0.18);
border-top-color: rgba(233, 216, 166, 0.92);
animation: spin 0.85s linear infinite;
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
/* tiny spark at bottom */
.spark {
position: relative;
margin: 14px auto 0;
width: 160px;
height: 2px;
border-radius: 999px;
background: linear-gradient(90deg, transparent, rgba(233,216,166,0.65), transparent);
opacity: 0.6;
filter: blur(0.2px);
animation: pulse 1.4s ease-in-out infinite;
}
@keyframes pulse {
0%, 100% { opacity: 0.35; transform: scaleX(0.92); }
50% { opacity: 0.85; transform: scaleX(1.02); }
} }
</style> </style>
@@ -66,9 +168,13 @@
</head> </head>
<body> <body>
<!-- ✅ Splash ist sichtbar, App lädt dahinter --> <div id="app-splash" aria-hidden="true">
<div id="app-splash"> <div class="splash-card">
<div class="title">Zauber-Detektiv Notizbogen</div> <div class="splash-title">Zauber-Detektiv Notizbogen</div>
<div class="splash-sub">Magie wird vorbereitet…</div>
<div class="loader" aria-label="Laden"></div>
<div class="spark"></div>
</div>
</div> </div>
<div id="root"></div> <div id="root"></div>

View File

@@ -5,7 +5,7 @@ import { applyTheme, DEFAULT_THEME_KEY } from "./styles/themes";
import { registerSW } from "virtual:pwa-register"; import { registerSW } from "virtual:pwa-register";
async function bootstrap() { async function bootstrap() {
// Theme sofort setzen // Theme sofort setzen
try { try {
const key = localStorage.getItem("hpTheme:guest") || DEFAULT_THEME_KEY; const key = localStorage.getItem("hpTheme:guest") || DEFAULT_THEME_KEY;
applyTheme(key); applyTheme(key);
@@ -13,29 +13,37 @@ async function bootstrap() {
applyTheme(DEFAULT_THEME_KEY); applyTheme(DEFAULT_THEME_KEY);
} }
// Fonts abwarten (kein Layout-Jump) // Fonts abwarten (verhindert Layout-Sprung)
try { try {
if (document.fonts?.ready) { if (document.fonts?.ready) {
await document.fonts.ready; await document.fonts.ready;
} }
} catch {} } catch {}
// React rendern // App rendern
ReactDOM.createRoot(document.getElementById("root")).render(<App />); ReactDOM.createRoot(document.getElementById("root")).render(<App />);
// Splash sauber ausblenden (KEIN Schwarz) // Splash mind. 3 Sekunden anzeigen (3000ms)
const splash = document.getElementById("app-splash"); const MIN_SPLASH_MS = 3000;
if (splash) { const tStart = performance.now();
requestAnimationFrame(() => splash.classList.add("hide"));
setTimeout(() => splash.remove(), 220);
}
// ✅ Service Worker ohne Reload-Flash const hideSplash = () => {
const splash = document.getElementById("app-splash");
if (!splash) return;
splash.classList.add("hide");
setTimeout(() => splash.remove(), 320);
};
const elapsed = performance.now() - tStart;
const remaining = Math.max(0, MIN_SPLASH_MS - elapsed);
setTimeout(hideSplash, remaining);
// Service Worker ohne Auto-Reload-Flash
registerSW({ registerSW({
immediate: true, immediate: true,
onNeedRefresh() { onNeedRefresh() {
console.info("Neue Version verfügbar"); console.info("Neue Version verfügbar");
// später Toast möglich // optional: später Toast "Update verfügbar"
}, },
}); });
} }