This userscript allows you to save media content (images, videos) from Twitter's tweets by just a click on a button which appears over the media in tweets.
The content saves (downloads) with the most appropriate filename. The userscript also keeps the download history, so you will not download some media twice if you do not want it.
An installed userscript manager browser extension is required.*
To install just do two clicks:
*For example: Tampermonkey , Violentmonkey , Greasemonkey .
It adds a colored download button to the left upper corner of a media. It appears only when you hover mouse pointer over the tweet. The red button means you did not save this image (or video), green — you have downloaded it right now, blue — the media is already saved.
Note: the green button does not disapper after the mouse leave the tweet in order to easier counting that you have downloaded right now.
I sure this userscript saves files with the best filename.
The filename pattern looks so: [twitter] {author}—{YYYY.MM.DD}—{id}—{filename}.{extension}
.
The examples:
It's the perfect filename.
Why? Because it resolves the problem of file organization and includes a lot of useful information!
With this filename the downloaded files are already orginazed:
with the default sorting by name (in a file explorer) the files will grouped by site, by user, by date and ordered by date and tweet ID.
It's not a problem if the files are located in the differet folders.
Just perform the seatch by [twitter]
in a root folder to list all files which you have download with this userscript. Again, they will be grouped and sorted only due to name sorting. That's extremely useful thing!
You can easily find some media from the selected user in you local files (the media's author is credited in the filename), know when it was posted, and go to the tweet by pasting the tweet ID
to https://twitter.com/_/status/{ID}
. The "default" filename (for example, EXLtL49UYAA7vCG.jpg
) is for "compatibility". For example, if someone shared with you a file with E7AdwdkUYAAqxy3.jpg
filename you can check did you downloaded it just by the search in your local files.
The date format is YYYY.MM.DD
. It's the only one proper format. It's unambiguous format. And it can be properly ordered by the sorting by name. The importans detail is it's UTC date. So the same file downloaded by people in different time zones will have the same filename.
[twitter]
, not just twitter
? The first character as a special character (not a-zA-Z0-9
) separates the downloaded files with the userscript from other files with "usual" names. And it looks nice, like a common tag.
Finally, "—" character. Probably, it's the best character for separating purpose. It just one character (UTF-16), you do not need to add extra spaces around it to make it looks good. It's a rarely used character, that makes parsing easier.
While the main purpose of the userscript is to be Twitter image and video downloader it also does some useful things:
a:visited
Twitter replaces all outer links in tweets with redirect links like it: https://t.co/0MLMmDhZRx?amp=1 (https://example.com).
The userscript transforms redirect links to the original links.
While Twitter says that it's used for protection, but it's mostly used for the analytic purpose.
With the direct link you immitiatly see where it to goes (in the browser bottom corner), also you can copy exactly it with a context menu.
In addtional to it the userscript enables highlight of :visited
links with darkorange
color. So you can see did you visit the link before or not. (Note: it's based on the browser history which keeps visits within 3 months).
The more useful feature is that it also adds to t.co
links in the title the original links.
For example, the default title:
Username on Twitter: "A test tweet. https://t.co/0MLMmDhZRx" / Twitter
transforms to
Username: "A test tweet. https://example.com/ (https://t.co/0MLMmDhZRx)"
It's very useful if you bookmark tweets. You can find the bookmarked tweet by searching of the site's name that was posted in the tweet, since the title is used as a bookmark's description.
And yes, I did not forget to add rel="nofollow noopener noreferrer"
to the direct links (If you know what it is).
If you have no Twitter account and you visit a profile or watch tweets with media that were marked as "may include potentially sensitive content" it's starting to be a pain to expand spoilers by a click on "View" button each damning time.
This userscript does it automatically, instantly.
It hides the sign up bar and the sign up section which shows all time while you are not logged in.
(Note: of course, you able to log in/sing up in the front page or in the pop up that appers after you click on some button ("Like", "Follow"))
Finally, it hides "Trends" and "Topic to follow" by default. I find them useless, but you can do not agree with me, so it's not a big problem to disable this option. Just comment three related lines in the code in Features to execute
section.
UPD. Hiding of the Sign Up bottom bar also hides "Messages" block. In additional, the hiding the bottom bar can disable auto playing videos that can be usefull. You need to set doNotPlayVideosAutomatically
to true
for that.
This userscript is suited for single media downloading. If you want to download a balk of media, use gallery-dl.
To have the same filenames ↑ use the follow config:
"twitter": {
"directory": ["[gallery-dl]", "[{category}] {author[name]}"],
"filename": "[{category}] {author[name]}—{date:%Y.%m.%d}—{retweet_id|tweet_id}—{filename}.{extension}",
"retweets": "original",
"videos": true
}
Update: Since March 2022 Twitter now requires an account to watch NSFW content, so you need to use in gallery-dl either "auth_token"
cookie from the browser where you are logged in, or "username"
and "password"
. (It's optionally, if you are going to download NSFW content.)
"cookies": {
"auth_token": "ABCDEF"
}
Only replace the example "auth_token"
's value with yours, or use "username"
and "password"
instead:
"username": "admin",
"password": "123"
The entire config file will look, for example, so:
{
"extractor": {
"base-directory": "./",
"...": "...",
"...": "...",
"reddit": {
"...": "..."
},
"twitter": {
"directory": ["[gallery-dl]", "[{category}] {author[name]}"],
"filename": "[{category}] {author[name]}—{date:%Y.%m.%d}—{retweet_id|tweet_id}—{filename}.{extension}",
"retweets": "original",
"videos": true,
"cookies": {
"auth_token": ""
}
},
"tumblr": {
"...": "...",
"...": "..."
}
}
}
(Just replace the default settings for "twitter"
in your %HOMEPATH%/gallery-dl.conf
config file.)
Do not forget to add a comma (,
) if you put this in the middle of the json file.
To download someone
's media use (/media
endpoint):
gallery-dl https://twitter.com/someone/media
If someone
's has a lot of posts (more than 1000) use a search result downloading:
gallery-dl "https://twitter.com/search?q=from:someone"
Some features are language dependent. Currently the script works fully with "en"
, "es"
, "ru"
, "zh"
, "ja"
. See getLanguageConstants
function. You can add ?lang=en
in the address bar to temporary change your language to check the work of the script.
The script uses LocalStorage
to keep the download history.
If you see the [warning] Original images are not available.
warning on the button:
it means that the original image orig
, or 4096x4096
is not available.
Possible reasons: the tweet containing the image was deleted, or some site issue (possibly, temporal — in this case try to download the image later).
browser.download.alwaysOpenPanel
in about:config
in order to the download popup does not open each download.The userscript may do not work if you have set "Enhanced Tracking Protection"
to "Strict"
in Firefox ("Tracking content"
option of the "Custom" preset) in about:preferences#privacy
. Try to enable "Strict Tracking Protection Fix"
in the userscript settings popup.