考勤管理流程

This commit is contained in:
XaoLi717 2024-11-22 14:44:46 +08:00
parent 3eed2ff50a
commit 958ca3160c
2 changed files with 738 additions and 0 deletions

View File

@ -0,0 +1,382 @@
<template>
<el-card shadow="never">
<template #header>
<span style="font-size: 16px">创建考勤管理流程</span>
</template>
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<eL-row>
<el-col :span="12">
<el-form-item label="用户名字" prop="userName">
<div class="pull-left" v-show="true" v-if="userInfo">{{ userInfo}} </div>
<div class="pull-left" v-show="true" v-if="!userInfo">获取失败 </div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="部门名字" prop="deptName">
<div class="pull-left" v-show="true" v-if="deptInfo">{{ deptInfo}} </div>
<div class="pull-left" v-show="true" v-if="!deptInfo">获取失败 </div>
</el-form-item>
</el-col>
</eL-row>
<el-form-item label="考勤日期" prop="date">
<el-date-picker
v-model="computedDate"
type="date"
value-format="x"
placeholder="选择考勤日期"
disabled
/>
</el-form-item>
<el-form-item label="考勤表单">
<el-table :data="listData" border style="width: 100%">
<el-table-column fixed prop="userName" label="姓名" width="80" />
<!-- 动态生成 1-31 天的列 -->
<el-table-column
v-for="day in 31"
:key="day"
:label="day.toString()+'号'"
width="60"
>
<template #default="{$index, row}">
<span
:style="{color : colorMap[row.dayStatus[day - 1]] || 'gray' }"
>
<span @click="pop=true" v-if="!pop">
{{workType[row.dayStatus[day - 1]]}}
</span>
<el-popover v-if="pop" placement="bottom" width="Min" trigger="click">
<template #reference>
{{workType[row.dayStatus[day - 1]]}}
</template>
<el-button-group>
<el-button @click="changeDay($index,day,1)" color="green">上班</el-button>
<el-button @click="changeDay($index,day,2)" color="orange">缺勤</el-button>
<el-button @click="changeDay($index,day,4)" color="red" >加班</el-button>
<el-button @click="changeDay($index,day,5)" color="violet" >年班</el-button>
</el-button-group>
</el-popover>
</span>
</template>
</el-table-column>
<el-table-column label="工作日" prop="workDay"/>
<el-table-column label="加班" prop="overDay"/>
<el-table-column label="年班" prop="yoverDay"/>
</el-table>
</el-form-item>
</el-form>
<template #footer>
<el-button @click="submitForm" type="primary" :disabled="formLoading"> </el-button>
</template>
</el-card>
</template>
<script setup lang="ts">
import { KqglApi, KqglVO } from '@/api/home/kqgl'
import {getUserProfile} from "@/api/system/user/profile";
import {KqdataApi, KqdataVO} from "@/api/home/kqdata";
import {getUserPageKQ} from "@/api/system/user";
import * as DefinitionApi from '@/api/bpm/definition'
import * as UserApi from '@/api/system/user'
import {useTagsViewStore} from "@/store/modules/tagsView";
/** 考勤管理 表单 */
defineOptions({ name: 'KqglCreate' })
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,
userName: undefined,
deptId: undefined,
deptName: undefined,
date: 0,
})
const formRules = reactive({
userId: [{ required: true, message: '用户id不能为空', trigger: 'blur' }],
deptId: [{ required: true, message: '部门id不能为空', trigger: 'blur' }],
date: [{ required: true, message: '考勤日期不能为空', trigger: 'blur' }],
})
const pop = ref(false)//spanpop
const dateKey = ref(0);
const listData = ref<KqdataVO[]>([]) //
//
const queryParamsData = reactive({
pageNo: 1,
pageSize: undefined,
id: undefined,
userName: undefined,
userId: undefined,
deptName: undefined,
deptId: undefined,
dayStatus: undefined,
tokey: 0,
workDay: undefined,
overDay: undefined,
yoverDay: undefined,
createTime: [],
})
//
const queryParamsUser = reactive({
pageNo: 1,
pageSize: undefined,
username: undefined,
mobile: undefined,
status: undefined,
deptId: undefined,
createTime: []
})
//
const dayStatus = [
1,1,1,1,1,3,3,1,1,1,1,1,3,3,
1,1,1,1,1,3,3,1,1,1,1,1,3,3,3,3,3
]
//map,
const colorMap: Record<number, string> = {
1: 'green',
2: 'orange',
3: 'yellow',
4: 'red',
5: 'violet',
};
//key
const workType = ref({
undefined:'空白',
1:'上班',
2:'缺勤',
3:'休息',
4:'加班',
5:'年班',
});
const formRef = ref() // Ref
const deptInfo = ref('') //
const userInfo = ref('') //
//
const computedDate = computed(() => {
return formData.value.date? formData.value.date : dateKey.value;
})
//
const { delView } = useTagsViewStore()//
const { push, currentRoute } = useRouter()
const processDefineKey = 'kqgl-001' // Key
const startUserSelectTasks = ref([]) //
const startUserSelectAssignees = ref({}) //
const startUserSelectAssigneesFormRef = ref() // Ref
const startUserSelectAssigneesFormRules = ref({}) // Rules
const userList = ref<any[]>([]) //
//
const getUserInfo = async () => {
const user = await getUserProfile();
formData.value.deptId = formData.value.deptId || user.dept.id;
formData.value.deptName = formData.value.deptName || user.dept.name;
formData.value.userId = formData.value.userId || user.id;
formData.value.userName = formData.value.userName || user.nickname;
deptInfo.value = formData.value.deptName ?? '';
userInfo.value = formData.value.userName ?? '';
};
//
const getWorkDay = async (index?:number)=>{
if (index != undefined){
const date = listData.value[index]
if (Array.isArray(date.dayStatus)){
date.workDay = date.dayStatus.filter(_ => _ === 1).length
date.overDay = date.dayStatus.filter(_ => _ === 4).length
date.yoverDay = date.dayStatus.filter(_ => _ === 5).length
}
//date
}else {
for (let item of listData.value){
if (Array.isArray(item.dayStatus)){
item.workDay = item.dayStatus.filter(_ => _ === 1).length
item.overDay = item.dayStatus.filter(_ => _ === 4).length
item.yoverDay = item.dayStatus.filter(_ => _ === 5).length
}
}
}
}
//
const changeDay = async (index:number,day:number,val:number)=>{
let dayStatus = listData.value[index].dayStatus
if (Array.isArray(dayStatus)){
dayStatus[day - 1] = val
}else{
dayStatus = [];
dayStatus[day - 1] = val; //
}
await getWorkDay(index)
}
//
const createUser = async ()=>{
queryParamsUser.deptId = formData.value.deptId
const user = await getUserPageKQ(queryParamsUser)
const dataUser = user.list
for (let item of dataUser){
const data : KqdataVO = {
id:null,
userId:item.id,
userName:item.nickname,
deptId:item.deptId,
deptName:item.deptName,
dayStatus:dayStatus.join(','),
tokey:dateKey.value,
workDay: 0,
overDay: 0,
yoverDay: 0,
}
// console.log(data)
await KqdataApi.createKqdata(data)
}
}
//
const updateUser = async ()=>{
for (let item of listData.value){
const data : KqdataVO = {
id:item.id,
userId:item.userId,
userName:item.userName,
deptId:item.deptId,
deptName:item.deptName,
dayStatus: Array.isArray(item.dayStatus)
? item.dayStatus.join(',')
: String(item.dayStatus), //
tokey:item.tokey,
workDay: item.workDay,
overDay: item.overDay,
yoverDay: item.yoverDay,
}
console.log(data)
await KqdataApi.updateKqdata(data);
}
}
/** 查询列表 */
const getList = async (dateKey?:number) => {
dateKey!==undefined?queryParamsData.tokey = dateKey:queryParamsData.tokey = formData.value.date
queryParamsData.deptId = formData.value.deptId
const data = await KqdataApi.getKqdataPage(queryParamsData)
listData.value = data.list
}
//
const changeStatus = async ()=>{
formLoading.value = true
try {
for (let item of listData.value){
if (typeof item.dayStatus === 'string'){
item.dayStatus = item.dayStatus.split(',').map(Number);
}
}
console.log(listData.value)
} finally {
formLoading.value = false
}
};
/** 打开弹窗 设置时间戳为固定信息 */
const open = async () => {
pop.value=false//span
const neDate = Date.now() //
dateKey.value = (neDate / 1000 | 0) * 1000; //
resetForm()
formLoading.value = true
try {
await getUserInfo() //,
//,,
await createUser()
await getList(dateKey.value)
await changeStatus()//
await getWorkDay()//
} finally {
formLoading.value = false
}
pop.value=true
}
defineExpose({ open }) // open
/** 提交表单 */
const emit = defineEmits(['success']) // success
const submitForm = async () => {
//
await formRef.value.validate()
// ++
if(startUserSelectTasks.value?.length > 0){
await startUserSelectAssigneesFormRef.value.validate()
}
//
formLoading.value = true
try {
const data = formData.value as unknown as KqglVO
if(startUserSelectTasks.value?.length > 0){
data.startUserSelectAssignees = startUserSelectAssignees.value
}
data.date = dateKey.value //
await KqglApi.createKqgl(data)
await updateUser() //
message.success(t('common.createSuccess'))
delView(unref(currentRoute))
await push({name: 'Kqgl'})
} finally {
formLoading.value = false
}
}
/** 初始化 */
onMounted(async () => {
await open()
const processDefinitionDetail = await DefinitionApi.getProcessDefinition(
undefined,
processDefineKey
)
if (!processDefinitionDetail) {
message.error('车辆管理流程模型未配置,请检查!')
return
}
startUserSelectTasks.value = processDefinitionDetail.startUserSelectTasks
//
if (startUserSelectTasks.value?.length > 0) {
//
for (const userTask of startUserSelectTasks.value) {
startUserSelectAssignees.value[userTask.id] = []
startUserSelectAssigneesFormRules.value[userTask.id] = [
{ required: true, message: '请选择审批人', trigger: 'blur' }
]
}
//
userList.value = await UserApi.getSimpleUserList()
}
})
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
userId: undefined,
userName: undefined,
deptId: undefined,
deptName: undefined,
date: 0,
}
formRef.value?.resetFields()
}
</script>

