You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
147 lines
4.3 KiB
147 lines
4.3 KiB
<?php |
|
|
|
namespace App\Http\Controllers; |
|
|
|
use App\Models\User; |
|
use Illuminate\View\View; |
|
use Illuminate\Http\Request; |
|
use Illuminate\Support\Facades\Auth; |
|
use Illuminate\Support\Facades\Hash; |
|
use Illuminate\Http\RedirectResponse; |
|
use Illuminate\Support\Facades\Storage; |
|
use Illuminate\Support\Facades\Redirect; |
|
use App\Http\Requests\ProfileUpdateRequest; |
|
use App\Http\Requests\UpdatePenggunaRequest; |
|
|
|
class ProfileController extends Controller |
|
{ |
|
//halaman setting profile |
|
public function setting(Request $request): View |
|
{ |
|
return view('profil.setting', [ |
|
'user' => $request->user(), |
|
]); |
|
} |
|
|
|
// Halaman edit profile |
|
public function edit() |
|
{ |
|
return view('profil.profil'); |
|
} |
|
|
|
//Proses update Profile |
|
public function updateprofile(Request $request, $id) |
|
{ |
|
$request->validate([ |
|
'fullname' => 'required', |
|
'email' => 'required', |
|
'no_hp' => 'required', |
|
'foto' => 'image|mimes:jpeg,png,jpg,gif|max:2048', // Validasi jenis file gambar |
|
'tgl_lahir' => 'required', |
|
'jenis_kelamin' => 'required', |
|
'agama' => 'required', |
|
'address' => 'required', |
|
]); |
|
|
|
try { |
|
$pengguna = User::findOrFail($id); |
|
|
|
// Handle foto upload if provided |
|
if ($request->hasFile('foto')) { |
|
// Hapus foto lama jika ada |
|
if ($pengguna->foto) { |
|
Storage::delete('public/' . $pengguna->foto); |
|
} |
|
|
|
// Upload foto baru |
|
$fotoPath = $request->file('foto')->store('profile_photos', 'public'); |
|
$pengguna->foto = $fotoPath; |
|
} |
|
|
|
// Update other fields |
|
$pengguna->fullname = $request->fullname; |
|
$pengguna->email = $request->email; |
|
$pengguna->no_hp = $request->no_hp; |
|
$pengguna->tgl_lahir = $request->tgl_lahir; |
|
$pengguna->jenis_kelamin = $request->jenis_kelamin; |
|
$pengguna->agama = $request->agama; |
|
$pengguna->address = $request->address; |
|
|
|
$pengguna->save(); |
|
|
|
return redirect()->back()->with('success', 'Profil pengguna berhasil diperbarui'); |
|
} catch (\Throwable $th) { |
|
return redirect()->back()->with('error', 'Data pengguna gagal diubah'); |
|
} |
|
} |
|
|
|
//Proses update Profile Photo |
|
public function updatePhoto(Request $request) |
|
{ |
|
// dd('okr'); |
|
$user = User::find(auth()->user()->id); |
|
if ($request->hasFile('foto')) { |
|
// Mengunggah file foto profil |
|
$file = $request->file('foto'); |
|
$foto = $file->store('profile-fotos'); |
|
$user->update(['foto' => $foto]); |
|
} |
|
|
|
// Logika lain yang diperlukan setelah update foto profil |
|
return redirect()->back()->with('success', 'Foto profil berhasil diperbarui.'); |
|
} |
|
|
|
//Proses update Profile Informasi |
|
public function update(ProfileUpdateRequest $request): RedirectResponse |
|
{ |
|
$request->user()->fill($request->validated()); |
|
|
|
if ($request->user()->isDirty('email')) { |
|
$request->user()->email_verified_at = null; |
|
} |
|
|
|
$request->user()->save(); |
|
|
|
return Redirect::back()->with('status', 'profile-updated'); |
|
} |
|
|
|
/** |
|
* Delete the user's account. |
|
*/ |
|
// public function destroy(Request $request) |
|
// { |
|
// $user = Auth::user(); |
|
|
|
// // Validasi password |
|
// if (!Hash::check($request->password, $user->password)) { |
|
// return back()->withErrors([ |
|
// 'password' => 'The provided password does not match your current password.', |
|
// ]); |
|
// } |
|
|
|
// // Hapus akun |
|
// $user->delete(); |
|
|
|
// // Logout |
|
// Auth::logout(); |
|
|
|
// return redirect('/'); |
|
// } |
|
// public function destroy(Request $request): RedirectResponse |
|
// { |
|
// $request->validateWithBag('userDeletion', [ |
|
// 'password' => ['required', 'current_password'], |
|
// ]); |
|
|
|
// $user = $request->user(); |
|
|
|
// Auth::logout(); |
|
|
|
// $user->delete(); |
|
|
|
// $request->session()->invalidate(); |
|
// $request->session()->regenerateToken(); |
|
|
|
// return Redirect::to('/'); |
|
// } |
|
}
|
|
|