From eb7d8402b8c23bbdb06f3199a114592f0a5d94e8 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期三, 11 五月 2022 13:23:25 +0800
Subject: [PATCH] 2022-05-11
---
src/utils/utils-custom.js | 185 ++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 162 insertions(+), 23 deletions(-)
diff --git a/src/utils/utils-custom.js b/src/utils/utils-custom.js
index ee48e7c..0d109b5 100644
--- a/src/utils/utils-custom.js
+++ b/src/utils/utils-custom.js
@@ -95,9 +95,16 @@
children: null
}
} else if (item.switchable) { // 鏁版嵁鍙垏鎹�
+ let disabled = false
+ if (item.type === 'card') {
+ disabled = item.wrap.cardType === ''
+ } else if (item.type === 'table') {
+ disabled = item.wrap.tableType === ''
+ }
return {
value: item.uuid,
- label: item.name
+ label: item.name,
+ disabled: disabled
}
} else if (item.type === 'form') { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
return {
@@ -274,8 +281,8 @@
uuids.push(act.uuid)
})
- if (card.type === 'card' || item.type === 'carousel' || (card.type === 'table' && card.subtype === 'tablecard')) {
- card.subcards.forEach(_card => {
+ if (['card', 'carousel', 'timeline'].includes(item.type) || (item.type === 'table' && item.subtype === 'tablecard')) {
+ item.subcards.forEach(_card => {
_card.elements && _card.elements.forEach(cell => {
if (cell.eleType !== 'button') return
if (appType === 'pc' && cell.OpenType !== 'popview') return
@@ -289,8 +296,8 @@
uuids.push(cell.uuid)
})
})
- } else if (card.type === 'table' && card.subtype === 'normaltable') {
- card.cols && card.cols.forEach(col => {
+ } else if (item.type === 'table' && (item.subtype === 'normaltable' || item.subtype === 'editable')) {
+ item.cols && item.cols.forEach(col => {
if (col.type !== 'action') return
col.elements && col.elements.forEach(cell => {
if (appType === 'pc' && cell.OpenType !== 'popview') return
@@ -298,8 +305,8 @@
uuids.push(cell.uuid)
})
})
- } else if (card.type === 'balcony') {
- card.elements && card.elements.forEach(cell => {
+ } else if (item.type === 'balcony') {
+ item.elements && item.elements.forEach(cell => {
if (appType === 'pc' && cell.OpenType !== 'popview') return
uuids.push(cell.uuid)
@@ -332,17 +339,19 @@
* @description 閲嶇疆鑿滃崟閰嶇疆锛岄〉闈㈡暣浣撳鍒�
* @return {String} components 閰嶇疆淇℃伅
*/
- static resetConfig = (components) => {
+ static resetConfig = (components, uuids = {}, clear = false) => {
return components.map(item => {
if (item.type === 'navbar') {
return item
}
- item.uuid = this.getuuid()
+ uuids[item.uuid] = this.getuuid()
+ item.uuid = uuids[item.uuid]
if (item.type === 'tabs') {
item.subtabs.forEach(tab => {
- tab.uuid = this.getuuid()
+ uuids[tab.uuid] = this.getuuid()
+ tab.uuid = uuids[tab.uuid]
tab.parentId = item.uuid
tab.components = tab.components.map(cell => {
@@ -350,31 +359,59 @@
cell.parentId = item.uuid
return cell
})
- tab.components = this.resetConfig(tab.components)
+ tab.components = this.resetConfig(tab.components, uuids, clear)
})
} else if (item.type === 'group') {
item.components = item.components.map(cell => {
cell.parentId = item.uuid
return cell
})
- item.components = this.resetConfig(item.components)
+ item.components = this.resetConfig(item.components, uuids, clear)
} else if (item.type === 'menubar') {
item.subMenus = item.subMenus.map(cell => {
cell.uuid = this.getuuid()
+ if (clear && cell.setting.type === 'linkmenu') {
+ cell.setting.type = 'menu'
+ cell.setting.linkMenuId = ''
+ }
return cell
})
- } else if (item.type === 'card' || item.type === 'carousel' || (item.type === 'table' && item.subtype === 'tablecard')) {
+ } else if (['card', 'carousel', 'timeline'].includes(item.type) || (item.type === 'table' && item.subtype === 'tablecard')) {
item.subcards.forEach(card => {
card.uuid = this.getuuid()
+
+ if (clear) {
+ if (card.setting.click === 'menu') {
+ card.setting.click = ''
+ card.setting.menu = ''
+ } else if (card.setting.click === 'menus') {
+ card.setting.click = ''
+ card.setting.menuType = ''
+ delete card.menus
+ }
+ }
+
if (card.elements) {
card.elements = card.elements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (clear && cell.eleType === 'button' && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+
return cell
})
}
if (card.backElements) {
card.backElements = card.backElements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (clear && cell.eleType === 'button' && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+
return cell
})
}
@@ -383,10 +420,16 @@
if (item.elements) {
item.elements = item.elements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (clear && cell.eleType === 'button' && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+
return cell
})
}
- } else if (item.type === 'table' && item.subtype === 'normaltable' && item.cols) {
+ } else if (item.type === 'table' && (item.subtype === 'normaltable' || item.subtype === 'editable') && item.cols) {
let loopCol = (col) => {
col.subcols = col.subcols.map(c => {
c.uuid = this.getuuid()
@@ -396,11 +439,18 @@
} else if (c.type === 'custom' && c.elements) {
c.elements = c.elements.map(cell => {
cell.uuid = this.getuuid()
+
return cell
})
} else if (c.type === 'action' && c.elements) {
c.elements = c.elements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+
return cell
})
}
@@ -409,9 +459,12 @@
return col
}
-
+ let _uuids = {}
item.cols = item.cols.map(col => {
- col.uuid = this.getuuid()
+ let uuid = this.getuuid()
+
+ _uuids[col.uuid] = uuid
+ col.uuid = uuid
if (col.type === 'colspan' && col.subcols) {
col = loopCol(col)
@@ -428,6 +481,15 @@
}
return col
})
+
+ if (item.subtype === 'editable') {
+ item.cols = item.cols.map(col => {
+ if (col.editable === 'true' && col.enter && _uuids[col.enter]) {
+ col.enter = _uuids[col.enter]
+ }
+ return col
+ })
+ }
}
if (item.btnlog) {
@@ -441,6 +503,11 @@
oriUids[cell.uuid] = _uuid
cell.uuid = _uuid
+
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
return cell
})
@@ -462,6 +529,9 @@
return cell
})
}
+ if (clear && item.wrap.menus) {
+ item.wrap.menus = []
+ }
} else if (item.search) {
item.search = item.search.map(cell => {
cell.uuid = this.getuuid()
@@ -475,12 +545,54 @@
})
}
+ if (item.setting && item.setting.supModule && item.setting.supModule[0] !== 'empty') {
+ let em = false
+ item.setting.supModule = item.setting.supModule.map(c => {
+ if (!uuids[c]) {
+ em = true
+ }
+ return uuids[c] || ''
+ })
+ if (em) {
+ item.setting.supModule = ''
+ }
+ }
+
if (item.wrap && item.wrap.doubleClick) {
item.wrap.doubleClick = oriUids[item.wrap.doubleClick] || ''
}
return item
})
+ }
+
+ /**
+ * @description 閲嶇疆鑿滃崟閰嶇疆锛岄〉闈㈡暣浣撳鍒�
+ * @return {String} components 閰嶇疆淇℃伅
+ */
+ static getFloor = (id) => {
+ let floor = 1
+ let finish = false
+
+ let reCheck = (components, f) => {
+ components.forEach(item => {
+ if (finish) return
+ if (item.type === 'tabs') {
+ if (item.uuid === id) {
+ floor = f
+ finish = true
+ } else {
+ item.subtabs.forEach(tab => {
+ reCheck(tab.components, f + 1)
+ })
+ }
+ }
+ })
+ }
+
+ reCheck(window.GLOB.customMenu.components, 1)
+
+ return floor
}
/**
@@ -501,12 +613,17 @@
* @description 閲嶇疆缁勪欢閰嶇疆
* @return {String} item 缁勪欢淇℃伅
*/
- static resetComponentConfig = (item, copyBtns) => {
+ static resetComponentConfig = (item, copyBtns, uuids = {}) => {
if (item.type === 'navbar') {
return item
}
- item.uuid = this.getuuid()
+ let _uuid = this.getuuid()
+
+ uuids[item.uuid] = _uuid
+
+ item.uuid = _uuid
+
if (item.dataName) {
item.dataName = this.getdataName()
}
@@ -529,7 +646,7 @@
cell.uuid = this.getuuid()
return cell
})
- } else if (item.type === 'card' || item.type === 'carousel' || (item.type === 'table' && item.subtype === 'tablecard')) {
+ } else if (['card', 'carousel', 'timeline'].includes(item.type) || (item.type === 'table' && item.subtype === 'tablecard')) {
item.subcards.forEach(card => {
card.uuid = this.getuuid()
if (card.elements) {
@@ -582,7 +699,7 @@
return cell
})
}
- } else if (item.type === 'table' && item.subtype === 'normaltable' && item.cols) {
+ } else if (item.type === 'table' && (item.subtype === 'normaltable' || item.subtype === 'editable') && item.cols) {
let loopCol = (col) => {
col.subcols = col.subcols.map(c => {
c.uuid = this.getuuid()
@@ -601,8 +718,12 @@
return col
}
+ let _uuids = {}
item.cols = item.cols.map(col => {
- col.uuid = this.getuuid()
+ let uuid = this.getuuid()
+
+ _uuids[col.uuid] = uuid
+ col.uuid = uuid
if (col.type === 'colspan' && col.subcols) {
col = loopCol(col)
@@ -629,6 +750,15 @@
}
return col
})
+
+ if (item.subtype === 'editable') {
+ item.cols = item.cols.map(col => {
+ if (col.editable === 'true' && col.enter && _uuids[col.enter]) {
+ col.enter = _uuids[col.enter]
+ }
+ return col
+ })
+ }
} else if (item.type === 'form') {
item.subcards = item.subcards.map(cell => {
cell.uuid = this.getuuid()
@@ -700,8 +830,17 @@
})
}
- if (item.setting && item.setting.supModule) {
- item.setting.supModule = ''
+ if (item.setting && item.setting.supModule && item.setting.supModule[0] !== 'empty') {
+ let em = false
+ item.setting.supModule = item.setting.supModule.map(c => {
+ if (!uuids[c]) {
+ em = true
+ }
+ return uuids[c] || ''
+ })
+ if (em) {
+ item.setting.supModule = ''
+ }
}
if (item.wrap && item.wrap.doubleClick) {
--
Gitblit v1.8.0