diff options
| author | joonhoekim <26rote@gmail.com> | 2025-11-18 20:49:59 +0900 |
|---|---|---|
| committer | joonhoekim <26rote@gmail.com> | 2025-11-18 20:49:59 +0900 |
| commit | 18a5bf7d1df331b8e554fc7fe2cabd8902cb0d19 (patch) | |
| tree | d258ed3f02cb1d05e6597c8b8f1e8aac84de4f5b /lib/soap/ecc/mapper | |
| parent | 36ac8e0b4e6dc3b7c5691046708645d643703c71 (diff) | |
(김준회) 견적목록관리: 설계담당자 정보 대표PR로 처리
Diffstat (limited to 'lib/soap/ecc/mapper')
| -rw-r--r-- | lib/soap/ecc/mapper/common-mapper-utils.ts | 51 | ||||
| -rw-r--r-- | lib/soap/ecc/mapper/rfq-and-pr-mapper.ts | 17 |
2 files changed, 66 insertions, 2 deletions
diff --git a/lib/soap/ecc/mapper/common-mapper-utils.ts b/lib/soap/ecc/mapper/common-mapper-utils.ts index 2199490a..ed655e0e 100644 --- a/lib/soap/ecc/mapper/common-mapper-utils.ts +++ b/lib/soap/ecc/mapper/common-mapper-utils.ts @@ -307,6 +307,57 @@ export interface ProjectInfo { } /** + * 사번(PERNR)으로 사용자 정보 조회 함수 + * PERNR(사번)으로 users 테이블의 employeeNumber와 매칭하여 사용자 정보 조회 + */ +export async function findUserInfoByPERNR(PERNR: string | null): Promise<{ + userId: number; + userName: string; + userEmail: string | null; + userPhone: string | null; + employeeNumber: string | null; +} | null> { + try { + debugLog('사번으로 사용자 조회 시작', { PERNR }); + + if (!PERNR) { + debugError('PERNR이 null 또는 undefined', { PERNR }); + return null; + } + + const userResult = await db + .select({ + id: users.id, + name: users.name, + email: users.email, + phone: users.phone, + employeeNumber: users.employeeNumber + }) + .from(users) + .where(eq(users.employeeNumber, PERNR)) + .limit(1); + + if (userResult.length === 0) { + debugError('PERNR에 해당하는 사용자를 찾을 수 없음', { PERNR }); + return null; + } + + const userInfo = { + userId: userResult[0].id, + userName: userResult[0].name, + userEmail: userResult[0].email, + userPhone: userResult[0].phone, + employeeNumber: userResult[0].employeeNumber + }; + debugSuccess('사번으로 사용자 정보 찾음', { PERNR, userInfo }); + return userInfo; + } catch (error) { + debugError('사번으로 사용자 조회 중 오류 발생', { PERNR, error }); + return null; + } +} + +/** * 협력업체 코드(LIFNR)로 vendorId 찾기 * LIFNR = 벤더코드 (ex. A0001234) * vendors 테이블의 vendorCode 필드와 비교하여 vendorId를 찾음 diff --git a/lib/soap/ecc/mapper/rfq-and-pr-mapper.ts b/lib/soap/ecc/mapper/rfq-and-pr-mapper.ts index 85fbb918..d08bc5fb 100644 --- a/lib/soap/ecc/mapper/rfq-and-pr-mapper.ts +++ b/lib/soap/ecc/mapper/rfq-and-pr-mapper.ts @@ -24,6 +24,7 @@ import { findUserInfoByEKGRP, findProjectInfoByPSPID, parseSAPDateTime, + findUserInfoByPERNR, } from './common-mapper-utils'; // ECC 데이터 타입 정의 @@ -154,11 +155,13 @@ export async function mapECCRfqHeaderToRfqLast( const inChargeUserInfo = await findUserInfoByEKGRP(eccHeader.EKGRP || null); const inChargeUserId = inChargeUserInfo?.userId || null; - // 대표 PR Item 기반으로 projectId, itemCode, itemName 설정 (없으면 첫번째 PR Item 사용) + // 대표 PR Item 기반으로 projectId, itemCode, itemName, 설계담당자 설정 (없으면 첫번째 PR Item 사용) let projectId: number | null = null; let itemCode: string | null = null; let itemName: string | null = null; let prNumber: string | null = null; + let engPicName: string | null = null; + let engPicEmployeeNumber: string | null = null; let representativeItem: ECCBidItem | undefined; if (firstItem) { @@ -185,6 +188,15 @@ export async function mapECCRfqHeaderToRfqLast( // prNumber: 대표 PR의 BANFN 또는 첫번째 PR의 ZREQ_FN 값 prNumber = representativeItem?.BANFN || firstItem.ZREQ_FN || null; + + // 설계담당자 정보: 대표 PR Item의 PERNR로 조회 + if (targetItem.PERNR) { + const engPicInfo = await findUserInfoByPERNR(targetItem.PERNR); + if (engPicInfo) { + engPicName = engPicInfo.userName; + engPicEmployeeNumber = engPicInfo.employeeNumber; + } + } } // 매핑 @@ -199,7 +211,8 @@ export async function mapECCRfqHeaderToRfqLast( rfqSendDate: null, // ECC에서 제공되지 않음 status: 'RFQ 생성', // 한글 상태로 변경 rfqSealedYn: false, - EngPicName: null, // ECC에서 제공되지 않음 + EngPicName: engPicName, // 대표 PR Item의 PERNR로 조회한 설계담당자명 + EngPicEmployeeNumber: engPicEmployeeNumber, // 대표 PR Item의 PERNR(사번) packageNo: null, // ECC에서 제공되지 않음 packageName: null, // ECC에서 제공되지 않음 remark: null, |
