fix: 修复Tab页中的不同画布之间的过滤组件可能相互影响问题
This commit is contained in:
parent
110c6857c8
commit
1409d06b29
@ -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
|
||||
|
||||
Loading…
Reference in New Issue
Block a user