From 31ec63f0419895876cbaba99637a884a32d33d0d Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期三, 01 九月 2021 10:31:45 +0800
Subject: [PATCH] 2021-09-01

---
 src/templates/formtabconfig/settingform/index.jsx |   49 +++++++++++++++++++++++++++++++++++++------------
 1 files changed, 37 insertions(+), 12 deletions(-)

diff --git a/src/templates/formtabconfig/settingform/index.jsx b/src/templates/formtabconfig/settingform/index.jsx
index 4dab6bc..1c1cdfe 100644
--- a/src/templates/formtabconfig/settingform/index.jsx
+++ b/src/templates/formtabconfig/settingform/index.jsx
@@ -2,6 +2,7 @@
 import PropTypes from 'prop-types'
 import { Form, Row, Col, Input, Radio, Select, Tooltip, Icon, notification, InputNumber } from 'antd'
 import { formRule } from '@/utils/option.js'
+import Utils from '@/utils/utils.js'
 import './index.scss'
 
 const { TextArea } = Input
@@ -11,13 +12,13 @@
     dict: PropTypes.object, // 瀛楀吀椤�
     menu: PropTypes.object,
     config: PropTypes.object,
-    usefulFields: PropTypes.array,
     inputSubmit: PropTypes.any     // 鍥炶溅鎻愪氦浜嬩欢
   }
 
   state = {
     interType: (this.props.config.setting && this.props.config.setting.interType) || 'inner',
     columns: null,
+    usefulFields: [],
     interReadonly: false,
   }
 
@@ -42,12 +43,23 @@
           return true
         }
       })
-    } catch {
+    } catch (e) {
       notification.warning({
         top: 92,
         message: '鑿滃崟淇℃伅閿欒锛�',
-        duration: 10
+        duration: 5
       })
+    }
+
+    let usefulFields = sessionStorage.getItem('permFuncField')
+    if (usefulFields) {
+      try {
+        usefulFields = JSON.parse(usefulFields)
+      } catch (e) {
+        usefulFields = []
+      }
+    } else {
+      usefulFields = []
     }
 
     this.setState({
@@ -55,7 +67,8 @@
       setting: _setting,
       interType: _setting.interType || 'inner',
       interReadonly: _setting.sysInterface === 'true',
-      datatype: _setting.datatype || 'maintable'
+      datatype: _setting.datatype || 'maintable',
+      usefulFields
     })
   }
 
@@ -64,6 +77,17 @@
     return new Promise((resolve, reject) => {
       this.props.form.validateFieldsAndScroll((err, values) => {
         if (!err) {
+          let error = Utils.verifySql(values.dataresource)
+
+          if (error) {
+            notification.warning({
+              top: 92,
+              message: '鏁版嵁婧愪腑涓嶅彲浣跨敤' + error,
+              duration: 5
+            })
+            return
+          }
+
           resolve(values)
         } else {
           reject(err)
@@ -142,9 +166,9 @@
   }
 
   render() {
-    const { dict, usefulFields, menu } = this.props
+    const { dict, menu } = this.props
     const { getFieldDecorator } = this.props.form
-    const { interType, setting, datatype } = this.state
+    const { interType, setting, datatype, usefulFields } = this.state
 
     const formItemLayout = {
       labelCol: {
@@ -173,8 +197,8 @@
                     message: dict['form.required.input'] + '琛ㄥ悕!'
                   },
                   {
-                    max: formRule.input.max,
-                    message: formRule.input.message
+                    max: 50,
+                    message: '琛ㄥ悕鏈�闀夸负50涓瓧绗�!'
                   }
                 ]
               })(<Input placeholder="" autoComplete="off" onPressEnter={this.handleSubmit} />)}
@@ -189,6 +213,7 @@
                   <Select.Option value="1">1鍒�</Select.Option>
                   <Select.Option value="2">2鍒�</Select.Option>
                   <Select.Option value="3">3鍒�</Select.Option>
+                  <Select.Option value="4">4鍒�</Select.Option>
                 </Select>
               )}
             </Form.Item>
@@ -218,8 +243,8 @@
                 initialValue: interType
               })(
                 <Radio.Group onChange={this.onChange}>
-                  <Radio value="inner">{dict['header.form.interface.inner']}</Radio>
-                  <Radio value="outer">{dict['header.form.interface.outer']}</Radio>
+                  <Radio value="inner">{dict['model.interface.inner']}</Radio>
+                  <Radio value="outer">{dict['model.interface.outer']}</Radio>
                 </Radio.Group>
               )}
             </Form.Item>
@@ -230,8 +255,8 @@
                 initialValue: setting.sysInterface || 'false'
               })(
                 <Radio.Group onChange={this.onSysChange}>
-                  <Radio value="true">{dict['header.form.true']}</Radio>
-                  <Radio value="false">{dict['header.form.false']}</Radio>
+                  <Radio value="true">{dict['model.true']}</Radio>
+                  <Radio value="false">{dict['model.false']}</Radio>
                 </Radio.Group>
               )}
             </Form.Item>

--
Gitblit v1.8.0