diff --git a/.gitignore b/.gitignore
index aa9d88e86..c619451c8 100644
--- a/.gitignore
+++ b/.gitignore
@@ -44,6 +44,7 @@ log/
# Ignore plugins except for the bundled ones.
/plugins/*
!/plugins/emoji/
+!/plugins/lazyYT/
!/plugins/poll/
/plugins/*/auto_generated/
diff --git a/plugins/lazyYT/README.md b/plugins/lazyYT/README.md
new file mode 100644
index 000000000..430a205f7
--- /dev/null
+++ b/plugins/lazyYT/README.md
@@ -0,0 +1,3 @@
+# lazyYT
+
+Lazy load YouTube videos plugin for [Discourse](http://discourse.org), highly inspired by the [lazyYT](https://github.com/tylerpearson/lazyYT) jQuery plugin.
\ No newline at end of file
diff --git a/plugins/lazyYT/assets/javascripts/initializers/lazyYT.js.es6 b/plugins/lazyYT/assets/javascripts/initializers/lazyYT.js.es6
new file mode 100644
index 000000000..0743a30c3
--- /dev/null
+++ b/plugins/lazyYT/assets/javascripts/initializers/lazyYT.js.es6
@@ -0,0 +1,13 @@
+/**
+ Apply lazyYT when the app boots
+**/
+import { decorateCooked } from 'discourse/lib/plugin-api';
+
+export default {
+ name: "apply-lazyYT",
+ initialize: function(container) {
+ decorateCooked(container, function($elem) {
+ $('.lazyYT', $elem).lazyYT();
+ });
+ }
+};
diff --git a/plugins/lazyYT/assets/javascripts/lazyYT.js b/plugins/lazyYT/assets/javascripts/lazyYT.js
new file mode 100644
index 000000000..747ea6922
--- /dev/null
+++ b/plugins/lazyYT/assets/javascripts/lazyYT.js
@@ -0,0 +1,59 @@
+/*! LazyYT (lazy load Youtube videos plugin) - v0.3.4 - 2014-06-30
+* Usage:
loading...
+* Copyright (c) 2014 Tyler Pearson; Licensed MIT */
+
+
+;(function ($) {
+ 'use strict';
+
+ function setUp($el) {
+ var width = $el.data('width'),
+ height = $el.data('height'),
+ ratio = $el.data('ratio'),
+ id = $el.data('youtube-id'),
+ aspectRatio = ['16', '9'],
+ paddingTop = 0,
+ youtubeParameters = $el.data('parameters') || '';
+
+ if (typeof width === 'undefined' || typeof height === 'undefined') {
+ height = 0;
+ width = '100%';
+ aspectRatio = (ratio.split(":")[1] / ratio.split(":")[0]) * 100;
+ paddingTop = aspectRatio + '%';
+ }
+
+ $el.css({
+ 'position': 'relative',
+ 'height': height,
+ 'width': width,
+ 'padding-top': paddingTop,
+ 'background': 'url(http://img.youtube.com/vi/' + id + '/hqdefault.jpg) center center no-repeat',
+ 'cursor': 'pointer',
+ 'background-size': 'cover'
+ })
+ .html('')
+ .addClass('lazyYT-image-loaded');
+
+ $.getJSON('https://gdata.youtube.com/feeds/api/videos/' + id + '?v=2&alt=json', function (data) {
+ $('#lazyYT-title-' + id).text(data.entry.title.$t);
+ });
+
+ $el.on('click', function (e) {
+ e.preventDefault();
+ if (!$el.hasClass('lazyYT-video-loaded') && $el.hasClass('lazyYT-image-loaded')) {
+ $el.html('')
+ .removeClass('lazyYT-image-loaded')
+ .addClass('lazyYT-video-loaded');
+ }
+ });
+
+ }
+
+ $.fn.lazyYT = function () {
+ return this.each(function () {
+ var $el = $(this).css('cursor', 'pointer');
+ setUp($el);
+ });
+ };
+
+}(jQuery));
diff --git a/plugins/lazyYT/assets/stylesheets/lazyYT.css b/plugins/lazyYT/assets/stylesheets/lazyYT.css
new file mode 100644
index 000000000..3887aa6dd
--- /dev/null
+++ b/plugins/lazyYT/assets/stylesheets/lazyYT.css
@@ -0,0 +1,34 @@
+/*!
+* lazyyt
+* v0.3.4 - 2014-06-30
+* Copyright (c) 2014 Tyler Pearson (http://tylerp.me); Licensed MIT %>
+*/
+
+.lazyYT-title {
+ z-index: 100!important;
+ color: #fff!important;
+ font-family: sans-serif!important;
+ font-size: 12px!important;
+ top: 10px!important;
+ left: 12px!important;
+ position: absolute!important;
+ margin: 0!important;
+ padding: 0!important;
+ line-height: 1!important;
+ font-style: normal!important;
+ font-weight: normal!important;
+}
+
+.lazyYT-button {
+ margin: 0!important;
+ padding: 0!important;
+ width: 60px!important;
+ height: 41px!important;
+ z-index: 100!important;
+ position: absolute!important;
+ top: 50%!important;
+ margin-top: -22px!important;
+ left: 50%!important;
+ margin-left: -30px!important;
+ background-image: url('')!important;
+}
diff --git a/plugins/lazyYT/plugin.rb b/plugins/lazyYT/plugin.rb
new file mode 100644
index 000000000..46b413933
--- /dev/null
+++ b/plugins/lazyYT/plugin.rb
@@ -0,0 +1,28 @@
+# name: lazyYT
+# about: Uses the lazyYT plugin to lazy load Youtube videos
+# version: 0.1
+# authors: Arpit Jalan
+
+# javascript
+register_asset "javascripts/lazyYT.js"
+
+# stylesheet
+register_asset "stylesheets/lazyYT.css"
+
+# freedom patch YouTube Onebox
+class Onebox::Engine::YoutubeOnebox
+ include Onebox::Engine
+
+ def to_html
+ if video_id
+ # Avoid making HTTP requests if we are able to get the video ID from the
+ # URL.
+ html = ""
+ else
+ # Fall back to making HTTP requests.
+ html = raw[:html] || ""
+ end
+
+ rewrite_agnostic(append_params(html))
+ end
+end