Ezmary commited on
Commit
49589a4
·
verified ·
1 Parent(s): a56b75a

Update src/components/logo/Logo.tsx

Browse files
Files changed (1) hide show
  1. 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("absolute rounded-full opacity-50 animate-ping", isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700", isMini ? "inset-[10px]" : "inset-[40px]")} />
 
 
 
 
33
 
34
  {/* این دایره با صدای ربات بزرگ و کوچک می‌شود */}
35
- <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} />
 
 
 
 
 
 
 
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({ size: isMini ? 24 : 45, isUserSpeaking: isUserSpeaking })}
 
 
 
 
 
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>