Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Negative timeLeft and percentage in autoplayTimeLeft after autoplay stop then start #7084

Closed
5 of 6 tasks
DrawThree opened this issue Oct 5, 2023 · 1 comment
Closed
5 of 6 tasks

Comments

@DrawThree
Copy link

Check that this is really a bug

  • I confirm

Reproduction link

https://codesandbox.io/s/c2px7m

Bug description

After stopping autoplay, waiting for a number of seconds longer than the delay time, then starting autoplay, the timeLeft and percentage values in the autoplayTimeLeft event are negative.

Expected Behavior

The timeLeft and percentage should accurately reflect the time left before transition to the next slide and percentage of that time related to autoplay delay.

Actual Behavior

Using the reproduction link, run swiper.autoplay.stop(), wait for 5-10 seconds, then run swiper.autoplay.start().

The autoplayTimeLeft event will get negative numbers for timeLeft and percentage, and the progress countdown UI element will reflect this.

Swiper version

10.3.1

Platform/Target and Browser Versions

Windows Chrome 117.0.5938.132

Validations

  • Follow our Code of Conduct
  • Read the docs.
  • Check that there isn't already an issue that request the same feature to avoid creating a duplicate.
  • Make sure this is a Swiper issue and not a framework-specific issue

Would you like to open a PR for this bug?

  • I'm willing to open a PR
@VijayMeena701
Copy link

VijayMeena701 commented Jan 2, 2025

There is still an issue with this. Instead of returning negative values, it now outputs excessively high progress values. The expected range is between 0 and 1, but currently, it returns values well above 1, sometimes exceeding 10. This happens when you stop or pause the autoplay. Below is the code for reference.

btw i forgot to mention previously but i have slides with different delays in autoplay.

const CarouselPagination: React.FC = ({ bullets }) => {
const swiper = useSwiper();

useLayoutEffect(() => {
	// Cache DOM elements
	const bullets = Array.from(document.querySelectorAll<HTMLElement>(".swiper-pagination-bullet"));

	const handleSlideChange = (s: SwiperType) => {
		bullets.forEach((bullet, index) => {
			if (index < s.activeIndex) {
				bullet.style.opacity = "1";
				bullet.style.background = "rgba(255, 255, 255, 1)";
			} else {
				bullet.style.opacity = "1";
				bullet.style.background = "rgba(255, 255, 255, 0.4)";
			}
		});
	};

	const handleProgress = (s: SwiperType, _: number, progress: number) => {
		bullets.forEach((bullet, index) => {
			if (index === s.activeIndex) {
				bullet.style.opacity = "1";
				bullet.style.background = `linear-gradient(to right, #FFF ${(1 - progress) * 100}%, rgba(255, 255, 255, 0.4) ${(1 - progress) * 100}%)`;
			}
		});
	};

	swiper.on("slideChange", handleSlideChange);
	swiper.on("autoplayTimeLeft", handleProgress);

	return () => {
		swiper.off("slideChange", handleSlideChange);
		swiper.off("autoplayTimeLeft", handleProgress);
	};
}, [swiper, bullets]);

return (
	<Box
		sx={{
			position: "absolute",
			bottom: 0,
			left: 0,
			right: 0,
			zIndex: 12000,
			background: "linear-gradient(180deg, rgba(20, 20, 20, 0.01) 0%, rgba(20, 20, 20, 0.8) 100%)",
			height: 36,
			display: "flex",
			justifyContent: "center",
			alignItems: "center",
			gap: 0.5,
			p: 2,
		}}
	>
		{bullets.map((_, index) => (
			<Box
				component="span"
				key={index}
				className={`swiper-pagination-bullet swiper-pagination-bullet-${index}`}
				sx={{
					flex: 1,
					height: 2,
					background: "#FFF",
					borderRadius: 0,
				}}
			/>
		))}
	</Box>
);

};

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants