mirror of
https://github.com/supabase/supabase.git
synced 2026-06-22 03:52:46 +08:00
* Final replacements of ui setNotification with toast * Rip out UiStore * Rip out UiStore * Shift files under authConfigSchema to components/Auth * Rip out use of observers
94 lines
3.2 KiB
TypeScript
94 lines
3.2 KiB
TypeScript
import { PermissionAction } from '@supabase/shared-types/out/constants'
|
|
import { partition } from 'lodash'
|
|
import { useRouter } from 'next/router'
|
|
import toast from 'react-hot-toast'
|
|
|
|
import { useTelemetryProps } from 'common'
|
|
import { SQL_TEMPLATES } from 'components/interfaces/SQLEditor/SQLEditor.queries'
|
|
import { useProjectContext } from 'components/layouts/ProjectLayout/ProjectContext'
|
|
import type { SqlSnippet } from 'data/content/sql-snippets-query'
|
|
import { useCheckPermissions } from 'hooks'
|
|
import { uuidv4 } from 'lib/helpers'
|
|
import { useProfile } from 'lib/profile'
|
|
import Telemetry from 'lib/telemetry'
|
|
import { useSqlEditorStateSnapshot } from 'state/sql-editor'
|
|
import { createSqlSnippetSkeleton } from '../SQLEditor.utils'
|
|
import SQLCard from './SQLCard'
|
|
|
|
const SQLTemplates = () => {
|
|
const router = useRouter()
|
|
const { profile } = useProfile()
|
|
const { project } = useProjectContext()
|
|
const [sql] = partition(SQL_TEMPLATES, { type: 'template' })
|
|
|
|
const telemetryProps = useTelemetryProps()
|
|
const snap = useSqlEditorStateSnapshot()
|
|
const canCreateSQLSnippet = useCheckPermissions(PermissionAction.CREATE, 'user_content', {
|
|
resource: { type: 'sql', owner_id: profile?.id },
|
|
subject: { id: profile?.id },
|
|
})
|
|
|
|
const handleNewQuery = async (sql: string, name: string) => {
|
|
if (!project) return console.error('Project is required')
|
|
if (!profile) return console.error('Profile is required')
|
|
if (!canCreateSQLSnippet) {
|
|
return toast('Your queries will not be saved as you do not have sufficient permissions')
|
|
}
|
|
|
|
try {
|
|
const snippet = createSqlSnippetSkeleton({
|
|
id: uuidv4(),
|
|
name,
|
|
sql,
|
|
owner_id: profile.id,
|
|
project_id: project.id,
|
|
})
|
|
|
|
snap.addSnippet(snippet as SqlSnippet, project.ref)
|
|
snap.addNeedsSaving(snippet.id!)
|
|
router.push(`/project/${project.ref}/sql/${snippet.id}`)
|
|
} catch (error: any) {
|
|
toast.error(`Failed to create new query: ${error.message}`)
|
|
}
|
|
}
|
|
|
|
return (
|
|
<div className="block h-full space-y-8 overflow-y-auto p-6">
|
|
<div>
|
|
<div className="mb-4">
|
|
<h1 className="text-foreground mb-3 text-xl">Scripts</h1>
|
|
<p className="text-foreground-light text-sm">Quick scripts to run on your database.</p>
|
|
<p className="text-foreground-light text-sm">
|
|
Click on any script to fill the query box, modify the script, then click
|
|
<span className="text-code">Run</span>.
|
|
</p>
|
|
</div>
|
|
<div className="grid gap-4 sm:grid-cols-1 lg:grid-cols-2 xl:grid-cols-3 2xl:grid-cols-4">
|
|
{sql.map((x) => (
|
|
<SQLCard
|
|
key={x.title}
|
|
title={x.title}
|
|
description={x.description}
|
|
sql={x.sql}
|
|
onClick={(sql, title) => {
|
|
handleNewQuery(sql, title)
|
|
Telemetry.sendEvent(
|
|
{
|
|
category: 'scripts',
|
|
action: 'script_clicked',
|
|
label: x.title,
|
|
},
|
|
telemetryProps,
|
|
router
|
|
)
|
|
}}
|
|
/>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default SQLTemplates
|