AssetGroupController.php 2.2 KB

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