@firestone-hs/reference-data 1.0.146 → 1.0.147

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.
@@ -1,2 +1,5 @@
1
+ import { GameFormat } from '../public-api';
1
2
  import { AllCardsService } from './all-cards.service';
2
3
  export declare const normalizeDeckList: (decklist: string, allCards: AllCardsService) => string;
4
+ export declare const getBaseCardForDeckbuilding: (dbfId: number, format: GameFormat, allCards: AllCardsService) => number;
5
+ export declare const getBaseCardIdForDeckbuilding: (cardId: string, format: GameFormat, allCards: AllCardsService) => string;
@@ -1,13 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.normalizeDeckList = void 0;
3
+ exports.getBaseCardIdForDeckbuilding = exports.getBaseCardForDeckbuilding = exports.normalizeDeckList = void 0;
4
4
  const deckstrings_1 = require("@firestone-hs/deckstrings");
5
5
  const public_api_1 = require("../public-api");
6
6
  const normalizeDeckList = (decklist, allCards) => {
7
7
  var _a;
8
8
  const decoded = deckstrings_1.decode(decklist);
9
9
  const cards = decoded.cards.map((pair) => [
10
- getBaseCardForDeckbuilding(pair[0], decoded.format, allCards),
10
+ exports.getBaseCardForDeckbuilding(pair[0], decoded.format, allCards),
11
11
  pair[1],
12
12
  ]);
13
13
  const sideboards = (_a = decoded.sideboards) === null || _a === void 0 ? void 0 : _a.map((sideboard) => normalizeSideboard(sideboard, decoded.format, allCards));
@@ -35,6 +35,24 @@ const getBaseCardForDeckbuilding = (dbfId, format, allCards) => {
35
35
  }
36
36
  return dbfId;
37
37
  };
