30 lines
735 B
TypeScript
30 lines
735 B
TypeScript
import { query } from '../../utils/db'
|
|
|
|
/**
|
|
* 사원 검색 (이름/이메일)
|
|
* GET /api/employee/search?q=keyword
|
|
*/
|
|
export default defineEventHandler(async (event) => {
|
|
const queryParams = getQuery(event)
|
|
const keyword = queryParams.q as string
|
|
|
|
if (!keyword || keyword.length < 1) {
|
|
return []
|
|
}
|
|
|
|
const employees = await query(`
|
|
SELECT * FROM wr_employee_info
|
|
WHERE is_active = true
|
|
AND (employee_name ILIKE $1 OR employee_email ILIKE $1)
|
|
ORDER BY employee_name
|
|
LIMIT 20
|
|
`, [`%${keyword}%`])
|
|
|
|
return employees.map((e: any) => ({
|
|
employeeId: e.employee_id,
|
|
employeeName: e.employee_name,
|
|
employeeEmail: e.employee_email,
|
|
employeePosition: e.employee_position
|
|
}))
|
|
})
|