Skip to content

Commit

Permalink
Merge pull request #115 from packetloop/React-Strict
Browse files Browse the repository at this point in the history
React.Strict compatibility
  • Loading branch information
nkbt authored Oct 17, 2019
2 parents 4b617c9 + 7a44186 commit 05e953f
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 13 deletions.
2 changes: 1 addition & 1 deletion example/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@ const appRoot = document.createElement('div');

appRoot.id = 'app';
document.body.appendChild(appRoot);
ReactDOM.render(<App />, appRoot);
ReactDOM.render(<React.StrictMode><App /></React.StrictMode>, appRoot);
20 changes: 8 additions & 12 deletions src/Component.js
Original file line number Diff line number Diff line change
Expand Up @@ -39,30 +39,26 @@ export class DebounceInput extends React.PureComponent {
constructor(props) {
super(props);

this.state = {
value: props.value || ''
};

this.isDebouncing = false;
}
this.state = {value: props.value || ''};


// eslint-disable-next-line react/no-deprecated
componentWillMount() {
const {debounceTimeout} = this.props;
this.createNotifier(debounceTimeout);
}


// eslint-disable-next-line react/no-deprecated
componentWillReceiveProps({value, debounceTimeout}) {
componentDidUpdate(prevProps) {
if (this.isDebouncing) {
return;
}
const {debounceTimeout: oldTimeout} = this.props;
const {value, debounceTimeout} = this.props;

const {debounceTimeout: oldTimeout, value: oldValue} = prevProps;
const {value: stateValue} = this.state;

if (typeof value !== 'undefined' && stateValue !== value) {
if (typeof value !== 'undefined' && oldValue !== value && stateValue !== value) {
// Update state.value if new value passed via props, yep re-render should happen
// eslint-disable-next-line react/no-did-update-set-state
this.setState({value});
}
if (debounceTimeout !== oldTimeout) {
Expand Down

0 comments on commit 05e953f

Please sign in to comment.