2023-03-03 15:23:46 +00:00
|
|
|
import { inject, injectable } from "tsyringe";
|
|
|
|
|
2023-12-05 20:41:43 +00:00
|
|
|
import { PaymentHelper } from "@spt-aki/helpers/PaymentHelper";
|
2023-10-19 17:21:17 +00:00
|
|
|
import { IRagfairOffer } from "@spt-aki/models/eft/ragfair/IRagfairOffer";
|
2023-12-05 20:41:43 +00:00
|
|
|
import { ISearchRequestData, OfferOwnerType } from "@spt-aki/models/eft/ragfair/ISearchRequestData";
|
|
|
|
import { MemberCategory } from "@spt-aki/models/enums/MemberCategory";
|
2023-10-19 17:21:17 +00:00
|
|
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
2023-03-03 15:23:46 +00:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class RagfairCategoriesService
|
|
|
|
{
|
2023-12-05 20:41:43 +00:00
|
|
|
constructor(
|
|
|
|
@inject("WinstonLogger") protected logger: ILogger,
|
|
|
|
@inject("PaymentHelper") protected paymentHelper: PaymentHelper,
|
|
|
|
)
|
2023-11-16 21:42:06 +00:00
|
|
|
{}
|
2023-03-03 15:23:46 +00:00
|
|
|
|
|
|
|
/**
|
2023-12-05 20:41:43 +00:00
|
|
|
* Get a dictionary of each item the play can see in their flea menu, filtered by what is available for them to buy
|
|
|
|
* @param offers All offers in flea
|
|
|
|
* @param searchRequestData Search criteria requested
|
|
|
|
* @param fleaUnlocked Can player see full flea yet (level 15 by default)
|
|
|
|
* @returns KVP of item tpls + count of offers
|
2023-03-03 15:23:46 +00:00
|
|
|
*/
|
2023-12-05 20:41:43 +00:00
|
|
|
public getCategoriesFromOffers(offers: IRagfairOffer[], searchRequestData: ISearchRequestData, fleaUnlocked: boolean): Record<string, number>
|
2023-03-03 15:23:46 +00:00
|
|
|
{
|
2023-12-05 20:41:43 +00:00
|
|
|
const validOffersForPlayerToSee = {};
|
2023-03-03 15:23:46 +00:00
|
|
|
for (const offer of offers)
|
|
|
|
{
|
2023-12-05 20:41:43 +00:00
|
|
|
const isTraderOffer = offer.user.memberType === MemberCategory.TRADER;
|
2023-03-03 15:23:46 +00:00
|
|
|
|
2023-12-05 20:41:43 +00:00
|
|
|
// Not level 15 and offer is from player, skip
|
|
|
|
if (!fleaUnlocked && !isTraderOffer)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
2023-03-03 15:23:46 +00:00
|
|
|
|
2023-12-05 20:41:43 +00:00
|
|
|
// Remove items not for money when `removeBartering` is enabled
|
|
|
|
if (searchRequestData.removeBartering && (offer.requirements.length > 1 || !this.paymentHelper.isMoneyTpl(offer.requirements[0]._tpl)))
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove when filter set to players only + offer is from trader
|
|
|
|
if (searchRequestData.offerOwnerType === OfferOwnerType.PLAYEROWNERTYPE && isTraderOffer)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Remove when filter set to traders only + offer is not from trader
|
|
|
|
if (searchRequestData.offerOwnerType === OfferOwnerType.TRADEROWNERTYPE && !isTraderOffer)
|
2023-03-03 15:23:46 +00:00
|
|
|
{
|
2023-12-05 20:41:43 +00:00
|
|
|
continue;
|
|
|
|
}
|
2023-03-03 15:23:46 +00:00
|
|
|
|
2023-12-05 20:41:43 +00:00
|
|
|
const itemTpl = offer.items[0]._tpl
|
|
|
|
|
|
|
|
if (!validOffersForPlayerToSee[itemTpl])
|
|
|
|
{
|
|
|
|
validOffersForPlayerToSee[itemTpl] = 1;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
validOffersForPlayerToSee[itemTpl]++;
|
2023-03-03 15:23:46 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-05 20:41:43 +00:00
|
|
|
return validOffersForPlayerToSee;
|
2023-03-03 15:23:46 +00:00
|
|
|
|
|
|
|
}
|
2023-11-16 21:42:06 +00:00
|
|
|
}
|