- 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
45 lines
1.6 KiB
JavaScript
45 lines
1.6 KiB
JavaScript
import { createRule } from '../utils/index.js';
|
|
export default createRule('no-export-load-in-svelte-module-in-kit-pages', {
|
|
meta: {
|
|
docs: {
|
|
description: 'disallow exporting load functions in `*.svelte` module in SvelteKit page components.',
|
|
category: 'SvelteKit',
|
|
recommended: true
|
|
},
|
|
schema: [],
|
|
messages: {
|
|
unexpected: 'disallow exporting load functions in `*.svelte` module in SvelteKit page components.'
|
|
},
|
|
type: 'problem',
|
|
conditions: [
|
|
{
|
|
svelteKitFileTypes: ['+page.svelte', '+error.svelte', '+layout.svelte']
|
|
}
|
|
]
|
|
},
|
|
create(context) {
|
|
let isModule = false;
|
|
return {
|
|
// <script context="module">
|
|
[`Program > SvelteScriptElement > SvelteStartTag > SvelteAttribute[key.name="context"] > SvelteLiteral[value="module"]`]: () => {
|
|
isModule = true;
|
|
},
|
|
// </script>
|
|
'Program > SvelteScriptElement:exit': () => {
|
|
isModule = false;
|
|
},
|
|
// export function load() {}
|
|
// export const load = () => {}
|
|
[`:matches(ExportNamedDeclaration > FunctionDeclaration, ExportNamedDeclaration > VariableDeclaration > VariableDeclarator) > Identifier.id[name="load"]`]: (node) => {
|
|
if (!isModule)
|
|
return {};
|
|
return context.report({
|
|
node,
|
|
loc: node.loc,
|
|
messageId: 'unexpected'
|
|
});
|
|
}
|
|
};
|
|
}
|
|
});
|