You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
342 lines
7.1 KiB
342 lines
7.1 KiB
/* |
|
Hugo Story by CaressOfSteel |
|
A (modular, highly tweakable) responsive one-page theme for Hugo. |
|
Ported from Story by HTML5UP. |
|
This Hugo theme is licensed under the Creative Commons Attribution 3.0 License. |
|
*/ |
|
|
|
(function($) { |
|
|
|
var $window = $(window), |
|
$body = $('body'), |
|
$wrapper = $('#wrapper'); |
|
|
|
// Breakpoints. |
|
breakpoints({ |
|
xlarge: [ '1281px', '1680px' ], |
|
large: [ '981px', '1280px' ], |
|
medium: [ '737px', '980px' ], |
|
small: [ '481px', '736px' ], |
|
xsmall: [ '361px', '480px' ], |
|
xxsmall: [ null, '360px' ] |
|
}); |
|
|
|
// Play initial animations on page load. |
|
$window.on('load', function() { |
|
window.setTimeout(function() { |
|
$body.removeClass('is-preload'); |
|
}, 100); |
|
}); |
|
|
|
// Browser fixes. |
|
|
|
// IE: Flexbox min-height bug. |
|
if (browser.name == 'ie') |
|
(function() { |
|
|
|
var flexboxFixTimeoutId; |
|
|
|
$window.on('resize.flexbox-fix', function() { |
|
|
|
var $x = $('.fullscreen'); |
|
|
|
clearTimeout(flexboxFixTimeoutId); |
|
|
|
flexboxFixTimeoutId = setTimeout(function() { |
|
|
|
if ($x.prop('scrollHeight') > $window.height()) |
|
$x.css('height', 'auto'); |
|
else |
|
$x.css('height', '100vh'); |
|
|
|
}, 250); |
|
|
|
}).triggerHandler('resize.flexbox-fix'); |
|
|
|
})(); |
|
|
|
// Object fit workaround. |
|
if (!browser.canUse('object-fit')) |
|
(function() { |
|
|
|
$('.banner .image, .spotlight .image').each(function() { |
|
|
|
var $this = $(this), |
|
$img = $this.children('img'), |
|
positionClass = $this.parent().attr('class').match(/image-position-([a-z]+)/); |
|
|
|
// Set image. |
|
$this |
|
.css('background-image', 'url("' + $img.attr('src') + '")') |
|
.css('background-repeat', 'no-repeat') |
|
.css('background-size', 'cover'); |
|
|
|
// Set position. |
|
switch (positionClass.length > 1 ? positionClass[1] : '') { |
|
|
|
case 'left': |
|
$this.css('background-position', 'left'); |
|
break; |
|
|
|
case 'right': |
|
$this.css('background-position', 'right'); |
|
break; |
|
|
|
default: |
|
case 'center': |
|
$this.css('background-position', 'center'); |
|
break; |
|
|
|
} |
|
|
|
// Hide original. |
|
$img.css('opacity', '0'); |
|
|
|
}); |
|
|
|
})(); |
|
|
|
// Smooth scroll. |
|
$('.smooth-scroll').scrolly(); |
|
$('.smooth-scroll-middle').scrolly({ anchor: 'middle' }); |
|
|
|
// Wrapper. |
|
$wrapper.children() |
|
.scrollex({ |
|
top: '30vh', |
|
bottom: '30vh', |
|
initialize: function() { |
|
$(this).addClass('is-inactive'); |
|
}, |
|
terminate: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
enter: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
leave: function() { |
|
|
|
var $this = $(this); |
|
|
|
if ($this.hasClass('onscroll-bidirectional')) |
|
$this.addClass('is-inactive'); |
|
|
|
} |
|
}); |
|
|
|
// Items. |
|
$('.items') |
|
.scrollex({ |
|
top: '30vh', |
|
bottom: '30vh', |
|
delay: 50, |
|
initialize: function() { |
|
$(this).addClass('is-inactive'); |
|
}, |
|
terminate: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
enter: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
leave: function() { |
|
|
|
var $this = $(this); |
|
|
|
if ($this.hasClass('onscroll-bidirectional')) |
|
$this.addClass('is-inactive'); |
|
|
|
} |
|
}) |
|
.children() |
|
.wrapInner('<div class="inner"></div>'); |
|
|
|
// Gallery. |
|
$('.gallery') |
|
.wrapInner('<div class="inner"></div>') |
|
.prepend(browser.mobile ? '' : '<div class="forward"></div><div class="backward"></div>') |
|
.scrollex({ |
|
top: '30vh', |
|
bottom: '30vh', |
|
delay: 50, |
|
initialize: function() { |
|
$(this).addClass('is-inactive'); |
|
}, |
|
terminate: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
enter: function() { |
|
$(this).removeClass('is-inactive'); |
|
}, |
|
leave: function() { |
|
|
|
var $this = $(this); |
|
|
|
if ($this.hasClass('onscroll-bidirectional')) |
|
$this.addClass('is-inactive'); |
|
|
|
} |
|
}) |
|
.children('.inner') |
|
//.css('overflow', 'hidden') |
|
.css('overflow-y', browser.mobile ? 'visible' : 'hidden') |
|
.css('overflow-x', browser.mobile ? 'scroll' : 'hidden') |
|
.scrollLeft(0); |
|
|
|
// Style #1. |
|
// ... |
|
|
|
// Style #2. |
|
$('.gallery') |
|
.on('wheel', '.inner', function(event) { |
|
|
|
var $this = $(this), |
|
delta = (event.originalEvent.deltaX * 10); |
|
|
|
// Cap delta. |
|
if (delta > 0) |
|
delta = Math.min(25, delta); |
|
else if (delta < 0) |
|
delta = Math.max(-25, delta); |
|
|
|
// Scroll. |
|
$this.scrollLeft( $this.scrollLeft() + delta ); |
|
|
|
}) |
|
.on('mouseenter', '.forward, .backward', function(event) { |
|
|
|
var $this = $(this), |
|
$inner = $this.siblings('.inner'), |
|
direction = ($this.hasClass('forward') ? 1 : -1); |
|
|
|
// Clear move interval. |
|
clearInterval(this._gallery_moveIntervalId); |
|
|
|
// Start interval. |
|
this._gallery_moveIntervalId = setInterval(function() { |
|
$inner.scrollLeft( $inner.scrollLeft() + (5 * direction) ); |
|
}, 10); |
|
|
|
}) |
|
.on('mouseleave', '.forward, .backward', function(event) { |
|
|
|
// Clear move interval. |
|
clearInterval(this._gallery_moveIntervalId); |
|
|
|
}); |
|
|
|
// Lightbox. |
|
$('.gallery.lightbox') |
|
.on('click', 'a', function(event) { |
|
|
|
var $a = $(this), |
|
$gallery = $a.parents('.gallery'), |
|
$modal = $gallery.children('.modal'), |
|
$modalImg = $modal.find('img'), |
|
href = $a.attr('href'); |
|
|
|
// Not an image? Bail. |
|
if (!href.match(/\.(jpg|gif|png|mp4)$/)) |
|
return; |
|
|
|
// Prevent default. |
|
event.preventDefault(); |
|
event.stopPropagation(); |
|
|
|
// Locked? Bail. |
|
if ($modal[0]._locked) |
|
return; |
|
|
|
// Lock. |
|
$modal[0]._locked = true; |
|
|
|
// Set src. |
|
$modalImg.attr('src', href); |
|
|
|
// Set visible. |
|
$modal.addClass('visible'); |
|
|
|
// Focus. |
|
$modal.focus(); |
|
|
|
// Delay. |
|
setTimeout(function() { |
|
|
|
// Unlock. |
|
$modal[0]._locked = false; |
|
|
|
}, 600); |
|
|
|
}) |
|
.on('click', '.modal', function(event) { |
|
|
|
var $modal = $(this), |
|
$modalImg = $modal.find('img'); |
|
|
|
// Locked? Bail. |
|
if ($modal[0]._locked) |
|
return; |
|
|
|
// Already hidden? Bail. |
|
if (!$modal.hasClass('visible')) |
|
return; |
|
|
|
// Lock. |
|
$modal[0]._locked = true; |
|
|
|
// Clear visible, loaded. |
|
$modal |
|
.removeClass('loaded') |
|
|
|
// Delay. |
|
setTimeout(function() { |
|
|
|
$modal |
|
.removeClass('visible') |
|
|
|
setTimeout(function() { |
|
|
|
// Clear src. |
|
$modalImg.attr('src', ''); |
|
|
|
// Unlock. |
|
$modal[0]._locked = false; |
|
|
|
// Focus. |
|
$body.focus(); |
|
|
|
}, 475); |
|
|
|
}, 125); |
|
|
|
}) |
|
.on('keypress', '.modal', function(event) { |
|
|
|
var $modal = $(this); |
|
|
|
// Escape? Hide modal. |
|
if (event.keyCode == 27) |
|
$modal.trigger('click'); |
|
|
|
}) |
|
.prepend('<div class="modal" tabIndex="-1"><div class="inner"><img src="" /></div></div>') |
|
.find('img') |
|
.on('load', function(event) { |
|
|
|
var $modalImg = $(this), |
|
$modal = $modalImg.parents('.modal'); |
|
|
|
setTimeout(function() { |
|
|
|
// No longer visible? Bail. |
|
if (!$modal.hasClass('visible')) |
|
return; |
|
|
|
// Set loaded. |
|
$modal.addClass('loaded'); |
|
|
|
}, 275); |
|
|
|
}); |
|
|
|
})(jQuery); |