From c7fded1d8f46f99a7f024589f4eff36fb80bc5e2 Mon Sep 17 00:00:00 2001 From: pesu98 Date: Mon, 11 May 2026 12:29:41 +0800 Subject: [PATCH] tambah namaste --- app/Http/Controllers/UserController.php | 10 +++++-- app/Models/Role.php | 6 ++++ app/Models/User.php | 6 ++++ ...26_05_11_040641_create_role_user_table.php | 28 +++++++++++++++++++ resources/views/users/edit.blade.php | 19 +++++++++++++ resources/views/welcome.blade.php | 2 +- 6 files changed, 68 insertions(+), 3 deletions(-) create mode 100644 database/migrations/2026_05_11_040641_create_role_user_table.php diff --git a/app/Http/Controllers/UserController.php b/app/Http/Controllers/UserController.php index a6fbeca..cbdc55d 100644 --- a/app/Http/Controllers/UserController.php +++ b/app/Http/Controllers/UserController.php @@ -2,6 +2,7 @@ namespace App\Http\Controllers; +use App\Models\Role; use App\Models\User; use Illuminate\Http\RedirectResponse; use Illuminate\Http\Request; @@ -18,7 +19,9 @@ class UserController extends Controller public function edit(User $user): View { - return view('users.edit', compact('user')); + $roles = Role::orderBy('name')->get(); + + return view('users.edit', compact('user', 'roles')); } public function update(Request $request, User $user): RedirectResponse @@ -26,9 +29,12 @@ class UserController extends Controller $validated = $request->validate([ 'name' => ['required', 'string', 'max:255'], 'email' => ['required', 'email', 'max:255', 'unique:users,email,'.$user->id], + 'roles' => ['nullable', 'array'], + 'roles.*' => ['integer', 'exists:roles,id'], ]); - $user->update($validated); + $user->update(['name' => $validated['name'], 'email' => $validated['email']]); + $user->roles()->sync($validated['roles'] ?? []); return redirect()->route('users.index')->with('success', __('User updated successfully.')); } diff --git a/app/Models/Role.php b/app/Models/Role.php index 01a4676..86b8213 100644 --- a/app/Models/Role.php +++ b/app/Models/Role.php @@ -5,6 +5,7 @@ namespace App\Models; use Database\Factories\RoleFactory; use Illuminate\Database\Eloquent\Factories\HasFactory; use Illuminate\Database\Eloquent\Model; +use Illuminate\Database\Eloquent\Relations\BelongsToMany; class Role extends Model { @@ -12,4 +13,9 @@ class Role extends Model use HasFactory; protected $fillable = ['name']; + + public function users(): BelongsToMany + { + return $this->belongsToMany(User::class); + } } diff --git a/app/Models/User.php b/app/Models/User.php index f6ba1d2..ee6a6d4 100644 --- a/app/Models/User.php +++ b/app/Models/User.php @@ -7,6 +7,7 @@ use Database\Factories\UserFactory; use Illuminate\Database\Eloquent\Attributes\Fillable; use Illuminate\Database\Eloquent\Attributes\Hidden; use Illuminate\Database\Eloquent\Factories\HasFactory; +use Illuminate\Database\Eloquent\Relations\BelongsToMany; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Notifications\Notifiable; @@ -29,4 +30,9 @@ class User extends Authenticatable 'password' => 'hashed', ]; } + + public function roles(): BelongsToMany + { + return $this->belongsToMany(Role::class); + } } diff --git a/database/migrations/2026_05_11_040641_create_role_user_table.php b/database/migrations/2026_05_11_040641_create_role_user_table.php new file mode 100644 index 0000000..bc623bd --- /dev/null +++ b/database/migrations/2026_05_11_040641_create_role_user_table.php @@ -0,0 +1,28 @@ +foreignId('user_id')->constrained()->cascadeOnDelete(); + $table->foreignId('role_id')->constrained()->cascadeOnDelete(); + $table->primary(['user_id', 'role_id']); + }); + } + + /** + * Reverse the migrations. + */ + public function down(): void + { + Schema::dropIfExists('role_user'); + } +}; diff --git a/resources/views/users/edit.blade.php b/resources/views/users/edit.blade.php index 2b56d48..910da9b 100644 --- a/resources/views/users/edit.blade.php +++ b/resources/views/users/edit.blade.php @@ -25,6 +25,25 @@ +
+ +
+ @foreach ($roles as $role) + + @endforeach +
+ +
+