Ezmary commited on
Commit
ebcc2a0
·
verified ·
1 Parent(s): c990d50

Update src/components/logo/Logo.tsx

Browse files
Files changed (1) hide show
  1. src/components/logo/Logo.tsx +14 -26
src/components/logo/Logo.tsx CHANGED
@@ -9,44 +9,32 @@ type LogoProps = {
9
  isAi: boolean;
10
  isActive: boolean;
11
  speakingVolume?: number;
 
12
  }
13
 
14
- export default function Logo({isAi, isActive, isMini, speakingVolume = 0}: LogoProps) {
15
-
16
  if (!isActive) return null;
17
 
18
  const aiVoiceScale = 1 + (speakingVolume * 1.5);
19
 
 
 
 
 
 
20
  return (
21
  <div className={cn("w-fit flex items-center justify-center")}>
22
  <div className={"hidden bg-green-200 bg-green-300 bg-green-400 bg-blue-200 bg-blue-300 bg-blue-400 dark:bg-green-700 dark:bg-green-600 dark:bg-green-500 dark:bg-blue-700 dark:bg-blue-600 dark:bg-blue-500"}>
23
  color pre-loader
24
  </div>
25
-
26
  <div className={cn("relative", isMini ? "w-[80px] h-[80px]" : "w-[200px] h-[200px]")}>
27
- <>
28
- <div
29
- className={cn(
30
- "absolute rounded-full opacity-50",
31
- "ai-speaking-ripple",
32
- isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700",
33
- isMini ? "inset-[10px]" : "inset-[40px]",
34
- )}
35
- style={{ '--ai-voice-scale': aiVoiceScale } as React.CSSProperties}
36
- />
37
-
38
- <div className={cn("absolute inset-0 rounded-full opacity-50", isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700")} />
39
- <div className={cn("absolute rounded-full opacity-50", isAi ? "bg-green-300 dark:bg-green-600" : "bg-blue-300 dark:bg-blue-600", isMini ? "inset-[5px]" : "inset-[20px]")} />
40
- <div className={cn("absolute rounded-full opacity-50", isAi ? "bg-green-400 dark:bg-green-500" : "bg-blue-400 dark:bg-blue-500", isMini ? "inset-[12px]" : "inset-[50px]")} />
41
-
42
- <div className={cn("z-10 absolute flex items-center justify-center inset-0")}>
43
- {humanAiIcon({
44
- size: isMini ? 24 : 45,
45
- humanColor: "#FFFFFF",
46
- aiColor: "#FFFFFF",
47
- })}
48
- </div>
49
- </>
50
  </div>
51
  </div>
52
  );
 
9
  isAi: boolean;
10
  isActive: boolean;
11
  speakingVolume?: number;
12
+ isUserSpeaking?: boolean;
13
  }
14
 
15
+ export default function Logo({ isAi, isActive, isMini, speakingVolume = 0, isUserSpeaking = false }: LogoProps) {
 
16
  if (!isActive) return null;
17
 
18
  const aiVoiceScale = 1 + (speakingVolume * 1.5);
19
 
20
+ const animatedCircleStyle: React.CSSProperties = {
21
+ transition: 'transform 0.15s ease-out',
22
+ transform: `scale(${aiVoiceScale})`
23
+ };
24
+
25
  return (
26
  <div className={cn("w-fit flex items-center justify-center")}>
27
  <div className={"hidden bg-green-200 bg-green-300 bg-green-400 bg-blue-200 bg-blue-300 bg-blue-400 dark:bg-green-700 dark:bg-green-600 dark:bg-green-500 dark:bg-blue-700 dark:bg-blue-600 dark:bg-blue-500"}>
28
  color pre-loader
29
  </div>
 
30
  <div className={cn("relative", isMini ? "w-[80px] h-[80px]" : "w-[200px] h-[200px]")}>
31
+ <div className={cn("absolute rounded-full opacity-50", isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700", isMini ? "inset-[10px]" : "inset-[40px]")} style={animatedCircleStyle} />
32
+ <div className={cn("absolute inset-0 rounded-full opacity-50", isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700")} />
33
+ <div className={cn("absolute rounded-full opacity-50", isAi ? "bg-green-300 dark:bg-green-600" : "bg-blue-300 dark:bg-blue-600", isMini ? "inset-[5px]" : "inset-[20px]")} />
34
+ <div className={cn("absolute rounded-full opacity-50", isAi ? "bg-green-400 dark:bg-green-500" : "bg-blue-400 dark:bg-blue-500", isMini ? "inset-[12px]" : "inset-[50px]")} />
35
+ <div className={cn("z-10 absolute flex items-center justify-center inset-0")}>
36
+ {humanAiIcon({ size: isMini ? 24 : 45, isUserSpeaking: isUserSpeaking })}
37
+ </div>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
38
  </div>
39
  </div>
40
  );