AssetGroupController.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  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()
  15. {
  16. $groups = AssetGroup::query()->orderByDesc("sequence")->get();
  17. return AssetGroupResource::collection($groups);
  18. }
  19. /**
  20. * Store a newly created resource in storage.
  21. */
  22. public function store(CreateOrUpdateRequest $request)
  23. {
  24. AssetGroup::create([
  25. ...$request->all(),
  26. 'company_id' => Auth::user()->company_id,
  27. ]);
  28. return $this->created();
  29. }
  30. /**
  31. * Display the specified resource.
  32. */
  33. public function show(string $id)
  34. {
  35. $asset = AssetGroup::findOrFail($id);
  36. return new AssetGroupResource($asset);
  37. }
  38. /**
  39. * Update the specified resource in storage.
  40. */
  41. public function update(CreateOrUpdateRequest $request, string $id)
  42. {
  43. $group = AssetGroup::query()->findOrFail($id);
  44. $group->fill($request->only(
  45. 'name', 'sequence'
  46. ));
  47. $group->save();
  48. return $this->noContent();
  49. }
  50. /**
  51. * Remove the specified resource from storage.
  52. */
  53. public function destroy(string $id)
  54. {
  55. $group = AssetGroup::query()->findOrFail($id);
  56. $group->delete();
  57. return $this->noContent();
  58. }
  59. }