TimelineItem.js 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import { createVNode as _createVNode } from "vue";
  2. import { computed, defineComponent } from 'vue';
  3. import PropTypes from '../_util/vue-types';
  4. import initDefaultProps from '../_util/props-util/initDefaultProps';
  5. import { tuple, booleanType } from '../_util/type';
  6. import useConfigInject from '../config-provider/hooks/useConfigInject';
  7. export const timelineItemProps = () => ({
  8. prefixCls: String,
  9. color: String,
  10. dot: PropTypes.any,
  11. pending: booleanType(),
  12. position: PropTypes.oneOf(tuple('left', 'right', '')).def(''),
  13. label: PropTypes.any
  14. });
  15. export default defineComponent({
  16. compatConfig: {
  17. MODE: 3
  18. },
  19. name: 'ATimelineItem',
  20. props: initDefaultProps(timelineItemProps(), {
  21. color: 'blue',
  22. pending: false
  23. }),
  24. slots: Object,
  25. setup(props, _ref) {
  26. let {
  27. slots
  28. } = _ref;
  29. const {
  30. prefixCls
  31. } = useConfigInject('timeline', props);
  32. const itemClassName = computed(() => ({
  33. [`${prefixCls.value}-item`]: true,
  34. [`${prefixCls.value}-item-pending`]: props.pending
  35. }));
  36. const customColor = computed(() => /blue|red|green|gray/.test(props.color || '') ? undefined : props.color || 'blue');
  37. const dotClassName = computed(() => ({
  38. [`${prefixCls.value}-item-head`]: true,
  39. [`${prefixCls.value}-item-head-${props.color || 'blue'}`]: !customColor.value
  40. }));
  41. return () => {
  42. var _a, _b, _c;
  43. const {
  44. label = (_a = slots.label) === null || _a === void 0 ? void 0 : _a.call(slots),
  45. dot = (_b = slots.dot) === null || _b === void 0 ? void 0 : _b.call(slots)
  46. } = props;
  47. return _createVNode("li", {
  48. "class": itemClassName.value
  49. }, [label && _createVNode("div", {
  50. "class": `${prefixCls.value}-item-label`
  51. }, [label]), _createVNode("div", {
  52. "class": `${prefixCls.value}-item-tail`
  53. }, null), _createVNode("div", {
  54. "class": [dotClassName.value, !!dot && `${prefixCls.value}-item-head-custom`],
  55. "style": {
  56. borderColor: customColor.value,
  57. color: customColor.value
  58. }
  59. }, [dot]), _createVNode("div", {
  60. "class": `${prefixCls.value}-item-content`
  61. }, [(_c = slots.default) === null || _c === void 0 ? void 0 : _c.call(slots)])]);
  62. };
  63. }
  64. });