Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devlato/react-shortcut
Convenient React component that detects if the given key combination is pressed, and triggers a callback
https://github.com/devlato/react-shortcut
callback hotkey hotkeys javascript konami konamicode react rodney shortcut shortcuts
Last synced: 4 months ago
JSON representation
Convenient React component that detects if the given key combination is pressed, and triggers a callback
- Host: GitHub
- URL: https://github.com/devlato/react-shortcut
- Owner: devlato
- License: mit
- Created: 2017-03-02T00:58:46.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T22:16:48.000Z (about 2 years ago)
- Last Synced: 2024-10-14T05:28:47.182Z (4 months ago)
- Topics: callback, hotkey, hotkeys, javascript, konami, konamicode, react, rodney, shortcut, shortcuts
- Language: TypeScript
- Homepage:
- Size: 6.98 MB
- Stars: 17
- Watchers: 3
- Forks: 7
- Open Issues: 24
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: CODEOWNERS
- Security: SECURITY.md
Awesome Lists containing this project
README
# react-shortcut
Convenient React component that detects if the given key combination is pressed, and triggers a callback
[data:image/s3,"s3://crabby-images/5ad56/5ad56976fc2e75feb58b056c81dcbddf08299db3" alt="View on npm"](https://npmjs.org/package/react-shortcut)
[data:image/s3,"s3://crabby-images/b0b50/b0b50daa6c65792230358db9ab9c3147671d96a5" alt="Master Build Status"](https://github.com/devlato/react-shortcut/actions?query=workflow%3ARelease)
[data:image/s3,"s3://crabby-images/dedde/deddecdbf6723d6d88621082194a4c374f85fc0f" alt="Release CI Status"](https://github.com/devlato/react-shortcut/actions?query=workflow%3APublish)
[data:image/s3,"s3://crabby-images/93951/93951cf6b13cfb137f3ad593cfe2659bb0b437ae" alt="Maintainability"](https://codeclimate.com/github/devlato/react-shortcut/maintainability)
[data:image/s3,"s3://crabby-images/ac7c8/ac7c8cd7595038b1b6b1047e7e9086d10ad9b4c1" alt="Test Coverage"](https://codeclimate.com/github/devlato/react-shortcut/test_coverage)
[data:image/s3,"s3://crabby-images/5693c/5693cd90b4fc5774ad4eb202d5b19e310d7d11bf" alt="Demo"](https://devlato.github.io/react-shortcut/)
[data:image/s3,"s3://crabby-images/c24c3/c24c379daa4712b80a23d9559228afd9fa58dd47" alt="Bundle size"](https://bundlephobia.com/result?p=react-shortcut)
[data:image/s3,"s3://crabby-images/224d7/224d77d5a4bc1045323460f78d52d4f5e7ca59c8" alt="Downloads"](https://npmjs.org/package/react-shortcut)
[data:image/s3,"s3://crabby-images/1f654/1f654b0df1714e00382a79ed6d68e89e442ebbe3" alt="MIT License"](https://npmjs.org/package/react-shortcut)
[data:image/s3,"s3://crabby-images/65a44/65a44227b6a04feb014625c8d97818d3e9a33a6f" alt="Issues"](https://github.com/devlato/react-shortcut/issues)## Installation
With npm:
```sh
$ npm install --save react-shortcut
```Or with Yarn:
```sh
$ yarn add react-shortcut
```## Using the component
Is very simple and straightforward! There are just a couple of props to pass in.
### Code example
```typescript jsx
import ReactShortcut from 'react-shortcut';// ...
// Somewhere in your component tree
;
```### Props
All the props are required.
| Name | Description | Type |
| --------------- | ------------------------------------------------------------------------------------------------------ | ------------------------------- |
| `keys` | A string containing comma-separated key combinations or/and key sequences, or an array of such strings | A string or an array of strings |
| `onKeysPressed` | A callback to be triggered when the user presses any of the specified key combinations | A function with no arguments |### Key combinations and Key sequences
The component supports both **key combinations** and **key sequences**.
#### Key combinations
A **key combination** is a string of key names separated by a plus sign, that describes what keys the user has to press at the same time, to execute the callback specified using `onKeysPressed` prop.
Examples: `Command+Shift+Left`, `Ctrl+P`.
To react on the keys combination(s) press, use the following format:
```typescript jsx
import ReactShortcut from 'react-shortcut';// Pass in the shortcut keys
// ... or an array of shortcuts
// ... or a string of comma-separated shortcuts
```
#### Key sequences
A **key sequence** is a string of key names separated by a space character, that lists out the keys the user has to press one by one, to trigger the callback specified using `onKeysPressed` prop.
Examples: `Up Up Down Down Left Right Left Right B A Enter`, `k o n a m i`.
To react on the keys sequence(s) press, use the following format:
```typescript jsx
import ReactShortcut from 'react-shortcut';// Pass in the shortcut keys
// ... or an array of shortcuts
// ... or a string of comma-separated shortcuts
```
#### Mixed use
Mixing both modes is possible –just follow the same key combination/key sequence convention:
```typescript jsx
import ReactShortcut from 'react-shortcut';// Array of shortcuts
// ... or a string of comma-separated shortcuts
```
## FAQ
### Does it support TypeScript?
It does. Moreover, it's implemented in TypeScript.
### Do I have to use component only in the root level component?
Nope. The component adds a global keyboard event listener and doesn't prevent events from bubbling or capturing.
### What if my app needs to support multiple shortcuts?
Just use the component as many times as you need, just make sure the shortcuts aren't repeated.
### Do I have to specify the shortcuts in lower case only?
No, the case doesn't matter.
### Any open-source examples of using this library?
There's an official™️ one called [react-easter](https://www.npmjs.com/package/react-easter), for adding easter eggs triggered by the keypress.
## License
The library is shipped "as is" under MIT License.
## Contributing [data:image/s3,"s3://crabby-images/2d0cd/2d0cd49a8347fb659c6059ef63ed9abc203c65ec" alt="contributions welcome"](https://github.com/devlato/react-shortcut/issues)
Feel free to contribute, but don't forget to write tests, mate/matess.