chore(storybook): switch to yarn and fix Storybook compatibility

- Switch from bun to yarn with node_modules linker
- Downgrade Svelte to 5.46.1 for Storybook compatibility
- Switch Storybook framework from @storybook/sveltekit to @storybook/svelte-vite
- Downgrade Storybook packages to 10.1.11
- Add FSD path aliases to vite.config.ts
- Add Svelte plugin to Storybook viteFinal to handle .svelte files
This commit is contained in:
Ilia Mashkov
2026-03-07 13:35:26 +03:00
parent 3f9f6e3f93
commit 0b2eae33b1
6 changed files with 4371 additions and 25 deletions

2
.gitignore vendored
View File

@@ -1,4 +1,5 @@
node_modules node_modules
.yarn
# Output # Output
.output .output
@@ -27,4 +28,3 @@ package-lock.json
# Git worktrees # Git worktrees
.worktrees .worktrees

3
.yarnrc.yml Normal file
View File

@@ -0,0 +1,3 @@
# Disable Plug'n'Play, use node_modules
nodeLinker: node-modules
enableGlobalCache: false

View File

@@ -1,17 +1,59 @@
import type { StorybookConfig } from '@storybook/sveltekit'; import type { StorybookConfig } from '@storybook/svelte-vite';
import {
dirname,
resolve,
} from 'path';
import { fileURLToPath } from 'url';
import {
loadConfigFromFile,
mergeConfig,
} from 'vite';
const __filename = fileURLToPath(import.meta.url);
const __dirname = dirname(__filename);
const config: StorybookConfig = { const config: StorybookConfig = {
"stories": [ stories: [
"../src/**/*.mdx", '../../src/**/*.mdx',
"../src/**/*.stories.@(js|ts|svelte)" '../../src/**/*.stories.@(js|ts|svelte)',
], ],
"addons": [ addons: [
"@storybook/addon-svelte-csf", {
"@chromatic-com/storybook", name: '@storybook/addon-svelte-csf',
"@storybook/addon-vitest", options: {
"@storybook/addon-a11y", // Use modern template syntax for better performance
"@storybook/addon-docs" legacyTemplate: false,
},
},
'@chromatic-com/storybook',
'@storybook/addon-vitest',
'@storybook/addon-a11y',
'@storybook/addon-docs',
], ],
"framework": "@storybook/sveltekit" framework: '@storybook/svelte-vite',
async viteFinal(config) {
// This attempts to find your actual vite.config.ts
const { config: userConfig } = await loadConfigFromFile(
{ command: 'serve', mode: 'development' },
resolve(__dirname, '../../vite.config.ts'),
) || {};
const mergedConfig = mergeConfig(config, {
// Merge resolve/alias parts to maintain path aliases
resolve: userConfig?.resolve || {},
});
const { svelte } = await import('@sveltejs/vite-plugin-svelte');
mergedConfig.plugins = mergedConfig.plugins || [];
// Add Svelte plugin to process @storybook's .svelte files
// This prevents Vite from trying to parse them before compilation
mergedConfig.plugins.unshift(svelte({
include: [/node_modules\/@storybook\/.+\.svelte$/],
}));
return mergedConfig;
},
}; };
export default config;
export default config;

View File

