import React, { forwardRef } from "react"; import classNames from "classnames"; import styles from "./Button.module.css"; import { ReactComponent as MicIcon } from "../icons/Mic.svg"; import { ReactComponent as MuteMicIcon } from "../icons/MuteMic.svg"; import { ReactComponent as VideoIcon } from "../icons/Video.svg"; import { ReactComponent as DisableVideoIcon } from "../icons/DisableVideo.svg"; import { ReactComponent as HangupIcon } from "../icons/Hangup.svg"; import { ReactComponent as ScreenshareIcon } from "../icons/Screenshare.svg"; import { useButton } from "@react-aria/button"; import { useObjectRef } from "@react-aria/utils"; export const variantToClassName = { default: [styles.button], toolbar: [styles.toolbarButton], icon: [styles.iconButton], secondary: [styles.secondary], copy: [styles.copyButton], iconCopy: [styles.iconCopyButton], }; export const sizeToClassName = { lg: [styles.lg], }; export const Button = forwardRef( ( { variant = "default", size, on, off, iconStyle, className, children, ...rest }, ref ) => { const buttonRef = useObjectRef(ref); const { buttonProps } = useButton(rest, buttonRef); // TODO: react-aria's useButton hook prevents form submission via keyboard // Remove the hack below after this is merged https://github.com/adobe/react-spectrum/pull/904 let filteredButtonProps = buttonProps; if (rest.type === "submit" && !rest.onPress) { const { onKeyDown, onKeyUp, ...filtered } = buttonProps; filteredButtonProps = filtered; } return ( ); } ); export function ButtonTooltip({ className, children }) { return (
{children}
); } export function MicButton({ muted, ...rest }) { return ( ); } export function VideoButton({ muted, ...rest }) { return ( ); } export function ScreenshareButton({ enabled, className, ...rest }) { return ( ); } export function HangupButton({ className, ...rest }) { return ( ); }