- 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
51 lines
963 B
JavaScript
51 lines
963 B
JavaScript
/**
|
|
* PluginArray.
|
|
*/
|
|
export default class PluginArray {
|
|
length;
|
|
/**
|
|
* Constructor.
|
|
*
|
|
* @param plugins Plugins.
|
|
*/
|
|
constructor(plugins) {
|
|
for (let i = 0, max = plugins.length; i < max; i++) {
|
|
this[i] = plugins[i];
|
|
this[plugins[i].name] = plugins[i];
|
|
}
|
|
this.length = plugins.length;
|
|
}
|
|
/**
|
|
* Returns an item.
|
|
*
|
|
* @param index Index.
|
|
* @returns Plugin.
|
|
*/
|
|
item(index) {
|
|
return this[index] || null;
|
|
}
|
|
/**
|
|
* Returns an item.
|
|
*
|
|
* @param name Name.
|
|
* @returns Plugin.
|
|
*/
|
|
namedItem(name) {
|
|
return this[name] || null;
|
|
}
|
|
/**
|
|
* Refreshes the list.
|
|
*/
|
|
refresh() {
|
|
// Do nothing
|
|
}
|
|
/**
|
|
* Returns the object as a string.
|
|
*
|
|
* @returns String.
|
|
*/
|
|
toString() {
|
|
return '[object PluginArray]';
|
|
}
|
|
}
|
|
//# sourceMappingURL=PluginArray.js.map
|