// ==UserScript== dislikes, auto repeat vid // @name Youtube Tools All in one local download mp3 mp4 HIGT QUALITY return dislikes and more // @name:zh-TW 本地 YouTube 下載器 // @name:zh-HK 本地 YouTube 下載器 // @name:zh-CN 本地 YouTube 下载器 // @name:ja ローカル YouTube ダウンローダー // @name:kr 로컬 YouTube 다운로더 // @name:ar Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:bg Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:cs Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:da Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:de Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:el Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:eo Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:es Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:fi Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:fr Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:fr-CA Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:he Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:hu Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:id Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:it Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:ko Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:nb Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:nl Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:pl Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:pt-BR Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:ro Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:ru Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:sk Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:sr Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:sv Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:th Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:tr Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:uk Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:ug Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @name:vi Youtube Tools All in one local Download MP4, MP3 HIGT QUALITY without external service and more. // @description Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:ar Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:bg Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:da Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:de Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:el Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:eo Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:fi Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:fr-CA Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:he Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:hu Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:id Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:it Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:ko Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:nb Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:nl Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:pl Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:pt-BR Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:ro Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:ru Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:sk Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:sr Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:sv Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:th Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:tr Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:uk Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:ug Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:vi Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @homepage https://github.com/DeveloperMDCM/ // @version 2.0.1 // @description Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @description:zh-TW 無需第三方服務即可下載 YouTube 視頻等。 // @description:zh-HK 無需第三方服務即可下載 YouTube 視頻等 // @description:zh-CN 无需通过第三方服务等即可下载 YouTube 视频 // @description:ja 外部サービスなどを使わずに YouTube 動画をダウンロード // @description:kr 외부 서비스 등 없이 YouTube 동영상 다운로드 // @description:fr Obtenez un lien brut de YouTube sans service externe. et de plus // @description:cs Stahujte videa z YouTube bez externích služeb. a více // @description:en Download MP4, MP3 HIGT QUALITY without external services. and more // @description:es Youtube Tools All in one local Download mp4, MP3 HIGT QUALITY without external service auto repeat video, skip ads, return dislikes and more // @author MDCM // @homepage https://github.com/DeveloperMDCM/ // @match https://*.youtube.com/* // @exclude *://music.youtube.com/* // @exclude *://*.music.youtube.com/* // @icon https://www.google.com/s2/favicons?sz=64&domain=youtube.com // @grant GM_info // @grant GM_setValue // @grant GM_getValue // @grant unsafeWindow // @run-at document-end // @compatible chrome // @compatible firefox // @compatible opera // @compatible safari // @compatible edge // @compatible brave // @license MIT // @namespace https://github.com/DeveloperMDCM/ // @downloadURL none // ==/UserScript== // new update 18/01/2024 (function () { // Youtube tools by: DeveloperMDCM // https://github.com/DeveloperMDCM/Youtube-tools-extension "use strict"; function paramsVideoURL() { const parametrosURL = new URLSearchParams(window.location.search); // Url parametros return parametrosURL.get("v"); } function cargarScript() { console.log("Scrip en ejecución by: DeveloperMDCM MDCM"); // alert('Script by: DeveloperMDCM', cat) let ad = true; const stylesCss = ` `; const thumbnailVideo = ` `; const modeReverse = ` `; const filterEyes = `
`; const resetButton = ` `; const repeatVideo = ` `; const downloadMp4Mp3 = ` `; const donwloadExternal = ` `; const viewExternalVideo = ` `; const pictureToPicture = ` `; const screenShot = ` `; const colorsTextPage = ` `; // Menu Buttons const menuBotones = ` Document ${stylesCss}
`; let validoBotones = true; // TODO: Inicia y inserta los botones function renderizarContenido() { const addButton = document.querySelector( ".style-scope .ytd-watch-metadata" ); if (addButton != undefined && validoBotones) { validoBotones = false; addButton.insertAdjacentHTML("beforebegin", menuBotones); // document.querySelector("video").style.borderRadius = "30px"; const containerButtons = document.querySelector(".containerButtons"); // Agregar cada contenido al contenedor si está activo if (containerButtons) { addButton.insertAdjacentHTML("beforebegin", menuBotones); containerButtons.innerHTML = ""; const contentData = { thumbnailVideo: { active: true, html: thumbnailVideo, }, colorTextPage: { active: true, html: colorsTextPage, }, resetButton: { active: true, html: resetButton, }, modeReverse: { active: true, html: modeReverse, }, filterEyes: { active: true, html: filterEyes, }, repeatVideo: { active: true, html: repeatVideo, }, downloadMp4Mp3: { active: true, html: downloadMp4Mp3, }, donwloadExternal: { active: true, html: donwloadExternal, }, viewExternalVideo: { active: true, html: viewExternalVideo, }, pictureToPicture: { active: true, html: pictureToPicture, }, screenShot: { active: true, html: screenShot, }, }; for (const key in contentData) { if (contentData[key].active) { containerButtons.innerHTML += contentData[key].html; } } // Resto del código para formularios y eventos... } else { console.error("Elemento .containerButtons no encontrado"); } // Formulario de botones para descargar const formulariodescarga = document.querySelector( ".formulariodescarga" ); const formulariodescargaaudio = document.querySelector( ".formulariodescargaaudio" ); const framedescarga = document.querySelector("#descargando"); const framedescargamp3 = document.querySelector("#descargandomp3"); if (formulariodescarga && formulariodescargaaudio) { formulariodescarga.addEventListener("click", (e) => { e.preventDefault(); }); formulariodescargaaudio.addEventListener("click", (e) => { e.preventDefault(); }); } const btn1mp4 = document.querySelector(".btn1"); const btn2mp3 = document.querySelector(".btn2"); const btn3cancel = document.querySelector(".btn3"); const selectcalidades = document.querySelector(".selectcalidades"); const selectcalidadesaudio = document.querySelector( ".selectcalidadesaudio" ); selectcalidades.addEventListener("change", (e) => { framedescarga.src = `https://loader.to/api/button/?url=${window.location.href}&f=${e.target.value}&color=0af`; framedescarga.classList.remove("ocultarframe"); }); selectcalidadesaudio.addEventListener("change", (e) => { framedescargamp3.src = `https://loader.to/api/button/?url=${window.location.href}&f=${e.target.value}&color=049c16`; // console.log(e.target.value) framedescargamp3.classList.remove("ocultarframeaudio"); }); if (btn3cancel) { btn3cancel.onclick = () => { formulariodescarga.style.display = "none"; formulariodescargaaudio.style.display = "none"; }; } if (btn1mp4) { btn1mp4.onclick = () => { selectcalidades.classList.remove("ocultarframe"); framedescarga.classList.add("ocultarframe"); formulariodescarga.classList.remove("ocultarframe"); formulariodescarga.style.display = ""; selectcalidadesaudio.classList.add("ocultarframeaudio"); formulariodescargaaudio.classList.add("ocultarframe"); formulariodescarga.reset(); }; } if (btn2mp3) { btn2mp3.onclick = () => { formulariodescargaaudio.classList.remove("ocultarframe"); formulariodescarga.classList.add("ocultarframe"); framedescargamp3.classList.remove("ocultarframeaudio"); formulariodescargaaudio.style.display = ""; selectcalidadesaudio.classList.remove("ocultarframeaudio"); framedescargamp3.classList.add("ocultarframeaudio"); formulariodescargaaudio.reset(); }; } const reverse = document.querySelector("#columns"); // Invertir contenido const InputColor = document.querySelector("#color"); // Input color const btnImagen = document.querySelector("#imagen"); // Download image video const formularioButtons = document.querySelector("#eyes"); // Filtro de pantalla // const btnFondo = document.querySelector("#fondo"); // Fondo cinematica completa const invertirVista = document.querySelector("#invertir"); // Intercambiar vista const buttonsVideo = document.querySelector( "#top-row.ytd-watch-metadata" ); // Botones para video reverse.style.flexDirection = "row"; buttonsVideo.style = "display: flex;flex-direction: column;justify-content: center;align-items: center ;"; document.querySelector("#title > h1").style = "text-align: center; color: red;"; document.querySelector("#owner").style.justifyContent = "center"; //document.querySelector("#search-icon-legacy.ytd-searchbox").style.backgroundColor = "gray"; let countViewRow = 0; // Count if (invertirVista) { invertirVista.onclick = () => { countViewRow += 1; switch (countViewRow) { case 1: reverse.style.flexDirection = "row-reverse"; break; case 2: reverse.style.flexDirection = "row"; countViewRow = 0; break; } }; } // valido modo oscuro y venta de video // Repeat video button let countRepeat = 0; // count const repeat = document.querySelector("#repeatvideo"); // Repeat button const imarepeat = document.querySelector(".icon-tabler-repeat"); // img repeat const videoFull = document.querySelector( "#movie_player > div.html5-video-container > video" ); repeat.onclick = () => { if ( document.querySelector("#cinematics > div") != undefined || videoFull != undefined ) { countRepeat += 1; setInterval(() => { switch (countRepeat) { case 1: document .querySelector( "#movie_player > div.html5-video-container > video" ) .setAttribute("loop", "true"); imarepeat.innerHTML = ` `; // img repeat break; case 2: countRepeat = 0; document .querySelector( "#movie_player > div.html5-video-container > video" ) .removeAttribute("loop"); imarepeat.innerHTML = ` `; break; } }, 1000); } else { mostrarAlerta("Active Dark Theme in Youtube page"); } }; // Background transparent reverse.style.flexDirection = "row"; const btnReset = document.querySelector("#reset"); // Reset button if (btnReset) { console.log(""); btnReset.addEventListener("click", function () { if ( document.querySelector("#cinematics > div") != undefined || videoFull != undefined ) { document.body.style.setProperty( "--yt-spec-text-primary", "#ffffff" ); // document.body.style.setProperty('--yt-spec-text-secondary', '#ffffff'); document.body.style.setProperty( "--yt-spec-static-overlay-background-brand", "#ffffff" ); document.body.style.setProperty( "--yt-spec-static-overlay-background-brand", "red" ); if (document.querySelector("#cinematics > div") != null) { document.querySelector("#cinematics > div").style = "position: relative; inset: 0px; pointer-events: none; background: transparent"; } document.body.style.setProperty( "--yt-spec-static-brand-red", "#ff0000" ); document.body.style.setProperty( "--yt-spec-static-brand-white", "gray" ); document.querySelector("#ojosprotect").style.backgroundColor = "transparent"; document.body.style.setProperty( "--ytd-searchbox-legacy-border-color", "#ffffff" ); document.body.style.setProperty( "--ytd-searchbox-legacy-border-shadow-color", "#ffffff" ); document.querySelector("#logo-icon").style.color = "#ffffff"; document.body.style.setProperty( "--yt-spec-general-background-a", "#000000" ); document.querySelector( "html[dark] [dark]" ).style.backgroundColor = "#000000"; document.querySelector( "ytd-playlist-panel-renderer[modern-panels]:not([within-miniplayer]) #container.ytd-playlist-panel-renderer" ).style = ""; } }); } if (btnImagen) { btnImagen.onclick = () => { if ( document.querySelector("#cinematics > div") != undefined || videoFull != undefined ) { const parametrosURL = new URLSearchParams(window.location.search); let enlace = parametrosURL.get("v"); // Construir la URL de la imagen const imageUrl = `https://i.ytimg.com/vi/${enlace}/maxresdefault.jpg`; // Realizar la solicitud para obtener la imagen fetch(imageUrl) .then((response) => { if (!response.ok) { throw new Error(`HTTP error! Status: ${response.status}`); } return response.blob(); }) .then((blob) => { // Obtener el tamaño de la imagen en kilobytes const imageSizeKB = blob.size / 1024; // Verificar si el tamaño de la imagen es menor o igual a 20 KB if (imageSizeKB >= 20) { window.open( `https://i.ytimg.com/vi/${enlace}/maxresdefault.jpg`, "popUpWindow", "height=500,width=400,left=100,top=100,resizable=yes,scrollbars=yes,toolbar=yes,menubar=no,location=no,directories=no, status=yes" ); // Crear una URL para la imagen const imageUrlObject = URL.createObjectURL(blob); // Crear un enlace para descargar la imagen const enlaceDescarga = document.createElement("a"); enlaceDescarga.href = imageUrlObject; const titleVideo = document.querySelector( "h1.style-scope.ytd-watch-metadata" ).innerText; enlaceDescarga.download = `${titleVideo}_maxresdefault.jpg`; // Simular un clic en el enlace para iniciar la descarga enlaceDescarga.click(); // Limpiar la URL del objeto después de la descarga URL.revokeObjectURL(imageUrlObject); } else { console.log( "La imagen excede los 20 KB. No se descargará." ); } }) .catch((error) => { console.error("Error al obtener la imagen:", error); }); } else { mostrarAlerta("Active Dark Theme in Youtube page"); } }; } const colorTextPage = localStorage.getItem("colorTextPage"); document.body.style.setProperty( "--yt-spec-text-primary", colorTextPage ); // Input color InputColor.addEventListener("input", function () { localStorage.setItem("colorTextPage", InputColor.value); const colorTextPage = localStorage.getItem("colorTextPage"); // console.log(colorTextPage); if ( document.querySelector("#cinematics > div") != undefined || videoFull != undefined ) { document.body.style.setProperty( "--yt-spec-text-primary", colorTextPage ); //document.body.style.setProperty("--yt-spec-text-secondary", "#ffffff"); document.body.style.setProperty( "--yt-spec-static-overlay-background-brand", colorTextPage ); document.body.style.setProperty( "--yt-spec-static-brand-red", colorTextPage ); //document.body.style.setProperty("--yt-spec-static-brand-white", colorTextPage); document.querySelector("#logo-icon").style.color = colorTextPage; // document.querySelector("#subscribe-button > ytd-subscribe-button-renderer > yt-button-shape > button").style = "color: black; background-color: white; border: 2px solid black;"; } else { mostrarAlerta("Active Dark Theme in Youtube page"); } }); const externalLink = document.querySelector(".external_link"); if (externalLink) { externalLink.onclick = () => { const parametrosURL = new URLSearchParams(window.location.search); // Url parametros let enlace; enlace = parametrosURL.get("v"); window.open( `https://www.y2mate.com/es/convert-youtube/${enlace}`, "popUpWindow", "height=800,width=1000,left=50%,top=100,resizable=no,scrollbars=yes,toolbar=no,menubar=yes,location=no,directories=yes, status=no" ); }; } const viewExternalLink = document.querySelector(".view_external_link"); if (viewExternalLink) { viewExternalLink.onclick = () => { document.querySelector("video").click(); const parametrosURL = new URLSearchParams(window.location.search); // Url parametros let enlace; enlace = parametrosURL.get("v"); window.open( `https://www.youtube.com/embed/${enlace}?rel=0&controls=2&color=white&iv_load_policy=3&showinfo=0&modestbranding=1&autoplay=1` ); }; } const viewPictureToPicture = document.querySelector( ".video_picture_to_picture" ); if (viewPictureToPicture) { viewPictureToPicture.onclick = () => { const video = document.querySelector("video"); // Verifica si el navegador admite Picture-in-Picture if ("pictureInPictureEnabled" in document) { // Verifica si el video aún no está en modo Picture-in-Picture if (!document.pictureInPictureElement) { // Intenta activar el modo Picture-in-Picture video .requestPictureInPicture() .then(() => { // El video está ahora en modo Picture-in-Picture }) .catch((error) => { console.error( "Error al activar el modo Picture-in-Picture:", error ); }); } else { // video picture } } else { alert("Picture-in-Picture not supported"); } }; // Filtro de pantalla if (formularioButtons) { formularioButtons.addEventListener("input", function () { if ( document.querySelector("#cinematics > div") != undefined || videoFull != undefined ) { document.querySelector("#ojosprotect").style.backgroundColor = formularioButtons.value; } }); } clearInterval(renderizarContenido); } const screenShotVideo = document.querySelector(".screenshot_video"); if (screenShotVideo) { screenShotVideo.onclick = () => { const video = document.querySelector("video"); const canvas = document.createElement("canvas"); canvas.width = video.videoWidth; canvas.height = video.videoHeight; const context = canvas.getContext("2d"); context.drawImage(video, 0, 0, canvas.width, canvas.height); const imagenURL = canvas.toDataURL("image/png"); const enlaceDescarga = document.createElement("a"); enlaceDescarga.href = imagenURL; const titleVideo = document.querySelector( "h1.style-scope.ytd-watch-metadata" ).innerText; enlaceDescarga.download = `${video.currentTime.toFixed( 0 )}s_${titleVideo}.png`; enlaceDescarga.click(); }; } else { // Si result.GeneralIsActiveIconColor es falso, quitar contenido del DOM const containerButtons = document.querySelector(".containerButtons"); if (containerButtons != undefined) { containerButtons.innerHTML = ""; // También puedes ocultar o manipular otros elementos según tus necesidades } } clearInterval(renderizarContenido); } } renderizarContenido(); // Función para link github project const existeFormButton = document.querySelector( "#below > ytd-watch-metadata > div.container > form" ); function MDCM() { if (!existeFormButton) { const mdcm = document.querySelector("#MDCM"); const sms = document.querySelector("#below > ytd-watch-metadata"); if (!mdcm) { if (sms != undefined) { const mdcm = document.createElement("P"); mdcm.innerHTML = 'Link GitHub Repository

