valtech-components 2.0.286 → 2.0.289

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.
Files changed (30) hide show
  1. package/README.md +61 -21
  2. package/esm2022/lib/components/atoms/text/text.component.mjs +46 -10
  3. package/esm2022/lib/components/atoms/text/types.mjs +1 -1
  4. package/esm2022/lib/examples/custom-content-demo.component.mjs +291 -0
  5. package/esm2022/lib/examples/link-processing-example.component.mjs +189 -0
  6. package/esm2022/lib/services/lang-provider/content.mjs +1 -13
  7. package/esm2022/lib/services/link-processor.service.mjs +192 -0
  8. package/esm2022/lib/shared/pipes/process-links.pipe.mjs +69 -0
  9. package/esm2022/public-api.mjs +5 -4
  10. package/fesm2022/valtech-components.mjs +473 -919
  11. package/fesm2022/valtech-components.mjs.map +1 -1
  12. package/lib/components/atoms/text/text.component.d.ts +5 -1
  13. package/lib/components/atoms/text/types.d.ts +5 -0
  14. package/lib/examples/link-processing-example.component.d.ts +24 -0
  15. package/lib/services/link-processor.service.d.ts +98 -0
  16. package/lib/shared/pipes/process-links.pipe.d.ts +55 -0
  17. package/package.json +1 -1
  18. package/public-api.d.ts +4 -3
  19. package/esm2022/lib/components/_examples/custom-content-demo.component.mjs +0 -291
  20. package/esm2022/lib/components/_examples/global-content-example-content.mjs +0 -23
  21. package/esm2022/lib/components/_examples/global-content-example.component.mjs +0 -504
  22. package/esm2022/lib/components/_examples/reactive-content-example-content.mjs +0 -43
  23. package/esm2022/lib/components/_examples/reactive-content-example.component.mjs +0 -347
  24. package/esm2022/lib/services/lang-provider/components/theme-settings.mjs +0 -15
  25. package/lib/components/_examples/global-content-example-content.d.ts +0 -9
  26. package/lib/components/_examples/global-content-example.component.d.ts +0 -73
  27. package/lib/components/_examples/reactive-content-example-content.d.ts +0 -32
  28. package/lib/components/_examples/reactive-content-example.component.d.ts +0 -47
  29. package/lib/services/lang-provider/components/theme-settings.d.ts +0 -3
  30. /package/lib/{components/_examples → examples}/custom-content-demo.component.d.ts +0 -0
