NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript==
// @name Mastodon Larger Preview
// @namespace https://onee3.org
// @version 0.1.2
// @description Larger Open Graph preview images in Mastodon
// @copyright 2020, Frederick888 (https://openuserjs.org/users/Frederick888)
// @author Frederick888
// @license GPL-3.0-or-later
// @homepageURL https://github.com/Frederick888/mastodon-larger-preview
// @supportURL https://github.com/Frederick888/mastodon-larger-preview/issues
// @contributionURL https://github.com/Frederick888/mastodon-larger-preview/pull
// @updateURL https://openuserjs.org/meta/Frederick888/Mastodon_Larger_Preview.meta.js
// @match https://mastodon.ktachibana.party/*
// ==/UserScript==
let galleryTemplate = `
<div class="media-gallery">
<div class="media-gallery__item" style="inset: auto; width: 100%; height: 100%;">
<a class="media-gallery__item-thumbnail" href="" target="_blank" rel="noopener noreferrer">
<img src=""
srcset=""
sizes="250px"
style="object-position: 50.5% 20%;"
/></a>
</div>
</div>
`;
function htmlToElement(html) {
var template = document.createElement('template');
html = html.trim(); // Never return a text node of whitespace as the result
template.innerHTML = html;
return template.content.firstChild;
}
function addLargerOpenGraph(container, ogImage) {
let ogImageLink = ogImage.getAttribute('src');
let ogContainer = ogImage.closest('.status-card');
let ogLink = ogContainer.getAttribute('href');
if (ogLink === null) {
let oembedActionsLink = ogContainer.querySelector('.status-card__actions a[href]');
if (oembedActionsLink !== null) {
ogLink = oembedActionsLink.getAttribute('href');
}
}
let actionBar = container.querySelector('.status__action-bar');
let mediaGallery = htmlToElement(galleryTemplate);
mediaGallery.querySelector('.media-gallery__item-thumbnail').setAttribute('href', ogLink);
let mediaGalleryImg = mediaGallery.querySelector('img');
mediaGalleryImg.setAttribute('src', ogImageLink);
mediaGalleryImg.setAttribute('srcset', ogImageLink + ' 960w ' + ogImageLink + ' 346w');
actionBar.before(mediaGallery);
}
function mainLoop() {
document.querySelectorAll('img.status-card__image-image:not([og-larger-processed])')
.forEach((ogImage) => {
ogImage.setAttribute('og-larger-processed', '1');
let container = ogImage.closest('.status__wrapper');
if (container.querySelector('.media-gallery:not(.og-larger)') === null) {
addLargerOpenGraph(container, ogImage);
}
});
}
(function () {
'use strict';
if (typeof MutationObserver === 'function') {
let observerConfig = {
attributes: true,
characterData: true,
childList: true,
subtree: true,
};
let body = document.getElementsByTagName('body')[0];
let observer = new MutationObserver(mainLoop);
observer.observe(body, observerConfig);
} else {
mainLoop();
setInterval(mainLoop, 200);
}
})();