From fa381753ef2a2b25b1c0722549ac17e333da79be Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期二, 06 九月 2022 22:50:54 +0800
Subject: [PATCH] 2022-09-06

---
 src/tabviews/zshare/mutilform/index.jsx |  196 +++++++++++++++++++++++++++++++++++--------------
 1 files changed, 140 insertions(+), 56 deletions(-)

diff --git a/src/tabviews/zshare/mutilform/index.jsx b/src/tabviews/zshare/mutilform/index.jsx
index 1db51b6..710d82e 100644
--- a/src/tabviews/zshare/mutilform/index.jsx
+++ b/src/tabviews/zshare/mutilform/index.jsx
@@ -25,11 +25,12 @@
 const MKTextArea = asyncComponent(() => import('./mkTextArea'))
 const MKFileUpload = asyncComponent(() => import('../fileupload'))
 const MKColor = asyncComponent(() => import('./mkColor'))
+const MkFormula = asyncComponent(() => import('./mkFormula'))
+const MkCascader = asyncComponent(() => import('./mkCascader'))
 const MKEditor = asyncComponent(() => import('@/components/editor'))
 
 class MainSearch extends Component {
   static propTpyes = {
-    menuType: PropTypes.object,  // 鑿滃崟绫诲瀷锛屾槸鍚︿负HS
     action: PropTypes.object,    // 鎸夐挳淇℃伅銆佽〃鍗曞垪琛�
     data: PropTypes.any,         // 琛ㄦ牸鏁版嵁
     BID: PropTypes.any,          // 涓昏〃ID
@@ -44,8 +45,10 @@
   record = {}
 
   componentDidMount () {
-    const { data, BData, action } = this.props
+    const { action } = this.props
 
+    let data = {}
+    let BData = {}
     let linkFields = {} // 鍏宠仈鑿滃崟
     let controlFields = {} // 鎺у埗琛ㄥ崟
     let deForms = []    // 闇�瑕佸姩鎬佽幏鍙栦笅鎷夎彍鍗曠殑琛ㄥ崟
@@ -54,6 +57,17 @@
     let formlist = fromJS(action.fields).toJS()
     let fieldMap = new Map()
     let check = action.setting.formType === 'check'
+
+    if (this.props.data) {
+      Object.keys(this.props.data).forEach(key => {
+        data[key.toLowerCase()] = this.props.data[key]
+      })
+    }
+    if (this.props.BData) {
+      Object.keys(this.props.BData).forEach(key => {
+        BData[key.toLowerCase()] = this.props.BData[key]
+      })
+    }
 
     formlist = formlist.filter(item => {
       if (item.supField) { // 澶氬眰琛ㄥ崟鎺у埗
@@ -77,10 +91,17 @@
         linkFields[item.linkField].push({field: item.field, uuid: item.uuid})
       }
 
-      if (item.type === 'split') return true
+      if (item.style) {
+        delete item.style.marginTop
+        delete item.style.marginBottom
+        delete item.style.marginLeft
+        delete item.style.marginRight
+      }
+
+      if (item.type === 'split' || item.type === 'formula') return true
       if (item.type === 'hint') {
-        if (item.field && data && data[item.field]) {
-          item.message = data[item.field]
+        if (item.field && data[item.field.toLowerCase()]) {
+          item.message = data[item.field.toLowerCase()]
         }
         delete item.field
         return true
@@ -91,7 +112,12 @@
         item.precision = 'second'
       }
 
-      if (!item.field || !['text', 'number', 'switch', 'rate', 'select', 'link', 'linkMain', 'funcvar', 'date', 'datemonth', 'radio', 'checkbox', 'checkcard', 'fileupload', 'textarea', 'multiselect', 'brafteditor', 'color'].includes(item.type)) return false
+      if (!item.field || !['text', 'number', 'switch', 'rate', 'select', 'link', 'cascader', 'linkMain', 'funcvar', 'date', 'datemonth', 'radio', 'checkbox', 'checkcard', 'fileupload', 'textarea', 'multiselect', 'brafteditor', 'color'].includes(item.type)) return false
+
+      if (/^\s+$/.test(item.label)) {
+        item.style = item.style || {}
+        item.style.color = 'transparent'
+      }
 
       // 鏁版嵁鑷姩濉厖
       let readin = item.readin !== 'false'
@@ -100,6 +126,8 @@
       item.writein = item.writein !== 'false'
       item.hidden = item.hidden === 'true'
       item.fieldlength = item.fieldlength || 50
+
+      let key = item.field.toLowerCase()
 
       if (item.type === 'funcvar') {
         readin = false
@@ -111,14 +139,8 @@
         item.initval = item.initval || 0
       }
 
-      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect'].includes(item.type)) {
+      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect', 'cascader'].includes(item.type)) {
         item.options = item.options || []
-        // item.options = item.options.map(cell => {
-        //   cell.value = cell.Value
-        //   cell.label = cell.Text
-
-        //   return cell
-        // })
         item.options = item.options.filter(cell => {
           cell.value = cell.Value
           cell.label = cell.Text
@@ -138,11 +160,11 @@
 
       let newval = '$empty'
 
-      if (readin && data && data.hasOwnProperty(item.field)) {
-        newval = data[item.field]
+      if (readin && data.hasOwnProperty(key)) {
+        newval = data[key]
       }
       if (item.type === 'linkMain') {
-        newval = BData && BData[item.field] ? BData[item.field] : '$empty'
+        newval = BData[key] || '$empty'
       } else if (item.type === 'date') { // 鏃堕棿鎼滅储
         let format = 'YYYY-MM-DD'
         let _format = 'YYYY-MM-DD HH:mm:ss'
@@ -199,7 +221,7 @@
         item.initval = ''
       }
 
-      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect'].includes(item.type) && item.resourceType === '1') {
+      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect', 'cascader'].includes(item.type) && item.resourceType === '1') {
         deForms.push(item)
       } else if (item.type === 'rate') {
         item.rateCount = item.rateCount || 5
@@ -227,7 +249,15 @@
         }
         let _rules = [{
           pattern: /^[^']*$/ig,
-          message: formRule.input.quotemsg
+          message: '涓嶅彲浣跨敤鑻辨枃鐘舵�佺殑鍗曞紩鍙凤紒'
+        }, {
+          validator: (rule, value, callback) => {
+            if (/--/ig.test(value)) {
+              callback('涓嶅彲浣跨敤 -- 锛�')
+            } else {
+              callback()
+            }
+          }
         }, {
           required: item.required === 'true',
           message: item.label + '涓嶅彲涓虹┖!'
@@ -243,27 +273,37 @@
         if (item.regular) {
           if (item.regular === 'number') {
             _rules.push({
-              pattern: /^[0-9.-]*$/ig,
+              pattern: /^[0-9.-]*$/,
               message: formRule.input.numbermsg
             })
           } else if (item.regular === 'letter') {
             _rules.push({
-              pattern: /^[a-zA-Z]*$/ig,
+              pattern: /^[a-zA-Z]*$/,
               message: formRule.input.lettermsg
+            })
+          } else if (item.regular === 'letter_number') {
+            _rules.push({
+              pattern: /^[a-zA-Z0-9]*$/,
+              message: '璇疯緭鍏ユ暟瀛楁垨瀛楁瘝'
             })
           } else if (item.regular === 'letter&number') {
             _rules.push({
-              pattern: /^[a-zA-Z0-9]*$/ig,
-              message: formRule.input.letternummsg
+              pattern: /^[a-zA-Z0-9@_.]*$/,
+              message: '璇疯緭鍏ユ暟瀛椼�佸瓧姣嶄互鍙夽_.'
             })
           } else if (item.regular === 'phone') {
             _rules.push({
-              pattern: /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/ig,
+              pattern: /^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/,
               message: '璇锋纭緭鍏ユ墜鏈哄彿'
+            })
+          } else if (item.regular === 'email') {
+            _rules.push({
+              pattern: /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(\.[a-zA-Z0-9_-])+/,
+              message: '璇锋纭緭鍏ラ偖绠卞湴鍧�'
             })
           } else if (item.regular === 'funcname') {
             _rules.push({
-              pattern: /^[\u4E00-\u9FA50-9a-zA-Z_]*$/ig,
+              pattern: /^[\u4E00-\u9FA50-9a-zA-Z_]*$/,
               message: formRule.input.funcname
             })
           }
@@ -286,14 +326,20 @@
           {
             max: item.fieldlength,
             message: formRule.input.formMessage.replace('@max', item.fieldlength)
+          },
+          {
+            pattern: /^[^']*$/ig,
+            message: '涓嶅彲浣跨敤鑻辨枃鐘舵�佺殑鍗曞紩鍙凤紒'
+          }, {
+            validator: (rule, value, callback) => {
+              if (/--/ig.test(value)) {
+                callback('涓嶅彲浣跨敤 -- 锛�')
+              } else {
+                callback()
+              }
+            }
           }
         ]
-        if (item.encryption !== 'true') {
-          _rules.push({
-            pattern: /^[^']*$/ig,
-            message: formRule.input.quotemsg
-          })
-        }
         item.rules = _rules
       } else if (item.type === 'brafteditor') {
         item.rules = [
@@ -364,7 +410,7 @@
       let item = fieldMap.get(cell.field)
 
       // 涓嬬骇琛ㄥ崟鎺у埗-瀛楁鍐欏叆
-      if ((['select', 'radio', 'link'].includes(item.type) || (item.type === 'checkcard' && item.multiple !== 'true')) && item.linkSubField) {
+      if ((['select', 'radio', 'link'].includes(item.type) || (item.type === 'checkcard' && item.multiple !== 'true') || (item.type === 'cascader' && item.resourceType !== '2')) && item.linkSubField) {
         item.subFields = []
         item.linkSubField.forEach(m => {
           let n = fieldMap.get(m)
@@ -397,14 +443,14 @@
 
         if (fieldMap.has(item.linkField)) {
           item.supInitVal = fieldMap.get(item.linkField).initval || ''
-        } else if (data && data.hasOwnProperty(item.linkField)) {
-          item.supInitVal = data[item.linkField]
+        } else if (data.hasOwnProperty(item.linkField.toLowerCase())) {
+          item.supInitVal = data[item.linkField.toLowerCase()]
         }
         
         item.options = item.oriOptions.filter(option => option.ParentID === item.supInitVal || option.value === '')
       }
 
-      if (['select', 'link', 'radio'].includes(item.type) && item.resourceType !== '1') { // 閫変腑绗竴椤�
+      if (['select', 'link', 'radio'].includes(item.type) && item.resourceType === '0') { // 閫変腑绗竴椤�
         if (typeof(item.initval) === 'string' && item.initval.indexOf('$first') > -1) {
           item.initval = item.options[0] ? item.options[0].value : ''
         }
@@ -431,8 +477,12 @@
       }
 
       if (item.subFields && item.options.length > 0) {
+        let initval = item.initval
+        if (item.type === 'cascader' && item.separator) {
+          initval = initval.split(item.separator).pop()
+        }
         // eslint-disable-next-line
-        let option = item.options.filter(cell => item.initval == cell.value)[0]
+        let option = item.options.filter(cell => initval == cell.value)[0]
 
         if (option) {
           reFieldsVal = reFieldsVal || {}
@@ -466,7 +516,7 @@
       }
 
       if (deForms.length > 0) {
-        if (this.props.menuType !== 'HS' && options.sysType === 'local' && window.GLOB.systemType !== 'production') {
+        if (!window.GLOB.mkHS && options.sysType === 'local' && window.GLOB.systemType !== 'production') {
           this.improveSimpleActionForm(deForms)
         } else {
           this.improveActionForm(deForms)
@@ -479,7 +529,7 @@
    * @description 鑾峰彇涓嬫媺琛ㄥ崟閫夐」淇℃伅
    */
   improveActionForm = (deForms) => {
-    const { BID, menuType, action } = this.props
+    const { BID, action } = this.props
 
     let deffers = []
     let mainItems = []  // 浜戠鎴栧崟鐐规暟鎹�
@@ -494,7 +544,7 @@
       }
     })
     
-    if (menuType !== 'HS' && options.sysType !== 'local') {
+    if (!window.GLOB.mkHS && options.sysType !== 'local') {
       localItems = [...localItems, ...mainItems]
       mainItems = []
     }
@@ -514,7 +564,7 @@
       param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
       param.secretkey = Utils.encrypt(param.LText, param.timestamp)
 
-      if (menuType === 'HS') { // 浜戠鏁版嵁楠岃瘉
+      if (window.GLOB.mkHS) { // 浜戠鏁版嵁楠岃瘉
         param.open_key = Utils.encryptOpenKey(param.secretkey, param.timestamp)
       }
 
@@ -549,7 +599,7 @@
       mainparam.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
       mainparam.secretkey = Utils.encrypt(mainparam.LText, mainparam.timestamp)
 
-      if (menuType === 'HS') { // 浜戠鏁版嵁楠岃瘉
+      if (window.GLOB.mkHS) { // 浜戠鏁版嵁楠岃瘉
         mainparam.open_key = Utils.encryptOpenKey(mainparam.secretkey, mainparam.timestamp)
         if (options.cloudServiceApi) {
           mainparam.rduri = options.cloudServiceApi
@@ -605,6 +655,10 @@
   
       param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
       param.secretkey = Utils.encrypt(param.LText, param.timestamp)
+
+      if (form.database === 'sso' && window.GLOB.mainSystemApi) {
+        param.rduri = window.GLOB.mainSystemApi
+      }
   
       return (
         new Promise(resolve => {
@@ -642,23 +696,31 @@
   resetFormList = (result) => {
     let reFieldsVal = null
     let _formlist = fromJS(this.state.formlist).toJS().map(item => {
-      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect'].includes(item.type) && result[item.field] && result[item.field].length > 0) {
+      if (['select', 'link', 'radio', 'checkbox', 'checkcard', 'multiselect', 'cascader'].includes(item.type) && result[item.field] && result[item.field].length > 0) {
         let options = []
+        let map = new Map()
         result[item.field].forEach(cell => {
-          let _cell = { key: Utils.getuuid() }
+          let _cell = { key: Utils.getuuid() , ParentID: ''}
+
+          if (item.linkField && cell[item.linkField] !== undefined) {
+            _cell.ParentID = cell[item.linkField]
+          }
 
           if (item.type !== 'checkcard') {
             _cell.value = cell[item.valueField]
-            _cell.label = cell[item.valueText]
-            if (!_cell.label && _cell.label !== 0) return
+            _cell.label = cell[item.valueText] + ''
+            if (!_cell.label || map.has(_cell.ParentID + _cell.value)) return
+            
+            map.set(_cell.ParentID + _cell.value, 0)
           } else {
             _cell.$value = cell[item.cardValField]
             _cell = {..._cell, ...cell}
+
+            if (map.has(_cell.ParentID + _cell.$value)) return
+            
+            map.set(_cell.ParentID + _cell.$value, 0)
           }
-  
-          if (item.linkField) {
-            _cell.ParentID = cell[item.linkField] === undefined ? '' : cell[item.linkField]
-          }
+          
           if (item.subFields) {
             item.subFields.forEach(m => {
               _cell[m.field] = cell[m.field] === undefined ? '' : cell[m.field]
@@ -688,8 +750,12 @@
         }
 
         if (item.subFields && item.options.length > 0) {
+          let initval = item.initval
+          if (item.type === 'cascader' && item.separator) {
+            initval = initval.split(item.separator).pop()
+          }
           // eslint-disable-next-line
-          let option = item.options.filter(cell => item.initval == cell.value)[0]
+          let option = item.options.filter(cell => initval == cell.value)[0]
   
           if (option) {
             reFieldsVal = reFieldsVal || {}
@@ -731,9 +797,12 @@
         callback(item.label + '鏈�灏忓�间负 ' + item.min)
       } else if (typeof(item.max) === 'number' && val > item.max) {
         callback(item.label + '鏈�澶у�间负 ' + item.max)
+      } else {
+        callback()
       }
+    } else {
+      callback()
     }
-    callback()
   }
 
   recordChange = (values, item) => {
@@ -801,6 +870,14 @@
             </Form.Item>
           </Col>
         )
+      } else if (item.type === 'formula') {
+        fields.push(
+          <Col span={item.span || 24} key={index}>
+            <Form.Item className="hint" colon={false} label={<span className="mk-form-label" style={item.style}>{item.label}</span>} labelCol={item.labelCol} wrapperCol={item.wrapperCol}>
+              <MkFormula config={item} data={this.record}></MkFormula>
+            </Form.Item>
+          </Col>
+        )
       } else {
         let content = null
         let className = ''
@@ -814,6 +891,8 @@
           content = (<MKNumberInput config={item} onChange={(val, defer) => !defer && this.recordChange({[item.field]: val})} onSubmit={this.props.inputSubmit} />)
         } else if (item.type === 'select' || item.type === 'link' || item.type === 'multiselect') {
           content = (<MKSelect config={item} onChange={(val, other) => this.recordChange({[item.field]: val, ...other}, item)} onSubmit={this.props.inputSubmit} />)
+        } else if (item.type === 'cascader') {
+          content = (<MkCascader config={item} onChange={(val, other) => this.recordChange({[item.field]: val, ...other}, item)}/>)
         } else if (item.type === 'color') {
           content = (<MKColor config={item} onChange={(val) => this.recordChange({[item.field]: val})}/>)
         } else if (item.type === 'checkcard') {
@@ -834,7 +913,7 @@
         } else if (item.type === 'textarea') {
           content = (<MKTextArea config={item} onChange={(val, defer) => !defer && this.recordChange({[item.field]: val})}/>)
         } else if (item.type === 'rate') {
-          content = (<Rate count={item.rateCount} disabled={item.readonly} onChange={(val) => this.recordChange({[item.field]: val})} character={item.character ? <MkIcon type={item.character}/> : <StarFilled />} allowHalf={item.allowHalf}/>)
+          content = (<Rate count={item.rateCount} disabled={item.readonly} style={{color: item.color || '#fadb14'}} onChange={(val) => this.recordChange({[item.field]: val})} character={item.character ? <MkIcon type={item.character}/> : <StarFilled />} allowHalf={item.allowHalf}/>)
         } else if (item.type === 'brafteditor') {
           content = (<MKEditor config={item} onChange={(val) => this.recordChange({[item.field]: val})}/>)
           label = item.hidelabel !== 'true' ? label : ''
@@ -900,15 +979,16 @@
             if (item.interception === 'true') {           // 鍘婚櫎棣栧熬绌烘牸
               _item.value = _item.value.replace(/(^\s*|\s*$)/g, '')
             }
-            if (item.type === 'text') { // 鐗规畩瀛楁鏇挎崲
-              _item.value = _item.value.replace(/^(\s*)@appkey@(\s*)$/ig, window.GLOB.appkey)
-              _item.value = _item.value.replace(/^(\s*)@SessionUid@(\s*)$/ig, (localStorage.getItem('SessionUid') || ''))
-              _item.value = _item.value.replace(/^(\s*)@bid@(\s*)$/ig, (this.props.BID || ''))
+            if (item.type === 'text' && /@appkey@|@SessionUid@|@bid@/ig.test(_item.value)) { // 鐗规畩瀛楁鏇挎崲
+              _item.value = _item.value.replace(/^(\s*)@appkey@(\s*)$/ig, window.GLOB.appkey).replace(/^(\s*)@SessionUid@(\s*)$/ig, (localStorage.getItem('SessionUid') || '')).replace(/^(\s*)@bid@(\s*)$/ig, (this.props.BID || ''))
             }
           } else if (item.type.indexOf('date') > -1) {
             if (item.declareType === 'nvarchar(50)') {
               _item.type = 'text'
             }
+          } else if (item.declare === 'decimal' && ['select', 'link', 'radio', 'checkcard'].includes(item.type)) {
+            _item.type = 'number'
+            _item.fieldlen = item.decimal || 0
           }
 
           if (item.type === 'text' && item.lenControl && item.lenControl !== 'limit') {
@@ -934,9 +1014,13 @@
     if (action.setting && action.setting.align) {
       _align = action.setting.align
     }
+    let space = ' space-normal'
+    if (action.setting && action.setting.verticalSpace) {
+      space = ' space-' + action.setting.verticalSpace
+    }
 
     return (
-      <Form className={'main-form-field ' + _align}>
+      <Form className={'main-form-field ' + _align + space}>
         <Row gutter={24}>{this.getFields()}</Row>
       </Form>
     )

--
Gitblit v1.8.0