SoundCloud Release Date

Replaces "... years ago" with exact upload date on SoundCloud

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

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

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

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

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

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

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

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

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

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

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

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

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

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

// ==UserScript==
// @name         SoundCloud Release Date
// @namespace    http://tampermonkey.net/
// @version      1.2
// @author       Agent102
// @description  Replaces "... years ago" with exact upload date on SoundCloud
// @match        https://soundcloud.com/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function () {
    'use strict';

    function updateDates() {
        const timeElements = document.querySelectorAll(
            'time:not([data-date-fixed])'
        );

        timeElements.forEach(timeEl => {
            const visibleSpan = timeEl.querySelector('span[aria-hidden="true"]');

            if (!visibleSpan) return;

            const title = timeEl.getAttribute('title');
            if (!title) return;

            let realDate = null;

            // Вариант:
            // "Posted on 8 December 2021"
            const postedMatch = title.match(/Posted on (.+)/);

            if (postedMatch) {
                realDate = postedMatch[1];
            } else {
                // Вариант:
                // "4 February 2026"
                realDate = title;
            }

            if (!realDate) return;

            visibleSpan.textContent = realDate;

            // Помечаем как обработанный
            timeEl.setAttribute('data-date-fixed', '1');
        });
    }

    updateDates();

    let timeout;

    const observer = new MutationObserver(() => {
        clearTimeout(timeout);

        timeout = setTimeout(() => {
            updateDates();
        }, 300);
    });

    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();