- 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
39 lines
1.1 KiB
JavaScript
39 lines
1.1 KiB
JavaScript
import { compileObjectLiteral, implementNode } from "../shared/implement.js";
|
|
import { BaseProp, intersectProps } from "./prop.js";
|
|
const implementation = implementNode({
|
|
kind: "required",
|
|
hasAssociatedError: true,
|
|
intersectionIsOpen: true,
|
|
keys: {
|
|
key: {},
|
|
value: {
|
|
child: true,
|
|
parse: (schema, ctx) => ctx.$.parseSchema(schema)
|
|
}
|
|
},
|
|
normalize: schema => schema,
|
|
defaults: {
|
|
description: node => `${node.compiledKey}: ${node.value.description}`,
|
|
expected: ctx => ctx.missingValueDescription,
|
|
actual: () => "missing"
|
|
},
|
|
intersections: {
|
|
required: intersectProps,
|
|
optional: intersectProps
|
|
}
|
|
});
|
|
export class RequiredNode extends BaseProp {
|
|
expression = `${this.compiledKey}: ${this.value.expression}`;
|
|
errorContext = Object.freeze({
|
|
code: "required",
|
|
missingValueDescription: this.value.defaultShortDescription,
|
|
relativePath: [this.key],
|
|
meta: this.meta
|
|
});
|
|
compiledErrorContext = compileObjectLiteral(this.errorContext);
|
|
}
|
|
export const Required = {
|
|
implementation,
|
|
Node: RequiredNode
|
|
};
|