iceshrimp-legacy/packages/backend/src/server/api/common/generate-muted-note-thread-query.ts
ThatOneCalculator 6b00abf05c
refactor: 🎨 rome
2023-01-12 20:40:33 -08:00

25 lines
732 B
TypeScript

import type { User } from "@/models/entities/user.js";
import { NoteThreadMutings } from "@/models/index.js";
import type { SelectQueryBuilder } from "typeorm";
import { Brackets } from "typeorm";
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 });
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()})`,
);
}),
);
q.setParameters(mutedQuery.getParameters());
}