chore: install storybook

This commit is contained in:
Ilia Mashkov
2026-03-24 19:28:20 +03:00
parent c378f7c83a
commit 1f20f11852
5 changed files with 1004 additions and 45 deletions

View File

@@ -1,3 +1,6 @@
// For more info, see https://github.com/storybookjs/eslint-plugin-storybook#configuration-flat-config-format
import storybook from "eslint-plugin-storybook";
import js from '@eslint/js' import js from '@eslint/js'
import globals from 'globals' import globals from 'globals'
import reactHooks from 'eslint-plugin-react-hooks' import reactHooks from 'eslint-plugin-react-hooks'
@@ -5,19 +8,16 @@ import reactRefresh from 'eslint-plugin-react-refresh'
import tseslint from 'typescript-eslint' import tseslint from 'typescript-eslint'
import { defineConfig, globalIgnores } from 'eslint/config' import { defineConfig, globalIgnores } from 'eslint/config'
export default defineConfig([ export default defineConfig([globalIgnores(['dist']), {
globalIgnores(['dist']), files: ['**/*.{ts,tsx}'],
{ extends: [
files: ['**/*.{ts,tsx}'], js.configs.recommended,
extends: [ tseslint.configs.recommended,
js.configs.recommended, reactHooks.configs.flat.recommended,
tseslint.configs.recommended, reactRefresh.configs.vite,
reactHooks.configs.flat.recommended, ],
reactRefresh.configs.vite, languageOptions: {
], ecmaVersion: 2020,
languageOptions: { globals: globals.browser,
ecmaVersion: 2020,
globals: globals.browser,
},
}, },
]) }, ...storybook.configs["flat/recommended"]])

View File

@@ -10,7 +10,9 @@
"preview": "vite preview", "preview": "vite preview",
"test:unit": "vitest", "test:unit": "vitest",
"test:run": "vitest run", "test:run": "vitest run",
"test:coverage": "vitest run --coverage" "test:coverage": "vitest run --coverage",
"storybook": "storybook dev -p 6006",
"build-storybook": "storybook build"
}, },
"dependencies": { "dependencies": {
"ky": "^1.14.3", "ky": "^1.14.3",
@@ -19,8 +21,13 @@
"zustand": "^5.0.12" "zustand": "^5.0.12"
}, },
"devDependencies": { "devDependencies": {
"@chromatic-com/storybook": "^5.0.2",
"@eslint/js": "^9.39.1", "@eslint/js": "^9.39.1",
"@module-federation/vite": "^1.12.3", "@module-federation/vite": "^1.12.3",
"@storybook/addon-a11y": "^10.3.3",
"@storybook/addon-docs": "^10.3.3",
"@storybook/addon-vitest": "^10.3.3",
"@storybook/react-vite": "^10.3.3",
"@testing-library/dom": "^10.4.1", "@testing-library/dom": "^10.4.1",
"@testing-library/jest-dom": "^6.9.1", "@testing-library/jest-dom": "^6.9.1",
"@testing-library/react": "^16.3.2", "@testing-library/react": "^16.3.2",
@@ -29,14 +36,18 @@
"@types/react": "^19.2.7", "@types/react": "^19.2.7",
"@types/react-dom": "^19.2.3", "@types/react-dom": "^19.2.3",
"@vitejs/plugin-react": "^5.1.4", "@vitejs/plugin-react": "^5.1.4",
"@vitest/browser-playwright": "4.1.0",
"@vitest/coverage-v8": "^4.1.0", "@vitest/coverage-v8": "^4.1.0",
"babel-plugin-react-compiler": "^1.0.0", "babel-plugin-react-compiler": "^1.0.0",
"eslint": "^9.39.1", "eslint": "^9.39.1",
"eslint-plugin-react-hooks": "^7.0.1", "eslint-plugin-react-hooks": "^7.0.1",
"eslint-plugin-react-refresh": "^0.4.24", "eslint-plugin-react-refresh": "^0.4.24",
"eslint-plugin-storybook": "^10.3.3",
"globals": "^16.5.0", "globals": "^16.5.0",
"jsdom": "^29.0.0", "jsdom": "^29.0.0",
"msw": "^2.12.11", "msw": "^2.12.11",
"playwright": "^1.58.2",
"storybook": "^10.3.3",
"typescript": "~5.9.3", "typescript": "~5.9.3",
"typescript-eslint": "^8.48.0", "typescript-eslint": "^8.48.0",
"vite": "^7.3.1", "vite": "^7.3.1",
@@ -47,4 +58,4 @@
"public" "public"
] ]
} }
} }

View File

@@ -1,32 +1,59 @@
import { defineConfig } from "vitest/config"; import { defineConfig } from "vitest/config";
import react from "@vitejs/plugin-react"; import react from "@vitejs/plugin-react";
import path from "path"; import path from "path";
import { fileURLToPath } from 'node:url';
import { storybookTest } from '@storybook/addon-vitest/vitest-plugin';
import { playwright } from '@vitest/browser-playwright';
const dirname = typeof __dirname !== 'undefined' ? __dirname : path.dirname(fileURLToPath(import.meta.url));
// More info at: https://storybook.js.org/docs/next/writing-tests/integrations/vitest-addon
export default defineConfig({ export default defineConfig({
plugins: [ plugins: [react({
react({ babel: {
babel: { plugins: [["babel-plugin-react-compiler", {}]]
plugins: [["babel-plugin-react-compiler", {}]], }
}, })],
}),
],
resolve: { resolve: {
alias: { alias: {
shared: path.resolve(__dirname, "src/shared"), shared: path.resolve(__dirname, "src/shared"),
entities: path.resolve(__dirname, "src/entities"), entities: path.resolve(__dirname, "src/entities"),
features: path.resolve(__dirname, "src/features"), features: path.resolve(__dirname, "src/features"),
widgets: path.resolve(__dirname, "src/widgets"), widgets: path.resolve(__dirname, "src/widgets"),
app: path.resolve(__dirname, "src/app"), app: path.resolve(__dirname, "src/app")
}, }
}, },
test: { test: {
globals: true,
environment: "jsdom",
setupFiles: ["./src/shared/config/test/setup.ts"],
coverage: { coverage: {
provider: "v8", provider: "v8",
reporter: ["text", "json", "html"], reporter: ["text", "json", "html"],
exclude: ["node_modules/", "src/test/"], exclude: ["node_modules/", "src/test/"]
}, },
}, projects: [{
}); extends: true,
test: {
globals: true,
environment: "jsdom",
setupFiles: ["./src/shared/config/test/setup.ts"]
}
}, {
extends: true,
plugins: [
// The plugin will run tests for the stories defined in your Storybook config
// See options at: https://storybook.js.org/docs/next/writing-tests/integrations/vitest-addon#storybooktest
storybookTest({
configDir: path.join(dirname, '.storybook')
})],
test: {
name: 'storybook',
browser: {
enabled: true,
headless: true,
provider: playwright({}),
instances: [{
browser: 'chromium'
}]
}
}
}]
}
});

1
vitest.shims.d.ts vendored Normal file
View File

@@ -0,0 +1 @@
/// <reference types="@vitest/browser-playwright" />

946
yarn.lock

File diff suppressed because it is too large Load Diff