85 lines
3.1 KiB
JavaScript
85 lines
3.1 KiB
JavaScript
|
jQuery(document).ready(function(){
|
||
|
|
||
|
var port_carousel_wrapper = jQuery('.portfolio-carousel-wrapper');
|
||
|
|
||
|
function carousel_port_init(){
|
||
|
port_carousel_wrapper.each(function(){
|
||
|
var port_carousel = jQuery(this);
|
||
|
var port_holder = port_carousel.children('.portfolio-item-holder');
|
||
|
var port_item = port_carousel.find('.portfolio-item');
|
||
|
|
||
|
port_item.css('float', 'left');
|
||
|
|
||
|
var child_size;
|
||
|
if( port_item.filter(':first').hasClass('three') ){
|
||
|
port_holder.attr('data-num', 4);
|
||
|
child_size = port_carousel.parents('.row').width() / 4;
|
||
|
}else if( port_item.filter(':first').hasClass('four') ){
|
||
|
port_holder.attr('data-num', 3);
|
||
|
child_size = port_carousel.parents('.row').width() / 3;
|
||
|
}else if( port_item.filter(':first').hasClass('six') ){
|
||
|
port_holder.attr('data-num', 2);
|
||
|
child_size = port_carousel.parents('.row').width() / 2;
|
||
|
}
|
||
|
|
||
|
if( jQuery('html').filter(':first').width() <= '767' ){
|
||
|
port_holder.attr('data-num', 1);
|
||
|
child_size = port_carousel.parents('.row').width();
|
||
|
}
|
||
|
|
||
|
port_item.css('width', child_size );
|
||
|
|
||
|
port_holder.attr('data-width', child_size);
|
||
|
port_holder.attr('data-max', port_item.length);
|
||
|
port_holder.width( port_item.length * child_size );
|
||
|
|
||
|
var cur_index = parseInt(port_holder.attr('data-index'));
|
||
|
port_holder.css({ 'margin-left': -(cur_index * child_size + 10) });
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// bind the navigation
|
||
|
var port_nav = port_carousel_wrapper.children('.port-nav-wrapper');
|
||
|
if( port_nav.length == 0 ){
|
||
|
port_nav = port_carousel_wrapper.siblings('.portfolio-carousel-description').children('.port-nav-wrapper');
|
||
|
}
|
||
|
|
||
|
port_nav.children('.port-nav.left').click(function(){
|
||
|
var port_holder = jQuery(this).parent('.port-nav-wrapper').siblings('.portfolio-item-holder');
|
||
|
if( port_holder.length == 0 ){
|
||
|
port_holder = jQuery(this).parent('.port-nav-wrapper').parent().siblings('.portfolio-carousel-wrapper').children('.portfolio-item-holder');
|
||
|
}
|
||
|
|
||
|
var cur_index = parseInt(port_holder.attr('data-index'));
|
||
|
|
||
|
if( cur_index > 0 ){ cur_index--; }
|
||
|
port_holder.attr('data-index', cur_index);
|
||
|
port_holder.animate({ 'margin-left': -(cur_index * parseInt(port_holder.attr('data-width')) + 10) });
|
||
|
});
|
||
|
port_nav.children('.port-nav.right').click(function(){
|
||
|
var port_holder = jQuery(this).parent('.port-nav-wrapper').siblings('.portfolio-item-holder');
|
||
|
if( port_holder.length == 0 ){
|
||
|
port_holder = jQuery(this).parent('.port-nav-wrapper').parent().siblings('.portfolio-carousel-wrapper').children('.portfolio-item-holder');
|
||
|
}
|
||
|
|
||
|
var cur_index = parseInt(port_holder.attr('data-index'));
|
||
|
if( cur_index + parseInt(port_holder.attr('data-num')) < parseInt(port_holder.attr('data-max')) ){
|
||
|
cur_index++;
|
||
|
}
|
||
|
|
||
|
port_holder.attr('data-index', cur_index);
|
||
|
port_holder.animate({ 'margin-left': -(cur_index * parseInt(port_holder.attr('data-width')) + 10) });
|
||
|
});
|
||
|
|
||
|
carousel_port_init();
|
||
|
|
||
|
//Auto animate
|
||
|
//var infiniteLoop = setInterval(function(){
|
||
|
// port_nav.children('.port-nav.right').trigger('click');
|
||
|
//}, 1000);
|
||
|
|
||
|
jQuery(window).resize(function(){
|
||
|
carousel_port_init();
|
||
|
});
|
||
|
|
||
|
});
|