66 lines
1.6 KiB
TypeScript
66 lines
1.6 KiB
TypeScript
import { Injectable } from '@nestjs/common';
|
|
import { BaseIndexManager } from 'src/core/modules/domain/usecase/managers/base-index.manager';
|
|
import { TimeGroupEntity } from '../../entities/time-group.entity';
|
|
import { SelectQueryBuilder } from 'typeorm';
|
|
import {
|
|
Param,
|
|
RelationParam,
|
|
} from 'src/core/modules/domain/entities/base-filter.entity';
|
|
|
|
// TODO:
|
|
// Implementasikan filter by start_time, end_timen, dan max_usage_time
|
|
|
|
@Injectable()
|
|
export class IndexPublicTimeGroupManager extends BaseIndexManager<TimeGroupEntity> {
|
|
async prepareData(): Promise<void> {
|
|
return;
|
|
}
|
|
|
|
async beforeProcess(): Promise<void> {
|
|
return;
|
|
}
|
|
|
|
async afterProcess(): Promise<void> {
|
|
return;
|
|
}
|
|
|
|
get relations(): RelationParam {
|
|
return {
|
|
joinRelations: ['items'],
|
|
selectRelations: [],
|
|
countRelations: ['items'],
|
|
};
|
|
}
|
|
|
|
get selects(): string[] {
|
|
return [
|
|
`${this.tableName}.id`,
|
|
`${this.tableName}.status`,
|
|
`${this.tableName}.name`,
|
|
`${this.tableName}.start_time`,
|
|
`${this.tableName}.end_time`,
|
|
`${this.tableName}.max_usage_time`,
|
|
`${this.tableName}.created_at`,
|
|
`${this.tableName}.creator_name`,
|
|
`${this.tableName}.updated_at`,
|
|
`${this.tableName}.editor_name`,
|
|
];
|
|
}
|
|
|
|
get specificFilter(): Param[] {
|
|
return [
|
|
{
|
|
cols: `${this.tableName}.name`,
|
|
data: this.filterParam.names,
|
|
},
|
|
];
|
|
}
|
|
|
|
setQueryFilter(
|
|
queryBuilder: SelectQueryBuilder<TimeGroupEntity>,
|
|
): SelectQueryBuilder<TimeGroupEntity> {
|
|
queryBuilder.andWhere(`items.id is not null`);
|
|
return queryBuilder;
|
|
}
|
|
}
|