mirror of
https://github.com/HDInnovations/UNIT3D-Community-Edition.git
synced 2026-05-03 08:50:22 -05:00
update: user followers
This commit is contained in:
@@ -14,7 +14,6 @@
|
||||
namespace App\Http\Controllers\User;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\Follow;
|
||||
use App\Models\User;
|
||||
use App\Notifications\NewFollow;
|
||||
use App\Notifications\NewUnfollow;
|
||||
@@ -25,33 +24,40 @@ use Illuminate\Http\Request;
|
||||
*/
|
||||
class FollowController extends Controller
|
||||
{
|
||||
/**
|
||||
* User Followers.
|
||||
*/
|
||||
public function index(string $username): \Illuminate\Contracts\View\Factory|\Illuminate\View\View
|
||||
{
|
||||
$user = User::where('username', '=', $username)->sole();
|
||||
$followers = $user->followers()->orderByPivot('created_at', 'desc')->paginate(25);
|
||||
|
||||
return \view('user.follower.index', [
|
||||
'followers' => $followers,
|
||||
'user' => $user,
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Follow A User.
|
||||
*/
|
||||
public function store(Request $request, string $username): \Illuminate\Http\RedirectResponse
|
||||
{
|
||||
$user = User::where('username', '=', $username)->firstOrFail();
|
||||
$user = User::where('username', '=', $username)->sole();
|
||||
|
||||
if ($request->user()->id == $user->id) {
|
||||
if ($request->user()->id === $user->id) {
|
||||
return \to_route('users.show', ['username' => $user->username])
|
||||
->withErrors(\trans('user.follow-yourself'));
|
||||
}
|
||||
|
||||
if ($request->user()->follows()->following($user->id)->doesntExist()) {
|
||||
$follow = new Follow();
|
||||
$follow->user_id = $request->user()->id;
|
||||
$follow->target_id = $user->id;
|
||||
$follow->save();
|
||||
if ($user->acceptsNotification($request->user(), $user, 'account', 'show_account_follow')) {
|
||||
$user->notify(new NewFollow('user', $request->user(), $user, $follow));
|
||||
}
|
||||
$user->followers()->attach($request->user()->id);
|
||||
|
||||
return \to_route('users.show', ['username' => $user->username])
|
||||
->withSuccess(\sprintf(\trans('user.follow-user'), $user->username));
|
||||
if ($user->acceptsNotification($request->user(), $user, 'account', 'show_account_follow')) {
|
||||
$user->notify(new NewFollow('user', $request->user()));
|
||||
}
|
||||
|
||||
return \to_route('users.show', ['username' => $user->username])
|
||||
->withErrors(\trans('user.follow-already'));
|
||||
->withSuccess(\sprintf(\trans('user.follow-user'), $user->username));
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -59,20 +65,15 @@ class FollowController extends Controller
|
||||
*/
|
||||
public function destroy(Request $request, string $username): \Illuminate\Http\RedirectResponse
|
||||
{
|
||||
$user = User::where('username', '=', $username)->firstOrFail();
|
||||
$user = User::where('username', '=', $username)->sole();
|
||||
|
||||
if ($request->user()->follows()->following($user->id)->exists()) {
|
||||
$follow = $request->user()->follows()->following($user->id)->first();
|
||||
$follow->delete();
|
||||
if ($user->acceptsNotification($request->user(), $user, 'account', 'show_account_unfollow')) {
|
||||
$user->notify(new NewUnfollow('user', $request->user(), $user, $follow));
|
||||
}
|
||||
$user->followers()->detach($request->user()->id);
|
||||
|
||||
return \to_route('users.show', ['username' => $user->username])
|
||||
->withSuccess(\sprintf(\trans('user.follow-revoked'), $user->username));
|
||||
if ($user->acceptsNotification($request->user(), $user, 'account', 'show_account_unfollow')) {
|
||||
$user->notify(new NewUnfollow('user', $request->user()));
|
||||
}
|
||||
|
||||
return \to_route('users.show', ['username' => $user->username])
|
||||
->withErrors(\trans('user.follow-not-to-begin-with'));
|
||||
->withSuccess(\sprintf(\trans('user.follow-revoked'), $user->username));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user