diff --git a/src/components/Carousel/Carousel.tsx b/src/components/Carousel/Carousel.tsx index fcda6099..c9d6bf40 100644 --- a/src/components/Carousel/Carousel.tsx +++ b/src/components/Carousel/Carousel.tsx @@ -82,6 +82,7 @@ const Carousel = forwardRef( { loop, startIndex, + inViewThreshold: 0.99, }, [ ...(useWheelGestures @@ -119,12 +120,15 @@ const Carousel = forwardRef( [api], ); - const onSettle = useCallback( + const onSlidesInView = useCallback( (api: CarouselApi) => { if (!api) { return; } - onSlideChange?.(api.selectedScrollSnap()); + const slideIndex = api.slidesInView()?.[0]; + if (slideIndex !== undefined) { + onSlideChange?.(slideIndex); + } }, [onSlideChange], ); @@ -133,15 +137,11 @@ const Carousel = forwardRef( if (!api) { return; } - onSettle(api); - api.on('reInit', onSettle); - api.on('settle', onSettle); - + api.on('slidesInView', onSlidesInView); return () => { - api?.off('settle', onSettle); - api?.off('reInit', onSettle); + api.off('slidesInView', onSlidesInView); }; - }, [api, onSettle]); + }, [api, onSlidesInView]); return ( { /** * Aspect ratio of the video - * Defaults to 1.777 (16/9) */ aspectRatio?: number; /** * The url of the video source */ videoSource: string; + /** + * The ref to the iframe + */ + iframeRef?: React.Ref; + /** + * The class name for the iframe + */ + iframeClassName?: string; } /** * ## Overview @@ -22,29 +29,34 @@ export interface VideoProps extends ComponentProps<'div'> { * * [Storybook Link](https://phillips-seldon.netlify.app/?path=/docs/components-video--overview) */ -const Video = ({ aspectRatio = 16 / 9, className, videoSource, ...props }: VideoProps) => { - const { className: baseClassName, 'data-testid': dataTestId, ...commonProps } = getCommonProps(props, 'Video'); +const Video = forwardRef( + ({ aspectRatio, className, videoSource, iframeRef, iframeClassName, ...props }, ref) => { + const { className: baseClassName, 'data-testid': dataTestId, ...commonProps } = getCommonProps(props, 'Video'); + + const componentProps = { + className: classnames(baseClassName, className), + 'data-testid': dataTestId, + style: { '--aspect-ratio': aspectRatio } as React.CSSProperties, + ...commonProps, + ...props, + }; - const componentProps = { - className: classnames(baseClassName, className), - 'data-testid': dataTestId, - style: { '--aspect-ratio': aspectRatio } as React.CSSProperties, - ...commonProps, - ...props, - }; + return ( +
+