58 lines
1.3 KiB
JavaScript
58 lines
1.3 KiB
JavaScript
|
"use strict";
|
||
|
|
||
|
const $ = require("jquery");
|
||
|
|
||
|
const options = require("./options");
|
||
|
const templates = require("../views");
|
||
|
|
||
|
module.exports = renderPreview;
|
||
|
|
||
|
function renderPreview(preview, msg) {
|
||
|
preview.shown = options.shouldOpenMessagePreview(preview.type);
|
||
|
|
||
|
const container = msg.closest(".chat");
|
||
|
let bottom = false;
|
||
|
if (container.length) {
|
||
|
bottom = container.isScrollBottom();
|
||
|
}
|
||
|
|
||
|
msg.find(`[data-url="${preview.link}"]`)
|
||
|
.first()
|
||
|
.append(templates.msg_preview({preview: preview}));
|
||
|
|
||
|
if (preview.shown && bottom) {
|
||
|
handleImageInPreview(msg.find(".toggle-content"), container);
|
||
|
}
|
||
|
|
||
|
container.trigger("keepToBottom");
|
||
|
}
|
||
|
|
||
|
$("#chat").on("click", ".toggle-button", function() {
|
||
|
const self = $(this);
|
||
|
const container = self.closest(".chat");
|
||
|
const content = self.parent().next(".toggle-content");
|
||
|
const bottom = container.isScrollBottom();
|
||
|
|
||
|
if (bottom && !content.hasClass("show")) {
|
||
|
handleImageInPreview(content, container);
|
||
|
}
|
||
|
|
||
|
content.toggleClass("show");
|
||
|
|
||
|
// If scrollbar was at the bottom before toggling the preview, keep it at the bottom
|
||
|
if (bottom) {
|
||
|
container.scrollBottom();
|
||
|
}
|
||
|
});
|
||
|
|
||
|
function handleImageInPreview(content, container) {
|
||
|
const img = content.find("img");
|
||
|
|
||
|
// Trigger scroll logic after the image loads
|
||
|
if (img.length && !img.width()) {
|
||
|
img.on("load", function() {
|
||
|
container.trigger("keepToBottom");
|
||
|
});
|
||
|
}
|
||
|
}
|