ctt-babylon 0.9.21 → 0.9.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, Input, ViewChild, ViewEncapsulation, } from '@angular/core';
1
+ import { CommonModule, isPlatformBrowser } from '@angular/common';
2
+ import { Component, inject, Input, PLATFORM_ID, ViewChild, ViewEncapsulation, } from '@angular/core';
3
3
  import 'swiper';
4
4
  import Swiper, { Autoplay, EffectFade, Navigation, Pagination } from 'swiper';
5
5
  import componentData from './content.json';
@@ -10,8 +10,11 @@ const defaultData = componentData;
10
10
  export class C4SliC2TxtImgComponent {
11
11
  constructor() {
12
12
  this.data = defaultData;
13
+ this.platformId = inject(PLATFORM_ID);
13
14
  }
14
15
  ngAfterViewInit() {
16
+ if (!isPlatformBrowser(this.platformId))
17
+ return;
15
18
  const rootEl = this.swiperRoot.nativeElement;
16
19
  const nextEl = rootEl.querySelector('.swiper-button-next.desktop');
17
20
  const prevEl = rootEl.querySelector('.swiper-button-prev.desktop');
@@ -41,6 +44,8 @@ export class C4SliC2TxtImgComponent {
41
44
  this.swiper?.slidePrev();
42
45
  }
43
46
  ngOnDestroy() {
47
+ if (!isPlatformBrowser(this.platformId))
48
+ return;
44
49
  this.swiper?.destroy(true, true);
45
50
  }
46
51
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: C4SliC2TxtImgComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -55,4 +60,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
55
60
  }], data: [{
56
61
  type: Input
57
62
  }] } });
