Compare commits
3 Commits
f915dad908
...
ecf64c679f
Author | SHA1 | Date | |
---|---|---|---|
ecf64c679f | |||
f1cf7f2867 | |||
63de9a9476 |
@ -17,22 +17,3 @@
|
||||
</ul>
|
||||
<span></span>
|
||||
</footer>
|
||||
<script
|
||||
src="https://code.jquery.com/jquery-3.7.1.min.js"
|
||||
integrity="sha256-/JqT3SQfawRcv/BIHPThkBvs0OEvtFFmqPF/lYI/Cxo="
|
||||
crossorigin="anonymous"></script>
|
||||
<script src="{{ "/assets/js/materialize.min.js" | relative_url }}"></script>
|
||||
<script>
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
var sidenavElems = document.querySelectorAll('.sidenav');
|
||||
var sidenavInstances = M.Sidenav.init(sidenavElems, {});
|
||||
});
|
||||
|
||||
document.querySelectorAll("button").forEach(button => {
|
||||
const href = button.getAttribute("data-href");
|
||||
if (!href) return;
|
||||
button.addEventListener("click", () => {
|
||||
window.location.href = button.getAttribute("data-href");
|
||||
});
|
||||
});
|
||||
</script>
|
||||
|
@ -9,10 +9,32 @@
|
||||
{{ content }}
|
||||
</main>
|
||||
{% include footer.html %}
|
||||
<script src="{{ "/assets/js/materialize.min.js" | relative_url }}"></script>
|
||||
<script>
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
var sidenavElems = document.querySelectorAll('.sidenav');
|
||||
var sidenavInstances = M.Sidenav.init(sidenavElems, {});
|
||||
});
|
||||
|
||||
document.querySelectorAll("button").forEach(button => {
|
||||
const href = button.getAttribute("data-href");
|
||||
if (!href) return;
|
||||
button.addEventListener("click", () => {
|
||||
window.location.href = button.getAttribute("data-href");
|
||||
});
|
||||
});
|
||||
</script>
|
||||
<script>
|
||||
if ('serviceWorker' in navigator) {
|
||||
navigator.serviceWorker.register("{{ '/assets/js/service-worker.js' | relative_url }}")
|
||||
.then(() => console.log("✅ Service Worker registriert"))
|
||||
.then((reg) => {
|
||||
console.log("✅ Service Worker registriert");
|
||||
if ('SyncManager' in window) {
|
||||
reg.sync.register('cache-all-pages')
|
||||
.then(() => console.log("✅ Alle Seiten werden gecached"))
|
||||
.catch(err => console.error("❌ Fehler beim Sync:", err));
|
||||
}
|
||||
})
|
||||
.catch(error => console.log("❌ Service Worker Fehler:", error));
|
||||
}
|
||||
</script>
|
||||
|
@ -3,6 +3,7 @@ layout: page
|
||||
title: Charaktere
|
||||
permalink: /characters/
|
||||
icon: account_circle
|
||||
weigth: 3
|
||||
---
|
||||
|
||||
<div class="row" style="column-gap: 5px;">
|
||||
|
@ -4,6 +4,7 @@ title: Chase Révolte
|
||||
permalink: /characters/chase
|
||||
image: /assets/img/Netrunner.png
|
||||
datasource: /assets/game-data/characters/chase.json
|
||||
nav: false
|
||||
---
|
||||
|
||||
Test
|
@ -3,6 +3,7 @@ layout: page
|
||||
title: Lebensweg
|
||||
permalink: /lifepaths/
|
||||
icon: merge
|
||||
weight: 1
|
||||
---
|
||||
|
||||
- [Kulturelle Herkunft](#kulturelle-herkunft)
|
||||
@ -15,7 +16,6 @@ icon: merge
|
||||
- [Deine Familienkrise](#deine-familienkrise)
|
||||
- [Deine Lebensziele](#deine-lebensziele)
|
||||
- [Deine Freunde, Deine Feinde, Deine tragische(n) Liebschaft(en), Süße Rache](#deine-freunde-deine-feinde-deine-tragischen-liebschaften-süße-rache)
|
||||
{:.cyber-ul style="align-self: start;"}
|
||||
|
||||
## Kulturelle Herkunft
|
||||
{:.cyber-h}
|
||||
|
@ -2,6 +2,7 @@
|
||||
layout: page
|
||||
title: Netrunner Guide
|
||||
permalink: /players-guide/netrunner
|
||||
nav: false
|
||||
---
|
||||
|
||||
TBD
|
@ -3,6 +3,7 @@ layout: page
|
||||
title: Spielerguide
|
||||
permalink: /players-guide/
|
||||
icon: description
|
||||
weigth: 2
|
||||
---
|
||||
|
||||
TBD
|
||||
|
@ -3,6 +3,7 @@ layout: page
|
||||
title: Rollen
|
||||
permalink: /roles/
|
||||
icon: manage_accounts
|
||||
weight: 4
|
||||
---
|
||||
|
||||
TBD
|
||||
|
@ -2,6 +2,7 @@
|
||||
layout: page
|
||||
title: Tech Guide
|
||||
permalink: /players-guide/tech
|
||||
nav: false
|
||||
---
|
||||
|
||||
TBD
|
@ -5,6 +5,7 @@ permalink: /assets/js/service-worker.js
|
||||
const CACHE_NAME = "cyberpunk-cache-v1";
|
||||
const OFFLINE_URL = "/offline.html"; // Diese Seite wird angezeigt, wenn offline
|
||||
const BASE_PATH = "{{ "/" | relative_url }}";
|
||||
const SITEMAP_URL = BASE_PATH + "sitemap.json";
|
||||
|
||||
const urlsToCache = [
|
||||
BASE_PATH,
|
||||
@ -34,7 +35,9 @@ const urlsToCache = [
|
||||
BASE_PATH + "/assets/game-data/characters/carver.json",
|
||||
];
|
||||
|
||||
// Installations-Event: Dateien werden in den Cache geladen
|
||||
/**
|
||||
* Install-Event: Cache Standarddateien
|
||||
*/
|
||||
self.addEventListener("install", (event) => {
|
||||
event.waitUntil(
|
||||
caches.open(CACHE_NAME).then((cache) => {
|
||||
@ -43,18 +46,45 @@ self.addEventListener("install", (event) => {
|
||||
);
|
||||
});
|
||||
|
||||
// Fetch-Event: Prüft, ob eine Datei im Cache ist, bevor sie aus dem Netz geladen wird
|
||||
/**
|
||||
* Fetch-Event: Cache-First Strategie mit Offline-Fallback
|
||||
*/
|
||||
self.addEventListener("fetch", (event) => {
|
||||
event.respondWith(
|
||||
caches.match(event.request).then((response) => {
|
||||
return response || fetch(event.request).catch(() => {
|
||||
return caches.match(OFFLINE_URL); // Falls offline, lade offline.html
|
||||
return caches.match(OFFLINE_URL);
|
||||
});
|
||||
})
|
||||
);
|
||||
});
|
||||
|
||||
// Aktivierungs-Event: Löscht alten Cache, wenn sich Dateien geändert haben
|
||||
/**
|
||||
* Wenn die Startseite geladen wird, lade automatisch alle Seiten aus der Sitemap in den Cache
|
||||
*/
|
||||
self.addEventListener("sync", (event) => {
|
||||
if (event.tag === "cache-all-pages") {
|
||||
event.waitUntil(
|
||||
fetch(SITEMAP_URL)
|
||||
.then((response) => response.json())
|
||||
.then((data) => {
|
||||
return caches.open(CACHE_NAME).then((cache) => {
|
||||
return Promise.all(
|
||||
data.pages.map((page) => {
|
||||
return fetch(page.url)
|
||||
.then((response) => cache.put(page.url, response))
|
||||
.catch((err) => console.error("Fehler beim Cachen:", err));
|
||||
})
|
||||
);
|
||||
});
|
||||
})
|
||||
);
|
||||
}
|
||||
});
|
||||
|
||||
/**
|
||||
* Aktivierungs-Event: Löscht alten Cache
|
||||
*/
|
||||
self.addEventListener("activate", (event) => {
|
||||
event.waitUntil(
|
||||
caches.keys().then((cacheNames) => {
|
||||
|
11
sitemap.json.html
Normal file
11
sitemap.json.html
Normal file
@ -0,0 +1,11 @@
|
||||
---
|
||||
permalink: /sitemap.json
|
||||
---
|
||||
|
||||
{
|
||||
"pages": [
|
||||
{% for page in site.pages %}
|
||||
{ "url": "{{ page.url | relative_url }}" }{% unless forloop.last %},{% endunless %}
|
||||
{% endfor %}
|
||||
]
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user