-
Notifications
You must be signed in to change notification settings - Fork 9.5k
feat: Blend educative tips with witty phrases during loading times (fun, subtle learning...) #10569
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 4 commits
b5e8dab
d8346c8
759f624
86e6971
a536fc3
0303a84
3e7cf51
ceb1f3c
c0ab1df
6299c0d
bba0d7e
30a1960
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -139,6 +139,151 @@ export const WITTY_LOADING_PHRASES = [ | |
| 'Releasing the HypnoDrones...', | ||
| ]; | ||
|
|
||
| export const INFORMATIVE_TIPS = [ | ||
| //settings tips start here | ||
| 'Set your preferred editor for opening files (/settings)...', | ||
| 'Toggle Vim mode for a modal editing experience (/settings)...', | ||
| 'Disable automatic updates if you prefer manual control (settings.json)...', | ||
| 'Turn off nagging update notifications (settings.json)...', | ||
| 'Enable checkpointing to recover your session after a crash (settings.json)...', | ||
| 'Change CLI output format to JSON for scripting (settings.json)...', | ||
| 'Personalize your CLI with a new color theme (/settings)...', | ||
| 'Create and use your own custom themes (settings.json)...', | ||
| 'Hide window title for a more minimal UI (/settings)...', | ||
| "Don't like these tips? You can hide them (/settings)...", | ||
| 'Hide the startup banner for a faster launch (/settings)...', | ||
| 'Reclaim vertical space by hiding the footer (/settings)...', | ||
| 'Show memory usage for performance monitoring (/settings)...', | ||
| 'Show line numbers in the chat for better context (/settings)...', | ||
|
||
| 'Show citations to see where the model gets information (/settings)...', | ||
| 'Disable loading phrases for a quieter experience (/settings)...', | ||
| 'Add custom witty phrases to the loading screen (settings.json)...', | ||
| 'Enable IDE integration mode for a seamless workflow (settings.json)...', | ||
|
||
| 'Help improve Gemini by enabling usage stats (/settings)...', | ||
|
||
| 'Choose a specific Gemini model for conversations (/settings)...', | ||
| 'Limit the number of turns in your session history (settings.json)...', | ||
| 'Automatically summarize large tool outputs to save tokens (settings.json)...', | ||
| 'Control when chat history gets compressed based on token usage (settings.json)...', | ||
| 'Define custom context file names, like CONTEXT.md (settings.json)...', | ||
| 'Set max directories to scan for context files (settings.json)...', | ||
| 'Expand your workspace with additional directories (settings.json)...', | ||
|
||
| 'Control how /memory refresh loads context files (settings.json)...', | ||
| 'Toggle respect for .gitignore files in context (/settings)...', | ||
| 'Toggle respect for .geminiignore files in context (/settings)...', | ||
| 'Enable recursive file search for @-file completions (settings.json)...', | ||
| 'Run tools in a secure sandbox environment (settings.json)...', | ||
| 'Use an interactive terminal for shell commands (settings.json)...', | ||
| 'Restrict available built-in tools (settings.json)...', | ||
| 'Exclude specific tools from being used (settings.json)...', | ||
| 'Bypass confirmation for trusted tools (settings.json)...', | ||
| 'Use a custom command for tool discovery (settings.json)...', | ||
| 'Define a custom command for calling discovered tools (settings.json)...', | ||
| 'Define and manage connections to MCP servers (settings.json)...', | ||
| 'Enable folder trust to enhance security (settings.json)...', | ||
| 'Change your authentication method (/settings)...', | ||
| 'Enforce auth type for enterprise use (settings.json)...', | ||
| 'Let Node.js auto-configure memory (settings.json)...', | ||
| 'Customize the DNS resolution order (settings.json)...', | ||
| 'Exclude env vars from the context (settings.json)...', | ||
| 'Configure a custom command for filing bug reports (settings.json)...', | ||
| 'Enable or disable telemetry collection (/settings)...', | ||
| 'Send telemetry data to a local file or GCP (settings.json)...', | ||
| 'Configure the OTLP endpoint for telemetry (settings.json)...', | ||
| 'Choose whether to log prompt content (settings.json)...', | ||
| 'Enable AI-powered prompt completion while typing (/settings)...', | ||
| 'Enable debug logging of keystrokes to the console (/settings)...', | ||
| 'Enable automatic session cleanup of old conversations (/settings)...', | ||
| 'Show Gemini CLI status in the terminal window title (/settings)...', | ||
| 'Use the entire width of the terminal for output (/settings)...', | ||
| 'Enable screen reader mode for better accessibility (/settings)...', | ||
| 'Skip the next speaker check for faster responses (/settings)...', | ||
| 'Use ripgrep for faster file content search (/settings)...', | ||
| 'Enable truncation of large tool outputs to save tokens (/settings)...', | ||
| 'Set the character threshold for truncating tool outputs (/settings)...', | ||
| 'Set the number of lines to keep when truncating outputs (/settings)...', | ||
| 'Enable policy-based tool confirmation via message bus (/settings)...', | ||
| 'Enable smart-edit tool for more precise editing (/settings)...', | ||
| 'Enable write_todos_list tool to generate task lists (/settings)...', | ||
| 'Enable model routing based on complexity (/settings)...', | ||
| 'Enable experimental subagents for task delegation (/settings)...', | ||
| //settings tips end here | ||
| // Keyboard shortcut tips start here | ||
| 'Close dialogs and suggestions with Esc...', | ||
| 'Cancel a request with Ctrl+C, or press twice to exit...', | ||
| 'Exit the app with Ctrl+D on an empty line...', | ||
| 'Clear your screen at any time with Ctrl+L...', | ||
| 'Toggle the debug console display with Ctrl+O...', | ||
| 'See full, untruncated responses with Ctrl+S...', | ||
| 'Show or hide tool descriptions with Ctrl+T...', | ||
| 'Toggle auto-approval (YOLO mode) for all tools with Ctrl+Y...', | ||
| 'Toggle shell mode by typing ! in an empty prompt...', | ||
| 'Insert a newline with a backslash (\\) followed by Enter...', | ||
| 'Navigate your prompt history with the Up and Down arrows...', | ||
| 'You can also use Ctrl+P (up) and Ctrl+N (down) for history...', | ||
| 'Submit your prompt to Gemini with Enter...', | ||
| 'Accept an autocomplete suggestion with Tab or Enter...', | ||
| 'Move to the start of the line with Ctrl+A or Home...', | ||
| 'Move to the end of the line with Ctrl+E or End...', | ||
| 'Move one character left or right with Ctrl+B/F or the arrow keys...', | ||
| 'Move one word left or right with Ctrl+Left/Right Arrow...', | ||
| 'Delete the character to the left with Ctrl+H or Backspace...', | ||
| 'Delete the character to the right with Ctrl+D or Delete...', | ||
| 'Delete the word to the left of the cursor with Ctrl+W...', | ||
| 'Delete the word to the right of the cursor with Ctrl+Delete...', | ||
| 'Delete from the cursor to the start of the line with Ctrl+U...', | ||
| 'Delete from the cursor to the end of the line with Ctrl+K...', | ||
| 'Clear the entire input prompt with a double-press of Esc...', | ||
| 'Paste from your clipboard with Ctrl+V...', | ||
| 'Open the current prompt in an external editor with Ctrl+X...', | ||
| 'In menus, move up/down with k/j or the arrow keys...', | ||
| 'In menus, select an item by typing its number...', | ||
| "If you're using an IDE, see the context with Ctrl+G...", | ||
| // Keyboard shortcut tips end here | ||
| // Command tips start here | ||
| 'Show version info with /about...', | ||
| 'Change your authentication method with /auth...', | ||
| 'File a bug report directly with /bug...', | ||
| 'List your saved chat checkpoints with /chat list...', | ||
| 'Save your current conversation with /chat save <tag>...', | ||
| 'Resume a saved conversation with /chat resume <tag>...', | ||
| 'Delete a conversation checkpoint with /chat delete <tag>...', | ||
| 'Share your conversation to a file with /chat share <file>...', | ||
| 'Clear the screen and history with /clear...', | ||
| 'Save tokens by summarizing the context with /compress...', | ||
| 'Copy the last response to your clipboard with /copy...', | ||
| 'Open the full documentation in your browser with /docs...', | ||
| 'Add directories to your workspace with /directory add <path>...', | ||
| 'Show all directories in your workspace with /directory show...', | ||
| 'Set your preferred external editor with /editor...', | ||
| 'List all active extensions with /extensions list...', | ||
| 'Update all or specific extensions with /extensions update...', | ||
| 'Get help on commands with /help...', | ||
| 'Manage IDE integration with /ide...', | ||
| 'Create a project-specific GEMINI.md file with /init...', | ||
| 'List configured MCP servers and tools with /mcp list...', | ||
| 'Authenticate with an OAuth-enabled MCP server with /mcp auth...', | ||
| 'Restart MCP servers with /mcp refresh...', | ||
| 'See the current instructional context with /memory show...', | ||
| 'Add content to the instructional memory with /memory add...', | ||
| 'Reload instructional context from GEMINI.md files with /memory refresh...', | ||
| 'List the paths of the GEMINI.md files in use with /memory list...', | ||
| 'Display the privacy notice with /privacy...', | ||
| 'Exit the CLI with /quit or /exit...', | ||
| 'Check model-specific usage stats with /stats model...', | ||
| 'Check tool-specific usage stats with /stats tools...', | ||
| "Change the CLI's color theme with /theme...", | ||
| 'List all available tools with /tools...', | ||
| 'View and edit settings with the /settings editor...', | ||
| 'Toggle Vim keybindings on and off with /vim...', | ||
| 'Set up GitHub Actions with /setup-github...', | ||
| 'Configure terminal keybindings for multiline input with /terminal-setup...', | ||
| 'Find relevant documentation with /find-docs...', | ||
| 'Review a pull request with /oncall:pr-review...', | ||
| 'Go back to main and clean up the branch with /github:cleanup-back-to-main...', | ||
| 'Execute any shell command with !<command>...', | ||
| // Command tips end here | ||
| ]; | ||
|
|
||
| export const PHRASE_CHANGE_INTERVAL_MS = 15000; | ||
|
|
||
| /** | ||
|
|
@@ -173,16 +318,26 @@ export const usePhraseCycler = ( | |
| if (phraseIntervalRef.current) { | ||
| clearInterval(phraseIntervalRef.current); | ||
| } | ||
|
|
||
| const setRandomPhrase = () => { | ||
| if (customPhrases && customPhrases.length > 0) { | ||
| const randomIndex = Math.floor(Math.random() * customPhrases.length); | ||
| setCurrentLoadingPhrase(customPhrases[randomIndex]); | ||
| } else { | ||
| // Roughly 1 in 6 chance to show a tip. | ||
| const showTip = Math.random() < 1 / 6; | ||
| const phraseList = showTip ? INFORMATIVE_TIPS : WITTY_LOADING_PHRASES; | ||
| const randomIndex = Math.floor(Math.random() * phraseList.length); | ||
| setCurrentLoadingPhrase(phraseList[randomIndex]); | ||
| } | ||
| }; | ||
|
|
||
| // Select an initial random phrase | ||
| const initialRandomIndex = Math.floor( | ||
| Math.random() * loadingPhrases.length, | ||
| ); | ||
| setCurrentLoadingPhrase(loadingPhrases[initialRandomIndex]); | ||
| setRandomPhrase(); | ||
|
|
||
| phraseIntervalRef.current = setInterval(() => { | ||
| // Select a new random phrase | ||
| const randomIndex = Math.floor(Math.random() * loadingPhrases.length); | ||
| setCurrentLoadingPhrase(loadingPhrases[randomIndex]); | ||
| setRandomPhrase(); | ||
| }, PHRASE_CHANGE_INTERVAL_MS); | ||
| } else { | ||
| // Idle or other states, clear the phrase interval | ||
|
|
@@ -200,7 +355,7 @@ export const usePhraseCycler = ( | |
| phraseIntervalRef.current = null; | ||
| } | ||
| }; | ||
| }, [isActive, isWaiting, loadingPhrases]); | ||
| }, [isActive, isWaiting, customPhrases, loadingPhrases]); | ||
|
|
||
| return currentLoadingPhrase; | ||
| }; | ||
Uh oh!
There was an error while loading. Please reload this page.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nit: not really faster. more just cleaner.