153 lines
4.0 KiB
Vue
Raw Normal View History

2022-09-22 17:09:26 +08:00
<template>
<v-chart ref="vChartRef" :theme="themeColor" :option="option.value" :manual-update="isPreview()" autoresize>
</v-chart>
</template>
<script setup lang="ts">
import { PropType, reactive, watch, ref, nextTick } from 'vue'
2022-09-25 17:48:51 +08:00
import config, { includes } from './config'
2022-09-22 17:09:26 +08:00
import VChart from 'vue-echarts'
2022-09-25 17:48:51 +08:00
import { use, registerMap } from 'echarts/core'
2022-09-22 17:09:26 +08:00
import { EffectScatterChart, MapChart } from 'echarts/charts'
import { CanvasRenderer } from 'echarts/renderers'
import { useChartDataFetch } from '@/hooks'
import { mergeTheme } from '@/packages/public/chart'
import { useChartEditStore } from '@/store/modules/chartEditStore/chartEditStore'
import { isPreview } from '@/utils'
import mapJsonWithoutHainanIsLands from './mapWithoutHainanIsLands.json'
import { DatasetComponent, GridComponent, TooltipComponent, GeoComponent, VisualMapComponent } from 'echarts/components'
2022-09-25 17:48:51 +08:00
2022-09-22 17:09:26 +08:00
const props = defineProps({
themeSetting: {
type: Object,
required: true
},
themeColor: {
type: Object,
required: true
},
chartConfig: {
type: Object as PropType<config>,
required: true
}
})
use([
MapChart,
DatasetComponent,
CanvasRenderer,
GridComponent,
TooltipComponent,
GeoComponent,
EffectScatterChart,
VisualMapComponent
])
const option = reactive({
value: mergeTheme(props.chartConfig.option, props.themeSetting, includes)
2022-09-22 17:09:26 +08:00
})
const vChartRef = ref<typeof VChart>()
2022-09-22 17:09:26 +08:00
//动态获取json注册地图
2022-09-22 17:09:26 +08:00
const getGeojson = (regionId: string) => {
return new Promise<boolean>(resolve => {
2022-09-22 17:09:26 +08:00
import(`./mapGeojson/${regionId}.json`).then(data => {
registerMap(regionId, { geoJSON: data.default as any, specialAreas: {} })
resolve(true)
})
})
}
2022-09-25 17:48:51 +08:00
//异步时先注册空的 保证初始化不报错
2022-09-22 17:09:26 +08:00
registerMap(props.chartConfig.option.mapRegion.adcode, { geoJSON: {} as any, specialAreas: {} })
2022-09-25 17:48:51 +08:00
// 进行更换初始化地图 如果为china 单独处理
const registerMapInitAsync = async () => {
await nextTick()
2022-10-12 21:57:30 +08:00
if (props.chartConfig.option.mapRegion.adcode != 'china') {
await getGeojson(props.chartConfig.option.mapRegion.adcode)
2022-10-12 21:57:30 +08:00
} else {
await hainanLandsHandle(props.chartConfig.option.mapRegion.showHainanIsLands)
}
vEchartsSetOption()
2022-09-22 17:09:26 +08:00
}
registerMapInitAsync()
2022-09-25 17:48:51 +08:00
// 手动触发渲染
const vEchartsSetOption = () => {
2022-09-22 17:09:26 +08:00
option.value = props.chartConfig.option
vChartRef.value?.setOption(props.chartConfig.option)
2022-09-22 17:09:26 +08:00
}
2022-09-25 17:48:51 +08:00
// 更新数据处理
const dataSetHandle = async (dataset: any) => {
2022-09-22 17:09:26 +08:00
props.chartConfig.option.series.forEach((item: any) => {
if (item.type === 'effectScatter' && dataset.point) item.data = dataset.point
2022-09-25 17:48:51 +08:00
else if (item.type === 'map' && dataset.map) item.data = dataset.map
2022-09-22 17:09:26 +08:00
})
2022-09-25 17:48:51 +08:00
if (dataset.pieces) props.chartConfig.option.visualMap.pieces = dataset.pieces
2022-09-25 17:48:51 +08:00
isPreview() && vEchartsSetOption()
2022-09-22 17:09:26 +08:00
}
// 处理海南群岛
2022-10-12 21:57:30 +08:00
const hainanLandsHandle = async (newData: boolean) => {
if (newData) {
2022-10-12 21:57:30 +08:00
await getGeojson('china')
} else {
registerMap('china', { geoJSON: mapJsonWithoutHainanIsLands as any, specialAreas: {} })
}
}
2022-09-25 17:48:51 +08:00
//监听 dataset 数据发生变化
2022-09-22 17:09:26 +08:00
watch(
() => props.chartConfig.option.dataset,
newData => {
dataSetHandle(newData)
},
{
immediate: true,
deep: false
}
)
2022-09-25 17:48:51 +08:00
2022-09-22 17:09:26 +08:00
//监听是否显示南海群岛
watch(
() => props.chartConfig.option.mapRegion.showHainanIsLands,
2022-09-25 17:48:51 +08:00
async newData => {
2022-10-12 21:57:30 +08:00
try {
await hainanLandsHandle(newData)
vEchartsSetOption()
} catch (error) {
console.log(error)
}
2022-09-22 17:09:26 +08:00
},
{
deep: false
2022-09-22 17:09:26 +08:00
}
)
2022-09-25 17:48:51 +08:00
//监听地图展示区域发生变化
2022-09-22 17:09:26 +08:00
watch(
() => props.chartConfig.option.mapRegion.adcode,
2022-09-25 17:48:51 +08:00
async newData => {
2022-10-12 21:57:30 +08:00
try {
await getGeojson(newData)
props.chartConfig.option.geo.map = newData
props.chartConfig.option.series.forEach((item: any) => {
if (item.type === 'map') item.map = newData
})
vEchartsSetOption()
} catch (error) {
console.log(error)
}
2022-09-22 17:09:26 +08:00
},
{
deep: false
2022-09-22 17:09:26 +08:00
}
)
// 预览
useChartDataFetch(props.chartConfig, useChartEditStore, (newData: any) => {
dataSetHandle(newData)
})
</script>