@bnsights/bbsf-controls 1.0.171 → 1.0.172

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.
@@ -225,6 +225,7 @@ export class TextboxComponent {
225
225
  this.englishLetterOnly = this.utilityService.getResourceValue('EnglishLetterOnly');
226
226
  }
227
227
  onTextChange() {
228
+ this.options.displayValue = null;
228
229
  if (this.options.type == InputType.Number)
229
230
  if (!this.textBoxFormControl.value) {
230
231
  this.textBoxFormControl.setErrors({ integerNumberValidationKey: '' });
@@ -279,6 +280,7 @@ export class TextboxComponent {
279
280
  }
280
281
  }
281
282
  this.onChange.emit(this.textBoxFormControl.value);
283
+ this.options.displayValue = this.textBoxFormControl.value;
282
284
  }
283
285
  onFocus(isFocus) {
284
286
  this.isShowWordCount = isFocus;
@@ -311,4 +313,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
311
313
  }], onBlur: [{
312
314
  type: Output
313
315
  }] } });
314
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextBox.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/TextBox/TextBox.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/TextBox/TextBox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport {\r\n  FormControl,\r\n  Validators,\r\n  FormGroup,\r\n  AbstractControl,\r\n  ControlContainer,\r\n  FormGroupDirective,\r\n} from '@angular/forms';\r\nimport { TextBoxOptions } from '../../Shared/Models/TextBoxOptions';\r\nimport { InputType } from '../../Shared/Enums/InputType';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport {\r\n  ControlValidationService,\r\n  UtilityService,\r\n} from '@bnsights/bbsf-utilities';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { LanguageValidation } from '../../Shared/Enums/LanguageValidation';\r\n\r\n@Component({\r\n  selector: 'BBSF-TextBox',\r\n  templateUrl: './TextBox.component.html',\r\n})\r\nexport class TextboxComponent implements OnInit {\r\n  static controlContainerstatic = null;\r\n  // tslint:disable-next-line: max-line-length\r\n  constructor(\r\n    private controlUtility: ControlUtility,\r\n    @Optional() private controlContainer: ControlContainer,\r\n    public textControlHost: FormGroupDirective,\r\n    public utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService,\r\n    private globalSettings: GlobalSettings\r\n  ) {\r\n    TextboxComponent.controlContainerstatic = this.controlContainer;\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() options: TextBoxOptions;\r\n  @Output() onChange = new EventEmitter();\r\n  @Output() onBlur = new EventEmitter();\r\n\r\n  public inputType = InputType;\r\n  textBoxFormControl: AbstractControl;\r\n  maskPattern: string = '';\r\n  wordCount: number = 0;\r\n  wordCountArray: number = 0;\r\n  emailValidationKey: string;\r\n  uRLValidationKey: string;\r\n  passwordComplexityHasNumber: string;\r\n  arabicLetterOnly: string;\r\n  englishLetterOnly: string;\r\n  passwordComplexityHasCapitalLetter: string;\r\n  passwordComplexityHasSmallLetter: string;\r\n  passwordComplexityHasSpecialLetter: string;\r\n  maxWordCountValidationKey: string;\r\n  isShowWordCount: boolean = false;\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  validationRulesasync = [];\r\n  //For Show warning message of max length limit\r\n  currentCharsCount: number = 0;\r\n  showCharsLimitMsg: boolean = false;\r\n  hasCharsLimitValidationError: boolean = false;\r\n  charsLimitMsgClass: string;\r\n  minCharsLimit: number = -1; //To disable chars limit feature by default\r\n  maxLimitWarningMsg: string = '';\r\n  textDir;\r\n  ngOnInit() {\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\r\n    this.controlValidationService.isCreatedBefor = false;\r\n\r\n    if (!this.options.maxLength)\r\n      this.options.maxLength = this.globalSettings.maxLengthTextBox;\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.maskPattern != null && this.options.maskPattern != '') {\r\n      this.maskPattern = this.options.maskPattern;\r\n      this.options.placeholder = this.maskPattern;\r\n    }\r\n    this.group.addControl(this.options.name, new FormControl(''));\r\n    this.textBoxFormControl = this.group.controls[this.options.name]; //  new FormControl('',validationRules);\r\n    this.textBoxFormControl.setValue(this.options.value);\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != '')\r\n      this.options.labelValue = this.utilityService.getResourceValue(\r\n        this.options.labelKey\r\n      );\r\n\r\n    this.getCustomErrorsMassages();\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    switch (this.options.type) {\r\n      case InputType.Email:\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              /^(([^<>()[\\]\\\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/,\r\n              { EmailValidationKey: this.emailValidationKey }\r\n            ),\r\n          ])\r\n        );\r\n        break;\r\n\r\n      case InputType.URL:\r\n        const pattern = /^(?:http(s)?:\\/\\/)?[\\w.-]+(?:\\.[\\w\\.-]+)+[\\w\\-\\._~:/?#[\\]!\\$&'\\(\\)\\*\\+,;=.]+$/;\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              pattern,\r\n              { URLValidationKey: this.uRLValidationKey }\r\n            ),\r\n          ])\r\n        );\r\n        break;\r\n      case InputType.EID:\r\n        this.maskPattern = '000-0000-0000000-0';\r\n        this.options.placeholder = this.maskPattern;\r\n\r\n        break;\r\n\r\n      case InputType.Number:\r\n        if (this.options.customValidation.length == 0) {\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(/^[0-9]*$/, {\r\n                integerNumberValidationKey: '',\r\n              }),\r\n            ])\r\n          );\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(\r\n                /^[+]?([.]\\d+|\\d+[.]?\\d*)$/,\r\n                { positiveNumberValidationKey: '' }\r\n              ),\r\n            ])\r\n          );\r\n        }\r\n        if (this.options.numberRange != null) {\r\n          this.validationRules.push(\r\n            Validators.min(this.options.numberRange.from)\r\n          );\r\n          this.validationRules.push(\r\n            Validators.max(this.options.numberRange.to)\r\n          );\r\n        }\r\n        break;\r\n      case InputType.Password:\r\n        if (!this.options.removeDefaultPasswordValidation) {\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(/\\d/, {\r\n                passwordComplexityHasNumber: this.passwordComplexityHasNumber,\r\n              }),\r\n              this.controlUtility.patternValidator(/[A-Z]/, {\r\n                passwordComplexityHasCapitalLetter:\r\n                  this.passwordComplexityHasCapitalLetter,\r\n              }),\r\n              this.controlUtility.patternValidator(/[a-z]/, {\r\n                passwordComplexityHasSmallLetter:\r\n                  this.passwordComplexityHasSmallLetter,\r\n              }),\r\n              this.controlUtility.patternValidator(/[!@#$%^&*(),.?\":{}|<>]/, {\r\n                passwordComplexityHasSpecialLetter:\r\n                  this.passwordComplexityHasSpecialLetter,\r\n              }),\r\n              Validators.minLength(8),\r\n            ])\r\n          );\r\n        }\r\n        break;\r\n    }\r\n    if (this.options.languageValidation) {\r\n      if (this.options.languageValidation == LanguageValidation.Arabic) {\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(/^[^A-Za-z]*$/, {\r\n              ArabicLetterOnly: this.arabicLetterOnly,\r\n            }),\r\n          ])\r\n        );\r\n      } else if (\r\n        this.options.languageValidation == LanguageValidation.English\r\n      ) {\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              /^[~`!@#$%^&*()‘’“”_+=[\\]\\\\{}|;':\",.\\/<>?a-zA-Z0-9- ]*$/,\r\n              { EnglishLetterOnly: this.englishLetterOnly }\r\n            ),\r\n          ])\r\n        );\r\n      }\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    if (this.options.minLength > 0) {\r\n      this.validationRules.push(Validators.minLength(this.options.minLength));\r\n    }\r\n    if (this.options.maxLength > 0) {\r\n      this.validationRules.push(Validators.maxLength(this.options.maxLength));\r\n\r\n      if (!this.options.maxLengthWarningLimit)\r\n        this.options.maxLengthWarningLimit =\r\n          this.globalSettings.maxLengthWarningLimit;\r\n\r\n      this.minCharsLimit =\r\n        this.options.maxLength - this.options.maxLengthWarningLimit;\r\n    }\r\n    this.textBoxFormControl.setValidators(this.validationRules);\r\n    this.textBoxFormControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.textBoxFormControl.disable();\r\n    }\r\n\r\n    this.textControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched();\r\n      this.markAllAsTouched = true;\r\n    });\r\n\r\n    this.options.validationRules = this.validationRules;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options);\r\n  }\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  getErrorValidation(ErrorList) {\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  getInputType(type: number) {\r\n    return this.controlUtility.getInputType(type);\r\n  }\r\n\r\n  trimControlValue() {\r\n    let originalValue = this.controlUtility.trimControlValue(\r\n      this.textBoxFormControl.value\r\n    );\r\n    this.textBoxFormControl.patchValue(originalValue);\r\n    if (\r\n      this.options.patchFunction &&\r\n      this.options.patchPath &&\r\n      this.textBoxFormControl.valid\r\n    ) {\r\n      this.controlUtility.patchControlValue(\r\n        originalValue,\r\n        this.options.patchFunction,\r\n        this.options.patchPath\r\n      );\r\n    }\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement);\r\n  }\r\n\r\n  getCustomErrorsMassages() {\r\n    this.emailValidationKey = this.utilityService.getResourceValue('EmailValidationKey');\r\n    this.uRLValidationKey = this.utilityService.getResourceValue('urlValidationError');\r\n    this.passwordComplexityHasCapitalLetter = this.utilityService.getResourceValue('PasswordComplexityHasCapitalLetter');\r\n    this.passwordComplexityHasNumber = this.utilityService.getResourceValue('PasswordComplexityHasNumber');\r\n    this.passwordComplexityHasSmallLetter = this.utilityService.getResourceValue('PasswordComplexityHasSmallLetter');\r\n    this.passwordComplexityHasSpecialLetter = this.utilityService.getResourceValue('PasswordComplexityHasSpecialLetter');\r\n    this.maxWordCountValidationKey = this.utilityService.getResourceValue('MaxWordCountValidationKey');\r\n    this.arabicLetterOnly = this.utilityService.getResourceValue('VAL_ArabicIsRequiredAndOnly50CharactersEnglish');\r\n    this.englishLetterOnly = this.utilityService.getResourceValue('EnglishLetterOnly');\r\n  }\r\n\r\n  onTextChange() {\r\n    if (this.options.type == InputType.Number)\r\n      if (!this.textBoxFormControl.value) {\r\n        this.textBoxFormControl.setErrors({ integerNumberValidationKey: '' });\r\n        return;\r\n      }\r\n\r\n    if (this.textBoxFormControl.value == '') {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\r\n      this.showCharsLimitMsg = false;\r\n      this.hasCharsLimitValidationError = false;\r\n    } else {\r\n      this.wordCountArray = this.textBoxFormControl.value?.split(' ').length;\r\n      if (this.wordCountArray > 0) {\r\n        if (this.wordCountArray > this.options.maxWordCount) {\r\n          this.wordCount = this.options.maxWordCount;\r\n          this.textBoxFormControl.setErrors({\r\n            MaxWordCountValidationKey: this.options.maxWordCount,\r\n          });\r\n          this.textBoxFormControl.markAsTouched();\r\n          this.textBoxFormControl.invalid;\r\n        } else {\r\n          this.wordCount = this.wordCountArray;\r\n        }\r\n      }\r\n\r\n      //Check for max_length limit count\r\n      //MaxLength should be greater than or equals chars limit so that minCharsLimit would be >= 0\r\n      if (this.textBoxFormControl.value && this.options.maxLength && this.minCharsLimit >= 0) {\r\n        this.currentCharsCount = this.textBoxFormControl.value.length;\r\n        if (this.currentCharsCount > this.minCharsLimit) {\r\n          this.showCharsLimitMsg = true;\r\n          this.hasCharsLimitValidationError = true;\r\n          if (this.currentCharsCount == this.options.maxLength)\r\n            this.charsLimitMsgClass = 'danger';\r\n          else this.charsLimitMsgClass = 'warning';\r\n        } else {\r\n          this.showCharsLimitMsg = false;\r\n          this.hasCharsLimitValidationError = false;\r\n        }\r\n\r\n        let max: number = this.options.maxLength;\r\n        let current: number = this.currentCharsCount;\r\n        let msg: string = this.utilityService.getResourceValue(\"MaxLengthLimitWarning\");\r\n\r\n        // Replace placeholders with actual values\r\n        this.maxLimitWarningMsg = msg.replace(\"${max}\", max.toString()).replace(\"${current}\", current.toString());\r\n      }\r\n      else {\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n      }\r\n    }\r\n\r\n    this.onChange.emit(this.textBoxFormControl.value);\r\n  }\r\n\r\n  onFocus(isFocus: boolean) {\r\n    this.isShowWordCount = isFocus;\r\n\r\n    //onFocus\r\n    if (isFocus) {\r\n      if (this.hasCharsLimitValidationError)\r\n        //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    } //onFocusOut\r\n    else this.showCharsLimitMsg = false;\r\n  }\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.textBoxFormControl);\r\n  };\r\n\r\n  onTextBlur() {\r\n    this.onBlur.emit(this.textBoxFormControl.value);\r\n  }\r\n}\r\n","<div class=\"form-group bbsf-control bbsf-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\" class=\"text-danger\">*</span>\r\n    </label>\r\n    <!--MaskPattern-->\r\n    <div *ngIf=\"maskPattern!=null&&maskPattern!=''&&!options.isReadonly\" class=\"bbsf-input-container\"\r\n      [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n      <!--Icon-->\r\n      <div *ngIf=\"options.icon!=null\" class=\"svg svg-icon-grey bbsf-icon\" [ngClass]=\"(options.iconPosition==1)?'bbsf-left-icon':'bbsf-right-icon'\">\r\n        <span [inlineSVG]=\"options.icon\"></span>\r\n      </div>\r\n      <!--input-->\r\n      <input class=\"form-control {{options.extraClasses}}\" [mask]=\"maskPattern\" placeHolderCharacter=\" \" [showMaskTyped]=\"true\" [validation]=\"true\"\r\n        [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\" type=\"{{getInputType(options.type)}}\"\r\n        [(ngModel)]=\"options.value\" [class.is-invalid]=\"textBoxFormControl.invalid && textBoxFormControl.touched\"\r\n        placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\" (change)=\"trimControlValue()\"\r\n        (keyup)=\"onTextChange()\" [readonly]=\"options.isReadonly\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\" #userinput (blur)=\"onTextBlur()\">\r\n      <!--CopyToClipboard-->\r\n      <span class=\"copy-clipboard\" ngbTooltip=\"Copied!\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(userinput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </span>\r\n    </div>\r\n    <!--NoMaskPattern-->\r\n    <div *ngIf=\"maskPattern==null||maskPattern==''&&!options.isReadonly\" class=\"bbsf-input-container\"\r\n      [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n      <!--Icon-->\r\n      <div class=\"svg svg-icon-grey bbsf-icon\" [ngClass]=\"(options.iconPosition==1)?'bbsf-left-icon':'bbsf-right-icon'\" *ngIf=\"options.icon!=null\">\r\n        <span [inlineSVG]=\"options.icon\"></span>\r\n      </div>\r\n      <!--input-->\r\n      <input class=\"form-control {{options.extraClasses}} \" [dir]=\"textDir\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n        maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" aria-describedby=\"email-error\" aria-invalid=\"true\"\r\n        formControlName=\"{{options.name}}\" type=\"{{getInputType(options.type)}}\"\r\n        [class.is-invalid]=\"textBoxFormControl.invalid && textBoxFormControl.touched\" placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\"\r\n        autocomplete=\"{{options.autoComplete}}\" (change)=\"trimControlValue()\" (keyup)=\"onTextChange()\" [(ngModel)]=\"options.value\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\" [readonly]=\"options.isReadonly\" #userinput\r\n        (blur)=\"onTextBlur()\">\r\n      <!--CopyToClipboard-->\r\n      <span class=\"copy-clipboard\" ngbTooltip=\"Copied!\" triggers=\"click:blur\" *ngIf=\"options.enableCopyToClipboard\"\r\n        (click)=\"copyInputMessage(userinput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </span>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\">\r\n      <a *ngIf=\"options.type==inputType.Email\" href=\"mailto: {{options.value}}\">{{options.value}}</a>\r\n      <a *ngIf=\"options.type==inputType.URL\" href=\"{{options.value}}\" target=\"_blank\">{{options.value}}</a>\r\n      <span *ngIf=\"options.type!=inputType.URL&&options.type!=inputType.Email\" class=\"readonly-view\">{{options.value}}</span>\r\n    </div>\r\n  </div>\r\n  <div class=\"subtext-container\">\r\n    <!--wordCount-->\r\n    <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">{{wordCount}}/{{options.maxWordCount}}\r\n      Words</div>\r\n    <!-- CharsLimitMsg-->\r\n    <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n      [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n      {{maxLimitWarningMsg}}\r\n    </div>\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\" [dir]=\"textDir\" *ngIf=\"(textBoxFormControl.invalid && textBoxFormControl.touched)\">\r\n      {{getErrorValidation(textBoxFormControl.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>"]}
316
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"TextBox.component.js","sourceRoot":"","sources":["../../../../../../projects/bbsf-controls/src/lib/controls/TextBox/TextBox.component.ts","../../../../../../projects/bbsf-controls/src/lib/controls/TextBox/TextBox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  Input,\r\n  Optional,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport {\r\n  FormControl,\r\n  Validators,\r\n  FormGroup,\r\n  AbstractControl,\r\n  ControlContainer,\r\n  FormGroupDirective,\r\n} from '@angular/forms';\r\nimport { TextBoxOptions } from '../../Shared/Models/TextBoxOptions';\r\nimport { InputType } from '../../Shared/Enums/InputType';\r\nimport { ControlUtility } from '../../Shared/services/ControlUtility';\r\nimport {\r\n  ControlValidationService,\r\n  UtilityService,\r\n} from '@bnsights/bbsf-utilities';\r\nimport { GlobalSettings } from '../../Shared/services/GlobalSettings.service';\r\nimport { LanguageValidation } from '../../Shared/Enums/LanguageValidation';\r\n\r\n@Component({\r\n  selector: 'BBSF-TextBox',\r\n  templateUrl: './TextBox.component.html',\r\n})\r\nexport class TextboxComponent implements OnInit {\r\n  static controlContainerstatic = null;\r\n  // tslint:disable-next-line: max-line-length\r\n  constructor(\r\n    private controlUtility: ControlUtility,\r\n    @Optional() private controlContainer: ControlContainer,\r\n    public textControlHost: FormGroupDirective,\r\n    public utilityService: UtilityService,\r\n    private controlValidationService: ControlValidationService,\r\n    private globalSettings: GlobalSettings\r\n  ) {\r\n    TextboxComponent.controlContainerstatic = this.controlContainer;\r\n  }\r\n  @Input() group: FormGroup;\r\n  @Input() options: TextBoxOptions;\r\n  @Output() onChange = new EventEmitter();\r\n  @Output() onBlur = new EventEmitter();\r\n\r\n  public inputType = InputType;\r\n  textBoxFormControl: AbstractControl;\r\n  maskPattern: string = '';\r\n  wordCount: number = 0;\r\n  wordCountArray: number = 0;\r\n  emailValidationKey: string;\r\n  uRLValidationKey: string;\r\n  passwordComplexityHasNumber: string;\r\n  arabicLetterOnly: string;\r\n  englishLetterOnly: string;\r\n  passwordComplexityHasCapitalLetter: string;\r\n  passwordComplexityHasSmallLetter: string;\r\n  passwordComplexityHasSpecialLetter: string;\r\n  maxWordCountValidationKey: string;\r\n  isShowWordCount: boolean = false;\r\n  markAllAsTouched: boolean = false;\r\n  validationRules = [];\r\n  validationRulesasync = [];\r\n  //For Show warning message of max length limit\r\n  currentCharsCount: number = 0;\r\n  showCharsLimitMsg: boolean = false;\r\n  hasCharsLimitValidationError: boolean = false;\r\n  charsLimitMsgClass: string;\r\n  minCharsLimit: number = -1; //To disable chars limit feature by default\r\n  maxLimitWarningMsg: string = '';\r\n  textDir;\r\n  ngOnInit() {\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\r\n    this.controlValidationService.isCreatedBefor = false;\r\n\r\n    if (!this.options.maxLength)\r\n      this.options.maxLength = this.globalSettings.maxLengthTextBox;\r\n\r\n    if (!this.options.viewType)\r\n      this.options.viewType = this.globalSettings.viewType;\r\n\r\n    if (this.options.maskPattern != null && this.options.maskPattern != '') {\r\n      this.maskPattern = this.options.maskPattern;\r\n      this.options.placeholder = this.maskPattern;\r\n    }\r\n    this.group.addControl(this.options.name, new FormControl(''));\r\n    this.textBoxFormControl = this.group.controls[this.options.name]; //  new FormControl('',validationRules);\r\n    this.textBoxFormControl.setValue(this.options.value);\r\n\r\n    if (this.options.labelKey != null && this.options.labelKey != '')\r\n      this.options.labelValue = this.utilityService.getResourceValue(\r\n        this.options.labelKey\r\n      );\r\n\r\n    this.getCustomErrorsMassages();\r\n    if (this.options.isRequired) {\r\n      this.validationRules.push(Validators.required);\r\n    }\r\n    switch (this.options.type) {\r\n      case InputType.Email:\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              /^(([^<>()[\\]\\\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/,\r\n              { EmailValidationKey: this.emailValidationKey }\r\n            ),\r\n          ])\r\n        );\r\n        break;\r\n\r\n      case InputType.URL:\r\n        const pattern = /^(?:http(s)?:\\/\\/)?[\\w.-]+(?:\\.[\\w\\.-]+)+[\\w\\-\\._~:/?#[\\]!\\$&'\\(\\)\\*\\+,;=.]+$/;\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              pattern,\r\n              { URLValidationKey: this.uRLValidationKey }\r\n            ),\r\n          ])\r\n        );\r\n        break;\r\n      case InputType.EID:\r\n        this.maskPattern = '000-0000-0000000-0';\r\n        this.options.placeholder = this.maskPattern;\r\n\r\n        break;\r\n\r\n      case InputType.Number:\r\n        if (this.options.customValidation.length == 0) {\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(/^[0-9]*$/, {\r\n                integerNumberValidationKey: '',\r\n              }),\r\n            ])\r\n          );\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(\r\n                /^[+]?([.]\\d+|\\d+[.]?\\d*)$/,\r\n                { positiveNumberValidationKey: '' }\r\n              ),\r\n            ])\r\n          );\r\n        }\r\n        if (this.options.numberRange != null) {\r\n          this.validationRules.push(\r\n            Validators.min(this.options.numberRange.from)\r\n          );\r\n          this.validationRules.push(\r\n            Validators.max(this.options.numberRange.to)\r\n          );\r\n        }\r\n        break;\r\n      case InputType.Password:\r\n        if (!this.options.removeDefaultPasswordValidation) {\r\n          this.validationRules.push(\r\n            Validators.compose([\r\n              this.controlUtility.patternValidator(/\\d/, {\r\n                passwordComplexityHasNumber: this.passwordComplexityHasNumber,\r\n              }),\r\n              this.controlUtility.patternValidator(/[A-Z]/, {\r\n                passwordComplexityHasCapitalLetter:\r\n                  this.passwordComplexityHasCapitalLetter,\r\n              }),\r\n              this.controlUtility.patternValidator(/[a-z]/, {\r\n                passwordComplexityHasSmallLetter:\r\n                  this.passwordComplexityHasSmallLetter,\r\n              }),\r\n              this.controlUtility.patternValidator(/[!@#$%^&*(),.?\":{}|<>]/, {\r\n                passwordComplexityHasSpecialLetter:\r\n                  this.passwordComplexityHasSpecialLetter,\r\n              }),\r\n              Validators.minLength(8),\r\n            ])\r\n          );\r\n        }\r\n        break;\r\n    }\r\n    if (this.options.languageValidation) {\r\n      if (this.options.languageValidation == LanguageValidation.Arabic) {\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(/^[^A-Za-z]*$/, {\r\n              ArabicLetterOnly: this.arabicLetterOnly,\r\n            }),\r\n          ])\r\n        );\r\n      } else if (\r\n        this.options.languageValidation == LanguageValidation.English\r\n      ) {\r\n        this.validationRules.push(\r\n          Validators.compose([\r\n            this.controlUtility.patternValidator(\r\n              /^[~`!@#$%^&*()‘’“”_+=[\\]\\\\{}|;':\",.\\/<>?a-zA-Z0-9- ]*$/,\r\n              { EnglishLetterOnly: this.englishLetterOnly }\r\n            ),\r\n          ])\r\n        );\r\n      }\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    if (this.options.minLength > 0) {\r\n      this.validationRules.push(Validators.minLength(this.options.minLength));\r\n    }\r\n    if (this.options.maxLength > 0) {\r\n      this.validationRules.push(Validators.maxLength(this.options.maxLength));\r\n\r\n      if (!this.options.maxLengthWarningLimit)\r\n        this.options.maxLengthWarningLimit =\r\n          this.globalSettings.maxLengthWarningLimit;\r\n\r\n      this.minCharsLimit =\r\n        this.options.maxLength - this.options.maxLengthWarningLimit;\r\n    }\r\n    this.textBoxFormControl.setValidators(this.validationRules);\r\n    this.textBoxFormControl.setAsyncValidators(this.validationRulesasync);\r\n    if (this.options.isDisabled) {\r\n      this.textBoxFormControl.disable();\r\n    }\r\n\r\n    this.textControlHost.ngSubmit.subscribe((value) => {\r\n      this.group.markAllAsTouched();\r\n      this.markAllAsTouched = true;\r\n    });\r\n\r\n    this.options.validationRules = this.validationRules;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.controlUtility.setAttributeForControl(this.options);\r\n  }\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  getErrorValidation(ErrorList) {\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  getInputType(type: number) {\r\n    return this.controlUtility.getInputType(type);\r\n  }\r\n\r\n  trimControlValue() {\r\n    let originalValue = this.controlUtility.trimControlValue(\r\n      this.textBoxFormControl.value\r\n    );\r\n    this.textBoxFormControl.patchValue(originalValue);\r\n    if (\r\n      this.options.patchFunction &&\r\n      this.options.patchPath &&\r\n      this.textBoxFormControl.valid\r\n    ) {\r\n      this.controlUtility.patchControlValue(\r\n        originalValue,\r\n        this.options.patchFunction,\r\n        this.options.patchPath\r\n      );\r\n    }\r\n  }\r\n\r\n  copyInputMessage(inputElement) {\r\n    this.controlUtility.CopyInputMessage(inputElement);\r\n  }\r\n\r\n  getCustomErrorsMassages() {\r\n    this.emailValidationKey = this.utilityService.getResourceValue('EmailValidationKey');\r\n    this.uRLValidationKey = this.utilityService.getResourceValue('urlValidationError');\r\n    this.passwordComplexityHasCapitalLetter = this.utilityService.getResourceValue('PasswordComplexityHasCapitalLetter');\r\n    this.passwordComplexityHasNumber = this.utilityService.getResourceValue('PasswordComplexityHasNumber');\r\n    this.passwordComplexityHasSmallLetter = this.utilityService.getResourceValue('PasswordComplexityHasSmallLetter');\r\n    this.passwordComplexityHasSpecialLetter = this.utilityService.getResourceValue('PasswordComplexityHasSpecialLetter');\r\n    this.maxWordCountValidationKey = this.utilityService.getResourceValue('MaxWordCountValidationKey');\r\n    this.arabicLetterOnly = this.utilityService.getResourceValue('VAL_ArabicIsRequiredAndOnly50CharactersEnglish');\r\n    this.englishLetterOnly = this.utilityService.getResourceValue('EnglishLetterOnly');\r\n  }\r\n\r\n  onTextChange() {\r\n    this.options.displayValue = null;\r\n    if (this.options.type == InputType.Number)\r\n      if (!this.textBoxFormControl.value) {\r\n        this.textBoxFormControl.setErrors({ integerNumberValidationKey: '' });\r\n        return;\r\n      }\r\n\r\n    if (this.textBoxFormControl.value == '') {\r\n      this.wordCountArray = 0;\r\n      this.wordCount = 0;\r\n      this.showCharsLimitMsg = false;\r\n      this.hasCharsLimitValidationError = false;\r\n    } else {\r\n      this.wordCountArray = this.textBoxFormControl.value?.split(' ').length;\r\n      if (this.wordCountArray > 0) {\r\n        if (this.wordCountArray > this.options.maxWordCount) {\r\n          this.wordCount = this.options.maxWordCount;\r\n          this.textBoxFormControl.setErrors({\r\n            MaxWordCountValidationKey: this.options.maxWordCount,\r\n          });\r\n          this.textBoxFormControl.markAsTouched();\r\n          this.textBoxFormControl.invalid;\r\n        } else {\r\n          this.wordCount = this.wordCountArray;\r\n        }\r\n      }\r\n\r\n      //Check for max_length limit count\r\n      //MaxLength should be greater than or equals chars limit so that minCharsLimit would be >= 0\r\n      if (this.textBoxFormControl.value && this.options.maxLength && this.minCharsLimit >= 0) {\r\n        this.currentCharsCount = this.textBoxFormControl.value.length;\r\n        if (this.currentCharsCount > this.minCharsLimit) {\r\n          this.showCharsLimitMsg = true;\r\n          this.hasCharsLimitValidationError = true;\r\n          if (this.currentCharsCount == this.options.maxLength)\r\n            this.charsLimitMsgClass = 'danger';\r\n          else this.charsLimitMsgClass = 'warning';\r\n        } else {\r\n          this.showCharsLimitMsg = false;\r\n          this.hasCharsLimitValidationError = false;\r\n        }\r\n\r\n        let max: number = this.options.maxLength;\r\n        let current: number = this.currentCharsCount;\r\n        let msg: string = this.utilityService.getResourceValue(\"MaxLengthLimitWarning\");\r\n\r\n        // Replace placeholders with actual values\r\n        this.maxLimitWarningMsg = msg.replace(\"${max}\", max.toString()).replace(\"${current}\", current.toString());\r\n      }\r\n      else {\r\n        this.showCharsLimitMsg = false;\r\n        this.hasCharsLimitValidationError = false;\r\n      }\r\n    }\r\n\r\n    this.onChange.emit(this.textBoxFormControl.value);\r\n    this.options.displayValue = this.textBoxFormControl.value;\r\n  }\r\n\r\n  onFocus(isFocus: boolean) {\r\n    this.isShowWordCount = isFocus;\r\n\r\n    //onFocus\r\n    if (isFocus) {\r\n      if (this.hasCharsLimitValidationError)\r\n        //check if there was previous validation error\r\n        this.showCharsLimitMsg = true;\r\n    } //onFocusOut\r\n    else this.showCharsLimitMsg = false;\r\n  }\r\n  //External Method\r\n  removeRequiredValidation = () => {\r\n    this.controlUtility.removeRequiredValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n  //External Method\r\n  addRequiredValidation = () => {\r\n    this.controlUtility.addRequiredValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      this.options\r\n    );\r\n  };\r\n\r\n  //External Method\r\n  removeCustomValidation = (customValidation) => {\r\n    this.controlUtility.removeCustomValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  addCustomValidation = (customValidation) => {\r\n    this.controlUtility.addCustomValidation(\r\n      this.textBoxFormControl,\r\n      this.validationRules,\r\n      customValidation\r\n    );\r\n  };\r\n  //External Method\r\n  isValid = () => {\r\n    this.controlUtility.isValid(this.textBoxFormControl);\r\n  };\r\n\r\n  onTextBlur() {\r\n    this.onBlur.emit(this.textBoxFormControl.value);\r\n  }\r\n}\r\n","<div class=\"form-group bbsf-control bbsf-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\" class=\"text-danger\">*</span>\r\n    </label>\r\n    <!--MaskPattern-->\r\n    <div *ngIf=\"maskPattern!=null&&maskPattern!=''&&!options.isReadonly\" class=\"bbsf-input-container\"\r\n      [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n      <!--Icon-->\r\n      <div *ngIf=\"options.icon!=null\" class=\"svg svg-icon-grey bbsf-icon\" [ngClass]=\"(options.iconPosition==1)?'bbsf-left-icon':'bbsf-right-icon'\">\r\n        <span [inlineSVG]=\"options.icon\"></span>\r\n      </div>\r\n      <!--input-->\r\n      <input class=\"form-control {{options.extraClasses}}\" [mask]=\"maskPattern\" placeHolderCharacter=\" \" [showMaskTyped]=\"true\" [validation]=\"true\"\r\n        [dir]=\"textDir\" aria-describedby=\"email-error\" aria-invalid=\"true\" formControlName=\"{{options.name}}\" type=\"{{getInputType(options.type)}}\"\r\n        [(ngModel)]=\"options.value\" [class.is-invalid]=\"textBoxFormControl.invalid && textBoxFormControl.touched\"\r\n        placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" autocomplete=\"{{options.autoComplete}}\" (change)=\"trimControlValue()\"\r\n        (keyup)=\"onTextChange()\" [readonly]=\"options.isReadonly\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\" #userinput (blur)=\"onTextBlur()\">\r\n      <!--CopyToClipboard-->\r\n      <span class=\"copy-clipboard\" ngbTooltip=\"Copied!\" *ngIf=\"options.enableCopyToClipboard\" (click)=\"copyInputMessage(userinput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </span>\r\n    </div>\r\n    <!--NoMaskPattern-->\r\n    <div *ngIf=\"maskPattern==null||maskPattern==''&&!options.isReadonly\" class=\"bbsf-input-container\"\r\n      [ngClass]=\"options.enableCopyToClipboard? 'p-40px' : '' \">\r\n      <!--Icon-->\r\n      <div class=\"svg svg-icon-grey bbsf-icon\" [ngClass]=\"(options.iconPosition==1)?'bbsf-left-icon':'bbsf-right-icon'\" *ngIf=\"options.icon!=null\">\r\n        <span [inlineSVG]=\"options.icon\"></span>\r\n      </div>\r\n      <!--input-->\r\n      <input class=\"form-control {{options.extraClasses}} \" [dir]=\"textDir\" (focus)=\"onFocus(true)\" (focusout)=\"onFocus(false)\"\r\n        maxlength=\"{{options.maxLength}}\" minlength=\"{{options.minLength}}\" aria-describedby=\"email-error\" aria-invalid=\"true\"\r\n        formControlName=\"{{options.name}}\" type=\"{{getInputType(options.type)}}\"\r\n        [class.is-invalid]=\"textBoxFormControl.invalid && textBoxFormControl.touched\" placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\"\r\n        autocomplete=\"{{options.autoComplete}}\" (change)=\"trimControlValue()\" (keyup)=\"onTextChange()\" [(ngModel)]=\"options.value\"\r\n        (keydown)=\"wordCountArray>options.maxWordCount&&$event.keyCode !=8?$event.preventDefault():null\" [readonly]=\"options.isReadonly\" #userinput\r\n        (blur)=\"onTextBlur()\">\r\n      <!--CopyToClipboard-->\r\n      <span class=\"copy-clipboard\" ngbTooltip=\"Copied!\" triggers=\"click:blur\" *ngIf=\"options.enableCopyToClipboard\"\r\n        (click)=\"copyInputMessage(userinput)\">\r\n        <i class=\"fas fa-copy\"></i>\r\n      </span>\r\n    </div>\r\n    <!-- readonly -->\r\n    <div *ngIf=\"options.isReadonly\">\r\n      <a *ngIf=\"options.type==inputType.Email\" href=\"mailto: {{options.value}}\">{{options.value}}</a>\r\n      <a *ngIf=\"options.type==inputType.URL\" href=\"{{options.value}}\" target=\"_blank\">{{options.value}}</a>\r\n      <span *ngIf=\"options.type!=inputType.URL&&options.type!=inputType.Email\" class=\"readonly-view\">{{options.value}}</span>\r\n    </div>\r\n  </div>\r\n  <div class=\"subtext-container\">\r\n    <!--wordCount-->\r\n    <div class=\"bbsf-word-count\" *ngIf=\"options.maxWordCount>0&&isShowWordCount\">{{wordCount}}/{{options.maxWordCount}}\r\n      Words</div>\r\n    <!-- CharsLimitMsg-->\r\n    <div class=\"bbsf-character-count\" *ngIf=\"showCharsLimitMsg\"\r\n      [ngClass]=\"{'badge-light-warning': charsLimitMsgClass === 'warning', 'badge-light-danger' : charsLimitMsgClass === 'danger' }\">\r\n      {{maxLimitWarningMsg}}\r\n    </div>\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\" [dir]=\"textDir\" *ngIf=\"(textBoxFormControl.invalid && textBoxFormControl.touched)\">\r\n      {{getErrorValidation(textBoxFormControl.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>"]}
@@ -1085,7 +1085,7 @@ class AutocompleteTextBoxComponent {
1085
1085
  }
