From 547e5fe219ee7bee309ecd67db74bc8df66b5433 Mon Sep 17 00:00:00 2001
From: king <18310653075@163.com>
Date: 星期三, 23 八月 2023 11:47:45 +0800
Subject: [PATCH] 2023-08-23

---
 src/index.js |  175 ++++++++++++++++++++++++++++++++++++----------------------
 1 files changed, 109 insertions(+), 66 deletions(-)

diff --git a/src/index.js b/src/index.js
index 7383548..df31aa8 100644
--- a/src/index.js
+++ b/src/index.js
@@ -1,27 +1,12 @@
 import React from 'react'
 import ReactDOM from 'react-dom'
 import Route from './router'
-import { Provider } from 'react-redux'
-import store from '@/store'
+import md5 from 'md5'
 import * as serviceWorker from './serviceWorker'
 import options, { styles } from '@/store/options.js'
 import '@/assets/css/main.scss'
 import '@/assets/css/action.scss'
-import '@/assets/css/minkeicon.css'
 import '@/assets/css/viewstyle.scss'
-
-if (window.location.href.indexOf('#/design') > -1) { // 缂栬緫椤甸潰鍒锋柊鏃讹紝璺宠浆鑷充富椤�
-  window.location.replace(window.location.href.replace(/design/ig, 'main'))
-}
-
-options.sysType = window.atob(options.sysType.replace('$mk', ''))
-options.caId = window.atob(options.caId.replace('$mk', ''))
-options.cakey = window.atob(options.cakey.replace('$mk', ''))
-options.cdomain = window.atob(options.cdomain.replace('$mk', ''))
-
-if (options.cdomain && options.sysType !== 'cloud') {
-  options.cloudServiceApi = options.cdomain + '/webapi/dostars'
-}
 
 if (!localStorage.getItem('SessionUid')) {
   localStorage.setItem('SessionUid', (() => {
@@ -36,18 +21,10 @@
 
 const render = Component => {
   ReactDOM.render(
-    <Provider store={store}>
-      <Component/>
-    </Provider>,
+    <Component/>,
     document.getElementById('root')
   )
 }
-
-sessionStorage.removeItem('isEditState')
-sessionStorage.setItem('role_id', sessionStorage.getItem('localRole_id') || '')
-sessionStorage.setItem('dataM', sessionStorage.getItem('localDataM') || '')
-
-// 鏂扮郴缁熸枃浠剁疆浜巃dmin涓� ../options.json , { cache: 'no-cache'}
 
 fetch('../options.json')
   .then(response => response.json())
@@ -69,17 +46,35 @@
     GLOB.lineColor = config.lineColor || ''
     GLOB.licenseKey = config.licenseKey || ''
     GLOB.probation = false
-    GLOB.watermark = config.watermark !== false
-    GLOB.keepKey = config.keepPassword !== 'false'
+    GLOB.watermark = config.watermark + '' !== 'false'
+    GLOB.transfer = config.transfer + '' === 'true'
+    GLOB.keepKey = config.keepPassword + '' !== 'false'
+    GLOB.nginx = config.nginx + '' === 'true'
+    GLOB.WXAppID = config.WXAppID || ''
+    GLOB.WXminiAppID = config.WXminiAppID || ''
+    GLOB.WXNotice = config.WXNotice + '' === 'true'
+    GLOB.accessToken = {}
+    GLOB.mkHS = false
+    GLOB.debugger = false
+    GLOB.dataFormat = false
+    GLOB.navBar = 'shutter' // 榛樿涓虹櫨鍙剁獥
+    GLOB.style = 'bg_black_style_blue'
 
-    if (config.externalDatabase !== false && config.externalDatabase !== 'false' && config.externalDatabase !== undefined) {
+    GLOB.sysType = options.sysType
+    if (GLOB.sysType !== 'cloud') {
+      GLOB.cloudServiceApi = options.cdomain + '/webapi/dostars'
+    }
+
+    if (sessionStorage.getItem('externalDatabase')) {
+      GLOB.externalDatabase = `[${sessionStorage.getItem('externalDatabase')}]..`
+    } else if (config.externalDatabase + '' !== 'false' && config.externalDatabase !== undefined) {
       GLOB.externalDatabase = config.externalDatabase ? `[${config.externalDatabase}]..` : ''
     } else {
       GLOB.externalDatabase = null
     }
 
     // 鍙湁涓氬姟绯荤粺鎵嶅彲浠ヨ缃负姝e紡绯荤粺
-    if (options.sysType === 'local' && (config.systemType === 'official' || config.systemType === 'production')) {
+    if (GLOB.sysType === 'local' && (config.systemType === 'official' || config.systemType === 'production')) {
       GLOB.systemType = 'production'
       if (config.probation && /^20\d{2}-\d{2}-\d{2}$/.test(config.probation) && new Date(config.probation).getTime() > new Date().getTime()) {
         GLOB.probation = true
@@ -95,13 +90,17 @@
         document.getElementById('root').innerHTML = '<div style="text-align: center; font-size: 30px; margin-top: 40vh;">姝e紡绯荤粺涓嶅彲浣跨敤 http://cloud.mk9h.cn 鍋氫负鍗曠偣鍦板潃锛岃鑱旂郴绠$悊鍛橈紒</div>'
         return
       }
-    } else if (options.sysType === 'local') {
+    } else if (GLOB.sysType === 'local') {
       GLOB.probation = true
+      GLOB.debugger = true
       GLOB.systemType = ''
 
       // GLOB.mainSystemApi = 'https://cloud.positecgroup.com/webapi/dostars'
 
-      GLOB.mainSystemApi = 'http://sso.mk9h.cn/cloud/webapi/dostars'
+      GLOB.mainSystemApi = 'https://sso.mk9h.cn/cloud/webapi/dostars'
+      if (!/^https/.test(window.location.protocol)) { // https杞崲
+        GLOB.mainSystemApi = 'http://sso.mk9h.cn/cloud/webapi/dostars'
+      }
 
       if (GLOB.watermark) {
         GLOB.dataFormat = true
@@ -111,20 +110,24 @@
       GLOB.mainSystemApi = ''
     }
 
-    GLOB.debugger = options.sysType === 'local' && GLOB.systemType !== 'production'
+    if (/#\/hs$/.test(window.location.href)) { // hs涓嬩笉鎵撳嵃鑴氭湰
+      GLOB.debugger = false
+    }
 
-    if (options.sysType !== 'cloud') {
+    if (GLOB.sysType !== 'cloud') {
       if (config.appkey === options.cakey) {
         document.getElementById('root').innerHTML = '<div style="text-align: center; font-size: 30px; margin-top: 40vh;">涓嶅彲浣跨敤浜戠appkey锛岃鑱旂郴绠$悊鍛橈紒</div>'
         return
       }
     }
 
-    if (options.sysType === 'cloud') { // cloud涓嶅彲璁剧疆鍗曠偣鏈嶅姟鍣ㄥ湴鍧�,浜戠appkey涓虹郴缁熻缃�
+    if (GLOB.sysType === 'cloud') { // cloud涓嶅彲璁剧疆鍗曠偣鏈嶅姟鍣ㄥ湴鍧�,浜戠appkey涓虹郴缁熻缃�
       GLOB.appkey = options.cakey
-    } else if (options.sysType === 'SSO') { // sso涓嶅彲璁剧疆鍗曠偣鏈嶅姟鍣ㄥ湴鍧�
+      GLOB.appId = options.caId
+      GLOB.WXNotice = false
+    } else if (GLOB.sysType === 'SSO') { // sso涓嶅彲璁剧疆鍗曠偣鏈嶅姟鍣ㄥ湴鍧�
       GLOB.appkey = config.appkey
-    } else if (options.sysType === 'local') { // 涓氬姟绯荤粺
+    } else if (GLOB.sysType === 'local') { // 涓氬姟绯荤粺
       GLOB.appkey = config.appkey
       if (GLOB.systemType === 'production') {
         let systemApi = config.mainSystemApi
@@ -133,14 +136,18 @@
         } else if (!/webapi\/dostars$/ig.test(systemApi)) {
           systemApi = systemApi.replace(/\/?$/, '/webapi/dostars')
         }
+
+        if (/^https/.test(window.location.protocol) && /^http:/.test(systemApi) && !GLOB.transfer) {
+          systemApi = systemApi.replace(/^http:/, 'https:')
+        }
       
         GLOB.mainSystemApi = systemApi
       }
     }
 
     let _href = window.location.href.split('#')[0]
-
     let _systemMsg = localStorage.getItem(_href + 'system')
+    let className = 'mk-blue-black'
 
     if (_systemMsg) {
       try {
@@ -156,9 +163,9 @@
         GLOB.mainlogo = _systemMsg.mainlogo
         GLOB.doclogo = _systemMsg.doclogo
         GLOB.webSite = _systemMsg.webSite
-        GLOB.style = _systemMsg.style
+        GLOB.style = _systemMsg.style || 'bg_black_style_blue'
         GLOB.showline = _systemMsg.showline || ''
-        GLOB.navBar = _systemMsg.navBar || ''
+        GLOB.navBar = _systemMsg.navBar || 'shutter'
         GLOB.appVersion = _systemMsg.app_version || ''
 
         if (GLOB.favicon) {
@@ -168,13 +175,15 @@
           link.href = GLOB.favicon
           document.getElementsByTagName('head')[0].appendChild(link)
         }
-        if (GLOB.style && styles[GLOB.style]) {
-          document.body.className = styles[GLOB.style] + ' ' + (GLOB.showline === 'false' ? 'hidden-split-line' : '')
+        if (styles[GLOB.style]) {
+          className = styles[GLOB.style] + ' ' + (GLOB.showline === 'false' ? 'hidden-split-line' : '')
         }
       } catch (e) {
         console.warn('Parse Failure')
       }
     }
+
+    document.body.className = className
 
     if (/^https/.test(window.location.protocol)) { // https杞崲
       let meta = document.createElement('meta')
@@ -186,40 +195,49 @@
     document.title = GLOB.platTitle || ''
 
     if (config.filter === 'true' || (/^20\d{2}-\d{2}-\d{2}$/.test(config.filter) && new Date(config.filter).getTime() + 86400000 >= new Date().getTime())) {
-      let html = document.getElementsByTagName('html')[0]
-      
-      if (html) {
-        html.style.filter = 'grayscale(100%)'
-      }
+      GLOB.filter = true
     }
 
     if (process.env.NODE_ENV === 'production') { // 鐢ㄤ簬鏍¢獙鏄惁瀛樺湪寮�鍙戞潈闄�
-      let _service = window.location.href.replace(/(\/admin)?\/index.html(.*)|(\/admin)?\/#(.*)/ig, '').replace(new RegExp(document.location.origin + '/?', 'ig'), '')
-      GLOB.linkurl = _href
-      if (!/index.html/ig.test(GLOB.linkurl)) {
-        GLOB.linkurl = GLOB.linkurl + 'index.html'
-      }
+      let _service = window.location.href.replace(/\/admin(.*)/ig, '').replace(new RegExp(document.location.origin + '/?', 'ig'), '')
       GLOB.service = _service ? _service + '/' : ''
       GLOB.host = window.location.host + (_service ? '_' + _service : '')
+      GLOB.baseurl = document.location.origin + '/' + GLOB.service
+      GLOB.linkurl = GLOB.baseurl + 'index.html'
     } else {
-      GLOB.linkurl = ''
       GLOB.location = config.host
       GLOB.service = config.service
       GLOB.host = config.host.replace(/http(s)?:\/\//ig, '') + (config.service ? '_' + config.service.replace(/\//ig, '') : '')
+      GLOB.baseurl = GLOB.location + '/' + GLOB.service
+      GLOB.linkurl = GLOB.baseurl + 'index.html'
+      GLOB.dataFormat = false
+
+      let mark = sessionStorage.getItem('system_mark')
+      let _mark = `sys_${GLOB.service.replace('/', '') || 'service'}`
+      if (mark && mark !== _mark) {
+        sessionStorage.clear()
+      }
+      sessionStorage.setItem('system_mark', _mark)
     }
 
-    let mark = sessionStorage.getItem('system_mark')
-    let _mark = `sys_${GLOB.service.replace('/', '') || 'service'}`
-    if (mark && mark !== _mark) {
-      sessionStorage.clear()
-    }
-    sessionStorage.setItem('system_mark', _mark)
+    let lang = localStorage.getItem(_href + 'lang') || (config.defaultLang !== 'en-US' ? 'zh-CN' : 'en-US')
+    sessionStorage.setItem('lang', lang)
 
-    if (localStorage.getItem(_href + 'lang')) {
-      sessionStorage.setItem('lang', localStorage.getItem(_href + 'lang'))
-    } else {
-      sessionStorage.setItem('lang', config.defaultLang !== 'en-US' ? 'zh-CN' : 'en-US')
+    let _level = 0
+    let _Mlevel = sessionStorage.getItem('Member_Level')
+
+    if (_Mlevel) {
+      if (_Mlevel === md5('mksoft' + GLOB.appkey + new Date().getFullYear() + new Date().getMonth() + 10)) {
+        _level = 10
+      } else if (_Mlevel === md5('mksoft' + GLOB.appkey + new Date().getFullYear() + new Date().getMonth() + 20)) {
+        _level = 20
+      } else if (_Mlevel === md5('mksoft' + GLOB.appkey + new Date().getFullYear() + new Date().getMonth() + 30)) {
+        _level = 30
+      }
     }
+    GLOB.memberLevel = _level
+    GLOB.mkThdMenus = [] // 涓夌骇鑿滃崟
+    GLOB.mkActions = {}  // 鎸夐挳鏉冮檺闆�
 
     Object.defineProperty(GLOB, 'appId', {
       writable: false,
@@ -233,10 +251,6 @@
       writable: false,
       value: GLOB.systemType
     })
-    Object.defineProperty(GLOB, 'debugger', {
-      writable: false,
-      value: GLOB.debugger
-    })
     Object.defineProperty(GLOB, 'mainSystemApi', {
       writable: false,
       value: GLOB.mainSystemApi
@@ -245,13 +259,42 @@
       writable: false,
       value: GLOB.linkurl
     })
+    Object.defineProperty(GLOB, 'sysType', {
+      writable: false,
+      value: GLOB.sysType
+    })
+    Object.defineProperty(GLOB, 'cloudServiceApi', {
+      writable: false,
+      value: GLOB.cloudServiceApi || ''
+    })
+
+    if (GLOB.sysType === 'cloud') {
+      Object.defineProperty(GLOB, 'debugger', {
+        writable: false,
+        value: GLOB.debugger
+      })
+
+      GLOB.breakpoint = false
+    } else {
+      if (sessionStorage.getItem('breakpoint')) {
+        GLOB.debugger = true
+        GLOB.breakpoint = sessionStorage.getItem('breakpoint')
+      } else {
+        GLOB.breakpoint = false
+      }
+    }
+
     Object.defineProperty(window, 'GLOB', {
       writable: false,
       value: GLOB
     })
 
     window.GLOB.CacheMap = new Map()     // 缂撳瓨閰嶇疆淇℃伅
+    window.GLOB.CacheVoucher = new Map() // 缂撳瓨鍑瘉淇℃伅
     window.GLOB.UserCacheMap = new Map() // 缂撳瓨鐢ㄦ埛鑷畾涔夎缃�
+    window.GLOB.CacheData = new Map()    // 瀛樺偍閫変腑鏁版嵁
+    window.GLOB.SearchBox = new Map()    // 瀛樺偍鎼滅储鏉′欢
+    window.GLOB.SyncData = new Map()     // 瀛樺偍鍚屾鏌ヨ鏁版嵁
 
     render(Route)
   })

--
Gitblit v1.8.0