diff --git a/src/lib/QueryType/SearchQueryType.php b/src/lib/QueryType/SearchQueryType.php index 7bca8cc..0a205f6 100644 --- a/src/lib/QueryType/SearchQueryType.php +++ b/src/lib/QueryType/SearchQueryType.php @@ -15,6 +15,7 @@ use Ibexa\Contracts\Core\Repository\Values\Content\Query\Aggregation\SectionTermAggregation; use Ibexa\Contracts\Core\Repository\Values\Content\Query\Criterion; use Ibexa\Contracts\Core\Repository\Values\Content\Query\SortClause\ContentId; +use Ibexa\Contracts\Core\Repository\Values\Content\Query\Spellcheck; use Ibexa\Contracts\Core\Repository\Values\User\User; use Ibexa\Contracts\Search\SortingDefinition\SortingDefinitionRegistryInterface; use Ibexa\Core\QueryType\OptionsResolverBasedQueryType; @@ -42,6 +43,10 @@ protected function doGetQuery(array $parameters): Query $query = new Query(); if (null !== $searchData->getQuery()) { $query->query = new Criterion\FullText($searchData->getQuery()); + + if ($this->searchService->supports(SearchService::CAPABILITY_SPELLCHECK)) { + $query->spellcheck = new Spellcheck($searchData->getQuery()); + } } $criteria = $this->buildCriteria($searchData); diff --git a/src/lib/View/SearchViewBuilder.php b/src/lib/View/SearchViewBuilder.php index 702b918..79a22f6 100644 --- a/src/lib/View/SearchViewBuilder.php +++ b/src/lib/View/SearchViewBuilder.php @@ -78,10 +78,13 @@ public function buildView(array $parameters): SearchView $pagerfanta->setMaxPerPage($data->getLimit()); $pagerfanta->setCurrentPage(min($data->getPage(), $pagerfanta->getNbPages())); + $results = $this->pagerSearchContentToDataMapper->map($pagerfanta); + $view->addParameters([ - 'results' => $this->pagerSearchContentToDataMapper->map($pagerfanta), + 'results' => $results, 'pager' => $pagerfanta, 'aggregations' => $adapter->getAggregations(), + 'spellcheck' => $adapter->getSpellcheck(), ]); }