news_reader 0.1.0

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 (81) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +12 -0
  3. data/.rspec +3 -0
  4. data/.travis.yml +5 -0
  5. data/.vscode/settings.json +3 -0
  6. data/CODE_OF_CONDUCT.md +74 -0
  7. data/Gemfile +6 -0
  8. data/Gemfile.lock +97 -0
  9. data/LICENSE.txt +21 -0
  10. data/README.md +41 -0
  11. data/Rakefile +6 -0
  12. data/bin/console +14 -0
  13. data/bin/news-reader +6 -0
  14. data/bin/setup +8 -0
  15. data/fixtures/.DS_Store +0 -0
  16. data/fixtures/blog/index.html +200 -0
  17. data/fixtures/blog/index_files/Box.css +29 -0
  18. data/fixtures/blog/index_files/Java_Box.js +89 -0
  19. data/fixtures/blog/index_files/ModuleStyleSheets.css +1655 -0
  20. data/fixtures/blog/index_files/black.css +11 -0
  21. data/fixtures/blog/index_files/blog-jive.jpg +0 -0
  22. data/fixtures/blog/index_files/blog-musolfs.jpg +0 -0
  23. data/fixtures/blog/index_files/blog-poolpak.jpg +0 -0
  24. data/fixtures/blog/index_files/blog-portalaudit.png +0 -0
  25. data/fixtures/blog/index_files/blog-semicolon1.jpg +0 -0
  26. data/fixtures/blog/index_files/blog-semicolon2.jpg +0 -0
  27. data/fixtures/blog/index_files/blog-spa1.jpg +0 -0
  28. data/fixtures/blog/index_files/blog-spa2.jpg +0 -0
  29. data/fixtures/blog/index_files/blog-statera.jpg +0 -0
  30. data/fixtures/blog/index_files/blue.css +11 -0
  31. data/fixtures/blog/index_files/common.js +149 -0
  32. data/fixtures/blog/index_files/dark.css +31 -0
  33. data/fixtures/blog/index_files/featherlight.min.css +8 -0
  34. data/fixtures/blog/index_files/featherlight.min.js +8 -0
  35. data/fixtures/blog/index_files/font-awesome.min.css +4 -0
  36. data/fixtures/blog/index_files/green.css +11 -0
  37. data/fixtures/blog/index_files/isotope.css +64 -0
  38. data/fixtures/blog/index_files/jquery-ui.min.js +5 -0
  39. data/fixtures/blog/index_files/jquery.carouFredSel-6.2.1-packed.js +16 -0
  40. data/fixtures/blog/index_files/jquery.contentcarousel.js +137 -0
  41. data/fixtures/blog/index_files/jquery.easing.1.3.js +205 -0
  42. data/fixtures/blog/index_files/jquery.form.js +1121 -0
  43. data/fixtures/blog/index_files/jquery.hoverdir.js +220 -0
  44. data/fixtures/blog/index_files/jquery.inview.js +60 -0
  45. data/fixtures/blog/index_files/jquery.isotope.min.js +11 -0
  46. data/fixtures/blog/index_files/jquery.magnific-popup.js +2046 -0
  47. data/fixtures/blog/index_files/jquery.mb.YTPlayer.js +1041 -0
  48. data/fixtures/blog/index_files/jquery.min.js +5 -0
  49. data/fixtures/blog/index_files/jquery.nav.js +223 -0
  50. data/fixtures/blog/index_files/jquery.smoothwheel.js +153 -0
  51. data/fixtures/blog/index_files/jquery.sticky.js +129 -0
  52. data/fixtures/blog/index_files/jquery.superslides.js +656 -0
  53. data/fixtures/blog/index_files/jquery.validate.js +1231 -0
  54. data/fixtures/blog/index_files/jquery.vegas.css +34 -0
  55. data/fixtures/blog/index_files/js +201 -0
  56. data/fixtures/blog/index_files/loading.gif +0 -0
  57. data/fixtures/blog/index_files/magnific-popup.css +365 -0
  58. data/fixtures/blog/index_files/main.css +301 -0
  59. data/fixtures/blog/index_files/main.js +26 -0
  60. data/fixtures/blog/index_files/modernizr-2.6.2.min.js +4 -0
  61. data/fixtures/blog/index_files/normalize.css +533 -0
  62. data/fixtures/blog/index_files/ohp3fra.js +44 -0
  63. data/fixtures/blog/index_files/orange.css +11 -0
  64. data/fixtures/blog/index_files/paralax.js +525 -0
  65. data/fixtures/blog/index_files/paralaxNEW4.css +2730 -0
  66. data/fixtures/blog/index_files/plugins.js +221 -0
  67. data/fixtures/blog/index_files/portfolio.js +142 -0
  68. data/fixtures/blog/index_files/purple.css +11 -0
  69. data/fixtures/blog/index_files/red.css +11 -0
  70. data/fixtures/blog/index_files/responsive3.css +329 -0
  71. data/fixtures/blog/index_files/superslides.css +65 -0
  72. data/fixtures/blog/index_files/turquoise.css +11 -0
  73. data/fixtures/blog/index_files/util.js +287 -0
  74. data/fixtures/blog/index_files/yellow.css +11 -0
  75. data/lib/news_reader/article.rb +60 -0
  76. data/lib/news_reader/cli.rb +41 -0
  77. data/lib/news_reader/scraper.rb +17 -0
  78. data/lib/news_reader/version.rb +3 -0
  79. data/lib/news_reader.rb +4 -0
  80. data/news_reader.gemspec +40 -0
  81. metadata +209 -0
@@ -0,0 +1,1041 @@
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);