diff --git a/apps/web/app/connect/portal/page.tsx b/apps/web/app/connect/portal/page.tsx
index 38df2faf..8fac6e6c 100644
--- a/apps/web/app/connect/portal/page.tsx
+++ b/apps/web/app/connect/portal/page.tsx
@@ -55,7 +55,7 @@ export default async function PortalPage({
}
const isAgMode =
- viewer.orgId = 'org_2nJZrA4Dk8i3wszhm6PsP3M2Vwy' ||
+ viewer.orgId === 'org_2nJZrA4Dk8i3wszhm6PsP3M2Vwy' ||
viewer.orgId === 'org_2lcCCimyICKI8cpPNQt195h5zrP' ||
viewer.orgId === 'org_2ms9FdeczlbrDIHJLcwGdpv3dTx'
diff --git a/packages/engine-frontend/components/AddConnectionTabContent.tsx b/packages/engine-frontend/components/AddConnectionTabContent.tsx
new file mode 100644
index 00000000..7267fec8
--- /dev/null
+++ b/packages/engine-frontend/components/AddConnectionTabContent.tsx
@@ -0,0 +1,29 @@
+import type {ConnectorConfigFilters} from '../hocs/WithConnectConfig'
+import {ConnectIntegrations} from './ConnectIntegrations'
+
+interface AddConnectionTabContentProps {
+ connectorConfigFilters: ConnectorConfigFilters
+ refetch: () => void
+}
+
+export function AddConnectionTabContent({
+ connectorConfigFilters,
+ refetch,
+}: AddConnectionTabContentProps) {
+ return (
+
- {/* Listing by categories */}
-
-
-
- My Connections ({connectionCount})
-
-
- Add a Connection
-
-
-
- {connectionCount === 0 ? (
-
-
-
- No connections yet
-
-
- Add a connection to get started
-
-
-
{
- if (event.type === 'close') {
- listConnectionsRes.refetch(); // Trigger refetch
- }
- }}
- >
-
- ) : (
-
- {listConnectionsRes.isLoading ? (
-
-
-
- ) : (
- categoriesWithConnections.map((category) => (
-
- {category.connections.map((conn) => (
- <>
-
-
-
-
-
-
- {conn.connectorName
- .charAt(0)
- .toUpperCase() +
- conn.connectorName.slice(1)}
-
-
- {category.name}
-
-
- {conn.pipelineIds.length > 0 && (
-
- {conn.syncInProgress ? (
-
- ) : (
-
Successfully synced
- )}
-
- )}
-
-
-
-
-
-
-
-
- deleteResource.mutate({id: conn.id})
- }>
-
- Delete
-
-
-
-
-
- {/* TODO: Improve the condition to hide the separator for the last item, right now it iterates
- over all categories and all connections, would be good to have a single array of connections with the category
- information included already */}
-
- >
- ))}
-
- ))
- )}
-
- )}
-
-
-
-
-
- Setup a new Connection
-
-
- Choose a connector config to start
-
-
-
{
- if (event.type === 'close') {
- listConnectionsRes.refetch(); // Trigger refetch
- }
- }}
- >
-
-
-
+
+
)
}}
diff --git a/packages/engine-frontend/components/ConnectionsTabContent.tsx b/packages/engine-frontend/components/ConnectionsTabContent.tsx
new file mode 100644
index 00000000..fa2e274e
--- /dev/null
+++ b/packages/engine-frontend/components/ConnectionsTabContent.tsx
@@ -0,0 +1,120 @@
+import {Loader, Settings} from 'lucide-react'
+import {
+ Badge,
+ ConnectorLogo,
+ DropdownMenu,
+ DropdownMenuContent,
+ DropdownMenuItem,
+ DropdownMenuTrigger,
+ Separator,
+} from '@openint/ui'
+import type {ConnectorConfig} from '../hocs/WithConnectConfig'
+import {ConnectDialog} from './ConnectDialog'
+
+interface ConnectionsTabContentProps {
+ connectionCount: number
+ categoriesWithConnections: Array<{
+ name: string
+ connections: Array<{
+ id: string
+ connectorConfig: ConnectorConfig
+ connectorName: string
+ pipelineIds: string[]
+ syncInProgress: boolean
+ }>
+ }>
+ refetch: () => void
+ isLoading: boolean
+ deleteResource: ({id}: {id: string}) => void
+}
+
+export function ConnectionsTabContent({
+ connectionCount,
+ refetch,
+ isLoading,
+ deleteResource,
+ categoriesWithConnections,
+}: ConnectionsTabContentProps) {
+ return connectionCount === 0 ? (
+
+
+
No connections yet
+
Add a connection to get started
+
+
{
+ if (event.type === 'close') {
+ refetch() // Trigger refetch
+ }
+ }}>
+
+ ) : (
+
+ {isLoading ? (
+
+
+
+ ) : (
+ categoriesWithConnections.map((category) => (
+
+ {category.connections.map((conn) => (
+ <>
+
+
+
+
+
+
+ {conn.connectorName.charAt(0).toUpperCase() +
+ conn.connectorName.slice(1)}
+
+ {category.name}
+
+ {conn.pipelineIds.length > 0 && (
+
+ {conn.syncInProgress ? (
+
+ ) : (
+
Successfully synced
+ )}
+
+ )}
+
+
+
+
+
+
+
+ deleteResource({id: conn.id})}>
+
+ Delete
+
+
+
+
+
+ {/* TODO: Improve the condition to hide the separator for the last item, right now it iterates
+ over all categories and all connections, would be good to have a single array of connections with the category
+ information included already */}
+
+ >
+ ))}
+
+ ))
+ )}
+
+ )
+}
diff --git a/packages/engine-frontend/components/IntegrationSearch.tsx b/packages/engine-frontend/components/IntegrationSearch.tsx
index aaa64c43..bfe42808 100644
--- a/packages/engine-frontend/components/IntegrationSearch.tsx
+++ b/packages/engine-frontend/components/IntegrationSearch.tsx
@@ -2,7 +2,8 @@
import {Loader, Search} from 'lucide-react'
import React from 'react'
-import {Card, cn, ConnectorLogo, Input} from '@openint/ui'
+import {Input} from '@openint/ui'
+import {ConnectionCard} from '@openint/ui/domain-components/ConnectionCard'
import type {ConnectorConfig} from '../hocs/WithConnectConfig'
import type {ConnectEventType} from '../hocs/WithConnectorConnect'
import {WithConnectorConnect} from '../hocs/WithConnectorConnect'
@@ -35,10 +36,20 @@ export function IntegrationSearch({
ccfg: connectorConfigs.find((ccfg) => ccfg.id === int.connector_config_id)!,
}))
+ const intsByCategory = ints?.reduce(
+ (acc, int) => {
+ int.ccfg.verticals.forEach((vertical) => {
+ acc[vertical] = (acc[vertical] || []).concat(int)
+ })
+ return acc
+ },
+ {} as Record
,
+ )
+
return (
{/* Search integrations */}
-