ant-design-vue/components/descriptions/Row.tsx

139 lines
3.8 KiB
Vue
Raw Normal View History

import Cell from './Cell';
2021-06-19 13:51:29 +00:00
import { getSlot, getClass, getStyle } from '../_util/props-util';
import type { CSSProperties, FunctionalComponent, VNode } from 'vue';
2021-06-26 01:35:40 +00:00
import { inject, ref } from 'vue';
import { descriptionsContext } from './index';
interface CellConfig {
component: string | [string, string];
type: string;
showLabel?: boolean;
showContent?: boolean;
}
export interface RowProps {
prefixCls: string;
vertical: boolean;
row: any[];
bordered: boolean;
colon: boolean;
index: number;
}
const Row: FunctionalComponent<RowProps> = props => {
const renderCells = (
items: VNode[],
{ colon, prefixCls, bordered },
2021-06-18 09:45:29 +00:00
{
component,
type,
showLabel,
showContent,
labelStyle: rootLabelStyle,
contentStyle: rootContentStyle,
}: CellConfig & { labelStyle?: CSSProperties; contentStyle?: CSSProperties },
) => {
return items.map((item, index) => {
const itemProps = item.props || {};
2021-06-18 09:45:29 +00:00
const {
prefixCls: itemPrefixCls = prefixCls,
span = 1,
labelStyle = itemProps['label-style'],
contentStyle = itemProps['content-style'],
2021-06-19 13:51:29 +00:00
label = (item.children as any)?.label?.(),
} = itemProps;
const children = getSlot(item);
const className = getClass(item);
const style = getStyle(item);
const { key } = item;
if (typeof component === 'string') {
return (
<Cell
2021-08-10 07:21:13 +00:00
key={`${type}-${String(key) || index}`}
class={className}
style={style}
labelStyle={{ ...rootLabelStyle, ...labelStyle }}
contentStyle={{ ...rootContentStyle, ...contentStyle }}
span={span}
colon={colon}
component={component}
itemPrefixCls={itemPrefixCls}
bordered={bordered}
label={showLabel ? label : null}
content={showContent ? children : null}
/>
);
}
return [
<Cell
2021-08-10 07:21:13 +00:00
key={`label-${String(key) || index}`}
class={className}
style={{ ...rootLabelStyle, ...style, ...labelStyle }}
span={1}
colon={colon}
component={component[0]}
itemPrefixCls={itemPrefixCls}
bordered={bordered}
label={label}
/>,
<Cell
2021-08-10 07:21:13 +00:00
key={`content-${String(key) || index}`}
class={className}
style={{ ...rootContentStyle, ...style, ...contentStyle }}
span={span * 2 - 1}
component={component[1]}
itemPrefixCls={itemPrefixCls}
bordered={bordered}
content={children}
/>,
];
});
};
const { prefixCls, vertical, row, index, bordered } = props;
2021-06-18 09:45:29 +00:00
const { labelStyle, contentStyle } = inject(descriptionsContext, {
2021-06-19 13:51:29 +00:00
labelStyle: ref({}),
contentStyle: ref({}),
2021-06-18 09:45:29 +00:00
});
if (vertical) {
return (
<>
<tr key={`label-${index}`} class={`${prefixCls}-row`}>
2021-06-18 09:45:29 +00:00
{renderCells(row, props, {
component: 'th',
type: 'label',
showLabel: true,
labelStyle: labelStyle.value,
contentStyle: contentStyle.value,
2021-06-18 09:45:29 +00:00
})}
</tr>
<tr key={`content-${index}`} class={`${prefixCls}-row`}>
{renderCells(row, props, {
component: 'td',
type: 'content',
showContent: true,
labelStyle: labelStyle.value,
contentStyle: contentStyle.value,
})}
</tr>
</>
);
}
return (
<tr key={index} class={`${prefixCls}-row`}>
{renderCells(row, props, {
component: bordered ? ['th', 'td'] : 'td',
type: 'item',
showLabel: true,
showContent: true,
labelStyle: labelStyle.value,
contentStyle: contentStyle.value,
})}
</tr>
);
};
export default Row;