- 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
828 B
JavaScript
35 lines
828 B
JavaScript
'use strict';
|
|
|
|
var resolve = require('./resolve');
|
|
|
|
module.exports = {
|
|
Validation: errorSubclass(ValidationError),
|
|
MissingRef: errorSubclass(MissingRefError)
|
|
};
|
|
|
|
|
|
function ValidationError(errors) {
|
|
this.message = 'validation failed';
|
|
this.errors = errors;
|
|
this.ajv = this.validation = true;
|
|
}
|
|
|
|
|
|
MissingRefError.message = function (baseId, ref) {
|
|
return 'can\'t resolve reference ' + ref + ' from id ' + baseId;
|
|
};
|
|
|
|
|
|
function MissingRefError(baseId, ref, message) {
|
|
this.message = message || MissingRefError.message(baseId, ref);
|
|
this.missingRef = resolve.url(baseId, ref);
|
|
this.missingSchema = resolve.normalizeId(resolve.fullPath(this.missingRef));
|
|
}
|
|
|
|
|
|
function errorSubclass(Subclass) {
|
|
Subclass.prototype = Object.create(Error.prototype);
|
|
Subclass.prototype.constructor = Subclass;
|
|
return Subclass;
|
|
}
|