Skip to content

Commit

Permalink
fix(react): dynamically enable/disable navigation/pagination/scrollbar
Browse files Browse the repository at this point in the history
fixes #4681
  • Loading branch information
nolimits4web committed Jun 16, 2021
1 parent 77d6909 commit d87ac0c
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 8 deletions.
1 change: 1 addition & 0 deletions src/react/get-params.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ function getParams(obj = {}) {
});
['navigation', 'pagination', 'scrollbar'].forEach((key) => {
if (params[key] === true) params[key] = {};
if (params[key] === false) delete params[key];
});

return { params, passedParams, rest, events };
Expand Down
11 changes: 10 additions & 1 deletion src/react/swiper.js
Original file line number Diff line number Diff line change
Expand Up @@ -145,7 +145,16 @@ const Swiper = forwardRef(
oldPassedParamsRef.current = passedParams;
oldSlides.current = slides;
if (changedParams.length && swiperRef.current && !swiperRef.current.destroyed) {
updateSwiper(swiperRef.current, slides, passedParams, changedParams);
updateSwiper({
swiper: swiperRef.current,
slides,
passedParams,
changedParams,
nextEl: nextElRef.current,
prevEl: prevElRef.current,
scrollbarEl: scrollbarElRef.current,
paginationEl: paginationElRef.current,
});
}
return () => {
detachEvents();
Expand Down
50 changes: 43 additions & 7 deletions src/react/update-swiper.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,15 @@
import { isObject, extend } from './utils';

function updateSwiper(swiper, slides, passedParams, changedParams) {
function updateSwiper({
swiper,
slides,
passedParams,
changedParams,
nextEl,
prevEl,
scrollbarEl,
paginationEl,
}) {
const updateParams = changedParams.filter((key) => key !== 'children' && key !== 'direction');
const { params: currentParams, pagination, navigation, scrollbar, virtual, thumbs } = swiper;
let needThumbsInit;
Expand Down Expand Up @@ -30,7 +39,7 @@ function updateSwiper(swiper, slides, passedParams, changedParams) {
if (
changedParams.includes('pagination') &&
passedParams.pagination &&
passedParams.pagination.el &&
(passedParams.pagination.el || paginationEl) &&
(currentParams.pagination || currentParams.pagination === false) &&
pagination &&
!pagination.el
Expand All @@ -41,19 +50,18 @@ function updateSwiper(swiper, slides, passedParams, changedParams) {
if (
changedParams.includes('scrollbar') &&
passedParams.scrollbar &&
passedParams.scrollbar.el &&
(passedParams.scrollbar.el || scrollbarEl) &&
(currentParams.scrollbar || currentParams.scrollbar === false) &&
scrollbar &&
!scrollbar.el
) {
needScrollbarInit = true;
}

if (
changedParams.includes('navigation') &&
passedParams.navigation &&
passedParams.navigation.prevEl &&
passedParams.navigation.nextEl &&
(passedParams.navigation.prevEl || prevEl) &&
(passedParams.navigation.nextEl || nextEl) &&
(currentParams.navigation || currentParams.navigation === false) &&
navigation &&
!navigation.prevEl &&
Expand All @@ -62,11 +70,35 @@ function updateSwiper(swiper, slides, passedParams, changedParams) {
needNavigationInit = true;
}

const destroyModule = (mod) => {
if (!swiper[mod]) return;
swiper[mod].destroy();
if (mod === 'navigation') {
currentParams[mod].prevEl = undefined;
currentParams[mod].nextEl = undefined;
swiper[mod].prevEl = undefined;
swiper[mod].nextEl = undefined;
} else {
currentParams[mod].el = undefined;
swiper[mod].el = undefined;
}
};

updateParams.forEach((key) => {
if (isObject(currentParams[key]) && isObject(passedParams[key])) {
extend(currentParams[key], passedParams[key]);
} else {
currentParams[key] = passedParams[key];
const newValue = passedParams[key];
if (
(newValue === true || newValue === false) &&
(key === 'navigation' || key === 'pagination' || key === 'scrollbar')
) {
if (newValue === false) {
destroyModule(key);
}
} else {
currentParams[key] = passedParams[key];
}
}
});

Expand All @@ -87,18 +119,22 @@ function updateSwiper(swiper, slides, passedParams, changedParams) {
}

if (needPaginationInit) {
if (paginationEl) currentParams.pagination.el = paginationEl;
pagination.init();
pagination.render();
pagination.update();
}

if (needScrollbarInit) {
if (scrollbarEl) currentParams.scrollbar.el = scrollbarEl;
scrollbar.init();
scrollbar.updateSize();
scrollbar.setTranslate();
}

if (needNavigationInit) {
if (nextEl) currentParams.navigation.nextEl = nextEl;
if (prevEl) currentParams.navigation.prevEl = prevEl;
navigation.init();
navigation.update();
}
Expand Down

0 comments on commit d87ac0c

Please sign in to comment.