RequirementController.php 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Requirement\ClosedRequest;
  5. use App\Http\Requests\API\Requirement\CreateOrUpdateRequest;
  6. use App\Http\Requests\API\Requirement\LinkPlanRequest;
  7. use App\Http\Requests\API\Requirement\BatchCreateRequest;
  8. use App\Http\Resources\API\AssetRequirementResource;
  9. use App\Http\Resources\API\RequirementResource;
  10. use App\Models\Asset;
  11. use App\Models\Enums\ActionObjectType;
  12. use App\Models\Enums\FileObjectType;
  13. use App\Models\Enums\RequirementStatus;
  14. use App\Models\Enums\ObjectAction;
  15. use App\Models\Plan;
  16. use App\Models\Requirement;
  17. use App\Repositories\ActionRepository;
  18. use App\Services\File\FileAssociationService;
  19. use App\Services\History\ModelChangeDetector;
  20. use Illuminate\Http\Request;
  21. use Illuminate\Support\Facades\Auth;
  22. use Illuminate\Support\Facades\DB;
  23. use Illuminate\Validation\Rules\Enum;
  24. class RequirementController extends Controller
  25. {
  26. /**
  27. * Display a listing of the resource.
  28. */
  29. public function index(Request $request)
  30. {
  31. $pageSize=$request->get('page_size') ?? 10;
  32. $requirements=Requirement::filter($request->all())->where('company_id',Auth::user()->company_id)->with(['createdBy', 'plan','group','asset'=>function($query){
  33. $query->with('parent');
  34. }]) ->paginate($pageSize);
  35. return AssetRequirementResource::collection($requirements);
  36. }
  37. // public function byAsset(Request $request,string $assetId)
  38. // {
  39. // $requirements=Requirement::filter($request->all())->with(['createdBy', 'plan','group']) ->where('asset_id', $assetId)->simplePaginate();
  40. //
  41. // return AssetRequirementResource::collection($requirements);
  42. // }
  43. /**
  44. * Store a newly created resource in storage.
  45. */
  46. public function store(FileAssociationService $service, CreateOrUpdateRequest $request)
  47. {
  48. $requirement = new Requirement();
  49. $requirement->mergeFillable([
  50. 'company_id', 'created_by',
  51. ]);
  52. $requirement->fill([
  53. ...$request->all(),
  54. 'company_id' => Auth::user()->company_id,
  55. 'description' => $request->description? (new \App\Services\File\ImageUrlService)->interceptImageUrl($request->description) : null,
  56. 'created_by' => Auth::id(),
  57. ]);
  58. $requirement->save();
  59. ActionRepository::createRequirement(
  60. $requirement, ObjectAction::CREATED
  61. );
  62. $service->association(
  63. $request->get("file_ids", []),
  64. $requirement->id,
  65. FileObjectType::REQUIREMENT
  66. );
  67. return $this->created();
  68. }
  69. /**
  70. * Display the specified resource.
  71. */
  72. public function show(string $id)
  73. {
  74. $requirement = Requirement::query()->findOrFail($id);
  75. return new RequirementResource($requirement);
  76. }
  77. /**
  78. * Update the specified resource in storage.
  79. */
  80. public function update(CreateOrUpdateRequest $request, string $id)
  81. {
  82. $requirement = Requirement::findOrFail($id);
  83. $requirement->fill([
  84. ...$request->all(),
  85. 'description' => $request->description? (new \App\Services\File\ImageUrlService)->interceptImageUrl($request->description) : null,
  86. ]);
  87. $changes = ModelChangeDetector::detector(ActionObjectType::REQUIREMENT, $requirement);
  88. $requirement->save();
  89. ActionRepository::createRequirement(
  90. $requirement, ObjectAction::EDITED,objectChanges: $changes
  91. );
  92. return $this->noContent();
  93. }
  94. /**
  95. * Remove the specified resource from storage.
  96. */
  97. public function destroy(string $id)
  98. {
  99. $requirement = Requirement::findOrFail($id);
  100. $requirement->delete();
  101. ActionRepository::createRequirement(
  102. $requirement, ObjectAction::DELETED
  103. );
  104. return $this->noContent();
  105. }
  106. public function close(Request $request,string $id){
  107. $requirement = Requirement::findOrFail($id);
  108. $requirement->status = RequirementStatus::CLOSED->value;
  109. $changes = ModelChangeDetector::detector(ActionObjectType::REQUIREMENT, $requirement);
  110. $requirement->save();
  111. ActionRepository::createRequirement(
  112. $requirement,
  113. ObjectAction::CLOSED,
  114. $request->comment?(new \App\Services\File\ImageUrlService)->interceptImageUrl($request->comment) : null,
  115. objectChanges: $changes
  116. );
  117. return $this->noContent();
  118. }
  119. public function start(Request $request, string $id)
  120. {
  121. $requirement = Requirement::findOrFail($id);
  122. $requirement->status = RequirementStatus::ACTIVE->value;
  123. $changes = ModelChangeDetector::detector(ActionObjectType::REQUIREMENT, $requirement);
  124. $requirement->save();
  125. ActionRepository::createRequirement(
  126. $requirement,
  127. ObjectAction::STARTED,
  128. $request->comment?(new \App\Services\File\ImageUrlService)->interceptImageUrl($request->comment) : null,
  129. objectChanges: $changes
  130. );
  131. return $this->noContent();
  132. }
  133. public function linkPlan(LinkPlanRequest $request, string $planId)
  134. {
  135. $plan = Plan::query()->findOrFail($planId);
  136. Requirement::query()->where("asset_id", $plan->asset_id)
  137. ->whereIn('id', $request->get("requirement_ids"))
  138. ->update([
  139. 'plan_id' => $plan->id,
  140. ]);
  141. return $this->noContent();
  142. }
  143. public function unlinkPlan(LinkPlanRequest $request)
  144. {
  145. Requirement::query()->whereIn('id', $request->get("requirement_ids"))
  146. ->update([
  147. 'plan_id' => null,
  148. ]);
  149. return $this->noContent();
  150. }
  151. public function batchStore(BatchCreateRequest $request)
  152. {
  153. $requirementsData = $request->all();
  154. $companyId = Auth::user()->company_id;
  155. $created_by = Auth::id();
  156. DB::transaction(function () use ($requirementsData,$companyId,$created_by) {
  157. foreach ($requirementsData as $k => $data) {
  158. $requirement = new Requirement();
  159. $requirement->mergeFillable([
  160. 'company_id', 'created_by',
  161. ]);
  162. if($k != 0){
  163. $requirementsData[$k]["requirement_group_id"] = $requirementsData[$k]["requirement_group_id"] == 'ditto'?$requirementsData[$k-1]["requirement_group_id"]:$requirementsData[$k]["requirement_group_id"];
  164. $requirementsData[$k]["priority"] = $requirementsData[$k]["priority"] == 'ditto'? $requirementsData[$k-1]["priority"]: $requirementsData[$k]["priority"];
  165. }
  166. $requirement->fill([
  167. ...$requirementsData[$k],
  168. 'company_id' => $companyId,
  169. 'created_by' => $created_by,
  170. 'status' => RequirementStatus::ACTIVE,
  171. 'mailto' => [],
  172. ]);
  173. $requirement->save();
  174. ActionRepository::createRequirement(
  175. $requirement, ObjectAction::CREATED
  176. );
  177. }
  178. });
  179. return $this->created();
  180. }
  181. }