- 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
35 lines
990 B
JavaScript
35 lines
990 B
JavaScript
import * as Inspectable from "../../Inspectable.js";
|
|
/** @internal */
|
|
export const getKeysForIndexSignature = (input, parameter) => {
|
|
switch (parameter._tag) {
|
|
case "StringKeyword":
|
|
case "TemplateLiteral":
|
|
return Object.keys(input);
|
|
case "SymbolKeyword":
|
|
return Object.getOwnPropertySymbols(input);
|
|
case "Refinement":
|
|
return getKeysForIndexSignature(input, parameter.from);
|
|
}
|
|
};
|
|
/** @internal */
|
|
export const memoizeThunk = f => {
|
|
let done = false;
|
|
let a;
|
|
return () => {
|
|
if (done) {
|
|
return a;
|
|
}
|
|
a = f();
|
|
done = true;
|
|
return a;
|
|
};
|
|
};
|
|
/** @internal */
|
|
export const isNonEmpty = x => Array.isArray(x);
|
|
/** @internal */
|
|
export const isSingle = x => !Array.isArray(x);
|
|
/** @internal */
|
|
export const formatPathKey = key => `[${Inspectable.formatPropertyKey(key)}]`;
|
|
/** @internal */
|
|
export const formatPath = path => isNonEmpty(path) ? path.map(formatPathKey).join("") : formatPathKey(path);
|
|
//# sourceMappingURL=util.js.map
|