hrbattle 1.1.3 → 1.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -20,7 +20,6 @@ export interface BattleJsonConfigBundle {
20
20
  monsterSkillBooks: JsonHeroSkillBook[];
21
21
  roster: JsonRoster;
22
22
  }
23
- export declare function loadBattleJsonConfigBundle(): BattleJsonConfigBundle;
24
23
  export declare function validateBattleJsonConfigBundle(bundle: BattleJsonConfigBundle): void;
25
24
  /** 英雄入参:可以是纯 heroId 字符串,也可以带技能等级覆盖 */
26
25
  export type HeroInput = string | {
@@ -45,20 +45,6 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
45
45
  }
46
46
  return to.concat(ar || Array.prototype.slice.call(from));
47
47
  };
48
- import designedBuffs from "./json/designed-buffs.json";
49
- import designedHeroSkillBooks from "./json/designed-hero-skill-books.json";
50
- import designedMonsterSkillBooks from "./json/designed-monster-skill-books.json";
51
- import designedRoster from "./json/designed-roster.json";
52
- import designedSkillTemplates from "./json/designed-skill-templates.json";
53
- export function loadBattleJsonConfigBundle() {
54
- return {
55
- buffs: designedBuffs,
56
- skillTemplates: designedSkillTemplates,
57
- heroSkillBooks: designedHeroSkillBooks,
58
- monsterSkillBooks: designedMonsterSkillBooks,
59
- roster: designedRoster
60
- };
61
- }
62
48
  export function validateBattleJsonConfigBundle(bundle) {
63
49
  var e_1, _a, e_2, _b, e_3, _c, e_4, _d, e_5, _e, e_6, _f;
64
50
  var buffIds = new Set(bundle.buffs.map(function (item) { return item.id; }));
@@ -2,7 +2,7 @@ import type { BattleResult } from "../battle/battleCore.js";
2
2
  import { type BattleJsonConfigBundle, type HeroInput } from "../battle/config/jsonConfigLoader.js";
3
3
  import type { BattleConfig, BattleInitUnit, ISkillScript } from "../battle/types.js";
4
4
  export interface ReusableBattleFacadeOptions {
5
- bundle?: BattleJsonConfigBundle;
5
+ bundle: BattleJsonConfigBundle;
6
6
  scripts?: Record<string, ISkillScript>;
7
7
  defaultConfig?: BattleConfig;
8
8
  validateBundle?: boolean;
@@ -12,7 +12,7 @@ export declare class ReusableBattleFacade {
12
12
  private readonly bundle;
13
13
  private readonly scripts;
14
14
  private defaultConfig?;
15
- constructor(options?: ReusableBattleFacadeOptions);
15
+ constructor(options: ReusableBattleFacadeOptions);
16
16
  getBundle(): BattleJsonConfigBundle;
17
17
  setDefaultConfig(config: BattleConfig): void;
18
18
  buildUnits(team1?: HeroInput[], team2?: HeroInput[]): BattleInitUnit[];
@@ -36,16 +36,15 @@ var __read = (this && this.__read) || function (o, n) {
36
36
  }
37
37
  return ar;
38
38
  };
39
- import { buildBattleUnitsFromJsonBundle, loadBattleJsonConfigBundle, validateBattleJsonConfigBundle } from "../battle/config/jsonConfigLoader.js";
39
+ import { buildBattleUnitsFromJsonBundle, validateBattleJsonConfigBundle } from "../battle/config/jsonConfigLoader.js";
40
40
  import { designedScripts } from "../battle/script/designedScripts.js";
41
41
  import { BattleFacade } from "./BattleFacade.js";
42
42
  var ReusableBattleFacade = /** @class */ (function () {
43
43
  function ReusableBattleFacade(options) {
44
- if (options === void 0) { options = {}; }
45
- var _a, _b;
44
+ var _a;
46
45
  this.facade = new BattleFacade();
47
- this.bundle = (_a = options.bundle) !== null && _a !== void 0 ? _a : loadBattleJsonConfigBundle();
48
- this.scripts = (_b = options.scripts) !== null && _b !== void 0 ? _b : designedScripts;
46
+ this.bundle = options.bundle;
47
+ this.scripts = (_a = options.scripts) !== null && _a !== void 0 ? _a : designedScripts;
49
48
  this.defaultConfig = options.defaultConfig;
50
49
  if (options.validateBundle !== false) {
51
50
  validateBattleJsonConfigBundle(this.bundle);
package/dist/index.d.ts CHANGED
@@ -8,7 +8,7 @@ export { EffectSystem } from "./battle/effectSystem.js";
8
8
  export { calcDamage, calcEffectProbability, calcHealOrShield } from "./battle/formula.js";
9
9
  export { ConfigSkillEngine, ScriptSkillEngine, SkillExecutor } from "./battle/skillEngine.js";
10
10
  export { designedScripts } from "./battle/script/designedScripts.js";
11
- export { loadBattleJsonConfigBundle, validateBattleJsonConfigBundle, buildBattleUnitsFromJsonBundle } from "./battle/config/jsonConfigLoader.js";
11
+ export { validateBattleJsonConfigBundle, buildBattleUnitsFromJsonBundle } from "./battle/config/jsonConfigLoader.js";
12
12
  export type { BattleJsonConfigBundle, HeroInput } from "./battle/config/jsonConfigLoader.js";
13
13
  export type { BattleScriptApi, BattleConfig, BattleInitUnit, BuffConfig, ElementType, ISkillScript, SkillDefinition, SkillExecMode, SkillTemplate, SkillType, TargetRule, UnitModel, UnitStats } from "./battle/types.js";
14
14
  export type { BattleResult } from "./battle/battleCore.js";
package/dist/index.js CHANGED
@@ -7,4 +7,4 @@ export { EffectSystem } from "./battle/effectSystem.js";
7
7
  export { calcDamage, calcEffectProbability, calcHealOrShield } from "./battle/formula.js";
8
8
  export { ConfigSkillEngine, ScriptSkillEngine, SkillExecutor } from "./battle/skillEngine.js";
9
9
  export { designedScripts } from "./battle/script/designedScripts.js";
10
- export { loadBattleJsonConfigBundle, validateBattleJsonConfigBundle, buildBattleUnitsFromJsonBundle } from "./battle/config/jsonConfigLoader.js";
10
+ export { validateBattleJsonConfigBundle, buildBattleUnitsFromJsonBundle } from "./battle/config/jsonConfigLoader.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "hrbattle",
3
- "version": "1.1.3",
3
+ "version": "1.1.4",
4
4
  "description": "一个基于回合制战斗引擎,支持技能脚本、buff系统和效果解析。",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -13,13 +13,11 @@
13
13
  },
14
14
  "files": [
15
15
  "dist",
16
- "src",
17
- "tests"
16
+ "src"
18
17
  ],
19
18
  "scripts": {
20
19
  "build": "tsc",
21
- "prepublishOnly": "npm run build",
22
- "battle:result": "vitest run tests/battleResultOutput.test.ts"
20
+ "prepublishOnly": "npm run build"
23
21
  },
24
22
  "keywords": [
25
23
  "battle",
@@ -34,7 +32,6 @@
34
32
  "@types/node": "^22.15.3",
35
33
  "tsx": "^4.19.4",
36
34
  "typescript": "^5.8.3",
37
- "vitest": "^3.1.2",
38
35
  "xlsx": "^0.18.5"
39
36
  }
40
37
  }
@@ -1,11 +1,5 @@
1
1
  import type { BattleInitUnit, BuffConfig, SkillDefinition, SkillTemplate, UnitStats } from "../types.js";
2
2
 
3
- import designedBuffs from "./json/designed-buffs.json";
4
- import designedHeroSkillBooks from "./json/designed-hero-skill-books.json";
5
- import designedMonsterSkillBooks from "./json/designed-monster-skill-books.json";
6
- import designedRoster from "./json/designed-roster.json";
7
- import designedSkillTemplates from "./json/designed-skill-templates.json";
8
-
9
3
  type JsonHeroSkillBook = {
10
4
  heroId: string;
11
5
  heroName: string;
@@ -30,16 +24,6 @@ export interface BattleJsonConfigBundle {
30
24
  roster: JsonRoster;
31
25
  }
32
26
 
33
- export function loadBattleJsonConfigBundle(): BattleJsonConfigBundle {
34
- return {
35
- buffs: designedBuffs as BuffConfig[],
36
- skillTemplates: designedSkillTemplates as SkillTemplate[],
37
- heroSkillBooks: designedHeroSkillBooks as JsonHeroSkillBook[],
38
- monsterSkillBooks: designedMonsterSkillBooks as JsonHeroSkillBook[],
39
- roster: designedRoster as JsonRoster
40
- };
41
- }
42
-
43
27
  export function validateBattleJsonConfigBundle(bundle: BattleJsonConfigBundle): void {
44
28
  const buffIds = new Set(bundle.buffs.map((item) => item.id));
45
29
  const templateIds = new Set(bundle.skillTemplates.map((item) => item.id));
@@ -1,7 +1,6 @@
1
1
  import type { BattleResult } from "../battle/battleCore.js";
2
2
  import {
3
3
  buildBattleUnitsFromJsonBundle,
4
- loadBattleJsonConfigBundle,
5
4
  validateBattleJsonConfigBundle,
6
5
  type BattleJsonConfigBundle,
7
6
  type HeroInput
@@ -11,7 +10,7 @@ import type { BattleConfig, BattleInitUnit, ISkillScript } from "../battle/types
11
10
  import { BattleFacade } from "./BattleFacade.js";
12
11
 
13
12
  export interface ReusableBattleFacadeOptions {
14
- bundle?: BattleJsonConfigBundle;
13
+ bundle: BattleJsonConfigBundle;
15
14
  scripts?: Record<string, ISkillScript>;
16
15
  defaultConfig?: BattleConfig;
17
16
  validateBundle?: boolean;
@@ -23,8 +22,8 @@ export class ReusableBattleFacade {
23
22
  private readonly scripts: Record<string, ISkillScript>;
24
23
  private defaultConfig?: BattleConfig;
25
24
 
26
- constructor(options: ReusableBattleFacadeOptions = {}) {
27
- this.bundle = options.bundle ?? loadBattleJsonConfigBundle();
25
+ constructor(options: ReusableBattleFacadeOptions) {
26
+ this.bundle = options.bundle;
28
27
  this.scripts = options.scripts ?? designedScripts;
29
28
  this.defaultConfig = options.defaultConfig;
30
29
  if (options.validateBundle !== false) {
package/src/index.ts CHANGED
@@ -20,7 +20,6 @@ export { calcDamage, calcEffectProbability, calcHealOrShield } from "./battle/fo
20
20
  export { ConfigSkillEngine, ScriptSkillEngine, SkillExecutor } from "./battle/skillEngine.js";
21
21
  export { designedScripts } from "./battle/script/designedScripts.js";
22
22
  export {
23
- loadBattleJsonConfigBundle,
24
23
  validateBattleJsonConfigBundle,
25
24
  buildBattleUnitsFromJsonBundle
26
25
  } from "./battle/config/jsonConfigLoader.js";
@@ -43,4 +42,4 @@ export type {
43
42
  UnitModel,
44
43
  UnitStats
45
44
  } from "./battle/types.js";
46
- export type { BattleResult } from "./battle/battleCore.js";
45
+ export type { BattleResult } from "./battle/battleCore.js";