From 57da72c823fab94a3ec6fadab2bc75173c8a03b1 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期二, 01 十二月 2020 13:45:25 +0800
Subject: [PATCH] 2020-12-01

---
 src/menu/components/table/normal-table/columns/editColumn/formconfig.jsx |  292 ++++++++++++
 src/components/header/index.jsx                                          |    1 
 src/templates/zshare/formconfig.jsx                                      |    2 
 src/templates/calendarconfig/index.jsx                                   |   76 +-
 src/templates/comtableconfig/index.jsx                                   |  148 +++---
 src/templates/subtableconfig/index.jsx                                   |  152 +++---
 src/templates/treepageconfig/index.jsx                                   |  124 ++--
 /dev/null                                                                |   40 -
 src/tabviews/zshare/mutilform/index.jsx                                  |   20 
 src/menu/components/table/normal-table/columns/editColumn/index.jsx      |  336 ++++++++++++++
 src/tabviews/zshare/verifycard/index.jsx                                 |   11 
 src/templates/sharecomponent/actioncomponent/index.jsx                   |    2 
 src/components/sidemenu/config.jsx                                       |    7 
 src/menu/components/table/normal-table/columns/index.scss                |   10 
 src/tabviews/subtable/index.jsx                                          |    2 
 src/menu/components/table/normal-table/columns/editColumn/index.scss     |   19 
 src/tabviews/commontable/index.jsx                                       |    1 
 src/menu/components/table/normal-table/columns/index.jsx                 |   94 +++
 src/tabviews/zshare/verifycard/tabcard/index.jsx                         |   96 ---
 19 files changed, 1,011 insertions(+), 422 deletions(-)

diff --git a/src/components/header/index.jsx b/src/components/header/index.jsx
index 9b0daf0..ebe4961 100644
--- a/src/components/header/index.jsx
+++ b/src/components/header/index.jsx
@@ -567,6 +567,7 @@
 
     this.props.modifyMainMenu(menulist[0] || null)
     this.props.resetEditLevel(false)
