From c8804ceb1fe2dea76f9949c5ea04423876ee2c81 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期五, 28 六月 2024 14:02:47 +0800
Subject: [PATCH] 2024-06-28

---
 src/views/pcdesign/index.jsx | 1589 +++++++++++++++++++++++++++-------------------------------
 1 files changed, 746 insertions(+), 843 deletions(-)

diff --git a/src/views/pcdesign/index.jsx b/src/views/pcdesign/index.jsx
index 5210249..d998c92 100644
--- a/src/views/pcdesign/index.jsx
+++ b/src/views/pcdesign/index.jsx
@@ -2,17 +2,15 @@
 import { DndProvider } from 'react-dnd'
 import { withRouter } from 'react-router'
 import { is, fromJS } from 'immutable'
-import moment from 'moment'
 import HTML5Backend from 'react-dnd-html5-backend'
-import { ConfigProvider, notification, Modal, Collapse, Switch, Button, message, Spin, Typography } from 'antd'
-import { DoubleLeftOutlined, DoubleRightOutlined, HomeOutlined, LoginOutlined, RedoOutlined, ArrowLeftOutlined, EyeOutlined, EyeInvisibleOutlined } from '@ant-design/icons'
+import { notification, Modal, Collapse, Switch, Button, message, Spin, Typography } from 'antd'
+import { DoubleLeftOutlined, DoubleRightOutlined, HomeOutlined, LoginOutlined, ArrowLeftOutlined, EyeOutlined, EyeInvisibleOutlined } from '@ant-design/icons'
+import moment from 'moment'
+import md5 from 'md5'
 
 import Api from '@/api'
 import Utils, { setGLOBFuncs } from '@/utils/utils.js'
-import zhCN from '@/locales/zh-CN/mob.js'
-import enUS from '@/locales/en-US/mob.js'
-import antdEnUS from 'antd/es/locale/en_US'
-import antdZhCN from 'antd/es/locale/zh_CN'
+import { getTables, getFuncsAndInters, getLangTrans } from '@/utils/utils-custom.js'
 import MKEmitter from '@/utils/events.js'
 import MenuUtils from '@/utils/utils-custom.js'
 import asyncComponent from '@/utils/asyncComponent'
@@ -25,17 +23,23 @@
 const { Paragraph } = Typography
 
 const MenuForm = asyncComponent(() => import('./menuform'))
+const Debug = asyncComponent(() => import('@/menu/debug'))
+const Header = asyncComponent(() => import('@/menu/header'))
+const PopView = asyncComponent(() => import('@/views/menudesign/popview'))
 const Transfer = asyncComponent(() => import('@/pc/transfer'))
 const Versions = asyncComponent(() => import('@/menu/versions'))
 const MenuShell = asyncComponent(() => import('@/pc/menushell'))
 const ViewNodes = asyncComponent(() => import('@/menu/viewnodes'))
 const SourceWrap = asyncComponent(() => import('@/pc/modulesource'))
+const Modulecell = asyncComponent(() => import('@/menu/modulecell'))
+const TableNodes = asyncComponent(() => import('@/menu/tablenodes'))
 const CreateView = asyncComponent(() => import('@/pc/createview'))
 const BgController = asyncComponent(() => import('@/pc/bgcontroller'))
 const Quotecomponent = asyncComponent(() => import('@/pc/quotecomponent'))
 const PasteController = asyncComponent(() => import('@/menu/pastecontroller'))
 const StyleController = asyncComponent(() => import('@/menu/stylecontroller'))
 const ReplaceField = asyncComponent(() => import('@/menu/replaceField'))
+const NormalCss = asyncComponent(() => import('@/menu/normalCss'))
 const SysInterface = asyncComponent(() => import('@/menu/sysinterface'))
 const UrlFieldComponent = asyncComponent(() => import('@/menu/urlfieldcomponent'))
 const PictureController = asyncComponent(() => import('@/menu/picturecontroller'))
@@ -44,62 +48,77 @@
 const StyleCombControlButton = asyncComponent(() => import('@/menu/stylecombcontrolbutton'))
 const TableComponent = asyncComponent(() => import('@/templates/sharecomponent/tablecomponent'))
 
-sessionStorage.setItem('isEditState', 'true')
-
 sessionStorage.setItem('appType', 'pc')        // 搴旂敤绫诲瀷
 sessionStorage.setItem('typename', 'pc')
 document.body.className = ''
 
