fx-form-builder-wrapper 2.0.97 → 2.0.99
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.
|
@@ -122,17 +122,36 @@ export class SummaryComponent extends FxBaseComponent {
|
|
|
122
122
|
const formValues = this.fxComponent?.fxData?.$formGroup?.value;
|
|
123
123
|
// const formValues = {name: 'John', age: 30}; // Example values, replace with actual form control values
|
|
124
124
|
// Replace placeholders in the text template with corresponding form control values
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
125
|
+
console.log('Form Values:', formValues);
|
|
126
|
+
const dynamicText = this.replacePlaceholders(this.dynamicText, formValues);
|
|
127
|
+
console.log('Replaced dynamic text:', dynamicText);
|
|
128
|
+
this.summaryForm.patchValue({ summary: dynamicText });
|
|
128
129
|
this.cdr.detectChanges();
|
|
129
130
|
}
|
|
130
|
-
// Method to replace placeholders in the string based on form control values
|
|
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
|
+
// }
|
|
131
139
|
replacePlaceholders(template, values) {
|
|
140
|
+
// Log the values to debug
|
|
141
|
+
console.log('Values:', values);
|
|
132
142
|
// Use a regular expression to find placeholders like {name}, {age}, etc.
|
|
133
143
|
return template.replace(/{(.*?)}/g, (match, placeholder) => {
|
|
134
|
-
//
|
|
135
|
-
|
|
144
|
+
// Log each placeholder being processed
|
|
145
|
+
console.log('Processing placeholder:', placeholder);
|
|
146
|
+
// Check if the placeholder exists in values
|
|
147
|
+
if (values[placeholder] !== undefined) {
|
|
148
|
+
console.log(`Replacing {${placeholder}} with:`, values[placeholder]);
|
|
149
|
+
return values[placeholder]; // Replace placeholder with its value
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
console.log(`No value found for {${placeholder}}, keeping the placeholder.`);
|
|
153
|
+
return match; // Keep placeholder if no value found
|
|
154
|
+
}
|
|
136
155
|
});
|
|
137
156
|
}
|
|
138
157
|
ngAfterViewChecked() {
|
|
@@ -150,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
150
169
|
type: ViewChild,
|
|
151
170
|
args: ['fxComponent']
|
|
152
171
|
}] } });
|
|
153
|
-
//# 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    this.dynamicText = this.replacePlaceholders(this.dynamicText, formValues);\r\n    console.log('Replaced dynamic text:', this.dynamicText);\r\n    this.summaryForm.patchValue({ summary: this.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  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>"]}
|
|
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>"]}
|
|
@@ -3068,17 +3068,36 @@ class SummaryComponent extends FxBaseComponent {
|
|
|
3068
3068
|
const formValues = this.fxComponent?.fxData?.$formGroup?.value;
|
|
3069
3069
|
// const formValues = {name: 'John', age: 30}; // Example values, replace with actual form control values
|
|
3070
3070
|
// Replace placeholders in the text template with corresponding form control values
|
|
3071
|
-
|
|
3072
|
-
|
|
3073
|
-
|
|
3071
|
+
console.log('Form Values:', formValues);
|
|
3072
|
+
const dynamicText = this.replacePlaceholders(this.dynamicText, formValues);
|
|
3073
|
+
console.log('Replaced dynamic text:', dynamicText);
|
|
3074
|
+
this.summaryForm.patchValue({ summary: dynamicText });
|
|
3074
3075
|
this.cdr.detectChanges();
|
|
3075
3076
|
}
|
|
3076
|
-
// Method to replace placeholders in the string based on form control values
|
|
3077
|
+
// // Method to replace placeholders in the string based on form control values
|
|
3078
|
+
// replacePlaceholders(template: string, values: any): string {
|
|
3079
|
+
// // Use a regular expression to find placeholders like {name}, {age}, etc.
|
|
3080
|
+
// return template.replace(/{(.*?)}/g, (match, placeholder) => {
|
|
3081
|
+
// // For each placeholder, look it up in the form control values
|
|
3082
|
+
// return values[placeholder] !== undefined ? values[placeholder] : match;
|
|
3083
|
+
// });
|
|
3084
|
+
// }
|
|
3077
3085
|
replacePlaceholders(template, values) {
|
|
3086
|
+
// Log the values to debug
|
|
3087
|
+
console.log('Values:', values);
|
|
3078
3088
|
// Use a regular expression to find placeholders like {name}, {age}, etc.
|
|
3079
3089
|
return template.replace(/{(.*?)}/g, (match, placeholder) => {
|
|
3080
|
-
//
|
|
3081
|
-
|
|
3090
|
+
// Log each placeholder being processed
|
|
3091
|
+
console.log('Processing placeholder:', placeholder);
|
|
3092
|
+
// Check if the placeholder exists in values
|
|
3093
|
+
if (values[placeholder] !== undefined) {
|
|
3094
|
+
console.log(`Replacing {${placeholder}} with:`, values[placeholder]);
|
|
3095
|
+
return values[placeholder]; // Replace placeholder with its value
|
|
3096
|
+
}
|
|
3097
|
+
else {
|
|
3098
|
+
console.log(`No value found for {${placeholder}}, keeping the placeholder.`);
|
|
3099
|
+
return match; // Keep placeholder if no value found
|
|
3100
|
+
}
|
|
3082
3101
|
});
|
|
3083
3102
|
}
|
|
3084
3103
|
ngAfterViewChecked() {
|