Files
supabase/apps/studio/components/interfaces/ProjectCreation/InitialStep.tsx
Saxon Fletcher d633ced97d Feat/new project creation experiment (#31237)
* some early ideas

* better approach

* fix globe stuff

* add initial step

* reset and submit button for chat

* cleanup

* remove www

* more clean up

* mobile and more cleanup

* fixes

* update advanced and security

* fix project checks

* connect form

* fix reset and tidied up other things

* add layout options

* a/b test

* add offset

* add ab test

* remove www packages

* remove www

* package

* update coordinates

* feat: create ProjectCreationInitialStepSubmittedEvent

* feat: add event for capturing intention of prompting

* fix: bring pnpm-lock up to date

* fix ts errors

* fix globe

* fix globe animation

* fix ts

* remove imports and tools

* update module resolution

* global redirect

* delay rendering

* Update apps/studio/pages/new/[slug].tsx

Co-authored-by: Alaister Young <alaister@users.noreply.github.com>

* take directly to v2 via project create dropdown

* move redirect to useEffect

* feat: distinguish events between initial and second step

* feat: emit an event when create project is clicked on new/v2

* fix: correct event type defs

* remove unused imports

* Various clean ups

* improvements

* Minor refactors

* clean up

* ts fixes

---------

Co-authored-by: Long Hoang <1732217+loong@users.noreply.github.com>
Co-authored-by: Alaister Young <alaister@users.noreply.github.com>
Co-authored-by: Joshen Lim <joshenlimek@gmail.com>
2025-01-17 09:59:21 +10:00

83 lines
2.6 KiB
TypeScript

import { Database, Import } from 'lucide-react'
import { cn } from 'ui'
import { SchemaGenerator } from './SchemaGenerator'
interface SupabaseService {
name: 'Auth' | 'Storage' | 'Database' | 'Edge Function' | 'Cron' | 'Queues' | 'Vector'
reason: string
}
export const InitialStep = ({
onSubmit,
onStartBlank,
onMigrate,
onSqlGenerated,
onServicesUpdated,
onTitleUpdated,
}: {
onSubmit: (value: string) => void
onStartBlank: () => void
onMigrate: () => void
onSqlGenerated: (sql: string) => void
onServicesUpdated: (services: SupabaseService[]) => void
onTitleUpdated: (title: string) => void
}) => {
return (
<div className="w-full">
<h3>What are you building?</h3>
<p className="text-sm text-foreground-lighter mb-4">
We can generate a schema for you to kick start your project.
</p>
<SchemaGenerator
isOneOff
step="initial"
onSqlGenerated={(sql) => {
onSqlGenerated(sql)
onSubmit(sql)
}}
onServicesUpdated={onServicesUpdated}
onTitleUpdated={onTitleUpdated}
/>
<div
className={cn(
'relative text-center text-sm text-foreground-lighter my-4 before:absolute before:inset-y-1/2 before:left-0 before:w-[calc(50%-24px)]',
'before:h-px before:bg-border after:absolute after:inset-y-1/2 after:right-0 after:w-[calc(50%-24px)] after:h-px after:bg-border'
)}
>
or
</div>
<div className="grid grid-cols-2 gap-4">
<div
className="p-4 h-auto block border rounded-md cursor text-sm border-strong hover:border-foreground-muted cursor-pointer flex items-center gap-4"
role="button"
onClick={onStartBlank}
>
<Database strokeWidth={1.5} size={16} className="text-foreground-lighter shrink-0" />
<div>
<span className="block">Start blank</span>
<span className="text-foreground-lighter">Configure a database and dive right in</span>
</div>
</div>
<div
className="p-4 h-auto block border rounded-md cursor text-sm border-strong hover:border-foreground-muted cursor-pointer flex items-center gap-4"
role="button"
onClick={onMigrate}
>
<Import
strokeWidth={1.5}
size={16}
className="text-foreground-lighter mx-auto shrink-0"
/>
<div>
<span className="mb-1 block">Migrate</span>
<span className="text-foreground-lighter">
Import your database from another provider
</span>
</div>
</div>
</div>
</div>
)
}