1
This commit is contained in:
10
src/api/recruit/recruitfile.ts
Normal file
10
src/api/recruit/recruitfile.ts
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
import request from '/@/utils/request';
|
||||||
|
|
||||||
|
|
||||||
|
export const makeExportTeacherInfoBySelfTask = (data?: any) => {
|
||||||
|
return request({
|
||||||
|
url: '/recruit/file/exportPreStuSuccess',
|
||||||
|
method: 'post',
|
||||||
|
data: data,
|
||||||
|
});
|
||||||
|
};
|
||||||
@@ -1,124 +0,0 @@
|
|||||||
<template>
|
|
||||||
<el-dialog :title="form.id ? '编辑' : '新增'" v-model="visible"
|
|
||||||
:close-on-click-modal="false" draggable>
|
|
||||||
<el-form ref="dataFormRef" :model="form" :rules="dataRules" formDialogRef label-width="90px" v-loading="loading">
|
|
||||||
<el-row :gutter="24">
|
|
||||||
<el-col :span="12" class="mb20">
|
|
||||||
<el-form-item label="学校代码" prop="schoolCode">
|
|
||||||
<el-input v-model="form.schoolCode" placeholder="请输入学校代码"/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="12" class="mb20">
|
|
||||||
<el-form-item label="原名称" prop="oldName">
|
|
||||||
<el-input v-model="form.oldName" placeholder="请输入原名称"/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="12" class="mb20">
|
|
||||||
<el-form-item label="新名称" prop="newName">
|
|
||||||
<el-input v-model="form.newName" placeholder="请输入新名称"/>
|
|
||||||
</el-form-item>
|
|
||||||
</el-col>
|
|
||||||
</el-row>
|
|
||||||
</el-form>
|
|
||||||
<template #footer>
|
|
||||||
<span class="dialog-footer">
|
|
||||||
<el-button @click="visible = false">取 消</el-button>
|
|
||||||
<el-button type="primary" @click="onSubmit" :disabled="loading">确 认</el-button>
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup lang="ts" name="RecruitSchoolHistoryDialog">
|
|
||||||
// ========== 1. 导入语句 ==========
|
|
||||||
import { useDict } from '/@/hooks/dict';
|
|
||||||
import { rule } from '/@/utils/validate';
|
|
||||||
import { useMessage } from "/@/hooks/message";
|
|
||||||
import { getObj, addObj, putObj, validateExist } from '/@/api/recruit/recruitSchoolHistory';
|
|
||||||
|
|
||||||
// ========== 2. 组件定义 ==========
|
|
||||||
// 定义组件事件
|
|
||||||
const emit = defineEmits(['refresh']);
|
|
||||||
|
|
||||||
// ========== 3. 响应式数据定义 ==========
|
|
||||||
// 基础响应式变量
|
|
||||||
const dataFormRef = ref(); // 表单引用
|
|
||||||
const visible = ref(false); // 弹窗显示状态
|
|
||||||
const loading = ref(false); // 加载状态
|
|
||||||
|
|
||||||
// 表单数据对象
|
|
||||||
const form = reactive({
|
|
||||||
id: '', // 主键
|
|
||||||
schoolCode: '', // 学校代码
|
|
||||||
oldName: '', // 原名称
|
|
||||||
newName: '', // 新名称
|
|
||||||
});
|
|
||||||
|
|
||||||
// ========== 4. 字典数据处理 ==========
|
|
||||||
|
|
||||||
// ========== 5. 表单校验规则 ==========
|
|
||||||
const dataRules = ref({
|
|
||||||
});
|
|
||||||
|
|
||||||
// ========== 6. 方法定义 ==========
|
|
||||||
// 获取详情数据
|
|
||||||
const getRecruitSchoolHistoryData = async (id: string) => {
|
|
||||||
try {
|
|
||||||
loading.value = true;
|
|
||||||
const { data } = await getObj({ id: id });
|
|
||||||
// 直接将第一条数据赋值给表单
|
|
||||||
Object.assign(form, data[0]);
|
|
||||||
} catch (error) {
|
|
||||||
useMessage().error('获取数据失败');
|
|
||||||
} finally {
|
|
||||||
loading.value = false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 打开弹窗方法
|
|
||||||
const openDialog = (id: string) => {
|
|
||||||
visible.value = true;
|
|
||||||
form.id = '';
|
|
||||||
|
|
||||||
// 重置表单数据
|
|
||||||
nextTick(() => {
|
|
||||||
dataFormRef.value?.resetFields();
|
|
||||||
});
|
|
||||||
|
|
||||||
// 获取RecruitSchoolHistory信息
|
|
||||||
if (id) {
|
|
||||||
form.id = id;
|
|
||||||
getRecruitSchoolHistoryData(id);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// 提交表单方法
|
|
||||||
const onSubmit = async () => {
|
|
||||||
loading.value = true; // 防止重复提交
|
|
||||||
|
|
||||||
// 表单校验
|
|
||||||
const valid = await dataFormRef.value.validate().catch(() => {});
|
|
||||||
if (!valid) {
|
|
||||||
loading.value = false;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
// 根据是否有ID判断是新增还是修改
|
|
||||||
form.id ? await putObj(form) : await addObj(form);
|
|
||||||
useMessage().success(form.id ? '修改成功' : '添加成功');
|
|
||||||
visible.value = false;
|
|
||||||
emit('refresh'); // 通知父组件刷新列表
|
|
||||||
} catch (err: any) {
|
|
||||||
useMessage().error(err.msg);
|
|
||||||
} finally {
|
|
||||||
loading.value = false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// ========== 7. 对外暴露 ==========
|
|
||||||
// 暴露方法给父组件
|
|
||||||
defineExpose({
|
|
||||||
openDialog
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
@@ -1,213 +0,0 @@
|
|||||||
<template>
|
|
||||||
<div class="layout-padding">
|
|
||||||
<div class="layout-padding-auto layout-padding-view">
|
|
||||||
|
|
||||||
<!-- 操作按钮区域 -->
|
|
||||||
<el-row>
|
|
||||||
<div class="mb8" style="width: 100%">
|
|
||||||
<el-button
|
|
||||||
icon="folder-add"
|
|
||||||
type="primary"
|
|
||||||
class="ml10"
|
|
||||||
@click="formDialogRef.openDialog()"
|
|
||||||
v-auth="'recruit_recruitSchoolHistory_add'"
|
|
||||||
>
|
|
||||||
新增
|
|
||||||
</el-button>
|
|
||||||
<el-button
|
|
||||||
plain
|
|
||||||
icon="upload-filled"
|
|
||||||
type="primary"
|
|
||||||
class="ml10"
|
|
||||||
@click="excelUploadRef.show()"
|
|
||||||
v-auth="'recruit_recruitSchoolHistory_add'"
|
|
||||||
>
|
|
||||||
导入
|
|
||||||
</el-button>
|
|
||||||
<el-button
|
|
||||||
plain
|
|
||||||
:disabled="multiple"
|
|
||||||
icon="Delete"
|
|
||||||
type="primary"
|
|
||||||
v-auth="'recruit_recruitSchoolHistory_del'"
|
|
||||||
@click="handleDelete(selectObjs)"
|
|
||||||
>
|
|
||||||
删除
|
|
||||||
</el-button>
|
|
||||||
<right-toolbar
|
|
||||||
v-model:showSearch="showSearch"
|
|
||||||
:export="'recruit_recruitSchoolHistory_export'"
|
|
||||||
@exportExcel="exportExcel"
|
|
||||||
class="ml10 mr20"
|
|
||||||
style="float: right;"
|
|
||||||
@queryTable="getDataList"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</el-row>
|
|
||||||
|
|
||||||
<!-- 数据表格区域 -->
|
|
||||||
<el-table
|
|
||||||
:data="state.dataList"
|
|
||||||
v-loading="state.loading"
|
|
||||||
border
|
|
||||||
:cell-style="tableStyle.cellStyle"
|
|
||||||
:header-cell-style="tableStyle.headerCellStyle"
|
|
||||||
@selection-change="selectionChangHandle"
|
|
||||||
@sort-change="sortChangeHandle"
|
|
||||||
>
|
|
||||||
<el-table-column type="selection" width="40" align="center" />
|
|
||||||
<el-table-column type="index" label="#" width="40" />
|
|
||||||
<el-table-column
|
|
||||||
prop="schoolCode"
|
|
||||||
label="学校代码"
|
|
||||||
show-overflow-tooltip
|
|
||||||
/>
|
|
||||||
<el-table-column
|
|
||||||
prop="oldName"
|
|
||||||
label="原名称"
|
|
||||||
show-overflow-tooltip
|
|
||||||
/>
|
|
||||||
<el-table-column
|
|
||||||
prop="newName"
|
|
||||||
label="新名称"
|
|
||||||
show-overflow-tooltip
|
|
||||||
/>
|
|
||||||
<el-table-column label="操作" width="150">
|
|
||||||
<template #default="scope">
|
|
||||||
<el-button
|
|
||||||
icon="edit-pen"
|
|
||||||
text
|
|
||||||
type="primary"
|
|
||||||
v-auth="'recruit_recruitSchoolHistory_edit'"
|
|
||||||
@click="formDialogRef.openDialog(scope.row.id)"
|
|
||||||
>
|
|
||||||
编辑
|
|
||||||
</el-button>
|
|
||||||
<el-button
|
|
||||||
icon="delete"
|
|
||||||
text
|
|
||||||
type="primary"
|
|
||||||
v-auth="'recruit_recruitSchoolHistory_del'"
|
|
||||||
@click="handleDelete([scope.row.id])"
|
|
||||||
>
|
|
||||||
删除
|
|
||||||
</el-button>
|
|
||||||
</template>
|
|
||||||
</el-table-column>
|
|
||||||
</el-table>
|
|
||||||
|
|
||||||
<!-- 分页组件 -->
|
|
||||||
<pagination
|
|
||||||
@size-change="sizeChangeHandle"
|
|
||||||
@current-change="currentChangeHandle"
|
|
||||||
v-bind="state.pagination"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<!-- 编辑、新增弹窗 -->
|
|
||||||
<form-dialog ref="formDialogRef" @refresh="getDataList(false)" />
|
|
||||||
|
|
||||||
<!-- 导入excel弹窗 (需要在 upms-biz/resources/file 下维护模板) -->
|
|
||||||
<upload-excel
|
|
||||||
ref="excelUploadRef"
|
|
||||||
title="导入"
|
|
||||||
url="/recruit/recruitSchoolHistory/import"
|
|
||||||
temp-url="/admin/sys-file/local/file/recruitSchoolHistory.xlsx"
|
|
||||||
@refreshDataList="getDataList"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<script setup lang="ts" name="systemRecruitSchoolHistory">
|
|
||||||
// ========== 导入声明 ==========
|
|
||||||
import { BasicTableProps, useTable } from "/@/hooks/table";
|
|
||||||
import { fetchList, delObjs } from "/@/api/recruit/recruitSchoolHistory";
|
|
||||||
import { useMessage, useMessageBox } from "/@/hooks/message";
|
|
||||||
import { useDict } from '/@/hooks/dict';
|
|
||||||
|
|
||||||
// ========== 组件声明 ==========
|
|
||||||
// 异步加载表单弹窗组件
|
|
||||||
const FormDialog = defineAsyncComponent(() => import('./form.vue'));
|
|
||||||
|
|
||||||
// ========== 字典数据 ==========
|
|
||||||
|
|
||||||
// ========== 组件引用 ==========
|
|
||||||
const formDialogRef = ref(); // 表单弹窗引用
|
|
||||||
const excelUploadRef = ref(); // Excel上传弹窗引用
|
|
||||||
const queryRef = ref(); // 查询表单引用
|
|
||||||
|
|
||||||
// ========== 响应式数据 ==========
|
|
||||||
const showSearch = ref(true); // 是否显示搜索区域
|
|
||||||
const selectObjs = ref([]) as any; // 表格多选数据
|
|
||||||
const multiple = ref(true); // 是否多选
|
|
||||||
|
|
||||||
// ========== 表格状态 ==========
|
|
||||||
const state: BasicTableProps = reactive<BasicTableProps>({
|
|
||||||
queryForm: {}, // 查询参数
|
|
||||||
pageList: fetchList // 分页查询方法
|
|
||||||
});
|
|
||||||
|
|
||||||
// ========== Hook引用 ==========
|
|
||||||
// 表格相关Hook
|
|
||||||
const {
|
|
||||||
getDataList,
|
|
||||||
currentChangeHandle,
|
|
||||||
sizeChangeHandle,
|
|
||||||
sortChangeHandle,
|
|
||||||
downBlobFile,
|
|
||||||
tableStyle
|
|
||||||
} = useTable(state);
|
|
||||||
|
|
||||||
// ========== 方法定义 ==========
|
|
||||||
/**
|
|
||||||
* 重置查询条件
|
|
||||||
*/
|
|
||||||
const resetQuery = () => {
|
|
||||||
// 清空搜索条件
|
|
||||||
queryRef.value?.resetFields();
|
|
||||||
// 清空多选
|
|
||||||
selectObjs.value = [];
|
|
||||||
// 重新查询
|
|
||||||
getDataList();
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 导出Excel文件
|
|
||||||
*/
|
|
||||||
const exportExcel = () => {
|
|
||||||
downBlobFile(
|
|
||||||
'/recruit/recruitSchoolHistory/export',
|
|
||||||
Object.assign(state.queryForm, { ids: selectObjs }),
|
|
||||||
'recruitSchoolHistory.xlsx'
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 表格多选事件处理
|
|
||||||
* @param objs 选中的数据行
|
|
||||||
*/
|
|
||||||
const selectionChangHandle = (objs: { id: string }[]) => {
|
|
||||||
selectObjs.value = objs.map(({ id }) => id);
|
|
||||||
multiple.value = !objs.length;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 删除数据处理
|
|
||||||
* @param ids 要删除的数据ID数组
|
|
||||||
*/
|
|
||||||
const handleDelete = async (ids: string[]) => {
|
|
||||||
try {
|
|
||||||
await useMessageBox().confirm('此操作将永久删除');
|
|
||||||
} catch {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
await delObjs(ids);
|
|
||||||
getDataList();
|
|
||||||
useMessage().success('删除成功');
|
|
||||||
} catch (err: any) {
|
|
||||||
useMessage().error(err.msg);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
@@ -92,7 +92,8 @@
|
|||||||
>
|
>
|
||||||
新增
|
新增
|
||||||
</el-button>
|
</el-button>
|
||||||
<el-button
|
<el-button
|
||||||
|
v-auth="'pre_stu_success_export'"
|
||||||
type="warning"
|
type="warning"
|
||||||
plain
|
plain
|
||||||
icon="Download"
|
icon="Download"
|
||||||
@@ -213,6 +214,7 @@ import { getList } from '/@/api/recruit/recruitstudentplangroup'
|
|||||||
import { listcz } from '/@/api/recruit/recruitstudentplan'
|
import { listcz } from '/@/api/recruit/recruitstudentplan'
|
||||||
import { queryByGroupId as schoolListApi} from '/@/api/recruit/recruitstudentschool'
|
import { queryByGroupId as schoolListApi} from '/@/api/recruit/recruitstudentschool'
|
||||||
import { getDeptListByLevelTwo } from '/@/api/basic/basicdept'
|
import { getDeptListByLevelTwo } from '/@/api/basic/basicdept'
|
||||||
|
import {makeExportTeacherInfoBySelfTask} from '/@/api/recruit/recruitfile'
|
||||||
|
|
||||||
const PreExamPeopleIndex = defineAsyncComponent(() => import('@/views/recruit/recruitPreexamPeople/index.vue'));
|
const PreExamPeopleIndex = defineAsyncComponent(() => import('@/views/recruit/recruitPreexamPeople/index.vue'));
|
||||||
|
|
||||||
@@ -375,18 +377,10 @@ const resetQuery = () => {
|
|||||||
|
|
||||||
// 导出
|
// 导出
|
||||||
const dataExportHandle = async () => {
|
const dataExportHandle = async () => {
|
||||||
try {
|
makeExportTeacherInfoBySelfTask(queryForm).then((res:any)=>{
|
||||||
exportLoading.value = true
|
message.success('导出后台执行中,请稍后查看下载任务')
|
||||||
await downBlobFile(
|
})
|
||||||
'/recruit/recruitprestudent/export',
|
|
||||||
queryForm,
|
|
||||||
'预登记导出.xls'
|
|
||||||
)
|
|
||||||
} catch (error: any) {
|
|
||||||
message.error(error.msg || '导出失败')
|
|
||||||
} finally {
|
|
||||||
exportLoading.value = false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user