Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vercel/react-maskedinput
Masked <input/> React component
https://github.com/vercel/react-maskedinput
Last synced: 3 months ago
JSON representation
Masked <input/> React component
- Host: GitHub
- URL: https://github.com/vercel/react-maskedinput
- Owner: vercel
- License: mit
- Archived: true
- Fork: true (insin/react-maskedinput)
- Created: 2017-11-27T07:01:30.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2017-11-27T07:11:53.000Z (about 7 years ago)
- Last Synced: 2024-09-23T02:32:43.047Z (3 months ago)
- Language: JavaScript
- Homepage: http://insin.github.io/react-maskedinput/
- Size: 119 KB
- Stars: 13
- Watchers: 10
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# `MaskedInput`
A [React](http://facebook.github.io/react/) component for `` masking, built on top of [inputmask-core](https://github.com/insin/inputmask-core).
![This project has never been used by its author, other than while making it.](https://img.shields.io/badge/author--usage-never-red.png "This project has never been used by its author, other than while making it")
## [Live Demo](http://insin.github.io/react-maskedinput/)
## Install
### npm
`MaskedInput` can be used on the server, or bundled for the client using an npm-compatible packaging system such as [Browserify](http://browserify.org/) or [webpack](http://webpack.github.io/).
```
npm install react-maskedinput --save
```### Browser bundle
The browser bundle exposes a global `MaskedInput` variable and expects to find a global `React` (>= 0.14.0) variable to work with.
* [react-maskedinput.js](https://unpkg.com/react-maskedinput/umd/react-maskedinput.js) (development version)
* [react-maskedinput.min.js](https://unpkg.com/react-maskedinput/umd/react-maskedinput.min.js) (compressed production version)## Usage
Give `MaskedInput` a [`mask`](#mask-string) and an `onChange` callback:
```javascript
var React = require('react')
var MaskedInput = require('react-maskedinput')var CreditCardDetails = React.createClass({
state: {
card: '',
expiry: '',
ccv: ''
},_onChange(e) {
var stateChange = {}
stateChange[e.target.name] = e.target.value
this.setState(stateChange)
},render() {
return
Card Number:{' '}
Expiry Date:{' '}
CCV:{' '}
}
})
```Create some wrapper components if you have a masking configuration which will be reused:
```javascript
var CustomInput = React.createClass({
render() {
return
}
})
```## Props
### `mask` : `string`
The masking pattern to be applied to the ``.
See the [inputmask-core docs](https://github.com/insin/inputmask-core#pattern) for supported formatting characters.
### `onChange` : `(event: SyntheticEvent) => any`
A callback which will be called any time the mask's value changes.
This will be passed a `SyntheticEvent` with the input accessible via `event.target` as usual.
**Note:** this component currently calls `onChange` directly, it does not generate an `onChange` event which will bubble up like a regular `` component, so you *must* pass an `onChange` if you want to get a value back out.
### `formatCharacters`: `Object`
Customised format character definitions for use in the pattern.
See the [inputmask-core docs](https://github.com/insin/inputmask-core#formatcharacters) for details of the structure of this object.
### `placeholderChar`: `string`
Customised placeholder character used to fill in editable parts of the pattern.
See the [inputmask-core docs](https://github.com/insin/inputmask-core#placeholderchar--string) for details.
### `value` : `string`
A default value for the mask.
### `placeholder` : `string`
A default `placeholder` will be generated from the mask's pattern, but you can pass a `placeholder` prop to provide your own.
### `size` : `number | string`
By default, the rendered ``'s `size` will be the length of the pattern, but you can pass a `size` prop to override this.
### Other props
Any other props passed in will be passed as props to the rendered ``, except for the following, which are managed by the component:
* `maxLength` - will always be equal to the pattern's `.length`
* `onKeyDown`, `onKeyPress` & `onPaste` - will each trigger a call to `onChange` when necessary## MIT Licensed