This commit is contained in:
zhoutianchi
2026-02-06 16:14:20 +08:00
parent 020468c6f1
commit 4403299835
2 changed files with 319 additions and 242 deletions

View File

@@ -0,0 +1,101 @@
<template>
<el-dialog v-model="visible" :title="title" width="600" append-to-body>
<div style="text-align: center; margin-bottom: 20px">
<el-button type="success" :icon="Download" @click="handleDownloadTemplate">下载模板</el-button>
</div>
<el-upload
class="upload-demo"
:action="uploadUrl"
:headers="headers"
:accept="'.xls,.xlsx'"
:on-success="handleUploadSuccess"
:on-error="handleAvatarError"
:limit="1"
drag
>
<el-icon class="el-icon--upload"><upload-filled /></el-icon>
<div class="el-upload__text">将文件拖到此处<em>点击上传</em></div>
<template #tip>
<div class="el-upload__tip">只能上传 .xls .xlsx 格式的 Excel 文件</div>
</template>
</el-upload>
</el-dialog>
</template>
<script setup lang="ts">
import { ref, computed } from 'vue';
import { ElNotification } from 'element-plus';
import { Download, UploadFilled } from '@element-plus/icons-vue';
import { Session } from '/@/utils/storage';
import { downBlobFile } from '/@/utils/other';
const title = ref('');
// 响应式数据
const visible = ref(false);
// 计算属性
const headers = computed(() => {
return {
Authorization: 'Bearer ' + Session.getToken(),
TENANT_ID: Session.getTenant()
};
});
const uploadUrl = ref('')
const currentType = ref('')
const titleMap: Record<string, string> = {
planMajor: '计划专业导入'
}
// 方法
const init = (type: any) => {
currentType.value = type
uploadUrl.value = '/professional/file/importTeacherOtherInfo?type=' + type
title.value = titleMap[type] || '信息导入'
visible.value = true
}
// Emits
const emit = defineEmits<{
(e: 'refreshData'): void
}>()
const handleUploadSuccess = () => {
visible.value = false;
ElNotification({
title: '成功',
message: '导入成功',
type: 'success',
});
emit('refreshData')
};
const handleAvatarError = (err: any) => {
const result = JSON.parse(err.message);
if (result.code == '1') {
ElNotification.error({
title: '错误',
message: result.msg,
duration: 30000,
});
}
};
const handleDownloadTemplate = () => {
downBlobFile('/recruit/file/exportRecruitTemplate', { type: currentType.value || 'planMajor' }, title.value+'模板.xlsx')
}
// 暴露方法给父组件
defineExpose({
init
});
</script>
<style scoped lang="scss">
.upload-demo {
:deep(.el-upload-dragger) {
width: 100%;
}
}
</style>

View File

