From 7cfd25aebe5869244e40dbbcd6384f115f35e66e Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期三, 14 六月 2023 09:37:21 +0800
Subject: [PATCH] Merge branch 'master' into positec
---
src/utils/utils-custom.js | 740 ++++++++++++++++++++++++++++++++++++++++++--------------
1 files changed, 551 insertions(+), 189 deletions(-)
diff --git a/src/utils/utils-custom.js b/src/utils/utils-custom.js
index 64fb0a1..be4f888 100644
--- a/src/utils/utils-custom.js
+++ b/src/utils/utils-custom.js
@@ -1,3 +1,5 @@
+import md5 from 'md5'
+
export default class MenuUtils {
/**
* @description 鑾峰彇涓嬬骇妯″潡
@@ -17,6 +19,8 @@
} else if (item.type === 'tabs') {
if (item.subtype === 'tabletabs') {
item.subtabs.forEach(tab => {
+ if (tab.components[0].uuid === selfId) return
+
modules.push({
value: tab.components[0].uuid,
label: tab.label,
@@ -171,7 +175,7 @@
* @description 鑾峰彇涓婄骇妯″潡
* @return {String} selfId 褰撳墠缁勪欢id
*/
- static getSupModules (components, selfId) {
+ static getSupModules (components, selfId, interfaces) {
let modules = []
components.forEach(item => {
if (item.uuid === selfId) {
@@ -264,7 +268,41 @@
}
})
+ if (interfaces && interfaces.length > 0) {
+ interfaces.forEach(item => {
+ modules.push({
+ value: item.uuid,
+ label: item.name
+ })
+ })
+ }
+
return modules
+ }
+
+ /**
+ * @description 鑾峰彇涓婄骇妯″潡
+ * @return {String} selfId 褰撳墠缁勪欢id
+ */
+ static checkSupModules (modules, supId) {
+ let has = false
+
+ let check = (list) => {
+ list.forEach(m => {
+ if (has) return
+ if (supId === m.value) {
+ has = true
+ return
+ }
+ if (m.children) {
+ check(m.children)
+ }
+ })
+ }
+
+ check(modules)
+
+ return has
}
/**
@@ -360,7 +398,7 @@
* @description 閲嶇疆鑿滃崟閰嶇疆锛岄〉闈㈡暣浣撳鍒�
* @return {String} components 閰嶇疆淇℃伅
*/
- static resetConfig = (components, uuids = {}, clear = false) => {
+ static resetConfig = (components, commonId, clear = false) => {
return components.map(item => {
if (item.type === 'navbar') {
return item
@@ -370,18 +408,16 @@
item.type = 'card'
}
- uuids[item.uuid] = this.getuuid()
- item.uuid = uuids[item.uuid]
+ item.uuid = md5(commonId + item.uuid)
if (item.type === 'tabs') {
item.subtabs.forEach(tab => {
- uuids[tab.uuid] = this.getuuid()
- tab.uuid = uuids[tab.uuid]
+ tab.uuid = md5(commonId + tab.uuid)
- tab.components = this.resetConfig(tab.components, uuids, clear)
+ tab.components = this.resetConfig(tab.components, commonId, clear)
})
} else if (item.type === 'group') {
- item.components = this.resetConfig(item.components, uuids, clear)
+ item.components = this.resetConfig(item.components, commonId, clear)
} else if (item.type === 'menubar') {
item.subMenus = item.subMenus.map(cell => {
cell.uuid = this.getuuid()
@@ -392,8 +428,20 @@
return cell
})
} else if (['card', 'carousel', 'timeline'].includes(item.type)) {
- if (item.wrap.datatype === 'public' && uuids[item.wrap.publicId]) {
- item.wrap.publicId = uuids[item.wrap.publicId]
+ if (item.wrap.datatype === 'public' && item.wrap.publicId) {
+ item.wrap.publicId = md5(commonId + item.wrap.publicId)
+ }
+ if (item.wrap.autoExec) {
+ item.wrap.autoExec = md5(commonId + item.wrap.autoExec)
+ }
+
+ if (item.supNodes && item.supNodes.length > 0) {
+ item.supNodes = item.supNodes.map(cell => {
+ cell.nodes = cell.nodes.map(n => md5(commonId + n))
+ cell.componentId = cell.nodes[cell.nodes.length - 1]
+
+ return cell
+ })
}
item.subcards.forEach(card => {
@@ -410,13 +458,21 @@
}
}
+ if (card.setting.click === 'button' && card.setting.linkbtn) {
+ card.setting.linkbtn = md5(commonId + card.setting.linkbtn)
+ }
+
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 = ''
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ } else {
+ cell.uuid = this.getuuid()
}
return cell
@@ -424,11 +480,15 @@
}
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 = ''
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ } else {
+ cell.uuid = this.getuuid()
}
return cell
@@ -436,82 +496,67 @@
}
})
} else if (item.type === 'balcony') {
- if (item.wrap.datatype === 'public' && uuids[item.wrap.publicId]) {
- item.wrap.publicId = uuids[item.wrap.publicId]
+ if (item.wrap.datatype === 'public' && item.wrap.publicId) {
+ item.wrap.publicId = md5(commonId + item.wrap.publicId)
+ }
+ if (item.wrap.linkbtn) {
+ item.wrap.linkbtn = md5(commonId + item.wrap.linkbtn)
}
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 = ''
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ } else {
+ cell.uuid = this.getuuid()
}
return cell
})
}
} else if (item.type === 'table' && item.cols) {
- let loopCol = (col) => {
- col.subcols = col.subcols.map(c => {
- c.uuid = this.getuuid()
+ let loopCol = (cols) => {
+ return cols.map(col => {
+ if (col.type === 'action') {
+ col.type = 'custom'
+ }
+
+ col.uuid = md5(commonId + col.uuid)
- if (c.type === 'colspan' && c.subcols) {
- c = loopCol(c)
- } else if (c.type === 'custom' && c.elements) {
- c.elements = c.elements.map(cell => {
- cell.uuid = this.getuuid()
+ if (col.type === 'colspan' && col.subcols) {
+ col.subcols = loopCol(col.subcols)
+ } else if (col.type === 'custom' && col.elements) {
+ col.elements = col.elements.map(cell => {
+ cell.uuid = md5(commonId + cell.uuid)
- return cell
- })
- } else if (c.type === 'action' && c.elements) {
- c.elements = c.elements.map(cell => {
- cell.uuid = this.getuuid()
+ if (cell.eleType === 'button') {
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
- if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
- cell.pageTemplate = ''
- cell.linkmenu = ''
+ this.resetBtn(cell, commonId)
}
return cell
})
+ } else if (col.editable === 'true' && col.enter && col.enter !== '$next' && col.enter !== '$sub') {
+ if (/\$next_/.test(col.enter)) {
+ col.enter = '$next_' + md5(commonId + col.enter.split('_')[1])
+ } else {
+ col.enter = md5(commonId + col.enter)
+ }
}
- return c
- })
-
- return col
- }
- let _uuids = {}
- item.cols = item.cols.map(col => {
- let uuid = this.getuuid()
- _uuids[col.uuid] = uuid
- col.uuid = uuid
-
- if (col.type === 'colspan' && col.subcols) {
- col = loopCol(col)
- } else if (col.type === 'custom' && col.elements) {
- col.elements = col.elements.map(cell => {
- cell.uuid = this.getuuid()
- return cell
- })
- } else if (col.type === 'action' && col.elements) {
- col.elements = col.elements.map(cell => {
- cell.uuid = this.getuuid()
- return cell
- })
- }
- 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
})
}
+
+ item.cols = loopCol(item.cols)
} else if (item.type === 'form') {
item.subcards = item.subcards.map(cell => {
cell.uuid = this.getuuid()
@@ -521,6 +566,11 @@
return m
})
+
+ if (cell.subButton) {
+ this.resetBtn(cell.subButton, commonId)
+ }
+
return cell
})
}
@@ -529,18 +579,16 @@
item.btnlog = null
}
- let oriUids = {}
if (item.action) {
item.action = item.action.map(cell => {
- let _uuid = this.getuuid()
-
- oriUids[cell.uuid] = _uuid
- cell.uuid = _uuid
+ cell.uuid = md5(commonId + cell.uuid)
if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
cell.pageTemplate = ''
cell.linkmenu = ''
}
+
+ this.resetBtn(cell, commonId)
return cell
})
@@ -579,24 +627,48 @@
}
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] || ''
+ return md5(commonId + c)
})
- if (em) {
- item.setting.supModule = ''
+ if (item.wrap && item.wrap.supModule) {
+ item.wrap.supModule = item.setting.supModule
}
}
if (item.wrap && item.wrap.doubleClick) {
- item.wrap.doubleClick = oriUids[item.wrap.doubleClick] || ''
+ item.wrap.doubleClick = md5(commonId + item.wrap.doubleClick)
}
return item
})
+ }
+
+ /**
+ * @description 鎸夐挳閲嶇疆
+ */
+ static resetBtn (btn, commonId) {
+ if (btn.OpenType === 'pop' || (btn.OpenType === 'funcbutton' && btn.execMode === 'pop')) {
+ if (btn.modal && btn.modal.fields.length > 0) {
+ btn.modal.fields = btn.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
+ if (btn.switchTab && btn.switchTab.length > 0) {
+ btn.switchTab = btn.switchTab.map(m => md5(commonId + m))
+ }
+ if (btn.anchors && btn.anchors.length > 0) {
+ btn.anchors = btn.anchors.map(m => md5(commonId + m))
+ }
+ if (btn.syncComponent && btn.syncComponent[0] === 'multiComponent' && btn.syncComponents) {
+ btn.syncComponents = btn.syncComponents.map(m => {
+ m.syncComId = m.syncComId.map(n => md5(commonId + n))
+ return m
+ })
+ } else if (btn.syncComponent && btn.syncComponent.length > 0) {
+ btn.syncComponent = btn.syncComponent.map(m => md5(commonId + m))
+ }
}
/**
@@ -615,7 +687,7 @@
* @description 閲嶇疆缁勪欢閰嶇疆
* @return {String} item 缁勪欢淇℃伅
*/
- static resetComponentConfig = (item, uuids = {}) => {
+ static resetComponentConfig = (item, appType) => {
if (item.type === 'navbar') {
return item
}
@@ -624,11 +696,8 @@
item.type = 'card'
}
- let _uuid = this.getuuid()
-
- uuids[item.uuid] = _uuid
-
- item.uuid = _uuid
+ item.uuid = this.getuuid()
+ let commonId = this.getuuid()
// 閲嶇疆缁勪欢鍚嶇О
let sign = this.getSignName()
@@ -649,14 +718,46 @@
return cell
})
} else if (['card', 'carousel', 'timeline'].includes(item.type)) {
+ if (item.wrap.autoExec) {
+ item.wrap.autoExec = md5(commonId + item.wrap.autoExec)
+ }
+
+ if (appType !== 'mob') {
+ if (item.wrap.pagestyle === 'slide') {
+ item.wrap.pagestyle = 'page'
+ }
+ } else {
+ if (item.wrap.pagestyle === 'switch') {
+ item.wrap.pagestyle = 'page'
+ }
+ }
+
item.subcards.forEach(card => {
card.uuid = this.getuuid()
+
+ if (card.setting.click === 'button' && card.setting.linkbtn) {
+ card.setting.linkbtn = md5(commonId + card.setting.linkbtn)
+ }
+
if (card.elements) {
if (sessionStorage.getItem('editMenuType') === 'popview') {
card.elements = card.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
card.elements = card.elements.map(cell => {
- cell.uuid = this.getuuid()
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (cell.modal && cell.modal.fields.length > 0) {
+ cell.modal.fields = cell.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
+ } else {
+ cell.uuid = this.getuuid()
+ }
return cell
})
}
@@ -665,7 +766,19 @@
card.elements = card.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
card.backElements = card.backElements.map(cell => {
- cell.uuid = this.getuuid()
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (cell.modal && cell.modal.fields.length > 0) {
+ cell.modal.fields = cell.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
+ } else {
+ cell.uuid = this.getuuid()
+ }
return cell
})
}
@@ -675,64 +788,68 @@
if (sessionStorage.getItem('editMenuType') === 'popview') {
item.elements = item.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
+ if (item.wrap.linkbtn) {
+ item.wrap.linkbtn = md5(commonId + item.wrap.linkbtn)
+ }
item.elements = item.elements.map(cell => {
- cell.uuid = this.getuuid()
+ if (cell.eleType === 'button') {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (cell.modal && cell.modal.fields.length > 0) {
+ cell.modal.fields = cell.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
+ } else {
+ cell.uuid = this.getuuid()
+ }
return cell
})
}
} else if (item.type === 'table' && item.cols) {
- let loopCol = (col) => {
- col.subcols = col.subcols.map(c => {
- c.uuid = this.getuuid()
+ let loopCol = (cols) => {
+ return cols.map(col => {
+ if (col.type === 'action') {
+ col.type = 'custom'
+ }
- if (c.type === 'colspan' && c.subcols) {
- c = loopCol(c)
- } else if (c.type === 'custom' && c.elements) {
- c.elements = c.elements.map(cell => {
- cell.uuid = this.getuuid()
+ col.uuid = md5(commonId + col.uuid)
+
+ if (col.type === 'colspan' && col.subcols) {
+ col.subcols = loopCol(col.subcols)
+ } else if (col.type === 'custom' && col.elements) {
+ if (sessionStorage.getItem('editMenuType') === 'popview') {
+ col.elements = col.elements.filter(c => c.eleType !== 'button' || (c.OpenType !== 'popview' && c.OpenType !== 'funcbutton'))
+ }
+ col.elements = col.elements.map(cell => {
+ cell.uuid = md5(commonId + cell.uuid)
+ if (cell.eleType === 'button') {
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (cell.modal && cell.modal.fields.length > 0) {
+ cell.modal.fields = cell.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
+ }
return cell
})
+ } else if (col.editable === 'true' && col.enter && col.enter !== '$next' && col.enter !== '$sub') { // 鍙紪杈戣〃
+ if (/\$next_/.test(col.enter)) {
+ col.enter = '$next_' + md5(commonId + col.enter.split('_')[1])
+ } else {
+ col.enter = md5(commonId + col.enter)
+ }
}
- return c
- })
- return col
- }
-
- let _uuids = {}
- item.cols = item.cols.map(col => {
- let uuid = this.getuuid()
-
- _uuids[col.uuid] = uuid
- col.uuid = uuid
-
- if (col.type === 'colspan' && col.subcols) {
- col = loopCol(col)
- } else if (col.type === 'custom' && col.elements) {
- col.elements = col.elements.map(cell => {
- cell.uuid = this.getuuid()
- return cell
- })
- } else if (col.type === 'action' && col.elements) {
- if (sessionStorage.getItem('editMenuType') === 'popview') {
- col.elements = col.elements.filter(c => c.OpenType !== 'popview' && c.OpenType !== 'funcbutton')
- }
- col.elements = col.elements.map(cell => {
- cell.uuid = this.getuuid()
- return cell
- })
- }
- 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
})
}
+
+ item.cols = loopCol(item.cols)
} else if (item.type === 'form') {
item.subcards = item.subcards.map(cell => {
cell.uuid = this.getuuid()
@@ -748,17 +865,20 @@
delete item.btnlog
- let oriUids = {}
if (item.action) {
if (sessionStorage.getItem('editMenuType') === 'popview') {
item.action = item.action.filter(c => c.OpenType !== 'popview' && c.OpenType !== 'funcbutton')
}
item.action = item.action.map(cell => {
- let _uuid = this.getuuid()
-
- oriUids[cell.uuid] = _uuid
-
- cell.uuid = _uuid
+ cell.uuid = md5(commonId + cell.uuid)
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (cell.modal && cell.modal.fields.length > 0) {
+ cell.modal.fields = cell.modal.fields.map(m => {
+ m.uuid = this.getuuid()
+ return m
+ })
+ }
+ }
return cell
})
@@ -796,20 +916,14 @@
}
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 = ''
- }
+ item.setting.supModule = ''
+ }
+ if (item.wrap && item.wrap.supModule) {
+ item.wrap.supModule = ''
}
if (item.wrap && item.wrap.doubleClick) {
- item.wrap.doubleClick = oriUids[item.wrap.doubleClick] || ''
+ item.wrap.doubleClick = md5(commonId + item.wrap.doubleClick)
}
return item
@@ -841,46 +955,78 @@
}
/**
+ * @description 鑾峰彇鍥捐〃楂樺害
+ */
+export function getHeight (val) {
+ if (typeof(val) === 'string') {
+ if (val.indexOf('px') > -1) {
+ val = parseFloat(val)
+ } else if (val.indexOf('vw') > -1) {
+ val = parseFloat(val)
+ val = document.body.clientWidth * val / 100
+ } else if (val.indexOf('vh') > -1) {
+ val = parseFloat(val)
+ val = document.body.clientHeight * val / 100
+ }
+ }
+
+ return parseInt(val || 400) - 30
+}
+
+/**
* @description 鑾峰彇琛ㄥ悕
*/
export function getTables (config, pops) {
let tables = []
let cuts = []
- let cutreg = /(from|update|insert\s+into)\s+(@db@)?[a-z_]+/ig
+ let cutreg = /(from|update|insert\s+into)\s+(@db@)?[a-z0-9_]+/ig
let trimreg = /(from|update|insert\s+into)\s+(@db@)?/ig
- if (!config.wrap || !config.wrap.datatype || config.wrap.datatype === 'dynamic') {
- if (config.setting) {
- if (config.setting.interType === 'system') {
- if (config.setting.execute !== 'false') {
- let tbs = config.setting.dataresource.match(cutreg)
- tbs && cuts.push(...tbs)
- }
- config.scripts && config.scripts.forEach(script => {
- if (script.status === 'false') return
- let tbs = script.sql.match(cutreg)
- tbs && cuts.push(...tbs)
- })
- } else {
- let tb = config.setting.tableName.replace(/@db@|\s+/ig, '')
- if (/[a-z_]+/ig.test(tb)) {
- tables.push(tb)
- }
+ if (config.setting && (!config.wrap || !config.wrap.datatype || config.wrap.datatype === 'dynamic')) {
+ if (config.setting.interType === 'system') {
+ if (config.setting.execute !== 'false' && config.setting.dataresource) {
+ let tbs = config.setting.dataresource.match(cutreg)
+ tbs && cuts.push(...tbs)
+ }
+ config.scripts && config.scripts.forEach(script => {
+ if (script.status === 'false') return
+ let tbs = script.sql.match(cutreg)
+ tbs && cuts.push(...tbs)
+ })
+ } else if (config.setting.tableName) {
+ let tb = config.setting.tableName.replace(/@db@|\s+/ig, '')
+ if (/[a-z_]+/ig.test(tb)) {
+ tables.push(tb)
}
}
}
+
+ config.search && config.search.forEach(cell => {
+ if (cell.resourceType === '1' && cell.dataSource) {
+ let tbs = cell.dataSource.match(cutreg)
+ tbs && cuts.push(...tbs)
+ }
+ })
let action = []
if (config.type === 'form') {
config.subcards.forEach(item => {
action.push(item.subButton)
+ item.fields && item.fields.forEach(cell => {
+ if (cell.resourceType === '1' && cell.dataSource) {
+ let tbs = cell.dataSource.match(cutreg)
+ tbs && cuts.push(...tbs)
+ }
+ })
})
} else if (config.subcards) {
config.subcards.forEach(item => {
item.elements.forEach(cell => {
if (cell.eleType !== 'button') return
if (['form', 'pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
+ action.push(cell)
+ } else if (cell.OpenType === 'funcbutton' && cell.funcType === 'print' && cell.verify) {
action.push(cell)
} else if (cell.OpenType === 'popview') {
if (pops) {
@@ -896,6 +1042,8 @@
if (cell.eleType !== 'button') return
if (['form', 'pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
action.push(cell)
+ } else if (cell.OpenType === 'funcbutton' && cell.funcType === 'print' && cell.verify) {
+ action.push(cell)
} else if (cell.OpenType === 'popview') {
if (pops) {
pops.push({...cell, parentId: config.uuid})
@@ -907,25 +1055,38 @@
}
})
}
- config.cols && config.cols.forEach(col => {
- if (col.type === 'action') {
- col.elements.forEach(cell => {
- if (['form', 'pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
- action.push(cell)
- } else if (cell.OpenType === 'popview') {
- if (pops) {
- pops.push({...cell, parentId: config.uuid})
- } else if (cell.config && cell.config.$tables) {
- tables.push(...cell.config.$tables)
- }
+
+ if (config.cols) {
+ let loopCol = (cols) => {
+ cols.forEach(col => {
+ if (col.type === 'colspan') {
+ loopCol(col.subcols)
+ } else if (col.type === 'custom') {
+ col.elements.forEach(cell => {
+ if (cell.eleType !== 'button') return
+ if (['form', 'pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
+ action.push(cell)
+ } else if (cell.OpenType === 'funcbutton' && cell.funcType === 'print' && cell.verify) {
+ action.push(cell)
+ } else if (cell.OpenType === 'popview') {
+ if (pops) {
+ pops.push({...cell, parentId: config.uuid})
+ } else if (cell.config && cell.config.$tables) {
+ tables.push(...cell.config.$tables)
+ }
+ }
+ })
}
})
}
- })
+ loopCol(config.cols)
+ }
config.elements && config.elements.forEach(cell => {
if (cell.eleType !== 'button') return
if (['form', 'pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
+ action.push(cell)
+ } else if (cell.OpenType === 'funcbutton' && cell.funcType === 'print' && cell.verify) {
action.push(cell)
} else if (cell.OpenType === 'popview') {
if (pops) {
@@ -938,6 +1099,8 @@
config.action && config.action.forEach(cell => {
if (['pop', 'prompt', 'exec', 'excelIn', 'excelOut'].includes(cell.OpenType)) {
+ action.push(cell)
+ } else if (cell.OpenType === 'funcbutton' && cell.funcType === 'print' && cell.verify) {
action.push(cell)
} else if (cell.OpenType === 'popview') {
if (pops) {
@@ -964,6 +1127,19 @@
tbs && cuts.push(...tbs)
})
}
+ } else if (btn.OpenType === 'funcbutton') {
+ if (btn.intertype !== 'system' || !btn.verify || !btn.verify.setting) return
+ if (btn.verify.dataType === 'custom') {
+ if (btn.verify.setting.defaultSql !== 'false') {
+ let tbs = btn.verify.setting.dataresource.match(cutreg)
+ tbs && cuts.push(...tbs)
+ }
+ btn.verify.scripts && btn.verify.scripts.forEach(script => {
+ if (script.status === 'false') return
+ let tbs = script.sql.match(cutreg)
+ tbs && cuts.push(...tbs)
+ })
+ }
} else if (btn.OpenType === 'excelOut') {
if (btn.intertype !== 'system' || !btn.verify) return
if (btn.verify.dataType === 'custom') {
@@ -982,6 +1158,14 @@
tbs && cuts.push(...tbs)
}
} else {
+ if (btn.OpenType === 'pop' && btn.modal && btn.modal.fields) {
+ btn.modal.fields.forEach(cell => {
+ if (cell.resourceType === '1' && cell.dataSource) {
+ let tbs = cell.dataSource.match(cutreg)
+ tbs && cuts.push(...tbs)
+ }
+ })
+ }
if (btn.intertype === 'inner') return
if (btn.intertype === 'outer' || btn.intertype === 'custom') {
if (btn.procMode === 'system' && btn.verify) {
@@ -1032,8 +1216,186 @@
cuts = cuts.map(item => item.replace(trimreg, ''))
tables.push(...cuts)
- tables = tables.filter(Boolean)
+ tables = tables.filter(tb => tb && tb !== 'dbo' && tb.length > 1)
tables = Array.from(new Set(tables))
return tables
+}
+
+/**
+ * @description 妫�娴嬬粍浠跺唴瀹�
+ */
+export function checkComponent (card) {
+ let errors = []
+ let columns = []
+
+ if (card.$c_ds) {
+ columns = card.columns.map(c => c.field)
+ if (card.setting.interType === 'system' && card.setting.execute !== 'false' && !card.setting.dataresource) {
+ errors.push({ level: 0, detail: '鏈缃暟鎹簮锛�'})
+ } else if (card.setting.interType === 'system' && card.setting.execute === 'false' && card.scripts.filter(script => script.status !== 'false').length === 0) {
+ errors.push({ level: 0, detail: '鏁版嵁婧愪腑鏃犲彲鐢ㄨ剼鏈紒'})
+ } else if (!card.setting.primaryKey) {
+ errors.push({ level: 0, detail: '鏈缃富閿紒'})
+ } else if (!columns.includes(card.setting.primaryKey)) {
+ errors.push({ level: 0, detail: '涓婚敭宸插け鏁堬紒'})
+ } else if (card.subtype === 'dualdatacard') { // 鍙岄噸鍗�
+ if (!card.setting.subKey) {
+ errors.push({ level: 0, detail: '鏈缃瓙琛ㄤ富閿紒'})
+ } else if (!card.setting.subBID) {
+ errors.push({ level: 0, detail: '鏈缃瓙琛˙ID锛�'})
+ } else if (!card.setting.supModule) {
+ errors.push({ level: 0, detail: '鏈缃笂绾х粍浠讹紒'})
+ }
+ } else if (card.type === 'card' && card.subtype === 'datacard') { // 鏁版嵁鍗★紝鍙兘鏈夊涓婄骇
+ if (card.wrap.supType !== 'multi' && !card.setting.supModule) {
+ errors.push({ level: 0, detail: '鏈缃笂绾х粍浠讹紒'})
+ }
+ } else if (card.type !== 'balcony' && !card.setting.supModule) { // 鎮诞妗嗕笂绾х粍浠堕渶鍗曠嫭璁剧疆
+ errors.push({ level: 0, detail: '鏈缃笂绾х粍浠讹紒'})
+ }
+ } else if ((card.type === 'balcony' || card.type === 'card') && card.wrap.datatype === 'public') {
+ columns = card.columns.map(c => c.field)
+ }
+
+ let doubleClick = ''
+ if (card.type === 'table') {
+ doubleClick = card.wrap.doubleClick || ''
+ }
+
+ if (card.$c_ac) {
+ card.action.forEach(cell => {
+ if (cell.hidden === 'true' || cell.origin) return
+ // if (cell.OpenType === 'popview') {
+ // if (!cell.config) {
+ // errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑寮圭獥鏍囩灏氭湭璁剧疆`})
+ // } else if (!cell.config.enabled) {
+ // errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑寮圭獥鏍囩鏈惎鐢╜})
+ // }
+ // }
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (!cell.modal || cell.modal.fields.length === 0) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑琛ㄥ崟灏氭湭娣诲姞`})
+ }
+ } else if (cell.OpenType === 'excelIn' && (!cell.verify || !cell.verify.sheet || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎叆鍒楁湭璁剧疆锛乣})
+ } else if (cell.OpenType === 'excelOut' && (!cell.verify || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎嚭鍒楁湭璁剧疆锛乣})
+ }
+ if (doubleClick === cell.uuid) {
+ doubleClick = ''
+ }
+ })
+ }
+
+ if (card.$c_sc) {
+ card.subcards.forEach((item, i) => {
+ let linkbtn = item.setting.linkbtn || ''
+ item.elements.forEach(cell => {
+ if (cell.eleType === 'button') {
+ if (cell.hidden === 'true') return
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (!cell.modal || cell.modal.fields.length === 0) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑琛ㄥ崟灏氭湭娣诲姞`})
+ }
+ } else if (cell.OpenType === 'excelIn' && (!cell.verify || !cell.verify.sheet || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎叆鍒楁湭璁剧疆锛乣})
+ } else if (cell.OpenType === 'excelOut' && (!cell.verify || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎嚭鍒楁湭璁剧疆锛乣})
+ }
+ if (linkbtn && linkbtn === cell.uuid) {
+ linkbtn = ''
+ }
+ } else if (cell.datatype === 'dynamic' && cell.field && !columns.includes(cell.field)) {
+ errors.push({ level: 1, detail: `鍗$墖涓姩鎬佸瓧娈碘��${cell.field}鈥濇棤鏁坄})
+ }
+ })
+
+ if (card.subtype === 'dualdatacard' || (item.setting.type === 'multi' && item.backElements && sessionStorage.getItem('appType') !== 'mob')) {
+ item.backElements.forEach(cell => {
+ if (cell.eleType === 'button') {
+ if (cell.hidden === 'true') return
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (!cell.modal || cell.modal.fields.length === 0) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑琛ㄥ崟灏氭湭娣诲姞`})
+ }
+ } else if (cell.OpenType === 'excelIn' && (!cell.verify || !cell.verify.sheet || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎叆鍒楁湭璁剧疆锛乣})
+ } else if (cell.OpenType === 'excelOut' && (!cell.verify || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎嚭鍒楁湭璁剧疆锛乣})
+ }
+ if (linkbtn && linkbtn === cell.uuid) {
+ linkbtn = ''
+ }
+ } else if (cell.datatype === 'dynamic' && cell.field && !columns.includes(cell.field)) {
+ errors.push({ level: 1, detail: `鍗$墖涓姩鎬佸瓧娈碘��${cell.field}鈥濇棤鏁坄})
+ }
+ })
+ }
+
+ if (linkbtn) {
+ errors.push({ level: 1, detail: `绗�${i + 1}寮犲崱鐗囦腑缁戝畾鎸夐挳宸插垹闄})
+ }
+ })
+
+ if (card.subcards.length === 0) {
+ errors.push({ level: 0, detail: '鍗$墖涓嶅彲涓虹┖锛�'})
+ }
+ }
+
+ if (card.$c_el) {
+ card.elements.forEach(cell => {
+ if (cell.eleType === 'button') {
+ if (cell.hidden === 'true') return
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (!cell.modal || cell.modal.fields.length === 0) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑琛ㄥ崟灏氭湭娣诲姞`})
+ }
+ } else if (cell.OpenType === 'excelIn' && (!cell.verify || !cell.verify.sheet || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎叆鍒楁湭璁剧疆锛乣})
+ } else if (cell.OpenType === 'excelOut' && (!cell.verify || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎嚭鍒楁湭璁剧疆锛乣})
+ }
+ } else if (cell.datatype === 'dynamic' && cell.field && !columns.includes(cell.field)) {
+ errors.push({ level: 1, detail: `鍗$墖涓姩鎬佸瓧娈碘��${cell.field}鈥濇棤鏁坄})
+ }
+ })
+ }
+
+ if (card.$c_cl) {
+ card.cols.forEach(col => {
+ if (col.type === 'custom') {
+ col.elements.forEach(cell => {
+ if (cell.eleType === 'button') {
+ if (cell.hidden === 'true') return
+ if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
+ if (!cell.modal || cell.modal.fields.length === 0) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑琛ㄥ崟灏氭湭娣诲姞`})
+ }
+ } else if (cell.OpenType === 'excelIn' && (!cell.verify || !cell.verify.sheet || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎叆鍒楁湭璁剧疆锛乣})
+ } else if (cell.OpenType === 'excelOut' && (!cell.verify || !cell.verify.columns || cell.verify.columns.length === 0)) {
+ errors.push({ level: 0, detail: `鎸夐挳鈥�${cell.label}鈥濅腑瀵煎嚭鍒楁湭璁剧疆锛乣})
+ }
+
+ if (doubleClick === cell.uuid) {
+ doubleClick = ''
+ }
+ } else {
+ if (cell.datatype === 'dynamic' && cell.field && !columns.includes(cell.field)) {
+ errors.push({ level: 1, detail: `鏄剧ず鍒椻��${col.label}鈥濅腑鍔ㄦ�佸瓧娈碘��${cell.field}鈥濇棤鏁坄})
+ }
+ }
+ })
+ } else if (col.field && !columns.includes(col.field)) {
+ errors.push({ level: 1, detail: `鏄剧ず鍒椻��${col.label}鈥濅腑瀛楁鈥�${col.field}鈥濇棤鏁坄})
+ }
+ })
+
+ if (doubleClick) {
+ errors.push({ level: 1, detail: `缁戝畾鐨勫弻鍑绘寜閽凡鍒犻櫎`})
+ }
+ }
+
+ return errors
}
\ No newline at end of file
--
Gitblit v1.8.0