ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
179 lines (178 loc) • 6.32 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
exports.getUuid = getUuid;
var _vue = require("vue");
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _Notice = _interopRequireDefault(require("./Notice"));
var _transition = require("../_util/transition");
var _classNames = _interopRequireDefault(require("../_util/classNames"));
var _Portal = _interopRequireDefault(require("../_util/Portal"));
let seed = 0;
const now = Date.now();
function getUuid() {
const id = seed;
seed += 1;
return `rcNotification_${now}_${id}`;
}
const Notification = (0, _vue.defineComponent)({
name: 'HookNotification',
inheritAttrs: false,
props: ['prefixCls', 'transitionName', 'animation', 'maxCount', 'closeIcon', 'hashId', 'remove', 'notices', 'getStyles', 'getClassName', 'onAllRemoved', 'getContainer'],
setup(props, _ref) {
let {
attrs,
slots
} = _ref;
const hookRefs = new Map();
const notices = (0, _vue.computed)(() => props.notices);
const transitionProps = (0, _vue.computed)(() => {
let name = props.transitionName;
if (!name && props.animation) {
switch (typeof props.animation) {
case 'string':
name = props.animation;
break;
case 'function':
name = props.animation().name;
break;
case 'object':
name = props.animation.name;
break;
default:
name = `${props.prefixCls}-fade`;
break;
}
}
return (0, _transition.getTransitionGroupProps)(name);
});
const remove = key => props.remove(key);
const placements = (0, _vue.ref)({});
(0, _vue.watch)(notices, () => {
const nextPlacements = {};
// init placements with animation
Object.keys(placements.value).forEach(placement => {
nextPlacements[placement] = [];
});
props.notices.forEach(config => {
const {
placement = 'topRight'
} = config.notice;
if (placement) {
nextPlacements[placement] = nextPlacements[placement] || [];
nextPlacements[placement].push(config);
}
});
placements.value = nextPlacements;
});
const placementList = (0, _vue.computed)(() => Object.keys(placements.value));
return () => {
var _a;
const {
prefixCls,
closeIcon = (_a = slots.closeIcon) === null || _a === void 0 ? void 0 : _a.call(slots, {
prefixCls
})
} = props;
const noticeNodes = placementList.value.map(placement => {
var _a, _b;
const noticesForPlacement = placements.value[placement];
const classes = (_a = props.getClassName) === null || _a === void 0 ? void 0 : _a.call(props, placement);
const styles = (_b = props.getStyles) === null || _b === void 0 ? void 0 : _b.call(props, placement);
const noticeNodesForPlacement = noticesForPlacement.map((_ref2, index) => {
let {
notice,
holderCallback
} = _ref2;
const updateMark = index === notices.value.length - 1 ? notice.updateMark : undefined;
const {
key,
userPassKey
} = notice;
const {
content
} = notice;
const noticeProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({
prefixCls,
closeIcon: typeof closeIcon === 'function' ? closeIcon({
prefixCls
}) : closeIcon
}, notice), notice.props), {
key,
noticeKey: userPassKey || key,
updateMark,
onClose: noticeKey => {
var _a;
remove(noticeKey);
(_a = notice.onClose) === null || _a === void 0 ? void 0 : _a.call(notice);
},
onClick: notice.onClick
});
if (holderCallback) {
return (0, _vue.createVNode)("div", {
"key": key,
"class": `${prefixCls}-hook-holder`,
"ref": div => {
if (typeof key === 'undefined') {
return;
}
if (div) {
hookRefs.set(key, div);
holderCallback(div, noticeProps);
} else {
hookRefs.delete(key);
}
}
}, null);
}
return (0, _vue.createVNode)(_Notice.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, noticeProps), {}, {
"class": (0, _classNames.default)(noticeProps.class, props.hashId)
}), {
default: () => [typeof content === 'function' ? content({
prefixCls
}) : content]
});
});
const className = {
[prefixCls]: 1,
[`${prefixCls}-${placement}`]: 1,
[attrs.class]: !!attrs.class,
[props.hashId]: true,
[classes]: !!classes
};
function onAfterLeave() {
var _a;
if (noticesForPlacement.length > 0) {
return;
}
Reflect.deleteProperty(placements.value, placement);
(_a = props.onAllRemoved) === null || _a === void 0 ? void 0 : _a.call(props);
}
return (0, _vue.createVNode)("div", {
"key": placement,
"class": className,
"style": attrs.style || styles || {
top: '65px',
left: '50%'
}
}, [(0, _vue.createVNode)(_vue.TransitionGroup, (0, _objectSpread2.default)((0, _objectSpread2.default)({
"tag": "div"
}, transitionProps.value), {}, {
"onAfterLeave": onAfterLeave
}), {
default: () => [noticeNodesForPlacement]
})]);
});
return (0, _vue.createVNode)(_Portal.default, {
"getContainer": props.getContainer
}, {
default: () => [noticeNodes]
});
};
}
});
var _default = exports.default = Notification;
;