HRM 员工福利

pull/781/head
quu 2025-05-13 10:08:44 +09:00
parent 42e73b5c17
commit 2459e24213
16 changed files with 2719 additions and 0 deletions

View File

@ -0,0 +1,52 @@
import request from '@/config/axios'
// 关怀通知 VO
export interface CareNoticeVO {
id: number // 主键,自动递增
careType: number // 关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等
noticeTitle: string // 通知主题
publishRangerType: number // 发布范围类型 1公司 2部门 3人员
releaseMethod: number // 发送时间方式(字典):前一天、当天、后一天
publishRanger: string // 发布范围选择
releaseTime: localtime // 发布时间
releaseDate: Date // 发布日期/节日日期
noticeMethod: number // 通知方式(字典):邮件、短信、系统通知
noticeContent: string // 通知内容
employmentDateType: number // 入职关怀日期类型
employmentNoticeType: number // 入职关怀发送通知
diyType: number // 自定义通知类型
diyEventType: number // 自定义事件名称
}
// 关怀通知 API
export const CareNoticeApi = {
// 查询关怀通知分页
getCareNoticePage: async (params: any) => {
return await request.get({ url: `/hrm/care-notice/page`, params })
},
// 查询关怀通知详情
getCareNotice: async (id: number) => {
return await request.get({ url: `/hrm/care-notice/get?id=` + id })
},
// 新增关怀通知
createCareNotice: async (data: CareNoticeVO) => {
return await request.post({ url: `/hrm/care-notice/create`, data })
},
// 修改关怀通知
updateCareNotice: async (data: CareNoticeVO) => {
return await request.put({ url: `/hrm/care-notice/update`, data })
},
// 删除关怀通知
deleteCareNotice: async (id: number) => {
return await request.delete({ url: `/hrm/care-notice/delete?id=` + id })
},
// 导出关怀通知 Excel
exportCareNotice: async (params) => {
return await request.download({ url: `/hrm/care-notice/export-excel`, params })
}
}

View File

@ -0,0 +1,50 @@
import request from '@/config/axios'
// 学历进修申请 VO
export interface EducationApplyVO {
id: number // 主键ID
userId: number // 员工ID
processInstanceId: string // 工作流编号
auditStatus: number // 审批状态
currentEducation: number // 现学历
advancedEducation: number // 进修后学历
studyStartDate: Date // 开始进修时间
studyEndDate: Date // 结束进修时间
studyFee: number // 进修费用
studySchool: string // 进修学校
studyMajor: string // 进修专业
elecSignature: string // 员工签字
}
// 学历进修申请 API
export const EducationApplyApi = {
// 查询学历进修申请分页
getEducationApplyPage: async (params: any) => {
return await request.get({ url: `/hrm/education-apply/page`, params })
},
// 查询学历进修申请详情
getEducationApply: async (id: number) => {
return await request.get({ url: `/hrm/education-apply/get?id=` + id })
},
// 新增学历进修申请
createEducationApply: async (data: EducationApplyVO) => {
return await request.post({ url: `/hrm/education-apply/create`, data })
},
// 修改学历进修申请
updateEducationApply: async (data: EducationApplyVO) => {
return await request.put({ url: `/hrm/education-apply/update`, data })
},
// 删除学历进修申请
deleteEducationApply: async (id: number) => {
return await request.delete({ url: `/hrm/education-apply/delete?id=` + id })
},
// 导出学历进修申请 Excel
exportEducationApply: async (params) => {
return await request.download({ url: `/hrm/education-apply/export-excel`, params })
}
}

View File

@ -0,0 +1,52 @@
import request from '@/config/axios'
// 补助申请 VO
export interface SubsidyApplyVO {
id: number // 主键,自动递增
userId: number // 员工ID
processInstanceId: string // 工作流编号
auditStatus: number // 审批状态
effectiveDate: Date // 生效日期
applyDesc: string // 申请说明
elecSignature: string // 本人签字
}
// 补助申请 API
export const SubsidyApplyApi = {
// 查询补助申请分页
getSubsidyApplyPage: async (params: any) => {
return await request.get({ url: `/hrm/subsidy-apply/page`, params })
},
// 查询补助申请详情
getSubsidyApply: async (id: number) => {
return await request.get({ url: `/hrm/subsidy-apply/get?id=` + id })
},
// 新增补助申请
createSubsidyApply: async (data: SubsidyApplyVO) => {
return await request.post({ url: `/hrm/subsidy-apply/create`, data })
},
// 修改补助申请
updateSubsidyApply: async (data: SubsidyApplyVO) => {
return await request.put({ url: `/hrm/subsidy-apply/update`, data })
},
// 删除补助申请
deleteSubsidyApply: async (id: number) => {
return await request.delete({ url: `/hrm/subsidy-apply/delete?id=` + id })
},
// 导出补助申请 Excel
exportSubsidyApply: async (params) => {
return await request.download({ url: `/hrm/subsidy-apply/export-excel`, params })
},
// ==================== 子表(补助申请明细) ====================
// 获得补助申请明细列表
getSubsidyApplyDetailListBySubsidyApplicationId: async (subsidyApplicationId) => {
return await request.get({ url: `/hrm/subsidy-apply/subsidy-apply-detail/list-by-subsidy-application-id?subsidyApplicationId=` + subsidyApplicationId })
}
}

View File

