enhance ui appearance of auto start chat config

This commit is contained in:
geekgeekrun
2025-05-25 01:30:32 +08:00
parent 10f1f150bf
commit 7d3a0e80d4

View File

@@ -1,218 +1,65 @@
<template>
<div class="form-wrap geek-auto-start-run-with-boss">
<el-form ref="formRef" :model="formContent" label-position="top" :rules="formRules">
<el-card class="config-section">
<el-form-item mb0>
<div>
<div font-size-16px>BOSS直聘 Cookie</div>
<el-button size="small" type="primary" @click="handleClickLaunchLogin"
>编辑Cookie</el-button
>
</div>
</el-form-item>
</el-card>
<!-- <el-form-item
label="钉钉机器人 AccessToken用于记录开聊请勿使用公司内部群"
prop="dingtalkRobotAccessToken"
>
<el-input v-model="formContent.dingtalkRobotAccessToken" />
</el-form-item> -->
<el-card class="config-section">
<el-form-item mb0>
<div font-size-16px>职位列表筛选条件</div>
</el-form-item>
<el-form-item prop="expectCompanies" mb0>
<div
font-size-14px
flex
:style="{
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
<div
:style="{
display: 'flex',
flexDirection: 'column'
}"
>
<div class="form-wrap geek-auto-start-run-with-boss">
<el-form ref="formRef" :model="formContent" label-position="top" :rules="formRules">
<el-card class="config-section">
<el-form-item mb0>
<div>
期望公司白名单以逗号分隔不区分大小写输入框留空表示不筛选<el-tooltip
effect="light"
placement="bottom-start"
@show="gtagRenderer('tooltip_show_about_expect_company_figure')"
<div font-size-16px>BOSS直聘 Cookie</div>
<el-button size="small" type="primary" @click="handleClickLaunchLogin"
>编辑Cookie</el-button
>
<template #content>
<img block h-270px src="../resources/intro-of-job-entry.png" />
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span>期望公司信息位置图示</el-button
>
</el-tooltip>
</div>
<el-dropdown @command="handleExpectCompanyTemplateClicked">
<el-button size="small"
>期望公司模板 <el-icon class="el-icon--right"><arrow-down /></el-icon
></el-button>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item
v-for="item in expectCompanyTemplateList"
:key="item.name"
:command="item"
>{{ item.name }}</el-dropdown-item
>
</el-dropdown-menu>
</template>
</el-dropdown>
</div>
<el-input
v-model="formContent.expectCompanies"
:autosize="{ minRows: 4 }"
max-h-8lh
type="textarea"
@blur="normalizeExpectCompanies"
/>
</el-form-item>
<!-- <el-form-item prop="expectSalary" mb10px>
<div
font-size-12px
:style="{
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
<div>期望薪资范围 k 为单位</div>
<el-input />
</div>
</el-form-item>
</el-card>
<!-- <el-form-item
label="钉钉机器人 AccessToken用于记录开聊请勿使用公司内部群"
prop="dingtalkRobotAccessToken"
>
<el-input v-model="formContent.dingtalkRobotAccessToken" />
</el-form-item> -->
<div class="h-1px bg-#f0f0f0" mt16px mb16px />
<div mt16px>
<div font-size-14px>期望工作地</div>
<div
:style="{
display: 'flex',
justifyContent: 'space-between',
gap: '10px'
}"
>
<el-form-item prop="expectCityList" mb0>
<div
font-size-12px
:style="{
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
<city-chooser v-model="formContent.expectCityList" />
</div>
</el-form-item>
<el-card class="config-section">
<el-form-item mb0>
<div font-size-16px>职位列表筛选条件</div>
</el-form-item>
<el-form-item prop="expectCompanies" mb0>
<div
v-if="formContent.expectCityList?.length"
font-size-14px
flex
:style="{
backgroundColor: '#f0f0f0',
width: '1px'
}"
></div>
<el-form-item
v-if="formContent.expectCityList?.length"
prop="expectCityList"
mb10px
:style="{
flex: 1,
minWidth: '400px'
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
<div
font-size-12px
:style="{
width: '100%'
}"
>
<div>当前职位工作地与期望工作地不匹配时</div>
<el-form-item mb0>
<el-select
v-model="formContent.expectCityNotMatchStrategy"
@change="
(value) => gtagRenderer('expect_city_not_match_strategy_changed', { value })
"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
>
</el-select>
</el-form-item>
</div>
</el-form-item>
</div>
<el-tooltip
effect="light"
placement="bottom-start"
@show="gtagRenderer('tooltip_show_about_wrongly_mark_not_suit')"
>
<template #content>
<ul m0 line-height-1.5em w-400px pl2em>
<li>
如有错误标记请在左侧<a
href="javascript:void(0)"
style="color: var(--el-color-primary)"
@click.prevent="
() => {
gtagRenderer('click_view_mansr_from_boss_b_tooltip')
$router.push('/main-layout/MarkAsNotSuitRecord')
}
"
>标记不合适</a
>记录中找到相关记录来查看职位详情或手动对这些职位发起会话
</li>
</ul>
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span
>职位被错误标记不合适时如何处理</el-button
>
</el-tooltip>
</div>
</el-card>
<el-card class="config-section">
<el-form-item mb0>
<div font-size-16px>职位详情筛选条件</div>
</el-form-item>
<div>
<div
flex
:style="{
alignItems: 'center',
justifyContent: 'space-between'
}"
>
<div font-size-14px>
期望职位信息
<el-tooltip
effect="light"
placement="bottom"
@show="gtagRenderer('tooltip_show_about_expect_job_info_figure')"
>
<template #content>
<img block h-270px src="../resources/intro-of-job-info.png" />
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span>如下各信息位置图示</el-button
<div>
期望公司白名单以逗号分隔不区分大小写输入框留空表示不筛选<el-tooltip
effect="light"
placement="bottom-start"
@show="gtagRenderer('tooltip_show_about_expect_company_figure')"
>
</el-tooltip>
</div>
<div>
<el-dropdown ml20px @command="handleExpectJobFilterTemplateClicked">
<template #content>
<img block h-270px src="../resources/intro-of-job-entry.png" />
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span
>期望公司信息位置图示</el-button
>
</el-tooltip>
</div>
<el-dropdown @command="handleExpectCompanyTemplateClicked">
<el-button size="small"
>职位详情筛选模板按职类区分
<el-icon class="el-icon--right"><arrow-down /></el-icon
>期望公司模板 <el-icon class="el-icon--right"><arrow-down /></el-icon
></el-button>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item
v-for="item in expectJobFilterTemplateList"
v-for="item in expectCompanyTemplateList"
:key="item.name"
:command="item"
>{{ item.name }}</el-dropdown-item
@@ -221,134 +68,92 @@
</template>
</el-dropdown>
</div>
</div>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1fr 1em 1fr 1em 1fr',
gap: '5px',
width: '100%',
alignItems: 'end'
}"
class="job-detail-filter-wrap"
>
<el-form-item mb0 prop="expectJobNameRegExpStr">
<div font-size-12px>职位名称正则不区分大小写</div>
<el-input
v-model="formContent.expectJobNameRegExpStr"
placeholder="true"
@blur="
formContent.expectJobNameRegExpStr =
formContent.expectJobNameRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
<div mb10px font-size-12px flex flex-justify-center></div>
<el-form-item mb0 prop="expectJobTypeRegExpStr">
<div font-size-12px>职位类型正则推荐填写不区分大小写</div>
<el-input
v-model="formContent.expectJobTypeRegExpStr"
placeholder="true"
@blur="
formContent.expectJobTypeRegExpStr =
formContent.expectJobTypeRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
<div mb10px font-size-12px flex flex-justify-center></div>
<el-form-item mb0 prop="expectJobDescRegExpStr">
<div font-size-12px>职位描述正则不区分大小写</div>
<el-input
v-model="formContent.expectJobDescRegExpStr"
placeholder="true"
@blur="
formContent.expectJobDescRegExpStr =
formContent.expectJobDescRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
</div>
<div class="mt10px lh-2em font-size-12px">当前职位名称/类型/描述不符合投递条件时</div>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1.25fr 0.75fr',
gap: '10px 0',
width: '100%',
alignItems: 'end'
}"
>
<el-form-item mb0>
<el-select
v-model="formContent.jobNotMatchStrategy"
@change="(value) => gtagRenderer('job_not_match_strategy_changed', { value })"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
>
</el-select>
</el-form-item>
<div />
</div>
</div>
<div class="h-1px bg-#f0f0f0" mt16px mb16px />
<div mt16px>
<div mb0 lh-2em font-size-14px>活跃度</div>
<el-form-item>
<div font-size-12px>认为职位不活跃的时间范围</div>
<el-slider
v-model="formContent.markAsNotActiveSelectedTimeRange"
:marks="noActiveDefinitionMarks"
:max="10"
:step="1"
pl50px
pr50px
pb30px
class="no-active-definition-text-slider"
:format-tooltip="
(v) =>
typeof noActiveDefinitionMarks[v] === 'string'
? noActiveDefinitionMarks[v]
: noActiveDefinitionMarks[v]?.label
"
@change="(value) => gtagRenderer('job_not_active_time_range_changed', { value })"
<el-input
v-model="formContent.expectCompanies"
:autosize="{ minRows: 4 }"
max-h-8lh
type="textarea"
@blur="normalizeExpectCompanies"
/>
</el-form-item>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1.25fr 0.75fr',
gap: '10px 0',
width: '100%',
alignItems: 'end'
}"
>
<el-form-item v-if="formContent.markAsNotActiveSelectedTimeRange > 0" mb0>
<div font-size-12px>发现当前职位不活跃时:</div>
<el-select
v-model="formContent.jobNotActiveStrategy"
@change="(value) => gtagRenderer('job_not_active_strategy_changed', { value })"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
<!-- <el-form-item prop="expectSalary" mb10px>
<div
font-size-12px
:style="{
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
<div>期望薪资范围 k 为单位</div>
<el-input />
</div>
</el-form-item> -->
<div class="h-1px bg-#f0f0f0" mt16px mb16px />
<div mt16px>
<div font-size-14px>期望工作地</div>
<div
:style="{
display: 'flex',
justifyContent: 'space-between',
gap: '10px'
}"
>
<el-form-item prop="expectCityList" mb0>
<div
font-size-12px
:style="{
justifyContent: 'space-between',
alignItems: 'center',
width: '100%'
}"
>
</el-select>
</el-form-item>
</div>
</div>
</el-card>
<el-card class="config-section">
<el-form-item prop="filter" mb0>
<div font-size-16px>
职位备选筛选条件
<city-chooser v-model="formContent.expectCityList" />
</div>
</el-form-item>
<div
v-if="formContent.expectCityList?.length"
:style="{
backgroundColor: '#f0f0f0',
width: '1px'
}"
></div>
<el-form-item
v-if="formContent.expectCityList?.length"
prop="expectCityList"
mb10px
:style="{
flex: 1,
minWidth: '400px'
}"
>
<div
font-size-12px
:style="{
width: '100%'
}"
>
<div>当前职位工作地与期望工作地不匹配时</div>
<el-form-item mb0>
<el-select
v-model="formContent.expectCityNotMatchStrategy"
@change="
(value) => gtagRenderer('expect_city_not_match_strategy_changed', { value })
"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
>
</el-select>
</el-form-item>
</div>
</el-form-item>
</div>
<el-tooltip
effect="light"
placement="bottom-start"
@@ -356,32 +161,247 @@
>
<template #content>
<ul m0 line-height-1.5em w-400px pl2em>
<li>当前求职期望无合适职位时自动更改Boss直聘页面上的筛选条件查找新工作</li>
<li>
如有错误标记请在左侧<a
href="javascript:void(0)"
style="color: var(--el-color-primary)"
@click.prevent="
() => {
gtagRenderer('click_view_mansr_from_boss_b_tooltip')
$router.push('/main-layout/MarkAsNotSuitRecord')
}
"
>标记不合适</a
>记录中找到相关记录来查看职位详情或手动对这些职位发起会话
</li>
</ul>
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span>这个配置是如何工作的?</el-button
><span><QuestionFilled w-1em h-1em mr2px /></span
>职位被错误标记不合适时如何处理</el-button
>
</el-tooltip>
</div>
<AnyCombineBossRecommendFilter v-model="formContent.anyCombineRecommendJobFilter" />
<div font-size-12px>
当前组合条件数:{{
currentAnyCombineRecommendJobFilterCombinationCount.toLocaleString()
}}
<span
v-if="currentAnyCombineRecommendJobFilterCombinationCount >= 20"
class="color-orange"
>不建议选择太多组合条件</span
</el-card>
<el-card class="config-section">
<el-form-item mb0>
<div font-size-16px>职位详情筛选条件</div>
</el-form-item>
<div>
<div
flex
:style="{
alignItems: 'center',
justifyContent: 'space-between'
}"
>
<div font-size-14px>
期望职位信息
<el-tooltip
effect="light"
placement="bottom"
@show="gtagRenderer('tooltip_show_about_expect_job_info_figure')"
>
<template #content>
<img block h-270px src="../resources/intro-of-job-info.png" />
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span>如下各信息位置图示</el-button
>
</el-tooltip>
</div>
<div>
<el-dropdown ml20px @command="handleExpectJobFilterTemplateClicked">
<el-button size="small"
>职位详情筛选模板按职类区分
<el-icon class="el-icon--right"><arrow-down /></el-icon
></el-button>
<template #dropdown>
<el-dropdown-menu>
<el-dropdown-item
v-for="item in expectJobFilterTemplateList"
:key="item.name"
:command="item"
>{{ item.name }}</el-dropdown-item
>
</el-dropdown-menu>
</template>
</el-dropdown>
</div>
</div>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1fr 1em 1fr 1em 1fr',
gap: '5px',
width: '100%',
alignItems: 'end'
}"
class="job-detail-filter-wrap"
>
<el-form-item mb0 prop="expectJobNameRegExpStr">
<div font-size-12px>职位名称正则不区分大小写</div>
<el-input
v-model="formContent.expectJobNameRegExpStr"
placeholder="true"
@blur="
formContent.expectJobNameRegExpStr =
formContent.expectJobNameRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
<div mb10px font-size-12px flex flex-justify-center></div>
<el-form-item mb0 prop="expectJobTypeRegExpStr">
<div font-size-12px>职位类型正则推荐填写不区分大小写</div>
<el-input
v-model="formContent.expectJobTypeRegExpStr"
placeholder="true"
@blur="
formContent.expectJobTypeRegExpStr =
formContent.expectJobTypeRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
<div mb10px font-size-12px flex flex-justify-center></div>
<el-form-item mb0 prop="expectJobDescRegExpStr">
<div font-size-12px>职位描述正则不区分大小写</div>
<el-input
v-model="formContent.expectJobDescRegExpStr"
placeholder="true"
@blur="
formContent.expectJobDescRegExpStr =
formContent.expectJobDescRegExpStr?.trim() ?? ''
"
/>
</el-form-item>
</div>
<div class="mt10px lh-2em font-size-12px">当前职位名称/类型/描述不符合投递条件时</div>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1.25fr 0.75fr',
gap: '10px 0',
width: '100%',
alignItems: 'end'
}"
>
<el-form-item mb0>
<el-select
v-model="formContent.jobNotMatchStrategy"
@change="(value) => gtagRenderer('job_not_match_strategy_changed', { value })"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
>
</el-select>
</el-form-item>
<div />
</div>
</div>
</el-form-item>
</el-card>
<el-form-item class="last-form-item mb20px mt20px">
<div class="h-1px bg-#f0f0f0" mt16px mb16px />
<div mt16px>
<div mb0 lh-2em font-size-14px>活跃度</div>
<el-form-item>
<div font-size-12px>认为职位不活跃的时间范围</div>
<el-slider
v-model="formContent.markAsNotActiveSelectedTimeRange"
:marks="noActiveDefinitionMarks"
:max="10"
:step="1"
pl50px
pr50px
pb30px
class="no-active-definition-text-slider"
:format-tooltip="
(v) =>
typeof noActiveDefinitionMarks[v] === 'string'
? noActiveDefinitionMarks[v]
: noActiveDefinitionMarks[v]?.label
"
@change="(value) => gtagRenderer('job_not_active_time_range_changed', { value })"
/>
</el-form-item>
<div
:style="{
display: 'grid',
gridTemplateColumns: '1.25fr 0.75fr',
gap: '10px 0',
width: '100%',
alignItems: 'end'
}"
>
<el-form-item v-if="formContent.markAsNotActiveSelectedTimeRange > 0" mb0>
<div font-size-12px>发现当前职位不活跃时:</div>
<el-select
v-model="formContent.jobNotActiveStrategy"
@change="(value) => gtagRenderer('job_not_active_strategy_changed', { value })"
>
<el-option
v-for="op in strategyOptionWhenCurrentJobNotMatch"
:key="op.value"
:label="op.name"
:value="op.value"
>{{ op.name }}</el-option
>
</el-select>
</el-form-item>
</div>
</div>
</el-card>
<el-card class="config-section">
<el-form-item prop="filter" mb0>
<div font-size-16px>
职位备选筛选条件
<el-tooltip
effect="light"
placement="bottom-start"
@show="gtagRenderer('tooltip_show_about_wrongly_mark_not_suit')"
>
<template #content>
<ul m0 line-height-1.5em w-400px pl2em>
<li>当前求职期望无合适职位时自动更改Boss直聘页面上的筛选条件查找新工作</li>
</ul>
</template>
<el-button type="text" font-size-12px
><span><QuestionFilled w-1em h-1em mr2px /></span
>这个配置是如何工作的?</el-button
>
</el-tooltip>
</div>
<AnyCombineBossRecommendFilter v-model="formContent.anyCombineRecommendJobFilter" />
<div font-size-12px>
当前组合条件数:{{
currentAnyCombineRecommendJobFilterCombinationCount.toLocaleString()
}}
<span
v-if="currentAnyCombineRecommendJobFilterCombinationCount >= 20"
class="color-orange"
>不建议选择太多组合条件</span
>
</div>
</el-form-item>
</el-card>
</el-form>
</div>
<div class="bg-#f8f8f8 pb10px pt10px">
<div
:style="{
display: 'flex',
justifyContent: 'end',
maxWidth: '1000px',
margin: '0 auto',
paddingLeft: '20px',
paddingRight: 'calc(20px + 16px)'
}"
>
<el-button @click="handleSave">仅保存配置</el-button>
<el-button type="primary" @click="handleSubmit"> 保存配置,并开始求职! </el-button>
</el-form-item>
</el-form>
</div>
</div>
</div>
</template>
@@ -728,9 +748,11 @@ const noActiveDefinitionMarks = computed(() => {
.form-wrap {
max-height: 100vh;
overflow: auto;
padding-top: 20px;
padding-left: 20px;
padding-right: 20px;
.config-section {
padding-bottom: 20px;
.config-section + .config-section {
margin-top: 10px;
}
:deep(.el-form) {