Multibye

Say bye to scammy multi-item listings on eBay

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         Multibye
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  Say bye to scammy multi-item listings on eBay
// @author       asameshimae
// @match        https://www.ebay.co.uk/*
// @icon         https://www.google.com/s2/favicons?sz=64&domain=ebay.co.uk
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    let checkInterval = 500 // ms
    let hiddenClass = 'hidden' // class to add to items once hidden
    let parentSelector = 'li.s-item' // selector for the parent element to hide
    let childSelector = 'span.DEFAULT' // selector for the child element to text search
    let textMatch = ' to ' // exact text content of selectors whose parent should be hidden

    let checkAndHide = ()=>{
        document.querySelectorAll(`${parentSelector}:not(.${hiddenClass}) ${childSelector}`).forEach(
            e=>{
                if(e.textContent===textMatch) {
                let target = e.closest(parentSelector);
                target.style.display='none';
                target.classList.add(hiddenClass)
                }
            }
        )
    }

    let i = setInterval(checkAndHide, checkInterval)
})();