diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 3b730ef99..5e6c7faab 100644 --- a/.github/dependabot.yml +++ b/.github/dependabot.yml @@ -8,6 +8,10 @@ updates: time: '21:00' timezone: Asia/Shanghai open-pull-requests-limit: 10 + groups: + npm-dependencies: + patterns: + - '*' - package-ecosystem: github-actions directory: '/' @@ -17,3 +21,7 @@ updates: time: '21:00' timezone: Asia/Shanghai open-pull-requests-limit: 10 + groups: + github-actions: + patterns: + - '*' diff --git a/README.md b/README.md index 24bbf8dc1..94a4b9fe5 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@
Part of the Ant Design ecosystem.
Part of the Ant Design ecosystem.
๐๏ธ Accessible React slider for single values, ranges, marks, and editable handles.
diff --git a/README.zh-CN.md b/README.zh-CN.md index a8800e576..5a094eefc 100644 --- a/README.zh-CN.md +++ b/README.zh-CN.md @@ -1,6 +1,6 @@
Ant Design ็ๆ็ไธ้จๅใ
Ant Design ็ๆ็ไธ้จๅใ
๐๏ธ React ๆปๅจ่พๅ ฅ็ปไปถ๏ผๆฏๆ่ๅดใๅปๅบฆใๆ็คบๅ้ฎ็ไบคไบใ
diff --git a/eslint.config.mjs b/eslint.config.mjs
new file mode 100644
index 000000000..0e70eed92
--- /dev/null
+++ b/eslint.config.mjs
@@ -0,0 +1,88 @@
+import { FlatCompat } from '@eslint/eslintrc';
+import js from '@eslint/js';
+import tsEslintPlugin from '@typescript-eslint/eslint-plugin';
+import { createRequire } from 'node:module';
+import path from 'node:path';
+import { fileURLToPath } from 'node:url';
+
+const __filename = fileURLToPath(import.meta.url);
+const __dirname = path.dirname(__filename);
+const require = createRequire(import.meta.url);
+
+const compat = new FlatCompat({
+ baseDirectory: __dirname,
+ recommendedConfig: js.configs.recommended,
+ allConfig: js.configs.all,
+});
+
+const recommendedTsRulesConfig = tsEslintPlugin.configs.recommended;
+const recommendedTsRulesObject = Array.isArray(recommendedTsRulesConfig)
+ ? recommendedTsRulesConfig.reduce(
+ (rules, config) => ({ ...rules, ...(config.rules || {}) }),
+ {},
+ )
+ : recommendedTsRulesConfig?.rules || {};
+const recommendedTsRules = new Set(Object.keys(recommendedTsRulesObject));
+const noopRule = {
+ meta: { type: 'problem', docs: {}, schema: [] },
+ create: () => ({}),
+};
+
+function normalizeConfig(config) {
+ const next = { ...config };
+
+ if (next.plugins?.['@typescript-eslint']) {
+ next.plugins = { ...next.plugins };
+ delete next.plugins['@typescript-eslint'];
+ }
+
+ if (next.rules) {
+ next.rules = Object.fromEntries(
+ Object.entries(next.rules).filter(([ruleName]) => {
+ if (!ruleName.startsWith('@typescript-eslint/')) {
+ return true;
+ }
+ return recommendedTsRules.has(ruleName);
+ }),
+ );
+ }
+
+ return next;
+}
+
+export default [
+ {
+ ignores: [
+ 'node_modules/',
+ 'coverage/',
+ 'es/',
+ 'lib/',
+ 'dist/',
+ 'docs-dist/',
+ '.dumi/',
+ '.doc/',
+ '.vercel/',
+ '.eslintrc.js',
+ 'src/index.d.ts',
+ ],
+ },
+ {
+ plugins: {
+ '@typescript-eslint': {
+ ...tsEslintPlugin,
+ rules: {
+ ...tsEslintPlugin.rules,
+ 'consistent-type-exports': noopRule,
+ },
+ },
+ },
+ },
+ ...compat.config(require('./.eslintrc.js')).map(normalizeConfig),
+ {
+ rules: {
+ '@typescript-eslint/no-empty-object-type': 'off',
+ '@typescript-eslint/no-unsafe-function-type': 'off',
+ '@typescript-eslint/no-unused-vars': 'off',
+ },
+ },
+];
diff --git a/global.d.ts b/global.d.ts
new file mode 100644
index 000000000..97e90a388
--- /dev/null
+++ b/global.d.ts
@@ -0,0 +1,48 @@
+/// (object: {} | null | undefined): object is React.ReactElement ;
+ function cloneElement (
+ element: React.ReactElement ,
+ props?: (Partial & React.Attributes) | null,
+ ...children: React.ReactNode[]
+ ): React.ReactElement ;
+}
diff --git a/tsconfig.json b/tsconfig.json
index 5b4fcdfa9..5debbbbcb 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -1,35 +1,43 @@
{
"compilerOptions": {
"target": "esnext",
- "moduleResolution": "node",
- "baseUrl": "./",
+ "moduleResolution": "bundler",
"jsx": "react",
"declaration": true,
"skipLibCheck": true,
"esModuleInterop": true,
"paths": {
"@/*": [
- "src/*"
+ "./src/*"
],
"@@/*": [
- "src/.umi/*"
+ "./src/.umi/*"
],
"@rc-component/slider": [
- "src/index.tsx"
+ "./src/index.tsx"
],
"@rc-component/slider/es": [
- "src"
+ "./src"
],
"@rc-component/slider/es/*": [
- "src/*"
+ "./src/*"
],
"@rc-component/slider/assets/*": [
- "assets/*"
+ "./assets/*"
]
},
- "ignoreDeprecations": "5.0"
+ "noImplicitAny": false,
+ "strictNullChecks": false,
+ "strictPropertyInitialization": false,
+ "strictFunctionTypes": false,
+ "strict": false,
+ "noImplicitThis": false,
+ "strictBindCallApply": false,
+ "module": "ESNext"
},
"include": [
+ "react-compat.d.ts",
+ "global.d.ts",
".dumirc.ts",
".fatherrc.ts",
"src",