zing/laravel-vote

该包已被废弃,不再维护。作者建议使用laravel-interaction/vote包。

Laravel的用户点赞/踩行为。

3.3.0 2024-03-18 14:48 UTC

README

Laravel的用户点赞/踩行为。

Latest Stable Version Total Downloads Latest Unstable Version License

简介

允许人们表达他们对模型(文档/答案/问题)的感受,这个模型是否有帮助/有用。

安装

要求

说明

使用Composer安装Laravel Vote。

composer require laravel-interaction/vote

发布配置和迁移

php artisan vendor:publish --tag=vote-config
php artisan vendor:publish --tag=vote-migrations

运行数据库迁移。

php artisan migrate

使用方法

设置投票者

use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Vote\Concerns\Voter;

class User extends Model
{
    use Voter;
}

设置可投票对象

use Illuminate\Database\Eloquent\Model;
use LaravelInteraction\Vote\Concerns\Voteable;

class Channel extends Model
{
    use Voteable;
}

投票者

use LaravelInteraction\Vote\Tests\Models\Channel;
/** @var \LaravelInteraction\Vote\Tests\Models\User $user */
/** @var \LaravelInteraction\Vote\Tests\Models\Channel $channel */
// Vote to Voteable
$user->vote($channel);
$user->upvote($channel);
$user->downvote($channel);
$user->cancelVote($channel);

// Compare Voteable
$user->hasVoted($channel);
$user->hasNotVoted($channel);
$user->hasUpvoted($channel);
$user->hasNotUpvoted($channel);
$user->hasDownvoted($channel);
$user->hasNotDownvoted($channel);

// Get voted info
$user->voterVotes()->count(); 

// with type
$user->voterVotes()->withType(Channel::class)->count(); 
$user->votedChannels()->count();
$user->upvotedChannels()->count();
$user->downvotedChannels()->count();

// get voted channels
Channel::query()->whereVotedBy($user)->get();
Channel::query()->whereUpvotedBy($user)->get();
Channel::query()->whereDownvotedBy($user)->get();

// get voted channels doesnt voted
Channel::query()->whereNotVotedBy($user)->get();
Channel::query()->whereNotUpvotedBy($user)->get();
Channel::query()->whereNotDownvotedBy($user)->get();

可投票对象

use LaravelInteraction\Vote\Tests\Models\User;
use LaravelInteraction\Vote\Tests\Models\Channel;
/** @var \LaravelInteraction\Vote\Tests\Models\User $user */
/** @var \LaravelInteraction\Vote\Tests\Models\Channel $channel */
// Compare Voter
$channel->isVotedBy($user); 
$channel->isNotVotedBy($user);
$channel->isUpvotedBy($user); 
$channel->isNotUpvotedBy($user);
$channel->isDownvotedBy($user); 
$channel->isNotDownvotedBy($user);
// Get voters info
$channel->voters->each(function (User $user){
    echo $user->getKey();
});
$channel->upvoters->each(function (User $user){
    echo $user->getKey();
});
$channel->downvoters->each(function (User $user){
    echo $user->getKey();
});

$channels = Channel::query()->withCount('voters')->get();
$channels->each(function (Channel $channel){
    echo $channel->voters()->count(); // 1100
    echo $channel->voters_count; // "1100"
    echo $channel->votersCount(); // 1100
    echo $channel->votersCountForHumans(); // "1.1K"
    echo $channel->upvoters()->count(); // 1100
    echo $channel->upvoters_count; // "1100"
    echo $channel->upvotersCount(); // 1100
    echo $channel->upvotersCountForHumans(); // "1.1K"
    echo $channel->downvoters()->count(); // 1100
    echo $channel->downvoters_count; // "1100"
    echo $channel->downvotersCount(); // 1100
    echo $channel->downvotersCountForHumans(); // "1.1K"
});

事件

事件 触发
LaravelInteraction\Vote\Events\Voted 当一个对象被投票/点赞/踩时。
LaravelInteraction\Vote\Events\VoteCanceled 当一个对象的投票被取消时。

许可证

Laravel Vote是一个开源软件,根据MIT许可证授权。