mirror of
				https://github.com/meta-llama/llama-stack.git
				synced 2025-10-25 09:05:37 +00:00 
			
		
		
		
	# What does this PR do? - Introduces the Agent Session creation for the Playground and allows users to set tools - note tools are actually not usable yet and this is marked explicitly - this also caches sessions locally for faster loading on the UI and deletes them appropriately - allows users to easily create new sessions as well - Moved Model Configuration settings and "System Message" / Prompt to the left component - Added new logo and favicon - Added new typing animation when LLM is generating ### Create New Session <img width="1916" height="1393" alt="Screenshot 2025-08-21 at 4 18 08 PM" src="https://github.com/user-attachments/assets/52c70ae3-a33e-4338-8522-8184c692c320" /> ### List of Sessions <img width="1920" height="1391" alt="Screenshot 2025-08-21 at 4 18 56 PM" src="https://github.com/user-attachments/assets/ed78c3c6-08ec-486c-8bad-9b7382c11360" /> <!-- If resolving an issue, uncomment and update the line below --> <!-- Closes #[issue-number] --> ## Test Plan Unit tests added --------- Signed-off-by: Francisco Javier Arceo <farceo@redhat.com>
		
			
				
	
	
		
			163 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			CSS
		
	
	
	
	
	
| @import "tailwindcss";
 | |
| @import "tw-animate-css";
 | |
| 
 | |
| @custom-variant dark (&:is(.dark *));
 | |
| 
 | |
| @theme inline {
 | |
|   --color-background: var(--background);
 | |
|   --color-foreground: var(--foreground);
 | |
|   --font-sans: var(--font-geist-sans);
 | |
|   --font-mono: var(--font-geist-mono);
 | |
|   --color-sidebar-ring: var(--sidebar-ring);
 | |
|   --color-sidebar-border: var(--sidebar-border);
 | |
|   --color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
 | |
|   --color-sidebar-accent: var(--sidebar-accent);
 | |
|   --color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
 | |
|   --color-sidebar-primary: var(--sidebar-primary);
 | |
|   --color-sidebar-foreground: var(--sidebar-foreground);
 | |
|   --color-sidebar: var(--sidebar);
 | |
|   --color-chart-5: var(--chart-5);
 | |
|   --color-chart-4: var(--chart-4);
 | |
|   --color-chart-3: var(--chart-3);
 | |
|   --color-chart-2: var(--chart-2);
 | |
|   --color-chart-1: var(--chart-1);
 | |
|   --color-ring: var(--ring);
 | |
|   --color-input: var(--input);
 | |
|   --color-border: var(--border);
 | |
|   --color-destructive: var(--destructive);
 | |
|   --color-accent-foreground: var(--accent-foreground);
 | |
|   --color-accent: var(--accent);
 | |
|   --color-muted-foreground: var(--muted-foreground);
 | |
|   --color-muted: var(--muted);
 | |
|   --color-secondary-foreground: var(--secondary-foreground);
 | |
|   --color-secondary: var(--secondary);
 | |
|   --color-primary-foreground: var(--primary-foreground);
 | |
|   --color-primary: var(--primary);
 | |
|   --color-popover-foreground: var(--popover-foreground);
 | |
|   --color-popover: var(--popover);
 | |
|   --color-card-foreground: var(--card-foreground);
 | |
|   --color-card: var(--card);
 | |
|   --radius-sm: calc(var(--radius) - 4px);
 | |
|   --radius-md: calc(var(--radius) - 2px);
 | |
|   --radius-lg: var(--radius);
 | |
|   --radius-xl: calc(var(--radius) + 4px);
 | |
| }
 | |
| 
 | |
| :root {
 | |
|   --radius: 0.625rem;
 | |
|   --background: oklch(1 0 0);
 | |
|   --foreground: oklch(0.145 0 0);
 | |
|   --card: oklch(1 0 0);
 | |
|   --card-foreground: oklch(0.145 0 0);
 | |
|   --popover: oklch(1 0 0);
 | |
|   --popover-foreground: oklch(0.145 0 0);
 | |
|   --primary: oklch(0.205 0 0);
 | |
|   --primary-foreground: oklch(0.985 0 0);
 | |
|   --secondary: oklch(0.97 0 0);
 | |
|   --secondary-foreground: oklch(0.205 0 0);
 | |
|   --muted: oklch(0.97 0 0);
 | |
|   --muted-foreground: oklch(0.556 0 0);
 | |
|   --accent: oklch(0.97 0 0);
 | |
|   --accent-foreground: oklch(0.205 0 0);
 | |
|   --destructive: oklch(0.577 0.245 27.325);
 | |
|   --border: oklch(0.922 0 0);
 | |
|   --input: oklch(0.922 0 0);
 | |
|   --ring: oklch(0.708 0 0);
 | |
|   --chart-1: oklch(0.646 0.222 41.116);
 | |
|   --chart-2: oklch(0.6 0.118 184.704);
 | |
|   --chart-3: oklch(0.398 0.07 227.392);
 | |
|   --chart-4: oklch(0.828 0.189 84.429);
 | |
|   --chart-5: oklch(0.769 0.188 70.08);
 | |
|   --sidebar: oklch(0.985 0 0);
 | |
|   --sidebar-foreground: oklch(0.145 0 0);
 | |
|   --sidebar-primary: oklch(0.205 0 0);
 | |
|   --sidebar-primary-foreground: oklch(0.985 0 0);
 | |
|   --sidebar-accent: oklch(0.97 0 0);
 | |
|   --sidebar-accent-foreground: oklch(0.205 0 0);
 | |
|   --sidebar-border: oklch(0.922 0 0);
 | |
|   --sidebar-ring: oklch(0.708 0 0);
 | |
| }
 | |
