Skip to content

Commit

Permalink
Configurable search limit and correct primary key (#11)
Browse files Browse the repository at this point in the history
* set explicit limit using paginate
* use the configured primary key instead of id
  • Loading branch information
kainiklas authored Apr 18, 2024
1 parent a1676d0 commit b15ce01
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 3 deletions.
38 changes: 37 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,43 @@ class ListMyResources extends ListRecords
}
```

The table defined in the resource needs to be `searchable()` as described in the [Filament table docs](https://filamentphp.com/docs/3.x/tables/advanced#searching-records-with-laravel-scout). Making each column searchable is not required anymore, as the content of what is searchable is defined within scout.
The table defined in the resource needs to be `searchable()` as described in the [Filament table docs](https://filamentphp.com/docs/3.x/tables/advanced#searching-records-with-laravel-scout).
Making each column searchable is not required anymore, as the content of what is searchable is defined within scout.

### Increase the number of search results

Depending on the scout engine you may have limitations on how many search results you get back.
This can be adjusted in two places:

#### 1. Search Limit

Add the following `env` variable to adjust the limit of search results:

```
SCOUT_SEARCH_LIMIT=100
```

`100` is the default value within this pagacke.
For example meilisearch has a default limit of `20`.

#### 2. Index Settings (Example for meilisearch)

Within meilisearch there is a default limit of `1000` total hits which is also the upper bound for the search limit.
That means if you want to have more than `1000` search results, you need to adapt both: the search limit and the index settings.
The index settings can be adjusted within `config\scout.php`:

```php
'index-settings' => [
MyClass::class => [
'pagination' => [
'maxTotalHits' => 10000
],
],
],
```

Then run the following command to sync the settings: `php artisan scout:sync-index-settings`


## Global Search

Expand Down
6 changes: 6 additions & 0 deletions config/kainiklas-filament-scout.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
<?php

// config for Kainiklas/FilamentScout
return [
'scout_search_limit' => env('SCOUT_SEARCH_LIMIT', 100),
];
2 changes: 2 additions & 0 deletions src/FilamentScoutServiceProvider.php
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,8 @@ public function configurePackage(Package $package): void
$command
->askToStarRepoOnGitHub('kainiklas/filament-scout');
});

$package->hasConfigFile();
}

public function packageRegistered(): void
Expand Down
12 changes: 10 additions & 2 deletions src/Traits/InteractsWithScout.php
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,16 @@ protected function applySearchToTableQuery(Builder $query): Builder
return $query;
}

$keys = $this->getModel()::search($search)->keys();
$searchLimit = config('kainiklas-filament-scout.scout_search_limit');
$primaryKeyName = app($this->getModel())->getKeyName();

return $query->whereIn('id', $keys);
$keys = $this->getModel()::search($search)
->query(function ($query) use ($primaryKeyName) {
$query->select($primaryKeyName);
})
->paginate($searchLimit, page: 1) // stick with first page, pagination is done later by filament
->pluck($primaryKeyName);

return $query->whereIn($primaryKeyName, $keys);
}
}

0 comments on commit b15ce01

Please sign in to comment.