mirror of
https://github.com/QwenLM/qwen-code.git
synced 2026-04-28 03:30:40 +00:00
feat: add contextual tips system with post-response context awareness (#2904)
* feat: add contextual tips system with post-response context awareness Add a context-aware tips system that proactively shows helpful tips based on session state. Post-response tips warn when context usage exceeds 80% or 95%, suggesting /compress. Startup tips rotate across sessions via LRU scheduling with cross-session persistence (~/.qwen/tip_history.json). Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: use value import for runtime values in useContextualTips Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: address PR review feedback - Use lastSessionTimestamp instead of totalShown for cross-session LRU - Move getTipHistory singleton from Tips.tsx to services/tips/index.ts - Defer TipHistory.load() when hideTips is true (no side effects) - Use os.tmpdir() in tests for cross-platform portability - Add proper translations for de/ja/pt/ru locale files - Accept TipHistory | null in useContextualTips Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: address Copilot review feedback - Validate tips field type in TipHistory.load() to handle corrupted JSON - Split approval-mode tip into platform-specific variants using ctx.platform - Add afterEach cleanup for temp files in all test suites - Guard useContextualTips against null tipHistory Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: import shared DEFAULT_TOKEN_LIMIT, harden tipHistory, set file permissions - Import DEFAULT_TOKEN_LIMIT from @qwen-code/qwen-code-core instead of hardcoding 1_048_576 in tipRegistry.ts and useContextualTips.ts - Add normalizeEntry() to defensively handle corrupted tip history entries - Write tip_history.json with mode 0o600 for privacy on multi-user systems Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: remove unused compressionThreshold from TipContext compressionThreshold was defined in TipContext but never used by any tip's isRelevant check. Remove it to avoid misleading consumers into thinking tips respect the user's compression settings. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * fix: sanitize sessionCount and getLastShown against corrupted tip history - Validate sessionCount is finite and non-negative in TipHistory.load() - Use normalizeEntry() in getLastShown() for corrupted lastSessionTimestamp Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com> * docs: add contextual tips user documentation Add docs/users/features/tips.md covering startup tips, post-response context warnings, tip history persistence, and the hideTips setting. Update settings.md description and register the new page in _meta.ts. --------- Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
6af0f37bb8
commit
b3bc42931e
19 changed files with 1147 additions and 79 deletions
|
|
@ -100,7 +100,7 @@ Settings are organized into categories. All settings should be placed within the
|
|||
| `ui.customThemes` | object | Custom theme definitions. | `{}` |
|
||||
| `ui.statusLine` | object | Custom status line configuration. A shell command whose output is shown in the footer's left section. See [Status Line](../features/status-line). | `undefined` |
|
||||
| `ui.hideWindowTitle` | boolean | Hide the window title bar. | `false` |
|
||||
| `ui.hideTips` | boolean | Hide helpful tips in the UI. | `false` |
|
||||
| `ui.hideTips` | boolean | Hide all tips (startup and post-response) in the UI. See [Contextual Tips](../features/tips). | `false` |
|
||||
| `ui.hideBanner` | boolean | Hide the application banner. | `false` |
|
||||
| `ui.hideFooter` | boolean | Hide the footer from the UI. | `false` |
|
||||
| `ui.showMemoryUsage` | boolean | Display memory usage information in the UI. | `false` |
|
||||
|
|
|
|||
|
|
@ -19,4 +19,5 @@ export default {
|
|||
hooks: 'Hooks',
|
||||
'status-line': 'Status Line',
|
||||
'scheduled-tasks': 'Scheduled Tasks',
|
||||
tips: 'Contextual Tips',
|
||||
};
|
||||
|
|
|
|||
54
docs/users/features/tips.md
Normal file
54
docs/users/features/tips.md
Normal file
|
|
@ -0,0 +1,54 @@
|
|||
# Contextual Tips
|
||||
|
||||
Qwen Code includes a contextual tips system that helps you discover features and stay aware of session state.
|
||||
|
||||
## Startup Tips
|
||||
|
||||
Each time you launch Qwen Code, a tip is shown in the header area. Tips are selected by priority first, then rotated across sessions using LRU (least-recently-used) scheduling among tips of the same priority, so you see a different tip each time.
|
||||
|
||||
New users see onboarding-focused tips during their first sessions:
|
||||
|
||||
| Sessions | Example tips |
|
||||
| -------- | ---------------------------------------------------- |
|
||||
| < 5 | Slash commands (`/`), Tab autocomplete |
|
||||
| < 10 | `QWEN.md` project context, `--continue` / `--resume` |
|
||||
| < 15 | Shell commands with `!` prefix |
|
||||
|
||||
After that, tips rotate through general features like `/compress`, `/approval-mode`, `/insight`, `/btw`, and more.
|
||||
|
||||
## Post-Response Tips
|
||||
|
||||
During a conversation, Qwen Code monitors your context window usage and shows tips when action may be needed:
|
||||
|
||||
| Context usage | Condition | Tip |
|
||||
| ------------- | ------------------------------ | ------------------------------------------------- |
|
||||
| 50-80% | After a few prompts in session | Suggests `/compress` to free up context |
|
||||
| 80-95% | — | Warns context is getting full |
|
||||
| >= 95% | — | Urgent: run `/compress` now or `/new` to continue |
|
||||
|
||||
Post-response tips have per-tip cooldowns to avoid being repetitive.
|
||||
|
||||
## Tip History
|
||||
|
||||
Tip display history is persisted at `~/.qwen/tip_history.json`. This file tracks:
|
||||
|
||||
- Session count (used for new-user tip selection)
|
||||
- Which tips have been shown and when (used for LRU rotation and cooldown)
|
||||
|
||||
You can safely delete this file to reset tip history.
|
||||
|
||||
## Disabling Tips
|
||||
|
||||
To hide all tips (both startup and post-response), set `ui.hideTips` to `true` in `~/.qwen/settings.json`:
|
||||
|
||||
```json
|
||||
{
|
||||
"ui": {
|
||||
"hideTips": true
|
||||
}
|
||||
}
|
||||
```
|
||||
|
||||
You can also toggle this in the settings dialog via the `/settings` command.
|
||||
|
||||
Tips are also automatically hidden when screen reader mode is enabled.
|
||||
Loading…
Add table
Add a link
Reference in a new issue