fx-form-builder-wrapper 2.0.99 → 2.0.100
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/customize-dropdown/customize-dropdown.component.mjs +398 -0
- package/esm2022/lib/components/dropdown-with-other/dropdown-with-other.component.mjs +6 -3
- package/esm2022/lib/components/fx-form-component/fx-form-component.component.mjs +3 -3
- package/esm2022/lib/components/radio-group/radio-group.component.mjs +6 -3
- package/esm2022/lib/components/summary/summary.component.mjs +12 -93
- package/esm2022/lib/components/uploader/uploader.component.mjs +2 -2
- package/esm2022/lib/fx-builder-wrapper.component.mjs +5 -5
- package/fesm2022/fx-form-builder-wrapper.mjs +412 -102
- package/fesm2022/fx-form-builder-wrapper.mjs.map +1 -1
- package/lib/components/customize-dropdown/customize-dropdown.component.d.ts +65 -0
- package/lib/components/dropdown-with-other/dropdown-with-other.component.d.ts +1 -0
- package/lib/components/radio-group/radio-group.component.d.ts +1 -0
- package/lib/components/summary/summary.component.d.ts +0 -1
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, inject, ViewChild } from '@angular/core';
|
|
3
3
|
import { ReactiveFormsModule, FormsModule, FormBuilder } from '@angular/forms';
|
|
4
|
-
import { FxBaseComponent, FxComponent, FxStringSetting
|
|
4
|
+
import { FxBaseComponent, FxComponent, FxStringSetting } from '@instantsys-labs/fx';
|
|
5
5
|
import { Subject, takeUntil } from 'rxjs';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@angular/common/http";
|
|
@@ -21,7 +21,7 @@ export class SummaryComponent extends FxBaseComponent {
|
|
|
21
21
|
summaryForm = this.fb.group({
|
|
22
22
|
summary: [''],
|
|
23
23
|
});
|
|
24
|
-
dynamicText = '
|
|
24
|
+
dynamicText = '';
|
|
25
25
|
constructor(cdr, http, fxBuilderWrapperService) {
|
|
26
26
|
super(cdr);
|
|
27
27
|
this.cdr = cdr;
|
|
@@ -32,141 +32,60 @@ export class SummaryComponent extends FxBaseComponent {
|
|
|
32
32
|
});
|
|
33
33
|
}
|
|
34
34
|
ngOnInit() {
|
|
35
|
+
this.dynamicText = this.setting('summaryText') || '';
|
|
35
36
|
this.fxBuilderWrapperService.variables$
|
|
36
37
|
.pipe(takeUntil(this.destroy$))
|
|
37
38
|
.subscribe((variables) => {
|
|
38
39
|
if (!variables)
|
|
39
40
|
return;
|
|
40
|
-
this.datePickerMap = new Map();
|
|
41
|
-
// for (const [key, value] of Object.entries(variables) as [string, any][]) {
|
|
42
|
-
// if (key.includes('lib-date-picker')) {
|
|
43
|
-
// this.datePickerMap.set(key, value);
|
|
44
|
-
// }
|
|
45
|
-
// }
|
|
46
|
-
for (const [key, value] of Object.entries(variables)) {
|
|
47
|
-
if (value &&
|
|
48
|
-
typeof value === 'object' &&
|
|
49
|
-
'date' in value) {
|
|
50
|
-
this.datePickerMap.set(key, value);
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
41
|
});
|
|
54
|
-
// const today = new Date();
|
|
55
|
-
// this.minDate = new Date(today);
|
|
56
|
-
// this.minDate.setDate(today.getDate() - 30);
|
|
57
|
-
// this.maxDate = new Date(today);
|
|
58
|
-
// this.maxDate.setDate(today.getDate() + 30);
|
|
59
|
-
// this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));
|
|
60
|
-
// this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + 31)));
|
|
61
|
-
const today = new Date();
|
|
62
|
-
const min = new Date();
|
|
63
|
-
min.setDate(today.getDate() - 30);
|
|
64
|
-
const max = new Date();
|
|
65
|
-
max.setDate(today.getDate());
|
|
66
|
-
this.minDate = this.formatDate(min);
|
|
67
|
-
this.maxDate = this.formatDate(max);
|
|
68
|
-
// this.getRangeValues();
|
|
69
42
|
}
|
|
70
|
-
// get dateControl() {
|
|
71
|
-
// return this.datePickerForm.get('date');
|
|
72
|
-
// }
|
|
73
43
|
ngAfterViewInit() {
|
|
74
44
|
const key = this.fxComponent?.fxData?.name;
|
|
75
45
|
if (key) {
|
|
76
|
-
const datePatch = this.datePickerMap.get(key);
|
|
77
|
-
const finalDate = datePatch || this.formatDate(new Date());
|
|
78
|
-
if (datePatch) {
|
|
79
|
-
this.minDate = datePatch;
|
|
80
|
-
}
|
|
81
|
-
else {
|
|
82
|
-
this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));
|
|
83
|
-
}
|
|
84
|
-
// this.datePickerForm.patchValue({date:finalDate});
|
|
85
46
|
}
|
|
86
47
|
this.getContextBaseId();
|
|
87
48
|
}
|
|
88
|
-
getRangeValues() {
|
|
89
|
-
this.http.get(this.setting('apiURL')).subscribe(response => {
|
|
90
|
-
const today = new Date();
|
|
91
|
-
const minOffset = response[this.setting('minDateKey')] || this.setting('minValidation');
|
|
92
|
-
const maxOffset = response[this.setting('maxDateKey')] || this.setting('maxValidation');
|
|
93
|
-
// this.minDate = new Date(today);
|
|
94
|
-
// this.minDate.setDate(today.getDate() + minOffset);
|
|
95
|
-
// this.maxDate = new Date(today);
|
|
96
|
-
// this.maxDate.setDate(today.getDate() + maxOffset);
|
|
97
|
-
this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + minOffset)));
|
|
98
|
-
this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + maxOffset)));
|
|
99
|
-
});
|
|
100
|
-
}
|
|
101
49
|
formatDate(date) {
|
|
102
50
|
return date.toISOString().split('T')[0];
|
|
103
51
|
}
|
|
104
52
|
settings() {
|
|
105
53
|
return [
|
|
106
|
-
new FxStringSetting({ key: '
|
|
107
|
-
new FxStringSetting({ key: '
|
|
108
|
-
new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),
|
|
109
|
-
new FxStringSetting({ key: 'minDateKey', $title: 'Min Range API Key', value: '' }),
|
|
110
|
-
new FxStringSetting({ key: 'maxDateKey', $title: 'Max Range API Key', value: '' }),
|
|
111
|
-
new FxStringSetting({ key: 'placeHolder', $title: 'Placeholder', value: 'Select Date' }),
|
|
112
|
-
new FxStringSetting({ key: 'label', $title: 'Label', value: '' }),
|
|
113
|
-
new FxStringSetting({ key: 'datePickerErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),
|
|
54
|
+
new FxStringSetting({ key: 'summaryText', $title: 'Summary Text', value: '' }),
|
|
55
|
+
new FxStringSetting({ key: 'summaryLabel', $title: 'Label', value: '' }),
|
|
114
56
|
];
|
|
115
57
|
}
|
|
116
58
|
validations() {
|
|
117
|
-
return [
|
|
59
|
+
return [];
|
|
118
60
|
}
|
|
119
61
|
updateTextArea() {
|
|
120
|
-
// Get all the form control values
|
|
121
|
-
console.log('Updating text area with dynamic values', this.fxComponent);
|
|
122
62
|
const formValues = this.fxComponent?.fxData?.$formGroup?.value;
|
|
123
|
-
// const formValues = {name: 'John', age: 30}; // Example values, replace with actual form control values
|
|
124
|
-
// Replace placeholders in the text template with corresponding form control values
|
|
125
|
-
console.log('Form Values:', formValues);
|
|
126
63
|
const dynamicText = this.replacePlaceholders(this.dynamicText, formValues);
|
|
127
|
-
console.log('Replaced dynamic text:', dynamicText);
|
|
128
64
|
this.summaryForm.patchValue({ summary: dynamicText });
|
|
129
65
|
this.cdr.detectChanges();
|
|
130
66
|
}
|
|
131
|
-
// // Method to replace placeholders in the string based on form control values
|
|
132
|
-
// replacePlaceholders(template: string, values: any): string {
|
|
133
|
-
// // Use a regular expression to find placeholders like {name}, {age}, etc.
|
|
134
|
-
// return template.replace(/{(.*?)}/g, (match, placeholder) => {
|
|
135
|
-
// // For each placeholder, look it up in the form control values
|
|
136
|
-
// return values[placeholder] !== undefined ? values[placeholder] : match;
|
|
137
|
-
// });
|
|
138
|
-
// }
|
|
139
67
|
replacePlaceholders(template, values) {
|
|
140
|
-
// Log the values to debug
|
|
141
|
-
console.log('Values:', values);
|
|
142
|
-
// Use a regular expression to find placeholders like {name}, {age}, etc.
|
|
143
68
|
return template.replace(/{(.*?)}/g, (match, placeholder) => {
|
|
144
|
-
// Log each placeholder being processed
|
|
145
|
-
console.log('Processing placeholder:', placeholder);
|
|
146
|
-
// Check if the placeholder exists in values
|
|
147
69
|
if (values[placeholder] !== undefined) {
|
|
148
|
-
|
|
149
|
-
return values[placeholder]; // Replace placeholder with its value
|
|
70
|
+
return values[placeholder];
|
|
150
71
|
}
|
|
151
72
|
else {
|
|
152
|
-
|
|
153
|
-
return match; // Keep placeholder if no value found
|
|
73
|
+
return match;
|
|
154
74
|
}
|
|
155
75
|
});
|
|
156
76
|
}
|
|
157
77
|
ngAfterViewChecked() {
|
|
158
|
-
// After the view has been checked, update text area if needed
|
|
159
78
|
this.updateTextArea();
|
|
160
|
-
this.cdr.detectChanges();
|
|
79
|
+
this.cdr.detectChanges();
|
|
161
80
|
}
|
|
162
81
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SummaryComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.HttpClient }, { token: i2.FxBuilderWrapperService }], target: i0.ɵɵFactoryTarget.Component });
|
|
163
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SummaryComponent, isStandalone: true, selector: "lib-summary", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"custom-date-picker relative\">\r\n <form [formGroup]=\"summaryForm\">\r\n\r\n <label
|
|
82
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: SummaryComponent, isStandalone: true, selector: "lib-summary", viewQueries: [{ propertyName: "fxComponent", first: true, predicate: ["fxComponent"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"custom-date-picker relative\">\r\n <form [formGroup]=\"summaryForm\">\r\n\r\n <label class=\"summary-label\">{{ setting('summaryLabel') }}</label>\r\n <div class=\"relative\">\r\n <textarea formControlName=\"summary\" readonly class=\"w-full\"></textarea>\r\n </div>\r\n <!-- <div>\r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('datePickerErrorMessage') }}\r\n </small>\r\n </div> -->\r\n </form>\r\n </div>\r\n\r\n</fx-component>", styles: [".summary-label{color:#4682b4;font-weight:600;margin-bottom:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "component", type: FxComponent, selector: "fx-component", inputs: ["fxData"] }] });
|
|
164
83
|
}
|
|
165
84
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SummaryComponent, decorators: [{
|
|
166
85
|
type: Component,
|
|
167
|
-
args: [{ selector: 'lib-summary', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"custom-date-picker relative\">\r\n <form [formGroup]=\"summaryForm\">\r\n\r\n <label
|
|
86
|
+
args: [{ selector: 'lib-summary', standalone: true, imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent], template: "<fx-component [fxData]=\"fxData\" #fxComponent>\r\n <div class=\"custom-date-picker relative\">\r\n <form [formGroup]=\"summaryForm\">\r\n\r\n <label class=\"summary-label\">{{ setting('summaryLabel') }}</label>\r\n <div class=\"relative\">\r\n <textarea formControlName=\"summary\" readonly class=\"w-full\"></textarea>\r\n </div>\r\n <!-- <div>\r\n <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n class=\"text-red-500\">\r\n {{ setting('datePickerErrorMessage') }}\r\n </small>\r\n </div> -->\r\n </form>\r\n </div>\r\n\r\n</fx-component>", styles: [".summary-label{color:#4682b4;font-weight:600;margin-bottom:10px}\n"] }]
|
|
168
87
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.HttpClient }, { type: i2.FxBuilderWrapperService }], propDecorators: { fxComponent: [{
|
|
169
88
|
type: ViewChild,
|
|
170
89
|
args: ['fxComponent']
|
|
171
90
|
}] } });
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/summary/summary.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/summary/summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewChecked, ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'lib-summary',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent],\r\n  templateUrl: './summary.component.html',\r\n  styleUrl: './summary.component.css'\r\n})\r\nexport class SummaryComponent extends FxBaseComponent implements OnInit, AfterViewChecked{\r\n  private fb = inject(FormBuilder);\r\n\r\nminDate!: string;\r\nmaxDate!: string;\r\n   today = new Date();\r\n   @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n   private destroy$ = new Subject<Boolean>();\r\n    datePickerMap = new Map<string, any>();\r\n  \r\n   \r\n\r\n\r\n    public summaryForm: FormGroup = this.fb.group({\r\n       summary: [''],\r\n     })\r\n\r\n      dynamicText: string = 'My name is {name} and I am {age} years old';\r\n   constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService) {\r\n      super(cdr)\r\n      this.onInit.subscribe(() => {\r\n        this._register(this.summaryForm);\r\n      });\r\n     \r\n    }\r\n\r\n\r\n  ngOnInit(): void {\r\n\r\n   this.fxBuilderWrapperService.variables$\r\n  .pipe(takeUntil(this.destroy$))\r\n  .subscribe((variables: any) => {\r\n    if (!variables) return;\r\n\r\n    this.datePickerMap = new Map<string, any>();\r\n\r\n    // for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n    //   if (key.includes('lib-date-picker')) {\r\n    //     this.datePickerMap.set(key, value);\r\n    //   }\r\n    // }\r\n\r\n    for (const [key, value] of Object.entries(variables) as [string, any][]) {\r\n  if (\r\n    value &&\r\n    typeof value === 'object' &&\r\n    'date' in value\r\n  ) {\r\n    this.datePickerMap.set(key, value);\r\n  }\r\n}\r\n  });\r\n\r\n\r\n    // const today = new Date();\r\n    // this.minDate = new Date(today);\r\n    // this.minDate.setDate(today.getDate() - 30);\r\n\r\n    // this.maxDate = new Date(today);\r\n    // this.maxDate.setDate(today.getDate() + 30);\r\n\r\n  // this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n  // this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + 31)));\r\n\r\n  const today = new Date();\r\n\r\nconst min = new Date();\r\nmin.setDate(today.getDate() - 30);\r\n\r\nconst max = new Date();\r\nmax.setDate(today.getDate());\r\n\r\nthis.minDate = this.formatDate(min);\r\nthis.maxDate = this.formatDate(max);\r\n\r\n    // this.getRangeValues();\r\n\r\n\r\n  }\r\n\r\n  // get dateControl() {\r\n  //   return this.datePickerForm.get('date');\r\n  // }\r\n\r\n   ngAfterViewInit(): void {\r\n    const key = this.fxComponent?.fxData?.name;\r\n    if(key){\r\n        const datePatch = this.datePickerMap.get(key)\r\n        const finalDate = datePatch || this.formatDate(new Date())\r\n        if(datePatch){\r\n            this.minDate = datePatch\r\n        }\r\n        else{\r\n         this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() - 30)));\r\n        }\r\n        \r\n\r\n      // this.datePickerForm.patchValue({date:finalDate});\r\n    }\r\n    this.getContextBaseId();\r\n  }\r\n\r\n  getRangeValues() {\r\n    this.http.get<any>(this.setting('apiURL')).subscribe(response => {\r\n      const today = new Date();\r\n  \r\n      const minOffset = response[this.setting('minDateKey')] || this.setting('minValidation');\r\n      const maxOffset = response[this.setting('maxDateKey')] || this.setting('maxValidation');\r\n  \r\n      // this.minDate = new Date(today);\r\n      // this.minDate.setDate(today.getDate() + minOffset);\r\n  \r\n      // this.maxDate = new Date(today);\r\n      // this.maxDate.setDate(today.getDate() + maxOffset);\r\n\r\n    this.minDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + minOffset)));\r\n  this.maxDate = this.formatDate(new Date(this.today.setDate(new Date().getDate() + maxOffset)));\r\n    });\r\n  }\r\n\r\n  private formatDate(date: Date): string {\r\n  return date.toISOString().split('T')[0]; \r\n}\r\n  \r\n\r\n\r\n    protected settings(): FxSetting[] {\r\n        return [\r\n          new FxStringSetting({ key: 'minValidation', $title: 'Min Validation', value: '' }),\r\n          new FxStringSetting({ key: 'maxValidation', $title: 'Max Validation', value: '' }),\r\n          new FxStringSetting({ key: 'apiURL', $title: 'API Url', value: '' }),\r\n          new FxStringSetting({ key: 'minDateKey', $title: 'Min Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'maxDateKey', $title: 'Max Range API Key', value: '' }),\r\n          new FxStringSetting({ key: 'placeHolder', $title: 'Placeholder', value: 'Select Date' }),\r\n          new FxStringSetting({ key: 'label', $title: 'Label', value: '' }),\r\n          new FxStringSetting({ key: 'datePickerErrorMessage', $title: 'Error Message', value: 'Please fill out the field' }),\r\n         \r\n        ];\r\n      }\r\n    \r\n      protected validations(): FxValidation[] {\r\n        return [FxValidatorService.required];\r\n      }\r\n\r\n      updateTextArea(): void {\r\n    // Get all the form control values\r\n    console.log('Updating text area with dynamic values',this.fxComponent);\r\n\r\n    const formValues = this.fxComponent?.fxData?.$formGroup?.value;\r\n\r\n    // const formValues = {name: 'John', age: 30}; // Example values, replace with actual form control values\r\n    \r\n    // Replace placeholders in the text template with corresponding form control values\r\n    console.log('Form Values:', formValues);\r\n    const dynamicText = this.replacePlaceholders(this.dynamicText, formValues);\r\n    console.log('Replaced dynamic text:', dynamicText);\r\n    this.summaryForm.patchValue({ summary: dynamicText });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  // // Method to replace placeholders in the string based on form control values\r\n  // replacePlaceholders(template: string, values: any): string {\r\n  //   // Use a regular expression to find placeholders like {name}, {age}, etc.\r\n  //   return template.replace(/{(.*?)}/g, (match, placeholder) => {\r\n  //     // For each placeholder, look it up in the form control values\r\n  //     return values[placeholder] !== undefined ? values[placeholder] : match;\r\n  //   });\r\n  // }\r\n\r\n\r\n  replacePlaceholders(template: string, values: any): string {\r\n  // Log the values to debug\r\n  console.log('Values:', values);\r\n  \r\n  // Use a regular expression to find placeholders like {name}, {age}, etc.\r\n  return template.replace(/{(.*?)}/g, (match, placeholder) => {\r\n    // Log each placeholder being processed\r\n    console.log('Processing placeholder:', placeholder);\r\n    \r\n    // Check if the placeholder exists in values\r\n    if (values[placeholder] !== undefined) {\r\n      console.log(`Replacing {${placeholder}} with:`, values[placeholder]);\r\n      return values[placeholder];  // Replace placeholder with its value\r\n    } else {\r\n      console.log(`No value found for {${placeholder}}, keeping the placeholder.`);\r\n      return match;  // Keep placeholder if no value found\r\n    }\r\n  });\r\n}\r\n\r\n\r\n  ngAfterViewChecked(): void {\r\n    // After the view has been checked, update text area if needed\r\n    this.updateTextArea();\r\n    this.cdr.detectChanges();  // Manually trigger change detection\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"custom-date-picker relative\">\r\n    <form [formGroup]=\"summaryForm\">\r\n\r\n        <label for=\"date\" class=\"input-label\">{{ setting('label') }}<span class=\"field-required\">*</span></label>\r\n        <div class=\"relative\">\r\n        <textarea formControlName=\"summary\"></textarea>\r\n        </div>\r\n    <!-- <div>\r\n      <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n      {{ setting('datePickerErrorMessage') }}\r\n      </small>\r\n    </div> -->\r\n    </form>\r\n  </div>\r\n\r\n</fx-component>"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary.component.js","sourceRoot":"","sources":["../../../../../../projects/fx-builder-wrapper/src/lib/components/summary/summary.component.ts","../../../../../../projects/fx-builder-wrapper/src/lib/components/summary/summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { AfterViewChecked, ChangeDetectorRef, Component, inject, OnInit, ViewChild } from '@angular/core';\r\nimport { ReactiveFormsModule, FormsModule, FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { FxBaseComponent, FxComponent, FxSetting, FxStringSetting, FxValidation, FxValidatorService } from '@instantsys-labs/fx';\r\nimport { CalendarModule } from 'primeng/calendar';\r\nimport { FxBuilderWrapperService } from '../../fx-builder-wrapper.service';\r\nimport { Subject, takeUntil } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'lib-summary',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule, FormsModule, FxComponent],\r\n  templateUrl: './summary.component.html',\r\n  styleUrl: './summary.component.css'\r\n})\r\nexport class SummaryComponent extends FxBaseComponent implements OnInit, AfterViewChecked{\r\n  private fb = inject(FormBuilder);\r\n\r\nminDate!: string;\r\nmaxDate!: string;\r\n   today = new Date();\r\n   @ViewChild('fxComponent') fxComponent!: FxComponent;\r\n   private destroy$ = new Subject<Boolean>();\r\n   datePickerMap = new Map<string, any>();\r\n  \r\n   \r\n\r\n\r\n    public summaryForm: FormGroup = this.fb.group({\r\n       summary: [''],\r\n     })\r\n\r\n      dynamicText: string = '';\r\n   constructor(private cdr: ChangeDetectorRef,private http: HttpClient,private fxBuilderWrapperService: FxBuilderWrapperService) {\r\n      super(cdr)\r\n      this.onInit.subscribe(() => {\r\n        this._register(this.summaryForm);\r\n      });\r\n     \r\n    }\r\n\r\n\r\n  ngOnInit(): void {\r\n    this.dynamicText = this.setting('summaryText') || '';\r\n   this.fxBuilderWrapperService.variables$\r\n  .pipe(takeUntil(this.destroy$))\r\n  .subscribe((variables: any) => {\r\n    if (!variables) return;\r\n  });\r\n  }\r\n\r\n   ngAfterViewInit(): void {\r\n    const key = this.fxComponent?.fxData?.name;\r\n    if(key){\r\n    }\r\n    this.getContextBaseId();\r\n  }\r\n\r\n  \r\n\r\n  private formatDate(date: Date): string {\r\n  return date.toISOString().split('T')[0]; \r\n}\r\n  \r\n\r\n\r\n    protected settings(): FxSetting[] {\r\n        return [\r\n          new FxStringSetting({ key: 'summaryText', $title: 'Summary Text', value: '' }),\r\n          new FxStringSetting({ key: 'summaryLabel', $title: 'Label', value: '' }),\r\n        ];\r\n      }\r\n    \r\n      protected validations(): FxValidation[] {\r\n        return [];\r\n      }\r\n\r\n    updateTextArea(): void {\r\n    const formValues = this.fxComponent?.fxData?.$formGroup?.value;\r\n    const dynamicText = this.replacePlaceholders(this.dynamicText, formValues);\r\n    this.summaryForm.patchValue({ summary: dynamicText });\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  replacePlaceholders(template: string, values: any): string {\r\n  return template.replace(/{(.*?)}/g, (match, placeholder) => {\r\n    if (values[placeholder] !== undefined) {\r\n      return values[placeholder];\r\n    } else {\r\n      return match;\r\n    }\r\n  });\r\n}\r\n\r\n\r\n  ngAfterViewChecked(): void {\r\n    this.updateTextArea();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<fx-component [fxData]=\"fxData\" #fxComponent>\r\n  <div class=\"custom-date-picker relative\">\r\n    <form [formGroup]=\"summaryForm\">\r\n\r\n        <label class=\"summary-label\">{{ setting('summaryLabel') }}</label>\r\n        <div class=\"relative\">\r\n        <textarea formControlName=\"summary\" readonly class=\"w-full\"></textarea>\r\n        </div>\r\n    <!-- <div>\r\n      <small *ngIf=\"datePickerForm.get('date')?.touched && datePickerForm.get('date')?.errors?.['required']\"\r\n        class=\"text-red-500\">\r\n      {{ setting('datePickerErrorMessage') }}\r\n      </small>\r\n    </div> -->\r\n    </form>\r\n  </div>\r\n\r\n</fx-component>"]}
|