2023-03-03 16:23:46 +01:00
|
|
|
import { inject, injectable } from "tsyringe";
|
|
|
|
|
2023-10-19 19:21:17 +02:00
|
|
|
import { ItemHelper } from "@spt-aki/helpers/ItemHelper";
|
|
|
|
import { NotificationSendHelper } from "@spt-aki/helpers/NotificationSendHelper";
|
|
|
|
import { NotifierHelper } from "@spt-aki/helpers/NotifierHelper";
|
|
|
|
import { Item } from "@spt-aki/models/eft/common/tables/IItem";
|
2024-02-02 19:54:07 +01:00
|
|
|
import { Dialogue, MessagePreview } from "@spt-aki/models/eft/profile/IAkiProfile";
|
2023-10-19 19:21:17 +02:00
|
|
|
import { ILogger } from "@spt-aki/models/spt/utils/ILogger";
|
|
|
|
import { DatabaseServer } from "@spt-aki/servers/DatabaseServer";
|
|
|
|
import { SaveServer } from "@spt-aki/servers/SaveServer";
|
|
|
|
import { LocalisationService } from "@spt-aki/services/LocalisationService";
|
|
|
|
import { HashUtil } from "@spt-aki/utils/HashUtil";
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
@injectable()
|
|
|
|
export class DialogueHelper
|
|
|
|
{
|
|
|
|
constructor(
|
|
|
|
@inject("WinstonLogger") protected logger: ILogger,
|
|
|
|
@inject("HashUtil") protected hashUtil: HashUtil,
|
|
|
|
@inject("SaveServer") protected saveServer: SaveServer,
|
|
|
|
@inject("DatabaseServer") protected databaseServer: DatabaseServer,
|
|
|
|
@inject("NotifierHelper") protected notifierHelper: NotifierHelper,
|
|
|
|
@inject("NotificationSendHelper") protected notificationSendHelper: NotificationSendHelper,
|
|
|
|
@inject("LocalisationService") protected localisationService: LocalisationService,
|
2023-11-16 02:35:05 +01:00
|
|
|
@inject("ItemHelper") protected itemHelper: ItemHelper,
|
2023-03-03 16:23:46 +01:00
|
|
|
)
|
2023-11-16 02:35:05 +01:00
|
|
|
{}
|
2023-03-03 16:23:46 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the preview contents of the last message in a dialogue.
|
2023-11-16 02:35:05 +01:00
|
|
|
* @param dialogue
|
2023-03-07 23:25:23 +01:00
|
|
|
* @returns MessagePreview
|
2023-03-03 16:23:46 +01:00
|
|
|
*/
|
|
|
|
public getMessagePreview(dialogue: Dialogue): MessagePreview
|
|
|
|
{
|
|
|
|
// The last message of the dialogue should be shown on the preview.
|
|
|
|
const message = dialogue.messages[dialogue.messages.length - 1];
|
2023-03-07 23:25:23 +01:00
|
|
|
const result: MessagePreview = {
|
2023-07-15 16:01:23 +02:00
|
|
|
dt: message?.dt,
|
|
|
|
type: message?.type,
|
|
|
|
templateId: message?.templateId,
|
2023-11-16 02:35:05 +01:00
|
|
|
uid: dialogue._id,
|
2023-03-03 16:23:46 +01:00
|
|
|
};
|
2023-03-07 23:25:23 +01:00
|
|
|
|
2023-07-15 16:01:23 +02:00
|
|
|
if (message?.text)
|
2023-03-07 23:25:23 +01:00
|
|
|
{
|
|
|
|
result.text = message.text;
|
|
|
|
}
|
|
|
|
|
2023-07-15 16:01:23 +02:00
|
|
|
if (message?.systemData)
|
2023-03-07 23:25:23 +01:00
|
|
|
{
|
|
|
|
result.systemData = message.systemData;
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the item contents for a particular message.
|
2023-11-16 02:35:05 +01:00
|
|
|
* @param messageID
|
|
|
|
* @param sessionID
|
2023-03-03 16:23:46 +01:00
|
|
|
* @param itemId Item being moved to inventory
|
2023-11-16 02:35:05 +01:00
|
|
|
* @returns
|
2023-03-03 16:23:46 +01:00
|
|
|
*/
|
|
|
|
public getMessageItemContents(messageID: string, sessionID: string, itemId: string): Item[]
|
|
|
|
{
|
|
|
|
const dialogueData = this.saveServer.getProfile(sessionID).dialogues;
|
|
|
|
for (const dialogueId in dialogueData)
|
|
|
|
{
|
2023-11-16 02:35:05 +01:00
|
|
|
const message = dialogueData[dialogueId].messages.find((x) => x._id === messageID);
|
2023-03-03 16:23:46 +01:00
|
|
|
if (!message)
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (message._id === messageID)
|
|
|
|
{
|
|
|
|
const attachmentsNew = this.saveServer.getProfile(sessionID).dialogues[dialogueId].attachmentsNew;
|
|
|
|
if (attachmentsNew > 0)
|
|
|
|
{
|
|
|
|
this.saveServer.getProfile(sessionID).dialogues[dialogueId].attachmentsNew = attachmentsNew - 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Check reward count when item being moved isn't in reward list
|
2023-11-27 19:24:02 +01:00
|
|
|
// If count is 0, it means after this move occurs the reward array will be empty and all rewards collected
|
|
|
|
if (!message.items.data)
|
|
|
|
{
|
|
|
|
message.items.data = [];
|
|
|
|
}
|
|
|
|
|
2023-11-26 23:53:09 +01:00
|
|
|
const rewardItemCount = message.items.data?.filter((item) => item._id !== itemId);
|
2023-03-03 16:23:46 +01:00
|
|
|
if (rewardItemCount.length === 0)
|
|
|
|
{
|
|
|
|
message.rewardCollected = true;
|
2023-10-10 13:03:20 +02:00
|
|
|
message.hasRewards = false;
|
2023-03-03 16:23:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return message.items.data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return [];
|
|
|
|
}
|
2023-08-03 13:25:09 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the dialogs dictionary for a profile, create if doesnt exist
|
|
|
|
* @param sessionId Session/player id
|
|
|
|
* @returns Dialog dictionary
|
|
|
|
*/
|
|
|
|
public getDialogsForProfile(sessionId: string): Record<string, Dialogue>
|
|
|
|
{
|
|
|
|
const profile = this.saveServer.getProfile(sessionId);
|
|
|
|
if (!profile.dialogues)
|
|
|
|
{
|
|
|
|
profile.dialogues = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
return profile.dialogues;
|
|
|
|
}
|
2023-11-16 02:35:05 +01:00
|
|
|
}
|