{"version":3,"sources":["webpack:///./assets/js/home22.js","webpack:///./assets/js/components/HomeTextColumn.js"],"names":["HomeTextColumn","redirectResponse","document","getElementById","swal","dataset","title","description","prevBtnSvgPath","nextBtnSvgPath","btnHtml","productSliderOptions","infinite","dots","slidesToShow","responsive","breakpoint","settings","prevArrow","replace","nextArrow","reviewSliderOptions","mobileFirst","swipeToSlide","$","slick","recentReviews","querySelector","reviewsUrl","url","forEach","item","style","cursor","href","addEventListener","location","handleRecentReviewLinks","videoImage","videoElement","videoUrl","iframe","test","navigator","platform","maxTouchPoints","window","MSStream","replaceImageWithVideo","remove","classList","add","insertAdjacentHTML","handleLazyVideo","this","textColumn","textColumnContent","textColumnOverflow","textColumnResizeButtons","querySelectorAll","onWindowResize","bind","setTextOverflowStatus","toggleTextOverflow","init","button","clearTimeout","timeout","setTimeout","textColumnContentHeight","clientHeight","textColumnOverflowHeight","toggle"],"mappings":"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","file":"home22.4524f8e4.js","sourcesContent":["import '../scss/home22.scss'\nimport '../scss/reviews_recent22.scss'\nimport HomeTextColumn from './components/HomeTextColumn'\n\nnew HomeTextColumn()\n\nconst redirectResponse = document.getElementById('redirect-response')\nif (redirectResponse !== null) {\n swal(redirectResponse.dataset.title, redirectResponse.dataset.description)\n}\n\nconst prevBtnSvgPath = '';\nconst nextBtnSvgPath = '';\nconst btnHtml = ''\n\nconst productSliderOptions = {\n infinite: true,\n dots: false,\n slidesToShow: 4,\n responsive: [\n {\n breakpoint: 1000,\n settings: { slidesToShow: 2 }\n },\n {\n breakpoint: 600,\n settings: { slidesToShow: 2 }\n },\n {\n breakpoint: 480,\n settings: { slidesToShow: 1 }\n }\n ],\n prevArrow: btnHtml\n .replace('%s', 'product-slider__prev slick-prev')\n .replace('%s', 'Previous')\n .replace('%s', prevBtnSvgPath),\n nextArrow: btnHtml\n .replace('%s', 'product-slider__next slick-next')\n .replace('%s', 'Next')\n .replace('%s', nextBtnSvgPath),\n}\n\nconst reviewSliderOptions = {\n infinite: true,\n mobileFirst: true,\n swipeToSlide: true,\n dots: false,\n slidesToShow: 1,\n responsive: [\n {\n breakpoint: 680,\n settings: { slidesToShow: 2 }\n },\n {\n breakpoint: 1024,\n settings: { slidesToShow: 3 }\n },\n {\n breakpoint: 1240,\n settings: { slidesToShow: 4 }\n }\n ],\n prevArrow: btnHtml\n .replace('%s', 'product-slider__prev slick-prev')\n .replace('%s', 'Previous')\n .replace('%s', prevBtnSvgPath),\n nextArrow: btnHtml\n .replace('%s', 'product-slider__next slick-next')\n .replace('%s', 'Next')\n .replace('%s', nextBtnSvgPath),\n}\n\n$('.product-slider-wrapper').slick(productSliderOptions)\n$('.recent-reviews__slider').slick(reviewSliderOptions)\n\nfunction handleRecentReviewLinks() {\n const recentReviews = document.querySelector('.recent-reviews');\n if (!recentReviews) {\n return;\n }\n const reviewsUrl = recentReviews.dataset.url\n if (!reviewsUrl) {\n return;\n }\n \n const reviewsStars = document.querySelector('.recent-reviews__stars');\n const reviewsDisplay = document.querySelector('.recent-reviews__display');\n \n [reviewsStars, reviewsDisplay].forEach((item) => {\n item.style.cursor = 'pointer';\n item.href = reviewsUrl;\n item.addEventListener('click', function() {\n document.location = reviewsUrl;\n })\n });\n}\n\nhandleRecentReviewLinks();\n\nfunction handleLazyVideo() {\n const videoImage = document.querySelector('.video-bar__image');\n const videoElement = document.querySelector('.video-bar__element');\n const videoUrl = videoImage.dataset.videoUrl;\n if (!videoImage || !videoElement || !videoUrl) {\n return;\n }\n\n const iframe = `\n \n `;\n\n function replaceImageWithVideo() {\n videoImage.remove();\n videoElement.classList.add('video-bar__element--active');\n videoElement.insertAdjacentHTML('afterbegin', iframe);\n }\n\n const isIOS = (/iPad|iPhone|iPod/.test(navigator.platform) ||\n (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1)) &&\n !window.MSStream;\n \n if (isIOS) {\n return replaceImageWithVideo();\n }\n\n videoImage.addEventListener('click', () => {\n replaceImageWithVideo();\n });\n}\n\nhandleLazyVideo();\n","const TEXT_COLUMN_HAS_OVERFLOW = 'text-column--has-overflow'\nconst TEXT_COLUMN_IS_EXPANDED = 'text-column--is-expanded'\n\nexport default class HomeTextColumn {\n constructor() {\n this.textColumn = document.querySelector('.text-column')\n this.textColumnContent = document.querySelector('.text-column__content')\n this.textColumnOverflow = document.querySelector('.text-column__overflow')\n this.textColumnResizeButtons = document.querySelectorAll('.text-column__resize')\n this.onWindowResize = this.onWindowResize.bind(this)\n this.setTextOverflowStatus = this.setTextOverflowStatus.bind(this)\n this.toggleTextOverflow = this.toggleTextOverflow.bind(this)\n\n if (this.textColumn) {\n this.init()\n }\n }\n\n init() {\n this.setTextOverflowStatus()\n window.addEventListener('resize', this.onWindowResize)\n\n this.textColumnResizeButtons.forEach((button) => {\n button.addEventListener('click', this.toggleTextOverflow)\n })\n }\n\n onWindowResize() {\n clearTimeout(this.timeout)\n this.timeout = setTimeout(() => {\n this.setTextOverflowStatus()\n }, 300)\n }\n\n setTextOverflowStatus() {\n const textColumnContentHeight = this.textColumnContent?.clientHeight\n const textColumnOverflowHeight = this.textColumnOverflow?.clientHeight\n\n if (!this.textColumn || !textColumnContentHeight || !textColumnOverflowHeight) {\n return\n }\n\n this.textColumn.classList.remove(TEXT_COLUMN_HAS_OVERFLOW)\n\n if (textColumnOverflowHeight >= textColumnContentHeight) {\n this.textColumn.classList.add(TEXT_COLUMN_HAS_OVERFLOW)\n }\n }\n\n toggleTextOverflow() {\n this.textColumn.classList.toggle(TEXT_COLUMN_IS_EXPANDED)\n }\n}\n"],"sourceRoot":""}