@acorex/components 16.18.10 → 16.18.12

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.
@@ -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,18 +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
- this.selectedItemsChange.emit(this.selectedItems);
70
67
  }
71
68
  }
69
+ this.selectedItemsChange.emit(this.selectedItems);
72
70
  }
73
71
  }
74
72
  focus() { }
75
73
  onvalueChanged(e) {
76
74
  if (!this.disabled) {
75
+ this.selectedItems = [e];
77
76
  this.selectedItemsChange.emit([e]);
78
77
  }
79
78
  }
@@ -118,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImpor
118
117
  }], selectedValues: [{
119
118
  type: Input
120
119
  }] } });
121
- //# 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          this.selectedItemsChange.emit(this.selectedItems);\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":"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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      } 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"]}
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { ElementRef, Component, Inject, Optional, Input, Injectable, EventEmitter, Output, Directive, ViewChild, ContentChild, TemplateRef, ViewEncapsulation, HostListener, NgModule, ChangeDetectionStrategy, Attribute, ContentChildren, ViewChildren, NO_ERRORS_SCHEMA, ViewContainerRef, HostBinding } from '@angular/core';
2
+ import { ElementRef, Component, Inject, Optional, Input, Injectable, EventEmitter, Output, Directive, ViewChild, ContentChild, TemplateRef, ViewEncapsulation, HostListener, NgModule, ChangeDetectionStrategy, Attribute, ContentChildren, ViewChildren, NO_ERRORS_SCHEMA, ViewContainerRef, HostBinding, input } from '@angular/core';
3
3
  import * as i1$2 from '@acorex/core';
4
4
  import { AXTranslator, AXHtmlUtil, AXConfig, AXDateTime, AXDateTimeRange, AXCoreModule, AXTranslatorModule, AXObjectUtil, AXScrollModule, setPropByPath, AXColorUtil } from '@acorex/core';
5
5
  import * as i1 from '@angular/cdk/overlay';
@@ -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,18 +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
- this.selectedItemsChange.emit(this.selectedItems);
3775
3772
  }
3776
3773
  }
3774
+ this.selectedItemsChange.emit(this.selectedItems);
3777
3775
  }
3778
3776
  }
3779
3777
  focus() { }
3780
3778
  onvalueChanged(e) {
3781
3779
  if (!this.disabled) {
3780
+ this.selectedItems = [e];
3782
3781
  this.selectedItemsChange.emit([e]);
3783
3782
  }
3784
3783
  }
@@ -7585,7 +7584,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7585
7584
  cdr;
7586
7585
  min = null;
7587
7586
  max = null;
7588
- showSeparator = false;
7587
+ showSeparator = input(false);
7589
7588
  showCurrency = false;
7590
7589
  showCounter = true;
7591
7590
  scrollWeel = true;
@@ -7615,7 +7614,9 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7615
7614
  this._values = '-';
7616
7615
  }
