ctt-babylon 0.10.14 → 0.10.15
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.
|
@@ -56,6 +56,7 @@ export class BabylonBlogDetailsComponent {
|
|
|
56
56
|
lang = 'es';
|
|
57
57
|
}
|
|
58
58
|
});
|
|
59
|
+
let domain = window.location.origin + '/' + lang;
|
|
59
60
|
const schema = {
|
|
60
61
|
'@context': 'https://schema.org',
|
|
61
62
|
'@graph': [
|
|
@@ -73,7 +74,7 @@ export class BabylonBlogDetailsComponent {
|
|
|
73
74
|
'@author': {
|
|
74
75
|
'@type': 'Organization',
|
|
75
76
|
name: this.organizationName ?? '',
|
|
76
|
-
url:
|
|
77
|
+
url: domain,
|
|
77
78
|
},
|
|
78
79
|
mainEntityOfPage: {
|
|
79
80
|
'@type': 'WebPage',
|
|
@@ -190,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
190
191
|
}], share: [{
|
|
191
192
|
type: Input
|
|
192
193
|
}] } });
|
|
193
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-blog-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-blog-details/babylon-blog-details.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-blog-details/babylon-blog-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Inject,\n    inject,\n    Input,\n    OnChanges,\n    OnDestroy,\n    SimpleChanges,\n    Pipe,\n    PipeTransform,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { BabylonTagsI, BabylonTextsColorsI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { BabylonDynamicHeadingComponent } from '../../shared';\nimport { BabylonBlogCategoryI, BabylonBlogPostI } from '../babylon-blog-list';\nimport { ActivatedRoute } from '@angular/router';\nimport { organization_name } from '../../../utils/organization-name.token';\n\n// --- PIPE para confiar en enlaces provenientes de contenido HTML ---\n@Pipe({\n    name: 'safeHtml',\n    standalone: true,\n})\nexport class SafeHtmlPipe implements PipeTransform {\n    constructor(private sanitizer: DomSanitizer) {}\n    transform(html: string): SafeHtml {\n        return this.sanitizer.bypassSecurityTrustHtml(html);\n    }\n}\n@Component({\n    selector: 'lib-babylon-blog-details',\n    standalone: true,\n    imports: [\n        CommonModule,\n        BabylonDynamicHeadingComponent,\n        BabylonLinkTypeDirective,\n        SafeHtmlPipe,\n    ],\n    templateUrl: './babylon-blog-details.component.html',\n    styleUrl: './babylon-blog-details.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonBlogDetailsComponent implements OnChanges, OnDestroy {\n    @Input() title?: string;\n    @Input() subtitle?: string;\n    @Input() description?: string;\n    @Input() additional1?: string;\n    @Input() additional2?: string;\n    @Input() additional3?: string;\n    @Input() additional4?: string;\n    @Input() img?: BabylonImageI;\n    @Input() tags?: BabylonTagsI;\n    @Input() textColors?: BabylonTextsColorsI;\n    @Input() button?: BabylonButtonI;\n    @Input() category?: string;\n    @Input() date?: Date;\n    @Input() categories?: BabylonBlogCategoryI[];\n    @Input() relatedPostsTitle?: string;\n    @Input() categoriesTitle?: string;\n    @Input() relatedPosts?: BabylonBlogPostI[] = [];\n    @Input() searchPlaceHolder?: string;\n    @Input() share?: string;\n\n    private organizationName = inject(organization_name);\n    private scriptId = 'babylon-json-ld';\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        private route: ActivatedRoute\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            changes['title'] ||\n            changes['description'] ||\n            changes['date'] ||\n            changes['img']\n        ) {\n            this.updateJsonLd();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.removeJsonLd();\n    }\n    private updateJsonLd(): void {\n        if (!this.title) return;\n        let lang;\n        this.route.url.subscribe((segments) => {\n            if (segments.length > 0) {\n                lang = segments[0].path;\n            } else {\n                lang = 'es';\n            }\n        });\n        const schema = {\n            '@context': 'https://schema.org',\n            '@graph': [\n                {\n                    '@type': 'BlogPosting',\n                    headline: this.title,\n                    description: this.htmlToText(this.additional1) || '',\n                    image: this.img?.src ? [this.img.src] : [],\n                    datePublished: this.date\n                        ? new Date(this.date).toISOString()\n                        : '',\n                    dateModified: this.date\n                        ? new Date(this.date).toISOString()\n                        : '',\n                    '@author': {\n                        '@type': 'Organization',\n                        name: this.organizationName ?? '',\n                        url: this.currentUrl,\n                    },\n                    mainEntityOfPage: {\n                        '@type': 'WebPage',\n                        '@id': this.currentUrl,\n                    },\n                },\n                {\n                    '@type': 'WebPage',\n                    '@id': this.currentUrl,\n                    url: this.currentUrl,\n                    name: this.title,\n                    inLanguage: lang,\n                },\n            ],\n        };\n\n        this.insertScript(schema);\n    }\n    private insertScript(schema: any): void {\n        this.removeJsonLd();\n\n        const script = this.document.createElement('script');\n        script.type = 'application/ld+json';\n        script.id = this.scriptId;\n        script.text = JSON.stringify(schema);\n\n        this.document.head.appendChild(script);\n    }\n    private removeJsonLd(): void {\n        const script = this.document.getElementById(this.scriptId);\n        if (script) {\n            script.remove();\n        }\n    }\n\n    private htmlToText(content: string | undefined) {\n        if (!content || !content.length) {\n            return;\n        }\n\n        const tempDiv = document.createElement('div');\n        tempDiv.innerHTML = content;\n\n        return tempDiv.textContent || tempDiv.innerText || '';\n    }\n\n    get currentUrl(): string {\n        if (typeof window === 'undefined') return '';\n        return window.location.href;\n    }\n\n    get shareText(): string {\n        return this.title ?? '';\n    }\n\n    get facebookShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        return `https://www.facebook.com/sharer/sharer.php?u=${url}`;\n    }\n\n    get twitterShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        const text = encodeURIComponent(this.shareText);\n        return `https://twitter.com/intent/tweet?url=${url}&text=${text}`;\n    }\n\n    get linkedinShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        return `https://www.linkedin.com/sharing/share-offsite/?url=${url}`;\n    }\n\n    get hasSidebar(): boolean {\n        return !!(this.categoriesTitle || this.relatedPostsTitle);\n    }\n}\n","<section class=\"babylon__blog-detail margin-main\">\n    @if (button) {\n        <div class=\"btns__box box-container col-lg-8 offset-lg-2\">\n            <a\n                [href]=\"button.url\"\n                [linkType]=\"button.linkType\"\n                class=\"btn-link\"\n                aria-label=\"volver\"\n            >\n                <span class=\"babylon-arrow-left-big\"></span>\n                <b>{{ button.label }}</b>\n            </a>\n        </div>\n    }\n    <div class=\"container-fluid cs_plr_100\">\n        <div class=\"intro_info title-container col-lg-8 offset-lg-2\">\n            @if (title) {\n                <h1 class=\"title cs_mb_13\">{{ title }}</h1>\n            }\n            <div class=\"cs_post_meta_4 cs_mb_13 pretitle\">\n                @if (category) {\n                    <span>{{ category }}</span>\n                }\n                @if (date) {\n                    <span>{{ date | date: 'dd/MM/yyyy' }}</span>\n                }\n            </div>\n        </div>\n    </div>\n    <div class=\"container-fluid cs_plr_100\">\n        <div class=\"row cs_gap_y_lg_80\">\n            <div ngClass=\"col-lg-8 offset-lg-2\">\n                <div class=\"cs_blog_details\">\n                    <div class=\"cs_image_layer cs_about_img\">\n                        @if (img) {\n                            <img\n                                [src]=\"img.src\"\n                                [alt]=\"img.alt\"\n                                class=\"cs--radius\"\n                                loading=\"lazy\"\n                            />\n                            @if (img.ndTitle) {\n                                {{ img.ndTitle }}\n                            }\n                        }\n                    </div>\n                    <div class=\"intro_info no-align\">\n                        @if (description) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"description | safeHtml\"\n                            ></p>\n                        }\n                        @if (subtitle) {\n                            <h2 class=\"title--small\">{{ subtitle }}</h2>\n                        }\n                        <!--Additional1 is used on blog list for resume -->\n                        @if (additional2) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional2 | safeHtml\"\n                            ></p>\n                        }\n                        @if (additional3) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional3 | safeHtml\"\n                            ></p>\n                        }\n                        @if (additional4) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional4 | safeHtml\"\n                            ></p>\n                        }\n                    </div>\n                </div>\n                @if (!hasSidebar) {\n                    <div class=\"cs_post_share d-lg-none\">\n                        <ng-container\n                            [ngTemplateOutlet]=\"shareButtons\"\n                        ></ng-container>\n                    </div>\n                }\n                @if (button) {\n                    <div class=\"btns__box\">\n                        <a\n                            [href]=\"button.url\"\n                            [linkType]=\"button.linkType\"\n                            class=\"btn-link\"\n                            aria-label=\"volver\"\n                        >\n                            <span class=\"babylon-arrow-left-big\"></span>\n                            <b>{{ button.label }}</b>\n                        </a>\n                    </div>\n                }\n            </div>\n            @if (!hasSidebar) {\n                <div class=\"col-lg-1 d-none d-lg-block\">\n                    <div class=\"share_sidebar\">\n                        <ng-container\n                            [ngTemplateOutlet]=\"shareButtons\"\n                        ></ng-container>\n                        @if (share) {\n                            <span class=\"share_label\">{{ share }}</span>\n                        }\n                    </div>\n                </div>\n            }\n            @if (hasSidebar) {\n                <div class=\"col-lg-4\">\n                    <div class=\"cs_sidebar cs_right_sidebar\">\n                        <div class=\"cs_sidebar_item widget_categories\">\n                            @if (categoriesTitle) {\n                                <lib-babylon-dynamic-heading\n                                    [tag]=\"tags?.categoriesTitle || 'h4'\"\n                                    cssClass=\"title--small mb--20\"\n                                    [color]=\"textColors?.categoriesTitle\"\n                                    [content]=\"categoriesTitle\"\n                                ></lib-babylon-dynamic-heading>\n                            }\n                            @if (categories?.length) {\n                                <ul>\n                                    @for (\n                                        category of categories;\n                                        track $index\n                                    ) {\n                                        <li class=\"cat-item\">\n                                            <a\n                                                aria-label=\"label\"\n                                                ?\n                                                [href]=\"\n                                                    button?.url +\n                                                    '?category=' +\n                                                    category?.title\n                                                \"\n                                                >{{ category?.title }} ({{\n                                                    category?.posts\n                                                }})</a\n                                            >\n                                        </li>\n                                    }\n                                </ul>\n                            }\n                        </div>\n                        <div class=\"cs_sidebar_item\">\n                            @if (relatedPostsTitle) {\n                                <lib-babylon-dynamic-heading\n                                    [tag]=\"tags?.latestPostsTitle || 'h4'\"\n                                    cssClass=\"title--small mb--20\"\n                                    [color]=\"textColors?.latestPostsTitle\"\n                                    [content]=\"relatedPostsTitle\"\n                                ></lib-babylon-dynamic-heading>\n                            }\n                            @if (relatedPosts?.length) {\n                                <ul class=\"cs_recent_posts\">\n                                    @for (post of relatedPosts; track $index) {\n                                        <li>\n                                            <div class=\"cs_recent_post\">\n                                                <h3\n                                                    class=\"title--smaller mb--10\"\n                                                >\n                                                    <a\n                                                        [attr.aria-label]=\"\n                                                            post.postUrl?.label\n                                                        \"\n                                                        [href]=\"\n                                                            post.postUrl?.url\n                                                        \"\n                                                        [linkType]=\"\n                                                            post.postUrl\n                                                                ?.linkType\n                                                        \"\n                                                        >{{ post?.title }}</a\n                                                    >\n                                                </h3>\n                                                @if (post?.date) {\n                                                    <em class=\"text--small\">{{\n                                                        post?.date\n                                                            | date: 'mediumDate'\n                                                    }}</em>\n                                                }\n                                            </div>\n                                        </li>\n                                    }\n                                </ul>\n                            }\n                        </div>\n                    </div>\n                </div>\n            }\n            <ng-template #shareButtons>\n                <div class=\"cs_social_share_btns\">\n                    <a\n                        [href]=\"facebookShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en Facebook\"\n                        class=\"share-facebook\"\n                    >\n                        <span class=\"babylon-facebook\"></span>\n                    </a>\n                    <a\n                        [href]=\"twitterShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en X\"\n                        class=\"share-twitter\"\n                    >\n                        <span class=\"babylon-twitter\"></span>\n                    </a>\n                    <a\n                        [href]=\"linkedinShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en LinkedIn\"\n                        class=\"share-linkedin\"\n                    >\n                        <span class=\"babylon-linkedin\"></span>\n                    </a>\n                </div>\n            </ng-template>\n        </div>\n    </div>\n</section>\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babylon-blog-details.component.js","sourceRoot":"","sources":["../../../../../../../projects/babylon/src/lib/components/core/babylon-blog-details/babylon-blog-details.component.ts","../../../../../../../projects/babylon/src/lib/components/core/babylon-blog-details/babylon-blog-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DOCUMENT } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    Inject,\n    inject,\n    Input,\n    OnChanges,\n    OnDestroy,\n    SimpleChanges,\n    Pipe,\n    PipeTransform,\n} from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';\nimport { BabylonTagsI, BabylonTextsColorsI } from '../../../interfaces';\nimport { BabylonButtonI } from '../../../interfaces/babylon-button.interface';\nimport { BabylonImageI } from '../../../interfaces/babylon-image.interface';\nimport { BabylonDynamicHeadingComponent } from '../../shared';\nimport { BabylonBlogCategoryI, BabylonBlogPostI } from '../babylon-blog-list';\nimport { ActivatedRoute } from '@angular/router';\nimport { organization_name } from '../../../utils/organization-name.token';\n\n// --- PIPE para confiar en enlaces provenientes de contenido HTML ---\n@Pipe({\n    name: 'safeHtml',\n    standalone: true,\n})\nexport class SafeHtmlPipe implements PipeTransform {\n    constructor(private sanitizer: DomSanitizer) {}\n    transform(html: string): SafeHtml {\n        return this.sanitizer.bypassSecurityTrustHtml(html);\n    }\n}\n@Component({\n    selector: 'lib-babylon-blog-details',\n    standalone: true,\n    imports: [\n        CommonModule,\n        BabylonDynamicHeadingComponent,\n        BabylonLinkTypeDirective,\n        SafeHtmlPipe,\n    ],\n    templateUrl: './babylon-blog-details.component.html',\n    styleUrl: './babylon-blog-details.component.scss',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BabylonBlogDetailsComponent implements OnChanges, OnDestroy {\n    @Input() title?: string;\n    @Input() subtitle?: string;\n    @Input() description?: string;\n    @Input() additional1?: string;\n    @Input() additional2?: string;\n    @Input() additional3?: string;\n    @Input() additional4?: string;\n    @Input() img?: BabylonImageI;\n    @Input() tags?: BabylonTagsI;\n    @Input() textColors?: BabylonTextsColorsI;\n    @Input() button?: BabylonButtonI;\n    @Input() category?: string;\n    @Input() date?: Date;\n    @Input() categories?: BabylonBlogCategoryI[];\n    @Input() relatedPostsTitle?: string;\n    @Input() categoriesTitle?: string;\n    @Input() relatedPosts?: BabylonBlogPostI[] = [];\n    @Input() searchPlaceHolder?: string;\n    @Input() share?: string;\n\n    private organizationName = inject(organization_name);\n    private scriptId = 'babylon-json-ld';\n    constructor(\n        @Inject(DOCUMENT) private document: Document,\n        private route: ActivatedRoute\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\n            changes['title'] ||\n            changes['description'] ||\n            changes['date'] ||\n            changes['img']\n        ) {\n            this.updateJsonLd();\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.removeJsonLd();\n    }\n    private updateJsonLd(): void {\n        if (!this.title) return;\n        let lang;\n        this.route.url.subscribe((segments) => {\n            if (segments.length > 0) {\n                lang = segments[0].path;\n            } else {\n                lang = 'es';\n            }\n        });\n        let domain = window.location.origin + '/' + lang;\n        const schema = {\n            '@context': 'https://schema.org',\n            '@graph': [\n                {\n                    '@type': 'BlogPosting',\n                    headline: this.title,\n                    description: this.htmlToText(this.additional1) || '',\n                    image: this.img?.src ? [this.img.src] : [],\n                    datePublished: this.date\n                        ? new Date(this.date).toISOString()\n                        : '',\n                    dateModified: this.date\n                        ? new Date(this.date).toISOString()\n                        : '',\n                    '@author': {\n                        '@type': 'Organization',\n                        name: this.organizationName ?? '',\n                        url: domain,\n                    },\n                    mainEntityOfPage: {\n                        '@type': 'WebPage',\n                        '@id': this.currentUrl,\n                    },\n                },\n                {\n                    '@type': 'WebPage',\n                    '@id': this.currentUrl,\n                    url: this.currentUrl,\n                    name: this.title,\n                    inLanguage: lang,\n                },\n            ],\n        };\n\n        this.insertScript(schema);\n    }\n    private insertScript(schema: any): void {\n        this.removeJsonLd();\n\n        const script = this.document.createElement('script');\n        script.type = 'application/ld+json';\n        script.id = this.scriptId;\n        script.text = JSON.stringify(schema);\n\n        this.document.head.appendChild(script);\n    }\n    private removeJsonLd(): void {\n        const script = this.document.getElementById(this.scriptId);\n        if (script) {\n            script.remove();\n        }\n    }\n\n    private htmlToText(content: string | undefined) {\n        if (!content || !content.length) {\n            return;\n        }\n\n        const tempDiv = document.createElement('div');\n        tempDiv.innerHTML = content;\n\n        return tempDiv.textContent || tempDiv.innerText || '';\n    }\n\n    get currentUrl(): string {\n        if (typeof window === 'undefined') return '';\n        return window.location.href;\n    }\n\n    get shareText(): string {\n        return this.title ?? '';\n    }\n\n    get facebookShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        return `https://www.facebook.com/sharer/sharer.php?u=${url}`;\n    }\n\n    get twitterShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        const text = encodeURIComponent(this.shareText);\n        return `https://twitter.com/intent/tweet?url=${url}&text=${text}`;\n    }\n\n    get linkedinShareUrl(): string {\n        const url = encodeURI(this.currentUrl);\n        return `https://www.linkedin.com/sharing/share-offsite/?url=${url}`;\n    }\n\n    get hasSidebar(): boolean {\n        return !!(this.categoriesTitle || this.relatedPostsTitle);\n    }\n}\n","<section class=\"babylon__blog-detail margin-main\">\n    @if (button) {\n        <div class=\"btns__box box-container col-lg-8 offset-lg-2\">\n            <a\n                [href]=\"button.url\"\n                [linkType]=\"button.linkType\"\n                class=\"btn-link\"\n                aria-label=\"volver\"\n            >\n                <span class=\"babylon-arrow-left-big\"></span>\n                <b>{{ button.label }}</b>\n            </a>\n        </div>\n    }\n    <div class=\"container-fluid cs_plr_100\">\n        <div class=\"intro_info title-container col-lg-8 offset-lg-2\">\n            @if (title) {\n                <h1 class=\"title cs_mb_13\">{{ title }}</h1>\n            }\n            <div class=\"cs_post_meta_4 cs_mb_13 pretitle\">\n                @if (category) {\n                    <span>{{ category }}</span>\n                }\n                @if (date) {\n                    <span>{{ date | date: 'dd/MM/yyyy' }}</span>\n                }\n            </div>\n        </div>\n    </div>\n    <div class=\"container-fluid cs_plr_100\">\n        <div class=\"row cs_gap_y_lg_80\">\n            <div ngClass=\"col-lg-8 offset-lg-2\">\n                <div class=\"cs_blog_details\">\n                    <div class=\"cs_image_layer cs_about_img\">\n                        @if (img) {\n                            <img\n                                [src]=\"img.src\"\n                                [alt]=\"img.alt\"\n                                class=\"cs--radius\"\n                                loading=\"lazy\"\n                            />\n                            @if (img.ndTitle) {\n                                {{ img.ndTitle }}\n                            }\n                        }\n                    </div>\n                    <div class=\"intro_info no-align\">\n                        @if (description) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"description | safeHtml\"\n                            ></p>\n                        }\n                        @if (subtitle) {\n                            <h2 class=\"title--small\">{{ subtitle }}</h2>\n                        }\n                        <!--Additional1 is used on blog list for resume -->\n                        @if (additional2) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional2 | safeHtml\"\n                            ></p>\n                        }\n                        @if (additional3) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional3 | safeHtml\"\n                            ></p>\n                        }\n                        @if (additional4) {\n                            <p\n                                class=\"text\"\n                                [innerHTML]=\"additional4 | safeHtml\"\n                            ></p>\n                        }\n                    </div>\n                </div>\n                @if (!hasSidebar) {\n                    <div class=\"cs_post_share d-lg-none\">\n                        <ng-container\n                            [ngTemplateOutlet]=\"shareButtons\"\n                        ></ng-container>\n                    </div>\n                }\n                @if (button) {\n                    <div class=\"btns__box\">\n                        <a\n                            [href]=\"button.url\"\n                            [linkType]=\"button.linkType\"\n                            class=\"btn-link\"\n                            aria-label=\"volver\"\n                        >\n                            <span class=\"babylon-arrow-left-big\"></span>\n                            <b>{{ button.label }}</b>\n                        </a>\n                    </div>\n                }\n            </div>\n            @if (!hasSidebar) {\n                <div class=\"col-lg-1 d-none d-lg-block\">\n                    <div class=\"share_sidebar\">\n                        <ng-container\n                            [ngTemplateOutlet]=\"shareButtons\"\n                        ></ng-container>\n                        @if (share) {\n                            <span class=\"share_label\">{{ share }}</span>\n                        }\n                    </div>\n                </div>\n            }\n            @if (hasSidebar) {\n                <div class=\"col-lg-4\">\n                    <div class=\"cs_sidebar cs_right_sidebar\">\n                        <div class=\"cs_sidebar_item widget_categories\">\n                            @if (categoriesTitle) {\n                                <lib-babylon-dynamic-heading\n                                    [tag]=\"tags?.categoriesTitle || 'h4'\"\n                                    cssClass=\"title--small mb--20\"\n                                    [color]=\"textColors?.categoriesTitle\"\n                                    [content]=\"categoriesTitle\"\n                                ></lib-babylon-dynamic-heading>\n                            }\n                            @if (categories?.length) {\n                                <ul>\n                                    @for (\n                                        category of categories;\n                                        track $index\n                                    ) {\n                                        <li class=\"cat-item\">\n                                            <a\n                                                aria-label=\"label\"\n                                                ?\n                                                [href]=\"\n                                                    button?.url +\n                                                    '?category=' +\n                                                    category?.title\n                                                \"\n                                                >{{ category?.title }} ({{\n                                                    category?.posts\n                                                }})</a\n                                            >\n                                        </li>\n                                    }\n                                </ul>\n                            }\n                        </div>\n                        <div class=\"cs_sidebar_item\">\n                            @if (relatedPostsTitle) {\n                                <lib-babylon-dynamic-heading\n                                    [tag]=\"tags?.latestPostsTitle || 'h4'\"\n                                    cssClass=\"title--small mb--20\"\n                                    [color]=\"textColors?.latestPostsTitle\"\n                                    [content]=\"relatedPostsTitle\"\n                                ></lib-babylon-dynamic-heading>\n                            }\n                            @if (relatedPosts?.length) {\n                                <ul class=\"cs_recent_posts\">\n                                    @for (post of relatedPosts; track $index) {\n                                        <li>\n                                            <div class=\"cs_recent_post\">\n                                                <h3\n                                                    class=\"title--smaller mb--10\"\n                                                >\n                                                    <a\n                                                        [attr.aria-label]=\"\n                                                            post.postUrl?.label\n                                                        \"\n                                                        [href]=\"\n                                                            post.postUrl?.url\n                                                        \"\n                                                        [linkType]=\"\n                                                            post.postUrl\n                                                                ?.linkType\n                                                        \"\n                                                        >{{ post?.title }}</a\n                                                    >\n                                                </h3>\n                                                @if (post?.date) {\n                                                    <em class=\"text--small\">{{\n                                                        post?.date\n                                                            | date: 'mediumDate'\n                                                    }}</em>\n                                                }\n                                            </div>\n                                        </li>\n                                    }\n                                </ul>\n                            }\n                        </div>\n                    </div>\n                </div>\n            }\n            <ng-template #shareButtons>\n                <div class=\"cs_social_share_btns\">\n                    <a\n                        [href]=\"facebookShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en Facebook\"\n                        class=\"share-facebook\"\n                    >\n                        <span class=\"babylon-facebook\"></span>\n                    </a>\n                    <a\n                        [href]=\"twitterShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en X\"\n                        class=\"share-twitter\"\n                    >\n                        <span class=\"babylon-twitter\"></span>\n                    </a>\n                    <a\n                        [href]=\"linkedinShareUrl\"\n                        target=\"_blank\"\n                        rel=\"noopener\"\n                        aria-label=\"Compartir en LinkedIn\"\n                        class=\"share-linkedin\"\n                    >\n                        <span class=\"babylon-linkedin\"></span>\n                    </a>\n                </div>\n            </ng-template>\n        </div>\n    </div>\n</section>\n"]}
|
package/fesm2022/ctt-babylon.mjs
CHANGED
|
@@ -5454,6 +5454,7 @@ class BabylonBlogDetailsComponent {
|
|
|
5454
5454
|
lang = 'es';
|
|
5455
5455
|
}
|
|
5456
5456
|
});
|
|
5457
|
+
let domain = window.location.origin + '/' + lang;
|
|
5457
5458
|
const schema = {
|
|
5458
5459
|
'@context': 'https://schema.org',
|
|
5459
5460
|
'@graph': [
|
|
@@ -5471,7 +5472,7 @@ class BabylonBlogDetailsComponent {
|
|
|
5471
5472
|
'@author': {
|
|
5472
5473
|
'@type': 'Organization',
|
|
5473
5474
|
name: this.organizationName ?? '',
|
|
5474
|
-
url:
|
|
5475
|
+
url: domain,
|
|
5475
5476
|
},
|
|
5476
5477
|
mainEntityOfPage: {
|
|
5477
5478
|
'@type': 'WebPage',
|