DataList.html 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127
  1. <!DOCTYPE html>
  2. <html class="x-admin-sm">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="renderer" content="webkit">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  7. <meta name="viewport"
  8. content="width=device-width,user-scalable=yes, minimum-scale=0.4, initial-scale=0.8,target-densitydpi=low-dpi"/>
  9. <link rel="shortcut icon" href="/static/favicon.ico">
  10. <link rel="bookmark" href="/static/favicon.ico">
  11. <link rel="stylesheet" href="/static/css/font.css">
  12. <link rel="stylesheet" href="/static/css/xadmin.css">
  13. <script src="/static/js/jquery.min.js"></script>
  14. <script src="/static/js/jquery.cookie.min.js"></script>
  15. <script src="/static/lib/layui/layui.js" charset="utf-8"></script>
  16. <script type="text/javascript" src="/static/js/xadmin.js"></script>
  17. </head>
  18. <body>
  19. <div class="x-nav">
  20. <span class="layui-breadcrumb">
  21. <a href="">首页</a>
  22. <a><cite>数据展示</cite></a>
  23. </span>
  24. <a class="layui-btn layui-btn-normal" style="line-height:1.6em;margin-top:3px;float:right"
  25. onclick="location.reload()" title="刷新">
  26. <i class="layui-icon layui-icon-refresh" style="line-height:30px"></i>
  27. </a>
  28. </div>
  29. <div class="layui-fluid">
  30. <div class="layui-row" style="display: flex;">
  31. <!-- 传感器 选择 start-->
  32. <div style="width: 340px">
  33. <div class="layui-card">
  34. <div class="layui-card-body ">
  35. <form class="layui-form layui-col-space5" οnsubmit="return false;">
  36. <div class="layui-input-inline layui-show-xs-block">
  37. <input value="" type="text" id="D_T_sn" name="D_T_sn" placeholder="请输入 SN"
  38. autocomplete="off"
  39. class="layui-input"></div>
  40. <div class="layui-input-inline layui-show-xs-block">
  41. <input value="" type="text" id="D_Name" name="D_Name" placeholder="请输入 传感器名称"
  42. autocomplete="off"
  43. class="layui-input"></div>
  44. <div class="layui-input-inline layui-show-xs-block" style="width: 168px">
  45. <select id="Class_1" name="Class_1">
  46. <option value=0>所有分类</option>
  47. {{range $index, $elem := .Class_List}}
  48. <option value={{$elem.Id}}>{{$elem.T_name}}</option>
  49. {{end}}
  50. </select>
  51. </div>
  52. <div class="layui-input-inline layui-show-xs-block">
  53. <div class="layui-btn layui-btn-normal"
  54. onclick="get_DeviceSensor_list(0)">
  55. <i class="layui-icon">&#xe615;</i></div>
  56. </div>
  57. </form>
  58. <hr>
  59. </div>
  60. <div class="layui-card-body " style="margin-top: -20px">
  61. <div id="DeviceSensor_list" style="width: 98%; overflow: hidden;max-height: 616px;overflow-y: auto">
  62. <div style="color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px">加载中...</div>
  63. </div>
  64. </div>
  65. <div class="layui-card-body ">
  66. <div style="height: 70px">
  67. <div class="layui-card-body " style="text-align: center">
  68. <div class="layui-input-inline layui-show-xs-block">
  69. <div class="layui-btn layui-btn-normal"
  70. onclick="Checkboxs_All()">
  71. <i class="layui-icon">全选择</i>
  72. </div>
  73. </div>
  74. <div class="layui-input-inline layui-show-xs-block">
  75. <div class="layui-btn layui-btn-normal"
  76. onclick="Checkboxs_Allno()">
  77. <i class="layui-icon">全取消</i>
  78. </div>
  79. </div>
  80. <div class="layui-input-inline layui-show-xs-block">
  81. <div class="layui-btn layui-btn-normal"
  82. onclick="Checkboxs_Allto()">
  83. <i class="layui-icon">反选</i>
  84. </div>
  85. </div>
  86. <div style="color: #1E9FFF;text-align: center" id="DeviceSensor_list_Pages_x"></div>
  87. </div>
  88. </div>
  89. </div>
  90. </div>
  91. </div>
  92. <!-- 传感器 选择 end-->
  93. <div style="padding-left: 15px; height: 100%;flex:1;">
  94. <div class="layui-card">
  95. <!-- 传感器数据时间选择 选择 start-->
  96. <div class="layui-card-body ">
  97. <div class="layui-form layui-col-space5" οnsubmit="return false;">
  98. <div class="layui-input-inline layui-show-xs-block">
  99. <div class="layui-btn layui-btn-normal"
  100. onclick="quick_1()">
  101. <i class="layui-icon">今天</i>
  102. </div>
  103. </div>
  104. <div class="layui-input-inline layui-show-xs-block">
  105. <div class="layui-btn layui-btn-normal"
  106. onclick="quick_2()">
  107. <i class="layui-icon">近一周</i>
  108. </div>
  109. </div>
  110. <div class="layui-input-inline layui-show-xs-block">
  111. <div class="layui-btn layui-btn-normal"
  112. onclick="quick_3()">
  113. <i class="layui-icon">近一月</i>
  114. </div>
  115. </div>
  116. <div class="layui-input-inline layui-show-xs-block">
  117. <div class="layui-btn layui-btn-normal"
  118. onclick="quick_4()">
  119. <i class="layui-icon">近一季度</i>
  120. </div>
  121. </div>
  122. <div class="layui-input-inline layui-show-xs-block">
  123. 自定义时间:
  124. </div>
  125. <div class="layui-inline layui-show-xs-block">
  126. <input class="layui-input" autocomplete="off" placeholder="开始日" name="Time_start"
  127. id="Time_start" lay-key="1"></div>
  128. <div class="layui-inline layui-show-xs-block">
  129. <input class="layui-input" autocomplete="off" placeholder="截止日" name="Time_end"
  130. id="Time_end" lay-key="2"></div>
  131. <div class="layui-input-inline layui-show-xs-block">
  132. <div class="layui-btn layui-btn-normal"
  133. onclick="get_DeviceSensor_data(0)">
  134. <i class="layui-icon">&#xe615;</i></div>
  135. </div>
  136. <div class="layui-input-inline layui-show-xs-block" style="float: right">
  137. <button class="layui-btn layui-btn-normal" id="importData">导入数据</button>
  138. <button class="layui-btn layui-btn-normal" id="exportData" onclick="exportData()">导出数据</button>
  139. <button class="layui-btn layui-btn-normal" onclick="F_moban()">导入模板说明</button>
  140. </div>
  141. </div>
  142. <hr>
  143. <div>
  144. <button class="layui-btn layui-btn-normal" onclick="selectAll()">全选</button>
  145. <button class="layui-btn layui-btn-normal" onclick="reverseSelect()">反选</button>
  146. <button class="layui-btn layui-btn-normal" onclick="noSelect()">全不选</button>
  147. <button class="layui-btn layui-btn-danger" onclick="deleteSelect()">删除</button>
  148. </div>
  149. </div>
  150. <!-- 传感器数据时间选择 选择 end-->
  151. <div class="layui-card-body" >
  152. <table class="layui-table ">
  153. <colgroup>
  154. <col width="100">
  155. <col>
  156. <col>
  157. <col>
  158. <col>
  159. <col>
  160. <col>
  161. </colgroup>
  162. <thead>
  163. <tr>
  164. <th>选择</th>
  165. <th>采集时间</th>
  166. <th>温度℃</th>
  167. <th>湿度%</th>
  168. <th>GPS</th>
  169. <th>录入时间</th>
  170. <th>操作</th>
  171. </tr>
  172. </thead>
  173. <tbody id="DeviceSensor_data">
  174. </tbody>
  175. </table>
  176. </div>
  177. <div class="layui-card-body " style="display: flex;justify-content: space-between">
  178. <!--按钮部分 start-->
  179. <div>
  180. <span>每页显示:</span>
  181. <select id="perPageSelect">
  182. <option value="10">10条/页</option>
  183. <option value="100">100条/页</option>
  184. <option value="300">300条/页</option>
  185. <option value="500">500条/页</option>
  186. <option value="800">800条/页</option>
  187. <option value="1000">1000条/页</option>
  188. </select>
  189. </div>
  190. <!--按钮部分 end-->
  191. <!--分页部分 start-->
  192. <div id="pageTool">
  193. </div>
  194. <!-- <input type="number" id="perPageInput" min="1" value="10">-->
  195. <!--分页部分 end-->
  196. </div>
  197. </div>
  198. </div>
  199. </div>
  200. <!--数据记录展示-->
  201. <div id="recordShow" style="display: none">
  202. <table class="layui-table">
  203. <colgroup>
  204. <col width="20px">
  205. <col width="20px">
  206. <col>
  207. <col>
  208. <col>
  209. <col>
  210. </colgroup>
  211. <thead>
  212. <tr>
  213. <th>温度</th>
  214. <th>湿度</th>
  215. <th>GPS</th>
  216. <th>操作人</th>
  217. <th>录入时间</th>
  218. <th>操作</th>
  219. </tr>
  220. </thead>
  221. <tbody id="recordTableBody"></tbody>
  222. </table>
  223. </div>
  224. </div>
  225. </body>
  226. <script>
  227. let uploadInst
  228. //获取GET
  229. function getPar(par) {
  230. //获取当前URL
  231. var local_url = document.location.href;
  232. //获取要取得的get参数位置
  233. var get = local_url.indexOf(par + "=")
  234. ;
  235. if (get == -1) {
  236. return false;
  237. }
  238. //截取字符串
  239. //截取字符串
  240. var get_par = local_url.slice(par.length + get + 1);
  241. //判断截取后的字符串是否还有其他get参数
  242. var nextPar = get_par.indexOf("&")
  243. ;
  244. if (nextPar != -1) {
  245. get_par = get_par.slice(0, nextPar);
  246. }
  247. return get_par;
  248. }
  249. function ChangeDiv(e) {
  250. // var divs = document.getElementsByClassName("ChangeDiv");
  251. // var len = divs.length;
  252. // for(var i=0;i<len;i++){
  253. // divs[i].style.border = "1px solid #ffffff";
  254. // }
  255. // e.style.border = "1px solid #ed0000";
  256. }
  257. // 今天
  258. function quick_1() {
  259. var myDate = new Date();
  260. y = myDate.getFullYear(); //获取当前年份(2位)
  261. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  262. d = myDate.getDate(); //获取当前日(1-31)
  263. console.log(y + "-" + m + "-" + d)
  264. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  265. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  266. $("#Time_start").val(Time_start)
  267. $("#Time_end").val(Time_end)
  268. get_DeviceSensor_data(0)
  269. }
  270. // 近一周
  271. function quick_2() {
  272. var myDate = new Date();
  273. y = myDate.getFullYear(); //获取当前年份(2位)
  274. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  275. d = myDate.getDate(); //获取当前日(1-31)
  276. console.log(y + "-" + m + "-" + d)
  277. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  278. $("#Time_end").val(Time_end)
  279. myDate = myDate.setDate(myDate.getDay() - 6);
  280. myDate = new Date(myDate);
  281. y = myDate.getFullYear(); //获取当前年份(2位)
  282. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  283. d = myDate.getDate(); //获取当前日(1-31)
  284. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  285. $("#Time_start").val(Time_start)
  286. get_DeviceSensor_data(0)
  287. }
  288. // 近一月
  289. function quick_3() {
  290. var myDate = new Date();
  291. y = myDate.getFullYear(); //获取当前年份(2位)
  292. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  293. d = myDate.getDate(); //获取当前日(1-31)
  294. console.log(y + "-" + m + "-" + d)
  295. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  296. $("#Time_end").val(Time_end)
  297. myDate = myDate.setDate(myDate.getDate() - 30);
  298. myDate = new Date(myDate);
  299. y = myDate.getFullYear(); //获取当前年份(2位)
  300. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  301. d = myDate.getDate(); //获取当前日(1-31)
  302. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  303. $("#Time_start").val(Time_start)
  304. get_DeviceSensor_data(0)
  305. }
  306. // 近一季度
  307. function quick_4() {
  308. var myDate = new Date();
  309. y = myDate.getFullYear(); //获取当前年份(2位)
  310. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  311. d = myDate.getDate(); //获取当前日(1-31)
  312. console.log(y + "-" + m + "-" + d)
  313. Time_end = y + "-" + m + "-" + d + " 23:59:59"
  314. $("#Time_end").val(Time_end)
  315. myDate = myDate.setDate(myDate.getDate() - 30 * 3);
  316. myDate = new Date(myDate);
  317. y = myDate.getFullYear(); //获取当前年份(2位)
  318. m = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月)
  319. d = myDate.getDate(); //获取当前日(1-31)
  320. Time_start = y + "-" + m + "-" + d + " 00:00:00"
  321. $("#Time_start").val(Time_start)
  322. get_DeviceSensor_data(0)
  323. }
  324. layui.use(['laydate', 'form', 'element'],
  325. function () {
  326. var laydate = layui.laydate;
  327. //执行一个laydate实例
  328. laydate.render({
  329. elem: '#Time_start' //指定元素
  330. , type: 'datetime'
  331. });
  332. //执行一个laydate实例
  333. laydate.render({
  334. elem: '#Time_end' //指定元素
  335. , type: 'datetime'
  336. });
  337. var element = layui.element;
  338. element.length = 30
  339. });
  340. var T_name = ""
  341. var T_sn = ""
  342. var T_class_id = 0
  343. var T_id = 0
  344. var T_sn_T_id = ""
  345. var Time_start = ""
  346. var Time_end = ""
  347. var DeviceSensor_lite = []
  348. var DeviceSensor_data = []
  349. var DeviceSensor_snid_list = ""
  350. /// --------------- 传感器列表
  351. // 页面 加载完成后执行
  352. window.onload = function () {
  353. console.log("页面 加载完成后执行")
  354. quick_1()
  355. get_DeviceSensor_list(0)
  356. }
  357. //获取div中所有的复选框 .value
  358. var checkboxs = document.getElementsByClassName("checkboxxx");
  359. function Checkboxs_All() {
  360. for (var i = 0; i < checkboxs.length; i++) {
  361. checkboxs[i].checked = true
  362. }
  363. }
  364. function Checkboxs_Allno() {
  365. for (var i = 0; i < checkboxs.length; i++) {
  366. checkboxs[i].checked = false
  367. }
  368. }
  369. function Checkboxs_Allto() {
  370. for (var i = 0; i < checkboxs.length; i++) {
  371. if (checkboxs[i].checked) {
  372. checkboxs[i].checked = false
  373. } else {
  374. checkboxs[i].checked = true
  375. }
  376. }
  377. }
  378. function Checkboxs_GetAll() {
  379. DeviceSensor_snid_list = ""
  380. for (var i = 0; i < checkboxs.length; i++) {
  381. if (checkboxs[i].checked) {
  382. DeviceSensor_snid_list = DeviceSensor_snid_list + checkboxs[i].value + "|"
  383. }
  384. }
  385. }
  386. function get_DeviceSensor_list(page) {
  387. T_sn = $("#D_T_sn").val();
  388. T_name = $("#D_Name").val();
  389. T_class_id = $("#Class_1").val();
  390. $.ajax({
  391. type: 'POST',
  392. url: '/Data/Device_Sensor_List',//发送请求
  393. data: {
  394. User_tokey: $.cookie("User_tokey"),
  395. T_sn: T_sn,
  396. T_name: T_name,
  397. T_class_id: parseInt(T_class_id),
  398. page: page,
  399. page_z: 1000,
  400. },
  401. success: function (result) {
  402. console.log(result)
  403. if (result.Code == 200) {
  404. if (page == 0)
  405. $('#DeviceSensor_list').html("")
  406. // $('#DeviceSensor_list_Pages').html("")
  407. // $('#DeviceSensor_list_Pages_x').html("")
  408. DeviceSensor_lite = result.Data.DeviceSensor_lite
  409. if (DeviceSensor_lite.length == 0) {
  410. $('#DeviceSensor_list').html("<div style=\"color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px\">没有设备</div>")
  411. return
  412. }
  413. Add_DeviceSensor_list(result.Data.DeviceSensor_lite) // 列表
  414. // Add_DeviceSensor_list_Pages(result.Data.Pages) // 分页
  415. $('#DeviceSensor_list_Pages_x').html(" 传感器 总数:" + result.Data.Num);
  416. if (result.Data.Page_size > result.Data.Page) {
  417. get_DeviceSensor_list(result.Data.Page + 1)
  418. }
  419. } else {
  420. }
  421. }
  422. });
  423. return false
  424. }
  425. //选择所有选择框
  426. let sensors = []
  427. function selectAll() {
  428. sensors = []
  429. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  430. $(e).prop('checked', true)
  431. })
  432. }
  433. //反选
  434. function reverseSelect() {
  435. sensors = []
  436. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  437. $(e).prop('checked', !$(e).prop('checked'))
  438. })
  439. }
  440. //全不选
  441. function noSelect() {
  442. sensors = []
  443. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  444. $(e).prop('checked', false)
  445. })
  446. }
  447. //删除所选择的内容
  448. function deleteSelect() {
  449. //获取选择的行
  450. sensors = []
  451. $('#DeviceSensor_data > tr > td > input[type="checkbox"]').each((i, e) => {
  452. if ($(e).prop('checked')) {
  453. let t = {
  454. t_sn: $(e).attr('data-sn'),
  455. t_id: Number.parseInt($(e).attr('data-id')),
  456. t_t: Number.parseFloat($(e).attr('data-tt')),
  457. t_rh: Number.parseFloat($(e).attr('data-trh')),
  458. t_site: $(e).attr('data-site'),
  459. }
  460. sensors.push(t)
  461. }
  462. })
  463. console.log(sensors)
  464. if (sensors.length == 0) {
  465. layui.layer.msg('没有选中要删除的记录哦!')
  466. return
  467. }
  468. layui.layer.confirm(`是否删除选中${sensors.length}条记录`, {title: '删除记录'}, function (index) {
  469. $.ajax({
  470. type: "POST",
  471. url: '/Data/Device_Sensor_List_Delete',
  472. data: JSON.stringify(sensors),
  473. cookie: $.cookie("User_tokey"),
  474. contentType: 'application/json;charset=utf-8',
  475. success: function (rlt) {
  476. if (rlt.Code == 200) {
  477. layui.layer.msg(`删除${sensors.length}条数据成功!`)
  478. get_DeviceSensor_data(0)
  479. } else {
  480. layui.layer.msg(rlt.Msg)
  481. }
  482. }
  483. })
  484. layui.layer.close(index);
  485. });
  486. }
  487. //删除当前行,当当前行按钮被点击后
  488. function deleteOne(e) {
  489. e = $(e).parent().prevAll()
  490. e = e[e.length - 1]
  491. e = $(e).children()[0]
  492. console.log(e,"==============")
  493. let t = {
  494. t_sn: $(e).attr('data-sn'),
  495. t_id: Number.parseInt($(e).attr('data-id')),
  496. t_t: Number.parseFloat($(e).attr('data-tt')),
  497. t_rh: Number.parseFloat($(e).attr('data-trh')),
  498. t_site: $(e).attr('data-site'),
  499. User_tokey: $.cookie("User_tokey")
  500. }
  501. layui.layer.confirm(`是否删除选中 sn: ${t.t_sn} 1 条记录`, {title: '删除记录'}, function (index) {
  502. $.ajax({
  503. type: "POST",
  504. url: '/Data/Device_Sensor_List_Delete',
  505. data: JSON.stringify([t]),
  506. contentType: 'application/json;charset=utf-8',
  507. success: function (rlt) {
  508. if (rlt.Code == 200) {
  509. layui.layer.msg(`删除1条数据成功!`)
  510. get_DeviceSensor_data(0)
  511. } else {
  512. layui.layer.msg(rlt.Msg)
  513. }
  514. }
  515. })
  516. layui.layer.close(index);
  517. });
  518. }
  519. function Add_DeviceSensor_list(DS_lite) {
  520. for (let i = 0; i < DS_lite.length; i++) {
  521. if (T_id == 0) {
  522. T_id = DS_lite[i].T_id;
  523. T_sn_T_id = DS_lite[i].T_sn;
  524. get_DeviceSensor_data(0)
  525. }
  526. $('#DeviceSensor_list').append("" +
  527. "<div class=\"layui-col ChangeDiv\" onclick=\"ChangeDiv(this);T_id = " + DS_lite[i].T_id + ";T_sn_T_id = '" + DS_lite[i].T_sn + "';\" \n" +
  528. " style=\"border: 1px solid #ffffff;height: 52px;background-color: #fafafa;border-radius:5px;padding-top: 2px;margin-top: 6px;\">\n" +
  529. " <input type=\"checkbox\" id='sn_id' name='checkboxxx' class='checkboxxx' value='" + DS_lite[i].T_sn + "," + DS_lite[i].T_id + "' style='float: left;width: 18px;height: 18px;margin-top: 16px;margin-left: 10px;'/>" +
  530. "<img style=\"float: left;width: 50px;margin: 0px 10px\" src=\"/static/images/温湿度传感器-1.png\"\n" +
  531. " height=\"50\"\n" +
  532. " width=\"40\"/>\n" +
  533. " <div style=\"float: left;\">\n" +
  534. " <div style=\"margin-top: 4px;font-size: 14px;height: 24px;\">" + DS_lite[i].T_name + "</div>\n" +
  535. " <div style=\"margin-top: -3px;font-size: 12px\">SN:" + DS_lite[i].T_sn + " [" + DS_lite[i].T_id + "]</div>\n" +
  536. " </div>\n" +
  537. " <div class=\"layui-card-header\"\n" +
  538. " style=\"float: right;padding-left: 0px;padding-top: 6px;color: #1E9FFF\">\n" +
  539. " \n" +
  540. " </div>\n" +
  541. " </div>")
  542. }
  543. }
  544. $('#perPageSelect').on('change', function() {
  545. let itemsPerPage = $(this).val();
  546. get_DeviceSensor_data(0, itemsPerPage); // 调用获取数据函数,传入新的每页条数
  547. });
  548. // 如果是输入框,则可能需要验证用户输入并做相应的处理
  549. $('#perPageInput').on('input', function() {
  550. let itemsPerPage = parseInt($(this).val());
  551. if (!isNaN(itemsPerPage)) {
  552. get_DeviceSensor_data(0, itemsPerPage);
  553. } else {
  554. alert('请输入有效的数字!');
  555. $(this).val('10'); // 重置为默认值
  556. }
  557. });
  558. function get_DeviceSensor_data(page,itemsPerPage) {
  559. if ($("#Time_start").val().length > 0) {
  560. Time_start = $("#Time_start").val();
  561. } else {
  562. Time_start = ""
  563. }
  564. if ($("#Time_end").val().length > 0) {
  565. Time_end = $("#Time_end").val();
  566. } else {
  567. Time_end = ""
  568. }
  569. Checkboxs_GetAll()
  570. var loading = layer.load(0, {
  571. shade: false,
  572. time: 99 * 1000
  573. });
  574. $.ajax({
  575. type: 'POST',
  576. url: 'Device_Sensor_Data_More',//发送请求
  577. data: {
  578. User_tokey: $.cookie("User_token"),
  579. Time_start: Time_start,
  580. Time_end: Time_end,
  581. T_snid: DeviceSensor_snid_list,
  582. page: page,
  583. page_z: itemsPerPage,
  584. },
  585. success: function (result) {
  586. console.log(result)
  587. layer.close(loading)
  588. if (result.Code == 200) {
  589. $('#DeviceSensor_data').html("")
  590. $('#DeviceSensor_data_Pages').html("")
  591. $('#DeviceSensor_data_Pages_x').html("")
  592. DeviceSensor_data = result.Data.list
  593. if (DeviceSensor_data.length == 0) {
  594. $('#DeviceSensor_data').html("<div style=\"color: #1E9FFF;text-align: center;font-size: 15px;margin-top: 150px\">没有数据</div>")
  595. return
  596. }
  597. addDeviceSensorData(result.Data.list)
  598. addDeviceSensorDataPage(result.Data,itemsPerPage)
  599. } else {
  600. }
  601. }
  602. });
  603. return false
  604. }
  605. function f_Device_Sensor_Data_Pu_data(Sn, tap, num, id) {
  606. $.ajax({
  607. type: 'POST',
  608. url: 'Device_Sensor_Data_Pu_data',//发送请求
  609. data: {
  610. Sn: Sn,
  611. tap: tap,
  612. num: num,
  613. id: id,
  614. },
  615. success: function (result) {
  616. if (result.Code != 200) {
  617. layer.msg(result.Msg);
  618. }
  619. }
  620. });
  621. }
  622. function f_Device_Sensor_Data_Del_data(Sn, id) {
  623. $.ajax({
  624. type: 'POST',
  625. url: 'Device_Sensor_Data_Del_data',//发送请求
  626. data: {
  627. Sn: Sn,
  628. id: id,
  629. },
  630. success: function (result) {
  631. if (result.Code != 200) {
  632. layer.msg(result.Msg);
  633. }
  634. get_DeviceSensor_data(0)
  635. }
  636. });
  637. }
  638. function ShowElement(element) {
  639. var oldhtml = element.innerHTML;
  640. var newobj = document.createElement('input');
  641. //创建新的input元素
  642. newobj.type = 'text';
  643. //为新增元素添加类型
  644. console.log(oldhtml)
  645. console.log(element.dataset.th)
  646. console.log(element.dataset.sn)
  647. console.log(element.dataset.id)
  648. newobj.value = oldhtml
  649. newobj.onblur = function () {
  650. console.log(this.value)
  651. element.innerHTML = this.value ? this.value : oldhtml;
  652. if (element.dataset.th == 1) {
  653. f_Device_Sensor_Data_Pu_data(element.dataset.sn, "t_t", this.value, element.dataset.id)
  654. } else {
  655. f_Device_Sensor_Data_Pu_data(element.dataset.sn, "t_rh", this.value, element.dataset.id)
  656. }
  657. //当触发时判断新增元素值是否为空,为空则不修改,并返回原有值
  658. }
  659. element.innerHTML = '';
  660. element.appendChild(newobj);
  661. newobj.focus();
  662. }
  663. //分页添加
  664. function addDeviceSensorDataPage(pageInfo,itemsPerPage) {
  665. let start, end
  666. start = pageInfo.currentPage - 5 < 1 ? 1 : pageInfo.currentPage - 5
  667. end = pageInfo.currentPage + 5 > pageInfo.totalPage ? pageInfo.totalPage : pageInfo.currentPage + 5
  668. end = end + Math.abs(end - start - 10) > pageInfo.totalPage ? pageInfo.totalPage : end + Math.abs(end - start - 10)
  669. $('#pageTool').html('')
  670. $('#pageTool').append(`<span style="padding: 0 10px;color: #0bace6">共${pageInfo.totalPage}页 / 当前${pageInfo.currentPage}页 共${pageInfo.totalCount}条数据</span>`)
  671. //上一页
  672. if (pageInfo.previousPage) {
  673. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${pageInfo.currentPage - 1},${itemsPerPage})">上一页</button>`)
  674. } else {
  675. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">上一页</button>`)
  676. }
  677. //页码
  678. for (; start <= end; start++) {
  679. if (start == pageInfo.currentPage) {
  680. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">${start}</button>`)
  681. } else {
  682. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${start},${itemsPerPage})">${start}</button>`)
  683. }
  684. }
  685. //下一页
  686. if (pageInfo.nextPage) {
  687. $('#pageTool').append(`<button class="layui-btn layui-btn-primary layui-btn-sm" onclick="get_DeviceSensor_data(${pageInfo.currentPage + 1},${itemsPerPage})">下一页</button>`)
  688. } else {
  689. $('#pageTool').append(`<button class="layui-btn layui-btn-disabled layui-btn-primary layui-btn-sm">下一页</button>`)
  690. }
  691. }
  692. //添加设备数据
  693. function addDeviceSensorData(list) {
  694. let style
  695. for (let v of list) {
  696. if (v.t_t < v.t_tl || v.t_rh < v.t_rhl) {
  697. style = 'style="background-color: #a8f7ff'
  698. }
  699. if (v.t_t > v.t_tu || v.t_rh > v.t_rhu) {
  700. style = 'style="background-color: #ff8585'
  701. }
  702. $('#DeviceSensor_data').append(`
  703. <tr>
  704. <td><input type="checkbox" class="layui-form-checkbox" data-sn="${v.t_sn}" data-id="${v.t_id}" data-tt="${v.t_t}" data-trh="${v.t_rh}" data-site="${v.t_site}" data-createTime="${v.create_time}"/></td>
  705. <td ondblclick="changeData(this)" data-type="t_time">${v.t_time}</td>
  706. <td ondblclick="changeData(this)" data-type="t_t">${v.t_t}</td>
  707. <td ondblclick="changeData(this)" data-type="t_rh">${v.t_rh}</td>
  708. <td ondblclick="changeData(this)" data-type="t_site">${v.t_site}</td>
  709. <td ondblclick="changeData(this)" data-type="create_time">${v.create_time}</td>
  710. <td>
  711. <button class="layui-btn layui-btn-danger layui-btn-sm" onclick="deleteOne(this)">删除</button>
  712. <button class="layui-btn layui-bg-blue layui-btn-sm" onclick="copyAndAdds(this, '${v.t_sn}', ${v.t_id}, ${v.t_t}, ${v.t_rh}, '${v.t_site}', '${v.create_time}')">复制添加</button>
  713. </td>
  714. </tr>
  715. `)
  716. /*
  717. <button class="layui-btn layui-btn-normal layui-btn-sm" onclick="showRecord(this)">记录</button>
  718. */
  719. }
  720. }
  721. // 新增copyAndAdd函数实现复制并添加新行
  722. function copyAndAdds(button, t_sn, t_id, t_t, t_rh, t_site, create_time) {
  723. // 准备发送给后端的数据对象
  724. let dataToSend = {
  725. t_sn: t_sn,
  726. t_id: t_id,
  727. t_t: t_t,
  728. t_rh: t_rh,
  729. t_site: t_site,
  730. createTime: create_time
  731. };
  732. // 提交数据到后端
  733. $.ajax({
  734. url: '/Device/Device_Copy', // 替换为你的后端接口地址
  735. type: 'POST',
  736. contentType: 'application/json',
  737. data: JSON.stringify(dataToSend),
  738. success: function(response) {
  739. console.log("数据提交成功,响应:", response.Data);
  740. // 假设后端返回了新行ID或者其他需要的数据,这里可以根据需要处理response
  741. let newRowId = response.id; // 假设后端返回了新行的唯一ID
  742. // 根据后端返回的数据(如果有的话)来构造新行的HTML
  743. let newRowHtml = `
  744. <tr class="new-row" data-id="${response.id}" style="background-color: #f0f8ff; border-left: 4px solid #007bff;">
  745. <td>
  746. <input
  747. type="checkbox"
  748. class="layui-form-checkbox"
  749. data-sn="${response.Data.t_sn}"
  750. data-id="${response.Data.t_id}"
  751. data-tt="${response.Data.t_t}"
  752. data-trh="${response.Data.t_rh}"
  753. data-site="${response.Data.t_site}"
  754. data-createTime="${response.Data.createTime}"
  755. />
  756. </td>
  757. <td ondblclick="changeData(this)" data-type="t_time" style="color: #007bff;">${response.Data.createTime}</td>
  758. <td ondblclick="changeData(this)" data-type="t_t" style="color: #007bff;">${response.Data.t_t}</td>
  759. <td ondblclick="changeData(this)" data-type="t_rh" style="color: #007bff;">${response.Data.t_rh}</td>
  760. <td ondblclick="changeData(this)" data-type="t_site" style="color: #007bff;">${response.Data.t_site}</td>
  761. <td ondblclick="changeData(this)" data-type="create_time" style="color: #007bff;">${response.Data.createTime}</td>
  762. <td>
  763. <button class="layui-btn layui-btn-danger layui-btn-sm" onclick="deleteOne(this)">删除</button>
  764. <button class="layui-btn layui-bg-blue layui-btn-sm" onclick="copyAndAdds(this, '${t_sn}', ${t_id}, ${t_t}, ${t_rh}, '${t_site}', '${create_time}')">复制添加</button>
  765. <!-- 注意:此处可能不需要再提供复制添加按钮,因为数据已持久化 -->
  766. </td>
  767. </tr>
  768. `;
  769. // 在当前行的下一行兄弟元素(下一行)之前插入新行
  770. $(button).closest('tr').after(newRowHtml);
  771. // window.location.reload()
  772. // 这里可以添加成功后的其他操作,如提示用户、更新界面等
  773. },
  774. error: function(jqXHR, textStatus, errorThrown) {
  775. console.error("数据提交失败:", textStatus, errorThrown);
  776. // 处理错误情况,比如提示用户
  777. alert("数据提交失败,请重试!");
  778. }
  779. });
  780. }
  781. function showRecord(e) {
  782. e = $(e).parent().prevAll()
  783. e = e[e.length - 1]
  784. e = $(e).children()[0]
  785. console.log(e)
  786. $.ajax({
  787. type: "post",
  788. url: "/Data/Device_Sensor_Record",
  789. data: {
  790. sn: $(e).attr('data-sn'),
  791. tId: $(e).attr('data-id'),
  792. createTime: $(e).attr('data-createTime')
  793. },
  794. success: function (rlt) {
  795. if (rlt.Code === 200) {
  796. if (rlt.Data == null) {
  797. layui.layer.msg("没有数据!")
  798. return
  799. }
  800. for (let v of rlt.Data) {
  801. $('#tableBody').append(`
  802. <tr>
  803. <td>${v.t_t}</td>
  804. <td>${v.t_rh}</td>
  805. <td>${v.t_site}</td>
  806. <td>${v.t_uuid}</tdj>
  807. <td>${v.create_time}</td>
  808. <td>
  809. <button class="layui-btn layui-btn-normal" onclick="">更新</button>
  810. </td>
  811. </tr>
  812. `)
  813. }
  814. layui.layer.open({
  815. type: 1,
  816. area: ['1200px', '800px'],
  817. content: $('#recordShow'),
  818. isOutAnim: true
  819. })
  820. }
  821. }
  822. })
  823. }
  824. //双击表格改变值
  825. function changeData(even) {
  826. let e = $(even).prevAll()
  827. console.log(e)
  828. e = $(e[e.length - 1]).children()[0]
  829. console.log(e)
  830. let t = {
  831. t_sn: $(e).attr('data-sn'),
  832. t_id: Number.parseInt($(e).attr('data-id')),
  833. t_t: Number.parseFloat($(e).attr('data-tt')),
  834. t_rh: Number.parseFloat($(e).attr('data-trh')),
  835. t_site: $(e).attr('data-site'),
  836. }
  837. let type = $(even).attr('data-type')
  838. console.log(t)
  839. let input = $(`<input class="layui-input" type="text" value="${even.innerText}">`)
  840. input[0].onblur = function () {
  841. t["type"] = type
  842. t["value"] = $(this).val()
  843. t["User_tokey"] = $.cookie("User_tokey")
  844. if (t[type] == t.value) {
  845. } else {
  846. $.ajax({
  847. type: "POST",
  848. url: "/Data/Device_Sensor_Update",
  849. data: t,
  850. cookie: $.cookie("User_token"),
  851. success: function (rlt) {
  852. console.log(rlt)
  853. }
  854. })
  855. }
  856. console.log(t)
  857. even.innerHTML = this.value
  858. $(e).attr(`data-${type}`, $(this).val())
  859. }
  860. $(even).html('')
  861. $(even).append(input)
  862. input.focus()
  863. }
  864. //点击上传按钮
  865. layui.use('upload', function () {
  866. let upload = layui.upload;
  867. //执行实例
  868. let uploadInst = upload.render({
  869. elem: '#importData',
  870. url: '/Data/importData' //上传接口
  871. , accept: 'file',
  872. data: {
  873. User_tokey: $.cookie("User_tokey"),
  874. }
  875. , field: 'file'
  876. , done: function (res) {
  877. layui.layer.msg(res.Msg)
  878. // layui.layer.close(index)
  879. }
  880. , error: function () {
  881. //请求异常回调
  882. layui.layer.msg('上传错误!')
  883. }
  884. })
  885. })
  886. //导出数据
  887. function exportData() {
  888. if ($("#Time_start").val().length > 0) {
  889. Time_start = $("#Time_start").val();
  890. } else {
  891. Time_start = ""
  892. }
  893. if ($("#Time_end").val().length > 0) {
  894. Time_end = $("#Time_end").val();
  895. } else {
  896. Time_end = ""
  897. }
  898. let checkbox = document.getElementById('sn_id');
  899. if (checkbox.checked) {
  900. $.ajax({
  901. type: "post",
  902. url: "/Data/EXportData",
  903. data: {
  904. T_snid: checkbox.value,
  905. Time_start: Time_start,
  906. Time_end: Time_end,
  907. },
  908. success: function (rlt) {
  909. console.log(rlt)
  910. if (rlt.Code === 200) {
  911. let link = document.createElement('a');
  912. link.href = rlt.Data;
  913. link.click(); // 触发点击事件以开始下载
  914. link.remove();
  915. }
  916. }
  917. })
  918. }else{
  919. layui.layer.msg("请选择导出项")
  920. }
  921. // let sn_id = $("#sn_id").val();
  922. // console.log(Time_start, Time_end,sn_id)
  923. }
  924. function Add_DeviceSensor_data(DS_lite) {
  925. console.log(DS_lite)
  926. for (let i = 0; i < DS_lite.length; i++) {
  927. style_s = ""
  928. if (DS_lite[i].T_t < DS_lite[i].T_Tlower || DS_lite[i].T_rh < DS_lite[i].T_RHlower) {
  929. style_s = " style='background-color: #a8f7ff' "
  930. }
  931. if (DS_lite[i].T_t > DS_lite[i].T_Tupper || DS_lite[i].T_rh > DS_lite[i].T_RHupper) {
  932. style_s = " style='background-color: #ff8585' "
  933. }
  934. $('#DeviceSensor_data').append("" +
  935. "<tr " + style_s + ">\n" +
  936. // " <td>"+DS_lite[i].T_sn+"</td>\n" +
  937. " <td>" + DS_lite[i].T_name + " [" + DS_lite[i].T_id + "]</td>\n" +
  938. " <td ondblclick=\"ShowElement(this)\" data-th=1 data-sn=\"" + DS_lite[i].T_sn + "\" data-id=" + DS_lite[i].T_id + " >" + DS_lite[i].T_t + "</td>\n" +
  939. " <td ondblclick=\"ShowElement(this)\" data-th=2 data-sn=\"" + DS_lite[i].T_sn + "\" data-id=" + DS_lite[i].T_id + " >" + DS_lite[i].T_rh + "</td>\n" +
  940. " <td>" + DS_lite[i].T_tl + "~" + DS_lite[i].T_tu + "</td>\n" +
  941. " <td>" + DS_lite[i].T_rhl + "~" + DS_lite[i].T_rhu + "</td>\n" +
  942. " <td>" + DS_lite[i].T_time + "</td>\n" +
  943. " <td> <span class='layui-btn layui-btn-danger' onclick='f_Device_Sensor_Data_Del_data(\"" + DS_lite[i].T_sn + "\"," + DS_lite[i].ID + ")'>删除</span>" + `<span class='layui-btn layui-btn-normal'>记录</span>` + "</td>\n" +
  944. "</tr>")
  945. }
  946. }
  947. function Add_DeviceSensor_data_Pages(Pages) {
  948. for (let i = 0; i < Pages.length; i++) {
  949. elem = Pages[i]
  950. switch (elem.A) {
  951. case 1:
  952. $('#DeviceSensor_data_Pages').append("<a class=\"prev\" onclick='get_DeviceSensor_data(" + elem.V + ")' >&lt;&lt;</a>\n");
  953. break;
  954. case 2:
  955. $('#DeviceSensor_data_Pages').append("<a class=\"num\" onclick='get_DeviceSensor_data(" + elem.V + ")' >" + elem.V + "</a>\n");
  956. break;
  957. case 3:
  958. $('#DeviceSensor_data_Pages').append("<span class=\"current\">" + elem.V + "</span>\n");
  959. break;
  960. case 4:
  961. $('#DeviceSensor_data_Pages').append("<a class=\"num\" onclick='get_DeviceSensor_data(" + elem.V + ")' >" + elem.V + "</a>\n");
  962. break;
  963. case 5:
  964. $('#DeviceSensor_data_Pages').append("<a class=\"next\" onclick='get_DeviceSensor_data(" + elem.V + ")' >&gt;&gt;</a>\n");
  965. break;
  966. }
  967. }
  968. }
  969. function get_DeviceSensor_Excel() {
  970. if ($("#Time_start").val().length > 0) {
  971. Time_start = $("#Time_start").val();
  972. } else {
  973. Time_start = ""
  974. }
  975. if ($("#Time_end").val().length > 0) {
  976. Time_end = $("#Time_end").val();
  977. } else {
  978. Time_end = ""
  979. }
  980. Checkboxs_GetAll()
  981. var loading = layer.load(0, {
  982. shade: false,
  983. time: 99 * 1000
  984. });
  985. $.ajax({
  986. type: 'POST',
  987. url: 'Device_Sensor_Data_Excel',//发送请求
  988. data: {
  989. User_tokey: $.cookie("User_tokey"),
  990. Time_start: Time_start,
  991. Time_end: Time_end,
  992. T_snid: DeviceSensor_snid_list,
  993. },
  994. success: function (result) {
  995. console.log(result)
  996. layer.close(loading)
  997. if (result.Code != 200) {
  998. layer.msg(result.Msg);
  999. return
  1000. }
  1001. window.location.href = result.Data;
  1002. }
  1003. });
  1004. return false
  1005. }
  1006. function F_moban() {
  1007. layer.open({
  1008. title: '导入模版'
  1009. ,content: '1、根据模板格式 导入数据 <a href="/static/20240523140020.xlsx" style="color: #1E9FFF">点击下载模版</a><hr>'+
  1010. '2、导入文件名为 SN编号,如 2024xxxxxxxxxx.xlsx <hr>'
  1011. });
  1012. }
  1013. </script>
  1014. </html>