diff --git a/src/pages/News.js b/src/pages/News.js index 8b03aa6..f4912ed 100644 --- a/src/pages/News.js +++ b/src/pages/News.js @@ -14,7 +14,9 @@ import moment from 'moment'; import eye from '../assets/eye.mp4'; -const artLimit = 64; +const articleLimit = 64; +const attemptLimit = 6; +let attempt = 0; class News extends Component { date = new Date(); @@ -32,6 +34,13 @@ class News extends Component { found: true } + adjustDates = () => { + this.date.setMonth( this.date.getMonth() - 1 ); + this.dateStr = moment( this.date ).format( 'MM-YYYY' ); + + this.setState( { loading: false } ); + } + loadArticles = async () => { const { data, length, loading, more } = this.state; if ( loading || !more ) { return; }; @@ -49,13 +58,19 @@ class News extends Component { length: length + response.data.length } ); - this.date.setMonth( this.date.getMonth() - 1 ); - this.dateStr = moment( this.date ).format( 'MM-YYYY' ); + this.adjustDates(); + + attempt = 0; } else { - this.setState( { more: false } ); + if ( attempt >= attemptLimit ) { + this.setState( { more: false } ); + } else { + attempt = attempt + 1; + + this.adjustDates(); + this.loadArticles(); + }; }; - - this.setState( { loading: false } ); } throttleSearching( func, delay ) { @@ -221,7 +236,7 @@ class News extends Component { dataLength={length} next={this.loadArticles} hasMore={more} - scrollThreshold={(length > artLimit) ? 0.75 : 0.4} + scrollThreshold={(length > articleLimit) ? 0.6 : 0.4} loader={this.renderLoading()} endMessage={