mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-11 09:51:40 +00:00
* feat: init * fix * fix * fix * feat * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: implement icons * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: update init command * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: dialog * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add registry:base item type * feat: rename frame to canva * fix * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fi * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add all colors * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add outfit font * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix
77 lines
2.2 KiB
TypeScript
77 lines
2.2 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import { Share03Icon, Tick02Icon } from "@hugeicons/core-free-icons"
|
|
import { HugeiconsIcon } from "@hugeicons/react"
|
|
import { useQueryStates } from "nuqs"
|
|
|
|
import { copyToClipboardWithMeta } from "@/components/copy-button"
|
|
import { Button } from "@/registry/new-york-v4/ui/button"
|
|
import {
|
|
Tooltip,
|
|
TooltipContent,
|
|
TooltipTrigger,
|
|
} from "@/registry/new-york-v4/ui/tooltip"
|
|
import { designSystemSearchParams } from "@/app/(create)/lib/search-params"
|
|
|
|
export function ShareButton() {
|
|
const [params] = useQueryStates(designSystemSearchParams, {
|
|
shallow: false,
|
|
})
|
|
const [hasCopied, setHasCopied] = React.useState(false)
|
|
|
|
const shareUrl = React.useMemo(() => {
|
|
const origin = process.env.NEXT_PUBLIC_APP_URL || "http://localhost:3000"
|
|
return `${origin}/create?base=${params.base}&style=${params.style}&baseColor=${params.baseColor}&theme=${params.theme}&iconLibrary=${params.iconLibrary}&font=${params.font}&menuAccent=${params.menuAccent}&menuColor=${params.menuColor}&radius=${params.radius}&item=${params.item}`
|
|
}, [
|
|
params.base,
|
|
params.style,
|
|
params.baseColor,
|
|
params.theme,
|
|
params.iconLibrary,
|
|
params.font,
|
|
params.menuAccent,
|
|
params.menuColor,
|
|
params.radius,
|
|
params.item,
|
|
])
|
|
|
|
React.useEffect(() => {
|
|
if (hasCopied) {
|
|
const timer = setTimeout(() => setHasCopied(false), 2000)
|
|
return () => clearTimeout(timer)
|
|
}
|
|
}, [hasCopied])
|
|
|
|
const handleCopy = React.useCallback(() => {
|
|
copyToClipboardWithMeta(shareUrl, {
|
|
name: "copy_create_share_url",
|
|
properties: {
|
|
url: shareUrl,
|
|
},
|
|
})
|
|
setHasCopied(true)
|
|
}, [shareUrl])
|
|
|
|
return (
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
size="sm"
|
|
variant="outline"
|
|
className="rounded-lg shadow-none"
|
|
onClick={handleCopy}
|
|
>
|
|
{hasCopied ? (
|
|
<HugeiconsIcon icon={Tick02Icon} strokeWidth={2} />
|
|
) : (
|
|
<HugeiconsIcon icon={Share03Icon} strokeWidth={2} />
|
|
)}
|
|
Share
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>Copy Link</TooltipContent>
|
|
</Tooltip>
|
|
)
|
|
}
|