Skip to content

Commit 7978b13

Browse files
committed
github btn
1 parent 624a1cb commit 7978b13

File tree

4 files changed

+92
-2
lines changed

4 files changed

+92
-2
lines changed

docs/next-js/app/page.tsx

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
import Image from "next/image";
2-
import LocalNetCDFMeta from "../components/loading/LocalNetCDFMeta";
3-
2+
import LocalNetCDFMeta from "@/components/loading/LocalNetCDFMeta";
3+
import GithubButton from "@/components/loading/GitHubButton";
44
export default function Home() {
55
return (
66
<div className="flex min-h-screen items-center justify-center bg-zinc-50 font-sans dark:bg-black">
@@ -19,6 +19,10 @@ export default function Home() {
1919
</span>
2020
</div>
2121
<LocalNetCDFMeta />
22+
23+
<div className="fixed top-2 right-4 z-50 flex items-center gap-2">
24+
<GithubButton />
25+
</div>
2226
</main>
2327
</div>
2428
);
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
"use client";
2+
3+
import { FaGithub } from "react-icons/fa";
4+
import Link from "next/link";
5+
import { Button } from "@/components/ui/button";
6+
import { Tooltip, TooltipContent, TooltipTrigger } from "@/components/ui/tooltip";
7+
8+
export default function GithubButton() {
9+
return (
10+
<Tooltip delayDuration={500}>
11+
<TooltipTrigger asChild>
12+
<Link href="https://github.com/EarthyScience/netcdf4-wasm" aria-label="github" target="_blank" rel="noopener noreferrer">
13+
<Button variant="ghost" size="icon" className="cursor-pointer hover:scale-90 transition-transform duration-100 ease-out">
14+
<FaGithub className="size-6"/>
15+
</Button>
16+
</Link>
17+
</TooltipTrigger>
18+
<TooltipContent side="bottom" align="start">
19+
github
20+
</TooltipContent>
21+
</Tooltip>
22+
);
23+
}
Lines changed: 61 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,61 @@
1+
"use client"
2+
3+
import * as React from "react"
4+
import * as TooltipPrimitive from "@radix-ui/react-tooltip"
5+
6+
import { cn } from "@/lib/utils"
7+
8+
function TooltipProvider({
9+
delayDuration = 0,
10+
...props
11+
}: React.ComponentProps<typeof TooltipPrimitive.Provider>) {
12+
return (
13+
<TooltipPrimitive.Provider
14+
data-slot="tooltip-provider"
15+
delayDuration={delayDuration}
16+
{...props}
17+
/>
18+
)
19+
}
20+
21+
function Tooltip({
22+
...props
23+
}: React.ComponentProps<typeof TooltipPrimitive.Root>) {
24+
return (
25+
<TooltipProvider>
26+
<TooltipPrimitive.Root data-slot="tooltip" {...props} />
27+
</TooltipProvider>
28+
)
29+
}
30+
31+
function TooltipTrigger({
32+
...props
33+
}: React.ComponentProps<typeof TooltipPrimitive.Trigger>) {
34+
return <TooltipPrimitive.Trigger data-slot="tooltip-trigger" {...props} />
35+
}
36+
37+
function TooltipContent({
38+
className,
39+
sideOffset = 0,
40+
children,
41+
...props
42+
}: React.ComponentProps<typeof TooltipPrimitive.Content>) {
43+
return (
44+
<TooltipPrimitive.Portal>
45+
<TooltipPrimitive.Content
46+
data-slot="tooltip-content"
47+
sideOffset={sideOffset}
48+
className={cn(
49+
"bg-foreground text-background animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 w-fit origin-(--radix-tooltip-content-transform-origin) rounded-md px-3 py-1.5 text-xs text-balance",
50+
className
51+
)}
52+
{...props}
53+
>
54+
{children}
55+
<TooltipPrimitive.Arrow className="bg-foreground fill-foreground z-50 size-2.5 translate-y-[calc(-50%_-_2px)] rotate-45 rounded-[2px]" />
56+
</TooltipPrimitive.Content>
57+
</TooltipPrimitive.Portal>
58+
)
59+
}
60+
61+
export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }

docs/next-js/package.json

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,12 +16,14 @@
1616
"@radix-ui/react-label": "^2.1.8",
1717
"@radix-ui/react-separator": "^1.1.8",
1818
"@radix-ui/react-slot": "^1.2.4",
19+
"@radix-ui/react-tooltip": "^1.2.8",
1920
"class-variance-authority": "^0.7.1",
2021
"clsx": "^2.1.1",
2122
"lucide-react": "^0.562.0",
2223
"next": "16.1.1",
2324
"react": "19.2.3",
2425
"react-dom": "19.2.3",
26+
"react-icons": "^5.5.0",
2527
"tailwind-merge": "^3.4.0"
2628
},
2729
"devDependencies": {

0 commit comments

Comments
 (0)