a
This commit is contained in:
@@ -294,14 +294,6 @@
|
||||
icon="Download"
|
||||
@click="handleExport()">名单导出
|
||||
</el-button>
|
||||
<!-- <el-button
|
||||
class="ml10"
|
||||
type="primary"
|
||||
plain
|
||||
icon="UploadFilled"
|
||||
v-auth="'recruit_send_img'"
|
||||
@click="handleSendImg()">图片同步
|
||||
</el-button> -->
|
||||
</div>
|
||||
</el-row>
|
||||
|
||||
@@ -637,23 +629,17 @@
|
||||
<!-- 支付二维码弹窗 -->
|
||||
<PayQrcodeDialog ref="payQrcodeDialogRef" @refresh="getDataList"></PayQrcodeDialog>
|
||||
|
||||
<!-- 延迟缴费弹窗 -->
|
||||
<DelayPayTimeDialog ref="delayPayTimeDialogRef" @refresh="getDataList"></DelayPayTimeDialog>
|
||||
|
||||
|
||||
<!-- 录取通知书弹窗 -->
|
||||
<AdmissionNoticeDialog ref="admissionNoticeDialogRef" @refresh="getDataList"></AdmissionNoticeDialog>
|
||||
|
||||
<DormFW ref="dormFWRef"></DormFW>
|
||||
<ShowMap ref="baiduMapRef"></ShowMap>
|
||||
<InterviewForm ref="interviewFormRef" @refresh="getDataList"></InterviewForm>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts" name="recruitstudentsignup">
|
||||
import { ref, reactive, onMounted, nextTick, defineAsyncComponent, watch } from 'vue'
|
||||
import { Edit, Check, DocumentChecked, Close, Switch, Tickets, Document, Upload, Warning, User, CircleCheck, CircleClose, Clock, WarningFilled } from '@element-plus/icons-vue'
|
||||
import { Edit, Check, DocumentChecked, Close, Switch, Tickets, Document, Warning, User, CircleCheck } from '@element-plus/icons-vue'
|
||||
import ClickableTag from '/@/components/ClickableTag/index.vue'
|
||||
import { useMessage, useMessageBox } from '/@/hooks/message'
|
||||
import { BasicTableProps, useTable } from '/@/hooks/table'
|
||||
@@ -661,20 +647,14 @@ import { auth } from '/@/utils/authFunction'
|
||||
import axios from 'axios'
|
||||
import { getList } from '/@/api/recruit/recruitstudentplangroup'
|
||||
import {
|
||||
delObj,
|
||||
exportZip,
|
||||
fetchList,
|
||||
leaveSchool,
|
||||
rePush as rePushApi,
|
||||
yjOut,
|
||||
oneClass,
|
||||
oneStuNo,
|
||||
tbStuWork,
|
||||
sendImg,
|
||||
pushCity as pushCityApi,
|
||||
resetSign as resetSignApi
|
||||
} from '/@/api/recruit/recruitstudentsignup'
|
||||
import { getLabelValue, getLabelValueByProps, getMajorLabelWithYears } from '/@/utils/dictLabel'
|
||||
import { getLabelValueByProps, getMajorLabelWithYears } from '/@/utils/dictLabel'
|
||||
import { getDeptList } from "/@/api/basic/basicclass";
|
||||
import { listPlanByCondition as planMajor } from "/@/api/recruit/recruitstudentplan";
|
||||
import { getDictsByTypes } from "/@/api/admin/dict";
|
||||
@@ -696,11 +676,8 @@ import { showLoading, hideLoading } from '/@/api/asset/loading'
|
||||
const TableForm = defineAsyncComponent(() => import('./detaiform.vue'))
|
||||
const MajorChange = defineAsyncComponent(() => import('./majorChange.vue'))
|
||||
const Update = defineAsyncComponent(() => import('./update.vue'))
|
||||
const DormFW = defineAsyncComponent(() => import('./dormFW.vue'))
|
||||
const ShowMap = defineAsyncComponent(() => import('./showMap.vue'))
|
||||
const InterviewForm = defineAsyncComponent(() => import('/@/views/recruit/recruitstudentsignup/interviewForm.vue'))
|
||||
const PayQrcodeDialog = defineAsyncComponent(() => import('./PayQrcodeDialog.vue'))
|
||||
const DelayPayTimeDialog = defineAsyncComponent(() => import('./DelayPayTimeDialog.vue'))
|
||||
const AdmissionNoticeDialog = defineAsyncComponent(() => import('./AdmissionNoticeDialog.vue'))
|
||||
const ActionDropdown = defineAsyncComponent(() => import('/@/components/tools/action-dropdown.vue'))
|
||||
|
||||
@@ -714,11 +691,8 @@ const searchFormRef = ref()
|
||||
const addOrUpdateRef = ref()
|
||||
const majorChangeRef = ref()
|
||||
const updateRef = ref()
|
||||
const dormFWRef = ref()
|
||||
const baiduMapRef = ref()
|
||||
const interviewFormRef = ref()
|
||||
const payQrcodeDialogRef = ref()
|
||||
const delayPayTimeDialogRef = ref()
|
||||
const admissionNoticeDialogRef = ref()
|
||||
|
||||
// 搜索表单显示状态
|
||||
@@ -727,7 +701,7 @@ const showSearch = ref(true)
|
||||
// 表单数据
|
||||
const dataForm = reactive({
|
||||
zlsh: '',
|
||||
groupId: '',
|
||||
groupId: '',
|
||||
deptCode: '',
|
||||
confirmedMajor: '',
|
||||
degreeOfEducation: '',
|
||||
@@ -738,13 +712,13 @@ const dataForm = reactive({
|
||||
isNewCity: '',
|
||||
startDate: '',
|
||||
endDate: '',
|
||||
lqStartDate: '',
|
||||
lqEndDate: '',
|
||||
lqStartDate: '',
|
||||
lqEndDate: '',
|
||||
paystatus: '',
|
||||
graPic: '',
|
||||
pushed: '',
|
||||
wishMajorOne: '',
|
||||
isTb: '',
|
||||
isTb: '',
|
||||
cityExamType: '',
|
||||
interview: '',
|
||||
type: '',
|
||||
@@ -834,60 +808,15 @@ const remoteTeacherByQuery = (query: string) => {
|
||||
teacherList.value = []
|
||||
})
|
||||
}, 200)
|
||||
}
|
||||
}
|
||||
|
||||
// 发送图片
|
||||
const handleSendImg = () => {
|
||||
messageBox.confirm('是否确认同步招生图片到市平台?请谨慎操作').then(() => {
|
||||
return sendImg()
|
||||
}).then(() => {
|
||||
message.success('同步图片请求已发起,请耐心等待')
|
||||
}).catch(() => {
|
||||
hideLoading()
|
||||
})
|
||||
}
|
||||
|
||||
// 同步学工
|
||||
const handleTbStuWork = () => {
|
||||
if (dataForm.groupId == '') {
|
||||
message.warning('招生计划不能为空')
|
||||
return
|
||||
}
|
||||
messageBox.confirm('是否确认同步学工?请谨慎操作').then(() => {
|
||||
showLoading()
|
||||
return tbStuWork(dataForm)
|
||||
}).then(() => {
|
||||
hideLoading()
|
||||
message.success('同步完成')
|
||||
}).catch(() => {
|
||||
hideLoading()
|
||||
})
|
||||
}
|
||||
|
||||
// 一键分配班级和学号
|
||||
const handleOneClassAndStuNo = () => {
|
||||
if (dataForm.groupId == '') {
|
||||
message.warning('招生计划不能为空')
|
||||
return
|
||||
}
|
||||
messageBox.confirm('是否确认一键分配班级和学号?请谨慎操作').then(() => {
|
||||
showLoading()
|
||||
return Promise.all([oneClass(dataForm), oneStuNo(dataForm)])
|
||||
}).then(() => {
|
||||
hideLoading()
|
||||
message.success('分配完成')
|
||||
}).catch(() => {
|
||||
hideLoading()
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
// 下载zip
|
||||
const downZip = () => {
|
||||
if (dataForm.groupId == '') {
|
||||
message.warning('招生计划不能为空')
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
showLoading()
|
||||
exportZip(dataForm).then(res => {
|
||||
hideLoading()
|
||||
@@ -905,45 +834,6 @@ const downZip = () => {
|
||||
})
|
||||
}
|
||||
|
||||
// 百度地图
|
||||
const baiduMap = (row: any) => {
|
||||
// 组件内部通过 v-model="visible" 控制显示
|
||||
nextTick(() => {
|
||||
baiduMapRef.value?.init(row)
|
||||
})
|
||||
}
|
||||
|
||||
// 设置宿舍
|
||||
const setDormFW = () => {
|
||||
// 组件内部通过 v-model="visible" 控制显示
|
||||
nextTick(() => {
|
||||
dormFWRef.value?.init()
|
||||
})
|
||||
}
|
||||
|
||||
// 一键判断是否超出住宿范围
|
||||
const handleYjOut = () => {
|
||||
if (dataForm.groupId == '') {
|
||||
message.warning('招生计划不能为空')
|
||||
return
|
||||
}
|
||||
messageBox.confirm('是否确认一键判断是否超出住宿范围?请谨慎操作').then(() => {
|
||||
return yjOut({ groupId: dataForm.groupId })
|
||||
}).then(() => {
|
||||
message.success('操作成功')
|
||||
getDataList()
|
||||
})
|
||||
}
|
||||
|
||||
// 导出审核
|
||||
const handleExportAudit = (type: number) => {
|
||||
if (dataForm.groupId == '') {
|
||||
message.warning('招生计划不能为空')
|
||||
return
|
||||
}
|
||||
downFile(type)
|
||||
}
|
||||
|
||||
// 导出Excel
|
||||
const exportExcel = (form: any, url: string) => {
|
||||
return axios({
|
||||
@@ -957,23 +847,6 @@ const exportExcel = (form: any, url: string) => {
|
||||
})
|
||||
}
|
||||
|
||||
// 导出文件
|
||||
const downFile = (type: number) => {
|
||||
dataForm.type = String(type)
|
||||
exportExcel(dataForm, '/recruit/recruitstudentsignup/exportExcel').then(res => {
|
||||
const blob = new Blob([res.data])
|
||||
const fileName = type == 1 ? '延迟缴费名单导出.xlsx' : '超时缴费名单导出.xlsx'
|
||||
const elink = document.createElement('a')
|
||||
elink.download = fileName
|
||||
elink.style.display = 'none'
|
||||
elink.href = URL.createObjectURL(blob)
|
||||
document.body.appendChild(elink)
|
||||
elink.click()
|
||||
URL.revokeObjectURL(elink.href)
|
||||
document.body.removeChild(elink)
|
||||
}).catch(() => {})
|
||||
}
|
||||
|
||||
// 导出
|
||||
const handleExport = () => {
|
||||
if (dataForm.groupId == '') {
|
||||
@@ -992,11 +865,6 @@ const handleExport = () => {
|
||||
document.body.removeChild(elink)
|
||||
}).catch(() => {})
|
||||
}
|
||||
// 去重
|
||||
const unique = (arr: any[]) => {
|
||||
const rese = new Map()
|
||||
return arr.filter((item) => !rese.has(item.username) && rese.set(item.username, 1))
|
||||
}
|
||||
|
||||
// 切换专业
|
||||
const chanMajor = () => {
|
||||
@@ -1091,18 +959,11 @@ const handlePushCity = (id: string) => {
|
||||
|
||||
// 重新推送
|
||||
const handleRePush = (row: any) => {
|
||||
// messageBox.confirm('是否确认重新推送本条数据?请谨慎操作').then(() => {
|
||||
// return rePushApi({ id: row.id })
|
||||
// }).then(() => {
|
||||
// message.success('推送成功')
|
||||
// getDataList()
|
||||
// })
|
||||
}
|
||||
|
||||
// 延迟缴费
|
||||
const delayPayTimeSet = (row: any) => {
|
||||
nextTick(() => {
|
||||
delayPayTimeDialogRef.value?.init(row)
|
||||
messageBox.confirm('是否确认重新推送本条数据?请谨慎操作').then(() => {
|
||||
return rePushApi({ id: row.id })
|
||||
}).then(() => {
|
||||
message.success('推送成功')
|
||||
getDataList()
|
||||
})
|
||||
}
|
||||
|
||||
@@ -1289,14 +1150,6 @@ onMounted(() => {
|
||||
|
||||
.major-icon {
|
||||
color: var(--el-color-primary);
|
||||
font-size: 14px;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.major-text {
|
||||
color: #303133;
|
||||
font-weight: 500;
|
||||
font-size: 13px;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1305,14 +1158,6 @@ onMounted(() => {
|
||||
font-size: 13px;
|
||||
}
|
||||
|
||||
// 面试结果样式
|
||||
.interview-cell {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
gap: 6px;
|
||||
}
|
||||
|
||||
// 面试详情弹窗样式
|
||||
.interview-detail-popover {
|
||||
.detail-title {
|
||||
@@ -1539,89 +1384,4 @@ onMounted(() => {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// 旧样式保留(如果其他地方还在使用)
|
||||
.material-check-cell {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 8px;
|
||||
padding: 4px 0;
|
||||
|
||||
.check-item {
|
||||
display: flex;
|
||||
align-items: flex-start;
|
||||
gap: 6px;
|
||||
line-height: 1.5;
|
||||
|
||||
.check-label {
|
||||
color: #606266;
|
||||
font-size: 12px;
|
||||
font-weight: 500;
|
||||
white-space: nowrap;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
:deep(.el-tag) {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
vertical-align: middle;
|
||||
gap: 4px;
|
||||
line-height: 1;
|
||||
|
||||
.tag-icon {
|
||||
font-size: 12px;
|
||||
vertical-align: middle;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.material-status {
|
||||
display: flex;
|
||||
flex-direction: row;
|
||||
flex-wrap: nowrap;
|
||||
gap: 6px;
|
||||
align-items: center;
|
||||
|
||||
.material-tag {
|
||||
margin: 0;
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.no-upload-text {
|
||||
color: #67c23a;
|
||||
font-size: 12px;
|
||||
white-space: nowrap;
|
||||
}
|
||||
}
|
||||
|
||||
.check-remark {
|
||||
margin-top: 4px;
|
||||
|
||||
.remark-content {
|
||||
display: flex;
|
||||
align-items: flex-start;
|
||||
gap: 4px;
|
||||
flex: 1;
|
||||
|
||||
.remark-icon {
|
||||
color: #f56c6c;
|
||||
font-size: 14px;
|
||||
flex-shrink: 0;
|
||||
margin-top: 2px;
|
||||
}
|
||||
|
||||
.remark-text {
|
||||
color: #f56c6c;
|
||||
font-size: 12px;
|
||||
line-height: 1.5;
|
||||
display: inline-block;
|
||||
max-width: 200px;
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
white-space: nowrap;
|
||||
vertical-align: top;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
</style>
|
||||
|
||||
Reference in New Issue
Block a user