feat(数据大屏): 大屏的tab组件支持图表组合后拖进去

This commit is contained in:
wangjiahao
2024-12-17 18:59:27 +08:00
committed by 王嘉豪
parent cccea9878c
commit 1fde5fabe8
7 changed files with 195 additions and 99 deletions

View File

@@ -1,4 +1,4 @@
import { cloneDeep } from 'lodash-es'
import { cloneDeep, forEach } from 'lodash-es'
import componentList, {
ACTION_SELECTION,
BASE_CAROUSEL,
@@ -633,6 +633,53 @@ export function isMainCanvas(canvasId) {
return canvasId === 'canvas-main'
}
// 目前仅允许group中还有一层Tab 或者 Tab中含有一层group
export function itemCanvasPathCheck(item, checkType) {
console.log('===test==' + item.component + '==' + checkType)
if (checkType === 'canvas-main') {
return isMainCanvas(item.canvasId)
}
const pathMap = {}
componentData.value.forEach(componentItem => {
canvasIdMapCheck(componentItem, null, pathMap)
})
// 父组件是Tab且否在group中
if (checkType === 'pTabGroup') {
return Boolean(
pathMap[item.id] &&
pathMap[item.id].component === 'DeTabs' &&
pathMap[pathMap[item.id].id] &&
pathMap[pathMap[item.id].id].component === 'Group'
)
}
// 父组件是group且否在Tab中
if (checkType === 'pGroupTab') {
return Boolean(
pathMap[item.id] &&
pathMap[item.id].component === 'Group' &&
pathMap[pathMap[item.id].id] &&
pathMap[pathMap[item.id].id].component === 'DeTabs'
)
}
return false
}
export function canvasIdMapCheck(item, pItem, pathMap) {
pathMap[item.id] = pItem
if (item.component === 'DeTabs') {
item.propValue.forEach(tabItem => {
tabItem.componentData.forEach(tabComponent => {
canvasIdMapCheck(tabComponent, item, pathMap)
})
})
} else if (item.component === 'Group') {
item.propValue.forEach(groupItem => {
canvasIdMapCheck(groupItem, item, pathMap)
})
}
}
export function isSameCanvas(item, canvasId) {
return item.canvasId === canvasId
}