'; sms.appendChild(mdcm); } } } } // Función para adaptar dislikes // Función para formatear los dislikes function FormatiarNumero(num, digits) { const lookup = [ { value: 1, symbol: "", }, { value: 1e3, symbol: " K", }, { value: 1e6, symbol: " M", }, ]; const rx = /\.0+$|(\.[0-9]*[1-9])0+$/; const item = lookup .slice() .reverse() .find((item) => { return num >= item.value; }); return item ? (num / item.value).toFixed(digits).replace(rx, "$1") + item.symbol : "0"; } let validoUrl = document.location.href; async function videoDislike() { validoUrl = document.location.href; const validoVentana = document.querySelector( "#below > ytd-watch-metadata > div.container > form > div.containerButtons" ); if ( validoVentana != undefined && document.location.href.split("?v=")[0].includes("youtube.com/watch") ) { validoUrl = paramsVideoURL(); const urlShorts = `https://returnyoutubedislikeapi.com/Votes?videoId=${validoUrl}`; try { const respuesta = await fetch(urlShorts); const datosShort = await respuesta.json(); const { dislikes } = datosShort; // alert(dislikes, 'Video') document.querySelector( "#top-level-buttons-computed > segmented-like-dislike-button-view-model > yt-smartimation > div > div > dislike-button-view-model > toggle-button-view-model > button" ).style = "width: 90px"; // document.querySelector('#top-level-buttons-computed > segmented-like-dislike-button-view-model > yt-smartimation > div > div > dislike-button-view-model > toggle-button-view-model > button > yt-touch-feedback-shape > div').insertAdjacentHTML("beforebegin", `${FormatiarNumero(dislikes, 0)}`); document.querySelector( "#top-level-buttons-computed > segmented-like-dislike-button-view-model > yt-smartimation > div > div > dislike-button-view-model > toggle-button-view-model > button" ).innerHTML = ` ${FormatiarNumero(dislikes, 0)}`; } catch (error) { console.log(error); } } } // Función para mostrar los dislikes en shorts async function shortDislike() { validoUrl = document.location.href; const validoVentanaShort = document.querySelectorAll( "#dislike-button > yt-button-shape > label > div > span" ); if ( validoVentanaShort != undefined && document.location.href.split("/")[3] === "shorts" ) { validoUrl = document.location.href.split("/")[4]; const urlShorts = `https://returnyoutubedislikeapi.com/Votes?videoId=${validoUrl}`; try { const respuesta = await fetch(urlShorts); const datosShort = await respuesta.json(); const { dislikes } = datosShort; for (var i = 0; i < validoVentanaShort.length; i++) { validoVentanaShort[i].textContent = `${FormatiarNumero( dislikes, 0 )}`; } } catch (error) { console.log(error); } } } // Mostrar alerta de activar modo oscuro function mostrarAlerta(mensaje) { alert("Active Dark Theme in Youtube page"); const addButton = document.querySelector( "#below > ytd-watch-metadata > div.container > form" ); const existeAlerta = document.querySelector(".alerta"); if (!existeAlerta) { if (addButton != undefined) { const modeDark = document.createElement("P"); modeDark.innerHTML = `

