From d38dc481492878c04ddf2d6bc2e9bf7d44c57fd7 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期一, 23 十二月 2019 18:29:38 +0800
Subject: [PATCH] 2019-12-23

---
 src/utils/utils.js |  443 +++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 377 insertions(+), 66 deletions(-)

diff --git a/src/utils/utils.js b/src/utils/utils.js
index 1102b7c..e5648a1 100644
--- a/src/utils/utils.js
+++ b/src/utils/utils.js
@@ -25,13 +25,14 @@
    */
   static getguid () {
     // 浜х敓涓�涓柊鐨凣UID鍊�
-    let uuid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, (c) => {
-      let r = Math.random() * 16 | 0
-      // eslint-disable-next-line
-      let v = (c === 'x') ? r : (r & 0x3 | 0x8)
-      return v.toString(16)
-    })
-    return uuid
+    let uuid = []
+    let d = new Date()
+    let options = '0123456789abcdefghigklmnopqrstuv'
+    for (let i = 0; i < 19; i++) {
+      uuid.push(options.substr(Math.floor(Math.random() * 0x20), 1))
+    }
+    uuid = moment().format('YYYYMMDDHHmmss') + d.getMilliseconds() + uuid.join('')
+    return uuid.toUpperCase()
   }
 
   /**
@@ -189,37 +190,117 @@
   }
 
   /**
-   * @description 鎷兼帴鎼滅储鏉′欢
+   * @description 鍒濆鍖栨悳绱㈡潯浠�
+   * @param {Array}   searches     鎼滅储鏉′欢
+   * @return {String}  searches    鏍煎紡鍖栧悗缁撴灉
+   */
+  static initMainSearch (searches) {
+    if (!searches || searches.length === 0) return []
+
+    let newsearches = []
+    searches.forEach(search => {
+      let item = {
+        key: search.field,
+        match: search.match,
+        type: search.type,
+        value: search.initval
+      }
+      if (item.type === 'date') {
+        item.value = item.value ? moment().subtract(item.value, 'days').format('YYYY-MM-DD') : ''
+      } else if (item.type === 'datemonth') {
+        item.value = item.value ? moment().subtract(item.value, 'month').format('YYYY-MM') : ''
+      } else if (item.type === 'dateweek') {
+        item.value = item.value ? [moment().subtract(item.value * 7, 'days').startOf('week').format('YYYY-MM-DD'),
+          moment().subtract(item.value * 7, 'days').endOf('week').format('YYYY-MM-DD')] : ''
+      } else if (item.type === 'daterange') {
+        let _val = item.value
+        if (_val) {
+          try {
+            _val = JSON.parse(_val)
+          } catch {
+            _val = ''
+          }
+        }
+        item.value = _val ? [moment().subtract(_val[0], 'days').format('YYYY-MM-DD'),
+          moment().subtract(_val[1], 'days').format('YYYY-MM-DD')] : ''
+      }
+      newsearches.push(item)
+    })
+    
+    return newsearches
+  }
+
+  /**
+   * @description 鍒濆鍖栨悳绱㈡潯浠�
+   * @param {Array}   searches     鎼滅储鏉′欢
+   * @return {String}  searches    鏍煎紡鍖栧悗缁撴灉
+   */
+  static formatCustomMainSearch (searches) {
+    if (!searches || searches.length === 0) return {}
+
+    let newsearches = {}
+    searches.forEach(item => {
+      if (item.type === 'date') {
+        let timetail = ''
+        let _val = item.value
+
+        if (item.match === '<' || item.match === '<=') {
+          timetail = ' 00:00:00.000'
+          if (_val) {
+            _val = moment(_val, 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD')
+          }
+        } else if (item.match === '>' || item.match === '>=') {
+          timetail = ' 00:00:00.000'
+        }
+
+        if (newsearches[item.key]) {
+          newsearches[item.key + '1'] = _val ? _val + timetail : null
+        } else {
+          newsearches[item.key] = _val ? _val + timetail : null
+        }
+      } else if (item.type === 'datemonth') {
+        // 鏈�-杩囨护鏉′欢锛屼粠鏈堝紑濮嬭嚦缁撴潫
+        let _startval = null
+        let _endval = null
+
+        if (item.value) {
+          _startval = moment(item.value, 'YYYY-MM').startOf('month').format('YYYY-MM-DD') + ' 00:00:00.000'
+          _endval = moment(item.value, 'YYYY-MM').endOf('month').add(1, 'days').format('YYYY-MM-DD') + ' 00:00:00.000'
+        }
+        
+        newsearches[item.key] = _startval
+        newsearches[item.key + '1'] = _endval
+      } else if (item.type === 'dateweek') {
+        let _endval = ''
+        if (item.value) {
+          _endval = moment(item.value[1], 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD')
+        }
+
+        newsearches[item.key] = item.value ? item.value[0] + ' 00:00:00.000' : null
+        newsearches[item.key + '1'] = item.value ? _endval + ' 00:00:00.000' : null
+      } else if (item.type === 'daterange') {
+        let _endval = ''
+        if (item.value) {
+          _endval = moment(item.value[1], 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD')
+        }
+
+        newsearches[item.key] = item.value ? item.value[0] + ' 00:00:00.000' : null
+        newsearches[item.key + '1'] = item.value ? _endval + ' 00:00:00.000' : null
+      } else {
+        newsearches[item.key] = item.value
+      }
+    })
+    
+    return newsearches
+  }
+
+  /**
+   * @description 鎷兼帴鎼滅储鏉′欢main
    * @param {Array}   searches     鎼滅储鏉′欢
    * @return {String}  searchText  鎷兼帴缁撴灉
    */
-  static mainjointsearchkey (searches) {
+  static joinMainSearchkey (searches) {
     if (!searches || searches.length === 0) return ''
-
-    if (searches[0].hasOwnProperty('initval')) {
-      let newsearches = []
-      searches.forEach(search => {
-        let item = {
-          key: search.field,
-          match: search.match,
-          type: search.type,
-          value: search.initval
-        }
-        if (item.type === 'date') {
-          item.value = item.value ? moment().subtract(item.value, 'days').format('YYYY-MM-DD') : ''
-        } else if (item.type === 'datemonth') {
-          item.value = item.value ? moment().subtract(item.value, 'month').format('YYYY-MM') : ''
-        } else if (item.type === 'dateweek') {
-          item.value = item.value ? [moment().subtract(item.value * 7, 'days').startOf('week').format('YYYY-MM-DD'),
-            moment().subtract(item.value * 7, 'days').endOf('week').format('YYYY-MM-DD')] : ''
-        } else if (item.type === 'daterange') {
-          item.value = item.value ? [moment().subtract(item.value, 'days').format('YYYY-MM-DD'),
-            moment().subtract(item.value === 1 ? 1 : 0, 'days').format('YYYY-MM-DD')] : ''
-        }
-        newsearches.push(item)
-      })
-      searches = newsearches
-    }
 
     let searchText = ''
     searches.forEach(item => {
@@ -231,15 +312,38 @@
         let str = item.match === '=' ? '' : '%'
         // eslint-disable-next-line
         searchText += item.key + ' ' + item.match + ' ' + '\'' + str + item.value + str + '\''
-      } else if (item.type === 'date' || item.type === 'datemonth') {
+      } else if (item.type === 'date') {
+        let _val = item.value
+        let timetail = ' 00:00:00.000'
+        let _match = item.match
+
+        if (item.match === '<' || item.match === '<=') { // 鏃堕棿涓�<=鏃讹紝鍖归厤鍚庝竴澶╃殑0鐐癸紝鍖归厤鏂瑰紡涓�<
+          _match = '<'
+          _val = moment(_val, 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD')
+        } else if (item.match === '=') {
+          timetail = ''
+        }
+
         // eslint-disable-next-line
-        searchText += '(' + item.key + ' ' + item.match + ' ' + '\'' + item.value + '\')'
-      } else if (item.type === 'dateweek') {
+        searchText += '(' + item.key + ' ' + _match + ' ' + '\'' + _val + timetail + '\')'
+      } else if (item.type === 'datemonth') { // 鏈�-杩囨护鏉′欢锛屼粠鏈堝紑濮嬭嚦缁撴潫锛岀粨鏉熸椂闂翠负鏈堟湯鍔犱竴澶╃殑0鐐癸紝鏂瑰紡涓�<
+        let _startval = moment(item.value, 'YYYY-MM').startOf('month').format('YYYY-MM-DD') + ' 00:00:00.000'
+        let _endval = moment(item.value, 'YYYY-MM').endOf('month').add(1, 'days').format('YYYY-MM-DD') + ' 00:00:00.000'
+
         // eslint-disable-next-line
-        searchText += '(' + item.key + ' ' + item.match + ' ' + '\'' + item.value[0] + '\' AND \'' + item.value[1] + '\')'
+        searchText += '(' + item.key + ' >= \'' + _startval + '\' AND ' + item.key + ' < \'' + _endval + '\')'
+      } else if (item.type === 'dateweek') { // 鍛�-杩囨护鏉′欢
+        let _startval = item.value[0] + ' 00:00:00.000'
+        let _endval = moment(item.value[1], 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD') + ' 00:00:00.000'
+
+        // eslint-disable-next-line
+        searchText += '(' + item.key + ' >= \'' + _startval + '\' AND ' + item.key + ' < \'' + _endval + '\')'
       } else if (item.type === 'daterange') {
+        let _startval = item.value[0] + ' 00:00:00.000'
+        let _endval = moment(item.value[1], 'YYYY-MM-DD').add(1, 'days').format('YYYY-MM-DD') + ' 00:00:00.000'
+
         // eslint-disable-next-line
-        searchText += '(' + item.key + ' ' + item.match + ' ' + '\'' + item.value[0] + '\' AND \'' + item.value[1] + '\')'
+        searchText += '(' + item.key + ' >= \'' + _startval + '\' AND ' + item.key + ' < \'' + _endval + '\')'
       } else {
         // eslint-disable-next-line
         searchText += '(' + item.key + ' ' + item.match + ' ' + '\'' + item.value + '\')'
@@ -249,7 +353,7 @@
   }
 
   /**
-   * @description 鎷兼帴鎼滅储鏉′欢
+   * @description 鎷兼帴鎼滅储鏉′欢datamanage
    * @param {Array}   searches     鎼滅储鏉′欢
    * @return {String}  searchText  鎷兼帴缁撴灉
    */
@@ -298,6 +402,49 @@
   }
 
   /**
+   * @description 浣跨敤绯荤粺鍑芥暟鏃讹紙sPC_TableData_InUpDe 锛夛紝鐢熸垚sql璇彞
+   * @return {String} type   鎵ц绫诲瀷
+   * @return {String} table  琛ㄥ悕
+   */
+  static getSysDefaultSql (btn, setting, formdata) {
+    let _sql = ''
+    if (btn.OpenType === 'pop' && btn.sqlType === 'insert') {
+      let keys = []
+      let values = []
+      formdata.forEach(item => {
+        if (!item.readonly && item.type === 'number') {
+          keys.push(item.key)
+          values.push(item.value)
+        } else if (!item.readonly) {
+          keys.push(item.key)
+          values.push('\'' + item.value + '\'')
+        }
+      })
+      keys = keys.join(',')
+      values = values.join(',')
+
+      _sql = `insert into ${btn.sql} (${keys}, createuserid) select ${values},@userid`
+    } else if (btn.OpenType === 'pop' && btn.sqlType === 'update') {
+      let _form = []
+      formdata.forEach(item => {
+        if (!item.readonly && item.type === 'number') {
+          _form.push(item.key + '=' + item.value)
+        } else if (!item.readonly) {
+          _form.push(item.key + '=\'' + item.value + '\'')
+        }
+      })
+      _form = _form.join(',')
+      _sql = `update ${btn.sql} set ${_form},modifydate=getdate(),modifyuserid=@userid where ${setting.primaryKey}=@id`
+    } else if ((btn.OpenType === 'prompt' || btn.OpenType === 'exec') && btn.sqlType === 'LogicDelete') { // 閫昏緫鍒犻櫎
+      _sql = `update ${btn.sql} set deleted=1,modifydate=getdate(),modifyuserid=@userid where ${setting.primaryKey}=@id`
+    } else if ((btn.OpenType === 'prompt' || btn.OpenType === 'exec') && btn.sqlType === 'delete') {
+      _sql = `insert into snote (remark,createuserid) select '鍒犻櫎琛�:${btn.sql} 鏁版嵁: id='+@id,@userid delete ${btn.sql} where ${setting.primaryKey}=@id`
+    }
+
+    return _sql
+  }
+
+  /**
    * @description 鍒犻櫎瀛樺偍杩囩▼sql
    * @return {String} name 瀛樺偍杩囩▼鍚嶇О
    */
@@ -306,41 +453,61 @@
   }
 
   /**
-   * @description 鍒涘缓瀛樺偍杩囩▼
+   * @description 鍒涘缓椤甸潰瀛樺偍杩囩▼
    * @return {String}
    */
-  static getfunc (param) {
+  static getTableFunc (param, menu, config) {
     let form = ''
-    if (param.fields && param.fields.length > 0) {
-      let _fields = []
-      param.fields.forEach(item => {
+    let formParam = ''
+    let _columns = []
+
+    if (config.search && config.search.length > 0) {
+      let _fields = new Map()
+      config.search.forEach(item => {
         if (item.field) {
-          _fields.push(item.field)
+          let type = ''
+          let _f = item.field
+
+          if (item.type.match(/date/ig)) {
+            type = 'datetime=null'
+          } else {
+            type = 'nvarchar(50)=\'\''
+          }
+
+          if (_fields.has(item.field)) {
+            _f = _f + '1'
+          }
+
+          _fields.set(item.field, true)
+          formParam = formParam + `mchr13k@${_f} ${type},`
+        }
+      })
+    }
+
+    if (config.columns && config.columns.length > 0) {
+      config.columns.forEach(item => {
+        if (item.field) {
+          _columns.push(`${item.field} as ${item.label}`)
         }
       })
 
-      let field1 = _fields.join(',')
-      let field2 = _fields.join(',@')
-      let field3 = _fields.map(cell => {
-        return cell + '=@' + cell
-      })
-
-      field2 = field2 ? '@' + field2 : ''
-      field3 = field3.join(',')
-
       form = `
-        insert into ${param.name} (${field1}) select ${field2},@UserID
+        declare @dc table (${_columns.join(',')})
         
-        update ${param.name} set ${field3},modifydate=getdate(),modifyuserid=@UserID
+        @tableid ='${menu.MenuID}'
       `
     }
 
-    let Ltext = `create proc ${param.name}
-    (
+    let Ltext = `create proc ${param.innerFunc}
+    ( /*${menu.MenuName}*/
     @BID nvarchar(50)='',
-    @ID nvarchar(50)='',
-    琛ㄥ崟浼犲��,鏂囨湰鐢╪varchar(50)='',鏃ユ湡鐢╠atetime is null ,鏁板�肩敤decimal(18,灏忔暟鐐逛綅鏁�)=0,
-    @sEPTMenuNo='', --浼犺彍鍗曞弬鏁�
+    @ID nvarchar(50)='',${formParam}
+    @PageIndex nvarchar(50)='',
+    @PageSize nvarchar(50)='',
+    @OrderCol nvarchar(50)='',
+    @OrderType nvarchar(50)='',
+    @exceltype nvarchar(50)='',
+    @sEPTMenuNo nvarchar(50)='${menu.MenuNo}',
     @lang nvarchar(50)='',
     @debug nvarchar(50)='',
     @LoginUID nvarchar(50)='',
@@ -360,10 +527,10 @@
       BEGIN TRAN
         /*鍏蜂綋涓氬姟鎿嶄綔*/
         
-         /* 
+        /* 
         select top 10 * from sProcExcep order by id desc
         
-        declare @UserName  nvarchar(50),@FullName nvarchar(50) 
+        declare @UserName  nvarchar(50),@FullName nvarchar(50)
         
         select @UserName=UserName,@FullName=FullName from SUsers where UID=@UserID
         ${form}
@@ -399,15 +566,159 @@
       RAISERROR(@ErrorMessage, /*-- Message text.*/
         @ErrorSeverity, /*-- Severity.*/
         @ErrorState  /*-- State.*/
-        );
+      );
     END CATCH
     
     GOTO_RETURN:
       ROLLBACK TRAN
       
     END`
-    Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k')
     console.log(Ltext)
+    Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k')
+
+    return Ltext
+  }
+
+  /**
+   * @description 鍒涘缓瀛樺偍杩囩▼
+   * @return {String}
+   */
+  static getfunc (param, btn, menu, columns) {
+    let form = ''
+    let formParam = ''
+
+    if (param.fields && param.fields.length > 0) {
+      let _fields = []
+      param.fields.forEach(item => {
+        if (item.field) {
+          let type = ''
+          if (item.type.match(/date/ig)) {
+            type = 'datetime=null'
+          } else if (item.type === 'number') {
+            type = `decimal(18,${item.decimal})=0`
+          } else {
+            type = 'nvarchar(50)=\'\''
+          }
+          formParam = formParam + `mchr13k@${item.field} ${type},`
+
+          _fields.push(item.field)
+        }
+      })
+
+      let field1 = _fields.join(',')
+      let field2 = _fields.join(',@')
+      let field3 = _fields.map(cell => {
+        return cell + '=@' + cell
+      })
+
+      field2 = field2 ? '@' + field2 : ''
+      field3 = field3.join(',')
+
+      form = `
+        insert into ${param.name} (${field1},createuserid) select ${field2},@UserID
+        
+        update ${param.name} set ${field3},modifydate=getdate(),modifyuserid=@UserID
+      `
+    }
+
+    if (columns) {
+      let _col = []
+      let _field = []
+      columns.forEach(col => {
+        if (col.field) {
+          if (col.type === 'number') {
+            _col.push(col.field + ' decimal(18,2)')
+          } else {
+            _col.push(col.field + ' nvarchar(50)')
+          }
+          _field.push(col.field)
+        }
+      })
+      _col = _col.join(',')
+      _field = _field.join(',')
+
+      form = form + `
+        declare @dc table (${_col})
+        
+        insert into @dc (${_field})
+
+        @tableid ='${menu.MenuID}'
+      `
+    }
+
+    let Ltext = `create proc ${param.funcName}
+    ( /*${menu.MenuName}  ${btn.label}*/
+    @BID nvarchar(50)='',
+    @ID nvarchar(50)='',${formParam}
+    @sEPTMenuNo nvarchar(50)='${param.menuNo}',
+    @lang nvarchar(50)='',
+    @debug nvarchar(50)='',
+    @LoginUID nvarchar(50)='',
+    @SessionUid nvarchar(50)='',
+    @UserID nvarchar(50),
+    @ErrorCode nvarchar(50) out,
+    @retmsg nvarchar(4000) out
+    )
+    as
+    begin
+    declare  @BegindateTest datetime,@EnddateTest datetime
+    select  @BegindateTest=getdate()
+    set @ErrorCode=''
+    set @retmsg=''
+    BEGIN TRY
+      /*浜嬪姟鎿嶄綔*/
+      BEGIN TRAN
+        /*鍏蜂綋涓氬姟鎿嶄綔*/
+        
+        /* 
+        select top 10 * from sProcExcep order by id desc
+        
+        declare @UserName  nvarchar(50),@FullName nvarchar(50)
+        
+        select @UserName=UserName,@FullName=FullName from SUsers where UID=@UserID
+        ${form}
+        if 1=2
+        begin
+          set @ErrorCode='E'
+          set @retmsg='鍦ㄦ鍐欐姤閿�'
+          goto GOTO_RETURN
+        end
+        
+        insert into sNote (remark,createuserid,CreateUser,CreateStaff)
+        select '鍦ㄦ鍐欐棩蹇�',@UserID,@UserName,@FullName
+        */
+        
+      COMMIT TRAN
+      SET NOCOUNT ON
+      RETURN
+    END TRY
+    BEGIN CATCH
+      /*閿欒澶勭悊*/
+      ROLLBACK TRAN
+      DECLARE @ErrorMessage NVARCHAR(4000);
+      DECLARE @ErrorSeverity INT;
+      DECLARE @ErrorState INT;
+      
+      /*鎶婅嚜瀹氫箟鐨勫弸濂界殑閿欒淇℃伅鎻愮ず鍔犱笂*/
+      set @ErrorCode=cast(ERROR_NUMBER() as nvarchar(50))
+      SET @retmsg=ERROR_MESSAGE();
+      SELECT @ErrorMessage=ERROR_MESSAGE(),
+        @ErrorSeverity=ERROR_SEVERITY(),
+        @ErrorState=ERROR_STATE();
+        
+      RAISERROR(@ErrorMessage, /*-- Message text.*/
+        @ErrorSeverity, /*-- Severity.*/
+        @ErrorState  /*-- State.*/
+      );
+    END CATCH
+    
+    GOTO_RETURN:
+      ROLLBACK TRAN
+      
+    END`
+
+    Ltext = Ltext.replace(/\n\s{4}/ig, 'mchr13k')
+
     return Ltext
   }
 }
\ No newline at end of file

--
Gitblit v1.8.0