index.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638
  1. <template>
  2. <div class="home-container layout-pd">
  3. <el-row :gutter="15" class="home-card-one mb15">
  4. <el-col
  5. :xs="24"
  6. :sm="12"
  7. :md="12"
  8. :lg="4"
  9. :xl="4"
  10. v-for="(v, k) in state.homeOne"
  11. :key="k"
  12. :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }"
  13. >
  14. <div class="home-card-item flex">
  15. <div class="flex-margin flex w100" :class="` home-one-animation${k}`">
  16. <div class="flex-auto">
  17. <span class="font30">{{ v.num1 }}</span>
  18. <!-- <span class="ml5 font16" :style="{ color: v.color1 }">{{ v.num2 }}%</span>-->
  19. <div class="mt10">{{ v.num3 }}</div>
  20. </div>
  21. <!-- <div class="home-card-item-icon flex" :style="{ background: `var(${v.color2})` }">-->
  22. <!-- <i class="flex-margin font32" :class="v.num4" :style="{ color: `var(${v.color3})` }"></i>-->
  23. <!-- </div>-->
  24. </div>
  25. </div>
  26. </el-col>
  27. </el-row>
  28. <el-row :gutter="15" class="home-card-two mb15">
  29. <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16">
  30. <div class="home-card-item">
  31. <div class="w100 trend-header">
  32. <div style="width: 300px">
  33. <el-date-picker
  34. @change="loadStationStat"
  35. value-format="YYYY-MM-DD"
  36. v-model="state.dateRange"
  37. type="daterange"
  38. unlink-panels
  39. range-separator="至"
  40. start-placeholder="开始时间"
  41. end-placeholder="结束时间"
  42. :shortcuts="shortcuts"
  43. />
  44. </div>
  45. <div class="trend-summary">
  46. 总实付服务费:
  47. <el-tag type="success">{{ u.fmt.fmtMoney(state.homeOneExtra.payServiceAmount) }}元</el-tag>
  48. 总电量:
  49. <el-tag type="danger">{{ state.homeOneExtra.totalPower }}Kwh</el-tag>
  50. </div>
  51. </div>
  52. <div style="height: 100%;padding: 20px;" ref="homeLineRef"></div>
  53. </div>
  54. </el-col>
  55. <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media">
  56. <div class="home-card-item">
  57. <div style="height: 100%" ref="homePieRef"></div>
  58. </div>
  59. </el-col>
  60. </el-row>
  61. </div>
  62. </template>
  63. <script setup lang="ts" name="home">
  64. import NProgress from 'nprogress';
  65. import 'nprogress/nprogress.css';
  66. import {markRaw, nextTick, onActivated, onMounted, reactive, ref, watch} from 'vue';
  67. import * as echarts from 'echarts';
  68. import {storeToRefs} from 'pinia';
  69. import {useThemeConfig} from '/@/stores/themeConfig';
  70. import {useTagsViewRoutes} from '/@/stores/tagsViewRoutes';
  71. import {$get} from "/@/utils/request";
  72. import u from "/@/utils/u";
  73. import mittBus from "/@/utils/mitt";
  74. import {Session} from "/@/utils/storage";
  75. // 定义变量内容
  76. const homeLineRef = ref();
  77. const homePieRef = ref();
  78. const storesTagsViewRoutes = useTagsViewRoutes();
  79. const storesThemeConfig = useThemeConfig();
  80. const {themeConfig} = storeToRefs(storesThemeConfig);
  81. const {isTagsViewCurrenFull} = storeToRefs(storesTagsViewRoutes);
  82. const end = new Date()
  83. const start = new Date()
  84. start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
  85. const defaultTime = ref<[Date, Date]>([
  86. new Date(2000, 1, 1, 12, 0, 0),
  87. new Date(2000, 2, 1, 23, 59, 59),
  88. ])
  89. const state = reactive({
  90. currentStationId: null,
  91. dateRange: [u.date.format(start, "YYYY-MM-DD"), u.date.format(end, "YYYY-MM-DD")],
  92. global: {
  93. homeChartOne: null,
  94. homeChartTwo: null,
  95. homeCharThree: null,
  96. dispose: [null, '', undefined],
  97. } as any,
  98. homeOne: [
  99. {
  100. num1: '0',
  101. num2: '-12.32',
  102. num3: '今日充电量(kwh)',
  103. num4: 'fa fa-meetup',
  104. color1: '#FF6462',
  105. color2: '--next-color-primary-lighter',
  106. color3: '--el-color-primary',
  107. },
  108. {
  109. num1: '0',
  110. num2: '+42.32',
  111. num3: '今日订单总金额(元)',
  112. num4: 'iconfont icon-ditu',
  113. color1: '#6690F9',
  114. color2: '--next-color-success-lighter',
  115. color3: '--el-color-success',
  116. },
  117. {
  118. num1: '0',
  119. num2: '+17.32',
  120. num3: '今日总电费(元)',
  121. num4: 'iconfont icon-zaosheng',
  122. color1: '#6690F9',
  123. color2: '--next-color-warning-lighter',
  124. color3: '--el-color-warning',
  125. },
  126. {
  127. num1: '0',
  128. num2: '-10.01',
  129. num3: '今日实付总服务费(元)',
  130. num4: 'fa fa-github-alt',
  131. color1: '#FF6462',
  132. color2: '--next-color-danger-lighter',
  133. color3: '--el-color-danger',
  134. },
  135. {
  136. num1: '0',
  137. num2: '-10.01',
  138. num3: '今日充电人数',
  139. num4: 'fa fa-github-alt',
  140. color1: '#FF6462',
  141. color2: '--next-color-danger-lighter',
  142. color3: '--el-color-danger',
  143. },
  144. {
  145. num1: '0',
  146. num2: '-10.01',
  147. num3: '今日充电订单数(笔)',
  148. num4: 'fa fa-github-alt',
  149. color1: '#FF6462',
  150. color2: '--next-color-danger-lighter',
  151. color3: '--el-color-danger',
  152. },
  153. ],
  154. myCharts: [] as EmptyArrayType,
  155. charts: {
  156. theme: '',
  157. bgColor: '',
  158. color: '#303133',
  159. },
  160. homeOneExtra: {}
  161. });
  162. const shortcuts = [
  163. {
  164. text: '近7天',
  165. value: () => {
  166. const end = new Date()
  167. const start = new Date()
  168. start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
  169. return [start, end]
  170. },
  171. },
  172. {
  173. text: '近30天',
  174. value: () => {
  175. const end = new Date()
  176. const start = new Date()
  177. start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
  178. return [start, end]
  179. },
  180. },
  181. {
  182. text: '近90天',
  183. value: () => {
  184. const end = new Date()
  185. const start = new Date()
  186. start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
  187. return [start, end]
  188. },
  189. },
  190. ]
  191. // 折线图
  192. const initLineChart = (dataList: Array<any>) => {
  193. if (!state.global.dispose.some((b: any) => b === state.global.homeChartOne)) state.global.homeChartOne.dispose();
  194. state.global.homeChartOne = markRaw(echarts.init(homeLineRef.value, state.charts.theme));
  195. u.sort(dataList, "statTime")
  196. let xAxis = dataList.map(k => k.statTime)
  197. const option = {
  198. backgroundColor: state.charts.bgColor,
  199. title: {
  200. text: '充电数据走势图',
  201. x: 'left',
  202. textStyle: {fontSize: '15', color: state.charts.color},
  203. },
  204. grid: {top: 70, right: 0, bottom: 30, left: 50},
  205. tooltip: {trigger: 'axis'},
  206. legend: {data: ['充电量', /*'总金额','电费',*/'实付服务费',], right: 0},
  207. xAxis: {
  208. data: xAxis,
  209. // data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
  210. },
  211. yAxis: [
  212. {
  213. type: 'value',
  214. name: '费用/元 充电量/度',
  215. position: 'left',
  216. splitLine: {show: true, lineStyle: {type: 'dashed', color: '#f5f5f5'}},
  217. },
  218. ],
  219. series: [
  220. {
  221. name: '充电量',
  222. type: 'bar',
  223. symbolSize: 6,
  224. symbol: 'circle',
  225. smooth: true,
  226. data: dataList.map(k => k.totalPower),
  227. // data: [0, 41.1, 30.4, 65.1, 53.3, 53.3, 53.3, 41.1, 30.4, 65.1, 53.3, 10],
  228. lineStyle: {color: '#68a7a0'},
  229. itemStyle: {color: '#68a7a0', borderColor: '#68a7a0', barBorderRadius: 5},
  230. areaStyle: {
  231. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  232. {offset: 0, color: '#25b8d2'},
  233. {offset: 1, color: '#fe9a8b03'},
  234. ]),
  235. },
  236. },
  237. /* {
  238. name: '总金额',
  239. type: 'line',
  240. symbolSize: 6,
  241. symbol: 'circle',
  242. smooth: true,
  243. data: dataList.map(k=>u.fmt.fmtMoney(k.totalMoney)),
  244. lineStyle: {color: '#fe9a8b'},
  245. itemStyle: {color: '#fe9a8b', borderColor: '#fe9a8b'},
  246. areaStyle: {
  247. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  248. {offset: 0, color: '#fe9a8bb3'},
  249. {offset: 1, color: '#fe9a8b03'},
  250. ]),
  251. },
  252. },
  253. {
  254. name: '电费',
  255. type: 'line',
  256. symbolSize: 6,
  257. symbol: 'circle',
  258. smooth: true,
  259. data: dataList.map(k=>u.fmt.fmtMoney(k.elecMoney)),
  260. lineStyle: {color: '#b5fe8b'},
  261. itemStyle: {color: '#b5fe8b', borderColor: '#b5fe8b'},
  262. areaStyle: {
  263. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  264. {offset: 0, color: '#b5fe8b'},
  265. {offset: 1, color: '#fe9a8b03'},
  266. ]),
  267. },
  268. },*/
  269. {
  270. name: '实付服务费',
  271. type: 'line',
  272. symbolSize: 6,
  273. symbol: 'circle',
  274. smooth: true,
  275. data: dataList.map(k => u.fmt.fmtMoney(k.payServiceAmount)),
  276. lineStyle: {color: '#3770ff'},
  277. itemStyle: {color: '#3770ff', borderColor: '#3770ff'},
  278. areaStyle: {
  279. color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
  280. {offset: 0, color: '#9E87FFb3'},
  281. {offset: 1, color: '#9E87FF03'},
  282. ]),
  283. },
  284. emphasis: {
  285. itemStyle: {
  286. color: {
  287. type: 'radial',
  288. x: 0.5,
  289. y: 0.5,
  290. r: 0.5,
  291. colorStops: [
  292. {offset: 0, color: '#9E87FF'},
  293. {offset: 0.4, color: '#9E87FF'},
  294. {offset: 0.5, color: '#fff'},
  295. {offset: 0.7, color: '#fff'},
  296. {offset: 0.8, color: '#fff'},
  297. {offset: 1, color: '#fff'},
  298. ],
  299. },
  300. borderColor: '#9E87FF',
  301. borderWidth: 2,
  302. },
  303. },
  304. },
  305. ],
  306. };
  307. state.global.homeChartOne.setOption(option);
  308. state.myCharts.push(state.global.homeChartOne);
  309. };
  310. // 饼图
  311. const initPieChart = (dataMap: any) => {
  312. if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose();
  313. state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme));
  314. var getname = ['离线', '空闲', '已连接', '充电中', '预约中', '故障'];
  315. const colorList = ['#6B6F75FF', '#36C78B', '#e9ee8e', '#ffa496', '#E790E8','#363638FF'];
  316. // var getvalue = [34.2, 38.87, 17.88];
  317. // var data = [dataMap["0"]||0,dataMap["1"]||0,dataMap["2"]||0];
  318. var data = [];
  319. for (var i = 0; i < getname.length; i++) {
  320. data.push({name: getname[i], value: dataMap[`${i}`] || 0});
  321. }
  322. const option = {
  323. backgroundColor: state.charts.bgColor,
  324. title: {
  325. text: '充电站电桩状态',
  326. x: 'left',
  327. textStyle: {fontSize: '15', color: state.charts.color},
  328. },
  329. tooltip: {trigger: 'item', formatter: '{b} <br/> {c}'},
  330. graphic: {
  331. elements: [
  332. {
  333. type: 'image',
  334. z: -1,
  335. style: {
  336. image: themeConfig.value.isIsDark
  337. ? ''
  338. : 'data:image/png;base64,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',
  339. width: 60,
  340. height: 60,
  341. },
  342. left: '27.5%',
  343. top: 'center',
  344. },
  345. ],
  346. },
  347. legend: {
  348. type: 'scroll',
  349. orient: 'vertical',
  350. right: '0%',
  351. left: '65%',
  352. top: 'center',
  353. itemWidth: 14,
  354. itemHeight: 14,
  355. data: getname,
  356. textStyle: {
  357. rich: {
  358. name: {
  359. fontSize: 14,
  360. fontWeight: 400,
  361. width: 200,
  362. height: 35,
  363. padding: [0, 0, 0, 60],
  364. color: state.charts.color,
  365. },
  366. rate: {
  367. fontSize: 15,
  368. fontWeight: 500,
  369. height: 35,
  370. width: 40,
  371. padding: [0, 0, 0, 30],
  372. color: state.charts.color,
  373. },
  374. },
  375. },
  376. },
  377. series: [
  378. {
  379. type: 'pie',
  380. radius: ['82', themeConfig.value.isIsDark ? '50' : '102'],
  381. center: ['32%', '50%'],
  382. itemStyle: {
  383. color: function (params: any) {
  384. return colorList[params.dataIndex];
  385. },
  386. },
  387. label: {show: false},
  388. labelLine: {show: false},
  389. data: data,
  390. },
  391. ],
  392. };
  393. state.global.homeChartTwo.setOption(option);
  394. state.myCharts.push(state.global.homeChartTwo);
  395. };
  396. // 柱状图
  397. // 批量设置 echarts resize
  398. const initEchartsResizeFun = () => {
  399. nextTick(() => {
  400. for (let i = 0; i < state.myCharts.length; i++) {
  401. setTimeout(() => {
  402. state.myCharts[i].resize();
  403. }, i * 1000);
  404. }
  405. });
  406. };
  407. // 批量设置 echarts resize
  408. const initEchartsResize = () => {
  409. window.addEventListener('resize', initEchartsResizeFun);
  410. };
  411. const loadCurrentEquipmentStatus = () => {
  412. $get(`connector/statConnectorStatus`, {stationId: state.currentStationId}).then((res: any) => {
  413. console.log(res)
  414. initPieChart(res || {});
  415. })
  416. }
  417. const loadStationStat = () => {
  418. let start = state.dateRange[0]
  419. let end = state.dateRange[1]
  420. let size = u.date.diff(new Date(start), new Date(end)) + 1;
  421. $get(`stat/stationStat`, {
  422. startTime: start,
  423. endTime: end,
  424. type: 'day',
  425. pageSize: size,
  426. stationId: state.currentStationId
  427. }).then((res: any) => {
  428. console.log(res)
  429. state.homeOneExtra = res.extraData
  430. initLineChart(res.list);
  431. })
  432. }
  433. const loadStationStatToday = () => {
  434. $get(`stat/stationTodayStat`, {stationId: state.currentStationId}).then((res: any) => {
  435. console.log(res)
  436. if (!u.isEmptyOrNull(res)) {
  437. let {chargeUsers, totalOrders, totalPower, totalMoney, elecMoney, payServiceAmount} = res
  438. state.homeOne[0].num1 = totalPower;
  439. state.homeOne[1].num1 = u.fmt.fmtMoney(totalMoney);
  440. state.homeOne[2].num1 = u.fmt.fmtMoney(elecMoney);
  441. state.homeOne[3].num1 = u.fmt.fmtMoney(payServiceAmount);
  442. state.homeOne[4].num1 = chargeUsers;
  443. state.homeOne[5].num1 = totalOrders;
  444. }
  445. })
  446. }
  447. // 页面加载时
  448. onMounted(() => {
  449. var currentStationId = Session.get("currentStationId");
  450. if (currentStationId) {
  451. state.currentStationId = currentStationId;
  452. }
  453. console.error("home onMounted")
  454. NProgress.done();
  455. initEchartsResize();
  456. //加载充电走势数据
  457. loadStationStat()
  458. //今日统计数据
  459. loadStationStatToday();
  460. //加载充电桩状态
  461. loadCurrentEquipmentStatus();
  462. mittBus.on('stationChangeRefresh', (stationId) => {
  463. if (stationId) {
  464. state.currentStationId = stationId;
  465. loadStationStat()
  466. loadStationStatToday()
  467. loadCurrentEquipmentStatus()
  468. }
  469. });
  470. });
  471. // 由于页面缓存原因,keep-alive
  472. onActivated(() => {
  473. initEchartsResizeFun();
  474. });
  475. // 监听 pinia 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等
  476. watch(
  477. () => isTagsViewCurrenFull.value,
  478. () => {
  479. initEchartsResizeFun();
  480. }
  481. );
  482. // 监听 pinia 中是否开启深色主题
  483. watch(
  484. () => themeConfig.value.isIsDark,
  485. (isIsDark) => {
  486. nextTick(() => {
  487. state.charts.theme = isIsDark ? 'dark' : '';
  488. state.charts.bgColor = isIsDark ? 'transparent' : '';
  489. state.charts.color = isIsDark ? '#dadada' : '#303133';
  490. setTimeout(() => {
  491. loadStationStat()
  492. }, 500);
  493. setTimeout(() => {
  494. loadCurrentEquipmentStatus();
  495. }, 700);
  496. // setTimeout(() => {
  497. // initBarChart();
  498. // }, 1000);
  499. });
  500. },
  501. {
  502. deep: true,
  503. immediate: true,
  504. }
  505. );
  506. </script>
  507. <style scoped lang="scss">
  508. $homeNavLengh: 8;
  509. .home-container {
  510. overflow: hidden;
  511. .home-card-one,
  512. .home-card-two,
  513. .home-card-three {
  514. .home-card-item {
  515. width: 100%;
  516. height: 180px;
  517. border-radius: 4px;
  518. transition: all ease 0.3s;
  519. padding: 20px;
  520. overflow: hidden;
  521. background: var(--el-color-white);
  522. color: var(--el-text-color-primary);
  523. border: 1px solid var(--next-border-color-light);
  524. &:hover {
  525. box-shadow: 0 2px 12px var(--next-color-dark-hover);
  526. transition: all ease 0.3s;
  527. }
  528. &-icon {
  529. width: 70px;
  530. height: 70px;
  531. border-radius: 100%;
  532. flex-shrink: 1;
  533. i {
  534. color: var(--el-text-color-placeholder);
  535. }
  536. }
  537. &-title {
  538. font-size: 15px;
  539. font-weight: bold;
  540. height: 30px;
  541. }
  542. }
  543. }
  544. .home-card-one {
  545. @for $i from 0 through 3 {
  546. .home-one-animation#{$i} {
  547. opacity: 0;
  548. animation-name: error-num;
  549. animation-duration: 0.5s;
  550. animation-fill-mode: forwards;
  551. animation-delay: calc($i/4) + s;
  552. }
  553. }
  554. }
  555. .home-card-two,
  556. .home-card-three {
  557. .home-card-item {
  558. height: 780px;
  559. width: 100%;
  560. overflow: hidden;
  561. .home-monitor {
  562. height: 100%;
  563. .flex-warp-item {
  564. width: 25%;
  565. height: 111px;
  566. display: flex;
  567. .flex-warp-item-box {
  568. margin: auto;
  569. text-align: center;
  570. color: var(--el-text-color-primary);
  571. display: flex;
  572. border-radius: 5px;
  573. background: var(--next-bg-color);
  574. cursor: pointer;
  575. transition: all 0.3s ease;
  576. &:hover {
  577. background: var(--el-color-primary-light-9);
  578. transition: all 0.3s ease;
  579. }
  580. }
  581. @for $i from 0 through $homeNavLengh {
  582. .home-animation#{$i} {
  583. opacity: 0;
  584. animation-name: error-num;
  585. animation-duration: 0.5s;
  586. animation-fill-mode: forwards;
  587. animation-delay: calc($i/10) + s;
  588. }
  589. }
  590. }
  591. }
  592. }
  593. }
  594. }
  595. .trend-header {
  596. display: inline-flex;
  597. justify-content: space-between;
  598. .trend-summary {
  599. flex: -1;
  600. }
  601. }
  602. </style>