HEX
Server: Apache
System: Linux scp1.abinfocom.com 5.4.0-216-generic #236-Ubuntu SMP Fri Apr 11 19:53:21 UTC 2025 x86_64
User: confeduphaar (1010)
PHP: 8.1.33
Disabled: exec,passthru,shell_exec,system
Upload Files
File: //proc/thread-self/cwd/wp-content/plugins/essential-blocks/src/blocks/parallax-slider/src/slider.js
/**
 * Internal dependencies
 */
import Slide from "./slide";
import SliderControl from "./slide-control";

const Slider = ({ slides, attributes, setAttributes }) => {
	const { current, prevIcon, nextIcon, iconColor } = attributes;

	const handleSlideClick = (current) => setAttributes({ current });

	const handlePreviousClick = () => {
		const previous = current - 1;
		const updateCurrent = previous < 0 ? slides.length - 1 : previous;
		handleSlideClick(updateCurrent);
	};

	const handleNextClick = () => {
		const next = current + 1;
		const updateCurrent = next === slides.length ? 0 : next;
		handleSlideClick(updateCurrent);
	};

	const wrapperTransform = {
		transform: `translateX(-${current * (100 / slides.length)}%)`,
	};

	return (
		<div className="eb-parallax-container">
			<div className="eb-parallax-slider">
				<ul className="eb-parallax-wrapper" style={wrapperTransform}>
					{slides.map((slide, index) => (
						<Slide
							key={index}
							position={index}
							slide={slide}
							handleSlideClick={handleSlideClick}
							attributes={attributes}
						/>
					))}
				</ul>

				<div className="eb-slider__controls">
					<SliderControl
						type="previous"
						icon={prevIcon}
						handleClick={handlePreviousClick}
					/>

					<SliderControl
						type="next"
						icon={nextIcon}
						handleClick={handleNextClick}
					/>
				</div>
			</div>
		</div>
	);
};

export default Slider;