namest / likeable
v0.1.2
2015-03-01 20:50 UTC
Requires
- illuminate/database: ~5.0
- illuminate/support: ~5.0
Requires (Dev)
- mockery/mockery: ~0.9
- phpunit/phpunit: ~4.5
This package is not auto-updated.
Last update: 2024-11-23 17:36:56 UTC
README
Provide an elegant way to interact with like feature between your eloquent models.
Note: Package only support Laravel 5
Installation
Step 1: Install package
composer require namest/likeable
Step 2: Register service provider in your config/app.php
return [ ... 'providers' => [ ... 'Namest\Likeable\LikeableServiceProvider', ], ... ];
Step 3: Publish package resources, include: configs, migrations. Open your terminal and type:
php artisan vendor:publish --provider="Namest\Likeable\LikeableServiceProvider"
Step 4: Migrate the migration that have been published
php artisan migrate
Step 5: Use some traits to make awesome things
class User extends Model { use \Namest\Likeable\LikerTrait; // ... } class Post extends Model { use \Namest\Likeable\LikeableTrait; // ... }
Step 6: Read API below and start happy
API
$user = \App\User::find(1); $post = \App\Post::find(2); $like = $user->like($post); // Return Namest\Likeable\Like instance $result = $user->unlike($post); // Return true when success and false on otherwise
$user = $like->liker; // Return model that like another model $post = $like->likeable; // Return model that was liked by another model
$posts = $user->likes; // Return likeable collection that liker was liked $users = $post->likers; // Return liker collection who like that post
$users = User::wasLike($post)->...->get(); // Return liker collection who like that post $posts = Post::likedBy($user)->...->get(); // Return post collection which was liked by the user
Events
namest.likeable.liking
When: Before $liker
like a likeable
Payloads:
$liker
: Who do this action$likeable
: Which will be liked
Usage:
\Event::listen('namest.likeable.liking', function ($liker, $likeable) { // Do something });
namest.likeable.liked
When: After $liker
was like a likeable
Payloads:
$liker
: Who do this action$likeable
: Which was liked$like
: Like instance
Usage:
\Event::listen('namest.likeable.liked', function ($liker, $likeable, $like) { // Do something });
namest.likeable.unliking
When: Before $liker
unlike a likeable
Payloads:
$liker
: Who do this action$likeable
: Which will be unliked
Usage:
\Event::listen('namest.likeable.unliking', function ($liker, $likeable) { // Do something });
namest.likeable.unliked
When: After $liker
was unlike a likeable
Payloads:
$liker
: Who do this action$likeable
: Which was unliked
Usage:
\Event::listen('namest.likeable.unliked', function ($liker, $likeable) { // Do something });