Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/halilb/react-native-textinput-effects
Text inputs with custom label and icon animations for iOS and android. Built with react native and inspired by Codrops.
https://github.com/halilb/react-native-textinput-effects
Last synced: about 13 hours ago
JSON representation
Text inputs with custom label and icon animations for iOS and android. Built with react native and inspired by Codrops.
- Host: GitHub
- URL: https://github.com/halilb/react-native-textinput-effects
- Owner: halilb
- License: mit
- Created: 2016-06-01T12:22:28.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-04-08T12:39:25.000Z (11 months ago)
- Last Synced: 2025-02-13T06:07:49.014Z (8 days ago)
- Language: JavaScript
- Homepage:
- Size: 3.31 MB
- Stars: 2,993
- Watchers: 35
- Forks: 293
- Open Issues: 28
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-react-native - react-native-textinput-effects ★2062 - Text inputs with custom label and icon animations for iOS and Android. Built by react native and inspired by Codrops. (Components / UI)
- awesome-react-native - react-native-textinput-effects ★2062 - Text inputs with custom label and icon animations for iOS and Android. Built by react native and inspired by Codrops. (Components / UI)
- awesome-reactnative-ui - react-native-textinput-effects - native-textinput-effects/master/screenshots/full.gif)| (Others)
- awesome-reactnative-ui - react-native-textinput-effects - native-textinput-effects/master/screenshots/full.gif)| (Others)
- awesome-react-native - react-native-textinput-effects ★2062 - Text inputs with custom label and icon animations for iOS and android. Built by react native and inspired by Codrops. (Components / UI)
- awesome-react-native-ui - react-native-textinput-effects ★841 - Text inputs with custom label and icon animations for iOS and android. Built by react native and inspired by Codrops. (Components / UI)
- awesome-react-native - react-native-textinput-effects ★2062 - Text inputs with custom label and icon animations for iOS and Android. Built by react native and inspired by Codrops. (Components / UI)
README
# React Native Textinput Effects
I've come across with [those beautiful](http://tympanus.net/Development/TextInputEffects) text inputs created and [blogged](http://tympanus.net/codrops/2015/01/08/inspiration-text-input-effects) by **Codrops** and wanted to port them to react-native. Some of those text fields are now ready to use in iOS and android thanks to react-native.
There is also a native iOS library called [TextFieldEffects](https://github.com/raulriera/TextFieldEffects) which has built some of them in Swift.
data:image/s3,"s3://crabby-images/a56ac/a56acde1853e1a7a0d3416d013d29a5198b37bea" alt=""
## Blog Post
I've recently written a blog post about [Creating an Animated TextField with React Native](https://bilir.me/blog/creating-an-animated-textfield-with-react-native). While it isn't directly related to this library, I think you might still find it useful to understand the basics of creating an animated text input with `React Native Animated` library.
## Installation
The latest version of this project needs **react-native >= 0.55(March 2018 release)** due to **createRef** usage. Go with the latest version:
`$ npm install react-native-textinput-effects --save`
You can stick with version 0.4 if you have an older react-native version:
`$ npm install [email protected] --save`
You also need to install [react-native-vector-icons](https://github.com/oblador/react-native-vector-icons) if you'd like to use a TextInputEffect component with an icon. Please check out [Installation section](https://github.com/oblador/react-native-vector-icons#installation) on that project.
## How to use
### Common Props
| Prop | Type | Description |
|---|---|---|
|**`label`**|String|Displayed as placeholder string of the input.|
|**`style`**|View Style Object|Applied to the root container of the input.|
|**`labelStyle`**|View Style Object|Applied to the container of the label view.|
|**`inputStyle`**|Text Style Object|Applied to the TextInput component.|
|**`value`**|String|This value will be applied to the TextInput and change it's state on every render. Use this prop if you want a [Controlled Component](https://facebook.github.io/react/docs/forms.html#controlled-components).|
|**`defaultValue`**|String|If you want to initialize the component with a non-empty value, you can supply a defaultValue prop. This prop creates an [Uncontrolled Component](https://facebook.github.io/react/docs/forms.html#uncontrolled-components) and is only used during initial render.|You can also use default [TextInput Props](https://facebook.github.io/react-native/docs/textinput.html#props). They'll be passed into TextInput component. E.g., use `TextInput`'s `onChange` prop to be notified on text changes.
```js
{ this.setState({textValue: text}) }
/>
```### Props for TextInputEffects with an Icon
This component needs `Icon` component from `react-native-vector-icons` to operate with icons. You should import it before creating a TextInputEffects component.
`import Icon from 'react-native-vector-icons/FontAwesome';`
| Prop | Type | Description |
|---|---|---|
|**`iconClass`**|Object|The Icon component class you've imported from react-native-vector-icons.|
|**`iconName`**|String|Name of the icon that is passed to Icon component.|
|**`iconColor`**|String|Applied to the Icon component.|
|**`iconSize`**|Number|Applied to the Icon component.|## Example
See [TextInputEffectsExample.js](Example/TextInputEffectsExample.js) file.
Follow those steps to run the example:
1. Clone the repo `git clone https://github.com/halilb/react-native-textinput-effects && cd react-native-textinput-effects/Example`
2. Install dependencies `npm install``
3. Follow [official instructions](https://facebook.github.io/react-native/docs/getting-started.html) to run the example project in a simulator or device.You can also check out the example library without any installation on [Appetize.io](https://appetize.io/app/uhgu1wc1htqfcf7bp812gevr2r?device=iphone6s&scale=75&orientation=portrait&osVersion=9.3)!
## Input Types
### Sae
data:image/s3,"s3://crabby-images/1ef91/1ef9148b10379eefdb590ca8dd89cc500a626648" alt=""
```js
import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
import { Sae } from 'react-native-textinput-effects';const saeInput = (
);
```### Fumi
data:image/s3,"s3://crabby-images/68884/688849f94d4632da02178bb162b496e5c69e9e9f" alt=""
```js
import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
import { Fumi } from 'react-native-textinput-effects';const fumiInput = (
);
```
### Kohanadata:image/s3,"s3://crabby-images/a43a0/a43a0ddfe860b94607c70aef16905208f9c7334f" alt=""
Kohana supports [Animated Native Driver](https://facebook.github.io/react-native/docs/animations.html#using-the-native-driver). You can use native driver by passing `useNativeDriver`.
```js
import MaterialsIcon from 'react-native-vector-icons/MaterialIcons';
import { Kohana } from 'react-native-textinput-effects';const kohanaInput = (
);
```### Makiko
data:image/s3,"s3://crabby-images/86d47/86d4792420f2e8bfa051c439e6c65c394b12a592" alt=""
```js
import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
import { Makiko } from 'react-native-textinput-effects';const makikoInput = (
);
```
Note: Icon component expands and covers the input. So, the icon should not have any blank spaces for the animation experience. This is the limitation for Makiko.### Isao
data:image/s3,"s3://crabby-images/0567b/0567bd76b7b86a58a288c5908cf593a10d7f5daa" alt=""
```js
import { Isao } from 'react-native-textinput-effects';const isaoInput = (
);
```### Hoshi
data:image/s3,"s3://crabby-images/295af/295af286aa172012e3049b613c0b6294ab96b701" alt=""
```js
import { Hoshi } from 'react-native-textinput-effects';const hoshiInput = (
);
```### Jiro
data:image/s3,"s3://crabby-images/62c69/62c69f386d26ebbb0b2d35ba7491b003254f9c91" alt=""
```js
import { Jiro } from 'react-native-textinput-effects';const jiroInput = (
);
```### Kaede
data:image/s3,"s3://crabby-images/f4dff/f4dff439ed437ea68529eccf147c64888b589c19" alt=""
```js
import { Kaede } from 'react-native-textinput-effects';const kaedeInput = (
);
```### Akira
data:image/s3,"s3://crabby-images/d4218/d421824cd9f5d3432728f312f69a97f21d2a3635" alt=""
```js
import { Akira } from 'react-native-textinput-effects';const akiraInput = (
);
```### Madoka
data:image/s3,"s3://crabby-images/42b6b/42b6b241244bf699910e01ac63a095ddd1700068" alt=""
```js
import { Madoka } from 'react-native-textinput-effects';const madokaInput = (
);
```### Hideo
data:image/s3,"s3://crabby-images/4d04c/4d04c8faf779b9513ac32f5e3e30ee78f5184daf" alt=""
```js
import FontAwesomeIcon from 'react-native-vector-icons/FontAwesome';
import { Hideo } from 'react-native-textinput-effects';const hideoInput = (
);
```## Licence
[MIT](http://opensource.org/licenses/mit-license.html)