ctt-babylon 0.8.18 → 0.9.1
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.
- package/esm2022/lib/components/core/babylon-faq-v2/babylon-faq-v2.component.mjs +2 -2
- package/esm2022/lib/components/core/babylon-list-c3-img-txt/babylon-list-c3-img-txt.component.mjs +12 -5
- package/esm2022/lib/components/core/babylon-slider-img-static/babylon-slider-img-static.component.mjs +12 -0
- package/esm2022/lib/components/core/babylon-slider-img-static/index.mjs +2 -0
- package/esm2022/lib/components/core/babylon-slider-img-static-v2/babylon-slider-img-static-v2.component.mjs +3 -3
- package/esm2022/lib/components/core/babylon-top-simple-banner/babylon-top-simple-banner.component.mjs +20 -0
- package/esm2022/lib/components/core/babylon-top-simple-banner/index.mjs +2 -0
- package/esm2022/lib/components/core/index.mjs +8 -7
- package/esm2022/lib/directives/babylon-sliders/babylon-swiper-slider.directive.mjs +2 -2
- package/esm2022/lib/directives/scrolls/scroll-to.directive.mjs +183 -0
- package/esm2022/lib/directives/scrolls/show-only-top.directive.mjs +103 -0
- package/esm2022/lib/directives/sliders/slick-init.directive.mjs +18 -11
- package/esm2022/lib/interfaces/babylon-item.interface.mjs +1 -1
- package/esm2022/lib/interfaces/babylon-text-info.interface.mjs +1 -1
- package/esm2022/lib/services/mapper/mapper.service.mjs +18 -11
- package/esm2022/lib/services/scroll/scroll-spy.service.mjs +50 -0
- package/fesm2022/ctt-babylon.mjs +955 -586
- package/fesm2022/ctt-babylon.mjs.map +1 -1
- package/lib/components/core/babylon-list-c3-img-txt/babylon-list-c3-img-txt.component.d.ts +5 -1
- package/lib/components/core/babylon-slider-img-static/babylon-slider-img-static.component.d.ts +5 -0
- package/lib/components/core/babylon-slider-img-static/index.d.ts +1 -0
- package/lib/components/core/babylon-top-simple-banner/babylon-top-simple-banner.component.d.ts +6 -0
- package/lib/components/core/babylon-top-simple-banner/index.d.ts +1 -0
- package/lib/components/core/index.d.ts +7 -6
- package/lib/directives/scrolls/scroll-to.directive.d.ts +31 -0
- package/lib/directives/scrolls/show-only-top.directive.d.ts +22 -0
- package/lib/interfaces/babylon-item.interface.d.ts +6 -0
- package/lib/interfaces/babylon-text-info.interface.d.ts +2 -0
- package/lib/services/mapper/mapper.service.d.ts +2 -1
- package/lib/services/scroll/scroll-spy.service.d.ts +17 -0
- package/lib/styles/styles/babylon/common.css +1 -1
- package/lib/styles/styles/babylon/common.scss +7 -0
- package/lib/styles/styles/babylon/globals.css +1 -1
- package/lib/styles/styles/babylon/globals.scss +299 -18
- package/package.json +1 -1
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
// directives/show-only-at-top.directive.ts
|
|
2
|
+
import { Directive, HostBinding, Input, } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ShowOnlyAtTopDirective {
|
|
5
|
+
get cls() {
|
|
6
|
+
return this.hidden;
|
|
7
|
+
}
|
|
8
|
+
get op() {
|
|
9
|
+
return this.hidden ? '0' : '1';
|
|
10
|
+
}
|
|
11
|
+
get pe() {
|
|
12
|
+
return this.hidden ? 'none' : 'auto';
|
|
13
|
+
}
|
|
14
|
+
constructor(zone) {
|
|
15
|
+
this.zone = zone;
|
|
16
|
+
/** Rango en px desde el top en el que el botón permanece visible */
|
|
17
|
+
this.topShowPx = 10; // ajusta a 4–16 si quieres más/menos sensible
|
|
18
|
+
this.minWidth = 540;
|
|
19
|
+
this.hidden = false;
|
|
20
|
+
this.active = false;
|
|
21
|
+
this.ticking = false;
|
|
22
|
+
this.t = 'opacity .25s ease, transform .25s ease';
|
|
23
|
+
}
|
|
24
|
+
ngAfterViewInit() {
|
|
25
|
+
const evaluateScroll = () => {
|
|
26
|
+
const y = Math.max(window.scrollY, document.documentElement.scrollTop || 0);
|
|
27
|
+
const shouldHide = this.active && y > this.topShowPx;
|
|
28
|
+
if (shouldHide !== this.hidden)
|
|
29
|
+
this.hidden = shouldHide;
|
|
30
|
+
};
|
|
31
|
+
const applyActiveState = () => {
|
|
32
|
+
const nowActive = window.innerWidth >= this.minWidth;
|
|
33
|
+
if (nowActive === this.active)
|
|
34
|
+
return;
|
|
35
|
+
this.active = nowActive;
|
|
36
|
+
if (!this.active) {
|
|
37
|
+
// Desactivado en < minWidth: muestra siempre y no escucha scroll
|
|
38
|
+
this.hidden = false;
|
|
39
|
+
window.removeEventListener('scroll', onScroll);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
// Re-activar
|
|
43
|
+
window.addEventListener('scroll', onScroll, { passive: true });
|
|
44
|
+
evaluateScroll();
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
const onScroll = () => {
|
|
48
|
+
if (this.ticking)
|
|
49
|
+
return;
|
|
50
|
+
this.ticking = true;
|
|
51
|
+
requestAnimationFrame(() => {
|
|
52
|
+
evaluateScroll();
|
|
53
|
+
this.ticking = false;
|
|
54
|
+
});
|
|
55
|
+
};
|
|
56
|
+
const onResize = () => {
|
|
57
|
+
applyActiveState();
|
|
58
|
+
if (this.active)
|
|
59
|
+
onScroll();
|
|
60
|
+
};
|
|
61
|
+
this.zone.runOutsideAngular(() => {
|
|
62
|
+
// Setup inicial
|
|
63
|
+
applyActiveState();
|
|
64
|
+
if (this.active) {
|
|
65
|
+
window.addEventListener('scroll', onScroll, { passive: true });
|
|
66
|
+
evaluateScroll();
|
|
67
|
+
}
|
|
68
|
+
window.addEventListener('resize', onResize, { passive: true });
|
|
69
|
+
this.offScroll = () => window.removeEventListener('scroll', onScroll);
|
|
70
|
+
this.offResize = () => window.removeEventListener('resize', onResize);
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
ngOnDestroy() {
|
|
74
|
+
this.offScroll?.();
|
|
75
|
+
this.offResize?.();
|
|
76
|
+
}
|
|
77
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ShowOnlyAtTopDirective, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
78
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: ShowOnlyAtTopDirective, isStandalone: true, selector: "[showOnlyAtTop]", inputs: { topShowPx: "topShowPx", minWidth: "minWidth" }, host: { properties: { "style.transition": "this.t", "class.is-hidden": "this.cls", "style.opacity": "this.op", "style.pointerEvents": "this.pe" } }, ngImport: i0 }); }
|
|
79
|
+
}
|
|
80
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ShowOnlyAtTopDirective, decorators: [{
|
|
81
|
+
type: Directive,
|
|
82
|
+
args: [{
|
|
83
|
+
selector: '[showOnlyAtTop]',
|
|
84
|
+
standalone: true,
|
|
85
|
+
}]
|
|
86
|
+
}], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { topShowPx: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], minWidth: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], t: [{
|
|
91
|
+
type: HostBinding,
|
|
92
|
+
args: ['style.transition']
|
|
93
|
+
}], cls: [{
|
|
94
|
+
type: HostBinding,
|
|
95
|
+
args: ['class.is-hidden']
|
|
96
|
+
}], op: [{
|
|
97
|
+
type: HostBinding,
|
|
98
|
+
args: ['style.opacity']
|
|
99
|
+
}], pe: [{
|
|
100
|
+
type: HostBinding,
|
|
101
|
+
args: ['style.pointerEvents']
|
|
102
|
+
}] } });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hvdy1vbmx5LXRvcC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvZGlyZWN0aXZlcy9zY3JvbGxzL3Nob3ctb25seS10b3AuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDJDQUEyQztBQUMzQyxPQUFPLEVBRUgsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEdBR1IsTUFBTSxlQUFlLENBQUM7O0FBTXZCLE1BQU0sT0FBTyxzQkFBc0I7SUFZL0IsSUFBb0MsR0FBRztRQUNuQyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUNELElBQWtDLEVBQUU7UUFDaEMsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztJQUNuQyxDQUFDO0lBQ0QsSUFBd0MsRUFBRTtRQUN0QyxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQ3pDLENBQUM7SUFFRCxZQUFvQixJQUFZO1FBQVosU0FBSSxHQUFKLElBQUksQ0FBUTtRQXJCaEMsb0VBQW9FO1FBQzNELGNBQVMsR0FBRyxFQUFFLENBQUMsQ0FBQyw4Q0FBOEM7UUFDOUQsYUFBUSxHQUFHLEdBQUcsQ0FBQztRQUNoQixXQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ2YsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUdmLFlBQU8sR0FBRyxLQUFLLENBQUM7UUFFUyxNQUFDLEdBQzlCLHdDQUF3QyxDQUFDO0lBV1YsQ0FBQztJQUVwQyxlQUFlO1FBQ1gsTUFBTSxjQUFjLEdBQUcsR0FBRyxFQUFFO1lBQ3hCLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQ2QsTUFBTSxDQUFDLE9BQU8sRUFDZCxRQUFRLENBQUMsZUFBZSxDQUFDLFNBQVMsSUFBSSxDQUFDLENBQzFDLENBQUM7WUFDRixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ3JELElBQUksVUFBVSxLQUFLLElBQUksQ0FBQyxNQUFNO2dCQUFFLElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxDQUFDO1FBQzdELENBQUMsQ0FBQztRQUVGLE1BQU0sZ0JBQWdCLEdBQUcsR0FBRyxFQUFFO1lBQzFCLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFFBQVEsQ0FBQztZQUNyRCxJQUFJLFNBQVMsS0FBSyxJQUFJLENBQUMsTUFBTTtnQkFBRSxPQUFPO1lBQ3RDLElBQUksQ0FBQyxNQUFNLEdBQUcsU0FBUyxDQUFDO1lBQ3hCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO2dCQUNkLGlFQUFpRTtnQkFDakUsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7Z0JBQ3BCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxRQUFRLEVBQUUsUUFBUSxDQUFDLENBQUM7YUFDbEQ7aUJBQU07Z0JBQ0gsYUFBYTtnQkFDYixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO2dCQUMvRCxjQUFjLEVBQUUsQ0FBQzthQUNwQjtRQUNMLENBQUMsQ0FBQztRQUVGLE1BQU0sUUFBUSxHQUFHLEdBQUcsRUFBRTtZQUNsQixJQUFJLElBQUksQ0FBQyxPQUFPO2dCQUFFLE9BQU87WUFDekIsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUM7WUFDcEIscUJBQXFCLENBQUMsR0FBRyxFQUFFO2dCQUN2QixjQUFjLEVBQUUsQ0FBQztnQkFDakIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7WUFDekIsQ0FBQyxDQUFDLENBQUM7UUFDUCxDQUFDLENBQUM7UUFFRixNQUFNLFFBQVEsR0FBRyxHQUFHLEVBQUU7WUFDbEIsZ0JBQWdCLEVBQUUsQ0FBQztZQUNuQixJQUFJLElBQUksQ0FBQyxNQUFNO2dCQUFFLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLENBQUMsQ0FBQztRQUVGLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFO1lBQzdCLGdCQUFnQjtZQUNoQixnQkFBZ0IsRUFBRSxDQUFDO1lBQ25CLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtnQkFDYixNQUFNLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxFQUFFLFFBQVEsRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO2dCQUMvRCxjQUFjLEVBQUUsQ0FBQzthQUNwQjtZQUNELE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUM7WUFDL0QsSUFBSSxDQUFDLFNBQVMsR0FBRyxHQUFHLEVBQUUsQ0FDbEIsTUFBTSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUNuRCxJQUFJLENBQUMsU0FBUyxHQUFHLEdBQUcsRUFBRSxDQUNsQixNQUFNLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLFFBQVEsQ0FBQyxDQUFDO1FBQ3ZELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsU0FBUyxFQUFFLEVBQUUsQ0FBQztJQUN2QixDQUFDOytHQWpGUSxzQkFBc0I7bUdBQXRCLHNCQUFzQjs7NEZBQXRCLHNCQUFzQjtrQkFKbEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUJBQWlCO29CQUMzQixVQUFVLEVBQUUsSUFBSTtpQkFDbkI7MkVBR1ksU0FBUztzQkFBakIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQU8yQixDQUFDO3NCQUFqQyxXQUFXO3VCQUFDLGtCQUFrQjtnQkFFSyxHQUFHO3NCQUF0QyxXQUFXO3VCQUFDLGlCQUFpQjtnQkFHSSxFQUFFO3NCQUFuQyxXQUFXO3VCQUFDLGVBQWU7Z0JBR1ksRUFBRTtzQkFBekMsV0FBVzt1QkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBkaXJlY3RpdmVzL3Nob3ctb25seS1hdC10b3AuZGlyZWN0aXZlLnRzXG5pbXBvcnQge1xuICAgIEFmdGVyVmlld0luaXQsXG4gICAgRGlyZWN0aXZlLFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIElucHV0LFxuICAgIE5nWm9uZSxcbiAgICBPbkRlc3Ryb3ksXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tzaG93T25seUF0VG9wXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgU2hvd09ubHlBdFRvcERpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gICAgLyoqIFJhbmdvIGVuIHB4IGRlc2RlIGVsIHRvcCBlbiBlbCBxdWUgZWwgYm90w7NuIHBlcm1hbmVjZSB2aXNpYmxlICovXG4gICAgQElucHV0KCkgdG9wU2hvd1B4ID0gMTA7IC8vIGFqdXN0YSBhIDTigJMxNiBzaSBxdWllcmVzIG3DoXMvbWVub3Mgc2Vuc2libGVcbiAgICBASW5wdXQoKSBtaW5XaWR0aCA9IDU0MDtcbiAgICBwcml2YXRlIGhpZGRlbiA9IGZhbHNlO1xuICAgIHByaXZhdGUgYWN0aXZlID0gZmFsc2U7XG4gICAgcHJpdmF0ZSBvZmZTY3JvbGw/OiAoKSA9PiB2b2lkO1xuICAgIHByaXZhdGUgb2ZmUmVzaXplPzogKCkgPT4gdm9pZDtcbiAgICBwcml2YXRlIHRpY2tpbmcgPSBmYWxzZTtcblxuICAgIEBIb3N0QmluZGluZygnc3R5bGUudHJhbnNpdGlvbicpIHQgPVxuICAgICAgICAnb3BhY2l0eSAuMjVzIGVhc2UsIHRyYW5zZm9ybSAuMjVzIGVhc2UnO1xuICAgIEBIb3N0QmluZGluZygnY2xhc3MuaXMtaGlkZGVuJykgZ2V0IGNscygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaGlkZGVuO1xuICAgIH1cbiAgICBASG9zdEJpbmRpbmcoJ3N0eWxlLm9wYWNpdHknKSBnZXQgb3AoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmhpZGRlbiA/ICcwJyA6ICcxJztcbiAgICB9XG4gICAgQEhvc3RCaW5kaW5nKCdzdHlsZS5wb2ludGVyRXZlbnRzJykgZ2V0IHBlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5oaWRkZW4gPyAnbm9uZScgOiAnYXV0byc7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSB6b25lOiBOZ1pvbmUpIHt9XG5cbiAgICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgICAgIGNvbnN0IGV2YWx1YXRlU2Nyb2xsID0gKCkgPT4ge1xuICAgICAgICAgICAgY29uc3QgeSA9IE1hdGgubWF4KFxuICAgICAgICAgICAgICAgIHdpbmRvdy5zY3JvbGxZLFxuICAgICAgICAgICAgICAgIGRvY3VtZW50LmRvY3VtZW50RWxlbWVudC5zY3JvbGxUb3AgfHwgMFxuICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIGNvbnN0IHNob3VsZEhpZGUgPSB0aGlzLmFjdGl2ZSAmJiB5ID4gdGhpcy50b3BTaG93UHg7XG4gICAgICAgICAgICBpZiAoc2hvdWxkSGlkZSAhPT0gdGhpcy5oaWRkZW4pIHRoaXMuaGlkZGVuID0gc2hvdWxkSGlkZTtcbiAgICAgICAgfTtcblxuICAgICAgICBjb25zdCBhcHBseUFjdGl2ZVN0YXRlID0gKCkgPT4ge1xuICAgICAgICAgICAgY29uc3Qgbm93QWN0aXZlID0gd2luZG93LmlubmVyV2lkdGggPj0gdGhpcy5taW5XaWR0aDtcbiAgICAgICAgICAgIGlmIChub3dBY3RpdmUgPT09IHRoaXMuYWN0aXZlKSByZXR1cm47XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZSA9IG5vd0FjdGl2ZTtcbiAgICAgICAgICAgIGlmICghdGhpcy5hY3RpdmUpIHtcbiAgICAgICAgICAgICAgICAvLyBEZXNhY3RpdmFkbyBlbiA8IG1pbldpZHRoOiBtdWVzdHJhIHNpZW1wcmUgeSBubyBlc2N1Y2hhIHNjcm9sbFxuICAgICAgICAgICAgICAgIHRoaXMuaGlkZGVuID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ3Njcm9sbCcsIG9uU2Nyb2xsKTtcbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgLy8gUmUtYWN0aXZhclxuICAgICAgICAgICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLCBvblNjcm9sbCwgeyBwYXNzaXZlOiB0cnVlIH0pO1xuICAgICAgICAgICAgICAgIGV2YWx1YXRlU2Nyb2xsKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG5cbiAgICAgICAgY29uc3Qgb25TY3JvbGwgPSAoKSA9PiB7XG4gICAgICAgICAgICBpZiAodGhpcy50aWNraW5nKSByZXR1cm47XG4gICAgICAgICAgICB0aGlzLnRpY2tpbmcgPSB0cnVlO1xuICAgICAgICAgICAgcmVxdWVzdEFuaW1hdGlvbkZyYW1lKCgpID0+IHtcbiAgICAgICAgICAgICAgICBldmFsdWF0ZVNjcm9sbCgpO1xuICAgICAgICAgICAgICAgIHRoaXMudGlja2luZyA9IGZhbHNlO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH07XG5cbiAgICAgICAgY29uc3Qgb25SZXNpemUgPSAoKSA9PiB7XG4gICAgICAgICAgICBhcHBseUFjdGl2ZVN0YXRlKCk7XG4gICAgICAgICAgICBpZiAodGhpcy5hY3RpdmUpIG9uU2Nyb2xsKCk7XG4gICAgICAgIH07XG5cbiAgICAgICAgdGhpcy56b25lLnJ1bk91dHNpZGVBbmd1bGFyKCgpID0+IHtcbiAgICAgICAgICAgIC8vIFNldHVwIGluaWNpYWxcbiAgICAgICAgICAgIGFwcGx5QWN0aXZlU3RhdGUoKTtcbiAgICAgICAgICAgIGlmICh0aGlzLmFjdGl2ZSkge1xuICAgICAgICAgICAgICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdzY3JvbGwnLCBvblNjcm9sbCwgeyBwYXNzaXZlOiB0cnVlIH0pO1xuICAgICAgICAgICAgICAgIGV2YWx1YXRlU2Nyb2xsKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB3aW5kb3cuYWRkRXZlbnRMaXN0ZW5lcigncmVzaXplJywgb25SZXNpemUsIHsgcGFzc2l2ZTogdHJ1ZSB9KTtcbiAgICAgICAgICAgIHRoaXMub2ZmU2Nyb2xsID0gKCkgPT5cbiAgICAgICAgICAgICAgICB3aW5kb3cucmVtb3ZlRXZlbnRMaXN0ZW5lcignc2Nyb2xsJywgb25TY3JvbGwpO1xuICAgICAgICAgICAgdGhpcy5vZmZSZXNpemUgPSAoKSA9PlxuICAgICAgICAgICAgICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdyZXNpemUnLCBvblJlc2l6ZSk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLm9mZlNjcm9sbD8uKCk7XG4gICAgICAgIHRoaXMub2ZmUmVzaXplPy4oKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -9,7 +9,13 @@ export class SlickInitDirective {
|
|
|
9
9
|
async ngAfterViewInit() {
|
|
10
10
|
if (!isPlatformBrowser(this.platformId))
|
|
11
11
|
return;
|
|
12
|
-
|
|
12
|
+
// 1) Espera a que jquery + slick estén listos
|
|
13
|
+
const slickReady = await this.waitForSlick();
|
|
14
|
+
// 2) Si NO están, no sigas (evita $ undefined)
|
|
15
|
+
if (!slickReady || typeof $ === 'undefined' || !$.fn || !$.fn.slick) {
|
|
16
|
+
console.warn('[SlickInitDirective] jQuery/Slick no están disponibles, no inicializo el slider');
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
13
19
|
const parent = this.host.nativeElement;
|
|
14
20
|
const get = (name) => parent.getAttribute(name);
|
|
15
21
|
const getBool = (name) => {
|
|
@@ -73,7 +79,6 @@ export class SlickInitDirective {
|
|
|
73
79
|
nextArrow +=
|
|
74
80
|
"<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
81
|
}
|
|
76
|
-
// --- normalizar altura en vertical (sin 'this' implícito) ---
|
|
77
82
|
const updateVerticalHeight = () => {
|
|
78
83
|
const $el = $(sliderSelector);
|
|
79
84
|
if (window.innerWidth >= 541) {
|
|
@@ -99,7 +104,6 @@ export class SlickInitDirective {
|
|
|
99
104
|
passive: true,
|
|
100
105
|
});
|
|
101
106
|
}
|
|
102
|
-
// --- INIT SLICK ---
|
|
103
107
|
$(sliderSelector).slick({
|
|
104
108
|
dots: showDots,
|
|
105
109
|
arrows: showBtns,
|
|
@@ -165,6 +169,8 @@ export class SlickInitDirective {
|
|
|
165
169
|
ngOnDestroy() {
|
|
166
170
|
if (!isPlatformBrowser(this.platformId))
|
|
167
171
|
return;
|
|
172
|
+
if (typeof $ === 'undefined' || !$.fn?.slick)
|
|
173
|
+
return;
|
|
168
174
|
if (this.sliderEl && $(this.sliderEl).hasClass('slick-initialized')) {
|
|
169
175
|
try {
|
|
170
176
|
$(this.sliderEl).slick('unslick');
|
|
@@ -177,18 +183,19 @@ export class SlickInitDirective {
|
|
|
177
183
|
window.removeEventListener('resize', this.resizeHandler);
|
|
178
184
|
}
|
|
179
185
|
}
|
|
180
|
-
//
|
|
181
|
-
waitForSlick(timeoutMs =
|
|
186
|
+
// Devuelve true si jQuery+Slick llegan a estar disponibles, false si no
|
|
187
|
+
waitForSlick(timeoutMs = 8000, stepMs = 100) {
|
|
182
188
|
if (!isPlatformBrowser(this.platformId))
|
|
183
|
-
return Promise.resolve();
|
|
189
|
+
return Promise.resolve(false);
|
|
184
190
|
const start = performance.now();
|
|
185
191
|
return new Promise((resolve) => {
|
|
186
192
|
const check = () => {
|
|
187
|
-
if (typeof $ !== 'undefined' && $.fn && $.fn.slick)
|
|
188
|
-
return resolve();
|
|
193
|
+
if (typeof $ !== 'undefined' && $.fn && $.fn.slick) {
|
|
194
|
+
return resolve(true);
|
|
195
|
+
}
|
|
189
196
|
if (performance.now() - start > timeoutMs) {
|
|
190
|
-
console.warn('[SlickInitDirective] Slick no disponible. ¿
|
|
191
|
-
return resolve();
|
|
197
|
+
console.warn('[SlickInitDirective] Slick no disponible tras timeout. ¿Scripts cargados?');
|
|
198
|
+
return resolve(false);
|
|
192
199
|
}
|
|
193
200
|
setTimeout(check, stepMs);
|
|
194
201
|
};
|
|
@@ -208,4 +215,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
208
215
|
type: Inject,
|
|
209
216
|
args: [PLATFORM_ID]
|
|
210
217
|
}] }] });
|
|
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"]}
|
|
218
|
+
//# 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// sigue igual, sólo para TS\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\n        // 1) Espera a que jquery + slick estén listos\n        const slickReady = await this.waitForSlick();\n\n        // 2) Si NO están, no sigas (evita $ undefined)\n        if (!slickReady || typeof $ === 'undefined' || !$.fn || !$.fn.slick) {\n            console.warn(\n                '[SlickInitDirective] jQuery/Slick no están disponibles, no inicializo el slider'\n            );\n            return;\n        }\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        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        $(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 (typeof $ === 'undefined' || !$.fn?.slick) return;\n\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    // Devuelve true si jQuery+Slick llegan a estar disponibles, false si no\n    private waitForSlick(timeoutMs = 8000, stepMs = 100): Promise<boolean> {\n        if (!isPlatformBrowser(this.platformId)) return Promise.resolve(false);\n        const start = performance.now();\n\n        return new Promise<boolean>((resolve) => {\n            const check = () => {\n                if (typeof $ !== 'undefined' && $.fn && $.fn.slick) {\n                    return resolve(true);\n                }\n                if (performance.now() - start > timeoutMs) {\n                    console.warn(\n                        '[SlickInitDirective] Slick no disponible tras timeout. ¿Scripts cargados?'\n                    );\n                    return resolve(false);\n                }\n                setTimeout(check, stepMs);\n            };\n            check();\n        });\n    }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1pdGVtLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhYnlsb24vc3JjL2xpYi9pbnRlcmZhY2VzL2JhYnlsb24taXRlbS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJhYnlsb25CdXR0b25JIH0gZnJvbSAnLi9iYWJ5bG9uLWJ1dHRvbi5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQmFieWxvbkltYWdlSSB9IGZyb20gJy4vYmFieWxvbi1pbWFnZS5pbnRlcmZhY2UnO1xuaW1wb3J0IHsgQmFieWxvblRleHRJbmZvSSB9IGZyb20gJy4vYmFieWxvbi10ZXh0LWluZm8uaW50ZXJmYWNlJztcblxuZXhwb3J0IGludGVyZmFjZSBCYWJ5bG9uSXRlbUkge1xuICAgIGxhYmVsPzogc3RyaW5nO1xuICAgIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAgIGJ1dHRvbnM/OiBCYWJ5bG9uQnV0dG9uSVtdO1xuICAgIG11bHRpbWVkaWE/OiBCYWJ5bG9uSW1hZ2VJW107XG4gICAgdGV4dHM/OiBCYWJ5bG9uVGV4dEluZm9JO1xufVxuIl19
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi10ZXh0LWluZm8uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFieWxvbi9zcmMvbGliL2ludGVyZmFjZXMvYmFieWxvbi10ZXh0LWluZm8uaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYWJ5bG9uRHluYW1pY0hlYWRpbmdJIH0gZnJvbSAnLi4vY29tcG9uZW50cy9zaGFyZWQnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJhYnlsb25UZXh0SW5mb0kge1xuICAgIHByZXRpdGxlPzogc3RyaW5nO1xuICAgIHRpdGxlPzogc3RyaW5nO1xuICAgIHRpdGxlMj86IHN0cmluZztcbiAgICBzdWJ0aXRsZT86IHN0cmluZztcbiAgICB0ZXh0Pzogc3RyaW5nO1xuICAgIGl0ZW0xPzogc3RyaW5nO1xuICAgIGl0ZW0xVGV4dD86IHN0cmluZztcbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZztcbiAgICBhZGRpdGlvbmFsMT86IHN0cmluZztcbiAgICBhZGRpdGlvbmFsMj86IHN0cmluZztcbiAgICBhZGRpdGlvbmFsMz86IHN0cmluZztcbiAgICBjb25kaXRpb25zPzogc3RyaW5nO1xuICAgIHVybD86IHN0cmluZztcbiAgICBwcmV0aXRsZUNvbnRhaW4/OiBCYWJ5bG9uRHluYW1pY0hlYWRpbmdJO1xuICAgIHRpdGxlQ29udGFpbj86IEJhYnlsb25EeW5hbWljSGVhZGluZ0k7XG4gICAgc3ZnPzogc3RyaW5nO1xufVxuIl19
|