View File

@ -0,0 +1,356 @@
<template>
<el-card shadow="never">
<template #header>
<span style="font-size: 16px">考勤管理流程</span>
</template>
<el-form
ref="formRef"
:model="formData"
:rules="formRules"
label-width="100px"
v-loading="formLoading"
>
<eL-row>
<el-col :span="12">
<el-form-item label="用户名字" prop="userName">
<div class="pull-left" v-show="true" v-if="userInfo">{{ userInfo}} </div>
<div class="pull-left" v-show="true" v-if="!userInfo">获取失败 </div>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="部门名字" prop="deptName">
<div class="pull-left" v-show="true" v-if="deptInfo">{{ deptInfo}} </div>
<div class="pull-left" v-show="true" v-if="!deptInfo">获取失败 </div>
</el-form-item>
</el-col>
</eL-row>
<el-form-item label="考勤日期" prop="date">
<el-date-picker
v-model="computedDate"
type="date"
value-format="x"
placeholder="选择考勤日期"
disabled
/>
</el-form-item>
<el-form-item label="考勤表单" >
<el-table :data="listData" border style="width: 100%">
<el-table-column fixed prop="userName" label="姓名" width="80" />
<!-- 动态生成 1-31 天的列 -->
<el-table-column
v-for="day in 31"
:key="day"
:label="day.toString()+'号'"
width="60"
>
<!-- <template #default="{$index, row}">-->
<template #default="{row}">
<span
:style="{color : colorMap[row.dayStatus[day - 1]] || 'gray' }"
>
<span @click="pop=true" v-if="!pop">
{{workType[row.dayStatus[day - 1]]}}
</span>
<!-- <el-popover disabled v-if="pop" placement="bottom" width="Min" trigger="click">-->
<!-- <template #reference>-->
<!-- {{workType[row.dayStatus[day - 1]]}}-->
<!-- </template>-->
<!-- <el-button-group>-->
<!-- <el-button @click="changeDay($index,day,1)" color="green">上班</el-button>-->
<!-- <el-button @click="changeDay($index,day,2)" color="orange">缺勤</el-button>-->
<!-- <el-button @click="changeDay($index,day,4)" color="red" >加班</el-button>-->
<!-- <el-button @click="changeDay($index,day,5)" color="violet" >年班</el-button>-->
<!-- </el-button-group>-->
<!-- </el-popover>-->
</span>
</template>
</el-table-column>
<el-table-column label="工作日" prop="workDay"/>
<el-table-column label="加班" prop="overDay"/>
<el-table-column label="年班" prop="yoverDay"/>
</el-table>
</el-form-item>
</el-form>
</el-card>
</template>
<script setup lang="ts">
// import { KqglApi, KqglVO } from '@/api/home/kqgl'
import { KqglApi } from '@/api/home/kqgl'
import {getUserProfile} from "@/api/system/user/profile";
import {KqdataApi, KqdataVO} from "@/api/home/kqdata";
// import {getUserPageKQ} from "@/api/system/user";
import {propTypes} from "@/utils/propTypes";
/** 考勤管理 表单 */
defineOptions({ name: 'KqglDetail' })
// const { t } = useI18n() //
// const message = useMessage() //
// const dialogVisible = ref(false) //
// const dialogTitle = ref('') //
// const formType = ref('') // create - update -
const formLoading = ref(false) // 12
const formData = ref({
id: undefined,
userId: undefined,
userName: undefined,
deptId: undefined,
deptName: undefined,
date: 0,
})
const formRules = reactive({
userId: [{ required: true, message: '用户id不能为空', trigger: 'blur' }],
deptId: [{ required: true, message: '部门id不能为空', trigger: 'blur' }],
date: [{ required: true, message: '考勤日期不能为空', trigger: 'blur' }],
})
const pop = ref(false)//spanpop
const dateKey = ref(0);
const listData = ref<KqdataVO[]>([]) //
//
const queryParamsData = reactive({
pageNo: 1,
pageSize: undefined,
id: undefined,
userName: undefined,
userId: undefined,
deptName: undefined,
deptId: undefined,
dayStatus: undefined,
tokey: 0,
workDay: undefined,
overDay: undefined,
yoverDay: undefined,
createTime: [],
})
//map,
const colorMap: Record<number, string> = {
1: 'green',
2: 'orange',
3: 'yellow',
4: 'red',
5: 'violet',
};
//key
const workType = ref({
undefined:'空白',
1:'上班',
2:'缺勤',
3:'休息',
4:'加班',
5:'年班',
});
const formRef = ref() // Ref
const deptInfo = ref('') //
const userInfo = ref('') //
//
const { query } = useRoute() //
const props = defineProps({
id: propTypes.number.def(undefined)
})
//
const computedDate = computed(() => {
return formData.value.date? formData.value.date : dateKey.value;
})
const queryId = query.id as unknown as number // URL id
/** 打开弹窗 设置时间戳为固定信息 */
const open = async () => {
pop.value=false//span
resetForm()
formLoading.value = true
try {
await getUserInfo() //,
formData.value = await KqglApi.getKqgl(props.id || queryId)
await getList() //使
await changeStatus()//
await getWorkDay()//
} finally {
formLoading.value = false
}
}
onMounted(async ()=>{
await open()
})
//
const getUserInfo = async () => {
const user = await getUserProfile();
formData.value.deptId = formData.value.deptId || user.dept.id;
formData.value.deptName = formData.value.deptName || user.dept.name;
formData.value.userId = formData.value.userId || user.id;
formData.value.userName = formData.value.userName || user.nickname;
deptInfo.value = formData.value.deptName ?? '';
userInfo.value = formData.value.userName ?? '';
};
/** 查询列表 */
const getList = async (dateKey?:number) => {
dateKey!==undefined?queryParamsData.tokey = dateKey:queryParamsData.tokey = formData.value.date
queryParamsData.deptId = formData.value.deptId
const data = await KqdataApi.getKqdataPage(queryParamsData)
listData.value = data.list
}
//
const changeStatus = async ()=>{
formLoading.value = true
try {
for (let item of listData.value){
if (typeof item.dayStatus === 'string'){
item.dayStatus = item.dayStatus.split(',').map(Number);
}
}
console.log(listData.value)
} finally {
formLoading.value = false
}
};
//
const getWorkDay = async (index?:number)=>{
if (index != undefined){
const date = listData.value[index]
if (Array.isArray(date.dayStatus)){
date.workDay = date.dayStatus.filter(_ => _ === 1).length
date.overDay = date.dayStatus.filter(_ => _ === 4).length
date.yoverDay = date.dayStatus.filter(_ => _ === 5).length
}
//date
}else {
for (let item of listData.value){
if (Array.isArray(item.dayStatus)){
item.workDay = item.dayStatus.filter(_ => _ === 1).length
item.overDay = item.dayStatus.filter(_ => _ === 4).length
item.yoverDay = item.dayStatus.filter(_ => _ === 5).length
}
}
}
}
/** 重置表单 */
const resetForm = () => {
formData.value = {
id: undefined,
userId: undefined,
userName: undefined,
deptId: undefined,
deptName: undefined,
date: 0,
}
formRef.value?.resetFields()
}
//
// const queryParamsUser = reactive({
// pageNo: 1,
// pageSize: undefined,
// username: undefined,
// mobile: undefined,
// status: undefined,
// deptId: undefined,
// createTime: []
// })
//
// const dayStatus = [
// 1,1,1,1,1,3,3,1,1,1,1,1,3,3,
// 1,1,1,1,1,3,3,1,1,1,1,1,3,3,3,3,3
// ]
//
// const changeDay = async (index:number,day:number,val:number)=>{
// let dayStatus = listData.value[index].dayStatus
// if (Array.isArray(dayStatus)){
// dayStatus[day - 1] = val
// }else{
// dayStatus = [];
// dayStatus[day - 1] = val; //
// }
// await getWorkDay(index)
// }
//
// const createUser = async ()=>{
// queryParamsUser.deptId = formData.value.deptId
// const user = await getUserPageKQ(queryParamsUser)
// const dataUser = user.list
// for (let item of dataUser){
// const data : KqdataVO = {
// id:null,
// userId:item.id,
// userName:item.nickname,
// deptId:item.deptId,
// deptName:item.deptName,
// dayStatus:dayStatus.join(','),
// tokey:dateKey.value,
// workDay: 0,
// overDay: 0,
// yoverDay: 0,
// }
// // console.log(data)
// await KqdataApi.createKqdata(data)
// }
// }
//
// const updateUser = async ()=>{
// for (let item of listData.value){
// const data : KqdataVO = {
// id:item.id,
// userId:item.userId,
// userName:item.userName,
// deptId:item.deptId,
// deptName:item.deptName,
// dayStatus: Array.isArray(item.dayStatus)
// ? item.dayStatus.join(',')
// : String(item.dayStatus), //
// tokey:item.tokey,
// workDay: item.workDay,
// overDay: item.overDay,
// yoverDay: item.yoverDay,
// }
// console.log(data)
// await KqdataApi.updateKqdata(data);
// }
// }
/** 获得数据 */
// const getInfo = async () => {
// pop.value=false//span
// await getUserInfo()
// formLoading.value = true
// try {
// formData.value = await KqglApi.getKqgl(props.id || queryId)
// await getList() //使
// await changeStatus()//
// await getWorkDay()//
// } 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 KqglVO
// if (formType.value === 'create') {
// data.date = dateKey.value //
// await KqglApi.createKqgl(data)
// message.success(t('common.createSuccess'))
// } else {
// await KqglApi.updateKqgl(data)
// message.success(t('common.updateSuccess'))
// }
// await updateUser() //
// dialogVisible.value = false
// //
// emit('success')
// } finally {
// formLoading.value = false
// }
// }
</script>