* Update Supabase docs URLs to use env variable Co-authored-by: a <a@alaisteryoung.com> * Refactor: Use DOCS_URL constant for documentation links This change centralizes documentation links using a new DOCS_URL constant, improving maintainability and consistency. Co-authored-by: a <a@alaisteryoung.com> * Refactor: Use DOCS_URL constant for all documentation links This change replaces hardcoded documentation URLs with a centralized constant, improving maintainability and consistency. Co-authored-by: a <a@alaisteryoung.com> * replace more instances * ci: Autofix updates from GitHub workflow * remaining instances * fix duplicate useRouter --------- Co-authored-by: Cursor Agent <cursoragent@cursor.com> Co-authored-by: alaister <10985857+alaister@users.noreply.github.com>
67 lines
2.5 KiB
TypeScript
67 lines
2.5 KiB
TypeScript
import { Download } from 'lucide-react'
|
|
import { useState } from 'react'
|
|
import { toast } from 'sonner'
|
|
|
|
import { useParams } from 'common'
|
|
import { DocsButton } from 'components/ui/DocsButton'
|
|
import { useProjectPostgrestConfigQuery } from 'data/config/project-postgrest-config-query'
|
|
import { generateTypes } from 'data/projects/project-type-generation-query'
|
|
import { DOCS_URL } from 'lib/constants'
|
|
import { Button } from 'ui'
|
|
import ContentSnippet from '../ContentSnippet'
|
|
import { DOCS_CONTENT } from '../ProjectAPIDocs.constants'
|
|
import type { ContentProps } from './Content.types'
|
|
|
|
const Entities = ({ language }: ContentProps) => {
|
|
const { ref } = useParams()
|
|
const [isGeneratingTypes, setIsGeneratingTypes] = useState(false)
|
|
|
|
const { data: config } = useProjectPostgrestConfigQuery({ projectRef: ref })
|
|
|
|
const onClickGenerateTypes = async () => {
|
|
try {
|
|
setIsGeneratingTypes(true)
|
|
const res = await generateTypes({ ref, included_schemas: config?.db_schema })
|
|
let element = document.createElement('a')
|
|
element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(res.types))
|
|
element.setAttribute('download', 'supabase.ts')
|
|
element.style.display = 'none'
|
|
document.body.appendChild(element)
|
|
element.click()
|
|
document.body.removeChild(element)
|
|
toast.success(`Successfully generated types! File is being downloaded`)
|
|
} catch (error: any) {
|
|
toast.error(`Failed to generate types: ${error.message}`)
|
|
} finally {
|
|
setIsGeneratingTypes(false)
|
|
}
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<ContentSnippet selectedLanguage={language} snippet={DOCS_CONTENT.entitiesIntroduction} />
|
|
<div>
|
|
<ContentSnippet selectedLanguage={language} snippet={DOCS_CONTENT.generatingTypes} />
|
|
<div className="flex items-center gap-x-2 px-4 mt-3">
|
|
<DocsButton href={`${DOCS_URL}/guides/database/api/generating-types`} />
|
|
<Button
|
|
type="default"
|
|
disabled={isGeneratingTypes}
|
|
loading={isGeneratingTypes}
|
|
icon={<Download strokeWidth={1.5} />}
|
|
onClick={onClickGenerateTypes}
|
|
>
|
|
Generate and download types
|
|
</Button>
|
|
</div>
|
|
<p className="text-xs text-foreground-light px-4 mt-2">
|
|
Remember to re-generate and download this file as you make changes to your tables.
|
|
</p>
|
|
</div>
|
|
<ContentSnippet selectedLanguage={language} snippet={DOCS_CONTENT.graphql} />
|
|
</>
|
|
)
|
|
}
|
|
|
|
export default Entities
|