Files
kebab/tasks/phase-9-ui.md
altair823 f9714aa5cb docs(rename): kb → kebab — README, tasks/, docs/, design doc, report
마지막 commit. 모든 .md 안의 `kb` 단어 일괄 갱신.

- 19 개 crate 이름 (`kb-core`, `kb-app`, …) → `kebab-*` (Rust 모듈
  path 표기 `kb_*` → `kebab_*` 포함).
- 미래 component (`kb-tui`, `kb-desktop`, `kb-asr-whisper`, `kb-ocr`,
  `kb-mcp`, `kb-vlm`, `kb-rerank`, `kb-vision-ocr`, `kb-index`,
  `kb-smoke`, `kb-architecture`) → `kebab-*` (P6+ 가 시작될 때
  같은 prefix 사용).
- CLI 명령 예제: `kb ingest` / `kb search` / `kb ask` / `kb init` /
  `kb doctor` / `kb inspect` / `kb list` / `kb eval` →
  `kebab <verb>`. fenced code block + 인라인 backtick 모두.
- XDG paths + env vars + binary 경로 (`target/release/kb` →
  `target/release/kebab`) 동기화.
- design doc / 최초 보고서 / SMOKE / HOTFIXES / phase epic / task
  spec 모든 reference 통일.
- task-decomposition.md 의 `git -c user.name=kb` 는 과거 git history
  기록용 author 정보라 그대로 유지 (실제 git history 의 author 는
  변경 불가).
- `tasks/phase-5-evaluation.md` 의 `status: planned` →
  `completed` 도 같이 (P5-1 + P5-2 PR 머지 후 미반영분).

## 검증

- `grep -rEn "\bkb-[a-z]|\bkb_[a-z]|\.config/kb\b|kb\.sqlite|\bKB_[A-Z]"
   --include="*.md"` 0 hits (task-decomposition.md 의 git author
  제외).
- 모든 file path reference 살아있음 (renamed file 들 모두 새 path
  로 update).

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-02 04:01:55 +00:00

121 lines
3.7 KiB
Markdown

---
phase: P9
title: "TUI + desktop app"
status: planned
depends_on: [P5]
source: kebab_local_rust_report.md §16, §17 Phase 9
---
# P9 — TUI + desktop app
## 목표
CLI 위에 사용성 레이어 추가. domain/검색/RAG 가 안정된 뒤 마지막에 붙임.
## 순서
```text
kebab-tui (먼저) → kebab-desktop (나중)
```
이유: TUI 는 domain 변화에 빠르게 적응 가능. desktop 은 packaging/배포 비용 큼.
---
## P9.A — kebab-tui (Ratatui)
### 산출 crate
- `kebab-tui` — Ratatui + crossterm 기반 terminal UI.
### 화면 구성
| 화면 | 내용 |
|------|------|
| Library | document 목록, tag/lang 필터, indexing 상태 |
| Search | 검색창 + 결과 list + preview pane (citation 포함) |
| Ask | RAG 질문창 + 답변 + citation 토글 |
| Inspect | document/chunk 상세 (heading path, source span, provenance) |
| Jobs | indexing/embedding/transcription 진행 |
### 키바인딩 1차
```text
Tab : 화면 전환
/ : 검색 모드
? : ask 모드
Enter : 결과 열기
g : citation 으로 점프 (외부 editor: $EDITOR +line file)
q : 종료
```
### 의존성 경계
- `kebab-tui``kebab-app` 만. parser/store/LLM 직접 호출 금지.
- 비동기 I/O (검색/ask) 는 `kebab-app` 비동기 wrapper 또는 thread + channel.
### 완료 조건
- [ ] document list / search / ask / inspect 4개 화면 동작
- [ ] 검색 결과 → editor 점프 (citation line 정확히)
- [ ] indexing job 진행률 표시
- [ ] CLI 와 동일 facade 호출 (기능 누락 0)
---
## P9.B — kebab-desktop
### 후보 비교
| 후보 | 장점 | 단점 |
|------|------|------|
| Tauri | Rust backend + web frontend. native webview, 작은 binary | web frontend 별도 stack (TS/JS) |
| egui/eframe | 순수 Rust, immediate-mode | 디자인 자유도/접근성 한계 |
추천: Tauri 1차. 기존 `kebab-app` facade 그대로 backend 로 노출. frontend 는 가볍게 (svelte/solid/vanilla).
### 산출 crate / 구조
- `kebab-desktop` (Tauri app crate)
- `kebab-desktop-frontend/` (web 자산)
Tauri command 는 `kebab-app` 함수 1:1 wrap. 신규 비즈니스 로직 추가 금지.
### 화면 구성 (1차)
| 패널 | 내용 |
|------|------|
| Library | document grid, multimodal 썸네일 (이미지/PDF/audio waveform) |
| Search | hybrid search + filter + citation preview |
| Ask | RAG chat. citation 클릭 시 source pane 동기화 |
| Source viewer | Markdown 렌더, PDF page viewer, image viewer (region overlay), audio player (segment seek) |
| Settings | model 선택, indexing 옵션, 경로 |
### Citation 클릭 동작
- Markdown: 내장 viewer 의 해당 line range scroll + highlight.
- PDF: page jump + (선택) span highlight.
- Image: region bounding box overlay.
- Audio: segment 시작 시각으로 seek + 재생.
### 의존성 경계
- frontend 는 Tauri command (= `kebab-app` wrapper) 만 호출. SQLite/LanceDB 직접 접근 금지.
- 모델 다운로드/실행은 backend 책임.
### 완료 조건
- [ ] document, image, PDF, audio citation 모두 viewer 에서 점프 동작
- [ ] hybrid search + RAG chat 동작
- [ ] indexing/embedding/transcription job UI 표시
- [ ] macOS dmg 배포 가능 (M4 기준 동작 확인)
---
## 공통 리스크 / 주의
- UI 부터 만들면 domain 흔들릴 때 비용 폭주. P5 까지 안정시킨 뒤 진입 (§16.3).
- TUI 와 desktop 모두 facade 만 호출. UI 안에 비즈니스 로직 들어가면 P10 같은 신규 phase 마다 양쪽 다시 손봐야 함.
- desktop packaging (코드 서명, notarization) 은 별도 작업. 1차 릴리스는 unsigned dev build OK.
- Tauri 채택 시 web stack 이 "최소"여야 함. 프레임워크 선택은 1주일 안에 결론.