Greasy Fork is available in English.
在每条推文新增媒体与链接按钮,提供一键复制网址及下载媒体的功能。
📍 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. The link button copies the tweet URL in either its native form or a third-party embed-friendly format. 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 optionally configure a custom domain (such as fixupx.com or vxtwitter.com) for single-click output via the settings panel.
Click and hold (0.5 s) — Copy the tweet URL using the Long-Press Domain, with your configured prefix prepended in Markdown link format. The long-press domain is configured separately from the single-click domain.
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.
This script generates URLs using the following domains when configured as the single-click or long-press 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./i/status/ card format instead of a standard status URL) cannot always be extracted when viewed in the feed. An API-based fallback resolves this in many cases, but it remains unreliable in the timeline view. Opening the individual tweet page resolves this consistently.| 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 and can be re-triggered at any time from the Help section inside the Settings Panel.
⚠️ 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.