- 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
28 lines
1.1 KiB
JavaScript
28 lines
1.1 KiB
JavaScript
//#region src/common.ts
|
|
const kMovable = Symbol("Tinypool.kMovable");
|
|
const kTransferable = Symbol.for("Tinypool.transferable");
|
|
const kValue = Symbol.for("Tinypool.valueOf");
|
|
const kQueueOptions = Symbol.for("Tinypool.queueOptions");
|
|
function isTransferable(value) {
|
|
return value != null && typeof value === "object" && kTransferable in value && kValue in value;
|
|
}
|
|
function isMovable(value) {
|
|
return isTransferable(value) && value[kMovable] === true;
|
|
}
|
|
function markMovable(value) {
|
|
Object.defineProperty(value, kMovable, {
|
|
enumerable: false,
|
|
configurable: true,
|
|
writable: true,
|
|
value: true
|
|
});
|
|
}
|
|
function isTaskQueue(value) {
|
|
return typeof value === "object" && value !== null && "size" in value && typeof value.shift === "function" && typeof value.remove === "function" && typeof value.push === "function";
|
|
}
|
|
const kRequestCountField = 0;
|
|
const kResponseCountField = 1;
|
|
const kFieldCount = 2;
|
|
|
|
//#endregion
|
|
export { isMovable, isTaskQueue, isTransferable, kFieldCount, kQueueOptions, kRequestCountField, kResponseCountField, kTransferable, kValue, markMovable }; |