mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-05-24 22:15:18 +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>
143 lines
5.2 KiB
TypeScript
143 lines
5.2 KiB
TypeScript
import { useParams } from 'common'
|
|
import { Button, Input, copyToClipboard } from 'ui'
|
|
|
|
import { useApiKeysVisibility } from 'components/interfaces/APIKeys/hooks/useApiKeysVisibility'
|
|
import { getKeys, useAPIKeysQuery } from 'data/api-keys/api-keys-query'
|
|
import { useProjectSettingsV2Query } from 'data/config/project-settings-v2-query'
|
|
import { useSendEventMutation } from 'data/telemetry/send-event-mutation'
|
|
import { useSelectedOrganizationQuery } from 'hooks/misc/useSelectedOrganization'
|
|
import { Copy } from 'lucide-react'
|
|
import { useEffect, useState } from 'react'
|
|
import ContentSnippet from '../ContentSnippet'
|
|
import { DOCS_CONTENT } from '../ProjectAPIDocs.constants'
|
|
import type { ContentProps } from './Content.types'
|
|
|
|
export const Introduction = ({ showKeys, language, apikey, endpoint }: ContentProps) => {
|
|
const { ref } = useParams()
|
|
const { canReadAPIKeys } = useApiKeysVisibility()
|
|
const { data: apiKeys } = useAPIKeysQuery({ projectRef: ref }, { enabled: canReadAPIKeys })
|
|
const { data } = useProjectSettingsV2Query({ projectRef: ref })
|
|
const { data: org } = useSelectedOrganizationQuery()
|
|
const { mutate: sendEvent } = useSendEventMutation()
|
|
|
|
const [copied, setCopied] = useState<'anon' | 'service'>()
|
|
|
|
useEffect(() => {
|
|
if (copied !== undefined) setTimeout(() => setCopied(undefined), 2000)
|
|
}, [copied])
|
|
|
|
const { anonKey, serviceKey } = getKeys(apiKeys)
|
|
const anonApiKey = anonKey?.api_key
|
|
const serviceApiKey = serviceKey?.api_key ?? 'SUPABASE_CLIENT_SERVICE_KEY'
|
|
|
|
return (
|
|
<>
|
|
<ContentSnippet
|
|
selectedLanguage={language}
|
|
apikey={apikey}
|
|
endpoint={endpoint}
|
|
snippet={DOCS_CONTENT.init}
|
|
>
|
|
<div className="px-4 space-y-6">
|
|
<div className="flex space-x-4 mt-8">
|
|
<p className="text-sm w-40">Project URL</p>
|
|
<Input disabled readOnly copy size="small" value={endpoint} className="w-full" />
|
|
</div>
|
|
<div className="flex space-x-4">
|
|
<p className="text-sm w-40">Client API key</p>
|
|
<Input
|
|
disabled
|
|
readOnly
|
|
size="small"
|
|
value={showKeys ? apikey : 'Reveal API keys via dropdown in the header'}
|
|
className="w-full"
|
|
descriptionText="This key is safe to use in a browser if you have enabled Row Level Security (RLS) for your tables and configured policies."
|
|
actions={[
|
|
<Button
|
|
key="copy"
|
|
type="default"
|
|
icon={<Copy />}
|
|
onClick={() => {
|
|
setCopied('anon')
|
|
copyToClipboard(anonApiKey ?? 'SUPABASE_CLIENT_ANON_KEY')
|
|
sendEvent({
|
|
action: 'api_docs_code_copy_button_clicked',
|
|
properties: {
|
|
title: 'Client API key',
|
|
selectedLanguage: language,
|
|
},
|
|
groups: {
|
|
project: ref ?? 'Unknown',
|
|
organization: org?.slug ?? 'Unknown',
|
|
},
|
|
})
|
|
}}
|
|
>
|
|
{copied === 'anon' ? 'Copied' : 'Copy'}
|
|
</Button>,
|
|
]}
|
|
/>
|
|
</div>
|
|
<div className="flex space-x-4">
|
|
<p className="text-sm w-40 mb-16">Service key</p>
|
|
<Input
|
|
disabled
|
|
readOnly
|
|
size="small"
|
|
value={
|
|
showKeys
|
|
? serviceApiKey ?? 'SUPABASE_CLIENT_SERVICE_KEY'
|
|
: 'Reveal API keys via dropdown in the header'
|
|
}
|
|
className="w-full"
|
|
descriptionText={
|
|
<p>
|
|
This key has the ability to bypass Row Level Security.{' '}
|
|
<span className="text-amber-900">Never share it publicly.</span>
|
|
</p>
|
|
}
|
|
actions={[
|
|
<Button
|
|
key="copy"
|
|
type="default"
|
|
icon={<Copy />}
|
|
onClick={() => {
|
|
setCopied('service')
|
|
copyToClipboard(serviceApiKey)
|
|
sendEvent({
|
|
action: 'api_docs_code_copy_button_clicked',
|
|
properties: {
|
|
title: 'Service key',
|
|
selectedLanguage: language,
|
|
},
|
|
groups: {
|
|
project: ref ?? 'Unknown',
|
|
organization: org?.slug ?? 'Unknown',
|
|
},
|
|
})
|
|
}}
|
|
>
|
|
{copied === 'service' ? 'Copied' : 'Copy'}
|
|
</Button>,
|
|
]}
|
|
/>
|
|
</div>
|
|
</div>
|
|
</ContentSnippet>
|
|
|
|
<ContentSnippet
|
|
selectedLanguage={language}
|
|
apikey={apikey}
|
|
endpoint={endpoint}
|
|
snippet={DOCS_CONTENT.clientApiKeys}
|
|
/>
|
|
|
|
<ContentSnippet
|
|
selectedLanguage={language}
|
|
apikey={showKeys ? serviceApiKey : 'SUPABASE_CLIENT_SERVICE_KEY'}
|
|
endpoint={endpoint}
|
|
snippet={DOCS_CONTENT.serviceApiKeys}
|
|
/>
|
|
</>
|
|
)
|
|
}
|