Files
gitmost/apps/client
claude_code f789be9c89 feat(ai-chat): interrupt agent and send a queued message now (#198)
Add a "Send now" button to each queued AI-chat message that interrupts the
running agent and immediately resends that message, preserving the agent's
partial output and telling it on the next turn that it was interrupted.

Client:
- queue-helpers: new pure promoteToHead() (+ tests)
- chat-thread: sendNow() promotes the chosen message to the queue head and
  aborts; onFinish flushes the promoted head on the intentional abort; a
  one-shot `interrupted` flag rides that resend request; stale flags are
  cleared at every turn start to defuse a clean-finish/click race leak
- "Send now" action icon + en-US/ru-RU translations

Server:
- AiChatStreamBody.interrupted flag; shouldInjectInterruptNote() gates on the
  flag AND a genuinely-unfinished previous turn (aborted/streaming)
- buildSystemPrompt() appends INTERRUPT_NOTE inside the safety sandwich so the
  model treats its previous, partial reply as incomplete
- prompt + service unit tests

Partial-output persistence already existed (onAbort -> 'aborted', findRecent
replays regardless of status); that path is unchanged.

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-06-26 00:00:05 +03:00
..
2024-06-07 17:29:34 +01:00
2024-01-09 18:58:26 +01:00
2024-12-09 14:51:31 +00:00
2024-01-09 18:58:26 +01:00
2024-01-09 18:58:26 +01:00
2024-01-09 18:58:26 +01:00
2024-01-09 18:58:26 +01:00

React + TypeScript + Vite

This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.

Currently, two official plugins are available:

Expanding the ESLint configuration

If you are developing a production application, we recommend updating the configuration to enable type aware lint rules:

  • Configure the top-level parserOptions property like this:
   parserOptions: {
    ecmaVersion: 'latest',
    sourceType: 'module',
    project: ['./tsconfig.json', './tsconfig.node.json'],
    tsconfigRootDir: __dirname,
   },
  • Replace plugin:@typescript-eslint/recommended to plugin:@typescript-eslint/recommended-type-checked or plugin:@typescript-eslint/strict-type-checked
  • Optionally add plugin:@typescript-eslint/stylistic-type-checked
  • Install eslint-plugin-react and add plugin:react/recommended & plugin:react/jsx-runtime to the extends list