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.
@@ -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, FxValidatorService } from '@instantsys-labs/fx';
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 = 'My name is {name} and I am {age} years old';
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: 'minValidation', $title: 'Min Validation', value: '' }),
107
- new FxStringSetting({ key: 'maxValidation', $title: 'Max Validation', value: '' }),
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 [FxValidatorService.required];
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
- console.log(`Replacing {${placeholder}} with:`, values[placeholder]);
149
- return values[placeholder]; // Replace placeholder with its value
70
+ return values[placeholder];
150
71
  }
151
72
  else {
152
- console.log(`No value found for {${placeholder}}, keeping the placeholder.`);
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(); // Manually trigger change detection
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 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>", styles: [""], 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"] }] });
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 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>" }]
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>"]}