|
@@ -8,16 +8,7 @@
|
|
|
:inline="true"
|
|
|
label-width="120px"
|
|
|
>
|
|
|
- <el-form-item label="用户id" prop="userId">
|
|
|
- <el-input
|
|
|
- v-model="queryParams.userId"
|
|
|
- placeholder="请输入用户id"
|
|
|
- clearable
|
|
|
- @keyup.enter="handleQuery"
|
|
|
- class="!w-240px"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="真实姓名" prop="name">
|
|
|
+ <el-form-item label="用户姓名" prop="name">
|
|
|
<el-input
|
|
|
v-model="queryParams.name"
|
|
|
placeholder="请输入真实姓名"
|
|
@@ -26,63 +17,74 @@
|
|
|
class="!w-240px"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="用户性别" prop="sex">
|
|
|
- <el-select
|
|
|
- v-model="queryParams.sex"
|
|
|
- placeholder="请选择用户性别"
|
|
|
- clearable
|
|
|
- class="!w-240px"
|
|
|
- >
|
|
|
- <el-option
|
|
|
- v-for="dict in getIntDictOptions(DICT_TYPE.MENDUNER_SEX)"
|
|
|
- :key="dict.value"
|
|
|
- :label="dict.label"
|
|
|
- :value="dict.value"
|
|
|
- />
|
|
|
- </el-select>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="联系手机号" prop="phone">
|
|
|
+ <el-form-item label="英文名" prop="foreignName">
|
|
|
<el-input
|
|
|
- v-model="queryParams.phone"
|
|
|
- placeholder="请输入联系手机号"
|
|
|
+ v-model="queryParams.foreignName"
|
|
|
+ placeholder="请输入英文名"
|
|
|
clearable
|
|
|
@keyup.enter="handleQuery"
|
|
|
class="!w-240px"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="用户邮箱" prop="email">
|
|
|
+ <el-form-item label="联系电话" prop="phone">
|
|
|
<el-input
|
|
|
- v-model="queryParams.email"
|
|
|
- placeholder="请输入用户邮箱"
|
|
|
+ v-model="queryParams.phone"
|
|
|
+ placeholder="请输入联系电话"
|
|
|
clearable
|
|
|
@keyup.enter="handleQuery"
|
|
|
class="!w-240px"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="工作经验" prop="expType">
|
|
|
+ <el-form-item label="求职状态" prop="jobStatus">
|
|
|
<el-select
|
|
|
- v-model="queryParams.expType"
|
|
|
- placeholder="请选择工作经验"
|
|
|
+ v-model="queryParams.jobStatus"
|
|
|
+ placeholder="请选择求职状态"
|
|
|
clearable
|
|
|
class="!w-240px"
|
|
|
>
|
|
|
<el-option
|
|
|
- v-for="dict in getIntDictOptions(DICT_TYPE.MENDUNER_EXP_TYPE)"
|
|
|
+ v-for="dict in getIntDictOptions(DICT_TYPE.MENDUNER_JOB_SEEK_STATUS)"
|
|
|
:key="dict.value"
|
|
|
:label="dict.label"
|
|
|
:value="dict.value"
|
|
|
/>
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="学历" prop="eduType">
|
|
|
+ <el-form-item label="会员套餐" prop="vipFlag">
|
|
|
<el-select
|
|
|
- v-model="queryParams.eduType"
|
|
|
- placeholder="请选择学历"
|
|
|
+ v-model="queryParams.vipFlag"
|
|
|
+ placeholder="请选择会员套餐"
|
|
|
clearable
|
|
|
class="!w-240px"
|
|
|
>
|
|
|
<el-option
|
|
|
- v-for="dict in getIntDictOptions(DICT_TYPE.MENDUNER_EDUCATION_TYPE)"
|
|
|
+ v-for="dict in packageList"
|
|
|
+ :key="dict.id"
|
|
|
+ :label="dict.name"
|
|
|
+ :value="dict.id"
|
|
|
+ />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="会员过期时间" prop="vipExpireDate">
|
|
|
+ <el-date-picker
|
|
|
+ v-model="queryParams.vipExpireDate"
|
|
|
+ value-format="YYYY-MM-DD HH:mm:ss"
|
|
|
+ type="daterange"
|
|
|
+ start-placeholder="开始日期"
|
|
|
+ end-placeholder="结束日期"
|
|
|
+ :default-time="[new Date('1 00:00:00'), new Date('1 23:59:59')]"
|
|
|
+ class="!w-240px"
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ <el-form-item label="帐号状态" prop="status">
|
|
|
+ <el-select
|
|
|
+ v-model="queryParams.status"
|
|
|
+ placeholder="请选择帐号状态"
|
|
|
+ clearable
|
|
|
+ class="!w-240px"
|
|
|
+ >
|
|
|
+ <el-option
|
|
|
+ v-for="dict in getIntDictOptions(DICT_TYPE.MENDUNER_STATUS)"
|
|
|
:key="dict.value"
|
|
|
:label="dict.label"
|
|
|
:value="dict.value"
|
|
@@ -103,14 +105,6 @@
|
|
|
<el-form-item>
|
|
|
<el-button @click="handleQuery"><Icon icon="ep:search" class="mr-5px" /> 搜索</el-button>
|
|
|
<el-button @click="resetQuery"><Icon icon="ep:refresh" class="mr-5px" /> 重置</el-button>
|
|
|
- <!-- <el-button
|
|
|
- type="primary"
|
|
|
- plain
|
|
|
- @click="openForm('create')"
|
|
|
- v-hasPermi="['menduner:system:person-info:create']"
|
|
|
- >
|
|
|
- <Icon icon="ep:plus" class="mr-5px" /> 新增
|
|
|
- </el-button> -->
|
|
|
<el-button
|
|
|
type="success"
|
|
|
plain
|
|
@@ -126,57 +120,41 @@
|
|
|
|
|
|
<!-- 列表 -->
|
|
|
<ContentWrap>
|
|
|
- <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
|
|
|
- <el-table-column label="用户id" align="center" prop="userId" />
|
|
|
- <el-table-column label="真实姓名" align="center" prop="name" />
|
|
|
- <el-table-column label="用户性别" align="center" prop="sex">
|
|
|
+ <el-table v-loading="loading" :data="list" :stripe="true">
|
|
|
+ <el-table-column label="用户头像" align="center" prop="avatar" width="90px">
|
|
|
<template #default="scope">
|
|
|
- <dict-tag v-if="scope.row.sex !== '0'" :type="DICT_TYPE.MENDUNER_SEX" :value="scope.row.sex" />
|
|
|
- <span v-else></span>
|
|
|
+ <el-image v-if="scope.row.person?.avatar" class="h-80px w-80px" :src="scope.row.person?.avatar" lazy preview-teleported :preview-src-list="[scope.row.person?.avatar]" fit="contain" />
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="头像地址" align="center" prop="avatar">
|
|
|
+ <el-table-column label="用户姓名" align="center" prop="person.name" />
|
|
|
+ <el-table-column label="英文名" align="center" prop="person.foreignName" />
|
|
|
+ <el-table-column label="联系电话" align="center" prop="user.phone" width="120px" />
|
|
|
+ <el-table-column label="任职酒店" align="center" prop="work.enterpriseName" />
|
|
|
+ <el-table-column label="职位" align="center" prop="work.positionName" />
|
|
|
+ <el-table-column label="求职状态" align="center" prop="person.jobStatus" width="130px">
|
|
|
<template #default="scope">
|
|
|
- <el-image v-if="scope.row.avatar" style="width: 60px; height: 60px" :src="scope.row.avatar" fit="contain" />
|
|
|
+ <dict-tag :type="DICT_TYPE.MENDUNER_JOB_SEEK_STATUS" :value="scope.row.person?.jobStatus" />
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="联系手机号" align="center" prop="phone" />
|
|
|
- <el-table-column label="用户邮箱" align="center" prop="email" />
|
|
|
- <el-table-column label="工作经验" align="center" prop="expType">
|
|
|
+ <el-table-column label="会员套餐" align="center" prop="user.vipFlag">
|
|
|
<template #default="scope">
|
|
|
- <dict-tag :type="DICT_TYPE.MENDUNER_EXP_TYPE" :value="scope.row.expType" />
|
|
|
+ {{ scope.row.user?.vipFlag ? packageList.find(e => e.id === Number(scope.row.user?.vipFlag))?.name : '' }}
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
- <el-table-column label="学历" align="center" prop="expType">
|
|
|
+ <el-table-column label="会员过期时间" align="center" prop="user.vipExpireDate" :formatter="dateFormatter" width="180px" />
|
|
|
+ <el-table-column label="邀请人" align="center" prop="inviteUserStr" />
|
|
|
+ <el-table-column label="帐号状态" align="center" prop="user.status">
|
|
|
<template #default="scope">
|
|
|
- <dict-tag :type="DICT_TYPE.MENDUNER_EDUCATION_TYPE" :value="scope.row.eduType" />
|
|
|
+ <dict-tag :type="DICT_TYPE.MENDUNER_STATUS" :value="scope.row.user.status" />
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
+ <el-table-column label="创建时间" align="center" prop="user.createTime" :formatter="dateFormatter" width="180px" />
|
|
|
<el-table-column label="操作" align="center">
|
|
|
<template #default="scope">
|
|
|
- <!-- <el-button
|
|
|
- link
|
|
|
- type="primary"
|
|
|
- @click="openForm('update', scope.row.id)"
|
|
|
- v-hasPermi="['menduner:system:person-info:update']"
|
|
|
- >
|
|
|
- 编辑
|
|
|
- </el-button>
|
|
|
- <el-button
|
|
|
- link
|
|
|
- type="danger"
|
|
|
- @click="handleDelete(scope.row.id)"
|
|
|
- v-hasPermi="['menduner:system:person-info:delete']"
|
|
|
- >
|
|
|
- 删除
|
|
|
- </el-button> -->
|
|
|
- <el-button
|
|
|
- link
|
|
|
- type="primary"
|
|
|
- @click="openDetail(scope.row.id, scope.row.userId)"
|
|
|
- >
|
|
|
- 详情
|
|
|
- </el-button>
|
|
|
+ <el-button link type="primary" @click="openDetail(scope.row.person?.id, scope.row.user.id)">详情</el-button>
|
|
|
+ <el-button v-if="scope.row.user.status === '1'" link type="success" @click="handleAction(scope.row.user.id, 'enable')">启用</el-button>
|
|
|
+ <el-button v-if="scope.row.user.status === '0'" link type="danger" @click="handleAction(scope.row.user.id, 'disabled')">禁用</el-button>
|
|
|
+ <el-button link type="primary" @click="handleResetPassword(scope.row.user.id)">修改登录密码</el-button>
|
|
|
</template>
|
|
|
</el-table-column>
|
|
|
</el-table>
|
|
@@ -191,20 +169,23 @@
|
|
|
|
|
|
<!-- 表单弹窗:添加/修改 -->
|
|
|
<PersonInfoForm ref="formRef" @success="getList" />
|
|
|
+
|
|
|
+ <!-- 表单弹窗:修改登录密码 -->
|
|
|
+ <ResetPassword ref="passwordRef" @success="getList" />
|
|
|
</template>
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
-// import { dateFormatter } from '@/utils/formatTime'
|
|
|
import download from '@/utils/download'
|
|
|
+import { dateFormatter } from '@/utils/formatTime'
|
|
|
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
|
|
|
import { PersonInfoApi, PersonInfoVO } from '@/api/menduner/system/person'
|
|
|
import PersonInfoForm from './PersonInfoForm.vue'
|
|
|
+import ResetPassword from './ResetPassword.vue'
|
|
|
|
|
|
/** 人才信息 列表 */
|
|
|
defineOptions({ name: 'PersonInfo' })
|
|
|
|
|
|
const message = useMessage() // 消息弹窗
|
|
|
-const { t } = useI18n() // 国际化
|
|
|
|
|
|
const loading = ref(true) // 列表的加载中
|
|
|
const list = ref<PersonInfoVO[]>([]) // 列表的数据
|
|
@@ -212,23 +193,26 @@ const total = ref(0) // 列表的总页数
|
|
|
const queryParams = reactive({
|
|
|
pageNo: 1,
|
|
|
pageSize: 10,
|
|
|
- userId: undefined,
|
|
|
name: undefined,
|
|
|
- sex: undefined,
|
|
|
phone: undefined,
|
|
|
- email: undefined,
|
|
|
- wxCode: undefined,
|
|
|
- maritalStatus: undefined,
|
|
|
- areaId: undefined,
|
|
|
- jobType: undefined,
|
|
|
+ foreignName: undefined,
|
|
|
jobStatus: undefined,
|
|
|
- expType: undefined,
|
|
|
- eduType: undefined,
|
|
|
- createTime: []
|
|
|
+ status: undefined,
|
|
|
+ vipFlag: undefined,
|
|
|
+ createTime: [],
|
|
|
+ vipExpireDate: []
|
|
|
})
|
|
|
const queryFormRef = ref() // 搜索的表单
|
|
|
const exportLoading = ref(false) // 导出的加载中
|
|
|
|
|
|
+// 会员套餐列表
|
|
|
+const packageList = ref([])
|
|
|
+const getPackageList = async () => {
|
|
|
+ const data = await PersonInfoApi.getPersonPackageList()
|
|
|
+ packageList.value = data
|
|
|
+}
|
|
|
+getPackageList()
|
|
|
+
|
|
|
/** 查询列表 */
|
|
|
const getList = async () => {
|
|
|
loading.value = true
|
|
@@ -247,7 +231,7 @@ const handleQuery = () => {
|
|
|
getList()
|
|
|
}
|
|
|
|
|
|
-/** 打开企业详情 */
|
|
|
+/** 打开用户详情 */
|
|
|
const { push } = useRouter()
|
|
|
const openDetail = (id: string, userId: string) => {
|
|
|
push({ name: 'PersonDetail', query: { id, userId } })
|
|
@@ -259,25 +243,6 @@ const resetQuery = () => {
|
|
|
handleQuery()
|
|
|
}
|
|
|
|
|
|
-/** 添加/修改操作 */
|
|
|
-const formRef = ref()
|
|
|
-const openForm = (type: string, id?: number) => {
|
|
|
- formRef.value.open(type, id)
|
|
|
-}
|
|
|
-
|
|
|
-/** 删除按钮操作 */
|
|
|
-const handleDelete = async (id: number) => {
|
|
|
- try {
|
|
|
- // 删除的二次确认
|
|
|
- await message.delConfirm()
|
|
|
- // 发起删除
|
|
|
- await PersonInfoApi.deletePersonInfo(id)
|
|
|
- message.success(t('common.delSuccess'))
|
|
|
- // 刷新列表
|
|
|
- await getList()
|
|
|
- } catch {}
|
|
|
-}
|
|
|
-
|
|
|
/** 导出按钮操作 */
|
|
|
const handleExport = async () => {
|
|
|
try {
|
|
@@ -293,6 +258,22 @@ const handleExport = async () => {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+// 账户禁用、启用
|
|
|
+const handleAction = async (id: number, type: string) => {
|
|
|
+ try {
|
|
|
+ await message.confirm(`确认${type === 'disabled' ? '禁用' : '启用'}该账户吗?`)
|
|
|
+ await PersonInfoApi[type === 'disabled' ? 'disabledUserAccount' : 'enableUserAccount'](id)
|
|
|
+ message.success('操作成功')
|
|
|
+ await getList()
|
|
|
+ } catch {}
|
|
|
+}
|
|
|
+
|
|
|
+// 修改登录密码
|
|
|
+const passwordRef = ref()
|
|
|
+const handleResetPassword = (id) => {
|
|
|
+ passwordRef.value.open(id)
|
|
|
+}
|
|
|
+
|
|
|
/** 初始化 **/
|
|
|
onMounted(() => {
|
|
|
getList()
|