mirror of
https://github.com/SkalaraAI/skalara-web.git
synced 2025-04-06 05:20:20 -04:00
style(client): add visual tags for tech stack
This commit is contained in:
parent
a459712c17
commit
16a8aef7ed
|
@ -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
36
components/ui/badge.tsx
Normal 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 }
|
Loading…
Reference in New Issue
Block a user