Deduplicate and optimize 'keep to bottom'
This commit is contained in:
parent
a5625ba203
commit
b982623aaa
@ -69,7 +69,9 @@
|
||||
<span v-else>Show older messages</span>
|
||||
</button>
|
||||
</div>
|
||||
<MessageList :channel="channel"/>
|
||||
<MessageList
|
||||
:channel="channel"
|
||||
@keepScrollPosition="keepScrollPosition"/>
|
||||
</div>
|
||||
<ChatUserList
|
||||
v-if="channel.type === 'channel'"
|
||||
@ -119,19 +121,7 @@ export default {
|
||||
},
|
||||
watch: {
|
||||
"channel.messages"() {
|
||||
const el = this.$refs.chat;
|
||||
|
||||
if (!el) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (el.scrollHeight - el.scrollTop - el.offsetHeight > 30) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.$nextTick(() => {
|
||||
el.scrollTop = el.scrollHeight;
|
||||
});
|
||||
this.keepScrollPosition();
|
||||
},
|
||||
},
|
||||
created() {
|
||||
@ -141,7 +131,7 @@ export default {
|
||||
}
|
||||
|
||||
if (window.IntersectionObserver) {
|
||||
this.historyObserver = new window.IntersectionObserver(loadMoreHistory, {
|
||||
this.historyObserver = new window.IntersectionObserver(this.onLoadButtonObserved, {
|
||||
root: this.$refs.chat,
|
||||
});
|
||||
}
|
||||
@ -173,10 +163,7 @@ export default {
|
||||
lastId: lastMessage,
|
||||
});
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
function loadMoreHistory(entries) {
|
||||
onLoadButtonObserved(entries) {
|
||||
entries.forEach((entry) => {
|
||||
if (!entry.isIntersecting) {
|
||||
return;
|
||||
@ -184,5 +171,30 @@ function loadMoreHistory(entries) {
|
||||
|
||||
entry.target.click();
|
||||
});
|
||||
},
|
||||
keepScrollPosition() {
|
||||
// If we are already waiting for the next tick to force scroll position,
|
||||
// we have no reason to perform more checks and set it again in the next tick
|
||||
if (this.isWaitingForNextTick) {
|
||||
return;
|
||||
}
|
||||
|
||||
const el = this.$refs.chat;
|
||||
|
||||
if (!el) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (el.scrollHeight - el.scrollTop - el.offsetHeight > 30) {
|
||||
return;
|
||||
}
|
||||
|
||||
this.isWaitingForNextTick = true;
|
||||
this.$nextTick(() => {
|
||||
this.isWaitingForNextTick = false;
|
||||
el.scrollTop = el.scrollHeight;
|
||||
});
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
@ -138,6 +138,9 @@ export default {
|
||||
const options = require("../js/options");
|
||||
this.$set(this.link, "canDisplay", this.link.type !== "loading" && options.shouldOpenMessagePreview(this.link.type));
|
||||
|
||||
// parent 1 - message - parent 2 - messagelist
|
||||
this.$parent.$parent.$emit("keepScrollPosition");
|
||||
|
||||
if (this.link.type !== "link") {
|
||||
return;
|
||||
}
|
||||
@ -152,7 +155,8 @@ export default {
|
||||
},
|
||||
methods: {
|
||||
onPreviewReady() {
|
||||
|
||||
// TODO: Instead of forcing scroll position, wait for image to load before showing it
|
||||
this.$parent.$parent.$emit("keepScrollPosition");
|
||||
},
|
||||
onMoreClick() {
|
||||
this.isContentShown = !this.isContentShown;
|
||||
|
Loading…
Reference in New Issue
Block a user