flat: 个人招工审核

This commit is contained in:
Apcallover
2024-03-06 16:40:00 +08:00
parent f2b547e9e4
commit a309075659
4 changed files with 162 additions and 184 deletions

33
src/api/manage/recruit.js Normal file
View File

@@ -0,0 +1,33 @@
import request from '@/router/axios';
export const getList =
(current, size, params, tenantId) => {
return request({
url: '/api/jobslink-api/user/userrecruit/list',
method: 'get',
params: {
...params,
current,
size,
tenantId,
},
})
}
export const getDetail = (params) => {
return request({
url: "/api/jobslink-api/user/userrecruit/detail",
method: "get",
params,
});
};
export const review = (params) => {
return request({
url: "/api/jobslink-api/user/userrecruit/approval",
method: "post",
data: params,
});
};

View File

@@ -352,3 +352,9 @@ export const serviceType = [
value: 2, value: 2,
} }
]; ];
export const recruitStatus = [
{ value: 9, label: "驳回" },
{ value: 1, label: "未审核" },
{ value: 0, label: "通过" },
];

View File

@@ -1,78 +1,78 @@
<template> <template>
<basic-container> <basic-container>
<!--搜索栏--> <!--搜索栏-->
<el-form <!-- <el-form-->
size="small" <!-- size="small"-->
label-position="right" <!-- label-position="right"-->
style="padding-left: 10px; padding-right: 10px" <!-- style="padding-left: 10px; padding-right: 10px"-->
:inline="true" <!-- :inline="true"-->
> <!-- >-->
<el-row :span="24"> <!-- <el-row :span="24">-->
<el-form-item label="社区街道名称:"> <!-- <el-form-item label="社区街道名称:">-->
<el-input <!-- <el-input-->
v-model="query.companyName" <!-- v-model="query.companyName"-->
placeholder="社区街道名称" <!-- placeholder="社区街道名称"-->
clearable <!-- clearable-->
></el-input> <!-- ></el-input>-->
</el-form-item> <!-- </el-form-item>-->
<el-form-item label="岗位编码:"> <!-- <el-form-item label="岗位编码:">-->
<el-input <!-- <el-input-->
v-model="query.missionNo" <!-- v-model="query.missionNo"-->
placeholder="岗位编码" <!-- placeholder="岗位编码"-->
clearable <!-- clearable-->
></el-input> <!-- ></el-input>-->
</el-form-item> <!-- </el-form-item>-->
<el-form-item label="岗位标题:"> <!-- <el-form-item label="岗位标题:">-->
<el-input <!-- <el-input-->
v-model="query.jobName" <!-- v-model="query.jobName"-->
placeholder="岗位标题" <!-- placeholder="岗位标题"-->
clearable <!-- clearable-->
></el-input> <!-- ></el-input>-->
</el-form-item> <!-- </el-form-item>-->
<!-- <el-form-item>--> <!--&lt;!&ndash; <el-form-item>&ndash;&gt;-->
<!-- <el-select v-model="query.type" placeholder="请选择搜索时间类型">--> <!--&lt;!&ndash; <el-select v-model="query.type" placeholder="请选择搜索时间类型">&ndash;&gt;-->
<!-- <el-option label="岗位开始日期" :value="0"></el-option>--> <!--&lt;!&ndash; <el-option label="岗位开始日期" :value="0"></el-option>&ndash;&gt;-->
<!-- <el-option label="岗位结束日期" :value="2"></el-option>--> <!--&lt;!&ndash; <el-option label="岗位结束日期" :value="2"></el-option>&ndash;&gt;-->
<!-- &lt;!&ndash; <el-option label="报名截止日期" :value="3"></el-option> &ndash;&gt;--> <!--&lt;!&ndash; &lt;!&ndash; <el-option label="报名截止日期" :value="3"></el-option> &ndash;&gt;&ndash;&gt;-->
<!--&lt;!&ndash; </el-select>&ndash;&gt;-->
<!--&lt;!&ndash; </el-form-item>&ndash;&gt;-->
<!-- <el-form-item label="日期范围:">-->
<!-- <el-date-picker-->
<!-- v-model="query.time"-->
<!-- type="daterange"-->
<!-- range-separator="至"-->
<!-- start-placeholder="开始日期"-->
<!-- end-placeholder="结束日期"-->
<!-- value-format="yyyy-MM-dd"-->
<!-- >-->
<!-- </el-date-picker>-->
<!-- </el-form-item>-->
<!--&lt;!&ndash; <tool-tip></tool-tip>&ndash;&gt;-->
<!-- <br>-->
<!-- <el-form-item label="岗位状态:">-->
<!-- <el-select v-model="query.reviewState">-->
<!-- <el-option-->
<!-- v-for="(item, index) in recruitStatus"-->
<!-- :key="index"-->
<!-- :label="item.label"-->
<!-- :value="item.value"-->
<!-- ></el-option>-->
<!-- </el-select>--> <!-- </el-select>-->
<!-- </el-form-item>--> <!-- </el-form-item>-->
<el-form-item label="日期范围:"> <!-- <div class="searchBtn">-->
<el-date-picker <!-- <el-button-->
v-model="query.time" <!-- type="primary"-->
type="daterange" <!-- size="small"-->
range-separator="" <!-- icon="el-icon-search"-->
start-placeholder="开始日期" <!-- @click="searchChange1"-->
end-placeholder="结束日期" <!-- > </el-button-->
value-format="yyyy-MM-dd" <!-- >-->
> <!-- <el-button size="small" icon="el-icon-delete" @click="searchReset1"-->
</el-date-picker> <!-- >清 空</el-button-->
</el-form-item> <!-- >-->
<!-- <tool-tip></tool-tip>--> <!-- </div>-->
<br> <!-- </el-row>-->
<el-form-item label="岗位状态:"> <!-- </el-form>-->
<el-select v-model="query.jobStatus">
<el-option
v-for="(item, index) in option.mStatusList"
:key="index"
:label="item.label"
:value="item.value"
></el-option>
</el-select>
</el-form-item>
<div class="searchBtn">
<el-button
type="primary"
size="small"
icon="el-icon-search"
@click="searchChange1"
> </el-button
>
<el-button size="small" icon="el-icon-delete" @click="searchReset1"
> </el-button
>
</div>
</el-row>
</el-form>
<!--搜索--> <!--搜索-->
<avue-crud <avue-crud
:option="option" :option="option"
@@ -94,20 +94,6 @@
@refresh-change="refreshChange" @refresh-change="refreshChange"
@on-load="onLoad" @on-load="onLoad"
> >
<template slot="menuLeft">
<el-button
v-if="vaildData(permission.manage_mission_check, false)"
size="small"
@click.stop="handleCheck"
type="primary"
>审核</el-button
>
</template>
<template slot="menuRight">
<el-button size="small" @click.stop="downRecords" type="primary"
>导出</el-button
>
</template>
<template slot-scope="{ row }" slot="menu"> <template slot-scope="{ row }" slot="menu">
<el-button <el-button
type="text" type="text"
@@ -117,34 +103,50 @@
>详情</el-button >详情</el-button
> >
<el-button <el-button
v-if="vaildData(permission.manage_mission_check, false) && row.reviewState === 1"
type="text" type="text"
size="small" size="small"
@click.stop="rowZPView(row)" @click.stop="handleCheck(row)"
v-if="vaildData(permission.manage_mission_zpview, false)" >审核</el-button
>报名详情</el-button
> >
</template> </template>
</avue-crud> </avue-crud>
<el-drawer title="详情" :visible.sync="viewDrawer" size="60%"> <el-drawer title="详情" :visible.sync="viewDrawer" size="60%">
<post-view :model="view"></post-view> <post-view :model="view"></post-view>
</el-drawer> </el-drawer>
<zp-view ref="zpView"></zp-view> <el-dialog
<wage-view ref="wageView"></wage-view> title="审核"
:visible.sync="centerDialogVisible"
width="30%"
append-to-body
center>
<span>请核对招聘信息后再进行审核通过</span>
<span slot="footer" class="dialog-footer">
<el-button @click="centerDialogVisible = false"> </el-button>
<el-button type="warning" @click="handelAuditing(0)">不通过</el-button>
<el-button type="primary" @click="handelAuditing(9)"> </el-button>
</span>
</el-dialog>
</basic-container> </basic-container>
</template> </template>
<script> <script>
import { import {
getList, // getList,
review, // review,
complet, complet,
getDetail, // getDetail,
download, download,
} from "@/api/workstation/post"; } from "@/api/workstation/post";
import {
getList,
getDetail,
review
} from '@/api/manage/recruit'
import { mapGetters } from "vuex"; import { mapGetters } from "vuex";
import postView from "@/views/util/post-view.vue"; import postView from "@/views/util/post-view.vue";
import zpView from "./zpView.vue"; import zpView from "./zpView.vue";
import { companyPostState, wageUnitCategoryState } from "@/common/dic"; import { recruitStatus, wageUnitCategoryState} from "@/common/dic";
import { calcDate } from "@/util/date"; import { calcDate } from "@/util/date";
import { Message } from "element-ui"; import { Message } from "element-ui";
import lodash from "lodash"; import lodash from "lodash";
@@ -162,6 +164,7 @@ export default {
name: "manage_mission", name: "manage_mission",
data() { data() {
return { return {
recruitStatus,
view: {}, view: {},
form: {}, form: {},
selectionList: [], selectionList: [],
@@ -193,7 +196,7 @@ export default {
searchMenuSpan: 5, searchMenuSpan: 5,
menuWidth: 270, menuWidth: 270,
border: true, border: true,
selection: true, selection: false,
viewBtn: false, viewBtn: false,
addBtn: false, addBtn: false,
editBtn: false, editBtn: false,
@@ -201,7 +204,7 @@ export default {
dialogClickModal: false, dialogClickModal: false,
dialogType: "drawer", dialogType: "drawer",
dialogFullscreen: true, dialogFullscreen: true,
mStatusList: companyPostState, mStatusList: recruitStatus,
column: [ column: [
{ {
label: "社区街道名称", label: "社区街道名称",
@@ -226,22 +229,6 @@ export default {
display: false, display: false,
minWidth: 70, minWidth: 70,
}, },
{
label: "申请人数",
prop: "applyNum",
search: false,
searchSpan: 1,
display: false,
minWidth: 70,
},
{
label: "确认人数",
prop: "applyPassNum",
search: false,
searchSpan: 1,
display: false,
minWidth: 70,
},
{ {
label: "岗位时长", label: "岗位时长",
prop: "missionDuration", prop: "missionDuration",
@@ -304,21 +291,19 @@ export default {
hide: true, hide: true,
}, },
{ {
label: "岗位状态", label: "审核状态",
type: "select", type: "reviewState",
prop: "jobStatus", prop: "reviewState",
dicData: companyPostState, dicData: recruitStatus,
display: false, display: false,
span: 24, span: 24,
width: 80, width: 80,
}, },
// {
// label:"备注",
// prop:"jobDescription"
// }
], ],
}, },
data: [], data: [],
centerDialogVisible: false,
AuditingData: null,
}; };
}, },
computed: { computed: {
@@ -344,17 +329,11 @@ export default {
this.onLoad(this.page, this.query); this.onLoad(this.page, this.query);
}, },
rowView(row) { rowView(row) {
getDetail(row.missionNo).then((resp) => { getDetail({id: row.id, jobType: row.jobType}).then((resp) => {
this.viewDrawer = true; this.viewDrawer = true;
this.view = resp.data.data; this.view = resp.data.data;
}); });
}, },
rowZPView(row) {
this.$refs.zpView.open(row.missionNo);
},
handleWageView(row) {
this.$refs.wageView.open(row.missionNo);
},
searchReset() { searchReset() {
this.query = {}; this.query = {};
this.onLoad(this.page); this.onLoad(this.page);
@@ -439,67 +418,27 @@ export default {
handleDelay(row) { handleDelay(row) {
this.$refs.delay.open(row.missionNo); this.$refs.delay.open(row.missionNo);
}, },
handleCheck() { async handelAuditing(type) {
if (this.ids.length < 1) { const {id, reviewState, jobType} = this.AuditingData
message({ let resData = await review({id, reviewState: type, jobType})
type: "warning", this.AuditingData = null
message: "请至少选择一条数据", this.centerDialogVisible = false
}); if(resData.data.code === 200) {
return;
}
let idList = [];
for (let i = 0; i < this.ids.length; i++) {
this.data.forEach((ele) => {
if (ele.jobStatus == 1 && ele.id == this.ids[i]) {
idList.push(ele.id);
}
});
}
if (idList.length == 0) {
this.$message.error("只能驳回【招聘中】的任务");
} else {
let h = this.$createElement;
this.$prompt(
h("p", { style: "color: #F56C6C" }, "一旦驳回无法进行后续操作"),
"您确定要驳回此任务吗?",
{
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning",
center: true,
inputType: "textarea",
inputPlaceholder: "备注驳回原因",
}
)
.then(({ value }) => {
this.loading = true;
review(idList.join(","), value)
.then(() => {
this.loading = false;
this.onLoad(this.page, this.params);
this.$message({ this.$message({
type: "success", type: "success",
message: "操作成功!", message: "审核成功!",
}); });
}) } else {
.catch(() => { message({
this.loading = false; type: "warning",
message: "审核失败",
}); });
})
.catch(() => {});
} }
}, },
downRecords() { handleCheck(row) {
if (this.query.time) { this.centerDialogVisible = true
this.query.stime = this.query.time[0]; this.AuditingData = row
this.query.etime = this.query.time[1];
// delete this.query.time;
}
window.open(download(this.query));
}, },
}, },
}; };
</script> </script>

View File

@@ -23,10 +23,10 @@ module.exports = {
port: 1888, port: 1888,
proxy: { proxy: {
"/api": { "/api": {
target: 'http://localhost:8000', // 本地服务接口地址 // target: 'http://localhost:8000', // 本地服务接口地址
// target: "http://39.98.184.58:8000", // 阿里云后台地址 // target: "http://39.98.184.58:8000", // 阿里云后台地址
// target: "http://192.168.3.108:8000", // 本地 // target: "http://192.168.3.108:8000", // 本地
// target: 'http://192.168.3.111:8000', target: 'http://192.168.3.111:8000',
ws: true, ws: true,
changeOrigin: true, changeOrigin: true,
pathRewrite: { pathRewrite: {