add the logic to save the record of manually mark boss inactive to db

This commit is contained in:
geekgeekrun
2024-10-20 15:13:01 +08:00
parent 0fd13c5ac5
commit b6304a5ab8
3 changed files with 88 additions and 6 deletions

View File

@@ -1,5 +1,5 @@
export enum MarkAsNotSuitReason {
UNKNOWN = 0,
BOSS_INACTIVE = 1,
OTHER = 2
USER_MANUAL_OPERATION_WITH_UNKNOWN_REASON = 2
}

View File

@@ -1,14 +1,19 @@
import { app } from 'electron'
import { initPuppeteer } from '@geekgeekrun/geek-auto-start-chat-with-boss/index.mjs'
import extractZip from 'extract-zip'
import { readStorageFile } from '@geekgeekrun/geek-auto-start-chat-with-boss/runtime-file-utils.mjs'
import {
readStorageFile,
writeStorageFile
} from '@geekgeekrun/geek-auto-start-chat-with-boss/runtime-file-utils.mjs'
import { setDomainLocalStorage } from '@geekgeekrun/utils/puppeteer/local-storage.mjs'
import {
saveJobInfoFromRecommendPage,
saveChatStartupRecord
saveChatStartupRecord,
saveMarkAsNotSuitRecord
} from '@geekgeekrun/sqlite-plugin/dist/handlers'
import { initDb } from '@geekgeekrun/sqlite-plugin'
import { getPublicDbFilePath } from '@geekgeekrun/geek-auto-start-chat-with-boss/runtime-file-utils.mjs'
import { MarkAsNotSuitReason } from '@geekgeekrun/sqlite-plugin/dist/enums'
import fs from 'node:fs'
import os from 'node:os'
@@ -68,11 +73,68 @@ const attachRequestsListener = async (target: Target) => {
if (data.code === 0) {
await saveJobInfoFromRecommendPage(await dbInitPromise, data.zpData)
}
} else if (
response.url().startsWith('https://www.zhipin.com/wapi/zpgeek/negativefeedback/reasons.json')
) {
const rawReasonResData = (await response.json())?.zpData?.result ?? []
const reasonCodeToTextMap = await readStorageFile(
'job-not-suit-reason-code-to-text-cache.json'
)
for (const it of rawReasonResData) {
reasonCodeToTextMap[it.code] = it.text?.content ?? ''
}
await writeStorageFile('job-not-suit-reason-code-to-text-cache.json', reasonCodeToTextMap)
} else if (
page.url().startsWith('https://www.zhipin.com/web/geek/job-recommend') &&
response.url().startsWith('https://www.zhipin.com/wapi/zpgeek/negativefeedback/save.json')
) {
const currentJobData = await page.evaluate(
'document.querySelector(".job-detail-box").__vue__.data'
)
const requestBody = new URLSearchParams(response.request().postData())
const securityIdInRequest = requestBody.get("securityId")
const currentJobSecurityId = currentJobData?.securityId
if (securityIdInRequest !== currentJobSecurityId) {
return
}
const chosenCode = Number(requestBody.get('code'))
const currentUserInfo = await page.evaluate(
'document.querySelector(".job-detail-box").__vue__.$store.state.userInfo'
)
const reasonCodeToTextMap = await readStorageFile(
'job-not-suit-reason-code-to-text-cache.json'
)
const markDetail = {
markFrom: ChatStartupFrom.ManuallyFromRecommendList,
extInfo: {
chosenReasonInUi: {
code: chosenCode,
text: reasonCodeToTextMap[chosenCode]
}
},
markReason: MarkAsNotSuitReason.USER_MANUAL_OPERATION_WITH_UNKNOWN_REASON
}
if (reasonCodeToTextMap[chosenCode]?.includes('活跃度低')) {
markDetail.markReason = MarkAsNotSuitReason.BOSS_INACTIVE
markDetail.extInfo.bossActiveTimeDesc = currentJobData?.bossInfo.activeTimeDesc
}
await saveMarkAsNotSuitRecord(
await dbInitPromise,
currentJobData,
{
encryptUserId: currentUserInfo.encryptUserId
},
markDetail
)
} else if (
page.url().startsWith('https://www.zhipin.com/web/geek/job-recommend') &&
response.url().startsWith('https://www.zhipin.com/wapi/zpgeek/friend/add.json')
) {
const request = (await response.request()).url()
const request = response.request().url()
const url = new URL(request)
const jobIdInAddFriendUrl = url.searchParams.get('jobId')

View File

@@ -22,7 +22,14 @@
<ElTableColumn prop="bossName" label="BOSS" width="64" />
<ElTableColumn prop="markReason" label="标记原因" width="250">
<template #default="{ row }">
<template v-if="row.markReason === MarkAsNotSuitReason.BOSS_INACTIVE">
<template
v-if="
[
MarkAsNotSuitReason.BOSS_INACTIVE,
MarkAsNotSuitReason.USER_MANUAL_OPERATION_WITH_UNKNOWN_REASON
].includes(row.markReason)
"
>
<strong>{{ markReasonTopicMap[row.markReason] }}</strong>
<pre class="m-0 of-auto">{{ formatMarkReason(row) }}</pre>
</template>
@@ -160,7 +167,8 @@ function handleViewJobSnapshotButtonClick(record: VMarkAsNotSuitLog) {
}
const markReasonTopicMap = {
[MarkAsNotSuitReason.BOSS_INACTIVE]: 'Boss不活跃'
[MarkAsNotSuitReason.BOSS_INACTIVE]: 'Boss不活跃',
[MarkAsNotSuitReason.USER_MANUAL_OPERATION_WITH_UNKNOWN_REASON]: '手动标记不合适'
}
function formatMarkReason(row: VMarkAsNotSuitLog) {
@@ -180,6 +188,18 @@ function formatMarkReason(row: VMarkAsNotSuitLog) {
.filter(Boolean)
.join('\n')
}
case MarkAsNotSuitReason.USER_MANUAL_OPERATION_WITH_UNKNOWN_REASON: {
const extInfo = (() => {
try {
return JSON.parse(row.extInfo)
} catch {
return null
}
})()
return [extInfo?.chosenReasonInUi?.text && `Boss选项内容${extInfo.chosenReasonInUi.text}`]
.filter(Boolean)
.join('\n')
}
default: {
return ''
}