- 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
44 lines
982 B
JavaScript
44 lines
982 B
JavaScript
/*
|
|
MIT License http://www.opensource.org/licenses/mit-license.php
|
|
Author Tobias Koppers @sokra
|
|
*/
|
|
|
|
"use strict";
|
|
|
|
/** @typedef {import("./Resolver")} Resolver */
|
|
/** @typedef {import("./Resolver").ResolveStepHook} ResolveStepHook */
|
|
|
|
module.exports = class ResultPlugin {
|
|
/**
|
|
* @param {ResolveStepHook} source source
|
|
*/
|
|
constructor(source) {
|
|
this.source = source;
|
|
}
|
|
|
|
/**
|
|
* @param {Resolver} resolver the resolver
|
|
* @returns {void}
|
|
*/
|
|
apply(resolver) {
|
|
this.source.tapAsync(
|
|
"ResultPlugin",
|
|
(request, resolverContext, callback) => {
|
|
const obj = { ...request };
|
|
if (resolverContext.log) {
|
|
resolverContext.log(`reporting result ${obj.path}`);
|
|
}
|
|
resolver.hooks.result.callAsync(obj, resolverContext, (err) => {
|
|
if (err) return callback(err);
|
|
if (typeof resolverContext.yield === "function") {
|
|
resolverContext.yield(obj);
|
|
callback(null, null);
|
|
} else {
|
|
callback(null, obj);
|
|
}
|
|
});
|
|
},
|
|
);
|
|
}
|
|
};
|