Update src/components/logo/Logo.tsx
Browse files- 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 |
-
|
| 29 |
-
|
| 30 |
-
|
| 31 |
-
|
| 32 |
-
|
| 33 |
-
|
| 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 |
);
|