After the "tinyurl.com" update, it's no longer possible to use their service as an API (which wasn't even official in the first place). Therefore, this repository is being archived.
This extension was made with the purpose of studying how browser add-ons work, thus the simple ideia. I also hope that this extension can help people out with their necessities as well as devs with how to code a browser extension.
This browser extension's goal is to use the TinyURL service to allow the user to create a short URL for the current page being visited. It also allows the user to choose between a "default" URL, where a random address is generated by the TinyURL website, or an "aliased" URL, which is chosen by the user.
There are two ways of using it:
- By clicking on the extension's icon;
- By right clicking anywhere on the current page and going to the
TinyURL
context menu.
This extension is compatible with Firefox; Google Chrome and derivatives; Opera.
Below the folders chrome/
and firefox/
you will find the extension's code for chrome based web browsers and for firefox, respectivelly.
At first I thought they would be extremelly necessary and that I'd face some serious core rewring when going from chrome based (where I started) to firefox, but that wasn't actually the case. When analysing the code, you'll notice that API calls under the chrome/
folder, starts with chrome.[something]
and for the firefox/
folder, browser.[something]
, and as it turns out this is not really necessary, since firefox can have API calls starting with chrome.[something]
. Regardless of that, I decided to keep the difference in the code and document it here.
The very first difference that I noticed was about the options
page. In both Google Chrome and Firefox, it'll be defined in the manifest.json
file, but for Firefox the key to be used is called options_ui
instead of options_page
. That happens because options_page
is deprecated on Firefox and is still supported by Google Chrome. In this case, it's recommended to use the options_ui
key, once it's supported by both browsers. Another relevant thing to notice is that, each browser has a different key for using the browser style; browser_style
for Firefox and chrome_style
for Google Chrome.
- Firefox:
"options_ui": {
[...],
"browser_style": true
}
- Google Chrome:
"options_ui": {
[...],
"chrome_style": true
}
Another important difference that I noticed was regarding a property called Add-on ID
. Firefox asks for a manually defined add-on ID
in the manifest.json
file, otherwise the storage
API won't work. See bugzilla.
In this case, it's necessary to define it as shown below:
"browser_specific_settings": {
"gecko": {
"id": "some_custom_addon_id@something.com"
}
}
More about the implications of the Add-on ID
are discussed here.
One more relevant thing that I noticed was about javascript popup boxes, such as alerts. When using Google Chrome and its based web browsers, it's possible to display popup boxes directly from the background script and it will be displayed in a kind-of different window and this happens to not be the case in Firefox. When trying to display alerts from a background script, the browser will notify that those are not supported by showing an warning, like this one below:
alert() is not supported in background windows; please use console.log instead.
;
There might be an issue that prevents this extension from working when currently on a search page, such as google search. As pointed out by this issue, go to the extension's preferences
menu and check the Allow access to search page results
option.
- Firefox: REMOVED
- Google Chrome: REMOVED
- Opera: Follow the instructions below.
- Install the
Install Chrome Extensions
addon for Opera. (link) - Go to the Chrome Web Store page;
- Hit the button
Add to Opera
; - Click OK on the dialogue that will show up;
- Click the
Install
button.
See the specifications regarding unpacked extensions for your particular browser.
- savetabs: A web browser extension that allows the user to save every tab's url to a file