7617
7616
  else {
7618
- if (v === '' || v == null || v === undefined ? true : isNaN(Number(v.toString().replace(/,/g, ''))) === false) {
7617
+ if (v === '' || v == null || v === undefined
7618
+ ? true
7619
+ : isNaN(Number(v.toString().replace(/,/g, ''))) === false) {
7619
7620
  if (v === '' || v == null || v === undefined) {
7620
7621
  this.textValue = '';
7621
7622
  const old = this._values;
@@ -7626,7 +7627,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7626
7627
  isUserChange: this.userEdite,
7627
7628
  component: this,
7628
7629
  value: null,
7629
- oldValue: this.showSeparator && old
7630
+ oldValue: this.showSeparator() && old
7630
7631
  ? old === '-'
7631
7632
  ? null
7632
7633
  : Number(old.replace(/,/g, ''))
@@ -7635,7 +7636,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7635
7636
  : old === '-'
7636
7637
  ? null
7637
7638
  : Number(old),
7638
- htmlElement: this.ref.nativeElement
7639
+ htmlElement: this.ref.nativeElement,
7639
7640
  });
7640
7641
  this.userEdite = false;
7641
7642
  this.cdr.detectChanges();
@@ -7645,7 +7646,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7645
7646
  else {
7646
7647
  v = v.toString();
7647
7648
  // this.addCommas(v.toString());
7648
- this.textValue = this.showSeparator && v ? this.addCommas(v.toString()) : v;
7649
+ this.textValue =
7650
+ this.showSeparator() && v ? this.addCommas(v.toString()) : v;
7649
7651
  // if (this.textValue.indexOf('.') !== -1) {
7650
7652
  // // const dottt= (this.textValue.length-1) - this.textValue.indexOf('.')
7651
7653
  // if (this.textValue.length - 1 - this.textValue.indexOf('.') < this.decimalNumber) {
@@ -7668,12 +7670,16 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7668
7670
  if (v !== this._values) {
7669
7671
  const old = this._values;
7670
7672
  this._values = v;
7671
- this.valueChange.emit(this.showSeparator && v ? Number(v.replace(/,/g, '')) : Number(v));
7673
+ this.valueChange.emit(this.showSeparator() && v
7674
+ ? Number(v.replace(/,/g, ''))
7675
+ : Number(v));
7672
7676
  this.onValueChanged.emit({
7673
7677
  isUserChange: this.userEdite,
7674
7678
  component: this,
7675
- value: this.showSeparator && v ? Number(v.replace(/,/g, '')) : Number(v),
7676
- oldValue: this.showSeparator && old
7679
+ value: this.showSeparator() && v
7680
+ ? Number(v.replace(/,/g, ''))
7681
+ : Number(v),
7682
+ oldValue: this.showSeparator() && old
7677
7683
  ? old === '-'
7678
7684
  ? null
7679
7685
  : Number(old.replace(/,/g, ''))
@@ -7682,7 +7688,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7682
7688
  : old === '-'
7683
7689
  ? null
7684
7690
  : Number(old),
7685
- htmlElement: this.ref.nativeElement
7691
+ htmlElement: this.ref.nativeElement,
7686
7692
  });
7687
7693
  this.userEdite = false;
7688
7694
  this.cdr.detectChanges();
@@ -7701,7 +7707,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7701
7707
  isUserChange: this.userEdite,
7702
7708
  component: this,
7703
7709
  value: null,
7704
- oldValue: this.showSeparator && old
7710
+ oldValue: this.showSeparator() && old
7705
7711
  ? old === '-'
7706
7712
  ? null
7707
7713
  : Number(old.replace(/,/g, ''))
@@ -7710,7 +7716,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7710
7716
  : old === '-'
7711
7717
  ? null
7712
7718
  : Number(old),
7713
- htmlElement: this.ref.nativeElement
7719
+ htmlElement: this.ref.nativeElement,
7714
7720
  });
7715
7721
  this.userEdite = false;
7716
7722
  this.cdr.detectChanges();
@@ -7725,7 +7731,7 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7725
7731
  this.textAlign = 'left';
7726
7732
  }
7727
7733
  calcSeparator(num) {
7728
- if (this.showSeparator) {
7734
+ if (this.showSeparator()) {
7729
7735
  return num + +(num / 3);
7730
7736
  }
7731
7737
  else {
@@ -7794,7 +7800,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7794
7800
  this.findMinus = false;
7795
7801
  }
7796
7802
  // get cursur position when key press
7797
- if (this.input.nativeElement.selectionStart || this.input.nativeElement.selectionStart === 0) {
7803
+ if (this.input.nativeElement.selectionStart ||
7804
+ this.input.nativeElement.selectionStart === 0) {
7798
7805
  this.cursorPosition = this.input.nativeElement.selectionStart;
7799
7806
  this.cursorPosition += 1;
7800
7807
  }
@@ -7823,7 +7830,9 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7823
7830
  if (this.value && this.value.toString().match(/\./g)) {
7824
7831
  const figureAfterDot = this.value.length - this.value.indexOf('.');
7825
7832
  const dotIndex = this.value.indexOf('.');
7826
- if (dotIndex - 1 + dotIndex + figureAfterDot > dotIndex - 1 + dotIndex + this.decimalNumber && this.cursorPosition - 1 > dotIndex) {
7833
+ if (dotIndex - 1 + dotIndex + figureAfterDot >
7834
+ dotIndex - 1 + dotIndex + this.decimalNumber &&
7835
+ this.cursorPosition - 1 > dotIndex) {
7827
7836
  event.preventDefault();
7828
7837
  }
7829
7838
  }
@@ -7859,7 +7868,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7859
7868
  }
7860
7869
  // left & right Button
7861
7870
  if (event.key === 'ArrowLeft' || event.key === 'ArrowRight') {
7862
- if (this.input.nativeElement.selectionStart || this.input.nativeElement.selectionStart === 0) {
7871
+ if (this.input.nativeElement.selectionStart ||
7872
+ this.input.nativeElement.selectionStart === 0) {
7863
7873
  this.cursorPosition = this.input.nativeElement.selectionStart;
7864
7874
  }
7865
7875
  }
@@ -7891,9 +7901,13 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7891
7901
  }
7892
7902
  if (this.readonly === false) {
7893
7903
  const countAfterDot = this.value !== null && this.value !== '' && this.value !== undefined
7894
- ? this.value.toString().length - 1 - this.value.toString().indexOf('.')
7904
+ ? this.value.toString().length -
7905
+ 1 -
7906
+ this.value.toString().indexOf('.')
7895
7907
  : 0;
7896
- const defaultStep = countAfterDot > this.decimalNumber ? Math.pow(this.decimalConstant, this.decimalNumber) : Math.pow(this.decimalConstant, countAfterDot);
7908
+ const defaultStep = countAfterDot > this.decimalNumber
7909
+ ? Math.pow(this.decimalConstant, this.decimalNumber)
7910
+ : Math.pow(this.decimalConstant, countAfterDot);
7897
7911
  // step and +- with up key and down key
7898
7912
  if (this.value && this.value.toString().match(/\./g)) {
7899
7913
  this.dotPosition = this.value.indexOf('.');
@@ -7903,14 +7917,18 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7903
7917
  this.count = this.tmp - +this.intStep;
7904
7918
  if (this.min === null || Number(this.count) >= Number(this.min)) {
7905
7919
  // this.value = this.count.toFixed(this.decimalNumber);
7906
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7920
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7921
+ ? this.decimalNumber
7922
+ : countAfterDot);
7907
7923
  }
7908
7924
  }
7909
7925
  if (event.key === 'ArrowUp') {
7910
7926
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
7911
7927
  this.count = this.tmp + +this.intStep;
7912
7928
  if (this.max === null || Number(this.count) <= Number(this.max)) {
7913
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7929
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7930
+ ? this.decimalNumber
7931
+ : countAfterDot);
7914
7932
  }
7915
7933
  }
7916
7934
  }
@@ -7920,16 +7938,26 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7920
7938
  if (this.customStep !== null) {
7921
7939
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
7922
7940
  this.lastStep =
7923
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) +
7924
- parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) -
7925
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot));
7941
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
7942
+ ? this.decimalNumber
7943
+ : countAfterDot)) +
7944
+ parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber
7945
+ ? this.decimalNumber
7946
+ : countAfterDot)) -
7947
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
7948
+ ? this.decimalNumber
7949
+ : countAfterDot));
7926
7950
  this.count = parseFloat(this.tmp) - this.lastStep;
