0.17.5 • Published 2 years ago

react-native-material-textfield-new v0.17.5

Weekly downloads
-
License
BSD-3-Clause
Repository
github
Last release
2 years ago

react-native-material-textfield-new

npm license codeclimate

Supports Latest react-native version 0.70.*

Material texfield with consistent behaviour on iOS and Android.

This package is a cloned version of react-native-material-textfield. I've added few fixes to the package.

example

Features

  • Material design guidelines compliance
  • Consistent look and feel on iOS and Android
  • Animated state transitions (normal, focused and errored)
  • Customizable font size, colors and animation duration
  • Disabled state (with dotted underline)
  • Outlined and filled fields
  • Masked input support
  • Multiline text input
  • Character counter
  • Prefix and suffix
  • Accessory views
  • Helper text
  • RTL support
  • Pure javascript implementation

Installation

npm install --save react-native-material-textfield-new

or

yarn add react-native-material-textfield-new

Usage

import React, { Component } from 'react';
import {
  TextField,
  FilledTextField,
  OutlinedTextField,
} from 'react-native-material-textfield-new';

class Example extends Component {
  fieldRef = React.createRef();

  onSubmit = () => {
    let { current: field } = this.fieldRef;

    console.log(field.value());
  };

  formatText = (text) => {
    return text.replace(/[^+\d]/g, '');
  };

  render() {
    return (
      <OutlinedTextField
        label='Phone number'
        keyboardType='phone-pad'
        formatText={this.formatText}
        onSubmitEditing={this.onSubmit}
        ref={this.fieldRef}
      />
    );
  }
}

Properties

namedescriptiontypedefault
textColorText input colorStringrgba(0, 0, 0, .87)
fontSizeText input font sizeNumber16
labelFontSizeText field label font sizeNumber12
lineWidthText field underline widthNumber0.5
activeLineWidthText field active underline widthNumber2
disabledLineWidthText field disabled underline widthNumber1
tintColorText field accent colorStringrgb(0, 145, 234)
baseColorText field base colorStringrgba(0, 0, 0, .38)
labelText field label textString-
titleText field helper textString-
prefixText field prefix textString-
suffixText field suffix textString-
errorText field error textString-
errorColorText field color for errored stateStringrgb(213, 0, 0)
errorTestIdText field error testIDString-
lineTypeText field line typeStringsolid
disabledLineTypeText field line type in disabled stateStringdotted
animationDurationText field animation duration in msNumber225
characterRestrictionText field soft limit for character counterNumber-
disabledText field availabilityBooleanfalse
editableText field text can be editedBooleantrue
multilineText filed multiline inputBooleanfalse
contentInsetLayout configuration objectObject{...}
labelOffsetLabel position adjustmentObject{...}
inputContainerStyleStyle for input container viewObject-
containerStyleStyle for container viewObject-
labelTextStyleStyle for label inner Text componentObject-
titleTextStyleStyle for title inner Text componentObject-
affixTextStyleStyle for affix inner Text componentObject-
formatTextInput mask callbackFunction-
renderLeftAccessoryRender left input accessory viewFunction-
renderRightAccessoryRender right input accessory viewFunction-
onChangeTextChange text callbackFunction-
onFocusFocus callbackFunction-
onBlurBlur callbackFunction-

Other TextInput properties will also work.

Content Inset

namedescriptionNormalFilledOutlined
topInset on the top side1680
leftInset on the left side01212
rightInset on the right side01212
labelSpace between label and TextInput444
inputSpace between line and TextInput8816

Label Offset

namedescriptionNormalFilledOutlined
x0Horizontal offset for inactive state000
y0Vertical offset for inactive state0-100
x1Horizontal offset for active state000
y1Vertical offset for active state0-2-10

Methods

namedescriptionreturns
focus()Acquire focus-
blur()Release focus-
clear()Clear text field-
value()Get current valueString
isFocused()Get current focus stateBoolean
isErrored()Get current error stateBoolean
isRestricted()Get current restriction stateBoolean
isDefaultVisible()Get default value visibilityBoolean
isPlaceholderVisible()Get placeholder visibilityBoolean
setValue()Set current value-

Example - (Development)

We are using Yalc to manage local dependency for development.

git clone https://github.com/sriram10/react-native-material-textfield-new

cd react-native-material-textfield-new
yarn
npx yarn publish
cd exampleApp
npx yalc add react-native-material-textfield-new
yarn
yarn ios # or yarn android

Copyright and License

BSD License Copyright 2022 Sriram. All rights reserved.

Credits

Thanks to Alexander Nazarov for creating this awesome library.