SlideShare une entreprise Scribd logo
1  sur  14
Chrome/Chromium extension development Presenter: 	Adam Horvath 	(adam@teamleadnet.com) 1 Adam Horvath September 27, 2011 - Sydney
What is a Chrome extension? Chrome policy: only add features that everyone will use Extra functionality added to pages or generally, to the browser Usually written using standard ‘web technologies’ Javascript HTML CSS JSON/XML data Special ZIP package with header information 2 Adam Horvath September 27, 2011 - Sydney
Why is it interesting? Business cases Add extra/new functionality to legacy systems Translate  (localise) an existing web UI Provide custom UI for third party services Learn proper/sustainable (Java)script programming Increasing your ‘brand awareness’ However: unlikely to sell from the store! 3 Adam Horvath September 27, 2011 - Sydney
Types of extensions Browser action (for every webpage) Page action (based/filtered on the URL) Override pages (Bookmark manager, History, New tab) Omnibox helpers (custom search function) NPAPI native code (Netscape Plugin Application Programming Interface) (Themes) 4 Adam Horvath September 27, 2011 - Sydney
Supporting pages/objects Background page (always running) Options page (opened when necessary) Popup page (for browser actions) Content (scripts, css, ...) Desktop notification 5 Adam Horvath September 27, 2011 - Sydney
6 Adam Horvath September 27, 2011 - Sydney
Messaging / storage Isolated world – One page, multiple extensions, no collision Almost all of the APIs are async Async communication between processes Send messages between extension/background pages Cross domain XMLHttpRequest / External services Storage (localStorage, 5Mb) 7 Adam Horvath September 27, 2011 - Sydney
Browser interaction Need to ask for permissions before installing Chrome.* namespace can access Bookmarks Cookies Events History Management Tabs Windows APIs are never removed after making their way into Stable branch 8 Adam Horvath September 27, 2011 - Sydney
Hosting / publishing Manifest JSON description or the extension Chrome web store (easy autoupdate) Free to host Connects with Google Analytics Can upload sample screenshots/YouTube video Custom location (Autoupdate possible) 9 Adam Horvath September 27, 2011 - Sydney
How to develop Need a good toolset Netbeans, Closure compiler, SED, batch job Crafting by small modules, iteratively Create sample page with sample Javascript Test, fix Merge into extension Testing (unpacked, compiled + packed) Debugging Do not rely on debugging, although Chrome is a good debugger Embedding images in CSS (base64) 10 Adam Horvath September 27, 2011 - Sydney
Demo 11 Adam Horvath September 27, 2011 - Sydney
Final thoughts Platform problems Users might randomly report ‘Does not work for me’ Psychology of voting Hard to change the vote average after just a few votes Votes are dependent on the type of audience Localisation Not covered here, but extensions can support many languages 12 Adam Horvath September 27, 2011 - Sydney
URLs This presentationhttp://slidesha.re/chromeextension efTwo (F2) Advanced Find on Pagehttp://bit.ly/eftwochrome Chrome Extensions Getting Started http://code.google.com/chrome/extensions Closure compilerhttp://code.google.com/closure/compiler/ Image/CSS converterhttp://webcodertools.com/imagetobase64converter encoded = urllib.parse.quote( base64.b64encode(open(filename, "rb").read()) ) Netbeanshttp://netbeans.org/downloads/ GNU Win32 (sed)http://sourceforge.net/projects/gnuwin32 13 Adam Horvath September 27, 2011 - Sydney
Questions 14 Adam Horvath Adam Horvath  (adam@teamleadnet.com) September 27, 2011 - Sydney

Contenu connexe

Tendances

Google chrome extension
Google chrome extensionGoogle chrome extension
Google chrome extensionJohnny Kingdom
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09mihaiionescu
 
Introduction of chrome extension development
Introduction of chrome extension developmentIntroduction of chrome extension development
Introduction of chrome extension developmentBalduran Chang
 
Introduction to chrome extension development
Introduction to chrome extension developmentIntroduction to chrome extension development
Introduction to chrome extension developmentKAI CHU CHUNG
 
Making Chrome Extension with AngularJS
Making Chrome Extension with AngularJSMaking Chrome Extension with AngularJS
Making Chrome Extension with AngularJSBen Lau
 
Orange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox ExtensionOrange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox Extensionchaykaborya
 
