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

What's hot (20)

PPTX
Hybrid Mobile App Development - Xamarin
Deepu S Nath
 
PDF
Workshop Ionic Framework - CC FE & UX
JWORKS powered by Ordina
 
PDF
Introduction to React Native & Rendering Charts / Graphs
Rahat Khanna a.k.a mAppMechanic
 
PDF
Ionic framework one day training
Troy Miles
 
PDF
An iOS Developer's Perspective on React Native
Aleksandras Smirnovas
 
PPTX
Desktop Apps in a Javascript World - Electron
Marc MacLeod
 
PDF
Get that Corner Office with Angular 2 and Electron
Lukas Ruebbelke
 
PDF
A Debugging Adventure: Journey through Ember.js Glue
Mike North
 
PDF
React Native in a nutshell
Brainhub
 
PDF
Experiences building apps with React Native @UtrechtJS May 2016
Adrian Philipp
 
PPTX
Lessons Learned From Applications That Kicked Titanium's Ass
Kevin Whinnery
 
PDF
When to (use / not use) React Native.
Bobby Schultz
 
PDF
Intro to react native
ModusJesus
 
PPTX
You are not_hiding_from_me_.net
Chung Wee Jing
 
PPTX
SharePoint Saturday Twin Cities - SharePoint Framework, Angular & Azure Funct...
Sébastien Levert
 
PPTX
React Native
Software Infrastructure
 
PPTX
SharePoint Fest DC - SharePoint Framework, Angular and Azure Functions
Sébastien Levert
 
PPTX
React Native - Why Designers should use React native. And everyone else too.
Val Scholz
 
PDF
MEAN Stack Warm-up
Troy Miles
 
PDF
Introduction to React Native & Redux
Barak Cohen
 
Hybrid Mobile App Development - Xamarin
Deepu S Nath
 
Workshop Ionic Framework - CC FE & UX
JWORKS powered by Ordina
 
Introduction to React Native & Rendering Charts / Graphs
Rahat Khanna a.k.a mAppMechanic
 
Ionic framework one day training
Troy Miles
 
An iOS Developer's Perspective on React Native
Aleksandras Smirnovas
 
Desktop Apps in a Javascript World - Electron
Marc MacLeod
 
Get that Corner Office with Angular 2 and Electron
Lukas Ruebbelke
 
A Debugging Adventure: Journey through Ember.js Glue
Mike North
 
React Native in a nutshell
Brainhub
 
Experiences building apps with React Native @UtrechtJS May 2016
Adrian Philipp
 
Lessons Learned From Applications That Kicked Titanium's Ass
Kevin Whinnery
 
When to (use / not use) React Native.
Bobby Schultz
 
Intro to react native
ModusJesus
 
You are not_hiding_from_me_.net
Chung Wee Jing
 
SharePoint Saturday Twin Cities - SharePoint Framework, Angular & Azure Funct...
Sébastien Levert
 
SharePoint Fest DC - SharePoint Framework, Angular and Azure Functions
Sébastien Levert
 
React Native - Why Designers should use React native. And everyone else too.
Val Scholz
 
MEAN Stack Warm-up
Troy Miles
 
Introduction to React Native & Redux
Barak Cohen
 

Similar to Building Browser Extensions with Ember (20)

PDF
Workshop 16: EmberJS Parte I
Visual Engineering
 
PDF
Developing Single Page Apps with Ember.js
Leo Hernandez
 
PPTX
Node.js meetup 17.05.2017 ember.js - escape the javascript fatigue
Tobias Braner
 
PPTX
Ember - introduction
Harikrishnan C
 
PDF
Riding the Edge with Ember.js
aortbals
 
PPT
Ember.js: Jump Start
Viacheslav Bukach
 
PPTX
Intro to EmberJS
Billy Onjea
 
PDF
Ember presentation
Daniel N
 
PDF
Introduction to Ember.js and how we used it at FlowPro.io
Paul Knittel
 
PDF
Ember App Kit & The Ember Resolver
tboyt
 
PDF
Viliam Elischer - Ember.js - Jak zatopit a neshořet!
Develcz
 
PPTX
Full slidescr16
Lucio Grenzi
 
PDF
Scalable vector ember
Matthew Beale
 
PPTX
The road to Ember.js 2.0
Codemotion
 
PDF
Ember.js 101 - JSChannel NCR
Achal Aggarwal
 
PDF
The road to Ember 2.0
Filippo Zanella
 
PDF
The Ember.js Framework - Everything You Need To Know
All Things Open
 
PDF
Ember.js - Harnessing Convention Over Configuration
Tracy Lee
 
