@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.
Files changed (139) hide show
  1. package/LICENSE +661 -0
  2. package/README.md +120 -0
  3. package/data/alchemy.json +31 -0
  4. package/data/ammo.json +32 -0
  5. package/data/backpack.json +23 -0
  6. package/data/buildingElement.json +1757 -0
  7. package/data/cannon.json +11 -0
  8. package/data/crewEquipment.json +12 -0
  9. package/data/food.json +127 -0
  10. package/data/hullModification.json +12 -0
  11. package/data/item.json +44 -0
  12. package/data/medicine.json +30 -0
  13. package/data/metal.json +12 -0
  14. package/data/miscellaneous.json +100 -0
  15. package/data/resource.json +243 -0
  16. package/data/tool.json +52 -0
  17. package/dist/daos/alchemy.d.ts +23 -0
  18. package/dist/daos/alchemy.d.ts.map +1 -0
  19. package/dist/daos/alchemy.js +27 -0
  20. package/dist/daos/alchemy.js.map +1 -0
  21. package/dist/daos/ammo.d.ts +23 -0
  22. package/dist/daos/ammo.d.ts.map +1 -0
  23. package/dist/daos/ammo.js +27 -0
  24. package/dist/daos/ammo.js.map +1 -0
  25. package/dist/daos/backpack.d.ts +23 -0
  26. package/dist/daos/backpack.d.ts.map +1 -0
  27. package/dist/daos/backpack.js +27 -0
  28. package/dist/daos/backpack.js.map +1 -0
  29. package/dist/daos/buildingElement.d.ts +37 -0
  30. package/dist/daos/buildingElement.d.ts.map +1 -0
  31. package/dist/daos/buildingElement.js +34 -0
  32. package/dist/daos/buildingElement.js.map +1 -0
  33. package/dist/daos/cannon.d.ts +21 -0
  34. package/dist/daos/cannon.d.ts.map +1 -0
  35. package/dist/daos/cannon.js +26 -0
  36. package/dist/daos/cannon.js.map +1 -0
  37. package/dist/daos/crewEquipment.d.ts +21 -0
  38. package/dist/daos/crewEquipment.d.ts.map +1 -0
  39. package/dist/daos/crewEquipment.js +26 -0
  40. package/dist/daos/crewEquipment.js.map +1 -0
  41. package/dist/daos/food.d.ts +23 -0
  42. package/dist/daos/food.d.ts.map +1 -0
  43. package/dist/daos/food.js +27 -0
  44. package/dist/daos/food.js.map +1 -0
  45. package/dist/daos/helpers.d.ts +11 -0
  46. package/dist/daos/helpers.d.ts.map +1 -0
  47. package/dist/daos/helpers.js +34 -0
  48. package/dist/daos/helpers.js.map +1 -0
  49. package/dist/daos/hullModification.d.ts +21 -0
  50. package/dist/daos/hullModification.d.ts.map +1 -0
  51. package/dist/daos/hullModification.js +26 -0
  52. package/dist/daos/hullModification.js.map +1 -0
  53. package/dist/daos/item.d.ts +23 -0
  54. package/dist/daos/item.d.ts.map +1 -0
  55. package/dist/daos/item.js +27 -0
  56. package/dist/daos/item.js.map +1 -0
  57. package/dist/daos/medicine.d.ts +23 -0
  58. package/dist/daos/medicine.d.ts.map +1 -0
  59. package/dist/daos/medicine.js +27 -0
  60. package/dist/daos/medicine.js.map +1 -0
  61. package/dist/daos/metal.d.ts +19 -0
  62. package/dist/daos/metal.d.ts.map +1 -0
  63. package/dist/daos/metal.js +20 -0
  64. package/dist/daos/metal.js.map +1 -0
  65. package/dist/daos/metals.d.ts +19 -0
  66. package/dist/daos/metals.d.ts.map +1 -0
  67. package/dist/daos/metals.js +19 -0
  68. package/dist/daos/metals.js.map +1 -0
  69. package/dist/daos/miscellaneous.d.ts +23 -0
  70. package/dist/daos/miscellaneous.d.ts.map +1 -0
  71. package/dist/daos/miscellaneous.js +27 -0
  72. package/dist/daos/miscellaneous.js.map +1 -0
  73. package/dist/daos/requirements.d.ts +48 -0
  74. package/dist/daos/requirements.d.ts.map +1 -0
  75. package/dist/daos/requirements.js +242 -0
  76. package/dist/daos/requirements.js.map +1 -0
  77. package/dist/daos/resource.d.ts +23 -0
  78. package/dist/daos/resource.d.ts.map +1 -0
  79. package/dist/daos/resource.js +30 -0
  80. package/dist/daos/resource.js.map +1 -0
  81. package/dist/daos/resources.d.ts +24 -0
  82. package/dist/daos/resources.d.ts.map +1 -0
  83. package/dist/daos/resources.js +49 -0
  84. package/dist/daos/resources.js.map +1 -0
  85. package/dist/daos/tool.d.ts +23 -0
  86. package/dist/daos/tool.d.ts.map +1 -0
  87. package/dist/daos/tool.js +30 -0
  88. package/dist/daos/tool.js.map +1 -0
  89. package/dist/daos/tools.d.ts +24 -0
  90. package/dist/daos/tools.d.ts.map +1 -0
  91. package/dist/daos/tools.js +23 -0
  92. package/dist/daos/tools.js.map +1 -0
  93. package/dist/daos/validation.d.ts +2 -0
  94. package/dist/daos/validation.d.ts.map +1 -0
  95. package/dist/daos/validation.js +32 -0
  96. package/dist/daos/validation.js.map +1 -0
  97. package/dist/daos/versions.d.ts +18 -0
  98. package/dist/daos/versions.d.ts.map +1 -0
  99. package/dist/daos/versions.js +33 -0
  100. package/dist/daos/versions.js.map +1 -0
  101. package/dist/index.d.ts +25 -0
  102. package/dist/index.d.ts.map +1 -0
  103. package/dist/index.js +24 -0
  104. package/dist/index.js.map +1 -0
  105. package/dist/languages.d.ts +1757 -0
  106. package/dist/languages.d.ts.map +1 -0
  107. package/dist/languages.js +44 -0
  108. package/dist/languages.js.map +1 -0
  109. package/dist/types/BuildingElement.d.ts +7 -0
  110. package/dist/types/BuildingElement.d.ts.map +1 -0
  111. package/dist/types/BuildingElement.js +8 -0
  112. package/dist/types/BuildingElement.js.map +1 -0
  113. package/dist/types/Rarity.d.ts +3 -0
  114. package/dist/types/Rarity.d.ts.map +1 -0
  115. package/dist/types/Rarity.js +4 -0
  116. package/dist/types/Rarity.js.map +1 -0
  117. package/dist/unifiedItems.d.ts +27 -0
  118. package/dist/unifiedItems.d.ts.map +1 -0
  119. package/dist/unifiedItems.js +47 -0
  120. package/dist/unifiedItems.js.map +1 -0
  121. package/dist/versions.d.ts +21 -0
  122. package/dist/versions.d.ts.map +1 -0
  123. package/dist/versions.js +36 -0
  124. package/dist/versions.js.map +1 -0
  125. package/languages/source/alchemy.json +36 -0
  126. package/languages/source/ammo.json +36 -0
  127. package/languages/source/backpack.json +18 -0
  128. package/languages/source/buildingElement.json +1567 -0
  129. package/languages/source/cannon.json +10 -0
  130. package/languages/source/crewEquipment.json +11 -0
  131. package/languages/source/food.json +164 -0
  132. package/languages/source/hullModification.json +10 -0
  133. package/languages/source/item.json +50 -0
  134. package/languages/source/medicine.json +39 -0
  135. package/languages/source/metal.json +11 -0
  136. package/languages/source/miscellaneous.json +147 -0
  137. package/languages/source/resource.json +300 -0
  138. package/languages/source/tool.json +44 -0
  139. 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"}