import * as React from 'react'; import RcRate from 'rc-rate'; import omit from 'omit.js'; import { StarFilled } from '@ant-design/icons'; import Tooltip from '../tooltip'; import { ConfigConsumer, ConfigConsumerProps } from '../config-provider'; export interface RateProps { prefixCls?: string; count?: number; value?: number; defaultValue?: number; allowHalf?: boolean; allowClear?: boolean; disabled?: boolean; tooltips?: Array; onChange?: (value: number) => void; onHoverChange?: (value: number) => void; character?: React.ReactNode; className?: string; style?: React.CSSProperties; } interface RateNodeProps { index: number; } export default class Rate extends React.Component { static defaultProps = { character: , }; private rcRate: any; saveRate = (node: any) => { this.rcRate = node; }; characterRender = (node: React.ReactNode, { index }: RateNodeProps) => { const { tooltips } = this.props; if (!tooltips) return node; return {node}; }; focus() { this.rcRate.focus(); } blur() { this.rcRate.blur(); } renderRate = ({ getPrefixCls }: ConfigConsumerProps) => { const { prefixCls, ...restProps } = this.props; const rateProps = omit(restProps, ['tooltips']); return ( ); }; render() { return {this.renderRate}; } }