Skip to content
Snippets Groups Projects
UserHeader.tsx 2.13 KiB
Newer Older
insert's avatar
insert committed
import Tooltip from "../Tooltip";
insert's avatar
insert committed
import { User } from "revolt.js";
import UserIcon from "./UserIcon";
insert's avatar
insert committed
import { Text } from "preact-i18n";
insert's avatar
insert committed
import Header from "../../ui/Header";
insert's avatar
insert committed
import UserStatus from './UserStatus';
import styled from "styled-components";
import { Localizer } from 'preact-i18n';
insert's avatar
insert committed
import { Link } from "react-router-dom";
insert's avatar
insert committed
import IconButton from "../../ui/IconButton";
import { Cog } from "@styled-icons/boxicons-solid";
insert's avatar
insert committed
import { openContextMenu } from "preact-context-menu";
insert's avatar
insert committed
import { isTouchscreenDevice } from "../../../lib/isTouchscreenDevice";
import { useIntermediate } from "../../../context/intermediate/Intermediate";
insert's avatar
insert committed

const HeaderBase = styled.div`
    gap: 0;
    flex-grow: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    
    * {
        min-width: 0;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
    }

    .username {
        cursor: pointer;
        font-size: 16px;
        font-weight: 600;
    }

    .status {
        cursor: pointer;
        font-size: 12px;
        margin-top: -2px;
    }
`;

interface Props {
    user: User
}

export default function UserHeader({ user }: Props) {
insert's avatar
insert committed
    const { writeClipboard } = useIntermediate();
insert's avatar
insert committed

    return (
insert's avatar
insert committed
        <Header borders placement="secondary">
insert's avatar
insert committed
            <HeaderBase>
                <Localizer>
insert's avatar
insert committed
                    <Tooltip content={<Text id="app.special.copy_username" />}>
insert's avatar
insert committed
                        <span className="username"
                            onClick={() => writeClipboard(user.username)}>
                            @{user.username}
                        </span>
insert's avatar
insert committed
                    </Tooltip>
insert's avatar
insert committed
                </Localizer>
                <span className="status"
                    onClick={() => openContextMenu("Status")}>
insert's avatar
insert committed
                    <UserStatus user={user} />
                </span>
            </HeaderBase>
            { !isTouchscreenDevice && <div className="actions">
insert's avatar
insert committed
                <Link to="/settings">
                    <IconButton>
                        <Cog size={24} />
insert's avatar
insert committed
                    </IconButton>
                </Link>
insert's avatar
insert committed
            </div> }
        </Header>
    )
}