Compare commits

...

4 Commits

Author SHA1 Message Date
xy 7aff7b2ddd 1
7 months ago
lion db551a4296 oa累计加班时长
7 months ago
lion 560138526d 权限
7 months ago
lion a0b1cb30b3 权限
7 months ago

@ -77,30 +77,31 @@
<vxe-column
min-width="180"
header-align="center"
field="title"
title="工作名称"
field="jiabanleixing"
title="加班类型"
></vxe-column>
<vxe-column width="190" align="center" title="开始时间" field="kaishiriqi" />
<vxe-column width="190" align="center" title="结束时间" field="jieshushijian" />
<vxe-column
width="80"
align="center"
field="status"
title="当前状态"
:formatter="({ cellValue }) => myStatus.get(cellValue)"
:export-method="
({ row, column, options }) => myStatus.get(row['status'])
"
>
<template #default="{ row }">
<el-tag
size="mini"
:type="statusColor.get(row.status)"
effect="dark"
>{{ myStatus.get(row.status) }}</el-tag
>
</template>
</vxe-column>
<vxe-column min-width="140" align="center" title="原因说明" field="yuanyinshuoming" />
<!-- <vxe-column-->
<!-- width="80"-->
<!-- align="center"-->
<!-- field="status"-->
<!-- title="当前状态"-->
<!-- :formatter="({ cellValue }) => myStatus.get(cellValue)"-->
<!-- :export-method="-->
<!-- ({ row, column, options }) => myStatus.get(row['status'])-->
<!-- "-->
<!-- >-->
<!-- <template #default="{ row }">-->
<!-- <el-tag-->
<!-- size="mini"-->
<!-- :type="statusColor.get(row.status)"-->
<!-- effect="dark"-->
<!-- >{{ myStatus.get(row.status) }}</el-tag-->
<!-- >-->
<!-- </template>-->
<!-- </vxe-column>-->
<vxe-column
width="200"
align="center"

@ -6,7 +6,7 @@
<el-date-picker v-model="select.month"
type="month" size="small" value-format="yyyy-MM"
placeholder="月份" format="yyyy-MM"/>
<el-select style="width:250px;margin-left:6px" size="small" @change="changeDepartment" v-model="select.department_id" placeholder="请选择">
<el-select v-if="is_bgs" style="width:250px;margin-left:6px" size="small" @change="changeDepartment" v-model="select.department_id" placeholder="请选择">
<el-option v-for="item in departments" :key="item.id" :label="item.name" :value="item.id">
</el-option>
</el-select>
@ -14,7 +14,7 @@
@click="getList">搜索</el-button>
</template>
</vxe-toolbar>
<vxe-table ref="table" stripe :border='true' style="margin-top: 10px;" :loading="loading"
<vxe-table ref="table" stripe :border='true' style="margin-top: 10px;border:1px solid #333" :loading="loading"
:max-height="1400" :min-height="400"
:export-config="{type: 'xlsx',filename:exportName,sheetName:exportName}"
:print-config="{}" :column-config="{ resizable: true }"
@ -75,7 +75,8 @@
} from "@/api/chart"
import {
departmentListNoAuth
} from "@/api/common.js"
} from "@/api/common.js"
import store from "@/store/modules/user.js"
export default {
data() {
return {
@ -87,6 +88,8 @@
month: this.$moment().format('YYYY-MM'),
department_id: ''
},
my_department_id:"",
is_bgs:false, //
departments:[],
mergeCells:[],
exportName:'调休统计表',
@ -177,6 +180,13 @@
},
computed: {},
created() {
console.log("store",store)
this.my_department_id = store.state.department?store.state.department.id:''
this.dName = store.state.department?store.state.department.name:'全部科室'
if(this.my_department_id){
this.is_bgs = this.my_department_id==2?true:false
this.select.department_id = this.my_department_id
}
this.getDepartmentList()
this.getList()
},
@ -190,5 +200,14 @@
}
</script>
<style scoped lang="scss">
<style scoped lang="scss">
::v-deep .vxe-body--column {
border-left: 1px solid #333 !important;
border-bottom: 1px solid #333 !important;
}
::v-deep th.vxe-header--column{
border-left: 1px solid #333 !important;
border-bottom: 2px solid #333 !important;
}
</style>

@ -5,7 +5,7 @@
<template #buttons>
<el-date-picker v-model="select.month" type="month" size="small" value-format="yyyy-MM" placeholder="月份"
format="yyyy-MM" />
<el-select style="width:250px;margin-left:6px" size="small" @change="changeDepartment"
<el-select v-if="is_bgs" style="width:250px;margin-left:6px" size="small" @change="changeDepartment"
v-model="select.department_id" placeholder="请选择">
<el-option v-for="item in departments" :key="item.id" :label="item.name" :value="item.id">
</el-option>
@ -14,7 +14,7 @@
@click="getList">搜索</el-button>
</template>
</vxe-toolbar>
<vxe-table ref="table" stripe :border='true' style="margin-top: 10px;" :loading="loading" :max-height="1400"
<vxe-table ref="table" stripe :border='true' style="margin-top: 10px;border:1px solid #333" :loading="loading" :max-height="1400"
:min-height="400" :export-config="{type: 'xlsx',filename:exportName,sheetName:exportName}" :print-config="{}"
:column-config="{ resizable: true }" :expand-config="{
visibleMethod: () => false,
@ -37,7 +37,7 @@
</vxe-column>
<vxe-column header-align="center" align="center" field="jiabanshichang" title="加班时长(h)"></vxe-column>
<!-- <vxe-column header-align="center" align="center" field="day" title="day"></vxe-column> -->
<vxe-column header-align="center" align="center" field="allDay" title="本月累计(d)"></vxe-column>
<vxe-column header-align="center" align="center" field="allDay" title="本月累计(h)"></vxe-column>
@ -52,11 +52,8 @@
} from "@/api/chart"
import {
departmentListNoAuth
} from "@/api/common.js"
import * as XLSX from "xlsx";
import {
saveAs
} from "file-saver";
} from "@/api/common.js"
import store from "@/store/modules/user.js"
export default {
data() {
return {
@ -67,7 +64,9 @@
page_size: 10,
month: this.$moment().format('YYYY-MM'),
department_id: ''
},
},
my_department_id:"",
is_bgs:false, //
departments: [],
mergeCells: [],
exportName: '加班统计表',
@ -116,7 +115,7 @@
department,
overtime
} = item;
const allDay = overtime.reduce((sum, overtimeItem) => sum + parseFloat(overtimeItem.day), 0);
const allDay = overtime.reduce((sum, overtimeItem) => sum + parseFloat(overtimeItem.jiabanshichang), 0);
overtime.forEach(overtimeItem => {
overtimeItem.pid = id;
overtimeItem.name = name;
@ -185,7 +184,14 @@
},
computed: {},
created() {
created() {
this.my_department_id = store.state.department?store.state.department.id:''
this.dName = store.state.department?store.state.department.name:'全部科室'
if(this.my_department_id){
this.is_bgs = this.my_department_id==2?true:false
this.select.department_id = this.my_department_id
}
this.getDepartmentList()
this.getList()
},
@ -199,5 +205,14 @@
}
</script>
<style scoped lang="scss">
<style scoped lang="scss">
::v-deep .vxe-body--column {
border-left: 1px solid #333 !important;
border-bottom: 1px solid #333 !important;
}
::v-deep th.vxe-header--column{
border-left: 1px solid #333 !important;
border-bottom: 2px solid #333 !important;
}
</style>

Loading…
Cancel
Save