PlanController.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Plan\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\PlanByAssetResource;
  6. use App\Http\Resources\API\PlanResource;
  7. use App\Models\Asset;
  8. use App\Models\Enums\FileObjectType;
  9. use App\Models\Plan;
  10. use App\Services\File\FileAssociationService;
  11. use Illuminate\Http\Request;
  12. use Illuminate\Support\Facades\Auth;
  13. class PlanController extends Controller
  14. {
  15. /**
  16. * Display a listing of the resource.
  17. */
  18. public function index(Request $request)
  19. {
  20. $sort=$request->input('sort','desc');
  21. $pageSize=$request->get('page_size') ?? 10;
  22. $plan=Plan::filter($request->all())->allowed()->orderBy('created_at',$sort)->paginate($pageSize);
  23. $planTree=$plan->each(function ($plan){
  24. $plan->asset_name= $plan->asset ? $plan->asset->name : null;
  25. $plan->requirement_total = $plan->requirements()->count();
  26. $plan->project_total = $plan->projects()->count();
  27. });
  28. $planTree=!empty(make_tree($planTree->toArray()))?make_tree($planTree->toArray()):$planTree->toArray();
  29. return $this->success([
  30. 'data' => $planTree,
  31. 'total'=>$plan->total()
  32. ]);
  33. // $plans = Plan::filter($request->all())->where("parent_id", 0)->orderBy('created_at',$sort)->with(['children','asset'=>function($query){
  34. // $query->with('parent');
  35. // }])->paginate($pageSize);
  36. //
  37. // return PlanResource::collection($plans);
  38. }
  39. public function byAssets(Request $request)
  40. {
  41. $assetIds = $request->get("assets", []);
  42. $emptyResponse = $this->success(['data' => []]);
  43. if (! $assetIds) {
  44. return $emptyResponse;
  45. }
  46. $assets = Asset::query()->allowed()->where(function ($query) use ($assetIds) {
  47. foreach ($assetIds as $index => $assetId) {
  48. $where = $index == 0 ? "where" : "orWhere";
  49. $query->$where("path", "like", "%,". $assetId . ",%");
  50. }
  51. })->pluck("id");
  52. if ($assets->isEmpty()) {
  53. return $emptyResponse;
  54. }
  55. $plans = Plan::query()->allowed()->with(['asset'])->whereIn("asset_id", $assets->toArray())->get();
  56. return PlanByAssetResource::collection($plans);
  57. }
  58. /**
  59. * Store a newly created resource in storage.
  60. */
  61. public function store(FileAssociationService $service, CreateOrUpdateRequest $request)
  62. {
  63. $plan = new Plan();
  64. $plan->mergeFillable([
  65. 'company_id'
  66. ]);
  67. $service->check(
  68. $request->get("file_ids", []),
  69. FileObjectType::PLAN,
  70. $request->get("file_uuid"),
  71. );
  72. $plan->fill([
  73. ...$request->all(),
  74. 'company_id' => Auth::user()->company_id,
  75. 'description' => $request->description? (new \App\Services\File\ImageUrlService)->interceptImageUrl($request->description) : null,
  76. ]);
  77. $plan->save();
  78. $service->association($plan->id);
  79. return $this->created();
  80. }
  81. /**
  82. * Display the specified resource.
  83. */
  84. public function show(string $id)
  85. {
  86. $plan = Plan::allowed()->findOrFail($id);
  87. return new PlanResource($plan);
  88. }
  89. /**
  90. * Update the specified resource in storage.
  91. */
  92. public function update(CreateOrUpdateRequest $request, string $id)
  93. {
  94. $plan = Plan::allowed()->findOrFail($id);
  95. $plan->fill([
  96. ...$request->all(),
  97. 'description' => $request->description? (new \App\Services\File\ImageUrlService)->interceptImageUrl($request->description) : null,
  98. ]);
  99. $plan->save();
  100. return $this->noContent();
  101. }
  102. /**
  103. * Remove the specified resource from storage.
  104. */
  105. public function destroy(string $id)
  106. {
  107. $plan = Plan::allowed()->findOrFail($id);
  108. if(!empty($plan->children()->first())){
  109. throw new \Exception("Please remove the sub-level plan.");
  110. }
  111. $plan->delete();
  112. return $this->noContent();
  113. }
  114. }