- Delete old Vite+Svelte frontend - Initialize new SvelteKit project with TypeScript - Configure Tailwind CSS v4 + DaisyUI - Implement JWT authentication with auto-refresh - Create login page with form validation (Zod) - Add protected route guards - Update Docker configuration for single-stage build - Add E2E tests with Playwright (6/11 passing) - Fix Svelte 5 reactivity with $state() runes Known issues: - 5 E2E tests failing (timing/async issues) - Token refresh implementation needs debugging - Validation error display timing
32 lines
1.1 KiB
JavaScript
32 lines
1.1 KiB
JavaScript
/**
|
|
* Simple JSON Schema generator for validation libraries without introspection.
|
|
*/
|
|
export function simpleSchema(value) {
|
|
if (value === null || value === undefined) {
|
|
return {};
|
|
}
|
|
switch (typeof value) {
|
|
case 'object': {
|
|
if (value instanceof Date) {
|
|
return { type: 'integer', format: 'unix-time' };
|
|
}
|
|
if (Array.isArray(value)) {
|
|
const output = { type: 'array' };
|
|
output.items = value.length ? simpleSchema(value[0]) : {};
|
|
return output;
|
|
}
|
|
else {
|
|
const obj = value;
|
|
return {
|
|
type: 'object',
|
|
properties: Object.fromEntries(Object.entries(obj).map(([key, value]) => [key, simpleSchema(value)])),
|
|
required: Object.keys(obj).filter((key) => (!obj[key] && obj[key] !== undefined && obj[key] !== null) ||
|
|
(Array.isArray(obj[key]) && !obj[key].length)),
|
|
additionalProperties: false
|
|
};
|
|
}
|
|
}
|
|
}
|
|
return { type: typeof value };
|
|
}
|