Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ayrton/react-key-handler
React component to handle keyboard events :key:
https://github.com/ayrton/react-key-handler
key-event keyboard react react-component react-components reactjs reactjs-component reactjs-components
Last synced: 3 months ago
JSON representation
React component to handle keyboard events :key:
- Host: GitHub
- URL: https://github.com/ayrton/react-key-handler
- Owner: ayrton
- Created: 2016-02-27T20:27:48.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2018-09-05T10:36:03.000Z (over 6 years ago)
- Last Synced: 2024-04-04T07:03:32.181Z (9 months ago)
- Topics: key-event, keyboard, react, react-component, react-components, reactjs, reactjs-component, reactjs-components
- Language: JavaScript
- Homepage: http://ayrton.be/react-key-handler
- Size: 480 KB
- Stars: 388
- Watchers: 8
- Forks: 29
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- awesome-react - react-key-handler - React component to handle keyboard events. ![](https://img.shields.io/github/stars/ayrton/react-key-handler.svg?style=social&label=Star) (UI Components / Device Input/User Action)
- awesome-list - react-key-handler - React component to handle keyboard events. (UI Utilites / Device Input)
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- fucking-awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
- awesome-react-components - react-key-handler - React component to handle keyboard events. (UI Utilities / Device Input)
README
# react-key-handler 🔑
[![npm version](https://img.shields.io/npm/v/react-key-handler.svg)](https://www.npmjs.com/package/react-key-handler) [![License](https://img.shields.io/npm/l/react-key-handler.svg)](https://www.npmjs.com/package/react-key-handler) [![Build Status](https://travis-ci.org/ayrton/react-key-handler.svg?branch=master)](https://travis-ci.org/ayrton/react-key-handler)
React component to handle keyboard events (such as `keyup`, `keydown` & `keypress`).
## Testimonials
>
“Happy to see that react-key-handler is SSR safe :+1:”
> [Veselin Todorov](https://github.com/vesln), Chai.js core## Table of Contents
1. [Installation](#installation)
2. [Usage](#usage)
1. [Higher-order Components](#higher-order-components)
2. [Component](#component)
3. [Form key handling](#form-key-handling)
3. [Key event names](#key-event-names)
4. [`keyValue`, `code` and `keyCode`](#keyvalue-code-and-keycode)
5. [Development](#development)
1. [Setup](#setup)
2. [Getting started](#getting-started)
3. [Tests](#tests)
6. [Contributing](#contributing)
7. [License](#license)## Installation
```sh
$ npm install react-key-handler --save
```## Usage
You can use `react-key-handler` library in two flavours:
- [higher-order components](#higher-order-components)
- [component](#component)### Higher-order Components
This library includes two similar higher-order components, but with a different puprose:
| Higher-order Component | Purpose |
| ---------------------- | ------------------- |
| `keyHandler` | Handles key changes |
| `keyToggleHandler` | Handles key toggles |Both have the same API and will decorate the given component with a `keyValue`, `code`
and `keyCode` property.Internally the `KeyHandler` component is used, for a full understanding be sure to
check out [the implementation](lib/key-handler.js).```jsx
import React from 'react';
import { keyHandler, KEYPRESS } from 'react-key-handler';function Demo({ keyValue }) {
return (
{keyValue === 's' && (
- hello
- world
)}
);
}export default keyHandler({ keyEventName: KEYPRESS, keyValue: 's' })(Demo);
```The prop types of the `KeyHandler` component are:
| Name | Type | Required | Default | |
| --------------- | ------ | ---------- | --------- | -------------------------------------- |
| keyEventName | string | no | `'keyup'` | `'keydown'`, `'keypress'` or `'keyup'` |
| keyValue | string | yes **\*** | | Any given [KeyboardEvent.key] |
| code | string | yes **\*** | | Any given [KeyboardEvent.code] |
| keyCode† | number | yes **\*** | | Any given [KeyboardEvent.keyCode] |**\*** You should pass at least one of these props.
† _Note_ that the keyCode is frequently browser specific and has therefore be set as
deprecated, see [MDN for details](https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode).[Examples](demo/components/examples/decorators/)
### Component
```jsx
import React from 'react';
import KeyHandler, { KEYPRESS } from 'react-key-handler';export default class Demo extends React.Component {
state = { showMenu: false };render() {
const { showMenu } = this.state;return (
{showMenu && (
- hello
- world
)}
);
},toggleMenu = (event) => {
event.preventDefault();this.setState({ showMenu: !this.state.showMenu });
};
}
```The prop types of the `KeyHandler` component are:
| Name | Type | Required | Default | |
| --------------- | -------- | ---------- | --------- | ------------------------------------------------ |
| keyEventName | string | no | `'keyup'` | `'keydown'`, `'keypress'` or `'keyup'` |
| keyValue | string | yes **\*** | | Any given [KeyboardEvent.key] |
| code | string | yes **\*** | | Any given [KeyboardEvent.code] |
| keyCode† | number | yes **\*** | | Any given [KeyboardEvent.keyCode] |
| onKeyHandle | function | yes | | Function that is called when they key is handled |**\*** You should pass at least one of these props.
† _Note_ that the keyCode is frequently browser specific and has therefore be set as
deprecated, see [MDN for details](https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode).[Example](demo/components/examples/component/index.js)
### Form key handling
This library does not handle key events for form elements such as `` and ``.
React does a fine job supporting these already via [keyboard events](https://reactjs.org/docs/events.html#keyboard-events).
[Examples](demo/components/examples/input/)
## Key event names
TODO: explain the differences between the different key events.
## `keyValue`, `code` and `keyCode`
The three available key events are
- `keyValue` This corresponds to the true value. This is the value of the key pressed
by the user while taking into considerations the state of modifier keys
such as the `shiftKey` as well as the keyboard locale/layout
- `code` This corresponds to the physical key on the keyboard (as opposed to the
character generated by pressing the key). In other words, this property
returns a value which isn't altered by keyboard layout or the state of
the modifier keys. The value is a string specific to the key, e.g. 'Digit0'
- `keyCode` This is similar to code but numeric and also _deprecated_.We recommend you to use the new Web standard [KeyboardEvent.key] or the [KeyboardEvent.code]
over the deprecated [KeyboardEvent.keyCode].Note that in **React** `key` is a reserved property, and thus we use `keyValue` when referring
to the `key` property.**Browser support:**
There's no need to worry about browser support because internally we normalize
deprecated HTML5 `keyValue` values and translate from legacy `keyCode` values,
similar to how React does this for their `SyntheticKeyboardEvent`.**More information:**
[W3C Working Draft].
## Development
### Setup
```sh
$ git clone
$ cd react-key-handler
$ npm install
```### Getting started
To start the server:
```sh
$ npm demo
```This starts a development server, which will automatically rebuild the demo app as you change files and supports hot module replacement for fast development:
```sh
$ open http://localhost:1234
```### Tests
To run all tests:
```sh
$ npm test
```Or you can run the linters, unit tests and check for type errors individually:
```sh
$ npm run test:lint
$ npm run test:unit
$ npm run test:flow
```## Contributing
Bug reports and pull requests are welcome on GitHub. This project is intended to be a
safe, welcoming space for collaboration, and contributors are expected to adhere
to the [Contributor Covenant](http://contributor-covenant.org/) code of conduct.## License
```
_________________
< The MIT License >
-----------------
\ ^__^
\ (oo)\_______
(__)\ )\/\
||----w |
|| ||
```[w3c working draft]: https://www.w3.org/TR/DOM-Level-3-Events-key/
[keyboardevent.key]: https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/key
[keyboardevent.code]: https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/code
[keyboardevent.keycode]: https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent/keyCode
[key]: https://facebook.github.io/react/docs/create-fragment.html