- Move api.server.ts, errors.ts, types.ts, utils.ts, relativeTime.ts to lib/shared/ - Move person relationship components to lib/person/relationship/ - Move Stammbaum components to lib/person/genealogy/ - Move HelpPopover to lib/shared/primitives/ - Update all import paths across routes, specs, and lib files - Update vi.mock() paths in server-project test files - Remove now-empty legacy directories (components/, hooks/, server/, etc.) - Update vite.config.ts coverage include paths for new structure - Update frontend/CLAUDE.md to reflect domain-based lib/ layout Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
32 lines
1002 B
TypeScript
32 lines
1002 B
TypeScript
import { error } from '@sveltejs/kit';
|
|
import { createApiClient } from '$lib/shared/api.server';
|
|
import { getErrorMessage } from '$lib/shared/errors';
|
|
|
|
export async function load({ url, fetch, locals }) {
|
|
const q = url.searchParams.get('q') || '';
|
|
const api = createApiClient(fetch);
|
|
|
|
const canWrite =
|
|
(locals.user as { groups?: { permissions: string[] }[] } | undefined)?.groups?.some((g) =>
|
|
g.permissions.includes('WRITE_ALL')
|
|
) ?? false;
|
|
|
|
const [personsResult, statsResult] = await Promise.all([
|
|
api.GET('/api/persons', { params: { query: { q: q || undefined } } }),
|
|
api.GET('/api/stats', {})
|
|
]);
|
|
|
|
if (!personsResult.response.ok) {
|
|
throw error(personsResult.response.status, getErrorMessage(undefined));
|
|
}
|
|
|
|
const stats = statsResult.response.ok
|
|
? {
|
|
totalPersons: statsResult.data!.totalPersons ?? 0,
|
|
totalDocuments: statsResult.data!.totalDocuments ?? 0
|
|
}
|
|
: { totalPersons: 0, totalDocuments: 0 };
|
|
|
|
return { persons: personsResult.data!, stats, q, canWrite };
|
|
}
|