FIX: Use much less aggressive cloaking
This commit is contained in:
parent
e6b95e56d7
commit
bff965327c
|
@ -41,8 +41,9 @@ export default MountWidget.extend({
|
||||||
|
|
||||||
const $w = $(window);
|
const $w = $(window);
|
||||||
const windowHeight = window.innerHeight ? window.innerHeight : $w.height();
|
const windowHeight = window.innerHeight ? window.innerHeight : $w.height();
|
||||||
const slack = Math.round(windowHeight * 15);
|
const slack = Math.round(windowHeight * 5);
|
||||||
const onscreen = [];
|
const onscreen = [];
|
||||||
|
const nearby = [];
|
||||||
|
|
||||||
let windowTop = $w.scrollTop();
|
let windowTop = $w.scrollTop();
|
||||||
|
|
||||||
|
@ -72,6 +73,7 @@ export default MountWidget.extend({
|
||||||
if (viewBottom > windowTop && viewTop <= windowBottom) {
|
if (viewBottom > windowTop && viewTop <= windowBottom) {
|
||||||
onscreen.push(bottomView);
|
onscreen.push(bottomView);
|
||||||
}
|
}
|
||||||
|
nearby.push(bottomView);
|
||||||
|
|
||||||
bottomView++;
|
bottomView++;
|
||||||
}
|
}
|
||||||
|
@ -114,20 +116,23 @@ export default MountWidget.extend({
|
||||||
}
|
}
|
||||||
|
|
||||||
const onscreenPostNumbers = [];
|
const onscreenPostNumbers = [];
|
||||||
const prev = this._previouslyOnscreen;
|
const prev = this._previouslyNearby;
|
||||||
const newPrev = {};
|
const newPrev = {};
|
||||||
onscreen.forEach(idx => {
|
nearby.forEach(idx => {
|
||||||
const post = posts.objectAt(idx);
|
const post = posts.objectAt(idx);
|
||||||
const postNumber = post.post_number;
|
const postNumber = post.post_number;
|
||||||
delete prev[postNumber];
|
delete prev[postNumber];
|
||||||
|
|
||||||
|
if (onscreen.indexOf(idx) !== -1) {
|
||||||
onscreenPostNumbers.push(postNumber);
|
onscreenPostNumbers.push(postNumber);
|
||||||
|
}
|
||||||
newPrev[postNumber] = post;
|
newPrev[postNumber] = post;
|
||||||
uncloak(post, this);
|
uncloak(post, this);
|
||||||
});
|
});
|
||||||
|
|
||||||
Object.keys(prev).forEach(pn => cloak(prev[pn], this));
|
Object.keys(prev).forEach(pn => cloak(prev[pn], this));
|
||||||
|
|
||||||
this._previouslyOnscreen = newPrev;
|
this._previouslyNearby = newPrev;
|
||||||
this.screenTrack.setOnscreen(onscreenPostNumbers);
|
this.screenTrack.setOnscreen(onscreenPostNumbers);
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -139,7 +144,7 @@ export default MountWidget.extend({
|
||||||
this._super();
|
this._super();
|
||||||
const debouncedScroll = () => Ember.run.debounce(this, this._scrollTriggered, 10);
|
const debouncedScroll = () => Ember.run.debounce(this, this._scrollTriggered, 10);
|
||||||
|
|
||||||
this._previouslyOnscreen = {};
|
this._previouslyNearby = {};
|
||||||
|
|
||||||
this.appEvents.on('post-stream:refresh', debouncedScroll);
|
this.appEvents.on('post-stream:refresh', debouncedScroll);
|
||||||
$(document).bind('touchmove.post-stream', debouncedScroll);
|
$(document).bind('touchmove.post-stream', debouncedScroll);
|
||||||
|
|
Loading…
Reference in New Issue