define(['jquery','jquery-ui-modules/widget','catalogGallery','loadPlayer'],function($){'use strict';var allowBase=true;function parseHref(href){var a=document.createElement('a');a.href=href;return a;} function parseURL(href,forceVideo){var id,type,ampersandPosition,vimeoRegex,useYoutubeNocookie=false;function _getYoutubeId(srcid){if(srcid){ampersandPosition=srcid.indexOf('&');if(ampersandPosition===-1){return srcid;} srcid=srcid.substring(0,ampersandPosition);} return srcid;} if(typeof href!=='string'){return href;} href=parseHref(href);if(href.host.match(/youtube\.com/)&&href.search){id=href.search.split('v=')[1];if(id){id=_getYoutubeId(id);type='youtube';}}else if(href.host.match(/youtube\.com|youtu\.be|youtube-nocookie.com/)){id=href.pathname.replace(/^\/(embed\/|v\/)?/,'').replace(/\/.*/,'');type='youtube';if(href.host.match(/youtube-nocookie.com/)){useYoutubeNocookie=true;}}else if(href.host.match(/vimeo\.com/)){type='vimeo';vimeoRegex=new RegExp(['https?:\\/\\/(?:www\\.|player\\.)?vimeo.com\\/(?:channels\\/(?:\\w+\\/)','?|groups\\/([^\\/]*)\\/videos\\/|album\\/(\\d+)\\/video\\/|video\\/|)(\\d+)(?:$|\\/|\\?)'].join(''));id=href.href.match(vimeoRegex)[3];} if((!id||!type)&&forceVideo){id=href.href;type='custom';} return id?{id:id,type:type,s:href.search.replace(/^\?/,''),useYoutubeNocookie:useYoutubeNocookie}:false;} $.widget('mage.AddFotoramaVideoEvents',{options:{videoData:'',videoSettings:'',optionsVideoData:'',dataMergeStrategy:'replace'},onVimeoJSFramework:function(){},defaultVideoData:[],PV:'product-video',VU:'video-unplayed',PVLOADED:'fotorama__product-video--loaded',PVLOADING:'fotorama__product-video--loading',VID:'video',VI:'vimeo',FTVC:'fotorama__video-close',FTAR:'fotorama__arr',fotoramaSpinner:'fotorama__spinner',fotoramaSpinnerShow:'fotorama__spinner--show',TI:'video-thumb-icon',isFullscreen:false,FTCF:'[data-gallery-role="fotorama__fullscreen-icon"]',Base:0,MobileMaxWidth:768,GP:'gallery-placeholder',videoData:null,videoDataPlaceholder:[{id:'',isBase:true,mediaType:'image',provider:''}],_create:function(){$(this.element).data('gallery')?this._onGalleryLoaded():$(this.element).on('gallery:loaded',this._onGalleryLoaded.bind(this));},_initialize:function(){if(!this.defaultVideoData.length){this.defaultVideoData=this.options.videoData;} if(!this.defaultVideoData.length&&!this.options.videoData.length){this.defaultVideoData=this.options.videoData=this.videoDataPlaceholder;} this.clearEvents();if(this._checkForVideoExist()){this._checkFullscreen();this._listenForFullscreen();this._isVideoBase();this._initFotoramaVideo();this._attachFotoramaEvents();}},_onGalleryLoaded:function(){this.fotoramaItem=$(this.element).find('.fotorama-item');this._initialize();},clearEvents:function(){if(this.fotoramaItem!==undefined){this.fotoramaItem.off('fotorama:show.'+this.PV+' fotorama:showend.'+this.PV+' fotorama:fullscreenenter.'+this.PV+' fotorama:fullscreenexit.'+this.PV);}},_setOptions:function(options){if(options.videoData&&options.videoData.length){this.options.videoData=options.videoData;} this._loadVideoData(options);this._initialize();},_loadVideoData:function(options){if(options.selectedOption){if(options.dataMergeStrategy==='prepend'){this.options.videoData=[].concat(this.options.optionsVideoData[options.selectedOption],this.defaultVideoData);}else{this.options.videoData=this.options.optionsVideoData[options.selectedOption];}}else{this.options.videoData=this.defaultVideoData;}},_checkFullscreen:function(){if(this.fotoramaItem.data('fotorama').fullScreen||false){this.isFullscreen=true;}},_listenForFullscreen:function(){this.fotoramaItem.on('fotorama:fullscreenenter.'+this.PV,$.proxy(function(){this.isFullscreen=true;},this));this.fotoramaItem.on('fotorama:fullscreenexit.'+this.PV,$.proxy(function(){this.isFullscreen=false;this._hideVideoArrows();},this));},_createVideoData:function(inputData,isJSON){var videoData=[],dataUrl,tmpVideoData,tmpInputData,i;if(isJSON){inputData=JSON.parse(inputData);} for(i=0;i');this.fotoramaItem.css('position','relative');closeVideo=this.fotoramaItem.find('.'+this.FTVC);this._closeVideoSetEvents(closeVideo,fotorama);if(isBase&&this.options.videoData[fotorama.activeIndex].isBase&&$(window).width()>this.MobileMaxWidth){this._showCloseVideo();}},_hideCloseVideo:function(){this.fotoramaItem.find('.'+this.FTVC).removeClass('fotorama-show-control');},_showCloseVideo:function(){this.fotoramaItem.find('.'+this.FTVC).addClass('fotorama-show-control');},_closeVideoSetEvents:function($closeVideo,fotorama){$closeVideo.on('click',$.proxy(function(){this._unloadVideoPlayer(fotorama.activeFrame.$stageFrame.parent(),fotorama,true);this._hideCloseVideo();},this));},_checkForVideoExist:function(){var key,result,checker,videoSettings;if(!this.options.videoData){return false;} if(!this.options.videoSettings){return false;} result=this._createVideoData(this.options.videoData,false);checker=false;videoSettings=this.options.videoSettings[0];videoSettings.playIfBase=parseInt(videoSettings.playIfBase,10);videoSettings.showRelated=parseInt(videoSettings.showRelated,10);videoSettings.videoAutoRestart=parseInt(videoSettings.videoAutoRestart,10);for(key in result){if(result[key].mediaType===this.VID){checker=true;}} if(checker){this.options.videoData=result;} return checker;},_isVideoBase:function(){var allVideoData=this.options.videoData,videoItem,allVideoDataKeys,key,i;allVideoDataKeys=Object.keys(allVideoData);for(i=0;i');},_setVideoEvent:function($image,PV,fotorama,number){$image.find('.magnify-lens').remove();$image.off('click tap',$.proxy(this._clickHandler,this)).on('click tap',$.proxy(this._clickHandler,this));this._handleBaseVideo(fotorama,number);},_hideVideoArrows:function(){var arrows=$('.'+this.FTAR);arrows.removeClass('fotorama__arr--shown');arrows.removeClass('fotorama__arr--hidden');},_showLoader:function(){var spinner=this.fotoramaItem.find('.'+this.fotoramaSpinner);spinner.addClass(this.fotoramaSpinnerShow);this.fotoramaItem.data('fotorama').activeFrame.$stageFrame.addClass(this.PVLOADING);},_hideLoader:function(){var spinner=this.fotoramaItem.find('.'+this.fotoramaSpinner);spinner.removeClass(this.fotoramaSpinnerShow);this.fotoramaItem.data('fotorama').activeFrame.$stageFrame.removeClass(this.PVLOADING);},_clickHandler:function(event){var type;if($(event.target).hasClass(this.VU)&&$(event.target).find('iframe').length===0){$(event.target).removeClass(this.VU);type=$(event.target).find('.'+this.PV).data('type');if(type===this.VI){$(event.target).find('.'+this.PV).productVideoLoader();}else if(type===this.VI){this._showLoader();this.onVimeoJSFramework=function(){$(event.target).find('.'+this.PV).productVideoLoader();this._hideLoader();}.bind(this);}else{$(event.target).find('.'+this.PV).productVideoLoader();} $('.'+this.FTAR).addClass(this.isFullscreen?'fotorama__arr--shown':'fotorama__arr--hidden');$('.'+this.FTVC).addClass('fotorama-show-control');}},_handleBaseVideo:function(fotorama,srcNumber){var videoData=this.options.videoData,activeIndex=fotorama.activeIndex,number=parseInt(srcNumber,10),activeIndexIsBase=videoData[activeIndex];if(!this.Base){return;} if(activeIndexIsBase&&number===1&&$(window).width()>this.MobileMaxWidth){setTimeout($.proxy(function(){fotorama.requestFullScreen();this.fotoramaItem.data('fotorama').activeFrame.$stageFrame[0].trigger('click');this.Base=false;},this),50);}},_unloadVideoPlayer:function($wrapper,current,close){var self=this;if(!$wrapper){return;} $wrapper.find('.'+this.PVLOADED).removeClass(this.PVLOADED);this._hideLoader();$wrapper.find('.'+this.PV).each(function(){var $item=$(this).parent(),cloneVideoDiv,iframeElement=$(this).find('iframe'),currentIndex,itemIndex;if(iframeElement.length===0){return;} currentIndex=current.activeFrame.$stageFrame.index();itemIndex=$item.index();if(currentIndex===itemIndex&&!close){return;} if(currentIndex!==itemIndex&&close){return;} iframeElement.remove();cloneVideoDiv=$(this).clone();$(this).remove();$item.append(cloneVideoDiv);$item.addClass(self.VU);self._hideCloseVideo();self._hideVideoArrows();if(self.isFullscreen&&!self.fotoramaItem.data('fotorama').options.fullscreen.arrows){if($('.'+self.FTAR+'--prev').is(':focus')||$('.'+self.FTAR+'--next').is(':focus')){$(self.FTCF).trigger('focus');}}});}});return $.mage.AddFotoramaVideoEvents;});