master-control 0.4.62 → 0.4.63

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.
@@ -120,7 +120,15 @@ export class AutocompleteComponent {
120
120
  this.filteredOptions = (this.field().options || []).filter((option) => option.label.toLowerCase().includes(filterValue));
121
121
  }
122
122
  displayFn = (option) => {
123
- return option && typeof option === 'object' ? option.label : option || '';
123
+ let filteredObjectValue = '';
124
+ let toFilterString = typeof option === 'object' && option.value ? option.value : option;
125
+ if (!this.masterService.checkIfValueIsEmpty(this.filteredOptions)) {
126
+ let filteredObj = this.filteredOptions.filter((opt) => ((opt.value.toLowerCase() === toFilterString.toLowerCase()) || (opt.label.toLowerCase() === toFilterString.toLowerCase())));
127
+ if (filteredObj.length > 0 && !this.masterService.checkIfValueIsEmpty(filteredObj[0]['label'])) {
128
+ filteredObjectValue = filteredObj[0]['label'];
129
+ }
130
+ }
131
+ return filteredObjectValue;
124
132
  };
125
133
  // Utility method to get the current selected value
126
134
  getCurrentValue() {
@@ -192,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
192
200
  }], optionSelected: [{
193
201
  type: Output
194
202
  }] } });
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/autocomplete/autocomplete.component.ts","../../../../../projects/master-control/src/lib/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, input, Output } from '@angular/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { CommonModule } from '@angular/common';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MasterControlService } from '../master-control.service';\nimport { FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule, ControlValueAccessor } from '@angular/forms';\nimport { MatSelectChange } from '@angular/material/select';\n@Component({\n  selector: 'lib-autocomplete',\n  standalone: true,\n  imports: [\n    MatFormFieldModule,\n    CommonModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    MatOptionModule,\n    FormsModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './autocomplete.component.html',\n  styleUrl: './autocomplete.component.css',\n  providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: AutocompleteComponent,\n        multi: true\n      }\n    ]\n})\nexport class AutocompleteComponent implements ControlValueAccessor {\n  constructor(public masterService : MasterControlService) {}\n  field: any = input.required<any>();\n  selectedOption: any = null;\n  filteredOptions:any=[];\n  inputValue: any = '';\n  reactiveFormControlobject : any = input<any>();\n\n  // Output events for parent component communication\n  @Output() blur = new EventEmitter<any>();\n  @Output() selectionChanged = new EventEmitter<any>();\n  @Output() valueChanged = new EventEmitter<any>();\n  @Output() optionSelected = new EventEmitter<any>();\n\n\n  ngOnInit() {\n    this.filteredOptions = this.field().options || [];\n    // Subscribe to valueChanges if using reactive forms\n    if (this.reactiveFormControlobject && this.reactiveFormControlobject.valueChanges) {\n      this.reactiveFormControlobject.valueChanges.subscribe((value: any) => {\n        this.onInputChange(value);\n      });\n    }\n  }\n\n    onChange: any = () => {};\n    onTouched: any = () => {};\n\n    writeValue(value: any): void {\n      if (value !== undefined && value !== null) {\n        // If value is an object, extract the label\n        if (typeof value === 'object' && value.label) {\n          this.inputValue = value.label;\n          this.selectedOption = value;\n        }\n        else {\n          let option = this.field().options?.find((opt: any) =>\n            opt.value === value\n          );\n          if (!option) {\n            option = this.field().options?.find((opt: any) =>\n              opt.label === value\n            );\n          }\n          if (option) {\n            this.inputValue = option.label;\n            this.selectedOption = option;\n          } else {\n            this.inputValue = value.toString();\n            this.selectedOption = { label: value.toString(), value: value };\n          }\n        }\n      } else {\n        this.inputValue = '';\n        this.selectedOption = null;\n      }\n      if(typeof this.inputValue === 'string' && value !== null) {\n        this.filterOptions();\n      }\n    }\n\n    registerOnChange(fn: any): void {\n      this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n      this.onTouched = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n      // Handle disabled state if needed\n    }\n\n    onInputChange(value: any): void {\n\n      this.inputValue = value;\n      if(typeof this.inputValue === 'string' && value !== null) {\n        this.filterOptions();\n      }\n\n      // Find matching option\n      const matchingOption = this.field().options?.find((option: any) =>\n        option.label.toLowerCase() === value.toLowerCase()\n      );\n\n      if (matchingOption) {\n        this.selectedOption = matchingOption;\n        this.onChange(matchingOption.value);\n      } else {\n        this.selectedOption = null;\n        this.onChange(value);\n      }\n\n      this.onTouched();\n      this.valueChanged.emit(value);\n      this.selectionChanged.emit(this.selectedOption);\n    }\n\n    onOptionSelected(option: any): void {\n      this.selectedOption = option;\n      this.inputValue = option.label;\n      this.onChange(option.value);\n      this.onTouched();\n\n      // Emit events for parent component\n      this.optionSelected.emit(option);\n      this.selectionChanged.emit(option);\n      this.valueChanged.emit(option.label);\n    }\n\n    onBlur(event?: any): void {\n      this.onTouched();\n      this.blur.emit(event);\n    }\n\n    filterOptions(): void {\n      if (!this.inputValue || this.inputValue.trim() === '') {\n        this.filteredOptions = this.field().options || [];\n        return;\n      }\n\n      const filterValue = this.inputValue.toLowerCase();\n      this.filteredOptions = (this.field().options || []).filter((option: any) =>\n        option.label.toLowerCase().includes(filterValue)\n      );\n    }\n\n    displayFn = (option: any): string => {\n      return option && typeof option === 'object' ? option.label : option || '';\n    }\n\n    // Utility method to get the current selected value\n    getCurrentValue(): any {\n      return this.selectedOption ? this.selectedOption.value : this.inputValue;\n    }\n\n    // Utility method to get the current selected option\n    getCurrentOption(): any {\n      return this.selectedOption;\n    }\n\n    // Method to set value programmatically (useful for parent components)\n    setValue(value: any): void {\n      this.writeValue(value);\n      this.onChange(this.getCurrentValue());\n    }\n\n  onInputChangeForReactiveForms(event : any) {\n      this.inputValue = event?.target?.value;\n      if(typeof this.inputValue === 'string' && event?.target?.value !== null) {\n        this.filterOptions();\n      }\n\n      // Find matching option\n      const matchingOption = this.field().options?.find((option: any) =>\n        option.label.toLowerCase() === event?.target?.value.toLowerCase()\n      );\n\n      if (matchingOption) {\n        this.selectedOption = matchingOption;\n        this.onChange(matchingOption.value);\n      } else {\n        this.selectedOption = null;\n        this.onChange(event?.target?.value);\n      }\n\n      this.onTouched();\n      this.valueChanged.emit(event?.target?.value);\n      this.selectionChanged.emit(this.selectedOption);\n  }\n\n  onFocus(): void {\n    this.filterOptions();\n  }\n}\n","  <label *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n  <mat-form-field class=\"w-100 show-arrow\" appearance=\"outline\" *ngIf=\"field() && field()?.isVisible\"  [ngStyle]=\"{\n  '--custom-border-color': field()?.controlStyle?.borderColor ,\n  '--custom-border-width': field()?.controlStyle?.borderWidth ,\n  '--custom-border-radius': field()?.controlStyle?.borderRadius ,\n  '--custom-bg-color': field()?.controlStyle?.background ,\n  '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n  '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n  '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n  '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n  '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n  '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n  '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n  }\">\n   @if(reactiveFormControlobject()) {\n     <input\n      matInput\n      type=\"text\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      [matAutocomplete]=\"auto\"\n      (focus)=\"onFocus()\"\n      (blur)=\"onBlur()\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [placeholder]=\"field()?.placeHolder\"\n      (input)=\"onInputChangeForReactiveForms($event)\"\n      [formControl]=\"reactiveFormControlobject()\"\n     />\n   }@else {\n     <input\n      matInput\n      type=\"text\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      [matAutocomplete]=\"auto\"\n      [ngModel]=\"inputValue\"\n      (ngModelChange)=\"onInputChange($event)\"\n      (focus)=\"onFocus()\"\n      (blur)=\"onBlur($event)\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [placeholder]=\"field()?.placeHolder\"\n     />\n   }\n   <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\" [displayWith]=\"displayFn\" (optionSelected)=\"onOptionSelected($event.option.value)\">\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\n      {{ option.label }}\n    </mat-option>\n  </mat-autocomplete>\n    <mat-error>\n    {{ field().validators.requiredMessage }}\n  </mat-error>\n  </mat-form-field>\n  <div class=\"error-message\" *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}.\n  </div>\n  <div class=\"error-message\" *ngIf=\"false\">\n    {{ field()?.validators?.patternMessage }}.\n  </div>\n"]}
203
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/autocomplete/autocomplete.component.ts","../../../../../projects/master-control/src/lib/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, input, Output } from '@angular/core';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { CommonModule } from '@angular/common';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatAutocompleteModule } from '@angular/material/autocomplete';\nimport { MatOptionModule } from '@angular/material/core';\nimport { MasterControlService } from '../master-control.service';\nimport { FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule, ControlValueAccessor } from '@angular/forms';\nimport { MatSelectChange } from '@angular/material/select';\n@Component({\n  selector: 'lib-autocomplete',\n  standalone: true,\n  imports: [\n    MatFormFieldModule,\n    CommonModule,\n    MatInputModule,\n    MatAutocompleteModule,\n    MatOptionModule,\n    FormsModule,\n    ReactiveFormsModule\n  ],\n  templateUrl: './autocomplete.component.html',\n  styleUrl: './autocomplete.component.css',\n  providers: [\n      {\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: AutocompleteComponent,\n        multi: true\n      }\n    ]\n})\nexport class AutocompleteComponent implements ControlValueAccessor {\n  constructor(public masterService : MasterControlService) {}\n  field: any = input.required<any>();\n  selectedOption: any = null;\n  filteredOptions:any=[];\n  inputValue: any = '';\n  reactiveFormControlobject : any = input<any>();\n\n  // Output events for parent component communication\n  @Output() blur = new EventEmitter<any>();\n  @Output() selectionChanged = new EventEmitter<any>();\n  @Output() valueChanged = new EventEmitter<any>();\n  @Output() optionSelected = new EventEmitter<any>();\n\n\n  ngOnInit() {\n    this.filteredOptions = this.field().options || [];\n    // Subscribe to valueChanges if using reactive forms\n    if (this.reactiveFormControlobject && this.reactiveFormControlobject.valueChanges) {\n      this.reactiveFormControlobject.valueChanges.subscribe((value: any) => {\n        this.onInputChange(value);\n      });\n    }\n  }\n\n    onChange: any = () => {};\n    onTouched: any = () => {};\n\n    writeValue(value: any): void {\n      if (value !== undefined && value !== null) {\n        // If value is an object, extract the label\n        if (typeof value === 'object' && value.label) {\n          this.inputValue = value.label;\n          this.selectedOption = value;\n        }\n        else {\n          let option = this.field().options?.find((opt: any) =>\n            opt.value === value\n          );\n          if (!option) {\n            option = this.field().options?.find((opt: any) =>\n              opt.label === value\n            );\n          }\n          if (option) {\n            this.inputValue = option.label;\n            this.selectedOption = option;\n          } else {\n            this.inputValue = value.toString();\n            this.selectedOption = { label: value.toString(), value: value };\n          }\n        }\n      } else {\n        this.inputValue = '';\n        this.selectedOption = null;\n      }\n      if(typeof this.inputValue === 'string' && value !== null) {\n        this.filterOptions();\n      }\n    }\n\n    registerOnChange(fn: any): void {\n      this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n      this.onTouched = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n      // Handle disabled state if needed\n    }\n\n    onInputChange(value: any): void {\n\n      this.inputValue = value;\n      if(typeof this.inputValue === 'string' && value !== null) {\n        this.filterOptions();\n      }\n\n      // Find matching option\n      const matchingOption = this.field().options?.find((option: any) =>\n        option.label.toLowerCase() === value.toLowerCase()\n      );\n\n      if (matchingOption) {\n        this.selectedOption = matchingOption;\n        this.onChange(matchingOption.value);\n      } else {\n        this.selectedOption = null;\n        this.onChange(value);\n      }\n\n      this.onTouched();\n      this.valueChanged.emit(value);\n      this.selectionChanged.emit(this.selectedOption);\n    }\n\n    onOptionSelected(option: any): void {\n      this.selectedOption = option;\n      this.inputValue = option.label;\n      this.onChange(option.value);\n      this.onTouched();\n\n      // Emit events for parent component\n      this.optionSelected.emit(option);\n      this.selectionChanged.emit(option);\n      this.valueChanged.emit(option.label);\n    }\n\n    onBlur(event?: any): void {\n      this.onTouched();\n      this.blur.emit(event);\n    }\n\n    filterOptions(): void {\n      if (!this.inputValue || this.inputValue.trim() === '') {\n        this.filteredOptions = this.field().options || [];\n        return;\n      }\n\n      const filterValue = this.inputValue.toLowerCase();\n      this.filteredOptions = (this.field().options || []).filter((option: any) =>\n        option.label.toLowerCase().includes(filterValue)\n      );\n    }\n\n    displayFn = (option: any): string => {\n      let filteredObjectValue : any = '';\n      let toFilterString : any = typeof option === 'object' && option.value ? option.value : option;\n      if(!this.masterService.checkIfValueIsEmpty(this.filteredOptions)) {\n        let filteredObj : any = this.filteredOptions.filter((opt: any) => ((opt.value.toLowerCase() === toFilterString.toLowerCase()) || (opt.label.toLowerCase() === toFilterString.toLowerCase())));\n        if(filteredObj.length > 0 && !this.masterService.checkIfValueIsEmpty(filteredObj[0]['label'])) {\n          filteredObjectValue = filteredObj[0]['label']\n        }\n\n      }\n      return filteredObjectValue;\n    }\n\n    // Utility method to get the current selected value\n    getCurrentValue(): any {\n      return this.selectedOption ? this.selectedOption.value : this.inputValue;\n    }\n\n    // Utility method to get the current selected option\n    getCurrentOption(): any {\n      return this.selectedOption;\n    }\n\n    // Method to set value programmatically (useful for parent components)\n    setValue(value: any): void {\n      this.writeValue(value);\n      this.onChange(this.getCurrentValue());\n    }\n\n  onInputChangeForReactiveForms(event : any) {\n      this.inputValue = event?.target?.value;\n      if(typeof this.inputValue === 'string' && event?.target?.value !== null) {\n        this.filterOptions();\n      }\n\n      // Find matching option\n      const matchingOption = this.field().options?.find((option: any) =>\n        option.label.toLowerCase() === event?.target?.value.toLowerCase()\n      );\n\n      if (matchingOption) {\n        this.selectedOption = matchingOption;\n        this.onChange(matchingOption.value);\n      } else {\n        this.selectedOption = null;\n        this.onChange(event?.target?.value);\n      }\n\n      this.onTouched();\n      this.valueChanged.emit(event?.target?.value);\n      this.selectionChanged.emit(this.selectedOption);\n  }\n\n  onFocus(): void {\n    this.filterOptions();\n  }\n}\n","  <label *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" class=\"field-lable\">{{field()?.label}}<span style=\"color: red;\" *ngIf=\"field() && field()?.validators?.isRequired\">*</span></label>\n  <mat-form-field class=\"w-100 show-arrow\" appearance=\"outline\" *ngIf=\"field() && field()?.isVisible\"  [ngStyle]=\"{\n  '--custom-border-color': field()?.controlStyle?.borderColor ,\n  '--custom-border-width': field()?.controlStyle?.borderWidth ,\n  '--custom-border-radius': field()?.controlStyle?.borderRadius ,\n  '--custom-bg-color': field()?.controlStyle?.background ,\n  '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\n  '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\n  '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\n  '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\n  '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\n  '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\n  '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\n'--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\n'--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\n  }\">\n   @if(reactiveFormControlobject()) {\n     <input\n      matInput\n      type=\"text\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      [matAutocomplete]=\"auto\"\n      (focus)=\"onFocus()\"\n      (blur)=\"onBlur()\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [placeholder]=\"field()?.placeHolder\"\n      (input)=\"onInputChangeForReactiveForms($event)\"\n      [formControl]=\"reactiveFormControlobject()\"\n     />\n   }@else {\n     <input\n      matInput\n      type=\"text\"\n      [name]=\"field()?.fieldName\"\n      [id]=\"field()?.fieldName\"\n      [matAutocomplete]=\"auto\"\n      [ngModel]=\"inputValue\"\n      (ngModelChange)=\"onInputChange($event)\"\n      (focus)=\"onFocus()\"\n      (blur)=\"onBlur($event)\"\n      [disabled]=\"field()?.isDisable\"\n      [required]=\"field()?.validators?.isRequired\"\n      [placeholder]=\"field()?.placeHolder\"\n     />\n   }\n   <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\" [displayWith]=\"displayFn\" (optionSelected)=\"onOptionSelected($event.option.value)\">\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\n      {{ option.label }}\n    </mat-option>\n  </mat-autocomplete>\n    <mat-error>\n    {{ field().validators.requiredMessage }}\n  </mat-error>\n  </mat-form-field>\n  <div class=\"error-message\" *ngIf=\"false\">\n    {{ field()?.validators?.isRequiredMessage }}.\n  </div>\n  <div class=\"error-message\" *ngIf=\"false\">\n    {{ field()?.validators?.patternMessage }}.\n  </div>\n"]}
@@ -1778,7 +1778,15 @@ class AutocompleteComponent {
1778
1778
  this.filteredOptions = (this.field().options || []).filter((option) => option.label.toLowerCase().includes(filterValue));
1779
1779
  }
1780
1780
  displayFn = (option) => {
1781
- return option && typeof option === 'object' ? option.label : option || '';
1781
+ let filteredObjectValue = '';
1782
+ let toFilterString = typeof option === 'object' && option.value ? option.value : option;
1783
+ if (!this.masterService.checkIfValueIsEmpty(this.filteredOptions)) {
1784
+ let filteredObj = this.filteredOptions.filter((opt) => ((opt.value.toLowerCase() === toFilterString.toLowerCase()) || (opt.label.toLowerCase() === toFilterString.toLowerCase())));
1785
+ if (filteredObj.length > 0 && !this.masterService.checkIfValueIsEmpty(filteredObj[0]['label'])) {
1786
+ filteredObjectValue = filteredObj[0]['label'];
1787
+ }
1788
+ }
1789
+ return filteredObjectValue;
1782
1790
  };
1783
1791
  // Utility method to get the current selected value
1784
1792
  getCurrentValue() {