2024-08-07 09:34:41 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<el-drawer size="100%" append-to-body title="推送服务" :visible.sync="viewDrawer">
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<div class="push-header">
|
|
|
|
|
|
<div>
|
|
|
|
|
|
<el-button type="primary" size="small" @click="changeTabs(0)">匹配政策</el-button>
|
|
|
|
|
|
<el-button type="primary" @click="changeTabs(1)" size="small">匹配岗位</el-button>
|
|
|
|
|
|
<el-input style="width: 300px; margin-left: 15px" placeholder="搜索岗位" v-show="rightTabs === 1" size="small"
|
|
|
|
|
|
prefix-icon="el-icon-search"
|
|
|
|
|
|
@input="searchInputChange" v-model="searchInput" clearable>
|
|
|
|
|
|
</el-input>
|
|
|
|
|
|
</div>
|
2025-11-03 16:53:20 +08:00
|
|
|
|
<div>
|
|
|
|
|
|
<el-button type="primary" style="width: 80px" size="small" @click="informationPush">
|
|
|
|
|
|
推送信息
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
<el-button type="primary" style="width: 80px" size="small" :disabled="pushState" @click="onSubmit">
|
|
|
|
|
|
{{ pushState ? '推送中...' : rightTabs ? '推送岗位' : '推送政策' }}
|
|
|
|
|
|
</el-button>
|
|
|
|
|
|
</div>
|
2024-08-07 09:34:41 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
<div class="content-right relative">
|
|
|
|
|
|
<avue-crud height="900" ref="crud2" :data="rightDataList"
|
|
|
|
|
|
:option="rightTabs ? rightPostOptions : rightPolicyOptions" :page.sync="rightPages"
|
|
|
|
|
|
@current-change="rightCurrentPageChange" @size-change="rightSizePageChange"
|
|
|
|
|
|
@selection-change="rightSelectionChange">
|
|
|
|
|
|
<template slot="labelName" slot-scope="{row}">
|
|
|
|
|
|
<TextTooltip :content="row.labelName" length="40"></TextTooltip>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<template slot="jobDescription" slot-scope="{row}">
|
|
|
|
|
|
<TextTooltip :content="row.jobDescription" length="40"></TextTooltip>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<template slot="address" slot-scope="{row}">
|
|
|
|
|
|
<TextTooltip :content="row.address" length="40"></TextTooltip>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</avue-crud>
|
|
|
|
|
|
<CustomLoading :visible="rightLoading" size="largeXXL" loading-text="智能分析匹配中...">
|
|
|
|
|
|
<div class="loading-box">
|
|
|
|
|
|
<div class="row-loading">
|
|
|
|
|
|
<span>结构化数据匹配:地理位置、学历、薪资要求</span>
|
|
|
|
|
|
<img v-if="progress < 1" class="imgcorrect" src="/img/correct1.png">
|
|
|
|
|
|
<img v-else class="imgcorrect" src="/img/correct2.png">
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="row-loading">
|
|
|
|
|
|
<span>非结构化数据:工作经历和简历、工作岗位和招聘岗位 相似度计算</span>
|
|
|
|
|
|
<img v-if="progress < 2" class="imgcorrect" src="/img/correct1.png">
|
|
|
|
|
|
<img v-else class="imgcorrect" src="/img/correct2.png">
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</CustomLoading>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</el-drawer>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
import {
|
|
|
|
|
|
getListByids,
|
|
|
|
|
|
getSearchAll,
|
|
|
|
|
|
getSearchAllByUserId,
|
|
|
|
|
|
pushPolicyUserServe,
|
|
|
|
|
|
pushPostUserServe,
|
2025-11-03 16:53:20 +08:00
|
|
|
|
getListAllByPolicy, phoneUpdate,
|
|
|
|
|
|
getMsgContent,
|
|
|
|
|
|
pushMsg
|
2024-08-07 09:34:41 +08:00
|
|
|
|
} from "@/api/tenant/serve.js";
|
|
|
|
|
|
import TextTooltip from "@/components/text-tooltip/index.vue";
|
|
|
|
|
|
import {debounce} from '@/util/util'
|
|
|
|
|
|
import {DateTime} from "@/util/dateTime";
|
|
|
|
|
|
import CustomLoading from "@/components/Custom-Loading/index.vue";
|
|
|
|
|
|
|
|
|
|
|
|
const pages = {pagerCount: 3, total: 0, size: 10, currentPage: 1}
|
|
|
|
|
|
const baseOptions = {
|
|
|
|
|
|
size: 'medium',
|
|
|
|
|
|
dateBtn: false,
|
|
|
|
|
|
addBtn: false,
|
|
|
|
|
|
editBtn: false,
|
|
|
|
|
|
delBtn: false,
|
|
|
|
|
|
height: "auto",
|
|
|
|
|
|
reserveSelection: false,
|
|
|
|
|
|
border: true,
|
|
|
|
|
|
columnBtn: false,
|
|
|
|
|
|
refreshBtn: false,
|
|
|
|
|
|
menu: false,
|
|
|
|
|
|
tip: false,
|
|
|
|
|
|
selection: true,
|
|
|
|
|
|
align: 'center',
|
|
|
|
|
|
}
|
|
|
|
|
|
let rightPolicyOptions = {
|
|
|
|
|
|
...baseOptions,
|
|
|
|
|
|
column: [{
|
|
|
|
|
|
label: '政策名称',
|
|
|
|
|
|
prop: 'name',
|
|
|
|
|
|
}, {
|
|
|
|
|
|
label: '政策标签',
|
|
|
|
|
|
prop: 'labelName',
|
|
|
|
|
|
slot: true,
|
|
|
|
|
|
}]
|
|
|
|
|
|
}
|
|
|
|
|
|
let rightPostOptions = {
|
|
|
|
|
|
...baseOptions,
|
|
|
|
|
|
column: [
|
|
|
|
|
|
{
|
|
|
|
|
|
label: '岗位名称',
|
|
|
|
|
|
prop: 'jobName',
|
|
|
|
|
|
}, {
|
|
|
|
|
|
label: '用工单位',
|
|
|
|
|
|
prop: 'companyName',
|
|
|
|
|
|
}, {
|
|
|
|
|
|
label: '详细地址',
|
|
|
|
|
|
prop: 'address',
|
|
|
|
|
|
slot: true,
|
|
|
|
|
|
}, {
|
|
|
|
|
|
label: '岗位描述',
|
|
|
|
|
|
prop: 'jobDescription',
|
|
|
|
|
|
slot: true,
|
|
|
|
|
|
}, {
|
|
|
|
|
|
label: "岗位类型",
|
|
|
|
|
|
prop: "type1",
|
|
|
|
|
|
type: "select",
|
|
|
|
|
|
dicData: [
|
|
|
|
|
|
{
|
|
|
|
|
|
value: "0",
|
|
|
|
|
|
label: "零工岗位",
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
|
|
|
|
|
value: "1",
|
|
|
|
|
|
label: "全职岗位",
|
|
|
|
|
|
},
|
|
|
|
|
|
],
|
|
|
|
|
|
display: false,
|
|
|
|
|
|
hide: true,
|
|
|
|
|
|
},
|
|
|
|
|
|
]
|
|
|
|
|
|
}
|
|
|
|
|
|
export default {
|
|
|
|
|
|
components: {TextTooltip, CustomLoading},
|
|
|
|
|
|
data() {
|
|
|
|
|
|
return {
|
|
|
|
|
|
leftUserSelections: [],
|
|
|
|
|
|
rightDataList: [],
|
|
|
|
|
|
rightLoading: false,
|
|
|
|
|
|
rightTabs: 0, // 0: 政策, 1: 岗位
|
|
|
|
|
|
rightPages: Object.assign({}, pages),
|
|
|
|
|
|
rightPolicyOptions: Object.assign({}, rightPolicyOptions),
|
|
|
|
|
|
rightPostOptions: Object.assign({}, rightPostOptions),
|
|
|
|
|
|
rightDataSelections: [],
|
|
|
|
|
|
searchInput: '',
|
|
|
|
|
|
pushState: false,
|
|
|
|
|
|
progress: 0,
|
|
|
|
|
|
timer: null,
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
props: {
|
|
|
|
|
|
visible: Boolean,
|
|
|
|
|
|
rowData: {default: null, type: Function},
|
2025-11-03 16:53:20 +08:00
|
|
|
|
phoneItem: {default: {}, type: Object},
|
2024-08-07 09:34:41 +08:00
|
|
|
|
changeVisible: {default: null, type: Function},
|
|
|
|
|
|
},
|
|
|
|
|
|
computed: {
|
|
|
|
|
|
viewDrawer: {
|
|
|
|
|
|
get() {
|
|
|
|
|
|
return this.visible;
|
|
|
|
|
|
},
|
|
|
|
|
|
set(val) {
|
|
|
|
|
|
this.$emit("update:visible", val);
|
|
|
|
|
|
},
|
|
|
|
|
|
},
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
2025-11-03 16:53:20 +08:00
|
|
|
|
async informationPush() {
|
|
|
|
|
|
let resData = await getMsgContent()
|
|
|
|
|
|
if (resData.status === 200 && resData.data.code === 200) {
|
|
|
|
|
|
const data = resData.data
|
|
|
|
|
|
this.$confirm(data.msg, {
|
|
|
|
|
|
confirmButtonText: "确定",
|
|
|
|
|
|
cancelButtonText: "取消",
|
|
|
|
|
|
type: "warning"
|
|
|
|
|
|
}).then(async (type) => {
|
|
|
|
|
|
if (type === 'confirm') {
|
|
|
|
|
|
pushMsg({
|
|
|
|
|
|
serveUserId: this.phoneItem.serveUserId,
|
|
|
|
|
|
id: this.phoneItem.id
|
|
|
|
|
|
}).then((res) => {
|
|
|
|
|
|
this.$message.success('推送成功');
|
|
|
|
|
|
}).cache(() => {
|
|
|
|
|
|
this.$message.error('推送失败');
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
} else {
|
|
|
|
|
|
this.$message.error('获取模板失败');
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2024-08-07 09:34:41 +08:00
|
|
|
|
changeTabs(type) {
|
|
|
|
|
|
this.rightDataList = []
|
|
|
|
|
|
this.rightTabs = type
|
|
|
|
|
|
this.rightDataSelections = []
|
|
|
|
|
|
type === 0 && this.getRightListPolicy()
|
2024-08-30 12:06:45 +08:00
|
|
|
|
if (type === 1) {
|
|
|
|
|
|
this.$message.success('智能分析匹配中');
|
|
|
|
|
|
this.getRightSearchByUserId()
|
|
|
|
|
|
}
|
2024-08-07 09:34:41 +08:00
|
|
|
|
},
|
|
|
|
|
|
upDateUser(user) {
|
|
|
|
|
|
this.leftUserSelections = [user]
|
|
|
|
|
|
},
|
|
|
|
|
|
searchInputChange: debounce(function (val) {
|
|
|
|
|
|
this.getRightSearch()
|
|
|
|
|
|
}, 1000),
|
|
|
|
|
|
refLeftSearch(name) {
|
|
|
|
|
|
},
|
|
|
|
|
|
rightCurrentPageChange(current) {
|
|
|
|
|
|
this.rightPages.currentPage = current
|
|
|
|
|
|
this.rightTabs === 0 && this.getRightListPolicy()
|
|
|
|
|
|
this.rightTabs === 1 && this.getRightSearchByUserId()
|
|
|
|
|
|
},
|
|
|
|
|
|
rightSizePageChange(current) {
|
|
|
|
|
|
this.rightPages.size = current
|
|
|
|
|
|
this.rightTabs === 0 && this.getRightListPolicy()
|
|
|
|
|
|
this.rightTabs === 1 && this.getRightSearchByUserId()
|
|
|
|
|
|
},
|
|
|
|
|
|
rightSelectionChange(val) {
|
|
|
|
|
|
this.rightDataSelections = val
|
|
|
|
|
|
},
|
|
|
|
|
|
onSubmit() {
|
|
|
|
|
|
if (!this.leftUserSelections.length) return this.$message.info('请选择推送用户')
|
|
|
|
|
|
if (!this.rightDataSelections.length) return this.$message.info('请选择推送政策或岗位')
|
|
|
|
|
|
if (this.rightTabs === 0) {
|
|
|
|
|
|
this.pushPolicyAndUser()
|
|
|
|
|
|
} else {
|
|
|
|
|
|
this.pushPostAndUser()
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
async pushPostAndUser() {
|
|
|
|
|
|
this.pushState = true
|
|
|
|
|
|
const createTime = Date.now() + 2000
|
|
|
|
|
|
let params = {
|
|
|
|
|
|
serveId: this.rowData.id,
|
|
|
|
|
|
posts: this.rightDataSelections.map((item) => ({id: item.id, type: item.type1, jobName: item.jobName})),
|
|
|
|
|
|
users: this.leftUserSelections.map((item) => ({
|
|
|
|
|
|
idNumber: item.idNumber,
|
|
|
|
|
|
talentsId: item.id,
|
|
|
|
|
|
userId: item.userId,
|
|
|
|
|
|
userName: item.name
|
|
|
|
|
|
}))
|
|
|
|
|
|
}
|
|
|
|
|
|
let resData = await pushPostUserServe(params)
|
|
|
|
|
|
if (resData.data.code === 200) {
|
|
|
|
|
|
const timed = createTime - Date.now() > 0 ? createTime - Date.now() : 0
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
this.$message.success('岗位推送成功')
|
|
|
|
|
|
this.$refs.crud2.selectClear()
|
|
|
|
|
|
this.pushState = false
|
|
|
|
|
|
}, timed)
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
async pushPolicyAndUser() {
|
|
|
|
|
|
this.pushState = true
|
|
|
|
|
|
const createTime = Date.now() + 2000
|
|
|
|
|
|
let params = {
|
|
|
|
|
|
serveId: this.rowData.id,
|
|
|
|
|
|
policyIds: this.rightDataSelections.map((item) => item.id),
|
|
|
|
|
|
users: this.leftUserSelections.map((item) => ({
|
|
|
|
|
|
idNumber: item.idNumber,
|
|
|
|
|
|
talentsId: item.id,
|
|
|
|
|
|
userId: item.userId,
|
|
|
|
|
|
userName: item.name
|
|
|
|
|
|
}))
|
|
|
|
|
|
}
|
|
|
|
|
|
let resData = await pushPolicyUserServe(params)
|
|
|
|
|
|
if (resData.data.code === 200) {
|
|
|
|
|
|
const timed = createTime - Date.now() > 0 ? createTime - Date.now() : 0
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
this.$message.success('政策推送成功')
|
|
|
|
|
|
this.$refs.crud2.selectClear()
|
|
|
|
|
|
this.pushState = false
|
|
|
|
|
|
}, timed)
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
async getRightSearch() {
|
|
|
|
|
|
this.progress = 0
|
|
|
|
|
|
let params = {keywords: this.searchInput || '1'}
|
|
|
|
|
|
const createTime = Date.now() + 4000
|
|
|
|
|
|
this.rightLoading = true
|
|
|
|
|
|
let resData = await getSearchAll(params)
|
|
|
|
|
|
|
|
|
|
|
|
if (resData.data.code === 200) {
|
|
|
|
|
|
this.setProgress().then(() => {
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
this.rightLoading = false
|
|
|
|
|
|
this.rightDataList = resData.data.data
|
|
|
|
|
|
this.rightPages = {total: 10, currentPage: 1}
|
|
|
|
|
|
}, 200)
|
|
|
|
|
|
})
|
|
|
|
|
|
// const timed = createTime - Date.now() > 0 ? createTime - Date.now() : 0
|
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
|
// this.rightLoading = false
|
|
|
|
|
|
// this.rightDataList = resData.data.data
|
|
|
|
|
|
// this.rightPages = {total: 10, currentPage: 1}
|
|
|
|
|
|
// }, timed)
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
async getRightListPolicy() {
|
|
|
|
|
|
this.searchInput = ''
|
|
|
|
|
|
this.progress = 0
|
|
|
|
|
|
const {currentPage, size} = this.rightPages
|
|
|
|
|
|
let params = {
|
|
|
|
|
|
ids: this.rowData.policyIds,
|
|
|
|
|
|
current: currentPage,
|
|
|
|
|
|
size,
|
|
|
|
|
|
}
|
|
|
|
|
|
// const createTime = Date.now() + 4000
|
2024-08-30 12:06:45 +08:00
|
|
|
|
// this.rightLoading = true
|
2024-08-07 09:34:41 +08:00
|
|
|
|
let resData = await getListByids(params)
|
|
|
|
|
|
if (resData.data.code === 200) {
|
2024-08-30 12:06:45 +08:00
|
|
|
|
// this.setProgress().then(() => {
|
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
|
// this.rightLoading = false
|
|
|
|
|
|
this.rightPages = {total: resData.data.data.length, currentPage: 1}
|
|
|
|
|
|
this.rightDataList = resData.data.data
|
|
|
|
|
|
// }, 200)
|
|
|
|
|
|
// })
|
2024-08-07 09:34:41 +08:00
|
|
|
|
// const timed = createTime - Date.now() > 0 ? createTime - Date.now() : 0
|
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
|
//
|
|
|
|
|
|
// }, timed)
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
async getRightSearchByUserId() {
|
|
|
|
|
|
this.progress = 0
|
|
|
|
|
|
this.searchInput = ''
|
|
|
|
|
|
const {currentPage, size} = this.rightPages
|
|
|
|
|
|
const idNumbers = this.leftUserSelections.map(item => item.idNumber).join(',');
|
|
|
|
|
|
const willingJobs = this.leftUserSelections.map(item => item.willingJob);
|
|
|
|
|
|
// const createTime = Date.now() + 4000
|
|
|
|
|
|
this.rightLoading = true
|
|
|
|
|
|
let params = {
|
|
|
|
|
|
idNumbers,
|
|
|
|
|
|
current: currentPage,
|
|
|
|
|
|
size,
|
|
|
|
|
|
}
|
|
|
|
|
|
let paramsBody = {
|
|
|
|
|
|
willingJobs: willingJobs
|
|
|
|
|
|
}
|
|
|
|
|
|
let resData = await getSearchAllByUserId(params, paramsBody)
|
|
|
|
|
|
if (resData.data.code === 200) {
|
|
|
|
|
|
this.setProgress().then(() => {
|
|
|
|
|
|
setTimeout(() => {
|
|
|
|
|
|
const {records, total, size, current} = resData.data.data
|
|
|
|
|
|
this.rightLoading = false
|
|
|
|
|
|
this.rightDataList = records
|
|
|
|
|
|
this.rightPages = {total, size, currentPage: current}
|
|
|
|
|
|
}, 200)
|
|
|
|
|
|
})
|
|
|
|
|
|
// const timed = createTime - Date.now() > 0 ? createTime - Date.now() : 0
|
|
|
|
|
|
// setTimeout(() => {
|
|
|
|
|
|
// const {records, total, size, current} = resData.data.data
|
|
|
|
|
|
// this.rightLoading = false
|
|
|
|
|
|
// this.rightDataList = records
|
|
|
|
|
|
// this.rightPages = {total, size, currentPage: current}
|
|
|
|
|
|
// }, timed)
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
setProgress(beforResolve) {
|
|
|
|
|
|
return new Promise((resolve) => {
|
|
|
|
|
|
const time = (Math.random() * 1000) + 500
|
|
|
|
|
|
this.timer = setTimeout(() => {
|
|
|
|
|
|
this.progress += 1
|
|
|
|
|
|
if (this.progress >= 2) {
|
|
|
|
|
|
clearTimeout(this.timer)
|
|
|
|
|
|
resolve()
|
|
|
|
|
|
beforResolve()
|
|
|
|
|
|
} else {
|
|
|
|
|
|
return this.setProgress(resolve)
|
|
|
|
|
|
}
|
|
|
|
|
|
}, time)
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
.push-header {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.loading-box {
|
|
|
|
|
|
min-width: 600px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.row-loading {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
|
color: #666666;
|
|
|
|
|
|
margin-top: 10px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.imgcorrect {
|
|
|
|
|
|
width: 20px;
|
|
|
|
|
|
height: 20px;
|
|
|
|
|
|
}
|
|
|
|
|
|
</style>
|