| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _vcDropdown = _interopRequireDefault(require("../vc-dropdown"));
- var _dropdownButton = _interopRequireDefault(require("./dropdown-button"));
- var _vnode = require("../_util/vnode");
- var _classNames = _interopRequireDefault(require("../_util/classNames"));
- var _propsUtil = require("../_util/props-util");
- var _props = require("./props");
- var _RightOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/RightOutlined"));
- var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
- var _devWarning = _interopRequireDefault(require("../vc-util/devWarning"));
- var _omit = _interopRequireDefault(require("../_util/omit"));
- var _placements = _interopRequireDefault(require("../_util/placements"));
- var _warning = _interopRequireDefault(require("../_util/warning"));
- var _style = _interopRequireDefault(require("./style"));
- var _OverrideContext = require("../menu/src/OverrideContext");
- const Dropdown = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'ADropdown',
- inheritAttrs: false,
- props: (0, _propsUtil.initDefaultProps)((0, _props.dropdownProps)(), {
- mouseEnterDelay: 0.15,
- mouseLeaveDelay: 0.1,
- placement: 'bottomLeft',
- trigger: 'hover'
- }),
- // emits: ['visibleChange', 'update:visible'],
- slots: Object,
- setup(props, _ref) {
- let {
- slots,
- attrs,
- emit
- } = _ref;
- const {
- prefixCls,
- rootPrefixCls,
- direction,
- getPopupContainer
- } = (0, _useConfigInject.default)('dropdown', props);
- const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
- // Warning for deprecated usage
- if (process.env.NODE_ENV !== 'production') {
- [['visible', 'open'], ['onVisibleChange', 'onOpenChange'], ['onUpdate:visible', 'onUpdate:open']].forEach(_ref2 => {
- let [deprecatedName, newName] = _ref2;
- (0, _warning.default)(props[deprecatedName] === undefined, 'Dropdown', `\`${deprecatedName}\` is deprecated which will be removed in next major version, please use \`${newName}\` instead.`);
- });
- }
- const transitionName = (0, _vue.computed)(() => {
- const {
- placement = '',
- transitionName
- } = props;
- if (transitionName !== undefined) {
- return transitionName;
- }
- if (placement.includes('top')) {
- return `${rootPrefixCls.value}-slide-down`;
- }
- return `${rootPrefixCls.value}-slide-up`;
- });
- (0, _OverrideContext.useProvideOverride)({
- prefixCls: (0, _vue.computed)(() => `${prefixCls.value}-menu`),
- expandIcon: (0, _vue.computed)(() => {
- return (0, _vue.createVNode)("span", {
- "class": `${prefixCls.value}-menu-submenu-arrow`
- }, [(0, _vue.createVNode)(_RightOutlined.default, {
- "class": `${prefixCls.value}-menu-submenu-arrow-icon`
- }, null)]);
- }),
- mode: (0, _vue.computed)(() => 'vertical'),
- selectable: (0, _vue.computed)(() => false),
- onClick: () => {},
- validator: _ref3 => {
- let {
- mode
- } = _ref3;
- // Warning if use other mode
- (0, _warning.default)(!mode || mode === 'vertical', 'Dropdown', `mode="${mode}" is not supported for Dropdown's Menu.`);
- }
- });
- const renderOverlay = () => {
- var _a, _b, _c;
- // rc-dropdown already can process the function of overlay, but we have check logic here.
- // So we need render the element to check and pass back to rc-dropdown.
- const overlay = props.overlay || ((_a = slots.overlay) === null || _a === void 0 ? void 0 : _a.call(slots));
- const overlayNode = Array.isArray(overlay) ? overlay[0] : overlay;
- if (!overlayNode) return null;
- const overlayProps = overlayNode.props || {};
- // Warning if use other mode
- (0, _devWarning.default)(!overlayProps.mode || overlayProps.mode === 'vertical', 'Dropdown', `mode="${overlayProps.mode}" is not supported for Dropdown's Menu.`);
- // menu cannot be selectable in dropdown defaultly
- const {
- selectable = false,
- expandIcon = (_c = (_b = overlayNode.children) === null || _b === void 0 ? void 0 : _b.expandIcon) === null || _c === void 0 ? void 0 : _c.call(_b)
- } = overlayProps;
- const overlayNodeExpandIcon = typeof expandIcon !== 'undefined' && (0, _propsUtil.isValidElement)(expandIcon) ? expandIcon : (0, _vue.createVNode)("span", {
- "class": `${prefixCls.value}-menu-submenu-arrow`
- }, [(0, _vue.createVNode)(_RightOutlined.default, {
- "class": `${prefixCls.value}-menu-submenu-arrow-icon`
- }, null)]);
- const fixedModeOverlay = (0, _propsUtil.isValidElement)(overlayNode) ? (0, _vnode.cloneElement)(overlayNode, {
- mode: 'vertical',
- selectable,
- expandIcon: () => overlayNodeExpandIcon
- }) : overlayNode;
- return fixedModeOverlay;
- };
- const placement = (0, _vue.computed)(() => {
- const placement = props.placement;
- if (!placement) {
- return direction.value === 'rtl' ? 'bottomRight' : 'bottomLeft';
- }
- if (placement.includes('Center')) {
- const newPlacement = placement.slice(0, placement.indexOf('Center'));
- (0, _devWarning.default)(!placement.includes('Center'), 'Dropdown', `You are using '${placement}' placement in Dropdown, which is deprecated. Try to use '${newPlacement}' instead.`);
- return newPlacement;
- }
- return placement;
- });
- const mergedVisible = (0, _vue.computed)(() => {
- return typeof props.visible === 'boolean' ? props.visible : props.open;
- });
- const handleVisibleChange = val => {
- emit('update:visible', val);
- emit('visibleChange', val);
- emit('update:open', val);
- emit('openChange', val);
- };
- return () => {
- var _a, _b;
- const {
- arrow,
- trigger,
- disabled,
- overlayClassName
- } = props;
- const child = (_a = slots.default) === null || _a === void 0 ? void 0 : _a.call(slots)[0];
- const dropdownTrigger = (0, _vnode.cloneElement)(child, (0, _extends2.default)({
- class: (0, _classNames.default)((_b = child === null || child === void 0 ? void 0 : child.props) === null || _b === void 0 ? void 0 : _b.class, {
- [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
- }, `${prefixCls.value}-trigger`)
- }, disabled ? {
- disabled
- } : {}));
- const overlayClassNameCustomized = (0, _classNames.default)(overlayClassName, hashId.value, {
- [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
- });
- const triggerActions = disabled ? [] : trigger;
- let alignPoint;
- if (triggerActions && triggerActions.includes('contextmenu')) {
- alignPoint = true;
- }
- const builtinPlacements = (0, _placements.default)({
- arrowPointAtCenter: typeof arrow === 'object' && arrow.pointAtCenter,
- autoAdjustOverflow: true
- });
- const dropdownProps = (0, _omit.default)((0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, props), attrs), {
- visible: mergedVisible.value,
- builtinPlacements,
- overlayClassName: overlayClassNameCustomized,
- arrow: !!arrow,
- alignPoint,
- prefixCls: prefixCls.value,
- getPopupContainer: getPopupContainer === null || getPopupContainer === void 0 ? void 0 : getPopupContainer.value,
- transitionName: transitionName.value,
- trigger: triggerActions,
- onVisibleChange: handleVisibleChange,
- placement: placement.value
- }), ['overlay', 'onUpdate:visible']);
- return wrapSSR((0, _vue.createVNode)(_vcDropdown.default, dropdownProps, {
- default: () => [dropdownTrigger],
- overlay: renderOverlay
- }));
- };
- }
- });
- Dropdown.Button = _dropdownButton.default;
- var _default = exports.default = Dropdown;
|