@firestone-hs/replay-parser
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.9.
99 lines • 17.3 kB
JavaScript
import { CardType, GameTag, Zone } from '@firestone-hs/reference-data';
import { Map } from 'immutable';
import { AttackAction } from '../../models/action/attack-action';
import { DamageAction } from '../../models/action/damage-action';
import { HealingAction } from '../../models/action/healing-action';
import { PowerTargetAction } from '../../models/action/power-target-action';
import { TagChangeHistoryItem } from '../../models/history/tag-change-history-item';
import { ActionButtonUsedAction, CardPlayedFromHandAction, FullEntityHistoryItem, GameHepler, } from '../../models/models';
import { ActionHelper } from './action-helper';
export class DamageParser {
constructor(allCards) {
this.allCards = allCards;
}
applies(item) {
return item instanceof TagChangeHistoryItem && item.tag.tag === GameTag.DAMAGE;
}
parse(item, currentTurn, entitiesBeforeAction, history) {
const entity = entitiesBeforeAction.get(item.tag.entity);
// Damage is reset to 0 after an entity dies, and we don't want to show this
if (!entity || entity.getTag(GameTag.ZONE) !== Zone.PLAY) {
return [];
}
// Ignore damage to locations
if (entity.getTag(GameTag.CARDTYPE) === CardType?.LOCATION) {
return [];
}
const previousDamageTag = entity.getTag(GameTag.DAMAGE);
const previousDamage = !previousDamageTag || previousDamageTag === -1 ? 0 : previousDamageTag;
const damageTaken = item.tag.value - previousDamage;
// If we are in battlegrounds, things are a bit trickier. We don't want to show the
// damage taken by the opponent hero at the start of a battle
const gameEntity = GameHepler.getGameEntity(entitiesBeforeAction);
if (gameEntity.isBattlegrounds()) {
const historyIndex = history.indexOf(item);
if (historyIndex > 0) {
const previous = history[historyIndex - 1];
if (previous instanceof FullEntityHistoryItem &&
previous.entityDefintion.cardID &&
previous.entityDefintion.cardID.indexOf('TB_BaconShop_HP_') !== -1) {
return [];
}
}
}
if (entity.id === 641) {
// console.log('adding damage action', item, damageTaken, previousDamageTag, entity.tags.toJS());
}
if (damageTaken > 0) {
return [
DamageAction.create({
timestamp: item.timestamp,
index: item.index,
damages: Map.of(item.tag.entity, damageTaken),
}, this.allCards),
];
}
else if (damageTaken < 0) {
return [
HealingAction.create({
timestamp: item.timestamp,
index: item.index,
damages: Map.of(item.tag.entity, damageTaken),
}, this.allCards),
];
}
return [];
}
reduce(actions) {
return ActionHelper.combineActions(actions, (previous, current) => this.shouldMergeActions(previous, current), (previous, current) => this.mergeActions(previous, current));
}
shouldMergeActions(previousAction, currentAction) {
if (currentAction instanceof DamageAction) {
return (previousAction instanceof DamageAction || // Merge all damages into a single action
previousAction instanceof AttackAction || // Add damage to the attack causing the damage
previousAction instanceof PowerTargetAction || // Add damages to the power causing the damage
previousAction instanceof ActionButtonUsedAction ||
previousAction instanceof CardPlayedFromHandAction // It's usually teh same "action"
);
}
else if (currentAction instanceof HealingAction) {
return (previousAction instanceof HealingAction || // Merge all heals into a single action
previousAction instanceof AttackAction || // Add heal to the attack causing the heal
previousAction instanceof PowerTargetAction || // Add heals to the power causing the heal
previousAction instanceof ActionButtonUsedAction || // Add heals to the power causing the heal
previousAction instanceof CardPlayedFromHandAction // It's usually teh same "action"
);
}
}
mergeActions(previousAction, currentAction) {
return this.mergeDamageIntoAction(previousAction, currentAction);
}
mergeDamageIntoAction(previousAction, currentAction) {
const result = ActionHelper.mergeIntoFirstAction(previousAction, currentAction, {
index: currentAction.index,
entities: currentAction.entities,
});
return result;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"damage-parser.js","sourceRoot":"","sources":["../../../../../../projects/replay-parser/src/lib/services/action/damage-parser.ts"],"names":[],"mappings":"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","sourcesContent":["import { CardType, GameTag, Zone } from '@firestone-hs/reference-data';\r\nimport { Map } from 'immutable';\r\nimport { Action } from '../../models/action/action';\r\nimport { AttackAction } from '../../models/action/attack-action';\r\nimport { DamageAction } from '../../models/action/damage-action';\r\nimport { HealingAction } from '../../models/action/healing-action';\r\nimport { PowerTargetAction } from '../../models/action/power-target-action';\r\nimport { Entity } from '../../models/game/entity';\r\nimport { HistoryItem } from '../../models/history/history-item';\r\nimport { TagChangeHistoryItem } from '../../models/history/tag-change-history-item';\r\nimport {\r\n\tActionButtonUsedAction,\r\n\tCardPlayedFromHandAction,\r\n\tFullEntityHistoryItem,\r\n\tGameEntity,\r\n\tGameHepler,\r\n} from '../../models/models';\r\nimport { AllCardsService } from '../all-cards.service';\r\nimport { ActionHelper } from './action-helper';\r\nimport { Parser } from './parser';\r\n\r\nexport class DamageParser implements Parser {\r\n\tconstructor(private allCards: AllCardsService) {}\r\n\r\n\tpublic applies(item: HistoryItem): boolean {\r\n\t\treturn item instanceof TagChangeHistoryItem && item.tag.tag === GameTag.DAMAGE;\r\n\t}\r\n\r\n\tpublic parse(\r\n\t\titem: TagChangeHistoryItem,\r\n\t\tcurrentTurn: number,\r\n\t\tentitiesBeforeAction: Map<number, Entity>,\r\n\t\thistory: readonly HistoryItem[],\r\n\t): Action[] {\r\n\t\tconst entity = entitiesBeforeAction.get(item.tag.entity);\r\n\t\t// Damage is reset to 0 after an entity dies, and we don't want to show this\r\n\t\tif (!entity || entity.getTag(GameTag.ZONE) !== Zone.PLAY) {\r\n\t\t\treturn [];\r\n\t\t}\r\n\t\t// Ignore damage to locations\r\n\t\tif (entity.getTag(GameTag.CARDTYPE) === CardType?.LOCATION) {\r\n\t\t\treturn [];\r\n\t\t}\r\n\r\n\t\tconst previousDamageTag = entity.getTag(GameTag.DAMAGE);\r\n\t\tconst previousDamage = !previousDamageTag || previousDamageTag === -1 ? 0 : previousDamageTag;\r\n\t\tconst damageTaken = item.tag.value - previousDamage;\r\n\t\t// If we are in battlegrounds, things are a bit trickier. We don't want to show the\r\n\t\t// damage taken by the opponent hero at the start of a battle\r\n\t\tconst gameEntity: GameEntity = GameHepler.getGameEntity(entitiesBeforeAction) as GameEntity;\r\n\t\tif (gameEntity.isBattlegrounds()) {\r\n\t\t\tconst historyIndex = history.indexOf(item);\r\n\t\t\tif (historyIndex > 0) {\r\n\t\t\t\tconst previous = history[historyIndex - 1];\r\n\t\t\t\tif (\r\n\t\t\t\t\tprevious instanceof FullEntityHistoryItem &&\r\n\t\t\t\t\tprevious.entityDefintion.cardID &&\r\n\t\t\t\t\tprevious.entityDefintion.cardID.indexOf('TB_BaconShop_HP_') !== -1\r\n\t\t\t\t) {\r\n\t\t\t\t\treturn [];\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (entity.id === 641) {\r\n\t\t\t// console.log('adding damage action', item, damageTaken, previousDamageTag, entity.tags.toJS());\r\n\t\t}\r\n\t\tif (damageTaken > 0) {\r\n\t\t\treturn [\r\n\t\t\t\tDamageAction.create(\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttimestamp: item.timestamp,\r\n\t\t\t\t\t\tindex: item.index,\r\n\t\t\t\t\t\tdamages: Map.of(item.tag.entity, damageTaken),\r\n\t\t\t\t\t} as Action,\r\n\t\t\t\t\tthis.allCards,\r\n\t\t\t\t),\r\n\t\t\t];\r\n\t\t} else if (damageTaken < 0) {\r\n\t\t\treturn [\r\n\t\t\t\tHealingAction.create(\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\ttimestamp: item.timestamp,\r\n\t\t\t\t\t\tindex: item.index,\r\n\t\t\t\t\t\tdamages: Map.of(item.tag.entity, damageTaken),\r\n\t\t\t\t\t},\r\n\t\t\t\t\tthis.allCards,\r\n\t\t\t\t),\r\n\t\t\t];\r\n\t\t}\r\n\t\treturn [];\r\n\t}\r\n\r\n\tpublic reduce(actions: readonly Action[]): readonly Action[] {\r\n\t\treturn ActionHelper.combineActions<Action>(\r\n\t\t\tactions,\r\n\t\t\t(previous, current) => this.shouldMergeActions(previous, current),\r\n\t\t\t(previous, current) => this.mergeActions(previous, current),\r\n\t\t);\r\n\t}\r\n\r\n\tprivate shouldMergeActions(previousAction: Action, currentAction: Action): boolean {\r\n\t\tif (currentAction instanceof DamageAction) {\r\n\t\t\treturn (\r\n\t\t\t\tpreviousAction instanceof DamageAction || // Merge all damages into a single action\r\n\t\t\t\tpreviousAction instanceof AttackAction || // Add damage to the attack causing the damage\r\n\t\t\t\tpreviousAction instanceof PowerTargetAction || // Add damages to the power causing the damage\r\n\t\t\t\tpreviousAction instanceof ActionButtonUsedAction ||\r\n\t\t\t\tpreviousAction instanceof CardPlayedFromHandAction // It's usually teh same \"action\"\r\n\t\t\t);\r\n\t\t} else if (currentAction instanceof HealingAction) {\r\n\t\t\treturn (\r\n\t\t\t\tpreviousAction instanceof HealingAction || // Merge all heals into a single action\r\n\t\t\t\tpreviousAction instanceof AttackAction || // Add heal to the attack causing the heal\r\n\t\t\t\tpreviousAction instanceof PowerTargetAction || // Add heals to the power causing the heal\r\n\t\t\t\tpreviousAction instanceof ActionButtonUsedAction || // Add heals to the power causing the heal\r\n\t\t\t\tpreviousAction instanceof CardPlayedFromHandAction // It's usually teh same \"action\"\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate mergeActions(previousAction: Action, currentAction: Action): Action {\r\n\t\treturn this.mergeDamageIntoAction(previousAction, currentAction as DamageAction);\r\n\t}\r\n\r\n\tprivate mergeDamageIntoAction(previousAction: Action, currentAction: DamageAction): Action {\r\n\t\tconst result = ActionHelper.mergeIntoFirstAction(previousAction, currentAction, {\r\n\t\t\tindex: currentAction.index,\r\n\t\t\tentities: currentAction.entities,\r\n\t\t} as Action);\r\n\t\treturn result;\r\n\t}\r\n}\r\n"]}