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,90 @@
import SVGElement from '../svg-element/SVGElement.js';
import * as PropertySymbol from '../../PropertySymbol.js';
import SVGAnimatedNumber from '../../svg/SVGAnimatedNumber.js';
import SVGAnimatedLength from '../../svg/SVGAnimatedLength.js';
import SVGAnimatedString from '../../svg/SVGAnimatedString.js';
/**
* SVGFESpecularLightingElement.
*
* @see https://developer.mozilla.org/en-US/docs/Web/API/SVGFESpecularLightingElement
*/
export default class SVGFESpecularLightingElement extends SVGElement {
[PropertySymbol.height]: SVGAnimatedLength | null;
[PropertySymbol.in1]: SVGAnimatedString | null;
[PropertySymbol.kernelUnitLengthX]: SVGAnimatedNumber | null;
[PropertySymbol.kernelUnitLengthY]: SVGAnimatedNumber | null;
[PropertySymbol.result]: SVGAnimatedString | null;
[PropertySymbol.specularConstant]: SVGAnimatedNumber | null;
[PropertySymbol.specularExponent]: SVGAnimatedNumber | null;
[PropertySymbol.surfaceScale]: SVGAnimatedNumber | null;
[PropertySymbol.width]: SVGAnimatedLength | null;
[PropertySymbol.x]: SVGAnimatedLength | null;
[PropertySymbol.y]: SVGAnimatedLength | null;
/**
* Returns height.
*
* @returns Height.
*/
get height(): SVGAnimatedLength;
/**
* Returns in1.
*
* @returns In1.
*/
get in1(): SVGAnimatedString;
/**
* Returns kernelUnitLengthX.
*
* @returns KernelUnitLengthX.
*/
get kernelUnitLengthX(): SVGAnimatedNumber;
/**
* Returns kernelUnitLengthY.
*
* @returns KernelUnitLengthY.
*/
get kernelUnitLengthY(): SVGAnimatedNumber;
/**
* Returns result.
*
* @returns Result.
*/
get result(): SVGAnimatedString;
/**
* Returns specularConstant.
*
* @returns SpecularConstant.
*/
get specularConstant(): SVGAnimatedNumber;
/**
* Returns specularExponent.
*
* @returns SpecularExponent.
*/
get specularExponent(): SVGAnimatedNumber;
/**
* Returns surfaceScale.
*
* @returns SurfaceScale.
*/
get surfaceScale(): SVGAnimatedNumber;
/**
* Returns width.
*
* @returns Width.
*/
get width(): SVGAnimatedLength;
/**
* Returns x position.
*
* @returns X position.
*/
get x(): SVGAnimatedLength;
/**
* Returns y position.
*
* @returns Y position.
*/
get y(): SVGAnimatedLength;
}
//# sourceMappingURL=SVGFESpecularLightingElement.d.ts.map

View File