+    this.props.modifyTabview([])
   }
   
   exitEdit = () => {
diff --git a/src/components/sidemenu/config.jsx b/src/components/sidemenu/config.jsx
index 688344c..c7b95af 100644
--- a/src/components/sidemenu/config.jsx
+++ b/src/components/sidemenu/config.jsx
@@ -90,6 +90,13 @@
     MenuID: '1602315375262ikd33ii0nii34pt861o',
     MenuNo: 's_worksflow_roleM',
     MenuName: '鍏抽敭瑙掕壊绠$悊',
+  }, {
+    src: '',
+    PageParam: {OpenType: 'newtab', Template: 'ManageTable'},
+    type: 'ManageTable',
+    MenuID: '1606794243739c5ihs58lucpskp3r4s2',
+    MenuNo: 's_custom_componentsM',
+    MenuName: '鑷畾涔夌粍浠�',
   }]
 }, {
   MenuID: 'systemManageViewInterface',
diff --git a/src/menu/components/table/normal-table/columns/cusSwitch/index.jsx b/src/menu/components/table/normal-table/columns/cusSwitch/index.jsx
deleted file mode 100644
index 82cd954..0000000
--- a/src/menu/components/table/normal-table/columns/cusSwitch/index.jsx
+++ /dev/null
@@ -1,54 +0,0 @@
-import React, {Component} from 'react'
-import PropTypes from 'prop-types'
-// import { is, fromJS } from 'immutable'
-import { Switch } from 'antd'
-
-import './index.scss'
-
-class ColorSketch extends Component {
-  static propTpyes = {
-    defaultValue: PropTypes.any,
-    value: PropTypes.any,
-    onChange: PropTypes.func
-  }
-  state = {
-    status: true,
-  }
-
-  UNSAFE_componentWillMount () {
-    const { defaultValue, value } = this.props
-    let initVal = 'true'
-
-    if (this.props['data-__meta']) {
-      initVal = this.props['data-__meta'].initialValue
-    } else if (defaultValue) {
-      initVal = defaultValue
-    } else if (value) {
-      initVal = value
-    }
-
-    if (initVal === 'false') {
-      initVal = false
-    } else {
-      initVal = true
-    }
-    
-    this.setState({status: initVal})
-  }
-
-  changeStatus = (val) => {
-    this.setState({ status: val }, () => {
-      let _val = val ? 'true' : 'false'
-      this.props.onChange && this.props.onChange(_val)
-    })
-  }
-
-  render() {
-    const { status } = this.state
-    return (
-      <Switch checkedChildren="鏄�" unCheckedChildren="鍚�" checked={status} onChange={this.changeStatus} />
-    )
-  }
-}
-
-export default ColorSketch
\ No newline at end of file
diff --git a/src/menu/components/table/normal-table/columns/cusSwitch/index.scss b/src/menu/components/table/normal-table/columns/cusSwitch/index.scss
deleted file mode 100644
index 96900ce..0000000
--- a/src/menu/components/table/normal-table/columns/cusSwitch/index.scss
+++ /dev/null
@@ -1,40 +0,0 @@
-.color-sketch-block {
-  height: 25px;
-  width: 100%;
-
-  .color-sketch-block-box {
-    display: inline-block;
-    width: calc(100% - 160px);
-    height: 100%;
-    border-radius: 2px;
-    background: #ffffff url('') left center;
-  }
-  .color-sketch-block-inner {
-    display: inline-block;
-    cursor: pointer;
-    border-radius: 2px;
-    box-shadow: 0 0 0 1px rgba(0, 0, 0, .1);
-    width: 100%;
-    height: 100%;
-  }
-  .color-sketch-value {
-    display: inline-block;
-    width: 160px;
-    padding-left: 10px;
-    height: 25px;
-    line-height: 25px;
-    vertical-align: top;
-    white-space: nowrap;
-    overflow: visible;
-  }
-}
-
-.color-sketch-popover {
-  z-index: 1090!important;
-  .ant-popover-inner-content {
-    padding: 0;
-    .sketch-picker {
-      width: 250px!important;
-    }
-  }
-}
\ No newline at end of file
diff --git a/src/menu/components/table/normal-table/columns/editColumn/formconfig.jsx b/src/menu/components/table/normal-table/columns/editColumn/formconfig.jsx
new file mode 100644
index 0000000..3d816a0
--- /dev/null
+++ b/src/menu/components/table/normal-table/columns/editColumn/formconfig.jsx
@@ -0,0 +1,292 @@
+import zhCN from '@/locales/zh-CN/model.js'
+import enUS from '@/locales/en-US/model.js'
+
+const Formdict = localStorage.getItem('lang') !== 'en-US' ? zhCN : enUS
+
+/**
+ * @description 鑾峰彇鏄剧ず鍒楄〃鍗曢厤缃俊鎭�
+ * @param {object} card       // 鎼滅储鏉′欢瀵硅薄
+ * @param {Array}  menulist   // 鑿滃崟鍒楄〃-鐢ㄤ簬瀛楁閫忚
+ */
+export function getColumnForm (card, menulist = [], fields = []) {
+  let roleList = sessionStorage.getItem('sysRoles')
+  if (roleList) {
+    try {
+      roleList = JSON.parse(roleList)
+    } catch {
+      roleList = []
+    }
+  } else {
+    roleList = []
+  }
+
+  return [
+    {
+      type: 'text',
+      key: 'label',
+      label: '鍒楀ご鏂囧瓧',
+      initVal: card.label,
+      required: true
+    },
+    {
+      type: 'select',
+      key: 'type',
+      label: Formdict['model.form.type'],
+      initVal: card.type,
+      required: true,
+      options: [{
+        value: 'text',
+        text: Formdict['model.form.text']
+      }, {
+        value: 'number',
+        text: Formdict['model.form.number']
+      }, {
+        value: 'picture',
+        text: Formdict['model.form.picture']
+      }, {
+        value: 'link',
+        text: Formdict['model.form.href']
+      }, {
+        value: 'textarea',
+        text: Formdict['model.form.textarea']
+      }]
+    },
+    {
+      type: 'select',
+      key: 'field',
+      label: Formdict['model.form.field'],
+      initVal: card.field,
+      required: true,
+      options: fields
+    },
+    {
+      type: 'number',
+      key: 'Width',
+      min: 1,
+      max: 1000,
+      decimal: 0,
+      label: Formdict['model.form.columnWidth'],
+      initVal: card.Width,
+      required: true
+    },
+    {
+      type: 'radio',
+      key: 'joint',
+      label: Formdict['model.form.paramJoint'],
+      initVal: card.joint || 'true',
+      required: true,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'Hide',
+      label: Formdict['model.hidden'],
+      initVal: card.Hide || 'false',
+      required: true,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'IsSort',
+      label: Formdict['model.sort'],
+      initVal: card.IsSort || 'true',
+      required: true,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'Align',
+      label: Formdict['model.form.align'],
+      initVal: card.Align || 'left',
+      required: true,
+      options: [{
+        value: 'left',
+        text: Formdict['model.form.alignLeft']
+      }, {
+        value: 'center',
+        text: Formdict['model.form.alignCenter']
+      }, {
+        value: 'right',
+        text: Formdict['model.form.alignRight']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'rowspan',
+      label: '琛屽悎骞�',
+      initVal: card.rowspan || 'false',
+      tooltip: '鐩搁偦琛屼俊鎭浉鍚屾椂锛屽崟鍏冩牸鍚堝苟銆傛敞锛氫负闃叉琛ㄦ牸淇℃伅閿欎贡锛岃鍚堝苟鍙兘娣诲姞涓�涓瓧娈点��',
+      required: false,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'sum',
+      label: '鏄剧ず鍚堣',
+      initVal: card.sum || 'false',
+      tooltip: '鍚堣淇℃伅鍙湪浣跨敤绯荤粺鏁版嵁婧愶紝涓斿綋鍓嶅垪鏈殣钘忔椂鏈夋晥銆�',
+      required: false,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'number',
+      key: 'decimal',
+      min: 0,
+      max: 18,
+      decimal: 0,
+      label: Formdict['header.form.decimal'],
+      initVal: card.decimal || 0,
+      required: true
+    },
+    {
+      type: 'number',
+      key: 'fieldlength',
+      label: Formdict['model.form.field'] + Formdict['model.length'],
+      initVal: card.fieldlength || (card.type === 'text' ? 50 : 512),
+      required: true
+    },
+    {
+      type: 'select',
+      key: 'format',
+      label: Formdict['header.form.format'],
+      initVal: card.format || '',
+      options: [{
+        value: '',
+        text: Formdict['model.empty']
+      }, {
+        value: 'thdSeparator',
+        text: Formdict['header.form.thdSeparator']
+      }, {
+        value: 'percent',
+        text: '鐧惧垎姣�'
+      }],
+      required: false
+    },
+    {
+      type: 'select',
+      key: 'textFormat',
+      label: Formdict['header.form.format'],
+      initVal: card.textFormat || '',
+      options: [{
+        value: '',
+        text: Formdict['model.empty']
+      }, {
+        value: 'YYYY-MM-DD',
+        text: 'YYYY-MM-DD'
+      }, {
+        value: 'YYYY-MM-DD HH:mm:ss',
+        text: 'YYYY-MM-DD HH:mm:ss'
+      }],
+      required: false
+    },
+    {
+      type: 'text',
+      key: 'prefix',
+      label: Formdict['header.form.prefix'],
+      initVal: card.prefix || '',
+      required: false,
+      readonly: false
+    },
+    {
+      type: 'text',
+      key: 'postfix',
+      label: Formdict['header.form.postfix'],
+      initVal: card.postfix || '',
+      tooltipClass: 'middle',
+      required: false,
+      readonly: false
+    },
+    {
+      type: 'number',
+      key: 'maxHeight',
+      min: 1,
+      max: 1000,
+      decimal: 0,
+      label: '鏈�澶ч珮搴�',
+      tooltip: '鍥剧墖鍦ㄨ〃鏍间腑鏄剧ず鐨勬渶澶ч珮搴�',
+      tooltipClass: 'middle',
+      initVal: card.maxHeight || 128,
+      required: true
+    },
+    {
+      type: 'radio',
+      key: 'scale',
+      label: Formdict['header.form.clickscale'],
+      initVal: card.scale || 'false',
+      required: false,
+      options: [{
+        value: 'true',
+        text: Formdict['model.true']
+      }, {
+        value: 'false',
+        text: Formdict['model.false']
+      }]
+    },
+    {
+      type: 'radio',
+      key: 'perspective',
+      label: '瀛楁閫忚',
+      initVal: card.perspective || 'linkmenu',
+      options: [{
+        value: 'linkmenu',
+        text: '鑿滃崟'
+      }, {
+        value: 'linkurl',
+        text: '閾炬帴'
+      }]
+    },
+    {
+      type: 'cascader',
+      key: 'linkmenu',
+      label: Formdict['model.menu'],
+      initVal: card.linkmenu || [],
+      required: false,
+      options: menulist
+    },
+    {
+      type: 'text',
+      key: 'linkurl',
+      label: '閾炬帴鍦板潃',
+      initVal: card.linkurl || '',
+      required: false
+    },
+    {
+      type: 'multiselect',
+      key: 'blacklist',
+      label: Formdict['header.form.blacklist'],
+      initVal: card.blacklist || [],
+      required: false,
+      options: roleList
+    }
+  ]
+}
diff --git a/src/menu/components/table/normal-table/columns/editColumn/index.jsx b/src/menu/components/table/normal-table/columns/editColumn/index.jsx
new file mode 100644
index 0000000..5ab0873
--- /dev/null
+++ b/src/menu/components/table/normal-table/columns/editColumn/index.jsx
@@ -0,0 +1,336 @@
+import React, {Component} from 'react'
+import PropTypes from 'prop-types'
+import { fromJS } from 'immutable'
+import { Form, Row, Col, Input, Select, InputNumber, Radio, Tooltip, Icon, Cascader, Modal } from 'antd'
+
+import { getColumnForm } from './formconfig'
+import { formRule } from '@/utils/option.js'
+import './index.scss'
+
+const columnTypeOptions = {
+  text: ['label', 'field', 'type', 'Align', 'Hide', 'IsSort', 'Width', 'prefix', 'postfix', 'textFormat', 'fieldlength', 'blacklist', 'perspective', 'rowspan'],
+  number: ['label', 'field', 'type', 'Align', 'Hide', 'IsSort', 'Width', 'decimal', 'format', 'prefix', 'postfix', 'blacklist', 'perspective', 'sum'],
+  link: ['label', 'field', 'type', 'Align', 'Hide', 'IsSort', 'joint', 'Width', 'fieldlength', 'blacklist'],
+  textarea: ['label', 'field', 'type', 'Align', 'Hide', 'IsSort', 'Width', 'prefix', 'postfix', 'fieldlength', 'blacklist'],
+  picture: ['label', 'field', 'type', 'Align', 'Hide', 'IsSort', 'Width', 'fieldlength', 'blacklist', 'scale', 'maxHeight']
+}
+
+class MainSearch extends Component {
+  static propTpyes = {
+    dict: PropTypes.object,     // 瀛楀吀椤�
+    column: PropTypes.object,
+    fields: PropTypes.array,
+    updateCol: PropTypes.func,  // 鎻愪氦浜嬩欢
+    deleteCol: PropTypes.func   // 鍙栨秷鏃跺垹闄や簨浠�
+  }
+
+  state = {
+    visible: false,
+    formlist: null
+  }
+
+  /**
+   * @description 鍒濇娣诲姞鐨勬樉绀哄垪鍏冪礌锛岃仛鐒︽彁绀烘枃瀛�
+   */
+  componentDidMount () {
+    if (this.props.column.focus) {
+      this.editColumn()
+    }
+  }
+
+  editColumn = () => {
+    let menulist = sessionStorage.getItem('fstMenuList')
+    if (menulist) {
+      try {
+        menulist = JSON.parse(menulist)
+      } catch {
+        menulist = []
+      }
+    } else {
+      menulist = []
+    }
+
+    this.setState({
+      visible: true,
+      formlist: getColumnForm(this.props.column, menulist, this.props.fields)
+    }, () => {
+      if (this.props.column.focus) {
+        try {
+          let _form = document.getElementById('label')
+          _form.select()
+        } catch {
+          console.warn('琛ㄥ崟focus澶辫触锛�')
+        }
+      }
+    })
+  }
+
+  typeChange = (key, value, option) => {
+    if (key === 'type') {
+      let _options = fromJS(columnTypeOptions[value]).toJS()
+
+      if (value === 'text' || value === 'number') {
+        _options.push('linkmenu')
+      }
+
+      let fieldlength = 50
+
+      if (value !== 'text') {
+        fieldlength = 512
+      }
+
+      this.setState({
+        type: value,
+        formlist: this.state.formlist.map(item => {
+          item.hidden = !_options.includes(item.key)
+
+          return item
+        })
+      }, () => {
+        if (this.props.form.getFieldValue('fieldlength') !== undefined) {
+          this.props.form.setFieldsValue({fieldlength: fieldlength})
+        } else if (this.props.form.getFieldValue('perspective') !== undefined) {
+          this.props.form.setFieldsValue({perspective: 'linkmenu'})
+        }
+      })
+    } else if (key === 'field') {
+      this.props.form.setFieldsValue({label: option.props.children})
+    } else if (key === 'format' && value === 'percent') {
+      this.props.form.setFieldsValue({postfix: '%'})
+    }
+  }
+
+  changeRadio = (key, value) => {
+    if (key === 'perspective') {
+      let _options = fromJS(columnTypeOptions[this.state.type]).toJS()
+
+      if (value !== 'linkurl') {
+        _options.push('linkmenu')
+      } else {
+        _options.push('linkurl')
+      }
+
+      this.setState({
+        formlist: this.state.formlist.map(item => {
+          item.hidden = !_options.includes(item.key)
+
+          return item
+        })
+      })
+    }
+  }
+
+  getFields() {
+    const { getFieldDecorator } = this.props.form
+    const { formlist } = this.state
+    const fields = []
+
+    if (!formlist) return null
+
+    formlist.forEach((item, index) => {
+      if (item.hidden) return
+
+      if (item.type === 'text') { // 鏂囨湰鎼滅储
+        let rules = []
+        if (item.key !== 'linkurl') {
+          rules = [{
+            max: formRule.input.max,
+            message: formRule.input.message
+          }]
+        }
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.tooltip ?
+              <Tooltip placement="topLeft" overlayClassName={item.tooltipClass} title={item.tooltip}>
+                <Icon type="question-circle" />
+                {item.label}
+              </Tooltip> : item.label
+            }>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal || '',
+                rules: [
+                  {
+                    required: !!item.required,
+                    message: this.props.dict['form.required.input'] + item.label + '!'
+                  },
+                  ...rules
+                ]
+              })(<Input placeholder="" autoComplete="off" disabled={item.readonly} onPressEnter={this.handleSubmit} />)}
+            </Form.Item>
+          </Col>
+        )
+      } else if (item.type === 'number') {
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.tooltip ?
+              <Tooltip placement="topLeft" overlayClassName={item.tooltipClass} title={item.tooltip}>
+                <Icon type="question-circle" />
+                {item.label}
+              </Tooltip> : item.label
+            }>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal,
+                rules: [
+                  {
+                    required: !!item.required,
+                    message: this.props.dict['form.required.input'] + item.label + '!'
+                  }
+                ]
+              })(item.unlimit ? <InputNumber /> :
+                  <InputNumber min={item.min} max={item.max} precision={item.decimal} />)}
+            </Form.Item>
+          </Col>
+        )
+      } else if (item.type === 'select') { // 涓嬫媺鎼滅储
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.label}>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal || '',
+                rules: [
+                  {
+                    required: !!item.required,
+                    message: this.props.dict['form.required.select'] + item.label + '!'
+                  }
+                ]
+              })(
+                <Select
+                  showSearch
+                  filterOption={(input, option) => option.props.children.toLowerCase().indexOf(input.toLowerCase()) >= 0}
+                  onChange={(value, option) => {this.typeChange(item.key, value, option)}}
+                  getPopupContainer={() => document.getElementById('columnwinter')}
+                >
+                  {item.options.map((option, index) =>
+                    <Select.Option key={index} value={option.value || option.field}>
+                      {option.text || option.label}
+                    </Select.Option>
+                  )}
+                </Select>
+              )}
+            </Form.Item>
+          </Col>
+        )
+      } else if (item.type === 'radio') {
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.tooltip ?
+              <Tooltip placement="topLeft" overlayClassName={item.tooltipClass} title={item.tooltip}>
+                <Icon type="question-circle" />
+                {item.label}
+              </Tooltip> : item.label
+            }>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal,
+                rules: [
+                  {
+                    required: !!item.required,
+                    message: this.props.dict['form.required.select'] + item.label + '!'
+                  }
+                ]
+              })(
+                <Radio.Group onChange={(e) => {this.changeRadio(item.key, e.target.value)}}>
+                  {
+                    item.options.map(option => {
+                      return (
+                        <Radio key={option.value} value={option.value}>{option.text}</Radio>
+                      )
+                    })
+                  }
+                </Radio.Group>
+              )}
+            </Form.Item>
+          </Col>
+        )
+      } else if (item.type === 'multiselect') { // 澶氶��
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.label}>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal || []
+              })(
+                <Select
+                  showSearch
+                  mode="multiple"
+                  filterOption={(input, option) => option.props.children.toLowerCase().indexOf(input.toLowerCase()) >= 0}
+                >
+                  {item.options.map((option, i) =>
+                    <Select.Option id={i} key={i} value={option.value}>{option.text}</Select.Option>
+                  )}
+                </Select>
+              )}
+            </Form.Item>
+          </Col>
+        )
+      } else if (item.type === 'cascader') { // 澶氶��
+        fields.push(
+          <Col span={12} key={index}>
+            <Form.Item label={item.label}>
+              {getFieldDecorator(item.key, {
+                initialValue: item.initVal || []
+              })(
+                <Cascader
+                  options={item.options}
+                  placeholder=""
+                  getPopupContainer={() => document.getElementById('columnwinter')}
+                />
+              )}
+            </Form.Item>
+          </Col>
+        )
+      }
+    })
+    return fields
+  }
+
+  handleSubmit = () => {
+    // 琛ㄥ崟鎻愪氦鏃舵鏌ヨ緭鍏ュ�兼槸鍚︽纭�
+    this.props.form.validateFieldsAndScroll((err, values) => {
+      if (!err) {
+        this.setState({visible: false, formlist: null})
+        this.props.updateCol(values)
+      }
+    })
+  }
+
+  editModalCancel = () => {
+    this.setState({visible: false, formlist: null})
+
+    if (this.props.column.focus) {
+      this.props.deleteCol()
+    }
+  }
+
+  render() {
+    const { visible } = this.state
+    const formItemLayout = {
+      labelCol: {
+        xs: { span: 24 },
+        sm: { span: 6 }
+      },
+      wrapperCol: {
+        xs: { span: 24 },
+        sm: { span: 18 }
+      }
+    }
+    return (
+      <div style={{display: 'inline-block'}}>
+        <Icon className="edit" title="缂栬緫" type="edit" onClick={this.editColumn} />
+        <Modal
+          title="鏄剧ず鍒楃紪杈�"
+          visible={visible}
+          width={800}
+          maskClosable={false}
+          onOk={this.handleSubmit}
+          onCancel={this.editModalCancel}
+          destroyOnClose
+        >
+          <Form {...formItemLayout} className="commontable-column-form" id="columnwinter">
+            <Row gutter={24}>{this.getFields()}</Row>
+          </Form>
+        </Modal>
+      </div>
+    )
+  }
+}
+
+export default Form.create()(MainSearch)
\ No newline at end of file
diff --git a/src/menu/components/table/normal-table/columns/editColumn/index.scss b/src/menu/components/table/normal-table/columns/editColumn/index.scss
new file mode 100644
index 0000000..fcf59ac
--- /dev/null
+++ b/src/menu/components/table/normal-table/columns/editColumn/index.scss
@@ -0,0 +1,19 @@
+.commontable-column-form {
+  min-height: 190px;
+  .ant-form-item {
+    .ant-input-number {
+      width: 100%;
+    }
+  }
+  .anticon-question-circle {
+    color: #c49f47;
+    position: relative;
+    left: -3px;
+  }
+  .ant-cascader-menus {
+    padding: 5px 0px;
+    .ant-cascader-menu:last-child {
+      padding-right: 3px;
+    }
+  }
+}
diff --git a/src/menu/components/table/normal-table/columns/index.jsx b/src/menu/components/table/normal-table/columns/index.jsx
index 9ca8013..8a5d67c 100644
--- a/src/menu/components/table/normal-table/columns/index.jsx
+++ b/src/menu/components/table/normal-table/columns/index.jsx
@@ -2,21 +2,56 @@
 import PropTypes from 'prop-types'
 import { is, fromJS } from 'immutable'
 import { DndProvider, DragSource, DropTarget } from 'react-dnd'