Effective TDD - Less is more
Effective TDD - Less is moreEffective TDD - Less is more
Effective TDD - Less is moreBen Lau
 
Creating chrome-extension
Creating chrome-extensionCreating chrome-extension
Creating chrome-extensionAkshay Khale
 
Dive Into Chrome-100119
Dive Into Chrome-100119Dive Into Chrome-100119
Dive Into Chrome-100119yiming he
 
Using disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themesUsing disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themescodebangla
 
WordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10nWordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10ncodebangla
 
Basic Introduction to Web Development
Basic Introduction to Web DevelopmentBasic Introduction to Web Development
Basic Introduction to Web DevelopmentBurhan Khalid
 
Introduction to web development
Introduction to web developmentIntroduction to web development
Introduction to web developmentAlberto Apellidos
 
Leksion 1 hyrje ne xhtml
Leksion 1   hyrje ne xhtmlLeksion 1   hyrje ne xhtml
Leksion 1 hyrje ne xhtmlmariokenga
 
Chapter 1
Chapter 1Chapter 1
Chapter 1Uma Sam
 
WEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web DevelopmentWEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web DevelopmentRandy Connolly
 
Basic Wordpress PPT
Basic Wordpress PPT Basic Wordpress PPT
Basic Wordpress PPT mayur akabari
 

Tendances (20)

Google chrome extension
Google chrome extensionGoogle chrome extension
Google chrome extension
 
HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09HTML5 and Google Chrome - DevFest09
HTML5 and Google Chrome - DevFest09
 
Introduction of chrome extension development
Introduction of chrome extension developmentIntroduction of chrome extension development
Introduction of chrome extension development
 
Introduction to chrome extension development
Introduction to chrome extension developmentIntroduction to chrome extension development
Introduction to chrome extension development
 
Making Chrome Extension with AngularJS
Making Chrome Extension with AngularJSMaking Chrome Extension with AngularJS
Making Chrome Extension with AngularJS
 
Orange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox ExtensionOrange is the new blue: How to port Chrome Extension to Firefox Extension
Orange is the new blue: How to port Chrome Extension to Firefox Extension
 
Effective TDD - Less is more
Effective TDD - Less is moreEffective TDD - Less is more
Effective TDD - Less is more
 
Develop Chrome Extension
Develop Chrome ExtensionDevelop Chrome Extension
Develop Chrome Extension
 
Creating chrome-extension
Creating chrome-extensionCreating chrome-extension
Creating chrome-extension
 
Chrome Extension
Chrome ExtensionChrome Extension
Chrome Extension
 
Dive Into Chrome-100119
Dive Into Chrome-100119Dive Into Chrome-100119
Dive Into Chrome-100119
 
Browser extension
Browser extensionBrowser extension
Browser extension
 
Using disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themesUsing disqus & facebook comment in wordpress themes
Using disqus & facebook comment in wordpress themes
 
WordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10nWordPress Theme & Plugin i18n & L10n
WordPress Theme & Plugin i18n & L10n
 
Basic Introduction to Web Development
Basic Introduction to Web DevelopmentBasic Introduction to Web Development
Basic Introduction to Web Development
 
Introduction to web development
Introduction to web developmentIntroduction to web development
Introduction to web development
 
Leksion 1 hyrje ne xhtml
Leksion 1   hyrje ne xhtmlLeksion 1   hyrje ne xhtml
Leksion 1 hyrje ne xhtml
 
Chapter 1
Chapter 1Chapter 1
Chapter 1
 
WEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web DevelopmentWEB I - 01 - Introduction to Web Development
WEB I - 01 - Introduction to Web Development
 
Basic Wordpress PPT
Basic Wordpress PPT Basic Wordpress PPT
Basic Wordpress PPT
 

En vedette

Uas pembelajaran matematika
Uas pembelajaran matematikaUas pembelajaran matematika
Uas pembelajaran matematikaChamida Ni'mah
 
Self hosted server applications - Adam Horvath
Self hosted server applications - Adam HorvathSelf hosted server applications - Adam Horvath
Self hosted server applications - Adam Horvathadamhorvath
 
1475243 634781082078971250
1475243 6347810820789712501475243 634781082078971250
1475243 634781082078971250Akshaya_J
 
Hfov presentation (abdul fattah)
Hfov  presentation (abdul fattah) Hfov  presentation (abdul fattah)
Hfov presentation (abdul fattah) Abdul Fatah Abro
 
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...adamhorvath
 
Volutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahVolutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahAbdul Fatah Abro
 
Neonatal assisted ventilation
Neonatal assisted ventilation   Neonatal assisted ventilation
Neonatal assisted ventilation Abdul Fatah Abro
 

En vedette (14)

Powerful presentation
Powerful presentationPowerful presentation
Powerful presentation
 
Uas pembelajaran matematika
Uas pembelajaran matematikaUas pembelajaran matematika
Uas pembelajaran matematika
 
Self hosted server applications - Adam Horvath
Self hosted server applications - Adam HorvathSelf hosted server applications - Adam Horvath
Self hosted server applications - Adam Horvath
 
1475243 634781082078971250
1475243 6347810820789712501475243 634781082078971250
1475243 634781082078971250
 
Picc line by abdul fatah
Picc line by abdul fatahPicc line by abdul fatah
Picc line by abdul fatah
 
Hfov presentation (abdul fattah)
Hfov  presentation (abdul fattah) Hfov  presentation (abdul fattah)
Hfov presentation (abdul fattah)
 
Respiratory acidosis
Respiratory acidosisRespiratory acidosis
Respiratory acidosis
 
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...MapReduce frameworks and methods  - Adam Horvath, Google Technology User Grou...
MapReduce frameworks and methods - Adam Horvath, Google Technology User Grou...
 
Volutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatahVolutrauma presentation Abdul fatah
Volutrauma presentation Abdul fatah
 
Neonatal physiology
Neonatal  physiologyNeonatal  physiology
Neonatal physiology
 
Neonatal assisted ventilation
Neonatal assisted ventilation   Neonatal assisted ventilation
Neonatal assisted ventilation
 
American Industrial Revolution
American Industrial RevolutionAmerican Industrial Revolution
American Industrial Revolution
 
Mattel ppt
Mattel pptMattel ppt
Mattel ppt
 
PGE tube
PGE tube PGE tube
PGE tube
 

Similaire à Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney

Creating Your Own Static Website Generator
Creating Your Own Static Website GeneratorCreating Your Own Static Website Generator
Creating Your Own Static Website GeneratorSean O'Mahoney
 
HTML5 Technical Executive Summary
HTML5 Technical Executive SummaryHTML5 Technical Executive Summary
HTML5 Technical Executive SummaryGilad Khen
 
Building the next generation of browser apps today
Building the next generation of browser apps todayBuilding the next generation of browser apps today
Building the next generation of browser apps todayRandy Williams
 
Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017Imran Qasim
 
HTML5 and the Open Web Platform
HTML5 and the Open Web PlatformHTML5 and the Open Web Platform
HTML5 and the Open Web PlatformBeat Signer
 
Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017LumoLink
 
Western web work Jan 25, 2013
Western web work Jan 25, 2013Western web work Jan 25, 2013
Western web work Jan 25, 2013Marie Toler Raney
 
Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium Peyman Fakharian
 
Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Nabil Babaci
 
Developing for Windows Phone 7
Developing for Windows Phone 7Developing for Windows Phone 7
Developing for Windows Phone 7Gergely Orosz
 
Mix Tech Ed Update No Video
Mix Tech Ed Update No VideoMix Tech Ed Update No Video
Mix Tech Ed Update No VideoAllyWick
 
How websites and search engines work
How websites and search engines workHow websites and search engines work
How websites and search engines workBrian Duffy
 
A Microsoft primer for PHP devs
A Microsoft primer for PHP devsA Microsoft primer for PHP devs
A Microsoft primer for PHP devsguest0a62e8
 
Getting Started with SharePoint Branding
Getting Started with SharePoint BrandingGetting Started with SharePoint Branding
Getting Started with SharePoint BrandingThomas Daly
 
SPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point brandingSPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point brandingThomas Daly
 
Angular jS Introduction by Google
Angular jS Introduction by GoogleAngular jS Introduction by Google
Angular jS Introduction by GoogleASG
 

Similaire à Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney (20)

Creating Your Own Static Website Generator
Creating Your Own Static Website GeneratorCreating Your Own Static Website Generator
Creating Your Own Static Website Generator
 
Ui development frameworks html-bootstrap by awa
Ui development frameworks html-bootstrap by awaUi development frameworks html-bootstrap by awa
Ui development frameworks html-bootstrap by awa
 
