valtech-components 2.0.302 → 2.0.305

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 (32) hide show
  1. package/esm2022/lib/components/atoms/button/button.component.mjs +103 -23
  2. package/esm2022/lib/components/types.mjs +1 -1
  3. package/esm2022/lib/services/lang-provider/content.mjs +1 -72
  4. package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +4 -9
  5. package/esm2022/lib/shared/utils/content.mjs +2 -8
  6. package/esm2022/public-api.mjs +1 -12
  7. package/fesm2022/valtech-components.mjs +124 -2824
  8. package/fesm2022/valtech-components.mjs.map +1 -1
  9. package/lib/components/atoms/button/button.component.d.ts +33 -2
  10. package/lib/components/types.d.ts +19 -7
  11. package/package.json +1 -1
  12. package/public-api.d.ts +0 -10
  13. package/esm2022/lib/examples/comprehensive-link-test.component.mjs +0 -208
  14. package/esm2022/lib/examples/custom-content-demo.component.mjs +0 -291
  15. package/esm2022/lib/examples/display-demo.component.mjs +0 -518
  16. package/esm2022/lib/examples/display-simple-example.component.mjs +0 -202
  17. package/esm2022/lib/examples/link-processing-example.component.mjs +0 -233
  18. package/esm2022/lib/examples/multi-language-demo.component.mjs +0 -304
  19. package/esm2022/lib/examples/reactive-components-demo.component.mjs +0 -303
  20. package/esm2022/lib/examples/reactivity-test.component.mjs +0 -200
  21. package/esm2022/lib/examples/selector-examples.component.mjs +0 -234
  22. package/esm2022/lib/examples/user-issue-test.component.mjs +0 -267
  23. package/lib/examples/comprehensive-link-test.component.d.ts +0 -23
  24. package/lib/examples/custom-content-demo.component.d.ts +0 -26
  25. package/lib/examples/display-demo.component.d.ts +0 -62
  26. package/lib/examples/display-simple-example.component.d.ts +0 -23
  27. package/lib/examples/link-processing-example.component.d.ts +0 -26
  28. package/lib/examples/multi-language-demo.component.d.ts +0 -34
  29. package/lib/examples/reactive-components-demo.component.d.ts +0 -45
  30. package/lib/examples/reactivity-test.component.d.ts +0 -27
  31. package/lib/examples/selector-examples.component.d.ts +0 -21
  32. package/lib/examples/user-issue-test.component.d.ts +0 -31
