From 8cdfdd9914d1c4f6cd59176d61869522f51f39e4 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期日, 10 十月 2021 13:53:57 +0800
Subject: [PATCH] 2021-10-10

---
 src/tabviews/custom/components/table/edit-table/normalTable/index.jsx |  496 ++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 454 insertions(+), 42 deletions(-)

diff --git a/src/tabviews/custom/components/table/edit-table/normalTable/index.jsx b/src/tabviews/custom/components/table/edit-table/normalTable/index.jsx
index dfdbc74..0881563 100644
--- a/src/tabviews/custom/components/table/edit-table/normalTable/index.jsx
+++ b/src/tabviews/custom/components/table/edit-table/normalTable/index.jsx
@@ -1,9 +1,12 @@
 import React, {Component} from 'react'
 import PropTypes from 'prop-types'
 import { is, fromJS } from 'immutable'
-import { Table, Typography, Icon, Switch, Input, InputNumber, Tooltip } from 'antd'
+import { Table, Typography, Icon, Switch, Modal, Input, InputNumber, Tooltip, Button, notification, message } from 'antd'
+import moment from 'moment'
 
+import Api from '@/api'
 import asyncComponent from '@/utils/asyncComponent'
+import Utils, { getEditTableSql } from '@/utils/utils.js'
 import MKEmitter from '@/utils/events.js'
 import zhCN from '@/locales/zh-CN/main.js'
 import enUS from '@/locales/en-US/main.js'
@@ -11,6 +14,7 @@
 import './index.scss'
 
 const { Paragraph } = Typography
+const { confirm } = Modal
 const CardCellComponent = asyncComponent(() => import('@/tabviews/custom/components/card/cardcellList'))
 
 class BodyRow extends React.Component {
@@ -203,8 +207,9 @@
       MKEmitter.emit('tdFocus', col.enter + record.$Index)
     }
 
-    let _record = {...record, [col.field]: value}
-    MKEmitter.emit('changeRecord', _record)
+    if (value !== record[col.field]) {
+      MKEmitter.emit('changeRecord', col.tableId, {...record, [col.field]: value})
+    }
   }
 
   focus = () => {
@@ -239,8 +244,9 @@
 
     this.setState({editing: false})
 
-    let _record = {...record, [col.field]: value}
-    MKEmitter.emit('changeRecord', _record)
+    if (value !== record[col.field]) {
+      MKEmitter.emit('changeRecord', col.tableId, {...record, [col.field]: value})
+    }
   }
   
   onChange = (val) => {
@@ -375,6 +381,11 @@
       children = (
         <CardCellComponent data={record} cards={config} elements={col.elements}/>
       )
+    } else if (col.type === 'operation') {
+      style.padding = '0px 5px'
+      children = (
+        <Button type="link" style={{color: 'rgb(255, 77, 79)', backgroundColor: 'transparent'}} onClick={() => MKEmitter.emit('delRecord', col.tableId, {...record})}>鍒犻櫎</Button>
+      )
     }
 
     return (<td className={className} style={style}>{children}</td>)
@@ -389,7 +400,7 @@
     columns: PropTypes.array,        // 琛ㄦ牸鍒�
     lineMarks: PropTypes.any,        // 琛屾爣璁�
     fields: PropTypes.array,         // 缁勪欢瀛楁闆�
-    BData: PropTypes.any,            // 涓昏〃鏁版嵁
+    BID: PropTypes.any,              // 涓昏〃ID
     data: PropTypes.any,             // 琛ㄦ牸鏁版嵁
     total: PropTypes.any,            // 鎬绘暟
     loading: PropTypes.bool,         // 琛ㄦ牸鍔犺浇涓�
