gtsoft-snail-job-admin/src/components/advanced/table-column-setting.vue
2024-03-26 11:47:11 +08:00

36 lines
1018 B
Vue

<script setup lang="ts" generic="T extends Record<string, unknown>, K = never">
import { VueDraggable } from 'vue-draggable-plus';
import { $t } from '@/locales';
defineOptions({
name: 'TableColumnSetting'
});
const columns = defineModel<NaiveUI.TableColumnCheck[]>('columns', {
required: true
});
</script>
<template>
<NPopover placement="bottom-end" trigger="click">
<template #trigger>
<NButton size="small">
<template #icon>
<icon-ant-design-setting-outlined class="text-icon" />
</template>
{{ $t('common.columnSetting') }}
</NButton>
</template>
<VueDraggable v-model="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 cursor-move text-icon" />
<NCheckbox v-model:checked="item.checked">
{{ item.title }}
</NCheckbox>
</div>
</VueDraggable>
</NPopover>
</template>
<style scoped></style>