Refactor user switching logic and update UI
This commit is contained in:
parent
600c43827a
commit
9268f9db1d
@ -15,30 +15,26 @@ class Index extends Component
|
|||||||
if (!isCloud()) {
|
if (!isCloud()) {
|
||||||
return redirect()->route('dashboard');
|
return redirect()->route('dashboard');
|
||||||
}
|
}
|
||||||
if (auth()->user()->id !== 0 && session('adminToken') === null) {
|
if (auth()->user()->id !== 0) {
|
||||||
return redirect()->route('dashboard');
|
return redirect()->route('dashboard');
|
||||||
}
|
}
|
||||||
$this->users = User::whereHas('teams', function ($query) {
|
$this->users = User::whereHas('teams', function ($query) {
|
||||||
$query->whereRelation('subscription', 'stripe_subscription_id', '!=', null);
|
$query->whereRelation('subscription', 'stripe_subscription_id', '!=', null);
|
||||||
})->get();
|
})->get()->filter(function ($user) {
|
||||||
|
return $user->id !== 0;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
public function switchUser(int $user_id)
|
public function switchUser(int $user_id)
|
||||||
{
|
{
|
||||||
$user = User::find($user_id);
|
if (auth()->user()->id !== 0) {
|
||||||
auth()->login($user);
|
return redirect()->route('dashboard');
|
||||||
|
|
||||||
if ($user_id === 0) {
|
|
||||||
Cache::forget('team:0');
|
|
||||||
session()->forget('adminToken');
|
|
||||||
} else {
|
|
||||||
$token_payload = [
|
|
||||||
'valid' => true,
|
|
||||||
];
|
|
||||||
$token = Crypt::encrypt($token_payload);
|
|
||||||
session(['adminToken' => $token]);
|
|
||||||
}
|
}
|
||||||
session()->regenerate();
|
$user = User::find($user_id);
|
||||||
return refreshSession();
|
$team_to_switch_to = $user->teams->first();
|
||||||
|
Cache::forget("team:{$user->id}");
|
||||||
|
auth()->login($user);
|
||||||
|
refreshSession($team_to_switch_to);
|
||||||
|
return redirect(request()->header('Referer'));
|
||||||
}
|
}
|
||||||
public function render()
|
public function render()
|
||||||
{
|
{
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
{{ auth()->user()->name }}
|
{{ auth()->user()->name }}
|
||||||
<h3 class="pt-4">Users</h3>
|
<h3 class="pt-4">Users</h3>
|
||||||
<div class="flex flex-wrap gap-2">
|
<div class="flex flex-wrap gap-2">
|
||||||
<div class="w-96 box" wire:click="switchUser('0')">
|
<div class="text-white cursor-pointer w-96 box-without-bg bg-coollabs-100" wire:click="switchUser('0')">
|
||||||
Root
|
Root
|
||||||
</div>
|
</div>
|
||||||
@foreach ($users as $user)
|
@foreach ($users as $user)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user