<?php
namespace App\Http\Controllers\Admin;
use App\Facades\DataTable;
use App\Http\Controllers\Controller;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Log;
use Illuminate\Validation\Rules;
use Inertia\Inertia;
class UserController extends Controller
{
public function index()
{
$filters = str_replace(
[
'status:verified',
'status:unverified',
'roles:Administrator',
'roles:Author',
'roles:Moderator',
],
[
'email_verified_at:NOT NULL',
'email_verified_at:NULL',
'roles.name:Administrator',
'roles.name:Author',
'roles.name:Moderator',
],
request()->query('filters') ?? []
);
$sort = str_replace(
['name', 'created_at'],
['name', 'created_at'],
request()->query('col')
);
$result = DataTable::query(User::whereIn('role', ['admin', 'operator']))
->searchable(['nama', 'email', 'role'])
->applyFilters($filters)
->allowedFilters([
'email_verified_at:NOT NULL',
'email_verified_at:NULL',
// 'roles.name:Administrator',
// 'roles.name:Author',
// 'roles.name:Moderator',
])
->applySort($sort)
->allowedSorts(['nama', 'email', 'created_at'])
->make()->toArray();
return Inertia::render('Admin/Users/Index', [
'datatable' => $result
]);
}
public function ajaxData($type, Request $request)
{
if ($type == 'provinces') {
$data = DB::table('provinces')->orderBy('name', 'ASC')->get();
} else if ($type == 'regencies') {
$data = DB::table('regencies')->orderBy('name', 'ASC')->where('province_id', $request->province_id)->get();
} else if ($type == 'districts') {
$data = DB::table('districts')->orderBy('name', 'ASC')->where('regency_id', $request->regency_id)->get();
} else if ($type == 'villages') {
$data = DB::table('villages')->orderBy('name', 'ASC')->where('district_id', $request->district_id)->get();
} else {
$data = [];
}
return response()->json($data);
}
public function create()
{
return Inertia::render('Admin/Users/Create');
}
public function store(Request $request)
{
$request->validate([
'nama' => 'required|string|max:255',
'email' => 'required|string|lowercase|email|max:255|unique:' . User::class,
'password' => ['required', 'confirmed', Rules\Password::defaults()],
]);
$user = User::create([
'nama' => $request->nama,
'email' => $request->email,
'password' => Hash::make($request->password),
'role' => $request->role
]);
$user->user_statuses()->create([
'status' => 'active',
'description' => 'menunggu verifikasi dokumen'
]);
return redirect()->route('admin.user.index')->with('success', 'Berhasil menambah user ' . $user->nama);
}
public function edit($id)
{
$user = User::findOrFail($id);
return Inertia::render('Admin/Users/Edit', compact('user'));
}
public function update(Request $request, $id)
{
$request->validate([
'nama' => 'required|string|max:255',
'email' => 'required|string|lowercase|email|max:255|unique:' . User::class . ',id,' . $id,
]);
$user = User::findOrFail($id);
$user->nama = $request->nama;
$user->email = $request->email;
$user->role = $request->role;
if ($request->password != "") {
$request->validate([
'password' => ['required', Rules\Password::defaults()],
]);
$user->password = Hash::make($request->password);
}
$user->save();
return redirect()->route('admin.user.index')->with('success', 'Berhasil mengubah user ' . $user->nama);
}
public function destroy($id)
{
$user = User::findOrFail($id);
DB::beginTransaction();
try {
$user->delete();
DB::commit();
return redirect()->route('admin.user.index')->with('success', 'Berhasil menghapus user ' . $user->nama);
} catch (\Throwable $th) {
//throw $th;
DB::rollBack();
Log::error($th);
return redirect()->route('admin.user.index')->with('error', 'Gagal menghapus user ' . $user->nama);
}
}
}
Anons79 File Manager Version 1.0, Coded By Anons79
Email: [email protected]