mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-26 09:15:40 +00:00 
			
		
		
		
	# What does this PR do? Implements table and detail views for chat completions <img width="1548" alt="image" src="https://github.com/user-attachments/assets/01061b7f-0d47-4b3b-b5ac-2df8f9035ef6" /> <img width="1549" alt="image" src="https://github.com/user-attachments/assets/738d8612-8258-4c2c-858b-bee39030649f" /> ## Test Plan npm run test
		
			
				
	
	
		
			92 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import * as React from "react";
 | |
| 
 | |
| import { cn } from "@/lib/utils";
 | |
| 
 | |
| function Card({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card"
 | |
|       className={cn(
 | |
|         "bg-card text-card-foreground flex flex-col gap-6 rounded-xl border py-6 shadow-sm",
 | |
|         className,
 | |
|       )}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardHeader({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-header"
 | |
|       className={cn(
 | |
|         "@container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-6 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-6",
 | |
|         className,
 | |
|       )}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardTitle({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-title"
 | |
|       className={cn("leading-none font-semibold", className)}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardDescription({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-description"
 | |
|       className={cn("text-muted-foreground text-sm", className)}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardAction({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-action"
 | |
|       className={cn(
 | |
|         "col-start-2 row-span-2 row-start-1 self-start justify-self-end",
 | |
|         className,
 | |
|       )}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardContent({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-content"
 | |
|       className={cn("px-6", className)}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| function CardFooter({ className, ...props }: React.ComponentProps<"div">) {
 | |
|   return (
 | |
|     <div
 | |
|       data-slot="card-footer"
 | |
|       className={cn("flex items-center px-6 [.border-t]:pt-6", className)}
 | |
|       {...props}
 | |
|     />
 | |
|   );
 | |
| }
 | |
| 
 | |
| export {
 | |
|   Card,
 | |
|   CardHeader,
 | |
|   CardFooter,
 | |
|   CardTitle,
 | |
|   CardAction,
 | |
|   CardDescription,
 | |
|   CardContent,
 | |
| };
 |