slider.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. (function($) {
  2. "use strict";
  3. $.fn.pbTouchSlider = function(options) {
  4. var slider_Opts = $.extend({
  5. slider_Wrap : '', // Assign a unique ID to the div.o-sliderContainer
  6. slider_Item : '.o-slider--item', // Single Item
  7. slider_Drag : true, // Your choise.. to dragIt or not to dragIt..this is the question...
  8. slider_Dots : { // Wanna see dots or not?
  9. class :'.o-slider-pagination',
  10. enabled : true,
  11. preview : true
  12. },
  13. slider_Arrows : { // Wanna see Arrows or not?
  14. class :'.o-slider-arrows',
  15. enabled : true
  16. },
  17. slider_Threshold : 25, // Percentage of dragX before go to next/prev slider
  18. slider_Speed : 1000,
  19. slider_Ease : 'cubic-bezier(0.5, 0, 0.5, 1)', // see http://cubic-bezier.com/
  20. slider_Breakpoints : { // Kind of media queries ( can add more if you know how to do it :D and if you need )
  21. default : {
  22. height : 500 // height on desktop
  23. },
  24. tablet : {
  25. height : 400, // height on tablet
  26. media : 1024 // tablet breakpoint
  27. },
  28. smartphone : {
  29. height : 300, // height on smartphone
  30. media : 768 // smartphone breakpoint
  31. }
  32. }
  33. }, options);
  34. /*:::::::: LOADER ::::::::*/
  35. var loaderHtml = '<div class="loaderWrap">'+
  36. '<div class="ball-scale-multiple">'+
  37. '<div></div>'+
  38. '<div></div>'+
  39. '<div></div>'+
  40. '<div></div>'+
  41. '</div></div>';
  42. $(slider_Opts.slider_Wrap).each( function(){$(this).append(loaderHtml);});
  43. function loader(visibility) {
  44. var thisLoader = $(slider_Opts.slider_Wrap +' .loaderWrap');
  45. if (visibility === true)
  46. $(thisLoader).show();
  47. else
  48. $(thisLoader).hide();
  49. }
  50. /*:::::::: RESPONSIVE ::::::::*/
  51. function setResponsive() {
  52. var VW = document.documentElement.clientWidth;
  53. if (VW >= slider_Opts.slider_Breakpoints.tablet.media) {
  54. $(pbSlider.slider_Wrap + '.o-sliderContainer,'+ pbSlider.slider_Wrap + ' ' + pbSlider.slider_Item).css({height: slider_Opts.slider_Breakpoints.default.height});
  55. } else if (VW >= slider_Opts.slider_Breakpoints.smartphone.media) {
  56. $(pbSlider.slider_Wrap + '.o-sliderContainer,'+ pbSlider.slider_Wrap + ' ' + pbSlider.slider_Item).css({height: slider_Opts.slider_Breakpoints.tablet.height});
  57. } else {
  58. $(pbSlider.slider_Wrap + '.o-sliderContainer,'+ pbSlider.slider_Wrap + ' ' + pbSlider.slider_Item).css({height: slider_Opts.slider_Breakpoints.smartphone.height});
  59. }
  60. }
  61. $(window).resize(function() {setResponsive();});
  62. /*:::::::: OBJECT SLIDER ::::::::*/
  63. var pbSlider = {};
  64. pbSlider.slider_Wrap = slider_Opts.slider_Wrap;
  65. pbSlider.slider_Item = slider_Opts.slider_Item;
  66. pbSlider.slider_Dots = slider_Opts.slider_Dots;
  67. pbSlider.slider_Threshold = slider_Opts.slider_Threshold;
  68. pbSlider.slider_Active = 0;
  69. pbSlider.slider_Count = 0;
  70. pbSlider.slider_NavWrap = '<div class="o-slider-controls"></div>';
  71. pbSlider.slider_NavPagination ='<ul class="o-slider-pagination"></ul>';
  72. pbSlider.slider_NavArrows ='<ul class="o-slider-arrows"><li class="o-slider-prev"><i class="icon-left-open-big"></i></li><li class="o-slider-next"><i class="icon-right-open-big"></i></li></ul>';
  73. /*:::::::: APPEND ANIMATION ::::::::*/
  74. $('head').append(
  75. '<style>' + pbSlider.slider_Wrap + ' .o-slider.isAnimate{' +
  76. '-webkit-transition: all ' + slider_Opts.slider_Speed + 'ms ' + slider_Opts.slider_Ease + ';' +
  77. 'transition: all ' + slider_Opts.slider_Speed + 'ms ' + slider_Opts.slider_Ease + ';' +
  78. '</style>'
  79. );
  80. /*:::::::: INIT ::::::::*/
  81. pbSlider.pbInit = function(selector) {
  82. pbSlider.slider_Draggable = selector;
  83. pbSlider.slider_Count = $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).length;
  84. $(selector).css('width', pbSlider.slider_Count * 100 + '%');
  85. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).css({'width': 100 / pbSlider.slider_Count+ '%'});
  86. var incrSlides = 0;
  87. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).each(function() {
  88. $(this).attr('data-id', 'slide-' + (incrSlides++));
  89. });
  90. if(slider_Opts.slider_Arrows.enabled === true || slider_Opts.slider_Dots.enabled === true ){
  91. $(pbSlider.slider_Wrap).append(pbSlider.slider_NavWrap);
  92. }
  93. if(slider_Opts.slider_Arrows.enabled === true){$(pbSlider.slider_Wrap).append(pbSlider.slider_NavArrows);}
  94. if(slider_Opts.slider_Dots.enabled === true){
  95. var incrPagination = 0;
  96. $(pbSlider.slider_Wrap).append(pbSlider.slider_NavPagination);
  97. for (incrPagination; incrPagination < pbSlider.slider_Count; incrPagination++) {
  98. var activeStatus = incrPagination === pbSlider.slider_Active ? ' class="isActive"' : '';
  99. var gotoSlide = 'data-increase="' + [incrPagination] + '"';
  100. var background = $(pbSlider.slider_Wrap).find("[data-id='slide-" + incrPagination + "']").attr('data-image');
  101. //background = background.replace('url(','').replace(')','').replace(/\"/gi, "");
  102. if(slider_Opts.slider_Dots.preview === true){
  103. $(pbSlider.slider_Wrap).find(pbSlider.slider_Dots.class)
  104. .append(
  105. '<li ' + activeStatus + ' ' + gotoSlide + '>'+
  106. '<span class="o-slider--preview" style="background-image:url('+background+')"></span>'+
  107. '</li>');
  108. } else {
  109. $(pbSlider.slider_Wrap).find(pbSlider.slider_Dots.class)
  110. .append('<li ' + activeStatus + ' ' + gotoSlide + '></li>');
  111. }
  112. }
  113. }
  114. setTimeout(function() {
  115. $(pbSlider.slider_Item + '[data-id=slide-' + pbSlider.slider_Active + ']').addClass('isActive');
  116. },400);
  117. /*:::::::: HAMMER => see http://hammerjs.github.io/ ::::::::*/
  118. if(slider_Opts.slider_Drag === true){
  119. $(pbSlider.slider_Draggable).addClass('isDraggable');
  120. var stuff4hammer = document.querySelector(pbSlider.slider_Wrap);
  121. var hammerOpts = {
  122. dragLockToAxis: true,
  123. dragBlockHorizontal: true,
  124. touchAction: 'pan-x',
  125. cssProps: {userSelect: true}
  126. }
  127. var hammertime = new Hammer(stuff4hammer, hammerOpts);
  128. hammertime.on('pan', function(e) {
  129. e.preventDefault();
  130. var percentage = 100 / pbSlider.slider_Count * e.deltaX / window.innerWidth;
  131. var percentageCalc = percentage - 100 / pbSlider.slider_Count * pbSlider.slider_Active;
  132. var notDraggable = $(e.target).find('.slider-textWrap').length;
  133. if(pbSlider.slider_Active != pbSlider.slider_Count-1 && pbSlider.slider_Active != 0){
  134. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).addClass('isMoving');
  135. }
  136. $(pbSlider.slider_Draggable).css({
  137. 'perspective': '1000px',
  138. 'backface-visibility': 'hidden',
  139. 'transform': 'translateX( ' + percentageCalc + '% )'
  140. });
  141. if (e.isFinal) {
  142. if (e.velocityX > 1) {
  143. pbSlider.pbGoslide(pbSlider.slider_Active - 1);
  144. } else if (e.velocityX < -1) {
  145. pbSlider.pbGoslide(pbSlider.slider_Active + 1);
  146. } else {
  147. if (percentage <= -(pbSlider.slider_Threshold / pbSlider.slider_Count)) {
  148. pbSlider.pbGoslide(pbSlider.slider_Active + 1);
  149. } else if (percentage >= (pbSlider.slider_Threshold / pbSlider.slider_Count)) {
  150. pbSlider.pbGoslide(pbSlider.slider_Active - 1);
  151. } else {
  152. pbSlider.pbGoslide(pbSlider.slider_Active);
  153. }
  154. }
  155. }
  156. });
  157. }
  158. $(pbSlider.slider_Wrap + ' .o-slider-pagination li').on('click', function() {
  159. var this_data = $(this).attr('data-increase');
  160. if(!$(this).hasClass('isActive')){
  161. pbSlider.pbGoslide(this_data);
  162. }
  163. //console.log(this_data + ' / ' + pbSlider.slider_Active );
  164. });
  165. $(pbSlider.slider_Wrap + ' .o-slider-prev').addClass('isDisabled');
  166. $(pbSlider.slider_Wrap + ' .o-slider-arrows li').on('click', function() {
  167. if ($(this).hasClass('o-slider-next')) {
  168. pbSlider.pbGoslide(pbSlider.slider_Active + 1);
  169. } else {
  170. pbSlider.pbGoslide(pbSlider.slider_Active - 1);
  171. }
  172. });
  173. };
  174. /*:::::::: SLIDER ENGINE ::::::::*/
  175. pbSlider.pbGoslide = function(number) {
  176. $(pbSlider.slider_Wrap + ' .o-slider-arrows li').removeClass('isDisabled');
  177. if (number < 0) {
  178. pbSlider.slider_Active = 0;
  179. } else if (number > pbSlider.slider_Count - 1) {
  180. pbSlider.slider_Active = pbSlider.slider_Count - 1;
  181. } else {
  182. pbSlider.slider_Active = number;
  183. }
  184. if (pbSlider.slider_Active >= pbSlider.slider_Count - 1) {
  185. var firstS = $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).first();
  186. $(pbSlider.slider_Wrap + ' .o-slider-next').addClass('isDisabled');
  187. } else if (pbSlider.slider_Active <= 0) {
  188. $(pbSlider.slider_Wrap + ' .o-slider-prev').addClass('isDisabled');
  189. } else {
  190. $(pbSlider.slider_Wrap + ' .o-slider-arrows li').removeClass('isDisabled');
  191. }
  192. if(pbSlider.slider_Active != pbSlider.slider_Count-1 && pbSlider.slider_Active != 0){
  193. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).addClass('isMoving');
  194. }
  195. $(pbSlider.slider_Draggable).addClass('isAnimate');
  196. var percentage = -(100 / pbSlider.slider_Count) * pbSlider.slider_Active;
  197. $(pbSlider.slider_Draggable).css({
  198. 'perspective': '1000px',
  199. 'backface-visibility': 'hidden',
  200. 'transform': 'translateX( ' + percentage + '% )'
  201. });
  202. clearTimeout(pbSlider.timer);
  203. pbSlider.timer = setTimeout(function() {
  204. $(pbSlider.slider_Wrap).find(pbSlider.slider_Draggable).removeClass('isAnimate');
  205. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item).removeClass('isActive').removeClass('isMoving');
  206. $(pbSlider.slider_Wrap).find(pbSlider.slider_Item + '[data-id=slide-' + pbSlider.slider_Active + ']').addClass('isActive');
  207. //$(pbSlider.slider_Wrap + ' .o-slider--item img').css('transform', 'translateX(0px )');
  208. }, slider_Opts.slider_Speed);
  209. if(slider_Opts.slider_Dots.enabled === true){
  210. var sliderDots = $(pbSlider.slider_Wrap).find(pbSlider.slider_Dots.class + ' > *');
  211. var increase = 0;
  212. for (increase; increase < sliderDots.length; increase++) {
  213. var className = increase == pbSlider.slider_Active ? 'isActive' : '';
  214. $(pbSlider.slider_Wrap).find(sliderDots[increase]).removeClass('isActive').addClass(className);
  215. $(pbSlider.slider_Wrap).find(sliderDots[increase]).children().removeClass('isActive').addClass(className);
  216. }
  217. setTimeout(function() {
  218. $(pbSlider.slider_Wrap).find(sliderDots).children().removeClass('isActive');
  219. },500);
  220. }
  221. pbSlider.slider_Active = Number(pbSlider.slider_Active);
  222. };
  223. pbSlider.auto = function() {
  224. pbSlider.autoTimer = setInterval(function() {
  225. if (pbSlider.slider_Active >= pbSlider.slider_Count - 1) {
  226. pbSlider.pbGoslide(0);
  227. } else {
  228. $(pbSlider.slider_Wrap + ' .o-slider-next').trigger('click');
  229. }
  230. }, 3000);
  231. }
  232. //pbSlider.auto();
  233. pbSlider.pbInit(this);
  234. /*:::::::: ONlOAD STUFF ::::::::*/
  235. $(document).ready(function(){
  236. $(pbSlider.slider_Item).each(function(){
  237. var bg = $(this).attr('data-image');
  238. $(this).css({'background-image':'url('+bg+')'});
  239. });
  240. setTimeout ( function(){
  241. loader(false);
  242. },1000);
  243. $(pbSlider.slider_Wrap + ' .o-slider-controls').addClass('isVisible');
  244. $(pbSlider.slider_Draggable).addClass('isVisible');
  245. setResponsive();
  246. });
  247. };
  248. }(jQuery));