使用自定义字段解析器指令进行分页

时间:2020-03-12 13:36:28

标签: laravel-lighthouse

我要实现的目标如下: 我想要一个查询模型的查询,该查询可能很复杂,因此需要单独的解析器或可以放置逻辑的地方。

出了什么问题: 这是我的查询

fighters(q: String): [FighterProfile] @field(resolver: "App\\Http\\Controllers\\FighterProfileController@search")

这是我的解析器

public function search($rootValue, array $args, GraphQLContext $context, ResolveInfo $resolveInfo) {
    $user = auth()->user();
    $q = isset($args['q']) ? $args['q'] : null;

    $query = FighterProfile::distinct();

    // admin and federation can see all fighters
    if ($user->type === 'member') {
        $fighterProfile = $user->fighterProfile;

        $query->where('club_id', $fighterProfile->club_id);
    }

    if ($q) {
        $query->where(function ($subQuery) use ($q) {
           $subQuery->where('first_name', 'LIKE', '%' . $q . '%')
           ->orWhere('last_name', 'LIKE', '%' . $q . '%');
        });
    }

    $query->where('type', 'fighter');
    return $query->paginate(25);
}

现在输出仅是25个项目的列表,没有分页信息。当我尝试添加@paginate指令时,出现以下错误

Node [fighters] can only have one directive of type [Nuwave\\Lighthouse\\Support\\Contracts\\FieldResolver] but found []

如何添加我的自定义逻辑,但仍然具有分页功能?

1 个答案:

答案 0 :(得分:1)

您不能将@field@paginate组合在一起,但是可以将@paginate@builder组合起来。

如果您仍然需要自定义解析器,则可以创建自己的自定义指令,例如https://lighthouse-php.slack.com/archives/CB28A070S/p1574102072286100?thread_ts=1574101207.285300