fix: show error bug.

This commit is contained in:
Rintim 2024-01-09 23:21:51 +08:00
parent 98fc7e4aa3
commit 0a3d5216f5
No known key found for this signature in database
GPG Key ID: BE9E1EA615BACFCF
1 changed files with 101 additions and 100 deletions

View File

@ -1,100 +1,101 @@
"use strict"; "use strict";
new Promise(resolve => { new Promise(resolve => {
// 客户端自带core.js的请注意跟进 // 客户端自带core.js的请注意跟进
if ('__core-js_shared__' in window) resolve(null); if ('__core-js_shared__' in window) resolve(null);
else { else {
const nonameInitialized = localStorage.getItem('noname_inited'); const nonameInitialized = localStorage.getItem('noname_inited');
const assetURL = typeof nonameInitialized != 'string' || nonameInitialized == 'nodejs' ? '' : nonameInitialized; const assetURL = typeof nonameInitialized != 'string' || nonameInitialized == 'nodejs' ? '' : nonameInitialized;
const coreJSBundle = document.createElement('script'); const coreJSBundle = document.createElement('script');
coreJSBundle.onerror = coreJSBundle.onload = resolve; coreJSBundle.onerror = coreJSBundle.onload = resolve;
coreJSBundle.src = `${assetURL}game/core-js-bundle.js`; coreJSBundle.src = `${assetURL}game/core-js-bundle.js`;
document.head.appendChild(coreJSBundle); document.head.appendChild(coreJSBundle);
} }
}).then(() => { }).then(() => {
const nonameInitialized = localStorage.getItem('noname_inited'); const nonameInitialized = localStorage.getItem('noname_inited');
const assetURL = typeof nonameInitialized != 'string' || nonameInitialized == 'nodejs' ? '' : nonameInitialized; const assetURL = typeof nonameInitialized != 'string' || nonameInitialized == 'nodejs' ? '' : nonameInitialized;
const userAgent = navigator.userAgent.toLowerCase(); const userAgent = navigator.userAgent.toLowerCase();
const exit = () => { const exit = () => {
const ios = userAgent.includes('iphone') || userAgent.includes('ipad') || userAgent.includes('macintosh'); const ios = userAgent.includes('iphone') || userAgent.includes('ipad') || userAgent.includes('macintosh');
//electron //electron
if (typeof window.process == 'object' && typeof window.require == 'function') { if (typeof window.process == 'object' && typeof window.require == 'function') {
const versions = window.process.versions; const versions = window.process.versions;
// @ts-ignore // @ts-ignore
const electronVersion = parseFloat(versions.electron); const electronVersion = parseFloat(versions.electron);
let remote; let remote;
if (electronVersion >= 14) { if (electronVersion >= 14) {
// @ts-ignore // @ts-ignore
remote = require('@electron/remote'); remote = require('@electron/remote');
} else { } else {
// @ts-ignore // @ts-ignore
remote = require('electron').remote; remote = require('electron').remote;
} }
const thisWindow = remote.getCurrentWindow(); const thisWindow = remote.getCurrentWindow();
thisWindow.destroy(); thisWindow.destroy();
window.process.exit(); window.process.exit();
} }
//android-cordova环境 //android-cordova环境
//ios-cordova环境或ios浏览器环境 //ios-cordova环境或ios浏览器环境
//非ios的网页版 //非ios的网页版
else if (!ios) { else if (!ios) {
window.close(); window.close();
} }
}; };
if (!localStorage.getItem('gplv3_noname_alerted')) { if (!localStorage.getItem('gplv3_noname_alerted')) {
if (confirm('①无名杀是一款基于GPLv3协议的开源软件\n你可以在遵守GPLv3协议的基础上任意使用修改并转发《无名杀》以及所有基于《无名杀》开发的拓展。\n点击“确定”即代表您认可并接受GPLv3协议↓\nhttps://www.gnu.org/licenses/gpl-3.0.html\n②无名杀官方发布地址仅有GitHub仓库\n其他所有的所谓“无名杀”社群包括但不限于绝大多数“官方”QQ群、QQ频道等均为玩家自发组织与无名杀官方无关')) { if (confirm('①无名杀是一款基于GPLv3协议的开源软件\n你可以在遵守GPLv3协议的基础上任意使用修改并转发《无名杀》以及所有基于《无名杀》开发的拓展。\n点击“确定”即代表您认可并接受GPLv3协议↓\nhttps://www.gnu.org/licenses/gpl-3.0.html\n②无名杀官方发布地址仅有GitHub仓库\n其他所有的所谓“无名杀”社群包括但不限于绝大多数“官方”QQ群、QQ频道等均为玩家自发组织与无名杀官方无关')) {
// @ts-ignore // @ts-ignore
localStorage.setItem('gplv3_noname_alerted', true); localStorage.setItem('gplv3_noname_alerted', true);
} }
else { else {
exit(); exit();
} }
} }
window['b' + 'ann' + 'e' + 'dE' + 'x' + 'ten' + 's' + 'i' + 'o' + 'ns'] = ['\u4fa0\u4e49', '\u5168\u6559\u7a0b']; window['b' + 'ann' + 'e' + 'dE' + 'x' + 'ten' + 's' + 'i' + 'o' + 'ns'] = ['\u4fa0\u4e49', '\u5168\u6559\u7a0b'];
/** /**
* *
* @returns {["firefox" | "chrome" | "safari" | "other", number]} * @returns {["firefox" | "chrome" | "safari" | "other", number]}
*/ */
function coreInfo() { function coreInfo() {
const regex = /(firefox|chrome|safari)\/([\d.]+)/; const regex = /(firefox|chrome|safari)\/([\d.]+)/;
let result; let result;
if (!(result = userAgent.match(regex))) return ["other", NaN]; if (!(result = userAgent.match(regex))) return ["other", NaN];
if (result[1] !== "safari") return [result[1], parseInt(result[2])]; if (result[1] !== "safari") return [result[1], parseInt(result[2])];
result = userAgent.match(/version\/([\d.]+).*safari/); result = userAgent.match(/version\/([\d.]+).*safari/);
// @ts-ignore // @ts-ignore
return ["safari", parseInt(result[1])]; return ["safari", parseInt(result[1])];
} }
const [core, version] = coreInfo(); const [core, version] = coreInfo();
const supportMap = { const supportMap = {
"firefox": 60, "firefox": 60,
"chrome": 61, "chrome": 61,
// 因为coreInfo不考虑子版本故就强行只能以11运行 // 因为coreInfo不考虑子版本故就强行只能以11运行
"safari": 11 "safari": 11
} }
if (core in supportMap && supportMap[core] > version) { if (core in supportMap && supportMap[core] > version) {
const tip = '检测到您的浏览器内核版本无法支持ES Module请立即升级浏览器或手机webview内核'; const tip = '检测到您的浏览器内核版本无法支持ES Module请立即升级浏览器或手机webview内核';
console.error(tip); console.error(tip);
const redirect_tip = '您使用的浏览器或无名杀客户端内核版本过低,已经无法正常运行无名杀!\n点击“确认”以前往GitHub下载最新版无名杀客户端可能需要科学上网。\n稍后您的无名杀将自动退出可能的话'; const redirect_tip = '您使用的浏览器或无名杀客户端内核版本过低,已经无法正常运行无名杀!\n点击“确认”以前往GitHub下载最新版无名杀客户端可能需要科学上网。\n稍后您的无名杀将自动退出可能的话';
if (confirm(redirect_tip)) { if (confirm(redirect_tip)) {
window.open('https://github.com/libccy/noname/releases/tag/chromium77-client'); window.open('https://github.com/libccy/noname/releases/tag/chromium77-client');
} }
exit() exit()
} }
else { else {
const script = document.createElement('script') const script = document.createElement('script')
script.type = "module"; script.type = "module";
script.src = `${assetURL}game/entry.js` script.src = `${assetURL}game/entry.js`
script.async = true script.async = true
script.onerror = (event) => { script.onerror = (event) => {
console.error(event) console.error(event)
const message = `您使用的浏览器或无名杀客户端加载内容失败!\n报错内容: \n${event}\n若该BUG不为您个人原因造成的请及时反馈给无名杀开发组`; const message = `您使用的浏览器或无名杀客户端加载内容失败!\n请检查游戏环境以及"(游戏根目录)/game/entry.js"文件的位置\n若该BUG不为您个人原因造成的请及时反馈给无名杀开发组`;
alert(message); console.error(message);
exit() alert(message);
} exit()
document.head.appendChild(script) }
} document.head.appendChild(script)
}); }
});