PDF
Delivering with ember.js
Andrei Sebastian Cîmpean
 
PDF
Ember.js - Jak zatopit a neshořet!
Viliam Elischer
 
Workshop 16: EmberJS Parte I
Visual Engineering
 
Developing Single Page Apps with Ember.js
Leo Hernandez
 
Node.js meetup 17.05.2017 ember.js - escape the javascript fatigue
Tobias Braner
 
Ember - introduction
Harikrishnan C
 
Riding the Edge with Ember.js
aortbals
 
Ember.js: Jump Start
Viacheslav Bukach
 
Intro to EmberJS
Billy Onjea
 
Ember presentation
Daniel N
 
Introduction to Ember.js and how we used it at FlowPro.io
Paul Knittel
 
Ember App Kit & The Ember Resolver
tboyt
 
Viliam Elischer - Ember.js - Jak zatopit a neshořet!
Develcz
 
Full slidescr16
Lucio Grenzi
 
Scalable vector ember
Matthew Beale
 
The road to Ember.js 2.0
Codemotion
 
Ember.js 101 - JSChannel NCR
Achal Aggarwal
 
The road to Ember 2.0
Filippo Zanella
 
The Ember.js Framework - Everything You Need To Know
All Things Open
 
Ember.js - Harnessing Convention Over Configuration
Tracy Lee
 
Delivering with ember.js
Andrei Sebastian Cîmpean
 
Ember.js - Jak zatopit a neshořet!
Viliam Elischer
 
Ad

More from Alex Blom (8)

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

Recently uploaded (20)

PDF
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 
PPTX
"Autonomy of LLM Agents: Current State and Future Prospects", Oles` Petriv
Fwdays
 
PDF
Chris Elwell Woburn, MA - Passionate About IT Innovation
Chris Elwell Woburn, MA
 
PDF
What Makes Contify’s News API Stand Out: Key Features at a Glance
Contify
 
PDF
Achieving Consistent and Reliable AI Code Generation - Medusa AI
medusaaico
 
PDF
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
PPTX
OpenID AuthZEN - Analyst Briefing July 2025
David Brossard
 
PPTX
Building Search Using OpenSearch: Limitations and Workarounds
Sease
 
PPTX
WooCommerce Workshop: Bring Your Laptop
Laura Hartwig
 
PDF
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
PDF
HubSpot Main Hub: A Unified Growth Platform
Jaswinder Singh
 
PDF
CIFDAQ Token Spotlight for 9th July 2025
CIFDAQ
 
PDF
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
PDF
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
PDF
Mastering Financial Management in Direct Selling
Epixel MLM Software
 
PPTX
From Sci-Fi to Reality: Exploring AI Evolution
Svetlana Meissner
 
PPTX
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
PDF
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
PDF
"AI Transformation: Directions and Challenges", Pavlo Shaternik
Fwdays
 
PDF
From Code to Challenge: Crafting Skill-Based Games That Engage and Reward
aiyshauae
 
Agentic AI lifecycle for Enterprise Hyper-Automation
Debmalya Biswas
 
"Autonomy of LLM Agents: Current State and Future Prospects", Oles` Petriv
Fwdays
 
Chris Elwell Woburn, MA - Passionate About IT Innovation
Chris Elwell Woburn, MA
 
What Makes Contify’s News API Stand Out: Key Features at a Glance
Contify
 
Achieving Consistent and Reliable AI Code Generation - Medusa AI
medusaaico
 
CIFDAQ Market Wrap for the week of 4th July 2025
CIFDAQ
 
OpenID AuthZEN - Analyst Briefing July 2025
David Brossard
 
Building Search Using OpenSearch: Limitations and Workarounds
Sease
 
WooCommerce Workshop: Bring Your Laptop
Laura Hartwig
 
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
HubSpot Main Hub: A Unified Growth Platform
Jaswinder Singh
 
CIFDAQ Token Spotlight for 9th July 2025
CIFDAQ
 
The Rise of AI and IoT in Mobile App Tech.pdf
IMG Global Infotech
 
Newgen Beyond Frankenstein_Build vs Buy_Digital_version.pdf
darshakparmar
 
Mastering Financial Management in Direct Selling
Epixel MLM Software
 
From Sci-Fi to Reality: Exploring AI Evolution
Svetlana Meissner
 
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
"AI Transformation: Directions and Challenges", Pavlo Shaternik
Fwdays
 
From Code to Challenge: Crafting Skill-Based Games That Engage and Reward
aiyshauae
 

Building Browser Extensions with Ember