pharmacy-pos-qr-system/docs/MEMBER_MEMO_SYSTEM.md
thug0bin 50825c597e feat: 특이(참고)사항 조회/수정 기능 구현
- 사용자 상세 모달에 특이사항 표시 (생일 옆 칸)
- 인라인 수정 UI (수정 버튼 → textarea → 저장/취소)
- PUT /api/members/{cuscode}/cusetc API 추가
- CD_PERSON.CUSETC 직접 UPDATE

Docs: MEMBER_MEMO_SYSTEM.md 문서 추가
- DB 구조, API 명세, 구현 현황 정리
2026-03-04 11:24:13 +09:00

273 lines
6.8 KiB
Markdown

# 환자 메모/특이사항 시스템 설계 문서
## 📅 작성일: 2026-03-04
---
## 1. DB 접속 정보
| 항목 | 값 |
|------|-----|
| 서버 | `192.168.0.4\PM2014` |
| 드라이버 | ODBC Driver 17 for SQL Server |
| 인증 | Windows 인증 (Trusted_Connection) |
| 데이터베이스 | PM_BASE (환자정보), PM_PRES (처방), PM_DRUG (약품) |
### 접속 코드 (pharmacy-pos-qr-system)
```python
from db.dbsetup import DatabaseManager
db = DatabaseManager()
session = db.get_session('PM_BASE')
```
---
## 2. 테이블 구조
### 2.1 CD_PERSON.CUSETC (특이참고사항)
**용도:** 단일 필드, 간단한 메모 (덮어쓰기 방식)
| 칼럼 | 타입 | 설명 |
|------|------|------|
| CUSETC | VARCHAR(2000) | 특이/참고사항 텍스트 |
**특징:**
- 한 환자당 하나의 값만 저장
- 새로 입력하면 기존 값 덮어씀
- 주로 미수금, 간단한 주의사항 등 기록
---
### 2.2 CD_PERSON_MEMO (메모 - 날짜별 누적)
**용도:** 별도 테이블, 상세 메모 이력 관리
| 칼럼 | 타입 | 설명 |
|------|------|------|
| CUSCODE | VARCHAR(10) | 고객코드 (PK) |
| MEMO_CODE | VARCHAR(5) | 메모코드 (PK) - 00001, 00002... |
| PHARMA_ID | VARCHAR(10) | 작성자명 (약사 이름 직접 저장) |
| MEMO_DATE | VARCHAR(8) | 작성일 (YYYYMMDD) |
| MEMO_TITLE | VARCHAR(40) | 메모 제목 |
| MEMO_Item | TEXT | 메모 내용 |
**특징:**
- 한 환자당 여러 메모 가능 (날짜별 누적)
- 복합 PK: CUSCODE + MEMO_CODE
- 작성자/날짜 추적 가능
---
## 3. PHARMA_ID 분석
### 현재 저장된 값 (2026-03-04 기준)
```
[김영빈] - 2448건
[박혜령] - 63건
[이충섭] - 4건
[시스템] - 2건
[이수지] - 1건
[지민구] - 1건
[PHARM001] - 1건
```
### 결론
- **직접 이름 저장 방식** (마스터 테이블 조인 불필요)
- 대부분 한글 이름, 일부 코드 형태 존재
- 별도 약사 마스터 테이블 연결 없이 독립적으로 저장
---
## 4. 실제 데이터 예시
### 예시 1: 김미성 (0000014615)
```
[특이사항 - CD_PERSON.CUSETC]
25/1 미수금:200
[메모 - CD_PERSON_MEMO]
메모코드: 00001
작성자: 김영빈
날짜: 20260304
제목: (없음)
내용: 신장투석.이식 가족력
```
### 예시 2: 박상호 (0000024142)
```
[특이사항 - CD_PERSON.CUSETC]
25/1 미수금:1400
[메모 - CD_PERSON_MEMO]
메모코드: 00003
작성자: 김영빈
날짜: 20260303
제목: 가루약
내용: 사미온만 아침,저녁
나머지 저녁으로
카나브는 알약으로 포장
```
### 예시 3: 안동옥 (0000001030)
```
[특이사항 - CD_PERSON.CUSETC]
25/1 미수금:200
[메모 - CD_PERSON_MEMO]
메모코드: 00001
작성자: 김영빈
날짜: 20260224
제목: (없음)
내용: 26.2.23-에터미 해모임과 고지혀약 피타로우에프 먹은지 한달 만에
간수피가 20대에서 120대로 수치가 오름.
고덱스 처방과 약 끊고 변화 확인 요망(010-6209-0796)
```
---
## 5. 기존 API 현황
### GET /api/members/search?q={검색어}
- 회원 검색 (이름 2자 이상, 전화번호)
- 응답에 `memo` (CUSETC 100자 미리보기) 포함
### GET /api/members/{cuscode}
- 회원 상세 조회
- `member.memo`: CUSETC 전체
- `memos[]`: CD_PERSON_MEMO 배열 (author, date, title, content)
---
## 6. 구현 계획
### 6.1 약사/직원 테이블 (신규 - SQLite)
**위치:** `backend/db/pharmacy_staff.db`
```sql
CREATE TABLE staff (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name VARCHAR(20) NOT NULL, -- 이름 (PHARMA_ID에 저장될 값)
role VARCHAR(20), -- 역할 (약사, 직원 등)
is_active BOOLEAN DEFAULT 1, -- 활성 여부
created_at DATETIME DEFAULT CURRENT_TIMESTAMP
);
-- 초기 데이터
INSERT INTO staff (name, role) VALUES ('김영빈', '약사');
INSERT INTO staff (name, role) VALUES ('박혜령', '약사');
```
**용도:**
- 메모 작성 시 드롭다운 목록 제공
- 향후 로그인 시스템 확장 대비
- 기본 작성자 설정 가능
### 6.2 UI 구현 방향
```
[회원 상세 페이지]
├── 기본 정보 (이름, 전화번호, 주민번호 등)
├── 특이(참고)사항
│ └── [단일 텍스트 영역] - 저장 시 덮어쓰기
└── 메모 (날짜별 누적)
├── [메모 목록] - 날짜순 정렬
│ └── 각 메모: 날짜, 작성자, 제목, 내용 미리보기
├── [새 메모 추가]
│ ├── 작성자 드롭다운 (staff 테이블에서)
│ ├── 제목 입력
│ └── 내용 입력
└── [메모 수정/삭제]
```
---
## 7. 현재 구현 현황 (2026-03-04)
### 7.1 특이(참고)사항 - 구현 완료 ✅
**위치:** https://mile.0bin.in/admin → 사용자 클릭 → 상세 모달
#### UI
```
┌──────────────────┬──────────────────┐
│ 🎂 생일 │ ⚠️ 특이사항 [✏️ 수정]│
│ 07월 12일 │ 개발약사2 │
└──────────────────┴──────────────────┘
```
- 생일 옆 칸에 표시 (공간 효율적 활용)
- 30자 초과 시 truncate, 클릭하면 펼침
- [✏️ 수정] 버튼 → 인라인 textarea → [저장] / [취소]
#### API
**조회:** `GET /admin/user/{userId}`
```json
{
"pos_customer": {
"cuscode": "0000000004",
"name": "김영빈",
"cusetc": "개발약사2"
}
}
```
**수정:** `PUT /api/members/{cuscode}/cusetc`
```json
// Request
{ "cusetc": "새로운 특이사항" }
// Response
{
"success": true,
"message": "특이사항이 저장되었습니다.",
"cusetc": "새로운 특이사항"
}
```
#### E2E 테스트 완료
```bash
# 검색
GET /api/members/search?q=김영빈 → cuscode: 0000000004
# 수정
PUT /api/members/0000000004/cusetc
Body: { "cusetc": "개발약사2 - 테스트 수정" }
→ 성공 ✅
# 확인
GET /api/members/search?q=김영빈
→ memo: "개발약사2 - 테스트 수정"
```
---
### 7.2 메모 (날짜별 누적) - 미구현 ⏳
**다음 단계:**
1. staff 테이블 생성 (SQLite)
2. 메모 CRUD API 구현
3. UI 구현 (메모 목록, 추가, 수정, 삭제)
---
## 8. 관련 파일
| 파일 | 설명 |
|------|------|
| `backend/app.py` | Flask API (3740행~ 회원 관련, CUSETC 수정 API 포함) |
| `backend/db/dbsetup.py` | DB 연결 설정 |
| `backend/templates/admin.html` | 어드민 대시보드 (사용자 상세 모달, 특이사항 UI) |
| `backend/templates/admin_members.html` | 회원 관리 페이지 |
| `person-lookup-web-local/models.py` | SQLAlchemy 모델 정의 |
---
## 9. 참고사항
- PIT3000 원본 테이블은 직접 수정 (INSERT/UPDATE)
- 마일리지 시스템(SQLite)과 별개로 MSSQL에 저장
- CD_PERSON_MEMO는 복합키(CUSCODE + MEMO_CODE) 주의