2025-11-27 16:55:35 +08:00
|
|
|
|
var example = null;
|
|
|
|
|
|
var pers = null;
|
|
|
|
|
|
$(function () {
|
|
|
|
|
|
layui.use(['layer', 'laydate', 'form'], function () {
|
|
|
|
|
|
var layer = layui.layer;
|
|
|
|
|
|
var laydate = layui.laydate;
|
|
|
|
|
|
var form = layui.form;
|
|
|
|
|
|
getPro(form);
|
|
|
|
|
|
pers = checkPermission();
|
2025-12-03 18:14:07 +08:00
|
|
|
|
|
|
|
|
|
|
var today = getNowTime(); // 假设你的 getNowTime() 返回 'yyyy-MM-dd' 格式
|
|
|
|
|
|
$('#test6').val(today + ' - ' + today);
|
|
|
|
|
|
// $('#test6').val('2025-09-01' + ' - ' + '2025-09-29');
|
|
|
|
|
|
laydate.render({
|
|
|
|
|
|
elem: '#test6',
|
|
|
|
|
|
range: true,
|
|
|
|
|
|
min: $('#hidMinListDate').val(),
|
|
|
|
|
|
max: $('#hidMaxListDate').val()
|
2025-11-27 16:55:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
|
2025-12-03 18:14:07 +08:00
|
|
|
|
|
2025-11-27 16:55:35 +08:00
|
|
|
|
$("#searchBt").click(function () {
|
2025-12-03 18:14:07 +08:00
|
|
|
|
var dateRange = $.trim($('#test6').val());
|
|
|
|
|
|
if (!dateRange) {
|
|
|
|
|
|
return layer.msg('请选择日期范围', { icon: 2, time: 2000 });
|
2025-11-27 16:55:35 +08:00
|
|
|
|
}
|
|
|
|
|
|
example.ajax.reload();
|
|
|
|
|
|
});
|
2025-12-03 18:14:07 +08:00
|
|
|
|
init();
|
2025-11-27 16:55:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
function init() {
|
|
|
|
|
|
example =
|
|
|
|
|
|
$('#dt-table').DataTable({
|
|
|
|
|
|
"searching": false,
|
|
|
|
|
|
"processing": true, //加载数据时显示进度状态
|
|
|
|
|
|
"serverSide": true,
|
|
|
|
|
|
"language": {
|
2025-12-02 14:22:34 +08:00
|
|
|
|
"url": contentPath + "/js/plugin/datatables/Chinese.lang"
|
2025-11-27 16:55:35 +08:00
|
|
|
|
},
|
|
|
|
|
|
"ajax": {
|
|
|
|
|
|
"url": ctxPath + "/faceContrast",
|
|
|
|
|
|
"type": "get",
|
|
|
|
|
|
"data": function (d) {
|
2025-12-03 18:14:07 +08:00
|
|
|
|
var dateRange = $.trim($('#test6').val());
|
|
|
|
|
|
var parts = dateRange.split(' - ');
|
|
|
|
|
|
var startTime = parts[0];
|
|
|
|
|
|
var endTime = parts[1];
|
|
|
|
|
|
|
|
|
|
|
|
|
2025-11-27 16:55:35 +08:00
|
|
|
|
d.name = $("#name").val();
|
|
|
|
|
|
d.subName = $("#subName").val();
|
|
|
|
|
|
d.teamName = $("#teamName").val();
|
|
|
|
|
|
|
|
|
|
|
|
d.proId = $("#proId").val();
|
|
|
|
|
|
d.status = $("#status").val();
|
2025-12-03 18:14:07 +08:00
|
|
|
|
d.startTime = startTime;
|
|
|
|
|
|
d.endTime = endTime;
|
2025-11-27 16:55:35 +08:00
|
|
|
|
},
|
|
|
|
|
|
"error": function (xhr, textStatus, errorThrown) {
|
|
|
|
|
|
var msg = xhr.responseText;
|
|
|
|
|
|
var response = JSON.parse(msg);
|
|
|
|
|
|
var code = response.code;
|
|
|
|
|
|
var message = response.message;
|
|
|
|
|
|
if (code == 400) {
|
|
|
|
|
|
layer.msg(message);
|
|
|
|
|
|
} else if (code == 401) {
|
|
|
|
|
|
localStorage.removeItem("token");
|
|
|
|
|
|
layer.msg("token过期,请先登录", {shift: -1, time: 1000}, function () {
|
|
|
|
|
|
location.href = ctxPath + '/login.html';
|
|
|
|
|
|
});
|
|
|
|
|
|
} else if (code == 403) {
|
|
|
|
|
|
console.log("未授权:" + message);
|
|
|
|
|
|
layer.msg('未授权');
|
|
|
|
|
|
} else if (code == 500) {
|
|
|
|
|
|
console.log('系统错误:' + message);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
"lengthMenu": [ [10, 20, 50], [10, 20, 50] ], // 设置每页显示数据量选项
|
|
|
|
|
|
"drawCallback": function() {
|
|
|
|
|
|
// alert( '表格重绘了' );
|
|
|
|
|
|
var thisDataTable = $('#dt-table').DataTable();
|
|
|
|
|
|
$(".pagination").append("<li>" +
|
|
|
|
|
|
"<a class='paginate_button' style='padding:4px;' href='#' tabindex='0'>到 <input style='margin:0px;width:40px;' id='changePage'> 页</a>" +
|
|
|
|
|
|
"<a class='paginate_button' style='margin-bottom:1px' href='#' tabindex='0' id='dataTable-btn'>确认</a></li>");
|
|
|
|
|
|
//点击按钮跳转指定页数
|
|
|
|
|
|
$('#dataTable-btn').click(function (e) {
|
|
|
|
|
|
if ($("#changePage").val() && $("#changePage").val() > 0) {
|
|
|
|
|
|
var redirectpage = $("#changePage").val() - 1;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
var redirectpage = 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
thisDataTable.page(redirectpage).draw( 'page' );
|
|
|
|
|
|
});
|
|
|
|
|
|
//敲击回车键跳转指定页数
|
|
|
|
|
|
$("#changePage").keypress(function (e) {
|
|
|
|
|
|
if(event.keyCode==13){
|
|
|
|
|
|
if ($("#changePage").val() && $("#changePage").val() > 0) {
|
|
|
|
|
|
var redirectpage = $("#changePage").val() - 1;
|
|
|
|
|
|
} else {
|
|
|
|
|
|
var redirectpage = 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
thisDataTable.page(redirectpage).draw( 'page' );
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
},
|
|
|
|
|
|
"dom": "<'dt-toolbar'r>t<'dt-toolbar-footer'<'col-sm-4 col-xs-4 hidden-xs'i><'col-xs-8 col-sm-8' p v>><'dt-table-length'l>",
|
|
|
|
|
|
"columns": [
|
|
|
|
|
|
{
|
|
|
|
|
|
width: '5%',
|
|
|
|
|
|
"orderable": false,
|
|
|
|
|
|
data: function (row, type, set, meta) {
|
|
|
|
|
|
var c = meta.settings._iDisplayStart + meta.row + 1;
|
|
|
|
|
|
return c;
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2025-12-03 18:14:07 +08:00
|
|
|
|
{"data": "name","orderable": false,width: '6%'},
|
|
|
|
|
|
{"data": "","orderable": false,width: '8%',
|
2025-11-27 16:55:35 +08:00
|
|
|
|
"render": function (data, type, row) {
|
|
|
|
|
|
var idNumber = row['idNumber'];
|
|
|
|
|
|
return decryptCBC(idNumber);
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
2025-12-03 18:14:07 +08:00
|
|
|
|
{"data": "postName","orderable": false,width: '6%'},
|
|
|
|
|
|
{"data": "proName","orderable": false,width: '10%'},
|
|
|
|
|
|
{"data": "status","orderable": false,width: '6%'},
|
|
|
|
|
|
{"data": "subName","orderable": false,width: '10%'},
|
|
|
|
|
|
{"data": "teamName","orderable": false,width: '10%'},
|
2025-11-27 16:55:35 +08:00
|
|
|
|
{"data": "dayNum","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "countingNum","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "idleWorkNum","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "notWorkHours","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "breakWork","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "gz","orderable": false,width: '5%'},
|
|
|
|
|
|
{"data": "jx","orderable": false,width: '5%'},
|
|
|
|
|
|
{
|
|
|
|
|
|
"data": "",
|
|
|
|
|
|
"defaultContent": "",width: '5%',
|
|
|
|
|
|
"orderable": false,
|
|
|
|
|
|
"render": function (data, type, row) {
|
|
|
|
|
|
var proId = row['proId'];
|
|
|
|
|
|
var teamId = row['teamId'];
|
|
|
|
|
|
var subId = row['subId'];
|
|
|
|
|
|
var postId = row['postId'];
|
|
|
|
|
|
var idNumber = row['idNumber'];
|
|
|
|
|
|
var name = row['name'];
|
|
|
|
|
|
var proName = row['proName'];
|
|
|
|
|
|
var exitTime = row['exitTime'];
|
|
|
|
|
|
var einTime = row['einTime'];
|
|
|
|
|
|
var gz = row['gz'];
|
|
|
|
|
|
var effectDate = row['effectDate'];
|
|
|
|
|
|
var html = '';
|
|
|
|
|
|
// sys:project:view
|
|
|
|
|
|
html += buttonView(exitTime,einTime,idNumber,proId,name,proName,subId,teamId, gz,effectDate,postId,"", pers);
|
|
|
|
|
|
return html;
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
],
|
2025-12-03 18:14:07 +08:00
|
|
|
|
"order": [] //在栏目列上显示排序功能
|
2025-11-27 16:55:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 查看
|
|
|
|
|
|
* */
|
|
|
|
|
|
function view(exitTime,einTime,idNumber,proId,name,proName,subId,teamId,gz,effectDate,postId) {
|
2025-12-03 18:14:07 +08:00
|
|
|
|
var dateRange = $.trim($('#test6').val());
|
|
|
|
|
|
var parts = dateRange.split(' - ');
|
|
|
|
|
|
var startTime = parts[0];
|
|
|
|
|
|
var endTime = parts[1];
|
2025-11-27 16:55:35 +08:00
|
|
|
|
localStorage.setItem("startTime",startTime);
|
|
|
|
|
|
localStorage.setItem("endTime",endTime);
|
|
|
|
|
|
localStorage.setItem("idNumber", decryptCBC(idNumber));
|
|
|
|
|
|
localStorage.setItem("proId", proId);
|
|
|
|
|
|
localStorage.setItem("name", name);
|
|
|
|
|
|
localStorage.setItem("subId", subId);
|
|
|
|
|
|
localStorage.setItem("teamId", teamId);
|
|
|
|
|
|
localStorage.setItem("exitTime", exitTime);
|
|
|
|
|
|
localStorage.setItem("einTime", einTime);
|
|
|
|
|
|
localStorage.setItem("gz", gz);
|
|
|
|
|
|
localStorage.setItem("effectDate", effectDate);
|
|
|
|
|
|
localStorage.setItem("postId", postId);
|
|
|
|
|
|
var index = layer.open({
|
|
|
|
|
|
title: false,
|
|
|
|
|
|
type: 2,
|
|
|
|
|
|
content: './faceContrastDetail.html',
|
2025-12-03 18:14:07 +08:00
|
|
|
|
area: ['75%', '75%'],
|
|
|
|
|
|
maxmin: false,
|
|
|
|
|
|
success: function (layero, index) {
|
|
|
|
|
|
var iframe = layero.find('iframe')[0];
|
|
|
|
|
|
if (iframe && iframe.contentWindow) {
|
|
|
|
|
|
iframe.contentWindow.setFaceData();
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
2025-11-27 16:55:35 +08:00
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// 详情按钮
|
|
|
|
|
|
function buttonView(exitTime,einTime,idNumber,proId,name,proName,subId,teamId,gz,effectDate, postId, permission, pers) {
|
|
|
|
|
|
if (permission != "") {
|
|
|
|
|
|
if ($.inArray(permission, pers) < 0) {
|
|
|
|
|
|
return "";
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2025-12-03 18:14:07 +08:00
|
|
|
|
var btn = $("<button class='layui-btn layui-btn-xs' title='详情' onclick='view(\"" + exitTime + "\",\"" + einTime + "\",\"" + idNumber + "\",\"" + proId + "\",\"" + name + "\",\"" + proName + "\",\"" + subId + "\",\"" + teamId + "\",\"" + gz + "\",\"" + effectDate + "\",\"" + postId + "\")' style='background-color: transparent;color: #009688;'>详情</button>");
|
2025-11-27 16:55:35 +08:00
|
|
|
|
return btn.prop("outerHTML");
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 导出数据
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 下载
|
|
|
|
|
|
*/
|
|
|
|
|
|
function downloadWorks() {
|
|
|
|
|
|
var token = localStorage.getItem("token");
|
|
|
|
|
|
var name = $("#name").val();
|
|
|
|
|
|
var teamName = $("#teamName").val();
|
|
|
|
|
|
var subName = $("#subName").val();
|
|
|
|
|
|
var proId = $("#proId").val();
|
|
|
|
|
|
var status = $("#status").val();
|
2025-12-03 18:14:07 +08:00
|
|
|
|
|
|
|
|
|
|
var dateRange = $.trim($('#test6').val());
|
|
|
|
|
|
var parts = dateRange.split(' - ');
|
|
|
|
|
|
var startTime = parts[0];
|
|
|
|
|
|
var endTime = parts[1];
|
2025-11-27 16:55:35 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var loadingMsg = layer.msg('下载中,请稍候...', {icon: 16, scrollbar: false, time: 0});
|
|
|
|
|
|
var url = ctxPath + "/faceContrast/exportWorkerAttendanceDownload?name=" + name + "&teamName=" + teamName+ "&subName=" + subName+ "&proId=" + proId+ "&status=" + status+ "&startTime=" + startTime+"&endTime=" + endTime+ "&token=" + token;
|
|
|
|
|
|
var xhr = new XMLHttpRequest();
|
|
|
|
|
|
xhr.open("get", url, true);
|
|
|
|
|
|
xhr.responseType = "blob"; // 转换流
|
|
|
|
|
|
xhr.onload = function () {
|
|
|
|
|
|
layer.close(loadingMsg);
|
|
|
|
|
|
if (this.status === 200) {
|
|
|
|
|
|
var blob = this.response;
|
|
|
|
|
|
var a = document.createElement("a");
|
|
|
|
|
|
var url = window.URL.createObjectURL(blob);
|
|
|
|
|
|
a.href = url;
|
|
|
|
|
|
a.download = "施工人员考勤信息-"+startTime+"~"+endTime+".xlsx"; // 文件名
|
|
|
|
|
|
}else {
|
|
|
|
|
|
layer.msg('发生异常,请稍后重试', {icon: 16, scrollbar: false, time: 2000});
|
|
|
|
|
|
}
|
|
|
|
|
|
a.click()
|
|
|
|
|
|
window.URL.revokeObjectURL(url)
|
|
|
|
|
|
};
|
|
|
|
|
|
xhr.send();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 获得当前时间 yyyy-MM-dd
|
|
|
|
|
|
* @returns {string}
|
|
|
|
|
|
*/
|
|
|
|
|
|
function getNowTime() {
|
|
|
|
|
|
var time = new Date();
|
|
|
|
|
|
var year = time.getFullYear();
|
|
|
|
|
|
var month = time.getMonth() + 1 >= 10 ? time.getMonth() + 1 : '0' + (time.getMonth() + 1);
|
|
|
|
|
|
var day = time.getDate() >= 10 ? time.getDate() : '0' + time.getDate();
|
|
|
|
|
|
return year + "-" + month + "-" + day;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* 获取当月第一天
|
|
|
|
|
|
* @returns {string}
|
|
|
|
|
|
*/
|
|
|
|
|
|
function getCurrentMonthFirst() {
|
|
|
|
|
|
var date = new Date();
|
|
|
|
|
|
date.setDate(1);
|
|
|
|
|
|
var year = date.getFullYear();
|
|
|
|
|
|
var month = date.getMonth() + 1 > 10 ? date.getMonth() + 1 : '0' + (date.getMonth() + 1);
|
|
|
|
|
|
var day = date.getDate() < 10 ? "0" + date.getDate() : date.getDate();
|
|
|
|
|
|
return year + "-" + month + "-" + day;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function getPro(form) {
|
|
|
|
|
|
$("#proId").empty();
|
|
|
|
|
|
$.ajax({
|
|
|
|
|
|
type: 'post',
|
|
|
|
|
|
url: ctxPath + '/users/getProInfo',
|
|
|
|
|
|
data: {
|
|
|
|
|
|
},
|
|
|
|
|
|
async: false,
|
|
|
|
|
|
success: function (data) {
|
|
|
|
|
|
var html = '<option value="">--请选择工程--</option>';
|
|
|
|
|
|
for (var i = 0; i < data.length; i++) {
|
|
|
|
|
|
html += '<option value="' + data[i].proId + '">' + data[i].proName + '</option>';
|
|
|
|
|
|
}
|
|
|
|
|
|
$("#proId").html(html);
|
|
|
|
|
|
form.render();
|
|
|
|
|
|
},
|
|
|
|
|
|
error: function (err) {
|
|
|
|
|
|
console.log("获取工程下拉列表出错:", err);
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
2025-12-03 18:14:07 +08:00
|
|
|
|
}
|