mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-10 05:58:39 +08:00
59d38ecea6
* fix: radioButton ref * fix: added radio types test
64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
import type * as React from 'react';
|
|
import type { AbstractCheckboxProps } from '../checkbox/Checkbox';
|
|
import type { AbstractCheckboxGroupProps } from '../checkbox/Group';
|
|
import type { DisabledType } from '../config-provider/DisabledContext';
|
|
import type { SizeType } from '../config-provider/SizeContext';
|
|
|
|
export type { CheckboxRef as RadioRef } from 'rc-checkbox';
|
|
export type RadioGroupButtonStyle = 'outline' | 'solid';
|
|
export type RadioGroupOptionType = 'default' | 'button';
|
|
|
|
export interface RadioGroupProps extends AbstractCheckboxGroupProps {
|
|
defaultValue?: any;
|
|
value?: any;
|
|
onChange?: (e: RadioChangeEvent) => void;
|
|
size?: SizeType;
|
|
disabled?: DisabledType;
|
|
onMouseEnter?: React.MouseEventHandler<HTMLDivElement>;
|
|
onMouseLeave?: React.MouseEventHandler<HTMLDivElement>;
|
|
name?: string;
|
|
children?: React.ReactNode;
|
|
id?: string;
|
|
optionType?: RadioGroupOptionType;
|
|
buttonStyle?: RadioGroupButtonStyle;
|
|
onFocus?: React.FocusEventHandler<HTMLDivElement>;
|
|
onBlur?: React.FocusEventHandler<HTMLDivElement>;
|
|
}
|
|
|
|
export interface RadioGroupContextProps {
|
|
onChange: (e: RadioChangeEvent) => void;
|
|
value: any;
|
|
disabled?: boolean;
|
|
name?: string;
|
|
/**
|
|
* Control the appearance for Radio to display as button or not
|
|
*
|
|
* @default 'default'
|
|
* @internal
|
|
*/
|
|
optionType?: RadioGroupOptionType;
|
|
}
|
|
|
|
export interface RadioProps extends AbstractCheckboxProps<RadioChangeEvent> {
|
|
/**
|
|
* Control the appearance for Radio to display as button or not
|
|
*
|
|
* @default 'default'
|
|
* @internal
|
|
*/
|
|
optionType?: RadioGroupOptionType;
|
|
}
|
|
|
|
export interface RadioChangeEventTarget extends RadioProps {
|
|
checked: boolean;
|
|
}
|
|
|
|
export interface RadioChangeEvent {
|
|
target: RadioChangeEventTarget;
|
|
stopPropagation: () => void;
|
|
preventDefault: () => void;
|
|
nativeEvent: MouseEvent;
|
|
}
|
|
|
|
export type RadioOptionTypeContextProps = RadioGroupOptionType;
|