@@ -1,303 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component } from '@angular/core';
3
- import { IonCard, IonCardContent, IonCardHeader, IonCardTitle, IonItem, IonLabel, IonSelect, IonSelectOption, } from '@ionic/angular/standalone';
4
- import { Subscription, map } from 'rxjs';
5
- import { ButtonComponent } from '../components/atoms/button/button.component';
6
- import { AlertBoxComponent } from '../components/molecules/alert-box/alert-box.component';
7
- import { ComponentStates } from '../components/types';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "../services/content.service";
10
- import * as i2 from "../services/lang-provider/lang-provider.service";
11
- import * as i3 from "@angular/common";
12
- /**
13
- * Simple demo component showcasing reactive content patterns
14
- * for buttons and alert boxes.
15
- *
16
- * Demonstrates:
17
- * - Button components with reactive text
18
- * - Alert boxes with reactive content
19
- * - Language switching
20
- * - Static vs reactive content patterns
21
- */
22
- export class ReactiveComponentsDemoComponent {
23
- constructor(contentService, langService) {
24
- this.contentService = contentService;
25
- this.langService = langService;
26
- this.subscriptions = new Subscription();
27
- }
28
- ngOnInit() {
29
- this.initializeContent();
30
- this.initializeComponents();
31
- }
32
- ngOnDestroy() {
33
- this.subscriptions.unsubscribe();
34
- }
35
- initializeContent() {
36
- // Page-level content
37
- this.pageTitle$ = this.contentService.fromContent({
38
- className: 'reactiveDemo',
39
- key: 'title',
40
- fallback: 'Reactive Components Demo',
41
- });
42
- this.languageLabel$ = this.contentService.fromContent({
43
- className: '_global',
44
- key: 'language',
45
- fallback: 'Language',
46
- });
47
- this.buttonSectionTitle$ = this.contentService.fromContent({
48
- className: 'reactiveDemo',
49
- key: 'buttons.title',
50
- fallback: 'Reactive Buttons',
51
- });
52
- this.alertSectionTitle$ = this.contentService.fromContent({
53
- className: 'reactiveDemo',
54
- key: 'alerts.title',
55
- fallback: 'Reactive Alerts',
56
- });
57
- // Language state
58
- this.currentLanguage$ = this.langService.currentLang$;
59
- this.availableLanguages$ = this.langService.currentLang$.pipe(map(() => this.langService.availableLangs));
60
- }
61
- initializeComponents() {
62
- // Reactive buttons with common actions
63
- this.saveButton = {
64
- color: 'primary',
65
- fill: 'solid',
66
- type: 'button',
67
- state: ComponentStates.ENABLED,
68
- textConfig: {
69
- className: '_global',
70
- key: 'save',
71
- fallback: 'Save',
72
- },
73
- handler: () => this.handleSave(),
74
- };
75
- this.cancelButton = {
76
- color: 'medium',
77
- fill: 'outline',
78
- type: 'button',
79
- state: ComponentStates.ENABLED,
80
- textConfig: {
81
- className: '_global',
82
- key: 'cancel',
83
- fallback: 'Cancel',
84
- },
85
- handler: () => this.handleCancel(),
86
- };
87
- // Static button for comparison
88
- this.staticButton = {
89
- color: 'tertiary',
90
- fill: 'outline',
91
- type: 'button',
92
- state: ComponentStates.ENABLED,
93
- text: 'Static Button', // Static text
94
- handler: () => this.handleStatic(),
95
- };
96
- // Reactive alert boxes
97
- this.warningAlert = {
98
- box: {
99
- color: 'warning',
100
- rounded: true,
101
- bordered: false,
102
- icon: 'warning',
103
- },
104
- icon: {
105
- name: 'warning',
106
- color: 'warning',
107
- size: 'medium',
108
- },
109
- textConfig: {
110
- className: 'reactiveDemo',
111
- key: 'alerts.warning',
112
- fallback: 'This is a warning message',
113
- },
114
- textStyle: {
115
- size: 'medium',
116
- bold: false,
117
- },
118
- };
119
- this.successAlert = {
120
- box: {
121
- color: 'success',
122
- rounded: true,
123
- bordered: false,
124
- icon: 'checkmark-circle',
125
- },
126
- icon: {
127
- name: 'checkmark-circle',
128
- color: 'success',
129
- size: 'medium',
130
- },
131
- textConfig: {
132
- className: 'reactiveDemo',
133
- key: 'alerts.success',
134
- fallback: 'Operation completed successfully!',
135
- },
136
- textStyle: {
137
- size: 'medium',
138
- bold: true,
139
- },
140
- };
141
- // Static alert for comparison
142
- this.staticAlert = {
143
- box: {
144
- color: 'dark',
145
- rounded: true,
146
- bordered: false,
147
- icon: 'information-circle',
148
- },
149
- icon: {
150
- name: 'information-circle',
151
- color: 'dark',
152
- size: 'medium',
153
- },
154
- text: 'This is a static alert message', // Static text
155
- textStyle: {
156
- size: 'medium',
157
- bold: false,
158
- },
159
- };
160
- }
161
- // Event handlers
162
- changeLanguage(language) {
163
- this.langService.setLang(language);
164
- }
165
- handleSave() {
166
- console.log('Save button clicked');
167
- }
168
- handleCancel() {
169
- console.log('Cancel button clicked');
170
- }
171
- handleStatic() {
172
- console.log('Static button clicked');
173
- }
174
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactiveComponentsDemoComponent, deps: [{ token: i1.ContentService }, { token: i2.LangService }], target: i0.ɵɵFactoryTarget.Component }); }
175
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReactiveComponentsDemoComponent, isStandalone: true, selector: "val-reactive-components-demo", ngImport: i0, template: `
176
- <div class="reactive-components-demo">
177
- <ion-card>
178
- <ion-card-header>
179
- <ion-card-title>{{ pageTitle$ | async }}</ion-card-title>
180
- </ion-card-header>
181
-
182
- <ion-card-content>
183
- <!-- Language Selector -->
184
- <ion-item>
185
- <ion-label>{{ languageLabel$ | async }}</ion-label>
186
- <ion-select
187
- interface="popover"
188
- [value]="currentLanguage$ | async"
189
- (ionChange)="changeLanguage($event.detail.value)"
190
- >
191
- <ion-select-option *ngFor="let lang of availableLanguages$ | async" [value]="lang">
192
- {{ lang | uppercase }}
193
- </ion-select-option>
194
- </ion-select>
195
- </ion-item>
196
-
197
- <!-- Reactive Buttons Demo -->
198
- <div class="section">
199
- <h3>{{ buttonSectionTitle$ | async }}</h3>
200
-
201
- <!-- Common action buttons with reactive text -->
202
- <div class="button-grid">
203
- <val-button [props]="saveButton"></val-button>
204
- <val-button [props]="cancelButton"></val-button>
205
- <val-button [props]="staticButton"></val-button>
206
- </div>
207
- </div>
208
-
209
- <!-- Reactive Alert Boxes Demo -->
210
- <div class="section">
211
- <h3>{{ alertSectionTitle$ | async }}</h3>
212
-
213
- <!-- Alert with reactive content -->
214
- <val-alert-box [props]="warningAlert"></val-alert-box>
215
- <val-alert-box [props]="successAlert"></val-alert-box>
216
- <val-alert-box [props]="staticAlert"></val-alert-box>
217
- </div>
218
-
219
- <!-- Analysis -->
220
- <div class="section">
221
- <h3>Analysis</h3>
222
- <div class="analysis-info">
223
- <p><strong>Current Language:</strong> {{ currentLanguage$ | async | uppercase }}</p>
224
- <p><strong>Available Languages:</strong> {{ (availableLanguages$ | async)?.join(', ') | uppercase }}</p>
225
- </div>
226
- </div>
227
- </ion-card-content>
228
- </ion-card>
229
- </div>
230
- `, isInline: true, styles: [".reactive-components-demo{padding:16px}.section{margin:24px 0}.button-grid{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}.analysis-info{background:var(--ion-color-light);padding:16px;border-radius:8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.UpperCasePipe, name: "uppercase" }, { 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: IonSelect, selector: "ion-select", inputs: ["cancelText", "color", "compareWith", "disabled", "expandedIcon", "fill", "interface", "interfaceOptions", "justify", "label", "labelPlacement", "mode", "multiple", "name", "okText", "placeholder", "selectedText", "shape", "toggleIcon", "value"] }, { kind: "component", type: IonSelectOption, selector: "ion-select-option", inputs: ["disabled", "value"] }, { 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: ButtonComponent, selector: "val-button", inputs: ["props"], outputs: ["onClick"] }, { kind: "component", type: AlertBoxComponent, selector: "val-alert-box", inputs: ["props"] }] }); }
231
- }
232
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactiveComponentsDemoComponent, decorators: [{
233
- type: Component,
234
- args: [{ selector: 'val-reactive-components-demo', standalone: true, imports: [
235
- CommonModule,
236
- IonCard,
237
- IonCardContent,
238
- IonCardHeader,
239
- IonCardTitle,
240
- IonSelect,
241
- IonSelectOption,
242
- IonItem,
243
- IonLabel,
244
- ButtonComponent,
245
- AlertBoxComponent,
246
- ], template: `
247
- <div class="reactive-components-demo">
248
- <ion-card>
249
- <ion-card-header>
250
- <ion-card-title>{{ pageTitle$ | async }}</ion-card-title>
251
- </ion-card-header>
252
-
253
- <ion-card-content>
254
- <!-- Language Selector -->
255
- <ion-item>
256
- <ion-label>{{ languageLabel$ | async }}</ion-label>
257
- <ion-select
258
- interface="popover"
259
- [value]="currentLanguage$ | async"
260
- (ionChange)="changeLanguage($event.detail.value)"
261
- >
262
- <ion-select-option *ngFor="let lang of availableLanguages$ | async" [value]="lang">
263
- {{ lang | uppercase }}
264
- </ion-select-option>
265
- </ion-select>
266
- </ion-item>
267
-
268
- <!-- Reactive Buttons Demo -->
269
- <div class="section">
270
- <h3>{{ buttonSectionTitle$ | async }}</h3>
271
-
272
- <!-- Common action buttons with reactive text -->
273
- <div class="button-grid">
274
- <val-button [props]="saveButton"></val-button>
275
- <val-button [props]="cancelButton"></val-button>
276
- <val-button [props]="staticButton"></val-button>
277
- </div>
278
- </div>
279
-
280
- <!-- Reactive Alert Boxes Demo -->
281
- <div class="section">
282
- <h3>{{ alertSectionTitle$ | async }}</h3>
283
-
284
- <!-- Alert with reactive content -->
285
- <val-alert-box [props]="warningAlert"></val-alert-box>
286
- <val-alert-box [props]="successAlert"></val-alert-box>
287
- <val-alert-box [props]="staticAlert"></val-alert-box>
288
- </div>
289
-
290
- <!-- Analysis -->
291
- <div class="section">
292
- <h3>Analysis</h3>
293
- <div class="analysis-info">
294
- <p><strong>Current Language:</strong> {{ currentLanguage$ | async | uppercase }}</p>
295
- <p><strong>Available Languages:</strong> {{ (availableLanguages$ | async)?.join(', ') | uppercase }}</p>
296
- </div>
297
- </div>
298
- </ion-card-content>
299
- </ion-card>
300
- </div>
301
- `, styles: [".reactive-components-demo{padding:16px}.section{margin:24px 0}.button-grid{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}.analysis-info{background:var(--ion-color-light);padding:16px;border-radius:8px}\n"] }]
302
- }], ctorParameters: () => [{ type: i1.ContentService }, { type: i2.LangService }] });
303
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhY3RpdmUtY29tcG9uZW50cy1kZW1vLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2V4YW1wbGVzL3JlYWN0aXZlLWNvbXBvbmVudHMtZGVtby5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQXFCLE1BQU0sZUFBZSxDQUFDO0FBQzdELE9BQU8sRUFDTCxPQUFPLEVBQ1AsY0FBYyxFQUNkLGFBQWEsRUFDYixZQUFZLEVBQ1osT0FBTyxFQUNQLFFBQVEsRUFDUixTQUFTLEVBQ1QsZUFBZSxHQUNoQixNQUFNLDJCQUEyQixDQUFDO0FBQ25DLE9BQU8sRUFBYyxZQUFZLEVBQUUsR0FBRyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3JELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1REFBdUQsQ0FBQztBQUUxRixPQUFPLEVBQWtCLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDOzs7OztBQUl0RTs7Ozs7Ozs7O0dBU0c7QUErRkgsTUFBTSxPQUFPLCtCQUErQjtJQXNCMUMsWUFDVSxjQUE4QixFQUM5QixXQUF3QjtRQUR4QixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFDOUIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUF2QjFCLGtCQUFhLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQXdCeEMsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUN6QixJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxF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O0lBRUQsaUJBQWlCO0lBQ2pCLGNBQWMsQ0FBQyxRQUFnQjtRQUM3QixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRU8sVUFBVTtRQUNoQixPQUFPLENBQUMsR0FBRyxDQUFDLHFCQUFxQixDQUFDLENBQUM7SUFDckMsQ0FBQztJQUVPLFlBQVk7UUFDbEIsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFFTyxZQUFZO1FBQ2xCLE9BQU8sQ0FBQyxHQUFHLENBQUMsdUJBQXVCLENBQUMsQ0FBQztJQUN2QyxDQUFDOytHQTVMVSwrQkFBK0I7bUdBQS9CLCtCQUErQix3RkE5RWhDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdURULHlSQW5FQyxZQUFZLDhRQUNaLE9BQU8seUxBQ1AsY0FBYywrRUFDZCxhQUFhLHNHQUNiLFlBQVksc0ZBQ1osU0FBUyx1VEFDVCxlQUFlLDZGQUNmLE9BQU8sME5BQ1AsUUFBUSw2RkFDUixlQUFlLGdHQUNmLGlCQUFpQjs7NEZBZ0ZSLCtCQUErQjtrQkE5RjNDLFNBQVM7K0JBQ0UsOEJBQThCLGNBQzVCLElBQUksV0FDUDt3QkFDUCxZQUFZO3dCQUNaLE9BQU87d0JBQ1AsY0FBYzt3QkFDZCxhQUFhO3dCQUNiLFlBQVk7d0JBQ1osU0FBUzt3QkFDVCxlQUFlO3dCQUNmLE9BQU87d0JBQ1AsUUFBUTt3QkFDUixlQUFlO3dCQUNmLGlCQUFpQjtxQkFDbEIsWUFDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVEVCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBJb25DYXJkLFxuICBJb25DYXJkQ29udGVudCxcbiAgSW9uQ2FyZEhlYWRlcixcbiAgSW9uQ2FyZFRpdGxlLFxuICBJb25JdGVtLFxuICBJb25MYWJlbCxcbiAgSW9uU2VsZWN0LFxuICBJb25TZWxlY3RPcHRpb24sXG59IGZyb20gJ0Bpb25pYy9hbmd1bGFyL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSwgU3Vic2NyaXB0aW9uLCBtYXAgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvYXRvbXMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQWxlcnRCb3hDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL21vbGVjdWxlcy9hbGVydC1ib3gvYWxlcnQtYm94LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSZWFjdGl2ZUFsZXJ0Qm94TWV0YWRhdGEgfSBmcm9tICcuLi9jb21wb25lbnRzL21vbGVjdWxlcy9hbGVydC1ib3gvdHlwZXMnO1xuaW1wb3J0IHsgQnV0dG9uTWV0YWRhdGEsIENvbXBvbmVudFN0YXRlcyB9IGZyb20gJy4uL2NvbXBvbmVudHMvdHlwZXMnO1xuaW1wb3J0IHsgQ29udGVudFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9jb250ZW50LnNlcnZpY2UnO1xuaW1wb3J0IHsgTGFuZ1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9sYW5nLXByb3ZpZGVyL2xhbmctcHJvdmlkZXIuc2VydmljZSc7XG5cbi8qKlxuICogU2ltcGxlIGRlbW8gY29tcG9uZW50IHNob3djYXNpbmcgcmVhY3RpdmUgY29udGVudCBwYXR0ZXJuc1xuICogZm9yIGJ1dHRvbnMgYW5kIGFsZXJ0IGJveGVzLlxuICpcbiAqIERlbW9uc3RyYXRlczpcbiAqIC0gQnV0dG9uIGNvbXBvbmVudHMgd2l0aCByZWFjdGl2ZSB0ZXh0XG4gKiAtIEFsZXJ0IGJveGVzIHdpdGggcmVhY3RpdmUgY29udGVudFxuICogLSBMYW5ndWFnZSBzd2l0Y2hpbmdcbiAqIC0gU3RhdGljIHZzIHJlYWN0aXZlIGNvbnRlbnQgcGF0dGVybnNcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXJlYWN0aXZlLWNvbXBvbmVudHMtZGVtbycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgSW9uQ2FyZCxcbiAgICBJb25DYXJkQ29udGVudCxcbiAgICBJb25DYXJkSGVhZGVyLFxuICAgIElvbkNhcmRUaXRsZSxcbiAgICBJb25TZWxlY3QsXG4gICAgSW9uU2VsZWN0T3B0aW9uLFxuICAgIElvbkl0ZW0sXG4gICAgSW9uTGFiZWwsXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIEFsZXJ0Qm94Q29tcG9uZW50LFxuICBdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJyZWFjdGl2ZS1jb21wb25lbnRzLWRlbW9cIj5cbiAgICAgIDxpb24tY2FyZD5cbiAgICAgICAgPGlvbi1jYXJkLWhlYWRlcj5cbiAgICAgICAgICA8aW9uLWNhcmQtdGl0bGU+e3sgcGFnZVRpdGxlJCB8IGFzeW5jIH19PC9pb24tY2FyZC10aXRsZT5cbiAgICAgICAgPC9pb24tY2FyZC1oZWFkZXI+XG5cbiAgICAgICAgPGlvbi1jYXJkLWNvbnRlbnQ+XG4gICAgICAgICAgPCEtLSBMYW5ndWFnZSBTZWxlY3RvciAtLT5cbiAgICAgICAgICA8aW9uLWl0ZW0+XG4gICAgICAgICAgICA8aW9uLWxhYmVsPnt7IGxhbmd1YWdlTGFiZWwkIHwgYXN5bmMgfX08L2lvbi1sYWJlbD5cbiAgICAgICAgICAgIDxpb24tc2VsZWN0XG4gICAgICAgICAgICAgIGludGVyZmFjZT1cInBvcG92ZXJcIlxuICAgICAgICAgICAgICBbdmFsdWVdPVwiY3VycmVudExhbmd1YWdlJCB8IGFzeW5jXCJcbiAgICAgICAgICAgICAgKGlvbkNoYW5nZSk9XCJjaGFuZ2VMYW5ndWFnZSgkZXZlbnQuZGV0YWlsLnZhbHVlKVwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIDxpb24tc2VsZWN0LW9wdGlvbiAqbmdGb3I9XCJsZXQgbGFuZyBvZiBhdmFpbGFibGVMYW5ndWFnZXMkIHwgYXN5bmNcIiBbdmFsdWVdPVwibGFuZ1wiPlxuICAgICAgICAgICAgICAgIHt7IGxhbmcgfCB1cHBlcmNhc2UgfX1cbiAgICAgICAgICAgICAgPC9pb24tc2VsZWN0LW9wdGlvbj5cbiAgICAgICAgICAgIDwvaW9uLXNlbGVjdD5cbiAgICAgICAgICA8L2lvbi1pdGVtPlxuXG4gICAgICAgICAgPCEtLSBSZWFjdGl2ZSBCdXR0b25zIERlbW8gLS0+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICAgIDxoMz57eyBidXR0b25TZWN0aW9uVGl0bGUkIHwgYXN5bmMgfX08L2gzPlxuXG4gICAgICAgICAgICA8IS0tIENvbW1vbiBhY3Rpb24gYnV0dG9ucyB3aXRoIHJlYWN0aXZlIHRleHQgLS0+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiYnV0dG9uLWdyaWRcIj5cbiAgICAgICAgICAgICAgPHZhbC1idXR0b24gW3Byb3BzXT1cInNhdmVCdXR0b25cIj48L3ZhbC1idXR0b24+XG4gICAgICAgICAgICAgIDx2YWwtYnV0dG9uIFtwcm9wc109XCJjYW5jZWxCdXR0b25cIj48L3ZhbC1idXR0b24+XG4gICAgICAgICAgICAgIDx2YWwtYnV0dG9uIFtwcm9wc109XCJzdGF0aWNCdXR0b25cIj48L3ZhbC1idXR0b24+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgIDwhLS0gUmVhY3RpdmUgQWxlcnQgQm94ZXMgRGVtbyAtLT5cbiAgICAgICAgICA8ZGl2IGNsYXNzPVwic2VjdGlvblwiPlxuICAgICAgICAgICAgPGgzPnt7IGFsZXJ0U2VjdGlvblRpdGxlJCB8IGFzeW5jIH19PC9oMz5cblxuICAgICAgICAgICAgPCEtLSBBbGVydCB3aXRoIHJlYWN0aXZlIGNvbnRlbnQgLS0+XG4gICAgICAgICAgICA8dmFsLWFsZXJ0LWJveCBbcHJvcHNdPVwid2FybmluZ0FsZXJ0XCI+PC92YWwtYWxlcnQtYm94PlxuICAgICAgICAgICAgPHZhbC1hbGVydC1ib3ggW3Byb3BzXT1cInN1Y2Nlc3NBbGVydFwiPjwvdmFsLWFsZXJ0LWJveD5cbiAgICAgICAgICAgIDx2YWwtYWxlcnQtYm94IFtwcm9wc109XCJzdGF0aWNBbGVydFwiPjwvdmFsLWFsZXJ0LWJveD5cbiAgICAgICAgICA8L2Rpdj5cblxuICAgICAgICAgIDwhLS0gQW5hbHlzaXMgLS0+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInNlY3Rpb25cIj5cbiAgICAgICAgICAgIDxoMz5BbmFseXNpczwvaDM+XG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiYW5hbHlzaXMtaW5mb1wiPlxuICAgICAgICAgICAgICA8cD48c3Ryb25nPkN1cnJlbnQgTGFuZ3VhZ2U6PC9zdHJvbmc+IHt7IGN1cnJlbnRMYW5ndWFnZSQgfCBhc3luYyB8IHVwcGVyY2FzZSB9fTwvcD5cbiAgICAgICAgICAgICAgPHA+PHN0cm9uZz5BdmFpbGFibGUgTGFuZ3VhZ2VzOjwvc3Ryb25nPiB7eyAoYXZhaWxhYmxlTGFuZ3VhZ2VzJCB8IGFzeW5jKT8uam9pbignLCAnKSB8IHVwcGVyY2FzZSB9fTwvcD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2lvbi1jYXJkLWNvbnRlbnQ+XG4gICAgICA8L2lvbi1jYXJkPlxuICAgIDwvZGl2PlxuICBgLFxuICBzdHlsZXM6IFtcbiAgICBgXG4gICAgICAucmVhY3RpdmUtY29tcG9uZW50cy1kZW1vIHtcbiAgICAgICAgcGFkZGluZzogMTZweDtcbiAgICAgIH1cbiAgICAgIC5zZWN0aW9uIHtcbiAgICAgICAgbWFyZ2luOiAyNHB4IDA7XG4gICAgICB9XG4gICAgICAuYnV0dG9uLWdyaWQge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBnYXA6IDEycHg7XG4gICAgICAgIGZsZXgtd3JhcDogd3JhcDtcbiAgICAgICAgbWFyZ2luOiAxNnB4IDA7XG4gICAgICB9XG4gICAgICAuYW5hbHlzaXMtaW5mbyB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWlvbi1jb2xvci1saWdodCk7XG4gICAgICAgIHBhZGRpbmc6IDE2cHg7XG4gICAgICAgIGJvcmRlci1yYWRpdXM6IDhweDtcbiAgICAgIH1cbiAgICBgLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBSZWFjdGl2ZUNvbXBvbmVudHNEZW1vQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBwcml2YXRlIHN1YnNjcmlwdGlvbnMgPSBuZXcgU3Vic2NyaXB0aW9uKCk7XG5cbiAgLy8gT2JzZXJ2YWJsZSBjb250ZW50IHN0cmVhbXNcbiAgcGFnZVRpdGxlJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuICBsYW5ndWFnZUxhYmVsJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuICBidXR0b25TZWN0aW9uVGl0bGUkOiBPYnNlcnZhYmxlPHN0cmluZz47XG4gIGFsZXJ0U2VjdGlvblRpdGxlJDogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIC8vIExhbmd1YWdlIHN0YXRlXG4gIGN1cnJlbnRMYW5ndWFnZSQ6IE9ic2VydmFibGU8c3RyaW5nPjtcbiAgYXZhaWxhYmxlTGFuZ3VhZ2VzJDogT2JzZXJ2YWJsZTxzdHJpbmdbXT47XG5cbiAgLy8gQ29tcG9uZW50IGNvbmZpZ3VyYXRpb25zXG4gIHNhdmVCdXR0b246IEJ1dHRvbk1ldGFkYXRhO1xuICBjYW5jZWxCdXR0b246IEJ1dHRvbk1ldGFkYXRhO1xuICBzdGF0aWNCdXR0b246IEJ1dHRvbk1ldGFkYXRhO1xuXG4gIHdhcm5pbmdBbGVydDogUmVhY3RpdmVBbGVydEJveE1ldGFkYXRhO1xuICBzdWNjZXNzQWxlcnQ6IFJlYWN0aXZlQWxlcnRCb3hNZXRhZGF0YTtcbiAgc3RhdGljQWxlcnQ6IFJlYWN0aXZlQWxlcnRCb3hNZXRhZGF0YTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIGNvbnRlbnRTZXJ2aWNlOiBDb250ZW50U2VydmljZSxcbiAgICBwcml2YXRlIGxhbmdTZXJ2aWNlOiBMYW5nU2VydmljZVxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5pbml0aWFsaXplQ29udGVudCgpO1xuICAgIHRoaXMuaW5pdGlhbGl6ZUNvbXBvbmVudHMoKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy51bnN1YnNjcmliZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBpbml0aWFsaXplQ29udGVudCgpIHtcbiAgICAvLyBQYWdlLWxldmVsIGNvbnRlbnRcbiAgICB0aGlzLnBhZ2VUaXRsZSQgPSB0aGlzLmNvbnRlbnRTZXJ2aWNlLmZyb21Db250ZW50KHtcbiAgICAgIGNsYXNzTmFtZTogJ3JlYWN0aXZlRGVtbycsXG4gICAgICBrZXk6ICd0aXRsZScsXG4gICAgICBmYWxsYmFjazogJ1JlYWN0aXZlIENvbXBvbmVudHMgRGVtbycsXG4gICAgfSk7XG5cbiAgICB0aGlzLmxhbmd1YWdlTGFiZWwkID0gdGhpcy5jb250ZW50U2VydmljZS5mcm9tQ29udGVudCh7XG4gICAgICBjbGFzc05hbWU6ICdfZ2xvYmFsJyxcbiAgICAgIGtleTogJ2xhbmd1YWdlJyxcbiAgICAgIGZhbGxiYWNrOiAnTGFuZ3VhZ2UnLFxuICAgIH0pO1xuXG4gICAgdGhpcy5idXR0b25TZWN0aW9uVGl0bGUkID0gdGhpcy5jb250ZW50U2VydmljZS5mcm9tQ29udGVudCh7XG4gICAgICBjbGFzc05hbWU6ICdyZWFjdGl2ZURlbW8nLFxuICAgICAga2V5OiAnYnV0dG9ucy50aXRsZScsXG4gICAgICBmYWxsYmFjazogJ1JlYWN0aXZlIEJ1dHRvbnMnLFxuICAgIH0pO1xuXG4gICAgdGhpcy5hbGVydFNlY3Rpb25UaXRsZSQgPSB0aGlzLmNvbnRlbnRTZXJ2aWNlLmZyb21Db250ZW50KHtcbiAgICAgIGNsYXNzTmFtZTogJ3JlYWN0aXZlRGVtbycsXG4gICAgICBrZXk6ICdhbGVydHMudGl0bGUnLFxuICAgICAgZmFsbGJhY2s6ICdSZWFjdGl2ZSBBbGVydHMnLFxuICAgIH0pO1xuXG4gICAgLy8gTGFuZ3VhZ2Ugc3RhdGVcbiAgICB0aGlzLmN1cnJlbnRMYW5ndWFnZSQgPSB0aGlzLmxhbmdTZXJ2aWNlLmN1cnJlbnRMYW5nJDtcbiAgICB0aGlzLmF2YWlsYWJsZUxhbmd1YWdlcyQgPSB0aGlzLmxhbmdTZXJ2aWNlLmN1cnJlbnRMYW5nJC5waXBlKG1hcCgoKSA9PiB0aGlzLmxhbmdTZXJ2aWNlLmF2YWlsYWJsZUxhbmdzKSk7XG4gIH1cblxuICBwcml2YXRlIGluaXRpYWxpemVDb21wb25lbnRzKCkge1xuICAgIC8vIFJlYWN0aXZlIGJ1dHRvbnMgd2l0aCBjb21tb24gYWN0aW9uc1xuICAgIHRoaXMuc2F2ZUJ1dHRvbiA9IHtcbiAgICAgIGNvbG9yOiAncHJpbWFyeScsXG4gICAgICBmaWxsOiAnc29saWQnLFxuICAgICAgdHlwZTogJ2J1dHRvbicsXG4gICAgICBzdGF0ZTogQ29tcG9uZW50U3RhdGVzLkVOQUJMRUQsXG4gICAgICB0ZXh0Q29uZmlnOiB7XG4gICAgICAgIGNsYXNzTmFtZTogJ19nbG9iYWwnLFxuICAgICAgICBrZXk6ICdzYXZlJyxcbiAgICAgICAgZmFsbGJhY2s6ICdTYXZlJyxcbiAgICAgIH0sXG4gICAgICBoYW5kbGVyOiAoKSA9PiB0aGlzLmhhbmRsZVNhdmUoKSxcbiAgICB9O1xuXG4gICAgdGhpcy5jYW5jZWxCdXR0b24gPSB7XG4gICAgICBjb2xvcjogJ21lZGl1bScsXG4gICAgICBmaWxsOiAnb3V0bGluZScsXG4gICAgICB0eXBlOiAnYnV0dG9uJyxcbiAgICAgIHN0YXRlOiBDb21wb25lbnRTdGF0ZXMuRU5BQkxFRCxcbiAgICAgIHRleHRDb25maWc6IHtcbiAgICAgICAgY2xhc3NOYW1lOiAnX2dsb2JhbCcsXG4gICAgICAgIGtleTogJ2NhbmNlbCcsXG4gICAgICAgIGZhbGxiYWNrOiAnQ2FuY2VsJyxcbiAgICAgIH0sXG4gICAgICBoYW5kbGVyOiAoKSA9PiB0aGlzLmhhbmRsZUNhbmNlbCgpLFxuICAgIH07XG5cbiAgICAvLyBTdGF0aWMgYnV0dG9uIGZvciBjb21wYXJpc29uXG4gICAgdGhpcy5zdGF0aWNCdXR0b24gPSB7XG4gICAgICBjb2xvcjogJ3RlcnRpYXJ5JyxcbiAgICAgIGZpbGw6ICdvdXRsaW5lJyxcbiAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgc3RhdGU6IENvbXBvbmVudFN0YXRlcy5FTkFCTEVELFxuICAgICAgdGV4dDogJ1N0YXRpYyBCdXR0b24nLCAvLyBTdGF0aWMgdGV4dFxuICAgICAgaGFuZGxlcjogKCkgPT4gdGhpcy5oYW5kbGVTdGF0aWMoKSxcbiAgICB9O1xuXG4gICAgLy8gUmVhY3RpdmUgYWxlcnQgYm94ZXNcbiAgICB0aGlzLndhcm5pbmdBbGVydCA9IHtcbiAgICAgIGJveDoge1xuICAgICAgICBjb2xvcjogJ3dhcm5pbmcnLFxuICAgICAgICByb3VuZGVkOiB0cnVlLFxuICAgICAgICBib3JkZXJlZDogZmFsc2UsXG4gICAgICAgIGljb246ICd3YXJuaW5nJyxcbiAgICAgIH0sXG4gICAgICBpY29uOiB7XG4gICAgICAgIG5hbWU6ICd3YXJuaW5nJyxcbiAgICAgICAgY29sb3I6ICd3YXJuaW5nJyxcbiAgICAgICAgc2l6ZTogJ21lZGl1bScsXG4gICAgICB9LFxuICAgICAgdGV4dENvbmZpZzoge1xuICAgICAgICBjbGFzc05hbWU6ICdyZWFjdGl2ZURlbW8nLFxuICAgICAgICBrZXk6ICdhbGVydHMud2FybmluZycsXG4gICAgICAgIGZhbGxiYWNrOiAnVGhpcyBpcyBhIHdhcm5pbmcgbWVzc2FnZScsXG4gICAgICB9LFxuICAgICAgdGV4dFN0eWxlOiB7XG4gICAgICAgIHNpemU6ICdtZWRpdW0nLFxuICAgICAgICBib2xkOiBmYWxzZSxcbiAgICAgIH0sXG4gICAgfTtcblxuICAgIHRoaXMuc3VjY2Vzc0FsZXJ0ID0ge1xuICAgICAgYm94OiB7XG4gICAgICAgIGNvbG9yOiAnc3VjY2VzcycsXG4gICAgICAgIHJvdW5kZWQ6IHRydWUsXG4gICAgICAgIGJvcmRlcmVkOiBmYWxzZSxcbiAgICAgICAgaWNvbjogJ2NoZWNrbWFyay1jaXJjbGUnLFxuICAgICAgfSxcbiAgICAgIGljb246IHtcbiAgICAgICAgbmFtZTogJ2NoZWNrbWFyay1jaXJjbGUnLFxuICAgICAgICBjb2xvcjogJ3N1Y2Nlc3MnLFxuICAgICAgICBzaXplOiAnbWVkaXVtJyxcbiAgICAgIH0sXG4gICAgICB0ZXh0Q29uZmlnOiB7XG4gICAgICAgIGNsYXNzTmFtZTogJ3JlYWN0aXZlRGVtbycsXG4gICAgICAgIGtleTogJ2FsZXJ0cy5zdWNjZXNzJyxcbiAgICAgICAgZmFsbGJhY2s6ICdPcGVyYXRpb24gY29tcGxldGVkIHN1Y2Nlc3NmdWxseSEnLFxuICAgICAgfSxcbiAgICAgIHRleHRTdHlsZToge1xuICAgICAgICBzaXplOiAnbWVkaXVtJyxcbiAgICAgICAgYm9sZDogdHJ1ZSxcbiAgICAgIH0sXG4gICAgfTtcblxuICAgIC8vIFN0YXRpYyBhbGVydCBmb3IgY29tcGFyaXNvblxuICAgIHRoaXMuc3RhdGljQWxlcnQgPSB7XG4gICAgICBib3g6IHtcbiAgICAgICAgY29sb3I6ICdkYXJrJyxcbiAgICAgICAgcm91bmRlZDogdHJ1ZSxcbiAgICAgICAgYm9yZGVyZWQ6IGZhbHNlLFxuICAgICAgICBpY29uOiAnaW5mb3JtYXRpb24tY2lyY2xlJyxcbiAgICAgIH0sXG4gICAgICBpY29uOiB7XG4gICAgICAgIG5hbWU6ICdpbmZvcm1hdGlvbi1jaXJjbGUnLFxuICAgICAgICBjb2xvcjogJ2RhcmsnLFxuICAgICAgICBzaXplOiAnbWVkaXVtJyxcbiAgICAgIH0sXG4gICAgICB0ZXh0OiAnVGhpcyBpcyBhIHN0YXRpYyBhbGVydCBtZXNzYWdlJywgLy8gU3RhdGljIHRleHRcbiAgICAgIHRleHRTdHlsZToge1xuICAgICAgICBzaXplOiAnbWVkaXVtJyxcbiAgICAgICAgYm9sZDogZmFsc2UsXG4gICAgICB9LFxuICAgIH07XG4gIH1cblxuICAvLyBFdmVudCBoYW5kbGVyc1xuICBjaGFuZ2VMYW5ndWFnZShsYW5ndWFnZTogc3RyaW5nKSB7XG4gICAgdGhpcy5sYW5nU2VydmljZS5zZXRMYW5nKGxhbmd1YWdlKTtcbiAgfVxuXG4gIHByaXZhdGUgaGFuZGxlU2F2ZSgpIHtcbiAgICBjb25zb2xlLmxvZygnU2F2ZSBidXR0b24gY2xpY2tlZCcpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYW5kbGVDYW5jZWwoKSB7XG4gICAgY29uc29sZS5sb2coJ0NhbmNlbCBidXR0b24gY2xpY2tlZCcpO1xuICB9XG5cbiAgcHJpdmF0ZSBoYW5kbGVTdGF0aWMoKSB7XG4gICAgY29uc29sZS5sb2coJ1N0YXRpYyBidXR0b24gY2xpY2tlZCcpO1xuICB9XG59XG4iXX0=
@@ -1,200 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, inject } from '@angular/core';
3
- import { ContentService } from '../services/content.service';
4
- import { LangService } from '../services/lang-provider/lang-provider.service';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common";
7
- /**
8
- * Test component to diagnose reactive content behavior.
9
- * Compares fromContent vs fromMultipleContent reactivity.
10
- */
11
- export class ReactivityTestComponent {
12
- constructor() {
13
- this.contentService = inject(ContentService);
14
- this.langService = inject(LangService);
15
- // Observable for current language
16
- this.currentLang$ = this.langService.currentLang$;
17
- // Single key content observables (using fromContent)
18
- this.singleWelcome$ = this.contentService.fromContent({
19
- className: 'testReactivity',
20
- key: 'welcomeMessage',
21
- fallback: 'Welcome',
22
- });
23
- this.singleSave$ = this.contentService.fromContent({
24
- className: 'testReactivity',
25
- key: 'saveButton',
26
- fallback: 'Save',
27
- });
28
- this.singleCancel$ = this.contentService.fromContent({
29
- className: 'testReactivity',
30
- key: 'cancelButton',
31
- fallback: 'Cancel',
32
- });
33
- // Multiple keys content observable (using fromMultipleContent)
34
- this.multipleContent$ = this.contentService.fromMultipleContent('testReactivity', [
35
- 'welcomeMessage',
36
- 'saveButton',
37
- 'cancelButton',
38
- ]);
39
- // Direct LangService tests
40
- this.directSingle$ = this.langService.getContent('testReactivity', 'welcomeMessage', 'Welcome');
41
- this.directMultiple$ = this.langService.getMultipleContent('testReactivity', ['welcomeMessage']);
42
- // Update counters
43
- this.singleUpdateCount = 0;
44
- this.multipleUpdateCount = 0;
45
- this.directSingleUpdateCount = 0;
46
- this.directMultipleUpdateCount = 0;
47
- }
48
- ngOnInit() {
49
- // Subscribe to observables to count updates
50
- this.singleWelcome$.subscribe(() => {
51
- this.singleUpdateCount++;
52
- console.log('Single key updated:', this.singleUpdateCount);
53
- });
54
- this.multipleContent$.subscribe(() => {
55
- this.multipleUpdateCount++;
56
- console.log('Multiple keys updated:', this.multipleUpdateCount);
57
- });
58
- this.directSingle$.subscribe(() => {
59
- this.directSingleUpdateCount++;
60
- console.log('Direct single updated:', this.directSingleUpdateCount);
61
- });
62
- this.directMultiple$.subscribe(() => {
63
- this.directMultipleUpdateCount++;
64
- console.log('Direct multiple updated:', this.directMultipleUpdateCount);
65
- });
66
- }
67
- switchToSpanish() {
68
- this.langService.setLang('es');
69
- }
70
- switchToEnglish() {
71
- this.langService.setLang('en');
72
- }
73
- switchToFrench() {
74
- this.langService.setLang('fr');
75
- }
76
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactivityTestComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
77
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ReactivityTestComponent, isStandalone: true, selector: "val-reactivity-test", ngImport: i0, template: `
78
- <div style="padding: 20px; border: 1px solid #ccc; margin: 10px;">
79
- <h3>Reactivity Test Component</h3>
80
-
81
- <!-- Current Language -->
82
- <div style="margin-bottom: 20px;"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>
83
-
84
- <!-- Language Switch Buttons -->
85
- <div style="margin-bottom: 20px;">
86
- <button (click)="switchToSpanish()" style="margin-right: 10px;">Switch to ES</button>
87
- <button (click)="switchToEnglish()" style="margin-right: 10px;">Switch to EN</button>
88
- <button (click)="switchToFrench()">Switch to FR</button>
89
- </div>
90
-
91
- <!-- Single Key Tests -->
92
- <div style="margin-bottom: 20px;">
93
- <h4>Single Key Tests (fromContent)</h4>
94
- <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>
95
- <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>
96
- <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>
97
- </div>
98
-
99
- <!-- Multiple Keys Test -->
100
- <div style="margin-bottom: 20px;">
101
- <h4>Multiple Keys Test (fromMultipleContent)</h4>
102
- <div>
103
- <strong>welcomeMessage (multiple):</strong>
104
- {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}
105
- </div>
106
- <div>
107
- <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}
108
- </div>
109
- <div>
110
- <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}
111
- </div>
112
- </div>
113
-
114
- <!-- Direct LangService Tests -->
115
- <div style="margin-bottom: 20px;">
116
- <h4>Direct LangService Tests</h4>
117
- <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>
118
- <div>
119
- <strong>welcomeMessage (direct multiple):</strong>
120
- {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}
121
- </div>
122
- </div>
123
-
124
- <!-- Update Counter -->
125
- <div>
126
- <h4>Update Counters</h4>
127
- <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>
128
- <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>
129
- <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>
130
- <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>
131
- </div>
132
- </div>
133
- `, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] }); }
134
- }
135
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ReactivityTestComponent, decorators: [{
136
- type: Component,
137
- args: [{
138
- selector: 'val-reactivity-test',
139
- standalone: true,
140
- imports: [CommonModule],
141
- template: `
142
- <div style="padding: 20px; border: 1px solid #ccc; margin: 10px;">
143
- <h3>Reactivity Test Component</h3>
144
-
145
- <!-- Current Language -->
146
- <div style="margin-bottom: 20px;"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>
147
-
148
- <!-- Language Switch Buttons -->
149
- <div style="margin-bottom: 20px;">
150
- <button (click)="switchToSpanish()" style="margin-right: 10px;">Switch to ES</button>
151
- <button (click)="switchToEnglish()" style="margin-right: 10px;">Switch to EN</button>
152
- <button (click)="switchToFrench()">Switch to FR</button>
153
- </div>
154
-
155
- <!-- Single Key Tests -->
156
- <div style="margin-bottom: 20px;">
157
- <h4>Single Key Tests (fromContent)</h4>
158
- <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>
159
- <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>
160
- <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>
161
- </div>
162
-
163
- <!-- Multiple Keys Test -->
164
- <div style="margin-bottom: 20px;">
165
- <h4>Multiple Keys Test (fromMultipleContent)</h4>
166
- <div>
167
- <strong>welcomeMessage (multiple):</strong>
168
- {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}
169
- </div>
170
- <div>
171
- <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}
172
- </div>
173
- <div>
174
- <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}
175
- </div>
176
- </div>
177
-
178
- <!-- Direct LangService Tests -->
179
- <div style="margin-bottom: 20px;">
180
- <h4>Direct LangService Tests</h4>
181
- <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>
182
- <div>
183
- <strong>welcomeMessage (direct multiple):</strong>
184
- {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}
185
- </div>
186
- </div>
187
-
188
- <!-- Update Counter -->
189
- <div>
190
- <h4>Update Counters</h4>
191
- <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>
192
- <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>
193
- <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>
194
- <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>
195
- </div>
196
- </div>
197
- `,
198
- }]
199
- }] });
200
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhY3Rpdml0eS10ZXN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3ZhbHRlY2gtY29tcG9uZW50cy9zcmMvbGliL2V4YW1wbGVzL3JlYWN0aXZpdHktdGVzdC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTFELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUM3RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saURBQWlELENBQUM7OztBQUU5RTs7O0dBR0c7QUErREgsTUFBTSxPQUFPLHVCQUF1QjtJQTlEcEM7UUErRFUsbUJBQWMsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDeEMsZ0JBQVcsR0FBRyxNQUFNLENBQUMsV0FBVyxDQUFDLENBQUM7UUFFMUMsa0NBQWtDO1FBQ2xDLGlCQUFZLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFZLENBQUM7UUFFN0MscURBQXFEO1FBQ3JELG1CQUFjLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUM7WUFDL0MsU0FBUyxFQUFFLGdCQUFnQjtZQUMzQixHQUFHLEVBQUUsZ0JBQWdCO1lBQ3JCLFFBQVEsRUFBRSxTQUFTO1NBQ3BCLENBQUMsQ0FBQztRQUVILGdCQUFXLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUM7WUFDNUMsU0FBUyxFQUFFLGdCQUFnQjtZQUMzQixHQUFHLEVBQUUsWUFBWTtZQUNqQixRQUFRLEVBQUUsTUFBTTtTQUNqQixDQUFDLENBQUM7UUFFSCxrQkFBYSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsV0FBVyxDQUFDO1lBQzlDLFNBQVMsRUFBRSxnQkFBZ0I7WUFDM0IsR0FBRyxFQUFFLGNBQWM7WUFDbkIsUUFBUSxFQUFFLFFBQVE7U0FDbkIsQ0FBQyxDQUFDO1FBRUgsK0RBQStEO1FBQy9ELHFCQUFnQixHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQUMsZ0JBQWdCLEVBQUU7WUFDM0UsZ0JBQWdCO1lBQ2hCLFlBQVk7WUFDWixjQUFjO1NBQ2YsQ0FBQyxDQUFDO1FBRUgsMkJBQTJCO1FBQzNCLGtCQUFhLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDM0Ysb0JBQWUsR0FBRyxJQUFJLENBQUMsV0FBVyxDQUFDLGtCQUFrQixDQUFDLGdCQUFnQixFQUFFLENBQUMsZ0JBQWdCLENBQUMsQ0FBQyxDQUFDO1FBRTVGLGtCQUFrQjtRQUNsQixzQkFBaUIsR0FBRyxDQUFDLENBQUM7UUFDdEIsd0JBQW1CLEdBQUcsQ0FBQyxDQUFDO1FBQ3hCLDRCQUF1QixHQUFHLENBQUMsQ0FBQztRQUM1Qiw4QkFBeUIsR0FBRyxDQUFDLENBQUM7S0FvQy9CO0lBbENDLFFBQVE7UUFDTiw0Q0FBNEM7UUFDNUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2pDLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ3pCLE9BQU8sQ0FBQyxHQUFHLENBQUMscUJBQXFCLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDN0QsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNuQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsQ0FBQztZQUMzQixPQUFPLENBQUMsR0FBRyxDQUFDLHdCQUF3QixFQUFFLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBQ2xFLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2hDLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO1lBQy9CLE9BQU8sQ0FBQyxHQUFHLENBQUMsd0JBQXdCLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDdEUsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsZUFBZSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDbEMsSUFBSSxDQUFDLHlCQUF5QixFQUFFLENBQUM7WUFDakMsT0FBTyxDQUFDLEdBQUcsQ0FBQywwQkFBMEIsRUFBRSxJQUFJLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUMxRSxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNqQyxDQUFDO0lBRUQsY0FBYztRQUNaLElBQUksQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2pDLENBQUM7K0dBNUVVLHVCQUF1QjttR0FBdkIsdUJBQXVCLCtFQTFEeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0RULDJEQXpEUyxZQUFZOzs0RkEyRFgsdUJBQXVCO2tCQTlEbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBd0RUO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQ29udGVudFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9jb250ZW50LnNlcnZpY2UnO1xuaW1wb3J0IHsgTGFuZ1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9sYW5nLXByb3ZpZGVyL2xhbmctcHJvdmlkZXIuc2VydmljZSc7XG5cbi8qKlxuICogVGVzdCBjb21wb25lbnQgdG8gZGlhZ25vc2UgcmVhY3RpdmUgY29udGVudCBiZWhhdmlvci5cbiAqIENvbXBhcmVzIGZyb21Db250ZW50IHZzIGZyb21NdWx0aXBsZUNvbnRlbnQgcmVhY3Rpdml0eS5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmFsLXJlYWN0aXZpdHktdGVzdCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgc3R5bGU9XCJwYWRkaW5nOiAyMHB4OyBib3JkZXI6IDFweCBzb2xpZCAjY2NjOyBtYXJnaW46IDEwcHg7XCI+XG4gICAgICA8aDM+UmVhY3Rpdml0eSBUZXN0IENvbXBvbmVudDwvaDM+XG5cbiAgICAgIDwhLS0gQ3VycmVudCBMYW5ndWFnZSAtLT5cbiAgICAgIDxkaXYgc3R5bGU9XCJtYXJnaW4tYm90dG9tOiAyMHB4O1wiPjxzdHJvbmc+Q3VycmVudCBMYW5ndWFnZTo8L3N0cm9uZz4ge3sgY3VycmVudExhbmckIHwgYXN5bmMgfX08L2Rpdj5cblxuICAgICAgPCEtLSBMYW5ndWFnZSBTd2l0Y2ggQnV0dG9ucyAtLT5cbiAgICAgIDxkaXYgc3R5bGU9XCJtYXJnaW4tYm90dG9tOiAyMHB4O1wiPlxuICAgICAgICA8YnV0dG9uIChjbGljayk9XCJzd2l0Y2hUb1NwYW5pc2goKVwiIHN0eWxlPVwibWFyZ2luLXJpZ2h0OiAxMHB4O1wiPlN3aXRjaCB0byBFUzwvYnV0dG9uPlxuICAgICAgICA8YnV0dG9uIChjbGljayk9XCJzd2l0Y2hUb0VuZ2xpc2goKVwiIHN0eWxlPVwibWFyZ2luLXJpZ2h0OiAxMHB4O1wiPlN3aXRjaCB0byBFTjwvYnV0dG9uPlxuICAgICAgICA8YnV0dG9uIChjbGljayk9XCJzd2l0Y2hUb0ZyZW5jaCgpXCI+U3dpdGNoIHRvIEZSPC9idXR0b24+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPCEtLSBTaW5nbGUgS2V5IFRlc3RzIC0tPlxuICAgICAgPGRpdiBzdHlsZT1cIm1hcmdpbi1ib3R0b206IDIwcHg7XCI+XG4gICAgICAgIDxoND5TaW5nbGUgS2V5IFRlc3RzIChmcm9tQ29udGVudCk8L2g0PlxuICAgICAgICA8ZGl2PjxzdHJvbmc+d2VsY29tZU1lc3NhZ2UgKGZyb21Db250ZW50KTo8L3N0cm9uZz4ge3sgc2luZ2xlV2VsY29tZSQgfCBhc3luYyB9fTwvZGl2PlxuICAgICAgICA8ZGl2PjxzdHJvbmc+c2F2ZUJ1dHRvbiAoZnJvbUNvbnRlbnQpOjwvc3Ryb25nPiB7eyBzaW5nbGVTYXZlJCB8IGFzeW5jIH19PC9kaXY+XG4gICAgICAgIDxkaXY+PHN0cm9uZz5jYW5jZWxCdXR0b24gKGZyb21Db250ZW50KTo8L3N0cm9uZz4ge3sgc2luZ2xlQ2FuY2VsJCB8IGFzeW5jIH19PC9kaXY+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPCEtLSBNdWx0aXBsZSBLZXlzIFRlc3QgLS0+XG4gICAgICA8ZGl2IHN0eWxlPVwibWFyZ2luLWJvdHRvbTogMjBweDtcIj5cbiAgICAgICAgPGg0Pk11bHRpcGxlIEtleXMgVGVzdCAoZnJvbU11bHRpcGxlQ29udGVudCk8L2g0PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxzdHJvbmc+d2VsY29tZU1lc3NhZ2UgKG11bHRpcGxlKTo8L3N0cm9uZz5cbiAgICAgICAgICB7eyAobXVsdGlwbGVDb250ZW50JCB8IGFzeW5jKT8uWyd3ZWxjb21lTWVzc2FnZSddIHx8ICdMb2FkaW5nLi4uJyB9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8c3Ryb25nPnNhdmVCdXR0b24gKG11bHRpcGxlKTo8L3N0cm9uZz4ge3sgKG11bHRpcGxlQ29udGVudCQgfCBhc3luYyk/Llsnc2F2ZUJ1dHRvbiddIHx8ICdMb2FkaW5nLi4uJyB9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8c3Ryb25nPmNhbmNlbEJ1dHRvbiAobXVsdGlwbGUpOjwvc3Ryb25nPiB7eyAobXVsdGlwbGVDb250ZW50JCB8IGFzeW5jKT8uWydjYW5jZWxCdXR0b24nXSB8fCAnTG9hZGluZy4uLicgfX1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPCEtLSBEaXJlY3QgTGFuZ1NlcnZpY2UgVGVzdHMgLS0+XG4gICAgICA8ZGl2IHN0eWxlPVwibWFyZ2luLWJvdHRvbTogMjBweDtcIj5cbiAgICAgICAgPGg0PkRpcmVjdCBMYW5nU2VydmljZSBUZXN0czwvaDQ+XG4gICAgICAgIDxkaXY+PHN0cm9uZz53ZWxjb21lTWVzc2FnZSAoZGlyZWN0IHNpbmdsZSk6PC9zdHJvbmc+IHt7IGRpcmVjdFNpbmdsZSQgfCBhc3luYyB9fTwvZGl2PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxzdHJvbmc+d2VsY29tZU1lc3NhZ2UgKGRpcmVjdCBtdWx0aXBsZSk6PC9zdHJvbmc+XG4gICAgICAgICAge3sgKGRpcmVjdE11bHRpcGxlJCB8IGFzeW5jKT8uWyd3ZWxjb21lTWVzc2FnZSddIHx8ICdMb2FkaW5nLi4uJyB9fVxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuXG4gICAgICA8IS0tIFVwZGF0ZSBDb3VudGVyIC0tPlxuICAgICAgPGRpdj5cbiAgICAgICAgPGg0PlVwZGF0ZSBDb3VudGVyczwvaDQ+XG4gICAgICAgIDxkaXY+PHN0cm9uZz5TaW5nbGUga2V5IHVwZGF0ZXM6PC9zdHJvbmc+IHt7IHNpbmdsZVVwZGF0ZUNvdW50IH19PC9kaXY+XG4gICAgICAgIDxkaXY+PHN0cm9uZz5NdWx0aXBsZSBrZXlzIHVwZGF0ZXM6PC9zdHJvbmc+IHt7IG11bHRpcGxlVXBkYXRlQ291bnQgfX08L2Rpdj5cbiAgICAgICAgPGRpdj48c3Ryb25nPkRpcmVjdCBzaW5nbGUgdXBkYXRlczo8L3N0cm9uZz4ge3sgZGlyZWN0U2luZ2xlVXBkYXRlQ291bnQgfX08L2Rpdj5cbiAgICAgICAgPGRpdj48c3Ryb25nPkRpcmVjdCBtdWx0aXBsZSB1cGRhdGVzOjwvc3Ryb25nPiB7eyBkaXJlY3RNdWx0aXBsZVVwZGF0ZUNvdW50IH19PC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgYCxcbn0pXG5leHBvcnQgY2xhc3MgUmVhY3Rpdml0eVRlc3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwcml2YXRlIGNvbnRlbnRTZXJ2aWNlID0gaW5qZWN0KENvbnRlbnRTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBsYW5nU2VydmljZSA9IGluamVjdChMYW5nU2VydmljZSk7XG5cbiAgLy8gT2JzZXJ2YWJsZSBmb3IgY3VycmVudCBsYW5ndWFnZVxuICBjdXJyZW50TGFuZyQgPSB0aGlzLmxhbmdTZXJ2aWNlLmN1cnJlbnRMYW5nJDtcblxuICAvLyBTaW5nbGUga2V5IGNvbnRlbnQgb2JzZXJ2YWJsZXMgKHVzaW5nIGZyb21Db250ZW50KVxuICBzaW5nbGVXZWxjb21lJCA9IHRoaXMuY29udGVudFNlcnZpY2UuZnJvbUNvbnRlbnQoe1xuICAgIGNsYXNzTmFtZTogJ3Rlc3RSZWFjdGl2aXR5JyxcbiAgICBrZXk6ICd3ZWxjb21lTWVzc2FnZScsXG4gICAgZmFsbGJhY2s6ICdXZWxjb21lJyxcbiAgfSk7XG5cbiAgc2luZ2xlU2F2ZSQgPSB0aGlzLmNvbnRlbnRTZXJ2aWNlLmZyb21Db250ZW50KHtcbiAgICBjbGFzc05hbWU6ICd0ZXN0UmVhY3Rpdml0eScsXG4gICAga2V5OiAnc2F2ZUJ1dHRvbicsXG4gICAgZmFsbGJhY2s6ICdTYXZlJyxcbiAgfSk7XG5cbiAgc2luZ2xlQ2FuY2VsJCA9IHRoaXMuY29udGVudFNlcnZpY2UuZnJvbUNvbnRlbnQoe1xuICAgIGNsYXNzTmFtZTogJ3Rlc3RSZWFjdGl2aXR5JyxcbiAgICBrZXk6ICdjYW5jZWxCdXR0b24nLFxuICAgIGZhbGxiYWNrOiAnQ2FuY2VsJyxcbiAgfSk7XG5cbiAgLy8gTXVsdGlwbGUga2V5cyBjb250ZW50IG9ic2VydmFibGUgKHVzaW5nIGZyb21NdWx0aXBsZUNvbnRlbnQpXG4gIG11bHRpcGxlQ29udGVudCQgPSB0aGlzLmNvbnRlbnRTZXJ2aWNlLmZyb21NdWx0aXBsZUNvbnRlbnQoJ3Rlc3RSZWFjdGl2aXR5JywgW1xuICAgICd3ZWxjb21lTWVzc2FnZScsXG4gICAgJ3NhdmVCdXR0b24nLFxuICAgICdjYW5jZWxCdXR0b24nLFxuICBdKTtcblxuICAvLyBEaXJlY3QgTGFuZ1NlcnZpY2UgdGVzdHNcbiAgZGlyZWN0U2luZ2xlJCA9IHRoaXMubGFuZ1NlcnZpY2UuZ2V0Q29udGVudCgndGVzdFJlYWN0aXZpdHknLCAnd2VsY29tZU1lc3NhZ2UnLCAnV2VsY29tZScpO1xuICBkaXJlY3RNdWx0aXBsZSQgPSB0aGlzLmxhbmdTZXJ2aWNlLmdldE11bHRpcGxlQ29udGVudCgndGVzdFJlYWN0aXZpdHknLCBbJ3dlbGNvbWVNZXNzYWdlJ10pO1xuXG4gIC8vIFVwZGF0ZSBjb3VudGVyc1xuICBzaW5nbGVVcGRhdGVDb3VudCA9IDA7XG4gIG11bHRpcGxlVXBkYXRlQ291bnQgPSAwO1xuICBkaXJlY3RTaW5nbGVVcGRhdGVDb3VudCA9IDA7XG4gIGRpcmVjdE11bHRpcGxlVXBkYXRlQ291bnQgPSAwO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIC8vIFN1YnNjcmliZSB0byBvYnNlcnZhYmxlcyB0byBjb3VudCB1cGRhdGVzXG4gICAgdGhpcy5zaW5nbGVXZWxjb21lJC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5zaW5nbGVVcGRhdGVDb3VudCsrO1xuICAgICAgY29uc29sZS5sb2coJ1NpbmdsZSBrZXkgdXBkYXRlZDonLCB0aGlzLnNpbmdsZVVwZGF0ZUNvdW50KTtcbiAgICB9KTtcblxuICAgIHRoaXMubXVsdGlwbGVDb250ZW50JC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5tdWx0aXBsZVVwZGF0ZUNvdW50Kys7XG4gICAgICBjb25zb2xlLmxvZygnTXVsdGlwbGUga2V5cyB1cGRhdGVkOicsIHRoaXMubXVsdGlwbGVVcGRhdGVDb3VudCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLmRpcmVjdFNpbmdsZSQuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIHRoaXMuZGlyZWN0U2luZ2xlVXBkYXRlQ291bnQrKztcbiAgICAgIGNvbnNvbGUubG9nKCdEaXJlY3Qgc2luZ2xlIHVwZGF0ZWQ6JywgdGhpcy5kaXJlY3RTaW5nbGVVcGRhdGVDb3VudCk7XG4gICAgfSk7XG5cbiAgICB0aGlzLmRpcmVjdE11bHRpcGxlJC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgdGhpcy5kaXJlY3RNdWx0aXBsZVVwZGF0ZUNvdW50Kys7XG4gICAgICBjb25zb2xlLmxvZygnRGlyZWN0IG11bHRpcGxlIHVwZGF0ZWQ6JywgdGhpcy5kaXJlY3RNdWx0aXBsZVVwZGF0ZUNvdW50KTtcbiAgICB9KTtcbiAgfVxuXG4gIHN3aXRjaFRvU3BhbmlzaCgpIHtcbiAgICB0aGlzLmxhbmdTZXJ2aWNlLnNldExhbmcoJ2VzJyk7XG4gIH1cblxuICBzd2l0Y2hUb0VuZ2xpc2goKSB7XG4gICAgdGhpcy5sYW5nU2VydmljZS5zZXRMYW5nKCdlbicpO1xuICB9XG5cbiAgc3dpdGNoVG9GcmVuY2goKSB7XG4gICAgdGhpcy5sYW5nU2VydmljZS5zZXRMYW5nKCdmcicpO1xuICB9XG59XG4iXX0=