Files
lcbp3/specs/200-fullstacks/226-document-chat-ui-pattern/quickstart.md
T
admin ea5499123e
CI / CD Pipeline / build (push) Failing after 3m57s
CI / CD Pipeline / deploy (push) Has been skipped
690519:1631 224 to 226 AI #01
2026-05-19 16:31:50 +07:00

71 lines
5.3 KiB
Markdown

// File: specs/200-fullstacks/226-document-chat-ui-pattern/quickstart.md
// Change Log:
// - 2026-05-19: Initial developer quickstart guide for Document Chat UI Pattern
# Developer Quickstart Guide: Document Chat UI Pattern
คู่มือแนะนำขั้นตอนการทำความเข้าใจ การทดสอบ และการตรวจสอบการทำงานของฟีเจอร์ AI Document Chat ในฝั่ง Frontend และการเชื่อมต่อกับ Backend AI Gateway (226)
---
## 1. การติดตั้งโค้ดและส่วนประกอบหลัก (Component Architecture)
โครงสร้างโฟลเดอร์ฝั่งไคลเอนต์จะอยู่ที่:
```text
frontend/components/ai/
├── ai-chat-panel.tsx # คอมโพเนนต์หลักที่ประกอบด้วย Sheet / Panel สำหรับแต่ละ Breakpoint
├── ai-chat-toggle.tsx # ปุ่มสำหรับสลับเปิด/ปิด Chat Panel (และปุ่มลอยสำหรับอุปกรณ์พกพา)
├── ai-chat-messages.tsx # รายการประวัติสนทนาและการเรนเดอร์ Message Bubbles ตาม Role
├── ai-chat-input.tsx # กล่องพิมพ์คำสั่ง ปุ่มส่งคำถาม และปุ่มลัด
├── ai-suggested-actions.tsx # แถบ Badge Chip แนะนำการทำงานต่อเนื่อง
└── hooks/
└── use-ai-chat.ts # คอนเท็กซ์และฮุกของ React / TanStack Query ในการจัดการ API และ State
```
---
## 2. การเปิดใช้งานและตั้งค่าพัฒนา (Development Setup)
### 2.1 รันระบบ Frontend ในโหมดพัฒนา
เปิด PowerShell (เนื่องจากทำงานบน Windows OS ตามกฎ) และรันคำสั่ง:
```powershell
cd frontend
pnpm dev
```
ระบบจะเริ่มต้นที่พอร์ต `http://localhost:3000`
### 2.2 โครงสร้าง API Mockup สำหรับการพัฒนาช่วงแรก
ในระหว่างการพัฒนาฝั่ง Frontend สามารถเปิดการใช้งาน Mock Data ใน `use-ai-chat.ts` หรือจำลองการทำงานโดยการทดสอบผ่าน `/api/ai/chat` Mock Route ได้
---
## 3. ขั้นตอนการทดสอบการใช้งานด้วยตนเอง (Manual Testing Steps)
### 3.1 การตรวจสอบบน Desktop (ขนาดหน้าจอ ≥ 1024px)
1. เข้าสู่หน้าเอกสาร เช่น `/rfas/019505a1-7c3e-7000-8000-abc123def456`
2. มองหาปุ่ม **AI Chat** ทางขวาบนของเอกสาร
3. คลิกปุ่มเพื่อเปิดใช้งาน Chat Panel (จะเห็นการ Slide-in เข้ามาจากทางขวาอย่างราบรื่นใช้เวลา 200ms)
4. พิมพ์ทดสอบสนทนาในช่องพิมพ์ หรือกดคีย์ลัด `Ctrl + .` เพื่อเปิด/ปิด Panel
### 3.2 การตรวจสอบความเข้ากันได้ของการแสดงผล (Responsive Test)
1. เปิด Developer Tools ในเว็บเบราว์เซอร์ แล้วเลือกขนาดหน้าจอเป็น Tablet (768px - 1023px)
2. ตรวจสอบว่าขนาดของ Panel กว้างขึ้นเป็นประมาณ 30% ของ viewport หรือไม่
3. เปลี่ยนขนาดหน้าจอเป็น Mobile (< 768px)
4. ยืนยันว่าปุ่มสลับกลายเป็นปุ่มลอย และเมื่อกดแล้วแชทเลื่อนขึ้นมาจากด้านล่าง (Bottom Sheet สูง 60% ของจอ)
---
## 4. การรันชุดทดสอบอัตโนมัติ (Automated Testing)
ฟีเจอร์นี้ครอบคลุมการตรวจสอบความถูกต้องด้วยชุดทดสอบผ่าน **Vitest** ในฝั่ง Frontend:
```powershell
# รันการทดสอบทั้งหมดของ AI module
cd frontend
pnpm test components/ai
```
### สิ่งที่ชุดทดสอบจะยืนยัน:
- `ai-chat-panel.tsx` สามารถปิดและเปิดได้จริงเมื่อรับคำสั่ง Action
- `use-ai-chat.ts` สามารถแปลงและแนบพารามิเตอร์ `contextType` และ `contextPublicId` ได้อย่างสมบูรณ์โดยไม่มีการใช้ Integer ID หลุดออกไป (Tier 1 UUID Compliance)