A higher-order text-mask component for React and React Native.
npm install react-text-mask-hoc> A higher-order text-mask component for
> React and React Native.
text-mask is great. It's a feature-rich solution for creating input masks for various libraries and frameworks.
However the React implementation has some long-standing bugs and feature requests that bury the potential of the
library.
Features:
- Supports all features from text-mask, see its
documentation for more information.
- Custom components: you can mask any components through a simple adapter interface!
- Platform agnostic: works in all browsers, React Native and Node.js (useful for server-side rendering)!
- Install
- Usage
- Examples
- API
- TextMask
- Adapters
- for React: InputAdapter and SpanAdapter
- for React Native: TextInputAdapter and TextAdapter
- TextMaskTransformer
``bash`
yarn add react-text-mask-hoc
# or
npm install --save react-text-mask-hoc
`jsx
import {TextMask, InputAdapter} from 'react-text-mask-hoc';
export default () => (
Component={InputAdapter}
mask={['(', /[1-9]/, /\d/, /\d/, ')', ' ', /\d/, /\d/, /\d/, '-', /\d/, /\d/, /\d/, /\d/]}
guide={false}
value="5554953947"
/>
);
`
To use in React Native import react-text-mask-hoc/ReactNative instead:
`jsx`
import {TextMask, TextInputAdapter} from 'react-text-mask-hoc/ReactNative';
A component that grants text-mask functionality to the passed component.
It's a controlled component by default, but it also maintains its own state, however it can also be switched to
uncontrolled.
Props
- all text-mask settings
- Component _(React.Component)_: A component that follows the adapter specification.[value]
- _(String|Number)_: A value that will be masked. Will be used as an initial value on mounting, and laterisControlled
can be used to control the component. If prop is set to false, the value will be ignored onnull
rerenders. Defaults to .[isControlled]
- _(Boolean)_: A way to set the component behaviour to be controlled by a value prop or to ignoretrue
it (to be uncontrolled). Can also be used to switch it in runtime. Defaults to .[onChange]
- _(Function)_: A function that is called on input changes. Takes 2 arguments: the native event (variesvalue
from a platform) and the next state (has and caretPosition properties).[componentRef]
- _(Function)_: A function that is called with a reference to the Component.
Instance methods
- the value getterfocus()
- blur()
-
---
Adapters are React components that implement a special interface for the
withTextMask.
List of adapters included in this library:
- for React
- InputAdapterSpanAdapter
- TextInputAdapter
- for React Native
- TextAdapter
-
Specification
An adapter must be a React component that takes value, caretPosition and onChange props, and exposes acaretPosition getter that always returns a positive integer number.
---
A class that calculates a value and a caret position. Based on the createTextMaskInputElement() fromtext-mask-core`.
Exported for testing purposes only.
---