From 7ad9c3c93f0cc103347ae2e2429e0122fb512e24 Mon Sep 17 00:00:00 2001 From: lrj <owen.stl@gmail.com> Date: 星期三, 01 十月 2025 21:26:12 +0800 Subject: [PATCH] feat: 修复员工管理功能并优化UI --- web/src/api/employee.ts | 100 +++++++++---------------------------------------- 1 files changed, 19 insertions(+), 81 deletions(-) diff --git a/web/src/api/employee.ts b/web/src/api/employee.ts index dd55bc7..6cb318e 100644 --- a/web/src/api/employee.ts +++ b/web/src/api/employee.ts @@ -1,5 +1,7 @@ // 鍛樺伐绠$悊API +import { API_CONFIG, graphqlRequest } from '@/config/api' + // 鍛樺伐鐩稿叧鐨� GraphQL 鏌ヨ鍜屽彉鏇� export const EMPLOYEE_QUERIES = { // 鑾峰彇鎵�鏈夊憳宸� @@ -17,7 +19,7 @@ } `, - // 鏍规嵁濮撳悕鎼滅储鍛樺伐 + // 鎼滅储鍛樺伐 SEARCH_EMPLOYEES: ` query SearchEmployees($name: String) { employeesByName(name: $name) { @@ -94,92 +96,41 @@ // API 鍑芥暟 export const employeeApi = { - // 鑾峰彇鎵�鏈夊憳宸� + // 鑾峰彇鍛樺伐鍒楄〃 async getEmployees(): Promise<Employee[]> { try { - const response = await fetch('http://localhost:8080/api/graphql', { - method: 'POST', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ - query: EMPLOYEE_QUERIES.GET_EMPLOYEES - }) - }) - const result = await response.json() - if (result.errors) { - throw new Error(result.errors[0].message) - } - return result.data?.employees || [] + const result = await graphqlRequest(EMPLOYEE_QUERIES.GET_EMPLOYEES) + return result?.data?.employees || [] } catch (error: any) { throw new Error(error.message || '鑾峰彇鍛樺伐鍒楄〃澶辫触') } }, - // 鏍规嵁鍚嶇О鎼滅储鍛樺伐 - async searchEmployees(name?: string): Promise<Employee[]> { + // 鎼滅储鍛樺伐 + async searchEmployees(name: string): Promise<Employee[]> { try { - const response = await fetch('http://localhost:8080/api/graphql', { - method: 'POST', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ - query: EMPLOYEE_QUERIES.SEARCH_EMPLOYEES, - variables: { name } - }) - }) - const result = await response.json() - if (result.errors) { - throw new Error(result.errors[0].message) - } - return result.data?.employeesByName || [] + const result = await graphqlRequest(EMPLOYEE_QUERIES.SEARCH_EMPLOYEES, { name }) + return result?.data?.employeesByName || [] } catch (error: any) { throw new Error(error.message || '鎼滅储鍛樺伐澶辫触') } }, - // 鑾峰彇鍛樺伐璇︽儏 + // 鏍规嵁ID鑾峰彇鍛樺伐璇︽儏 async getEmployee(id: string): Promise<Employee | null> { try { - const response = await fetch('http://localhost:8080/api/graphql', { - method: 'POST', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ - query: EMPLOYEE_QUERIES.GET_EMPLOYEE, - variables: { id } - }) - }) - const result = await response.json() - if (result.errors) { - throw new Error(result.errors[0].message) - } - return result.data?.employee || null + const result = await graphqlRequest(EMPLOYEE_QUERIES.GET_EMPLOYEE, { id }) + return result?.data?.employee || null } catch (error: any) { throw new Error(error.message || '鑾峰彇鍛樺伐璇︽儏澶辫触') } }, - // 淇濆瓨鍛樺伐 - async saveEmployee(input: EmployeeInput): Promise<Employee> { + // 淇濆瓨鍛樺伐锛堟柊澧炴垨鏇存柊锛� + async saveEmployee(employee: EmployeeInput): Promise<Employee> { try { - const response = await fetch('http://localhost:8080/api/graphql', { - method: 'POST', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ - query: EMPLOYEE_MUTATIONS.SAVE_EMPLOYEE, - variables: { input } - }) - }) - const result = await response.json() - if (result.errors) { - throw new Error(result.errors[0].message) - } - return result.data?.saveEmployee + const result = await graphqlRequest(EMPLOYEE_MUTATIONS.SAVE_EMPLOYEE, { input: employee }) + return result?.data?.saveEmployee } catch (error: any) { throw new Error(error.message || '淇濆瓨鍛樺伐澶辫触') } @@ -188,21 +139,8 @@ // 鍒犻櫎鍛樺伐 async deleteEmployee(id: string): Promise<boolean> { try { - const response = await fetch('http://localhost:8080/api/graphql', { - method: 'POST', - headers: { - 'Content-Type': 'application/json', - }, - body: JSON.stringify({ - query: EMPLOYEE_MUTATIONS.DELETE_EMPLOYEE, - variables: { id } - }) - }) - const result = await response.json() - if (result.errors) { - throw new Error(result.errors[0].message) - } - return result.data?.deleteEmployee || false + const result = await graphqlRequest(EMPLOYEE_MUTATIONS.DELETE_EMPLOYEE, { id }) + return result?.data?.deleteEmployee || false } catch (error: any) { throw new Error(error.message || '鍒犻櫎鍛樺伐澶辫触') } -- Gitblit v1.8.0