import { withStyles } from '@material-ui/styles'; import React from 'react'; import Icon from '../../base/icons/components/Icon'; type Props = { /** * The css classes generated from theme. */ classes: any, /** * Attribute used in automated testing. */ dataTestId: string, /** * The button's icon. */ icon: Function, /** * The button's label. */ label: string, /** * Function to be called when button is clicked. */ onButtonClick: (e?: React.MouseEvent) => void, /** * Function to be called on key pressed. */ onKeyPressed: (e?: React.KeyboardEvent) => void }; /** * Creates the styles for the component. * * @param {Object} theme - The current UI theme. * * @returns {Object} */ const styles = (theme: any) => { return { prejoinPreviewDropdownBtn: { alignItems: 'center', color: '#1C2025', cursor: 'pointer', display: 'flex', height: 40, fontSize: 15, lineHeight: '24px', padding: '0 16px', backgroundColor: theme.palette.field02, '&:hover': { backgroundColor: theme.palette.field02Hover } }, prejoinPreviewDropdownIcon: { display: 'inline-block', marginRight: 16, '& > svg': { fill: '#1C2025' } } }; }; /** * Buttons used for pre meeting actions. * * @returns {ReactElement} */ const DropdownButton = ({ classes, dataTestId, icon, onButtonClick, onKeyPressed, label }: Props) => (