${mensaje}

`; addButton.appendChild(modeDark); setTimeout(() => { modeDark.remove(); }, 7000); } } } // Función para eliminar los posibles anuncios function eliminarAnuancios() { // Skip ads video / saltar publicidad if ( document.querySelector(".ytp-ad-skip-button-modern.ytp-button") !== null || document.querySelector( ".ytp-ad-text.ytp-ad-preview-text-modern" !== null ) || document.querySelector(".ytp-ad-text") || document.querySelector(".ytp-ad-preview-container" !== null) || document.querySelector( ".ytp-ad-preview-container.ytp-ad-preview-container-detached" ) ) { if ( document.querySelector( ".ytp-ad-preview-container.ytp-ad-preview-container-detached" ) != undefined ) { document.querySelector( "#movie_player > div.html5-video-container > video" ).currentTime = 100000; } document.querySelector(".ytp-ad-skip-button-modern.ytp-button").click(); document.querySelector(".video-ads.ytp-ad-module").click(); } const buttonSkip = document.querySelector( ".ytp-ad-skip-button.ytp-button" ); const validar = undefined; let bannerAds = document.querySelector( ".ytd-banner-promo-renderer-background" ); let bannerProm = document.querySelector("#simple-ad-badge"); let ytpminiplayerscrim = document.querySelector("ytp-miniplayer-scrim"); let cross = document.getElementsByClassName( "ytp-ad-overlay-close-container" )[0]; let skip = document.getElementsByClassName("ytp-ad-skip-button")[0]; let ad1 = document.querySelector( "#contents > ytd-promoted-sparkles-web-renderer" ); let ad2 = document.querySelector( "#player-ads > ytd-player-legacy-desktop-watch-ads-renderer" ); let ad3 = document.querySelector("#action-companion-click-target"); let ad4 = document.querySelector( "#player-overlay\\:0 > div.ytp-ad-player-overlay-flyout-cta.ytp-ad-player-overlay-flyout-cta-rounded" ); let ad5 = document.querySelector( "#invideo-overlay\\:0 > div > div.ytp-ad-image-overlay" ); let ad6 = document.querySelector("#root"); let ad7 = document.querySelector( "#rendering-content > ytd-video-masthead-ad-v3-renderer" ); let ad8 = document.querySelector( "#player-ads > ytd-player-legacy-desktop-watch-ads-renderer" ); let ad9 = document.querySelector(".ytp-ad-text-overlay"); const adVideo = document.querySelectorAll(".ad-showing")[0]; const adTimeVideo = document.querySelector( ".ytp-ad-text.ytp-ad-preview-text" ); const video = document.querySelector("video"); if (adVideo != validar && video != validar && adTimeVideo != validar) { video.currentTime = video.duration; } if (ytpminiplayerscrim != validar) alert("eliminado"); if (ad1 != validar) ad1.remove(); if (ad2 != validar) ad2.remove(); if (ad3 != validar) ad3.remove(); if (ad4 != validar) ad4.remove(); if (ad5 != validar) ad5.remove(); if (ad6 != validar && ad) { ad6.style.display = "none"; ad = false; } if (ad7 != validar) ad7.remove(); if (ad8 != validar) ad8.remove(); if (ad9 != validar) ad9.remove(); if (bannerAds != validar) bannerAds.remove(); if (bannerProm != validar) bannerProm.remove(); if (cross != validar) cross.click(); if (skip != validar) skip.click(); if (buttonSkip != validar) { buttonSkip.click(); } } // Validar que la url a cambiado por una nueva let prevUrl = undefined; // Sin cambios setInterval(async () => { // URL changed / Cambio const currUrl2 = window.location.href; const video = document.querySelector( "#below > ytd-watch-metadata > div.container > form > div.containerButtons" ); if (currUrl2 != prevUrl && video != undefined) { setTimeout(() => { videoDislike(); }, 2000); } const currUrl = window.location.href; if (currUrl != prevUrl) { MDCM(); setTimeout(() => { shortDislike(); }, 1000); const formulariodescarga = document.querySelector( ".formulariodescarga" ); const formulariodescargaaudio = document.querySelector( ".formulariodescargaaudio" ); setTimeout(() => { if (formulariodescarga != undefined) { formulariodescarga.classList.add("ocultarframe"); formulariodescargaaudio.classList.add("ocultarframe"); } }, 500); prevUrl = currUrl; } const ventanaShortComentarios = document.querySelector( "body > ytd-app > ytd-popup-container > tp-yt-paper-dialog > ytd-engagement-panel-section-list-renderer" ); const historias = document.querySelectorAll("#shorts-inner-container"); if (ventanaShortComentarios && historias) { limpiarHTML(); } eliminarAnuancios(); }, 500); // Cada 2 segundos se ejecuta mientras la url cambie eliminarAnuancios(); } // Variables para la traduccion de comentarios let traducido; // Texto traducido let urlLista; // Url lista //TODO: Traducir comentarios async function traductor() { const texto = document.querySelectorAll("#content-text"); let o = `?client=dict-chrome-ex&sl=auto&tl=${navigator.language}&q=`; for (let i = 0; i < texto.length; i++) { const botonTraducir = document.createElement("BUTTON"); botonTraducir.classList.add("mdcm"); botonTraducir.textContent = "Traducir"; botonTraducir.style.backgroundColor = "white"; botonTraducir.style.color = "black"; botonTraducir.style.borderRadius = "5px"; botonTraducir.setAttribute("id", `btn${i}`); texto[i].insertAdjacentElement("afterend", botonTraducir); const mdcm = document.querySelectorAll(`.mdcm`); mdcm[i].onclick = function () { traducido = o; urlLista = traducido + texto[i].textContent; fetch("https://translate.googleapis.com/translate_a/t" + urlLista) //API .then((response) => response.json()) .then((datos) => { texto[i].textContent = datos[0][0]; mdcm[i].textContent = "Translated"; }); }; } } // Limpiar botones de comentarios function limpiarHTML() { const buttons = document.querySelectorAll(".mdcm"); [].forEach.call(buttons, function (buttons) { buttons.remove(); }); traductor(); } // TODO: mostrar boton de traducir en comentarios cuando sean visibles window.onscroll = () => { const divEl = document.querySelector("#content-text"); if (divEl != undefined) { limpiarHTML(); } }; setTimeout(() => { cargarScript(); }, 2000); })();