perf: pre-generate Bible verse data and reduce DOM via conditional rendering
All checks were successful
CI / update (push) Successful in 1m34s

- Extract Bible lookup logic into shared src/lib/server/bible.ts module
- Add build script to pre-generate all 20 mystery verse lookups as static data,
  eliminating runtime API calls on rosary page load
- Update Prayer.svelte to pass showLatin/urlLang as snippet parameters; all 14
  prayer components now conditionally render only visible language elements
  instead of hiding via CSS
- Extract 4 inline mystery selector SVGs into MysteryIcon.svelte component
- Remove unused CSS selectors from angelus page
This commit is contained in:
2026-02-03 14:27:39 +01:00
parent 3ff3d0dc8a
commit b28154564f
23 changed files with 1251 additions and 720 deletions

View File

@@ -3,33 +3,35 @@
</script>
<Prayer>
{#snippet children(showLatin, urlLang)}
<p>
<v lang="la">Pater noster, qui es in cælis</v>
<v lang="de">Vater unser, der Du bist im Himmel,</v>
<v lang="en">Our Father, Who art in heaven,</v>
<v lang="la">Sanctificétur nomen tuum</v>
<v lang="de">geheiligt werde Dein Name;</v>
<v lang="en">hallowed be Thy name;</v>
<v lang="la">Advéniat regnum tuum</v>
<v lang="de">zu uns komme Dein Reich;</v>
<v lang="en">Thy kingdom come;</v>
<v lang="la">Fiat volúntas tua, sicut in cælo, et in terra.</v>
<v lang="de">Dein Wille geschehe, wie im Himmel, also auch auf Erden!</v>
<v lang="en">Thy will be done on earth as it is in heaven.</v>
<v lang="la">Panem nostrum quotidiánum da nobis hódie.</v>
<v lang="de">Unser tägliches Brot gib uns heute;</v>
<v lang="en">Give us this day our daily bread;</v>
<v lang="la">Et dimítte nobis debíta nostra,</v>
<v lang="de">und vergib uns unsere Schulden,</v>
<v lang="en">and forgive us our trespasses,</v>
<v lang="la">sicut et nos dimíttimus debitóribus nostris.</v>
<v lang="de">wie auch wir vergeben unsern Schuldigern;</v>
<v lang="en">as we forgive those who trespass against us;</v>
<v lang="la">Et ne nos indúcas in tentatiónem.</v>
<v lang="de">und führe uns nicht in Versuchung.</v>
<v lang="en">and lead us not into temptation,</v>
<v lang="la">Sed líbera nos a malo. Amen.</v>
<v lang="de">Sondern erlöse uns von dem Übel. Amen.</v>
<v lang="en">but deliver us from evil. Amen.</v>
{#if showLatin}<v lang="la">Pater noster, qui es in cælis</v>{/if}
{#if urlLang === 'de'}<v lang="de">Vater unser, der Du bist im Himmel,</v>{/if}
{#if urlLang === 'en'}<v lang="en">Our Father, Who art in heaven,</v>{/if}
{#if showLatin}<v lang="la">Sanctificétur nomen tuum</v>{/if}
{#if urlLang === 'de'}<v lang="de">geheiligt werde Dein Name;</v>{/if}
{#if urlLang === 'en'}<v lang="en">hallowed be Thy name;</v>{/if}
{#if showLatin}<v lang="la">Advéniat regnum tuum</v>{/if}
{#if urlLang === 'de'}<v lang="de">zu uns komme Dein Reich;</v>{/if}
{#if urlLang === 'en'}<v lang="en">Thy kingdom come;</v>{/if}
{#if showLatin}<v lang="la">Fiat volúntas tua, sicut in cælo, et in terra.</v>{/if}
{#if urlLang === 'de'}<v lang="de">Dein Wille geschehe, wie im Himmel, also auch auf Erden!</v>{/if}
{#if urlLang === 'en'}<v lang="en">Thy will be done on earth as it is in heaven.</v>{/if}
{#if showLatin}<v lang="la">Panem nostrum quotidiánum da nobis hódie.</v>{/if}
{#if urlLang === 'de'}<v lang="de">Unser tägliches Brot gib uns heute;</v>{/if}
{#if urlLang === 'en'}<v lang="en">Give us this day our daily bread;</v>{/if}
{#if showLatin}<v lang="la">Et dimítte nobis debíta nostra,</v>{/if}
{#if urlLang === 'de'}<v lang="de">und vergib uns unsere Schulden,</v>{/if}
{#if urlLang === 'en'}<v lang="en">and forgive us our trespasses,</v>{/if}
{#if showLatin}<v lang="la">sicut et nos dimíttimus debitóribus nostris.</v>{/if}
{#if urlLang === 'de'}<v lang="de">wie auch wir vergeben unsern Schuldigern;</v>{/if}
{#if urlLang === 'en'}<v lang="en">as we forgive those who trespass against us;</v>{/if}
{#if showLatin}<v lang="la">Et ne nos indúcas in tentatiónem.</v>{/if}
{#if urlLang === 'de'}<v lang="de">und führe uns nicht in Versuchung.</v>{/if}
{#if urlLang === 'en'}<v lang="en">and lead us not into temptation,</v>{/if}
{#if showLatin}<v lang="la">Sed líbera nos a malo. Amen.</v>{/if}
{#if urlLang === 'de'}<v lang="de">Sondern erlöse uns von dem Übel. Amen.</v>{/if}
{#if urlLang === 'en'}<v lang="en">but deliver us from evil. Amen.</v>{/if}
</p>
{/snippet}
</Prayer>