valtech-components 2.0.808 → 2.0.810
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/molecules/update-banner/types.mjs +42 -0
- package/esm2022/lib/components/molecules/update-banner/update-banner.component.mjs +205 -74
- package/esm2022/lib/components/organisms/faq/faq.component.mjs +136 -0
- package/esm2022/lib/components/organisms/faq/types.mjs +9 -0
- package/esm2022/lib/services/app-version/app-version.service.mjs +187 -0
- package/esm2022/lib/services/app-version/config.mjs +42 -0
- package/esm2022/lib/services/app-version/index.mjs +24 -0
- package/esm2022/lib/services/app-version/types.mjs +17 -0
- package/esm2022/lib/version.mjs +2 -2
- package/esm2022/public-api.mjs +8 -1
- package/fesm2022/valtech-components.mjs +745 -179
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/molecules/update-banner/types.d.ts +41 -0
- package/lib/components/molecules/update-banner/update-banner.component.d.ts +26 -20
- package/lib/components/organisms/faq/faq.component.d.ts +38 -0
- package/lib/components/organisms/faq/types.d.ts +53 -0
- package/lib/services/app-version/app-version.service.d.ts +64 -0
- package/lib/services/app-version/config.d.ts +35 -0
- package/lib/services/app-version/index.d.ts +23 -0
- package/lib/services/app-version/types.d.ts +35 -0
- package/lib/version.d.ts +1 -1
- package/package.json +5 -1
- package/public-api.d.ts +4 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* UpdateBanner Types
|
|
3
|
+
*
|
|
4
|
+
* Contenido i18n del banner de actualización de la app.
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Namespace i18n usado por `val-update-banner`.
|
|
8
|
+
* Las apps consumidoras pueden sobreescribir estas keys registrando
|
|
9
|
+
* contenido bajo este namespace en `I18nService`.
|
|
10
|
+
*/
|
|
11
|
+
export const UPDATE_BANNER_I18N_NAMESPACE = 'UpdateBanner';
|
|
12
|
+
/**
|
|
13
|
+
* Textos por defecto del banner (fallback si la app no registra el namespace).
|
|
14
|
+
* Soporta es / en / pt.
|
|
15
|
+
*/
|
|
16
|
+
export const UPDATE_BANNER_DEFAULT_CONTENT = {
|
|
17
|
+
es: {
|
|
18
|
+
availableTitle: 'Hay una versión nueva disponible',
|
|
19
|
+
availableMessage: 'Actualiza para obtener las últimas mejoras.',
|
|
20
|
+
requiredTitle: 'Debes actualizar para continuar',
|
|
21
|
+
requiredMessage: 'Esta versión ya no es compatible. Actualiza para seguir.',
|
|
22
|
+
updateAction: 'Actualizar',
|
|
23
|
+
dismissAction: 'Cerrar',
|
|
24
|
+
},
|
|
25
|
+
en: {
|
|
26
|
+
availableTitle: 'A new version is available',
|
|
27
|
+
availableMessage: 'Update to get the latest improvements.',
|
|
28
|
+
requiredTitle: 'You must update to continue',
|
|
29
|
+
requiredMessage: 'This version is no longer supported. Please update.',
|
|
30
|
+
updateAction: 'Update',
|
|
31
|
+
dismissAction: 'Close',
|
|
32
|
+
},
|
|
33
|
+
pt: {
|
|
34
|
+
availableTitle: 'Há uma nova versão disponível',
|
|
35
|
+
availableMessage: 'Atualize para obter as últimas melhorias.',
|
|
36
|
+
requiredTitle: 'Você precisa atualizar para continuar',
|
|
37
|
+
requiredMessage: 'Esta versão não é mais compatível. Atualize para seguir.',
|
|
38
|
+
updateAction: 'Atualizar',
|
|
39
|
+
dismissAction: 'Fechar',
|
|
40
|
+
},
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3VwZGF0ZS1iYW5uZXIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7R0FJRztBQUVIOzs7O0dBSUc7QUFDSCxNQUFNLENBQUMsTUFBTSw0QkFBNEIsR0FBRyxjQUFjLENBQUM7QUFFM0Q7OztHQUdHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUc7SUFDM0MsRUFBRSxFQUFFO1FBQ0YsY0FBYyxFQUFFLGtDQUFrQztRQUNsRCxnQkFBZ0IsRUFBRSw2Q0FBNkM7UUFDL0QsYUFBYSxFQUFFLGlDQUFpQztRQUNoRCxlQUFlLEVBQUUsMERBQTBEO1FBQzNFLFlBQVksRUFBRSxZQUFZO1FBQzFCLGFBQWEsRUFBRSxRQUFRO0tBQ3hCO0lBQ0QsRUFBRSxFQUFFO1FBQ0YsY0FBYyxFQUFFLDRCQUE0QjtRQUM1QyxnQkFBZ0IsRUFBRSx3Q0FBd0M7UUFDMUQsYUFBYSxFQUFFLDZCQUE2QjtRQUM1QyxlQUFlLEVBQUUscURBQXFEO1FBQ3RFLFlBQVksRUFBRSxRQUFRO1FBQ3RCLGFBQWEsRUFBRSxPQUFPO0tBQ3ZCO0lBQ0QsRUFBRSxFQUFFO1FBQ0YsY0FBYyxFQUFFLCtCQUErQjtRQUMvQyxnQkFBZ0IsRUFBRSwyQ0FBMkM7UUFDN0QsYUFBYSxFQUFFLHVDQUF1QztRQUN0RCxlQUFlLEVBQUUsMERBQTBEO1FBQzNFLFlBQVksRUFBRSxXQUFXO1FBQ3pCLGFBQWEsRUFBRSxRQUFRO0tBQ3hCO0NBQ08sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVXBkYXRlQmFubmVyIFR5cGVzXG4gKlxuICogQ29udGVuaWRvIGkxOG4gZGVsIGJhbm5lciBkZSBhY3R1YWxpemFjacOzbiBkZSBsYSBhcHAuXG4gKi9cblxuLyoqXG4gKiBOYW1lc3BhY2UgaTE4biB1c2FkbyBwb3IgYHZhbC11cGRhdGUtYmFubmVyYC5cbiAqIExhcyBhcHBzIGNvbnN1bWlkb3JhcyBwdWVkZW4gc29icmVlc2NyaWJpciBlc3RhcyBrZXlzIHJlZ2lzdHJhbmRvXG4gKiBjb250ZW5pZG8gYmFqbyBlc3RlIG5hbWVzcGFjZSBlbiBgSTE4blNlcnZpY2VgLlxuICovXG5leHBvcnQgY29uc3QgVVBEQVRFX0JBTk5FUl9JMThOX05BTUVTUEFDRSA9ICdVcGRhdGVCYW5uZXInO1xuXG4vKipcbiAqIFRleHRvcyBwb3IgZGVmZWN0byBkZWwgYmFubmVyIChmYWxsYmFjayBzaSBsYSBhcHAgbm8gcmVnaXN0cmEgZWwgbmFtZXNwYWNlKS5cbiAqIFNvcG9ydGEgZXMgLyBlbiAvIHB0LlxuICovXG5leHBvcnQgY29uc3QgVVBEQVRFX0JBTk5FUl9ERUZBVUxUX0NPTlRFTlQgPSB7XG4gIGVzOiB7XG4gICAgYXZhaWxhYmxlVGl0bGU6ICdIYXkgdW5hIHZlcnNpw7NuIG51ZXZhIGRpc3BvbmlibGUnLFxuICAgIGF2YWlsYWJsZU1lc3NhZ2U6ICdBY3R1YWxpemEgcGFyYSBvYnRlbmVyIGxhcyDDumx0aW1hcyBtZWpvcmFzLicsXG4gICAgcmVxdWlyZWRUaXRsZTogJ0RlYmVzIGFjdHVhbGl6YXIgcGFyYSBjb250aW51YXInLFxuICAgIHJlcXVpcmVkTWVzc2FnZTogJ0VzdGEgdmVyc2nDs24geWEgbm8gZXMgY29tcGF0aWJsZS4gQWN0dWFsaXphIHBhcmEgc2VndWlyLicsXG4gICAgdXBkYXRlQWN0aW9uOiAnQWN0dWFsaXphcicsXG4gICAgZGlzbWlzc0FjdGlvbjogJ0NlcnJhcicsXG4gIH0sXG4gIGVuOiB7XG4gICAgYXZhaWxhYmxlVGl0bGU6ICdBIG5ldyB2ZXJzaW9uIGlzIGF2YWlsYWJsZScsXG4gICAgYXZhaWxhYmxlTWVzc2FnZTogJ1VwZGF0ZSB0byBnZXQgdGhlIGxhdGVzdCBpbXByb3ZlbWVudHMuJyxcbiAgICByZXF1aXJlZFRpdGxlOiAnWW91IG11c3QgdXBkYXRlIHRvIGNvbnRpbnVlJyxcbiAgICByZXF1aXJlZE1lc3NhZ2U6ICdUaGlzIHZlcnNpb24gaXMgbm8gbG9uZ2VyIHN1cHBvcnRlZC4gUGxlYXNlIHVwZGF0ZS4nLFxuICAgIHVwZGF0ZUFjdGlvbjogJ1VwZGF0ZScsXG4gICAgZGlzbWlzc0FjdGlvbjogJ0Nsb3NlJyxcbiAgfSxcbiAgcHQ6IHtcbiAgICBhdmFpbGFibGVUaXRsZTogJ0jDoSB1bWEgbm92YSB2ZXJzw6NvIGRpc3BvbsOtdmVsJyxcbiAgICBhdmFpbGFibGVNZXNzYWdlOiAnQXR1YWxpemUgcGFyYSBvYnRlciBhcyDDumx0aW1hcyBtZWxob3JpYXMuJyxcbiAgICByZXF1aXJlZFRpdGxlOiAnVm9jw6ogcHJlY2lzYSBhdHVhbGl6YXIgcGFyYSBjb250aW51YXInLFxuICAgIHJlcXVpcmVkTWVzc2FnZTogJ0VzdGEgdmVyc8OjbyBuw6NvIMOpIG1haXMgY29tcGF0w612ZWwuIEF0dWFsaXplIHBhcmEgc2VndWlyLicsXG4gICAgdXBkYXRlQWN0aW9uOiAnQXR1YWxpemFyJyxcbiAgICBkaXNtaXNzQWN0aW9uOiAnRmVjaGFyJyxcbiAgfSxcbn0gYXMgY29uc3Q7XG4iXX0=
|
|
@@ -1,112 +1,243 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* UpdateBannerComponent
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
*
|
|
4
|
+
* Banner que avisa al usuario cuando hay una versión nueva de la app.
|
|
5
|
+
* Consume `AppVersionService` (no toca `SwUpdate` ni `AppConfigService`
|
|
6
|
+
* directamente) y soporta dos modos:
|
|
7
|
+
*
|
|
8
|
+
* - `update-available` — banner descartable: mensaje + botón "Actualizar"
|
|
9
|
+
* + botón cerrar.
|
|
10
|
+
* - `update-required` — overlay bloqueante no-descartable (hard gate):
|
|
11
|
+
* mensaje + botón "Actualizar". Sin botón cerrar.
|
|
12
|
+
*
|
|
13
|
+
* Cuando el estado es `up-to-date` (o el usuario descartó el banner opcional)
|
|
14
|
+
* no renderiza nada.
|
|
6
15
|
*/
|
|
7
16
|
import { CommonModule } from '@angular/common';
|
|
8
|
-
import { Component, computed, inject
|
|
9
|
-
import { BannerComponent } from '../../organisms/banner/banner.component';
|
|
10
|
-
import { AppConfigService } from '../../../services/app-config/app-config.service';
|
|
17
|
+
import { Component, computed, inject } from '@angular/core';
|
|
11
18
|
import { I18nService } from '../../../services/i18n';
|
|
19
|
+
import { AppVersionService } from '../../../services/app-version/app-version.service';
|
|
20
|
+
import { ButtonComponent } from '../../atoms/button/button.component';
|
|
21
|
+
import { IconComponent } from '../../atoms/icon/icon.component';
|
|
22
|
+
import { TextComponent } from '../../atoms/text/text.component';
|
|
23
|
+
import { UPDATE_BANNER_DEFAULT_CONTENT, UPDATE_BANNER_I18N_NAMESPACE } from './types';
|
|
12
24
|
import * as i0 from "@angular/core";
|
|
13
25
|
/**
|
|
14
26
|
* val-update-banner
|
|
15
27
|
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
28
|
+
* Avisa al usuario de una versión nueva. Colócalo una sola vez, alto en el
|
|
29
|
+
* árbol de la app (p.ej. en `app.component` por encima del router outlet)
|
|
30
|
+
* para que sea visible en cualquier ruta.
|
|
18
31
|
*
|
|
19
32
|
* @example
|
|
20
33
|
* ```html
|
|
21
|
-
* <!-- Uso básico -->
|
|
22
34
|
* <val-update-banner />
|
|
23
|
-
*
|
|
24
|
-
* <!-- El banner solo aparece si hay actualización disponible -->
|
|
25
35
|
* ```
|
|
26
36
|
*/
|
|
27
37
|
export class UpdateBannerComponent {
|
|
28
38
|
constructor() {
|
|
29
|
-
this.
|
|
39
|
+
this.version = inject(AppVersionService);
|
|
30
40
|
this.i18n = inject(I18nService);
|
|
31
41
|
/**
|
|
32
|
-
*
|
|
42
|
+
* True cuando el banner está en modo obligatorio (hard gate, no descartable).
|
|
33
43
|
*/
|
|
34
|
-
this.
|
|
44
|
+
this.required = computed(() => this.version.status() === 'update-required');
|
|
35
45
|
/**
|
|
36
|
-
*
|
|
46
|
+
* True cuando el banner debe renderizarse:
|
|
47
|
+
* - siempre que el estado sea `update-required`, o
|
|
48
|
+
* - si es `update-available` y el usuario no lo descartó.
|
|
37
49
|
*/
|
|
38
|
-
this.
|
|
50
|
+
this.visible = computed(() => {
|
|
51
|
+
const status = this.version.status();
|
|
52
|
+
if (status === 'update-required')
|
|
53
|
+
return true;
|
|
54
|
+
if (status === 'update-available')
|
|
55
|
+
return !this.version.dismissed();
|
|
56
|
+
return false;
|
|
57
|
+
});
|
|
39
58
|
/**
|
|
40
|
-
*
|
|
59
|
+
* Textos resolvidos del banner. Reactivo a idioma y al estado required.
|
|
60
|
+
* Usa el namespace `UpdateBanner` de `I18nService` con fallback embebido.
|
|
41
61
|
*/
|
|
42
|
-
this.
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
content: this.i18n.t('clickToUpdate', 'AppConfig'),
|
|
53
|
-
size: 'small',
|
|
54
|
-
color: 'light',
|
|
55
|
-
bold: false,
|
|
56
|
-
},
|
|
57
|
-
},
|
|
58
|
-
actions: {
|
|
59
|
-
position: 'center',
|
|
60
|
-
columned: false,
|
|
61
|
-
buttons: [
|
|
62
|
-
{
|
|
63
|
-
token: 'update',
|
|
64
|
-
text: this.i18n.t('updateNow', 'AppConfig'),
|
|
65
|
-
color: 'light',
|
|
66
|
-
fill: 'outline',
|
|
67
|
-
size: 'small',
|
|
68
|
-
state: 'ENABLED',
|
|
69
|
-
type: 'button',
|
|
70
|
-
},
|
|
71
|
-
],
|
|
72
|
-
},
|
|
73
|
-
}));
|
|
62
|
+
this.t = computed(() => {
|
|
63
|
+
this.i18n.lang(); // track para reactividad
|
|
64
|
+
const isRequired = this.required();
|
|
65
|
+
return {
|
|
66
|
+
title: this.tr(isRequired ? 'requiredTitle' : 'availableTitle'),
|
|
67
|
+
message: this.tr(isRequired ? 'requiredMessage' : 'availableMessage'),
|
|
68
|
+
updateAction: this.tr('updateAction'),
|
|
69
|
+
dismissAction: this.tr('dismissAction'),
|
|
70
|
+
};
|
|
71
|
+
});
|
|
74
72
|
}
|
|
75
|
-
/**
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
73
|
+
/** Aplica la actualización (activa el SW si existe + recarga). */
|
|
74
|
+
onUpdate() {
|
|
75
|
+
void this.version.applyUpdate();
|
|
76
|
+
}
|
|
77
|
+
/** Descarta el banner opcional. No-op en modo obligatorio. */
|
|
78
|
+
onDismiss() {
|
|
79
|
+
this.version.dismiss();
|
|
82
80
|
}
|
|
83
81
|
/**
|
|
84
|
-
*
|
|
82
|
+
* Resuelve una key i18n del namespace `UpdateBanner` con fallback al
|
|
83
|
+
* contenido por defecto embebido (es / en / pt).
|
|
85
84
|
*/
|
|
86
|
-
|
|
87
|
-
this.
|
|
85
|
+
tr(key) {
|
|
86
|
+
const value = this.i18n.t(key, UPDATE_BANNER_I18N_NAMESPACE);
|
|
87
|
+
if (value && !value.startsWith('['))
|
|
88
|
+
return value;
|
|
89
|
+
const lang = this.i18n.lang();
|
|
90
|
+
const pack = UPDATE_BANNER_DEFAULT_CONTENT[lang] ??
|
|
91
|
+
UPDATE_BANNER_DEFAULT_CONTENT.es;
|
|
92
|
+
return pack[key];
|
|
88
93
|
}
|
|
89
94
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UpdateBannerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
90
95
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: UpdateBannerComponent, isStandalone: true, selector: "val-update-banner", ngImport: i0, template: `
|
|
91
|
-
@if (
|
|
92
|
-
<
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
96
|
+
@if (visible()) {
|
|
97
|
+
<div
|
|
98
|
+
class="val-update-banner"
|
|
99
|
+
[class.val-update-banner--required]="required()"
|
|
100
|
+
role="alert"
|
|
101
|
+
[attr.aria-live]="required() ? 'assertive' : 'polite'"
|
|
102
|
+
>
|
|
103
|
+
@if (required()) {
|
|
104
|
+
<div class="val-update-banner__backdrop"></div>
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
<div class="val-update-banner__panel">
|
|
108
|
+
<div class="val-update-banner__icon">
|
|
109
|
+
<val-icon
|
|
110
|
+
[props]="{
|
|
111
|
+
name: required() ? 'warning-outline' : 'cloud-download-outline',
|
|
112
|
+
size: 'large',
|
|
113
|
+
color: required() ? 'warning' : 'primary',
|
|
114
|
+
}"
|
|
115
|
+
/>
|
|
116
|
+
</div>
|
|
117
|
+
|
|
118
|
+
<div class="val-update-banner__body">
|
|
119
|
+
<val-text
|
|
120
|
+
[props]="{
|
|
121
|
+
content: t().title,
|
|
122
|
+
size: 'medium',
|
|
123
|
+
bold: true,
|
|
124
|
+
color: 'dark',
|
|
125
|
+
}"
|
|
126
|
+
/>
|
|
127
|
+
<val-text
|
|
128
|
+
[props]="{
|
|
129
|
+
content: t().message,
|
|
130
|
+
size: 'small',
|
|
131
|
+
bold: false,
|
|
132
|
+
color: 'medium',
|
|
133
|
+
}"
|
|
134
|
+
/>
|
|
135
|
+
</div>
|
|
136
|
+
|
|
137
|
+
<div class="val-update-banner__actions">
|
|
138
|
+
<val-button
|
|
139
|
+
[props]="{
|
|
140
|
+
text: t().updateAction,
|
|
141
|
+
color: 'primary',
|
|
142
|
+
fill: 'solid',
|
|
143
|
+
size: 'small',
|
|
144
|
+
state: 'ENABLED',
|
|
145
|
+
type: 'button',
|
|
146
|
+
}"
|
|
147
|
+
(onClick)="onUpdate()"
|
|
148
|
+
/>
|
|
149
|
+
@if (!required()) {
|
|
150
|
+
<val-button
|
|
151
|
+
[props]="{
|
|
152
|
+
text: t().dismissAction,
|
|
153
|
+
color: 'medium',
|
|
154
|
+
fill: 'clear',
|
|
155
|
+
size: 'small',
|
|
156
|
+
state: 'ENABLED',
|
|
157
|
+
type: 'button',
|
|
158
|
+
}"
|
|
159
|
+
(onClick)="onDismiss()"
|
|
160
|
+
/>
|
|
161
|
+
}
|
|
162
|
+
</div>
|
|
163
|
+
</div>
|
|
164
|
+
</div>
|
|
97
165
|
}
|
|
98
|
-
`, isInline: true, styles: [":host{display:
|
|
166
|
+
`, isInline: true, styles: [":host{display:contents}.val-update-banner{position:fixed;top:0;left:0;right:0;z-index:1100;display:flex;justify-content:center;padding:calc(12px + env(safe-area-inset-top,0px)) 16px 12px;pointer-events:none}.val-update-banner__backdrop{position:fixed;inset:0;z-index:-1;background:#0000008c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:auto}.val-update-banner__panel{pointer-events:auto;display:flex;flex-direction:row;align-items:center;gap:12px;width:100%;max-width:640px;padding:12px 16px;background:var(--ion-background-color, #fff);border:1px solid var(--val-border-color, rgba(0, 0, 0, .08));border-radius:var(--val-border-radius, 12px);box-shadow:0 4px 24px #0000001f;animation:val-update-banner-in .25s ease-out}.val-update-banner--required{align-items:center;height:100%}.val-update-banner--required .val-update-banner__panel{flex-direction:column;text-align:center;max-width:420px}.val-update-banner__icon{flex:0 0 auto;display:inline-flex;align-items:center}.val-update-banner__body{flex:1 1 auto;display:flex;flex-direction:column;gap:2px;min-width:0}.val-update-banner__actions{flex:0 0 auto;display:flex;flex-direction:row;align-items:center;gap:4px}.val-update-banner--required .val-update-banner__actions{margin-top:8px}@keyframes val-update-banner-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 540px){.val-update-banner__panel{flex-direction:column;text-align:center}.val-update-banner__actions{width:100%;justify-content:center}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: TextComponent, selector: "val-text", inputs: ["props"] }, { kind: "component", type: ButtonComponent, selector: "val-button", inputs: ["preset", "props"], outputs: ["onClick"] }, { kind: "component", type: IconComponent, selector: "val-icon", inputs: ["props"] }] }); }
|
|
99
167
|
}
|
|
100
168
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: UpdateBannerComponent, decorators: [{
|
|
101
169
|
type: Component,
|
|
102
|
-
args: [{ selector: 'val-update-banner', standalone: true, imports: [CommonModule,
|
|
103
|
-
@if (
|
|
104
|
-
<
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
170
|
+
args: [{ selector: 'val-update-banner', standalone: true, imports: [CommonModule, TextComponent, ButtonComponent, IconComponent], template: `
|
|
171
|
+
@if (visible()) {
|
|
172
|
+
<div
|
|
173
|
+
class="val-update-banner"
|
|
174
|
+
[class.val-update-banner--required]="required()"
|
|
175
|
+
role="alert"
|
|
176
|
+
[attr.aria-live]="required() ? 'assertive' : 'polite'"
|
|
177
|
+
>
|
|
178
|
+
@if (required()) {
|
|
179
|
+
<div class="val-update-banner__backdrop"></div>
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
<div class="val-update-banner__panel">
|
|
183
|
+
<div class="val-update-banner__icon">
|
|
184
|
+
<val-icon
|
|
185
|
+
[props]="{
|
|
186
|
+
name: required() ? 'warning-outline' : 'cloud-download-outline',
|
|
187
|
+
size: 'large',
|
|
188
|
+
color: required() ? 'warning' : 'primary',
|
|
189
|
+
}"
|
|
190
|
+
/>
|
|
191
|
+
</div>
|
|
192
|
+
|
|
193
|
+
<div class="val-update-banner__body">
|
|
194
|
+
<val-text
|
|
195
|
+
[props]="{
|
|
196
|
+
content: t().title,
|
|
197
|
+
size: 'medium',
|
|
198
|
+
bold: true,
|
|
199
|
+
color: 'dark',
|
|
200
|
+
}"
|
|
201
|
+
/>
|
|
202
|
+
<val-text
|
|
203
|
+
[props]="{
|
|
204
|
+
content: t().message,
|
|
205
|
+
size: 'small',
|
|
206
|
+
bold: false,
|
|
207
|
+
color: 'medium',
|
|
208
|
+
}"
|
|
209
|
+
/>
|
|
210
|
+
</div>
|
|
211
|
+
|
|
212
|
+
<div class="val-update-banner__actions">
|
|
213
|
+
<val-button
|
|
214
|
+
[props]="{
|
|
215
|
+
text: t().updateAction,
|
|
216
|
+
color: 'primary',
|
|
217
|
+
fill: 'solid',
|
|
218
|
+
size: 'small',
|
|
219
|
+
state: 'ENABLED',
|
|
220
|
+
type: 'button',
|
|
221
|
+
}"
|
|
222
|
+
(onClick)="onUpdate()"
|
|
223
|
+
/>
|
|
224
|
+
@if (!required()) {
|
|
225
|
+
<val-button
|
|
226
|
+
[props]="{
|
|
227
|
+
text: t().dismissAction,
|
|
228
|
+
color: 'medium',
|
|
229
|
+
fill: 'clear',
|
|
230
|
+
size: 'small',
|
|
231
|
+
state: 'ENABLED',
|
|
232
|
+
type: 'button',
|
|
233
|
+
}"
|
|
234
|
+
(onClick)="onDismiss()"
|
|
235
|
+
/>
|
|
236
|
+
}
|
|
237
|
+
</div>
|
|
238
|
+
</div>
|
|
239
|
+
</div>
|
|
109
240
|
}
|
|
110
|
-
`, styles: [":host{display:
|
|
241
|
+
`, styles: [":host{display:contents}.val-update-banner{position:fixed;top:0;left:0;right:0;z-index:1100;display:flex;justify-content:center;padding:calc(12px + env(safe-area-inset-top,0px)) 16px 12px;pointer-events:none}.val-update-banner__backdrop{position:fixed;inset:0;z-index:-1;background:#0000008c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:auto}.val-update-banner__panel{pointer-events:auto;display:flex;flex-direction:row;align-items:center;gap:12px;width:100%;max-width:640px;padding:12px 16px;background:var(--ion-background-color, #fff);border:1px solid var(--val-border-color, rgba(0, 0, 0, .08));border-radius:var(--val-border-radius, 12px);box-shadow:0 4px 24px #0000001f;animation:val-update-banner-in .25s ease-out}.val-update-banner--required{align-items:center;height:100%}.val-update-banner--required .val-update-banner__panel{flex-direction:column;text-align:center;max-width:420px}.val-update-banner__icon{flex:0 0 auto;display:inline-flex;align-items:center}.val-update-banner__body{flex:1 1 auto;display:flex;flex-direction:column;gap:2px;min-width:0}.val-update-banner__actions{flex:0 0 auto;display:flex;flex-direction:row;align-items:center;gap:4px}.val-update-banner--required .val-update-banner__actions{margin-top:8px}@keyframes val-update-banner-in{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 540px){.val-update-banner__panel{flex-direction:column;text-align:center}.val-update-banner__actions{width:100%;justify-content:center}}\n"] }]
|
|
111
242
|
}] });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLWJhbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3VwZGF0ZS1iYW5uZXIvdXBkYXRlLWJhbm5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFFSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDbkYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQUdyRDs7Ozs7Ozs7Ozs7OztHQWFHO0FBc0JILE1BQU0sT0FBTyxxQkFBcUI7SUFyQmxDO1FBc0JVLGNBQVMsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUNyQyxTQUFJLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBRW5DOztXQUVHO1FBQ0ssY0FBUyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUVsQzs7V0FFRztRQUNNLFNBQUksR0FBRyxRQUFRLENBQ3RCLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQ3RELENBQUM7UUFFRjs7V0FFRztRQUNNLGdCQUFXLEdBQUcsUUFBUSxDQUFpQixHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3JELEtBQUssRUFBRSxTQUFTO1lBQ2hCLFFBQVEsRUFBRSxLQUFLO1lBQ2YsUUFBUSxFQUFFLElBQUk7WUFDZCxJQUFJLEVBQUUsUUFBUTtZQUNkLFNBQVMsRUFBRSxRQUFRO1lBQ25CLE9BQU8sRUFBRSxhQUFhO1lBQ3RCLE9BQU8sRUFBRTtnQkFDUCxRQUFRLEVBQUUsUUFBUTtnQkFDbEIsS0FBSyxFQUFFO29CQUNMLE9BQU8sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxlQUFlLEVBQUUsV0FBVyxDQUFDO29CQUNsRCxJQUFJLEVBQUUsT0FBTztvQkFDYixLQUFLLEVBQUUsT0FBTztvQkFDZCxJQUFJLEVBQUUsS0FBSztpQkFDWjthQUNGO1lBQ0QsT0FBTyxFQUFFO2dCQUNQLFFBQVEsRUFBRSxRQUFRO2dCQUNsQixRQUFRLEVBQUUsS0FBSztnQkFDZixPQUFPLEVBQUU7b0JBQ1A7d0JBQ0UsS0FBSyxFQUFFLFFBQVE7d0JBQ2YsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxXQUFXLENBQUM7d0JBQzNDLEtBQUssRUFBRSxPQUFPO3dCQUNkLElBQUksRUFBRSxTQUFTO3dCQUNmLElBQUksRUFBRSxPQUFPO3dCQUNiLEtBQUssRUFBRSxTQUFTO3dCQUNoQixJQUFJLEVBQUUsUUFBUTtxQkFDZjtpQkFDRjthQUNGO1NBQ0YsQ0FBQyxDQUFDLENBQUM7S0FpQkw7SUFmQzs7T0FFRztJQUNILFFBQVEsQ0FBQyxLQUFhO1FBQ3BCLElBQUksS0FBSyxLQUFLLFFBQVEsRUFBRSxDQUFDO1lBQ3ZCLE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDM0IsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNILE9BQU87UUFDTCxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMzQixDQUFDOytHQWxFVSxxQkFBcUI7bUdBQXJCLHFCQUFxQiw2RUFqQnRCOzs7Ozs7OztHQVFULCtGQVRTLFlBQVksK0JBQUUsZUFBZTs7NEZBa0I1QixxQkFBcUI7a0JBckJqQyxTQUFTOytCQUNFLG1CQUFtQixjQUNqQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFlBQzlCOzs7Ozs7OztHQVFUIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBVcGRhdGVCYW5uZXJDb21wb25lbnRcbiAqXG4gKiBDb21wb25lbnRlIHF1ZSBtdWVzdHJhIHVuIGJhbm5lciBjdWFuZG8gaGF5IHVuYSBudWV2YSB2ZXJzacOzbiBkZSBsYSBhcGxpY2FjacOzbiBkaXNwb25pYmxlLlxuICogU2UgaW50ZWdyYSBhdXRvbcOhdGljYW1lbnRlIGNvbiBBcHBDb25maWdTZXJ2aWNlIHBhcmEgZGV0ZWN0YXIgYWN0dWFsaXphY2lvbmVzLlxuICovXG5cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIGNvbXB1dGVkLCBpbmplY3QsIHNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBCYW5uZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi9vcmdhbmlzbXMvYmFubmVyL2Jhbm5lci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXBwQ29uZmlnU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FwcC1jb25maWcvYXBwLWNvbmZpZy5zZXJ2aWNlJztcbmltcG9ydCB7IEkxOG5TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvaTE4bic7XG5pbXBvcnQgeyBCYW5uZXJNZXRhZGF0YSB9IGZyb20gJy4uLy4uL29yZ2FuaXNtcy9iYW5uZXIvdHlwZXMnO1xuXG4vKipcbiAqIHZhbC11cGRhdGUtYmFubmVyXG4gKlxuICogQmFubmVyIGRlIGFjdHVhbGl6YWNpw7NuIHF1ZSBhcGFyZWNlIGN1YW5kbyBoYXkgdW5hIG51ZXZhIHZlcnNpw7NuIGRpc3BvbmlibGUuXG4gKiBTZSBjaWVycmEgYXV0b23DoXRpY2FtZW50ZSBjdWFuZG8gZWwgdXN1YXJpbyBoYWNlIGNsaWMgZW4gXCJBY3R1YWxpemFyXCIgbyBlbiBjZXJyYXIuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYGh0bWxcbiAqIDwhLS0gVXNvIGLDoXNpY28gLS0+XG4gKiA8dmFsLXVwZGF0ZS1iYW5uZXIgLz5cbiAqXG4gKiA8IS0tIEVsIGJhbm5lciBzb2xvIGFwYXJlY2Ugc2kgaGF5IGFjdHVhbGl6YWNpw7NuIGRpc3BvbmlibGUgLS0+XG4gKiBgYGBcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXVwZGF0ZS1iYW5uZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBCYW5uZXJDb21wb25lbnRdLFxuICB0ZW1wbGF0ZTogYFxuICAgIEBpZiAoc2hvdygpKSB7XG4gICAgICA8dmFsLWJhbm5lclxuICAgICAgICBbcHJvcHNdPVwiYmFubmVyUHJvcHMoKVwiXG4gICAgICAgIChvbkNsaWNrKT1cIm9uQWN0aW9uKCRldmVudClcIlxuICAgICAgICAob25DbG9zZSk9XCJkaXNtaXNzKClcIlxuICAgICAgLz5cbiAgICB9XG4gIGAsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIDpob3N0IHtcbiAgICAgICAgZGlzcGxheTogYmxvY2s7XG4gICAgICB9XG4gICAgYCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVXBkYXRlQmFubmVyQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBhcHBDb25maWcgPSBpbmplY3QoQXBwQ29uZmlnU2VydmljZSk7XG4gIHByaXZhdGUgaTE4biA9IGluamVjdChJMThuU2VydmljZSk7XG5cbiAgLyoqXG4gICAqIFNpZ25hbCBwYXJhIGNvbnRyb2xhciBzaSBlbCBiYW5uZXIgZnVlIGRlc2NhcnRhZG8gcG9yIGVsIHVzdWFyaW8uXG4gICAqL1xuICBwcml2YXRlIGRpc21pc3NlZCA9IHNpZ25hbChmYWxzZSk7XG5cbiAgLyoqXG4gICAqIEluZGljYSBzaSBlbCBiYW5uZXIgZGViZSBtb3N0cmFyc2UuXG4gICAqL1xuICByZWFkb25seSBzaG93ID0gY29tcHV0ZWQoXG4gICAgKCkgPT4gdGhpcy5hcHBDb25maWcuaGFzVXBkYXRlKCkgJiYgIXRoaXMuZGlzbWlzc2VkKClcbiAgKTtcblxuICAvKipcbiAgICogUHJvcHMgZGVsIGJhbm5lciBjYWxjdWxhZGFzIHJlYWN0aXZhbWVudGUuXG4gICAqL1xuICByZWFkb25seSBiYW5uZXJQcm9wcyA9IGNvbXB1dGVkPEJhbm5lck1ldGFkYXRhPigoKSA9PiAoe1xuICAgIGNvbG9yOiAncHJpbWFyeScsXG4gICAgYm9yZGVyZWQ6IGZhbHNlLFxuICAgIGNsb3NhYmxlOiB0cnVlLFxuICAgIG1vZGU6ICdjZW50ZXInLFxuICAgIGFsaWdubWVudDogJ2NlbnRlcicsXG4gICAgcGFkZGluZzogJzAuNXJlbSAxcmVtJyxcbiAgICBjb250ZW50OiB7XG4gICAgICBwb3NpdGlvbjogJ2NlbnRlcicsXG4gICAgICB0aXRsZToge1xuICAgICAgICBjb250ZW50OiB0aGlzLmkxOG4udCgnY2xpY2tUb1VwZGF0ZScsICdBcHBDb25maWcnKSxcbiAgICAgICAgc2l6ZTogJ3NtYWxsJyxcbiAgICAgICAgY29sb3I6ICdsaWdodCcsXG4gICAgICAgIGJvbGQ6IGZhbHNlLFxuICAgICAgfSxcbiAgICB9LFxuICAgIGFjdGlvbnM6IHtcbiAgICAgIHBvc2l0aW9uOiAnY2VudGVyJyxcbiAgICAgIGNvbHVtbmVkOiBmYWxzZSxcbiAgICAgIGJ1dHRvbnM6IFtcbiAgICAgICAge1xuICAgICAgICAgIHRva2VuOiAndXBkYXRlJyxcbiAgICAgICAgICB0ZXh0OiB0aGlzLmkxOG4udCgndXBkYXRlTm93JywgJ0FwcENvbmZpZycpLFxuICAgICAgICAgIGNvbG9yOiAnbGlnaHQnLFxuICAgICAgICAgIGZpbGw6ICdvdXRsaW5lJyxcbiAgICAgICAgICBzaXplOiAnc21hbGwnLFxuICAgICAgICAgIHN0YXRlOiAnRU5BQkxFRCcsXG4gICAgICAgICAgdHlwZTogJ2J1dHRvbicsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0sXG4gIH0pKTtcblxuICAvKipcbiAgICogTWFuZWphIGVsIGNsaWMgZW4gYWNjaW9uZXMgZGVsIGJhbm5lci5cbiAgICovXG4gIG9uQWN0aW9uKHRva2VuOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAodG9rZW4gPT09ICd1cGRhdGUnKSB7XG4gICAgICB3aW5kb3cubG9jYXRpb24ucmVsb2FkKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIERlc2NhcnRhIGVsIGJhbm5lciB0ZW1wb3JhbG1lbnRlIChoYXN0YSBxdWUgc2UgcmVjYXJndWUgbGEgcMOhZ2luYSkuXG4gICAqL1xuICBkaXNtaXNzKCk6IHZvaWQge1xuICAgIHRoaXMuZGlzbWlzc2VkLnNldCh0cnVlKTtcbiAgfVxufVxuIl19
|
|
243
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLWJhbm5lci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbW9sZWN1bGVzL3VwZGF0ZS1iYW5uZXIvdXBkYXRlLWJhbm5lci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7Ozs7Ozs7Ozs7O0dBY0c7QUFFSCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTVELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN0RixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNoRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxTQUFTLENBQUM7O0FBRXRGOzs7Ozs7Ozs7OztHQVdHO0FBK0VILE1BQU0sT0FBTyxxQkFBcUI7SUE5RWxDO1FBK0VtQixZQUFPLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDcEMsU0FBSSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUU1Qzs7V0FFRztRQUNNLGFBQVEsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsS0FBSyxpQkFBaUIsQ0FBQyxDQUFDO1FBRWhGOzs7O1dBSUc7UUFDTSxZQUFPLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUMvQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3JDLElBQUksTUFBTSxLQUFLLGlCQUFpQjtnQkFBRSxPQUFPLElBQUksQ0FBQztZQUM5QyxJQUFJLE1BQU0sS0FBSyxrQkFBa0I7Z0JBQUUsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDcEUsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDLENBQUMsQ0FBQztRQUVIOzs7V0FHRztRQUNNLE1BQUMsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3pCLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyx5QkFBeUI7WUFDM0MsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ25DLE9BQU87Z0JBQ0wsS0FBSyxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLGdCQUFnQixDQUFDO2dCQUMvRCxPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQztnQkFDckUsWUFBWSxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDO2dCQUNyQyxhQUFhLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQyxlQUFlLENBQUM7YUFDeEMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO0tBMEJKO0lBeEJDLGtFQUFrRTtJQUNsRSxRQUFRO1FBQ04sS0FBSyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFRCw4REFBOEQ7SUFDOUQsU0FBUztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVEOzs7T0FHRztJQUNLLEVBQUUsQ0FBQyxHQUFrRDtRQUMzRCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsNEJBQTRCLENBQUMsQ0FBQztRQUM3RCxJQUFJLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFFbEQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM5QixNQUFNLElBQUksR0FDUiw2QkFBNkIsQ0FBQyxJQUFrRCxDQUFDO1lBQ2pGLDZCQUE2QixDQUFDLEVBQUUsQ0FBQztRQUNuQyxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQixDQUFDOytHQTNEVSxxQkFBcUI7bUdBQXJCLHFCQUFxQiw2RUExRXRCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVFVCx1a0RBeEVTLFlBQVksK0JBQUUsYUFBYSx3RUFBRSxlQUFlLDBHQUFFLGFBQWE7OzRGQTJFMUQscUJBQXFCO2tCQTlFakMsU0FBUzsrQkFDRSxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSxlQUFlLEVBQUUsYUFBYSxDQUFDLFlBQzVEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVFVCIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogVXBkYXRlQmFubmVyQ29tcG9uZW50XG4gKlxuICogQmFubmVyIHF1ZSBhdmlzYSBhbCB1c3VhcmlvIGN1YW5kbyBoYXkgdW5hIHZlcnNpw7NuIG51ZXZhIGRlIGxhIGFwcC5cbiAqIENvbnN1bWUgYEFwcFZlcnNpb25TZXJ2aWNlYCAobm8gdG9jYSBgU3dVcGRhdGVgIG5pIGBBcHBDb25maWdTZXJ2aWNlYFxuICogZGlyZWN0YW1lbnRlKSB5IHNvcG9ydGEgZG9zIG1vZG9zOlxuICpcbiAqIC0gYHVwZGF0ZS1hdmFpbGFibGVgIOKAlCBiYW5uZXIgZGVzY2FydGFibGU6IG1lbnNhamUgKyBib3TDs24gXCJBY3R1YWxpemFyXCJcbiAqICAgKyBib3TDs24gY2VycmFyLlxuICogLSBgdXBkYXRlLXJlcXVpcmVkYCDigJQgb3ZlcmxheSBibG9xdWVhbnRlIG5vLWRlc2NhcnRhYmxlIChoYXJkIGdhdGUpOlxuICogICBtZW5zYWplICsgYm90w7NuIFwiQWN0dWFsaXphclwiLiBTaW4gYm90w7NuIGNlcnJhci5cbiAqXG4gKiBDdWFuZG8gZWwgZXN0YWRvIGVzIGB1cC10by1kYXRlYCAobyBlbCB1c3VhcmlvIGRlc2NhcnTDsyBlbCBiYW5uZXIgb3BjaW9uYWwpXG4gKiBubyByZW5kZXJpemEgbmFkYS5cbiAqL1xuXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEkxOG5TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvaTE4bic7XG5pbXBvcnQgeyBBcHBWZXJzaW9uU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FwcC12ZXJzaW9uL2FwcC12ZXJzaW9uLnNlcnZpY2UnO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vYXRvbXMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgSWNvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL2ljb24vaWNvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGV4dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2F0b21zL3RleHQvdGV4dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVVBEQVRFX0JBTk5FUl9ERUZBVUxUX0NPTlRFTlQsIFVQREFURV9CQU5ORVJfSTE4Tl9OQU1FU1BBQ0UgfSBmcm9tICcuL3R5cGVzJztcblxuLyoqXG4gKiB2YWwtdXBkYXRlLWJhbm5lclxuICpcbiAqIEF2aXNhIGFsIHVzdWFyaW8gZGUgdW5hIHZlcnNpw7NuIG51ZXZhLiBDb2zDs2NhbG8gdW5hIHNvbGEgdmV6LCBhbHRvIGVuIGVsXG4gKiDDoXJib2wgZGUgbGEgYXBwIChwLmVqLiBlbiBgYXBwLmNvbXBvbmVudGAgcG9yIGVuY2ltYSBkZWwgcm91dGVyIG91dGxldClcbiAqIHBhcmEgcXVlIHNlYSB2aXNpYmxlIGVuIGN1YWxxdWllciBydXRhLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBodG1sXG4gKiA8dmFsLXVwZGF0ZS1iYW5uZXIgLz5cbiAqIGBgYFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd2YWwtdXBkYXRlLWJhbm5lcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRleHRDb21wb25lbnQsIEJ1dHRvbkNvbXBvbmVudCwgSWNvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgQGlmICh2aXNpYmxlKCkpIHtcbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3M9XCJ2YWwtdXBkYXRlLWJhbm5lclwiXG4gICAgICAgIFtjbGFzcy52YWwtdXBkYXRlLWJhbm5lci0tcmVxdWlyZWRdPVwicmVxdWlyZWQoKVwiXG4gICAgICAgIHJvbGU9XCJhbGVydFwiXG4gICAgICAgIFthdHRyLmFyaWEtbGl2ZV09XCJyZXF1aXJlZCgpID8gJ2Fzc2VydGl2ZScgOiAncG9saXRlJ1wiXG4gICAgICA+XG4gICAgICAgIEBpZiAocmVxdWlyZWQoKSkge1xuICAgICAgICAgIDxkaXYgY2xhc3M9XCJ2YWwtdXBkYXRlLWJhbm5lcl9fYmFja2Ryb3BcIj48L2Rpdj5cbiAgICAgICAgfVxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJ2YWwtdXBkYXRlLWJhbm5lcl9fcGFuZWxcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwidmFsLXVwZGF0ZS1iYW5uZXJfX2ljb25cIj5cbiAgICAgICAgICAgIDx2YWwtaWNvblxuICAgICAgICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgICAgICAgIG5hbWU6IHJlcXVpcmVkKCkgPyAnd2FybmluZy1vdXRsaW5lJyA6ICdjbG91ZC1kb3dubG9hZC1vdXRsaW5lJyxcbiAgICAgICAgICAgICAgICBzaXplOiAnbGFyZ2UnLFxuICAgICAgICAgICAgICAgIGNvbG9yOiByZXF1aXJlZCgpID8gJ3dhcm5pbmcnIDogJ3ByaW1hcnknLFxuICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwidmFsLXVwZGF0ZS1iYW5uZXJfX2JvZHlcIj5cbiAgICAgICAgICAgIDx2YWwtdGV4dFxuICAgICAgICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgICAgICAgIGNvbnRlbnQ6IHQoKS50aXRsZSxcbiAgICAgICAgICAgICAgICBzaXplOiAnbWVkaXVtJyxcbiAgICAgICAgICAgICAgICBib2xkOiB0cnVlLFxuICAgICAgICAgICAgICAgIGNvbG9yOiAnZGFyaycsXG4gICAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIDx2YWwtdGV4dFxuICAgICAgICAgICAgICBbcHJvcHNdPVwie1xuICAgICAgICAgICAgICAgIGNvbnRlbnQ6IHQoKS5tZXNzYWdlLFxuICAgICAgICAgICAgICAgIHNpemU6ICdzbWFsbCcsXG4gICAgICAgICAgICAgICAgYm9sZDogZmFsc2UsXG4gICAgICAgICAgICAgICAgY29sb3I6ICdtZWRpdW0nLFxuICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwidmFsLXVwZGF0ZS1iYW5uZXJfX2FjdGlvbnNcIj5cbiAgICAgICAgICAgIDx2YWwtYnV0dG9uXG4gICAgICAgICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgICAgICAgdGV4dDogdCgpLnVwZGF0ZUFjdGlvbixcbiAgICAgICAgICAgICAgICBjb2xvcjogJ3ByaW1hcnknLFxuICAgICAgICAgICAgICAgIGZpbGw6ICdzb2xpZCcsXG4gICAgICAgICAgICAgICAgc2l6ZTogJ3NtYWxsJyxcbiAgICAgICAgICAgICAgICBzdGF0ZTogJ0VOQUJMRUQnLFxuICAgICAgICAgICAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgICAgICAgICB9XCJcbiAgICAgICAgICAgICAgKG9uQ2xpY2spPVwib25VcGRhdGUoKVwiXG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAgQGlmICghcmVxdWlyZWQoKSkge1xuICAgICAgICAgICAgICA8dmFsLWJ1dHRvblxuICAgICAgICAgICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgICAgICAgICB0ZXh0OiB0KCkuZGlzbWlzc0FjdGlvbixcbiAgICAgICAgICAgICAgICAgIGNvbG9yOiAnbWVkaXVtJyxcbiAgICAgICAgICAgICAgICAgIGZpbGw6ICdjbGVhcicsXG4gICAgICAgICAgICAgICAgICBzaXplOiAnc21hbGwnLFxuICAgICAgICAgICAgICAgICAgc3RhdGU6ICdFTkFCTEVEJyxcbiAgICAgICAgICAgICAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgICAgIChvbkNsaWNrKT1cIm9uRGlzbWlzcygpXCJcbiAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIH1cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICB9XG4gIGAsXG4gIHN0eWxlVXJsczogWycuL3VwZGF0ZS1iYW5uZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgVXBkYXRlQmFubmVyQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSByZWFkb25seSB2ZXJzaW9uID0gaW5qZWN0KEFwcFZlcnNpb25TZXJ2aWNlKTtcbiAgcHJpdmF0ZSByZWFkb25seSBpMThuID0gaW5qZWN0KEkxOG5TZXJ2aWNlKTtcblxuICAvKipcbiAgICogVHJ1ZSBjdWFuZG8gZWwgYmFubmVyIGVzdMOhIGVuIG1vZG8gb2JsaWdhdG9yaW8gKGhhcmQgZ2F0ZSwgbm8gZGVzY2FydGFibGUpLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVxdWlyZWQgPSBjb21wdXRlZCgoKSA9PiB0aGlzLnZlcnNpb24uc3RhdHVzKCkgPT09ICd1cGRhdGUtcmVxdWlyZWQnKTtcblxuICAvKipcbiAgICogVHJ1ZSBjdWFuZG8gZWwgYmFubmVyIGRlYmUgcmVuZGVyaXphcnNlOlxuICAgKiAtIHNpZW1wcmUgcXVlIGVsIGVzdGFkbyBzZWEgYHVwZGF0ZS1yZXF1aXJlZGAsIG9cbiAgICogLSBzaSBlcyBgdXBkYXRlLWF2YWlsYWJsZWAgeSBlbCB1c3VhcmlvIG5vIGxvIGRlc2NhcnTDsy5cbiAgICovXG4gIHJlYWRvbmx5IHZpc2libGUgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgY29uc3Qgc3RhdHVzID0gdGhpcy52ZXJzaW9uLnN0YXR1cygpO1xuICAgIGlmIChzdGF0dXMgPT09ICd1cGRhdGUtcmVxdWlyZWQnKSByZXR1cm4gdHJ1ZTtcbiAgICBpZiAoc3RhdHVzID09PSAndXBkYXRlLWF2YWlsYWJsZScpIHJldHVybiAhdGhpcy52ZXJzaW9uLmRpc21pc3NlZCgpO1xuICAgIHJldHVybiBmYWxzZTtcbiAgfSk7XG5cbiAgLyoqXG4gICAqIFRleHRvcyByZXNvbHZpZG9zIGRlbCBiYW5uZXIuIFJlYWN0aXZvIGEgaWRpb21hIHkgYWwgZXN0YWRvIHJlcXVpcmVkLlxuICAgKiBVc2EgZWwgbmFtZXNwYWNlIGBVcGRhdGVCYW5uZXJgIGRlIGBJMThuU2VydmljZWAgY29uIGZhbGxiYWNrIGVtYmViaWRvLlxuICAgKi9cbiAgcmVhZG9ubHkgdCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICB0aGlzLmkxOG4ubGFuZygpOyAvLyB0cmFjayBwYXJhIHJlYWN0aXZpZGFkXG4gICAgY29uc3QgaXNSZXF1aXJlZCA9IHRoaXMucmVxdWlyZWQoKTtcbiAgICByZXR1cm4ge1xuICAgICAgdGl0bGU6IHRoaXMudHIoaXNSZXF1aXJlZCA/ICdyZXF1aXJlZFRpdGxlJyA6ICdhdmFpbGFibGVUaXRsZScpLFxuICAgICAgbWVzc2FnZTogdGhpcy50cihpc1JlcXVpcmVkID8gJ3JlcXVpcmVkTWVzc2FnZScgOiAnYXZhaWxhYmxlTWVzc2FnZScpLFxuICAgICAgdXBkYXRlQWN0aW9uOiB0aGlzLnRyKCd1cGRhdGVBY3Rpb24nKSxcbiAgICAgIGRpc21pc3NBY3Rpb246IHRoaXMudHIoJ2Rpc21pc3NBY3Rpb24nKSxcbiAgICB9O1xuICB9KTtcblxuICAvKiogQXBsaWNhIGxhIGFjdHVhbGl6YWNpw7NuIChhY3RpdmEgZWwgU1cgc2kgZXhpc3RlICsgcmVjYXJnYSkuICovXG4gIG9uVXBkYXRlKCk6IHZvaWQge1xuICAgIHZvaWQgdGhpcy52ZXJzaW9uLmFwcGx5VXBkYXRlKCk7XG4gIH1cblxuICAvKiogRGVzY2FydGEgZWwgYmFubmVyIG9wY2lvbmFsLiBOby1vcCBlbiBtb2RvIG9ibGlnYXRvcmlvLiAqL1xuICBvbkRpc21pc3MoKTogdm9pZCB7XG4gICAgdGhpcy52ZXJzaW9uLmRpc21pc3MoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXN1ZWx2ZSB1bmEga2V5IGkxOG4gZGVsIG5hbWVzcGFjZSBgVXBkYXRlQmFubmVyYCBjb24gZmFsbGJhY2sgYWxcbiAgICogY29udGVuaWRvIHBvciBkZWZlY3RvIGVtYmViaWRvIChlcyAvIGVuIC8gcHQpLlxuICAgKi9cbiAgcHJpdmF0ZSB0cihrZXk6IGtleW9mIHR5cGVvZiBVUERBVEVfQkFOTkVSX0RFRkFVTFRfQ09OVEVOVC5lcyk6IHN0cmluZyB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLmkxOG4udChrZXksIFVQREFURV9CQU5ORVJfSTE4Tl9OQU1FU1BBQ0UpO1xuICAgIGlmICh2YWx1ZSAmJiAhdmFsdWUuc3RhcnRzV2l0aCgnWycpKSByZXR1cm4gdmFsdWU7XG5cbiAgICBjb25zdCBsYW5nID0gdGhpcy5pMThuLmxhbmcoKTtcbiAgICBjb25zdCBwYWNrID1cbiAgICAgIFVQREFURV9CQU5ORVJfREVGQVVMVF9DT05URU5UW2xhbmcgYXMga2V5b2YgdHlwZW9mIFVQREFURV9CQU5ORVJfREVGQVVMVF9DT05URU5UXSA/P1xuICAgICAgVVBEQVRFX0JBTk5FUl9ERUZBVUxUX0NPTlRFTlQuZXM7XG4gICAgcmV0dXJuIHBhY2tba2V5XTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, computed, Input, signal } from '@angular/core';
|
|
3
|
+
import { AccordionComponent } from '../../molecules/accordion/accordion.component';
|
|
4
|
+
import { SearchbarComponent } from '../../molecules/searchbar/searchbar.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* `val-faq`
|
|
8
|
+
*
|
|
9
|
+
* Organism de preguntas frecuentes. Q&A categorizado con accordion colapsable
|
|
10
|
+
* y buscador en vivo. Pensado para vistas FAQ públicas — el caller puede
|
|
11
|
+
* reusar la misma data (`FaqMetadata.categories`) para emitir el structured
|
|
12
|
+
* data `FAQPage` (JSON-LD) y ganar rich results en buscadores.
|
|
13
|
+
*
|
|
14
|
+
* Compone `val-accordion` (una por categoría) + `val-searchbar`.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```html
|
|
18
|
+
* <val-faq [props]="{ categories: faqCategories, searchable: true }" />
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export class FaqComponent {
|
|
22
|
+
constructor() {
|
|
23
|
+
this.props_ = signal({ categories: [] });
|
|
24
|
+
/** Término de búsqueda actual (lowercase). */
|
|
25
|
+
this.query = signal('');
|
|
26
|
+
/**
|
|
27
|
+
* Categorías visibles tras aplicar el filtro de búsqueda. Una categoría
|
|
28
|
+
* desaparece si ninguna de sus preguntas matchea. El match es sobre
|
|
29
|
+
* pregunta + respuesta, case-insensitive.
|
|
30
|
+
*/
|
|
31
|
+
this.visibleCategories = computed(() => {
|
|
32
|
+
const q = this.query().trim().toLowerCase();
|
|
33
|
+
const cats = this.props_().categories ?? [];
|
|
34
|
+
if (!q)
|
|
35
|
+
return cats;
|
|
36
|
+
return cats
|
|
37
|
+
.map(cat => ({
|
|
38
|
+
...cat,
|
|
39
|
+
items: cat.items.filter(it => it.question.toLowerCase().includes(q) || it.answer.toLowerCase().includes(q)),
|
|
40
|
+
}))
|
|
41
|
+
.filter(cat => cat.items.length > 0);
|
|
42
|
+
});
|
|
43
|
+
/** `true` si se debe mostrar el label de cada categoría. */
|
|
44
|
+
this.showCategoryLabel = computed(() => {
|
|
45
|
+
const p = this.props_();
|
|
46
|
+
if (p.hideSingleCategoryLabel === false)
|
|
47
|
+
return true;
|
|
48
|
+
return (p.categories?.length ?? 0) > 1;
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
set props(value) {
|
|
52
|
+
if (value)
|
|
53
|
+
this.props_.set(value);
|
|
54
|
+
}
|
|
55
|
+
get props() {
|
|
56
|
+
return this.props_();
|
|
57
|
+
}
|
|
58
|
+
/** Mapea una categoría a `AccordionMetadata` para `val-accordion`. */
|
|
59
|
+
accordionFor(cat) {
|
|
60
|
+
return {
|
|
61
|
+
multiple: this.props_().multiple ?? false,
|
|
62
|
+
expandIconSlot: 'end',
|
|
63
|
+
items: cat.items.map(it => ({
|
|
64
|
+
value: it.id,
|
|
65
|
+
header: it.question,
|
|
66
|
+
content: it.answer,
|
|
67
|
+
})),
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
onSearch(term) {
|
|
71
|
+
this.query.set(term ?? '');
|
|
72
|
+
}
|
|
73
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FaqComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: FaqComponent, isStandalone: true, selector: "val-faq", inputs: { props: "props" }, ngImport: i0, template: `
|
|
75
|
+
<div class="val-faq">
|
|
76
|
+
@if (props.searchable !== false) {
|
|
77
|
+
<div class="val-faq__search">
|
|
78
|
+
<val-searchbar
|
|
79
|
+
[props]="{
|
|
80
|
+
placeholder: props.searchPlaceholder || '',
|
|
81
|
+
debounce: 200,
|
|
82
|
+
}"
|
|
83
|
+
(filterEvent)="onSearch($event)"
|
|
84
|
+
/>
|
|
85
|
+
</div>
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@if (visibleCategories().length === 0) {
|
|
89
|
+
<p class="val-faq__empty">{{ props.noResultsText || 'Sin resultados' }}</p>
|
|
90
|
+
} @else {
|
|
91
|
+
@for (cat of visibleCategories(); track cat.id) {
|
|
92
|
+
<section class="val-faq__category">
|
|
93
|
+
@if (showCategoryLabel()) {
|
|
94
|
+
<h3 class="val-faq__category-label">{{ cat.label }}</h3>
|
|
95
|
+
}
|
|
96
|
+
<val-accordion [props]="accordionFor(cat)" />
|
|
97
|
+
</section>
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
</div>
|
|
101
|
+
`, isInline: true, styles: [":host{display:block;width:100%}.val-faq__search{margin-bottom:16px}.val-faq__category+.val-faq__category{margin-top:24px}.val-faq__category-label{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ion-color-medium, #92949c);margin:0 0 8px;padding-inline:4px}.val-faq__empty{text-align:center;padding:32px 16px;color:var(--ion-color-medium, #92949c);font-size:.95rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: AccordionComponent, selector: "val-accordion", inputs: ["preset", "props"], outputs: ["accordionChange"] }, { kind: "component", type: SearchbarComponent, selector: "val-searchbar", inputs: ["preset", "props"], outputs: ["filterEvent", "focusEvent", "blurEvent"] }] }); }
|
|
102
|
+
}
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: FaqComponent, decorators: [{
|
|
104
|
+
type: Component,
|
|
105
|
+
args: [{ selector: 'val-faq', standalone: true, imports: [CommonModule, AccordionComponent, SearchbarComponent], template: `
|
|
106
|
+
<div class="val-faq">
|
|
107
|
+
@if (props.searchable !== false) {
|
|
108
|
+
<div class="val-faq__search">
|
|
109
|
+
<val-searchbar
|
|
110
|
+
[props]="{
|
|
111
|
+
placeholder: props.searchPlaceholder || '',
|
|
112
|
+
debounce: 200,
|
|
113
|
+
}"
|
|
114
|
+
(filterEvent)="onSearch($event)"
|
|
115
|
+
/>
|
|
116
|
+
</div>
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
@if (visibleCategories().length === 0) {
|
|
120
|
+
<p class="val-faq__empty">{{ props.noResultsText || 'Sin resultados' }}</p>
|
|
121
|
+
} @else {
|
|
122
|
+
@for (cat of visibleCategories(); track cat.id) {
|
|
123
|
+
<section class="val-faq__category">
|
|
124
|
+
@if (showCategoryLabel()) {
|
|
125
|
+
<h3 class="val-faq__category-label">{{ cat.label }}</h3>
|
|
126
|
+
}
|
|
127
|
+
<val-accordion [props]="accordionFor(cat)" />
|
|
128
|
+
</section>
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
</div>
|
|
132
|
+
`, styles: [":host{display:block;width:100%}.val-faq__search{margin-bottom:16px}.val-faq__category+.val-faq__category{margin-top:24px}.val-faq__category-label{font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ion-color-medium, #92949c);margin:0 0 8px;padding-inline:4px}.val-faq__empty{text-align:center;padding:32px 16px;color:var(--ion-color-medium, #92949c);font-size:.95rem}\n"] }]
|
|
133
|
+
}], propDecorators: { props: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}] } });
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmFxLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9vcmdhbmlzbXMvZmFxL2ZhcS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFFbkYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sK0NBQStDLENBQUM7O0FBR25GOzs7Ozs7Ozs7Ozs7OztHQWNHO0FBbUVILE1BQU0sT0FBTyxZQUFZO0lBbEV6QjtRQW1FbUIsV0FBTSxHQUFHLE1BQU0sQ0FBYyxFQUFFLFVBQVUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBU2xFLDhDQUE4QztRQUM3QixVQUFLLEdBQUcsTUFBTSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBRXBDOzs7O1dBSUc7UUFDTSxzQkFBaUIsR0FBRyxRQUFRLENBQWdCLEdBQUcsRUFBRTtZQUN4RCxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDNUMsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDLFVBQVUsSUFBSSxFQUFFLENBQUM7WUFDNUMsSUFBSSxDQUFDLENBQUM7Z0JBQUUsT0FBTyxJQUFJLENBQUM7WUFDcEIsT0FBTyxJQUFJO2lCQUNSLEdBQUcsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUM7Z0JBQ1gsR0FBRyxHQUFHO2dCQUNOLEtBQUssRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQzVHLENBQUMsQ0FBQztpQkFDRixNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztRQUN6QyxDQUFDLENBQUMsQ0FBQztRQUVILDREQUE0RDtRQUNuRCxzQkFBaUIsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3pDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUN4QixJQUFJLENBQUMsQ0FBQyx1QkFBdUIsS0FBSyxLQUFLO2dCQUFFLE9BQU8sSUFBSSxDQUFDO1lBQ3JELE9BQU8sQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLE1BQU0sSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7S0FrQko7SUFsREMsSUFBYSxLQUFLLENBQUMsS0FBOEI7UUFDL0MsSUFBSSxLQUFLO1lBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUNELElBQUksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUE2QkQsc0VBQXNFO0lBQ3RFLFlBQVksQ0FBQyxHQUFnQjtRQUMzQixPQUFPO1lBQ0wsUUFBUSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxRQUFRLElBQUksS0FBSztZQUN6QyxjQUFjLEVBQUUsS0FBSztZQUNyQixLQUFLLEVBQUUsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDO2dCQUMxQixLQUFLLEVBQUUsRUFBRSxDQUFDLEVBQUU7Z0JBQ1osTUFBTSxFQUFFLEVBQUUsQ0FBQyxRQUFRO2dCQUNuQixPQUFPLEVBQUUsRUFBRSxDQUFDLE1BQU07YUFDbkIsQ0FBQyxDQUFDO1NBQ0osQ0FBQztJQUNKLENBQUM7SUFFRCxRQUFRLENBQUMsSUFBWTtRQUNuQixJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxJQUFJLElBQUksRUFBRSxDQUFDLENBQUM7SUFDN0IsQ0FBQzsrR0FwRFUsWUFBWTttR0FBWixZQUFZLCtGQTlEYjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBMkJULGdlQTVCUyxZQUFZLCtCQUFFLGtCQUFrQixxSEFBRSxrQkFBa0I7OzRGQStEbkQsWUFBWTtrQkFsRXhCLFNBQVM7K0JBQ0UsU0FBUyxjQUNQLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsQ0FBQyxZQUNyRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBMkJUOzhCQXNDWSxLQUFLO3NCQUFqQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgY29tcHV0ZWQsIElucHV0LCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFjY29yZGlvbkNvbXBvbmVudCB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9hY2NvcmRpb24vYWNjb3JkaW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBY2NvcmRpb25NZXRhZGF0YSB9IGZyb20gJy4uLy4uL21vbGVjdWxlcy9hY2NvcmRpb24vdHlwZXMnO1xuaW1wb3J0IHsgU2VhcmNoYmFyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbW9sZWN1bGVzL3NlYXJjaGJhci9zZWFyY2hiYXIuY29tcG9uZW50JztcbmltcG9ydCB7IEZhcUNhdGVnb3J5LCBGYXFNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnO1xuXG4vKipcbiAqIGB2YWwtZmFxYFxuICpcbiAqIE9yZ2FuaXNtIGRlIHByZWd1bnRhcyBmcmVjdWVudGVzLiBRJkEgY2F0ZWdvcml6YWRvIGNvbiBhY2NvcmRpb24gY29sYXBzYWJsZVxuICogeSBidXNjYWRvciBlbiB2aXZvLiBQZW5zYWRvIHBhcmEgdmlzdGFzIEZBUSBww7pibGljYXMg4oCUIGVsIGNhbGxlciBwdWVkZVxuICogcmV1c2FyIGxhIG1pc21hIGRhdGEgKGBGYXFNZXRhZGF0YS5jYXRlZ29yaWVzYCkgcGFyYSBlbWl0aXIgZWwgc3RydWN0dXJlZFxuICogZGF0YSBgRkFRUGFnZWAgKEpTT04tTEQpIHkgZ2FuYXIgcmljaCByZXN1bHRzIGVuIGJ1c2NhZG9yZXMuXG4gKlxuICogQ29tcG9uZSBgdmFsLWFjY29yZGlvbmAgKHVuYSBwb3IgY2F0ZWdvcsOtYSkgKyBgdmFsLXNlYXJjaGJhcmAuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYGh0bWxcbiAqIDx2YWwtZmFxIFtwcm9wc109XCJ7IGNhdGVnb3JpZXM6IGZhcUNhdGVnb3JpZXMsIHNlYXJjaGFibGU6IHRydWUgfVwiIC8+XG4gKiBgYGBcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLWZhcScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIEFjY29yZGlvbkNvbXBvbmVudCwgU2VhcmNoYmFyQ29tcG9uZW50XSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwidmFsLWZhcVwiPlxuICAgICAgQGlmIChwcm9wcy5zZWFyY2hhYmxlICE9PSBmYWxzZSkge1xuICAgICAgICA8ZGl2IGNsYXNzPVwidmFsLWZhcV9fc2VhcmNoXCI+XG4gICAgICAgICAgPHZhbC1zZWFyY2hiYXJcbiAgICAgICAgICAgIFtwcm9wc109XCJ7XG4gICAgICAgICAgICAgIHBsYWNlaG9sZGVyOiBwcm9wcy5zZWFyY2hQbGFjZWhvbGRlciB8fCAnJyxcbiAgICAgICAgICAgICAgZGVib3VuY2U6IDIwMCxcbiAgICAgICAgICAgIH1cIlxuICAgICAgICAgICAgKGZpbHRlckV2ZW50KT1cIm9uU2VhcmNoKCRldmVudClcIlxuICAgICAgICAgIC8+XG4gICAgICAgIDwvZGl2PlxuICAgICAgfVxuXG4gICAgICBAaWYgKHZpc2libGVDYXRlZ29yaWVzKCkubGVuZ3RoID09PSAwKSB7XG4gICAgICAgIDxwIGNsYXNzPVwidmFsLWZhcV9fZW1wdHlcIj57eyBwcm9wcy5ub1Jlc3VsdHNUZXh0IHx8ICdTaW4gcmVzdWx0YWRvcycgfX08L3A+XG4gICAgICB9IEBlbHNlIHtcbiAgICAgICAgQGZvciAoY2F0IG9mIHZpc2libGVDYXRlZ29yaWVzKCk7IHRyYWNrIGNhdC5pZCkge1xuICAgICAgICAgIDxzZWN0aW9uIGNsYXNzPVwidmFsLWZhcV9fY2F0ZWdvcnlcIj5cbiAgICAgICAgICAgIEBpZiAoc2hvd0NhdGVnb3J5TGFiZWwoKSkge1xuICAgICAgICAgICAgICA8aDMgY2xhc3M9XCJ2YWwtZmFxX19jYXRlZ29yeS1sYWJlbFwiPnt7IGNhdC5sYWJlbCB9fTwvaDM+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICA8dmFsLWFjY29yZGlvbiBbcHJvcHNdPVwiYWNjb3JkaW9uRm9yKGNhdClcIiAvPlxuICAgICAgICAgIDwvc2VjdGlvbj5cbiAgICAgICAgfVxuICAgICAgfVxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICA6aG9zdCB7XG4gICAgICAgIGRpc3BsYXk6IGJsb2NrO1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICAgIH1cblxuICAgICAgLnZhbC1mYXFfX3NlYXJjaCB7XG4gICAgICAgIG1hcmdpbi1ib3R0b206IDE2cHg7XG4gICAgICB9XG5cbiAgICAgIC52YWwtZmFxX19jYXRlZ29yeSArIC52YWwtZmFxX19jYXRlZ29yeSB7XG4gICAgICAgIG1hcmdpbi10b3A6IDI0cHg7XG4gICAgICB9XG5cbiAgICAgIC52YWwtZmFxX19jYXRlZ29yeS1sYWJlbCB7XG4gICAgICAgIGZvbnQtc2l6ZTogMC44cmVtO1xuICAgICAgICBmb250LXdlaWdodDogNzAwO1xuICAgICAgICBsZXR0ZXItc3BhY2luZzogMC4wNmVtO1xuICAgICAgICB0ZXh0LXRyYW5zZm9ybTogdXBwZXJjYXNlO1xuICAgICAgICBjb2xvcjogdmFyKC0taW9uLWNvbG9yLW1lZGl1bSwgIzkyOTQ5Yyk7XG4gICAgICAgIG1hcmdpbjogMCAwIDhweDtcbiAgICAgICAgcGFkZGluZy1pbmxpbmU6IDRweDtcbiAgICAgIH1cblxuICAgICAgLnZhbC1mYXFfX2VtcHR5IHtcbiAgICAgICAgdGV4dC1hbGlnbjogY2VudGVyO1xuICAgICAgICBwYWRkaW5nOiAzMnB4IDE2cHg7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1pb24tY29sb3ItbWVkaXVtLCAjOTI5NDljKTtcbiAgICAgICAgZm9udC1zaXplOiAwLjk1cmVtO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZhcUNvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgcHJvcHNfID0gc2lnbmFsPEZhcU1ldGFkYXRhPih7IGNhdGVnb3JpZXM6IFtdIH0pO1xuXG4gIEBJbnB1dCgpIHNldCBwcm9wcyh2YWx1ZTogRmFxTWV0YWRhdGEgfCB1bmRlZmluZWQpIHtcbiAgICBpZiAodmFsdWUpIHRoaXMucHJvcHNfLnNldCh2YWx1ZSk7XG4gIH1cbiAgZ2V0IHByb3BzKCk6IEZhcU1ldGFkYXRhIHtcbiAgICByZXR1cm4gdGhpcy5wcm9wc18oKTtcbiAgfVxuXG4gIC8qKiBUw6lybWlubyBkZSBiw7pzcXVlZGEgYWN0dWFsIChsb3dlcmNhc2UpLiAqL1xuICBwcml2YXRlIHJlYWRvbmx5IHF1ZXJ5ID0gc2lnbmFsKCcnKTtcblxuICAvKipcbiAgICogQ2F0ZWdvcsOtYXMgdmlzaWJsZXMgdHJhcyBhcGxpY2FyIGVsIGZpbHRybyBkZSBiw7pzcXVlZGEuIFVuYSBjYXRlZ29yw61hXG4gICAqIGRlc2FwYXJlY2Ugc2kgbmluZ3VuYSBkZSBzdXMgcHJlZ3VudGFzIG1hdGNoZWEuIEVsIG1hdGNoIGVzIHNvYnJlXG4gICAqIHByZWd1bnRhICsgcmVzcHVlc3RhLCBjYXNlLWluc2Vuc2l0aXZlLlxuICAgKi9cbiAgcmVhZG9ubHkgdmlzaWJsZUNhdGVnb3JpZXMgPSBjb21wdXRlZDxGYXFDYXRlZ29yeVtdPigoKSA9PiB7XG4gICAgY29uc3QgcSA9IHRoaXMucXVlcnkoKS50cmltKCkudG9Mb3dlckNhc2UoKTtcbiAgICBjb25zdCBjYXRzID0gdGhpcy5wcm9wc18oKS5jYXRlZ29yaWVzID8/IFtdO1xuICAgIGlmICghcSkgcmV0dXJuIGNhdHM7XG4gICAgcmV0dXJuIGNhdHNcbiAgICAgIC5tYXAoY2F0ID0+ICh7XG4gICAgICAgIC4uLmNhdCxcbiAgICAgICAgaXRlbXM6IGNhdC5pdGVtcy5maWx0ZXIoaXQgPT4gaXQucXVlc3Rpb24udG9Mb3dlckNhc2UoKS5pbmNsdWRlcyhxKSB8fCBpdC5hbnN3ZXIudG9Mb3dlckNhc2UoKS5pbmNsdWRlcyhxKSksXG4gICAgICB9KSlcbiAgICAgIC5maWx0ZXIoY2F0ID0+IGNhdC5pdGVtcy5sZW5ndGggPiAwKTtcbiAgfSk7XG5cbiAgLyoqIGB0cnVlYCBzaSBzZSBkZWJlIG1vc3RyYXIgZWwgbGFiZWwgZGUgY2FkYSBjYXRlZ29yw61hLiAqL1xuICByZWFkb25seSBzaG93Q2F0ZWdvcnlMYWJlbCA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICBjb25zdCBwID0gdGhpcy5wcm9wc18oKTtcbiAgICBpZiAocC5oaWRlU2luZ2xlQ2F0ZWdvcnlMYWJlbCA9PT0gZmFsc2UpIHJldHVybiB0cnVlO1xuICAgIHJldHVybiAocC5jYXRlZ29yaWVzPy5sZW5ndGggPz8gMCkgPiAxO1xuICB9KTtcblxuICAvKiogTWFwZWEgdW5hIGNhdGVnb3LDrWEgYSBgQWNjb3JkaW9uTWV0YWRhdGFgIHBhcmEgYHZhbC1hY2NvcmRpb25gLiAqL1xuICBhY2NvcmRpb25Gb3IoY2F0OiBGYXFDYXRlZ29yeSk6IEFjY29yZGlvbk1ldGFkYXRhIHtcbiAgICByZXR1cm4ge1xuICAgICAgbXVsdGlwbGU6IHRoaXMucHJvcHNfKCkubXVsdGlwbGUgPz8gZmFsc2UsXG4gICAgICBleHBhbmRJY29uU2xvdDogJ2VuZCcsXG4gICAgICBpdGVtczogY2F0Lml0ZW1zLm1hcChpdCA9PiAoe1xuICAgICAgICB2YWx1ZTogaXQuaWQsXG4gICAgICAgIGhlYWRlcjogaXQucXVlc3Rpb24sXG4gICAgICAgIGNvbnRlbnQ6IGl0LmFuc3dlcixcbiAgICAgIH0pKSxcbiAgICB9O1xuICB9XG5cbiAgb25TZWFyY2godGVybTogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5xdWVyeS5zZXQodGVybSA/PyAnJyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tipos del organism `val-faq`.
|
|
3
|
+
*
|
|
4
|
+
* Modelo Q&A categorizado. Pensado para vistas FAQ públicas (sitio corporativo)
|
|
5
|
+
* — el caller también puede usar la misma data para emitir structured data
|
|
6
|
+
* `FAQPage` (JSON-LD) y ganar rich results en buscadores.
|
|
7
|
+
*/
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvb3JnYW5pc21zL2ZhcS90eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0dBTUciLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRpcG9zIGRlbCBvcmdhbmlzbSBgdmFsLWZhcWAuXG4gKlxuICogTW9kZWxvIFEmQSBjYXRlZ29yaXphZG8uIFBlbnNhZG8gcGFyYSB2aXN0YXMgRkFRIHDDumJsaWNhcyAoc2l0aW8gY29ycG9yYXRpdm8pXG4gKiDigJQgZWwgY2FsbGVyIHRhbWJpw6luIHB1ZWRlIHVzYXIgbGEgbWlzbWEgZGF0YSBwYXJhIGVtaXRpciBzdHJ1Y3R1cmVkIGRhdGFcbiAqIGBGQVFQYWdlYCAoSlNPTi1MRCkgeSBnYW5hciByaWNoIHJlc3VsdHMgZW4gYnVzY2Fkb3Jlcy5cbiAqL1xuXG4vKiogVW5hIHByZWd1bnRhLXJlc3B1ZXN0YS4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmFxSXRlbSB7XG4gIC8qKiBJZGVudGlmaWNhZG9yIMO6bmljbyBkZW50cm8gZGUgbGEgRkFRIOKAlCB1c2FkbyBjb21vIHRyYWNrICsgYWNjb3JkaW9uIHZhbHVlLiAqL1xuICBpZDogc3RyaW5nO1xuICAvKiogTGEgcHJlZ3VudGEuICovXG4gIHF1ZXN0aW9uOiBzdHJpbmc7XG4gIC8qKiBMYSByZXNwdWVzdGEuIFRleHRvIHBsYW5vIChsb3Mgc2FsdG9zIGRlIGzDrW5lYSBzZSByZXNwZXRhbikuICovXG4gIGFuc3dlcjogc3RyaW5nO1xufVxuXG4vKiogR3J1cG8gZGUgcHJlZ3VudGFzIGJham8gdW4gdGVtYS4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRmFxQ2F0ZWdvcnkge1xuICAvKiogSWRlbnRpZmljYWRvciDDum5pY28gZGUgbGEgY2F0ZWdvcsOtYS4gKi9cbiAgaWQ6IHN0cmluZztcbiAgLyoqIEV0aXF1ZXRhIHZpc2libGUgZGVsIGdydXBvLiAqL1xuICBsYWJlbDogc3RyaW5nO1xuICAvKiogUHJlZ3VudGFzIGRlbCBncnVwby4gKi9cbiAgaXRlbXM6IEZhcUl0ZW1bXTtcbn1cblxuLyoqXG4gKiBDb25maWd1cmFjacOzbiBkZWwgb3JnYW5pc20gYHZhbC1mYXFgLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBodG1sXG4gKiA8dmFsLWZhcVxuICogICBbcHJvcHNdPVwie1xuICogICAgIGNhdGVnb3JpZXM6IGZhcUNhdGVnb3JpZXMsXG4gKiAgICAgc2VhcmNoYWJsZTogdHJ1ZSxcbiAqICAgICBzZWFyY2hQbGFjZWhvbGRlcjogJ0J1c2Nhci4uLicsXG4gKiAgIH1cIlxuICogLz5cbiAqIGBgYFxuICovXG5leHBvcnQgaW50ZXJmYWNlIEZhcU1ldGFkYXRhIHtcbiAgLyoqIENhdGVnb3LDrWFzIGNvbiBzdXMgcHJlZ3VudGFzLCBlbiBvcmRlbiBkZSBhcGFyaWNpw7NuLiAqL1xuICBjYXRlZ29yaWVzOiBGYXFDYXRlZ29yeVtdO1xuICAvKiogTXVlc3RyYSBlbCBidXNjYWRvciBxdWUgZmlsdHJhIHByZWd1bnRhcyBlbiB2aXZvLiBEZWZhdWx0IGB0cnVlYC4gKi9cbiAgc2VhcmNoYWJsZT86IGJvb2xlYW47XG4gIC8qKiBQbGFjZWhvbGRlciBkZWwgYnVzY2Fkb3IuICovXG4gIHNlYXJjaFBsYWNlaG9sZGVyPzogc3RyaW5nO1xuICAvKiogUGVybWl0ZSB2YXJpYXMgcHJlZ3VudGFzIGFiaWVydGFzIGEgbGEgdmV6LiBEZWZhdWx0IGBmYWxzZWAuICovXG4gIG11bHRpcGxlPzogYm9vbGVhbjtcbiAgLyoqIFRleHRvIGN1YW5kbyBsYSBiw7pzcXVlZGEgbm8gYXJyb2phIHJlc3VsdGFkb3MuICovXG4gIG5vUmVzdWx0c1RleHQ/OiBzdHJpbmc7XG4gIC8qKiBPY3VsdGEgZWwgbGFiZWwgZGUgY2F0ZWdvcsOtYSBjdWFuZG8gc29sbyBoYXkgdW5hLiBEZWZhdWx0IGB0cnVlYC4gKi9cbiAgaGlkZVNpbmdsZUNhdGVnb3J5TGFiZWw/OiBib29sZWFuO1xufVxuIl19
|