@bnsights/bbsf-controls 1.0.115 → 1.0.116

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/README.md CHANGED
@@ -5,6 +5,10 @@ BBSF Controls package is part of BBSF 3 packages. It has all the form controls t
5
5
  For more info please visit [BBSF Controls documenation](https://bbsfadmin.bnsights.com/controls) or [BBSF documentation](https://bnsightsprojects.visualstudio.com/BBSF%203/_wiki/wikis/BBSF-3.wiki/65/BBSF-Documentation)
6
6
 
7
7
  # Change Log
8
+ ## 1.0.116 / 7-2-2024
9
+ ===================
10
+ * Fix AutoComplate Control Custom Validator Issue
11
+
8
12
  ## 1.0.115 / 6-2-2024
9
13
  ===================
10
14
  * Fix AutoComplate Control Custom Validator Issue
@@ -39,14 +39,31 @@ export class AutocompleteTextBoxComponent {
39
39
  this.newSelectionValidationKey = '';
40
40
  this.markAllAsTouched = false;
41
41
  this.validationRules = [];
42
- this.newSelectionValidation = new CustomValidation();
43
42
  this.validationRulesasync = [];
44
43
  this.dataList = [];
45
44
  this.SelectedValue = "";
46
45
  this.avatarImage = "./src/assets/images/userimg.png";
46
+ this.newSelectionValidation = new CustomValidation();
47
+ this.loadValidator = () => {
48
+ this.newSelectionValidation.functionBody = (control) => {
49
+ if ((control.value && typeof control.value === "string"))
50
+ return { customerError: true };
51
+ return null;
52
+ };
53
+ this.newSelectionValidation.massage = this.utilityService.getResourceValue("NewSelectionValidationKey");
54
+ };
47
55
  this.resetError = () => {
48
56
  this.controlValidationService.removeGlobalError();
49
57
  };
58
+ this.getErrorValidation = (ErrorList) => {
59
+ if (this.markAllAsTouched && this.group.invalid) {
60
+ this.showGlobalError();
61
+ this.markAllAsTouched = false;
62
+ }
63
+ if (!this.options.allowNewSelection && !this.options.customValidation.includes(this.newSelectionValidation))
64
+ this.options.customValidation.push(this.newSelectionValidation);
65
+ return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);
66
+ };
50
67
  // onFocused(e) {
51
68
  // // do something
52
69
  // }
@@ -118,6 +135,13 @@ export class AutocompleteTextBoxComponent {
118
135
  if (this.options.labelKey != null && this.options.labelKey != "")
119
136
  this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);
120
137
  // this.autoCompleteTextBoxControl.setValue(this.options.Value);
138
+ if (this.options.isRequired) {
139
+ this.validationRules.push(Validators.required);
140
+ }
141
+ if (!this.options.allowNewSelection) {
142
+ this.loadValidator();
143
+ this.options.customValidation.push(this.newSelectionValidation);
144
+ }
121
145
  if (this.options.customValidation.length > 0) {
122
146
  let Validations = this.options.customValidation;
123
147
  for (let index = 0; index < Validations.length; index++) {
@@ -125,13 +149,6 @@ export class AutocompleteTextBoxComponent {
125
149
  this.validationRules.push(Validation.functionBody);
126
150
  }
127
151
  }
128
- if (this.options.isRequired) {
129
- this.validationRules.push(Validators.required);
130
- }
131
- if (!this.options.allowNewSelection) {
132
- this.loadValidator();
133
- this.validationRules.push(this.newSelectionValidation);
134
- }
135
152
  this.autoCompleteTextBoxControl.setValidators(this.validationRules);
136
153
  this.autoCompleteTextBoxControl.setAsyncValidators(this.validationRulesasync);
137
154
  if (this.options.isDisabled) {
@@ -171,27 +188,12 @@ export class AutocompleteTextBoxComponent {
171
188
  return of([]);
172
189
  }));
173
190
  }
174
- loadValidator() {
175
- this.newSelectionValidation.functionBody = (control) => {
176
- if ((control.value && typeof control.value === "string" && control.value == this.Search))
177
- return { customerError: true };
178
- return null;
179
- };
180
- this.newSelectionValidation.massage = this.utilityService.getResourceValue("NewSelectionValidationKey");
181
- }
182
191
  ngAfterViewInit() {
183
192
  this.controlUtility.setAttributeForControl(this.options);
184
193
  }
185
194
  showGlobalError() {
186
195
  this.controlUtility.showGlobalError();
187
196
  }
188
- getErrorValidation(ErrorList) {
189
- if (this.markAllAsTouched && this.group.invalid) {
190
- this.showGlobalError();
191
- this.markAllAsTouched = false;
192
- }
193
- return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);
194
- }
195
197
  copyInputMessage(inputElement) {
196
198
  this.controlUtility.CopyInputMessage(inputElement);
197
199
  }
@@ -210,7 +212,7 @@ export class AutocompleteTextBoxComponent {
210
212
  }
