import type { ExtractPropTypes } from 'vue'; import { defineComponent } from 'vue'; import useConfigInject from '../config-provider/hooks/useConfigInject'; import PropTypes from '../_util/vue-types'; import type { CustomSlotsType } from '../_util/type'; export const listItemMetaProps = () => ({ avatar: PropTypes.any, description: PropTypes.any, prefixCls: String, title: PropTypes.any, }); export type ListItemMetaProps = Partial>>; export default defineComponent({ compatConfig: { MODE: 3 }, name: 'AListItemMeta', props: listItemMetaProps(), displayName: 'AListItemMeta', // 兼容历史函数式组件 __ANT_LIST_ITEM_META: true, slots: Object as CustomSlotsType<{ avatar: any; description: any; title: any; default: any; }>, setup(props, { slots }) { const { prefixCls } = useConfigInject('list', props); return () => { const classString = `${prefixCls.value}-item-meta`; const title = props.title ?? slots.title?.(); const description = props.description ?? slots.description?.(); const avatar = props.avatar ?? slots.avatar?.(); const content = (
{title &&

{title}

} {description && (
{description}
)}
); return (
{avatar &&
{avatar}
} {(title || description) && content}
); }; }, });