pi-thinking-translator
Pi extension package for translating configured visible assistant content blocks.
Package details
Install pi-thinking-translator from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:pi-thinking-translator- Package
pi-thinking-translator- Version
0.1.9- Published
- Jun 8, 2026
- Downloads
- 1,440/mo · 353/wk
- Author
- wplct
- License
- MIT
- Types
- extension
- Size
- 40.2 KB
- Dependencies
- 0 dependencies · 2 peers
Pi manifest JSON
{
"extensions": [
"./extensions/thinking-translator.ts"
]
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
README
Pi Thinking Translator
Translate Pi assistant thinking blocks for display without sending those translations back into future model context.
This package is a Pi extension for users who prefer to inspect visible assistant thinking/reasoning summaries in another language. By default, it only translates thinking blocks and does not choose a translator model automatically.
Features
- Translates configured visible assistant content blocks during assistant streaming.
- Uses a model already configured in Pi's model registry.
- Shows translations in a fixed widget above the editor instead of notifications, persistent session messages, or message-stream entries.
- For
thinking, splits content by paragraph using ashort title + blank line + bodyheuristic, then translates the previous completed paragraph as soon as the next paragraph begins. - Accumulates translations in a scrolling widget (last 20 body lines visible); clears automatically 30 seconds after the last update.
- Does not modify assistant messages, future model context, compaction input, or provider cache keys.
- Supports optional translation of normal assistant
textanswers when explicitly enabled. - Supports global config with project-level overrides.
Install
Install from npm:
pi install npm:pi-thinking-translator
Install from GitHub:
pi install git:github.com/wplct/pi-thinking-translator@v0.1.9
For local development from a checkout:
pi -e /absolute/path/to/pi-thinking-translator
Quick Start
Install the extension:
pi install npm:pi-thinking-translatorCreate a global config template from inside Pi:
/thinking-translator init --globalEdit the generated file:
~/.pi/agent/thinking-translator.jsonEnable translation and point the extension at a Pi model:
{ "enabled": true, "translatorModel": { "provider": "deepseek", "id": "deepseek-v4-flash" } }Check the effective config:
/thinking-translator status
The provider and id must match a model visible to Pi, for example a model configured in ~/.pi/agent/models.json or provided by a built-in provider.
Commands
/thinking-translator
/thinking-translator status
/thinking-translator clear
/thinking-translator init
/thinking-translator init --global
/thinking-translator init --project
/thinking-translatorand/thinking-translator statusshow the effective config, config file paths, and translator model availability./thinking-translator clearclears the current temporary translation widget./thinking-translator initcreates the global config, same as/thinking-translator init --global./thinking-translator init --globalcreates~/.pi/agent/thinking-translator.jsonif it does not already exist./thinking-translator init --projectcreates.pi/thinking-translator.jsonin the current project if it does not already exist.
The init commands create a disabled template and do not write a default model. You must explicitly set translatorModel and enable translation.
Configuration
The extension does not create a config file automatically and does not choose a default translator model. Built-in defaults are used unless you explicitly override them:
{
"enabled": true,
"targetLanguage": "Simplified Chinese",
"contentTypes": ["thinking"],
"minLatinChars": 250
}
Configuration files are optional partial overrides. They follow Pi's global/project convention:
- Built-in defaults
- Global config:
~/.pi/agent/thinking-translator.json - Project config:
.pi/thinking-translator.json
Project config overrides global config.
Example: global translator model
{
"enabled": true,
"translatorModel": {
"provider": "deepseek",
"id": "deepseek-v4-flash"
}
}
Example: enable normal answer translation for one project
Create .pi/thinking-translator.json in that project:
{
"contentTypes": ["thinking", "text"]
}
When text is enabled, the translated answer is shown in the same temporary widget. The extension still leaves the original assistant answer unchanged.
Options
| Option | Type | Default | Description |
|---|---|---|---|
enabled |
boolean | true |
Enables translation processing. If no translatorModel is configured, translation is skipped with a warning. |
targetLanguage |
string | "Simplified Chinese" |
Target language passed to the translator model. |
contentTypes |
string[] | ["thinking"] |
Visible assistant block types to translate. Supported values: thinking, reasoning, reasoning_summary, text. |
minLatinChars |
number | 250 |
Minimum number of Latin letters required before a block is considered translatable. |
translatorModel |
object | unset | Pi model reference: { "provider": "...", "id": "..." }. |
If translation is enabled but translatorModel is missing, cannot be found, or the Pi model registry is unavailable, the extension shows a warning and skips translation without affecting the main assistant message. If a configured model request or credential lookup fails, the extension keeps the original assistant message unchanged and shows a warning for the first occurrence of that error.
How It Works
- During an agent turn, the extension listens to assistant streaming events.
- For
thinking, it detects paragraph starts using ashort title + blank lineheuristic and treats eachtitle + bodygroup as one translatable paragraph. - When the next paragraph starts, it sends each newly completed paragraph to the configured Pi model with strict plain-text translation instructions.
- It cleans common model wrappers such as Markdown fences or
<text>...</text>tags and rejects empty outputs instead of displaying them. - It appends the cleaned translation to a fixed scrolling widget above the editor.
- It clears the widget automatically 30 seconds after the last translated update.
- It does not call
sendMessage, append a custom message, or return a modified assistant message, so translations are not written to the session file or future context.
This design lets you inspect translations during streaming while avoiding display translations becoming future model input or provider cache material.
Security Notes
Pi extensions run with full system permissions. Review extension source before installing third-party packages.
Translation backends may receive the visible blocks enabled by contentTypes, including final assistant answers if text is enabled. Use a local model if that content should not leave your machine.
The current implementation displays translations through a temporary widget instead of assistant messages, so display translations do not enter future model context or compaction summaries.
Development
pnpm install
pnpm check
Package Layout
pi-thinking-translator/
package.json
README.md
TODO.md
extensions/
thinking-translator.ts
tests/
thinking-translator.test.ts
Roadmap
- Add optional API translator backends.
- Add more runtime validation around context and compaction isolation.