@@ -16,303 +16,279 @@
--> -->
<template> <template>
<div class="layout-padding"> <div class="layout-padding">
<div class="layout-padding-auto layout-padding-view"> <div class="layout-padding-auto layout-padding-view">
<!-- 搜索表单 --> <!-- 搜索表单 -->
<el-form :model="queryForm" inline ref="searchFormRef"> <el-form :model="queryForm" inline ref="searchFormRef">
<el-form-item label="招生计划" prop="groupId"> <el-form-item label="招生计划" prop="groupId">
<el-select v-model="queryForm.groupId" filterable clearable placeholder="请选择招生计划"> <el-select v-model="queryForm.groupId" filterable clearable placeholder="请选择招生计划">
<el-option <el-option v-for="item in planList" :key="item.id" :label="item.groupName" :value="item.id" />
v-for="item in planList" </el-select>
:key="item.id" </el-form-item>
:label="item.groupName" <el-form-item label="学院" prop="deptCode">
:value="item.id" <el-select v-model="queryForm.deptCode" filterable clearable placeholder="请选择">
/> <el-option v-for="item in deptList" :key="item.deptCode" :label="item.deptName" :value="item.deptCode" />
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item label="学院" prop="deptCode"> <el-form-item label="专业序号" prop="majorCode">
<el-select v-model="queryForm.deptCode" filterable clearable placeholder="请选择"> <el-input v-model="queryForm.majorCode" placeholder="专业序号" />
<el-option </el-form-item>
v-for="item in deptList" <el-form-item label="专业名称" prop="majorName">
:key="item.deptCode" <el-input v-model="queryForm.majorName" placeholder="专业名称" />
:label="item.deptName" </el-form-item>
:value="item.deptCode" <el-form-item label="学制" prop="learnYear">
/> <el-input v-model="queryForm.learnYear" placeholder="学制" />
</el-select> </el-form-item>
</el-form-item> <el-form-item>
<el-form-item label="专业序号" prop="majorCode"> <el-button type="primary" icon="Search" @click="getDataList">查询</el-button>
<el-input v-model="queryForm.majorCode" placeholder="专业序号" /> <el-button plain icon="Refresh" class="ml10" @click="resetQuery">重置</el-button>
</el-form-item> </el-form-item>
<el-form-item label="专业名称" prop="majorName"> </el-form>
<el-input v-model="queryForm.majorName" placeholder="专业名称" />
</el-form-item>
<el-form-item label="学制" prop="learnYear">
<el-input v-model="queryForm.learnYear" placeholder="学制" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="Search" @click="getDataList">查询</el-button>
<el-button plain icon="Refresh" class="ml10" @click="resetQuery">重置</el-button>
</el-form-item>
</el-form>
<!-- 操作按钮 --> <!-- 操作按钮 -->
<div class="mb15"> <div class="mb15">
<el-button <el-button v-if="hasAuth('recruit_recruitplanmajor_add')" type="primary" icon="FolderAdd" @click="addOrUpdateHandle"> </el-button>
v-if="hasAuth('recruit_recruitplanmajor_add')"
type="primary"
icon="FolderAdd"
@click="addOrUpdateHandle"
>
</el-button>
</div>
<!-- 表格 --> <el-button
<el-table v-auth="'professional_teacherinfo_import'"
ref="tableRef" type="primary"
:data="state.dataList" plain
v-loading="state.loading" icon="UploadFilled"
border :loading="exportLoading"
stripe @click="handleImportDialog"
row-key="id" >导入信息
:cell-style="tableStyle.cellStyle" </el-button>
:header-cell-style="tableStyle.headerCellStyle" </div>
>
<el-table-column type="index" label="序号" width="60" align="center" />
<el-table-column prop="groupId" label="招生计划名称" align="center" min-width="140" show-overflow-tooltip>
<template #default="scope">
{{ getPlanName(scope.row.groupId) }}
</template>
</el-table-column>
<el-table-column prop="majorCode" label="专业序号" align="center" show-overflow-tooltip />
<el-table-column prop="majorName" label="专业名称" align="center" show-overflow-tooltip />
<el-table-column prop="deptCode" label="学院" align="center" show-overflow-tooltip>
<template #default="scope">
{{ getDeptName(scope.row.deptCode) }}
</template>
</el-table-column>
<el-table-column prop="learnYear" label="学制" align="center" width="80" show-overflow-tooltip />
<el-table-column prop="majorLevel" label="层次" align="center" show-overflow-tooltip />
<el-table-column prop="isOrder" label="订单班|中德班|联院班" align="center" width="180" show-overflow-tooltip>
<template #default="scope">
{{ getYesNoLabel(scope.row.isOrder) }}{{ getYesNoLabel(scope.row.isZd) }}{{ getYesNoLabel(scope.row.isUnion) }}
</template>
</el-table-column>
<el-table-column prop="sm" label="色盲不可录" align="center" width="120"> <!-- 表格 -->
<template #default="scope"> <el-table
<el-switch ref="tableRef"
v-model="scope.row.sm" :data="state.dataList"
active-text="" v-loading="state.loading"
inactive-text="" border
active-value="1" stripe
inactive-value="0" row-key="id"
@change="changeSm(scope.row)" :cell-style="tableStyle.cellStyle"
/> :header-cell-style="tableStyle.headerCellStyle"
</template> >
</el-table-column> <el-table-column type="index" label="序号" width="60" align="center" />
<el-table-column prop="stuworkMajorCode" label="正式专业代码" align="center" show-overflow-tooltip> <el-table-column prop="groupId" label="招生计划名称" align="center" min-width="140" show-overflow-tooltip>
<template #default="scope"> <template #default="scope">
{{ getMajorCodeName(scope.row.stuworkMajorCode) }} {{ getPlanName(scope.row.groupId) }}
</template> </template>
</el-table-column> </el-table-column>
<!-- <el-table-column prop="cityPlanId" label="市平台招生计划" align="center" show-overflow-tooltip> <el-table-column prop="majorCode" label="专业序号" align="center" show-overflow-tooltip />
<el-table-column prop="majorName" label="专业名称" align="center" show-overflow-tooltip />
<el-table-column prop="deptCode" label="学院" align="center" show-overflow-tooltip>
<template #default="scope">
{{ getDeptName(scope.row.deptCode) }}
</template>
</el-table-column>
<el-table-column prop="learnYear" label="学制" align="center" width="80" show-overflow-tooltip />
<el-table-column prop="majorLevel" label="层次" align="center" show-overflow-tooltip />
<el-table-column prop="isOrder" label="订单班|中德班|联院班" align="center" width="180" show-overflow-tooltip>
<template #default="scope">
{{ getYesNoLabel(scope.row.isOrder) }}{{ getYesNoLabel(scope.row.isZd) }}{{ getYesNoLabel(scope.row.isUnion) }}
</template>
</el-table-column>
<el-table-column prop="sm" label="色盲不可录" align="center" width="120">
<template #default="scope">
<el-switch v-model="scope.row.sm" active-text="是" inactive-text="否" active-value="1" inactive-value="0" @change="changeSm(scope.row)" />
</template>
</el-table-column>
<el-table-column prop="stuworkMajorCode" label="正式专业代码" align="center" show-overflow-tooltip>
<template #default="scope">
{{ getMajorCodeName(scope.row.stuworkMajorCode) }}
</template>
</el-table-column>
<!-- <el-table-column prop="cityPlanId" label="市平台招生计划" align="center" show-overflow-tooltip>
<template #default="scope"> <template #default="scope">
{{ scope.row.cityPlanName != undefined ? (scope.row.cityPlanName + '|' + scope.row.cityPlanYear) : '' }} {{ scope.row.cityPlanName != undefined ? (scope.row.cityPlanName + '|' + scope.row.cityPlanYear) : '' }}
</template> </template>
</el-table-column> --> </el-table-column> -->
<!-- <el-table-column prop="sort" label="排序" align="center" show-overflow-tooltip /> --> <!-- <el-table-column prop="sort" label="排序" align="center" show-overflow-tooltip /> -->
<el-table-column label="操作" width="150" align="center" fixed="right"> <el-table-column label="操作" width="150" align="center" fixed="right">
<template #default="scope"> <template #default="scope">
<el-button <el-button type="primary" link icon="EditPen" @click="addOrUpdateHandle(scope.row)"> 修改 </el-button>
type="primary" <el-button v-if="hasAuth('recruit_recruitplanmajor_del')" type="danger" link icon="Delete" @click="deleteHandle(scope.row.id)">
link 删除
icon="EditPen" </el-button>
@click="addOrUpdateHandle(scope.row)" </template>
> </el-table-column>
修改 </el-table>
</el-button>
<el-button
v-if="hasAuth('recruit_recruitplanmajor_del')"
type="danger"
link
icon="Delete"
@click="deleteHandle(scope.row.id)"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 --> <!-- 分页 -->
<pagination <pagination v-bind="state.pagination" @current-change="currentChangeHandle" @size-change="sizeChangeHandle" />
v-bind="state.pagination"
@current-change="currentChangeHandle"
@size-change="sizeChangeHandle"
/>
<!-- 弹窗, 新增 / 修改 --> <!-- 弹窗, 新增 / 修改 -->
<table-form ref="addOrUpdateRef" @refreshDataList="getDataList" /> <table-form ref="addOrUpdateRef" @refreshDataList="getDataList" />
</div>
</div> <import-recruit-info ref="ImportRecruitInfoRef"></import-recruit-info>
</div>
</div>
</template> </template>
<script setup lang="ts" name="recruitplanmajor"> <script setup lang="ts" name="recruitplanmajor">
import { ref, reactive, onMounted, nextTick, defineAsyncComponent } from 'vue' import { ref, reactive, onMounted, nextTick, defineAsyncComponent } from 'vue';
import { useAuth } from '/@/hooks/auth' import { useAuth } from '/@/hooks/auth';
import { BasicTableProps, useTable } from '/@/hooks/table' import { BasicTableProps, useTable } from '/@/hooks/table';
import { useMessage, useMessageBox } from '/@/hooks/message' import { useMessage, useMessageBox } from '/@/hooks/message';
import { useDict } from '/@/hooks/dict' import { useDict } from '/@/hooks/dict';
import { getList } from '/@/api/recruit/recruitstudentplangroup' import { getList } from '/@/api/recruit/recruitstudentplangroup';
import { fetchList, delObj, editQuickField } from '/@/api/recruit/recruitstudentplan' import { fetchList, delObj, editQuickField } from '/@/api/recruit/recruitstudentplan';
import { getDeptList } from '/@/api/basic/basicclass' import { getDeptList } from '/@/api/basic/basicclass';
import { getMajorNameList } from '/@/api/basic/major' import { getMajorNameList } from '/@/api/basic/major';
const TableForm = defineAsyncComponent(() => import('./detaiform.vue')) const TableForm = defineAsyncComponent(() => import('./detaiform.vue'));
const { hasAuth } = useAuth() const ImportRecruitInfo = defineAsyncComponent(() => import('/@/views/recruit/common/import-recruit-info.vue'));
const ImportRecruitInfoRef=ref<any>();
const { hasAuth } = useAuth();
// 消息提示 hooks // 消息提示 hooks
const message = useMessage() const message = useMessage();
const messageBox = useMessageBox() const messageBox = useMessageBox();
// 表格引用 // 表格引用
const tableRef = ref() const tableRef = ref();
const searchFormRef = ref() const searchFormRef = ref();
const addOrUpdateRef = ref() const addOrUpdateRef = ref();
// 字典数据 // 字典数据
const { yes_no_type } = useDict('yes_no_type') const { yes_no_type } = useDict('yes_no_type');
// 数据 // 数据
const planList = ref<any[]>([]) const planList = ref<any[]>([]);
const deptList = ref<any[]>([]) const deptList = ref<any[]>([]);
const offcialZydmList = ref<any[]>([]) const offcialZydmList = ref<any[]>([]);
// 查询表单 // 查询表单
const queryForm = reactive({ const queryForm = reactive({
groupId: '', groupId: '',
deptCode: '', deptCode: '',
majorCode: '', majorCode: '',
majorName: '', majorName: '',
learnYear: '' learnYear: '',
}) });
// 获取计划名称 // 获取计划名称
const getPlanName = (groupId: string) => { const getPlanName = (groupId: string) => {
const item = planList.value.find(item => item.id === groupId) const item = planList.value.find((item) => item.id === groupId);
return item ? item.groupName : '' return item ? item.groupName : '';
} };
// 获取学院名称 // 获取学院名称
const getDeptName = (deptCode: string) => { const getDeptName = (deptCode: string) => {
const item = deptList.value.find(item => item.deptCode === deptCode) const item = deptList.value.find((item) => item.deptCode === deptCode);
return item ? item.deptName : '' return item ? item.deptName : '';
} };
// 获取是/否标签 // 获取是/否标签
const getYesNoLabel = (value: string) => { const getYesNoLabel = (value: string) => {
const item = yes_no_type.value.find((item: any) => item.value === value) const item = yes_no_type.value.find((item: any) => item.value === value);
return item ? item.label : '' return item ? item.label : '';
} };
// 获取专业代码名称 // 获取专业代码名称
const getMajorCodeName = (majorCode: string) => { const getMajorCodeName = (majorCode: string) => {
const item = offcialZydmList.value.find(item => item.majorCode === majorCode) const item = offcialZydmList.value.find((item) => item.majorCode === majorCode);
return item ? item.majorCodeAndName : '' return item ? item.majorCodeAndName : '';
} };
// 表格状态 // 表格状态
const state: BasicTableProps = reactive<BasicTableProps>({ const state: BasicTableProps = reactive<BasicTableProps>({
queryForm: queryForm, queryForm: queryForm,
pageList: async (params: any) => { pageList: async (params: any) => {
const response = await fetchList(params) const response = await fetchList(params);
return { return {
data: { data: {
records: response.data.records, records: response.data.records,
total: response.data.total total: response.data.total,
} },
} };
}, },
createdIsNeed: false createdIsNeed: false,
}) });
// 使用 table hook // 使用 table hook
const { getDataList, currentChangeHandle, sizeChangeHandle, tableStyle } = useTable(state) const { getDataList, currentChangeHandle, sizeChangeHandle, tableStyle } = useTable(state);
// 初始化 // 初始化
const init = async () => { const init = async () => {
try { try {
// 查询二级学院信息 // 查询二级学院信息
const deptData = await getDeptList() const deptData = await getDeptList();
deptList.value = deptData.data || [] deptList.value = deptData.data || [];
// 获取招生计划列表 // 获取招生计划列表
const planData = await getList() const planData = await getList();
planList.value = planData.data || [] planList.value = planData.data || [];
if (planList.value.length > 0) { if (planList.value.length > 0) {
queryForm.groupId = planList.value[0].id queryForm.groupId = planList.value[0].id;
} }
// 获取专业名称列表 // 获取专业名称列表
const majorData = await getMajorNameList() const majorData = await getMajorNameList();
offcialZydmList.value = majorData.data || [] offcialZydmList.value = majorData.data || [];
getDataList() getDataList();
} catch (error) { } catch (error) {
console.log(error) console.log(error);
}
} };
}
// 修改开关 // 修改开关
const changeSm = async (row: any) => { const changeSm = async (row: any) => {
try { try {
let parmas={id:row.id,sm:row.sm} let parmas = { id: row.id, sm: row.sm };
await editQuickField(parmas) await editQuickField(parmas);
message.success('修改成功') message.success('修改成功');
} catch (error: any) { } catch (error: any) {
console.log(error) console.log(error);
}
} };
}
// 新增 / 修改 // 新增 / 修改
const addOrUpdateHandle = (row?: any) => { const addOrUpdateHandle = (row?: any) => {
nextTick(() => { nextTick(() => {
addOrUpdateRef.value?.init(row.id || null) addOrUpdateRef.value?.init(row.id || null);
}) });
} };
// 删除 // 删除
const deleteHandle = async (id: string) => { const deleteHandle = async (id: string) => {
try { try {
await messageBox.confirm('是否确认删除本条数据?请谨慎操作') await messageBox.confirm('是否确认删除本条数据?请谨慎操作');
await delObj(id) await delObj(id);
message.success('删除成功') message.success('删除成功');
getDataList() getDataList();
} catch { } catch {
// 用户取消 // 用户取消
} }
} };
// 重置查询 // 重置查询
const resetQuery = () => { const resetQuery = () => {
searchFormRef.value?.resetFields() searchFormRef.value?.resetFields();
queryForm.groupId = '' queryForm.groupId = '';
queryForm.deptCode = '' queryForm.deptCode = '';
queryForm.majorCode = '' queryForm.majorCode = '';
queryForm.majorName = '' queryForm.majorName = '';
queryForm.learnYear = '' queryForm.learnYear = '';
if (planList.value.length > 0) { if (planList.value.length > 0) {
queryForm.groupId = planList.value[0].id queryForm.groupId = planList.value[0].id;
} }
getDataList() getDataList();
} };
const exportLoading = ref(false);
const handleImportDialog = () => {
ImportRecruitInfoRef.value?.init("planMajor");
};
onMounted(() => { onMounted(() => {
init() init();
}) });
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped></style>
</style>