| 
 | |
| .dark {
 | |
|   --background: oklch(0.145 0 0);
 | |
|   --foreground: oklch(0.985 0 0);
 | |
|   --card: oklch(0.205 0 0);
 | |
|   --card-foreground: oklch(0.985 0 0);
 | |
|   --popover: oklch(0.205 0 0);
 | |
|   --popover-foreground: oklch(0.985 0 0);
 | |
|   --primary: oklch(0.922 0 0);
 | |
|   --primary-foreground: oklch(0.205 0 0);
 | |
|   --secondary: oklch(0.269 0 0);
 | |
|   --secondary-foreground: oklch(0.985 0 0);
 | |
|   --muted: oklch(0.269 0 0);
 | |
|   --muted-foreground: oklch(0.708 0 0);
 | |
|   --accent: oklch(0.269 0 0);
 | |
|   --accent-foreground: oklch(0.985 0 0);
 | |
|   --destructive: oklch(0.704 0.191 22.216);
 | |
|   --border: oklch(1 0 0 / 10%);
 | |
|   --input: oklch(1 0 0 / 15%);
 | |
|   --ring: oklch(0.556 0 0);
 | |
|   --chart-1: oklch(0.488 0.243 264.376);
 | |
|   --chart-2: oklch(0.696 0.17 162.48);
 | |
|   --chart-3: oklch(0.769 0.188 70.08);
 | |
|   --chart-4: oklch(0.627 0.265 303.9);
 | |
|   --chart-5: oklch(0.645 0.246 16.439);
 | |
|   --sidebar: oklch(0.205 0 0);
 | |
|   --sidebar-foreground: oklch(0.985 0 0);
 | |
|   --sidebar-primary: oklch(0.488 0.243 264.376);
 | |
|   --sidebar-primary-foreground: oklch(0.985 0 0);
 | |
|   --sidebar-accent: oklch(0.269 0 0);
 | |
|   --sidebar-accent-foreground: oklch(0.985 0 0);
 | |
|   --sidebar-border: oklch(1 0 0 / 10%);
 | |
|   --sidebar-ring: oklch(0.556 0 0);
 | |
| }
 | |
| 
 | |
| @layer base {
 | |
|   * {
 | |
|     @apply border-border outline-ring/50;
 | |
|   }
 | |
|   body {
 | |
|     @apply bg-background text-foreground;
 | |
|   }
 | |
| }
 | |
| 
 | |
| @layer utilities {
 | |
|   .animate-typing-dot-1 {
 | |
|     animation: typing-dot-bounce-1 0.8s cubic-bezier(0.4, 0, 0.6, 1) infinite;
 | |
|   }
 | |
| 
 | |
|   .animate-typing-dot-2 {
 | |
|     animation: typing-dot-bounce-2 0.8s cubic-bezier(0.4, 0, 0.6, 1) infinite;
 | |
|   }
 | |
| 
 | |
|   .animate-typing-dot-3 {
 | |
|     animation: typing-dot-bounce-3 0.8s cubic-bezier(0.4, 0, 0.6, 1) infinite;
 | |
|   }
 | |
| 
 | |
|   @keyframes typing-dot-bounce-1 {
 | |
|     0%, 15%, 85%, 100% {
 | |
|       transform: translateY(0);
 | |
|     }
 | |
|     7.5% {
 | |
|       transform: translateY(-6px);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @keyframes typing-dot-bounce-2 {
 | |
|     0%, 15%, 35%, 85%, 100% {
 | |
|       transform: translateY(0);
 | |
|     }
 | |
|     25% {
 | |
|       transform: translateY(-6px);
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   @keyframes typing-dot-bounce-3 {
 | |
|     0%, 35%, 55%, 85%, 100% {
 | |
|       transform: translateY(0);
 | |
|     }
 | |
|     45% {
 | |
|       transform: translateY(-6px);
 | |
|     }
 | |
|   }
 | |
| }
 |