Fix chat interface - restore continuous conversation flow

🎯 Major improvements to MissionControl component:
- Always keep input field visible and functional after AI responses
- Auto-clear input after submitting questions for better UX
- Add dynamic visual indicators (first question vs follow-up)
- Improve response layout with clear separation and hints
- Enable proper chat-like experience for continuous learning

🌟 Additional enhancements:
- Better language-specific messaging throughout interface
- Clearer visual hierarchy between input and response areas
- Intuitive flow that guides users to ask follow-up questions
- Maintains responsive design and accessibility

🔧 Technical changes:
- Enhanced MissionControl state management
- Improved component layout and styling
- Better TypeScript integration across components
- Updated tsconfig for stricter type checking
This commit is contained in:
rwiegand
2025-07-14 12:39:05 +02:00
parent b31492a354
commit f893530471
1798 changed files with 25329 additions and 92638 deletions

View File

@@ -1,11 +1,10 @@
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
import { parseResponse, addOutputText, } from "../../lib/ResponsesParser.mjs";
import { ResponseStream } from "../../lib/responses/ResponseStream.mjs";
import { APIResource } from "../../core/resource.mjs";
import { APIResource } from "../../resource.mjs";
import * as InputItemsAPI from "./input-items.mjs";
import { InputItems } from "./input-items.mjs";
import { buildHeaders } from "../../internal/headers.mjs";
import { path } from "../../internal/utils/path.mjs";
import { ResponseStream } from "../../lib/responses/ResponseStream.mjs";
import { CursorPage } from "../../pagination.mjs";
export class Responses extends APIResource {
constructor() {
super(...arguments);
@@ -19,16 +18,11 @@ export class Responses extends APIResource {
return rsp;
});
}
retrieve(responseID, query = {}, options) {
return this._client.get(path `/responses/${responseID}`, {
retrieve(responseId, query = {}, options) {
return this._client.get(`/responses/${responseId}`, {
query,
...options,
stream: query?.stream ?? false,
})._thenUnwrap((rsp) => {
if ('object' in rsp && rsp.object === 'response') {
addOutputText(rsp);
}
return rsp;
});
}
/**
@@ -36,15 +30,15 @@ export class Responses extends APIResource {
*
* @example
* ```ts
* await client.responses.delete(
* await client.responses.del(
* 'resp_677efb5139a88190b512bc3fef8e535d',
* );
* ```
*/
delete(responseID, options) {
return this._client.delete(path `/responses/${responseID}`, {
del(responseId, options) {
return this._client.delete(`/responses/${responseId}`, {
...options,
headers: buildHeaders([{ Accept: '*/*' }, options?.headers]),
headers: { Accept: '*/*', ...options?.headers },
});
}
parse(body, options) {
@@ -65,14 +59,19 @@ export class Responses extends APIResource {
*
* @example
* ```ts
* const response = await client.responses.cancel(
* await client.responses.cancel(
* 'resp_677efb5139a88190b512bc3fef8e535d',
* );
* ```
*/
cancel(responseID, options) {
return this._client.post(path `/responses/${responseID}/cancel`, options);
cancel(responseId, options) {
return this._client.post(`/responses/${responseId}/cancel`, {
...options,
headers: { Accept: '*/*', ...options?.headers },
});
}
}
export class ResponseItemsPage extends CursorPage {
}
Responses.InputItems = InputItems;
//# sourceMappingURL=responses.mjs.map