plate.html 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812
  1. <!DOCTYPE HTML>
  2. <html xmlns:th="http://www.thymeleaf.org"
  3. xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
  4. layout:decorate="~{admin/common/common}">
  5. <head>
  6. <title>板块统计</title>
  7. <style>
  8. /*.chartContent * {*/
  9. /* padding: 0;*/
  10. /* margin: 0;*/
  11. /* }*/
  12. .chartContent .title {
  13. border-left: 5px solid #2B9CF9;
  14. padding: 0 10px;
  15. line-height: 1.5em;
  16. color: #666;
  17. margin: 25px 0 15px;
  18. }
  19. .chartLiContent {
  20. overflow: hidden
  21. }
  22. .chartContent .chartLi {
  23. float: left;
  24. height: 300px;
  25. box-sizing: border-box;
  26. }
  27. .chartContent .tableHead {
  28. background: #2B9CF9;
  29. line-height: 1.5em;
  30. color: #fff;
  31. padding: 10px 0;
  32. text-align: center;
  33. }
  34. .chartContent .tableHead .tableHeadLi {
  35. float: left;
  36. }
  37. .chartContent .tableHead {
  38. overflow: hidden;
  39. }
  40. .chartContent .tableBody {
  41. }
  42. .chartContent .tableBodyLi {
  43. overflow: hidden;
  44. background: #eee;
  45. }
  46. .chartContent .tableBodyLi .liHead {
  47. overflow: hidden;
  48. }
  49. .chartContent .tableBodyLi .liHeadTopTd {
  50. float: left;
  51. line-height: 1.2em;
  52. padding: 5px 0px 5px 0px;
  53. font-size: 14px;
  54. color: #666;
  55. }
  56. .chartContent .tableBodyLi .liHeadTopTd i.close:before {
  57. content: "\e665";
  58. }
  59. .chartContent .tableBodyLi .liBodyLi .td {
  60. float: left;
  61. line-height: 1.2em;
  62. /*padding: 5px;*/
  63. /*color: #666;*/
  64. text-align: center;
  65. display: flex;
  66. align-items: center;
  67. justify-content: center;
  68. min-height: 30px;
  69. }
  70. .table001 * {
  71. padding: 0;
  72. margin: 0;
  73. }
  74. .table001 table, .table001 .table {
  75. display: table;
  76. border-collapse: collapse;
  77. border-spacing: 0;
  78. table-layout: fixed;
  79. }
  80. .table001 table td {
  81. border: 1px solid #999;
  82. padding: 5px;
  83. }
  84. .table001 table thead td {
  85. background: #2B9CF9;
  86. color: #fff;
  87. border-color: #2B9CF9;
  88. padding: 5px 10px;
  89. line-height: 1.5em;
  90. text-align: center;
  91. }
  92. .plate_tab_list {
  93. padding-left: 20px;
  94. padding-right: 20px;
  95. width: 100%;
  96. margin-top: 15px;
  97. }
  98. .plate_tab_item {
  99. display: inline-block;
  100. float: left;
  101. text-align: center;
  102. border: 1px solid #e2e3e3;
  103. border-right: none;
  104. background-color: #ffffff;
  105. padding: 8px 20px;
  106. cursor: pointer;
  107. }
  108. .plate_tab_item:last-child {
  109. border-right: 1px solid #e2e3e3;
  110. }
  111. .date_tab_list {
  112. width: 100%;
  113. margin-top: 15px;
  114. padding-left: 20px;
  115. padding-right: 20px;
  116. }
  117. .date_tab_item {
  118. display: inline-block;
  119. float: left;
  120. text-align: center;
  121. border: 1px solid #e2e3e3;
  122. border-right: none;
  123. background-color: #ffffff;
  124. padding: 8px 20px;
  125. cursor: pointer;
  126. }
  127. .active_date {
  128. color: #ffffff;
  129. background-color: #00a0e9;
  130. }
  131. .active_plate {
  132. color: #ffffff;
  133. background-color: #00a0e9;
  134. }
  135. .liBody {
  136. background-color: #ffffff;
  137. }
  138. .liBodyLi {
  139. border-bottom: 1px solid #eaeaea;
  140. }
  141. .clearfix:after { /*伪元素是行内元素 正常浏览器清除浮动方法*/
  142. content: "";
  143. display: block;
  144. height: 0;
  145. clear: both;
  146. visibility: hidden;
  147. }
  148. .clearfix {
  149. *zoom: 1; /*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/
  150. }
  151. .chartContent{
  152. padding-left: 20px;
  153. padding-right: 20px;
  154. border-bottom: 1px solid #ded7d5;
  155. }
  156. </style>
  157. </head>
  158. <body layout:fragment="content">
  159. <nav class="breadcrumb">
  160. <i class="Hui-iconfont">&#xe67f;</i>
  161. 首页
  162. <span class="c-gray en">&gt;</span>
  163. 用地服务
  164. <span class="c-gray en">&gt;</span>
  165. 用地管理统计
  166. <span class="c-gray en">&gt;</span>
  167. 板块统计
  168. </nav>
  169. <div class="plate_tab_list clearfix" id="streetList">
  170. <!-- <span class="plate_tab_item active_plate">全部</span>-->
  171. <!-- <span class="plate_tab_item">狮山街道(含横塘)</span>-->
  172. <!-- <span class="plate_tab_item">枫桥街道</span>-->
  173. <!-- <span class="plate_tab_item">浒墅关镇</span>-->
  174. <!-- <span class="plate_tab_item">通安镇</span>-->
  175. <!-- <span class="plate_tab_item">浒墅关经开区</span>-->
  176. <!-- <span class="plate_tab_item">科技城(含东渚)</span>-->
  177. <!-- <span class="plate_tab_item">综合保税区</span>-->
  178. <!-- <span class="plate_tab_item">度假区(含镇湖)</span>-->
  179. <!-- <span class="plate_tab_item">区外</span>-->
  180. </div>
  181. <div class="chartContent">
  182. <div class="title">当前审核状态统计</div>
  183. <div class="chartLiContent">
  184. <div id="pending_pie" class="chartLi" style="width:30%;"></div>
  185. <div id="processing_bar" class="chartLi" style="width:40%;"></div>
  186. <div id="processed_pie" class="chartLi" style="width:30%;"></div>
  187. </div>
  188. </div>
  189. <div class="date_tab_list clearfix">
  190. <span class="date_tab_item" data-type="-7">7天</span>
  191. <span class="date_tab_item" data-type="-14">14天</span>
  192. <span class="date_tab_item" style="border-right: 1px solid #e2e3e3;" data-type="-30">30天</span>
  193. </div>
  194. <div class="chartContent">
  195. <div class="title">每日统计</div>
  196. <div id="daily_type_line" style="width: 96%; height: 400px"></div>
  197. </div>
  198. <div class="chartContent">
  199. <div class="title">周期分类统计</div>
  200. <div id="monthly_type_bar" style="width: 96%; height: 400px"></div>
  201. </div>
  202. <div class="chartContent">
  203. <div class="title">月度审核统计表</div>
  204. <input class="Wdate input-text" type="text" th:id="monthly_start_time" th:name="monthly_start_time"
  205. style="float:left; width: 150px;"
  206. onclick="WdatePicker({dateFmt:'yyyy-MM-dd',maxDate:'#F{$dp.$D(\'monthly_end_time\')}',isShowClear:true,readOnly:true,onpicked: function(){getMontylyApproveStatistic()} })"/>
  207. <input class="Wdate input-text" type="text" th:id="monthly_end_time" th:name="monthly_end_time"
  208. style="float:left; width: 150px;"
  209. onclick="WdatePicker({dateFmt:'yyyy-MM-dd',minDate:'#F{$dp.$D(\'monthly_start_time\')}',isShowClear:true,readOnly:true,onpicked: function(){getMontylyApproveStatistic()} })"/>
  210. <a th:onclick="'javascript:exportMonthlyStatistic();'"
  211. class="btn btn-secondary radius" type="button">导出</a>
  212. <div class="table001" style="width: 96%; margin-left: 2%;margin-top:15px;">
  213. <table id="monthly_approve_statistic" th:fragment="approve_statistic_monthly">
  214. <thead>
  215. <tr>
  216. <td>&nbsp;</td>
  217. <td colspan="3">存量工业用地房屋出租</td>
  218. <td colspan="3">存量工业用地用途依法改变</td>
  219. <td colspan="3">存量工业用地不动产权权属转移登记</td>
  220. <td colspan="3">存量工业用地项目公司股权(结构)变更登记</td>
  221. <td colspan="3">汇总</td>
  222. </tr>
  223. <tr>
  224. <td>&nbsp;</td>
  225. <td>提交数</td>
  226. <td>通过数</td>
  227. <td>通过率</td>
  228. <td>提交数</td>
  229. <td>通过数</td>
  230. <td>通过率</td>
  231. <td>提交数</td>
  232. <td>通过数</td>
  233. <td>通过率</td>
  234. <td>提交数</td>
  235. <td>通过数</td>
  236. <td>通过率</td>
  237. <td>提交数</td>
  238. <td>通过数</td>
  239. <td>通过率</td>
  240. </tr>
  241. </thead>
  242. <tbody>
  243. <tr th:each="model,iterStat:${list}" th:object="${model}">
  244. <td th:text="*{rowName}"></td>
  245. <td th:text="*{rentApplyNum}"></td>
  246. <td th:text="*{rentPassNum}"></td>
  247. <td th:text="*{rentPassRate + '%'}"></td>
  248. <td th:text="*{useChangeApplyNum}"></td>
  249. <td th:text="*{useChangePassNum}"></td>
  250. <td th:text="*{useChangePassRate + '%'}"></td>
  251. <td th:text="*{immovablesChangeApplyNum}"></td>
  252. <td th:text="*{immovablesChangePassNum}"></td>
  253. <td th:text="*{immovablesChangePassRate + '%'}"></td>
  254. <td th:text="*{equityStructureChangeApplyNum}"></td>
  255. <td th:text="*{equityStructureChangePassNum}"></td>
  256. <td th:text="*{equityStructureChangePassRate}"></td>
  257. <td th:text="*{totalApplyNum}"></td>
  258. <td th:text="*{totalPassNum}"></td>
  259. <td th:text="*{totalPassRate + '%'}"></td>
  260. </tr>
  261. </tbody>
  262. </table>
  263. </div>
  264. </div>
  265. <script th:inline="javascript">
  266. var streetId = "", startTime = "", endTime = "";
  267. var streetList = [[${streetList}]]
  268. // console.log([[${streetList}]])
  269. getApproveStatus(streetId);
  270. // getDailyStatistic(streetId, "2018-04-20", "2018-04-30");
  271. // getTypeStatistic(streetId, "", "");
  272. getMontylyApproveStatistic(streetId);
  273. //当前审核状态统计
  274. function getApproveStatus(streedId) {
  275. $.ajax({
  276. url: pagePath + "/land_statistic/approve/status?street_id=" + streedId,
  277. type: "get",
  278. dataType: "json",
  279. data: {
  280. "timestamp": new Date().getTime(),
  281. },
  282. success: function (result) {
  283. if (result.success) {
  284. // console.log(result.obj)
  285. pendingArray = result.obj.pending;
  286. processingArray = result.obj.processing;
  287. processedArray = result.obj.processed;
  288. var processingXAxisData = new Array();
  289. var processingData = new Array();
  290. // for (var argument of processingArray) {
  291. // processingXAxisData.push(argument.name);
  292. // processingData.push(argument.value);
  293. // // console.log(argument)
  294. // }
  295. processingArray.forEach(function (argument){
  296. processingXAxisData.push(argument.name);
  297. processingData.push(argument.value);
  298. })
  299. renderPendingPie("待审核", pendingArray, pendingArray);
  300. renderProcessingBar("审核中", processingXAxisData, processingData);
  301. renderProcessedPie("已审核", processedArray, processedArray);
  302. } else {
  303. errorMessage(result.message);
  304. }
  305. },
  306. error: function () {
  307. errorMessage('系统错误!');
  308. }
  309. });
  310. }
  311. //每日状态统计
  312. function getDailyStatistic(streedId, startTime, endTime) {
  313. $.ajax({
  314. url: pagePath + "/land_statistic/approve/statistic/daily?street_id=" + streedId + "&start_time=" + startTime + "&end_time=" + endTime,
  315. type: "get",
  316. dataType: "json",
  317. data: {
  318. "timestamp": new Date().getTime(),
  319. },
  320. success: function (result) {
  321. if (result.success) {
  322. console.log(result.obj)
  323. var data = result.obj.data
  324. var xAxisName = result.obj.xAxisName;
  325. var legendData = new Array();
  326. // for (var argument of data) {
  327. // legendData.push(argument.name);
  328. // }
  329. data.forEach(function (argument){
  330. legendData.push(argument.name);
  331. })
  332. renderdailyTypeLine(legendData, xAxisName, data);
  333. } else {
  334. errorMessage(result.message);
  335. }
  336. },
  337. error: function () {
  338. errorMessage('系统错误!');
  339. }
  340. });
  341. }
  342. //周期分类统计
  343. function getTypeStatistic(streedId, startTime, endTime) {
  344. $.ajax({
  345. url: pagePath + "/land_statistic/approve/type?street_id=" + streedId + "&start_time=" + startTime + "&end_time=" + endTime,
  346. type: "get",
  347. dataType: "json",
  348. data: {
  349. "timestamp": new Date().getTime(),
  350. },
  351. success: function (result) {
  352. if (result.success) {
  353. // console.log(result.obj)
  354. var data = result.obj.data
  355. var xAxisName = result.obj.xAxisName;
  356. var legendData = new Array();
  357. // for (var argument of data) {
  358. // legendData.push(argument.name);
  359. // }
  360. data.forEach(function (argument){
  361. legendData.push(argument.name);
  362. })
  363. renderMonthlyTypeBar(legendData, xAxisName, data);
  364. } else {
  365. errorMessage(result.message);
  366. }
  367. },
  368. error: function () {
  369. errorMessage('系统错误!');
  370. }
  371. });
  372. }
  373. //当前审核状态统计 待审核
  374. function renderPendingPie(title, legendData, data) {
  375. // 基于准备好的dom,初始化echarts实例
  376. var charts = echarts.init(document.getElementById('pending_pie'));
  377. // 指定图表的配置项和数据
  378. var option = {
  379. color: ['#61A5E8', '#EECB5F'],
  380. title: {
  381. text: title,
  382. textStyle: {
  383. fontSize: 18,
  384. fontWeight: 'bold'
  385. }
  386. },
  387. tooltip: {
  388. trigger: 'item',
  389. zlevel: 1,
  390. formatter: '{a} <br/>{b}: {c} ({d}%)'
  391. },
  392. legend: {
  393. orient: 'horizontal',
  394. bottom: 10,
  395. data: legendData
  396. },
  397. series: [
  398. {
  399. name: title,
  400. type: 'pie',
  401. radius: ['50%', '70%'],
  402. avoidLabelOverlap: false,
  403. label: {
  404. normal: {
  405. show: true,
  406. zlevel: 0,
  407. position: 'center',
  408. formatter: function () {
  409. var num = 0;
  410. // for (var obj of data) {
  411. // num += obj.value;
  412. // }
  413. data.forEach(function(obj){
  414. num += obj.value;
  415. })
  416. return num;
  417. }
  418. },
  419. emphasis: {
  420. show: false,
  421. textStyle: {
  422. fontSize: '30',
  423. fontWeight: 'bold'
  424. }
  425. }
  426. },
  427. labelLine: {
  428. normal: {
  429. show: false
  430. }
  431. },
  432. data: data
  433. }
  434. ]
  435. };
  436. // 使用刚指定的配置项和数据显示图表。
  437. charts.setOption(option);
  438. }
  439. //当前审核状态统计 审核中
  440. function renderProcessingBar(title, xAxisData, data) {
  441. // 基于准备好的dom,初始化echarts实例
  442. var charts = echarts.init(document.getElementById('processing_bar'));
  443. // 指定图表的配置项和数据
  444. option = {
  445. color: ['#61A5E8'],
  446. title: {
  447. text: title,
  448. textStyle: {
  449. fontSize: '18',
  450. fontWeight: 'bold'
  451. }
  452. },
  453. tooltip: {
  454. trigger: 'axis',
  455. axisPointer: { // 坐标轴指示器,坐标轴触发有效
  456. type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
  457. }
  458. },
  459. grid: {
  460. left: '3%',
  461. right: '4%',
  462. bottom: '3%',
  463. containLabel: true
  464. },
  465. xAxis: [
  466. {
  467. type: 'category',
  468. data: xAxisData,
  469. axisTick: {
  470. alignWithLabel: true
  471. },
  472. axisLabel: {
  473. interval: 0
  474. }
  475. }
  476. ],
  477. yAxis: [
  478. {
  479. type: 'value'
  480. }
  481. ],
  482. series: [
  483. {
  484. name: '',
  485. type: 'bar',
  486. barWidth: '40%',
  487. label: {
  488. normal: {
  489. show: true,
  490. position: 'top'
  491. }
  492. },
  493. data: data
  494. }
  495. ]
  496. };
  497. // 使用刚指定的配置项和数据显示图表。
  498. charts.setOption(option);
  499. }
  500. //当前审核状态统计 已审核
  501. function renderProcessedPie(title, legendData, data) {
  502. // 基于准备好的dom,初始化echarts实例
  503. var charts = echarts.init(document.getElementById('processed_pie'));
  504. // 指定图表的配置项和数据
  505. var option = {
  506. color: ['#7ECF51', '#B9646E', '#E3935D'],
  507. title: {
  508. text: title,
  509. textStyle: {
  510. fontSize: '18',
  511. fontWeight: 'bold'
  512. }
  513. },
  514. tooltip: {
  515. trigger: 'item',
  516. zlevel: 1,
  517. formatter: '{a} <br/>{b}: {c} ({d}%)'
  518. },
  519. legend: {
  520. orient: 'horizontal',
  521. bottom: 10,
  522. data: legendData
  523. },
  524. series: [
  525. {
  526. name: title,
  527. type: 'pie',
  528. radius: '70%',
  529. avoidLabelOverlap: false,
  530. label: {
  531. normal: {
  532. show: true,
  533. zlevel: 0,
  534. position: 'top',
  535. formatter: '{b}: {c}'
  536. // formatter: function () {
  537. // var num = 0;
  538. // for (var obj of data) {
  539. // num += obj.value;
  540. // }
  541. // return num;
  542. // }
  543. },
  544. emphasis: {
  545. show: false,
  546. textStyle: {
  547. fontSize: '30',
  548. fontWeight: 'bold'
  549. }
  550. }
  551. },
  552. labelLine: {
  553. normal: {
  554. show: false
  555. }
  556. },
  557. data: data
  558. }
  559. ]
  560. };
  561. // 使用刚指定的配置项和数据显示图表。
  562. charts.setOption(option);
  563. }
  564. //每日统计
  565. function renderdailyTypeLine(legendData, xAxisName, data) {
  566. // 基于准备好的dom,初始化echarts实例
  567. var charts = echarts.init(document.getElementById('daily_type_line'));
  568. // 指定图表的配置项和数据
  569. option = {
  570. color: ['#61A5E8', '#7ECF51', '#B9464E', '#E3935D'],
  571. // title: {
  572. // text: '折线图堆叠'
  573. // },
  574. tooltip: {
  575. trigger: 'axis'
  576. },
  577. legend: {
  578. data: legendData
  579. },
  580. grid: {
  581. left: '3%',
  582. right: '4%',
  583. bottom: '3%',
  584. containLabel: true
  585. },
  586. toolbox: {
  587. feature: {
  588. saveAsImage: {}
  589. }
  590. },
  591. xAxis: {
  592. type: 'category',
  593. boundaryGap: false,
  594. data: xAxisName
  595. },
  596. yAxis: {
  597. type: 'value'
  598. },
  599. series: data
  600. };
  601. // 使用刚指定的配置项和数据显示图表。
  602. charts.setOption(option);
  603. }
  604. //周期分类统计
  605. function renderMonthlyTypeBar(legendData, xAxisName, data) {
  606. // 基于准备好的dom,初始化echarts实例
  607. var charts = echarts.init(document.getElementById('monthly_type_bar'));
  608. // 指定图表的配置项和数据
  609. option = {
  610. color: ['#61A5E8', '#E3935D', '#7ECF51', '#B9464E'],
  611. tooltip: {
  612. trigger: 'axis',
  613. axisPointer: {
  614. type: 'shadow'
  615. }
  616. },
  617. legend: {
  618. orient: 'vertical',
  619. top: 80,
  620. right: 10,
  621. data: legendData
  622. },
  623. xAxis: [
  624. {
  625. type: 'category',
  626. axisTick: {show: false},
  627. data: xAxisName,
  628. axisLabel: {
  629. interval: 0,
  630. formatter: function (value) {
  631. var ret = '';
  632. var maxLength = 10;
  633. var xAxisName = value.split("\n\n")[0];
  634. var rate = value.split("\n\n")[1];
  635. var rowNum = Math.ceil(xAxisName.length / maxLength);
  636. if (rowNum > 1) {
  637. for (var i = 0; i < rowNum; i++) {
  638. var temp = "";
  639. var start = i * maxLength;
  640. var end = start + maxLength;
  641. temp = xAxisName.substring(start, end) + "\n";
  642. ret += temp;
  643. }
  644. return ret + "\n" + rate;
  645. } else {
  646. return xAxisName + "\n" + rate;
  647. }
  648. }
  649. }
  650. }
  651. ],
  652. yAxis: [{type: 'value'}],
  653. series: data
  654. };
  655. // 使用刚指定的配置项和数据显示图表。
  656. charts.setOption(option);
  657. }
  658. //月度审核统计表
  659. function getMontylyApproveStatistic() {
  660. var url = pagePath + "/land_statistic/approve/statistic/monthly"
  661. var start_time = $('#monthly_start_time').val();
  662. var end_time = $('#monthly_end_time').val();
  663. url += "?street_id=" + streetId + "&start_time=" + start_time + "&end_time=" + end_time;
  664. // 装载局部刷新返回的页面
  665. $('#monthly_approve_statistic').load(url);
  666. }
  667. //导出月度统计
  668. function exportMonthlyStatistic() {
  669. var start_time = $('#monthly_start_time').val();
  670. var end_time = $('#monthly_end_time').val();
  671. window.open(pagePath + "/land_statistic/approve/statistic/monthly/export?start_time="
  672. + start_time + "&end_time=" + end_time + "&street_id=" + streetId);
  673. }
  674. //全局修改时间
  675. function renderTime() {
  676. getDailyStatistic(streetId, startTime, endTime);
  677. getTypeStatistic(streetId, startTime, endTime);
  678. }
  679. $(function () {
  680. /*街道初始化*/
  681. var str = "<span class='plate_tab_item active_plate' data-id=''>全部</span>"
  682. for (var i = 0; i < streetList.length; i++) {
  683. str += "<span class='plate_tab_item' data-id='" + streetList[i].id + "'>" + streetList[i].name + "</span>";
  684. }
  685. $("#streetList").append(str);
  686. // 点击板块
  687. $('.plate_tab_list .plate_tab_item').click(function () {
  688. // console.log('当前点击板块', $(this).html())
  689. // console.log('当前点击板块id', $(this).data("id"))
  690. $(this).addClass('active_plate').siblings().removeClass("active_plate")
  691. streetId = $(this).data("id");
  692. getApproveStatus(streetId);
  693. getDailyStatistic(streetId, startTime, endTime);
  694. getTypeStatistic(streetId, startTime, endTime);
  695. getMontylyApproveStatistic(streetId);
  696. })
  697. /*时间初始化*/
  698. function fun_date(num) {
  699. num = num + 1
  700. //num是正数表示之后的时间,num负数表示之前的时间,0表示今天
  701. var date1 = new Date();
  702. //今天时间
  703. var year1, month1, day1;
  704. year1 = date1.getFullYear();
  705. month1 = (date1.getMonth() + 1);
  706. day1 = date1.getDate();
  707. if (month1 < 10) {
  708. month1 = "0" + month1;
  709. }
  710. if (day1 < 10) {
  711. day1 = "0" + day1;
  712. }
  713. var time1 = year1 + "-" + month1 + "-" + day1;
  714. // console.log(time1);
  715. endTime = time1;
  716. var date2 = new Date(date1);
  717. date2.setDate(date1.getDate() + num);
  718. var year2, month2, day2;
  719. year2 = date2.getFullYear();
  720. month2 = (date2.getMonth() + 1);
  721. day2 = date2.getDate();
  722. if (month2 < 10) {
  723. month2 = "0" + month2;
  724. }
  725. if (day2 < 10) {
  726. day2 = "0" + day2;
  727. }
  728. var time2 = year2 + "-" + month2 + "-" + day2;
  729. // console.log(time2);
  730. startTime = time2;
  731. renderTime()
  732. return time2;
  733. }
  734. fun_date(-7)
  735. // 点击日期
  736. $('.date_tab_list .date_tab_item').click(function () {
  737. // console.log('当前点击日期', $(this).html())
  738. // console.log('当前点击板块id', $(this).data("type"))
  739. fun_date($(this).data("type"))
  740. $(this).addClass('active_date').siblings().removeClass("active_date")
  741. })
  742. })
  743. </script>
  744. </body>
  745. </html>