react-use-hotkeys
TypeScript icon, indicating that this package has built-in type declarations

1.1.2 • Public • Published

react-use-hotkeys

React hook for creating simple keyboard shortcuts.

Coverage Status Build Status npm bundle size (scoped) npm (scoped) GitHub

Installation

npm install @reecelucas/react-use-hotkeys

This package has a single dependency, a tiny shim called shim-keyboard-event-key that normalises the non-standard KeyBoardEvent.key values implemented in Edge and IE.

Example Usage

All hotkey combinations must use valid KeyBoardEvent "key" values. A full list can be found on MDN and Wes Bos has created a great interactive lookup.

// Single keys
useHotkeys('Escape', () => {
  console.log('some action');
});
 
useHotkeys('F7', () => {
  console.log('some action');
});
 
// Modifier combinations
useHotkeys('Meta+Shift+z', () => {
  console.log('some action');
});
 
// Key sequences
useHotkeys('w s d', () => {
  console.log('some action');
});
 
useHotkeys('w " " d', () => {
  // space key in sequence (`w ' ' d` also works)
  console.log('some action');
});

The following patterns are not supported (yet):

// Modifier keys in sequences
useHotkeys('Control i d', () => {
  console.log("I won't run!");
});
 
// Modifier combinations in sequences
useHotkeys('Control+z i d', () => {
  console.log("I won't run!");
});
 
// Multiple combinations mapped to the same callback
useHotkeys(['Control+z', 'Meta+z'], () => {
  console.log("I won't run!");
});

If you find a use case where the API is too restrictive you can use the escape hatch to perform whatever custom logic you need:

useHotkeys('*', event => {
  console.log("I will run on every keydown");
 
  if (customKeyLogic(event)) {
    console.log("some action");
  }
});

Call Signature

useHotkeys(hotkeysstring, callback: (event: KeyboardEvent) => void);

Tests

Tests use Jest and react-testing-library.

git clone git@github.com:reecelucas/react-use-hotkeys.git
cd react-use-hotkeys
yarn
yarn test

LICENSE

MIT

Package Sidebar

Install

npm i react-use-hotkeys

Weekly Downloads

3

Version

1.1.2

License

MIT

Unpacked Size

24.7 kB

Total Files

51

Last publish

Collaborators

  • jordancooperman