AssetGroupController.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\AssetGroup\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\AssetGroupResource;
  6. use App\Models\AssetGroup;
  7. use Illuminate\Http\Request;
  8. use Illuminate\Support\Facades\Auth;
  9. class AssetGroupController extends Controller
  10. {
  11. /**
  12. * Display a listing of the resource.
  13. */
  14. public function index(Request $request)
  15. {
  16. $name = $request->input('name');
  17. $groups = AssetGroup::where('name', 'like', "%{$name}%")->orderByDesc("sequence")->get();
  18. return AssetGroupResource::collection($groups);
  19. }
  20. /**
  21. * Store a newly created resource in storage.
  22. */
  23. public function store(CreateOrUpdateRequest $request)
  24. {
  25. AssetGroup::create([
  26. ...$request->all(),
  27. 'company_id' => Auth::user()->company_id,
  28. ]);
  29. return $this->created();
  30. }
  31. /**
  32. * Display the specified resource.
  33. */
  34. public function show(string $id)
  35. {
  36. $asset = AssetGroup::findOrFail($id);
  37. return new AssetGroupResource($asset);
  38. }
  39. /**
  40. * Update the specified resource in storage.
  41. */
  42. public function update(CreateOrUpdateRequest $request, string $id)
  43. {
  44. $group = AssetGroup::query()->findOrFail($id);
  45. $group->fill($request->only(
  46. 'name', 'sequence'
  47. ));
  48. $group->save();
  49. return $this->noContent();
  50. }
  51. /**
  52. * Remove the specified resource from storage.
  53. */
  54. public function destroy(string $id)
  55. {
  56. $group = AssetGroup::query()->findOrFail($id);
  57. if(($group->assets)->isEmpty()){
  58. $group->delete();
  59. }
  60. else{
  61. throw new \Exception("The asset group still has assets associated with it, and cannot be deleted.");
  62. }
  63. return $this->noContent();
  64. }
  65. }