| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638 |
- <template>
- <div class="home-container layout-pd">
- <el-row :gutter="15" class="home-card-one mb15">
- <el-col
- :xs="24"
- :sm="12"
- :md="12"
- :lg="4"
- :xl="4"
- v-for="(v, k) in state.homeOne"
- :key="k"
- :class="{ 'home-media home-media-lg': k > 1, 'home-media-sm': k === 1 }"
- >
- <div class="home-card-item flex">
- <div class="flex-margin flex w100" :class="` home-one-animation${k}`">
- <div class="flex-auto">
- <span class="font30">{{ v.num1 }}</span>
- <!-- <span class="ml5 font16" :style="{ color: v.color1 }">{{ v.num2 }}%</span>-->
- <div class="mt10">{{ v.num3 }}</div>
- </div>
- <!-- <div class="home-card-item-icon flex" :style="{ background: `var(${v.color2})` }">-->
- <!-- <i class="flex-margin font32" :class="v.num4" :style="{ color: `var(${v.color3})` }"></i>-->
- <!-- </div>-->
- </div>
- </div>
- </el-col>
- </el-row>
- <el-row :gutter="15" class="home-card-two mb15">
- <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16">
- <div class="home-card-item">
- <div class="w100 trend-header">
- <div style="width: 300px">
- <el-date-picker
- @change="loadStationStat"
- value-format="YYYY-MM-DD"
- v-model="state.dateRange"
- type="daterange"
- unlink-panels
- range-separator="至"
- start-placeholder="开始时间"
- end-placeholder="结束时间"
- :shortcuts="shortcuts"
- />
- </div>
- <div class="trend-summary">
- 总实付服务费:
- <el-tag type="success">{{ u.fmt.fmtMoney(state.homeOneExtra.payServiceAmount) }}元</el-tag>
- 总电量:
- <el-tag type="danger">{{ state.homeOneExtra.totalPower }}Kwh</el-tag>
- </div>
- </div>
- <div style="height: 100%;padding: 20px;" ref="homeLineRef"></div>
- </div>
- </el-col>
- <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8" class="home-media">
- <div class="home-card-item">
- <div style="height: 100%" ref="homePieRef"></div>
- </div>
- </el-col>
- </el-row>
- </div>
- </template>
- <script setup lang="ts" name="home">
- import NProgress from 'nprogress';
- import 'nprogress/nprogress.css';
- import {markRaw, nextTick, onActivated, onMounted, reactive, ref, watch} from 'vue';
- import * as echarts from 'echarts';
- import {storeToRefs} from 'pinia';
- import {useThemeConfig} from '/@/stores/themeConfig';
- import {useTagsViewRoutes} from '/@/stores/tagsViewRoutes';
- import {$get} from "/@/utils/request";
- import u from "/@/utils/u";
- import mittBus from "/@/utils/mitt";
- import {Session} from "/@/utils/storage";
- // 定义变量内容
- const homeLineRef = ref();
- const homePieRef = ref();
- const storesTagsViewRoutes = useTagsViewRoutes();
- const storesThemeConfig = useThemeConfig();
- const {themeConfig} = storeToRefs(storesThemeConfig);
- const {isTagsViewCurrenFull} = storeToRefs(storesTagsViewRoutes);
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
- const defaultTime = ref<[Date, Date]>([
- new Date(2000, 1, 1, 12, 0, 0),
- new Date(2000, 2, 1, 23, 59, 59),
- ])
- const state = reactive({
- currentStationId: null,
- dateRange: [u.date.format(start, "YYYY-MM-DD"), u.date.format(end, "YYYY-MM-DD")],
- global: {
- homeChartOne: null,
- homeChartTwo: null,
- homeCharThree: null,
- dispose: [null, '', undefined],
- } as any,
- homeOne: [
- {
- num1: '0',
- num2: '-12.32',
- num3: '今日充电量(kwh)',
- num4: 'fa fa-meetup',
- color1: '#FF6462',
- color2: '--next-color-primary-lighter',
- color3: '--el-color-primary',
- },
- {
- num1: '0',
- num2: '+42.32',
- num3: '今日订单总金额(元)',
- num4: 'iconfont icon-ditu',
- color1: '#6690F9',
- color2: '--next-color-success-lighter',
- color3: '--el-color-success',
- },
- {
- num1: '0',
- num2: '+17.32',
- num3: '今日总电费(元)',
- num4: 'iconfont icon-zaosheng',
- color1: '#6690F9',
- color2: '--next-color-warning-lighter',
- color3: '--el-color-warning',
- },
- {
- num1: '0',
- num2: '-10.01',
- num3: '今日实付总服务费(元)',
- num4: 'fa fa-github-alt',
- color1: '#FF6462',
- color2: '--next-color-danger-lighter',
- color3: '--el-color-danger',
- },
- {
- num1: '0',
- num2: '-10.01',
- num3: '今日充电人数',
- num4: 'fa fa-github-alt',
- color1: '#FF6462',
- color2: '--next-color-danger-lighter',
- color3: '--el-color-danger',
- },
- {
- num1: '0',
- num2: '-10.01',
- num3: '今日充电订单数(笔)',
- num4: 'fa fa-github-alt',
- color1: '#FF6462',
- color2: '--next-color-danger-lighter',
- color3: '--el-color-danger',
- },
- ],
- myCharts: [] as EmptyArrayType,
- charts: {
- theme: '',
- bgColor: '',
- color: '#303133',
- },
- homeOneExtra: {}
- });
- const shortcuts = [
- {
- text: '近7天',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 7)
- return [start, end]
- },
- },
- {
- text: '近30天',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 30)
- return [start, end]
- },
- },
- {
- text: '近90天',
- value: () => {
- const end = new Date()
- const start = new Date()
- start.setTime(start.getTime() - 3600 * 1000 * 24 * 90)
- return [start, end]
- },
- },
- ]
- // 折线图
- const initLineChart = (dataList: Array<any>) => {
- if (!state.global.dispose.some((b: any) => b === state.global.homeChartOne)) state.global.homeChartOne.dispose();
- state.global.homeChartOne = markRaw(echarts.init(homeLineRef.value, state.charts.theme));
- u.sort(dataList, "statTime")
- let xAxis = dataList.map(k => k.statTime)
- const option = {
- backgroundColor: state.charts.bgColor,
- title: {
- text: '充电数据走势图',
- x: 'left',
- textStyle: {fontSize: '15', color: state.charts.color},
- },
- grid: {top: 70, right: 0, bottom: 30, left: 50},
- tooltip: {trigger: 'axis'},
- legend: {data: ['充电量', /*'总金额','电费',*/'实付服务费',], right: 0},
- xAxis: {
- data: xAxis,
- // data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
- },
- yAxis: [
- {
- type: 'value',
- name: '费用/元 充电量/度',
- position: 'left',
- splitLine: {show: true, lineStyle: {type: 'dashed', color: '#f5f5f5'}},
- },
- ],
- series: [
- {
- name: '充电量',
- type: 'bar',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: dataList.map(k => k.totalPower),
- // data: [0, 41.1, 30.4, 65.1, 53.3, 53.3, 53.3, 41.1, 30.4, 65.1, 53.3, 10],
- lineStyle: {color: '#68a7a0'},
- itemStyle: {color: '#68a7a0', borderColor: '#68a7a0', barBorderRadius: 5},
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {offset: 0, color: '#25b8d2'},
- {offset: 1, color: '#fe9a8b03'},
- ]),
- },
- },
- /* {
- name: '总金额',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: dataList.map(k=>u.fmt.fmtMoney(k.totalMoney)),
- lineStyle: {color: '#fe9a8b'},
- itemStyle: {color: '#fe9a8b', borderColor: '#fe9a8b'},
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {offset: 0, color: '#fe9a8bb3'},
- {offset: 1, color: '#fe9a8b03'},
- ]),
- },
- },
- {
- name: '电费',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: dataList.map(k=>u.fmt.fmtMoney(k.elecMoney)),
- lineStyle: {color: '#b5fe8b'},
- itemStyle: {color: '#b5fe8b', borderColor: '#b5fe8b'},
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {offset: 0, color: '#b5fe8b'},
- {offset: 1, color: '#fe9a8b03'},
- ]),
- },
- },*/
- {
- name: '实付服务费',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: dataList.map(k => u.fmt.fmtMoney(k.payServiceAmount)),
- lineStyle: {color: '#3770ff'},
- itemStyle: {color: '#3770ff', borderColor: '#3770ff'},
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- {offset: 0, color: '#9E87FFb3'},
- {offset: 1, color: '#9E87FF03'},
- ]),
- },
- emphasis: {
- itemStyle: {
- color: {
- type: 'radial',
- x: 0.5,
- y: 0.5,
- r: 0.5,
- colorStops: [
- {offset: 0, color: '#9E87FF'},
- {offset: 0.4, color: '#9E87FF'},
- {offset: 0.5, color: '#fff'},
- {offset: 0.7, color: '#fff'},
- {offset: 0.8, color: '#fff'},
- {offset: 1, color: '#fff'},
- ],
- },
- borderColor: '#9E87FF',
- borderWidth: 2,
- },
- },
- },
- ],
- };
- state.global.homeChartOne.setOption(option);
- state.myCharts.push(state.global.homeChartOne);
- };
- // 饼图
- const initPieChart = (dataMap: any) => {
- if (!state.global.dispose.some((b: any) => b === state.global.homeChartTwo)) state.global.homeChartTwo.dispose();
- state.global.homeChartTwo = markRaw(echarts.init(homePieRef.value, state.charts.theme));
- var getname = ['离线', '空闲', '已连接', '充电中', '预约中', '故障'];
- const colorList = ['#6B6F75FF', '#36C78B', '#e9ee8e', '#ffa496', '#E790E8','#363638FF'];
- // var getvalue = [34.2, 38.87, 17.88];
- // var data = [dataMap["0"]||0,dataMap["1"]||0,dataMap["2"]||0];
- var data = [];
- for (var i = 0; i < getname.length; i++) {
- data.push({name: getname[i], value: dataMap[`${i}`] || 0});
- }
- const option = {
- backgroundColor: state.charts.bgColor,
- title: {
- text: '充电站电桩状态',
- x: 'left',
- textStyle: {fontSize: '15', color: state.charts.color},
- },
- tooltip: {trigger: 'item', formatter: '{b} <br/> {c}'},
- graphic: {
- elements: [
- {
- type: 'image',
- z: -1,
- style: {
- image: themeConfig.value.isIsDark
- ? ''
- : 'data:image/png;base64,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',
- width: 60,
- height: 60,
- },
- left: '27.5%',
- top: 'center',
- },
- ],
- },
- legend: {
- type: 'scroll',
- orient: 'vertical',
- right: '0%',
- left: '65%',
- top: 'center',
- itemWidth: 14,
- itemHeight: 14,
- data: getname,
- textStyle: {
- rich: {
- name: {
- fontSize: 14,
- fontWeight: 400,
- width: 200,
- height: 35,
- padding: [0, 0, 0, 60],
- color: state.charts.color,
- },
- rate: {
- fontSize: 15,
- fontWeight: 500,
- height: 35,
- width: 40,
- padding: [0, 0, 0, 30],
- color: state.charts.color,
- },
- },
- },
- },
- series: [
- {
- type: 'pie',
- radius: ['82', themeConfig.value.isIsDark ? '50' : '102'],
- center: ['32%', '50%'],
- itemStyle: {
- color: function (params: any) {
- return colorList[params.dataIndex];
- },
- },
- label: {show: false},
- labelLine: {show: false},
- data: data,
- },
- ],
- };
- state.global.homeChartTwo.setOption(option);
- state.myCharts.push(state.global.homeChartTwo);
- };
- // 柱状图
- // 批量设置 echarts resize
- const initEchartsResizeFun = () => {
- nextTick(() => {
- for (let i = 0; i < state.myCharts.length; i++) {
- setTimeout(() => {
- state.myCharts[i].resize();
- }, i * 1000);
- }
- });
- };
- // 批量设置 echarts resize
- const initEchartsResize = () => {
- window.addEventListener('resize', initEchartsResizeFun);
- };
- const loadCurrentEquipmentStatus = () => {
- $get(`connector/statConnectorStatus`, {stationId: state.currentStationId}).then((res: any) => {
- console.log(res)
- initPieChart(res || {});
- })
- }
- const loadStationStat = () => {
- let start = state.dateRange[0]
- let end = state.dateRange[1]
- let size = u.date.diff(new Date(start), new Date(end)) + 1;
- $get(`stat/stationStat`, {
- startTime: start,
- endTime: end,
- type: 'day',
- pageSize: size,
- stationId: state.currentStationId
- }).then((res: any) => {
- console.log(res)
- state.homeOneExtra = res.extraData
- initLineChart(res.list);
- })
- }
- const loadStationStatToday = () => {
- $get(`stat/stationTodayStat`, {stationId: state.currentStationId}).then((res: any) => {
- console.log(res)
- if (!u.isEmptyOrNull(res)) {
- let {chargeUsers, totalOrders, totalPower, totalMoney, elecMoney, payServiceAmount} = res
- state.homeOne[0].num1 = totalPower;
- state.homeOne[1].num1 = u.fmt.fmtMoney(totalMoney);
- state.homeOne[2].num1 = u.fmt.fmtMoney(elecMoney);
- state.homeOne[3].num1 = u.fmt.fmtMoney(payServiceAmount);
- state.homeOne[4].num1 = chargeUsers;
- state.homeOne[5].num1 = totalOrders;
- }
- })
- }
- // 页面加载时
- onMounted(() => {
- var currentStationId = Session.get("currentStationId");
- if (currentStationId) {
- state.currentStationId = currentStationId;
- }
- console.error("home onMounted")
- NProgress.done();
- initEchartsResize();
- //加载充电走势数据
- loadStationStat()
- //今日统计数据
- loadStationStatToday();
- //加载充电桩状态
- loadCurrentEquipmentStatus();
- mittBus.on('stationChangeRefresh', (stationId) => {
- if (stationId) {
- state.currentStationId = stationId;
- loadStationStat()
- loadStationStatToday()
- loadCurrentEquipmentStatus()
- }
- });
- });
- // 由于页面缓存原因,keep-alive
- onActivated(() => {
- initEchartsResizeFun();
- });
- // 监听 pinia 中的 tagsview 开启全屏变化,重新 resize 图表,防止不出现/大小不变等
- watch(
- () => isTagsViewCurrenFull.value,
- () => {
- initEchartsResizeFun();
- }
- );
- // 监听 pinia 中是否开启深色主题
- watch(
- () => themeConfig.value.isIsDark,
- (isIsDark) => {
- nextTick(() => {
- state.charts.theme = isIsDark ? 'dark' : '';
- state.charts.bgColor = isIsDark ? 'transparent' : '';
- state.charts.color = isIsDark ? '#dadada' : '#303133';
- setTimeout(() => {
- loadStationStat()
- }, 500);
- setTimeout(() => {
- loadCurrentEquipmentStatus();
- }, 700);
- // setTimeout(() => {
- // initBarChart();
- // }, 1000);
- });
- },
- {
- deep: true,
- immediate: true,
- }
- );
- </script>
- <style scoped lang="scss">
- $homeNavLengh: 8;
- .home-container {
- overflow: hidden;
- .home-card-one,
- .home-card-two,
- .home-card-three {
- .home-card-item {
- width: 100%;
- height: 180px;
- border-radius: 4px;
- transition: all ease 0.3s;
- padding: 20px;
- overflow: hidden;
- background: var(--el-color-white);
- color: var(--el-text-color-primary);
- border: 1px solid var(--next-border-color-light);
- &:hover {
- box-shadow: 0 2px 12px var(--next-color-dark-hover);
- transition: all ease 0.3s;
- }
- &-icon {
- width: 70px;
- height: 70px;
- border-radius: 100%;
- flex-shrink: 1;
- i {
- color: var(--el-text-color-placeholder);
- }
- }
- &-title {
- font-size: 15px;
- font-weight: bold;
- height: 30px;
- }
- }
- }
- .home-card-one {
- @for $i from 0 through 3 {
- .home-one-animation#{$i} {
- opacity: 0;
- animation-name: error-num;
- animation-duration: 0.5s;
- animation-fill-mode: forwards;
- animation-delay: calc($i/4) + s;
- }
- }
- }
- .home-card-two,
- .home-card-three {
- .home-card-item {
- height: 780px;
- width: 100%;
- overflow: hidden;
- .home-monitor {
- height: 100%;
- .flex-warp-item {
- width: 25%;
- height: 111px;
- display: flex;
- .flex-warp-item-box {
- margin: auto;
- text-align: center;
- color: var(--el-text-color-primary);
- display: flex;
- border-radius: 5px;
- background: var(--next-bg-color);
- cursor: pointer;
- transition: all 0.3s ease;
- &:hover {
- background: var(--el-color-primary-light-9);
- transition: all 0.3s ease;
- }
- }
- @for $i from 0 through $homeNavLengh {
- .home-animation#{$i} {
- opacity: 0;
- animation-name: error-num;
- animation-duration: 0.5s;
- animation-fill-mode: forwards;
- animation-delay: calc($i/10) + s;
- }
- }
- }
- }
- }
- }
- }
- .trend-header {
- display: inline-flex;
- justify-content: space-between;
- .trend-summary {
- flex: -1;
- }
- }
- </style>
|