king
2020-12-04 3659f0773a14b54c18ed0af8b64de4afe8227489
src/utils/utils.js
@@ -1048,7 +1048,7 @@
   * @return {String} type   执行类型
   * @return {String} table  表名
   */
  static getSysDefaultSql (btn, setting, formdata, param, data, logcolumns, tab) {
  static getSysDefaultSql (btn, setting, formdata, param, data, columns, tab) {
    let primaryId = param.ID
    let BID = param.BID
    let verify = btn.verify || {}
@@ -1150,38 +1150,29 @@
    // 添加数据中字段,表单值优先(按钮不选行或多行拼接时跳过)
    if (data && btn.Ot !== 'notRequired' && btn.Ot !== 'requiredOnce') {
      _formFieldValue = {...data, ..._formFieldValue}
      const setField = (col) => {
        if (!col.field) return
        let _key = col.field.toLowerCase()
      if (logcolumns && logcolumns.length > 0) {
        logcolumns.forEach(col => {
          let _key = col.field.toLowerCase()
        if (!_initvars.includes(_key)) {
          let _val = data.hasOwnProperty(col.field) ? data[col.field] : ''
          if (!_initvars.includes(_key)) {
            _initvars.push(_key)
          _initvars.push(_key)
          _initColfields.push(`@${_key}='${_val}'`)
        }
        if (!_vars.includes(_key)) {
          _vars.push(_key)
            let _val = data.hasOwnProperty(col.field) ? data[col.field] : ''
            if (col.type === 'number') {
              if (typeof(_val) !== 'number') {
                _val = parseFloat(_val)
                if (isNaN(_val)) {
                  _val = 0
                }
              }
              _initColfields.push(`@${_key}=${_val}`)
            } else {
              _initColfields.push(`@${_key}='${_val}'`)
            }
          }
          if (!_vars.includes(_key)) {
            _vars.push(_key)
          if (col.datatype) {
            _declarefields.push(`@${_key} ${col.datatype}`)
          } else {
            if (col.fieldlength && col.fieldlength > 2048) {
              col.fieldlength = 'max'
            }
  
            let _type = `nvarchar(${col.fieldlength || 50})`
            if (col.type === 'number') {
              let _length = col.decimal ? col.decimal : 0
              _type = `decimal(18,${_length})`
@@ -1190,6 +1181,18 @@
            }
  
            _declarefields.push(`@${_key} ${_type}`)
          }
        }
      }
      if (columns && columns.length > 0) {
        columns.forEach(col => {
          if (col.type === 'colspan' || col.type === 'old_colspan') {
            col.subcols.forEach(cell => {
              setField(cell)
            })
          } else {
            setField(col)
          }
        })
      }
@@ -1623,10 +1626,10 @@
    
    } else if (_actionType === 'delete') {      // 物理删除
      let _msg = ''
      if (data && logcolumns && logcolumns.length > 0) {
      if (data && columns && columns.length > 0) {
        let _index = 0
        logcolumns.forEach(col => {
          if (col.Hide !== 'true' && _index < 4) {
        columns.forEach(col => {
          if (col.Hide !== 'true' && col.type !== 'colspan' && col.type !== 'old_colspan' && _index < 4) {
            _msg += col.label + '=' + data[col.field] + ','
            _index++
          }