mirror of
https://github.com/stackblitz/bolt.new
synced 2025-06-26 18:17:50 +00:00
feat(Avatar): 更新Avatar组件以使用环境变量
This commit is contained in:
parent
8ae3280bbd
commit
3955a13050
@ -1,4 +1,5 @@
|
|||||||
import { useState } from 'react';
|
import { useState } from 'react';
|
||||||
|
import { env } from '~/config/env.client';
|
||||||
|
|
||||||
interface AvatarProps {
|
interface AvatarProps {
|
||||||
src: string;
|
src: string;
|
||||||
@ -7,13 +8,13 @@ interface AvatarProps {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function Avatar({ src, alt, className = '' }: AvatarProps) {
|
export function Avatar({ src, alt, className = '' }: AvatarProps) {
|
||||||
const [imgSrc, setImgSrc] = useState(src.startsWith('http') ? src : `${window.ENV.OSS_HOST}${src}`);
|
const [imgSrc, setImgSrc] = useState(src.startsWith('http') ? src : `${env.OSS_HOST}${src}`);
|
||||||
const [error, setError] = useState(false);
|
const [error, setError] = useState(false);
|
||||||
|
|
||||||
const handleError = () => {
|
const handleError = () => {
|
||||||
setError(true);
|
setError(true);
|
||||||
// 设置一个默认的头像 URL
|
// 设置一个默认的头像 URL
|
||||||
setImgSrc(`${window.ENV.OSS_HOST}/avatars/default-avatar.png`);
|
setImgSrc(`${env.OSS_HOST}/avatars/default-avatar.png`);
|
||||||
};
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|||||||
13
app/config/env.client.ts
Normal file
13
app/config/env.client.ts
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
declare global {
|
||||||
|
interface Window {
|
||||||
|
ENV: {
|
||||||
|
OSS_HOST: string;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const env = {
|
||||||
|
get OSS_HOST() {
|
||||||
|
return window.ENV?.OSS_HOST ?? '';
|
||||||
|
},
|
||||||
|
};
|
||||||
Loading…
Reference in New Issue
Block a user