news_reader 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +1 -1
  3. data/lib/news_reader/scraper.rb +1 -1
  4. data/lib/news_reader/version.rb +1 -1
  5. metadata +1 -61
  6. data/fixtures/.DS_Store +0 -0
  7. data/fixtures/blog/index.html +0 -200
  8. data/fixtures/blog/index_files/Box.css +0 -29
  9. data/fixtures/blog/index_files/Java_Box.js +0 -89
  10. data/fixtures/blog/index_files/ModuleStyleSheets.css +0 -1655
  11. data/fixtures/blog/index_files/black.css +0 -11
  12. data/fixtures/blog/index_files/blog-jive.jpg +0 -0
  13. data/fixtures/blog/index_files/blog-musolfs.jpg +0 -0
  14. data/fixtures/blog/index_files/blog-poolpak.jpg +0 -0
  15. data/fixtures/blog/index_files/blog-portalaudit.png +0 -0
  16. data/fixtures/blog/index_files/blog-semicolon1.jpg +0 -0
  17. data/fixtures/blog/index_files/blog-semicolon2.jpg +0 -0
  18. data/fixtures/blog/index_files/blog-spa1.jpg +0 -0
  19. data/fixtures/blog/index_files/blog-spa2.jpg +0 -0
  20. data/fixtures/blog/index_files/blog-statera.jpg +0 -0
  21. data/fixtures/blog/index_files/blue.css +0 -11
  22. data/fixtures/blog/index_files/common.js +0 -149
  23. data/fixtures/blog/index_files/dark.css +0 -31
  24. data/fixtures/blog/index_files/featherlight.min.css +0 -8
  25. data/fixtures/blog/index_files/featherlight.min.js +0 -8
  26. data/fixtures/blog/index_files/font-awesome.min.css +0 -4
  27. data/fixtures/blog/index_files/green.css +0 -11
  28. data/fixtures/blog/index_files/isotope.css +0 -64
  29. data/fixtures/blog/index_files/jquery-ui.min.js +0 -5
  30. data/fixtures/blog/index_files/jquery.carouFredSel-6.2.1-packed.js +0 -16
  31. data/fixtures/blog/index_files/jquery.contentcarousel.js +0 -137
  32. data/fixtures/blog/index_files/jquery.easing.1.3.js +0 -205
  33. data/fixtures/blog/index_files/jquery.form.js +0 -1121
  34. data/fixtures/blog/index_files/jquery.hoverdir.js +0 -220
  35. data/fixtures/blog/index_files/jquery.inview.js +0 -60
  36. data/fixtures/blog/index_files/jquery.isotope.min.js +0 -11
  37. data/fixtures/blog/index_files/jquery.magnific-popup.js +0 -2046
  38. data/fixtures/blog/index_files/jquery.mb.YTPlayer.js +0 -1041
  39. data/fixtures/blog/index_files/jquery.min.js +0 -5
  40. data/fixtures/blog/index_files/jquery.nav.js +0 -223
  41. data/fixtures/blog/index_files/jquery.smoothwheel.js +0 -153
  42. data/fixtures/blog/index_files/jquery.sticky.js +0 -129
  43. data/fixtures/blog/index_files/jquery.superslides.js +0 -656
  44. data/fixtures/blog/index_files/jquery.validate.js +0 -1231
  45. data/fixtures/blog/index_files/jquery.vegas.css +0 -34
  46. data/fixtures/blog/index_files/js +0 -201
  47. data/fixtures/blog/index_files/loading.gif +0 -0
  48. data/fixtures/blog/index_files/magnific-popup.css +0 -365
  49. data/fixtures/blog/index_files/main.css +0 -301
  50. data/fixtures/blog/index_files/main.js +0 -26
  51. data/fixtures/blog/index_files/modernizr-2.6.2.min.js +0 -4
  52. data/fixtures/blog/index_files/normalize.css +0 -533
  53. data/fixtures/blog/index_files/ohp3fra.js +0 -44
  54. data/fixtures/blog/index_files/orange.css +0 -11
  55. data/fixtures/blog/index_files/paralax.js +0 -525
  56. data/fixtures/blog/index_files/paralaxNEW4.css +0 -2730
  57. data/fixtures/blog/index_files/plugins.js +0 -221
  58. data/fixtures/blog/index_files/portfolio.js +0 -142
  59. data/fixtures/blog/index_files/purple.css +0 -11
  60. data/fixtures/blog/index_files/red.css +0 -11
  61. data/fixtures/blog/index_files/responsive3.css +0 -329
  62. data/fixtures/blog/index_files/superslides.css +0 -65
  63. data/fixtures/blog/index_files/turquoise.css +0 -11
  64. data/fixtures/blog/index_files/util.js +0 -287
  65. data/fixtures/blog/index_files/yellow.css +0 -11
