| 123456789101112131415161718192021222324252627282930313233343536 |
- 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
- }
- }
|