Bluesky Account Finder for Twitter (Script Edition)
here's what the extension looks like btw https://chromewebstore.google.com/detail/bluesky-account-finder-fo/copkfihlldjjedifhdgkgdnijkipgdel
.
thats actually extremely easy, i could do it later if you want?
yes please i would love you too
*to
// ==UserScript==
// @name Bsky Finder
// @namespace http://tampermonkey.net/
// @version 1.0
// @description Adds Bsky link to Twitter/X usernames if they exist on Bsky.
// @author Your Name
// @match https://twitter.com/*
// @match https://x.com/*
// @grant none
// @run-at document-end
// ==/UserScript==
function checkForAtSymbol(nodes) {
nodes.forEach(node => {
if (node.nodeType === Node.ELEMENT_NODE && node.textContent.includes("@") && !node.textContent.includes(" ")) {
const textParts = node.textContent.split("@");
const processedIds = new Set();
for (let i = 1; i < textParts.length; i++) {
const part = textParts[i].trim().split(" ")[0];
if (processedIds.has(part)) {
continue;
}
const existingImage = node.querySelector(`.inline-at-icon[data-at="${part}"]`);
if (existingImage) {
processedIds.add(part);
continue;
}
const link = document.createElement('a');
link.href = `https://bsky.app/profile/${part}.bsky.social`;
link.target = '_blank';
link.style.display = 'inline-block';
link.style.width = '10px';
link.style.height = '10px';
link.style.marginLeft = '2px';
link.className = 'inline-at-icon';
link.setAttribute('data-at', part);
const image = new Image();
image.src = '';
image.style.width = '10px';
image.style.height = '10px';
image.alt = '';
link.appendChild(image);
node.innerHTML = node.innerHTML.replace("@" + part, "@" + part + link.outerHTML);
processedIds.add(part);
}
}
});
}
const observer = new MutationObserver(mutations => {
mutations.forEach(mutation => {
if (mutation.addedNodes.length) {
checkForAtSymbol(mutation.addedNodes);
}
});
});
observer.observe(document.body, {
childList: true,
subtree: true
});
function checkTextOnScroll() {
const allNodes = Array.from(document.body.getElementsByTagName('*'));
checkForAtSymbol(allNodes);
}
let debounceTimeout;
window.addEventListener('scroll', () => {
clearTimeout(debounceTimeout);
debounceTimeout = setTimeout(checkTextOnScroll, 100);
});
checkForAtSymbol(Array.from(document.body.getElementsByTagName('*')));
here it is, this functions a bit differently as the original extension is completely non-working now, but i made it as visually appealing and nice as i could. I hope this serves well, and btw, some extensions do use apis and functions that userscripts simply cannot, however this was one that doesnt, but was simply unmaintained.
thanks for making this but can you put a link to the userscript i'm having trouble finding it
i didnt post it anywhere, i pasted it into the comment only
can somebody make a script version of the bluesky account finder for twitter google chrome extension i want a script version of this cause the extension doesn't work that well anymore