UNPKG

swiper

Version:

Most modern mobile touch slider and framework with hardware accelerated transitions

79 lines (62 loc) 2.55 kB
import React from 'react'; // eslint-disable-next-line import Swiper from '../../core'; function calcLoopedSlides(slides, swiperParams) { var slidesPerViewParams = swiperParams.slidesPerView; if (swiperParams.breakpoints) { var breakpoint = Swiper.prototype.getBreakpoint(swiperParams.breakpoints); var breakpointOnlyParams = breakpoint in swiperParams.breakpoints ? swiperParams.breakpoints[breakpoint] : undefined; if (breakpointOnlyParams && breakpointOnlyParams.slidesPerView) { slidesPerViewParams = breakpointOnlyParams.slidesPerView; } } var loopedSlides = Math.ceil(parseFloat(swiperParams.loopedSlides || slidesPerViewParams, 10)); loopedSlides += swiperParams.loopAdditionalSlides; if (loopedSlides > slides.length) { loopedSlides = slides.length; } return loopedSlides; } function renderLoop(swiper, slides, swiperParams) { var modifiedSlides = slides.map(function (child, index) { return React.cloneElement(child, { swiper: swiper, 'data-swiper-slide-index': index }); }); function duplicateSlide(child, index, position) { return React.cloneElement(child, { key: child.key + "-duplicate-" + index + "-" + position, className: (child.props.className || '') + " " + swiperParams.slideDuplicateClass }); } if (swiperParams.loopFillGroupWithBlank) { var blankSlidesNum = swiperParams.slidesPerGroup - modifiedSlides.length % swiperParams.slidesPerGroup; if (blankSlidesNum !== swiperParams.slidesPerGroup) { for (var i = 0; i < blankSlidesNum; i += 1) { var blankSlide = /*#__PURE__*/React.createElement("div", { className: swiperParams.slideClass + " " + swiperParams.slideBlankClass }); modifiedSlides.push(blankSlide); } } } if (swiperParams.slidesPerView === 'auto' && !swiperParams.loopedSlides) { swiperParams.loopedSlides = modifiedSlides.length; } var loopedSlides = calcLoopedSlides(modifiedSlides, swiperParams); var prependSlides = []; var appendSlides = []; modifiedSlides.forEach(function (child, index) { if (index < loopedSlides) { appendSlides.push(duplicateSlide(child, index, 'prepend')); } if (index < modifiedSlides.length && index >= modifiedSlides.length - loopedSlides) { prependSlides.push(duplicateSlide(child, index, 'append')); } }); if (swiper) { swiper.loopedSlides = loopedSlides; } return [].concat(prependSlides, modifiedSlides, appendSlides); } export { calcLoopedSlides, renderLoop };