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,{"version":3,"file":"reactive-components-demo.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/reactive-components-demo.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, OnDestroy, OnInit } from '@angular/core';\nimport {\n  IonCard,\n  IonCardContent,\n  IonCardHeader,\n  IonCardTitle,\n  IonItem,\n  IonLabel,\n  IonSelect,\n  IonSelectOption,\n} from '@ionic/angular/standalone';\nimport { Observable, Subscription, map } from 'rxjs';\nimport { ButtonComponent } from '../components/atoms/button/button.component';\nimport { AlertBoxComponent } from '../components/molecules/alert-box/alert-box.component';\nimport { ReactiveAlertBoxMetadata } from '../components/molecules/alert-box/types';\nimport { ButtonMetadata, ComponentStates } from '../components/types';\nimport { ContentService } from '../services/content.service';\nimport { LangService } from '../services/lang-provider/lang-provider.service';\n\n/**\n * Simple demo component showcasing reactive content patterns\n * for buttons and alert boxes.\n *\n * Demonstrates:\n * - Button components with reactive text\n * - Alert boxes with reactive content\n * - Language switching\n * - Static vs reactive content patterns\n */\n@Component({\n  selector: 'val-reactive-components-demo',\n  standalone: true,\n  imports: [\n    CommonModule,\n    IonCard,\n    IonCardContent,\n    IonCardHeader,\n    IonCardTitle,\n    IonSelect,\n    IonSelectOption,\n    IonItem,\n    IonLabel,\n    ButtonComponent,\n    AlertBoxComponent,\n  ],\n  template: `\n    <div class=\"reactive-components-demo\">\n      <ion-card>\n        <ion-card-header>\n          <ion-card-title>{{ pageTitle$ | async }}</ion-card-title>\n        </ion-card-header>\n\n        <ion-card-content>\n          <!-- Language Selector -->\n          <ion-item>\n            <ion-label>{{ languageLabel$ | async }}</ion-label>\n            <ion-select\n              interface=\"popover\"\n              [value]=\"currentLanguage$ | async\"\n              (ionChange)=\"changeLanguage($event.detail.value)\"\n            >\n              <ion-select-option *ngFor=\"let lang of availableLanguages$ | async\" [value]=\"lang\">\n                {{ lang | uppercase }}\n              </ion-select-option>\n            </ion-select>\n          </ion-item>\n\n          <!-- Reactive Buttons Demo -->\n          <div class=\"section\">\n            <h3>{{ buttonSectionTitle$ | async }}</h3>\n\n            <!-- Common action buttons with reactive text -->\n            <div class=\"button-grid\">\n              <val-button [props]=\"saveButton\"></val-button>\n              <val-button [props]=\"cancelButton\"></val-button>\n              <val-button [props]=\"staticButton\"></val-button>\n            </div>\n          </div>\n\n          <!-- Reactive Alert Boxes Demo -->\n          <div class=\"section\">\n            <h3>{{ alertSectionTitle$ | async }}</h3>\n\n            <!-- Alert with reactive content -->\n            <val-alert-box [props]=\"warningAlert\"></val-alert-box>\n            <val-alert-box [props]=\"successAlert\"></val-alert-box>\n            <val-alert-box [props]=\"staticAlert\"></val-alert-box>\n          </div>\n\n          <!-- Analysis -->\n          <div class=\"section\">\n            <h3>Analysis</h3>\n            <div class=\"analysis-info\">\n              <p><strong>Current Language:</strong> {{ currentLanguage$ | async | uppercase }}</p>\n              <p><strong>Available Languages:</strong> {{ (availableLanguages$ | async)?.join(', ') | uppercase }}</p>\n            </div>\n          </div>\n        </ion-card-content>\n      </ion-card>\n    </div>\n  `,\n  styles: [\n    `\n      .reactive-components-demo {\n        padding: 16px;\n      }\n      .section {\n        margin: 24px 0;\n      }\n      .button-grid {\n        display: flex;\n        gap: 12px;\n        flex-wrap: wrap;\n        margin: 16px 0;\n      }\n      .analysis-info {\n        background: var(--ion-color-light);\n        padding: 16px;\n        border-radius: 8px;\n      }\n    `,\n  ],\n})\nexport class ReactiveComponentsDemoComponent implements OnInit, OnDestroy {\n  private subscriptions = new Subscription();\n\n  // Observable content streams\n  pageTitle$: Observable<string>;\n  languageLabel$: Observable<string>;\n  buttonSectionTitle$: Observable<string>;\n  alertSectionTitle$: Observable<string>;\n\n  // Language state\n  currentLanguage$: Observable<string>;\n  availableLanguages$: Observable<string[]>;\n\n  // Component configurations\n  saveButton: ButtonMetadata;\n  cancelButton: ButtonMetadata;\n  staticButton: ButtonMetadata;\n\n  warningAlert: ReactiveAlertBoxMetadata;\n  successAlert: ReactiveAlertBoxMetadata;\n  staticAlert: ReactiveAlertBoxMetadata;\n\n  constructor(\n    private contentService: ContentService,\n    private langService: LangService\n  ) {}\n\n  ngOnInit() {\n    this.initializeContent();\n    this.initializeComponents();\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n\n  private initializeContent() {\n    // Page-level content\n    this.pageTitle$ = this.contentService.fromContent({\n      className: 'reactiveDemo',\n      key: 'title',\n      fallback: 'Reactive Components Demo',\n    });\n\n    this.languageLabel$ = this.contentService.fromContent({\n      className: '_global',\n      key: 'language',\n      fallback: 'Language',\n    });\n\n    this.buttonSectionTitle$ = this.contentService.fromContent({\n      className: 'reactiveDemo',\n      key: 'buttons.title',\n      fallback: 'Reactive Buttons',\n    });\n\n    this.alertSectionTitle$ = this.contentService.fromContent({\n      className: 'reactiveDemo',\n      key: 'alerts.title',\n      fallback: 'Reactive Alerts',\n    });\n\n    // Language state\n    this.currentLanguage$ = this.langService.currentLang$;\n    this.availableLanguages$ = this.langService.currentLang$.pipe(map(() => this.langService.availableLangs));\n  }\n\n  private initializeComponents() {\n    // Reactive buttons with common actions\n    this.saveButton = {\n      color: 'primary',\n      fill: 'solid',\n      type: 'button',\n      state: ComponentStates.ENABLED,\n      textConfig: {\n        className: '_global',\n        key: 'save',\n        fallback: 'Save',\n      },\n      handler: () => this.handleSave(),\n    };\n\n    this.cancelButton = {\n      color: 'medium',\n      fill: 'outline',\n      type: 'button',\n      state: ComponentStates.ENABLED,\n      textConfig: {\n        className: '_global',\n        key: 'cancel',\n        fallback: 'Cancel',\n      },\n      handler: () => this.handleCancel(),\n    };\n\n    // Static button for comparison\n    this.staticButton = {\n      color: 'tertiary',\n      fill: 'outline',\n      type: 'button',\n      state: ComponentStates.ENABLED,\n      text: 'Static Button', // Static text\n      handler: () => this.handleStatic(),\n    };\n\n    // Reactive alert boxes\n    this.warningAlert = {\n      box: {\n        color: 'warning',\n        rounded: true,\n        bordered: false,\n        icon: 'warning',\n      },\n      icon: {\n        name: 'warning',\n        color: 'warning',\n        size: 'medium',\n      },\n      textConfig: {\n        className: 'reactiveDemo',\n        key: 'alerts.warning',\n        fallback: 'This is a warning message',\n      },\n      textStyle: {\n        size: 'medium',\n        bold: false,\n      },\n    };\n\n    this.successAlert = {\n      box: {\n        color: 'success',\n        rounded: true,\n        bordered: false,\n        icon: 'checkmark-circle',\n      },\n      icon: {\n        name: 'checkmark-circle',\n        color: 'success',\n        size: 'medium',\n      },\n      textConfig: {\n        className: 'reactiveDemo',\n        key: 'alerts.success',\n        fallback: 'Operation completed successfully!',\n      },\n      textStyle: {\n        size: 'medium',\n        bold: true,\n      },\n    };\n\n    // Static alert for comparison\n    this.staticAlert = {\n      box: {\n        color: 'dark',\n        rounded: true,\n        bordered: false,\n        icon: 'information-circle',\n      },\n      icon: {\n        name: 'information-circle',\n        color: 'dark',\n        size: 'medium',\n      },\n      text: 'This is a static alert message', // Static text\n      textStyle: {\n        size: 'medium',\n        bold: false,\n      },\n    };\n  }\n\n  // Event handlers\n  changeLanguage(language: string) {\n    this.langService.setLang(language);\n  }\n\n  private handleSave() {\n    console.log('Save button clicked');\n  }\n\n  private handleCancel() {\n    console.log('Cancel button clicked');\n  }\n\n  private handleStatic() {\n    console.log('Static button clicked');\n  }\n}\n"]}
@@ -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,{"version":3,"file":"reactivity-test.component.js","sourceRoot":"","sources":["../../../../../projects/valtech-components/src/lib/examples/reactivity-test.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, OnInit, inject } from '@angular/core';\n\nimport { ContentService } from '../services/content.service';\nimport { LangService } from '../services/lang-provider/lang-provider.service';\n\n/**\n * Test component to diagnose reactive content behavior.\n * Compares fromContent vs fromMultipleContent reactivity.\n */\n@Component({\n  selector: 'val-reactivity-test',\n  standalone: true,\n  imports: [CommonModule],\n  template: `\n    <div style=\"padding: 20px; border: 1px solid #ccc; margin: 10px;\">\n      <h3>Reactivity Test Component</h3>\n\n      <!-- Current Language -->\n      <div style=\"margin-bottom: 20px;\"><strong>Current Language:</strong> {{ currentLang$ | async }}</div>\n\n      <!-- Language Switch Buttons -->\n      <div style=\"margin-bottom: 20px;\">\n        <button (click)=\"switchToSpanish()\" style=\"margin-right: 10px;\">Switch to ES</button>\n        <button (click)=\"switchToEnglish()\" style=\"margin-right: 10px;\">Switch to EN</button>\n        <button (click)=\"switchToFrench()\">Switch to FR</button>\n      </div>\n\n      <!-- Single Key Tests -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Single Key Tests (fromContent)</h4>\n        <div><strong>welcomeMessage (fromContent):</strong> {{ singleWelcome$ | async }}</div>\n        <div><strong>saveButton (fromContent):</strong> {{ singleSave$ | async }}</div>\n        <div><strong>cancelButton (fromContent):</strong> {{ singleCancel$ | async }}</div>\n      </div>\n\n      <!-- Multiple Keys Test -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Multiple Keys Test (fromMultipleContent)</h4>\n        <div>\n          <strong>welcomeMessage (multiple):</strong>\n          {{ (multipleContent$ | async)?.['welcomeMessage'] || 'Loading...' }}\n        </div>\n        <div>\n          <strong>saveButton (multiple):</strong> {{ (multipleContent$ | async)?.['saveButton'] || 'Loading...' }}\n        </div>\n        <div>\n          <strong>cancelButton (multiple):</strong> {{ (multipleContent$ | async)?.['cancelButton'] || 'Loading...' }}\n        </div>\n      </div>\n\n      <!-- Direct LangService Tests -->\n      <div style=\"margin-bottom: 20px;\">\n        <h4>Direct LangService Tests</h4>\n        <div><strong>welcomeMessage (direct single):</strong> {{ directSingle$ | async }}</div>\n        <div>\n          <strong>welcomeMessage (direct multiple):</strong>\n          {{ (directMultiple$ | async)?.['welcomeMessage'] || 'Loading...' }}\n        </div>\n      </div>\n\n      <!-- Update Counter -->\n      <div>\n        <h4>Update Counters</h4>\n        <div><strong>Single key updates:</strong> {{ singleUpdateCount }}</div>\n        <div><strong>Multiple keys updates:</strong> {{ multipleUpdateCount }}</div>\n        <div><strong>Direct single updates:</strong> {{ directSingleUpdateCount }}</div>\n        <div><strong>Direct multiple updates:</strong> {{ directMultipleUpdateCount }}</div>\n      </div>\n    </div>\n  `,\n})\nexport class ReactivityTestComponent implements OnInit {\n  private contentService = inject(ContentService);\n  private langService = inject(LangService);\n\n  // Observable for current language\n  currentLang$ = this.langService.currentLang$;\n\n  // Single key content observables (using fromContent)\n  singleWelcome$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'welcomeMessage',\n    fallback: 'Welcome',\n  });\n\n  singleSave$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'saveButton',\n    fallback: 'Save',\n  });\n\n  singleCancel$ = this.contentService.fromContent({\n    className: 'testReactivity',\n    key: 'cancelButton',\n    fallback: 'Cancel',\n  });\n\n  // Multiple keys content observable (using fromMultipleContent)\n  multipleContent$ = this.contentService.fromMultipleContent('testReactivity', [\n    'welcomeMessage',\n    'saveButton',\n    'cancelButton',\n  ]);\n\n  // Direct LangService tests\n  directSingle$ = this.langService.getContent('testReactivity', 'welcomeMessage', 'Welcome');\n  directMultiple$ = this.langService.getMultipleContent('testReactivity', ['welcomeMessage']);\n\n  // Update counters\n  singleUpdateCount = 0;\n  multipleUpdateCount = 0;\n  directSingleUpdateCount = 0;\n  directMultipleUpdateCount = 0;\n\n  ngOnInit() {\n    // Subscribe to observables to count updates\n    this.singleWelcome$.subscribe(() => {\n      this.singleUpdateCount++;\n      console.log('Single key updated:', this.singleUpdateCount);\n    });\n\n    this.multipleContent$.subscribe(() => {\n      this.multipleUpdateCount++;\n      console.log('Multiple keys updated:', this.multipleUpdateCount);\n    });\n\n    this.directSingle$.subscribe(() => {\n      this.directSingleUpdateCount++;\n      console.log('Direct single updated:', this.directSingleUpdateCount);\n    });\n\n    this.directMultiple$.subscribe(() => {\n      this.directMultipleUpdateCount++;\n      console.log('Direct multiple updated:', this.directMultipleUpdateCount);\n    });\n  }\n\n  switchToSpanish() {\n    this.langService.setLang('es');\n  }\n\n  switchToEnglish() {\n    this.langService.setLang('en');\n  }\n\n  switchToFrench() {\n    this.langService.setLang('fr');\n  }\n}\n"]}