mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-05-25 23:24:03 +00:00
Major additions: - Complete Next.js studio application with 1600+ components - Docker support (Dockerfile.combined, docker-compose.yml) - GCP deployment documentation and benchmarks - SQL benchmark scripts for performance testing - Sentry integration for monitoring - Comprehensive test suite and mocks Studio features: - Dashboard and admin interfaces - Data visualization components - Authentication and user management - API integration with RuVector backend - Static data and public assets 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
70 lines
2.2 KiB
TypeScript
70 lines
2.2 KiB
TypeScript
import { useParams } from 'common'
|
|
import { COMMAND_MENU_SECTIONS } from 'components/interfaces/App/CommandMenu/CommandMenu.utils'
|
|
import { orderCommandSectionsByPriority } from 'components/interfaces/App/CommandMenu/ordering'
|
|
import {
|
|
IntegrationDefinition,
|
|
INTEGRATIONS,
|
|
} from 'components/interfaces/Integrations/Landing/Integrations.constants'
|
|
import { useIsFeatureEnabled } from 'hooks/misc/useIsFeatureEnabled'
|
|
import type { CommandOptions } from 'ui-patterns/CommandMenu'
|
|
import { useRegisterCommands } from 'ui-patterns/CommandMenu'
|
|
|
|
export function useIntegrationsGotoCommands(options?: CommandOptions) {
|
|
let { ref } = useParams()
|
|
ref ||= '_'
|
|
|
|
const { integrationsWrappers } = useIsFeatureEnabled(['integrations:wrappers'])
|
|
|
|
const allIntegrations = integrationsWrappers
|
|
? INTEGRATIONS
|
|
: INTEGRATIONS.filter((x) => !x.id.endsWith('_wrapper'))
|
|
|
|
const getName = (integration: IntegrationDefinition) => {
|
|
switch (integration.id) {
|
|
case 'cron':
|
|
return 'View and manage your Cron Jobs'
|
|
case 'graphiql':
|
|
return 'Query database using GraphQL'
|
|
case 'vault':
|
|
return 'View and manage your keys and secrets via Vault'
|
|
default:
|
|
return `View and manage your ${integration.name}${integration.type === 'wrapper' ? 's' : ''}`
|
|
}
|
|
}
|
|
|
|
useRegisterCommands(
|
|
COMMAND_MENU_SECTIONS.NAVIGATE,
|
|
allIntegrations.map((x) => {
|
|
return {
|
|
id: `nav-integrations-${x.id}`,
|
|
name: x.name,
|
|
value: `Integrations: ${x.name}`,
|
|
route: `/project/${ref}/integrations/${x.id}/overview`,
|
|
defaultHidden: true,
|
|
}
|
|
}),
|
|
{ ...options, deps: [ref] }
|
|
)
|
|
|
|
useRegisterCommands(
|
|
COMMAND_MENU_SECTIONS.INTEGRATIONS,
|
|
allIntegrations.map((x) => {
|
|
return {
|
|
id: `manage-${x.id}`,
|
|
name: getName(x),
|
|
route: `/project/${ref}/integrations/${x.id}/overview`,
|
|
icon: () => (
|
|
<div className="w-6 h-6 relative bg-white border rounded-md flex items-center justify-center [&>img]:!p-1 [&>svg]:!p-1">
|
|
{x.icon()}
|
|
</div>
|
|
),
|
|
}
|
|
}),
|
|
{
|
|
...options,
|
|
deps: [ref],
|
|
orderSection: orderCommandSectionsByPriority,
|
|
sectionMeta: { priority: 3 },
|
|
}
|
|
)
|
|
}
|