2025-01-05 05:56:57 +01:00
|
|
|
// Copyright 2025, Command Line Inc.
|
2024-10-27 21:22:06 +01:00
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
import clsx from "clsx";
|
|
|
|
import { memo } from "react";
|
|
|
|
import { Avatar } from "../../element/avatar";
|
2024-11-22 01:05:04 +01:00
|
|
|
import "./userlist.scss";
|
2024-10-27 21:22:06 +01:00
|
|
|
|
|
|
|
export interface UserStatus {
|
|
|
|
label: string;
|
|
|
|
status: "online" | "busy" | "away" | "offline";
|
|
|
|
onClick: () => void;
|
|
|
|
avatarUrl?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface UserListProps {
|
|
|
|
users: UserStatus[];
|
|
|
|
className?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
const UserList = memo(({ users, className }: UserListProps) => {
|
|
|
|
return (
|
|
|
|
<div className={clsx("user-list", className)}>
|
|
|
|
{users.map(({ label, status, onClick, avatarUrl }, index) => (
|
|
|
|
<div key={index} className={clsx("user-status-item", status)} onClick={onClick}>
|
|
|
|
<div className="user-status-icon">
|
|
|
|
<Avatar name={label} status={status} className="size-sm" imageUrl={avatarUrl} />
|
|
|
|
</div>
|
|
|
|
<div className="user-status-text">{label}</div>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
UserList.displayName = "UserList";
|
|
|
|
|
|
|
|
export { UserList };
|