- 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
27 lines
822 B
JavaScript
27 lines
822 B
JavaScript
import { CommentDirectives } from './comment-directives.js';
|
|
export class Shared {
|
|
constructor() {
|
|
this.commentDirectives = [];
|
|
}
|
|
newCommentDirectives(options) {
|
|
const directives = new CommentDirectives(options);
|
|
this.commentDirectives.push(directives);
|
|
return directives;
|
|
}
|
|
}
|
|
const sharedMap = new Map();
|
|
/** Start sharing and make the data available. */
|
|
export function beginShared(filename) {
|
|
sharedMap.set(filename, new Shared());
|
|
}
|
|
/** Get the shared data and end the sharing. */
|
|
export function terminateShared(filename) {
|
|
const result = sharedMap.get(filename);
|
|
sharedMap.delete(filename);
|
|
return result ?? null;
|
|
}
|
|
/** If sharing has started, get the shared data. */
|
|
export function getShared(filename) {
|
|
return sharedMap.get(filename) ?? null;
|
|
}
|