Files
sam-manage/app/Http/Controllers/Api/Admin/TenantUserApiController.php
김보곤 0be540ff83 fix: [approvals] 결재자 검색 API 응답 필드 수정
- department_name → department 필드명 변경 (프론트엔드 호환)
- tenant_user_profiles 조인으로 position(직급) 데이터 추가
- 부서명 검색 지원 추가
2026-02-28 00:56:27 +09:00

54 lines
1.8 KiB
PHP

<?php
namespace App\Http\Controllers\Api\Admin;
use App\Http\Controllers\Controller;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class TenantUserApiController extends Controller
{
/**
* 테넌트 사용자 검색 (결재라인 담당자 선택용)
*/
public function search(Request $request): JsonResponse
{
$tenantId = session('selected_tenant_id');
$query = $request->input('q', '');
$users = DB::table('users')
->join('user_tenants', function ($join) use ($tenantId) {
$join->on('users.id', '=', 'user_tenants.user_id')
->where('user_tenants.tenant_id', $tenantId)
->where('user_tenants.is_active', true);
})
->leftJoin('tenant_user_profiles as tp', function ($join) use ($tenantId) {
$join->on('tp.user_id', '=', 'users.id')
->where('tp.tenant_id', $tenantId);
})
->leftJoin('departments', 'departments.id', '=', 'tp.department_id')
->whereNull('users.deleted_at')
->when($query, function ($q) use ($query) {
$q->where(function ($sub) use ($query) {
$sub->where('users.name', 'like', "%{$query}%")
->orWhere('departments.name', 'like', "%{$query}%");
});
})
->orderBy('users.name')
->limit(30)
->select([
'users.id',
'users.name',
'departments.name as department',
'tp.position_key as position',
])
->get();
return response()->json([
'success' => true,
'data' => $users,
]);
}
}