| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _TreeNode = _interopRequireDefault(require("./TreeNode"));
- var _contextTypes = require("./contextTypes");
- var _props = require("./props");
- var _collapseMotion = _interopRequireDefault(require("../_util/collapseMotion"));
- var __rest = void 0 && (void 0).__rest || function (s, e) {
- var t = {};
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
- if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
- }
- return t;
- };
- var _default = exports.default = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'MotionTreeNode',
- inheritAttrs: false,
- props: (0, _extends2.default)((0, _extends2.default)({}, _props.treeNodeProps), {
- active: Boolean,
- motion: Object,
- motionNodes: {
- type: Array
- },
- onMotionStart: Function,
- onMotionEnd: Function,
- motionType: String
- }),
- setup(props, _ref) {
- let {
- attrs,
- slots
- } = _ref;
- const visible = (0, _vue.shallowRef)(true);
- const context = (0, _contextTypes.useInjectTreeContext)();
- const motionedRef = (0, _vue.shallowRef)(false);
- const transitionProps = (0, _vue.computed)(() => {
- if (props.motion) {
- return props.motion;
- } else {
- return (0, _collapseMotion.default)();
- }
- });
- const onMotionEnd = (node, type) => {
- var _a, _b, _c, _d;
- if (type === 'appear') {
- (_b = (_a = transitionProps.value) === null || _a === void 0 ? void 0 : _a.onAfterEnter) === null || _b === void 0 ? void 0 : _b.call(_a, node);
- } else if (type === 'leave') {
- (_d = (_c = transitionProps.value) === null || _c === void 0 ? void 0 : _c.onAfterLeave) === null || _d === void 0 ? void 0 : _d.call(_c, node);
- }
- if (!motionedRef.value) {
- props.onMotionEnd();
- }
- motionedRef.value = true;
- };
- (0, _vue.watch)(() => props.motionNodes, () => {
- if (props.motionNodes && props.motionType === 'hide' && visible.value) {
- (0, _vue.nextTick)(() => {
- visible.value = false;
- });
- }
- }, {
- immediate: true,
- flush: 'post'
- });
- (0, _vue.onMounted)(() => {
- props.motionNodes && props.onMotionStart();
- });
- (0, _vue.onBeforeUnmount)(() => {
- props.motionNodes && onMotionEnd();
- });
- return () => {
- const {
- motion,
- motionNodes,
- motionType,
- active,
- eventKey
- } = props,
- otherProps = __rest(props, ["motion", "motionNodes", "motionType", "active", "eventKey"]);
- if (motionNodes) {
- return (0, _vue.createVNode)(_vue.Transition, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, transitionProps.value), {}, {
- "appear": motionType === 'show',
- "onAfterAppear": node => onMotionEnd(node, 'appear'),
- "onAfterLeave": node => onMotionEnd(node, 'leave')
- }), {
- default: () => [(0, _vue.withDirectives)((0, _vue.createVNode)("div", {
- "class": `${context.value.prefixCls}-treenode-motion`
- }, [motionNodes.map(treeNode => {
- const restProps = __rest(treeNode.data, []),
- {
- title,
- key,
- isStart,
- isEnd
- } = treeNode;
- delete restProps.children;
- return (0, _vue.createVNode)(_TreeNode.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, restProps), {}, {
- "title": title,
- "active": active,
- "data": treeNode.data,
- "key": key,
- "eventKey": key,
- "isStart": isStart,
- "isEnd": isEnd
- }), slots);
- })]), [[_vue.vShow, visible.value]])]
- });
- }
- return (0, _vue.createVNode)(_TreeNode.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({
- "class": attrs.class,
- "style": attrs.style
- }, otherProps), {}, {
- "active": active,
- "eventKey": eventKey
- }), slots);
- };
- }
- });
|