Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- // ==UserScript==
- // @name Twitter Video Download
- // @namespace http://tampermonkey.net/
- // @version 1.0.8
- // @description Adds a button to download video from a tweet
- // @run-at document-idle
- // @author naileD
- // @match https://x.com/*
- // @match https://mobile.x.com/*
- // @match https://twitter.com/*
- // @match https://mobile.twitter.com/*
- // @icon https://www.google.com/s2/favicons?domain=x.com
- // @grant none
- // @license Unlicense
- // @downloadURL https://update.greasyfork.org/scripts/434883/Twitter%20Video%20Download.user.js
- // @updateURL https://update.greasyfork.org/scripts/434883/Twitter%20Video%20Download.meta.js
- // ==/UserScript==
- 'use strict';
- setInterval(() => {
- try {
- var main = document.querySelector("main[role='main'] section[role='region']");
- if (!main) throw new Error("Main section not found.");
- var react = Object.entries(main.parentElement).find(el => el[0].startsWith("__reactFiber"));
- if (!react || !react[1] || !react[1].memoizedProps.children.length) throw new Error("React component not found.");
- var tweet = react[1].memoizedProps.children.filter(el => (el || {})._owner).map(el => el._owner.memoizedProps.focalTweet).filter(el => el)[0];
- if (!tweet || !tweet.extended_entities || !tweet.extended_entities.media || !tweet.extended_entities.media.find(el => el.video_info)) {
- throw new Error("No video found in the tweet.");
- }
- var el = document.querySelector(`a[href*="${tweet.id_str}"]`);
- if (!el) throw new Error("Tweet link not found.");
- while (el.tagName !== "ARTICLE") { el = el.parentElement; }
- el = el.querySelector(`[id^="id"][role="group"]`);
- if (!el) throw new Error("Media group not found.");
- if (el.lastElementChild.tagName === "A") return;
- var videos = tweet.extended_entities.media.filter(el => el.video_info).map(el => el.video_info.variants.filter(v => v.content_type == "video/mp4").sort((a,b) => b.bitrate - a.bitrate)[0].url.replace(new RegExp("\\?tag=.*"), ""));
- var color = el.firstElementChild.style.color || "#536471";
- var svg = `<svg width="1.5em" height="1.5em" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="square" stroke-linejoin="arcs">
- <g><path d="M18 14v5a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8c0-1.1.9-2 2-2h5M15 3h6v6M10 14L20.2 3.8"/></g></svg>`;
- videos.forEach(video => el.insertAdjacentHTML("beforeend", `<a href="${video}" target="_blank" style="display: flex; place-self: center; color: ${color};" title="Download Video">${svg}</a>`));
- } catch (error) {
- console.error("Error: " + error.message); // Log error message to the console
- }
- }, 1000);
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement