import PropTypes from '../_util/vue-types'; import classNames from '../_util/classNames'; import { getComponent, isStringElement, isEmptyElement, getSlot } from '../_util/props-util'; import { Col } from '../grid'; import { defaultConfigProvider } from '../config-provider'; import { cloneElement } from '../_util/vnode'; import { defineComponent, ExtractPropTypes, FunctionalComponent, inject } from 'vue'; export const ListItemProps = { prefixCls: PropTypes.string, extra: PropTypes.any, actions: PropTypes.array, grid: PropTypes.any, }; export const ListItemMetaProps = { avatar: PropTypes.any, description: PropTypes.any, prefixCls: PropTypes.string, title: PropTypes.any, }; export const ListItemMeta: FunctionalComponent >> = (props, { slots }) => { const configProvider = inject('configProvider', defaultConfigProvider); const { getPrefixCls } = configProvider; const { prefixCls: customizePrefixCls } = props; const prefixCls = getPrefixCls('list', customizePrefixCls); const avatar = props.avatar || slots.avatar?.(); const title = props.title || slots.title?.(); const description = props.description || slots.description?.(); const content = (
{title &&

{title}

} {description &&
{description}
}
); return (
{avatar &&
{avatar}
} {(title || description) && content}
); }; Object.assign(ListItemMeta, { props: ListItemMetaProps, __ANT_LIST_ITEM_META: true, displayName: 'AListItemMeta', }); function getGrid(grid, t) { return grid[t] && Math.floor(24 / grid[t]); } export interface ListContext { grid?: any; itemLayout?: string; } export default defineComponent({ name: 'AListItem', inheritAttrs: false, Meta: ListItemMeta, props: ListItemProps, setup() { const listContext = inject('listContext', {}); const configProvider = inject('configProvider', defaultConfigProvider); return { listContext, configProvider, }; }, methods: { isItemContainsTextNodeAndNotSingular() { const children = getSlot(this) || []; let result; children.forEach(element => { if (isStringElement(element) && !isEmptyElement(element)) { result = true; } }); return result && children.length > 1; }, isFlexMode() { const extra = getComponent(this, 'extra'); const { itemLayout } = this.listContext; if (itemLayout === 'vertical') { return !!extra; } return !this.isItemContainsTextNodeAndNotSingular(); }, }, render() { const { grid, itemLayout } = this.listContext; const { prefixCls: customizePrefixCls, $attrs } = this; const { class: _className, ...restAttrs } = $attrs; const getPrefixCls = this.configProvider.getPrefixCls; const prefixCls = getPrefixCls('list', customizePrefixCls); const extra = getComponent(this, 'extra'); let actions = getComponent(this, 'actions'); actions = actions && !Array.isArray(actions) ? [actions] : actions; const actionsContent = actions && actions.length > 0 && ( ); const children = getSlot(this); const Tag = grid ? 'div' : 'li'; const itemChildren = ( {itemLayout === 'vertical' && extra ? [
{children} {actionsContent}
,
{extra}
, ] : [children, actionsContent, cloneElement(extra, { key: 'extra' })]}
); const mainContent = grid ? ( {itemChildren} ) : ( itemChildren ); return mainContent; }, });