2018-10-26 06:41:20 +03:00
|
|
|
import { Case } from "./entities/Case";
|
|
|
|
import { CaseNote } from "./entities/CaseNote";
|
|
|
|
import { BaseRepository } from "./BaseRepository";
|
|
|
|
import { getRepository, In, Repository } from "typeorm";
|
2019-01-15 04:15:22 +02:00
|
|
|
import { disableLinkPreviews } from "../utils";
|
|
|
|
import { CaseTypes } from "./CaseTypes";
|
|
|
|
|
|
|
|
const CASE_SUMMARY_REASON_MAX_LENGTH = 300;
|
2018-07-12 02:53:26 +03:00
|
|
|
|
2018-10-26 06:41:20 +03:00
|
|
|
export class GuildCases extends BaseRepository {
|
|
|
|
private cases: Repository<Case>;
|
|
|
|
private caseNotes: Repository<CaseNote>;
|
2018-07-12 02:53:26 +03:00
|
|
|
|
|
|
|
constructor(guildId) {
|
2018-10-26 06:41:20 +03:00
|
|
|
super(guildId);
|
|
|
|
this.cases = getRepository(Case);
|
|
|
|
this.caseNotes = getRepository(CaseNote);
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
|
|
|
|
2018-08-05 00:18:50 +03:00
|
|
|
async get(ids: number[]): Promise<Case[]> {
|
2018-10-26 06:41:20 +03:00
|
|
|
return this.cases.find({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
2019-02-17 15:23:40 +02:00
|
|
|
id: In(ids),
|
|
|
|
},
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
2018-08-05 00:18:50 +03:00
|
|
|
}
|
|
|
|
|
2018-07-12 02:53:26 +03:00
|
|
|
async find(id: number): Promise<Case> {
|
2018-10-26 06:41:20 +03:00
|
|
|
return this.cases.findOne({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
2019-02-17 15:23:40 +02:00
|
|
|
id,
|
|
|
|
},
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
async findByCaseNumber(caseNumber: number): Promise<Case> {
|
2018-10-26 06:41:20 +03:00
|
|
|
return this.cases.findOne({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
2019-02-17 15:23:40 +02:00
|
|
|
case_number: caseNumber,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
async findLatestByModId(modId: string): Promise<Case> {
|
|
|
|
return this.cases.findOne({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
|
|
|
mod_id: modId,
|
|
|
|
},
|
|
|
|
order: {
|
|
|
|
case_number: "DESC",
|
|
|
|
},
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
async getByUserId(userId: string): Promise<Case[]> {
|
2018-10-26 06:41:20 +03:00
|
|
|
return this.cases.find({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
2019-02-17 15:23:40 +02:00
|
|
|
user_id: userId,
|
|
|
|
},
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
2018-08-02 00:51:25 +03:00
|
|
|
}
|
|
|
|
|
2019-02-23 21:33:57 +02:00
|
|
|
async getRecent(count: number): Promise<Case[]> {
|
|
|
|
return this.cases.find({
|
|
|
|
relations: this.getRelations(),
|
|
|
|
where: {
|
|
|
|
guild_id: this.guildId,
|
|
|
|
is_hidden: 0,
|
|
|
|
},
|
|
|
|
take: count,
|
|
|
|
order: {
|
|
|
|
case_number: "DESC",
|
|
|
|
},
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-01-13 17:56:14 +02:00
|
|
|
async setHidden(id: number, hidden: boolean): Promise<void> {
|
|
|
|
await this.cases.update(
|
|
|
|
{ id },
|
|
|
|
{
|
2019-02-17 15:23:40 +02:00
|
|
|
is_hidden: hidden,
|
|
|
|
},
|
2019-01-13 17:56:14 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2018-11-25 17:04:26 +02:00
|
|
|
async create(data): Promise<Case> {
|
2018-10-26 06:41:20 +03:00
|
|
|
const result = await this.cases.insert({
|
|
|
|
...data,
|
|
|
|
guild_id: this.guildId,
|
2019-02-17 15:23:40 +02:00
|
|
|
case_number: () => `(SELECT IFNULL(MAX(case_number)+1, 1) FROM cases AS ma2 WHERE guild_id = ${this.guildId})`,
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
|
|
|
|
2018-11-25 17:04:26 +02:00
|
|
|
return this.find(result.identifiers[0].id);
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
update(id, data) {
|
2018-10-26 06:41:20 +03:00
|
|
|
return this.cases.update(id, data);
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
|
|
|
|
2018-11-25 17:04:26 +02:00
|
|
|
async createNote(caseId: number, data: any): Promise<void> {
|
|
|
|
await this.caseNotes.insert({
|
2018-10-26 06:41:20 +03:00
|
|
|
...data,
|
2019-02-17 15:23:40 +02:00
|
|
|
case_id: caseId,
|
2018-10-26 06:41:20 +03:00
|
|
|
});
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|
2019-01-15 04:15:22 +02:00
|
|
|
|
|
|
|
getSummaryText(theCase: Case) {
|
|
|
|
const firstNote = theCase.notes[0];
|
|
|
|
let reason = firstNote ? firstNote.body : "";
|
|
|
|
|
|
|
|
if (reason.length > CASE_SUMMARY_REASON_MAX_LENGTH) {
|
|
|
|
const match = reason.slice(CASE_SUMMARY_REASON_MAX_LENGTH, 100).match(/(?:[.,!?\s]|$)/);
|
|
|
|
const nextWhitespaceIndex = match ? CASE_SUMMARY_REASON_MAX_LENGTH + match.index : CASE_SUMMARY_REASON_MAX_LENGTH;
|
|
|
|
if (nextWhitespaceIndex < reason.length) {
|
|
|
|
reason = reason.slice(0, nextWhitespaceIndex - 1) + "...";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
reason = disableLinkPreviews(reason);
|
|
|
|
|
|
|
|
let line = `Case \`#${theCase.case_number}\` __${CaseTypes[theCase.type]}__ ${reason}`;
|
|
|
|
if (theCase.notes.length > 1) {
|
|
|
|
line += ` *(+${theCase.notes.length - 1} ${theCase.notes.length === 2 ? "note" : "notes"})*`;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (theCase.is_hidden) {
|
|
|
|
line += " *(hidden)*";
|
|
|
|
}
|
|
|
|
|
|
|
|
return line;
|
|
|
|
}
|
2018-07-12 02:53:26 +03:00
|
|
|
}
|