Files
cinny/src/app/utils/keyboard.ts
T

26 lines
600 B
TypeScript
Raw Normal View History

2023-06-12 21:15:23 +10:00
import isHotkey from 'is-hotkey';
import { KeyboardEventHandler } from 'react';
export interface KeyboardEventLike {
key: string;
which: number;
altKey: boolean;
ctrlKey: boolean;
metaKey: boolean;
shiftKey: boolean;
preventDefault(): void;
}
export const onTabPress = (evt: KeyboardEventLike, callback: () => void) => {
if (isHotkey('tab', evt)) {
evt.preventDefault();
callback();
}
};
export const preventScrollWithArrowKey: KeyboardEventHandler = (evt) => {
if (isHotkey(['arrowup', 'arrowright', 'arrowdown', 'arrowleft'], evt)) {
evt.preventDefault();
}
};