Skip to content
Snippets Groups Projects
UserHeader.tsx 2.22 KiB
Newer Older
insert's avatar
insert committed
import { Cog } from "@styled-icons/boxicons-solid";
import { observer } from "mobx-react-lite";
insert's avatar
insert committed
import { Link } from "react-router-dom";
insert's avatar
insert committed
import { User } from "revolt.js/dist/maps/Users";
insert's avatar
insert committed
import styled from "styled-components";
insert's avatar
insert committed

insert's avatar
insert committed
import { openContextMenu } from "preact-context-menu";
insert's avatar
insert committed
import { Text, Localizer } from "preact-i18n";
insert's avatar
insert committed

insert's avatar
insert committed
import { isTouchscreenDevice } from "../../../lib/isTouchscreenDevice";
insert's avatar
insert committed
import { useIntermediate } from "../../../context/intermediate/Intermediate";
insert's avatar
insert committed

insert's avatar
insert committed
import Header from "../../ui/Header";
import IconButton from "../../ui/IconButton";

import Tooltip from "../Tooltip";
import UserStatus from "./UserStatus";

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;
    }
insert's avatar
insert committed

    .username {
        cursor: pointer;
        font-size: 16px;
        font-weight: 600;
    }
insert's avatar
insert committed

    .status {
        cursor: pointer;
        font-size: 12px;
        margin-top: -2px;
    }
insert's avatar
insert committed
`;

interface Props {
    user: User;
insert's avatar
insert committed
}

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

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