import PropTypes from '../_util/vue-types'; import { initDefaultProps, getOptionProps, getComponentFromProp } from '../_util/props-util'; import VcRate from '../vc-rate'; import Icon from '../icon'; export const RateProps = { prefixCls: PropTypes.string, count: PropTypes.number, value: PropTypes.value, defaultValue: PropTypes.value, allowHalf: PropTypes.bool, allowClear: PropTypes.bool, disabled: PropTypes.bool, character: PropTypes.any, autoFocus: PropTypes.bool, }; const Rate = { name: 'ARate', model: { prop: 'value', event: 'change', }, props: initDefaultProps(RateProps, { prefixCls: 'ant-rate', }), methods: { focus() { this.$refs.refRate.focus(); }, blur() { this.$refs.refRate.blur(); }, }, render() { const character = getComponentFromProp(this, 'character') || ( ); const rateProps = { props: { character, ...getOptionProps(this), }, on: this.$listeners, ref: 'refRate', }; return ; }, }; /* istanbul ignore next */ Rate.install = function(Vue) { Vue.component(Rate.name, Rate); }; export default Rate;