mirror of
https://github.com/hotomoe/hotomoe
synced 2025-01-06 18:02:58 +09:00
29 lines
1.2 KiB
TypeScript
29 lines
1.2 KiB
TypeScript
|
import { SelectQueryBuilder } from 'typeorm';
|
||
|
|
||
|
export function makePaginationQuery<T>(q: SelectQueryBuilder<T>, sinceId: string, untilId: string, sinceDate?: number, untilDate?: number) {
|
||
|
if (sinceId && untilId) {
|
||
|
q.andWhere(`${q.alias}.id > :sinceId`, { sinceId: sinceId });
|
||
|
q.andWhere(`${q.alias}.id < :untilId`, { untilId: untilId });
|
||
|
q.orderBy(`${q.alias}.id`, 'DESC');
|
||
|
} else if (sinceId) {
|
||
|
q.andWhere(`${q.alias}.id > :sinceId`, { sinceId: sinceId });
|
||
|
q.orderBy(`${q.alias}.id`, 'ASC');
|
||
|
} else if (untilId) {
|
||
|
q.andWhere(`${q.alias}.id < :untilId`, { untilId: untilId });
|
||
|
q.orderBy(`${q.alias}.id`, 'DESC');
|
||
|
} else if (sinceDate && untilDate) {
|
||
|
q.andWhere(`${q.alias}.createdAt > :sinceDate`, { sinceDate: new Date(sinceDate) });
|
||
|
q.andWhere(`${q.alias}.createdAt < :untilDate`, { untilDate: new Date(untilDate) });
|
||
|
q.orderBy(`${q.alias}.createdAt`, 'DESC');
|
||
|
} else if (sinceDate) {
|
||
|
q.andWhere(`${q.alias}.createdAt > :sinceDate`, { sinceDate: new Date(sinceDate) });
|
||
|
q.orderBy(`${q.alias}.createdAt`, 'ASC');
|
||
|
} else if (untilDate) {
|
||
|
q.andWhere(`${q.alias}.createdAt < :untilDate`, { untilDate: new Date(untilDate) });
|
||
|
q.orderBy(`${q.alias}.createdAt`, 'DESC');
|
||
|
} else {
|
||
|
q.orderBy(`${q.alias}.id`, 'DESC');
|
||
|
}
|
||
|
return q;
|
||
|
}
|