craftcodery / laravel-searchable
Searchable trait for Laravel Eloquent models
Installs: 4 673
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 1
Open Issues: 0
pkg:composer/craftcodery/laravel-searchable
Requires
- php: ^8.2
- laravel/framework: ^10.0|^11.0|^12.0
README
This package makes it easy to search your Laravel models.
Installation
You can install the package via composer:
composer require craftcodery/laravel-searchable
Usage
Preparing your models
In order to search through models you'll have to use the Searchable trait and add the toSearchableArray method.
namespace App\Models; use Illuminate\Database\Eloquent\Model; use CraftCodery\Searchable\Searchable; class User extends Model { use Searchable; /** * Get the searchable data array for the model. * * @return array */ public function toSearchableArray() { return [ 'columns' => [ 'users.name' => 60, 'users.email' => 60, 'locations.city' => 40, 'organizations.name' => 40 ], 'joins' => [ 'locations' => [ 'users.location_id', 'locations.id' ], 'organizations' => [ // use commas to join on multiple columns, e.g. where // organizations.id equals primary_org_id OR secondary_or_id 'users.primary_org_id,users.secondary_org_id', 'organizations.id' ] ], 'groupBy' => 'users.id' ]; } }
Searching models
To search your models, just use the search method.
$users = User::search('john')->get();
Configuring search matchers
You can configure the different search matchers and weights given to each used by the package.
php artisan vendor:publish --tag=searchable-config
License
The MIT License (MIT). Please see License File for more information.