Twitter "from:" UI upgrade

makes twitter search better lol

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Twitter "from:" UI upgrade
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  makes twitter search better lol
// @author       @gd3kr
// @match        https://twitter.com/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=twitter.com
// @grant        none
// ==/UserScript==


//MIT license or something

//Paste directly into console

let search;
let fromFlag = false;

setTimeout(() => {
  search = document.querySelectorAll(
     "input[placeholder='Search Twitter']"
   )[0];
   
 search.addEventListener("keydown", function (e) {
   let searchValue = search.value;
   if (searchValue.indexOf("from:") > -1) {
     if (fromFlag === false) {
       createSpanElement();
       search.value = searchValue.replace(/from:/, "");

       fromFlag = true;
     }
   }
   if (search.value === "" && e.keyCode === 8) {
     let span = document.getElementById("customSpan");
     span.parentNode.removeChild(span);
     fromFlag = false;
   }

   if (e.keyCode === 13) {
     e.preventDefault();
     window.location.href = "https://twitter.com/search?q=from:" + search.value;
   }
 });
}, 1000); //one second delay to initialise the search bar


const createSpanElement = () => {
  let span = document.createElement("span");
  span.innerHTML = "from:";
  span.style.color = "white";
  span.style.margin = "0px";
  span.style.height = "20px";
  span.style.marginRight = "0.5em";
  span.style.padding = "0.3em";
  span.style.marginTop = "0.45em";
  span.style.borderRadius = "0.5em";
  span.id = "customSpan";
  span.style.backgroundColor = "#1d99eb";
  search.parentNode.insertBefore(span, search);
};

  

setInterval(function () {
  // try catch block
    let elements = document.getElementById("typeaheadDropdown-1")?.children;

    // if null or undefined return
    if (!elements) return;

    for (let i = 0; i < elements.length; i++) {
      elements[i].addEventListener("click", function (e) {
        search.focus();
        e.stopImmediatePropagation();
        let text = this.innerText.match(/@.*\n/)[0];
        search.value = text;
      });
    }
}, 200);