import type { ExtractPropTypes } from 'vue'; import { defineComponent } from 'vue'; import { getPropsSlot } from '../_util/props-util'; import useConfigInject from '../config-provider/hooks/useConfigInject'; import { vNodeType } from '../_util/type'; import type { CustomSlotsType } from '../_util/type'; export const cardMetaProps = () => ({ prefixCls: String, title: vNodeType(), description: vNodeType(), avatar: vNodeType(), }); export type CardGridProps = Partial>>; export default defineComponent({ compatConfig: { MODE: 3 }, name: 'ACardMeta', props: cardMetaProps(), slots: Object as CustomSlotsType<{ title: any; description: any; avatar: any; default: any; }>, setup(props, { slots }) { const { prefixCls } = useConfigInject('card', props); return () => { const classString = { [`${prefixCls.value}-meta`]: true, }; const avatar = getPropsSlot(slots, props, 'avatar'); const title = getPropsSlot(slots, props, 'title'); const description = getPropsSlot(slots, props, 'description'); const avatarDom = avatar ? (
{avatar}
) : null; const titleDom = title ?
{title}
: null; const descriptionDom = description ? (
{description}
) : null; const MetaDetail = titleDom || descriptionDom ? (
{titleDom} {descriptionDom}
) : null; return (
{avatarDom} {MetaDetail}
); }; }, });