//META{"name":"ShowImageDetails","website":"https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/ShowImageDetails","source":"https://raw.githubusercontent.com/mwittrien/BetterDiscordAddons/master/Plugins/ShowImageDetails/ShowImageDetails.plugin.js"}*// class ShowImageDetails { getName () {return "ShowImageDetails";} getVersion () {return "1.1.5";} getAuthor () {return "DevilBro";} getDescription () {return "Display the name, size and dimensions of uploaded images (does not include embed images) in the chat as an header or as a tooltip.";} constructor () { this.changelog = { "fixed":[["Light Theme Update","Fixed bugs for the Light Theme Update, which broke 99% of my plugins"]] }; this.patchModules = { "LazyImageZoomable":"componentDidMount", "StandardSidebarView":"componentWillUnmount" }; } initConstructor () { this.css = ` .image-details .image-details-size { margin: 0 10px; } .image-details-tooltip { max-width: 500px; } .image-details-tooltip .image-details-tooltip-size { margin: 10px 0; } `; this.defaults = { settings: { showOnHover: {value:false, description:"Show the details as Tooltip instead:"} }, amounts: { hoverDelay: {value:0, min:0, description:"Tooltip delay in millisec:"} } }; } getSettingsPanel () { if (!global.BDFDB || typeof BDFDB != "object" || !BDFDB.loaded || !this.started) return; let settings = BDFDB.DataUtils.get(this, "settings"); let amounts = BDFDB.DataUtils.get(this, "amounts"); let settingshtml = `
${this.name}
`; for (let key in settings) { settingshtml += `

${this.defaults.settings[key].description}

`; } for (let key in amounts) { settingshtml += `

${this.defaults.amounts[key].description}

`; } settingshtml += `
`; let settingspanel = BDFDB.DOMUtils.create(settingshtml); BDFDB.initElements(settingspanel, this); return settingspanel; } //legacy load () {} start () { if (!global.BDFDB) global.BDFDB = {myPlugins:{}}; if (global.BDFDB && global.BDFDB.myPlugins && typeof global.BDFDB.myPlugins == "object") global.BDFDB.myPlugins[this.getName()] = this; var libraryScript = document.querySelector('head script#BDFDBLibraryScript'); if (!libraryScript || (performance.now() - libraryScript.getAttribute("date")) > 600000) { if (libraryScript) libraryScript.remove(); libraryScript = document.createElement("script"); libraryScript.setAttribute("id", "BDFDBLibraryScript"); libraryScript.setAttribute("type", "text/javascript"); libraryScript.setAttribute("src", "https://mwittrien.github.io/BetterDiscordAddons/Plugins/BDFDB.min.js"); libraryScript.setAttribute("date", performance.now()); libraryScript.addEventListener("load", () => {this.initialize();}); document.head.appendChild(libraryScript); } else if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) this.initialize(); this.startTimeout = setTimeout(() => {this.initialize();}, 30000); } initialize () { if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) { if (this.started) return; BDFDB.PluginUtils.init(this); BDFDB.ModuleUtils.forceAllUpdates(this); } else console.error(`%c[${this.getName()}]%c`, 'color: #3a71c1; font-weight: 700;', '', 'Fatal Error: Could not load BD functions!'); } stop () { if (global.BDFDB && typeof BDFDB === "object" && BDFDB.loaded) { this.stopping = true; document.querySelectorAll(".image-details-added").forEach(image => {this.resetImage(image);}); BDFDB.PluginUtils.clear(this); } } // begin of own functions resetImage (image) { BDFDB.DOMUtils.removeClass(image, "image-details-added"); image.removeEventListener("mouseenter", image.mouseenterShowImageDetails); let wrapper = image.parentElement; if (BDFDB.DOMUtils.containsClass(wrapper, "image-details-wrapper")) { wrapper.parentElement.insertBefore(image, wrapper); wrapper.remove(); } } processLazyImageZoomable (instance, image, returnvalue) { let attachment = BDFDB.ReactUtils.getValue(instance, "_reactInternalFiber.return.return.memoizedProps.attachment"); if (attachment && !attachment.filename.endsWith(".bdemote.png") && !attachment.filename.endsWith(".bdemote.gif")) { if (BDFDB.DOMUtils.containsClass(image.parentElement.parentElement, BDFDB.disCN.spoilercontainer, BDFDB.disCN.spoilertext, false)) image = image.parentElement.parentElement; BDFDB.DOMUtils.addClass(image, "image-details-added"); image.removeEventListener("mouseenter", image.mouseenterShowImageDetails); if (BDFDB.DataUtils.get(this, "settings", "showOnHover")) { image.mouseenterShowImageDetails = () => { BDFDB.TooltipUtils.create(image, `
${attachment.filename}
${BDFDB.formatBytes(attachment.size)}
${attachment.width}x${attachment.height}px
`, {type:"right", html:true, selector:"image-details-tooltip", delay:BDFDB.DataUtils.get(this, "amounts", "hoverDelay")}); }; image.addEventListener("mouseenter", image.mouseenterShowImageDetails); } else { let imagedetailswrapper = BDFDB.DOMUtils.create(`
${attachment.filename}
`); image.parentElement.insertBefore(imagedetailswrapper, image); imagedetailswrapper.appendChild(image); let scroller = BDFDB.DOMUtils.getParent(BDFDB.dotCN.messages, image); if (scroller) scroller.scrollTop += BDFDB.DOMUtils.getRects(imagedetailswrapper).height - BDFDB.DOMUtils.getRects(image).height; } } } processStandardSidebarView (instance) { if (this.SettingsUpdated) { delete this.SettingsUpdated; document.querySelectorAll(".image-details-added").forEach(image => {this.resetImage(image);}); BDFDB.ModuleUtils.forceAllUpdates(this); } } }