38
+ exports.getBaseCardForDeckbuilding = getBaseCardForDeckbuilding;
39
+ const getBaseCardIdForDeckbuilding = (cardId, format, allCards) => {
40
+ var _a;
41
+ const card = allCards.getCard(cardId);
42
+ if (!card.deckDuplicateDbfId) {
43
+ return cardId;
44
+ }
45
+ const originCard = allCards.getCard(card.deckDuplicateDbfId);
46
+ if (!originCard) {
47
+ return cardId;
48
+ }
49
+ const allowedSets = getAllowedSets(format);
50
+ if (allowedSets.includes((_a = originCard.set) === null || _a === void 0 ? void 0 : _a.toLowerCase())) {
51
+ return originCard.id;
52
+ }
53
+ return cardId;
54
+ };
55
+ exports.getBaseCardIdForDeckbuilding = getBaseCardIdForDeckbuilding;
38
56
  const getAllowedSets = (format) => {
39
57
  switch (format) {
40
58
  case public_api_1.GameFormat.FT_STANDARD:
@@ -50,7 +68,7 @@ const getAllowedSets = (format) => {
50
68
  };
51
69
  const normalizeSideboard = (sideboard, format, allCards) => {
52
70
  const cards = sideboard.cards.map((pair) => [
53
- getBaseCardForDeckbuilding(pair[0], format, allCards),
71
+ exports.getBaseCardForDeckbuilding(pair[0], format, allCards),
54
72
  pair[1],
55
73
  ]);
56
74
  return {
@@ -1 +1 @@
1
- {"version":3,"file":"deck-utils.js","sourceRoot":"","sources":["../../src/services/deck-utils.ts"],"names":[],"mappings":";;;AAAA,2DAAgG;AAChG,8CAA8E;AAGvE,MAAM,iBAAiB,GAAG,CAAC,QAAgB,EAAE,QAAyB,EAAU,EAAE;;IACxF,MAAM,OAAO,GAAmB,oBAAM,CAAC,QAAQ,CAAC,CAAC;IACjD,MAAM,KAAK,GAAa,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;QACnD,0BAA0B,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC;QAC7D,IAAI,CAAC,CAAC,CAAC;KACP,CAAC,CAAC;IACH,MAAM,UAAU,GAAgB,MAAA,OAAO,CAAC,UAAU,0CAAE,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CACrE,kBAAkB,CAAC,SAAS,EAAE,OAAO,CAAC,MAAM,EAAE,QAAQ,CAAC,CACvD,CAAC;IACF,MAAM,OAAO,GAAmB;QAC/B,GAAG,OAAO;QACV,KAAK,EAAE,KAAK;QACZ,UAAU,EAAE,UAAU;KACtB,CAAC;IACF,OAAO,oBAAM,CAAC,OAAO,CAAC,CAAC;AACxB,CAAC,CAAC;AAfW,QAAA,iBAAiB,qBAe5B;AAGF,MAAM,0BAA0B,GAAG,CAAC,KAAa,EAAE,MAAkB,EAAE,QAAyB,EAAU,EAAE;;IAC3G,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE;QAC7B,OAAO,KAAK,CAAC;KACb;IAED,MAAM,UAAU,GAAG,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC7D,IAAI,CAAC,UAAU,EAAE;QAChB,OAAO,KAAK,CAAC;KACb;IAGD,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAC3C,IAAI,WAAW,CAAC,QAAQ,CAAC,MAAA,UAAU,CAAC,GAAG,0CAAE,WAAW,EAAE,CAAC,EAAE;QACxD,OAAO,UAAU,CAAC,KAAK,CAAC;KACxB;IAED,OAAO,KAAK,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,MAAkB,EAAqB,EAAE;IAChE,QAAQ,MAAM,EAAE;QACf,KAAK,uBAAU,CAAC,WAAW;YAC1B,OAAO,yBAAY,CAAC;QACrB,KAAK,uBAAU,CAAC,UAAU;YACzB,OAAO,CAAC,SAAS,CAAC,CAAC;QACpB,KAAK,uBAAU,CAAC,QAAQ;YACvB,OAAO,sBAAS,CAAC;QAClB,KAAK,uBAAU,CAAC,OAAO,CAAC;QACxB;YACC,OAAO,qBAAQ,CAAC;KACjB;AACF,CAAC,CAAC;AAEF,MAAM,kBAAkB,GAAG,CAAC,SAAoB,EAAE,MAAkB,EAAE,QAAyB,EAAa,EAAE;IAC7G,MAAM,KAAK,GAAa,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC;QACrD,0BAA0B,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,CAAC;QACrD,IAAI,CAAC,CAAC,CAAC;KACP,CAAC,CAAC;IACH,OAAO;QACN,GAAG,SAAS;QACZ,KAAK,EAAE,KAAK;KACZ,CAAC;AACH,CAAC,CAAC","sourcesContent":["import { DeckDefinition, DeckList, decode, encode, Sideboard } from '@firestone-hs/deckstrings';\r\nimport { GameFormat, standardSets, twistSets, wildSets } from '../public-api';\r\nimport { AllCardsService } from './all-cards.service';\r\n\r\nexport const normalizeDeckList = (decklist: string, allCards: AllCardsService): string => {\r\n\tconst decoded: DeckDefinition = decode(decklist);\r\n\tconst cards: DeckList = decoded.cards.map((pair) => [\r\n\t\tgetBaseCardForDeckbuilding(pair[0], decoded.format, allCards),\r\n\t\tpair[1],\r\n\t]);\r\n\tconst sideboards: Sideboard[] = decoded.sideboards?.map((sideboard) =>\r\n\t\tnormalizeSideboard(sideboard, decoded.format, allCards),\r\n\t);\r\n\tconst updated: DeckDefinition = {\r\n\t\t...decoded,\r\n\t\tcards: cards,\r\n\t\tsideboards: sideboards,\r\n\t};\r\n\treturn encode(updated);\r\n};\r\n\r\n// TODO: add the standard/wild/twist etc distinction\r\nconst getBaseCardForDeckbuilding = (dbfId: number, format: GameFormat, allCards: AllCardsService): number => {\r\n\tconst card = allCards.getCard(dbfId);\r\n\tif (!card.deckDuplicateDbfId) {\r\n\t\treturn dbfId;\r\n\t}\r\n\r\n\tconst originCard = allCards.getCard(card.deckDuplicateDbfId);\r\n\tif (!originCard) {\r\n\t\treturn dbfId;\r\n\t}\r\n\r\n\t// Now check if the origin card is in the list of sets allowed for the format\r\n\tconst allowedSets = getAllowedSets(format);\r\n\tif (allowedSets.includes(originCard.set?.toLowerCase())) {\r\n\t\treturn originCard.dbfId;\r\n\t}\r\n\r\n\treturn dbfId;\r\n};\r\n\r\nconst getAllowedSets = (format: GameFormat): readonly string[] => {\r\n\tswitch (format) {\r\n\t\tcase GameFormat.FT_STANDARD:\r\n\t\t\treturn standardSets;\r\n\t\tcase GameFormat.FT_CLASSIC:\r\n\t\t\treturn ['classic'];\r\n\t\tcase GameFormat.FT_TWIST:\r\n\t\t\treturn twistSets;\r\n\t\tcase GameFormat.FT_WILD:\r\n\t\tdefault:\r\n\t\t\treturn wildSets;\r\n\t}\r\n};\r\n\r\nconst normalizeSideboard = (sideboard: Sideboard, format: GameFormat, allCards: AllCardsService): Sideboard => {\r\n\tconst cards: DeckList = sideboard.cards.map((pair) => [\r\n\t\tgetBaseCardForDeckbuilding(pair[0], format, allCards),\r\n\t\tpair[1],\r\n\t]);\r\n\treturn {\r\n\t\t...sideboard,\r\n\t\tcards: cards,\r\n\t};\r\n};\r\n"]}
1
+ {"version":3,"file":"deck-utils.js","sourceRoot":"","sources":["../../src/services/deck-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { DeckDefinition, DeckList, decode, encode, Sideboard } from '@firestone-hs/deckstrings';\r\nimport { GameFormat, standardSets, twistSets, wildSets } from '../public-api';\r\nimport { AllCardsService } from './all-cards.service';\r\n\r\nexport const normalizeDeckList = (decklist: string, allCards: AllCardsService): string => {\r\n\tconst decoded: DeckDefinition = decode(decklist);\r\n\tconst cards: DeckList = decoded.cards.map((pair) => [\r\n\t\tgetBaseCardForDeckbuilding(pair[0], decoded.format, allCards),\r\n\t\tpair[1],\r\n\t]);\r\n\tconst sideboards: Sideboard[] = decoded.sideboards?.map((sideboard) =>\r\n\t\tnormalizeSideboard(sideboard, decoded.format, allCards),\r\n\t);\r\n\tconst updated: DeckDefinition = {\r\n\t\t...decoded,\r\n\t\tcards: cards,\r\n\t\tsideboards: sideboards,\r\n\t};\r\n\treturn encode(updated);\r\n};\r\n\r\n// TODO: add the standard/wild/twist etc distinction\r\nexport const getBaseCardForDeckbuilding = (dbfId: number, format: GameFormat, allCards: AllCardsService): number => {\r\n\tconst card = allCards.getCard(dbfId);\r\n\tif (!card.deckDuplicateDbfId) {\r\n\t\treturn dbfId;\r\n\t}\r\n\r\n\tconst originCard = allCards.getCard(card.deckDuplicateDbfId);\r\n\tif (!originCard) {\r\n\t\treturn dbfId;\r\n\t}\r\n\r\n\t// Now check if the origin card is in the list of sets allowed for the format\r\n\tconst allowedSets = getAllowedSets(format);\r\n\tif (allowedSets.includes(originCard.set?.toLowerCase())) {\r\n\t\treturn originCard.dbfId;\r\n\t}\r\n\r\n\treturn dbfId;\r\n};\r\n\r\nexport const getBaseCardIdForDeckbuilding = (cardId: string, format: GameFormat, allCards: AllCardsService): string => {\r\n\tconst card = allCards.getCard(cardId);\r\n\tif (!card.deckDuplicateDbfId) {\r\n\t\treturn cardId;\r\n\t}\r\n\r\n\tconst originCard = allCards.getCard(card.deckDuplicateDbfId);\r\n\tif (!originCard) {\r\n\t\treturn cardId;\r\n\t}\r\n\r\n\t// Now check if the origin card is in the list of sets allowed for the format\r\n\tconst allowedSets = getAllowedSets(format);\r\n\tif (allowedSets.includes(originCard.set?.toLowerCase())) {\r\n\t\treturn originCard.id;\r\n\t}\r\n\r\n\treturn cardId;\r\n};\r\n\r\nconst getAllowedSets = (format: GameFormat): readonly string[] => {\r\n\tswitch (format) {\r\n\t\tcase GameFormat.FT_STANDARD:\r\n\t\t\treturn standardSets;\r\n\t\tcase GameFormat.FT_CLASSIC:\r\n\t\t\treturn ['classic'];\r\n\t\tcase GameFormat.FT_TWIST:\r\n\t\t\treturn twistSets;\r\n\t\tcase GameFormat.FT_WILD:\r\n\t\tdefault:\r\n\t\t\treturn wildSets;\r\n\t}\r\n};\r\n\r\nconst normalizeSideboard = (sideboard: Sideboard, format: GameFormat, allCards: AllCardsService): Sideboard => {\r\n\tconst cards: DeckList = sideboard.cards.map((pair) => [\r\n\t\tgetBaseCardForDeckbuilding(pair[0], format, allCards),\r\n\t\tpair[1],\r\n\t]);\r\n\treturn {\r\n\t\t...sideboard,\r\n\t\tcards: cards,\r\n\t};\r\n};\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@firestone-hs/reference-data",
3
- "version": "1.0.146",
3
+ "version": "1.0.147",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "build": "rm -rf dist && tsc",