Merge branch 'main' of http://39.117.244.52:3000/kjs/ERP-node into lhj
; Please enter a commit message to explain why this merge is necessary, ; especially if it merges an updated upstream into a topic branch. ; ; Lines starting with ';' will be ignored, and an empty message aborts ; the commit.
This commit is contained in:
@@ -707,12 +707,19 @@ export class ButtonActionExecutor {
|
||||
|
||||
if (repeaterJsonKeys.length > 0) {
|
||||
console.log("🔄 [handleSave] RepeaterFieldGroup JSON 문자열 감지:", repeaterJsonKeys);
|
||||
|
||||
|
||||
// 🎯 채번 규칙 할당 처리 (RepeaterFieldGroup 저장 전에 실행)
|
||||
console.log("🔍 [handleSave-RepeaterFieldGroup] 채번 규칙 할당 체크 시작");
|
||||
|
||||
// 🔧 수정 모드 체크: formData.id가 존재하면 UPDATE 모드이므로 채번 코드 재할당 금지
|
||||
const isEditModeRepeater =
|
||||
context.formData.id !== undefined && context.formData.id !== null && context.formData.id !== "";
|
||||
|
||||
console.log("🔍 [handleSave-RepeaterFieldGroup] 채번 규칙 할당 체크 시작", {
|
||||
isEditMode: isEditModeRepeater,
|
||||
formDataId: context.formData.id,
|
||||
});
|
||||
|
||||
const fieldsWithNumberingRepeater: Record<string, string> = {};
|
||||
|
||||
|
||||
// formData에서 채번 규칙이 설정된 필드 찾기
|
||||
for (const [key, value] of Object.entries(context.formData)) {
|
||||
if (key.endsWith("_numberingRuleId") && value) {
|
||||
@@ -721,22 +728,27 @@ export class ButtonActionExecutor {
|
||||
console.log(`🎯 [handleSave-RepeaterFieldGroup] 채번 필드 발견: ${fieldName} → 규칙 ${value}`);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
console.log("📋 [handleSave-RepeaterFieldGroup] 채번 규칙이 설정된 필드:", fieldsWithNumberingRepeater);
|
||||
|
||||
// 채번 규칙이 있는 필드에 대해 allocateCode 호출
|
||||
if (Object.keys(fieldsWithNumberingRepeater).length > 0) {
|
||||
console.log("🎯 [handleSave-RepeaterFieldGroup] 채번 규칙 할당 시작 (allocateCode 호출)");
|
||||
|
||||
// 🔧 수정 모드에서는 채번 코드 할당 건너뛰기 (기존 번호 유지)
|
||||
// 신규 등록 모드에서만 allocateCode 호출하여 새 번호 할당
|
||||
if (Object.keys(fieldsWithNumberingRepeater).length > 0 && !isEditModeRepeater) {
|
||||
console.log(
|
||||
"🎯 [handleSave-RepeaterFieldGroup] 신규 등록 모드 - 채번 규칙 할당 시작 (allocateCode 호출)",
|
||||
);
|
||||
const { allocateNumberingCode } = await import("@/lib/api/numberingRule");
|
||||
|
||||
|
||||
for (const [fieldName, ruleId] of Object.entries(fieldsWithNumberingRepeater)) {
|
||||
try {
|
||||
console.log(`🔄 [handleSave-RepeaterFieldGroup] ${fieldName} 필드에 대해 allocateCode 호출: ${ruleId}`);
|
||||
const allocateResult = await allocateNumberingCode(ruleId);
|
||||
|
||||
|
||||
if (allocateResult.success && allocateResult.data?.generatedCode) {
|
||||
const newCode = allocateResult.data.generatedCode;
|
||||
console.log(`✅ [handleSave-RepeaterFieldGroup] ${fieldName} 새 코드 할당: ${context.formData[fieldName]} → ${newCode}`);
|
||||
console.log(
|
||||
`✅ [handleSave-RepeaterFieldGroup] ${fieldName} 새 코드 할당: ${context.formData[fieldName]} → ${newCode}`,
|
||||
);
|
||||
context.formData[fieldName] = newCode;
|
||||
} else {
|
||||
console.warn(`⚠️ [handleSave-RepeaterFieldGroup] ${fieldName} 코드 할당 실패:`, allocateResult.error);
|
||||
@@ -745,9 +757,11 @@ export class ButtonActionExecutor {
|
||||
console.error(`❌ [handleSave-RepeaterFieldGroup] ${fieldName} 코드 할당 오류:`, allocateError);
|
||||
}
|
||||
}
|
||||
} else if (isEditModeRepeater) {
|
||||
console.log("⏭️ [handleSave-RepeaterFieldGroup] 수정 모드 - 채번 코드 할당 건너뜀 (기존 번호 유지)");
|
||||
}
|
||||
|
||||
console.log("✅ [handleSave-RepeaterFieldGroup] 채번 규칙 할당 완료");
|
||||
|
||||
console.log("✅ [handleSave-RepeaterFieldGroup] 채번 규칙 할당 처리 완료");
|
||||
|
||||
// 🆕 상단 폼 데이터(마스터 정보) 추출
|
||||
// RepeaterFieldGroup JSON과 컴포넌트 키를 제외한 나머지가 마스터 정보
|
||||
@@ -803,7 +817,7 @@ export class ButtonActionExecutor {
|
||||
|
||||
for (const item of parsedData) {
|
||||
// 메타 필드 제거
|
||||
const { _targetTable, _isNewItem, _existingRecord, _originalItemIds, _deletedItemIds, _repeaterFields, ...itemData } = item;
|
||||
const { _targetTable, _isNewItem, _existingRecord, _originalItemIds, _deletedItemIds, _repeaterFields, _subDataSelection, _subDataMaxValue, ...itemData } = item;
|
||||
|
||||
// 🔧 품목 고유 필드만 추출 (RepeaterFieldGroup 설정 기반)
|
||||
const itemOnlyData: Record<string, any> = {};
|
||||
@@ -812,6 +826,42 @@ export class ButtonActionExecutor {
|
||||
itemOnlyData[field] = itemData[field];
|
||||
}
|
||||
});
|
||||
|
||||
// 🆕 하위 데이터 선택에서 값 추출 (subDataSource 설정 기반)
|
||||
// 필드 정의에서 subDataSource.enabled가 true이고 sourceColumn이 설정된 필드만 처리
|
||||
if (_subDataSelection && typeof _subDataSelection === 'object') {
|
||||
// _repeaterFieldsConfig에서 subDataSource 설정 확인
|
||||
const fieldsConfig = item._repeaterFieldsConfig as Array<{
|
||||
name: string;
|
||||
subDataSource?: { enabled: boolean; sourceColumn: string };
|
||||
}> | undefined;
|
||||
|
||||
if (fieldsConfig && Array.isArray(fieldsConfig)) {
|
||||
fieldsConfig.forEach((fieldConfig) => {
|
||||
if (fieldConfig.subDataSource?.enabled && fieldConfig.subDataSource?.sourceColumn) {
|
||||
const targetField = fieldConfig.name; // 필드명 = 저장할 컬럼명
|
||||
const sourceColumn = fieldConfig.subDataSource.sourceColumn;
|
||||
const sourceValue = _subDataSelection[sourceColumn];
|
||||
|
||||
if (sourceValue !== undefined && sourceValue !== null) {
|
||||
itemOnlyData[targetField] = sourceValue;
|
||||
console.log(`📋 [handleSave] 하위 데이터 값 매핑: ${sourceColumn} → ${targetField} = ${sourceValue}`);
|
||||
}
|
||||
}
|
||||
});
|
||||
} else {
|
||||
// 하위 호환성: fieldsConfig가 없으면 기존 방식 사용
|
||||
Object.keys(_subDataSelection).forEach((subDataKey) => {
|
||||
if (itemOnlyData[subDataKey] === undefined || itemOnlyData[subDataKey] === null || itemOnlyData[subDataKey] === '') {
|
||||
const subDataValue = _subDataSelection[subDataKey];
|
||||
if (subDataValue !== undefined && subDataValue !== null) {
|
||||
itemOnlyData[subDataKey] = subDataValue;
|
||||
console.log(`📋 [handleSave] 하위 데이터 선택 값 추가 (레거시): ${subDataKey} = ${subDataValue}`);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
// 🔧 마스터 정보 + 품목 고유 정보 병합
|
||||
// masterFields: 상단 폼에서 수정한 최신 마스터 정보
|
||||
@@ -1915,7 +1965,16 @@ export class ButtonActionExecutor {
|
||||
}
|
||||
|
||||
// 🎯 채번 규칙 할당 처리 (저장 시점에 실제 순번 증가)
|
||||
console.log("🔍 [handleUniversalFormModalTableSectionSave] 채번 규칙 할당 체크 시작");
|
||||
// 🔧 수정 모드 체크: formData.id 또는 originalGroupedData가 있으면 UPDATE 모드
|
||||
const isEditModeUniversal =
|
||||
(formData.id !== undefined && formData.id !== null && formData.id !== "") ||
|
||||
originalGroupedData.length > 0;
|
||||
|
||||
console.log("🔍 [handleUniversalFormModalTableSectionSave] 채번 규칙 할당 체크 시작", {
|
||||
isEditMode: isEditModeUniversal,
|
||||
formDataId: formData.id,
|
||||
originalGroupedDataCount: originalGroupedData.length,
|
||||
});
|
||||
|
||||
const fieldsWithNumbering: Record<string, string> = {};
|
||||
|
||||
@@ -1941,9 +2000,12 @@ export class ButtonActionExecutor {
|
||||
|
||||
console.log("📋 [handleUniversalFormModalTableSectionSave] 채번 규칙이 설정된 필드:", fieldsWithNumbering);
|
||||
|
||||
// 🔥 저장 시점에 allocateCode 호출하여 실제 순번 증가
|
||||
if (Object.keys(fieldsWithNumbering).length > 0) {
|
||||
console.log("🎯 [handleUniversalFormModalTableSectionSave] 채번 규칙 할당 시작 (allocateCode 호출)");
|
||||
// 🔧 수정 모드에서는 채번 코드 할당 건너뛰기 (기존 번호 유지)
|
||||
// 신규 등록 모드에서만 allocateCode 호출하여 새 번호 할당
|
||||
if (Object.keys(fieldsWithNumbering).length > 0 && !isEditModeUniversal) {
|
||||
console.log(
|
||||
"🎯 [handleUniversalFormModalTableSectionSave] 신규 등록 모드 - 채번 규칙 할당 시작 (allocateCode 호출)",
|
||||
);
|
||||
const { allocateNumberingCode } = await import("@/lib/api/numberingRule");
|
||||
|
||||
for (const [fieldName, ruleId] of Object.entries(fieldsWithNumbering)) {
|
||||
@@ -1970,6 +2032,8 @@ export class ButtonActionExecutor {
|
||||
// 오류 시 기존 값 유지
|
||||
}
|
||||
}
|
||||
} else if (isEditModeUniversal) {
|
||||
console.log("⏭️ [handleUniversalFormModalTableSectionSave] 수정 모드 - 채번 코드 할당 건너뜀 (기존 번호 유지)");
|
||||
}
|
||||
|
||||
console.log("✅ [handleUniversalFormModalTableSectionSave] 채번 규칙 할당 완료");
|
||||
|
||||
Reference in New Issue
Block a user