@@ -1,504 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, inject } from '@angular/core';
3
- import { FormsModule } from '@angular/forms';
4
- import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonInput, IonItem, IonLabel, IonTextarea, } from '@ionic/angular/standalone';
5
- import { ContentService } from '../../services/content.service';
6
- import { TextComponent } from '../atoms/text/text.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/common";
9
- import * as i2 from "@angular/forms";
10
- /**
11
- * Comprehensive example demonstrating global content usage.
12
- *
13
- * This component shows:
14
- * 1. Global button texts
15
- * 2. Global state messages
16
- * 3. Global confirmations with interpolation
17
- * 4. Mixing global and component-specific content
18
- * 5. Language switching
19
- */
20
- export class GlobalContentExampleComponent {
21
- constructor() {
22
- this.content = inject(ContentService);
23
- this.componentContent = this.content.forComponent('GlobalContentExample');
24
- // Form data
25
- this.formData = {
26
- name: '',
27
- email: '',
28
- message: '',
29
- };
30
- // Action state
31
- this.actionPerformed = false;
32
- // Component-specific content properties
33
- this.titleProps = {
34
- contentKey: 'title',
35
- contentClass: 'GlobalContentExample',
36
- contentFallback: 'Global Content Example',
37
- color: 'primary',
38
- size: 'xlarge',
39
- bold: true,
40
- };
41
- this.languageLabel = {
42
- contentKey: 'languageLabel',
43
- contentClass: 'GlobalContentExample',
44
- contentFallback: 'Language:',
45
- color: 'medium',
46
- size: 'medium',
47
- bold: true,
48
- };
49
- this.componentDescriptionProps = {
50
- contentKey: 'description',
51
- contentClass: 'GlobalContentExample',
52
- contentFallback: 'This example demonstrates global and component-specific content.',
53
- color: 'dark',
54
- size: 'medium',
55
- bold: false,
56
- };
57
- // Global button content (reactive)
58
- this.saveButton$ = this.content.fromContent({ key: 'save' });
59
- this.editButton$ = this.content.fromContent({ key: 'edit' });
60
- this.deleteButton$ = this.content.fromContent({ key: 'delete' });
61
- this.cancelButton$ = this.content.fromContent({ key: 'cancel' });
62
- this.backButton$ = this.content.fromContent({ key: 'back' });
63
- this.nextButton$ = this.content.fromContent({ key: 'next' });
64
- this.okButton$ = this.content.fromContent({ key: 'ok' });
65
- this.closeButton$ = this.content.fromContent({ key: 'close' });
66
- // Global action content
67
- this.addButton$ = this.content.fromContent({ key: 'add' });
68
- this.removeButton$ = this.content.fromContent({ key: 'remove' });
69
- this.searchButton$ = this.content.fromContent({ key: 'search' });
70
- this.filterButton$ = this.content.fromContent({ key: 'filter' });
71
- this.sortButton$ = this.content.fromContent({ key: 'sort' });
72
- this.refreshButton$ = this.content.fromContent({ key: 'refresh' });
73
- // Global state content
74
- this.loadingText$ = this.content.fromContent({ key: 'loading' });
75
- this.successText$ = this.content.fromContent({ key: 'success' });
76
- this.errorText$ = this.content.fromContent({ key: 'error' });
77
- this.warningText$ = this.content.fromContent({ key: 'warning' });
78
- this.infoText$ = this.content.fromContent({ key: 'info' });
79
- this.noDataText$ = this.content.fromContent({ key: 'noData' });
80
- // Global form content
81
- this.requiredText$ = this.content.fromContent({ key: 'required' });
82
- this.optionalText$ = this.content.fromContent({ key: 'optional' });
83
- this.searchPlaceholder$ = this.content.fromContent({ key: 'searchPlaceholder' });
84
- // Global confirmation content with interpolation
85
- this.deleteConfirmation$ = this.content.fromContentWithInterpolation({
86
- key: 'deleteConfirmation',
87
- interpolation: { itemName: 'este registro' },
88
- });
89
- this.areYouSureText$ = this.content.fromContent({ key: 'areYouSure' });
90
- this.unsavedChangesText$ = this.content.fromContent({ key: 'unsavedChanges' });
91
- }
92
- /**
93
- * Set language
94
- */
95
- setLanguage(lang) {
96
- this.content.setLang(lang);
97
- }
98
- /**
99
- * Perform an action to demonstrate status messages
100
- */
101
- performAction() {
102
- this.actionPerformed = true;
103
- setTimeout(() => {
104
- this.actionPerformed = false;
105
- }, 3000);
106
- }
107
- /**
108
- * Cancel action
109
- */
110
- cancelAction() {
111
- this.formData = { name: '', email: '', message: '' };
112
- this.actionPerformed = false;
113
- }
114
- /**
115
- * Example of synchronous global content access
116
- */
117
- getOkTextSync() {
118
- return this.content.getGlobalText('ok');
119
- }
120
- /**
121
- * Example of synchronous global content access using getText
122
- */
123
- getCancelTextSync() {
124
- return this.content.getText('cancel');
125
- }
126
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GlobalContentExampleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
127
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GlobalContentExampleComponent, isStandalone: true, selector: "val-global-content-example", ngImport: i0, template: `
128
- <ion-card>
129
- <ion-card-header>
130
- <ion-card-title>
131
- <val-text [props]="titleProps"></val-text>
132
- </ion-card-title>
133
- </ion-card-header>
134
-
135
- <ion-card-content>
136
- <!-- Language switcher -->
137
- <div class="language-section">
138
- <val-text [props]="languageLabel"></val-text>
139
- <ion-button fill="outline" size="small" (click)="setLanguage('es')"> Español </ion-button>
140
- <ion-button fill="outline" size="small" (click)="setLanguage('en')"> English </ion-button>
141
- </div>
142
-
143
- <div class="divider"></div>
144
-
145
- <!-- Global buttons demonstration -->
146
- <div class="section">
147
- <h3>Global Buttons</h3>
148
- <div class="button-grid">
149
- <ion-button color="primary">{{ saveButton$ | async }}</ion-button>
150
- <ion-button color="secondary">{{ editButton$ | async }}</ion-button>
151
- <ion-button color="danger">{{ deleteButton$ | async }}</ion-button>
152
- <ion-button fill="outline">{{ cancelButton$ | async }}</ion-button>
153
- <ion-button fill="outline">{{ backButton$ | async }}</ion-button>
154
- <ion-button fill="outline">{{ nextButton$ | async }}</ion-button>
155
- <ion-button color="success">{{ okButton$ | async }}</ion-button>
156
- <ion-button fill="clear">{{ closeButton$ | async }}</ion-button>
157
- </div>
158
- </div>
159
-
160
- <div class="divider"></div>
161
-
162
- <!-- Global actions demonstration -->
163
- <div class="section">
164
- <h3>Global Actions</h3>
165
- <div class="button-grid">
166
- <ion-button size="small">{{ addButton$ | async }}</ion-button>
167
- <ion-button size="small">{{ removeButton$ | async }}</ion-button>
168
- <ion-button size="small">{{ searchButton$ | async }}</ion-button>
169
- <ion-button size="small">{{ filterButton$ | async }}</ion-button>
170
- <ion-button size="small">{{ sortButton$ | async }}</ion-button>
171
- <ion-button size="small">{{ refreshButton$ | async }}</ion-button>
172
- </div>
173
- </div>
174
-
175
- <div class="divider"></div>
176
-
177
- <!-- Global states demonstration -->
178
- <div class="section">
179
- <h3>Global States</h3>
180
- <div class="state-messages">
181
- <div class="state-item loading">
182
- <val-text
183
- [props]="{ content: loadingText$ | async, color: 'medium', size: 'small', bold: false }"
184
- ></val-text>
185
- </div>
186
- <div class="state-item success">
187
- <val-text
188
- [props]="{ content: successText$ | async, color: 'success', size: 'small', bold: false }"
189
- ></val-text>
190
- </div>
191
- <div class="state-item error">
192
- <val-text
193
- [props]="{ content: errorText$ | async, color: 'danger', size: 'small', bold: false }"
194
- ></val-text>
195
- </div>
196
- <div class="state-item warning">
197
- <val-text
198
- [props]="{ content: warningText$ | async, color: 'warning', size: 'small', bold: false }"
199
- ></val-text>
200
- </div>
201
- <div class="state-item info">
202
- <val-text
203
- [props]="{ content: infoText$ | async, color: 'primary', size: 'small', bold: false }"
204
- ></val-text>
205
- </div>
206
- <div class="state-item no-data">
207
- <val-text
208
- [props]="{ content: noDataText$ | async, color: 'medium', size: 'small', bold: false }"
209
- ></val-text>
210
- </div>
211
- </div>
212
- </div>
213
-
214
- <div class="divider"></div>
215
-
216
- <!-- Form with global placeholders and labels -->
217
- <div class="section">
218
- <h3>Form with Global Content</h3>
219
- <form class="example-form">
220
- <ion-item>
221
- <ion-label position="stacked">Name ({{ requiredText$ | async }})</ion-label>
222
- <ion-input [(ngModel)]="formData.name" [placeholder]="'Enter your name' + '...'" name="name"> </ion-input>
223
- </ion-item>
224
-
225
- <ion-item>
226
- <ion-label position="stacked">Email ({{ optionalText$ | async }})</ion-label>
227
- <ion-input [(ngModel)]="formData.email" [placeholder]="'Enter your email' + '...'" name="email">
228
- </ion-input>
229
- </ion-item>
230
-
231
- <ion-item>
232
- <ion-label position="stacked">Message</ion-label>
233
- <ion-textarea [(ngModel)]="formData.message" [placeholder]="searchPlaceholder$ | async" name="message">
234
- </ion-textarea>
235
- </ion-item>
236
- </form>
237
- </div>
238
-
239
- <div class="divider"></div>
240
-
241
- <!-- Global confirmations with interpolation -->
242
- <div class="section">
243
- <h3>Confirmations with Interpolation</h3>
244
- <div class="confirmation-examples">
245
- <p><strong>Delete Confirmation:</strong></p>
246
- <val-text
247
- [props]="{ content: deleteConfirmation$ | async, color: 'danger', size: 'medium', bold: false }"
248
- ></val-text>
249
-
250
- <br /><br />
251
- <p><strong>General Confirmation:</strong></p>
252
- <val-text
253
- [props]="{ content: areYouSureText$ | async, color: 'warning', size: 'medium', bold: false }"
254
- ></val-text>
255
-
256
- <br /><br />
257
- <p><strong>Unsaved Changes:</strong></p>
258
- <val-text
259
- [props]="{ content: unsavedChangesText$ | async, color: 'medium', size: 'medium', bold: false }"
260
- ></val-text>
261
- </div>
262
- </div>
263
-
264
- <div class="divider"></div>
265
-
266
- <!-- Mixed content: Global + Component specific -->
267
- <div class="section">
268
- <h3>Mixed Content Example</h3>
269
- <div class="mixed-content">
270
- <!-- Component-specific content -->
271
- <val-text [props]="componentDescriptionProps"></val-text>
272
-
273
- <br /><br />
274
-
275
- <!-- Action buttons mixing global and component content -->
276
- <div class="action-buttons">
277
- <ion-button color="primary" (click)="performAction()">
278
- {{ saveButton$ | async }}
279
- </ion-button>
280
- <ion-button fill="outline" (click)="cancelAction()">
281
- {{ cancelButton$ | async }}
282
- </ion-button>
283
- </div>
284
-
285
- <!-- Status message using global content -->
286
- <div *ngIf="actionPerformed" class="status-message">
287
- <val-text
288
- [props]="{ content: successText$ | async, color: 'success', size: 'small', bold: false }"
289
- ></val-text>
290
- </div>
291
- </div>
292
- </div>
293
-
294
- <!-- Demo of synchronous global content access -->
295
- <div class="section">
296
- <h3>Synchronous Access Example</h3>
297
- <p>
298
- OK button text (sync): <strong>{{ getOkTextSync() }}</strong>
299
- </p>
300
- <p>
301
- Cancel button text (sync): <strong>{{ getCancelTextSync() }}</strong>
302
- </p>
303
- </div>
304
- </ion-card-content>
305
- </ion-card>
306
- `, isInline: true, styles: [".language-section{display:flex;align-items:center;gap:8px;margin-bottom:16px}.divider{height:1px;background-color:var(--ion-color-light);margin:16px 0}.section{margin-bottom:16px}.section h3{margin:0 0 12px;color:var(--ion-color-primary)}.button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.state-messages{display:flex;flex-direction:column;gap:8px}.state-item{padding:8px;border-radius:4px;background-color:var(--ion-color-light-shade)}.state-item.loading{background-color:var(--ion-color-medium-tint)}.state-item.success{background-color:var(--ion-color-success-tint)}.state-item.error{background-color:var(--ion-color-danger-tint)}.state-item.warning{background-color:var(--ion-color-warning-tint)}.state-item.info{background-color:var(--ion-color-primary-tint)}.example-form{margin-top:12px}.confirmation-examples{padding:12px;background-color:var(--ion-color-light-tint);border-radius:8px}.mixed-content{padding:12px;background-color:var(--ion-color-light-shade);border-radius:8px}.action-buttons{display:flex;gap:8px;margin:12px 0}.status-message{padding:8px;background-color:var(--ion-color-success-tint);border-radius:4px;margin-top:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: IonCard, selector: "ion-card", inputs: ["button", "color", "disabled", "download", "href", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonCardContent, selector: "ion-card-content", inputs: ["mode"] }, { kind: "component", type: IonCardHeader, selector: "ion-card-header", inputs: ["color", "mode", "translucent"] }, { kind: "component", type: IonCardTitle, selector: "ion-card-title", inputs: ["color", "mode"] }, { kind: "component", type: IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "size", "spellcheck", "step", "type", "value"] }, { kind: "component", type: IonTextarea, selector: "ion-textarea", inputs: ["autoGrow", "autocapitalize", "autofocus", "clearOnEdit", "color", "cols", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "maxlength", "minlength", "mode", "name", "placeholder", "readonly", "required", "rows", "shape", "spellcheck", "value", "wrap"] }, { kind: "component", type: TextComponent, selector: "val-text", inputs: ["props"] }] }); }
307
- }
308
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GlobalContentExampleComponent, decorators: [{
309
- type: Component,
310
- args: [{ selector: 'val-global-content-example', standalone: true, imports: [
311
- CommonModule,
312
- FormsModule,
313
- IonCard,
314
- IonCardContent,
315
- IonCardHeader,
316
- IonCardTitle,
317
- IonButton,
318
- IonItem,
319
- IonLabel,
320
- IonInput,
321
- IonTextarea,
322
- TextComponent,
323
- ], template: `
324
- <ion-card>
325
- <ion-card-header>
326
- <ion-card-title>
327
- <val-text [props]="titleProps"></val-text>
328
- </ion-card-title>
329
- </ion-card-header>
330
-
331
- <ion-card-content>
332
- <!-- Language switcher -->
333
- <div class="language-section">
334
- <val-text [props]="languageLabel"></val-text>
335
- <ion-button fill="outline" size="small" (click)="setLanguage('es')"> Español </ion-button>
336
- <ion-button fill="outline" size="small" (click)="setLanguage('en')"> English </ion-button>
337
- </div>
338
-
339
- <div class="divider"></div>
340
-
341
- <!-- Global buttons demonstration -->
342
- <div class="section">
343
- <h3>Global Buttons</h3>
344
- <div class="button-grid">
345
- <ion-button color="primary">{{ saveButton$ | async }}</ion-button>
346
- <ion-button color="secondary">{{ editButton$ | async }}</ion-button>
347
- <ion-button color="danger">{{ deleteButton$ | async }}</ion-button>
348
- <ion-button fill="outline">{{ cancelButton$ | async }}</ion-button>
349
- <ion-button fill="outline">{{ backButton$ | async }}</ion-button>
350
- <ion-button fill="outline">{{ nextButton$ | async }}</ion-button>
351
- <ion-button color="success">{{ okButton$ | async }}</ion-button>
352
- <ion-button fill="clear">{{ closeButton$ | async }}</ion-button>
353
- </div>
354
- </div>
355
-
356
- <div class="divider"></div>
357
-
358
- <!-- Global actions demonstration -->
359
- <div class="section">
360
- <h3>Global Actions</h3>
361
- <div class="button-grid">
362
- <ion-button size="small">{{ addButton$ | async }}</ion-button>
363
- <ion-button size="small">{{ removeButton$ | async }}</ion-button>
364
- <ion-button size="small">{{ searchButton$ | async }}</ion-button>
365
- <ion-button size="small">{{ filterButton$ | async }}</ion-button>
366
- <ion-button size="small">{{ sortButton$ | async }}</ion-button>
367
- <ion-button size="small">{{ refreshButton$ | async }}</ion-button>
368
- </div>
369
- </div>
370
-
371
- <div class="divider"></div>
372
-
373
- <!-- Global states demonstration -->
374
- <div class="section">
375
- <h3>Global States</h3>
376
- <div class="state-messages">
377
- <div class="state-item loading">
378
- <val-text
379
- [props]="{ content: loadingText$ | async, color: 'medium', size: 'small', bold: false }"
380
- ></val-text>
381
- </div>
382
- <div class="state-item success">
383
- <val-text
384
- [props]="{ content: successText$ | async, color: 'success', size: 'small', bold: false }"
385
- ></val-text>
386
- </div>
387
- <div class="state-item error">
388
- <val-text
389
- [props]="{ content: errorText$ | async, color: 'danger', size: 'small', bold: false }"
390
- ></val-text>
391
- </div>
392
- <div class="state-item warning">
393
- <val-text
394
- [props]="{ content: warningText$ | async, color: 'warning', size: 'small', bold: false }"
395
- ></val-text>
396
- </div>
397
- <div class="state-item info">
398
- <val-text
399
- [props]="{ content: infoText$ | async, color: 'primary', size: 'small', bold: false }"
400
- ></val-text>
401
- </div>
402
- <div class="state-item no-data">
403
- <val-text
404
- [props]="{ content: noDataText$ | async, color: 'medium', size: 'small', bold: false }"
405
- ></val-text>
406
- </div>
407
- </div>
408
- </div>
409
-
410
- <div class="divider"></div>
411
-
412
- <!-- Form with global placeholders and labels -->
413
- <div class="section">
414
- <h3>Form with Global Content</h3>
415
- <form class="example-form">
416
- <ion-item>
417
- <ion-label position="stacked">Name ({{ requiredText$ | async }})</ion-label>
418
- <ion-input [(ngModel)]="formData.name" [placeholder]="'Enter your name' + '...'" name="name"> </ion-input>
419
- </ion-item>
420
-
421
- <ion-item>
422
- <ion-label position="stacked">Email ({{ optionalText$ | async }})</ion-label>
423
- <ion-input [(ngModel)]="formData.email" [placeholder]="'Enter your email' + '...'" name="email">
424
- </ion-input>
425
- </ion-item>
426
-
427
- <ion-item>
428
- <ion-label position="stacked">Message</ion-label>
429
- <ion-textarea [(ngModel)]="formData.message" [placeholder]="searchPlaceholder$ | async" name="message">
430
- </ion-textarea>
431
- </ion-item>
432
- </form>
433
- </div>
434
-
435
- <div class="divider"></div>
436
-
437
- <!-- Global confirmations with interpolation -->
438
- <div class="section">
439
- <h3>Confirmations with Interpolation</h3>
440
- <div class="confirmation-examples">
441
- <p><strong>Delete Confirmation:</strong></p>
442
- <val-text
443
- [props]="{ content: deleteConfirmation$ | async, color: 'danger', size: 'medium', bold: false }"
444
- ></val-text>
445
-
446
- <br /><br />
447
- <p><strong>General Confirmation:</strong></p>
448
- <val-text
449
- [props]="{ content: areYouSureText$ | async, color: 'warning', size: 'medium', bold: false }"
450
- ></val-text>
451
-
452
- <br /><br />
453
- <p><strong>Unsaved Changes:</strong></p>
454
- <val-text
455
- [props]="{ content: unsavedChangesText$ | async, color: 'medium', size: 'medium', bold: false }"
456
- ></val-text>
457
- </div>
458
- </div>
459
-
460
- <div class="divider"></div>
461
-
462
- <!-- Mixed content: Global + Component specific -->
463
- <div class="section">
464
- <h3>Mixed Content Example</h3>
465
- <div class="mixed-content">
466
- <!-- Component-specific content -->
467
- <val-text [props]="componentDescriptionProps"></val-text>
468
-
469
- <br /><br />
470
-
471
- <!-- Action buttons mixing global and component content -->
472
- <div class="action-buttons">
473
- <ion-button color="primary" (click)="performAction()">
474
- {{ saveButton$ | async }}
475
- </ion-button>
476
- <ion-button fill="outline" (click)="cancelAction()">
477
- {{ cancelButton$ | async }}
478
- </ion-button>
479
- </div>
480
-
481
- <!-- Status message using global content -->
482
- <div *ngIf="actionPerformed" class="status-message">
483
- <val-text
484
- [props]="{ content: successText$ | async, color: 'success', size: 'small', bold: false }"
485
- ></val-text>
486
- </div>
487
- </div>
488
- </div>
489
-
490
- <!-- Demo of synchronous global content access -->
491
- <div class="section">
492
- <h3>Synchronous Access Example</h3>
493
- <p>
494
- OK button text (sync): <strong>{{ getOkTextSync() }}</strong>
495
- </p>
496
- <p>
497
- Cancel button text (sync): <strong>{{ getCancelTextSync() }}</strong>
498
- </p>
499
- </div>
500
- </ion-card-content>
501
- </ion-card>
502
- `, styles: [".language-section{display:flex;align-items:center;gap:8px;margin-bottom:16px}.divider{height:1px;background-color:var(--ion-color-light);margin:16px 0}.section{margin-bottom:16px}.section h3{margin:0 0 12px;color:var(--ion-color-primary)}.button-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px}.state-messages{display:flex;flex-direction:column;gap:8px}.state-item{padding:8px;border-radius:4px;background-color:var(--ion-color-light-shade)}.state-item.loading{background-color:var(--ion-color-medium-tint)}.state-item.success{background-color:var(--ion-color-success-tint)}.state-item.error{background-color:var(--ion-color-danger-tint)}.state-item.warning{background-color:var(--ion-color-warning-tint)}.state-item.info{background-color:var(--ion-color-primary-tint)}.example-form{margin-top:12px}.confirmation-examples{padding:12px;background-color:var(--ion-color-light-tint);border-radius:8px}.mixed-content{padding:12px;background-color:var(--ion-color-light-shade);border-radius:8px}.action-buttons{display:flex;gap:8px;margin:12px 0}.status-message{padding:8px;background-color:var(--ion-color-success-tint);border-radius:4px;margin-top:8px}\n"] }]
503
- }] });
504
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2xvYmFsLWNvbnRlbnQtZXhhbXBsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL19leGFtcGxlcy9nbG9iYWwtY29udGVudC1leGFtcGxlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFDTCxTQUFTLEVBQ1QsT0FBTyxFQUNQLGNBQWMsRUFDZCxhQUFhLEVBQ2IsWUFBWSxFQUNaLFFBQVEsRUFDUixPQUFPLEVBQ1AsUUFBUSxFQUNSLFdBQVcsR0FDWixNQUFNLDJCQUEyQixDQUFDO0FBQ25DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7QUFHN0Q7Ozs7Ozs7OztHQVNHO0FBbVNILE1BQU0sT0FBTyw2QkFBNkI7SUFsUzFDO1FBbVNVLFlBQU8sR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDakMscUJBQWdCLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsc0JBQXNCLENBQUMsQ0FBQztRQUU3RSxZQUFZO1FBQ1osYUFBUSxHQUFHO1lBQ1QsSUFBSSxFQUFFLEVBQUU7WUFDUixLQUFLLEVBQUUsRUFBRTtZQUNULE9BQU8sRUFBRSxFQUFFO1NBQ1osQ0FBQztRQUVGLGVBQWU7UUFDZixvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUV4Qix3Q0FBd0M7UUFDeEMsZUFBVSxHQUFpQjtZQUN6QixVQUFVLEVB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LDZGQUNSLFFBQVEsOGVBQ1IsV0FBVyxpYUFDWCxhQUFhOzs0RkFtUkosNkJBQTZCO2tCQWxTekMsU0FBUzsrQkFDRSw0QkFBNEIsY0FDMUIsSUFBSSxXQUNQO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxPQUFPO3dCQUNQLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixZQUFZO3dCQUNaLFNBQVM7d0JBQ1QsT0FBTzt3QkFDUCxRQUFRO3dCQUNSLFFBQVE7d0JBQ1IsV0FBVzt3QkFDWCxhQUFhO3FCQUNkLFlBQ1M7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBbUxUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7XG4gIElvbkJ1dHRvbixcbiAgSW9uQ2FyZCxcbiAgSW9uQ2FyZENvbnRlbnQsXG4gIElvbkNhcmRIZWFkZXIsXG4gIElvbkNhcmRUaXRsZSxcbiAgSW9uSW5wdXQsXG4gIElvbkl0ZW0sXG4gIElvbkxhYmVsLFxuICBJb25UZXh0YXJlYSxcbn0gZnJvbSAnQGlvbmljL2FuZ3VsYXIvc3RhbmRhbG9uZSc7XG5pbXBvcnQgeyBDb250ZW50U2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2NvbnRlbnQuc2VydmljZSc7XG5pbXBvcnQgeyBUZXh0Q29tcG9uZW50IH0gZnJvbSAnLi4vYXRvbXMvdGV4dC90ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUZXh0TWV0YWRhdGEgfSBmcm9tICcuLi9hdG9tcy90ZXh0L3R5cGVzJztcblxuLyoqXG4gKiBDb21wcmVoZW5zaXZlIGV4YW1wbGUgZGVtb25zdHJhdGluZyBnbG9iYWwgY29udGVudCB1c2FnZS5cbiAqXG4gKiBUaGlzIGNvbXBvbmVudCBzaG93czpcbiAqIDEuIEdsb2JhbCBidXR0b24gdGV4dHNcbiAqIDIuIEdsb2JhbCBzdGF0ZSBtZXNzYWdlc1xuICogMy4gR2xvYmFsIGNvbmZpcm1hdGlvbnMgd2l0aCBpbnRlcnBvbGF0aW9uXG4gKiA0LiBNaXhpbmcgZ2xvYmFsIGFuZCBjb21wb25lbnQtc3BlY2lmaWMgY29udGVudFxuICogNS4gTGFuZ3VhZ2Ugc3dpdGNoaW5nXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1nbG9iYWwtY29udGVudC1leGFtcGxlJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBJb25DYXJkLFxuICAgIElvbkNhcmRDb250ZW50LFxuICAgIElvbkNhcmRIZWFkZXIsXG4gICAgSW9uQ2FyZFRpdGxlLFxuICAgIElvbkJ1dHRvbixcbiAgICBJb25JdGVtLFxuICAgIElvbkxhYmVsLFxuICAgIElvbklucHV0LFxuICAgIElvblRleHRhcmVhLFxuICAgIFRleHRDb21wb25lbnQsXG4gIF0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGlvbi1jYXJkPlxuICAgICAgPGlvbi1jYXJkLWhlYWRlcj5cbiAgICAgICAgPGlvbi1jYXJkLXRpdGxlPlxuICAgICAgICAgIDx2YWwtdGV4dCBbcHJvcHNdPVwidGl0bGVQcm9wc1wiPjwvdmFsLXRleHQ+XG4gICAgICAgIDwvaW9uLWNhcmQtdGl0bGU+XG4gICAgICA8L2lvbi1jYXJkLWhlYWRlcj5cblxuICAgICAgPGlvbi1jYXJkLWNvbnRlbnQ+XG4gICAgICAgIDwhLS0gTGFuZ3VhZ2Ugc3dpdGNoZXIgLS0+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJsYW5ndWFnZS1zZWN0aW9uXCI+XG4gICAgICAgICAgPHZhbC10ZXh0IFtwcm9wc109XCJsYW5ndWFnZUxhYmVsXCI+PC92YWwtdGV4dD5cbiAgICAgICAgICA8aW9uLWJ1dHRvbiBmaWxsPVwib3V0bGluZVwiIHNpemU9XCJzbWFsbFwiIChjbGljayk9XCJzZXRMYW5ndWFnZSgnZXMnKVwiPiBFc3Bhw7FvbCA8L2lvbi1idXR0b24+XG4gICAgICAgICAgPGlvbi1idXR0b24gZmlsbD1cIm91dGxpbmVcIiBzaXplPVwic21hbGxcIiAoY2xpY2spPVwic2V0TGFuZ3VhZ2UoJ2VuJylcIj4gRW5nbGlzaCA8L2lvbi1idXR0b24+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkaXZpZGVyXCI+PC9kaXY+XG5cbiAgICAgICAgPCEtLSBHbG9iYWwgYnV0dG9ucyBkZW1vbnN0cmF0aW9uIC0tPlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2VjdGlvblwiPlxuICAgICAgICAgIDxoMz5HbG9iYWwgQnV0dG9uczwvaDM+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImJ1dHRvbi1ncmlkXCI+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBjb2xvcj1cInByaW1hcnlcIj57eyBzYXZlQnV0dG9uJCB8IGFzeW5jIH19PC9pb24tYnV0dG9uPlxuICAgICAgICAgICAgPGlvbi1idXR0b24gY29sb3I9XCJzZWNvbmRhcnlcIj57eyBlZGl0QnV0dG9uJCB8IGFzeW5jIH19PC9pb24tYnV0dG9uPlxuICAgICAgICAgICAgPGlvbi1idXR0b24gY29sb3I9XCJkYW5nZXJcIj57eyBkZWxldGVCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBmaWxsPVwib3V0bGluZVwiPnt7IGNhbmNlbEJ1dHRvbiQgfCBhc3luYyB9fTwvaW9uLWJ1dHRvbj5cbiAgICAgICAgICAgIDxpb24tYnV0dG9uIGZpbGw9XCJvdXRsaW5lXCI+e3sgYmFja0J1dHRvbiQgfCBhc3luYyB9fTwvaW9uLWJ1dHRvbj5cbiAgICAgICAgICAgIDxpb24tYnV0dG9uIGZpbGw9XCJvdXRsaW5lXCI+e3sgbmV4dEJ1dHRvbiQgfCBhc3luYyB9fTwvaW9uLWJ1dHRvbj5cbiAgICAgICAgICAgIDxpb24tYnV0dG9uIGNvbG9yPVwic3VjY2Vzc1wiPnt7IG9rQnV0dG9uJCB8IGFzeW5jIH19PC9pb24tYnV0dG9uPlxuICAgICAgICAgICAgPGlvbi1idXR0b24gZmlsbD1cImNsZWFyXCI+e3sgY2xvc2VCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvZGl2PlxuXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkaXZpZGVyXCI+PC9kaXY+XG5cbiAgICAgICAgPCEtLSBHbG9iYWwgYWN0aW9ucyBkZW1vbnN0cmF0aW9uIC0tPlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2VjdGlvblwiPlxuICAgICAgICAgIDxoMz5HbG9iYWwgQWN0aW9uczwvaDM+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cImJ1dHRvbi1ncmlkXCI+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBzaXplPVwic21hbGxcIj57eyBhZGRCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBzaXplPVwic21hbGxcIj57eyByZW1vdmVCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBzaXplPVwic21hbGxcIj57eyBzZWFyY2hCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBzaXplPVwic21hbGxcIj57eyBmaWx0ZXJCdXR0b24kIHwgYXN5bmMgfX08L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8aW9uLWJ1dHRvbiBzaXplPVwic21hbGxcIj57eyBzb3J0QnV0dG9uJCB8IGFzeW5jIH19PC9pb24tYnV0dG9uPlxuICAgICAgICAgICAgPGlvbi1idXR0b24gc2l6ZT1cInNtYWxsXCI+e3sgcmVmcmVzaEJ1dHRvbiQgfCBhc3luYyB9fTwvaW9uLWJ1dHRvbj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImRpdmlkZXJcIj48L2Rpdj5cblxuICAgICAgICA8IS0tIEdsb2JhbCBzdGF0ZXMgZGVtb25zdHJhdGlvbiAtLT5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICA8aDM+R2xvYmFsIFN0YXRlczwvaDM+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInN0YXRlLW1lc3NhZ2VzXCI+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwic3RhdGUtaXRlbSBsb2FkaW5nXCI+XG4gICAgICAgICAgICAgIDx2YWwtdGV4dFxuICAgICAgICAgICAgICAgIFtwcm9wc109XCJ7IGNvbnRlbnQ6IGxvYWRpbmdUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ21lZGl1bScsIHNpemU6ICdzbWFsbCcsIGJvbGQ6IGZhbHNlIH1cIlxuICAgICAgICAgICAgICA+PC92YWwtdGV4dD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInN0YXRlLWl0ZW0gc3VjY2Vzc1wiPlxuICAgICAgICAgICAgICA8dmFsLXRleHRcbiAgICAgICAgICAgICAgICBbcHJvcHNdPVwieyBjb250ZW50OiBzdWNjZXNzVGV4dCQgfCBhc3luYywgY29sb3I6ICdzdWNjZXNzJywgc2l6ZTogJ3NtYWxsJywgYm9sZDogZmFsc2UgfVwiXG4gICAgICAgICAgICAgID48L3ZhbC10ZXh0PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwic3RhdGUtaXRlbSBlcnJvclwiPlxuICAgICAgICAgICAgICA8dmFsLXRleHRcbiAgICAgICAgICAgICAgICBbcHJvcHNdPVwieyBjb250ZW50OiBlcnJvclRleHQkIHwgYXN5bmMsIGNvbG9yOiAnZGFuZ2VyJywgc2l6ZTogJ3NtYWxsJywgYm9sZDogZmFsc2UgfVwiXG4gICAgICAgICAgICAgID48L3ZhbC10ZXh0PlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwic3RhdGUtaXRlbSB3YXJuaW5nXCI+XG4gICAgICAgICAgICAgIDx2YWwtdGV4dFxuICAgICAgICAgICAgICAgIFtwcm9wc109XCJ7IGNvbnRlbnQ6IHdhcm5pbmdUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ3dhcm5pbmcnLCBzaXplOiAnc21hbGwnLCBib2xkOiBmYWxzZSB9XCJcbiAgICAgICAgICAgICAgPjwvdmFsLXRleHQ+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzdGF0ZS1pdGVtIGluZm9cIj5cbiAgICAgICAgICAgICAgPHZhbC10ZXh0XG4gICAgICAgICAgICAgICAgW3Byb3BzXT1cInsgY29udGVudDogaW5mb1RleHQkIHwgYXN5bmMsIGNvbG9yOiAncHJpbWFyeScsIHNpemU6ICdzbWFsbCcsIGJvbGQ6IGZhbHNlIH1cIlxuICAgICAgICAgICAgICA+PC92YWwtdGV4dD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInN0YXRlLWl0ZW0gbm8tZGF0YVwiPlxuICAgICAgICAgICAgICA8dmFsLXRleHRcbiAgICAgICAgICAgICAgICBbcHJvcHNdPVwieyBjb250ZW50OiBub0RhdGFUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ21lZGl1bScsIHNpemU6ICdzbWFsbCcsIGJvbGQ6IGZhbHNlIH1cIlxuICAgICAgICAgICAgICA+PC92YWwtdGV4dD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwiZGl2aWRlclwiPjwvZGl2PlxuXG4gICAgICAgIDwhLS0gRm9ybSB3aXRoIGdsb2JhbCBwbGFjZWhvbGRlcnMgYW5kIGxhYmVscyAtLT5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICA8aDM+Rm9ybSB3aXRoIEdsb2JhbCBDb250ZW50PC9oMz5cbiAgICAgICAgICA8Zm9ybSBjbGFzcz1cImV4YW1wbGUtZm9ybVwiPlxuICAgICAgICAgICAgPGlvbi1pdGVtPlxuICAgICAgICAgICAgICA8aW9uLWxhYmVsIHBvc2l0aW9uPVwic3RhY2tlZFwiPk5hbWUgKHt7IHJlcXVpcmVkVGV4dCQgfCBhc3luYyB9fSk8L2lvbi1sYWJlbD5cbiAgICAgICAgICAgICAgPGlvbi1pbnB1dCBbKG5nTW9kZWwpXT1cImZvcm1EYXRhLm5hbWVcIiBbcGxhY2Vob2xkZXJdPVwiJ0VudGVyIHlvdXIgbmFtZScgKyAnLi4uJ1wiIG5hbWU9XCJuYW1lXCI+IDwvaW9uLWlucHV0PlxuICAgICAgICAgICAgPC9pb24taXRlbT5cblxuICAgICAgICAgICAgPGlvbi1pdGVtPlxuICAgICAgICAgICAgICA8aW9uLWxhYmVsIHBvc2l0aW9uPVwic3RhY2tlZFwiPkVtYWlsICh7eyBvcHRpb25hbFRleHQkIHwgYXN5bmMgfX0pPC9pb24tbGFiZWw+XG4gICAgICAgICAgICAgIDxpb24taW5wdXQgWyhuZ01vZGVsKV09XCJmb3JtRGF0YS5lbWFpbFwiIFtwbGFjZWhvbGRlcl09XCInRW50ZXIgeW91ciBlbWFpbCcgKyAnLi4uJ1wiIG5hbWU9XCJlbWFpbFwiPlxuICAgICAgICAgICAgICA8L2lvbi1pbnB1dD5cbiAgICAgICAgICAgIDwvaW9uLWl0ZW0+XG5cbiAgICAgICAgICAgIDxpb24taXRlbT5cbiAgICAgICAgICAgICAgPGlvbi1sYWJlbCBwb3NpdGlvbj1cInN0YWNrZWRcIj5NZXNzYWdlPC9pb24tbGFiZWw+XG4gICAgICAgICAgICAgIDxpb24tdGV4dGFyZWEgWyhuZ01vZGVsKV09XCJmb3JtRGF0YS5tZXNzYWdlXCIgW3BsYWNlaG9sZGVyXT1cInNlYXJjaFBsYWNlaG9sZGVyJCB8IGFzeW5jXCIgbmFtZT1cIm1lc3NhZ2VcIj5cbiAgICAgICAgICAgICAgPC9pb24tdGV4dGFyZWE+XG4gICAgICAgICAgICA8L2lvbi1pdGVtPlxuICAgICAgICAgIDwvZm9ybT5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPGRpdiBjbGFzcz1cImRpdmlkZXJcIj48L2Rpdj5cblxuICAgICAgICA8IS0tIEdsb2JhbCBjb25maXJtYXRpb25zIHdpdGggaW50ZXJwb2xhdGlvbiAtLT5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICA8aDM+Q29uZmlybWF0aW9ucyB3aXRoIEludGVycG9sYXRpb248L2gzPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb25maXJtYXRpb24tZXhhbXBsZXNcIj5cbiAgICAgICAgICAgIDxwPjxzdHJvbmc+RGVsZXRlIENvbmZpcm1hdGlvbjo8L3N0cm9uZz48L3A+XG4gICAgICAgICAgICA8dmFsLXRleHRcbiAgICAgICAgICAgICAgW3Byb3BzXT1cInsgY29udGVudDogZGVsZXRlQ29uZmlybWF0aW9uJCB8IGFzeW5jLCBjb2xvcjogJ2RhbmdlcicsIHNpemU6ICdtZWRpdW0nLCBib2xkOiBmYWxzZSB9XCJcbiAgICAgICAgICAgID48L3ZhbC10ZXh0PlxuXG4gICAgICAgICAgICA8YnIgLz48YnIgLz5cbiAgICAgICAgICAgIDxwPjxzdHJvbmc+R2VuZXJhbCBDb25maXJtYXRpb246PC9zdHJvbmc+PC9wPlxuICAgICAgICAgICAgPHZhbC10ZXh0XG4gICAgICAgICAgICAgIFtwcm9wc109XCJ7IGNvbnRlbnQ6IGFyZVlvdVN1cmVUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ3dhcm5pbmcnLCBzaXplOiAnbWVkaXVtJywgYm9sZDogZmFsc2UgfVwiXG4gICAgICAgICAgICA+PC92YWwtdGV4dD5cblxuICAgICAgICAgICAgPGJyIC8+PGJyIC8+XG4gICAgICAgICAgICA8cD48c3Ryb25nPlVuc2F2ZWQgQ2hhbmdlczo8L3N0cm9uZz48L3A+XG4gICAgICAgICAgICA8dmFsLXRleHRcbiAgICAgICAgICAgICAgW3Byb3BzXT1cInsgY29udGVudDogdW5zYXZlZENoYW5nZXNUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ21lZGl1bScsIHNpemU6ICdtZWRpdW0nLCBib2xkOiBmYWxzZSB9XCJcbiAgICAgICAgICAgID48L3ZhbC10ZXh0PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8ZGl2IGNsYXNzPVwiZGl2aWRlclwiPjwvZGl2PlxuXG4gICAgICAgIDwhLS0gTWl4ZWQgY29udGVudDogR2xvYmFsICsgQ29tcG9uZW50IHNwZWNpZmljIC0tPlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2VjdGlvblwiPlxuICAgICAgICAgIDxoMz5NaXhlZCBDb250ZW50IEV4YW1wbGU8L2gzPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJtaXhlZC1jb250ZW50XCI+XG4gICAgICAgICAgICA8IS0tIENvbXBvbmVudC1zcGVjaWZpYyBjb250ZW50IC0tPlxuICAgICAgICAgICAgPHZhbC10ZXh0IFtwcm9wc109XCJjb21wb25lbnREZXNjcmlwdGlvblByb3BzXCI+PC92YWwtdGV4dD5cblxuICAgICAgICAgICAgPGJyIC8+PGJyIC8+XG5cbiAgICAgICAgICAgIDwhLS0gQWN0aW9uIGJ1dHRvbnMgbWl4aW5nIGdsb2JhbCBhbmQgY29tcG9uZW50IGNvbnRlbnQgLS0+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiYWN0aW9uLWJ1dHRvbnNcIj5cbiAgICAgICAgICAgICAgPGlvbi1idXR0b24gY29sb3I9XCJwcmltYXJ5XCIgKGNsaWNrKT1cInBlcmZvcm1BY3Rpb24oKVwiPlxuICAgICAgICAgICAgICAgIHt7IHNhdmVCdXR0b24kIHwgYXN5bmMgfX1cbiAgICAgICAgICAgICAgPC9pb24tYnV0dG9uPlxuICAgICAgICAgICAgICA8aW9uLWJ1dHRvbiBmaWxsPVwib3V0bGluZVwiIChjbGljayk9XCJjYW5jZWxBY3Rpb24oKVwiPlxuICAgICAgICAgICAgICAgIHt7IGNhbmNlbEJ1dHRvbiQgfCBhc3luYyB9fVxuICAgICAgICAgICAgICA8L2lvbi1idXR0b24+XG4gICAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgICAgPCEtLSBTdGF0dXMgbWVzc2FnZSB1c2luZyBnbG9iYWwgY29udGVudCAtLT5cbiAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJhY3Rpb25QZXJmb3JtZWRcIiBjbGFzcz1cInN0YXR1cy1tZXNzYWdlXCI+XG4gICAgICAgICAgICAgIDx2YWwtdGV4dFxuICAgICAgICAgICAgICAgIFtwcm9wc109XCJ7IGNvbnRlbnQ6IHN1Y2Nlc3NUZXh0JCB8IGFzeW5jLCBjb2xvcjogJ3N1Y2Nlc3MnLCBzaXplOiAnc21hbGwnLCBib2xkOiBmYWxzZSB9XCJcbiAgICAgICAgICAgICAgPjwvdmFsLXRleHQ+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG5cbiAgICAgICAgPCEtLSBEZW1vIG9mIHN5bmNocm9ub3VzIGdsb2JhbCBjb250ZW50IGFjY2VzcyAtLT5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICA8aDM+U3luY2hyb25vdXMgQWNjZXNzIEV4YW1wbGU8L2gzPlxuICAgICAgICAgIDxwPlxuICAgICAgICAgICAgT0sgYnV0dG9uIHRleHQgKHN5bmMpOiA8c3Ryb25nPnt7IGdldE9rVGV4dFN5bmMoKSB9fTwvc3Ryb25nPlxuICAgICAgICAgIDwvcD5cbiAgICAgICAgICA8cD5cbiAgICAgICAgICAgIENhbmNlbCBidXR0b24gdGV4dCAoc3luYyk6IDxzdHJvbmc+e3sgZ2V0Q2FuY2VsVGV4dFN5bmMoKSB9fTwvc3Ryb25nPlxuICAgICAgICAgIDwvcD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2lvbi1jYXJkLWNvbnRlbnQ+XG4gICAgPC9pb24tY2FyZD5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgLmxhbmd1YWdlLXNlY3Rpb24ge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBnYXA6IDhweDtcbiAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgIH1cblxuICAgICAgLmRpdmlkZXIge1xuICAgICAgICBoZWlnaHQ6IDFweDtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLWxpZ2h0KTtcbiAgICAgICAgbWFyZ2luOiAxNnB4IDA7XG4gICAgICB9XG5cbiAgICAgIC5zZWN0aW9uIHtcbiAgICAgICAgbWFyZ2luLWJvdHRvbTogMTZweDtcbiAgICAgIH1cblxuICAgICAgLnNlY3Rpb24gaDMge1xuICAgICAgICBtYXJnaW46IDAgMCAxMnB4IDA7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1pb24tY29sb3ItcHJpbWFyeSk7XG4gICAgICB9XG5cbiAgICAgIC5idXR0b24tZ3JpZCB7XG4gICAgICAgIGRpc3BsYXk6IGdyaWQ7XG4gICAgICAgIGdyaWQtdGVtcGxhdGUtY29sdW1uczogcmVwZWF0KGF1dG8tZml0LCBtaW5tYXgoMTIwcHgsIDFmcikpO1xuICAgICAgICBnYXA6IDhweDtcbiAgICAgIH1cblxuICAgICAgLnN0YXRlLW1lc3NhZ2VzIHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgZ2FwOiA4cHg7XG4gICAgICB9XG5cbiAgICAgIC5zdGF0ZS1pdGVtIHtcbiAgICAgICAgcGFkZGluZzogOHB4O1xuICAgICAgICBib3JkZXItcmFkaXVzOiA0cHg7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWlvbi1jb2xvci1saWdodC1zaGFkZSk7XG4gICAgICB9XG5cbiAgICAgIC5zdGF0ZS1pdGVtLmxvYWRpbmcge1xuICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1pb24tY29sb3ItbWVkaXVtLXRpbnQpO1xuICAgICAgfVxuXG4gICAgICAuc3RhdGUtaXRlbS5zdWNjZXNzIHtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLXN1Y2Nlc3MtdGludCk7XG4gICAgICB9XG5cbiAgICAgIC5zdGF0ZS1pdGVtLmVycm9yIHtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLWRhbmdlci10aW50KTtcbiAgICAgIH1cblxuICAgICAgLnN0YXRlLWl0ZW0ud2FybmluZyB7XG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWlvbi1jb2xvci13YXJuaW5nLXRpbnQpO1xuICAgICAgfVxuXG4gICAgICAuc3RhdGUtaXRlbS5pbmZvIHtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLXByaW1hcnktdGludCk7XG4gICAgICB9XG5cbiAgICAgIC5leGFtcGxlLWZvcm0ge1xuICAgICAgICBtYXJnaW4tdG9wOiAxMnB4O1xuICAgICAgfVxuXG4gICAgICAuY29uZmlybWF0aW9uLWV4YW1wbGVzIHtcbiAgICAgICAgcGFkZGluZzogMTJweDtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLWxpZ2h0LXRpbnQpO1xuICAgICAgICBib3JkZXItcmFkaXVzOiA4cHg7XG4gICAgICB9XG5cbiAgICAgIC5taXhlZC1jb250ZW50IHtcbiAgICAgICAgcGFkZGluZzogMTJweDtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLWxpZ2h0LXNoYWRlKTtcbiAgICAgICAgYm9yZGVyLXJhZGl1czogOHB4O1xuICAgICAgfVxuXG4gICAgICAuYWN0aW9uLWJ1dHRvbnMge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBnYXA6IDhweDtcbiAgICAgICAgbWFyZ2luOiAxMnB4IDA7XG4gICAgICB9XG5cbiAgICAgIC5zdGF0dXMtbWVzc2FnZSB7XG4gICAgICAgIHBhZGRpbmc6IDhweDtcbiAgICAgICAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0taW9uLWNvbG9yLXN1Y2Nlc3MtdGludCk7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDRweDtcbiAgICAgICAgbWFyZ2luLXRvcDogOHB4O1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEdsb2JhbENvbnRlbnRFeGFtcGxlQ29tcG9uZW50IHtcbiAgcHJpdmF0ZSBjb250ZW50ID0gaW5qZWN0KENvbnRlbnRTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBjb21wb25lbnRDb250ZW50ID0gdGhpcy5jb250ZW50LmZvckNvbXBvbmVudCgnR2xvYmFsQ29udGVudEV4YW1wbGUnKTtcblxuICAvLyBGb3JtIGRhdGFcbiAgZm9ybURhdGEgPSB7XG4gICAgbmFtZTogJycsXG4gICAgZW1haWw6ICcnLFxuICAgIG1lc3NhZ2U6ICcnLFxuICB9O1xuXG4gIC8vIEFjdGlvbiBzdGF0ZVxuICBhY3Rpb25QZXJmb3JtZWQgPSBmYWxzZTtcblxuICAvLyBDb21wb25lbnQtc3BlY2lmaWMgY29udGVudCBwcm9wZXJ0aWVzXG4gIHRpdGxlUHJvcHM6IFRleHRNZXRhZGF0YSA9IHtcbiAgICBjb250ZW50S2V5OiAndGl0bGUnLFxuICAgIGNvbnRlbnRDbGFzczogJ0dsb2JhbENvbnRlbnRFeGFtcGxlJyxcbiAgICBjb250ZW50RmFsbGJhY2s6ICdHbG9iYWwgQ29udGVudCBFeGFtcGxlJyxcbiAgICBjb2xvcjogJ3ByaW1hcnknLFxuICAgIHNpemU6ICd4bGFyZ2UnLFxuICAgIGJvbGQ6IHRydWUsXG4gIH07XG5cbiAgbGFuZ3VhZ2VMYWJlbDogVGV4dE1ldGFkYXRhID0ge1xuICAgIGNvbnRlbnRLZXk6ICdsYW5ndWFnZUxhYmVsJyxcbiAgICBjb250ZW50Q2xhc3M6ICdHbG9iYWxDb250ZW50RXhhbXBsZScsXG4gICAgY29udGVudEZhbGxiYWNrOiAnTGFuZ3VhZ2U6JyxcbiAgICBjb2xvcjogJ21lZGl1bScsXG4gICAgc2l6ZTogJ21lZGl1bScsXG4gICAgYm9sZDogdHJ1ZSxcbiAgfTtcblxuICBjb21wb25lbnREZXNjcmlwdGlvblByb3BzOiBUZXh0TWV0YWRhdGEgPSB7XG4gICAgY29udGVudEtleTogJ2Rlc2NyaXB0aW9uJyxcbiAgICBjb250ZW50Q2xhc3M6ICdHbG9iYWxDb250ZW50RXhhbXBsZScsXG4gICAgY29udGVudEZhbGxiYWNrOiAnVGhpcyBleGFtcGxlIGRlbW9uc3RyYXRlcyBnbG9iYWwgYW5kIGNvbXBvbmVudC1zcGVjaWZpYyBjb250ZW50LicsXG4gICAgY29sb3I6ICdkYXJrJyxcbiAgICBzaXplOiAnbWVkaXVtJyxcbiAgICBib2xkOiBmYWxzZSxcbiAgfTtcblxuICAvLyBHbG9iYWwgYnV0dG9uIGNvbnRlbnQgKHJlYWN0aXZlKVxuICBzYXZlQnV0dG9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ3NhdmUnIH0pO1xuICBlZGl0QnV0dG9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ2VkaXQnIH0pO1xuICBkZWxldGVCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnZGVsZXRlJyB9KTtcbiAgY2FuY2VsQnV0dG9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ2NhbmNlbCcgfSk7XG4gIGJhY2tCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnYmFjaycgfSk7XG4gIG5leHRCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnbmV4dCcgfSk7XG4gIG9rQnV0dG9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ29rJyB9KTtcbiAgY2xvc2VCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnY2xvc2UnIH0pO1xuXG4gIC8vIEdsb2JhbCBhY3Rpb24gY29udGVudFxuICBhZGRCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnYWRkJyB9KTtcbiAgcmVtb3ZlQnV0dG9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ3JlbW92ZScgfSk7XG4gIHNlYXJjaEJ1dHRvbiQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdzZWFyY2gnIH0pO1xuICBmaWx0ZXJCdXR0b24kID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnZmlsdGVyJyB9KTtcbiAgc29ydEJ1dHRvbiQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdzb3J0JyB9KTtcbiAgcmVmcmVzaEJ1dHRvbiQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdyZWZyZXNoJyB9KTtcblxuICAvLyBHbG9iYWwgc3RhdGUgY29udGVudFxuICBsb2FkaW5nVGV4dCQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdsb2FkaW5nJyB9KTtcbiAgc3VjY2Vzc1RleHQkID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnc3VjY2VzcycgfSk7XG4gIGVycm9yVGV4dCQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdlcnJvcicgfSk7XG4gIHdhcm5pbmdUZXh0JCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ3dhcm5pbmcnIH0pO1xuICBpbmZvVGV4dCQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdpbmZvJyB9KTtcbiAgbm9EYXRhVGV4dCQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdub0RhdGEnIH0pO1xuXG4gIC8vIEdsb2JhbCBmb3JtIGNvbnRlbnRcbiAgcmVxdWlyZWRUZXh0JCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ3JlcXVpcmVkJyB9KTtcbiAgb3B0aW9uYWxUZXh0JCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ29wdGlvbmFsJyB9KTtcbiAgc2VhcmNoUGxhY2Vob2xkZXIkID0gdGhpcy5jb250ZW50LmZyb21Db250ZW50KHsga2V5OiAnc2VhcmNoUGxhY2Vob2xkZXInIH0pO1xuXG4gIC8vIEdsb2JhbCBjb25maXJtYXRpb24gY29udGVudCB3aXRoIGludGVycG9sYXRpb25cbiAgZGVsZXRlQ29uZmlybWF0aW9uJCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudFdpdGhJbnRlcnBvbGF0aW9uKHtcbiAgICBrZXk6ICdkZWxldGVDb25maXJtYXRpb24nLFxuICAgIGludGVycG9sYXRpb246IHsgaXRlbU5hbWU6ICdlc3RlIHJlZ2lzdHJvJyB9LFxuICB9KTtcblxuICBhcmVZb3VTdXJlVGV4dCQgPSB0aGlzLmNvbnRlbnQuZnJvbUNvbnRlbnQoeyBrZXk6ICdhcmVZb3VTdXJlJyB9KTtcbiAgdW5zYXZlZENoYW5nZXNUZXh0JCA9IHRoaXMuY29udGVudC5mcm9tQ29udGVudCh7IGtleTogJ3Vuc2F2ZWRDaGFuZ2VzJyB9KTtcblxuICAvKipcbiAgICogU2V0IGxhbmd1YWdlXG4gICAqL1xuICBzZXRMYW5ndWFnZShsYW5nOiAnZXMnIHwgJ2VuJykge1xuICAgIHRoaXMuY29udGVudC5zZXRMYW5nKGxhbmcgYXMgYW55KTtcbiAgfVxuXG4gIC8qKlxuICAgKiBQZXJmb3JtIGFuIGFjdGlvbiB0byBkZW1vbnN0cmF0ZSBzdGF0dXMgbWVzc2FnZXNcbiAgICovXG4gIHBlcmZvcm1BY3Rpb24oKSB7XG4gICAgdGhpcy5hY3Rpb25QZXJmb3JtZWQgPSB0cnVlO1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5hY3Rpb25QZXJmb3JtZWQgPSBmYWxzZTtcbiAgICB9LCAzMDAwKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDYW5jZWwgYWN0aW9uXG4gICAqL1xuICBjYW5jZWxBY3Rpb24oKSB7XG4gICAgdGhpcy5mb3JtRGF0YSA9IHsgbmFtZTogJycsIGVtYWlsOiAnJywgbWVzc2FnZTogJycgfTtcbiAgICB0aGlzLmFjdGlvblBlcmZvcm1lZCA9IGZhbHNlO1xuICB9XG5cbiAgLyoqXG4gICAqIEV4YW1wbGUgb2Ygc3luY2hyb25vdXMgZ2xvYmFsIGNvbnRlbnQgYWNjZXNzXG4gICAqL1xuICBnZXRPa1RleHRTeW5jKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuY29udGVudC5nZXRHbG9iYWxUZXh0KCdvaycpO1xuICB9XG5cbiAgLyoqXG4gICAqIEV4YW1wbGUgb2Ygc3luY2hyb25vdXMgZ2xvYmFsIGNvbnRlbnQgYWNjZXNzIHVzaW5nIGdldFRleHRcbiAgICovXG4gIGdldENhbmNlbFRleHRTeW5jKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuY29udGVudC5nZXRUZXh0KCdjYW5jZWwnKTtcbiAgfVxufVxuIl19
@@ -1,43 +0,0 @@
1
- /**
2
- * Example content configuration for demonstrating the reactive content system.
3
- *
4
- * This file shows how to structure content for components that use the reactive
5
- * language system with the new fromContent pattern.
6
- */
7
- import { TextContent } from '../../services/lang-provider/types';
8
- // Example content for a sample component
9
- const exampleComponentContent = {
10
- es: {
11
- title: 'Ejemplo de Contenido Reactivo',
12
- subtitle: 'Este es un subtítulo que cambia automáticamente',
13
- description: 'Esta descripción se actualiza cuando cambias el idioma sin necesidad de recargar la página.',
14
- greeting: 'Hola {name}, tienes {count} mensajes nuevos',
15
- welcomeMessage: 'Bienvenido a la biblioteca de componentes Valtech',
16
- dynamicText: 'Este texto se actualiza automáticamente cuando cambias el idioma',
17
- buttonText: 'Cambiar Idioma',
18
- loadingText: 'Cargando...',
19
- errorMessage: 'Error: No se pudo cargar el contenido',
20
- successMessage: 'Contenido cargado exitosamente',
21
- confirmDialog: '¿Estás seguro de que quieres continuar?',
22
- cancelButton: 'Cancelar',
23
- acceptButton: 'Aceptar',
24
- },
25
- en: {
26
- title: 'Reactive Content Example',
27
- subtitle: 'This is a subtitle that changes automatically',
28
- description: 'This description updates when you change the language without needing to reload the page.',
29
- greeting: 'Hello {name}, you have {count} new messages',
30
- welcomeMessage: 'Welcome to the Valtech component library',
31
- dynamicText: 'This text updates automatically when you change the language',
32
- buttonText: 'Change Language',
33
- loadingText: 'Loading...',
34
- errorMessage: 'Error: Could not load content',
35
- successMessage: 'Content loaded successfully',
36
- confirmDialog: 'Are you sure you want to continue?',
37
- cancelButton: 'Cancel',
38
- acceptButton: 'Accept',
39
- },
40
- };
41
- // Export the content as a TextContent instance
42
- export default new TextContent(exampleComponentContent);
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhY3RpdmUtY29udGVudC1leGFtcGxlLWNvbnRlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92YWx0ZWNoLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL19leGFtcGxlcy9yZWFjdGl2ZS1jb250ZW50LWV4YW1wbGUtY29udGVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUVILE9BQU8sRUFBb0IsV0FBVyxFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFFbkYseUNBQXlDO0FBQ3pDLE1BQU0sdUJBQXVCLEdBQXFCO0lBQ2hELEVBQUUsRUFBRTtRQUNGLEtBQUssRUFBRSwrQkFBK0I7UUFDdEMsUUFBUSxFQUFFLGlEQUFpRDtRQUMzRCxXQUFXLEVBQ1QsNkZBQTZGO1FBQy9GLFFBQVEsRUFBRSw2Q0FBNkM7UUFDdkQsY0FBYyxFQUFFLG1EQUFtRDtRQUNuRSxXQUFXLEVBQUUsa0VBQWtFO1FBQy9FLFVBQVUsRUFBRSxnQkFBZ0I7UUFDNUIsV0FBVyxFQUFFLGFBQWE7UUFDMUIsWUFBWSxFQUFFLHVDQUF1QztRQUNyRCxjQUFjLEVBQUUsZ0NBQWdDO1FBQ2hELGFBQWEsRUFBRSx5Q0FBeUM7UUFDeEQsWUFBWSxFQUFFLFVBQVU7UUFDeEIsWUFBWSxFQUFFLFNBQVM7S0FDeEI7SUFDRCxFQUFFLEVBQUU7UUFDRixLQUFLLEVBQUUsMEJBQTBCO1FBQ2pDLFFBQVEsRUFBRSwrQ0FBK0M7UUFDekQsV0FBVyxFQUNULDJGQUEyRjtRQUM3RixRQUFRLEVBQUUsNkNBQTZDO1FBQ3ZELGNBQWMsRUFBRSwwQ0FBMEM7UUFDMUQsV0FBVyxFQUFFLDhEQUE4RDtRQUMzRSxVQUFVLEVBQUUsaUJBQWlCO1FBQzdCLFdBQVcsRUFBRSxZQUFZO1FBQ3pCLFlBQVksRUFBRSwrQkFBK0I7UUFDN0MsY0FBYyxFQUFFLDZCQUE2QjtRQUM3QyxhQUFhLEVBQUUsb0NBQW9DO1FBQ25ELFlBQVksRUFBRSxRQUFRO1FBQ3RCLFlBQVksRUFBRSxRQUFRO0tBQ3ZCO0NBQ0YsQ0FBQztBQUVGLCtDQUErQztBQUMvQyxlQUFlLElBQUksV0FBVyxDQUFDLHVCQUF1QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEV4YW1wbGUgY29udGVudCBjb25maWd1cmF0aW9uIGZvciBkZW1vbnN0cmF0aW5nIHRoZSByZWFjdGl2ZSBjb250ZW50IHN5c3RlbS5cbiAqXG4gKiBUaGlzIGZpbGUgc2hvd3MgaG93IHRvIHN0cnVjdHVyZSBjb250ZW50IGZvciBjb21wb25lbnRzIHRoYXQgdXNlIHRoZSByZWFjdGl2ZVxuICogbGFuZ3VhZ2Ugc3lzdGVtIHdpdGggdGhlIG5ldyBmcm9tQ29udGVudCBwYXR0ZXJuLlxuICovXG5cbmltcG9ydCB7IExhbmd1YWdlc0NvbnRlbnQsIFRleHRDb250ZW50IH0gZnJvbSAnLi4vLi4vc2VydmljZXMvbGFuZy1wcm92aWRlci90eXBlcyc7XG5cbi8vIEV4YW1wbGUgY29udGVudCBmb3IgYSBzYW1wbGUgY29tcG9uZW50XG5jb25zdCBleGFtcGxlQ29tcG9uZW50Q29udGVudDogTGFuZ3VhZ2VzQ29udGVudCA9IHtcbiAgZXM6IHtcbiAgICB0aXRsZTogJ0VqZW1wbG8gZGUgQ29udGVuaWRvIFJlYWN0aXZvJyxcbiAgICBzdWJ0aXRsZTogJ0VzdGUgZXMgdW4gc3VidMOtdHVsbyBxdWUgY2FtYmlhIGF1dG9tw6F0aWNhbWVudGUnLFxuICAgIGRlc2NyaXB0aW9uOlxuICAgICAgJ0VzdGEgZGVzY3JpcGNpw7NuIHNlIGFjdHVhbGl6YSBjdWFuZG8gY2FtYmlhcyBlbCBpZGlvbWEgc2luIG5lY2VzaWRhZCBkZSByZWNhcmdhciBsYSBww6FnaW5hLicsXG4gICAgZ3JlZXRpbmc6ICdIb2xhIHtuYW1lfSwgdGllbmVzIHtjb3VudH0gbWVuc2FqZXMgbnVldm9zJyxcbiAgICB3ZWxjb21lTWVzc2FnZTogJ0JpZW52ZW5pZG8gYSBsYSBiaWJsaW90ZWNhIGRlIGNvbXBvbmVudGVzIFZhbHRlY2gnLFxuICAgIGR5bmFtaWNUZXh0OiAnRXN0ZSB0ZXh0byBzZSBhY3R1YWxpemEgYXV0b23DoXRpY2FtZW50ZSBjdWFuZG8gY2FtYmlhcyBlbCBpZGlvbWEnLFxuICAgIGJ1dHRvblRleHQ6ICdDYW1iaWFyIElkaW9tYScsXG4gICAgbG9hZGluZ1RleHQ6ICdDYXJnYW5kby4uLicsXG4gICAgZXJyb3JNZXNzYWdlOiAnRXJyb3I6IE5vIHNlIHB1ZG8gY2FyZ2FyIGVsIGNvbnRlbmlkbycsXG4gICAgc3VjY2Vzc01lc3NhZ2U6ICdDb250ZW5pZG8gY2FyZ2FkbyBleGl0b3NhbWVudGUnLFxuICAgIGNvbmZpcm1EaWFsb2c6ICfCv0VzdMOhcyBzZWd1cm8gZGUgcXVlIHF1aWVyZXMgY29udGludWFyPycsXG4gICAgY2FuY2VsQnV0dG9uOiAnQ2FuY2VsYXInLFxuICAgIGFjY2VwdEJ1dHRvbjogJ0FjZXB0YXInLFxuICB9LFxuICBlbjoge1xuICAgIHRpdGxlOiAnUmVhY3RpdmUgQ29udGVudCBFeGFtcGxlJyxcbiAgICBzdWJ0aXRsZTogJ1RoaXMgaXMgYSBzdWJ0aXRsZSB0aGF0IGNoYW5nZXMgYXV0b21hdGljYWxseScsXG4gICAgZGVzY3JpcHRpb246XG4gICAgICAnVGhpcyBkZXNjcmlwdGlvbiB1cGRhdGVzIHdoZW4geW91IGNoYW5nZSB0aGUgbGFuZ3VhZ2Ugd2l0aG91dCBuZWVkaW5nIHRvIHJlbG9hZCB0aGUgcGFnZS4nLFxuICAgIGdyZWV0aW5nOiAnSGVsbG8ge25hbWV9LCB5b3UgaGF2ZSB7Y291bnR9IG5ldyBtZXNzYWdlcycsXG4gICAgd2VsY29tZU1lc3NhZ2U6ICdXZWxjb21lIHRvIHRoZSBWYWx0ZWNoIGNvbXBvbmVudCBsaWJyYXJ5JyxcbiAgICBkeW5hbWljVGV4dDogJ1RoaXMgdGV4dCB1cGRhdGVzIGF1dG9tYXRpY2FsbHkgd2hlbiB5b3UgY2hhbmdlIHRoZSBsYW5ndWFnZScsXG4gICAgYnV0dG9uVGV4dDogJ0NoYW5nZSBMYW5ndWFnZScsXG4gICAgbG9hZGluZ1RleHQ6ICdMb2FkaW5nLi4uJyxcbiAgICBlcnJvck1lc3NhZ2U6ICdFcnJvcjogQ291bGQgbm90IGxvYWQgY29udGVudCcsXG4gICAgc3VjY2Vzc01lc3NhZ2U6ICdDb250ZW50IGxvYWRlZCBzdWNjZXNzZnVsbHknLFxuICAgIGNvbmZpcm1EaWFsb2c6ICdBcmUgeW91IHN1cmUgeW91IHdhbnQgdG8gY29udGludWU/JyxcbiAgICBjYW5jZWxCdXR0b246ICdDYW5jZWwnLFxuICAgIGFjY2VwdEJ1dHRvbjogJ0FjY2VwdCcsXG4gIH0sXG59O1xuXG4vLyBFeHBvcnQgdGhlIGNvbnRlbnQgYXMgYSBUZXh0Q29udGVudCBpbnN0YW5jZVxuZXhwb3J0IGRlZmF1bHQgbmV3IFRleHRDb250ZW50KGV4YW1wbGVDb21wb25lbnRDb250ZW50KTtcblxuLyoqXG4gKiBUeXBlLXNhZmUgY29udGVudCBrZXlzIGZvciB0aGUgZXhhbXBsZSBjb21wb25lbnQuXG4gKiBVc2UgdGhpcyBpbnRlcmZhY2UgdG8gZW5zdXJlIHR5cGUgc2FmZXR5IHdoZW4gYWNjZXNzaW5nIGNvbnRlbnQga2V5cy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFeGFtcGxlQ29tcG9uZW50Q29udGVudEtleXMge1xuICB0aXRsZTogc3RyaW5nO1xuICBzdWJ0aXRsZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBncmVldGluZzogc3RyaW5nO1xuICB3ZWxjb21lTWVzc2FnZTogc3RyaW5nO1xuICBkeW5hbWljVGV4dDogc3RyaW5nO1xuICBidXR0b25UZXh0OiBzdHJpbmc7XG4gIGxvYWRpbmdUZXh0OiBzdHJpbmc7XG4gIGVycm9yTWVzc2FnZTogc3RyaW5nO1xuICBzdWNjZXNzTWVzc2FnZTogc3RyaW5nO1xuICBjb25maXJtRGlhbG9nOiBzdHJpbmc7XG4gIGNhbmNlbEJ1dHRvbjogc3RyaW5nO1xuICBhY2NlcHRCdXR0b246IHN0cmluZztcbn1cblxuLyoqXG4gKiBVdGlsaXR5IHR5cGUgZm9yIGdldHRpbmcgY29udGVudCBrZXlzIHdpdGggdHlwZSBzYWZldHkuXG4gKi9cbmV4cG9ydCB0eXBlIEV4YW1wbGVDb250ZW50S2V5ID0ga2V5b2YgRXhhbXBsZUNvbXBvbmVudENvbnRlbnRLZXlzO1xuIl19