DepartmentController.php 5.2 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\UserSimpleResource;
  8. use App\Models\Company;
  9. use App\Models\Department;
  10. use App\Models\Scopes\CompanyScope;
  11. use App\Models\User;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Facades\Auth;
  14. class DepartmentController extends Controller
  15. {
  16. public function index(Request $request)
  17. {
  18. return $this->getDepartments($request);
  19. }
  20. public function publicSearch(Request $request)
  21. {
  22. return $this->getDepartments($request);
  23. }
  24. protected function getDepartments(Request $request)
  25. {
  26. $sort = $request->input('sort', 'desc');
  27. $pageSize = $request->get('page_size') ?? 0;
  28. $company_id = $request->get('company_id') ?? Auth::user()->company_id;
  29. $departments = Department::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())
  30. ->where('company_id' ,$company_id)->orderBy('created_at', $sort)->paginate($pageSize);
  31. $departmentTree = !empty(make_tree($departments->toArray()['data'])) ? make_tree($departments->toArray()['data']) : $departments->toArray()['data'];
  32. return [
  33. 'data' => $departmentTree,
  34. 'total' => $departments->total(),
  35. ];
  36. }
  37. public function structure(Request $request)
  38. {
  39. $company_id = $request->get('company_id') ?? Auth::user()->company_id;
  40. $departments = Department::query()->withoutGlobalScope(CompanyScope::class)->filter($request->all())
  41. ->where('company_id' ,$company_id)
  42. ->where('parent_id' ,0)
  43. ->orderBy('created_at', 'desc')->get();
  44. $noDepartment = User::query()
  45. ->where('company_id' ,$company_id)
  46. ->whereNull('department_id')
  47. ->orderBy('id', 'desc')
  48. ->get();
  49. return [
  50. 'departments' => DepartmentResource::collection($departments),
  51. 'noDepartment' => UserInfoResource::collection($noDepartment),
  52. ];
  53. }
  54. public function userList(Request $request)
  55. {
  56. $pageSize = $request->get('page_size') ?? 0;
  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')->paginate($pageSize);;
  62. return UserSimpleResource::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. }