ctt-babylon 0.1.76 → 0.1.77
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-footer-logos/babylon-footer-logos.component.mjs +10 -3
- package/esm2022/lib/utils/utils.mjs +30 -28
- package/fesm2022/ctt-babylon.mjs +38 -29
- package/fesm2022/ctt-babylon.mjs.map +1 -1
- package/lib/components/core/babylon-footer-logos/babylon-footer-logos.component.d.ts +2 -0
- package/lib/styles/styles/babylon/common.scss +0 -2
- package/package.json +1 -1
|
@@ -3,12 +3,19 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { BabylonLinkTypeDirective } from '../../../directives/link-type/link-type.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class BabylonFooterLogosComponent {
|
|
6
|
+
get filteredButtons() {
|
|
7
|
+
return (this.buttons || []).filter(b => !!b);
|
|
8
|
+
}
|
|
9
|
+
hasContent() {
|
|
10
|
+
return ((this.texts && (this.texts.title || this.texts.subtitle || this.texts.description)) ||
|
|
11
|
+
this.filteredButtons.length);
|
|
12
|
+
}
|
|
6
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonFooterLogosComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
7
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BabylonFooterLogosComponent, isStandalone: true, selector: "lib-babylon-footer-logos", inputs: { logos: "logos", texts: "texts", buttons: "buttons" }, ngImport: i0, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BabylonFooterLogosComponent, isStandalone: true, selector: "lib-babylon-footer-logos", inputs: { logos: "logos", texts: "texts", buttons: "buttons" }, ngImport: i0, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (hasContent()) {\n <div class=\"intro_info align--center no-align pt--30\">\n @if (texts?.title) {\n <h1 class=\"title--small mb--10\">{{ texts?.title }}</h1>\n }\n @if (texts?.subtitle) {\n <h2 class=\"title\">{{ texts?.subtitle }}</h2>\n }\n @if (texts?.description) {\n <p class=\"text mb--10\">\n {{ texts?.description }}\n </p>\n }\n @if (buttons?.length) {\n <div class=\"btns__box align--center\">\n @for (button of buttons; track $index) {\n @if (button) {\n <div>\n <a [href]=\"button?.url\" [linkType]=\"button?.linkType\" class=\"btn btn_primary\"><b>{{ button?.label\n }}</b><span class=\"babylon-arrow-right-big\"></span></a>\n </div>\n }\n }\n </div>\n }\n </div>\n }\n @if (logos) {\n <ul>\n @for (logo of logos; track $index) {\n <li>\n @if (logo.link) {\n <a [href]=\"logo.link.url\" [linkType]=\"logo.link.linkType\" aria-label=\"link\">\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" /></a>\n } @else {\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" />\n }\n </li>\n }\n </ul>\n }\n </div>\n</section>", styles: [".babylon__footer-logos{background-color:var(--cl_footer-bg-logos)}.babylon__footer-logos ul{display:flex;gap:30px 20px;padding-block:30px;align-items:center;justify-content:space-around;flex-wrap:wrap}.babylon__footer-logos img{width:200px;height:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: BabylonLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href"], outputs: ["anchorClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
8
15
|
}
|
|
9
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonFooterLogosComponent, decorators: [{
|
|
10
17
|
type: Component,
|
|
11
|
-
args: [{ selector: 'lib-babylon-footer-logos', standalone: true, imports: [CommonModule, BabylonLinkTypeDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (
|
|
18
|
+
args: [{ selector: 'lib-babylon-footer-logos', standalone: true, imports: [CommonModule, BabylonLinkTypeDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (hasContent()) {\n <div class=\"intro_info align--center no-align pt--30\">\n @if (texts?.title) {\n <h1 class=\"title--small mb--10\">{{ texts?.title }}</h1>\n }\n @if (texts?.subtitle) {\n <h2 class=\"title\">{{ texts?.subtitle }}</h2>\n }\n @if (texts?.description) {\n <p class=\"text mb--10\">\n {{ texts?.description }}\n </p>\n }\n @if (buttons?.length) {\n <div class=\"btns__box align--center\">\n @for (button of buttons; track $index) {\n @if (button) {\n <div>\n <a [href]=\"button?.url\" [linkType]=\"button?.linkType\" class=\"btn btn_primary\"><b>{{ button?.label\n }}</b><span class=\"babylon-arrow-right-big\"></span></a>\n </div>\n }\n }\n </div>\n }\n </div>\n }\n @if (logos) {\n <ul>\n @for (logo of logos; track $index) {\n <li>\n @if (logo.link) {\n <a [href]=\"logo.link.url\" [linkType]=\"logo.link.linkType\" aria-label=\"link\">\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" /></a>\n } @else {\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" />\n }\n </li>\n }\n </ul>\n }\n </div>\n</section>", styles: [".babylon__footer-logos{background-color:var(--cl_footer-bg-logos)}.babylon__footer-logos ul{display:flex;gap:30px 20px;padding-block:30px;align-items:center;justify-content:space-around;flex-wrap:wrap}.babylon__footer-logos img{width:200px;height:auto}\n"] }]
|
|
12
19
|
}], propDecorators: { logos: [{
|
|
13
20
|
type: Input
|
|
14
21
|
}], texts: [{
|
|
@@ -16,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
16
23
|
}], buttons: [{
|
|
17
24
|
type: Input
|
|
18
25
|
}] } });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFieWxvbi1mb290ZXItbG9nb3MuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFieWxvbi9zcmMvbGliL2NvbXBvbmVudHMvY29yZS9iYWJ5bG9uLWZvb3Rlci1sb2dvcy9iYWJ5bG9uLWZvb3Rlci1sb2dvcy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYWJ5bG9uL3NyYy9saWIvY29tcG9uZW50cy9jb3JlL2JhYnlsb24tZm9vdGVyLWxvZ29zL2JhYnlsb24tZm9vdGVyLWxvZ29zLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7QUFVN0YsTUFBTSxPQUFPLDJCQUEyQjtJQUtwQyxJQUFJLGVBQWU7UUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLElBQUksRUFBRSxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQy9DLENBQUM7SUFFRCxVQUFVO1FBQ1IsT0FBTyxDQUNMLENBQUMsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUM7WUFDbkYsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQzVCLENBQUM7SUFDSixDQUFDOytHQWRRLDJCQUEyQjttR0FBM0IsMkJBQTJCLG9KQ2J4QywrbURBNENVLHVURHBDRSxZQUFZLCtCQUFFLHdCQUF3Qjs7NEZBS3JDLDJCQUEyQjtrQkFSdkMsU0FBUzsrQkFDRSwwQkFBMEIsY0FDeEIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLHdCQUF3QixDQUFDLG1CQUc5Qix1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBCYWJ5bG9uSW1hZ2VJLCBCYWJ5bG9uVGV4dHMsIEJhYnlsb25CdXR0b25JIH0gZnJvbSAnLi4vLi4vLi4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQmFieWxvbkxpbmtUeXBlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlcy9saW5rLXR5cGUvbGluay10eXBlLmRpcmVjdGl2ZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xpYi1iYWJ5bG9uLWZvb3Rlci1sb2dvcycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEJhYnlsb25MaW5rVHlwZURpcmVjdGl2ZV0sXG4gIHRlbXBsYXRlVXJsOiAnLi9iYWJ5bG9uLWZvb3Rlci1sb2dvcy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsOiAnLi9iYWJ5bG9uLWZvb3Rlci1sb2dvcy5jb21wb25lbnQuc2NzcycsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIEJhYnlsb25Gb290ZXJMb2dvc0NvbXBvbmVudCB7XG4gICAgQElucHV0KCkgbG9nb3M/OiBCYWJ5bG9uRm9vdGVyTG9nb0l0ZW1JW107XG4gICAgQElucHV0KCkgdGV4dHM/OiBCYWJ5bG9uVGV4dHM7XG4gICAgQElucHV0KCkgYnV0dG9ucz86IEJhYnlsb25CdXR0b25JW107XG4gICAgXG4gICAgZ2V0IGZpbHRlcmVkQnV0dG9ucygpIHtcbiAgICAgIHJldHVybiAodGhpcy5idXR0b25zIHx8IFtdKS5maWx0ZXIoYiA9PiAhIWIpO1xuICAgIH1cbiAgICBcbiAgICBoYXNDb250ZW50KCkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgKHRoaXMudGV4dHMgJiYgKHRoaXMudGV4dHMudGl0bGUgfHwgdGhpcy50ZXh0cy5zdWJ0aXRsZSB8fCB0aGlzLnRleHRzLmRlc2NyaXB0aW9uKSkgfHxcbiAgICAgICAgdGhpcy5maWx0ZXJlZEJ1dHRvbnMubGVuZ3RoXG4gICAgICApO1xuICAgIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBCYWJ5bG9uRm9vdGVyTG9nb0l0ZW1JIHtcbiAgaW1nPzogQmFieWxvbkltYWdlSTtcbiAgbGluaz86IEJhYnlsb25CdXR0b25JO1xufSIsIjxzZWN0aW9uIGNsYXNzPVwiYmFieWxvbl9fZm9vdGVyLWxvZ29zXCI+XG4gICAgPGRpdiBjbGFzcz1cImNvbnRhaW5lclwiPlxuICAgICAgICBAaWYgKGhhc0NvbnRlbnQoKSkge1xuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImludHJvX2luZm8gYWxpZ24tLWNlbnRlciBuby1hbGlnbiBwdC0tMzBcIj5cbiAgICAgICAgICAgIEBpZiAodGV4dHM/LnRpdGxlKSB7XG4gICAgICAgICAgICA8aDEgY2xhc3M9XCJ0aXRsZS0tc21hbGwgbWItLTEwXCI+e3sgdGV4dHM/LnRpdGxlIH19PC9oMT5cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIEBpZiAodGV4dHM/LnN1YnRpdGxlKSB7XG4gICAgICAgICAgICA8aDIgY2xhc3M9XCJ0aXRsZVwiPnt7IHRleHRzPy5zdWJ0aXRsZSB9fTwvaDI+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBAaWYgKHRleHRzPy5kZXNjcmlwdGlvbikge1xuICAgICAgICAgICAgPHAgY2xhc3M9XCJ0ZXh0IG1iLS0xMFwiPlxuICAgICAgICAgICAgICAgIHt7IHRleHRzPy5kZXNjcmlwdGlvbiB9fVxuICAgICAgICAgICAgPC9wPlxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgQGlmIChidXR0b25zPy5sZW5ndGgpIHtcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJidG5zX19ib3ggYWxpZ24tLWNlbnRlclwiPlxuICAgICAgICAgICAgICAgIEBmb3IgKGJ1dHRvbiBvZiBidXR0b25zOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgICAgICAgICAgICAgICAgQGlmIChidXR0b24pIHtcbiAgICAgICAgICAgICAgICAgICAgPGRpdj5cbiAgICAgICAgICAgICAgICAgICAgICAgIDxhIFtocmVmXT1cImJ1dHRvbj8udXJsXCIgW2xpbmtUeXBlXT1cImJ1dHRvbj8ubGlua1R5cGVcIiBjbGFzcz1cImJ0biBidG5fcHJpbWFyeVwiPjxiPnt7IGJ1dHRvbj8ubGFiZWxcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgfX08L2I+PHNwYW4gY2xhc3M9XCJiYWJ5bG9uLWFycm93LXJpZ2h0LWJpZ1wiPjwvc3Bhbj48L2E+XG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICB9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICB9XG4gICAgICAgIEBpZiAobG9nb3MpIHtcbiAgICAgICAgPHVsPlxuICAgICAgICAgICAgQGZvciAobG9nbyBvZiBsb2dvczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgICAgICA8bGk+XG4gICAgICAgICAgICAgICAgQGlmIChsb2dvLmxpbmspIHtcbiAgICAgICAgICAgICAgICA8YSBbaHJlZl09XCJsb2dvLmxpbmsudXJsXCIgW2xpbmtUeXBlXT1cImxvZ28ubGluay5saW5rVHlwZVwiIGFyaWEtbGFiZWw9XCJsaW5rXCI+XG4gICAgICAgICAgICAgICAgICAgIDxpbWcgW3NyY109XCJsb2dvLmltZz8uc3JjXCIgW2FsdF09XCJsb2dvLmltZz8uYWx0XCIgLz48L2E+XG4gICAgICAgICAgICAgICAgfSBAZWxzZSB7XG4gICAgICAgICAgICAgICAgPGltZyBbc3JjXT1cImxvZ28uaW1nPy5zcmNcIiBbYWx0XT1cImxvZ28uaW1nPy5hbHRcIiAvPlxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICB9XG4gICAgICAgIDwvdWw+XG4gICAgICAgIH1cbiAgICA8L2Rpdj5cbjwvc2VjdGlvbj4iXX0=
|
|
@@ -44,38 +44,40 @@ export class Utils {
|
|
|
44
44
|
}
|
|
45
45
|
static mapButtons(button, buttonType) {
|
|
46
46
|
if (Array.isArray(button)) {
|
|
47
|
-
return button?.map((btn) =>
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
47
|
+
return button?.map((btn) => btn.label?.length
|
|
48
|
+
? {
|
|
49
|
+
type: buttonType ?? undefined,
|
|
50
|
+
label: btn?.label ?? undefined,
|
|
51
|
+
linkType: Utils.formatLinkType(btn?.linkType),
|
|
52
|
+
url: (() => {
|
|
53
|
+
if (btn.linkValue &&
|
|
54
|
+
typeof btn.linkValue === 'string') {
|
|
55
|
+
const trimmedValue = btn.linkValue?.charAt(btn.linkValue?.length - 1) === '/'
|
|
56
|
+
? btn.linkValue?.slice(0, -1)
|
|
57
|
+
: btn.linkValue;
|
|
58
|
+
if (/^\+?[0-9]+$/.test(trimmedValue)) {
|
|
59
|
+
// Es un teléfono
|
|
60
|
+
return trimmedValue.startsWith('tel:')
|
|
61
|
+
? trimmedValue
|
|
62
|
+
: `tel:${trimmedValue}`;
|
|
63
|
+
}
|
|
64
|
+
else if (/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(trimmedValue)) {
|
|
65
|
+
// Es un correo
|
|
66
|
+
return trimmedValue.startsWith('mailto:')
|
|
67
|
+
? trimmedValue
|
|
68
|
+
: `mailto:${trimmedValue}`;
|
|
69
|
+
}
|
|
70
|
+
return trimmedValue;
|
|
62
71
|
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
}
|
|
69
|
-
return trimmedValue;
|
|
70
|
-
}
|
|
71
|
-
return undefined;
|
|
72
|
-
})(),
|
|
73
|
-
icon: btn.icon ? btn?.icon : undefined,
|
|
74
|
-
}));
|
|
72
|
+
return undefined;
|
|
73
|
+
})(),
|
|
74
|
+
icon: btn.icon ? btn?.icon : undefined,
|
|
75
|
+
}
|
|
76
|
+
: undefined);
|
|
75
77
|
}
|
|
76
78
|
else {
|
|
77
79
|
return [];
|
|
78
80
|
}
|
|
79
81
|
}
|
|
80
82
|
}
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../projects/babylon/src/lib/utils/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { BabylonButtonI, BodyComponent } from '../interfaces';\n\nexport class Utils {\n    // Función para convertir una cadena de snake_case a camelCase\n    static snakeToCamel(snake: string): string {\n        return snake.replace(/(_\\w)/g, (matches) => matches[1].toUpperCase());\n    }\n\n    // Función para convertir las propiedades de un objeto de snake_case a camelCase\n    static convertObjectKeysToCamelCase(obj: any): any {\n        if (Array.isArray(obj)) {\n            return obj.map((item) => this.convertObjectKeysToCamelCase(item));\n        } else if (obj !== null && obj.constructor === Object) {\n            return Object.keys(obj).reduce((result, key) => {\n                const camelKey = this.snakeToCamel(key);\n                result[camelKey] = this.convertObjectKeysToCamelCase(obj[key]);\n                return result;\n            }, {} as any);\n        }\n        return obj;\n    }\n\n    static formatLinkType(linkType: string): string | undefined {\n        return linkType === 'external_link' || linkType === 'external'\n            ? 'external'\n            : linkType === 'internal_link' || linkType === 'internal'\n              ? 'internal'\n              : linkType;\n    }\n\n    static findComponent<T>(\n        body: BodyComponent<T>[],\n        name: string\n    ): T | undefined {\n        return body.find((component) => component?.name?.toLowerCase() === name)\n            ?.props;\n    }\n\n    static convertToBase64(file: File): Promise<string> {\n        return new Promise<string>((resolve, reject) => {\n            const reader = new FileReader();\n            reader.readAsDataURL(file);\n            reader.onload = () => resolve(reader.result as string);\n            reader.onerror = (error) => reject(error);\n        });\n    }\n\n    static normalizeText(text: string): string {\n        return text\n            ?.normalize('NFD') // Descompone los caracteres con acentos\n            ?.replace(/[\\u0300-\\u036f]/g, '') // Elimina los acentos\n            ?.toLowerCase();\n    }\n\n    static mapButtons(\n        button: any | any[] | undefined | null,\n        buttonType?: string\n    ): (BabylonButtonI | undefined)[] {\n        if (Array.isArray(button)) {\n            return button?.map((btn) =>\n                btn.label?.length\n                    ? ({\n                        type: buttonType ?? undefined,\n                        label: btn?.label ?? undefined,\n                        linkType: Utils.formatLinkType(btn?.linkType),\n                        url: (() => {\n                            if (\n                                btn.linkValue &&\n                                typeof btn.linkValue === 'string'\n                            ) {\n                                const trimmedValue =\n                                    btn.linkValue?.charAt(\n                                        btn.linkValue?.length - 1\n                                    ) === '/'\n                                        ? btn.linkValue?.slice(0, -1)\n                                        : btn.linkValue;\n\n                                if (/^\\+?[0-9]+$/.test(trimmedValue)) {\n                                    // Es un teléfono\n                                    return trimmedValue.startsWith('tel:')\n                                        ? trimmedValue\n                                        : `tel:${trimmedValue}`;\n                                } else if (\n                                    /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(\n                                        trimmedValue\n                                    )\n                                ) {\n                                    // Es un correo\n                                    return trimmedValue.startsWith('mailto:')\n                                        ? trimmedValue\n                                        : `mailto:${trimmedValue}`;\n                                }\n\n                                return trimmedValue;\n                            }\n                            return undefined;\n                        })(),\n                        icon: btn.icon ? btn?.icon : undefined,\n                    } as BabylonButtonI)\n                : undefined\n            );\n        } else {\n            return [];\n        }\n    }\n}\n"]}
|
package/fesm2022/ctt-babylon.mjs
CHANGED
|
@@ -1592,12 +1592,19 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1592
1592
|
}] } });
|
|
1593
1593
|
|
|
1594
1594
|
class BabylonFooterLogosComponent {
|
|
1595
|
+
get filteredButtons() {
|
|
1596
|
+
return (this.buttons || []).filter(b => !!b);
|
|
1597
|
+
}
|
|
1598
|
+
hasContent() {
|
|
1599
|
+
return ((this.texts && (this.texts.title || this.texts.subtitle || this.texts.description)) ||
|
|
1600
|
+
this.filteredButtons.length);
|
|
1601
|
+
}
|
|
1595
1602
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonFooterLogosComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1596
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BabylonFooterLogosComponent, isStandalone: true, selector: "lib-babylon-footer-logos", inputs: { logos: "logos", texts: "texts", buttons: "buttons" }, ngImport: i0, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (
|
|
1603
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BabylonFooterLogosComponent, isStandalone: true, selector: "lib-babylon-footer-logos", inputs: { logos: "logos", texts: "texts", buttons: "buttons" }, ngImport: i0, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (hasContent()) {\n <div class=\"intro_info align--center no-align pt--30\">\n @if (texts?.title) {\n <h1 class=\"title--small mb--10\">{{ texts?.title }}</h1>\n }\n @if (texts?.subtitle) {\n <h2 class=\"title\">{{ texts?.subtitle }}</h2>\n }\n @if (texts?.description) {\n <p class=\"text mb--10\">\n {{ texts?.description }}\n </p>\n }\n @if (buttons?.length) {\n <div class=\"btns__box align--center\">\n @for (button of buttons; track $index) {\n @if (button) {\n <div>\n <a [href]=\"button?.url\" [linkType]=\"button?.linkType\" class=\"btn btn_primary\"><b>{{ button?.label\n }}</b><span class=\"babylon-arrow-right-big\"></span></a>\n </div>\n }\n }\n </div>\n }\n </div>\n }\n @if (logos) {\n <ul>\n @for (logo of logos; track $index) {\n <li>\n @if (logo.link) {\n <a [href]=\"logo.link.url\" [linkType]=\"logo.link.linkType\" aria-label=\"link\">\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" /></a>\n } @else {\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" />\n }\n </li>\n }\n </ul>\n }\n </div>\n</section>", styles: [".babylon__footer-logos{background-color:var(--cl_footer-bg-logos)}.babylon__footer-logos ul{display:flex;gap:30px 20px;padding-block:30px;align-items:center;justify-content:space-around;flex-wrap:wrap}.babylon__footer-logos img{width:200px;height:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: BabylonLinkTypeDirective, selector: "[linkType]", inputs: ["linkType", "href"], outputs: ["anchorClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
1597
1604
|
}
|
|
1598
1605
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BabylonFooterLogosComponent, decorators: [{
|
|
1599
1606
|
type: Component,
|
|
1600
|
-
args: [{ selector: 'lib-babylon-footer-logos', standalone: true, imports: [CommonModule, BabylonLinkTypeDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (
|
|
1607
|
+
args: [{ selector: 'lib-babylon-footer-logos', standalone: true, imports: [CommonModule, BabylonLinkTypeDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<section class=\"babylon__footer-logos\">\n <div class=\"container\">\n @if (hasContent()) {\n <div class=\"intro_info align--center no-align pt--30\">\n @if (texts?.title) {\n <h1 class=\"title--small mb--10\">{{ texts?.title }}</h1>\n }\n @if (texts?.subtitle) {\n <h2 class=\"title\">{{ texts?.subtitle }}</h2>\n }\n @if (texts?.description) {\n <p class=\"text mb--10\">\n {{ texts?.description }}\n </p>\n }\n @if (buttons?.length) {\n <div class=\"btns__box align--center\">\n @for (button of buttons; track $index) {\n @if (button) {\n <div>\n <a [href]=\"button?.url\" [linkType]=\"button?.linkType\" class=\"btn btn_primary\"><b>{{ button?.label\n }}</b><span class=\"babylon-arrow-right-big\"></span></a>\n </div>\n }\n }\n </div>\n }\n </div>\n }\n @if (logos) {\n <ul>\n @for (logo of logos; track $index) {\n <li>\n @if (logo.link) {\n <a [href]=\"logo.link.url\" [linkType]=\"logo.link.linkType\" aria-label=\"link\">\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" /></a>\n } @else {\n <img [src]=\"logo.img?.src\" [alt]=\"logo.img?.alt\" />\n }\n </li>\n }\n </ul>\n }\n </div>\n</section>", styles: [".babylon__footer-logos{background-color:var(--cl_footer-bg-logos)}.babylon__footer-logos ul{display:flex;gap:30px 20px;padding-block:30px;align-items:center;justify-content:space-around;flex-wrap:wrap}.babylon__footer-logos img{width:200px;height:auto}\n"] }]
|
|
1601
1608
|
}], propDecorators: { logos: [{
|
|
1602
1609
|
type: Input
|
|
1603
1610
|
}], texts: [{
|
|
@@ -1937,34 +1944,36 @@ class Utils {
|
|
|
1937
1944
|
}
|
|
1938
1945
|
static mapButtons(button, buttonType) {
|
|
1939
1946
|
if (Array.isArray(button)) {
|
|
1940
|
-
return button?.map((btn) =>
|
|
1941
|
-
|
|
1942
|
-
|
|
1943
|
-
|
|
1944
|
-
|
|
1945
|
-
|
|
1946
|
-
|
|
1947
|
-
|
|
1948
|
-
|
|
1949
|
-
|
|
1950
|
-
|
|
1951
|
-
|
|
1952
|
-
|
|
1953
|
-
|
|
1954
|
-
|
|
1955
|
-
|
|
1956
|
-
|
|
1957
|
-
|
|
1958
|
-
|
|
1959
|
-
|
|
1960
|
-
|
|
1947
|
+
return button?.map((btn) => btn.label?.length
|
|
1948
|
+
? {
|
|
1949
|
+
type: buttonType ?? undefined,
|
|
1950
|
+
label: btn?.label ?? undefined,
|
|
1951
|
+
linkType: Utils.formatLinkType(btn?.linkType),
|
|
1952
|
+
url: (() => {
|
|
1953
|
+
if (btn.linkValue &&
|
|
1954
|
+
typeof btn.linkValue === 'string') {
|
|
1955
|
+
const trimmedValue = btn.linkValue?.charAt(btn.linkValue?.length - 1) === '/'
|
|
1956
|
+
? btn.linkValue?.slice(0, -1)
|
|
1957
|
+
: btn.linkValue;
|
|
1958
|
+
if (/^\+?[0-9]+$/.test(trimmedValue)) {
|
|
1959
|
+
// Es un teléfono
|
|
1960
|
+
return trimmedValue.startsWith('tel:')
|
|
1961
|
+
? trimmedValue
|
|
1962
|
+
: `tel:${trimmedValue}`;
|
|
1963
|
+
}
|
|
1964
|
+
else if (/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(trimmedValue)) {
|
|
1965
|
+
// Es un correo
|
|
1966
|
+
return trimmedValue.startsWith('mailto:')
|
|
1967
|
+
? trimmedValue
|
|
1968
|
+
: `mailto:${trimmedValue}`;
|
|
1969
|
+
}
|
|
1970
|
+
return trimmedValue;
|
|
1961
1971
|
}
|
|
1962
|
-
return
|
|
1963
|
-
}
|
|
1964
|
-
|
|
1965
|
-
}
|
|
1966
|
-
|
|
1967
|
-
}));
|
|
1972
|
+
return undefined;
|
|
1973
|
+
})(),
|
|
1974
|
+
icon: btn.icon ? btn?.icon : undefined,
|
|
1975
|
+
}
|
|
1976
|
+
: undefined);
|
|
1968
1977
|
}
|
|
1969
1978
|
else {
|
|
1970
1979
|
return [];
|