2023-03-03 16:23:46 +01:00
|
|
|
import { inject, injectable } from "tsyringe";
|
2023-10-19 19:21:17 +02:00
|
|
|
import { IPreset } from "@spt-aki/models/eft/common/IGlobals";
|
2024-02-07 21:32:24 +01:00
|
|
|
import { BaseClasses } from "@spt-aki/models/enums/BaseClasses";
|
2023-10-19 19:21:17 +02:00
|
|
|
import { DatabaseServer } from "@spt-aki/servers/DatabaseServer";
|
2024-05-13 19:58:17 +02:00
|
|
|
import { ICloner } from "@spt-aki/utils/cloners/ICloner";
|
2024-02-07 21:32:24 +01:00
|
|
|
import { ItemHelper } from "./ItemHelper";
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class PresetHelper
|
|
|
|
{
|
|
|
|
protected lookup: Record<string, string[]> = {};
|
2024-02-07 21:32:24 +01:00
|
|
|
protected defaultEquipmentPresets: Record<string, IPreset>;
|
|
|
|
protected defaultWeaponPresets: Record<string, IPreset>;
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
constructor(
|
2023-11-16 02:35:05 +01:00
|
|
|
@inject("DatabaseServer") protected databaseServer: DatabaseServer,
|
2024-02-07 21:32:24 +01:00
|
|
|
@inject("ItemHelper") protected itemHelper: ItemHelper,
|
2024-05-13 19:58:17 +02:00
|
|
|
@inject("RecursiveCloner") protected cloner: ICloner,
|
2023-03-03 16:23:46 +01:00
|
|
|
)
|
2023-11-16 02:35:05 +01:00
|
|
|
{}
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
public hydratePresetStore(input: Record<string, string[]>): void
|
|
|
|
{
|
|
|
|
this.lookup = input;
|
|
|
|
}
|
|
|
|
|
2024-02-07 21:32:24 +01:00
|
|
|
/**
|
|
|
|
* Get default weapon and equipment presets
|
|
|
|
* @returns Dictionary
|
|
|
|
*/
|
2023-07-18 16:44:14 +02:00
|
|
|
public getDefaultPresets(): Record<string, IPreset>
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2024-02-07 21:32:24 +01:00
|
|
|
const weapons = this.getDefaultWeaponPresets();
|
|
|
|
const equipment = this.getDefaultEquipmentPresets();
|
|
|
|
|
|
|
|
return Object.assign({}, weapons, equipment);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get default weapon presets
|
|
|
|
* @returns Dictionary
|
|
|
|
*/
|
|
|
|
public getDefaultWeaponPresets(): Record<string, IPreset>
|
|
|
|
{
|
|
|
|
if (!this.defaultWeaponPresets)
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2024-05-08 05:57:08 +02:00
|
|
|
this.defaultWeaponPresets = Object.values(
|
|
|
|
this.databaseServer.getTables().globals.ItemPresets,
|
|
|
|
)
|
|
|
|
.filter(
|
|
|
|
preset =>
|
|
|
|
preset._encyclopedia !== undefined
|
|
|
|
&& this.itemHelper.isOfBaseclass(preset._encyclopedia, BaseClasses.WEAPON),
|
|
|
|
)
|
|
|
|
.reduce((acc, cur) =>
|
|
|
|
{
|
|
|
|
acc[cur._id] = cur;
|
|
|
|
return acc;
|
|
|
|
}, {});
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
2024-02-07 21:32:24 +01:00
|
|
|
return this.defaultWeaponPresets;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get default equipment presets
|
|
|
|
* @returns Dictionary
|
|
|
|
*/
|
|
|
|
public getDefaultEquipmentPresets(): Record<string, IPreset>
|
|
|
|
{
|
|
|
|
if (!this.defaultEquipmentPresets)
|
|
|
|
{
|
2024-05-13 19:58:17 +02:00
|
|
|
this.defaultEquipmentPresets = Object.values(this.databaseServer.getTables().globals.ItemPresets)
|
|
|
|
.filter(preset => preset._encyclopedia !== undefined
|
|
|
|
&& this.itemHelper.armorItemCanHoldMods(preset._encyclopedia),
|
|
|
|
).reduce((acc, cur) =>
|
2024-02-07 21:32:24 +01:00
|
|
|
{
|
|
|
|
acc[cur._id] = cur;
|
|
|
|
return acc;
|
|
|
|
}, {});
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.defaultEquipmentPresets;
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public isPreset(id: string): boolean
|
|
|
|
{
|
|
|
|
return id in this.databaseServer.getTables().globals.ItemPresets;
|
|
|
|
}
|
|
|
|
|
2024-04-10 18:23:19 +02:00
|
|
|
/**
|
|
|
|
* Checks to see if the preset is of the given base class.
|
|
|
|
* @param id The id of the preset
|
|
|
|
* @param baseClass The BaseClasses enum to check against
|
|
|
|
* @returns True if the preset is of the given base class, false otherwise
|
|
|
|
*/
|
|
|
|
public isPresetBaseClass(id: string, baseClass: BaseClasses): boolean
|
|
|
|
{
|
|
|
|
return this.isPreset(id) && this.itemHelper.isOfBaseclass(this.getPreset(id)._encyclopedia, baseClass);
|
|
|
|
}
|
|
|
|
|
2023-03-03 16:23:46 +01:00
|
|
|
public hasPreset(templateId: string): boolean
|
|
|
|
{
|
|
|
|
return templateId in this.lookup;
|
|
|
|
}
|
|
|
|
|
2023-07-18 16:44:14 +02:00
|
|
|
public getPreset(id: string): IPreset
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
2024-05-13 19:58:17 +02:00
|
|
|
return this.cloner.clone(this.databaseServer.getTables().globals.ItemPresets[id]);
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
2024-01-16 11:28:08 +01:00
|
|
|
public getAllPresets(): IPreset[]
|
|
|
|
{
|
2024-05-13 19:58:17 +02:00
|
|
|
return this.cloner.clone(Object.values(this.databaseServer.getTables().globals.ItemPresets));
|
2024-01-16 11:28:08 +01:00
|
|
|
}
|
|
|
|
|
2023-07-18 16:44:14 +02:00
|
|
|
public getPresets(templateId: string): IPreset[]
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
|
|
|
if (!this.hasPreset(templateId))
|
|
|
|
{
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
const presets = [];
|
|
|
|
const ids = this.lookup[templateId];
|
|
|
|
|
|
|
|
for (const id of ids)
|
|
|
|
{
|
|
|
|
presets.push(this.getPreset(id));
|
|
|
|
}
|
|
|
|
|
|
|
|
return presets;
|
|
|
|
}
|
|
|
|
|
2023-08-09 12:52:20 +02:00
|
|
|
/**
|
2024-01-10 11:04:09 +01:00
|
|
|
* Get the default preset for passed in item id
|
|
|
|
* @param templateId Item id to get preset for
|
2023-08-09 12:52:20 +02:00
|
|
|
* @returns Null if no default preset, otherwise IPreset
|
|
|
|
*/
|
2023-07-18 16:44:14 +02:00
|
|
|
public getDefaultPreset(templateId: string): IPreset
|
2023-03-03 16:23:46 +01:00
|
|
|
{
|
|
|
|
if (!this.hasPreset(templateId))
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
const allPresets = this.getPresets(templateId);
|
|
|
|
|
|
|
|
for (const preset of allPresets)
|
|
|
|
{
|
|
|
|
if ("_encyclopedia" in preset)
|
|
|
|
{
|
|
|
|
return preset;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return allPresets[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
public getBaseItemTpl(presetId: string): string
|
|
|
|
{
|
|
|
|
if (this.isPreset(presetId))
|
|
|
|
{
|
|
|
|
const preset = this.getPreset(presetId);
|
|
|
|
|
|
|
|
for (const item of preset._items)
|
|
|
|
{
|
|
|
|
if (preset._parent === item._id)
|
|
|
|
{
|
|
|
|
return item._tpl;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return "";
|
|
|
|
}
|
2024-03-11 01:03:41 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the price of the preset for the given item tpl, or for the tpl itself if no preset exists
|
|
|
|
* @param tpl The item template to get the price of
|
|
|
|
* @returns The price of the given item preset, or base item if no preset exists
|
|
|
|
*/
|
|
|
|
public getDefaultPresetOrItemPrice(tpl: string): number
|
|
|
|
{
|
|
|
|
// Get default preset if it exists
|
|
|
|
const defaultPreset = this.getDefaultPreset(tpl);
|
|
|
|
|
|
|
|
// Bundle up tpls we want price for
|
2024-05-08 05:57:08 +02:00
|
|
|
const tpls = defaultPreset ? defaultPreset._items.map(item => item._tpl) : [tpl];
|
2024-03-11 01:03:41 +01:00
|
|
|
|
|
|
|
// Get price of tpls
|
|
|
|
return this.itemHelper.getItemAndChildrenPrice(tpls);
|
|
|
|
}
|
2023-11-16 02:35:05 +01:00
|
|
|
}
|