mirror of
				https://github.com/soybeanjs/soybean-admin.git
				synced 2025-11-04 07:43:42 +08:00 
			
		
		
		
	feat(projects): feat(projects): TableColumnCheck title support VNode (#716)
This commit is contained in:
		@@ -1,5 +1,5 @@
 | 
			
		||||
import { computed, reactive, ref } from 'vue';
 | 
			
		||||
import type { Ref } from 'vue';
 | 
			
		||||
import type { Ref, VNodeChild } from 'vue';
 | 
			
		||||
import { jsonClone } from '@sa/utils';
 | 
			
		||||
import useBoolean from './use-boolean';
 | 
			
		||||
import useLoading from './use-loading';
 | 
			
		||||
@@ -8,9 +8,11 @@ export type MaybePromise<T> = T | Promise<T>;
 | 
			
		||||
 | 
			
		||||
export type ApiFn = (args: any) => Promise<unknown>;
 | 
			
		||||
 | 
			
		||||
export type TableColumnCheckTitle = string | ((...args: any) => VNodeChild);
 | 
			
		||||
 | 
			
		||||
export type TableColumnCheck = {
 | 
			
		||||
  key: string;
 | 
			
		||||
  title: string;
 | 
			
		||||
  title: TableColumnCheckTitle;
 | 
			
		||||
  checked: boolean;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -25,7 +25,10 @@ const columns = defineModel<NaiveUI.TableColumnCheck[]>('columns', {
 | 
			
		||||
      <div v-for="item in columns" :key="item.key" class="h-36px flex-y-center rd-4px hover:(bg-primary bg-opacity-20)">
 | 
			
		||||
        <icon-mdi-drag class="mr-8px h-full cursor-move text-icon" />
 | 
			
		||||
        <NCheckbox v-model:checked="item.checked" class="none_draggable flex-1">
 | 
			
		||||
          {{ item.title }}
 | 
			
		||||
          <template v-if="typeof item.title === 'function'">
 | 
			
		||||
            <component :is="item.title" />
 | 
			
		||||
          </template>
 | 
			
		||||
          <template v-else>{{ item.title }}</template>
 | 
			
		||||
        </NCheckbox>
 | 
			
		||||
      </div>
 | 
			
		||||
    </VueDraggable>
 | 
			
		||||
 
 | 
			
		||||
@@ -64,7 +64,7 @@ export function useTable<A extends NaiveUI.TableApiFn>(config: NaiveUI.NaiveTabl
 | 
			
		||||
        if (isTableColumnHasKey(column)) {
 | 
			
		||||
          checks.push({
 | 
			
		||||
            key: column.key as string,
 | 
			
		||||
            title: column.title as string,
 | 
			
		||||
            title: column.title!,
 | 
			
		||||
            checked: true
 | 
			
		||||
          });
 | 
			
		||||
        } else if (column.type === 'selection') {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user