SlideShare a Scribd company logo
Browser Extensions
with Ember
@alexblom
alex@isleofcode.com
Isle of Code
• Toronto based development;
• Focused on Ember for:
• Prototyping;
• Hybrid Apps /w Cordova; and
• A lot of beacon work.
Extensions are easy
• Main concerns:
• Build Ember app
• Set root element;
• A bit of work to deal with AJAX requests in
Firefox;
• Write some JS to start & stop the Ember app;
Building Browser Extensions with Ember
App Structure
• /ember
• /extension
• /output
• /chrome
• /firefox
Building Browser Extensions with Ember
Building Browser Extensions with Ember
1 import Ember from 'ember';
2 import Resolver from 'ember/resolver';
3 import loadInitializers from 'ember/load-initializers';
4 import config from './config/environment';
5
6 Ember.MODEL_FACTORY_INJECTIONS = true;
7
8 var App = Ember.Application.extend({
9 modulePrefix: config.modulePrefix,
10 podModulePrefix: config.podModulePrefix,
11 Resolver: Resolver,
12 rootElement: '#morsebar-content'
13 });
14
15 loadInitializers(App, config.modulePrefix);
16
17 export default App;
• Need to import your css again;
• Namespace your css;
• Probably want webRequest;
• In general, best to have light JS that will inject
your Ember app on user prompt;
locationType: none;
storeConfigInMeta: false;
Firefox: self is
reserved
Firefox: runs in strict
mode
Firefox: Can not run
AJAX requests
Building Browser Extensions with Ember
Building Browser Extensions with Ember
Building Browser Extensions with Ember
Manage Reflows
What causes Reflow?
• Resizing the browser window;
• using JavaScript methods involving computed
styles;
• adding or removing elements from the DOM; and
• changing an element's classes.
• https://developers.google.com/speed/articles/reflo
w
Use CSS Transforms
visibility:hidden
Browser Extensions
with Ember
@alexblom
alex@isleofcode.com

More Related Content

PPTX
Phonegap Day 2016: Ember/JS & Hybrid Apps Tips
PPTX
Ember Conf 2016: Building Mobile Apps with Ember
PDF
Cordova 3.x
PPTX
Web Unleashed Toronto 2015: Hybrid Mobile Apps with Ember.js
PPTX
React Native - Unleash the power of React in your device - Eduard Tomàs - Cod...
PDF
Isomorphic web application
PDF
Ember Overview in 5 Minutes
Phonegap Day 2016: Ember/JS & Hybrid Apps Tips
Ember Conf 2016: Building Mobile Apps with Ember
Cordova 3.x
Web Unleashed Toronto 2015: Hybrid Mobile Apps with Ember.js
React Native - Unleash the power of React in your device - Eduard Tomàs - Cod...
Isomorphic web application
Ember Overview in 5 Minutes

What's hot (20)

PPTX
Hybrid Mobile App Development - Xamarin
PDF
Workshop Ionic Framework - CC FE & UX
PDF
Introduction to React Native & Rendering Charts / Graphs
PDF
Ionic framework one day training
PDF
An iOS Developer's Perspective on React Native
PPTX
Desktop Apps in a Javascript World - Electron
PDF
Get that Corner Office with Angular 2 and Electron
PDF
A Debugging Adventure: Journey through Ember.js Glue
PDF
React Native in a nutshell
PDF
Experiences building apps with React Native @UtrechtJS May 2016
PPTX
Lessons Learned From Applications That Kicked Titanium's Ass
PDF
When to (use / not use) React Native.
PDF
Intro to react native
PPTX
You are not_hiding_from_me_.net
PPTX
SharePoint Saturday Twin Cities - SharePoint Framework, Angular & Azure Funct...
PPTX
PPTX
SharePoint Fest DC - SharePoint Framework, Angular and Azure Functions
PPTX
React Native - Why Designers should use React native. And everyone else too.
PDF
MEAN Stack Warm-up
PDF
Introduction to React Native & Redux
Hybrid Mobile App Development - Xamarin
Workshop Ionic Framework - CC FE & UX
Introduction to React Native & Rendering Charts / Graphs
Ionic framework one day training
An iOS Developer's Perspective on React Native
Desktop Apps in a Javascript World - Electron
Get that Corner Office with Angular 2 and Electron
A Debugging Adventure: Journey through Ember.js Glue
React Native in a nutshell
Experiences building apps with React Native @UtrechtJS May 2016
Lessons Learned From Applications That Kicked Titanium's Ass
When to (use / not use) React Native.
Intro to react native
You are not_hiding_from_me_.net
SharePoint Saturday Twin Cities - SharePoint Framework, Angular & Azure Funct...
SharePoint Fest DC - SharePoint Framework, Angular and Azure Functions
React Native - Why Designers should use React native. And everyone else too.
MEAN Stack Warm-up
Introduction to React Native & Redux
Ad