7927
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7951
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7952
+ ? this.decimalNumber
7953
+ : countAfterDot);
7928
7954
  }
7929
7955
  else {
7930
7956
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
7931
7957
  this.count = parseFloat(this.tmp) - defaultStep;
7932
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7958
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7959
+ ? this.decimalNumber
7960
+ : countAfterDot);
7933
7961
  }
7934
7962
  }
7935
7963
  }
@@ -7938,16 +7966,26 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7938
7966
  if (this.customStep !== null) {
7939
7967
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
7940
7968
  this.lastStep =
7941
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) +
7942
- parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) -
7943
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot));
7969
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
7970
+ ? this.decimalNumber
7971
+ : countAfterDot)) +
7972
+ parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber
7973
+ ? this.decimalNumber
7974
+ : countAfterDot)) -
7975
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
7976
+ ? this.decimalNumber
7977
+ : countAfterDot));
7944
7978
  this.count = parseFloat(this.tmp) + this.lastStep;
7945
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7979
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7980
+ ? this.decimalNumber
7981
+ : countAfterDot);
7946
7982
  }
7947
7983
  else {
7948
7984
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
7949
7985
  this.count = parseFloat(this.tmp) + defaultStep;
7950
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
7986
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
7987
+ ? this.decimalNumber
7988
+ : countAfterDot);
7951
7989
  }
