diff --git a/.github/dependabot.yml b/.github/dependabot.yml index 3b730ef..5e6c7fa 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 ae8ad8d..440e965 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@
Part of the Ant Design ecosystem.
Part of the Ant Design ecosystem.
📤 Low-level React upload primitive for Ajax, drag, paste, directory, and custom requests.
diff --git a/README.zh-CN.md b/README.zh-CN.md index fa00a14..cc0e8dc 100644 --- a/README.zh-CN.md +++ b/README.zh-CN.md @@ -1,6 +1,6 @@
Ant Design 生态的一部分。
📤 React 文件上传基础组件,支持拖拽、请求定制和上传列表。
diff --git a/eslint.config.mjs b/eslint.config.mjs
new file mode 100644
index 0000000..b25fb5d
--- /dev/null
+++ b/eslint.config.mjs
@@ -0,0 +1,79 @@
+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 recommendedTsRules = new Set(Object.keys(tsEslintPlugin.configs.recommended.rules || {}));
+const noopRule = {
+ meta: { type: 'problem', docs: {}, schema: [] },
+ create: () => ({}),
+};
+
+function normalizeConfig(config) {
+ const next = { ...config };
+
+ if (next.plugins?.['@typescript-eslint']) {
+ next.plugins = {
+ ...next.plugins,
+ '@typescript-eslint': {
+ ...next.plugins['@typescript-eslint'],
+ rules: {
+ ...next.plugins['@typescript-eslint'].rules,
+ 'ban-types': noopRule,
+ },
+ },
+ };
+ }
+
+ if (next.rules) {
+ next.rules = Object.fromEntries(
+ Object.entries(next.rules).filter(([ruleName]) => {
+ if (!ruleName.startsWith('@typescript-eslint/')) {
+ return true;
+ }
+ return recommendedTsRules.has(ruleName) || ruleName === '@typescript-eslint/ban-types';
+ }),
+ );
+ }
+
+ return next;
+}
+
+export default [
+ {
+ ignores: [
+ 'node_modules/',
+ 'coverage/',
+ 'es/',
+ 'lib/',
+ 'dist/',
+ 'docs-dist/',
+ '.dumi/',
+ '.doc/',
+ '.vercel/',
+ '.eslintrc.js',
+ 'src/index.d.ts',
+ ],
+ },
+ ...compat.config(require('./.eslintrc.js')).map(normalizeConfig),
+ {
+ rules: {
+ '@typescript-eslint/ban-types': 'off',
+ '@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 0000000..e35e177
--- /dev/null
+++ b/global.d.ts
@@ -0,0 +1,56 @@
+/// (object: {} | null | undefined): object is React.ReactElement ;
+ function cloneElement (
+ element: React.ReactElement ,
+ props?: (Partial & React.Attributes) | null,
+ ...children: React.ReactNode[]
+ ): React.ReactElement ;
+}
+
+declare module 'react-dom' {
+ function hydrate(element: React.ReactNode, container: Element | DocumentFragment): void;
+}
diff --git a/tsconfig.json b/tsconfig.json
index d4e3e1a..efc3f61 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -24,9 +24,18 @@
"src/*"
]
},
- "ignoreDeprecations": "5.0"
+ "ignoreDeprecations": "6.0",
+ "noImplicitAny": false,
+ "strictNullChecks": false,
+ "strictPropertyInitialization": false,
+ "strictFunctionTypes": false,
+ "strict": false,
+ "noImplicitThis": false,
+ "strictBindCallApply": false
},
"include": [
+ "react-compat.d.ts",
+ "global.d.ts",
".dumirc.ts",
".fatherrc.ts",
"src",