# 입력 타입과 세부 타입 시스템 가이드 ## 📋 개요 화면 관리 시스템에서 사용자가 **입력 타입**과 **세부 타입**을 2단계로 선택할 수 있는 시스템입니다. ### 구조 1. **입력 타입 (Input Type)**: 테이블 타입 관리에서 정의한 8개 핵심 타입 2. **세부 타입 (Detail Type)**: 입력 타입의 구체적인 구현 방식 (웹타입) ``` 입력 타입 (PropertiesPanel에서 선택) ↓ 세부 타입 (DetailSettingsPanel에서 선택) ↓ 세부 설정 (DetailSettingsPanel에서 설정) ``` --- ## 🎯 8개 핵심 입력 타입과 세부 타입 ### 1. **텍스트 (text)** 사용 가능한 세부 타입: - `text` - 일반 텍스트 입력 - `email` - 이메일 주소 입력 - `tel` - 전화번호 입력 - `url` - 웹사이트 주소 입력 - `textarea` - 여러 줄 텍스트 입력 - `password` - 비밀번호 입력 (마스킹) ### 2. **숫자 (number)** 사용 가능한 세부 타입: - `number` - 정수 숫자 입력 - `decimal` - 소수점 포함 숫자 입력 ### 3. **날짜 (date)** 사용 가능한 세부 타입: - `date` - 날짜 선택 (YYYY-MM-DD) - `datetime` - 날짜와 시간 선택 - `time` - 시간 선택 (HH:mm) ### 4. **코드 (code)** 세부 타입: - `code` - 공통 코드 선택 (세부 타입 고정) - 코드 카테고리는 상세 설정에서 선택 ### 5. **엔티티 (entity)** 세부 타입: - `entity` - 다른 테이블 참조 (세부 타입 고정) - 참조 테이블은 상세 설정에서 선택 ### 6. **선택박스 (select)** 사용 가능한 세부 타입: - `select` - 기본 드롭다운 선택 - `dropdown` - 검색 기능이 있는 드롭다운 ### 7. **체크박스 (checkbox)** 사용 가능한 세부 타입: - `checkbox` - 단일 체크박스 - `boolean` - On/Off 스위치 ### 8. **라디오버튼 (radio)** 세부 타입: - `radio` - 라디오 버튼 그룹 (세부 타입 고정) --- ## 🔧 사용 방법 ### 1. PropertiesPanel - 입력 타입 선택 위젯 컴포넌트를 선택하면 **속성 편집** 패널에서 입력 타입을 선택할 수 있습니다. ```typescript // 입력 타입 선택 ``` **동작:** - 입력 타입을 선택하면 해당 타입의 **기본 세부 타입**이 자동으로 설정됩니다 - 예: `text` 입력 타입 선택 → `text` 세부 타입 자동 설정 ### 2. DetailSettingsPanel - 세부 타입 선택 **상세 설정** 패널에서 선택한 입력 타입의 세부 타입을 선택할 수 있습니다. ```typescript // 세부 타입 선택 ``` **동작:** - 입력 타입에 해당하는 세부 타입만 표시됩니다 - 세부 타입을 변경하면 `widgetType` 속성이 업데이트됩니다 ### 3. DetailSettingsPanel - 세부 설정 세부 타입을 선택한 후, 해당 타입의 상세 설정을 할 수 있습니다. 예: - **날짜 (date)**: 날짜 형식, 최소/최대 날짜 등 - **숫자 (number)**: 최소/최대값, 소수점 자리수 등 - **코드 (code)**: 코드 카테고리 선택 - **엔티티 (entity)**: 참조 테이블, 표시 컬럼 선택 --- ## 📁 파일 구조 ### 새로 추가된 파일 #### `frontend/types/input-type-mapping.ts` 입력 타입과 세부 타입 매핑 정의 ```typescript // 8개 핵심 입력 타입 export type BaseInputType = "text" | "number" | "date" | ...; // 입력 타입별 세부 타입 매핑 export const INPUT_TYPE_DETAIL_TYPES: Record; // 유틸리티 함수들 export function getBaseInputType(webType: WebType): BaseInputType; export function getDetailTypes(baseInputType: BaseInputType): DetailTypeOption[]; export function getDefaultDetailType(baseInputType: BaseInputType): WebType; ``` ### 수정된 파일 #### `frontend/components/screen/panels/PropertiesPanel.tsx` - 입력 타입 선택 UI 추가 - 웹타입 선택 → 입력 타입 선택으로 변경 #### `frontend/components/screen/panels/DetailSettingsPanel.tsx` - 세부 타입 선택 UI 추가 - 입력 타입 표시 - 세부 타입 목록 동적 생성 --- ## 🎨 UI 레이아웃 ``` ┌─────────────────────────────────────────────────────────────┐ │ 속성 편집 (PropertiesPanel) │ ├─────────────────────────────────────────────────────────────┤ │ 입력 타입: [텍스트 ▼] ← 8개 중 선택 │ │ 세부 타입은 "상세 설정"에서 선택하세요 │ └─────────────────────────────────────────────────────────────┘ ┌─────────────────────────────────────────────────────────────┐ │ 상세 설정 (DetailSettingsPanel) │ ├─────────────────────────────────────────────────────────────┤ │ 입력 타입: [text] │ ├─────────────────────────────────────────────────────────────┤ │ 세부 타입 선택: │ │ [일반 텍스트 ▼] ← 입력 타입에 따라 동적으로 변경 │ │ - 일반 텍스트 │ │ - 이메일 │ │ - 전화번호 │ │ - URL │ │ - 여러 줄 텍스트 │ │ - 비밀번호 │ ├─────────────────────────────────────────────────────────────┤ │ [세부 설정 영역] │ │ (선택한 세부 타입에 맞는 설정 패널) │ └─────────────────────────────────────────────────────────────┘ ``` --- ## 🔄 데이터 흐름 ### 1. 새 컴포넌트 생성 시 ``` 테이블 컬럼 드래그 → 컬럼의 dataType 분석 → 입력 타입 자동 선택 (text, number, date 등) → 기본 세부 타입 자동 설정 (text, number, date 등) ``` ### 2. 입력 타입 변경 시 ``` PropertiesPanel에서 입력 타입 선택 → 해당 입력 타입의 기본 세부 타입 설정 → DetailSettingsPanel 세부 타입 목록 업데이트 ``` ### 3. 세부 타입 변경 시 ``` DetailSettingsPanel에서 세부 타입 선택 → widgetType 업데이트 → 해당 세부 타입의 설정 패널 표시 ``` --- ## 🚀 확장 가능성 ### 세부 타입 추가 새로운 세부 타입을 추가하려면: 1. `frontend/types/input-type-mapping.ts`의 `INPUT_TYPE_DETAIL_TYPES`에 추가 2. 해당 세부 타입의 설정 패널 구현 3. DB의 `web_types` 테이블에 레코드 추가 ### 입력 타입 추가 새로운 입력 타입을 추가하려면: 1. `BaseInputType` 타입에 추가 2. `BASE_INPUT_TYPE_OPTIONS`에 옵션 추가 3. `INPUT_TYPE_DETAIL_TYPES`에 세부 타입 목록 정의 4. 테이블 타입 관리 시스템 업데이트 --- ## ✅ 체크리스트 - [x] 8개 핵심 입력 타입 정의 - [x] 입력 타입별 세부 타입 매핑 - [x] PropertiesPanel에 입력 타입 선택 UI 추가 - [x] DetailSettingsPanel에 세부 타입 선택 UI 추가 - [x] 입력 타입 변경 시 기본 세부 타입 자동 설정 - [x] 세부 타입 변경 시 widgetType 업데이트 - [x] 타입 안전성 보장 (TypeScript) --- ## 📝 사용 예시 ### 텍스트 입력 필드 생성 1. **PropertiesPanel**에서 입력 타입을 "텍스트"로 선택 2. **DetailSettingsPanel**로 이동 3. 세부 타입에서 "이메일" 선택 4. 이메일 형식 검증 등 세부 설정 입력 ### 날짜 입력 필드 생성 1. **PropertiesPanel**에서 입력 타입을 "날짜"로 선택 2. **DetailSettingsPanel**로 이동 3. 세부 타입에서 "날짜+시간" 선택 4. 날짜 형식, 최소/최대 날짜 등 설정 --- ## 🐛 문제 해결 ### 세부 타입이 표시되지 않음 - 입력 타입이 올바르게 설정되었는지 확인 - `getDetailTypes()` 함수가 올바른 값을 반환하는지 확인 ### 입력 타입 변경 시 세부 타입이 초기화되지 않음 - `getDefaultDetailType()` 함수 확인 - `onUpdateProperty("widgetType", ...)` 호출 확인 --- ## 📚 참고 자료 - [테이블 타입 관리 개선 계획서](../테이블_타입_관리_개선_계획서.md) - [테이블 타입 관리 개선 사용 가이드](../테이블_타입_관리_개선_사용_가이드.md) - [화면관리 시스템 개요](./screen-management-system.md)