wxElectronicsCert.jsp 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  2. <%
  3. String path = request.getContextPath();
  4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  5. %>
  6. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  7. <html>
  8. <head>
  9. <base href="<%=basePath%>">
  10. <title>使用登记证</title>
  11. <meta http-equiv="pragma" content="no-cache">
  12. <meta http-equiv="cache-control" content="no-cache">
  13. <meta http-equiv="expires" content="0">
  14. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  15. <meta http-equiv="description" content="This is my page">
  16. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  17. <meta http-equiv="X-UA-Compatible" content="IE=10"/>
  18. <link rel="stylesheet" type="text/css" href="css/easyui/themes/default/easyui.css">
  19. <link rel="stylesheet" type="text/css" href="css/easyui/themes/icon.css">
  20. <link rel="stylesheet" type="text/css" href="css/easyui/demo/demo.css">
  21. <script type="text/javascript" src="css/easyui/jquery.min.js"></script>
  22. <script type="text/javascript" src="css/easyui/jquery.easyui.min.js" charset="utf-8"></script>
  23. <script type="text/javascript" src="css/easyui/locale/easyui-lang-zh_CN.js" charset="utf-8"></script>
  24. <link rel="stylesheet" type="text/css" href="css/common/hzbstyle.css">
  25. <script type="text/javascript" src="js/tool.js"></script>
  26. <script type="text/javascript">
  27. function isNull(exp){
  28. if(!exp || typeof exp=="undefined" || exp.length==0){
  29. return true;
  30. }else{
  31. return false;
  32. }
  33. }
  34. function confirm(okStr,cancelStr,tip,content,unitNo){
  35. $.messager.defaults = { ok: okStr, cancel: cancelStr };
  36. $.messager.confirm(tip, content,function (data) {
  37. if (data) {
  38. }else {
  39. if(isNull(unitNo)){
  40. showMsg("提示", "未获取到此单位的编号,操作失败!", 5000);
  41. }else{
  42. $.ajax({
  43. type: 'POST',
  44. url: "updateUnitTip",
  45. data: {
  46. "unitNo":unitNo
  47. },
  48. dataType:'text',
  49. success: function (data) {
  50. var pData = $.parseJSON(data);
  51. switch (pData.result) {
  52. case 0:
  53. showMsg("提示","操作失败",5000);
  54. break;
  55. case 1:
  56. showMsg("提示","操作成功",2000);
  57. break;
  58. }
  59. }
  60. });
  61. }
  62. }
  63. });
  64. }
  65. function showMsg(title,msg,out){
  66. $.messager.show({
  67. title: title,
  68. msg: msg,
  69. timeout:out
  70. });
  71. }
  72. function showProgress(title,msg,text){
  73. $.messager.progress({
  74. title: title,
  75. msg: msg,
  76. text: text
  77. });
  78. }
  79. function checkedbox(name){
  80. var arr=new Array();
  81. var checkbox=document.getElementsByName(name);
  82. for(var i=0;i<checkbox.length;i++){
  83. if(checkbox[i].checked==true){
  84. arr.push(checkbox[i].value);
  85. }
  86. }
  87. return arr;
  88. }
  89. function getCheckTree(id){
  90. var nodes = $("#"+id).tree('getChecked', ['checked']);
  91. var arr=new Array();
  92. for(var i=0; i<nodes.length; i++){
  93. if(nodes[i].checked==true){
  94. if(nodes[i].id.length==1){
  95. arr.push("0"+nodes[i].id);
  96. }else if(nodes[i].id.length==2){
  97. arr.push(nodes[i].id+"0000");
  98. }else if(nodes[i].id.length==4){
  99. arr.push(nodes[i].id+"00");
  100. }else{
  101. arr.push(nodes[i].id);
  102. }
  103. }
  104. }
  105. return arr;
  106. }
  107. function getCheckTreeName(id){
  108. var nodes = $("#"+id).tree('getChecked', ['checked']);
  109. var arr=new Array();
  110. for(var i=0; i<nodes.length; i++){
  111. if(nodes[i].checked==true){
  112. arr.push(nodes[i].text);
  113. }
  114. }
  115. return arr;
  116. }
  117. function isCarNo(str) {//验证车牌号
  118. return /(^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-Z0-9]{6}$)|(^[A-Z]{2}[A-Z0-9]{2}[A-Z0-9\u4E00-\u9FA5]{1}[A-Z0-9]{4}$)|(^[\u4E00-\u9FA5]{1}[A-Z0-9]{5}[挂学警军港澳]{1}$)|(^[A-Z]{2}[0-9]{5}$)|(^(08|38){1}[A-Z0-9]{4}[A-Z0-9挂学警军港澳]{1}$)/.test(str);
  119. //return /(^[\u4E00-\u9FA5]{1}[A-Z0-9]{6}$)|(^[A-Z]{2}[A-Z0-9]{2}[A-Z0-9\u4E00-\u9FA5]{1}[A-Z0-9]{4}$)|(^[\u4E00-\u9FA5]{1}[A-Z0-9]{5}[挂学警军港澳]{1}$)|(^[A-Z]{2}[0-9]{5}$)|(^(08|38){1}[A-Z0-9]{4}[A-Z0-9挂学警军港澳]{1}$)/.test(str);
  120. }
  121. function isCarNo1(str){
  122. return /(^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}(([0-9]{5}[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{4})))|([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领A-Z]{1}[A-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]{1}$)/.test(str);
  123. }
  124. /**
  125. * 获取上一个月
  126. *
  127. * @date 格式为yyyy-mm-dd的日期,如:2014-01-25
  128. */
  129. function getPreMonth(date) {
  130. var arr = date.split('-');
  131. var year = arr[0]; //获取当前日期的年份
  132. var month = arr[1]; //获取当前日期的月份
  133. var day = arr[2]; //获取当前日期的日
  134. var days = new Date(year, month, 0);
  135. days = days.getDate(); //获取当前日期中月的天数
  136. var year2 = year;
  137. var month2 = parseInt(month) - 1;
  138. if (month2 == 0) {//如果是1月份,则取上一年的12月份
  139. year2 = parseInt(year2) - 1;
  140. month2 = 12;
  141. }
  142. var day2 = day;
  143. var days2 = new Date(year2, month2, 0);
  144. days2 = days2.getDate();
  145. if (day2 > days2) {//如果原来日期大于上一月的日期,则取当月的最大日期。比如3月的30日,在2月中没有30
  146. day2 = days2;
  147. }
  148. if (month2 < 10) {
  149. month2 = '0' + month2;//月份填补成2位。
  150. }
  151. var date11 = new Date();
  152. var hor = date11.getHours()>9?date11.getHours():"0"+date11.getHours();
  153. var min = date11.getMinutes()>9?date11.getMinutes():"0"+date11.getMinutes();
  154. var sec = date11.getSeconds()>9?date11.getSeconds():"0"+date11.getSeconds();
  155. var t2 = year2 + '-' + month2 + '-' + day2+" "+hor+":"+min+":"+sec;
  156. return t2;
  157. }
  158. /**
  159. * 获取上一个月
  160. *
  161. * @date 格式为yyyy-mm-dd的日期,如:2014-01-25
  162. */
  163. function getPreMonth1(date) {
  164. var arr = date.split('-');
  165. var year = arr[0]; //获取当前日期的年份
  166. var month = arr[1]; //获取当前日期的月份
  167. var day = arr[2]; //获取当前日期的日
  168. var days = new Date(year, month, 0);
  169. days = days.getDate(); //获取当前日期中月的天数
  170. var year2 = year;
  171. var month2 = parseInt(month) - 1;
  172. if (month2 == 0) {//如果是1月份,则取上一年的12月份
  173. year2 = parseInt(year2) - 1;
  174. month2 = 12;
  175. }
  176. var day2 = day;
  177. var days2 = new Date(year2, month2, 0);
  178. days2 = days2.getDate();
  179. if (day2 > days2) {//如果原来日期大于上一月的日期,则取当月的最大日期。比如3月的30日,在2月中没有30
  180. day2 = days2;
  181. }
  182. if (month2 < 10) {
  183. month2 = '0' + month2;//月份填补成2位。
  184. }
  185. var hor = "00";
  186. var min = "00";
  187. var sec = "00";
  188. var t2 = year2 + '-' + month2 + '-' + day2+" "+hor+":"+min+":"+sec;
  189. return t2;
  190. }
  191. function getPreMonth2(date) {
  192. var arr = date.split('-');
  193. var year = arr[0]; //获取当前日期的年份
  194. var month = arr[1]; //获取当前日期的月份
  195. var day = arr[2]; //获取当前日期的日
  196. var days = new Date(year, month, 0);
  197. days = days.getDate(); //获取当前日期中月的天数
  198. var year2 = year;
  199. var month2 = parseInt(month) - 1;
  200. if (month2 == 0) {//如果是1月份,则取上一年的12月份
  201. year2 = parseInt(year2) - 1;
  202. month2 = 12;
  203. }
  204. var day2 = day;
  205. var days2 = new Date(year2, month2, 0);
  206. days2 = days2.getDate();
  207. if (day2 > days2) {//如果原来日期大于上一月的日期,则取当月的最大日期。比如3月的30日,在2月中没有30
  208. day2 = days2;
  209. }
  210. if (month2 < 10) {
  211. month2 = '0' + month2;//月份填补成2位。
  212. }
  213. var hor = "00";
  214. var min = "00";
  215. var sec = "00";
  216. day2 = "01";
  217. var t2 = year2 + '-' + month2 + '-' + day2+" "+hor+":"+min+":"+sec;
  218. return t2;
  219. }
  220. function getNowDay(date) {
  221. var arr = date.split('-');
  222. var year = arr[0]; //获取当前日期的年份
  223. var month = arr[1]; //获取当前日期的月份
  224. var day = arr[2]; //获取当前日期的日
  225. var days = new Date(year, month, 0);
  226. days = days.getDate(); //获取当前日期中月的天数
  227. var year2 = year;
  228. var month2 = parseInt(month) - 0;
  229. if (month2 == 0) {//如果是1月份,则取上一年的12月份
  230. year2 = parseInt(year2) - 1;
  231. month2 = 12;
  232. }
  233. var day2 = day;
  234. var days2 = new Date(year2, month2, 0);
  235. days2 = days2.getDate();
  236. if (day2 > days2) {//如果原来日期大于上一月的日期,则取当月的最大日期。比如3月的30日,在2月中没有30
  237. day2 = days2;
  238. }
  239. if (month2 < 10) {
  240. month2 = '0' + month2;//月份填补成2位。
  241. }
  242. var date11 = new Date();
  243. var hor = date11.getHours()>9?date11.getHours():"0"+date11.getHours();
  244. var min = date11.getMinutes()>9?date11.getMinutes():"0"+date11.getMinutes();
  245. var sec = date11.getSeconds()>9?date11.getSeconds():"0"+date11.getSeconds();
  246. var t2 = year2 + '-' + month2 + '-' + day2;
  247. return t2;
  248. }
  249. function getBeforeDate(number) {
  250. const num = number;
  251. const date = new Date();
  252. let year = date.getFullYear();
  253. let mon = date.getMonth() + 1;
  254. let day = date.getDate();
  255. if (day <= num) {
  256. if (mon > 1) {
  257. mon = mon - 1;
  258. } else {
  259. year = year - 1;
  260. mon = 12;
  261. }
  262. }
  263. date.setDate(date.getDate() - num);
  264. year = date.getFullYear();
  265. mon = date.getMonth() + 1;
  266. day = date.getDate();
  267. const s = year + '-' + (mon < 10 ? ('0' + mon) : mon) + '-' + (day < 10 ? ('0' + day) : day);
  268. return s;
  269. }
  270. function compareDate(date1,date2){
  271. var oDate1 = new Date(date1);
  272. var oDate2 = new Date(date2);
  273. if(oDate1.getTime() >= oDate2.getTime()){
  274. return true;
  275. } else {
  276. return false;
  277. }
  278. }
  279. function fnKeyUp(){
  280. this.value=this.value.toUpperCase();
  281. }
  282. function getDateAA(aa,dat){
  283. // var date1 = new Date(),
  284. // time1=date1.getFullYear()+"-"+(date1.getMonth()+1)+"-"+date1.getDate();//time1表示当前时间
  285. var date2 = new Date(dat);
  286. date2.setDate(date2.getDate()+aa);
  287. var time2 = date2.getFullYear()+"-"+(date2.getMonth()+1)+"-"+date2.getDate();
  288. return time2;
  289. }
  290. </script>
  291. <script type="text/javascript" src="js/beforeDatagrid.js"></script>
  292. <script type="text/javascript">
  293. $(document).ready(function(){
  294. var carGuid="<%=(String)request.getAttribute("carGuid") %>";
  295. var cylinderGuid="";
  296. var page = 1;
  297. var size = 100;
  298. getCarInfo(carGuid,page,size);
  299. getCylinder(carGuid,page,size);
  300. });
  301. function getCarInfo(carGuid,page,size){
  302. showProgress('提示','请等待','请求源数据中……');
  303. $.ajax({
  304. type: 'POST',
  305. url: "ajax/getCarInfo",
  306. data: {
  307. "carGuid":carGuid,
  308. "page":page,
  309. "size":size
  310. },
  311. dataType:'text',
  312. success: function (data) {
  313. $.messager.progress('close');
  314. var vData = $.parseJSON(data);
  315. if(vData.total==1){
  316. $.each(vData.rows, function(i,item){
  317. document.getElementById("no").innerHTML=item.regNo;
  318. document.getElementById("carNo").innerHTML=item.carNo;
  319. document.getElementById("useUnit").innerHTML=item.carOwnerName;
  320. document.getElementById("address").innerHTML=item.addr;
  321. document.getElementById("giveCertUnit").innerHTML=item.manaUnitName;
  322. document.getElementById("year").innerHTML=item.regTime1.substring(0,4);
  323. document.getElementById("month").innerHTML=item.regTime1.substring(5,7);
  324. document.getElementById("day").innerHTML=item.regTime1.substring(8,10);
  325. });
  326. }
  327. },
  328. error:function(e){
  329. $.messager.progress('close');
  330. console.log(e);
  331. }
  332. });
  333. }
  334. function getCylinder(carGuid,page,size){
  335. showProgress('提示','请等待','请求源数据中……');
  336. $.ajax({
  337. type: 'POST',
  338. url: "ajax/getCylinderInfo",
  339. data: {
  340. "carGuid":carGuid,
  341. "page":page,
  342. "size":size
  343. },
  344. dataType:'text',
  345. success: function (data) {
  346. $.messager.progress('close');
  347. var vData = $.parseJSON(data);
  348. var productNo="";
  349. $.each(vData.rows, function(i,item){
  350. document.getElementById("deviceCode").innerHTML=item.EQUIPMENTNO;
  351. if(item.cylinderTypeName){
  352. if(item.cylinderTypeName.indexOf("钢质")==0){
  353. document.getElementById("deviceVariety").innerHTML="无缝气瓶";
  354. }else{
  355. document.getElementById("deviceVariety").innerHTML="特种气瓶";
  356. }
  357. document.getElementById("deviceType").innerHTML="压力容器";
  358. document.getElementById("deviceType1").innerHTML="气瓶";
  359. if(vData.rows.length<=8){
  360. if(productNo){
  361. productNo +='<br/>'+ item.cylinderNo;
  362. }else{
  363. productNo = item.cylinderNo;
  364. }
  365. }else{
  366. if(productNo){
  367. productNo +=','+ item.cylinderNo;
  368. }else{
  369. productNo = item.cylinderNo;
  370. }
  371. }
  372. }
  373. });
  374. document.getElementById("productNo").innerHTML=productNo;
  375. },
  376. error:function(e){
  377. $.messager.progress('close');
  378. console.log(e);
  379. }
  380. });
  381. }
  382. </script>
  383. <style type="text/css">
  384. .title{
  385. font-size: 24px;
  386. font-weight: bold;
  387. }
  388. .content{
  389. font-size: 24px;
  390. }
  391. .colorBlack{
  392. color: black;
  393. }
  394. .colorSmallBlack{
  395. color: #808080;
  396. }
  397. .top50{
  398. padding-top: 50px;
  399. }
  400. tr{
  401. margin-left: 20px;
  402. }
  403. .sealDiv{
  404. z-index: 999;
  405. position: absolute;
  406. margin-left: 500px;
  407. margin-top: -200px;
  408. }
  409. </style>
  410. </head>
  411. <body style="font-size:12.0pt; font-family:微软雅黑">
  412. <center>
  413. <div style="border: 5px double; width: 700px;margin-top: 20px">
  414. <table width="680px" border="0" cellpadding="2" cellspacing="0" style="padding: 10px;table-layout:fixed;" >
  415. <tr><td>&nbsp;</td></tr>
  416. <tr class="title colorBlack top50">
  417. <td colspan="4" align="center">
  418. 特种设备使用登记证
  419. </td>
  420. </tr>
  421. <tr><td>&nbsp;</td></tr>
  422. <tr >
  423. <td style="width: 50%;" colspan="2"></td>
  424. <td class="colorBlack">编号:</td>
  425. <td class="colorSmallBlack">
  426. <span id="no"></span>
  427. </td>
  428. </tr>
  429. <tr><td>&nbsp;</td></tr>
  430. <tr>
  431. <td class="colorBlack content" colspan="4">&nbsp;&nbsp;&nbsp;&nbsp;按照《中华人民共和国特种设备安全法》的规定,依据特种设备安全技术规范要求,予以使用登记。</td>
  432. </tr>
  433. <tr><td>&nbsp;</td></tr>
  434. <tr>
  435. <td>
  436. 使用单位名称:
  437. </td>
  438. <td class="colorSmallBlack" colspan="3">
  439. <span id="useUnit"></span>
  440. </td>
  441. </tr>
  442. <tr>
  443. <td>
  444. 使用单位地址:
  445. </td>
  446. <td class="colorSmallBlack" colspan="3">
  447. <span id="address"></span>
  448. </td>
  449. </tr>
  450. <tr>
  451. <td>
  452. 设备种类:
  453. </td>
  454. <td class="colorSmallBlack">
  455. <span id="deviceType"></span>
  456. </td>
  457. <td>
  458. 设备类别:
  459. </td>
  460. <td class="colorSmallBlack">
  461. <span id="deviceType1"></span>
  462. </td>
  463. </tr>
  464. <tr>
  465. <td>
  466. 设备品种:
  467. </td>
  468. <td class="colorSmallBlack">
  469. <span id="deviceVariety"></span>
  470. </td>
  471. <td>
  472. 单位内编号:
  473. </td>
  474. <td class="colorSmallBlack">
  475. <span id="carNo"></span>
  476. </td>
  477. </tr>
  478. <tr>
  479. <td>
  480. 设备代码:
  481. </td>
  482. <td class="colorSmallBlack">
  483. <span id="deviceCode"></span>
  484. </td>
  485. <td style="width:100px;">
  486. 产品编号:
  487. </td>
  488. <td class="colorSmallBlack" rowspan="3" style="word-break: break-all;word-wrap: break-word;" valign="top">
  489. <span id="productNo"></span>
  490. </td>
  491. </tr>
  492. <tr><td>&nbsp;</td></tr>
  493. <tr>
  494. <td colspan="2" align="center">
  495. <img alt="" src="testQRcode.png" width="120px"/>
  496. </td>
  497. </tr>
  498. <tr>
  499. <td colspan="2"></td>
  500. <td>登记机关:</td>
  501. <td class="colorSmallBlack">
  502. <span id="giveCertUnit"></span>
  503. </td>
  504. </tr>
  505. <tr>
  506. <td colspan="2"></td>
  507. <td>发证日期:</td>
  508. <td class="colorSmallBlack"><span id="year"></span>&nbsp;<span class="colorBlack">年</span>&nbsp;<span id="month"></span>&nbsp;<span class="colorBlack">月</span>&nbsp;<span id="day"></span>&nbsp;<span class="colorBlack">日</span>&nbsp;</td>
  509. </tr>
  510. <tr><td>&nbsp;</td></tr>
  511. <tr>
  512. <td class="colorBlack" colspan="4">&nbsp;&nbsp;&nbsp;&nbsp;依据安全技术规范的要求,应当在定期检验确定的有效期和技术参数范围内使用。</td>
  513. </tr>
  514. <tr><td>&nbsp;</td></tr>
  515. </table>
  516. <div class="sealDiv" >
  517. <img alt="" src="images/seal.png" width="150px" height="auto"/>
  518. </div>
  519. </div>
  520. </center>
  521. </body>
  522. </html>