import React from 'react'; import PropTypes from 'prop-types'; import Input from '../input'; import type { NumberPickerProps, NumberPickerState } from './types'; /** NumberPicker */ declare class NumberPicker extends React.Component { static propTypes: { prefix: PropTypes.Requireable; type: PropTypes.Requireable; size: PropTypes.Requireable; value: PropTypes.Requireable>; defaultValue: PropTypes.Requireable>; disabled: PropTypes.Requireable; step: PropTypes.Requireable>; precision: PropTypes.Requireable; editable: PropTypes.Requireable; autoFocus: PropTypes.Requireable; onChange: PropTypes.Requireable<(...args: any[]) => any>; onKeyDown: PropTypes.Requireable<(...args: any[]) => any>; onFocus: PropTypes.Requireable<(...args: any[]) => any>; onBlur: PropTypes.Requireable<(...args: any[]) => any>; onCorrect: PropTypes.Requireable<(...args: any[]) => any>; onDisabled: PropTypes.Requireable<(...args: any[]) => any>; max: PropTypes.Requireable>; min: PropTypes.Requireable>; className: PropTypes.Requireable; style: PropTypes.Requireable; state: PropTypes.Requireable; format: PropTypes.Requireable<(...args: any[]) => any>; upBtnProps: PropTypes.Requireable; downBtnProps: PropTypes.Requireable; label: PropTypes.Requireable; innerAfter: PropTypes.Requireable; rtl: PropTypes.Requireable; isPreview: PropTypes.Requireable; renderPreview: PropTypes.Requireable<(...args: any[]) => any>; device: PropTypes.Requireable; hasTrigger: PropTypes.Requireable; alwaysShowTrigger: PropTypes.Requireable; stringMode: PropTypes.Requireable; }; static defaultProps: { prefix: string; type: string; size: string; step: number; style: {}; precision: number; editable: boolean; onChange: () => void; onKeyDown: () => void; onBlur: () => void; onCorrect: () => void; onDisabled: () => void; hasTrigger: boolean; alwaysShowTrigger: boolean; stringMode: boolean; }; static displayName: string; inputRef: React.ComponentRef | null; constructor(props: NumberPickerProps); static getDerivedStateFromProps(nextProps: NumberPickerProps, prevState: NumberPickerState): Partial | null; isGreaterThan(v1: string | number, v2: string | number): boolean; correctBoundary(value: string | number): string | number; setFocus(status: boolean): void; onFocus: NumberPickerProps['onFocus']; onBlur: NumberPickerProps['onBlur']; withinMinMax(value: number | string): boolean; withinMin(value: number | string): boolean; setDisplayValue({ displayValue, onlyDisplay, }: { displayValue: string | number; onlyDisplay?: boolean; }): void; getDisplayValue(): string | number; /** * 输入时判断是否要触发onChange * 正常触发: 合法数字 (eg: -0 -0. 0.1);超出最大值 * 不触发: 1. 非数字(eg: - ), 2. 小于最小值(输入需要过程由小变大) */ shouldFireOnChange(value: string): boolean; onChange(value: string, e: React.ChangeEvent | React.CompositionEvent | React.KeyboardEvent): void; correctValue(value: string): string | number; setValue({ value, e, triggerType, }: { value: string | number; e: React.ChangeEvent | React.CompositionEvent | React.KeyboardEvent; triggerType?: 'up' | 'down'; }): void; getPrecision(): number; getPrecisionFactor(): number; onKeyDown: NumberPickerProps['onKeyDown']; up(disabled: boolean, e: React.KeyboardEvent): void; down(disabled: boolean, e: React.KeyboardEvent): void; step(type: 'up' | 'down', disabled: boolean, e: React.KeyboardEvent): void; upStep(val: number | string): string | number; downStep(val: number | string): string | number; /** * fix bug in chrome browser * 0.28 + 0.01 = 0.29000000000000004 * 0.29 - 0.01 = 0.27999999999999997 * @param value - The numeric value to be corrected */ hackChrome(value: number): number; focus(): void; saveInputRef(ref: React.ComponentRef | null): void; getInputNode(): (import("../config-provider/types").ConfiguredComponent> & Pick, "focus" | "getInputNode">) | null; handleMouseDown(e: React.MouseEvent): void; render(): React.JSX.Element; } declare const _default: typeof NumberPicker; export default _default;