UNPKG

swiper

Version:

Most modern mobile touch slider and framework with hardware accelerated transitions

88 lines (67 loc) 2.82 kB
"use strict"; exports.__esModule = true; exports.calcLoopedSlides = calcLoopedSlides; exports.renderLoop = renderLoop; var _react = _interopRequireDefault(require("react")); var _core = _interopRequireDefault(require("../../core")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // eslint-disable-next-line function calcLoopedSlides(slides, swiperParams) { var slidesPerViewParams = swiperParams.slidesPerView; if (swiperParams.breakpoints) { var breakpoint = _core.default.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.default.cloneElement(child, { swiper: swiper, 'data-swiper-slide-index': index }); }); function duplicateSlide(child, index, position) { return _react.default.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.default.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); }