DepartmentController.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  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'=>UserSimpleResource::collection($users)];
  63. }
  64. public function store(CreateOrUpdateRequest $request)
  65. {
  66. $department=new Department();
  67. $department->mergeFillable([
  68. 'company_id'
  69. ]);
  70. $company_id = $request->input('company_id',Auth::user()->company_id);
  71. $department->fill([
  72. ...$request->all(),
  73. 'company_id' => $company_id,
  74. ]);
  75. $department->save();
  76. return $this->created();
  77. }
  78. public function show(string $id)
  79. {
  80. $department=Department::query()->findOrFail($id);
  81. return new DepartmentResource($department);
  82. }
  83. public function update(CreateOrUpdateRequest $request,string $id)
  84. {
  85. $department=Department::findOrFail($id);
  86. $department->fill($request->all());
  87. $department->save();
  88. return $this->noContent();
  89. }
  90. public function destroy(string $id)
  91. {
  92. $department = Department::findOrFail($id);
  93. if(!empty($department->children()->first())){
  94. throw new \Exception("Please remove the sub-level departments.");
  95. }
  96. $department->delete();
  97. return $this->noContent();
  98. }
  99. public function departmentUserIndex(){
  100. //封装部门
  101. $departments=Department::query()->get(['id','name','parent_id'])->each(function ($departments){
  102. $departments->new_id='department'.$departments->id;
  103. $departments->new_parent_id='department'.$departments->parent_id;
  104. $departments->type='department';
  105. })->toArray();
  106. //封装用户
  107. $users=User::query()->where('company_id',Auth::user()->company_id)->get(['id','name','department_id'])->each(function ($users){
  108. $users->new_id='user'.$users->id;
  109. $users->new_parent_id='department'.$users->department_id;
  110. $users->type='user';
  111. })->toArray();
  112. $departmentTree=$this->makeUserTree(array_merge($departments, $users));
  113. return $this->success([
  114. 'data' => $departmentTree
  115. ]);
  116. }
  117. protected function makeUserTree(array $departmentUsers, $parentId = 'department0') {
  118. $tree = [];
  119. if (empty($departmentUsers)) {
  120. return $tree;
  121. }
  122. $newList = [];
  123. foreach ($departmentUsers as $k => $v) {
  124. $newList[$v['new_id']] = $v;
  125. }
  126. foreach ($newList as $value) {
  127. if ($parentId == $value['new_parent_id']) {
  128. $tree[] = &$newList[$value['new_id']];
  129. }elseif (isset($newList[$value['new_parent_id']])) {
  130. $newList[$value['new_parent_id']]['children'][] = &$newList[$value['new_id']];
  131. }
  132. }
  133. return $tree;
  134. }
  135. }