Files
td_official/src/views/personnelManagement/project/projectRelevancy/component/ShuttleFrame.vue

89 lines
2.4 KiB
Vue
Raw Normal View History

2025-03-06 11:50:32 +08:00
<template>
<div>
<div>
<el-transfer v-model="selectedProjects" :data="allProjects" filterable :titles="['项目列表', '已关联项目']" @change="handleTransferChange" />
</div>
<div style="text-align: right; margin-top: 20px">
<el-button type="primary" @click="$emit('close')">关闭</el-button>
</div>
</div>
</template>
<script lang="ts" setup>
import { ref, onMounted, defineProps, watch } from 'vue';
import { listProject } from '@/api/project/project';
import { listUserProjects, addNewProjectRelevancy, removeNewProjectRelevancy } from '@/api/project/projectRelevancy';
// **从父组件接收 `userId`**
const props = defineProps<{ userId: number }>();
// **所有项目列表**
const allProjects = ref<{ key: number; label: string }[]>([]);
// **已关联的项目 ID 列表**
const selectedProjects = ref<number[]>([]);
// **获取所有项目列表**
const getProjectList = async () => {
try {
const res = await listProject();
allProjects.value = res.records.map((project) => ({
key: project.id,
label: project.projectName
}));
} catch (error) {
console.error('获取项目列表失败:', error);
}
};
const getUserProjects = async () => {
if (!props.userId) return;
try {
const res = await listUserProjects({ userId: props.userId });
// **确保 `res.rows` 是数组**
selectedProjects.value = Array.isArray(res.rows) ? res.rows.map((item) => item.projectId) : [];
} catch (error) {
console.error('获取用户关联的项目失败:', error);
selectedProjects.value = []; // **请求失败时清空列表**
}
};
// **监听 `userId` 变化,重新加载关联数据**
watch(
() => props.userId,
async (newUserId) => {
if (newUserId) {
await getUserProjects();
}
},
{ immediate: true }
);
// **处理穿梭框变更**
const handleTransferChange = async (newValue: number[], direction: 'left' | 'right', movedKeys: number[]) => {
try {
if (direction === 'right') {
// **添加关联**
await addNewProjectRelevancy({
userId: props.userId,
projectIdList: movedKeys
});
} else {
// **移除关联**
await removeNewProjectRelevancy({
userId: props.userId,
projectIdList: movedKeys
});
}
} catch (error) {
console.error('更新项目关联失败:', error);
}
};
// **初始化数据**
onMounted(async () => {
await getProjectList();
});
</script>