iOS & watchOS speech-to-text app with AI voice keyboard, on-device RAG, and chat with your notes - powered by Apple Foundation Models, WhisperKit, NVIDIA Parakeet, and 20+ AI providers
Website •
App Store •
Documentation
Started as "I don't want to pay for WisprFlow." Ended up building something more flexible — on-device transcription, 20+ AI providers, on-device RAG with chat, OAuth sign-in, CLI agent bridge, and full control over your voice-to-text pipeline.
VivaDicta records speech, transcribes it using on-device or cloud models, and optionally processes the text through an AI provider — including Apple Foundation Models for free, fully on-device AI. Its key feature is a system-wide AI voice keyboard that lets you dictate and AI-process text directly into any app — Messages, WhatsApp, Slack, email, or anything else. The keyboard can also rewrite existing text in any app — select text, apply an AI preset, and get the result in place. Chat with your notes - ask questions about one note or many, powered by on-device RAG pipeline. Smart Search finds notes by meaning with on-device semantic search. Sign in with your ChatGPT, Gemini, or GitHub Copilot account via OAuth, or route AI through CLI agents on your Mac with VivAgents. Supports 11 transcription providers, 20+ AI providers, and syncs across devices (iOS/iPadOS/macOS/watchOS) via CloudKit.
Transcription
- On-device - WhisperKit (OpenAI Whisper), Parakeet (NVIDIA) - professional-grade models running entirely on your device
- Cloud - OpenAI, Groq, Cohere, Deepgram, ElevenLabs, Gemini, Mistral, Soniox, or any OpenAI-compatible endpoint
- 100+ languages with automatic detection
- Diarization - speaker-separated transcripts for meetings, interviews, and group conversations
- Filler word removal, paragraph formatting, custom word replacements
AI Presets
- 40+ built-in presets across categories: Rewrite, Style, Communication, Summarize, Social Media, Writing, Learn & Study, Translate
- AI Assistant - ask questions, fact-check, explain, reformat, or give instructions by voice
- Auto-Translation - speak in one language, get output in another
- Each result saved as a variation - compare different AI outputs side by side
- Create custom presets with full prompt control, mark favorites for quick access
Chat & RAG
- Single-note chat - ask questions about any transcription, extract action items, summarize
- Multi-note chat - select multiple notes, find common themes, compare ideas across recordings
- Smart Search Chat - ask a question in plain language, the AI searches your library semantically, reads relevant notes, and answers with source citations
- Chat tools - cross-note semantic search and web search, with results injected into LLM context as tool calls
- Fully on-device RAG pipeline - chunking, vector embedding, similarity search via LumoKit/VecturaKit - no server, no cloud, your data never leaves your device
- Smart Search bar - semantic search across all notes by meaning, not just keywords. On-device vector matching with relevance scores
- Citation-backed answers with tappable source references
- Reminder Suggestions - AI extracts actionable items from notes, review and send to Apple Reminders
- All chat modes work with Apple Foundation Models on-device (free, private) or any cloud AI provider
AI Providers
- 20+ providers: Apple Foundation Models (on-device, free), Anthropic, OpenAI, Gemini, GitHub Copilot, Groq, Mistral, Cerebras, Grok, OpenRouter, Vercel AI Gateway, HuggingFace, Ollama, and more
- OAuth sign-in for ChatGPT, Gemini, and GitHub Copilot - use your existing subscription, no API keys needed
- Bring your own AI via any OpenAI-compatible API endpoint
VivAgents — CLI Agent Bridge
- Route AI processing through CLI agents (Claude Code, Codex, Gemini CLI) running on your Mac or a remote server
- Use your existing CLI subscriptions instead of separate API keys
- Per-agent toggles, health monitoring, and automatic fallback to API keys if the server is unavailable
VivaModes
- Configurable profiles combining transcription provider, AI provider, model, preset, and language
- Each mode remembers its settings — switch contexts with one tap
- Clipboard context - AI uses copied text as context when processing your dictation (e.g., copy a message, then dictate your reply)
Custom AI Voice Keyboard
- System-wide voice keyboard - dictate into Messages, WhatsApp, Email, Notion, Slack, or any app
- Full transcription + AI processing pipeline right from the keyboard
- AI text processing in any app - select existing text in any app and rewrite, summarize, translate, or apply any preset without leaving it. The keyboard reads the text, sends it to the main app for AI processing via IPC, and replaces it in place
- Swipe to switch between modes without leaving the app you're typing in
Personalization
- Custom dictionary for names and terms (OpenClaw, Dr. Johnson, etc.)
- Word replacements and shortcuts (e.g., "my email" → support@vivadicta.com)
- Audio recordings saved alongside transcriptions
Apple Watch App
- Record voice notes directly on Apple Watch - audio transfers to iPhone via WatchConnectivity
- Background transcription - notes are processed before you open the iPhone app
- Watch face complications for one-tap recording
- Control Center button and Action Button support for start/stop toggle
- Viva Mode picker - switch modes right on the watch
Sync & Extensions
- iCloud sync across iPhone, iPad, and Mac — transcriptions, presets, custom dictionary, and API keys
- Home and Lock screen widgets and Control Center control to quickly record a note
- Live Activity for recording status
- Share Extension and Action Extension for importing audio files from other apps
- On-device RAG pipeline - chunked vector indexing, semantic search, and LLM synthesis via LumoKit/VecturaKit
- Apple Foundation Models for free, private on-device AI processing
- On-device STT via WhisperKit and NVIDIA Parakeet (CoreML / Apple Neural Engine)
- Swift 6 with strict concurrency
- SwiftUI + Liquid Glass
- SwiftData with CloudKit sync
- watchOS companion app with WatchConnectivity file transfer and background transcription
- Cross-process IPC using Darwin Notifications between 6 targets
- 7-stage text processing pipeline with customizable transforms
- App Intents — Siri and Shortcuts integration
- CoreSpotlight — indexed transcriptions for iOS spotlight search
- OAuth for ChatGPT, Gemini, and GitHub Copilot
- VivAgents client for routing AI through CLI agents on Mac/remote server
- iCloud Keychain for secure cross-device API key sync
graph LR
R[Recording] --> T[Transcription] --> AI[AI Processing] --> S[Storage]
S --> RAG[RAG Index]
RAG --> Chat[Chat & Search]
R -.- R1[AVAudioRecorder<br/>AVAudioEngine]
T -.- T1[WhisperKit · Parakeet<br/>Cloud STT providers]
AI -.- AI1[AIService<br/>20+ providers]
S -.- S1[SwiftData<br/>+ CloudKit]
RAG -.- RAG1[LumoKit/VecturaKit<br/>on-device vectors]
Chat -.- Chat1[Single · Multi · Smart Search]
Main app ↔ extensions IPC via AppGroupCoordinator (Darwin Notifications + Shared UserDefaults):
graph LR
K[Keyboard Extension] <-->|Darwin Notifications<br/>Shared UserDefaults| M[Main App]
W[Widget + Live Activity] <--> M
WA[Watch App] <-->|WatchConnectivity<br/>transferFile + sendMessage| M
SE[Share Extension] <--> M
AE[Action Extension] <--> M
Watch app ↔ iPhone communication via WatchConnectivity:
graph LR
WR[Watch Recorder] -->|transferFile<br/>audio + modeId| PC[PhoneWatchConnectivityService]
PC --> WP[WatchAudioProcessor]
WP --> T[TranscriptionManager]
WP --> AI[AIService]
WP --> S[SwiftData]
PC -->|updateApplicationContext<br/>mode list| WR
WR -->|sendMessage<br/>wake ping| PC
On-device RAG pipeline:
graph LR
N[Notes] -->|chunk + embed| VI[Vector Index<br/>LumoKit/VecturaKit]
Q[User Query] -->|embed| VS[Vector Search]
VI --> VS
VS -->|top-k chunks| LLM[LLM Synthesis<br/>Apple FM / Cloud AI]
LLM --> A[Answer + Citations]
Core components:
| Component | Role |
|---|---|
AppGroupCoordinator |
Cross-process communication using Darwin Notifications (custom keyboard, widgets, share, action extensions) |
PhoneWatchConnectivityService |
WatchConnectivity file reception, mode syncing, background transcription via WatchAudioProcessor |
WatchAppCoordinator |
Darwin notifications between watch app and watch widget extension (Control Center, Action Button) |
RecordViewModel |
Recording lifecycle, dual audio paths (normal + keyboard prewarm) |
TranscriptionManager |
Routes to on-device or cloud STT, post-processing pipeline |
AIService |
AI text processing, 20+ providers, OAuth, VivAgents, mode/API key management |
PresetManager |
Built-in + custom presets, CloudKit sync |
RAGIndexingService |
On-device vector indexing, chunking, semantic search via LumoKit/VecturaKit |
SmartSearchChatViewModel |
Smart Search Chat - semantic retrieval + LLM synthesis with source citations |
ChatViewModel |
Single-note chat with cross-note search capability |
MultiNoteChatViewModel |
Multi-note chat with theme extraction and comparison |
AudioPrewarmManager |
Continuous audio engine for keyboard extension low-latency recording |
See the documentation for detailed diagrams and flows.
Requirements:
- Xcode 26+
- iOS 18+ / watchOS 10+ deployment targets
# Clone
git clone https://github.com/n0an/VivaDicta.git
cd VivaDicta
# Open in Xcode
open VivaDicta.xcodeproj
# Or build from command line
xcodebuild build \
-scheme VivaDicta \
-workspace ./VivaDicta.xcodeproj/project.xcworkspace \
-destination generic/platform=iOS \
CODE_SIGNING_ALLOWED=NONote: On-device transcription models (WhisperKit, Parakeet) are downloaded on first use. Cloud AI providers work via API keys, OAuth sign-in (ChatGPT, Gemini, Copilot), or VivAgents server connection.
VivaDicta/
├── VivaDicta/ # Main app target
│ ├── Views/ # SwiftUI views + view models
│ ├── Models/ # SwiftData models (Transcription, Preset, etc.)
│ ├── Services/ # Core services
│ │ ├── AIEnhance/ # AIService, providers, prompts
│ │ ├── RAG/ # RAGIndexingService, vector search, chunking
│ │ └── Transcription/ # TranscriptionManager, STT providers
│ ├── Shared/ # AppGroupCoordinator, shared utilities
│ └── VivaDicta.docc/ # DocC documentation catalog
├── VivaDictaKeyboard/ # Custom keyboard extension
├── VivaDictaWidget/ # Widget + Live Activity
├── ShareExtension/ # Share extension
├── ActionExtension/ # Action extension
├── VivaDictaWatch Watch App/ # watchOS companion app
├── VivaDictaWatchWidget/ # Watch complications + Control Center control
├── documentation/ # Architecture docs, references
└── .github/workflows/ # CI: build check, Claude review, GitGuardian
- Documentation - recording pipeline, transcription system, AI processing, RAG & chat, text pipeline, preset system, AppGroupCoordinator, review request architecture
- RAG Architecture - on-device vector indexing, semantic search, and retrieval pipeline
- Chat Architecture - single-note, multi-note, Smart Search Chat, and tool system
- Text Processing Pipeline - 7-stage pipeline from raw audio to formatted text
- DocC Reference - generated DocC documentation
- Website Docs - user-facing guides with screenshots
Contributions are welcome. Please open an issue first to discuss what you'd like to change.
- Fork the repository
- Create your feature branch (
git checkout -b feature/my-feature) - Commit your changes
- Push to the branch (
git push origin feature/my-feature) - Open a Pull Request
The CI will run a build check on your PR automatically.
This project is licensed under the MIT License. See LICENSE for details.