7952
7990
  }
7953
7991
  }
@@ -7959,7 +7997,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7959
7997
  this.value = this.min.toString();
7960
7998
  }
7961
7999
  else {
7962
- if (this.min === null || Number(this.value) > parseInt(this.min.toString())) {
8000
+ if (this.min === null ||
8001
+ Number(this.value) > parseInt(this.min.toString())) {
7963
8002
  if (this.value == null) {
7964
8003
  this.value = '0';
7965
8004
  }
@@ -7976,7 +8015,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7976
8015
  this.value = this.min.toString();
7977
8016
  }
7978
8017
  else {
7979
- if (this.max === null || Number(this.value) < parseInt(this.max.toString())) {
8018
+ if (this.max === null ||
8019
+ Number(this.value) < parseInt(this.max.toString())) {
7980
8020
  if (this.value == null) {
7981
8021
  this.value = '0';
7982
8022
  }
@@ -7999,7 +8039,8 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
7999
8039
  }
8000
8040
  }
8001
8041
  handleClick() {
8002
- if (this.input.nativeElement.selectionStart || this.input.nativeElement.selectionStart === 0) {
8042
+ if (this.input.nativeElement.selectionStart ||
8043
+ this.input.nativeElement.selectionStart === 0) {
8003
8044
  this.cursorPosition = this.input.nativeElement.selectionStart;
8004
8045
  }
8005
8046
  }
@@ -8007,7 +8048,9 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8007
8048
  Observable.create((observer) => {
8008
8049
  this.userQuestionUpdate = observer;
8009
8050
  });
8010
- this.userQuestionUpdate.pipe(debounceTime(1000), distinctUntilChanged()).subscribe((text) => this.checkMinMax(text));
8051
+ this.userQuestionUpdate
8052
+ .pipe(debounceTime(1000), distinctUntilChanged())
8053
+ .subscribe((text) => this.checkMinMax(text));
8011
8054
  // this.userQuestionUpdate.next((e.target as any).value);
8012
8055
  setTimeout(() => {
8013
8056
  this.userQuestionUpdate.next(this.input.nativeElement.value);
@@ -8063,20 +8106,26 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8063
8106
  else {
8064
8107
  if (this.readonly === false) {
8065
8108
  const countAfterDot = this.value !== null && this.value !== '' && this.value !== undefined
8066
- ? this.value.toString().length - 1 - this.value.toString().indexOf('.')
8109
+ ? this.value.toString().length -
8110
+ 1 -
8111
+ this.value.toString().indexOf('.')
8067
8112
  : 0;
8068
8113
  if (this.value == null) {
8069
8114
  this.value = '0';
8070
8115
  }
8071
8116
  else {
8072
- const defaultStep = countAfterDot > this.decimalNumber ? Math.pow(this.decimalConstant, this.decimalNumber) : Math.pow(this.decimalConstant, countAfterDot);
8117
+ const defaultStep = countAfterDot > this.decimalNumber
8118
+ ? Math.pow(this.decimalConstant, this.decimalNumber)
8119
+ : Math.pow(this.decimalConstant, countAfterDot);
8073
8120
  this.dotPosition = this.value.toString().indexOf('.') + 1;
8074
8121
  if (this.value && this.value.toString().match(/\./g)) {
8075
8122
  if (this.dotPosition > this.cursorPosition) {
8076
8123
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8077
8124
  this.count = this.tmp + +this.intStep;
8078
8125
  if (this.max === null || Number(this.count) <= this.max) {
8079
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
8126
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
8127
+ ? this.decimalNumber
8128
+ : countAfterDot);
8080
8129
  }
8081
8130
  }
8082
8131
  else {
@@ -8084,22 +8133,37 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8084
8133
  if (this.customStep !== null) {
8085
8134
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8086
8135
  this.lastStep =
8087
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) +
8088
- parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) -
8089
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot));
8136
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
8137
+ ? this.decimalNumber
8138
+ : countAfterDot)) +
8139
+ parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber
8140
+ ? this.decimalNumber
8141
+ : countAfterDot)) -
8142
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
8143
+ ? this.decimalNumber
8144
+ : countAfterDot));
8090
8145
  this.count = parseFloat(this.tmp) + this.lastStep;
8091
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot).replace(/,/g, '');
8146
+ this.value = this.count
8147
+ .toFixed(countAfterDot > this.decimalNumber
8148
+ ? this.decimalNumber
8149
+ : countAfterDot)
8150
+ .replace(/,/g, '');
8092
8151
  }
