FEATURE: ship lazyYT plugin by default

This commit is contained in:
Arpit Jalan 2014-07-22 08:09:32 +05:30
parent a4cdf33b22
commit a711575947
6 changed files with 139 additions and 0 deletions

1
.gitignore vendored
View File

@ -44,6 +44,7 @@ log/
# Ignore plugins except for the bundled ones. # Ignore plugins except for the bundled ones.
/plugins/* /plugins/*
!/plugins/emoji/ !/plugins/emoji/
!/plugins/lazyYT/
!/plugins/poll/ !/plugins/poll/
/plugins/*/auto_generated/ /plugins/*/auto_generated/

3
plugins/lazyYT/README.md Normal file
View File

@ -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.

View File

@ -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();
});
}
};

View File

@ -0,0 +1,59 @@
/*! LazyYT (lazy load Youtube videos plugin) - v0.3.4 - 2014-06-30
* Usage: <div class="lazyYT" data-youtube-id="laknj093n" ratio="16:9" data-parameters="rel=0">loading...</div>
* 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('<p id="lazyYT-title-' + id + '" class="lazyYT-title"></p><div class="lazyYT-button"></div>')
.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('<iframe width="' + width + '" height="' + height + '" src="//www.youtube.com/embed/' + id + '?autoplay=1&' + youtubeParameters + '" style="position:absolute; top:0; left:0; width:100%; height:100%;" frameborder="0" allowfullscreen></iframe>')
.removeClass('lazyYT-image-loaded')
.addClass('lazyYT-video-loaded');
}
});
}
$.fn.lazyYT = function () {
return this.each(function () {
var $el = $(this).css('cursor', 'pointer');
setUp($el);
});
};
}(jQuery));

View File

@ -0,0 +1,34 @@
/*!
* lazyyt
* v0.3.4 - 2014-06-30
* Copyright (c) 2014 Tyler Pearson <ty.pearson@gmail.com> (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;
}

29
plugins/lazyYT/plugin.rb Normal file
View File

@ -0,0 +1,29 @@
# name: lazyYT
# about: Uses the lazyYT plugin to lazy load Youtube videos
# version: 0.1
# authors: Arpit Jalan
# javascript
register_asset "javascripts/lazyYT.js"
register_asset "javascripts/initializers/lazyYT.js.es6"
# 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 = "<div class=\"lazyYT\" data-youtube-id=\"#{video_id}\" data-width=\"480\" data-height=\"270\"></div>"
else
# Fall back to making HTTP requests.
html = raw[:html] || ""
end
rewrite_agnostic(append_params(html))
end
end