@ -0,0 +1,43 @@
import request from '@/config/axios'
// 补助申请明细 VO
export interface SubsidyApplyDetailVO {
id: number // 主键,自动递增
subsidyApplicationId: number // 补助申请ID
subsidyType: number // 补助类型
beforeMoney: number // 原补助金额
afterMoney: number // 补助后金额
}
// 补助申请明细 API
export const SubsidyApplyDetailApi = {
// 查询补助申请明细分页
getSubsidyApplyDetailPage: async (params: any) => {
return await request.get({ url: `/hrm/subsidy-apply-detail/page`, params })
},
// 查询补助申请明细详情
getSubsidyApplyDetail: async (id: number) => {
return await request.get({ url: `/hrm/subsidy-apply-detail/get?id=` + id })
},
// 新增补助申请明细
createSubsidyApplyDetail: async (data: SubsidyApplyDetailVO) => {
return await request.post({ url: `/hrm/subsidy-apply-detail/create`, data })
},
// 修改补助申请明细
updateSubsidyApplyDetail: async (data: SubsidyApplyDetailVO) => {
return await request.put({ url: `/hrm/subsidy-apply-detail/update`, data })
},
// 删除补助申请明细
deleteSubsidyApplyDetail: async (id: number) => {
return await request.delete({ url: `/hrm/subsidy-apply-detail/delete?id=` + id })
},
// 导出补助申请明细 Excel
exportSubsidyApplyDetail: async (params) => {
return await request.download({ url: `/hrm/subsidy-apply-detail/export-excel`, params })
}
}

View File

@ -0,0 +1,48 @@
import request from '@/config/axios'
// 员工消息 VO
export interface UserMessageVO {
id: number // 主键 ID
userId: number // 员工ID
messageType: number // 消息类型,如系统通知、提醒、关怀等
careType: number // 消息关怀类型,如生日、节日等
title: string // 通知主题
content: string // 通知内容
noticeMethod: number // 通知方式,如邮件、短信、系统通知
noticeTime: Date // 通知时间
messageStatus: number // 消息状态0=未读1=已读
readTime: Date // 已读时间
}
// 员工消息 API
export const UserMessageApi = {
// 查询员工消息分页
getUserMessagePage: async (params: any) => {
return await request.get({ url: `/hrm/user-message/page`, params })
},
// 查询员工消息详情
getUserMessage: async (id: number) => {
return await request.get({ url: `/hrm/user-message/get?id=` + id })
},
// 新增员工消息
createUserMessage: async (data: UserMessageVO) => {
return await request.post({ url: `/hrm/user-message/create`, data })
},
// 修改员工消息
updateUserMessage: async (data: UserMessageVO) => {
return await request.put({ url: `/hrm/user-message/update`, data })
},
// 删除员工消息
deleteUserMessage: async (id: number) => {
return await request.delete({ url: `/hrm/user-message/delete?id=` + id })
},
// 导出员工消息 Excel
exportUserMessage: async (params) => {
return await request.download({ url: `/hrm/user-message/export-excel`, params })
}
}

View File

