ctt-babylon 0.8.14 → 0.8.16

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 (51) hide show
  1. package/esm2022/lib/components/core/babylon-advantages-v2/babylon-advantages-v2.component.mjs +16 -0
  2. package/esm2022/lib/components/core/babylon-advantages-v2/index.mjs +2 -0
  3. package/esm2022/lib/components/core/babylon-faq/babylon-faq.component.mjs +1 -1
  4. package/esm2022/lib/components/core/babylon-faq/babylon-faq.interface.mjs +1 -1
  5. package/esm2022/lib/components/core/babylon-faq-v2/babylon-faq-v2.component.mjs +30 -0
  6. package/esm2022/lib/components/core/babylon-faq-v2/index.mjs +2 -0
  7. package/esm2022/lib/components/core/babylon-footer-contact/babylon-footer-contact.component.mjs +3 -3
  8. package/esm2022/lib/components/core/babylon-modal-multiple-motors/babylon-modal-multiple-motors.component.mjs +3 -3
  9. package/esm2022/lib/components/core/babylon-slider-img-static-v2/babylon-slider-img-static-v2.component.mjs +19 -0
  10. package/esm2022/lib/components/core/babylon-slider-img-static-v2/index.mjs +2 -0
  11. package/esm2022/lib/components/core/babylon-social-bar/babylon-social-bar.component.mjs +20 -0
  12. package/esm2022/lib/components/core/babylon-social-bar/index.mjs +2 -0
  13. package/esm2022/lib/components/core/babylon-top-slider-video-v2/babylon-top-slider-video-v2.component.mjs +14 -0
  14. package/esm2022/lib/components/core/babylon-top-slider-video-v2/index.mjs +2 -0
  15. package/esm2022/lib/components/core/index.mjs +7 -1
  16. package/esm2022/lib/directives/sliders/slick-init.directive.mjs +211 -0
  17. package/esm2022/lib/directives/sliders/slider-fix-arrows.directive.mjs +105 -0
  18. package/esm2022/lib/directives/utils/sticky-avoid-footer.directive.mjs +91 -0
  19. package/esm2022/lib/interfaces/babylon-advantages-item.interface.mjs +2 -0
  20. package/esm2022/lib/interfaces/babylon-advantages.interface.mjs +2 -0
  21. package/esm2022/lib/interfaces/babylon-global.interface.mjs +2 -0
  22. package/esm2022/lib/interfaces/babylon-image.interface.mjs +1 -1
  23. package/esm2022/lib/interfaces/babylon-item.interface.mjs +2 -0
  24. package/esm2022/lib/interfaces/babylon-multimedia.interface.mjs +2 -0
  25. package/esm2022/lib/services/mapper/mapper.service.mjs +55 -5
  26. package/fesm2022/ctt-babylon.mjs +544 -9
  27. package/fesm2022/ctt-babylon.mjs.map +1 -1
  28. package/lib/components/core/babylon-advantages-v2/babylon-advantages-v2.component.d.ts +9 -0
  29. package/lib/components/core/babylon-advantages-v2/index.d.ts +1 -0
  30. package/lib/components/core/babylon-faq/babylon-faq.component.d.ts +2 -5
  31. package/lib/components/core/babylon-faq/babylon-faq.interface.d.ts +2 -2
  32. package/lib/components/core/babylon-faq-v2/babylon-faq-v2.component.d.ts +16 -0
  33. package/lib/components/core/babylon-faq-v2/index.d.ts +1 -0
  34. package/lib/components/core/babylon-slider-img-static-v2/babylon-slider-img-static-v2.component.d.ts +10 -0
  35. package/lib/components/core/babylon-slider-img-static-v2/index.d.ts +1 -0
  36. package/lib/components/core/babylon-social-bar/babylon-social-bar.component.d.ts +9 -0
  37. package/lib/components/core/babylon-social-bar/index.d.ts +1 -0
  38. package/lib/components/core/babylon-top-slider-video-v2/babylon-top-slider-video-v2.component.d.ts +7 -0
  39. package/lib/components/core/babylon-top-slider-video-v2/index.d.ts +1 -0
  40. package/lib/components/core/index.d.ts +6 -0
  41. package/lib/directives/sliders/slick-init.directive.d.ts +14 -0
  42. package/lib/directives/sliders/slider-fix-arrows.directive.d.ts +21 -0
  43. package/lib/directives/utils/sticky-avoid-footer.directive.d.ts +24 -0
  44. package/lib/interfaces/babylon-advantages-item.interface.d.ts +5 -0
  45. package/lib/interfaces/babylon-advantages.interface.d.ts +6 -0
  46. package/lib/interfaces/babylon-global.interface.d.ts +22 -0
  47. package/lib/interfaces/babylon-image.interface.d.ts +4 -0
  48. package/lib/interfaces/babylon-item.interface.d.ts +4 -0
  49. package/lib/interfaces/babylon-multimedia.interface.d.ts +5 -0
  50. package/lib/services/mapper/mapper.service.d.ts +3 -1
  51. package/package.json +1 -1
