코드병합기능 개선

This commit is contained in:
kjs
2026-01-08 14:24:07 +09:00
parent a3c83c834e
commit 3f81c449ad
3 changed files with 216 additions and 12 deletions

View File

@@ -4920,26 +4920,35 @@ export class ButtonActionExecutor {
const { oldValue, newValue } = confirmed;
// 미리보기 표시 (옵션)
// 미리보기 표시 (값 기반 검색 - 모든 테이블의 모든 컬럼에서 검색)
if (config.mergeShowPreview !== false) {
const { apiClient } = await import("@/lib/api/client");
const previewResponse = await apiClient.post("/code-merge/preview", {
columnName,
toast.loading("영향받는 데이터 검색 중...", { duration: Infinity });
const previewResponse = await apiClient.post("/code-merge/preview-by-value", {
oldValue,
});
toast.dismiss();
if (previewResponse.data.success) {
const preview = previewResponse.data.data;
const totalRows = preview.totalAffectedRows;
// 상세 정보 생성
const detailList = preview.preview
.map((p: any) => ` - ${p.tableName}.${p.columnName}: ${p.affectedRows}`)
.join("\n");
const confirmMerge = confirm(
"⚠️ 코드 병합 확인\n\n" +
"코드 병합 확인\n\n" +
`${oldValue}${newValue}\n\n` +
"영향받는 데이터:\n" +
`- 테이블 수: ${preview.preview.length}\n` +
`- 테이블/컬럼 수: ${preview.preview.length}\n` +
`- 총 행 수: ${totalRows}\n\n` +
`데이터는 삭제되지 않고, "${columnName}" 컬럼 값만 변경됩니다.\n\n` +
(preview.preview.length <= 10 ? `상세:\n${detailList}\n\n` : "") +
"모든 테이블에서 해당 값이 변경됩니다.\n\n" +
"계속하시겠습니까?",
);
@@ -4949,13 +4958,12 @@ export class ButtonActionExecutor {
}
}
// 병합 실행
// 병합 실행 (값 기반 - 모든 테이블의 모든 컬럼)
toast.loading("코드 병합 중...", { duration: Infinity });
const { apiClient } = await import("@/lib/api/client");
const response = await apiClient.post("/code-merge/merge-all-tables", {
columnName,
const response = await apiClient.post("/code-merge/merge-by-value", {
oldValue,
newValue,
});
@@ -4964,9 +4972,17 @@ export class ButtonActionExecutor {
if (response.data.success) {
const data = response.data.data;
// 변경된 테이블/컬럼 목록 생성
const changedList = data.affectedData
.map((d: any) => `${d.tableName}.${d.columnName}: ${d.rowsUpdated}`)
.join(", ");
toast.success(
"코드 병합 완료!\n" + `${data.affectedTables.length}개 테이블, ${data.totalRowsUpdated}개 행 업데이트`,
`코드 병합 완료! ${data.affectedData.length}개 테이블/컬럼, ${data.totalRowsUpdated}개 행 업데이트`,
);
console.log("코드 병합 결과:", data.affectedData);
// 화면 새로고침
context.onRefresh?.();