From 3a959caa5561c571556a6ddc0ba7a2ac1c072999 Mon Sep 17 00:00:00 2001 From: Alexander Ebert Date: Sun, 11 Apr 2021 18:24:54 +0200 Subject: [PATCH] Logical separation of attachments in messages and signatures Fixes #3835 --- wcfsetup/install/files/js/WCF.ImageViewer.js | 49 ++++++++++++++++---- 1 file changed, 41 insertions(+), 8 deletions(-) diff --git a/wcfsetup/install/files/js/WCF.ImageViewer.js b/wcfsetup/install/files/js/WCF.ImageViewer.js index 16b635fca6..fa61f9a140 100644 --- a/wcfsetup/install/files/js/WCF.ImageViewer.js +++ b/wcfsetup/install/files/js/WCF.ImageViewer.js @@ -188,6 +188,11 @@ $.widget('ui.wcfImageViewer', { * @var boolean */ _isOpen: false, + + /** + * @var HTMLElement|null + */ + _messageSignature: null, /** * number of total images @@ -304,6 +309,7 @@ $.widget('ui.wcfImageViewer', { height: document.documentElement.clientHeight, width: document.documentElement.clientWidth }; + this._messageSignature = null; this._proxy = new WCF.Action.Proxy({ success: $.proxy(this._success, this) }); @@ -352,7 +358,16 @@ $.widget('ui.wcfImageViewer', { }, '', ''); } + this._messageSignature = null; if (this.options.staticViewer) { + if (targetImageElementID) { + this._messageSignature = document.getElementById(targetImageElementID).closest(".messageSignature"); + } + + // Reset the internal state because it could refer to a different set of images. + this._active = -1; + this._activeImage = null; + var $images = this._getStaticImages(); this._initUI(); this._createThumbnails($images, true); @@ -601,14 +616,25 @@ $.widget('ui.wcfImageViewer', { }, this)); } else if (targetImageElementID) { + var images = []; + + $(this.options.imageSelector).each((function (_index, image) { + // If the target image is inside a signature, then only include images within + // the same signature. Otherwise this check will exclude images that are within + // a user's signature. + if (image.closest(".messageSignature") !== this._messageSignature) { + return; + } + + images.push(image); + }).bind(this)); + var $i = 0; - $(this.options.imageSelector).each(function(index, element) { - if ($(element).wcfIdentify() == targetImageElementID) { + images.forEach(function (image, index) { + if (image.id === targetImageElementID) { $i = index; - - return false; } - }); + }) var $item = this._ui.imageList.children('li:eq(' + $i + ')'); @@ -1261,8 +1287,15 @@ $.widget('ui.wcfImageViewer', { */ _getStaticImages: function() { var $images = [ ]; - - $(this.options.imageSelector).each(function(index, link) { + + $(this.options.imageSelector).each((function(index, link) { + // If the target image is inside a signature, then only include images within + // the same signature. Otherwise this check will exclude images that are within + // a user's signature. + if (link.closest(".messageSignature") !== this._messageSignature) { + return; + } + var $link = $(link); var $thumbnail = $link.find('> img, .attachmentThumbnailImage > img').first(); if (!$thumbnail.length) { @@ -1282,7 +1315,7 @@ $.widget('ui.wcfImageViewer', { }, user: null }); - }); + }).bind(this)); this._items = $images.length; -- 2.20.1