type: optimization AnyObject type (#43366)

* type: optimization AnyObject type

* fix lint

* rerun
This commit is contained in:
lijianan 2023-07-05 16:54:04 +08:00 committed by GitHub
parent 1d01a1f681
commit 67900a7aad
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 19 additions and 18 deletions

View File

@ -1,4 +1,5 @@
import * as React from 'react'; import * as React from 'react';
import type { AnyObject } from './type';
export const { isValidElement } = React; export const { isValidElement } = React;
@ -6,8 +7,6 @@ export function isFragment(child: any): boolean {
return child && isValidElement(child) && child.type === React.Fragment; return child && isValidElement(child) && child.type === React.Fragment;
} }
type AnyObject = Record<PropertyKey, any>;
type RenderProps = AnyObject | ((originProps: AnyObject) => AnyObject | void); type RenderProps = AnyObject | ((originProps: AnyObject) => AnyObject | void);
export function replaceElement( export function replaceElement(

View File

@ -1,2 +1,4 @@
/** https://github.com/Microsoft/TypeScript/issues/29729 */ /** https://github.com/Microsoft/TypeScript/issues/29729 */
export type LiteralUnion<T extends string> = T | (string & {}); export type LiteralUnion<T extends string> = T | (string & {});
export type AnyObject = Record<PropertyKey, any>;

View File

@ -1,10 +1,11 @@
import classNames from 'classnames'; import classNames from 'classnames';
import { type TableProps as RcTableProps, INTERNAL_HOOKS } from 'rc-table'; import { INTERNAL_HOOKS, type TableProps as RcTableProps } from 'rc-table';
import { convertChildrenToColumns } from 'rc-table/lib/hooks/useColumns'; import { convertChildrenToColumns } from 'rc-table/lib/hooks/useColumns';
import omit from 'rc-util/lib/omit'; import omit from 'rc-util/lib/omit';
import * as React from 'react'; import * as React from 'react';
import type { Breakpoint } from '../_util/responsiveObserver'; import type { Breakpoint } from '../_util/responsiveObserver';
import scrollTo from '../_util/scrollTo'; import scrollTo from '../_util/scrollTo';
import type { AnyObject } from '../_util/type';
import warning from '../_util/warning'; import warning from '../_util/warning';
import type { SizeType } from '../config-provider/SizeContext'; import type { SizeType } from '../config-provider/SizeContext';
import type { ConfigConsumerProps } from '../config-provider/context'; import type { ConfigConsumerProps } from '../config-provider/context';
@ -19,7 +20,6 @@ import Spin from '../spin';
import type { TooltipProps } from '../tooltip'; import type { TooltipProps } from '../tooltip';
import renderExpandIcon from './ExpandIcon'; import renderExpandIcon from './ExpandIcon';
import RcTable from './RcTable'; import RcTable from './RcTable';
import type { AnyObject } from './Table';
import type { FilterState } from './hooks/useFilter'; import type { FilterState } from './hooks/useFilter';
import useFilter, { getFilterData } from './hooks/useFilter'; import useFilter, { getFilterData } from './hooks/useFilter';
import useLazyKVMap from './hooks/useLazyKVMap'; import useLazyKVMap from './hooks/useLazyKVMap';
@ -109,7 +109,7 @@ export interface TableProps<RecordType>
showSorterTooltip?: boolean | TooltipProps; showSorterTooltip?: boolean | TooltipProps;
} }
const InternalTable = <RecordType extends AnyObject = any>( const InternalTable = <RecordType extends AnyObject = AnyObject>(
props: InternalTableProps<RecordType>, props: InternalTableProps<RecordType>,
ref: React.MutableRefObject<HTMLDivElement>, ref: React.MutableRefObject<HTMLDivElement>,
) => { ) => {

View File

@ -1,5 +1,6 @@
import { EXPAND_COLUMN, Summary } from 'rc-table'; import { EXPAND_COLUMN, Summary } from 'rc-table';
import * as React from 'react'; import * as React from 'react';
import type { AnyObject } from '../_util/type';
import Column from './Column'; import Column from './Column';
import ColumnGroup from './ColumnGroup'; import ColumnGroup from './ColumnGroup';
import type { TableProps } from './InternalTable'; import type { TableProps } from './InternalTable';
@ -12,13 +13,11 @@ import {
} from './hooks/useSelection'; } from './hooks/useSelection';
import type { RefTable } from './interface'; import type { RefTable } from './interface';
export type AnyObject = Record<PropertyKey, any>; const Table = <RecordType extends AnyObject = AnyObject>(
const Table = <RecordType extends AnyObject = any>(
props: TableProps<RecordType>, props: TableProps<RecordType>,
ref: React.Ref<HTMLDivElement>, ref: React.Ref<HTMLDivElement>,
) => { ) => {
const renderTimesRef = React.useRef(0); const renderTimesRef = React.useRef<number>(0);
renderTimesRef.current += 1; renderTimesRef.current += 1;
return <InternalTable<RecordType> {...props} ref={ref} _renderTimes={renderTimesRef.current} />; return <InternalTable<RecordType> {...props} ref={ref} _renderTimes={renderTimesRef.current} />;
}; };

View File

@ -251,7 +251,7 @@ describe('Table', () => {
dataIndex: 'name', dataIndex: 'name',
}, },
]; ];
render(<Table columns={columns} rowKey={(record, index) => record + index} />); render(<Table columns={columns} rowKey={(record, index) => record.key + index} />);
expect(warnSpy).toHaveBeenCalledWith( expect(warnSpy).toHaveBeenCalledWith(
'Warning: [antd: Table] `index` parameter of `rowKey` function is deprecated. There is no guarantee that it will work as expected.', 'Warning: [antd: Table] `index` parameter of `rowKey` function is deprecated. There is no guarantee that it will work as expected.',
); );

