mirror of
https://github.com/cinnyapp/cinny.git
synced 2025-11-05 06:50:28 +03:00
Some checks failed
Deploy to Netlify (dev) / Deploy to Netlify (push) Has been cancelled
* WIP - new profile view * render common rooms in user profile * add presence component * WIP - room user profile * temp hide profile button * show mutual rooms in spaces, rooms and direct messages categories * add message button * add option to change user powers in profile * improve ban info and option to unban * add share user button in user profile * add option to block user in user profile * improve blocked user alert body * add moderation tool in user profile * open profile view on left side in member drawer * open new user profile in all places
80 lines
2 KiB
TypeScript
80 lines
2 KiB
TypeScript
import {
|
|
as,
|
|
Badge,
|
|
Box,
|
|
color,
|
|
ContainerColor,
|
|
MainColor,
|
|
Text,
|
|
Tooltip,
|
|
TooltipProvider,
|
|
toRem,
|
|
} from 'folds';
|
|
import React, { ReactNode, useId } from 'react';
|
|
import * as css from './styles.css';
|
|
import { Presence, usePresenceLabel } from '../../hooks/useUserPresence';
|
|
|
|
const PresenceToColor: Record<Presence, MainColor> = {
|
|
[Presence.Online]: 'Success',
|
|
[Presence.Unavailable]: 'Warning',
|
|
[Presence.Offline]: 'Secondary',
|
|
};
|
|
|
|
type PresenceBadgeProps = {
|
|
presence: Presence;
|
|
status?: string;
|
|
size?: '200' | '300' | '400' | '500';
|
|
};
|
|
export function PresenceBadge({ presence, status, size }: PresenceBadgeProps) {
|
|
const label = usePresenceLabel();
|
|
const badgeLabelId = useId();
|
|
|
|
return (
|
|
<TooltipProvider
|
|
position="Right"
|
|
align="Center"
|
|
offset={4}
|
|
delay={200}
|
|
tooltip={
|
|
<Tooltip id={badgeLabelId}>
|
|
<Box style={{ maxWidth: toRem(250) }} alignItems="Baseline" gap="100">
|
|
<Text size="L400">{label[presence]}</Text>
|
|
{status && <Text size="T200">•</Text>}
|
|
{status && <Text size="T200">{status}</Text>}
|
|
</Box>
|
|
</Tooltip>
|
|
}
|
|
>
|
|
{(triggerRef) => (
|
|
<Badge
|
|
aria-labelledby={badgeLabelId}
|
|
ref={triggerRef}
|
|
size={size}
|
|
variant={PresenceToColor[presence]}
|
|
fill={presence === Presence.Offline ? 'Soft' : 'Solid'}
|
|
radii="Pill"
|
|
/>
|
|
)}
|
|
</TooltipProvider>
|
|
);
|
|
}
|
|
|
|
type AvatarPresenceProps = {
|
|
badge: ReactNode;
|
|
variant?: ContainerColor;
|
|
};
|
|
export const AvatarPresence = as<'div', AvatarPresenceProps>(
|
|
({ as: AsAvatarPresence, badge, variant = 'Surface', children, ...props }, ref) => (
|
|
<Box as={AsAvatarPresence} className={css.AvatarPresence} {...props} ref={ref}>
|
|
{badge && (
|
|
<div
|
|
className={css.AvatarPresenceBadge}
|
|
style={{ backgroundColor: color[variant].Container }}
|
|
>
|
|
{badge}
|
|
</div>
|
|
)}
|
|
{children}
|
|
</Box>
|
|
)
|
|
);
|