Replace SOON and Update Views

Replaces the text "SOON" with the video duration and updates the view count in the metadata.

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.

(У мене вже є менеджер скриптів, дайте мені встановити його!)

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         Replace SOON and Update Views
// @namespace    http://tampermonkey.net/
// @version      0.81
// @description  Replaces the text "SOON" with the video duration and updates the view count in the metadata.
// @match        *://www.youtube.com/*
// @grant        none
// @license      none
// @run-at       document-end
// ==/UserScript==

(function() {
    'use strict';

    function updateVideoInfo() {
        // Substituir "EM BREVE" pelo tempo do vídeo
        document.querySelectorAll('ytd-thumbnail-overlay-time-status-renderer').forEach(overlay => {
            const textElement = overlay.querySelector('.badge-shape-wiz__text');
            const spanTextElement = overlay.querySelector('#text');

            if (textElement && textElement.textContent.trim() === 'EM BREVE') {
                const lengthElement = overlay.closest('ytd-rich-grid-media').querySelector('yt-formatted-string#length');

                if (lengthElement) {
                    const videoTime = lengthElement.textContent.trim();
                    textElement.textContent = videoTime;
                    if (spanTextElement) {
                        spanTextElement.textContent = videoTime;
                    }
                }
            }
        });

        // Atualizar visualizações no metadado do vídeo
        document.querySelectorAll('ytd-video-meta-block').forEach(metaBlock => {
            const ariaLabel = metaBlock.querySelector('yt-formatted-string[aria-label]');
            const viewCountElement = metaBlock.querySelector('span.inline-metadata-item.style-scope.ytd-video-meta-block');

            if (ariaLabel && viewCountElement) {
                // Extrai visualizações do aria-label
                const ariaText = ariaLabel.getAttribute('aria-label');
                const viewCountMatch = ariaText.match(/(\d+ visualizações)/);

                if (viewCountMatch) {
                    const viewCount = viewCountMatch[0];
                    // Substitui o texto do metadado com a contagem de visualizações extraída
                    viewCountElement.textContent = viewCount;
                }
            }
        });
    }

    // Execute a função quando o DOM estiver totalmente carregado
    document.addEventListener('DOMContentLoaded', updateVideoInfo);

    // Execute a função também em intervalos regulares para cobrir alterações dinâmicas
    setInterval(updateVideoInfo, 3000); // Executa a cada 3 segundos
})();