Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sandiiarov/use-hotkeys
➷ Hotkeys React Hook
https://github.com/sandiiarov/use-hotkeys
Last synced: 4 months ago
JSON representation
➷ Hotkeys React Hook
- Host: GitHub
- URL: https://github.com/sandiiarov/use-hotkeys
- Owner: sandiiarov
- Archived: true
- Created: 2019-02-22T05:33:43.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2020-12-11T02:13:53.000Z (about 4 years ago)
- Last Synced: 2024-07-31T07:15:47.262Z (7 months ago)
- Language: TypeScript
- Homepage:
- Size: 419 KB
- Stars: 18
- Watchers: 1
- Forks: 2
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- fucking-awesome-react-hooks - `use-hotkeys`
- awesome-react-hooks-cn - `use-hotkeys`
- awesome-react-hooks - `use-hotkeys`
- awesome-react-hooks - `use-hotkeys`
README
# Use Hotkeys
data:image/s3,"s3://crabby-images/735ca/735ca76de4d9f7d73fc71f006c4e70e374c245ec" alt="npm"
data:image/s3,"s3://crabby-images/b6487/b64872f1b9f4e07c9316e99caf1acc1bebc5281b" alt="npm"
data:image/s3,"s3://crabby-images/75206/75206a98a145f9db0adf051e56e8d9eb5632a66c" alt="NpmLicense"React wrapper around [Hotkeys.js](https://github.com/jaywcjlove/hotkeys).
```shell
╭┈┈╮ ╭┈┈╮ ╭┈┈╮
┆ ├┈┈..┈┈┈┈┈.┆ └┈╮┆ ├┈┈..┈┈┈┈┈..┈┈.┈┈..┈┈┈┈┈.
┆ ┆┆ □ ┆┆ ┈┤┆ < ┆ -__┘┆ ┆ ┆┆__ ┈┈┤
╰┈┈┴┈┈╯╰┈┈┈┈┈╯╰┈┈┈┈╯╰┈┈┴┈┈╯╰┈┈┈┈┈╯╰┈┈┈ ┆╰┈┈┈┈┈╯
╰┈┈┈┈┈╯
```**Use Hotkeys** - React hook that listen to keyboard events, defining and dispatching keyboard shortcuts.
Read about [Hooks](https://reactjs.org/docs/hooks-intro.html) feature.
## Installation
> Note: React 16.8+ is required for Hooks.
### With npm
```sh
npm i use-hotkeys
```### Or with yarn
```sh
yarn add use-hotkeys
```## Usage
[data:image/s3,"s3://crabby-images/30d34/30d34521f10c786f5cd9a38072d0f1491464ec1f" alt="Edit 1llx4n8q4"](https://codesandbox.io/s/1llx4n8q4?fontsize=14)
```jsx
import useHotkeys from 'use-hotkeys';
``````jsx
const Counter = () => {
const [count, setCount] = React.useState(0);useHotkeys(
(key, event, handle) => {
switch (key) {
case 'up':
return setCount(count + 1);
case 'down':
return setCount(count - 1);
default:
return setCount(count);
}
},
['up', 'down'],
[count]
);return
{count};
};
```