Files
sign/packages/lib/server-only/user/get-monthly-completed-document.ts

36 lines
1.3 KiB
TypeScript
Raw Normal View History

import { DateTime } from 'luxon';
2024-05-29 20:03:51 +10:00
import { kyselyPrisma, sql } from '@documenso/prisma';
2024-05-29 14:47:33 +10:00
import { DocumentStatus } from '@documenso/prisma/client';
export const getCompletedDocumentsMonthly = async () => {
2024-05-29 14:47:33 +10:00
const qb = kyselyPrisma.$kysely
.selectFrom('Document')
2024-05-29 20:03:51 +10:00
.select(({ fn }) => [
fn<Date>('DATE_TRUNC', [sql.lit('MONTH'), 'Document.updatedAt']).as('month'),
2024-05-29 14:47:33 +10:00
fn.count('id').as('count'),
fn
.sum(fn.count('id'))
// Feels like a bug in the Kysely extension but I just can not do this orderBy in a type-safe manner
// eslint-disable-next-line @typescript-eslint/consistent-type-assertions, @typescript-eslint/no-explicit-any
2024-05-29 20:03:51 +10:00
.over((ob) => ob.orderBy(fn('DATE_TRUNC', [sql.lit('MONTH'), 'Document.updatedAt']) as any))
2024-05-29 14:47:33 +10:00
.as('cume_count'),
])
.where(() => sql`"Document"."status" = ${DocumentStatus.COMPLETED}::"DocumentStatus"`)
.groupBy('month')
.orderBy('month', 'desc')
.limit(12);
const result = await qb.execute();
return result.map((row) => ({
month: DateTime.fromJSDate(row.month).toFormat('yyyy-MM'),
count: Number(row.count),
cume_count: Number(row.cume_count),
}));
};
2024-05-29 20:53:50 +10:00
export type GetCompletedDocumentsMonthlyResult = Awaited<
ReturnType<typeof getCompletedDocumentsMonthly>
>;