HTML5 Technical Executive Summary
HTML5 Technical Executive SummaryHTML5 Technical Executive Summary
HTML5 Technical Executive Summary
 
Building the next generation of browser apps today
Building the next generation of browser apps todayBuilding the next generation of browser apps today
Building the next generation of browser apps today
 
Ie9 overview
Ie9 overviewIe9 overview
Ie9 overview
 
Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017Become a Successful Web Developer in Web development Field in 2017
Become a Successful Web Developer in Web development Field in 2017
 
HTML5 and the Open Web Platform
HTML5 and the Open Web PlatformHTML5 and the Open Web Platform
HTML5 and the Open Web Platform
 
Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017Going Back to Static HTML Sites - SEMPRO 2017
Going Back to Static HTML Sites - SEMPRO 2017
 
Western web work Jan 25, 2013
Western web work Jan 25, 2013Western web work Jan 25, 2013
Western web work Jan 25, 2013
 
Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium Web UI Tests: Introduce UI tests using Selenium
Web UI Tests: Introduce UI tests using Selenium
 
Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013Branding Effort under SharePoint 2013
Branding Effort under SharePoint 2013
 
Developing for Windows Phone 7
Developing for Windows Phone 7Developing for Windows Phone 7
Developing for Windows Phone 7
 
Wordpress as a CMS
Wordpress as a CMSWordpress as a CMS
Wordpress as a CMS
 
Mix Tech Ed Update No Video
Mix Tech Ed Update No VideoMix Tech Ed Update No Video
Mix Tech Ed Update No Video
 
Lecture 6 Data Driven Design
Lecture 6  Data Driven DesignLecture 6  Data Driven Design
Lecture 6 Data Driven Design
 
How websites and search engines work
How websites and search engines workHow websites and search engines work
How websites and search engines work
 
A Microsoft primer for PHP devs
A Microsoft primer for PHP devsA Microsoft primer for PHP devs
A Microsoft primer for PHP devs
 
Getting Started with SharePoint Branding
Getting Started with SharePoint BrandingGetting Started with SharePoint Branding
Getting Started with SharePoint Branding
 
SPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point brandingSPSVB 1 7-2012 - getting started with share point branding
SPSVB 1 7-2012 - getting started with share point branding
 
Angular jS Introduction by Google
Angular jS Introduction by GoogleAngular jS Introduction by Google
Angular jS Introduction by Google
 

Dernier

Neurulation and the formation of the neural tube
Neurulation and the formation of the neural tubeNeurulation and the formation of the neural tube
Neurulation and the formation of the neural tubeSaadHumayun7
 
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdf
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdfDanh sách HSG Bộ môn cấp trường - Cấp THPT.pdf
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdfQucHHunhnh
 
philosophy and it's principles based on the life
philosophy and it's principles based on the lifephilosophy and it's principles based on the life
philosophy and it's principles based on the lifeNitinDeodare
 
The Benefits and Challenges of Open Educational Resources
The Benefits and Challenges of Open Educational ResourcesThe Benefits and Challenges of Open Educational Resources
The Benefits and Challenges of Open Educational Resourcesaileywriter
 
2024_Student Session 2_ Set Plan Preparation.pptx
2024_Student Session 2_ Set Plan Preparation.pptx2024_Student Session 2_ Set Plan Preparation.pptx
2024_Student Session 2_ Set Plan Preparation.pptxmansk2
 
How to the fix Attribute Error in odoo 17
How to the fix Attribute Error in odoo 17How to the fix Attribute Error in odoo 17
How to the fix Attribute Error in odoo 17Celine George
 
Mbaye_Astou.Education Civica_Human Rights.pptx
Mbaye_Astou.Education Civica_Human Rights.pptxMbaye_Astou.Education Civica_Human Rights.pptx
Mbaye_Astou.Education Civica_Human Rights.pptxnuriaiuzzolino1
 
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17Celine George
 
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45MysoreMuleSoftMeetup
 
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文中 央社
 
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdf
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdfTelling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdf
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdfTechSoup
 
slides CapTechTalks Webinar May 2024 Alexander Perry.pptx
slides CapTechTalks Webinar May 2024 Alexander Perry.pptxslides CapTechTalks Webinar May 2024 Alexander Perry.pptx
slides CapTechTalks Webinar May 2024 Alexander Perry.pptxCapitolTechU
 
