SlideShare uma empresa Scribd logo
1 de 32
FIReFOX HARISHANKARAN Co-FOUNDER, INTERVIEWSTREET.COM
QUICK POLL 2
OPERATING SYSTEM? 3
HISTORY FORKED FROM THE MOZILLA SUITE SOFTWARE BLOAT OF MOZILLA SUITE (IRC, MAIL, NEWS, HTML EDITOR AND WHAT NOT) FF3, THE MOST DOWNLOADED SOFTWARE IN 24 HOURS (28,340,281 DOWNLOADS ON JUNE 17. BROWSER SHARE OF FIREFOX – 46% 4
WHAT IS AN EXTENSION? A TYPE OF “ADD-ONS” EXTENSIONS PLUGINS THEMES EXTENSIONS EXTEND YOUR BROWSER SINGLE FEATURE (HIDE MENUBAR) FEATURE ENHANCEMENT (NOSCRIPT) WEB APP INTEGRATION (TWITTERFOX) NEW FEATURES (FIREBUG) 5
EXTENSIONS 6,000 EXTENSIONS AND STILL COUNTING EXCELLENT  API  TO CREATE ANYTHING. EXTENSIONS  ARE MADE BY GOOGLE, FACEBOOK, MICROSOFT, YAHOO AND NOW EVEN YOU. 6
HELLO WORLD OUR FIRST EXTENSION. A MENU ITEM IN TOOL BAR ON CLICK, SHOWS A POPUP “HELLO WORLD” UPDATES STATUS BAR BY “YIPEE” 7
8
9
TECHNOLOGY 10
XUL XML USER INTERFACE LANGUAGE CROSS PLATFORM INTERFACE ELEMENTS https://developer.mozilla.org/en/xul http://www.hevanet.com/acorbin/xul/top.xul <button label="Press Me" oncommand = "alert(Hola!');"/> 11
XUL <menulist>  <menupopup>  <menuitem label="option 1" value="1"/>  <menuitem label="option 2" value="2"/>  <menuitem label="option 3" value="3"/>  <menuitem label="option 4" value="4"/> </menupopup>  </menulist> 12
CSS IT’S TRUE! CSS IS USED TO MODIFY USER INTERFACE #hello-menuitem {   color: red !important; } 13
JAVASCRIPT IT’S TRUE… AGAIN! HANDLES COMMANDS IN THE INTERFACE XMLHTTPREQUEST, DOM. ALSO HAS ACCESS TO CORE API onMenuItemCommand: function(e) { document.getElementById('hello-panel').label = "Yippee";     alert("Hello World");   }, 14
XPCOM Cross Platform Component Object Model The core or the “black box” of Firefox Similar to Microsoft’s COM or GNOME’s  Corba or D-Bus A Cross-platform API 15
SO… XPCOM IS THE “BRAIN” XUL  IS THE “SKELETON” JAVASCRIPT IS THE “MUSCLE” CSS IS THE “SKIN” 16
17
EXTENSION 18
FOLDER STRUCTURE 19
CONFUSING? TRUST ME IT’S NOT THAT HARD ;-) 20
LET’S CREATE THE EXTENSION https://addons.mozilla.org/en-US/developers/tools/builder Add-on Name : Hello World Description : This is my first Firefox extension. Add-on Version : 1.0.0 Unique ID : http://extensions.roachfiend.com/cgi-bin/guid.pl Package Name : hello Authors-name : <Your-name> Other contributors: <Friend’s name> 21
LET’S CREATE THE EXTENSION Applications to support : FF Pre-built features :  ,[object Object]
Main Menu CommandCreate My Add-on 22
EDIT THE FILES Now we add features to this extension. Windows: C:ocuments and Settingsaripplication Dataozillairefoxrofiles GNU/Linux: .mozilla/firefox/ 23
ff-overlay.xul  <menupopup id="menu_ToolsPopup"> <menuitem id="hello-hello" label="Hello World" oncommand="hello.onMenuItemCommand(event);"/>   </menupopup> 24
ff-overlay.xul  <statusbar id="status-bar"> 	<statusbarpanel id="hello-panel" label="" tooltiptext="" />   </statusbar> 25
overlay.js onMenuItemCommand: function(e) { document.getElementById('hello-panel').label = "Yippee"; 		alert("Hello World");   } 26
YOUR FIRST EXTENSION IS READY! 27
A BETTER EXTENSION GET UPDATES FROM TWITTER SHOW THE LAST UPDATE 28
HOW TO LEARN ALL THIS? 29
Before 1995 30
After 1995  31

