User bookmark/unbookmark behaviour for Laravel.
It let people express how they feel about the model(documentation/subject/topic).
Require Laravel Bookmark using Composer.
composer require laravel-interaction/bookmark
Publish configuration and migrations
php artisan vendor:publish --tag=bookmark-config
php artisan vendor:publish --tag=bookmark-migrations
Run database migrations.
php artisan migrate
use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Bookmark\Concerns\Bookmarker;
class User extends Model
{
use Bookmarker;
}
use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Bookmark\Concerns\Bookmarkable;
class Channel extends Model
{
use Bookmarkable;
}
use LaravelInteraction\Bookmark\Tests\Models\Channel;
/** @var \LaravelInteraction\Bookmark\Tests\Models\User $user */
/** @var \LaravelInteraction\Bookmark\Tests\Models\Channel $channel */
// Bookmark to Bookmarkable
$user->bookmark($channel);
$user->unbookmark($channel);
$user->toggleBookmark($channel);
// Compare Bookmarkable
$user->hasBookmarked($channel);
$user->hasNotBookmarked($channel);
// Get bookmarked info
$user->bookmarkableBookmarks()->count();
// with type
$user->bookmarkableBookmarks()->withType(Channel::class)->count();
// get bookmarked channels
Channel::query()->whereBookmarkedBy($user)->get();
// get bookmarked channels doesnt bookmarked
Channel::query()->whereNotBookmarkedBy($user)->get();
use LaravelInteraction\Bookmark\Tests\Models\User;
use LaravelInteraction\Bookmark\Tests\Models\Channel;
/** @var \LaravelInteraction\Bookmark\Tests\Models\User $user */
/** @var \LaravelInteraction\Bookmark\Tests\Models\Channel $channel */
// Compare Bookmarker
$channel->isBookmarkedBy($user);
$channel->isNotBookmarkedBy($user);
// Get bookmarkers info
$channel->bookmarkers->each(function (User $user){
echo $user->getKey();
});
$channels = Channel::query()->withCount('bookmarkers')->get();
$channels->each(function (Channel $channel){
echo $channel->bookmarkers()->count(); // 1100
echo $channel->bookmarkers_count; // "1100"
echo $channel->bookmarkersCount(); // 1100
echo $channel->bookmarkersCountForHumans(); // "1.1K"
});
Event | Fired |
---|---|
LaravelInteraction\Bookmark\Events\Bookmarked |
When an object get bookmarked. |
LaravelInteraction\Bookmark\Events\Unbookmarked |
When an object get unbookmarked. |
Laravel Bookmark is an open-sourced software licensed under the MIT license.