- 화면 그룹 삭제 시 연결된 메뉴를 정리하는 로직을 추가하여, 삭제될 그룹에 연결된 메뉴를 자동으로 삭제하도록 하였습니다. - 메뉴 삭제 시 관련된 화면 및 플로우 데이터도 함께 정리하여 데이터 일관성을 유지하였습니다. - 복제 화면 모달에서 원본 회사와 동일한 회사 선택 시 자동으로 다른 회사로 변경하는 기능을 추가하였습니다. - 삭제 확인 다이얼로그에 경고 메시지를 추가하여 사용자에게 삭제 작업의 영향을 명확히 안내하였습니다.
300 lines
8.9 KiB
TypeScript
300 lines
8.9 KiB
TypeScript
/**
|
|
* 채번 규칙 관리 API 클라이언트
|
|
*/
|
|
|
|
import { apiClient } from "./client";
|
|
import { NumberingRuleConfig } from "@/types/numbering-rule";
|
|
|
|
export interface ApiResponse<T> {
|
|
success: boolean;
|
|
data?: T;
|
|
error?: string;
|
|
message?: string;
|
|
}
|
|
|
|
export async function getNumberingRules(): Promise<ApiResponse<NumberingRuleConfig[]>> {
|
|
try {
|
|
const response = await apiClient.get("/numbering-rules");
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "규칙 목록 조회 실패" };
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 메뉴별 사용 가능한 채번 규칙 조회 (기존 방식, 하위 호환성 유지)
|
|
* @param menuObjid 현재 메뉴의 objid (선택)
|
|
* @returns 사용 가능한 채번 규칙 목록
|
|
*/
|
|
export async function getAvailableNumberingRules(
|
|
menuObjid?: number
|
|
): Promise<ApiResponse<NumberingRuleConfig[]>> {
|
|
try {
|
|
const url = menuObjid
|
|
? `/numbering-rules/available/${menuObjid}`
|
|
: "/numbering-rules/available";
|
|
const response = await apiClient.get(url);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "사용 가능한 규칙 조회 실패" };
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 화면용 채번 규칙 조회 (테이블 기반 필터링 - 간소화)
|
|
* @param tableName 화면의 테이블명 (필수)
|
|
* @returns 해당 테이블의 채번 규칙 목록
|
|
*/
|
|
export async function getAvailableNumberingRulesForScreen(
|
|
tableName: string
|
|
): Promise<ApiResponse<NumberingRuleConfig[]>> {
|
|
try {
|
|
const response = await apiClient.get("/numbering-rules/available-for-screen", {
|
|
params: { tableName },
|
|
});
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.message || "화면용 규칙 조회 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
export async function getNumberingRuleById(ruleId: string): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.get(`/numbering-rules/${ruleId}`);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "규칙 조회 실패" };
|
|
}
|
|
}
|
|
|
|
export async function createNumberingRule(
|
|
config: NumberingRuleConfig
|
|
): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.post("/numbering-rules", config);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "규칙 생성 실패" };
|
|
}
|
|
}
|
|
|
|
export async function updateNumberingRule(
|
|
ruleId: string,
|
|
config: Partial<NumberingRuleConfig>
|
|
): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.put(`/numbering-rules/${ruleId}`, config);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "규칙 수정 실패" };
|
|
}
|
|
}
|
|
|
|
export async function deleteNumberingRule(ruleId: string): Promise<ApiResponse<void>> {
|
|
try {
|
|
const response = await apiClient.delete(`/numbering-rules/${ruleId}`);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "규칙 삭제 실패" };
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 코드 미리보기 (순번 증가 없음)
|
|
* 화면 표시용으로 사용
|
|
* @param ruleId 채번 규칙 ID
|
|
* @param formData 폼 데이터 (카테고리 기반 채번 시 사용)
|
|
*/
|
|
export async function previewNumberingCode(
|
|
ruleId: string,
|
|
formData?: Record<string, unknown>
|
|
): Promise<ApiResponse<{ generatedCode: string }>> {
|
|
// ruleId 유효성 검사
|
|
if (!ruleId || ruleId === "undefined" || ruleId === "null") {
|
|
return { success: false, error: "채번 규칙 ID가 설정되지 않았습니다" };
|
|
}
|
|
|
|
try {
|
|
const response = await apiClient.post(`/numbering-rules/${ruleId}/preview`, {
|
|
formData: formData || {},
|
|
});
|
|
if (!response.data) {
|
|
return { success: false, error: "서버 응답이 비어있습니다" };
|
|
}
|
|
return response.data;
|
|
} catch (error: unknown) {
|
|
const err = error as { response?: { data?: { error?: string; message?: string } }; message?: string };
|
|
const errorMessage =
|
|
err.response?.data?.error ||
|
|
err.response?.data?.message ||
|
|
err.message ||
|
|
"코드 미리보기 실패";
|
|
return { success: false, error: errorMessage };
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 코드 할당 (저장 시점에 실제 순번 증가)
|
|
* 실제 저장할 때만 호출
|
|
*/
|
|
export async function allocateNumberingCode(
|
|
ruleId: string
|
|
): Promise<ApiResponse<{ generatedCode: string }>> {
|
|
try {
|
|
const response = await apiClient.post(`/numbering-rules/${ruleId}/allocate`);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "코드 할당 실패" };
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @deprecated 기존 generateNumberingCode는 previewNumberingCode를 사용하세요
|
|
*/
|
|
export async function generateNumberingCode(
|
|
ruleId: string
|
|
): Promise<ApiResponse<{ generatedCode: string }>> {
|
|
console.warn("generateNumberingCode는 deprecated. previewNumberingCode 사용 권장");
|
|
return previewNumberingCode(ruleId);
|
|
}
|
|
|
|
// 하위 호환성을 위한 별칭
|
|
export const generateCode = generateNumberingCode;
|
|
|
|
export async function resetSequence(ruleId: string): Promise<ApiResponse<void>> {
|
|
try {
|
|
const response = await apiClient.post(`/numbering-rules/${ruleId}/reset`);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return { success: false, error: error.message || "시퀀스 초기화 실패" };
|
|
}
|
|
}
|
|
|
|
// ====== 테스트용 API (numbering_rules 테이블 사용) ======
|
|
|
|
/**
|
|
* [테스트] 테스트 테이블에서 채번규칙 목록 조회
|
|
* numbering_rules 테이블 사용
|
|
* @param menuObjid 메뉴 OBJID (선택) - 필터링용
|
|
*/
|
|
export async function getNumberingRulesFromTest(
|
|
menuObjid?: number
|
|
): Promise<ApiResponse<NumberingRuleConfig[]>> {
|
|
try {
|
|
const url = menuObjid
|
|
? `/numbering-rules/test/list/${menuObjid}`
|
|
: "/numbering-rules/test/list";
|
|
const response = await apiClient.get(url);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.response?.data?.error || error.message || "테스트 규칙 목록 조회 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* [테스트] 테이블+컬럼 기반 채번규칙 조회
|
|
* numbering_rules 테이블 사용
|
|
*/
|
|
export async function getNumberingRuleByColumn(
|
|
tableName: string,
|
|
columnName: string
|
|
): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.get("/numbering-rules/test/by-column", {
|
|
params: { tableName, columnName },
|
|
});
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.response?.data?.error || error.message || "테이블+컬럼 기반 규칙 조회 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* [테스트] 테스트 테이블에 채번규칙 저장
|
|
* numbering_rules 테이블 사용
|
|
*/
|
|
export async function saveNumberingRuleToTest(
|
|
config: NumberingRuleConfig
|
|
): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.post("/numbering-rules/test/save", config);
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.response?.data?.error || error.message || "테스트 규칙 저장 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* [테스트] 테스트 테이블에서 채번규칙 삭제
|
|
* numbering_rules 테이블 사용
|
|
*/
|
|
export async function deleteNumberingRuleFromTest(
|
|
ruleId: string
|
|
): Promise<ApiResponse<void>> {
|
|
try {
|
|
const response = await apiClient.delete(`/numbering-rules/test/${ruleId}`);
|
|
return response.data;
|
|
} catch (error: unknown) {
|
|
const err = error as { response?: { data?: { error?: string } }; message?: string };
|
|
return {
|
|
success: false,
|
|
error: err.response?.data?.error || err.message || "테스트 규칙 삭제 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* [테스트] 카테고리 조건 포함 채번규칙 조회
|
|
*/
|
|
export async function getNumberingRuleByColumnWithCategory(
|
|
tableName: string,
|
|
columnName: string,
|
|
categoryColumn?: string,
|
|
categoryValueId?: number
|
|
): Promise<ApiResponse<NumberingRuleConfig>> {
|
|
try {
|
|
const response = await apiClient.get("/numbering-rules/test/by-column-with-category", {
|
|
params: { tableName, columnName, categoryColumn, categoryValueId },
|
|
});
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.response?.data?.error || error.message || "카테고리 조건 규칙 조회 실패",
|
|
};
|
|
}
|
|
}
|
|
|
|
/**
|
|
* [테스트] 테이블.컬럼별 모든 채번규칙 조회 (카테고리 조건별)
|
|
*/
|
|
export async function getRulesByTableColumn(
|
|
tableName: string,
|
|
columnName: string
|
|
): Promise<ApiResponse<NumberingRuleConfig[]>> {
|
|
try {
|
|
const response = await apiClient.get("/numbering-rules/test/rules-by-table-column", {
|
|
params: { tableName, columnName },
|
|
});
|
|
return response.data;
|
|
} catch (error: any) {
|
|
return {
|
|
success: false,
|
|
error: error.response?.data?.error || error.message || "테이블.컬럼별 규칙 목록 조회 실패",
|
|
};
|
|
}
|
|
}
|
|
|