You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
2.6 KiB
PHP
89 lines
2.6 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use Illuminate\Http\Request;
|
|
use App\Models\Category;
|
|
use Illuminate\Validation\Rule;
|
|
|
|
class CategoryController extends Controller
|
|
{
|
|
public function index(Request $request)
|
|
{
|
|
if ($request->q != null) {
|
|
$query = Category::where('name', 'like', '%'.$request->q.'%')
|
|
->orWhere('description', 'like', '%'.$request->q.'%')
|
|
->orderBy('created_at', 'asc')
|
|
->paginate(10);
|
|
} else {
|
|
$query = Category::orderBy('created_at', 'asc')->paginate(10);
|
|
}
|
|
return inertia('Category', [
|
|
'categories' => $query,
|
|
'_search' => $request->q ? $request->q : ''
|
|
]);
|
|
}
|
|
|
|
public function store(Request $request)
|
|
{
|
|
$request->validate([
|
|
'name' => [
|
|
'required',
|
|
'string',
|
|
'max:255',
|
|
Rule::unique('categories', 'name')->where(function ($query) {
|
|
return $query->where('deleted_at', null);
|
|
})
|
|
],
|
|
'description' => 'required|string|max:255',
|
|
'amount' => 'required|numeric|max:999999999|min:1'
|
|
]);
|
|
|
|
$category = Category::create([
|
|
'name' => $request->name,
|
|
'description' => $request->description,
|
|
'default_budget' => $request->amount
|
|
]);
|
|
|
|
$category->budgets()->create([
|
|
'budget' => $request->amount,
|
|
'start_date' => now()->toDateString(),
|
|
'end_date' => null,
|
|
'remain' => $request->amount
|
|
]);
|
|
|
|
return redirect()->route('categories');
|
|
}
|
|
|
|
public function update(Request $request, Category $category)
|
|
{
|
|
$request->validate([
|
|
'name' => 'required|string|max:255',
|
|
'description' => 'required|string|max:255',
|
|
'amount' => 'required|numeric|max:999999999|min:1'
|
|
]);
|
|
|
|
$category->update([
|
|
'name' => $request->name,
|
|
'description' => $request->description,
|
|
'default_budget' => $request->amount,
|
|
]);
|
|
|
|
$budget = $category->budgets()->where('end_date', null)->first();
|
|
$budget->update([
|
|
'budget' => $request->amount,
|
|
'remain' => ($request->amount + $budget->rollover) - ($budget->total_used)
|
|
]);
|
|
|
|
return redirect()->route('categories');
|
|
}
|
|
|
|
public function destroy(Category $category)
|
|
{
|
|
$category->budgets()->delete();
|
|
$category->delete();
|
|
|
|
return redirect()->route('categories');
|
|
}
|
|
}
|