1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _tooltip = require('../tooltip');
var _tooltip2 = _interopRequireDefault(_tooltip);
var _abstractTooltipProps = require('../tooltip/abstractTooltipProps');
var _abstractTooltipProps2 = _interopRequireDefault(_abstractTooltipProps);
var _vueTypes = require('../_util/vue-types');
var _vueTypes2 = _interopRequireDefault(_vueTypes);
var _propsUtil = require('../_util/props-util');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }
var props = (0, _abstractTooltipProps2['default'])();
var Popover = {
name: 'APopover',
props: (0, _extends3['default'])({}, props, {
prefixCls: _vueTypes2['default'].string.def('ant-popover'),
transitionName: _vueTypes2['default'].string.def('zoom-big'),
content: _vueTypes2['default'].any,
title: _vueTypes2['default'].any
}),
model: {
prop: 'visible',
event: 'visibleChange'
},
methods: {
getPopupDomNode: function getPopupDomNode() {
return this.$refs.tooltip.getPopupDomNode();
}
},
render: function render() {
var h = arguments[0];
var title = this.title,
prefixCls = this.prefixCls,
$slots = this.$slots;
var props = (0, _propsUtil.getOptionProps)(this);
delete props.title;
delete props.content;
var tooltipProps = {
props: (0, _extends3['default'])({}, props),
ref: 'tooltip',
on: this.$listeners
};
return h(
_tooltip2['default'],
tooltipProps,
[h(
'template',
{ slot: 'title' },
[h('div', [(title || $slots.title) && h(
'div',
{ 'class': prefixCls + '-title' },
[(0, _propsUtil.getComponentFromProp)(this, 'title')]
), h(
'div',
{ 'class': prefixCls + '-inner-content' },
[(0, _propsUtil.getComponentFromProp)(this, 'content')]
)])]
), this.$slots['default']]
);
}
};
/* istanbul ignore next */
Popover.install = function (Vue) {
Vue.component(Popover.name, Popover);
};
exports['default'] = Popover;