2024-10-27 21:22:06 +01:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import { memo } from "react";
|
|
|
|
|
|
|
|
import clsx from "clsx";
|
2024-11-22 01:05:04 +01:00
|
|
|
import "./avatar.scss";
|
2024-10-27 21:22:06 +01:00
|
|
|
|
|
|
|
interface AvatarProps {
|
|
|
|
name: string;
|
|
|
|
status: "online" | "offline" | "busy" | "away";
|
|
|
|
className?: string;
|
|
|
|
imageUrl?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const Avatar = memo(({ name, status = "offline", className, imageUrl }: AvatarProps) => {
|
|
|
|
const getInitials = (name: string) => {
|
|
|
|
const nameParts = name.split(" ");
|
|
|
|
const initials = nameParts.map((part) => part[0]).join("");
|
|
|
|
return initials.toUpperCase();
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={clsx("avatar", status, className)} title="status">
|
|
|
|
{imageUrl ? (
|
|
|
|
<img src={imageUrl} alt={`${name}'s avatar`} className="avatar-image" />
|
|
|
|
) : (
|
|
|
|
<div className="avatar-initials">{getInitials(name)}</div>
|
|
|
|
)}
|
|
|
|
<div className={`status-indicator ${status}`} />
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
Avatar.displayName = "Avatar";
|
|
|
|
|
|
|
|
export { Avatar };
|