Mat*_*tis 1 pagination typescript typeorm typegraphql
我想使用TypeORM的findAndCount
函数返回Promise<[Entity[], number]>
分页。所以我有一个解析器:
offers(@Arg('page', { defaultValue: 1 }) page: number): Promise<[Offer[], number]> {
const COUNT = 10
return this.offerRepository.findAndCount({ take: COUNT, skip: (page - 1) * COUNT })
}
Run Code Online (Sandbox Code Playgroud)
我也在使用type-graphql并想用这样的Query
注释来注释这个解析器:
@Query(returns => ???)
Run Code Online (Sandbox Code Playgroud)
但是我无法弄清楚返回类型,我尝试了这个(这当然不起作用,因为findAndCount
返回的是什么):
@ObjectType()
class TestType {
@Field(type => [Offer])
offers: Offer[]
@Field()
count: number
}
Run Code Online (Sandbox Code Playgroud)
并尝试像这样使用它:@Query(returns => [TestType])
和 this @Query(returns => TestType)
。
GraphQL 不支持元组,因此您需要创建一个响应对象类型:
@ObjectType()
class OffersResponse {
@Field(type => [Offer])
items: Offer[]
@Field(type => Int)
totalCount: number
}
Run Code Online (Sandbox Code Playgroud)
然后手动将元组映射到对象:
@Query(returns => OffersResponse)
offers(@Arg('page', { defaultValue: 1 }) page: number): Promise<OffersResponse> {
const COUNT = 10
const [items, totalCount] = await this.offerRepository.findAndCount(
{ take: COUNT, skip: (page - 1) * COUNT }
)
return { items, totalCount }
}
Run Code Online (Sandbox Code Playgroud)