-
Notifications
You must be signed in to change notification settings - Fork 0
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
Feature: Integrations Setup #185
Conversation
Conflicts: src/app/store.ts On branch integrations-api Changes to be committed: modified: package-lock.json modified: package.json modified: src/app/middleware.ts modified: src/app/store.ts modified: src/components/Chat/Chat.tsx modified: src/components/ChatContent/ChatContent.tsx modified: src/components/ChatContent/UserInput.tsx modified: src/components/ChatForm/ChatForm.tsx modified: src/components/ChatForm/RetryForm.tsx new file: src/components/Dropzone/Dropzone.tsx new file: src/components/Dropzone/index.tsx new file: src/features/AttachedImages/imagesSlice.ts new file: src/features/AttachedImages/index.ts modified: src/features/Chat/Thread/utils.ts modified: src/features/History/historySlice.ts new file: src/hooks/useAttachedImages.ts modified: src/hooks/useSendChatRequest.ts modified: src/services/refact/chat.ts modified: src/services/refact/types.ts
Conflicts: src/__fixtures__/index.ts src/app/store.ts Changes to be committed: modified: .prettierignore modified: .storybook/main.ts modified: .storybook/preview.tsx deleted: TODO.md modified: package-lock.json modified: package.json new file: public/mockServiceWorker.js modified: src/__fixtures__/chat.ts modified: src/__fixtures__/index.ts modified: src/__fixtures__/markdown.ts new file: src/__fixtures__/some_chrome_screenshots.json new file: src/__fixtures__/survey_questions.ts new file: src/__tests__/UserSurvey.test.tsx modified: src/app/middleware.ts modified: src/app/store.ts modified: src/components/Chart/Chart.tsx modified: src/components/Chat/Chat.tsx modified: src/components/ChatContent/ChatContent.stories.tsx modified: src/components/ChatContent/ChatContent.tsx modified: src/components/ChatContent/ToolsContent.tsx modified: src/components/ChatContent/UserInput.tsx modified: src/components/ChatForm/ChatForm.stories.tsx modified: src/components/ChatForm/ChatForm.test.tsx modified: src/components/ChatForm/ChatForm.tsx new file: src/components/ChatForm/ToolConfirmation.module.css new file: src/components/ChatForm/ToolConfirmation.tsx modified: src/components/Command/Command.module.css modified: src/components/Command/Markdown.tsx modified: src/components/Markdown/Markdown.tsx modified: src/components/Reveal/reveal.module.css modified: src/components/Spinner/Spinner.module.css modified: src/components/Spinner/Spinner.stories.tsx modified: src/components/Spinner/Spinner.tsx modified: src/components/StatisticView/StatisticView.tsx modified: src/components/Table/Table.tsx modified: src/components/Toolbar/Toolbar.tsx modified: src/events/index.ts modified: src/features/App.tsx modified: src/features/Chat/Thread/actions.ts modified: src/features/Chat/Thread/utils.ts modified: src/features/TipOfTheDay.tsx new file: src/features/ToolConfirmation/confirmationSlice.ts new file: src/features/UserSurvey/UserSurvey.stories.tsx new file: src/features/UserSurvey/UserSurvey.tsx new file: src/features/UserSurvey/index.ts new file: src/features/UserSurvey/userSurveySlice.ts modified: src/hooks/index.ts modified: src/hooks/useEventBusForIDE.ts modified: src/hooks/useGetToolsQuery.ts new file: src/hooks/useGetUserSurvey.ts modified: src/hooks/usePatchActions.ts modified: src/hooks/useSendChatRequest.ts modified: src/lib/render/index.tsx modified: src/services/refact/chat.ts modified: src/services/refact/consts.ts modified: src/services/refact/path.ts modified: src/services/refact/tools.ts modified: src/services/refact/types.ts modified: src/services/smallcloud/index.ts new file: src/utils/extractFilePathFromPin.ts modified: src/utils/index.ts modified: src/utils/mockServer.ts modified: src/vite-env.d.ts modified: vite.config.ts
… into feat/setup-integrations
- [x] Implemented an `IntegrationForm` with reusable fields for each integration field type - [x] Schema check in `handleSubmit` to transform formData to corresponding field types - [x] Added `toPascalCase` utility function
Slight refactoring of apply and return buttons, and some other minor changes.
* wip(configuration chat): send first messages. * wip(configuration chat): tool use in configuration chat.
* wip(configuration chat): handle going back. * fix(integration chat): change tools setting to explore. * chore(missing deps in hook): `renderField` function was missing deps. * feat(integration data cache): add slice for integrations cache. * fix(integration cache): remove item on save. * fix(config chat): chat being sent multiple times. * wip(tool confirmation): skip confirming tool use when running a configuration. * feat: add apply all button to configuration chat. * feat: reload old configuration chat and go back to the form * feat(configuration chat): add error message handler. * fix(configuration chat): use agentic mode and don't set the model. --------- Co-authored-by: Andrii Lashchov <84778697+alashchev17@users.noreply.github.com>
* wip: docker containers api handlers * wip: docker actions API & action buttons * wip: better action handling * wip: simplification of dockerApi & action buttons improvements * chore: fixtures update * chore: removal of unnecessary esling rule bypass * wip: docker container card & refactoring of integration form * feat(configuration): adjusted size of inputs based on f_size & DataList instead of raw flexboxes * wip: form appearance & responsive layout * wip: updated docker section * wip(refactoring): smartlink, availability, renderField, handleSmartlinkClick extracted to separate files and scopes * wip(form): bool f_type support * wip(refactoring): making docker within integr_schema optional, conditional rendering of docker section within integration form * wip(docker): error handling * wip(refactoring): toolscontent usage summary refactoring * wip(docker containers): collapsible container details & reveal if large * wip(refactoring): project name handling for macOS & Windows * wip(refactoring): docker error card & debounced loaded state * wip(docker containers): better loading state management * wip: separation & refactoring of UI, making docker containers cards better & making integrationsview setup better * fix: error types for docker error cards * fix: unchecked switch values included to formData * chore: removal no-console * chore: removal of unexisting prop * fix: extra fields showup button conditional rendering * chore: TODO insertion * fix: rule bypass removal * feat: debug logging library usage for integrations logs * feat: implementing root debug instance, managing debuggable instances launch * chore: better logging message * chore: TODO for tags invalidation docker * fix: replaced <label/> to <Text as='label' />
const next = createInitialState("agent", action.payload.integration); | ||
next.thread.integration = action.payload.integration; | ||
next.thread.messages = action.payload.messages; | ||
|
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.
Delete these comments
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.
TODO: find out about tool use
this one also?
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.
no, I think that's still up in the air with the new chat_mode object in the meta property for chat requests.
} | ||
|
||
function isDockerLabels(json: unknown): json is DockerLabels { | ||
// Since DockerPorts is defined as NonNullable<unknown>, we don't have specific structure to validate. Just checking, that it's not null | undefined |
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.
Are these unknown or likely to change?
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.
To be honest, we don't even render them, the only requirement for labels
and ports
is to be an object (NonNullable<unknown>
)
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.
Left some comments.
const integrationLogo = INTEGRATIONS_WITH_TERMINAL_ICON.includes( | ||
integration.integr_name.split("_")[0], | ||
) | ||
? `/integrations/cmdline.png` |
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.
note: test the build to make sure the images are available from the dist
folder
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.
will do right now
Feature: Integrations Setup
Description
Type of change
Screenshots (if applicable)
Main integrations setup screen
PostgreSQL setup screen
Docker Containers section related to integration
Checklist