king
2024-08-03 c18f79e01a2705d34d5ac2923a26913dba07ea14
src/menu/debug/index.jsx
@@ -1,4 +1,4 @@
import React, {Component} from 'react'
import React, { Component } from 'react'
import PropTypes from 'prop-types'
import { fromJS } from 'immutable'
import { Modal, Button, Drawer, Tooltip } from 'antd'
@@ -26,6 +26,7 @@
  sqlList = []
  verSqls = []
  linkMain = null
  trigger = () => {
    let config = fromJS(this.props.config).toJS()
@@ -66,6 +67,7 @@
    }
    this.sqlList = []
    this.linkMain = []
    let regs = [
      { reg: /@userName@/ig, value: `'User_Name'` },
@@ -137,8 +139,80 @@
    this.verSqls = sqls
    let that = this
    let formErrors = []
    if (this.linkMain.length) {
      let map = new Map()
      if (config.interfaces) {
        config.interfaces.forEach(m => {
          if (m.status !== 'true' || !m.columns) return false
          map.set(m.uuid, m.columns)
        })
      }
      let forEachComs = (components) => {
        components.forEach(item => {
          if (item.type === 'tabs') {
            item.subtabs.forEach(tab => {
              forEachComs(tab.components)
            })
          } else if (item.type === 'group') {
            forEachComs(item.components)
          } else if (item.columns && item.columns.length) {
            map.set(item.uuid, item.columns)
          }
        })
      }
      forEachComs(config.components)
      this.linkMain.forEach(item => {
        if (item.config.wrap && item.config.wrap.datatype === 'public') return
        let supModule = ''
        if (item.config.wrap && item.config.wrap.datatype === 'static') {
          supModule = item.config.wrap.supModule ? item.config.wrap.supModule[item.config.wrap.supModule.length - 1] : ''
        } else if (item.config.setting && item.config.setting.supModule) {
          supModule = item.config.setting.supModule[item.config.setting.supModule.length - 1] || ''
          if (supModule === 'empty') {
            supModule = ''
          }
        }
        if (!supModule) return
        let cols = map.get(supModule)
        if (!cols) {
          formErrors.push(<div key={item.forms[0].uuid}>
            组件<span style={{color: '#1890ff', margin: '0 2px 0 2px'}}>{item.config.name}{item.label ? '-' + item.label : ''}</span>中表单<span style={{color: 'orange', margin: '0 2px 0 2px'}}>{item.forms.map(c => c.label + ' (' + c.field + ')').join('、')}</span>无效
          </div>)
        } else {
          let _forms = []
          let _cols = cols.map(col => col.field.toLowerCase())
          item.forms.forEach(m => {
            if (_cols.includes(m.field.toLowerCase())) return
            _forms.push(m.label + ' (' + m.field + ')')
          })
          if (_forms.length) {
            formErrors.push(<div key={item.forms[0].uuid}>
              组件<span style={{color: '#1890ff', margin: '0 2px 0 2px'}}>{item.config.name}{item.label ? '-' + item.label : ''}</span>中表单<span style={{color: 'orange', margin: '0 2px 0 2px'}}>{_forms.join('、')}</span>无效
            </div>)
          }
        }
      })
    }
    formErrors = formErrors.length ? formErrors : ''
    Modal.confirm({
      content: `当前菜单共${this.sqlList.length}个组件,${sqls.length}项脚本需要检验${sqls.length > 20 ? ',时间大概需要' + parseInt(sqls.length / 2) + '秒' : ''}。`,
      content: <div style={{paddingLeft: '38px'}}>
        {`当前菜单共${this.sqlList.length}个组件,${sqls.length}项脚本需要检验${sqls.length > 20 ? ',时间大概需要' + parseInt(sqls.length / 2) + '秒' : ''}。`}
        {formErrors}
      </div>,
      onOk() {
        that.setState({visible: true, status: 'loading', sqlList: fromJS(sqls).toJS(), successIds: [], errorIds: [], errorMsg: {}, execId: ''}, () => {
          that.roopSql()
@@ -354,6 +428,18 @@
            if (!group.subButton.Ot) {
              group.subButton.Ot = item.wrap.datatype === 'static' ? 'notRequired' : 'requiredSgl'
            }
            if (group.fields) {
              let cells = group.fields.filter(cell => cell.type === 'linkMain')
              if (cells.length) {
                this.linkMain.push({
                  config: item,
                  forms: cells
                })
              }
            }
            let res = this.resetButton(item, group.subButton, process, group)
            if (res) {
@@ -380,6 +466,19 @@
  resetButton = (item, cell, process, group, isback) => {
    let sql = ''
    if (cell.OpenType === 'pop' || (cell.OpenType === 'funcbutton' && cell.execMode === 'pop')) {
      if (cell.modal && cell.modal.fields.length) {
        let cells = cell.modal.fields.filter(n => n.type === 'linkMain')
        if (cells.length) {
          this.linkMain.push({
            config: item,
            forms: cells,
            label: cell.label
          })
        }
      }
    }
    if (['exec', 'prompt', 'pop', 'form', 'formSubmit'].includes(cell.OpenType)) {
      if (cell.intertype === 'system' || cell.procMode === 'system') { // 系统接口
        if (item.subtype === 'dualdatacard' && isback) {
@@ -430,7 +529,7 @@
      }
    } else if (cell.OpenType === 'excelIn') {
      if (cell.intertype === 'system') {
        sql = this.getExcelInSql(cell)
        sql = this.getExcelInSql(cell, process)
      }
    } else if (cell.OpenType === 'excelOut') {
      if (cell.intertype === 'system' && cell.verify && cell.verify.dataType === 'custom') {
@@ -439,6 +538,12 @@
    } else if (cell.OpenType === 'funcbutton') {
      if (cell.funcType === 'print') {
      } else if ((cell.funcType === 'refund' || cell.funcType === 'pay') && cell.payMode === 'system') {
        sql = this.getPaySql(cell, item)
      }
    } else if (cell.OpenType === 'innerpage' || cell.OpenType === 'outerpage') {
      if (cell.pageTemplate === 'pay' && cell.payMode === 'system') {
        sql = this.getPaySql(cell, item)
      }
    } else if (cell.OpenType === 'popview') {
      if (cell.config && cell.config.components) {
@@ -615,8 +720,10 @@
            _item.type = 'text'
          } else if (_item.type === 'number' || _item.type === 'rate') {
            _item.fieldlen = item.decimal || 0
          } else  if (_item.type === 'date') {
          } else if (_item.type === 'date') {
            _item.type = item.declareType === 'nvarchar(50)' ? 'text' : 'date'
          } else if (_item.type === 'datetime') {
            _item.type = 'date'
          } else if (item.declare === 'decimal') {
            _item.type = 'number'
            _item.fieldlen = item.decimal || 0
@@ -662,8 +769,10 @@
            _item.type = 'text'
          } else if (_item.type === 'number' || _item.type === 'rate') {
            _item.fieldlen = item.decimal || 0
          } else  if (_item.type === 'date') {
          } else if (_item.type === 'date') {
            _item.type = item.declareType === 'nvarchar(50)' ? 'text' : 'date'
          } else if (_item.type === 'datetime') {
            _item.type = 'date'
          } else if (item.declare === 'decimal') {
            _item.type = 'number'
            _item.fieldlen = item.decimal || 0
@@ -1580,12 +1689,54 @@
      ${_uniquesql}
      ${_prevCustomScript}
      ${_insert}
      ${_backCustomScript}
      ${_insert}`
      drop table #${sheet}
      aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
    if (btn.workFlow === 'true' && process) {
      if (btn.flowSql === 'true') {
        sql += `
        /* 工作流默认sql */
        insert into s_my_works_flow (works_flow_id,works_flow_code,works_flow_name,works_flow_param,status,statusname,work_group,works_flow_detail_id,work_grade,bid,createuserid,CreateUser,CreateStaff,upid)
        select jskey,@works_flow_code@,@works_flow_name@,@works_flow_param@,@status@,@statusname@,@work_group@,@works_flow_detail_id@,@work_grade@,@bid@,@UserID@,@UserName,@FullName,@time_id@
        from #${sheet}
        insert into s_my_works_flow_log (works_flow_id,works_flow_code,works_flow_name,works_flow_param,status,statusname,works_flow_detail_id,work_group,work_grade,bid,createuserid,CreateUser,CreateStaff,upid)
        select jskey,@works_flow_code@,@works_flow_name@ ,@works_flow_param@,@status@,@statusname@,@works_flow_detail_id@,@work_group@,@work_grade@,@bid@,@UserID@,@UserName,@FullName,@time_id@
        from #${sheet}
        insert into s_my_works_flow_notice (works_flow_id,works_flow_code,works_flow_detail_id,userid,notice_type,createuserid,CreateUser,CreateStaff,upid)
        select jskey,@works_flow_code@,@works_flow_detail_id@,@userid@,@start_type@,@userid@,@UserName,@FullName,@time_id@
        from #${sheet}
        insert into s_my_works_flow_role (works_flow_id,works_flow_code,userid,works_flow_detail_id,createuserid,CreateUser,CreateStaff,upid,typecharone)
        select jskey,@works_flow_code@,@userid@,@works_flow_detail_id@,@userid@,@UserName,@FullName,@time_id@,'begin'
        from #${sheet}
        `
      }
      sql += `
        ${_backCustomScript}
        drop table #${sheet}
        aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
      sql = sql.replace(/@start_type@/ig, `'开始'`)
      sql = sql.replace(/@works_flow_code@/ig, `'mk'`)
      sql = sql.replace(/@works_flow_name@/ig, `'mk'`)
      sql = sql.replace(/@works_flow_param@/ig, `''`)
      sql = sql.replace(/@works_flow_detail_id@/ig, `'0'`)
      sql = sql.replace(/@status@/ig, `'888'`)
      sql = sql.replace(/@statusname@/ig, `'结束'`)
      sql = sql.replace(/@work_group@/ig, `'mk'`)
      sql = sql.replace(/@work_grade@/ig, `'0'`)
    } else {
      sql += `
        ${_backCustomScript}
        drop table #${sheet}
        aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
    }
    return sql
  }
@@ -1854,6 +2005,54 @@
    return sql
  }
  getPaySql = (btn, component) => {
    let sysfields = ['username', 'fullname', 'roleid', 'mk_departmentcode', 'mk_organization', 'mk_user_type', 'mk_nation', 'mk_province', 'mk_city', 'mk_district', 'mk_address', 'tbid', 'bid']
    let _declare = []
    let _select = []
    component.columns.forEach(_f => {
      if (sysfields.includes(_f.field.toLowerCase())) return
      if (/decimal|int/ig.test(_f.datatype)) {
        _select.push(`@${_f.field}=1`)
      } else if (/date/ig.test(_f.datatype)) {
        _select.push(`@${_f.field}='1949-10-01'`)
      } else {
        _select.push(`@${_f.field}=''`)
      }
      _declare.push(`@${_f.field} ${_f.datatype}`)
    })
    _declare = _declare.join(', ')
    _select = _select.join(', ')
    let _sql = `Declare @UserName nvarchar(50), @FullName nvarchar(50), @RoleID nvarchar(512), @mk_departmentcode nvarchar(512), @mk_organization nvarchar(512), @mk_user_type nvarchar(20), @mk_nation nvarchar(50), @mk_province nvarchar(50), @mk_city nvarchar(50), @mk_district nvarchar(50), @mk_address nvarchar(100), @ErrorCode nvarchar(50), @retmsg nvarchar(4000), @bid nvarchar(50), @tbid nvarchar(50), ${_declare}
    Select @UserName='', @FullName='', @RoleID='', @mk_departmentcode='', @mk_organization='', @mk_user_type='', @mk_nation='', @mk_province='', @mk_city='', @mk_district='', @mk_address='', @ErrorCode='', @retmsg='', @bid='', ${_select}
    `
    btn.verify.scripts.forEach(item => {
      if (item.status === 'false') return
      _sql += `
      ${item.sql}
      `
    })
    if (btn.output) {
      _sql += `
        aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg,${btn.output} as mk_b_id`
    } else {
      _sql += `
        aaa: select @ErrorCode as ErrorCode,@retmsg as retmsg`
    }
    _sql = _sql.replace(/@typename@/ig, `'typename'`)
    _sql = _sql.replace(/@\$|\$@/ig, '').replace(/@datam@/ig, `''`)
    return _sql
  }
  formatDataSource = (item, regs, mainSearch = []) => {
    if (!item.setting || item.setting.interType !== 'system') return false
    
@@ -1914,7 +2113,7 @@
    item.setting.dataresource = _dataresource
    item.setting.customScript = _customScript
    let custompage = /@pageSize@|@orderBy@/i.test(_dataresource + _customScript)
    let custompage = /@pageSize@|@orderBy@|@mk_total/i.test(_dataresource + _customScript)
    if (_dataresource) {
      if (custompage) {
@@ -1967,10 +2166,16 @@
    )
    if (item.hasExtend) {
      regs.push({reg: /@mk_time@/ig, value: '2024-04-29 17:20:00'})
      regoptions.push({reg: /@mk_time@/ig, value: '2024-04-29 17:20:00'})
    }
    if (item.type === 'calendar') {
      regoptions.push({ reg: /@mk_year@/ig, value: '2024' })
    }
    if (window.GLOB.getLocation) {
      regoptions.push(
        {reg: /@mk_longitude@/ig, value: 0},
        {reg: /@mk_latitude@/ig, value: 0}
      )
    }
    regoptions.forEach(cell => {
@@ -1998,7 +2203,7 @@
    this.setState({status: this.verSqls.length > 0 ? 'loading' : 'over', execId: item.uuid})
    console.info(`/* 组件:${item.name}  检验项:${item.label} */`)
    window.mkInfo(`/* 组件:${item.name}  检验项:${item.label} */`)
    Api.sDebug(item.sql).then(result => {
      if (result.status || result.ErrCode === '-2') {