|
1 | 1 | // For more info, see https://github.com/storybookjs/eslint-plugin-storybook#configuration-flat-config-format |
2 | 2 | import storybook from "eslint-plugin-storybook"; |
| 3 | +import tseslint from 'typescript-eslint'; |
| 4 | +import js from '@eslint/js'; |
| 5 | +import globals from 'globals'; |
| 6 | +import reactHooks from 'eslint-plugin-react-hooks'; |
| 7 | +import reactRefresh from 'eslint-plugin-react-refresh'; |
| 8 | +import { defineConfig, globalIgnores } from 'eslint/config'; |
3 | 9 |
|
4 | | -import js from '@eslint/js' |
5 | | -import globals from 'globals' |
6 | | -import reactHooks from 'eslint-plugin-react-hooks' |
7 | | -import reactRefresh from 'eslint-plugin-react-refresh' |
8 | | -import { defineConfig, globalIgnores } from 'eslint/config' |
9 | | - |
10 | | -export default defineConfig([globalIgnores(['dist']), { |
11 | | - files: ['**/*.{js,jsx}'], |
12 | | - extends: [ |
13 | | - js.configs.recommended, |
14 | | - reactHooks.configs.flat.recommended, |
15 | | - reactRefresh.configs.vite, |
16 | | - ], |
17 | | - languageOptions: { |
18 | | - ecmaVersion: 2020, |
19 | | - globals: globals.browser, |
20 | | - parserOptions: { |
21 | | - ecmaVersion: 'latest', |
22 | | - ecmaFeatures: { jsx: true }, |
23 | | - sourceType: 'module', |
| 10 | +export default defineConfig([ |
| 11 | + globalIgnores(['dist', '.features-gen']), |
| 12 | + // Node/Config files: process etc. |
| 13 | + { |
| 14 | + files: ['vite.config.js', 'vitest.config.ts', 'playwright.config.ts'], |
| 15 | + languageOptions: { globals: { ...globals.node } }, |
| 16 | + }, |
| 17 | + // JS/JSX |
| 18 | + { |
| 19 | + files: ['**/*.{js,jsx}'], |
| 20 | + extends: [ |
| 21 | + js.configs.recommended, |
| 22 | + reactHooks.configs.flat.recommended, |
| 23 | + reactRefresh.configs.vite, |
| 24 | + ], |
| 25 | + languageOptions: { |
| 26 | + ecmaVersion: 2020, |
| 27 | + globals: globals.browser, |
| 28 | + parserOptions: { |
| 29 | + ecmaVersion: 'latest', |
| 30 | + ecmaFeatures: { jsx: true }, |
| 31 | + sourceType: 'module', |
| 32 | + }, |
| 33 | + }, |
| 34 | + rules: { |
| 35 | + 'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }], |
24 | 36 | }, |
25 | 37 | }, |
26 | | - rules: { |
27 | | - 'no-unused-vars': ['error', { varsIgnorePattern: '^[A-Z_]' }], |
| 38 | + // TypeScript/TSX: parser so .stories.tsx and .storybook parse correctly |
| 39 | + { |
| 40 | + files: ['**/*.{ts,tsx}'], |
| 41 | + extends: [ |
| 42 | + js.configs.recommended, |
| 43 | + ...tseslint.configs.recommended, |
| 44 | + reactHooks.configs.flat.recommended, |
| 45 | + reactRefresh.configs.vite, |
| 46 | + ], |
| 47 | + languageOptions: { |
| 48 | + ecmaVersion: 2020, |
| 49 | + globals: { ...globals.browser }, |
| 50 | + parserOptions: { |
| 51 | + ecmaVersion: 'latest', |
| 52 | + ecmaFeatures: { jsx: true }, |
| 53 | + sourceType: 'module', |
| 54 | + }, |
| 55 | + }, |
| 56 | + rules: { |
| 57 | + 'no-unused-vars': 'off', |
| 58 | + '@typescript-eslint/no-unused-vars': ['error', { argsIgnorePattern: '^_', varsIgnorePattern: '^[A-Z_]' }], |
| 59 | + 'no-empty-pattern': 'off', |
| 60 | + '@typescript-eslint/no-require-imports': 'off', |
| 61 | + 'react-refresh/only-export-components': 'off', |
| 62 | + 'react-hooks/set-state-in-effect': 'off', |
| 63 | + }, |
28 | 64 | }, |
29 | | -}, ...storybook.configs["flat/recommended"]]) |
| 65 | + ...storybook.configs['flat/recommended'], |
| 66 | +]); |
0 commit comments