-const memberLevel = Utils.getMemberLevel()
-
 class MenuDesign extends Component {
   state = {
-    localedict: sessionStorage.getItem('lang') !== 'en-US' ? antdZhCN : antdEnUS,
-    dict: sessionStorage.getItem('lang') !== 'en-US' ? zhCN : enUS,
     loading: true,
     MenuId: '',
     MenuName: '',
     MenuNo: '',
-    delButtons: [],
-    copyButtons: [],
     activeKey: 'basedata',
     menuloading: false,
     oriConfig: null,
     config: null,
-    customComponents: [],
     settingshow: sessionStorage.getItem('settingshow') !== 'false',
     controlshow: sessionStorage.getItem('controlshow') !== 'false',
     comloading: false,
     eyeopen: false,
-    modalStatus: false       // 寮圭獥鏄惁寮�鍚紝鍒ゆ柇ctrl+s鏄惁鍙敤
+    view: '',
+    popConfig: null,
+    needUpdate: false
   }
 
   UNSAFE_componentWillMount() {
-    if (memberLevel < 30) return
+    if (sessionStorage.getItem('devError') === 'true') {
+      sessionStorage.clear()
+      window.history.replaceState(null, null, window.location.href.split('#')[0] + '#/login')
+      window.location.reload()
+      return
+    }
+    
+    if (!sessionStorage.getItem('UserID')) {
+      sessionStorage.removeItem('appType')
+      this.props.history.replace('/login')
+      return
+    }
+    
+    if (window.GLOB.memberLevel < 30) return
 
     sessionStorage.setItem('editMenuType', 'menu') // 缂栬緫鑿滃崟绫诲瀷
 
-    window.GLOB.UserComponentMap = new Map() // 缂撳瓨鐢ㄦ埛鑷畾涔夌粍浠�
+    window.GLOB.curDate = moment().format('YYYY-MM-DD')
     window.GLOB.TabsMap = new Map()          // 缂撳瓨鐢ㄦ埛鎿嶄綔鐨勬爣绛鹃〉
     window.GLOB.CacheIndependent = new Map()
     window.GLOB.urlFields = []               // url鍙橀噺
     window.GLOB.customMenu = null            // 淇濆瓨鑿滃崟淇℃伅
+    window.GLOB.developing = true
 
     try {
       let param = JSON.parse(window.decodeURIComponent(window.atob(this.props.match.params.param)))
 
+      if (param.lang) {
+        sessionStorage.setItem('lang', param.lang)
+      }
+
       if (param.type === 'app') {
         sessionStorage.setItem('appId', param.ID || '')
-        sessionStorage.setItem('lang', param.lang || 'zh-CN')
+        sessionStorage.setItem('appName', param.remark || '')
         sessionStorage.setItem('kei_no', param.kei_no || '')
-        sessionStorage.setItem('role_type', param.role_type || 'true')
-        sessionStorage.setItem('login_types', param.login_types || 'false')
         sessionStorage.setItem('sysBgColor', param.sysBgColor || '#ffffff')
 
-        this.setState({
-          localedict: sessionStorage.getItem('lang') !== 'en-US' ? antdZhCN : antdEnUS,
-          dict: sessionStorage.getItem('lang') !== 'en-US' ? zhCN : enUS
-        })
+        if (param.applangList) {
+          sessionStorage.setItem('applangList', param.applangList)
+        } else {
+          sessionStorage.removeItem('applangList')
+        }
+
+        if (param.wxAppId) {
+          sessionStorage.setItem('wxAppId', param.wxAppId)
+        }
+
         this.getAppMessage(param.MenuID)
       } else if (param.type === 'view') {
         this.setState({
@@ -128,29 +147,20 @@
   }
 
   componentDidMount () {
-    if (memberLevel < 30) {
+    if (!sessionStorage.getItem('UserID')) return
+    if (window.GLOB.memberLevel < 30) {
       document.getElementById('mk-pc-design-view').innerHTML = '<div style="text-align: center; font-size: 30px; margin-top: 40vh; height: 100vh; background: #fff;">鏈簲鐢ㄦ病鏈塒C绔〉闈㈢殑缂栬緫鏉冮檺锛岃鑱旂郴绠$悊鍛橈紒</div>'
       return
     }
-    MKEmitter.addListener('delButtons', this.delButtons)
-    MKEmitter.addListener('modalStatus', this.modalStatus)
-    MKEmitter.addListener('copyButtons', this.copyButtons)
     MKEmitter.addListener('changePopview', this.initPopview)
     MKEmitter.addListener('changeEditMenu', this.changeEditMenu)
     MKEmitter.addListener('triggerMenuSave', this.triggerMenuSave)
-    MKEmitter.addListener('submitComponentStyle', this.updateComponentStyle)
-    MKEmitter.addListener('updateCustomComponent', this.updateCustomComponent)
-    setTimeout(() => {
-      if (sessionStorage.getItem('app_custom_components')) {
-        let list = sessionStorage.getItem('app_custom_components')
-        list = JSON.parse(list)
 
-        this.setCustomComponent(list)
-      } else {
-        this.updateCustomComponent()
-      }
-      this.getAppPictures()
-      this.getSmStemp()
+    if (sessionStorage.getItem('wxAppId')) {
+      window.GLOB.WXAppID = sessionStorage.getItem('wxAppId')
+    }
+
+    setTimeout(() => {
       this.getRoleFields()
       setGLOBFuncs()
     }, 1000)
@@ -174,10 +184,23 @@
       let _shortcut = `${preKey}+${keyCode}`
 
       if (_shortcut === 'ctrl+83') {
-        if (this.state.modalStatus) {
+        let modals = document.querySelectorAll('.mk-pop-modal')
+        let msg = null
+        for (let i = 0; i < modals.length; i++) {
+          if (msg) {
+            break
+          }
+
+          let node = modals[i].querySelector('.mk-com-name')
+
+          if (node) {
+            msg = node.innerText
+          }
+        }
+        if (msg) {
           notification.warning({
             top: 92,
-            message: '璇蜂繚瀛�' + this.state.modalStatus,
+            message: '璇蜂繚瀛�' + msg,
             duration: 5
           })
           return false
@@ -206,21 +229,14 @@
     this.setState = () => {
       return
     }
-    MKEmitter.removeListener('delButtons', this.delButtons)
-    MKEmitter.removeListener('modalStatus', this.modalStatus)
-    MKEmitter.removeListener('copyButtons', this.copyButtons)
     MKEmitter.removeListener('changePopview', this.initPopview)
     MKEmitter.removeListener('changeEditMenu', this.changeEditMenu)
     MKEmitter.removeListener('triggerMenuSave', this.triggerMenuSave)
-    MKEmitter.removeListener('submitComponentStyle', this.updateComponentStyle)
-    MKEmitter.removeListener('updateCustomComponent', this.updateCustomComponent)
-  }
-
-  modalStatus = (val) => {
-    this.setState({modalStatus: val})
   }
 
   triggerMenuSave = () => {
+    if (this.state.view === 'popview') return
+
     this.submitConfig()
   }
 
@@ -240,7 +256,8 @@
       MenuID: menu.MenuID,
       copyMenuId: menu.copyMenuId || '',
       clearMenu: menu.clearMenu !== 'false',
-      type: 'view'
+      type: 'view',
+      lang: sessionStorage.getItem('lang')
     }
 
     // param.MenuNo = menu.MenuNo || ''
@@ -257,7 +274,7 @@
   }
 
   getAppMessage = (MenuID) => {
-    Api.getSystemConfig({
+    Api.getCloudConfig({
       func: 's_get_keyids',
       bid: sessionStorage.getItem('appId')
     }).then(res => {
@@ -287,7 +304,7 @@
         let param = {
           func: 's_kei_link_keyids_addupt',
           BID: sessionStorage.getItem('appId'),
-          exec_type: 'y',
+          exec_type: 'x',
           LText: ''
         }
 
@@ -302,12 +319,12 @@
 
         param.LText = appViewList.map(item => `select '${item.keys_id}','${item.keys_type}','${item.kei_no}','${item.appkey}','${item.bid}','${sessionStorage.getItem('CloudUserID')}','${item.remark}'`)
         param.LText = param.LText.join(' union all ')
-        param.LText = Utils.formatOptions(param.LText)
+        param.LText = Utils.formatOptions(param.LText, 'x')
   
         param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
         param.secretkey = Utils.encrypt('', param.timestamp)
 
-        Api.getSystemConfig(param).then(result => {
+        Api.getCloudConfig(param).then(result => {
           if (!result.status) {
             notification.warning({
               top: 92,
@@ -316,245 +333,130 @@
             })
           } else {
             sessionStorage.setItem('appViewList', JSON.stringify(appViewList))
-            this.props.history.replace('/pcdesign/' + window.btoa(window.encodeURIComponent(JSON.stringify({MenuID: homeId, type: 'view'}))))
+            this.props.history.replace('/pcdesign/' + window.btoa(window.encodeURIComponent(JSON.stringify({MenuID: homeId, type: 'view', lang: sessionStorage.getItem('lang')}))))
           }
         })
       } else {
         sessionStorage.setItem('appViewList', JSON.stringify(appViewList))
-        this.props.history.replace('/pcdesign/' + window.btoa(window.encodeURIComponent(JSON.stringify({MenuID: MenuID || homeId, type: 'view'}))))
+        this.props.history.replace('/pcdesign/' + window.btoa(window.encodeURIComponent(JSON.stringify({MenuID: MenuID || homeId, type: 'view', lang: sessionStorage.getItem('lang')}))))
       }
     })
-  }
-
-  getSmStemp = () => {
-    if (!sessionStorage.getItem('msgTemplate')) {
-      let _sql = `select ID,TemplateCode,SignName from (select * from bd_msn_sms_temp where deleted=0 and status=20 ) a 
-        inner join (select openid from sapp where id='${window.GLOB.appkey}') b
-        on a.openid=b.openid`
-  
-      _sql = Utils.formatOptions(_sql)
-  
-      let param = {
-        func: 'sPC_Get_SelectedList',
-        LText: _sql,
-        obj_name: 'data',
-        arr_field: 'ID,TemplateCode,SignName'
-      }
-      
-      param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
-      param.secretkey = Utils.encrypt(param.LText, param.timestamp)
-      param.open_key = Utils.encryptOpenKey(param.secretkey, param.timestamp) // 浜戠鏁版嵁楠岃瘉
-      
-      Api.getSystemConfig(param).then(res => {
-        let msgs = []
-        if (!res.status) {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-        } else if (res.data) {
-          msgs = res.data
-          sessionStorage.setItem('msgTemplate', JSON.stringify(msgs))
-        }
-      })
-    }
-
-    if (!sessionStorage.getItem('printTemps')) {
-      let _sql = `select ID,Images,PrintTempNO+PrintTempName as PN from sPrintTemplate 
-      where appkey= @appkey@ and Deleted=0 and typechartwo='web_print'
-      union select ID,Images,a.PrintTempNO+PrintTempName as PN 
-      from (select * from sPrintTemplate where appkey= '' and Deleted=0 and typechartwo='web_print') a 
-      left join (select PrintTempNO from sPrintTemplate where appkey= @appkey@ and Deleted=0 ) b 
-      on a.PrintTempNO=b.PrintTempNO 
-      left join (select Srcid from sPrintTemplate_Log where appkey='' and apicode= @appkey@ and Deleted=0 ) c 
-      on a.ID=c.Srcid where b.PrintTempNO is null and c.Srcid is null`
-  
-      let param = {
-        func: 'sPC_Get_SelectedList',
-        LText: Utils.formatOptions(_sql),
-        obj_name: 'data',
-        arr_field: 'PN,ID,Images'
-      }
-  
-      param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
-      param.secretkey = Utils.encrypt(param.LText, param.timestamp)
-  
-      param.open_key = Utils.encryptOpenKey(param.secretkey, param.timestamp) // 浜戠鏁版嵁楠岃瘉
-  
-      Api.getSystemConfig(param).then(res => {
-        if (res.status) {
-          let temps = res.data.map(temp => {
-            return {
-              value: temp.ID,
-              text: temp.PN
-            }
-          })
-  
-          sessionStorage.setItem('printTemps', JSON.stringify(temps))
-        } else {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-        }
-      })
-    }
-  }
-
-  getAppPictures = () => {
-    if (sessionStorage.getItem('app_videos') || sessionStorage.getItem('app_pictures')) return
-
-    Api.getSystemConfig({
-      func: 's_url_db_adduptdel',
-      PageIndex: 0,  // 0 浠h〃鍏ㄩ儴
-      PageSize: 0,   // 0 浠h〃鍏ㄩ儴
-      typecharone: 'image',
-      type: 'search'
-    }).then(res => {
-      if (res.status) {
-        sessionStorage.setItem('app_pictures', JSON.stringify(res.data || []))
-      } else if (!res.status) {
-        notification.warning({
-          top: 92,
-          message: res.message,
-          duration: 5
-        })
-      }
-
-      Api.getSystemConfig({
-        func: 's_url_db_adduptdel',
-        PageIndex: 0,  // 0 浠h〃鍏ㄩ儴
-        PageSize: 0,   // 0 浠h〃鍏ㄩ儴
-        typecharone: 'video',
-        type: 'search'
-      }).then(res => {
-        if (res.status) {
-          sessionStorage.setItem('app_videos', JSON.stringify(res.data || []))
-        } else if (!res.status) {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-        }
-      })
-      Api.getSystemConfig({
-        func: 's_url_db_adduptdel',
-        PageIndex: 0,  // 0 浠h〃鍏ㄩ儴
-        PageSize: 0,   // 0 浠h〃鍏ㄩ儴
-        typecharone: 'color',
-        type: 'search'
-      }).then(res => {
-        if (res.status) {
-          sessionStorage.setItem('app_colors', JSON.stringify(res.data || []))
-        } else if (!res.status) {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-        }
-      })
-    })
-  }
-
-  updateCustomComponent = () => {
-    Api.getSystemConfig({
-      func: 's_get_custom_components',
-      typename: 'pc',
-      typecharone: ''
-    }).then(res => {
-      if (!res.status) {
-        notification.warning({
-          top: 92,
-          message: res.message,
-          duration: 5
-        })
-      } else if (res.cus_list) {
-        sessionStorage.setItem('app_custom_components', JSON.stringify(res.cus_list))
-        this.setCustomComponent(res.cus_list)
-      }
-    })
-  }
-
-  setCustomComponent = (cus_list) => {
-    let coms = []
-
-    cus_list.forEach(item => {
-      let config = ''
-
-      try {
-        config = JSON.parse(window.decodeURIComponent(window.atob(item.long_param)))
-      } catch (e) {
-        console.warn('Parse Failure')
-        config = ''
-      }
-
-      if (!config || !item.c_name) return
-
-      window.GLOB.UserComponentMap.set(item.c_id, item.c_name)
-      coms.push({
-        uuid: item.c_id,
-        type: 'menu',
-        title: item.c_name,
-        url: item.images,
-        component: config.type,
-        subtype: config.subtype,
-        config
-      })
-    })
-    this.setState({customComponents: coms})
-  }
-
-  updateComponentStyle = (parentId, keys, style) => {
-    const { config } = this.state
-
-    if (config.uuid !== parentId) return
-
-    let components = config.components.map(item => {
-      if (keys.includes(item.uuid)) {
-        item.style = {...item.style, ...style}
-      }
-      return item
-    })
-
-    this.setState({
-      config: {...config, components},
-      comloading: true
-    }, () => {
-      this.setState({
-        comloading: false
-      })
-    })
-  }
-
-  delButtons = (items) => {
-    this.setState({ delButtons: [...this.state.delButtons, ...items] })
-  }
-
-  copyButtons = (items) => {
-    this.setState({copyButtons: [...this.state.copyButtons, ...items]})
   }
 
   initPopview = (card, btn) => {
-    const { oriConfig, config } = this.state
+    const { config } = this.state
 
-    if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) {
-      notification.warning({
-        top: 92,
-        message: '閰嶇疆淇℃伅鏈繚瀛橈紒',
-        duration: 5
-      })
+    if (!this.checkBase()) {
       return
     }
 
     let _btn = fromJS(btn).toJS()
-    _btn.MenuName = config.MenuName + '-' + card.name + '-' + btn.label
-    _btn.ParentMenuID = config.uuid
 
-    this.props.history.push('/popdesign/' + window.btoa(window.encodeURIComponent((JSON.stringify(_btn)))))
+    if (_btn.config) {
+      _btn.config.uuid = _btn.uuid
+      _btn.config.MenuID = _btn.uuid
+      _btn.config.ParentId = card.uuid
+      _btn.config.MenuName = _btn.label
+
+      _btn.config.components = this.updateComponents(_btn.config.components || [])
+    } else {
+      _btn.config = {
+        uuid: _btn.uuid,
+        MenuID: _btn.uuid,
+        ParentId: card.uuid,
+        enabled: false,
+        MenuName: _btn.label,
+        tables: config.tables || [],
+        Template: 'CustomPage',
+        components: [],
+        viewType: 'popview',
+        style: { backgroundColor: '#ffffff', backgroundImage: '', paddingTop: '16px', paddingBottom: '40px', paddingLeft: '16px', paddingRight: '16px' }
+      }
+    }
+
+    this.setState({view: 'popview', popConfig: _btn})
+  }
+
+  submitPopConfig = (btnconfig) => {
+    let parents = {[btnconfig.ParentId]: true}
+    let popbtns = {[btnconfig.uuid]: fromJS(btnconfig).toJS()}
+    let config = fromJS(this.state.config).toJS()
+
+    config.components = this.setPopView(config.components, parents, popbtns)
+
+    this.setState({ config }, () => {
+      this.submitConfig()
+    })
+  }
+
+  setPopView = (components, parents, popbtns) => {
+    return components.map(item => {
+      if (item.type === 'tabs') {
+        item.subtabs.forEach(tab => {
+          tab.components = this.setPopView(tab.components, parents, popbtns)
+        })
+      } else if (item.type === 'group') {
+        item.components = this.setPopView(item.components, parents, popbtns)
+      } else if (parents[item.uuid]) {
+        this.setpopConfig(item, popbtns)
+      }
+      return item
+    })
+  }
+
+  setpopConfig = (config, popbtns) => {
+    config.subcards && config.subcards.forEach(item => {
+      item.elements.forEach(cell => {
+        if (cell.eleType !== 'button') return
+        if (cell.OpenType === 'popview' && popbtns[cell.uuid]) {
+          cell.config = popbtns[cell.uuid]
+        }
+      })
+    })
+
+    if (config.cols) {
+      let loopCol = (cols) => {
+        cols.forEach(col => {
+          if (col.type === 'colspan') {
+            loopCol(col.subcols)
+          } else if (col.type === 'custom') {
+            col.elements.forEach(cell => {
+              if (cell.eleType !== 'button') return
+              if (cell.OpenType === 'popview' && popbtns[cell.uuid]) {
+                cell.config = popbtns[cell.uuid]
+              }
+            })
+          }
+        })
+      }
+      loopCol(config.cols)
+    }
+
+    config.elements && config.elements.forEach(cell => {
+      if (cell.eleType !== 'button') return
+      if (cell.OpenType === 'popview' && popbtns[cell.uuid]) {
+        cell.config = popbtns[cell.uuid]
+      }
+    })
+  
+    config.action && config.action.forEach(cell => {
+      if (cell.OpenType === 'popview' && popbtns[cell.uuid]) {
+        cell.config = popbtns[cell.uuid]
+      }
+    })
+
+    config.$tables = getTables(config)
+  }
+
+  closePop = () => {
+    const {config} = this.state
+
+    sessionStorage.setItem('editMenuType', 'menu')
+
+    window.GLOB.urlFields = config.urlFields || []
+    window.GLOB.customMenu = config
+
+    this.setState({view: '', popConfig: null})
   }
 
   closeView = () => {
@@ -605,7 +507,7 @@
       MenuID: MenuId
     }
 
-    Api.getSystemConfig(param).then(result => {
+    Api.getCloudConfig(param).then(result => {
       if (!result.status) {
         notification.warning({
           top: 92,
@@ -618,7 +520,6 @@
         this.getCopyParam(urlParam)
       } else {
         let config = null
-        let isCreate = false
 
         try {
           config = result.LongParam ? JSON.parse(window.decodeURIComponent(window.atob(result.LongParam))) : null
@@ -628,9 +529,8 @@
         }
 
         if (!config) {
-          isCreate = true
           config = {
-            version: 1.0,
+            version: 2.0,
             uuid: MenuId,
             MenuID: MenuId,
             Template: 'webPage',
@@ -648,30 +548,100 @@
 
         config.uuid = MenuId
         config.MenuID = MenuId
+        config.Template = 'webPage'
         config.open_edition = result.open_edition || ''
         window.GLOB.urlFields = config.urlFields || []
 
-        let indeComs = []
+        if (config.version !== 2.0) {
+          config.components = this.collectTB(config.components)
+          config.version = 2.0
+
+          this.setState({
+            needUpdate: true
+          })
+        } else {
+          config.components = this.updateComponents(config.components)
+        }
+
+        let navItem = null
         config.components.forEach(item => {
           if (item.type === 'navbar') {
-            indeComs.push(fromJS(item).toJS())
+            navItem = fromJS(item).toJS()
           }
         })
 
-        if (indeComs.length === 0) {
+        if (!navItem) {
           this.setState({
-            oriConfig: isCreate ? null : config,
-            config: fromJS(config).toJS(),
+            oriConfig: fromJS(config).toJS(),
+            config: config,
             loading: false
           })
 
           window.GLOB.customMenu = config
         } else {
-          this.jointComponents(config, indeComs, isCreate)
+          this.jointComponents(config, navItem)
         }
       }
     })
     this.getAppMenus()
+  }
+
+  updateComponents = (components) => { // 鍏煎鎬у崌绾� table
+    return components.map(item => {
+      if (item.type === 'tabs') {
+        item.subtabs.forEach(tab => {
+          tab.components = this.updateComponents(tab.components)
+        })
+      } else if (item.type === 'group') {
+        item.components = this.updateComponents(item.components)
+      } else if (item.type === 'table') {
+        item.cols = item.cols.map(col => {
+          if (col.type === 'action') {
+            col.type = 'custom'
+          }
+          return col
+        })
+      }
+
+      return item
+    })
+  }
+
+  collectTB = (components) => {
+    return components.map(item => {
+      if (item.type === 'tabs') {
+        item.subtabs.forEach(tab => {
+          delete tab.floor
+          delete tab.hasSearch
+          delete tab.parentId
+
+          tab.components = this.collectTB(tab.components)
+        })
+      } else if (item.type === 'group') {
+        item.components = this.collectTB(item.components)
+      } else if (!['search', 'navbar', 'login', 'topbar', 'officialAccount'].includes(item.type)) {
+        item.$tables = getTables(item)
+      }
+
+      if (item.subtype === 'tablecard') { // 鍏煎
+        item.type = 'card'
+      } else if (item.type === 'table') {
+        item.cols = item.cols.map(col => {
+          if (col.type === 'action') {
+            col.type = 'custom'
+          }
+          return col
+        })
+      }
+
+      delete item.tabId
+      delete item.parentId
+      delete item.btnlog
+      delete item.floor
+      delete item.dataName
+
+      return item
+    })
   }
 
   getAppMenus = () => {
@@ -685,7 +655,7 @@
 
     _param.secretkey = Utils.encrypt(_param.LText, _param.timestamp)
 
-    Api.getSystemConfig(_param).then(res => {
+    Api.getCloudConfig(_param).then(res => {
       if (!res.status) {
         notification.warning({
           top: 92,
@@ -697,12 +667,16 @@
 
       let appIndeList = sessionStorage.getItem('appViewList')
       appIndeList = JSON.parse(appIndeList)
-      appIndeList = appIndeList.map(item => (item.keys_type !== 'index' ? item.keys_id : '')).join(',')
+      appIndeList = appIndeList.map(item => (item.keys_type === 'navbar' ? item.keys_id : '')).join(',')
 
       let menus = res.menus.filter(item => appIndeList.indexOf(item.MenuID) === -1)
       menus = menus.map(item => {
         item.value = item.MenuID
-        item.label = item.MenuName
+        if (item.MenuNo) {
+          item.label = item.MenuName + '锛�' + item.MenuNo + '锛�'
+        } else {
+          item.label = item.MenuName
+        }
         return item
       })
       sessionStorage.setItem('appMenus', JSON.stringify(menus))
@@ -720,7 +694,7 @@
       MenuID: urlParam.copyMenuId
     }
 
-    Api.getSystemConfig(param).then(result => {
+    Api.getCloudConfig(param).then(result => {
       if (!result.status) {
         notification.warning({
           top: 92,
@@ -729,12 +703,6 @@
         })
         this.setState({loading: false})
         return
-      } else if (!result.LongParam) {
-        notification.warning({
-          top: 92,
-          message: '鏈煡璇㈠埌澶嶅埗鑿滃崟閰嶇疆淇℃伅锛�',
-          duration: 5
-        })
       }
 
       let config = null
@@ -745,11 +713,10 @@
         console.warn('Parse Failure')
         config = null
       }
-
       
       if (!config) {
         config = {
-          version: 1.0,
+          version: 2.0,
           uuid: MenuId,
           MenuID: MenuId,
           Template: 'webPage',
@@ -764,63 +731,71 @@
           }
         }
       } else {
-        config.components = MenuUtils.resetConfig(config.components, {}, urlParam.clearMenu)
+        let commonId = Utils.getuuid()
+        if (config.interfaces && config.interfaces.length > 0) {
+          config.interfaces = config.interfaces.map(inter => {
+            inter.uuid = md5(commonId + inter.uuid)
+            return inter
+          })
+        }
+        config.components = MenuUtils.resetConfig(config.components, commonId, urlParam.clearMenu)
+
+        if (config.version !== 2.0) {
+          config.components = this.collectTB(config.components)
+          config.version = 2.0
+
+          this.setState({
+            needUpdate: true
+          })
+        }
+
         config.enabled = false
         message.success('澶嶅埗鎴愬姛锛屼繚瀛樺悗鐢熸晥銆�')
       }
       
       config.uuid = MenuId
       config.MenuID = MenuId
+      config.Template = 'webPage'
       config.open_edition = ''
       config.MenuName = urlParam.MenuName || ''
       config.MenuNo = ''
 
-      let indeComs = []
+      let navItem = null
       config.components.forEach(item => {
         if (item.type === 'navbar') {
-          indeComs.push(fromJS(item).toJS())
+          navItem = fromJS(item).toJS()
         }
       })
 
-      if (indeComs.length === 0) {
+      if (!navItem) {
         this.setState({
-          oriConfig: null,
-          config: fromJS(config).toJS(),
+          oriConfig: fromJS(config).toJS(),
+          config: config,
           loading: false
         })
         window.GLOB.customMenu = config
       } else {
-        this.jointComponents(config, indeComs, true)
+        this.jointComponents(config, navItem)
       }
     })
   }
 
-  jointComponents = (config, indeComs, isCreate) => {
-    let deffers = indeComs.map(item => {
-      return new Promise(resolve => {
-        Api.getSystemConfig({
-          func: 'sPC_Get_LongParam',
-          TypeCharOne: sessionStorage.getItem('kei_no'),
-          typename: 'pc',
-          MenuID: item.uuid
-        }).then(res => {
-          res.uuid = item.uuid
-
-          if (!res.status) {
-            notification.warning({
-              top: 92,
-              message: res.message,
-              duration: 5
-            })
-          }
-          
-          resolve(res)
+  jointComponents = (config, navItem) => {
+    Api.getCloudConfig({
+      func: 'sPC_Get_LongParam',
+      TypeCharOne: sessionStorage.getItem('kei_no'),
+      typename: 'pc',
+      MenuID: navItem.uuid
+    }).then(res => {
+      if (!res.status) {
+        notification.warning({
+          top: 92,
+          message: res.message,
+          duration: 5
         })
-      })
-    })
-    Promise.all(deffers).then(result => {
-      let _conf = {}
-      result.forEach(res => {
+
+        config.components = config.components.filter(item => item.type !== 'navbar')
+      } else {
         let _config = null
         try {
           _config = res.LongParam ? JSON.parse(window.decodeURIComponent(window.atob(res.LongParam))) : null
@@ -831,35 +806,21 @@
 
         if (_config) {
           _config.open_edition = res.open_edition || ''
-          _conf[res.uuid] = _config
-          window.GLOB.CacheIndependent.set(res.uuid, fromJS(_config).toJS())
+          config.components = config.components.map(item => {
+            if (item.type === 'navbar') {
+              return _config
+            }
+            return item
+          })
+
+          window.GLOB.CacheIndependent.set(navItem.uuid, fromJS(_config).toJS())
+        } else {
+          config.components = config.components.filter(item => item.type !== 'navbar')
         }
-      })
-
-      let _length = config.components.length
-      config.components = config.components.map(item => {
-        if (item.type === 'navbar') {
-          if (_conf[item.uuid]) {
-            item = _conf[item.uuid]
-          } else {
-            item = null
-          }
-        }
-        return item
-      })
-
-      config.components = config.components.filter(Boolean)
-
-      if (_length > config.components.length) {
-        notification.warning({
-          top: 92,
-          message: '閮ㄥ垎缁勪欢宸插垹闄わ紒',
-          duration: 5
-        })
       }
 
       this.setState({
-        oriConfig: isCreate ? null : fromJS(config).toJS(),
+        oriConfig: fromJS(config).toJS(),
         config: config,
         loading: false
       })
@@ -868,22 +829,32 @@
     })
   }
 
-  getMenuMessage = () => {
+  getMenuMessage = (tbs) => {
     const { config } = this.state
     let nodes = {type: 'view', version: '1.0', key: config.uuid, title: config.MenuName, children: []}
-    let popviews = []
 
     let traversal = (components) => {
       let list = []
       components.forEach(item => {
+        if (item.$tables) {
+          tbs.push(...item.$tables)
+        }
+
+        if (item.plot && item.plot.permission !== 'true') {
+          return
+        } else if (item.type === 'login' || item.type === 'navbar') {
+          return
+        } else if (!['tabs', 'group'].includes(item.type) && item.wrap && item.wrap.permission !== 'true') {
+          return
+        }
+
         let m = {
           key: item.uuid,
           title: item.name,
           children: []
         }
-        if (item.type === 'login' || item.type === 'navbar') {
-          return null
-        } else if (item.type === 'tabs') {
+
+        if (item.type === 'tabs') {
           let tabs = []
           let mm = []
           item.subtabs.forEach(tab => {
@@ -910,7 +881,7 @@
             list.push(...mm)
           }
           
-          return null
+          return
         } else if (item.type === 'group') {
           m.children = traversal(item.components)
 
@@ -920,87 +891,43 @@
             list.push(...m.children)
           }
           
-          return null
-        } if (item.plot && item.plot.permission !== 'true') {
-          return null
-        } if (item.wrap && item.wrap.permission !== 'true') {
-          return null
-        } else if (item.type === 'card' || (item.type === 'table' && item.subtype === 'tablecard')) {
+          return
+        } else if (item.type === 'card' || item.type === 'carousel' || item.type === 'timeline') {
           item.action && item.action.forEach(btn => {
-            if (btn.hidden === 'true') return
+            if (btn.hidden === 'true' || btn.permission === 'false') return
 
             m.children.push({
               key: btn.uuid,
               title: btn.label,
             })
-            if (btn.OpenType === 'popview') {
-              popviews.push(btn.uuid)
-            }
           })
           item.subcards.forEach(card => {
             card.elements && card.elements.forEach(cell => {
-              if (cell.eleType !== 'button') return
-              if (cell.hidden === 'true') return
+              if (cell.eleType !== 'button' || cell.hidden === 'true' || cell.permission === 'false') return
 
               m.children.push({
                 key: cell.uuid,
                 title: cell.label,
               })
-              if (cell.OpenType === 'popview') {
-                popviews.push(cell.uuid)
-              }
             })
+
             card.backElements && card.backElements.forEach(cell => {
-              if (cell.eleType !== 'button') return
-              if (cell.hidden === 'true') return
+              if (cell.eleType !== 'button' || cell.hidden === 'true' || cell.permission === 'false') return
 
               m.children.push({
                 key: cell.uuid,
                 title: cell.label,
               })
-              if (cell.OpenType === 'popview') {
-                popviews.push(cell.uuid)
-              }
-            })
-          })
-        } else if (item.type === 'carousel' || item.type === 'timeline') {
-          item.subcards.forEach(card => {
-            card.elements && card.elements.forEach(cell => {
-              if (cell.eleType !== 'button') return
-              if (cell.hidden === 'true') return
-
-              m.children.push({
-                key: cell.uuid,
-                title: cell.label,
-              })
-              if (cell.OpenType === 'popview') {
-                popviews.push(cell.uuid)
-              }
             })
           })
         } else if (item.type === 'balcony') {
           item.elements && item.elements.forEach(cell => {
-            if (cell.eleType !== 'button') return
-            if (cell.hidden === 'true') return
+            if (cell.eleType !== 'button' || cell.hidden === 'true' || cell.permission === 'false') return
 
             m.children.push({
               key: cell.uuid,
               title: cell.label,
             })
-            if (cell.OpenType === 'popview') {
-              popviews.push(cell.uuid)
-            }
-          })
-        } else if (item.type === 'menubar') {
-          if (item.wrap.title) {
-            m.title = item.wrap.title
-          }
-
-          m.children = item.subMenus.map(menu => {
-            return {
-              key: menu.uuid,
-              title: menu.setting.name
-            }
           })
         } else if (item.type === 'form') {
           if (item.subtype !== 'simpleform') {
@@ -1011,32 +938,31 @@
               }
             })
           }
-        } else if (item.type === 'table' && (item.subtype === 'normaltable' || item.subtype === 'editable')) {
-          item.action && item.action.forEach(btn => {
-            if (btn.hidden === 'true') return
+        } else if (item.type === 'table') {
+          item.action.forEach(btn => {
+            if (btn.hidden === 'true' || btn.permission === 'false') return
 
             m.children.push({
               key: btn.uuid,
               title: btn.label,
             })
-            if (btn.OpenType === 'popview') {
-              popviews.push(btn.uuid)
-            }
           })
-          item.cols && item.cols.forEach(col => {
-            if (col.type !== 'action') return
-            col.elements.forEach(btn => {
-              if (btn.hidden === 'true') return
-              
-              m.children.push({
-                key: btn.uuid,
-                title: btn.label,
-              })
-              if (btn.OpenType === 'popview') {
-                popviews.push(btn.uuid)
+          let loopCol = (cols) => {
+            cols.forEach(col => {
+              if (col.type === 'colspan') {
+                loopCol(col.subcols)
+              } else if (col.type === 'custom') {
+                col.elements.forEach(cell => {
+                  if (cell.eleType !== 'button' || cell.hidden === 'true' || cell.permission === 'false') return
+                  m.children.push({
+                    key: cell.uuid,
+                    title: cell.label,
+                  })
+                })
               }
             })
-          })
+          }
+          loopCol(item.cols)
         }
 
         list.push(m)
@@ -1048,7 +974,6 @@
     let trees = traversal(config.components)
 
     nodes.children = trees
-    nodes.popviews = popviews
 
     if (config.components.findIndex(item => item.type === 'login') > -1) {
       nodes.login = true
@@ -1056,6 +981,14 @@
     }
     if (nodes.children.length === 0) {
       nodes.pass = true
+    }
+
+    if (config.interfaces) {
+      config.interfaces.forEach(item => {
+        if (item.$tables) {
+          tbs.push(...item.$tables)
+        }
+      })
     }
 
     return nodes
@@ -1083,7 +1016,7 @@
           })
         } else if (item.type === 'group') {
           traversal(item.components)
-        } else if (item.type === 'card' || (item.type === 'table' && item.subtype === 'tablecard')) {
+        } else if (item.type === 'card' || item.type === 'carousel' || item.type === 'timeline') {
           item.action && item.action.forEach(btn => {
             if (btn.linkmenu && menuObj[btn.linkmenu]) {
               menus.push(menuObj[btn.linkmenu])
@@ -1102,23 +1035,14 @@
               })
             }
             card.elements && card.elements.forEach(cell => {
-              if (cell.eleType !== 'button') return
-
               if (cell.linkmenu && menuObj[cell.linkmenu]) {
                 menus.push(menuObj[cell.linkmenu])
               } else if (cell.openmenu && menuObj[cell.openmenu]) {
                 menus.push(menuObj[cell.openmenu])
               }
             })
-          })
-        } else if (item.type === 'carousel' || item.type === 'timeline') {
-          item.subcards.forEach(card => {
-            if (card.setting.click === 'menu' && menuObj[card.setting.menu]) {
-              menus.push(menuObj[card.setting.menu])
-            }
-            card.elements && card.elements.forEach(cell => {
-              if (cell.eleType !== 'button') return
 
+            card.backElements && card.backElements.forEach(cell => {
               if (cell.linkmenu && menuObj[cell.linkmenu]) {
                 menus.push(menuObj[cell.linkmenu])
               } else if (cell.openmenu && menuObj[cell.openmenu]) {
@@ -1128,8 +1052,6 @@
           })
         } else if (item.type === 'balcony') {
           item.elements && item.elements.forEach(cell => {
-            if (cell.eleType !== 'button') return
-
             if (cell.linkmenu && menuObj[cell.linkmenu]) {
                 menus.push(menuObj[cell.linkmenu])
               } else if (cell.openmenu && menuObj[cell.openmenu]) {
@@ -1142,7 +1064,7 @@
               menus.push(menuObj[m.subButton.linkmenu])
             }
           })
-        } else if (item.type === 'table' && item.subtype === 'normaltable') {
+        } else if (item.type === 'table') {
           item.action && item.action.forEach(btn => {
             if (btn.linkmenu && menuObj[btn.linkmenu]) {
               menus.push(menuObj[btn.linkmenu])
@@ -1150,16 +1072,22 @@
               menus.push(menuObj[btn.openmenu])
             }
           })
-          item.cols && item.cols.forEach(col => {
-            if (col.type !== 'action') return
-            col.elements.forEach(btn => {
-              if (btn.linkmenu && menuObj[btn.linkmenu]) {
-                menus.push(menuObj[btn.linkmenu])
-              } else if (btn.openmenu && menuObj[btn.openmenu]) {
-                menus.push(menuObj[btn.openmenu])
+          let loopCol = (cols) => {
+            cols.forEach(col => {
+              if (col.type === 'colspan') {
+                loopCol(col.subcols)
+              } else if (col.type === 'custom') {
+                col.elements.forEach(cell => {
+                  if (cell.linkmenu && menuObj[cell.linkmenu]) {
+                    menus.push(menuObj[cell.linkmenu])
+                  } else if (cell.openmenu && menuObj[cell.openmenu]) {
+                    menus.push(menuObj[cell.openmenu])
+                  }
+                })
               }
             })
-          })
+          }
+          loopCol(item.cols)
         }
       })
     }
@@ -1176,9 +1104,8 @@
     return menus
   }
 
-  submitConfig = () => {
-    const { delButtons, copyButtons } = this.state
-    let config = fromJS(this.state.config).toJS()
+  checkBase = () => {
+    const { config } = this.state
 
     if (!config.MenuName || !config.MenuNo || (config.cacheUseful === 'true' && !config.cacheTime)) {
       notification.warning({
@@ -1191,7 +1118,57 @@
         settingshow: true,
         activeKey: 'basedata'
       })
+      return false
+    }
+    return true
+  }
+
+  resetSyncQuery = (components) => {
+    return components.map(item => {
+      if (item.type === 'tabs') {
+        item.subtabs.forEach(tab => {
+          tab.components = this.resetSyncQuery(tab.components)
+        })
+      } else if (item.type === 'group') {
+        item.components = this.resetSyncQuery(item.components)
+      } else if (item.setting && item.setting.interType === 'system' && item.setting.sync === 'true') {
+        let sql = ''
+        if (item.setting.execute !== 'false' && item.setting.dataresource) {
+          sql = item.setting.dataresource
+        }
+
+        item.scripts && item.scripts.forEach(script => {
+          if (script.status === 'false') return
+
+          sql += script.sql
+        })
+       
+        if (sql.length > 8000) {
+          item.setting.sync = 'false'
+        }
+      }
+
+      return item
+    })
+  }
+
+  submitConfig = () => {
+    let config = fromJS(this.state.config).toJS()
+
+    if (!this.checkBase()) {
       return
+    } else if (this.checklog()) {
+      if (sessionStorage.getItem('applangList') && !config.trans) {
+
+      } else {
+        notification.success({
+          top: 92,
+          message: '褰撳墠閰嶇疆鏈慨鏀癸紝鏃犻渶淇濆瓨銆�',
+          duration: 5
+        })
+        MKEmitter.emit('completeSave')
+        return
+      }
     }
 
     this.setState({
@@ -1199,15 +1176,68 @@
     })
 
     setTimeout(() => {
-      if (config.enabled && this.verifyConfig()) {
+      let _pass = this.verifyConfig(config)
+
+      if (config.enabled && !_pass) {
         config.enabled = false
+        config.force = true
+      } else if (!config.enabled && config.force && _pass) {
+        config.enabled = true
+        delete config.force
       }
 
-      let roleParam = this.getMenuMessage()
+      if (config.cacheUseful !== 'true') {
+        config.components = this.resetSyncQuery(config.components)
+      }
+
+      let tbs = []
+      let roleParam = this.getMenuMessage(tbs)
 
       let subMenus = this.getSubMenus()
       let menus_used_list = subMenus.map(m => `'${config.uuid}','${config.MenuName || ''}','${config.MenuNo || ''}','${m.MenuID}','${m.MenuName}'`).join(';')
       menus_used_list = window.btoa(window.encodeURIComponent(menus_used_list || 'del'))
+
+      let arr = []
+      tbs = tbs.filter(tb => {
+        let _tb = tb.toLowerCase()
+
+        if (arr.includes(_tb)) return false
+        arr.push(_tb)
+
+        return true
+      })
+      tbs.sort()
+      if (tbs.length && sessionStorage.getItem('mk_tb_names')) {
+        let names = sessionStorage.getItem('mk_tb_names')
+        tbs = tbs.filter(tb => names.indexOf(',' + tb.toLowerCase() + ',') > -1)
+      }
+      tbs = tbs.map(tb => `'${tb}'`).join(';')
+
+      let key = md5(config.uuid + sessionStorage.getItem('kei_no') + 'pc' + sessionStorage.getItem('lang') + tbs.toLowerCase())
+      let url = ''
+
+      if (config.tbkey === key) {
+        key = ''
+      } else {
+        let urlparam = {
+          type: 'app',
+          MenuID: config.uuid,
+          ID: sessionStorage.getItem('appId') || '',
+          remark: sessionStorage.getItem('appName') || '',
+          lang: sessionStorage.getItem('lang') || '',
+          kei_no: sessionStorage.getItem('kei_no') || '',
+          typename: 'pc',
+          sysBgColor: sessionStorage.getItem('sysBgColor') || '',
+          MenuName: config.MenuName || '',
+        }
+
+        url = window.btoa(window.encodeURIComponent(JSON.stringify(urlparam)))
+        config.tbkey = key
+      }
+
+      let interfaces = getFuncsAndInters(config)
+      roleParam.interfaces = interfaces
+      let langSql = getLangTrans(config)
 
       let param = {
         func: 'sPC_TrdMenu_AddUpt',
@@ -1221,212 +1251,177 @@
         TypeCharOne: sessionStorage.getItem('kei_no'),
         Typename: 'pc',
         MenuName: config.MenuName || '',
-        PageParam: JSON.stringify({Template: 'webPage'}),
+        PageParam: JSON.stringify({Template: 'webPage', interfaces}),
         menus_rolelist: window.btoa(window.encodeURIComponent(JSON.stringify(roleParam))),
         open_edition: config.open_edition,
-        LText: '',
-        LTexttb: '',
-        menus_used_list
+        // LText: '',
+        // LTexttb: '',
+        menus_used_list,
+        debug_md5: key,
+        debug_url: url,
+        debug_list: window.btoa(tbs)
+      }
+
+      if (langSql) {
+        param.lang_translation = window.btoa(window.encodeURIComponent(langSql))
       }
 
       param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
       param.secretkey = Utils.encrypt('', param.timestamp)
 
-      new Promise(resolve => {
-        let _config = fromJS(config).toJS()
-        let indeComs = []
-        _config.components = _config.components.map(item => {
-          if (item.type === 'navbar') {
-            indeComs.push(item)
-            return {
-              type: 'navbar',
-              uuid: item.uuid
-            }
+      let _config = fromJS(config).toJS()
+      let NavBar = null
+      _config.components = _config.components.map(item => {
+        if (item.type === 'navbar') {
+          NavBar = fromJS(item).toJS()
+          return {
+            type: 'navbar',
+            uuid: item.uuid
           }
-          return item
-        })
+        }
+        return item
+      })
 
-        param.LongParam = window.btoa(window.encodeURIComponent(JSON.stringify(_config)))
+      param.LongParam = window.btoa(window.encodeURIComponent(JSON.stringify(_config)))
 
-        if (indeComs.length === 0) {
-          resolve(true)
+      new Promise(resolve => {
+        if (!NavBar) {
+          resolve({status: true})
         } else {
-          let new_open_edition = {}
-          let deffers = indeComs.map(item => {
-            return new Promise(resolve => {
-              let _item = window.GLOB.CacheIndependent.get(item.uuid)
-              if (_item && is(fromJS(_item), fromJS(item))) {
-                new_open_edition[item.uuid] = item.open_edition || ''
-                resolve()
-                return
-              }
+          let _item = window.GLOB.CacheIndependent.get(NavBar.uuid) || {}
+          NavBar.open_edition = _item.open_edition || ''
+          if (is(fromJS(_item), fromJS(NavBar))) {
+            resolve({status: true})
+          } else {
+            let roles = {
+              type: 'navbar',
+              version: '1.0',
+              key: NavBar.uuid,
+              title: NavBar.name,
+              children: []
+            }
 
-              let roles = {
-                type: 'navbar',
-                version: '1.0',
-                key: item.uuid,
-                title: item.name,
-                children: []
-              }
-
-              if (item.wrap.permission === 'true') {
-                roles.children = item.menus.map(fst => {
-                  if (fst.property === 'classify' && fst.sublist.length > 0) {
-                    return {
-                      key: fst.MenuID,
-                      title: fst.name,
-                      children: fst.sublist.map(scd => {
-                        if (scd.property === 'classify' && scd.sublist.length > 0) {
-                          return {
-                            key: scd.MenuID,
-                            title: scd.name,
-                            children: scd.sublist.map(thd => {
-                              return { key: thd.MenuID, title: thd.name }
-                            })
-                          }
-                        } else {
-                          return { key: scd.MenuID, title: scd.name }
+            if (NavBar.wrap.permission === 'true') {
+              roles.children = NavBar.menus.map(fst => {
+                if (fst.property === 'classify' && fst.sublist.length > 0) {
+                  return {
+                    key: fst.MenuID,
+                    title: fst.name,
+                    children: fst.sublist.map(scd => {
+                      if (scd.property === 'classify' && scd.sublist.length > 0) {
+                        return {
+                          key: scd.MenuID,
+                          title: scd.name,
+                          children: scd.sublist.map(thd => {
+                            return { key: thd.MenuID, title: thd.name }
+                          })
                         }
-                      })
-                    }
-                  } else {
-                    return { key: fst.MenuID, title: fst.name }
+                      } else {
+                        return { key: scd.MenuID, title: scd.name }
+                      }
+                    })
                   }
-                })
-              } else {
-                roles.pass = true
-              }
-
-              let _param = {
-                func: 'sPC_TrdMenu_AddUpt',
-                FstID: 'mk_app',
-                SndID: 'mk_app',
-                ParentID: 'mk_app',
-                MenuID: item.uuid,
-                MenuNo: item.wrap.MenuNo || Utils.getuuid(),
-                EasyCode: '',
-                Template: item.type,
-                TypeCharOne: sessionStorage.getItem('kei_no'),
-                Typename: 'pc',
-                MenuName: item.name || '',
-                PageParam: JSON.stringify({Template: item.type}),
-                menus_rolelist: window.btoa(window.encodeURIComponent(JSON.stringify(roles))),
-                open_edition: item.open_edition || '',
-                LText: '',
-                LTexttb: ''
-              }
-
-              _param.LongParam = window.btoa(window.encodeURIComponent(JSON.stringify(item)))
-              _param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
-              _param.secretkey = Utils.encrypt('', _param.timestamp)
-
-              Api.getSystemConfig(_param).then(res => {
-                if (!res.status) {
-                  notification.warning({
-                    top: 92,
-                    message: res.message,
-                    duration: 5
-                  })
-                  this.setState({ menuloading: false })
-                  return
-                }
-
-                new_open_edition[item.uuid] = res.open_edition || ''
-                resolve()
-              })
-            })
-          })
-          Promise.all(deffers).then(() => {
-            let appViewList = sessionStorage.getItem('appViewList')
-            appViewList = JSON.parse(appViewList)
-            let _appViewList = fromJS(appViewList).toJS()
-            let appIndeList = appViewList.map(item => item.keys_id).join(',')
-
-            config.components = config.components.map(item => {
-              if (item.type === 'navbar') {
-                item.open_edition = new_open_edition[item.uuid] || ''
-                window.GLOB.CacheIndependent.set(item.uuid, fromJS(item).toJS())
-
-                if (appIndeList.indexOf(item.uuid) === -1) {
-                  appViewList.unshift({
-                    appkey: window.GLOB.appkey || '',
-                    bid: sessionStorage.getItem('appId') || '',
-                    kei_no: sessionStorage.getItem('kei_no') || '',
-                    keys_id: item.uuid,
-                    keys_type: 'navbar',
-                    remark: item.name
-                  })
                 } else {
-                  appViewList = appViewList.map(view => {
-                    if (view.keys_id === item.uuid) {
-                      view.remark = item.name
-                    }
-                    return view
-                  })
-                }
-              }
-              return item
-            })
-
-            if (!is(fromJS(appViewList), fromJS(_appViewList))) {
-              let kparam = {
-                func: 's_kei_link_keyids_addupt',
-                BID: sessionStorage.getItem('appId'),
-                exec_type: 'y',
-                LText: ''
-              }
-    
-              kparam.LText = appViewList.map(item => `select '${item.keys_id}','${item.keys_type}','${item.kei_no}','${item.appkey}','${item.bid}','${sessionStorage.getItem('CloudUserID')}','${item.remark}'`)
-              kparam.LText = kparam.LText.join(' union all ')
-              kparam.LText = Utils.formatOptions(kparam.LText)
-        
-              kparam.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
-              kparam.secretkey = Utils.encrypt('', kparam.timestamp)
-    
-              Api.getSystemConfig(kparam).then(result => {
-                if (!result.status) {
-                  notification.warning({
-                    top: 92,
-                    message: result.message,
-                    duration: 5
-                  })
-                  this.setState({ menuloading: false })
-                } else {
-                  sessionStorage.setItem('appViewList', JSON.stringify(appViewList))
-                  resolve(true)
+                  return { key: fst.MenuID, title: fst.name }
                 }
               })
             } else {
-              resolve(true)
+              roles.pass = true
             }
-          })
-        }
-      }).then(res => { // 鎸夐挳鎴栬彍鍗曞垹闄�
-        if (!res) return
 
-        if (delButtons.length === 0) {
-          return { status: true, nonexec: true }
-        } else {
-          let _param = {
-            func: 'sPC_MainMenu_Del',
-            MenuID: delButtons.join(',')
+            let _param = {
+              func: 'sPC_TrdMenu_AddUpt',
+              FstID: 'mk_app',
+              SndID: 'mk_app',
+              ParentID: 'mk_app',
+              MenuID: NavBar.uuid,
+              MenuNo: NavBar.wrap.MenuNo || Utils.getuuid(),
+              EasyCode: '',
+              Template: NavBar.type,
+              TypeCharOne: sessionStorage.getItem('kei_no'),
+              Typename: 'pc',
+              MenuName: NavBar.name || '',
+              PageParam: JSON.stringify({Template: NavBar.type}),
+              menus_rolelist: window.btoa(window.encodeURIComponent(JSON.stringify(roles))),
+              open_edition: NavBar.open_edition,
+              // LText: '',
+              // LTexttb: ''
+            }
+
+            _param.LongParam = window.btoa(window.encodeURIComponent(JSON.stringify(NavBar)))
+            _param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
+            _param.secretkey = Utils.encrypt('', _param.timestamp)
+
+            Api.getCloudConfig(_param).then(res => {
+              if (res.status) {
+                NavBar.open_edition = res.open_edition || ''
+                window.GLOB.CacheIndependent.set(NavBar.uuid, fromJS(NavBar).toJS())
+
+                let appViewList = sessionStorage.getItem('appViewList')
+                let _appViewList = JSON.parse(appViewList)
+
+                let index = _appViewList.findIndex(item => item.keys_id === NavBar.uuid)
+                
+                if (index === -1) {
+                  _appViewList.unshift({
+                    appkey: window.GLOB.appkey || '',
+                    bid: sessionStorage.getItem('appId') || '',
+                    kei_no: sessionStorage.getItem('kei_no') || '',
+                    keys_id: NavBar.uuid,
+                    keys_type: 'navbar',
+                    remark: NavBar.name
+                  })
+                } else {
+                  _appViewList = _appViewList.map(item => {
+                    if (item.keys_id === NavBar.uuid && item.remark !== NavBar.name) {
+                      item.remark = NavBar.name
+                    }
+                    return item
+                  })
+                }
+
+                let viewList = JSON.stringify(_appViewList)
+
+                if (appViewList !== viewList) {
+                  let kparam = {
+                    func: 's_kei_link_keyids_addupt',
+                    BID: sessionStorage.getItem('appId'),
+                    exec_type: 'x',
+                    LText: ''
+                  }
+        
+                  kparam.LText = _appViewList.map(item => `select '${item.keys_id}','${item.keys_type}','${item.kei_no}','${item.appkey}','${item.bid}','${sessionStorage.getItem('CloudUserID')}','${item.remark}'`)
+                  kparam.LText = kparam.LText.join(' union all ')
+                  kparam.LText = Utils.formatOptions(kparam.LText, 'x')
+            
+                  kparam.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
+                  kparam.secretkey = Utils.encrypt('', kparam.timestamp)
+        
+                  Api.getCloudConfig(kparam).then(result => {
+                    if (result.status) {
+                      sessionStorage.setItem('appViewList', viewList)
+                    }
+
+                    resolve(result)
+                  }, this.netError)
+                } else {
+                  resolve(res)
+                }
+              } else {
+                resolve(res)
+              }
+            }, this.netError)
           }
-          return Api.getSystemConfig(_param)
         }
       }).then(res => { // 椤甸潰淇濆瓨
-        if (!res) return
+        if (!res || !res.status) return res
 
-        if (res.status) {
-          return Api.getSystemConfig(param)
-        } else {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-          return false
-        }
-      }).then(res => { // 椤甸潰鎸夐挳鍏崇郴淇濆瓨
+        return Api.getCloudConfig(param)
+      }).then(res => {
+        this.setState({
+          menuloading: false
+        })
+
         if (!res) return
 
         if (res.status) {
@@ -1435,142 +1430,46 @@
           this.setState({
             config,
             oriConfig: fromJS(config).toJS(),
+            needUpdate: false
           })
 
-          return {
-            status: true
-          }
-        } else {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-          return false
-        }
-      }).then(res => { // 鎸夐挳澶嶅埗
-        if (!res) return
-        if (!res.status) {
-          notification.warning({
-            top: 92,
-            message: res.message,
-            duration: 5
-          })
-          return false
-        }
+          localStorage.setItem('pcUpdate', new Date().getTime() + ',' + config.uuid)
 
-        if (copyButtons.length === 0) {
-          return {
-            status: true
-          }
-        } else {
-          return new Promise(resolve => {
-            let deffers = copyButtons.map(item => {
-              return new Promise(resolve => {
-                if (delButtons.includes(item.uuid)) { // 澶嶅埗鐨勬寜閽凡鍒犻櫎
-                  resolve({
-                    status: true
-                  })
-                  return
-                }
-
-                Api.getSystemConfig({
-                  func: 'sPC_Get_LongParam',
-                  MenuID: item.$originUuid,
-                  TypeCharOne: sessionStorage.getItem('kei_no'),
-                  typename: 'pc',
-                }).then(result => {
-                  if (result.status) {
-                    let _conf = ''
-              
-                    try {
-                      _conf = result.LongParam ? JSON.parse(window.decodeURIComponent(window.atob(result.LongParam))) : ''
-                    } catch (e) {
-                      console.warn('Parse Failure')
-                      _conf = ''
-                    }
-                    
-                    if (_conf) {
-                      _conf.components = MenuUtils.resetConfig(_conf.components)
-                      _conf.uuid = item.uuid
-                      _conf.MenuID = item.uuid
-                      _conf.Template = 'webPage'
-                      _conf.enabled = false
-                    } else {
-                      resolve({
-                        status: true
-                      })
-                      return
-                    }
-
-                    let _param = {
-                      func: 'sPC_ButtonParam_AddUpt',
-                      ParentID: config.uuid,
-                      MenuID: item.uuid,
-                      MenuNo: '',
-                      Template: 'webPage',
-                      MenuName: item.label,
-                      PageParam: JSON.stringify({Template: 'webPage'}),
-                      LongParam: window.btoa(window.encodeURIComponent(JSON.stringify(_conf))),
-                      TypeCharOne: sessionStorage.getItem('kei_no'),
-                      Typename: 'pc',
-                    }
-            
-                    Api.getSystemConfig(_param).then(response => {
-                      resolve(response)
-                    })
-                  }
-                })
-              })
-            })
-            Promise.all(deffers).then(result => {
-              let error = null
-              result.forEach(response => {
-                if (!response.status) {
-                  error = response
-                }
-              })
-    
-              if (error) {
-                notification.warning({
-                  top: 92,
-                  message: error.message,
-                  duration: 5
-                })
-                resolve(false)
-              } else {
-                resolve({
-                  status: true
-                })
-              }
-            })
-          })
-        }
-      }).then(res => {
-        if (res && res.status) {
-          this.setState({
-            delButtons: [],
-            copyButtons: [],
-            menuloading: false
-          })
           notification.success({
             top: 92,
             message: '淇濆瓨鎴愬姛',
             duration: 2
           })
         } else {
-          this.setState({
-            menuloading: false
+          Modal.warning({
+            width: 400,
+            title: res.message,
+            okText: '鐭ラ亾浜�'
           })
         }
         MKEmitter.emit('completeSave')
-      })
+      }, this.netError)
     }, 300 + (+sessionStorage.getItem('mkDelay')))
+  }
+
+  netError = (error) => {
+    this.setState({
+      menuloading: false
+    })
+
+    if (!error) {
+      notification.warning({
+        top: 92,
+        message: '淇濆瓨澶辫触锛岃妫�鏌ョ綉缁滄槸鍚︽甯搞��',
+        duration: 5
+      })
+    }
+    MKEmitter.emit('completeSave')
   }
 
   getRoleFields = () => {
     if (sessionStorage.getItem('sysRoles') || sessionStorage.getItem('permFuncField')) return
-    Api.getSystemConfig({func: 'sPC_Get_Roles_sModular'}).then(res => {
+    Api.getCloudConfig({func: 'sPC_Get_Roles_sModular'}).then(res => {
       if (res.status) {
         let _permFuncField = []
         let _sysRoles = []
@@ -1603,17 +1502,22 @@
   onEnabledChange = () => {
     const { config } = this.state
 
-    if (!config || (!config.enabled && this.verifyConfig(true))) {
-      return
-    }
+    let _config = {...config, enabled: !config.enabled}
 
-    this.setState({
-      config: {...config, enabled: !config.enabled}
-    })
+    delete _config.force
+
+    if (!_config.enabled) {
+      this.setState({
+        config: _config
+      })
+    } else if (this.verifyConfig(_config)) {
+      this.setState({
+        config: _config
+      })
+    }
   }
 
-  verifyConfig = (show) => {
-    const { config } = this.state
+  verifyConfig = (config) => {
     let error = ''
 
     let check = (components) => {
@@ -1640,7 +1544,7 @@
 
     check(config.components)
 
-    if (show && error) {
+    if (config.enabled && error) {
       notification.warning({
         top: 92,
         message: error,
@@ -1648,7 +1552,7 @@
       })
     }
 
-    return error
+    return error === ''
   }
 
   // 鏇存柊閰嶇疆淇℃伅
@@ -1680,38 +1584,12 @@
 
     this.setState({config})
     window.GLOB.customMenu = config
-
-    notification.success({
-      top: 92,
-      message: '绮樿创鎴愬姛锛�',
-      duration: 2
-    })
-  }
-
-  refreshView = () => {
-    const { oriConfig, config } = this.state
-
-    if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) {
-      notification.warning({
-        top: 92,
-        message: '閰嶇疆淇℃伅鏈繚瀛橈紒',
-        duration: 5
-      })
-      return
-    }
-
-    sessionStorage.removeItem('sysRoles')
-    sessionStorage.removeItem('permFuncField')
-    sessionStorage.removeItem('app_videos')
-    sessionStorage.removeItem('app_pictures')
-    
-    window.location.reload()
   }
 
   setHomeView = () => {
-    const { oriConfig, config } = this.state
+    const { config } = this.state
 
-    if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) {
+    if (!is(fromJS(this.state.oriConfig || {}), fromJS(config || {}))) {
       notification.warning({
         top: 92,
         message: '閰嶇疆淇℃伅鏈繚瀛橈紒',
@@ -1723,7 +1601,7 @@
     let param = {
       func: 's_kei_link_keyids_addupt',
       BID: sessionStorage.getItem('appId'),
-      exec_type: 'y',
+      exec_type: 'x',
       LText: ''
     }
 
@@ -1742,7 +1620,7 @@
 
     param.LText = appViewList.map(item => `select '${item.keys_id}','${item.keys_type}','${item.kei_no}','${item.appkey}','${item.bid}','${sessionStorage.getItem('CloudUserID')}','${item.remark}'`)
     param.LText = param.LText.join(' union all ')
-    param.LText = Utils.formatOptions(param.LText)
+    param.LText = Utils.formatOptions(param.LText, 'x')
 
     param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
     param.secretkey = Utils.encrypt('', param.timestamp)
@@ -1751,7 +1629,7 @@
       title: '纭畾璁剧疆鏈〉闈负棣栭〉鍚楋紵',
       content: '',
       onOk() {
-        Api.getSystemConfig(param).then(result => {
+        Api.getCloudConfig(param).then(result => {
           if (!result.status) {
             notification.warning({
               top: 92,
@@ -1768,9 +1646,9 @@
   }
 
   setLoginView = () => {
-    const { oriConfig, config } = this.state
+    const { config } = this.state
 
-    if (!oriConfig || !is(fromJS(oriConfig), fromJS(config))) {
+    if (!is(fromJS(this.state.oriConfig || {}), fromJS(config || {}))) {
       notification.warning({
         top: 92,
         message: '閰嶇疆淇℃伅鏈繚瀛橈紒',
@@ -1782,7 +1660,7 @@
     let param = {
       func: 's_kei_link_keyids_addupt',
       BID: sessionStorage.getItem('appId'),
-      exec_type: 'y',
+      exec_type: 'x',
       LText: ''
     }
 
@@ -1801,7 +1679,7 @@
 
     param.LText = appViewList.map(item => `select '${item.keys_id}','${item.keys_type}','${item.kei_no}','${item.appkey}','${item.bid}','${sessionStorage.getItem('CloudUserID')}','${item.remark}'`)
     param.LText = param.LText.join(' union all ')
-    param.LText = Utils.formatOptions(param.LText)
+    param.LText = Utils.formatOptions(param.LText, 'x')
 
     param.timestamp = moment().format('YYYY-MM-DD HH:mm:ss')
     param.secretkey = Utils.encrypt('', param.timestamp)
@@ -1812,7 +1690,7 @@
       title: '纭畾璁剧疆鏈〉闈负鐧诲綍椤靛悧锛�',
       content: hasLogin ? '' : '褰撳墠椤甸潰灏氭湭娣诲姞鐧诲綍缁勪欢銆�',
       onOk() {
-        Api.getSystemConfig(param).then(result => {
+        Api.getCloudConfig(param).then(result => {
           if (!result.status) {
             notification.warning({
               top: 92,
@@ -1828,14 +1706,34 @@
     })
   }
 
+  checklog = () => {
+    const { oriConfig, config } = this.state
+
+    return is(fromJS(oriConfig), fromJS(config))
+  }
+
+  updateLogConfig = (config) => {
+    config.open_edition = this.state.config.open_edition || ''
+    
+    this.setState({
+      config: null
+    }, () => {
+      this.setState({
+        config: config
+      })
+    })
+    
+    window.GLOB.customMenu = config
+  }
+
   render () {
-    const { localedict, loading, comloading, activeKey, settingshow, controlshow, dict, MenuId, config, menuloading, customComponents, eyeopen } = this.state
+    const { view, loading, comloading, activeKey, settingshow, controlshow, MenuId, config, menuloading, eyeopen, needUpdate } = this.state
 
     return (
-      <ConfigProvider locale={localedict}>
-        <div className={'mk-pc-view '} id="mk-pc-design-view">
-          {loading ? <Spin className="view-spin" size="large" /> : null}
-          <DndProvider backend={HTML5Backend}>
+      <>
+        <DndProvider backend={HTML5Backend}>
+          {view !== 'popview' ? <div className={'mk-pc-view '} id="mk-pc-design-view">
+            {loading ? <Spin className="view-spin" size="large" /> : null}
             <div className={'menu-setting ' + (!settingshow ? 'hidden' : '')}>
               <div className="draw">
                 {settingshow ? <DoubleLeftOutlined onClick={() => {sessionStorage.setItem('settingshow', 'false'); this.setState({settingshow: false})}}/> : null}
@@ -1845,26 +1743,27 @@
                 <Collapse accordion activeKey={activeKey} bordered={false} onChange={(key) => this.setState({activeKey: key})}>
                   {/* 鍩烘湰淇℃伅 */}
                   <Panel header="鍩烘湰淇℃伅" key="basedata">
-                    {/* 鑿滃崟淇℃伅 */}
-                    {config ? <MenuForm
-                      dict={dict}
-                      config={config}
-                      MenuId={MenuId}
-                      updateConfig={this.updateConfig}
-                    /> : null}
-                    {config ? <UrlFieldComponent config={config} updateConfig={this.updateConfig}/> : null}
-                    {/* 琛ㄥ悕娣诲姞 */}
-                    {config ? <TableComponent config={config} updatetable={this.updateConfig}/> : null}
-                    {config ? <Paragraph style={{padding: '15px 0px 0px 18px'}} copyable={{ text: MenuId }}>鑿滃崟ID</Paragraph> : null}
+                    {config ? <>
+                      <MenuForm
+                        config={config}
+                        MenuId={MenuId}
+                        updateConfig={this.updateConfig}
+                      />
+                      <UrlFieldComponent config={config} updateConfig={this.updateConfig}/>
+                      {/* 琛ㄥ悕娣诲姞 */}
+                      <TableComponent config={config} updatetable={this.updateConfig}/>
+                      <Paragraph style={{padding: '15px 0px 0px 18px'}} copyable={{ text: MenuId }}>鑿滃崟ID</Paragraph>
+                      <NormalCss config={config} updateConfig={this.updateConfig}/>
+                    </> : null}
                   </Panel>
                   {/* 缁勪欢娣诲姞 */}
-                  <Panel header={dict['mob.component']} key="component">
+                  <Panel header="缁勪欢" key="component">
                     <SourceWrap />
                   </Panel>
-                  {customComponents && customComponents.length ? <Panel header="鑷畾涔夌粍浠�" key="cuscomponent">
-                    <SourceWrap components={customComponents} />
-                  </Panel> : null}
-                  <Panel header={'椤甸潰鏍峰紡'} key="background">
+                  <Panel header="鍏冪礌" key="element">
+                    <Modulecell />
+                  </Panel>
+                  <Panel header="椤甸潰鏍峰紡" key="background">
                     {config ? <BgController config={config} updateConfig={this.updateConfig} /> : null}
                   </Panel>
                 </Collapse>
@@ -1876,35 +1775,39 @@
                 {!controlshow ? <DoubleLeftOutlined onClick={() => {sessionStorage.setItem('controlshow', 'true'); this.setState({controlshow: true})}}/> : null}
               </div>
               <div className="wrap">
-                <Button type="primary" id="save-config" onClick={this.submitConfig} loading={menuloading}>{dict['mob.save']}</Button>
-                <Switch className="big" checkedChildren={dict['mob.enable']} unCheckedChildren={dict['mob.disable']} checked={config && config.enabled} onChange={this.onEnabledChange} />
+                <Button type="primary" className={needUpdate ? 'update-tip' : ''} id="save-config" onClick={this.submitConfig} loading={menuloading}>淇濆瓨</Button>
+                {config ? <Switch className="big" checkedChildren="鍚�" unCheckedChildren="鍋�" checked={config.enabled} onChange={this.onEnabledChange} /> : null}
                 <ArrowLeftOutlined title="鍚庨��" className="back-view" onClick={this.backView}/>
+                {config ? <Debug config={config}/> : null}
                 <Button className="mk-border-purple" onClick={() => this.setState({eyeopen: !eyeopen})}>{!eyeopen ? <EyeOutlined /> : <EyeInvisibleOutlined />} 缁勪欢鍚�</Button>
                 <CreateView resetmenu={this.getAppMenus} />
                 <PasteController insert={this.insert} />
+                <TableNodes config={config} />
                 <ViewNodes config={config} MenuId={MenuId}/>
                 <SysInterface config={config} updateConfig={this.updateConfig}/>
                 <PictureController/>
                 <Quotecomponent config={config} updateConfig={this.updateConfig}/>
+                <StyleCombControlButton menu={config} />
                 <Button className="mk-border-green" onClick={this.setHomeView}><HomeOutlined /> 璁句负棣栭〉</Button>
                 <Button className="mk-border-purple" onClick={this.setLoginView}><LoginOutlined/> 璁句负鐧诲綍椤�</Button>
                 <ReplaceField type="custom" config={config} updateConfig={this.resetConfig}/>
                 <Transfer MenuID={MenuId} />
-                <Versions MenuId={MenuId} open_edition={config ? config.open_edition : ''}/>
-                <StyleCombControlButton menu={config} />
-                <Button className="mk-border-danger" onClick={this.refreshView}><RedoOutlined /> 寮哄埗鍒锋柊</Button>
+                {config ? <Versions MenuId={MenuId} Template="webPage" checklog={this.checklog} updateConfig={this.updateLogConfig}/> : null}
                 <Button type="default" onClick={this.closeView}>鍏抽棴</Button>
               </div>
             </div>
             <div className={'menu-body menu-view' + (menuloading ? ' saving' : '') + (eyeopen ? ' eye-open' : '')}>
               {config && !comloading ? <MenuShell menu={config} handleList={this.updateConfig} /> : null}
             </div>
-          </DndProvider>
-          <StyleController />
-          <StyleCombController />
-          <ModalController />
-        </div>
-      </ConfigProvider>
+          </div> : <>
+            <Header/>
+            <PopView btn={this.state.popConfig} save={this.submitPopConfig} cancel={this.closePop}/>
+          </>}
+        </DndProvider>
+        <StyleController />
+        <StyleCombController />
+        <ModalController />
+      </>
     )
   }
 }

--
Gitblit v1.8.0