110 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			110 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
| import Cell from './Cell';
 | |
| import { getOptionProps, getSlot, getClass, getStyle, getComponent } from '../_util/props-util';
 | |
| import { FunctionalComponent } from 'vue';
 | |
| 
 | |
| 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,
 | |
|     { colon, prefixCls, bordered },
 | |
|     { component, type, showLabel, showContent }: CellConfig,
 | |
|   ) => {
 | |
|     return items.map((item, index) => {
 | |
|       const { prefixCls: itemPrefixCls = prefixCls, span = 1 } = getOptionProps(item);
 | |
|       const label = getComponent(item, 'label');
 | |
| 
 | |
|       const children = getSlot(item);
 | |
|       const className = getClass(item);
 | |
|       const style = getStyle(item);
 | |
|       const { key } = item;
 | |
| 
 | |
|       if (typeof component === 'string') {
 | |
|         return (
 | |
|           <Cell
 | |
|             key={`${type}-${key || index}`}
 | |
|             class={className}
 | |
|             style={style}
 | |
|             span={span}
 | |
|             colon={colon}
 | |
|             component={component}
 | |
|             itemPrefixCls={itemPrefixCls}
 | |
|             bordered={bordered}
 | |
|             label={showLabel ? label : null}
 | |
|             content={showContent ? children : null}
 | |
|           />
 | |
|         );
 | |
|       }
 | |
| 
 | |
|       return [
 | |
|         <Cell
 | |
|           key={`label-${key || index}`}
 | |
|           class={className}
 | |
|           style={style}
 | |
|           span={1}
 | |
|           colon={colon}
 | |
|           component={component[0]}
 | |
|           itemPrefixCls={itemPrefixCls}
 | |
|           bordered={bordered}
 | |
|           label={label}
 | |
|         />,
 | |
|         <Cell
 | |
|           key={`content-${key || index}`}
 | |
|           class={className}
 | |
|           style={style}
 | |
|           span={span * 2 - 1}
 | |
|           component={component[1]}
 | |
|           itemPrefixCls={itemPrefixCls}
 | |
|           bordered={bordered}
 | |
|           content={children}
 | |
|         />,
 | |
|       ];
 | |
|     });
 | |
|   };
 | |
| 
 | |
|   const { prefixCls, vertical, row, index, bordered } = props;
 | |
|   if (vertical) {
 | |
|     return (
 | |
|       <>
 | |
|         <tr key={`label-${index}`} class={`${prefixCls}-row`}>
 | |
|           {renderCells(row, props, { component: 'th', type: 'label', showLabel: true })}
 | |
|         </tr>
 | |
|         <tr key={`content-${index}`} class={`${prefixCls}-row`}>
 | |
|           {renderCells(row, props, {
 | |
|             component: 'td',
 | |
|             type: 'content',
 | |
|             showContent: true,
 | |
|           })}
 | |
|         </tr>
 | |
|       </>
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   return (
 | |
|     <tr key={index} class={`${prefixCls}-row`}>
 | |
|       {renderCells(row, props, {
 | |
|         component: bordered ? ['th', 'td'] : 'td',
 | |
|         type: 'item',
 | |
|         showLabel: true,
 | |
|         showContent: true,
 | |
|       })}
 | |
|     </tr>
 | |
|   );
 | |
| };
 | |
| 
 | |
| export default Row;
 |