mirror of
https://github.com/supabase/supabase.git
synced 2026-07-03 11:14:34 +08:00
* Add social login block. * Regen the registry. * Fix the nextjs social auth. * Add social auth blocks for RR, Tanstack and React. * Minor fixes. * Add docs. * Update the docs. * Minor fixes to the blocks. * Update the docs. * Fix various doc issues. * Fix the redirect in the password-based auth. * Fix note about supabase clients in docs. * Use with instead of assert in the registry imports. * Update all auth blocks to use /protected. * Update all docs for the password-based auth. * Add new label to social auth. * Fix docs issues. * Light mode fix * Smol fixes * Fix the origin in the login route. * Add social auth to the landing page. * Regenerate the registry. --------- Co-authored-by: Terry Sutton <saltcod@gmail.com>
84 lines
3.0 KiB
TypeScript
84 lines
3.0 KiB
TypeScript
'use client'
|
|
|
|
import { motion } from 'framer-motion'
|
|
import { Tabs_Shadcn_, TabsContent_Shadcn_, TabsList_Shadcn_, TabsTrigger_Shadcn_ } from 'ui'
|
|
import { CommandCopyButton } from './command-copy-button'
|
|
import { useLocalStorage } from './use-local-storage'
|
|
|
|
interface CommandCopyProps {
|
|
name: string
|
|
highlight?: boolean
|
|
}
|
|
|
|
type PackageManager = 'npm' | 'pnpm' | 'yarn' | 'bun'
|
|
|
|
const LOCAL_STORAGE_KEY = 'package-manager-copy-command'
|
|
|
|
export function Command({ name, highlight }: CommandCopyProps) {
|
|
const [value, setValue] = useLocalStorage(LOCAL_STORAGE_KEY, 'npm')
|
|
|
|
const getBaseUrl = () => {
|
|
if (process.env.NEXT_PUBLIC_VERCEL_TARGET_ENV === 'production') {
|
|
return `https://supabase.com`
|
|
} else if (process.env.NEXT_PUBLIC_VERCEL_TARGET_ENV === 'preview') {
|
|
return `https://${process.env.NEXT_PUBLIC_VERCEL_BRANCH_URL}`
|
|
} else {
|
|
return 'http://localhost:3004'
|
|
}
|
|
}
|
|
|
|
const baseUrl = getBaseUrl()
|
|
const componentPath = `${process.env.NEXT_PUBLIC_BASE_PATH ?? ''}/r/${name}.json`
|
|
|
|
const commands: Record<PackageManager, string> = {
|
|
npm: `npx shadcn@latest add ${baseUrl}${componentPath}`,
|
|
pnpm: `pnpm dlx shadcn@latest add ${baseUrl}${componentPath}`,
|
|
yarn: `yarn dlx shadcn@latest add ${baseUrl}${componentPath}`,
|
|
bun: `bunx --bun shadcn@latest add ${baseUrl}${componentPath}`,
|
|
}
|
|
|
|
return (
|
|
<Tabs_Shadcn_ value={value} onValueChange={setValue} className="w-full">
|
|
<div className="w-full group relative rounded-lg bg-surface-200 dark:bg-surface-100 px-4 py-2 overflow-hidden">
|
|
{highlight && (
|
|
<motion.div
|
|
className="absolute inset-0 bg-gradient-to-l from-transparent via-[#bbb] dark:via-white to-transparent opacity-10 z-0"
|
|
initial={{ x: '100%' }}
|
|
animate={{ x: '-100%' }}
|
|
transition={{
|
|
repeat: Infinity,
|
|
duration: 2.5,
|
|
ease: 'linear',
|
|
repeatType: 'loop',
|
|
}}
|
|
/>
|
|
)}
|
|
|
|
<div className="flex flex-col">
|
|
<TabsList_Shadcn_ className="gap-2 relative mb-2 z-10">
|
|
{(Object.keys(commands) as PackageManager[]).map((manager) => (
|
|
<TabsTrigger_Shadcn_ key={manager} value={manager} className="text-xs">
|
|
{manager}
|
|
</TabsTrigger_Shadcn_>
|
|
))}
|
|
</TabsList_Shadcn_>
|
|
|
|
{(Object.keys(commands) as PackageManager[]).map((manager) => (
|
|
<TabsContent_Shadcn_ key={manager} value={manager} className="m-0">
|
|
<div className="flex items-center">
|
|
<div className="flex-1 font-mono text-sm text-foreground relative z-10">
|
|
<span className="mr-2 text-[#888]">$</span>
|
|
{commands[manager]}
|
|
</div>
|
|
<div className="relative z-10">
|
|
<CommandCopyButton command={commands[manager]} />
|
|
</div>
|
|
</div>
|
|
</TabsContent_Shadcn_>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</Tabs_Shadcn_>
|
|
)
|
|
}
|