Skip to content

Commit

Permalink
fix: detect key presses via key code instead of localized key
Browse files Browse the repository at this point in the history
  • Loading branch information
DASPRiD committed Dec 27, 2023
1 parent b5cc302 commit 01a4845
Showing 1 changed file with 7 additions and 5 deletions.
12 changes: 7 additions & 5 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ export type UnregisterUidCapture = () => void;

type Handler = [callback : UidCaptureCallback, errorHandler ?: UidCaptureErrorHandler];

const allowedKeys = /^[a-fA-F0-9]$/;
const keyCodeRegex = /^(?:Key|Digit)([A-F0-9])$/;
const registeredHandlers = new Set<Handler>();
let keydownHandler : (event : KeyboardEvent) => void;

Expand Down Expand Up @@ -37,7 +37,7 @@ export const registerUidCapture = (
let timeout : number;

keydownHandler = (event : KeyboardEvent) => {
if (event.altKey && event.ctrlKey && event.shiftKey && event.key === 'U') {
if (event.altKey && event.ctrlKey && event.shiftKey && event.code === 'KeyU') {
capturing = true;
uid = '';
event.preventDefault();
Expand All @@ -56,7 +56,7 @@ export const registerUidCapture = (
event.preventDefault();
event.stopPropagation();

if (event.altKey && event.ctrlKey && event.shiftKey && event.key === 'D') {
if (event.altKey && event.ctrlKey && event.shiftKey && event.code === 'KeyD') {
capturing = false;
window.clearTimeout(timeout);

Expand All @@ -76,11 +76,13 @@ export const registerUidCapture = (
return;
}

if (!allowedKeys.test(event.key)) {
const matchResult = keyCodeRegex.exec(event.code);

if (!matchResult) {
return;
}

uid += event.key;
uid += matchResult[1];
};

window.addEventListener('keydown', keydownHandler, {capture: true});
Expand Down

0 comments on commit 01a4845

Please sign in to comment.