fix: 修复Tab页中的不同画布之间的过滤组件可能相互影响问题

This commit is contained in:
wangjiahao 2023-11-22 14:26:14 +08:00
parent 110c6857c8
commit 1409d06b29

View File

@ -70,6 +70,23 @@ export const buildViewKeyMap = panelItems => {
return result
}
export const buildCanvasIdMap = panelItems => {
const result = {}
panelItems.forEach(element => {
if (element.type === 'view') {
result[element.propValue.viewId] = element.canvasId
}
if (element.type === 'de-tabs') {
element.options.tabList && element.options.tabList.forEach(tab => {
if (tab.content && tab.content.propValue && tab.content.propValue.viewId) {
result[tab.content.propValue.viewId] = element.id + '-' + tab.name
}
})
}
})
return result
}
const cacheCondition = (cb, obj) => {
obj.cb = cb
}
@ -78,6 +95,7 @@ export const buildViewKeyFilters = (panelItems, result) => {
return result
}
const buildItems = panelItems[0].canvasId === 'canvas-main' ? panelItems : store.state.componentData
const canvasIdMap = buildCanvasIdMap(buildItems)
buildItems.forEach((element, index) => {
if (element.type !== 'custom') {
return true
@ -91,6 +109,8 @@ export const buildViewKeyFilters = (panelItems, result) => {
const vValid = valueValid(condition)
const filterComponentId = condition.componentId
Object.keys(result).forEach(viewId => {
// 进行过滤时 如果过滤组件在主画布 则条件适用于所有画布视图 否则需要过滤组件和视图在相同画布
if (element.canvasId === 'canvas-main' || element.canvasId === canvasIdMap[viewId]) {
const vidMatch = viewIdMatch(condition.viewIds, viewId)
if (vidMatch && selectFirst) {
const obj = {}
@ -114,6 +134,7 @@ export const buildViewKeyFilters = (panelItems, result) => {
}
vidMatch && vValid && viewFilters.push(condition)
}
}
})
})
return result