@rededor/site-front-end-lib 0.0.51 → 0.0.53
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/breadcrumbs/breadcrumbs.component.mjs +78 -12
- package/esm2022/lib/components/cta-wrapper/cta-wrapper.component.mjs +72 -0
- package/esm2022/lib/components/error/error-service/error.service.mjs +17 -0
- package/esm2022/lib/components/error/error.component.mjs +125 -0
- package/esm2022/lib/components/index.mjs +5 -1
- package/esm2022/lib/components/page-header/page-header.component.mjs +1 -1
- package/esm2022/lib/components/page-template-sidebar/page-template-sidebar.component.mjs +3 -3
- package/esm2022/lib/components/section-navigation/section-navigation.component.mjs +67 -0
- package/esm2022/lib/enums/EnumError.enum.mjs +6 -0
- package/esm2022/lib/enums/EnumThemes.enum.mjs +8 -0
- package/esm2022/lib/enums/index.mjs +3 -1
- package/esm2022/lib/helpers/mediaQueries.mjs +11 -0
- package/esm2022/lib/models/section-navigation.model.mjs +2 -0
- package/esm2022/lib/services/log/log.service.mjs +4 -1
- package/esm2022/lib/services/scroll-service/scroll-service.service.mjs +39 -0
- package/esm2022/lib/services/seo/seo.service.mjs +13 -1
- package/fesm2022/rededor-site-front-end-lib.mjs +460 -62
- package/fesm2022/rededor-site-front-end-lib.mjs.map +1 -1
- package/lib/components/breadcrumbs/breadcrumbs.component.d.ts +17 -4
- package/lib/components/cta-wrapper/cta-wrapper.component.d.ts +29 -0
- package/lib/components/error/error-service/error.service.d.ts +17 -0
- package/lib/components/error/error.component.d.ts +42 -0
- package/lib/components/index.d.ts +4 -0
- package/lib/components/section-navigation/section-navigation.component.d.ts +19 -0
- package/lib/enums/EnumError.enum.d.ts +4 -0
- package/lib/enums/EnumThemes.enum.d.ts +6 -0
- package/lib/enums/index.d.ts +2 -0
- package/lib/helpers/mediaQueries.d.ts +6 -0
- package/lib/models/section-navigation.model.d.ts +9 -0
- package/lib/services/log/log.service.d.ts +1 -0
- package/lib/services/scroll-service/scroll-service.service.d.ts +7 -0
- package/lib/services/seo/seo.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,30 +1,96 @@
|
|
|
1
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, HostBinding, Input } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, HostBinding, Inject, Input } from '@angular/core';
|
|
2
|
+
import { CommonModule, DOCUMENT } from '@angular/common';
|
|
3
3
|
import { RdsiteLinkDirective } from '../../directives';
|
|
4
|
+
import { LIB_CONFIG } from '../../tokens/LibConfig';
|
|
5
|
+
import * as he from 'he';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
import * as i1 from "../../services/cura/cura.service";
|
|
6
8
|
export class BreadcrumbsComponent {
|
|
7
|
-
|
|
9
|
+
set breadcrumbs(value) {
|
|
10
|
+
this._breadcrumbs = value || [];
|
|
11
|
+
if (value.length) {
|
|
12
|
+
this.setBreadcrumbsJson(value);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
get breadcrumbs() {
|
|
16
|
+
return this._breadcrumbs;
|
|
17
|
+
}
|
|
18
|
+
constructor(curaService, libConfig, document) {
|
|
8
19
|
this.curaService = curaService;
|
|
9
|
-
this.
|
|
20
|
+
this.libConfig = libConfig;
|
|
21
|
+
this.document = document;
|
|
22
|
+
this.fontColor = this.curaService.getColor('primary');
|
|
23
|
+
this._breadcrumbs = [];
|
|
24
|
+
this.breadcrumbsJsonTagId = 'breadcrumbsJSON';
|
|
10
25
|
this.style = {
|
|
11
|
-
'--font-
|
|
26
|
+
'--font-size': this.curaService.getFontSize(),
|
|
27
|
+
'--font-color': this.fontColor,
|
|
12
28
|
'--symbol-color': this.curaService.getColor('neutral-dark'),
|
|
13
29
|
};
|
|
14
30
|
}
|
|
15
|
-
|
|
16
|
-
return
|
|
31
|
+
getUrl(urls = []) {
|
|
32
|
+
return urls.join('');
|
|
33
|
+
}
|
|
34
|
+
setBreadcrumbsJson(items) {
|
|
35
|
+
this.breadcrumbsJsonTag = this.getBreadcrumbsJSONTag();
|
|
36
|
+
const json = {
|
|
37
|
+
'@context': 'http://schema.org',
|
|
38
|
+
'@type': 'BreadcrumbList',
|
|
39
|
+
itemListElement: this.getJsonBreadcrumbItems(items),
|
|
40
|
+
};
|
|
41
|
+
this.breadcrumbsJsonTag.innerHTML = JSON.stringify(json);
|
|
42
|
+
return this;
|
|
43
|
+
}
|
|
44
|
+
getBreadcrumbsJSONTag() {
|
|
45
|
+
const elements = this.document.head.children;
|
|
46
|
+
let i;
|
|
47
|
+
for (i = 0; i < elements.length; i++) {
|
|
48
|
+
const elem = elements[i];
|
|
49
|
+
if (elem && elem.id === this.breadcrumbsJsonTagId) {
|
|
50
|
+
return elem;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
return this.createBreadcrumbsJSONTag();
|
|
54
|
+
}
|
|
55
|
+
createBreadcrumbsJSONTag() {
|
|
56
|
+
const tag = this.document.createElement('script');
|
|
57
|
+
tag.id = this.breadcrumbsJsonTagId;
|
|
58
|
+
tag.type = 'application/ld+json';
|
|
59
|
+
this.document.head.appendChild(tag);
|
|
60
|
+
this.breadcrumbsJsonTag = tag;
|
|
61
|
+
return tag;
|
|
17
62
|
}
|
|
18
|
-
|
|
19
|
-
|
|
63
|
+
getJsonBreadcrumbItems(items) {
|
|
64
|
+
return items.map((item, i) => {
|
|
65
|
+
const jsonItem = {
|
|
66
|
+
'@type': 'ListItem',
|
|
67
|
+
position: i + 2,
|
|
68
|
+
item: {
|
|
69
|
+
'@id': `${this.libConfig.siteUrl.replace(/\/$/, '')}${this.getUrl(item.url)}`,
|
|
70
|
+
name: he.encode(item.label),
|
|
71
|
+
},
|
|
72
|
+
};
|
|
73
|
+
return jsonItem;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BreadcrumbsComponent, deps: [{ token: i1.CuraService }, { token: LIB_CONFIG }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: BreadcrumbsComponent, isStandalone: true, selector: "rdsite-breadcrumbs", inputs: { fontColor: "fontColor", breadcrumbs: "breadcrumbs" }, host: { properties: { "style": "this.style" } }, ngImport: i0, template: "@if (breadcrumbs.length) {\n <nav class=\"breadcrumbs\" aria-label=\"breadcrumbs\">\n <ul>\n @for (item of breadcrumbs; track item.label; let i = $index; let last = $last; let first = $first) {\n <li>\n @if (item.url) {\n <a [href]=\"item.url\" rdsitelink [class.last]=\"last\">\n @if (first && item.icon) {\n <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n }\n {{ item.label }}\n </a>\n } @else {\n @if (first && item.icon) {\n <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n }\n <p [class.last]=\"last\">{{ item.label }}</p>\n }\n @if (!last && breadcrumbs.length > 1) {\n <span>/</span>\n }\n </li>\n }\n </ul>\n </nav>\n}\n", styles: [".breadcrumbs{padding-block:16px;margin:0}ul{display:flex;justify-content:start;align-items:center;gap:8px;margin:0;padding:0}li{display:flex;justify-content:center;align-items:center;margin:0;padding:0;font-size:var(--font-size);font-weight:500;color:var(--font-color)}.last{color:var(--symbol-color);text-decoration:none}li span{margin-left:8px;color:var(--symbol-color)}a{display:flex;justify-content:space-between;align-items:flex-end;gap:4px;text-align:center;padding:0;text-decoration:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:1px;text-underline-offset:auto;text-decoration-color:var(--font-color);font-size:12px;color:var(--font-color)}a:hover{text-decoration:none;transition:text-decoration .5s ease-in-out}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: RdsiteLinkDirective, selector: "[rdsitelink]", inputs: ["anchorAdjustment", "anchorExtraAdjustment", "phonemodal"] }] }); }
|
|
20
78
|
}
|
|
21
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BreadcrumbsComponent, decorators: [{
|
|
22
80
|
type: Component,
|
|
23
|
-
args: [{ selector: 'rdsite-breadcrumbs', standalone: true, imports: [CommonModule, RdsiteLinkDirective], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<nav class=\"breadcrumbs\" aria-label=\"breadcrumbs\">\n
|
|
24
|
-
}], ctorParameters: () => [{ type: i1.CuraService }
|
|
81
|
+
args: [{ selector: 'rdsite-breadcrumbs', standalone: true, imports: [CommonModule, RdsiteLinkDirective], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "@if (breadcrumbs.length) {\n <nav class=\"breadcrumbs\" aria-label=\"breadcrumbs\">\n <ul>\n @for (item of breadcrumbs; track item.label; let i = $index; let last = $last; let first = $first) {\n <li>\n @if (item.url) {\n <a [href]=\"item.url\" rdsitelink [class.last]=\"last\">\n @if (first && item.icon) {\n <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n }\n {{ item.label }}\n </a>\n } @else {\n @if (first && item.icon) {\n <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n }\n <p [class.last]=\"last\">{{ item.label }}</p>\n }\n @if (!last && breadcrumbs.length > 1) {\n <span>/</span>\n }\n </li>\n }\n </ul>\n </nav>\n}\n", styles: [".breadcrumbs{padding-block:16px;margin:0}ul{display:flex;justify-content:start;align-items:center;gap:8px;margin:0;padding:0}li{display:flex;justify-content:center;align-items:center;margin:0;padding:0;font-size:var(--font-size);font-weight:500;color:var(--font-color)}.last{color:var(--symbol-color);text-decoration:none}li span{margin-left:8px;color:var(--symbol-color)}a{display:flex;justify-content:space-between;align-items:flex-end;gap:4px;text-align:center;padding:0;text-decoration:underline;text-decoration-style:solid;text-decoration-skip-ink:none;text-decoration-thickness:1px;text-underline-offset:auto;text-decoration-color:var(--font-color);font-size:12px;color:var(--font-color)}a:hover{text-decoration:none;transition:text-decoration .5s ease-in-out}\n"] }]
|
|
82
|
+
}], ctorParameters: () => [{ type: i1.CuraService }, { type: undefined, decorators: [{
|
|
83
|
+
type: Inject,
|
|
84
|
+
args: [LIB_CONFIG]
|
|
85
|
+
}] }, { type: Document, decorators: [{
|
|
86
|
+
type: Inject,
|
|
87
|
+
args: [DOCUMENT]
|
|
88
|
+
}] }], propDecorators: { fontColor: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], breadcrumbs: [{
|
|
25
91
|
type: Input
|
|
26
92
|
}], style: [{
|
|
27
93
|
type: HostBinding,
|
|
28
94
|
args: ['style']
|
|
29
95
|
}] } });
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumbs.component.js","sourceRoot":"","sources":["../../../../../../projects/site-front-end-lib/src/lib/components/breadcrumbs/breadcrumbs.component.ts","../../../../../../projects/site-front-end-lib/src/lib/components/breadcrumbs/breadcrumbs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, CUSTOM_ELEMENTS_SCHEMA, HostBinding, Inject, Input } from '@angular/core';\nimport { CommonModule, DOCUMENT } from '@angular/common';\nimport { BreadcrumbsItems } from '../../models/breadcrumbs/breadcrumbs-items.model';\nimport { CuraService } from '../../services/cura/cura.service';\nimport { RdsiteLinkDirective } from '../../directives';\nimport { BreadcrumbsJsonItem } from '../../models/breadcrumbs/breadcrumbs-json-item.model';\nimport { LIB_CONFIG, LibConfig } from '../../tokens/LibConfig';\nimport * as he from 'he';\n\n@Component({\n  selector: 'rdsite-breadcrumbs',\n  standalone: true,\n  imports: [CommonModule, RdsiteLinkDirective],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  templateUrl: './breadcrumbs.component.html',\n  styleUrl: './breadcrumbs.component.scss',\n})\nexport class BreadcrumbsComponent {\n  @Input() fontColor = this.curaService.getColor('primary');\n\n  private _breadcrumbs: BreadcrumbsItems[] = [];\n  @Input()\n  set breadcrumbs(value: BreadcrumbsItems[]) {\n    this._breadcrumbs = value || [];\n    if (value.length) {\n      this.setBreadcrumbsJson(value);\n    }\n  }\n  get breadcrumbs() {\n    return this._breadcrumbs;\n  }\n\n  private breadcrumbsJsonTag!: HTMLScriptElement;\n  private breadcrumbsJsonTagId = 'breadcrumbsJSON';\n\n  @HostBinding('style') style = {\n    '--font-size': this.curaService.getFontSize(),\n    '--font-color': this.fontColor,\n    '--symbol-color': this.curaService.getColor('neutral-dark'),\n  };\n\n  constructor(\n    private curaService: CuraService,\n    @Inject(LIB_CONFIG) private libConfig: LibConfig,\n    @Inject(DOCUMENT) private document: Document,\n  ) {}\n\n  getUrl(urls: string[] = []) {\n    return urls.join('');\n  }\n\n  private setBreadcrumbsJson(items: BreadcrumbsItems[]) {\n    this.breadcrumbsJsonTag = this.getBreadcrumbsJSONTag();\n    const json = {\n      '@context': 'http://schema.org',\n      '@type': 'BreadcrumbList',\n      itemListElement: this.getJsonBreadcrumbItems(items),\n    };\n    this.breadcrumbsJsonTag.innerHTML = JSON.stringify(json);\n    return this;\n  }\n\n  private getBreadcrumbsJSONTag(): HTMLScriptElement {\n    const elements = this.document.head.children;\n    let i: number;\n    for (i = 0; i < elements.length; i++) {\n      const elem = elements[i] as HTMLScriptElement;\n      if (elem && elem.id === this.breadcrumbsJsonTagId) {\n        return elem;\n      }\n    }\n    return this.createBreadcrumbsJSONTag();\n  }\n\n  private createBreadcrumbsJSONTag(): HTMLScriptElement {\n    const tag: HTMLScriptElement = this.document.createElement('script');\n    tag.id = this.breadcrumbsJsonTagId;\n    tag.type = 'application/ld+json';\n    this.document.head.appendChild(tag);\n    this.breadcrumbsJsonTag = tag;\n    return tag;\n  }\n\n  private getJsonBreadcrumbItems(items: BreadcrumbsItems[]): BreadcrumbsJsonItem[] {\n    return items.map((item, i) => {\n      const jsonItem: BreadcrumbsJsonItem = {\n        '@type': 'ListItem',\n        position: i + 2,\n        item: {\n          '@id': `${this.libConfig.siteUrl.replace(/\\/$/, '')}${this.getUrl(item.url)}`,\n          name: he.encode(item.label),\n        },\n      };\n      return jsonItem;\n    });\n  }\n}\n","@if (breadcrumbs.length) {\n  <nav class=\"breadcrumbs\" aria-label=\"breadcrumbs\">\n    <ul>\n      @for (item of breadcrumbs; track item.label; let i = $index; let last = $last; let first = $first) {\n        <li>\n          @if (item.url) {\n            <a [href]=\"item.url\" rdsitelink [class.last]=\"last\">\n              @if (first && item.icon) {\n                <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n              }\n              {{ item.label }}\n            </a>\n          } @else {\n            @if (first && item.icon) {\n              <cura-icon [name]=\"item.icon\" [color]=\"item.iconColor\" [size]=\"item.iconSize\" [disabled]=\"item.iconDisabled\"> </cura-icon>\n            }\n            <p [class.last]=\"last\">{{ item.label }}</p>\n          }\n          @if (!last && breadcrumbs.length > 1) {\n            <span>/</span>\n          }\n        </li>\n      }\n    </ul>\n  </nav>\n}\n"]}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component, HostBinding, HostListener, Inject, Input, PLATFORM_ID, ViewChild } from '@angular/core';
|
|
3
|
+
import { NguCarousel, NguCarouselDefDirective, NguItemComponent } from '@ngu/carousel';
|
|
4
|
+
import { MediaQueries } from '../../helpers/mediaQueries';
|
|
5
|
+
import { RdsiteLinkDirective } from '../../directives';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../services";
|
|
8
|
+
export class CtaWrapperComponent {
|
|
9
|
+
onWindowResize() {
|
|
10
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
11
|
+
this.bannerControl = window.innerWidth > MediaQueries.smallBreakpoint;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
constructor(curaService, nguService, platformId) {
|
|
15
|
+
this.curaService = curaService;
|
|
16
|
+
this.nguService = nguService;
|
|
17
|
+
this.platformId = platformId;
|
|
18
|
+
this.colors = {
|
|
19
|
+
border: 'primary-darker',
|
|
20
|
+
icon: 'primary-darker',
|
|
21
|
+
};
|
|
22
|
+
this.seeMoreControl = false;
|
|
23
|
+
this.styleBinding = {
|
|
24
|
+
'--more-options-color': this.curaService.getColor(this.colors.icon),
|
|
25
|
+
'--border-color': this.curaService.getColor(this.colors.border),
|
|
26
|
+
'--label-color': this.curaService.getColor(this.colors.icon),
|
|
27
|
+
};
|
|
28
|
+
this.class = true;
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
32
|
+
this.bannerControl = window.innerWidth > MediaQueries.smallBreakpoint;
|
|
33
|
+
}
|
|
34
|
+
this.carouselCtasConfig = this.nguService.customCarouselConfig({
|
|
35
|
+
grid: { xs: 2.1, sm: 2.1, md: 2.1, lg: 2.1, all: 0 },
|
|
36
|
+
loop: true,
|
|
37
|
+
interval: {
|
|
38
|
+
timing: 600000,
|
|
39
|
+
initialDelay: 600000,
|
|
40
|
+
},
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
moreOptions() {
|
|
44
|
+
this.seeMoreControl = !this.seeMoreControl;
|
|
45
|
+
}
|
|
46
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CtaWrapperComponent, deps: [{ token: i1.CuraService }, { token: i1.NguCarouselService }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: CtaWrapperComponent, isStandalone: true, selector: "rdsite-cta-wrapper", inputs: { ctas: "ctas", colors: "colors" }, host: { listeners: { "window:resize": "onWindowResize()" }, properties: { "style": "this.styleBinding", "class.wp-content-wrapper": "this.class" } }, viewQueries: [{ propertyName: "nguCarouselCtas", first: true, predicate: ["nguCarouselCtas"], descendants: true }], ngImport: i0, template: "@if (!seeMoreControl) {\n @if (!bannerControl) {\n <ngu-carousel #nguCarouselCtas [inputs]=\"carouselCtasConfig\" [dataSource]=\"ctas\">\n <ngu-item *nguCarouselDef=\"let cta; let i = index\">\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n </ngu-item>\n </ngu-carousel>\n @if (ctas.length > 3) {\n <div class=\"show-more\">\n <button type=\"button\" (click)=\"moreOptions()\">Mais op\u00E7\u00F5es</button>\n </div>\n }\n } @else {\n @for (cta of ctas; track cta) {\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n }\n }\n}\n@if (seeMoreControl) {\n <div class=\"more-options\">\n @for (cta of ctas; track cta) {\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n }\n </div>\n}\n", styles: [":host{display:flex;flex-wrap:wrap;gap:16px}:host ngu-carousel{max-width:100vw}:host ngu-item a{margin-right:16px}:host .show-more{display:flex;justify-content:flex-end;width:100%;height:auto}:host .show-more button{color:var(--more-options-color);background-color:transparent;font-size:16px;font-weight:500;line-height:145%;letter-spacing:.32px;text-decoration-line:underline;text-align:center}.more-options{display:flex;flex-wrap:wrap;gap:16px}.more-options .cta{height:auto}.cta{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-width:150px;height:100%;min-height:150px;padding:24px 16px;border-radius:4px;border:1px solid var(--border-color);text-decoration:none}.cta p{color:var(--label-color);font-size:12px;font-weight:700;line-height:145%;letter-spacing:.32px;padding:0;margin:0;text-align:center}\n"], dependencies: [{ kind: "component", type: NguCarousel, selector: "ngu-carousel", inputs: ["inputs", "dataSource", "trackBy"], outputs: ["carouselLoad", "onMove"] }, { kind: "component", type: NguItemComponent, selector: "ngu-item" }, { kind: "directive", type: NguCarouselDefDirective, selector: "[nguCarouselDef]" }, { kind: "directive", type: RdsiteLinkDirective, selector: "[rdsitelink]", inputs: ["anchorAdjustment", "anchorExtraAdjustment", "phonemodal"] }] }); }
|
|
48
|
+
}
|
|
49
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CtaWrapperComponent, decorators: [{
|
|
50
|
+
type: Component,
|
|
51
|
+
args: [{ selector: 'rdsite-cta-wrapper', standalone: true, imports: [NguCarousel, NguItemComponent, NguCarouselDefDirective, RdsiteLinkDirective], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "@if (!seeMoreControl) {\n @if (!bannerControl) {\n <ngu-carousel #nguCarouselCtas [inputs]=\"carouselCtasConfig\" [dataSource]=\"ctas\">\n <ngu-item *nguCarouselDef=\"let cta; let i = index\">\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n </ngu-item>\n </ngu-carousel>\n @if (ctas.length > 3) {\n <div class=\"show-more\">\n <button type=\"button\" (click)=\"moreOptions()\">Mais op\u00E7\u00F5es</button>\n </div>\n }\n } @else {\n @for (cta of ctas; track cta) {\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n }\n }\n}\n@if (seeMoreControl) {\n <div class=\"more-options\">\n @for (cta of ctas; track cta) {\n <a rdsitelink class=\"cta\" [href]=\"cta?.link\">\n @if (cta?.icon) {\n <cura-icon [attr.name]=\"cta?.icon\" size=\"24\" [color]=\"colors.icon\"></cura-icon>\n }\n <p>{{ cta?.label }}</p>\n </a>\n }\n </div>\n}\n", styles: [":host{display:flex;flex-wrap:wrap;gap:16px}:host ngu-carousel{max-width:100vw}:host ngu-item a{margin-right:16px}:host .show-more{display:flex;justify-content:flex-end;width:100%;height:auto}:host .show-more button{color:var(--more-options-color);background-color:transparent;font-size:16px;font-weight:500;line-height:145%;letter-spacing:.32px;text-decoration-line:underline;text-align:center}.more-options{display:flex;flex-wrap:wrap;gap:16px}.more-options .cta{height:auto}.cta{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-width:150px;height:100%;min-height:150px;padding:24px 16px;border-radius:4px;border:1px solid var(--border-color);text-decoration:none}.cta p{color:var(--label-color);font-size:12px;font-weight:700;line-height:145%;letter-spacing:.32px;padding:0;margin:0;text-align:center}\n"] }]
|
|
52
|
+
}], ctorParameters: () => [{ type: i1.CuraService }, { type: i1.NguCarouselService }, { type: undefined, decorators: [{
|
|
53
|
+
type: Inject,
|
|
54
|
+
args: [PLATFORM_ID]
|
|
55
|
+
}] }], propDecorators: { ctas: [{
|
|
56
|
+
type: Input
|
|
57
|
+
}], colors: [{
|
|
58
|
+
type: Input
|
|
59
|
+
}], nguCarouselCtas: [{
|
|
60
|
+
type: ViewChild,
|
|
61
|
+
args: ['nguCarouselCtas']
|
|
62
|
+
}], onWindowResize: [{
|
|
63
|
+
type: HostListener,
|
|
64
|
+
args: ['window:resize']
|
|
65
|
+
}], styleBinding: [{
|
|
66
|
+
type: HostBinding,
|
|
67
|
+
args: ['style']
|
|
68
|
+
}], class: [{
|
|
69
|
+
type: HostBinding,
|
|
70
|
+
args: ['class.wp-content-wrapper']
|
|
71
|
+
}] } });
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3RhLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2l0ZS1mcm9udC1lbmQtbGliL3NyYy9saWIvY29tcG9uZW50cy9jdGEtd3JhcHBlci9jdGEtd3JhcHBlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaXRlLWZyb250LWVuZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2N0YS13cmFwcGVyL2N0YS13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDcEksT0FBTyxFQUFFLFdBQVcsRUFBcUIsdUJBQXVCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzFELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7QUFVdkQsTUFBTSxPQUFPLG1CQUFtQjtJQWU5QixjQUFjO1FBQ1osSUFBSSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsQ0FBQztZQUN2QyxJQUFJLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FBQyxVQUFVLEdBQUcsWUFBWSxDQUFDLGVBQWUsQ0FBQztRQUN4RSxDQUFDO0lBQ0gsQ0FBQztJQVVELFlBQ21CLFdBQXdCLEVBQ2pDLFVBQThCLEVBQ0EsVUFBa0I7UUFGdkMsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFDakMsZUFBVSxHQUFWLFVBQVUsQ0FBb0I7UUFDQSxlQUFVLEdBQVYsVUFBVSxDQUFRO1FBOUJqRCxXQUFNLEdBQUc7WUFDaEIsTUFBTSxFQUFFLGdCQUFnQjtZQUN4QixJQUFJLEVBQUUsZ0JBQWdCO1NBQ3ZCLENBQUM7UUFLRixtQkFBYyxHQUFHLEtBQUssQ0FBQztRQVdELGlCQUFZLEdBQUc7WUFDbkMsc0JBQXNCLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7WUFDbkUsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUM7WUFDL0QsZUFBZSxFQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO1NBQzdELENBQUM7UUFFdUMsVUFBSyxHQUFHLElBQUksQ0FBQztJQU1uRCxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDdkMsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUMsVUFBVSxHQUFHLFlBQVksQ0FBQyxlQUFlLENBQUM7UUFDeEUsQ0FBQztRQUVELElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLG9CQUFvQixDQUFDO1lBQzdELElBQUksRUFBRSxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsRUFBRSxFQUFFLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxFQUFFLEVBQUUsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRTtZQUNwRCxJQUFJLEVBQUUsSUFBSTtZQUNWLFFBQVEsRUFBRTtnQkFDUixNQUFNLEVBQUUsTUFBTTtnQkFDZCxZQUFZLEVBQUUsTUFBTTthQUNyQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGNBQWMsR0FBRyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0MsQ0FBQzsrR0FwRFUsbUJBQW1CLCtFQWdDcEIsV0FBVzttR0FoQ1YsbUJBQW1CLG9ZQ2ZoQyx1eUNBd0NBLCs0QkQ5QlksV0FBVywySUFBRSxnQkFBZ0IscURBQUUsdUJBQXVCLDZEQUFFLG1CQUFtQjs7NEZBSzFFLG1CQUFtQjtrQkFSL0IsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLENBQUMsV0FBVyxFQUFFLGdCQUFnQixFQUFFLHVCQUF1QixFQUFFLG1CQUFtQixDQUFDLFdBQzdFLENBQUMsc0JBQXNCLENBQUM7OzBCQW9DOUIsTUFBTTsyQkFBQyxXQUFXO3lDQS9CWixJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQVV3QixlQUFlO3NCQUE1QyxTQUFTO3VCQUFDLGlCQUFpQjtnQkFHNUIsY0FBYztzQkFEYixZQUFZO3VCQUFDLGVBQWU7Z0JBT1AsWUFBWTtzQkFBakMsV0FBVzt1QkFBQyxPQUFPO2dCQU1xQixLQUFLO3NCQUE3QyxXQUFXO3VCQUFDLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIEhvc3RMaXN0ZW5lciwgSW5qZWN0LCBJbnB1dCwgUExBVEZPUk1fSUQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTmd1Q2Fyb3VzZWwsIE5ndUNhcm91c2VsQ29uZmlnLCBOZ3VDYXJvdXNlbERlZkRpcmVjdGl2ZSwgTmd1SXRlbUNvbXBvbmVudCB9IGZyb20gJ0BuZ3UvY2Fyb3VzZWwnO1xuaW1wb3J0IHsgQ3VyYVNlcnZpY2UsIE5ndUNhcm91c2VsU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzJztcbmltcG9ydCB7IE1lZGlhUXVlcmllcyB9IGZyb20gJy4uLy4uL2hlbHBlcnMvbWVkaWFRdWVyaWVzJztcbmltcG9ydCB7IFJkc2l0ZUxpbmtEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncmRzaXRlLWN0YS13cmFwcGVyJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW05ndUNhcm91c2VsLCBOZ3VJdGVtQ29tcG9uZW50LCBOZ3VDYXJvdXNlbERlZkRpcmVjdGl2ZSwgUmRzaXRlTGlua0RpcmVjdGl2ZV0sXG4gIHNjaGVtYXM6IFtDVVNUT01fRUxFTUVOVFNfU0NIRU1BXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2N0YS13cmFwcGVyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL2N0YS13cmFwcGVyLmNvbXBvbmVudC5zY3NzJyxcbn0pXG5leHBvcnQgY2xhc3MgQ3RhV3JhcHBlckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIGN0YXM6IGFueTtcbiAgQElucHV0KCkgY29sb3JzID0ge1xuICAgIGJvcmRlcjogJ3ByaW1hcnktZGFya2VyJyxcbiAgICBpY29uOiAncHJpbWFyeS1kYXJrZXInLFxuICB9O1xuXG4gIGNhcm91c2VsQ3Rhc0NvbmZpZyE6IE5ndUNhcm91c2VsQ29uZmlnO1xuXG4gIGJhbm5lckNvbnRyb2whOiBib29sZWFuO1xuICBzZWVNb3JlQ29udHJvbCA9IGZhbHNlO1xuXG4gIEBWaWV3Q2hpbGQoJ25ndUNhcm91c2VsQ3RhcycpIG5ndUNhcm91c2VsQ3RhcyE6IE5ndUNhcm91c2VsPGFueSwgYW55PjtcblxuICBASG9zdExpc3RlbmVyKCd3aW5kb3c6cmVzaXplJylcbiAgb25XaW5kb3dSZXNpemUoKSB7XG4gICAgaWYgKGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcbiAgICAgIHRoaXMuYmFubmVyQ29udHJvbCA9IHdpbmRvdy5pbm5lcldpZHRoID4gTWVkaWFRdWVyaWVzLnNtYWxsQnJlYWtwb2ludDtcbiAgICB9XG4gIH1cblxuICBASG9zdEJpbmRpbmcoJ3N0eWxlJykgc3R5bGVCaW5kaW5nID0ge1xuICAgICctLW1vcmUtb3B0aW9ucy1jb2xvcic6IHRoaXMuY3VyYVNlcnZpY2UuZ2V0Q29sb3IodGhpcy5jb2xvcnMuaWNvbiksXG4gICAgJy0tYm9yZGVyLWNvbG9yJzogdGhpcy5jdXJhU2VydmljZS5nZXRDb2xvcih0aGlzLmNvbG9ycy5ib3JkZXIpLFxuICAgICctLWxhYmVsLWNvbG9yJzogdGhpcy5jdXJhU2VydmljZS5nZXRDb2xvcih0aGlzLmNvbG9ycy5pY29uKSxcbiAgfTtcblxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLndwLWNvbnRlbnQtd3JhcHBlcicpIGNsYXNzID0gdHJ1ZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IGN1cmFTZXJ2aWNlOiBDdXJhU2VydmljZSxcbiAgICBwcml2YXRlIG5ndVNlcnZpY2U6IE5ndUNhcm91c2VsU2VydmljZSxcbiAgICBASW5qZWN0KFBMQVRGT1JNX0lEKSBwcml2YXRlIHJlYWRvbmx5IHBsYXRmb3JtSWQ6IG9iamVjdCxcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmIChpc1BsYXRmb3JtQnJvd3Nlcih0aGlzLnBsYXRmb3JtSWQpKSB7XG4gICAgICB0aGlzLmJhbm5lckNvbnRyb2wgPSB3aW5kb3cuaW5uZXJXaWR0aCA+IE1lZGlhUXVlcmllcy5zbWFsbEJyZWFrcG9pbnQ7XG4gICAgfVxuXG4gICAgdGhpcy5jYXJvdXNlbEN0YXNDb25maWcgPSB0aGlzLm5ndVNlcnZpY2UuY3VzdG9tQ2Fyb3VzZWxDb25maWcoe1xuICAgICAgZ3JpZDogeyB4czogMi4xLCBzbTogMi4xLCBtZDogMi4xLCBsZzogMi4xLCBhbGw6IDAgfSxcbiAgICAgIGxvb3A6IHRydWUsXG4gICAgICBpbnRlcnZhbDoge1xuICAgICAgICB0aW1pbmc6IDYwMDAwMCxcbiAgICAgICAgaW5pdGlhbERlbGF5OiA2MDAwMDAsXG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgbW9yZU9wdGlvbnMoKTogdm9pZCB7XG4gICAgdGhpcy5zZWVNb3JlQ29udHJvbCA9ICF0aGlzLnNlZU1vcmVDb250cm9sO1xuICB9XG59XG4iLCJAaWYgKCFzZWVNb3JlQ29udHJvbCkge1xuICBAaWYgKCFiYW5uZXJDb250cm9sKSB7XG4gICAgPG5ndS1jYXJvdXNlbCAjbmd1Q2Fyb3VzZWxDdGFzIFtpbnB1dHNdPVwiY2Fyb3VzZWxDdGFzQ29uZmlnXCIgW2RhdGFTb3VyY2VdPVwiY3Rhc1wiPlxuICAgICAgPG5ndS1pdGVtICpuZ3VDYXJvdXNlbERlZj1cImxldCBjdGE7IGxldCBpID0gaW5kZXhcIj5cbiAgICAgICAgPGEgcmRzaXRlbGluayBjbGFzcz1cImN0YVwiIFtocmVmXT1cImN0YT8ubGlua1wiPlxuICAgICAgICAgIEBpZiAoY3RhPy5pY29uKSB7XG4gICAgICAgICAgICA8Y3VyYS1pY29uIFthdHRyLm5hbWVdPVwiY3RhPy5pY29uXCIgc2l6ZT1cIjI0XCIgW2NvbG9yXT1cImNvbG9ycy5pY29uXCI+PC9jdXJhLWljb24+XG4gICAgICAgICAgfVxuICAgICAgICAgIDxwPnt7IGN0YT8ubGFiZWwgfX08L3A+XG4gICAgICAgIDwvYT5cbiAgICAgIDwvbmd1LWl0ZW0+XG4gICAgPC9uZ3UtY2Fyb3VzZWw+XG4gICAgQGlmIChjdGFzLmxlbmd0aCA+IDMpIHtcbiAgICAgIDxkaXYgY2xhc3M9XCJzaG93LW1vcmVcIj5cbiAgICAgICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgKGNsaWNrKT1cIm1vcmVPcHRpb25zKClcIj5NYWlzIG9ww6fDtWVzPC9idXR0b24+XG4gICAgICA8L2Rpdj5cbiAgICB9XG4gIH0gQGVsc2Uge1xuICAgIEBmb3IgKGN0YSBvZiBjdGFzOyB0cmFjayBjdGEpIHtcbiAgICAgIDxhIHJkc2l0ZWxpbmsgY2xhc3M9XCJjdGFcIiBbaHJlZl09XCJjdGE/LmxpbmtcIj5cbiAgICAgICAgQGlmIChjdGE/Lmljb24pIHtcbiAgICAgICAgICA8Y3VyYS1pY29uIFthdHRyLm5hbWVdPVwiY3RhPy5pY29uXCIgc2l6ZT1cIjI0XCIgW2NvbG9yXT1cImNvbG9ycy5pY29uXCI+PC9jdXJhLWljb24+XG4gICAgICAgIH1cbiAgICAgICAgPHA+e3sgY3RhPy5sYWJlbCB9fTwvcD5cbiAgICAgIDwvYT5cbiAgICB9XG4gIH1cbn1cbkBpZiAoc2VlTW9yZUNvbnRyb2wpIHtcbiAgPGRpdiBjbGFzcz1cIm1vcmUtb3B0aW9uc1wiPlxuICAgIEBmb3IgKGN0YSBvZiBjdGFzOyB0cmFjayBjdGEpIHtcbiAgICAgIDxhIHJkc2l0ZWxpbmsgY2xhc3M9XCJjdGFcIiBbaHJlZl09XCJjdGE/LmxpbmtcIj5cbiAgICAgICAgQGlmIChjdGE/Lmljb24pIHtcbiAgICAgICAgICA8Y3VyYS1pY29uIFthdHRyLm5hbWVdPVwiY3RhPy5pY29uXCIgc2l6ZT1cIjI0XCIgW2NvbG9yXT1cImNvbG9ycy5pY29uXCI+PC9jdXJhLWljb24+XG4gICAgICAgIH1cbiAgICAgICAgPHA+e3sgY3RhPy5sYWJlbCB9fTwvcD5cbiAgICAgIDwvYT5cbiAgICB9XG4gIDwvZGl2PlxufVxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ErrorService {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.ctas = new BehaviorSubject([]);
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ErrorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
9
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ErrorService, providedIn: 'root' }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ErrorService, decorators: [{
|
|
12
|
+
type: Injectable,
|
|
13
|
+
args: [{
|
|
14
|
+
providedIn: 'root',
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3Iuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpdGUtZnJvbnQtZW5kLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvZXJyb3IvZXJyb3Itc2VydmljZS9lcnJvci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFpQnZDLE1BQU0sT0FBTyxZQUFZO0lBSHpCO1FBSUUsU0FBSSxHQUFHLElBQUksZUFBZSxDQUFnQixFQUFFLENBQUMsQ0FBQztLQUMvQzsrR0FGWSxZQUFZO21IQUFaLFlBQVksY0FGWCxNQUFNOzs0RkFFUCxZQUFZO2tCQUh4QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIGN0YXM0MDRfNTAyIHtcbiAgbGFiZWw6IHN0cmluZztcbiAgbGluazogc3RyaW5nO1xuICBpY29uOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgY3Rhc0FyZWEge1xuICBsYWJlbDogc3RyaW5nO1xuICBsaW5rOiBzdHJpbmc7XG4gIGljb246IHN0cmluZztcbn1cblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIEVycm9yU2VydmljZSB7XG4gIGN0YXMgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGN0YXM0MDRfNTAyW10+KFtdKTtcbn1cbiJdfQ==
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { CUSTOM_ELEMENTS_SCHEMA, Component, Inject, Input, PLATFORM_ID, ViewChild } from '@angular/core';
|
|
2
|
+
import { CtaWrapperComponent } from '../cta-wrapper/cta-wrapper.component';
|
|
3
|
+
import { RdsiteLinkDirective } from '../../directives';
|
|
4
|
+
import { isPlatformServer } from '@angular/common';
|
|
5
|
+
import { BreadcrumbsComponent } from '../breadcrumbs/breadcrumbs.component';
|
|
6
|
+
import { Errors, Themes } from '../../enums';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./error-service/error.service";
|
|
9
|
+
import * as i2 from "../../services";
|
|
10
|
+
export class ErrorComponent {
|
|
11
|
+
constructor(errorService, curaService, logService, seoService, serverResponse, platformId) {
|
|
12
|
+
this.errorService = errorService;
|
|
13
|
+
this.curaService = curaService;
|
|
14
|
+
this.logService = logService;
|
|
15
|
+
this.seoService = seoService;
|
|
16
|
+
this.serverResponse = serverResponse;
|
|
17
|
+
this.platformId = platformId;
|
|
18
|
+
this.theme = Themes.REDE;
|
|
19
|
+
this.pageTitle = 'Default component';
|
|
20
|
+
this.component = 'DefaultComponent';
|
|
21
|
+
this.responseText = '';
|
|
22
|
+
this.error = Errors;
|
|
23
|
+
}
|
|
24
|
+
ngOnInit() {
|
|
25
|
+
if (this.type === Errors.NOT_FOUND) {
|
|
26
|
+
this.responseText = 'A página que você acessou não existe mais ou foi movida para outra URL';
|
|
27
|
+
if (isPlatformServer(this.platformId)) {
|
|
28
|
+
this.serverResponse.setNotFound();
|
|
29
|
+
}
|
|
30
|
+
this.logService.log404(this.component);
|
|
31
|
+
this.seoService.set404Title(this.pageTitle);
|
|
32
|
+
}
|
|
33
|
+
else if (this.type === Errors.SERVER_RESPONSE) {
|
|
34
|
+
this.responseText = 'Recomendamos atualizar a página ou tentar novamente mais tarde.';
|
|
35
|
+
if (isPlatformServer(this.platformId)) {
|
|
36
|
+
this.serverResponse.setError();
|
|
37
|
+
}
|
|
38
|
+
this.logService.log500(this.component);
|
|
39
|
+
this.seoService.set500Title(this.pageTitle);
|
|
40
|
+
}
|
|
41
|
+
this.ctasSubscription = this.errorService.ctas.subscribe((ctas) => {
|
|
42
|
+
this.ctas = ctas;
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
ngAfterViewInit() {
|
|
46
|
+
this.setTheme(this.theme);
|
|
47
|
+
}
|
|
48
|
+
setTheme(theme) {
|
|
49
|
+
switch (theme) {
|
|
50
|
+
case Themes.REDE:
|
|
51
|
+
this.backgroundColor = this.curaService.getColor('neutral-white') ?? '';
|
|
52
|
+
this.labelColor = this.curaService.getColor('primary-lighter') ?? '';
|
|
53
|
+
this.labelTextColor = 'primary-dark';
|
|
54
|
+
this.curaButtonColor = 'primary';
|
|
55
|
+
this.curaButtonOutlineColor = 'primary';
|
|
56
|
+
this.ctasBorderColor = 'primary-darker';
|
|
57
|
+
this.ctasIconColor = 'primary-darker';
|
|
58
|
+
break;
|
|
59
|
+
case Themes.ONCO:
|
|
60
|
+
this.backgroundColor = this.curaService.getColor('neutral-light') ?? '';
|
|
61
|
+
this.labelColor = this.curaService.getColor('auxiliar-lighter') ?? '';
|
|
62
|
+
this.labelTextColor = 'primary-lighter';
|
|
63
|
+
this.curaButtonColor = 'accent';
|
|
64
|
+
this.curaButtonOutlineColor = 'accent';
|
|
65
|
+
this.ctasBorderColor = 'accent-base';
|
|
66
|
+
this.ctasIconColor = 'primary-base';
|
|
67
|
+
break;
|
|
68
|
+
case Themes.MATERNIDADE:
|
|
69
|
+
this.backgroundColor = this.curaService.getColor('accent-lighter') ?? '';
|
|
70
|
+
this.labelColor = this.curaService.getColor('primary-light') ?? '';
|
|
71
|
+
this.labelTextColor = 'accent-base';
|
|
72
|
+
this.curaButtonColor = 'accent';
|
|
73
|
+
this.curaButtonOutlineColor = 'accent';
|
|
74
|
+
this.ctasBorderColor = 'accent-base';
|
|
75
|
+
this.ctasIconColor = 'accent-base';
|
|
76
|
+
break;
|
|
77
|
+
case Themes.RICHET:
|
|
78
|
+
this.backgroundColor = this.curaService.getColor('neutral-white') ?? '';
|
|
79
|
+
this.labelColor = this.curaService.getColor('primary-lighter') ?? '';
|
|
80
|
+
this.labelTextColor = 'primary-dark';
|
|
81
|
+
this.curaButtonColor = 'primary';
|
|
82
|
+
this.curaButtonOutlineColor = 'primary';
|
|
83
|
+
this.ctasBorderColor = 'primary-darker';
|
|
84
|
+
this.ctasIconColor = 'primary-darker';
|
|
85
|
+
break;
|
|
86
|
+
}
|
|
87
|
+
this.errorElement.nativeElement.style.setProperty('--backgroundColor', this.backgroundColor);
|
|
88
|
+
this.errorElement.nativeElement.style.setProperty('--labelColor', this.labelColor);
|
|
89
|
+
}
|
|
90
|
+
reloadPage() {
|
|
91
|
+
if (window !== undefined) {
|
|
92
|
+
window.location.reload();
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
ngOnDestroy() {
|
|
96
|
+
this.ctasSubscription?.unsubscribe();
|
|
97
|
+
}
|
|
98
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ErrorComponent, deps: [{ token: i1.ErrorService }, { token: i2.CuraService }, { token: i2.LogService }, { token: i2.SeoService }, { token: i2.ServerResponseService }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
99
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ErrorComponent, isStandalone: true, selector: "rdsite-error", inputs: { theme: "theme", type: "type", returnRoute: "returnRoute", returnLabel: "returnLabel", pageTitle: "pageTitle", component: "component", breadcrumbsItems: "breadcrumbsItems" }, viewQueries: [{ propertyName: "errorElement", first: true, predicate: ["errorElement"], descendants: true }], ngImport: i0, template: "<div class=\"rdsite-error\" #errorElement>\n <rdsite-breadcrumbs [breadcrumbs]=\"breadcrumbsItems\" [fontColor]=\"ctasBorderColor\"></rdsite-breadcrumbs>\n <div class=\"rdsite-error-container\">\n <cura-label [color]=\"labelTextColor\">\n {{ type === 'server-response' ? '500' : '404' }}\n </cura-label>\n\n <cura-heading color=\"neutral-black\" size=\"medium\" weight=\"bold\"> Algo deu errado :( </cura-heading>\n\n <cura-paragraph color=\"neutral-black\" size=\"large\">\n {{ responseText }}\n </cura-paragraph>\n\n @if (type === error.NOT_FOUND && returnRoute && returnLabel) {\n <cura-button\n rdsitelink\n [href]=\"returnRoute\"\n size=\"medium\"\n type=\"button\"\n [color]=\"curaButtonColor\"\n font-color=\"light\"\n icon-name=\"arrowLeft\"\n target=\"_self\"\n >\n Voltar para {{ returnLabel }}\n </cura-button>\n }\n\n @if (type === error.SERVER_RESPONSE) {\n @if (curaButtonColor) {\n <cura-button size=\"medium\" type=\"button\" (click)=\"reloadPage()\" [attr.color]=\"curaButtonColor\" font-color=\"light\" icon-name=\"arrowLeft\" target=\"_self\">\n Atualizar p\u00E1gina novamente\n </cura-button>\n }\n\n @if (returnLabel && returnRoute) {\n <cura-paragraph color=\"neutral-black\" size=\"large\">ou</cura-paragraph>\n @if (curaButtonOutlineColor) {\n <cura-button-outline\n rdsitelink\n [href]=\"returnRoute\"\n size=\"medium\"\n type=\"button\"\n [color]=\"curaButtonOutlineColor\"\n icon-name=\"arrowLeft\"\n target=\"_self\"\n >\n Voltar para {{ returnLabel }}\n </cura-button-outline>\n }\n }\n }\n\n <cura-paragraph class=\"wrapper-text\" color=\"neutral-black\" size=\"large\"> Voc\u00EA pode tamb\u00E9m: </cura-paragraph>\n\n @if (ctas.length > 0) {\n <rdsite-cta-wrapper [ctas]=\"ctas\" [colors]=\"{ border: ctasBorderColor, icon: ctasIconColor }\"></rdsite-cta-wrapper>\n }\n </div>\n</div>\n", styles: [".richet-container,.rdsite-error-container,.rdsite-error rdsite-breadcrumbs{display:block;box-sizing:border-box;width:90%;position:relative;max-width:1366px;margin-left:auto;margin-right:auto}.rdsite-error{width:100%;background-color:var(--backgroundColor)}.rdsite-error-container{padding:48px 0 40px}.rdsite-error-container cura-label{width:fit-content;padding:var(--sizes-space-tiny, 4px);border-radius:var(--sizes-cornerRadius-nano, 2px);background:var(--labelColor)}.rdsite-error-container cura-heading{--margin-block: 40px}.rdsite-error-container cura-paragraph.wrapper-text{margin-top:80px}\n"], dependencies: [{ kind: "component", type: CtaWrapperComponent, selector: "rdsite-cta-wrapper", inputs: ["ctas", "colors"] }, { kind: "directive", type: RdsiteLinkDirective, selector: "[rdsitelink]", inputs: ["anchorAdjustment", "anchorExtraAdjustment", "phonemodal"] }, { kind: "component", type: BreadcrumbsComponent, selector: "rdsite-breadcrumbs", inputs: ["fontColor", "breadcrumbs"] }] }); }
|
|
100
|
+
}
|
|
101
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ErrorComponent, decorators: [{
|
|
102
|
+
type: Component,
|
|
103
|
+
args: [{ selector: 'rdsite-error', standalone: true, imports: [CtaWrapperComponent, RdsiteLinkDirective, BreadcrumbsComponent], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"rdsite-error\" #errorElement>\n <rdsite-breadcrumbs [breadcrumbs]=\"breadcrumbsItems\" [fontColor]=\"ctasBorderColor\"></rdsite-breadcrumbs>\n <div class=\"rdsite-error-container\">\n <cura-label [color]=\"labelTextColor\">\n {{ type === 'server-response' ? '500' : '404' }}\n </cura-label>\n\n <cura-heading color=\"neutral-black\" size=\"medium\" weight=\"bold\"> Algo deu errado :( </cura-heading>\n\n <cura-paragraph color=\"neutral-black\" size=\"large\">\n {{ responseText }}\n </cura-paragraph>\n\n @if (type === error.NOT_FOUND && returnRoute && returnLabel) {\n <cura-button\n rdsitelink\n [href]=\"returnRoute\"\n size=\"medium\"\n type=\"button\"\n [color]=\"curaButtonColor\"\n font-color=\"light\"\n icon-name=\"arrowLeft\"\n target=\"_self\"\n >\n Voltar para {{ returnLabel }}\n </cura-button>\n }\n\n @if (type === error.SERVER_RESPONSE) {\n @if (curaButtonColor) {\n <cura-button size=\"medium\" type=\"button\" (click)=\"reloadPage()\" [attr.color]=\"curaButtonColor\" font-color=\"light\" icon-name=\"arrowLeft\" target=\"_self\">\n Atualizar p\u00E1gina novamente\n </cura-button>\n }\n\n @if (returnLabel && returnRoute) {\n <cura-paragraph color=\"neutral-black\" size=\"large\">ou</cura-paragraph>\n @if (curaButtonOutlineColor) {\n <cura-button-outline\n rdsitelink\n [href]=\"returnRoute\"\n size=\"medium\"\n type=\"button\"\n [color]=\"curaButtonOutlineColor\"\n icon-name=\"arrowLeft\"\n target=\"_self\"\n >\n Voltar para {{ returnLabel }}\n </cura-button-outline>\n }\n }\n }\n\n <cura-paragraph class=\"wrapper-text\" color=\"neutral-black\" size=\"large\"> Voc\u00EA pode tamb\u00E9m: </cura-paragraph>\n\n @if (ctas.length > 0) {\n <rdsite-cta-wrapper [ctas]=\"ctas\" [colors]=\"{ border: ctasBorderColor, icon: ctasIconColor }\"></rdsite-cta-wrapper>\n }\n </div>\n</div>\n", styles: [".richet-container,.rdsite-error-container,.rdsite-error rdsite-breadcrumbs{display:block;box-sizing:border-box;width:90%;position:relative;max-width:1366px;margin-left:auto;margin-right:auto}.rdsite-error{width:100%;background-color:var(--backgroundColor)}.rdsite-error-container{padding:48px 0 40px}.rdsite-error-container cura-label{width:fit-content;padding:var(--sizes-space-tiny, 4px);border-radius:var(--sizes-cornerRadius-nano, 2px);background:var(--labelColor)}.rdsite-error-container cura-heading{--margin-block: 40px}.rdsite-error-container cura-paragraph.wrapper-text{margin-top:80px}\n"] }]
|
|
104
|
+
}], ctorParameters: () => [{ type: i1.ErrorService }, { type: i2.CuraService }, { type: i2.LogService }, { type: i2.SeoService }, { type: i2.ServerResponseService }, { type: undefined, decorators: [{
|
|
105
|
+
type: Inject,
|
|
106
|
+
args: [PLATFORM_ID]
|
|
107
|
+
}] }], propDecorators: { theme: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], type: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], returnRoute: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], returnLabel: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}], pageTitle: [{
|
|
116
|
+
type: Input
|
|
117
|
+
}], component: [{
|
|
118
|
+
type: Input
|
|
119
|
+
}], breadcrumbsItems: [{
|
|
120
|
+
type: Input
|
|
121
|
+
}], errorElement: [{
|
|
122
|
+
type: ViewChild,
|
|
123
|
+
args: ['errorElement']
|
|
124
|
+
}] } });
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"error.component.js","sourceRoot":"","sources":["../../../../../../projects/site-front-end-lib/src/lib/components/error/error.component.ts","../../../../../../projects/site-front-end-lib/src/lib/components/error/error.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, CUSTOM_ELEMENTS_SCHEMA, Component, ElementRef, Inject, Input, OnDestroy, OnInit, PLATFORM_ID, ViewChild } from '@angular/core';\nimport { CtaWrapperComponent } from '../cta-wrapper/cta-wrapper.component';\nimport { ErrorService, ctas404_502 } from './error-service/error.service';\nimport { Subscription } from 'rxjs';\nimport { CuraService, LogService, SeoService, ServerResponseService } from '../../services';\nimport { RdsiteLinkDirective } from '../../directives';\nimport { isPlatformServer } from '@angular/common';\nimport { BreadcrumbsComponent } from '../breadcrumbs/breadcrumbs.component';\nimport { BreadcrumbsItems } from '../../models/breadcrumbs/breadcrumbs-items.model';\nimport { Errors, Themes } from '../../enums';\n\n@Component({\n  selector: 'rdsite-error',\n  standalone: true,\n  imports: [CtaWrapperComponent, RdsiteLinkDirective, BreadcrumbsComponent],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n  templateUrl: './error.component.html',\n  styleUrl: './error.component.scss',\n})\nexport class ErrorComponent implements OnInit, AfterViewInit, OnDestroy {\n  @Input() theme: Themes = Themes.REDE;\n  @Input() type!: Errors;\n  @Input() returnRoute!: string;\n  @Input() returnLabel!: string;\n  @Input() pageTitle = 'Default component';\n  @Input() component = 'DefaultComponent';\n  @Input() breadcrumbsItems!: BreadcrumbsItems[];\n\n  ctasSubscription!: Subscription;\n  ctas!: ctas404_502[];\n  responseText = '';\n\n  backgroundColor!: string;\n  labelColor!: string;\n  labelTextColor!: string;\n  curaButtonColor!: string;\n  curaButtonOutlineColor!: string;\n  ctasBorderColor!: string;\n  ctasIconColor!: string;\n  public error = Errors;\n  @ViewChild('errorElement') errorElement!: ElementRef<HTMLDivElement>;\n\n  constructor(\n    private errorService: ErrorService,\n    private curaService: CuraService,\n    private logService: LogService,\n    private seoService: SeoService,\n    private serverResponse: ServerResponseService,\n    @Inject(PLATFORM_ID) private readonly platformId: object,\n  ) {}\n\n  ngOnInit(): void {\n    if (this.type === Errors.NOT_FOUND) {\n      this.responseText = 'A página que você acessou não existe mais ou foi movida para outra URL';\n      if (isPlatformServer(this.platformId)) {\n        this.serverResponse.setNotFound();\n      }\n      this.logService.log404(this.component);\n      this.seoService.set404Title(this.pageTitle);\n    } else if (this.type === Errors.SERVER_RESPONSE) {\n      this.responseText = 'Recomendamos atualizar a página ou tentar novamente mais tarde.';\n      if (isPlatformServer(this.platformId)) {\n        this.serverResponse.setError();\n      }\n      this.logService.log500(this.component);\n      this.seoService.set500Title(this.pageTitle);\n    }\n    this.ctasSubscription = this.errorService.ctas.subscribe((ctas) => {\n      this.ctas = ctas;\n    });\n  }\n\n  ngAfterViewInit(): void {\n    this.setTheme(this.theme);\n  }\n\n  setTheme(theme: Themes) {\n    switch (theme) {\n      case Themes.REDE:\n        this.backgroundColor = this.curaService.getColor('neutral-white') ?? '';\n        this.labelColor = this.curaService.getColor('primary-lighter') ?? '';\n        this.labelTextColor = 'primary-dark';\n        this.curaButtonColor = 'primary';\n        this.curaButtonOutlineColor = 'primary';\n        this.ctasBorderColor = 'primary-darker';\n        this.ctasIconColor = 'primary-darker';\n        break;\n      case Themes.ONCO:\n        this.backgroundColor = this.curaService.getColor('neutral-light') ?? '';\n        this.labelColor = this.curaService.getColor('auxiliar-lighter') ?? '';\n        this.labelTextColor = 'primary-lighter';\n        this.curaButtonColor = 'accent';\n        this.curaButtonOutlineColor = 'accent';\n        this.ctasBorderColor = 'accent-base';\n        this.ctasIconColor = 'primary-base';\n        break;\n      case Themes.MATERNIDADE:\n        this.backgroundColor = this.curaService.getColor('accent-lighter') ?? '';\n        this.labelColor = this.curaService.getColor('primary-light') ?? '';\n        this.labelTextColor = 'accent-base';\n        this.curaButtonColor = 'accent';\n        this.curaButtonOutlineColor = 'accent';\n        this.ctasBorderColor = 'accent-base';\n        this.ctasIconColor = 'accent-base';\n        break;\n      case Themes.RICHET:\n        this.backgroundColor = this.curaService.getColor('neutral-white') ?? '';\n        this.labelColor = this.curaService.getColor('primary-lighter') ?? '';\n        this.labelTextColor = 'primary-dark';\n        this.curaButtonColor = 'primary';\n        this.curaButtonOutlineColor = 'primary';\n        this.ctasBorderColor = 'primary-darker';\n        this.ctasIconColor = 'primary-darker';\n        break;\n    }\n\n    this.errorElement.nativeElement.style.setProperty('--backgroundColor', this.backgroundColor);\n    this.errorElement.nativeElement.style.setProperty('--labelColor', this.labelColor);\n  }\n\n  reloadPage() {\n    if (window !== undefined) {\n      window.location.reload();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.ctasSubscription?.unsubscribe();\n  }\n}\n","<div class=\"rdsite-error\" #errorElement>\n  <rdsite-breadcrumbs [breadcrumbs]=\"breadcrumbsItems\" [fontColor]=\"ctasBorderColor\"></rdsite-breadcrumbs>\n  <div class=\"rdsite-error-container\">\n    <cura-label [color]=\"labelTextColor\">\n      {{ type === 'server-response' ? '500' : '404' }}\n    </cura-label>\n\n    <cura-heading color=\"neutral-black\" size=\"medium\" weight=\"bold\"> Algo deu errado :( </cura-heading>\n\n    <cura-paragraph color=\"neutral-black\" size=\"large\">\n      {{ responseText }}\n    </cura-paragraph>\n\n    @if (type === error.NOT_FOUND && returnRoute && returnLabel) {\n      <cura-button\n        rdsitelink\n        [href]=\"returnRoute\"\n        size=\"medium\"\n        type=\"button\"\n        [color]=\"curaButtonColor\"\n        font-color=\"light\"\n        icon-name=\"arrowLeft\"\n        target=\"_self\"\n      >\n        Voltar para {{ returnLabel }}\n      </cura-button>\n    }\n\n    @if (type === error.SERVER_RESPONSE) {\n      @if (curaButtonColor) {\n        <cura-button size=\"medium\" type=\"button\" (click)=\"reloadPage()\" [attr.color]=\"curaButtonColor\" font-color=\"light\" icon-name=\"arrowLeft\" target=\"_self\">\n          Atualizar página novamente\n        </cura-button>\n      }\n\n      @if (returnLabel && returnRoute) {\n        <cura-paragraph color=\"neutral-black\" size=\"large\">ou</cura-paragraph>\n        @if (curaButtonOutlineColor) {\n          <cura-button-outline\n            rdsitelink\n            [href]=\"returnRoute\"\n            size=\"medium\"\n            type=\"button\"\n            [color]=\"curaButtonOutlineColor\"\n            icon-name=\"arrowLeft\"\n            target=\"_self\"\n          >\n            Voltar para {{ returnLabel }}\n          </cura-button-outline>\n        }\n      }\n    }\n\n    <cura-paragraph class=\"wrapper-text\" color=\"neutral-black\" size=\"large\"> Você pode também: </cura-paragraph>\n\n    @if (ctas.length > 0) {\n      <rdsite-cta-wrapper [ctas]=\"ctas\" [colors]=\"{ border: ctasBorderColor, icon: ctasIconColor }\"></rdsite-cta-wrapper>\n    }\n  </div>\n</div>\n"]}
|
|
@@ -26,8 +26,12 @@ export * from './side-ctas/components/side-ctas-right-middle/side-ctas-right-mid
|
|
|
26
26
|
export * from './side-ctas/components/side-ctas-right-top/side-ctas-right-top.component';
|
|
27
27
|
export * from './whatsapp/whatsapp.component';
|
|
28
28
|
export * from './algolia/algolia.component';
|
|
29
|
+
export * from './error/error.component';
|
|
30
|
+
export * from './error/error-service/error.service';
|
|
31
|
+
export * from './cta-wrapper/cta-wrapper.component';
|
|
29
32
|
export * from './page-header/page-header.component';
|
|
30
33
|
export * from './breadcrumbs/breadcrumbs.component';
|
|
31
34
|
export * from './page-template-sidebar/page-template-sidebar.component';
|
|
32
35
|
export * from './filter-letter-and-terms/filter-letter-and-terms.component';
|
|
33
|
-
|
|
36
|
+
export * from './section-navigation/section-navigation.component';
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaXRlLWZyb250LWVuZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGFBQWE7QUFDYixjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsbUVBQW1FLENBQUM7QUFDbEYsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHFFQUFxRSxDQUFDO0FBQ3BGLGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYyxtRkFBbUYsQ0FBQztBQUNsRyxjQUFjLHlFQUF5RSxDQUFDO0FBQ3hGLGNBQWMsMkZBQTJGLENBQUM7QUFDMUcsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsMkVBQTJFLENBQUM7QUFDMUYsY0FBYyw2RkFBNkYsQ0FBQztBQUM1RyxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsMkVBQTJFLENBQUM7QUFDMUYsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLG9FQUFvRSxDQUFDO0FBQ25GLGNBQWMsZ0ZBQWdGLENBQUM7QUFDL0YsY0FBYyxnRkFBZ0YsQ0FBQztBQUMvRixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsbURBQW1ELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBDb21wb25lbnRzXG5leHBvcnQgKiBmcm9tICcuL2Zvb3Rlci9mb290ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9vdGVyL2NvbXBvbmVudHMvZm9vdGVyLWRpc2NsYWltZXIvZm9vdGVyLWRpc2NsYWltZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9vdGVyL2NvbXBvbmVudHMvZm9vdGVyLW1lbnUvZm9vdGVyLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZm9vdGVyL2NvbXBvbmVudHMvZm9vdGVyLW1lbnUtaXRlbS9mb290ZXItbWVudS1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Zvb3Rlci9jb21wb25lbnRzL2Zvb3Rlci1zb2NpYWwtbWVkaWFzL2Zvb3Rlci1zb2NpYWwtbWVkaWFzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci9oZWFkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaGVhZGVyL2NvbXBvbmVudHMvaGVhZGVyLWFjdGlvbi1tZW51L2hlYWRlci1hY3Rpb24tbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItYXV4LW1lbnUvaGVhZGVyLWF1eC1tZW51LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci9jb21wb25lbnRzL2hlYWRlci1hdXgtbWVudS1jb250YWluZXIvaGVhZGVyLWF1eC1tZW51LWNvbnRhaW5lci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItYXV4LW1lbnUtaXRlbS9oZWFkZXItYXV4LW1lbnUtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItYXV4LW1lbnUtaXRlbS1kcm9wZG93bi9oZWFkZXItYXV4LW1lbnUtaXRlbS1kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItbG9nby9oZWFkZXItbG9nby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItbWFpbi1tZW51L2hlYWRlci1tYWluLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaGVhZGVyL2NvbXBvbmVudHMvaGVhZGVyLW1haW4tbWVudS1pdGVtL2hlYWRlci1tYWluLW1lbnUtaXRlbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItbWFpbi1tZW51LWl0ZW0tZHJvcGRvd24vaGVhZGVyLW1haW4tbWVudS1pdGVtLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRlci9jb21wb25lbnRzL2hlYWRlci1zaWRlLW1lbnUvaGVhZGVyLXNpZGUtbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWFkZXIvY29tcG9uZW50cy9oZWFkZXItc2lkZS1tZW51LWl0ZW0vaGVhZGVyLXNpZGUtbWVudS1pdGVtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xvYWQtc2NyZWVuL2xvYWQtc2NyZWVuLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL292ZXJsYXkvb3ZlcmxheS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gvc2VhcmNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NpZGUtY3Rhcy9zaWRlLWN0YXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2lkZS1jdGFzL2NvbXBvbmVudHMvc2lkZS1jdGFzLWJvdHRvbS9zaWRlLWN0YXMtYm90dG9tLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NpZGUtY3Rhcy9jb21wb25lbnRzL3NpZGUtY3Rhcy1yaWdodC1ib3R0b20vc2lkZS1jdGFzLXJpZ2h0LWJvdHRvbS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlLWN0YXMvY29tcG9uZW50cy9zaWRlLWN0YXMtcmlnaHQtbWlkZGxlL3NpZGUtY3Rhcy1yaWdodC1taWRkbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2lkZS1jdGFzL2NvbXBvbmVudHMvc2lkZS1jdGFzLXJpZ2h0LXRvcC9zaWRlLWN0YXMtcmlnaHQtdG9wLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3doYXRzYXBwL3doYXRzYXBwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2FsZ29saWEvYWxnb2xpYS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lcnJvci9lcnJvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lcnJvci9lcnJvci1zZXJ2aWNlL2Vycm9yLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9jdGEtd3JhcHBlci9jdGEtd3JhcHBlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdlLWhlYWRlci9wYWdlLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9icmVhZGNydW1icy9icmVhZGNydW1icy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wYWdlLXRlbXBsYXRlLXNpZGViYXIvcGFnZS10ZW1wbGF0ZS1zaWRlYmFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlci1sZXR0ZXItYW5kLXRlcm1zL2ZpbHRlci1sZXR0ZXItYW5kLXRlcm1zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlY3Rpb24tbmF2aWdhdGlvbi9zZWN0aW9uLW5hdmlnYXRpb24uY29tcG9uZW50JztcbiJdfQ==
|
|
@@ -31,7 +31,7 @@ export class PageHeaderComponent {
|
|
|
31
31
|
this.breadcrumbsItems = [];
|
|
32
32
|
}
|
|
33
33
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PageHeaderComponent, deps: [{ token: i1.CuraService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PageHeaderComponent, isStandalone: true, selector: "rdsite-page-header", inputs: { layoutStyle: "layoutStyle", pageTitle: "pageTitle", pageSubtitle: "pageSubtitle", headerImageUrl: "headerImageUrl", useBackgroundImage: "useBackgroundImage", showBreadcrumbs: "showBreadcrumbs", breadcrumbsItems: "breadcrumbsItems" }, host: { properties: { "style": "this.hostStyles" } }, ngImport: i0, template: "<header class=\"page-header\" [ngClass]=\"headerClasses\">\n <!-- Imagem de fundo do cabe\u00E7alho (opcional) -->\n @if (shouldShowHeaderImage) {\n <div class=\"header-background\">\n <img [src]=\"headerImageUrl\" [alt]=\"pageTitle\" />\n </div>\n }\n\n <!-- Conte\u00FAdo do cabe\u00E7alho -->\n <div class=\"header-content\">\n <!-- Breadcrumbs -->\n @if (shouldShowBreadcrumbs) {\n <rdsite-breadcrumbs [items]=\"breadcrumbsItems\"></rdsite-breadcrumbs>\n }\n\n <!-- T\u00EDtulo e subt\u00EDtulo -->\n @if (pageTitle) {\n <cura-display color=\"neutral-purewhite\" margin-block=\"12\">\n {{ pageTitle }}\n </cura-display>\n }\n\n @if (pageSubtitle) {\n <cura-paragraph color=\"neutral-purewhite\" [innerHTML]=\"pageSubtitle\"></cura-paragraph>\n }\n\n <!-- Conte\u00FAdo customizado -->\n <ng-content></ng-content>\n </div>\n</header>\n", styles: [".page-header{position:relative;width:100%;min-height:272px;display:flex;flex-direction:column;justify-content:center;background-color:var(--header-bg-color);padding:50px 140px 50px 142px}.page-header::ng-deep *{font-family:Gotham,Arial,Helvetica,sans-serif}.page-header.with-bg-image{background-color:transparent}.page-header.with-bg-image .header-background img{position:absolute;top:0;right:0;height:100%;max-width:100%;object-fit:cover;opacity:.7}.page-header .header-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;background-color:var(--header-bg-color)}.page-header .header-background img{width:100%;height:100%;object-fit:cover;opacity:.3}.page-header .header-content{position:relative;z-index:1;width:100%;max-width:688px!important;text-align:left}@media (max-width: 361px){.page-header{padding:20px 15px;min-height:148px}}@media (min-width: 361px) and (max-width: 769px){.page-header{padding:30px 40px}}@media (min-width: 769px) and (max-width: 1024px){.page-header{padding:40px 90px}}@media (min-width: 1024px) and (max-width: 1366px){.page-header{padding:45px 52px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: BreadcrumbsComponent, selector: "rdsite-breadcrumbs", inputs: ["
|
|
34
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: PageHeaderComponent, isStandalone: true, selector: "rdsite-page-header", inputs: { layoutStyle: "layoutStyle", pageTitle: "pageTitle", pageSubtitle: "pageSubtitle", headerImageUrl: "headerImageUrl", useBackgroundImage: "useBackgroundImage", showBreadcrumbs: "showBreadcrumbs", breadcrumbsItems: "breadcrumbsItems" }, host: { properties: { "style": "this.hostStyles" } }, ngImport: i0, template: "<header class=\"page-header\" [ngClass]=\"headerClasses\">\n <!-- Imagem de fundo do cabe\u00E7alho (opcional) -->\n @if (shouldShowHeaderImage) {\n <div class=\"header-background\">\n <img [src]=\"headerImageUrl\" [alt]=\"pageTitle\" />\n </div>\n }\n\n <!-- Conte\u00FAdo do cabe\u00E7alho -->\n <div class=\"header-content\">\n <!-- Breadcrumbs -->\n @if (shouldShowBreadcrumbs) {\n <rdsite-breadcrumbs [items]=\"breadcrumbsItems\"></rdsite-breadcrumbs>\n }\n\n <!-- T\u00EDtulo e subt\u00EDtulo -->\n @if (pageTitle) {\n <cura-display color=\"neutral-purewhite\" margin-block=\"12\">\n {{ pageTitle }}\n </cura-display>\n }\n\n @if (pageSubtitle) {\n <cura-paragraph color=\"neutral-purewhite\" [innerHTML]=\"pageSubtitle\"></cura-paragraph>\n }\n\n <!-- Conte\u00FAdo customizado -->\n <ng-content></ng-content>\n </div>\n</header>\n", styles: [".page-header{position:relative;width:100%;min-height:272px;display:flex;flex-direction:column;justify-content:center;background-color:var(--header-bg-color);padding:50px 140px 50px 142px}.page-header::ng-deep *{font-family:Gotham,Arial,Helvetica,sans-serif}.page-header.with-bg-image{background-color:transparent}.page-header.with-bg-image .header-background img{position:absolute;top:0;right:0;height:100%;max-width:100%;object-fit:cover;opacity:.7}.page-header .header-background{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;background-color:var(--header-bg-color)}.page-header .header-background img{width:100%;height:100%;object-fit:cover;opacity:.3}.page-header .header-content{position:relative;z-index:1;width:100%;max-width:688px!important;text-align:left}@media (max-width: 361px){.page-header{padding:20px 15px;min-height:148px}}@media (min-width: 361px) and (max-width: 769px){.page-header{padding:30px 40px}}@media (min-width: 769px) and (max-width: 1024px){.page-header{padding:40px 90px}}@media (min-width: 1024px) and (max-width: 1366px){.page-header{padding:45px 52px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: BreadcrumbsComponent, selector: "rdsite-breadcrumbs", inputs: ["fontColor", "breadcrumbs"] }] }); }
|
|
35
35
|
}
|
|
36
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PageHeaderComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/common";
|
|
5
5
|
export class PageTemplateSidebarComponent {
|
|
@@ -8,7 +8,7 @@ export class PageTemplateSidebarComponent {
|
|
|
8
8
|
}
|
|
9
9
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PageTemplateSidebarComponent, decorators: [{
|
|
10
10
|
type: Component,
|
|
11
|
-
args: [{ selector: 'rdsite-page-template-sidebar', standalone: true, imports: [CommonModule], template: "<div class=\"page-template-sidebar\">\n <!-- Header Section -->\n <div class=\"header-content\">\n @if (headerContent) {\n <ng-container [ngTemplateOutlet]=\"headerContent\"></ng-container>\n }\n </div>\n\n <!-- Before Content Section -->\n <div class=\"before-content\">\n @if (beforeContent) {\n <ng-container [ngTemplateOutlet]=\"beforeContent\"></ng-container>\n }\n </div>\n\n <!-- Main Content -->\n <div class=\"main-content\">\n @if (mainContent) {\n <ng-container [ngTemplateOutlet]=\"mainContent\"></ng-container>\n }\n </div>\n\n <!-- Sidebars -->\n <div class=\"main-sidebar\">\n @if (mainSidebar) {\n <ng-container [ngTemplateOutlet]=\"mainSidebar\"></ng-container>\n }\n </div>\n <div class=\"secondary-sidebar\">\n @if (sidebarContent) {\n <ng-container [ngTemplateOutlet]=\"sidebarContent\"></ng-container>\n }\n </div>\n\n <!-- After Content -->\n <div class=\"after-content\">\n @if (afterContent) {\n <ng-container [ngTemplateOutlet]=\"afterContent\"></ng-container>\n }\n </div>\n</div>\n", styles: [".page-template-sidebar{display:grid;grid-template-columns:733px 292px;grid-template-rows:auto auto;grid-auto-rows:auto;gap:0px 53px;grid-auto-flow:row dense;padding:0 146px 0 142px;box-sizing:border-box}.page-template-sidebar .header-content{grid-area:1/1/2/4;margin:0 -146px 0 -142px;width:calc(100% + 288px)}.page-template-sidebar .main-sidebar{grid-area:1/3/3/4}.page-template-sidebar .secondary-sidebar{grid-area:3/3/5/4}.page-template-sidebar .before-content{grid-area:2/1/3/3}.page-template-sidebar .main-content{grid-area:3/1/5/3}.page-template-sidebar .after-content{grid-area:5/1/6/4}@media (max-width: 361px){.page-template-sidebar{padding:0 15px;min-height:148px}}@media (min-width: 361px) and (max-width: 769px){.page-template-sidebar{padding:0 40px}}@media (min-width: 769px) and (max-width: 1024px){.page-template-sidebar{padding:0 90px}}@media (min-width: 1024px) and (max-width: 1366px){.page-template-sidebar{padding:0 52px}}\n"] }]
|
|
11
|
+
args: [{ selector: 'rdsite-page-template-sidebar', standalone: true, imports: [CommonModule], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<div class=\"page-template-sidebar\">\n <!-- Header Section -->\n <div class=\"header-content\">\n @if (headerContent) {\n <ng-container [ngTemplateOutlet]=\"headerContent\"></ng-container>\n }\n </div>\n\n <!-- Before Content Section -->\n <div class=\"before-content\">\n @if (beforeContent) {\n <ng-container [ngTemplateOutlet]=\"beforeContent\"></ng-container>\n }\n </div>\n\n <!-- Main Content -->\n <div class=\"main-content\">\n @if (mainContent) {\n <ng-container [ngTemplateOutlet]=\"mainContent\"></ng-container>\n }\n </div>\n\n <!-- Sidebars -->\n <div class=\"main-sidebar\">\n @if (mainSidebar) {\n <ng-container [ngTemplateOutlet]=\"mainSidebar\"></ng-container>\n }\n </div>\n <div class=\"secondary-sidebar\">\n @if (sidebarContent) {\n <ng-container [ngTemplateOutlet]=\"sidebarContent\"></ng-container>\n }\n </div>\n\n <!-- After Content -->\n <div class=\"after-content\">\n @if (afterContent) {\n <ng-container [ngTemplateOutlet]=\"afterContent\"></ng-container>\n }\n </div>\n</div>\n", styles: [".page-template-sidebar{display:grid;grid-template-columns:733px 292px;grid-template-rows:auto auto;grid-auto-rows:auto;gap:0px 53px;grid-auto-flow:row dense;padding:0 146px 0 142px;box-sizing:border-box}.page-template-sidebar .header-content{grid-area:1/1/2/4;margin:0 -146px 0 -142px;width:calc(100% + 288px)}.page-template-sidebar .main-sidebar{grid-area:1/3/3/4}.page-template-sidebar .secondary-sidebar{grid-area:3/3/5/4}.page-template-sidebar .before-content{grid-area:2/1/3/3}.page-template-sidebar .main-content{grid-area:3/1/5/3}.page-template-sidebar .after-content{grid-area:5/1/6/4}@media (max-width: 361px){.page-template-sidebar{padding:0 15px;min-height:148px}}@media (min-width: 361px) and (max-width: 769px){.page-template-sidebar{padding:0 40px}}@media (min-width: 769px) and (max-width: 1024px){.page-template-sidebar{padding:0 90px}}@media (min-width: 1024px) and (max-width: 1366px){.page-template-sidebar{padding:0 52px}}\n"] }]
|
|
12
12
|
}], propDecorators: { headerContent: [{
|
|
13
13
|
type: Input
|
|
14
14
|
}], beforeContent: [{
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
22
22
|
}], afterContent: [{
|
|
23
23
|
type: Input
|
|
24
24
|
}] } });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10ZW1wbGF0ZS1zaWRlYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpdGUtZnJvbnQtZW5kLWxpYi9zcmMvbGliL2NvbXBvbmVudHMvcGFnZS10ZW1wbGF0ZS1zaWRlYmFyL3BhZ2UtdGVtcGxhdGUtc2lkZWJhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaXRlLWZyb250LWVuZC1saWIvc3JjL2xpYi9jb21wb25lbnRzL3BhZ2UtdGVtcGxhdGUtc2lkZWJhci9wYWdlLXRlbXBsYXRlLXNpZGViYXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsc0JBQXNCLEVBQUUsS0FBSyxFQUFlLE1BQU0sZUFBZSxDQUFDOzs7QUFVdEYsTUFBTSxPQUFPLDRCQUE0QjsrR0FBNUIsNEJBQTRCO21HQUE1Qiw0QkFBNEIsNFJDWHpDLHFrQ0F5Q0EseStCRG5DWSxZQUFZOzs0RkFLWCw0QkFBNEI7a0JBUnhDLFNBQVM7K0JBQ0UsOEJBQThCLGNBQzVCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxXQUNkLENBQUMsc0JBQXNCLENBQUM7OEJBS3hCLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLFdBQVc7c0JBQW5CLEtBQUs7Z0JBQ0csY0FBYztzQkFBdEIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQSwgSW5wdXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3Jkc2l0ZS1wYWdlLXRlbXBsYXRlLXNpZGViYXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxuICB0ZW1wbGF0ZVVybDogJy4vcGFnZS10ZW1wbGF0ZS1zaWRlYmFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmw6ICcuL3BhZ2UtdGVtcGxhdGUtc2lkZWJhci5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIFBhZ2VUZW1wbGF0ZVNpZGViYXJDb21wb25lbnQge1xuICBASW5wdXQoKSBoZWFkZXJDb250ZW50PzogVGVtcGxhdGVSZWY8YW55PjtcbiAgQElucHV0KCkgYmVmb3JlQ29udGVudD86IFRlbXBsYXRlUmVmPGFueT47XG4gIEBJbnB1dCgpIG1haW5Db250ZW50PzogVGVtcGxhdGVSZWY8YW55PjtcbiAgQElucHV0KCkgbWFpblNpZGViYXI/OiBUZW1wbGF0ZVJlZjxhbnk+O1xuICBASW5wdXQoKSBzaWRlYmFyQ29udGVudD86IFRlbXBsYXRlUmVmPGFueT47XG4gIEBJbnB1dCgpIGFmdGVyQ29udGVudD86IFRlbXBsYXRlUmVmPGFueT47XG59XG4iLCI8ZGl2IGNsYXNzPVwicGFnZS10ZW1wbGF0ZS1zaWRlYmFyXCI+XG4gIDwhLS0gSGVhZGVyIFNlY3Rpb24gLS0+XG4gIDxkaXYgY2xhc3M9XCJoZWFkZXItY29udGVudFwiPlxuICAgIEBpZiAoaGVhZGVyQ29udGVudCkge1xuICAgICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJoZWFkZXJDb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4gICAgfVxuICA8L2Rpdj5cblxuICA8IS0tIEJlZm9yZSBDb250ZW50IFNlY3Rpb24gLS0+XG4gIDxkaXYgY2xhc3M9XCJiZWZvcmUtY29udGVudFwiPlxuICAgIEBpZiAoYmVmb3JlQ29udGVudCkge1xuICAgICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJiZWZvcmVDb250ZW50XCI+PC9uZy1jb250YWluZXI+XG4gICAgfVxuICA8L2Rpdj5cblxuICA8IS0tIE1haW4gQ29udGVudCAtLT5cbiAgPGRpdiBjbGFzcz1cIm1haW4tY29udGVudFwiPlxuICAgIEBpZiAobWFpbkNvbnRlbnQpIHtcbiAgICAgIDxuZy1jb250YWluZXIgW25nVGVtcGxhdGVPdXRsZXRdPVwibWFpbkNvbnRlbnRcIj48L25nLWNvbnRhaW5lcj5cbiAgICB9XG4gIDwvZGl2PlxuXG4gIDwhLS0gU2lkZWJhcnMgLS0+XG4gIDxkaXYgY2xhc3M9XCJtYWluLXNpZGViYXJcIj5cbiAgICBAaWYgKG1haW5TaWRlYmFyKSB7XG4gICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cIm1haW5TaWRlYmFyXCI+PC9uZy1jb250YWluZXI+XG4gICAgfVxuICA8L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInNlY29uZGFyeS1zaWRlYmFyXCI+XG4gICAgQGlmIChzaWRlYmFyQ29udGVudCkge1xuICAgICAgPG5nLWNvbnRhaW5lciBbbmdUZW1wbGF0ZU91dGxldF09XCJzaWRlYmFyQ29udGVudFwiPjwvbmctY29udGFpbmVyPlxuICAgIH1cbiAgPC9kaXY+XG5cbiAgPCEtLSBBZnRlciBDb250ZW50IC0tPlxuICA8ZGl2IGNsYXNzPVwiYWZ0ZXItY29udGVudFwiPlxuICAgIEBpZiAoYWZ0ZXJDb250ZW50KSB7XG4gICAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImFmdGVyQ29udGVudFwiPjwvbmctY29udGFpbmVyPlxuICAgIH1cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|