ztfx.vue 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719
  1. <template>
  2. <div class="ztfx">
  3. <div class="action-bar">
  4. <div class="query mg-b-16">
  5. <div class="query-items">
  6. <div class="query-item">
  7. <div class="lable">日期:</div>
  8. <div class="search-input">
  9. <el-date-picker
  10. v-model="value4"
  11. type="date"
  12. placeholder="选择日期"
  13. popper-class="date-select"
  14. >
  15. </el-date-picker>
  16. </div>
  17. </div>
  18. <div class="query-item">
  19. <div class="search-input select-btn">
  20. <el-select
  21. v-model="value2"
  22. multiple
  23. placeholder="计算"
  24. popper-class="select"
  25. >
  26. <el-option
  27. v-for="item in options"
  28. :key="item.value"
  29. :label="item.label"
  30. :value="item.value"
  31. >
  32. </el-option>
  33. </el-select>
  34. </div>
  35. </div>
  36. </div>
  37. </div>
  38. </div>
  39. <el-row :gutter="20" class="table-panel">
  40. <el-col :span="12">
  41. <panel :title="'月度'" :showLine="false">
  42. <div class="table">
  43. <table style="width:100%;" border="0" cellspacing="0">
  44. <thead>
  45. <tr>
  46. <th rowspan="2" class="type1" style="width:5vh;"></th>
  47. <th rowspan="2" class="type1" style="width:6vh;">
  48. 故障损失电量
  49. </th>
  50. <th rowspan="2" class="type1" style="width:6vh;">
  51. 故障损失电量
  52. </th>
  53. <th rowspan="2" class="type1" style="width:6vh;">
  54. 故障损失电量
  55. </th>
  56. <th rowspan="2" class="type1" style="width:6vh;">
  57. 故障损失电量
  58. </th>
  59. <th rowspan="2" class="type1" style="width:6vh;">
  60. 故障损失电量
  61. </th>
  62. <th rowspan="2" class="type1" style="width:6vh;">
  63. 故障损失电量
  64. </th>
  65. <th rowspan="2" class="type1" style="width:6vh;">
  66. 故障损失电量
  67. </th>
  68. <th rowspan="2" class="type1" style="width:6vh;">
  69. 故障损失电量
  70. </th>
  71. <th rowspan="2" class="type1" style="width:6vh;">
  72. 故障损失电量
  73. </th>
  74. <th rowspan="2" class="type1" style="width:6vh;">
  75. 故障损失电量
  76. </th>
  77. <th rowspan="2" class="type1" style="width:6vh;">
  78. 故障损失电量
  79. </th>
  80. <th rowspan="2" class="type1" style="width:6vh;">
  81. 故障损失电量
  82. </th>
  83. </tr>
  84. </thead>
  85. </table>
  86. <el-scrollbar>
  87. <div style=" ">
  88. <table
  89. style="width:100%;text-align:center;"
  90. border="0"
  91. cellspacing="0"
  92. >
  93. <tbody>
  94. <tr>
  95. <td style="width:5vh;">
  96. 本期
  97. </td>
  98. <td class="td-item">
  99. 0.59
  100. </td>
  101. <td class="td-item">
  102. 0.59
  103. <span class="svg-icon svg-icon-green">
  104. <svg-icon svgid="svg-arrow-up-1" />
  105. </span>
  106. </td>
  107. <td class="td-item">
  108. 0.59
  109. </td>
  110. <td class="td-item">
  111. 0.59
  112. </td>
  113. <td class="td-item">
  114. 0.59
  115. </td>
  116. <td class="td-item">
  117. 0.59
  118. </td>
  119. <td class="td-item">
  120. 0.59
  121. </td>
  122. <td class="td-item">
  123. 0.59
  124. </td>
  125. <td class="td-item">
  126. 0.59
  127. </td>
  128. <td class="td-item">
  129. 0.59
  130. </td>
  131. <td class="td-item">
  132. 0.59
  133. </td>
  134. <td class="td-item">
  135. 0.59
  136. </td>
  137. </tr>
  138. <tr>
  139. <td style="width:5vh;">
  140. 当期
  141. </td>
  142. <td class="td-item">
  143. 0.59
  144. </td>
  145. <td class="td-item">
  146. 0.59
  147. <span class="svg-icon svg-icon-yellow">
  148. <svg-icon svgid="svg-arrow-dpwn-1" />
  149. </span>
  150. </td>
  151. <td class="td-item">
  152. 0.59
  153. </td>
  154. <td class="td-item">
  155. 0.59
  156. </td>
  157. <td class="td-item">
  158. 0.59
  159. </td>
  160. <td class="td-item">
  161. 0.59
  162. </td>
  163. <td class="td-item">
  164. 0.59
  165. </td>
  166. <td class="td-item">
  167. 0.59
  168. </td>
  169. <td class="td-item">
  170. 0.59
  171. </td>
  172. <td class="td-item">
  173. 0.59
  174. </td>
  175. <td class="td-item">
  176. 0.59
  177. </td>
  178. <td class="td-item">
  179. 0.59
  180. </td>
  181. </tr>
  182. </tbody>
  183. </table>
  184. </div>
  185. </el-scrollbar>
  186. </div>
  187. </panel>
  188. </el-col>
  189. <el-col :span="12">
  190. <panel :title="'年度'" :showLine="false">
  191. <div class="table">
  192. <table style="width:100%;" border="0" cellspacing="0">
  193. <thead>
  194. <tr>
  195. <th rowspan="2" class="type1" style="width:6vh;">
  196. 故障损失电量
  197. </th>
  198. <th rowspan="2" class="type1" style="width:6vh;">
  199. 故障损失电量
  200. </th>
  201. <th rowspan="2" class="type1" style="width:6vh;">
  202. 故障损失电量
  203. </th>
  204. <th rowspan="2" class="type1" style="width:6vh;">
  205. 故障损失电量
  206. </th>
  207. <th rowspan="2" class="type1" style="width:6vh;">
  208. 故障损失电量
  209. </th>
  210. <th rowspan="2" class="type1" style="width:6vh;">
  211. 故障损失电量
  212. </th>
  213. <th rowspan="2" class="type1" style="width:6vh;">
  214. 故障损失电量
  215. </th>
  216. <th rowspan="2" class="type1" style="width:6vh;">
  217. 故障损失电量
  218. </th>
  219. <th rowspan="2" class="type1" style="width:6vh;">
  220. 故障损失电量
  221. </th>
  222. <th rowspan="2" class="type1" style="width:6vh;">
  223. 故障损失电量
  224. </th>
  225. <th rowspan="2" class="type1" style="width:6vh;">
  226. 故障损失电量
  227. </th>
  228. <th rowspan="2" class="type1" style="width:6vh;">
  229. 故障损失电量
  230. </th>
  231. <th rowspan="2" class="type1" style="width:6vh;">
  232. 故障损失电量
  233. </th>
  234. </tr>
  235. </thead>
  236. </table>
  237. <el-scrollbar>
  238. <div style=" ">
  239. <table
  240. style="width:100%;text-align:center;"
  241. border="0"
  242. cellspacing="0"
  243. >
  244. <tbody>
  245. <tr v-for="index of 2" :key="index">
  246. <td class="td-item">
  247. 0.59
  248. </td>
  249. <td class="td-item">
  250. 0.59
  251. <span class="svg-icon svg-icon-yellow">
  252. <svg-icon svgid="svg-arrow-dpwn-1" />
  253. </span>
  254. </td>
  255. <td class="td-item">
  256. 0.59
  257. </td>
  258. <td class="td-item">
  259. 0.59
  260. </td>
  261. <td class="td-item">
  262. 0.59
  263. </td>
  264. <td class="td-item">
  265. 0.59
  266. </td>
  267. <td class="td-item">
  268. 0.59
  269. </td>
  270. <td class="td-item">
  271. 0.59
  272. </td>
  273. <td class="td-item">
  274. 0.59
  275. </td>
  276. <td class="td-item">
  277. 0.59
  278. </td>
  279. <td class="td-item">
  280. 0.59
  281. </td>
  282. <td class="td-item">
  283. 0.59
  284. </td>
  285. <td class="td-item">
  286. 0.59
  287. </td>
  288. </tr>
  289. </tbody>
  290. </table>
  291. </div>
  292. </el-scrollbar>
  293. </div>
  294. </panel>
  295. </el-col>
  296. </el-row>
  297. <el-row :gutter="20" class="table-complex">
  298. <el-col :span="12">
  299. <div class="table">
  300. <table style="width:100%;" border="0" cellspacing="0">
  301. <thead>
  302. <tr>
  303. <th rowspan="2" class="type1" style="width:50px;"></th>
  304. <th colspan="2" class="type1" style="width:205px;">麻黄山</th>
  305. <th colspan="2" class="type1" style="width:205px;">牛首山</th>
  306. <th colspan="2" class="type1" style="width:205px;">青山</th>
  307. <th colspan="2" class="type1" style="width:205px;">石板泉</th>
  308. <th colspan="2" class="type1" style="width:205px;">香山</th>
  309. </tr>
  310. <tr>
  311. <th style="width:105px;">当月</th>
  312. <th style="width:105px;">同期</th>
  313. <th style="width:105px;">当月</th>
  314. <th style="width:105px;">同期</th>
  315. <th style="width:105px;">当月</th>
  316. <th style="width:105px;">同期</th>
  317. <th style="width:105px;">当月</th>
  318. <th style="width:105px;">同期</th>
  319. <th style="width:105px;">当月</th>
  320. <th style="width:105px;">同期</th>
  321. </tr>
  322. </thead>
  323. </table>
  324. <el-scrollbar>
  325. <div style=" ">
  326. <table
  327. style="width:100%;text-align:center;"
  328. border="0"
  329. cellspacing="0"
  330. >
  331. <tbody>
  332. <tr v-for="index of 5" :key="index">
  333. <td style="width:50px;">
  334. NTEF
  335. </td>
  336. <td style="width:105px;">
  337. 0.59
  338. </td>
  339. <td style="width:105px;">
  340. 0.59
  341. <span class="svg-icon svg-icon-yellow">
  342. <svg-icon svgid="svg-arrow-dpwn-1" />
  343. </span>
  344. </td>
  345. <td style="width:105px;">
  346. 0.59
  347. </td>
  348. <td style="width:105px;">
  349. 0.59
  350. <span class="svg-icon svg-icon-green">
  351. <svg-icon svgid="svg-arrow-up-1" />
  352. </span>
  353. </td>
  354. <td style="width:105px;">
  355. 0.59
  356. </td>
  357. <td style="width:105px;">
  358. 0.59
  359. <span class="svg-icon svg-icon-yellow">
  360. <svg-icon svgid="svg-arrow-dpwn-1" />
  361. </span>
  362. </td>
  363. <td style="width:105px;">
  364. 0.59
  365. </td>
  366. <td style="width:105px;">
  367. 0.59
  368. <span class="svg-icon svg-icon-green">
  369. <svg-icon svgid="svg-arrow-up-1" />
  370. </span>
  371. </td>
  372. <td style="width:105px;">
  373. 0.59
  374. </td>
  375. <td style="width:105px;">
  376. 0.59
  377. <span class="svg-icon svg-icon-yellow">
  378. <svg-icon svgid="svg-arrow-dpwn-1" />
  379. </span>
  380. </td>
  381. </tr>
  382. </tbody>
  383. </table>
  384. </div>
  385. </el-scrollbar>
  386. </div>
  387. </el-col>
  388. <el-col :span="12">
  389. <div class="table">
  390. <table style="width:100%;" border="0" cellspacing="0">
  391. <thead>
  392. <tr>
  393. <th rowspan="2" class="type1" style="width:50px;"></th>
  394. <th colspan="2" class="type1" style="width:205px;">麻黄山</th>
  395. <th colspan="2" class="type1" style="width:205px;">牛首山</th>
  396. <th colspan="2" class="type1" style="width:205px;">青山</th>
  397. <th colspan="2" class="type1" style="width:205px;">石板泉</th>
  398. <th colspan="2" class="type1" style="width:205px;">香山</th>
  399. </tr>
  400. <tr>
  401. <th style="width:105px;">当月</th>
  402. <th style="width:105px;">同期</th>
  403. <th style="width:105px;">当月</th>
  404. <th style="width:105px;">同期</th>
  405. <th style="width:105px;">当月</th>
  406. <th style="width:105px;">同期</th>
  407. <th style="width:105px;">当月</th>
  408. <th style="width:105px;">同期</th>
  409. <th style="width:105px;">当月</th>
  410. <th style="width:105px;">同期</th>
  411. </tr>
  412. </thead>
  413. </table>
  414. <el-scrollbar>
  415. <div style=" ">
  416. <table
  417. style="width:100%;text-align:center;"
  418. border="0"
  419. cellspacing="0"
  420. >
  421. <tbody>
  422. <tr v-for="index of 5" :key="index">
  423. <td style="width:50px;">
  424. NTEF
  425. </td>
  426. <td style="width:105px;">
  427. 0.59
  428. </td>
  429. <td style="width:105px;">
  430. 0.59
  431. <span class="svg-icon svg-icon-yellow">
  432. <svg-icon svgid="svg-arrow-dpwn-1" />
  433. </span>
  434. </td>
  435. <td style="width:105px;">
  436. 0.59
  437. </td>
  438. <td style="width:105px;">
  439. 0.59
  440. <span class="svg-icon svg-icon-green">
  441. <svg-icon svgid="svg-arrow-up-1" />
  442. </span>
  443. </td>
  444. <td style="width:105px;">
  445. 0.59
  446. </td>
  447. <td style="width:105px;">
  448. 0.59
  449. <span class="svg-icon svg-icon-yellow">
  450. <svg-icon svgid="svg-arrow-dpwn-1" />
  451. </span>
  452. </td>
  453. <td style="width:105px;">
  454. 0.59
  455. </td>
  456. <td style="width:105px;">
  457. 0.59
  458. <span class="svg-icon svg-icon-green">
  459. <svg-icon svgid="svg-arrow-up-1" />
  460. </span>
  461. </td>
  462. <td style="width:105px;">
  463. 0.59
  464. </td>
  465. <td style="width:105px;">
  466. 0.59
  467. <span class="svg-icon svg-icon-yellow">
  468. <svg-icon svgid="svg-arrow-dpwn-1" />
  469. </span>
  470. </td>
  471. </tr>
  472. </tbody>
  473. </table>
  474. </div>
  475. </el-scrollbar></div
  476. ></el-col>
  477. </el-row>
  478. <el-row :gutter="20" class="pie-chart-panel">
  479. <el-col :span="6">
  480. <panel title="当月理论平衡分析">
  481. <dual-pie-chart height="27.296vh" />
  482. </panel>
  483. </el-col>
  484. <el-col :span="6">
  485. <panel title="当月理论平衡分析">
  486. <dual-pie-chart height="27.296vh" />
  487. </panel>
  488. </el-col>
  489. <el-col :span="6">
  490. <panel title="当月理论平衡分析">
  491. <dual-pie-chart height="27.296vh" />
  492. </panel>
  493. </el-col>
  494. <el-col :span="6">
  495. <panel title="当月理论平衡分析">
  496. <dual-pie-chart height="27.296vh" />
  497. </panel>
  498. </el-col>
  499. </el-row>
  500. </div>
  501. </template>
  502. <script>
  503. import Panel from "../../components/coms/panel/panel.vue";
  504. import DualPieChart from "../../components/chart/pie/dual-pie-chart.vue";
  505. import SvgIcon from "../../components/coms/icon/svg-icon.vue";
  506. export default {
  507. setup() {},
  508. components: {
  509. Panel,
  510. DualPieChart,
  511. SvgIcon,
  512. },
  513. data() {
  514. return {
  515. tableData2: {
  516. column: [
  517. {
  518. name: " ",
  519. field: "name",
  520. width: "10%",
  521. },
  522. {
  523. name: "故障损失电量",
  524. field: "v1",
  525. },
  526. {
  527. name: "故障损失电量",
  528. field: "v2",
  529. template: function(data) {
  530. return data;
  531. },
  532. },
  533. {
  534. name: "故障损失电量",
  535. field: "v3",
  536. },
  537. {
  538. name: "故障损失电量",
  539. field: "v4",
  540. },
  541. {
  542. name: "故障损失电量",
  543. field: "v5",
  544. },
  545. {
  546. name: "故障损失电量",
  547. field: "v6",
  548. },
  549. {
  550. name: "故障损失电量",
  551. field: "v7",
  552. },
  553. {
  554. name: "故障损失电量",
  555. field: "v8",
  556. },
  557. {
  558. name: "故障损失电量",
  559. field: "v9",
  560. },
  561. {
  562. name: "故障损失电量",
  563. field: "v10",
  564. },
  565. {
  566. name: "故障损失电量",
  567. field: "v11",
  568. },
  569. {
  570. name: "故障损失电量",
  571. field: "v12",
  572. },
  573. ],
  574. data: [
  575. {
  576. name: "本期",
  577. v1: "0.59",
  578. v2: "0.59",
  579. v3: "0.59",
  580. v4: "0.59",
  581. v5: "0.59",
  582. v6: "0.59",
  583. v7: "0.59",
  584. v8: "0.59",
  585. v9: "0.59",
  586. v10: "0.59",
  587. v11: "0.59",
  588. v12: "0.59",
  589. },
  590. {
  591. name: "同期",
  592. v1: "0.59",
  593. v2: "0.59",
  594. v3: "0.59",
  595. v4: "0.59",
  596. v5: "0.59",
  597. v6: "0.59",
  598. v7: "0.59",
  599. v8: "0.59",
  600. v9: "0.59",
  601. v10: "0.59",
  602. v11: "0.59",
  603. v12: "0.59",
  604. },
  605. ],
  606. },
  607. };
  608. },
  609. created() {},
  610. };
  611. </script>
  612. <style lang="less">
  613. .ztfx {
  614. font-size: 12px;
  615. .select-btn {
  616. width: 92px;
  617. }
  618. .com-panel {
  619. border: 1px solid #6067697d;
  620. }
  621. .table-complex {
  622. margin-top: 10px;
  623. .table {
  624. border: 1px solid #6067697d;
  625. tbody {
  626. tr:nth-child(2n) td {
  627. background-color: fade(@gray, 20%);
  628. &.item {
  629. background-color: transparent;
  630. }
  631. }
  632. }
  633. th {
  634. background: fade(@gray, 40);
  635. font-size: 12px;
  636. font-weight: 400;
  637. line-height: 24px;
  638. color: @gray-l;
  639. &.type1 {
  640. border-left: 0;
  641. border-right: 0;
  642. }
  643. }
  644. td {
  645. color: @gray-l;
  646. text-align: center;
  647. height: 26px;
  648. line-height: 26px;
  649. &.item {
  650. width: 100px;
  651. }
  652. }
  653. svg {
  654. height: 1.222vh;
  655. }
  656. }
  657. }
  658. .table-panel {
  659. margin-top: 10px;
  660. .panel-header {
  661. text-align: center;
  662. }
  663. .table {
  664. border: 1px solid #6067697d;
  665. tbody {
  666. tr:nth-child(2n) td {
  667. background-color: fade(@gray, 20%);
  668. &.item {
  669. background-color: transparent;
  670. }
  671. }
  672. }
  673. .td-item {
  674. width: 6vh;
  675. }
  676. th {
  677. background: fade(@gray, 40);
  678. font-size: 12px;
  679. font-weight: 400;
  680. line-height: 24px;
  681. color: @gray-l;
  682. &.type1 {
  683. border-left: 0;
  684. border-right: 0;
  685. height: 4vh;
  686. }
  687. }
  688. td {
  689. color: @gray-l;
  690. text-align: center;
  691. height: 26px;
  692. line-height: 26px;
  693. &.item {
  694. width: 100px;
  695. }
  696. }
  697. svg {
  698. height: 1.222vh;
  699. }
  700. }
  701. }
  702. .pie-chart-panel {
  703. margin-top: 10px;
  704. .line{
  705. border:none;
  706. }
  707. }
  708. }
  709. </style>