Morse OER Some Benefits and Challenges.pptx
Morse OER Some Benefits and Challenges.pptxMorse OER Some Benefits and Challenges.pptx
Morse OER Some Benefits and Challenges.pptxjmorse8
 
IATP How-to Foreign Travel May 2024.pdff
IATP How-to Foreign Travel May 2024.pdffIATP How-to Foreign Travel May 2024.pdff
IATP How-to Foreign Travel May 2024.pdff17thcssbs2
 
....................Muslim-Law notes.pdf
....................Muslim-Law notes.pdf....................Muslim-Law notes.pdf
....................Muslim-Law notes.pdfVikramadityaRaj
 
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17Celine George
 
Open Educational Resources Primer PowerPoint
Open Educational Resources Primer PowerPointOpen Educational Resources Primer PowerPoint
Open Educational Resources Primer PowerPointELaRue0
 
REPRODUCTIVE TOXICITY STUDIE OF MALE AND FEMALEpptx
REPRODUCTIVE TOXICITY  STUDIE OF MALE AND FEMALEpptxREPRODUCTIVE TOXICITY  STUDIE OF MALE AND FEMALEpptx
REPRODUCTIVE TOXICITY STUDIE OF MALE AND FEMALEpptxmanishaJyala2
 

Dernier (20)

Neurulation and the formation of the neural tube
Neurulation and the formation of the neural tubeNeurulation and the formation of the neural tube
Neurulation and the formation of the neural tube
 
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdf
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdfDanh sách HSG Bộ môn cấp trường - Cấp THPT.pdf
Danh sách HSG Bộ môn cấp trường - Cấp THPT.pdf
 
philosophy and it's principles based on the life
philosophy and it's principles based on the lifephilosophy and it's principles based on the life
philosophy and it's principles based on the life
 
“O BEIJO” EM ARTE .
“O BEIJO” EM ARTE                       .“O BEIJO” EM ARTE                       .
“O BEIJO” EM ARTE .
 
The Benefits and Challenges of Open Educational Resources
The Benefits and Challenges of Open Educational ResourcesThe Benefits and Challenges of Open Educational Resources
The Benefits and Challenges of Open Educational Resources
 
2024_Student Session 2_ Set Plan Preparation.pptx
2024_Student Session 2_ Set Plan Preparation.pptx2024_Student Session 2_ Set Plan Preparation.pptx
2024_Student Session 2_ Set Plan Preparation.pptx
 
How to the fix Attribute Error in odoo 17
How to the fix Attribute Error in odoo 17How to the fix Attribute Error in odoo 17
How to the fix Attribute Error in odoo 17
 
Operations Management - Book1.p - Dr. Abdulfatah A. Salem
Operations Management - Book1.p  - Dr. Abdulfatah A. SalemOperations Management - Book1.p  - Dr. Abdulfatah A. Salem
Operations Management - Book1.p - Dr. Abdulfatah A. Salem
 
Mbaye_Astou.Education Civica_Human Rights.pptx
Mbaye_Astou.Education Civica_Human Rights.pptxMbaye_Astou.Education Civica_Human Rights.pptx
Mbaye_Astou.Education Civica_Human Rights.pptx
 
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17
Removal Strategy _ FEFO _ Working with Perishable Products in Odoo 17
 
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45
Exploring Gemini AI and Integration with MuleSoft | MuleSoft Mysore Meetup #45
 
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文
會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文會考英文
 
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdf
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdfTelling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdf
Telling Your Story_ Simple Steps to Build Your Nonprofit's Brand Webinar.pdf
 
slides CapTechTalks Webinar May 2024 Alexander Perry.pptx
slides CapTechTalks Webinar May 2024 Alexander Perry.pptxslides CapTechTalks Webinar May 2024 Alexander Perry.pptx
slides CapTechTalks Webinar May 2024 Alexander Perry.pptx
 
Morse OER Some Benefits and Challenges.pptx
Morse OER Some Benefits and Challenges.pptxMorse OER Some Benefits and Challenges.pptx
Morse OER Some Benefits and Challenges.pptx
 
IATP How-to Foreign Travel May 2024.pdff
IATP How-to Foreign Travel May 2024.pdffIATP How-to Foreign Travel May 2024.pdff
IATP How-to Foreign Travel May 2024.pdff
 
....................Muslim-Law notes.pdf
....................Muslim-Law notes.pdf....................Muslim-Law notes.pdf
....................Muslim-Law notes.pdf
 
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17
Incoming and Outgoing Shipments in 2 STEPS Using Odoo 17
 
