Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jaywcjlove/react-hotkeys
React component to listen to keydown and keyup keyboard events, defining and dispatching keyboard shortcuts.
https://github.com/jaywcjlove/react-hotkeys
hotkeys javascript keyboard react-component reactjs shortcut
Last synced: 3 days ago
JSON representation
React component to listen to keydown and keyup keyboard events, defining and dispatching keyboard shortcuts.
- Host: GitHub
- URL: https://github.com/jaywcjlove/react-hotkeys
- Owner: jaywcjlove
- Created: 2017-08-15T15:08:06.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-05T20:51:49.000Z (about 1 month ago)
- Last Synced: 2025-01-09T20:19:30.590Z (10 days ago)
- Topics: hotkeys, javascript, keyboard, react-component, reactjs, shortcut
- Language: TypeScript
- Homepage: https://jaywcjlove.github.io/react-hotkeys/
- Size: 16.6 MB
- Stars: 420
- Watchers: 5
- Forks: 22
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
- awesome - jaywcjlove/react-hotkeys - React component to listen to keydown and keyup keyboard events, defining and dispatching keyboard shortcuts. (TypeScript)
README
react-hotkeys
===[![NPM Downloads](https://img.shields.io/npm/dm/react-hot-keys.svg?style=flat)](https://www.npmjs.com/package/react-hot-keys)
[![CI](https://github.com/jaywcjlove/react-hotkeys/actions/workflows/ci.yml/badge.svg)](https://github.com/jaywcjlove/react-hotkeys/actions/workflows/ci.yml)
[![npm package](https://img.shields.io/npm/v/react-hot-keys.svg)](https://www.npmjs.org/package/react-hot-keys) [![Coveralls](https://jaywcjlove.github.io/react-hotkeys/coverage/badges.svg)](https://jaywcjlove.github.io/react-hotkeys/coverage/lcov-report/)React component to listen to keydown and keyup keyboard events, defining and dispatching keyboard shortcuts. Uses a fork of [hotkeys.js](https://github.com/jaywcjlove/hotkeys) for keydown detection of special characters. You give it a keymap of shortcuts & it bind it to the mousetrap singleton. The, it'll unbind it when the component unmounts.
> [react-hotkeys-hook](https://github.com/JohannesKlauss/react-hotkeys-hook) - React hook for using keyboard shortcuts in components. Make sure that you have at least version 16.8 of react and react-dom installed, or otherwise hooks won't work for you.
## Example
### Install
```sh
npm i -S react-hot-keys
```### Demo
Preview [demo](https://jaywcjlove.github.io/react-hotkeys/).
- [Codepen example](https://codepen.io/jaywcjlove/pen/bJxbwG?editors=0010).
- [CodesandBox Example](https://codesandbox.io/s/hotkeys-116-8rge8)```js
import React from 'react';
import Hotkeys from 'react-hot-keys';export default class HotkeysDemo extends React.Component {
constructor(props) {
super(props);
this.state = {
output: 'Hello, I am a component that listens to keydown and keyup of a',
}
}
onKeyUp(keyName, e, handle) {
console.log("test:onKeyUp", e, handle)
this.setState({
output: `onKeyUp ${keyName}`,
});
}
onKeyDown(keyName, e, handle) {
console.log("test:onKeyDown", keyName, e, handle)
this.setState({
output: `onKeyDown ${keyName}`,
});
}
render() {
return (
{this.state.output}
)
}
}
```
## API### keyName
Supported keys `⇧`, `shift`, `option`, `⌥`, `alt`, `ctrl`, `control`, `command`, `⌘` .
`⌘` Command()
`⌃` Control
`⌥` Option(alt)
`⇧` Shift
`⇪` Caps Lock
~~`fn` Function key is `fn` (not supported)~~
`↩︎` return/enter
`space` space keys### onKeyDown
Callback function to be called when user pressed the target buttons
`space` space keys### onKeyUp
Callback function to be called when user key uped the target buttons
### allowRepeat
> allowRepeat?: boolean;
`allowRepeat` to allow auto repeating key down
### disabled
> disabled?: boolean;
Disable `onKeyDown` and `onKeyUp` events. Default: `undefined`
### filter
`INPUT` `SELECT` `TEXTAREA` default does not handle. `filter` to return to the true shortcut keys set to play a role, flase shortcut keys set up failure.
```diff
{
+ return true;
+ }}
onKeyDown={this.onKeyDown.bind(this)}
onKeyUp={this.onKeyUp.bind(this)}
/>
```## Contributors
As always, thanks to our amazing contributors!
Made with [action-contributors](https://github.com/jaywcjlove/github-action-contributors).
## License
Licensed under the MIT License.