From c95918fb0fffb61b1117fbf4cd429e291b9594d0 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期五, 17 九月 2021 01:02:34 +0800
Subject: [PATCH] 2021-09-17
---
src/templates/sharecomponent/settingcomponent/settingform/utils.jsx | 158 ++++++++++++++++++++++++++++++++++++++++++++--------
1 files changed, 132 insertions(+), 26 deletions(-)
diff --git a/src/templates/sharecomponent/settingcomponent/settingform/utils.jsx b/src/templates/sharecomponent/settingcomponent/settingform/utils.jsx
index ebd508d..3b8c1e9 100644
--- a/src/templates/sharecomponent/settingcomponent/settingform/utils.jsx
+++ b/src/templates/sharecomponent/settingcomponent/settingform/utils.jsx
@@ -7,53 +7,91 @@
* @return {Object} setting 椤甸潰璁剧疆
* @return {Array} regoptions 鎼滅储鏉′欢姝e垯鏇挎崲
*/
- static getDebugSql (setting, arr_field, regoptions, search) {
+ static getDebugSql (setting, scripts, arr_field, regoptions, search) {
let sql = ''
- let _dataresource = setting.dataresource
- let _customScript = setting.customScript
+ let _dataresource = setting.dataresource || ''
+ let _customScript = ''
+ scripts && scripts.forEach(script => {
+ _customScript += `
+ ${script.sql}
+ `
+ })
- if (setting.interType === 'inner' && !setting.innerFunc && setting.default === 'false') {
+ if (_customScript) {
+ _customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@departmentcode nvarchar(50),@organization nvarchar(50),@login_city nvarchar(50) select @ErrorCode='',@retmsg =''
+ ${_customScript}
+ `
+ }
+
+ if (setting.default === 'false') {
_dataresource = ''
}
-
- if (_dataresource) {
- _dataresource = _dataresource.replace(/@\$|\$@/ig, '')
+
+ if (window.GLOB.funcs && window.GLOB.funcs.length > 0) {
+ window.GLOB.funcs.forEach(item => {
+ let reg = new RegExp('\\$ex@' + item.func_code + '@ex\\$', 'ig')
+ _dataresource = _dataresource.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
+ _customScript = _customScript.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
+ })
}
- if (_customScript) {
- _customScript = _customScript.replace(/@\$|\$@/ig, '')
+
+ _dataresource = _dataresource.replace(/@\$|\$@/ig, '')
+ _customScript = _customScript.replace(/@\$|\$@/ig, '')
+ _dataresource = _dataresource.replace(/@select\$|\$select@/ig, '')
+ _customScript = _customScript.replace(/@select\$|\$select@/ig, '')
+ _dataresource = _dataresource.replace(/@sum\$|\$sum@/ig, '')
+ _customScript = _customScript.replace(/@sum\$|\$sum@/ig, '')
+
+ // 澶栬仈鏁版嵁搴撴浛鎹�
+ if (window.GLOB.externalDatabase !== null) {
+ _dataresource = _dataresource.replace(/@db@/ig, window.GLOB.externalDatabase)
+ _customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
}
// 姝e垯鏇挎崲
let _regoptions = regoptions.map(item => {
return {
reg: new RegExp('@' + item.key + '@', 'ig'),
- value: `'${item.value}'`
+ value: `'0'`,
+ type: item.type || ''
}
})
+
+ _regoptions.push({
+ reg: new RegExp('@login_city@', 'ig'),
+ value: `''`
+ }, {
+ reg: new RegExp('@userName@', 'ig'),
+ value: `''`
+ }, {
+ reg: new RegExp('@fullName@', 'ig'),
+ value: `''`
+ }, {
+ reg: new RegExp('@orderBy@', 'ig'),
+ value: setting.order
+ }, {
+ reg: new RegExp('@pageSize@', 'ig'),
+ value: 10
+ }, {
+ reg: new RegExp('@pageIndex@', 'ig'),
+ value: 1
+ })
+
let _search = search
if (setting.queryType === 'statistics' && _dataresource) {
_regoptions.forEach(item => {
_dataresource = _dataresource.replace(item.reg, item.value)
})
-
_search = ''
+ } else if (_dataresource) {
+ _regoptions.forEach(item => {
+ if (item.type !== 'url') return
+ _dataresource = _dataresource.replace(item.reg, item.value)
+ })
}
if (_customScript) {
- _regoptions.push({
- reg: new RegExp('@orderBy@', 'ig'),
- value: setting.order
- })
- if (setting.laypage !== 'false') {
- _regoptions.push({
- reg: new RegExp('@pageSize@', 'ig'),
- value: 10
- }, {
- reg: new RegExp('@pageIndex@', 'ig'),
- value: 1
- })
- }
_regoptions.forEach(item => {
_customScript = _customScript.replace(item.reg, item.value)
})
@@ -69,16 +107,84 @@
}
if (_customScript) {
- sql = `${_customScript}
+ sql = `/* sql 楠岃瘉 */
+ ${_customScript}
${_dataresource}
aaa:
if @ErrorCode!=''
insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,@UserID@
`
} else {
- sql = _dataresource
+ sql = `/* sql 楠岃瘉 */
+ ${_dataresource}`
+ }
+ sql = sql.replace(/\n\s{8}/ig, '\n')
+ console.info(sql)
+
+ return sql
+ }
+
+ /**
+ * @description 鐢熸垚鍓嶇疆鎴栧悗缃鍙�
+ * @return {String} scripts 鑴氭湰
+ * @return {Array} regoptions 鎼滅储鏉′欢姝e垯鏇挎崲
+ */
+ static getCustomDebugSql (scripts, regoptions) {
+ let sql = ''
+ let _customScript = ''
+
+ scripts.forEach(script => {
+ if (script.status === 'false') return
+
+ _customScript += `
+ ${script.sql}
+ `
+ })
+
+ if (_customScript) {
+ _customScript = `declare @ErrorCode nvarchar(50),@retmsg nvarchar(4000),@UserName nvarchar(50),@FullName nvarchar(50),@RoleID nvarchar(512),@departmentcode nvarchar(50),@organization nvarchar(50),@login_city nvarchar(50) select @ErrorCode='',@retmsg =''
+ ${_customScript}
+ `
+ }
+
+ if (window.GLOB.funcs && window.GLOB.funcs.length > 0) {
+ window.GLOB.funcs.forEach(item => {
+ let reg = new RegExp('\\$ex@' + item.func_code + '@ex\\$', 'ig')
+ _customScript = _customScript.replace(reg, `/*$ex@${item.func_code}-begin*/\n${item.key_sql}\n/*@ex$-end*/`)
+ })
+ }
+
+ _customScript = _customScript.replace(/@\$|\$@/ig, '')
+ _customScript = _customScript.replace(/@userName@|@fullName@|@login_city@/ig, `''`)
+ // 澶栬仈鏁版嵁搴撴浛鎹�
+ if (window.GLOB.externalDatabase !== null) {
+ _customScript = _customScript.replace(/@db@/ig, window.GLOB.externalDatabase)
}
+ // 姝e垯鏇挎崲
+ if (regoptions) {
+ let _regoptions = regoptions.map(item => {
+ return {
+ reg: new RegExp('@' + item.key + '@', 'ig'),
+ value: `'0'`
+ }
+ })
+ _regoptions.forEach(item => {
+ _customScript = _customScript.replace(item.reg, item.value)
+ })
+ }
+
+ if (_customScript) {
+ sql = `/* sql 楠岃瘉 */
+ ${_customScript}
+ aaa:
+ if @ErrorCode!=''
+ insert into tmp_err_retmsg (ID, ErrorCode, retmsg, CreateUserID) select @time_id@,@ErrorCode, @retmsg,@UserID@
+ `
+ }
+ sql = sql.replace(/\n\s{8}/ig, '\n')
+ console.info(sql)
+
return sql
}
}
\ No newline at end of file
--
Gitblit v1.8.0