@acorex/components 16.18.9 → 16.18.11

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,4 +1,4 @@
1
- import { Component, Input, Output, EventEmitter, ChangeDetectorRef, ElementRef, ChangeDetectionStrategy } from '@angular/core';
1
+ import { Component, Input, Output, EventEmitter, ChangeDetectorRef, ElementRef, ChangeDetectionStrategy, } from '@angular/core';
2
2
  import { Observable } from 'rxjs';
3
3
  import { debounceTime, distinctUntilChanged } from 'rxjs/operators';
4
4
  import { AXBaseTextComponent } from '../base/element.class';
@@ -28,7 +28,7 @@ export class AXSearchBoxComponent extends AXBaseTextComponent {
28
28
  this.textChanged.emit({
29
29
  component: this,
30
30
  value: v,
31
- oldValue: old
31
+ oldValue: old,
32
32
  });
33
33
  }
34
34
  }
@@ -37,16 +37,47 @@ export class AXSearchBoxComponent extends AXBaseTextComponent {
37
37
  this.text = '';
38
38
  }
39
39
  onSearchChanged(text) {
40
- console.log(text);
41
40
  if (this.onDemandTranslate) {
42
41
  const latinPattern = /[A-Za-z;'\/\\[\],]/;
43
42
  const asciiToPersianMap = {
44
- 113: "ض", 119: "ص", 101: "ث", 114: "ق", 116: "ف", 121: "غ", 117: "ع", 105: "ه", 111: "خ", 112: "ح",
45
- 97: "ش", 115: "س", 100: "ی", 102: "ب", 103: "ل", 104: "ا", 106: "ت", 107: "ن", 108: "م", 59: "ک",
46
- 122: "ظ", 120: "ط", 99: "ز", 118: "ر", 98: "ذ", 110: "د", 44: "و", 39: "گ", 67: "ژ", 93: "چ", 91: "ج", 92: "پ", 109: "ئ"
43
+ 113: 'ض',
44
+ 119: 'ص',
45
+ 101: 'ث',
46
+ 114: 'ق',
47
+ 116: 'ف',
48
+ 121: 'غ',
49
+ 117: 'ع',
50
+ 105: 'ه',
51
+ 111: 'خ',
52
+ 112: 'ح',
53
+ 97: 'ش',
54
+ 115: 'س',
55
+ 100: 'ی',
56
+ 102: 'ب',
57
+ 103: 'ل',
58
+ 104: 'ا',
59
+ 106: 'ت',
60
+ 107: 'ن',
61
+ 108: 'م',
62
+ 59: 'ک',
63
+ 122: 'ظ',
64
+ 120: 'ط',
65
+ 99: 'ز',
66
+ 118: 'ر',
67
+ 98: 'ذ',
68
+ 110: 'د',
69
+ 44: 'و',
70
+ 39: 'گ',
71
+ 67: 'ژ',
72
+ 93: 'چ',
73
+ 91: 'ج',
74
+ 92: 'پ',
75
+ 109: 'ئ',
47
76
  };
48
77
  if (latinPattern.test(text)) {
49
- text = text.split('').map((char) => {
78
+ text = text
79
+ .split('')
80
+ .map((char) => {
50
81
  const asciiValue = char.charCodeAt(0);
51
82
  if (asciiToPersianMap[asciiValue]) {
52
83
  return asciiToPersianMap[asciiValue];
@@ -54,16 +85,17 @@ export class AXSearchBoxComponent extends AXBaseTextComponent {
54
85
  else {
55
86
  return char;
56
87
  }
57
- }).join('');
88
+ })
89
+ .join('');
58
90
  }
59
91
  }
60
92
  if (!this.searchChangeObserver) {
61
- Observable.create(observer => {
93
+ Observable.create((observer) => {
62
94
  this.searchChangeObserver = observer;
63
95
  })
64
96
  .pipe(debounceTime(this.delay))
65
97
  .pipe(distinctUntilChanged())
66
- .subscribe(c => {
98
+ .subscribe((c) => {
67
99
  this.text = c;
68
100
  this.value = c;
69
101
  });
@@ -80,7 +112,7 @@ export class AXSearchBoxComponent extends AXBaseTextComponent {
80
112
  this.onButtonClick.emit({
81
113
  component: this,
82
114
  htmlElement: this.ref.nativeElement,
83
- value: this.text
115
+ value: this.text,
84
116
  });
85
117
  // this.searchChangeObserver.next(this.text);
86
118
  }
@@ -103,4 +135,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImpor
103
135
  }], delay: [{
104
136
  type: Input
105
137
  }] } });
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchbox.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/searchbox/searchbox.component.ts","../../../../../../libs/components/src/lib/searchbox/searchbox.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAE,UAAU,EAAE,uBAAuB,EAAa,MAAM,eAAe,CAAC;AAClJ,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAE5D,OAAO,EAAE,YAAY,EAAE,MAAM,cAAc,CAAC;;;;;AAS5C,MAAM,OAAO,oBAAqB,SAAQ,mBAAmB;IAarC;IAVf,WAAW,GAAoC,IAAI,YAAY,EAAqB,CAAC;IAE5F,aAAa,GAAoC,IAAI,YAAY,EAAqB,CAAC;IAGvF,WAAW,GAAW,YAAY,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAGxD,iBAAiB,GAAY,KAAK,CAAA;IAElC,YAAsB,GAAsB,EAAE,GAAe;QAC3D,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QADI,QAAG,GAAH,GAAG,CAAmB;IAE5C,CAAC;IAEO,KAAK,CAAS;IACtB,IACW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IACD,IAAW,IAAI,CAAC,CAAS;QACvB,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE,CAAC;YACrB,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC;YACvB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACf,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACpB,SAAS,EAAE,IAAI;gBACf,KAAK,EAAE,CAAC;gBACR,QAAQ,EAAE,GAAG;aACd,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;IACjB,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAElB,IAAI,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,MAAM,YAAY,GAAG,oBAAoB,CAAC;YAC1C,MAAM,iBAAiB,GAAG;gBACxB,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;gBAClG,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG;gBAChG,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;aACzH,CAAC;YAEF,IAAI,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;oBACjC,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;oBACtC,IAAI,iBAAiB,CAAC,UAAU,CAAC,EAAE,CAAC;wBAClC,OAAO,iBAAiB,CAAC,UAAU,CAAC,CAAC;oBACvC,CAAC;yBAAM,CAAC;wBACN,OAAO,IAAI,CAAC;oBACd,CAAC;gBACH,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACd,CAAC;QACH,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC/B,UAAU,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE;gBAC3B,IAAI,CAAC,oBAAoB,GAAG,QAAQ,CAAC;YACvC,CAAC,CAAC;iBACC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC9B,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC5B,SAAS,CAAC,CAAC,CAAC,EAAE;gBACb,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACd,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;YACjB,CAAC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAGD,KAAK,GAAW,GAAG,CAAC;IAEZ,oBAAoB,CAAM;IAElC,cAAc,CAAC,CAAgB;QAE7B,8CAA8C;QAC9C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAED,KAAK,CAAC,CAAa;QACjB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;YACtB,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,IAAI,CAAC,GAAG,CAAC,aAAa;YACnC,KAAK,EAAE,IAAI,CAAC,IAAI;SACjB,CAAC,CAAC;QACH,6CAA6C;IAC/C,CAAC;uGA9FU,oBAAoB;2FAApB,oBAAoB,4SCdjC,m4CAwBM;;2FDVO,oBAAoB;kBANhC,SAAS;+BACE,eAAe,QAEnB,EAAE,KAAK,EAAE,aAAa,EAAE,mBACb,uBAAuB,CAAC,MAAM;+GAKxC,WAAW;sBADjB,MAAM;gBAGP,aAAa;sBADZ,MAAM;gBAIP,WAAW;sBADV,KAAK;gBAIN,iBAAiB;sBADhB,KAAK;gBASK,IAAI;sBADd,KAAK;gBA2DN,KAAK;sBADJ,KAAK","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, ChangeDetectorRef, ElementRef, ChangeDetectionStrategy, ViewChild } from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { AXBaseTextComponent } from '../base/element.class';\nimport { AXBaseEvent, AXValueEvent } from '../base/events.class';\nimport { AXTranslator } from '@acorex/core';\n\n\n@Component({\n  selector: 'ax-search-box',\n  templateUrl: './searchbox.component.html',\n  host: { style: 'width: 100%' },\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AXSearchBoxComponent extends AXBaseTextComponent {\n\n  @Output()\n  public textChanged: EventEmitter<AXValueEvent<any>> = new EventEmitter<AXValueEvent<any>>();\n  @Output()\n  onButtonClick: EventEmitter<AXValueEvent<any>> = new EventEmitter<AXValueEvent<any>>();\n\n  @Input()\n  placeholder: string = AXTranslator.get('common.search');\n\n  @Input()\n  onDemandTranslate: boolean = false\n\n  constructor(protected cdr: ChangeDetectorRef, ref: ElementRef) {\n    super(cdr, ref);\n  }\n\n  private _text: string;\n  @Input()\n  public get text(): string {\n    return this._text;\n  }\n  public set text(v: string) {\n    if (v !== this._text) {\n      const old = this._text;\n      this._text = v;\n      this.textChanged.emit({\n        component: this,\n        value: v,\n        oldValue: old\n      });\n    }\n  }\n\n  ngOnInit() {\n    this.value = '';\n    this.text = '';\n  }\n\n  onSearchChanged(text: string) {\n    console.log(text);\n\n    if (this.onDemandTranslate) {\n      const latinPattern = /[A-Za-z;'\\/\\\\[\\],]/;\n      const asciiToPersianMap = {\n        113: \"ض\", 119: \"ص\", 101: \"ث\", 114: \"ق\", 116: \"ف\", 121: \"غ\", 117: \"ع\", 105: \"ه\", 111: \"خ\", 112: \"ح\",\n        97: \"ش\", 115: \"س\", 100: \"ی\", 102: \"ب\", 103: \"ل\", 104: \"ا\", 106: \"ت\", 107: \"ن\", 108: \"م\", 59: \"ک\",\n        122: \"ظ\", 120: \"ط\", 99: \"ز\", 118: \"ر\", 98: \"ذ\", 110: \"د\", 44: \"و\", 39: \"گ\", 67: \"ژ\", 93: \"چ\", 91: \"ج\", 92: \"پ\", 109: \"ئ\"\n      };\n\n      if (latinPattern.test(text)) {\n        text = text.split('').map((char) => {\n          const asciiValue = char.charCodeAt(0);\n          if (asciiToPersianMap[asciiValue]) {\n            return asciiToPersianMap[asciiValue];\n          } else {\n            return char;\n          }\n        }).join('');\n      }\n    }\n    if (!this.searchChangeObserver) {\n      Observable.create(observer => {\n        this.searchChangeObserver = observer;\n      })\n        .pipe(debounceTime(this.delay))\n        .pipe(distinctUntilChanged())\n        .subscribe(c => {\n          this.text = c;\n          this.value = c;\n        });\n    }\n\n    this.searchChangeObserver.next(text);\n  }\n\n  @Input()\n  delay: number = 500;\n\n  private searchChangeObserver: any;\n\n  handleKeyEvent(e: KeyboardEvent) {\n\n    //  this.searchChangeObserver.next(this.text);\n    this.onkey.emit(e);\n  }\n\n  click(e: MouseEvent) {\n    this.onButtonClick.emit({\n      component: this,\n      htmlElement: this.ref.nativeElement,\n      value: this.text\n    });\n    // this.searchChangeObserver.next(this.text);\n  }\n}\n","<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\">\n    <div class=\"ax items-wrapper\">\n        <ng-content select=\"[start]\">\n        </ng-content>\n        <i class=\"form-item-icon {{icon}}\" *ngIf=\"icon\"></i>\n    </div>\n    <div class=\"content\" #content>\n        <div class=\"ax input form-control {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n            [class.icon]=\"icon\">\n            <input #input type=\"text\" class=\"ax {{size}}\" [(ngModel)]=\"value\"\n                (input)=\"onSearchChanged($event.target.value)\" [placeholder]=\"placeholder\" [readonly]=\"readonly\"\n                [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\" [class.clear]=\"value && allowClear\"\n                (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\" (keyup)=\"handleKeyEvent($event)\"\n                (keydown)=\"handleKeyEvent($event)\">\n        </div>\n    </div>\n    <div class=\"ax items-wrapper\">\n        <ax-button [size]=\"size\" *ngIf=\"value && allowClear\" icon=\"far fa-times\" type=\"danger blank\" (click)=\"clear()\"  [tabIndex]=\"-1\">\n        </ax-button>\n        <ax-button [size]=\"size\" type=\"light blank\" icon=\"far fa-search\" end (click)=\"click($event)\"  [tabIndex]=\"-1\">\n        </ax-button>\n        <ng-content select=\"[end]\">\n        </ng-content>\n    </div>\n</div>"]}
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchbox.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/searchbox/searchbox.component.ts","../../../../../../libs/components/src/lib/searchbox/searchbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ChangeDetectorRef,\n  ElementRef,\n  ChangeDetectionStrategy,\n  ViewChild,\n} from '@angular/core';\nimport { Observable } from 'rxjs';\nimport { debounceTime, distinctUntilChanged } from 'rxjs/operators';\nimport { AXBaseTextComponent } from '../base/element.class';\nimport { AXBaseEvent, AXValueEvent } from '../base/events.class';\nimport { AXTranslator } from '@acorex/core';\n\n@Component({\n  selector: 'ax-search-box',\n  templateUrl: './searchbox.component.html',\n  host: { style: 'width: 100%' },\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXSearchBoxComponent extends AXBaseTextComponent {\n  @Output()\n  public textChanged: EventEmitter<AXValueEvent<any>> = new EventEmitter<\n    AXValueEvent<any>\n  >();\n  @Output()\n  onButtonClick: EventEmitter<AXValueEvent<any>> = new EventEmitter<\n    AXValueEvent<any>\n  >();\n\n  @Input()\n  placeholder: string = AXTranslator.get('common.search');\n\n  @Input()\n  onDemandTranslate: boolean = false;\n\n  constructor(protected cdr: ChangeDetectorRef, ref: ElementRef) {\n    super(cdr, ref);\n  }\n\n  private _text: string;\n  @Input()\n  public get text(): string {\n    return this._text;\n  }\n  public set text(v: string) {\n    if (v !== this._text) {\n      const old = this._text;\n      this._text = v;\n      this.textChanged.emit({\n        component: this,\n        value: v,\n        oldValue: old,\n      });\n    }\n  }\n\n  ngOnInit() {\n    this.value = '';\n    this.text = '';\n  }\n\n  onSearchChanged(text: string) {\n    if (this.onDemandTranslate) {\n      const latinPattern = /[A-Za-z;'\\/\\\\[\\],]/;\n      const asciiToPersianMap = {\n        113: 'ض',\n        119: 'ص',\n        101: 'ث',\n        114: 'ق',\n        116: 'ف',\n        121: 'غ',\n        117: 'ع',\n        105: 'ه',\n        111: 'خ',\n        112: 'ح',\n        97: 'ش',\n        115: 'س',\n        100: 'ی',\n        102: 'ب',\n        103: 'ل',\n        104: 'ا',\n        106: 'ت',\n        107: 'ن',\n        108: 'م',\n        59: 'ک',\n        122: 'ظ',\n        120: 'ط',\n        99: 'ز',\n        118: 'ر',\n        98: 'ذ',\n        110: 'د',\n        44: 'و',\n        39: 'گ',\n        67: 'ژ',\n        93: 'چ',\n        91: 'ج',\n        92: 'پ',\n        109: 'ئ',\n      };\n\n      if (latinPattern.test(text)) {\n        text = text\n          .split('')\n          .map((char) => {\n            const asciiValue = char.charCodeAt(0);\n            if (asciiToPersianMap[asciiValue]) {\n              return asciiToPersianMap[asciiValue];\n            } else {\n              return char;\n            }\n          })\n          .join('');\n      }\n    }\n    if (!this.searchChangeObserver) {\n      Observable.create((observer) => {\n        this.searchChangeObserver = observer;\n      })\n        .pipe(debounceTime(this.delay))\n        .pipe(distinctUntilChanged())\n        .subscribe((c) => {\n          this.text = c;\n          this.value = c;\n        });\n    }\n\n    this.searchChangeObserver.next(text);\n  }\n\n  @Input()\n  delay: number = 500;\n\n  private searchChangeObserver: any;\n\n  handleKeyEvent(e: KeyboardEvent) {\n    //  this.searchChangeObserver.next(this.text);\n    this.onkey.emit(e);\n  }\n\n  click(e: MouseEvent) {\n    this.onButtonClick.emit({\n      component: this,\n      htmlElement: this.ref.nativeElement,\n      value: this.text,\n    });\n    // this.searchChangeObserver.next(this.text);\n  }\n}\n","<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\">\n    <div class=\"ax items-wrapper\">\n        <ng-content select=\"[start]\">\n        </ng-content>\n        <i class=\"form-item-icon {{icon}}\" *ngIf=\"icon\"></i>\n    </div>\n    <div class=\"content\" #content>\n        <div class=\"ax input form-control {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n            [class.icon]=\"icon\">\n            <input #input type=\"text\" class=\"ax {{size}}\" [(ngModel)]=\"value\"\n                (input)=\"onSearchChanged($event.target.value)\" [placeholder]=\"placeholder\" [readonly]=\"readonly\"\n                [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\" [class.clear]=\"value && allowClear\"\n                (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\" (keyup)=\"handleKeyEvent($event)\"\n                (keydown)=\"handleKeyEvent($event)\">\n        </div>\n    </div>\n    <div class=\"ax items-wrapper\">\n        <ax-button [size]=\"size\" *ngIf=\"value && allowClear\" icon=\"far fa-times\" type=\"danger blank\" (click)=\"clear()\"  [tabIndex]=\"-1\">\n        </ax-button>\n        <ax-button [size]=\"size\" type=\"light blank\" icon=\"far fa-search\" end (click)=\"click($event)\"  [tabIndex]=\"-1\">\n        </ax-button>\n        <ng-content select=\"[end]\">\n        </ng-content>\n    </div>\n</div>"]}
@@ -52,7 +52,6 @@ export class AXSelectionListComponent extends AXValidatableComponent {
52
52
  if (!this.disabled) {
53
53
  if (this.mode === 'single') {
54
54
  this.selectedValues = [value[this.valueField]];
55
- this.selectedItemsChange.emit(this.selectedItems);
56
55
  }
57
56
  else {
58
57
  if (checked) {
@@ -62,17 +61,18 @@ export class AXSelectionListComponent extends AXValidatableComponent {
62
61
  ...[value[this.valueField]],
63
62
  ];
64
63
  }
65
- this.selectedItemsChange.emit(this.selectedItems);
66
64
  }
67
65
  else {
68
66
  this.selectedValues = this.selectedValues.filter((c) => c !== value[this.valueField]);
69
67
  }
70
68
  }
69
+ this.selectedItemsChange.emit(this.selectedItems);
71
70
  }
72
71
  }
73
72
  focus() { }
74
73
  onvalueChanged(e) {
75
74
  if (!this.disabled) {
75
+ this.selectedItems = [e];
76
76
  this.selectedItemsChange.emit([e]);
77
77
  }
78
78
  }
@@ -117,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImpor
117
117
  }], selectedValues: [{
118
118
  type: Input
119
119
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/selection-list/selection-list.component.ts","../../../../../../libs/components/src/lib/selection-list/selection-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXSelectionList } from '@acorex/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AXBaseComponent,\n  AXBaseSizableComponent,\n  AXElementSize,\n  AXValidatableComponent,\n} from '../base/element.class';\n\n@Component({\n  selector: 'ax-selection-list',\n  templateUrl: './selection-list.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXSelectionListComponent\n  extends AXValidatableComponent\n  implements AXBaseSizableComponent, AXBaseComponent\n{\n  private _selectedItems: any[] = [];\n\n  @Input()\n  readonly: boolean;\n\n  @Input()\n  value: boolean;\n\n  @Input()\n  disabled: boolean;\n\n  @Input()\n  size: AXElementSize = 'md';\n\n  @Input()\n  direction: string = 'horizontal';\n\n  @Input()\n  items: Array<AXSelectionList> = [];\n\n  @Input()\n  mode: string = 'single';\n\n  @Input()\n  textField: string = 'text';\n\n  @Input()\n  valueField: string = 'value';\n\n  @Output()\n  selectionChanged: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  selectedItemsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  @Input()\n  public get selectedItems(): any[] {\n    return this._selectedItems || [];\n  }\n  public set selectedItems(v: any[]) {\n    this._selectedItems = v;\n    this.cdr.detectChanges();\n  }\n\n  @Output()\n  selectedValuesChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  @Input()\n  public get selectedValues(): any[] {\n    return this._selectedItems.map((c) => c[this.valueField]) || [];\n  }\n  public set selectedValues(v: any[]) {\n    const old = this.selectedValues;\n    if (v == null) {\n      v = [];\n    }\n    if (JSON.stringify(old) != JSON.stringify(v)) {\n      this.selectedItems = this.items.filter((c) =>\n        v.includes(c[this.valueField])\n      );\n      this.selectedValuesChange.emit(this.selectedValues);\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.selectedItems?.length && this.mode === 'single') {\n      this.selectedItemsChange.emit(this.selectedItems);\n    }\n    this.cdr.detectChanges();\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  onCheckValueChange(value: any, checked: boolean) {\n    if (!this.disabled) {\n      if (this.mode === 'single') {\n        this.selectedValues = [value[this.valueField]];\n        this.selectedItemsChange.emit(this.selectedItems);\n      } else {\n        if (checked) {\n          if (!this.selectedValues.includes(value[this.valueField])) {\n            this.selectedValues = [\n              ...this.selectedValues,\n              ...[value[this.valueField]],\n            ];\n          }\n          this.selectedItemsChange.emit(this.selectedItems);\n        } else {\n          this.selectedValues = this.selectedValues.filter(\n            (c) => c !== value[this.valueField]\n          );\n        }\n      }\n    }\n  }\n  focus(): void {}\n\n  onvalueChanged(e) {\n    if (!this.disabled) {\n      this.selectedItemsChange.emit([e]);\n    }\n  }\n\n  checkBoxClick(e, data) {\n    this.selectionChanged.emit({\n      valueField: data[this.valueField],\n      value: e.value,\n    });\n  }\n}\n","<ng-container\n  *ngIf=\"mode == 'multiple'; then checkboxList; else radioButtonList\"\n></ng-container>\n<ng-template #checkboxList>\n  <div\n    class=\"ax selection-list {{ size }}\"\n    style=\"flex-wrap: wrap; gap: 4px\"\n    [ngClass]=\"direction\"\n  >\n    <ax-check-box\n      label=\"{{ item[textField] }}\"\n      *ngFor=\"let item of items\"\n      [disabled]=\"item.disable || disabled\"\n      [readonly]=\"item.readonly || readonly\"\n      [value]=\"selectedValues.indexOf(item[valueField]) > -1\"\n      (onValueChanged)=\"onCheckValueChange(item, $event.value)\"\n      (onClick)=\"checkBoxClick($event, item)\"\n    >\n    </ax-check-box>\n  </div>\n</ng-template>\n<ng-template #radioButtonList>\n  <div\n    style=\"flex-wrap: wrap; gap: 4px\"\n    class=\"ax selection-list {{ size }}\"\n    [ngClass]=\"direction\"\n  >\n    <label\n      class=\"ax radio\"\n      for=\"{{ uid }}\"\n      [class.disabled]=\"disabled\"\n      [class.readonly]=\"readonly\"\n      *ngFor=\"let item of items\"\n      (click)=\"onvalueChanged(item)\"\n    >\n      {{ item[textField] }}\n      <input\n        type=\"radio\"\n        (change)=\"onCheckValueChange(item[valueField], true)\"\n        [value]=\"item[valueField]\"\n        [checked]=\"selectedValues == item[valueField]\"\n        [name]=\"uid\"\n        [disabled]=\"item.disable || disabled\"\n        [readonly]=\"item.readonly || readonly\"\n      />\n      <span class=\"checkmark\"></span>\n    </label>\n  </div>\n</ng-template>\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/selection-list/selection-list.component.ts","../../../../../../libs/components/src/lib/selection-list/selection-list.component.html"],"names":[],"mappings":"AACA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAIL,sBAAsB,GACvB,MAAM,uBAAuB,CAAC;;;;AAQ/B,MAAM,OAAO,wBACX,SAAQ,sBAAsB;IA0EV;IAvEZ,cAAc,GAAU,EAAE,CAAC;IAGnC,QAAQ,CAAU;IAGlB,KAAK,CAAU;IAGf,QAAQ,CAAU;IAGlB,IAAI,GAAkB,IAAI,CAAC;IAG3B,SAAS,GAAW,YAAY,CAAC;IAGjC,KAAK,GAA2B,EAAE,CAAC;IAGnC,IAAI,GAAW,QAAQ,CAAC;IAGxB,SAAS,GAAW,MAAM,CAAC;IAG3B,UAAU,GAAW,OAAO,CAAC;IAG7B,gBAAgB,GAAsB,IAAI,YAAY,EAAO,CAAC;IAG9D,mBAAmB,GAAwB,IAAI,YAAY,EAAS,CAAC;IAErE,IACW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;IACnC,CAAC;IACD,IAAW,aAAa,CAAC,CAAQ;QAC/B,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAGD,oBAAoB,GAAwB,IAAI,YAAY,EAAS,CAAC;IAEtE,IACW,cAAc;QACvB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAAC;IAClE,CAAC;IACD,IAAW,cAAc,CAAC,CAAQ;QAChC,MAAM,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC;QAChC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;YACd,CAAC,GAAG,EAAE,CAAC;QACT,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAC3C,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAC/B,CAAC;YACF,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YACzD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACpD,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,YAAoB,GAAsB;QACxC,KAAK,EAAE,CAAC;QADU,QAAG,GAAH,GAAG,CAAmB;IAE1C,CAAC;IAED,kBAAkB,CAAC,KAAU,EAAE,OAAgB;QAC7C,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;gBAC3B,IAAI,CAAC,cAAc,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACjD,CAAC;iBAAM,CAAC;gBACN,IAAI,OAAO,EAAE,CAAC;oBACZ,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC;wBAC1D,IAAI,CAAC,cAAc,GAAG;4BACpB,GAAG,IAAI,CAAC,cAAc;4BACtB,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;yBAC5B,CAAC;oBACJ,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAC9C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CACpC,CAAC;gBACJ,CAAC;YACH,CAAC;YACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACpD,CAAC;IACH,CAAC;IACD,KAAK,KAAU,CAAC;IAEhB,cAAc,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;IAED,aAAa,CAAC,CAAC,EAAE,IAAI;QACnB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;YACzB,UAAU,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;YACjC,KAAK,EAAE,CAAC,CAAC,KAAK;SACf,CAAC,CAAC;IACL,CAAC;uGAlHU,wBAAwB;2FAAxB,wBAAwB,6dCvBrC,q+CAiDA;;2FD1Ba,wBAAwB;kBANpC,SAAS;+BACE,mBAAmB,iBAEd,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM;sFAS/C,QAAQ;sBADP,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,gBAAgB;sBADf,MAAM;gBAIP,mBAAmB;sBADlB,MAAM;gBAII,aAAa;sBADvB,KAAK;gBAUN,oBAAoB;sBADnB,MAAM;gBAII,cAAc;sBADxB,KAAK","sourcesContent":["import { AXSelectionList } from '@acorex/core';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AXBaseComponent,\n  AXBaseSizableComponent,\n  AXElementSize,\n  AXValidatableComponent,\n} from '../base/element.class';\n\n@Component({\n  selector: 'ax-selection-list',\n  templateUrl: './selection-list.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXSelectionListComponent\n  extends AXValidatableComponent\n  implements AXBaseSizableComponent, AXBaseComponent\n{\n  private _selectedItems: any[] = [];\n\n  @Input()\n  readonly: boolean;\n\n  @Input()\n  value: boolean;\n\n  @Input()\n  disabled: boolean;\n\n  @Input()\n  size: AXElementSize = 'md';\n\n  @Input()\n  direction: string = 'horizontal';\n\n  @Input()\n  items: Array<AXSelectionList> = [];\n\n  @Input()\n  mode: string = 'single';\n\n  @Input()\n  textField: string = 'text';\n\n  @Input()\n  valueField: string = 'value';\n\n  @Output()\n  selectionChanged: EventEmitter<any> = new EventEmitter<any>();\n\n  @Output()\n  selectedItemsChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  @Input()\n  public get selectedItems(): any[] {\n    return this._selectedItems || [];\n  }\n  public set selectedItems(v: any[]) {\n    this._selectedItems = v;\n    this.cdr.detectChanges();\n  }\n\n  @Output()\n  selectedValuesChange: EventEmitter<any[]> = new EventEmitter<any[]>();\n\n  @Input()\n  public get selectedValues(): any[] {\n    return this._selectedItems.map((c) => c[this.valueField]) || [];\n  }\n  public set selectedValues(v: any[]) {\n    const old = this.selectedValues;\n    if (v == null) {\n      v = [];\n    }\n    if (JSON.stringify(old) != JSON.stringify(v)) {\n      this.selectedItems = this.items.filter((c) =>\n        v.includes(c[this.valueField])\n      );\n      this.selectedValuesChange.emit(this.selectedValues);\n    }\n  }\n\n  ngAfterViewInit(): void {\n    if (this.selectedItems?.length && this.mode === 'single') {\n      this.selectedItemsChange.emit(this.selectedItems);\n    }\n    this.cdr.detectChanges();\n  }\n\n  constructor(private cdr: ChangeDetectorRef) {\n    super();\n  }\n\n  onCheckValueChange(value: any, checked: boolean) {\n    if (!this.disabled) {\n      if (this.mode === 'single') {\n        this.selectedValues = [value[this.valueField]];\n      } else {\n        if (checked) {\n          if (!this.selectedValues.includes(value[this.valueField])) {\n            this.selectedValues = [\n              ...this.selectedValues,\n              ...[value[this.valueField]],\n            ];\n          }\n        } else {\n          this.selectedValues = this.selectedValues.filter(\n            (c) => c !== value[this.valueField]\n          );\n        }\n      }\n      this.selectedItemsChange.emit(this.selectedItems);\n    }\n  }\n  focus(): void {}\n\n  onvalueChanged(e) {\n    if (!this.disabled) {\n      this.selectedItems = [e];\n      this.selectedItemsChange.emit([e]);\n    }\n  }\n\n  checkBoxClick(e, data) {\n    this.selectionChanged.emit({\n      valueField: data[this.valueField],\n      value: e.value,\n    });\n  }\n}\n","<ng-container\n  *ngIf=\"mode == 'multiple'; then checkboxList; else radioButtonList\"\n></ng-container>\n<ng-template #checkboxList>\n  <div\n    class=\"ax selection-list {{ size }}\"\n    style=\"flex-wrap: wrap; gap: 4px\"\n    [ngClass]=\"direction\"\n  >\n    <ax-check-box\n      label=\"{{ item[textField] }}\"\n      *ngFor=\"let item of items\"\n      [disabled]=\"item.disable || disabled\"\n      [readonly]=\"item.readonly || readonly\"\n      [value]=\"selectedValues.indexOf(item[valueField]) > -1\"\n      (onValueChanged)=\"onCheckValueChange(item, $event.value)\"\n      (onClick)=\"checkBoxClick($event, item)\"\n    >\n    </ax-check-box>\n  </div>\n</ng-template>\n<ng-template #radioButtonList>\n  <div\n    style=\"flex-wrap: wrap; gap: 4px\"\n    class=\"ax selection-list {{ size }}\"\n    [ngClass]=\"direction\"\n  >\n    <label\n      class=\"ax radio\"\n      for=\"{{ uid }}\"\n      [class.disabled]=\"disabled\"\n      [class.readonly]=\"readonly\"\n      *ngFor=\"let item of items\"\n      (click)=\"onvalueChanged(item)\"\n    >\n      {{ item[textField] }}\n      <input\n        type=\"radio\"\n        (change)=\"onCheckValueChange(item[valueField], true)\"\n        [value]=\"item[valueField]\"\n        [checked]=\"selectedValues == item[valueField]\"\n        [name]=\"uid\"\n        [disabled]=\"item.disable || disabled\"\n        [readonly]=\"item.readonly || readonly\"\n      />\n      <span class=\"checkmark\"></span>\n    </label>\n  </div>\n</ng-template>\n"]}
@@ -3757,7 +3757,6 @@ class AXSelectionListComponent extends AXValidatableComponent {
3757
3757
  if (!this.disabled) {
3758
3758
  if (this.mode === 'single') {
3759
3759
  this.selectedValues = [value[this.valueField]];
3760
- this.selectedItemsChange.emit(this.selectedItems);
3761
3760
  }
3762
3761
  else {
3763
3762
  if (checked) {
@@ -3767,17 +3766,18 @@ class AXSelectionListComponent extends AXValidatableComponent {
3767
3766
  ...[value[this.valueField]],
3768
3767
  ];
3769
3768
  }
3770
- this.selectedItemsChange.emit(this.selectedItems);
3771
3769
  }
3772
3770
  else {
3773
3771
  this.selectedValues = this.selectedValues.filter((c) => c !== value[this.valueField]);
3774
3772
  }
3775
3773
  }
3774
+ this.selectedItemsChange.emit(this.selectedItems);
3776
3775
  }
3777
3776
  }
3778
3777
  focus() { }
3779
3778
  onvalueChanged(e) {
3780
3779
  if (!this.disabled) {
3780
+ this.selectedItems = [e];
3781
3781
  this.selectedItemsChange.emit([e]);
3782
3782
  }
3783
3783
  }
@@ -8420,7 +8420,7 @@ class AXSearchBoxComponent extends AXBaseTextComponent {
8420
8420
  this.textChanged.emit({
8421
8421
  component: this,
8422
8422
  value: v,
8423
- oldValue: old
8423
+ oldValue: old,
8424
8424
  });
8425
8425
  }
8426
8426
  }
@@ -8429,16 +8429,47 @@ class AXSearchBoxComponent extends AXBaseTextComponent {
8429
8429
  this.text = '';
8430
8430
  }
8431
8431
  onSearchChanged(text) {
8432
- console.log(text);
8433
8432
  if (this.onDemandTranslate) {
8434
8433
  const latinPattern = /[A-Za-z;'\/\\[\],]/;
8435
8434
  const asciiToPersianMap = {
8436
- 113: "ض", 119: "ص", 101: "ث", 114: "ق", 116: "ف", 121: "غ", 117: "ع", 105: "ه", 111: "خ", 112: "ح",
8437
- 97: "ش", 115: "س", 100: "ی", 102: "ب", 103: "ل", 104: "ا", 106: "ت", 107: "ن", 108: "م", 59: "ک",
8438
- 122: "ظ", 120: "ط", 99: "ز", 118: "ر", 98: "ذ", 110: "د", 44: "و", 39: "گ", 67: "ژ", 93: "چ", 91: "ج", 92: "پ", 109: "ئ"
8435
+ 113: 'ض',
8436
+ 119: 'ص',
8437
+ 101: 'ث',
8438
+ 114: 'ق',
8439
+ 116: 'ف',
8440
+ 121: 'غ',
8441
+ 117: 'ع',
8442
+ 105: 'ه',
8443
+ 111: 'خ',
8444
+ 112: 'ح',
8445
+ 97: 'ش',
8446
+ 115: 'س',
8447
+ 100: 'ی',
8448
+ 102: 'ب',
8449
+ 103: 'ل',
8450
+ 104: 'ا',
8451
+ 106: 'ت',
8452
+ 107: 'ن',
8453
+ 108: 'م',
8454
+ 59: 'ک',
8455
+ 122: 'ظ',
8456
+ 120: 'ط',
8457
+ 99: 'ز',
8458
+ 118: 'ر',
8459
+ 98: 'ذ',
8460
+ 110: 'د',
8461
+ 44: 'و',
8462
+ 39: 'گ',
8463
+ 67: 'ژ',
8464
+ 93: 'چ',
8465
+ 91: 'ج',
8466
+ 92: 'پ',
8467
+ 109: 'ئ',
8439
8468
  };
8440
8469
  if (latinPattern.test(text)) {
8441
- text = text.split('').map((char) => {
8470
+ text = text
8471
+ .split('')
8472
+ .map((char) => {
8442
8473
  const asciiValue = char.charCodeAt(0);
8443
8474
  if (asciiToPersianMap[asciiValue]) {
8444
8475
  return asciiToPersianMap[asciiValue];
@@ -8446,16 +8477,17 @@ class AXSearchBoxComponent extends AXBaseTextComponent {
8446
8477
  else {
8447
8478
  return char;
8448
8479
  }
8449
- }).join('');
8480
+ })
8481
+ .join('');
8450
8482
  }
8451
8483
  }
8452
8484
  if (!this.searchChangeObserver) {
8453
- Observable.create(observer => {
8485
+ Observable.create((observer) => {
8454
8486
  this.searchChangeObserver = observer;
8455
8487
  })
8456
8488
  .pipe(debounceTime(this.delay))
8457
8489
  .pipe(distinctUntilChanged())
8458
- .subscribe(c => {
8490
+ .subscribe((c) => {
8459
8491
  this.text = c;
8460
8492
  this.value = c;
8461
8493
  });
@@ -8472,7 +8504,7 @@ class AXSearchBoxComponent extends AXBaseTextComponent {
8472
8504
  this.onButtonClick.emit({
8473
8505
  component: this,
8474
8506
  htmlElement: this.ref.nativeElement,
8475
- value: this.text
8507
+ value: this.text,
8476
8508
  });
8477
8509
  // this.searchChangeObserver.next(this.text);
8478
8510
  }