import Tooltip from '../tooltip'; import abstractTooltipProps from '../tooltip/abstractTooltipProps'; import PropTypes from '../_util/vue-types'; import { getOptionProps, getComponentFromProp } from '../_util/props-util'; import Base from '../base'; const props = abstractTooltipProps(); const Popover = { name: 'APopover', props: { ...props, prefixCls: PropTypes.string.def('ant-popover'), transitionName: PropTypes.string.def('zoom-big'), content: PropTypes.any, title: PropTypes.any, }, model: { prop: 'visible', event: 'visibleChange', }, methods: { getPopupDomNode() { return this.$refs.tooltip.getPopupDomNode(); }, }, render() { const { title, prefixCls, $slots } = this; const props = getOptionProps(this); delete props.title; delete props.content; const tooltipProps = { props: { ...props, }, ref: 'tooltip', on: this.$listeners, }; return ( {this.$slots.default} ); }, }; /* istanbul ignore next */ Popover.install = function(Vue) { Vue.use(Base); Vue.component(Popover.name, Popover); }; export default Popover;