Files
Fluxtra2020/assets/js/jquery.background-video.js
2020-03-15 13:32:24 -04:00

259 lines
7.4 KiB
JavaScript
Executable File

// The MIT License (MIT)
// Copyright (c) 2015 BG Stock - html5backgroundvideos.com
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
// SOFTWARE.
(function($) {
// Add js class to html
$('html').addClass('js');
// Add IE8 shim for Date.now()
if (!Date.now) {
Date.now = function() { return new Date().getTime(); }
}
// Return current time in seconds
function currentTime() {
return Math.floor(Date.now() / 1000);
}
// The plugin
$.fn.bgVideo = function( options ) {
// @bool iOS
var iOS = /iPad|iPhone|iPod/.test(navigator.platform) || /iPad|iPhone|iPod/.test(navigator.userAgent);
// Settings
var settings = $.extend({}, $.fn.bgVideo.defaults, options );
// Do the things
return this.each(function() {
// Set some handy variables
var $video = $(this); // jQuery Object
var video = $video[0]; // DOM node
var poster = $video.attr('poster') || '';
var $container = $video.parent();
var $pauseplay = $('<button class="jquery-background-video-pauseplay pause"><span>Pause</span></button>');
var start_time; // We'll set this when it starts playing
// Check for any data attributes that will override the settings for this particular element
var el_settings = $.extend({}, settings);
var data_attrs = $video.data();
$.each( data_attrs, function( data_name, data_val ) {
if( data_name.indexOf('bgvideo') === 0 ) {
// It's a match! Strip the bgvideo prefix and lowercase the first letter
data_name = data_name.replace('bgvideo', '');
data_name = data_name.charAt(0).toLowerCase() + data_name.slice(1);
// Then set the setting
el_settings[data_name] = data_val;
}
});
// Attach to playing event
$video.on('playing', function(){
if(start_time == null){
start_time = currentTime();
}
$video.addClass('is-playing is-visible');
$pauseplay.removeClass('play').addClass('pause').find('span').text('Pause');
$.fn.bgVideo.fitVideo( $video );
});
// If the video is already playing before js loads
if( video.currentTime > 0 ) {
$video.addClass('is-playing is-visible');
}
// Attach to pause event
$video.on('pause', function(){
$video.removeClass('is-playing');
$pauseplay.removeClass('pause').addClass('play').find('span').text('Play');
if(el_settings.fadeOnPause) {
$video.removeClass('is-visible');
}
});
// Set default styles
$container.css({
'position': 'relative',
'overflow': 'hidden',
'background-size': 'cover',
'background-position': 'center center',
'background-repeat': 'no-repeat',
'background-image': 'url(' + poster + ')'
});
$video.css({
'min-width': 'auto',
'min-height': 'auto',
'width': '100%',
'height': 'auto',
'position': 'absolute',
'left': '50%',
'top': '50%',
'transform': 'translate(-50%,-50%)'
});
if( el_settings.fullScreen ) {
$container.css({
'position': 'fixed',
'top': '0',
'bottom': '0',
'left': '0',
'right': '0',
'height': 'auto',
'margin': '0',
'z-index': '-1'
});
}
// Fade in video by setting the transition duration
$video.css('transition-duration', el_settings.fadeIn + 'ms');
// Remove on iOS
if( iOS ) {
// Unset sources to prevent them from continuing to download
$video.attr('src', '');
$video.find('source').attr('src', '');
$video.remove();
}
// Mimic background-size: cover with video element
$.fn.bgVideo.fitVideo( $video );
$(window).resize(function(){
$.fn.bgVideo.fitVideo( $video );
});
// Pause after X seconds
el_settings.pauseAfter = parseInt( el_settings.pauseAfter, 10 );
if( el_settings.pauseAfter > 0 ) {
$video.on('timeupdate', function(){
var now = currentTime();
if( now > start_time + el_settings.pauseAfter ) {
video.pause();
if( el_settings.fadeOnEnd ) {
$video.removeClass('is-visible');
}
}
});
}
// Play / pause button
if( el_settings.showPausePlay && !iOS ) {
// Append pauseplay element created earlier
$container.append($pauseplay);
// Position element
$pauseplay.css({
'left': 'auto',
'right': 'auto',
'top': 'auto',
'bottom': 'auto'
});
$pauseplay.css(el_settings.pausePlayXPos, el_settings.pausePlayXOffset);
$pauseplay.css(el_settings.pausePlayYPos, el_settings.pausePlayYOffset);
if( el_settings.pausePlayXPos === 'center' ) {
$pauseplay.css({
'left': '50%',
'margin-left': '-10px'
});
}
if( el_settings.pausePlayYPos === 'center' ) {
$pauseplay.css({
'top': '50%',
'margin-top': '-10px'
});
}
// Add functionality
$pauseplay.on('click', function(){
if(video.paused) {
video.play();
start_time = currentTime();
} else {
video.pause();
}
});
}
});
};
// Default settings
$.fn.bgVideo.defaults = {
fullScreen: false, // Sets the video to be fixed to the full window
fadeIn: 500, // Milliseconds to fade video in/out (0 for no fade)
pauseAfter: 120, // Seconds to play before pausing (0 for forever)
fadeOnPause: false, // For all (including manual) pauses
fadeOnEnd: true, // When we've reached the pauseAfter time
showPausePlay: true, // Show pause/play button
pausePlayXPos: 'right', // left|right|center
pausePlayYPos: 'top', // top|bottom|center
pausePlayXOffset: '15px', // pixels or percent from side - ignored if positioned center
pausePlayYOffset: '15px' // pixels or percent from top/bottom - ignored if positioned center
};
// Fit video
$.fn.bgVideo.fitVideo = function( $video ) {
var $container = $video.parent(),
container_height = $container.outerHeight(),
container_width = $container.outerWidth();
// Do this again every time the screen size changes
$video.css({
'height': 'auto',
'width': container_width + 'px'
});
var video_height = $video.height();
if( container_height > video_height ) {
//console.log('Container height > video height');
$video.css({
'height': container_height + 'px',
'width': 'auto'
});
}
};
// Auto run based on data attributes
$(document).ready(function(){
$('[data-bgvideo]').bgVideo();
});
}(jQuery));