@@ -1,1041 +0,0 @@
1
- $(document).ready(function(){
2
-
3
-
4
- var onMobile = false;
5
- if( /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent) ) { onMobile = true; }
6
-
7
- if( ( onMobile === false ) ) {
8
-
9
- $(".player").mb_YTPlayer();
10
-
11
- } else {
12
-
13
- /* as a fallback we add a special class to the header which displays a poster image */
14
- $('#home').addClass('video-section');
15
-
16
- /* hide player */
17
- $(".player").hide();
18
-
19
- $("#video-volume").hide();
20
-
21
- }
22
-
23
-
24
-
25
- });
26
-
27
-
28
- /*
29
- * ******************************************************************************
30
- * jquery.mb.components
31
- * file: jquery.mb.YTPlayer.js
32
- *
33
- * Copyright (c) 2001-2013. Matteo Bicocchi (Pupunzi);
34
- * Open lab srl, Firenze - Italy
35
- * email: matteo@open-lab.com
36
- * site: http://pupunzi.com
37
- * blog: http://pupunzi.open-lab.com
38
- * http://open-lab.com
39
- *
40
- * Licences: MIT, GPL
41
- * http://www.opensource.org/licenses/mit-license.php
42
- * http://www.gnu.org/licenses/gpl.html
43
- *
44
- * last modified: 30/08/13 23.31
45
- * *****************************************************************************
46
- */
47
-
48
- /*Browser detection patch*/
49
- (function(){if(!(8>jQuery.fn.jquery.split(".")[1])){jQuery.browser={};jQuery.browser.mozilla=!1;jQuery.browser.webkit=!1;jQuery.browser.opera=!1;jQuery.browser.msie=!1;var a=navigator.userAgent;jQuery.browser.name=navigator.appName;jQuery.browser.fullVersion=""+parseFloat(navigator.appVersion);jQuery.browser.majorVersion=parseInt(navigator.appVersion,10);var c,b;if(-1!=(b=a.indexOf("Opera"))){if(jQuery.browser.opera=!0,jQuery.browser.name="Opera",jQuery.browser.fullVersion=a.substring(b+6),-1!=(b= a.indexOf("Version")))jQuery.browser.fullVersion=a.substring(b+8)}else if(-1!=(b=a.indexOf("MSIE")))jQuery.browser.msie=!0,jQuery.browser.name="Microsoft Internet Explorer",jQuery.browser.fullVersion=a.substring(b+5);else if(-1!=(b=a.indexOf("Chrome")))jQuery.browser.webkit=!0,jQuery.browser.name="Chrome",jQuery.browser.fullVersion=a.substring(b+7);else if(-1!=(b=a.indexOf("Safari"))){if(jQuery.browser.webkit=!0,jQuery.browser.name="Safari",jQuery.browser.fullVersion=a.substring(b+7),-1!=(b=a.indexOf("Version")))jQuery.browser.fullVersion= a.substring(b+8)}else if(-1!=(b=a.indexOf("Firefox")))jQuery.browser.mozilla=!0,jQuery.browser.name="Firefox",jQuery.browser.fullVersion=a.substring(b+8);else if((c=a.lastIndexOf(" ")+1)<(b=a.lastIndexOf("/")))jQuery.browser.name=a.substring(c,b),jQuery.browser.fullVersion=a.substring(b+1),jQuery.browser.name.toLowerCase()==jQuery.browser.name.toUpperCase()&&(jQuery.browser.name=navigator.appName);if(-1!=(a=jQuery.browser.fullVersion.indexOf(";")))jQuery.browser.fullVersion=jQuery.browser.fullVersion.substring(0, a);if(-1!=(a=jQuery.browser.fullVersion.indexOf(" ")))jQuery.browser.fullVersion=jQuery.browser.fullVersion.substring(0,a);jQuery.browser.majorVersion=parseInt(""+jQuery.browser.fullVersion,10);isNaN(jQuery.browser.majorVersion)&&(jQuery.browser.fullVersion=""+parseFloat(navigator.appVersion),jQuery.browser.majorVersion=parseInt(navigator.appVersion,10));jQuery.browser.version=jQuery.browser.majorVersion}})(jQuery);
50
-
51
- /*******************************************************************************
52
- * jQuery.mb.components: jquery.mb.CSSAnimate
53
- ******************************************************************************/
54
-
55
- jQuery.fn.CSSAnimate=function(a,b,k,l,f){return this.each(function(){var c=jQuery(this);if(0!==c.length&&a){"function"==typeof b&&(f=b,b=jQuery.fx.speeds._default);"function"==typeof k&&(f=k,k=0);"function"==typeof l&&(f=l,l="cubic-bezier(0.65,0.03,0.36,0.72)");if("string"==typeof b)for(var j in jQuery.fx.speeds)if(b==j){b=jQuery.fx.speeds[j];break}else b=null;if(jQuery.support.transition){var e="",h="transitionEnd";jQuery.browser.webkit?(e="-webkit-",h="webkitTransitionEnd"):jQuery.browser.mozilla? (e="-moz-",h="transitionend"):jQuery.browser.opera?(e="-o-",h="otransitionend"):jQuery.browser.msie&&(e="-ms-",h="msTransitionEnd");j=[];for(d in a){var g=d;"transform"===g&&(g=e+"transform",a[g]=a[d],delete a[d]);"transform-origin"===g&&(g=e+"transform-origin",a[g]=a[d],delete a[d]);j.push(g);c.css(g)||c.css(g,0)}d=j.join(",");c.css(e+"transition-property",d);c.css(e+"transition-duration",b+"ms");c.css(e+"transition-delay",k+"ms");c.css(e+"transition-timing-function",l);c.css(e+"backface-visibility", "hidden");setTimeout(function(){c.css(a)},0);setTimeout(function(){c.called||!f?c.called=!1:f()},b+20);c.on(h,function(a){c.off(h);c.css(e+"transition","");a.stopPropagation();"function"==typeof f&&(c.called=!0,f());return!1})}else{for(var d in a)"transform"===d&&delete a[d],"transform-origin"===d&&delete a[d],"auto"===a[d]&&delete a[d];if(!f||"string"===typeof f)f="linear";c.animate(a,b,f)}}})}; jQuery.fn.CSSAnimateStop=function(){var a="",b="transitionEnd";jQuery.browser.webkit?(a="-webkit-",b="webkitTransitionEnd"):jQuery.browser.mozilla?(a="-moz-",b="transitionend"):jQuery.browser.opera?(a="-o-",b="otransitionend"):jQuery.browser.msie&&(a="-ms-",b="msTransitionEnd");jQuery(this).css(a+"transition","");jQuery(this).off(b)}; jQuery.support.transition=function(){var a=(document.body||document.documentElement).style;return void 0!==a.transition||void 0!==a.WebkitTransition||void 0!==a.MozTransition||void 0!==a.MsTransition||void 0!==a.OTransition}();
56
-
57
- /*
58
- * Metadata - jQuery plugin for parsing metadata from elements
59
- * Copyright (c) 2006 John Resig, Yehuda Katz, Jörn Zaefferer, Paul McLanahan
60
- * Dual licensed under the MIT and GPL licenses:
61
- * http://www.opensource.org/licenses/mit-license.php
62
- * http://www.gnu.org/licenses/gpl.html
63
- */
64
-
65
- (function(c){c.extend({metadata:{defaults:{type:"class",name:"metadata",cre:/({.*})/,single:"metadata"},setType:function(b,c){this.defaults.type=b;this.defaults.name=c},get:function(b,f){var d=c.extend({},this.defaults,f);d.single.length||(d.single="metadata");var a=c.data(b,d.single);if(a)return a;a="{}";if("class"==d.type){var e=d.cre.exec(b.className);e&&(a=e[1])}else if("elem"==d.type){if(!b.getElementsByTagName)return;e=b.getElementsByTagName(d.name);e.length&&(a=c.trim(e[0].innerHTML))}else void 0!= b.getAttribute&&(e=b.getAttribute(d.name))&&(a=e);0>a.indexOf("{")&&(a="{"+a+"}");a=eval("("+a+")");c.data(b,d.single,a);return a}}});c.fn.metadata=function(b){return c.metadata.get(this[0],b)}})(jQuery);
66
-
67
- /***************************************************************************************/
68
- if(typeof ytp != "object")
69
- ytp ={};
70
-
71
- String.prototype.getVideoID=function(){
72
- var movieURL;
73
- if(this.substr(0,16)=="http://youtu.be/"){
74
- movieURL= this.replace("http://youtu.be/","");
75
- }else if(this.indexOf("http")>-1){
76
- movieURL = this.match(/[\\?&]v=([^&#]*)/)[1];
77
- }else{
78
- movieURL = this
79
- }
80
- return movieURL;
81
- };
82
-
83
- var isDevice = 'ontouchstart' in window;
84
-
85
- function onYouTubePlayerAPIReady() {
86
- if(ytp.YTAPIReady)
87
- return;
88
-
89
- ytp.YTAPIReady=true;
90
- jQuery(document).trigger("YTAPIReady");
91
- }
92
-
93
- (function (jQuery) {
94
-
95
- jQuery.mbYTPlayer = {
96
- name : "jquery.mb.YTPlayer",
97
- version : "2.5.7",
98
- author : "Matteo Bicocchi",
99
- defaults : {
100
- containment : "body",
101
- ratio : "16/9",
102
- showYTLogo : false,
103
- videoURL : null,
104
- startAt : 0,
105
- autoPlay : true,
106
- vol :10,
107
- addRaster : false,
108
- opacity : 1,
109
- quality : "default", //or "small", "medium", "large", "hd720", "hd1080", "highres"
110
- mute : false,
111
- loop : true,
112
- showControls : true,
113
- showAnnotations : false,
114
- printUrl : true,
115
- stopMovieOnClick :false,
116
- realfullscreen :true,
117
- onReady : function (player) {},
118
- onStateChange : function (player) {},
119
- onPlaybackQualityChange: function (player) {},
120
- onError : function (player) {}
121
- },
122
- //todo: use @font-face instead
123
- controls : {
124
- play : "P",
125
- pause : "p",
126
- mute : "M",
127
- unmute: "A",
128
- onlyYT: "O",
129
- showSite: "R",
130
- ytLogo: "Y"
131
- },
132
- rasterImg : "images/raster.png",
133
- rasterImgRetina: "images/raster@2x.png",
134
-
135
- buildPlayer: function (options) {
136
-
137
- return this.each(function () {
138
- var YTPlayer = this;
139
- var $YTPlayer = jQuery(YTPlayer);
140
-
141
- YTPlayer.loop = 0;
142
- YTPlayer.opt = {};
143
- var property = {};
144
-
145
- $YTPlayer.addClass("mb_YTVPlayer");
146
-
147
- if (jQuery.metadata) {
148
- jQuery.metadata.setType("class");
149
- property = $YTPlayer.metadata();
150
- }
151
-
152
- if (jQuery.isEmptyObject(property))
153
- property = $YTPlayer.data("property") && typeof $YTPlayer.data("property") == "string" ? eval('(' + $YTPlayer.data("property") + ')') : $YTPlayer.data("property");
154
-
155
- jQuery.extend(YTPlayer.opt, jQuery.mbYTPlayer.defaults, options, property);
156
-
157
- var canGoFullscreen = true;
158
-
159
- if(!canGoFullscreen)
160
- YTPlayer.opt.realfullscreen = t;
161
-
162
- if (!$YTPlayer.attr("id"))
163
- $YTPlayer.attr("id", "id_" + new Date().getTime());
164
-
165
- YTPlayer.opt.id = YTPlayer.id;
166
- YTPlayer.isAlone = false;
167
-
168
- /*to maintain back compatibility
169
- * ***********************************************************/
170
- if (YTPlayer.opt.isBgndMovie)
171
- YTPlayer.opt.containment = "body";
172
-
173
- if (YTPlayer.opt.isBgndMovie && YTPlayer.opt.isBgndMovie.mute != undefined)
174
- YTPlayer.opt.mute = YTPlayer.opt.isBgndMovie.mute;
175
-
176
- if (!YTPlayer.opt.videoURL)
177
- YTPlayer.opt.videoURL = $YTPlayer.attr("href");
178
-
179
- /************************************************************/
180
-
181
- var playerID = "mbYTP_" + YTPlayer.id;
182
- var videoID = this.opt.videoURL ? this.opt.videoURL.getVideoID() : $YTPlayer.attr("href") ? $YTPlayer.attr("href").getVideoID() : false;
183
- YTPlayer.videoID = videoID;
184
-
185
-
186
- YTPlayer.opt.showAnnotations = (YTPlayer.opt.showAnnotations) ? '0' : '3';
187
- var playerVars = { 'autoplay': 0, 'modestbranding': 1, 'controls': 0, 'showinfo': 0, 'rel': 0, 'enablejsapi': 1, 'version': 3, 'playerapiid': playerID, 'origin': '*', 'allowfullscreen': true, 'wmode': "transparent", 'iv_load_policy': YTPlayer.opt.showAnnotations};
188
-
189
- var canPlayHTML5 = false;
190
- var v = document.createElement('video');
191
- if (v.canPlayType ) { // && !jQuery.browser.msie
192
- canPlayHTML5 = true;
193
- }
194
-
195
- if (canPlayHTML5) // && !(YTPlayer.isPlayList && jQuery.browser.msie)
196
- jQuery.extend(playerVars, {'html5': 1});
197
-
198
- if(jQuery.browser.msie && jQuery.browser.version < 9 ){
199
- this.opt.opacity = 1;
200
- }
201
-
202
- var playerBox = jQuery("<div/>").attr("id", playerID).addClass("playerBox");
203
- var overlay = jQuery("<div/>").css({position: "absolute", top: 0, left: 0, width: "100%", height: "100%"}).addClass("YTPOverlay"); //YTPlayer.isBackground ? "fixed" :
204
-
205
- YTPlayer.opt.containment = YTPlayer.opt.containment == "self" ? jQuery(this) : jQuery(YTPlayer.opt.containment);
206
-
207
- YTPlayer.isBackground = YTPlayer.opt.containment.get(0).tagName.toLowerCase() == "body";
208
-
209
- if (isDevice && YTPlayer.isBackground){
210
- $YTPlayer.hide();
211
- return;
212
- }
213
-
214
- if (YTPlayer.opt.addRaster) {
215
- var retina = (window.retina || window.devicePixelRatio > 1);
216
- overlay.addClass(retina ? "raster retina" : "raster");
217
- }else{
218
- overlay.removeClass("raster retina");
219
- }
220
-
221
- var wrapper = jQuery("<div/>").addClass("mbYTP_wrapper").attr("id", "wrapper_" + playerID);
222
- wrapper.css({position: "absolute", zIndex: 0, minWidth: "100%", minHeight: "100%",left:0, top:0, overflow: "hidden", opacity: 0});
223
- playerBox.css({position: "absolute", zIndex: 0, width: "100%", height: "100%", top: 0, left: 0, overflow: "hidden", opacity: this.opt.opacity});
224
- wrapper.append(playerBox);
225
-
226
- if (YTPlayer.isBackground && ytp.isInit)
227
- return;
228
-
229
- YTPlayer.opt.containment.children().each(function () {
230
- if (jQuery(this).css("position") == "static")
231
- jQuery(this).css("position", "relative");
232
- });
233
-
234
- if (YTPlayer.isBackground) {
235
- jQuery("body").css({position: "relative", minWidth: "100%", minHeight: "100%", zIndex: 1, boxSizing: "border-box"});
236
- wrapper.css({position: "absolute", top: 0, left: 0, zIndex: 0});
237
- $YTPlayer.hide();
238
- YTPlayer.opt.containment.prepend(wrapper);
239
- } else
240
- YTPlayer.opt.containment.prepend(wrapper);
241
-
242
- YTPlayer.wrapper = wrapper;
243
-
244
- playerBox.css({opacity: 1});
245
-
246
- if (!isDevice){
247
- playerBox.after(overlay);
248
- YTPlayer.overlay = overlay;
249
- }
250
-
251
-
252
- if(!YTPlayer.isBackground){
253
- overlay.on("mouseenter",function(){
254
- $YTPlayer.find(".mb_YTVPBar").addClass("visible");
255
- }).on("mouseleave",function(){
256
- $YTPlayer.find(".mb_YTVPBar").removeClass("visible");
257
- })
258
- }
259
-
260
- // add YT API to the header
261
- //jQuery("#YTAPI").remove();
262
-
263
- if(!ytp.YTAPIReady){
264
- var tag = document.createElement('script');
265
- tag.src = "http://www.youtube.com/player_api";
266
- tag.id = "YTAPI";
267
- var firstScriptTag = document.getElementsByTagName('script')[0];
268
- firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
269
- }else{
270
- setTimeout(function(){
271
- jQuery(document).trigger("YTAPIReady");
272
- }, 200)
273
- }
274
-
275
- jQuery(document).on("YTAPIReady", function () {
276
-
277
- if ((YTPlayer.isBackground && ytp.isInit) || YTPlayer.opt.isInit)
278
- return;
279
-
280
- if(YTPlayer.isBackground && YTPlayer.opt.stopMovieOnClick)
281
- jQuery(document).off("mousedown.ytplayer").on("mousedown,.ytplayer",function(e){
282
- var target = jQuery(e.target);
283
- if(target.is("a") || target.parents().is("a")){
284
- $YTPlayer.pauseYTP();
285
- }
286
- });
287
-
288
- if (YTPlayer.isBackground)
289
- ytp.isInit = true;
290
-
291
- YTPlayer.opt.isInit = true;
292
-
293
- YTPlayer.opt.vol = YTPlayer.opt.vol ? YTPlayer.opt.vol : 100;
294
-
295
- jQuery.mbYTPlayer.getDataFromFeed(YTPlayer.videoID, YTPlayer);
296
-
297
- jQuery(document).on("getVideoInfo_" + YTPlayer.opt.id, function () {
298
-
299
- if(isDevice && !YTPlayer.isBackground){
300
- new YT.Player(playerID, {
301
- height: '100%',
302
- width: '100%',
303
- videoId: YTPlayer.videoID,
304
- events: {
305
- 'onReady': function(){
306
- $YTPlayer.optimizeDisplay();
307
- playerBox.css({opacity: 1});
308
- YTPlayer.wrapper.css({opacity: 1});
309
- $YTPlayer.optimizeDisplay();
310
- },
311
- 'onStateChange': function(){}
312
- }
313
- });
314
- return;
315
- }
316
-
317
- new YT.Player(playerID, {
318
- videoId : YTPlayer.videoID.toString(),
319
- playerVars: playerVars,
320
- events : {
321
- 'onReady': function (event) {
322
-
323
- YTPlayer.player = event.target;
324
-
325
- if(YTPlayer.isReady)
326
- return;
327
-
328
- YTPlayer.isReady = true;
329
-
330
- YTPlayer.playerEl = YTPlayer.player.getIframe();
331
- $YTPlayer.optimizeDisplay();
332
-
333
- YTPlayer.videoID = videoID;
334
-
335
- jQuery(window).on("resize.YTP",function () {
336
- $YTPlayer.optimizeDisplay();
337
- });
338
-
339
- if (YTPlayer.opt.showControls)
340
- jQuery(YTPlayer).buildYTPControls();
341
-
342
- //YTPlayer.player.setPlaybackQuality(YTPlayer.opt.quality);
343
-
344
- if (YTPlayer.opt.startAt > 0)
345
- YTPlayer.player.seekTo(parseFloat(YTPlayer.opt.startAt), true);
346
-
347
- if (!YTPlayer.opt.autoPlay) {
348
-
349
- $YTPlayer.stopYTP();
350
- YTPlayer.checkForStartAt = setInterval(function () {
351
- if (YTPlayer.player.getCurrentTime() >= YTPlayer.opt.startAt) {
352
- clearInterval(YTPlayer.checkForStartAt);
353
- $YTPlayer.pauseYTP();
354
-
355
- if (YTPlayer.opt.mute) {
356
- jQuery(YTPlayer).muteYTPVolume();
357
- }else{
358
- jQuery(YTPlayer).unmuteYTPVolume();
359
- }
360
- }
361
- }, 1);
362
-
363
- } else {
364
- $YTPlayer.playYTP();
365
- YTPlayer.player.setVolume(YTPlayer.opt.vol);
366
-
367
- if (YTPlayer.opt.mute) {
368
- jQuery(YTPlayer).muteYTPVolume();
369
- }else{
370
- jQuery(YTPlayer).unmuteYTPVolume();
371
- }
372
- }
373
-
374
- if (typeof YTPlayer.opt.onReady == "function")
375
- YTPlayer.opt.onReady($YTPlayer);
376
-
377
- jQuery.mbYTPlayer.checkForState(YTPlayer);
378
-
379
- },
380
-
381
- 'onStateChange' : function (event) {
382
-
383
- /*
384
- -1 (unstarted)
385
- 0 (ended)
386
- 1 (playing)
387
- 2 (paused)
388
- 3 (buffering)
389
- 5 (video cued).
390
- */
391
-
392
- if (typeof event.target.getPlayerState != "function")
393
- return;
394
- var state = event.target.getPlayerState();
395
-
396
- if (typeof YTPlayer.opt.onStateChange == "function")
397
- YTPlayer.opt.onStateChange($YTPlayer, state);
398
-
399
- var playerBox = jQuery(YTPlayer.playerEl);
400
- var controls = jQuery("#controlBar_" + YTPlayer.id);
401
-
402
- var data = YTPlayer.opt;
403
-
404
- if (state == 0) { // end
405
- if (YTPlayer.state == state)
406
- return;
407
-
408
- YTPlayer.state = state;
409
- YTPlayer.player.pauseVideo();
410
- var startAt = YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1;
411
-
412
- if (data.loop) {
413
- YTPlayer.wrapper.css({opacity: 0});
414
- $YTPlayer.playYTP();
415
- YTPlayer.player.seekTo(startAt,true);
416
-
417
- } else if (!YTPlayer.isBackground) {
418
- YTPlayer.player.seekTo(startAt, true);
419
- $YTPlayer.playYTP();
420
- setTimeout(function () {
421
- $YTPlayer.pauseYTP();
422
- }, 10);
423
- }
424
-
425
- if (!data.loop && YTPlayer.isBackground)
426
- YTPlayer.wrapper.CSSAnimate({opacity: 0}, 2000);
427
- else if (data.loop) {
428
- YTPlayer.wrapper.css({opacity: 0});
429
- YTPlayer.loop++;
430
- }
431
-
432
- controls.find(".mb_YTVPPlaypause").html(jQuery.mbYTPlayer.controls.play);
433
- jQuery(YTPlayer).trigger("YTPEnd");
434
- }
435
-
436
- if (state == 3) { // buffering
437
- if (YTPlayer.state == state)
438
- return;
439
- YTPlayer.state = state;
440
- controls.find(".mb_YTVPPlaypause").html(jQuery.mbYTPlayer.controls.play);
441
- jQuery(YTPlayer).trigger("YTPBuffering");
442
- }
443
-
444
- if (state == -1) { // unstarted
445
- if (YTPlayer.state == state)
446
- return;
447
- YTPlayer.state = state;
448
-
449
- YTPlayer.wrapper.css({opacity:0});
450
-
451
- jQuery(YTPlayer).trigger("YTPUnstarted");
452
- }
453
-
454
- if (state == 1) { // play
455
- if (YTPlayer.state == state)
456
- return;
457
- YTPlayer.state = state;
458
- YTPlayer.player.setPlaybackQuality(YTPlayer.opt.quality);
459
-
460
- if(YTPlayer.opt.mute){
461
- $YTPlayer.muteYTPVolume();
462
- YTPlayer.opt.mute = false;
463
- }
464
-
465
- if (YTPlayer.opt.autoPlay && YTPlayer.loop == 0) {
466
- YTPlayer.wrapper.CSSAnimate({opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity}, 2000);
467
- } else if(!YTPlayer.isBackground) {
468
- YTPlayer.wrapper.css({opacity: YTPlayer.isAlone ? 1 : YTPlayer.opt.opacity});
469
- $YTPlayer.css({background: "rgba(0,0,0,0.5)"});
470
- }else{
471
- setTimeout(function () {
472
- jQuery(YTPlayer.playerEl).CSSAnimate({opacity: 1}, 2000);
473
- YTPlayer.wrapper.CSSAnimate({opacity: YTPlayer.opt.opacity}, 2000);
474
- }, 1000);
475
- }
476
-
477
- controls.find(".mb_YTVPPlaypause").html(jQuery.mbYTPlayer.controls.pause);
478
-
479
- jQuery(YTPlayer).trigger("YTPStart");
480
- }
481
-
482
- if (state == 2) { // pause
483
- if (YTPlayer.state == state)
484
- return;
485
- YTPlayer.state = state;
486
- controls.find(".mb_YTVPPlaypause").html(jQuery.mbYTPlayer.controls.play);
487
- jQuery(YTPlayer).trigger("YTPPause");
488
- }
489
- },
490
- 'onPlaybackQualityChange': function (e) {
491
- if (typeof YTPlayer.opt.onPlaybackQualityChange == "function")
492
- YTPlayer.opt.onPlaybackQualityChange($YTPlayer);
493
- },
494
- 'onError' : function (err) {
495
-
496
- if(err.data == 2 && YTPlayer.isPlayList)
497
- jQuery(YTPlayer).playNext();
498
-
499
- if (typeof YTPlayer.opt.onError == "function")
500
- YTPlayer.opt.onError($YTPlayer, err);
501
- }
502
- }
503
- });
504
- });
505
- })
506
- });
507
- },
508
-
509
- getDataFromFeed: function (videoID, YTPlayer) {
510
- //Get video info from FEEDS API
511
-
512
- YTPlayer.videoID = videoID;
513
- if (!jQuery.browser.msie) { //!(jQuery.browser.msie && jQuery.browser.version<9)
514
-
515
- jQuery.getJSON('http://gdata.youtube.com/feeds/api/videos/' + videoID + '?v=2&alt=jsonc', function (data, status, xhr) {
516
-
517
- YTPlayer.dataReceived = true;
518
-
519
- var videoData = data.data;
520
-
521
- YTPlayer.title = videoData.title;
522
- YTPlayer.videoData = videoData;
523
-
524
- if (YTPlayer.opt.ratio == "auto")
525
- if (videoData.aspectRatio && videoData.aspectRatio === "widescreen")
526
- YTPlayer.opt.ratio = "16/9";
527
- else
528
- YTPlayer.opt.ratio = "4/3";
529
-
530
- if(!YTPlayer.isInit){
531
-
532
- YTPlayer.isInit = true;
533
-
534
- if (!YTPlayer.isBackground) {
535
- var bgndURL = YTPlayer.videoData.thumbnail.hqDefault;
536
-
537
- jQuery(YTPlayer).css({background: "rgba(0,0,0,0.5) url(" + bgndURL + ") center center", backgroundSize: "cover"});
538
- }
539
-
540
- jQuery(document).trigger("getVideoInfo_" + YTPlayer.opt.id);
541
- }
542
- jQuery(YTPlayer).trigger("YTPChanged");
543
- });
544
-
545
- setTimeout(function(){
546
- if(!YTPlayer.dataReceived && !YTPlayer.isInit){
547
- YTPlayer.isInit = true;
548
- jQuery(document).trigger("getVideoInfo_" + YTPlayer.opt.id);
549
- }
550
- },2500)
551
-
552
- } else {
553
- YTPlayer.opt.ratio == "auto" ? YTPlayer.opt.ratio = "16/9" : YTPlayer.opt.ratio;
554
-
555
- if(!YTPlayer.isInit){
556
- YTPlayer.isInit = true;
557
- setTimeout(function(){
558
- jQuery(document).trigger("getVideoInfo_" + YTPlayer.opt.id);
559
- },100)
560
-
561
- }
562
- jQuery(YTPlayer).trigger("YTPChanged");
563
- }
564
- },
565
-
566
- getVideoID: function(){
567
- var YTPlayer = this.get(0);
568
- return YTPlayer.videoID || false ;
569
- },
570
-
571
- setVideoQuality: function(quality){
572
- var YTPlayer = this.get(0);
573
- YTPlayer.player.setPlaybackQuality(quality);
574
- },
575
-
576
- YTPlaylist : function(videos, shuffle, callback){
577
- var YTPlayer = this.get(0);
578
-
579
- YTPlayer.isPlayList = true;
580
-
581
- if(shuffle)
582
- videos = jQuery.shuffle(videos);
583
-
584
- if(!YTPlayer.videoID){
585
- YTPlayer.videos = videos;
586
- YTPlayer.videoCounter = 0;
587
- YTPlayer.videoLength = videos.length;
588
-
589
- jQuery(YTPlayer).data("property", videos[0]);
590
- jQuery(YTPlayer).mb_YTPlayer();
591
- }
592
-
593
- if(typeof callback == "function")
594
- jQuery(YTPlayer).on("YTPChanged",function(){
595
- callback(YTPlayer);
596
- });
597
-
598
- jQuery(YTPlayer).on("YTPEnd", function(){
599
- jQuery(YTPlayer).playNext();
600
- });
601
- },
602
-
603
- playNext: function(){
604
- var YTPlayer = this.get(0);
605
- YTPlayer.videoCounter++;
606
- if(YTPlayer.videoCounter>=YTPlayer.videoLength)
607
- YTPlayer.videoCounter = 0;
608
- jQuery(YTPlayer.playerEl).css({opacity:0});
609
- jQuery(YTPlayer).changeMovie(YTPlayer.videos[YTPlayer.videoCounter]);
610
- },
611
-
612
- changeMovie: function (opt) {
613
- var YTPlayer = this.get(0);
614
- var data = YTPlayer.opt;
615
- if (opt) {
616
- jQuery.extend(data, opt);
617
- }
618
-
619
- YTPlayer.videoID = data.videoURL.getVideoID();
620
-
621
- jQuery(YTPlayer).pauseYTP();
622
- var timer = jQuery.browser.msie ? 1000 : 0;
623
- jQuery(YTPlayer).getPlayer().cueVideoByUrl(encodeURI("http://www.youtube.com/v/" + YTPlayer.videoID) , 5 , YTPlayer.opt.quality);
624
-
625
- setTimeout(function(){
626
- jQuery(YTPlayer).playYTP();
627
- jQuery(YTPlayer).one("YTPStart", function(){
628
- jQuery(YTPlayer.playerEl).CSSAnimate({opacity:1},2000);
629
- });
630
-
631
- },timer)
632
-
633
- if (YTPlayer.opt.mute) {
634
- jQuery(YTPlayer).muteYTPVolume();
635
- }else{
636
- jQuery(YTPlayer).unmuteYTPVolume();
637
- }
638
-
639
- if (YTPlayer.opt.addRaster) {
640
- var retina = (window.retina || window.devicePixelRatio > 1);
641
- YTPlayer.overlay.addClass(retina ? "raster retina" : "raster");
642
- }else{
643
- YTPlayer.overlay.removeClass("raster");
644
- YTPlayer.overlay.removeClass("retina");
645
- }
646
-
647
- jQuery("#controlBar_" + YTPlayer.id).remove();
648
-
649
- if (YTPlayer.opt.showControls)
650
- jQuery(YTPlayer).buildYTPControls();
651
-
652
- jQuery.mbYTPlayer.getDataFromFeed(YTPlayer.videoID, YTPlayer);
653
- jQuery(YTPlayer).optimizeDisplay();
654
- jQuery.mbYTPlayer.checkForState(YTPlayer);
655
-
656
- },
657
-
658
- getPlayer: function () {
659
- return jQuery(this).get(0).player;
660
- },
661
-
662
- playerDestroy: function () {
663
- var YTPlayer = this.get(0);
664
- ytp.YTAPIReady = false;
665
- ytp.isInit = false;
666
- YTPlayer.opt.isInit = false;
667
- YTPlayer.videoID = null;
668
-
669
- var playerBox = YTPlayer.wrapper;
670
- playerBox.remove();
671
- jQuery("#controlBar_" + YTPlayer.id).remove();
672
- },
673
-
674
- fullscreen: function(real) {
675
-
676
- var YTPlayer = this.get(0);
677
-
678
- var controls = jQuery("#controlBar_" + YTPlayer.id);
679
- var fullScreenBtn = controls.find(".mb_OnlyYT");
680
- var videoWrapper = jQuery(YTPlayer.wrapper);
681
- if(real){
682
- var fullscreenchange = jQuery.browser.mozilla ? "mozfullscreenchange" : jQuery.browser.webkit ? "webkitfullscreenchange" : "fullscreenchange";
683
- jQuery(document).off(fullscreenchange);
684
- jQuery(document).on(fullscreenchange, function() {
685
- var isFullScreen = RunPrefixMethod(document, "IsFullScreen") || RunPrefixMethod(document, "FullScreen");
686
-
687
- if (!isFullScreen) {
688
- jQuery(YTPlayer).removeClass("fullscreen");
689
- YTPlayer.isAlone = false;
690
- fullScreenBtn.html(jQuery.mbYTPlayer.controls.onlyYT)
691
- jQuery(YTPlayer).setVideoQuality(YTPlayer.opt.quality);
692
-
693
- if (YTPlayer.isBackground){
694
- jQuery("body").after(controls);
695
- }else{
696
- YTPlayer.wrapper.before(controls);
697
- }
698
- }else{
699
- jQuery(YTPlayer).setVideoQuality("default");
700
- }
701
- });
702
- }
703
-
704
- if (!YTPlayer.isAlone) {
705
-
706
- if (YTPlayer.player.getPlayerState() >= 1) {
707
-
708
- if(YTPlayer.player.getPlayerState() != 1 && YTPlayer.player.getPlayerState() != 2)
709
- jQuery(YTPlayer).playYTP();
710
-
711
- if(real){
712
- YTPlayer.wrapper.append(controls);
713
- jQuery(YTPlayer).addClass("fullscreen");
714
- launchFullscreen(videoWrapper.get(0));
715
- } else
716
- videoWrapper.css({zIndex: 10000}).CSSAnimate({opacity: 1}, 1000, 0);
717
-
718
- jQuery(YTPlayer).trigger("YTPFullScreenStart");
719
-
720
- fullScreenBtn.html(jQuery.mbYTPlayer.controls.showSite)
721
- YTPlayer.isAlone = true;
722
- }
723
-
724
- } else {
725
-
726
- if(real){
727
- cancelFullscreen();
728
- } else{
729
- videoWrapper.CSSAnimate({opacity: YTPlayer.opt.opacity}, 500);
730
- }
731
-
732
- jQuery(YTPlayer).trigger("YTPFullScreenEnd");
733
-
734
- videoWrapper.css({zIndex: -1});
735
- fullScreenBtn.html(jQuery.mbYTPlayer.controls.onlyYT)
736
- YTPlayer.isAlone = false;
737
- }
738
-
739
- function RunPrefixMethod(obj, method) {
740
- var pfx = ["webkit", "moz", "ms", "o", ""];
741
- var p = 0, m, t;
742
- while (p < pfx.length && !obj[m]) {
743
- m = method;
744
- if (pfx[p] == "") {
745
- m = m.substr(0,1).toLowerCase() + m.substr(1);
746
- }
747
- m = pfx[p] + m;
748
- t = typeof obj[m];
749
- if (t != "undefined") {
750
- pfx = [pfx[p]];
751
- return (t == "function" ? obj[m]() : obj[m]);
752
- }
753
- p++;
754
- }
755
- }
756
-
757
- function launchFullscreen(element) {
758
- RunPrefixMethod(element, "RequestFullScreen");
759
- }
760
-
761
- function cancelFullscreen() {
762
- if (RunPrefixMethod(document, "FullScreen") || RunPrefixMethod(document, "IsFullScreen")) {
763
- RunPrefixMethod(document, "CancelFullScreen");
764
- }
765
- }
766
- },
767
-
768
- playYTP: function () {
769
- var YTPlayer = this.get(0);
770
- var controls = jQuery("#controlBar_" + YTPlayer.id);
771
- var playBtn = controls.find(".mb_YTVPPlaypause");
772
- playBtn.html(jQuery.mbYTPlayer.controls.pause);
773
- YTPlayer.player.playVideo();
774
-
775
- YTPlayer.wrapper.CSSAnimate({opacity: YTPlayer.opt.opacity}, 2000);
776
- $(YTPlayer).on("YTPStart", function(){
777
- jQuery(YTPlayer).css("background", "none");
778
- })
779
- },
780
-
781
- toggleLoops: function () {
782
- var YTPlayer = this.get(0);
783
- var data = YTPlayer.opt;
784
- if (data.loop == 1) {
785
- data.loop = 0;
786
- } else {
787
- if(data.startAt) {
788
- YTPlayer.player.seekTo(data.startAt);
789
- } else {
790
- YTPlayer.player.playVideo();
791
- }
792
- data.loop = 1;
793
- }
794
- },
795
-
796
- stopYTP: function () {
797
- var YTPlayer = this.get(0);
798
- var controls = jQuery("#controlBar_" + YTPlayer.id);
799
- var playBtn = controls.find(".mb_YTVPPlaypause");
800
- playBtn.html(jQuery.mbYTPlayer.controls.play);
801
- YTPlayer.player.stopVideo();
802
- },
803
-
804
- pauseYTP: function () {
805
- var YTPlayer = this.get(0);
806
- var data = YTPlayer.opt;
807
- var controls = jQuery("#controlBar_" + YTPlayer.id);
808
- var playBtn = controls.find(".mb_YTVPPlaypause");
809
- playBtn.html(jQuery.mbYTPlayer.controls.play);
810
- YTPlayer.player.pauseVideo();
811
- },
812
-
813
- setYTPVolume: function (val) {
814
- var YTPlayer = this.get(0);
815
- if (!val && !YTPlayer.opt.vol && player.getVolume() == 0)
816
- jQuery(YTPlayer).unmuteYTPVolume();
817
- else if ((!val && YTPlayer.player.getVolume() > 0) || (val && YTPlayer.player.getVolume() == val))
818
- jQuery(YTPlayer).muteYTPVolume();
819
- else
820
- YTPlayer.opt.vol = val;
821
- YTPlayer.player.setVolume(YTPlayer.opt.vol);
822
- },
823
-
824
- muteYTPVolume: function () {
825
- var YTPlayer = this.get(0);
826
- YTPlayer.opt.vol = YTPlayer.player.getVolume() || 50;
827
- YTPlayer.player.mute();
828
- YTPlayer.player.setVolume(0);
829
- var controls = jQuery("#controlBar_" + YTPlayer.id);
830
- var muteBtn = controls.find(".mb_YTVPMuteUnmute");
831
- muteBtn.html(jQuery.mbYTPlayer.controls.unmute);
832
- },
833
-
834
- unmuteYTPVolume: function () {
835
- var YTPlayer = this.get(0);
836
-
837
- YTPlayer.player.unMute();
838
- YTPlayer.player.setVolume(YTPlayer.opt.vol);
839
-
840
- var controls = jQuery("#controlBar_" + YTPlayer.id);
841
- var muteBtn = controls.find(".mb_YTVPMuteUnmute");
842
- muteBtn.html(jQuery.mbYTPlayer.controls.mute);
843
- },
844
-
845
- manageYTPProgress: function () {
846
- var YTPlayer = this.get(0);
847
- var controls = jQuery("#controlBar_" + YTPlayer.id);
848
- var progressBar = controls.find(".mb_YTVPProgress");
849
- var loadedBar = controls.find(".mb_YTVPLoaded");
850
- var timeBar = controls.find(".mb_YTVTime");
851
- var totW = progressBar.outerWidth();
852
-
853
- var currentTime = Math.floor(YTPlayer.player.getCurrentTime());
854
- var totalTime = Math.floor(YTPlayer.player.getDuration());
855
- var timeW = (currentTime * totW) / totalTime;
856
- var startLeft = 0;
857
-
858
- var loadedW = YTPlayer.player.getVideoLoadedFraction() * 100;
859
-
860
- loadedBar.css({left: startLeft, width: loadedW + "%"});
861
- timeBar.css({left: 0, width: timeW});
862
- return {totalTime: totalTime, currentTime: currentTime};
863
- },
864
-
865
- buildYTPControls: function () {
866
- var YTPlayer = this.get(0);
867
- var data = YTPlayer.opt;
868
-
869
- if(jQuery("#controlBar_"+ YTPlayer.id).length)
870
- return;
871
-
872
- var controlBar = jQuery("<span/>").attr("id", "controlBar_" + YTPlayer.id).addClass("mb_YTVPBar").css({whiteSpace: "noWrap", position: YTPlayer.isBackground ? "fixed" : "absolute", zIndex: YTPlayer.isBackground ? 10000 : 1000}).hide();
873
- var buttonBar = jQuery("<div/>").addClass("buttonBar");
874
- var playpause = jQuery("<span>" + jQuery.mbYTPlayer.controls.play + "</span>").addClass("mb_YTVPPlaypause ytpicon").click(function () {
875
- if (YTPlayer.player.getPlayerState() == 1)
876
- jQuery(YTPlayer).pauseYTP();
877
- else
878
- jQuery(YTPlayer).playYTP();
879
- });
880
-
881
- var MuteUnmute = jQuery("<span>" + jQuery.mbYTPlayer.controls.mute + "</span>").addClass("mb_YTVPMuteUnmute ytpicon").click(function () {
882
- if (YTPlayer.player.getVolume()==0) {
883
- jQuery(YTPlayer).unmuteYTPVolume();
884
- } else {
885
- jQuery(YTPlayer).muteYTPVolume();
886
- }
887
- });
888
-
889
- var idx = jQuery("<span/>").addClass("mb_YTVPTime");
890
-
891
- var vURL = data.videoURL;
892
- if(vURL.indexOf("http") < 0)
893
- vURL = "http://www.youtube.com/watch?v="+data.videoURL;
894
- var movieUrl = jQuery("<span/>").html(jQuery.mbYTPlayer.controls.ytLogo).addClass("mb_YTVPUrl ytpicon").attr("title", "view on YouTube").on("click", function () {window.open(vURL, "viewOnYT")});
895
- var onlyVideo = jQuery("<span/>").html(jQuery.mbYTPlayer.controls.onlyYT).addClass("mb_OnlyYT ytpicon").on("click",function () {jQuery(YTPlayer).fullscreen(data.realfullscreen);});
896
-
897
- var progressBar = jQuery("<div/>").addClass("mb_YTVPProgress").css("position", "absolute").click(function (e) {
898
- timeBar.css({width: (e.clientX - timeBar.offset().left)});
899
- YTPlayer.timeW = e.clientX - timeBar.offset().left;
900
- controlBar.find(".mb_YTVPLoaded").css({width: 0});
901
- var totalTime = Math.floor(YTPlayer.player.getDuration());
902
- YTPlayer.goto = (timeBar.outerWidth() * totalTime) / progressBar.outerWidth();
903
-
904
- YTPlayer.player.seekTo(parseFloat(YTPlayer.goto), true);
905
- controlBar.find(".mb_YTVPLoaded").css({width: 0});
906
- });
907
-
908
- var loadedBar = jQuery("<div/>").addClass("mb_YTVPLoaded").css("position", "absolute");
909
- var timeBar = jQuery("<div/>").addClass("mb_YTVTime").css("position", "absolute");
910
-
911
- progressBar.append(loadedBar).append(timeBar);
912
- buttonBar.append(playpause).append(MuteUnmute).append(idx);
913
-
914
- if (data.printUrl){
915
- buttonBar.append(movieUrl);
916
- }
917
-
918
- if (YTPlayer.isBackground || (YTPlayer.opt.realfullscreen && !YTPlayer.isBackground))
919
- buttonBar.append(onlyVideo);
920
-
921
- controlBar.append(buttonBar).append(progressBar);
922
-
923
- if (!YTPlayer.isBackground) {
924
- controlBar.addClass("inlinePlayer");
925
- YTPlayer.wrapper.before(controlBar);
926
- } else {
927
- jQuery("body").after(controlBar);
928
- }
929
- controlBar.fadeIn();
930
-
931
- },
932
-
933
- checkForState:function(YTPlayer){
934
-
935
- var controlBar = jQuery("#controlBar_" + YTPlayer.id);
936
- var data = YTPlayer.opt;
937
- var startAt = YTPlayer.opt.startAt ? YTPlayer.opt.startAt : 1;
938
-
939
- YTPlayer.getState = setInterval(function () {
940
- var prog = jQuery(YTPlayer).manageYTPProgress();
941
-
942
- controlBar.find(".mb_YTVPTime").html(jQuery.mbYTPlayer.formatTime(prog.currentTime) + " / " + jQuery.mbYTPlayer.formatTime(prog.totalTime));
943
- if (parseFloat(YTPlayer.player.getDuration() - 3) < YTPlayer.player.getCurrentTime() && YTPlayer.player.getPlayerState() == 1 && !YTPlayer.isPlayList) {
944
- if(!data.loop){
945
- YTPlayer.player.pauseVideo();
946
- YTPlayer.wrapper.CSSAnimate({opacity: 0}, 2000,function(){
947
- YTPlayer.player.seekTo(startAt);
948
-
949
- if (!YTPlayer.isBackground) {
950
- var bgndURL = YTPlayer.videoData.thumbnail.hqDefault;
951
- jQuery(YTPlayer).css({background: "rgba(0,0,0,0.5) url(" + bgndURL + ") center center", backgroundSize: "cover"});
952
- }
953
- });
954
- }else
955
- YTPlayer.player.seekTo(startAt);
956
- jQuery(YTPlayer).trigger("YTPEnd");
957
- }
958
- }, 1);
959
-
960
- },
961
-
962
- formatTime : function (s) {
963
- var min = Math.floor(s / 60);
964
- var sec = Math.floor(s - (60 * min));
965
- return (min < 9 ? "0" + min : min) + " : " + (sec < 9 ? "0" + sec : sec);
966
- }
967
- };
968
-
969
- jQuery.fn.toggleVolume = function () {
970
- var YTPlayer = this.get(0);
971
- if (!YTPlayer)
972
- return;
973
-
974
- if (YTPlayer.player.isMuted()) {
975
- jQuery(YTPlayer).unmuteYTPVolume();
976
- return true;
977
- } else {
978
- jQuery(YTPlayer).muteYTPVolume();
979
- return false;
980
- }
981
- };
982
-
983
- jQuery.fn.optimizeDisplay = function () {
984
- var YTPlayer = this.get(0);
985
- var data = YTPlayer.opt;
986
- var playerBox = jQuery(YTPlayer.playerEl);
987
- var win = {};
988
- var el = !YTPlayer.isBackground ? data.containment : jQuery(window);
989
-
990
- win.width = el.width();
991
- win.height = el.height();
992
-
993
- var margin = 24;
994
- var vid = {};
995
- vid.width = win.width + ((win.width * margin) / 100);
996
- vid.height = data.ratio == "16/9" ? Math.ceil((9 * win.width) / 16) : Math.ceil((3 * win.width) / 4);
997
- vid.marginTop = -((vid.height - win.height) / 2);
998
- vid.marginLeft = -((win.width * (margin / 2)) / 100);
999
-
1000
- if (vid.height < win.height) {
1001
- vid.height = win.height + ((win.height * margin) / 100);
1002
- vid.width = data.ratio == "16/9" ? Math.floor((16 * win.height) / 9) : Math.floor((4 * win.height) / 3);
1003
- vid.marginTop = -((win.height * (margin / 2)) / 100);
1004
- vid.marginLeft = -((vid.width - win.width) / 2);
1005
- }
1006
- playerBox.css({width: vid.width, height: vid.height, marginTop: vid.marginTop, marginLeft: vid.marginLeft});
1007
- };
1008
-
1009
- jQuery.shuffle = function(arr) {
1010
- var newArray = arr.slice();
1011
- var len = newArray.length;
1012
- var i = len;
1013
- while (i--) {
1014
- var p = parseInt(Math.random()*len);
1015
- var t = newArray[i];
1016
- newArray[i] = newArray[p];
1017
- newArray[p] = t;
1018
- }
1019
- return newArray;
1020
- };
1021
-
1022
- jQuery.fn.mb_YTPlayer = jQuery.mbYTPlayer.buildPlayer;
1023
- jQuery.fn.YTPlaylist = jQuery.mbYTPlayer.YTPlaylist;
1024
- jQuery.fn.playNext = jQuery.mbYTPlayer.playNext;
1025
- jQuery.fn.changeMovie = jQuery.mbYTPlayer.changeMovie;
1026
- jQuery.fn.getVideoID = jQuery.mbYTPlayer.getVideoID;
1027
- jQuery.fn.getPlayer = jQuery.mbYTPlayer.getPlayer;
1028
- jQuery.fn.playerDestroy = jQuery.mbYTPlayer.playerDestroy;
1029
- jQuery.fn.fullscreen = jQuery.mbYTPlayer.fullscreen;
1030
- jQuery.fn.buildYTPControls = jQuery.mbYTPlayer.buildYTPControls;
1031
- jQuery.fn.playYTP = jQuery.mbYTPlayer.playYTP;
1032
- jQuery.fn.toggleLoops = jQuery.mbYTPlayer.toggleLoops;
1033
- jQuery.fn.stopYTP = jQuery.mbYTPlayer.stopYTP;
1034
- jQuery.fn.pauseYTP = jQuery.mbYTPlayer.pauseYTP;
1035
- jQuery.fn.muteYTPVolume = jQuery.mbYTPlayer.muteYTPVolume;
1036
- jQuery.fn.unmuteYTPVolume = jQuery.mbYTPlayer.unmuteYTPVolume;
1037
- jQuery.fn.setYTPVolume = jQuery.mbYTPlayer.setYTPVolume;
1038
- jQuery.fn.setVideoQuality = jQuery.mbYTPlayer.setVideoQuality;
1039
- jQuery.fn.manageYTPProgress = jQuery.mbYTPlayer.manageYTPProgress;
1040
-
1041
- })(jQuery);