@@ -0,0 +1,211 @@
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 SlickInitDirective {
5
+ constructor(host, platformId) {
6
+ this.host = host;
7
+ this.platformId = platformId;
8
+ }
9
+ async ngAfterViewInit() {
10
+ if (!isPlatformBrowser(this.platformId))
11
+ return;
12
+ await this.waitForSlick(); // espera a $ y $.fn.slick
13
+ const parent = this.host.nativeElement;
14
+ const get = (name) => parent.getAttribute(name);
15
+ const getBool = (name) => {
16
+ const v = get(name);
17
+ return v === 'true' || v === '1' || v === '' || v === true;
18
+ };
19
+ const getNum = (name, def = 0) => {
20
+ const v = Number(get(name));
21
+ return Number.isFinite(v) ? v : def;
22
+ };
23
+ const sliderName = get('data-slider_name') || '';
24
+ const sliderSpeed = getNum('data-slider_speed', 750);
25
+ const showBtns = getBool('data-slider_showbtns');
26
+ const showDots = getBool('data-slider_showdots');
27
+ const fade = getBool('data-slider_fade');
28
+ const centerMode = getBool('data-slider_centermode');
29
+ const autoplay = getBool('data-slider_autoplay');
30
+ const slidesPc = getNum('data-slides_pc', 1);
31
+ const slidesLaptop = getNum('data-slides_laptop') || slidesPc;
32
+ const slidesTablet = getNum('data-slides_tablet') || slidesLaptop;
33
+ const slidesMobile = getNum('data-slides_mobile') || slidesTablet;
34
+ const slidesMobileSmall = getNum('data-slides_mobile_small') || slidesMobile;
35
+ const slidesMobileXSmall = getNum('data-slides_mobile_xsmall') || slidesMobileSmall;
36
+ const infinite = getBool('data-slides_infinite');
37
+ let rowsPc = getNum('data-slidesrows_pc', 1);
38
+ let rowsLaptop = getNum('data-slidesrows_laptop', 1);
39
+ let rowsTablet = getNum('data-slidesrows_tablet', 1);
40
+ let rowsMobile = getNum('data-slidesrows_mobile', 1);
41
+ let rowsMobileSmall = getNum('data-slidesrows_mobile_small', 1);
42
+ let rowsMobileXSmall = getNum('data-slidesrows_mobile_xsmall', 1);
43
+ const asNavFor = get('data-slider_asNavFor') || undefined;
44
+ const vertical = getBool('data-slider_vertical');
45
+ const adaptiveHeight = getBool('data-slider_adaptive_height');
46
+ const pause = getBool('data-slider_pause');
47
+ const draggable = getBool('data-slider_draggable');
48
+ const rtl = getBool('data-slider_rtl');
49
+ const variableWidth = getBool('data-slider_variable_width');
50
+ const btnsMode = get('data-slider_btns') || '';
51
+ if (window.innerWidth < 540 && parent.classList.contains('rows-2')) {
52
+ rowsPc = 1;
53
+ }
54
+ const sliderArrows = parent.querySelector('.js-slider-arrows');
55
+ const sliderDots = parent.querySelector('.js-slider-dots');
56
+ const sliderSelector = parent.querySelector('.' + sliderName);
57
+ if (!sliderSelector)
58
+ return;
59
+ this.sliderEl = sliderSelector;
60
+ if ($(sliderSelector).hasClass('slick-initialized'))
61
+ return;
62
+ let prevArrow = '';
63
+ let nextArrow = '';
64
+ if (btnsMode.includes('icon-small')) {
65
+ prevArrow +=
66
+ "<button type='button' class='slick-prev icon-small'><svg aria-hidden='true' focusable='false' class='line'><use href='/assets/babylon/svg/arrow-line.svg#arrow-line'></use></svg><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow.svg#icon-arrow'></use></svg></button>";
67
+ nextArrow +=
68
+ "<button type='button' class='slick-next icon-small'><svg aria-hidden='true' focusable='false' class='line'><use href='/assets/babylon/svg/arrow-line.svg#arrow-line'></use></svg><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow.svg#icon-arrow'></use></svg></button>";
69
+ }
70
+ if (btnsMode.includes('icon-large')) {
71
+ prevArrow +=
72
+ "<button type='button' class='slick-prev icon-large'><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow-large.svg#icon-arrow-large'></use></svg></button>";
73
+ nextArrow +=
74
+ "<button type='button' class='slick-next icon-large'><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow-large.svg#icon-arrow-large'></use></svg></button>";
75
+ }
76
+ // --- normalizar altura en vertical (sin 'this' implícito) ---
77
+ const updateVerticalHeight = () => {
78
+ const $el = $(sliderSelector);
79
+ if (window.innerWidth >= 541) {
80
+ let maxH = 0;
81
+ $el.find('.slick-slide:not(.slick-cloned)').each((_, el) => {
82
+ const h = $(el).outerHeight();
83
+ if (h > maxH)
84
+ maxH = h;
85
+ });
86
+ $el.find('.slick-slide').each((_, el) => {
87
+ $(el).css('height', `${maxH}px`);
88
+ });
89
+ }
90
+ else {
91
+ $(sliderSelector).find('.slick-slide').css('height', '');
92
+ }
93
+ };
94
+ if (vertical) {
95
+ $(sliderSelector).on('setPosition', updateVerticalHeight);
96
+ $(sliderSelector).on('init', () => setTimeout(updateVerticalHeight, 0));
97
+ this.resizeHandler = () => updateVerticalHeight();
98
+ window.addEventListener('resize', this.resizeHandler, {
99
+ passive: true,
100
+ });
101
+ }
102
+ // --- INIT SLICK ---
103
+ $(sliderSelector).slick({
104
+ dots: showDots,
105
+ arrows: showBtns,
106
+ appendArrows: sliderArrows || parent,
107
+ prevArrow,
108
+ nextArrow,
109
+ appendDots: sliderDots || parent,
110
+ infinite,
111
+ useTransform: true,
112
+ fade,
113
+ centerMode,
114
+ centerPadding: '0',
115
+ cssEase: 'cubic-bezier(0.785, 0.135, 0.15, 0.86)',
116
+ speed: sliderSpeed,
117
+ slidesToShow: slidesPc,
118
+ slidesToScroll: 1,
119
+ rows: rowsPc,
120
+ autoplay,
121
+ autoplaySpeed: 5000,
122
+ swipeToSlide: true,
123
+ vertical,
124
+ verticalSwiping: vertical,
125
+ adaptiveHeight,
126
+ asNavFor,
127
+ pauseOnFocus: pause,
128
+ pauseOnHover: pause,
129
+ draggable,
130
+ swipe: draggable,
131
+ rtl,
132
+ variableWidth,
133
+ responsive: [
134
+ {
135
+ breakpoint: 1680,
136
+ settings: { slidesToShow: slidesLaptop, rows: rowsLaptop },
137
+ },
138
+ {
139
+ breakpoint: 1366,
140
+ settings: { slidesToShow: slidesTablet, rows: rowsTablet },
141
+ },
142
+ {
143
+ breakpoint: 1280,
144
+ settings: { slidesToShow: slidesMobile, rows: rowsMobile },
145
+ },
146
+ {
147
+ breakpoint: 1023,
148
+ settings: {
149
+ slidesToShow: slidesMobileSmall,
150
+ rows: rowsMobileSmall,
151
+ },
152
+ },
153
+ {
154
+ breakpoint: 767,
155
+ settings: {
156
+ slidesToShow: slidesMobileXSmall,
157
+ rows: rowsMobileXSmall,
158
+ vertical: false,
159
+ verticalSwiping: false,
160
+ },
161
+ },
162
+ ],
163
+ });
164
+ }
165
+ ngOnDestroy() {
166
+ if (!isPlatformBrowser(this.platformId))
167
+ return;
168
+ if (this.sliderEl && $(this.sliderEl).hasClass('slick-initialized')) {
169
+ try {
170
+ $(this.sliderEl).slick('unslick');
171
+ }
172
+ catch {
173
+ /* nada */
174
+ }
175
+ }
176
+ if (this.resizeHandler) {
177
+ window.removeEventListener('resize', this.resizeHandler);
178
+ }
179
+ }
180
+ // Espera a $ y slick: resuelve (no rechaza) y loguea si no llegan
181
+ waitForSlick(timeoutMs = 4000, stepMs = 100) {
182
+ if (!isPlatformBrowser(this.platformId))
183
+ return Promise.resolve();
184
+ const start = performance.now();
185
+ return new Promise((resolve) => {
186
+ const check = () => {
187
+ if (typeof $ !== 'undefined' && $.fn && $.fn.slick)
188
+ return resolve();
189
+ if (performance.now() - start > timeoutMs) {
190
+ console.warn('[SlickInitDirective] Slick no disponible. ¿Cargaste jQuery y slick?');
191
+ return resolve(); // evita error si no llega
192
+ }
193
+ setTimeout(check, stepMs);
194
+ };
195
+ check();
196
+ });
197
+ }
198
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SlickInitDirective, deps: [{ token: i0.ElementRef }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Directive }); }
199
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: SlickInitDirective, isStandalone: true, selector: ".js-active-slider,[appSlickInit]", ngImport: i0 }); }
200
+ }
201
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SlickInitDirective, decorators: [{
202
+ type: Directive,
203
+ args: [{
204
+ selector: '.js-active-slider,[appSlickInit]',
205
+ standalone: true,
206
+ }]
207
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: undefined, decorators: [{
208
+ type: Inject,
209
+ args: [PLATFORM_ID]
210
+ }] }] });
211
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-init.directive.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/directives/sliders/slick-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// Si no tienes @types/jquery, déjalo como any\ndeclare const $: any;\n\n@Directive({\n    selector: '.js-active-slider,[appSlickInit]',\n    standalone: true,\n})\nexport class SlickInitDirective implements AfterViewInit, OnDestroy {\n    private resizeHandler?: () => void;\n    private sliderEl?: HTMLElement;\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)) return;\n        await this.waitForSlick(); // espera a $ y $.fn.slick\n\n        const parent = this.host.nativeElement;\n        const get = (name: string) => parent.getAttribute(name);\n        const getBool = (name: string) => {\n            const v = get(name);\n            return v === 'true' || v === '1' || v === '' || (v as any) === true;\n        };\n        const getNum = (name: string, def = 0) => {\n            const v = Number(get(name));\n            return Number.isFinite(v) ? v : def;\n        };\n\n        const sliderName = get('data-slider_name') || '';\n        const sliderSpeed = getNum('data-slider_speed', 750);\n        const showBtns = getBool('data-slider_showbtns');\n        const showDots = getBool('data-slider_showdots');\n        const fade = getBool('data-slider_fade');\n        const centerMode = getBool('data-slider_centermode');\n        const autoplay = getBool('data-slider_autoplay');\n        const slidesPc = getNum('data-slides_pc', 1);\n        const slidesLaptop = getNum('data-slides_laptop') || slidesPc;\n        const slidesTablet = getNum('data-slides_tablet') || slidesLaptop;\n        const slidesMobile = getNum('data-slides_mobile') || slidesTablet;\n        const slidesMobileSmall =\n            getNum('data-slides_mobile_small') || slidesMobile;\n        const slidesMobileXSmall =\n            getNum('data-slides_mobile_xsmall') || slidesMobileSmall;\n        const infinite = getBool('data-slides_infinite');\n\n        let rowsPc = getNum('data-slidesrows_pc', 1);\n        let rowsLaptop = getNum('data-slidesrows_laptop', 1);\n        let rowsTablet = getNum('data-slidesrows_tablet', 1);\n        let rowsMobile = getNum('data-slidesrows_mobile', 1);\n        let rowsMobileSmall = getNum('data-slidesrows_mobile_small', 1);\n        let rowsMobileXSmall = getNum('data-slidesrows_mobile_xsmall', 1);\n\n        const asNavFor = get('data-slider_asNavFor') || undefined;\n        const vertical = getBool('data-slider_vertical');\n        const adaptiveHeight = getBool('data-slider_adaptive_height');\n        const pause = getBool('data-slider_pause');\n        const draggable = getBool('data-slider_draggable');\n        const rtl = getBool('data-slider_rtl');\n        const variableWidth = getBool('data-slider_variable_width');\n        const btnsMode = get('data-slider_btns') || '';\n\n        if (window.innerWidth < 540 && parent.classList.contains('rows-2')) {\n            rowsPc = 1;\n        }\n\n        const sliderArrows = parent.querySelector(\n            '.js-slider-arrows'\n        ) as HTMLElement | null;\n        const sliderDots = parent.querySelector(\n            '.js-slider-dots'\n        ) as HTMLElement | null;\n        const sliderSelector = parent.querySelector(\n            '.' + sliderName\n        ) as HTMLElement | null;\n        if (!sliderSelector) return;\n        this.sliderEl = sliderSelector;\n\n        if ($(sliderSelector).hasClass('slick-initialized')) return;\n\n        let prevArrow = '';\n        let nextArrow = '';\n        if (btnsMode.includes('icon-small')) {\n            prevArrow +=\n                \"<button type='button' class='slick-prev icon-small'><svg aria-hidden='true' focusable='false' class='line'><use href='/assets/babylon/svg/arrow-line.svg#arrow-line'></use></svg><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow.svg#icon-arrow'></use></svg></button>\";\n            nextArrow +=\n                \"<button type='button' class='slick-next icon-small'><svg aria-hidden='true' focusable='false' class='line'><use href='/assets/babylon/svg/arrow-line.svg#arrow-line'></use></svg><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow.svg#icon-arrow'></use></svg></button>\";\n        }\n        if (btnsMode.includes('icon-large')) {\n            prevArrow +=\n                \"<button type='button' class='slick-prev icon-large'><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow-large.svg#icon-arrow-large'></use></svg></button>\";\n            nextArrow +=\n                \"<button type='button' class='slick-next icon-large'><svg aria-hidden='true' focusable='false'><use href='/assets/babylon/svg/icon-arrow-large.svg#icon-arrow-large'></use></svg></button>\";\n        }\n\n        // --- normalizar altura en vertical (sin 'this' implícito) ---\n        const updateVerticalHeight = () => {\n            const $el = $(sliderSelector);\n            if (window.innerWidth >= 541) {\n                let maxH = 0;\n                $el.find('.slick-slide:not(.slick-cloned)').each(\n                    (_: number, el: HTMLElement) => {\n                        const h = ($(el) as any).outerHeight();\n                        if (h > maxH) maxH = h;\n                    }\n                );\n                $el.find('.slick-slide').each((_: number, el: HTMLElement) => {\n                    ($(el) as any).css('height', `${maxH}px`);\n                });\n            } else {\n                $(sliderSelector).find('.slick-slide').css('height', '');\n            }\n        };\n\n        if (vertical) {\n            $(sliderSelector).on('setPosition', updateVerticalHeight);\n            $(sliderSelector).on('init', () =>\n                setTimeout(updateVerticalHeight, 0)\n            );\n            this.resizeHandler = () => updateVerticalHeight();\n            window.addEventListener('resize', this.resizeHandler, {\n                passive: true,\n            });\n        }\n\n        // --- INIT SLICK ---\n        $(sliderSelector).slick({\n            dots: showDots,\n            arrows: showBtns,\n            appendArrows: sliderArrows || parent,\n            prevArrow,\n            nextArrow,\n            appendDots: sliderDots || parent,\n            infinite,\n            useTransform: true,\n            fade,\n            centerMode,\n            centerPadding: '0',\n            cssEase: 'cubic-bezier(0.785, 0.135, 0.15, 0.86)',\n            speed: sliderSpeed,\n            slidesToShow: slidesPc,\n            slidesToScroll: 1,\n            rows: rowsPc,\n            autoplay,\n            autoplaySpeed: 5000,\n            swipeToSlide: true,\n            vertical,\n            verticalSwiping: vertical,\n            adaptiveHeight,\n            asNavFor,\n            pauseOnFocus: pause,\n            pauseOnHover: pause,\n            draggable,\n            swipe: draggable,\n            rtl,\n            variableWidth,\n            responsive: [\n                {\n                    breakpoint: 1680,\n                    settings: { slidesToShow: slidesLaptop, rows: rowsLaptop },\n                },\n                {\n                    breakpoint: 1366,\n                    settings: { slidesToShow: slidesTablet, rows: rowsTablet },\n                },\n                {\n                    breakpoint: 1280,\n                    settings: { slidesToShow: slidesMobile, rows: rowsMobile },\n                },\n                {\n                    breakpoint: 1023,\n                    settings: {\n                        slidesToShow: slidesMobileSmall,\n                        rows: rowsMobileSmall,\n                    },\n                },\n                {\n                    breakpoint: 767,\n                    settings: {\n                        slidesToShow: slidesMobileXSmall,\n                        rows: rowsMobileXSmall,\n                        vertical: false,\n                        verticalSwiping: false,\n                    },\n                },\n            ],\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n        if (this.sliderEl && $(this.sliderEl).hasClass('slick-initialized')) {\n            try {\n                $(this.sliderEl).slick('unslick');\n            } catch {\n                /* nada */\n            }\n        }\n        if (this.resizeHandler) {\n            window.removeEventListener('resize', this.resizeHandler);\n        }\n    }\n\n    // Espera a $ y slick: resuelve (no rechaza) y loguea si no llegan\n    private waitForSlick(timeoutMs = 4000, stepMs = 100): Promise<void> {\n        if (!isPlatformBrowser(this.platformId)) return Promise.resolve();\n        const start = performance.now();\n        return new Promise<void>((resolve) => {\n            const check = () => {\n                if (typeof $ !== 'undefined' && $.fn && $.fn.slick)\n                    return resolve();\n                if (performance.now() - start > timeoutMs) {\n                    console.warn(\n                        '[SlickInitDirective] Slick no disponible. ¿Cargaste jQuery y slick?'\n                    );\n                    return resolve(); // evita error si no llega\n                }\n                setTimeout(check, stepMs);\n            };\n            check();\n        });\n    }\n}\n"]}
@@ -0,0 +1,105 @@
1
+ import { Directive, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SliderFixArrowsDirective {
4
+ constructor(el, r2, zone) {
5
+ this.el = el;
6
+ this.r2 = r2;
7
+ this.zone = zone;
8
+ this.rafPending = false;
9
+ this.cleanups = [];
10
+ }
11
+ ngAfterViewInit() {
12
+ // Primer cálculo
13
+ this.calcPosition();
14
+ // Recalcular a los 500ms (similar a tu setTimeout)
15
+ setTimeout(() => this.calcPosition(), 500);
16
+ // Escuchar scroll/resize sin disparar change detection a lo loco
17
+ this.zone.runOutsideAngular(() => {
18
+ const onScroll = () => this.scheduleCalc();
19
+ const onResize = () => this.scheduleCalc();
20
+ window.addEventListener('scroll', onScroll, { passive: true });
21
+ window.addEventListener('resize', onResize, { passive: true });
22
+ this.cleanups.push(() => window.removeEventListener('scroll', onScroll));
23
+ this.cleanups.push(() => window.removeEventListener('resize', onResize));
24
+ });
25
+ }
26
+ ngOnDestroy() {
27
+ this.cleanups.forEach((fn) => fn());
28
+ }
29
+ scheduleCalc() {
30
+ if (this.rafPending)
31
+ return;
32
+ this.rafPending = true;
33
+ requestAnimationFrame(() => {
34
+ this.rafPending = false;
35
+ this.calcPosition();
36
+ });
37
+ }
38
+ calcPosition() {
39
+ const slider = this.el.nativeElement; // .js-slider_fix-arrows
40
+ if (!slider)
41
+ return;
42
+ // Buscamos el contenedor donde aplicar la variable
43
+ const arrowsContainer = this.closest(slider, '.js-active-slider');
44
+ if (!arrowsContainer)
45
+ return;
46
+ // Resolver "zona" según mobile/desktop
47
+ const zone = this.pickZone(slider);
48
+ if (!zone)
49
+ return;
50
+ // Necesitamos el ancestro .relative para medir relativo a él
51
+ const relative = this.closest(zone, '.relative');
52
+ if (!relative)
53
+ return;
54
+ const zoneRect = zone.getBoundingClientRect();
55
+ const relRect = relative.getBoundingClientRect();
56
+ // Distancia relativa top + mitad de la altura de la zona
57
+ const height = zoneRect.top - relRect.top + zoneRect.height / 2;
58
+ // Seteamos la CSS var
59
+ this.r2.setStyle(arrowsContainer, '--sliderNav__position', `${height}px`);
60
+ }
61
+ /** Lógica mobile/desktop como en tu código original */
62
+ pickZone(root) {
63
+ const all = root.querySelectorAll('.js-slider_fix-arrows-zone');
64
+ if (!all.length)
65
+ return null;
66
+ const w = window.innerWidth || 0;
67
+ // ¿existe .mobile y estamos <= 1279?
68
+ const mobile = root.querySelector('.js-slider_fix-arrows-zone.mobile');
69
+ if (mobile && w <= 1279)
70
+ return mobile;
71
+ // ¿existe .desktop y estamos >= 1280?
72
+ const desktop = root.querySelector('.js-slider_fix-arrows-zone.desktop');
73
+ if (desktop && w >= 1280)
74
+ return desktop;
75
+ // fallback: el primero que exista
76
+ return all[0];
77
+ }
78
+ /** closest sin jQuery, con fallback para navegadores raros */
79
+ closest(el, selector) {
80
+ if (el.closest)
81
+ return el.closest(selector);
82
+ let current = el;
83
+ while (current) {
84
+ if (this.matches(current, selector))
85
+ return current;
86
+ current = current.parentElement;
87
+ }
88
+ return null;
89
+ }
90
+ matches(el, selector) {
91
+ const p = Element.prototype;
92
+ const f = p.matches || p.msMatchesSelector || p.webkitMatchesSelector;
93
+ return f.call(el, selector);
94
+ }
95
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SliderFixArrowsDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
96
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: SliderFixArrowsDirective, isStandalone: true, selector: "[sliderFixArrows]", ngImport: i0 }); }
97
+ }
98
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SliderFixArrowsDirective, decorators: [{
99
+ type: Directive,
100
+ args: [{
101
+ selector: '[sliderFixArrows]',
102
+ standalone: true,
103
+ }]
104
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.NgZone }] });
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-fix-arrows.directive.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/directives/sliders/slider-fix-arrows.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Directive,\n    ElementRef,\n    NgZone,\n    OnDestroy,\n    Renderer2,\n} from '@angular/core';\n\n@Directive({\n    selector: '[sliderFixArrows]', // úsala en el nodo con .js-slider_fix-arrows\n    standalone: true,\n})\nexport class SliderFixArrowsDirective implements AfterViewInit, OnDestroy {\n    private rafPending = false;\n    private cleanups: Array<() => void> = [];\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private r2: Renderer2,\n        private zone: NgZone\n    ) {}\n\n    ngAfterViewInit(): void {\n        // Primer cálculo\n        this.calcPosition();\n\n        // Recalcular a los 500ms (similar a tu setTimeout)\n        setTimeout(() => this.calcPosition(), 500);\n\n        // Escuchar scroll/resize sin disparar change detection a lo loco\n        this.zone.runOutsideAngular(() => {\n            const onScroll = () => this.scheduleCalc();\n            const onResize = () => this.scheduleCalc();\n\n            window.addEventListener('scroll', onScroll, { passive: true });\n            window.addEventListener('resize', onResize, { passive: true });\n\n            this.cleanups.push(() =>\n                window.removeEventListener('scroll', onScroll)\n            );\n            this.cleanups.push(() =>\n                window.removeEventListener('resize', onResize)\n            );\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.cleanups.forEach((fn) => fn());\n    }\n\n    private scheduleCalc() {\n        if (this.rafPending) return;\n        this.rafPending = true;\n        requestAnimationFrame(() => {\n            this.rafPending = false;\n            this.calcPosition();\n        });\n    }\n\n    private calcPosition(): void {\n        const slider = this.el.nativeElement; // .js-slider_fix-arrows\n        if (!slider) return;\n\n        // Buscamos el contenedor donde aplicar la variable\n        const arrowsContainer = this.closest(\n            slider,\n            '.js-active-slider'\n        ) as HTMLElement | null;\n        if (!arrowsContainer) return;\n\n        // Resolver \"zona\" según mobile/desktop\n        const zone = this.pickZone(slider);\n        if (!zone) return;\n\n        // Necesitamos el ancestro .relative para medir relativo a él\n        const relative = this.closest(zone, '.relative') as HTMLElement | null;\n        if (!relative) return;\n\n        const zoneRect = zone.getBoundingClientRect();\n        const relRect = relative.getBoundingClientRect();\n\n        // Distancia relativa top + mitad de la altura de la zona\n        const height = zoneRect.top - relRect.top + zoneRect.height / 2;\n\n        // Seteamos la CSS var\n        this.r2.setStyle(\n            arrowsContainer,\n            '--sliderNav__position',\n            `${height}px`\n        );\n    }\n\n    /** Lógica mobile/desktop como en tu código original */\n    private pickZone(root: HTMLElement): HTMLElement | null {\n        const all = root.querySelectorAll<HTMLElement>(\n            '.js-slider_fix-arrows-zone'\n        );\n        if (!all.length) return null;\n\n        const w = window.innerWidth || 0;\n\n        // ¿existe .mobile y estamos <= 1279?\n        const mobile = root.querySelector<HTMLElement>(\n            '.js-slider_fix-arrows-zone.mobile'\n        );\n        if (mobile && w <= 1279) return mobile;\n\n        // ¿existe .desktop y estamos >= 1280?\n        const desktop = root.querySelector<HTMLElement>(\n            '.js-slider_fix-arrows-zone.desktop'\n        );\n        if (desktop && w >= 1280) return desktop;\n\n        // fallback: el primero que exista\n        return all[0];\n    }\n\n    /** closest sin jQuery, con fallback para navegadores raros */\n    private closest(el: Element, selector: string): Element | null {\n        if (el.closest) return el.closest(selector);\n        let current: Element | null = el;\n        while (current) {\n            if (this.matches(current, selector)) return current;\n            current = current.parentElement;\n        }\n        return null;\n    }\n\n    private matches(el: Element, selector: string): boolean {\n        const p = Element.prototype as any;\n        const f = p.matches || p.msMatchesSelector || p.webkitMatchesSelector;\n        return f.call(el, selector);\n    }\n}\n"]}
@@ -0,0 +1,91 @@
1
+ import { Directive, Input, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class StickyAvoidFooterDirective {
4
+ constructor(el, zone, r2) {
5
+ this.el = el;
6
+ this.zone = zone;
7
+ this.r2 = r2;
8
+ /** Selector del footer (por defecto como en tu HTML) */
9
+ this.footerSelector = '.footer__links';
10
+ /** Margen de seguridad inferior del viewport al evaluar visibilidad del footer */
11
+ this.viewportPadding = 30; // px
12
+ /** Bottom cuando el footer NO es visible */
13
+ this.defaultBottom = '3rem';
14
+ /** Ajuste fino cuando el footer SÍ es visible */
15
+ this.overlapAdjustPx = 10; // px
16
+ this.cleanupFns = [];
17
+ this.rafPending = false;
18
+ }
19
+ ngAfterViewInit() {
20
+ // Cálculo inicial
21
+ this.adjust();
22
+ // Listeners performantes fuera de Angular
23
+ this.zone.runOutsideAngular(() => {
24
+ const onScroll = () => this.scheduleAdjust();
25
+ const onResize = () => this.scheduleAdjust();
26
+ window.addEventListener('scroll', onScroll, { passive: true });
27
+ window.addEventListener('resize', onResize, { passive: true });
28
+ this.cleanupFns.push(() => window.removeEventListener('scroll', onScroll));
29
+ this.cleanupFns.push(() => window.removeEventListener('resize', onResize));
30
+ });
31
+ }
32
+ ngOnDestroy() {
33
+ this.cleanupFns.forEach((fn) => fn());
34
+ }
35
+ scheduleAdjust() {
36
+ if (this.rafPending)
37
+ return;
38
+ this.rafPending = true;
39
+ requestAnimationFrame(() => {
40
+ this.rafPending = false;
41
+ this.adjust();
42
+ });
43
+ }
44
+ adjust() {
45
+ const button = this.el.nativeElement;
46
+ const footer = document.querySelector(this.footerSelector);
47
+ if (!button)
48
+ return;
49
+ // Asegura posición controlable (por si acaso)
50
+ const pos = getComputedStyle(button).position;
51
+ if (pos === 'static') {
52
+ this.r2.setStyle(button, 'position', 'fixed'); // o 'absolute' según tu layout
53
+ this.r2.setStyle(button, 'right', getComputedStyle(button).right || '1rem');
54
+ }
55
+ if (!footer) {
56
+ this.r2.setStyle(button, 'bottom', this.defaultBottom);
57
+ return;
58
+ }
59
+ const footerRect = footer.getBoundingClientRect();
60
+ const windowHeight = window.innerHeight;
61
+ const footerHeight = footer.offsetHeight;
62
+ const isFooterFullyVisible = footerRect.top >= 0 &&
63
+ footerRect.bottom <= windowHeight - this.viewportPadding;
64
+ if (isFooterFullyVisible) {
65
+ const overlap = windowHeight - footerRect.top;
66
+ const bottomPx = overlap - footerHeight + this.overlapAdjustPx;
67
+ this.r2.setStyle(button, 'bottom', `${bottomPx}px`);
68
+ }
69
+ else {
70
+ this.r2.setStyle(button, 'bottom', this.defaultBottom);
71
+ }
72
+ }
73
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: StickyAvoidFooterDirective, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
74
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: StickyAvoidFooterDirective, isStandalone: true, selector: "[stickyAvoidFooter]", inputs: { footerSelector: "footerSelector", viewportPadding: "viewportPadding", defaultBottom: "defaultBottom", overlapAdjustPx: "overlapAdjustPx" }, ngImport: i0 }); }
75
+ }
76
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: StickyAvoidFooterDirective, decorators: [{
77
+ type: Directive,
78
+ args: [{
79
+ selector: '[stickyAvoidFooter]',
80
+ standalone: true,
81
+ }]
82
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.Renderer2 }], propDecorators: { footerSelector: [{
83
+ type: Input
84
+ }], viewportPadding: [{
85
+ type: Input
86
+ }], defaultBottom: [{
87
+ type: Input
88
+ }], overlapAdjustPx: [{
89
+ type: Input
90
+ }] } });
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sticky-avoid-footer.directive.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/directives/utils/sticky-avoid-footer.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Directive,\n    ElementRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    Renderer2,\n} from '@angular/core';\n\n@Directive({\n    selector: '[stickyAvoidFooter]', // úsala en .hero-banner__actions\n    standalone: true,\n})\nexport class StickyAvoidFooterDirective implements AfterViewInit, OnDestroy {\n    /** Selector del footer (por defecto como en tu HTML) */\n    @Input() footerSelector = '.footer__links';\n    /** Margen de seguridad inferior del viewport al evaluar visibilidad del footer */\n    @Input() viewportPadding = 30; // px\n    /** Bottom cuando el footer NO es visible */\n    @Input() defaultBottom = '3rem';\n    /** Ajuste fino cuando el footer SÍ es visible */\n    @Input() overlapAdjustPx = 10; // px\n\n    private cleanupFns: Array<() => void> = [];\n    private rafPending = false;\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private zone: NgZone,\n        private r2: Renderer2\n    ) {}\n\n    ngAfterViewInit(): void {\n        // Cálculo inicial\n        this.adjust();\n\n        // Listeners performantes fuera de Angular\n        this.zone.runOutsideAngular(() => {\n            const onScroll = () => this.scheduleAdjust();\n            const onResize = () => this.scheduleAdjust();\n            window.addEventListener('scroll', onScroll, { passive: true });\n            window.addEventListener('resize', onResize, { passive: true });\n            this.cleanupFns.push(() =>\n                window.removeEventListener('scroll', onScroll)\n            );\n            this.cleanupFns.push(() =>\n                window.removeEventListener('resize', onResize)\n            );\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.cleanupFns.forEach((fn) => fn());\n    }\n\n    private scheduleAdjust(): void {\n        if (this.rafPending) return;\n        this.rafPending = true;\n        requestAnimationFrame(() => {\n            this.rafPending = false;\n            this.adjust();\n        });\n    }\n\n    private adjust(): void {\n        const button = this.el.nativeElement;\n        const footer = document.querySelector<HTMLElement>(this.footerSelector);\n\n        if (!button) return;\n\n        // Asegura posición controlable (por si acaso)\n        const pos = getComputedStyle(button).position;\n        if (pos === 'static') {\n            this.r2.setStyle(button, 'position', 'fixed'); // o 'absolute' según tu layout\n            this.r2.setStyle(\n                button,\n                'right',\n                getComputedStyle(button).right || '1rem'\n            );\n        }\n\n        if (!footer) {\n            this.r2.setStyle(button, 'bottom', this.defaultBottom);\n            return;\n        }\n\n        const footerRect = footer.getBoundingClientRect();\n        const windowHeight = window.innerHeight;\n        const footerHeight = footer.offsetHeight;\n\n        const isFooterFullyVisible =\n            footerRect.top >= 0 &&\n            footerRect.bottom <= windowHeight - this.viewportPadding;\n\n        if (isFooterFullyVisible) {\n            const overlap = windowHeight - footerRect.top;\n            const bottomPx = overlap - footerHeight + this.overlapAdjustPx;\n            this.r2.setStyle(button, 'bottom', `${bottomPx}px`);\n        } else {\n            this.r2.setStyle(button, 'bottom', this.defaultBottom);\n        }\n    }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1hZHZhbnRhZ2VzLWl0ZW0uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFieWxvbi9zcmMvbGliL2ludGVyZmFjZXMvYmFieWxvbi1hZHZhbnRhZ2VzLWl0ZW0uaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEJhYnlsb25BZHZhbnRhZ2VJdGVtSSB7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICB0ZXh0OiBzdHJpbmc7XG4gICAgaWNvbjogc3RyaW5nO1xufVxuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1hZHZhbnRhZ2VzLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9pbnRlcmZhY2VzL2JhYnlsb24tYWR2YW50YWdlcy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhYnlsb25BZHZhbnRhZ2VJdGVtSSB9IGZyb20gXCIuL2JhYnlsb24tYWR2YW50YWdlcy1pdGVtLmludGVyZmFjZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJhYnlsb25BZHZhbnRhZ2VzSSB7XG4gICAgIHRpdGxlPzogc3RyaW5nO1xuICAgICBpdGVtcz86IEJhYnlsb25BZHZhbnRhZ2VJdGVtSVtdO1xuICAgICBzbGlkZXJDb250cm9sczogc3RyaW5nW107XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1nbG9iYWwuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFieWxvbi9zcmMvbGliL2ludGVyZmFjZXMvYmFieWxvbi1nbG9iYWwuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWJ5bG9uQWR2YW50YWdlc0kgfSBmcm9tICcuLi9jb21wb25lbnRzL2NvcmUnO1xuaW1wb3J0IHsgQmFieWxvbkltYWdlSSB9IGZyb20gJy4vYmFieWxvbi1pbWFnZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQmFieWxvbkl0ZW1JIH0gZnJvbSAnLi9iYWJ5bG9uLWl0ZW0uaW50ZXJmYWNlJztcbmltcG9ydCB7IEJhYnlsb25UZXh0SW5mb0kgfSBmcm9tICcuL2JhYnlsb24tdGV4dC1pbmZvLmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFieWxvbkdsb2JhbCB7XG4gICAgdGV4dHM/OiBCYWJ5bG9uVGV4dEluZm9JO1xuICAgIHJpZ2h0U2lkZT86IGJvb2xlYW47XG4gICAgaXRlbXM/OiBCYWJ5bG9uSXRlbUlbXTtcbiAgICBtdWx0aW1lZGlhPzoge1xuICAgICAgICBpbWFnZW5lcz86IEJhYnlsb25JbWFnZUlbXTtcbiAgICAgICAgc3RhdGljSW1hZ2VuZXM/OiBCYWJ5bG9uSW1hZ2VJW107XG4gICAgfTtcbiAgICBhZHZhbnRhZ2VzPzogQmFieWxvbkFkdmFudGFnZXNJW107XG4gICAgdGFnczoge1xuICAgICAgICB0aXRsZTogU3RyaW5nO1xuICAgIH07XG4gICAgdGV4dENvbG9yczoge1xuICAgICAgICB0aXRsZTogU3RyaW5nO1xuICAgIH07XG4gICAgc2VlTW9yZTogU3RyaW5nO1xuICAgIHNlZUxlc3M6IFN0cmluZztcbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1pbWFnZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvaW50ZXJmYWNlcy9iYWJ5bG9uLWltYWdlLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFieWxvbkJ1dHRvbkkgfSBmcm9tICcuL2JhYnlsb24tYnV0dG9uLmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFieWxvbkltYWdlSSB7XG4gICAgc3JjOiBzdHJpbmc7XG4gICAgYWx0Pzogc3RyaW5nO1xuICAgIHN1YnRpdGxlPzogc3RyaW5nO1xuICAgIHRpdGxlPzogc3RyaW5nO1xuICAgIHByZXRpdGxlPzogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIGJ1dHRvbnM/OiBCYWJ5bG9uQnV0dG9uSVtdO1xuICAgIGxpbmtzPzogQmFieWxvbkJ1dHRvbklbXTtcbiAgICB0YWc/OiBzdHJpbmc7XG59XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1pbWFnZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvaW50ZXJmYWNlcy9iYWJ5bG9uLWltYWdlLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFieWxvbkJ1dHRvbkkgfSBmcm9tICcuL2JhYnlsb24tYnV0dG9uLmludGVyZmFjZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFieWxvbkltYWdlSSB7XG4gICAgc3JjOiBzdHJpbmc7XG4gICAgYWx0Pzogc3RyaW5nO1xuICAgIHN1YnRpdGxlPzogc3RyaW5nO1xuICAgIHRpdGxlPzogc3RyaW5nO1xuICAgIHByZXRpdGxlPzogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIGJ1dHRvbnM/OiBCYWJ5bG9uQnV0dG9uSVtdO1xuICAgIGxpbmtzPzogQmFieWxvbkJ1dHRvbklbXTtcbiAgICB0YWc/OiBzdHJpbmc7XG4gICAgaW1nPzoge1xuICAgICAgc3JjPzogc3RyaW5nO1xuICAgICAgYWx0Pzogc3RyaW5nO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1pdGVtLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9pbnRlcmZhY2VzL2JhYnlsb24taXRlbS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQmFieWxvbkl0ZW1JIHtcbiAgICBsYWJlbD86IHN0cmluZztcbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcbn1cbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1tdWx0aW1lZGlhLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9pbnRlcmZhY2VzL2JhYnlsb24tbXVsdGltZWRpYS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhYnlsb25JbWFnZUkgfSBmcm9tIFwiLi9iYWJ5bG9uLWltYWdlLmludGVyZmFjZVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJhYnlsb25NdWx0aW1lZGlhSSB7XG4gICAgaW1hZ2VuZXM6IEJhYnlsb25JbWFnZUlbXTtcbiAgICBzdGF0aWNJbWFnZW5lczogQmFieWxvbkltYWdlSVtdO1xufVxuIl19