ctt-babylon 0.13.34 → 0.13.36

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.
Files changed (29) hide show
  1. package/esm2022/lib/components/core/babylon-he-me-svg-text-cta-mot/babylon-he-me-svg-text-cta-mot.component.mjs +104 -0
  2. package/esm2022/lib/components/core/babylon-he-me-svg-text-cta-mot/index.mjs +2 -0
  3. package/esm2022/lib/components/core/babylon-sli-c3-svg-vid-cta/babylon-sli-c3-svg-vid-cta.component.mjs +98 -0
  4. package/esm2022/lib/components/core/babylon-sli-c3-svg-vid-cta/index.mjs +2 -0
  5. package/esm2022/lib/components/core/index.mjs +3 -1
  6. package/esm2022/lib/components/external/core/c2-txt-cta-des/c2-txt-cta-des.component.mjs +3 -3
  7. package/esm2022/lib/components/external/core/c2-txt-img-v2/c2-txt-img-v2.component.mjs +86 -0
  8. package/esm2022/lib/components/external/core/c2-txt-img-v2/c2-txt-img-v2.content.json +29 -0
  9. package/esm2022/lib/components/external/core/c2-txt-img-v2/c2-txt-img-v2.interfaces.mjs +2 -0
  10. package/esm2022/lib/components/external/core/c2-txt-img-v2/index.mjs +2 -0
  11. package/esm2022/lib/components/external/core/index.mjs +2 -1
  12. package/esm2022/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.mjs +51 -93
  13. package/esm2022/lib/components/external/core/lis-c2-txt-img-svg-c/lis-c2-txt-img-svg-c.component.mjs +3 -3
  14. package/esm2022/lib/components/external/core/sli-c2-txt-img-svg-c/sli-c2-txt-img-svg-c.component.mjs +3 -3
  15. package/esm2022/lib/directives/sliders/swiper-init.directive.mjs +215 -0
  16. package/fesm2022/ctt-babylon.mjs +628 -151
  17. package/fesm2022/ctt-babylon.mjs.map +1 -1
  18. package/lib/components/core/babylon-he-me-svg-text-cta-mot/babylon-he-me-svg-text-cta-mot.component.d.ts +22 -0
  19. package/lib/components/core/babylon-he-me-svg-text-cta-mot/index.d.ts +1 -0
  20. package/lib/components/core/babylon-sli-c3-svg-vid-cta/babylon-sli-c3-svg-vid-cta.component.d.ts +14 -0
  21. package/lib/components/core/babylon-sli-c3-svg-vid-cta/index.d.ts +1 -0
  22. package/lib/components/core/index.d.ts +2 -0
  23. package/lib/components/external/core/c2-txt-img-v2/c2-txt-img-v2.component.d.ts +19 -0
  24. package/lib/components/external/core/c2-txt-img-v2/c2-txt-img-v2.interfaces.d.ts +14 -0
  25. package/lib/components/external/core/c2-txt-img-v2/index.d.ts +1 -0
  26. package/lib/components/external/core/index.d.ts +1 -0
  27. package/lib/components/external/core/lis-c2-txt-img/lis-c2-txt-img.component.d.ts +19 -17
  28. package/lib/directives/sliders/swiper-init.directive.d.ts +14 -0
  29. package/package.json +1 -1
