@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.
- package/esm2022/lib/number-box/number-box.component.mjs +147 -60
- package/esm2022/lib/selection-list/selection-list.component.mjs +3 -4
- package/fesm2022/acorex-components.mjs +147 -61
- package/fesm2022/acorex-components.mjs.map +1 -1
- package/lib/number-box/number-box.component.d.ts +2 -2
- package/package.json +1 -1
@@ -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":"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;gBAC/C,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACpD,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;oBACD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACpD,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;oBACF,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACpD,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC;IACD,KAAK,KAAU,CAAC;IAEhB,cAAc,CAAC,CAAC;QACd,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,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;uGAnHU,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        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
|
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 =
|
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
|
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
|
7676
|
-
|
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 ||
|
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 >
|
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 ||
|
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 -
|
7904
|
+
? this.value.toString().length -
|
7905
|
+
1 -
|
7906
|
+
this.value.toString().indexOf('.')
|
7895
7907
|
: 0;
|
7896
|
-
const defaultStep = countAfterDot > this.decimalNumber
|
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
|
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
|
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
|
7924
|
-
|
7925
|
-
|
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
|
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
|
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
|
7942
|
-
|
7943
|
-
|
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
|
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
|
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 ||
|
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 ||
|
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 ||
|
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
|
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 -
|
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
|
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
|
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
|
8088
|
-
|
8089
|
-
|
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
|
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
|
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 ||
|
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 -
|
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
|
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 =
|
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
|
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
|
8142
|
-
|
8143
|
-
|
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
|
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
|
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 ||
|
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: "
|
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: [
|
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: [{
|