From 8bf585b22232d0bc683df8185d5b8c542749503f Mon Sep 17 00:00:00 2001 From: Ethan McElroy Date: Fri, 29 Nov 2024 13:06:49 -0500 Subject: [PATCH] chore: improve shortcut support --- .../keyboard-shortcut-controls.test.tsx | 2 +- src/components/keyboard-shortcut-controls.tsx | 50 +++++++++---------- src/utils.ts | 5 +- 3 files changed, 30 insertions(+), 27 deletions(-) diff --git a/src/components/keyboard-shortcut-controls.test.tsx b/src/components/keyboard-shortcut-controls.test.tsx index 0a9b882..f683029 100644 --- a/src/components/keyboard-shortcut-controls.test.tsx +++ b/src/components/keyboard-shortcut-controls.test.tsx @@ -55,7 +55,7 @@ describe("test keyboard shortcut controls component", () => { expect(input).toHaveAttribute("aria-describedby", "custom-keyboard-shortcut-confirmation"); expect(screen.getByTestId("custom-keyboard-shortcut-confirmation")).toBeInTheDocument(); const confirmationMsg = screen.getByTestId("custom-keyboard-shortcut-confirmation").textContent; - expect(confirmationMsg).toContain(`Keyboard shortcut changed to ${customShortcut}.`); + expect(confirmationMsg).toContain(`Keyboard shortcut changed to ${customShortcut}`); const dismissButton = screen.getByTestId("custom-keyboard-shortcut-confirmation-dismiss"); expect(dismissButton).toHaveTextContent("X"); }); diff --git a/src/components/keyboard-shortcut-controls.tsx b/src/components/keyboard-shortcut-controls.tsx index 9414d6b..ba60c59 100644 --- a/src/components/keyboard-shortcut-controls.tsx +++ b/src/components/keyboard-shortcut-controls.tsx @@ -1,4 +1,4 @@ -import React from "react"; +import React, { FormEvent, useState } from "react"; import "./keyboard-shortcut-controls.scss"; @@ -10,34 +10,34 @@ interface IProps { } export const KeyboardShortcutControls = (props: IProps) => { - const { shortcutEnabled, onToggleShortcut } = props; + const { shortcutEnabled, shortcutKeys, onCustomizeShortcut, onToggleShortcut } = props; const toggleButtonLabel = shortcutEnabled ? "Disable Shortcut" : "Enable Shortcut"; - // const [showError, setShowError] = useState(false); - // const [showConfirmation, setShowConfirmation] = useState(false); + const [showError, setShowError] = useState(false); + const [showConfirmation, setShowConfirmation] = useState(false); const handleToggleShortcut = () => { onToggleShortcut(); }; - // const handleCustomizeShortcut = (event: FormEvent) => { - // event.preventDefault(); - // const form = event.target as HTMLInputElement; - // const shortcut = form.querySelector("input")?.value; - // if (shortcut) { - // onCustomizeShortcut?.(shortcut); - // setShowError(false); - // setShowConfirmation(true); - // } else { - // setShowError(true); - // setShowConfirmation(false); - // } - // }; + const handleCustomizeShortcut = (event: FormEvent) => { + event.preventDefault(); + const form = event.target as HTMLInputElement; + const shortcut = form.querySelector("input")?.value; + if (shortcut) { + onCustomizeShortcut?.(shortcut); + setShowError(false); + setShowConfirmation(true); + } else { + setShowError(true); + setShowConfirmation(false); + } + }; - // const customShortcutInputDescribedBy = showConfirmation - // ? "custom-keyboard-shortcut-confirmation" - // : showError - // ? "custom-keyboard-shortcut-error" - // : undefined; + const customShortcutInputDescribedBy = showConfirmation + ? "custom-keyboard-shortcut-confirmation" + : showError + ? "custom-keyboard-shortcut-error" + : undefined; return (
@@ -45,7 +45,7 @@ export const KeyboardShortcutControls = (props: IProps) => { - {/*
+
{ id="custom-keyboard-shortcut-confirmation" role="alert" > - Keyboard shortcut changed to {shortcutKeys}. + Keyboard shortcut changed to {shortcutKeys}
} - */} + ); }; diff --git a/src/utils.ts b/src/utils.ts index c3cb5ae..6a85821 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -52,11 +52,14 @@ export const charKeyMap: Record = { export const isShortcutPressed = (event: KeyboardEvent, shortcutKeys: string): boolean => { const keystrokeElements = shortcutKeys.split("+"); + const isMac = navigator.platform.toUpperCase().indexOf("MAC") >= 0; return keystrokeElements.every((keystroke) => { if (keystroke in specialKeyMap) { return event[specialKeyMap[keystroke as keyof typeof specialKeyMap] as keyof KeyboardEvent]; + } else if (keystroke in charKeyMap && isMac) { + return event.key === charKeyMap[keystroke]; } else { - const normalizedKey = charKeyMap[keystroke] || keystroke.toLowerCase(); + const normalizedKey = keystroke.toLowerCase(); const isShifted = keystroke !== keystroke.toLowerCase(); return event.key.toLowerCase() === normalizedKey && (!isShifted || event.shiftKey); }