ctt-puro 0.45.7 → 0.45.8

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.
@@ -18,7 +18,6 @@ export class PuroNavStickyDirective {
18
18
  return;
19
19
  this.banner = document.querySelector('.banner');
20
20
  this.isInitialized = true;
21
- // Recalcular al finalizar cada navegación
22
21
  this.sub = this.router.events
23
22
  .pipe(filter((e) => e instanceof NavigationEnd))
24
23
  .subscribe(() => this.updateStickyState());
@@ -38,7 +37,7 @@ export class PuroNavStickyDirective {
38
37
  isMobile() {
39
38
  if (!isPlatformBrowser(this.platformId))
40
39
  return false;
41
- return window.matchMedia('(max-width: 1280px)').matches; // ajusta a tu "md"
40
+ return window.matchMedia('(max-width: 1280px)').matches;
42
41
  }
43
42
  updateStickyState() {
44
43
  if (!isPlatformBrowser(this.platformId) || !this.isInitialized)
@@ -47,34 +46,52 @@ export class PuroNavStickyDirective {
47
46
  document.documentElement.scrollTop ||
48
47
  document.body.scrollTop ||
49
48
  0;
49
+ const header = document.querySelector('header.header');
50
+ /**
51
+ * 🔵 DETECCIÓN NUEVA:
52
+ * Header tocando el borde superior del viewport
53
+ */
54
+ if (header && header.getBoundingClientRect().top <= 0) {
55
+ document.body.classList.add('nav-sticky--top');
56
+ }
57
+ else {
58
+ document.body.classList.remove('nav-sticky--top');
59
+ }
60
+ /**
61
+ * 🔵 MODO DINÁMICO (HOTELS)
62
+ */
50
63
  if (this.isDynamic) {
51
- // 🔹 Modo dinámico: en función del scroll
52
64
  if (y > this.mobileHeader) {
53
65
  document.body.classList.add('nav-sticky', 'mobile-sticky');
54
66
  }
55
67
  else {
56
68
  document.body.classList.remove('nav-sticky', 'mobile-sticky');
57
69
  }
70
+ return;
58
71
  }
59
- else {
60
- if (this.banner) {
61
- // 🔹 Desktop con banner: sticky al superar el banner
62
- const bannerHeight = this.getOuterHeight(this.banner);
63
- if (y >= bannerHeight) {
64
- document.body.classList.add('nav-sticky');
65
- }
66
- else {
67
- document.body.classList.remove('nav-sticky');
68
- }
69
- document.body.classList.remove('mobile-sticky');
72
+ /**
73
+ * 🔵 Desktop con banner
74
+ */
75
+ if (this.banner) {
76
+ const bannerHeight = this.getOuterHeight(this.banner);
77
+ if (y >= bannerHeight) {
78
+ document.body.classList.add('nav-sticky');
70
79
  }
71
- // 🔹 Desktop sin banner: siempre nav-sticky
72
- document.body.classList.add('nav-sticky');
73
- document.body.classList.remove('mobile-sticky');
74
- // 🔹 Mobile sin banner: siempre mobile-sticky
75
- if (this.isMobile()) {
76
- document.body.classList.add('nav-sticky', 'mobile-sticky');
80
+ else {
81
+ document.body.classList.remove('nav-sticky');
77
82
  }
83
+ document.body.classList.remove('mobile-sticky');
84
+ }
85
+ /**
86
+ * 🔵 Desktop sin banner
87
+ */
88
+ document.body.classList.add('nav-sticky');
89
+ document.body.classList.remove('mobile-sticky');
90
+ /**
91
+ * 🔵 Mobile sin banner
92
+ */
93
+ if (this.isMobile()) {
94
+ document.body.classList.add('nav-sticky', 'mobile-sticky');
78
95
  }
79
96
  }
80
97
  getOuterHeight(element) {
@@ -103,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
103
120
  type: HostListener,
104
121
  args: ['window:resize']
105
122
  }] } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-nav-sticky.directive.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/directives/puro-nav-sticky/puro-nav-sticky.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    Directive,\n    HostListener,\n    Inject,\n    Input,\n    OnChanges,\n    PLATFORM_ID,\n    SimpleChanges,\n} from '@angular/core';\nimport { Router, NavigationEnd } from '@angular/router';\nimport { filter, Subscription } from 'rxjs';\n\n@Directive({\n    selector: '[navSticky]',\n    standalone: true,\n})\nexport class PuroNavStickyDirective implements AfterViewInit, OnChanges {\n    @Input() isDynamic: boolean = false;\n\n    private banner: HTMLElement | null = null;\n    private mobileHeader = 1;\n    private isInitialized = false;\n    private sub?: Subscription;\n\n    constructor(\n        @Inject(PLATFORM_ID) private platformId: Object,\n        private router: Router\n    ) {}\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platformId)) return;\n\n        this.banner = document.querySelector('.banner');\n        this.isInitialized = true;\n\n        // Recalcular al finalizar cada navegación\n        this.sub = this.router.events\n            .pipe(filter((e): e is NavigationEnd => e instanceof NavigationEnd))\n            .subscribe(() => this.updateStickyState());\n\n        this.updateStickyState();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (this.isInitialized && 'isDynamic' in changes) {\n            this.updateStickyState();\n        }\n    }\n\n    @HostListener('window:scroll')\n    onWindowScroll() {\n        this.updateStickyState();\n    }\n\n    @HostListener('window:resize')\n    onResize() {\n        this.updateStickyState();\n    }\n\n    private isMobile(): boolean {\n        if (!isPlatformBrowser(this.platformId)) return false;\n        return window.matchMedia('(max-width: 1280px)').matches; // ajusta a tu \"md\"\n    }\n\n    private updateStickyState() {\n        if (!isPlatformBrowser(this.platformId) || !this.isInitialized) return;\n\n        const y =\n            window.pageYOffset ||\n            document.documentElement.scrollTop ||\n            document.body.scrollTop ||\n            0;\n\n        if (this.isDynamic) {\n            // 🔹 Modo dinámico: en función del scroll\n            if (y > this.mobileHeader) {\n                document.body.classList.add('nav-sticky', 'mobile-sticky');\n            } else {\n                document.body.classList.remove('nav-sticky', 'mobile-sticky');\n            }\n        } else {\n            if (this.banner) {\n                // 🔹 Desktop con banner: sticky al superar el banner\n                const bannerHeight = this.getOuterHeight(this.banner);\n                if (y >= bannerHeight) {\n                    document.body.classList.add('nav-sticky');\n                } else {\n                    document.body.classList.remove('nav-sticky');\n                }\n                document.body.classList.remove('mobile-sticky');\n            }\n\n            // 🔹 Desktop sin banner: siempre nav-sticky\n            document.body.classList.add('nav-sticky');\n            document.body.classList.remove('mobile-sticky');\n\n            // 🔹 Mobile sin banner: siempre mobile-sticky\n            if (this.isMobile()) {\n                document.body.classList.add('nav-sticky', 'mobile-sticky');\n            }\n        }\n    }\n\n    private getOuterHeight(element: HTMLElement): number {\n        const height = element.offsetHeight;\n        const style = window.getComputedStyle(element);\n        return (\n            height + parseInt(style.marginTop) + parseInt(style.marginBottom)\n        );\n    }\n}\n"]}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"puro-nav-sticky.directive.js","sourceRoot":"","sources":["../../../../../../projects/puro/src/lib/directives/puro-nav-sticky/puro-nav-sticky.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    Directive,\n    HostListener,\n    Inject,\n    Input,\n    OnChanges,\n    PLATFORM_ID,\n    SimpleChanges,\n} from '@angular/core';\nimport { Router, NavigationEnd } from '@angular/router';\nimport { filter, Subscription } from 'rxjs';\n\n@Directive({\n    selector: '[navSticky]',\n    standalone: true,\n})\nexport class PuroNavStickyDirective implements AfterViewInit, OnChanges {\n    @Input() isDynamic: boolean = false;\n\n    private banner: HTMLElement | null = null;\n    private mobileHeader = 1;\n    private isInitialized = false;\n    private sub?: Subscription;\n\n    constructor(\n        @Inject(PLATFORM_ID) private platformId: Object,\n        private router: Router\n    ) {}\n\n    ngAfterViewInit() {\n        if (!isPlatformBrowser(this.platformId)) return;\n\n        this.banner = document.querySelector('.banner');\n        this.isInitialized = true;\n\n        this.sub = this.router.events\n            .pipe(filter((e): e is NavigationEnd => e instanceof NavigationEnd))\n            .subscribe(() => this.updateStickyState());\n\n        this.updateStickyState();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (this.isInitialized && 'isDynamic' in changes) {\n            this.updateStickyState();\n        }\n    }\n\n    @HostListener('window:scroll')\n    onWindowScroll() {\n        this.updateStickyState();\n    }\n\n    @HostListener('window:resize')\n    onResize() {\n        this.updateStickyState();\n    }\n\n    private isMobile(): boolean {\n        if (!isPlatformBrowser(this.platformId)) return false;\n        return window.matchMedia('(max-width: 1280px)').matches;\n    }\n\n    private updateStickyState() {\n        if (!isPlatformBrowser(this.platformId) || !this.isInitialized) return;\n\n        const y =\n            window.pageYOffset ||\n            document.documentElement.scrollTop ||\n            document.body.scrollTop ||\n            0;\n\n        const header: HTMLElement | null =\n            document.querySelector('header.header');\n\n        /**\n         * 🔵 DETECCIÓN NUEVA:\n         * Header tocando el borde superior del viewport\n         */\n        if (header && header.getBoundingClientRect().top <= 0) {\n            document.body.classList.add('nav-sticky--top');\n        } else {\n            document.body.classList.remove('nav-sticky--top');\n        }\n\n        /**\n         * 🔵 MODO DINÁMICO (HOTELS)\n         */\n        if (this.isDynamic) {\n            if (y > this.mobileHeader) {\n                document.body.classList.add('nav-sticky', 'mobile-sticky');\n            } else {\n                document.body.classList.remove('nav-sticky', 'mobile-sticky');\n            }\n            return;\n        }\n\n        /**\n         * 🔵 Desktop con banner\n         */\n        if (this.banner) {\n            const bannerHeight = this.getOuterHeight(this.banner);\n            if (y >= bannerHeight) {\n                document.body.classList.add('nav-sticky');\n            } else {\n                document.body.classList.remove('nav-sticky');\n            }\n            document.body.classList.remove('mobile-sticky');\n        }\n\n        /**\n         * 🔵 Desktop sin banner\n         */\n        document.body.classList.add('nav-sticky');\n        document.body.classList.remove('mobile-sticky');\n\n        /**\n         * 🔵 Mobile sin banner\n         */\n        if (this.isMobile()) {\n            document.body.classList.add('nav-sticky', 'mobile-sticky');\n        }\n    }\n\n    private getOuterHeight(element: HTMLElement): number {\n        const height = element.offsetHeight;\n        const style = window.getComputedStyle(element);\n        return (\n            height + parseInt(style.marginTop) + parseInt(style.marginBottom)\n        );\n    }\n}\n"]}
@@ -1192,7 +1192,6 @@ class PuroNavStickyDirective {
1192
1192
  return;
1193
1193
  this.banner = document.querySelector('.banner');
1194
1194
  this.isInitialized = true;
1195
- // Recalcular al finalizar cada navegación
1196
1195
  this.sub = this.router.events
1197
1196
  .pipe(filter((e) => e instanceof NavigationEnd))
1198
1197
  .subscribe(() => this.updateStickyState());
@@ -1212,7 +1211,7 @@ class PuroNavStickyDirective {
1212
1211
  isMobile() {
1213
1212
  if (!isPlatformBrowser(this.platformId))
1214
1213
  return false;
1215
- return window.matchMedia('(max-width: 1280px)').matches; // ajusta a tu "md"
1214
+ return window.matchMedia('(max-width: 1280px)').matches;
1216
1215
  }
1217
1216
  updateStickyState() {
1218
1217
  if (!isPlatformBrowser(this.platformId) || !this.isInitialized)
@@ -1221,34 +1220,52 @@ class PuroNavStickyDirective {
1221
1220
  document.documentElement.scrollTop ||
1222
1221
  document.body.scrollTop ||
1223
1222
  0;
1223
+ const header = document.querySelector('header.header');
1224
+ /**
1225
+ * 🔵 DETECCIÓN NUEVA:
1226
+ * Header tocando el borde superior del viewport
1227
+ */
1228
+ if (header && header.getBoundingClientRect().top <= 0) {
1229
+ document.body.classList.add('nav-sticky--top');
1230
+ }
1231
+ else {
1232
+ document.body.classList.remove('nav-sticky--top');
1233
+ }
1234
+ /**
1235
+ * 🔵 MODO DINÁMICO (HOTELS)
1236
+ */
1224
1237
  if (this.isDynamic) {
1225
- // 🔹 Modo dinámico: en función del scroll
1226
1238
  if (y > this.mobileHeader) {
1227
1239
  document.body.classList.add('nav-sticky', 'mobile-sticky');
1228
1240
  }
1229
1241
  else {
1230
1242
  document.body.classList.remove('nav-sticky', 'mobile-sticky');
1231
1243
  }
1244
+ return;
1232
1245
  }
1233
- else {
1234
- if (this.banner) {
1235
- // 🔹 Desktop con banner: sticky al superar el banner
1236
- const bannerHeight = this.getOuterHeight(this.banner);
1237
- if (y >= bannerHeight) {
1238
- document.body.classList.add('nav-sticky');
1239
- }
1240
- else {
1241
- document.body.classList.remove('nav-sticky');
1242
- }
1243
- document.body.classList.remove('mobile-sticky');
1246
+ /**
1247
+ * 🔵 Desktop con banner
1248
+ */
1249
+ if (this.banner) {
1250
+ const bannerHeight = this.getOuterHeight(this.banner);
1251
+ if (y >= bannerHeight) {
1252
+ document.body.classList.add('nav-sticky');
1244
1253
  }
1245
- // 🔹 Desktop sin banner: siempre nav-sticky
1246
- document.body.classList.add('nav-sticky');
1247
- document.body.classList.remove('mobile-sticky');
1248
- // 🔹 Mobile sin banner: siempre mobile-sticky
1249
- if (this.isMobile()) {
1250
- document.body.classList.add('nav-sticky', 'mobile-sticky');
1254
+ else {
1255
+ document.body.classList.remove('nav-sticky');
1251
1256
  }
1257
+ document.body.classList.remove('mobile-sticky');
1258
+ }
1259
+ /**
1260
+ * 🔵 Desktop sin banner
1261
+ */
1262
+ document.body.classList.add('nav-sticky');
1263
+ document.body.classList.remove('mobile-sticky');
1264
+ /**
1265
+ * 🔵 Mobile sin banner
1266
+ */
1267
+ if (this.isMobile()) {
1268
+ document.body.classList.add('nav-sticky', 'mobile-sticky');
1252
1269
  }
1253
1270
  }
1254
1271
  getOuterHeight(element) {