Siopas Inventory PETI for ISTW Website
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.8 KiB

1 year ago
<?php
namespace App\Http\Controllers;
use App\Models\User;
use Illuminate\View\View;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\RedirectResponse;
use Illuminate\Support\Facades\Redirect;
use App\Http\Requests\ProfileUpdateRequest;
1 year ago
use App\Http\Requests\UpdatePenggunaRequest;
1 year ago
use Illuminate\Support\Facades\Storage;
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');
}
1 year ago
//Proses update Profile
1 year ago
public function updateprofile(Request $request, $id)
1 year ago
{
1 year ago
$request->validate([
'name' => 'required|string|max:255|min:3|regex:/^[a-zA-Z\s]+$/',
'email' => 'required|email|max:255|min:3',
'phone' => 'required|numeric|digits_between:10,13',
'foto' => 'nullable|image|mimes:jpg,jpeg,png|max:2048',
'tgl_lahir' => 'date',
'jenis_kelamin' => 'required|in:L,P',
'agama' => 'required|in:Islam,Kristen,Katolik,Hindu,Budha,Konghucu',
'alamat' => 'required|string|max:255|min:3',
]);
1 year ago
try {
$pengguna = User::findOrFail($id);
1 year ago
// Handle foto upload if provided
if ($request->hasFile('foto')) {
// Upload and update foto
$fotoPath = $request->file('foto')->store('profile_photos', 'public');
$pengguna->foto = $fotoPath;
}
// Update other fields
$pengguna->name = $request->name;
$pengguna->email = $request->email;
$pengguna->phone = $request->phone;
$pengguna->tgl_lahir = $request->tgl_lahir;
$pengguna->jenis_kelamin = $request->jenis_kelamin;
$pengguna->agama = $request->agama;
$pengguna->alamat = $request->alamat;
$pengguna->save();
return redirect()->back()->with('success', 'Profil pengguna berhasil diperbarui');
1 year ago
} catch (\Throwable $th) {
1 year ago
// Uncomment this line to see the error details
// dd($th);
return redirect()->back()->with('error', 'Data pengguna gagal diubah');
1 year ago
}
}
// {
// // dd('oke');
1 year ago
// $request->validate([
// 'name' => 'required|string|max:255|min:3|regex:/^[a-zA-Z\s]+$/',
// 'email' => 'required|email|max:255|min:3',
// 'phone' => 'required|numeric|digits_between:10,13',
// 'foto' => 'nullable|image|mimes:jpg,jpeg,png|max:2048',
// 'tgl_lahir' => 'date',
// 'jenis_kelamin' => 'required|in:L,P',
// 'agama' => 'required|in:Islam,Kristen,Katolik,Hindu,Budha,Konghucu',
// 'alamat' => 'required|string|max:255|min:3',
// ]);
// // dd($request);
1 year ago
// try {
1 year ago
// $pengguna = User::findOrFail($id);
// $pengguna->update($request->validated());
// return redirect()->back()->with('success', 'Profil pengguna berhasil diperbarui');
1 year ago
// } catch (\Throwable $th) {
1 year ago
// dd($th);
// return redirect()->back()->with('error', 'Data pengguna gagal diubah');
1 year ago
// }
// }
1 year ago
//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
1 year ago
// public function update(ProfileUpdateRequest $request): RedirectResponse
// {
// $request->user()->fill($request->validated());
1 year ago
1 year ago
// if ($request->user()->isDirty('email')) {
// $request->user()->email_verified_at = null;
// }
1 year ago
1 year ago
// $request->user()->save();
1 year ago
1 year ago
// return Redirect::back()->with('status', 'profile-updated');
// }
1 year ago
/**
* Delete the user's account.
*/
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('/');
}
}