From 31aa3ba8a4b028d04c43b5960e23820abffd1ad1 Mon Sep 17 00:00:00 2001 From: king <18310653075@163.com> Date: 星期一, 27 五月 2024 14:23:09 +0800 Subject: [PATCH] 2024-05-27 --- src/index.js | 196 +++++++++++++++++++++++++++++++----------------- 1 files changed, 127 insertions(+), 69 deletions(-) diff --git a/src/index.js b/src/index.js index af0d183..2fbab2f 100644 --- a/src/index.js +++ b/src/index.js @@ -1,9 +1,7 @@ import React from 'react' import ReactDOM from 'react-dom' import Route from './router' -import { Provider } from 'react-redux' import md5 from 'md5' -import store from '@/store' import * as serviceWorker from './serviceWorker' import options, { styles } from '@/store/options.js' import '@/assets/css/main.scss' @@ -23,9 +21,7 @@ const render = Component => { ReactDOM.render( - <Provider store={store}> - <Component/> - </Provider>, + <Component/>, document.getElementById('root') ) } @@ -39,14 +35,10 @@ if (!config) return if (config.defaultApp) { - if ((navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i))) { + if (/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i.test(navigator.userAgent)) { window.location.replace(window.location.href.split(/(index.html)+/ig)[0].replace('admin/', '') + 'mob/index.html#/index') return } - } - - if (options.cdomain && options.sysType !== 'cloud') { - options.cloudServiceApi = options.cdomain + '/webapi/dostars' } let GLOB = {} @@ -61,8 +53,19 @@ GLOB.WXAppID = config.WXAppID || '' GLOB.WXminiAppID = config.WXminiAppID || '' GLOB.WXNotice = config.WXNotice + '' === 'true' + GLOB.execType = config.execType === 'x' ? 'x' : '' GLOB.accessToken = {} GLOB.mkHS = false + GLOB.debugger = false + GLOB.dataFormat = false + GLOB.upStatus = false + GLOB.navBar = 'shutter' // 榛樿涓虹櫨鍙剁獥 + GLOB.style = 'bg_black_style_blue' + + GLOB.sysType = options.sysType + if (GLOB.sysType !== 'cloud') { + GLOB.cloudServiceApi = options.cdomain + '/webapi/dostars' + } if (sessionStorage.getItem('externalDatabase')) { GLOB.externalDatabase = `[${sessionStorage.getItem('externalDatabase')}]..` @@ -72,13 +75,15 @@ GLOB.externalDatabase = null } - // 鍙湁涓氬姟绯荤粺鎵嶅彲浠ヨ缃负姝e紡绯荤粺 - if (options.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 - } + if (config.probation && /^20\d{2}-\d{2}-\d{2}$/.test(config.probation) && new Date(config.probation).getTime() > new Date().getTime()) { + GLOB.probation = true + } + if (config.forcedUpdate && /^20\d{2}-\d{2}-\d{2}$/.test(config.forcedUpdate) && new Date(config.forcedUpdate).getTime() > new Date().getTime()) { + GLOB.forcedUpdate = true + } + // 鍙湁涓氬姟绯荤粺鎵嶅彲浠ヨ缃负姝e紡绯荤粺 + if (GLOB.sysType === 'local' && (config.systemType === 'official' || config.systemType === 'production')) { if (!config.mainSystemApi) { document.getElementById('root').innerHTML = '<div style="text-align: center; font-size: 30px; margin-top: 40vh;">绯荤粺鏈缃崟鐐瑰湴鍧�锛岃鑱旂郴绠$悊鍛橈紒</div>' return @@ -89,9 +94,13 @@ 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') { + + GLOB.systemType = 'production' + } else if (GLOB.sysType === 'local') { GLOB.probation = true + GLOB.debugger = true GLOB.systemType = '' + GLOB.upStatus = config.updateStatus + '' !== 'false' // GLOB.mainSystemApi = 'https://cloud.positecgroup.com/webapi/dostars' @@ -108,25 +117,20 @@ 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 + GLOB.appId = options.caId GLOB.WXNotice = false - } else if (options.sysType === 'SSO') { // sso涓嶅彲璁剧疆鍗曠偣鏈嶅姟鍣ㄥ湴鍧� + } 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 @@ -144,10 +148,20 @@ } } + if (/#\/hs$/.test(window.location.href)) { // hs涓嬩笉鎵撳嵃鑴氭湰 + GLOB.debugger = false + + if (GLOB.mainSystemApi) { + GLOB.localSystemApi = GLOB.mainSystemApi + GLOB.mainSystemApi = '' + } + if (GLOB.cloudServiceApi) { + GLOB.mainSystemApi = GLOB.cloudServiceApi + } + } + let _href = window.location.href.split('#')[0] let _systemMsg = localStorage.getItem(_href + 'system') - - GLOB.navBar = 'shutter' // 榛樿涓虹櫨鍙剁獥 let className = 'mk-blue-black' if (_systemMsg) { @@ -164,10 +178,21 @@ 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 || 'shutter' GLOB.appVersion = _systemMsg.app_version || '' + sessionStorage.setItem('appname', _systemMsg.appname || '') + + let levels = [30, 10, 20, 40, 50, 60, 70, 80, 90, 100] + + levels.some(m => { + if (_systemMsg.Member_Level === md5('mksoft' + GLOB.appkey + m)) { + GLOB.memberLevel = m + return true + } + return false + }) if (GLOB.favicon) { let link = document.querySelector("link[rel*='icon']") || document.createElement('link') @@ -176,17 +201,12 @@ link.href = GLOB.favicon document.getElementsByTagName('head')[0].appendChild(link) } - if (GLOB.style && styles[GLOB.style]) { + if (styles[GLOB.style]) { className = styles[GLOB.style] + ' ' + (GLOB.showline === 'false' ? 'hidden-split-line' : '') } } catch (e) { console.warn('Parse Failure') } - } - - // 涓嶄娇鐢ㄧ櫨鍙剁獥鎵撳紑鑿滃崟鏃讹紝鍘绘帀鍚堝苟鏍囪 - if (GLOB.navBar !== 'shutter') { - localStorage.removeItem('collapse') } document.body.className = className @@ -216,43 +236,50 @@ 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) - - if (localStorage.getItem(_href + 'lang')) { - sessionStorage.setItem('lang', localStorage.getItem(_href + 'lang')) - } else { - sessionStorage.setItem('lang', config.defaultLang !== 'en-US' ? 'zh-CN' : 'en-US') + if (config.mainkey && GLOB.sysType !== 'cloud' && config.mainkey !== options.cakey) { + GLOB.localkey = GLOB.appkey + GLOB.appkey = config.mainkey } - let _level = 10 - let _Mlevel = sessionStorage.getItem('Member_Level') + let lang = localStorage.getItem(_href + 'lang') || (config.defaultLang !== 'en-US' ? 'zh-CN' : 'en-US') + sessionStorage.setItem('lang', lang) - 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 + if (localStorage.getItem(_href + 'files') === md5(_href + 'files')) { + let d = localStorage.getItem(_href + 'filesDate') + + GLOB.storeFiles = true + GLOB.storeDate = Math.ceil((new Date(d).getTime() - new Date().getTime()) / 86400000) + } else if (GLOB.licenseKey && config.storeKey && config.storeKey.length === 16) { + let trans = {A:0, B:1, C:2, D:3, E:4, F:5, G:6, H:7, I:8, J:9} + let d = config.storeKey.slice(0, 8) + + d = d.split('').map(k => trans[k]).join('') + + let key = config.storeKey.slice(8) + let _key = GLOB.appId + GLOB.appkey + 'e_files_key' + d + _key = md5(_key.toLowerCase()) + _key = _key.toUpperCase() + _key = _key.slice(-8) + + if (key === _key) { + GLOB.storeFiles = true + + d = d.slice(0, 4) + '-' + d.slice(4, 6) + '-' + d.slice(6) + GLOB.storeDate = Math.ceil((new Date(d).getTime() - new Date().getTime()) / 86400000) } } - GLOB.memberLevel = _level - GLOB.mkThdMenus = [] // 涓夌骇鑿滃崟 - GLOB.mkActions = {} // 鎸夐挳鏉冮檺闆� - if (sessionStorage.getItem('breakpoint')) { - window.debugger = true - GLOB.breakpoint = sessionStorage.getItem('breakpoint') - } else { - GLOB.breakpoint = false - } + GLOB.mkActions = {} // 鎸夐挳鏉冮檺闆� Object.defineProperty(GLOB, 'appId', { writable: false, @@ -266,10 +293,6 @@ writable: false, value: GLOB.systemType }) - Object.defineProperty(GLOB, 'debugger', { - writable: false, - value: GLOB.debugger - }) Object.defineProperty(GLOB, 'mainSystemApi', { writable: false, value: GLOB.mainSystemApi @@ -278,6 +301,40 @@ 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.memberLevel) { + Object.defineProperty(GLOB, 'memberLevel', { + writable: false, + value: GLOB.memberLevel + }) + } else { + GLOB.memberLevel = 0 + } + + 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 @@ -289,6 +346,7 @@ window.GLOB.CacheData = new Map() // 瀛樺偍閫変腑鏁版嵁 window.GLOB.SearchBox = new Map() // 瀛樺偍鎼滅储鏉′欢 window.GLOB.SyncData = new Map() // 瀛樺偍鍚屾鏌ヨ鏁版嵁 + window.GLOB.mkThdMenus = new Map() // 涓夌骇鑿滃崟 render(Route) }) -- Gitblit v1.8.0