ContainerController.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Container\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\ContainerDetailResource;
  6. use App\Http\Resources\API\ContainerReportResource;
  7. use App\Http\Resources\API\ContainerResource;
  8. use App\Http\Resources\API\FileByObjectResource;
  9. use App\Http\Resources\API\LibraryReportResource;
  10. use App\Models\Container;
  11. use App\Models\ContainerContent;
  12. use App\Models\Enums\ActionObjectType;
  13. use App\Models\Enums\FileObjectType;
  14. use App\Models\Enums\ObjectAction;
  15. use App\Models\File;
  16. use App\Models\Folder;
  17. use App\Models\Library;
  18. use App\Repositories\ActionRepository;
  19. use App\Repositories\CustomFieldRepository;
  20. use App\Services\File\FileAssociationService;
  21. use App\Services\File\ImageUrlService;
  22. use App\Services\History\ModelChangeDetector;
  23. use Carbon\Carbon;
  24. use Illuminate\Http\Request;
  25. use Illuminate\Support\Facades\Auth;
  26. class ContainerController extends Controller
  27. {
  28. /**
  29. * Display a listing of the resource.
  30. */
  31. public function index(Request $request)
  32. {
  33. $containers = Container::query()->allowed()->filter($request->all())->paginate();
  34. $foldsCount = Folder::query()
  35. ->where('object_type','container')
  36. ->where('parent_id',0)
  37. ->whereIn("object_id", $containers->pluck("id")->toArray())
  38. ->selectRaw("count(*) as cut, object_id")
  39. ->groupBy("object_id")
  40. ->pluck("cut", "object_id");
  41. $fileCount = File::query()
  42. ->where('object_type','container')
  43. ->whereIn('object_id',$containers->pluck("id")->toArray())
  44. ->where("folder_id", 0)
  45. ->where("is_latest_version", 1)
  46. ->selectRaw("count(*) as cut, object_id")
  47. ->groupBy("object_id")
  48. ->pluck("cut", "object_id");
  49. $containers = $containers->map(function (Container $container) use ($foldsCount,$fileCount) {
  50. $container->itemCount =$foldsCount->get($container->id, 0)+$fileCount->get($container->id, 0);
  51. $container->type = 'container';
  52. $container->uniId = $container->type . '_' . $container->id;
  53. return $container;
  54. });
  55. return $this->success([
  56. 'data' => $containers
  57. ]);
  58. //return ContainerResource::collection($containers);
  59. }
  60. /**
  61. * Store a newly created resource in storage.
  62. */
  63. public function store(
  64. CreateOrUpdateRequest $request,
  65. ImageUrlService $imageUrlService,
  66. FileAssociationService $service,
  67. CustomFieldRepository $customFieldRepo
  68. )
  69. {
  70. $formData = [
  71. ...$request->all(),
  72. 'company_id' => Auth::user()->company_id,
  73. 'created_by' => Auth::id(),
  74. 'whitelist' => $request->whitelist ? sprintf(",%s,", implode(',', $request->whitelist)) : null,
  75. ];
  76. $service->check(
  77. $request->get("file_ids", []),
  78. FileObjectType::CONTAINER,
  79. $request->get("file_uuid"),
  80. );
  81. if ($request->has("naming_rule_id") && $request->get("naming_rule_id") > 0) {
  82. $keys = $customFieldRepo->keysByGroup($request->get("naming_rule_id"));
  83. $formData['naming_rules'] = $request->only($keys);
  84. }
  85. $container = new Container();
  86. $container->mergeFillable(['company_id', 'created_by']);
  87. $container->fill($formData);
  88. $container->save();
  89. $service->association($container->id);
  90. $files = File::query()->where('object_id', $container->id)
  91. ->where('object_type', ActionObjectType::CONTAINER)
  92. ->where('source', 1)
  93. ->pluck("id")
  94. ->sort();
  95. $contentFormData = [
  96. 'description' => $imageUrlService->interceptImageUrl($request->description),
  97. 'container_id' => $container->id,
  98. 'created_by' => Auth::id(),
  99. 'name' => $request->name,
  100. 'files' => $files->implode(",") ?: null
  101. ];
  102. ContainerContent::query()->create($contentFormData);
  103. ActionRepository::createByContainer($container, ObjectAction::CREATED);
  104. return $this->created();
  105. }
  106. /**
  107. * Display the specified resource.
  108. */
  109. public function show(string $id)
  110. {
  111. $container = Container::query()->allowed()
  112. ->when(\request("version") > 0, fn($query) => $query->where("version", ">=", \request("version")))
  113. ->findOrFail($id);
  114. return new ContainerDetailResource($container);
  115. }
  116. /**
  117. * Update the specified resource in storage.
  118. */
  119. public function update(
  120. CreateOrUpdateRequest $request,
  121. ImageUrlService $imageUrlService,
  122. CustomFieldRepository $customFieldRepo,
  123. string $id
  124. )
  125. {
  126. $container = Container::query()->allowed()->findOrFail($id);
  127. $formData = [
  128. ...$request->all(),
  129. 'whitelist' => $request->whitelist ? sprintf(",%s,", implode(',', $request->whitelist)) : null,
  130. 'description' => $imageUrlService->interceptImageUrl($request->description) ,
  131. ];
  132. if ($request->has("naming_rule_id") && $request->get("naming_rule_id") > 0) {
  133. $keys = $customFieldRepo->keysByGroup($request->get("naming_rule_id"));
  134. $formData['naming_rules'] = $request->only($keys);
  135. }
  136. $container->fill($formData);
  137. $changes = ModelChangeDetector::detector(ActionObjectType::CONTAINER, $container);
  138. $files = File::query()->where('object_id', $container->id)
  139. ->where('object_type', ActionObjectType::CONTAINER)
  140. ->where('source', 1)
  141. ->pluck("id")
  142. ->sort();
  143. $contentFormData = [
  144. 'description' => $imageUrlService->interceptImageUrl($request->description),
  145. 'name' => $request->name,
  146. 'files' => $files->implode(",") ?: null
  147. ];
  148. $containerContent = $container->content;
  149. $containerContent->fill($contentFormData);
  150. $contentChange = ModelChangeDetector::detector(ActionObjectType::CONTAINER_CONTENT, $containerContent);
  151. if ($contentChange) {
  152. $container->version++;
  153. $changes = array_merge($changes, $contentChange);
  154. ContainerContent::query()->create([
  155. ...$contentFormData,
  156. 'container_id' => $container->id,
  157. 'created_by' => Auth::id(),
  158. 'version' => $container->version,
  159. ]);
  160. }
  161. $container->save();
  162. ActionRepository::createByContainer($container, ObjectAction::EDITED, objectChanges: $changes);
  163. return $this->noContent();
  164. }
  165. /**
  166. * Remove the specified resource from storage.
  167. */
  168. public function destroy(string $id)
  169. {
  170. $container = Container::query()->allowed()->findOrFail($id);
  171. $container->delete();
  172. ActionRepository::createByContainer($container, ObjectAction::DELETED);
  173. return $this->noContent();
  174. }
  175. public function linkage(string $libraryId)
  176. {
  177. $items = Container::query()->allowed()->where("library_id", $libraryId)->get(['id', 'name'])->each(function ($items) {
  178. // 设置固定的type值
  179. $items->type = 'container';
  180. $items->uniId=$items->type.'_'.$items->id;
  181. });
  182. return $this->success([
  183. 'data' => $items
  184. ]);
  185. }
  186. public function attachments(Request $request){
  187. $folderObjectType = FileObjectType::from($request->object_type);
  188. $object=$folderObjectType->modelBuilderAllowed()->findOrFail($request->object_id);
  189. if($folderObjectType->value==='asset'){
  190. $requirementsId=$object->requirements->pluck('id');
  191. if(!$requirementsId->isEmpty()){
  192. $file=File::query()->where('object_type','requirement')
  193. ->whereIn('object_id',$requirementsId)
  194. ->where('is_latest_version',1)
  195. ->where('source',1)
  196. ->get();
  197. return FileByObjectResource::collection($file);
  198. }
  199. }else if($folderObjectType->value==='project'){
  200. $tasksId=$object->tasks->pluck('id');
  201. if(!$tasksId->isEmpty()){
  202. $file=File::query()->where('object_type','task')
  203. ->whereIn('object_id',$tasksId)
  204. ->where('is_latest_version',1)
  205. ->where('source',1)
  206. ->get();
  207. return FileByObjectResource::collection($file);
  208. }
  209. }
  210. return $this->noContent();
  211. }
  212. public function containerReport(){
  213. $companyId=Auth::user()->company_id;
  214. $librarys=Library::query()->where('company_id',$companyId)->withCount('container') ->get(['id', 'name', 'created_at', 'updated_at', 'container_count as container_count']);
  215. $libraryCount=$librarys->count();
  216. $containerCount = $librarys->sum('container_count');
  217. $MyLibrarys=Library::query()->allowed()->orderBy('updated_at', 'desc')->get(['id', 'name', 'type','created_at', 'updated_at']);
  218. $MyContainers = Container::query()->allowed()->orderBy('updated_at', 'desc')->get( ['id', 'name','library_id', 'created_at', 'updated_at']);
  219. return $this->success([
  220. 'data' =>[
  221. 'libraryCount'=>$libraryCount,
  222. 'containerCount'=>$containerCount,
  223. 'MyLibrarysCount'=>$MyLibrarys->count(),
  224. 'MyContainersCount'=>$MyContainers->count(),
  225. 'MyContainers'=>ContainerReportResource::collection($MyContainers),
  226. 'MyLibrarys'=>LibraryReportResource::collection($MyLibrarys)
  227. ]
  228. ]);
  229. }
  230. }