nexxtway/react-rainbow

View on GitHub
src/libs/hocs/withDebounce/index.js

Summary

Maintainability
A
1 hr
Test Coverage
/* eslint-disable react/prop-types */
import React, { Component } from 'react';
import debounce from '../../debounce';

export default function withDebounce(WrappedComponent) {
    return class extends Component {
        constructor(props) {
            super(props);
            this.fieldRef = React.createRef();
            this.handleChange = this.handleChange.bind(this);
            this.debouncedChange = debounce(this.debouncedChange, props.debounceTimeout);
        }

        handleChange(event) {
            event.persist();
            this.debouncedChange(event);
        }

        debouncedChange(event) {
            const { onChange } = this.props;
            onChange(event);
        }

        focus() {
            this.fieldRef.current.focus();
        }

        click() {
            this.fieldRef.current.click();
        }

        blur() {
            this.fieldRef.current.blur();
        }

        render() {
            const { onChange, ...rest } = this.props;

            // eslint-disable-next-line react/jsx-props-no-spreading
            return <WrappedComponent {...rest} onChange={this.handleChange} ref={this.fieldRef} />;
        }
    };
}