TeaWeb/shared/js/ui/react-elements/Avatar.tsx

62 lines
2.3 KiB
TypeScript
Raw Normal View History

import * as React from "react";
import {ClientAvatar} from "tc-shared/file/Avatars";
import {useState} from "react";
2020-07-17 23:56:20 +02:00
import * as image_preview from "tc-shared/ui/frames/image_preview";
2020-07-17 23:56:20 +02:00
const ImageStyle = { height: "100%", width: "100%", cursor: "pointer" };
export const AvatarRenderer = React.memo((props: { avatar: ClientAvatar, className?: string, alt?: string }) => {
let [ revision, setRevision ] = useState(0);
let image;
switch (props.avatar.state) {
case "unset":
2020-07-17 23:56:20 +02:00
image = <img
key={"default"}
title={tr("default avatar")}
alt={typeof props.alt === "string" ? props.alt : tr("default avatar")}
src={props.avatar.avatarUrl}
style={ImageStyle}
onClick={event => {
if(event.isDefaultPrevented())
return;
event.preventDefault();
image_preview.preview_image(props.avatar.avatarUrl, undefined);
}}
/>;
break;
case "loaded":
2020-07-17 23:56:20 +02:00
image = <img
key={"user-" + props.avatar.currentAvatarHash}
alt={typeof props.alt === "string" ? props.alt : tr("user avatar")}
title={tr("user avatar")}
src={props.avatar.avatarUrl}
style={ImageStyle}
onClick={event => {
if(event.isDefaultPrevented())
return;
event.preventDefault();
image_preview.preview_image(props.avatar.avatarUrl, undefined);
}}
/>;
break;
case "errored":
2020-07-17 23:56:20 +02:00
image = <img key={"error"} alt={typeof props.alt === "string" ? props.alt : tr("error")} title={tr("avatar failed to load:\n") + props.avatar.loadError} src={props.avatar.avatarUrl} style={ImageStyle} />;
break;
case "loading":
2020-07-17 23:56:20 +02:00
image = <img key={"loading"} alt={typeof props.alt === "string" ? props.alt : tr("loading")} title={tr("loading avatar")} src={"img/loading_image.svg"} style={ImageStyle} />;
break;
}
props.avatar.events.reactUse("avatar_state_changed", () => setRevision(revision + 1));
return (
<div className={props.className} style={{ overflow: "hidden" }}>
{image}
</div>
)
2020-07-17 23:56:20 +02:00
});