From daa986828136df5d5231f265d267884ab3fbcc90 Mon Sep 17 00:00:00 2001 From: Vishwajeet Date: Thu, 23 Nov 2023 03:07:26 +0530 Subject: [PATCH] fix(#2017): Dots state error when SlideToshow uses decimal value and infinite false. --- src/dots.js | 9 ++++----- src/utils/innerSliderUtils.js | 17 ++++++++++++----- 2 files changed, 16 insertions(+), 10 deletions(-) diff --git a/src/dots.js b/src/dots.js index 93520cbd7..0069ca665 100644 --- a/src/dots.js +++ b/src/dots.js @@ -2,8 +2,7 @@ import React from "react"; import classnames from "classnames"; -import { clamp } from "./utils/innerSliderUtils"; - +import { clamp, roundToDecimal } from "./utils/innerSliderUtils"; const getDotCount = spec => { let dots; @@ -46,14 +45,14 @@ export class Dots extends React.PureComponent { const mouseEvents = { onMouseEnter, onMouseOver, onMouseLeave }; let dots = []; for (let i = 0; i < dotCount; i++) { - let _rightBound = (i + 1) * slidesToScroll - 1; + let _rightBound = roundToDecimal((i + 1) * slidesToScroll - 1, 2); let rightBound = infinite ? _rightBound : clamp(_rightBound, 0, slideCount - 1); - let _leftBound = rightBound - (slidesToScroll - 1); + let _leftBound = roundToDecimal(rightBound - (slidesToScroll - 1), 2); let leftBound = infinite ? _leftBound - : clamp(_leftBound, 0, slideCount - 1); + : clamp(_leftBound, 0, roundToDecimal(slideCount - slidesToShow, 2)); let className = classnames({ "slick-active": infinite diff --git a/src/utils/innerSliderUtils.js b/src/utils/innerSliderUtils.js index c06029d0a..8e9e34409 100644 --- a/src/utils/innerSliderUtils.js +++ b/src/utils/innerSliderUtils.js @@ -6,10 +6,10 @@ export function clamp(number, lowerBound, upperBound) { export const safePreventDefault = event => { const passiveEvents = ["onTouchStart", "onTouchMove", "onWheel"]; - if(!passiveEvents.includes(event._reactName)) { + if (!passiveEvents.includes(event._reactName)) { event.preventDefault(); } -} +}; export const getOnDemandLazySlides = spec => { let onDemandSlides = []; @@ -386,9 +386,12 @@ export const swipeMove = (e, spec) => { let touchSwipeLength = touchObject.swipeLength; if (!infinite) { if ( - (currentSlide === 0 && (swipeDirection === "right" || swipeDirection === "down")) || - (currentSlide + 1 >= dotCount && (swipeDirection === "left" || swipeDirection === "up")) || - (!canGoNext(spec) && (swipeDirection === "left" || swipeDirection === "up")) + (currentSlide === 0 && + (swipeDirection === "right" || swipeDirection === "down")) || + (currentSlide + 1 >= dotCount && + (swipeDirection === "left" || swipeDirection === "up")) || + (!canGoNext(spec) && + (swipeDirection === "left" || swipeDirection === "up")) ) { touchSwipeLength = touchObject.swipeLength * edgeFriction; if (edgeDragged === false && onEdge) { @@ -849,3 +852,7 @@ export const canUseDOM = () => window.document && window.document.createElement ); +export function roundToDecimal(number, decimalPlaces) { + const factor = Math.pow(10, decimalPlaces); + return Math.round(number * factor) / factor; +}