Spaces:
Running
Running
Update src/components/logo/Logo.tsx
Browse files- src/components/logo/Logo.tsx +27 -8
src/components/logo/Logo.tsx
CHANGED
@@ -8,15 +8,16 @@ type LogoProps = {
|
|
8 |
isMini: boolean;
|
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})`
|
@@ -24,23 +25,41 @@ export default function Logo({ isAi, isActive, isMini, speakingVolume = 0, isUse
|
|
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 |
-
{/*
|
32 |
-
<div className={cn(
|
|
|
|
|
|
|
|
|
33 |
|
34 |
{/* این دایره با صدای ربات بزرگ و کوچک میشود */}
|
35 |
-
<div
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
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 |
-
{
|
|
|
|
|
|
|
|
|
|
|
44 |
</div>
|
45 |
</div>
|
46 |
</div>
|
|
|
8 |
isMini: boolean;
|
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 |
+
// --- منطق انیمیشن صدای ربات ---
|
19 |
+
// مقیاس موج بر اساس حجم صدای ربات
|
20 |
const aiVoiceScale = 1 + (speakingVolume * 1.5);
|
|
|
21 |
const animatedCircleStyle: React.CSSProperties = {
|
22 |
transition: 'transform 0.15s ease-out',
|
23 |
transform: `scale(${aiVoiceScale})`
|
|
|
25 |
|
26 |
return (
|
27 |
<div className={cn("w-fit flex items-center justify-center")}>
|
28 |
+
{/* Pre-loading Tailwind colors (برای اطمینان از وجود کلاسهای رنگ) */}
|
29 |
<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"}>
|
30 |
color pre-loader
|
31 |
</div>
|
32 |
+
|
33 |
<div className={cn("relative", isMini ? "w-[80px] h-[80px]" : "w-[200px] h-[200px]")}>
|
34 |
+
{/* انیمیشن پینگ اصلی که همیشه فعال است */}
|
35 |
+
<div className={cn(
|
36 |
+
"absolute rounded-full opacity-50 animate-ping",
|
37 |
+
isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700",
|
38 |
+
isMini ? "inset-[10px]" : "inset-[40px]"
|
39 |
+
)} />
|
40 |
|
41 |
{/* این دایره با صدای ربات بزرگ و کوچک میشود */}
|
42 |
+
<div
|
43 |
+
className={cn(
|
44 |
+
"absolute rounded-full opacity-50",
|
45 |
+
isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700",
|
46 |
+
isMini ? "inset-[10px]" : "inset-[40px]"
|
47 |
+
)}
|
48 |
+
style={animatedCircleStyle}
|
49 |
+
/>
|
50 |
|
51 |
+
{/* بقیه دایرههای ثابت پسزمینه */}
|
52 |
<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")} />
|
53 |
<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]")} />
|
54 |
<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]")} />
|
55 |
|
56 |
<div className={cn("z-10 absolute flex items-center justify-center inset-0")}>
|
57 |
+
{/* --- 👇 تغییر اصلی اینجاست 👇 --- */}
|
58 |
+
{/* isUserSpeaking به آیکون پاس داده میشود تا فقط آدمک تکان بخورد */}
|
59 |
+
{humanAiIcon({
|
60 |
+
size: isMini ? 24 : 45,
|
61 |
+
isUserSpeaking: isUserSpeaking
|
62 |
+
})}
|
63 |
</div>
|
64 |
</div>
|
65 |
</div>
|