forked from Archives/Athou_commafeed
63 lines
2.2 KiB
TypeScript
63 lines
2.2 KiB
TypeScript
import type { MessageDescriptor } from "@lingui/core"
|
|
import { useLingui } from "@lingui/react"
|
|
import { ActionIcon, Box, Button, type ButtonVariant, Tooltip, useMantineTheme } from "@mantine/core"
|
|
import type { ActionIconVariant } from "@mantine/core/lib/components/ActionIcon/ActionIcon"
|
|
import { forwardRef, type MouseEventHandler, type ReactNode } from "react"
|
|
import { Constants } from "@/app/constants"
|
|
import { useActionButton } from "@/hooks/useActionButton"
|
|
|
|
interface ActionButtonProps {
|
|
icon: ReactNode
|
|
className?: string
|
|
label?: string | MessageDescriptor
|
|
onClick?: MouseEventHandler
|
|
variant?: ActionIconVariant & ButtonVariant
|
|
hideLabelOnDesktop?: boolean
|
|
showLabelOnMobile?: boolean
|
|
}
|
|
|
|
/**
|
|
* Switches between Button with label (desktop) and ActionIcon (mobile)
|
|
*/
|
|
export const ActionButton = forwardRef<HTMLDivElement, ActionButtonProps>((props: ActionButtonProps, ref) => {
|
|
const { mobile } = useActionButton()
|
|
const theme = useMantineTheme()
|
|
const { _ } = useLingui()
|
|
|
|
const label = typeof props.label === "string" ? props.label : props.label && _(props.label)
|
|
const variant = props.variant ?? "subtle"
|
|
const iconOnly = (mobile && !props.showLabelOnMobile) || (!mobile && props.hideLabelOnDesktop)
|
|
|
|
return (
|
|
<Box ref={ref} className="cf-action-button">
|
|
{iconOnly && (
|
|
<Tooltip label={label} openDelay={Constants.tooltip.delay}>
|
|
<ActionIcon
|
|
color={theme.primaryColor}
|
|
variant={variant}
|
|
className={props.className}
|
|
onClick={props.onClick}
|
|
aria-label={label}
|
|
>
|
|
{props.icon}
|
|
</ActionIcon>
|
|
</Tooltip>
|
|
)}
|
|
{!iconOnly && (
|
|
<Button
|
|
variant={variant}
|
|
size="xs"
|
|
className={props.className}
|
|
leftSection={props.icon}
|
|
onClick={props.onClick}
|
|
aria-label={label}
|
|
>
|
|
{label}
|
|
</Button>
|
|
)}
|
|
</Box>
|
|
)
|
|
})
|
|
|
|
ActionButton.displayName = "HeaderButton"
|