Files
vexplor/화면관리_및_테이블관리_개선사항_목록.md

387 lines
10 KiB
Markdown
Raw Normal View History

# 화면관리 및 테이블관리 시스템 개선사항 목록
## 문서 정보
- **작성일**: 2025-11-03
- **목적**: 사용자 피드백 기반 개선사항 정리
- **우선순위**: 높음
---
## 1. 화면관리 (Screen Management) 개선사항
### 1.1 리스트 컬럼 Width 조절 기능
**현재 문제**: 리스트 컬럼의 너비가 고정되어 있어 사용자가 조절할 수 없음
**요구사항**:
- 사용자가 각 컬럼의 너비를 드래그로 조절할 수 있어야 함
- 조절된 너비는 저장되어 다음 접속 시에도 유지되어야 함
- 최소/최대 너비 제한 필요
**구현 방안**:
- 컬럼 헤더에 리사이저 핸들 추가
- `ComponentData` 인터페이스에 `columnWidths` 속성 추가
- PropertiesPanel에서 개별 컬럼 너비 설정 UI 제공
**관련 파일**:
- `frontend/components/screen/ScreenDesigner.tsx`
- `frontend/components/screen/RealtimePreview.tsx`
- `frontend/types/screen.ts`
---
### 1.2 되돌리기(Undo) 단축키 에러 수정
**현재 문제**: 되돌리기 단축키(Ctrl+Z/Cmd+Z) 실행 시 에러 발생
**요구사항**:
- 되돌리기 기능이 안정적으로 작동해야 함
- 다시 실행(Redo) 기능도 함께 제공 (Ctrl+Y/Cmd+Shift+Z)
**구현 방안**:
- 히스토리 스택 구현 (최대 50개 상태 저장)
- `useUndo` 커스텀 훅 생성
- 키보드 단축키 이벤트 리스너 추가
**관련 파일**:
- `frontend/hooks/useUndo.ts` (신규 생성)
- `frontend/components/screen/ScreenDesigner.tsx`
---
### 1.3 리스트 헤더 스타일 개선
**현재 문제**: 리스트 헤더가 눈에 잘 띄지 않음
**요구사항**:
- 헤더가 시각적으로 구분되어야 함
- 배경색, 폰트 굵기, 테두리 등으로 강조
**구현 방안**:
- 헤더 기본 스타일 변경:
- 배경색: `bg-muted``bg-primary/10`
- 폰트: `font-medium``font-semibold`
- 하단 테두리: `border-b-2 border-primary`
**관련 파일**:
- `frontend/components/screen/RealtimePreview.tsx`
- `frontend/components/screen-viewer/InteractiveScreenViewer.tsx`
---
### 1.4 텍스트 줄바꿈 문제 방지
**현재 문제**: 화면을 줄였을 때 텍스트가 2줄로 나뉘거나 깨지는 현상
**요구사항**:
- 텍스트가 항상 1줄로 표시되어야 함
- 긴 텍스트는 말줄임표(...) 처리
**구현 방안**:
- 모든 텍스트 요소에 다음 클래스 적용:
```tsx
className="truncate whitespace-nowrap overflow-hidden"
```
- 툴팁으로 전체 텍스트 표시
**관련 파일**:
- 모든 컴포넌트의 텍스트 렌더링 부분
---
### 1.5 수정 모달 자동 닫기
**현재 문제**: 수정 완료 후 모달이 자동으로 닫히지 않음
**요구사항**:
- 수정 완료 시 모달이 즉시 닫혀야 함
- 성공 메시지 표시 후 닫기
**구현 방안**:
```typescript
const handleUpdate = async () => {
const result = await updateData(formData);
if (result.success) {
toast.success("수정이 완료되었습니다");
setIsModalOpen(false); // 모달 닫기
refreshList(); // 목록 새로고침
}
};
```
**관련 파일**:
- `frontend/components/screen-viewer/InteractiveScreenViewer.tsx`
---
### 1.6 테이블 Align 조절 기능
**현재 문제**: 테이블 컬럼의 정렬(align)을 사용자가 조절할 수 없음
**요구사항**:
- 각 컬럼의 정렬을 left/center/right로 설정 가능해야 함
- 숫자 타입은 기본적으로 right 정렬
**구현 방안**:
- `TableColumnConfig` 인터페이스에 `align` 속성 추가
- PropertiesPanel에서 정렬 선택 UI 제공
- 컬럼 타입별 기본 정렬 설정
**관련 파일**:
- `frontend/types/screen.ts`
- `frontend/components/screen/PropertiesPanel.tsx`
---
### 1.7 숫자 천 단위 콤마 표시
**현재 문제**: 숫자가 콤마 없이 표시됨
**요구사항**:
- 모든 숫자는 천 단위마다 콤마(,)를 찍어야 함
- 예: 1000000 → 1,000,000
**구현 방안**:
```typescript
// 유틸리티 함수 생성
export const formatNumber = (value: number | string): string => {
const num = typeof value === "string" ? parseFloat(value) : value;
if (isNaN(num)) return "0";
return new Intl.NumberFormat("ko-KR").format(num);
};
```
**관련 파일**:
- `frontend/lib/utils/numberFormat.ts` (신규 생성)
- 모든 숫자 표시 컴포넌트
---
### 1.8 Drilldown UI 개선
**현재 문제**: 화면이 횡으로 너무 길게 나열됨
**요구사항**:
- 계층적 구조로 정보 표시
- 펼치기/접기 기능으로 공간 절약
**구현 방안**:
- Accordion 컴포넌트 활용
- 탭 네비게이션 구조 적용
- 마스터-디테일 레이아웃 패턴
**관련 파일**:
- `frontend/components/screen/ScreenDesigner.tsx`
- `frontend/components/ui/accordion.tsx`
---
## 2. 테이블 관리 (Table Management) 개선사항
### 2.1 테이블 기본 정보 선택 기능
**현재 문제**: 테이블 기본 정보를 사용자가 선택할 수 없음
**요구사항**:
- 테이블 생성/수정 시 다음 정보를 선택 가능해야 함:
- 테이블 타입 (마스터/트랜잭션/코드)
- 카테고리
- 로그 사용 여부
- 버전 관리 여부
- 소프트 삭제 여부
**구현 방안**:
- `TableManagement.tsx`에 선택 UI 추가
- `CREATE TABLE` DDL 자동 생성 시 옵션 반영
**관련 파일**:
- `frontend/components/table/TableManagement.tsx`
- `backend-node/src/controllers/tableController.ts`
---
### 2.2 컬럼 추가 기능
**현재 문제**: 기존 테이블에 새 컬럼을 추가하는 기능 부족
**요구사항**:
- 테이블 수정 시 컬럼을 동적으로 추가할 수 있어야 함
- `ALTER TABLE ADD COLUMN` DDL 자동 생성
- 컬럼 순서 조정 기능
**구현 방안**:
```typescript
// 컬럼 추가 API
POST /api/table-management/tables/:tableName/columns
{
"columnName": "new_column",
"dataType": "VARCHAR(100)",
"nullable": true,
"defaultValue": null
}
```
**관련 파일**:
- `frontend/components/table/TableManagement.tsx`
- `backend-node/src/controllers/tableController.ts`
- `backend-node/src/services/ddlExecutionService.ts`
---
### 2.3 테이블 복제 기능
**현재 문제**: 기존 테이블의 구조를 재사용하기 어려움
**요구사항**:
- 기존 테이블을 복제하여 새 테이블 생성
- 다음 정보를 복사:
- 컬럼 구조 (이름, 타입, 제약조건)
- 인덱스 정의
- 외래키 관계 (선택적)
- 데이터는 복사하지 않음 (구조만)
**구현 방안**:
```typescript
// 테이블 복제 API
POST /api/table-management/tables/:sourceTableName/clone
{
"newTableName": "cloned_table",
"includeIndexes": true,
"includeForeignKeys": false,
"copyData": false
}
```
**구현 단계**:
1. 원본 테이블 정보 조회 (INFORMATION_SCHEMA)
2. DDL 스크립트 생성
3. 새 테이블 생성
4. 인덱스 및 제약조건 추가
5. 감사 로그 기록
**관련 파일**:
- `frontend/components/table/TableManagement.tsx`
- `backend-node/src/controllers/tableController.ts`
- `backend-node/src/services/ddlExecutionService.ts`
**참고 문서**:
- `/Users/kimjuseok/ERP-node/테이블_복제_기능_구현_계획서.md`
---
### 2.4 채번 Rule 관리 기능
**현재 문제**: 자동 채번 규칙을 사용자가 관리할 수 없음
**요구사항**:
- 채번 규칙 생성/수정/삭제 UI
- 규칙 형식:
- 접두사 (예: "PROD-")
- 날짜 포맷 (예: "YYYYMMDD")
- 일련번호 자릿수 (예: 5자리 → 00001)
- 구분자 (예: "-")
- 예시: `PROD-20251103-00001`
**구현 방안**:
```typescript
interface NumberingRule {
id: string;
ruleName: string;
prefix: string;
dateFormat?: "YYYY" | "YYYYMM" | "YYYYMMDD" | "YYYYMMDD-HH";
sequenceDigits: number;
separator: string;
resetPeriod: "none" | "daily" | "monthly" | "yearly";
currentSequence: number;
tableName: string;
columnName: string;
}
```
**관련 파일**:
- `frontend/components/table/NumberingRuleManagement.tsx` (신규 생성)
- `backend-node/src/controllers/numberingRuleController.ts` (신규 생성)
- `backend-node/src/services/numberingRuleService.ts` (신규 생성)
---
## 3. 제어 관리 (Flow Management) 개선사항
### 3.1 제목 클릭 시 노드 선택 해제
**현재 문제**: 제목을 입력할 때 백스페이스를 누르면 노드가 삭제됨
**요구사항**:
- 제목(플로우명) 입력란 클릭 시 노드 선택이 해제되어야 함
- 백스페이스 키가 텍스트 입력으로만 작동해야 함
**구현 방안**:
```typescript
const handleTitleClick = (e: React.MouseEvent) => {
e.stopPropagation(); // 이벤트 전파 중지
setSelectedNodes([]); // 노드 선택 해제
};
const handleTitleKeyDown = (e: React.KeyboardEvent) => {
e.stopPropagation(); // 백스페이스 키가 노드 삭제로 전파되지 않도록
};
<Input
value={flowName}
onClick={handleTitleClick}
onKeyDown={handleTitleKeyDown}
onChange={(e) => setFlowName(e.target.value)}
/>
```
**관련 파일**:
- `frontend/components/flow/FlowDesigner.tsx`
- `frontend/components/flow/FlowCanvas.tsx`
---
## 4. 우선순위 및 구현 일정
### 높음 (즉시 수정 필요)
1. **되돌리기 단축키 에러 수정** - 기능 오류
2. **수정 모달 자동 닫기** - 사용자 경험 저해
3. **제어관리 제목 입력 문제** - 데이터 손실 위험
4. **숫자 천 단위 콤마 표시** - 가독성 문제
### 중간 (2주 내 완료)
5. **리스트 컬럼 Width 조절**
6. **리스트 헤더 스타일 개선**
7. **텍스트 줄바꿈 문제 방지**
8. **테이블 Align 조절**
9. **컬럼 추가 기능**
### 낮음 (기능 추가)
10. **테이블 기본 정보 선택**
11. **테이블 복제 기능**
12. **Drilldown UI 개선**
13. **채번 Rule 관리**
---
## 5. 테스트 계획
각 개선사항 완료 시 다음을 확인:
### 기능 테스트
- [ ] 새 기능이 정상 작동함
- [ ] 기존 기능에 영향 없음
- [ ] 에러 처리가 적절함
### 사용자 경험 테스트
- [ ] UI가 직관적임
- [ ] 반응 속도가 빠름
- [ ] 모바일/태블릿 대응
### 성능 테스트
- [ ] 대량 데이터 처리 시 성능 저하 없음
- [ ] 메모리 누수 없음
---
## 6. 참고 문서
- [화면관리 시스템 현황](화면관리_및_테이블관리_개선사항_목록.md)
- [테이블 복제 기능 계획서](테이블_복제_기능_구현_계획서.md)
- [Shadcn/ui 레이아웃 패턴](docs/shadcn-ui-레이아웃-패턴-분석-보고서.md)
---
## 변경 이력
| 날짜 | 작성자 | 내용 |
|------|--------|------|
| 2025-11-03 | 개발팀 | 초안 작성 |