MotionTreeNode.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. 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 _TreeNode = _interopRequireDefault(require("./TreeNode"));
  11. var _contextTypes = require("./contextTypes");
  12. var _props = require("./props");
  13. var _collapseMotion = _interopRequireDefault(require("../_util/collapseMotion"));
  14. var __rest = void 0 && (void 0).__rest || function (s, e) {
  15. var t = {};
  16. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  17. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  18. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  19. }
  20. return t;
  21. };
  22. var _default = exports.default = (0, _vue.defineComponent)({
  23. compatConfig: {
  24. MODE: 3
  25. },
  26. name: 'MotionTreeNode',
  27. inheritAttrs: false,
  28. props: (0, _extends2.default)((0, _extends2.default)({}, _props.treeNodeProps), {
  29. active: Boolean,
  30. motion: Object,
  31. motionNodes: {
  32. type: Array
  33. },
  34. onMotionStart: Function,
  35. onMotionEnd: Function,
  36. motionType: String
  37. }),
  38. setup(props, _ref) {
  39. let {
  40. attrs,
  41. slots
  42. } = _ref;
  43. const visible = (0, _vue.shallowRef)(true);
  44. const context = (0, _contextTypes.useInjectTreeContext)();
  45. const motionedRef = (0, _vue.shallowRef)(false);
  46. const transitionProps = (0, _vue.computed)(() => {
  47. if (props.motion) {
  48. return props.motion;
  49. } else {
  50. return (0, _collapseMotion.default)();
  51. }
  52. });
  53. const onMotionEnd = (node, type) => {
  54. var _a, _b, _c, _d;
  55. if (type === 'appear') {
  56. (_b = (_a = transitionProps.value) === null || _a === void 0 ? void 0 : _a.onAfterEnter) === null || _b === void 0 ? void 0 : _b.call(_a, node);
  57. } else if (type === 'leave') {
  58. (_d = (_c = transitionProps.value) === null || _c === void 0 ? void 0 : _c.onAfterLeave) === null || _d === void 0 ? void 0 : _d.call(_c, node);
  59. }
  60. if (!motionedRef.value) {
  61. props.onMotionEnd();
  62. }
  63. motionedRef.value = true;
  64. };
  65. (0, _vue.watch)(() => props.motionNodes, () => {
  66. if (props.motionNodes && props.motionType === 'hide' && visible.value) {
  67. (0, _vue.nextTick)(() => {
  68. visible.value = false;
  69. });
  70. }
  71. }, {
  72. immediate: true,
  73. flush: 'post'
  74. });
  75. (0, _vue.onMounted)(() => {
  76. props.motionNodes && props.onMotionStart();
  77. });
  78. (0, _vue.onBeforeUnmount)(() => {
  79. props.motionNodes && onMotionEnd();
  80. });
  81. return () => {
  82. const {
  83. motion,
  84. motionNodes,
  85. motionType,
  86. active,
  87. eventKey
  88. } = props,
  89. otherProps = __rest(props, ["motion", "motionNodes", "motionType", "active", "eventKey"]);
  90. if (motionNodes) {
  91. return (0, _vue.createVNode)(_vue.Transition, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, transitionProps.value), {}, {
  92. "appear": motionType === 'show',
  93. "onAfterAppear": node => onMotionEnd(node, 'appear'),
  94. "onAfterLeave": node => onMotionEnd(node, 'leave')
  95. }), {
  96. default: () => [(0, _vue.withDirectives)((0, _vue.createVNode)("div", {
  97. "class": `${context.value.prefixCls}-treenode-motion`
  98. }, [motionNodes.map(treeNode => {
  99. const restProps = __rest(treeNode.data, []),
  100. {
  101. title,
  102. key,
  103. isStart,
  104. isEnd
  105. } = treeNode;
  106. delete restProps.children;
  107. return (0, _vue.createVNode)(_TreeNode.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, restProps), {}, {
  108. "title": title,
  109. "active": active,
  110. "data": treeNode.data,
  111. "key": key,
  112. "eventKey": key,
  113. "isStart": isStart,
  114. "isEnd": isEnd
  115. }), slots);
  116. })]), [[_vue.vShow, visible.value]])]
  117. });
  118. }
  119. return (0, _vue.createVNode)(_TreeNode.default, (0, _objectSpread2.default)((0, _objectSpread2.default)({
  120. "class": attrs.class,
  121. "style": attrs.style
  122. }, otherProps), {}, {
  123. "active": active,
  124. "eventKey": eventKey
  125. }), slots);
  126. };
  127. }
  128. });