Files
zellyy-finance/src/components/AvatarImageView.tsx

88 lines
4.8 KiB
TypeScript

import React, { useEffect, useState } from 'react';
import { Capacitor } from '@capacitor/core';
import { Avatar, AvatarFallback } from '@/components/ui/avatar';
import { Skeleton } from '@/components/ui/skeleton';
interface AvatarImageViewProps {
className?: string;
fallback?: string;
}
const AvatarImageView: React.FC<AvatarImageViewProps> = ({
className = "h-12 w-12",
fallback = "ZY"
}) => {
const [loaded, setLoaded] = useState(false);
const [error, setError] = useState(false);
const [imageSrc, setImageSrc] = useState<string>('/zellyy.png');
useEffect(() => {
const loadImage = async () => {
try {
// 플랫폼 체크
if (Capacitor.isNativePlatform()) {
const platform = Capacitor.getPlatform();
if (platform === 'android') {
// Android에서는 res/mipmap 리소스 사용
setImageSrc('file:///android_asset/public/zellyy.png');
// 다른 가능한 경로들
const possiblePaths = [
'file:///android_asset/public/zellyy.png',
'file:///android_res/mipmap/zellyy.png',
'@mipmap/zellyy',
'mipmap/zellyy',
'res/mipmap/zellyy.png',
'/zellyy.png',
'./zellyy.png',
'android.resource://com.lovable.zellyfinance/mipmap/zellyy',
];
// 하드코딩된 Base64 이미지
const fallbackBase64 = '';
// 마지막 수단으로 Base64 사용
setImageSrc(fallbackBase64);
} else if (platform === 'ios') {
// iOS 경로 처리
setImageSrc('/zellyy.png');
}
} else {
// 웹에서는 일반 경로 사용
setImageSrc('/zellyy.png');
}
setLoaded(true);
} catch (err) {
console.error('이미지 로드 오류:', err);
setError(true);
}
};
loadImage();
}, []);
return (
<Avatar className={className}>
{!loaded ? (
<div className="h-full w-full flex items-center justify-center">
<Skeleton className="h-full w-full rounded-full" />
</div>
) : (
<>
<img
src={imageSrc}
alt="Zellyy"
className="h-full w-full object-cover"
onError={() => setError(true)}
/>
{error && <AvatarFallback delayMs={100}>{fallback}</AvatarFallback>}
</>
)}
</Avatar>
);
};
export default AvatarImageView;