console-old.html 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  6. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
  7. <title>EasyWeb后台开发框架</title>
  8. <link rel="stylesheet" href="../../assets/libs/layui/css/layui.css"/>
  9. <link rel="stylesheet" href="../../assets/module/admin.css?v=315"/>
  10. <!--[if lt IE 9]>
  11. <script src="https://oss.maxcdn.com/html5shiv/3.7.3/html5shiv.min.js"></script>
  12. <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
  13. <![endif]-->
  14. <style>
  15. /** 统计快捷方式样式 */
  16. .console-link-block {
  17. display: block;
  18. position: relative;
  19. color: #fff;
  20. font-size: 18px;
  21. padding: 25px 20px;
  22. border-radius: 4px;
  23. overflow: hidden;
  24. box-shadow: 0px 3px 5px rgba(0, 0, 0, .1);
  25. background-color: rgb(155, 197, 57);
  26. }
  27. .console-link-block .console-link-block-num {
  28. font-size: 40px;
  29. font-weight: bold;
  30. margin-bottom: 10px;
  31. }
  32. .console-link-block .console-link-block-icon {
  33. height: 70px;
  34. position: absolute;
  35. right: 20px;
  36. top: 50%;
  37. transform: translateY(-50%);
  38. }
  39. .console-link-block .console-link-block-band {
  40. background-color: rgb(227, 42, 22);
  41. font-size: 14px;
  42. position: absolute;
  43. width: 80px;
  44. padding: 2px 0;
  45. text-align: center;
  46. transform: rotate(45deg);
  47. right: -21px;
  48. top: 8px;
  49. color: rgba(255, 255, 255, .9);
  50. z-index: 1;
  51. }
  52. /** //统计快捷方式样式end */
  53. /** 小屏幕下样式 */
  54. @media screen and (max-width: 992px) {
  55. .console-link-block {
  56. font-size: 14px;
  57. padding: 15px 10px;
  58. }
  59. .console-link-block .console-link-block-num {
  60. font-size: 28px;
  61. margin-bottom: 0px;
  62. }
  63. .console-link-block .console-link-block-icon {
  64. height: 45px;
  65. right: 10px;
  66. }
  67. .console-link-block .console-link-block-band {
  68. font-size: 12px;
  69. right: -25px;
  70. top: 8px;
  71. }
  72. }
  73. /** 设置每个快捷块的颜色 */
  74. #consoleLink > div:first-child .console-link-block {
  75. background-color: rgb(155, 197, 57);
  76. }
  77. #consoleLink > div:nth-child(2) .console-link-block {
  78. background-color: rgb(85, 165, 234);
  79. }
  80. #consoleLink > div:nth-child(3) .console-link-block {
  81. background-color: rgb(157, 175, 291);
  82. }
  83. #consoleLink > div:nth-child(4) .console-link-block {
  84. background-color: rgb(245, 145, 162);
  85. }
  86. #consoleLink > div:nth-child(5) .console-link-block {
  87. background-color: rgb(254, 170, 79);
  88. }
  89. #consoleLink > div:last-child .console-link-block {
  90. background-color: rgb(64, 212, 176);
  91. }
  92. /** //设置每个快捷块的颜色end */
  93. </style>
  94. </head>
  95. <body>
  96. <!-- 正文开始 -->
  97. <div class="layui-fluid">
  98. <!-- 快捷方式 -->
  99. <div id="consoleLink" class="layui-row layui-col-space15">
  100. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  101. <div class="console-link-block" ew-href="page/system/user.html" ew-title="外出申请">
  102. <div class="console-link-block-num">15</div>
  103. <div class="console-link-block-text">外出申请</div>
  104. <div class="console-link-block-band">待审批</div>
  105. <img class="console-link-block-icon" src="../../assets/images/homepic1.png">
  106. </div>
  107. </div>
  108. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  109. <div class="console-link-block" ew-href="page/system/role.html" ew-title="请假审批">
  110. <div class="console-link-block-num">13</div>
  111. <div class="console-link-block-text">请假审批</div>
  112. <div class="console-link-block-band">待审批</div>
  113. <img class="console-link-block-icon" src="../../assets/images/homepic2.png">
  114. </div>
  115. </div>
  116. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  117. <div class="console-link-block" ew-href="page/system/authorities.html" ew-title="研发周报">
  118. <img class="console-link-block-icon" src="../../assets/images/homepic3.png">
  119. <div class="console-link-block-num">22</div>
  120. <div class="console-link-block-text">研发周报</div>
  121. <div class="console-link-block-band">去查看</div>
  122. </div>
  123. </div>
  124. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  125. <div class="console-link-block" ew-href="page/system/loginRecord.html" ew-title="研发月报">
  126. <img class="console-link-block-icon" src="../../assets/images/homepic4.png">
  127. <div class="console-link-block-num">18</div>
  128. <div class="console-link-block-text">研发月报</div>
  129. <div class="console-link-block-band">去查看</div>
  130. </div>
  131. </div>
  132. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  133. <div class="console-link-block" ew-href="page/plugin/basic/dialog.html" ew-title="拜访记录">
  134. <img class="console-link-block-icon" src="../../assets/images/homepic5.png">
  135. <div class="console-link-block-num">11</div>
  136. <div class="console-link-block-text">拜访记录</div>
  137. <div class="console-link-block-band">去查看</div>
  138. </div>
  139. </div>
  140. <div class="layui-col-lg2 layui-col-md4 layui-col-sm4 layui-col-xs6">
  141. <div class="console-link-block" ew-href="page/plugin/basic/notice.html" ew-title="项目申报">
  142. <img class="console-link-block-icon" src="../../assets/images/homepic6.png">
  143. <div class="console-link-block-num">26</div>
  144. <div class="console-link-block-text">项目申报</div>
  145. <div class="console-link-block-band">待审批</div>
  146. </div>
  147. </div>
  148. </div>
  149. <!-- 统计图表 -->
  150. <div class="layui-row layui-col-space15">
  151. <div class="layui-col-md4 layui-col-xs12">
  152. <div class="layui-card">
  153. <div class="layui-card-header">日统计</div>
  154. <div class="layui-card-body">
  155. <div style="height: 300px;position: relative;">
  156. <div id="tjDivDay" style="height: 100%;"></div>
  157. <span id="btnShowDetail"
  158. style="color: #1AB4E8;font-size: 18px;position: absolute;bottom: 75px;left: 50%;transform: translateX(-50%);cursor: pointer;">
  159. 签到明细<i class="layui-icon layui-icon-right" style="font-size: 16px;"></i>
  160. </span>
  161. </div>
  162. <div class="layui-row text-center">
  163. <div class="layui-col-xs6">
  164. <div id="tv1Num1" style="color: #28a6d6;font-size: 22px;">22</div>
  165. <div style="font-size: 18px;padding: 10px 0 15px 0;">未签到</div>
  166. </div>
  167. <div class="layui-col-xs6">
  168. <div id="tv1Num2" style="color: #28a6d6;font-size: 22px;">38</div>
  169. <div style="font-size: 18px;padding: 10px 0 15px 0;">已签到</div>
  170. </div>
  171. </div>
  172. </div>
  173. </div>
  174. </div>
  175. <div class="layui-col-md4 layui-col-xs12">
  176. <div class="layui-card">
  177. <div class="layui-card-header">周统计</div>
  178. <div class="layui-card-body">
  179. <div id="tjDivWeek" style="height: 373px;"></div>
  180. </div>
  181. </div>
  182. </div>
  183. <div class="layui-col-md4 layui-col-xs12">
  184. <div class="layui-card">
  185. <div class="layui-card-header">月统计</div>
  186. <div class="layui-card-body">
  187. <div id="tjDivMonth" style="height: 373px;"></div>
  188. </div>
  189. </div>
  190. </div>
  191. </div>
  192. </div>
  193. <!-- 加载动画 -->
  194. <div class="page-loading">
  195. <div class="ball-loader">
  196. <span></span><span></span><span></span><span></span>
  197. </div>
  198. </div>
  199. <!-- js部分 -->
  200. <script type="text/javascript" src="../../assets/libs/layui/layui.js"></script>
  201. <script type="text/javascript" src="../../assets/js/common.js?v=315"></script>
  202. <script src="../../assets/libs/echarts/echarts.min.js"></script>
  203. <script src="../../assets/libs/echarts/echartsTheme.js"></script>
  204. <script>
  205. layui.use(['layer', 'table', 'admin'], function () {
  206. var $ = layui.jquery;
  207. var layer = layui.layer;
  208. var table = layui.table;
  209. var admin = layui.admin;
  210. // 渲染日签到图表
  211. var myCharts1 = echarts.init(document.getElementById('tjDivDay'), myEchartsTheme);
  212. var options1 = {
  213. title: {
  214. show: true,
  215. x: 'center',
  216. y: '33%',
  217. text: '签到人数/应到人数',
  218. textStyle: {
  219. fontSize: 20,
  220. color: '#333'
  221. },
  222. subtextStyle: {
  223. fontSize: 50,
  224. lineHeight: 100,
  225. color: '#28a6d6'
  226. }
  227. },
  228. color: ['#18B4E7', '#ddd'],
  229. tooltip: {
  230. trigger: 'item'
  231. },
  232. series: [
  233. {
  234. name: '人数',
  235. type: 'pie',
  236. radius: ['75%', '80%'],
  237. label: {
  238. normal: {
  239. show: false
  240. }
  241. }
  242. }
  243. ]
  244. };
  245. myCharts1.setOption(options1);
  246. // 搜索
  247. var res1 = JSON.parse('{"msg":"操作成功","signNum":38,"signList":[{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"},{"number":"12","name":"用户一","time":"05:30"}],"code":200,"allNum":60}');
  248. var mSignList = res1.signList;
  249. myCharts1.setOption({
  250. title: {
  251. subtext: res1.signNum + "/" + res1.allNum
  252. },
  253. series: [
  254. {
  255. data: [
  256. {name: "已签到", value: res1.signNum},
  257. {name: "未签到", value: res1.allNum - res1.signNum}
  258. ]
  259. }
  260. ]
  261. });
  262. // 签到明细
  263. $('#btnShowDetail').click(function () {
  264. admin.open({
  265. type: 1,
  266. area: '500px',
  267. offset: '80px',
  268. title: '签到明细',
  269. content: '<table id="signDetailTable" lay-filter="signDetailTable"></table>',
  270. success: function (layero, dIndex) {
  271. // 渲染表格
  272. table.render({
  273. elem: '#signDetailTable',
  274. data: mSignList,
  275. page: false,
  276. height: 280,
  277. cellMinWidth: 100,
  278. cols: [[
  279. {type: 'numbers', title: '#'},
  280. {field: 'number', title: '工号'},
  281. {field: 'name', title: '姓名'},
  282. {field: 'time', title: '签到时间'},
  283. ]],
  284. done: function () {
  285. $(layero).find('.layui-table-view').css('margin', '0');
  286. }
  287. });
  288. // end
  289. }
  290. });
  291. });
  292. // ------------------------------------------------------------------------
  293. // 渲染周签到图表
  294. var myCharts2 = echarts.init(document.getElementById('tjDivWeek'), myEchartsTheme);
  295. var options2 = {
  296. tooltip: {
  297. trigger: "axis",
  298. axisPointer: {
  299. lineStyle: {
  300. color: '#E0E0E0'
  301. }
  302. }
  303. },
  304. color: ['#10B4E8', '#FFA800'],
  305. legend: {
  306. orient: 'vertical',
  307. right: '0px',
  308. top: '25px',
  309. data: ['已签到', '未签到']
  310. },
  311. grid: {
  312. top: '120px',
  313. left: '35px',
  314. right: '55px'
  315. },
  316. xAxis: {
  317. name: '星期',
  318. nameTextStyle: {
  319. color: '#333'
  320. },
  321. type: 'category',
  322. data: ['周一', '周二', '周三', '周四', '周五'],
  323. axisLine: {
  324. lineStyle: {
  325. color: '#E0E0E0'
  326. },
  327. symbol: ['none', 'arrow'],
  328. symbolOffset: [0, 10]
  329. },
  330. axisLabel: {
  331. color: '#9A9A9A'
  332. }
  333. },
  334. yAxis: {
  335. name: '人数',
  336. nameTextStyle: {
  337. color: '#333'
  338. },
  339. type: 'value',
  340. boundaryGap: ['0', '20%'],
  341. axisTick: {
  342. show: false
  343. },
  344. axisLine: {
  345. lineStyle: {
  346. color: '#E0E0E0'
  347. },
  348. symbol: ['none', 'arrow'],
  349. symbolOffset: [0, 10]
  350. },
  351. axisLabel: {
  352. color: '#9A9A9A'
  353. },
  354. splitLine: {
  355. show: false
  356. },
  357. splitArea: {
  358. show: false
  359. },
  360. minInterval: 1
  361. },
  362. series: [
  363. {
  364. name: '已签到',
  365. type: 'bar',
  366. stack: "one",
  367. barMaxWidth: '30px',
  368. data: [0, 0, 0, 0, 0],
  369. label: {
  370. normal: {
  371. show: true,
  372. position: 'inside',
  373. formatter: function (params) {
  374. if (params.value > 0) {
  375. return params.value;
  376. } else {
  377. return '';
  378. }
  379. }
  380. }
  381. }
  382. },
  383. {
  384. name: '未签到',
  385. type: 'bar',
  386. stack: "one",
  387. barMaxWidth: '30px',
  388. data: [0, 0, 0, 0, 0],
  389. label: {
  390. normal: {
  391. show: true,
  392. position: 'inside'
  393. }
  394. }
  395. }
  396. ]
  397. };
  398. myCharts2.setOption(options2);
  399. // 获取数据
  400. var res2 = JSON.parse('{"msg":"操作成功","code":200,"data":[{"date":"2019-06-03","signNum":5,"unSignNum":10},{"date":"2019-06-04","signNum":9,"unSignNum":6},{"date":"2019-06-05","signNum":5,"unSignNum":10},{"date":"2019-06-06","signNum":2,"unSignNum":13},{"date":"2019-06-07","signNum":3,"unSignNum":12}]}');
  401. var dateList = [], signNums = [], unSignNums = [];
  402. for (var i = 0; i < res2.data.length; i++) {
  403. var one = res2.data[i];
  404. dateList.push(one.date);
  405. signNums.push(one.signNum);
  406. unSignNums.push(one.unSignNum);
  407. }
  408. myCharts2.setOption({
  409. series: [{data: signNums}, {data: unSignNums}]
  410. });
  411. // -------------------------------------------------------------------------
  412. // 渲染周签到图表
  413. var myCharts3 = echarts.init(document.getElementById('tjDivMonth'), myEchartsTheme);
  414. var options3 = {
  415. tooltip: {
  416. trigger: 'axis',
  417. axisPointer: {
  418. lineStyle: {
  419. color: '#E0E0E0'
  420. }
  421. },
  422. formatter: '{b}号<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:#10B4E8;"></span>{a0}: {c0}<br/><span style="display:inline-block;margin-right:5px;border-radius:10px;width:10px;height:10px;background-color:#FFA800;"></span>{a1}: {c1}'
  423. },
  424. color: ['#10B4E8', '#FFA800'],
  425. legend: {
  426. orient: 'vertical',
  427. right: '0px',
  428. top: '25px',
  429. data: ['已签到', '未签到']
  430. },
  431. grid: {
  432. top: '120px',
  433. left: '35px',
  434. right: '55px'
  435. },
  436. xAxis: {
  437. name: '日期',
  438. nameTextStyle: {
  439. color: '#333'
  440. },
  441. type: 'category',
  442. data: ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18', '19', '20', '21', '22', '23', '24', '25', '26', '27', '28', '29', '30', '31'],
  443. axisLine: {
  444. lineStyle: {
  445. color: '#E0E0E0'
  446. },
  447. symbol: ['none', 'arrow'],
  448. symbolOffset: [0, 10]
  449. },
  450. axisLabel: {
  451. color: '#9A9A9A',
  452. interval: function (index, value) {
  453. if (index == 0 || ((index + 1) % 5 == 0)) {
  454. return true;
  455. }
  456. return false;
  457. }
  458. }
  459. },
  460. yAxis: {
  461. name: '人数',
  462. nameTextStyle: {
  463. color: '#333'
  464. },
  465. type: 'value',
  466. boundaryGap: ['0', '20%'],
  467. axisTick: {
  468. show: false
  469. },
  470. axisLine: {
  471. lineStyle: {
  472. color: '#E0E0E0'
  473. },
  474. symbol: ['none', 'arrow'],
  475. symbolOffset: [0, 10]
  476. },
  477. axisLabel: {
  478. color: '#9A9A9A'
  479. },
  480. splitLine: {
  481. show: false
  482. },
  483. splitArea: {
  484. show: false
  485. },
  486. minInterval: 1
  487. },
  488. series: [
  489. {
  490. name: '已签到',
  491. type: 'line',
  492. smooth: false,
  493. data: []
  494. },
  495. {
  496. name: '未签到',
  497. type: 'line',
  498. smooth: false,
  499. data: []
  500. }
  501. ]
  502. };
  503. myCharts3.setOption(options3);
  504. // 获取数据
  505. var res3 = JSON.parse('{"msg":"操作成功","code":200,"data":[{"date":"2019-06-01","signNum":5,"unSignNum":10},{"date":"2019-06-02","signNum":3,"unSignNum":12},{"date":"2019-06-03","signNum":2,"unSignNum":13},{"date":"2019-06-04","signNum":5,"unSignNum":10},{"date":"2019-06-05","signNum":3,"unSignNum":12},{"date":"2019-06-06","signNum":6,"unSignNum":9},{"date":"2019-06-07","signNum":8,"unSignNum":7},{"date":"2019-06-08","signNum":2,"unSignNum":13},{"date":"2019-06-09","signNum":13,"unSignNum":2},{"date":"2019-06-10","signNum":5,"unSignNum":10},{"date":"2019-06-11","signNum":10,"unSignNum":5},{"date":"2019-06-12","signNum":9,"unSignNum":6},{"date":"2019-06-13","signNum":10,"unSignNum":5},{"date":"2019-06-14","signNum":5,"unSignNum":10},{"date":"2019-06-15","signNum":8,"unSignNum":7},{"date":"2019-06-16","signNum":6,"unSignNum":9},{"date":"2019-06-17","signNum":3,"unSignNum":12},{"date":"2019-06-18","signNum":5,"unSignNum":10},{"date":"2019-06-19","signNum":12,"unSignNum":3},{"date":"2019-06-20","signNum":8,"unSignNum":7},{"date":"2019-06-21","signNum":9,"unSignNum":6},{"date":"2019-06-22","signNum":12,"unSignNum":3},{"date":"2019-06-23","signNum":11,"unSignNum":4},{"date":"2019-06-24","signNum":10,"unSignNum":5},{"date":"2019-06-25","signNum":8,"unSignNum":7},{"date":"2019-06-26","signNum":9,"unSignNum":6},{"date":"2019-06-27","signNum":9,"unSignNum":6},{"date":"2019-06-28","signNum":10,"unSignNum":5},{"date":"2019-06-29","signNum":3,"unSignNum":12},{"date":"2019-06-30","signNum":2,"unSignNum":13}]}');
  506. var dateList = [], signNums = [], unSignNums = [];
  507. for (var i = 0; i < res3.data.length; i++) {
  508. var one = res3.data[i];
  509. dateList.push(i + 1);
  510. signNums.push(one.signNum);
  511. unSignNums.push(one.unSignNum);
  512. }
  513. myCharts3.setOption({
  514. xAxis: {data: dateList},
  515. series: [{data: signNums}, {data: unSignNums}]
  516. });
  517. // -------------------------------------------------------------------------
  518. // 窗口大小改变事件
  519. window.onresize = function () {
  520. myCharts1.resize();
  521. myCharts2.resize();
  522. myCharts3.resize();
  523. };
  524. });
  525. </script>
  526. </body>
  527. </html>