@ -0,0 +1,224 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等" prop="careType">
<el-select v-model="formData.careType" placeholder="请选择关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_CARA_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知主题" prop="noticeTitle">
<el-input v-model="formData.noticeTitle" placeholder="请输入通知主题" />
</el-form-item>
<el-form-item label="发布范围类型 1公司 2部门 3人员" prop="publishRangerType">
<el-select v-model="formData.publishRangerType" placeholder="请选择发布范围类型 1公司 2部门 3人员">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_PUBLISH_RANGER_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="发送时间方式(字典):前一天、当天、后一天" prop="releaseMethod">
<el-select v-model="formData.releaseMethod" placeholder="请选择发送时间方式(字典):前一天、当天、后一天">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_RELEASE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="发布范围选择" prop="publishRanger">
<el-input v-model="formData.publishRanger" placeholder="请输入发布范围选择" />
</el-form-item>
<el-form-item label="发布时间" prop="releaseTime">
<el-date-picker
v-model="formData.releaseTime"
type="date"
value-format="x"
placeholder="选择发布时间"
/>
</el-form-item>
<el-form-item label="发布日期/节日日期" prop="releaseDate">
<el-date-picker
v-model="formData.releaseDate"
type="date"
value-format="x"
placeholder="选择发布日期/节日日期"
/>
</el-form-item>
<el-form-item label="通知方式(字典):邮件、短信、系统通知" prop="noticeMethod">
<el-select v-model="formData.noticeMethod" placeholder="请选择通知方式(字典):邮件、短信、系统通知">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_NOTICE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知内容" prop="noticeContent">
<Editor v-model="formData.noticeContent" height="150px" />
</el-form-item>
<el-form-item label="入职关怀日期类型" prop="employmentDateType">
<el-select v-model="formData.employmentDateType" placeholder="请选择入职关怀日期类型">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EMPLOYMENT_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="入职关怀发送通知" prop="employmentNoticeType">
<el-select v-model="formData.employmentNoticeType" placeholder="请选择入职关怀发送通知">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EMPLOYMENT_NOTICE_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="自定义通知类型" prop="diyType">
<el-select v-model="formData.diyType" placeholder="请选择自定义通知类型">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_DIY_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="自定义事件名称" prop="diyEventType">
<el-select v-model="formData.diyEventType" placeholder="请选择自定义事件名称">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_DIY_EVENT_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { CareNoticeApi, CareNoticeVO } from '@/api/hrm/carenotice'
/** 关怀通知 表单 */
defineOptions({ name: 'CareNoticeForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
careType: undefined,
noticeTitle: undefined,
publishRangerType: undefined,
releaseMethod: undefined,
publishRanger: undefined,
releaseTime: undefined,
releaseDate: undefined,
noticeMethod: undefined,
noticeContent: undefined,
employmentDateType: undefined,
employmentNoticeType: undefined,
diyType: undefined,
diyEventType: undefined
})
const formRules = reactive({
careType: [{ required: true, message: '关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等不能为空', trigger: 'change' }],
noticeTitle: [{ required: true, message: '通知主题不能为空', trigger: 'blur' }],
releaseMethod: [{ required: true, message: '发送时间方式(字典):前一天、当天、后一天不能为空', trigger: 'change' }],
releaseTime: [{ required: true, message: '发布时间不能为空', trigger: 'blur' }],
noticeMethod: [{ required: true, message: '通知方式(字典):邮件、短信、系统通知不能为空', trigger: 'change' }],
noticeContent: [{ required: true, message: '通知内容不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await CareNoticeApi.getCareNotice(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
formLoading.value = true
try {
const data = formData.value as unknown as CareNoticeVO
if (formType.value === 'create') {
await CareNoticeApi.createCareNotice(data)
message.success(t('common.createSuccess'))
} else {
await CareNoticeApi.updateCareNotice(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
careType: undefined,
noticeTitle: undefined,
publishRangerType: undefined,
releaseMethod: undefined,
publishRanger: undefined,
releaseTime: undefined,
releaseDate: undefined,
noticeMethod: undefined,
noticeContent: undefined,
employmentDateType: undefined,
employmentNoticeType: undefined,
diyType: undefined,
diyEventType: undefined
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,395 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<el-form-item label="关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等" prop="careType">
<el-select
v-model="queryParams.careType"
placeholder="请选择关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_CARA_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知主题" prop="noticeTitle">
<el-input
v-model="queryParams.noticeTitle"
placeholder="请输入通知主题"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="发布范围类型 1公司 2部门 3人员" prop="publishRangerType">
<el-select
v-model="queryParams.publishRangerType"
placeholder="请选择发布范围类型 1公司 2部门 3人员"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_PUBLISH_RANGER_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="发送时间方式(字典):前一天、当天、后一天" prop="releaseMethod">
<el-select
v-model="queryParams.releaseMethod"
placeholder="请选择发送时间方式(字典):前一天、当天、后一天"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_RELEASE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="发布范围选择" prop="publishRanger">
<el-input
v-model="queryParams.publishRanger"
placeholder="请输入发布范围选择"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="发布时间" prop="releaseTime">
<el-date-picker
v-model="queryParams.releaseTime"
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-220px"
/>
</el-form-item>
<el-form-item label="发布日期/节日日期" prop="releaseDate">
<el-date-picker
v-model="queryParams.releaseDate"
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-220px"
/>
</el-form-item>
<el-form-item label="通知方式(字典):邮件、短信、系统通知" prop="noticeMethod">
<el-select
v-model="queryParams.noticeMethod"
placeholder="请选择通知方式(字典):邮件、短信、系统通知"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_NOTICE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="入职关怀日期类型" prop="employmentDateType">
<el-select
v-model="queryParams.employmentDateType"
placeholder="请选择入职关怀日期类型"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EMPLOYMENT_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="入职关怀发送通知" prop="employmentNoticeType">
<el-select
v-model="queryParams.employmentNoticeType"
placeholder="请选择入职关怀发送通知"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EMPLOYMENT_NOTICE_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="自定义通知类型" prop="diyType">
<el-select
v-model="queryParams.diyType"
placeholder="请选择自定义通知类型"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_DIY_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="自定义事件名称" prop="diyEventType">
<el-select
v-model="queryParams.diyEventType"
placeholder="请选择自定义事件名称"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_DIY_EVENT_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
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-220px"
/>
</el-form-item>
<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="['hrm:care-notice:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['hrm:care-notice:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="主键,自动递增" align="center" prop="id" />
<el-table-column label="关怀类型(字典):生日、节日、入职周年、转正日期到期、任职开始/结束、退休到期、身份证有效期到期等" align="center" prop="careType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_CARA_TYPE" :value="scope.row.careType" />
</template>
</el-table-column>
<el-table-column label="通知主题" align="center" prop="noticeTitle" />
<el-table-column label="发布范围类型 1公司 2部门 3人员" align="center" prop="publishRangerType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_PUBLISH_RANGER_TYPE" :value="scope.row.publishRangerType" />
</template>
</el-table-column>
<el-table-column label="发送时间方式(字典):前一天、当天、后一天" align="center" prop="releaseMethod">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_RELEASE_METHOD" :value="scope.row.releaseMethod" />
</template>
</el-table-column>
<el-table-column label="发布范围选择" align="center" prop="publishRanger" />
<el-table-column label="发布时间" align="center" prop="releaseTime" />
<el-table-column label="发布日期/节日日期" align="center" prop="releaseDate" />
<el-table-column label="通知方式(字典):邮件、短信、系统通知" align="center" prop="noticeMethod">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_NOTICE_METHOD" :value="scope.row.noticeMethod" />
</template>
</el-table-column>
<el-table-column label="通知内容" align="center" prop="noticeContent" />
<el-table-column label="入职关怀日期类型" align="center" prop="employmentDateType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_EMPLOYMENT_TYPE" :value="scope.row.employmentDateType" />
</template>
</el-table-column>
<el-table-column label="入职关怀发送通知" align="center" prop="employmentNoticeType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_EMPLOYMENT_NOTICE_TYPE" :value="scope.row.employmentNoticeType" />
</template>
</el-table-column>
<el-table-column label="自定义通知类型" align="center" prop="diyType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_DIY_TYPE" :value="scope.row.diyType" />
</template>
</el-table-column>
<el-table-column label="自定义事件名称" align="center" prop="diyEventType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_DIY_EVENT_TYPE" :value="scope.row.diyEventType" />
</template>
</el-table-column>
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['hrm:care-notice:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['hrm:care-notice:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<CareNoticeForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { CareNoticeApi, CareNoticeVO } from '@/api/hrm/carenotice'
import CareNoticeForm from './CareNoticeForm.vue'
/** 关怀通知 列表 */
defineOptions({ name: 'CareNotice' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref<CareNoticeVO[]>([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
careType: undefined,
noticeTitle: undefined,
publishRangerType: undefined,
releaseMethod: undefined,
publishRanger: undefined,
releaseTime: [],
releaseDate: [],
noticeMethod: undefined,
noticeContent: undefined,
employmentDateType: undefined,
employmentNoticeType: undefined,
diyType: undefined,
diyEventType: undefined,
createTime: []
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await CareNoticeApi.getCareNoticePage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
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 CareNoticeApi.deleteCareNotice(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await CareNoticeApi.exportCareNotice(queryParams)
download.excel(data, '关怀通知.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>

View File

@ -0,0 +1,174 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="员工ID" prop="userId">
<el-input v-model="formData.userId" placeholder="请输入员工ID" />
</el-form-item>
<el-form-item label="工作流编号" prop="processInstanceId">
<el-input v-model="formData.processInstanceId" placeholder="请输入工作流编号" />
</el-form-item>
<el-form-item label="审批状态" prop="auditStatus">
<el-radio-group v-model="formData.auditStatus">
<el-radio value="1">请选择字典生成</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="现学历" prop="currentEducation">
<el-select v-model="formData.currentEducation" placeholder="请选择现学历">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EDUCATION)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="进修后学历" prop="advancedEducation">
<el-select v-model="formData.advancedEducation" placeholder="请选择进修后学历">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EDUCATION)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="开始进修时间" prop="studyStartDate">
<el-date-picker
v-model="formData.studyStartDate"
type="date"
value-format="x"
placeholder="选择开始进修时间"
/>
</el-form-item>
<el-form-item label="结束进修时间" prop="studyEndDate">
<el-date-picker
v-model="formData.studyEndDate"
type="date"
value-format="x"
placeholder="选择结束进修时间"
/>
</el-form-item>
<el-form-item label="进修费用" prop="studyFee">
<el-input v-model="formData.studyFee" placeholder="请输入进修费用" />
</el-form-item>
<el-form-item label="进修学校" prop="studySchool">
<el-input v-model="formData.studySchool" placeholder="请输入进修学校" />
</el-form-item>
<el-form-item label="进修专业" prop="studyMajor">
<el-input v-model="formData.studyMajor" placeholder="请输入进修专业" />
</el-form-item>
<el-form-item label="员工签字" prop="elecSignature">
<el-input v-model="formData.elecSignature" placeholder="请输入员工签字" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { EducationApplyApi, EducationApplyVO } from '@/api/hrm/educationapply'
/** 学历进修申请 表单 */
defineOptions({ name: 'EducationApplyForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
currentEducation: undefined,
advancedEducation: undefined,
studyStartDate: undefined,
studyEndDate: undefined,
studyFee: undefined,
studySchool: undefined,
studyMajor: undefined,
elecSignature: undefined
})
const formRules = reactive({
userId: [{ required: true, message: '员工ID不能为空', trigger: 'blur' }],
auditStatus: [{ required: true, message: '审批状态不能为空', trigger: 'blur' }],
currentEducation: [{ required: true, message: '现学历不能为空', trigger: 'change' }],
advancedEducation: [{ required: true, message: '进修后学历不能为空', trigger: 'change' }],
studyStartDate: [{ required: true, message: '开始进修时间不能为空', trigger: 'blur' }],
studyEndDate: [{ required: true, message: '结束进修时间不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await EducationApplyApi.getEducationApply(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
formLoading.value = true
try {
const data = formData.value as unknown as EducationApplyVO
if (formType.value === 'create') {
await EducationApplyApi.createEducationApply(data)
message.success(t('common.createSuccess'))
} else {
await EducationApplyApi.updateEducationApply(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
currentEducation: undefined,
advancedEducation: undefined,
studyStartDate: undefined,
studyEndDate: undefined,
studyFee: undefined,
studySchool: undefined,
studyMajor: undefined,
elecSignature: undefined
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,323 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<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="processInstanceId">
<el-input
v-model="queryParams.processInstanceId"
placeholder="请输入工作流编号"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="审批状态" prop="auditStatus">
<el-select
v-model="queryParams.auditStatus"
placeholder="请选择审批状态"
clearable
class="!w-240px"
>
<el-option label="请选择字典生成" value="" />
</el-select>
</el-form-item>
<el-form-item label="现学历" prop="currentEducation">
<el-select
v-model="queryParams.currentEducation"
placeholder="请选择现学历"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EDUCATION)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="进修后学历" prop="advancedEducation">
<el-select
v-model="queryParams.advancedEducation"
placeholder="请选择进修后学历"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_EDUCATION)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="开始进修时间" prop="studyStartDate">
<el-date-picker
v-model="queryParams.studyStartDate"
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-220px"
/>
</el-form-item>
<el-form-item label="结束进修时间" prop="studyEndDate">
<el-date-picker
v-model="queryParams.studyEndDate"
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-220px"
/>
</el-form-item>
<el-form-item label="进修费用" prop="studyFee">
<el-input
v-model="queryParams.studyFee"
placeholder="请输入进修费用"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="进修学校" prop="studySchool">
<el-input
v-model="queryParams.studySchool"
placeholder="请输入进修学校"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="进修专业" prop="studyMajor">
<el-input
v-model="queryParams.studyMajor"
placeholder="请输入进修专业"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="员工签字" prop="elecSignature">
<el-input
v-model="queryParams.elecSignature"
placeholder="请输入员工签字"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
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-220px"
/>
</el-form-item>
<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="['hrm:education-apply:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['hrm:education-apply:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="主键ID" align="center" prop="id" />
<el-table-column label="员工ID" align="center" prop="userId" />
<el-table-column label="工作流编号" align="center" prop="processInstanceId" />
<el-table-column label="审批状态" align="center" prop="auditStatus" />
<el-table-column label="现学历" align="center" prop="currentEducation">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_EDUCATION" :value="scope.row.currentEducation" />
</template>
</el-table-column>
<el-table-column label="进修后学历" align="center" prop="advancedEducation">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_EDUCATION" :value="scope.row.advancedEducation" />
</template>
</el-table-column>
<el-table-column label="开始进修时间" align="center" prop="studyStartDate" />
<el-table-column label="结束进修时间" align="center" prop="studyEndDate" />
<el-table-column label="进修费用" align="center" prop="studyFee" />
<el-table-column label="进修学校" align="center" prop="studySchool" />
<el-table-column label="进修专业" align="center" prop="studyMajor" />
<el-table-column label="员工签字" align="center" prop="elecSignature" />
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['hrm:education-apply:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['hrm:education-apply:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<EducationApplyForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { EducationApplyApi, EducationApplyVO } from '@/api/hrm/educationapply'
import EducationApplyForm from './EducationApplyForm.vue'
/** 学历进修申请 列表 */
defineOptions({ name: 'EducationApply' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref<EducationApplyVO[]>([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
currentEducation: undefined,
advancedEducation: undefined,
studyStartDate: [],
studyEndDate: [],
studyFee: undefined,
studySchool: undefined,
studyMajor: undefined,
elecSignature: undefined,
createTime: []
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await EducationApplyApi.getEducationApplyPage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
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 EducationApplyApi.deleteEducationApply(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await EducationApplyApi.exportEducationApply(queryParams)
download.excel(data, '学历进修申请.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>

View File

@ -0,0 +1,147 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="员工ID" prop="userId">
<el-input v-model="formData.userId" placeholder="请输入员工ID" />
</el-form-item>
<el-form-item label="工作流编号" prop="processInstanceId">
<el-input v-model="formData.processInstanceId" placeholder="请输入工作流编号" />
</el-form-item>
<el-form-item label="审批状态" prop="auditStatus">
<el-radio-group v-model="formData.auditStatus">
<el-radio value="1">请选择字典生成</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="生效日期" prop="effectiveDate">
<el-date-picker
v-model="formData.effectiveDate"
type="date"
value-format="x"
placeholder="选择生效日期"
/>
</el-form-item>
<el-form-item label="申请说明" prop="applyDesc">
<el-input v-model="formData.applyDesc" placeholder="请输入申请说明" />
</el-form-item>
<el-form-item label="本人签字" prop="elecSignature">
<el-input v-model="formData.elecSignature" placeholder="请输入本人签字" />
</el-form-item>
</el-form>
<!-- 子表的表单 -->
<el-tabs v-model="subTabsName">
<el-tab-pane label="补助申请明细" name="subsidyApplyDetail">
<SubsidyApplyDetailForm ref="subsidyApplyDetailFormRef" :subsidy-application-id="formData.id" />
</el-tab-pane>
</el-tabs>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { SubsidyApplyApi, SubsidyApplyVO } from '@/api/hrm/subsidyapply'
import SubsidyApplyDetailForm from './components/SubsidyApplyDetailForm.vue'
/** 补助申请 表单 */
defineOptions({ name: 'SubsidyApplyForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
effectiveDate: undefined,
applyDesc: undefined,
elecSignature: undefined
})
const formRules = reactive({
userId: [{ required: true, message: '员工ID不能为空', trigger: 'blur' }],
auditStatus: [{ required: true, message: '审批状态不能为空', trigger: 'blur' }],
effectiveDate: [{ required: true, message: '生效日期不能为空', trigger: 'blur' }],
applyDesc: [{ required: true, message: '申请说明不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
/** 子表的表单 */
const subTabsName = ref('subsidyApplyDetail')
const subsidyApplyDetailFormRef = ref()
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await SubsidyApplyApi.getSubsidyApply(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
try {
await subsidyApplyDetailFormRef.value.validate()
} catch (e) {
subTabsName.value = 'subsidyApplyDetail'
return
}
//
formLoading.value = true
try {
const data = formData.value as unknown as SubsidyApplyVO
//
data.subsidyApplyDetails = subsidyApplyDetailFormRef.value.getData()
if (formType.value === 'create') {
await SubsidyApplyApi.createSubsidyApply(data)
message.success(t('common.createSuccess'))
} else {
await SubsidyApplyApi.updateSubsidyApply(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
effectiveDate: undefined,
applyDesc: undefined,
elecSignature: undefined
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,117 @@
<template>
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
v-loading="formLoading"
label-width="0px"
:inline-message="true"
>
<el-table :data="formData" class="-mt-10px">
<el-table-column label="序号" type="index" width="100" />
<el-table-column label="补助类型" min-width="150">
<template #default="{ row, $index }">
<el-form-item :prop="`${$index}.subsidyType`" :rules="formRules.subsidyType" class="mb-0px!">
<el-select v-model="row.subsidyType" placeholder="请选择补助类型">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_SUBSIDY_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
</template>
</el-table-column>
<el-table-column label="原补助金额" min-width="150">
<template #default="{ row, $index }">
<el-form-item :prop="`${$index}.beforeMoney`" :rules="formRules.beforeMoney" class="mb-0px!">
<el-input v-model="row.beforeMoney" placeholder="请输入原补助金额" />
</el-form-item>
</template>
</el-table-column>
<el-table-column label="补助后金额" min-width="150">
<template #default="{ row, $index }">
<el-form-item :prop="`${$index}.afterMoney`" :rules="formRules.afterMoney" class="mb-0px!">
<el-input v-model="row.afterMoney" placeholder="请输入补助后金额" />
</el-form-item>
</template>
</el-table-column>
<el-table-column align="center" fixed="right" label="操作" width="60">
<template #default="{ $index }">
<el-button @click="handleDelete($index)" link></el-button>
</template>
</el-table-column>
</el-table>
</el-form>
<el-row justify="center" class="mt-3">
<el-button @click="handleAdd" round>+ 添加补助申请明细</el-button>
</el-row>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { SubsidyApplyApi } from '@/api/hrm/subsidyapply'
const props = defineProps<{
subsidyApplicationId: undefined // ID
}>()
const formLoading = ref(false) //
const formData = ref([])
const formRules = reactive({
subsidyApplicationId: [{ required: true, message: '补助申请ID不能为空', trigger: 'blur' }],
subsidyType: [{ required: true, message: '补助类型不能为空', trigger: 'change' }],
beforeMoney: [{ required: true, message: '原补助金额不能为空', trigger: 'blur' }],
afterMoney: [{ required: true, message: '补助后金额不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
/** 监听主表的关联字段的变化,加载对应的子表数据 */
watch(
() => props.subsidyApplicationId,
async (val) => {
// 1.
formData.value = []
// 2. val
if (!val) {
return;
}
try {
formLoading.value = true
formData.value = await SubsidyApplyApi.getSubsidyApplyDetailListBySubsidyApplicationId(val)
} finally {
formLoading.value = false
}
},
{ immediate: true }
)
/** 新增按钮操作 */
const handleAdd = () => {
const row = {
id: undefined,
subsidyApplicationId: undefined,
subsidyType: undefined,
beforeMoney: undefined,
afterMoney: undefined
}
row.subsidyApplicationId = props.subsidyApplicationId
formData.value.push(row)
}
/** 删除按钮操作 */
const handleDelete = (index) => {
formData.value.splice(index, 1)
}
/** 表单校验 */
const validate = () => {
return formRef.value.validate()
}
/** 表单值 */
const getData = () => {
return formData.value
}
defineExpose({ validate, getData })
</script>

View File

@ -0,0 +1,245 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<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="processInstanceId">
<el-input
v-model="queryParams.processInstanceId"
placeholder="请输入工作流编号"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="审批状态" prop="auditStatus">
<el-select
v-model="queryParams.auditStatus"
placeholder="请选择审批状态"
clearable
class="!w-240px"
>
<el-option label="请选择字典生成" value="" />
</el-select>
</el-form-item>
<el-form-item label="生效日期" prop="effectiveDate">
<el-date-picker
v-model="queryParams.effectiveDate"
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-220px"
/>
</el-form-item>
<el-form-item label="申请说明" prop="applyDesc">
<el-input
v-model="queryParams.applyDesc"
placeholder="请输入申请说明"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="本人签字" prop="elecSignature">
<el-input
v-model="queryParams.elecSignature"
placeholder="请输入本人签字"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
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-220px"
/>
</el-form-item>
<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="['hrm:subsidy-apply:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['hrm:subsidy-apply:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="主键,自动递增" align="center" prop="id" />
<el-table-column label="员工ID" align="center" prop="userId" />
<el-table-column label="工作流编号" align="center" prop="processInstanceId" />
<el-table-column label="审批状态" align="center" prop="auditStatus" />
<el-table-column label="生效日期" align="center" prop="effectiveDate" />
<el-table-column label="申请说明" align="center" prop="applyDesc" />
<el-table-column label="本人签字" align="center" prop="elecSignature" />
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['hrm:subsidy-apply:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['hrm:subsidy-apply:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<SubsidyApplyForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { SubsidyApplyApi, SubsidyApplyVO } from '@/api/hrm/subsidyapply'
import SubsidyApplyForm from './SubsidyApplyForm.vue'
/** 补助申请 列表 */
defineOptions({ name: 'SubsidyApply' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref<SubsidyApplyVO[]>([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
userId: undefined,
processInstanceId: undefined,
auditStatus: undefined,
effectiveDate: [],
applyDesc: undefined,
elecSignature: undefined,
createTime: []
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await SubsidyApplyApi.getSubsidyApplyPage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
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 SubsidyApplyApi.deleteSubsidyApply(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await SubsidyApplyApi.exportSubsidyApply(queryParams)
download.excel(data, '补助申请.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>

View File

@ -0,0 +1,118 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="补助申请ID" prop="subsidyApplicationId">
<el-input v-model="formData.subsidyApplicationId" placeholder="请输入补助申请ID" />
</el-form-item>
<el-form-item label="补助类型" prop="subsidyType">
<el-select v-model="formData.subsidyType" placeholder="请选择补助类型">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_SUBSIDY_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="原补助金额" prop="beforeMoney">
<el-input v-model="formData.beforeMoney" placeholder="请输入原补助金额" />
</el-form-item>
<el-form-item label="补助后金额" prop="afterMoney">
<el-input v-model="formData.afterMoney" placeholder="请输入补助后金额" />
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { SubsidyApplyDetailApi, SubsidyApplyDetailVO } from '@/api/hrm/subsidyapplydetail'
/** 补助申请明细 表单 */
defineOptions({ name: 'SubsidyApplyDetailForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
subsidyApplicationId: undefined,
subsidyType: undefined,
beforeMoney: undefined,
afterMoney: undefined
})
const formRules = reactive({
subsidyApplicationId: [{ required: true, message: '补助申请ID不能为空', trigger: 'blur' }],
subsidyType: [{ required: true, message: '补助类型不能为空', trigger: 'change' }],
beforeMoney: [{ required: true, message: '原补助金额不能为空', trigger: 'blur' }],
afterMoney: [{ required: true, message: '补助后金额不能为空', trigger: 'blur' }]
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await SubsidyApplyDetailApi.getSubsidyApplyDetail(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
formLoading.value = true
try {
const data = formData.value as unknown as SubsidyApplyDetailVO
if (formType.value === 'create') {
await SubsidyApplyDetailApi.createSubsidyApplyDetail(data)
message.success(t('common.createSuccess'))
} else {
await SubsidyApplyDetailApi.updateSubsidyApplyDetail(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
subsidyApplicationId: undefined,
subsidyType: undefined,
beforeMoney: undefined,
afterMoney: undefined
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,231 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<el-form-item label="补助申请ID" prop="subsidyApplicationId">
<el-input
v-model="queryParams.subsidyApplicationId"
placeholder="请输入补助申请ID"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="补助类型" prop="subsidyType">
<el-select
v-model="queryParams.subsidyType"
placeholder="请选择补助类型"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_SUBSIDY_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="原补助金额" prop="beforeMoney">
<el-input
v-model="queryParams.beforeMoney"
placeholder="请输入原补助金额"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="补助后金额" prop="afterMoney">
<el-input
v-model="queryParams.afterMoney"
placeholder="请输入补助后金额"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
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-220px"
/>
</el-form-item>
<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="['hrm:subsidy-apply-detail:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['hrm:subsidy-apply-detail:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="主键,自动递增" align="center" prop="id" />
<el-table-column label="补助申请ID" align="center" prop="subsidyApplicationId" />
<el-table-column label="补助类型" align="center" prop="subsidyType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_SUBSIDY_TYPE" :value="scope.row.subsidyType" />
</template>
</el-table-column>
<el-table-column label="原补助金额" align="center" prop="beforeMoney" />
<el-table-column label="补助后金额" align="center" prop="afterMoney" />
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['hrm:subsidy-apply-detail:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['hrm:subsidy-apply-detail:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<SubsidyApplyDetailForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { SubsidyApplyDetailApi, SubsidyApplyDetailVO } from '@/api/hrm/subsidyapplydetail'
import SubsidyApplyDetailForm from './SubsidyApplyDetailForm.vue'
/** 补助申请明细 列表 */
defineOptions({ name: 'SubsidyApplyDetail' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref<SubsidyApplyDetailVO[]>([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
subsidyApplicationId: undefined,
subsidyType: undefined,
beforeMoney: undefined,
afterMoney: undefined,
createTime: []
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await SubsidyApplyDetailApi.getSubsidyApplyDetailPage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
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 SubsidyApplyDetailApi.deleteSubsidyApplyDetail(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await SubsidyApplyDetailApi.exportSubsidyApplyDetail(queryParams)
download.excel(data, '补助申请明细.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>

View File

@ -0,0 +1,177 @@
<template>
<Dialog :title="dialogTitle" v-model="dialogVisible">
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<el-form-item label="员工ID" prop="userId">
<el-input v-model="formData.userId" placeholder="请输入员工ID" />
</el-form-item>
<el-form-item label="消息类型,如系统通知、提醒、关怀等" prop="messageType">
<el-select v-model="formData.messageType" placeholder="请选择消息类型,如系统通知、提醒、关怀等">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_MESSAGE_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="消息关怀类型,如生日、节日等" prop="careType">
<el-select v-model="formData.careType" placeholder="请选择消息关怀类型,如生日、节日等">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_CARA_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知主题" prop="title">
<el-input v-model="formData.title" placeholder="请输入通知主题" />
</el-form-item>
<el-form-item label="通知内容" prop="content">
<Editor v-model="formData.content" height="150px" />
</el-form-item>
<el-form-item label="通知方式,如邮件、短信、系统通知" prop="noticeMethod">
<el-select v-model="formData.noticeMethod" placeholder="请选择通知方式,如邮件、短信、系统通知">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_NOTICE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知时间" prop="noticeTime">
<el-date-picker
v-model="formData.noticeTime"
type="date"
value-format="x"
placeholder="选择通知时间"
/>
</el-form-item>
<el-form-item label="消息状态0=未读1=已读" prop="messageStatus">
<el-select v-model="formData.messageStatus" placeholder="请选择消息状态0=未读1=已读">
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_MESSAGE_STATUS)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="已读时间" prop="readTime">
<el-date-picker
v-model="formData.readTime"
type="date"
value-format="x"
placeholder="选择已读时间"
/>
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
<el-button @click="dialogVisible = false"> </el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { UserMessageApi, UserMessageVO } from '@/api/hrm/usermessage'
/** 员工消息 表单 */
defineOptions({ name: 'UserMessageForm' })
const { t } = useI18n() //
const message = useMessage() //
const dialogVisible = ref(false) //
const dialogTitle = ref('') //
const formLoading = ref(false) // 12
const formType = ref('') // create - update -
const formData = ref({
id: undefined,
userId: undefined,
messageType: undefined,
careType: undefined,
title: undefined,
content: undefined,
noticeMethod: undefined,
noticeTime: undefined,
messageStatus: undefined,
readTime: undefined
})
const formRules = reactive({
userId: [{ required: true, message: '员工ID不能为空', trigger: 'blur' }],
messageType: [{ required: true, message: '消息类型,如系统通知、提醒、关怀等不能为空', trigger: 'change' }],
title: [{ required: true, message: '通知主题不能为空', trigger: 'blur' }],
content: [{ required: true, message: '通知内容不能为空', trigger: 'blur' }],
noticeMethod: [{ required: true, message: '通知方式,如邮件、短信、系统通知不能为空', trigger: 'change' }],
noticeTime: [{ required: true, message: '通知时间不能为空', trigger: 'blur' }],
messageStatus: [{ required: true, message: '消息状态0=未读1=已读不能为空', trigger: 'change' }]
})
const formRef = ref() // Ref
/** 打开弹窗 */
const open = async (type: string, id?: number) => {
dialogVisible.value = true
dialogTitle.value = t('action.' + type)
formType.value = type
resetForm()
//
if (id) {
formLoading.value = true
try {
formData.value = await UserMessageApi.getUserMessage(id)
} finally {
formLoading.value = false
}
}
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
//
formLoading.value = true
try {
const data = formData.value as unknown as UserMessageVO
if (formType.value === 'create') {
await UserMessageApi.createUserMessage(data)
message.success(t('common.createSuccess'))
} else {
await UserMessageApi.updateUserMessage(data)
message.success(t('common.updateSuccess'))
}
dialogVisible.value = false
//
emit('success')
} finally {
formLoading.value = false
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
userId: undefined,
messageType: undefined,
careType: undefined,
title: undefined,
content: undefined,
noticeMethod: undefined,
noticeTime: undefined,
messageStatus: undefined,
readTime: undefined
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,323 @@
<template>
<ContentWrap>
<!-- 搜索工作栏 -->
<el-form
class="-mb-15px"
:model="queryParams"
ref="queryFormRef"
:inline="true"
label-width="68px"
>
<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="messageType">
<el-select
v-model="queryParams.messageType"
placeholder="请选择消息类型,如系统通知、提醒、关怀等"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_MESSAGE_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="消息关怀类型,如生日、节日等" prop="careType">
<el-select
v-model="queryParams.careType"
placeholder="请选择消息关怀类型,如生日、节日等"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_CARA_TYPE)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知主题" prop="title">
<el-input
v-model="queryParams.title"
placeholder="请输入通知主题"
clearable
@keyup.enter="handleQuery"
class="!w-240px"
/>
</el-form-item>
<el-form-item label="通知方式,如邮件、短信、系统通知" prop="noticeMethod">
<el-select
v-model="queryParams.noticeMethod"
placeholder="请选择通知方式,如邮件、短信、系统通知"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_NOTICE_METHOD)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="通知时间" prop="noticeTime">
<el-date-picker
v-model="queryParams.noticeTime"
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-220px"
/>
</el-form-item>
<el-form-item label="消息状态0=未读1=已读" prop="messageStatus">
<el-select
v-model="queryParams.messageStatus"
placeholder="请选择消息状态0=未读1=已读"
clearable
class="!w-240px"
>
<el-option
v-for="dict in getIntDictOptions(DICT_TYPE.HRM_MESSAGE_STATUS)"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="已读时间" prop="readTime">
<el-date-picker
v-model="queryParams.readTime"
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-220px"
/>
</el-form-item>
<el-form-item label="创建时间" prop="createTime">
<el-date-picker
v-model="queryParams.createTime"
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-220px"
/>
</el-form-item>
<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="['hrm:user-message:create']"
>
<Icon icon="ep:plus" class="mr-5px" /> 新增
</el-button>
<el-button
type="success"
plain
@click="handleExport"
:loading="exportLoading"
v-hasPermi="['hrm:user-message:export']"
>
<Icon icon="ep:download" class="mr-5px" /> 导出
</el-button>
</el-form-item>
</el-form>
</ContentWrap>
<!-- 列表 -->
<ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="主键 ID" align="center" prop="id" />
<el-table-column label="员工ID" align="center" prop="userId" />
<el-table-column label="消息类型,如系统通知、提醒、关怀等" align="center" prop="messageType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_MESSAGE_TYPE" :value="scope.row.messageType" />
</template>
</el-table-column>
<el-table-column label="消息关怀类型,如生日、节日等" align="center" prop="careType">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_CARA_TYPE" :value="scope.row.careType" />
</template>
</el-table-column>
<el-table-column label="通知主题" align="center" prop="title" />
<el-table-column label="通知内容" align="center" prop="content" />
<el-table-column label="通知方式,如邮件、短信、系统通知" align="center" prop="noticeMethod">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_NOTICE_METHOD" :value="scope.row.noticeMethod" />
</template>
</el-table-column>
<el-table-column
label="通知时间"
align="center"
prop="noticeTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="消息状态0=未读1=已读" align="center" prop="messageStatus">
<template #default="scope">
<dict-tag :type="DICT_TYPE.HRM_MESSAGE_STATUS" :value="scope.row.messageStatus" />
</template>
</el-table-column>
<el-table-column
label="已读时间"
align="center"
prop="readTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column
label="创建时间"
align="center"
prop="createTime"
:formatter="dateFormatter"
width="180px"
/>
<el-table-column label="操作" align="center" min-width="120px">
<template #default="scope">
<el-button
link
type="primary"
@click="openForm('update', scope.row.id)"
v-hasPermi="['hrm:user-message:update']"
>
编辑
</el-button>
<el-button
link
type="danger"
@click="handleDelete(scope.row.id)"
v-hasPermi="['hrm:user-message:delete']"
>
删除
</el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
/>
</ContentWrap>
<!-- 表单弹窗添加/修改 -->
<UserMessageForm ref="formRef" @success="getList" />
</template>
<script setup lang="ts">
import { getIntDictOptions, DICT_TYPE } from '@/utils/dict'
import { dateFormatter } from '@/utils/formatTime'
import download from '@/utils/download'
import { UserMessageApi, UserMessageVO } from '@/api/hrm/usermessage'
import UserMessageForm from './UserMessageForm.vue'
/** 员工消息 列表 */
defineOptions({ name: 'UserMessage' })
const message = useMessage() //
const { t } = useI18n() //
const loading = ref(true) //
const list = ref<UserMessageVO[]>([]) //
const total = ref(0) //
const queryParams = reactive({
pageNo: 1,
pageSize: 10,
userId: undefined,
messageType: undefined,
careType: undefined,
title: undefined,
content: undefined,
noticeMethod: undefined,
noticeTime: [],
messageStatus: undefined,
readTime: [],
createTime: []
})
const queryFormRef = ref() //
const exportLoading = ref(false) //
/** 查询列表 */
const getList = async () => {
loading.value = true
try {
const data = await UserMessageApi.getUserMessagePage(queryParams)
list.value = data.list
total.value = data.total
} finally {
loading.value = false
}
}
/** 搜索按钮操作 */
const handleQuery = () => {
queryParams.pageNo = 1
getList()
}
/** 重置按钮操作 */
const resetQuery = () => {
queryFormRef.value.resetFields()
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 UserMessageApi.deleteUserMessage(id)
message.success(t('common.delSuccess'))
//
await getList()
} catch {}
}
/** 导出按钮操作 */
const handleExport = async () => {
try {
//
await message.exportConfirm()
//
exportLoading.value = true
const data = await UserMessageApi.exportUserMessage(queryParams)
download.excel(data, '员工消息.xls')
} catch {
} finally {
exportLoading.value = false
}
}
/** 初始化 **/
onMounted(() => {
getList()
})
</script>