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 { APIResource } from "../../../core/resource.mjs";
import { APIResource } from "../../../resource.mjs";
import { isRequestOptions } from "../../../core.mjs";
import * as Core from "../../../core.mjs";
import * as ContentAPI from "./content.mjs";
import { Content } from "./content.mjs";
import { CursorPage } from "../../../core/pagination.mjs";
import { buildHeaders } from "../../../internal/headers.mjs";
import { multipartFormRequestOptions } from "../../../internal/uploads.mjs";
import { path } from "../../../internal/utils/path.mjs";
import { CursorPage } from "../../../pagination.mjs";
export class Files extends APIResource {
constructor() {
super(...arguments);
@@ -17,21 +16,20 @@ export class Files extends APIResource {
* You can send either a multipart/form-data request with the raw file content, or
* a JSON request with a file ID.
*/
create(containerID, body, options) {
return this._client.post(path `/containers/${containerID}/files`, multipartFormRequestOptions({ body, ...options }, this._client));
create(containerId, body, options) {
return this._client.post(`/containers/${containerId}/files`, Core.multipartFormRequestOptions({ body, ...options }));
}
/**
* Retrieve Container File
*/
retrieve(fileID, params, options) {
const { container_id } = params;
return this._client.get(path `/containers/${container_id}/files/${fileID}`, options);
retrieve(containerId, fileId, options) {
return this._client.get(`/containers/${containerId}/files/${fileId}`, options);
}
/**
* List Container files
*/
list(containerID, query = {}, options) {
return this._client.getAPIList(path `/containers/${containerID}/files`, (CursorPage), {
list(containerId, query = {}, options) {
if (isRequestOptions(query)) {
return this.list(containerId, {}, query);
}
return this._client.getAPIList(`/containers/${containerId}/files`, FileListResponsesPage, {
query,
...options,
});
@@ -39,13 +37,15 @@ export class Files extends APIResource {
/**
* Delete Container File
*/
delete(fileID, params, options) {
const { container_id } = params;
return this._client.delete(path `/containers/${container_id}/files/${fileID}`, {
del(containerId, fileId, options) {
return this._client.delete(`/containers/${containerId}/files/${fileId}`, {
...options,
headers: buildHeaders([{ Accept: '*/*' }, options?.headers]),
headers: { Accept: '*/*', ...options?.headers },
});
}
}
export class FileListResponsesPage extends CursorPage {
}
Files.FileListResponsesPage = FileListResponsesPage;
Files.Content = Content;
//# sourceMappingURL=files.mjs.map