mirror of
				https://github.com/continew-org/continew-admin-ui.git
				synced 2025-10-25 08:57:10 +08:00 
			
		
		
		
	feat: 仪表盘地图板块(未完成)
This commit is contained in:
		
							
								
								
									
										103310
									
								
								src/components/Chart/china.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										103310
									
								
								src/components/Chart/china.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,16 +1,13 @@ | |||||||
| <template> | <template> | ||||||
|   <VCharts |   <VCharts v-if="renderChart" :option="option" :autoresize="autoResize" :style="{ width, height }" ref="chart" /> | ||||||
|     v-if="renderChart" |  | ||||||
|     :option="option" |  | ||||||
|     :autoresize="autoResize" |  | ||||||
|     :style="{ width, height }" |  | ||||||
|   /> |  | ||||||
| </template> | </template> | ||||||
|  |  | ||||||
| <script lang="ts" setup> | <script lang="ts" setup> | ||||||
|  | import { registerMap } from 'echarts/core'; | ||||||
| import { nextTick, ref } from 'vue' | import { nextTick, ref } from 'vue' | ||||||
| import VCharts from 'vue-echarts' | import VCharts from 'vue-echarts' | ||||||
|  | import worldMap from './world.json' | ||||||
|  | import chinaMap from './china.json' | ||||||
| defineProps({ | defineProps({ | ||||||
|   option: { |   option: { | ||||||
|     type: Object, |     type: Object, | ||||||
| @@ -31,7 +28,13 @@ defineProps({ | |||||||
|     default: '100%' |     default: '100%' | ||||||
|   } |   } | ||||||
| }) | }) | ||||||
|  | registerMap('world', worldMap) | ||||||
|  | registerMap('china', chinaMap) | ||||||
| const renderChart = ref(false) | const renderChart = ref(false) | ||||||
|  | const chart = ref(null) | ||||||
|  | defineExpose({ | ||||||
|  |   chart | ||||||
|  | }) | ||||||
| // wait container expand | // wait container expand | ||||||
| nextTick(() => { | nextTick(() => { | ||||||
|   renderChart.value = true |   renderChart.value = true | ||||||
|   | |||||||
							
								
								
									
										111599
									
								
								src/components/Chart/world.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111599
									
								
								src/components/Chart/world.json
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										175
									
								
								src/views/dashboard/analysis/components/AccessTrendNew.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										175
									
								
								src/views/dashboard/analysis/components/AccessTrendNew.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,175 @@ | |||||||
|  | <template> | ||||||
|  |   <a-spin :loading="loading" style="width: 100%"> | ||||||
|  |     <a-card class="general-card" title="访问趋势"> | ||||||
|  |       <template #extra> | ||||||
|  |         <a-radio-group v-model:model-value="dateRange" type="button" size="small" @change="onChange as any"> | ||||||
|  |           <a-radio value="world">世界</a-radio> | ||||||
|  |           <a-radio value="china">中国</a-radio> | ||||||
|  |         </a-radio-group> | ||||||
|  |       </template> | ||||||
|  |       <div class="content"> | ||||||
|  |         <div class="mapChart"> | ||||||
|  |           <Chart :option="chartOption" style="height: 600px" ref="chartRef" /> | ||||||
|  |         </div> | ||||||
|  |         <div class="dataShow"> | ||||||
|  |           <div class="dataItem" v-for="item in data" :key="item.name"> | ||||||
|  |             <div class="title"> | ||||||
|  |               <span>{{ item.name }}</span> | ||||||
|  |               <span>{{ item.value }}</span> | ||||||
|  |             </div> | ||||||
|  |             <a-progress color="#246EFF" size="medium" :percent="(item.value - 0) / 100" :show-text="false" /> | ||||||
|  |           </div> | ||||||
|  |         </div> | ||||||
|  |       </div> | ||||||
|  |  | ||||||
|  |     </a-card> | ||||||
|  |   </a-spin> | ||||||
|  | </template> | ||||||
|  |  | ||||||
|  | <script lang="ts" setup> | ||||||
|  | import { type EChartsOption, graphic } from 'echarts' | ||||||
|  | import { type DashboardAccessTrendResp, getDashboardAccessTrend as getData } from '@/apis' | ||||||
|  | import { useChart } from '@/hooks' | ||||||
|  |  | ||||||
|  | const chartRef = ref(null) | ||||||
|  | const xAxis = ref<string[]>([]) | ||||||
|  | const pvChartData = ref<number[]>([]) | ||||||
|  | const ipChartData = ref<number[]>([]) | ||||||
|  | const data = [ | ||||||
|  |   { name: "河北省", value: 9 }, | ||||||
|  |   { name: "山西省", value: 9 }, | ||||||
|  |   { name: "辽宁省", value: 9 }, | ||||||
|  |   { name: "吉林省", value: 9 }, | ||||||
|  |   { name: "黑龙江省", value: 9 }, | ||||||
|  |   { name: "江苏省", value: 9 }, | ||||||
|  |   { name: "浙江省", value: 2000 }, | ||||||
|  |   { name: "安徽省", value: 9 }, | ||||||
|  |   { name: "福建省", value: 9 }, | ||||||
|  |   { name: "江西省", value: 9 }, | ||||||
|  |   { name: "山东省", value: 9 }, | ||||||
|  |   { name: "河南省", value: 9 }, | ||||||
|  |   { name: "湖北省", value: 9 }, | ||||||
|  |   { name: "湖南省", value: 9 }, | ||||||
|  |   { name: "广东省", value: 9 }, | ||||||
|  |   { name: "海南省", value: 9 }, | ||||||
|  |   { name: "四川省", value: 9 }, | ||||||
|  |   { name: "贵州省", value: 9 }, | ||||||
|  |   { name: "云南省", value: 9 }, | ||||||
|  |   { name: "陕西省", value: 9 }, | ||||||
|  |   { name: "甘肃省", value: 9 }, | ||||||
|  |  | ||||||
|  | ]; | ||||||
|  | const { chartOption } = useChart((isDark: EChartsOption) => { | ||||||
|  |   return { | ||||||
|  |     visualMap: { | ||||||
|  |       left: 'left', | ||||||
|  |       min: 1, | ||||||
|  |       max: 20000, | ||||||
|  |       inRange: { | ||||||
|  |         color: [ | ||||||
|  |           '#81E2FF', | ||||||
|  |           '#246EFE', | ||||||
|  |         ] | ||||||
|  |       }, | ||||||
|  |       calculable: false | ||||||
|  |     }, | ||||||
|  |     tooltip: { | ||||||
|  |       trigger: 'item', | ||||||
|  |       formatter: '{b}<br/>访问量:{c}' | ||||||
|  |     }, | ||||||
|  |  | ||||||
|  |     series: [ | ||||||
|  |       { | ||||||
|  |         type: 'map', | ||||||
|  |         map: 'china', | ||||||
|  |         label: { | ||||||
|  |           show: false | ||||||
|  |         }, | ||||||
|  |         itemStyle: { | ||||||
|  |           color: '#F7F8FA' | ||||||
|  |         }, | ||||||
|  |         data: data | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |     ] | ||||||
|  |   }; | ||||||
|  | }) | ||||||
|  |  | ||||||
|  | const loading = ref(false) | ||||||
|  | const dateRange = ref('china') | ||||||
|  | // 查询图表数据 | ||||||
|  | const getChartData = async (days: number) => { | ||||||
|  |   try { | ||||||
|  |     loading.value = true | ||||||
|  |     xAxis.value = [] | ||||||
|  |     pvChartData.value = [] | ||||||
|  |     ipChartData.value = [] | ||||||
|  |     const { data: chartData } = await getData(days) | ||||||
|  |     chartData.forEach((item: DashboardAccessTrendResp) => { | ||||||
|  |       xAxis.value.push(item.date) | ||||||
|  |       pvChartData.value.push(item.pvCount) | ||||||
|  |       ipChartData.value.push(item.ipCount) | ||||||
|  |     }) | ||||||
|  |   } finally { | ||||||
|  |     loading.value = false | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | // 切换 | ||||||
|  | const onChange = (type: string) => { | ||||||
|  |   chartRef.value?.chart.setOption({ | ||||||
|  |     series: [{ | ||||||
|  |       map: type, | ||||||
|  |       label: { | ||||||
|  |         show: false | ||||||
|  |       }, | ||||||
|  |       itemStyle: { | ||||||
|  |         color: '#F7F8FA' | ||||||
|  |       }, | ||||||
|  |       data: data | ||||||
|  |     }] | ||||||
|  |   }) | ||||||
|  | } | ||||||
|  |  | ||||||
|  | onMounted(() => { | ||||||
|  |   getChartData(30) | ||||||
|  | }) | ||||||
|  | </script> | ||||||
|  | <style lang="scss" scoped> | ||||||
|  | .content { | ||||||
|  |   display: flex; | ||||||
|  |  | ||||||
|  |   .mapChart { | ||||||
|  |     flex: 3; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   .dataShow { | ||||||
|  |     height: 100%; | ||||||
|  |     max-height: 500px; | ||||||
|  |     flex: 1; | ||||||
|  |     padding: 16px 24px; | ||||||
|  |     border-radius: 5px; | ||||||
|  |     overflow: auto; | ||||||
|  |     background-color: #333333; | ||||||
|  |  | ||||||
|  |     .dataItem { | ||||||
|  |       padding-top: 10px; | ||||||
|  |  | ||||||
|  |       .title { | ||||||
|  |         display: flex; | ||||||
|  |         justify-content: space-between; | ||||||
|  |         align-items: center; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     .dataItem:first-child { | ||||||
|  |       padding-top: 0; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     &::-webkit-scrollbar { | ||||||
|  |       display: none; | ||||||
|  |       /* 隐藏滚动条 */ | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | </style> | ||||||
| @@ -7,7 +7,7 @@ | |||||||
|       <div> |       <div> | ||||||
|         <a-grid :cols="24" :col-gap="14" :row-gap="14"> |         <a-grid :cols="24" :col-gap="14" :row-gap="14"> | ||||||
|           <a-grid-item :span="{ xs: 24, sm: 24, md: 24, lg: 24, xl: 18, xxl: 18 }"> |           <a-grid-item :span="{ xs: 24, sm: 24, md: 24, lg: 24, xl: 18, xxl: 18 }"> | ||||||
|             <AccessTrend /> |             <AccessTrendNew /> | ||||||
|           </a-grid-item> |           </a-grid-item> | ||||||
|           <a-grid-item :span="{ xs: 24, sm: 24, md: 24, lg: 24, xl: 6, xxl: 6 }"> |           <a-grid-item :span="{ xs: 24, sm: 24, md: 24, lg: 24, xl: 6, xxl: 6 }"> | ||||||
|             <Os style="margin-bottom: 16px" /> |             <Os style="margin-bottom: 16px" /> | ||||||
| @@ -31,7 +31,7 @@ | |||||||
|  |  | ||||||
| <script setup lang="ts"> | <script setup lang="ts"> | ||||||
| import DataOverview from './components/DataOverview/index.vue' | import DataOverview from './components/DataOverview/index.vue' | ||||||
| import AccessTrend from './components/AccessTrend.vue' | import AccessTrendNew from './components/AccessTrendNew.vue' | ||||||
| import Os from './components/Os.vue' | import Os from './components/Os.vue' | ||||||
| import Browser from './components/Browser.vue' | import Browser from './components/Browser.vue' | ||||||
| import Module from './components/Module.vue' | import Module from './components/Module.vue' | ||||||
| @@ -40,5 +40,4 @@ import AccessTimeslot from './components/AccessTimeslot.vue' | |||||||
| defineOptions({ name: 'Analysis' }) | defineOptions({ name: 'Analysis' }) | ||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped></style> | ||||||
| </style> |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 秋帆
					秋帆