index.js 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.popoverProps = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _tooltip = _interopRequireDefault(require("../tooltip"));
  11. var _abstractTooltipProps = _interopRequireDefault(require("../tooltip/abstractTooltipProps"));
  12. var _propsUtil = require("../_util/props-util");
  13. var _type = require("../_util/type");
  14. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  15. var _omit = _interopRequireDefault(require("../_util/omit"));
  16. var _transition = require("../_util/transition");
  17. var _Tooltip = require("../tooltip/Tooltip");
  18. var _style = _interopRequireDefault(require("./style"));
  19. var _classNames = _interopRequireDefault(require("../_util/classNames"));
  20. var _warning = _interopRequireDefault(require("../_util/warning"));
  21. const popoverProps = () => (0, _extends2.default)((0, _extends2.default)({}, (0, _abstractTooltipProps.default)()), {
  22. content: (0, _type.anyType)(),
  23. title: (0, _type.anyType)()
  24. });
  25. exports.popoverProps = popoverProps;
  26. const Popover = (0, _vue.defineComponent)({
  27. compatConfig: {
  28. MODE: 3
  29. },
  30. name: 'APopover',
  31. inheritAttrs: false,
  32. props: (0, _propsUtil.initDefaultProps)(popoverProps(), (0, _extends2.default)((0, _extends2.default)({}, (0, _Tooltip.tooltipDefaultProps)()), {
  33. trigger: 'hover',
  34. placement: 'top',
  35. mouseEnterDelay: 0.1,
  36. mouseLeaveDelay: 0.1
  37. })),
  38. setup(props, _ref) {
  39. let {
  40. expose,
  41. slots,
  42. attrs
  43. } = _ref;
  44. const tooltipRef = (0, _vue.ref)();
  45. (0, _warning.default)(props.visible === undefined, 'popover', `\`visible\` will be removed in next major version, please use \`open\` instead.`);
  46. expose({
  47. getPopupDomNode: () => {
  48. var _a, _b;
  49. return (_b = (_a = tooltipRef.value) === null || _a === void 0 ? void 0 : _a.getPopupDomNode) === null || _b === void 0 ? void 0 : _b.call(_a);
  50. }
  51. });
  52. const {
  53. prefixCls,
  54. configProvider
  55. } = (0, _useConfigInject.default)('popover', props);
  56. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  57. const rootPrefixCls = (0, _vue.computed)(() => configProvider.getPrefixCls());
  58. const getOverlay = () => {
  59. var _a, _b;
  60. const {
  61. title = (0, _propsUtil.filterEmpty)((_a = slots.title) === null || _a === void 0 ? void 0 : _a.call(slots)),
  62. content = (0, _propsUtil.filterEmpty)((_b = slots.content) === null || _b === void 0 ? void 0 : _b.call(slots))
  63. } = props;
  64. const hasTitle = !!(Array.isArray(title) ? title.length : title);
  65. const hasContent = !!(Array.isArray(content) ? content.length : title);
  66. if (!hasTitle && !hasContent) return null;
  67. return (0, _vue.createVNode)(_vue.Fragment, null, [hasTitle && (0, _vue.createVNode)("div", {
  68. "class": `${prefixCls.value}-title`
  69. }, [title]), (0, _vue.createVNode)("div", {
  70. "class": `${prefixCls.value}-inner-content`
  71. }, [content])]);
  72. };
  73. return () => {
  74. const overlayCls = (0, _classNames.default)(props.overlayClassName, hashId.value);
  75. return wrapSSR((0, _vue.createVNode)(_tooltip.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _omit.default)(props, ['title', 'content'])), attrs), {}, {
  76. "prefixCls": prefixCls.value,
  77. "ref": tooltipRef,
  78. "overlayClassName": overlayCls,
  79. "transitionName": (0, _transition.getTransitionName)(rootPrefixCls.value, 'zoom-big', props.transitionName),
  80. "data-popover-inject": true
  81. }), {
  82. title: getOverlay,
  83. default: slots.default
  84. }));
  85. };
  86. }
  87. });
  88. var _default = exports.default = (0, _type.withInstall)(Popover);