- 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
1.5 KiB
JavaScript
44 lines
1.5 KiB
JavaScript
import { createRule } from '../utils/index.js';
|
|
import { extractStoreReferences } from './reference-helpers/svelte-store.js';
|
|
export default createRule('no-store-async', {
|
|
meta: {
|
|
docs: {
|
|
description: 'disallow using async/await inside svelte stores because it causes issues with the auto-unsubscribing features',
|
|
category: 'Possible Errors',
|
|
recommended: true,
|
|
default: 'error'
|
|
},
|
|
schema: [],
|
|
messages: {
|
|
unexpected: 'Do not pass async functions to svelte stores.'
|
|
},
|
|
type: 'problem'
|
|
},
|
|
create(context) {
|
|
return {
|
|
Program() {
|
|
for (const { node } of extractStoreReferences(context)) {
|
|
const [, fn] = node.arguments;
|
|
if (!fn ||
|
|
(fn.type !== 'ArrowFunctionExpression' && fn.type !== 'FunctionExpression') ||
|
|
!fn.async) {
|
|
continue;
|
|
}
|
|
const start = fn.loc.start;
|
|
context.report({
|
|
node: fn,
|
|
loc: {
|
|
start,
|
|
end: {
|
|
line: start.line,
|
|
column: start.column + 5
|
|
}
|
|
},
|
|
messageId: 'unexpected'
|
|
});
|
|
}
|
|
}
|
|
};
|
|
}
|
|
});
|