@2digits/eslint-config 2.0.1 → 2.1.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 CHANGED
@@ -3,11 +3,11 @@
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  var x = require('eslint-plugin-unicorn');
6
- var k = require('eslint-plugin-eslint-comments');
7
- var T = require('eslint-plugin-n');
6
+ var T = require('eslint-plugin-eslint-comments');
7
+ var w = require('eslint-plugin-n');
8
8
  var eslintFlatConfigUtils = require('eslint-flat-config-utils');
9
- var A = require('@eslint/js');
10
- var h = require('globals');
9
+ var X = require('@eslint/js');
10
+ var k = require('globals');
11
11
  var compat = require('@eslint/compat');
12
12
  var findUp = require('find-up');
13
13
  var localPkg = require('local-pkg');
@@ -15,28 +15,28 @@ var localPkg = require('local-pkg');
15
15
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
16
16
 
17
17
  var x__default = /*#__PURE__*/_interopDefault(x);
18
- var k__default = /*#__PURE__*/_interopDefault(k);
19
18
  var T__default = /*#__PURE__*/_interopDefault(T);
20
- var A__default = /*#__PURE__*/_interopDefault(A);
21
- var h__default = /*#__PURE__*/_interopDefault(h);
19
+ var w__default = /*#__PURE__*/_interopDefault(w);
20
+ var X__default = /*#__PURE__*/_interopDefault(X);
21
+ var k__default = /*#__PURE__*/_interopDefault(k);
22
22
 
