navigation.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. import createElementIfNotDefined from '../../shared/create-element-if-not-defined.js';
  2. import $ from '../../shared/dom.js';
  3. export default function Navigation(_ref) {
  4. let {
  5. swiper,
  6. extendParams,
  7. on,
  8. emit
  9. } = _ref;
  10. extendParams({
  11. navigation: {
  12. nextEl: null,
  13. prevEl: null,
  14. hideOnClick: false,
  15. disabledClass: 'swiper-button-disabled',
  16. hiddenClass: 'swiper-button-hidden',
  17. lockClass: 'swiper-button-lock'
  18. }
  19. });
  20. swiper.navigation = {
  21. nextEl: null,
  22. $nextEl: null,
  23. prevEl: null,
  24. $prevEl: null
  25. };
  26. function getEl(el) {
  27. let $el;
  28. if (el) {
  29. $el = $(el);
  30. if (swiper.params.uniqueNavElements && typeof el === 'string' && $el.length > 1 && swiper.$el.find(el).length === 1) {
  31. $el = swiper.$el.find(el);
  32. }
  33. }
  34. return $el;
  35. }
  36. function toggleEl($el, disabled) {
  37. const params = swiper.params.navigation;
  38. if ($el && $el.length > 0) {
  39. $el[disabled ? 'addClass' : 'removeClass'](params.disabledClass);
  40. if ($el[0] && $el[0].tagName === 'BUTTON') $el[0].disabled = disabled;
  41. if (swiper.params.watchOverflow && swiper.enabled) {
  42. $el[swiper.isLocked ? 'addClass' : 'removeClass'](params.lockClass);
  43. }
  44. }
  45. }
  46. function update() {
  47. // Update Navigation Buttons
  48. if (swiper.params.loop) return;
  49. const {
  50. $nextEl,
  51. $prevEl
  52. } = swiper.navigation;
  53. toggleEl($prevEl, swiper.isBeginning && !swiper.params.rewind);
  54. toggleEl($nextEl, swiper.isEnd && !swiper.params.rewind);
  55. }
  56. function onPrevClick(e) {
  57. e.preventDefault();
  58. if (swiper.isBeginning && !swiper.params.loop && !swiper.params.rewind) return;
  59. swiper.slidePrev();
  60. }
  61. function onNextClick(e) {
  62. e.preventDefault();
  63. if (swiper.isEnd && !swiper.params.loop && !swiper.params.rewind) return;
  64. swiper.slideNext();
  65. }
  66. function init() {
  67. const params = swiper.params.navigation;
  68. swiper.params.navigation = createElementIfNotDefined(swiper, swiper.originalParams.navigation, swiper.params.navigation, {
  69. nextEl: 'swiper-button-next',
  70. prevEl: 'swiper-button-prev'
  71. });
  72. if (!(params.nextEl || params.prevEl)) return;
  73. const $nextEl = getEl(params.nextEl);
  74. const $prevEl = getEl(params.prevEl);
  75. if ($nextEl && $nextEl.length > 0) {
  76. $nextEl.on('click', onNextClick);
  77. }
  78. if ($prevEl && $prevEl.length > 0) {
  79. $prevEl.on('click', onPrevClick);
  80. }
  81. Object.assign(swiper.navigation, {
  82. $nextEl,
  83. nextEl: $nextEl && $nextEl[0],
  84. $prevEl,
  85. prevEl: $prevEl && $prevEl[0]
  86. });
  87. if (!swiper.enabled) {
  88. if ($nextEl) $nextEl.addClass(params.lockClass);
  89. if ($prevEl) $prevEl.addClass(params.lockClass);
  90. }
  91. }
  92. function destroy() {
  93. const {
  94. $nextEl,
  95. $prevEl
  96. } = swiper.navigation;
  97. if ($nextEl && $nextEl.length) {
  98. $nextEl.off('click', onNextClick);
  99. $nextEl.removeClass(swiper.params.navigation.disabledClass);
  100. }
  101. if ($prevEl && $prevEl.length) {
  102. $prevEl.off('click', onPrevClick);
  103. $prevEl.removeClass(swiper.params.navigation.disabledClass);
  104. }
  105. }
  106. on('init', () => {
  107. init();
  108. update();
  109. });
  110. on('toEdge fromEdge lock unlock', () => {
  111. update();
  112. });
  113. on('destroy', () => {
  114. destroy();
  115. });
  116. on('enable disable', () => {
  117. const {
  118. $nextEl,
  119. $prevEl
  120. } = swiper.navigation;
  121. if ($nextEl) {
  122. $nextEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);
  123. }
  124. if ($prevEl) {
  125. $prevEl[swiper.enabled ? 'removeClass' : 'addClass'](swiper.params.navigation.lockClass);
  126. }
  127. });
  128. on('click', (_s, e) => {
  129. const {
  130. $nextEl,
  131. $prevEl
  132. } = swiper.navigation;
  133. const targetEl = e.target;
  134. if (swiper.params.navigation.hideOnClick && !$(targetEl).is($prevEl) && !$(targetEl).is($nextEl)) {
  135. if (swiper.pagination && swiper.params.pagination && swiper.params.pagination.clickable && (swiper.pagination.el === targetEl || swiper.pagination.el.contains(targetEl))) return;
  136. let isHidden;
  137. if ($nextEl) {
  138. isHidden = $nextEl.hasClass(swiper.params.navigation.hiddenClass);
  139. } else if ($prevEl) {
  140. isHidden = $prevEl.hasClass(swiper.params.navigation.hiddenClass);
  141. }
  142. if (isHidden === true) {
  143. emit('navigationShow');
  144. } else {
  145. emit('navigationHide');
  146. }
  147. if ($nextEl) {
  148. $nextEl.toggleClass(swiper.params.navigation.hiddenClass);
  149. }
  150. if ($prevEl) {
  151. $prevEl.toggleClass(swiper.params.navigation.hiddenClass);
  152. }
  153. }
  154. });
  155. Object.assign(swiper.navigation, {
  156. update,
  157. init,
  158. destroy
  159. });
  160. }