@windrosetools/windrosedata 0.0.1
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.
- package/LICENSE +661 -0
- package/README.md +120 -0
- package/data/alchemy.json +31 -0
- package/data/ammo.json +32 -0
- package/data/backpack.json +23 -0
- package/data/buildingElement.json +1757 -0
- package/data/cannon.json +11 -0
- package/data/crewEquipment.json +12 -0
- package/data/food.json +127 -0
- package/data/hullModification.json +12 -0
- package/data/item.json +44 -0
- package/data/medicine.json +30 -0
- package/data/metal.json +12 -0
- package/data/miscellaneous.json +100 -0
- package/data/resource.json +243 -0
- package/data/tool.json +52 -0
- package/dist/daos/alchemy.d.ts +23 -0
- package/dist/daos/alchemy.d.ts.map +1 -0
- package/dist/daos/alchemy.js +27 -0
- package/dist/daos/alchemy.js.map +1 -0
- package/dist/daos/ammo.d.ts +23 -0
- package/dist/daos/ammo.d.ts.map +1 -0
- package/dist/daos/ammo.js +27 -0
- package/dist/daos/ammo.js.map +1 -0
- package/dist/daos/backpack.d.ts +23 -0
- package/dist/daos/backpack.d.ts.map +1 -0
- package/dist/daos/backpack.js +27 -0
- package/dist/daos/backpack.js.map +1 -0
- package/dist/daos/buildingElement.d.ts +37 -0
- package/dist/daos/buildingElement.d.ts.map +1 -0
- package/dist/daos/buildingElement.js +34 -0
- package/dist/daos/buildingElement.js.map +1 -0
- package/dist/daos/cannon.d.ts +21 -0
- package/dist/daos/cannon.d.ts.map +1 -0
- package/dist/daos/cannon.js +26 -0
- package/dist/daos/cannon.js.map +1 -0
- package/dist/daos/crewEquipment.d.ts +21 -0
- package/dist/daos/crewEquipment.d.ts.map +1 -0
- package/dist/daos/crewEquipment.js +26 -0
- package/dist/daos/crewEquipment.js.map +1 -0
- package/dist/daos/food.d.ts +23 -0
- package/dist/daos/food.d.ts.map +1 -0
- package/dist/daos/food.js +27 -0
- package/dist/daos/food.js.map +1 -0
- package/dist/daos/helpers.d.ts +11 -0
- package/dist/daos/helpers.d.ts.map +1 -0
- package/dist/daos/helpers.js +34 -0
- package/dist/daos/helpers.js.map +1 -0
- package/dist/daos/hullModification.d.ts +21 -0
- package/dist/daos/hullModification.d.ts.map +1 -0
- package/dist/daos/hullModification.js +26 -0
- package/dist/daos/hullModification.js.map +1 -0
- package/dist/daos/item.d.ts +23 -0
- package/dist/daos/item.d.ts.map +1 -0
- package/dist/daos/item.js +27 -0
- package/dist/daos/item.js.map +1 -0
- package/dist/daos/medicine.d.ts +23 -0
- package/dist/daos/medicine.d.ts.map +1 -0
- package/dist/daos/medicine.js +27 -0
- package/dist/daos/medicine.js.map +1 -0
- package/dist/daos/metal.d.ts +19 -0
- package/dist/daos/metal.d.ts.map +1 -0
- package/dist/daos/metal.js +20 -0
- package/dist/daos/metal.js.map +1 -0
- package/dist/daos/metals.d.ts +19 -0
- package/dist/daos/metals.d.ts.map +1 -0
- package/dist/daos/metals.js +19 -0
- package/dist/daos/metals.js.map +1 -0
- package/dist/daos/miscellaneous.d.ts +23 -0
- package/dist/daos/miscellaneous.d.ts.map +1 -0
- package/dist/daos/miscellaneous.js +27 -0
- package/dist/daos/miscellaneous.js.map +1 -0
- package/dist/daos/requirements.d.ts +48 -0
- package/dist/daos/requirements.d.ts.map +1 -0
- package/dist/daos/requirements.js +242 -0
- package/dist/daos/requirements.js.map +1 -0
- package/dist/daos/resource.d.ts +23 -0
- package/dist/daos/resource.d.ts.map +1 -0
- package/dist/daos/resource.js +30 -0
- package/dist/daos/resource.js.map +1 -0
- package/dist/daos/resources.d.ts +24 -0
- package/dist/daos/resources.d.ts.map +1 -0
- package/dist/daos/resources.js +49 -0
- package/dist/daos/resources.js.map +1 -0
- package/dist/daos/tool.d.ts +23 -0
- package/dist/daos/tool.d.ts.map +1 -0
- package/dist/daos/tool.js +30 -0
- package/dist/daos/tool.js.map +1 -0
- package/dist/daos/tools.d.ts +24 -0
- package/dist/daos/tools.d.ts.map +1 -0
- package/dist/daos/tools.js +23 -0
- package/dist/daos/tools.js.map +1 -0
- package/dist/daos/validation.d.ts +2 -0
- package/dist/daos/validation.d.ts.map +1 -0
- package/dist/daos/validation.js +32 -0
- package/dist/daos/validation.js.map +1 -0
- package/dist/daos/versions.d.ts +18 -0
- package/dist/daos/versions.d.ts.map +1 -0
- package/dist/daos/versions.js +33 -0
- package/dist/daos/versions.js.map +1 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +24 -0
- package/dist/index.js.map +1 -0
- package/dist/languages.d.ts +1757 -0
- package/dist/languages.d.ts.map +1 -0
- package/dist/languages.js +44 -0
- package/dist/languages.js.map +1 -0
- package/dist/types/BuildingElement.d.ts +7 -0
- package/dist/types/BuildingElement.d.ts.map +1 -0
- package/dist/types/BuildingElement.js +8 -0
- package/dist/types/BuildingElement.js.map +1 -0
- package/dist/types/Rarity.d.ts +3 -0
- package/dist/types/Rarity.d.ts.map +1 -0
- package/dist/types/Rarity.js +4 -0
- package/dist/types/Rarity.js.map +1 -0
- package/dist/unifiedItems.d.ts +27 -0
- package/dist/unifiedItems.d.ts.map +1 -0
- package/dist/unifiedItems.js +47 -0
- package/dist/unifiedItems.js.map +1 -0
- package/dist/versions.d.ts +21 -0
- package/dist/versions.d.ts.map +1 -0
- package/dist/versions.js +36 -0
- package/dist/versions.js.map +1 -0
- package/languages/source/alchemy.json +36 -0
- package/languages/source/ammo.json +36 -0
- package/languages/source/backpack.json +18 -0
- package/languages/source/buildingElement.json +1567 -0
- package/languages/source/cannon.json +10 -0
- package/languages/source/crewEquipment.json +11 -0
- package/languages/source/food.json +164 -0
- package/languages/source/hullModification.json +10 -0
- package/languages/source/item.json +50 -0
- package/languages/source/medicine.json +39 -0
- package/languages/source/metal.json +11 -0
- package/languages/source/miscellaneous.json +147 -0
- package/languages/source/resource.json +300 -0
- package/languages/source/tool.json +44 -0
- package/package.json +41 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import alchemyData from "../../data/alchemy.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Alchemy {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.stackLimit = data.stackLimit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
}
|
|
11
|
+
static loadAlchemyByVersion() {
|
|
12
|
+
const rawByVersion = createVersionedRawStore(alchemyData);
|
|
13
|
+
const alchemyByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
14
|
+
const { required: _required, ...baseData } = data;
|
|
15
|
+
return new Alchemy(id, baseData);
|
|
16
|
+
});
|
|
17
|
+
RequirementUtils.registerLookupContext({
|
|
18
|
+
getAlchemy: (id, version) => alchemyByVersion[version][id],
|
|
19
|
+
});
|
|
20
|
+
resolveVersionedRequirements(rawByVersion, alchemyByVersion, (data) => data.required, (alchemy, required) => {
|
|
21
|
+
alchemy.required = required;
|
|
22
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
23
|
+
return alchemyByVersion;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const Alchemies = Alchemy.loadAlchemyByVersion();
|
|
27
|
+
//# sourceMappingURL=alchemy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"alchemy.js","sourceRoot":"","sources":["../../src/daos/alchemy.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,yBAAyB,CAAC;AAGlD,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAapE,MAAM,OAAO,OAAO;IAMhB,YAAY,EAAU,EAAE,IAAyB;QAC7C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,oBAAoB;QACvB,MAAM,YAAY,GAAG,uBAAuB,CACxC,WAA2E,CAC9E,CAAC;QACF,MAAM,gBAAgB,GAAG,2BAA2B,CAChD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,OAAO,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QACrC,CAAC,CACgB,CAAC;QAEtB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,UAAU,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,EAAgB,CAAC;SAC3E,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,gBAAgB,EAChB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,OAAO,EAAE,QAAQ,EAAE,EAAE;YAClB,OAAO,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAChC,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,gBAAgB,CAAC;IAC5B,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,SAAS,GAAqB,OAAO,CAAC,oBAAoB,EAAE,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import ammoData from "../../data/ammo.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type AmmoKey = keyof typeof ammoData;
|
|
6
|
+
type AmmoData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
stackLimit: number;
|
|
9
|
+
required?: Record<string, TRequired>;
|
|
10
|
+
};
|
|
11
|
+
type AmmoResolvedData = AmmoData<RequirementEntry>;
|
|
12
|
+
type AmmoByVersion = MultiVersion<AmmoKey, Ammo>;
|
|
13
|
+
export declare class Ammo {
|
|
14
|
+
id: string;
|
|
15
|
+
rarity: Rarity;
|
|
16
|
+
stackLimit: number;
|
|
17
|
+
required?: Record<string, RequirementEntry>;
|
|
18
|
+
constructor(id: string, data: AmmoResolvedData);
|
|
19
|
+
static loadAmmoByVersion(): AmmoByVersion;
|
|
20
|
+
}
|
|
21
|
+
export declare const Ammos: AmmoByVersion;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=ammo.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ammo.d.ts","sourceRoot":"","sources":["../../src/daos/ammo.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,OAAO,GAAG,MAAM,OAAO,QAAQ,CAAC;AACrC,KAAK,QAAQ,CAAC,SAAS,GAAG,MAAM,IAAI;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACxC,CAAC;AAGF,KAAK,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC;AACnD,KAAK,aAAa,GAAG,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAEjD,qBAAa,IAAI;IACN,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEvC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,gBAAgB;IAO9C,MAAM,CAAC,iBAAiB,IAAI,aAAa;CA6B5C;AAED,eAAO,MAAM,KAAK,EAAE,aAAwC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import ammoData from "../../data/ammo.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Ammo {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.stackLimit = data.stackLimit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
}
|
|
11
|
+
static loadAmmoByVersion() {
|
|
12
|
+
const rawByVersion = createVersionedRawStore(ammoData);
|
|
13
|
+
const ammoByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
14
|
+
const { required: _required, ...baseData } = data;
|
|
15
|
+
return new Ammo(id, baseData);
|
|
16
|
+
});
|
|
17
|
+
RequirementUtils.registerLookupContext({
|
|
18
|
+
getAmmo: (id, version) => ammoByVersion[version][id],
|
|
19
|
+
});
|
|
20
|
+
resolveVersionedRequirements(rawByVersion, ammoByVersion, (data) => data.required, (ammo, required) => {
|
|
21
|
+
ammo.required = required;
|
|
22
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
23
|
+
return ammoByVersion;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const Ammos = Ammo.loadAmmoByVersion();
|
|
27
|
+
//# sourceMappingURL=ammo.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ammo.js","sourceRoot":"","sources":["../../src/daos/ammo.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAG5C,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAapE,MAAM,OAAO,IAAI;IAMb,YAAY,EAAU,EAAE,IAAsB;QAC1C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,iBAAiB;QACpB,MAAM,YAAY,GAAG,uBAAuB,CACxC,QAAkE,CACrE,CAAC;QACF,MAAM,aAAa,GAAG,2BAA2B,CAC7C,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAClC,CAAC,CACa,CAAC;QAEnB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,OAAO,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAAa,CAAC;SAClE,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,aAAa,EACb,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;YACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAC7B,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,aAAa,CAAC;IACzB,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,KAAK,GAAkB,IAAI,CAAC,iBAAiB,EAAE,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import backpackData from "../../data/backpack.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type BackpackKey = keyof typeof backpackData;
|
|
6
|
+
type BackpackData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
stackLimit: number;
|
|
9
|
+
required: Record<string, TRequired>;
|
|
10
|
+
};
|
|
11
|
+
type BackpackResolvedData = BackpackData<RequirementEntry>;
|
|
12
|
+
type BackpacksByVersion = MultiVersion<BackpackKey, Backpack>;
|
|
13
|
+
export declare class Backpack {
|
|
14
|
+
id: string;
|
|
15
|
+
rarity: Rarity;
|
|
16
|
+
stackLimit: number;
|
|
17
|
+
required: Record<string, RequirementEntry>;
|
|
18
|
+
constructor(id: string, data: BackpackResolvedData);
|
|
19
|
+
static loadBackpacksByVersion(): BackpacksByVersion;
|
|
20
|
+
}
|
|
21
|
+
export declare const Backpacks: BackpacksByVersion;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=backpack.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backpack.d.ts","sourceRoot":"","sources":["../../src/daos/backpack.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,WAAW,GAAG,MAAM,OAAO,YAAY,CAAC;AAC7C,KAAK,YAAY,CAAC,SAAS,GAAG,MAAM,IAAI;IACpC,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACvC,CAAC;AAGF,KAAK,oBAAoB,GAAG,YAAY,CAAC,gBAAgB,CAAC,CAAC;AAC3D,KAAK,kBAAkB,GAAG,YAAY,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;AAE9D,qBAAa,QAAQ;IACV,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEtC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,oBAAoB;IAOlD,MAAM,CAAC,sBAAsB,IAAI,kBAAkB;CA6BtD;AAED,eAAO,MAAM,SAAS,EAAE,kBAAsD,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import backpackData from "../../data/backpack.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Backpack {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.stackLimit = data.stackLimit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
}
|
|
11
|
+
static loadBackpacksByVersion() {
|
|
12
|
+
const rawByVersion = createVersionedRawStore(backpackData);
|
|
13
|
+
const backpacksByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
14
|
+
const { required: _required, ...baseData } = data;
|
|
15
|
+
return new Backpack(id, { ...baseData, required: {} });
|
|
16
|
+
});
|
|
17
|
+
RequirementUtils.registerLookupContext({
|
|
18
|
+
getBackpack: (id, version) => backpacksByVersion[version][id],
|
|
19
|
+
});
|
|
20
|
+
resolveVersionedRequirements(rawByVersion, backpacksByVersion, (data) => data.required, (backpack, required) => {
|
|
21
|
+
backpack.required = required ?? {};
|
|
22
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
23
|
+
return backpacksByVersion;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const Backpacks = Backpack.loadBackpacksByVersion();
|
|
27
|
+
//# sourceMappingURL=backpack.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"backpack.js","sourceRoot":"","sources":["../../src/daos/backpack.ts"],"names":[],"mappings":"AAAA,OAAO,YAAY,MAAM,0BAA0B,CAAC;AAGpD,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAapE,MAAM,OAAO,QAAQ;IAMjB,YAAY,EAAU,EAAE,IAA0B;QAC9C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,sBAAsB;QACzB,MAAM,YAAY,GAAG,uBAAuB,CACxC,YAA8E,CACjF,CAAC;QACF,MAAM,kBAAkB,GAAG,2BAA2B,CAClD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,QAAQ,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAC3D,CAAC,CACkB,CAAC;QAExB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,WAAW,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,EAAiB,CAAC;SAC/E,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,kBAAkB,EAClB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE;YACnB,QAAQ,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QACvC,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,kBAAkB,CAAC;IAC9B,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,SAAS,GAAuB,QAAQ,CAAC,sBAAsB,EAAE,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import buildingElementData from "../../data/buildingElement.json";
|
|
2
|
+
import { BEType, MountingRestriction, WorkingRestriction } from "../types/BuildingElement";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type BuildingElementKey = keyof typeof buildingElementData;
|
|
6
|
+
type BuildingElementData<TRequired = number> = {
|
|
7
|
+
type: BEType;
|
|
8
|
+
limit?: number;
|
|
9
|
+
required: Record<string, TRequired>;
|
|
10
|
+
revivalPoint?: boolean;
|
|
11
|
+
requiresBonfire?: boolean;
|
|
12
|
+
requiresShoreline?: boolean;
|
|
13
|
+
workingRestriction?: WorkingRestriction;
|
|
14
|
+
mountingRestriction?: MountingRestriction;
|
|
15
|
+
capacity?: number;
|
|
16
|
+
comfort?: number;
|
|
17
|
+
};
|
|
18
|
+
type BuildingElementResolvedData = BuildingElementData<RequirementEntry>;
|
|
19
|
+
type BuildingElementsByVersion = MultiVersion<BuildingElementKey, BuildingElement>;
|
|
20
|
+
export declare class BuildingElement {
|
|
21
|
+
id: string;
|
|
22
|
+
type: BEType;
|
|
23
|
+
limit?: number;
|
|
24
|
+
required: Record<string, RequirementEntry>;
|
|
25
|
+
revivalPoint?: boolean;
|
|
26
|
+
requiresBonfire?: boolean;
|
|
27
|
+
requiresShoreline?: boolean;
|
|
28
|
+
workingRestriction?: WorkingRestriction;
|
|
29
|
+
mountingRestriction?: MountingRestriction;
|
|
30
|
+
capacity?: number;
|
|
31
|
+
comfort?: number;
|
|
32
|
+
constructor(id: string, data: BuildingElementResolvedData);
|
|
33
|
+
static loadBuildingElementsByVersion(): BuildingElementsByVersion;
|
|
34
|
+
}
|
|
35
|
+
export declare const BuildingElements: BuildingElementsByVersion;
|
|
36
|
+
export {};
|
|
37
|
+
//# sourceMappingURL=buildingElement.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildingElement.d.ts","sourceRoot":"","sources":["../../src/daos/buildingElement.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC3F,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,kBAAkB,GAAG,MAAM,OAAO,mBAAmB,CAAC;AAC3D,KAAK,mBAAmB,CAAC,SAAS,GAAG,MAAM,IAAI;IAC3C,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IACpC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IACxC,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAGF,KAAK,2BAA2B,GAAG,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;AACzE,KAAK,yBAAyB,GAAG,YAAY,CAAC,kBAAkB,EAAE,eAAe,CAAC,CAAC;AAEnF,qBAAa,eAAe;IACjB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;IAC3C,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,kBAAkB,CAAC,EAAE,kBAAkB,CAAC;IACxC,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;gBAEZ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,2BAA2B;IAczD,MAAM,CAAC,6BAA6B,IAAI,yBAAyB;CA6BpE;AAED,eAAO,MAAM,gBAAgB,EAAE,yBAA2E,CAAC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import buildingElementData from "../../data/buildingElement.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class BuildingElement {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.type = data.type;
|
|
8
|
+
this.limit = data.limit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
this.revivalPoint = data.revivalPoint ?? false;
|
|
11
|
+
this.requiresBonfire = data.requiresBonfire ?? false;
|
|
12
|
+
this.requiresShoreline = data.requiresShoreline ?? false;
|
|
13
|
+
this.workingRestriction = data.workingRestriction ?? "none";
|
|
14
|
+
this.mountingRestriction = data.mountingRestriction ?? "none";
|
|
15
|
+
this.capacity = data.capacity;
|
|
16
|
+
this.comfort = data.comfort;
|
|
17
|
+
}
|
|
18
|
+
static loadBuildingElementsByVersion() {
|
|
19
|
+
const rawByVersion = createVersionedRawStore(buildingElementData);
|
|
20
|
+
const buildingElementsByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
21
|
+
const { required: _required, ...baseData } = data;
|
|
22
|
+
return new BuildingElement(id, { ...baseData, required: {} });
|
|
23
|
+
});
|
|
24
|
+
RequirementUtils.registerLookupContext({
|
|
25
|
+
getBuildingElement: (id, version) => buildingElementsByVersion[version][id],
|
|
26
|
+
});
|
|
27
|
+
resolveVersionedRequirements(rawByVersion, buildingElementsByVersion, (data) => data.required, (buildingElement, required) => {
|
|
28
|
+
buildingElement.required = required ?? {};
|
|
29
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
30
|
+
return buildingElementsByVersion;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
export const BuildingElements = BuildingElement.loadBuildingElementsByVersion();
|
|
34
|
+
//# sourceMappingURL=buildingElement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"buildingElement.js","sourceRoot":"","sources":["../../src/daos/buildingElement.ts"],"names":[],"mappings":"AAAA,OAAO,mBAAmB,MAAM,iCAAiC,CAAC;AAGlE,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAoBpE,MAAM,OAAO,eAAe;IAaxB,YAAY,EAAU,EAAE,IAAiC;QACrD,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC;QAC/C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,IAAI,KAAK,CAAC;QACrD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,IAAI,KAAK,CAAC;QACzD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,IAAI,MAAM,CAAC;QAC5D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,mBAAmB,IAAI,MAAM,CAAC;QAC9D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;IAChC,CAAC;IAED,MAAM,CAAC,6BAA6B;QAChC,MAAM,YAAY,GAAG,uBAAuB,CACxC,mBAAmG,CACtG,CAAC;QACF,MAAM,yBAAyB,GAAG,2BAA2B,CACzD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,eAAe,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAClE,CAAC,CACyB,CAAC;QAE/B,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,kBAAkB,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC,EAAwB,CAAC;SACpG,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,yBAAyB,EACzB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,eAAe,EAAE,QAAQ,EAAE,EAAE;YAC1B,eAAe,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QAC9C,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,yBAAyB,CAAC;IACrC,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,gBAAgB,GAA8B,eAAe,CAAC,6BAA6B,EAAE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import cannonData from "../../data/cannon.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type CannonKey = keyof typeof cannonData;
|
|
6
|
+
type CannonData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
required: Record<string, TRequired>;
|
|
9
|
+
};
|
|
10
|
+
type CannonResolvedData = CannonData<RequirementEntry>;
|
|
11
|
+
type CannonsByVersion = MultiVersion<CannonKey, Cannon>;
|
|
12
|
+
export declare class Cannon {
|
|
13
|
+
id: string;
|
|
14
|
+
rarity: Rarity;
|
|
15
|
+
required: Record<string, RequirementEntry>;
|
|
16
|
+
constructor(id: string, data: CannonResolvedData);
|
|
17
|
+
static loadCannonsByVersion(): CannonsByVersion;
|
|
18
|
+
}
|
|
19
|
+
export declare const Cannons: CannonsByVersion;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=cannon.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cannon.d.ts","sourceRoot":"","sources":["../../src/daos/cannon.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,SAAS,GAAG,MAAM,OAAO,UAAU,CAAC;AACzC,KAAK,UAAU,CAAC,SAAS,GAAG,MAAM,IAAI;IAClC,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACvC,CAAC;AAGF,KAAK,kBAAkB,GAAG,UAAU,CAAC,gBAAgB,CAAC,CAAC;AACvD,KAAK,gBAAgB,GAAG,YAAY,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;AAExD,qBAAa,MAAM;IACR,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEtC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,kBAAkB;IAMhD,MAAM,CAAC,oBAAoB,IAAI,gBAAgB;CA6BlD;AAED,eAAO,MAAM,OAAO,EAAE,gBAAgD,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import cannonData from "../../data/cannon.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Cannon {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.required = data.required;
|
|
9
|
+
}
|
|
10
|
+
static loadCannonsByVersion() {
|
|
11
|
+
const rawByVersion = createVersionedRawStore(cannonData);
|
|
12
|
+
const cannonsByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
13
|
+
const { required: _required, ...baseData } = data;
|
|
14
|
+
return new Cannon(id, { ...baseData, required: {} });
|
|
15
|
+
});
|
|
16
|
+
RequirementUtils.registerLookupContext({
|
|
17
|
+
getCannon: (id, version) => cannonsByVersion[version][id],
|
|
18
|
+
});
|
|
19
|
+
resolveVersionedRequirements(rawByVersion, cannonsByVersion, (data) => data.required, (cannon, required) => {
|
|
20
|
+
cannon.required = required ?? {};
|
|
21
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
22
|
+
return cannonsByVersion;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export const Cannons = Cannon.loadCannonsByVersion();
|
|
26
|
+
//# sourceMappingURL=cannon.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cannon.js","sourceRoot":"","sources":["../../src/daos/cannon.ts"],"names":[],"mappings":"AAAA,OAAO,UAAU,MAAM,wBAAwB,CAAC;AAGhD,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAYpE,MAAM,OAAO,MAAM;IAKf,YAAY,EAAU,EAAE,IAAwB;QAC5C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,oBAAoB;QACvB,MAAM,YAAY,GAAG,uBAAuB,CACxC,UAAwE,CAC3E,CAAC;QACF,MAAM,gBAAgB,GAAG,2BAA2B,CAChD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,MAAM,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QACzD,CAAC,CACgB,CAAC;QAEtB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,SAAS,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,EAAe,CAAC;SACzE,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,gBAAgB,EAChB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,MAAM,EAAE,QAAQ,EAAE,EAAE;YACjB,MAAM,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QACrC,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,gBAAgB,CAAC;IAC5B,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,OAAO,GAAqB,MAAM,CAAC,oBAAoB,EAAE,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import crewEquipmentData from "../../data/crewEquipment.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type CrewEquipmentKey = keyof typeof crewEquipmentData;
|
|
6
|
+
type CrewEquipmentData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
required: Record<string, TRequired>;
|
|
9
|
+
};
|
|
10
|
+
type CrewEquipmentResolvedData = CrewEquipmentData<RequirementEntry>;
|
|
11
|
+
type CrewEquipmentsByVersion = MultiVersion<CrewEquipmentKey, CrewEquipment>;
|
|
12
|
+
export declare class CrewEquipment {
|
|
13
|
+
id: string;
|
|
14
|
+
rarity: Rarity;
|
|
15
|
+
required: Record<string, RequirementEntry>;
|
|
16
|
+
constructor(id: string, data: CrewEquipmentResolvedData);
|
|
17
|
+
static loadCrewEquipmentByVersion(): CrewEquipmentsByVersion;
|
|
18
|
+
}
|
|
19
|
+
export declare const CrewEquipments: CrewEquipmentsByVersion;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=crewEquipment.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crewEquipment.d.ts","sourceRoot":"","sources":["../../src/daos/crewEquipment.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,+BAA+B,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,gBAAgB,GAAG,MAAM,OAAO,iBAAiB,CAAC;AACvD,KAAK,iBAAiB,CAAC,SAAS,GAAG,MAAM,IAAI;IACzC,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACvC,CAAC;AAGF,KAAK,yBAAyB,GAAG,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;AACrE,KAAK,uBAAuB,GAAG,YAAY,CAAC,gBAAgB,EAAE,aAAa,CAAC,CAAC;AAE7E,qBAAa,aAAa;IACf,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEtC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,yBAAyB;IAMvD,MAAM,CAAC,0BAA0B,IAAI,uBAAuB;CA6B/D;AAED,eAAO,MAAM,cAAc,EAAE,uBAAoE,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import crewEquipmentData from "../../data/crewEquipment.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class CrewEquipment {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.required = data.required;
|
|
9
|
+
}
|
|
10
|
+
static loadCrewEquipmentByVersion() {
|
|
11
|
+
const rawByVersion = createVersionedRawStore(crewEquipmentData);
|
|
12
|
+
const crewEquipmentByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
13
|
+
const { required: _required, ...baseData } = data;
|
|
14
|
+
return new CrewEquipment(id, { ...baseData, required: {} });
|
|
15
|
+
});
|
|
16
|
+
RequirementUtils.registerLookupContext({
|
|
17
|
+
getCrewEquipment: (id, version) => crewEquipmentByVersion[version][id],
|
|
18
|
+
});
|
|
19
|
+
resolveVersionedRequirements(rawByVersion, crewEquipmentByVersion, (data) => data.required, (crewEquipment, required) => {
|
|
20
|
+
crewEquipment.required = required ?? {};
|
|
21
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
22
|
+
return crewEquipmentByVersion;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export const CrewEquipments = CrewEquipment.loadCrewEquipmentByVersion();
|
|
26
|
+
//# sourceMappingURL=crewEquipment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crewEquipment.js","sourceRoot":"","sources":["../../src/daos/crewEquipment.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,+BAA+B,CAAC;AAG9D,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAYpE,MAAM,OAAO,aAAa;IAKtB,YAAY,EAAU,EAAE,IAA+B;QACnD,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,0BAA0B;QAC7B,MAAM,YAAY,GAAG,uBAAuB,CACxC,iBAA6F,CAChG,CAAC;QACF,MAAM,sBAAsB,GAAG,2BAA2B,CACtD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,aAAa,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAChE,CAAC,CACuB,CAAC;QAE7B,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,gBAAgB,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC,EAAsB,CAAC;SAC7F,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,sBAAsB,EACtB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,aAAa,EAAE,QAAQ,EAAE,EAAE;YACxB,aAAa,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QAC5C,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,sBAAsB,CAAC;IAClC,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,cAAc,GAA4B,aAAa,CAAC,0BAA0B,EAAE,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import foodData from "../../data/food.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type FoodKey = keyof typeof foodData;
|
|
6
|
+
type FoodData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
stackLimit: number;
|
|
9
|
+
required?: Record<string, TRequired>;
|
|
10
|
+
};
|
|
11
|
+
type FoodResolvedData = FoodData<RequirementEntry>;
|
|
12
|
+
type FoodItemsByVersion = MultiVersion<FoodKey, Food>;
|
|
13
|
+
export declare class Food {
|
|
14
|
+
id: string;
|
|
15
|
+
rarity: Rarity;
|
|
16
|
+
stackLimit: number;
|
|
17
|
+
required?: Record<string, RequirementEntry>;
|
|
18
|
+
constructor(id: string, data: FoodResolvedData);
|
|
19
|
+
static loadFoodItemsByVersion(): FoodItemsByVersion;
|
|
20
|
+
}
|
|
21
|
+
export declare const Foods: FoodItemsByVersion;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=food.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"food.d.ts","sourceRoot":"","sources":["../../src/daos/food.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,OAAO,GAAG,MAAM,OAAO,QAAQ,CAAC;AACrC,KAAK,QAAQ,CAAC,SAAS,GAAG,MAAM,IAAI;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACxC,CAAC;AAGF,KAAK,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC;AACnD,KAAK,kBAAkB,GAAG,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAEtD,qBAAa,IAAI;IACN,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEvC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,gBAAgB;IAO9C,MAAM,CAAC,sBAAsB,IAAI,kBAAkB;CA6BtD;AAED,eAAO,MAAM,KAAK,EAAE,kBAAkD,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import foodData from "../../data/food.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Food {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.stackLimit = data.stackLimit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
}
|
|
11
|
+
static loadFoodItemsByVersion() {
|
|
12
|
+
const rawByVersion = createVersionedRawStore(foodData);
|
|
13
|
+
const foodItemsByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
14
|
+
const { required: _required, ...baseData } = data;
|
|
15
|
+
return new Food(id, baseData);
|
|
16
|
+
});
|
|
17
|
+
RequirementUtils.registerLookupContext({
|
|
18
|
+
getFood: (id, version) => foodItemsByVersion[version][id],
|
|
19
|
+
});
|
|
20
|
+
resolveVersionedRequirements(rawByVersion, foodItemsByVersion, (data) => data.required, (foodItem, required) => {
|
|
21
|
+
foodItem.required = required;
|
|
22
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
23
|
+
return foodItemsByVersion;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const Foods = Food.loadFoodItemsByVersion();
|
|
27
|
+
//# sourceMappingURL=food.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"food.js","sourceRoot":"","sources":["../../src/daos/food.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAG5C,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAapE,MAAM,OAAO,IAAI;IAMb,YAAY,EAAU,EAAE,IAAsB;QAC1C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,sBAAsB;QACzB,MAAM,YAAY,GAAG,uBAAuB,CACxC,QAAkE,CACrE,CAAC;QACF,MAAM,kBAAkB,GAAG,2BAA2B,CAClD,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAClC,CAAC,CACkB,CAAC;QAExB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,OAAO,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,EAAa,CAAC;SACvE,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,kBAAkB,EAClB,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,QAAQ,EAAE,QAAQ,EAAE,EAAE;YACnB,QAAQ,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACjC,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,kBAAkB,CAAC;IAC9B,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,KAAK,GAAuB,IAAI,CAAC,sBAAsB,EAAE,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { MultiVersion, Version } from "../versions";
|
|
2
|
+
import { RequirementEntry, RequirementResolver } from "./requirements";
|
|
3
|
+
type RawPayload<K extends string, TRaw> = {
|
|
4
|
+
id: K;
|
|
5
|
+
data: TRaw;
|
|
6
|
+
};
|
|
7
|
+
export declare function createVersionedRawStore<K extends string, TRaw>(dataByKey: Record<K, Partial<Record<Version, TRaw>>>): MultiVersion<K, RawPayload<K, TRaw>>;
|
|
8
|
+
export declare function instantiateVersionedEntries<K extends string, TRaw, TEntity>(rawByVersion: MultiVersion<K, RawPayload<K, TRaw>>, createEntry: (id: K, data: TRaw, version: Version) => TEntity): MultiVersion<K, TEntity>;
|
|
9
|
+
export declare function resolveVersionedRequirements<K extends string, TRaw, TEntity>(rawByVersion: MultiVersion<K, RawPayload<K, TRaw>>, entriesByVersion: MultiVersion<K, TEntity>, getRequired: (data: TRaw) => Record<string, number> | undefined, setRequired: (entity: TEntity, required: Record<string, RequirementEntry> | undefined) => void, resolvers: RequirementResolver[]): void;
|
|
10
|
+
export {};
|
|
11
|
+
//# sourceMappingURL=helpers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/daos/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,OAAO,EAAqB,MAAM,aAAa,CAAC;AACvE,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAoB,MAAM,gBAAgB,CAAC;AAEzF,KAAK,UAAU,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,IAAI;IACtC,EAAE,EAAE,CAAC,CAAC;IACN,IAAI,EAAE,IAAI,CAAC;CACd,CAAC;AAEF,wBAAgB,uBAAuB,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAC1D,SAAS,EAAE,MAAM,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,GACrD,YAAY,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAQtC;AAED,wBAAgB,2BAA2B,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,OAAO,EACvE,YAAY,EAAE,YAAY,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAClD,WAAW,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,KAAK,OAAO,GAC9D,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,CAc1B;AAED,wBAAgB,4BAA4B,CAAC,CAAC,SAAS,MAAM,EAAE,IAAI,EAAE,OAAO,EACxE,YAAY,EAAE,YAAY,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,EAClD,gBAAgB,EAAE,YAAY,CAAC,CAAC,EAAE,OAAO,CAAC,EAC1C,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,EAC/D,WAAW,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,GAAG,SAAS,KAAK,IAAI,EAC9F,SAAS,EAAE,mBAAmB,EAAE,GACjC,IAAI,CAiBN"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { loadVersionedData } from "../versions";
|
|
2
|
+
import { RequirementUtils } from "./requirements";
|
|
3
|
+
export function createVersionedRawStore(dataByKey) {
|
|
4
|
+
return loadVersionedData(dataByKey, (id, data) => ({
|
|
5
|
+
id,
|
|
6
|
+
data: { ...data },
|
|
7
|
+
}));
|
|
8
|
+
}
|
|
9
|
+
export function instantiateVersionedEntries(rawByVersion, createEntry) {
|
|
10
|
+
const entriesByVersion = {};
|
|
11
|
+
for (const version of Object.keys(rawByVersion)) {
|
|
12
|
+
const versionEntries = {};
|
|
13
|
+
for (const [id, payload] of Object.entries(rawByVersion[version])) {
|
|
14
|
+
versionEntries[id] = createEntry(id, payload.data, version);
|
|
15
|
+
}
|
|
16
|
+
entriesByVersion[version] = versionEntries;
|
|
17
|
+
}
|
|
18
|
+
return entriesByVersion;
|
|
19
|
+
}
|
|
20
|
+
export function resolveVersionedRequirements(rawByVersion, entriesByVersion, getRequired, setRequired, resolvers) {
|
|
21
|
+
for (const version of Object.keys(rawByVersion)) {
|
|
22
|
+
for (const [id, payload] of Object.entries(rawByVersion[version])) {
|
|
23
|
+
const entity = entriesByVersion[version][id];
|
|
24
|
+
if (!entity) {
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
const required = getRequired(payload.data);
|
|
28
|
+
setRequired(entity, required
|
|
29
|
+
? RequirementUtils.resolveRequiredEntries(required, version, resolvers)
|
|
30
|
+
: undefined);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/daos/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACvE,OAAO,EAAyC,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAOzF,MAAM,UAAU,uBAAuB,CACnC,SAAoD;IAEpD,OAAO,iBAAiB,CACpB,SAAS,EACT,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC;QACX,EAAE;QACF,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE;KACpB,CAAC,CACmC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,2BAA2B,CACvC,YAAkD,EAClD,WAA6D;IAE7D,MAAM,gBAAgB,GAAG,EAA8B,CAAC;IAExD,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAc,EAAE,CAAC;QAC3D,MAAM,cAAc,GAAG,EAAiC,CAAC;QAEzD,KAAK,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAoC,EAAE,CAAC;YACnG,cAAc,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,EAAE,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAChE,CAAC;QAED,gBAAgB,CAAC,OAAO,CAAC,GAAG,cAAc,CAAC;IAC/C,CAAC;IAED,OAAO,gBAAgB,CAAC;AAC5B,CAAC;AAED,MAAM,UAAU,4BAA4B,CACxC,YAAkD,EAClD,gBAA0C,EAC1C,WAA+D,EAC/D,WAA8F,EAC9F,SAAgC;IAEhC,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,YAAY,CAAc,EAAE,CAAC;QAC3D,KAAK,MAAM,CAAC,EAAE,EAAE,OAAO,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,CAAoC,EAAE,CAAC;YACnG,MAAM,MAAM,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,CAAC;YAC7C,IAAI,CAAC,MAAM,EAAE,CAAC;gBACV,SAAS;YACb,CAAC;YAED,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YAC3C,WAAW,CACP,MAAM,EACN,QAAQ;gBACJ,CAAC,CAAC,gBAAgB,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,EAAE,SAAS,CAAC;gBACvE,CAAC,CAAC,SAAS,CAClB,CAAC;QACN,CAAC;IACL,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import hullModificationData from "../../data/hullModification.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type HullModificationKey = keyof typeof hullModificationData;
|
|
6
|
+
type HullModificationData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
required: Record<string, TRequired>;
|
|
9
|
+
};
|
|
10
|
+
type HullModificationResolvedData = HullModificationData<RequirementEntry>;
|
|
11
|
+
type HullModificationsByVersion = MultiVersion<HullModificationKey, HullModification>;
|
|
12
|
+
export declare class HullModification {
|
|
13
|
+
id: string;
|
|
14
|
+
rarity: Rarity;
|
|
15
|
+
required: Record<string, RequirementEntry>;
|
|
16
|
+
constructor(id: string, data: HullModificationResolvedData);
|
|
17
|
+
static loadHullModificationsByVersion(): HullModificationsByVersion;
|
|
18
|
+
}
|
|
19
|
+
export declare const HullModifications: HullModificationsByVersion;
|
|
20
|
+
export {};
|
|
21
|
+
//# sourceMappingURL=hullModification.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hullModification.d.ts","sourceRoot":"","sources":["../../src/daos/hullModification.ts"],"names":[],"mappings":"AAAA,OAAO,oBAAoB,MAAM,kCAAkC,CAAC;AACpE,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,mBAAmB,GAAG,MAAM,OAAO,oBAAoB,CAAC;AAC7D,KAAK,oBAAoB,CAAC,SAAS,GAAG,MAAM,IAAI;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACvC,CAAC;AAGF,KAAK,4BAA4B,GAAG,oBAAoB,CAAC,gBAAgB,CAAC,CAAC;AAC3E,KAAK,0BAA0B,GAAG,YAAY,CAAC,mBAAmB,EAAE,gBAAgB,CAAC,CAAC;AAEtF,qBAAa,gBAAgB;IAClB,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEtC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,4BAA4B;IAM1D,MAAM,CAAC,8BAA8B,IAAI,0BAA0B;CA6BtE;AAED,eAAO,MAAM,iBAAiB,EAAE,0BAA8E,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import hullModificationData from "../../data/hullModification.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class HullModification {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.required = data.required;
|
|
9
|
+
}
|
|
10
|
+
static loadHullModificationsByVersion() {
|
|
11
|
+
const rawByVersion = createVersionedRawStore(hullModificationData);
|
|
12
|
+
const hullModificationsByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
13
|
+
const { required: _required, ...baseData } = data;
|
|
14
|
+
return new HullModification(id, { ...baseData, required: {} });
|
|
15
|
+
});
|
|
16
|
+
RequirementUtils.registerLookupContext({
|
|
17
|
+
getHullModification: (id, version) => hullModificationsByVersion[version][id],
|
|
18
|
+
});
|
|
19
|
+
resolveVersionedRequirements(rawByVersion, hullModificationsByVersion, (data) => data.required, (hullModification, required) => {
|
|
20
|
+
hullModification.required = required ?? {};
|
|
21
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
22
|
+
return hullModificationsByVersion;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
export const HullModifications = HullModification.loadHullModificationsByVersion();
|
|
26
|
+
//# sourceMappingURL=hullModification.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hullModification.js","sourceRoot":"","sources":["../../src/daos/hullModification.ts"],"names":[],"mappings":"AAAA,OAAO,oBAAoB,MAAM,kCAAkC,CAAC;AAGpE,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAYpE,MAAM,OAAO,gBAAgB;IAKzB,YAAY,EAAU,EAAE,IAAkC;QACtD,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,8BAA8B;QACjC,MAAM,YAAY,GAAG,uBAAuB,CACxC,oBAAsG,CACzG,CAAC;QACF,MAAM,0BAA0B,GAAG,2BAA2B,CAC1D,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,gBAAgB,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QACnE,CAAC,CAC0B,CAAC;QAEhC,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,mBAAmB,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,0BAA0B,CAAC,OAAO,CAAC,CAAC,EAAyB,CAAC;SACvG,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,0BAA0B,EAC1B,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,gBAAgB,EAAE,QAAQ,EAAE,EAAE;YAC3B,gBAAgB,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QAC/C,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,0BAA0B,CAAC;IACtC,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,iBAAiB,GAA+B,gBAAgB,CAAC,8BAA8B,EAAE,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import itemData from "../../data/item.json";
|
|
2
|
+
import { Rarity } from "../types/Rarity";
|
|
3
|
+
import { MultiVersion } from "../versions";
|
|
4
|
+
import { RequirementEntry } from "./requirements";
|
|
5
|
+
type ItemKey = keyof typeof itemData;
|
|
6
|
+
type ItemData<TRequired = number> = {
|
|
7
|
+
rarity: Rarity;
|
|
8
|
+
stackLimit: number;
|
|
9
|
+
required: Record<string, TRequired>;
|
|
10
|
+
};
|
|
11
|
+
type ItemResolvedData = ItemData<RequirementEntry>;
|
|
12
|
+
type ItemsByVersion = MultiVersion<ItemKey, Item>;
|
|
13
|
+
export declare class Item {
|
|
14
|
+
id: string;
|
|
15
|
+
rarity: Rarity;
|
|
16
|
+
stackLimit: number;
|
|
17
|
+
required: Record<string, RequirementEntry>;
|
|
18
|
+
constructor(id: string, data: ItemResolvedData);
|
|
19
|
+
static loadItemsByVersion(): ItemsByVersion;
|
|
20
|
+
}
|
|
21
|
+
export declare const Items: ItemsByVersion;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=item.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"item.d.ts","sourceRoot":"","sources":["../../src/daos/item.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAC5C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAW,MAAM,aAAa,CAAC;AAEpD,OAAO,EAAE,gBAAgB,EAAoB,MAAM,gBAAgB,CAAC;AAEpE,KAAK,OAAO,GAAG,MAAM,OAAO,QAAQ,CAAC;AACrC,KAAK,QAAQ,CAAC,SAAS,GAAG,MAAM,IAAI;IAChC,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;CACvC,CAAC;AAGF,KAAK,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC,CAAC;AACnD,KAAK,cAAc,GAAG,YAAY,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;AAElD,qBAAa,IAAI;IACN,EAAE,EAAE,MAAM,CAAC;IACX,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;gBAEtC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,gBAAgB;IAO9C,MAAM,CAAC,kBAAkB,IAAI,cAAc;CA6B9C;AAED,eAAO,MAAM,KAAK,EAAE,cAA0C,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import itemData from "../../data/item.json";
|
|
2
|
+
import { createVersionedRawStore, instantiateVersionedEntries, resolveVersionedRequirements } from "./helpers";
|
|
3
|
+
import { RequirementUtils } from "./requirements";
|
|
4
|
+
export class Item {
|
|
5
|
+
constructor(id, data) {
|
|
6
|
+
this.id = id;
|
|
7
|
+
this.rarity = data.rarity;
|
|
8
|
+
this.stackLimit = data.stackLimit;
|
|
9
|
+
this.required = data.required;
|
|
10
|
+
}
|
|
11
|
+
static loadItemsByVersion() {
|
|
12
|
+
const rawByVersion = createVersionedRawStore(itemData);
|
|
13
|
+
const itemsByVersion = instantiateVersionedEntries(rawByVersion, (id, data) => {
|
|
14
|
+
const { required: _required, ...baseData } = data;
|
|
15
|
+
return new Item(id, { ...baseData, required: {} });
|
|
16
|
+
});
|
|
17
|
+
RequirementUtils.registerLookupContext({
|
|
18
|
+
getItem: (id, version) => itemsByVersion[version][id],
|
|
19
|
+
});
|
|
20
|
+
resolveVersionedRequirements(rawByVersion, itemsByVersion, (data) => data.required, (item, required) => {
|
|
21
|
+
item.required = required ?? {};
|
|
22
|
+
}, RequirementUtils.createDefaultRequirementResolvers());
|
|
23
|
+
return itemsByVersion;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export const Items = Item.loadItemsByVersion();
|
|
27
|
+
//# sourceMappingURL=item.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"item.js","sourceRoot":"","sources":["../../src/daos/item.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,sBAAsB,CAAC;AAG5C,OAAO,EAAE,uBAAuB,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,WAAW,CAAC;AAC/G,OAAO,EAAoB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAapE,MAAM,OAAO,IAAI;IAMb,YAAY,EAAU,EAAE,IAAsB;QAC1C,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAClC,CAAC;IAED,MAAM,CAAC,kBAAkB;QACrB,MAAM,YAAY,GAAG,uBAAuB,CACxC,QAAkE,CACrE,CAAC;QACF,MAAM,cAAc,GAAG,2BAA2B,CAC9C,YAAY,EACZ,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE;YACT,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;YAElD,OAAO,IAAI,IAAI,CAAC,EAAE,EAAE,EAAE,GAAG,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QACvD,CAAC,CACc,CAAC;QAEpB,gBAAgB,CAAC,qBAAqB,CAAC;YACnC,OAAO,EAAE,CAAC,EAAE,EAAE,OAAO,EAAE,EAAE,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,EAAa,CAAC;SACnE,CAAC,CAAC;QAEH,4BAA4B,CACxB,YAAY,EACZ,cAAc,EACd,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EACvB,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE;YACf,IAAI,CAAC,QAAQ,GAAG,QAAQ,IAAI,EAAE,CAAC;QACnC,CAAC,EACD,gBAAgB,CAAC,iCAAiC,EAAE,CACvD,CAAC;QAEF,OAAO,cAAc,CAAC;IAC1B,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,KAAK,GAAmB,IAAI,CAAC,kBAAkB,EAAE,CAAC"}
|