-import { Table, Form } from 'antd'
+import { Table, Form, Popover, Icon } from 'antd'
 
+import asyncIconComponent from '@/utils/asyncIconComponent'
 import Utils from '@/utils/utils.js'
+import zhCN from '@/locales/zh-CN/model.js'
+import enUS from '@/locales/en-US/model.js'
 import './index.scss'
 
+const coldict = localStorage.getItem('lang') !== 'en-US' ? zhCN : enUS
+const EditColumn = asyncIconComponent(() => import('./editColumn'))
+
 class HeaderCol extends Component {
+  updateCol = (values) => {
+    const { column } = this.props
+    this.props.updateCol({...column, ...values})
+  }
+
+  deleteCol = () => {
+    this.props.deleteCol(this.props.column)
+  }
+
   render() {
-    const { connectDragSource, connectDropTarget, moveCol, index, ...restProps } = this.props
+    const { connectDragSource, connectDropTarget, moveCol, updateCol, deleteCol, index, column, fields, children, ...restProps } = this.props
 
     if (index !== undefined) {
       return connectDragSource(
-        connectDropTarget(<th {...restProps} index={index} style={{ cursor: 'move' }}/>),
+        connectDropTarget(<th {...restProps} index={index} style={{ cursor: 'move' }}>
+          <Popover overlayClassName="mk-popover-control-wrap" mouseLeaveDelay={0.2} mouseEnterDelay={0.2} content={
+            <div className="mk-popover-control">
+              <EditColumn column={column} dict={coldict} fields={fields} updateCol={this.updateCol} deleteCol={this.deleteCol}/>
+              <Icon className="close" title="delete" type="delete" onClick={this.deleteCol} />
+            </div>
+          } trigger="hover">
+            {children}
+          </Popover>
+        </th>),
       )
     } else {
-      return (<th {...restProps} index={index}/>)
+      return (
+        <th {...restProps}>
+          <Popover overlayClassName="mk-popover-control-wrap" mouseLeaveDelay={0.2} mouseEnterDelay={0.2} content={
+            <div className="mk-popover-control">
+              <EditColumn column={column} dict={coldict} fields={fields} updateCol={this.updateCol} deleteCol={this.deleteCol}/>
+              <Icon className="close" title="delete" type="delete" onClick={this.deleteCol} />
+            </div>
+          } trigger="hover">
+            {children}
+          </Popover>
+        </th>
+      )
     }
   }
 }
