a homebrewed DnD campaign based in the Honkai: Star Rail universe
hsr honkaistarrail dnd
1
fork

Configure Feed

Select the types of activity you want to include in your feed.

migrate feats to use remote functions

+56 -35
-16
app/src/routes/(app)/feats/+page.server.ts
··· 1 - import { db } from '$server/db' 2 - import { FeatRepository } from '$server/db/repos/feat' 3 - import { definePageMeta } from '$ui/page-meta' 4 - import type { PageServerLoad } from './$types' 5 - 6 - export const load: PageServerLoad = async () => { 7 - const featRepo = new FeatRepository(db) 8 - const queryFeats = await featRepo.getFeatsBy() 9 - 10 - return { 11 - meta: definePageMeta({ 12 - title: 'Feats', 13 - }), 14 - feats: queryFeats, 15 - } 16 - }
+6 -6
app/src/routes/(app)/feats/+page.svelte
··· 3 3 import FeatIcon from '$ui/icons/FeatIcon.svelte' 4 4 import { Breadcrumb } from '$ui/layout/breadcrumb' 5 5 import NoEntriesFound from '../NoEntriesFound.svelte' 6 - import type { PageProps } from './$types' 6 + import { getPageMeta, queryBreadcrumb } from './page.remote' 7 + import { querySpells } from '../spells/page.remote' 7 8 8 - const { data }: PageProps = $props() 9 - const { meta, feats } = $derived(data) 9 + const meta = await getPageMeta() 10 + const paths = await queryBreadcrumb() 11 + const feats = await querySpells() 10 12 </script> 11 13 12 14 <svelte:head> 13 15 <PageMeta {...meta} /> 14 16 </svelte:head> 15 17 16 - <Breadcrumb links={[ 17 - { path: '/feats', text: 'Feats' } 18 - ]} /> 18 + <Breadcrumb links={paths.root} /> 19 19 20 20 {#each feats as feat (feat.id)} 21 21 {@debug feat}
-10
app/src/routes/(app)/feats/new/+page.server.ts
··· 1 - import { definePageMeta } from '$ui/page-meta' 2 - import type { PageServerLoad } from './$types' 3 - 4 - export const load: PageServerLoad = async () => { 5 - return { 6 - meta: definePageMeta({ 7 - title: 'Create a new feat entry', 8 - }), 9 - } 10 - }
+7 -3
app/src/routes/(app)/feats/new/+page.svelte
··· 1 1 <script lang="ts"> 2 + import { Breadcrumb } from '$ui/layout/breadcrumb' 2 3 import { PageMeta } from '$ui/page-meta' 3 - import type { PageProps } from './$types' 4 + import { queryBreadcrumb } from '../page.remote' 5 + import { getPageMeta } from './page.remote' 4 6 5 - let { data }: PageProps = $props() 6 - const { meta } = $derived(data) 7 + const meta = await getPageMeta() 8 + const paths = await queryBreadcrumb() 7 9 </script> 8 10 9 11 <svelte:head> 10 12 <PageMeta {...meta} /> 11 13 </svelte:head> 14 + 15 + <Breadcrumb links={paths.newEntry} />
+15
app/src/routes/(app)/feats/new/page.remote.ts
··· 1 + import { form, prerender } from '$app/server' 2 + import { db } from '$server/db' 3 + import { FeatRepository, zFeatSchema } from '$server/db/repos/feat' 4 + import { definePageMeta } from '$ui/page-meta' 5 + 6 + export const getPageMeta = prerender(() => 7 + definePageMeta({ 8 + title: 'Create a new feat entry', 9 + }), 10 + ) 11 + 12 + export const createFeat = form(zFeatSchema.toInsert, async (model) => { 13 + const featRepo = new FeatRepository(db) 14 + return await featRepo.createFeat(model) 15 + })
+28
app/src/routes/(app)/feats/page.remote.ts
··· 1 + import { prerender, query } from '$app/server' 2 + import { db } from '$server/db' 3 + import { FeatRepository } from '$server/db/repos/feat' 4 + import { definePaths } from '$ui/layout/breadcrumb' 5 + import { definePageMeta } from '$ui/page-meta' 6 + 7 + export const getPageMeta = prerender(() => 8 + definePageMeta({ 9 + title: 'Feats', 10 + }), 11 + ) 12 + 13 + export const queryFeats = query(async () => { 14 + const featRepo = new FeatRepository(db) 15 + const queryFeats = await featRepo.getFeatsBy() 16 + 17 + return queryFeats 18 + }) 19 + 20 + export const queryBreadcrumb = query(async () => { 21 + const root = { path: '/feats', text: 'Feats' } 22 + const newEntry = { path: '/feat/new', text: 'Create a new feat entry' } 23 + 24 + return definePaths({ 25 + root: [root], 26 + newEntry: [root, newEntry], 27 + }) 28 + })