Similar to Building Browser Extensions with Ember (20)

PDF
Webapi
PDF
[2015/2016] Apache Cordova
PPTX
Telerik AppBuilder Presentation for TelerikNEXT Conference
PDF
Intro to PhoneGap
PPTX
Cross Platform Mobile App Development
PDF
Introduction to PhoneGap
PPTX
[Devoxx Morocco 2015] Apache Cordova In Action
PPTX
Phoenix 1.3 Umbrella App deployment via Distillery-Docker-Docker_Compose
PDF
Web, Native iOS and Native Android with One Ember.js App
PPTX
PDF
Apache Cordova 4.x
PPTX
1 app 2 developers 3 servers
PDF
Building websites with Node.ACS
PDF
Building websites with Node.ACS
PDF
Locally it worked! virtualizing docker
PPTX
Workshop on Hybrid App Development with Ionic Framework
PDF
Cordova Tutorial
PPTX
Oracle APEX & PhoneGap
PDF
MongoDB World 2018: Tutorial - Got Dibs? Building a Real-Time Bidding App wit...
PPTX
PhoneGap Day EU 2017: Hybrid Ember Apps
Webapi
[2015/2016] Apache Cordova
Telerik AppBuilder Presentation for TelerikNEXT Conference
Intro to PhoneGap
Cross Platform Mobile App Development
Introduction to PhoneGap
[Devoxx Morocco 2015] Apache Cordova In Action
Phoenix 1.3 Umbrella App deployment via Distillery-Docker-Docker_Compose
Web, Native iOS and Native Android with One Ember.js App
Apache Cordova 4.x
1 app 2 developers 3 servers
Building websites with Node.ACS
Building websites with Node.ACS
Locally it worked! virtualizing docker
Workshop on Hybrid App Development with Ionic Framework
Cordova Tutorial
Oracle APEX & PhoneGap
MongoDB World 2018: Tutorial - Got Dibs? Building a Real-Time Bidding App wit...
PhoneGap Day EU 2017: Hybrid Ember Apps
Ad

More from Alex Blom (7)

PPTX
PG Day Us: Animations for Web & Hybrid
PPTX
Browser Internals for JS Devs: WebU Toronto 2016 by Alex Blom
PPTX
Build email apps with morse.io
PPT
Innovation Growth Strategies for Small Business
PDF
Freelance Camp Toronto: How to sell to Enterprise by Dr Cindy Gordon
PPTX
Freelance Camp Toronto: Social is not new and the 7 biggest social mistakes
PPTX
Ryerson 6th August
PG Day Us: Animations for Web & Hybrid
Browser Internals for JS Devs: WebU Toronto 2016 by Alex Blom
Build email apps with morse.io
Innovation Growth Strategies for Small Business
Freelance Camp Toronto: How to sell to Enterprise by Dr Cindy Gordon
Freelance Camp Toronto: Social is not new and the 7 biggest social mistakes
Ryerson 6th August

Recently uploaded (20)

DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
sap open course for s4hana steps from ECC to s4
PDF
Encapsulation theory and applications.pdf
PPTX
Cloud computing and distributed systems.
PPTX
Spectroscopy.pptx food analysis technology
PDF
gpt5_lecture_notes_comprehensive_20250812015547.pdf
PPTX
Machine Learning_overview_presentation.pptx
PDF
Spectral efficient network and resource selection model in 5G networks
PDF
cuic standard and advanced reporting.pdf
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
Encapsulation_ Review paper, used for researhc scholars
PDF
Approach and Philosophy of On baking technology
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
NewMind AI Weekly Chronicles - August'25-Week II
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PPTX
Programs and apps: productivity, graphics, security and other tools
PPTX
A Presentation on Artificial Intelligence
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PPT
Teaching material agriculture food technology
The AUB Centre for AI in Media Proposal.docx
sap open course for s4hana steps from ECC to s4
Encapsulation theory and applications.pdf
Cloud computing and distributed systems.
Spectroscopy.pptx food analysis technology
gpt5_lecture_notes_comprehensive_20250812015547.pdf
Machine Learning_overview_presentation.pptx
Spectral efficient network and resource selection model in 5G networks
cuic standard and advanced reporting.pdf
Mobile App Security Testing_ A Comprehensive Guide.pdf
Encapsulation_ Review paper, used for researhc scholars
Approach and Philosophy of On baking technology
“AI and Expert System Decision Support & Business Intelligence Systems”
NewMind AI Weekly Chronicles - August'25-Week II
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Programs and apps: productivity, graphics, security and other tools
A Presentation on Artificial Intelligence
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
Teaching material agriculture food technology

Building Browser Extensions with Ember