2023-11-02 01:47:28 -04:00
|
|
|
import "reflect-metadata";
|
2023-11-10 17:21:20 -05:00
|
|
|
|
|
|
|
import { format } from "date-fns";
|
2024-05-21 17:59:04 +00:00
|
|
|
import { container } from "tsyringe";
|
|
|
|
import { ItemHelper } from "@spt/helpers/ItemHelper";
|
|
|
|
import { Insurance } from "@spt/models/eft/profile/ISptProfile";
|
|
|
|
import { profileInsuranceFixture } from "@tests/__fixture__/profileInsurance.fixture";
|
2023-11-02 01:47:28 -04:00
|
|
|
|
2024-05-21 17:59:04 +00:00
|
|
|
type DateInput = number | number[] | { [index: number]: number };
|
2023-11-02 01:47:28 -04:00
|
|
|
|
|
|
|
export class ProfileInsuranceFactory
|
|
|
|
{
|
|
|
|
private profileInsuranceFixture: Insurance[];
|
|
|
|
|
|
|
|
constructor()
|
|
|
|
{
|
|
|
|
this.init();
|
|
|
|
}
|
|
|
|
|
|
|
|
public init(): this
|
|
|
|
{
|
|
|
|
this.profileInsuranceFixture = JSON.parse(JSON.stringify(profileInsuranceFixture)); // Deep clone.
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2024-04-11 21:17:09 -04:00
|
|
|
* Adjusts the scheduledTime, messageContent.systemData.date, and messageContent.systemData.time, otherwise the
|
2023-11-02 01:47:28 -04:00
|
|
|
* dates in the original fixture will likely be expired.
|
|
|
|
*/
|
|
|
|
public adjustPackageDates(dateInput?: DateInput): this
|
|
|
|
{
|
|
|
|
this.profileInsuranceFixture = this.profileInsuranceFixture.map((insurance, index) =>
|
|
|
|
{
|
2023-11-03 17:39:33 -04:00
|
|
|
// Default to 1 hour ago.
|
|
|
|
const defaultDate = Math.floor((Date.now() / 1000) - (1 * 60 * 60));
|
2023-11-02 01:47:28 -04:00
|
|
|
|
|
|
|
let date: number;
|
|
|
|
if (Array.isArray(dateInput) || typeof dateInput === "object")
|
|
|
|
{
|
|
|
|
date = dateInput[index] || defaultDate;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
date = dateInput || defaultDate;
|
|
|
|
}
|
|
|
|
|
|
|
|
insurance.scheduledTime = date;
|
2024-04-11 21:17:09 -04:00
|
|
|
insurance.systemData.date = format(date, "MM.dd.yyyy");
|
|
|
|
insurance.systemData.time = format(date, "HH:mm");
|
2023-11-02 01:47:28 -04:00
|
|
|
return insurance;
|
|
|
|
});
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes all attachment items that are currently attached to their parent, leaving the "normal" base items.
|
|
|
|
*/
|
|
|
|
public removeAttachmentItems(): this
|
|
|
|
{
|
|
|
|
const itemHelper = container.resolve<ItemHelper>("ItemHelper");
|
|
|
|
|
|
|
|
this.profileInsuranceFixture = this.profileInsuranceFixture.map((insurance) =>
|
|
|
|
{
|
2023-11-10 17:21:20 -05:00
|
|
|
insurance.items = insurance.items.filter((item) => !itemHelper.isAttachmentAttached(item));
|
2023-11-02 01:47:28 -04:00
|
|
|
return insurance;
|
|
|
|
});
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes all normal base items leaving only attachment items that are currently attached to their parent.
|
|
|
|
* This *will* cause orphaned attachments.
|
|
|
|
*/
|
|
|
|
public removeRegularItems(): this
|
|
|
|
{
|
|
|
|
const itemHelper = container.resolve<ItemHelper>("ItemHelper");
|
|
|
|
|
|
|
|
this.profileInsuranceFixture = this.profileInsuranceFixture.map((insurance) =>
|
|
|
|
{
|
2023-11-10 17:21:20 -05:00
|
|
|
insurance.items = insurance.items.filter((item) => itemHelper.isAttachmentAttached(item));
|
2023-11-02 01:47:28 -04:00
|
|
|
return insurance;
|
|
|
|
});
|
|
|
|
|
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public get(): Insurance[]
|
|
|
|
{
|
|
|
|
return this.profileInsuranceFixture;
|
|
|
|
}
|
|
|
|
}
|