Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 8 additions & 2 deletions src/Search/Searchables/Assets.php
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,11 @@ public function provide(): Collection

// TODO: query scope support?

return $assets->filter($this->filter())->values()->map->reference();
if ($filter = $this->filter()) {
$assets = $assets->filter($filter);
}

return $assets->values()->map->reference();
}

public function contains($searchable): bool
Expand All @@ -41,7 +45,9 @@ public function contains($searchable): bool
return false;
}

return $this->filter()($searchable);
return ($filter = $this->filter())
? $filter($searchable)
: true;
}

public function find(array $keys): Collection
Expand Down
17 changes: 6 additions & 11 deletions src/Search/Searchables/Entries.php
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,15 @@ public function provide(): Collection|LazyCollection

$this->applyQueryScope($query);

if ($this->hasFilter()) {
if ($filter = $this->filter()) {
return $query
->lazy(config('statamic.search.chunk_size'))
->filter($this->filter())
->filter($filter)
->values()
->map->reference();
}

$query->where('status', 'published');
$query->whereStatus('published');

return $query->pluck('reference');
}
Expand All @@ -60,12 +60,12 @@ public function contains($searchable): bool
return false;
}

if ($this->hasFilter()) {
return $this->filter()($searchable);
if ($filter = $this->filter()) {
return $filter($searchable);
}

$query = Entry::query()
->where('status', 'published')
->whereStatus('published')
->where('id', $searchable->id());

$this->applyQueryScope($query);
Expand All @@ -77,9 +77,4 @@ public function find(array $ids): Collection
{
return Entry::query()->whereIn('id', $ids)->get();
}

protected function defaultFilter()
{
return fn ($item) => $item->status() === 'published';
}
}
8 changes: 1 addition & 7 deletions src/Search/Searchables/Provider.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
use Statamic\Facades\Search;
use Statamic\Search\Index;
use Statamic\Search\ProvidesSearchables;
use Statamic\Support\Arr;

abstract class Provider implements ProvidesSearchables
{
Expand Down Expand Up @@ -66,11 +65,6 @@ protected function applyQueryScope($query)
Scope::find($scope)->apply($query, []);
}

protected function hasFilter()
{
return Arr::has($this->index->config(), 'filter');
}

protected function filter()
{
$filter = $this->index->config()['filter'] ?? null;
Expand All @@ -84,6 +78,6 @@ protected function filter()

protected function defaultFilter()
{
return fn () => true;
return null;
}
}
8 changes: 4 additions & 4 deletions src/Search/Searchables/Terms.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,10 +34,10 @@ public function provide(): Collection|LazyCollection

$this->applyQueryScope($query);

if ($this->hasFilter()) {
if ($filter = $this->filter()) {
return $query
->lazy(config('statamic.search.chunk_size'))
->filter($this->filter())
->filter($filter)
->values()
->map->reference();
}
Expand All @@ -59,8 +59,8 @@ public function contains($searchable): bool
return false;
}

if ($this->hasFilter()) {
return $this->filter()($searchable);
if ($filter = $this->filter()) {
return $filter($searchable);
}

$query = Term::query()->where('reference', $searchable->reference());
Expand Down
8 changes: 4 additions & 4 deletions src/Search/Searchables/Users.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,10 @@ public function provide(): Collection|LazyCollection

$this->applyQueryScope($query);

if ($this->hasFilter()) {
if ($filter = $this->filter()) {
return $query
->lazy(config('statamic.search.chunk_size'))
->filter($this->filter())
->filter($filter)
->values()
->map->reference();
}
Expand All @@ -42,8 +42,8 @@ public function contains($searchable): bool
return false;
}

if ($this->hasFilter()) {
return $this->filter()($searchable);
if ($filter = $this->filter()) {
return $filter($searchable);
}

$query = User::query()->where('id', $searchable->id());
Expand Down