All Projects → francescomalatesta → laravel-reactions

francescomalatesta / laravel-reactions

Licence: MIT license
Implement reactions for your Eloquent models, easily.

Programming Languages

PHP
23972 projects - #3 most used programming language

Projects that are alternatives of or similar to laravel-reactions

ReactButton
Android Library to make it easy to add ReactButton feature in your app with Multi Reactions like Facebook or Linkedin, you can add many reactions as you want, you can also split them into a number of columns, and also customize the colours and text for each reaction
Stars: ✭ 100 (+69.49%)
Mutual labels:  reactions
ReactionDecoder
Reaction Decoder Tool (RDT) - Atom Atom Mapping Tool
Stars: ✭ 59 (+0%)
Mutual labels:  reactions
anime-reaction-api
An API/Slack/Discord Bot to serve image links of anime reactions
Stars: ✭ 25 (-57.63%)
Mutual labels:  reactions
reactions
❤ A Flarum extension that adds reactions to your Flarum Community!
Stars: ✭ 17 (-71.19%)
Mutual labels:  reactions
discord-reaction-role-bot
A Discord bot that allows users to self-assign roles using reactions.
Stars: ✭ 110 (+86.44%)
Mutual labels:  reactions
k-ramel
State manager for your components apps, the safe and easy way
Stars: ✭ 20 (-66.1%)
Mutual labels:  reactions
BrokenDisc
A discord music bot || NO CODING NEEDED!
Stars: ✭ 52 (-11.86%)
Mutual labels:  reactions
RulesBot
A bot for creating rules and give members a role when they accept the rules
Stars: ✭ 13 (-77.97%)
Mutual labels:  reactions
ReactionMechanismSimulator.jl
The amazing Reaction Mechanism Simulator for simulating large chemical kinetic mechanisms
Stars: ✭ 39 (-33.9%)
Mutual labels:  reactions
MAESTRO
A low Mach number stellar hydrodynamics code
Stars: ✭ 29 (-50.85%)
Mutual labels:  reactions
Discord-EmojiToRole
A discord.js bot that assigns roles based on reactions to a message.
Stars: ✭ 55 (-6.78%)
Mutual labels:  reactions
react-reactions
😲 Create custom reaction pickers and counters or use your favorites!
Stars: ✭ 34 (-42.37%)
Mutual labels:  reactions
sourcekarma
Discover how people react to you on GitHub 👍
Stars: ✭ 101 (+71.19%)
Mutual labels:  reactions
reaction-light
Easy to use reaction role Discord bot written in Python.
Stars: ✭ 108 (+83.05%)
Mutual labels:  reactions

Laravel Reactions

Latest Version on Packagist Software License Build Status Quality Score Total Downloads

Laravel Reactions is the package you need if you want to implement reactions for your Eloquent models, in a similar way you can see on Facebook.

Features

  • easy to install, nothing to configure;
  • ready-to-use traits;
  • you can implement reactions for multiple entities, thanks to a polymorphic many to many relationship;
  • you can implement reactions from multiple entities, thanks to some extra magic under the hood;

Disclaimer

This project is not associated with Facebook in any way. I've used the "reactions" just to give an idea of the concept. In case of legal issues, let me know using an email.

Install

Install the package with Composer.

$ composer require francescomalatesta/laravel-reactions

Add the Service Provider to your config/app.php file.

FrancescoMalatesta\LaravelReactions\Providers\ReactionsServiceProvider::class,

Run the migrations to create reactions and reactables tables.

$ php artisan migrate

You're good to go.

Usage

Add Traits to Models

To use the package you need to follow two steps:

  • add the FrancescoMalatesta\LaravelReactions\Traits\Reacts trait to the entity that is going to react to something;
  • add the FrancescoMalatesta\LaravelReactions\Traits\Reactable trait to the entity that is going to "receive" reactions;
  • be sure that the entity that receives reactions also implements the FrancescoMalatesta\LaravelReactions\Contracts\ReactableInterface;

Let's make an example.

Imagine that you have some users in your application. You are building a blog, so you will have posts.

You want to let your user add reactions to your posts. Just like Facebook, you know.

Let's say we have two models: User and Post.

Following the steps, we first add the FrancescoMalatesta\LaravelReactions\Traits\Reacts trait to our User model.

use FrancescoMalatesta\LaravelReactions\Traits\Reacts;

class User extends Model {
    use Reacts;
}

Done! Now, to the Post model!

use FrancescoMalatesta\LaravelReactions\Traits\Reacts;
use FrancescoMalatesta\LaravelReactions\Contracts\ReactableInterface;

class Post extends Model implements ReactableInterface {
    use Reactable;
}

Ta-dah! You're done.

By default, the package ships with a Reaction model. This model has a single, simple property: its name. You can create a new one easily, with

$likeReaction = Reaction::createFromName('like');
$likeReaction->save();

$loveReaction = Reaction::createFromName('love');
$loveReaction->save();

React!

Our models are ready. We can use them. How?

// picking the first user, for this example...
$user = User::first();

// the previously created reaction
$likeReaction = Reaction::where('name', '=', 'like')->first();

// picking up a post...
$awesomePost = Post::first();

// react to it!
$user->reactTo($awesomePost, $likeReaction);

Easy, isn't it? The reactTo method handles everything for you.

Get Reactions for a Model

Just like you can let one of your entities react to another one, you should be able to get all the reactions for an entity.

Let's see how to do it.

// picking up a post...
$awesomePost = Post::first();

// get all reactions
$reactions = $awesomePost->reactions;

In $reactions you will have a collection of Reaction models, ready to be used.

Get a Reactions Summary

Probably you won't need everything about reactions to a specific entity everytime. So, I implemented a getReactionsSummary for you.

// picking up a post...
$awesomePost = Post::first();

// get a summary of related reactions
$reactionsSummary = $awesomePost->getReactionsSummary();

In $reactionsSummary you will find a collection of items, composed by two properties: name and count. Imagine that we do something like the following code in a controller:

$reactionsSummary = $awesomePost->getReactionsSummary();
return $reactionsSummary;

Here's what we will get:

[
    {
        "name": "like",
        "count": 12
    },
    {
        "name": "love",
        "count": 7
    }
]

Accessing the "Responder"

When on Facebook, you can see "who" reacted in some way to a post. To get that who you can use the getResponder method. This works for every reaction you get using the reactions relationship method, of course.

Let's assume that a User named "Francesco" already reacted with the "love" reaction to a post.

// our awesome post.
$awesomePost = Post::first();

// every $reaction is a Reaction model
foreach($awesomePost->reactions as $reaction) 
{
    $user = $reaction->getResponder();
   
    // this will output "Francesco"
    echo $user->name;
}

Change log

Please see CHANGELOG for more information on what has changed recently.

Testing

$ vendor/bin/phpunit

Contributing

Please see CONTRIBUTING and CONDUCT for details.

Security

If you discover any security related issues, please email [email protected] instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].