update code

dev_xds
haha 2023-09-26 00:01:20 +08:00
parent e0f32fb7df
commit 3ab35b0d15
12 changed files with 550 additions and 520 deletions

View File

@ -42,3 +42,11 @@ export function delAttendanceWorker(id) {
method: 'delete'
})
}
export function queryAttendanceData(data){
return request({
url: '/project/attendanceWorker/queryAttendanceData',
method: 'post',
data:data
})
}

View File

@ -1,154 +1,90 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="厂商编号参考字典attendance_vendors" prop="vendorsCode">
<el-input
v-model="queryParams.vendorsCode"
placeholder="请输入厂商编号参考字典attendance_vendors"
clearable
@keyup.enter.native="handleQuery"
/>
<el-form-item label="项目名称" prop="projectId">
<el-select v-model="queryParams.projectId" placeholder="请选择项目" clearable @change="doQuerySub">
<el-option v-for="(item, index) in projectOptions" :key="index" :label="item.projectName" :value="item.id">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="工人Id" prop="workerId">
<el-input
v-model="queryParams.workerId"
placeholder="请输入工人Id"
clearable
@keyup.enter.native="handleQuery"
/>
<el-form-item label="总包单位" prop="subDeptId">
<el-select v-model="queryParams.subDeptId" placeholder="请选择总包单位" clearable>
<el-option v-for="(item, index) in depts" :key="index" :label="item.deptName" :value="item.deptId">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="考勤时间yyyy-MM-dd HH:mm:ss" prop="attendanceTime">
<el-input
v-model="queryParams.attendanceTime"
placeholder="请输入考勤时间yyyy-MM-dd HH:mm:ss"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="设备编号" prop="deviceCode">
<el-input
v-model="queryParams.deviceCode"
placeholder="请输入设备编号"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="作业面Id" prop="workPointId">
<el-input
v-model="queryParams.workPointId"
placeholder="请输入作业面Id"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="${comment}" prop="state">
<el-input
v-model="queryParams.state"
placeholder="请输入${comment}"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="${comment}" prop="isDel">
<el-input
v-model="queryParams.isDel"
placeholder="请输入${comment}"
clearable
@keyup.enter.native="handleQuery"
/>
<el-form-item label="日期" prop="createBy">
<el-date-picker v-model="queryParams.createBy" type="date" placeholder="选择日期">
</el-date-picker>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button>
<el-button type="warning" plain icon="el-icon-setting" size="mini" @click="handleSetting"
v-hasPermi="['project:attendanceConfig:edit']">设置</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-row :gutter="10" class="mb8" v-if="1 == 2">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:attendance:add']"
>新增</el-button>
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
v-hasPermi="['project:attendance:add']">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="success"
plain
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['project:attendance:edit']"
>修改</el-button>
<el-button type="success" plain icon="el-icon-edit" size="mini" :disabled="single" @click="handleUpdate"
v-hasPermi="['project:attendance:edit']">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="danger"
plain
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['project:attendance:remove']"
>删除</el-button>
<el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
v-hasPermi="['project:attendance:remove']">删除</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['project:attendance:export']"
>导出</el-button>
<el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
v-hasPermi="['project:attendance:export']">导出</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="attendanceList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="${comment}" align="center" prop="id" />
<el-table-column label="厂商编号参考字典attendance_vendors" align="center" prop="vendorsCode" />
<el-table-column label="工人Id" align="center" prop="workerId" />
<el-table-column label="进门还是出门E进L出" align="center" prop="attendanceType" />
<el-table-column label="考勤时间yyyy-MM-dd HH:mm:ss" align="center" prop="attendanceTime" />
<el-table-column label="设备编号" align="center" prop="deviceCode" />
<el-table-column label="作业面Id" align="center" prop="workPointId" />
<el-table-column label="服务返回的JSON" align="center" prop="other" />
<el-table-column label="${comment}" align="center" prop="state" />
<el-table-column label="${comment}" align="center" prop="remark" />
<el-table-column label="${comment}" align="center" prop="isDel" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<el-table-column label="照片" align="center" prop="id">
<template slot-scope="{row}">
<el-image :src="row.recentPhoto" :preview-src-list="[row.recentPhoto]" style="height:60px"/>
</template>
</el-table-column>
<el-table-column label="姓名" align="center" prop="name" />
<el-table-column label="籍贯" align="center" prop="nativePlace" />
<el-table-column label="性别" align="center" prop="attendanceType" >
<template slot-scope="{row}">{{ row.gender==1?'女':'男' }}</template>
</el-table-column>
<el-table-column label="进场时间" align="center" prop="inTime">
<template slot-scope="{row}">{{ row.inTime|formatDateTime }}</template>
</el-table-column>
<el-table-column label="离场时间" align="center" prop="outTime">
<template slot-scope="{row}">{{ row.outTime|formatDateTime }}</template>
</el-table-column>
<el-table-column label="状态" align="center" prop="status">
<template slot-scope="{row}">{{ row.status==1?'退场':'进场' }}</template>
</el-table-column>
<el-table-column label="分包商名称" align="center" prop="companyName" />
<el-table-column label="所属班组" align="center" prop="groupName" />
<el-table-column label="工种" align="center" prop="workTypeName" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width" v-if="1==2">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:attendance:edit']"
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:attendance:remove']"
>删除</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
v-hasPermi="['project:attendance:edit']">修改</el-button>
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
v-hasPermi="['project:attendance:remove']">删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
@pagination="getList" />
<!-- 添加或修改劳务实名制管理对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
@ -186,18 +122,23 @@
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
<attConfigDrawer ref="attDrawer"></attConfigDrawer>
</div>
</template>
<script>
import { listAttendance, getAttendance, delAttendance, addAttendance, updateAttendance } from "@/api/project/attendance";
import { listAttendanceWorker, getAttendanceWorker, delAttendanceWorker, addAttendanceWorker, updateAttendanceWorker, queryAttendanceData } from "@/api/project/attendanceWorker";
import attConfigDrawer from '../attendanceConfig/attendanceConfigDrawer.vue'
export default {
name: "Attendance",
components: {
attConfigDrawer,
},
data() {
return {
//
loading: true,
loading: false,
//
ids: [],
//
@ -216,37 +157,72 @@ export default {
open: false,
//
queryParams: {
vendorsCode:'gld',
pageNum: 1,
pageSize: 10,
vendorsCode: null,
workerId: null,
attendanceType: null,
attendanceTime: null,
deviceCode: null,
workPointId: null,
other: null,
state: null,
isDel: null,
projectId:null,
subDeptId:null,
createBy:new Date()
},
//
form: {},
//
rules: {
}
},
projectOptions: [],
depts: []
};
},
created() {
this.getList();
//this.getList();
this.$api.publics.getMyProjectList({}).then((response) => {
this.projectOptions = response.rows;
});
/*
queryAttendanceData('2023-09-25').then(d=>{
debugger
})*/
},
methods: {
doQuerySub() {
let tmps = this.prjDept2 && this.prjDept2[this.queryParams.projectId] ? this.prjDept2[this.queryParams.projectId] || [] : [];
if (tmps.length > 0) {
this.depts = tmps;
if (tmps.length == 1) {
this.queryParams.subDeptId = tmps[0].deptId;
} else {
this.queryParams.subDeptId = '';
}
return;
}
this.$api.publics.queryUnitList({
projectId: this.queryParams.projectId,
unitTypes: "2".split(","),
}).then((d) => {
let objs = d.rows || [];
if (!this.prjDept2) {
this.prjDept2 = {};
}
this.prjDept2[this.queryParams.projectId] = objs;
this.depts = objs;
if (objs.length == 1) {
this.queryParams.subDeptId = objs[0].deptId;
} else {
this.queryParams.subDeptId = '';
}
});
},
handleSetting() {
this.$refs.attDrawer.show();
},
/** 查询劳务实名制管理列表 */
getList() {
this.loading = true;
listAttendance(this.queryParams).then(response => {
queryAttendanceData(this.queryParams).then(response=>{
this.attendanceList = response.rows;
this.total = response.total;
this.loading = false;
});
})
},
//
cancel() {

View File

@ -0,0 +1,54 @@
<template>
<div class="project-attendance-config-drawer" v-if="isOpen">
<el-drawer v-if="isOpen" :visible.sync="isOpen" direction="rtl" size="70%" style="padding-left: 20px">
<template slot="title">
<div>{{ title + " 【考勤配置】" }}</div>
</template>
<div>
<main-index ref="main"></main-index>
</div>
</el-drawer>
</div>
</template>
<script>
import mainIndex from './index.vue'
export default {
components:{
mainIndex
},
data() {
return {
isOpen: false,
title: '',
};
},
mounted() {
},
methods: {
show() {
this.title = "";
this.isOpen = true;
setTimeout(()=>{
this.$refs.main.init();
},400);
},
},
};
</script>
<style lang="scss" scoped>
.project-attendance-config-drawer {
::v-deep .el-drawer__header {
margin-bottom: 0px;
}
::v-deep .el-drawer__body {
padding: 12px 24px;
}
}
</style>

View File

@ -1,53 +1,17 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="项目编号" prop="projectId">
<el-input
v-model="queryParams.projectId"
placeholder="请输入项目编号"
clearable
@keyup.enter.native="handleQuery"
/>
<el-form-item label="项目名称" prop="projectId">
<el-select v-model="queryParams.projectId" placeholder="请选择项目" clearable @change="doQuerySub">
<el-option v-for="(item, index) in projectOptions" :key="index" :label="item.projectName" :value="item.id">
</el-option>
</el-select>
</el-form-item>
<el-form-item label="总包单位" prop="subDeptId">
<el-input
v-model="queryParams.subDeptId"
placeholder="请输入总包单位"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="厂商编号参考字典attendance_vendors" prop="vendorsCode">
<el-input
v-model="queryParams.vendorsCode"
placeholder="请输入厂商编号参考字典attendance_vendors"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="1-启用,0-停用" prop="enabled">
<el-input
v-model="queryParams.enabled"
placeholder="请输入1-启用,0-停用"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="状态" prop="state">
<el-input
v-model="queryParams.state"
placeholder="请输入状态"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="${comment}" prop="isDel">
<el-input
v-model="queryParams.isDel"
placeholder="请输入${comment}"
clearable
@keyup.enter.native="handleQuery"
/>
<el-select v-model="queryParams.subDeptId" placeholder="请选择总包单位" clearable>
<el-option v-for="(item, index) in depts" :key="index" :label="item.deptName" :value="item.deptId">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
@ -57,116 +21,83 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:attendanceConfig:add']"
>新增</el-button>
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
v-hasPermi="['project:attendanceConfig:add']">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="success"
plain
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['project:attendanceConfig:edit']"
>修改</el-button>
<el-button type="success" plain icon="el-icon-edit" size="mini" :disabled="single" @click="handleUpdate"
v-hasPermi="['project:attendanceConfig:edit']">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="danger"
plain
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['project:attendanceConfig:remove']"
>删除</el-button>
<el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
v-hasPermi="['project:attendanceConfig:remove']">删除</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['project:attendanceConfig:export']"
>导出</el-button>
<el-col :span="1.5" v-if="1 == 2">
<el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
v-hasPermi="['project:attendanceConfig:export']">导出</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="attendanceConfigList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="${comment}" align="center" prop="id" />
<el-table-column label="项目编号" align="center" prop="projectId" />
<el-table-column label="总包单位" align="center" prop="subDeptId" />
<el-table-column label="厂商编号参考字典attendance_vendors" align="center" prop="vendorsCode" />
<el-table-column label="厂商参数" align="center" prop="vendorsParameter" />
<el-table-column label="1-启用,0-停用" align="center" prop="enabled" />
<el-table-column label="状态" align="center" prop="state" />
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="${comment}" align="center" prop="isDel" />
<el-table-column label="对接厂商" align="center" prop="vendorName" />
<el-table-column label="项目名称" align="center" prop="projectName" />
<el-table-column label="总包单位" align="center" prop="unitName" />
<el-table-column label="是否启用" align="center" prop="enabled">
<template slot-scope="{row}">
<el-switch v-model="row.enabled" :active-value="1" @change="doUpdateRow(row)" :inactive-value="0"></el-switch>
</template>
</el-table-column>
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:attendanceConfig:edit']"
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:attendanceConfig:remove']"
>删除</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
v-hasPermi="['project:attendanceConfig:edit']">修改</el-button>
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
v-hasPermi="['project:attendanceConfig:remove']">删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
@pagination="getList" />
<!-- 添加或修改项目考勤配置对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="项目编号" prop="projectId">
<el-input v-model="form.projectId" placeholder="请输入项目编号" />
<el-dialog :title="title" :visible.sync="open" width="800px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-form-item label="项目名称" prop="projectId">
<el-select v-if="mode == 'add'" v-model="form.projectId" placeholder="请选择项目" clearable @change="doQueryFormSub">
<el-option v-for="(item, index) in projectOptions" :key="index" :label="item.projectName" :value="item.id">
</el-option>
</el-select>
<span v-else>{{ form.projectName }}</span>
</el-form-item>
<el-form-item label="总包单位" prop="subDeptId">
<el-input v-model="form.subDeptId" placeholder="请输入总包单位" />
<el-select v-if="mode == 'add'" v-model="form.subDeptId" placeholder="请选择总包单位" clearable>
<el-option v-for="(item, index) in formDepts" :key="index" :label="item.deptName" :value="item.deptId">
</el-option>
</el-select>
<span v-else>{{ form.unitName }}</span>
</el-form-item>
<el-form-item label="厂商编号参考字典attendance_vendors" prop="vendorsCode">
<el-input v-model="form.vendorsCode" placeholder="请输入厂商编号参考字典attendance_vendors" />
<el-tabs v-model="actTab">
<el-tab-pane v-for="(it, idx) in dict.type.attendance_vendors" :key="idx" :label="it.label" :name="it.value">
<el-form-item label="APPID" prop="appId">
<el-input v-model="form.appId" placeholder="请输AppId" clearable />
</el-form-item>
<el-form-item label="厂商参数" prop="vendorsParameter">
<el-input v-model="form.vendorsParameter" type="textarea" placeholder="请输入内容" />
<el-form-item label="Secret" prop="secret">
<el-input v-model="form.secret" placeholder="请输Secret" clearable />
</el-form-item>
<el-form-item label="1-启用,0-停用" prop="enabled">
<el-input v-model="form.enabled" placeholder="请输入1-启用,0-停用" />
<el-form-item label="ProjectId" prop="appProjectId">
<el-input v-model="form.appProjectId" placeholder="请输ProjectId" clearable />
</el-form-item>
<el-form-item label="状态" prop="state">
<el-input v-model="form.state" placeholder="请输入状态" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入备注" />
</el-form-item>
<el-form-item label="${comment}" prop="isDel">
<el-input v-model="form.isDel" placeholder="请输入${comment}" />
<el-form-item label="是否启用" prop="enabled">
<el-radio-group v-model="form.enabled">
<el-radio :label="1">启用</el-radio>
<el-radio :label="0">停用</el-radio>
</el-radio-group>
</el-form-item>
</el-tab-pane>
</el-tabs>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
@ -181,6 +112,7 @@ import { listAttendanceConfig, getAttendanceConfig, delAttendanceConfig, addAtte
export default {
name: "AttendanceConfig",
dicts: ['attendance_vendors'],
data() {
return {
//
@ -214,16 +146,94 @@ export default {
isDel: null,
},
//
form: {},
form: {
projectId: '',
subDeptId: '',
appId: '',
secret: '',
appProjectId: '',
enabled: 0
},
//
rules: {
}
},
projectOptions: [],
depts: [],
formDepts: [],
actTab: '',
mode: '',
};
},
created() {
this.getList();
},
methods: {
doQueryFormSub() {
let prjId = this.form.projectId;
let tmps = this.prjDept2 && this.prjDept2[prjId] ? this.prjDept2[prjId] || [] : [];
if (tmps.length > 0) {
this.formDepts = tmps;
if (tmps.length == 1) {
this.form.subDeptId = tmps[0].deptId;
} else {
this.form.subDeptId = '';
}
return;
}
this.$api.publics.queryUnitList({
projectId: prjId,
unitTypes: "2".split(","),
}).then((d) => {
let objs = d.rows || [];
if (!this.prjDept2) {
this.prjDept2 = {};
}
this.prjDept2[this.queryParams.projectId] = objs;
this.formDepts = objs;
if (objs.length == 1) {
this.form.subDeptId = objs[0].deptId;
} else {
this.form.subDeptId = '';
}
});
},
doQuerySub() {
let tmps = this.prjDept2 && this.prjDept2[this.queryParams.projectId] ? this.prjDept2[this.queryParams.projectId] || [] : [];
if (tmps.length > 0) {
this.depts = tmps;
if (tmps.length == 1) {
this.queryParams.subDeptId = tmps[0].deptId;
} else {
this.queryParams.subDeptId = '';
}
return;
}
this.$api.publics.queryUnitList({
projectId: this.queryParams.projectId,
unitTypes: "2".split(","),
}).then((d) => {
let objs = d.rows || [];
if (!this.prjDept2) {
this.prjDept2 = {};
}
this.prjDept2[this.queryParams.projectId] = objs;
this.depts = objs;
if (objs.length == 1) {
this.queryParams.subDeptId = objs[0].deptId;
} else {
this.queryParams.subDeptId = '';
}
});
},
init() {
if (this.projectOptions && this.projectOptions.length > 0) {
return;
}
this.$api.publics.getMyProjectList({}).then((response) => {
this.projectOptions = response.rows;
});
},
/** 查询项目考勤配置列表 */
getList() {
this.loading = true;
@ -277,30 +287,80 @@ export default {
handleAdd() {
this.reset();
this.open = true;
this.title = "添加项目考勤配置";
this.mode = "add";
this.title = "添加劳务实名制配置";
this.rules = {
projectId: [{ required: true, trigger: "blur", message: "请选择" }],
subDeptId: [{ required: true, trigger: "blur", message: "请选择" }],
appId: [{ required: true, trigger: "blur", message: "请输入" }],
secret: [{ required: true, trigger: "blur", message: "请输入" }],
appProjectId: [{ required: true, trigger: "blur", message: "请输入" }],
enabled: [{ required: true, trigger: "blur", message: "请选择" }]
}
this.actTab = this.dict.type.attendance_vendors[0].value;
setTimeout(()=>{
this.$refs["form"].clearValidate();
},0);
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset();
const id = row.id || this.ids
getAttendanceConfig(id).then(response => {
this.form = response.data;
this.mode = "edit"
let obj = response.data;
let p = obj.vendorsParameter ? this.$tryToJson(obj.vendorsParameter, {}) : {};
obj.appId = p.appId || '';
obj.secret = p.secret || '',
obj.appProjectId = p.projectId || '';
this.form = obj;
this.open = true;
this.title = "修改项目考勤配置";
this.title = "修改劳务实名制配置";
this.actTab = this.dict.type.attendance_vendors[0].value;
this.rules = {
appId: [{ required: true, trigger: "blur", message: "请输入" }],
secret: [{ required: true, trigger: "blur", message: "请输入" }],
appProjectId: [{ required: true, trigger: "blur", message: "请输入" }],
enabled: [{ required: true, trigger: "blur", message: "请选择" }]
}
setTimeout(()=>{
this.$refs["form"].clearValidate();
},400);
});
},
doUpdateRow(row){
updateAttendanceConfig(row).then(response => {
this.$modal.msgSuccess("修改成功");
this.getList();
});
},
/** 提交按钮 */
submitForm() {
this.$refs["form"].validate(valid => {
if (valid) {
let params = {
appId: this.form.appId,
secret: this.form.secret,
projectId: this.form.appProjectId
};
let obj = {
projectId: this.form.projectId,
subDeptId: this.form.subDeptId,
vendorsCode: this.actTab,
vendorsParameter: JSON.stringify(params),
enabled: this.form.enabled,
state: 0,
isDel: 0
};
if (this.form.id != null) {
updateAttendanceConfig(this.form).then(response => {
obj.id = this.form.id;
updateAttendanceConfig(obj).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getList();
});
} else {
addAttendanceConfig(this.form).then(response => {
addAttendanceConfig(obj).then(response => {
this.$modal.msgSuccess("新增成功");
this.open = false;
this.getList();

View File

@ -1,229 +1,101 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="配置项ID,可以获取项目ID和总包ID" prop="cfgid">
<el-input v-model="queryParams.cfgid" placeholder="请输入配置项ID,可以获取项目ID和总包ID" clearable
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="厂商编号参考字典attendance_vendors" prop="vendorsCode">
<el-input v-model="queryParams.vendorsCode" placeholder="请输入厂商编号参考字典attendance_vendors" clearable
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="工人id" prop="workerId">
<el-input
v-model="queryParams.workerId"
placeholder="请输入工人id"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.workerId" placeholder="请输入工人id" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" prop="laborWorkerId">
<el-input
v-model="queryParams.laborWorkerId"
placeholder="请输入项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.laborWorkerId"
placeholder="请输入项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" clearable
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="人员类别0工人1管理人员" prop="workerCategory">
<el-input
v-model="queryParams.workerCategory"
placeholder="请输入人员类别0工人1管理人员"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.workerCategory" placeholder="请输入人员类别0工人1管理人员" clearable
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="工号" prop="qrCode">
<el-input
v-model="queryParams.qrCode"
placeholder="请输入工号"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.qrCode" placeholder="请输入工号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="姓名" prop="name">
<el-input
v-model="queryParams.name"
placeholder="请输入姓名"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.name" placeholder="请输入姓名" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="民族" prop="ethnic">
<el-input
v-model="queryParams.ethnic"
placeholder="请输入民族"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.ethnic" placeholder="请输入民族" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="籍贯" prop="nativePlace">
<el-input
v-model="queryParams.nativePlace"
placeholder="请输入籍贯"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.nativePlace" placeholder="请输入籍贯" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="性别0:男 1:女" prop="gender">
<el-input
v-model="queryParams.gender"
placeholder="请输入性别0:男 1:女"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.gender" placeholder="请输入性别0:男 1:女" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="出生日期时间戳" prop="birthDate">
<el-input
v-model="queryParams.birthDate"
placeholder="请输入出生日期时间戳"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.birthDate" placeholder="请输入出生日期时间戳" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="联系电话" prop="phone">
<el-input
v-model="queryParams.phone"
placeholder="请输入联系电话"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.phone" placeholder="请输入联系电话" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="学历" prop="degreeName">
<el-input
v-model="queryParams.degreeName"
placeholder="请输入学历"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.degreeName" placeholder="请输入学历" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="身份证照" prop="photo">
<el-input
v-model="queryParams.photo"
placeholder="请输入身份证照"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.photo" placeholder="请输入身份证照" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="近照" prop="recentPhoto">
<el-input
v-model="queryParams.recentPhoto"
placeholder="请输入近照"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.recentPhoto" placeholder="请输入近照" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="所属班组ID" prop="groupId">
<el-input
v-model="queryParams.groupId"
placeholder="请输入所属班组ID"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.groupId" placeholder="请输入所属班组ID" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="所属班组" prop="groupName">
<el-input
v-model="queryParams.groupName"
placeholder="请输入所属班组"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.groupName" placeholder="请输入所属班组" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="是否班组长" prop="leader">
<el-input
v-model="queryParams.leader"
placeholder="请输入是否班组长"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.leader" placeholder="请输入是否班组长" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="工种编码" prop="workTypeCode">
<el-input
v-model="queryParams.workTypeCode"
placeholder="请输入工种编码"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.workTypeCode" placeholder="请输入工种编码" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="工种" prop="workTypeName">
<el-input
v-model="queryParams.workTypeName"
placeholder="请输入工种"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.workTypeName" placeholder="请输入工种" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="安全帽编号" prop="hatCode">
<el-input
v-model="queryParams.hatCode"
placeholder="请输入安全帽编号"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.hatCode" placeholder="请输入安全帽编号" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="进退场状态0:进场1:退场" prop="state">
<el-input
v-model="queryParams.state"
placeholder="请输入进退场状态0:进场1:退场"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.state" placeholder="请输入进退场状态0:进场1:退场" clearable
@keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="进场日期" prop="enterDate">
<el-input
v-model="queryParams.enterDate"
placeholder="请输入进场日期"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.enterDate" placeholder="请输入进场日期" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="退场日期" prop="exitDate">
<el-input
v-model="queryParams.exitDate"
placeholder="请输入退场日期"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.exitDate" placeholder="请输入退场日期" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="分包商id" prop="companyId">
<el-input
v-model="queryParams.companyId"
placeholder="请输入分包商id"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.companyId" placeholder="请输入分包商id" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="分包商名称" prop="companyName">
<el-input
v-model="queryParams.companyName"
placeholder="请输入分包商名称"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.companyName" placeholder="请输入分包商名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="平台对应分包商ID" prop="vendorId">
<el-input
v-model="queryParams.vendorId"
placeholder="请输入平台对应分包商ID"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.vendorId" placeholder="请输入平台对应分包商ID" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="队伍id" prop="teamId">
<el-input
v-model="queryParams.teamId"
placeholder="请输入队伍id"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.teamId" placeholder="请输入队伍id" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="队伍名称" prop="teamName">
<el-input
v-model="queryParams.teamName"
placeholder="请输入队伍名称"
clearable
@keyup.enter.native="handleQuery"
/>
<el-input v-model="queryParams.teamName" placeholder="请输入队伍名称" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item label="${comment}" prop="isDel">
<el-input
v-model="queryParams.isDel"
placeholder="请输入${comment}"
clearable
@keyup.enter.native="handleQuery"
/>
<el-form-item label="" prop="isDel">
<el-input v-model="queryParams.isDel" placeholder="请输入" clearable @keyup.enter.native="handleQuery" />
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
@ -233,55 +105,32 @@
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['project:attendanceWorker:add']"
>新增</el-button>
<el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd"
v-hasPermi="['project:attendanceWorker:add']">新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="success"
plain
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['project:attendanceWorker:edit']"
>修改</el-button>
<el-button type="success" plain icon="el-icon-edit" size="mini" :disabled="single" @click="handleUpdate"
v-hasPermi="['project:attendanceWorker:edit']">修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="danger"
plain
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['project:attendanceWorker:remove']"
>删除</el-button>
<el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
v-hasPermi="['project:attendanceWorker:remove']">删除</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['project:attendanceWorker:export']"
>导出</el-button>
<el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
v-hasPermi="['project:attendanceWorker:export']">导出</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="attendanceWorkerList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="${comment}" align="center" prop="id" />
<el-table-column label="" align="center" prop="id" />
<el-table-column label="配置项ID,可以获取项目ID和总包ID" align="center" prop="cfgid" />
<el-table-column label="厂商编号参考字典attendance_vendors" align="center" prop="vendorsCode" />
<el-table-column label="工人id" align="center" prop="workerId" />
<el-table-column label="项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" align="center" prop="laborWorkerId" />
<el-table-column label="项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" align="center"
prop="laborWorkerId" />
<el-table-column label="人员类别0工人1管理人员" align="center" prop="workerCategory" />
<el-table-column label="工号" align="center" prop="qrCode" />
<el-table-column label="姓名" align="center" prop="name" />
@ -311,43 +160,35 @@
<el-table-column label="进场方式0:自动,1:手动2:拍照" align="center" prop="enterType" />
<el-table-column label="服务返回的JSON" align="center" prop="other" />
<el-table-column label="备注" align="center" prop="remark" />
<el-table-column label="${comment}" align="center" prop="isDel" />
<el-table-column label="" align="center" prop="isDel" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['project:attendanceWorker:edit']"
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['project:attendanceWorker:remove']"
>删除</el-button>
<el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
v-hasPermi="['project:attendanceWorker:edit']">修改</el-button>
<el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
v-hasPermi="['project:attendanceWorker:remove']">删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
@pagination="getList" />
<!-- 添加或修改考勤人员基本属性对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="配置项ID,可以获取项目ID和总包ID" prop="cfgid">
<el-input v-model="form.cfgid" placeholder="请输入配置项ID,可以获取项目ID和总包ID" />
</el-form-item>
<el-form-item label="厂商编号参考字典attendance_vendors" prop="vendorsCode">
<el-input v-model="form.vendorsCode" placeholder="请输入厂商编号参考字典attendance_vendors" />
</el-form-item>
<el-form-item label="工人id" prop="workerId">
<el-input v-model="form.workerId" placeholder="请输入工人id" />
</el-form-item>
<el-form-item label="项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" prop="laborWorkerId">
<el-input v-model="form.laborWorkerId" placeholder="请输入项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" />
<el-input v-model="form.laborWorkerId"
placeholder="请输入项目工人履历id对于旧劳务这个字段相当于工人的projectWorkerId管理人员的registerManagerId" />
</el-form-item>
<el-form-item label="人员类别0工人1管理人员" prop="workerCategory">
<el-input v-model="form.workerCategory" placeholder="请输入人员类别0工人1管理人员" />
@ -430,8 +271,8 @@
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" placeholder="请输入备注" />
</el-form-item>
<el-form-item label="${comment}" prop="isDel">
<el-input v-model="form.isDel" placeholder="请输入${comment}" />
<el-form-item label="" prop="isDel">
<el-input v-model="form.isDel" placeholder="请输入" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
@ -443,7 +284,7 @@
</template>
<script>
import { listAttendanceWorker, getAttendanceWorker, delAttendanceWorker, addAttendanceWorker, updateAttendanceWorker } from "@/api/project/attendanceWorker";
import { listAttendanceWorker, getAttendanceWorker, delAttendanceWorker, addAttendanceWorker, updateAttendanceWorker,queryAttendanceData } from "@/api/project/attendanceWorker";
export default {
name: "AttendanceWorker",
@ -471,6 +312,8 @@ export default {
queryParams: {
pageNum: 1,
pageSize: 10,
cfgid: null,
vendorsCode: null,
workerId: null,
laborWorkerId: null,
workerCategory: null,
@ -518,6 +361,10 @@ export default {
},
created() {
this.getList();
debugger
queryAttendanceData('2023-09-25').then(d=>{
debugger
})
},
methods: {
/** 查询考勤人员基本属性列表 */
@ -538,6 +385,8 @@ export default {
reset() {
this.form = {
id: null,
cfgid: null,
vendorsCode: null,
workerId: null,
laborWorkerId: null,
workerCategory: null,

View File

@ -76,6 +76,7 @@ export default {
data() {
return {
elKey: 0,
title:'',
isOpen: false,
prj: null,
//

View File

@ -2,6 +2,8 @@ package com.yanzhu.jh.project.controller;
import java.util.List;
import javax.servlet.http.HttpServletResponse;
import com.yanzhu.jh.project.domain.SurProjectAttendanceCfg;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
@ -101,4 +103,11 @@ public class SurProjectAttendanceUserController extends BaseController
{
return toAjax(surProjectAttendanceUserService.deleteSurProjectAttendanceUserByIds(ids));
}
@PostMapping("/queryAttendanceData")
public TableDataInfo queryAttendanceData(@RequestBody SurProjectAttendanceCfg where){
startPage();
List<SurProjectAttendanceUser> list =surProjectAttendanceUserService.queryAttendanceData(where);
return getDataTable(list);
}
}

View File

@ -6,6 +6,8 @@ import org.apache.commons.lang3.builder.ToStringStyle;
import com.ruoyi.common.annotation.Excel;
import com.ruoyi.common.core.domain.BaseEntity;
import java.util.Date;
/**
* sur_project_attendance_user
*
@ -150,6 +152,26 @@ public class SurProjectAttendanceUser extends BaseEntity
/** */
@Excel(name = "")
private Long isDel;
private Date inTime;
private Date outTime;
public Date getInTime() {
return inTime;
}
public void setInTime(Date inTime) {
this.inTime = inTime;
}
public Date getOutTime() {
return outTime;
}
public void setOutTime(Date outTime) {
this.outTime = outTime;
}
public static SurProjectAttendanceUser create(JSONObject json) {
SurProjectAttendanceUser u=new SurProjectAttendanceUser();
u.workerId=json.getLong("workerId");

View File

@ -1,6 +1,8 @@
package com.yanzhu.jh.project.mapper;
import java.util.List;
import com.yanzhu.jh.project.domain.SurProjectAttendanceCfg;
import com.yanzhu.jh.project.domain.SurProjectAttendanceUser;
/**
@ -58,4 +60,6 @@ public interface SurProjectAttendanceUserMapper
* @return
*/
public int deleteSurProjectAttendanceUserByIds(Long[] ids);
public List<SurProjectAttendanceUser> queryAttendanceData(SurProjectAttendanceCfg where);
}

View File

@ -1,6 +1,8 @@
package com.yanzhu.jh.project.service;
import java.util.List;
import com.yanzhu.jh.project.domain.SurProjectAttendanceCfg;
import com.yanzhu.jh.project.domain.SurProjectAttendanceUser;
/**
@ -60,4 +62,6 @@ public interface ISurProjectAttendanceUserService
public int deleteSurProjectAttendanceUserById(Long id);
public void add(SurProjectAttendanceUser user);
public List<SurProjectAttendanceUser> queryAttendanceData(SurProjectAttendanceCfg where);
}

View File

@ -2,6 +2,7 @@ package com.yanzhu.jh.project.service.impl;
import java.util.List;
import com.ruoyi.common.utils.DateUtils;
import com.yanzhu.jh.project.domain.SurProjectAttendanceCfg;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.yanzhu.jh.project.mapper.SurProjectAttendanceUserMapper;
@ -110,4 +111,9 @@ public class SurProjectAttendanceUserServiceImpl implements ISurProjectAttendanc
updateSurProjectAttendanceUser(user);
}
}
@Override
public List<SurProjectAttendanceUser> queryAttendanceData(SurProjectAttendanceCfg where) {
return surProjectAttendanceUserMapper.queryAttendanceData(where);
}
}

View File

@ -233,4 +233,41 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
#{id}
</foreach>
</delete>
<sql id="sqlAttendanceData">
(
SELECT * FROM sur_project_attendance_data WHERE DATE(attendance_time)=date(#{createBy}) AND cfgid IN (
SELECT id FROM sur_project_attendance_cfg WHERE project_id=#{projectId} AND sub_dept_id=#{subDeptId} AND vendors_code=#{vendorsCode}
) ) xx
</sql>
<select id="queryAttendanceData" parameterType="SurProjectAttendanceCfg" resultMap="SurProjectAttendanceUserResult">
select n.*,m.inTime,m.outTime from (
SELECT * FROM (
SELECT workerId,attendance_time inTime,null outtime FROM sur_project_attendance_data WHERE id IN (
SELECT min(id) id FROM <include refid="sqlAttendanceData"/> WHERE attendance_type='e' GROUP BY workerId )) X WHERE workerId NOT IN (
SELECT workerId FROM <include refid="sqlAttendanceData"/> WHERE attendance_type='l' GROUP BY workerId
)
union
select * from (
select workerId,null inTime,attendance_time outTime from sur_project_attendance_data where id in (
select max(id) id from <include refid="sqlAttendanceData"/> where attendance_type='l' group by workerId )) x where workerId not in (
SELECT workerId FROM <include refid="sqlAttendanceData"/> WHERE attendance_type='e' GROUP BY workerId
)
union
select x.workerId,y.attendance_time inTime,x.attendance_time outTime from (
SELECT id,workerId,attendance_time FROM sur_project_attendance_data WHERE id IN (
SELECT MAX(id) id FROM <include refid="sqlAttendanceData"/> WHERE attendance_type='l' GROUP BY workerId )
) x cross join (
SELECT id,workerId,attendance_time FROM sur_project_attendance_data WHERE id IN (
SELECT MIN(id) id FROM <include refid="sqlAttendanceData"/> WHERE attendance_type='e' GROUP BY workerId )
) y on x.workerId=y.workerId
) m left join sur_project_attendance_user n on m.workerId=n.workerId
</select>
</mapper>