@@ -81,20 +116,24 @@
 
   state = {
     data: [{uuid: Utils.getuuid()}],
-    columns: []
+    columns: [],
+    fields: []
   }
 
   UNSAFE_componentWillMount () {
     this.setState({
-      columns: fromJS(this.props.config.cols).toJS()
+      columns: fromJS(this.props.config.cols).toJS(),
+      fields: fromJS(this.props.config.columns).toJS()
     })
   }
 
-  // UNSAFE_componentWillReceiveProps (nextProps) {
-  //   if (!is(fromJS(this.state.data), fromJS(nextProps.data))) {
-  //     this.setState({data: nextProps.data})
-  //   }
-  // }
+  UNSAFE_componentWillReceiveProps (nextProps) {
+    if (!is(fromJS(this.state.columns), fromJS(nextProps.config.cols))) {
+      this.setState({columns: fromJS(nextProps.config.cols).toJS()})
+    } else if (!is(fromJS(this.state.fields), fromJS(nextProps.config.columns))) {
+      this.setState({fields: fromJS(nextProps.config.columns).toJS()})
+    }
+  }
   shouldComponentUpdate (nextProps, nextState) {
     return !is(fromJS(this.state), fromJS(nextState))
   }
@@ -111,8 +150,17 @@
     })
   }
 
