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 0d63d5f..33f2d99 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@
Part of the Ant Design ecosystem.
Part of the Ant Design ecosystem.
π Virtual scrolling list component for React.
diff --git a/README.zh-CN.md b/README.zh-CN.md index d0a3192..d1cbe56 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 0000000..0e70eed
--- /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/examples/no-virtual.tsx b/examples/no-virtual.tsx
index 793ab90..d48e0df 100644
--- a/examples/no-virtual.tsx
+++ b/examples/no-virtual.tsx
@@ -7,7 +7,7 @@ interface Item {
height: number;
}
-const MyItem: React.FC (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/src/Item.tsx b/src/Item.tsx
index 8a8cb6c..2839a53 100644
--- a/src/Item.tsx
+++ b/src/Item.tsx
@@ -6,11 +6,14 @@ export interface ItemProps {
}
export function Item({ children, setRef }: ItemProps) {
- const refFunc = React.useCallback(node => {
- setRef(node);
- }, []);
+ const refFunc = React.useCallback(
+ node => {
+ setRef(node);
+ },
+ [setRef],
+ );
- return React.cloneElement(children, {
+ return React.cloneElement(children as React.ReactElement