HRM 员工福利
parent
42e73b5c17
commit
2459e24213
|
|
@ -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 })
|
||||
}
|
||||
}
|
||||
|
|
@ -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 })
|
||||
}
|
||||
}
|
||||
|
|
@ -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 })
|
||||
}
|
||||
}
|
||||
|
|
@ -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 })
|
||||
}
|
||||
}
|
||||
|
|
@ -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 })
|
||||
}
|
||||
}
|
||||
|
|
@ -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) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||||
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>
|
||||
|
|
@ -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>
|
||||
|
|
@ -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) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||||
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>
|
||||
|
|
@ -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>
|
||||
|
|
@ -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) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||||
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>
|
||||
|
|
@ -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>
|
||||
|
|
@ -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>
|
||||
|
|
@ -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) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||||
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>
|
||||
|
|
@ -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>
|
||||
|
|
@ -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) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用
|
||||
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>
|
||||
|
|
@ -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>
|
||||
Loading…
Reference in New Issue