- Replace is_admin boolean with role enum('super_admin','admin') via migration
- ProgramPolicy: admin program can only view/edit/delete own programs
- EnsureIsAdmin: accepts both roles; EnsureSuperAdmin: super_admin only
- UserController + views: super_admin can manage admin accounts
- Sidebar: user management link & role badge gated on isSuperAdmin()
- Fix Controller base class: add AuthorizesRequests trait
- Fix tests: replace nonAdmin() (invalid enum) with adminProgram() against super_admin-only route
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
78 lines
4.0 KiB
PHP
78 lines
4.0 KiB
PHP
@extends('layouts.admin')
|
|
|
|
@section('title', 'Edit Pengguna — ' . $user->name)
|
|
@section('header', 'Edit Pengguna')
|
|
|
|
@section('breadcrumb')
|
|
<li class="breadcrumb-item"><a href="{{ route('admin.users.index') }}">Pengguna</a></li>
|
|
<li class="breadcrumb-item active">{{ Str::limit($user->name, 30) }}</li>
|
|
@endsection
|
|
|
|
@section('content')
|
|
|
|
<div class="row justify-content-center">
|
|
<div class="col-md-6">
|
|
<div class="card border-0 shadow-sm">
|
|
<div class="card-body p-4">
|
|
<form method="POST" action="{{ route('admin.users.update', $user) }}">
|
|
@csrf @method('PUT')
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label fw-medium">Nama Penuh <span class="text-danger">*</span></label>
|
|
<input type="text" name="name" value="{{ old('name', $user->name) }}"
|
|
class="form-control @error('name') is-invalid @enderror">
|
|
@error('name')<div class="invalid-feedback">{{ $message }}</div>@enderror
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label fw-medium">Emel <span class="text-danger">*</span></label>
|
|
<input type="email" name="email" value="{{ old('email', $user->email) }}"
|
|
class="form-control @error('email') is-invalid @enderror">
|
|
@error('email')<div class="invalid-feedback">{{ $message }}</div>@enderror
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label fw-medium">Peranan <span class="text-danger">*</span></label>
|
|
<select name="role" class="form-select @error('role') is-invalid @enderror"
|
|
{{ $user->id === auth()->id() ? 'disabled' : '' }}>
|
|
<option value="admin" {{ old('role', $user->role) === 'admin' ? 'selected' : '' }}>
|
|
Admin Program
|
|
</option>
|
|
<option value="super_admin" {{ old('role', $user->role) === 'super_admin' ? 'selected' : '' }}>
|
|
Super Admin
|
|
</option>
|
|
</select>
|
|
@if($user->id === auth()->id())
|
|
<input type="hidden" name="role" value="{{ $user->role }}">
|
|
<div class="form-text text-warning"><i class="bi bi-exclamation-circle me-1"></i>Anda tidak boleh tukar peranan akaun sendiri.</div>
|
|
@endif
|
|
@error('role')<div class="invalid-feedback">{{ $message }}</div>@enderror
|
|
</div>
|
|
|
|
<div class="mb-3">
|
|
<label class="form-label fw-medium">Kata Laluan Baru <span class="text-muted small">(kosongkan jika tidak tukar)</span></label>
|
|
<input type="password" name="password"
|
|
class="form-control @error('password') is-invalid @enderror"
|
|
placeholder="Minimum 8 aksara, huruf besar, huruf kecil, nombor">
|
|
@error('password')<div class="invalid-feedback">{{ $message }}</div>@enderror
|
|
</div>
|
|
|
|
<div class="mb-4">
|
|
<label class="form-label fw-medium">Sahkan Kata Laluan Baru</label>
|
|
<input type="password" name="password_confirmation" class="form-control">
|
|
</div>
|
|
|
|
<div class="d-flex gap-2">
|
|
<button type="submit" class="btn btn-primary">
|
|
<i class="bi bi-check-lg me-1"></i> Simpan Perubahan
|
|
</button>
|
|
<a href="{{ route('admin.users.index') }}" class="btn btn-outline-secondary">Batal</a>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
@endsection
|