52 lines
1.7 KiB
Vue
52 lines
1.7 KiB
Vue
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<ExtractPropTypes<ReturnType<typeof listItemMetaProps>>>;
|
|
|
|
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 = (
|
|
<div class={`${prefixCls.value}-item-meta-content`}>
|
|
{title && <h4 class={`${prefixCls.value}-item-meta-title`}>{title}</h4>}
|
|
{description && (
|
|
<div class={`${prefixCls.value}-item-meta-description`}>{description}</div>
|
|
)}
|
|
</div>
|
|
);
|
|
return (
|
|
<div class={classString}>
|
|
{avatar && <div class={`${prefixCls.value}-item-meta-avatar`}>{avatar}</div>}
|
|
{(title || description) && content}
|
|
</div>
|
|
);
|
|
};
|
|
},
|
|
});
|