mirror of
https://gitee.com/dromara/go-view.git
synced 2025-04-22 21:46:23 +08:00
37 lines
1.1 KiB
TypeScript
37 lines
1.1 KiB
TypeScript
import { ref } from 'vue'
|
|
import { ChartEditStorageType } from '../index.d'
|
|
import { CreateComponentType, CreateComponentGroupType } from '@/packages/index.d'
|
|
import { fetchChartComponent } from '@/packages/index'
|
|
|
|
export const useComInstall = (localStorageInfo: ChartEditStorageType) => {
|
|
const show = ref(false)
|
|
|
|
// 注册组件(一开始无法获取window['$vue'])
|
|
const intervalTiming = setInterval(() => {
|
|
if (window['$vue'].component) {
|
|
clearInterval(intervalTiming)
|
|
|
|
const intComponent = (target: CreateComponentType) => {
|
|
if (!window['$vue'].component(target.chartConfig.chartKey)) {
|
|
window['$vue'].component(target.chartConfig.chartKey, fetchChartComponent(target.chartConfig))
|
|
}
|
|
}
|
|
|
|
localStorageInfo.componentList.forEach(async (e: CreateComponentType | CreateComponentGroupType) => {
|
|
if (e.isGroup) {
|
|
(e as CreateComponentGroupType).groupList.forEach(groupItem => {
|
|
intComponent(groupItem)
|
|
})
|
|
} else {
|
|
intComponent(e as CreateComponentType)
|
|
}
|
|
})
|
|
show.value = true
|
|
}
|
|
}, 200)
|
|
|
|
return {
|
|
show
|
|
}
|
|
}
|