excalidraw/packages/excalidraw/components/PenModeButton.tsx
Marcel Mraz 21ffaf4d76
All checks were successful
Tests / test (push) Successful in 4m38s
refactor: auto ordered imports (#9163)
2025-03-12 15:23:31 +01:00

48 lines
1,007 B
TypeScript

import clsx from "clsx";
import "./ToolIcon.scss";
import { PenModeIcon } from "./icons";
import type { ToolButtonSize } from "./ToolButton";
type PenModeIconProps = {
title?: string;
name?: string;
checked: boolean;
onChange?(): void;
zenModeEnabled?: boolean;
isMobile?: boolean;
penDetected: boolean;
};
const DEFAULT_SIZE: ToolButtonSize = "medium";
export const PenModeButton = (props: PenModeIconProps) => {
if (!props.penDetected) {
return null;
}
return (
<label
className={clsx(
"ToolIcon ToolIcon__penMode",
`ToolIcon_size_${DEFAULT_SIZE}`,
{
"is-mobile": props.isMobile,
},
)}
title={`${props.title}`}
>
<input
className="ToolIcon_type_checkbox"
type="checkbox"
name={props.name}
onChange={props.onChange}
checked={props.checked}
aria-label={props.title}
/>
<div className="ToolIcon__icon">{PenModeIcon}</div>
</label>
);
};