wetrade-design
Version:
一款多语言支持Vue3的UI框架
121 lines (120 loc) • 5.02 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _vue = require("vue");
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _vcTrigger = _interopRequireDefault(require("../../vc-trigger"));
var _useMenuContext = require("./hooks/useMenuContext");
var _placements = require("./placements");
var _raf = _interopRequireDefault(require("../../_util/raf"));
var _classNames2 = _interopRequireDefault(require("../../_util/classNames"));
var _transition = require("../../_util/transition");
var popupPlacementMap = {
horizontal: 'bottomLeft',
vertical: 'rightTop',
'vertical-left': 'rightTop',
'vertical-right': 'leftTop'
};
var _default = (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: 'PopupTrigger',
inheritAttrs: false,
props: {
prefixCls: String,
mode: String,
visible: Boolean,
// popup: React.ReactNode;
popupClassName: String,
popupOffset: Array,
disabled: Boolean,
onVisibleChange: Function
},
slots: ['popup'],
emits: ['visibleChange'],
setup: function setup(props, _ref) {
var slots = _ref.slots,
emit = _ref.emit;
var innerVisible = (0, _vue.ref)(false);
var _useInjectMenu = (0, _useMenuContext.useInjectMenu)(),
getPopupContainer = _useInjectMenu.getPopupContainer,
rtl = _useInjectMenu.rtl,
subMenuOpenDelay = _useInjectMenu.subMenuOpenDelay,
subMenuCloseDelay = _useInjectMenu.subMenuCloseDelay,
builtinPlacements = _useInjectMenu.builtinPlacements,
triggerSubMenuAction = _useInjectMenu.triggerSubMenuAction,
isRootMenu = _useInjectMenu.isRootMenu,
forceSubMenuRender = _useInjectMenu.forceSubMenuRender,
motion = _useInjectMenu.motion,
defaultMotions = _useInjectMenu.defaultMotions;
var forceRender = (0, _useMenuContext.useInjectForceRender)();
var placement = (0, _vue.computed)(function () {
return rtl.value ? (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _placements.placementsRtl), builtinPlacements.value) : (0, _objectSpread2.default)((0, _objectSpread2.default)({}, _placements.placements), builtinPlacements.value);
});
var popupPlacement = (0, _vue.computed)(function () {
return popupPlacementMap[props.mode];
});
var visibleRef = (0, _vue.ref)();
(0, _vue.watch)(function () {
return props.visible;
}, function (visible) {
_raf.default.cancel(visibleRef.value);
visibleRef.value = (0, _raf.default)(function () {
innerVisible.value = visible;
});
}, {
immediate: true
});
(0, _vue.onBeforeUnmount)(function () {
_raf.default.cancel(visibleRef.value);
});
var onVisibleChange = function onVisibleChange(visible) {
emit('visibleChange', visible);
};
var mergedMotion = (0, _vue.computed)(function () {
var _defaultMotions$value, _defaultMotions$value2;
var m = motion.value || ((_defaultMotions$value = defaultMotions.value) === null || _defaultMotions$value === void 0 ? void 0 : _defaultMotions$value[props.mode]) || ((_defaultMotions$value2 = defaultMotions.value) === null || _defaultMotions$value2 === void 0 ? void 0 : _defaultMotions$value2.other);
var res = typeof m === 'function' ? m() : m;
return res ? (0, _transition.getTransitionProps)(res.name, {
css: true
}) : undefined;
});
return function () {
var prefixCls = props.prefixCls,
popupClassName = props.popupClassName,
mode = props.mode,
popupOffset = props.popupOffset,
disabled = props.disabled;
return (0, _vue.createVNode)(_vcTrigger.default, {
"prefixCls": prefixCls,
"popupClassName": (0, _classNames2.default)("".concat(prefixCls, "-popup"), (0, _defineProperty2.default)({}, "".concat(prefixCls, "-rtl"), rtl.value), popupClassName),
"stretch": mode === 'horizontal' ? 'minWidth' : null,
"getPopupContainer": isRootMenu.value ? getPopupContainer.value : function (triggerNode) {
return triggerNode.parentNode;
},
"builtinPlacements": placement.value,
"popupPlacement": popupPlacement.value,
"popupVisible": innerVisible.value,
"popupAlign": popupOffset && {
offset: popupOffset
},
"action": disabled ? [] : [triggerSubMenuAction.value],
"mouseEnterDelay": subMenuOpenDelay.value,
"mouseLeaveDelay": subMenuCloseDelay.value,
"onPopupVisibleChange": onVisibleChange,
"forceRender": forceRender || forceSubMenuRender.value,
"popupAnimation": mergedMotion.value,
"enterable": true
}, {
popup: slots.popup,
default: slots.default
});
};
}
});
exports.default = _default;