211
213
  else {
212
214
  if (this.autoCompleteTextBoxControl.value == item.value) {
213
- this.autoCompleteTextBoxControl.setErrors({ NewSelectionValidationKey: this.newSelectionValidationKey });
215
+ this.autoCompleteTextBoxControl.setErrors({ errorMassage: this.utilityService.getResourceValue('NewSelectionValidationKey') });
214
216
  this.autoCompleteTextBoxControl.markAsTouched();
215
217
  this.autoCompleteTextBoxControl.invalid;
216
218
  return;
@@ -274,4 +276,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.6", ngImpor
274
276
  }], OnChange: [{
275
277
  type: Output
276
278
  }] } });
277
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AutocompleteTextBox.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, DoCheck, Optional, Output, EventEmitter, Attribute } from '@angular/core';\r\nimport { FormControl, Validators, FormGroup, AbstractControl, ControlContainer, FormGroupDirective, ValidationErrors, ValidatorFn } from '@angular/forms';\r\nimport { ErrorMassageValidation } from '../../Shared/services/validationErrorMassage.service';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport { AutocompleteOptions } from '../../Shared/Models/AutocompleteOptions';\r\nimport { AutocompleteDTO } from '../../Shared/Models/AutocompleteDTO';\r\nimport { noop, Observable, Observer, of } from 'rxjs';\r\nimport { map, switchMap, tap } from 'rxjs/operators';\r\nimport { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\r\nimport { ControlValidationService, RequestHandlerService, RequestOptionsModel, UtilityService } from '@bnsights/bbsf-utilities';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { CustomValidation } from '../../Shared/Models/CustomValidation';\r\n\r\n@Component({\r\n  // tslint:disable-next-line: component-selector\r\n  selector: 'BBSF-AutocompleteTextBox',\r\n  templateUrl: './AutocompleteTextBox.component.html'\r\n})\r\nexport class AutocompleteTextBoxComponent implements OnInit {\r\n\r\n\r\n  static controlContainerstatic = null;\r\n  // tslint:disable-next-line: max-line-length\r\n  constructor(private http: HttpClient, private ErrorHandler: ErrorMassageValidation, private requestHandlerService: RequestHandlerService,\r\n    private controlUtility: ControlUtility, @Optional() private controlContainer:\r\n      ControlContainer, public autoCompleteTextBoxControlHost: FormGroupDirective, private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService, private globalSettings: GlobalSettings) {\r\n    AutocompleteTextBoxComponent.controlContainerstatic = this.controlContainer;\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() name: string;\r\n  @Input() options: AutocompleteOptions;\r\n  @Output() OnChange = new EventEmitter();\r\n  keyword: string = 'value'\r\n  autoCompleteTextBoxControl: AbstractControl;\r\n  Search: string = ''\r\n  Key: string = ''\r\n\r\n  api: string = 'http';\r\n  Value: string = 'value'\r\n  newSelectionValidationKey: string = '';\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  newSelectionValidation:CustomValidation= new CustomValidation();\r\n  validationRulesasync = [];\r\n  dataSource: Observable<any>;\r\n  suggestions$: Observable<any[]>;\r\n  errorMessage: string;\r\n  dataList: any[] = [];\r\n  SelectedValue: string = \"\"\r\n  avatarImage: string = \"./src/assets/images/userimg.png\";\r\n  textDir;\r\n\r\n  ngOnInit() {\r\n    if (this.options.name)\r\n      this.name=this.options.name\r\n    if (this.options.isReadonly && !this.options.value)\r\n      this.options.value = this.utilityService.getResourceValue('NA');\r\n\r\n    if (this.options.forceDirection)\r\n      this.textDir = this.options.forceDirection == 2 ? 'rtl' : 'ltr';\r\n    else\r\n      this.textDir = localStorage.getItem('language') == 'ar' ? 'rtl' : 'ltr';\r\n    this.controlValidationService.isCreatedBefor = false\r\n    this.group.addControl(this.name, new FormControl(''));\r\n    this.autoCompleteTextBoxControl = this.group.controls[this.name]; //  new FormControl('',validationRules);\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != \"\")\r\n      this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);\r\n\r\n    // this.autoCompleteTextBoxControl.setValue(this.options.Value);\r\n\r\n    if (this.options.customValidation.length > 0) {\r\n      let Validations = this.options.customValidation\r\n      for (let index = 0; index < Validations.length; index++) {\r\n        const Validation = Validations[index];\r\n        this.validationRules.push(Validation.functionBody);\r\n      }\r\n    }\r\n\r\n\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    if (!this.options.allowNewSelection) {\r\n      this.loadValidator()\r\n      this.validationRules.push(this.newSelectionValidation);\r\n    }\r\n    this.autoCompleteTextBoxControl.setValidators(this.validationRules);\r\n    this.autoCompleteTextBoxControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.autoCompleteTextBoxControl.disable();\r\n    }\r\n\r\n\r\n    if (this.options.selectedValue != undefined && this.options.selectedValue != null) {\r\n      this.SelectedValue = this.options.selectedValue;\r\n    }\r\n\r\n\r\n    this.autoCompleteTextBoxControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched()\r\n      this.markAllAsTouched = true\r\n    })\r\n\r\n    const httpOptions = {\r\n      headers: new HttpHeaders({\r\n        'Content-Type': 'application/json',\r\n        'Authorization': this.options.validationToken\r\n      }),\r\n    };\r\n\r\n\r\n\r\n\r\n    this.suggestions$ = new Observable((observer: Observer<string>) => {\r\n      observer.next(this.Search);\r\n    }).pipe(\r\n      switchMap((query: string) => {\r\n        if (query) {\r\n          let params = new HttpParams();\r\n          params = params.append(this.options.queryParam, query);\r\n          if (this.options.extraFilterParamName && this.options.extraFilter)\r\n            params = params.append(this.options.extraFilterParamName, (typeof this.options.extraFilter === \"string\") ? this.options.extraFilter : this.options.extraFilter());\r\n          let requestOptionsModel = new RequestOptionsModel()\r\n          requestOptionsModel.disableBlockUI = true;\r\n          requestOptionsModel.disableSuccessNotification = true;\r\n          // using github public api to get users by name\r\n          return this.requestHandlerService.get(this.options.actionURL, params, null, requestOptionsModel)\r\n            .pipe(\r\n              map((data) => data as Attribute[] || []),\r\n              tap(() => noop, err => {\r\n                // in case of http error\r\n                this.errorMessage = err && err.message || 'Something goes wrong';\r\n              })\r\n            );\r\n        }\r\n\r\n        return of([]);\r\n      })\r\n    );\r\n  }\r\n\r\n  loadValidator() {\r\n    this.newSelectionValidation.functionBody = (\r\n      control: AbstractControl\r\n    ): { [key: string]: any } => {\r\n      if ((control.value && typeof control.value === \"string\"&&control.value==this.Search)) return { customerError: true };\r\n      return null;\r\n    };\r\n    this.newSelectionValidation.massage = this.utilityService.getResourceValue(\"NewSelectionValidationKey\");\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options)\r\n  }\r\n  resetError = () => {\r\n    this.controlValidationService.removeGlobalError();\r\n  }\r\n\r\n  showGlobalError() {\r\n    this.controlUtility.showGlobalError()\r\n  }\r\n\r\n\r\n  getErrorValidation(ErrorList) {\r\n\r\n    if (this.markAllAsTouched && this.group.invalid) {\r\n      this.showGlobalError()\r\n      this.markAllAsTouched = false\r\n    }\r\n\r\n    return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement)\r\n  }\r\n\r\n\r\n  selectEvent(item) {\r\n\r\n    if (this.options.allowNewSelection == true) {\r\n      if (typeof (item) == 'object') {\r\n        this.autoCompleteTextBoxControl.setValue(item);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n      }\r\n      else {\r\n        let AutocompleteModel = new AutocompleteDTO();\r\n        AutocompleteModel.value = item;\r\n        this.autoCompleteTextBoxControl.setValue(AutocompleteModel);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n      }\r\n    }\r\n    else {\r\n      if (this.autoCompleteTextBoxControl.value == item.value) {\r\n        this.autoCompleteTextBoxControl.setErrors({ NewSelectionValidationKey: this.newSelectionValidationKey });\r\n        this.autoCompleteTextBoxControl.markAsTouched();\r\n        this.autoCompleteTextBoxControl.invalid;\r\n        return;\r\n      }\r\n      else {\r\n        this.autoCompleteTextBoxControl.setValue(item);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n        let originalValue = this.autoCompleteTextBoxControl.value;\r\n        if (this.options.patchFunction && this.options.patchPath && this.group.get(this.name).valid) {\r\n          this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath)\r\n        }\r\n\r\n      }\r\n    }\r\n\r\n    // move this line here to emit value no matter is from database or not\r\n    this.OnChange.emit(this.autoCompleteTextBoxControl.value)\r\n    //Use this line to enable two way binding.\r\n    this.options.value = this.autoCompleteTextBoxControl.value;\r\n  }\r\n\r\n  async onChangeSearch(search: string) {\r\n    if (this.options.maxLength && search.length > this.options.maxLength) {\r\n      const formControl = this.autoCompleteTextBoxControl;\r\n      formControl.setErrors({ errorMassage: this.utilityService.getResourceValue(\"MaxLenghtValidationKey\") + \" \" + this.options.maxLength });\r\n      formControl.markAsTouched();\r\n      return;\r\n    }\r\n    this.Search = search;\r\n    this.SelectedValue = \"\";\r\n    await this.suggestions$.subscribe((result) => {\r\n      if ((result == null || result.length == 0 || result.length == 0) && this.options.allowNewSelection == true) {\r\n        this.dataList = [\r\n          {\r\n            key: 0,\r\n            value: this.Search\r\n          }\r\n        ]\r\n      }\r\n      else {\r\n        this.dataList = result\r\n      }\r\n    })\r\n  }\r\n\r\n  onInputCleared() {\r\n    this.autoCompleteTextBoxControl.setValue(null);\r\n    this.OnChange.emit(null);\r\n    this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n  }\r\n  // onFocused(e) {\r\n  //   // do something\r\n  // }\r\n\r\n\r\n  // onBlur(Value) {\r\n  //   if (this.options.AllowNewSelection == true) {\r\n\r\n  //     if (typeof (Value) == 'object') {\r\n  //       this.autoCompleteTextBoxControl.setValue(Value);\r\n  //       this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n\r\n  //     }\r\n  //     else {\r\n  //       let AutocompleteModel = new AutocompleteDTO();\r\n  //       AutocompleteModel.value = Value;\r\n  //       let model = new TypeaheadMatch(AutocompleteModel,Value);\r\n  //       this.autoCompleteTextBoxControl.setValue(model);\r\n  //       this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n\r\n  //     }\r\n  //   }\r\n\r\n  //   else {\r\n\r\n  //     if (this.autoCompleteTextBoxControl.value == Value) {\r\n  //       this.autoCompleteTextBoxControl.setErrors({ NewSelectionValidationKey: this.NewSelectionValidationKey });\r\n  //       this.autoCompleteTextBoxControl.markAsTouched();\r\n  //       this.autoCompleteTextBoxControl.invalid;\r\n  //       return;\r\n  //     }\r\n  //   }\r\n  //  }\r\n\r\n\r\n  // handleResultSelected(result) {\r\n\r\n  //   this.autoCompleteTextBoxControl.setValue(result);\r\n  //   this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n  //   this.OnChange.emit(this.autoCompleteTextBoxControl.value)\r\n  //   this.Search = this.autoCompleteTextBoxControl.value.value\r\n\r\n\r\n\r\n  // }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(this.autoCompleteTextBoxControl, this.validationRules, this.options)\r\n  }\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(this.autoCompleteTextBoxControl, this.validationRules, this.options)\r\n  }\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(this.autoCompleteTextBoxControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(this.autoCompleteTextBoxControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.autoCompleteTextBoxControl)\r\n  }\r\n\r\n}\r\n\r\n\r\n","<div class=\"form-group bbsf-control bbsf-autocomplete-textbox\" [formGroup]=\"group\">\r\n  <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n    <!--label-->\r\n    <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n      {{options.labelValue}}\r\n      <!--Asterisk-->\r\n      <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n        class=\"text-danger\">*</span>\r\n    </label>\r\n    <!--Input container-->\r\n    <div class=\"bbsf-input-container\" *ngIf=\"!options.isReadonly\">\r\n      <!--input-->\r\n      <ng-autocomplete class=\"form-control  {{options.extraClasses}}\" *ngIf=\"!options.allowNewSelection\"\r\n        [data]=\"dataList\" [initialValue]=\"SelectedValue\" [searchKeyword]=\"keyword\" placeholder=\"{{options.placeholder}}\"\r\n        (selected)='selectEvent($event)' (inputChanged)='onChangeSearch($event)' historyIdentifier=\"dataList\"\r\n        [itemTemplate]=\"options.customTemplate?options.customTemplate:itemTemplate\" [dir]=\"textDir\"\r\n        formControlName=\"{{name}}\" aria-describedby=\"email-error\" aria-invalid=\"true\"\r\n        [class.is-invalid]=\"autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched\"\r\n        (inputCleared)=\"onInputCleared()\">\r\n      </ng-autocomplete>\r\n\r\n      <ng-autocomplete class=\"form-control {{options.extraClasses}}\" *ngIf=\"options.allowNewSelection\" [data]=\"dataList\"\r\n        [initialValue]=\"SelectedValue\" [searchKeyword]=\"keyword\" placeholder=\"{{options.placeholder}}\"\r\n        (selected)='selectEvent($event)' (inputChanged)='onChangeSearch($event)' historyIdentifier=\"dataList\"\r\n        [itemTemplate]=\"options.customTemplate?options.customTemplate:itemTemplate\" [dir]=\"textDir\"\r\n        (inputCleared)=\"onInputCleared()\" formControlName=\"{{name}}\" aria-describedby=\"email-error\"\r\n        aria-invalid=\"true\"\r\n        [class.is-invalid]=\"autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched\">\r\n      </ng-autocomplete>\r\n\r\n      <ng-template #itemTemplate let-item>\r\n        <img *ngIf=\"options.itemWithImage\" src=\"{{(item.image?item.image:avatarImage)}}\" />\r\n        <a [innerHTML]=\"item.value\"></a>\r\n      </ng-template>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{autoCompleteTextBoxControl.value.value}}</span>\r\n    </div>\r\n  </div>\r\n  <div class=\"subtext-container\" *ngIf=\"!options.isReadonly\">\r\n    <!-- labelDescription-->\r\n    <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n    <!-- requiredText-->\r\n    <div class=\"bbsf-validation\" *ngIf=\"(autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched)\">\r\n      {{getErrorValidation(autoCompleteTextBoxControl.errors|keyvalue)}}\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty)\">\r\n    {{resetError()}} </div>\r\n</div>\r\n"]}
279
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AutocompleteTextBox.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/AutocompleteTextBox/AutocompleteTextBox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, DoCheck, Optional, Output, EventEmitter, Attribute } from '@angular/core';\r\nimport { FormControl, Validators, FormGroup, AbstractControl, ControlContainer, FormGroupDirective, ValidationErrors, ValidatorFn } from '@angular/forms';\r\nimport { ErrorMassageValidation } from '../../Shared/services/validationErrorMassage.service';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport { AutocompleteOptions } from '../../Shared/Models/AutocompleteOptions';\r\nimport { AutocompleteDTO } from '../../Shared/Models/AutocompleteDTO';\r\nimport { noop, Observable, Observer, of } from 'rxjs';\r\nimport { map, switchMap, tap } from 'rxjs/operators';\r\nimport { HttpClient, HttpHeaders, HttpParams } from '@angular/common/http';\r\nimport { ControlValidationService, RequestHandlerService, RequestOptionsModel, UtilityService } from '@bnsights/bbsf-utilities';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { CustomValidation } from '../../Shared/Models/CustomValidation';\r\n\r\n@Component({\r\n  // tslint:disable-next-line: component-selector\r\n  selector: 'BBSF-AutocompleteTextBox',\r\n  templateUrl: './AutocompleteTextBox.component.html'\r\n})\r\nexport class AutocompleteTextBoxComponent implements OnInit {\r\n\r\n\r\n  static controlContainerstatic = null;\r\n  // tslint:disable-next-line: max-line-length\r\n  constructor(private http: HttpClient, private ErrorHandler: ErrorMassageValidation, private requestHandlerService: RequestHandlerService,\r\n    private controlUtility: ControlUtility, @Optional() private controlContainer:\r\n      ControlContainer, public autoCompleteTextBoxControlHost: FormGroupDirective, private utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService, private globalSettings: GlobalSettings) {\r\n    AutocompleteTextBoxComponent.controlContainerstatic = this.controlContainer;\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() name: string;\r\n  @Input() options: AutocompleteOptions;\r\n  @Output() OnChange = new EventEmitter();\r\n  keyword: string = 'value'\r\n  autoCompleteTextBoxControl: AbstractControl;\r\n  Search: string = ''\r\n  Key: string = ''\r\n\r\n  api: string = 'http';\r\n  Value: string = 'value'\r\n  newSelectionValidationKey: string = '';\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  validationRulesasync = [];\r\n  dataSource: Observable<any>;\r\n  suggestions$: Observable<any[]>;\r\n  errorMessage: string;\r\n  dataList: any[] = [];\r\n  SelectedValue: string = \"\"\r\n  avatarImage: string = \"./src/assets/images/userimg.png\";\r\n  textDir;\r\n  newSelectionValidation: CustomValidation = new CustomValidation();\r\n  ngOnInit() {\r\n    if (this.options.name)\r\n      this.name = this.options.name\r\n    if (this.options.isReadonly && !this.options.value)\r\n      this.options.value = this.utilityService.getResourceValue('NA');\r\n\r\n    if (this.options.forceDirection)\r\n      this.textDir = this.options.forceDirection == 2 ? 'rtl' : 'ltr';\r\n    else\r\n      this.textDir = localStorage.getItem('language') == 'ar' ? 'rtl' : 'ltr';\r\n    this.controlValidationService.isCreatedBefor = false\r\n    this.group.addControl(this.name, new FormControl(''));\r\n    this.autoCompleteTextBoxControl = this.group.controls[this.name]; //  new FormControl('',validationRules);\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != \"\")\r\n      this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);\r\n\r\n    // this.autoCompleteTextBoxControl.setValue(this.options.Value);\r\n\r\n\r\n\r\n\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    if (!this.options.allowNewSelection) {\r\n      this.loadValidator();\r\n      this.options.customValidation.push(this.newSelectionValidation)\r\n    }\r\n\r\n    if (this.options.customValidation.length > 0) {\r\n      let Validations = this.options.customValidation\r\n      for (let index = 0; index < Validations.length; index++) {\r\n        const Validation = Validations[index];\r\n        this.validationRules.push(Validation.functionBody);\r\n      }\r\n    }\r\n    this.autoCompleteTextBoxControl.setValidators(this.validationRules);\r\n    this.autoCompleteTextBoxControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.autoCompleteTextBoxControl.disable();\r\n    }\r\n\r\n    if (this.options.selectedValue != undefined && this.options.selectedValue != null) {\r\n      this.SelectedValue = this.options.selectedValue;\r\n    }\r\n\r\n    this.autoCompleteTextBoxControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched()\r\n      this.markAllAsTouched = true\r\n    })\r\n\r\n    const httpOptions = {\r\n      headers: new HttpHeaders({\r\n        'Content-Type': 'application/json',\r\n        'Authorization': this.options.validationToken\r\n      }),\r\n    };\r\n\r\n\r\n\r\n\r\n    this.suggestions$ = new Observable((observer: Observer<string>) => {\r\n      observer.next(this.Search);\r\n    }).pipe(\r\n      switchMap((query: string) => {\r\n        if (query) {\r\n          let params = new HttpParams();\r\n          params = params.append(this.options.queryParam, query);\r\n          if (this.options.extraFilterParamName && this.options.extraFilter)\r\n            params = params.append(this.options.extraFilterParamName, (typeof this.options.extraFilter === \"string\") ? this.options.extraFilter : this.options.extraFilter());\r\n          let requestOptionsModel = new RequestOptionsModel()\r\n          requestOptionsModel.disableBlockUI = true;\r\n          requestOptionsModel.disableSuccessNotification = true;\r\n          // using github public api to get users by name\r\n          return this.requestHandlerService.get(this.options.actionURL, params, null, requestOptionsModel)\r\n            .pipe(\r\n              map((data) => data as Attribute[] || []),\r\n              tap(() => noop, err => {\r\n                // in case of http error\r\n                this.errorMessage = err && err.message || 'Something goes wrong';\r\n              })\r\n            );\r\n        }\r\n\r\n        return of([]);\r\n      })\r\n    );\r\n  }\r\n\r\n  loadValidator = () => {\r\n    this.newSelectionValidation.functionBody = (control) => {\r\n      if ((control.value && typeof control.value === \"string\"))\r\n        return { customerError: true };\r\n      return null;\r\n    };\r\n    this.newSelectionValidation.massage = this.utilityService.getResourceValue(\"NewSelectionValidationKey\");\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options)\r\n  }\r\n  resetError = () => {\r\n    this.controlValidationService.removeGlobalError();\r\n  }\r\n\r\n  showGlobalError() {\r\n    this.controlUtility.showGlobalError()\r\n  }\r\n\r\n\r\n  getErrorValidation = (ErrorList) => {\r\n\r\n    if (this.markAllAsTouched && this.group.invalid) {\r\n      this.showGlobalError()\r\n      this.markAllAsTouched = false\r\n    }\r\n    if (!this.options.allowNewSelection && !this.options.customValidation.includes(this.newSelectionValidation))\r\n      this.options.customValidation.push(this.newSelectionValidation)\r\n    return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement)\r\n  }\r\n\r\n\r\n  selectEvent(item) {\r\n\r\n    if (this.options.allowNewSelection == true) {\r\n      if (typeof (item) == 'object') {\r\n        this.autoCompleteTextBoxControl.setValue(item);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n      }\r\n      else {\r\n        let AutocompleteModel = new AutocompleteDTO();\r\n        AutocompleteModel.value = item;\r\n        this.autoCompleteTextBoxControl.setValue(AutocompleteModel);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n      }\r\n    }\r\n    else {\r\n      if (this.autoCompleteTextBoxControl.value == item.value) {\r\n        this.autoCompleteTextBoxControl.setErrors({ errorMassage: this.utilityService.getResourceValue('NewSelectionValidationKey') });\r\n        this.autoCompleteTextBoxControl.markAsTouched();\r\n        this.autoCompleteTextBoxControl.invalid;\r\n        return;\r\n      }\r\n      else {\r\n        this.autoCompleteTextBoxControl.setValue(item);\r\n        this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n        let originalValue = this.autoCompleteTextBoxControl.value;\r\n        if (this.options.patchFunction && this.options.patchPath && this.group.get(this.name).valid) {\r\n          this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath)\r\n        }\r\n\r\n      }\r\n    }\r\n\r\n    // move this line here to emit value no matter is from database or not\r\n    this.OnChange.emit(this.autoCompleteTextBoxControl.value)\r\n    //Use this line to enable two way binding.\r\n    this.options.value = this.autoCompleteTextBoxControl.value;\r\n  }\r\n\r\n  async onChangeSearch(search: string) {\r\n    if (this.options.maxLength && search.length > this.options.maxLength) {\r\n      const formControl = this.autoCompleteTextBoxControl;\r\n      formControl.setErrors({ errorMassage: this.utilityService.getResourceValue(\"MaxLenghtValidationKey\") + \" \" + this.options.maxLength });\r\n      formControl.markAsTouched();\r\n      return;\r\n    }\r\n    this.Search = search;\r\n    this.SelectedValue = \"\";\r\n    await this.suggestions$.subscribe((result) => {\r\n      if ((result == null || result.length == 0 || result.length == 0) && this.options.allowNewSelection == true) {\r\n        this.dataList = [\r\n          {\r\n            key: 0,\r\n            value: this.Search\r\n          }\r\n        ]\r\n      }\r\n      else {\r\n        this.dataList = result\r\n      }\r\n    })\r\n  }\r\n\r\n  onInputCleared() {\r\n    this.autoCompleteTextBoxControl.setValue(null);\r\n    this.OnChange.emit(null);\r\n    this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n  }\r\n  // onFocused(e) {\r\n  //   // do something\r\n  // }\r\n\r\n\r\n  // onBlur(Value) {\r\n  //   if (this.options.AllowNewSelection == true) {\r\n\r\n  //     if (typeof (Value) == 'object') {\r\n  //       this.autoCompleteTextBoxControl.setValue(Value);\r\n  //       this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n\r\n  //     }\r\n  //     else {\r\n  //       let AutocompleteModel = new AutocompleteDTO();\r\n  //       AutocompleteModel.value = Value;\r\n  //       let model = new TypeaheadMatch(AutocompleteModel,Value);\r\n  //       this.autoCompleteTextBoxControl.setValue(model);\r\n  //       this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n\r\n  //     }\r\n  //   }\r\n\r\n  //   else {\r\n\r\n  //     if (this.autoCompleteTextBoxControl.value == Value) {\r\n  //       this.autoCompleteTextBoxControl.setErrors({ NewSelectionValidationKey: this.NewSelectionValidationKey });\r\n  //       this.autoCompleteTextBoxControl.markAsTouched();\r\n  //       this.autoCompleteTextBoxControl.invalid;\r\n  //       return;\r\n  //     }\r\n  //   }\r\n  //  }\r\n\r\n\r\n  // handleResultSelected(result) {\r\n\r\n  //   this.autoCompleteTextBoxControl.setValue(result);\r\n  //   this.autoCompleteTextBoxControl.updateValueAndValidity()\r\n  //   this.OnChange.emit(this.autoCompleteTextBoxControl.value)\r\n  //   this.Search = this.autoCompleteTextBoxControl.value.value\r\n\r\n\r\n\r\n  // }\r\n\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(this.autoCompleteTextBoxControl, this.validationRules, this.options)\r\n  }\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(this.autoCompleteTextBoxControl, this.validationRules, this.options)\r\n  }\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(this.autoCompleteTextBoxControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(this.autoCompleteTextBoxControl, this.validationRules, customValidation)\r\n  }\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.autoCompleteTextBoxControl)\r\n  }\r\n\r\n}\r\n\r\n\r\n","<div class=\"form-group bbsf-control bbsf-autocomplete-textbox\" [formGroup]=\"group\">\r\n  <div [ngClass]=\"(options.viewType==1)?'bbsf-vertical':'bbsf-horizontal'\">\r\n    <!--label-->\r\n    <label *ngIf=\"!options.hideLabel\" class=\"bbsf-label {{options.labelExtraClasses}}\">\r\n      {{options.labelValue}}\r\n      <!--Asterisk-->\r\n      <span *ngIf=\"((options.showAsterisk&&options.isRequired)||(options.isRequired))&&!options.isReadonly\"\r\n        class=\"text-danger\">*</span>\r\n    </label>\r\n    <!--Input container-->\r\n    <div class=\"bbsf-input-container\" *ngIf=\"!options.isReadonly\">\r\n      <!--input-->\r\n      <ng-autocomplete class=\"form-control  {{options.extraClasses}}\" *ngIf=\"!options.allowNewSelection\"\r\n        [data]=\"dataList\" [initialValue]=\"SelectedValue\" [searchKeyword]=\"keyword\" placeholder=\"{{options.placeholder}}\"\r\n        (selected)='selectEvent($event)' (inputChanged)='onChangeSearch($event)' historyIdentifier=\"dataList\"\r\n        [itemTemplate]=\"options.customTemplate?options.customTemplate:itemTemplate\" [dir]=\"textDir\"\r\n        formControlName=\"{{name}}\" aria-describedby=\"email-error\" aria-invalid=\"true\"\r\n        [class.is-invalid]=\"autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched\"\r\n        (inputCleared)=\"onInputCleared()\">\r\n      </ng-autocomplete>\r\n\r\n      <ng-autocomplete class=\"form-control {{options.extraClasses}}\" *ngIf=\"options.allowNewSelection\" [data]=\"dataList\"\r\n        [initialValue]=\"SelectedValue\" [searchKeyword]=\"keyword\" placeholder=\"{{options.placeholder}}\"\r\n        (selected)='selectEvent($event)' (inputChanged)='onChangeSearch($event)' historyIdentifier=\"dataList\"\r\n        [itemTemplate]=\"options.customTemplate?options.customTemplate:itemTemplate\" [dir]=\"textDir\"\r\n        (inputCleared)=\"onInputCleared()\" formControlName=\"{{name}}\" aria-describedby=\"email-error\"\r\n        aria-invalid=\"true\"\r\n        [class.is-invalid]=\"autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched\">\r\n      </ng-autocomplete>\r\n\r\n      <ng-template #itemTemplate let-item>\r\n        <img *ngIf=\"options.itemWithImage\" src=\"{{(item.image?item.image:avatarImage)}}\" />\r\n        <a [innerHTML]=\"item.value\"></a>\r\n      </ng-template>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\"><span class=\"readonly-view\">{{autoCompleteTextBoxControl.value.value}}</span>\r\n    </div>\r\n  </div>\r\n  <div class=\"subtext-container\" *ngIf=\"!options.isReadonly\">\r\n    <!-- labelDescription-->\r\n    <div class=\"bbsf-control-desc\" *ngIf=\"options.labelDescription!=null\">{{options.labelDescription}}</div>\r\n    <!-- requiredText-->\r\n    <div class=\"bbsf-validation\" *ngIf=\"(autoCompleteTextBoxControl.invalid && autoCompleteTextBoxControl.touched)\">\r\n      {{getErrorValidation(autoCompleteTextBoxControl.errors|keyvalue)}}\r\n    </div>\r\n  </div>\r\n  <div *ngIf=\"(group.valid&&group.dirty&&group.touched )||(group.untouched&&group.invalid&&group.dirty)\">\r\n    {{resetError()}} </div>\r\n</div>\r\n"]}
@@ -922,14 +922,31 @@ class AutocompleteTextBoxComponent {
922
922
  this.newSelectionValidationKey = '';
923
923
  this.markAllAsTouched = false;
924
924
  this.validationRules = [];
925
- this.newSelectionValidation = new CustomValidation();
926
925
  this.validationRulesasync = [];
927
926
  this.dataList = [];
928
927
  this.SelectedValue = "";
929
928
  this.avatarImage = "./src/assets/images/userimg.png";
929
+ this.newSelectionValidation = new CustomValidation();
930
+ this.loadValidator = () => {
931
+ this.newSelectionValidation.functionBody = (control) => {
932
+ if ((control.value && typeof control.value === "string"))
933
+ return { customerError: true };
934
+ return null;
935
+ };
936
+ this.newSelectionValidation.massage = this.utilityService.getResourceValue("NewSelectionValidationKey");
937
+ };
930
938
  this.resetError = () => {
931
939
  this.controlValidationService.removeGlobalError();
932
940
  };
941
+ this.getErrorValidation = (ErrorList) => {
942
+ if (this.markAllAsTouched && this.group.invalid) {
943
+ this.showGlobalError();
944
+ this.markAllAsTouched = false;
945
+ }
946
+ if (!this.options.allowNewSelection && !this.options.customValidation.includes(this.newSelectionValidation))
947
+ this.options.customValidation.push(this.newSelectionValidation);
948
+ return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);
949
+ };
933
950
  // onFocused(e) {
934
951
  // // do something
935
952
  // }
@@ -1001,6 +1018,13 @@ class AutocompleteTextBoxComponent {
1001
1018
  if (this.options.labelKey != null && this.options.labelKey != "")
1002
1019
  this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);
1003
1020
  // this.autoCompleteTextBoxControl.setValue(this.options.Value);
1021
+ if (this.options.isRequired) {
1022
+ this.validationRules.push(Validators.required);
1023
+ }
1024
+ if (!this.options.allowNewSelection) {
1025
+ this.loadValidator();
1026
+ this.options.customValidation.push(this.newSelectionValidation);
1027
+ }
1004
1028
  if (this.options.customValidation.length > 0) {
1005
1029
  let Validations = this.options.customValidation;
1006
1030
  for (let index = 0; index < Validations.length; index++) {
@@ -1008,13 +1032,6 @@ class AutocompleteTextBoxComponent {
1008
1032
  this.validationRules.push(Validation.functionBody);
1009
1033
  }
1010
1034
  }
1011
- if (this.options.isRequired) {
1012
- this.validationRules.push(Validators.required);
1013
- }
1014
- if (!this.options.allowNewSelection) {
1015
- this.loadValidator();
1016
- this.validationRules.push(this.newSelectionValidation);
1017
- }
1018
1035
  this.autoCompleteTextBoxControl.setValidators(this.validationRules);
1019
1036
  this.autoCompleteTextBoxControl.setAsyncValidators(this.validationRulesasync);
1020
1037
  if (this.options.isDisabled) {
@@ -1054,27 +1071,12 @@ class AutocompleteTextBoxComponent {
1054
1071
  return of([]);
1055
1072
  }));
1056
1073
  }
1057
- loadValidator() {
1058
- this.newSelectionValidation.functionBody = (control) => {
1059
- if ((control.value && typeof control.value === "string" && control.value == this.Search))
1060
- return { customerError: true };
1061
- return null;
1062
- };
1063
- this.newSelectionValidation.massage = this.utilityService.getResourceValue("NewSelectionValidationKey");
1064
- }
1065
1074
  ngAfterViewInit() {
1066
1075
  this.controlUtility.setAttributeForControl(this.options);
1067
1076
  }
1068
1077
  showGlobalError() {
1069
1078
  this.controlUtility.showGlobalError();
1070
1079
  }
1071
- getErrorValidation(ErrorList) {
1072
- if (this.markAllAsTouched && this.group.invalid) {
1073
- this.showGlobalError();
1074
- this.markAllAsTouched = false;
1075
- }
1076
- return this.controlUtility.getErrorValidationMassage(ErrorList, this.group, this.options);
1077
- }
1078
1080
  copyInputMessage(inputElement) {
1079
1081
  this.controlUtility.CopyInputMessage(inputElement);
1080
1082
  }
@@ -1093,7 +1095,7 @@ class AutocompleteTextBoxComponent {
1093
1095
  }
1094
1096
  else {
1095
1097
  if (this.autoCompleteTextBoxControl.value == item.value) {
1096
- this.autoCompleteTextBoxControl.setErrors({ NewSelectionValidationKey: this.newSelectionValidationKey });
1098
+ this.autoCompleteTextBoxControl.setErrors({ errorMassage: this.utilityService.getResourceValue('NewSelectionValidationKey') });
1097
1099
  this.autoCompleteTextBoxControl.markAsTouched();
1098
1100
  this.autoCompleteTextBoxControl.invalid;
1099
1101
  return;