* docs: add vue client to ui-library * docs: add missing vue client to llms.txt * docs: add nuxt client to ui-library * docs: wrong env variable names * docs: fix dependencies * docs: update client-nuxtjs.json * Reinstall the deps so that the pnpm-lock.yaml has less changes. * Add blocks/vue package. * Remove the vue blocks from ui-library. * Copy the vue blocks into ui-library. * Clean up unneeded files. * Regenerate the pnpm-lock file from master. * Fix prettier errors. * docs: update shadcn-vue cli * docs: reusable server client * Small things * docs: improvments after CR --------- Co-authored-by: Ivan Vasilov <vasilov.ivan@gmail.com> Co-authored-by: Terry Sutton <saltcod@gmail.com>
101 lines
3.8 KiB
TypeScript
101 lines
3.8 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
|
|
// For Vue, we need to use the `shadcn-vue` package instead of `shadcn`
|
|
framework?: 'react' | 'vue'
|
|
}
|
|
|
|
type PackageManager = 'npm' | 'pnpm' | 'yarn' | 'bun'
|
|
|
|
const LOCAL_STORAGE_KEY = 'package-manager-copy-command'
|
|
|
|
export function Command({ name, highlight, framework = 'react' }: 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> =
|
|
framework === 'react'
|
|
? {
|
|
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}`,
|
|
}
|
|
: framework === 'vue'
|
|
? {
|
|
npm: `npx shadcn-vue@latest add ${baseUrl}${componentPath}`,
|
|
pnpm: `pnpm dlx shadcn-vue@latest add ${baseUrl}${componentPath}`,
|
|
yarn: `yarn dlx shadcn-vue@latest add ${baseUrl}${componentPath}`,
|
|
bun: `bunx --bun shadcn-vue@latest add ${baseUrl}${componentPath}`,
|
|
}
|
|
: {
|
|
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] select-none">$</span>
|
|
{commands[manager]}
|
|
</div>
|
|
<div className="relative z-10">
|
|
<CommandCopyButton command={commands[manager]} />
|
|
</div>
|
|
</div>
|
|
</TabsContent_Shadcn_>
|
|
))}
|
|
</div>
|
|
</div>
|
|
</Tabs_Shadcn_>
|
|
)
|
|
}
|