From cc0f3b83ee42805ee4803fb1656d49afcb3a3d0d Mon Sep 17 00:00:00 2001 From: Arpit Jalan Date: Tue, 27 Jan 2015 18:00:07 +0530 Subject: [PATCH] Update lazyYT plugin to version 1.0.1 --- plugins/lazyYT/assets/javascripts/lazyYT.js | 163 +++++++++++++------ plugins/lazyYT/assets/stylesheets/lazyYT.css | 140 ++++++++++++---- plugins/lazyYT/plugin.rb | 2 +- 3 files changed, 225 insertions(+), 80 deletions(-) diff --git a/plugins/lazyYT/assets/javascripts/lazyYT.js b/plugins/lazyYT/assets/javascripts/lazyYT.js index 5c9f7cfba1d..18644400443 100644 --- a/plugins/lazyYT/assets/javascripts/lazyYT.js +++ b/plugins/lazyYT/assets/javascripts/lazyYT.js @@ -1,61 +1,126 @@ -/*! LazyYT (lazy load Youtube videos plugin) - v0.3.4 - 2014-06-30 -* Usage:
loading...
-* Copyright (c) 2014 Tyler Pearson; Licensed MIT */ - +/*! +* lazyYT (lazy load YouTube videos) +* v1.0.1 - 2014-12-30 +* (CC) This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License. +* http://creativecommons.org/licenses/by-sa/4.0/ +* Contributors: https://github.com/tylerpearson/lazyYT/graphs/contributors || https://github.com/daugilas/lazyYT/graphs/contributors +* +* Usage:
loading...
+*/ ;(function ($) { - 'use strict'; + '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') || ''; + function setUp($el, settings) { + var width = $el.data('width'), + height = $el.data('height'), + ratio = ($el.data('ratio')) ? $el.data('ratio') : settings.default_ratio, + id = $el.data('youtube-id'), + padding_bottom, + innerHtml = [], + $thumb, + thumb_img, + loading_text = $el.text() ? $el.text() : settings.loading_text, + youtube_parameters = $el.data('parameters') || ''; - if (typeof width === 'undefined' || typeof height === 'undefined') { - height = 0; - width = '100%'; - aspectRatio = (ratio.split(":")[1] / ratio.split(":")[0]) * 100; - paddingTop = aspectRatio + '%'; - } + ratio = ratio.split(":"); - $el.css({ - 'position': 'relative', - 'height': height, - 'width': width, - 'padding-top': paddingTop, - 'background': 'url(//img.youtube.com/vi/' + id + '/hqdefault.jpg) center center no-repeat', - 'cursor': 'pointer', - 'background-size': 'cover' - }) - .html('

') - .addClass('lazyYT-image-loaded'); - - var $el_title = $el.find("p.lazyYT-title"); //get reference to the current container title element - - $.getJSON('https://gdata.youtube.com/feeds/api/videos/' + id + '?v=2&alt=json', function (data) { - $el_title.text(data.entry.title.$t); - }); + // width and height might override default_ratio value + if (typeof width === 'number' && typeof height === 'number') { + $el.width(width); + padding_bottom = height + 'px'; + } else if (typeof width === 'number') { + $el.width(width); + padding_bottom = (width * ratio[1] / ratio[0]) + 'px'; + } else { + width = $el.width(); - $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'); - } - }); + // no width means that container is fluid and will be the size of its parent + if (width === 0) { + width = $el.parent().width(); + } + padding_bottom = (ratio[1] / ratio[0] * 100) + '%'; } - $.fn.lazyYT = function () { - return this.each(function () { - var $el = $(this).css('cursor', 'pointer'); - setUp($el); - }); + // + // This HTML will be placed inside 'lazyYT' container + + innerHtml.push('
'); + + // Play button from YouTube (exactly as it is in YouTube) + innerHtml.push('
'); + innerHtml.push(''); + innerHtml.push(''); + innerHtml.push(''); + innerHtml.push(''); + innerHtml.push('
'); // end of .ytp-large-play-button + + innerHtml.push('
'); // end of .ytp-thumbnail + + // Video title (info bar) + innerHtml.push('
'); + innerHtml.push('
'); + innerHtml.push('
'); + innerHtml.push(''); + innerHtml.push(loading_text); + innerHtml.push(''); + innerHtml.push('
'); // .html5-title + innerHtml.push('
'); // .html5-title-text-wrapper + innerHtml.push('
'); // end of Video title .html5-info-bar + + $el.css({ + 'padding-bottom': padding_bottom + }) + .html(innerHtml.join('')); + + if (width > 640) { + thumb_img = 'maxresdefault.jpg'; + } else if (width > 480) { + thumb_img = 'sddefault.jpg'; + } else if (width > 320) { + thumb_img = 'hqdefault.jpg'; + } else if (width > 120) { + thumb_img = 'mqdefault.jpg'; + } else if (width === 0) { // sometimes it fails on fluid layout + thumb_img = 'hqdefault.jpg'; + } else { + thumb_img = 'default.jpg'; + } + + $thumb = $el.find('.ytp-thumbnail').css({ + 'background-image': ['url(http://img.youtube.com/vi/', id, '/', thumb_img, ')'].join('') + }) + .addClass('lazyYT-image-loaded') + .on('click', function (e) { + e.preventDefault(); + if (!$el.hasClass('lazyYT-video-loaded') && $thumb.hasClass('lazyYT-image-loaded')) { + $el.html('') + .addClass('lazyYT-video-loaded'); + } + }); + + $.getJSON('https://gdata.youtube.com/feeds/api/videos/' + id + '?v=2&alt=json', function (data) { + $el.find('#lazyYT-title-' + id).text(data.entry.title.$t); + }); + + } + + $.fn.lazyYT = function (newSettings) { + var defaultSettings = { + loading_text: 'Loading...', + default_ratio: '16:9', + callback: null, // ToDO execute callback if given + container_class: 'lazyYT-container' }; + var settings = $.extend(defaultSettings, newSettings); + + return this.each(function () { + var $el = $(this).addClass(settings.container_class); + setUp($el, settings); + }); + }; }(jQuery)); diff --git a/plugins/lazyYT/assets/stylesheets/lazyYT.css b/plugins/lazyYT/assets/stylesheets/lazyYT.css index 43e49d4c65e..732735138a0 100644 --- a/plugins/lazyYT/assets/stylesheets/lazyYT.css +++ b/plugins/lazyYT/assets/stylesheets/lazyYT.css @@ -1,36 +1,116 @@ /*! -* lazyyt -* v0.3.4 - 2014-06-30 -* Copyright (c) 2014 Tyler Pearson (http://tylerp.me); Licensed MIT %> +* lazyYT (lazy load YouTube videos) +* v1.0.1 - 2014-12-30 +* (CC) This work is licensed under a Creative Commons Attribution-ShareAlike 4.0 International License. +* http://creativecommons.org/licenses/by-sa/4.0/ +* Contributors: https://github.com/tylerpearson/lazyYT/graphs/contributors || https://github.com/daugilas/lazyYT/graphs/contributors */ -.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.5em!important; - line-height: 1!important; - font-style: normal!important; - font-weight: normal!important; - background-color: rgba(0,0,0,0.8)!important; - border-radius: 0.5em!important; +.lazyYT-container { + position: relative; + display: block; + height: 0; + padding: 0 0 56.25% 0; + overflow: hidden; + background-color: #000000; } -.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; +.lazyYT-container iframe { + position: absolute; + top: 0; + bottom: 0; + left: 0; + width: 100%; + height: 100%; + border: 0; +} + +/* +* Video Title (YouTube style) +*/ + +.lazyYT-container .html5-info-bar { + position: absolute; + top: 0; + z-index: 935; + width: 100%; + height: 30px; + overflow: hidden; + font-family: Arial, Helvetica, sans-serif; + font-size: 12px; + color: #fff; + background-color: rgba(0, 0, 0, 0.8); + -webkit-transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1); + -moz-transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1); + transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1); +} + +.lazyYT-container .html5-title { + padding-right: 6px; + padding-left: 12px; +} + +.lazyYT-container .html5-title-text-wrapper { + overflow: hidden; + -o-text-overflow: ellipsis; + text-overflow: ellipsis; + word-wrap: normal; + white-space: nowrap; +} + +.lazyYT-container .html5-title-text { + width: 100%; + font-size: 13px; + line-height: 30px; + color: #ccc; + text-decoration: none; +} + +.lazyYT-container .html5-title-text:hover { + color: #fff; + text-decoration: underline; +} + +/* +* Thumbnail +*/ + +.ytp-thumbnail { + padding-bottom: inherit; + cursor: pointer; + background-position: 50% 50%; + background-repeat: no-repeat; + -webkit-background-size: cover; + -moz-background-size: cover; + -o-background-size: cover; + background-size: cover; +} + +/* +* Play button (YouTube style) +*/ + +.ytp-large-play-button { + position: absolute; + top: 50% !important; + left: 50% !important; + width: 86px !important; + height: 60px !important; + padding: 0 !important; + margin: -29px 0 0 -42px !important; + font-size: normal !important; + font-weight: normal !important; + line-height: 1 !important; + opacity: .9; +} + +.ytp-large-play-button-svg { + opacity: .9; + fill: #1f1f1f; +} + +.lazyYT-image-loaded:hover .ytp-large-play-button-svg, +.ytp-large-play-button:focus .ytp-large-play-button-svg { + opacity: 1; + fill: #cc181e; } diff --git a/plugins/lazyYT/plugin.rb b/plugins/lazyYT/plugin.rb index 95bc299145b..3bb49aeb996 100644 --- a/plugins/lazyYT/plugin.rb +++ b/plugins/lazyYT/plugin.rb @@ -1,6 +1,6 @@ # name: lazyYT # about: Uses the lazyYT plugin to lazy load Youtube videos -# version: 0.1 +# version: 1.0.1 # authors: Arpit Jalan # javascript