import * as React from 'react'; import Input, { InputProps } from './Input'; import { SizeType } from '../config-provider/SizeContext'; import { ConfigConsumerProps } from '../config-provider'; export interface SearchProps extends InputProps { inputPrefixCls?: string; onSearch?: (value: string, event?: React.ChangeEvent | React.MouseEvent | React.KeyboardEvent) => void; enterButton?: React.ReactNode; loading?: boolean; } export default class Search extends React.Component { static defaultProps: { enterButton: boolean; }; private input; saveInput: (node: Input) => void; onChange: (e: React.ChangeEvent) => void; onMouseDown: React.MouseEventHandler; onSearch: (e: React.MouseEvent | React.KeyboardEvent) => void; focus(): void; blur(): void; renderLoading: (prefixCls: string) => JSX.Element; renderSuffix: (prefixCls: string) => {} | null | undefined; renderAddonAfter: (prefixCls: string, size: SizeType) => {} | null | undefined; renderSearch: ({ getPrefixCls, direction }: ConfigConsumerProps) => JSX.Element; render(): JSX.Element; }