From 81e1787aaee9d03da52ab8938d1961c4333ee5b5 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期四, 02 三月 2023 11:27:51 +0800
Subject: [PATCH] 2023-03-02
---
src/utils/utils-custom.js | 854 ++++++++++++++++++++++++++++++++++++++++++--------------
1 files changed, 639 insertions(+), 215 deletions(-)
diff --git a/src/utils/utils-custom.js b/src/utils/utils-custom.js
index 621c33c..eb12ca9 100644
--- a/src/utils/utils-custom.js
+++ b/src/utils/utils-custom.js
@@ -1,25 +1,107 @@
+import md5 from 'md5'
+
export default class MenuUtils {
/**
* @description 鑾峰彇涓嬬骇妯″潡
* @return {String} selfId 褰撳墠缁勪欢id
*/
- static getSubModules (components, selfId) {
+ static getSubModules (components, selfId, supId) {
+ let modules = []
+ components.forEach(item => {
+ if (item.uuid === selfId || item.type === 'navbar') {
+ return
+ } else if (item.format) { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
+ modules.push({
+ value: item.uuid,
+ label: item.name,
+ disabled: supId === item.uuid
+ })
+ } else if (item.type === 'tabs') {
+ if (item.subtype === 'tabletabs') {
+ item.subtabs.forEach(tab => {
+ modules.push({
+ value: tab.components[0].uuid,
+ label: tab.label,
+ disabled: supId === tab.components[0].uuid
+ })
+ })
+ } else {
+ let _item = {
+ type: 'tabs',
+ value: item.uuid,
+ label: item.name,
+ children: item.subtabs.map(f_tab => {
+ let subItem = {
+ type: 'tab',
+ value: f_tab.uuid,
+ label: f_tab.label,
+ children: this.getSubModules(f_tab.components, selfId, supId)
+ }
+
+ if (subItem.children.length === 0) {
+ return {children: null}
+ }
+ return subItem
+ })
+ }
+
+ _item.children = _item.children.filter(t => t.children !== null)
+
+ if (_item.children.length > 0) {
+ modules.push(_item)
+ }
+ }
+ } else if (item.type === 'group') {
+ let _item = {
+ value: item.uuid,
+ label: item.name,
+ children: item.components.map(f_tab => {
+ if (f_tab.uuid === selfId) {
+ return {
+ children: null
+ }
+ } else if (f_tab.format) {
+ return {
+ value: f_tab.uuid,
+ label: f_tab.name,
+ disabled: supId === f_tab.uuid
+ }
+ }
+ return {
+ children: null
+ }
+ })
+ }
+
+ _item.children = _item.children.filter(t => t.children !== null)
+
+ if (_item.children.length > 0) {
+ modules.push(_item)
+ }
+ }
+ })
+
+ return modules
+ }
+
+ /**
+ * @description 鑾峰彇涓嬬骇妯″潡
+ * @return {String} selfId 褰撳墠缁勪欢id
+ */
+ static getAnchors (components, selfId) {
let modules = components.map(item => {
if (item.uuid === selfId) {
return {
children: null
}
- } else if (item.format) { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
- return {
- value: item.uuid,
- label: item.name
- }
} else if (item.type === 'tabs') {
let _item = {
+ type: 'tabs',
value: item.uuid,
label: item.name,
children: item.subtabs.map(f_tab => {
let subItem = {
+ type: 'tab',
value: f_tab.uuid,
label: f_tab.label,
children: this.getSubModules(f_tab.components, selfId)
@@ -67,6 +149,11 @@
}
return _item
+ } else if (!['login', 'navbar', 'topbar', 'tabs', 'search', 'group', 'balcony'].includes(item.type)) { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
+ return {
+ value: item.uuid,
+ label: item.name
+ }
} else {
return {
children: null
@@ -86,47 +173,63 @@
* @description 鑾峰彇涓婄骇妯″潡
* @return {String} selfId 褰撳墠缁勪欢id
*/
- static getSupModules (components, selfId) {
- let modules = components.map(item => {
+ static getSupModules (components, selfId, interfaces) {
+ let modules = []
+ components.forEach(item => {
if (item.uuid === selfId) {
- return {
- children: null
- }
+
} else if (item.switchable) { // 鏁版嵁鍙垏鎹�
- return {
- value: item.uuid,
- label: item.name
+ let disabled = false
+ if (item.type === 'card') {
+ disabled = item.wrap.cardType === ''
+ } else if (item.type === 'table') {
+ disabled = item.wrap.tableType === ''
}
- } else if (item.type === 'form') { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
- return {
- value: item.uuid,
- label: item.name
- }
- } else if (item.type === 'tabs') {
- let _item = {
+ modules.push({
value: item.uuid,
label: item.name,
- children: item.subtabs.map(f_tab => {
- let subItem = {
- value: f_tab.uuid,
- label: f_tab.label,
- children: this.getSupModules(f_tab.components, selfId)
- }
+ disabled: disabled
+ })
+ } else if (item.type === 'form') { // 鏁版嵁鏍煎紡锛屽瓨鍦ㄦ暟鎹簮
+ modules.push({
+ value: item.uuid,
+ label: item.name
+ })
+ } else if (item.type === 'tabs') {
+ if (item.subtype === 'tabletabs') {
+ item.subtabs.forEach(tab => {
+ if (tab.components[0].uuid === selfId) return
- if (!subItem.children || subItem.children.length === 0) {
- return {children: null}
- }
- return subItem
+ modules.push({
+ value: tab.components[0].uuid,
+ label: tab.label,
+ disabled: tab.components[0].wrap.tableType === ''
+ })
})
+ } else {
+ let _item = {
+ value: item.uuid,
+ label: item.name,
+ children: item.subtabs.map(f_tab => {
+ let subItem = {
+ value: f_tab.uuid,
+ label: f_tab.label,
+ children: this.getSupModules(f_tab.components, selfId)
+ }
+
+ if (subItem.children.length === 0) {
+ return {children: null}
+ }
+ return subItem
+ })
+ }
+
+ _item.children = _item.children.filter(t => t.children !== null)
+
+ if (_item.children.length > 0) {
+ modules.push(_item)
+ }
}
-
- _item.children = _item.children.filter(t => t.children !== null)
-
- if (_item.children.length === 0) {
- return {children: null}
- }
-
- return _item
} else if (item.type === 'group') {
let _item = {
value: item.uuid,
@@ -137,9 +240,16 @@
children: null
}
} else if (f_tab.switchable) {
+ let disabled = false
+ if (f_tab.type === 'card') {
+ disabled = f_tab.wrap.cardType === ''
+ } else if (f_tab.type === 'table') {
+ disabled = f_tab.wrap.tableType === ''
+ }
return {
value: f_tab.uuid,
- label: f_tab.name
+ label: f_tab.name,
+ disabled: disabled
}
}
return {
@@ -150,24 +260,47 @@
_item.children = _item.children.filter(t => t.children !== null)
- if (_item.children.length === 0) {
- return {children: null}
- }
-
- return _item
- } else {
- return {
- children: null
+ if (_item.children.length > 0) {
+ modules.push(_item)
}
}
})
- modules = modules.filter(mod => mod.children !== null)
-
- if (modules.length === 0) {
- return null
+ 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
}
/**
@@ -245,73 +378,6 @@
}
/**
- * @description 鑾峰彇鍒犻櫎鎸夐挳Id
- * @return {String} name
- */
- static getDelButtonIds (card) {
- let appType = sessionStorage.getItem('appType')
- let uuids = []
-
- if (appType === 'mob') return uuids
-
- const getUuids = (item) => {
- if (item.type === 'tabs') {
- item.subtabs.forEach(tab => {
- tab.components.forEach(c => {
- getUuids(c)
- })
- })
- } else if (item.type === 'group') {
- item.components.forEach(c => {
- getUuids(c)
- })
- } else {
- item.action && item.action.forEach(act => {
- if (act.origin || (appType === 'pc' && act.OpenType !== 'popview')) return
-
- uuids.push(act.uuid)
- })
-
- if (card.type === 'card' || item.type === 'carousel' || (card.type === 'table' && card.subtype === 'tablecard')) {
- card.subcards.forEach(_card => {
- _card.elements && _card.elements.forEach(cell => {
- if (cell.eleType !== 'button') return
- if (appType === 'pc' && cell.OpenType !== 'popview') return
-
- uuids.push(cell.uuid)
- })
- _card.backElements && _card.backElements.forEach(cell => {
- if (cell.eleType !== 'button') return
- if (appType === 'pc' && cell.OpenType !== 'popview') return
-
- uuids.push(cell.uuid)
- })
- })
- } else if (card.type === 'table' && card.subtype === 'normaltable') {
- card.cols && card.cols.forEach(col => {
- if (col.type !== 'action') return
- col.elements && col.elements.forEach(cell => {
- if (appType === 'pc' && cell.OpenType !== 'popview') return
-
- uuids.push(cell.uuid)
- })
- })
- } else if (card.type === 'balcony') {
- card.elements && card.elements.forEach(cell => {
- if (appType === 'pc' && cell.OpenType !== 'popview') return
-
- uuids.push(cell.uuid)
- })
- }
- }
- }
-
- getUuids(card)
-
- return uuids
- }
-
- /**
* @description 鐢熸垚32浣島uid string + 鏃堕棿
* @return {String} uuid
*/
@@ -330,75 +396,137 @@
* @description 閲嶇疆鑿滃崟閰嶇疆锛岄〉闈㈡暣浣撳鍒�
* @return {String} components 閰嶇疆淇℃伅
*/
- static resetConfig = (components) => {
+ static resetConfig = (components, commonId, clear = false) => {
return components.map(item => {
if (item.type === 'navbar') {
return item
}
- item.uuid = this.getuuid()
+ if (item.subtype === 'tablecard') { // 鍏煎
+ item.type = 'card'
+ }
+
+ item.uuid = md5(commonId + item.uuid)
if (item.type === 'tabs') {
item.subtabs.forEach(tab => {
- tab.uuid = this.getuuid()
- tab.parentId = item.uuid
-
- tab.components = tab.components.map(cell => {
- cell.tabId = tab.uuid
- cell.parentId = item.uuid
- return cell
- })
- tab.components = this.resetConfig(tab.components)
+ tab.uuid = md5(commonId + tab.uuid)
+
+ tab.components = this.resetConfig(tab.components, commonId, 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, commonId, 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)) {
+ if (item.wrap.datatype === 'public' && item.wrap.publicId) {
+ item.wrap.publicId = md5(commonId + item.wrap.publicId)
+ }
+
+ 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 => {
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 (cell.eleType === 'button') {
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ }
+
return cell
})
}
if (card.backElements) {
card.backElements = card.backElements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (cell.eleType === 'button') {
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ }
+
return cell
})
}
})
} else if (item.type === 'balcony') {
+ if (item.wrap.datatype === 'public' && item.wrap.publicId) {
+ item.wrap.publicId = md5(commonId + item.wrap.publicId)
+ }
if (item.elements) {
item.elements = item.elements.map(cell => {
cell.uuid = this.getuuid()
+
+ if (cell.eleType === 'button') {
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+ this.resetBtn(cell, commonId)
+ }
+
return cell
})
}
- } else if (item.type === 'table' && item.subtype === 'normaltable' && item.cols) {
+ } else if (item.type === 'table' && item.cols) {
let loopCol = (col) => {
col.subcols = col.subcols.map(c => {
- c.uuid = this.getuuid()
+ c.uuid = md5(commonId + c.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()
+
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 = ''
+ }
+
+ this.resetBtn(cell, commonId)
+
return cell
})
}
@@ -407,9 +535,9 @@
return col
}
-
+
item.cols = item.cols.map(col => {
- col.uuid = this.getuuid()
+ col.uuid = md5(commonId + col.uuid)
if (col.type === 'colspan' && col.subcols) {
col = loopCol(col)
@@ -421,24 +549,60 @@
} else if (col.type === 'action' && col.elements) {
col.elements = col.elements.map(cell => {
cell.uuid = this.getuuid()
+ this.resetBtn(cell, commonId)
return cell
})
}
return col
})
+
+ if (item.subtype === 'editable') {
+ item.cols = item.cols.map(col => {
+ if (col.editable === 'true' && col.enter) {
+ col.enter = md5(commonId + col.enter)
+ } else if (col.type === 'colspan' && col.subcols) {
+ col.subcols = col.subcols.map(c => {
+ if (c.editable === 'true' && c.enter) {
+ c.enter = md5(commonId + c.enter)
+ }
+ return c
+ })
+ }
+ return col
+ })
+ }
+ } else if (item.type === 'form') {
+ item.subcards = item.subcards.map(cell => {
+ cell.uuid = this.getuuid()
+
+ cell.fields = cell.fields.map(m => {
+ m.uuid = this.getuuid()
+
+ return m
+ })
+
+ if (cell.subButton) {
+ this.resetBtn(cell.subButton, commonId)
+ }
+
+ return cell
+ })
}
if (item.btnlog) {
- item.btnlog = []
+ item.btnlog = null
}
- let oriUids = {}
if (item.action) {
item.action = item.action.map(cell => {
- let _uuid = this.getuuid()
+ cell.uuid = md5(commonId + cell.uuid)
- oriUids[cell.uuid] = _uuid
- cell.uuid = _uuid
+ if (clear && cell.pageTemplate === 'linkpage' && cell.linkmenu) {
+ cell.pageTemplate = ''
+ cell.linkmenu = ''
+ }
+
+ this.resetBtn(cell, commonId)
return cell
})
@@ -460,6 +624,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()
@@ -473,8 +640,17 @@
})
}
+ if (item.setting && item.setting.supModule && item.setting.supModule[0] !== 'empty') {
+ item.setting.supModule = item.setting.supModule.map(c => {
+ return md5(commonId + c)
+ })
+ 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
@@ -482,35 +658,50 @@
}
/**
- * @description 鏁版嵁婧愬悕绉帮紝鐢ㄤ簬缁熶竴鏌ヨ
- * @return {String} name
+ * @description 鎸夐挳閲嶇疆
*/
- static getdataName () {
+ static resetBtn (btn, commonId) {
+ 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.length > 0) {
+ btn.syncComponent = btn.syncComponent.map(m => md5(commonId + m))
+ }
+ }
+
+ /**
+ * @description 缁勪欢鍚嶅姞鍚庣紑
+ */
+ static getSignName () {
let name = []
let _options = 'abcdefghigklmnopqrstuvwxyz'
- for (let i = 0; i < 6; i++) {
+ for (let i = 0; i < 3; i++) {
name.push(_options.substr(Math.floor(Math.random() * 26), 1))
}
- name.splice(3, 0, new Date().getTime())
- return name.join('')
+ return (Math.floor(Math.random()*10) + name.join('')).toUpperCase()
}
/**
* @description 閲嶇疆缁勪欢閰嶇疆
* @return {String} item 缁勪欢淇℃伅
*/
- static resetComponentConfig = (item, copyBtns) => {
+ static resetComponentConfig = (item) => {
if (item.type === 'navbar') {
return item
}
- item.uuid = this.getuuid()
- if (item.dataName) {
- item.dataName = this.getdataName()
+ if (item.subtype === 'tablecard') { // 鍏煎
+ item.type = 'card'
}
+ item.uuid = this.getuuid()
+ let commonId = this.getuuid()
+
// 閲嶇疆缁勪欢鍚嶇О
- let sign = this.getdataName().toUpperCase().substr(-4)
+ let sign = this.getSignName()
if (item.plot) { // 鍥捐〃
item.plot.name = item.plot.name + sign
item.name = item.plot.name
@@ -527,7 +718,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.subcards.forEach(card => {
card.uuid = this.getuuid()
if (card.elements) {
@@ -535,14 +726,7 @@
card.elements = card.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
card.elements = card.elements.map(cell => {
- let _uuid = this.getuuid()
- if (cell.OpenType === 'popview' && copyBtns) {
- let _cell = JSON.parse(JSON.stringify(cell))
- _cell.$originUuid = _cell.uuid
- _cell.uuid = _uuid
- copyBtns.set(_uuid, _cell)
- }
- cell.uuid = _uuid
+ cell.uuid = this.getuuid()
return cell
})
}
@@ -551,14 +735,7 @@
card.elements = card.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
card.backElements = card.backElements.map(cell => {
- let _uuid = this.getuuid()
- if (cell.OpenType === 'popview' && copyBtns) {
- let _cell = JSON.parse(JSON.stringify(cell))
- _cell.$originUuid = _cell.uuid
- _cell.uuid = _uuid
- copyBtns.set(_uuid, _cell)
- }
- cell.uuid = _uuid
+ cell.uuid = this.getuuid()
return cell
})
}
@@ -569,18 +746,11 @@
item.elements = item.elements.filter(b => b.OpenType !== 'popview' && b.OpenType !== 'funcbutton')
}
item.elements = item.elements.map(cell => {
- let _uuid = this.getuuid()
- if (cell.OpenType === 'popview' && copyBtns) {
- let _cell = JSON.parse(JSON.stringify(cell))
- _cell.$originUuid = _cell.uuid
- _cell.uuid = _uuid
- copyBtns.set(_uuid, _cell)
- }
- cell.uuid = _uuid
+ cell.uuid = this.getuuid()
return cell
})
}
- } else if (item.type === 'table' && item.subtype === 'normaltable' && item.cols) {
+ } else if (item.type === 'table' && item.cols) {
let loopCol = (col) => {
col.subcols = col.subcols.map(c => {
c.uuid = this.getuuid()
@@ -600,7 +770,7 @@
}
item.cols = item.cols.map(col => {
- col.uuid = this.getuuid()
+ col.uuid = md5(commonId + col.uuid)
if (col.type === 'colspan' && col.subcols) {
col = loopCol(col)
@@ -614,19 +784,21 @@
col.elements = col.elements.filter(c => c.OpenType !== 'popview' && c.OpenType !== 'funcbutton')
}
col.elements = col.elements.map(cell => {
- let _uuid = this.getuuid()
- if (cell.OpenType === 'popview' && copyBtns) {
- let _cell = JSON.parse(JSON.stringify(cell))
- _cell.$originUuid = _cell.uuid
- _cell.uuid = _uuid
- copyBtns.set(_uuid, _cell)
- }
- cell.uuid = _uuid
+ cell.uuid = this.getuuid()
return cell
})
}
return col
})
+
+ if (item.subtype === 'editable') {
+ item.cols = item.cols.map(col => {
+ if (col.editable === 'true' && col.enter) {
+ col.enter = md5(commonId + col.enter)
+ }
+ return col
+ })
+ }
} else if (item.type === 'form') {
item.subcards = item.subcards.map(cell => {
cell.uuid = this.getuuid()
@@ -640,33 +812,21 @@
})
}
- if (item.btnlog) {
- item.btnlog = []
- }
+ 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
-
- if (cell.OpenType === 'popview' && copyBtns) {
- let _cell = JSON.parse(JSON.stringify(cell))
- _cell.$originUuid = _cell.uuid
- _cell.uuid = _uuid
- copyBtns.set(_uuid, _cell)
- }
-
- cell.uuid = _uuid
+ cell.uuid = md5(commonId + cell.uuid)
return cell
})
}
if (item.type === 'topbar') {
+ item.wrap.name = ''
+ item.name = ''
if (item.search && item.search.fields) {
item.search.fields = item.search.fields.map(cell => {
cell.uuid = this.getuuid()
@@ -696,12 +856,15 @@
})
}
- if (item.setting && item.setting.supModule) {
+ if (item.setting && item.setting.supModule && item.setting.supModule[0] !== 'empty') {
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
@@ -714,9 +877,11 @@
*/
export function resetStyle (style) {
if (!style) return {}
- if (sessionStorage.getItem('appType') === 'mob') {
- let _style = JSON.stringify(style)
+ let _style = JSON.stringify(style)
+ _style = _style.replace(/@mywebsite@\//ig, window.GLOB.baseurl)
+
+ if (sessionStorage.getItem('appType') === 'mob') {
// scaleview
_style = _style.replace(/\d+vw/ig, (word) => {
return parseFloat(word) * (window.GLOB.winWidth || 420) / 100 + 'px'
@@ -725,8 +890,267 @@
return parseFloat(word) * (window.GLOB.winHeight || 738) / 100 + 'px'
// return parseFloat(word) * 615 / 100 + 'px'
})
-
- return JSON.parse(_style)
}
- return JSON.parse(JSON.stringify(style))
+
+ return JSON.parse(_style)
+}
+
+/**
+ * @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-z0-9_]+/ig
+ let trimreg = /(from|update|insert\s+into)\s+(@db@)?/ig
+
+ 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) {
+ pops.push({...cell, parentId: config.uuid})
+ } else if (cell.config && cell.config.$tables) {
+ tables.push(...cell.config.$tables)
+ }
+ }
+ })
+
+ if (item.backElements && item.setting.type === 'multi') {
+ item.backElements.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)
+ }
+ }
+ })
+ }
+ })
+ }
+
+ 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 === '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)
+ }
+ }
+ })
+ }
+ })
+
+ 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) {
+ pops.push({...cell, parentId: config.uuid})
+ } else if (cell.config && cell.config.$tables) {
+ tables.push(...cell.config.$tables)
+ }
+ }
+ })
+
+ 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) {
+ pops.push({...cell, parentId: config.uuid})
+ } else if (cell.config && cell.config.$tables) {
+ tables.push(...cell.config.$tables)
+ }
+ }
+ })
+
+ action.forEach(btn => {
+ if (btn.OpenType === 'excelIn') {
+ if (!btn.verify) return
+ if (btn.intertype !== 'system' || btn.verify.default !== 'false') {
+ let tb = btn.sheet.replace(/@db@|\s+/ig, '')
+ if (/[a-z_]+/ig.test(tb)) {
+ tables.push(tb)
+ }
+ }
+ if (btn.intertype === 'system' && 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 === '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') {
+ if (btn.verify.defaultSql !== 'false') {
+ let tbs = btn.verify.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)
+ })
+ }
+ if (btn.verify.enable === 'true' && btn.verify.script) {
+ let tbs = btn.verify.script.match(cutreg)
+ 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) {
+ if (btn.verify.default !== 'false' && btn.sql) {
+ let tb = btn.sql.replace(/@db@|\s+/ig, '')
+ if (/[a-z_]+/ig.test(tb)) {
+ tables.push(tb)
+ }
+ }
+ btn.verify.customverifys && btn.verify.customverifys.forEach(script => {
+ if (script.status === 'false') return
+ let tbs = script.sql.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)
+ })
+ }
+ if (btn.callbackType === 'script' && btn.verify) {
+ btn.verify.cbScripts && btn.verify.cbScripts.forEach(script => {
+ if (script.status === 'false') return
+ let tbs = script.sql.match(cutreg)
+ tbs && cuts.push(...tbs)
+ })
+ }
+ } else if (btn.verify) {
+ if (btn.verify.default !== 'false' && btn.sql) {
+ let tb = btn.sql.replace(/@db@|\s+/ig, '')
+ if (/[a-z_]+/ig.test(tb)) {
+ tables.push(tb)
+ }
+ }
+ btn.verify.customverifys && btn.verify.customverifys.forEach(script => {
+ if (script.status === 'false') return
+ let tbs = script.sql.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)
+ })
+ }
+ }
+ })
+
+ cuts = cuts.map(item => item.replace(trimreg, ''))
+ tables.push(...cuts)
+ tables = tables.filter(tb => tb && tb !== 'dbo' && tb.length > 1)
+ tables = Array.from(new Set(tables))
+
+ return tables
}
\ No newline at end of file
--
Gitblit v1.8.0