58
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c4-sli-c2-txt-img.component.js","sourceRoot":"","sources":["../../../../../../../../projects/babylon/src/lib/components/external/core/c4-sli-c2-txt-img/c4-sli-c2-txt-img.component.ts","../../../../../../../../projects/babylon/src/lib/components/external/core/c4-sli-c2-txt-img/c4-sli-c2-txt-img.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAEH,SAAS,EAET,KAAK,EAEL,SAAS,EACT,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,QAAQ,CAAC;AAChB,OAAO,MAAM,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAG9E,OAAO,aAAa,MAAM,gBAAgB,CAAC;;;AAE3C,MAAM,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC;AAE3D,MAAM,WAAW,GAAG,aAAqC,CAAC;AAU1D,MAAM,OAAO,sBAAsB;IARnC;QAUa,SAAI,GAAyB,WAAW,CAAC;KA6CrD;IAzCG,eAAe;QACX,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAC/B,6BAA6B,CACV,CAAC;QACxB,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAC/B,6BAA6B,CACV,CAAC;QAExB,MAAM,aAAa,GAAkB;YACjC,aAAa,EAAE,CAAC;YAChB,YAAY,EAAE,EAAE;YAChB,IAAI,EAAE,IAAI;YACV,UAAU,EAAE;gBACR,MAAM,EAAE,MAAM,IAAI,SAAS;gBAC3B,MAAM,EAAE,MAAM,IAAI,SAAS;aAC9B;YACD,WAAW,EAAE;gBACT,GAAG,EAAE;oBACD,aAAa,EAAE,CAAC;iBACnB;gBACD,IAAI,EAAE;oBACF,aAAa,EAAE,CAAC;iBACnB;aACJ;SACJ,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC;IAED,SAAS;QACL,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;IAC7B,CAAC;IAED,SAAS;QACL,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACrC,CAAC;+GA9CQ,sBAAsB;mGAAtB,sBAAsB,qNC5BnC,6rMA6HA,sv+nDDtGc,YAAY;;4FAKb,sBAAsB;kBARlC,SAAS;+BACI,uBAAuB,cACrB,IAAI,WACP,CAAC,YAAY,CAAC,iBAGR,iBAAiB,CAAC,IAAI;8BAGZ,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACd,IAAI;sBAAZ,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Input,\n    OnDestroy,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport 'swiper';\nimport Swiper, { Autoplay, EffectFade, Navigation, Pagination } from 'swiper';\nimport { SwiperOptions } from 'swiper/types';\nimport { C4SliC2TxtImgContent } from './c4-sli-c2-txt-img.interfaces';\nimport componentData from './content.json';\n\nSwiper.use([Navigation, Pagination, Autoplay, EffectFade]);\n\nconst defaultData = componentData as C4SliC2TxtImgContent;\n\n@Component({\n    selector: 'ces-c4-sli-c2-txt-img',\n    standalone: true,\n    imports: [CommonModule],\n    templateUrl: './c4-sli-c2-txt-img.component.html',\n    styleUrl: './c4-sli-c2-txt-img.component.scss',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class C4SliC2TxtImgComponent implements AfterViewInit, OnDestroy {\n    @ViewChild('swiperRoot') swiperRoot!: ElementRef<HTMLElement>;\n    @Input() data: C4SliC2TxtImgContent = defaultData;\n\n    private swiper?: Swiper;\n\n    ngAfterViewInit(): void {\n        const rootEl = this.swiperRoot.nativeElement;\n        const nextEl = rootEl.querySelector(\n            '.swiper-button-next.desktop'\n        ) as HTMLElement | null;\n        const prevEl = rootEl.querySelector(\n            '.swiper-button-prev.desktop'\n        ) as HTMLElement | null;\n\n        const swiperOptions: SwiperOptions = {\n            slidesPerView: 1,\n            spaceBetween: 50,\n            loop: true,\n            navigation: {\n                nextEl: nextEl || undefined,\n                prevEl: prevEl || undefined,\n            },\n            breakpoints: {\n                768: {\n                    slidesPerView: 1,\n                },\n                1024: {\n                    slidesPerView: 1,\n                },\n            },\n        };\n\n        this.swiper = new Swiper(rootEl, swiperOptions);\n    }\n\n    slideNext(): void {\n        this.swiper?.slideNext();\n    }\n\n    slidePrev(): void {\n        this.swiper?.slidePrev();\n    }\n\n    ngOnDestroy(): void {\n        this.swiper?.destroy(true, true);\n    }\n}\n","<section class=\"mdl-experiencias\" *ngIf=\"data\">\n    <div class=\"container\">\n        <div class=\"header\">\n            <h2>\n                {{ data.header.title }}<br />\n                <span>{{ data.header.highlight }}</span>\n            </h2>\n            <p>\n                {{ data.header.description }}\n            </p>\n        </div>\n\n        <div class=\"swiper experiencias-swiper\" #swiperRoot>\n            <div class=\"swiper-wrapper\">\n                @for (slide of data.slides; track $index) {\n                    <div class=\"swiper-slide experiencia\">\n                        <div class=\"content-slide\">\n                            <div class=\"imagen\">\n                                <img\n                                    [src]=\"slide.image.src\"\n                                    [alt]=\"slide.image.alt\"\n                                />\n                            </div>\n                            <div class=\"arrows-navigation\">\n                                <div\n                                    class=\"swiper-button-prev mobile prev fill\"\n                                    role=\"button\"\n                                    tabindex=\"0\"\n                                    (click)=\"slidePrev()\"\n                                >\n                                    <svg\n                                        width=\"8\"\n                                        height=\"14\"\n                                        viewBox=\"0 0 8 14\"\n                                        fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\"\n                                    >\n                                        <path\n                                            d=\"M6.84717 0.5L0.707031 6.64014L6.84717 12.7798\"\n                                            stroke=\"#B7985D\"\n                                            stroke-linecap=\"round\"\n                                        />\n                                    </svg>\n                                </div>\n                                <div\n                                    class=\"swiper-button-next mobile prev fill\"\n                                    role=\"button\"\n                                    tabindex=\"0\"\n                                    (click)=\"slideNext()\"\n                                >\n                                    <svg\n                                        width=\"8\"\n                                        height=\"14\"\n                                        viewBox=\"0 0 8 14\"\n                                        fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\"\n                                    >\n                                        <path\n                                            d=\"M0.500488 0.5L6.64062 6.64014L0.500488 12.7798\"\n                                            stroke=\"#B7985D\"\n                                            stroke-linecap=\"round\"\n                                        />\n                                    </svg>\n                                </div>\n                            </div>\n                            <div class=\"texto\">\n                                <h3>{{ slide.title }}</h3>\n                                <h4>{{ slide.subtitle }}</h4>\n\n                                <div class=\"content-texto\">\n                                    <ul>\n                                        @for (item of slide.items; track item) {\n                                            <li>\n                                                {{ item }}\n                                            </li>\n                                        }\n                                    </ul>\n                                    @if (slide.note) {\n                                        <p class=\"nota\">{{ slide.note }}</p>\n                                    }\n                                    @if (slide.price) {\n                                        <p class=\"precio\">\n                                            {{ slide.price }}\n                                        </p>\n                                    }\n                                    <a\n                                        href=\"{{ slide.button.link }}\"\n                                        class=\"m-button-clean\"\n                                        [attr.aria-label]=\"\n                                            slide.button.ariaLabel ||\n                                            slide.button.text\n                                        \"\n                                    >\n                                        {{ slide.button.text }}\n                                        <svg\n                                            width=\"50\"\n                                            height=\"6\"\n                                            viewBox=\"0 0 50 6\"\n                                            fill=\"none\"\n                                            xmlns=\"http://www.w3.org/2000/svg\"\n                                        >\n                                            <path\n                                                d=\"M45.875 0L49.875 2.8L45.875 5.6V0Z\"\n                                                fill=\"#B7985D\"\n                                            ></path>\n                                            <path\n                                                d=\"M48.875 2.80078H0.375\"\n                                                stroke=\"#B7985D\"\n                                                stroke-width=\"0.75\"\n                                                stroke-linecap=\"round\"\n                                            ></path>\n                                        </svg>\n                                    </a>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n\n            <div class=\"swiper-button-prev desktop\"></div>\n            <div class=\"swiper-button-next desktop\"></div>\n        </div>\n    </div>\n</section>\n"]}
63
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"c4-sli-c2-txt-img.component.js","sourceRoot":"","sources":["../../../../../../../../projects/babylon/src/lib/components/external/core/c4-sli-c2-txt-img/c4-sli-c2-txt-img.component.ts","../../../../../../../../projects/babylon/src/lib/components/external/core/c4-sli-c2-txt-img/c4-sli-c2-txt-img.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAEH,SAAS,EAET,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,EACT,iBAAiB,GACpB,MAAM,eAAe,CAAC;AACvB,OAAO,QAAQ,CAAC;AAChB,OAAO,MAAM,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAG9E,OAAO,aAAa,MAAM,gBAAgB,CAAC;;;AAE3C,MAAM,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC;AAE3D,MAAM,WAAW,GAAG,aAAqC,CAAC;AAU1D,MAAM,OAAO,sBAAsB;IARnC;QAUa,SAAI,GAAyB,WAAW,CAAC;QAGjC,eAAU,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;KA6CrD;IA3CG,eAAe;QACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAChD,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAC/B,6BAA6B,CACV,CAAC;QACxB,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAC/B,6BAA6B,CACV,CAAC;QAExB,MAAM,aAAa,GAAkB;YACjC,aAAa,EAAE,CAAC;YAChB,YAAY,EAAE,EAAE;YAChB,IAAI,EAAE,IAAI;YACV,UAAU,EAAE;gBACR,MAAM,EAAE,MAAM,IAAI,SAAS;gBAC3B,MAAM,EAAE,MAAM,IAAI,SAAS;aAC9B;YACD,WAAW,EAAE;gBACT,GAAG,EAAE;oBACD,aAAa,EAAE,CAAC;iBACnB;gBACD,IAAI,EAAE;oBACF,aAAa,EAAE,CAAC;iBACnB;aACJ;SACJ,CAAC;QAEF,IAAI,CAAC,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IACpD,CAAC;IAED,SAAS;QACL,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;IAC7B,CAAC;IAED,SAAS;QACL,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAAE,OAAO;QAChD,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACrC,CAAC;+GAjDQ,sBAAsB;mGAAtB,sBAAsB,qNC9BnC,6rMA6HA,sv+nDDpGc,YAAY;;4FAKb,sBAAsB;kBARlC,SAAS;+BACI,uBAAuB,cACrB,IAAI,WACP,CAAC,YAAY,CAAC,iBAGR,iBAAiB,CAAC,IAAI;8BAGZ,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACd,IAAI;sBAAZ,KAAK","sourcesContent":["import { CommonModule, isPlatformBrowser } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    inject,\n    Input,\n    OnDestroy,\n    PLATFORM_ID,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\nimport 'swiper';\nimport Swiper, { Autoplay, EffectFade, Navigation, Pagination } from 'swiper';\nimport { SwiperOptions } from 'swiper/types';\nimport { C4SliC2TxtImgContent } from './c4-sli-c2-txt-img.interfaces';\nimport componentData from './content.json';\n\nSwiper.use([Navigation, Pagination, Autoplay, EffectFade]);\n\nconst defaultData = componentData as C4SliC2TxtImgContent;\n\n@Component({\n    selector: 'ces-c4-sli-c2-txt-img',\n    standalone: true,\n    imports: [CommonModule],\n    templateUrl: './c4-sli-c2-txt-img.component.html',\n    styleUrl: './c4-sli-c2-txt-img.component.scss',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class C4SliC2TxtImgComponent implements AfterViewInit, OnDestroy {\n    @ViewChild('swiperRoot') swiperRoot!: ElementRef<HTMLElement>;\n    @Input() data: C4SliC2TxtImgContent = defaultData;\n\n    private swiper?: Swiper;\n    private readonly platformId = inject(PLATFORM_ID);\n\n    ngAfterViewInit(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n        const rootEl = this.swiperRoot.nativeElement;\n        const nextEl = rootEl.querySelector(\n            '.swiper-button-next.desktop'\n        ) as HTMLElement | null;\n        const prevEl = rootEl.querySelector(\n            '.swiper-button-prev.desktop'\n        ) as HTMLElement | null;\n\n        const swiperOptions: SwiperOptions = {\n            slidesPerView: 1,\n            spaceBetween: 50,\n            loop: true,\n            navigation: {\n                nextEl: nextEl || undefined,\n                prevEl: prevEl || undefined,\n            },\n            breakpoints: {\n                768: {\n                    slidesPerView: 1,\n                },\n                1024: {\n                    slidesPerView: 1,\n                },\n            },\n        };\n\n        this.swiper = new Swiper(rootEl, swiperOptions);\n    }\n\n    slideNext(): void {\n        this.swiper?.slideNext();\n    }\n\n    slidePrev(): void {\n        this.swiper?.slidePrev();\n    }\n\n    ngOnDestroy(): void {\n        if (!isPlatformBrowser(this.platformId)) return;\n        this.swiper?.destroy(true, true);\n    }\n}\n","<section class=\"mdl-experiencias\" *ngIf=\"data\">\n    <div class=\"container\">\n        <div class=\"header\">\n            <h2>\n                {{ data.header.title }}<br />\n                <span>{{ data.header.highlight }}</span>\n            </h2>\n            <p>\n                {{ data.header.description }}\n            </p>\n        </div>\n\n        <div class=\"swiper experiencias-swiper\" #swiperRoot>\n            <div class=\"swiper-wrapper\">\n                @for (slide of data.slides; track $index) {\n                    <div class=\"swiper-slide experiencia\">\n                        <div class=\"content-slide\">\n                            <div class=\"imagen\">\n                                <img\n                                    [src]=\"slide.image.src\"\n                                    [alt]=\"slide.image.alt\"\n                                />\n                            </div>\n                            <div class=\"arrows-navigation\">\n                                <div\n                                    class=\"swiper-button-prev mobile prev fill\"\n                                    role=\"button\"\n                                    tabindex=\"0\"\n                                    (click)=\"slidePrev()\"\n                                >\n                                    <svg\n                                        width=\"8\"\n                                        height=\"14\"\n                                        viewBox=\"0 0 8 14\"\n                                        fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\"\n                                    >\n                                        <path\n                                            d=\"M6.84717 0.5L0.707031 6.64014L6.84717 12.7798\"\n                                            stroke=\"#B7985D\"\n                                            stroke-linecap=\"round\"\n                                        />\n                                    </svg>\n                                </div>\n                                <div\n                                    class=\"swiper-button-next mobile prev fill\"\n                                    role=\"button\"\n                                    tabindex=\"0\"\n                                    (click)=\"slideNext()\"\n                                >\n                                    <svg\n                                        width=\"8\"\n                                        height=\"14\"\n                                        viewBox=\"0 0 8 14\"\n                                        fill=\"none\"\n                                        xmlns=\"http://www.w3.org/2000/svg\"\n                                    >\n                                        <path\n                                            d=\"M0.500488 0.5L6.64062 6.64014L0.500488 12.7798\"\n                                            stroke=\"#B7985D\"\n                                            stroke-linecap=\"round\"\n                                        />\n                                    </svg>\n                                </div>\n                            </div>\n                            <div class=\"texto\">\n                                <h3>{{ slide.title }}</h3>\n                                <h4>{{ slide.subtitle }}</h4>\n\n                                <div class=\"content-texto\">\n                                    <ul>\n                                        @for (item of slide.items; track item) {\n                                            <li>\n                                                {{ item }}\n                                            </li>\n                                        }\n                                    </ul>\n                                    @if (slide.note) {\n                                        <p class=\"nota\">{{ slide.note }}</p>\n                                    }\n                                    @if (slide.price) {\n                                        <p class=\"precio\">\n                                            {{ slide.price }}\n                                        </p>\n                                    }\n                                    <a\n                                        href=\"{{ slide.button.link }}\"\n                                        class=\"m-button-clean\"\n                                        [attr.aria-label]=\"\n                                            slide.button.ariaLabel ||\n                                            slide.button.text\n                                        \"\n                                    >\n                                        {{ slide.button.text }}\n                                        <svg\n                                            width=\"50\"\n                                            height=\"6\"\n                                            viewBox=\"0 0 50 6\"\n                                            fill=\"none\"\n                                            xmlns=\"http://www.w3.org/2000/svg\"\n                                        >\n                                            <path\n                                                d=\"M45.875 0L49.875 2.8L45.875 5.6V0Z\"\n                                                fill=\"#B7985D\"\n                                            ></path>\n                                            <path\n                                                d=\"M48.875 2.80078H0.375\"\n                                                stroke=\"#B7985D\"\n                                                stroke-width=\"0.75\"\n                                                stroke-linecap=\"round\"\n                                            ></path>\n                                        </svg>\n                                    </a>\n                                </div>\n                            </div>\n                        </div>\n                    </div>\n                }\n            </div>\n\n            <div class=\"swiper-button-prev desktop\"></div>\n            <div class=\"swiper-button-next desktop\"></div>\n        </div>\n    </div>\n</section>\n"]}
@@ -12380,8 +12380,11 @@ const defaultData = componentData;
12380
12380
  class C4SliC2TxtImgComponent {
12381
12381
  constructor() {
12382
12382
  this.data = defaultData;
12383
+ this.platformId = inject(PLATFORM_ID);
12383
12384
  }
12384
12385
  ngAfterViewInit() {
12386
+ if (!isPlatformBrowser(this.platformId))
12387
+ return;
12385
12388
  const rootEl = this.swiperRoot.nativeElement;
12386
12389
  const nextEl = rootEl.querySelector('.swiper-button-next.desktop');
12387
12390
  const prevEl = rootEl.querySelector('.swiper-button-prev.desktop');
@@ -12411,6 +12414,8 @@ class C4SliC2TxtImgComponent {
12411
12414
  this.swiper?.slidePrev();
12412
12415
  }
12413
12416
  ngOnDestroy() {
12417
+ if (!isPlatformBrowser(this.platformId))
12418
+ return;
12414
12419
  this.swiper?.destroy(true, true);
12415
12420
  }
12416
12421
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: C4SliC2TxtImgComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }