From b3547d1c531e479021219fda5df153a11b9b52a3 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期一, 31 八月 2020 17:28:09 +0800
Subject: [PATCH] 2020-08-31

---
 src/utils/utils.js |  271 ++++++++++++++++++++++++++++--------------------------
 1 files changed, 140 insertions(+), 131 deletions(-)

diff --git a/src/utils/utils.js b/src/utils/utils.js
index f72b359..3c58522 100644
--- a/src/utils/utils.js
+++ b/src/utils/utils.js
@@ -689,7 +689,7 @@
     arrfield = arrfield.join(',')
 
     if (item.orderBy) {
-      sql = 'select distinct ' + arrfield + ',' + item.orderBy + ' as orderfield from ' + _datasource + ' order by orderfield ' + item.orderType
+      sql = `select ${arrfield} from (select distinct ${arrfield},${item.orderBy} as orderfield from ${_datasource} ) a order by orderfield ${item.orderType}`
     } else {
       sql = 'select distinct ' + arrfield + ' from ' + _datasource
     }
@@ -705,7 +705,7 @@
    * @return {String} btn   鎸夐挳
    * @return {String} data  excel鏁版嵁
    */
-  static getExcelInSql (item, data, dict) {
+  static getExcelInSql (item, data, dict, BID) {
     let btn = item.verify
     let keys = ['delete', 'drop', 'insert', 'truncate', 'update']
     let userName = sessionStorage.getItem('User_Name') || ''
@@ -747,8 +747,11 @@
       })
     }
 
+    // 鎺у埗鍙版墦鍗版暟鎹�
+    let conLtext = []
     let _Ltext = data.map((item, lindex) => {
       let vals = []
+      let convals = []
       btn.columns.forEach((col, cindex) => {
         if (col.import === 'false') return
 
@@ -762,92 +765,91 @@
 
           val = val.replace(/(^\s*$)|\t*|\v*/ig, '')
 
-          if (!val && col.required === 'true') { // 蹇呭~鏍¢獙
-            let _error =  _position + dict['main.excel.content.emptyerror']
-            errors.push(_error)
-          } else if (val.length > col.limit) {    // 闀垮害鏍¢獙
-            let _error =  _position + dict['main.excel.content.maxlimit']
-            errors.push(_error)
-          } else {                               // 鍏抽敭瀛楁牎楠�
+          if (!val && col.required === 'true') {            // 蹇呭~鏍¢獙
+            errors.push(_position + dict['main.excel.content.emptyerror'])
+          } else if (col.limit && val.length > col.limit) { // 闀垮害鏍¢獙
+            errors.push(_position + dict['main.excel.content.maxlimit'])
+          } else {                                          // 鍏抽敭瀛楁牎楠�
             keys.forEach(key => {
               let _patten = new RegExp('(^' + key + '\\s+)|(\\s+' + key + '\\s+)', 'ig')
               if (_patten.test(val)) {
-                let _error = _position + dict['main.excel.includekey'] + key
-                errors.push(_error)
+                errors.push(_position + dict['main.excel.includekey'] + key)
               }
             })
           }
         } else if (/^int/ig.test(col.type)) {
           if (!val && val !== 0) {
-            let _error =  _position + dict['main.excel.content.emptyerror']
-            errors.push(_error)
+            errors.push(_position + dict['main.excel.content.emptyerror'])
           } else {
             let _val = val + ''
 
             if (!/^(([^0][0-9]+|0)$)|^(([1-9]+)$)/.test(_val)) {               // 妫�楠屾槸鍚︿负鏁存暟
-              let _error = _position + dict['main.excel.content.interror']
-              errors.push(_error)
+              errors.push(_position + dict['main.excel.content.interror'])
             } else if ((col.min || col.min === 0) && val < col.min) {          // 鏈�灏忓�兼楠�
-              let _error = _position + dict['main.excel.content.limitmin']
-              errors.push(_error)
+              errors.push(_position + dict['main.excel.content.limitmin'])
             } else if ((col.max || col.max === 0) && val > col.max) {          // 鏈�澶у�兼楠�
-              let _error = _position + dict['main.excel.content.limitmax']
-              errors.push(_error)
+              errors.push(_position + dict['main.excel.content.limitmax'])
             }
           }
         } else if (/^Decimal/ig.test(col.type)) {
           if (!val && val !== 0) {
-            let _error =  _position + dict['main.excel.content.emptyerror']
-            errors.push(_error)
+            errors.push(_position + dict['main.excel.content.emptyerror'])
           } else {
             let _val = val + ''
             let _vals = _val.split('.')
 
             if (!/^(([^0][0-9]+|0)\.([0-9]+)$)|^(([^0][0-9]+|0)$)|^(([1-9]+)\.([0-9]+)$)|^(([1-9]+)$)/.test(_val)) {                           // 妫�楠屾槸鍚︿负娴偣鏁�
-              let _error = _position + dict['main.excel.content.floaterror']
-              errors.push(_error)
-            } else if (_vals[0].length > 18) {                         // 妫�楠屾暣鏁颁綅
-              let _error = _position + dict['main.excel.content.floatIntover']
-              errors.push(_error)
+              errors.push(_position + dict['main.excel.content.floaterror'])
+            } else if (_vals[0].length > 18) {                          // 妫�楠屾暣鏁颁綅
+              errors.push(_position + dict['main.excel.content.floatIntover'])
             } else if (_vals[1] && _vals[1].length > col.limit) {       // 鏈�灏忓�兼楠�
-              let _error = _position + dict['main.excel.content.floatPointover']
-              errors.push(_error)
-            } else if ((col.min || col.min === 0) && val < col.min) { // 鏈�灏忓�兼楠�
-              let _error = _position + dict['main.excel.content.limitmin']
-              errors.push(_error)
-            } else if ((col.max || col.max === 0) && val > col.max) { // 鏈�澶у�兼楠�
-              let _error = _position + dict['main.excel.content.limitmax']
-              errors.push(_error)
+              errors.push(_position + dict['main.excel.content.floatPointover'])
+            } else if ((col.min || col.min === 0) && val < col.min) {   // 鏈�灏忓�兼楠�
+              errors.push(_position + dict['main.excel.content.limitmin'])
+            } else if ((col.max || col.max === 0) && val > col.max) {   // 鏈�澶у�兼楠�
+              errors.push(_position + dict['main.excel.content.limitmax'])
             }
           }
         } else if (col.type === 'date') {
-          val = val.replace(/(^\s*$)|\t*|\v*/ig, '')
-
-          if (!val && col.required === 'true') { // 蹇呭~鏍¢獙
-            let _error =  _position + dict['main.excel.content.emptyerror']
-            errors.push(_error)
-          } else {                               // 鍏抽敭瀛楁牎楠�
-            keys.forEach(key => {
-              let _patten = new RegExp('(^' + key + '\\s+)|(\\s+' + key + '\\s+)', 'ig')
-              if (_patten.test(val)) {
-                let _error = _position + dict['main.excel.includekey'] + key
-                errors.push(_error)
+          if (typeof(val) === 'number') {
+            if (val > 2958465 || val <= 0) {                 // 鏃堕棿杩囧ぇ鎴栧皬浜庣瓑浜�0
+              errors.push(_position + dict['main.excel.content.date.over'])
+            } else {                                         // 鏃堕棿鏍煎紡鍖�
+              if (val < 60) {                                // 1900-2-29锛宔xcel涓瓨鍦紝瀹為檯涓嶅瓨鍦�
+                val++
               }
-            })
+              val = moment('19000101', 'YYYYMMDD').add(Math.floor(val - 2), 'days').format('YYYY-MM-DD')
+            }
+          } else if (typeof(val) === 'string') {
+            val = val.replace(/(^\s*$)|\t*|\v*/ig, '')
+            if (!val && col.required === 'true') {           // 鏃堕棿蹇呭~鏍¢獙
+              errors.push(_position + dict['main.excel.content.emptyerror'])
+            } else if (val && !/^[1-9][0-9]{3}/.test(val)) { // 鏃堕棿姝e垯鏍¢獙
+              errors.push(_position + dict['main.excel.content.date.formatError'])
+            }
+          } else {                                           // 鏃堕棿鏍煎紡閿欒
+            errors.push(_position + dict['main.excel.content.date.formatError'])
           }
         }
 
-        if (col.type === 'date') {
-          vals.push(`case when ${col.Column}='' then '1900-01-01' else dateadd(day,cast('${val}' as int)-2,'1900-01-01') end as ${col.Column}`)
-        } else {
-          vals.push(`'${val}' as ${col.Column}`)
+        vals.push(`'${val}'`)
+
+        if (lindex < 40) {
+          convals.push(`'${val}' as ${col.Column}`)
         }
       })
 
       let _lineIndex = '0000' + (lindex + 1) + '0'
       _lineIndex = _lineIndex.substring(_lineIndex.length - 6)
 
-      vals.push(`'${upId + _lineIndex}' as jskey`)
+      vals.push(`'${upId + _lineIndex}'`)
+      vals.push(`'${BID}'`)
+      
+      if (lindex < 40) {
+        convals.push(`'${upId + _lineIndex}' as jskey`)
+        convals.push(`'${BID}' as BID`)
+        conLtext.push(`Select ${convals.join(',')}`)
+      }
 
       return `Select ${vals.join(',')}`
     })
@@ -926,13 +928,13 @@
 
       _sql = `
         /* 绯荤粺鐢熸垚 */
-        declare @${item.sheet} table (${declarefields.join(',')},jskey nvarchar(50) )
+        declare @${item.sheet} table (${declarefields.join(',')},jskey nvarchar(50),BID nvarchar(50) )
         Declare @UserName nvarchar(50),@FullName nvarchar(50),@ErrorCode nvarchar(50),@retmsg nvarchar(4000),@tbid Nvarchar(512)
         
         Select  @ErrorCode='', @retmsg='', @UserName='${userName}', @FullName='${fullName}'
         ${_initCustomScript}
         `
-      _sqlInsert = `Insert into  @${item.sheet} (${fields},jskey)`
+      _sqlInsert = `Insert into @${item.sheet} (${fields},jskey,BID)`
       _sqlBottom = `
         /* 榛樿sql */
         delete tmp_excel_in where upid=@upid@
@@ -946,13 +948,13 @@
         
         aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
 
-      if (window.GLOB.systemType !== 'production' && options.sysType !== 'cloud') {
+      if ((window.GLOB.systemType !== 'production' && options.sysType !== 'cloud') || window.debugger === true) {
         let fsql = `
         ${_sql}
         ${_sqlInsert}
         
         /* excel鏁版嵁锛堝墠40鏉★級 */
-        ${_Ltext.slice(0, 40).join(' Union all ')}
+        ${conLtext.join(' Union all ')}
         ${_sqlBottom}
         `
         fsql = fsql.replace(/\n\s{8}/ig, '\n')
@@ -967,7 +969,7 @@
         Select  @ErrorCode='', @retmsg='', @UserName='${userName}', @FullName='${fullName}'
         `
     }
-    
+
     return {
       sql: _sql,
       lines: result.map((list, index) => {
@@ -994,7 +996,7 @@
     let _formFieldValue = {}
     let _actionType = null
     let appkey = window.GLOB.appkey || ''
-    let sessionUid = sessionStorage.getItem('SessionUid') || ''
+    let sessionUid = localStorage.getItem('SessionUid') || ''
 
     if (verify.default !== 'false') { // 鍒ゆ柇鏄惁浣跨敤榛樿sql
       _actionType = btn.sqlType
@@ -1150,7 +1152,9 @@
     // 鍙橀噺璧嬪��
     _initfields = _initfields.join(',')
     if (_initfields) {
-      _sql += `select ${_initfields}
+      _sql += `
+        
+        select ${_initfields}
         `
     }
 
@@ -1243,6 +1247,77 @@
         `
       })
     }
+    
+    // 鑷畾涔夐獙璇�
+    verify.customverifys && verify.customverifys.forEach(item => {        
+      _sql += `
+        /* 鑷畾涔夐獙璇� */
+        select @tbid='', @ErrorCode='',@retmsg=''
+        select top 1 @tbid='X' from (${item.sql}) a
+        If @tbid ${item.result === 'true' ? '!=' : '='}''
+        Begin
+          select @ErrorCode='${item.errorCode}',@retmsg='${item.errmsg}'
+          goto aaa
+        end
+        `
+    })
+
+    // 鍗曞彿鐢熸垚锛屼娇鐢ㄤ笂绾d锛圔ID锛夋垨鍒楄〃鏁版嵁锛屽0鏄庡彉閲忥紙妫�楠岋級
+    let _billcodesSql  = ''
+    if (verify.billcodes && verify.billcodes.length > 0) {
+      verify.billcodes.forEach(item => {
+        let _ModularDetailCode = ''
+        let _lpline = ''
+        if (item.TypeCharOne === 'Lp') {
+          if (item.linkField === 'BID' && BID) { // 鏇挎崲bid
+            _lpline = `set @ModularDetailCode= 'Lp'+ right('${item.mark || btn.uuid}'+@BID@,48)`
+          } else {
+            _lpline = `set @ModularDetailCode= 'Lp'+ right('${item.mark || btn.uuid}'+@${item.linkField},48)`
+          }
+          _ModularDetailCode = '@ModularDetailCode'
+        } else if (item.TypeCharOne === 'BN') {
+          let _val = ''
+          if (item.linkField === 'BID' && BID) { // 鏇挎崲bid
+            _val = BID
+          } else if (data && data.hasOwnProperty(item.linkField)) {
+            _val = data[item.linkField]
+          }
+          _ModularDetailCode = `'${item.TypeCharOne + _val}'`
+        } else {
+          _ModularDetailCode = `'${item.ModularDetailCode}'`
+        }
+
+        let _declare = ''
+        let _key = item.field.toLowerCase()
+
+        if (!_vars.includes(_key)) {
+          _declare = `Declare @${_key} nvarchar(50)`
+          _vars.push(_key)
+        }
+
+        _billcodesSql += `
+        /* 鍗曞彿鐢熸垚 */
+        ${_declare}
+        select @BillCode='', @${_key}='', @ModularDetailCode=''
+        ${_lpline}
+        exec s_get_BillCode
+          @ModularDetailCode=${_ModularDetailCode},
+          @Type=${item.Type},
+          @TypeCharOne='${item.TypeCharOne}',
+          @TypeCharTwo ='${item.TypeCharTwo}',
+          @BillCode =@BillCode output,
+          @ErrorCode =@ErrorCode output, 
+          @retmsg=@retmsg output
+        if @ErrorCode!=''
+          goto aaa
+        set @${_key}=@BillCode
+        `
+      })
+
+      if (_actionType !== 'insertOrUpdate') {
+        _sql += _billcodesSql
+      }
+    }
 
     // 鍞竴鎬ч獙璇侊紝蹇呴』瀛樺湪琛ㄥ崟锛堣〃鍗曞瓨鍦ㄦ椂锛屼富閿潎涓哄崟鍊硷級,蹇呴』濉啓鏁版嵁婧愶紝澶氳鎷兼帴鏃朵笉鍙敤
     if (formdata && verify.uniques && verify.uniques.length > 0 && btn.Ot !== 'requiredOnce') {
@@ -1318,77 +1393,6 @@
         `
       })
     }
-    
-    // 鑷畾涔夐獙璇�
-    verify.customverifys && verify.customverifys.forEach(item => {        
-      _sql += `
-        /* 鑷畾涔夐獙璇� */
-        select @tbid='', @ErrorCode='',@retmsg=''
-        select top 1 @tbid='X' from (${item.sql}) a
-        If @tbid ${item.result === 'true' ? '!=' : '='}''
-        Begin
-          select @ErrorCode='${item.errorCode}',@retmsg='${item.errmsg}'
-          goto aaa
-        end
-        `
-    })
-
-    // 鍗曞彿鐢熸垚锛屼娇鐢ㄤ笂绾d锛圔ID锛夋垨鍒楄〃鏁版嵁锛屽0鏄庡彉閲忥紙妫�楠岋級
-    let _billcodesSql  = ''
-    if (verify.billcodes && verify.billcodes.length > 0) {
-      verify.billcodes.forEach(item => {
-        let _ModularDetailCode = ''
-        let _lpline = ''
-        if (item.TypeCharOne === 'Lp') {
-          if (item.linkField === 'BID' && BID) { // 鏇挎崲bid
-            _lpline = `set @ModularDetailCode= 'Lp'+ right('${item.mark || btn.uuid}'+@BID@,48)`
-          } else {
-            _lpline = `set @ModularDetailCode= 'Lp'+ right('${item.mark || btn.uuid}'+@${item.linkField},48)`
-          }
-          _ModularDetailCode = '@ModularDetailCode'
-        } else if (item.TypeCharOne === 'BN') {
-          let _val = ''
-          if (item.linkField === 'BID' && BID) { // 鏇挎崲bid
-            _val = BID
-          } else if (data && data.hasOwnProperty(item.linkField)) {
-            _val = data[item.linkField]
-          }
-          _ModularDetailCode = `'${item.TypeCharOne + _val}'`
-        } else {
-          _ModularDetailCode = `'${item.ModularDetailCode}'`
-        }
-
-        let _declare = ''
-        let _key = item.field.toLowerCase()
-
-        if (!_vars.includes(_key)) {
-          _declare = `Declare @${_key} nvarchar(50)`
-          _vars.push(_key)
-        }
-
-        _billcodesSql += `
-        /* 鍗曞彿鐢熸垚 */
-        ${_declare}
-        select @BillCode='', @${_key}='', @ModularDetailCode=''
-        ${_lpline}
-        exec s_get_BillCode
-          @ModularDetailCode=${_ModularDetailCode},
-          @Type=${item.Type},
-          @TypeCharOne='${item.TypeCharOne}',
-          @TypeCharTwo ='${item.TypeCharTwo}',
-          @BillCode =@BillCode output,
-          @ErrorCode =@ErrorCode output, 
-          @retmsg=@retmsg output
-        if @ErrorCode!=''
-          goto aaa
-        set @${_key}=@BillCode
-        `
-      })
-
-      if (_actionType !== 'insertOrUpdate') {
-        _sql += _billcodesSql
-      }
-    }
 
     let hasvoucher = false
 
@@ -1425,6 +1429,8 @@
       let values = []
 
       formdata.forEach(item => {
+        if (item.writein === false) return
+
         keys.push(item.key.toLowerCase())
         values.push('@' + item.key)
       })
@@ -1468,6 +1474,8 @@
       let _arr = []
 
       formdata.forEach(item => {
+        if (item.writein === false) return
+        
         _arr.push(item.key.toLowerCase())
         _form.push(item.key + '=@' + item.key)
       })
@@ -1551,7 +1559,8 @@
 
       _sql += `
         /* 榛樿sql */
-        insert into snote (remark,createuserid,CreateUser,CreateStaff) select left('鍒犻櫎琛�:${btn.sql} 鏁版嵁: ${_msg}${primaryKey}='+@ID@,200),@userid@,@username,@fullname delete ${btn.sql} where ${primaryKey}${_ID};`
+        insert into snote (remark,createuserid,CreateUser,CreateStaff) select left('鍒犻櫎琛�:${btn.sql} 鏁版嵁: ${_msg}${primaryKey}='+@ID@,200),@userid@,@username,@fullname
+        delete ${btn.sql} where ${primaryKey}${_ID};`
     } else if (_actionType === 'insertOrUpdate') {
       _sql += `
         /* 榛樿sql */
@@ -1576,7 +1585,7 @@
     _sql += `
         aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
 
-    if (window.GLOB.systemType !== 'production' && options.sysType !== 'cloud') {
+    if ((window.GLOB.systemType !== 'production' && options.sysType !== 'cloud') || window.debugger === true) {
       _sql = _sql.replace(/\n\s{8}/ig, '\n')
       console.log(_sql)
     }

--
Gitblit v1.8.0