Greasy Fork is available in English.
Adds a media button and a link button to every tweet for one-click URL copying and media downloading.
📍 Author: GitHub | Script: Repository
Adds two buttons to every tweet's action bar — one for media, one for the tweet link — each with click, long-press, and right-click behaviours.
💡 Overview After installation, a 🎞️ Media Button and a 🔗 Link Button appear on every tweet. The media button lets you copy image and video URLs, preview them inline, or download them with structured filenames. A floating Download History Panel tracks every file you have saved, with group-based organisation, search, and export. A lightweight settings panel, accessible by hovering the top-right corner of the page, centralises all configuration without requiring the userscript manager menu.
After installation, two buttons are appended to the right side of every tweet's action row, alongside the native reply, retweet, and like buttons. A history tracker and settings panel are accessible from the top-right corner of any page.
| Icon | Feature Name | Where It Appears |
|---|---|---|
| 🎞️ | Media Button | Tweet action bar — rightmost position |
| 🔗 | Link Button | Tweet action bar — second from right |
| 📋 | History Panel | Top-right corner of the page (appears after first download) |
| ⚙️ | Settings Panel | Top-right corner of the page (hover to reveal) |
Handles image and video URLs attached to any tweet.
Left-click — Copy all media URLs to the clipboard as plain text, one per line.
Left-click and hold (0.5 s) — Copy media URLs with your configured prefix prepended in Markdown link format.
/* Output format when prefix is set:
[prefix](https://pbs.twimg.com/.../photo.jpg)
[prefix](https://video.twimg.com/.../video.mp4) */
Middle-click — Open an inline preview:
Right-click — Download all media files directly to your device. A circular progress indicator appears on the button during the download. Files are saved with the following structured filename:
/* [twitter] DisplayName(@screenname)_YYYY.MM.DD_tweettext_tweetID_1.jpg
Example: [twitter] Jane(@janedoe)_2026.04.09_Hello world_1234567890_1.jpg */
If one or more files fail to download, the button displays a warning with a partial success count (e.g., ⚠️ 2/3).
Handles the tweet URL, with configurable domain output.
Click — Copy the tweet URL. By default this uses x.com. You can configure a custom domain (such as fixupx.com or vxtwitter.com) for single-click output via the settings panel. Clicking the same settings row again toggles back to x.com.
Click and hold (0.5 s) — Copy the tweet URL using the configured domain, with your configured prefix prepended in Markdown link format.
Available domains for both behaviours:
vxtwitter.comfixupx.comfxtwitter.comcunnyx.comfixvx.comtwitter.comx.comTracks every file you have downloaded, up to 300 records.
When a download completes, a brief animation flies from the 🎞️ button toward the 📋 button to confirm the record was saved.
Organise downloaded media into named groups — useful for sorting by project, topic, or date range.
There is a hidden "Auto-Hide" toggle.
This script generates URLs using the following domains when configured as the link target. The script itself does not contact these services — it only constructs URLs that you copy to your clipboard.
| Domain | Type | Notes |
|---|---|---|
vxtwitter.com |
Third-party embed converter | Enables richer Twitter embeds in other platforms |
fixupx.com |
Third-party embed converter | Alternative embed fixer |
fxtwitter.com |
Third-party embed converter | Alternative embed fixer |
cunnyx.com |
Third-party embed converter | Alternative embed fixer |
fixvx.com |
Third-party embed converter | Alternative embed fixer |
twitter.com / x.com |
Official | Native tweet URLs |
⚠️ The third-party domains listed above have no affiliation with this script. Review their terms and privacy policies before using them.
💡 Media download contacts Twitter's own content delivery network to fetch files you have already viewed on the timeline — no credentials are sent to any service outside of Twitter/X.
⚠️ 2/3) appears if any file fails under both methods.| Situation | Impact | Recommended Action |
|---|---|---|
| Strict Content Security Policy on some pages | Media download may fall back to the secondary method | Navigate directly to twitter.com or x.com rather than embedded views |
Hover the top-right corner of any twitter.com or x.com page to reveal the ⚙️ button. Click it to open the panel. Changes take effect immediately without a page reload, except for language changes (which require a reload to apply).
🔗 Link section
x.com.[text].🎞 Media section
YYYY.MM.DD) and Western (DD.MM.YYYY) formats used in downloaded filenames.⭐ Groups section
🗂 History Panel section
All settings are also accessible from the userscript manager's menu (e.g., Tampermonkey, Violentmonkey).
The History Panel can be docked to either the left or right edge of the screen, collapsing into a thin tab when not in use.
Nine languages are built in: English, 繁體中文, 简体中文, 日本語, 한국어, Español, Português (BR), Français, Русский.
A Custom Language option is available via the Language panel:
{lang}, HTML tags, and emoji must be left unchanged.A loaded custom language can be cleared at any time from the same panel, reverting the UI to English.
Due to increasing maintenance costs, official translations are currently maintained up to Russian. Additional languages may be added based on user demand.
On the first launch after installation, a brief spotlight overlay highlights the Settings Panel entry point and explains the primary controls. The guide appears only once after installation.
⚠️ This script reads session data from your active Twitter / X session to enable a fallback method — used only when the standard approach cannot retrieve video URLs from the timeline.
| Data Type | Source | Purpose | Storage | Transmitted To |
|---|---|---|---|---|
| Anti-forgery token | Read from your browser's active Twitter / X session | Verify that requests originate from your own session when retrieving embedded video URLs | Never stored by the script | Twitter / X only |
| Session identifier | Read from your browser's active Twitter / X session | Identify your session when the standard video extraction method fails | Never stored by the script | Twitter / X only |
| Download history | Generated by the script on each download | Show past downloads in the History Panel | Saved locally on your device via the userscript manager | Not transmitted |
| Groups configuration | Created by you in the Settings Panel | Organise history records into named groups | Saved locally on your device via the userscript manager | Not transmitted |
This script does not collect, share, or transmit your credentials to any server outside of Twitter / X.
💡 Cookie access only occurs when the standard video extraction method fails — it is an automatic internal fallback, not an opt-in feature. No passwords, direct message content, or account credentials are read or stored at any point. Reviewing the source code before installation is always recommended.