ItemMeta.js 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.listItemMetaProps = exports.default = void 0;
  7. var _vue = require("vue");
  8. var _useConfigInject = _interopRequireDefault(require("../config-provider/hooks/useConfigInject"));
  9. var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
  10. const listItemMetaProps = () => ({
  11. avatar: _vueTypes.default.any,
  12. description: _vueTypes.default.any,
  13. prefixCls: String,
  14. title: _vueTypes.default.any
  15. });
  16. exports.listItemMetaProps = listItemMetaProps;
  17. var _default = exports.default = (0, _vue.defineComponent)({
  18. compatConfig: {
  19. MODE: 3
  20. },
  21. name: 'AListItemMeta',
  22. props: listItemMetaProps(),
  23. displayName: 'AListItemMeta',
  24. __ANT_LIST_ITEM_META: true,
  25. slots: Object,
  26. setup(props, _ref) {
  27. let {
  28. slots
  29. } = _ref;
  30. const {
  31. prefixCls
  32. } = (0, _useConfigInject.default)('list', props);
  33. return () => {
  34. var _a, _b, _c, _d, _e, _f;
  35. const classString = `${prefixCls.value}-item-meta`;
  36. const title = (_a = props.title) !== null && _a !== void 0 ? _a : (_b = slots.title) === null || _b === void 0 ? void 0 : _b.call(slots);
  37. const description = (_c = props.description) !== null && _c !== void 0 ? _c : (_d = slots.description) === null || _d === void 0 ? void 0 : _d.call(slots);
  38. const avatar = (_e = props.avatar) !== null && _e !== void 0 ? _e : (_f = slots.avatar) === null || _f === void 0 ? void 0 : _f.call(slots);
  39. const content = (0, _vue.createVNode)("div", {
  40. "class": `${prefixCls.value}-item-meta-content`
  41. }, [title && (0, _vue.createVNode)("h4", {
  42. "class": `${prefixCls.value}-item-meta-title`
  43. }, [title]), description && (0, _vue.createVNode)("div", {
  44. "class": `${prefixCls.value}-item-meta-description`
  45. }, [description])]);
  46. return (0, _vue.createVNode)("div", {
  47. "class": classString
  48. }, [avatar && (0, _vue.createVNode)("div", {
  49. "class": `${prefixCls.value}-item-meta-avatar`
  50. }, [avatar]), (title || description) && content]);
  51. };
  52. }
  53. });