From 225585977abf9c459e4722e2f7547173f3040e19 Mon Sep 17 00:00:00 2001
From: unanmed <1319491857@qq.com>
Date: Sun, 16 Apr 2023 17:30:22 +0800
Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8Dbug?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
public/libs/control.js | 2 +-
public/libs/core.js | 9 ++++----
public/main.js | 5 +++--
public/project/floors/MT42.js | 7 -------
public/project/plugin/index.js | 36 ++++++++++++++++----------------
public/project/plugin/loopMap.js | 2 +-
public/project/plugin/replay.js | 2 +-
script/build.ts | 11 +++++-----
src/types/core.d.ts | 2 +-
9 files changed, 34 insertions(+), 42 deletions(-)
diff --git a/public/libs/control.js b/public/libs/control.js
index e2ab60f..37ca008 100644
--- a/public/libs/control.js
+++ b/public/libs/control.js
@@ -2568,7 +2568,7 @@ control.prototype._doSL_load = function (id, callback) {
id == 'autoSave' ? id : 'save' + id,
null,
function (data) {
- if (!main.replayChecking) {
+ if (!main.replayChecking && data) {
core.plugin.startOpened.value = false;
core.plugin.loaded.value = false;
}
diff --git a/public/libs/core.js b/public/libs/core.js
index 4f10a4f..6e34670 100644
--- a/public/libs/core.js
+++ b/public/libs/core.js
@@ -322,11 +322,10 @@ core.prototype._loadPlugin = async function () {
if (main.pluginUseCompress) {
await main.loadScript(`project/plugin.m.js?v=${main.version}`);
} else {
- for await (const plugin of mainData.plugin) {
- await main.loadScript(
- `project/plugin/${plugin}.js?v=${main.version}`
- );
- }
+ await main.loadScript(
+ `project/plugin/index.js?v=${main.version}`,
+ true
+ );
}
};
diff --git a/public/main.js b/public/main.js
index 40a93ef..f5b2865 100644
--- a/public/main.js
+++ b/public/main.js
@@ -5,7 +5,7 @@ function main() {
this.version = '1.0.0'; // 游戏版本号;如果更改了游戏内容建议修改此version以免造成缓存问题。
this.useCompress = false; // 是否使用压缩文件
- this.pluginUseCompress = false; // 仅限于gh-pages使用
+ this.pluginUseCompress = false;
// 当你即将发布你的塔时,请使用“JS代码压缩工具”将所有js代码进行压缩,然后将这里的useCompress改为true。
// 请注意,只有useCompress是false时才会读取floors目录下的文件,为true时会直接读取libs目录下的floors.min.js文件。
// 如果要进行剧本的修改请务必将其改成false。
@@ -219,9 +219,10 @@ function main() {
}
// >>>> body end
-main.prototype.loadScript = async function (src) {
+main.prototype.loadScript = async function (src, module) {
const script = document.createElement('script');
script.src = src;
+ if (module) script.type = 'module';
document.body.appendChild(script);
await new Promise(res => {
script.addEventListener('load', res);
diff --git a/public/project/floors/MT42.js b/public/project/floors/MT42.js
index 0d1897f..dd12f07 100644
--- a/public/project/floors/MT42.js
+++ b/public/project/floors/MT42.js
@@ -59,13 +59,6 @@ main.floors.MT42=
0,
13
]
- },
- "8,12": {
- "floorId": "MT48",
- "loc": [
- 3,
- 7
- ]
}
},
"beforeBattle": {},
diff --git a/public/project/plugin/index.js b/public/project/plugin/index.js
index 6aea035..076069e 100644
--- a/public/project/plugin/index.js
+++ b/public/project/plugin/index.js
@@ -1,21 +1,21 @@
-import './fiveLayer';
-import './heroFourFrames';
-import './hotReload';
-import './itemDetail';
-import './popup';
-import './replay';
-import './ui';
-import * as halo from './halo';
-import * as hero from './hero';
-import * as loopMap from './loopMap';
-import * as remainEnemy from './remainEnemy';
-import * as removeMap from './removeMap';
-import * as shop from './shop';
-import * as skill from './skills';
-import * as skillTree from './skillTree';
-import * as study from './study';
-import * as towerBoss from './towerBoss';
-import * as utils from './utils';
+import './fiveLayer.js';
+import './heroFourFrames.js';
+import './hotReload.js';
+import './itemDetail.js';
+import './popup.js';
+import './replay.js';
+import './ui.js';
+import * as halo from './halo.js';
+import * as hero from './hero.js';
+import * as loopMap from './loopMap.js';
+import * as remainEnemy from './remainEnemy.js';
+import * as removeMap from './removeMap.js';
+import * as shop from './shop.js';
+import * as skill from './skills.js';
+import * as skillTree from './skillTree.js';
+import * as study from './study.js';
+import * as towerBoss from './towerBoss.js';
+import * as utils from './utils.js';
export {
halo,
diff --git a/public/project/plugin/loopMap.js b/public/project/plugin/loopMap.js
index 4cdef85..93cf92c 100644
--- a/public/project/plugin/loopMap.js
+++ b/public/project/plugin/loopMap.js
@@ -1,5 +1,5 @@
///
-import { slide } from './utils';
+import { slide } from './utils.js';
const list = ['tower6'];
diff --git a/public/project/plugin/replay.js b/public/project/plugin/replay.js
index b246dd4..24012a7 100644
--- a/public/project/plugin/replay.js
+++ b/public/project/plugin/replay.js
@@ -1,6 +1,6 @@
///
-import { studySkill, canStudySkill } from './study';
+import { studySkill, canStudySkill } from './study.js';
const replayableSettings = ['autoSkill'];
diff --git a/script/build.ts b/script/build.ts
index 4104431..45850c9 100644
--- a/script/build.ts
+++ b/script/build.ts
@@ -108,11 +108,6 @@ import * as rollup from 'rollup';
const compressed = babel.transformSync(code.output[0].code)?.code!;
await fs.writeFile('./dist/project/plugin.m.js', compressed, 'utf-8');
- const main = await fs.readFile('./dist/main.js', 'utf-8');
- main.replace(
- /this.pluginUseCompress\s*=\s*false\;/,
- 'this.pluginUseCompress = true;'
- );
await fse.remove('./dist/project/plugin/');
} catch (e) {
console.log('压缩插件失败');
@@ -121,7 +116,11 @@ import * as rollup from 'rollup';
// 4. 压缩main.js
try {
// 先获取不能压缩的部分
- const main = await fs.readFile('./dist/main.js', 'utf-8');
+ const main = (await fs.readFile('./public/main.js', 'utf-8')).replace(
+ /this.pluginUseCompress\s*=\s*false\;/,
+ 'this.pluginUseCompress = true;'
+ );
+
const endIndex = main.indexOf('// >>>> body end');
const nonCompress = main.slice(0, endIndex);
const needCompress = main.slice(endIndex + 17);
diff --git a/src/types/core.d.ts b/src/types/core.d.ts
index 2209235..5a75455 100644
--- a/src/types/core.d.ts
+++ b/src/types/core.d.ts
@@ -1267,7 +1267,7 @@ interface Main extends MainData {
* 加载一个脚本
* @param src 脚本路径
*/
- loadScript(src: string): Promise;
+ loadScript(src: string, module?: boolean): Promise;
/**
* 动态加载js文件