mirror of
https://github.com/documenso/documenso.git
synced 2025-11-13 00:03:33 +10:00
82 lines
1.6 KiB
TypeScript
82 lines
1.6 KiB
TypeScript
import { prisma } from '@documenso/prisma';
|
|
import { DocumentStatus } from '@documenso/prisma/client';
|
|
|
|
export type SearchDocumentsWithKeywordOptions = {
|
|
query: string;
|
|
userId: number;
|
|
limit?: number;
|
|
};
|
|
|
|
export const searchDocumentsWithKeyword = async ({
|
|
query,
|
|
userId,
|
|
limit = 5,
|
|
}: SearchDocumentsWithKeywordOptions) => {
|
|
const user = await prisma.user.findFirstOrThrow({
|
|
where: {
|
|
id: userId,
|
|
},
|
|
});
|
|
|
|
const documents = await prisma.document.findMany({
|
|
where: {
|
|
OR: [
|
|
{
|
|
title: {
|
|
contains: query,
|
|
mode: 'insensitive',
|
|
},
|
|
userId: userId,
|
|
deletedAt: null,
|
|
},
|
|
{
|
|
Recipient: {
|
|
some: {
|
|
email: {
|
|
contains: query,
|
|
mode: 'insensitive',
|
|
},
|
|
},
|
|
},
|
|
userId: userId,
|
|
deletedAt: null,
|
|
},
|
|
{
|
|
status: DocumentStatus.COMPLETED,
|
|
Recipient: {
|
|
some: {
|
|
email: user.email,
|
|
},
|
|
},
|
|
title: {
|
|
contains: query,
|
|
mode: 'insensitive',
|
|
},
|
|
},
|
|
{
|
|
status: DocumentStatus.PENDING,
|
|
Recipient: {
|
|
some: {
|
|
email: user.email,
|
|
},
|
|
},
|
|
title: {
|
|
contains: query,
|
|
mode: 'insensitive',
|
|
},
|
|
deletedAt: null,
|
|
},
|
|
],
|
|
},
|
|
include: {
|
|
Recipient: true,
|
|
},
|
|
orderBy: {
|
|
createdAt: 'desc',
|
|
},
|
|
take: limit,
|
|
});
|
|
|
|
return documents;
|
|
};
|