type: React.forwardRef type optimization (#43610)

* type: React.forwardRef type optimization

* fix

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint

* fix lint
This commit is contained in:
lijianan 2023-07-18 12:18:51 +08:00 committed by GitHub
parent 5bf08faeea
commit f438c133ff
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 32 additions and 21 deletions

View File

@ -137,7 +137,7 @@ export interface CascaderRef {
blur: () => void; blur: () => void;
} }
const Cascader = React.forwardRef((props: CascaderProps<any>, ref: React.Ref<CascaderRef>) => { const Cascader = React.forwardRef<CascaderRef, CascaderProps<any>>((props, ref) => {
const { const {
prefixCls: customizePrefixCls, prefixCls: customizePrefixCls,
size: customizeSize, size: customizeSize,

View File

@ -1,4 +1,4 @@
import type { TriggerProps } from '@rc-component/trigger'; import type { TriggerProps, TriggerRef } from '@rc-component/trigger';
import dayjs from 'dayjs'; import dayjs from 'dayjs';
import customParseFormat from 'dayjs/plugin/customParseFormat'; import customParseFormat from 'dayjs/plugin/customParseFormat';
import React from 'react'; import React from 'react';
@ -16,9 +16,9 @@ function triggerProps(): TriggerProps {
} }
jest.mock('@rc-component/trigger', () => { jest.mock('@rc-component/trigger', () => {
const R = jest.requireActual('react'); const R: typeof React = jest.requireActual('react');
const Trigger = jest.requireActual('@rc-component/trigger').default; const Trigger = jest.requireActual('@rc-component/trigger').default;
return R.forwardRef((props: any, ref: any) => { return R.forwardRef<TriggerRef, TriggerProps>((props, ref) => {
(global as any).triggerProps = props; (global as any).triggerProps = props;
return <Trigger {...props} ref={ref} />; return <Trigger {...props} ref={ref} />;
}); });

View File

@ -1,5 +1,6 @@
import type { Dayjs } from 'dayjs'; import type { Dayjs } from 'dayjs';
import * as React from 'react'; import * as React from 'react';
import type { DatePickerProps, RangePickerProps } from '..';
import DatePicker from '..'; import DatePicker from '..';
import type { DatePickRef, RangePickerRef } from '../generatePicker/interface'; import type { DatePickRef, RangePickerRef } from '../generatePicker/interface';
@ -18,7 +19,7 @@ describe('DatePicker.typescript', () => {
// https://github.com/ant-design/ant-design/issues/33417 // https://github.com/ant-design/ant-design/issues/33417
it('DatePicker ref methods with forwardRef', () => { it('DatePicker ref methods with forwardRef', () => {
const MyDatePicker = React.forwardRef((props, ref: DatePickRef<Dayjs>) => ( const MyDatePicker = React.forwardRef((props: DatePickerProps, ref: DatePickRef<Dayjs>) => (
<DatePicker {...props} ref={ref} /> <DatePicker {...props} ref={ref} />
)); ));
const datePicker = ( const datePicker = (
@ -45,9 +46,11 @@ describe('DatePicker.typescript', () => {
}); });
it('RangePicker ref methods with forwardRef', () => { it('RangePicker ref methods with forwardRef', () => {
const MyRangePicker = React.forwardRef((props, ref: RangePickerRef<Dayjs>) => ( const MyRangePicker = React.forwardRef(
<DatePicker.RangePicker {...props} ref={ref} /> (props: RangePickerProps, ref: RangePickerRef<Dayjs>) => (
)); <DatePicker.RangePicker {...props} ref={ref} />
),
);
const datePicker = ( const datePicker = (
<MyRangePicker <MyRangePicker
ref={(picker) => { ref={(picker) => {

View File

@ -1,11 +1,14 @@
import React, { forwardRef } from 'react'; import React, { forwardRef } from 'react';
import type { InputNumberProps } from '..';
import InputNumber from '..'; import InputNumber from '..';
import focusTest from '../../../tests/shared/focusTest'; import focusTest from '../../../tests/shared/focusTest';
import { fireEvent, render } from '../../../tests/utils'; import { fireEvent, render } from '../../../tests/utils';
describe('prefix', () => { describe('prefix', () => {
focusTest( focusTest(
forwardRef((props, ref) => <InputNumber {...props} prefix="A" ref={ref} />), forwardRef<HTMLInputElement, InputNumberProps>((props, ref) => (
<InputNumber {...props} prefix="A" ref={ref} />
)),
{ refFocus: true }, { refFocus: true },
); );
it('should support className when has prefix', () => { it('should support className when has prefix', () => {

View File

@ -6,7 +6,7 @@ import rtlTest from '../../../tests/shared/rtlTest';
import { act, fireEvent, render } from '../../../tests/utils'; import { act, fireEvent, render } from '../../../tests/utils';
import { resetWarned } from '../../_util/warning'; import { resetWarned } from '../../_util/warning';
import ConfigProvider from '../../config-provider'; import ConfigProvider from '../../config-provider';
import type { TooltipProps } from '../../tooltip'; import type { TooltipProps, TooltipRef } from '../../tooltip';
import SliderTooltip from '../SliderTooltip'; import SliderTooltip from '../SliderTooltip';
function tooltipProps(): TooltipProps { function tooltipProps(): TooltipProps {
@ -14,10 +14,10 @@ function tooltipProps(): TooltipProps {
} }
jest.mock('../../tooltip', () => { jest.mock('../../tooltip', () => {
const ReactReal = jest.requireActual('react'); const ReactReal: typeof React = jest.requireActual('react');
const Tooltip = jest.requireActual('../../tooltip'); const Tooltip = jest.requireActual('../../tooltip');
const TooltipComponent = Tooltip.default; const TooltipComponent = Tooltip.default;
return ReactReal.forwardRef((props: TooltipProps, ref: any) => { return ReactReal.forwardRef<TooltipRef, TooltipProps>((props, ref) => {
(global as any).tooltipProps = props; (global as any).tooltipProps = props;
return <TooltipComponent {...props} ref={ref} />; return <TooltipComponent {...props} ref={ref} />;
}); });

View File

@ -44,7 +44,7 @@ export interface ListItemProps {
progress?: UploadListProgressProps; progress?: UploadListProgressProps;
} }
const ListItem = React.forwardRef( const ListItem = React.forwardRef<HTMLDivElement, ListItemProps>(
( (
{ {
prefixCls, prefixCls,
@ -68,8 +68,8 @@ const ListItem = React.forwardRef(
onPreview, onPreview,
onDownload, onDownload,
onClose, onClose,
}: ListItemProps, },
ref: React.Ref<HTMLDivElement>, ref,
) => { ) => {
// Status: which will ignore `removed` status // Status: which will ignore `removed` status
const { status } = file; const { status } = file;
@ -111,8 +111,7 @@ const ListItem = React.forwardRef(
) : ( ) : (
iconNode iconNode
); );
const aClassName = classNames({ const aClassName = classNames(`${prefixCls}-list-item-thumbnail`, {
[`${prefixCls}-list-item-thumbnail`]: true,
[`${prefixCls}-list-item-file`]: isImgUrl && !isImgUrl(file), [`${prefixCls}-list-item-file`]: isImgUrl && !isImgUrl(file),
}); });
icon = ( icon = (

View File

@ -1,9 +1,15 @@
import React from 'react'; import React from 'react';
import type { PortalProps, PortalRef } from 'rc-util/lib/Portal';
import { TriggerMockContext } from '../../../shared/demoTestContext'; import { TriggerMockContext } from '../../../shared/demoTestContext';
let OriginPortal = jest.requireActual('rc-util/lib/Portal'); let OriginPortal = jest.requireActual('rc-util/lib/Portal');
OriginPortal = OriginPortal.default ?? OriginPortal; OriginPortal = OriginPortal.default ?? OriginPortal;
class MockPortal extends React.Component<{ children?: React.ReactNode }> {
interface MockPortalProps {
children?: React.ReactNode
}
class MockPortal extends React.Component<MockPortalProps> {
container: boolean; container: boolean;
static contextType = TriggerMockContext; static contextType = TriggerMockContext;
@ -26,12 +32,12 @@ class MockPortal extends React.Component<{ children?: React.ReactNode }> {
} }
} }
export default React.forwardRef((props: any, ref: any) => { const CustomPortal = React.forwardRef<PortalRef, PortalProps | MockPortalProps>((props, ref) => {
const context = React.useContext(TriggerMockContext); const context = React.useContext(TriggerMockContext);
if (context?.mock === false) { if (context?.mock === false) {
return <OriginPortal {...props} ref={ref} />; return <OriginPortal {...props} ref={ref} />;
} }
return <MockPortal {...props} />; return <MockPortal {...props} />;
}); });
export default CustomPortal;