- Description
- Installation
- Install with Composer
- Add service provider to App
- Add facade alias to App
- Publish vendor with Artisan
- Tables details
- Make migration with Artisan
- Usage
- Groups
- Create, Delete, Update, Users list, Add member, Join request, Accept join, Decline join, Join request list
- Posts
- Create, Get, Update, Delete, Add to group, Group posts list, User posts list
- Comments
- Add, Get, Update, Delete
- Reporting
- Report, Remove, Toggle , Count
- Likes
- Like, Unlike, Toggle, Count
- Groups
This package allows you to add user groups (groups, comment, like ...) system to your Laravel 5 application.
- Via Composer, from the command line, run :
composer require musonza/groups- Add the service provider to
./config/app.phpinprovidersarray, like :
/*
* Package Service Providers...
*/
Musonza\Groups\GroupsServiceProvider::class,- You can use the facade for shorter code.
Add this to
./config/app.phpat the end ofaliasesarray :
'Groups' => Musonza\Groups\Facades\GroupsFacade::class,Note : The class is bound to the ioC as Groups.
$groups = App::make('Groups');- From the command line, publish the assets:
php artisan vendor:publishNote : This will publish database migrations in
./database/migrations/.
create_groups_table // main groups table
id
name
description
short_description
image
url
user_id
private
conversation_id
extra_info
settings
# Usage
## Groups
1. ##### Create a group
```php
$group = Groups::create($userId, $data);
Note : Accepted fields in $data array :
$data = [
'name' => '',
'description' => '', // optional
'short_description' => '', // optional
'image' => '', // optional
'private' => 0, // 0 (public) or 1 (private)
'extra_info' => '', // optional
'settings' => '', // optional
'conversation_id' => 0, // optional if you want to add messaging to your groups this can be useful
];$group->delete();$group->update($updateArray);$user = Groups::getUser($userId); $group->addMembers([$userId, $userId2, ...]);$group->request($userId);$group->acceptRequest($userId);$group->declineRequest($userId);$requests = $group->requests;$user = Groups::getUser($userId);
$count = $user->groups->count();$group->leave([$userId, $userId2, ...]);$post = Groups::createPost($data);Note : Acceptable values for Post $data array
$data = [
'title' => '',
'user_id' => 0,
'body' => '',
'type' => '',
'extra_info' => '',
];$post = Groups::post($postId);$post->update($data);$post->delete();$group->attachPost($postId);$group->attachPost([$postId, $postId2, ...]);$group->detachPost($postId);$posts = $group->posts;
$posts = $group->posts()->paginate(5);
$posts = $group->posts()->orderBy('id', 'DESC')->paginate(5);$user = Groups::getUser($userId);
$posts = $user->posts;Note : Acceptable values for Comment $data array
$data = [
'post_id' => 0,
'user_id' => 0,
'body' => '',
];$comment = Groups::addComment($data);$comment = Groups::comment($commentId);
$comment->update($data);$comment->delete();$comment->report($userIdOfReporter);
$post->report($userIdOfReporter);$post->removeReport($userId);
$comment->removeReport($userId);$post->toggleReport($userId);
$comment->toggleReport($userId);$commentReports = $comment->reportsCount;
$postReports = $post->reportsCount;$post->like($userId);
$comment->like($userId);$post->unlike($userId);
$comment->unlike($userId);$post->toggleLike($userId);
$comment->toggleLike($userId);$postLikes = $post->likesCount;
$commentLikes = $comment->likesCount;