adbanner-test/modules/ad_banner/_ad_banner_widget2_video.ht...

252 lines
9.8 KiB
Plaintext
Raw Normal View History

2021-09-02 02:40:58 +00:00
<div class="w-ad-banner ad-banner-widget-2 w-ba-banner ba-banner-widget-1 ba-banner-widget-youtube">
<div class="w-ad-banner__wrap w-ba-banner__wrap cycle-slideshow"
2021-04-10 15:16:17 +00:00
data-list="images"
data-level="0"
data-cycle-slides=".w-ba-banner__slide"
data-cycle-log="false"
data-overlay=".w-ad-banner__overlay_{{subpart-id}}"
data-overlay-template="<h2><span>{{title}}</span></h2>{{desc}}"
data-cycle-auto-height="{{base_image}}"
data-cycle-speed="{{speed}}"
data-cycle-timeout="{{timeout}}"
data-cycle-fx="{{ad_fx}}"
data-pager=".banner_caption_{{subpart-id}}"
data-pager-template="<li><button></button></li>"
data-pager-active-class="active-slide"
data-cycle-youtube="true"
data-cycle-youtube-autostart="false"
data-cycle-swipe="true"
data-cycle-prev=".banner_prev"
data-cycle-next=".banner_next"
data-cycle-pause-on-hover="true"
style="padding-bottom: 56.25%;"
>
{{html}}
</div>
<div class="ad-overlay w-ad-banner__overlay_{{subpart-id}}"></div>
2021-09-02 02:40:58 +00:00
<div class="w-ba-banner__caption w-ad-banner__pager-2 banner-pager banner_caption_{{subpart-id}}"></div>
2021-04-10 15:16:17 +00:00
<ul class="controlplay"><a class="resume-slide active" title = "<%= (I18n.locale.to_s =="zh_tw") ? "繼續播放" : "resume" %>"><i></i></a><a class="pause-slide" title = "<%= (I18n.locale.to_s =="zh_tw") ? "暫停播放" : "pause"%>"><i></i></a></ul>
<ul class="button-mid">
2021-08-31 09:31:24 +00:00
<i class="fa fa-angle-left prev-button" aria-hidden="true" title = "<%= (I18n.locale.to_s =="zh_tw") ? "上一張" : "prev" %>"></i>
<i class="fa fa-angle-right next-button" aria-hidden="true" title = "<%= (I18n.locale.to_s =="zh_tw") ? "下一張" : "next" %>"></i>
2021-04-10 15:16:17 +00:00
</ul>
</div>
</div>
<script type="text/javascript">
if (typeof ad_banners_count === 'undefined'){
var ad_banners_count = 0;
}
2021-11-14 04:43:46 +00:00
function ad_audio_button(ele,is_stop){
if (is_stop){
2021-11-14 04:51:36 +00:00
$(ele).find('.jarallax-video-audio').remove();
2021-11-14 04:43:46 +00:00
}else{
2021-11-14 05:12:33 +00:00
var audio_div;
if ($(ele).hasClass('have-audio')){
audio_div = $('<div class="jarallax-video-audio"><i class="fas fa-volume-up"></i></div>');
}else{
audio_div = $('<div class="jarallax-video-audio"><i class="fas fa-volume-mute"></i></div>');
}
2021-11-14 05:17:32 +00:00
audio_div.click(function(event){
event.stopPropagation();
2021-11-14 05:12:33 +00:00
var $video = $(ele).find('video');
if ($(ele).hasClass('have-audio')){
$(ele).removeClass('have-audio');
$(this).find('i.fas').attr('class','fas fa-volume-mute');
}else{
$(ele).addClass('have-audio');
$(this).find('i.fas').attr('class','fas fa-volume-up');
}
if ($video.length>0){
$video[0].muted = !$video[0].muted;
}else{//youtube
2021-11-14 05:17:32 +00:00
console.log('control youtube audio');
2021-11-14 05:12:33 +00:00
}
})
$(ele).append(audio_div);
2021-11-14 04:43:46 +00:00
}
}
2021-04-10 15:16:17 +00:00
if(document.getElementById("youtube-iframe-api") == null){
var tag = document.createElement('script');
tag.setAttribute("id", "youtube-iframe-api");
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
}
$("*[data-yt-binded=0]").each(function(){
$(this).attr("data-yt-binded","1");
var obj = $(this).find("iframe");
obj.attr("id",$(this).data("youtube-id") + "_" + ad_banners_count);
ad_banners_count++;
})
2021-04-10 15:16:17 +00:00
if (typeof onYouTubeIframeAPIReady !== 'function'){
if(window.yt_players == undefined)
window.yt_players = {};
2021-04-10 15:16:17 +00:00
function onYouTubeIframeAPIReady(){
$(".w-ba-banner").each(function(i,banner){
var iframes = $(banner).find("iframe");
if(iframes.length > 0){
var id = $(banner).attr("data-subpart-id");
if(yt_players[id] == undefined)
yt_players[id] = {};
var remove_ids = [];
Object.keys(yt_players[id]).forEach(function(k){
var yt_player = yt_players[id][k];
if($(yt_player.getIframe()).length == 0){
yt_player.destroy();
remove_ids.push(k);
}
})
remove_ids.forEach(function(k){
delete yt_players[id][k];
})
iframes.each(function(i,iframe){
var yt_player = yt_players[id][$(iframe).attr("id")];
if(yt_player){
}else{
yt_player = new YT.Player($(iframe).attr("id"), {
events: {
'onReady': function(event){
var height = $(event.target.getIframe()).height();
2021-10-25 10:13:30 +00:00
var banner_wrap = $(".w-ba-banner__wrap[data-overlay=\".w-ad-banner__overlay_"+id+"\"]");
banner_wrap.height(height).css({"padding-bottom":"","padding-top":""});
banner_wrap.find(".cycle-carousel-wrap").css("top","3em");
2021-09-06 15:01:21 +00:00
delete (event.target.B || event.target.H).onStateChange;
var onStateChange_idx = event.target.l.i.onStateChange;
onStateChange_idx.reverse();
var event_size = 3;
onStateChange_idx.forEach(function(start_idx){
event.target.l.h.splice(start_idx,event_size);
});
event.target.l.i.onStateChange = [];
event.target.l.s = event.target.l.h.length;
event.target.addEventListener('onStateChange',onPlayerStateChange);
{{extra_ready_script}}
},
'onStateChange': onPlayerStateChange
}
});
yt_players[id][$(iframe).attr("id")] = yt_player;
$(iframe).data("yt_player",yt_player);
}
})
}
2021-04-10 15:16:17 +00:00
})
}
function onPlayerStateChange(event){
2021-04-10 16:34:57 +00:00
var iframe = $(event.target.h),
2021-04-10 15:16:17 +00:00
cyclediv = iframe.parents("div.cycle-slideshow");
var widget = cyclediv.parents('.ba-banner-widget-youtube');
2021-04-10 15:16:17 +00:00
if(event.data == YT.PlayerState.PLAYING || event.data == YT.PlayerState.BUFFERING){
cyclediv[0].need_resume = !(cyclediv.hasClass("cycle-paused"));
2021-04-10 15:16:17 +00:00
cyclediv.cycle("pause");
2021-04-10 16:34:57 +00:00
widget.find('.banner-pager,.controlplay,.button-mid,.ad-overlay').css('visibility','hidden')
2021-11-14 04:51:36 +00:00
ad_audio_button(cyclediv,false);
}else if(event.data == YT.PlayerState.UNSTARTED || event.data == YT.PlayerState.PAUSED || event.data == YT.PlayerState.ENDED){
if(cyclediv[0].need_resume)
cyclediv.cycle("resume");
2021-04-10 16:34:57 +00:00
widget.find('.banner-pager,.controlplay,.button-mid,.ad-overlay').css('visibility','')
2021-11-14 04:51:36 +00:00
ad_audio_button(cyclediv,true);
2021-04-10 15:16:17 +00:00
}
{{extra_state_chnage_script}}
2021-04-10 15:16:17 +00:00
}
2021-10-27 10:15:17 +00:00
}
2021-04-10 15:16:17 +00:00
$(document).ready(function(){
2021-04-10 16:34:57 +00:00
window.onYouTubePlayerAPIReady = function() {
onYouTubeIframeAPIReady.apply(this,arguments);
2021-04-10 16:34:57 +00:00
};
var banner_wrap = $(".w-ba-banner__wrap[data-overlay=\".w-ad-banner__overlay_{{subpart-id}}\"]");
var opts = banner_wrap.data('cycle.opts');
banner_wrap.on('cycle-paused',function(opts){
var controlplay = $(this).nextAll(".controlplay");
if(controlplay.length != 0){
controlplay.find(".resume-slide").removeClass("active");
controlplay.find(".pause-slide").addClass("active");
}
})
banner_wrap.on('cycle-resumed',function(opts){
var controlplay = $(this).nextAll(".controlplay");
if(controlplay.length != 0){
controlplay.find(".resume-slide").addClass("active");
controlplay.find(".pause-slide").removeClass("active");
}
})
2021-10-14 03:14:55 +00:00
/*
var height = opts.slides.filter('.active').height() || opts.slides.height();
2021-10-14 03:14:55 +00:00
banner_wrap.height(height)*/
banner_wrap.css("padding-bottom","");
{{extra_document_ready_script}}
2021-04-10 15:16:17 +00:00
$('.pause-slide').off('click').click(function(){
$(this).parent("ul").parent('.w-ba-banner').find(".cycle-slideshow").cycle('pause');
$(this).addClass('active');
$(this).parents('.controlplay').eq(0).find('.resume-slide').removeClass('active');
2021-04-10 15:16:17 +00:00
});
$('.resume-slide').off('click').click(function(){
$(this).parent("ul").parent('.w-ba-banner').find(".cycle-slideshow").cycle('resume');
$(this).addClass('active');
$(this).parents('.controlplay').eq(0).find('.pause-slide').removeClass('active');
2021-04-10 15:16:17 +00:00
});
$('.next-button').off('click').on('click',function(){
$(this).parent("ul").parent('.w-ba-banner').find(".cycle-slideshow").cycle("next");
})
$('.prev-button').off('click').on('click',function(){
$(this).parent("ul").parent('.w-ba-banner').find(".cycle-slideshow").cycle("prev");
})
var resize_timeout_id;
$(window).resize(function(){
if(resize_timeout_id){
window.clearTimeout(resize_timeout_id);
}
resize_timeout_id = window.setTimeout(function(){
var banner_wrap = $(".w-ba-banner__wrap[data-overlay=\".w-ad-banner__overlay_{{subpart-id}}\"]");
var opts = banner_wrap.data('cycle.opts');
var height = opts.slides.filter('.active').height() || opts.slides.height();
banner_wrap.height(height).css("padding-bottom","");
},300);
})
2021-04-10 15:16:17 +00:00
})
</script>
<style type="text/css">
2021-11-14 04:43:46 +00:00
.jarallax-video-audio{
z-index: 1;
font-size: 36px;
color: #FFF;
text-align: center;
position: absolute;
top: 2%;
right: 2%;
height: 66px;
width: 66px;
border-radius: 50%;
line-height: 1.8;
cursor: pointer;
border: 2px solid rgba(255,255,255,.6);
background-color: rgba(0,0,0,.6);
transition: all 1.2s ease;
}
.jarallax-video-audio:hover{
color: #FFC500;
transition: all 0.6s ease;
}
2021-08-31 09:31:24 +00:00
.w-ba-banner .controlplay .resume-slide.active i{
2021-04-10 15:16:17 +00:00
color: #32D9C3;
}
2021-08-31 09:31:24 +00:00
.w-ba-banner .controlplay .pause-slide.active i{
2021-04-10 15:16:17 +00:00
color: #ff4500;
}
2021-08-31 09:31:24 +00:00
.w-ba-banner .controlplay{
width: auto;
}
.w-ba-banner .button-mid{
position: absolute;
width: 100%;
height: 100%;
2021-09-02 02:59:37 +00:00
top: 0;
left: 0;
2021-08-31 09:31:24 +00:00
}
.next-button,.prev-button{
cursor: pointer;
}
2021-09-06 15:01:21 +00:00
</style>