View File

@ -9,12 +9,12 @@ import { convertDataToEntities } from 'rc-tree/lib/utils/treeUtil';
import useMergedState from 'rc-util/lib/hooks/useMergedState'; import useMergedState from 'rc-util/lib/hooks/useMergedState';
import * as React from 'react'; import * as React from 'react';
import { useCallback, useMemo, useState } from 'react'; import { useCallback, useMemo, useState } from 'react';
import type { AnyObject } from '../../_util/type';
import warning from '../../_util/warning'; import warning from '../../_util/warning';
import type { CheckboxProps } from '../../checkbox'; import type { CheckboxProps } from '../../checkbox';
import Checkbox from '../../checkbox'; import Checkbox from '../../checkbox';
import Dropdown from '../../dropdown'; import Dropdown from '../../dropdown';
import Radio from '../../radio'; import Radio from '../../radio';
import type { AnyObject } from '../Table';
import type { import type {
ColumnType, ColumnType,
ColumnsType, ColumnsType,
@ -38,7 +38,7 @@ export const SELECTION_NONE = 'SELECT_NONE' as const;
const EMPTY_LIST: React.Key[] = []; const EMPTY_LIST: React.Key[] = [];
interface UseSelectionConfig<RecordType extends AnyObject = any> { interface UseSelectionConfig<RecordType extends AnyObject = AnyObject> {
prefixCls: string; prefixCls: string;
pageData: RecordType[]; pageData: RecordType[];
data: RecordType[]; data: RecordType[];
@ -56,7 +56,7 @@ export type INTERNAL_SELECTION_ITEM =
| typeof SELECTION_INVERT | typeof SELECTION_INVERT
| typeof SELECTION_NONE; | typeof SELECTION_NONE;
const flattenData = <RecordType extends AnyObject = any>( const flattenData = <RecordType extends AnyObject = AnyObject>(
childrenColumnName: keyof RecordType, childrenColumnName: keyof RecordType,
data?: RecordType[], data?: RecordType[],
): RecordType[] => { ): RecordType[] => {
@ -70,7 +70,7 @@ const flattenData = <RecordType extends AnyObject = any>(
return list; return list;
}; };
const useSelection = <RecordType extends AnyObject = any>( const useSelection = <RecordType extends AnyObject = AnyObject>(
config: UseSelectionConfig<RecordType>, config: UseSelectionConfig<RecordType>,
rowSelection?: TableRowSelection<RecordType>, rowSelection?: TableRowSelection<RecordType>,
): readonly [TransformColumns<RecordType>, Set<Key>] => { ): readonly [TransformColumns<RecordType>, Set<Key>] => {

View File

@ -7,23 +7,24 @@ import type {
import { ExpandableConfig, GetRowKey } from 'rc-table/lib/interface'; import { ExpandableConfig, GetRowKey } from 'rc-table/lib/interface';
import type * as React from 'react'; import type * as React from 'react';
import type { Breakpoint } from '../_util/responsiveObserver'; import type { Breakpoint } from '../_util/responsiveObserver';
import type { AnyObject } from '../_util/type';
import type { CheckboxProps } from '../checkbox'; import type { CheckboxProps } from '../checkbox';
import type { PaginationProps } from '../pagination'; import type { PaginationProps } from '../pagination';
import type { TooltipProps } from '../tooltip'; import type { TooltipProps } from '../tooltip';
import type { InternalTableProps, TableProps } from './InternalTable'; import type { InternalTableProps, TableProps } from './InternalTable';
import type { INTERNAL_SELECTION_ITEM } from './hooks/useSelection'; import type { INTERNAL_SELECTION_ITEM } from './hooks/useSelection';
export type RefTable = <RecordType extends object = any>( export type RefTable = <RecordType extends AnyObject = AnyObject>(
props: React.PropsWithChildren<TableProps<RecordType>> & { ref?: React.Ref<HTMLDivElement> }, props: React.PropsWithChildren<TableProps<RecordType>> & { ref?: React.Ref<HTMLDivElement> },
) => React.ReactElement; ) => React.ReactElement;
export type RefInternalTable = <RecordType extends object = any>( export type RefInternalTable = <RecordType extends AnyObject = AnyObject>(
props: React.PropsWithChildren<InternalTableProps<RecordType>> & { props: React.PropsWithChildren<InternalTableProps<RecordType>> & {
ref?: React.Ref<HTMLDivElement>; ref?: React.Ref<HTMLDivElement>;
}, },
) => React.ReactElement; ) => React.ReactElement;
export { GetRowKey, ExpandableConfig }; export { ExpandableConfig, GetRowKey };
export type Key = React.Key; export type Key = React.Key;
@ -82,7 +83,7 @@ export type ColumnTitle<RecordType> =
export type FilterValue = (Key | boolean)[]; export type FilterValue = (Key | boolean)[];
export type FilterKey = Key[] | null; export type FilterKey = Key[] | null;
export type FilterSearchType<RecordType = Record<string, any>> = export type FilterSearchType<RecordType = AnyObject> =
| boolean | boolean
| ((input: string, record: RecordType) => boolean); | ((input: string, record: RecordType) => boolean);
export interface FilterConfirmProps { export interface FilterConfirmProps {