64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			64 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
| import { camelize } from 'vue';
 | |
| import { flattenChildren } from '../_util/props-util';
 | |
| import type { ColumnType, ColumnsType, ColumnTitle, ColumnTitleProps, Key } from './interface';
 | |
| 
 | |
| export function getColumnKey<RecordType>(column: ColumnType<RecordType>, defaultKey: string): Key {
 | |
|   if ('key' in column && column.key !== undefined && column.key !== null) {
 | |
|     return column.key;
 | |
|   }
 | |
|   if (column.dataIndex) {
 | |
|     return (Array.isArray(column.dataIndex) ? column.dataIndex.join('.') : column.dataIndex) as Key;
 | |
|   }
 | |
| 
 | |
|   return defaultKey;
 | |
| }
 | |
| 
 | |
| export function getColumnPos(index: number, pos?: string) {
 | |
|   return pos ? `${pos}-${index}` : `${index}`;
 | |
| }
 | |
| 
 | |
| export function renderColumnTitle<RecordType>(
 | |
|   title: ColumnTitle<RecordType>,
 | |
|   props: ColumnTitleProps<RecordType>,
 | |
| ) {
 | |
|   if (typeof title === 'function') {
 | |
|     return title(props);
 | |
|   }
 | |
| 
 | |
|   return title;
 | |
| }
 | |
| 
 | |
| export function convertChildrenToColumns<RecordType>(
 | |
|   elements: any[] = [],
 | |
| ): ColumnsType<RecordType> {
 | |
|   const flattenElements = flattenChildren(elements);
 | |
|   const columns = [];
 | |
|   flattenElements.forEach(element => {
 | |
|     if (!element) {
 | |
|       return;
 | |
|     }
 | |
|     const key = element.key;
 | |
|     const style = element.props?.style || {};
 | |
|     const cls = element.props?.class || '';
 | |
|     const props = element.props || {};
 | |
|     for (const [k, v] of Object.entries(props)) {
 | |
|       props[camelize(k)] = v;
 | |
|     }
 | |
|     const { default: children, ...restSlots } = element.children || {};
 | |
|     const column = { ...restSlots, ...props, style, class: cls };
 | |
|     if (key) {
 | |
|       column.key = key;
 | |
|     }
 | |
|     if (element.type?.__ANT_TABLE_COLUMN_GROUP) {
 | |
|       column.children = convertChildrenToColumns(
 | |
|         typeof children === 'function' ? children() : children,
 | |
|       );
 | |
|     } else {
 | |
|       const customRender = element.children?.default;
 | |
|       column.customRender = column.customRender || customRender;
 | |
|     }
 | |
|     columns.push(column);
 | |
|   });
 | |
|   return columns;
 | |
| }
 |