DepartmentController.php 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. <?php
  2. namespace App\Http\Controllers\API;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Requests\API\Department\CreateOrUpdateRequest;
  5. use App\Http\Resources\API\DepartmentResource;
  6. use App\Http\Resources\API\UserInfoResource;
  7. use App\Http\Resources\API\UserProfileResource;
  8. use App\Http\Resources\API\UserSimpleResource;
  9. use App\Models\Company;
  10. use App\Models\Department;
  11. use App\Models\Scopes\CompanyScope;
  12. use App\Models\User;
  13. use Illuminate\Http\Request;
  14. use Illuminate\Support\Facades\Auth;
  15. class DepartmentController extends Controller
  16. {
  17. public function index(Request $request)
  18. {
  19. return $this->getDepartments($request);
  20. }
  21. public function publicSearch(Request $request)
  22. {
  23. return $this->getDepartments($request);
  24. }
  25. protected function getDepartments(Request $request)
  26. {
  27. $sort = $request->input('sort', 'desc');
  28. $pageSize = $request->get('page_size') ?? 0;
  29. $company_id = $request->get('company_id') ?? Auth::user()->company_id;
  30. $departments = Department::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())
  31. ->where('company_id' ,$company_id)->orderBy('created_at', $sort)->paginate($pageSize);
  32. $departmentTree = !empty(make_tree($departments->toArray()['data'])) ? make_tree($departments->toArray()['data']) : $departments->toArray()['data'];
  33. return [
  34. 'data' => $departmentTree,
  35. 'total' => $departments->total(),
  36. ];
  37. }
  38. public function structure(Request $request)
  39. {
  40. $company_id = $request->get('company_id') ?? Auth::user()->company_id;
  41. $departments = Department::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())
  42. ->where('company_id' ,$company_id)
  43. ->where('parent_id' ,0)
  44. ->orderBy('created_at', 'desc')->get();
  45. $noDepartment = User::query()
  46. ->where('company_id' ,$company_id)
  47. ->whereNull('department_id')
  48. ->orderBy('id', 'desc')
  49. ->get();
  50. return [
  51. 'departments' => DepartmentResource::collection($departments),
  52. 'noDepartment' => UserInfoResource::collection($noDepartment),
  53. ];
  54. }
  55. public function userList(Request $request)
  56. {
  57. $users = User::query()
  58. ->filter($request->all())
  59. ->where('department_id', $request->department_id)
  60. ->where('company_id',$request->company_id)
  61. ->orderBy('created_at','desc')->get();
  62. return ['data'=>UserProfileResource::collection($users)];
  63. }
  64. public function store(CreateOrUpdateRequest $request)
  65. {
  66. $department=new Department();
  67. $department->mergeFillable([
  68. 'company_id'
  69. ]);
  70. $department->fill([
  71. ...$request->all(),
  72. 'company_id' => Auth::user()->company_id,
  73. ]);
  74. $department->save();
  75. return $this->created();
  76. }
  77. public function show(string $id)
  78. {
  79. $department=Department::query()->findOrFail($id);
  80. return new DepartmentResource($department);
  81. }
  82. public function update(CreateOrUpdateRequest $request,string $id)
  83. {
  84. $department=Department::findOrFail($id);
  85. $department->fill($request->all());
  86. $department->save();
  87. return $this->noContent();
  88. }
  89. public function destroy(string $id)
  90. {
  91. $department = Department::findOrFail($id);
  92. if(!empty($department->children()->first())){
  93. throw new \Exception("Please remove the sub-level departments.");
  94. }
  95. $department->delete();
  96. return $this->noContent();
  97. }
  98. public function departmentUserIndex(){
  99. //封装部门
  100. $departments=Department::query()->get(['id','name','parent_id'])->each(function ($departments){
  101. $departments->new_id='department'.$departments->id;
  102. $departments->new_parent_id='department'.$departments->parent_id;
  103. $departments->type='department';
  104. })->toArray();
  105. //封装用户
  106. $users=User::query()->where('company_id',Auth::user()->company_id)->get(['id','name','department_id'])->each(function ($users){
  107. $users->new_id='user'.$users->id;
  108. $users->new_parent_id='department'.$users->department_id;
  109. $users->type='user';
  110. })->toArray();
  111. $departmentTree=$this->makeUserTree(array_merge($departments, $users));
  112. return $this->success([
  113. 'data' => $departmentTree
  114. ]);
  115. }
  116. protected function makeUserTree(array $departmentUsers, $parentId = 'department0') {
  117. $tree = [];
  118. if (empty($departmentUsers)) {
  119. return $tree;
  120. }
  121. $newList = [];
  122. foreach ($departmentUsers as $k => $v) {
  123. $newList[$v['new_id']] = $v;
  124. }
  125. foreach ($newList as $value) {
  126. if ($parentId == $value['new_parent_id']) {
  127. $tree[] = &$newList[$value['new_id']];
  128. }elseif (isset($newList[$value['new_parent_id']])) {
  129. $newList[$value['new_parent_id']]['children'][] = &$newList[$value['new_id']];
  130. }
  131. }
  132. return $tree;
  133. }
  134. }