zeit/react-maskedinput

Name: react-maskedinput

Owner: ZEIT

Description: Masked React component

Forked from: insin/react-maskedinput

Created: 2017-11-27 07:01:30.0

Updated: 2018-04-09 07:31:31.0

Pushed: 2017-11-27 07:11:53.0

Homepage: http://insin.github.io/react-maskedinput/

Size: 122

Language: JavaScript

GitHub Committers

UserMost Recent Commit# Commits

Other Committers

UserEmailMost Recent Commit# Commits

README

MaskedInput

A React component for <input> masking, built on top of inputmask-core.

This project has never been used by its author, other than while making it.

Live Demo
Install
npm

MaskedInput can be used on the server, or bundled for the client using an npm-compatible packaging system such as Browserify or webpack.

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.

Usage

Give MaskedInput a mask and an onChange callback:

React = require('react')
MaskedInput = require('react-maskedinput')

CreditCardDetails = React.createClass({
ate: {
card: '',
expiry: '',
ccv: ''


nChange(e) {
var stateChange = {}
stateChange[e.target.name] = e.target.value
this.setState(stateChange)


nder() {
return <div className="CreditCardDetails">
  <label>
    Card Number:{' '}
    <MaskedInput mask="1111 1111 1111 1111" name="card" size="20" onChange={this._onChange}/>
  </label>
  <label>
    Expiry Date:{' '}
    <MaskedInput mask="11/1111" name="expiry" placeholder="mm/yyyy" onChange={this._onChange}/>
  </label>
  <label>
    CCV:{' '}
    <MaskedInput mask="111" name="ccv" onChange={this._onChange}/>
  </label>
</div>


Create some wrapper components if you have a masking configuration which will be reused:

CustomInput = React.createClass({
nder() {
return <MaskedInput
  mask="1111-WW-11"
  placeholder="1234-WW-12"
  size="11"
  {...this.props}
  formatCharacters={{
    'W': {
      validate(char) { return /\w/.test(char ) },
      transform(char) { return char.toUpperCase() }
    }
  }
}/>


Props
mask : string

The masking pattern to be applied to the <input>.

See the inputmask-core docs 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 <input> 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 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 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 <input>'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 <input>, except for the following, which are managed by the component:

MIT Licensed

This work is supported by the National Institutes of Health's National Center for Advancing Translational Sciences, Grant Number U24TR002306. This work is solely the responsibility of the creators and does not necessarily represent the official views of the National Institutes of Health.