@@ -399,24 +410,42 @@
   state = {
     dict: sessionStorage.getItem('lang') !== 'en-US' ? zhCN : enUS,
     data: [],
+    edData: [],
+    edColumns: [],
     tableId: '',          // 琛ㄦ牸ID
     pageIndex: 1,         // 鍒濆椤甸潰绱㈠紩
     pageSize: 10,         // 姣忛〉鏁版嵁鏉℃暟
     columns: null,        // 鏄剧ず鍒�
+    fields: [],
     pickup: false,        // 鏀惰捣鏈�夋嫨椤�
-    orderfields: {}       // 鎺掑簭id涓巉ield杞崲
+    orderfields: {},      // 鎺掑簭id涓巉ield杞崲
+    loading: false
   }
 
   UNSAFE_componentWillMount () {
     const { setting, fields, columns, data } = this.props
     let orderfields = {}
     let initEditLine = null
+    let edColumns = []
+    let tableId = (() => {
+      let uuid = []
+      let _options = 'abcdefghigklmnopqrstuv'
+      for (let i = 0; i < 19; i++) {
+        uuid.push(_options.substr(Math.floor(Math.random() * 0x20), 1))
+      }
+      return uuid.join('')
+    }) ()
 
-    let _columns = columns.map(item => {
+    let _columns = []
+    columns.forEach(item => {
+      if (item.Hide === 'true') return
       if (item.type === 'index') {
         item.field = '$Index'
         item.type = 'text'
       }
+
+      item.tableId = tableId
+
       if (!initEditLine && item.editable === 'true') {
         initEditLine = item
       }
@@ -429,7 +458,7 @@
         orderfields[item.uuid] = item.field
       }
 
-      return {
+      let _item = {
         align: item.Align,
         dataIndex: item.uuid,
         title: item.label,
@@ -441,16 +470,26 @@
           config: item.type === 'custom' || item.type === 'action' ? {setting, columns: fields} : null,
         })
       }
+
+      if (item.type !== 'action') {
+        let _copy = fromJS(_item).toJS()
+        _copy.sorter = false
+        edColumns.push(_copy)
+      }
+      _columns.push(_item)
     })
 
-    let tableId = (() => {
-      let uuid = []
-      let _options = 'abcdefghigklmnopqrstuv'
-      for (let i = 0; i < 19; i++) {
-        uuid.push(_options.substr(Math.floor(Math.random() * 0x20), 1))
-      }
-      return uuid.join('')
-    }) ()
+    edColumns.push({
+      align: 'center',
+      dataIndex: 'mkoperation',
+      title: '鎿嶄綔',
+      sorter: false,
+      width: 100,
+      onCell: record => ({
+        record,
+        col: {type: 'operation', tableId: tableId},
+      })
+    })
 
     if (setting.borderColor) { // 杈规棰滆壊
       let style = `#${tableId} table, #${tableId} tr, #${tableId} th, #${tableId} td {border-color: ${setting.borderColor}}`
@@ -462,6 +501,7 @@
     this.setState({
       data,
       columns: _columns,
+      edColumns,
       tableId,
       orderfields,
       initEditLine
@@ -473,8 +513,28 @@
   }
 
   componentDidMount () {
-    MKEmitter.addListener('resetTable', this.resetTable)
+    const { fields, columns } = this.props
+
+    let _fields = []
+
+    let fieldType = {}
+    fields.forEach(item => {
+      fieldType[item.field] = item.datatype
+    })
+
+    columns.forEach(col => {
+      if (!col.field || col.type === 'index') return
+
+      _fields.push({...col, datatype: fieldType[col.field] || 'Nvarchar(50)'})
+    })
+
+    this.setState({
+      fields: _fields,
+    })
+
     MKEmitter.addListener('nextLine', this.nextLine)
+    MKEmitter.addListener('delRecord', this.delRecord)
+    MKEmitter.addListener('resetTable', this.resetTable)
     MKEmitter.addListener('changeRecord', this.changeRecord)
   }
 
@@ -485,8 +545,9 @@
     this.setState = () => {
       return
     }
-    MKEmitter.removeListener('resetTable', this.resetTable)
     MKEmitter.removeListener('nextLine', this.nextLine)
+    MKEmitter.removeListener('delRecord', this.delRecord)
+    MKEmitter.removeListener('resetTable', this.resetTable)
     MKEmitter.removeListener('changeRecord', this.changeRecord)
   }
 
@@ -497,16 +558,88 @@
   }
   
   nextLine = (col, index) => {
-    const { data, initEditLine } = this.state
+    const { setting } = this.props
+    const { edData, initEditLine, tableId } = this.state
+
+    if (col.tableId !== tableId) return
+
     index = +index
 
-    if (index < data.length && initEditLine) {
+    if (index < edData.length && initEditLine) {
       MKEmitter.emit('tdFocus', initEditLine.uuid + (index + 1))
+    } else if (col.footEnter === 'add' && setting.addable === 'true') {
+      setTimeout(() => {
+        this.plusLine(initEditLine)
+      }, 10)
+    } else if (col.footEnter === 'sub') {
+      setTimeout(() => {
+        this.checkData()
+      }, 10)
     }
   }
 
-  changeRecord = (record) => {
-    let _data = this.state.data.map(item => {
+  plusLine = (initEditLine) => {
+    const { edData, fields } = this.state
+
+    let item = {...edData[edData.length - 1]}
+
+    item.key = item.key + 1
+    item.$$uuid = '$new'
+    item.$Index = item.key + 1 + ''
+
+    fields.forEach(col => {
+      item[col.field] = item[col.field] !== undefined ? item[col.field] : ''
+
+      if (col.initval !== '$copy') {
+        item[col.field] = col.initval
+      }
+      if (col.type === 'number') {
+        item[col.field] = +item[col.field]
+        if (isNaN(item[col.field])) {
+          item[col.field] = 0
+        }
+      }
+    })
+
+    this.setState({edData: [...edData, item]}, () => {
+      MKEmitter.emit('tdFocus', initEditLine.uuid + item.$Index)
+    })
+  }
+
+  delRecord = (id, record) => {
+    const { tableId, edData } = this.state
+
+    if (id !== tableId) return
+
+    let _data = []
+
+    if (record.$$uuid === '$new') {
+      _data = edData.filter(item => item.$Index !== record.$Index)
+      _data = _data.map((item, index) => {
+        item.key = index
+        item.$Index = 1 + index + ''
+        return item
+      })
+    } else {
+      _data = edData.map(item => {
+        if (item.$Index === record.$Index) {
+          record.$deleted = true
+          return record
+        } else {
+          return item
+        }
+      })
+    }
+
+    this.setState({edData: _data})
+  }
+
+  changeRecord = (id, record) => {
+    const { tableId } = this.state
+
+    if (id !== tableId) return
+
+    let _data = this.state.edData.map(item => {
       if (item.$Index === record.$Index) {
         return record
       } else {
@@ -514,7 +647,255 @@
       }
     })
 
-    this.setState({data: _data})
+    this.setState({edData: _data})
+  }
+
+  addLine = () => {
+    const { BID } = this.props
+    const { edData, fields } = this.state
+
+    let item = {}
+    if (edData.length > 0) {
+      item = {...edData[edData.length - 1]}
+      item.key = item.key + 1
+      item.$$uuid = '$new'
+      item.$Index = item.key + 1 + ''
+    } else {
+      item.key = 0
+      item.$$uuid = '$new'
+      item.$Index = item.key + 1 + ''
+      item.$$BID = BID || ''
+    }
+
+    fields.forEach(col => {
+      item[col.field] = item[col.field] !== undefined ? item[col.field] : ''
+
+      if (col.initval !== '$copy') {
+        item[col.field] = col.initval
+      }
+      if (col.type === 'number') {
+        item[col.field] = +item[col.field]
+        if (isNaN(item[col.field])) {
+          item[col.field] = 0
+        }
+      }
+    })
+
+    this.setState({edData: [...edData, item]})
+  }
+
+  checkData = () => {
+    const { edData, fields } = this.state
+
+    if (edData.length === 0) {
+      notification.warning({
+        top: 92,
+        message: '鎻愪氦鏁版嵁涓嶅彲涓虹┖锛�',
+        duration: 5
+      })
+      return
+    }
+    let err = ''
+    let data = fromJS(edData).toJS().map(item => {
+      let line = []
+      fields.forEach(col => {
+        if (col.editable !== 'true' || item.$deleted) {
+          if (col.type === 'number') {
+            item[col.field] = +item[col.field]
+            if (isNaN(item[col.field])) {
+              item[col.field] = 0
+            }
+          } else {
+            item[col.field] = item[col.field] !== undefined ? (item[col.field] + '') : ''
+          }
+          return
+        }
+        if (col.type === 'text') {
+          let val = item[col.field] !== undefined ? (item[col.field] + '') : ''
+          if (col.required === 'true' && !val) {
+            line.push(`${col.label}涓嶅彲涓虹┖`)
+          }
+          item[col.field] = val
+        } else if (col.type === 'number') {
+          let val = item[col.field]
+          if (!val && val !== 0) {
+            line.push(`${col.label}涓嶅彲涓虹┖`)
+            return
+          }
+          val = +val
+          if (isNaN(val)) {
+            line.push(`${col.label}鏁版嵁鏍煎紡閿欒`)
+            return
+          }
+
+          val = +val.toFixed(col.decimal || 0)
+          
+          if (typeof(col.max) === 'number' && val > col.max) {
+            line.push(`${col.label}涓嶅彲澶т簬${col.max}`)
+          } else if (typeof(col.min) === 'number' && val < col.min) {
+            line.push(`${col.label}涓嶅彲灏忎簬${col.min}`)
+          }
+
+          item[col.field] = val
+        }
+      })
+
+      if (line.length > 0) {
+        err += `绗�${item.$Index}琛岋細` + line.join('锛�') + '锛�'
+      }
+
+      return item
+    })
+
+    if (err) {
+      notification.warning({
+        top: 92,
+        message: err,
+        duration: 5
+      })
+    } else {
+      this.submit(data)
+    }
+  }
+
+  submit = (data) => {
+    const { submit, BID } = this.props
+    const { fields } = this.state
+
+    let result = getEditTableSql(submit, data, fields)
+
+    let param = {
+      excel_in: result.lines,
+      BID: BID || ''
+    }
+
+    this.setState({
+      loading: true
+    })
+
+    if (submit.intertype === 'system') { // 绯荤粺瀛樺偍杩囩▼
+      param.func = 'sPC_TableData_InUpDe'
+      
+      if (sessionStorage.getItem('dataM') === 'true') { // 鏁版嵁鏉冮檺
+        result.sql = result.sql.replace(/\$@/ig, '/*')
+        result.sql = result.sql.replace(/@\$/ig, '*/')
+        result.bottom = result.bottom.replace(/\$@/ig, '/*')
+        result.bottom = result.bottom.replace(/@\$/ig, '*/')
+      } else {
+        result.sql = result.sql.replace(/@\$|\$@/ig, '')
+        result.bottom = result.bottom.replace(/@\$|\$@/ig, '')
+      }
+      
+      param.excel_in_type = 'true'
+      param.LText1 = Utils.formatOptions(result.insert)
+      param.LText2 = Utils.formatOptions(result.bottom)
+      param.LText = Utils.formatOptions(result.sql)
+      param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
+      param.secretkey = Utils.encrypt(param.LText, param.timestamp)
+
+      param.menuname = submit.logLabel
+
+      if (window.GLOB.probation) {
+        param.s_debug_type = 'Y'
+      }
+
+      Api.genericInterface(param).then((res) => {
+        if (res.status) {
+          this.execSuccess(res)
+        } else {
+          this.execError(res)
+        }
+      }, () => {
+        this.execError({})
+      })
+    } else if (submit.intertype === 'inner' && submit.innerFunc) { // 鑷畾涔夊瓨鍌ㄨ繃绋�
+      param.func = submit.innerFunc
+
+      Api.genericInterface(param).then((res) => {
+        if (res.status) {
+          this.execSuccess(res)
+        } else {
+          this.execError(res)
+        }
+      }, () => {
+        this.execError({})
+      })
+    }
+  }
+
+  execSuccess = (res) => {
+    const { submit } = this.props
+
+    if (res && res.ErrCode === 'S') { // 鎵ц鎴愬姛
+      notification.success({
+        top: 92,
+        message: res.ErrMesg || this.state.dict['main.action.confirm.success'],
+        duration: submit.stime ? submit.stime : 2
+      })
+    } else if (res && res.ErrCode === 'Y') { // 鎵ц鎴愬姛
+      Modal.success({
+        title: res.ErrMesg || this.state.dict['main.action.confirm.success']
+      })
+    } else if (res && res.ErrCode === '-1') { // 瀹屾垚鍚庝笉鎻愮ず
+
+    }
+
+    this.setState({
+      loading: false
+    })
+
+    if (submit.execSuccess !== 'never') {
+      this.repick()
+      MKEmitter.emit('refreshByButtonResult', submit.$menuId, submit.execSuccess, submit)
+    }
+  }
+
+  execError = (res) => {
+    const { submit } = this.props
+
+    if (res.ErrCode === 'E') {
+      Modal.error({
+        title: res.message || res.ErrMesg,
+      })
+    } else if (res.ErrCode === 'N') {
+      notification.error({
+        top: 92,
+        message: res.message || res.ErrMesg,
+        duration: submit.ntime ? submit.ntime : 10
+      })
+    } else if (res.ErrCode === 'F') {
+      notification.error({
+        className: 'notification-custom-error',
+        top: 92,
+        message: res.message || res.ErrMesg,
+        duration: submit.ftime ? submit.ftime : 10
+      })
+    } else if (res.ErrCode === 'NM') {
+      message.error(res.message || res.ErrMesg)
+    }
+    
+    this.setState({
+      loading: false
+    })
+
+    if (submit.execError !== 'never') {
+      this.repick()
+      MKEmitter.emit('refreshByButtonResult', submit.$menuId, submit.execError, submit)
+    }
+  }
+
+  repick = () => {
+    const { data } = this.state
+
+    this.setState({
+      data: [],
+      edData: [],
+      pickup: false,
+    }, () => {
+      this.setState({
+        data: data,
+      })
+    })
   }
 
   changeTable = (pagination, filters, sorter) => {
@@ -522,8 +903,7 @@
 
     this.setState({
       pageIndex: pagination.current,
-      pageSize: pagination.pageSize,
-      pickup: false
+      pageSize: pagination.pageSize
     })
 
     sorter.field = orderfields[sorter.field] || ''
@@ -536,27 +916,54 @@
 
     if (id !== MenuID) return
 
-    if (repage === 'false') {
+    if (repage !== 'false') {
       this.setState({
-        pickup: false
-      })
-    } else {
-      this.setState({
-        pageIndex: 1,
-        pickup: false
+        pageIndex: 1
       })
     }
   }
 
   pickupChange = () => {
-    this.setState({
-      pickup: !this.state.pickup
-    })
+    const { data } = this.state
+
+    let pickup = !this.state.pickup
+
+    if (!pickup && !is(fromJS(data), fromJS(this.state.edData))) {
+      const _this = this
+      confirm({
+        title: '鏁版嵁宸蹭慨鏀癸紝纭畾鏀惧純淇濆瓨鍚楋紵',
+        onOk() {
+          _this.setState({
+            data: [],
+            edData: [],
+            pickup
+          }, () => {
+            _this.setState({
+              data: data,
+              edData: pickup ? fromJS(data).toJS() : []
+            })
+          })
+        },
+        onCancel() {}
+      })
+    } else {
+      this.setState({
+        data: [],
+        edData: [],
+        pickup,
+        loading: false
+      }, () => {
+        this.setState({
+          data: data,
+          edData: pickup ? fromJS(data).toJS() : []
+        })
+      })
+    }
   }
 
   render() {
     const { setting, statFValue, lineMarks } = this.props
-    const { pickup, tableId, data } = this.state
+    const { pickup, tableId, data, edData, columns, edColumns, loading } = this.state
 
     const components = {
       body: {
@@ -566,14 +973,17 @@
     }
 
     // 鏁版嵁鏀惰捣鏃讹紝杩囨护宸查�夋暟鎹�
-    let _data = data || []
+    let _data = data
+    let _columns = columns
 
     if (pickup) {
+      _data = edData
       _data = _data.filter(item => !item.$deleted)
+      _columns = edColumns
     }
-    
+
     let _pagination = false
-    if (setting.laypage !== 'false' && setting.laypage !== false) {
+    if (!pickup && setting.laypage !== 'false' && setting.laypage !== false) {
       _pagination = {
         current: this.state.pageIndex,
         pageSize: this.state.pageSize,
@@ -586,7 +996,7 @@
 
     let _footer = ''
 
-    if (statFValue && statFValue.length > 0) {
+    if (!pickup && statFValue && statFValue.length > 0) {
       _footer = statFValue.map(f => `${f.label}(鍚堣)锛�${f.value}`).join('锛�')
     }
 
@@ -595,12 +1005,13 @@
     return (
       <div className={`edit-custom-table ${pickup ? 'editable' : ''} ${setting.tableHeader || ''} ${height ? 'fixed-height' : ''} ${setting.mode || ''}`} id={tableId}>
         <Switch title="缂栬緫" className="main-pickup" checkedChildren="寮�" unCheckedChildren="鍏�" checked={pickup} onChange={this.pickupChange} />
+        {pickup ? <Button onClick={() => setTimeout(() => {this.checkData()}, 10)} loading={loading} className="submit-table" type="link">鎻愪氦</Button> : null}
         <Table
           components={components}
           style={setting.style}
           size={setting.size || 'middle'}
           bordered={setting.bordered !== 'false'}
-          columns={this.state.columns}
+          columns={_columns}
           dataSource={_data}
           loading={this.props.loading}
           scroll={{ x: '100%', y: height }}
@@ -614,6 +1025,7 @@
           pagination={_pagination}
         />
         {_footer ? <div className={'normal-table-footer ' + (_pagination ? 'pagination' : '')}>{_footer}</div> : null}
+        {pickup && setting.addable === 'true' ? <Button onClick={this.addLine} style={{display: 'block', width: '100%', color: '#26C281'}} icon="plus" type="link"></Button> : null}
       </div>
     )
   }

--
Gitblit v1.8.0