loopCreate.js 1.44 KB
Newer Older
xhw committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
export default function loopCreate() {
	const swiper = this;
	const {
		params,
		$wrapperEl,
		native
	} = swiper; // Remove duplicated slides
	const $selector = $wrapperEl;
	let slides = native.children;

	if (params.loopFillGroupWithBlank) {
		const blankSlidesNum = params.slidesPerGroup - slides.length % params.slidesPerGroup;

		if (blankSlidesNum !== params.slidesPerGroup) {
			native.loopBlankShow = true;
			native.loopBlankNumber = blankSlidesNum;
		}
	}

	if (params.slidesPerView === 'auto' && !params.loopedSlides) params.loopedSlides = slides.length;
	swiper.loopedSlides = Math.ceil(parseFloat(params.loopedSlides || params.slidesPerView, 10));
	swiper.loopedSlides += params.loopAdditionalSlides;

	if (swiper.loopedSlides > slides.length) {
		swiper.loopedSlides = slides.length;
	}
	const prependSlides = [];
	const appendSlides = [];
	slides.forEach((el, index) => {
		const slide = el;
		if (index < slides.length && index >= slides.length - swiper.loopedSlides) {
			prependSlides.push(el);
		}

		if (index < swiper.loopedSlides) {
			appendSlides.push(el);
		}
	});
	let list = [...swiper.native.value];
	let newList = [...list];
	swiper.originalDataList = [...swiper.native.value];
	for (let i = 0; i < appendSlides.length; i += 1) {
		newList.push(list[appendSlides[i].index]);
	}

	for (let i = prependSlides.length - 1; i >= 0; i -= 1) {
		newList.unshift(list[prependSlides[i].index]);
	}
	swiper.native.$emit("input", newList)
	return true;
}