Mais conteúdo relacionado

Mais procurados

web browsers by Daniel rhenals
web browsers by Daniel rhenalsweb browsers by Daniel rhenals
web browsers by Daniel rhenals
danielrhenals
 
Web browsers
Web       browsersWeb       browsers
Web browsers
fedelae
 
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作るハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
Shin Ise
 

Mais procurados (13)

web browsers by Daniel rhenals
web browsers by Daniel rhenalsweb browsers by Daniel rhenals
web browsers by Daniel rhenals
 
web browsers
web browsersweb browsers
web browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Web browsers
Web       browsersWeb       browsers
Web browsers
 
Window 10 ppt
Window 10 pptWindow 10 ppt
Window 10 ppt
 
Change Firefox Addon Version
Change Firefox Addon VersionChange Firefox Addon Version
Change Firefox Addon Version
 
Windows 10
Windows 10Windows 10
Windows 10
 
Web browsers
Web browsersWeb browsers
Web browsers
 
surface pro x windows 11
surface pro x windows 11surface pro x windows 11
surface pro x windows 11
 
Firefox 4 & THE AFTER
Firefox 4 & THE AFTERFirefox 4 & THE AFTER
Firefox 4 & THE AFTER
 
Banquet 08
Banquet 08Banquet 08
Banquet 08
 
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作るハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
ハブインテグレーションでWindows Phone 7の世界に溶け込むアプリを作る
 
Surfing of the internet
Surfing of the internetSurfing of the internet
Surfing of the internet
 

Destaque

Savage, Savage, &amp; Brown, Inc
Savage, Savage, &amp; Brown, IncSavage, Savage, &amp; Brown, Inc
Savage, Savage, &amp; Brown, Inc
dallaswilliams
 
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
South West Observatory
 
Chua Cop Thai Lan
Chua Cop Thai LanChua Cop Thai Lan
Chua Cop Thai Lan
vbtuoc
 
Meet The Officers Fall 2009
Meet The Officers Fall 2009Meet The Officers Fall 2009
Meet The Officers Fall 2009
UMAatCal
 

Destaque (20)

Email - Good Practices
Email - Good PracticesEmail - Good Practices
Email - Good Practices
 
Hug a startup
Hug a startupHug a startup
Hug a startup
 
Spider Course Day 1
Spider Course Day 1Spider Course Day 1
Spider Course Day 1
 
The Cloud Platform Play
The Cloud Platform PlayThe Cloud Platform Play
The Cloud Platform Play
 
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
 
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
Unsupervised Learning and Modeling of Knowledge and Intent for Spoken Dialogu...
 
Calendario Bibliotecas Universidad de Salamanca 2010
Calendario Bibliotecas Universidad de Salamanca 2010Calendario Bibliotecas Universidad de Salamanca 2010
Calendario Bibliotecas Universidad de Salamanca 2010
 
Savage, Savage, &amp; Brown, Inc
Savage, Savage, &amp; Brown, IncSavage, Savage, &amp; Brown, Inc
Savage, Savage, &amp; Brown, Inc
 
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
Louise Li - Gloucestershire Population Projections Using Locally Derived Popu...
 
Wcf Project Design 2012
Wcf Project Design 2012Wcf Project Design 2012
Wcf Project Design 2012
 
Nigel Swier ONS - Migration Statistics Improvement Work
Nigel Swier ONS - Migration Statistics Improvement WorkNigel Swier ONS - Migration Statistics Improvement Work
Nigel Swier ONS - Migration Statistics Improvement Work
 
Chua Cop Thai Lan
Chua Cop Thai LanChua Cop Thai Lan
Chua Cop Thai Lan
 
ว1306
ว1306ว1306
ว1306
 
Semantic-based Segmentation and Annotation of 3D Models
Semantic-based Segmentation and Annotation of 3D ModelsSemantic-based Segmentation and Annotation of 3D Models
Semantic-based Segmentation and Annotation of 3D Models
 
The War Years Notes 3
The War Years Notes 3The War Years Notes 3
The War Years Notes 3
 
Meet The Officers Fall 2009
Meet The Officers Fall 2009Meet The Officers Fall 2009
Meet The Officers Fall 2009
 
Ilona Ignatuhhina
Ilona IgnatuhhinaIlona Ignatuhhina
Ilona Ignatuhhina
 
