2023-01-13 05:40:33 +01:00
|
|
|
import type { User } from "@/models/entities/user.js";
|
|
|
|
import { NoteThreadMutings } from "@/models/index.js";
|
|
|
|
import type { SelectQueryBuilder } from "typeorm";
|
|
|
|
import { Brackets } from "typeorm";
|
2021-10-31 07:30:22 +01:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
export function generateMutedNoteThreadQuery(
|
|
|
|
q: SelectQueryBuilder<any>,
|
|
|
|
me: { id: User["id"] },
|
|
|
|
) {
|
|
|
|
const mutedQuery = NoteThreadMutings.createQueryBuilder("threadMuted")
|
|
|
|
.select("threadMuted.threadId")
|
|
|
|
.where("threadMuted.userId = :userId", { userId: me.id });
|
2021-10-31 07:30:22 +01:00
|
|
|
|
2023-01-13 05:40:33 +01:00
|
|
|
q.andWhere(`note.id NOT IN (${mutedQuery.getQuery()})`);
|
|
|
|
q.andWhere(
|
|
|
|
new Brackets((qb) => {
|
|
|
|
qb.where("note.threadId IS NULL").orWhere(
|
|
|
|
`note.threadId NOT IN (${mutedQuery.getQuery()})`,
|
|
|
|
);
|
|
|
|
}),
|
|
|
|
);
|
2021-10-31 07:30:22 +01:00
|
|
|
|
|
|
|
q.setParameters(mutedQuery.getParameters());
|
|
|
|
}
|