Old Twitter Logo

bring back the old Twitter logo.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name         Old Twitter Logo
// @version      1.0.2
// @description  bring back the old Twitter logo.
// @author       sapondanaisriwan
// @license      MIT
// @match        *://x.com/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=twitter.com
// @run-at       document-start
// @namespace    https://greatest.deepsurf.us/en/users/1021085-sapondanaisriwan
// @homepageURL  https://github.com/sapondanaisriwan/old-twitter-logo
// @supportURL   https://github.com/sapondanaisriwan/old-twitter-logo/issues
// ==/UserScript==

// Customize the way you liking
const settings = {
  favicon_link: "https://abs.twimg.com/favicons/twitter.2.ico", // URL of the new Twitter favicon
  logo_color: "#1DA1F2", // Color for the custom logo
};

// Variables
const selectors = {
  favicon: "link[rel='shortcut icon']",
};
const styles = {
  twitterLogo: `
  [d="M18.244 2.25h3.308l-7.227 8.26 8.502 11.24H16.17l-5.214-6.817L4.99 21.75H1.68l7.73-8.835L1.254 2.25H8.08l4.713 6.231zm-1.161 17.52h1.833L7.084 4.126H5.117z"],
  [d="M14.258 10.152L23.176 0h-2.113l-7.747 8.813L7.133 0H0l9.352 13.328L0 23.973h2.113l8.176-9.309 6.531 9.309h7.133zm-2.895 3.293l-.949-1.328L2.875 1.56h3.246l6.086 8.523.945 1.328 7.91 11.078h-3.246zm0 0"] {
    d: path("M23.643 4.937c-.835.37-1.732.62-2.675.733.962-.576 1.7-1.49 2.048-2.578-.9.534-1.897.922-2.958 1.13-.85-.904-2.06-1.47-3.4-1.47-2.572 0-4.658 2.086-4.658 4.66 0 .364.042.718.12 1.06-3.873-.195-7.304-2.05-9.602-4.868-.4.69-.63 1.49-.63 2.342 0 1.616.823 3.043 2.072 3.878-.764-.025-1.482-.234-2.11-.583v.06c0 2.257 1.605 4.14 3.737 4.568-.392.106-.803.162-1.227.162-.3 0-.593-.028-.877-.082.593 1.85 2.313 3.198 4.352 3.234-1.595 1.25-3.604 1.995-5.786 1.995-.376 0-.747-.022-1.112-.065 2.062 1.323 4.51 2.093 7.14 2.093 8.57 0 13.255-7.098 13.255-13.254 0-.2-.005-.402-.014-.602.91-.658 1.7-1.477 2.323-2.41z");
    fill: ${settings.logo_color};
  }
  `,
};

// Elements Variables
const faviconEle = document.querySelector(selectors.favicon);

// Function to add custom CSS styles to the page
const addStyles = (css) => {
  const styleEle = document.createElement("style");
  styleEle.type = "text/css";
  styleEle.textContent = css;
  document.documentElement.appendChild(styleEle);
};

// Function to set a new favicon for the page
const setNewFavicon = (ele, newFaviconLink) => {
  ele.href = newFaviconLink; // Update the "href" attribute of the favicon element with the new URL
};

const main = () => {
  faviconEle && setNewFavicon(faviconEle, settings.favicon_link);
  addStyles(styles.twitterLogo);
};

main();