// ==UserScript== // @name Twitter Engagement Button // @namespace http://tampermonkey.net/ // @version 0.7 // @description ツイートの下にエンゲージメント画面に飛ぶリンクを追加します。結構自分用。 // @author sambaquiz // @match https://twitter.com/* // @match https://mobile.twitter.com/* // @match https://pbs.twimg.com/media/* // @icon https://www.google.com/s2/favicons?sz=64&domain=twitter.com // @license MIT // @grant none // @downloadURL none // ==/UserScript== const EB = (function() { 'use strict'; return { inject: function (article) { if (article.getAttribute('data-testid') === 'tweet') { let wrapper = document.createElement('div'); wrapper.style.marginTop = '15px'; wrapper.style.display = 'flex'; const username = article.querySelector('a[href*="/status/"]').href.split('/')[3]; const statusId = article.querySelector('a[href*="/status/"]').href.split('/status/').pop().split('/').shift(); { let engagementButtonDiv = document.createElement('div'); engagementButtonDiv.style.marginRight = '30px'; let engagementButton = document.createElement('a'); engagementButton.className = 'engagementButton r-a023e6 css-18t94o4'; engagementButton.href = `/${username}/status/${statusId}/quotes`; engagementButton.target= '_blank'; engagementButton.style.color = 'inherit'; engagementButton.style.textDecoration = 'none'; engagementButton.addEventListener('mouseover', function() { this.style.textDecoration = 'underline'; }); engagementButton.addEventListener('mouseout', function() { this.style.textDecoration = 'none'; }); engagementButton.style.marginLeft = '5px'; engagementButton.textContent = `引用確認`; let svg = document.createElement('svg'); svg.style.float = 'left'; svg.innerHTML = ` `; engagementButton.appendChild(svg); engagementButtonDiv.appendChild(engagementButton); wrapper.appendChild(engagementButtonDiv); } { let retweetEngagementButtonDiv = document.createElement('div'); retweetEngagementButtonDiv.style.marginRight = '30px'; let retweetEngagementButton = document.createElement('a'); retweetEngagementButton.className = 'engagementButton r-a023e6 css-18t94o4'; retweetEngagementButton.href = `/${username}/status/${statusId}/retweets`; retweetEngagementButton.target= '_blank'; retweetEngagementButton.style.color = 'inherit'; retweetEngagementButton.style.textDecoration = 'none'; retweetEngagementButton.addEventListener('mouseover', function() { this.style.textDecoration = 'underline'; }); retweetEngagementButton.addEventListener('mouseout', function() { this.style.textDecoration = 'none'; }); retweetEngagementButton.style.marginLeft = '5px'; retweetEngagementButton.textContent = `RT確認`; let svg = document.createElement('svg'); svg.style.float = 'left'; svg.innerHTML = ` `; retweetEngagementButton.appendChild(svg); retweetEngagementButtonDiv.appendChild(retweetEngagementButton); wrapper.appendChild(retweetEngagementButtonDiv); } { let likesEngagementButtonDiv = document.createElement('div'); likesEngagementButtonDiv.style.marginRight = '30px'; let likesEngagementButton = document.createElement('a'); likesEngagementButton.className = 'engagementButton r-a023e6 css-18t94o4'; likesEngagementButton.href = `/${username}/status/${statusId}/likes`; likesEngagementButton.target= '_blank'; likesEngagementButton.style.color = 'inherit'; likesEngagementButton.style.textDecoration = 'none'; likesEngagementButton.addEventListener('mouseover', function() { this.style.textDecoration = 'underline'; }); likesEngagementButton.addEventListener('mouseout', function() { this.style.textDecoration = 'none'; }); likesEngagementButton.style.marginLeft = '5px'; likesEngagementButton.textContent = `いいね確認`; let svg = document.createElement('svg'); svg.style.float = 'left'; svg.innerHTML = ` `; likesEngagementButton.appendChild(svg); likesEngagementButtonDiv.appendChild(likesEngagementButton); wrapper.appendChild(likesEngagementButtonDiv); } const element = article.querySelector('div[data-testid="reply"]'); element.parentElement.parentElement.parentElement.appendChild(wrapper); } article.dataset.EBinjected = 'true'; } } })(); (function () { const callback = ms => ms.forEach(m => m.addedNodes.forEach(node => { const article = node.tagName == 'ARTICLE' && node || node.tagName == 'DIV' && (node.querySelector('article') || node.closest('article')); if (article && !article.dataset.EBinjected) EB.inject(article); })); const observer = new MutationObserver(callback) observer.observe(document.body, {childList: true, subtree: true}); })();