Corrija Shift+Enter para quebras de linha, obtenha um sinal sonoro do terminal quando Claude terminar, configure tmux, corresponda o tema de cores e ative o modo Vim na CLI do Claude Code.
Use this file to discover all available pages before exploring further.
Claude Code funciona em qualquer terminal sem configuração. Esta página é para quando algo específico não está se comportando da forma que você espera. Encontre seu sintoma abaixo. Se tudo já se sente certo, você não precisa desta página.
Esta página é sobre fazer seu terminal enviar os sinais corretos para Claude Code. Para alterar quais teclas Claude Code responde, consulte atalhos de teclado em vez disso.
Pressionar Enter envia sua mensagem. Para adicionar uma quebra de linha sem enviar, pressione Ctrl+J, ou digite \ e depois pressione Enter. Ambos funcionam em todos os terminais sem configuração.Na maioria dos terminais você também pode pressionar Shift+Enter, mas o suporte varia por emulador de terminal:
Terminal
Shift+Enter para quebra de linha
Ghostty, Kitty, iTerm2, WezTerm, Warp, Apple Terminal, Windows Terminal
Funciona sem configuração
VS Code, Cursor, Windsurf, Alacritty, Zed
Execute /terminal-setup uma vez
gnome-terminal, JetBrains IDEs como PyCharm e Android Studio
Não disponível; use Ctrl+J ou \ depois Enter
Para VS Code, Cursor, Windsurf, Alacritty e Zed, /terminal-setup escreve Shift+Enter e outros atalhos de teclado no arquivo de configuração do terminal. Em VS Code, Cursor e Windsurf, também define terminal.integrated.mouseWheelScrollSensitivity nas configurações do editor para rolagem mais suave no modo de tela cheia. As vinculações e configurações existentes são mantidas no lugar; se você vir uma mensagem como VSCode terminal Shift+Enter key binding already configured, nenhuma alteração foi feita. Execute /terminal-setup diretamente no terminal do host em vez de dentro do tmux ou screen, pois ele precisa escrever na configuração do terminal do host.Se você estiver executando dentro do tmux, Shift+Enter também requer a configuração do tmux abaixo mesmo quando o terminal externo a suporta.Para vincular quebra de linha a uma tecla diferente, ou para trocar o comportamento para que Enter insira uma quebra de linha e Shift+Enter envie, mapeie as ações chat:newline e chat:submit em seu arquivo de atalhos de teclado.
Alguns atalhos do Claude Code usam a tecla Option, como Option+Enter para uma quebra de linha ou Option+P para trocar modelos. No macOS, a maioria dos terminais não envia Option como um modificador por padrão, então esses atalhos não funcionam até que você o ative. A configuração do terminal para isso geralmente é rotulada como “Use Option as Meta Key”; Meta é o nome histórico do Unix para a tecla agora rotulada como Option ou Alt.
Apple Terminal
iTerm2
VS Code
Abra Configurações → Perfis → Teclado e marque “Use Option as Meta Key”.Se você aceitou o prompt de primeira execução do Claude Code que oferecia “Option+Enter para quebras de linha e sino visual”, isso já foi feito. Esse prompt executa /terminal-setup para você, que ativa Option como Meta e muda o sino de áudio para um flash de tela visual em seu perfil do Apple Terminal.
Abra Configurações → Perfis → Teclas → Geral e defina a tecla Option Esquerda e a tecla Option Direita como “Esc+”.Executar /terminal-setup no iTerm2 ativa “Applications in terminal may access clipboard” em Configurações → Geral → Seleção para que o comando /copy possa escrever na sua área de transferência do sistema. O comando detecta iTerm2 mesmo quando executado dentro do tmux. Reinicie o iTerm2 para que a alteração tenha efeito.
Adicione "terminal.integrated.macOptionIsMeta": true às suas configurações do VS Code.
Para Ghostty, Kitty e outros terminais, procure por uma configuração Option-as-Alt ou Option-as-Meta no arquivo de configuração do terminal.
Quando Claude termina uma tarefa ou pausa para um prompt de permissão, ele dispara um evento de notificação. Exibir isso como um sino de terminal ou notificação de desktop permite que você mude para outro trabalho enquanto uma tarefa longa é executada.Por padrão, Claude Code envia uma notificação de desktop apenas em Ghostty, Kitty e iTerm2. Em outros terminais, defina preferredNotifChannel como "terminal_bell" para tocar o sino do terminal, ou configure um hook de Notificação para um som personalizado ou comando.A notificação de desktop chega à sua máquina local via SSH, portanto uma sessão remota ainda pode alertá-lo. Ghostty e Kitty a encaminham para seu centro de notificações do SO sem configuração adicional. iTerm2 requer que você ative o encaminhamento:
1
Abra as configurações de notificação do iTerm2
Vá para Configurações → Perfis → Terminal.
2
Ative alertas
Marque “Notification Center Alerts”, depois clique em “Filter Alerts” e ative “Send escape sequence-generated alerts”.
Se as notificações ainda não aparecerem, confirme que seu aplicativo de terminal tem permissão de notificação nas configurações do seu SO, e se você estiver executando dentro do tmux, ative passthrough.
Em qualquer terminal você pode configurar um hook de Notificação para reproduzir um som ou executar um comando personalizado quando Claude precisar de sua atenção. Hooks são executados junto com a notificação de desktop em vez de substituí-la, portanto terminais que não recebem uma notificação de desktop, como Warp ou o terminal integrado do VS Code, podem usar um hook ou definir preferredNotifChannel como "terminal_bell" em vez disso.O exemplo abaixo reproduz um som do sistema no macOS. O guia vinculado tem comandos de notificação de desktop para macOS, Linux e Windows.
Quando Claude Code é executado dentro do tmux, duas coisas quebram por padrão: Shift+Enter envia em vez de inserir uma quebra de linha, e notificações de desktop e a barra de progresso nunca chegam ao terminal externo. Adicione estas linhas a ~/.tmux.conf, depois execute tmux source-file ~/.tmux.conf para aplicá-las ao servidor em execução:
~/.tmux.conf
set -g allow-passthrough onset -s extended-keys onset -as terminal-features 'xterm*:extkeys'
A linha allow-passthrough permite que notificações e atualizações de progresso cheguem ao terminal externo em vez de serem engolidas pelo tmux. As linhas extended-keys permitem que tmux distinga Shift+Enter de Enter simples para que o atalho de quebra de linha funcione.
Use o comando /theme, ou o seletor de tema em /config, para escolher um tema do Claude Code que corresponda ao seu terminal. Selecionar a opção auto detecta o fundo claro ou escuro do seu terminal, para que o tema siga as mudanças de aparência do SO sempre que seu terminal fizer. Claude Code não controla o esquema de cores do próprio terminal, que é definido pela aplicação de terminal.Para personalizar o que aparece na parte inferior da interface, configure uma linha de status personalizada que mostra o modelo atual, diretório de trabalho, branch do git ou outro contexto.
Temas personalizados requerem Claude Code v2.1.118 ou posterior.
Além dos presets integrados, /theme lista todos os temas personalizados que você definiu e quaisquer temas contribuídos por plugins instalados. Selecione Novo tema personalizado… no final da lista para criar um interativamente: você nomeia o tema e depois escolhe tokens de cor individuais para substituir. Pressione Ctrl+E enquanto um tema personalizado está destacado para editá-lo.Cada tema personalizado é um arquivo JSON em ~/.claude/themes/. O nome do arquivo sem a extensão .json é o slug do tema, e selecionar o tema armazena custom:<slug> como sua preferência de tema. O arquivo tem três campos opcionais:
Campo
Tipo
Descrição
name
string
Rótulo de exibição mostrado em /theme. Padrão é o slug do nome do arquivo
base
string
Preset integrado do qual o tema começa: dark, light, dark-daltonized, light-daltonized, dark-ansi, ou light-ansi. Padrão é dark
overrides
object
Mapa de nomes de tokens de cor para valores de cor. Tokens não listados aqui caem através do preset base
Valores de cor aceitam #rrggbb, #rgb, rgb(r,g,b), ansi256(n), ou ansi:<name> onde <name> é um dos 16 nomes de cores ANSI padrão como red ou cyanBright. Tokens desconhecidos e valores de cor inválidos são ignorados, portanto um erro de digitação não pode quebrar a renderização.O exemplo a seguir define um tema que mantém o preset escuro, mas recolore o acento do prompt, o texto de erro e o texto de sucesso:
Claude Code monitora ~/.claude/themes/ e recarrega quando um arquivo muda, portanto edições feitas no seu editor se aplicam a uma sessão em execução sem necessidade de reinicialização.A referência abaixo cobre os tokens que você pode definir em overrides. O editor interativo em /theme mostra os mesmos tokens com uma visualização ao vivo, além de alguns acentos de propósito único, como cores de tela de integração, que são omitidas aqui.
Referência de tokens de cor
O exemplo a seguir combina tokens de vários dos grupos abaixo: o acento da marca, a borda do modo de plano, os fundos de diff e o fundo da mensagem em tela cheia.
Vários tokens têm uma variante de shimmer emparelhada que fornece a cor mais clara usada no gradiente animado do spinner. Substitua o shimmer junto com seu token base se a animação parecer incompatível.
claude e claudeShimmer
warning e warningShimmer
permission e permissionShimmer
promptBorder e promptBorderShimmer
inactive e inactiveShimmer
fastMode e fastModeShimmer
Cada subagente e tarefa paralela é mostrado em uma das oito cores nomeadas para que você possa diferenciá-los na transcrição. Os nomes dos tokens seguem o padrão <color>_FOR_SUBAGENTS_ONLY, onde <color> é red, blue, green, yellow, purple, orange, pink, ou cyan. Substitua estes para alterar a aparência de cada cor nomeada. Por exemplo, um subagente com color: blue em sua definição é desenhado usando o valor blue_FOR_SUBAGENTS_ONLY.As palavras-chave ultrathink e ultraplan na entrada do prompt são renderizadas com um gradiente arco-íris de sete cores. Os nomes dos tokens seguem o padrão rainbow_<color> e rainbow_<color>_shimmer, onde <color> é red, orange, yellow, green, blue, indigo, ou violet.
Se a exibição piscar ou a posição de rolagem pular enquanto Claude está trabalhando, mude para o modo de renderização em tela cheia. Ele desenha em uma tela separada que o terminal reserva para aplicativos em tela cheia em vez de anexar ao seu scrollback normal, o que mantém o uso de memória plano e adiciona suporte a mouse para rolagem e seleção. Neste modo você rola com o mouse ou PageUp dentro do Claude Code em vez de com o scrollback nativo do seu terminal; consulte a página de tela cheia para saber como pesquisar e copiar.Execute /tui fullscreen para mudar na sessão atual com sua conversa intacta. Para torná-lo o padrão, defina a variável de ambiente CLAUDE_CODE_NO_FLICKER antes de iniciar Claude Code:
Quando você cola mais de 10.000 caracteres no prompt, Claude Code reduz a entrada para um placeholder [Pasted text] para que a caixa de entrada permaneça utilizável. O conteúdo completo ainda é enviado para Claude quando você envia.O terminal integrado do VS Code pode descartar caracteres de colagens muito grandes antes de chegarem ao Claude Code, então prefira fluxos de trabalho baseados em arquivo lá. Para entradas muito grandes, como arquivos inteiros ou logs longos, escreva o conteúdo em um arquivo e peça ao Claude para lê-lo em vez de colar. Isso mantém a transcrição da conversa legível e permite que Claude referencie o arquivo por caminho em turnos posteriores.
Claude Code inclui um modo de edição estilo Vim para a entrada do prompt. Ative-o através de /config → Editor mode, ou definindo editorMode como "vim" em ~/.claude/settings.json. Defina Editor mode de volta para normal para desativá-lo.O modo Vim suporta um subconjunto de motions de modo NORMAL e VISUAL e operadores, como navegação hjkl, seleção v/V, e d/c/y com objetos de texto. Consulte a referência do modo editor Vim para a tabela de teclas completa. Motions de Vim não são remapeáveis através do arquivo de atalhos de teclado.Pressionar Enter ainda envia seu prompt no modo INSERT, diferentemente do Vim padrão. Use o ou O no modo NORMAL, ou Ctrl+J, para inserir uma quebra de linha em vez disso.