Timeline.js 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  2. import { createVNode as _createVNode } from "vue";
  3. import { cloneVNode, defineComponent } from 'vue';
  4. import classNames from '../_util/classNames';
  5. import PropTypes from '../_util/vue-types';
  6. import { filterEmpty } from '../_util/props-util';
  7. import initDefaultProps from '../_util/props-util/initDefaultProps';
  8. import TimelineItem from './TimelineItem';
  9. import LoadingOutlined from "@ant-design/icons-vue/es/icons/LoadingOutlined";
  10. import { tuple, booleanType } from '../_util/type';
  11. import useConfigInject from '../config-provider/hooks/useConfigInject';
  12. // CSSINJS
  13. import useStyle from './style';
  14. export const timelineProps = () => ({
  15. prefixCls: String,
  16. /** 指定最后一个幽灵节点是否存在或内容 */
  17. pending: PropTypes.any,
  18. pendingDot: PropTypes.any,
  19. reverse: booleanType(),
  20. mode: PropTypes.oneOf(tuple('left', 'alternate', 'right', ''))
  21. });
  22. export default defineComponent({
  23. compatConfig: {
  24. MODE: 3
  25. },
  26. name: 'ATimeline',
  27. inheritAttrs: false,
  28. props: initDefaultProps(timelineProps(), {
  29. reverse: false,
  30. mode: ''
  31. }),
  32. slots: Object,
  33. setup(props, _ref) {
  34. let {
  35. slots,
  36. attrs
  37. } = _ref;
  38. const {
  39. prefixCls,
  40. direction
  41. } = useConfigInject('timeline', props);
  42. // style
  43. const [wrapSSR, hashId] = useStyle(prefixCls);
  44. const getPositionCls = (ele, idx) => {
  45. const eleProps = ele.props || {};
  46. if (props.mode === 'alternate') {
  47. if (eleProps.position === 'right') return `${prefixCls.value}-item-right`;
  48. if (eleProps.position === 'left') return `${prefixCls.value}-item-left`;
  49. return idx % 2 === 0 ? `${prefixCls.value}-item-left` : `${prefixCls.value}-item-right`;
  50. }
  51. if (props.mode === 'left') return `${prefixCls.value}-item-left`;
  52. if (props.mode === 'right') return `${prefixCls.value}-item-right`;
  53. if (eleProps.position === 'right') return `${prefixCls.value}-item-right`;
  54. return '';
  55. };
  56. return () => {
  57. var _a, _b, _c;
  58. const {
  59. pending = (_a = slots.pending) === null || _a === void 0 ? void 0 : _a.call(slots),
  60. pendingDot = (_b = slots.pendingDot) === null || _b === void 0 ? void 0 : _b.call(slots),
  61. reverse,
  62. mode
  63. } = props;
  64. const pendingNode = typeof pending === 'boolean' ? null : pending;
  65. const children = filterEmpty((_c = slots.default) === null || _c === void 0 ? void 0 : _c.call(slots));
  66. const pendingItem = pending ? _createVNode(TimelineItem, {
  67. "pending": !!pending,
  68. "dot": pendingDot || _createVNode(LoadingOutlined, null, null)
  69. }, {
  70. default: () => [pendingNode]
  71. }) : null;
  72. if (pendingItem) {
  73. children.push(pendingItem);
  74. }
  75. const timeLineItems = reverse ? children.reverse() : children;
  76. const itemsCount = timeLineItems.length;
  77. const lastCls = `${prefixCls.value}-item-last`;
  78. const items = timeLineItems.map((ele, idx) => {
  79. const pendingClass = idx === itemsCount - 2 ? lastCls : '';
  80. const readyClass = idx === itemsCount - 1 ? lastCls : '';
  81. return cloneVNode(ele, {
  82. class: classNames([!reverse && !!pending ? pendingClass : readyClass, getPositionCls(ele, idx)])
  83. });
  84. });
  85. const hasLabelItem = timeLineItems.some(item => {
  86. var _a, _b;
  87. return !!(((_a = item.props) === null || _a === void 0 ? void 0 : _a.label) || ((_b = item.children) === null || _b === void 0 ? void 0 : _b.label));
  88. });
  89. const classString = classNames(prefixCls.value, {
  90. [`${prefixCls.value}-pending`]: !!pending,
  91. [`${prefixCls.value}-reverse`]: !!reverse,
  92. [`${prefixCls.value}-${mode}`]: !!mode && !hasLabelItem,
  93. [`${prefixCls.value}-label`]: hasLabelItem,
  94. [`${prefixCls.value}-rtl`]: direction.value === 'rtl'
  95. }, attrs.class, hashId.value);
  96. return wrapSSR(_createVNode("ul", _objectSpread(_objectSpread({}, attrs), {}, {
  97. "class": classString
  98. }), [items]));
  99. };
  100. }
  101. });