infiniteScrolling.js 736 B

12345678910111213141516171819202122232425262728293031323334353637
  1. const peakAnticipation = 200;
  2. Mixins.InfiniteScrolling = BlazeComponent.extendComponent({
  3. onCreated() {
  4. this._nextPeak = Infinity;
  5. },
  6. setNextPeak(v) {
  7. this._nextPeak = v;
  8. },
  9. getNextPeak() {
  10. return this._nextPeak;
  11. },
  12. resetNextPeak() {
  13. this._nextPeak = Infinity;
  14. },
  15. // To be overwritten by consumers of this mixin
  16. reachNextPeak() {
  17. },
  18. events() {
  19. return [{
  20. scroll(evt) {
  21. const domElement = evt.currentTarget;
  22. let altitude = domElement.scrollTop + domElement.offsetHeight;
  23. altitude += peakAnticipation;
  24. if (altitude >= this.callFirstWith(null, 'getNextPeak')) {
  25. this.callFirstWith(null, 'reachNextPeak');
  26. }
  27. },
  28. }];
  29. },
  30. });