var example = null; var pers = null; var tokens = localStorage.getItem("token"); var ballIndex = localStorage.getItem("ballIndex"); var puid = localStorage.getItem("puid"); $(function () { layui.use(['layer', 'laydate', 'form'], function () { var layer = layui.layer; var laydate = layui.laydate; var form = layui.form; var minListDate = $('#hidMinListDate').val();//最小可选时间,例:1990-02-01 var maxListDate = $('#hidMaxListDate').val();//最大可选时间,例:2200-12-31 var begin = "#startTime", end = "#endTime";//开始时间选择框、结束时间选择框:文本框 var endChange = function (val, date) { if (date && date.year) begindate.config.max = { year: date.year, month: date.month - 1,//必须减1才是正确值 date: date.date, hours: date.hours, minutes: date.minutes, seconds: date.seconds }; else { var dateInit = new Date(maxListDate.replace(/-/g, "/")); begindate.config.max = { year: dateInit.getFullYear(), month: dateInit.getMonth(), date: dateInit.getDate(), hours: dateInit.getHours(), minutes: dateInit.getMinutes(), seconds: dateInit.getSeconds() }; } }; var beginChange = function (val, date) { if (date && date.year) enddate.config.min = { year: date.year, month: date.month - 1, date: date.date, hours: date.hours, minutes: date.minutes, seconds: date.seconds }; else { var dateInit = new Date(minListDate.replace(/-/g, "/")); enddate.config.min = { year: dateInit.getFullYear(), month: dateInit.getMonth(), date: dateInit.getDate(), hours: dateInit.getHours(), minutes: dateInit.getMinutes(), seconds: dateInit.getSeconds() }; } }; var enddate = laydate.render({ elem: end, format: 'yyyy-MM-dd', min: minListDate, max: maxListDate, done: endChange }); var begindate = laydate.render({ elem: begin, format: 'yyyy-MM-dd', min: minListDate, max: maxListDate, done: beginChange }); $("#searchBt").click(function () { var startTime = $("#startTime").val(); var endTime = $("#endTime").val(); var dateStart = new Date(startTime); var dateEnd = new Date(endTime); var difValue = (dateEnd - dateStart) / (1000 * 60 * 60 * 24); var startDateTemp = startTime.split("-"); var endDateTemp = endTime.split("-"); var allStartDate = new Date(startDateTemp[0], startDateTemp[1], startDateTemp[2]); var allEndDate = new Date(endDateTemp[0], endDateTemp[1], endDateTemp[2]); if (allStartDate.getTime() > allEndDate.getTime()) { return top.layer.msg('时间选择不合理,请重新选择', { icon: 2, time: 2000 //2秒关闭(如果不配置,默认是3秒) }); } example.ajax.reload(); }); init(); }); $("#searchBt").click(function () { example.ajax.reload(); }); //导出 $("#exportBt").click(function () { exportBtn(); }); }) function init() { example = $('#dt-table').DataTable({ "sort": false, "searching": false, "processing": true, //加载数据时显示进度状态 "serverSide": true, 'scrollY': 'calc(100vh - 150px)', 'scroller': true, 'scrollCollapse':true, "language": { "url": ctxPath + "/js/plugin/datatables/Chinese.lang" }, "ajax": { "url": ctxPath + "/eventQueryDevice", "type": "get", "data": function (d) { d.data = $("#data").val(); d.ballIndex = ballIndex; d.puid = puid; d.startTime = $("#startTime").val(); d.endTime = $("#endTime").val(); }, "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); } } }, "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>>", "columns": [ { "data": null, "width": "10%", "bSortable": false, render: function (data, type, full, meta) { var node = ''; var checkedStatus = data['checkedStatus']; node = ''; if (checkedStatus == 1) { node = ''; } return node; } }, {"data": "deviceName",width: '15%'}, {"data": "cameraName",width: '15%'}, {"data": "type1",width: '10%'}, {"data": "onlineTime",width: '10%',}, {"data": "type2",width: '15%'}, {"data": "offlineTime",width: '10%', "render": function (data, type, row ) { var offlineTime =row.offlineTime; if(offlineTime==null || offlineTime==''){ return '/'; } else{ return offlineTime; } } }, {"data": "onlineDuration",width: '15%', "render": function (data, type, row) { var dat1 =row.onlineTime; var dat2 =row.offlineTime; if(dat2==null || dat2==''){ var dat2=getCurrentDate(); return getTime(dat1,dat2); } else{ return getTime(dat1,dat2); } } }, ], "fnInitComplete":function () { // 防止页面闪烁 $('.table').css('display',''); //自动调整列宽 let table = $('#dt-table').DataTable(); table.columns.adjust().draw(); }, "order": [[0, "desc"], [1, "asc"]] //在栏目列上显示排序功能 }); } /** * 导出数据 */ function exportBtn() { var id = null; var selected = []; // 选中导出的数据 var oTable = $('#dt-table').dataTable(); var rowcollection = oTable.$(".checkall:checked", {"page": "all"}); rowcollection.each(function (index, elem) { var checkbox_value = $(elem).val(); selected.push(checkbox_value); }); if (selected.length == 0) { return layer.msg("请勾选要导出的数据", {icon: 7, time: 2000}); } id = selected.toString(); window.location.href = ctxPath + "/eventQueryDevice/exportEventQueryDevice?id=" + id + "&token=" + tokens; } /** * 获得当前时间 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; } function getTime(dt1,dt2){ console.log("测试数据"); var regTime = /(\d{4})-(\d{1,2})-(\d{1,2})( \d{1,2}:\d{1,2})/g; var interval = Math.abs(Date.parse(dt1.replace(regTime, "$2-$3-$1$4")) - Date.parse(dt2.replace(regTime, "$2-$3-$1$4")))/1000; var h = Math.floor(interval / 3600); var m = Math.floor(interval % 3600 / 60); if(h==0){ return m+"分钟"; } return h+'小时'+m+"分"; } function getCurrentDate() { var d = new Date() var year = d.getFullYear() var month = d.getMonth() month = month + 1 > 12 ? 1 : month + 1 month = month > 9 ? month : '0' + month.toString() var day = d.getDate() var hour = d.getHours() hour = hour > 9 ? hour : '0' + hour.toString() var minute = d.getMinutes() minute = minute > 9 ? minute : '0' + minute.toString() var second = d.getSeconds() return `${year}-${month}-${day} ${hour}:${minute}:${second}` }