Gurukul Training Initiative
Gurukul Training InitiativeGurukul Training Initiative
Gurukul Training Initiative
 
A 2 The Key Atomic Bomb Events of the Cold War, class 2, Fall 2011 and Spring...
A 2 The Key Atomic Bomb Events of the Cold War, class 2, Fall 2011 and Spring...A 2 The Key Atomic Bomb Events of the Cold War, class 2, Fall 2011 and Spring...
A 2 The Key Atomic Bomb Events of the Cold War, class 2, Fall 2011 and Spring...
 
11 439
11 43911 439
11 439
 

Semelhante a HungryFox - Firefox Extension Workshop

(Christian heilman) firefox
(Christian heilman) firefox(Christian heilman) firefox
(Christian heilman) firefox
NAVER D2
 

Semelhante a HungryFox - Firefox Extension Workshop (20)

Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Cape Cod Web Technology Meetup - 3
Cape Cod Web Technology Meetup - 3Cape Cod Web Technology Meetup - 3
Cape Cod Web Technology Meetup - 3
 
Getting started contributing Firefox OS
Getting started contributing Firefox OSGetting started contributing Firefox OS
Getting started contributing Firefox OS
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
So what's the Deal with Firefox OS - MobileTechCon Berlin 2014
So what's the Deal with Firefox OS - MobileTechCon Berlin 2014So what's the Deal with Firefox OS - MobileTechCon Berlin 2014
So what's the Deal with Firefox OS - MobileTechCon Berlin 2014
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers
BrowsersBrowsers
Browsers
 
Browsers by NGE
Browsers by NGEBrowsers by NGE
Browsers by NGE
 
Browsers
BrowsersBrowsers
Browsers
 
(Christian heilman) firefox
(Christian heilman) firefox(Christian heilman) firefox
(Christian heilman) firefox
 
browsers MEZH
browsers MEZHbrowsers MEZH
browsers MEZH
 
Foss Presentation
Foss PresentationFoss Presentation
Foss Presentation
 
Surfing of the internet
Surfing of the internetSurfing of the internet
Surfing of the internet
 
Web browsers
Web browsersWeb browsers
Web browsers
 

Último

Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Victor Rentea
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
panagenda
 

Último (20)

Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...Apidays New York 2024 - The value of a flexible API Management solution for O...
Apidays New York 2024 - The value of a flexible API Management solution for O...
 
