From 9b47c3b50ec7a7db01d243b4cab484047be5cf29 Mon Sep 17 00:00:00 2001 From: Dev Date: Thu, 25 Jan 2024 14:40:28 +0000 Subject: [PATCH] Fix being unable to buy items via equipment preset menu --- project/src/helpers/RagfairOfferHelper.ts | 30 ++++++++++------------- 1 file changed, 13 insertions(+), 17 deletions(-) diff --git a/project/src/helpers/RagfairOfferHelper.ts b/project/src/helpers/RagfairOfferHelper.ts index 6351f2b3..602fe24c 100644 --- a/project/src/helpers/RagfairOfferHelper.ts +++ b/project/src/helpers/RagfairOfferHelper.ts @@ -528,8 +528,9 @@ export class RagfairOfferHelper pmcProfile: IPmcData, ): boolean { - const item = offer.items[0]; - const money = offer.requirements[0]._tpl; + const offerRootItem = offer.items[0]; + /** Currency offer is sold for */ + const moneyTypeTpl = offer.requirements[0]._tpl; const isTraderOffer = offer.user.memberType === MemberCategory.TRADER; const isDefaultUserOffer = offer.user.memberType === MemberCategory.DEFAULT; @@ -542,7 +543,8 @@ export class RagfairOfferHelper return false; } - if (!!itemsToAdd && !itemsToAdd.includes(item._tpl)) + // Offer root items tpl not in searched for array + if (!itemsToAdd?.includes(offerRootItem._tpl)) { // skip items we shouldn't include return false; @@ -575,32 +577,26 @@ export class RagfairOfferHelper return false; } - if (searchRequest.quantityFrom > 0 && searchRequest.quantityFrom >= item.upd.StackObjectsCount) + if (searchRequest.quantityFrom > 0 && searchRequest.quantityFrom >= offerRootItem.upd.StackObjectsCount) { // too little items to offer return false; } - if (searchRequest.quantityTo > 0 && searchRequest.quantityTo <= item.upd.StackObjectsCount) + if (searchRequest.quantityTo > 0 && searchRequest.quantityTo <= offerRootItem.upd.StackObjectsCount) { // too many items to offer return false; } - if (searchRequest.onlyFunctional && this.presetHelper.hasPreset(item._tpl) && offer.items.length === 1) + if (searchRequest.onlyFunctional && this.presetHelper.hasPreset(offerRootItem._tpl) && offer.items.length === 1) { // don't include non-functional items return false; } - if (searchRequest.buildCount && this.presetHelper.hasPreset(item._tpl) && offer.items.length > 1) - { - // don't include preset items - return false; - } - - if (this.isConditionItem(item) - && !this.itemQualityInRange(item, searchRequest.conditionFrom, searchRequest.conditionTo) + if (this.isConditionItem(offerRootItem) + && !this.itemQualityInRange(offerRootItem, searchRequest.conditionFrom, searchRequest.conditionTo) ) { return false; @@ -608,17 +604,17 @@ export class RagfairOfferHelper // commented out as required search "which is for checking offers that are barters" // has info.removeBartering as true, this if statement removed barter items. - if (searchRequest.removeBartering && !this.paymentHelper.isMoneyTpl(money)) + if (searchRequest.removeBartering && !this.paymentHelper.isMoneyTpl(moneyTypeTpl)) { // don't include barter offers return false; } - if (searchRequest.currency > 0 && this.paymentHelper.isMoneyTpl(money)) + if (searchRequest.currency > 0 && this.paymentHelper.isMoneyTpl(moneyTypeTpl)) { const currencies = ["all", "RUB", "USD", "EUR"]; - if (this.ragfairHelper.getCurrencyTag(money) !== currencies[searchRequest.currency]) + if (this.ragfairHelper.getCurrencyTag(moneyTypeTpl) !== currencies[searchRequest.currency]) { // don't include item paid in wrong currency return false;