style(client): add visual tags for tech stack

This commit is contained in:
Christopher Arraya 2023-07-30 13:28:01 -04:00
parent a459712c17
commit 16a8aef7ed
2 changed files with 62 additions and 0 deletions

View File

@ -4,6 +4,8 @@ import Link from "next/link";
import { Project } from "@/types/models";
import { Button, buttonVariants } from "@/components/ui/button";
import { Input } from "@/components/ui/input";
import { Badge } from "@/components/ui/badge";
import { X } from "lucide-react";
import {
Dialog,
DialogContent,
@ -14,6 +16,7 @@ import {
} from "@/components/ui/dialog";
import {
Form,
FormDescription,
FormControl,
FormField,
FormItem,
@ -160,6 +163,29 @@ export default function Projects() {
onKeyDown={keyHandler}
/>
</FormControl>
<FormDescription>
{form.getValues("stack").map((stack) => (
<Badge
key={stack}
className="mr-2 font-light"
variant="outline"
>
{stack}{" "}
<X
className="inline font-light"
size={16}
onClick={() =>
setValue(
"stack",
form
.getValues("stack")
.filter((s) => s !== stack)
)
}
/>
</Badge>
))}
</FormDescription>
<FormMessage />
</FormItem>
)}

36
components/ui/badge.tsx Normal file
View File

@ -0,0 +1,36 @@
import * as React from "react"
import { cva, type VariantProps } from "class-variance-authority"
import { cn } from "@/lib/utils"
const badgeVariants = cva(
"inline-flex items-center rounded-full border px-2.5 py-0.5 text-xs font-semibold transition-colors focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2",
{
variants: {
variant: {
default:
"border-transparent bg-primary text-primary-foreground hover:bg-primary/80",
secondary:
"border-transparent bg-secondary text-secondary-foreground hover:bg-secondary/80",
destructive:
"border-transparent bg-destructive text-destructive-foreground hover:bg-destructive/80",
outline: "text-foreground",
},
},
defaultVariants: {
variant: "default",
},
}
)
export interface BadgeProps
extends React.HTMLAttributes<HTMLDivElement>,
VariantProps<typeof badgeVariants> {}
function Badge({ className, variant, ...props }: BadgeProps) {
return (
<div className={cn(badgeVariants({ variant }), className)} {...props} />
)
}
export { Badge, badgeVariants }