ctt-babylon 0.1.109 → 0.1.110
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, effect, EventEmitter, input, Input, Output } from '@angular/core';
|
|
2
|
-
import { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';
|
|
3
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, effect, EventEmitter, input, Input, Output, } from '@angular/core';
|
|
3
|
+
import Swiper from 'swiper';
|
|
4
|
+
import { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "../../../services/screen-sizer";
|
|
6
7
|
export class BabylonTopSliderComponent {
|
|
@@ -36,8 +37,61 @@ export class BabylonTopSliderComponent {
|
|
|
36
37
|
}
|
|
37
38
|
}
|
|
38
39
|
updateParallax() {
|
|
39
|
-
|
|
40
|
-
|
|
40
|
+
const parallaxSliderSelector = '.cs_parallax_slider';
|
|
41
|
+
const interleaveOffset = 0.5;
|
|
42
|
+
const parallaxSliderElement = document.querySelector(parallaxSliderSelector);
|
|
43
|
+
if (parallaxSliderElement) {
|
|
44
|
+
const slides = parallaxSliderElement.querySelectorAll('.swiper-slide');
|
|
45
|
+
const slideCount = slides.length;
|
|
46
|
+
const mainSliderOptions = {
|
|
47
|
+
loop: false,
|
|
48
|
+
speed: 1000,
|
|
49
|
+
autoplay: slideCount > 1 ? { delay: 3000 } : false,
|
|
50
|
+
loopAdditionalSlides: 10,
|
|
51
|
+
grabCursor: slideCount > 1,
|
|
52
|
+
watchSlidesProgress: true,
|
|
53
|
+
navigation: {
|
|
54
|
+
nextEl: '.cs_swiper_button_next',
|
|
55
|
+
prevEl: '.cs_swiper_button_prev',
|
|
56
|
+
},
|
|
57
|
+
pagination: false,
|
|
58
|
+
on: {
|
|
59
|
+
init: (swp) => {
|
|
60
|
+
swp.autoplay?.stop();
|
|
61
|
+
},
|
|
62
|
+
imagesReady: (swp) => {
|
|
63
|
+
parallaxSliderElement.classList.remove('loading');
|
|
64
|
+
swp.autoplay?.start();
|
|
65
|
+
},
|
|
66
|
+
progress: (swp) => {
|
|
67
|
+
swp.slides.forEach((slide) => {
|
|
68
|
+
const slideProgress = slide.progress || 0;
|
|
69
|
+
const innerOffset = swp.width * interleaveOffset;
|
|
70
|
+
const innerTranslate = slideProgress * innerOffset;
|
|
71
|
+
const parallaxBg = slide.querySelector('.cs_swiper_parallax_bg');
|
|
72
|
+
if (parallaxBg) {
|
|
73
|
+
parallaxBg.style.transform = `translateX(${innerTranslate}px)`;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
},
|
|
77
|
+
touchStart: function () {
|
|
78
|
+
this.slides.forEach((slide) => {
|
|
79
|
+
slide.style.transition = '';
|
|
80
|
+
});
|
|
81
|
+
},
|
|
82
|
+
setTransition: (swp, transition) => {
|
|
83
|
+
swp.slides.forEach((slide) => {
|
|
84
|
+
slide.style.transition =
|
|
85
|
+
`${transition}ms`;
|
|
86
|
+
const parallaxBg = slide.querySelector('.cs_swiper_parallax_bg');
|
|
87
|
+
if (parallaxBg) {
|
|
88
|
+
parallaxBg.style.transition = `${transition}ms`;
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
},
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
new Swiper(parallaxSliderSelector, mainSliderOptions);
|
|
41
95
|
}
|
|
42
96
|
}
|
|
43
97
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonTopSliderComponent, deps: [{ token: i1.ScreenSizerService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -53,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
53
107
|
}], btnClick: [{
|
|
54
108
|
type: Output
|
|
55
109
|
}] } });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,KAAK,EAAU,MAAM,EAAG,MAAM,eAAe,CAAC;AAGxH,OAAO,EAAE,8BAA8B,EAAE,MAAM,+DAA+D,CAAC;AAC/G,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;AAkB/C,MAAM,OAAO,yBAAyB;IAWpC,YAA6B,WAA+B;QAA/B,gBAAW,GAAX,WAAW,CAAoB;QAP5D,UAAK,GAAG,KAAK,EAA0B,CAAC;QACxC,gBAAW,GAAG,KAAK,EAA0B,CAAC;QAEpC,aAAQ,GAAG,IAAI,YAAY,EAAkB,CAAC;QAExD,WAAM,GAAY,KAAK,CAAC;QAGtB,MAAM,CAAC,GAAG,EAAE;YACV,IAAG,IAAI,CAAC,WAAW,EAAE,EAAC;gBACpB,IAAI,CAAC,gBAAgB,EAAE,CAAC;aACzB;iBAAM;gBACL,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IACD,QAAQ;QACN,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,eAAe,CAAC,KAAY,EAAE,SAAiB;QAC7C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;QACnD,IAAI,OAAO,EAAE;YACT,OAAO,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;SAClD;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE;YAC9D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAED,cAAc;QACZ,IAAI,MAAM,IAAI,MAAM,CAAC,oBAAoB,EAAE;YACzC,MAAM,CAAC,oBAAoB,EAAE,CAAC;SAC/B;IACH,CAAC;+GA3CU,yBAAyB;mGAAzB,yBAAyB,wnBCtBtC,6mIAyFA,kywBDxEY,YAAY,+BAAE,8BAA8B;;4FAK3C,yBAAyB;kBARrC,SAAS;+BACE,wBAAwB,cACtB,IAAI,WACP,CAAC,YAAY,EAAE,8BAA8B,CAAC,mBAGtC,uBAAuB,CAAC,MAAM;uFAGtC,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAKI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, effect, EventEmitter, input, Input, OnInit, Output  } from '@angular/core';\nimport { BabylonTopSliderItem } from './babylon-top-slider-item.interface';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';\nimport { CommonModule } from '@angular/common';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\n\ndeclare global {\n  interface Window {\n    parallaxSwiperSlider: () => void;\n  }\n}\n\n@Component({\n  selector: 'lib-babylon-top-slider',\n  standalone: true,\n  imports: [CommonModule, BabylonDataBackgroundDirective],\n  templateUrl: './babylon-top-slider.component.html',\n  styleUrl: './babylon-top-slider.component.scss',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderComponent implements OnInit {\n  @Input() buttons?: BabylonButtonI[];\n  @Input() logo?: BabylonImageI;\n\n  items = input<BabylonTopSliderItem[]>();\n  itemsMobile = input<BabylonTopSliderItem[]>();\n\n  @Output() btnClick = new EventEmitter<BabylonButtonI>();\n\n  mobile: boolean = false;\n\n  constructor(private readonly screenSizer: ScreenSizerService) {\n    effect(() => {\n      if(this.itemsMobile()){\n        this.checkScreenSizer();\n      } else {\n        this.updateParallax();\n      }\n    })\n  }\n  ngOnInit(): void {\n    this.checkScreenSizer();\n  }\n\n  scrollToSection(event: Event, sectionId: string): void {\n    event.preventDefault();\n    const section = document.getElementById(sectionId);\n    if (section) {\n        section.scrollIntoView({ behavior: 'smooth' });\n    }\n  }\n\n  checkScreenSizer(): void {\n    if (this.screenSizer.width < 768 && this.itemsMobile()?.length) {\n      this.mobile = true;\n      this.updateParallax();\n    }\n  }\n\n  updateParallax(): void {\n    if (window && window.parallaxSwiperSlider) {\n      window.parallaxSwiperSlider();\n    }\n  }\n}\n","<section class=\"babylon__topslider margin-main-botom\">\n    <div class=\"cs_parallax_slider loading overflow-hidden position-relative\">\n        @if ((mobile && this.itemsMobile()?.length) || items()?.length) {\n            <div class=\"swiper-wrapper\">\n                @for (item of mobile ? itemsMobile() : items(); track $index) {\n                    <div class=\"swiper-slide\">\n                        <div\n                            class=\"cs_hero cs_style_1 cs_center text-center position-relative\"\n                        >\n                            @if (item.img) {\n                                <figure\n                                    class=\"cs_swiper_parallax_bg cs_hero_bg cs_bg_filed h-100 w-100 position-absolute top-0 start-0 mb-0\"\n                                    dataBackground=\"url('{{ item.img.src }}')\"\n                                ></figure>\n                            }\n                            <div\n                                class=\"container position-relative cs_zindex_3\"\n                            >\n                                <div class=\"cs_hero_text\">\n                                    @if (item.subtitle) {\n                                        <h2 class=\"pretitle_carrusel\">\n                                            {{ item.subtitle }}\n                                        </h2>\n                                    }\n                                    @if (item.title) {\n                                        <h1 class=\"title_carrusel\">\n                                            {{ item.title }}\n                                        </h1>\n                                    }\n                                    @if (item?.buttons?.length) {\n                                        @for (\n                                            button of item?.buttons;\n                                            track $index\n                                        ) {\n                                            <div\n                                                class=\"btns__box align--center\"\n                                            >\n                                                <a\n                                                    [href]=\"button?.url ?? '#'\"\n                                                    class=\"btn btn_primary btn--light\"\n                                                >\n                                                    <b>{{\n                                                        button?.label ?? ''\n                                                    }}</b>\n                                                    <span\n                                                        class=\"babylon-arrow-right-big\"\n                                                    ></span>\n                                                </a>\n                                            </div>\n                                        }\n                                    }\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n        }\n    </div>\n    @if ((mobile && itemsMobile()?.length) || (!mobile && items()?.length)) {\n        <div class=\"cs_slider_navigation cs_white_color\">\n            <div class=\"cs_swiper_button_prev\">\n                <span class=\"babylon-arrow-left-big\"></span>\n            </div>\n            <div class=\"cs_swiper_button_next\">\n                <span class=\"babylon-arrow-right-big\"></span>\n            </div>\n        </div>\n    }\n    @if (logo) {\n        <img\n            [src]=\"logo.src\"\n            [alt]=\"logo.alt\"\n            class=\"top-slider-logo\"\n            loading=\"lazy\"\n        />\n    }\n    <div class=\"mouse_wp\">\n        <a\n            href=\"#first_section\"\n            aria-label=\"first_section\"\n            (click)=\"scrollToSection($event, 'first_section')\"\n            class=\"cs_down_btn_2\"\n        >\n            <div class=\"mouse\"></div>\n        </a>\n    </div>\n</section>\n<div id=\"first_section\"></div>\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-top-slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-top-slider/babylon-top-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    effect,\n    EventEmitter,\n    input,\n    Input,\n    OnInit,\n    Output,\n} from '@angular/core';\nimport Swiper, { SwiperOptions } from 'swiper';\nimport { BabylonDataBackgroundDirective } from '../../../directives/data-background/data-background.directive';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { ScreenSizerService } from '../../../services/screen-sizer';\nimport { BabylonTopSliderItem } from './babylon-top-slider-item.interface';\n\n@Component({\n    selector: 'lib-babylon-top-slider',\n    standalone: true,\n    imports: [CommonModule, BabylonDataBackgroundDirective],\n    templateUrl: './babylon-top-slider.component.html',\n    styleUrl: './babylon-top-slider.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonTopSliderComponent implements OnInit {\n    @Input() buttons?: BabylonButtonI[];\n    @Input() logo?: BabylonImageI;\n\n    items = input<BabylonTopSliderItem[]>();\n    itemsMobile = input<BabylonTopSliderItem[]>();\n\n    @Output() btnClick = new EventEmitter<BabylonButtonI>();\n\n    mobile: boolean = false;\n\n    constructor(private readonly screenSizer: ScreenSizerService) {\n        effect(() => {\n            if (this.itemsMobile()) {\n                this.checkScreenSizer();\n            } else {\n                this.updateParallax();\n            }\n        });\n    }\n    ngOnInit(): void {\n        this.checkScreenSizer();\n    }\n\n    scrollToSection(event: Event, sectionId: string): void {\n        event.preventDefault();\n        const section = document.getElementById(sectionId);\n        if (section) {\n            section.scrollIntoView({ behavior: 'smooth' });\n        }\n    }\n\n    checkScreenSizer(): void {\n        if (this.screenSizer.width < 768 && this.itemsMobile()?.length) {\n            this.mobile = true;\n            this.updateParallax();\n        }\n    }\n\n    updateParallax(): void {\n        const parallaxSliderSelector = '.cs_parallax_slider';\n        const interleaveOffset = 0.5;\n\n        const parallaxSliderElement = document.querySelector(\n            parallaxSliderSelector\n        );\n        if (parallaxSliderElement) {\n            const slides =\n                parallaxSliderElement.querySelectorAll('.swiper-slide');\n            const slideCount = slides.length;\n\n            const mainSliderOptions: SwiperOptions = {\n                loop: false,\n                speed: 1000,\n                autoplay: slideCount > 1 ? { delay: 3000 } : false,\n                loopAdditionalSlides: 10,\n                grabCursor: slideCount > 1,\n                watchSlidesProgress: true,\n                navigation: {\n                    nextEl: '.cs_swiper_button_next',\n                    prevEl: '.cs_swiper_button_prev',\n                },\n                pagination: false,\n                on: {\n                    init: (swp: Swiper) => {\n                        swp.autoplay?.stop();\n                    },\n                    imagesReady: (swp: Swiper) => {\n                        parallaxSliderElement.classList.remove('loading');\n                        swp.autoplay?.start();\n                    },\n                    progress: (swp: Swiper) => {\n                        swp.slides.forEach((slide) => {\n                            const slideProgress = (slide as any).progress || 0;\n                            const innerOffset = swp.width * interleaveOffset;\n                            const innerTranslate = slideProgress * innerOffset;\n\n                            const parallaxBg = slide.querySelector<HTMLElement>(\n                                '.cs_swiper_parallax_bg'\n                            );\n                            if (parallaxBg) {\n                                parallaxBg.style.transform = `translateX(${innerTranslate}px)`;\n                            }\n                        });\n                    },\n                    touchStart: function (this: Swiper) {\n                        this.slides.forEach((slide) => {\n                            (slide as HTMLElement).style.transition = '';\n                        });\n                    },\n                    setTransition: (swp: Swiper, transition: number) => {\n                        swp.slides.forEach((slide) => {\n                            (slide as HTMLElement).style.transition =\n                                `${transition}ms`;\n                            const parallaxBg = slide.querySelector<HTMLElement>(\n                                '.cs_swiper_parallax_bg'\n                            );\n                            if (parallaxBg) {\n                                parallaxBg.style.transition = `${transition}ms`;\n                            }\n                        });\n                    },\n                },\n            };\n\n            new Swiper(parallaxSliderSelector, mainSliderOptions);\n        }\n    }\n}\n","<section class=\"babylon__topslider margin-main-botom\">\n    <div class=\"cs_parallax_slider loading overflow-hidden position-relative\">\n        @if ((mobile && this.itemsMobile()?.length) || items()?.length) {\n            <div class=\"swiper-wrapper\">\n                @for (item of mobile ? itemsMobile() : items(); track $index) {\n                    <div class=\"swiper-slide\">\n                        <div\n                            class=\"cs_hero cs_style_1 cs_center text-center position-relative\"\n                        >\n                            @if (item.img) {\n                                <figure\n                                    class=\"cs_swiper_parallax_bg cs_hero_bg cs_bg_filed h-100 w-100 position-absolute top-0 start-0 mb-0\"\n                                    dataBackground=\"url('{{ item.img.src }}')\"\n                                ></figure>\n                            }\n                            <div\n                                class=\"container position-relative cs_zindex_3\"\n                            >\n                                <div class=\"cs_hero_text\">\n                                    @if (item.subtitle) {\n                                        <h2 class=\"pretitle_carrusel\">\n                                            {{ item.subtitle }}\n                                        </h2>\n                                    }\n                                    @if (item.title) {\n                                        <h1 class=\"title_carrusel\">\n                                            {{ item.title }}\n                                        </h1>\n                                    }\n                                    @if (item?.buttons?.length) {\n                                        @for (\n                                            button of item?.buttons;\n                                            track $index\n                                        ) {\n                                            <div\n                                                class=\"btns__box align--center\"\n                                            >\n                                                <a\n                                                    [href]=\"button?.url ?? '#'\"\n                                                    class=\"btn btn_primary btn--light\"\n                                                >\n                                                    <b>{{\n                                                        button?.label ?? ''\n                                                    }}</b>\n                                                    <span\n                                                        class=\"babylon-arrow-right-big\"\n                                                    ></span>\n                                                </a>\n                                            </div>\n                                        }\n                                    }\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n        }\n    </div>\n    @if ((mobile && itemsMobile()?.length) || (!mobile && items()?.length)) {\n        <div class=\"cs_slider_navigation cs_white_color\">\n            <div class=\"cs_swiper_button_prev\">\n                <span class=\"babylon-arrow-left-big\"></span>\n            </div>\n            <div class=\"cs_swiper_button_next\">\n                <span class=\"babylon-arrow-right-big\"></span>\n            </div>\n        </div>\n    }\n    @if (logo) {\n        <img\n            [src]=\"logo.src\"\n            [alt]=\"logo.alt\"\n            class=\"top-slider-logo\"\n            loading=\"lazy\"\n        />\n    }\n    <div class=\"mouse_wp\">\n        <a\n            href=\"#first_section\"\n            aria-label=\"first_section\"\n            (click)=\"scrollToSection($event, 'first_section')\"\n            class=\"cs_down_btn_2\"\n        >\n            <div class=\"mouse\"></div>\n        </a>\n    </div>\n</section>\n<div id=\"first_section\"></div>\n"]}
|
package/fesm2022/ctt-babylon.mjs
CHANGED
|
@@ -19,6 +19,7 @@ import { Subject, takeUntil, tap, fromEvent, debounceTime, map, distinctUntilCha
|
|
|
19
19
|
import * as i1$3 from '@angular/material/dialog';
|
|
20
20
|
import { MatDialog, MatDialogRef } from '@angular/material/dialog';
|
|
21
21
|
import { trigger, state, transition, style, animate } from '@angular/animations';
|
|
22
|
+
import Swiper from 'swiper';
|
|
22
23
|
|
|
23
24
|
class Babylon404Component {
|
|
24
25
|
btnClick(e) {
|
|
@@ -5674,8 +5675,61 @@ class BabylonTopSliderComponent {
|
|
|
5674
5675
|
}
|
|
5675
5676
|
}
|
|
5676
5677
|
updateParallax() {
|
|
5677
|
-
|
|
5678
|
-
|
|
5678
|
+
const parallaxSliderSelector = '.cs_parallax_slider';
|
|
5679
|
+
const interleaveOffset = 0.5;
|
|
5680
|
+
const parallaxSliderElement = document.querySelector(parallaxSliderSelector);
|
|
5681
|
+
if (parallaxSliderElement) {
|
|
5682
|
+
const slides = parallaxSliderElement.querySelectorAll('.swiper-slide');
|
|
5683
|
+
const slideCount = slides.length;
|
|
5684
|
+
const mainSliderOptions = {
|
|
5685
|
+
loop: false,
|
|
5686
|
+
speed: 1000,
|
|
5687
|
+
autoplay: slideCount > 1 ? { delay: 3000 } : false,
|
|
5688
|
+
loopAdditionalSlides: 10,
|
|
5689
|
+
grabCursor: slideCount > 1,
|
|
5690
|
+
watchSlidesProgress: true,
|
|
5691
|
+
navigation: {
|
|
5692
|
+
nextEl: '.cs_swiper_button_next',
|
|
5693
|
+
prevEl: '.cs_swiper_button_prev',
|
|
5694
|
+
},
|
|
5695
|
+
pagination: false,
|
|
5696
|
+
on: {
|
|
5697
|
+
init: (swp) => {
|
|
5698
|
+
swp.autoplay?.stop();
|
|
5699
|
+
},
|
|
5700
|
+
imagesReady: (swp) => {
|
|
5701
|
+
parallaxSliderElement.classList.remove('loading');
|
|
5702
|
+
swp.autoplay?.start();
|
|
5703
|
+
},
|
|
5704
|
+
progress: (swp) => {
|
|
5705
|
+
swp.slides.forEach((slide) => {
|
|
5706
|
+
const slideProgress = slide.progress || 0;
|
|
5707
|
+
const innerOffset = swp.width * interleaveOffset;
|
|
5708
|
+
const innerTranslate = slideProgress * innerOffset;
|
|
5709
|
+
const parallaxBg = slide.querySelector('.cs_swiper_parallax_bg');
|
|
5710
|
+
if (parallaxBg) {
|
|
5711
|
+
parallaxBg.style.transform = `translateX(${innerTranslate}px)`;
|
|
5712
|
+
}
|
|
5713
|
+
});
|
|
5714
|
+
},
|
|
5715
|
+
touchStart: function () {
|
|
5716
|
+
this.slides.forEach((slide) => {
|
|
5717
|
+
slide.style.transition = '';
|
|
5718
|
+
});
|
|
5719
|
+
},
|
|
5720
|
+
setTransition: (swp, transition) => {
|
|
5721
|
+
swp.slides.forEach((slide) => {
|
|
5722
|
+
slide.style.transition =
|
|
5723
|
+
`${transition}ms`;
|
|
5724
|
+
const parallaxBg = slide.querySelector('.cs_swiper_parallax_bg');
|
|
5725
|
+
if (parallaxBg) {
|
|
5726
|
+
parallaxBg.style.transition = `${transition}ms`;
|
|
5727
|
+
}
|
|
5728
|
+
});
|
|
5729
|
+
},
|
|
5730
|
+
},
|
|
5731
|
+
};
|
|
5732
|
+
new Swiper(parallaxSliderSelector, mainSliderOptions);
|
|
5679
5733
|
}
|
|
5680
5734
|
}
|
|
5681
5735
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonTopSliderComponent, deps: [{ token: ScreenSizerService }], target: i0.ɵɵFactoryTarget.Component }); }
|