RequirementGroupController.php 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\RequirementGroup\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\AssetGroupResource;
  6. use App\Http\Resources\API\RequirementGroupResource;
  7. use App\Models\RequirementGroup;
  8. use Illuminate\Http\Request;
  9. use Illuminate\Support\Facades\Auth;
  10. class RequirementGroupController 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 = RequirementGroup::filter($request->all())->where("parent_id",0)->with(['children','asset'])->paginate($pageSize);
  19. make_display_id($groups,$pageSize);
  20. return RequirementGroupResource::collection($groups);
  21. }
  22. //公共RequirementGroup查询
  23. public function publicSearch(Request $request)
  24. {
  25. $groups = RequirementGroup::filter($request->all())->where("parent_id",0)->with(['children'])->get();
  26. return RequirementGroupResource::collection($groups);
  27. }
  28. /**
  29. * Store a newly created resource in storage.
  30. */
  31. public function store(CreateOrUpdateRequest $request)
  32. {
  33. RequirementGroup::create([
  34. ...$request->all(),
  35. 'company_id' => Auth::user()->company_id,
  36. ]);
  37. return $this->created();
  38. }
  39. /**
  40. * Display the specified resource.
  41. */
  42. public function show(string $id)
  43. {
  44. $groups = RequirementGroup::findOrFail($id);
  45. return new RequirementGroupResource($groups);
  46. }
  47. /**
  48. * Update the specified resource in storage.
  49. */
  50. public function update(CreateOrUpdateRequest $request, string $id)
  51. {
  52. $group = RequirementGroup::query()->findOrFail($id);
  53. $group->fill($request->all());
  54. $group->save();
  55. return $this->noContent();
  56. }
  57. /**
  58. * Remove the specified resource from storage.
  59. */
  60. public function destroy(string $id)
  61. {
  62. $group = RequirementGroup::query()->findOrFail($id);
  63. if(empty($group->children()->first())){
  64. $group->delete();
  65. }
  66. else{
  67. throw new \Exception("Please remove the sub-level requirementGroup");
  68. }
  69. return $this->noContent();
  70. }
  71. }