Timeline.js 4.6 KB

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