- 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
33 lines
743 B
TypeScript
33 lines
743 B
TypeScript
import { readdirSync, writeFileSync, statSync } from "fs";
|
|
|
|
const ignore = ["src/index.ts"];
|
|
|
|
function checkSrcDir(path: string): string[] {
|
|
const lines: string[] = [];
|
|
|
|
for (const item of readdirSync(path)) {
|
|
const itemPath = path + "/" + item;
|
|
|
|
if (ignore.includes(itemPath)) {
|
|
continue;
|
|
}
|
|
|
|
if (statSync(itemPath).isDirectory()) {
|
|
lines.push(...checkSrcDir(itemPath));
|
|
} else if (item.endsWith(".ts")) {
|
|
lines.push('export * from "./' + itemPath.slice(4, -2) + 'js"');
|
|
}
|
|
}
|
|
|
|
return lines;
|
|
}
|
|
|
|
const lines = checkSrcDir("src");
|
|
|
|
lines.push(
|
|
'import { zodToJsonSchema } from "./zodToJsonSchema.js"',
|
|
"export default zodToJsonSchema;",
|
|
);
|
|
|
|
writeFileSync("./src/index.ts", lines.join(";\n"));
|