+  updateCol = (col) => {
+
+  }
+
+  deleteCol = (col) => {
+
+  }
+
   render() {
-    let components = {
+    const { fields } = this.state
+    const components = {
       header: {
         cell: DragableHeaderCol
       },
@@ -123,28 +171,36 @@
     
     const columns = this.state.columns.map((col, index) => {
       return {
-        ...col,
         title: col.label,
         dataIndex: col.field,
         align: 'right',
         sorter: col.IsSort === 'true',
         onCell: () => ({
-          column: col
+          column: col,
+          fields: fields
         }),
         children: col.subcols && col.subcols.length > 0 ? col.subcols.map(cell => ({
           align: 'left',
           title: cell.label,
           key: cell.uuid,
-          width: 120,
           onCell: () => ({
-            column: cell
+            column: cell,
+            fields: fields
           }),
+          onHeaderCell: () => ({
+            column: cell,
+            fields: fields,
+            updateCol: this.updateCol,
+            deleteCol: this.deleteCol,
+          })
         })) : null,
-        onHeaderCell: column => ({
+        onHeaderCell: () => ({
           index,
-          key: column.uuid,
-          title: column.label,
+          column: col,
+          fields: fields,
           moveCol: this.moveCol,
+          updateCol: this.updateCol,
+          deleteCol: this.deleteCol,
         })
       }
     })
diff --git a/src/menu/components/table/normal-table/columns/index.scss b/src/menu/components/table/normal-table/columns/index.scss
index 7bf3269..dc02829 100644
--- a/src/menu/components/table/normal-table/columns/index.scss
+++ b/src/menu/components/table/normal-table/columns/index.scss
@@ -5,7 +5,15 @@
   }
   .ant-table-thead {
     th {
-      width: 100px;
+      position: relative;
+      .ant-table-column-sorter::before {
+        position: absolute;
+        top: 0;
+        right: 0;
+        bottom: 0;
+        left: 0;
+        content: '';
+      }
     }
   }
 }
diff --git a/src/tabviews/commontable/index.jsx b/src/tabviews/commontable/index.jsx
index 5f3e6cb..d5e7747 100644
--- a/src/tabviews/commontable/index.jsx
+++ b/src/tabviews/commontable/index.jsx
@@ -240,7 +240,6 @@
       }
 
       if (_curUserConfig) {
-        config.setting = {...config.setting, ..._curUserConfig.setting}
         config.easyCode = _curUserConfig.easyCode || config.easyCode || ''
 
         config.action = config.action.map(item => {
diff --git a/src/tabviews/subtable/index.jsx b/src/tabviews/subtable/index.jsx
index 0f73c96..6a9bdbd 100644
--- a/src/tabviews/subtable/index.jsx
+++ b/src/tabviews/subtable/index.jsx
@@ -197,8 +197,6 @@
       let chartId = config.charts[0] ? config.charts[0].uuid : ''
 
       if (userConfig) {
-        config.setting.tableType = userConfig.setting.tableType
-
         config.action = config.action.map(item => {
           if (userConfig.action[item.uuid]) {
             delete userConfig.action[item.uuid].label
diff --git a/src/tabviews/zshare/mutilform/index.jsx b/src/tabviews/zshare/mutilform/index.jsx
index 0fcddd3..2767199 100644
--- a/src/tabviews/zshare/mutilform/index.jsx
+++ b/src/tabviews/zshare/mutilform/index.jsx
@@ -85,7 +85,7 @@
       formlist = action.fields
     }
 
-    let _inputfields = formlist.filter(item => item.type === 'text' || item.type === 'number') // 鐢ㄤ簬杩囨护涓嬫媺鑿滃崟鍏宠仈琛ㄥ崟
+    let _inputfields = formlist.filter(item => (item.type === 'text' || item.type === 'number') && item.field) // 鐢ㄤ簬杩囨护涓嬫媺鑿滃崟鍏宠仈琛ㄥ崟
 
     formlist = formlist.map(item => {
       if (item.type === 'title') return item
@@ -135,9 +135,15 @@
         item.oriOptions = fromJS(item.options).toJS()
 
         // 涓嬬骇琛ㄥ崟鎺у埗-瀛楁鍐欏叆
-        if (item.linkSubField && item.linkSubField.length > 0) {
-          let _fields = _inputfields.map(_item => _item.field)
-          item.linkSubField = item.linkSubField.filter(_item => _fields.includes(_item))
+        if (item.type === 'select' || item.type === 'radio') {
+          if (item.linkSubField && item.linkSubField.length > 0) {
+            item.linkSubField = item.linkSubField.filter(_item => _inputfields.includes(_item))
+          }
+          if (item.linkSubField && item.linkSubField.length === 0) {
+            item.linkSubField = null
+          }
+        } else {
+          item.linkSubField = null
         }
       }
 
@@ -422,7 +428,7 @@
     
             if (item.type === 'link') {
               _cell.ParentID = cell[item.linkField] === undefined ? '' : cell[item.linkField]
-            } else if ((item.type === 'select' || item.type === 'radio') && item.linkSubField && item.linkSubField.length > 0) {
+            } else if (item.linkSubField) {
               item.linkSubField.forEach(_field => {
                 _cell[_field] = (cell[_field] || cell[_field] === 0) ? cell[_field] : ''
               })
@@ -519,7 +525,7 @@
     
             if (item.type === 'link') {
               _cell.ParentID = cell[item.linkField] === undefined ? '' : cell[item.linkField]
-            } else if ((item.type === 'select' || item.type === 'radio') && item.linkSubField && item.linkSubField.length > 0) {
+            } else if (item.linkSubField) {
               item.linkSubField.forEach(_field => {
                 _cell[_field] = (cell[_field] || cell[_field] === 0) ? cell[_field] : ''
               })
@@ -600,7 +606,7 @@
     })
     
     // 琛ㄥ崟鍒囨崲鏃讹紝鏇存柊鍏宠仈瀛楁
-    if ((_field.type === 'select' || _field.type === 'radio') && _field.linkSubField && _field.linkSubField.length > 0) {
+    if (_field.linkSubField) {
       let _data = _field.options.filter(op => op.Value === value)[0]
 
       if (_data) {
diff --git a/src/tabviews/zshare/verifycard/index.jsx b/src/tabviews/zshare/verifycard/index.jsx
index a8d1db8..0678cf7 100644
--- a/src/tabviews/zshare/verifycard/index.jsx
+++ b/src/tabviews/zshare/verifycard/index.jsx
@@ -40,11 +40,6 @@
       type: 'main',
       label: MenuName + '(涓昏〃)',
       easyCode: config.easyCode || '',
-      setting: {
-        actionfixed: config.setting.actionfixed,
-        columnfixed: config.setting.columnfixed,
-        tableType: config.setting.tableType
-      },
       action: config.action.map(item => {
         let _item = {
           uuid: item.uuid,
@@ -126,7 +121,7 @@
           subconfig.action = subconfig.action.filter(item => permAction[item.uuid])
     
           subconfig.columns = subconfig.columns.filter(col => {
-            if (!col.field || !col.blacklist || col.blacklist.length === 0 || subconfig.setting.primaryKey === col.field) return true
+            if (!col.field || !col.blacklist || col.blacklist.length === 0) return true
     
             let _black = col.blacklist.filter(v => {
               return permRoles.indexOf(v) !== -1
@@ -140,8 +135,6 @@
           })
 
           if (subUserConfig) {
-            subconfig.setting.tableType = subUserConfig.setting.tableType
-
             subconfig.action = subconfig.action.map(item => {
               if (subUserConfig.action[item.uuid]) {
                 delete subUserConfig.action[item.uuid].label
@@ -232,7 +225,6 @@
             uuid: res.tab.uuid,
             linkTab: res.tab.linkTab,
             label: res.tab.label,
-            setting: {tableType: subconfig.setting.tableType},
             action: subconfig.action.map(item => {
               let _item = {
                 uuid: item.uuid,
@@ -295,7 +287,6 @@
     config.forEach(tab => {
       let _tab = {
         label: tab.label,
-        setting: tab.setting,
         action: {},
         columns: {}
       }
diff --git a/src/tabviews/zshare/verifycard/tabcard/index.jsx b/src/tabviews/zshare/verifycard/tabcard/index.jsx
index e560fe3..9893c14 100644
--- a/src/tabviews/zshare/verifycard/tabcard/index.jsx
+++ b/src/tabviews/zshare/verifycard/tabcard/index.jsx
@@ -1,6 +1,6 @@
 import React, {Component} from 'react'
 import PropTypes from 'prop-types'
-import { Form, Tabs, Row, Col, Radio, Table, Icon, Select, notification, Input } from 'antd'
+import { Form, Tabs, Row, Col, Table, Icon, notification, Input } from 'antd'
 
 import ActionForm from './actionform'
 import ColumnForm from './columnform'
@@ -174,7 +174,6 @@
     
     let _subconfig = {
       label: config.label,
-      setting: config.setting,
       action: {},
       columns: {}
     }
@@ -456,66 +455,6 @@
     this.props.handleconfig(_config.uuid, _subconfig)
   }
 
-  handleConfirm = () => {
-    const { config } = this.state
-    // 琛ㄥ崟鎻愪氦鏃舵鏌ヨ緭鍏ュ�兼槸鍚︽纭�
-    return new Promise((resolve, reject) => {
-      this.props.form.validateFieldsAndScroll((err, values) => {
-        if (!err) {
-          let _config = {}
-          _config.setting = values
-          _config.action = config.action.map(item => {
-            return {
-              uuid: item.uuid,
-              shortcut: item.shortcut || '',
-              printer: item.printer || ''
-            }
-          })
-          
-          resolve(_config)
-        }
-      })
-    })
-  }
-
-  changebtnfix = (e) => {
-    let val = e.target.value
-    const { config } = this.props
-    let subconfig = JSON.parse(JSON.stringify(this.state.subconfig))
-
-    subconfig.setting.actionfixed = val === 'true'
-
-    this.setState({
-      subconfig: subconfig
-    })
-    this.props.handleconfig(config.uuid, subconfig)
-  }
-
-  changecolfix = (e) => {
-    let val = e.target.value
-    const { config } = this.props
-    let subconfig = JSON.parse(JSON.stringify(this.state.subconfig))
-
-    subconfig.setting.columnfixed = val === 'true'
-
-    this.setState({
-      subconfig: subconfig
-    })
-    this.props.handleconfig(config.uuid, subconfig)
-  }
-
-  changecheckbox = (val) => {
-    const { config } = this.props
-    let subconfig = JSON.parse(JSON.stringify(this.state.subconfig))
-
-    subconfig.setting.tableType = val
-
-    this.setState({
-      subconfig: subconfig
-    })
-    this.props.handleconfig(config.uuid, subconfig)
-  }
-
   changeEasyCode = ({ target: { value } }) => {
     const { config } = this.props
     let subconfig = JSON.parse(JSON.stringify(this.state.subconfig))
@@ -543,43 +482,18 @@
     }
 
     return (
-      <Tabs defaultActiveKey="1" tabPosition="left" className="verify-card-box-vertical-tab">
-        <TabPane tab="鍩虹璁剧疆" key="1">
+      <Tabs defaultActiveKey="action" tabPosition="left" className="verify-card-box-vertical-tab">
+        {config.type === 'main' ? <TabPane tab="鍩虹璁剧疆" key="1">
           <Form {...formItemLayout}>
             <Row gutter={24}>
-              {config.type === 'main' ? <Col span={9}>
+              <Col span={9}>
                 <Form.Item label="鍔╄鐮�">
                   <Input defaultValue={config.easyCode} placeholder="" autoComplete="off" onChange={this.changeEasyCode}/>
                 </Form.Item>
-              </Col> : null}
-              <Col span={9}>
-                <Form.Item label="琛ㄦ牸灞炴��">
-                  <Select defaultValue={config.setting.tableType} onChange={this.changecheckbox}>
-                    <Select.Option value="">涓嶅彲閫�</Select.Option>
-                    <Select.Option value="radio">鍗曢��</Select.Option>
-                    <Select.Option value="checkbox">澶氶��</Select.Option>
-                  </Select>
-                </Form.Item>
               </Col>
-              {config.type === 'main' ? <Col span={9}>
-                <Form.Item label="鍥哄畾鎸夐挳">
-                  <Radio.Group defaultValue={config.setting.actionfixed ? 'true' : 'false'} onChange={this.changebtnfix}>
-                    <Radio value="true">鏄�</Radio>
-                    <Radio value="false">鍚�</Radio>
-                  </Radio.Group>
-                </Form.Item>
-              </Col> : null}
-              {config.type === 'main' ? <Col span={9}>
-                <Form.Item label="鍥哄畾琛ㄥご">
-                  <Radio.Group defaultValue={config.setting.columnfixed ? 'true' : 'false'} onChange={this.changecolfix}>
-                    <Radio value="true">鏄�</Radio>
-                    <Radio value="false">鍚�</Radio>
-                  </Radio.Group>
-                </Form.Item>
-              </Col> : null}
             </Row>
           </Form>
-        </TabPane>
+        </TabPane> : null}
         <TabPane tab="鎸夐挳璁剧疆" key="action">
           <ActionForm
             dict={this.props.dict}
diff --git a/src/templates/calendarconfig/index.jsx b/src/templates/calendarconfig/index.jsx
index 5929c3f..e0e78ea 100644
--- a/src/templates/calendarconfig/index.jsx
+++ b/src/templates/calendarconfig/index.jsx
@@ -230,19 +230,20 @@
 
   getFuncNames = (data, funcNames, tableNames) => {
     data.forEach(item => {
-      if (item.subfuncs) {
-        this.getFuncNames(item.subfuncs, funcNames, tableNames)
-      } else {
-        if (item.tableName) {
-          tableNames.push(item.tableName)
-        }
-        if (item.innerFunc) {
-          funcNames.push({func: item.innerFunc, label: item.label || ''})
-        }
+      // if (item.subfuncs) {
+      //   this.getFuncNames(item.subfuncs, funcNames, tableNames)
+      //   return
+      // }
 
-        if (item.callbackFunc) {
-          funcNames.push({func: item.callbackFunc, label: item.label || ''})
-        }
+      if (item.tableName) {
+        tableNames.push(item.tableName)
+      }
+      if (item.innerFunc) {
+        funcNames.push({func: item.innerFunc, label: item.label || ''})
+      }
+
+      if (item.callbackFunc) {
+        funcNames.push({func: item.callbackFunc, label: item.label || ''})
       }
     })
 
@@ -322,33 +323,34 @@
     }
 
     new Promise(resolve => {
-      if (_config.tab) {
-        Api.getSystemConfig({
-          func: 'sPC_Get_LongParam',
-          MenuID: _config.tab.linkTab
-        }).then(result => {
-          if (result.status && result.LongParam) {
-            let _LongParam = ''
+      // if (_config.tab) {
+      //   Api.getSystemConfig({
+      //     func: 'sPC_Get_LongParam',
+      //     MenuID: _config.tab.linkTab
+      //   }).then(result => {
+      //     if (result.status && result.LongParam) {
+      //       let _LongParam = ''
   
-            if (result.LongParam) {
-              try {
-                _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
-              } catch (e) {
-                console.warn('Parse Failure')
-                _LongParam = ''
-              }
-            }
+      //       if (result.LongParam) {
+      //         try {
+      //           _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
+      //         } catch (e) {
+      //           console.warn('Parse Failure')
+      //           _LongParam = ''
+      //         }
+      //       }
 
-            if (_LongParam) {
-              _config.funcs[1].menuNo = _LongParam.tabNo || ''
-              _config.funcs[1].subfuncs = _LongParam.funcs || []
-            }
-          }
-          resolve()
-        })
-      } else {
-        resolve()
-      }
+      //       if (_LongParam) {
+      //         _config.funcs[1].menuNo = _LongParam.tabNo || ''
+      //         _config.funcs[1].subfuncs = _LongParam.funcs || []
+      //       }
+      //     }
+      //     resolve()
+      //   })
+      // } else {
+      //   resolve()
+      // }
+      resolve()
     }).then(() => {
       // 淇濆瓨鏃跺垹闄ら厤缃被鍨嬶紝system 銆乽ser
       delete _config.type
diff --git a/src/templates/comtableconfig/index.jsx b/src/templates/comtableconfig/index.jsx
index d637149..e7643b1 100644
--- a/src/templates/comtableconfig/index.jsx
+++ b/src/templates/comtableconfig/index.jsx
@@ -205,19 +205,20 @@
 
   getFuncNames = (data, funcNames, tableNames) => {
     data.forEach(item => {
-      if (item.subfuncs) {
-        this.getFuncNames(item.subfuncs, funcNames, tableNames)
-      } else {
-        if (item.tableName) {
-          tableNames.push(item.tableName)
-        }
-        if (item.innerFunc) {
-          funcNames.push({func: item.innerFunc, label: item.label || ''})
-        }
+      // if (item.subfuncs) {
+      //   this.getFuncNames(item.subfuncs, funcNames, tableNames)
+      //   return
+      // }
+      
+      if (item.tableName) {
+        tableNames.push(item.tableName)
+      }
+      if (item.innerFunc) {
+        funcNames.push({func: item.innerFunc, label: item.label || ''})
+      }
 
-        if (item.callbackFunc) {
-          funcNames.push({func: item.callbackFunc, label: item.label || ''})
-        }
+      if (item.callbackFunc) {
+        funcNames.push({func: item.callbackFunc, label: item.label || ''})
       }
     })
 
@@ -355,46 +356,47 @@
     }
 
     new Promise(resolve => {
-      let deffers = []
-      _config.funcs.forEach(item => {
-        if (item.type === 'tab') {
-          let deffer = new Promise(resolve => {
-            Api.getSystemConfig({
-              func: 'sPC_Get_LongParam',
-              MenuID: item.linkTab
-            }).then(result => {
-              if (result.status && result.LongParam) {
-                let _LongParam = ''
+      // let deffers = []
+      // _config.funcs.forEach(item => {
+      //   if (item.type === 'tab') {
+      //     let deffer = new Promise(resolve => {
+      //       Api.getSystemConfig({
+      //         func: 'sPC_Get_LongParam',
+      //         MenuID: item.linkTab
+      //       }).then(result => {
+      //         if (result.status && result.LongParam) {
+      //           let _LongParam = ''
       
-                if (result.LongParam) {
-                  try {
-                    _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
-                  } catch (e) {
-                    console.warn('Parse Failure')
-                    _LongParam = ''
-                  }
-                }
+      //           if (result.LongParam) {
+      //             try {
+      //               _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
+      //             } catch (e) {
+      //               console.warn('Parse Failure')
+      //               _LongParam = ''
+      //             }
+      //           }
     
-                if (_LongParam) {
-                  item.menuNo = _LongParam.tabNo || ''
-                  item.subfuncs = _LongParam.funcs || []
-                }
-              }
-              resolve()
-            })
-          })
+      //           if (_LongParam) {
+      //             item.menuNo = _LongParam.tabNo || ''
+      //             item.subfuncs = _LongParam.funcs || []
+      //           }
+      //         }
+      //         resolve()
+      //       })
+      //     })
 
-          deffers.push(deffer)
-        }
-      })
+      //     deffers.push(deffer)
+      //   }
+      // })
 
-      if (deffers.length === 0) {
-        resolve()
-      } else {
-        Promise.all(deffers).then(() => {
-          resolve()
-        })
-      }
+      // if (deffers.length === 0) {
+      //   resolve()
+      // } else {
+      //   Promise.all(deffers).then(() => {
+      //     resolve()
+      //   })
+      // }
+      resolve()
     }).then(() => {
       // 淇濆瓨鏃跺垹闄ら厤缃被鍨嬶紝system 銆乽ser
       delete _config.type
@@ -623,10 +625,6 @@
               originMenu: fromJS(_config).toJS()
             })
 
-            this.props.reloadmenu()
-            
-            this.submitAction(btnParam, tabParam)
-
             localParam.func = 'sPC_TrdMenu_AddUpt_For_Local'
             delete localParam.LongParam
             delete localParam.PageParam
@@ -635,7 +633,7 @@
             delete localParam.EasyCode
             delete localParam.open_edition
 
-            Api.getLocalConfig(localParam)
+            this.submitAction(btnParam, tabParam, localParam)
           } else {
             this.setState({
               menuloading: false,
@@ -655,7 +653,7 @@
   /**
    * @description 淇濆瓨鎴栦慨鏀硅彍鍗曟寜閽泦
    */
-  submitAction = (btnParam, tabParam) => {
+  submitAction = (btnParam, tabParam, localParam) => {
     const { config } = this.state
 
     new Promise(resolve => {
@@ -682,29 +680,25 @@
         deffers.push(defer)
       }
 
-      if (deffers.length === 0) {
-        resolve(true)
-      } else {
-        Promise.all(deffers).then(result => {
-          let error = false
-          result.forEach(res => {
-            if (!res.status) {
-              error = res
-            }
-          })
-
-          if (error) {
-            notification.warning({
-              top: 92,
-              message: error.message,
-              duration: 5
-            })
-            resolve(false)
-          } else {
-            resolve(true)
+      Promise.all(deffers).then(result => {
+        let error = false
+        result.forEach(res => {
+          if (!res.status) {
+            error = res
           }
         })
-      }
+
+        if (error) {
+          notification.warning({
+            top: 92,
+            message: error.message,
+            duration: 5
+          })
+          resolve(false)
+        } else {
+          resolve(true)
+        }
+      })
     }).then(response => {
       if (response === false) return response
 
@@ -822,6 +816,8 @@
             menucloseloading: false
           })
         }
+        this.props.reloadmenu()
+        Api.getLocalConfig(localParam)
       } else {
         this.setState({
           menuloading: false,
@@ -1194,7 +1190,7 @@
     const { menu } = this.props
     const { activeKey, config, chartview } = this.state
 
-    const confActions = config.action.filter(_action => !_action.origin && ['pop', 'popview', 'blank', 'tab'].includes(_action.OpenType))
+    const confActions = config.action.filter(_action => !_action.origin && (['pop', 'popview', 'blank'].includes(_action.OpenType) || (_action.OpenType === 'tab' && _action.tabTemplate === 'FormTab')))
 
     let configTabs = []
     config.tabgroups.forEach(group => {
diff --git a/src/templates/sharecomponent/actioncomponent/index.jsx b/src/templates/sharecomponent/actioncomponent/index.jsx
index 7b6ec62..639af29 100644
--- a/src/templates/sharecomponent/actioncomponent/index.jsx
+++ b/src/templates/sharecomponent/actioncomponent/index.jsx
@@ -839,7 +839,7 @@
    * @description 鎸夐挳鍙屽嚮瑙﹀彂瀛愰厤缃�
    */
   btnDoubleClick = (element) => {
-    if (!element.origin && (element.OpenType === 'pop' || element.OpenType === 'popview' || element.OpenType === 'blank')) {
+    if (!element.origin && (element.OpenType === 'pop' || element.OpenType === 'popview' || element.OpenType === 'blank' || (element.OpenType === 'tab' && element.tabTemplate === 'FormTab'))) {
       this.props.setSubConfig(element)
     } else {
       notification.warning({
diff --git a/src/templates/subtableconfig/index.jsx b/src/templates/subtableconfig/index.jsx
index eb3f3da..5a2cebe 100644
--- a/src/templates/subtableconfig/index.jsx
+++ b/src/templates/subtableconfig/index.jsx
@@ -275,49 +275,49 @@
       _config.enabled = false
     }
 
-    _config.funcs = []
+    // _config.funcs = []
 
-    _config.funcs.push({
-      type: 'view',
-      subtype: 'view',
-      uuid: _config.uuid,
-      intertype: _config.setting.interType || 'system',
-      interface: _config.setting.interface || '',
-      tableName: _config.setting.tableName || '',
-      innerFunc: _config.setting.innerFunc || '',
-      outerFunc: _config.setting.outerFunc || ''
-    })
+    // _config.funcs.push({
+    //   type: 'view',
+    //   subtype: 'view',
+    //   uuid: _config.uuid,
+    //   intertype: _config.setting.interType || 'system',
+    //   interface: _config.setting.interface || '',
+    //   tableName: _config.setting.tableName || '',
+    //   innerFunc: _config.setting.innerFunc || '',
+    //   outerFunc: _config.setting.outerFunc || ''
+    // })
 
-    _config.action.forEach(item => {
-      let tablename = item.OpenType === 'excelIn' ? (item.sheet || '') : (item.sql || '')
+    // _config.action.forEach(item => {
+    //   let tablename = item.OpenType === 'excelIn' ? (item.sheet || '') : (item.sql || '')
 
-      if (item.OpenType === 'excelOut' && item.intertype === 'system') {
-        tablename = _config.setting.tableName || ''
-      }
+    //   if (item.OpenType === 'excelOut' && item.intertype === 'system') {
+    //     tablename = _config.setting.tableName || ''
+    //   }
 
-      if (item.OpenType === 'popview') {
-        _config.funcs.push({
-          type: 'tab',
-          subtype: 'btn',
-          uuid: item.uuid,
-          label: item.label,
-          linkTab: item.linkTab
-        })
-      } else {
-        _config.funcs.push({
-          type: 'button',
-          subtype: 'btn',
-          uuid: item.uuid,
-          label: item.label,
-          tableName: tablename,
-          intertype: item.intertype,
-          interface: item.interface || '',
-          innerFunc: item.innerFunc || '',
-          outerFunc: item.outerFunc || '',
-          callbackFunc: item.callbackFunc || ''
-        })
-      }
-    })
+    //   if (item.OpenType === 'popview') {
+    //     _config.funcs.push({
+    //       type: 'tab',
+    //       subtype: 'btn',
+    //       uuid: item.uuid,
+    //       label: item.label,
+    //       linkTab: item.linkTab
+    //     })
+    //   } else {
+    //     _config.funcs.push({
+    //       type: 'button',
+    //       subtype: 'btn',
+    //       uuid: item.uuid,
+    //       label: item.label,
+    //       tableName: tablename,
+    //       intertype: item.intertype,
+    //       interface: item.interface || '',
+    //       innerFunc: item.innerFunc || '',
+    //       outerFunc: item.outerFunc || '',
+    //       callbackFunc: item.callbackFunc || ''
+    //     })
+    //   }
+    // })
 
     if (this.state.closeVisible) { // 鏄剧ず鍏抽棴瀵硅瘽妗嗘椂锛屾ā鎬佹涓繚瀛樻寜閽紝鏄剧ず淇濆瓨涓姸鎬�
       this.setState({
@@ -330,48 +330,48 @@
     }
 
     new Promise(resolve => {
-      let deffers = []
-      _config.funcs.forEach(item => {
-        if (item.type === 'tab') {
-          let deffer = new Promise(resolve => {
-            Api.getSystemConfig({
-              func: 'sPC_Get_LongParam',
-              MenuID: item.linkTab
-            }).then(result => {
-              if (result.status && result.LongParam) {
-                let _LongParam = ''
+      // let deffers = []
+      // _config.funcs.forEach(item => {
+      //   if (item.type === 'tab') {
+      //     let deffer = new Promise(resolve => {
+      //       Api.getSystemConfig({
+      //         func: 'sPC_Get_LongParam',
+      //         MenuID: item.linkTab
+      //       }).then(result => {
+      //         if (result.status && result.LongParam) {
+      //           let _LongParam = ''
       
-                if (result.LongParam) {
-                  try {
-                    _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
-                  } catch (e) {
-                    console.warn('Parse Failure')
-                    _LongParam = ''
-                  }
-                }
+      //           if (result.LongParam) {
+      //             try {
+      //               _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
+      //             } catch (e) {
+      //               console.warn('Parse Failure')
+      //               _LongParam = ''
+      //             }
+      //           }
     
-                if (_LongParam) {
-                  item.menuNo = _LongParam.tabNo
-                  item.subfuncs = _LongParam.funcs || []
-                }
-              }
-              resolve()
-            })
-          })
+      //           if (_LongParam) {
+      //             item.menuNo = _LongParam.tabNo
+      //             item.subfuncs = _LongParam.funcs || []
+      //           }
+      //         }
+      //         resolve()
+      //       })
+      //     })
 
-          deffers.push(deffer)
-        }
-      })
+      //     deffers.push(deffer)
+      //   }
+      // })
 
-      if (deffers.length === 0) {
-        resolve()
-      } else {
-        Promise.all(deffers).then(() => {
-          resolve()
-        })
-      }
+      // if (deffers.length === 0) {
+      //   resolve()
+      // } else {
+      //   Promise.all(deffers).then(() => {
+      //     resolve()
+      //   })
+      // }
+      resolve()
     }).then(() => {
-
       // 淇濆瓨鏃跺垹闄ら厤缃被鍨嬶紝system 銆乽ser
       delete _config.type
       delete _config.isAdd
diff --git a/src/templates/treepageconfig/index.jsx b/src/templates/treepageconfig/index.jsx
index 4b887e6..24d2716 100644
--- a/src/templates/treepageconfig/index.jsx
+++ b/src/templates/treepageconfig/index.jsx
@@ -166,19 +166,19 @@
 
   getFuncNames = (data, funcNames, tableNames) => {
     data.forEach(item => {
-      if (item.subfuncs) {
-        this.getFuncNames(item.subfuncs, funcNames, tableNames)
-      } else {
-        if (item.tableName) {
-          tableNames.push(item.tableName)
-        }
-        if (item.innerFunc) {
-          funcNames.push({func: item.innerFunc, label: item.label || ''})
-        }
+      // if (item.subfuncs) {
+      //   this.getFuncNames(item.subfuncs, funcNames, tableNames)
+      //   return
+      // }
+      if (item.tableName) {
+        tableNames.push(item.tableName)
+      }
+      if (item.innerFunc) {
+        funcNames.push({func: item.innerFunc, label: item.label || ''})
+      }
 
-        if (item.callbackFunc) {
-          funcNames.push({func: item.callbackFunc, label: item.label || ''})
-        }
+      if (item.callbackFunc) {
+        funcNames.push({func: item.callbackFunc, label: item.label || ''})
       }
     })
 
@@ -267,46 +267,47 @@
     }
 
     new Promise(resolve => {
-      let deffers = []
-      _config.funcs.forEach(item => {
-        if (item.type === 'tab') {
-          let deffer = new Promise(resolve => {
-            Api.getSystemConfig({
-              func: 'sPC_Get_LongParam',
-              MenuID: item.linkTab
-            }).then(result => {
-              if (result.status && result.LongParam) {
-                let _LongParam = ''
+      // let deffers = []
+      // _config.funcs.forEach(item => {
+      //   if (item.type === 'tab') {
+      //     let deffer = new Promise(resolve => {
+      //       Api.getSystemConfig({
+      //         func: 'sPC_Get_LongParam',
+      //         MenuID: item.linkTab
+      //       }).then(result => {
+      //         if (result.status && result.LongParam) {
+      //           let _LongParam = ''
       
-                if (result.LongParam) {
-                  try {
-                    _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
-                  } catch (e) {
-                    console.warn('Parse Failure')
-                    _LongParam = ''
-                  }
-                }
+      //           if (result.LongParam) {
+      //             try {
+      //               _LongParam = JSON.parse(window.decodeURIComponent(window.atob(result.LongParam)))
+      //             } catch (e) {
+      //               console.warn('Parse Failure')
+      //               _LongParam = ''
+      //             }
+      //           }
     
-                if (_LongParam) {
-                  item.menuNo = _LongParam.tabNo || ''
-                  item.subfuncs = _LongParam.funcs || []
-                }
-              }
-              resolve()
-            })
-          })
+      //           if (_LongParam) {
+      //             item.menuNo = _LongParam.tabNo || ''
+      //             item.subfuncs = _LongParam.funcs || []
+      //           }
+      //         }
+      //         resolve()
+      //       })
+      //     })
 
-          deffers.push(deffer)
-        }
-      })
+      //     deffers.push(deffer)
+      //   }
+      // })
 
-      if (deffers.length === 0) {
-        resolve()
-      } else {
-        Promise.all(deffers).then(() => {
-          resolve()
-        })
-      }
+      // if (deffers.length === 0) {
+      //   resolve()
+      // } else {
+      //   Promise.all(deffers).then(() => {
+      //     resolve()
+      //   })
+      // }
+      resolve()
     }).then(() => {
       // 淇濆瓨鏃跺垹闄ら厤缃被鍨嬶紝system 銆乽ser
       delete _config.type
@@ -437,6 +438,13 @@
       }).then(resp => {
         if (resp === false) return
         let localParam = fromJS(param).toJS()
+        localParam.func = 'sPC_TrdMenu_AddUpt_For_Local'
+        delete localParam.LongParam
+        delete localParam.PageParam
+        delete localParam.Template
+        delete localParam.Sort
+        delete localParam.EasyCode
+        delete localParam.open_edition
 
         Api.getSystemConfig(param).then(response => {
           if (response.status) {
@@ -446,8 +454,6 @@
               originMenu: fromJS(_config).toJS()
             })
 
-            this.props.reloadmenu()
-            
             // 瀛樺湪鏍囩椤垫椂
             if (tabParam.LText) {
               Api.getSystemConfig(tabParam).then(result => {
@@ -457,6 +463,10 @@
                     message: '淇濆瓨鎴愬姛',
                     duration: 2
                   })
+
+                  this.props.reloadmenu()
+                  Api.getLocalConfig(localParam)
+
                   if (this.state.closeVisible) {
                     this.props.handleView()
                   } else {
@@ -483,6 +493,10 @@
                 message: '淇濆瓨鎴愬姛',
                 duration: 2
               })
+
+              this.props.reloadmenu()
+              Api.getLocalConfig(localParam)
+
               if (this.state.closeVisible) {
                 this.props.handleView()
               } else {
@@ -492,16 +506,6 @@
                 })
               }
             }
-
-            localParam.func = 'sPC_TrdMenu_AddUpt_For_Local'
-            delete localParam.LongParam
-            delete localParam.PageParam
-            delete localParam.Template
-            delete localParam.Sort
-            delete localParam.EasyCode
-            delete localParam.open_edition
-
-            Api.getLocalConfig(localParam)
           } else {
             this.setState({
               menuloading: false,
diff --git a/src/templates/zshare/formconfig.jsx b/src/templates/zshare/formconfig.jsx
index 8bde153..b50d21e 100644
--- a/src/templates/zshare/formconfig.jsx
+++ b/src/templates/zshare/formconfig.jsx
@@ -697,7 +697,7 @@
         text: Formdict['header.form.func.changeuser']
       }, {
         value: 'print',
-        text: Formdict['header.form.func.print']
+        text: '鏍囩鎵撳嵃'
       }]
     },
     {

--
Gitblit v1.8.0