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.
- package/esm2022/lib/components/atoms/button/button.component.mjs +103 -23
- package/esm2022/lib/components/types.mjs +1 -1
- package/esm2022/lib/services/lang-provider/content.mjs +1 -72
- package/esm2022/lib/services/lang-provider/lang-provider.service.mjs +4 -9
- package/esm2022/lib/shared/utils/content.mjs +2 -8
- package/esm2022/public-api.mjs +1 -12
- package/fesm2022/valtech-components.mjs +124 -2824
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/button/button.component.d.ts +33 -2
- package/lib/components/types.d.ts +19 -7
- package/package.json +1 -1
- package/public-api.d.ts +0 -10
- package/esm2022/lib/examples/comprehensive-link-test.component.mjs +0 -208
- package/esm2022/lib/examples/custom-content-demo.component.mjs +0 -291
- package/esm2022/lib/examples/display-demo.component.mjs +0 -518
- package/esm2022/lib/examples/display-simple-example.component.mjs +0 -202
- package/esm2022/lib/examples/link-processing-example.component.mjs +0 -233
- package/esm2022/lib/examples/multi-language-demo.component.mjs +0 -304
- package/esm2022/lib/examples/reactive-components-demo.component.mjs +0 -303
- package/esm2022/lib/examples/reactivity-test.component.mjs +0 -200
- package/esm2022/lib/examples/selector-examples.component.mjs +0 -234
- package/esm2022/lib/examples/user-issue-test.component.mjs +0 -267
- package/lib/examples/comprehensive-link-test.component.d.ts +0 -23
- package/lib/examples/custom-content-demo.component.d.ts +0 -26
- package/lib/examples/display-demo.component.d.ts +0 -62
- package/lib/examples/display-simple-example.component.d.ts +0 -23
- package/lib/examples/link-processing-example.component.d.ts +0 -26
- package/lib/examples/multi-language-demo.component.d.ts +0 -34
- package/lib/examples/reactive-components-demo.component.d.ts +0 -45
- package/lib/examples/reactivity-test.component.d.ts +0 -27
- package/lib/examples/selector-examples.component.d.ts +0 -21
- 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"]}
|