mirror of
https://github.com/revoltchat/revite.git
synced 2025-01-16 01:11:32 -05:00
60 lines
1.4 KiB
TypeScript
60 lines
1.4 KiB
TypeScript
import Tippy, { TippyProps } from "@tippyjs/react";
|
|
import styled from "styled-components/macro";
|
|
|
|
import { Text } from "preact-i18n";
|
|
|
|
import { Children } from "../../types/Preact";
|
|
|
|
type Props = Omit<TippyProps, "children"> & {
|
|
children: Children;
|
|
content: Children;
|
|
};
|
|
|
|
export default function Tooltip(props: Props) {
|
|
const { children, content, ...tippyProps } = props;
|
|
|
|
return (
|
|
<Tippy content={content} animation="shift-away" {...tippyProps}>
|
|
{/*
|
|
// @ts-expect-error Type mis-match. */}
|
|
<div style={`display: flex;`}>{children}</div>
|
|
</Tippy>
|
|
);
|
|
}
|
|
|
|
const PermissionTooltipBase = styled.div`
|
|
display: flex;
|
|
align-items: center;
|
|
flex-direction: column;
|
|
|
|
span {
|
|
font-size: 11px;
|
|
font-weight: 700;
|
|
text-transform: uppercase;
|
|
color: var(--secondary-foreground);
|
|
}
|
|
|
|
code {
|
|
font-family: var(--monospace-font);
|
|
}
|
|
`;
|
|
|
|
export function PermissionTooltip(
|
|
props: Omit<Props, "content"> & { permission: string },
|
|
) {
|
|
const { permission, ...tooltipProps } = props;
|
|
|
|
return (
|
|
<Tooltip
|
|
content={
|
|
<PermissionTooltipBase>
|
|
<span>
|
|
<Text id="app.permissions.required" />
|
|
</span>
|
|
<code>{permission}</code>
|
|
</PermissionTooltipBase>
|
|
}
|
|
{...tooltipProps}
|
|
/>
|
|
);
|
|
}
|