Spaces:
Running
Running
File size: 3,312 Bytes
275fd75 f8d0efc 9dfab18 275fd75 f8d0efc 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 275fd75 9dfab18 f8d0efc 275fd75 9dfab18 275fd75 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 |
// src/components/logo/Logo.tsx
import React from 'react';
import cn from "classnames";
import { humanAiIcon } from '../icons';
import './Logo.scss'; // <-- فایل استایل جدید را ایمپورت کنید
type LogoProps = {
isMini: boolean;
isAi: boolean;
isActive: boolean;
speakingVolume?: number; // ولوم صدای AI برای انیمیشن موج
isUserSpeaking?: boolean; // برای فعال کردن انیمیشن صحبت کاربر
}
export default function Logo({isAi, isActive, isMini, speakingVolume = 0, isUserSpeaking = false}: LogoProps) {
if (!isActive) return null;
// محاسبه مقیاس موج بر اساس حجم صدای AI
// ضریب 1.5 برای محسوستر شدن انیمیشن است
const aiVoiceScale = 1 + (speakingVolume * 1.5);
return (
<div className={cn("w-fit flex items-center justify-center")}>
{/* loads colors for tailwind */}
<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"}>
color pre-loader
</div>
<div className={cn("relative", isMini ? "w-[80px] h-[80px]" : "w-[200px] h-[200px]")}>
<>
{/* این div موج اصلی انیمیشن صحبت کردن AI است */}
<div
className={cn(
"absolute rounded-full opacity-50",
"ai-speaking-ripple", // کلاس برای کنترل انیمیشن
isAi ? "bg-green-200 dark:bg-green-700" : "bg-blue-200 dark:bg-blue-700",
isMini ? "inset-[10px]" : "inset-[40px]",
)}
// متغیر CSS را برای کنترل مقیاس موج تنظیم میکنیم
style={{ '--ai-voice-scale': aiVoiceScale } as React.CSSProperties}
/>
{/* دایرههای ثابت پسزمینه */}
<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",
)}
/>
<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]",
)}
/>
<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]",
)}
/>
{/* آیکون اصلی */}
<div className={cn(
"z-10 absolute flex items-center justify-center text-white",
"inset-0"
)}>
{humanAiIcon({
size: isMini ? 24 : 45,
// اگر کاربر در حال صحبت است، کلاس مربوطه را اضافه کن
className: cn({ 'user-speaking': isUserSpeaking })
})}
</div>
</>
</div>
</div>
);
} |