ContainerController.php 12 KB

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