0.0.12 • Published 6 years ago

react-responsive-input v0.0.12

Weekly downloads
4
License
MIT
Repository
github
Last release
6 years ago

react-responsive-input

customizable react text input

Use simple props to change the styles and functionality.

Themes and labels coming soon.

This is an alpha version. Please don't use it in production.

Demo at - http://quizzical-baby.surge.sh/

NPM JavaScript Style Guide

Install

npm install --save react-responsive-input

Usage

import React, { Component } from 'react'
import styled from 'styled-components'
import InputComponent from 'react-responsive-input'

const TestPage = styled.div`
    height:100vh;
    width:100%;
    display:flex;
    justify-content:center;
    align-items:center;
`
const ParentStyle = styled.div`
    height:35px;
    width:450px;
`

class Test extends Component {

    state = {
        value:'',
        isFocused:false,
        isError:false
    }
    
    componentDidMount(){

    }

    handleChangeUser = (e) => {
        const value = e.target.value
        
        this.setState({
            value,
            isError: value.length === this.props.maxLength ? true : false
        })
    }

    handleInputFocus = () => {
        this.setState({ isFocused: true })
    }

    handleInputBlur = () => {
        this.setState({ isFocused: false })
    }

    getInputRef = (ref) => {
        console.log(ref)
    }
  
    render() {
        const { value, isFocused, isError } = this.state

        return (
            <TestPage>
                <ParentStyle>
                    <InputComponent 
                        value={value}
                        onChange={this.handleChangeUser}

                        fontSize={'1em'}
                        maxLength={60}
                        height={'parent'} // takes parent's height
                        width={'parent'} // takes parent's width
                        // height={45}
                        // width={500}

                        isFocused={isFocused}
                        onBlur={this.handleInputBlur}
                        onFocus={this.handleInputFocus}

                        isFocusedByDefault={false}

                        isError={isError}

                        inputRef={this.getInputRef}

                    />
                </ParentStyle>
            </TestPage>
        )
    }
}

export default Test

Props Overview

Input.propTypes = {

    value:PropTypes.string,
    isFocused:PropTypes.bool,
    isError:PropTypes.bool,
    isFocusedByDefault:PropTypes.bool,

    height:PropTypes.node,
    width:PropTypes.node,
    maxLength:PropTypes.number,
    fontSize:PropTypes.string,

    onChange:PropTypes.func,
    onBlur:PropTypes.func,
    onFocus:PropTypes.func,
    inputRef:PropTypes.func,

}

Props Configuration

  • If you pass no props, the default props take over. The input component maintains default state to store your input.

  • The event handler functions you pass as props are passed the synthetic event object of React as parameter.

  • The width and height can be set to a positive integer (treated in pixels). However, for a responsive behavior, just set the height and width to 'parent'. This will set the height and width of the input to 100% of the container's dimensions which wraps the input component. From there on, just control the parent's dimensions to control the input component's dimensions.

License

MIT © gulshanzealous

0.0.12

6 years ago

0.0.11

6 years ago

0.0.1

6 years ago

0.0.2

6 years ago

1.0.0

6 years ago