8093
8152
  else {
8094
8153
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8095
8154
  this.count = parseFloat(this.tmp) + defaultStep;
8096
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot).replace(/,/g, '');
8155
+ this.value = this.count
8156
+ .toFixed(countAfterDot > this.decimalNumber
8157
+ ? this.decimalNumber
8158
+ : countAfterDot)
8159
+ .replace(/,/g, '');
8097
8160
  }
8098
8161
  }
8099
8162
  }
8100
8163
  }
8101
8164
  else {
8102
- if (this.max === null || Number(this.value) < parseInt(this.max.toString())) {
8165
+ if (this.max === null ||
8166
+ Number(this.value) < parseInt(this.max.toString())) {
8103
8167
  this.tmp = this.value.toString().replace(/,/g, '');
8104
8168
  this.count = +this.tmp + +this.intStep;
8105
8169
  this.value = this.count.toString().replace(/,/g, '');
@@ -8117,20 +8181,29 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8117
8181
  else {
8118
8182
  if (this.readonly === false) {
8119
8183
  const countAfterDot = this.value !== null && this.value !== '' && this.value !== undefined
8120
- ? this.value.toString().length - 1 - this.value.toString().indexOf('.')
8184
+ ? this.value.toString().length -
8185
+ 1 -
8186
+ this.value.toString().indexOf('.')
8121
8187
  : 0;
8122
8188
  if (this.value == null) {
8123
8189
  this.value = '0';
8124
8190
  }
8125
8191
  else {
8126
- const defaultStep = countAfterDot > this.decimalNumber ? Math.pow(this.decimalConstant, this.decimalNumber) : Math.pow(this.decimalConstant, countAfterDot);
8192
+ const defaultStep = countAfterDot > this.decimalNumber
8193
+ ? Math.pow(this.decimalConstant, this.decimalNumber)
8194
+ : Math.pow(this.decimalConstant, countAfterDot);
8127
8195
  this.dotPosition = this.value.toString().indexOf('.') + 1;
8128
8196
  if (this.value && this.value.toString().match(/\./g)) {
8129
8197
  if (this.dotPosition > this.cursorPosition) {
8130
8198
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8131
- this.count = parseFloat(this.value.replace(/,/g, '')) - +this.intStep;
8199
+ this.count =
8200
+ parseFloat(this.value.replace(/,/g, '')) - +this.intStep;
8132
8201
  if (this.min === null || Number(this.count) >= this.min) {
8133
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot).replace(/,/g, '');
8202
+ this.value = this.count
8203
+ .toFixed(countAfterDot > this.decimalNumber
8204
+ ? this.decimalNumber
8205
+ : countAfterDot)
8206
+ .replace(/,/g, '');
8134
8207
  }
8135
8208
  }
8136
8209
  else {
@@ -8138,22 +8211,33 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8138
8211
  if (this.customStep !== null) {
8139
8212
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8140
8213
  this.lastStep =
8141
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) +
8142
- parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot)) -
8143
- parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot));
8214
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
8215
+ ? this.decimalNumber
8216
+ : countAfterDot)) +
8217
+ parseFloat(this.customStep.toFixed(countAfterDot > this.decimalNumber
8218
+ ? this.decimalNumber
8219
+ : countAfterDot)) -
8220
+ parseFloat(defaultStep.toFixed(countAfterDot > this.decimalNumber
8221
+ ? this.decimalNumber
8222
+ : countAfterDot));
8144
8223
  this.count = parseFloat(this.tmp) - this.lastStep;
8145
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
8224
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
8225
+ ? this.decimalNumber
8226
+ : countAfterDot);
8146
8227
  }
