- 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
26 lines
710 B
JavaScript
26 lines
710 B
JavaScript
export const hasDomain = (data, kind) => domainOf(data) === kind;
|
|
export const domainOf = (data) => {
|
|
const builtinType = typeof data;
|
|
return (builtinType === "object" ?
|
|
data === null ?
|
|
"null"
|
|
: "object"
|
|
: builtinType === "function" ? "object"
|
|
: builtinType);
|
|
};
|
|
/** Each domain's completion for the phrase "must be _____" */
|
|
export const domainDescriptions = {
|
|
boolean: "boolean",
|
|
null: "null",
|
|
undefined: "undefined",
|
|
bigint: "a bigint",
|
|
number: "a number",
|
|
object: "an object",
|
|
string: "a string",
|
|
symbol: "a symbol"
|
|
};
|
|
export const jsTypeOfDescriptions = {
|
|
...domainDescriptions,
|
|
function: "a function"
|
|
};
|