MS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectorsMS Copilot expands with MS Graph connectors
MS Copilot expands with MS Graph connectors
 
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024Finding Java's Hidden Performance Traps @ DevoxxUK 2024
Finding Java's Hidden Performance Traps @ DevoxxUK 2024
 
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
Web Form Automation for Bonterra Impact Management (fka Social Solutions Apri...
 
ICT role in 21st century education and its challenges
ICT role in 21st century education and its challengesICT role in 21st century education and its challenges
ICT role in 21st century education and its challenges
 
Why Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire businessWhy Teams call analytics are critical to your entire business
Why Teams call analytics are critical to your entire business
 
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdfRising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
Rising Above_ Dubai Floods and the Fortitude of Dubai International Airport.pdf
 
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
Apidays New York 2024 - Accelerating FinTech Innovation by Vasa Krishnan, Fin...
 
CNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In PakistanCNIC Information System with Pakdata Cf In Pakistan
CNIC Information System with Pakdata Cf In Pakistan
 
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
Emergent Methods: Multi-lingual narrative tracking in the news - real-time ex...
 
MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024MINDCTI Revenue Release Quarter One 2024
MINDCTI Revenue Release Quarter One 2024
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
 
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWEREMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
EMPOWERMENT TECHNOLOGY GRADE 11 QUARTER 2 REVIEWER
 
AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024AXA XL - Insurer Innovation Award Americas 2024
AXA XL - Insurer Innovation Award Americas 2024
 
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
Apidays New York 2024 - The Good, the Bad and the Governed by David O'Neill, ...
 
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin WoodPolkadot JAM Slides - Token2049 - By Dr. Gavin Wood
Polkadot JAM Slides - Token2049 - By Dr. Gavin Wood
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 AmsterdamDEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
DEV meet-up UiPath Document Understanding May 7 2024 Amsterdam
 

HungryFox - Firefox Extension Workshop

  • 1. FIReFOX HARISHANKARAN Co-FOUNDER, INTERVIEWSTREET.COM
  • 4. HISTORY FORKED FROM THE MOZILLA SUITE SOFTWARE BLOAT OF MOZILLA SUITE (IRC, MAIL, NEWS, HTML EDITOR AND WHAT NOT) FF3, THE MOST DOWNLOADED SOFTWARE IN 24 HOURS (28,340,281 DOWNLOADS ON JUNE 17. BROWSER SHARE OF FIREFOX – 46% 4
  • 5. WHAT IS AN EXTENSION? A TYPE OF “ADD-ONS” EXTENSIONS PLUGINS THEMES EXTENSIONS EXTEND YOUR BROWSER SINGLE FEATURE (HIDE MENUBAR) FEATURE ENHANCEMENT (NOSCRIPT) WEB APP INTEGRATION (TWITTERFOX) NEW FEATURES (FIREBUG) 5
  • 6. EXTENSIONS 6,000 EXTENSIONS AND STILL COUNTING EXCELLENT API TO CREATE ANYTHING. EXTENSIONS ARE MADE BY GOOGLE, FACEBOOK, MICROSOFT, YAHOO AND NOW EVEN YOU. 6
  • 7. HELLO WORLD OUR FIRST EXTENSION. A MENU ITEM IN TOOL BAR ON CLICK, SHOWS A POPUP “HELLO WORLD” UPDATES STATUS BAR BY “YIPEE” 7
  • 8. 8
  • 9. 9
  • 11. XUL XML USER INTERFACE LANGUAGE CROSS PLATFORM INTERFACE ELEMENTS https://developer.mozilla.org/en/xul http://www.hevanet.com/acorbin/xul/top.xul <button label="Press Me" oncommand = "alert(Hola!');"/> 11
  • 12. XUL <menulist> <menupopup> <menuitem label="option 1" value="1"/> <menuitem label="option 2" value="2"/> <menuitem label="option 3" value="3"/> <menuitem label="option 4" value="4"/> </menupopup> </menulist> 12
  • 13. CSS IT’S TRUE! CSS IS USED TO MODIFY USER INTERFACE #hello-menuitem { color: red !important; } 13
  • 14. JAVASCRIPT IT’S TRUE… AGAIN! HANDLES COMMANDS IN THE INTERFACE XMLHTTPREQUEST, DOM. ALSO HAS ACCESS TO CORE API onMenuItemCommand: function(e) { document.getElementById('hello-panel').label = "Yippee"; alert("Hello World"); }, 14
  • 15. XPCOM Cross Platform Component Object Model The core or the “black box” of Firefox Similar to Microsoft’s COM or GNOME’s Corba or D-Bus A Cross-platform API 15
  • 16. SO… XPCOM IS THE “BRAIN” XUL IS THE “SKELETON” JAVASCRIPT IS THE “MUSCLE” CSS IS THE “SKIN” 16
  • 17. 17
  • 20. CONFUSING? TRUST ME IT’S NOT THAT HARD ;-) 20
  • 21. LET’S CREATE THE EXTENSION https://addons.mozilla.org/en-US/developers/tools/builder Add-on Name : Hello World Description : This is my first Firefox extension. Add-on Version : 1.0.0 Unique ID : http://extensions.roachfiend.com/cgi-bin/guid.pl Package Name : hello Authors-name : <Your-name> Other contributors: <Friend’s name> 21
  • 22.
  • 23. Main Menu CommandCreate My Add-on 22
  • 24. EDIT THE FILES Now we add features to this extension. Windows: C:ocuments and Settingsaripplication Dataozillairefoxrofiles GNU/Linux: .mozilla/firefox/ 23
  • 25. ff-overlay.xul <menupopup id="menu_ToolsPopup"> <menuitem id="hello-hello" label="Hello World" oncommand="hello.onMenuItemCommand(event);"/> </menupopup> 24
  • 26. ff-overlay.xul <statusbar id="status-bar"> <statusbarpanel id="hello-panel" label="" tooltiptext="" /> </statusbar> 25
  • 27. overlay.js onMenuItemCommand: function(e) { document.getElementById('hello-panel').label = "Yippee"; alert("Hello World"); } 26
  • 28. YOUR FIRST EXTENSION IS READY! 27
  • 29. A BETTER EXTENSION GET UPDATES FROM TWITTER SHOW THE LAST UPDATE 28
  • 30. HOW TO LEARN ALL THIS? 29
  • 33. THE END  hari@interviewstreet.com http://twitter.com/sp2hari 32