Added optional blacklist functionality to generateReward()

This commit is contained in:
Dev 2024-10-09 10:40:32 +01:00
parent ff501d31c9
commit ad95b227dd

View File

@ -77,6 +77,7 @@ export class RepeatableQuestRewardGenerator {
traderId: string, traderId: string,
repeatableConfig: IRepeatableQuestConfig, repeatableConfig: IRepeatableQuestConfig,
questConfig: IBaseQuestConfig, questConfig: IBaseQuestConfig,
rewardTplBlacklist?: string[],
): IQuestRewards { ): IQuestRewards {
// Get vars to configure rewards with // Get vars to configure rewards with
const rewardParams = this.getQuestRewardValues(repeatableConfig.rewardScaling, difficulty, pmcLevel); const rewardParams = this.getQuestRewardValues(repeatableConfig.rewardScaling, difficulty, pmcLevel);
@ -126,7 +127,15 @@ export class RepeatableQuestRewardGenerator {
} }
} }
const inBudgetRewardItemPool = this.chooseRewardItemsWithinBudget(repeatableConfig, itemRewardBudget, traderId); let inBudgetRewardItemPool = this.chooseRewardItemsWithinBudget(repeatableConfig, itemRewardBudget, traderId);
if (rewardTplBlacklist) {
// Filter reward pool of items from blacklist, only use if there's at least 1 item remaining
const filteredRewardItemPool = inBudgetRewardItemPool.filter((x) => !rewardTplBlacklist.includes(x._id));
if (filteredRewardItemPool.length > 0) {
inBudgetRewardItemPool = filteredRewardItemPool;
}
}
this.logger.debug( this.logger.debug(
`Generating daily quest for: ${traderId} with budget: ${itemRewardBudget} totalling: ${rewardParams.rewardNumItems} items`, `Generating daily quest for: ${traderId} with budget: ${itemRewardBudget} totalling: ${rewardParams.rewardNumItems} items`,
); );