@jimmy.codes/eslint-config 3.20.0 → 3.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -43,6 +43,7 @@ export default eslintConfig({
43
43
  jest: false,
44
44
  playwright: false,
45
45
  react: false,
46
+ storybook: false,
46
47
  tanstackQuery: false,
47
48
  testingLibrary: false,
48
49
  typescript: false,
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";var H=Object.create;var d=Object.defineProperty;var U=Object.getOwnPropertyDescriptor;var W=Object.getOwnPropertyNames;var Y=Object.getPrototypeOf,D=Object.prototype.hasOwnProperty;var t=(e,r)=>d(e,"name",{value:r,configurable:!0});var M=(e,r,s,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let a of W(r))!D.call(e,a)&&a!==s&&d(e,a,{get:()=>r[a],enumerable:!(n=U(r,a))||n.enumerable});return e};var o=(e,r,s)=>(s=e!=null?H(Y(e)):{},M(r||!e||!e.__esModule?d(s,"default",{value:e,enumerable:!0}):s,e));var g=require("globals"),p=require("typescript-eslint"),O=require("@eslint-community/eslint-plugin-eslint-comments/configs"),u=require("eslint-plugin-import-x"),E=require("eslint-plugin-n"),K=require("@eslint/js"),C=require("eslint-plugin-perfectionist"),Z=require("eslint-config-prettier"),ee=require("eslint-plugin-regexp"),l=require("local-pkg"),q=require("eslint-plugin-unicorn");function re(e){var r=Object.create(null);return e&&Object.keys(e).forEach(function(s){if(s!=="default"){var n=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(r,s,n.get?n:{enumerable:!0,get:t(function(){return e[s]},"get")})}}),r.default=e,Object.freeze(r)}t(re,"_interopNamespaceDefault");var _=re(ee);const c="?([cm])[jt]s?(x)",te=["**/node_modules","**/dist","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/bun.lockb","**/output","**/coverage","**/temp","**/.temp","**/tmp","**/.tmp","**/.history","**/.vitepress/cache","**/.nuxt","**/.next","**/.vercel","**/.changeset","**/.idea","**/.cache","**/.output","**/.vite-inspect","**/.yarn","**/storybook-static","**/.eslint-config-inspector","**/playwright-report","**/.astro","**/.vinxi","**/app.config.timestamp_*.js","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts","**/vite.config.ts.*.mjs","**/*.gen.*","!.storybook"],se="**/*.?([cm])js",y="**/*.?([cm])jsx",T="**/*.?([cm])tsx",m=[`**/__tests__/**/*.${c}`,`**/*.spec.${c}`,`**/*.test.${c}`,`**/*.bench.${c}`,`**/*.benchmark.${c}`],R=[`**/e2e/**/*.spec.${c}`,`**/e2e/**/*.test.${c}`],j=[...R,`**/cypress/**/*.spec.${c}`,`**/cypress/**/*.test.${c}`],oe="**/*.cjs",ne="**/*.astro",ie=["vi.mock","describe","expect","it"],ae=["@testing-library/react"],i=t(async e=>{const r=await e;return r.default??r},"interopDefault"),ce=t(async()=>{const e=[ne],[r,s,n]=await Promise.all([import("eslint-plugin-astro"),import("astro-eslint-parser"),i(import("eslint-plugin-jsx-a11y"))]);return[{files:e,languageOptions:{globals:{...g.node,Astro:!1,Fragment:!1},parser:s,parserOptions:{extraFileExtensions:[".astro"],parser:p.parser},sourceType:"module"},name:"jimmy.codes/astro",plugins:{astro:r,"jsx-a11y":n},processor:"astro/client-side-ts",rules:{...n.configs.recommended.rules,"astro/missing-client-only-directive-value":"error","astro/no-conflict-set-directives":"error","astro/no-deprecated-astro-canonicalurl":"error","astro/no-deprecated-astro-fetchcontent":"error","astro/no-deprecated-astro-resolve":"error","astro/no-deprecated-getentrybyslug":"error","astro/no-exports-from-components":"off","astro/no-unused-define-vars-in-style":"error","astro/valid-compile":"error"}},{files:e,languageOptions:{parserOptions:p.configs.disableTypeChecked.languageOptions?.parserOptions},name:"jimmy.codes/astro/disable-type-checked",rules:p.configs.disableTypeChecked.rules},{name:"jimmy.codes/astro/imports",settings:{"import-x/core-modules":["astro:content"]}}]},"astroConfig"),le=t(()=>[{files:[oe],languageOptions:{globals:g.commonjs},name:"jimmy.codes/commonjs"}],"commonjsConfig"),pe={...O.recommended.rules,"@eslint-community/eslint-comments/no-unused-disable":"off","@eslint-community/eslint-comments/require-description":"error"},fe=t(()=>[{...O.recommended,name:"jimmy.codes/eslint-comments",rules:pe}],"eslintCommentsConfig"),ue=t(e=>[{ignores:[...te,...e],name:"jimmy.codes/ignores"}],"ignoresConfig"),me={...u.configs.recommended.rules,"import-x/consistent-type-specifier-style":["error","prefer-top-level"],"import-x/extensions":["error","never",{checkTypedImports:!0,svg:"always"}],"import-x/first":"error","import-x/namespace":"off","import-x/newline-after-import":"error","import-x/no-absolute-path":"error","import-x/no-duplicates":"error","import-x/no-empty-named-blocks":"error","import-x/no-named-as-default":"error","import-x/no-named-as-default-member":"error","import-x/no-self-import":"error","import-x/no-unresolved":["error",{ignore:[String.raw`\.svg$`]}],"import-x/no-useless-path-segments":"error"},de={name:"jimmy.codes/imports/typescript",rules:u.configs.typescript.rules,settings:{...u.configs.typescript.settings,"import-x/resolver":{...u.configs.typescript.settings["import-x/resolver"],typescript:!0}}},ge=t(({typescript:e=!1}={})=>[{name:"jimmy.codes/imports",plugins:{"import-x":u,n:E},rules:me},...e?[de]:[]],"importsConfig"),ye={...K.configs.recommended.rules,"array-callback-return":["error",{allowImplicit:!0}],"arrow-body-style":["error","always"],curly:["error","all"],"no-console":"warn","no-self-compare":"error","no-template-curly-in-string":"error","no-unmodified-loop-condition":"error","no-unreachable-loop":"error","no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"no-useless-rename":"error","object-shorthand":"error","prefer-arrow-callback":"error"},je=t(()=>[{linterOptions:{reportUnusedDisableDirectives:!0},name:"jimmy.codes/javascript",rules:ye}],"javascriptConfig"),he={"n/no-process-exit":"off","n/prefer-node-protocol":"error"},xe=t(()=>[{name:"jimmy.codes/node",plugins:{n:E},rules:he}],"nodeConfig"),be={...C.configs["recommended-natural"].rules,"perfectionist/sort-imports":["error",{customGroups:{type:{},value:{}},environment:"node",groups:["side-effect-style","builtin","type","external","internal-type","internal",["parent-type","sibling-type","index-type"],["parent","sibling","index"],"object","style","unknown"],internalPattern:["^~/.*","^@/.*"],order:"asc",type:"natural"}],"perfectionist/sort-modules":"off"},we=t(()=>[{name:"jimmy.codes/perfectionist",plugins:{perfectionist:C},rules:be}],"perfectionistConfig"),ve=t(async()=>({...(await i(import("eslint-plugin-playwright"))).configs["flat/recommended"].rules,"playwright/expect-expect":"error","playwright/max-nested-describe":"error","playwright/no-conditional-expect":"error","playwright/no-conditional-in-test":"error","playwright/no-element-handle":"error","playwright/no-eval":"error","playwright/no-force-option":"error","playwright/no-nested-step":"error","playwright/no-page-pause":"error","playwright/no-skipped-test":"error","playwright/no-useless-await":"error","playwright/no-useless-not":"error","playwright/no-wait-for-selector":"error","playwright/no-wait-for-timeout":"error"}),"playwrightRules"),ke=t(async()=>[{...(await i(import("eslint-plugin-playwright"))).configs["flat/recommended"],files:R,name:"jimmy.codes/playwright",rules:await ve()}],"playwrightConfig"),Pe=t(()=>[{name:"jimmy.codes/prettier",...Z}],"prettierConfig"),Oe=t(e=>e===2?"error":e===1?"warn":"off","toStringSeverity"),L=t((e={})=>Object.fromEntries(Object.entries(e).map(([r,s])=>[r,typeof s=="number"?Oe(s):s])),"normalizeRuleEntries"),Ee=t(async()=>{const[e,r]=await Promise.all([i(import("eslint-plugin-react")),i(import("eslint-plugin-jsx-a11y"))]);return{...r.configs.recommended.rules,...L(e.configs.flat?.recommended?.rules),...L(e.configs.flat?.["jsx-runtime"]?.rules),"react-hooks/exhaustive-deps":"error","react-hooks/rules-of-hooks":"error","react-refresh/only-export-components":["warn",{allowConstantExport:!0}],"react/boolean-prop-naming":"off","react/button-has-type":"error","react/checked-requires-onchange-or-readonly":"error","react/default-props-match-prop-types":"error","react/destructuring-assignment":"off","react/forbid-component-props":"off","react/forbid-dom-props":"off","react/forbid-elements":"off","react/forbid-foreign-prop-types":"off","react/forbid-prop-types":"off","react/forward-ref-uses-ref":"error","react/function-component-definition":"off","react/hook-use-state":"error","react/iframe-missing-sandbox":"error","react/jsx-boolean-value":["error","never"],"react/jsx-curly-brace-presence":"error","react/jsx-filename-extension":"off","react/jsx-fragments":["error","syntax"],"react/jsx-handler-names":"off","react/jsx-max-depth":"off","react/jsx-no-bind":"off","react/jsx-no-constructed-context-values":"error","react/jsx-no-leaked-render":"error","react/jsx-no-literals":"off","react/jsx-no-script-url":"error","react/jsx-no-useless-fragment":"error","react/jsx-one-expression-per-line":"off","react/jsx-pascal-case":["error",{allowNamespace:!0}],"react/jsx-props-no-spread-multi":"off","react/jsx-props-no-spreading":"off","react/jsx-sort-default-props":"off","react/jsx-sort-props":"off","react/no-access-state-in-setstate":"error","react/no-adjacent-inline-elements":"off","react/no-array-index-key":"off","react/no-arrow-function-lifecycle":"error","react/no-danger":"off","react/no-did-mount-set-state":"error","react/no-did-update-set-state":"error","react/no-invalid-html-attribute":"error","react/no-multi-comp":"off","react/no-namespace":"error","react/no-object-type-as-default-prop":"error","react/no-redundant-should-component-update":"error","react/no-set-state":"off","react/no-this-in-sfc":"error","react/no-typos":"error","react/no-unstable-nested-components":"error","react/no-unused-class-component-methods":"error","react/no-unused-prop-types":"error","react/no-unused-state":"error","react/no-will-update-set-state":"error","react/prefer-es6-class":"off","react/prefer-exact-props":"off","react/prefer-read-only-props":"off","react/prefer-stateless-function":"off","react/require-default-props":"off","react/require-optimization":"off","react/self-closing-comp":"error","react/sort-comp":"off","react/sort-default-props":"off","react/sort-prop-types":"off","react/state-in-constructor":"off","react/static-property-placement":"off","react/style-prop-object":"error","react/void-dom-elements-no-children":"error"}},"reactRules"),Ce=t(async()=>{const[e,r,s,n]=await Promise.all([i(import("eslint-plugin-react")),i(import("eslint-plugin-jsx-a11y")),import("eslint-plugin-react-hooks"),import("eslint-plugin-react-refresh")]);return[{files:[y,T],languageOptions:{globals:{...g.browser},parserOptions:{ecmaFeatures:{jsx:!0},jsxPragma:null}},name:"jimmy.codes/react",plugins:{"jsx-a11y":r,react:e,"react-hooks":s,"react-refresh":n},rules:await Ee(),settings:{react:{version:"detect"}}}]},"reactConfig"),qe={..._.configs["flat/recommended"].rules,"regexp/confusing-quantifier":"error","regexp/no-empty-alternative":"error","regexp/no-lazy-ends":"error","regexp/no-potentially-useless-backreference":"error","regexp/no-useless-flag":"error","regexp/optimal-lookaround-quantifier":"error"},_e=t(()=>[{name:"jimmy.codes/regexp",plugins:{regexp:_},rules:qe}],"regexpConfig"),Te=t(async()=>{const e=await i(import("@tanstack/eslint-plugin-query"));return[{files:[y,T],name:"jimmy.codes/react/query",plugins:{"@tanstack/query":e},rules:{"@tanstack/query/exhaustive-deps":"error","@tanstack/query/no-rest-destructuring":"warn","@tanstack/query/stable-query-client":"error"}}]},"tanstackQueryConfig"),S=t(async()=>{const e=await i(import("eslint-plugin-jest"));return{...e.configs["flat/recommended"].rules,...e.configs["flat/style"].rules,"jest/consistent-test-it":["error",{fn:"test",withinDescribe:"it"}],"jest/expect-expect":"error","jest/no-alias-methods":"error","jest/no-commented-out-tests":"error","jest/no-conditional-in-test":"error","jest/no-confusing-set-timeout":"error","jest/no-duplicate-hooks":"error","jest/no-hooks":"off","jest/no-large-snapshots":"off","jest/no-restricted-jest-methods":"off","jest/no-restricted-matchers":"off","jest/no-test-return-statement":"error","jest/no-untyped-mock-factory":"off","jest/prefer-called-with":"error","jest/prefer-comparison-matcher":"error","jest/prefer-each":"error","jest/prefer-equality-matcher":"error","jest/prefer-expect-assertions":"off","jest/prefer-expect-resolves":"error","jest/prefer-hooks-in-order":"error","jest/prefer-hooks-on-top":"error","jest/prefer-lowercase-title":"off","jest/prefer-mock-promise-shorthand":"error","jest/prefer-snapshot-hint":"error","jest/prefer-spy-on":"off","jest/prefer-strict-equal":"error","jest/prefer-todo":"warn","jest/require-hook":"error","jest/require-to-throw-message":"error","jest/require-top-level-describe":"off","jest/unbound-method":"off"}},"jestRules"),Re=t(async()=>({...await S(),"jest/no-deprecated-functions":"off","jest/require-hook":["error",{allowedFunctionCalls:ie}]}),"vitestRules"),Le=t(()=>l.isPackageExists("typescript"),"hasTypescript"),Se=t(()=>l.isPackageExists("react"),"hasReact"),G=t(()=>l.isPackageExists("vitest"),"hasVitest"),A=t(()=>l.isPackageExists("jest"),"hasJest"),Ge=t(()=>G()||A(),"hasTesting"),Ae=t(()=>ae.some(e=>l.isPackageExists(e)),"hasTestingLibrary"),Ie=t(()=>l.isPackageExists("@tanstack/react-query"),"hasReactQuery"),Be=t(()=>l.isPackageExists("astro"),"hasAstro"),Ne=t(()=>l.isPackageExists("@playwright/test"),"hasPlaywright"),$e=t(async({framework:e="vitest"}={},r=!0)=>{const s=r?G():e==="vitest",n=e==="jest"||r&&A(),a=[];if(s){const f=await i(import("eslint-plugin-jest"));a.push({files:m,ignores:j,...f.configs["flat/recommended"],name:"jimmy.codes/vitest",rules:await Re()})}if(n){const f=await i(import("eslint-plugin-jest"));a.push({files:m,ignores:j,...f.configs["flat/recommended"],name:"jimmy.codes/jest",rules:await S()})}return a},"testingConfig"),Fe=t(async()=>{const[e,r]=await Promise.all([import("eslint-plugin-jest-dom"),i(import("eslint-plugin-testing-library"))]);return{...r.configs["flat/react"].rules,...e.configs["flat/recommended"].rules}},"testingLibraryRules"),Je=t(async()=>{const[e,r]=await Promise.all([import("eslint-plugin-jest-dom"),i(import("eslint-plugin-testing-library"))]);return[{files:m,ignores:j,name:"jimmy.codes/testing-library",plugins:{"jest-dom":e,"testing-library":r},rules:await Fe()}]},"testingLibraryConfig"),ze={"@typescript-eslint/consistent-type-exports":["error",{fixMixedExportsWithInlineTypeSpecifier:!1}],"@typescript-eslint/consistent-type-imports":["error",{fixStyle:"separate-type-imports"}],"@typescript-eslint/no-deprecated":"warn","@typescript-eslint/no-misused-promises":["error",{checksVoidReturn:{attributes:!1}}],"@typescript-eslint/no-unused-vars":["error",{args:"all",argsIgnorePattern:"^_",caughtErrors:"all",caughtErrorsIgnorePattern:"^_",destructuredArrayIgnorePattern:"^_",ignoreRestSiblings:!0,varsIgnorePattern:"^_"}],"@typescript-eslint/no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"@typescript-eslint/restrict-template-expressions":["error",{allowNumber:!0}],"no-use-before-define":"off"},Qe=t(e=>[...p.configs.strictTypeChecked,...p.configs.stylisticTypeChecked.filter(r=>r.name==="typescript-eslint/stylistic-type-checked"),{languageOptions:{parserOptions:{...e?.project?{project:e.project}:{projectService:!0},tsconfigRootDir:process.cwd()}},name:"jimmy.codes/typescript",rules:ze},{files:[se,y],...p.configs.disableTypeChecked},{files:m,name:"jimmy.codes/typescript/testing",rules:{"@typescript-eslint/no-unsafe-argument":"off","@typescript-eslint/no-unsafe-assignment":"off"}}],"typescriptConfig"),Ve={...q.configs["flat/recommended"].rules,"unicorn/filename-case":"off","unicorn/import-style":"off","unicorn/no-abusive-eslint-disable":"off","unicorn/no-anonymous-default-export":"off","unicorn/no-array-callback-reference":"off","unicorn/no-array-reduce":"off","unicorn/no-null":"off","unicorn/no-process-exit":"off","unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-node-protocol":"off","unicorn/prevent-abbreviations":"off"},Xe=t(()=>[{...q.configs["flat/recommended"],name:"jimmy.codes/unicorn",rules:Ve}],"unicornConfig"),He=t(e=>typeof e=="object"?e:void 0,"getTypescriptOptions"),Ue=t((e,r)=>typeof e=="object"?e:{framework:r.vitest?"vitest":r.jest?"jest":"vitest",...r.testingLibrary&&{utilities:["testing-library"]}},"getTestingOptions"),We=t(e=>typeof e=="object"?e:{utilities:[]},"getReactOptions"),Ye=t(({utilities:e=[]},r,s)=>r||e.includes("@tanstack/query")||s&&Ie(),"shouldEnableTanstackQuery"),De=t(({utilities:e=[]},r)=>e.includes("testing-library")||r&&Ae(),"shouldEnableTestingLibrary"),Me=t(async({astro:e=!1,autoDetect:r=!0,configs:s=[],ignores:n=[],jest:a=!1,playwright:f=!1,react:h=!1,tanstackQuery:I=!1,testing:x=!1,testingLibrary:B=!1,typescript:b=!1,vitest:w=!1}={},...N)=>{const $=We(h),v=Ue(x,{jest:a,testingLibrary:B,vitest:w}),k=He(b),P=b||!!k||r&&Le(),F=h||r&&Se(),J=x||a||w||r&&Ge(),z=e||r&&Be(),Q=Ye($,I,r),V=De(v,r),X=f||r&&Ne();return[je(),we(),xe(),Xe(),fe(),_e(),ge({typescript:P}),P?Qe(k):[],F?await Ce():[],Q?await Te():[],z?await ce():[],J?await $e(v,r):[],V?await Je():[],X?await ke():[],Pe(),le(),ue(n),s,N].flat()},"eslintConfig");module.exports=Me;
1
+ "use strict";var W=Object.create;var d=Object.defineProperty;var Y=Object.getOwnPropertyDescriptor;var M=Object.getOwnPropertyNames;var D=Object.getPrototypeOf,K=Object.prototype.hasOwnProperty;var t=(e,r)=>d(e,"name",{value:r,configurable:!0});var Z=(e,r,s,n)=>{if(r&&typeof r=="object"||typeof r=="function")for(let a of M(r))!K.call(e,a)&&a!==s&&d(e,a,{get:()=>r[a],enumerable:!(n=Y(r,a))||n.enumerable});return e};var o=(e,r,s)=>(s=e!=null?W(D(e)):{},Z(r||!e||!e.__esModule?d(s,"default",{value:e,enumerable:!0}):s,e));var g=require("globals"),p=require("typescript-eslint"),E=require("@eslint-community/eslint-plugin-eslint-comments/configs"),u=require("eslint-plugin-import-x"),O=require("eslint-plugin-n"),ee=require("@eslint/js"),C=require("eslint-plugin-perfectionist"),re=require("eslint-config-prettier"),te=require("eslint-plugin-regexp"),c=require("local-pkg"),q=require("eslint-plugin-unicorn");function se(e){var r=Object.create(null);return e&&Object.keys(e).forEach(function(s){if(s!=="default"){var n=Object.getOwnPropertyDescriptor(e,s);Object.defineProperty(r,s,n.get?n:{enumerable:!0,get:t(function(){return e[s]},"get")})}}),r.default=e,Object.freeze(r)}t(se,"_interopNamespaceDefault");var _=se(te);const l="?([cm])[jt]s?(x)",oe=["**/node_modules","**/dist","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/bun.lockb","**/output","**/coverage","**/temp","**/.temp","**/tmp","**/.tmp","**/.history","**/.vitepress/cache","**/.nuxt","**/.next","**/.vercel","**/.changeset","**/.idea","**/.cache","**/.output","**/.vite-inspect","**/.yarn","**/storybook-static","**/.eslint-config-inspector","**/playwright-report","**/.astro","**/.vinxi","**/app.config.timestamp_*.js","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts","**/vite.config.ts.*.mjs","**/*.gen.*","!.storybook"],ne="**/*.?([cm])js",y="**/*.?([cm])jsx",T="**/*.?([cm])tsx",m=[`**/__tests__/**/*.${l}`,`**/*.spec.${l}`,`**/*.test.${l}`,`**/*.bench.${l}`,`**/*.benchmark.${l}`],R=[`**/e2e/**/*.spec.${l}`,`**/e2e/**/*.test.${l}`],j=[...R,`**/cypress/**/*.spec.${l}`,`**/cypress/**/*.test.${l}`],ie="**/*.cjs",ae="**/*.astro",ce=["vi.mock","describe","expect","it"],le=["@testing-library/react"],i=t(async e=>{const r=await e;return r.default??r},"interopDefault"),pe=t(async()=>{const e=[ae],[r,s,n]=await Promise.all([import("eslint-plugin-astro"),import("astro-eslint-parser"),i(import("eslint-plugin-jsx-a11y"))]);return[{files:e,languageOptions:{globals:{...g.node,Astro:!1,Fragment:!1},parser:s,parserOptions:{extraFileExtensions:[".astro"],parser:p.parser},sourceType:"module"},name:"jimmy.codes/astro",plugins:{astro:r,"jsx-a11y":n},processor:"astro/client-side-ts",rules:{...n.configs.recommended.rules,"astro/missing-client-only-directive-value":"error","astro/no-conflict-set-directives":"error","astro/no-deprecated-astro-canonicalurl":"error","astro/no-deprecated-astro-fetchcontent":"error","astro/no-deprecated-astro-resolve":"error","astro/no-deprecated-getentrybyslug":"error","astro/no-exports-from-components":"off","astro/no-unused-define-vars-in-style":"error","astro/valid-compile":"error"}},{files:e,languageOptions:{parserOptions:p.configs.disableTypeChecked.languageOptions?.parserOptions},name:"jimmy.codes/astro/disable-type-checked",rules:p.configs.disableTypeChecked.rules},{name:"jimmy.codes/astro/imports",settings:{"import-x/core-modules":["astro:content"]}}]},"astroConfig"),fe=t(()=>[{files:[ie],languageOptions:{globals:g.commonjs},name:"jimmy.codes/commonjs"}],"commonjsConfig"),ue={...E.recommended.rules,"@eslint-community/eslint-comments/no-unused-disable":"off","@eslint-community/eslint-comments/require-description":"error"},me=t(()=>[{...E.recommended,name:"jimmy.codes/eslint-comments",rules:ue}],"eslintCommentsConfig"),de=t(e=>[{ignores:[...oe,...e],name:"jimmy.codes/ignores"}],"ignoresConfig"),ge={...u.configs.recommended.rules,"import-x/consistent-type-specifier-style":["error","prefer-top-level"],"import-x/extensions":["error","never",{checkTypedImports:!0,svg:"always"}],"import-x/first":"error","import-x/namespace":"off","import-x/newline-after-import":"error","import-x/no-absolute-path":"error","import-x/no-duplicates":"error","import-x/no-empty-named-blocks":"error","import-x/no-named-as-default":"error","import-x/no-named-as-default-member":"error","import-x/no-self-import":"error","import-x/no-unresolved":["error",{ignore:[String.raw`\.svg$`]}],"import-x/no-useless-path-segments":"error"},ye={name:"jimmy.codes/imports/typescript",rules:u.configs.typescript.rules,settings:{...u.configs.typescript.settings,"import-x/resolver":{...u.configs.typescript.settings["import-x/resolver"],typescript:!0}}},je=t(({typescript:e=!1}={})=>[{name:"jimmy.codes/imports",plugins:{"import-x":u,n:O},rules:ge},...e?[ye]:[]],"importsConfig"),xe={...ee.configs.recommended.rules,"array-callback-return":["error",{allowImplicit:!0}],"arrow-body-style":["error","always"],curly:["error","all"],"no-console":"warn","no-self-compare":"error","no-template-curly-in-string":"error","no-unmodified-loop-condition":"error","no-unreachable-loop":"error","no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"no-useless-rename":"error","object-shorthand":"error","prefer-arrow-callback":"error"},he=t(()=>[{linterOptions:{reportUnusedDisableDirectives:!0},name:"jimmy.codes/javascript",rules:xe}],"javascriptConfig"),be={"n/no-process-exit":"off","n/prefer-node-protocol":"error"},we=t(()=>[{name:"jimmy.codes/node",plugins:{n:O},rules:be}],"nodeConfig"),ve={...C.configs["recommended-natural"].rules,"perfectionist/sort-imports":["error",{customGroups:{type:{},value:{}},environment:"node",groups:["side-effect-style","builtin","type","external","internal-type","internal",["parent-type","sibling-type","index-type"],["parent","sibling","index"],"object","style","unknown"],internalPattern:["^~/.*","^@/.*"],order:"asc",type:"natural"}],"perfectionist/sort-modules":"off"},ke=t(()=>[{name:"jimmy.codes/perfectionist",plugins:{perfectionist:C},rules:ve}],"perfectionistConfig"),Pe=t(async()=>({...(await i(import("eslint-plugin-playwright"))).configs["flat/recommended"].rules,"playwright/expect-expect":"error","playwright/max-nested-describe":"error","playwright/no-conditional-expect":"error","playwright/no-conditional-in-test":"error","playwright/no-element-handle":"error","playwright/no-eval":"error","playwright/no-force-option":"error","playwright/no-nested-step":"error","playwright/no-page-pause":"error","playwright/no-skipped-test":"error","playwright/no-useless-await":"error","playwright/no-useless-not":"error","playwright/no-wait-for-selector":"error","playwright/no-wait-for-timeout":"error"}),"playwrightRules"),Ee=t(async()=>[{...(await i(import("eslint-plugin-playwright"))).configs["flat/recommended"],files:R,name:"jimmy.codes/playwright",rules:await Pe()}],"playwrightConfig"),Oe=t(()=>[{name:"jimmy.codes/prettier",...re}],"prettierConfig"),Ce=t(e=>e===2?"error":e===1?"warn":"off","toStringSeverity"),L=t((e={})=>Object.fromEntries(Object.entries(e).map(([r,s])=>[r,typeof s=="number"?Ce(s):s])),"normalizeRuleEntries"),qe=t(async()=>{const[e,r]=await Promise.all([i(import("eslint-plugin-react")),i(import("eslint-plugin-jsx-a11y"))]);return{...r.configs.recommended.rules,...L(e.configs.flat?.recommended?.rules),...L(e.configs.flat?.["jsx-runtime"]?.rules),"react-compiler/react-compiler":"error","react-hooks/exhaustive-deps":"error","react-hooks/rules-of-hooks":"error","react-refresh/only-export-components":["warn",{allowConstantExport:!0}],"react/boolean-prop-naming":"off","react/button-has-type":"error","react/checked-requires-onchange-or-readonly":"error","react/default-props-match-prop-types":"error","react/destructuring-assignment":"off","react/forbid-component-props":"off","react/forbid-dom-props":"off","react/forbid-elements":"off","react/forbid-foreign-prop-types":"off","react/forbid-prop-types":"off","react/forward-ref-uses-ref":"error","react/function-component-definition":"off","react/hook-use-state":"error","react/iframe-missing-sandbox":"error","react/jsx-boolean-value":["error","never"],"react/jsx-curly-brace-presence":"error","react/jsx-filename-extension":"off","react/jsx-fragments":["error","syntax"],"react/jsx-handler-names":"off","react/jsx-max-depth":"off","react/jsx-no-bind":"off","react/jsx-no-constructed-context-values":"error","react/jsx-no-leaked-render":"error","react/jsx-no-literals":"off","react/jsx-no-script-url":"error","react/jsx-no-useless-fragment":"error","react/jsx-one-expression-per-line":"off","react/jsx-pascal-case":["error",{allowNamespace:!0}],"react/jsx-props-no-spread-multi":"off","react/jsx-props-no-spreading":"off","react/jsx-sort-default-props":"off","react/jsx-sort-props":"off","react/no-access-state-in-setstate":"error","react/no-adjacent-inline-elements":"off","react/no-array-index-key":"off","react/no-arrow-function-lifecycle":"error","react/no-danger":"off","react/no-did-mount-set-state":"error","react/no-did-update-set-state":"error","react/no-invalid-html-attribute":"error","react/no-multi-comp":"off","react/no-namespace":"error","react/no-object-type-as-default-prop":"error","react/no-redundant-should-component-update":"error","react/no-set-state":"off","react/no-this-in-sfc":"error","react/no-typos":"error","react/no-unstable-nested-components":"error","react/no-unused-class-component-methods":"error","react/no-unused-prop-types":"error","react/no-unused-state":"error","react/no-will-update-set-state":"error","react/prefer-es6-class":"off","react/prefer-exact-props":"off","react/prefer-read-only-props":"off","react/prefer-stateless-function":"off","react/require-default-props":"off","react/require-optimization":"off","react/self-closing-comp":"error","react/sort-comp":"off","react/sort-default-props":"off","react/sort-prop-types":"off","react/state-in-constructor":"off","react/static-property-placement":"off","react/style-prop-object":"error","react/void-dom-elements-no-children":"error"}},"reactRules"),_e=t(async()=>{const[e,r,s,n,a]=await Promise.all([i(import("eslint-plugin-react")),i(import("eslint-plugin-jsx-a11y")),import("eslint-plugin-react-hooks"),import("eslint-plugin-react-refresh"),i(import("eslint-plugin-react-compiler"))]);return[{files:[y,T],languageOptions:{globals:{...g.browser},parserOptions:{ecmaFeatures:{jsx:!0},jsxPragma:null}},name:"jimmy.codes/react",plugins:{"jsx-a11y":r,react:e,"react-compiler":a,"react-hooks":s,"react-refresh":n},rules:await qe(),settings:{react:{version:"detect"}}}]},"reactConfig"),Te={..._.configs["flat/recommended"].rules,"regexp/confusing-quantifier":"error","regexp/no-empty-alternative":"error","regexp/no-lazy-ends":"error","regexp/no-potentially-useless-backreference":"error","regexp/no-useless-flag":"error","regexp/optimal-lookaround-quantifier":"error"},Re=t(()=>[{name:"jimmy.codes/regexp",plugins:{regexp:_},rules:Te}],"regexpConfig"),Le=t((e={})=>Object.fromEntries(Object.entries(e).map(([r,s])=>[r,s==="warn"?"error":s])),"warningAsErrors"),Se=t(async()=>{const{configs:e}=await i(import("eslint-plugin-storybook")),[r,s,n]=e["flat/recommended"];return[{name:"jimmy.codes/storybook/setup",plugins:r?.plugins},{files:s?.files,name:"jimmy.codes/storybook/stories-rules",rules:{...Le(s?.rules),"import-x/no-anonymous-default-export":"off","unicorn/no-anonymous-default-export":"off"}},{files:n?.files,name:"jimmy.codes/storybook/main-rules",rules:{...n?.rules}}]},"storybookConfig"),Ae=t(async()=>{const e=await i(import("@tanstack/eslint-plugin-query"));return[{files:[y,T],name:"jimmy.codes/react/query",plugins:{"@tanstack/query":e},rules:{"@tanstack/query/exhaustive-deps":"error","@tanstack/query/no-rest-destructuring":"warn","@tanstack/query/stable-query-client":"error"}}]},"tanstackQueryConfig"),S=t(async()=>{const e=await i(import("eslint-plugin-jest"));return{...e.configs["flat/recommended"].rules,...e.configs["flat/style"].rules,"jest/consistent-test-it":["error",{fn:"test",withinDescribe:"it"}],"jest/expect-expect":"error","jest/no-alias-methods":"error","jest/no-commented-out-tests":"error","jest/no-conditional-in-test":"error","jest/no-confusing-set-timeout":"error","jest/no-duplicate-hooks":"error","jest/no-hooks":"off","jest/no-large-snapshots":"off","jest/no-restricted-jest-methods":"off","jest/no-restricted-matchers":"off","jest/no-test-return-statement":"error","jest/no-untyped-mock-factory":"off","jest/prefer-called-with":"error","jest/prefer-comparison-matcher":"error","jest/prefer-each":"error","jest/prefer-equality-matcher":"error","jest/prefer-expect-assertions":"off","jest/prefer-expect-resolves":"error","jest/prefer-hooks-in-order":"error","jest/prefer-hooks-on-top":"error","jest/prefer-lowercase-title":"off","jest/prefer-mock-promise-shorthand":"error","jest/prefer-snapshot-hint":"error","jest/prefer-spy-on":"off","jest/prefer-strict-equal":"error","jest/prefer-todo":"warn","jest/require-hook":"error","jest/require-to-throw-message":"error","jest/require-top-level-describe":"off","jest/unbound-method":"off"}},"jestRules"),Ge=t(async()=>({...await S(),"jest/no-deprecated-functions":"off","jest/require-hook":["error",{allowedFunctionCalls:ce}]}),"vitestRules"),Ie=t(()=>c.isPackageExists("typescript"),"hasTypescript"),Be=t(()=>c.isPackageExists("react"),"hasReact"),A=t(()=>c.isPackageExists("vitest"),"hasVitest"),G=t(()=>c.isPackageExists("jest"),"hasJest"),Ne=t(()=>A()||G(),"hasTesting"),$e=t(()=>le.some(e=>c.isPackageExists(e)),"hasTestingLibrary"),Fe=t(()=>c.isPackageExists("@tanstack/react-query"),"hasReactQuery"),Je=t(()=>c.isPackageExists("astro"),"hasAstro"),ze=t(()=>c.isPackageExists("@playwright/test"),"hasPlaywright"),Qe=t(()=>c.isPackageExists("storybook"),"hasStorybook"),Ve=t(async({framework:e="vitest"}={},r=!0)=>{const s=r?A():e==="vitest",n=e==="jest"||r&&G(),a=[];if(s){const f=await i(import("eslint-plugin-jest"));a.push({files:m,ignores:j,...f.configs["flat/recommended"],name:"jimmy.codes/vitest",rules:await Ge()})}if(n){const f=await i(import("eslint-plugin-jest"));a.push({files:m,ignores:j,...f.configs["flat/recommended"],name:"jimmy.codes/jest",rules:await S()})}return a},"testingConfig"),Xe=t(async()=>{const[e,r]=await Promise.all([import("eslint-plugin-jest-dom"),i(import("eslint-plugin-testing-library"))]);return{...r.configs["flat/react"].rules,...e.configs["flat/recommended"].rules}},"testingLibraryRules"),He=t(async()=>{const[e,r]=await Promise.all([import("eslint-plugin-jest-dom"),i(import("eslint-plugin-testing-library"))]);return[{files:m,ignores:j,name:"jimmy.codes/testing-library",plugins:{"jest-dom":e,"testing-library":r},rules:await Xe()}]},"testingLibraryConfig"),Ue={"@typescript-eslint/consistent-type-exports":["error",{fixMixedExportsWithInlineTypeSpecifier:!1}],"@typescript-eslint/consistent-type-imports":["error",{fixStyle:"separate-type-imports"}],"@typescript-eslint/no-deprecated":"warn","@typescript-eslint/no-misused-promises":["error",{checksVoidReturn:{attributes:!1}}],"@typescript-eslint/no-unused-vars":["error",{args:"all",argsIgnorePattern:"^_",caughtErrors:"all",caughtErrorsIgnorePattern:"^_",destructuredArrayIgnorePattern:"^_",ignoreRestSiblings:!0,varsIgnorePattern:"^_"}],"@typescript-eslint/no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"@typescript-eslint/restrict-template-expressions":["error",{allowNumber:!0}],"no-use-before-define":"off"},We=t(e=>[...p.configs.strictTypeChecked,...p.configs.stylisticTypeChecked.filter(r=>r.name==="typescript-eslint/stylistic-type-checked"),{languageOptions:{parserOptions:{...e?.project?{project:e.project}:{projectService:!0},tsconfigRootDir:process.cwd()}},name:"jimmy.codes/typescript",rules:Ue},{files:[ne,y],...p.configs.disableTypeChecked},{files:m,name:"jimmy.codes/typescript/testing",rules:{"@typescript-eslint/no-unsafe-argument":"off","@typescript-eslint/no-unsafe-assignment":"off"}}],"typescriptConfig"),Ye={...q.configs["flat/recommended"].rules,"unicorn/filename-case":"off","unicorn/import-style":"off","unicorn/no-abusive-eslint-disable":"off","unicorn/no-anonymous-default-export":"off","unicorn/no-array-callback-reference":"off","unicorn/no-array-reduce":"off","unicorn/no-null":"off","unicorn/no-process-exit":"off","unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-node-protocol":"off","unicorn/prevent-abbreviations":"off"},Me=t(()=>[{...q.configs["flat/recommended"],name:"jimmy.codes/unicorn",rules:Ye}],"unicornConfig"),De=t(e=>typeof e=="object"?e:void 0,"getTypescriptOptions"),Ke=t((e,r)=>typeof e=="object"?e:{framework:r.vitest?"vitest":r.jest?"jest":"vitest",...r.testingLibrary&&{utilities:["testing-library"]}},"getTestingOptions"),Ze=t(e=>typeof e=="object"?e:{utilities:[]},"getReactOptions"),er=t(({utilities:e=[]},r,s)=>r||e.includes("@tanstack/query")||s&&Fe(),"shouldEnableTanstackQuery"),rr=t(({utilities:e=[]},r)=>e.includes("testing-library")||r&&$e(),"shouldEnableTestingLibrary"),tr=t(async({astro:e=!1,autoDetect:r=!0,configs:s=[],ignores:n=[],jest:a=!1,playwright:f=!1,react:x=!1,storybook:I=!1,tanstackQuery:B=!1,testing:h=!1,testingLibrary:N=!1,typescript:b=!1,vitest:w=!1}={},...$)=>{const F=Ze(x),v=Ke(h,{jest:a,testingLibrary:N,vitest:w}),k=De(b),P=b||!!k||r&&Ie(),J=x||r&&Be(),z=h||a||w||r&&Ne(),Q=e||r&&Je(),V=er(F,B,r),X=rr(v,r),H=f||r&&ze(),U=I||r&&Qe();return[he(),ke(),we(),Me(),me(),Re(),je({typescript:P}),P?We(k):[],J?await _e():[],V?await Ae():[],Q?await pe():[],z?await Ve(v,r):[],X?await He():[],H?await Ee():[],U?await Se():[],Oe(),fe(),de(n),s,$].flat()},"eslintConfig");module.exports=tr;
package/dist/index.d.cts CHANGED
@@ -3714,6 +3714,10 @@ interface RuleOptions {
3714
3714
  * @see https://eslint.org/docs/latest/rules/radix
3715
3715
  */
3716
3716
  'radix'?: Linter.RuleEntry<Radix>
3717
+ /**
3718
+ * Surfaces diagnostics from React Forget
3719
+ */
3720
+ 'react-compiler/react-compiler'?: Linter.RuleEntry<ReactCompilerReactCompiler>
3717
3721
  /**
3718
3722
  * verifies the list of dependencies for Hooks like useEffect and similar
3719
3723
  * @see https://github.com/facebook/react/issues/14920
@@ -4747,6 +4751,76 @@ interface RuleOptions {
4747
4751
  * @deprecated
4748
4752
  */
4749
4753
  'spaced-comment'?: Linter.RuleEntry<SpacedComment>
4754
+ /**
4755
+ * Interactions should be awaited
4756
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/await-interactions.md
4757
+ */
4758
+ 'storybook/await-interactions'?: Linter.RuleEntry<[]>
4759
+ /**
4760
+ * Pass a context when invoking play function of another story
4761
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/context-in-play-function.md
4762
+ */
4763
+ 'storybook/context-in-play-function'?: Linter.RuleEntry<[]>
4764
+ /**
4765
+ * The component property should be set
4766
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/csf-component.md
4767
+ */
4768
+ 'storybook/csf-component'?: Linter.RuleEntry<[]>
4769
+ /**
4770
+ * Story files should have a default export
4771
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/default-exports.md
4772
+ */
4773
+ 'storybook/default-exports'?: Linter.RuleEntry<[]>
4774
+ /**
4775
+ * Deprecated hierarchy separator in title property
4776
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/hierarchy-separator.md
4777
+ */
4778
+ 'storybook/hierarchy-separator'?: Linter.RuleEntry<[]>
4779
+ /**
4780
+ * Meta should only have inline properties
4781
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/meta-inline-properties.md
4782
+ */
4783
+ 'storybook/meta-inline-properties'?: Linter.RuleEntry<StorybookMetaInlineProperties>
4784
+ /**
4785
+ * A story should not have a redundant name property
4786
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-redundant-story-name.md
4787
+ */
4788
+ 'storybook/no-redundant-story-name'?: Linter.RuleEntry<[]>
4789
+ /**
4790
+ * storiesOf is deprecated and should not be used
4791
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-stories-of.md
4792
+ */
4793
+ 'storybook/no-stories-of'?: Linter.RuleEntry<[]>
4794
+ /**
4795
+ * Do not define a title in meta
4796
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-title-property-in-meta.md
4797
+ */
4798
+ 'storybook/no-title-property-in-meta'?: Linter.RuleEntry<[]>
4799
+ /**
4800
+ * This rule identifies storybook addons that are invalid because they are either not installed or contain a typo in their name.
4801
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-uninstalled-addons.md
4802
+ */
4803
+ 'storybook/no-uninstalled-addons'?: Linter.RuleEntry<StorybookNoUninstalledAddons>
4804
+ /**
4805
+ * Stories should use PascalCase
4806
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/prefer-pascal-case.md
4807
+ */
4808
+ 'storybook/prefer-pascal-case'?: Linter.RuleEntry<[]>
4809
+ /**
4810
+ * A story file must contain at least one story export
4811
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/story-exports.md
4812
+ */
4813
+ 'storybook/story-exports'?: Linter.RuleEntry<[]>
4814
+ /**
4815
+ * Use expect from `@storybook/test` or `@storybook/jest`
4816
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/use-storybook-expect.md
4817
+ */
4818
+ 'storybook/use-storybook-expect'?: Linter.RuleEntry<[]>
4819
+ /**
4820
+ * Do not use testing-library directly on stories
4821
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/use-storybook-testing-library.md
4822
+ */
4823
+ 'storybook/use-storybook-testing-library'?: Linter.RuleEntry<[]>
4750
4824
  /**
4751
4825
  * Require or disallow strict mode directives
4752
4826
  * @see https://eslint.org/docs/latest/rules/strict
@@ -9729,6 +9803,10 @@ type Quotes = []|[("single" | "double" | "backtick")]|[("single" | "double" | "b
9729
9803
  })]
9730
9804
  // ----- radix -----
9731
9805
  type Radix = []|[("always" | "as-needed")]
9806
+ // ----- react-compiler/react-compiler -----
9807
+ type ReactCompilerReactCompiler = []|[{
9808
+ [k: string]: unknown | undefined
9809
+ }]
9732
9810
  // ----- react-hooks/exhaustive-deps -----
9733
9811
  type ReactHooksExhaustiveDeps = []|[{
9734
9812
  additionalHooks?: string
@@ -10408,6 +10486,16 @@ type SpacedComment = []|[("always" | "never")]|[("always" | "never"), {
10408
10486
  balanced?: boolean
10409
10487
  }
10410
10488
  }]
10489
+ // ----- storybook/meta-inline-properties -----
10490
+ type StorybookMetaInlineProperties = []|[{
10491
+ csfVersion?: number
10492
+ }]
10493
+ // ----- storybook/no-uninstalled-addons -----
10494
+ type StorybookNoUninstalledAddons = []|[{
10495
+ packageJsonLocation?: string
10496
+ ignore?: string[]
10497
+ [k: string]: unknown | undefined
10498
+ }]
10411
10499
  // ----- strict -----
10412
10500
  type Strict = []|[("never" | "global" | "function" | "safe")]
10413
10501
  // ----- switch-colon-spacing -----
@@ -10792,6 +10880,11 @@ interface Options {
10792
10880
  * @default false
10793
10881
  */
10794
10882
  react?: boolean | ReactOptions;
10883
+ /**
10884
+ * Are Storybook rules enabled?
10885
+ * @default false
10886
+ */
10887
+ storybook?: boolean;
10795
10888
  /**
10796
10889
  * Are Tanstack Query rules enabled?
10797
10890
  * @default false
@@ -10820,7 +10913,7 @@ interface Options {
10820
10913
  vitest?: boolean;
10821
10914
  }
10822
10915
 
10823
- declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwright, react, tanstackQuery, testing, testingLibrary, typescript, vitest, }?: Options, ...moreConfigs: Linter.Config[] | TypedConfigItem[]) => Promise<(TypedConfigItem | Linter.Config<Linter.RulesRecord> | _typescript_eslint_utils_ts_eslint.FlatConfig.Config | {
10916
+ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwright, react, storybook, tanstackQuery, testing, testingLibrary, typescript, vitest, }?: Options, ...moreConfigs: Linter.Config[] | TypedConfigItem[]) => Promise<(TypedConfigItem | Linter.Config<Linter.RulesRecord> | _typescript_eslint_utils_ts_eslint.FlatConfig.Config | {
10824
10917
  files: string[];
10825
10918
  languageOptions: {
10826
10919
  globals: {
@@ -13043,6 +13136,7 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13043
13136
  flat?: Record<string, eslint_plugin_react.ReactFlatConfig>;
13044
13137
  };
13045
13138
  };
13139
+ "react-compiler": eslint.ESLint.Plugin;
13046
13140
  "react-hooks": {
13047
13141
  default: {
13048
13142
  configs: {
@@ -13072,6 +13166,7 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13072
13166
  "react-refresh": typeof eslint_plugin_react_refresh;
13073
13167
  };
13074
13168
  rules: {
13169
+ "react-compiler/react-compiler": "error";
13075
13170
  "react-hooks/exhaustive-deps": "error";
13076
13171
  "react-hooks/rules-of-hooks": "error";
13077
13172
  "react-refresh/only-export-components": ["warn", {
@@ -13164,6 +13259,26 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13164
13259
  "regexp/no-useless-flag": "error";
13165
13260
  "regexp/optimal-lookaround-quantifier": "error";
13166
13261
  };
13262
+ } | {
13263
+ name: string;
13264
+ plugins: {
13265
+ readonly storybook: any;
13266
+ } | undefined;
13267
+ files?: undefined;
13268
+ rules?: undefined;
13269
+ } | {
13270
+ files: string[] | undefined;
13271
+ name: string;
13272
+ rules: {
13273
+ "import-x/no-anonymous-default-export": "off";
13274
+ "unicorn/no-anonymous-default-export": "off";
13275
+ };
13276
+ plugins?: undefined;
13277
+ } | {
13278
+ files: string[] | undefined;
13279
+ name: string;
13280
+ rules: {};
13281
+ plugins?: undefined;
13167
13282
  } | {
13168
13283
  files: string[];
13169
13284
  name: string;
package/dist/index.d.mts CHANGED
@@ -3714,6 +3714,10 @@ interface RuleOptions {
3714
3714
  * @see https://eslint.org/docs/latest/rules/radix
3715
3715
  */
3716
3716
  'radix'?: Linter.RuleEntry<Radix>
3717
+ /**
3718
+ * Surfaces diagnostics from React Forget
3719
+ */
3720
+ 'react-compiler/react-compiler'?: Linter.RuleEntry<ReactCompilerReactCompiler>
3717
3721
  /**
3718
3722
  * verifies the list of dependencies for Hooks like useEffect and similar
3719
3723
  * @see https://github.com/facebook/react/issues/14920
@@ -4747,6 +4751,76 @@ interface RuleOptions {
4747
4751
  * @deprecated
4748
4752
  */
4749
4753
  'spaced-comment'?: Linter.RuleEntry<SpacedComment>
4754
+ /**
4755
+ * Interactions should be awaited
4756
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/await-interactions.md
4757
+ */
4758
+ 'storybook/await-interactions'?: Linter.RuleEntry<[]>
4759
+ /**
4760
+ * Pass a context when invoking play function of another story
4761
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/context-in-play-function.md
4762
+ */
4763
+ 'storybook/context-in-play-function'?: Linter.RuleEntry<[]>
4764
+ /**
4765
+ * The component property should be set
4766
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/csf-component.md
4767
+ */
4768
+ 'storybook/csf-component'?: Linter.RuleEntry<[]>
4769
+ /**
4770
+ * Story files should have a default export
4771
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/default-exports.md
4772
+ */
4773
+ 'storybook/default-exports'?: Linter.RuleEntry<[]>
4774
+ /**
4775
+ * Deprecated hierarchy separator in title property
4776
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/hierarchy-separator.md
4777
+ */
4778
+ 'storybook/hierarchy-separator'?: Linter.RuleEntry<[]>
4779
+ /**
4780
+ * Meta should only have inline properties
4781
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/meta-inline-properties.md
4782
+ */
4783
+ 'storybook/meta-inline-properties'?: Linter.RuleEntry<StorybookMetaInlineProperties>
4784
+ /**
4785
+ * A story should not have a redundant name property
4786
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-redundant-story-name.md
4787
+ */
4788
+ 'storybook/no-redundant-story-name'?: Linter.RuleEntry<[]>
4789
+ /**
4790
+ * storiesOf is deprecated and should not be used
4791
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-stories-of.md
4792
+ */
4793
+ 'storybook/no-stories-of'?: Linter.RuleEntry<[]>
4794
+ /**
4795
+ * Do not define a title in meta
4796
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-title-property-in-meta.md
4797
+ */
4798
+ 'storybook/no-title-property-in-meta'?: Linter.RuleEntry<[]>
4799
+ /**
4800
+ * This rule identifies storybook addons that are invalid because they are either not installed or contain a typo in their name.
4801
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/no-uninstalled-addons.md
4802
+ */
4803
+ 'storybook/no-uninstalled-addons'?: Linter.RuleEntry<StorybookNoUninstalledAddons>
4804
+ /**
4805
+ * Stories should use PascalCase
4806
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/prefer-pascal-case.md
4807
+ */
4808
+ 'storybook/prefer-pascal-case'?: Linter.RuleEntry<[]>
4809
+ /**
4810
+ * A story file must contain at least one story export
4811
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/story-exports.md
4812
+ */
4813
+ 'storybook/story-exports'?: Linter.RuleEntry<[]>
4814
+ /**
4815
+ * Use expect from `@storybook/test` or `@storybook/jest`
4816
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/use-storybook-expect.md
4817
+ */
4818
+ 'storybook/use-storybook-expect'?: Linter.RuleEntry<[]>
4819
+ /**
4820
+ * Do not use testing-library directly on stories
4821
+ * @see https://github.com/storybookjs/eslint-plugin-storybook/blob/main/docs/rules/use-storybook-testing-library.md
4822
+ */
4823
+ 'storybook/use-storybook-testing-library'?: Linter.RuleEntry<[]>
4750
4824
  /**
4751
4825
  * Require or disallow strict mode directives
4752
4826
  * @see https://eslint.org/docs/latest/rules/strict
@@ -9729,6 +9803,10 @@ type Quotes = []|[("single" | "double" | "backtick")]|[("single" | "double" | "b
9729
9803
  })]
9730
9804
  // ----- radix -----
9731
9805
  type Radix = []|[("always" | "as-needed")]
9806
+ // ----- react-compiler/react-compiler -----
9807
+ type ReactCompilerReactCompiler = []|[{
9808
+ [k: string]: unknown | undefined
9809
+ }]
9732
9810
  // ----- react-hooks/exhaustive-deps -----
9733
9811
  type ReactHooksExhaustiveDeps = []|[{
9734
9812
  additionalHooks?: string
@@ -10408,6 +10486,16 @@ type SpacedComment = []|[("always" | "never")]|[("always" | "never"), {
10408
10486
  balanced?: boolean
10409
10487
  }
10410
10488
  }]
10489
+ // ----- storybook/meta-inline-properties -----
10490
+ type StorybookMetaInlineProperties = []|[{
10491
+ csfVersion?: number
10492
+ }]
10493
+ // ----- storybook/no-uninstalled-addons -----
10494
+ type StorybookNoUninstalledAddons = []|[{
10495
+ packageJsonLocation?: string
10496
+ ignore?: string[]
10497
+ [k: string]: unknown | undefined
10498
+ }]
10411
10499
  // ----- strict -----
10412
10500
  type Strict = []|[("never" | "global" | "function" | "safe")]
10413
10501
  // ----- switch-colon-spacing -----
@@ -10792,6 +10880,11 @@ interface Options {
10792
10880
  * @default false
10793
10881
  */
10794
10882
  react?: boolean | ReactOptions;
10883
+ /**
10884
+ * Are Storybook rules enabled?
10885
+ * @default false
10886
+ */
10887
+ storybook?: boolean;
10795
10888
  /**
10796
10889
  * Are Tanstack Query rules enabled?
10797
10890
  * @default false
@@ -10820,7 +10913,7 @@ interface Options {
10820
10913
  vitest?: boolean;
10821
10914
  }
10822
10915
 
10823
- declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwright, react, tanstackQuery, testing, testingLibrary, typescript, vitest, }?: Options, ...moreConfigs: Linter.Config[] | TypedConfigItem[]) => Promise<(TypedConfigItem | Linter.Config<Linter.RulesRecord> | _typescript_eslint_utils_ts_eslint.FlatConfig.Config | {
10916
+ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwright, react, storybook, tanstackQuery, testing, testingLibrary, typescript, vitest, }?: Options, ...moreConfigs: Linter.Config[] | TypedConfigItem[]) => Promise<(TypedConfigItem | Linter.Config<Linter.RulesRecord> | _typescript_eslint_utils_ts_eslint.FlatConfig.Config | {
10824
10917
  files: string[];
10825
10918
  languageOptions: {
10826
10919
  globals: {
@@ -13043,6 +13136,7 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13043
13136
  flat?: Record<string, eslint_plugin_react.ReactFlatConfig>;
13044
13137
  };
13045
13138
  };
13139
+ "react-compiler": eslint.ESLint.Plugin;
13046
13140
  "react-hooks": {
13047
13141
  default: {
13048
13142
  configs: {
@@ -13072,6 +13166,7 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13072
13166
  "react-refresh": typeof eslint_plugin_react_refresh;
13073
13167
  };
13074
13168
  rules: {
13169
+ "react-compiler/react-compiler": "error";
13075
13170
  "react-hooks/exhaustive-deps": "error";
13076
13171
  "react-hooks/rules-of-hooks": "error";
13077
13172
  "react-refresh/only-export-components": ["warn", {
@@ -13164,6 +13259,26 @@ declare const eslintConfig: ({ astro, autoDetect, configs, ignores, jest, playwr
13164
13259
  "regexp/no-useless-flag": "error";
13165
13260
  "regexp/optimal-lookaround-quantifier": "error";
13166
13261
  };
13262
+ } | {
13263
+ name: string;
13264
+ plugins: {
13265
+ readonly storybook: any;
13266
+ } | undefined;
13267
+ files?: undefined;
13268
+ rules?: undefined;
13269
+ } | {
13270
+ files: string[] | undefined;
13271
+ name: string;
13272
+ rules: {
13273
+ "import-x/no-anonymous-default-export": "off";
13274
+ "unicorn/no-anonymous-default-export": "off";
13275
+ };
13276
+ plugins?: undefined;
13277
+ } | {
13278
+ files: string[] | undefined;
13279
+ name: string;
13280
+ rules: {};
13281
+ plugins?: undefined;
13167
13282
  } | {
13168
13283
  files: string[];
13169
13284
  name: string;
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- var X=Object.defineProperty;var r=(e,t)=>X(e,"name",{value:t,configurable:!0});import u from"globals";import{parser as z,configs as p}from"typescript-eslint";import k from"@eslint-community/eslint-plugin-eslint-comments/configs";import f from"eslint-plugin-import-x";import P from"eslint-plugin-n";import H from"@eslint/js";import O from"eslint-plugin-perfectionist";import U from"eslint-config-prettier";import*as C from"eslint-plugin-regexp";import{isPackageExists as a}from"local-pkg";import E from"eslint-plugin-unicorn";const n="?([cm])[jt]s?(x)",W=["**/node_modules","**/dist","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/bun.lockb","**/output","**/coverage","**/temp","**/.temp","**/tmp","**/.tmp","**/.history","**/.vitepress/cache","**/.nuxt","**/.next","**/.vercel","**/.changeset","**/.idea","**/.cache","**/.output","**/.vite-inspect","**/.yarn","**/storybook-static","**/.eslint-config-inspector","**/playwright-report","**/.astro","**/.vinxi","**/app.config.timestamp_*.js","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts","**/vite.config.ts.*.mjs","**/*.gen.*","!.storybook"],Y="**/*.?([cm])js",d="**/*.?([cm])jsx",T="**/*.?([cm])tsx",m=[`**/__tests__/**/*.${n}`,`**/*.spec.${n}`,`**/*.test.${n}`,`**/*.bench.${n}`,`**/*.benchmark.${n}`],_=[`**/e2e/**/*.spec.${n}`,`**/e2e/**/*.test.${n}`],g=[..._,`**/cypress/**/*.spec.${n}`,`**/cypress/**/*.test.${n}`],M="**/*.cjs",D="**/*.astro",K=["vi.mock","describe","expect","it"],Z=["@testing-library/react"],s=r(async e=>{const t=await e;return t.default??t},"interopDefault"),ee=r(async()=>{const e=[D],[t,o,i]=await Promise.all([import("eslint-plugin-astro"),import("astro-eslint-parser"),s(import("eslint-plugin-jsx-a11y"))]);return[{files:e,languageOptions:{globals:{...u.node,Astro:!1,Fragment:!1},parser:o,parserOptions:{extraFileExtensions:[".astro"],parser:z},sourceType:"module"},name:"jimmy.codes/astro",plugins:{astro:t,"jsx-a11y":i},processor:"astro/client-side-ts",rules:{...i.configs.recommended.rules,"astro/missing-client-only-directive-value":"error","astro/no-conflict-set-directives":"error","astro/no-deprecated-astro-canonicalurl":"error","astro/no-deprecated-astro-fetchcontent":"error","astro/no-deprecated-astro-resolve":"error","astro/no-deprecated-getentrybyslug":"error","astro/no-exports-from-components":"off","astro/no-unused-define-vars-in-style":"error","astro/valid-compile":"error"}},{files:e,languageOptions:{parserOptions:p.disableTypeChecked.languageOptions?.parserOptions},name:"jimmy.codes/astro/disable-type-checked",rules:p.disableTypeChecked.rules},{name:"jimmy.codes/astro/imports",settings:{"import-x/core-modules":["astro:content"]}}]},"astroConfig"),re=r(()=>[{files:[M],languageOptions:{globals:u.commonjs},name:"jimmy.codes/commonjs"}],"commonjsConfig"),te={...k.recommended.rules,"@eslint-community/eslint-comments/no-unused-disable":"off","@eslint-community/eslint-comments/require-description":"error"},oe=r(()=>[{...k.recommended,name:"jimmy.codes/eslint-comments",rules:te}],"eslintCommentsConfig"),se=r(e=>[{ignores:[...W,...e],name:"jimmy.codes/ignores"}],"ignoresConfig"),ne={...f.configs.recommended.rules,"import-x/consistent-type-specifier-style":["error","prefer-top-level"],"import-x/extensions":["error","never",{checkTypedImports:!0,svg:"always"}],"import-x/first":"error","import-x/namespace":"off","import-x/newline-after-import":"error","import-x/no-absolute-path":"error","import-x/no-duplicates":"error","import-x/no-empty-named-blocks":"error","import-x/no-named-as-default":"error","import-x/no-named-as-default-member":"error","import-x/no-self-import":"error","import-x/no-unresolved":["error",{ignore:[String.raw`\.svg$`]}],"import-x/no-useless-path-segments":"error"},ie={name:"jimmy.codes/imports/typescript",rules:f.configs.typescript.rules,settings:{...f.configs.typescript.settings,"import-x/resolver":{...f.configs.typescript.settings["import-x/resolver"],typescript:!0}}},ae=r(({typescript:e=!1}={})=>[{name:"jimmy.codes/imports",plugins:{"import-x":f,n:P},rules:ne},...e?[ie]:[]],"importsConfig"),ce={...H.configs.recommended.rules,"array-callback-return":["error",{allowImplicit:!0}],"arrow-body-style":["error","always"],curly:["error","all"],"no-console":"warn","no-self-compare":"error","no-template-curly-in-string":"error","no-unmodified-loop-condition":"error","no-unreachable-loop":"error","no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"no-useless-rename":"error","object-shorthand":"error","prefer-arrow-callback":"error"},le=r(()=>[{linterOptions:{reportUnusedDisableDirectives:!0},name:"jimmy.codes/javascript",rules:ce}],"javascriptConfig"),pe={"n/no-process-exit":"off","n/prefer-node-protocol":"error"},fe=r(()=>[{name:"jimmy.codes/node",plugins:{n:P},rules:pe}],"nodeConfig"),me={...O.configs["recommended-natural"].rules,"perfectionist/sort-imports":["error",{customGroups:{type:{},value:{}},environment:"node",groups:["side-effect-style","builtin","type","external","internal-type","internal",["parent-type","sibling-type","index-type"],["parent","sibling","index"],"object","style","unknown"],internalPattern:["^~/.*","^@/.*"],order:"asc",type:"natural"}],"perfectionist/sort-modules":"off"},ue=r(()=>[{name:"jimmy.codes/perfectionist",plugins:{perfectionist:O},rules:me}],"perfectionistConfig"),de=r(async()=>({...(await s(import("eslint-plugin-playwright"))).configs["flat/recommended"].rules,"playwright/expect-expect":"error","playwright/max-nested-describe":"error","playwright/no-conditional-expect":"error","playwright/no-conditional-in-test":"error","playwright/no-element-handle":"error","playwright/no-eval":"error","playwright/no-force-option":"error","playwright/no-nested-step":"error","playwright/no-page-pause":"error","playwright/no-skipped-test":"error","playwright/no-useless-await":"error","playwright/no-useless-not":"error","playwright/no-wait-for-selector":"error","playwright/no-wait-for-timeout":"error"}),"playwrightRules"),ge=r(async()=>[{...(await s(import("eslint-plugin-playwright"))).configs["flat/recommended"],files:_,name:"jimmy.codes/playwright",rules:await de()}],"playwrightConfig"),ye=r(()=>[{name:"jimmy.codes/prettier",...U}],"prettierConfig"),je=r(e=>e===2?"error":e===1?"warn":"off","toStringSeverity"),R=r((e={})=>Object.fromEntries(Object.entries(e).map(([t,o])=>[t,typeof o=="number"?je(o):o])),"normalizeRuleEntries"),he=r(async()=>{const[e,t]=await Promise.all([s(import("eslint-plugin-react")),s(import("eslint-plugin-jsx-a11y"))]);return{...t.configs.recommended.rules,...R(e.configs.flat?.recommended?.rules),...R(e.configs.flat?.["jsx-runtime"]?.rules),"react-hooks/exhaustive-deps":"error","react-hooks/rules-of-hooks":"error","react-refresh/only-export-components":["warn",{allowConstantExport:!0}],"react/boolean-prop-naming":"off","react/button-has-type":"error","react/checked-requires-onchange-or-readonly":"error","react/default-props-match-prop-types":"error","react/destructuring-assignment":"off","react/forbid-component-props":"off","react/forbid-dom-props":"off","react/forbid-elements":"off","react/forbid-foreign-prop-types":"off","react/forbid-prop-types":"off","react/forward-ref-uses-ref":"error","react/function-component-definition":"off","react/hook-use-state":"error","react/iframe-missing-sandbox":"error","react/jsx-boolean-value":["error","never"],"react/jsx-curly-brace-presence":"error","react/jsx-filename-extension":"off","react/jsx-fragments":["error","syntax"],"react/jsx-handler-names":"off","react/jsx-max-depth":"off","react/jsx-no-bind":"off","react/jsx-no-constructed-context-values":"error","react/jsx-no-leaked-render":"error","react/jsx-no-literals":"off","react/jsx-no-script-url":"error","react/jsx-no-useless-fragment":"error","react/jsx-one-expression-per-line":"off","react/jsx-pascal-case":["error",{allowNamespace:!0}],"react/jsx-props-no-spread-multi":"off","react/jsx-props-no-spreading":"off","react/jsx-sort-default-props":"off","react/jsx-sort-props":"off","react/no-access-state-in-setstate":"error","react/no-adjacent-inline-elements":"off","react/no-array-index-key":"off","react/no-arrow-function-lifecycle":"error","react/no-danger":"off","react/no-did-mount-set-state":"error","react/no-did-update-set-state":"error","react/no-invalid-html-attribute":"error","react/no-multi-comp":"off","react/no-namespace":"error","react/no-object-type-as-default-prop":"error","react/no-redundant-should-component-update":"error","react/no-set-state":"off","react/no-this-in-sfc":"error","react/no-typos":"error","react/no-unstable-nested-components":"error","react/no-unused-class-component-methods":"error","react/no-unused-prop-types":"error","react/no-unused-state":"error","react/no-will-update-set-state":"error","react/prefer-es6-class":"off","react/prefer-exact-props":"off","react/prefer-read-only-props":"off","react/prefer-stateless-function":"off","react/require-default-props":"off","react/require-optimization":"off","react/self-closing-comp":"error","react/sort-comp":"off","react/sort-default-props":"off","react/sort-prop-types":"off","react/state-in-constructor":"off","react/static-property-placement":"off","react/style-prop-object":"error","react/void-dom-elements-no-children":"error"}},"reactRules"),xe=r(async()=>{const[e,t,o,i]=await Promise.all([s(import("eslint-plugin-react")),s(import("eslint-plugin-jsx-a11y")),import("eslint-plugin-react-hooks"),import("eslint-plugin-react-refresh")]);return[{files:[d,T],languageOptions:{globals:{...u.browser},parserOptions:{ecmaFeatures:{jsx:!0},jsxPragma:null}},name:"jimmy.codes/react",plugins:{"jsx-a11y":t,react:e,"react-hooks":o,"react-refresh":i},rules:await he(),settings:{react:{version:"detect"}}}]},"reactConfig"),be={...C.configs["flat/recommended"].rules,"regexp/confusing-quantifier":"error","regexp/no-empty-alternative":"error","regexp/no-lazy-ends":"error","regexp/no-potentially-useless-backreference":"error","regexp/no-useless-flag":"error","regexp/optimal-lookaround-quantifier":"error"},we=r(()=>[{name:"jimmy.codes/regexp",plugins:{regexp:C},rules:be}],"regexpConfig"),ve=r(async()=>{const e=await s(import("@tanstack/eslint-plugin-query"));return[{files:[d,T],name:"jimmy.codes/react/query",plugins:{"@tanstack/query":e},rules:{"@tanstack/query/exhaustive-deps":"error","@tanstack/query/no-rest-destructuring":"warn","@tanstack/query/stable-query-client":"error"}}]},"tanstackQueryConfig"),L=r(async()=>{const e=await s(import("eslint-plugin-jest"));return{...e.configs["flat/recommended"].rules,...e.configs["flat/style"].rules,"jest/consistent-test-it":["error",{fn:"test",withinDescribe:"it"}],"jest/expect-expect":"error","jest/no-alias-methods":"error","jest/no-commented-out-tests":"error","jest/no-conditional-in-test":"error","jest/no-confusing-set-timeout":"error","jest/no-duplicate-hooks":"error","jest/no-hooks":"off","jest/no-large-snapshots":"off","jest/no-restricted-jest-methods":"off","jest/no-restricted-matchers":"off","jest/no-test-return-statement":"error","jest/no-untyped-mock-factory":"off","jest/prefer-called-with":"error","jest/prefer-comparison-matcher":"error","jest/prefer-each":"error","jest/prefer-equality-matcher":"error","jest/prefer-expect-assertions":"off","jest/prefer-expect-resolves":"error","jest/prefer-hooks-in-order":"error","jest/prefer-hooks-on-top":"error","jest/prefer-lowercase-title":"off","jest/prefer-mock-promise-shorthand":"error","jest/prefer-snapshot-hint":"error","jest/prefer-spy-on":"off","jest/prefer-strict-equal":"error","jest/prefer-todo":"warn","jest/require-hook":"error","jest/require-to-throw-message":"error","jest/require-top-level-describe":"off","jest/unbound-method":"off"}},"jestRules"),ke=r(async()=>({...await L(),"jest/no-deprecated-functions":"off","jest/require-hook":["error",{allowedFunctionCalls:K}]}),"vitestRules"),Pe=r(()=>a("typescript"),"hasTypescript"),Oe=r(()=>a("react"),"hasReact"),q=r(()=>a("vitest"),"hasVitest"),S=r(()=>a("jest"),"hasJest"),Ce=r(()=>q()||S(),"hasTesting"),Ee=r(()=>Z.some(e=>a(e)),"hasTestingLibrary"),Te=r(()=>a("@tanstack/react-query"),"hasReactQuery"),_e=r(()=>a("astro"),"hasAstro"),Re=r(()=>a("@playwright/test"),"hasPlaywright"),Le=r(async({framework:e="vitest"}={},t=!0)=>{const o=t?q():e==="vitest",i=e==="jest"||t&&S(),c=[];if(o){const l=await s(import("eslint-plugin-jest"));c.push({files:m,ignores:g,...l.configs["flat/recommended"],name:"jimmy.codes/vitest",rules:await ke()})}if(i){const l=await s(import("eslint-plugin-jest"));c.push({files:m,ignores:g,...l.configs["flat/recommended"],name:"jimmy.codes/jest",rules:await L()})}return c},"testingConfig"),qe=r(async()=>{const[e,t]=await Promise.all([import("eslint-plugin-jest-dom"),s(import("eslint-plugin-testing-library"))]);return{...t.configs["flat/react"].rules,...e.configs["flat/recommended"].rules}},"testingLibraryRules"),Se=r(async()=>{const[e,t]=await Promise.all([import("eslint-plugin-jest-dom"),s(import("eslint-plugin-testing-library"))]);return[{files:m,ignores:g,name:"jimmy.codes/testing-library",plugins:{"jest-dom":e,"testing-library":t},rules:await qe()}]},"testingLibraryConfig"),Ge={"@typescript-eslint/consistent-type-exports":["error",{fixMixedExportsWithInlineTypeSpecifier:!1}],"@typescript-eslint/consistent-type-imports":["error",{fixStyle:"separate-type-imports"}],"@typescript-eslint/no-deprecated":"warn","@typescript-eslint/no-misused-promises":["error",{checksVoidReturn:{attributes:!1}}],"@typescript-eslint/no-unused-vars":["error",{args:"all",argsIgnorePattern:"^_",caughtErrors:"all",caughtErrorsIgnorePattern:"^_",destructuredArrayIgnorePattern:"^_",ignoreRestSiblings:!0,varsIgnorePattern:"^_"}],"@typescript-eslint/no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"@typescript-eslint/restrict-template-expressions":["error",{allowNumber:!0}],"no-use-before-define":"off"},Ae=r(e=>[...p.strictTypeChecked,...p.stylisticTypeChecked.filter(t=>t.name==="typescript-eslint/stylistic-type-checked"),{languageOptions:{parserOptions:{...e?.project?{project:e.project}:{projectService:!0},tsconfigRootDir:process.cwd()}},name:"jimmy.codes/typescript",rules:Ge},{files:[Y,d],...p.disableTypeChecked},{files:m,name:"jimmy.codes/typescript/testing",rules:{"@typescript-eslint/no-unsafe-argument":"off","@typescript-eslint/no-unsafe-assignment":"off"}}],"typescriptConfig"),Ie={...E.configs["flat/recommended"].rules,"unicorn/filename-case":"off","unicorn/import-style":"off","unicorn/no-abusive-eslint-disable":"off","unicorn/no-anonymous-default-export":"off","unicorn/no-array-callback-reference":"off","unicorn/no-array-reduce":"off","unicorn/no-null":"off","unicorn/no-process-exit":"off","unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-node-protocol":"off","unicorn/prevent-abbreviations":"off"},Be=r(()=>[{...E.configs["flat/recommended"],name:"jimmy.codes/unicorn",rules:Ie}],"unicornConfig"),$e=r(e=>typeof e=="object"?e:void 0,"getTypescriptOptions"),Ne=r((e,t)=>typeof e=="object"?e:{framework:t.vitest?"vitest":t.jest?"jest":"vitest",...t.testingLibrary&&{utilities:["testing-library"]}},"getTestingOptions"),Fe=r(e=>typeof e=="object"?e:{utilities:[]},"getReactOptions"),Je=r(({utilities:e=[]},t,o)=>t||e.includes("@tanstack/query")||o&&Te(),"shouldEnableTanstackQuery"),Qe=r(({utilities:e=[]},t)=>e.includes("testing-library")||t&&Ee(),"shouldEnableTestingLibrary"),Ve=r(async({astro:e=!1,autoDetect:t=!0,configs:o=[],ignores:i=[],jest:c=!1,playwright:l=!1,react:y=!1,tanstackQuery:G=!1,testing:j=!1,testingLibrary:A=!1,typescript:h=!1,vitest:x=!1}={},...I)=>{const B=Fe(y),b=Ne(j,{jest:c,testingLibrary:A,vitest:x}),w=$e(h),v=h||!!w||t&&Pe(),$=y||t&&Oe(),N=j||c||x||t&&Ce(),F=e||t&&_e(),J=Je(B,G,t),Q=Qe(b,t),V=l||t&&Re();return[le(),ue(),fe(),Be(),oe(),we(),ae({typescript:v}),v?Ae(w):[],$?await xe():[],J?await ve():[],F?await ee():[],N?await Le(b,t):[],Q?await Se():[],V?await ge():[],ye(),re(),se(i),o,I].flat()},"eslintConfig");export{Ve as default};
1
+ var H=Object.defineProperty;var r=(e,t)=>H(e,"name",{value:t,configurable:!0});import u from"globals";import{parser as U,configs as p}from"typescript-eslint";import v from"@eslint-community/eslint-plugin-eslint-comments/configs";import f from"eslint-plugin-import-x";import C from"eslint-plugin-n";import W from"@eslint/js";import P from"eslint-plugin-perfectionist";import Y from"eslint-config-prettier";import*as O from"eslint-plugin-regexp";import{isPackageExists as i}from"local-pkg";import E from"eslint-plugin-unicorn";const a="?([cm])[jt]s?(x)",M=["**/node_modules","**/dist","**/package-lock.json","**/yarn.lock","**/pnpm-lock.yaml","**/bun.lockb","**/output","**/coverage","**/temp","**/.temp","**/tmp","**/.tmp","**/.history","**/.vitepress/cache","**/.nuxt","**/.next","**/.vercel","**/.changeset","**/.idea","**/.cache","**/.output","**/.vite-inspect","**/.yarn","**/storybook-static","**/.eslint-config-inspector","**/playwright-report","**/.astro","**/.vinxi","**/app.config.timestamp_*.js","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts","**/vite.config.ts.*.mjs","**/*.gen.*","!.storybook"],K="**/*.?([cm])js",d="**/*.?([cm])jsx",T="**/*.?([cm])tsx",m=[`**/__tests__/**/*.${a}`,`**/*.spec.${a}`,`**/*.test.${a}`,`**/*.bench.${a}`,`**/*.benchmark.${a}`],_=[`**/e2e/**/*.spec.${a}`,`**/e2e/**/*.test.${a}`],y=[..._,`**/cypress/**/*.spec.${a}`,`**/cypress/**/*.test.${a}`],Z="**/*.cjs",D="**/*.astro",ee=["vi.mock","describe","expect","it"],re=["@testing-library/react"],s=r(async e=>{const t=await e;return t.default??t},"interopDefault"),te=r(async()=>{const e=[D],[t,o,n]=await Promise.all([import("eslint-plugin-astro"),import("astro-eslint-parser"),s(import("eslint-plugin-jsx-a11y"))]);return[{files:e,languageOptions:{globals:{...u.node,Astro:!1,Fragment:!1},parser:o,parserOptions:{extraFileExtensions:[".astro"],parser:U},sourceType:"module"},name:"jimmy.codes/astro",plugins:{astro:t,"jsx-a11y":n},processor:"astro/client-side-ts",rules:{...n.configs.recommended.rules,"astro/missing-client-only-directive-value":"error","astro/no-conflict-set-directives":"error","astro/no-deprecated-astro-canonicalurl":"error","astro/no-deprecated-astro-fetchcontent":"error","astro/no-deprecated-astro-resolve":"error","astro/no-deprecated-getentrybyslug":"error","astro/no-exports-from-components":"off","astro/no-unused-define-vars-in-style":"error","astro/valid-compile":"error"}},{files:e,languageOptions:{parserOptions:p.disableTypeChecked.languageOptions?.parserOptions},name:"jimmy.codes/astro/disable-type-checked",rules:p.disableTypeChecked.rules},{name:"jimmy.codes/astro/imports",settings:{"import-x/core-modules":["astro:content"]}}]},"astroConfig"),oe=r(()=>[{files:[Z],languageOptions:{globals:u.commonjs},name:"jimmy.codes/commonjs"}],"commonjsConfig"),se={...v.recommended.rules,"@eslint-community/eslint-comments/no-unused-disable":"off","@eslint-community/eslint-comments/require-description":"error"},ne=r(()=>[{...v.recommended,name:"jimmy.codes/eslint-comments",rules:se}],"eslintCommentsConfig"),ie=r(e=>[{ignores:[...M,...e],name:"jimmy.codes/ignores"}],"ignoresConfig"),ae={...f.configs.recommended.rules,"import-x/consistent-type-specifier-style":["error","prefer-top-level"],"import-x/extensions":["error","never",{checkTypedImports:!0,svg:"always"}],"import-x/first":"error","import-x/namespace":"off","import-x/newline-after-import":"error","import-x/no-absolute-path":"error","import-x/no-duplicates":"error","import-x/no-empty-named-blocks":"error","import-x/no-named-as-default":"error","import-x/no-named-as-default-member":"error","import-x/no-self-import":"error","import-x/no-unresolved":["error",{ignore:[String.raw`\.svg$`]}],"import-x/no-useless-path-segments":"error"},ce={name:"jimmy.codes/imports/typescript",rules:f.configs.typescript.rules,settings:{...f.configs.typescript.settings,"import-x/resolver":{...f.configs.typescript.settings["import-x/resolver"],typescript:!0}}},le=r(({typescript:e=!1}={})=>[{name:"jimmy.codes/imports",plugins:{"import-x":f,n:C},rules:ae},...e?[ce]:[]],"importsConfig"),pe={...W.configs.recommended.rules,"array-callback-return":["error",{allowImplicit:!0}],"arrow-body-style":["error","always"],curly:["error","all"],"no-console":"warn","no-self-compare":"error","no-template-curly-in-string":"error","no-unmodified-loop-condition":"error","no-unreachable-loop":"error","no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"no-useless-rename":"error","object-shorthand":"error","prefer-arrow-callback":"error"},fe=r(()=>[{linterOptions:{reportUnusedDisableDirectives:!0},name:"jimmy.codes/javascript",rules:pe}],"javascriptConfig"),me={"n/no-process-exit":"off","n/prefer-node-protocol":"error"},ue=r(()=>[{name:"jimmy.codes/node",plugins:{n:C},rules:me}],"nodeConfig"),de={...P.configs["recommended-natural"].rules,"perfectionist/sort-imports":["error",{customGroups:{type:{},value:{}},environment:"node",groups:["side-effect-style","builtin","type","external","internal-type","internal",["parent-type","sibling-type","index-type"],["parent","sibling","index"],"object","style","unknown"],internalPattern:["^~/.*","^@/.*"],order:"asc",type:"natural"}],"perfectionist/sort-modules":"off"},ye=r(()=>[{name:"jimmy.codes/perfectionist",plugins:{perfectionist:P},rules:de}],"perfectionistConfig"),ge=r(async()=>({...(await s(import("eslint-plugin-playwright"))).configs["flat/recommended"].rules,"playwright/expect-expect":"error","playwright/max-nested-describe":"error","playwright/no-conditional-expect":"error","playwright/no-conditional-in-test":"error","playwright/no-element-handle":"error","playwright/no-eval":"error","playwright/no-force-option":"error","playwright/no-nested-step":"error","playwright/no-page-pause":"error","playwright/no-skipped-test":"error","playwright/no-useless-await":"error","playwright/no-useless-not":"error","playwright/no-wait-for-selector":"error","playwright/no-wait-for-timeout":"error"}),"playwrightRules"),je=r(async()=>[{...(await s(import("eslint-plugin-playwright"))).configs["flat/recommended"],files:_,name:"jimmy.codes/playwright",rules:await ge()}],"playwrightConfig"),he=r(()=>[{name:"jimmy.codes/prettier",...Y}],"prettierConfig"),xe=r(e=>e===2?"error":e===1?"warn":"off","toStringSeverity"),R=r((e={})=>Object.fromEntries(Object.entries(e).map(([t,o])=>[t,typeof o=="number"?xe(o):o])),"normalizeRuleEntries"),be=r(async()=>{const[e,t]=await Promise.all([s(import("eslint-plugin-react")),s(import("eslint-plugin-jsx-a11y"))]);return{...t.configs.recommended.rules,...R(e.configs.flat?.recommended?.rules),...R(e.configs.flat?.["jsx-runtime"]?.rules),"react-compiler/react-compiler":"error","react-hooks/exhaustive-deps":"error","react-hooks/rules-of-hooks":"error","react-refresh/only-export-components":["warn",{allowConstantExport:!0}],"react/boolean-prop-naming":"off","react/button-has-type":"error","react/checked-requires-onchange-or-readonly":"error","react/default-props-match-prop-types":"error","react/destructuring-assignment":"off","react/forbid-component-props":"off","react/forbid-dom-props":"off","react/forbid-elements":"off","react/forbid-foreign-prop-types":"off","react/forbid-prop-types":"off","react/forward-ref-uses-ref":"error","react/function-component-definition":"off","react/hook-use-state":"error","react/iframe-missing-sandbox":"error","react/jsx-boolean-value":["error","never"],"react/jsx-curly-brace-presence":"error","react/jsx-filename-extension":"off","react/jsx-fragments":["error","syntax"],"react/jsx-handler-names":"off","react/jsx-max-depth":"off","react/jsx-no-bind":"off","react/jsx-no-constructed-context-values":"error","react/jsx-no-leaked-render":"error","react/jsx-no-literals":"off","react/jsx-no-script-url":"error","react/jsx-no-useless-fragment":"error","react/jsx-one-expression-per-line":"off","react/jsx-pascal-case":["error",{allowNamespace:!0}],"react/jsx-props-no-spread-multi":"off","react/jsx-props-no-spreading":"off","react/jsx-sort-default-props":"off","react/jsx-sort-props":"off","react/no-access-state-in-setstate":"error","react/no-adjacent-inline-elements":"off","react/no-array-index-key":"off","react/no-arrow-function-lifecycle":"error","react/no-danger":"off","react/no-did-mount-set-state":"error","react/no-did-update-set-state":"error","react/no-invalid-html-attribute":"error","react/no-multi-comp":"off","react/no-namespace":"error","react/no-object-type-as-default-prop":"error","react/no-redundant-should-component-update":"error","react/no-set-state":"off","react/no-this-in-sfc":"error","react/no-typos":"error","react/no-unstable-nested-components":"error","react/no-unused-class-component-methods":"error","react/no-unused-prop-types":"error","react/no-unused-state":"error","react/no-will-update-set-state":"error","react/prefer-es6-class":"off","react/prefer-exact-props":"off","react/prefer-read-only-props":"off","react/prefer-stateless-function":"off","react/require-default-props":"off","react/require-optimization":"off","react/self-closing-comp":"error","react/sort-comp":"off","react/sort-default-props":"off","react/sort-prop-types":"off","react/state-in-constructor":"off","react/static-property-placement":"off","react/style-prop-object":"error","react/void-dom-elements-no-children":"error"}},"reactRules"),we=r(async()=>{const[e,t,o,n,c]=await Promise.all([s(import("eslint-plugin-react")),s(import("eslint-plugin-jsx-a11y")),import("eslint-plugin-react-hooks"),import("eslint-plugin-react-refresh"),s(import("eslint-plugin-react-compiler"))]);return[{files:[d,T],languageOptions:{globals:{...u.browser},parserOptions:{ecmaFeatures:{jsx:!0},jsxPragma:null}},name:"jimmy.codes/react",plugins:{"jsx-a11y":t,react:e,"react-compiler":c,"react-hooks":o,"react-refresh":n},rules:await be(),settings:{react:{version:"detect"}}}]},"reactConfig"),ke={...O.configs["flat/recommended"].rules,"regexp/confusing-quantifier":"error","regexp/no-empty-alternative":"error","regexp/no-lazy-ends":"error","regexp/no-potentially-useless-backreference":"error","regexp/no-useless-flag":"error","regexp/optimal-lookaround-quantifier":"error"},ve=r(()=>[{name:"jimmy.codes/regexp",plugins:{regexp:O},rules:ke}],"regexpConfig"),Ce=r((e={})=>Object.fromEntries(Object.entries(e).map(([t,o])=>[t,o==="warn"?"error":o])),"warningAsErrors"),Pe=r(async()=>{const{configs:e}=await s(import("eslint-plugin-storybook")),[t,o,n]=e["flat/recommended"];return[{name:"jimmy.codes/storybook/setup",plugins:t?.plugins},{files:o?.files,name:"jimmy.codes/storybook/stories-rules",rules:{...Ce(o?.rules),"import-x/no-anonymous-default-export":"off","unicorn/no-anonymous-default-export":"off"}},{files:n?.files,name:"jimmy.codes/storybook/main-rules",rules:{...n?.rules}}]},"storybookConfig"),Oe=r(async()=>{const e=await s(import("@tanstack/eslint-plugin-query"));return[{files:[d,T],name:"jimmy.codes/react/query",plugins:{"@tanstack/query":e},rules:{"@tanstack/query/exhaustive-deps":"error","@tanstack/query/no-rest-destructuring":"warn","@tanstack/query/stable-query-client":"error"}}]},"tanstackQueryConfig"),L=r(async()=>{const e=await s(import("eslint-plugin-jest"));return{...e.configs["flat/recommended"].rules,...e.configs["flat/style"].rules,"jest/consistent-test-it":["error",{fn:"test",withinDescribe:"it"}],"jest/expect-expect":"error","jest/no-alias-methods":"error","jest/no-commented-out-tests":"error","jest/no-conditional-in-test":"error","jest/no-confusing-set-timeout":"error","jest/no-duplicate-hooks":"error","jest/no-hooks":"off","jest/no-large-snapshots":"off","jest/no-restricted-jest-methods":"off","jest/no-restricted-matchers":"off","jest/no-test-return-statement":"error","jest/no-untyped-mock-factory":"off","jest/prefer-called-with":"error","jest/prefer-comparison-matcher":"error","jest/prefer-each":"error","jest/prefer-equality-matcher":"error","jest/prefer-expect-assertions":"off","jest/prefer-expect-resolves":"error","jest/prefer-hooks-in-order":"error","jest/prefer-hooks-on-top":"error","jest/prefer-lowercase-title":"off","jest/prefer-mock-promise-shorthand":"error","jest/prefer-snapshot-hint":"error","jest/prefer-spy-on":"off","jest/prefer-strict-equal":"error","jest/prefer-todo":"warn","jest/require-hook":"error","jest/require-to-throw-message":"error","jest/require-top-level-describe":"off","jest/unbound-method":"off"}},"jestRules"),Ee=r(async()=>({...await L(),"jest/no-deprecated-functions":"off","jest/require-hook":["error",{allowedFunctionCalls:ee}]}),"vitestRules"),Te=r(()=>i("typescript"),"hasTypescript"),_e=r(()=>i("react"),"hasReact"),S=r(()=>i("vitest"),"hasVitest"),q=r(()=>i("jest"),"hasJest"),Re=r(()=>S()||q(),"hasTesting"),Le=r(()=>re.some(e=>i(e)),"hasTestingLibrary"),Se=r(()=>i("@tanstack/react-query"),"hasReactQuery"),qe=r(()=>i("astro"),"hasAstro"),Ae=r(()=>i("@playwright/test"),"hasPlaywright"),Ge=r(()=>i("storybook"),"hasStorybook"),Ie=r(async({framework:e="vitest"}={},t=!0)=>{const o=t?S():e==="vitest",n=e==="jest"||t&&q(),c=[];if(o){const l=await s(import("eslint-plugin-jest"));c.push({files:m,ignores:y,...l.configs["flat/recommended"],name:"jimmy.codes/vitest",rules:await Ee()})}if(n){const l=await s(import("eslint-plugin-jest"));c.push({files:m,ignores:y,...l.configs["flat/recommended"],name:"jimmy.codes/jest",rules:await L()})}return c},"testingConfig"),Be=r(async()=>{const[e,t]=await Promise.all([import("eslint-plugin-jest-dom"),s(import("eslint-plugin-testing-library"))]);return{...t.configs["flat/react"].rules,...e.configs["flat/recommended"].rules}},"testingLibraryRules"),$e=r(async()=>{const[e,t]=await Promise.all([import("eslint-plugin-jest-dom"),s(import("eslint-plugin-testing-library"))]);return[{files:m,ignores:y,name:"jimmy.codes/testing-library",plugins:{"jest-dom":e,"testing-library":t},rules:await Be()}]},"testingLibraryConfig"),Ne={"@typescript-eslint/consistent-type-exports":["error",{fixMixedExportsWithInlineTypeSpecifier:!1}],"@typescript-eslint/consistent-type-imports":["error",{fixStyle:"separate-type-imports"}],"@typescript-eslint/no-deprecated":"warn","@typescript-eslint/no-misused-promises":["error",{checksVoidReturn:{attributes:!1}}],"@typescript-eslint/no-unused-vars":["error",{args:"all",argsIgnorePattern:"^_",caughtErrors:"all",caughtErrorsIgnorePattern:"^_",destructuredArrayIgnorePattern:"^_",ignoreRestSiblings:!0,varsIgnorePattern:"^_"}],"@typescript-eslint/no-use-before-define":["error",{allowNamedExports:!1,classes:!1,functions:!1,variables:!0}],"@typescript-eslint/restrict-template-expressions":["error",{allowNumber:!0}],"no-use-before-define":"off"},Fe=r(e=>[...p.strictTypeChecked,...p.stylisticTypeChecked.filter(t=>t.name==="typescript-eslint/stylistic-type-checked"),{languageOptions:{parserOptions:{...e?.project?{project:e.project}:{projectService:!0},tsconfigRootDir:process.cwd()}},name:"jimmy.codes/typescript",rules:Ne},{files:[K,d],...p.disableTypeChecked},{files:m,name:"jimmy.codes/typescript/testing",rules:{"@typescript-eslint/no-unsafe-argument":"off","@typescript-eslint/no-unsafe-assignment":"off"}}],"typescriptConfig"),Je={...E.configs["flat/recommended"].rules,"unicorn/filename-case":"off","unicorn/import-style":"off","unicorn/no-abusive-eslint-disable":"off","unicorn/no-anonymous-default-export":"off","unicorn/no-array-callback-reference":"off","unicorn/no-array-reduce":"off","unicorn/no-null":"off","unicorn/no-process-exit":"off","unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-node-protocol":"off","unicorn/prevent-abbreviations":"off"},Qe=r(()=>[{...E.configs["flat/recommended"],name:"jimmy.codes/unicorn",rules:Je}],"unicornConfig"),Ve=r(e=>typeof e=="object"?e:void 0,"getTypescriptOptions"),Xe=r((e,t)=>typeof e=="object"?e:{framework:t.vitest?"vitest":t.jest?"jest":"vitest",...t.testingLibrary&&{utilities:["testing-library"]}},"getTestingOptions"),ze=r(e=>typeof e=="object"?e:{utilities:[]},"getReactOptions"),He=r(({utilities:e=[]},t,o)=>t||e.includes("@tanstack/query")||o&&Se(),"shouldEnableTanstackQuery"),Ue=r(({utilities:e=[]},t)=>e.includes("testing-library")||t&&Le(),"shouldEnableTestingLibrary"),We=r(async({astro:e=!1,autoDetect:t=!0,configs:o=[],ignores:n=[],jest:c=!1,playwright:l=!1,react:g=!1,storybook:A=!1,tanstackQuery:G=!1,testing:j=!1,testingLibrary:I=!1,typescript:h=!1,vitest:x=!1}={},...B)=>{const $=ze(g),b=Xe(j,{jest:c,testingLibrary:I,vitest:x}),w=Ve(h),k=h||!!w||t&&Te(),N=g||t&&_e(),F=j||c||x||t&&Re(),J=e||t&&qe(),Q=He($,G,t),V=Ue(b,t),X=l||t&&Ae(),z=A||t&&Ge();return[fe(),ye(),ue(),Qe(),ne(),ve(),le({typescript:k}),k?Fe(w):[],N?await we():[],Q?await Oe():[],J?await te():[],F?await Ie(b,t):[],V?await $e():[],X?await je():[],z?await Pe():[],he(),oe(),ie(n),o,B].flat()},"eslintConfig");export{We as default};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jimmy.codes/eslint-config",
3
- "version": "3.20.0",
3
+ "version": "3.22.0",
4
4
  "description": "another opinionated eslint config",
5
5
  "keywords": [
6
6
  "eslint",
@@ -49,9 +49,11 @@
49
49
  "eslint-plugin-perfectionist": "^4.1.2",
50
50
  "eslint-plugin-playwright": "^2.1.0",
51
51
  "eslint-plugin-react": "^7.37.2",
52
+ "eslint-plugin-react-compiler": "19.0.0-beta-df7b47d-20241124",
52
53
  "eslint-plugin-react-hooks": "^5.0.0",
53
54
  "eslint-plugin-react-refresh": "0.4.14",
54
55
  "eslint-plugin-regexp": "^2.7.0",
56
+ "eslint-plugin-storybook": "0.11.1",
55
57
  "eslint-plugin-testing-library": "^7.0.0",
56
58
  "eslint-plugin-unicorn": "^56.0.1",
57
59
  "globals": "^15.12.0",