How To Create A Firefox Plugin
Your first extension
Writing the extension
Create a new directory and navigate to it. For example, in your command line/terminal you do it like this:
mkdir borderify cd borderify
manifest.json
Now create a new file called "manifest.json" directly under the "borderify" directory. Give it the following contents:
{ "manifest_version" : 2 , "name" : "Borderify" , "version" : "1.0" , "description" : "Adds a red border to all webpages matching mozilla.org." , "icons" : { "48" : "icons/border-48.png" } , "content_scripts" : [ { "matches" : [ "*://*.mozilla.org/*" ] , "js" : [ "borderify.js" ] } ] }
- The first three keys:
manifest_version
,name
, andversion
, are mandatory and contain basic metadata for the extension. -
description
is optional, but recommended: it's displayed in the Add-ons Manager. -
icons
is optional, but recommended: it allows you to specify an icon for the extension, that will be shown in the Add-ons Manager.
The most interesting key here is content_scripts
, which tells Firefox to load a script into Web pages whose URL matches a specific pattern. In this case, we're asking Firefox to load a script called "borderify.js" into all HTTP or HTTPS pages served from "mozilla.org" or any of its subdomains.
- Learn more about content scripts.
- Learn more about match patterns.
icons/border-48.png
The extension should have an icon. This will be shown next to the extension's listing in the Add-ons Manager. Our manifest.json promised that we would have an icon at "icons/border-48.png".
Create the "icons" directory directly under the "borderify" directory. Save an icon there named "border-48.png". You could use the one from our example, which is taken from the Google Material Design iconset, and is used under the terms of the Creative Commons Attribution-ShareAlike license.
If you choose to supply your own icon, It should be 48x48 pixels. You could also supply a 96x96 pixel icon, for high-resolution displays, and if you do this it will be specified as the 96
property of the icons
object in manifest.json:
"icons" : { "48" : "icons/border-48.png" , "96" : "icons/border-96.png" }
Alternatively, you could supply an SVG file here, and it will be scaled correctly. (Though: if you're using SVG and your icon includes text, you may want to use your SVG editor's "convert to path" tool to flatten the text, so that it scales with a consistent size/position.)
- Learn more about specifying icons.
borderify.js
Finally, create a file called "borderify.js" directly under the "borderify" directory. Give it this content:
document.body.style.border = "5px solid red" ;
This script will be loaded into the pages that match the pattern given in the content_scripts
manifest.json key. The script has direct access to the document, just like scripts loaded by the page itself.
- Learn more about content scripts.
Trying it out
First, double check that you have the right files in the right places:
borderify/ icons/ border-48.png borderify.js manifest.json
Installing
In Firefox: Open the about:debugging page, click the This Firefox option, click the Load Temporary Add-on button, then select any file in your extension's directory.
The extension now installs, and remains installed until you restart Firefox.
Alternatively, you can run the extension from the command line using the web-ext tool.
Testing
Note: By default extensions don't work in private browsing. If you want to test this extension in private browsing open "about:addons
", click on the extension, and select the Allow radio button for Run in Private Windows.
Now visit a page under "mozilla.org
", and you should see the red border round the page.
Note: Don't try it on "addons.mozilla.org
", though! Content scripts are currently blocked on that domain.
Try experimenting a bit. Edit the content script to change the color of the border, or do something else to the page content. Save the content script, then reload the extension's files by clicking the Reload button in "about:debugging
". You can see the changes right away.
- Learn more about loading extensions
Packaging and publishing
For other people to use your extension, you need to package it and submit it to Mozilla for signing. To learn more about that, see "Publishing your extension".
What's next?
How To Create A Firefox Plugin
Source: https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/Your_first_WebExtension
Posted by: vanalstynerefustoo.blogspot.com
0 Response to "How To Create A Firefox Plugin"
Post a Comment