@2digits/eslint-config 2.0.1 → 2.2.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/dist/index.cjs +27 -23
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +820 -10
- package/dist/index.d.ts +820 -10
- package/dist/index.js +9 -8
- package/dist/index.js.map +1 -1
- package/package.json +13 -10
package/dist/index.js
CHANGED
|
@@ -1,15 +1,16 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import M from '@eslint/js';
|
|
6
|
-
import k from 'globals';
|
|
1
|
+
import k from 'eslint-plugin-unicorn';
|
|
2
|
+
import v from 'eslint-plugin-eslint-comments';
|
|
3
|
+
import j from 'eslint-plugin-n';
|
|
4
|
+
import T from 'eslint-plugin-sonarjs';
|
|
7
5
|
import { fixupPluginRules } from '@eslint/compat';
|
|
6
|
+
import { renamePluginsInRules, composer, renamePluginsInConfigs, FlatConfigComposer } from 'eslint-flat-config-utils';
|
|
7
|
+
import Q from '@eslint/js';
|
|
8
|
+
import w from 'globals';
|
|
8
9
|
import { findUp } from 'find-up';
|
|
9
10
|
import { isPackageExists } from 'local-pkg';
|
|
10
11
|
|
|
11
|
-
function v(){return [{name:"2digits:comments",plugins:{"eslint-comments":T},rules:{"eslint-comments/no-aggregating-enable":"error","eslint-comments/no-duplicate-disable":"error","eslint-comments/no-unlimited-disable":"error","eslint-comments/no-unused-enable":"error","eslint-comments/no-unused-disable":"error"}}]}var j="**/*.?([cm])[jt]s?(x)",b="**/*.?([cm])ts",O="**/*.?([cm])tsx",S="**/*.stories.tsx",C=["**/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","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts"];async function o(e){let t=await e;return t.default||t}async function F(e={}){return composer({ignores:C,name:"2digits:ignores"},o(import('eslint-config-flat-gitignore')).then(t=>({...t(e),name:"2digits:gitignore"})))}function I(e={}){let{overrides:t={}}=e;return [{name:"2digits:javascript",languageOptions:{ecmaVersion:2022,globals:{...k.browser,...k.es2021,...k.node,document:"readonly",navigator:"readonly",window:"readonly"},parserOptions:{ecmaFeatures:{jsx:!0},ecmaVersion:2022,sourceType:"module"},sourceType:"module"},linterOptions:{reportUnusedDisableDirectives:!0},rules:{...M.configs.recommended.rules,"accessor-pairs":["error",{enforceForClassMembers:!0,setWithoutGet:!0}],"array-callback-return":"error","block-scoped-var":"error","constructor-super":"error","default-case-last":"error","dot-notation":["error",{allowKeywords:!0}],eqeqeq:["error","smart"],"new-cap":["error",{capIsNew:!1,newIsCap:!0,properties:!0}],"no-alert":"error","no-array-constructor":"error","no-async-promise-executor":"error","no-caller":"error","no-case-declarations":"error","no-class-assign":"error","no-compare-neg-zero":"error","no-cond-assign":["error","always"],"no-const-assign":"error","no-control-regex":"error","no-debugger":"error","no-delete-var":"error","no-dupe-args":"error","no-dupe-class-members":"error","no-dupe-keys":"error","no-duplicate-case":"error","no-empty":["error",{allowEmptyCatch:!0}],"no-empty-character-class":"error","no-empty-pattern":"error","no-eval":"error","no-ex-assign":"error","no-extend-native":"error","no-extra-bind":"error","no-extra-boolean-cast":"error","no-fallthrough":"error","no-func-assign":"error","no-global-assign":"error","no-implied-eval":"error","no-import-assign":"error","no-invalid-regexp":"error","no-irregular-whitespace":"error","no-iterator":"error","no-labels":["error",{allowLoop:!1,allowSwitch:!1}],"no-lone-blocks":"error","no-loss-of-precision":"error","no-misleading-character-class":"error","no-multi-str":"error","no-new":"error","no-new-func":"error","no-new-native-nonconstructor":"error","no-new-wrappers":"error","no-obj-calls":"error","no-octal":"error","no-octal-escape":"error","no-proto":"error","no-prototype-builtins":"error","no-redeclare":["error",{builtinGlobals:!1}],"no-regex-spaces":"error","no-restricted-globals":["error",{message:"Use `globalThis` instead.",name:"global"},{message:"Use `globalThis` instead.",name:"self"}],"no-restricted-properties":["error",{message:"Use `Object.getPrototypeOf` or `Object.setPrototypeOf` instead.",property:"__proto__"},{message:"Use `Object.defineProperty` instead.",property:"__defineGetter__"},{message:"Use `Object.defineProperty` instead.",property:"__defineSetter__"},{message:"Use `Object.getOwnPropertyDescriptor` instead.",property:"__lookupGetter__"},{message:"Use `Object.getOwnPropertyDescriptor` instead.",property:"__lookupSetter__"}],"no-restricted-syntax":["error","DebuggerStatement","LabeledStatement","WithStatement","TSEnumDeclaration","TSExportAssignment"],"no-self-assign":["error",{props:!0}],"no-self-compare":"error","no-sequences":"error","no-shadow-restricted-names":"error","no-sparse-arrays":"error","no-template-curly-in-string":"error","no-this-before-super":"error","no-throw-literal":"error","no-undef":"error","no-undef-init":"error","no-unexpected-multiline":"error","no-unmodified-loop-condition":"error","no-unneeded-ternary":["error",{defaultAssignment:!1}],"no-unreachable":"error","no-unreachable-loop":"error","no-unsafe-finally":"error","no-unsafe-negation":"error","no-unused-expressions":["error",{allowShortCircuit:!0,allowTaggedTemplates:!0,allowTernary:!0}],"no-unused-vars":["error",{args:"none",caughtErrors:"none",ignoreRestSiblings:!0,vars:"all"}],"no-useless-backreference":"error","no-useless-call":"error","no-useless-catch":"error","no-useless-computed-key":"error","no-useless-constructor":"error","no-useless-rename":"error","no-var":"error","no-with":"error","object-shorthand":["error","always",{avoidQuotes:!0,ignoreConstructors:!1}],"one-var":["error",{initialized:"never"}],"prefer-arrow-callback":["error",{allowNamedFunctions:!0,allowUnboundThis:!0}],"prefer-const":["error",{destructuring:"all",ignoreReadBeforeAssign:!0}],"prefer-exponentiation-operator":"error","prefer-promise-reject-errors":"error","prefer-regex-literals":["error",{disallowRedundantWrapping:!0}],"prefer-rest-params":"error","prefer-spread":"error","prefer-template":"error","symbol-description":"error","unicode-bom":["error","never"],"use-isnan":["error",{enforceForIndexOf:!0,enforceForSwitchCase:!0}],"valid-typeof":["error",{requireStringLiterals:!0}],"vars-on-top":"error",yoda:["error","never"],...t}}]}async function P(){return [{name:"2digits:jsdoc",plugins:{jsdoc:await o(import('eslint-plugin-jsdoc'))},rules:{"jsdoc/check-access":"error","jsdoc/check-param-names":"error","jsdoc/check-property-names":"error","jsdoc/check-types":"error","jsdoc/empty-tags":"error","jsdoc/implements-on-classes":"error","jsdoc/no-defaults":"error","jsdoc/no-multi-asterisks":"error","jsdoc/require-param-name":"error","jsdoc/require-property":"error","jsdoc/require-property-description":"error","jsdoc/require-property-name":"error","jsdoc/require-returns-check":"error","jsdoc/require-returns-description":"error","jsdoc/require-yields-check":"error"}}]}var d={"@next/next":"next","@eslint-react/naming-convention":"react-naming-convention","@eslint-react/hooks-extra":"react-hooks-extra","@eslint-react/dom":"react-dom","@eslint-react":"react-extra","react-hooks":"react-hooks",react:"react","@typescript-eslint":"ts",node:"node","eslint-comments":"eslint-comments",storybook:"storybook",turbo:"turbo",jsdoc:"jsdoc",unicorn:"unicorn",tailwindcss:"tailwindcss","@tanstack/query":"tanstack","@2digits":"@2digits"};async function _(e={}){let{files:t=[b,O],overrides:r={},tsconfigPath:a,parserOptions:i}=e,[l,m]=await Promise.all([o(import('@next/eslint-plugin-next')),o(import('@typescript-eslint/parser'))]),c=renamePluginsInRules({...l.configs.recommended.rules,...l.configs["core-web-vitals"].rules},d);return [{name:"2digits:next/setup",plugins:{next:fixupPluginRules(l)}},{name:"2digits:next/rules",files:t,languageOptions:{parser:m,parserOptions:{ecmaFeatures:{jsx:!0},project:a,...i},sourceType:"module"},rules:{...c,"next/no-html-link-for-pages":"off",...r}}]}function D(){return [{name:"2digits:node",settings:{node:{version:">= 20.0.0"}},plugins:{node:w},rules:{"node/handle-callback-err":["error","^(err|error)$"],"node/no-deprecated-api":"error","node/no-exports-assign":"error","node/no-new-require":"error","node/no-path-concat":"error","node/no-unsupported-features/node-builtins":["error",{allowExperimental:!0}],"node/prefer-global/buffer":"error","node/prefer-global/process":"error","node/prefer-global/text-encoder":"error","node/prefer-global/url":"error","node/prefer-global/console":"error","node/prefer-global/url-search-params":"error","node/prefer-global/text-decoder":"error","node/process-exit-as-throw":"error"}}]}async function W(){return [{name:"2digits:prettier",rules:(await o(import('eslint-config-prettier'))).rules}]}async function G(e={}){let{files:t=[b,O],overrides:r={},tsconfigPath:a,parserOptions:i,tsconfigRootDir:l}=e,[m,c,u,x]=await Promise.all([o(import('@eslint-react/eslint-plugin')),o(import('eslint-plugin-react-hooks')),o(import('eslint-plugin-react')),o(import('@typescript-eslint/parser'))]),y=m.configs.all.plugins,N=renamePluginsInRules({...u.configs.recommended.rules,...u.configs["jsx-runtime"].rules,...c.configs.recommended.rules,...m.configs["recommended-type-checked"].rules},d);return [{name:"2digits:react/setup",plugins:{react:u,"react-dom":y["@eslint-react/dom"],"react-extra":y["@eslint-react"],"react-hooks":fixupPluginRules(c),"react-hooks-extra":y["@eslint-react/hooks-extra"],"react-naming-convention":y["@eslint-react/naming-convention"]},settings:{react:{version:"detect"}}},{name:"2digits:react/rules",files:t,languageOptions:{parser:x,parserOptions:{ecmaFeatures:{jsx:!0},tsconfigRootDir:l,project:a,...i},sourceType:"module"},rules:{...N,"react-hooks-extra/ensure-use-memo-has-non-empty-deps":"error","react-hooks-extra/prefer-use-state-lazy-initialization":"error","react-hooks-extra/ensure-custom-hooks-using-other-hooks":"error","react-hooks-extra/ensure-use-callback-has-non-empty-deps":"error","react/jsx-curly-newline":"off","react/jsx-newline":["error",{prevent:!1}],...r}}]}async function L(e={}){let{files:t=[S],overrides:r={},parserOptions:a,tsconfigPath:i,storybookDirectory:l=".storybook"}=e,[m,c]=await Promise.all([o(import('eslint-plugin-storybook')),o(import('@typescript-eslint/parser'))]),u={parser:c,parserOptions:{ecmaFeatures:{jsx:!0},project:i,...a},sourceType:"module"};return [{name:"2digits:storybook/setup",plugins:{storybook:fixupPluginRules(m)}},{name:"2digits:storybook/rules",files:t,languageOptions:u,rules:{"storybook/await-interactions":"error","storybook/context-in-play-function":"error","storybook/csf-component":"error","storybook/default-exports":"error","storybook/hierarchy-separator":"error","storybook/no-redundant-story-name":"error","storybook/no-stories-of":"error","storybook/no-title-property-in-meta":"error","storybook/prefer-pascal-case":"error","storybook/story-exports":"error","storybook/use-storybook-expect":"error","storybook/use-storybook-testing-library":"error",...r}},{name:"2digits:storybook/disables",files:t,rules:{"react-hooks/rules-of-hooks":"off","react/display-name":"off"}},{name:"2digits:storybook/config",files:[`${l}/main.@(js|cjs|mjs|ts)`],languageOptions:u,rules:{"storybook/no-uninstalled-addons":"error"}}]}async function q(e={}){let{overrides:t={}}=e,[r,{tailwindFunctions:a},i]=await Promise.all([o(import('eslint-plugin-tailwindcss')),o(import('@2digits/constants')),findUp(["tailwind.config.ts","tailwind.config.js"])]);return [{name:"2digits:tailwind",plugins:{tailwindcss:r},settings:{tailwindcss:{callees:a,config:i}},rules:{...r.configs.recommended.rules,"tailwindcss/classnames-order":"off",...t}}]}async function E(e={}){let{overrides:t={}}=e,r=await o(import('@tanstack/eslint-plugin-query'));return [{name:"2digits:tanstack",plugins:{tanstack:fixupPluginRules(r)},rules:{"tanstack/exhaustive-deps":"error","tanstack/stable-query-client":"error","tanstack/no-rest-destructuring":"error",...t}}]}async function R(e={}){let{overrides:t={}}=e;return [{name:"2digits:turbo",plugins:{turbo:await o(import('eslint-plugin-turbo'))},rules:{"turbo/no-undeclared-env-vars":"error",...t}}]}async function U(e={}){let{overrides:t={},parserOptions:r={},tsconfigPath:a=!0}=e,[{plugin:i,configs:l,parser:m},c]=await Promise.all([o(import('typescript-eslint')),o(import('@2digits/eslint-plugin'))]),u=renamePluginsInConfigs(l.strictTypeChecked,d),x=Object.fromEntries(u.flatMap(({rules:y})=>Object.entries(y??{})));return [{name:"2digits:typescript/setup",plugins:{ts:i,"@2digits":c},languageOptions:{parser:m,parserOptions:{sourceType:"module",tsconfigRootDir:process.cwd(),project:a,...r}}},{name:"2digits:typescript/rules",files:[j],rules:{...x,"ts/restrict-template-expressions":["error",{allowNumber:!0}],"ts/ban-ts-comment":["error",{"ts-ignore":"allow-with-description"}],"ts/consistent-type-exports":["error"],"ts/consistent-type-imports":["error",{prefer:"type-imports",disallowTypeAnnotations:!1,fixStyle:"inline-type-imports"}],"ts/no-empty-interface":["error",{allowSingleExtends:!0}],"ts/no-explicit-any":["error"],"ts/no-import-type-side-effects":["error"],"ts/no-misused-promises":"off","ts/no-confusing-void-expression":["error",{ignoreArrowShorthand:!0,ignoreVoidOperator:!0}],"ts/no-unused-vars":["error",{ignoreRestSiblings:!0,argsIgnorePattern:"^_",varsIgnorePattern:"^_"}],...c.configs.recommended.rules,...t}},{files:["**/*.d.ts"],name:"2digits:typescript/disables/dts",rules:{"unicorn/no-abusive-eslint-disable":"off","no-duplicate-imports":"off","no-restricted-syntax":"off","ts/no-unused-vars":"off"}},{files:["**/*.{test,spec}.ts?(x)"],name:"2digits:typescript/disables/test",rules:{"no-unused-expressions":"off"}},{files:["**/*.js","**/*.cjs","**/*.cts"],name:"2digits:typescript/disables/cjs",rules:{"ts/no-require-imports":"off","ts/no-var-requires":"off"}}]}function B(){return [{name:"2digits:unicorn",plugins:{unicorn:h},rules:{...h.configs.recommended.rules,"unicorn/filename-case":["off"],"unicorn/prefer-module":["off"],"unicorn/prevent-abbreviations":["off"],"unicorn/prefer-ternary":["error","only-single-line"],"unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-top-level-await":["off"]}}]}function g(e,t){return typeof e=="boolean"?e:e?.enable??t??!1}function f(e){if(typeof e=="boolean"||e===void 0)return {};let{enable:t,...r}=e;return r}function Z(e={},...t){let r=new FlatConfigComposer(F(e.ignores),I(e.js),D(),v(),P(),B());g(e.turbo,isPackageExists("turbo"))&&(r=r.append(R(f(e.turbo))));let{overrides:a,...i}=f(e.ts);return g(e.ts,isPackageExists("typescript"))&&(r=r.append(U(f(e.ts)))),g(e.react,isPackageExists("react"))&&(r=r.append(G({...f(e.react),...i}))),g(e.next,isPackageExists("next"))&&(r=r.append(_({...f(e.next),...i}))),g(e.storybook,isPackageExists("storybook"))&&(r=r.append(L({...f(e.storybook),...i}))),g(e.tailwind,isPackageExists("tailwindcss"))&&(r=r.append(q(f(e.tailwind)))),g(e.tanstack,isPackageExists("react-query")||isPackageExists("@tanstack/react-query")||isPackageExists("@tanstack/react-query-devtools"))&&(r=r.append(E(f(e.tanstack)))),r=r.append(...t),isPackageExists("prettier")&&(r=r.append(W())),r.renamePlugins(d).toConfigs()}
|
|
12
|
+
function C(){return [{name:"2digits:comments",plugins:{"eslint-comments":v},rules:{"eslint-comments/no-aggregating-enable":"error","eslint-comments/no-duplicate-disable":"error","eslint-comments/no-unlimited-disable":"error","eslint-comments/no-unused-enable":"error","eslint-comments/no-unused-disable":"error"}}]}var p={"@next/next":"next","@eslint-react/naming-convention":"react-naming-convention","@eslint-react/hooks-extra":"react-hooks-extra","@eslint-react/dom":"react-dom","@eslint-react":"react-extra","react-hooks":"react-hooks","react-compiler":"react-compiler",react:"react","@typescript-eslint":"ts",node:"node","eslint-comments":"eslint-comments",storybook:"storybook",turbo:"turbo",jsdoc:"jsdoc",unicorn:"unicorn",tailwindcss:"tailwindcss","@tanstack/query":"tanstack","@2digits":"@2digits","@graphql-eslint":"gql",sonarjs:"sonar"};async function o(e){let t=await e;return t.default||t}async function S(e={}){let{overrides:t={},files:r=["**/*.graphql","**/*.gql"]}=e,i=await o(import('@graphql-eslint/eslint-plugin')),a=renamePluginsInRules(i.flatConfigs["operations-recommended"].rules,p);return [{name:"2digits:graphql",plugins:{gql:fixupPluginRules(i)},languageOptions:{parser:{...i,meta:{name:"graphql"}}},files:r,rules:{...a,...t}}]}var F="**/*.?([cm])[jt]s?(x)",h="**/*.?([cm])ts",O="**/*.?([cm])tsx",I="**/*.stories.tsx",P=["**/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","**/CHANGELOG*.md","**/*.min.*","**/LICENSE*","**/__snapshots__","**/auto-import?(s).d.ts","**/components.d.ts"];async function _(e={}){let{gitIgnore:t,ignores:r=[]}=e;return composer({ignores:[P,r].flat(),name:"2digits:ignores"},o(import('eslint-config-flat-gitignore')).then(i=>({...i(t),name:"2digits:gitignore"})))}function q(e={}){let{overrides:t={}}=e;return [{name:"2digits:javascript",languageOptions:{ecmaVersion:2022,globals:{...w.browser,...w.es2021,...w.node,document:"readonly",navigator:"readonly",window:"readonly"},parserOptions:{ecmaFeatures:{jsx:!0},ecmaVersion:2022,sourceType:"module"},sourceType:"module"},linterOptions:{reportUnusedDisableDirectives:!0},rules:{...Q.configs.recommended.rules,"accessor-pairs":["error",{enforceForClassMembers:!0,setWithoutGet:!0}],"array-callback-return":"error","block-scoped-var":"error","constructor-super":"error","default-case-last":"error","dot-notation":["error",{allowKeywords:!0}],eqeqeq:["error","smart"],"new-cap":["error",{capIsNew:!1,newIsCap:!0,properties:!0}],"no-alert":"error","no-array-constructor":"error","no-async-promise-executor":"error","no-caller":"error","no-case-declarations":"error","no-class-assign":"error","no-compare-neg-zero":"error","no-cond-assign":["error","always"],"no-const-assign":"error","no-control-regex":"error","no-debugger":"error","no-delete-var":"error","no-dupe-args":"error","no-dupe-class-members":"error","no-dupe-keys":"error","no-duplicate-case":"error","no-empty":["error",{allowEmptyCatch:!0}],"no-empty-character-class":"error","no-empty-pattern":"error","no-eval":"error","no-ex-assign":"error","no-extend-native":"error","no-extra-bind":"error","no-extra-boolean-cast":"error","no-fallthrough":"error","no-func-assign":"error","no-global-assign":"error","no-implied-eval":"error","no-import-assign":"error","no-invalid-regexp":"error","no-irregular-whitespace":"error","no-iterator":"error","no-labels":["error",{allowLoop:!1,allowSwitch:!1}],"no-lone-blocks":"error","no-loss-of-precision":"error","no-misleading-character-class":"error","no-multi-str":"error","no-new":"error","no-new-func":"error","no-new-native-nonconstructor":"error","no-new-wrappers":"error","no-obj-calls":"error","no-octal":"error","no-octal-escape":"error","no-proto":"error","no-prototype-builtins":"error","no-redeclare":["error",{builtinGlobals:!1}],"no-regex-spaces":"error","no-restricted-globals":["error",{message:"Use `globalThis` instead.",name:"global"},{message:"Use `globalThis` instead.",name:"self"}],"no-restricted-properties":["error",{message:"Use `Object.getPrototypeOf` or `Object.setPrototypeOf` instead.",property:"__proto__"},{message:"Use `Object.defineProperty` instead.",property:"__defineGetter__"},{message:"Use `Object.defineProperty` instead.",property:"__defineSetter__"},{message:"Use `Object.getOwnPropertyDescriptor` instead.",property:"__lookupGetter__"},{message:"Use `Object.getOwnPropertyDescriptor` instead.",property:"__lookupSetter__"}],"no-restricted-syntax":["error","DebuggerStatement","LabeledStatement","WithStatement","TSEnumDeclaration","TSExportAssignment"],"no-self-assign":["error",{props:!0}],"no-self-compare":"error","no-sequences":"error","no-shadow-restricted-names":"error","no-sparse-arrays":"error","no-template-curly-in-string":"error","no-this-before-super":"error","no-throw-literal":"error","no-undef":"error","no-undef-init":"error","no-unexpected-multiline":"error","no-unmodified-loop-condition":"error","no-unneeded-ternary":["error",{defaultAssignment:!1}],"no-unreachable":"error","no-unreachable-loop":"error","no-unsafe-finally":"error","no-unsafe-negation":"error","no-unused-expressions":["error",{allowShortCircuit:!0,allowTaggedTemplates:!0,allowTernary:!0}],"no-unused-vars":["error",{args:"none",caughtErrors:"none",ignoreRestSiblings:!0,vars:"all"}],"no-useless-backreference":"error","no-useless-call":"error","no-useless-catch":"error","no-useless-computed-key":"error","no-useless-constructor":"error","no-useless-rename":"error","no-var":"error","no-with":"error","object-shorthand":["error","always",{avoidQuotes:!0,ignoreConstructors:!1}],"one-var":["error",{initialized:"never"}],"prefer-arrow-callback":["error",{allowNamedFunctions:!0,allowUnboundThis:!0}],"prefer-const":["error",{destructuring:"all",ignoreReadBeforeAssign:!0}],"prefer-exponentiation-operator":"error","prefer-promise-reject-errors":"error","prefer-regex-literals":["error",{disallowRedundantWrapping:!0}],"prefer-rest-params":"error","prefer-spread":"error","prefer-template":"error","symbol-description":"error","unicode-bom":["error","never"],"use-isnan":["error",{enforceForIndexOf:!0,enforceForSwitchCase:!0}],"valid-typeof":["error",{requireStringLiterals:!0}],"vars-on-top":"error",yoda:["error","never"],...t}}]}async function W(){return [{name:"2digits:jsdoc",plugins:{jsdoc:await o(import('eslint-plugin-jsdoc'))},rules:{"jsdoc/check-access":"error","jsdoc/check-param-names":"error","jsdoc/check-property-names":"error","jsdoc/check-types":"error","jsdoc/empty-tags":"error","jsdoc/implements-on-classes":"error","jsdoc/no-defaults":"error","jsdoc/no-multi-asterisks":"error","jsdoc/require-param-name":"error","jsdoc/require-property":"error","jsdoc/require-property-description":"error","jsdoc/require-property-name":"error","jsdoc/require-returns-check":"error","jsdoc/require-returns-description":"error","jsdoc/require-yields-check":"error"}}]}async function D(e={}){let{files:t=[h,O],overrides:r={},tsconfigPath:i,parserOptions:a}=e,[c,m]=await Promise.all([o(import('@next/eslint-plugin-next')),o(import('@typescript-eslint/parser'))]),u=renamePluginsInRules({...c.configs.recommended.rules,...c.configs["core-web-vitals"].rules},p);return [{name:"2digits:next/setup",plugins:{next:fixupPluginRules(c)}},{name:"2digits:next/rules",files:t,languageOptions:{parser:m,parserOptions:{ecmaFeatures:{jsx:!0},project:i,...a},sourceType:"module"},rules:{...u,"next/no-html-link-for-pages":"off",...r}}]}function R(){return [{name:"2digits:node",settings:{node:{version:">= 20.0.0"}},plugins:{node:j},rules:{"node/handle-callback-err":["error","^(err|error)$"],"node/no-deprecated-api":"error","node/no-exports-assign":"error","node/no-new-require":"error","node/no-path-concat":"error","node/no-unsupported-features/node-builtins":["error",{allowExperimental:!0}],"node/prefer-global/buffer":"error","node/prefer-global/process":"error","node/prefer-global/text-encoder":"error","node/prefer-global/url":"error","node/prefer-global/console":"error","node/prefer-global/url-search-params":"error","node/prefer-global/text-decoder":"error","node/process-exit-as-throw":"error"}}]}async function L(){return [{name:"2digits:prettier",rules:{...(await o(import('eslint-config-prettier'))).rules,"tailwindcss/classnames-order":"off"}}]}async function E(e={}){let{files:t=[h,O],overrides:r={},tsconfigPath:i,parserOptions:a,tsconfigRootDir:c,reactCompiler:m=!0}=e,[u,f,y,x,z]=await Promise.all([o(import('@eslint-react/eslint-plugin')),o(import('eslint-plugin-react-hooks')),o(import('eslint-plugin-react')),o(import('@typescript-eslint/parser')),m?o(import('eslint-plugin-react-compiler')):void 0]),b=u.configs.all.plugins,V=renamePluginsInRules({...y.configs.recommended.rules,...y.configs["jsx-runtime"].rules,...f.configs.recommended.rules,...u.configs["recommended-type-checked"].rules},p);return [{name:"2digits:react/setup",plugins:{react:y,"react-dom":b["@eslint-react/dom"],"react-extra":b["@eslint-react"],"react-hooks":fixupPluginRules(f),"react-hooks-extra":b["@eslint-react/hooks-extra"],"react-naming-convention":b["@eslint-react/naming-convention"],...m?{"react-compiler":z}:{}},settings:{react:{version:"detect"}}},{name:"2digits:react/rules",files:t,languageOptions:{parser:x,parserOptions:{ecmaFeatures:{jsx:!0},tsconfigRootDir:c,project:i,...a},sourceType:"module"},rules:{...V,...m?{"react-compiler/react-compiler":"error"}:{},"react-hooks-extra/ensure-use-memo-has-non-empty-deps":"error","react-hooks-extra/prefer-use-state-lazy-initialization":"error","react-hooks-extra/ensure-custom-hooks-using-other-hooks":"error","react-hooks-extra/ensure-use-callback-has-non-empty-deps":"error","react/jsx-curly-newline":"off","react/jsx-newline":["error",{prevent:!1}],...r}}]}var oe=renamePluginsInRules(T.configs.recommended.rules,p);function G(){return [{name:"2digits:sonar",plugins:{sonar:T},rules:oe}]}async function N(e={}){let{files:t=[I],overrides:r={},parserOptions:i,tsconfigPath:a,storybookDirectory:c=".storybook"}=e,[m,u]=await Promise.all([o(import('eslint-plugin-storybook')),o(import('@typescript-eslint/parser'))]),f={parser:u,parserOptions:{ecmaFeatures:{jsx:!0},project:a,...i},sourceType:"module"};return [{name:"2digits:storybook/setup",plugins:{storybook:fixupPluginRules(m)}},{name:"2digits:storybook/rules",files:t,languageOptions:f,rules:{"storybook/await-interactions":"error","storybook/context-in-play-function":"error","storybook/csf-component":"error","storybook/default-exports":"error","storybook/hierarchy-separator":"error","storybook/no-redundant-story-name":"error","storybook/no-stories-of":"error","storybook/no-title-property-in-meta":"error","storybook/prefer-pascal-case":"error","storybook/story-exports":"error","storybook/use-storybook-expect":"error","storybook/use-storybook-testing-library":"error",...r}},{name:"2digits:storybook/disables",files:t,rules:{"react-hooks/rules-of-hooks":"off","react/display-name":"off"}},{name:"2digits:storybook/config",files:[`${c}/main.@(js|cjs|mjs|ts)`],languageOptions:f,rules:{"storybook/no-uninstalled-addons":"error"}}]}async function U(e={}){let{overrides:t={}}=e,[r,{tailwindFunctions:i},a]=await Promise.all([o(import('eslint-plugin-tailwindcss')),o(import('@2digits/constants')),findUp(["tailwind.config.ts","tailwind.config.js"])]);return [{name:"2digits:tailwind",plugins:{tailwindcss:r},settings:{tailwindcss:{callees:i,config:a}},rules:{...r.configs.recommended.rules,...t}}]}async function B(e={}){let{overrides:t={}}=e,r=await o(import('@tanstack/eslint-plugin-query'));return [{name:"2digits:tanstack",plugins:{tanstack:fixupPluginRules(r)},rules:{"tanstack/exhaustive-deps":"error","tanstack/stable-query-client":"error","tanstack/no-rest-destructuring":"error",...t}}]}async function A(e={}){let{overrides:t={}}=e;return [{name:"2digits:turbo",plugins:{turbo:await o(import('eslint-plugin-turbo'))},rules:{"turbo/no-undeclared-env-vars":"error",...t}}]}async function M(e={}){let{overrides:t={},parserOptions:r={},tsconfigPath:i=!0}=e,[{plugin:a,configs:c,parser:m},u]=await Promise.all([o(import('typescript-eslint')),o(import('@2digits/eslint-plugin'))]),f=renamePluginsInConfigs(c.strictTypeChecked,p),y=Object.fromEntries(f.flatMap(({rules:x})=>Object.entries(x??{})));return [{name:"2digits:typescript/setup",plugins:{ts:a,"@2digits":u},languageOptions:{parser:m,parserOptions:{sourceType:"module",tsconfigRootDir:process.cwd(),project:i,...r}}},{name:"2digits:typescript/rules",files:[F],rules:{...y,"ts/restrict-template-expressions":["error",{allowNumber:!0}],"ts/ban-ts-comment":["error",{"ts-ignore":"allow-with-description"}],"ts/consistent-type-exports":["error"],"ts/consistent-type-imports":["error",{prefer:"type-imports",disallowTypeAnnotations:!1,fixStyle:"inline-type-imports"}],"ts/no-empty-interface":["error",{allowSingleExtends:!0}],"ts/no-explicit-any":["error"],"ts/no-import-type-side-effects":["error"],"ts/no-misused-promises":"off","ts/no-confusing-void-expression":["error",{ignoreArrowShorthand:!0,ignoreVoidOperator:!0}],"ts/no-unused-vars":["error",{ignoreRestSiblings:!0,argsIgnorePattern:"^_",varsIgnorePattern:"^_"}],...u.configs.recommended.rules,...t}},{files:["**/*.d.ts"],name:"2digits:typescript/disables/dts",rules:{"unicorn/no-abusive-eslint-disable":"off","no-duplicate-imports":"off","no-restricted-syntax":"off","ts/no-unused-vars":"off"}},{files:["**/*.{test,spec}.ts?(x)"],name:"2digits:typescript/disables/test",rules:{"no-unused-expressions":"off"}},{files:["**/*.js","**/*.cjs","**/*.cts"],name:"2digits:typescript/disables/cjs",rules:{"ts/no-require-imports":"off","ts/no-var-requires":"off"}}]}function X(){return [{name:"2digits:unicorn",plugins:{unicorn:k},rules:{...k.configs.recommended.rules,"unicorn/filename-case":["off"],"unicorn/prefer-module":["off"],"unicorn/prevent-abbreviations":["off"],"unicorn/prefer-ternary":["error","only-single-line"],"unicorn/no-useless-undefined":["error",{checkArguments:!1,checkArrowFunctionBody:!1}],"unicorn/prefer-top-level-await":["off"]}}]}function g(e,t){return typeof e=="boolean"?e:e?.enable??t??!1}function d(e){if(typeof e=="boolean"||e===void 0)return {};let{enable:t,...r}=e;return r}function pe(e={},...t){let r=new FlatConfigComposer(_(e.ignores),q(e.js),R(),C(),W(),X(),G());g(e.turbo,isPackageExists("turbo"))&&(r=r.append(A(d(e.turbo))));let{overrides:i,...a}=d(e.ts);return g(e.ts,isPackageExists("typescript"))&&(r=r.append(M(d(e.ts)))),g(e.react,isPackageExists("react"))&&(r=r.append(E({...d(e.react),...a}))),g(e.next,isPackageExists("next"))&&(r=r.append(D({...d(e.next),...a}))),g(e.storybook,isPackageExists("storybook"))&&(r=r.append(N({...d(e.storybook),...a}))),g(e.tailwind,isPackageExists("tailwindcss"))&&(r=r.append(U(d(e.tailwind)))),g(e.tanstack,isPackageExists("react-query")||isPackageExists("@tanstack/react-query")||isPackageExists("@tanstack/react-query-devtools"))&&(r=r.append(B(d(e.tanstack)))),isPackageExists("graphql")&&(r=r.append(S(d(e.graphql)))),r=r.append(...t),isPackageExists("prettier")&&(r=r.append(L())),r.renamePlugins(p).toConfigs()}
|
|
12
13
|
|
|
13
|
-
export {
|
|
14
|
+
export { C as comments, pe as default, S as graphql, _ as ignores, q as javascript, W as jsdoc, D as next, R as node, L as prettier, E as react, G as sonar, N as storybook, U as tailwind, B as tanstack, A as turbo, pe as twoDigits, M as typescript, X as unicorn };
|
|
14
15
|
//# sourceMappingURL=out.js.map
|
|
15
16
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/plugins.ts","../src/configs/comments.ts","../src/configs/ignores.ts","../src/globs.ts","../src/utils.ts","../src/configs/javascript.ts","../src/configs/jsdoc.ts","../src/configs/next.ts","../src/constants.ts","../src/configs/node.ts","../src/configs/prettier.ts","../src/configs/react.ts","../src/configs/storybook.ts","../src/configs/tailwind.ts","../src/configs/tanstack.ts","../src/configs/turbo.ts","../src/configs/typescript.ts","../src/configs/unicorn.ts","../src/factory.ts"],"names":["default","comments","composer","GLOB_SRC","GLOB_TS","GLOB_TSX","GLOB_STORIES","GLOB_EXCLUDE","interopDefault","m","resolved","ignores","options","eslint","globals","javascript","overrides","jsdoc","fixupPluginRules","renamePluginsInRules","PluginNameMap","next","files","tsconfigPath","parserOptions","parser","recommended","node","prettier","react","tsconfigRootDir","pluginReact","pluginReactHooks","plugins","storybook","storybookDirectory","languageOptions","findUp","tailwind","tailwindcss","tailwindFunctions","config","tanstack","turbo","renamePluginsInConfigs","typescript","plugin","configs","twoDigits","strictConfig","rules","unicorn","FlatConfigComposer","isPackageExists","enabled","defaults","_","rest","userConfig","typescriptOptions"],"mappings":"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","sourcesContent":["export { default as pluginUnicorn } from 'eslint-plugin-unicorn';\nexport { default as pluginComments } from 'eslint-plugin-eslint-comments';\nexport { default as pluginNode } from 'eslint-plugin-n';\n","import { pluginComments } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function comments(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:comments',\n plugins: {\n 'eslint-comments': pluginComments,\n },\n rules: {\n 'eslint-comments/no-aggregating-enable': 'error',\n 'eslint-comments/no-duplicate-disable': 'error',\n 'eslint-comments/no-unlimited-disable': 'error',\n 'eslint-comments/no-unused-enable': 'error',\n 'eslint-comments/no-unused-disable': 'error',\n },\n },\n ];\n}\n","import type { FlatGitignoreOptions } from 'eslint-config-flat-gitignore';\nimport { composer } from 'eslint-flat-config-utils';\n\nimport { GLOB_EXCLUDE } from '../globs';\nimport type { TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function ignores(options: FlatGitignoreOptions = {}): Promise<TypedFlatConfigItem[]> {\n return composer(\n {\n ignores: GLOB_EXCLUDE,\n name: '2digits:ignores',\n },\n interopDefault(import('eslint-config-flat-gitignore')).then((m) => ({\n ...m(options),\n name: '2digits:gitignore',\n })),\n );\n}\n","export const GLOB_SRC = '**/*.?([cm])[jt]s?(x)';\n\nexport const GLOB_TS = '**/*.?([cm])ts';\nexport const GLOB_TSX = '**/*.?([cm])tsx';\n\nexport const GLOB_STORIES = '**/*.stories.tsx';\n\nexport const GLOB_EXCLUDE = [\n '**/node_modules',\n '**/dist',\n '**/package-lock.json',\n '**/yarn.lock',\n '**/pnpm-lock.yaml',\n '**/bun.lockb',\n\n '**/output',\n '**/coverage',\n '**/temp',\n '**/.temp',\n '**/tmp',\n '**/.tmp',\n '**/.history',\n '**/.vitepress/cache',\n '**/.nuxt',\n '**/.next',\n '**/.vercel',\n '**/.changeset',\n '**/.idea',\n '**/.cache',\n '**/.output',\n '**/.vite-inspect',\n '**/.yarn',\n\n '**/CHANGELOG*.md',\n '**/*.min.*',\n '**/LICENSE*',\n '**/__snapshots__',\n '**/auto-import?(s).d.ts',\n '**/components.d.ts',\n];\n","import type { Awaitable } from 'eslint-flat-config-utils';\n\nexport async function interopDefault<T>(\n m: Awaitable<T>,\n): Promise<T extends { default: infer U } ? U : T> {\n const resolved = await m;\n\n return ((resolved as Record<string, unknown>).default || resolved) as never;\n}\n","import eslint from '@eslint/js';\nimport globals from 'globals';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\n\nexport function javascript(options: OptionsOverrides = {}): TypedFlatConfigItem[] {\n const { overrides = {} } = options;\n\n return [\n {\n name: '2digits:javascript',\n languageOptions: {\n ecmaVersion: 2022,\n globals: {\n ...globals.browser,\n ...globals.es2021,\n ...globals.node,\n document: 'readonly',\n navigator: 'readonly',\n window: 'readonly',\n },\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n ecmaVersion: 2022,\n sourceType: 'module',\n },\n sourceType: 'module',\n },\n linterOptions: {\n reportUnusedDisableDirectives: true,\n },\n rules: {\n ...eslint.configs.recommended.rules,\n\n 'accessor-pairs': ['error', { enforceForClassMembers: true, setWithoutGet: true }],\n 'array-callback-return': 'error',\n 'block-scoped-var': 'error',\n 'constructor-super': 'error',\n 'default-case-last': 'error',\n 'dot-notation': ['error', { allowKeywords: true }],\n eqeqeq: ['error', 'smart'],\n 'new-cap': ['error', { capIsNew: false, newIsCap: true, properties: true }],\n 'no-alert': 'error',\n 'no-array-constructor': 'error',\n 'no-async-promise-executor': 'error',\n 'no-caller': 'error',\n 'no-case-declarations': 'error',\n 'no-class-assign': 'error',\n 'no-compare-neg-zero': 'error',\n 'no-cond-assign': ['error', 'always'],\n 'no-const-assign': 'error',\n 'no-control-regex': 'error',\n 'no-debugger': 'error',\n 'no-delete-var': 'error',\n 'no-dupe-args': 'error',\n 'no-dupe-class-members': 'error',\n 'no-dupe-keys': 'error',\n 'no-duplicate-case': 'error',\n 'no-empty': ['error', { allowEmptyCatch: true }],\n 'no-empty-character-class': 'error',\n 'no-empty-pattern': 'error',\n 'no-eval': 'error',\n 'no-ex-assign': 'error',\n 'no-extend-native': 'error',\n 'no-extra-bind': 'error',\n 'no-extra-boolean-cast': 'error',\n 'no-fallthrough': 'error',\n 'no-func-assign': 'error',\n 'no-global-assign': 'error',\n 'no-implied-eval': 'error',\n 'no-import-assign': 'error',\n 'no-invalid-regexp': 'error',\n 'no-irregular-whitespace': 'error',\n 'no-iterator': 'error',\n 'no-labels': ['error', { allowLoop: false, allowSwitch: false }],\n 'no-lone-blocks': 'error',\n 'no-loss-of-precision': 'error',\n 'no-misleading-character-class': 'error',\n 'no-multi-str': 'error',\n 'no-new': 'error',\n 'no-new-func': 'error',\n 'no-new-native-nonconstructor': 'error',\n 'no-new-wrappers': 'error',\n 'no-obj-calls': 'error',\n 'no-octal': 'error',\n 'no-octal-escape': 'error',\n 'no-proto': 'error',\n 'no-prototype-builtins': 'error',\n 'no-redeclare': ['error', { builtinGlobals: false }],\n 'no-regex-spaces': 'error',\n 'no-restricted-globals': [\n 'error',\n { message: 'Use `globalThis` instead.', name: 'global' },\n { message: 'Use `globalThis` instead.', name: 'self' },\n ],\n 'no-restricted-properties': [\n 'error',\n {\n message: 'Use `Object.getPrototypeOf` or `Object.setPrototypeOf` instead.',\n property: '__proto__',\n },\n { message: 'Use `Object.defineProperty` instead.', property: '__defineGetter__' },\n { message: 'Use `Object.defineProperty` instead.', property: '__defineSetter__' },\n {\n message: 'Use `Object.getOwnPropertyDescriptor` instead.',\n property: '__lookupGetter__',\n },\n {\n message: 'Use `Object.getOwnPropertyDescriptor` instead.',\n property: '__lookupSetter__',\n },\n ],\n 'no-restricted-syntax': [\n 'error',\n 'DebuggerStatement',\n 'LabeledStatement',\n 'WithStatement',\n 'TSEnumDeclaration',\n 'TSExportAssignment',\n ],\n 'no-self-assign': ['error', { props: true }],\n 'no-self-compare': 'error',\n 'no-sequences': 'error',\n 'no-shadow-restricted-names': 'error',\n 'no-sparse-arrays': 'error',\n 'no-template-curly-in-string': 'error',\n 'no-this-before-super': 'error',\n 'no-throw-literal': 'error',\n 'no-undef': 'error',\n 'no-undef-init': 'error',\n 'no-unexpected-multiline': 'error',\n 'no-unmodified-loop-condition': 'error',\n 'no-unneeded-ternary': ['error', { defaultAssignment: false }],\n 'no-unreachable': 'error',\n 'no-unreachable-loop': 'error',\n 'no-unsafe-finally': 'error',\n 'no-unsafe-negation': 'error',\n 'no-unused-expressions': [\n 'error',\n {\n allowShortCircuit: true,\n allowTaggedTemplates: true,\n allowTernary: true,\n },\n ],\n 'no-unused-vars': [\n 'error',\n {\n args: 'none',\n caughtErrors: 'none',\n ignoreRestSiblings: true,\n vars: 'all',\n },\n ],\n 'no-useless-backreference': 'error',\n 'no-useless-call': 'error',\n 'no-useless-catch': 'error',\n 'no-useless-computed-key': 'error',\n 'no-useless-constructor': 'error',\n 'no-useless-rename': 'error',\n 'no-var': 'error',\n 'no-with': 'error',\n 'object-shorthand': [\n 'error',\n 'always',\n {\n avoidQuotes: true,\n ignoreConstructors: false,\n },\n ],\n 'one-var': ['error', { initialized: 'never' }],\n 'prefer-arrow-callback': [\n 'error',\n {\n allowNamedFunctions: true,\n allowUnboundThis: true,\n },\n ],\n 'prefer-const': [\n 'error',\n {\n destructuring: 'all',\n ignoreReadBeforeAssign: true,\n },\n ],\n 'prefer-exponentiation-operator': 'error',\n 'prefer-promise-reject-errors': 'error',\n 'prefer-regex-literals': ['error', { disallowRedundantWrapping: true }],\n 'prefer-rest-params': 'error',\n 'prefer-spread': 'error',\n 'prefer-template': 'error',\n 'symbol-description': 'error',\n 'unicode-bom': ['error', 'never'],\n 'use-isnan': ['error', { enforceForIndexOf: true, enforceForSwitchCase: true }],\n 'valid-typeof': ['error', { requireStringLiterals: true }],\n 'vars-on-top': 'error',\n yoda: ['error', 'never'],\n\n ...overrides,\n },\n },\n ];\n}\n","import type { TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function jsdoc(): Promise<TypedFlatConfigItem[]> {\n return [\n {\n name: '2digits:jsdoc',\n plugins: {\n jsdoc: await interopDefault(import('eslint-plugin-jsdoc')),\n },\n rules: {\n 'jsdoc/check-access': 'error',\n 'jsdoc/check-param-names': 'error',\n 'jsdoc/check-property-names': 'error',\n 'jsdoc/check-types': 'error',\n 'jsdoc/empty-tags': 'error',\n 'jsdoc/implements-on-classes': 'error',\n 'jsdoc/no-defaults': 'error',\n 'jsdoc/no-multi-asterisks': 'error',\n 'jsdoc/require-param-name': 'error',\n 'jsdoc/require-property': 'error',\n 'jsdoc/require-property-description': 'error',\n 'jsdoc/require-property-name': 'error',\n 'jsdoc/require-returns-check': 'error',\n 'jsdoc/require-returns-description': 'error',\n 'jsdoc/require-yields-check': 'error',\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\nimport { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_TS, GLOB_TSX } from '../globs';\nimport type { OptionsTypeScriptWithTypes, OptionsWithFiles, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function next(\n options: OptionsWithFiles & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const { files = [GLOB_TS, GLOB_TSX], overrides = {}, tsconfigPath, parserOptions } = options;\n\n const [next, parser] = await Promise.all([\n interopDefault(import('@next/eslint-plugin-next')),\n interopDefault(import('@typescript-eslint/parser')),\n ]);\n\n const recommended = renamePluginsInRules(\n {\n ...next.configs.recommended.rules,\n ...next.configs['core-web-vitals'].rules,\n },\n PluginNameMap,\n );\n\n return [\n {\n name: '2digits:next/setup',\n plugins: {\n next: fixupPluginRules(next as never),\n },\n },\n {\n name: '2digits:next/rules',\n files,\n languageOptions: {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n project: tsconfigPath,\n ...(parserOptions as object),\n },\n sourceType: 'module',\n },\n rules: {\n ...recommended,\n\n 'next/no-html-link-for-pages': 'off',\n\n ...overrides,\n },\n },\n ];\n}\n","export const PluginNameMap = {\n '@next/next': 'next',\n '@eslint-react/naming-convention': 'react-naming-convention',\n '@eslint-react/hooks-extra': 'react-hooks-extra',\n '@eslint-react/dom': 'react-dom',\n '@eslint-react': 'react-extra',\n 'react-hooks': 'react-hooks',\n react: 'react',\n '@typescript-eslint': 'ts',\n node: 'node',\n 'eslint-comments': 'eslint-comments',\n storybook: 'storybook',\n turbo: 'turbo',\n jsdoc: 'jsdoc',\n unicorn: 'unicorn',\n tailwindcss: 'tailwindcss',\n '@tanstack/query': 'tanstack',\n '@2digits': '@2digits',\n} as const;\n","import { pluginNode } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function node(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:node',\n settings: {\n node: {\n version: '>= 20.0.0',\n },\n },\n plugins: {\n node: pluginNode,\n },\n rules: {\n 'node/handle-callback-err': ['error', '^(err|error)$'],\n 'node/no-deprecated-api': 'error',\n 'node/no-exports-assign': 'error',\n 'node/no-new-require': 'error',\n 'node/no-path-concat': 'error',\n 'node/no-unsupported-features/node-builtins': ['error', { allowExperimental: true }],\n 'node/prefer-global/buffer': 'error',\n 'node/prefer-global/process': 'error',\n 'node/prefer-global/text-encoder': 'error',\n 'node/prefer-global/url': 'error',\n 'node/prefer-global/console': 'error',\n 'node/prefer-global/url-search-params': 'error',\n 'node/prefer-global/text-decoder': 'error',\n 'node/process-exit-as-throw': 'error',\n },\n },\n ];\n}\n","import type { TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function prettier(): Promise<TypedFlatConfigItem[]> {\n const prettier = await interopDefault(import('eslint-config-prettier'));\n\n return [\n {\n name: '2digits:prettier',\n rules: prettier.rules,\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\nimport { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_TS, GLOB_TSX } from '../globs';\nimport type { OptionsTypeScriptWithTypes, OptionsWithFiles, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function react(\n options: OptionsWithFiles & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const {\n files = [GLOB_TS, GLOB_TSX],\n overrides = {},\n tsconfigPath,\n parserOptions,\n tsconfigRootDir,\n } = options;\n\n const [pluginReact, pluginReactHooks, react, parser] = await Promise.all([\n interopDefault(import('@eslint-react/eslint-plugin')),\n interopDefault(import('eslint-plugin-react-hooks')),\n interopDefault(import('eslint-plugin-react')),\n interopDefault(import('@typescript-eslint/parser')),\n ]);\n\n const plugins = pluginReact.configs.all.plugins;\n\n const recommended = renamePluginsInRules(\n {\n ...react.configs.recommended.rules,\n ...react.configs['jsx-runtime'].rules,\n ...pluginReactHooks.configs.recommended.rules,\n ...pluginReact.configs['recommended-type-checked'].rules,\n },\n PluginNameMap,\n );\n\n return [\n {\n name: '2digits:react/setup',\n plugins: {\n react,\n 'react-dom': plugins['@eslint-react/dom'],\n 'react-extra': plugins['@eslint-react'],\n 'react-hooks': fixupPluginRules(pluginReactHooks as never),\n 'react-hooks-extra': plugins['@eslint-react/hooks-extra'],\n 'react-naming-convention': plugins['@eslint-react/naming-convention'],\n },\n settings: {\n react: {\n version: 'detect',\n },\n },\n },\n {\n name: '2digits:react/rules',\n files,\n languageOptions: {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n tsconfigRootDir,\n project: tsconfigPath,\n ...parserOptions,\n },\n sourceType: 'module',\n },\n rules: {\n ...recommended,\n\n 'react-hooks-extra/ensure-use-memo-has-non-empty-deps': 'error',\n 'react-hooks-extra/prefer-use-state-lazy-initialization': 'error',\n 'react-hooks-extra/ensure-custom-hooks-using-other-hooks': 'error',\n 'react-hooks-extra/ensure-use-callback-has-non-empty-deps': 'error',\n\n 'react/jsx-curly-newline': 'off',\n 'react/jsx-newline': ['error', { prevent: false }],\n\n ...overrides,\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\n\nimport { GLOB_STORIES } from '../globs';\nimport type {\n OptionsTypeScriptWithTypes,\n OptionsWithStorybook,\n TypedFlatConfigItem,\n} from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function storybook(\n options: OptionsWithStorybook & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const {\n files = [GLOB_STORIES],\n overrides = {},\n parserOptions,\n tsconfigPath,\n storybookDirectory = '.storybook',\n } = options;\n\n const [storybook, parser] = await Promise.all([\n interopDefault(import('eslint-plugin-storybook')),\n interopDefault(import('@typescript-eslint/parser')),\n ]);\n\n const languageOptions = {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n project: tsconfigPath,\n ...(parserOptions as object),\n },\n sourceType: 'module' as const,\n };\n\n return [\n {\n name: '2digits:storybook/setup',\n plugins: {\n storybook: fixupPluginRules(storybook as never),\n },\n },\n {\n name: '2digits:storybook/rules',\n files,\n languageOptions,\n rules: {\n 'storybook/await-interactions': 'error',\n 'storybook/context-in-play-function': 'error',\n 'storybook/csf-component': 'error',\n 'storybook/default-exports': 'error',\n 'storybook/hierarchy-separator': 'error',\n 'storybook/no-redundant-story-name': 'error',\n 'storybook/no-stories-of': 'error',\n 'storybook/no-title-property-in-meta': 'error',\n 'storybook/prefer-pascal-case': 'error',\n 'storybook/story-exports': 'error',\n 'storybook/use-storybook-expect': 'error',\n 'storybook/use-storybook-testing-library': 'error',\n\n ...overrides,\n },\n },\n {\n name: '2digits:storybook/disables',\n files,\n rules: {\n 'react-hooks/rules-of-hooks': 'off',\n 'react/display-name': 'off',\n },\n },\n {\n name: '2digits:storybook/config',\n files: [`${storybookDirectory}/main.@(js|cjs|mjs|ts)`],\n languageOptions,\n rules: {\n 'storybook/no-uninstalled-addons': 'error',\n },\n },\n ];\n}\n","import { findUp } from 'find-up';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function tailwind(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const [tailwindcss, { tailwindFunctions }, config] = await Promise.all([\n interopDefault(import('eslint-plugin-tailwindcss')),\n interopDefault(import('@2digits/constants')),\n findUp(['tailwind.config.ts', 'tailwind.config.js']),\n ]);\n\n return [\n {\n name: '2digits:tailwind',\n plugins: {\n tailwindcss,\n },\n settings: {\n tailwindcss: {\n callees: tailwindFunctions,\n config,\n },\n },\n rules: {\n ...tailwindcss.configs.recommended.rules,\n 'tailwindcss/classnames-order': 'off',\n\n ...overrides,\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function tanstack(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const tanstack = await interopDefault(import('@tanstack/eslint-plugin-query'));\n\n return [\n {\n name: '2digits:tanstack',\n plugins: {\n tanstack: fixupPluginRules(tanstack as never),\n },\n rules: {\n 'tanstack/exhaustive-deps': 'error',\n 'tanstack/stable-query-client': 'error',\n 'tanstack/no-rest-destructuring': 'error',\n\n ...overrides,\n },\n },\n ];\n}\n","import type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function turbo(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const turbo = await interopDefault(import('eslint-plugin-turbo'));\n\n return [\n {\n name: '2digits:turbo',\n plugins: {\n turbo,\n },\n rules: {\n 'turbo/no-undeclared-env-vars': 'error',\n\n ...overrides,\n },\n },\n ];\n}\n","import { renamePluginsInConfigs } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_SRC } from '../globs';\nimport type { OptionsTypeScriptWithTypes, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function typescript(\n options: OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const { overrides = {}, parserOptions = {}, tsconfigPath = true } = options;\n\n const [{ plugin, configs, parser }, twoDigits] = await Promise.all([\n interopDefault(import('typescript-eslint')),\n interopDefault(import('@2digits/eslint-plugin')),\n ]);\n\n const strictConfig = renamePluginsInConfigs(configs.strictTypeChecked as never, PluginNameMap);\n\n const rules = Object.fromEntries(\n strictConfig.flatMap(({ rules }) => Object.entries(rules ?? {})),\n );\n\n return [\n {\n name: '2digits:typescript/setup',\n plugins: {\n ts: plugin,\n '@2digits': twoDigits,\n },\n languageOptions: {\n parser,\n parserOptions: {\n sourceType: 'module',\n tsconfigRootDir: process.cwd(),\n project: tsconfigPath,\n ...parserOptions,\n },\n },\n },\n\n {\n name: '2digits:typescript/rules',\n files: [GLOB_SRC],\n rules: {\n ...rules,\n 'ts/restrict-template-expressions': ['error', { allowNumber: true }],\n 'ts/ban-ts-comment': ['error', { 'ts-ignore': 'allow-with-description' }],\n 'ts/consistent-type-exports': ['error'],\n 'ts/consistent-type-imports': [\n 'error',\n {\n prefer: 'type-imports',\n disallowTypeAnnotations: false,\n fixStyle: 'inline-type-imports',\n },\n ],\n 'ts/no-empty-interface': ['error', { allowSingleExtends: true }],\n 'ts/no-explicit-any': ['error'],\n 'ts/no-import-type-side-effects': ['error'],\n 'ts/no-misused-promises': 'off',\n 'ts/no-confusing-void-expression': [\n 'error',\n { ignoreArrowShorthand: true, ignoreVoidOperator: true },\n ],\n 'ts/no-unused-vars': [\n 'error',\n { ignoreRestSiblings: true, argsIgnorePattern: '^_', varsIgnorePattern: '^_' },\n ],\n\n ...(twoDigits.configs.recommended.rules as object),\n\n ...overrides,\n },\n },\n {\n files: ['**/*.d.ts'],\n name: '2digits:typescript/disables/dts',\n rules: {\n 'unicorn/no-abusive-eslint-disable': 'off',\n 'no-duplicate-imports': 'off',\n 'no-restricted-syntax': 'off',\n 'ts/no-unused-vars': 'off',\n },\n },\n {\n files: ['**/*.{test,spec}.ts?(x)'],\n name: '2digits:typescript/disables/test',\n rules: {\n 'no-unused-expressions': 'off',\n },\n },\n {\n files: ['**/*.js', '**/*.cjs', '**/*.cts'],\n name: '2digits:typescript/disables/cjs',\n rules: {\n 'ts/no-require-imports': 'off',\n 'ts/no-var-requires': 'off',\n },\n },\n ];\n}\n","import { pluginUnicorn } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function unicorn(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:unicorn',\n plugins: {\n unicorn: pluginUnicorn,\n },\n rules: {\n ...pluginUnicorn.configs.recommended.rules,\n\n 'unicorn/filename-case': ['off'],\n 'unicorn/prefer-module': ['off'],\n 'unicorn/prevent-abbreviations': ['off'],\n 'unicorn/prefer-ternary': ['error', 'only-single-line'],\n 'unicorn/no-useless-undefined': [\n 'error',\n {\n checkArguments: false,\n checkArrowFunctionBody: false,\n },\n ],\n 'unicorn/prefer-top-level-await': ['off'],\n },\n },\n ];\n}\n","import type { FlatGitignoreOptions } from 'eslint-config-flat-gitignore';\nimport { FlatConfigComposer } from 'eslint-flat-config-utils';\nimport { isPackageExists } from 'local-pkg';\n\nimport {\n comments,\n ignores,\n javascript,\n jsdoc,\n next,\n node,\n prettier,\n react,\n storybook,\n tailwind,\n tanstack,\n turbo,\n typescript,\n unicorn,\n} from './configs';\nimport { PluginNameMap } from './constants';\nimport type {\n ConfigNames,\n OptionsOverrides,\n OptionsTypeScriptWithTypes,\n OptionsWithFiles,\n OptionsWithStorybook,\n TypedFlatConfigItem,\n} from './types';\n\ntype SharedOptions<T = unknown> = T & {\n enable?: boolean;\n};\n\ninterface ESLint2DigitsOptions {\n ignores?: FlatGitignoreOptions;\n turbo?: SharedOptions<OptionsOverrides> | boolean;\n js?: OptionsOverrides;\n ts?: SharedOptions<OptionsTypeScriptWithTypes> | boolean;\n react?: SharedOptions<OptionsWithFiles> | boolean;\n next?: SharedOptions<OptionsWithFiles> | boolean;\n tailwind?: SharedOptions<OptionsOverrides> | boolean;\n storybook?: SharedOptions<OptionsWithStorybook> | boolean;\n tanstack?: SharedOptions<OptionsOverrides> | boolean;\n}\n\nfunction enabled<T extends SharedOptions>(\n options: T | boolean | undefined,\n defaults?: boolean | undefined,\n): options is T {\n if (typeof options === 'boolean') return options;\n return options?.enable ?? defaults ?? false;\n}\n\nfunction config<T>(options: SharedOptions<T> | undefined | boolean): T {\n if (typeof options === 'boolean' || options === undefined) return {} as T;\n const { enable: _, ...rest } = options;\n return rest as T;\n}\n\nexport function twoDigits(\n options: ESLint2DigitsOptions = {},\n ...userConfig: TypedFlatConfigItem[]\n): Promise<TypedFlatConfigItem[]> {\n let composer = new FlatConfigComposer<TypedFlatConfigItem, ConfigNames>(\n ignores(options.ignores),\n javascript(options.js),\n node(),\n comments(),\n jsdoc(),\n unicorn(),\n );\n\n if (enabled(options.turbo, isPackageExists('turbo'))) {\n composer = composer.append(turbo(config(options.turbo)));\n }\n\n const { overrides: _, ...typescriptOptions } = config(options.ts);\n\n if (enabled(options.ts, isPackageExists('typescript'))) {\n composer = composer.append(typescript(config(options.ts)));\n }\n\n if (enabled(options.react, isPackageExists('react'))) {\n composer = composer.append(\n react({\n ...config(options.react),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.next, isPackageExists('next'))) {\n composer = composer.append(\n next({\n ...config(options.next),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.storybook, isPackageExists('storybook'))) {\n composer = composer.append(\n storybook({\n ...config(options.storybook),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.tailwind, isPackageExists('tailwindcss'))) {\n composer = composer.append(tailwind(config(options.tailwind)));\n }\n\n if (\n enabled(\n options.tanstack,\n isPackageExists('react-query') ||\n isPackageExists('@tanstack/react-query') ||\n isPackageExists('@tanstack/react-query-devtools'),\n )\n ) {\n composer = composer.append(tanstack(config(options.tanstack)));\n }\n\n composer = composer.append(...userConfig);\n\n if (isPackageExists('prettier')) {\n composer = composer.append(prettier());\n }\n\n return composer.renamePlugins(PluginNameMap).toConfigs();\n}\n"]}
|
|
1
|
+
{"version":3,"sources":["../src/plugins.ts","../src/configs/comments.ts","../src/configs/graphql.ts","../src/constants.ts","../src/utils.ts","../src/configs/ignores.ts","../src/globs.ts","../src/configs/javascript.ts","../src/configs/jsdoc.ts","../src/configs/next.ts","../src/configs/node.ts","../src/configs/prettier.ts","../src/configs/react.ts","../src/configs/sonar.ts","../src/configs/storybook.ts","../src/configs/tailwind.ts","../src/configs/tanstack.ts","../src/configs/turbo.ts","../src/configs/typescript.ts","../src/configs/unicorn.ts","../src/factory.ts"],"names":["default","comments","fixupPluginRules","renamePluginsInRules","PluginNameMap","interopDefault","m","resolved","graphql","options","overrides","files","gql","recommended","composer","GLOB_SRC","GLOB_TS","GLOB_TSX","GLOB_STORIES","GLOB_EXCLUDE","ignores","gitIgnore","eslint","globals","javascript","jsdoc","next","tsconfigPath","parserOptions","parser","node","prettier","react","tsconfigRootDir","reactCompiler","pluginReact","pluginReactHooks","pluginReactCompiler","plugins","rules","sonar","storybook","storybookDirectory","languageOptions","findUp","tailwind","tailwindcss","tailwindFunctions","config","tanstack","turbo","renamePluginsInConfigs","typescript","plugin","configs","twoDigits","strictConfig","unicorn","FlatConfigComposer","isPackageExists","enabled","defaults","_","rest","userConfig","typescriptOptions"],"mappings":"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","sourcesContent":["export { default as pluginUnicorn } from 'eslint-plugin-unicorn';\nexport { default as pluginComments } from 'eslint-plugin-eslint-comments';\nexport { default as pluginNode } from 'eslint-plugin-n';\nexport { default as pluginSonar } from 'eslint-plugin-sonarjs';\n","import { pluginComments } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function comments(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:comments',\n plugins: {\n 'eslint-comments': pluginComments,\n },\n rules: {\n 'eslint-comments/no-aggregating-enable': 'error',\n 'eslint-comments/no-duplicate-disable': 'error',\n 'eslint-comments/no-unlimited-disable': 'error',\n 'eslint-comments/no-unused-enable': 'error',\n 'eslint-comments/no-unused-disable': 'error',\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\nimport { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport type { OptionsWithFiles, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function graphql(options: OptionsWithFiles = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {}, files = ['**/*.graphql', '**/*.gql'] } = options;\n\n const gql = await interopDefault(import('@graphql-eslint/eslint-plugin'));\n\n const recommended = renamePluginsInRules(\n gql.flatConfigs['operations-recommended'].rules,\n PluginNameMap,\n );\n\n return [\n {\n name: '2digits:graphql',\n plugins: {\n gql: fixupPluginRules(gql as never),\n },\n languageOptions: {\n parser: { ...gql, meta: { name: 'graphql' } },\n },\n files,\n rules: {\n ...recommended,\n\n ...overrides,\n },\n },\n ];\n}\n","export const PluginNameMap = {\n '@next/next': 'next',\n '@eslint-react/naming-convention': 'react-naming-convention',\n '@eslint-react/hooks-extra': 'react-hooks-extra',\n '@eslint-react/dom': 'react-dom',\n '@eslint-react': 'react-extra',\n 'react-hooks': 'react-hooks',\n 'react-compiler': 'react-compiler',\n react: 'react',\n '@typescript-eslint': 'ts',\n node: 'node',\n 'eslint-comments': 'eslint-comments',\n storybook: 'storybook',\n turbo: 'turbo',\n jsdoc: 'jsdoc',\n unicorn: 'unicorn',\n tailwindcss: 'tailwindcss',\n '@tanstack/query': 'tanstack',\n '@2digits': '@2digits',\n '@graphql-eslint': 'gql',\n sonarjs: 'sonar',\n} as const;\n","import type { Awaitable } from 'eslint-flat-config-utils';\n\nexport async function interopDefault<T>(\n m: Awaitable<T>,\n): Promise<T extends { default: infer U } ? U : T> {\n const resolved = await m;\n\n return ((resolved as Record<string, unknown>).default || resolved) as never;\n}\n","import { composer } from 'eslint-flat-config-utils';\n\nimport { GLOB_EXCLUDE } from '../globs';\nimport type { OptionsWithIgnores, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function ignores(options: OptionsWithIgnores = {}): Promise<TypedFlatConfigItem[]> {\n const { gitIgnore, ignores = [] } = options;\n\n return composer(\n {\n ignores: [GLOB_EXCLUDE, ignores].flat(),\n name: '2digits:ignores',\n },\n interopDefault(import('eslint-config-flat-gitignore')).then((m) => ({\n ...m(gitIgnore),\n name: '2digits:gitignore',\n })),\n );\n}\n","export const GLOB_SRC = '**/*.?([cm])[jt]s?(x)';\n\nexport const GLOB_TS = '**/*.?([cm])ts';\nexport const GLOB_TSX = '**/*.?([cm])tsx';\n\nexport const GLOB_STORIES = '**/*.stories.tsx';\n\nexport const GLOB_EXCLUDE = [\n '**/node_modules',\n '**/dist',\n '**/package-lock.json',\n '**/yarn.lock',\n '**/pnpm-lock.yaml',\n '**/bun.lockb',\n\n '**/output',\n '**/coverage',\n '**/temp',\n '**/.temp',\n '**/tmp',\n '**/.tmp',\n '**/.history',\n '**/.vitepress/cache',\n '**/.nuxt',\n '**/.next',\n '**/.vercel',\n '**/.changeset',\n '**/.idea',\n '**/.cache',\n '**/.output',\n '**/.vite-inspect',\n '**/.yarn',\n\n '**/CHANGELOG*.md',\n '**/*.min.*',\n '**/LICENSE*',\n '**/__snapshots__',\n '**/auto-import?(s).d.ts',\n '**/components.d.ts',\n] as const;\n","import eslint from '@eslint/js';\nimport globals from 'globals';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\n\nexport function javascript(options: OptionsOverrides = {}): TypedFlatConfigItem[] {\n const { overrides = {} } = options;\n\n return [\n {\n name: '2digits:javascript',\n languageOptions: {\n ecmaVersion: 2022,\n globals: {\n ...globals.browser,\n ...globals.es2021,\n ...globals.node,\n document: 'readonly',\n navigator: 'readonly',\n window: 'readonly',\n },\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n ecmaVersion: 2022,\n sourceType: 'module',\n },\n sourceType: 'module',\n },\n linterOptions: {\n reportUnusedDisableDirectives: true,\n },\n rules: {\n ...eslint.configs.recommended.rules,\n\n 'accessor-pairs': ['error', { enforceForClassMembers: true, setWithoutGet: true }],\n 'array-callback-return': 'error',\n 'block-scoped-var': 'error',\n 'constructor-super': 'error',\n 'default-case-last': 'error',\n 'dot-notation': ['error', { allowKeywords: true }],\n eqeqeq: ['error', 'smart'],\n 'new-cap': ['error', { capIsNew: false, newIsCap: true, properties: true }],\n 'no-alert': 'error',\n 'no-array-constructor': 'error',\n 'no-async-promise-executor': 'error',\n 'no-caller': 'error',\n 'no-case-declarations': 'error',\n 'no-class-assign': 'error',\n 'no-compare-neg-zero': 'error',\n 'no-cond-assign': ['error', 'always'],\n 'no-const-assign': 'error',\n 'no-control-regex': 'error',\n 'no-debugger': 'error',\n 'no-delete-var': 'error',\n 'no-dupe-args': 'error',\n 'no-dupe-class-members': 'error',\n 'no-dupe-keys': 'error',\n 'no-duplicate-case': 'error',\n 'no-empty': ['error', { allowEmptyCatch: true }],\n 'no-empty-character-class': 'error',\n 'no-empty-pattern': 'error',\n 'no-eval': 'error',\n 'no-ex-assign': 'error',\n 'no-extend-native': 'error',\n 'no-extra-bind': 'error',\n 'no-extra-boolean-cast': 'error',\n 'no-fallthrough': 'error',\n 'no-func-assign': 'error',\n 'no-global-assign': 'error',\n 'no-implied-eval': 'error',\n 'no-import-assign': 'error',\n 'no-invalid-regexp': 'error',\n 'no-irregular-whitespace': 'error',\n 'no-iterator': 'error',\n 'no-labels': ['error', { allowLoop: false, allowSwitch: false }],\n 'no-lone-blocks': 'error',\n 'no-loss-of-precision': 'error',\n 'no-misleading-character-class': 'error',\n 'no-multi-str': 'error',\n 'no-new': 'error',\n 'no-new-func': 'error',\n 'no-new-native-nonconstructor': 'error',\n 'no-new-wrappers': 'error',\n 'no-obj-calls': 'error',\n 'no-octal': 'error',\n 'no-octal-escape': 'error',\n 'no-proto': 'error',\n 'no-prototype-builtins': 'error',\n 'no-redeclare': ['error', { builtinGlobals: false }],\n 'no-regex-spaces': 'error',\n 'no-restricted-globals': [\n 'error',\n { message: 'Use `globalThis` instead.', name: 'global' },\n { message: 'Use `globalThis` instead.', name: 'self' },\n ],\n 'no-restricted-properties': [\n 'error',\n {\n message: 'Use `Object.getPrototypeOf` or `Object.setPrototypeOf` instead.',\n property: '__proto__',\n },\n { message: 'Use `Object.defineProperty` instead.', property: '__defineGetter__' },\n { message: 'Use `Object.defineProperty` instead.', property: '__defineSetter__' },\n {\n message: 'Use `Object.getOwnPropertyDescriptor` instead.',\n property: '__lookupGetter__',\n },\n {\n message: 'Use `Object.getOwnPropertyDescriptor` instead.',\n property: '__lookupSetter__',\n },\n ],\n 'no-restricted-syntax': [\n 'error',\n 'DebuggerStatement',\n 'LabeledStatement',\n 'WithStatement',\n 'TSEnumDeclaration',\n 'TSExportAssignment',\n ],\n 'no-self-assign': ['error', { props: true }],\n 'no-self-compare': 'error',\n 'no-sequences': 'error',\n 'no-shadow-restricted-names': 'error',\n 'no-sparse-arrays': 'error',\n 'no-template-curly-in-string': 'error',\n 'no-this-before-super': 'error',\n 'no-throw-literal': 'error',\n 'no-undef': 'error',\n 'no-undef-init': 'error',\n 'no-unexpected-multiline': 'error',\n 'no-unmodified-loop-condition': 'error',\n 'no-unneeded-ternary': ['error', { defaultAssignment: false }],\n 'no-unreachable': 'error',\n 'no-unreachable-loop': 'error',\n 'no-unsafe-finally': 'error',\n 'no-unsafe-negation': 'error',\n 'no-unused-expressions': [\n 'error',\n {\n allowShortCircuit: true,\n allowTaggedTemplates: true,\n allowTernary: true,\n },\n ],\n 'no-unused-vars': [\n 'error',\n {\n args: 'none',\n caughtErrors: 'none',\n ignoreRestSiblings: true,\n vars: 'all',\n },\n ],\n 'no-useless-backreference': 'error',\n 'no-useless-call': 'error',\n 'no-useless-catch': 'error',\n 'no-useless-computed-key': 'error',\n 'no-useless-constructor': 'error',\n 'no-useless-rename': 'error',\n 'no-var': 'error',\n 'no-with': 'error',\n 'object-shorthand': [\n 'error',\n 'always',\n {\n avoidQuotes: true,\n ignoreConstructors: false,\n },\n ],\n 'one-var': ['error', { initialized: 'never' }],\n 'prefer-arrow-callback': [\n 'error',\n {\n allowNamedFunctions: true,\n allowUnboundThis: true,\n },\n ],\n 'prefer-const': [\n 'error',\n {\n destructuring: 'all',\n ignoreReadBeforeAssign: true,\n },\n ],\n 'prefer-exponentiation-operator': 'error',\n 'prefer-promise-reject-errors': 'error',\n 'prefer-regex-literals': ['error', { disallowRedundantWrapping: true }],\n 'prefer-rest-params': 'error',\n 'prefer-spread': 'error',\n 'prefer-template': 'error',\n 'symbol-description': 'error',\n 'unicode-bom': ['error', 'never'],\n 'use-isnan': ['error', { enforceForIndexOf: true, enforceForSwitchCase: true }],\n 'valid-typeof': ['error', { requireStringLiterals: true }],\n 'vars-on-top': 'error',\n yoda: ['error', 'never'],\n\n ...overrides,\n },\n },\n ];\n}\n","import type { TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function jsdoc(): Promise<TypedFlatConfigItem[]> {\n return [\n {\n name: '2digits:jsdoc',\n plugins: {\n jsdoc: await interopDefault(import('eslint-plugin-jsdoc')),\n },\n rules: {\n 'jsdoc/check-access': 'error',\n 'jsdoc/check-param-names': 'error',\n 'jsdoc/check-property-names': 'error',\n 'jsdoc/check-types': 'error',\n 'jsdoc/empty-tags': 'error',\n 'jsdoc/implements-on-classes': 'error',\n 'jsdoc/no-defaults': 'error',\n 'jsdoc/no-multi-asterisks': 'error',\n 'jsdoc/require-param-name': 'error',\n 'jsdoc/require-property': 'error',\n 'jsdoc/require-property-description': 'error',\n 'jsdoc/require-property-name': 'error',\n 'jsdoc/require-returns-check': 'error',\n 'jsdoc/require-returns-description': 'error',\n 'jsdoc/require-yields-check': 'error',\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\nimport { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_TS, GLOB_TSX } from '../globs';\nimport type { OptionsTypeScriptWithTypes, OptionsWithFiles, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function next(\n options: OptionsWithFiles & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const { files = [GLOB_TS, GLOB_TSX], overrides = {}, tsconfigPath, parserOptions } = options;\n\n const [next, parser] = await Promise.all([\n interopDefault(import('@next/eslint-plugin-next')),\n interopDefault(import('@typescript-eslint/parser')),\n ]);\n\n const recommended = renamePluginsInRules(\n {\n ...next.configs.recommended.rules,\n ...next.configs['core-web-vitals'].rules,\n },\n PluginNameMap,\n );\n\n return [\n {\n name: '2digits:next/setup',\n plugins: {\n next: fixupPluginRules(next as never),\n },\n },\n {\n name: '2digits:next/rules',\n files,\n languageOptions: {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n project: tsconfigPath,\n ...(parserOptions as object),\n },\n sourceType: 'module',\n },\n rules: {\n ...recommended,\n\n 'next/no-html-link-for-pages': 'off',\n\n ...overrides,\n },\n },\n ];\n}\n","import { pluginNode } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function node(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:node',\n settings: {\n node: {\n version: '>= 20.0.0',\n },\n },\n plugins: {\n node: pluginNode,\n },\n rules: {\n 'node/handle-callback-err': ['error', '^(err|error)$'],\n 'node/no-deprecated-api': 'error',\n 'node/no-exports-assign': 'error',\n 'node/no-new-require': 'error',\n 'node/no-path-concat': 'error',\n 'node/no-unsupported-features/node-builtins': ['error', { allowExperimental: true }],\n 'node/prefer-global/buffer': 'error',\n 'node/prefer-global/process': 'error',\n 'node/prefer-global/text-encoder': 'error',\n 'node/prefer-global/url': 'error',\n 'node/prefer-global/console': 'error',\n 'node/prefer-global/url-search-params': 'error',\n 'node/prefer-global/text-decoder': 'error',\n 'node/process-exit-as-throw': 'error',\n },\n },\n ];\n}\n","import type { TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function prettier(): Promise<TypedFlatConfigItem[]> {\n const prettier = await interopDefault(import('eslint-config-prettier'));\n\n return [\n {\n name: '2digits:prettier',\n rules: {\n ...prettier.rules,\n\n 'tailwindcss/classnames-order': 'off',\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\nimport { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_TS, GLOB_TSX } from '../globs';\nimport type { OptionsTypeScriptWithTypes, OptionsWithReact, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function react(\n options: OptionsWithReact & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const {\n files = [GLOB_TS, GLOB_TSX],\n overrides = {},\n tsconfigPath,\n parserOptions,\n tsconfigRootDir,\n reactCompiler = true,\n } = options;\n\n const [pluginReact, pluginReactHooks, react, parser, pluginReactCompiler] = await Promise.all([\n interopDefault(import('@eslint-react/eslint-plugin')),\n interopDefault(import('eslint-plugin-react-hooks')),\n interopDefault(import('eslint-plugin-react')),\n interopDefault(import('@typescript-eslint/parser')),\n reactCompiler ? interopDefault(import('eslint-plugin-react-compiler')) : undefined,\n ]);\n\n const plugins = pluginReact.configs.all.plugins;\n\n const recommended = renamePluginsInRules(\n {\n ...react.configs.recommended.rules,\n ...react.configs['jsx-runtime'].rules,\n ...pluginReactHooks.configs.recommended.rules,\n ...pluginReact.configs['recommended-type-checked'].rules,\n },\n PluginNameMap,\n );\n\n return [\n {\n name: '2digits:react/setup',\n plugins: {\n react,\n 'react-dom': plugins['@eslint-react/dom'],\n 'react-extra': plugins['@eslint-react'],\n 'react-hooks': fixupPluginRules(pluginReactHooks as never),\n 'react-hooks-extra': plugins['@eslint-react/hooks-extra'],\n 'react-naming-convention': plugins['@eslint-react/naming-convention'],\n ...(reactCompiler ? { 'react-compiler': pluginReactCompiler } : {}),\n },\n settings: {\n react: {\n version: 'detect',\n },\n },\n },\n {\n name: '2digits:react/rules',\n files,\n languageOptions: {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n tsconfigRootDir,\n project: tsconfigPath,\n ...parserOptions,\n },\n sourceType: 'module',\n },\n rules: {\n ...recommended,\n\n ...(reactCompiler ? { 'react-compiler/react-compiler': 'error' } : {}),\n\n 'react-hooks-extra/ensure-use-memo-has-non-empty-deps': 'error',\n 'react-hooks-extra/prefer-use-state-lazy-initialization': 'error',\n 'react-hooks-extra/ensure-custom-hooks-using-other-hooks': 'error',\n 'react-hooks-extra/ensure-use-callback-has-non-empty-deps': 'error',\n\n 'react/jsx-curly-newline': 'off',\n 'react/jsx-newline': ['error', { prevent: false }],\n\n ...overrides,\n },\n },\n ];\n}\n","import { renamePluginsInRules } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { pluginSonar } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nconst rules = renamePluginsInRules(pluginSonar.configs.recommended.rules as never, PluginNameMap);\n\nexport function sonar(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:sonar',\n plugins: {\n sonar: pluginSonar,\n },\n rules,\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\n\nimport { GLOB_STORIES } from '../globs';\nimport type {\n OptionsTypeScriptWithTypes,\n OptionsWithStorybook,\n TypedFlatConfigItem,\n} from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function storybook(\n options: OptionsWithStorybook & OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const {\n files = [GLOB_STORIES],\n overrides = {},\n parserOptions,\n tsconfigPath,\n storybookDirectory = '.storybook',\n } = options;\n\n const [storybook, parser] = await Promise.all([\n interopDefault(import('eslint-plugin-storybook')),\n interopDefault(import('@typescript-eslint/parser')),\n ]);\n\n const languageOptions = {\n parser,\n parserOptions: {\n ecmaFeatures: {\n jsx: true,\n },\n project: tsconfigPath,\n ...(parserOptions as object),\n },\n sourceType: 'module' as const,\n };\n\n return [\n {\n name: '2digits:storybook/setup',\n plugins: {\n storybook: fixupPluginRules(storybook as never),\n },\n },\n {\n name: '2digits:storybook/rules',\n files,\n languageOptions,\n rules: {\n 'storybook/await-interactions': 'error',\n 'storybook/context-in-play-function': 'error',\n 'storybook/csf-component': 'error',\n 'storybook/default-exports': 'error',\n 'storybook/hierarchy-separator': 'error',\n 'storybook/no-redundant-story-name': 'error',\n 'storybook/no-stories-of': 'error',\n 'storybook/no-title-property-in-meta': 'error',\n 'storybook/prefer-pascal-case': 'error',\n 'storybook/story-exports': 'error',\n 'storybook/use-storybook-expect': 'error',\n 'storybook/use-storybook-testing-library': 'error',\n\n ...overrides,\n },\n },\n {\n name: '2digits:storybook/disables',\n files,\n rules: {\n 'react-hooks/rules-of-hooks': 'off',\n 'react/display-name': 'off',\n },\n },\n {\n name: '2digits:storybook/config',\n files: [`${storybookDirectory}/main.@(js|cjs|mjs|ts)`],\n languageOptions,\n rules: {\n 'storybook/no-uninstalled-addons': 'error',\n },\n },\n ];\n}\n","import { findUp } from 'find-up';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function tailwind(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const [tailwindcss, { tailwindFunctions }, config] = await Promise.all([\n interopDefault(import('eslint-plugin-tailwindcss')),\n interopDefault(import('@2digits/constants')),\n findUp(['tailwind.config.ts', 'tailwind.config.js']),\n ]);\n\n return [\n {\n name: '2digits:tailwind',\n plugins: {\n tailwindcss,\n },\n settings: {\n tailwindcss: {\n callees: tailwindFunctions,\n config,\n },\n },\n rules: {\n ...tailwindcss.configs.recommended.rules,\n\n ...overrides,\n },\n },\n ];\n}\n","import { fixupPluginRules } from '@eslint/compat';\n\nimport type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function tanstack(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const tanstack = await interopDefault(import('@tanstack/eslint-plugin-query'));\n\n return [\n {\n name: '2digits:tanstack',\n plugins: {\n tanstack: fixupPluginRules(tanstack as never),\n },\n rules: {\n 'tanstack/exhaustive-deps': 'error',\n 'tanstack/stable-query-client': 'error',\n 'tanstack/no-rest-destructuring': 'error',\n\n ...overrides,\n },\n },\n ];\n}\n","import type { OptionsOverrides, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function turbo(options: OptionsOverrides = {}): Promise<TypedFlatConfigItem[]> {\n const { overrides = {} } = options;\n\n const turbo = await interopDefault(import('eslint-plugin-turbo'));\n\n return [\n {\n name: '2digits:turbo',\n plugins: {\n turbo,\n },\n rules: {\n 'turbo/no-undeclared-env-vars': 'error',\n\n ...overrides,\n },\n },\n ];\n}\n","import { renamePluginsInConfigs } from 'eslint-flat-config-utils';\n\nimport { PluginNameMap } from '../constants';\nimport { GLOB_SRC } from '../globs';\nimport type { OptionsTypeScriptWithTypes, TypedFlatConfigItem } from '../types';\nimport { interopDefault } from '../utils';\n\nexport async function typescript(\n options: OptionsTypeScriptWithTypes = {},\n): Promise<TypedFlatConfigItem[]> {\n const { overrides = {}, parserOptions = {}, tsconfigPath = true } = options;\n\n const [{ plugin, configs, parser }, twoDigits] = await Promise.all([\n interopDefault(import('typescript-eslint')),\n interopDefault(import('@2digits/eslint-plugin')),\n ]);\n\n const strictConfig = renamePluginsInConfigs(configs.strictTypeChecked as never, PluginNameMap);\n\n const rules = Object.fromEntries(\n strictConfig.flatMap(({ rules }) => Object.entries(rules ?? {})),\n );\n\n return [\n {\n name: '2digits:typescript/setup',\n plugins: {\n ts: plugin,\n '@2digits': twoDigits,\n },\n languageOptions: {\n parser,\n parserOptions: {\n sourceType: 'module',\n tsconfigRootDir: process.cwd(),\n project: tsconfigPath,\n ...parserOptions,\n },\n },\n },\n\n {\n name: '2digits:typescript/rules',\n files: [GLOB_SRC],\n rules: {\n ...rules,\n 'ts/restrict-template-expressions': ['error', { allowNumber: true }],\n 'ts/ban-ts-comment': ['error', { 'ts-ignore': 'allow-with-description' }],\n 'ts/consistent-type-exports': ['error'],\n 'ts/consistent-type-imports': [\n 'error',\n {\n prefer: 'type-imports',\n disallowTypeAnnotations: false,\n fixStyle: 'inline-type-imports',\n },\n ],\n 'ts/no-empty-interface': ['error', { allowSingleExtends: true }],\n 'ts/no-explicit-any': ['error'],\n 'ts/no-import-type-side-effects': ['error'],\n 'ts/no-misused-promises': 'off',\n 'ts/no-confusing-void-expression': [\n 'error',\n { ignoreArrowShorthand: true, ignoreVoidOperator: true },\n ],\n 'ts/no-unused-vars': [\n 'error',\n { ignoreRestSiblings: true, argsIgnorePattern: '^_', varsIgnorePattern: '^_' },\n ],\n\n ...(twoDigits.configs.recommended.rules as object),\n\n ...overrides,\n },\n },\n {\n files: ['**/*.d.ts'],\n name: '2digits:typescript/disables/dts',\n rules: {\n 'unicorn/no-abusive-eslint-disable': 'off',\n 'no-duplicate-imports': 'off',\n 'no-restricted-syntax': 'off',\n 'ts/no-unused-vars': 'off',\n },\n },\n {\n files: ['**/*.{test,spec}.ts?(x)'],\n name: '2digits:typescript/disables/test',\n rules: {\n 'no-unused-expressions': 'off',\n },\n },\n {\n files: ['**/*.js', '**/*.cjs', '**/*.cts'],\n name: '2digits:typescript/disables/cjs',\n rules: {\n 'ts/no-require-imports': 'off',\n 'ts/no-var-requires': 'off',\n },\n },\n ];\n}\n","import { pluginUnicorn } from '../plugins';\nimport type { TypedFlatConfigItem } from '../types';\n\nexport function unicorn(): TypedFlatConfigItem[] {\n return [\n {\n name: '2digits:unicorn',\n plugins: {\n unicorn: pluginUnicorn,\n },\n rules: {\n ...pluginUnicorn.configs.recommended.rules,\n\n 'unicorn/filename-case': ['off'],\n 'unicorn/prefer-module': ['off'],\n 'unicorn/prevent-abbreviations': ['off'],\n 'unicorn/prefer-ternary': ['error', 'only-single-line'],\n 'unicorn/no-useless-undefined': [\n 'error',\n {\n checkArguments: false,\n checkArrowFunctionBody: false,\n },\n ],\n 'unicorn/prefer-top-level-await': ['off'],\n },\n },\n ];\n}\n","import { FlatConfigComposer } from 'eslint-flat-config-utils';\nimport { isPackageExists } from 'local-pkg';\n\nimport {\n comments,\n graphql,\n ignores,\n javascript,\n jsdoc,\n next,\n node,\n prettier,\n react,\n sonar,\n storybook,\n tailwind,\n tanstack,\n turbo,\n typescript,\n unicorn,\n} from './configs';\nimport { PluginNameMap } from './constants';\nimport type {\n ConfigNames,\n OptionsOverrides,\n OptionsTypeScriptWithTypes,\n OptionsWithFiles,\n OptionsWithIgnores,\n OptionsWithReact,\n OptionsWithStorybook,\n TypedFlatConfigItem,\n} from './types';\n\ntype SharedOptions<T = unknown> = T & {\n enable?: boolean;\n};\n\ninterface ESLint2DigitsOptions {\n ignores?: OptionsWithIgnores;\n turbo?: SharedOptions<OptionsOverrides> | boolean;\n js?: OptionsOverrides;\n ts?: SharedOptions<OptionsTypeScriptWithTypes> | boolean;\n graphql?: SharedOptions<OptionsWithFiles> | boolean;\n react?: SharedOptions<OptionsWithReact> | boolean;\n next?: SharedOptions<OptionsWithFiles> | boolean;\n tailwind?: SharedOptions<OptionsOverrides> | boolean;\n storybook?: SharedOptions<OptionsWithStorybook> | boolean;\n tanstack?: SharedOptions<OptionsOverrides> | boolean;\n}\n\nfunction enabled<T extends SharedOptions>(\n options: T | boolean | undefined,\n defaults?: boolean | undefined,\n): options is T {\n if (typeof options === 'boolean') return options;\n return options?.enable ?? defaults ?? false;\n}\n\nfunction config<T>(options: SharedOptions<T> | undefined | boolean): T {\n if (typeof options === 'boolean' || options === undefined) return {} as T;\n const { enable: _, ...rest } = options;\n return rest as T;\n}\n\nexport function twoDigits(\n options: ESLint2DigitsOptions = {},\n ...userConfig: TypedFlatConfigItem[]\n): Promise<TypedFlatConfigItem[]> {\n let composer = new FlatConfigComposer<TypedFlatConfigItem, ConfigNames>(\n ignores(options.ignores),\n javascript(options.js),\n node(),\n comments(),\n jsdoc(),\n unicorn(),\n sonar(),\n );\n\n if (enabled(options.turbo, isPackageExists('turbo'))) {\n composer = composer.append(turbo(config(options.turbo)));\n }\n\n const { overrides: _, ...typescriptOptions } = config(options.ts);\n\n if (enabled(options.ts, isPackageExists('typescript'))) {\n composer = composer.append(typescript(config(options.ts)));\n }\n\n if (enabled(options.react, isPackageExists('react'))) {\n composer = composer.append(\n react({\n ...config(options.react),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.next, isPackageExists('next'))) {\n composer = composer.append(\n next({\n ...config(options.next),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.storybook, isPackageExists('storybook'))) {\n composer = composer.append(\n storybook({\n ...config(options.storybook),\n ...typescriptOptions,\n }),\n );\n }\n\n if (enabled(options.tailwind, isPackageExists('tailwindcss'))) {\n composer = composer.append(tailwind(config(options.tailwind)));\n }\n\n if (\n enabled(\n options.tanstack,\n isPackageExists('react-query') ||\n isPackageExists('@tanstack/react-query') ||\n isPackageExists('@tanstack/react-query-devtools'),\n )\n ) {\n composer = composer.append(tanstack(config(options.tanstack)));\n }\n\n if (isPackageExists('graphql')) {\n composer = composer.append(graphql(config(options.graphql)));\n }\n\n composer = composer.append(...userConfig);\n\n if (isPackageExists('prettier')) {\n composer = composer.append(prettier());\n }\n\n return composer.renamePlugins(PluginNameMap).toConfigs();\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@2digits/eslint-config",
|
|
3
3
|
"description": "Effortlessly enforce best practices and catch errors with this comprehensive ESLint configuration for TypeScript, featuring popular plugins like @typescript-eslint, eslint-plugin-react, and eslint-plugin-unicorn.",
|
|
4
|
-
"version": "2.0
|
|
4
|
+
"version": "2.2.0",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"public": true,
|
|
@@ -29,36 +29,39 @@
|
|
|
29
29
|
],
|
|
30
30
|
"dependencies": {
|
|
31
31
|
"@2digits/constants": "0.1.6",
|
|
32
|
-
"@2digits/eslint-plugin": "2.0.
|
|
32
|
+
"@2digits/eslint-plugin": "2.0.1",
|
|
33
33
|
"@eslint-react/eslint-plugin": "^1.5.14",
|
|
34
34
|
"@eslint/compat": "^1.0.3",
|
|
35
35
|
"@eslint/js": "^9.4.0",
|
|
36
|
+
"@graphql-eslint/eslint-plugin": "^3.20.1",
|
|
36
37
|
"@next/eslint-plugin-next": "^14.2.3",
|
|
37
38
|
"@tanstack/eslint-plugin-query": "^5.35.6",
|
|
38
|
-
"@typescript-eslint/parser": "^7.
|
|
39
|
+
"@typescript-eslint/parser": "^7.12.0",
|
|
39
40
|
"eslint-config-flat-gitignore": "^0.1.5",
|
|
40
41
|
"eslint-config-prettier": "^9.1.0",
|
|
41
42
|
"eslint-flat-config-utils": "^0.2.5",
|
|
42
43
|
"eslint-plugin-eslint-comments": "^3.2.0",
|
|
43
|
-
"eslint-plugin-jsdoc": "^48.2.
|
|
44
|
-
"eslint-plugin-n": "^17.
|
|
44
|
+
"eslint-plugin-jsdoc": "^48.2.8",
|
|
45
|
+
"eslint-plugin-n": "^17.8.0",
|
|
45
46
|
"eslint-plugin-react": "^7.34.2",
|
|
47
|
+
"eslint-plugin-react-compiler": "0.0.0-experimental-51a85ea-20240601",
|
|
46
48
|
"eslint-plugin-react-hooks": "^4.6.2",
|
|
49
|
+
"eslint-plugin-sonarjs": "^1.0.3",
|
|
47
50
|
"eslint-plugin-storybook": "^0.8.0",
|
|
48
|
-
"eslint-plugin-tailwindcss": "^3.17.
|
|
49
|
-
"eslint-plugin-turbo": "^
|
|
51
|
+
"eslint-plugin-tailwindcss": "^3.17.1",
|
|
52
|
+
"eslint-plugin-turbo": "^2.0.1",
|
|
50
53
|
"eslint-plugin-unicorn": "^53.0.0",
|
|
51
54
|
"find-up": "^7.0.0",
|
|
52
55
|
"globals": "^15.3.0",
|
|
53
56
|
"local-pkg": "^0.5.0",
|
|
54
|
-
"typescript-eslint": "^7.
|
|
57
|
+
"typescript-eslint": "^7.12.0"
|
|
55
58
|
},
|
|
56
59
|
"devDependencies": {
|
|
57
60
|
"@2digits/tsconfig": "0.3.5",
|
|
58
|
-
"@eslint/config-inspector": "^0.4.10",
|
|
59
61
|
"@types/eslint": "^8.56.10",
|
|
60
62
|
"@types/eslint__js": "^8.42.3",
|
|
61
|
-
"@types/node": "^20.14.
|
|
63
|
+
"@types/node": "^20.14.2",
|
|
64
|
+
"@typescript-eslint/utils": "7.12.0",
|
|
62
65
|
"eslint": "^9.4.0",
|
|
63
66
|
"eslint-typegen": "^0.2.4",
|
|
64
67
|
"tsup": "^8.1.0",
|