import { ActionIcon, Button, type ButtonVariant, Tooltip, useMantineTheme } from "@mantine/core" import { type ActionIconVariant } from "@mantine/core/lib/components/ActionIcon/ActionIcon" import { Constants } from "app/constants" import { useActionButton } from "hooks/useActionButton" import { forwardRef, type MouseEventHandler, type ReactNode } from "react" interface ActionButtonProps { className?: string icon?: ReactNode label: ReactNode onClick?: MouseEventHandler variant?: ActionIconVariant & ButtonVariant hideLabelOnDesktop?: boolean showLabelOnMobile?: boolean } /** * Switches between Button with label (desktop) and ActionIcon (mobile) */ export const ActionButton = forwardRef((props: ActionButtonProps, ref) => { const { mobile } = useActionButton() const theme = useMantineTheme() const variant = props.variant ?? "subtle" const iconOnly = (mobile && !props.showLabelOnMobile) || (!mobile && props.hideLabelOnDesktop) return iconOnly ? ( {props.icon} ) : ( ) }) ActionButton.displayName = "HeaderButton"