import * as React from 'react'; import { ToolbarButtonInfo } from '@joplin/lib/services/commands/ToolbarButtonUtils'; import { StyledRoot, StyledIconSpan, StyledIconI } from './styles'; interface Props { readonly themeId: number; readonly toolbarButtonInfo?: ToolbarButtonInfo; readonly title?: string; readonly tooltip?: string; readonly iconName?: string; readonly disabled?: boolean; readonly backgroundHover?: boolean; } function isFontAwesomeIcon(iconName: string) { const s = iconName.split(' '); return s.length === 2 && ['fa', 'fas'].includes(s[0]); } // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied function getProp(props: Props, name: string, defaultValue: any = null) { // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied if (props.toolbarButtonInfo && (name in props.toolbarButtonInfo)) return (props.toolbarButtonInfo as any)[name]; if (!(name in props)) return defaultValue; // eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied return (props as any)[name]; } export default function ToolbarButton(props: Props) { const title = getProp(props, 'title', ''); const tooltip = getProp(props, 'tooltip', title); let icon = null; const iconName = getProp(props, 'iconName'); if (iconName) { const IconClass = isFontAwesomeIcon(iconName) ? StyledIconI : StyledIconSpan; icon = ; } // Keep this for legacy compatibility but for consistency we should use "disabled" prop let isEnabled = getProp(props, 'enabled', null); if (isEnabled === null) isEnabled = true; if (props.disabled) isEnabled = false; const classes = ['button']; if (!isEnabled) classes.push('disabled'); const onClick = getProp(props, 'onClick'); const style: React.CSSProperties = { whiteSpace: 'nowrap', overflow: 'hidden', textOverflow: 'ellipsis' }; return ( { if (isEnabled && onClick) onClick(); }} > {icon} {title} ); }