@@ -1,6 +1,7 @@
{ {
"name": "allmywork", "name": "allmywork",
"private": true, "private": true,
"packageManager": "yarn@4.11.0",
"version": "0.0.1", "version": "0.0.1",
"type": "module", "type": "module",
"scripts": { "scripts": {
@@ -17,43 +18,46 @@
"test": "vitest", "test": "vitest",
"test:watch": "vitest --watch", "test:watch": "vitest --watch",
"test:e2e": "playwright test", "test:e2e": "playwright test",
"test:all": "bun run test && bun run test:e2e", "test:all": "yarn test && yarn test:e2e",
"test:coverage": "vitest --coverage", "test:coverage": "vitest --coverage",
"storybook": "storybook dev -p 6006 --config-dir config/storybook", "storybook": "storybook dev -p 6006 --config-dir config/storybook",
"build-storybook": "storybook build --config-dir config/storybook" "build-storybook": "storybook build --config-dir config/storybook"
}, },
"devDependencies": { "devDependencies": {
"@biomejs/biome": "^2.4.5", "@biomejs/biome": "^2.4.5",
"@chromatic-com/storybook": "4.1.3",
"@playwright/test": "^1.58.2", "@playwright/test": "^1.58.2",
"@storybook/addon-a11y": "10.1.11",
"@storybook/addon-docs": "10.1.11",
"@storybook/addon-svelte-csf": "5.0.10",
"@storybook/addon-vitest": "10.1.11",
"@sveltejs/adapter-auto": "^7.0.0", "@sveltejs/adapter-auto": "^7.0.0",
"@sveltejs/kit": "^2.50.2", "@sveltejs/kit": "^2.50.2",
"@sveltejs/vite-plugin-svelte": "^6.2.4", "@sveltejs/vite-plugin-svelte": "^6.2.4",
"@tailwindcss/postcss": "^4.2.1", "@tailwindcss/postcss": "^4.2.1",
"@testing-library/svelte": "^5.3.1", "@testing-library/svelte": "^5.3.1",
"@types/node": "^25.3.3", "@types/node": "^25.3.3",
"@vitest/browser-playwright": "^4.0.18",
"@vitest/coverage-v8": "^4.0.18", "@vitest/coverage-v8": "^4.0.18",
"@vitest/ui": "^4.0.18", "@vitest/ui": "^4.0.18",
"autoprefixer": "^10.4.27", "autoprefixer": "^10.4.27",
"jsdom": "^28.1.0", "jsdom": "^28.1.0",
"playwright": "^1.58.2",
"postcss": "^8.5.8", "postcss": "^8.5.8",
"svelte": "^5.51.0", "storybook": "10.1.11",
"svelte": "5.46.1",
"svelte-adapter-bun": "^1.0.1", "svelte-adapter-bun": "^1.0.1",
"svelte-check": "^4.4.2", "svelte-check": "^4.4.2",
"tailwindcss": "^4.2.1", "tailwindcss": "^4.2.1",
"typescript": "^5.9.3", "typescript": "^5.9.3",
"vite": "^7.3.1", "vite": "^7.3.1",
"vitest": "^4.0.18", "vitest": "^4.0.18"
"storybook": "^10.2.16",
"@storybook/sveltekit": "^10.2.16",
"@storybook/addon-svelte-csf": "^5.0.11",
"@chromatic-com/storybook": "^5.0.1",
"@storybook/addon-vitest": "^10.2.16",
"@storybook/addon-a11y": "^10.2.16",
"@storybook/addon-docs": "^10.2.16",
"playwright": "^1.58.2",
"@vitest/browser-playwright": "^4.0.18"
}, },
"dependencies": { "dependencies": {
"@storybook/builder-vite": "10.1.11",
"@storybook/csf-plugin": "10.1.11",
"@storybook/svelte": "10.1.11",
"@storybook/svelte-vite": "10.1.11",
"clsx": "^2.1.1", "clsx": "^2.1.1",
"tailwind-merge": "^3.5.0" "tailwind-merge": "^3.5.0"
} }

View File

@@ -7,6 +7,12 @@ export default defineConfig({
resolve: { resolve: {
alias: { alias: {
$lib: path.resolve("./src/shared/lib"), $lib: path.resolve("./src/shared/lib"),
$shared: path.resolve("./src/shared"),
$pages: path.resolve("./src/pages"),
$features: path.resolve("./src/features"),
$entities: path.resolve("./src/entities"),
$widgets: path.resolve("./src/widgets"),
"$/*": "./src/*",
}, },
}, },
}); });

4291
yarn.lock Normal file

File diff suppressed because it is too large Load Diff