Open Educational Resources Primer PowerPoint
Open Educational Resources Primer PowerPointOpen Educational Resources Primer PowerPoint
Open Educational Resources Primer PowerPoint
 
REPRODUCTIVE TOXICITY STUDIE OF MALE AND FEMALEpptx
REPRODUCTIVE TOXICITY  STUDIE OF MALE AND FEMALEpptxREPRODUCTIVE TOXICITY  STUDIE OF MALE AND FEMALEpptx
REPRODUCTIVE TOXICITY STUDIE OF MALE AND FEMALEpptx
 

Chrome Extension Development - Adam Horvath, Google Technology User Group, Sydney

  • 1. Chrome/Chromium extension development Presenter: Adam Horvath (adam@teamleadnet.com) 1 Adam Horvath September 27, 2011 - Sydney
  • 2. What is a Chrome extension? Chrome policy: only add features that everyone will use Extra functionality added to pages or generally, to the browser Usually written using standard ‘web technologies’ Javascript HTML CSS JSON/XML data Special ZIP package with header information 2 Adam Horvath September 27, 2011 - Sydney
  • 3. Why is it interesting? Business cases Add extra/new functionality to legacy systems Translate (localise) an existing web UI Provide custom UI for third party services Learn proper/sustainable (Java)script programming Increasing your ‘brand awareness’ However: unlikely to sell from the store! 3 Adam Horvath September 27, 2011 - Sydney
  • 4. Types of extensions Browser action (for every webpage) Page action (based/filtered on the URL) Override pages (Bookmark manager, History, New tab) Omnibox helpers (custom search function) NPAPI native code (Netscape Plugin Application Programming Interface) (Themes) 4 Adam Horvath September 27, 2011 - Sydney
  • 5. Supporting pages/objects Background page (always running) Options page (opened when necessary) Popup page (for browser actions) Content (scripts, css, ...) Desktop notification 5 Adam Horvath September 27, 2011 - Sydney
  • 6. 6 Adam Horvath September 27, 2011 - Sydney
  • 7. Messaging / storage Isolated world – One page, multiple extensions, no collision Almost all of the APIs are async Async communication between processes Send messages between extension/background pages Cross domain XMLHttpRequest / External services Storage (localStorage, 5Mb) 7 Adam Horvath September 27, 2011 - Sydney
  • 8. Browser interaction Need to ask for permissions before installing Chrome.* namespace can access Bookmarks Cookies Events History Management Tabs Windows APIs are never removed after making their way into Stable branch 8 Adam Horvath September 27, 2011 - Sydney
  • 9. Hosting / publishing Manifest JSON description or the extension Chrome web store (easy autoupdate) Free to host Connects with Google Analytics Can upload sample screenshots/YouTube video Custom location (Autoupdate possible) 9 Adam Horvath September 27, 2011 - Sydney
  • 10. How to develop Need a good toolset Netbeans, Closure compiler, SED, batch job Crafting by small modules, iteratively Create sample page with sample Javascript Test, fix Merge into extension Testing (unpacked, compiled + packed) Debugging Do not rely on debugging, although Chrome is a good debugger Embedding images in CSS (base64) 10 Adam Horvath September 27, 2011 - Sydney
  • 11. Demo 11 Adam Horvath September 27, 2011 - Sydney
  • 12. Final thoughts Platform problems Users might randomly report ‘Does not work for me’ Psychology of voting Hard to change the vote average after just a few votes Votes are dependent on the type of audience Localisation Not covered here, but extensions can support many languages 12 Adam Horvath September 27, 2011 - Sydney
  • 13. URLs This presentationhttp://slidesha.re/chromeextension efTwo (F2) Advanced Find on Pagehttp://bit.ly/eftwochrome Chrome Extensions Getting Started http://code.google.com/chrome/extensions Closure compilerhttp://code.google.com/closure/compiler/ Image/CSS converterhttp://webcodertools.com/imagetobase64converter encoded = urllib.parse.quote( base64.b64encode(open(filename, "rb").read()) ) Netbeanshttp://netbeans.org/downloads/ GNU Win32 (sed)http://sourceforge.net/projects/gnuwin32 13 Adam Horvath September 27, 2011 - Sydney
  • 14. Questions 14 Adam Horvath Adam Horvath (adam@teamleadnet.com) September 27, 2011 - Sydney