2023-03-03 16:23:46 +01:00
|
|
|
import { inject, injectable } from "tsyringe";
|
2024-05-21 19:59:04 +02:00
|
|
|
import { HandbookHelper } from "@spt/helpers/HandbookHelper";
|
|
|
|
import { ItemHelper } from "@spt/helpers/ItemHelper";
|
|
|
|
import { TraderAssortHelper } from "@spt/helpers/TraderAssortHelper";
|
|
|
|
import { UtilityHelper } from "@spt/helpers/UtilityHelper";
|
|
|
|
import { Item } from "@spt/models/eft/common/tables/IItem";
|
|
|
|
import { ITraderAssort } from "@spt/models/eft/common/tables/ITrader";
|
|
|
|
import { ISearchRequestData } from "@spt/models/eft/ragfair/ISearchRequestData";
|
|
|
|
import { ConfigTypes } from "@spt/models/enums/ConfigTypes";
|
|
|
|
import { Money } from "@spt/models/enums/Money";
|
|
|
|
import { IRagfairConfig } from "@spt/models/spt/config/IRagfairConfig";
|
|
|
|
import { ILogger } from "@spt/models/spt/utils/ILogger";
|
|
|
|
import { ConfigServer } from "@spt/servers/ConfigServer";
|
2024-05-28 23:24:52 +02:00
|
|
|
import { DatabaseService } from "@spt/services/DatabaseService";
|
2024-05-21 19:59:04 +02:00
|
|
|
import { RagfairLinkedItemService } from "@spt/services/RagfairLinkedItemService";
|
|
|
|
import { ICloner } from "@spt/utils/cloners/ICloner";
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class RagfairHelper
|
|
|
|
{
|
|
|
|
protected ragfairConfig: IRagfairConfig;
|
|
|
|
|
|
|
|
constructor(
|
2024-05-28 16:04:20 +02:00
|
|
|
@inject("PrimaryLogger") protected logger: ILogger,
|
2023-03-03 16:23:46 +01:00
|
|
|
@inject("TraderAssortHelper") protected traderAssortHelper: TraderAssortHelper,
|
2024-05-28 23:24:52 +02:00
|
|
|
@inject("DatabaseService") protected databaseService: DatabaseService,
|
2023-03-03 16:23:46 +01:00
|
|
|
@inject("HandbookHelper") protected handbookHelper: HandbookHelper,
|
|
|
|
@inject("ItemHelper") protected itemHelper: ItemHelper,
|
|
|
|
@inject("RagfairLinkedItemService") protected ragfairLinkedItemService: RagfairLinkedItemService,
|
|
|
|
@inject("UtilityHelper") protected utilityHelper: UtilityHelper,
|
2023-11-13 17:07:59 +01:00
|
|
|
@inject("ConfigServer") protected configServer: ConfigServer,
|
2024-05-28 16:04:20 +02:00
|
|
|
@inject("PrimaryCloner") protected cloner: ICloner,
|
2023-03-03 16:23:46 +01:00
|
|
|
)
|
|
|
|
{
|
|
|
|
this.ragfairConfig = this.configServer.getConfig(ConfigTypes.RAGFAIR);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2023-11-13 17:07:59 +01:00
|
|
|
* Gets currency TAG from TPL
|
|
|
|
* @param {string} currency
|
|
|
|
* @returns string
|
|
|
|
*/
|
2023-03-03 16:23:46 +01:00
|
|
|
public getCurrencyTag(currency: string): string
|
|
|
|
{
|
|
|
|
switch (currency)
|
|
|
|
{
|
|
|
|
case "569668774bdc2da2298b4568":
|
|
|
|
return "EUR";
|
|
|
|
|
|
|
|
case "5696686a4bdc2da3298b456a":
|
|
|
|
return "USD";
|
|
|
|
|
|
|
|
case "5449016a4bdc2d6f028b456f":
|
|
|
|
return "RUB";
|
|
|
|
default:
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-12-14 16:47:01 +01:00
|
|
|
public filterCategories(sessionID: string, request: ISearchRequestData): string[]
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
|
|
|
let result: string[] = [];
|
|
|
|
|
|
|
|
// Case: weapon builds
|
2023-12-14 16:47:01 +01:00
|
|
|
if (request.buildCount)
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2023-12-14 16:47:01 +01:00
|
|
|
return Object.keys(request.buildItems);
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Case: search
|
2023-12-14 16:47:01 +01:00
|
|
|
if (request.linkedSearchId)
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2023-12-14 16:47:01 +01:00
|
|
|
const data = this.ragfairLinkedItemService.getLinkedItems(request.linkedSearchId);
|
2023-11-13 18:31:52 +01:00
|
|
|
result = !data ? [] : [...data];
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// Case: category
|
2023-12-14 16:47:01 +01:00
|
|
|
if (request.handbookId)
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2023-12-14 16:47:01 +01:00
|
|
|
const handbook = this.getCategoryList(request.handbookId);
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
if (result.length)
|
|
|
|
{
|
|
|
|
result = this.utilityHelper.arrayIntersect(result, handbook);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
result = handbook;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
public getDisplayableAssorts(sessionID: string): Record<string, ITraderAssort>
|
|
|
|
{
|
|
|
|
const result: Record<string, ITraderAssort> = {};
|
|
|
|
|
2024-05-28 23:24:52 +02:00
|
|
|
for (const traderID in this.databaseService.getTraders())
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
|
|
|
if (this.ragfairConfig.traders[traderID])
|
|
|
|
{
|
|
|
|
result[traderID] = this.traderAssortHelper.getAssort(sessionID, traderID, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getCategoryList(handbookId: string): string[]
|
|
|
|
{
|
|
|
|
let result: string[] = [];
|
|
|
|
|
|
|
|
// if its "mods" great-parent category, do double recursive loop
|
|
|
|
if (handbookId === "5b5f71a686f77447ed5636ab")
|
|
|
|
{
|
|
|
|
for (const categ of this.handbookHelper.childrenCategories(handbookId))
|
|
|
|
{
|
|
|
|
for (const subcateg of this.handbookHelper.childrenCategories(categ))
|
|
|
|
{
|
|
|
|
result = [...result, ...this.handbookHelper.templatesWithParent(subcateg)];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// item is in any other category
|
|
|
|
if (this.handbookHelper.isCategory(handbookId))
|
|
|
|
{
|
|
|
|
// list all item of the category
|
|
|
|
result = this.handbookHelper.templatesWithParent(handbookId);
|
|
|
|
|
|
|
|
for (const categ of this.handbookHelper.childrenCategories(handbookId))
|
|
|
|
{
|
|
|
|
result = [...result, ...this.handbookHelper.templatesWithParent(categ)];
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
// its a specific item searched
|
|
|
|
result.push(handbookId);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Merges Root Items
|
|
|
|
* Ragfair allows abnormally large stacks.
|
|
|
|
*/
|
|
|
|
public mergeStackable(items: Item[]): Item[]
|
|
|
|
{
|
|
|
|
const list = [];
|
2024-05-27 22:06:07 +02:00
|
|
|
let rootItem = undefined;
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
for (let item of items)
|
|
|
|
{
|
|
|
|
item = this.itemHelper.fixItemStackCount(item);
|
2024-05-17 21:32:41 +02:00
|
|
|
const isChild = items.find((it) => it._id === item.parentId);
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
if (!isChild)
|
|
|
|
{
|
|
|
|
if (!rootItem)
|
|
|
|
{
|
2024-05-13 19:58:17 +02:00
|
|
|
rootItem = this.cloner.clone(item);
|
2023-03-03 16:23:46 +01:00
|
|
|
rootItem.upd.OriginalStackObjectsCount = rootItem.upd.StackObjectsCount;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
rootItem.upd.StackObjectsCount += item.upd.StackObjectsCount;
|
|
|
|
list.push(item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
list.push(item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return [...[rootItem], ...list];
|
|
|
|
}
|
|
|
|
|
2023-12-14 16:47:01 +01:00
|
|
|
/**
|
|
|
|
* Return the symbol for a currency
|
|
|
|
* e.g. 5449016a4bdc2d6f028b456f return ₽
|
|
|
|
* @param currencyTpl currency to get symbol for
|
|
|
|
* @returns symbol of currency
|
|
|
|
*/
|
2023-03-03 16:23:46 +01:00
|
|
|
public getCurrencySymbol(currencyTpl: string): string
|
|
|
|
{
|
|
|
|
switch (currencyTpl)
|
|
|
|
{
|
|
|
|
case Money.EUROS:
|
|
|
|
return "€";
|
|
|
|
case Money.DOLLARS:
|
|
|
|
return "$";
|
2023-11-01 15:42:45 +01:00
|
|
|
default: // Money.ROUBLES
|
2023-03-03 16:23:46 +01:00
|
|
|
return "₽";
|
|
|
|
}
|
|
|
|
}
|
2023-11-01 15:42:45 +01:00
|
|
|
}
|