index.vue 28 KB

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