@@ -0,0 +1,215 @@
1
+ import { isPlatformBrowser } from '@angular/common';
2
+ import { Directive, Inject, PLATFORM_ID, } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class SwiperInitDirective {
5
+ constructor(host, platformId) {
6
+ this.host = host;
7
+ this.platformId = platformId;
8
+ this.arrowCleanupFns = [];
9
+ }
10
+ async ngAfterViewInit() {
11
+ if (!isPlatformBrowser(this.platformId)) {
12
+ console.log('[SwiperInitDirective] No es browser, salgo');
13
+ return;
14
+ }
15
+ const parent = this.host.nativeElement;
16
+ const dataset = parent.dataset;
17
+ console.log('[SwiperInitDirective] ngAfterViewInit', {
18
+ parent,
19
+ dataset,
20
+ });
21
+ // Helpers para leer data-*
22
+ const get = (key) => dataset[key];
23
+ const getBool = (key) => get(key) === 'true';
24
+ const getNum = (key, fallback = 0) => {
25
+ const v = Number(get(key));
26
+ return Number.isFinite(v) ? v : fallback;
27
+ };
28
+ const sliderName = get('slider_name');
29
+ if (!sliderName) {
30
+ console.warn('[SwiperInitDirective] Sin data-slider_name en el parent', parent);
31
+ return;
32
+ }
33
+ const sliderSelector = parent.querySelector('.' + sliderName);
34
+ if (!sliderSelector) {
35
+ console.warn('[SwiperInitDirective] No encuentro el contenedor .', sliderName, ' dentro de ', parent);
36
+ return;
37
+ }
38
+ // Swiper ya inicializado → salir
39
+ if (sliderSelector.classList.contains('swiper-initialized')) {
40
+ console.log('[SwiperInitDirective] Swiper ya inicializado en este contenedor, salgo');
41
+ return;
42
+ }
43
+ // ====== LECTURA DE DATA-ATTRIBUTES ======
44
+ const showDots = getBool('slider_showdots');
45
+ const showButtons = getBool('slider_showbtns');
46
+ const fade = getBool('slider_fade');
47
+ const center = getBool('slider_centermode');
48
+ const autoplay = getBool('slider_autoplay');
49
+ const vertical = getBool('slider_vertical');
50
+ const rtl = getBool('slider_rtl');
51
+ const draggable = get('slider_draggable') !== 'false';
52
+ const adaptiveHeight = getBool('slider_adaptive_height');
53
+ const variableWidth = getBool('slider_variable_width');
54
+ const freeMode = getBool('slider_freemode');
55
+ const speed = getNum('slider_speed', 750);
56
+ const infinite = getBool('slides_infinite');
57
+ // contenedores
58
+ const navContainer = parent.querySelector('.js-slider-arrows');
59
+ const dotsContainer = parent.querySelector('.js-slider-dots');
60
+ // ====== SVG FLECHAS ======
61
+ const arrowSVG = `
62
+ <svg width="35" height="70" viewBox="0 0 35 70" fill="none" xmlns="http://www.w3.org/2000/svg">
63
+ <path d="M35 70C30.4037 70 25.8525 69.0947 21.6061 67.3358C17.3597 65.5769 13.5013 62.9988 10.2513 59.7487C7.00121 56.4987 4.42313 52.6403 2.66421 48.3939C0.9053 44.1475 -4.0182e-07 39.5963 0 35C4.0182e-07 30.4037 0.905303 25.8525 2.66422 21.6061C4.42313 17.3597 7.00121 13.5013 10.2513 10.2513C13.5013 7.00121 17.3597 4.42313 21.6061 2.66421C25.8525 0.9053 30.4037 -6.0273e-07 35 0V35V70Z" fill="#D0A67B"/>
64
+ <path d="M16.7368 28.126C16.5683 27.9578 16.2949 27.9577 16.1265 28.126C15.958 28.2944 15.9582 28.5678 16.1265 28.7363L22.6821 35.292L16.1265 41.8477C15.9579 42.0162 15.9579 42.2895 16.1265 42.458C16.295 42.6265 16.5683 42.6265 16.7368 42.458L23.5972 35.5977C23.6816 35.5133 23.7242 35.4026 23.7241 35.292C23.7241 35.1816 23.6814 35.0715 23.5972 34.9873L16.7368 28.126Z" fill="white"/>
65
+ </svg>`.trim();
66
+ if (showButtons && navContainer) {
67
+ if (!navContainer.querySelector('.swiper-button-prev')) {
68
+ const prev = document.createElement('div');
69
+ prev.className = 'swiper-button-prev';
70
+ prev.innerHTML = arrowSVG;
71
+ prev.style.transform = 'rotate(180deg)'; // Prev girada
72
+ navContainer.appendChild(prev);
73
+ }
74
+ if (!navContainer.querySelector('.swiper-button-next')) {
75
+ const next = document.createElement('div');
76
+ next.className = 'swiper-button-next';
77
+ next.innerHTML = arrowSVG;
78
+ navContainer.appendChild(next);
79
+ }
80
+ }
81
+ // ====== BREAKPOINTS ======
82
+ const slides_pc = getNum('slides_pc', 1);
83
+ const slides_laptop = getNum('slides_laptop', slides_pc);
84
+ const slides_tablet = getNum('slides_tablet', slides_laptop);
85
+ const slides_mobile = getNum('slides_mobile', slides_tablet);
86
+ const slides_mobile_small = getNum('slides_mobile_small', slides_mobile);
87
+ const slides_mobile_xsmall = getNum('slides_mobile_xsmall', slides_mobile_small);
88
+ // ====== OPCIONES SWIPER ======
89
+ const swiperOptions = {
90
+ direction: vertical ? 'vertical' : 'horizontal',
91
+ speed,
92
+ loop: infinite,
93
+ centeredSlides: center,
94
+ effect: fade ? 'fade' : 'slide',
95
+ autoplay: autoplay ? { delay: 5000 } : false,
96
+ allowTouchMove: draggable,
97
+ observer: true,
98
+ observeParents: true,
99
+ autoHeight: adaptiveHeight,
100
+ freeMode: freeMode ? { enabled: true, momentum: true } : false,
101
+ slidesPerView: variableWidth ? 'auto' : slides_mobile_xsmall,
102
+ spaceBetween: variableWidth ? 16 : 0,
103
+ navigation: showButtons && navContainer
104
+ ? {
105
+ nextEl: navContainer.querySelector('.swiper-button-next'),
106
+ prevEl: navContainer.querySelector('.swiper-button-prev'),
107
+ }
108
+ : undefined,
109
+ pagination: showDots && dotsContainer
110
+ ? { el: dotsContainer, clickable: true }
111
+ : undefined,
112
+ breakpoints: {
113
+ 540: {
114
+ slidesPerView: variableWidth ? 'auto' : slides_mobile_small,
115
+ freeMode: freeMode ? { enabled: true } : false,
116
+ },
117
+ 768: {
118
+ slidesPerView: variableWidth ? 'auto' : slides_mobile,
119
+ freeMode: freeMode ? { enabled: true } : false,
120
+ },
121
+ 1024: {
122
+ slidesPerView: variableWidth ? 'auto' : slides_tablet,
123
+ freeMode: freeMode ? { enabled: true } : false,
124
+ },
125
+ 1280: {
126
+ slidesPerView: variableWidth ? 'auto' : slides_laptop,
127
+ freeMode: freeMode ? { enabled: true } : false,
128
+ },
129
+ 1366: {
130
+ slidesPerView: variableWidth ? 'auto' : slides_pc,
131
+ freeMode: freeMode ? { enabled: true } : false,
132
+ },
133
+ },
134
+ };
135
+ // ====== INIT SWIPER ======
136
+ if (!Swiper) {
137
+ console.error('[SwiperInitDirective] Swiper global no encontrado (window.Swiper es falsy)');
138
+ return;
139
+ }
140
+ console.log('[SwiperInitDirective] INIT SWIPER', {
141
+ sliderName,
142
+ sliderSelector,
143
+ options: swiperOptions,
144
+ swiperType: typeof Swiper,
145
+ });
146
+ this.swiperInstance = new Swiper(sliderSelector, swiperOptions);
147
+ // Posición flechas tipo --sliderNav__position
148
+ this.initArrowPositioning(parent);
149
+ }
150
+ ngOnDestroy() {
151
+ if (!isPlatformBrowser(this.platformId))
152
+ return;
153
+ if (this.swiperInstance?.destroy) {
154
+ this.swiperInstance.destroy(true, true);
155
+ }
156
+ this.arrowCleanupFns.forEach((fn) => fn());
157
+ this.arrowCleanupFns = [];
158
+ }
159
+ // ======== POSICIÓN DE FLECHAS (equivalente js-slider_fix-arrows) ========
160
+ initArrowPositioning(parent) {
161
+ const sliders = parent.querySelectorAll('.js-slider_fix-arrows');
162
+ if (!sliders.length)
163
+ return;
164
+ sliders.forEach((slider) => {
165
+ const section = slider.closest('.js-active-slider') || parent;
166
+ if (!section)
167
+ return;
168
+ const calcPosition = () => {
169
+ let heightSelector = null;
170
+ const mobileSel = slider.querySelector('.js-slider_fix-arrows-zone.mobile');
171
+ const desktopSel = slider.querySelector('.js-slider_fix-arrows-zone.desktop');
172
+ const genericSel = slider.querySelector('.js-slider_fix-arrows-zone');
173
+ if (mobileSel && window.innerWidth <= 1279) {
174
+ heightSelector = mobileSel;
175
+ }
176
+ else if (desktopSel && window.innerWidth >= 1280) {
177
+ heightSelector = desktopSel;
178
+ }
179
+ else {
180
+ heightSelector = genericSel;
181
+ }
182
+ if (!heightSelector)
183
+ return;
184
+ const relative = heightSelector.closest('.relative');
185
+ if (!relative)
186
+ return;
187
+ const rect = heightSelector.getBoundingClientRect();
188
+ const parentRect = relative.getBoundingClientRect();
189
+ const height = rect.top - parentRect.top + rect.height / 2;
190
+ section.style.setProperty('--sliderNav__position', `${height}px`);
191
+ };
192
+ calcPosition();
193
+ setTimeout(calcPosition, 500);
194
+ const onScroll = () => calcPosition();
195
+ const onResize = () => calcPosition();
196
+ window.addEventListener('scroll', onScroll, { passive: true });
197
+ window.addEventListener('resize', onResize, { passive: true });
198
+ this.arrowCleanupFns.push(() => window.removeEventListener('scroll', onScroll));
199
+ this.arrowCleanupFns.push(() => window.removeEventListener('resize', onResize));
200
+ });
201
+ }
202
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SwiperInitDirective, deps: [{ token: i0.ElementRef }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
203
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: SwiperInitDirective, isStandalone: true, selector: ".js-active-slider,[appSwiperInit]", ngImport: i0 }); }
204
+ }
205
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SwiperInitDirective, decorators: [{
206
+ type: Directive,
207
+ args: [{
208
+ selector: '.js-active-slider,[appSwiperInit]',
209
+ standalone: true,
210
+ }]
211
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
212
+ type: Inject,
213
+ args: [PLATFORM_ID]
214
+ }] }] });
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"swiper-init.directive.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/directives/sliders/swiper-init.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    Directive,\n    ElementRef,\n    Inject,\n    OnDestroy,\n    PLATFORM_ID,\n} from '@angular/core';\n\n// Swiper global (viene del angular.json -> scripts)\ndeclare const Swiper: any;\n\n@Directive({\n    selector: '.js-active-slider,[appSwiperInit]',\n    standalone: true,\n})\nexport class SwiperInitDirective implements AfterViewInit, OnDestroy {\n    private swiperInstance?: any;\n    private arrowCleanupFns: Array<() => void> = [];\n\n    constructor(\n        private host: ElementRef<HTMLElement>,\n        @Inject(PLATFORM_ID) private platformId: object\n    ) {}\n\n    async ngAfterViewInit(): Promise<void> {\n        if (!isPlatformBrowser(this.platformId)) {\n            console.log('[SwiperInitDirective] No es browser, salgo');\n            return;\n        }\n\n        const parent = this.host.nativeElement;\n        const dataset = parent.dataset as DOMStringMap;\n\n        console.log('[SwiperInitDirective] ngAfterViewInit', {\n            parent,\n            dataset,\n        });\n\n        // Helpers para leer data-*\n        const get = (key: string): string | undefined => dataset[key];\n        const getBool = (key: string): boolean => get(key) === 'true';\n        const getNum = (key: string, fallback = 0): number => {\n            const v = Number(get(key));\n            return Number.isFinite(v) ? v : fallback;\n        };\n\n        const sliderName = get('slider_name');\n        if (!sliderName) {\n            console.warn(\n                '[SwiperInitDirective] Sin data-slider_name en el parent',\n                parent\n            );\n            return;\n        }\n\n        const sliderSelector = parent.querySelector<HTMLElement>(\n            '.' + sliderName\n        );\n        if (!sliderSelector) {\n            console.warn(\n                '[SwiperInitDirective] No encuentro el contenedor .',\n                sliderName,\n                ' dentro de ',\n                parent\n            );\n            return;\n        }\n\n        // Swiper ya inicializado → salir\n        if (sliderSelector.classList.contains('swiper-initialized')) {\n            console.log(\n                '[SwiperInitDirective] Swiper ya inicializado en este contenedor, salgo'\n            );\n            return;\n        }\n\n        // ====== LECTURA DE DATA-ATTRIBUTES ======\n        const showDots = getBool('slider_showdots');\n        const showButtons = getBool('slider_showbtns');\n        const fade = getBool('slider_fade');\n        const center = getBool('slider_centermode');\n        const autoplay = getBool('slider_autoplay');\n        const vertical = getBool('slider_vertical');\n        const rtl = getBool('slider_rtl');\n        const draggable = get('slider_draggable') !== 'false';\n        const adaptiveHeight = getBool('slider_adaptive_height');\n\n        const variableWidth = getBool('slider_variable_width');\n        const freeMode = getBool('slider_freemode');\n\n        const speed = getNum('slider_speed', 750);\n        const infinite = getBool('slides_infinite');\n\n        // contenedores\n        const navContainer =\n            parent.querySelector<HTMLElement>('.js-slider-arrows');\n        const dotsContainer =\n            parent.querySelector<HTMLElement>('.js-slider-dots');\n\n        // ====== SVG FLECHAS ======\n        const arrowSVG = `\n<svg width=\"35\" height=\"70\" viewBox=\"0 0 35 70\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<path d=\"M35 70C30.4037 70 25.8525 69.0947 21.6061 67.3358C17.3597 65.5769 13.5013 62.9988 10.2513 59.7487C7.00121 56.4987 4.42313 52.6403 2.66421 48.3939C0.9053 44.1475 -4.0182e-07 39.5963 0 35C4.0182e-07 30.4037 0.905303 25.8525 2.66422 21.6061C4.42313 17.3597 7.00121 13.5013 10.2513 10.2513C13.5013 7.00121 17.3597 4.42313 21.6061 2.66421C25.8525 0.9053 30.4037 -6.0273e-07 35 0V35V70Z\" fill=\"#D0A67B\"/>\n<path d=\"M16.7368 28.126C16.5683 27.9578 16.2949 27.9577 16.1265 28.126C15.958 28.2944 15.9582 28.5678 16.1265 28.7363L22.6821 35.292L16.1265 41.8477C15.9579 42.0162 15.9579 42.2895 16.1265 42.458C16.295 42.6265 16.5683 42.6265 16.7368 42.458L23.5972 35.5977C23.6816 35.5133 23.7242 35.4026 23.7241 35.292C23.7241 35.1816 23.6814 35.0715 23.5972 34.9873L16.7368 28.126Z\" fill=\"white\"/>\n</svg>`.trim();\n\n        if (showButtons && navContainer) {\n            if (!navContainer.querySelector('.swiper-button-prev')) {\n                const prev = document.createElement('div');\n                prev.className = 'swiper-button-prev';\n                prev.innerHTML = arrowSVG;\n                prev.style.transform = 'rotate(180deg)'; // Prev girada\n                navContainer.appendChild(prev);\n            }\n\n            if (!navContainer.querySelector('.swiper-button-next')) {\n                const next = document.createElement('div');\n                next.className = 'swiper-button-next';\n                next.innerHTML = arrowSVG;\n                navContainer.appendChild(next);\n            }\n        }\n\n        // ====== BREAKPOINTS ======\n        const slides_pc = getNum('slides_pc', 1);\n        const slides_laptop = getNum('slides_laptop', slides_pc);\n        const slides_tablet = getNum('slides_tablet', slides_laptop);\n        const slides_mobile = getNum('slides_mobile', slides_tablet);\n        const slides_mobile_small = getNum(\n            'slides_mobile_small',\n            slides_mobile\n        );\n        const slides_mobile_xsmall = getNum(\n            'slides_mobile_xsmall',\n            slides_mobile_small\n        );\n\n        // ====== OPCIONES SWIPER ======\n        const swiperOptions: any = {\n            direction: vertical ? 'vertical' : 'horizontal',\n            speed,\n            loop: infinite,\n            centeredSlides: center,\n            effect: fade ? 'fade' : 'slide',\n            autoplay: autoplay ? { delay: 5000 } : false,\n            allowTouchMove: draggable,\n            observer: true,\n            observeParents: true,\n            autoHeight: adaptiveHeight,\n\n            freeMode: freeMode ? { enabled: true, momentum: true } : false,\n\n            slidesPerView: variableWidth ? 'auto' : slides_mobile_xsmall,\n            spaceBetween: variableWidth ? 16 : 0,\n\n            navigation:\n                showButtons && navContainer\n                    ? {\n                          nextEl: navContainer.querySelector(\n                              '.swiper-button-next'\n                          ),\n                          prevEl: navContainer.querySelector(\n                              '.swiper-button-prev'\n                          ),\n                      }\n                    : undefined,\n\n            pagination:\n                showDots && dotsContainer\n                    ? { el: dotsContainer, clickable: true }\n                    : undefined,\n\n            breakpoints: {\n                540: {\n                    slidesPerView: variableWidth ? 'auto' : slides_mobile_small,\n                    freeMode: freeMode ? { enabled: true } : false,\n                },\n                768: {\n                    slidesPerView: variableWidth ? 'auto' : slides_mobile,\n                    freeMode: freeMode ? { enabled: true } : false,\n                },\n                1024: {\n                    slidesPerView: variableWidth ? 'auto' : slides_tablet,\n                    freeMode: freeMode ? { enabled: true } : false,\n                },\n                1280: {\n                    slidesPerView: variableWidth ? 'auto' : slides_laptop,\n                    freeMode: freeMode ? { enabled: true } : false,\n                },\n                1366: {\n                    slidesPerView: variableWidth ? 'auto' : slides_pc,\n                    freeMode: freeMode ? { enabled: true } : false,\n                },\n            },\n        };\n\n        // ====== INIT SWIPER ======\n        if (!Swiper) {\n            console.error(\n                '[SwiperInitDirective] Swiper global no encontrado (window.Swiper es falsy)'\n            );\n            return;\n        }\n\n        console.log('[SwiperInitDirective] INIT SWIPER', {\n            sliderName,\n            sliderSelector,\n            options: swiperOptions,\n            swiperType: typeof Swiper,\n        });\n\n        this.swiperInstance = new Swiper(sliderSelector, swiperOptions);\n\n        // Posición flechas tipo --sliderNav__position\n        this.initArrowPositioning(parent);\n    }\n\n    ngOnDestroy(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n\n        if (this.swiperInstance?.destroy) {\n            this.swiperInstance.destroy(true, true);\n        }\n\n        this.arrowCleanupFns.forEach((fn) => fn());\n        this.arrowCleanupFns = [];\n    }\n\n    // ======== POSICIÓN DE FLECHAS (equivalente js-slider_fix-arrows) ========\n    private initArrowPositioning(parent: HTMLElement): void {\n        const sliders = parent.querySelectorAll<HTMLElement>(\n            '.js-slider_fix-arrows'\n        );\n        if (!sliders.length) return;\n\n        sliders.forEach((slider) => {\n            const section =\n                slider.closest<HTMLElement>('.js-active-slider') || parent;\n            if (!section) return;\n\n            const calcPosition = () => {\n                let heightSelector: HTMLElement | null = null;\n\n                const mobileSel = slider.querySelector<HTMLElement>(\n                    '.js-slider_fix-arrows-zone.mobile'\n                );\n                const desktopSel = slider.querySelector<HTMLElement>(\n                    '.js-slider_fix-arrows-zone.desktop'\n                );\n                const genericSel = slider.querySelector<HTMLElement>(\n                    '.js-slider_fix-arrows-zone'\n                );\n\n                if (mobileSel && window.innerWidth <= 1279) {\n                    heightSelector = mobileSel;\n                } else if (desktopSel && window.innerWidth >= 1280) {\n                    heightSelector = desktopSel;\n                } else {\n                    heightSelector = genericSel;\n                }\n\n                if (!heightSelector) return;\n\n                const relative =\n                    heightSelector.closest<HTMLElement>('.relative');\n                if (!relative) return;\n\n                const rect = heightSelector.getBoundingClientRect();\n                const parentRect = relative.getBoundingClientRect();\n                const height = rect.top - parentRect.top + rect.height / 2;\n\n                section.style.setProperty(\n                    '--sliderNav__position',\n                    `${height}px`\n                );\n            };\n\n            calcPosition();\n            setTimeout(calcPosition, 500);\n\n            const onScroll = () => calcPosition();\n            const onResize = () => calcPosition();\n\n            window.addEventListener('scroll', onScroll, { passive: true });\n            window.addEventListener('resize', onResize, { passive: true });\n\n            this.arrowCleanupFns.push(() =>\n                window.removeEventListener('scroll', onScroll)\n            );\n            this.arrowCleanupFns.push(() =>\n                window.removeEventListener('resize', onResize)\n            );\n        });\n    }\n}\n"]}