π A powerful CLI tool for English learning with real-time translation and intelligent note-taking
- πΌοΈ Image Translation: Copy and paste images from clipboard for instant translation
- π Text Translation: Fast and accurate text translation powered by Tencent Cloud
- π Voice Pronunciation: Real-time text-to-speech with natural English pronunciation
- π€ AI Word Analysis: Intelligent word analysis with definitions, examples, and usage
- π Notion Integration: Automatic vocabulary saving to your Notion database
- π― Adaptive Learning: Content adapted to your English proficiency level
- β¨οΈ Intuitive Interface: Clean terminal UI with keyboard shortcuts
# Install globally
npm install -g fnglish-notebook
# Run the application
fnglish
# or use alternative commands
fnglish-notebook
fnb- Node.js 18.0.0 or higher
- Grok API Key: Get from Grok AI
- Notion Integration & Page Setup (detailed steps below)
β
Windows: PowerShell support (Windows 7+)
β
macOS: Native AppleScript support
β
Linux: Requires xclip installation (Ubuntu: sudo apt install xclip)
Important: Before you start, please duplicate the official template to your Notion workspace. This template contains the required database structure.
π Click here to get the fnglish-v2 Template
- Visit Notion Integrations
- Click "New integration"
- Fill in the integration details:
- Name: Enter
Fnglish Notebookor any name you prefer - Associated workspace: Select your workspace
- Type: Choose "Internal integration"
- Name: Enter
- Click "Submit" to create
- Copy the Integration Token (format:
secret_xxx...) - this is your Notion API Key
- Create a Database: Create a new database in Notion (Full page or Inline).
- Ensure it has a Text property named
θι’(Back). - Ensure it has a Relation property named
ηη»(Deck). - Share this database with your Integration (click "..." -> "Add connections" -> search for your integration).
- Ensure it has a Text property named
- Create a Template Page: Create a page that will serve as the icon/cover template.
- Set your desired Icon and Cover image on this page.
- Share this page with your Integration as well.
- Database ID: Open your database as a full page. Copy the link.
- Link format:
https://www.notion.so/workspace/DATABASE_ID?v=... - The Database ID is the 32-character string before
?v=.
- Link format:
- Deck Page ID: Open the specific Deck Page you want to link to. Copy the link.
- Link format:
https://www.notion.so/workspace/page-title-DECK_PAGE_ID - The Deck Page ID is the 32-character string at the end.
- Link format:
- You must add the Integration to the page first, otherwise the API cannot access the page
- Page ID is a 32-character string, excluding other parts in the URL
- Ensure the Integration has edit permissions to create databases and add content
npm install -g fnglish-notebookImportant: Please complete the Notion Integration Setup steps above before running the application!
On first run, the app will guide you through the configuration:
-
English Level: Choose your English proficiency level
middle_school: Middle school level - Basic vocabulary and simple grammaruniversity: University level - Intermediate vocabulary and complex grammar structuresstudy_abroad: Study abroad level - Advanced vocabulary for academic/professional use
-
API Keys Configuration:
- Grok API Key: Get from Grok Console for AI word analysis
- Notion API Key: Integration Token from Step 1 above (
secret_xxx...) - Notion Database ID: Database ID from Step 3
- Notion Template ID: Template Page ID from Step 3
- Notion Deck ID: Deck Page ID from Step 3
- Type or paste English text in the input box
- Press Enter to translate and analyze
- Vocabulary automatically saved to Notion
- Copy an image containing text to your clipboard
- Press
Ctrl+Vin the application - Image text will be extracted, translated, and analyzed
- Vocabulary automatically saved to Notion
- Type English text in the input box
- Press
Ctrl+Sto hear the pronunciation - High-quality Google Text-to-Speech with natural female voice
Ctrl+C: Exit applicationCtrl+V: Paste and translate image from clipboardCtrl+S: Play voice pronunciation of input textEnter: Submit text for translation
Configuration is stored in ~/.fnglish-notebook and includes:
- English proficiency level
- API keys (Grok, Notion)
- Notion Database ID & Template ID
- Text Translation: Real-time text translation
- Image Translation: OCR and translation of images
- Built-in Configuration: No additional setup required
- Voice Quality: High-quality natural female voice (en-US-Standard-H)
- Language: American English pronunciation
- Built-in Configuration: No additional setup required
- Model:
grok-4-fast-non-reasoningfor fast responses - Features: Word definitions, parts of speech, example sentences
- Adaptive: Content difficulty adapted to your English level
- User-provided Database: Uses your existing database
- Structure: Title property for the word, 'θι’' property for details, 'ηη»' property for relation
- Template Support: Uses a template page for icon and cover styles
- Deck Linking: Automatically links new words to a specific Deck Page
- Smart Deduplication: Prevents duplicate entries
- Middle School: Age-appropriate vocabulary and basic grammar structures
- University: Complex vocabulary and advanced sentence patterns
- Study Abroad: Academic and professional terminology for international students
-
Image translation not working:
- Ensure image is copied to clipboard (not saved file)
- Try copying the image again
- Check if image contains clear, readable text
-
Notion database not saving:
- β Check if Integration is added to page: Most common issue! Must follow Step 2 above to invite integration to page
- β
Verify API Key format: Should be a long string starting with
secret_ - β Validate Page ID: Must be a 32-character string extracted from the share link
- β Check permissions: Integration must have edit permissions (Can edit) for the page
- Error example:
Notion API error: Object not foundβ Usually means integration not added to page
-
API errors:
- Verify all API keys are valid
- Check internet connection
- Ensure API quotas are not exceeded
-
Platform-specific issues:
- Windows:
- Ensure PowerShell is available (pre-installed on Windows 7+)
- If image paste fails, try running terminal as administrator
- Encountering
clipboard-fileserrors? Check Windows Fix Guide
- Linux:
- Image paste requires xclip installation:
sudo apt install xclip - May need additional configuration on Wayland desktop environments
- Image paste requires xclip installation:
- macOS:
- System will request accessibility permissions, please allow terminal access
- Windows:
We welcome contributions! Please feel free to submit issues and enhancement requests.
MIT License - see LICENSE file for details
- Tencent Cloud for translation services
- Google Cloud Text-to-Speech for voice pronunciation
- Grok AI for intelligent word analysis
- Notion for note-taking integration
- Ink for beautiful terminal UI
Made with β€οΈ for English learners worldwide

