feat: Reinitialize frontend with SvelteKit and TypeScript

- 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
This commit is contained in:
2026-02-17 16:19:59 -05:00
parent 54df6018f5
commit de2d83092e
28274 changed files with 3816354 additions and 90 deletions

View File

@@ -0,0 +1,21 @@
import Document from '../nodes/document/Document.js';
import * as PropertySymbol from '../PropertySymbol.js';
import BrowserWindow from '../window/BrowserWindow.js';
/**
* DOM parser.
*
* Reference:
* https://developer.mozilla.org/en-US/docs/Web/API/DOMParser.
*/
export default class DOMParser {
protected [PropertySymbol.window]: BrowserWindow;
/**
* Parses HTML and returns a root element.
*
* @param string HTML data.
* @param mimeType Mime type.
* @returns Root element.
*/
parseFromString(string: string, mimeType: string): Document;
}
//# sourceMappingURL=DOMParser.d.ts.map

View File

@@ -0,0 +1 @@
{"version":3,"file":"DOMParser.d.ts","sourceRoot":"","sources":["../../src/dom-parser/DOMParser.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,+BAA+B,CAAC;AACrD,OAAO,KAAK,cAAc,MAAM,sBAAsB,CAAC;AAEvD,OAAO,aAAa,MAAM,4BAA4B,CAAC;AAGvD;;;;;GAKG;AACH,MAAM,CAAC,OAAO,OAAO,SAAS;IAE7B,UAAkB,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,aAAa,CAAC;IAEzD;;;;;;OAMG;IACI,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,QAAQ;CAuBlE"}

View File

@@ -0,0 +1,38 @@
import * as PropertySymbol from '../PropertySymbol.js';
import XMLParser from '../xml-parser/XMLParser.js';
import HTMLParser from '../html-parser/HTMLParser.js';
/**
* DOM parser.
*
* Reference:
* https://developer.mozilla.org/en-US/docs/Web/API/DOMParser.
*/
export default class DOMParser {
/**
* Parses HTML and returns a root element.
*
* @param string HTML data.
* @param mimeType Mime type.
* @returns Root element.
*/
parseFromString(string, mimeType) {
if (!mimeType) {
throw new this[PropertySymbol.window].DOMException('Second parameter "mimeType" is mandatory.');
}
const window = this[PropertySymbol.window];
switch (mimeType) {
case 'text/html':
const newDocument = new window.HTMLDocument();
newDocument[PropertySymbol.defaultView] = window;
return new HTMLParser(this[PropertySymbol.window]).parse(string, newDocument);
case 'image/svg+xml':
case 'text/xml':
case 'application/xml':
case 'application/xhtml+xml':
return new XMLParser(this[PropertySymbol.window]).parse(string);
default:
throw new window.DOMException(`Unknown mime type "${mimeType}".`);
}
}
}
//# sourceMappingURL=DOMParser.js.map

View File

@@ -0,0 +1 @@
{"version":3,"file":"DOMParser.js","sourceRoot":"","sources":["../../src/dom-parser/DOMParser.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,cAAc,MAAM,sBAAsB,CAAC;AACvD,OAAO,SAAS,MAAM,4BAA4B,CAAC;AAEnD,OAAO,UAAU,MAAM,8BAA8B,CAAC;AAEtD;;;;;GAKG;AACH,MAAM,CAAC,OAAO,OAAO,SAAS;IAI7B;;;;;;OAMG;IACI,eAAe,CAAC,MAAc,EAAE,QAAgB;QACtD,IAAI,CAAC,QAAQ,EAAE,CAAC;YACf,MAAM,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,YAAY,CACjD,2CAA2C,CAC3C,CAAC;QACH,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;QAE3C,QAAQ,QAAQ,EAAE,CAAC;YAClB,KAAK,WAAW;gBACf,MAAM,WAAW,GAAG,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC;gBAC9C,WAAW,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,MAAM,CAAC;gBACjD,OAAiB,IAAI,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,WAAW,CAAC,CAAC;YACzF,KAAK,eAAe,CAAC;YACrB,KAAK,UAAU,CAAC;YAChB,KAAK,iBAAiB,CAAC;YACvB,KAAK,uBAAuB;gBAC3B,OAAiB,IAAI,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YAC3E;gBACC,MAAM,IAAI,MAAM,CAAC,YAAY,CAAC,sBAAsB,QAAQ,IAAI,CAAC,CAAC;QACpE,CAAC;IACF,CAAC;CACD"}