8147
8228
  else {
8148
8229
  this.tmp = parseFloat(this.value.replace(/,/g, ''));
8149
8230
  this.count = parseFloat(this.tmp) - defaultStep;
8150
- this.value = this.count.toFixed(countAfterDot > this.decimalNumber ? this.decimalNumber : countAfterDot);
8231
+ this.value = this.count.toFixed(countAfterDot > this.decimalNumber
8232
+ ? this.decimalNumber
8233
+ : countAfterDot);
8151
8234
  }
8152
8235
  }
8153
8236
  }
8154
8237
  }
8155
8238
  else {
8156
- if (this.min === null || Number(this.value) > parseInt(this.min.toString())) {
8239
+ if (this.min === null ||
8240
+ Number(this.value) > parseInt(this.min.toString())) {
8157
8241
  this.tmp = +this.value.toString().replace(/,/g, '');
8158
8242
  this.count = +this.tmp - +this.intStep;
8159
8243
  this.value = this.count.toString().replace(/,/g, '');
@@ -8168,21 +8252,23 @@ class AXNumberBoxComponent extends AXBaseTextComponent {
8168
8252
  this.onBlur.emit({
8169
8253
  component: this,
8170
8254
  htmlElement: this.ref.nativeElement,
8171
- htmlEvent: e
8255
+ htmlEvent: e,
8172
8256
  });
8173
8257
  }
8174
8258
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: AXNumberBoxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
8175
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.7", type: AXNumberBoxComponent, selector: "ax-number-box", inputs: { min: "min", max: "max", showSeparator: "showSeparator", showCurrency: "showCurrency", showCounter: "showCounter", scrollWeel: "scrollWeel", showDoubleCounter: "showDoubleCounter", maxLength: "maxLength", intStep: "intStep", decimalNumber: "decimalNumber", customStep: "customStep" }, host: { styleAttribute: "width: 100%" }, providers: [{ provide: AXValidatableComponent, useExisting: AXNumberBoxComponent }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\" #fc>\n <div class=\"ax items-wrapper\">\n <ng-content select=\"[start]\">\n </ng-content>\n <ax-button icon=\"far fa-plus\" type=\"success blank\" (click)=\"upStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n </div>\n <div class=\"content\" #content>\n <div class=\"ax form-control input {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n [class.icon]=\"icon\">\n <input [autocomplete]=\"autocomplete\" [name]=\"name\" #input type=\"text\" class=\"ax {{size}}\" [maxlength]=\"calcSeparator(maxLength)\" [(ngModel)]=\"textValue\" placeholder=\"{{placeholder}}\"\n [readonly]=\"readonly\" [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\"\n [class.clear]=\"value && allowClear\" (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\"\n (keypress)=\"handleKeyPress($event)\" (ngModelChange)=\"this.userQuestionUpdate.next($event)\"\n (keydown)=\"handleKeyDown($event)\" (click)=\"handleClick()\" (keyup)=\"handleKeyUp($event)\">\n <i class=\"{{icon}}\" *ngIf=\"icon\"></i>\n </div>\n </div>\n <div class=\"ax items-wrapper\">\n <ax-button *ngIf=\"value && allowClear\" [disabled]=\"disabled\" icon=\"far fa-times\" type=\"danger blank\"\n (click)=\"clear()\"></ax-button>\n <ax-button icon=\"far fa-minus\" type=\"danger blank\" (click)=\"downStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n <div class=\"arrow-number\" *ngIf=\"showCounter && !showDoubleCounter && !readonly\" >\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-up\" [size]=\"size\"\n (mousedown)=\"upStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-down\" [size]=\"size\"\n (mousedown)=\"downStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n </div>\n </div>\n\n</div>\n", dependencies: [{ kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "directive", type: i2$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
8259
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.7", type: AXNumberBoxComponent, selector: "ax-number-box", inputs: { min: { classPropertyName: "min", publicName: "min", isSignal: false, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: false, isRequired: false, transformFunction: null }, showSeparator: { classPropertyName: "showSeparator", publicName: "showSeparator", isSignal: true, isRequired: false, transformFunction: null }, showCurrency: { classPropertyName: "showCurrency", publicName: "showCurrency", isSignal: false, isRequired: false, transformFunction: null }, showCounter: { classPropertyName: "showCounter", publicName: "showCounter", isSignal: false, isRequired: false, transformFunction: null }, scrollWeel: { classPropertyName: "scrollWeel", publicName: "scrollWeel", isSignal: false, isRequired: false, transformFunction: null }, showDoubleCounter: { classPropertyName: "showDoubleCounter", publicName: "showDoubleCounter", isSignal: false, isRequired: false, transformFunction: null }, maxLength: { classPropertyName: "maxLength", publicName: "maxLength", isSignal: false, isRequired: false, transformFunction: null }, intStep: { classPropertyName: "intStep", publicName: "intStep", isSignal: false, isRequired: false, transformFunction: null }, decimalNumber: { classPropertyName: "decimalNumber", publicName: "decimalNumber", isSignal: false, isRequired: false, transformFunction: null }, customStep: { classPropertyName: "customStep", publicName: "customStep", isSignal: false, isRequired: false, transformFunction: null } }, host: { styleAttribute: "width: 100%" }, providers: [
8260
+ { provide: AXValidatableComponent, useExisting: AXNumberBoxComponent },
8261
+ ], usesInheritance: true, ngImport: i0, template: "<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\" #fc>\n <div class=\"ax items-wrapper\">\n <ng-content select=\"[start]\">\n </ng-content>\n <ax-button icon=\"far fa-plus\" type=\"success blank\" (click)=\"upStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n </div>\n <div class=\"content\" #content>\n <div class=\"ax form-control input {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n [class.icon]=\"icon\">\n <input [autocomplete]=\"autocomplete\" [name]=\"name\" #input type=\"text\" class=\"ax {{size}}\" [maxlength]=\"calcSeparator(maxLength)\" [(ngModel)]=\"textValue\" placeholder=\"{{placeholder}}\"\n [readonly]=\"readonly\" [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\"\n [class.clear]=\"value && allowClear\" (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\"\n (keypress)=\"handleKeyPress($event)\" (ngModelChange)=\"this.userQuestionUpdate.next($event)\"\n (keydown)=\"handleKeyDown($event)\" (click)=\"handleClick()\" (keyup)=\"handleKeyUp($event)\">\n <i class=\"{{icon}}\" *ngIf=\"icon\"></i>\n </div>\n </div>\n <div class=\"ax items-wrapper\">\n <ax-button *ngIf=\"value && allowClear\" [disabled]=\"disabled\" icon=\"far fa-times\" type=\"danger blank\"\n (click)=\"clear()\"></ax-button>\n <ax-button icon=\"far fa-minus\" type=\"danger blank\" (click)=\"downStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n <div class=\"arrow-number\" *ngIf=\"showCounter && !showDoubleCounter && !readonly\" >\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-up\" [size]=\"size\"\n (mousedown)=\"upStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-down\" [size]=\"size\"\n (mousedown)=\"downStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n </div>\n </div>\n\n</div>\n", dependencies: [{ kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "directive", type: i2$2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
8176
8262
  }
8177
8263
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.7", ngImport: i0, type: AXNumberBoxComponent, decorators: [{
8178
8264
  type: Component,
8179
- args: [{ selector: 'ax-number-box', changeDetection: ChangeDetectionStrategy.OnPush, host: { style: 'width: 100%' }, providers: [{ provide: AXValidatableComponent, useExisting: AXNumberBoxComponent }], template: "<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\" #fc>\n <div class=\"ax items-wrapper\">\n <ng-content select=\"[start]\">\n </ng-content>\n <ax-button icon=\"far fa-plus\" type=\"success blank\" (click)=\"upStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n </div>\n <div class=\"content\" #content>\n <div class=\"ax form-control input {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n [class.icon]=\"icon\">\n <input [autocomplete]=\"autocomplete\" [name]=\"name\" #input type=\"text\" class=\"ax {{size}}\" [maxlength]=\"calcSeparator(maxLength)\" [(ngModel)]=\"textValue\" placeholder=\"{{placeholder}}\"\n [readonly]=\"readonly\" [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\"\n [class.clear]=\"value && allowClear\" (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\"\n (keypress)=\"handleKeyPress($event)\" (ngModelChange)=\"this.userQuestionUpdate.next($event)\"\n (keydown)=\"handleKeyDown($event)\" (click)=\"handleClick()\" (keyup)=\"handleKeyUp($event)\">\n <i class=\"{{icon}}\" *ngIf=\"icon\"></i>\n </div>\n </div>\n <div class=\"ax items-wrapper\">\n <ax-button *ngIf=\"value && allowClear\" [disabled]=\"disabled\" icon=\"far fa-times\" type=\"danger blank\"\n (click)=\"clear()\"></ax-button>\n <ax-button icon=\"far fa-minus\" type=\"danger blank\" (click)=\"downStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n <div class=\"arrow-number\" *ngIf=\"showCounter && !showDoubleCounter && !readonly\" >\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-up\" [size]=\"size\"\n (mousedown)=\"upStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-down\" [size]=\"size\"\n (mousedown)=\"downStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n </div>\n </div>\n\n</div>\n" }]
8265
+ args: [{ selector: 'ax-number-box', changeDetection: ChangeDetectionStrategy.OnPush, host: { style: 'width: 100%' }, providers: [
8266
+ { provide: AXValidatableComponent, useExisting: AXNumberBoxComponent },
8267
+ ], template: "<div class=\"ax form-item\" [class.disabled]=\"disabled\" [attr.id]=\"uid\" #fc>\n <div class=\"ax items-wrapper\">\n <ng-content select=\"[start]\">\n </ng-content>\n <ax-button icon=\"far fa-plus\" type=\"success blank\" (click)=\"upStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n </div>\n <div class=\"content\" #content>\n <div class=\"ax form-control input {{size}}\" [class.disabled]=\"disabled\" [class.readonly]=\"readonly\"\n [class.icon]=\"icon\">\n <input [autocomplete]=\"autocomplete\" [name]=\"name\" #input type=\"text\" class=\"ax {{size}}\" [maxlength]=\"calcSeparator(maxLength)\" [(ngModel)]=\"textValue\" placeholder=\"{{placeholder}}\"\n [readonly]=\"readonly\" [disabled]=\"disabled\" [ngClass]=\"setTextAlign()\"\n [class.clear]=\"value && allowClear\" (focus)=\"handleInputFocus($event)\" (blur)=\"handleInputBlur($event)\"\n (keypress)=\"handleKeyPress($event)\" (ngModelChange)=\"this.userQuestionUpdate.next($event)\"\n (keydown)=\"handleKeyDown($event)\" (click)=\"handleClick()\" (keyup)=\"handleKeyUp($event)\">\n <i class=\"{{icon}}\" *ngIf=\"icon\"></i>\n </div>\n </div>\n <div class=\"ax items-wrapper\">\n <ax-button *ngIf=\"value && allowClear\" [disabled]=\"disabled\" icon=\"far fa-times\" type=\"danger blank\"\n (click)=\"clear()\"></ax-button>\n <ax-button icon=\"far fa-minus\" type=\"danger blank\" (click)=\"downStepHandel()\" [disabled]=\"disabled\" *ngIf=\"showDoubleCounter\"></ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n <div class=\"arrow-number\" *ngIf=\"showCounter && !showDoubleCounter && !readonly\" >\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-up\" [size]=\"size\"\n (mousedown)=\"upStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n <ax-button type=\"light blank\" [disabled]=\"disabled\" icon=\"fas fa-angle-down\" [size]=\"size\"\n (mousedown)=\"downStepHandel()\" (mouseup)=\"delaySearch()\" [tabIndex]=\"-1\"></ax-button>\n </div>\n </div>\n\n</div>\n" }]
8180
8268
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }], propDecorators: { min: [{
8181
8269
  type: Input
8182
8270
  }], max: [{
8183
8271
  type: Input
8184
- }], showSeparator: [{
8185
- type: Input
8186
8272
  }], showCurrency: [{
8187
8273
  type: Input
8188
8274
  }], showCounter: [{