7.4 KiB
7.4 KiB
AutocompleteSearchInput 컴포넌트 사용 가이드
📌 이 컴포넌트는 무엇인가요?
검색 가능한 드롭다운 선택 박스입니다. 거래처, 품목, 직원 등을 검색해서 선택할 때 사용합니다.
⚙️ 패널 설정 방법
1. 기본 검색 설정 (필수)
테이블명
- 의미: 어디서 검색할 것인가?
- 예시:
customer_mng(거래처 테이블)
표시 필드
- 의미: 사용자에게 무엇을 보여줄 것인가?
- 예시:
customer_name→ 화면에 "삼성전자" 표시
값 필드
- 의미: 실제로 어떤 값을 가져올 것인가?
- 예시:
customer_code→ "CUST-0001" 가져오기
검색 필드 (선택)
- 의미: 어떤 컬럼으로 검색할 것인가?
- 예시:
customer_name,customer_code추가 - 동작: 이름으로도 검색, 코드로도 검색 가능
2. 값 필드 저장 위치 (고급, 선택)
저장 테이블
- 기본값: 화면의 연결 테이블에 자동 저장
- 변경 시: 다른 테이블에 저장 가능
저장 컬럼
- 기본값: 컴포넌트의 바인딩 필드
- 변경 시: 다른 컬럼에 저장 가능
💡 대부분은 기본값을 사용하면 됩니다!
📖 사용 예제
예제 1: 거래처 선택 (가장 일반적)
패널 설정
테이블명: customer_mng
표시 필드: customer_name
값 필드: customer_code
검색 필드: customer_name, customer_code
플레이스홀더: 거래처명 또는 코드 입력
동작
사용자 입력: "삼성"
드롭다운 표시: "삼성전자", "삼성물산", ...
선택: "삼성전자"
저장 값: "CUST-0001" (customer_code)
결과
order_mng 테이블
┌───────────┬───────────────┐
│ order_id │ customer_code │
├───────────┼───────────────┤
│ ORD-0001 │ CUST-0001 │ ✅
└───────────┴───────────────┘
예제 2: 거래처명을 직접 저장
패널 설정
테이블명: customer_mng
표시 필드: customer_name
값 필드: customer_name ← 이름을 가져옴
플레이스홀더: 거래처명 입력
동작
사용자 선택: "삼성전자"
저장 값: "삼성전자" (customer_name)
결과
order_mng 테이블
┌───────────┬───────────────┐
│ order_id │ customer_name │
├───────────┼───────────────┤
│ ORD-0001 │ 삼성전자 │ ✅
└───────────┴───────────────┘
예제 3: 품목 선택 (추가 정보 표시)
패널 설정
테이블명: item_mng
표시 필드: item_name
값 필드: item_code
검색 필드: item_name, item_code, category
플레이스홀더: 품목명, 코드, 카테고리로 검색
추가 정보 표시: ON
추가 필드: item_code, unit_price
동작
드롭다운:
┌────────────────────────────┐
│ 삼성 노트북 │
│ item_code: ITEM-0123 │
│ unit_price: 1,500,000 │
├────────────────────────────┤
│ LG 그램 노트북 │
│ item_code: ITEM-0124 │
│ unit_price: 1,800,000 │
└────────────────────────────┘
🎯 필드 선택 가이드
언제 표시 필드 ≠ 값 필드 인가?
대부분의 경우 (권장)
표시 필드: customer_name (이름 - 사람이 읽기 쉬움)
값 필드: customer_code (코드 - 데이터베이스에 저장)
이유:
✅ 외래키 관계 유지
✅ 데이터 무결성
✅ 이름이 바뀌어도 코드는 그대로
언제 표시 필드 = 값 필드 인가?
특수한 경우
표시 필드: customer_name
값 필드: customer_name
사용 케이스:
- 이름 자체를 저장해야 할 때
- 외래키가 필요 없을 때
- 간단한 참조용 데이터
💡 자주 묻는 질문
Q1. 저장 위치를 설정하지 않으면?
A: 자동으로 화면의 연결 테이블에 바인딩 필드로 저장됩니다.
화면: 수주 등록 (연결 테이블: order_mng)
컴포넌트 바인딩 필드: customer_code
→ order_mng.customer_code에 자동 저장 ✅
Q2. 값 필드와 저장 위치의 차이는?
A:
- 값 필드: 검색 테이블에서 무엇을 가져올지
- 저장 위치: 가져온 값을 어디에 저장할지
값 필드: customer_mng.customer_code (어떤 값?)
저장 위치: order_mng.customer_code (어디에?)
Q3. 검색 필드는 왜 여러 개 추가하나요?
A: 여러 방법으로 검색할 수 있게 하기 위해서입니다.
검색 필드: [customer_name, customer_code]
사용자가 "삼성" 입력 → customer_name에서 검색
사용자가 "CUST" 입력 → customer_code에서 검색
Q4. 추가 정보 표시는 언제 사용하나요?
A: 선택할 때 참고할 정보를 함께 보여주고 싶을 때 사용합니다.
추가 정보 표시: ON
추가 필드: [address, phone]
드롭다운:
┌────────────────────────────┐
│ 삼성전자 │
│ address: 서울시 서초구 │
│ phone: 02-1234-5678 │
└────────────────────────────┘
🚀 빠른 시작
1단계: 기본 설정만 입력
테이블명: [검색할 테이블]
표시 필드: [사용자에게 보여줄 컬럼]
값 필드: [저장할 컬럼]
2단계: 화면 디자이너에서 바인딩 필드 설정
컴포넌트 ID: customer_search
바인딩 필드: customer_code
3단계: 완료!
이제 사용자가 선택하면 자동으로 저장됩니다.
✅ 체크리스트
설정 전:
- 어느 테이블에서 검색할지 알고 있나요?
- 사용자에게 무엇을 보여줄지 정했나요?
- 어떤 값을 저장할지 정했나요?
설정 후:
- 검색이 정상적으로 되나요?
- 드롭다운에 원하는 항목이 보이나요?
- 선택 후 값이 저장되나요?
📊 설정 패턴 비교
| 패턴 | 표시 필드 | 값 필드 | 사용 케이스 |
|---|---|---|---|
| 1 | customer_name | customer_code | 이름 표시, 코드 저장 (일반적) |
| 2 | customer_name | customer_name | 이름 표시, 이름 저장 (특수) |
| 3 | item_name | item_code | 품목명 표시, 품목코드 저장 |
| 4 | employee_name | employee_id | 직원명 표시, ID 저장 |
🎨 실전 팁
1. 검색 필드는 2-3개가 적당
✅ 좋음: [name, code]
✅ 좋음: [name, code, category]
❌ 과함: [name, code, address, phone, email, ...]
2. 플레이스홀더는 구체적으로
❌ "검색..."
✅ "거래처명 또는 코드 입력"
✅ "품목명, 코드, 카테고리로 검색"
3. 추가 정보는 선택에 도움되는 것만
✅ 도움됨: 가격, 주소, 전화번호
❌ 불필요: 등록일, 수정일, ID
이 가이드로 autocomplete-search-input 컴포넌트를 쉽게 사용할 수 있습니다! 🎉