@@ -0,0 +1 @@
{"version":3,"file":"SVGFESpecularLightingElement.d.ts","sourceRoot":"","sources":["../../../src/nodes/svg-fe-specular-lighting-element/SVGFESpecularLightingElement.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,8BAA8B,CAAC;AACtD,OAAO,KAAK,cAAc,MAAM,yBAAyB,CAAC;AAC1D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAE/D;;;;GAIG;AACH,MAAM,CAAC,OAAO,OAAO,4BAA6B,SAAQ,UAAU;IAE5D,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACzD,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACtD,CAAC,cAAc,CAAC,iBAAiB,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACpE,CAAC,cAAc,CAAC,iBAAiB,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACpE,CAAC,cAAc,CAAC,MAAM,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACzD,CAAC,cAAc,CAAC,gBAAgB,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACnE,CAAC,cAAc,CAAC,gBAAgB,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACnE,CAAC,cAAc,CAAC,YAAY,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IAC/D,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACxD,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IACpD,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IAE3D;;;;OAIG;IACH,IAAW,MAAM,IAAI,iBAAiB,CAYrC;IAED;;;;OAIG;IACH,IAAW,GAAG,IAAI,iBAAiB,CAYlC;IAED;;;;OAIG;IACH,IAAW,iBAAiB,IAAI,iBAAiB,CAYhD;IAED;;;;OAIG;IACH,IAAW,iBAAiB,IAAI,iBAAiB,CAYhD;IAED;;;;OAIG;IACH,IAAW,MAAM,IAAI,iBAAiB,CAYrC;IAED;;;;OAIG;IACH,IAAW,gBAAgB,IAAI,iBAAiB,CAa/C;IAED;;;;OAIG;IACH,IAAW,gBAAgB,IAAI,iBAAiB,CAa/C;IAED;;;;OAIG;IACH,IAAW,YAAY,IAAI,iBAAiB,CAa3C;IAED;;;;OAIG;IACH,IAAW,KAAK,IAAI,iBAAiB,CAYpC;IAED;;;;OAIG;IACH,IAAW,CAAC,IAAI,iBAAiB,CAYhC;IAED;;;;OAIG;IACH,IAAW,CAAC,IAAI,iBAAiB,CAYhC;CACD"}

View File

@@ -0,0 +1,182 @@
import SVGElement from '../svg-element/SVGElement.js';
import * as PropertySymbol from '../../PropertySymbol.js';
import SVGAnimatedNumber from '../../svg/SVGAnimatedNumber.js';
import SVGAnimatedLength from '../../svg/SVGAnimatedLength.js';
import SVGAnimatedString from '../../svg/SVGAnimatedString.js';
/**
* SVGFESpecularLightingElement.
*
* @see https://developer.mozilla.org/en-US/docs/Web/API/SVGFESpecularLightingElement
*/
export default class SVGFESpecularLightingElement extends SVGElement {
// Internal properties
[PropertySymbol.height] = null;
[PropertySymbol.in1] = null;
[PropertySymbol.kernelUnitLengthX] = null;
[PropertySymbol.kernelUnitLengthY] = null;
[PropertySymbol.result] = null;
[PropertySymbol.specularConstant] = null;
[PropertySymbol.specularExponent] = null;
[PropertySymbol.surfaceScale] = null;
[PropertySymbol.width] = null;
[PropertySymbol.x] = null;
[PropertySymbol.y] = null;
/**
* Returns height.
*
* @returns Height.
*/
get height() {
if (!this[PropertySymbol.height]) {
this[PropertySymbol.height] = new SVGAnimatedLength(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('height'),
setAttribute: (value) => this.setAttribute('height', value)
});
}
return this[PropertySymbol.height];
}
/**
* Returns in1.
*
* @returns In1.
*/
get in1() {
if (!this[PropertySymbol.in1]) {
this[PropertySymbol.in1] = new SVGAnimatedString(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('in'),
setAttribute: (value) => this.setAttribute('in', value)
});
}
return this[PropertySymbol.in1];
}
/**
* Returns kernelUnitLengthX.
*
* @returns KernelUnitLengthX.
*/
get kernelUnitLengthX() {
if (!this[PropertySymbol.kernelUnitLengthX]) {
this[PropertySymbol.kernelUnitLengthX] = new SVGAnimatedNumber(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('kernelUnitLengthX'),
setAttribute: (value) => this.setAttribute('kernelUnitLengthX', value)
});
}
return this[PropertySymbol.kernelUnitLengthX];
}
/**
* Returns kernelUnitLengthY.
*
* @returns KernelUnitLengthY.
*/
get kernelUnitLengthY() {
if (!this[PropertySymbol.kernelUnitLengthY]) {
this[PropertySymbol.kernelUnitLengthY] = new SVGAnimatedNumber(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('kernelUnitLengthY'),
setAttribute: (value) => this.setAttribute('kernelUnitLengthY', value)
});
}
return this[PropertySymbol.kernelUnitLengthY];
}
/**
* Returns result.
*
* @returns Result.
*/
get result() {
if (!this[PropertySymbol.result]) {
this[PropertySymbol.result] = new SVGAnimatedString(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('result'),
setAttribute: (value) => this.setAttribute('result', value)
});
}
return this[PropertySymbol.result];
}
/**
* Returns specularConstant.
*
* @returns SpecularConstant.
*/
get specularConstant() {
if (!this[PropertySymbol.specularConstant]) {
this[PropertySymbol.specularConstant] = new SVGAnimatedNumber(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('specularConstant'),
setAttribute: (value) => this.setAttribute('specularConstant', value),
defaultValue: 1
});
}
return this[PropertySymbol.specularConstant];
}
/**
* Returns specularExponent.
*
* @returns SpecularExponent.
*/
get specularExponent() {
if (!this[PropertySymbol.specularExponent]) {
this[PropertySymbol.specularExponent] = new SVGAnimatedNumber(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('specularExponent'),
setAttribute: (value) => this.setAttribute('specularExponent', value),
defaultValue: 1
});
}
return this[PropertySymbol.specularExponent];
}
/**
* Returns surfaceScale.
*
* @returns SurfaceScale.
*/
get surfaceScale() {
if (!this[PropertySymbol.surfaceScale]) {
this[PropertySymbol.surfaceScale] = new SVGAnimatedNumber(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('surfaceScale'),
setAttribute: (value) => this.setAttribute('surfaceScale', value),
defaultValue: 1
});
}
return this[PropertySymbol.surfaceScale];
}
/**
* Returns width.
*
* @returns Width.
*/
get width() {
if (!this[PropertySymbol.width]) {
this[PropertySymbol.width] = new SVGAnimatedLength(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('width'),
setAttribute: (value) => this.setAttribute('width', value)
});
}
return this[PropertySymbol.width];
}
/**
* Returns x position.
*
* @returns X position.
*/
get x() {
if (!this[PropertySymbol.x]) {
this[PropertySymbol.x] = new SVGAnimatedLength(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('x'),
setAttribute: (value) => this.setAttribute('x', value)
});
}
return this[PropertySymbol.x];
}
/**
* Returns y position.
*
* @returns Y position.
*/
get y() {
if (!this[PropertySymbol.y]) {
this[PropertySymbol.y] = new SVGAnimatedLength(PropertySymbol.illegalConstructor, this[PropertySymbol.window], {
getAttribute: () => this.getAttribute('y'),
setAttribute: (value) => this.setAttribute('y', value)
});
}
return this[PropertySymbol.y];
}
}
//# sourceMappingURL=SVGFESpecularLightingElement.js.map

File diff suppressed because one or more lines are too long