考勤汇总快照
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
<template>
|
||||
<div class="app-container">
|
||||
<el-table v-loading="loading" :data="attendanceSummaryDetailList">
|
||||
<el-table-column label="用户" align="center" prop="nickName" />
|
||||
<el-table-column label="用户" align="center" prop="userId" />
|
||||
<el-table-column label="正常出勤小时数" align="center" prop="normalHours" />
|
||||
<el-table-column label="加班小时数" align="center" prop="overtimeHours" />
|
||||
<el-table-column label="出差小时数" align="center" prop="travelHours" />
|
||||
@@ -10,8 +10,8 @@
|
||||
</template>
|
||||
|
||||
<script setup name="AttendanceSummaryDetail">
|
||||
import { ref, watch } from "vue";
|
||||
import { listAttendanceSummaryDetail } from "@/api/oa/attendanceSummaryDetail";
|
||||
import { computed } from "vue";
|
||||
|
||||
const props = defineProps({
|
||||
// 考勤汇总ID
|
||||
@@ -19,10 +19,40 @@ const props = defineProps({
|
||||
type: String,
|
||||
required: true
|
||||
}
|
||||
})
|
||||
});
|
||||
|
||||
const loading = ref(false)
|
||||
const attendanceSummaryDetailList = computed(() => {
|
||||
return props.summaryId ? listAttendanceSummaryDetail({summaryId: props.summaryId, pageSize: 9999}) : []
|
||||
})
|
||||
const loading = ref(false);
|
||||
const attendanceSummaryDetailList = ref([]); // 使用ref替代computed
|
||||
|
||||
// 监听summaryId变化
|
||||
watch(() => props.summaryId, async (newVal) => {
|
||||
if (newVal) {
|
||||
try {
|
||||
loading.value = true;
|
||||
// 调用API获取数据
|
||||
const response = await listAttendanceSummaryDetail({
|
||||
summaryId: newVal,
|
||||
pageSize: 9999
|
||||
});
|
||||
// 先将数字全部转为整数,再判断如果是0转为空字符串
|
||||
|
||||
response.rows.forEach(item => {
|
||||
const normalHours = parseInt(item.normalHours);
|
||||
const overtimeHours = parseInt(item.overtimeHours);
|
||||
const travelHours = parseInt(item.travelHours);
|
||||
item.normalHours = normalHours === 0 ? '' : normalHours;
|
||||
item.overtimeHours = overtimeHours === 0 ? '' : overtimeHours;
|
||||
item.travelHours = travelHours === 0 ? '' : travelHours;
|
||||
});
|
||||
attendanceSummaryDetailList.value = response.rows || [];
|
||||
} catch (error) {
|
||||
console.error("数据获取失败", error);
|
||||
attendanceSummaryDetailList.value = [];
|
||||
} finally {
|
||||
loading.value = false;
|
||||
}
|
||||
} else {
|
||||
attendanceSummaryDetailList.value = [];
|
||||
}
|
||||
}, { immediate: true }); // 立即执行一次获取初始数据
|
||||
</script>
|
||||
|
||||
Reference in New Issue
Block a user