1086
1086
  selectEvent(item) {
1087
1087
  if (this.options.allowNewSelection == true) {
1088
- if (typeof (item) == 'object') {
1088
+ if (typeof item == 'object') {
1089
1089
  this.autoCompleteTextBoxControl.setValue(item);
1090
1090
  this.autoCompleteTextBoxControl.updateValueAndValidity();
1091
1091
  }
@@ -1098,7 +1098,9 @@ class AutocompleteTextBoxComponent {
1098
1098
  }
1099
1099
  else {
1100
1100
  if (this.autoCompleteTextBoxControl.value == item.value) {
1101
- this.autoCompleteTextBoxControl.setErrors({ errorMassage: this.utilityService.getResourceValue('NewSelectionValidationKey') });
1101
+ this.autoCompleteTextBoxControl.setErrors({
1102
+ errorMassage: this.utilityService.getResourceValue('NewSelectionValidationKey')
1103
+ });
1102
1104
  this.autoCompleteTextBoxControl.markAsTouched();
1103
1105
  this.autoCompleteTextBoxControl.invalid;
1104
1106
  return;
@@ -1107,7 +1109,9 @@ class AutocompleteTextBoxComponent {
1107
1109
  this.autoCompleteTextBoxControl.setValue(item);
1108
1110
  this.autoCompleteTextBoxControl.updateValueAndValidity();
1109
1111
  let originalValue = this.autoCompleteTextBoxControl.value;
1110
- if (this.options.patchFunction && this.options.patchPath && this.group.get(this.name).valid) {
1112
+ if (this.options.patchFunction &&
1113
+ this.options.patchPath &&
1114
+ this.group.get(this.name).valid) {
1111
1115
  this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath);
1112
1116
  }
1113
1117
  }
@@ -1116,6 +1120,15 @@ class AutocompleteTextBoxComponent {
1116
1120
  this.OnChange.emit(this.autoCompleteTextBoxControl.value);
1117
1121
  //Use this line to enable two way binding.
1118
1122
  this.options.value = this.autoCompleteTextBoxControl.value;
1123
+ if (this.options.value) {
1124
+ let displayValues = this.options.value;
1125
+ displayValues.forEach((element, index) => {
1126
+ this.options.displayValue += element.Value;
1127
+ if (index < displayValues.length - 1) {
1128
+ this.options.displayValue += ',';
1129
+ }
1130
+ });
1131
+ }
1119
1132
  }
1120
1133
  async onChangeSearch(search) {
1121
1134
  if (this.options.maxLength && search.length > this.options.maxLength) {
@@ -1702,10 +1715,18 @@ class DateInputComponent {
1702
1715
  }
1703
1716
  //#region events
1704
1717
  ngOnInit() {
1705
- this.textDir = this.options.forceDirection ? (this.options.forceDirection == ForceDirection.Arabic ? 'rtl' : 'ltr') : (localStorage.getItem('language') == 'ar' ? 'rtl' : 'ltr');
1706
- this.startView = (this.options.startView == StartView.MultiYear ? 'multi-year' : StartView[this.options.startView].toLowerCase());
1718
+ this.textDir = this.options.forceDirection
1719
+ ? this.options.forceDirection == ForceDirection.Arabic
1720
+ ? 'rtl'
1721
+ : 'ltr'
1722
+ : localStorage.getItem('language') == 'ar'
1723
+ ? 'rtl'
1724
+ : 'ltr';
1725
+ this.startView = (this.options.startView == StartView.MultiYear
1726
+ ? 'multi-year'
1727
+ : StartView[this.options.startView].toLowerCase());
1707
1728
  // Update the DateTimeAdapter Language with the current thread langauge
1708
- this.dateTimeAdapter.setLocale(this.utilityService.getCurrentLanguage() == "ar" ? "ar" : "en-UK");
1729
+ this.dateTimeAdapter.setLocale(this.utilityService.getCurrentLanguage() == 'ar' ? 'ar' : 'en-UK');
1709
1730
  this.controlValidationService.isCreatedBefor = false;
1710
1731
  this.group.addControl(this.options.name, new FormControl(''));
1711
1732
  this.datePickerFormControl = this.group.controls[this.options.name];
@@ -1719,7 +1740,7 @@ class DateInputComponent {
1719
1740
  }
1720
1741
  if (this.options.isRequired)
1721
1742
  this.validationRules.push(Validators.required);
1722
- if (this.options.labelKey != null && this.options.labelKey != "")
1743
+ if (this.options.labelKey != null && this.options.labelKey != '')
1723
1744
  this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);
1724
1745
  if (this.options.isDisabled)
1725
1746
  this.datePickerFormControl.disable();
@@ -1769,8 +1790,10 @@ class DateInputComponent {
1769
1790
  }
1770
1791
  }
1771
1792
  onDateSelect(item) {
1772
- if (!item)
1793
+ if (!item) {
1794
+ this.options.displayValue = "";
1773
1795
  return;
1796
+ }
1774
1797
  let dateValue = new Date(item.value);
1775
1798
  // var tzOffset = (new Date()).getTimezoneOffset() * 60000; //offset in milliseconds
1776
1799
  if (this.options.selectMode == SelectMode.Range) {
@@ -1786,21 +1809,24 @@ class DateInputComponent {
1786
1809
  this.datePickerFormControl.setValue(dateValue);
1787
1810
  this.onChangeService.ChangeValue(this.options.name);
1788
1811
  let originalValue = dateValue;
1789
- if (this.options.patchFunction && this.options.patchPath && this.group.get(this.options.name).valid) {
1812
+ if (this.options.patchFunction &&
1813
+ this.options.patchPath &&
1814
+ this.group.get(this.options.name).valid) {
1790
1815
  this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath);
1791
1816
  }
1792
1817
  //Use this line to enable two way binding.
1793
1818
  this.options.value = originalValue;
1794
1819
  this.onChange.emit(originalValue);
1820
+ this.options.displayValue = originalValue;
1795
1821
  }
1796
1822
  subscribeDateChanges() {
1797
1823
  const startDateChanges = this.comparedControl.valueChanges;
1798
1824
  const endDateChanges = this.group.get(this.options.name).valueChanges;
1799
- startDateChanges.subscribe(start => {
1825
+ startDateChanges.subscribe((start) => {
1800
1826
  this.comparedControl.addValidators(this.checkIfStartDateBeForEndDate);
1801
1827
  this.comparedControl.updateValueAndValidity();
1802
1828
  });
1803
- endDateChanges.subscribe(end => {
1829
+ endDateChanges.subscribe((end) => {
1804
1830
  this.datePickerFormControl.addValidators(this.checkIfEndDateAfterStartDate);
1805
1831
  this.datePickerFormControl.updateValueAndValidity();
1806
1832
  });
@@ -1899,7 +1925,7 @@ class DropdownListComponent {
1899
1925
  this.SelectedList = this.options.selectedItems;
1900
1926
  this.dropdownSettings = {
1901
1927
  singleSelection: this.options.singleSelection,
1902
- text: "Select",
1928
+ text: 'Select',
1903
1929
  selectAllText: 'Select All',
1904
1930
  unSelectAllText: 'UnSelect All',
1905
1931
  enableSearchFilter: this.options.allowSearchFilter,
@@ -1912,8 +1938,8 @@ class DropdownListComponent {
1912
1938
  showSelectedItemsAtTop: true,
1913
1939
  limitSelection: this.options.limitSelection,
1914
1940
  searchPlaceholderText: this.options.placeholder,
1915
- labelKey: "value",
1916
- primaryKey: "key"
1941
+ labelKey: 'value',
1942
+ primaryKey: 'key'
1917
1943
  };
1918
1944
  this.group.addControl(this.options.name, new FormControl(''));
1919
1945
  this.dropdownListFormControl = this.group.controls[this.options.name]; // new FormControl('',validationRules);
@@ -1929,7 +1955,7 @@ class DropdownListComponent {
1929
1955
  if (this.options.isRequired) {
1930
1956
  this.validationRules.push(Validators.required);
1931
1957
  }
1932
- if (this.options.labelKey != null && this.options.labelKey != "")
1958
+ if (this.options.labelKey != null && this.options.labelKey != '')
1933
1959
  this.options.labelValue = this.utilityService.getResourceValue(this.options.labelKey);
1934
1960
  this.dropdownListFormControl.setValidators(this.validationRules);
1935
1961
  this.dropdownListFormControl.setAsyncValidators(this.validationRulesasync);
@@ -1957,9 +1983,11 @@ class DropdownListComponent {
1957
1983
  getSelectedItemValue() {
1958
1984
  if (this.options.selectedItems) {
1959
1985
  if (this.options.singleSelection)
1960
- return this.options.dataSource.filter(item => item[this.options.itemTempletkey] == this.options.selectedItems)[0][this.options.itemTempletvalue];
1986
+ return this.options.dataSource.filter((item) => item[this.options.itemTempletkey] == this.options.selectedItems)[0][this.options.itemTempletvalue];
1961
1987
  else
1962
- return this.options.dataSource.filter(item => this.options.selectedItems.includes(item[this.options.itemTempletkey])).map(item => item[this.options.itemTempletvalue]);
1988
+ return this.options.dataSource
1989
+ .filter((item) => this.options.selectedItems.includes(item[this.options.itemTempletkey]))
1990
+ .map((item) => item[this.options.itemTempletvalue]);
1963
1991
  }
1964
1992
  else
1965
1993
  return this.utilityService.getResourceValue('NA');
@@ -1967,10 +1995,13 @@ class DropdownListComponent {
1967
1995
  onItemSelect() {
1968
1996
  this.onChangeService.ChangeValue(this.options.name);
1969
1997
  let originalValue = this.options.selectedItems;
1970
- if (this.options.patchFunction && this.options.patchPath && this.group.get(this.options.name).valid) {
1998
+ if (this.options.patchFunction &&
1999
+ this.options.patchPath &&
2000
+ this.group.get(this.options.name).valid) {
1971
2001
  this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath);
1972
2002
  }
1973
2003
  this.onChange.emit(originalValue);
2004
+ this.updateDisplayValues();
1974
2005
  //console.log(this.dropdownListFormControl.value)
1975
2006
  }
1976
2007
  Clear() {
@@ -1984,31 +2015,47 @@ class DropdownListComponent {
1984
2015
  this.DropdownTemplateVariable.open();
1985
2016
  }, 0);
1986
2017
  }
2018
+ this.updateDisplayValues();
1987
2019
  }
1988
2020
  onSelectAll(items) {
1989
2021
  this.selectedItems = items;
1990
2022
  this.dropdownListFormControl.setValue(this.selectedItems);
2023
+ this.updateDisplayValues();
1991
2024
  }
1992
2025
  onDeselect(items) {
1993
2026
  this.dropdownListFormControl.setValue(this.selectedItems);
1994
- if ((this.selectedItems.length == 0) && this.options.isRequired == true) {
2027
+ if (this.selectedItems.length == 0 && this.options.isRequired == true) {
1995
2028
  this.dropdownListFormControl.markAsTouched();
1996
2029
  this.dropdownListFormControl.invalid;
1997
2030
  }
2031
+ this.updateDisplayValues();
1998
2032
  }
1999
2033
  onDeselectAll(items) {
2000
2034
  this.dropdownListFormControl.setValue(this.selectedItems);
2001
- if ((this.selectedItems.length == 0) && this.options.isRequired == true) {
2035
+ if (this.selectedItems.length == 0 && this.options.isRequired == true) {
2002
2036
  this.dropdownListFormControl.markAsTouched();
2003
2037
  this.dropdownListFormControl.invalid;
2004
2038
  }
2039
+ this.updateDisplayValues();
2005
2040
  }
2006
2041
  onDropDownClose() {
2007
- if ((this.selectedItems == undefined || this.selectedItems.length == 0) && this.options.isRequired == true) {
2042
+ if ((this.selectedItems == undefined || this.selectedItems.length == 0) &&
2043
+ this.options.isRequired == true) {
2008
2044
  this.dropdownListFormControl.markAsTouched();
2009
2045
  this.dropdownListFormControl.invalid;
2010
2046
  }
2011
2047
  }
2048
+ updateDisplayValues() {
2049
+ this.options.displayValue = "";
2050
+ if (this.options.selectedItems) {
2051
+ this.options.selectedItems.forEach((item, index) => {
2052
+ this.options.displayValue += this.options.dataSource.find((i) => i.key == item).value;
2053
+ if (index < this.options.selectedItems.length - 1) {
2054
+ this.options.displayValue += ',';
2055
+ }
2056
+ });
2057
+ }
2058
+ }
2012
2059
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DropdownListComponent, deps: [{ token: OnPagingFiltersChangeService }, { token: ControlUtility }, { token: i2.ControlContainer, optional: true }, { token: i2.FormGroupDirective }, { token: i3.UtilityService }, { token: i3.ControlValidationService }, { token: GlobalSettings }], target: i0.ɵɵFactoryTarget.Component }); }
2013
2060
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DropdownListComponent, selector: "BBSF-DropdownList", inputs: { group: "group", options: "options", DropdownTemplateVariable: "DropdownTemplateVariable" }, outputs: { onChange: "onChange", onClear: "onClear" }, ngImport: i0, template: "<div class=\"form-group bbsf-control bbsf-dropdown\" [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\" aria-required=\"true\">*</span>\r\n </label>\r\n\r\n\r\n <div class=\"bbsf-input-container\">\r\n <!--input enabled bootstrap select-->\r\n <ng-select class=\"form-control\" *ngIf=\"options.disableBootstrapSelect==false&&!options.isReadonly\"\r\n [attr.dir]=\"options.forceDirection==2?'rtl':'auto'\" [bindValue]=\"options.itemTempletkey\" groupBy=\"group\"\r\n [bindLabel]=\"options.itemTempletvalue\" [items]=\"options.dataSource\" [notFoundText]=\"options.notFoundText\"\r\n [maxSelectedItems]=\"options.limitSelection\" [searchable]=\"options.allowSearchFilter\"\r\n [multiple]=\"!options.singleSelection\" [readonly]=\"options.isDisabled\" [clearable]=\"true\"\r\n placeholder=\"{{options.placeholder}}\" id=\"{{options.name}}\" [selectableGroup]=\"true\"\r\n [selectableGroupAsModel]=\"false\" formControlName=\"{{options.name}}\" [(ngModel)]=\"options.selectedItems\"\r\n (change)=\"onItemSelect()\" (clear)=\"Clear()\"\r\n [class.is-invalid]=\"dropdownListFormControl.invalid && dropdownListFormControl.touched\"\r\n [closeOnSelect]=\"options.singleSelection ? true : false\">\r\n <!--No checkbox, Customize item template-->\r\n <ng-template *ngIf=\"!options.showCheckbox\" ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n <label class=\"bbsf-label\" title=\"{{item.disabled ? options.disabledItemsTooltipValue : ''}}\"\r\n id={{item.key}}>{{item.value}}</label>\r\n </ng-template>\r\n <!--checkbox, Customize item template-->\r\n <ng-template *ngIf=\"options.showCheckbox\" ng-option-tmp let-item=\"item\" let-item$=\"item$\" let-index=\"index\">\r\n <div class=\" bbsf-checkbox\">\r\n <div class=\"bbsf-input-container align-items-center\">\r\n <input class=\"bbsf-checkbox-input\" id=\"item-{{index}}\" type=\"checkbox\"\r\n [ngModelOptions]=\"{standalone: true}\" [ngModel]=\"item$.selected\" />\r\n <div class=\"label-subtext-container\">\r\n <label class=\"bbsf-label\" id={{item.key}}>{{item.value}}</label>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n <!--Has group, Customize group template-->\r\n <ng-template *ngIf=\"options.hasGroup\" ng-optgroup-tmp let-item=\"item\" let-item$=\"item$\">\r\n <label class=\"bbsf-label bbsf-group-label\">{{item.group}}</label>\r\n </ng-template>\r\n\r\n </ng-select>\r\n\r\n <!--input disabled bootstrap select-->\r\n <select *ngIf=\"options.disableBootstrapSelect&&!options.isReadonly\" class=\"form-control\"\r\n [attr.dir]=\"options.forceDirection==2?'rtl':'auto'\" (change)=\"onItemSelect()\"\r\n [(ngModel)]=\"options.selectedItems\" [disabled]=\"options.isDisabled\" formControlName=\"{{options.name}}\">\r\n <option value=\"\" disabled>--{{utilityService.getResourceValue(\"select\")}}--</option>\r\n <option *ngFor=\"let item of options.dataSource\" value=\"{{item.key}}\" [ngValue]=\"item.key\">\r\n {{item.value}}\r\n </option>\r\n </select>\r\n <!-- readonly -->\r\n <div *ngIf=\"options.isReadonly\">\r\n <span class=\"readonly-view\">{{getSelectedItemValue()}}</span>\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=\"(dropdownListFormControl.invalid && dropdownListFormControl.touched)\">\r\n {{getErrorValidation(dropdownListFormControl.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 </div>\r\n</div>", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i7$1.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i7$1.NgOptgroupTemplateDirective, selector: "[ng-optgroup-tmp]" }, { kind: "directive", type: i7$1.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i7.NativeElementInjectorDirective, selector: "[ngModel], [formControl], [formControlName]" }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i5.KeyValuePipe, name: "keyvalue" }] }); }
2014
2061
  }
@@ -4766,21 +4813,23 @@ class MultiLingualTextBoxComponent {
4766
4813
  }
4767
4814
  onTextChange() {
4768
4815
  // this.trimControlValue(type)
4769
- let arabicValue = "";
4770
- let englishValue = "";
4771
- if (this.englishFormControl.value == "") {
4816
+ let arabicValue = '';
4817
+ let englishValue = '';
4818
+ if (this.englishFormControl.value == '') {
4772
4819
  this.englishWordCountArray = 0;
4773
4820
  this.englishWordCount = 0;
4774
4821
  }
4775
4822
  else {
4776
4823
  if (this.englishFormControl.value != null && this.englishFormControl.value != undefined) {
4777
- this.englishWordCountArray = this.englishFormControl.value.split(" ").length;
4824
+ this.englishWordCountArray = this.englishFormControl.value.split(' ').length;
4778
4825
  if (this.englishWordCountArray > 0) {
4779
4826
  if (this.englishWordCountArray > this.options.maxWordCount) {
4780
4827
  this.englishWordCount = this.options.maxWordCount;
4781
- this.multiLanguageGroup.controls["English"].setErrors({ MaxWordCountValidationKey: this.options.maxWordCount });
4782
- this.multiLanguageGroup.controls["English"].markAsTouched();
4783
- this.multiLanguageGroup.controls["English"].invalid;
4828
+ this.multiLanguageGroup.controls['English'].setErrors({
4829
+ MaxWordCountValidationKey: this.options.maxWordCount
4830
+ });
4831
+ this.multiLanguageGroup.controls['English'].markAsTouched();
4832
+ this.multiLanguageGroup.controls['English'].invalid;
4784
4833
  }
4785
4834
  else {
4786
4835
  this.englishWordCount = this.englishWordCountArray;
@@ -4796,9 +4845,9 @@ class MultiLingualTextBoxComponent {
4796
4845
  this.showEnglishCharsLimitMsg = true;
4797
4846
  this.hasEnglishCharsLimitValidationError = true;
4798
4847
  if (this.englishCurrentCharsCount == this.options.maxLength)
4799
- this.englishCharsLimitMsgClass = "danger";
4848
+ this.englishCharsLimitMsgClass = 'danger';
4800
4849
  else
4801
- this.englishCharsLimitMsgClass = "warning";
4850
+ this.englishCharsLimitMsgClass = 'warning';
4802
4851
  }
4803
4852
  else {
4804
4853
  this.showEnglishCharsLimitMsg = false;
@@ -4806,24 +4855,28 @@ class MultiLingualTextBoxComponent {
4806
4855
  }
4807
4856
  let max = this.options.maxLength;
4808
4857
  let current = this.englishCurrentCharsCount;
4809
- let msg = this.utilityService.getResourceValue("MaxLengthLimitWarning");
4858
+ let msg = this.utilityService.getResourceValue('MaxLengthLimitWarning');
4810
4859
  // Replace placeholders with actual values
4811
- this.englishMaxLimitWarningMsg = msg.replace("${max}", max.toString()).replace("${current}", current.toString());
4860
+ this.englishMaxLimitWarningMsg = msg
4861
+ .replace('${max}', max.toString())
4862
+ .replace('${current}', current.toString());
4812
4863
  }
4813
4864
  }
4814
- if (this.arabicFormControl.value == "") {
4865
+ if (this.arabicFormControl.value == '') {
4815
4866
  this.arabicWordCountArray = 0;
4816
4867
  this.arabicWordCount = 0;
4817
4868
  }
4818
4869
  else {
4819
4870
  if (this.arabicFormControl.value != null && this.arabicFormControl.value != undefined) {
4820
- this.arabicWordCountArray = this.arabicFormControl.value.split(" ").length;
4871
+ this.arabicWordCountArray = this.arabicFormControl.value.split(' ').length;
4821
4872
  if (this.arabicWordCountArray > 0) {
4822
4873
  if (this.arabicWordCountArray > this.options.maxWordCount) {
4823
4874
  this.arabicWordCount = this.options.maxWordCount;
4824
- this.multiLanguageGroup.controls["Arabic"].setErrors({ MaxWordCountValidationKey: this.options.maxWordCount });
4825
- this.multiLanguageGroup.controls["Arabic"].markAsTouched();
4826
- this.multiLanguageGroup.controls["Arabic"].invalid;
4875
+ this.multiLanguageGroup.controls['Arabic'].setErrors({
4876
+ MaxWordCountValidationKey: this.options.maxWordCount
4877
+ });
4878
+ this.multiLanguageGroup.controls['Arabic'].markAsTouched();
4879
+ this.multiLanguageGroup.controls['Arabic'].invalid;
4827
4880
  }
4828
4881
  else {
4829
4882
  this.arabicWordCount = this.arabicWordCountArray;
@@ -4839,9 +4892,9 @@ class MultiLingualTextBoxComponent {
4839
4892
  this.showArabicCharsLimitMsg = true;
4840
4893
  this.hasArabicCharsLimitValidationError = true;
4841
4894
  if (this.arabicCurrentCharsCount == this.options.maxLength)
4842
- this.arabicCharsLimitMsgClass = "danger";
4895
+ this.arabicCharsLimitMsgClass = 'danger';
4843
4896
  else
4844
- this.arabicCharsLimitMsgClass = "warning";
4897
+ this.arabicCharsLimitMsgClass = 'warning';
4845
4898
  }
4846
4899
  else {
4847
4900
  this.showArabicCharsLimitMsg = false;
@@ -4849,9 +4902,11 @@ class MultiLingualTextBoxComponent {
4849
4902
  }
4850
4903
  let max = this.options.maxLength;
4851
4904
  let current = this.arabicCurrentCharsCount;
4852
- let msg = this.utilityService.getResourceValue("MaxLengthLimitWarning");
4905
+ let msg = this.utilityService.getResourceValue('MaxLengthLimitWarning');
4853
4906
  // Replace placeholders with actual values
4854
- this.arabicMaxLimitWarningMsg = msg.replace("${max}", max.toString()).replace("${current}", current.toString());
4907
+ this.arabicMaxLimitWarningMsg = msg
4908
+ .replace('${max}', max.toString())
4909
+ .replace('${current}', current.toString());
4855
4910
  }
4856
4911
  }
4857
4912
  let multiLangModel = new EnglishArabicDTO();
@@ -4867,6 +4922,7 @@ class MultiLingualTextBoxComponent {
4867
4922
  this.group.markAllAsTouched();
4868
4923
  this.markAllAsTouched = true;
4869
4924
  });
4925
+ this.options.displayValue = multiLangModel;
4870
4926
  }
4871
4927
  //#region form events
4872
4928
  resetError() {
@@ -5288,6 +5344,7 @@ class TextboxComponent {
5288
5344
  this.englishLetterOnly = this.utilityService.getResourceValue('EnglishLetterOnly');
5289
5345
  }
5290
5346
  onTextChange() {
5347
+ this.options.displayValue = null;
5291
5348
  if (this.options.type == InputType.Number)
5292
5349
  if (!this.textBoxFormControl.value) {
5293
5350
  this.textBoxFormControl.setErrors({ integerNumberValidationKey: '' });
@@ -5342,6 +5399,7 @@ class TextboxComponent {
5342
5399
  }
5343
5400
  }
5344
5401
  this.onChange.emit(this.textBoxFormControl.value);
5402
+ this.options.displayValue = this.textBoxFormControl.value;
5345
5403
  }
5346
5404
  onFocus(isFocus) {
5347
5405
  this.isShowWordCount = isFocus;
@@ -5670,6 +5728,7 @@ class TagsInputComponent {
5670
5728
  }
5671
5729
  }
5672
5730
  onTagsChanged(result) {
5731
+ this.options.displayValue = "";
5673
5732
  //console.log(this.tags)
5674
5733
  if (result["change"] == "add") {
5675
5734
  this.selectedId.push(result.tag.id);
@@ -5691,6 +5750,15 @@ class TagsInputComponent {
5691
5750
  this.tagsFormControl.updateValueAndValidity();
5692
5751
  this.group.updateValueAndValidity();
5693
5752
  this.onChange.emit(originalValue);
5753
+ if (this.tags) {
5754
+ let displayValues = this.tags;
5755
+ displayValues.forEach((tag, index) => {
5756
+ this.options.displayValue += tag.name;
5757
+ if (index < displayValues.length - 1) {
5758
+ this.options.displayValue += ',';
5759
+ }
5760
+ });
5761
+ }
5694
5762
  this.checkIsTagInFilter();
5695
5763
  }
5696
5764
  onNoOptionsMatch(event) {
@@ -6666,6 +6734,7 @@ class PhoneComponent {
6666
6734
  this.controlUtility.patchControlValue(originalValue, this.options.patchFunction, this.options.patchPath);
6667
6735
  }
6668
6736
  this.onChange.emit(originalValue);
6737
+ this.options.displayValue = originalValue;
6669
6738
  }
6670
6739
  getSelectedCountry(selectedCountry) {
6671
6740
  let value = selectedCountry;
@@ -7137,6 +7206,7 @@ class RadioButtonComponent {
7137
7206
  }
7138
7207
  //Use this line to enable two way binding.
7139
7208
  this.options.value = originalValue;
7209
+ this.options.displayValue = originalValue;
7140
7210
  this.onChange.emit(originalValue);
7141
7211
  }
7142
7212
  getSelectedItemValue(value) {
@@ -7629,6 +7699,7 @@ class TextAreaComponent {
7629
7699
  .replace('${current}', current.toString());
7630
7700
  }
7631
7701
  this.onChange.emit(this.textAreaFormControl.value);
7702
+ this.options.displayValue = this.textAreaFormControl.value;
7632
7703
  }
7633
7704
  onFocus(isFocus) {
7634
7705
  this.isShowWordCount = isFocus;