HOME


Mini Shell 1.0
DIR: /var/www/yme/wp-content/themes/oceanwp/assets/src/js/theme/
Upload File :
Current File : /var/www/yme/wp-content/themes/oceanwp/assets/src/js/theme/carousel.js
class Carousel {
  #elements;

  constructor(context) {
    this.#setElements();
    this.#start(context);
  }

  #setElements = () => {
    this.#elements = {
      body: document.body,
    };
  };

  #start = (context) => {
    const elementsString = `.gallery-format, .product-entry-slider${
      context ? `, ${context}` : ""
    }`;
    const elements = document.querySelectorAll(elementsString);

    elements.forEach((element) => {
      const flickity = new Flickity(element, {
        autoPlay: element.classList.contains("woo-entry-image") ? false : 7000,
        imagesLoaded: true,
        contain: true,
        rightToLeft: this.#elements.body.classList.contains("rtl")
          ? true
          : false,
      });

      const imgs = element.querySelectorAll(".carousel-cell img");
      // get transform property
      const docStyle = document.documentElement.style;
      const transformProp =
        typeof docStyle.transform == "string" ? "transform" : "WebkitTransform";

      flickity.on("scroll", function () {
        flickity.slides.forEach(function (slide, i) {
          const img = imgs[i];
          let x = ((slide.target + flickity.x) * -1) / 3;
          img.style[transformProp] = "translateX(" + x + "px)";
        });
      });
    });
  };
}

new Carousel();