23
- function w(){return [{name:"2digits:comments",plugins:{"eslint-comments":k__default.default},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 v="**/*.?([cm])[jt]s?(x)",y="**/*.?([cm])ts",b="**/*.?([cm])tsx",j="**/*.stories.tsx",S=["**/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 C(e={}){return eslintFlatConfigUtils.composer({ignores:S,name:"2digits:ignores"},o(import('eslint-config-flat-gitignore')).then(t=>({...t(e),name:"2digits:gitignore"})))}function F(e={}){let{overrides:t={}}=e;return [{name:"2digits:javascript",languageOptions:{ecmaVersion:2022,globals:{...h__default.default.browser,...h__default.default.es2021,...h__default.default.node,document:"readonly",navigator:"readonly",window:"readonly"},parserOptions:{ecmaFeatures:{jsx:!0},ecmaVersion:2022,sourceType:"module"},sourceType:"module"},linterOptions:{reportUnusedDisableDirectives:!0},rules:{...A__default.default.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 I(){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 u={"@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 P(e={}){let{files:t=[y,b],overrides:r={},tsconfigPath:i,parserOptions:n}=e,[p,c]=await Promise.all([o(import('@next/eslint-plugin-next')),o(import('@typescript-eslint/parser'))]),l=eslintFlatConfigUtils.renamePluginsInRules({...p.configs.recommended.rules,...p.configs["core-web-vitals"].rules},u);return [{name:"2digits:next/setup",plugins:{next:compat.fixupPluginRules(p)}},{name:"2digits:next/rules",files:t,languageOptions:{parser:c,parserOptions:{ecmaFeatures:{jsx:!0},project:i,...n},sourceType:"module"},rules:{...l,"next/no-html-link-for-pages":"off",...r}}]}function _(){return [{name:"2digits:node",settings:{node:{version:">= 20.0.0"}},plugins:{node:T__default.default},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 D(){return [{name:"2digits:prettier",rules:(await o(import('eslint-config-prettier'))).rules}]}async function W(e={}){let{files:t=[y,b],overrides:r={},tsconfigPath:i,parserOptions:n,tsconfigRootDir:p}=e,[c,l,m,O]=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'))]),g=c.configs.all.plugins,B=eslintFlatConfigUtils.renamePluginsInRules({...m.configs.recommended.rules,...m.configs["jsx-runtime"].rules,...l.configs.recommended.rules,...c.configs["recommended-type-checked"].rules},u);return [{name:"2digits:react/setup",plugins:{react:m,"react-dom":g["@eslint-react/dom"],"react-extra":g["@eslint-react"],"react-hooks":compat.fixupPluginRules(l),"react-hooks-extra":g["@eslint-react/hooks-extra"],"react-naming-convention":g["@eslint-react/naming-convention"]},settings:{react:{version:"detect"}}},{name:"2digits:react/rules",files:t,languageOptions:{parser:O,parserOptions:{ecmaFeatures:{jsx:!0},tsconfigRootDir:p,project:i,...n},sourceType:"module"},rules:{...B,"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 G(e={}){let{files:t=[j],overrides:r={},parserOptions:i,tsconfigPath:n,storybookDirectory:p=".storybook"}=e,[c,l]=await Promise.all([o(import('eslint-plugin-storybook')),o(import('@typescript-eslint/parser'))]),m={parser:l,parserOptions:{ecmaFeatures:{jsx:!0},project:n,...i},sourceType:"module"};return [{name:"2digits:storybook/setup",plugins:{storybook:compat.fixupPluginRules(c)}},{name:"2digits:storybook/rules",files:t,languageOptions:m,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:[`${p}/main.@(js|cjs|mjs|ts)`],languageOptions:m,rules:{"storybook/no-uninstalled-addons":"error"}}]}async function L(e={}){let{overrides:t={}}=e,[r,{tailwindFunctions:i},n]=await Promise.all([o(import('eslint-plugin-tailwindcss')),o(import('@2digits/constants')),findUp.findUp(["tailwind.config.ts","tailwind.config.js"])]);return [{name:"2digits:tailwind",plugins:{tailwindcss:r},settings:{tailwindcss:{callees:i,config:n}},rules:{...r.configs.recommended.rules,"tailwindcss/classnames-order":"off",...t}}]}async function q(e={}){let{overrides:t={}}=e,r=await o(import('@tanstack/eslint-plugin-query'));return [{name:"2digits:tanstack",plugins:{tanstack:compat.fixupPluginRules(r)},rules:{"tanstack/exhaustive-deps":"error","tanstack/stable-query-client":"error","tanstack/no-rest-destructuring":"error",...t}}]}async function E(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 R(e={}){let{overrides:t={},parserOptions:r={},tsconfigPath:i=!0}=e,[{plugin:n,configs:p,parser:c},l]=await Promise.all([o(import('typescript-eslint')),o(import('@2digits/eslint-plugin'))]),m=eslintFlatConfigUtils.renamePluginsInConfigs(p.strictTypeChecked,u),O=Object.fromEntries(m.flatMap(({rules:g})=>Object.entries(g??{})));return [{name:"2digits:typescript/setup",plugins:{ts:n,"@2digits":l},languageOptions:{parser:c,parserOptions:{sourceType:"module",tsconfigRootDir:process.cwd(),project:i,...r}}},{name:"2digits:typescript/rules",files:[v],rules:{...O,"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:"^_"}],...l.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 U(){return [{name:"2digits:unicorn",plugins:{unicorn:x__default.default},rules:{...x__default.default.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 f(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 Y(e={},...t){let r=new eslintFlatConfigUtils.FlatConfigComposer(C(e.ignores),F(e.js),_(),w(),I(),U());f(e.turbo,localPkg.isPackageExists("turbo"))&&(r=r.append(E(d(e.turbo))));let{overrides:i,...n}=d(e.ts);return f(e.ts,localPkg.isPackageExists("typescript"))&&(r=r.append(R(d(e.ts)))),f(e.react,localPkg.isPackageExists("react"))&&(r=r.append(W({...d(e.react),...n}))),f(e.next,localPkg.isPackageExists("next"))&&(r=r.append(P({...d(e.next),...n}))),f(e.storybook,localPkg.isPackageExists("storybook"))&&(r=r.append(G({...d(e.storybook),...n}))),f(e.tailwind,localPkg.isPackageExists("tailwindcss"))&&(r=r.append(L(d(e.tailwind)))),f(e.tanstack,localPkg.isPackageExists("react-query")||localPkg.isPackageExists("@tanstack/react-query")||localPkg.isPackageExists("@tanstack/react-query-devtools"))&&(r=r.append(q(d(e.tanstack)))),r=r.append(...t),localPkg.isPackageExists("prettier")&&(r=r.append(D())),r.renamePlugins(u).toConfigs()}
23
+ function v(){return [{name:"2digits:comments",plugins:{"eslint-comments":T__default.default},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",h="**/*.?([cm])tsx",C="**/*.stories.tsx",S=["**/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 I(e={}){let{gitIgnore:t,ignores:r=[]}=e;return eslintFlatConfigUtils.composer({ignores:[S,r].flat(),name:"2digits:ignores"},o(import('eslint-config-flat-gitignore')).then(i=>({...i(t),name:"2digits:gitignore"})))}function F(e={}){let{overrides:t={}}=e;return [{name:"2digits:javascript",languageOptions:{ecmaVersion:2022,globals:{...k__default.default.browser,...k__default.default.es2021,...k__default.default.node,document:"readonly",navigator:"readonly",window:"readonly"},parserOptions:{ecmaFeatures:{jsx:!0},ecmaVersion:2022,sourceType:"module"},sourceType:"module"},linterOptions:{reportUnusedDisableDirectives:!0},rules:{...X__default.default.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 m={"@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"};async function _(e={}){let{files:t=[b,h],overrides:r={},tsconfigPath:i,parserOptions:n}=e,[p,c]=await Promise.all([o(import('@next/eslint-plugin-next')),o(import('@typescript-eslint/parser'))]),l=eslintFlatConfigUtils.renamePluginsInRules({...p.configs.recommended.rules,...p.configs["core-web-vitals"].rules},m);return [{name:"2digits:next/setup",plugins:{next:compat.fixupPluginRules(p)}},{name:"2digits:next/rules",files:t,languageOptions:{parser:c,parserOptions:{ecmaFeatures:{jsx:!0},project:i,...n},sourceType:"module"},rules:{...l,"next/no-html-link-for-pages":"off",...r}}]}function W(){return [{name:"2digits:node",settings:{node:{version:">= 20.0.0"}},plugins:{node:w__default.default},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 D(){return [{name:"2digits:prettier",rules:(await o(import('eslint-config-prettier'))).rules}]}async function R(e={}){let{files:t=[b,h],overrides:r={},tsconfigPath:i,parserOptions:n,tsconfigRootDir:p,reactCompiler:c=!0}=e,[l,d,g,O,N]=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')),c?o(import('eslint-plugin-react-compiler')):void 0]),y=l.configs.all.plugins,A=eslintFlatConfigUtils.renamePluginsInRules({...g.configs.recommended.rules,...g.configs["jsx-runtime"].rules,...d.configs.recommended.rules,...l.configs["recommended-type-checked"].rules},m);return [{name:"2digits:react/setup",plugins:{react:g,"react-dom":y["@eslint-react/dom"],"react-extra":y["@eslint-react"],"react-hooks":compat.fixupPluginRules(d),"react-hooks-extra":y["@eslint-react/hooks-extra"],"react-naming-convention":y["@eslint-react/naming-convention"],...c?{"react-compiler":N}:{}},settings:{react:{version:"detect"}}},{name:"2digits:react/rules",files:t,languageOptions:{parser:O,parserOptions:{ecmaFeatures:{jsx:!0},tsconfigRootDir:p,project:i,...n},sourceType:"module"},rules:{...A,...c?{"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}}]}async function L(e={}){let{files:t=[C],overrides:r={},parserOptions:i,tsconfigPath:n,storybookDirectory:p=".storybook"}=e,[c,l]=await Promise.all([o(import('eslint-plugin-storybook')),o(import('@typescript-eslint/parser'))]),d={parser:l,parserOptions:{ecmaFeatures:{jsx:!0},project:n,...i},sourceType:"module"};return [{name:"2digits:storybook/setup",plugins:{storybook:compat.fixupPluginRules(c)}},{name:"2digits:storybook/rules",files:t,languageOptions:d,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:[`${p}/main.@(js|cjs|mjs|ts)`],languageOptions:d,rules:{"storybook/no-uninstalled-addons":"error"}}]}async function q(e={}){let{overrides:t={}}=e,[r,{tailwindFunctions:i},n]=await Promise.all([o(import('eslint-plugin-tailwindcss')),o(import('@2digits/constants')),findUp.findUp(["tailwind.config.ts","tailwind.config.js"])]);return [{name:"2digits:tailwind",plugins:{tailwindcss:r},settings:{tailwindcss:{callees:i,config:n}},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:compat.fixupPluginRules(r)},rules:{"tanstack/exhaustive-deps":"error","tanstack/stable-query-client":"error","tanstack/no-rest-destructuring":"error",...t}}]}async function G(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:i=!0}=e,[{plugin:n,configs:p,parser:c},l]=await Promise.all([o(import('typescript-eslint')),o(import('@2digits/eslint-plugin'))]),d=eslintFlatConfigUtils.renamePluginsInConfigs(p.strictTypeChecked,m),g=Object.fromEntries(d.flatMap(({rules:O})=>Object.entries(O??{})));return [{name:"2digits:typescript/setup",plugins:{ts:n,"@2digits":l},languageOptions:{parser:c,parserOptions:{sourceType:"module",tsconfigRootDir:process.cwd(),project:i,...r}}},{name:"2digits:typescript/rules",files:[j],rules:{...g,"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:"^_"}],...l.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:x__default.default},rules:{...x__default.default.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 f(e,t){return typeof e=="boolean"?e:e?.enable??t??!1}function u(e){if(typeof e=="boolean"||e===void 0)return {};let{enable:t,...r}=e;return r}function ee(e={},...t){let r=new eslintFlatConfigUtils.FlatConfigComposer(I(e.ignores),F(e.js),W(),v(),P(),B());f(e.turbo,localPkg.isPackageExists("turbo"))&&(r=r.append(G(u(e.turbo))));let{overrides:i,...n}=u(e.ts);return f(e.ts,localPkg.isPackageExists("typescript"))&&(r=r.append(U(u(e.ts)))),f(e.react,localPkg.isPackageExists("react"))&&(r=r.append(R({...u(e.react),...n}))),f(e.next,localPkg.isPackageExists("next"))&&(r=r.append(_({...u(e.next),...n}))),f(e.storybook,localPkg.isPackageExists("storybook"))&&(r=r.append(L({...u(e.storybook),...n}))),f(e.tailwind,localPkg.isPackageExists("tailwindcss"))&&(r=r.append(q(u(e.tailwind)))),f(e.tanstack,localPkg.isPackageExists("react-query")||localPkg.isPackageExists("@tanstack/react-query")||localPkg.isPackageExists("@tanstack/react-query-devtools"))&&(r=r.append(E(u(e.tanstack)))),r=r.append(...t),localPkg.isPackageExists("prettier")&&(r=r.append(D())),r.renamePlugins(m).toConfigs()}
24
24
 
25
- exports.comments = w;
26
- exports.default = Y;
27
- exports.ignores = C;
25
+ exports.comments = v;
26
+ exports.default = ee;
27
+ exports.ignores = I;
28
28
  exports.javascript = F;
29
- exports.jsdoc = I;
30
- exports.next = P;
31
- exports.node = _;
29
+ exports.jsdoc = P;
30
+ exports.next = _;
31
+ exports.node = W;
32
32
  exports.prettier = D;
33
- exports.react = W;
34
- exports.storybook = G;
35
- exports.tailwind = L;
36
- exports.tanstack = q;
37
- exports.turbo = E;
38
- exports.twoDigits = Y;
39
- exports.typescript = R;
40
- exports.unicorn = U;
33
+ exports.react = R;
34
+ exports.storybook = L;
35
+ exports.tailwind = q;
36
+ exports.tanstack = E;
37
+ exports.turbo = G;
38
+ exports.twoDigits = ee;
39
+ exports.typescript = U;
40
+ exports.unicorn = B;
41
41
  //# sourceMappingURL=out.js.map
42
42
  //# sourceMappingURL=index.cjs.map
@@ -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/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","gitIgnore","eslint","globals","javascript","overrides","jsdoc","fixupPluginRules","renamePluginsInRules","PluginNameMap","next","files","tsconfigPath","parserOptions","parser","recommended","node","prettier","react","tsconfigRootDir","reactCompiler","pluginReact","pluginReactHooks","pluginReactCompiler","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 { 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 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-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} 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, 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 { 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 { 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 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 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 );\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"]}
package/dist/index.d.cts CHANGED
@@ -10,7 +10,7 @@ import { FlatGitignoreOptions } from 'eslint-config-flat-gitignore';
10
10
  interface RuleOptions {
11
11
  /**
12
12
  * Enforce giving proper names to type parameters when there are two or more
13
- * @see https://github.com/2digits-agency/configs/blob/@2digits/eslint-plugin@2.0.0/packages/eslint/src/rules/type-param-names.ts
13
+ * @see https://github.com/2digits-agency/configs/blob/@2digits/eslint-plugin@2.0.1/packages/eslint/src/rules/type-param-names.ts
14
14
  */
15
15
  '@2digits/type-param-names'?: Linter.RuleEntry<[]>
16
16
  /**
@@ -2004,6 +2004,10 @@ interface RuleOptions {
2004
2004
  * @see https://eslint.org/docs/latest/rules/radix
2005
2005
  */
2006
2006
  'radix'?: Linter.RuleEntry<Radix>
2007
+ /**
2008
+ * Surfaces diagnostics from React Forget
2009
+ */
2010
+ 'react-compiler/react-compiler'?: Linter.RuleEntry<ReactCompilerReactCompiler>
2007
2011
  /**
2008
2012
  * disallow passing 'children' to void DOM elements
2009
2013
  * @see https://eslint-react.xyz/rules/dom-no-children-in-void-dom-elements
@@ -3496,6 +3500,11 @@ interface RuleOptions {
3496
3500
  * @see https://typescript-eslint.io/rules/no-unnecessary-qualifier
3497
3501
  */
3498
3502
  'ts/no-unnecessary-qualifier'?: Linter.RuleEntry<[]>
3503
+ /**
3504
+ * Disallow unnecessary template expressions
3505
+ * @see https://typescript-eslint.io/rules/no-unnecessary-template-expression
3506
+ */
3507
+ 'ts/no-unnecessary-template-expression'?: Linter.RuleEntry<[]>
3499
3508
  /**
3500
3509
  * Disallow type arguments that are equal to the default
3501
3510
  * @see https://typescript-eslint.io/rules/no-unnecessary-type-arguments
@@ -3577,8 +3586,9 @@ interface RuleOptions {
3577
3586
  */
3578
3587
  'ts/no-useless-empty-export'?: Linter.RuleEntry<[]>
3579
3588
  /**
3580
- * Disallow unnecessary template literals
3589
+ * Disallow unnecessary template expressions
3581
3590
  * @see https://typescript-eslint.io/rules/no-useless-template-literals
3591
+ * @deprecated
3582
3592
  */
3583
3593
  'ts/no-useless-template-literals'?: Linter.RuleEntry<[]>
3584
3594
  /**
@@ -3726,7 +3736,7 @@ interface RuleOptions {
3726
3736
  */
3727
3737
  'ts/require-array-sort-compare'?: Linter.RuleEntry<TsRequireArraySortCompare>
3728
3738
  /**
3729
- * Disallow async functions which have no `await` expression
3739
+ * Disallow async functions which do not return promises and have no `await` expression
3730
3740
  * @see https://typescript-eslint.io/rules/require-await
3731
3741
  */
3732
3742
  'ts/require-await'?: Linter.RuleEntry<[]>
@@ -6568,6 +6578,10 @@ type Quotes = []|[("single" | "double" | "backtick")]|[("single" | "double" | "b
6568
6578
  })]
6569
6579
  // ----- radix -----
6570
6580
  type Radix = []|[("always" | "as-needed")]
6581
+ // ----- react-compiler/react-compiler -----
6582
+ type ReactCompilerReactCompiler = []|[{
6583
+ [k: string]: unknown | undefined
6584
+ }]
6571
6585
  // ----- react-hooks/exhaustive-deps -----
6572
6586
  type ReactHooksExhaustiveDeps = []|[{
6573
6587
  additionalHooks?: string
@@ -8217,6 +8231,18 @@ type TsNoFloatingPromises = []|[{
8217
8231
  ignoreVoid?: boolean
8218
8232
 
8219
8233
  ignoreIIFE?: boolean
8234
+ allowForKnownSafePromises?: (string | {
8235
+ from: "file"
8236
+ name: (string | [string, ...(string)[]])
8237
+ path?: string
8238
+ } | {
8239
+ from: "lib"
8240
+ name: (string | [string, ...(string)[]])
8241
+ } | {
8242
+ from: "package"
8243
+ name: (string | [string, ...(string)[]])
8244
+ package: string
8245
+ })[]
8220
8246
  }]
8221
8247
  // ----- ts/no-inferrable-types -----
8222
8248
  type TsNoInferrableTypes = []|[{
@@ -8949,10 +8975,24 @@ interface OptionsWithStorybook extends OptionsWithFiles {
8949
8975
  */
8950
8976
  storybookDirectory?: string;
8951
8977
  }
8978
+ interface OptionsWithReact extends OptionsWithFiles {
8979
+ /**
8980
+ * Enable the react-compiler plugin.
8981
+ *
8982
+ * @default true
8983
+ */
8984
+ reactCompiler?: boolean;
8985
+ }
8986
+ interface OptionsWithIgnores {
8987
+ /** Options to pass to eslint-config-flat-gitignore */
8988
+ gitIgnore?: Omit<FlatGitignoreOptions, 'name' | 'root'>;
8989
+ /** An array of glob patterns to ignore in addition to the default ignores. */
8990
+ ignores?: string[];
8991
+ }
8952
8992
 
8953
8993
  declare function comments(): TypedFlatConfigItem[];
8954
8994
 
8955
- declare function ignores(options?: FlatGitignoreOptions): Promise<TypedFlatConfigItem[]>;
8995
+ declare function ignores(options?: OptionsWithIgnores): Promise<TypedFlatConfigItem[]>;
8956
8996
 
8957
8997
  declare function javascript(options?: OptionsOverrides): TypedFlatConfigItem[];
8958
8998
 
@@ -8964,7 +9004,7 @@ declare function node(): TypedFlatConfigItem[];
8964
9004
 
8965
9005
  declare function prettier(): Promise<TypedFlatConfigItem[]>;
8966
9006
 
8967
- declare function react(options?: OptionsWithFiles & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
9007
+ declare function react(options?: OptionsWithReact & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
8968
9008
 
8969
9009
  declare function storybook(options?: OptionsWithStorybook & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
8970
9010
 
@@ -8982,11 +9022,11 @@ type SharedOptions<T = unknown> = T & {
8982
9022
  enable?: boolean;
8983
9023
  };
8984
9024
  interface ESLint2DigitsOptions {
8985
- ignores?: FlatGitignoreOptions;
9025
+ ignores?: OptionsWithIgnores;
8986
9026
  turbo?: SharedOptions<OptionsOverrides> | boolean;
8987
9027
  js?: OptionsOverrides;
8988
9028
  ts?: SharedOptions<OptionsTypeScriptWithTypes> | boolean;
8989
- react?: SharedOptions<OptionsWithFiles> | boolean;
9029
+ react?: SharedOptions<OptionsWithReact> | boolean;
8990
9030
  next?: SharedOptions<OptionsWithFiles> | boolean;
8991
9031
  tailwind?: SharedOptions<OptionsOverrides> | boolean;
8992
9032
  storybook?: SharedOptions<OptionsWithStorybook> | boolean;
@@ -8994,4 +9034,4 @@ interface ESLint2DigitsOptions {
8994
9034
  }
8995
9035
  declare function twoDigits(options?: ESLint2DigitsOptions, ...userConfig: TypedFlatConfigItem[]): Promise<TypedFlatConfigItem[]>;
8996
9036
 
8997
- export { type ConfigNames, type OptionsOverrides, type OptionsTypeScriptWithTypes, type OptionsWithFiles, type OptionsWithStorybook, type Rules, type TypedFlatConfigItem, comments, twoDigits as default, ignores, javascript, jsdoc, next, node, prettier, react, storybook, tailwind, tanstack, turbo, twoDigits, typescript, unicorn };
9037
+ export { type ConfigNames, type OptionsOverrides, type OptionsTypeScriptWithTypes, type OptionsWithFiles, type OptionsWithIgnores, type OptionsWithReact, type OptionsWithStorybook, type Rules, type TypedFlatConfigItem, comments, twoDigits as default, ignores, javascript, jsdoc, next, node, prettier, react, storybook, tailwind, tanstack, turbo, twoDigits, typescript, unicorn };
package/dist/index.d.ts CHANGED
@@ -10,7 +10,7 @@ import { FlatGitignoreOptions } from 'eslint-config-flat-gitignore';
10
10
  interface RuleOptions {
11
11
  /**
12
12
  * Enforce giving proper names to type parameters when there are two or more
13
- * @see https://github.com/2digits-agency/configs/blob/@2digits/eslint-plugin@2.0.0/packages/eslint/src/rules/type-param-names.ts
13
+ * @see https://github.com/2digits-agency/configs/blob/@2digits/eslint-plugin@2.0.1/packages/eslint/src/rules/type-param-names.ts
14
14
  */
15
15
  '@2digits/type-param-names'?: Linter.RuleEntry<[]>
16
16
  /**
@@ -2004,6 +2004,10 @@ interface RuleOptions {
2004
2004
  * @see https://eslint.org/docs/latest/rules/radix
2005
2005
  */
2006
2006
  'radix'?: Linter.RuleEntry<Radix>
2007
+ /**
2008
+ * Surfaces diagnostics from React Forget
2009
+ */
2010
+ 'react-compiler/react-compiler'?: Linter.RuleEntry<ReactCompilerReactCompiler>
2007
2011
  /**
2008
2012
  * disallow passing 'children' to void DOM elements
2009
2013
  * @see https://eslint-react.xyz/rules/dom-no-children-in-void-dom-elements
@@ -3496,6 +3500,11 @@ interface RuleOptions {
3496
3500
  * @see https://typescript-eslint.io/rules/no-unnecessary-qualifier
3497
3501
  */
3498
3502
  'ts/no-unnecessary-qualifier'?: Linter.RuleEntry<[]>
3503
+ /**
3504
+ * Disallow unnecessary template expressions
3505
+ * @see https://typescript-eslint.io/rules/no-unnecessary-template-expression
3506
+ */
3507
+ 'ts/no-unnecessary-template-expression'?: Linter.RuleEntry<[]>
3499
3508
  /**
3500
3509
  * Disallow type arguments that are equal to the default
3501
3510
  * @see https://typescript-eslint.io/rules/no-unnecessary-type-arguments
@@ -3577,8 +3586,9 @@ interface RuleOptions {
3577
3586
  */
3578
3587
  'ts/no-useless-empty-export'?: Linter.RuleEntry<[]>
3579
3588
  /**
3580
- * Disallow unnecessary template literals
3589
+ * Disallow unnecessary template expressions
3581
3590
  * @see https://typescript-eslint.io/rules/no-useless-template-literals
3591
+ * @deprecated
3582
3592
  */
3583
3593
  'ts/no-useless-template-literals'?: Linter.RuleEntry<[]>
3584
3594
  /**
@@ -3726,7 +3736,7 @@ interface RuleOptions {
3726
3736
  */
3727
3737
  'ts/require-array-sort-compare'?: Linter.RuleEntry<TsRequireArraySortCompare>
3728
3738
  /**
3729
- * Disallow async functions which have no `await` expression
3739
+ * Disallow async functions which do not return promises and have no `await` expression
3730
3740
  * @see https://typescript-eslint.io/rules/require-await
3731
3741
  */
3732
3742
  'ts/require-await'?: Linter.RuleEntry<[]>
@@ -6568,6 +6578,10 @@ type Quotes = []|[("single" | "double" | "backtick")]|[("single" | "double" | "b
6568
6578
  })]
6569
6579
  // ----- radix -----
6570
6580
  type Radix = []|[("always" | "as-needed")]
6581
+ // ----- react-compiler/react-compiler -----
6582
+ type ReactCompilerReactCompiler = []|[{
6583
+ [k: string]: unknown | undefined
6584
+ }]
6571
6585
  // ----- react-hooks/exhaustive-deps -----
6572
6586
  type ReactHooksExhaustiveDeps = []|[{
6573
6587
  additionalHooks?: string
@@ -8217,6 +8231,18 @@ type TsNoFloatingPromises = []|[{
8217
8231
  ignoreVoid?: boolean
8218
8232
 
8219
8233
  ignoreIIFE?: boolean
8234
+ allowForKnownSafePromises?: (string | {
8235
+ from: "file"
8236
+ name: (string | [string, ...(string)[]])
8237
+ path?: string
8238
+ } | {
8239
+ from: "lib"
8240
+ name: (string | [string, ...(string)[]])
8241
+ } | {
8242
+ from: "package"
8243
+ name: (string | [string, ...(string)[]])
8244
+ package: string
8245
+ })[]
8220
8246
  }]
8221
8247
  // ----- ts/no-inferrable-types -----
8222
8248
  type TsNoInferrableTypes = []|[{
@@ -8949,10 +8975,24 @@ interface OptionsWithStorybook extends OptionsWithFiles {
8949
8975
  */
8950
8976
  storybookDirectory?: string;
8951
8977
  }
8978
+ interface OptionsWithReact extends OptionsWithFiles {
8979
+ /**
8980
+ * Enable the react-compiler plugin.
8981
+ *
8982
+ * @default true
8983
+ */
8984
+ reactCompiler?: boolean;
8985
+ }
8986
+ interface OptionsWithIgnores {
8987
+ /** Options to pass to eslint-config-flat-gitignore */
8988
+ gitIgnore?: Omit<FlatGitignoreOptions, 'name' | 'root'>;
8989
+ /** An array of glob patterns to ignore in addition to the default ignores. */
8990
+ ignores?: string[];
8991
+ }
8952
8992
 
8953
8993
  declare function comments(): TypedFlatConfigItem[];
8954
8994
 
8955
- declare function ignores(options?: FlatGitignoreOptions): Promise<TypedFlatConfigItem[]>;
8995
+ declare function ignores(options?: OptionsWithIgnores): Promise<TypedFlatConfigItem[]>;
8956
8996
 
8957
8997
  declare function javascript(options?: OptionsOverrides): TypedFlatConfigItem[];
8958
8998
 
@@ -8964,7 +9004,7 @@ declare function node(): TypedFlatConfigItem[];
8964
9004
 
8965
9005
  declare function prettier(): Promise<TypedFlatConfigItem[]>;
8966
9006
 
8967
- declare function react(options?: OptionsWithFiles & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
9007
+ declare function react(options?: OptionsWithReact & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
8968
9008
 
8969
9009
  declare function storybook(options?: OptionsWithStorybook & OptionsTypeScriptWithTypes): Promise<TypedFlatConfigItem[]>;
8970
9010
 
@@ -8982,11 +9022,11 @@ type SharedOptions<T = unknown> = T & {
8982
9022
  enable?: boolean;
8983
9023
  };
8984
9024
  interface ESLint2DigitsOptions {
8985
- ignores?: FlatGitignoreOptions;
9025
+ ignores?: OptionsWithIgnores;
8986
9026
  turbo?: SharedOptions<OptionsOverrides> | boolean;
8987
9027
  js?: OptionsOverrides;
8988
9028
  ts?: SharedOptions<OptionsTypeScriptWithTypes> | boolean;
8989
- react?: SharedOptions<OptionsWithFiles> | boolean;
9029
+ react?: SharedOptions<OptionsWithReact> | boolean;
8990
9030
  next?: SharedOptions<OptionsWithFiles> | boolean;
8991
9031
  tailwind?: SharedOptions<OptionsOverrides> | boolean;
8992
9032
  storybook?: SharedOptions<OptionsWithStorybook> | boolean;
@@ -8994,4 +9034,4 @@ interface ESLint2DigitsOptions {
8994
9034
  }
8995
9035
  declare function twoDigits(options?: ESLint2DigitsOptions, ...userConfig: TypedFlatConfigItem[]): Promise<TypedFlatConfigItem[]>;
8996
9036
 
8997
- export { type ConfigNames, type OptionsOverrides, type OptionsTypeScriptWithTypes, type OptionsWithFiles, type OptionsWithStorybook, type Rules, type TypedFlatConfigItem, comments, twoDigits as default, ignores, javascript, jsdoc, next, node, prettier, react, storybook, tailwind, tanstack, turbo, twoDigits, typescript, unicorn };
9037
+ export { type ConfigNames, type OptionsOverrides, type OptionsTypeScriptWithTypes, type OptionsWithFiles, type OptionsWithIgnores, type OptionsWithReact, type OptionsWithStorybook, type Rules, type TypedFlatConfigItem, comments, twoDigits as default, ignores, javascript, jsdoc, next, node, prettier, react, storybook, tailwind, tanstack, turbo, twoDigits, typescript, unicorn };
package/dist/index.js CHANGED
@@ -1,15 +1,15 @@
1
- import h from 'eslint-plugin-unicorn';
2
- import T from 'eslint-plugin-eslint-comments';
3
- import w from 'eslint-plugin-n';
1
+ import k from 'eslint-plugin-unicorn';
2
+ import w from 'eslint-plugin-eslint-comments';
3
+ import v from 'eslint-plugin-n';
4
4
  import { composer, renamePluginsInRules, renamePluginsInConfigs, FlatConfigComposer } from 'eslint-flat-config-utils';
5
- import M from '@eslint/js';
6
- import k from 'globals';
5
+ import z from '@eslint/js';
6
+ import T from 'globals';
7
7
  import { fixupPluginRules } from '@eslint/compat';
8
8
  import { findUp } from 'find-up';
9
9
  import { isPackageExists } from 'local-pkg';
10
10
 
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()}
11
+ function j(){return [{name:"2digits:comments",plugins:{"eslint-comments":w},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 C="**/*.?([cm])[jt]s?(x)",h="**/*.?([cm])ts",O="**/*.?([cm])tsx",S="**/*.stories.tsx",I=["**/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={}){let{gitIgnore:t,ignores:r=[]}=e;return composer({ignores:[I,r].flat(),name:"2digits:ignores"},o(import('eslint-config-flat-gitignore')).then(a=>({...a(t),name:"2digits:gitignore"})))}function P(e={}){let{overrides:t={}}=e;return [{name:"2digits:javascript",languageOptions:{ecmaVersion:2022,globals:{...T.browser,...T.es2021,...T.node,document:"readonly",navigator:"readonly",window:"readonly"},parserOptions:{ecmaFeatures:{jsx:!0},ecmaVersion:2022,sourceType:"module"},sourceType:"module"},linterOptions:{reportUnusedDisableDirectives:!0},rules:{...z.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 _(){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 u={"@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"};async function W(e={}){let{files:t=[h,O],overrides:r={},tsconfigPath:a,parserOptions:i}=e,[c,l]=await Promise.all([o(import('@next/eslint-plugin-next')),o(import('@typescript-eslint/parser'))]),m=renamePluginsInRules({...c.configs.recommended.rules,...c.configs["core-web-vitals"].rules},u);return [{name:"2digits:next/setup",plugins:{next:fixupPluginRules(c)}},{name:"2digits:next/rules",files:t,languageOptions:{parser:l,parserOptions:{ecmaFeatures:{jsx:!0},project:a,...i},sourceType:"module"},rules:{...m,"next/no-html-link-for-pages":"off",...r}}]}function D(){return [{name:"2digits:node",settings:{node:{version:">= 20.0.0"}},plugins:{node:v},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 R(){return [{name:"2digits:prettier",rules:(await o(import('eslint-config-prettier'))).rules}]}async function L(e={}){let{files:t=[h,O],overrides:r={},tsconfigPath:a,parserOptions:i,tsconfigRootDir:c,reactCompiler:l=!0}=e,[m,f,y,x,A]=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')),l?o(import('eslint-plugin-react-compiler')):void 0]),b=m.configs.all.plugins,M=renamePluginsInRules({...y.configs.recommended.rules,...y.configs["jsx-runtime"].rules,...f.configs.recommended.rules,...m.configs["recommended-type-checked"].rules},u);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"],...l?{"react-compiler":A}:{}},settings:{react:{version:"detect"}}},{name:"2digits:react/rules",files:t,languageOptions:{parser:x,parserOptions:{ecmaFeatures:{jsx:!0},tsconfigRootDir:c,project:a,...i},sourceType:"module"},rules:{...M,...l?{"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}}]}async function q(e={}){let{files:t=[S],overrides:r={},parserOptions:a,tsconfigPath:i,storybookDirectory:c=".storybook"}=e,[l,m]=await Promise.all([o(import('eslint-plugin-storybook')),o(import('@typescript-eslint/parser'))]),f={parser:m,parserOptions:{ecmaFeatures:{jsx:!0},project:i,...a},sourceType:"module"};return [{name:"2digits:storybook/setup",plugins:{storybook:fixupPluginRules(l)}},{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 E(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 G(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 U(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 B(e={}){let{overrides:t={},parserOptions:r={},tsconfigPath:a=!0}=e,[{plugin:i,configs:c,parser:l},m]=await Promise.all([o(import('typescript-eslint')),o(import('@2digits/eslint-plugin'))]),f=renamePluginsInConfigs(c.strictTypeChecked,u),y=Object.fromEntries(f.flatMap(({rules:x})=>Object.entries(x??{})));return [{name:"2digits:typescript/setup",plugins:{ts:i,"@2digits":m},languageOptions:{parser:l,parserOptions:{sourceType:"module",tsconfigRootDir:process.cwd(),project:a,...r}}},{name:"2digits:typescript/rules",files:[C],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:"^_"}],...m.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 N(){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 re(e={},...t){let r=new FlatConfigComposer(F(e.ignores),P(e.js),D(),j(),_(),N());g(e.turbo,isPackageExists("turbo"))&&(r=r.append(U(d(e.turbo))));let{overrides:a,...i}=d(e.ts);return g(e.ts,isPackageExists("typescript"))&&(r=r.append(B(d(e.ts)))),g(e.react,isPackageExists("react"))&&(r=r.append(L({...d(e.react),...i}))),g(e.next,isPackageExists("next"))&&(r=r.append(W({...d(e.next),...i}))),g(e.storybook,isPackageExists("storybook"))&&(r=r.append(q({...d(e.storybook),...i}))),g(e.tailwind,isPackageExists("tailwindcss"))&&(r=r.append(E(d(e.tailwind)))),g(e.tanstack,isPackageExists("react-query")||isPackageExists("@tanstack/react-query")||isPackageExists("@tanstack/react-query-devtools"))&&(r=r.append(G(d(e.tanstack)))),r=r.append(...t),isPackageExists("prettier")&&(r=r.append(R())),r.renamePlugins(u).toConfigs()}
12
12
 
13
- export { v as comments, Z as default, F as ignores, I as javascript, P as jsdoc, _ as next, D as node, W as prettier, G as react, L as storybook, q as tailwind, E as tanstack, R as turbo, Z as twoDigits, U as typescript, B as unicorn };
13
+ export { j as comments, re as default, F as ignores, P as javascript, _ as jsdoc, W as next, D as node, R as prettier, L as react, q as storybook, E as tailwind, G as tanstack, U as turbo, re as twoDigits, B as typescript, N as unicorn };
14
14
  //# sourceMappingURL=out.js.map
15
15
  //# 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/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","gitIgnore","eslint","globals","javascript","overrides","jsdoc","fixupPluginRules","renamePluginsInRules","PluginNameMap","next","files","tsconfigPath","parserOptions","parser","recommended","node","prettier","react","tsconfigRootDir","reactCompiler","pluginReact","pluginReactHooks","pluginReactCompiler","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 { 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 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-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} 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, 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 { 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 { 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 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 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 );\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"]}
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.1",
4
+ "version": "2.1.0",
5
5
  "type": "module",
6
6
  "license": "MIT",
7
7
  "public": true,
@@ -29,13 +29,13 @@
29
29
  ],
30
30
  "dependencies": {
31
31
  "@2digits/constants": "0.1.6",
32
- "@2digits/eslint-plugin": "2.0.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
36
  "@next/eslint-plugin-next": "^14.2.3",
37
37
  "@tanstack/eslint-plugin-query": "^5.35.6",
38
- "@typescript-eslint/parser": "^7.11.0",
38
+ "@typescript-eslint/parser": "^7.12.0",
39
39
  "eslint-config-flat-gitignore": "^0.1.5",
40
40
  "eslint-config-prettier": "^9.1.0",
41
41
  "eslint-flat-config-utils": "^0.2.5",
@@ -43,22 +43,23 @@
43
43
  "eslint-plugin-jsdoc": "^48.2.7",
44
44
  "eslint-plugin-n": "^17.7.0",
45
45
  "eslint-plugin-react": "^7.34.2",
46
+ "eslint-plugin-react-compiler": "0.0.0-experimental-51a85ea-20240601",
46
47
  "eslint-plugin-react-hooks": "^4.6.2",
47
48
  "eslint-plugin-storybook": "^0.8.0",
48
49
  "eslint-plugin-tailwindcss": "^3.17.0",
49
- "eslint-plugin-turbo": "^1.13.3",
50
+ "eslint-plugin-turbo": "^2.0.1",
50
51
  "eslint-plugin-unicorn": "^53.0.0",
51
52
  "find-up": "^7.0.0",
52
53
  "globals": "^15.3.0",
53
54
  "local-pkg": "^0.5.0",
54
- "typescript-eslint": "^7.11.0"
55
+ "typescript-eslint": "^7.12.0"
55
56
  },
56
57
  "devDependencies": {
57
58
  "@2digits/tsconfig": "0.3.5",
58
59
  "@eslint/config-inspector": "^0.4.10",
59
60
  "@types/eslint": "^8.56.10",
60
61
  "@types/eslint__js": "^8.42.3",
61
- "@types/node": "^20.14.0",
62
+ "@types/node": "^20.14.1",
62
63
  "eslint": "^9.4.0",
63
64
  "eslint-typegen": "^0.2.4",
64
65
  "tsup": "^8.1.0",