123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750 |
- <template>
- <div class="home-container layout-pd" v-loading="state.loading">
- <el-row :gutter="15" class="home-card-one mb15">
- <el-col
- :xs="24"
- :sm="12"
- :md="12"
- :lg="6"
- :xl="6"
- 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 style="height: 100%" 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>
- <!-- <el-row :gutter="15" class="home-card-three">-->
- <!-- <el-col :xs="24" :sm="10" :md="10" :lg="8" :xl="8">-->
- <!-- <div class="home-card-item">-->
- <!-- <div class="home-card-item-title">快捷导航工具</div>-->
- <!-- <div class="home-monitor">-->
- <!-- <div class="flex-warp">-->
- <!-- <div class="flex-warp-item" v-for="(v, k) in state.homeThree" :key="k">-->
- <!-- <div class="flex-warp-item-box" :class="`home-animation${k}`">-->
- <!-- <div class="flex-margin">-->
- <!-- <i :class="v.icon" :style="{ color: v.iconColor }"></i>-->
- <!-- <span class="pl5">{{ v.label }}</span>-->
- <!-- <div class="mt10">{{ v.value }}</div>-->
- <!-- </div>-->
- <!-- </div>-->
- <!-- </div>-->
- <!-- </div>-->
- <!-- </div>-->
- <!-- </div>-->
- <!-- </el-col>-->
- <!-- <el-col :xs="24" :sm="14" :md="14" :lg="16" :xl="16" class="home-media">-->
- <!-- <div class="home-card-item">-->
- <!-- <div style="height: 100%" ref="homeBarRef"></div>-->
- <!-- </div>-->
- <!-- </el-col>-->
- <!-- </el-row>-->
- <div class="version">
- 托肯恒山科技有限公司 V 4.1.1
- </div>
- </div>
- </template>
- <script setup lang="ts" name="example/home">
- 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 {useChartDataStore} from "/@/stores/chartDataStore";
- import {workBenchDto} from "/@/api/admin/workbench/workBenchDto";
- const chartDataStore = useChartDataStore()
- // 定义变量内容
- const homeLineRef = ref()
- const homePieRef = ref()
- const homeBarRef = ref()
- const storesTagsViewRoutes = useTagsViewRoutes()
- const storesThemeConfig = useThemeConfig()
- const { themeConfig } = storeToRefs(storesThemeConfig)
- const { isTagsViewCurrenFull } = storeToRefs(storesTagsViewRoutes)
- const state = reactive({
- loading:false,
- global: {
- homeChartOne: null,
- homeChartTwo: null,
- homeCharThree: null,
- dispose: [null, '', undefined],
- } as any,
- homeOne: [
- {
- num1: 0,
- // num2: '-12.32',
- num3: '国标备案主板',
- num4: 'fa fa-microchip',
- color1: '#FF6462',
- color2: '--next-color-primary-lighter',
- color3: '--el-color-primary',
- },
- {
- num1: 0,
- // num2: '+42.32',
- num3: '备案ECVR-FM',
- num4: 'fa fa-flag-checkered',
- color1: '#6690F9',
- color2: '--next-color-success-lighter',
- color3: '--el-color-success',
- },
- {
- num1: 0,
- // num2: '+17.32',
- num3: '待使用主板密钥',
- num4: 'fa fa-key',
- color1: '#6690F9',
- color2: '--next-color-warning-lighter',
- color3: '--el-color-warning',
- },
- {
- num1: 0,
- // num2: '-10.01',
- num3: '待使用ECVR-FM',
- num4: 'fa fa-flag-o',
- color1: '#FF6462',
- color2: '--next-color-danger-lighter',
- color3: '--el-color-danger',
- },
- // {
- // num1: 0,
- // // num2: '-10.01',
- // num3: '备案OPW',
- // num4: 'fa fa-flag-o',
- // color1: '#FBD4A0',
- // color2: '--next-color-danger-lighter',
- // color3: '--el-color-success',
- // },
- // {
- // num1: 0,
- // // num2: '-10.01',
- // num3: '待使用OPW密钥',
- // num4: 'fa fa-flag-o',
- // color1: '#FBD4A0',
- // color2: '--next-color-danger-lighter',
- // color3: '--el-color-danger',
- // },
- ],
- homeThree: [
- {
- icon: 'iconfont icon-yangan',
- label: '浅粉红',
- value: '2.1%OBS/M',
- iconColor: '#F72B3F',
- },
- {
- icon: 'iconfont icon-wendu',
- label: '深红(猩红)',
- value: '30℃',
- iconColor: '#91BFF8',
- },
- {
- icon: 'iconfont icon-shidu',
- label: '淡紫红',
- value: '57%RH',
- iconColor: '#88D565',
- },
- {
- icon: 'iconfont icon-shidu',
- label: '弱紫罗兰红',
- value: '107w',
- iconColor: '#88D565',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '中紫罗兰红',
- value: '57DB',
- iconColor: '#FBD4A0',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '紫罗兰',
- value: '57PV',
- iconColor: '#FBD4A0',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '暗紫罗兰',
- value: '517Cpd',
- iconColor: '#FBD4A0',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '幽灵白',
- value: '12kg',
- iconColor: '#FBD4A0',
- },
- {
- icon: 'iconfont icon-zaosheng',
- label: '海军蓝',
- value: '64fm',
- iconColor: '#FBD4A0',
- },
- ],
- myCharts: [] as EmptyArrayType,
- charts: {
- theme: '',
- bgColor: '',
- color: '#303133',
- },
- })
- /**折线图数据*/
- const lineChart = ref({
- option : {
- backgroundColor: state.charts.bgColor,
- title: {
- text: '国标灌注',
- x: 'left',
- textStyle: { fontSize: '15', color: state.charts.color },
- },
- grid: { top: 70, right: 20, bottom: 30, left: 30 },
- tooltip: { trigger: 'axis' },
- legend: { data: ['ECVR-FM', '国标主板', '国标备案主板', 'ECVR-FM备案'], right: 0 },
- xAxis: {
- data: ['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'],
- },
- yAxis: [
- {
- type: 'value',
- name: '数量',
- splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } },
- },
- ],
- series: [
- {
- name: 'ECVR-FM',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: [],
- lineStyle: { color: '#3498db' },
- itemStyle: { color: '#3498db', borderColor: '#3498db' },
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: '#3498db' },
- { offset: 1, color: '#3498db' },
- ]),
- },
- },
- {
- name: '国标主板',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: [],
- lineStyle: { color: '#2ecc71' },
- itemStyle: { color: '#2ecc71', borderColor: '#2ecc71' },
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: '#51cc88' },
- { offset: 1, color: '#51cc88' },
- ]),
- },
- },
- {
- name: '国标备案主板',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: [],
- lineStyle: { color: '#e74c3c' },
- itemStyle: { color: '#e74c3c', borderColor: '#e74c3c' },
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: '#e3584a' },
- { offset: 1, color: '#e3584a' },
- ]),
- },
- },
- {
- name: 'ECVR-FM备案',
- type: 'line',
- symbolSize: 6,
- symbol: 'circle',
- smooth: true,
- data: [],
- lineStyle: { color: '#f39c12' },
- itemStyle: { color: '#f39c12', borderColor: '#f39c12' },
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: '#eea93c' },
- { offset: 1, color: '#eea93c' },
- ]),
- },
- },
- ],
- }
- })
- /**饼图数据*/
- const pieChart = reactive({
- getName : [],
- getValue : []
- })
- //折线图
- const initLineChart = () => {
- 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))
- state.global.homeChartOne.setOption(lineChart.value.option)
- state.myCharts.push(state.global.homeChartOne)
- }
- // 饼图
- const initPieChart = () => {
- 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 data = []
- for (var i = 0; i < pieChart.getName.length; i++) {
- data.push({ name: pieChart.getName[i], value: pieChart.getValue[i] })
- }
- const colorList = ['#E720E8', '#36C78B', '#FEC279', '#968AF5', '#B0C54EFF','#51A3FC','#E710E8','#75c7c0','#fd95de','#5900ff','#e4252e','#c8ff00','#65808d']
- 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
- ? ''
- : '',
- width: 230,
- height: 230,
- },
- left: '16.5%',
- top: 'center',
- },
- ],
- },
- legend: {
- type: 'scroll',
- orient: 'vertical',
- right: '0%',
- left: '65%',
- top: 'center',
- itemWidth: 14,
- itemHeight: 14,
- data: pieChart.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)
- }
- // 柱状图
- const initBarChart = () => {
- if (!state.global.dispose.some((b: any) => b === state.global.homeCharThree)) state.global.homeCharThree.dispose()
- state.global.homeCharThree = markRaw(echarts.init(homeBarRef.value, state.charts.theme))
- const option = {
- backgroundColor: state.charts.bgColor,
- title: {
- text: '地热开发利用',
- x: 'left',
- textStyle: { fontSize: '15', color: state.charts.color },
- },
- tooltip: { trigger: 'axis' },
- legend: { data: ['供温', '回温', '压力值(Mpa)'], right: 0 },
- grid: { top: 70, right: 80, bottom: 30, left: 80 },
- xAxis: [
- {
- type: 'category',
- data: ['1km', '2km', '3km', '4km', '5km', '6km'],
- boundaryGap: true,
- axisTick: { show: false },
- },
- ],
- yAxis: [
- {
- name: '供回温度(℃)',
- nameLocation: 'middle',
- nameTextStyle: { padding: [3, 4, 50, 6] },
- splitLine: { show: true, lineStyle: { type: 'dashed', color: '#f5f5f5' } },
- axisLine: { show: false },
- axisTick: { show: false },
- axisLabel: { color: state.charts.color, formatter: '{value} ' },
- },
- {
- name: '压力值(Mpa)',
- nameLocation: 'middle',
- nameTextStyle: { padding: [50, 4, 5, 6] },
- splitLine: { show: false },
- axisLine: { show: false },
- axisTick: { show: false },
- axisLabel: { color: state.charts.color, formatter: '{value} ' },
- },
- ],
- series: [
- {
- name: '供温',
- type: 'line',
- smooth: true,
- showSymbol: true,
- // 矢量画五角星
- symbol: 'path://M150 0 L80 175 L250 75 L50 75 L220 175 Z',
- symbolSize: 12,
- yAxisIndex: 0,
- areaStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: 'rgba(250,180,101,0.3)' },
- { offset: 1, color: 'rgba(250,180,101,0)' },
- ]),
- shadowColor: 'rgba(250,180,101,0.2)',
- shadowBlur: 20,
- },
- itemStyle: { color: '#FF8000' },
- // data中可以使用对象,value代表相应的值,另外可加入自定义的属性
- data: [
- { value: 1, stationName: 's1' },
- { value: 3, stationName: 's2' },
- { value: 4, stationName: 's3' },
- { value: 9, stationName: 's4' },
- { value: 3, stationName: 's5' },
- { value: 2, stationName: 's6' },
- ],
- },
- {
- name: '回温',
- type: 'line',
- smooth: true,
- showSymbol: true,
- symbol: 'emptyCircle',
- symbolSize: 12,
- yAxisIndex: 0,
- areaStyle: {
- color: new echarts.graphic.LinearGradient(
- 0,
- 0,
- 0,
- 1,
- [
- { offset: 0, color: 'rgba(199, 237, 250,0.5)' },
- { offset: 1, color: 'rgba(199, 237, 250,0.2)' },
- ],
- false
- ),
- },
- itemStyle: {
- color: '#3bbc86',
- },
- data: [
- { value: 31, stationName: 's1' },
- { value: 36, stationName: 's2' },
- { value: 54, stationName: 's3' },
- { value: 24, stationName: 's4' },
- { value: 73, stationName: 's5' },
- { value: 22, stationName: 's6' },
- ],
- },
- {
- name: '压力值(Mpa)',
- type: 'bar',
- barWidth: 30,
- yAxisIndex: 1,
- itemStyle: {
- color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
- { offset: 0, color: 'rgba(108,80,243,0.3)' },
- { offset: 1, color: 'rgba(108,80,243,0)' },
- ]),
- //柱状图圆角
- borderRadius: [30, 30, 0, 0],
- },
- data: [
- { value: 11, stationName: 's1' },
- { value: 34, stationName: 's2' },
- { value: 54, stationName: 's3' },
- { value: 39, stationName: 's4' },
- { value: 63, stationName: 's5' },
- { value: 24, stationName: 's6' },
- ],
- },
- ],
- }
- state.global.homeCharThree.setOption(option)
- state.myCharts.push(state.global.homeCharThree)
- }
- // 批量设置 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 initData = async () => {
- state.loading = true
- const data : workBenchDto = chartDataStore.getChartStore()
- const { mainboardChart } = data.chart
- state.homeOne[0].num1 = data.calculatorMainboardCount ?? 0
- state.homeOne[1].num1 = data.vaporRecoveryCount ?? 0
- state.homeOne[2].num1 = data.vaporRecoveryStateCount ?? 0
- state.homeOne[3].num1 = data.calculatorMainboardStateCount ?? 0
- lineChart.value.option.series[0].data = getSeriesData(data.chart?.vaporRecovery)
- lineChart.value.option.series[1].data = getSeriesData(data.chart?.calculatorMainboard)
- lineChart.value.option.series[2].data = getSeriesData(data.chart?.recordCalculatorMainboard)
- lineChart.value.option.series[3].data = getSeriesData(data.chart?.recordVaporRecovery)
- pieChart.getName = pieChartGetName(mainboardChart)
- pieChart.getValue = pieChartGetValue(mainboardChart)
- debugger
- state.loading = false
- }
- /**获取当前月份*/
- const nowMonth = new Date().getMonth() + 1
- /**获取当前月份之前的数据*/
- const getSeriesData = (obj) => {
- const fixedLengthArray: number[] = new Array(nowMonth).fill(0);
- obj.map(item => {
- // console.log(item)
- if(item.month <= nowMonth){
- fixedLengthArray[item.month-1] = item.totalCount
- }
- })
- return fixedLengthArray
- }
- /**计算饼状图的数组*/
- const pieChartGetName = (val) => {
- return val?.reduce((v, obj) => {
- v.push(obj.name)
- return v
- }, [])
- }
- /**计算饼状图的数据*/
- const pieChartGetValue = (val) => {
- const total = val?.reduce((v, obj) => {
- v += obj?.totalCount ?? 0
- return v
- },0)
- const arr = val?.reduce((v, obj) => {
- v.push((obj.totalCount/total * 100).toFixed(2))
- return v
- },[])
- return arr
- }
- // 页面加载时
- onMounted(() => {
- initEchartsResize()
- initData()
- })
- // 由于页面缓存原因,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(() => {
- initLineChart()
- }, 500)
- setTimeout(() => {
- initPieChart()
- }, 700)
- setTimeout(() => {
- initBarChart()
- }, 1000)
- })
- },
- {
- deep: true,
- immediate: true,
- }
- )
- </script>
- <style scoped lang="scss">
- $homeNavLengh: 8;
- .home-container {
- overflow: hidden;
- max-height:100%;
- .home-card-one,
- .home-card-two,
- .home-card-three {
- .home-card-item {
- width: 100%;
- height: 130px;
- 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: 600px;
- height: 60vh;
- 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;
- }
- }
- }
- }
- }
- }
- .home-card-one{
- .home-card-item{
- overflow: hidden;
- height: 16vh;
- }
- }
- .version{
- display: flex;
- justify-content: center;
- margin-top: 6vh;
- font-size: 15px;
- }
- }
- </style>
|